@leav/ui 0.3.6-032b1da → 0.3.6-04ab99a

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 (214) hide show
  1. package/dist/__mocks__/common/attribute.js +2 -1
  2. package/dist/__mocks__/common/attribute.js.map +1 -1
  3. package/dist/__mocks__/common/form.d.ts +10 -5
  4. package/dist/__mocks__/common/form.js +2 -2
  5. package/dist/__mocks__/common/form.js.map +1 -1
  6. package/dist/__mocks__/common/record.d.ts +13 -2
  7. package/dist/__mocks__/common/record.js.map +1 -1
  8. package/dist/_gqlTypes/index.d.ts +248 -18
  9. package/dist/_gqlTypes/index.js +98 -5
  10. package/dist/_gqlTypes/index.js.map +1 -1
  11. package/dist/_queries/records/getRecordFormQuery.js +2 -0
  12. package/dist/_queries/records/getRecordFormQuery.js.map +1 -1
  13. package/dist/_queries/records/getRecordPropertiesQuery.js +2 -0
  14. package/dist/_queries/records/getRecordPropertiesQuery.js.map +1 -1
  15. package/dist/_queries/records/recordFormAttributeFragment.js +2 -0
  16. package/dist/_queries/records/recordFormAttributeFragment.js.map +1 -1
  17. package/dist/_utils/index.d.ts +2 -0
  18. package/dist/_utils/index.js +4 -0
  19. package/dist/_utils/index.js.map +1 -1
  20. package/dist/components/EditApplication/EditApplication.js +2 -2
  21. package/dist/components/EditApplication/EditApplication.js.map +1 -1
  22. package/dist/components/EditApplication/_types.d.ts +2 -2
  23. package/dist/components/Explorer/DataView.d.ts +10 -1
  24. package/dist/components/Explorer/DataView.js +32 -34
  25. package/dist/components/Explorer/DataView.js.map +1 -1
  26. package/dist/components/Explorer/Explorer.d.ts +9 -4
  27. package/dist/components/Explorer/Explorer.js +47 -10
  28. package/dist/components/Explorer/Explorer.js.map +1 -1
  29. package/dist/components/Explorer/ExplorerTitle.d.ts +7 -0
  30. package/dist/components/Explorer/ExplorerTitle.js +30 -0
  31. package/dist/components/Explorer/ExplorerTitle.js.map +1 -0
  32. package/dist/components/Explorer/IdCard.d.ts +7 -0
  33. package/dist/components/Explorer/IdCard.js +15 -0
  34. package/dist/components/Explorer/IdCard.js.map +1 -0
  35. package/dist/components/Explorer/TableCell.d.ts +8 -0
  36. package/dist/components/Explorer/TableCell.js +110 -0
  37. package/dist/components/Explorer/TableCell.js.map +1 -0
  38. package/dist/components/Explorer/TableTagGroup.d.ts +6 -0
  39. package/dist/components/Explorer/TableTagGroup.js +22 -0
  40. package/dist/components/Explorer/TableTagGroup.js.map +1 -0
  41. package/dist/components/Explorer/_queries/useExplorerData.d.ts +24 -0
  42. package/dist/components/Explorer/_queries/useExplorerData.js +55 -0
  43. package/dist/components/Explorer/_queries/useExplorerData.js.map +1 -0
  44. package/dist/components/Explorer/_types.d.ts +35 -0
  45. package/dist/components/Explorer/_types.js +2 -0
  46. package/dist/components/Explorer/_types.js.map +1 -0
  47. package/dist/components/Explorer/index.d.ts +9 -1
  48. package/dist/components/Explorer/index.js +6 -1
  49. package/dist/components/Explorer/index.js.map +1 -1
  50. package/dist/components/Explorer/manage-view-settings/_shared/ColumnItem.d.ts +12 -0
  51. package/dist/components/Explorer/manage-view-settings/_shared/ColumnItem.js +77 -0
  52. package/dist/components/Explorer/manage-view-settings/_shared/ColumnItem.js.map +1 -0
  53. package/dist/components/Explorer/manage-view-settings/_shared/useAttributeDetailsData.d.ts +11 -0
  54. package/dist/components/Explorer/manage-view-settings/_shared/useAttributeDetailsData.js +61 -0
  55. package/dist/components/Explorer/manage-view-settings/_shared/useAttributeDetailsData.js.map +1 -0
  56. package/dist/components/Explorer/manage-view-settings/configure-display/ConfigureDisplay.d.ts +6 -0
  57. package/dist/components/Explorer/manage-view-settings/configure-display/ConfigureDisplay.js +28 -0
  58. package/dist/components/Explorer/manage-view-settings/configure-display/ConfigureDisplay.js.map +1 -0
  59. package/dist/components/Explorer/manage-view-settings/configure-display/attributes/SelectVisibleAttributes.d.ts +6 -0
  60. package/dist/components/Explorer/manage-view-settings/configure-display/attributes/SelectVisibleAttributes.js +58 -0
  61. package/dist/components/Explorer/manage-view-settings/configure-display/attributes/SelectVisibleAttributes.js.map +1 -0
  62. package/dist/components/Explorer/manage-view-settings/configure-display/view-type/SelectViewType.d.ts +8 -0
  63. package/dist/components/Explorer/manage-view-settings/configure-display/view-type/SelectViewType.js +12 -0
  64. package/dist/components/Explorer/manage-view-settings/configure-display/view-type/SelectViewType.js.map +1 -0
  65. package/dist/components/Explorer/manage-view-settings/index.d.ts +8 -0
  66. package/dist/components/Explorer/manage-view-settings/index.js +11 -0
  67. package/dist/components/Explorer/manage-view-settings/index.js.map +1 -0
  68. package/dist/components/Explorer/manage-view-settings/open-view-settings/EditSettingsContext.d.ts +14 -0
  69. package/dist/components/Explorer/manage-view-settings/open-view-settings/EditSettingsContext.js +15 -0
  70. package/dist/components/Explorer/manage-view-settings/open-view-settings/EditSettingsContext.js.map +1 -0
  71. package/dist/components/Explorer/manage-view-settings/open-view-settings/EditSettingsContextProvider.d.ts +7 -0
  72. package/dist/components/Explorer/manage-view-settings/open-view-settings/EditSettingsContextProvider.js +17 -0
  73. package/dist/components/Explorer/manage-view-settings/open-view-settings/EditSettingsContextProvider.js.map +1 -0
  74. package/dist/components/Explorer/manage-view-settings/open-view-settings/SidePanel.d.ts +2 -0
  75. package/dist/components/Explorer/manage-view-settings/open-view-settings/SidePanel.js +19 -0
  76. package/dist/components/Explorer/manage-view-settings/open-view-settings/SidePanel.js.map +1 -0
  77. package/dist/components/Explorer/manage-view-settings/open-view-settings/useEditSettings.d.ts +1 -0
  78. package/dist/components/Explorer/manage-view-settings/open-view-settings/useEditSettings.js +7 -0
  79. package/dist/components/Explorer/manage-view-settings/open-view-settings/useEditSettings.js.map +1 -0
  80. package/dist/components/Explorer/manage-view-settings/open-view-settings/useOpenViewSettings.d.ts +3 -0
  81. package/dist/components/Explorer/manage-view-settings/open-view-settings/useOpenViewSettings.js +21 -0
  82. package/dist/components/Explorer/manage-view-settings/open-view-settings/useOpenViewSettings.js.map +1 -0
  83. package/dist/components/Explorer/manage-view-settings/router-menu/SettingItem.d.ts +9 -0
  84. package/dist/components/Explorer/manage-view-settings/router-menu/SettingItem.js +55 -0
  85. package/dist/components/Explorer/manage-view-settings/router-menu/SettingItem.js.map +1 -0
  86. package/dist/components/Explorer/manage-view-settings/router-menu/SettingsPanel.d.ts +7 -0
  87. package/dist/components/Explorer/manage-view-settings/router-menu/SettingsPanel.js +52 -0
  88. package/dist/components/Explorer/manage-view-settings/router-menu/SettingsPanel.js.map +1 -0
  89. package/dist/components/Explorer/manage-view-settings/sort-items/SortItems.d.ts +4 -0
  90. package/dist/components/Explorer/manage-view-settings/sort-items/SortItems.js +109 -0
  91. package/dist/components/Explorer/manage-view-settings/sort-items/SortItems.js.map +1 -0
  92. package/dist/components/Explorer/manage-view-settings/sort-items/SortListItem.d.ts +10 -0
  93. package/dist/components/Explorer/manage-view-settings/sort-items/SortListItem.js +32 -0
  94. package/dist/components/Explorer/manage-view-settings/sort-items/SortListItem.js.map +1 -0
  95. package/dist/components/Explorer/manage-view-settings/store-view-settings/ViewSettingsContext.d.ts +6 -0
  96. package/dist/components/Explorer/manage-view-settings/store-view-settings/ViewSettingsContext.js +11 -0
  97. package/dist/components/Explorer/manage-view-settings/store-view-settings/ViewSettingsContext.js.map +1 -0
  98. package/dist/components/Explorer/manage-view-settings/store-view-settings/useViewSettingsContext.d.ts +4 -0
  99. package/dist/components/Explorer/manage-view-settings/store-view-settings/useViewSettingsContext.js +7 -0
  100. package/dist/components/Explorer/manage-view-settings/store-view-settings/useViewSettingsContext.js.map +1 -0
  101. package/dist/components/Explorer/manage-view-settings/store-view-settings/viewSettingsInitialState.d.ts +3 -0
  102. package/dist/components/Explorer/manage-view-settings/store-view-settings/viewSettingsInitialState.js +8 -0
  103. package/dist/components/Explorer/manage-view-settings/store-view-settings/viewSettingsInitialState.js.map +1 -0
  104. package/dist/components/Explorer/manage-view-settings/store-view-settings/viewSettingsReducer.d.ts +87 -0
  105. package/dist/components/Explorer/manage-view-settings/store-view-settings/viewSettingsReducer.js +100 -0
  106. package/dist/components/Explorer/manage-view-settings/store-view-settings/viewSettingsReducer.js.map +1 -0
  107. package/dist/components/Explorer/{useCreateMainAction.d.ts → useCreateAction.d.ts} +3 -3
  108. package/dist/components/Explorer/{useCreateMainAction.js → useCreateAction.js} +11 -7
  109. package/dist/components/Explorer/useCreateAction.js.map +1 -0
  110. package/dist/components/Explorer/useDeactivateAction.d.ts +1 -1
  111. package/dist/components/Explorer/useDeactivateAction.js +1 -1
  112. package/dist/components/Explorer/useDeactivateAction.js.map +1 -1
  113. package/dist/components/Explorer/useEditAction.d.ts +1 -1
  114. package/dist/components/Explorer/useEditAction.js +3 -2
  115. package/dist/components/Explorer/useEditAction.js.map +1 -1
  116. package/dist/components/Explorer/usePagination.d.ts +7 -0
  117. package/dist/components/Explorer/usePagination.js +25 -0
  118. package/dist/components/Explorer/usePagination.js.map +1 -0
  119. package/dist/components/Explorer/usePrimaryActions.d.ts +12 -0
  120. package/dist/components/Explorer/usePrimaryActions.js +21 -0
  121. package/dist/components/Explorer/usePrimaryActions.js.map +1 -0
  122. package/dist/components/Explorer/useTableScrollableHeight.d.ts +5 -0
  123. package/dist/components/Explorer/useTableScrollableHeight.js +15 -0
  124. package/dist/components/Explorer/useTableScrollableHeight.js.map +1 -0
  125. package/dist/components/ImportModal/ImportModalConfigStep/ImportModalConfigStep.js +5 -5
  126. package/dist/components/ImportModal/ImportModalConfigStep/ImportModalConfigStep.js.map +1 -1
  127. package/dist/components/RecordEdition/EditRecord/EditRecord.js +23 -5
  128. package/dist/components/RecordEdition/EditRecord/EditRecord.js.map +1 -1
  129. package/dist/components/RecordEdition/EditRecordContent/EditRecordContent.js +1 -1
  130. package/dist/components/RecordEdition/EditRecordContent/EditRecordContent.js.map +1 -1
  131. package/dist/components/RecordEdition/EditRecordContent/_types.d.ts +6 -6
  132. package/dist/components/RecordEdition/EditRecordContent/antdUtils.js +34 -31
  133. package/dist/components/RecordEdition/EditRecordContent/antdUtils.js.map +1 -1
  134. package/dist/components/RecordEdition/EditRecordContent/hooks/useRunActionsListAndFormatOnValue.d.ts +121 -0
  135. package/dist/components/RecordEdition/EditRecordContent/hooks/useRunActionsListAndFormatOnValue.js +31 -0
  136. package/dist/components/RecordEdition/EditRecordContent/hooks/useRunActionsListAndFormatOnValue.js.map +1 -0
  137. package/dist/components/RecordEdition/EditRecordContent/reducers/standardFieldReducer/standardFieldReducer.d.ts +2 -2
  138. package/dist/components/RecordEdition/EditRecordContent/reducers/standardFieldReducer/standardFieldReducer.js +3 -9
  139. package/dist/components/RecordEdition/EditRecordContent/reducers/standardFieldReducer/standardFieldReducer.js.map +1 -1
  140. package/dist/components/RecordEdition/EditRecordContent/uiElements/LinkField/MonoValueSelect/MonoValueSelect.js +1 -1
  141. package/dist/components/RecordEdition/EditRecordContent/uiElements/LinkField/MonoValueSelect/MonoValueSelect.js.map +1 -1
  142. package/dist/components/RecordEdition/EditRecordContent/uiElements/LinkField/MultiValueSelect/MultiValueSelect.js +1 -1
  143. package/dist/components/RecordEdition/EditRecordContent/uiElements/LinkField/MultiValueSelect/MultiValueSelect.js.map +1 -1
  144. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/DeleteAllValuesButton.d.ts +4 -0
  145. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/DeleteAllValuesButton.js +25 -0
  146. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/DeleteAllValuesButton.js.map +1 -0
  147. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardField.d.ts +2 -1
  148. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardField.js +191 -35
  149. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardField.js.map +1 -1
  150. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSBooleanWrapper.d.ts +2 -8
  151. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSBooleanWrapper.js +9 -25
  152. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSBooleanWrapper.js.map +1 -1
  153. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSColorPickerWrapper.d.ts +2 -13
  154. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSColorPickerWrapper.js +21 -31
  155. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSColorPickerWrapper.js.map +1 -1
  156. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSDatePickerWrapper.d.ts +3 -14
  157. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSDatePickerWrapper.js +21 -37
  158. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSDatePickerWrapper.js.map +1 -1
  159. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputEncryptedWrapper.d.ts +3 -14
  160. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputEncryptedWrapper.js +11 -76
  161. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputEncryptedWrapper.js.map +1 -1
  162. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputNumberWrapper.d.ts +3 -14
  163. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputNumberWrapper.js +20 -43
  164. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputNumberWrapper.js.map +1 -1
  165. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputWrapper.d.ts +3 -14
  166. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputWrapper.js +25 -45
  167. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSInputWrapper.js.map +1 -1
  168. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSRangePickerWrapper.d.ts +3 -14
  169. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSRangePickerWrapper.js +38 -49
  170. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSRangePickerWrapper.js.map +1 -1
  171. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSRichTextWrapper.d.ts +3 -14
  172. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSRichTextWrapper.js +26 -46
  173. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/DSRichTextWrapper.js.map +1 -1
  174. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValue.d.ts +6 -3
  175. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValue.js +61 -19
  176. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValue.js.map +1 -1
  177. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/ValuesList/MonoValueSelect.d.ts +4 -0
  178. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/ValuesList/MonoValueSelect.js +119 -0
  179. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/ValuesList/MonoValueSelect.js.map +1 -0
  180. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/ValuesList/_types.d.ts +12 -0
  181. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/ValuesList/_types.js +2 -0
  182. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/ValuesList/_types.js.map +1 -0
  183. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/_types.d.ts +9 -0
  184. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/_types.js +2 -0
  185. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/_types.js.map +1 -0
  186. package/dist/components/index.d.ts +1 -0
  187. package/dist/components/index.js +1 -0
  188. package/dist/components/index.js.map +1 -1
  189. package/dist/hooks/useDebouncedValue/index.d.ts +1 -0
  190. package/dist/{components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler → hooks/useDebouncedValue}/index.js +1 -1
  191. package/dist/hooks/useDebouncedValue/index.js.map +1 -0
  192. package/dist/hooks/useGetRecordForm/useGetRecordForm.d.ts +1 -0
  193. package/dist/hooks/useGetRecordForm/useGetRecordForm.js.map +1 -1
  194. package/dist/locales/en/shared.json +40 -4
  195. package/dist/locales/fr/shared.json +40 -4
  196. package/package.json +5 -2
  197. package/dist/components/Explorer/types.d.ts +0 -21
  198. package/dist/components/Explorer/types.js +0 -2
  199. package/dist/components/Explorer/types.js.map +0 -1
  200. package/dist/components/Explorer/useCreateMainAction.js.map +0 -1
  201. package/dist/components/Explorer/useExplorerData.d.ts +0 -11
  202. package/dist/components/Explorer/useExplorerData.js +0 -23
  203. package/dist/components/Explorer/useExplorerData.js.map +0 -1
  204. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueDisplayHandler.d.ts +0 -13
  205. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueDisplayHandler.js +0 -80
  206. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueDisplayHandler.js.map +0 -1
  207. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueRead/ColorPickerBlock.d.ts +0 -7
  208. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueRead/ColorPickerBlock.js +0 -45
  209. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueRead/ColorPickerBlock.js.map +0 -1
  210. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueRead/StandardFieldValueRead.d.ts +0 -9
  211. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueRead/StandardFieldValueRead.js +0 -137
  212. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/StandardFieldValueRead/StandardFieldValueRead.js.map +0 -1
  213. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/index.d.ts +0 -1
  214. package/dist/components/RecordEdition/EditRecordContent/uiElements/StandardField/StandardFieldValue/StandardFieldValueDisplayHandler/index.js.map +0 -1
@@ -1,10 +1,15 @@
1
1
  import { FunctionComponent } from 'react';
2
- import { IItemAction } from './types';
2
+ import { IItemAction, IPrimaryAction } from './_types';
3
+ import { type IViewSettingsState } from './manage-view-settings';
3
4
  interface IExplorerProps {
5
+ noPagination?: true;
4
6
  library: string;
5
- itemActions: IItemAction[];
6
- defaultActionsForItem?: [] | ['deactivate'] | ['edit'] | ['edit', 'deactivate'] | ['deactivate', 'edit'] | undefined;
7
- defaultMainActions?: [] | ['create'];
7
+ itemActions?: IItemAction[];
8
+ primaryActions?: IPrimaryAction[];
9
+ title?: string;
10
+ defaultActionsForItem?: Array<'edit' | 'deactivate'>;
11
+ defaultPrimaryActions?: Array<'create'>;
12
+ defaultViewSettings?: Partial<IViewSettingsState>;
8
13
  }
9
14
  export declare const Explorer: FunctionComponent<IExplorerProps>;
10
15
  export {};
@@ -1,11 +1,20 @@
1
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
- import { KitTypography } from 'aristid-ds';
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 { useReducer } from 'react';
6
+ import { createPortal } from 'react-dom';
7
+ import { KitSpace, KitTypography } from 'aristid-ds';
3
8
  import styled from 'styled-components';
9
+ import { useExplorerData } from './_queries/useExplorerData';
4
10
  import { DataView } from './DataView';
5
- import { useExplorerData } from './useExplorerData';
6
11
  import { useDeactivateAction } from './useDeactivateAction';
7
12
  import { useEditAction } from './useEditAction';
8
- import { useCreateMainAction } from './useCreateMainAction';
13
+ import { usePrimaryActionsButton } from './usePrimaryActions';
14
+ import { ExplorerTitle } from './ExplorerTitle';
15
+ import { useCreateAction } from './useCreateAction';
16
+ import { SidePanel, useEditSettings, useOpenViewSettings, ViewSettingsContext, viewSettingsInitialState, defaultPageSizeOptions, viewSettingsReducer } from './manage-view-settings';
17
+ import { usePagination } from './usePagination';
9
18
  const isNotEmpty = (union) => union.length > 0;
10
19
  const ExplorerHeaderDivStyled = styled.div `
11
20
  display: flex;
@@ -13,20 +22,48 @@ const ExplorerHeaderDivStyled = styled.div `
13
22
  align-items: center;
14
23
  padding-bottom: calc(var(--general-spacing-xs) * 1px);
15
24
  `;
16
- export const Explorer = ({ library, itemActions, defaultActionsForItem = ['edit', 'deactivate'], defaultMainActions = ['create'] }) => {
17
- const currentAttribute = 'id';
18
- const { data, loading, refetch } = useExplorerData(library, [currentAttribute]); // TODO: refresh when go back on page
25
+ const ExplorerPageDivStyled = styled.div `
26
+ display: flex;
27
+ flex-direction: column;
28
+ height: 100%;
29
+ overflow: hidden;
30
+ `;
31
+ export const Explorer = ({ library, itemActions, primaryActions, title, noPagination, defaultActionsForItem = ['edit', 'deactivate'], defaultPrimaryActions = ['create'], defaultViewSettings }) => {
32
+ const { panelElement } = useEditSettings();
33
+ const [view, dispatch] = useReducer(viewSettingsReducer, { ...viewSettingsInitialState, ...defaultViewSettings });
34
+ const { currentPage, setNewPageSize, setNewPage } = usePagination(dispatch);
35
+ const { data, loading, refetch } = useExplorerData({
36
+ libraryId: library,
37
+ attributeIds: view.attributesIds,
38
+ pagination: noPagination ? null : { limit: view.pageSize, offset: view.pageSize * (currentPage - 1) },
39
+ sorts: view.sort
40
+ }); // TODO: refresh when go back on page
19
41
  const { deactivateAction } = useDeactivateAction({
20
42
  isEnabled: isNotEmpty(defaultActionsForItem) && defaultActionsForItem.includes('deactivate')
21
43
  });
22
44
  const { editAction, editModal } = useEditAction({
23
45
  isEnabled: isNotEmpty(defaultActionsForItem) && defaultActionsForItem.includes('edit')
24
46
  });
25
- const { createButton, createModal } = useCreateMainAction({
26
- isEnabled: isNotEmpty(defaultMainActions) && defaultMainActions.includes('create'),
47
+ const { createAction, createModal } = useCreateAction({
48
+ isEnabled: isNotEmpty(defaultPrimaryActions) && defaultPrimaryActions.includes('create'),
27
49
  library,
28
50
  refetch
29
51
  });
30
- return (_jsxs(_Fragment, { children: [loading ? ('Loading...') : (_jsxs(_Fragment, { children: [_jsxs(ExplorerHeaderDivStyled, { children: [_jsx(KitTypography.Title, { level: "h1", children: library /* TODO: get correct name from backend */ }), createButton] }), _jsx(DataView, { dataGroupedFilteredSorted: data ?? [], attributesToDisplay: [currentAttribute, 'whoAmI'], itemActions: [editAction, deactivateAction, ...itemActions].filter(Boolean) })] })), editModal, createModal] }));
52
+ const { primaryButton } = usePrimaryActionsButton([createAction, ...(primaryActions ?? [])].filter(Boolean));
53
+ const { viewSettingsButton } = useOpenViewSettings(library);
54
+ const dataViewAdditionalProps = noPagination
55
+ ? {}
56
+ : {
57
+ paginationProps: {
58
+ pageSizeOptions: defaultPageSizeOptions,
59
+ currentPage,
60
+ pageSize: view.pageSize,
61
+ setNewPageSize,
62
+ setNewPage,
63
+ totalItems: data?.totalCount ?? 0
64
+ }
65
+ };
66
+ return (_jsxs(ViewSettingsContext.Provider, { value: { view, dispatch }, children: [loading ? ('Loading...' // TODO: handle loading properly
67
+ ) : (_jsxs(ExplorerPageDivStyled, { children: [_jsxs(ExplorerHeaderDivStyled, { children: [_jsx(KitTypography.Title, { level: "h1", children: _jsx(ExplorerTitle, { library: library, title: title }) }), _jsxs(KitSpace, { size: "xs", children: [viewSettingsButton, primaryButton] })] }), _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] }));
31
68
  };
32
69
  //# sourceMappingURL=Explorer.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Explorer.js","sourceRoot":"","sources":["../../../src/components/Explorer/Explorer.tsx"],"names":[],"mappings":";AAIA,OAAO,EAAC,aAAa,EAAC,MAAM,YAAY,CAAC;AACzC,OAAO,MAAM,MAAM,mBAAmB,CAAC;AAEvC,OAAO,EAAC,QAAQ,EAAC,MAAM,YAAY,CAAC;AACpC,OAAO,EAAC,eAAe,EAAC,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAC,mBAAmB,EAAC,MAAM,uBAAuB,CAAC;AAC1D,OAAO,EAAC,aAAa,EAAC,MAAM,iBAAiB,CAAC;AAC9C,OAAO,EAAC,mBAAmB,EAAC,MAAM,uBAAuB,CAAC;AAe1D,MAAM,UAAU,GAAG,CAAsB,KAAQ,EAA2B,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;AAEhG,MAAM,uBAAuB,GAAG,MAAM,CAAC,GAAG,CAAA;;;;;CAKzC,CAAC;AAEF,MAAM,CAAC,MAAM,QAAQ,GAAsC,CAAC,EACxD,OAAO,EACP,WAAW,EACX,qBAAqB,GAAG,CAAC,MAAM,EAAE,YAAY,CAAC,EAC9C,kBAAkB,GAAG,CAAC,QAAQ,CAAC,EAClC,EAAE,EAAE;IACD,MAAM,gBAAgB,GAAG,IAAI,CAAC;IAE9B,MAAM,EAAC,IAAI,EAAE,OAAO,EAAE,OAAO,EAAC,GAAG,eAAe,CAAC,OAAO,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,qCAAqC;IAEpH,MAAM,EAAC,gBAAgB,EAAC,GAAG,mBAAmB,CAAC;QAC3C,SAAS,EAAE,UAAU,CAAC,qBAAqB,CAAC,IAAI,qBAAqB,CAAC,QAAQ,CAAC,YAAY,CAAC;KAC/F,CAAC,CAAC;IAEH,MAAM,EAAC,UAAU,EAAE,SAAS,EAAC,GAAG,aAAa,CAAC;QAC1C,SAAS,EAAE,UAAU,CAAC,qBAAqB,CAAC,IAAI,qBAAqB,CAAC,QAAQ,CAAC,MAAM,CAAC;KACzF,CAAC,CAAC;IAEH,MAAM,EAAC,YAAY,EAAE,WAAW,EAAC,GAAG,mBAAmB,CAAC;QACpD,SAAS,EAAE,UAAU,CAAC,kBAAkB,CAAC,IAAI,kBAAkB,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAClF,OAAO;QACP,OAAO;KACV,CAAC,CAAC;IAEH,OAAO,CACH,8BACK,OAAO,CAAC,CAAC,CAAC,CACP,YAAY,CACf,CAAC,CAAC,CAAC,CACA,8BACI,MAAC,uBAAuB,eACpB,KAAC,aAAa,CAAC,KAAK,IAAC,KAAK,EAAC,IAAI,YAC1B,OAAO,CAAC,yCAAyC,GAChC,EACrB,YAAY,IACS,EAC1B,KAAC,QAAQ,IACL,yBAAyB,EAAE,IAAI,IAAI,EAAE,EACrC,mBAAmB,EAAE,CAAC,gBAAgB,EAAE,QAAQ,CAAC,EACjD,WAAW,EAAE,CAAC,UAAU,EAAE,gBAAgB,EAAE,GAAG,WAAW,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,GAC7E,IACH,CACN,EACA,SAAS,EACT,WAAW,IACb,CACN,CAAC;AACN,CAAC,CAAC"}
1
+ {"version":3,"file":"Explorer.js","sourceRoot":"","sources":["../../../src/components/Explorer/Explorer.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,7 @@
1
+ import { FunctionComponent } from 'react';
2
+ interface IExplorerTitleProps {
3
+ title?: string;
4
+ library: string;
5
+ }
6
+ export declare const ExplorerTitle: FunctionComponent<IExplorerTitleProps>;
7
+ export {};
@@ -0,0 +1,30 @@
1
+ import { jsx as _jsx } 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 { localizedTranslation } from '@leav/utils';
6
+ import { useExplorerLibraryDataQuery } from '../../_gqlTypes';
7
+ import useLang from '../../hooks/useLang';
8
+ import { AntSkeleton } from 'aristid-ds';
9
+ // TODO: use <h1 /> tag
10
+ export const ExplorerTitle = ({ title, library }) => {
11
+ const { data, loading, error } = useExplorerLibraryDataQuery({ variables: { libraryId: library }, skip: !!title });
12
+ const { lang } = useLang();
13
+ if (title) {
14
+ return _jsx("span", { children: title });
15
+ }
16
+ if (loading) {
17
+ return _jsx(AntSkeleton.Input, { style: { width: 400 }, active: true });
18
+ }
19
+ // TODO: handle error and bad library ID
20
+ if (error) {
21
+ return _jsx("span", { children: error.message });
22
+ }
23
+ const libraryData = data?.libraries?.list[0];
24
+ if (!libraryData) {
25
+ // TODO: make it i18n
26
+ return _jsx("span", { children: "Unknown library" });
27
+ }
28
+ return _jsx("span", { children: localizedTranslation(libraryData.label, lang) });
29
+ };
30
+ //# sourceMappingURL=ExplorerTitle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ExplorerTitle.js","sourceRoot":"","sources":["../../../src/components/Explorer/ExplorerTitle.tsx"],"names":[],"mappings":";AAAA,oFAAoF;AACpF,sCAAsC;AACtC,sEAAsE;AACtE,OAAO,EAAC,oBAAoB,EAAC,MAAM,aAAa,CAAC;AACjD,OAAO,EAAC,2BAA2B,EAAC,MAAM,eAAe,CAAC;AAC1D,OAAO,OAAO,MAAM,mBAAmB,CAAC;AACxC,OAAO,EAAC,WAAW,EAAC,MAAM,YAAY,CAAC;AAQvC,uBAAuB;AACvB,MAAM,CAAC,MAAM,aAAa,GAA2C,CAAC,EAAC,KAAK,EAAE,OAAO,EAAC,EAAE,EAAE;IACtF,MAAM,EAAC,IAAI,EAAE,OAAO,EAAE,KAAK,EAAC,GAAG,2BAA2B,CAAC,EAAC,SAAS,EAAE,EAAC,SAAS,EAAE,OAAO,EAAC,EAAE,IAAI,EAAE,CAAC,CAAC,KAAK,EAAC,CAAC,CAAC;IAC7G,MAAM,EAAC,IAAI,EAAC,GAAG,OAAO,EAAE,CAAC;IAEzB,IAAI,KAAK,EAAE,CAAC;QACR,OAAO,yBAAO,KAAK,GAAQ,CAAC;IAChC,CAAC;IAED,IAAI,OAAO,EAAE,CAAC;QACV,OAAO,KAAC,WAAW,CAAC,KAAK,IAAC,KAAK,EAAE,EAAC,KAAK,EAAE,GAAG,EAAC,EAAE,MAAM,SAAG,CAAC;IAC7D,CAAC;IAED,wCAAwC;IACxC,IAAI,KAAK,EAAE,CAAC;QACR,OAAO,yBAAO,KAAK,CAAC,OAAO,GAAQ,CAAC;IACxC,CAAC;IAED,MAAM,WAAW,GAAG,IAAI,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;IAE7C,IAAI,CAAC,WAAW,EAAE,CAAC;QACf,qBAAqB;QACrB,OAAO,6CAA4B,CAAC;IACxC,CAAC;IAED,OAAO,yBAAO,oBAAoB,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,GAAQ,CAAC;AACxE,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { FunctionComponent } from 'react';
2
+ import { RecordIdentityFragment } from '../../_gqlTypes';
3
+ interface IIdCardProps {
4
+ item: RecordIdentityFragment['whoAmI'];
5
+ }
6
+ export declare const IdCard: FunctionComponent<IIdCardProps>;
7
+ export {};
@@ -0,0 +1,15 @@
1
+ import { jsx as _jsx } 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 { KitIdCard } from 'aristid-ds';
6
+ export const IdCard = ({ item }) => {
7
+ const { id, label, library, preview, subLabel } = item;
8
+ const itemLabel = label ?? id;
9
+ const avatarProps = { label: itemLabel };
10
+ if (preview) {
11
+ avatarProps.src = preview.small;
12
+ }
13
+ return _jsx(KitIdCard, { avatarProps: avatarProps, title: label ?? id, description: subLabel ?? library.id });
14
+ };
15
+ //# sourceMappingURL=IdCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IdCard.js","sourceRoot":"","sources":["../../../src/components/Explorer/IdCard.tsx"],"names":[],"mappings":";AAAA,oFAAoF;AACpF,sCAAsC;AACtC,sEAAsE;AACtE,OAAO,EAAC,SAAS,EAAC,MAAM,YAAY,CAAC;AASrC,MAAM,CAAC,MAAM,MAAM,GAAoC,CAAC,EAAC,IAAI,EAAC,EAAE,EAAE;IAC9D,MAAM,EAAC,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAC,GAAG,IAAI,CAAC;IACrD,MAAM,SAAS,GAAG,KAAK,IAAI,EAAE,CAAC;IAC9B,MAAM,WAAW,GAAe,EAAC,KAAK,EAAE,SAAS,EAAC,CAAC;IAEnD,IAAI,OAAO,EAAE,CAAC;QACV,WAAW,CAAC,GAAG,GAAG,OAAO,CAAC,KAAK,CAAC;IACpC,CAAC;IAED,OAAO,KAAC,SAAS,IAAC,WAAW,EAAE,WAAW,EAAE,KAAK,EAAE,KAAK,IAAI,EAAE,EAAE,WAAW,EAAE,QAAQ,IAAI,OAAO,CAAC,EAAE,GAAI,CAAC;AAC5G,CAAC,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { AttributePropertiesFragment, PropertyValueFragment } from '../../_gqlTypes';
2
+ import { FunctionComponent } from 'react';
3
+ interface ITableCellProps {
4
+ values: PropertyValueFragment[];
5
+ attributeProperties: AttributePropertiesFragment;
6
+ }
7
+ export declare const TableCell: FunctionComponent<ITableCellProps>;
8
+ export {};
@@ -0,0 +1,110 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, 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 { AttributeFormat, AttributeType } from '../../_gqlTypes';
6
+ import { useSharedTranslation } from '../../hooks/useSharedTranslation';
7
+ import { KitAvatar, KitTag, KitTypography } from 'aristid-ds';
8
+ import styled from 'styled-components';
9
+ import { IdCard } from './IdCard';
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);
18
+ const StyledCenteringWrapper = styled.div `
19
+ display: flex;
20
+ align-items: center;
21
+ gap: calc(var(--general-spacing-xs) * 1px);
22
+ `;
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 }) => {
33
+ const { t } = useSharedTranslation();
34
+ if (attributeProperties.multiple_values) {
35
+ if (isStandardValues(values, attributeProperties)) {
36
+ const tags = values.map(value => {
37
+ switch (attributeProperties.format) {
38
+ case AttributeFormat.boolean:
39
+ return {
40
+ idCardProps: {
41
+ description: value.valuePayload ? String(t('global.yes')) : String(t('global.no'))
42
+ },
43
+ type: value.valuePayload ? 'primary' : 'neutral'
44
+ };
45
+ default:
46
+ const valueContent = attributeProperties.format === AttributeFormat.encrypted
47
+ ? '●●●●●●●●●●●●'
48
+ : value.valuePayload;
49
+ return {
50
+ idCardProps: { description: valueContent },
51
+ type: 'primary'
52
+ };
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;
79
+ }
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;
99
+ }
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
+ }
109
+ };
110
+ //# sourceMappingURL=TableCell.js.map
@@ -0,0 +1 @@
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"}
@@ -0,0 +1,24 @@
1
+ import { IExplorerData } from '../_types';
2
+ import { ExplorerQuery, SortOrder } from '../../../_gqlTypes';
3
+ export declare const useExplorerData: ({ libraryId, attributeIds, sorts, pagination }: {
4
+ libraryId: string;
5
+ attributeIds: string[];
6
+ sorts: Array<{
7
+ attributeId: string;
8
+ order: SortOrder;
9
+ }>;
10
+ pagination: null | {
11
+ limit: number;
12
+ offset: number;
13
+ };
14
+ }) => {
15
+ data: IExplorerData;
16
+ loading: boolean;
17
+ refetch: (variables?: Partial<import("../../../_gqlTypes").Exact<{
18
+ libraryId: import("../../../_gqlTypes").Scalars["ID"];
19
+ attributeIds: Array<import("../../../_gqlTypes").Scalars["ID"]> | import("../../../_gqlTypes").Scalars["ID"];
20
+ pagination?: import("../../../_gqlTypes").InputMaybe<import("../../../_gqlTypes").RecordsPagination>;
21
+ filters?: import("../../../_gqlTypes").InputMaybe<Array<import("../../../_gqlTypes").InputMaybe<import("../../../_gqlTypes").RecordFilterInput>> | import("../../../_gqlTypes").InputMaybe<import("../../../_gqlTypes").RecordFilterInput>>;
22
+ multipleSort?: import("../../../_gqlTypes").InputMaybe<Array<import("../../../_gqlTypes").RecordSortInput> | import("../../../_gqlTypes").RecordSortInput>;
23
+ }>>) => Promise<import("@apollo/client").ApolloQueryResult<ExplorerQuery>>;
24
+ };
@@ -0,0 +1,55 @@
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 { localizedTranslation } from '@leav/utils';
5
+ import { useExplorerQuery } from '../../../_gqlTypes';
6
+ import { useLang } from '../../../hooks';
7
+ const _mapping = (data, libraryId, availableLangs) => {
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
+ : {};
17
+ const records = data.records.list.map(({ whoAmI, properties }) => ({
18
+ libraryId,
19
+ key: whoAmI.id, // For <KitTable /> only
20
+ itemId: whoAmI.id, // For <KitTable /> only
21
+ whoAmI: {
22
+ label: null,
23
+ subLabel: null,
24
+ color: null,
25
+ preview: null,
26
+ ...whoAmI
27
+ },
28
+ propertiesById: properties.reduce((acc, { attributeId, values }) => ({ ...acc, [attributeId]: values }), {})
29
+ }));
30
+ return {
31
+ totalCount: data.records.totalCount ?? 0,
32
+ attributes,
33
+ records
34
+ };
35
+ };
36
+ export const useExplorerData = ({ libraryId, attributeIds, sorts, pagination }) => {
37
+ const { lang: availableLangs } = useLang();
38
+ const { data, loading, refetch } = useExplorerQuery({
39
+ variables: {
40
+ libraryId,
41
+ attributeIds,
42
+ pagination,
43
+ multipleSort: sorts.map(({ order, attributeId }) => ({
44
+ field: attributeId,
45
+ order
46
+ }))
47
+ }
48
+ });
49
+ return {
50
+ data: data !== undefined ? _mapping(data, libraryId, availableLangs) : null,
51
+ loading,
52
+ refetch
53
+ };
54
+ };
55
+ //# sourceMappingURL=useExplorerData.js.map
@@ -0,0 +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,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,KAAK,EACL,UAAU,EASb,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,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"}
@@ -0,0 +1,35 @@
1
+ import { Override } from '@leav/utils';
2
+ import { AttributePropertiesFragment, PropertyValueFragment, RecordIdentityFragment } from '../../_gqlTypes';
3
+ import { ReactElement } from 'react';
4
+ export interface IExplorerData {
5
+ totalCount: number;
6
+ attributes: {
7
+ [attributeId: string]: Override<AttributePropertiesFragment, {
8
+ label: string;
9
+ }>;
10
+ };
11
+ records: IItemData[];
12
+ }
13
+ export interface IItemData {
14
+ libraryId: string;
15
+ key: string;
16
+ itemId: string;
17
+ whoAmI: Required<RecordIdentityFragment['whoAmI']>;
18
+ propertiesById: {
19
+ [attributeId: string]: PropertyValueFragment[];
20
+ };
21
+ }
22
+ export interface IItemAction {
23
+ callback: (item: IItemData) => void;
24
+ icon: ReactElement;
25
+ label: string;
26
+ isDanger?: boolean;
27
+ }
28
+ export interface IPrimaryAction {
29
+ callback: () => void;
30
+ icon: ReactElement;
31
+ label: string;
32
+ }
33
+ export type ActionHook<T = {}> = {
34
+ isEnabled: boolean;
35
+ } & T;
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=_types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_types.js","sourceRoot":"","sources":["../../../src/components/Explorer/_types.ts"],"names":[],"mappings":""}
@@ -1 +1,9 @@
1
- export { Explorer } from './Explorer';
1
+ import { Explorer as InternalExplorer } from './Explorer';
2
+ import { useEditSettings, SidePanel, EditSettingsContextProvider } from './manage-view-settings';
3
+ type CompoundedComponent = typeof InternalExplorer & {
4
+ useEditSettings: typeof useEditSettings;
5
+ EditSettingsContextProvider: typeof EditSettingsContextProvider;
6
+ SettingsSidePanel: typeof SidePanel;
7
+ };
8
+ export declare const Explorer: CompoundedComponent;
9
+ export {};
@@ -1,5 +1,10 @@
1
1
  // Copyright LEAV Solutions 2017 until 2023/11/05, Copyright Aristid from 2023/11/06
2
2
  // This file is released under LGPL V3
3
3
  // License text available at https://www.gnu.org/licenses/lgpl-3.0.txt
4
- export { Explorer } from './Explorer';
4
+ import { Explorer as InternalExplorer } from './Explorer';
5
+ import { useEditSettings, SidePanel, EditSettingsContextProvider } from './manage-view-settings';
6
+ export const Explorer = InternalExplorer;
7
+ Explorer.EditSettingsContextProvider = EditSettingsContextProvider;
8
+ Explorer.useEditSettings = useEditSettings;
9
+ Explorer.SettingsSidePanel = SidePanel;
5
10
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Explorer/index.tsx"],"names":[],"mappings":"AAAA,oFAAoF;AACpF,sCAAsC;AACtC,sEAAsE;AACtE,OAAO,EAAC,QAAQ,EAAC,MAAM,YAAY,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Explorer/index.ts"],"names":[],"mappings":"AAAA,oFAAoF;AACpF,sCAAsC;AACtC,sEAAsE;AACtE,OAAO,EAAC,QAAQ,IAAI,gBAAgB,EAAC,MAAM,YAAY,CAAC;AACxD,OAAO,EAAC,eAAe,EAAE,SAAS,EAAE,2BAA2B,EAAC,MAAM,wBAAwB,CAAC;AAQ/F,MAAM,CAAC,MAAM,QAAQ,GAAG,gBAAkD,CAAC;AAC3E,QAAQ,CAAC,2BAA2B,GAAG,2BAA2B,CAAC;AACnE,QAAQ,CAAC,eAAe,GAAG,eAAe,CAAC;AAC3C,QAAQ,CAAC,iBAAiB,GAAG,SAAS,CAAC"}
@@ -0,0 +1,12 @@
1
+ import { FunctionComponent, ReactNode } from 'react';
2
+ interface IColumnItemProps {
3
+ itemId: string;
4
+ dragHandler?: ReactNode;
5
+ visible: boolean;
6
+ title: string;
7
+ onVisibilityClick?: () => void;
8
+ disabled?: boolean;
9
+ value?: string;
10
+ }
11
+ export declare const ColumnItem: FunctionComponent<IColumnItemProps>;
12
+ export {};
@@ -0,0 +1,77 @@
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 { KitTypography } from 'aristid-ds';
6
+ import { FaEye, FaEyeSlash } from 'react-icons/fa';
7
+ import styled from 'styled-components';
8
+ import { useSortable } from '@dnd-kit/sortable';
9
+ import { CSS } from '@dnd-kit/utilities';
10
+ import { useSharedTranslation } from '../../../../hooks/useSharedTranslation';
11
+ const StyledValue = styled(KitTypography.Text) `
12
+ color: var(--general-utilities-disabled);
13
+ `;
14
+ const StyledConfigurationItem = styled.li `
15
+ color: var(--general-utilities-text-primary);
16
+ display: flex;
17
+ width: 100%;
18
+ height: 40px;
19
+ padding: 0 calc(var(--general-spacing-xs) * 1px);
20
+ align-items: center;
21
+ gap: calc(var(--general-spacing-xs) * 1px);
22
+ border-radius: calc(var(--general-spacing-xs) * 1px);
23
+ text-align: left;
24
+
25
+ &:first-child {
26
+ margin-top: calc(var(--general-spacing-xs) * 1px);
27
+ }
28
+
29
+ &:hover {
30
+ background: var(--general-utilities-main-light);
31
+
32
+ ${StyledValue} {
33
+ color: var(--general-utilities-text-primary);
34
+ }
35
+ }
36
+
37
+ .title {
38
+ flex: 1 1 auto;
39
+ }
40
+
41
+ > svg {
42
+ flex: 0 0 calc(var(--general-spacing-s) * 1px);
43
+ }
44
+
45
+ > button {
46
+ border: none;
47
+ background: transparent;
48
+ padding: 0;
49
+ &:not([disabled]) {
50
+ cursor: pointer;
51
+ }
52
+ }
53
+ `;
54
+ const StyledFaEye = styled(FaEye) `
55
+ color: currentColor;
56
+ `;
57
+ const StyledEyeSlash = styled(FaEyeSlash) `
58
+ color: var(--general-utilities-disabled);
59
+ `;
60
+ const StyledDragHandle = styled.span `
61
+ cursor: ${props => (props.$isDragging ? 'grabbing' : 'grab')};
62
+ `;
63
+ const StyledEmptyIcon = styled.div `
64
+ width: calc(var(--general-spacing-s) * 1px);
65
+ `;
66
+ export const ColumnItem = ({ itemId, dragHandler, title, disabled, visible, onVisibilityClick }) => {
67
+ const { t } = useSharedTranslation();
68
+ const { attributes, listeners, setNodeRef, transform, transition, isDragging } = useSortable({ id: itemId });
69
+ const style = {
70
+ transform: CSS.Transform.toString(transform),
71
+ transition
72
+ };
73
+ const _handleClick = () => onVisibilityClick?.();
74
+ const visibilityButtonLabel = visible ? t('explorer.hide') : t('explorer.show');
75
+ return (_jsxs(StyledConfigurationItem, { className: disabled ? 'disabled' : '', ref: setNodeRef, style: style, children: [dragHandler ? (_jsx(StyledDragHandle, { ...attributes, ...listeners, "$isDragging": isDragging, children: dragHandler })) : (_jsx(StyledEmptyIcon, {})), _jsx(KitTypography.Text, { size: "fontSize5", ellipsis: true, className: "title", children: title }), _jsx("button", { disabled: disabled, onClick: _handleClick, title: visibilityButtonLabel, "aria-label": visibilityButtonLabel, children: visible ? _jsx(StyledFaEye, {}) : _jsx(StyledEyeSlash, {}) })] }));
76
+ };
77
+ //# sourceMappingURL=ColumnItem.js.map
@@ -0,0 +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;;;;;;;;;;;;;;;;;;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"}