@leav/ui 0.3.6-be1e7eb → 0.3.6-c50d2b4

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 (155) hide show
  1. package/dist/__mocks__/common/form.d.ts +10 -5
  2. package/dist/__mocks__/common/record.d.ts +13 -2
  3. package/dist/__mocks__/common/record.js.map +1 -1
  4. package/dist/_gqlTypes/index.d.ts +28 -36
  5. package/dist/_gqlTypes/index.js +25 -8
  6. package/dist/_gqlTypes/index.js.map +1 -1
  7. package/dist/components/EditApplication/EditApplication.js +2 -2
  8. package/dist/components/EditApplication/EditApplication.js.map +1 -1
  9. package/dist/components/EditApplication/_types.d.ts +2 -2
  10. package/dist/components/Explorer/DataView.d.ts +9 -1
  11. package/dist/components/Explorer/DataView.js +30 -8
  12. package/dist/components/Explorer/DataView.js.map +1 -1
  13. package/dist/components/Explorer/Explorer.d.ts +1 -0
  14. package/dist/components/Explorer/Explorer.js +41 -14
  15. package/dist/components/Explorer/Explorer.js.map +1 -1
  16. package/dist/components/Explorer/TableCell.d.ts +2 -1
  17. package/dist/components/Explorer/TableCell.js +89 -20
  18. package/dist/components/Explorer/TableCell.js.map +1 -1
  19. package/dist/components/Explorer/TableTagGroup.d.ts +6 -0
  20. package/dist/components/Explorer/TableTagGroup.js +22 -0
  21. package/dist/components/Explorer/TableTagGroup.js.map +1 -0
  22. package/dist/components/Explorer/_queries/useExplorerData.d.ts +17 -2
  23. package/dist/components/Explorer/_queries/useExplorerData.js +23 -12
  24. package/dist/components/Explorer/_queries/useExplorerData.js.map +1 -1
  25. package/dist/components/Explorer/_types.d.ts +7 -3
  26. package/dist/components/Explorer/manage-view-settings/_shared/ColumnItem.js +0 -1
  27. package/dist/components/Explorer/manage-view-settings/_shared/ColumnItem.js.map +1 -1
  28. package/dist/components/Explorer/manage-view-settings/_shared/useAttributeDetailsData.d.ts +11 -0
  29. package/dist/components/Explorer/manage-view-settings/_shared/useAttributeDetailsData.js +61 -0
  30. package/dist/components/Explorer/manage-view-settings/_shared/useAttributeDetailsData.js.map +1 -0
  31. package/dist/components/Explorer/manage-view-settings/configure-display/attributes/SelectVisibleAttributes.js +9 -40
  32. package/dist/components/Explorer/manage-view-settings/configure-display/attributes/SelectVisibleAttributes.js.map +1 -1
  33. package/dist/components/Explorer/manage-view-settings/filter-items/FilterItems.d.ts +4 -0
  34. package/dist/components/Explorer/manage-view-settings/filter-items/FilterItems.js +89 -0
  35. package/dist/components/Explorer/manage-view-settings/filter-items/FilterItems.js.map +1 -0
  36. package/dist/components/Explorer/manage-view-settings/filter-items/FilterListItem.d.ts +10 -0
  37. package/dist/components/Explorer/manage-view-settings/filter-items/FilterListItem.js +33 -0
  38. package/dist/components/Explorer/manage-view-settings/filter-items/FilterListItem.js.map +1 -0
  39. package/dist/components/Explorer/manage-view-settings/filter-items/filter-type/SimpleFilterDropDown.d.ts +8 -0
  40. package/dist/components/Explorer/manage-view-settings/filter-items/filter-type/SimpleFilterDropDown.js +100 -0
  41. package/dist/components/Explorer/manage-view-settings/filter-items/filter-type/SimpleFilterDropDown.js.map +1 -0
  42. package/dist/components/Explorer/manage-view-settings/index.d.ts +4 -4
  43. package/dist/components/Explorer/manage-view-settings/index.js +3 -3
  44. package/dist/components/Explorer/manage-view-settings/index.js.map +1 -1
  45. package/dist/components/Explorer/manage-view-settings/open-view-settings/SidePanel.js +1 -1
  46. package/dist/components/Explorer/manage-view-settings/open-view-settings/SidePanel.js.map +1 -1
  47. package/dist/components/Explorer/manage-view-settings/open-view-settings/useOpenViewSettings.d.ts +3 -0
  48. package/dist/components/Explorer/manage-view-settings/open-view-settings/{useOpenSettings.js → useOpenViewSettings.js} +5 -3
  49. package/dist/components/Explorer/manage-view-settings/open-view-settings/useOpenViewSettings.js.map +1 -0
  50. package/dist/components/Explorer/manage-view-settings/router-menu/SettingsPanel.d.ts +1 -1
  51. package/dist/components/Explorer/manage-view-settings/router-menu/SettingsPanel.js +5 -5
  52. package/dist/components/Explorer/manage-view-settings/router-menu/SettingsPanel.js.map +1 -1
  53. package/dist/components/Explorer/manage-view-settings/sort-items/SortItems.d.ts +4 -0
  54. package/dist/components/Explorer/manage-view-settings/sort-items/SortItems.js +109 -0
  55. package/dist/components/Explorer/manage-view-settings/sort-items/SortItems.js.map +1 -0
  56. package/dist/components/Explorer/manage-view-settings/sort-items/SortListItem.d.ts +10 -0
  57. package/dist/components/Explorer/manage-view-settings/sort-items/SortListItem.js +32 -0
  58. package/dist/components/Explorer/manage-view-settings/sort-items/SortListItem.js.map +1 -0
  59. package/dist/components/Explorer/manage-view-settings/store-view-settings/viewSettingsInitialState.d.ts +2 -0
  60. package/dist/components/Explorer/manage-view-settings/store-view-settings/viewSettingsInitialState.js +9 -1
  61. package/dist/components/Explorer/manage-view-settings/store-view-settings/viewSettingsInitialState.js.map +1 -1
  62. package/dist/components/Explorer/manage-view-settings/store-view-settings/viewSettingsReducer.d.ts +108 -16
  63. package/dist/components/Explorer/manage-view-settings/store-view-settings/viewSettingsReducer.js +134 -27
  64. package/dist/components/Explorer/manage-view-settings/store-view-settings/viewSettingsReducer.js.map +1 -1
  65. package/dist/components/Explorer/useEditAction.js +1 -0
  66. package/dist/components/Explorer/useEditAction.js.map +1 -1
  67. package/dist/components/Explorer/usePagination.d.ts +7 -0
  68. package/dist/components/Explorer/usePagination.js +25 -0
  69. package/dist/components/Explorer/usePagination.js.map +1 -0
  70. package/dist/components/Explorer/usePrimaryActions.d.ts +1 -9
  71. package/dist/components/Explorer/usePrimaryActions.js +4 -12
  72. package/dist/components/Explorer/usePrimaryActions.js.map +1 -1
  73. package/dist/components/Explorer/useSearchInput.d.ts +10 -0
  74. package/dist/components/Explorer/useSearchInput.js +31 -0
  75. package/dist/components/Explorer/useSearchInput.js.map +1 -0
  76. package/dist/components/Explorer/useTableScrollableHeight.d.ts +5 -0
  77. package/dist/components/Explorer/useTableScrollableHeight.js +15 -0
  78. package/dist/components/Explorer/useTableScrollableHeight.js.map +1 -0
  79. package/dist/components/ImportModal/ImportModalConfigStep/ImportModalConfigStep.js +5 -5
  80. package/dist/components/ImportModal/ImportModalConfigStep/ImportModalConfigStep.js.map +1 -1
  81. package/dist/components/RecordEdition/EditRecord/EditRecord.js +1 -1
  82. package/dist/components/RecordEdition/EditRecord/EditRecord.js.map +1 -1
  83. package/dist/components/RecordEdition/EditRecordContent/_types.d.ts +4 -4
  84. package/dist/components/RecordEdition/EditRecordContent/antdUtils.js +34 -31
  85. package/dist/components/RecordEdition/EditRecordContent/antdUtils.js.map +1 -1
  86. package/dist/components/RecordEdition/EditRecordContent/reducers/standardFieldReducer/standardFieldReducer.js +2 -2
  87. package/dist/components/RecordEdition/EditRecordContent/reducers/standardFieldReducer/standardFieldReducer.js.map +1 -1
  88. package/dist/components/RecordEdition/EditRecordContent/uiElements/LinkField/MonoValueSelect/MonoValueSelect.js +1 -1
  89. package/dist/components/RecordEdition/EditRecordContent/uiElements/LinkField/MonoValueSelect/MonoValueSelect.js.map +1 -1
  90. package/dist/components/RecordEdition/EditRecordContent/uiElements/LinkField/MultiValueSelect/MultiValueSelect.js +1 -1
  91. package/dist/components/RecordEdition/EditRecordContent/uiElements/LinkField/MultiValueSelect/MultiValueSelect.js.map +1 -1
  92. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/DeleteAllValuesButton.d.ts +4 -0
  93. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/DeleteAllValuesButton.js +25 -0
  94. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/DeleteAllValuesButton.js.map +1 -0
  95. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardField.d.ts +2 -1
  96. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardField.js +191 -35
  97. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardField.js.map +1 -1
  98. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSBooleanWrapper.d.ts +2 -8
  99. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSBooleanWrapper.js +6 -25
  100. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSBooleanWrapper.js.map +1 -1
  101. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSColorPickerWrapper.d.ts +2 -13
  102. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSColorPickerWrapper.js +18 -31
  103. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSColorPickerWrapper.js.map +1 -1
  104. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSDatePickerWrapper.d.ts +3 -14
  105. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSDatePickerWrapper.js +15 -38
  106. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSDatePickerWrapper.js.map +1 -1
  107. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputEncryptedWrapper.d.ts +3 -14
  108. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputEncryptedWrapper.js +9 -77
  109. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputEncryptedWrapper.js.map +1 -1
  110. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputNumberWrapper.d.ts +3 -14
  111. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputNumberWrapper.js +20 -43
  112. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputNumberWrapper.js.map +1 -1
  113. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputWrapper.d.ts +3 -14
  114. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputWrapper.js +22 -45
  115. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputWrapper.js.map +1 -1
  116. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSRangePickerWrapper.d.ts +3 -14
  117. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSRangePickerWrapper.js +32 -50
  118. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSRangePickerWrapper.js.map +1 -1
  119. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSRichTextWrapper.d.ts +3 -14
  120. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSRichTextWrapper.js +23 -46
  121. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSRichTextWrapper.js.map +1 -1
  122. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValue.d.ts +6 -3
  123. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValue.js +61 -19
  124. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValue.js.map +1 -1
  125. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/ValuesList/MonoValueSelect.d.ts +3 -2
  126. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/ValuesList/MonoValueSelect.js +17 -43
  127. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/ValuesList/MonoValueSelect.js.map +1 -1
  128. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/ValuesList/_types.d.ts +3 -8
  129. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/_types.d.ts +9 -0
  130. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/_types.js +2 -0
  131. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/_types.js.map +1 -0
  132. package/dist/hooks/useDebouncedValue/index.d.ts +1 -0
  133. package/dist/{components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler → hooks/useDebouncedValue}/index.js +1 -1
  134. package/dist/hooks/useDebouncedValue/index.js.map +1 -0
  135. package/dist/hooks/useGetRecordForm/useGetRecordForm.d.ts +1 -0
  136. package/dist/hooks/useGetRecordForm/useGetRecordForm.js.map +1 -1
  137. package/dist/locales/en/shared.json +29 -4
  138. package/dist/locales/fr/shared.json +29 -4
  139. package/package.json +3 -2
  140. package/dist/components/Explorer/manage-view-settings/_shared/useGetLibraryColumns.d.ts +0 -10
  141. package/dist/components/Explorer/manage-view-settings/_shared/useGetLibraryColumns.js +0 -24
  142. package/dist/components/Explorer/manage-view-settings/_shared/useGetLibraryColumns.js.map +0 -1
  143. package/dist/components/Explorer/manage-view-settings/open-view-settings/useOpenSettings.d.ts +0 -1
  144. package/dist/components/Explorer/manage-view-settings/open-view-settings/useOpenSettings.js.map +0 -1
  145. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueDisplayHandler.d.ts +0 -13
  146. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueDisplayHandler.js +0 -90
  147. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueDisplayHandler.js.map +0 -1
  148. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueRead/ColorPickerBlock.d.ts +0 -7
  149. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueRead/ColorPickerBlock.js +0 -45
  150. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueRead/ColorPickerBlock.js.map +0 -1
  151. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueRead/StandardFieldValueRead.d.ts +0 -9
  152. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueRead/StandardFieldValueRead.js +0 -141
  153. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueRead/StandardFieldValueRead.js.map +0 -1
  154. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/index.d.ts +0 -1
  155. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/index.js.map +0 -1
@@ -1,4 +1,4 @@
1
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  // Copyright LEAV Solutions 2017 until 2023/11/05, Copyright Aristid from 2023/11/06
3
3
  // This file is released under LGPL V3
4
4
  // License text available at https://www.gnu.org/licenses/lgpl-3.0.txt
@@ -13,7 +13,10 @@ import { useEditAction } from './useEditAction';
13
13
  import { usePrimaryActionsButton } from './usePrimaryActions';
14
14
  import { ExplorerTitle } from './ExplorerTitle';
15
15
  import { useCreateAction } from './useCreateAction';
16
- import { useOpenSettings, SidePanel, useEditSettings, viewSettingsReducer, ViewSettingsContext, viewSettingsInitialState } from './manage-view-settings';
16
+ import { SidePanel, useEditSettings, useOpenViewSettings, ViewSettingsContext, viewSettingsInitialState, defaultPageSizeOptions, viewSettingsReducer } from './manage-view-settings';
17
+ import { useSearchInput } from './useSearchInput';
18
+ import { usePagination } from './usePagination';
19
+ import { Loading } from '../Loading';
17
20
  const isNotEmpty = (union) => union.length > 0;
18
21
  const ExplorerHeaderDivStyled = styled.div `
19
22
  display: flex;
@@ -21,10 +24,27 @@ const ExplorerHeaderDivStyled = styled.div `
21
24
  align-items: center;
22
25
  padding-bottom: calc(var(--general-spacing-xs) * 1px);
23
26
  `;
24
- export const Explorer = ({ library, itemActions, primaryActions, title, defaultActionsForItem = ['edit', 'deactivate'], defaultPrimaryActions = ['create'], defaultViewSettings }) => {
27
+ const ExplorerPageDivStyled = styled.div `
28
+ display: flex;
29
+ flex-direction: column;
30
+ height: 100%;
31
+ overflow: hidden;
32
+ `;
33
+ export const Explorer = ({ library, itemActions, primaryActions, title, noPagination, defaultActionsForItem = ['edit', 'deactivate'], defaultPrimaryActions = ['create'], defaultViewSettings }) => {
25
34
  const { panelElement } = useEditSettings();
26
- const [view, dispatch] = useReducer(viewSettingsReducer, { ...viewSettingsInitialState, ...defaultViewSettings });
27
- const { data, loading, refetch } = useExplorerData(library, view.fields); // TODO: refresh when go back on page
35
+ const [view, dispatch] = useReducer(viewSettingsReducer, {
36
+ ...viewSettingsInitialState,
37
+ ...defaultViewSettings,
38
+ maxFilters: defaultViewSettings?.maxFilters ?? viewSettingsInitialState.maxFilters
39
+ });
40
+ const { currentPage, setNewPageSize, setNewPage } = usePagination(dispatch);
41
+ const { data, loading, refetch } = useExplorerData({
42
+ libraryId: library,
43
+ attributeIds: view.attributesIds,
44
+ fulltextSearch: view.fulltextSearch,
45
+ pagination: noPagination ? null : { limit: view.pageSize, offset: view.pageSize * (currentPage - 1) },
46
+ sorts: view.sort
47
+ }); // TODO: refresh when go back on page
28
48
  const { deactivateAction } = useDeactivateAction({
29
49
  isEnabled: isNotEmpty(defaultActionsForItem) && defaultActionsForItem.includes('deactivate')
30
50
  });
@@ -36,14 +56,21 @@ export const Explorer = ({ library, itemActions, primaryActions, title, defaultA
36
56
  library,
37
57
  refetch
38
58
  });
39
- // TODO: move to `useCreateAction` directly?
40
- const enabledDefaultActions = createAction ? [createAction] : [];
41
- const { primaryButton } = usePrimaryActionsButton([...enabledDefaultActions, ...(primaryActions ?? [])]);
42
- // TODO: harmonize to other hook signature that return only object
43
- const settingsButton = useOpenSettings(library);
44
- // TODO: remove SET
45
- const dedupItemActions = [...new Set([editAction, deactivateAction, ...(itemActions ?? [])].filter(Boolean))];
46
- return (_jsxs(ViewSettingsContext.Provider, { value: { view, dispatch }, children: [loading ? ('Loading...' // TODO: handle loading properly
47
- ) : (_jsxs(_Fragment, { children: [_jsxs(ExplorerHeaderDivStyled, { children: [_jsx(KitTypography.Title, { level: "h1", children: _jsx(ExplorerTitle, { library: library, title: title }) }), _jsxs(KitSpace, { size: "xs", children: [settingsButton, primaryButton] })] }), _jsx(DataView, { dataGroupedFilteredSorted: data?.records ?? [], itemActions: dedupItemActions, columnsLabels: data?.attributes ?? {}, attributesToDisplay: ['whoAmI', ...view.fields] })] })), panelElement && createPortal(_jsx(SidePanel, {}), panelElement), editModal, createModal] }));
59
+ const { primaryButton } = usePrimaryActionsButton([createAction, ...(primaryActions ?? [])].filter(Boolean));
60
+ const { viewSettingsButton } = useOpenViewSettings(library);
61
+ const { searchInput } = useSearchInput({ view, dispatch });
62
+ const dataViewAdditionalProps = noPagination
63
+ ? {}
64
+ : {
65
+ paginationProps: {
66
+ pageSizeOptions: defaultPageSizeOptions,
67
+ currentPage,
68
+ pageSize: view.pageSize,
69
+ setNewPageSize,
70
+ setNewPage,
71
+ totalItems: data?.totalCount ?? 0
72
+ }
73
+ };
74
+ return (_jsxs(ViewSettingsContext.Provider, { value: { view, dispatch }, children: [_jsxs(ExplorerPageDivStyled, { children: [_jsxs(ExplorerHeaderDivStyled, { children: [_jsx(KitTypography.Title, { level: "h1", children: _jsx(ExplorerTitle, { library: library, title: title }) }), _jsxs(KitSpace, { size: "xs", children: [searchInput, viewSettingsButton, primaryButton] })] }), loading ? (_jsx(Loading, {})) : (_jsx(DataView, { dataGroupedFilteredSorted: data?.records ?? [], itemActions: [editAction, deactivateAction, ...(itemActions ?? [])].filter(Boolean), attributesProperties: data?.attributes ?? {}, attributesToDisplay: ['whoAmI', ...view.attributesIds], ...dataViewAdditionalProps }))] }), panelElement && createPortal(_jsx(SidePanel, {}), panelElement), editModal, createModal] }));
48
75
  };
49
76
  //# sourceMappingURL=Explorer.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Explorer.js","sourceRoot":"","sources":["../../../src/components/Explorer/Explorer.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Explorer.js","sourceRoot":"","sources":["../../../src/components/Explorer/Explorer.tsx"],"names":[],"mappings":"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"}
@@ -1,7 +1,8 @@
1
- import { PropertyValueFragment } from '../../_gqlTypes';
1
+ import { AttributePropertiesFragment, PropertyValueFragment } from '../../_gqlTypes';
2
2
  import { FunctionComponent } from 'react';
3
3
  interface ITableCellProps {
4
4
  values: PropertyValueFragment[];
5
+ attributeProperties: AttributePropertiesFragment;
5
6
  }
6
7
  export declare const TableCell: FunctionComponent<ITableCellProps>;
7
8
  export {};
@@ -1,41 +1,110 @@
1
- import { jsx as _jsx } from "react/jsx-runtime";
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  // Copyright LEAV Solutions 2017 until 2023/11/05, Copyright Aristid from 2023/11/06
3
3
  // This file is released under LGPL V3
4
4
  // License text available at https://www.gnu.org/licenses/lgpl-3.0.txt
5
5
  import { AttributeFormat, AttributeType } from '../../_gqlTypes';
6
6
  import { useSharedTranslation } from '../../hooks/useSharedTranslation';
7
- import { KitTag, KitTypography } from 'aristid-ds';
7
+ import { KitAvatar, KitTag, KitTypography } from 'aristid-ds';
8
8
  import styled from 'styled-components';
9
9
  import { IdCard } from './IdCard';
10
- const isLinkValue = (v) => [AttributeType.simple_link, AttributeType.advanced_link].includes(v.attribute.type);
11
- const isTreeValue = (v) => [AttributeType.tree].includes(v.attribute.type);
12
- const isStandardValue = (v) => [AttributeType.simple, AttributeType.advanced].includes(v.attribute.type);
10
+ import { TableTagGroup } from './TableTagGroup';
11
+ import { FaListAlt } from 'react-icons/fa';
12
+ import DOMPurify from 'dompurify';
13
+ const isStandardValue = (v, attribute) => [AttributeType.simple, AttributeType.advanced].includes(attribute.type);
14
+ const isStandardValues = (values, attribute) => values.every(value => isStandardValue(value, attribute));
15
+ const isLinkValue = (v, attribute) => [AttributeType.simple_link, AttributeType.advanced_link].includes(attribute.type);
16
+ const isLinkValues = (values, attribute) => values.every(value => isLinkValue(value, attribute));
17
+ const isTreeValue = (v, attribute) => [AttributeType.tree].includes(attribute.type);
13
18
  const StyledCenteringWrapper = styled.div `
14
19
  display: flex;
15
20
  align-items: center;
21
+ gap: calc(var(--general-spacing-xs) * 1px);
16
22
  `;
17
- export const TableCell = ({ values }) => {
23
+ const StyledColorChip = styled.div `
24
+ height: calc(var(--general-spacing-s) * 1px);
25
+ width: calc(var(--general-spacing-s) * 1px);
26
+ border-radius: calc(var(--general-border-radius-xs) * 1px);
27
+ background-color: ${props => props.$colorTextContent};
28
+ `;
29
+ const StyledFaListAlt = styled(FaListAlt) `
30
+ flex-shrink: 0;
31
+ `;
32
+ export const TableCell = ({ values, attributeProperties }) => {
18
33
  const { t } = useSharedTranslation();
19
- return (_jsx(StyledCenteringWrapper, { children: values.map((value) => {
20
- if (isStandardValue(value)) {
21
- switch (value.attribute.format) {
34
+ if (attributeProperties.multiple_values) {
35
+ if (isStandardValues(values, attributeProperties)) {
36
+ const tags = values.map(value => {
37
+ switch (attributeProperties.format) {
22
38
  case AttributeFormat.boolean:
23
- const valueToDisplay = value.valuePayload ? t('global.yes') : t('global.no');
24
- return (_jsx(KitTag, { type: !!value.valuePayload ? 'primary' : 'neutral', idCardProps: { description: valueToDisplay } }, value.attribute.id));
39
+ return {
40
+ idCardProps: {
41
+ description: value.valuePayload ? String(t('global.yes')) : String(t('global.no'))
42
+ },
43
+ type: value.valuePayload ? 'primary' : 'neutral'
44
+ };
25
45
  default:
26
- const valueContent = value.attribute.format === AttributeFormat.encrypted
46
+ const valueContent = attributeProperties.format === AttributeFormat.encrypted
27
47
  ? '●●●●●●●●●●●●'
28
48
  : value.valuePayload;
29
- return (_jsx(KitTypography.Text, { ellipsis: { tooltip: valueContent }, children: valueContent }, value.attribute.id));
49
+ return {
50
+ idCardProps: { description: valueContent },
51
+ type: 'primary'
52
+ };
30
53
  }
54
+ });
55
+ return _jsx(TableTagGroup, { tags: tags });
56
+ }
57
+ else if (isLinkValues(values, attributeProperties)) {
58
+ return (_jsx(KitAvatar.Group, { maxCount: 5, children: values.map((value, index) => {
59
+ if (!isLinkValue(value, attributeProperties)) {
60
+ return null;
61
+ }
62
+ return (_jsx(KitAvatar, { label: String(value?.linkPayload?.whoAmI.label), src: value?.linkPayload?.whoAmI.preview?.small, color: "primary", secondaryColorInvert: true }, index));
63
+ }) }));
64
+ }
65
+ else {
66
+ // TODO: handle multiple tree values
67
+ return null;
68
+ }
69
+ }
70
+ else {
71
+ const value = values[0]; // Not multiple_values attribute should not have more than one value
72
+ if (!value) {
73
+ return null;
74
+ }
75
+ let content = null;
76
+ if (isStandardValue(value, attributeProperties)) {
77
+ if (value.valuePayload === null) {
78
+ return null;
31
79
  }
32
- const defaultValue = '';
33
- if (isTreeValue(value)) {
34
- return value.treePayload?.record.id ?? defaultValue;
35
- }
36
- if (isLinkValue(value)) {
37
- return value.linkPayload?.whoAmI ? (_jsx(IdCard, { item: value.linkPayload?.whoAmI }, value.attribute.id)) : null;
80
+ switch (attributeProperties.format) {
81
+ case AttributeFormat.boolean:
82
+ const valueToDisplay = value.valuePayload ? t('global.yes') : t('global.no');
83
+ content = (_jsx(KitTag, { type: !!value.valuePayload ? 'primary' : 'neutral', idCardProps: { description: valueToDisplay } }, attributeProperties.id));
84
+ break;
85
+ case AttributeFormat.rich_text:
86
+ const tmp = document.createElement('div');
87
+ tmp.innerHTML = DOMPurify.sanitize(value.valuePayload);
88
+ const textContent = tmp.textContent;
89
+ content = (_jsxs(_Fragment, { children: [_jsx(StyledFaListAlt, {}), _jsx(KitTypography.Text, { ellipsis: { tooltip: textContent }, children: textContent }, attributeProperties.id)] }));
90
+ break;
91
+ case AttributeFormat.color:
92
+ const colorTextContent = `#${value.valuePayload}`;
93
+ content = (_jsxs(_Fragment, { children: [_jsx(StyledColorChip, { "$colorTextContent": colorTextContent }), _jsx(KitTypography.Text, { ellipsis: { tooltip: colorTextContent }, children: colorTextContent }, attributeProperties.id)] }));
94
+ break;
95
+ default:
96
+ const valueContent = attributeProperties.format === AttributeFormat.encrypted ? '●●●●●●●●●●●●' : value.valuePayload;
97
+ content = (_jsx(KitTypography.Text, { ellipsis: { tooltip: valueContent }, children: valueContent }, attributeProperties.id));
98
+ break;
38
99
  }
39
- }) }));
100
+ }
101
+ if (isTreeValue(value, attributeProperties)) {
102
+ content = value.treePayload?.record.id ?? '';
103
+ }
104
+ if (isLinkValue(value, attributeProperties)) {
105
+ content = value.linkPayload?.whoAmI ? (_jsx(IdCard, { item: value.linkPayload?.whoAmI }, attributeProperties.id)) : null;
106
+ }
107
+ return _jsx(StyledCenteringWrapper, { children: content });
108
+ }
40
109
  };
41
110
  //# sourceMappingURL=TableCell.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TableCell.js","sourceRoot":"","sources":["../../../src/components/Explorer/TableCell.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"TableCell.js","sourceRoot":"","sources":["../../../src/components/Explorer/TableCell.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ import { IKitTag } from 'aristid-ds/dist/Kit/DataDisplay/Tag/types';
2
+ import { FunctionComponent } from 'react';
3
+ export declare const TableTagGroup: FunctionComponent<{
4
+ tags: IKitTag[];
5
+ maxTags?: number;
6
+ }>;
@@ -0,0 +1,22 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ // Copyright LEAV Solutions 2017 until 2023/11/05, Copyright Aristid from 2023/11/06
3
+ // This file is released under LGPL V3
4
+ // License text available at https://www.gnu.org/licenses/lgpl-3.0.txt
5
+ import { KitTag, KitTooltip } from 'aristid-ds';
6
+ import styled from 'styled-components';
7
+ const StyledTagsGroupDiv = styled.div `
8
+ display: flex;
9
+ column-gap: calc(var(--general-spacing-xxs) * 1px);
10
+ row-gap: calc(var(--general-spacing-xxs) * 0.5px);
11
+ flex-wrap: wrap;
12
+
13
+ & > span {
14
+ margin-right: var(--general-spacing-none);
15
+ }
16
+ `;
17
+ export const TableTagGroup = ({ tags, maxTags = 3 }) => {
18
+ const hiddenTags = tags.slice(maxTags);
19
+ const visibleTags = tags.slice(0, maxTags);
20
+ return (_jsxs(StyledTagsGroupDiv, { children: [visibleTags.map((tag, index) => (_jsx(KitTag, { ...tag }, index))), hiddenTags.length > 0 && (_jsx(KitTooltip, { overlay: hiddenTags.map((hiddenTag, index) => (_jsx("div", { children: hiddenTag.idCardProps?.description }, index))), children: _jsx(KitTag, { type: "primary", idCardProps: { description: `+${hiddenTags.length}` } }) }))] }));
21
+ };
22
+ //# sourceMappingURL=TableTagGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableTagGroup.js","sourceRoot":"","sources":["../../../src/components/Explorer/TableTagGroup.tsx"],"names":[],"mappings":";AAAA,oFAAoF;AACpF,sCAAsC;AACtC,sEAAsE;AACtE,OAAO,EAAC,MAAM,EAAE,UAAU,EAAC,MAAM,YAAY,CAAC;AAG9C,OAAO,MAAM,MAAM,mBAAmB,CAAC;AAEvC,MAAM,kBAAkB,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;;;;;CASpC,CAAC;AAEF,MAAM,CAAC,MAAM,aAAa,GAGrB,CAAC,EAAC,IAAI,EAAE,OAAO,GAAG,CAAC,EAAC,EAAE,EAAE;IACzB,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;IACvC,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;IAE3C,OAAO,CACH,MAAC,kBAAkB,eACd,WAAW,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,CAC7B,KAAC,MAAM,OAAiB,GAAG,IAAd,KAAK,CAAa,CAClC,CAAC,EACD,UAAU,CAAC,MAAM,GAAG,CAAC,IAAI,CACtB,KAAC,UAAU,IACP,OAAO,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,KAAK,EAAE,EAAE,CAAC,CAC1C,wBAAkB,SAAS,CAAC,WAAW,EAAE,WAAW,IAA1C,KAAK,CAA4C,CAC9D,CAAC,YAEF,KAAC,MAAM,IAAC,IAAI,EAAC,SAAS,EAAC,WAAW,EAAE,EAAC,WAAW,EAAE,IAAI,UAAU,CAAC,MAAM,EAAE,EAAC,GAAI,GACrE,CAChB,IACgB,CACxB,CAAC;AACN,CAAC,CAAC"}
@@ -1,11 +1,26 @@
1
1
  import { IExplorerData } from '../_types';
2
- import { ExplorerQuery } from '../../../_gqlTypes';
3
- export declare const useExplorerData: (libraryId: string, attributeIds: string[]) => {
2
+ import { ExplorerQuery, SortOrder } from '../../../_gqlTypes';
3
+ export declare const useExplorerData: ({ libraryId, attributeIds, fulltextSearch, sorts, pagination }: {
4
+ libraryId: string;
5
+ attributeIds: string[];
6
+ fulltextSearch: string;
7
+ sorts: Array<{
8
+ attributeId: string;
9
+ order: SortOrder;
10
+ }>;
11
+ pagination: null | {
12
+ limit: number;
13
+ offset: number;
14
+ };
15
+ }) => {
4
16
  data: IExplorerData;
5
17
  loading: boolean;
6
18
  refetch: (variables?: Partial<import("../../../_gqlTypes").Exact<{
7
19
  libraryId: import("../../../_gqlTypes").Scalars["ID"];
8
20
  attributeIds: Array<import("../../../_gqlTypes").Scalars["ID"]> | import("../../../_gqlTypes").Scalars["ID"];
21
+ pagination?: import("../../../_gqlTypes").InputMaybe<import("../../../_gqlTypes").RecordsPagination>;
9
22
  filters?: import("../../../_gqlTypes").InputMaybe<Array<import("../../../_gqlTypes").InputMaybe<import("../../../_gqlTypes").RecordFilterInput>> | import("../../../_gqlTypes").InputMaybe<import("../../../_gqlTypes").RecordFilterInput>>;
23
+ multipleSort?: import("../../../_gqlTypes").InputMaybe<Array<import("../../../_gqlTypes").RecordSortInput> | import("../../../_gqlTypes").RecordSortInput>;
24
+ searchQuery?: import("../../../_gqlTypes").InputMaybe<import("../../../_gqlTypes").Scalars["String"]>;
10
25
  }>>) => Promise<import("@apollo/client").ApolloQueryResult<ExplorerQuery>>;
11
26
  };
@@ -5,16 +5,15 @@ import { localizedTranslation } from '@leav/utils';
5
5
  import { useExplorerQuery } from '../../../_gqlTypes';
6
6
  import { useLang } from '../../../hooks';
7
7
  const _mapping = (data, libraryId, availableLangs) => {
8
- const attributes = {};
9
- // TODO: can we use `Array.reduce` method?
10
- // TODO: if no value on first record, no label!
11
- if (data.records.list.length > 0) {
12
- data.records.list[0].properties.forEach(({ attributeId, values }) => {
13
- attributes[attributeId] = values[0]?.attribute.label
14
- ? localizedTranslation(values[0].attribute.label, availableLangs)
15
- : attributeId;
16
- });
17
- }
8
+ const attributes = data.records.list.length
9
+ ? data.records.list[0].properties.reduce((acc, property) => {
10
+ acc[property.attributeId] = {
11
+ ...property.attributeProperties,
12
+ label: localizedTranslation(property.attributeProperties.label, availableLangs)
13
+ };
14
+ return acc;
15
+ }, {})
16
+ : {};
18
17
  const records = data.records.list.map(({ whoAmI, properties }) => ({
19
18
  libraryId,
20
19
  key: whoAmI.id, // For <KitTable /> only
@@ -29,13 +28,25 @@ const _mapping = (data, libraryId, availableLangs) => {
29
28
  propertiesById: properties.reduce((acc, { attributeId, values }) => ({ ...acc, [attributeId]: values }), {})
30
29
  }));
31
30
  return {
31
+ totalCount: data.records.totalCount ?? 0,
32
32
  attributes,
33
33
  records
34
34
  };
35
35
  };
36
- export const useExplorerData = (libraryId, attributeIds) => {
36
+ export const useExplorerData = ({ libraryId, attributeIds, fulltextSearch, sorts, pagination }) => {
37
37
  const { lang: availableLangs } = useLang();
38
- const { data, loading, refetch } = useExplorerQuery({ variables: { libraryId, attributeIds } });
38
+ const { data, loading, refetch } = useExplorerQuery({
39
+ variables: {
40
+ libraryId,
41
+ attributeIds,
42
+ pagination,
43
+ searchQuery: fulltextSearch,
44
+ multipleSort: sorts.map(({ order, attributeId }) => ({
45
+ field: attributeId,
46
+ order
47
+ }))
48
+ }
49
+ });
39
50
  return {
40
51
  data: data !== undefined ? _mapping(data, libraryId, availableLangs) : null,
41
52
  loading,
@@ -1 +1 @@
1
- {"version":3,"file":"useExplorerData.js","sourceRoot":"","sources":["../../../../src/components/Explorer/_queries/useExplorerData.ts"],"names":[],"mappings":"AAAA,oFAAoF;AACpF,sCAAsC;AACtC,sEAAsE;AACtE,OAAO,EAAC,oBAAoB,EAAC,MAAM,aAAa,CAAC;AAEjD,OAAO,EAAgB,gBAAgB,EAAC,MAAM,eAAe,CAAC;AAC9D,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAC;AAElC,MAAM,QAAQ,GAAG,CAAC,IAAmB,EAAE,SAAiB,EAAE,cAAwB,EAAiB,EAAE;IACjG,MAAM,UAAU,GAAG,EAAE,CAAC;IACtB,0CAA0C;IAC1C,+CAA+C;IAC/C,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC/B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,EAAC,WAAW,EAAE,MAAM,EAAC,EAAE,EAAE;YAC9D,UAAU,CAAC,WAAW,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,KAAK;gBAChD,CAAC,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,EAAE,cAAc,CAAC;gBACjE,CAAC,CAAC,WAAW,CAAC;QACtB,CAAC,CAAC,CAAC;IACP,CAAC;IACD,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAC,MAAM,EAAE,UAAU,EAAC,EAAE,EAAE,CAAC,CAAC;QAC7D,SAAS;QACT,GAAG,EAAE,MAAM,CAAC,EAAE,EAAE,wBAAwB;QACxC,MAAM,EAAE,MAAM,CAAC,EAAE,EAAE,wBAAwB;QAC3C,MAAM,EAAE;YACJ,KAAK,EAAE,IAAI;YACX,QAAQ,EAAE,IAAI;YACd,KAAK,EAAE,IAAI;YACX,OAAO,EAAE,IAAI;YACb,GAAG,MAAM;SACZ;QACD,cAAc,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAC,WAAW,EAAE,MAAM,EAAC,EAAE,EAAE,CAAC,CAAC,EAAC,GAAG,GAAG,EAAE,CAAC,WAAW,CAAC,EAAE,MAAM,EAAC,CAAC,EAAE,EAAE,CAAC;KAC3G,CAAC,CAAC,CAAC;IAEJ,OAAO;QACH,UAAU;QACV,OAAO;KACV,CAAC;AACN,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,SAAiB,EAAE,YAAsB,EAAE,EAAE;IACzE,MAAM,EAAC,IAAI,EAAE,cAAc,EAAC,GAAG,OAAO,EAAE,CAAC;IACzC,MAAM,EAAC,IAAI,EAAE,OAAO,EAAE,OAAO,EAAC,GAAG,gBAAgB,CAAC,EAAC,SAAS,EAAE,EAAC,SAAS,EAAE,YAAY,EAAC,EAAC,CAAC,CAAC;IAE1F,OAAO;QACH,IAAI,EAAE,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,IAAI;QAC3E,OAAO;QACP,OAAO;KACV,CAAC;AACN,CAAC,CAAC"}
1
+ {"version":3,"file":"useExplorerData.js","sourceRoot":"","sources":["../../../../src/components/Explorer/_queries/useExplorerData.ts"],"names":[],"mappings":"AAAA,oFAAoF;AACpF,sCAAsC;AACtC,sEAAsE;AACtE,OAAO,EAAC,oBAAoB,EAAC,MAAM,aAAa,CAAC;AAEjD,OAAO,EAA2B,gBAAgB,EAAC,MAAM,eAAe,CAAC;AACzE,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAC;AAElC,MAAM,QAAQ,GAAG,CAAC,IAAmB,EAAE,SAAiB,EAAE,cAAwB,EAAiB,EAAE;IACjG,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM;QACvC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,QAAQ,EAAE,EAAE;YACrD,GAAG,CAAC,QAAQ,CAAC,WAAW,CAAC,GAAG;gBACxB,GAAG,QAAQ,CAAC,mBAAmB;gBAC/B,KAAK,EAAE,oBAAoB,CAAC,QAAQ,CAAC,mBAAmB,CAAC,KAAK,EAAE,cAAc,CAAC;aAClF,CAAC;YAEF,OAAO,GAAG,CAAC;QACf,CAAC,EAAE,EAAE,CAAC;QACR,CAAC,CAAC,EAAE,CAAC;IAET,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAC,MAAM,EAAE,UAAU,EAAC,EAAE,EAAE,CAAC,CAAC;QAC7D,SAAS;QACT,GAAG,EAAE,MAAM,CAAC,EAAE,EAAE,wBAAwB;QACxC,MAAM,EAAE,MAAM,CAAC,EAAE,EAAE,wBAAwB;QAC3C,MAAM,EAAE;YACJ,KAAK,EAAE,IAAI;YACX,QAAQ,EAAE,IAAI;YACd,KAAK,EAAE,IAAI;YACX,OAAO,EAAE,IAAI;YACb,GAAG,MAAM;SACZ;QACD,cAAc,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAC,WAAW,EAAE,MAAM,EAAC,EAAE,EAAE,CAAC,CAAC,EAAC,GAAG,GAAG,EAAE,CAAC,WAAW,CAAC,EAAE,MAAM,EAAC,CAAC,EAAE,EAAE,CAAC;KAC3G,CAAC,CAAC,CAAC;IAEJ,OAAO;QACH,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,CAAC;QACxC,UAAU;QACV,OAAO;KACV,CAAC;AACN,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,EAC5B,SAAS,EACT,YAAY,EACZ,cAAc,EACd,KAAK,EACL,UAAU,EAUb,EAAE,EAAE;IACD,MAAM,EAAC,IAAI,EAAE,cAAc,EAAC,GAAG,OAAO,EAAE,CAAC;IACzC,MAAM,EAAC,IAAI,EAAE,OAAO,EAAE,OAAO,EAAC,GAAG,gBAAgB,CAAC;QAC9C,SAAS,EAAE;YACP,SAAS;YACT,YAAY;YACZ,UAAU;YACV,WAAW,EAAE,cAAc;YAC3B,YAAY,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,EAAC,KAAK,EAAE,WAAW,EAAC,EAAE,EAAE,CAAC,CAAC;gBAC/C,KAAK,EAAE,WAAW;gBAClB,KAAK;aACR,CAAC,CAAC;SACN;KACJ,CAAC,CAAC;IAEH,OAAO;QACH,IAAI,EAAE,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC,IAAI;QAC3E,OAAO;QACP,OAAO;KACV,CAAC;AACN,CAAC,CAAC"}
@@ -1,8 +1,12 @@
1
- import { PropertyValueFragment, RecordIdentityFragment } from '../../_gqlTypes';
1
+ import { Override } from '@leav/utils';
2
+ import { AttributePropertiesFragment, PropertyValueFragment, RecordIdentityFragment } from '../../_gqlTypes';
2
3
  import { ReactElement } from 'react';
3
4
  export interface IExplorerData {
5
+ totalCount: number;
4
6
  attributes: {
5
- [attributeId: string]: string;
7
+ [attributeId: string]: Override<AttributePropertiesFragment, {
8
+ label: string;
9
+ }>;
6
10
  };
7
11
  records: IItemData[];
8
12
  }
@@ -10,7 +14,7 @@ export interface IItemData {
10
14
  libraryId: string;
11
15
  key: string;
12
16
  itemId: string;
13
- whoAmI: RecordIdentityFragment['whoAmI'];
17
+ whoAmI: Required<RecordIdentityFragment['whoAmI']>;
14
18
  propertiesById: {
15
19
  [attributeId: string]: PropertyValueFragment[];
16
20
  };
@@ -12,7 +12,6 @@ const StyledValue = styled(KitTypography.Text) `
12
12
  color: var(--general-utilities-disabled);
13
13
  `;
14
14
  const StyledConfigurationItem = styled.li `
15
- list-style: none;
16
15
  color: var(--general-utilities-text-primary);
17
16
  display: flex;
18
17
  width: 100%;
@@ -1 +1 @@
1
- {"version":3,"file":"ColumnItem.js","sourceRoot":"","sources":["../../../../../src/components/Explorer/manage-view-settings/_shared/ColumnItem.tsx"],"names":[],"mappings":";AAAA,oFAAoF;AACpF,sCAAsC;AACtC,sEAAsE;AACtE,OAAO,EAAC,aAAa,EAAC,MAAM,YAAY,CAAC;AAEzC,OAAO,EAAC,KAAK,EAAE,UAAU,EAAC,MAAM,gBAAgB,CAAC;AACjD,OAAO,MAAM,MAAM,mBAAmB,CAAC;AACvC,OAAO,EAAC,WAAW,EAAC,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAC,GAAG,EAAC,MAAM,oBAAoB,CAAC;AACvC,OAAO,EAAC,oBAAoB,EAAC,MAAM,gCAAgC,CAAC;AAEpE,MAAM,WAAW,GAAG,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAA;;CAE7C,CAAC;AAEF,MAAM,uBAAuB,GAAG,MAAM,CAAC,EAAE,CAAA;;;;;;;;;;;;;;;;;;;UAmB/B,WAAW;;;;;;;;;;;;;;;;;;;;;CAqBpB,CAAC;AAEF,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;;CAEhC,CAAC;AAEF,MAAM,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,CAAA;;CAExC,CAAC;AAEF,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAwB;cAC9C,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC;CAC/D,CAAC;AAEF,MAAM,eAAe,GAAG,MAAM,CAAC,GAAG,CAAA;;CAEjC,CAAC;AAYF,MAAM,CAAC,MAAM,UAAU,GAAwC,CAAC,EAC5D,MAAM,EACN,WAAW,EACX,KAAK,EACL,QAAQ,EACR,OAAO,EACP,iBAAiB,EACpB,EAAE,EAAE;IACD,MAAM,EAAC,CAAC,EAAC,GAAG,oBAAoB,EAAE,CAAC;IACnC,MAAM,EAAC,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,EAAC,GAAG,WAAW,CAAC,EAAC,EAAE,EAAE,MAAM,EAAC,CAAC,CAAC;IACzG,MAAM,KAAK,GAAG;QACV,SAAS,EAAE,GAAG,CAAC,SAAS,CAAC,QAAQ,CAAC,SAAS,CAAC;QAC5C,UAAU;KACb,CAAC;IAEF,MAAM,YAAY,GAAG,GAAG,EAAE,CAAC,iBAAiB,EAAE,EAAE,CAAC;IAEjD,MAAM,qBAAqB,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;IAChF,OAAO,CACH,MAAC,uBAAuB,IAAC,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,aACxF,WAAW,CAAC,CAAC,CAAC,CACX,KAAC,gBAAgB,OAAK,UAAU,KAAM,SAAS,iBAAe,UAAU,YACnE,WAAW,GACG,CACtB,CAAC,CAAC,CAAC,CACA,KAAC,eAAe,KAAG,CACtB,EACD,KAAC,aAAa,CAAC,IAAI,IAAC,IAAI,EAAC,WAAW,EAAC,QAAQ,QAAC,SAAS,EAAC,OAAO,YAC1D,KAAK,GACW,EACrB,iBACI,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,YAAY,EACrB,KAAK,EAAE,qBAAqB,gBAChB,qBAAqB,YAEhC,OAAO,CAAC,CAAC,CAAC,KAAC,WAAW,KAAG,CAAC,CAAC,CAAC,KAAC,cAAc,KAAG,GAC1C,IACa,CAC7B,CAAC;AACN,CAAC,CAAC"}
1
+ {"version":3,"file":"ColumnItem.js","sourceRoot":"","sources":["../../../../../src/components/Explorer/manage-view-settings/_shared/ColumnItem.tsx"],"names":[],"mappings":";AAAA,oFAAoF;AACpF,sCAAsC;AACtC,sEAAsE;AACtE,OAAO,EAAC,aAAa,EAAC,MAAM,YAAY,CAAC;AAEzC,OAAO,EAAC,KAAK,EAAE,UAAU,EAAC,MAAM,gBAAgB,CAAC;AACjD,OAAO,MAAM,MAAM,mBAAmB,CAAC;AACvC,OAAO,EAAC,WAAW,EAAC,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAC,GAAG,EAAC,MAAM,oBAAoB,CAAC;AACvC,OAAO,EAAC,oBAAoB,EAAC,MAAM,gCAAgC,CAAC;AAEpE,MAAM,WAAW,GAAG,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAA;;CAE7C,CAAC;AAEF,MAAM,uBAAuB,GAAG,MAAM,CAAC,EAAE,CAAA;;;;;;;;;;;;;;;;;;UAkB/B,WAAW;;;;;;;;;;;;;;;;;;;;;CAqBpB,CAAC;AAEF,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,CAAA;;CAEhC,CAAC;AAEF,MAAM,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,CAAA;;CAExC,CAAC;AAEF,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAwB;cAC9C,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC;CAC/D,CAAC;AAEF,MAAM,eAAe,GAAG,MAAM,CAAC,GAAG,CAAA;;CAEjC,CAAC;AAYF,MAAM,CAAC,MAAM,UAAU,GAAwC,CAAC,EAC5D,MAAM,EACN,WAAW,EACX,KAAK,EACL,QAAQ,EACR,OAAO,EACP,iBAAiB,EACpB,EAAE,EAAE;IACD,MAAM,EAAC,CAAC,EAAC,GAAG,oBAAoB,EAAE,CAAC;IACnC,MAAM,EAAC,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,EAAC,GAAG,WAAW,CAAC,EAAC,EAAE,EAAE,MAAM,EAAC,CAAC,CAAC;IACzG,MAAM,KAAK,GAAG;QACV,SAAS,EAAE,GAAG,CAAC,SAAS,CAAC,QAAQ,CAAC,SAAS,CAAC;QAC5C,UAAU;KACb,CAAC;IAEF,MAAM,YAAY,GAAG,GAAG,EAAE,CAAC,iBAAiB,EAAE,EAAE,CAAC;IAEjD,MAAM,qBAAqB,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;IAChF,OAAO,CACH,MAAC,uBAAuB,IAAC,SAAS,EAAE,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,aACxF,WAAW,CAAC,CAAC,CAAC,CACX,KAAC,gBAAgB,OAAK,UAAU,KAAM,SAAS,iBAAe,UAAU,YACnE,WAAW,GACG,CACtB,CAAC,CAAC,CAAC,CACA,KAAC,eAAe,KAAG,CACtB,EACD,KAAC,aAAa,CAAC,IAAI,IAAC,IAAI,EAAC,WAAW,EAAC,QAAQ,QAAC,SAAS,EAAC,OAAO,YAC1D,KAAK,GACW,EACrB,iBACI,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,YAAY,EACrB,KAAK,EAAE,qBAAqB,gBAChB,qBAAqB,YAEhC,OAAO,CAAC,CAAC,CAAC,KAAC,WAAW,KAAG,CAAC,CAAC,CAAC,KAAC,cAAc,KAAG,GAC1C,IACa,CAC7B,CAAC;AACN,CAAC,CAAC"}
@@ -0,0 +1,11 @@
1
+ import { ChangeEvent } from 'react';
2
+ import { AttributeDetailsFragment } from '../../../../_gqlTypes';
3
+ interface IColumnsById {
4
+ [attributeId: string]: AttributeDetailsFragment;
5
+ }
6
+ export declare const useAttributeDetailsData: (libraryId: string) => {
7
+ attributeDetailsById: IColumnsById;
8
+ searchFilteredColumnsIds: string[];
9
+ onSearchChanged: (event: ChangeEvent<HTMLInputElement>) => void;
10
+ };
11
+ export {};
@@ -0,0 +1,61 @@
1
+ // Copyright LEAV Solutions 2017 until 2023/11/05, Copyright Aristid from 2023/11/06
2
+ // This file is released under LGPL V3
3
+ // License text available at https://www.gnu.org/licenses/lgpl-3.0.txt
4
+ import { useMemo, useState } from 'react';
5
+ import { useDebouncedValue } from '../../../../hooks/useDebouncedValue';
6
+ import { useGetAttributesByLibQuery } from '../../../../_gqlTypes';
7
+ import { localizedTranslation } from '@leav/utils';
8
+ import { useLang } from '../../../../hooks';
9
+ const _mapping = (data, availableLanguages) => data?.attributes?.list.reduce((acc, attribute) => {
10
+ acc[attribute.id] = {
11
+ ...attribute,
12
+ label: localizedTranslation(attribute.label, availableLanguages)
13
+ };
14
+ return acc;
15
+ }, {}) ?? {};
16
+ export const useAttributeDetailsData = (libraryId) => {
17
+ const [searchInput, setSearchInput] = useState('');
18
+ const debouncedSearchInput = useDebouncedValue(searchInput, 300);
19
+ const { lang: availableLanguages } = useLang();
20
+ const { data } = useGetAttributesByLibQuery({
21
+ variables: {
22
+ library: libraryId
23
+ }
24
+ });
25
+ const attributeDetailsById = _mapping(data, availableLanguages);
26
+ const searchFilteredColumns = useMemo(() => {
27
+ const columnIds = Object.keys(attributeDetailsById);
28
+ if (columnIds.length === 0) {
29
+ return {};
30
+ }
31
+ if (debouncedSearchInput === '') {
32
+ return attributeDetailsById;
33
+ }
34
+ return columnIds.reduce((acc, columnId) => {
35
+ if (attributeDetailsById[columnId].label.includes(debouncedSearchInput) ||
36
+ columnId.includes(debouncedSearchInput)) {
37
+ acc[columnId] = attributeDetailsById[columnId];
38
+ }
39
+ return acc;
40
+ }, {});
41
+ }, [debouncedSearchInput, attributeDetailsById]);
42
+ const searchFilteredColumnsIds = Object.keys(searchFilteredColumns);
43
+ const onSearchChanged = (event) => {
44
+ const shouldIgnoreInputChange = event.target.value.length < 3 && debouncedSearchInput.length < 3;
45
+ if (shouldIgnoreInputChange) {
46
+ return;
47
+ }
48
+ setSearchInput(() => {
49
+ if (event.target.value.length > 2) {
50
+ return event.target.value;
51
+ }
52
+ return '';
53
+ });
54
+ };
55
+ return {
56
+ attributeDetailsById,
57
+ searchFilteredColumnsIds,
58
+ onSearchChanged
59
+ };
60
+ };
61
+ //# sourceMappingURL=useAttributeDetailsData.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useAttributeDetailsData.js","sourceRoot":"","sources":["../../../../../src/components/Explorer/manage-view-settings/_shared/useAttributeDetailsData.tsx"],"names":[],"mappings":"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"}
@@ -2,18 +2,16 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  // Copyright LEAV Solutions 2017 until 2023/11/05, Copyright Aristid from 2023/11/06
3
3
  // This file is released under LGPL V3
4
4
  // License text available at https://www.gnu.org/licenses/lgpl-3.0.txt
5
- import { useDebouncedValue } from '../../../../../hooks/useDebouncedValue/useDebouncedValue';
6
5
  import { useSharedTranslation } from '../../../../../hooks/useSharedTranslation';
7
6
  import { KitInput, KitTypography } from 'aristid-ds';
8
- import { useMemo, useState } from 'react';
9
7
  import styled from 'styled-components';
10
8
  import { closestCenter, DndContext, KeyboardSensor, PointerSensor, useSensor, useSensors } from '@dnd-kit/core';
11
9
  import { SortableContext, sortableKeyboardCoordinates, verticalListSortingStrategy } from '@dnd-kit/sortable';
12
10
  import { FaGripLines } from 'react-icons/fa';
13
11
  import { ColumnItem } from '../../_shared/ColumnItem';
14
- import { useGetLibraryColumns } from '../../_shared/useGetLibraryColumns';
15
12
  import { ViewSettingsActionTypes } from '../../store-view-settings/viewSettingsReducer';
16
13
  import { useViewSettingsContext } from '../../store-view-settings/useViewSettingsContext';
14
+ import { useAttributeDetailsData } from '../../_shared/useAttributeDetailsData';
17
15
  const StyledList = styled.ul `
18
16
  padding: 0;
19
17
  margin: 0;
@@ -34,43 +32,14 @@ export const SelectVisibleAttributes = ({ libraryId }) => {
34
32
  coordinateGetter: sortableKeyboardCoordinates
35
33
  }));
36
34
  const { view, dispatch } = useViewSettingsContext();
37
- const { fields: orderedVisibleColumns } = view;
38
- const [searchInput, setSearchInput] = useState('');
39
- const debouncedSearchInput = useDebouncedValue(searchInput, 300);
40
- const { attributeDetailsById } = useGetLibraryColumns(libraryId);
41
- const searchFilteredColumns = useMemo(() => {
42
- const columnIds = Object.keys(attributeDetailsById);
43
- if (columnIds.length === 0) {
44
- return {};
45
- }
46
- if (searchInput === '') {
47
- return attributeDetailsById;
48
- }
49
- return columnIds.reduce((acc, columnId) => {
50
- if (attributeDetailsById[columnId].label.includes(searchInput) || columnId.includes(searchInput)) {
51
- acc[columnId] = attributeDetailsById[columnId];
52
- }
53
- return acc;
54
- }, {});
55
- }, [debouncedSearchInput, attributeDetailsById]);
56
- const searchFilteredColumnsIds = Object.keys(searchFilteredColumns);
57
- const _onSearchChanged = (event) => {
58
- const shouldIgnoreInputChange = event.target.value.length < 3 && searchInput.length < 3;
59
- if (shouldIgnoreInputChange) {
60
- return;
61
- }
62
- setSearchInput(() => {
63
- if (event.target.value.length > 2) {
64
- return event.target.value;
65
- }
66
- return '';
67
- });
68
- };
35
+ // TODO: make naming great again
36
+ const { attributesIds: orderedVisibleColumns } = view;
37
+ const { attributeDetailsById, searchFilteredColumnsIds, onSearchChanged } = useAttributeDetailsData(libraryId);
69
38
  const _toggleColumnVisibility = (columnId) => () => {
70
39
  const actionType = orderedVisibleColumns.includes(columnId)
71
- ? ViewSettingsActionTypes.REMOVE_FIELD
72
- : ViewSettingsActionTypes.ADD_FIELD;
73
- dispatch({ type: actionType, payload: { field: columnId } });
40
+ ? ViewSettingsActionTypes.REMOVE_ATTRIBUTE
41
+ : ViewSettingsActionTypes.ADD_ATTRIBUTE;
42
+ dispatch({ type: actionType, payload: { attributeId: columnId } });
74
43
  };
75
44
  const _handleDragEnd = ({ active: draggedElement, over: dropTarget }) => {
76
45
  const indexFrom = orderedVisibleColumns.indexOf(String(draggedElement.id));
@@ -78,9 +47,9 @@ export const SelectVisibleAttributes = ({ libraryId }) => {
78
47
  if (!dropTarget || indexFrom === indexTo || indexTo === -1) {
79
48
  return;
80
49
  }
81
- dispatch({ type: ViewSettingsActionTypes.MOVE_FIELD, payload: { indexFrom, indexTo } });
50
+ dispatch({ type: ViewSettingsActionTypes.MOVE_ATTRIBUTE, payload: { indexFrom, indexTo } });
82
51
  };
83
- return (_jsxs("div", { children: [_jsx(KitTypography.Title, { level: "h4", children: t('items_list.columns') }), _jsx(KitInput, { placeholder: String(t('global.search')), onChange: _onSearchChanged, allowClear: true }), _jsxs("div", { children: [_jsx(StyledList, { children: _jsx(DndContext, { sensors: sensors, collisionDetection: closestCenter, onDragEnd: _handleDragEnd, children: _jsxs(SortableContext, { items: orderedVisibleColumns, strategy: verticalListSortingStrategy, children: [_jsx(ColumnItem, { itemId: "", title: t('record_edition.whoAmI'), visible: false, disabled: true }), orderedVisibleColumns
52
+ return (_jsxs("div", { children: [_jsx(KitTypography.Title, { level: "h4", children: t('items_list.columns') }), _jsx(KitInput, { placeholder: String(t('global.search')), onChange: onSearchChanged, allowClear: true }), _jsxs("div", { children: [_jsx(StyledList, { children: _jsx(DndContext, { sensors: sensors, collisionDetection: closestCenter, onDragEnd: _handleDragEnd, children: _jsxs(SortableContext, { items: orderedVisibleColumns, strategy: verticalListSortingStrategy, children: [_jsx(ColumnItem, { itemId: "", title: t('record_edition.whoAmI'), visible: false, disabled: true }), orderedVisibleColumns
84
53
  .filter(columnId => searchFilteredColumnsIds.includes(columnId))
85
54
  .map(columnId => (_jsx(ColumnItem, { itemId: attributeDetailsById[columnId].id, title: attributeDetailsById[columnId].label, visible: true, onVisibilityClick: _toggleColumnVisibility(columnId), dragHandler: _jsx(FaGripLines, {}) }, columnId)))] }) }) }), _jsx(StyledDivider, {}), _jsx(StyledList, { children: searchFilteredColumnsIds
86
55
  .filter(columnId => !orderedVisibleColumns.includes(columnId))