'use client'; import { ReactNode, useContext } from 'react'; import WebsitesTable from 'app/(main)/settings/websites/WebsitesTable'; import useApi from 'components/hooks/useApi'; import DataTable from 'components/common/DataTable'; import useFilterQuery from 'components/hooks/useFilterQuery'; import useCache from 'store/cache'; import SettingsContext from '../SettingsContext'; export interface WebsitesDataTableProps { userId: string; allowEdit?: boolean; allowView?: boolean; showActions?: boolean; showTeam?: boolean; includeTeams?: boolean; onlyTeams?: boolean; children?: ReactNode; } export function WebsitesDataTable({ userId, allowEdit = true, allowView = true, showActions = true, showTeam, includeTeams, onlyTeams, children, }: WebsitesDataTableProps) { const { get } = useApi(); const modified = useCache((state: any) => state?.websites); const { websitesUrl } = useContext(SettingsContext); const queryResult = useFilterQuery({ queryKey: ['websites', { includeTeams, onlyTeams, modified }], queryFn: (params: any) => { return get(websitesUrl, { includeTeams, onlyTeams, ...params, }); }, enabled: !!userId, }); return ( {({ data }) => ( {children} )} ); } export default WebsitesDataTable;