Skip to content

Commit

Permalink
Merge branch 'feature/III-6364' of https://github.com/cultuurnet/udb3…
Browse files Browse the repository at this point in the history
…-frontend into feature/III-6364
  • Loading branch information
vhande committed Nov 22, 2024
2 parents a0d7e68 + ea99c39 commit 161b049
Show file tree
Hide file tree
Showing 6 changed files with 188 additions and 47 deletions.
38 changes: 38 additions & 0 deletions src/hooks/api/ownerships.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,11 @@ export type OwnershipRequest = {
state: RequestState;
};

export type OwnershipCreator = {
userId: string;
email: string;
};

export const RequestState = {
APPROVED: 'approved',
REQUESTED: 'requested',
Expand Down Expand Up @@ -131,9 +136,42 @@ const useDeleteOwnershipRequestMutation = (configuration = {}) =>
...configuration,
});

const getOwnershipCreator = async ({ headers, organizerId }) => {
const res = await fetchFromApi({
path: `/organizers/${organizerId}/creator`,
options: {
headers,
},
});
if (isErrorObject(res)) {
// eslint-disable-next-line no-console
return console.error(res);
}
return await res.json();
};

type UseGetOwnershipCreatorArguments = ServerSideQueryOptions & {
organizerId: string;
};

const useGetOwnershipCreatorQuery = (
{ req, queryClient, organizerId }: UseGetOwnershipCreatorArguments,
configuration: UseQueryOptions = {},
) =>
useAuthenticatedQuery<OwnershipCreator>({
req,
queryClient,
queryKey: ['ownership-creator'],
queryFn: getOwnershipCreator,
queryArguments: { organizerId },
refetchOnWindowFocus: false,
...configuration,
});

export {
useApproveOwnershipRequestMutation,
useDeleteOwnershipRequestMutation,
useGetOwnershipCreatorQuery,
useGetOwnershipRequestsQuery,
useRejectOwnershipRequestMutation,
useRequestOwnershipMutation,
Expand Down
4 changes: 2 additions & 2 deletions src/pages/CityPicker.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { City, useGetCitiesByQuery } from '@/hooks/api/cities';
import { Countries, Country } from '@/types/Country';
import { FormElement } from '@/ui/FormElement';
import { getStackProps, Stack, StackProps } from '@/ui/Stack';
import { Typeahead } from '@/ui/Typeahead';
import { Typeahead, TypeaheadElement } from '@/ui/Typeahead';
import { valueToArray } from '@/utils/valueToArray';

import { SupportedLanguages } from '../i18n';
Expand All @@ -20,7 +20,7 @@ type Props = Omit<StackProps, 'onChange'> & {
error?: string;
};

const CityPicker = forwardRef<HTMLInputElement, Props>(
const CityPicker = forwardRef<TypeaheadElement<City>, Props>(
(
{ offerId, country, name, value, onChange, onBlur, error, ...props },
ref,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,20 +1,25 @@
import { useTranslation } from 'react-i18next';

import { OwnershipRequest } from '@/hooks/api/ownerships';
import { OwnershipCreator, OwnershipRequest } from '@/hooks/api/ownerships';
import { Inline } from '@/ui/Inline';
import { List } from '@/ui/List';
import { Stack } from '@/ui/Stack';
import { colors, getValueFromTheme } from '@/ui/theme';
import { Title } from '@/ui/Title';

type Props = {
creator?: OwnershipCreator;
requests: OwnershipRequest[];
renderActions: (request: OwnershipRequest) => JSX.Element;
};

const getGlobalValue = getValueFromTheme('global');

export const OwnershipsTable = ({ requests, renderActions }: Props) => {
export const OwnershipsTable = ({
creator,
requests,
renderActions,
}: Props) => {
const { grey3 } = colors;
const { t } = useTranslation();
return (
Expand All @@ -38,13 +43,13 @@ export const OwnershipsTable = ({ requests, renderActions }: Props) => {
<Title size={3}>{t('organizers.ownerships.table.user')}</Title>
<Title size={3}>{t('organizers.ownerships.table.actions.title')}</Title>
</Inline>
<List>
<List paddingY={3}>
<List.Item>{creator.email}</List.Item>
{requests.map((request) => (
<Inline
key={request.id}
justifyContent="space-between"
alignItems="center"
paddingY={3}
css={`
&:not(:last-child) {
border-bottom: 1px solid ${grey3};
Expand Down
91 changes: 54 additions & 37 deletions src/pages/organizers/[organizerId]/ownerships/index.page.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import {
RequestState,
useApproveOwnershipRequestMutation,
useDeleteOwnershipRequestMutation,
useGetOwnershipCreatorQuery,
useGetOwnershipRequestsQuery,
useRejectOwnershipRequestMutation,
} from '@/hooks/api/ownerships';
Expand Down Expand Up @@ -60,12 +61,17 @@ const Ownership = () => {
const organizer: Organizer = getOrganizerByIdQuery?.data;
const organizerName =
organizer?.name?.[i18n.language] ??
organizer?.name?.[organizer.mainLanguage];
organizer?.name?.[organizer.mainLanguage] ??
organizer?.name;

const getOwnershipRequestsQuery = useGetOwnershipRequestsQuery({
organizerId: organizerId,
});

const getOwnershipCreatorQuery = useGetOwnershipCreatorQuery({
organizerId: organizerId,
});

const requestsByState: { [key: string]: OwnershipRequest[] } = useMemo(
() =>
groupBy(
Expand All @@ -77,6 +83,9 @@ const Ownership = () => {
[getOwnershipRequestsQuery.data],
);

// @ts-expect-error
const creator = getOwnershipCreatorQuery.data;

const approvedRequests = requestsByState[RequestState.APPROVED] ?? [];
const pendingRequests = requestsByState[RequestState.REQUESTED] ?? [];

Expand Down Expand Up @@ -148,42 +157,45 @@ const Ownership = () => {
/>
</Alert>
)}
<Stack spacing={4}>
<Title size={3}>{t('organizers.ownerships.owners')}</Title>
<OwnershipsTable
requests={approvedRequests}
renderActions={(request) => (
<Button
variant={ButtonVariants.ICON}
iconName={Icons.TRASH}
onClick={() => setRequestToBeDeleted(request)}
/>
)}
/>
<Modal
title={t('organizers.ownerships.delete_modal.title')}
confirmTitle={t('organizers.ownerships.delete_modal.confirm')}
cancelTitle={t('organizers.ownerships.delete_modal.cancel')}
visible={!!requestToBeDeleted}
variant={ModalVariants.QUESTION}
onConfirm={() =>
deleteOwnershipRequestMutation.mutate({
ownershipId: requestToBeDeleted.id,
})
}
onClose={() => setRequestToBeDeleted(undefined)}
size={ModalSizes.MD}
>
<Box padding={4}>
<Trans
i18nKey="organizers.ownerships.delete_modal.body"
values={{
ownerEmail: requestToBeDeleted?.ownerEmail,
}}
/>
</Box>
</Modal>
</Stack>
{(approvedRequests.length > 0 || !!creator) && (
<Stack spacing={4}>
<Title size={3}>{t('organizers.ownerships.owners')}</Title>
<OwnershipsTable
creator={creator}
requests={approvedRequests}
renderActions={(request) => (
<Button
variant={ButtonVariants.ICON}
iconName={Icons.TRASH}
onClick={() => setRequestToBeDeleted(request)}
/>
)}
/>
<Modal
title={t('organizers.ownerships.delete_modal.title')}
confirmTitle={t('organizers.ownerships.delete_modal.confirm')}
cancelTitle={t('organizers.ownerships.delete_modal.cancel')}
visible={!!requestToBeDeleted}
variant={ModalVariants.QUESTION}
onConfirm={() =>
deleteOwnershipRequestMutation.mutate({
ownershipId: requestToBeDeleted.id,
})
}
onClose={() => setRequestToBeDeleted(undefined)}
size={ModalSizes.MD}
>
<Box padding={4}>
<Trans
i18nKey="organizers.ownerships.delete_modal.body"
values={{
ownerEmail: requestToBeDeleted?.ownerEmail,
}}
/>
</Box>
</Modal>
</Stack>
)}
{pendingRequests.length > 0 && (
<Stack spacing={4}>
<Title size={3}>{t('organizers.ownerships.pending')}</Title>
Expand Down Expand Up @@ -273,6 +285,11 @@ export const getServerSideProps = getApplicationServerSideProps(
queryClient,
organizerId: query.organizerId,
}),
await useGetOwnershipCreatorQuery({
req,
queryClient,
organizerId: query.organizerId,
}),
]);
return {
props: {
Expand Down
4 changes: 2 additions & 2 deletions src/ui/Typeahead.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import 'react-bootstrap-typeahead/css/Typeahead.css';

import type { ForwardedRef } from 'react';
import type { ForwardedRef, Ref } from 'react';
import { forwardRef } from 'react';
import type { TypeaheadModel } from 'react-bootstrap-typeahead';
import { AsyncTypeahead as BootstrapTypeahead } from 'react-bootstrap-typeahead';
Expand Down Expand Up @@ -86,7 +86,7 @@ const TypeaheadInner = <T extends TypeaheadModel>(
disabled={disabled}
className={className}
flex={1}
ref={ref}
ref={ref as unknown as Ref<HTMLElement>}
css={`
input[type='time']::-webkit-calendar-picker-indicator {
display: none;
Expand Down
Loading

0 comments on commit 161b049

Please sign in to comment.