umami/src/app/(main)/settings/teams/[id]/TeamWebsites.js

53 lines
1.7 KiB
JavaScript
Raw Normal View History

2023-10-01 23:11:12 +00:00
import { ActionForm, Button, Icon, Icons, Modal, ModalTrigger, Text } from 'react-basics';
2023-09-29 12:29:22 +00:00
import TeamWebsitesTable from './TeamWebsitesTable';
2023-10-08 01:55:14 +00:00
import TeamWebsiteAddForm from './TeamWebsiteAddForm';
import useApi from 'components/hooks/useApi';
import useMessages from 'components/hooks/useMessages';
2023-10-01 23:11:12 +00:00
import useUser from 'components/hooks/useUser';
import useFilterQuery from 'components/hooks/useFilterQuery';
import DataTable from 'components/common/DataTable';
2023-10-08 07:15:29 +00:00
import useCache from 'store/cache';
2023-01-25 15:42:46 +00:00
2023-04-21 15:00:42 +00:00
export function TeamWebsites({ teamId }) {
2023-03-22 21:05:55 +00:00
const { formatMessage, labels, messages } = useMessages();
2023-10-01 23:11:12 +00:00
const { user } = useUser();
const { get } = useApi();
2023-10-08 07:15:29 +00:00
const modified = useCache(state => state?.['team:websites']);
2023-12-02 04:27:59 +00:00
const queryResult = useFilterQuery({
queryKey: ['team:websites', { teamId, modified }],
queryFn: params => {
2023-10-01 23:11:12 +00:00
return get(`/teams/${teamId}/websites`, {
...params,
});
},
2023-12-02 04:27:59 +00:00
enabled: !!user,
});
2023-01-25 15:42:46 +00:00
2023-10-04 08:46:00 +00:00
const handleChange = () => {
queryResult.refetch();
};
2023-01-25 15:42:46 +00:00
return (
2023-10-01 23:11:12 +00:00
<>
<ActionForm description={formatMessage(messages.teamWebsitesInfo)}>
<ModalTrigger>
<Button variant="primary">
<Icon>
<Icons.Plus />
</Icon>
<Text>{formatMessage(labels.addWebsite)}</Text>
</Button>
<Modal title={formatMessage(labels.addWebsite)}>
2023-10-08 01:55:14 +00:00
{close => <TeamWebsiteAddForm teamId={teamId} onSave={handleChange} onClose={close} />}
2023-10-01 23:11:12 +00:00
</Modal>
</ModalTrigger>
</ActionForm>
2023-10-04 08:46:00 +00:00
<DataTable queryResult={queryResult}>
{({ data }) => <TeamWebsitesTable data={data} onRemove={handleChange} />}
</DataTable>
2023-10-01 23:11:12 +00:00
</>
2023-01-25 15:42:46 +00:00
);
}
2023-04-21 15:00:42 +00:00
export default TeamWebsites;