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';
|
2023-08-21 09:06:09 +00:00
|
|
|
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-10-04 08:46:00 +00:00
|
|
|
const queryResult = useFilterQuery(
|
2023-10-08 07:15:29 +00:00
|
|
|
['team:websites', { teamId, modified }],
|
2023-10-01 23:11:12 +00:00
|
|
|
params => {
|
|
|
|
|
return get(`/teams/${teamId}/websites`, {
|
|
|
|
|
...params,
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
{ enabled: !!user },
|
2023-01-25 15:42:46 +00:00
|
|
|
);
|
|
|
|
|
|
2023-10-04 08:46:00 +00:00
|
|
|
const handleChange = () => {
|
|
|
|
|
queryResult.refetch();
|
2023-03-09 20:42:12 +00:00
|
|
|
};
|
|
|
|
|
|
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;
|