@zextras/carbonio-shell-ui 9.0.1 → 10.0.0-devel.1741258975575

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 (167) hide show
  1. package/THIRDPARTIES +431 -0
  2. package/lib/boot/app/app-context-provider.d.ts +5 -0
  3. package/lib/boot/app/app-context-provider.js +5 -0
  4. package/lib/boot/app/app-context-provider.js.map +1 -1
  5. package/lib/boot/app/app-dependant-exports.d.ts +1 -9
  6. package/lib/boot/app/app-dependant-exports.js +1 -11
  7. package/lib/boot/app/app-dependant-exports.js.map +1 -1
  8. package/lib/boot/app/app-direct-exports.d.ts +21 -9
  9. package/lib/boot/app/app-direct-exports.js +20 -37
  10. package/lib/boot/app/app-direct-exports.js.map +1 -1
  11. package/lib/boot/app/app-error-catcher.js +17 -7
  12. package/lib/boot/app/app-error-catcher.js.map +1 -1
  13. package/lib/constants/index.d.ts +4 -54
  14. package/lib/constants/index.js +8 -65
  15. package/lib/constants/index.js.map +1 -1
  16. package/lib/constants/locales.d.ts +6 -87
  17. package/lib/constants/locales.js +87 -23
  18. package/lib/constants/locales.js.map +1 -1
  19. package/lib/dark-mode/use-dark-reader-result-value.js +4 -5
  20. package/lib/dark-mode/use-dark-reader-result-value.js.map +1 -1
  21. package/lib/history/hooks.d.ts +0 -10
  22. package/lib/history/hooks.js +1 -51
  23. package/lib/history/hooks.js.map +1 -1
  24. package/lib/lib.d.ts +9 -15
  25. package/lib/lib.js +1 -3
  26. package/lib/lib.js.map +1 -1
  27. package/lib/network/edit-settings.d.ts +1 -1
  28. package/lib/network/fetch-utils.d.ts +1 -1
  29. package/lib/network/fetch.d.ts +10 -4
  30. package/lib/network/fetch.js +18 -4
  31. package/lib/network/fetch.js.map +1 -1
  32. package/lib/network/logout.d.ts +1 -0
  33. package/lib/network/logout.js +29 -0
  34. package/lib/network/logout.js.map +1 -0
  35. package/lib/network/utils.js +2 -3
  36. package/lib/network/utils.js.map +1 -1
  37. package/lib/settings/components/settings-header.js +22 -16
  38. package/lib/settings/components/settings-header.js.map +1 -1
  39. package/lib/shell/creation-button.d.ts +1 -1
  40. package/lib/shell/creation-button.js +24 -8
  41. package/lib/shell/creation-button.js.map +1 -1
  42. package/lib/shell/hooks/useLocalStorage.js +2 -2
  43. package/lib/shell/hooks/useLocalStorage.js.map +1 -1
  44. package/lib/store/account/hooks.js +2 -1
  45. package/lib/store/account/hooks.js.map +1 -1
  46. package/lib/store/account/utils.js +4 -5
  47. package/lib/store/account/utils.js.map +1 -1
  48. package/lib/store/app/hooks.d.ts +0 -6
  49. package/lib/store/app/hooks.js +1 -13
  50. package/lib/store/app/hooks.js.map +1 -1
  51. package/lib/store/app/store.d.ts +2 -4
  52. package/lib/store/app/store.js +5 -28
  53. package/lib/store/app/store.js.map +1 -1
  54. package/lib/store/app/utils.d.ts +2 -3
  55. package/lib/store/app/utils.js +1 -14
  56. package/lib/store/app/utils.js.map +1 -1
  57. package/lib/store/boards/hooks.js +17 -7
  58. package/lib/store/boards/hooks.js.map +1 -1
  59. package/lib/store/boards/store.d.ts +4 -4
  60. package/lib/store/i18n/store.js +14 -4
  61. package/lib/store/i18n/store.js.map +1 -1
  62. package/lib/store/integrations/composer.d.ts +1 -1
  63. package/lib/store/integrations/composer.js +17 -7
  64. package/lib/store/integrations/composer.js.map +1 -1
  65. package/lib/store/integrations/getters.d.ts +4 -4
  66. package/lib/store/integrations/getters.js +3 -1
  67. package/lib/store/integrations/getters.js.map +1 -1
  68. package/lib/store/integrations/hooks.d.ts +4 -4
  69. package/lib/store/integrations/hooks.js.map +1 -1
  70. package/lib/store/integrations/utils.d.ts +2 -2
  71. package/lib/store/integrations/utils.js +12 -8
  72. package/lib/store/integrations/utils.js.map +1 -1
  73. package/lib/store/login/getters.js +2 -3
  74. package/lib/store/login/getters.js.map +1 -1
  75. package/lib/store/login/hooks.js +4 -4
  76. package/lib/store/login/hooks.js.map +1 -1
  77. package/lib/store/network/hooks.js +4 -2
  78. package/lib/store/network/hooks.js.map +1 -1
  79. package/lib/store/network/utils.d.ts +1 -2
  80. package/lib/store/network/utils.js +4 -40
  81. package/lib/store/network/utils.js.map +1 -1
  82. package/lib/types/apps/index.d.ts +2 -15
  83. package/lib/types/misc/index.d.ts +1 -45
  84. package/lib/types/network/index.d.ts +6 -31
  85. package/lib/types/network/soap.d.ts +1 -0
  86. package/lib/types/network/soap.js +4 -0
  87. package/lib/types/network/soap.js.map +1 -1
  88. package/lib/types/tags/index.d.ts +0 -4
  89. package/lib/types/theme.d.ts +10 -0
  90. package/lib/types/{search/items.js → theme.js} +1 -1
  91. package/lib/types/theme.js.map +1 -0
  92. package/lib/ui-extras/auth-guard.d.ts +5 -0
  93. package/lib/ui-extras/auth-guard.js +14 -0
  94. package/lib/ui-extras/auth-guard.js.map +1 -0
  95. package/lib/ui-extras/nav-guard.d.ts +1 -1
  96. package/lib/ui-extras/nav-guard.js +39 -47
  97. package/lib/ui-extras/nav-guard.js.map +1 -1
  98. package/lib/utility-bar/bar.d.ts +19 -0
  99. package/lib/utility-bar/bar.js +129 -0
  100. package/lib/utility-bar/bar.js.map +1 -0
  101. package/lib/utility-bar/store.d.ts +2 -0
  102. package/lib/utility-bar/store.js +19 -0
  103. package/lib/utility-bar/store.js.map +1 -0
  104. package/lib/utility-bar/utils.d.ts +4 -0
  105. package/lib/utility-bar/utils.js +30 -0
  106. package/lib/utility-bar/utils.js.map +1 -0
  107. package/lib/utils/typeUtils.d.ts +0 -1
  108. package/lib/utils/utils.d.ts +0 -3
  109. package/lib/utils/utils.js +4 -6
  110. package/lib/utils/utils.js.map +1 -1
  111. package/package.json +31 -32
  112. package/lib/network/tags.d.ts +0 -27
  113. package/lib/network/tags.js +0 -31
  114. package/lib/network/tags.js.map +0 -1
  115. package/lib/search/run-search.d.ts +0 -2
  116. package/lib/search/run-search.js +0 -17
  117. package/lib/search/run-search.js.map +0 -1
  118. package/lib/search/search-store.d.ts +0 -2
  119. package/lib/search/search-store.js +0 -20
  120. package/lib/search/search-store.js.map +0 -1
  121. package/lib/search/useSearchModule.d.ts +0 -3
  122. package/lib/search/useSearchModule.js +0 -21
  123. package/lib/search/useSearchModule.js.map +0 -1
  124. package/lib/store/context-bridge.d.ts +0 -11
  125. package/lib/store/context-bridge.js +0 -34
  126. package/lib/store/context-bridge.js.map +0 -1
  127. package/lib/store/folder/hooks.d.ts +0 -21
  128. package/lib/store/folder/hooks.js +0 -77
  129. package/lib/store/folder/hooks.js.map +0 -1
  130. package/lib/store/folder/index.d.ts +0 -2
  131. package/lib/store/folder/index.js +0 -24
  132. package/lib/store/folder/index.js.map +0 -1
  133. package/lib/store/folder/store.d.ts +0 -2
  134. package/lib/store/folder/store.js +0 -20
  135. package/lib/store/folder/store.js.map +0 -1
  136. package/lib/store/folder/utils.d.ts +0 -16
  137. package/lib/store/folder/utils.js +0 -53
  138. package/lib/store/folder/utils.js.map +0 -1
  139. package/lib/store/tags/hooks.d.ts +0 -3
  140. package/lib/store/tags/hooks.js +0 -15
  141. package/lib/store/tags/hooks.js.map +0 -1
  142. package/lib/store/tags/index.d.ts +0 -2
  143. package/lib/store/tags/index.js +0 -24
  144. package/lib/store/tags/index.js.map +0 -1
  145. package/lib/store/tags/store.d.ts +0 -2
  146. package/lib/store/tags/store.js +0 -18
  147. package/lib/store/tags/store.js.map +0 -1
  148. package/lib/types/folder/index.d.ts +0 -29
  149. package/lib/types/folder/index.js +0 -8
  150. package/lib/types/folder/index.js.map +0 -1
  151. package/lib/types/search/index.d.ts +0 -11
  152. package/lib/types/search/index.js +0 -23
  153. package/lib/types/search/index.js.map +0 -1
  154. package/lib/types/search/items.d.ts +0 -6
  155. package/lib/types/search/items.js.map +0 -1
  156. package/lib/types/workers/index.d.ts +0 -17
  157. package/lib/types/workers/index.js +0 -3
  158. package/lib/types/workers/index.js.map +0 -1
  159. package/lib/ui-extras/app-link.d.ts +0 -6
  160. package/lib/ui-extras/app-link.js +0 -40
  161. package/lib/ui-extras/app-link.js.map +0 -1
  162. package/lib/ui-extras/spinner.d.ts +0 -2
  163. package/lib/ui-extras/spinner.js +0 -18
  164. package/lib/ui-extras/spinner.js.map +0 -1
  165. package/lib/workers/index.d.ts +0 -2
  166. package/lib/workers/index.js +0 -15
  167. package/lib/workers/index.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"soap.js","sourceRoot":"","sources":["../../../src/types/network/soap.ts"],"names":[],"mappings":";AAAA;;;;GAIG"}
1
+ {"version":3,"file":"soap.js","sourceRoot":"","sources":["../../../src/types/network/soap.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;AA6DH,wDAIC;AAJD,SAAgB,sBAAsB,CACrC,IAA8C;IAE9C,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,KAAK,SAAS,CAAC;AACtC,CAAC"}
@@ -6,7 +6,3 @@ export type Tag = {
6
6
  u?: number;
7
7
  n?: number;
8
8
  };
9
- export type Tags = Record<string, Tag>;
10
- export type TagState = {
11
- tags: Tags;
12
- };
@@ -0,0 +1,10 @@
1
+ import type { CSSProperties } from 'react';
2
+ declare module '@zextras/carbonio-design-system' {
3
+ interface Theme {
4
+ globalCursors: CSSProperties['cursor'][];
5
+ }
6
+ interface Palette {
7
+ shared: ThemeColorObj;
8
+ linked: ThemeColorObj;
9
+ }
10
+ }
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=items.js.map
3
+ //# sourceMappingURL=theme.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"theme.js","sourceRoot":"","sources":["../../src/types/theme.ts"],"names":[],"mappings":""}
@@ -0,0 +1,5 @@
1
+ import type { ReactNode } from 'react';
2
+ export type AuthGuardProps = {
3
+ children: ReactNode;
4
+ };
5
+ export declare const AuthGuard: ({ children }: AuthGuardProps) => ReactNode;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.AuthGuard = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const account_1 = require("../store/account");
9
+ const AuthGuard = ({ children }) => {
10
+ const isAuthenticated = (0, account_1.useAuthenticated)();
11
+ return isAuthenticated ? react_1.default.createElement(react_1.default.Fragment, null, children) : null;
12
+ };
13
+ exports.AuthGuard = AuthGuard;
14
+ //# sourceMappingURL=auth-guard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth-guard.js","sourceRoot":"","sources":["../../src/ui-extras/auth-guard.tsx"],"names":[],"mappings":";;;;;;AAMA,kDAA0B;AAE1B,8CAAoD;AAM7C,MAAM,SAAS,GAAG,CAAC,EAAE,QAAQ,EAAkB,EAAa,EAAE;IACpE,MAAM,eAAe,GAAG,IAAA,0BAAgB,GAAE,CAAC;IAE3C,OAAO,eAAe,CAAC,CAAC,CAAC,8DAAG,QAAQ,CAAI,CAAC,CAAC,CAAC,IAAI,CAAC;AACjD,CAAC,CAAC;AAJW,QAAA,SAAS,aAIpB"}
@@ -2,7 +2,7 @@ import React from 'react';
2
2
  import type { ModalProps } from '@zextras/carbonio-design-system';
3
3
  export interface RouteLeavingGuardProps {
4
4
  children: ModalProps['children'];
5
- when?: boolean;
5
+ when: boolean;
6
6
  onSave: () => Promise<PromiseSettledResult<Awaited<unknown>>[]>;
7
7
  dataHasError?: boolean;
8
8
  }
@@ -20,48 +20,44 @@ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (
20
20
  }) : function(o, v) {
21
21
  o["default"] = v;
22
22
  });
23
- var __importStar = (this && this.__importStar) || function (mod) {
24
- if (mod && mod.__esModule) return mod;
25
- var result = {};
26
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
27
- __setModuleDefault(result, mod);
28
- return result;
29
- };
23
+ var __importStar = (this && this.__importStar) || (function () {
24
+ var ownKeys = function(o) {
25
+ ownKeys = Object.getOwnPropertyNames || function (o) {
26
+ var ar = [];
27
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
28
+ return ar;
29
+ };
30
+ return ownKeys(o);
31
+ };
32
+ return function (mod) {
33
+ if (mod && mod.__esModule) return mod;
34
+ var result = {};
35
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
36
+ __setModuleDefault(result, mod);
37
+ return result;
38
+ };
39
+ })();
30
40
  Object.defineProperty(exports, "__esModule", { value: true });
31
41
  exports.RouteLeavingGuard = void 0;
32
42
  const react_1 = __importStar(require("react"));
33
43
  const carbonio_design_system_1 = require("@zextras/carbonio-design-system");
34
44
  const lodash_1 = require("lodash");
45
+ const react_i18next_1 = require("react-i18next");
35
46
  const react_router_dom_1 = require("react-router-dom");
36
- const hooks_1 = require("../store/i18n/hooks");
47
+ function areLocationsDifferent(loc1, loc2) {
48
+ return loc1.pathname !== loc2.pathname || loc1.search !== loc2.search || loc1.hash !== loc2.hash;
49
+ }
37
50
  const RouteLeavingGuard = ({ children, when, onSave, dataHasError = false }) => {
38
- const history = (0, react_router_dom_1.useHistory)();
39
- const lastLocationInitial = (0, react_1.useMemo)(() => history.location, [history]);
40
- const [modalVisible, setModalVisible] = (0, react_1.useState)(false);
41
- const lastLocationRef = (0, react_1.useRef)(lastLocationInitial);
42
- const confirmedNavigationRef = (0, react_1.useRef)(false);
43
- const t = (0, hooks_1.getT)();
51
+ const [t] = (0, react_i18next_1.useTranslation)();
52
+ const blockerFunction = ({ currentLocation, nextLocation }) => {
53
+ const areDifferent = areLocationsDifferent(currentLocation, nextLocation);
54
+ return when && areDifferent;
55
+ };
56
+ // Block navigating elsewhere when data has been entered into the input
57
+ const blocker = (0, react_router_dom_1.useBlocker)(blockerFunction);
44
58
  const cancel = (0, react_1.useCallback)(() => {
45
- setModalVisible(false);
46
- confirmedNavigationRef.current = false;
47
- }, []);
48
- const confirmNavigation = (0, react_1.useCallback)(() => {
49
- confirmedNavigationRef.current = true;
50
- if (lastLocationRef.current) {
51
- // Navigate to the previous blocked location with your navigate function
52
- history.push(lastLocationRef.current);
53
- }
54
- }, [history]);
55
- const handleBlockedNavigation = (0, react_1.useCallback)((nextLocation) => {
56
- if (!confirmedNavigationRef.current &&
57
- `${nextLocation.pathname}${nextLocation.search || ''}` !==
58
- `${history.location.pathname}${history.location.search}`) {
59
- setModalVisible(true);
60
- lastLocationRef.current = nextLocation;
61
- return false;
62
- }
63
- return true;
64
- }, [history.location.pathname, history.location.search]);
59
+ blocker.reset?.();
60
+ }, [blocker]);
65
61
  const onConfirm = (0, react_1.useCallback)(() => {
66
62
  onSave()
67
63
  .then((results) => {
@@ -71,26 +67,22 @@ const RouteLeavingGuard = ({ children, when, onSave, dataHasError = false }) =>
71
67
  cancel();
72
68
  }
73
69
  else {
74
- setModalVisible(false);
75
- confirmNavigation();
70
+ blocker.proceed?.();
76
71
  }
77
72
  })
78
73
  .catch((reason) => {
79
74
  console.error(reason);
80
75
  cancel();
81
76
  });
82
- }, [cancel, confirmNavigation, onSave]);
77
+ }, [blocker, cancel, onSave]);
83
78
  const onSecondaryAction = (0, react_1.useCallback)(() => {
84
- setModalVisible(false);
85
- confirmNavigation();
86
- }, [confirmNavigation]);
87
- return (react_1.default.createElement(react_1.default.Fragment, null,
88
- react_1.default.createElement(react_router_dom_1.Prompt, { when: when, message: handleBlockedNavigation }),
89
- react_1.default.createElement(carbonio_design_system_1.Modal, { showCloseIcon: true, closeIconTooltip: t('label.close', 'Close'), open: modalVisible, title: dataHasError
90
- ? t('label.cannot_save_changes', 'Some changes cannot be saved')
91
- : t('label.unsaved_changes', 'You have unsaved changes'), onClose: cancel, onConfirm: dataHasError ? onSecondaryAction : onConfirm, confirmLabel: dataHasError
92
- ? t('label.leave_anyway', 'Leave anyway')
93
- : t('label.save_and_leave', 'Save and leave'), onSecondaryAction: dataHasError ? cancel : onSecondaryAction, secondaryActionLabel: dataHasError ? t('label.cancel', 'Cancel') : t('label.leave_anyway', 'Leave anyway'), optionalFooter: !dataHasError ? (react_1.default.createElement(carbonio_design_system_1.Button, { color: "secondary", type: "outlined", label: t('label.cancel', 'Cancel'), onClick: cancel })) : undefined }, children)));
79
+ blocker.proceed?.();
80
+ }, [blocker]);
81
+ return (react_1.default.createElement(carbonio_design_system_1.Modal, { showCloseIcon: true, closeIconTooltip: t('label.close', 'Close'), open: blocker.state === 'blocked', title: dataHasError
82
+ ? t('label.cannot_save_changes', 'Some changes cannot be saved')
83
+ : t('label.unsaved_changes', 'You have unsaved changes'), onClose: cancel, onConfirm: dataHasError ? onSecondaryAction : onConfirm, confirmLabel: dataHasError
84
+ ? t('label.leave_anyway', 'Leave anyway')
85
+ : t('label.save_and_leave', 'Save and leave'), onSecondaryAction: dataHasError ? cancel : onSecondaryAction, secondaryActionLabel: dataHasError ? t('label.cancel', 'Cancel') : t('label.leave_anyway', 'Leave anyway'), optionalFooter: !dataHasError ? (react_1.default.createElement(carbonio_design_system_1.Button, { color: "secondary", type: "outlined", label: t('label.cancel', 'Cancel'), onClick: cancel })) : undefined }, children));
94
86
  };
95
87
  exports.RouteLeavingGuard = RouteLeavingGuard;
96
88
  //# sourceMappingURL=nav-guard.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"nav-guard.js","sourceRoot":"","sources":["../../src/ui-extras/nav-guard.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"nav-guard.js","sourceRoot":"","sources":["../../src/ui-extras/nav-guard.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,19 @@
1
+ import React from 'react';
2
+ import type { DropdownItem } from '@zextras/carbonio-design-system';
3
+ import type { UtilityView } from '../types/apps';
4
+ import type { Action } from '../types/integrations';
5
+ export interface UtilityBarItemProps {
6
+ view: UtilityView;
7
+ }
8
+ /**
9
+ * Interface representing an account menu action.
10
+ *
11
+ * This interface extends the `Action` interface and omits the `label` and `onClick` properties
12
+ * from the `DropdownItem` interface. It includes an `execute` function and a `position` property.
13
+ *
14
+ */
15
+ export interface AccountMenuAction extends Action, Omit<DropdownItem, 'label' | 'onClick'> {
16
+ execute: NonNullable<DropdownItem['onClick']>;
17
+ position: number;
18
+ }
19
+ export declare const ShellUtilityBar: () => React.JSX.Element;
@@ -0,0 +1,129 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.ShellUtilityBar = void 0;
37
+ /*
38
+ * SPDX-FileCopyrightText: 2022 Zextras <https://www.zextras.com>
39
+ *
40
+ * SPDX-License-Identifier: AGPL-3.0-only
41
+ */
42
+ const react_1 = __importStar(require("react"));
43
+ const carbonio_design_system_1 = require("@zextras/carbonio-design-system");
44
+ const lodash_1 = require("lodash");
45
+ const store_1 = require("./store");
46
+ const utils_1 = require("./utils");
47
+ const constants_1 = require("../constants");
48
+ const logout_1 = require("../network/logout");
49
+ const account_1 = require("../store/account");
50
+ const hooks_1 = require("../store/i18n/hooks");
51
+ const hooks_2 = require("../store/integrations/hooks");
52
+ const tracker_1 = require("../tracker/tracker");
53
+ const UtilityBarItem = ({ view }) => {
54
+ const { mode, setMode, current, setCurrent } = (0, store_1.useUtilityBarStore)();
55
+ const onClick = (0, react_1.useCallback)(() => {
56
+ setMode((current !== view.id && 'open') || (mode !== 'open' && 'open') || 'closed');
57
+ setCurrent(view.id);
58
+ }, [current, mode, setCurrent, setMode, view.id]);
59
+ if (typeof view.button === 'string') {
60
+ return (react_1.default.createElement(carbonio_design_system_1.Tooltip, { label: view.label, placement: "bottom-end" },
61
+ react_1.default.createElement(carbonio_design_system_1.IconButton, { icon: view.button, iconColor: current === view.id ? 'primary' : 'text', onClick: onClick, size: "large" })));
62
+ }
63
+ return react_1.default.createElement(view.button, { mode: mode, setMode: setMode });
64
+ };
65
+ const ShellUtilityBar = () => {
66
+ const views = (0, utils_1.useUtilityViews)();
67
+ const t = (0, hooks_1.getT)();
68
+ const account = (0, account_1.useAccountStore)((s) => s.account);
69
+ const updateViews = (0, react_1.useCallback)(() => {
70
+ const updateViewEvent = new CustomEvent(constants_1.CUSTOM_EVENTS.updateView);
71
+ window.dispatchEvent(updateViewEvent);
72
+ }, []);
73
+ const { reset } = (0, tracker_1.useTracker)();
74
+ const actions = (0, hooks_2.useActions)(undefined, constants_1.ACTION_TYPES.ACCOUNT_MENU);
75
+ const accountMenuItems = (0, react_1.useMemo)(() => actions
76
+ .toSorted((a, b) => a.position - b.position)
77
+ .map(({ execute, position: _position, ...action }) => ({
78
+ onClick: execute,
79
+ ...action
80
+ })), [actions]);
81
+ const accountItems = (0, react_1.useMemo)(() => [
82
+ {
83
+ id: 'account',
84
+ label: account?.displayName ?? 'Account',
85
+ disabled: true
86
+ },
87
+ {
88
+ id: 'email',
89
+ label: account?.name ?? '',
90
+ disabled: true
91
+ },
92
+ {
93
+ type: 'divider',
94
+ id: 'divider',
95
+ label: 'divider'
96
+ },
97
+ {
98
+ id: 'update',
99
+ label: t('label.update_view', 'Update view'),
100
+ onClick: updateViews,
101
+ icon: 'Refresh'
102
+ },
103
+ ...accountMenuItems,
104
+ {
105
+ id: 'docs',
106
+ label: t('label.documentation', 'Documentation'),
107
+ onClick: lodash_1.noop,
108
+ disabled: true,
109
+ icon: 'InfoOutline'
110
+ },
111
+ {
112
+ id: 'logout',
113
+ label: t('label.logout', 'Logout'),
114
+ onClick: () => {
115
+ reset();
116
+ (0, logout_1.logout)();
117
+ },
118
+ icon: 'LogOut'
119
+ }
120
+ ], [account?.displayName, account?.name, accountMenuItems, reset, t, updateViews]);
121
+ const viewItems = (0, react_1.useMemo)(() => (0, lodash_1.map)(views, (view) => react_1.default.createElement(UtilityBarItem, { view: view, key: view.id })), [views]);
122
+ return (react_1.default.createElement(carbonio_design_system_1.Container, { orientation: "horizontal", width: "fit" },
123
+ viewItems,
124
+ react_1.default.createElement(carbonio_design_system_1.Tooltip, { label: account?.displayName ?? account?.name, placement: "bottom-end" },
125
+ react_1.default.createElement(carbonio_design_system_1.Dropdown, { items: accountItems, maxWidth: "18.75rem", disableAutoFocus: true },
126
+ react_1.default.createElement(carbonio_design_system_1.IconButton, { icon: "PersonOutline", size: "large", onClick: lodash_1.noop })))));
127
+ };
128
+ exports.ShellUtilityBar = ShellUtilityBar;
129
+ //# sourceMappingURL=bar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"bar.js","sourceRoot":"","sources":["../../src/utility-bar/bar.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ import type { UtilityBarStore } from '../types/misc';
2
+ export declare const useUtilityBarStore: import("zustand").UseBoundStore<import("zustand").StoreApi<UtilityBarStore>>;
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useUtilityBarStore = void 0;
4
+ /*
5
+ * SPDX-FileCopyrightText: 2022 Zextras <https://www.zextras.com>
6
+ *
7
+ * SPDX-License-Identifier: AGPL-3.0-only
8
+ */
9
+ const zustand_1 = require("zustand");
10
+ // extra currying as suggested in https://github.com/pmndrs/zustand/blob/main/docs/guides/typescript.md#basic-usage
11
+ exports.useUtilityBarStore = (0, zustand_1.create)()((set) => ({
12
+ mode: 'closed',
13
+ current: undefined,
14
+ secondaryBarState: true,
15
+ setMode: (mode) => set((s) => ({ mode, secondaryBarState: mode === 'open' ? false : s.secondaryBarState })),
16
+ setCurrent: (current) => set({ current }),
17
+ setSecondaryBarState: (secondaryBarState) => set({ secondaryBarState })
18
+ }));
19
+ //# sourceMappingURL=store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/utility-bar/store.ts"],"names":[],"mappings":";;;AAAA;;;;GAIG;AACH,qCAAiC;AAIjC,mHAAmH;AACtG,QAAA,kBAAkB,GAAG,IAAA,gBAAM,GAAmB,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IACrE,IAAI,EAAE,QAAQ;IACd,OAAO,EAAE,SAAS;IAClB,iBAAiB,EAAE,IAAI;IACvB,OAAO,EAAE,CAAC,IAAI,EAAQ,EAAE,CACvB,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,iBAAiB,EAAE,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,iBAAiB,EAAE,CAAC,CAAC;IACzF,UAAU,EAAE,CAAC,OAAO,EAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,OAAO,EAAE,CAAC;IAC/C,oBAAoB,EAAE,CAAC,iBAA0B,EAAQ,EAAE,CAAC,GAAG,CAAC,EAAE,iBAAiB,EAAE,CAAC;CACtF,CAAC,CAAC,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { AppRoute, PrimaryAccessoryView, SecondaryAccessoryView, UtilityView } from '../types/apps';
2
+ export declare const checkList: (l1: Array<string>, l2?: Array<string>) => boolean;
3
+ export declare const checkRoute: (view: UtilityView | PrimaryAccessoryView | SecondaryAccessoryView, activeRoute?: AppRoute) => boolean;
4
+ export declare const useUtilityViews: () => Array<UtilityView>;
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ /*
3
+ * SPDX-FileCopyrightText: 2022 Zextras <https://www.zextras.com>
4
+ *
5
+ * SPDX-License-Identifier: AGPL-3.0-only
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.useUtilityViews = exports.checkRoute = exports.checkList = void 0;
9
+ const react_1 = require("react");
10
+ const lodash_1 = require("lodash");
11
+ const hooks_1 = require("../history/hooks");
12
+ const app_1 = require("../store/app");
13
+ const checkList = (l1, l2) => (0, lodash_1.intersection)(l1, l2).length > 0;
14
+ exports.checkList = checkList;
15
+ const checkRoute = (view, activeRoute) => {
16
+ const activeRouteValues = Object.values((0, lodash_1.omit)(activeRoute, 'focusMode') ?? {});
17
+ if (view.blacklistRoutes)
18
+ return !(0, exports.checkList)(activeRouteValues, view.blacklistRoutes);
19
+ if (view.whitelistRoutes)
20
+ return (0, exports.checkList)(activeRouteValues, view.whitelistRoutes);
21
+ return true;
22
+ };
23
+ exports.checkRoute = checkRoute;
24
+ const useUtilityViews = () => {
25
+ const utilityViews = (0, app_1.useAppStore)((s) => s.views.utilityBar);
26
+ const activeRoute = (0, hooks_1.useCurrentRoute)();
27
+ return (0, react_1.useMemo)(() => (0, lodash_1.filter)(utilityViews, (v) => (0, exports.checkRoute)(v, activeRoute)), [activeRoute, utilityViews]);
28
+ };
29
+ exports.useUtilityViews = useUtilityViews;
30
+ //# sourceMappingURL=utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utility-bar/utils.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;;AAEH,iCAAgC;AAEhC,mCAAoD;AAEpD,4CAAmD;AACnD,sCAA2C;AAQpC,MAAM,SAAS,GAAG,CAAC,EAAiB,EAAE,EAAkB,EAAW,EAAE,CAC3E,IAAA,qBAAY,EAAC,EAAE,EAAE,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;AADpB,QAAA,SAAS,aACW;AAE1B,MAAM,UAAU,GAAG,CACzB,IAAiE,EACjE,WAAsB,EACZ,EAAE;IACZ,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,CAAC,IAAA,aAAI,EAAC,WAAW,EAAE,WAAW,CAAC,IAAI,EAAE,CAAC,CAAC;IAC9E,IAAI,IAAI,CAAC,eAAe;QAAE,OAAO,CAAC,IAAA,iBAAS,EAAC,iBAAiB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;IACrF,IAAI,IAAI,CAAC,eAAe;QAAE,OAAO,IAAA,iBAAS,EAAC,iBAAiB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;IACpF,OAAO,IAAI,CAAC;AACb,CAAC,CAAC;AARW,QAAA,UAAU,cAQrB;AACK,MAAM,eAAe,GAAG,GAAuB,EAAE;IACvD,MAAM,YAAY,GAAG,IAAA,iBAAW,EAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IAE5D,MAAM,WAAW,GAAG,IAAA,uBAAe,GAAE,CAAC;IACtC,OAAO,IAAA,eAAO,EACb,GAAG,EAAE,CAAC,IAAA,eAAM,EAAC,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,kBAAU,EAAC,CAAC,EAAE,WAAW,CAAC,CAAC,EAC7D,CAAC,WAAW,EAAE,YAAY,CAAC,CAC3B,CAAC;AACH,CAAC,CAAC;AARW,QAAA,eAAe,mBAQ1B"}
@@ -6,7 +6,6 @@ export type StringOfLength<Min, Max = Min> = string & {
6
6
  export type RequireAtLeastOne<T, Keys extends keyof T = keyof T> = Pick<T, Exclude<keyof T, Keys>> & {
7
7
  [K in Keys]-?: Required<Pick<T, K>> & Partial<Pick<T, Exclude<Keys, K>>>;
8
8
  }[Keys];
9
- export type Override<TObj extends Record<string, unknown>, TOverride extends Partial<Record<keyof TObj, unknown>>> = Omit<TObj, keyof TOverride> & TOverride;
10
9
  export type AnyFunction = (...args: any[]) => any;
11
10
  export type ValueOf<T> = T[keyof T];
12
11
  export type Exactify<T, X extends T> = T & {
@@ -8,9 +8,6 @@ export type ElementSize = {
8
8
  height: number;
9
9
  };
10
10
  export type SizeAndPosition = ElementPosition & ElementSize;
11
- export declare const testFolderIsChecked: ({ string }: {
12
- string: string | undefined;
13
- }) => boolean;
14
11
  export declare function setGlobalCursor(cursor: CSSProperties['cursor']): void;
15
12
  export declare function setElementSizeAndPosition(element: HTMLElement, key: keyof SizeAndPosition, value: number | undefined): void;
16
13
  export declare function createExportForTestOnly<TObj extends Record<string, unknown>>(objToExport: TObj): {
@@ -1,9 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getCurrentLocationHost = exports.createExportForTestOnly = exports.setElementSizeAndPosition = exports.setGlobalCursor = exports.testFolderIsChecked = void 0;
3
+ exports.getCurrentLocationHost = void 0;
4
+ exports.setGlobalCursor = setGlobalCursor;
5
+ exports.setElementSizeAndPosition = setElementSizeAndPosition;
6
+ exports.createExportForTestOnly = createExportForTestOnly;
4
7
  const lodash_1 = require("lodash");
5
- const testFolderIsChecked = ({ string }) => /#/.test(string ?? '');
6
- exports.testFolderIsChecked = testFolderIsChecked;
7
8
  function setGlobalCursor(cursor) {
8
9
  // remove previously set cursor
9
10
  const cursors = [];
@@ -17,12 +18,10 @@ function setGlobalCursor(cursor) {
17
18
  document.body.classList.add(`global-cursor-${cursor}`);
18
19
  }
19
20
  }
20
- exports.setGlobalCursor = setGlobalCursor;
21
21
  function setElementSizeAndPosition(element, key, value) {
22
22
  // eslint-disable-next-line no-param-reassign
23
23
  element.style[key] = value !== undefined ? `${value}px` : '';
24
24
  }
25
- exports.setElementSizeAndPosition = setElementSizeAndPosition;
26
25
  function createExportForTestOnly(objToExport) {
27
26
  return process.env.NODE_ENV === 'test'
28
27
  ? objToExport
@@ -31,7 +30,6 @@ function createExportForTestOnly(objToExport) {
31
30
  return accumulator;
32
31
  }, {});
33
32
  }
34
- exports.createExportForTestOnly = createExportForTestOnly;
35
33
  const getCurrentLocationHost = () => window.location.host;
36
34
  exports.getCurrentLocationHost = getCurrentLocationHost;
37
35
  //# sourceMappingURL=utils.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils/utils.ts"],"names":[],"mappings":";;;AAOA,mCAAgC;AAczB,MAAM,mBAAmB,GAAG,CAAC,EAAE,MAAM,EAAkC,EAAW,EAAE,CAC1F,GAAG,CAAC,IAAI,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;AADX,QAAA,mBAAmB,uBACR;AAExB,SAAgB,eAAe,CAAC,MAA+B;IAC9D,+BAA+B;IAC/B,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;QACxC,IAAI,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,EAAE,CAAC;YACvC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpB,CAAC;IACF,CAAC,CAAC,CAAC;IACH,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC;IAC3C,IAAI,MAAM,EAAE,CAAC;QACZ,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,iBAAiB,MAAM,EAAE,CAAC,CAAC;IACxD,CAAC;AACF,CAAC;AAZD,0CAYC;AAED,SAAgB,yBAAyB,CACxC,OAAoB,EACpB,GAA0B,EAC1B,KAAyB;IAEzB,6CAA6C;IAC7C,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;AAC9D,CAAC;AAPD,8DAOC;AAED,SAAgB,uBAAuB,CACtC,WAAiB;IAEjB,OAAO,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,MAAM;QACrC,CAAC,CAAC,WAAW;QACb,CAAC,CAAC,IAAA,eAAM,EACN,WAAW,EACX,CAAC,WAAW,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE;YAC5B,WAAW,CAAC,GAAiB,CAAC,GAAG,SAAS,CAAC;YAC3C,OAAO,WAAW,CAAC;QACpB,CAAC,EACD,EAAmC,CACnC,CAAC;AACL,CAAC;AAbD,0DAaC;AAEM,MAAM,sBAAsB,GAAG,GAAW,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;AAA5D,QAAA,sBAAsB,0BAAsC"}
1
+ {"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils/utils.ts"],"names":[],"mappings":";;;AAqBA,0CAYC;AAED,8DAOC;AAED,0DAaC;AAlDD,mCAAgC;AAchC,SAAgB,eAAe,CAAC,MAA+B;IAC9D,+BAA+B;IAC/B,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;QACxC,IAAI,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,EAAE,CAAC;YACvC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACpB,CAAC;IACF,CAAC,CAAC,CAAC;IACH,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC;IAC3C,IAAI,MAAM,EAAE,CAAC;QACZ,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,iBAAiB,MAAM,EAAE,CAAC,CAAC;IACxD,CAAC;AACF,CAAC;AAED,SAAgB,yBAAyB,CACxC,OAAoB,EACpB,GAA0B,EAC1B,KAAyB;IAEzB,6CAA6C;IAC7C,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;AAC9D,CAAC;AAED,SAAgB,uBAAuB,CACtC,WAAiB;IAEjB,OAAO,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,MAAM;QACrC,CAAC,CAAC,WAAW;QACb,CAAC,CAAC,IAAA,eAAM,EACN,WAAW,EACX,CAAC,WAAW,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE;YAC5B,WAAW,CAAC,GAAiB,CAAC,GAAG,SAAS,CAAC;YAC3C,OAAO,WAAW,CAAC;QACpB,CAAC,EACD,EAAmC,CACnC,CAAC;AACL,CAAC;AAEM,MAAM,sBAAsB,GAAG,GAAW,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAC;AAA5D,QAAA,sBAAsB,0BAAsC"}
package/package.json CHANGED
@@ -1,11 +1,12 @@
1
1
  {
2
2
  "name": "@zextras/carbonio-shell-ui",
3
- "version": "9.0.1",
3
+ "version": "10.0.0-devel.1741258975575",
4
4
  "description": "The Zextras Carbonio web client",
5
5
  "main": "./lib/lib.js",
6
6
  "types": "./lib/lib.d.ts",
7
7
  "exports": {
8
- ".": "./lib/lib.js"
8
+ ".": "./lib/lib.js",
9
+ "./*": null
9
10
  },
10
11
  "engines": {
11
12
  "node": "v18",
@@ -39,8 +40,7 @@
39
40
  },
40
41
  "files": [
41
42
  "lib/",
42
- "COPYING",
43
- "README.md"
43
+ "THIRDPARTIES"
44
44
  ],
45
45
  "keywords": [
46
46
  "zextras"
@@ -48,36 +48,35 @@
48
48
  "author": "Zextras Dev Team <https://www.zextras.com/carbonio/>",
49
49
  "license": "AGPL-3.0-only",
50
50
  "devDependencies": {
51
- "@babel/core": "^7.24.7",
52
- "@babel/preset-env": "^7.24.7",
53
- "@babel/preset-react": "^7.24.7",
54
- "@babel/preset-typescript": "^7.24.7",
55
- "@commitlint/cli": "^19.0.3",
56
- "@commitlint/config-conventional": "^19.0.3",
51
+ "@babel/core": "^7.26.7",
52
+ "@babel/preset-env": "^7.26.7",
53
+ "@babel/preset-react": "^7.26.3",
54
+ "@babel/preset-typescript": "^7.26.0",
55
+ "@commitlint/cli": "^19.6.1",
56
+ "@commitlint/config-conventional": "^19.6.0",
57
57
  "@faker-js/faker": "^8.4.1",
58
58
  "@microsoft/api-extractor": "^7.42.3",
59
59
  "@svgr/webpack": "^8.1.0",
60
60
  "@testing-library/dom": "^10.4.0",
61
- "@testing-library/jest-dom": "^6.5.0",
62
- "@testing-library/react": "^16.0.1",
63
- "@testing-library/user-event": "^14.5.2",
61
+ "@testing-library/jest-dom": "^6.6.3",
62
+ "@testing-library/react": "^16.2.0",
63
+ "@testing-library/user-event": "^14.6.1",
64
64
  "@tsconfig/node18": "^18.2.4",
65
65
  "@types/jest": "^29.5.12",
66
66
  "@types/lodash": "^4.17.4",
67
- "@types/node": "^18.19.54",
67
+ "@types/node": "^18.19.67",
68
68
  "@types/react": "^18.3.11",
69
69
  "@types/react-dom": "^18.3.0",
70
- "@types/react-router-dom": "^5.3.3",
71
- "@types/styled-components": "^5.1.34",
72
70
  "@types/ua-parser-js": "^0.7.39",
73
71
  "@types/webpack": "^5.28.5",
74
72
  "@types/webpack-env": "^1.18.4",
75
- "@zextras/carbonio-ui-configs": "^1.0.3",
76
- "@zextras/carbonio-ui-sdk": "^1.7.10",
73
+ "@zextras/carbonio-search-ui": "github:zextras/carbonio-search-ui#devel",
74
+ "@zextras/carbonio-ui-configs": "^2.0.1",
75
+ "@zextras/carbonio-ui-sdk": "^1.7.12",
77
76
  "autoprefixer": "^10.4.17",
78
- "babel-loader": "^9.1.3",
77
+ "babel-loader": "^9.2.1",
79
78
  "babel-plugin-styled-components": "^2.1.4",
80
- "babel-plugin-transform-import-meta": "^2.2.1",
79
+ "babel-plugin-transform-import-meta": "^2.3.2",
81
80
  "copy-webpack-plugin": "^12.0.2",
82
81
  "core-js": "^3.36.0",
83
82
  "css-loader": "^6.10.0",
@@ -106,11 +105,12 @@
106
105
  "@fontsource/roboto": "^5.0.8",
107
106
  "@sentry/browser": "^7.103.0",
108
107
  "@tinymce/tinymce-react": "^4.3.2",
109
- "@zextras/carbonio-design-system": "^8.1.0",
110
- "@zextras/carbonio-ui-preview": "^3.1.0",
108
+ "@zextras/carbonio-design-system": "9.0.0",
109
+ "@zextras/carbonio-ui-preview": "^3.1.1",
111
110
  "darkreader": "^4.9.79",
112
- "history": "^5.3.0",
111
+ "date-fns": "^4.1.0",
113
112
  "i18next": "^22.5.1",
113
+ "i18next-chained-backend": "^4.6.2",
114
114
  "i18next-http-backend": "^2.5.0",
115
115
  "immer": "^10.0.3",
116
116
  "lodash": "^4.17.21",
@@ -118,23 +118,22 @@
118
118
  "react": "^18.3.1",
119
119
  "react-dom": "^18.3.1",
120
120
  "react-i18next": "^12.3.1",
121
- "react-router-dom": "^5.3.4",
122
- "react-router-dom-v5-compat": "^6.28.0",
123
- "styled-components": "^5.3.11",
121
+ "react-router-dom": "^6.30.0",
122
+ "styled-components": "^6.1.13",
124
123
  "tinymce": "^6.8.4",
125
124
  "ua-parser-js": "^1.0.37",
126
- "zustand": "^4.5.1"
125
+ "zustand": "^5.0.3"
127
126
  },
128
127
  "peerDependencies": {
129
- "@zextras/carbonio-design-system": "^8.1.0",
130
- "@zextras/carbonio-ui-preview": "^3.1.0",
131
- "core-js": "^3.31.1",
128
+ "@zextras/carbonio-design-system": "9.0.0",
129
+ "@zextras/carbonio-ui-preview": "^3.1.1",
130
+ "core-js": "^3.39.0",
132
131
  "lodash": "^4.17.21",
133
132
  "react": "^18.3.1",
134
133
  "react-dom": "^18.3.1",
135
134
  "react-i18next": "^12.3.1",
136
- "react-router-dom": "^5.3.4",
137
- "styled-components": "^5.3.11"
135
+ "react-router-dom": "^6.30.0",
136
+ "styled-components": "^6.1.13"
138
137
  },
139
138
  "peerDependenciesMeta": {
140
139
  "@zextras/carbonio-design-system": {