@centreon/ui 24.4.39 → 24.4.40

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (95) hide show
  1. package/package.json +14 -19
  2. package/public/mockServiceWorker.js +1 -1
  3. package/src/Button/Icon/index.tsx +1 -1
  4. package/src/Button/Save/StartIcon.tsx +3 -3
  5. package/src/Button/Save/index.tsx +5 -9
  6. package/src/Checkbox/Checkbox.tsx +2 -2
  7. package/src/Checkbox/CheckboxGroup/index.tsx +2 -2
  8. package/src/Dashboard/Item.tsx +1 -1
  9. package/src/Dashboard/Layout.tsx +2 -2
  10. package/src/Dialog/index.tsx +1 -1
  11. package/src/FallbackPage/FallbackPage.tsx +3 -3
  12. package/src/FileDropZone/index.tsx +1 -3
  13. package/src/Form/Inputs/CheckboxGroup.tsx +4 -1
  14. package/src/Form/Inputs/index.tsx +1 -3
  15. package/src/Form/Inputs/models.ts +1 -9
  16. package/src/Graph/LineChart/BasicComponents/Lines/Threshold/Circle.tsx +2 -2
  17. package/src/Graph/LineChart/BasicComponents/Lines/Threshold/index.tsx +4 -5
  18. package/src/Graph/LineChart/BasicComponents/Thresholds.tsx +2 -2
  19. package/src/Graph/LineChart/BasicComponents/useFilterLines.ts +1 -1
  20. package/src/Graph/LineChart/InteractiveComponents/AnchorPoint/GuidingLines.tsx +2 -2
  21. package/src/Graph/LineChart/InteractiveComponents/Annotations/Annotation/index.tsx +3 -2
  22. package/src/Graph/LineChart/InteractiveComponents/Annotations/EventAnnotations.tsx +1 -1
  23. package/src/Graph/LineChart/Legend/useLegend.ts +3 -3
  24. package/src/Graph/LineChart/helpers/doc.ts +13 -16
  25. package/src/Graph/LineChart/helpers/index.ts +1 -1
  26. package/src/Graph/LineChart/index.stories.tsx +2 -4
  27. package/src/Graph/SingleBar/Thresholds.tsx +2 -2
  28. package/src/Graph/Text/Text.stories.tsx +4 -60
  29. package/src/Graph/common/timeSeries/index.ts +3 -3
  30. package/src/InputField/Select/Autocomplete/Connected/index.tsx +7 -10
  31. package/src/InputField/Select/Autocomplete/Draggable/SortableList.tsx +1 -1
  32. package/src/InputField/Select/Autocomplete/Draggable/SortableListContent.tsx +1 -1
  33. package/src/InputField/Select/Autocomplete/Draggable/index.tsx +1 -1
  34. package/src/InputField/Select/Autocomplete/index.tsx +115 -121
  35. package/src/InputField/Select/IconPopover/index.tsx +2 -2
  36. package/src/InputField/Select/index.tsx +1 -1
  37. package/src/InputField/Text/index.tsx +2 -2
  38. package/src/Listing/Cell/DataCell.tsx +1 -15
  39. package/src/Listing/Header/ListingHeader.tsx +1 -1
  40. package/src/Listing/Listing.styles.ts +3 -2
  41. package/src/Listing/index.stories.tsx +1 -12
  42. package/src/Listing/index.tsx +2 -1
  43. package/src/Module/index.tsx +4 -2
  44. package/src/RichTextEditor/RichTextEditor.tsx +1 -12
  45. package/src/SortableItems/index.tsx +7 -2
  46. package/src/ThemeProvider/index.tsx +0 -24
  47. package/src/TimePeriods/CustomTimePeriod/CompactCustomTimePeriod.styles.ts +7 -6
  48. package/src/TimePeriods/CustomTimePeriod/PopoverCustomTimePeriod/PickersStartEndDate.tsx +3 -8
  49. package/src/TimePeriods/CustomTimePeriod/PopoverCustomTimePeriod/models.ts +2 -0
  50. package/src/TimePeriods/DateTimePickerInput.tsx +19 -56
  51. package/src/TimePeriods/ResolutionTimePeriod.cypress.spec.tsx +9 -12
  52. package/src/TimePeriods/TimePeriods.cypress.spec.tsx +33 -9
  53. package/src/TimePeriods/helpers/index.ts +1 -1
  54. package/src/TimePeriods/index.stories.tsx +4 -12
  55. package/src/TimePeriods/index.tsx +2 -2
  56. package/src/api/QueryProvider.tsx +1 -1
  57. package/src/api/TestQueryProvider.tsx +1 -1
  58. package/src/api/useFetchQuery/index.ts +23 -27
  59. package/src/api/useMutationQuery/index.ts +21 -45
  60. package/src/components/Button/Icon/IconButton.tsx +2 -6
  61. package/src/components/DataTable/DataTable.stories.tsx +0 -40
  62. package/src/components/DataTable/DataTable.styles.ts +0 -3
  63. package/src/components/DataTable/DataTable.tsx +3 -3
  64. package/src/components/DataTable/Item/DataTableItem.styles.ts +2 -7
  65. package/src/components/DataTable/Item/DataTableItem.tsx +4 -4
  66. package/src/components/DataTable/index.ts +1 -3
  67. package/src/components/Form/Dashboard/DashboardForm.tsx +12 -15
  68. package/src/components/Layout/PageLayout/PageLayout.tsx +1 -1
  69. package/src/components/Layout/PageLayout/PageLayoutActions.tsx +0 -1
  70. package/src/components/Layout/PageLayout/PageLayoutBody.tsx +0 -1
  71. package/src/components/Layout/PageLayout/PageLayoutHeader.tsx +1 -5
  72. package/src/components/Layout/PageLayout/index.ts +1 -3
  73. package/src/components/Modal/Modal.styles.ts +1 -1
  74. package/src/components/Tooltip/ConfirmationTooltip/ConfirmationTooltip.stories.tsx +3 -3
  75. package/src/components/Tooltip/ConfirmationTooltip/ConfirmationTooltip.tsx +1 -1
  76. package/src/components/Tooltip/ConfirmationTooltip/models.ts +1 -1
  77. package/src/index.ts +2 -2
  78. package/src/queryParameters/url/index.ts +1 -5
  79. package/src/screens/dashboard/DashboardsDetail.stories.tsx +108 -0
  80. package/src/screens/dashboard/DashboardsOverview.stories.tsx +281 -0
  81. package/src/utils/index.ts +1 -2
  82. package/src/utils/useDateTimePickerAdapter.ts +309 -0
  83. package/src/utils/{useLicenseExpirationWarning.test.tsx → useLicenseExpirationWarning.cypress.spec.tsx} +37 -48
  84. package/src/utils/useLicenseExpirationWarning.ts +18 -18
  85. package/src/Form/Form.cypress.spec.tsx +0 -133
  86. package/src/Form/Inputs/List/Content.tsx +0 -62
  87. package/src/Form/Inputs/List/List.styles.ts +0 -29
  88. package/src/Form/Inputs/List/List.tsx +0 -58
  89. package/src/Form/Inputs/List/useList.ts +0 -81
  90. package/src/Module/Module.cypress.spec.tsx +0 -129
  91. package/src/components/DataTable/DataListing.tsx +0 -6
  92. package/src/components/DataTable/DataTable.cypress.spec.tsx +0 -193
  93. package/src/components/Layout/PageLayout/PageQuickAccess.tsx +0 -76
  94. package/src/components/Layout/PageLayout.cypress.spec.tsx +0 -66
  95. package/src/utils/usePluralizedTranslation.ts +0 -21
@@ -2,15 +2,12 @@ import { useAtomValue } from 'jotai';
2
2
  import { makeStyles } from 'tss-react/mui';
3
3
  import { equals } from 'ramda';
4
4
  import { useTranslation } from 'react-i18next';
5
- import dayjs from 'dayjs';
6
- import utc from 'dayjs/plugin/utc';
7
- import timezone from 'dayjs/plugin/timezone';
8
5
 
9
- import { AdapterDayjs } from '@mui/x-date-pickers/AdapterDayjs';
10
6
  import { Typography } from '@mui/material';
11
7
  import { LocalizationProvider } from '@mui/x-date-pickers';
12
8
 
13
9
  import { userAtom } from '@centreon/ui-context';
10
+ import { useDateTimePickerAdapter } from '@centreon/ui';
14
11
 
15
12
  import DateTimePickerInput from '../../DateTimePickerInput';
16
13
  import {
@@ -23,9 +20,6 @@ import ErrorText from './ErrorText';
23
20
  import { PickersData, PickersStartEndDateDirection } from './models';
24
21
  import { PickersStartEndDateModel } from './usePickersStartEndDate';
25
22
 
26
- dayjs.extend(utc);
27
- dayjs.extend(timezone);
28
-
29
23
  const useStyles = makeStyles()((theme) => ({
30
24
  error: {
31
25
  textAlign: 'center'
@@ -110,6 +104,7 @@ const PickersStartEndDate = ({
110
104
  direction = PickersStartEndDateDirection.column
111
105
  }: Props): JSX.Element => {
112
106
  const { classes, cx } = useStyles();
107
+ const { Adapter } = useDateTimePickerAdapter();
113
108
 
114
109
  const { locale } = useAtomValue(userAtom);
115
110
  const error = useAtomValue(errorTimePeriodAtom);
@@ -131,7 +126,7 @@ const PickersStartEndDate = ({
131
126
  return (
132
127
  <LocalizationProvider
133
128
  adapterLocale={locale.substring(0, 2)}
134
- dateAdapter={AdapterDayjs}
129
+ dateAdapter={Adapter}
135
130
  >
136
131
  <div className={styleContainer}>
137
132
  <PickerDateWithLabel
@@ -18,6 +18,8 @@ export interface PickersData {
18
18
  getError?: (value: boolean) => void;
19
19
  isDisabledEndPicker?: boolean;
20
20
  isDisabledStartPicker?: boolean;
21
+ onCloseEndPicker?: (isClosed: boolean) => void;
22
+ onCloseStartPicker?: (isClosed: boolean) => void;
21
23
  rangeEndDate?: RangeDate;
22
24
  rangeStartDate?: RangeDate;
23
25
  }
@@ -1,85 +1,48 @@
1
- import { useCallback } from 'react';
1
+ import dayjs from 'dayjs';
2
2
 
3
- import dayjs, { Dayjs } from 'dayjs';
4
- import { useAtomValue } from 'jotai';
5
- import { equals } from 'ramda';
3
+ import { DateTimePicker } from '@mui/x-date-pickers';
6
4
 
7
- import {
8
- DateTimePicker,
9
- DateTimePickerProps,
10
- LocalizationProvider
11
- } from '@mui/x-date-pickers';
12
- import { AdapterDayjs } from '@mui/x-date-pickers/AdapterDayjs';
13
-
14
- import { userAtom } from '@centreon/ui-context';
5
+ import { useDateTimePickerAdapter } from '@centreon/ui';
15
6
 
16
7
  import { CustomTimePeriodProperty } from './models';
17
8
 
18
- interface ChangeDateProps {
19
- date: Date;
20
- property: CustomTimePeriodProperty | string;
21
- }
22
-
23
9
  interface Props {
24
- changeDate: (props: ChangeDateProps) => void;
10
+ changeDate: (props) => void;
25
11
  date: Date | null;
26
12
  desktopMediaQuery?: string;
27
13
  disabled?: boolean;
28
14
  maxDate?: Date;
29
15
  minDate?: Date;
30
- minDateTime?: Date;
31
- property: CustomTimePeriodProperty | string;
16
+ property: CustomTimePeriodProperty;
32
17
  }
33
18
 
34
19
  const DateTimePickerInput = ({
35
20
  date,
36
21
  maxDate,
37
22
  minDate,
38
- minDateTime,
39
23
  property,
40
24
  changeDate,
41
25
  disabled = false,
42
- desktopMediaQuery,
43
- ...rest
44
- }: Props & DateTimePickerProps<dayjs.Dayjs>): JSX.Element => {
45
- const desktopPickerMediaQuery =
46
- '@media (min-width: 1024px) or (pointer: fine)';
47
-
48
- const { timezone, locale } = useAtomValue(userAtom);
49
-
50
- const isUTC = equals(timezone, 'UTC');
26
+ desktopMediaQuery
27
+ }: Props): JSX.Element => {
28
+ const { desktopPickerMediaQuery } = useDateTimePickerAdapter();
51
29
 
52
30
  const changeTime = (newValue: dayjs.Dayjs | null): void => {
53
31
  changeDate({ date: dayjs(newValue).toDate(), property });
54
32
  };
55
33
 
56
- const formatDate = useCallback(
57
- (currentDate: Date | null): Dayjs => {
58
- return isUTC ? dayjs.utc(currentDate) : dayjs.tz(currentDate, timezone);
59
- },
60
- [isUTC, timezone]
61
- );
62
-
63
34
  return (
64
- <LocalizationProvider
65
- adapterLocale={locale.substring(0, 2)}
66
- dateAdapter={AdapterDayjs}
67
- dateLibInstance={dayjs}
68
- >
69
- <DateTimePicker<dayjs.Dayjs>
70
- dayOfWeekFormatter={(dayOfWeek) =>
71
- dayOfWeek.substring(0, 2).toLocaleUpperCase()
72
- }
73
- desktopModeMediaQuery={desktopMediaQuery ?? desktopPickerMediaQuery}
74
- disabled={disabled}
75
- maxDate={maxDate && formatDate(maxDate)}
76
- minDate={minDate && formatDate(minDate)}
77
- minDateTime={minDateTime && formatDate(minDateTime)}
78
- value={formatDate(date)}
79
- onChange={changeTime}
80
- {...rest}
81
- />
82
- </LocalizationProvider>
35
+ <DateTimePicker<dayjs.Dayjs>
36
+ dayOfWeekFormatter={(day: string): string =>
37
+ day.substring(0, 2).toUpperCase()
38
+ }
39
+ desktopModeMediaQuery={desktopMediaQuery ?? desktopPickerMediaQuery}
40
+ disabled={disabled}
41
+ maxDate={maxDate && dayjs(maxDate)}
42
+ minDate={minDate && dayjs(minDate)}
43
+ value={dayjs(date)}
44
+ onChange={changeTime}
45
+ />
83
46
  );
84
47
  };
85
48
 
@@ -1,5 +1,5 @@
1
1
  import dayjs from 'dayjs';
2
- import 'dayjs/locale/en';
2
+ import 'dayjs/locale/fr';
3
3
  import localizedFormatPlugin from 'dayjs/plugin/localizedFormat';
4
4
  import timezonePlugin from 'dayjs/plugin/timezone';
5
5
  import utcPlugin from 'dayjs/plugin/utc';
@@ -19,18 +19,18 @@ dayjs.extend(localizedFormatPlugin);
19
19
 
20
20
  const data = [
21
21
  {
22
- locale: 'en_US',
23
- resolution: { height: 590, width: 500 },
22
+ locale: 'fr_FR',
23
+ resolution: { height: 720, width: 500 },
24
24
  timezone: 'Europe/Paris'
25
25
  },
26
26
  {
27
- locale: 'en_US',
28
- resolution: { height: 590, width: 200 },
27
+ locale: 'fr_FR',
28
+ resolution: { height: 720, width: 200 },
29
29
  timezone: 'Europe/Paris'
30
30
  },
31
31
  {
32
- locale: 'en_US',
33
- resolution: { height: 590, width: 1024 },
32
+ locale: 'fr_FR',
33
+ resolution: { height: 720, width: 1024 },
34
34
  timezone: 'Europe/Paris'
35
35
  }
36
36
  ];
@@ -45,7 +45,7 @@ data.forEach((item) =>
45
45
 
46
46
  store.set(userAtom, {
47
47
  ...retrievedUser,
48
- locale: 'en_US',
48
+ locale: 'fr_FR',
49
49
  timezone: 'Europe/Paris'
50
50
  });
51
51
 
@@ -59,10 +59,7 @@ data.forEach((item) =>
59
59
  });
60
60
 
61
61
  it(`displays correctly the dates design when screen resolution is ${width}px`, () => {
62
- cy.makeSnapshotWithCustomResolution({
63
- resolution: { height, width },
64
- title: `${width}px`
65
- });
62
+ cy.makeSnapshot(`${width}px`);
66
63
  });
67
64
  })
68
65
  );
@@ -3,10 +3,15 @@ import localizedFormatPlugin from 'dayjs/plugin/localizedFormat';
3
3
  import timezonePlugin from 'dayjs/plugin/timezone';
4
4
  import utcPlugin from 'dayjs/plugin/utc';
5
5
  import { Provider, createStore } from 'jotai';
6
- import { equals } from 'ramda';
6
+ import { equals, inc } from 'ramda';
7
7
  import { renderHook } from '@testing-library/react';
8
8
 
9
- import { useLocaleDateTimeFormat } from '@centreon/ui';
9
+ import { LocalizationProvider } from '@mui/x-date-pickers';
10
+
11
+ import {
12
+ useLocaleDateTimeFormat,
13
+ useDateTimePickerAdapter
14
+ } from '@centreon/ui';
10
15
  import { ListingVariant, userAtom } from '@centreon/ui-context';
11
16
 
12
17
  import { CustomTimePeriodProperty } from './models';
@@ -292,6 +297,10 @@ testData.forEach((item) =>
292
297
  beforeEach(() => {
293
298
  cy.viewport('macbook-13');
294
299
 
300
+ const { result } = renderHook(() => useDateTimePickerAdapter());
301
+
302
+ const { Adapter } = result.current;
303
+
295
304
  const store = createStore();
296
305
  store.set(userAtom, {
297
306
  ...retrievedUser,
@@ -302,16 +311,31 @@ testData.forEach((item) =>
302
311
  cy.mount({
303
312
  Component: (
304
313
  <Provider store={store}>
305
- <DateTimePickerInput
306
- changeDate={cy.stub()}
307
- date={new Date(item.initialDate)}
308
- property={CustomTimePeriodProperty.start}
309
- />
314
+ <LocalizationProvider adapterLocale="en" dateAdapter={Adapter}>
315
+ <DateTimePickerInput
316
+ changeDate={cy.stub()}
317
+ date={new Date(item.initialDate)}
318
+ desktopMediaQuery="@media (min-width: 1024px)"
319
+ property={CustomTimePeriodProperty.start}
320
+ />
321
+ </LocalizationProvider>
310
322
  </Provider>
311
323
  )
312
324
  });
313
325
  });
314
326
 
327
+ it('checks input calendar value contains correct date', () => {
328
+ const { result } = renderHook(() => useLocaleDateTimeFormat());
329
+ const { format } = result.current;
330
+
331
+ const dateInput = format({
332
+ date: dayjs(item.initialDate).tz(item.timezone),
333
+ formatString: 'L hh:mm A'
334
+ });
335
+
336
+ cy.get('input').should('have.value', dateInput);
337
+ });
338
+
315
339
  it(`displays the correct number of days for the current month when the ${item.button} button is clicked`, () => {
316
340
  cy.get('button').click();
317
341
  item.data.forEach((element) => {
@@ -365,7 +389,7 @@ testData.forEach((item) =>
365
389
 
366
390
  cy.get('[role="rowgroup"]').children().as('listWeeks');
367
391
 
368
- cy.get('@listWeeks').should('have.length', numberWeeks);
392
+ cy.get('@listWeeks').should('have.length', inc(numberWeeks));
369
393
  cy.get('@listWeeks').eq(0).as('firstWeek');
370
394
  cy.get('@firstWeek').children().as('listDaysInFirstWeek');
371
395
 
@@ -392,7 +416,7 @@ testData.forEach((item) =>
392
416
 
393
417
  cy.get('[role="rowgroup"]').children().as('listWeeks');
394
418
 
395
- cy.get('@listWeeks').should('have.length', numberWeeks);
419
+ cy.get('@listWeeks').should('have.length', inc(numberWeeks));
396
420
 
397
421
  cy.get('@listWeeks')
398
422
  .eq(numberWeeks - 1)
@@ -23,4 +23,4 @@ export const getTimePeriodById = ({
23
23
  id,
24
24
  timePeriods
25
25
  }: TimePeriodById): TimePeriod =>
26
- find<TimePeriod>(propEq(id, 'id'))(timePeriods) as TimePeriod;
26
+ find<TimePeriod>(propEq('id', id))(timePeriods) as TimePeriod;
@@ -88,27 +88,20 @@ const args = {
88
88
  ]
89
89
  };
90
90
 
91
- const parameters = {
92
- chromatic: { diffThreshold: 0.1 }
93
- };
94
-
95
91
  export const BasicTimePeriod: Story = {
96
92
  ...Template,
97
- argTypes,
98
- parameters
93
+ argTypes
99
94
  };
100
95
 
101
96
  export const WithExtraTimePeriods: Story = {
102
97
  ...Template,
103
98
  argTypes,
104
- args,
105
- parameters
99
+ args
106
100
  };
107
101
 
108
102
  export const WithExternalComponent: Story = {
109
103
  ...TemplateWithExternalComponent,
110
- argTypes,
111
- parameters
104
+ argTypes
112
105
  };
113
106
 
114
107
  export const SimpleTimePeriod: StorySimpleTimePeriod = {
@@ -116,6 +109,5 @@ export const SimpleTimePeriod: StorySimpleTimePeriod = {
116
109
  args: {
117
110
  endDate: dayjs(Date.now()).toDate(),
118
111
  startDate: dayjs(Date.now()).subtract(29, 'day').toDate()
119
- },
120
- parameters
112
+ }
121
113
  };
@@ -20,7 +20,7 @@ import { useStyles } from './TimePeriods.styles';
20
20
  import {
21
21
  CustomTimePeriod as CustomTimePeriodModel,
22
22
  EndStartInterval,
23
- TimePeriod as TimePeriodModel
23
+ TimePeriod
24
24
  } from './models';
25
25
  import useTimePeriod from './useTimePeriod';
26
26
 
@@ -34,7 +34,7 @@ interface Parameters extends EndStartInterval {
34
34
  export interface Props {
35
35
  adjustTimePeriodData?: Omit<CustomTimePeriodModel, 'timelineEventsLimit'>;
36
36
  disabled?: boolean;
37
- extraTimePeriods?: Array<Omit<TimePeriodModel, 'timelineEventsLimit'>>;
37
+ extraTimePeriods?: Array<Omit<TimePeriod, 'timelineEventsLimit'>>;
38
38
  getIsError?: (value: boolean) => void;
39
39
  getParameters?: ({ start, end, timelineEventsLimit }: Parameters) => void;
40
40
  renderExternalComponent?: ReactNode;
@@ -7,7 +7,7 @@ const defaultCacheTime = 5 * 1_000;
7
7
  const client = new QueryClient({
8
8
  defaultOptions: {
9
9
  queries: {
10
- gcTime: defaultCacheTime,
10
+ cacheTime: defaultCacheTime,
11
11
  refetchOnWindowFocus: false,
12
12
  staleTime: defaultCacheTime,
13
13
  suspense: true
@@ -5,7 +5,7 @@ import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
5
5
  const client = new QueryClient({
6
6
  defaultOptions: {
7
7
  queries: {
8
- gcTime: 0,
8
+ cacheTime: 0,
9
9
  retry: false
10
10
  }
11
11
  }
@@ -27,9 +27,7 @@ export interface UseFetchQueryProps<T> {
27
27
  getQueryKey: () => QueryKey;
28
28
  httpCodesBypassErrorSnackbar?: Array<number>;
29
29
  isPaginated?: boolean;
30
- queryOptions?: {
31
- suspense?: boolean;
32
- } & Omit<
30
+ queryOptions?: Omit<
33
31
  UseQueryOptions<T | ResponseError, Error, T | ResponseError, QueryKey>,
34
32
  'queryKey' | 'queryFn'
35
33
  >;
@@ -37,12 +35,11 @@ export interface UseFetchQueryProps<T> {
37
35
 
38
36
  export type UseFetchQueryState<T> = {
39
37
  data?: T;
40
- error: Omit<ResponseError, 'isError'> | null;
41
38
  fetchQuery: () => Promise<T | ResponseError>;
42
39
  prefetchNextPage: ({ page, getPrefetchQueryKey }) => void;
43
40
  prefetchPreviousPage: ({ page, getPrefetchQueryKey }) => void;
44
41
  prefetchQuery: ({ endpointParams, queryKey }) => void;
45
- } & Omit<QueryObserverBaseResult, 'data' | 'error'>;
42
+ } & Omit<QueryObserverBaseResult, 'data'>;
46
43
 
47
44
  export interface PrefetchEndpointParams {
48
45
  page: number;
@@ -67,8 +64,9 @@ const useFetchQuery = <T extends object>({
67
64
 
68
65
  const { showErrorMessage } = useSnackbar();
69
66
 
70
- const queryData = useQuery<T | ResponseError, Error>({
71
- queryFn: ({ signal }): Promise<T | ResponseError> =>
67
+ const queryData = useQuery<T | ResponseError, Error>(
68
+ getQueryKey(),
69
+ ({ signal }): Promise<T | ResponseError> =>
72
70
  customFetch<T>({
73
71
  baseEndpoint,
74
72
  catchError,
@@ -78,9 +76,10 @@ const useFetchQuery = <T extends object>({
78
76
  headers: new Headers(fetchHeaders),
79
77
  signal
80
78
  }),
81
- queryKey: getQueryKey(),
82
- ...queryOptions
83
- });
79
+ {
80
+ ...queryOptions
81
+ }
82
+ );
84
83
 
85
84
  const queryClient = useQueryClient();
86
85
 
@@ -100,8 +99,9 @@ const useFetchQuery = <T extends object>({
100
99
  };
101
100
 
102
101
  const prefetchQuery = ({ endpointParams, queryKey }): void => {
103
- queryClient.prefetchQuery({
104
- queryFn: ({ signal }): Promise<T | ResponseError> =>
102
+ queryClient.prefetchQuery(
103
+ queryKey,
104
+ ({ signal }): Promise<T | ResponseError> =>
105
105
  customFetch<T>({
106
106
  baseEndpoint,
107
107
  catchError,
@@ -110,9 +110,8 @@ const useFetchQuery = <T extends object>({
110
110
  endpoint: getEndpoint(endpointParams),
111
111
  headers: new Headers(fetchHeaders),
112
112
  signal
113
- }),
114
- queryKey
115
- });
113
+ })
114
+ );
116
115
  };
117
116
 
118
117
  const prefetchNextPage = ({ page, getPrefetchQueryKey }): void => {
@@ -142,8 +141,9 @@ const useFetchQuery = <T extends object>({
142
141
  };
143
142
 
144
143
  const fetchQuery = (): Promise<T | ResponseError> => {
145
- return queryClient.fetchQuery({
146
- queryFn: ({ signal }): Promise<T | ResponseError> =>
144
+ return queryClient.fetchQuery(
145
+ getQueryKey(),
146
+ ({ signal }): Promise<T | ResponseError> =>
147
147
  customFetch<T>({
148
148
  baseEndpoint,
149
149
  catchError,
@@ -152,9 +152,8 @@ const useFetchQuery = <T extends object>({
152
152
  endpoint: getEndpoint(),
153
153
  headers: new Headers(fetchHeaders),
154
154
  signal
155
- }),
156
- queryKey: getQueryKey()
157
- });
155
+ })
156
+ );
158
157
  };
159
158
 
160
159
  const data = useMemo(
@@ -175,16 +174,13 @@ const useFetchQuery = <T extends object>({
175
174
  return;
176
175
  }
177
176
 
178
- queryClient.cancelQueries({ queryKey: getQueryKey() });
177
+ queryClient.cancelQueries(getQueryKey());
179
178
  };
180
179
  }, []);
181
180
 
182
- useEffect(
183
- () => {
184
- manageError();
185
- },
186
- useDeepCompare([queryData.data])
187
- );
181
+ useEffect(() => {
182
+ manageError();
183
+ }, useDeepCompare([queryData.data]));
188
184
 
189
185
  return {
190
186
  ...omit(['data', 'error'], queryData),
@@ -8,7 +8,7 @@ import {
8
8
  } from '@tanstack/react-query';
9
9
  import { JsonDecoder } from 'ts.data.json';
10
10
  import anylogger from 'anylogger';
11
- import { includes, omit } from 'ramda';
11
+ import { includes } from 'ramda';
12
12
 
13
13
  import { CatchErrorProps, customFetch, ResponseError } from '../customFetch';
14
14
  import useSnackbar from '../../Snackbar/useSnackbar';
@@ -31,33 +31,14 @@ export type UseMutationQueryProps<T, TMeta> = {
31
31
  getEndpoint: (_meta: TMeta) => string;
32
32
  httpCodesBypassErrorSnackbar?: Array<number>;
33
33
  method: Method;
34
- onError?: (
35
- error: ResponseError,
36
- variables: T & { _meta: TMeta },
37
- context: unknown
38
- ) => unknown;
39
- onMutate?: (variables: T & { _meta: TMeta }) => Promise<unknown> | unknown;
40
- onSuccess?: (
41
- data: ResponseError | T,
42
- variables: T & {
43
- _meta: TMeta;
44
- },
45
- context: unknown
46
- ) => unknown;
47
- } & Omit<
48
- UseMutationOptions<T & { _meta?: TMeta }>,
49
- 'mutationFn' | 'onError' | 'onMutate' | 'onSuccess'
50
- >;
34
+ } & Omit<UseMutationOptions<T & { _meta?: TMeta }>, 'mutationFn'>;
51
35
 
52
36
  const log = anylogger('API Request');
53
37
 
54
- export type UseMutationQueryState<T> = Omit<
55
- UseMutationResult<T | ResponseError>,
56
- 'isError'
57
- > & {
38
+ export type UseMutationQueryState<T> = {
58
39
  isError: boolean;
59
40
  isMutating: boolean;
60
- };
41
+ } & UseMutationResult<T | ResponseError>;
61
42
 
62
43
  const useMutationQuery = <T extends object, TMeta>({
63
44
  getEndpoint,
@@ -70,7 +51,6 @@ const useMutationQuery = <T extends object, TMeta>({
70
51
  onMutate,
71
52
  onError,
72
53
  onSuccess,
73
- onSettled,
74
54
  baseEndpoint
75
55
  }: UseMutationQueryProps<T, TMeta>): UseMutationQueryState<T> => {
76
56
  const { showErrorMessage } = useSnackbar();
@@ -79,10 +59,8 @@ const useMutationQuery = <T extends object, TMeta>({
79
59
  T | ResponseError,
80
60
  ResponseError,
81
61
  T & { _meta: TMeta }
82
- >({
83
- mutationFn: (
84
- _payload: T & { _meta: TMeta }
85
- ): Promise<T | ResponseError> => {
62
+ >(
63
+ (_payload: T & { _meta: TMeta }): Promise<T | ResponseError> => {
86
64
  const { _meta, ...payload } = _payload || {};
87
65
 
88
66
  return customFetch<T>({
@@ -100,18 +78,19 @@ const useMutationQuery = <T extends object, TMeta>({
100
78
  payload
101
79
  });
102
80
  },
103
- onError,
104
- onMutate,
105
- onSettled,
106
- onSuccess: (data, variables, context) => {
107
- if (data?.isError) {
108
- onError?.(data, variables, context);
81
+ {
82
+ onError,
83
+ onMutate,
84
+ onSuccess: (data, variables, context) => {
85
+ if (data?.isError) {
86
+ onError?.(data, variables, context);
109
87
 
110
- return;
88
+ return;
89
+ }
90
+ onSuccess?.(data, variables, context);
111
91
  }
112
- onSuccess?.(data, variables, context);
113
92
  }
114
- });
93
+ );
115
94
 
116
95
  const manageError = (): void => {
117
96
  const data = queryData.data as ResponseError | undefined;
@@ -128,17 +107,14 @@ const useMutationQuery = <T extends object, TMeta>({
128
107
  }
129
108
  };
130
109
 
131
- useEffect(
132
- () => {
133
- manageError();
134
- },
135
- useDeepCompare([queryData.data])
136
- );
110
+ useEffect(() => {
111
+ manageError();
112
+ }, useDeepCompare([queryData.data]));
137
113
 
138
114
  return {
139
- ...omit(['isError'], queryData),
115
+ ...queryData,
140
116
  isError: (queryData.data as ResponseError | undefined)?.isError || false,
141
- isMutating: queryData.isPending
117
+ isMutating: queryData.isLoading
142
118
  };
143
119
  };
144
120
 
@@ -1,9 +1,6 @@
1
1
  import React, { ReactElement, ReactNode } from 'react';
2
2
 
3
- import {
4
- IconButton as MuiIconButton,
5
- IconButtonProps as MuiIconButtonProps
6
- } from '@mui/material';
3
+ import { IconButton as MuiIconButton } from '@mui/material';
7
4
 
8
5
  import { AriaLabelingAttributes } from '../../../@types/aria-attributes';
9
6
  import { DataTestAttributes } from '../../../@types/data-attributes';
@@ -26,8 +23,7 @@ type IconButtonProps = {
26
23
  size?: 'small' | 'medium' | 'large';
27
24
  variant?: 'primary' | 'secondary' | 'ghost';
28
25
  } & AriaLabelingAttributes &
29
- DataTestAttributes &
30
- MuiIconButtonProps;
26
+ DataTestAttributes;
31
27
 
32
28
  /**
33
29
  * @todo re-factor as `iconVariant: 'icon-only'` Button variant, and remove IconButton component (reason: code duplication)
@@ -1,9 +1,5 @@
1
1
  import { Meta, StoryObj } from '@storybook/react';
2
2
 
3
- import { Box } from '@mui/material';
4
-
5
- import { ColumnType } from '../../Listing/models';
6
-
7
3
  import { DataTable } from './index';
8
4
 
9
5
  const meta: Meta<typeof DataTable> = {
@@ -53,39 +49,3 @@ export const withFixedHeightContainer: Story = {
53
49
  </div>
54
50
  )
55
51
  };
56
-
57
- const ListingTemplate = (args): JSX.Element => (
58
- <Box sx={{ height: '80vh' }}>
59
- <DataTable {...args} />
60
- </Box>
61
- );
62
-
63
- export const listing: Story = {
64
- args: {
65
- children: (
66
- <DataTable.Listing
67
- columns={[
68
- {
69
- getFormattedString: (row) => row.title,
70
- id: 'title',
71
- label: 'Title',
72
- type: ColumnType.string
73
- },
74
- {
75
- getFormattedString: (row) => row.description,
76
- id: 'description',
77
- label: 'Description',
78
- type: ColumnType.string
79
- }
80
- ]}
81
- rows={[...Array(5)].map((_, i) => ({
82
- description: `Item description ${i}`,
83
- id: i,
84
- title: `Item ${i}`
85
- }))}
86
- />
87
- ),
88
- variant: 'listing'
89
- },
90
- render: ListingTemplate
91
- };