@uxf/cms 11.74.0 → 11.74.2

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 (337) hide show
  1. package/api/index.d.ts +165 -0
  2. package/api/index.js +100 -0
  3. package/api/swr.d.ts +76 -0
  4. package/api/swr.js +43 -0
  5. package/config/container.d.ts +29 -0
  6. package/config/container.js +24 -0
  7. package/config/index.d.ts +2 -0
  8. package/config/index.js +6 -0
  9. package/content-builder/content-builder-body.d.ts +6 -0
  10. package/content-builder/content-builder-body.js +10 -0
  11. package/content-builder/content-builder-header.d.ts +7 -0
  12. package/content-builder/content-builder-header.js +15 -0
  13. package/content-builder/content-builder-root.d.ts +11 -0
  14. package/content-builder/content-builder-root.js +13 -0
  15. package/content-builder/content-builder-sidebar.d.ts +7 -0
  16. package/content-builder/content-builder-sidebar.js +12 -0
  17. package/content-builder/content-builder.d.ts +14 -0
  18. package/content-builder/content-builder.js +57 -0
  19. package/content-builder/forms/content-builder-basic-form.d.ts +10 -0
  20. package/content-builder/forms/content-builder-basic-form.js +49 -0
  21. package/content-builder/forms/content-builder-seo-form.d.ts +10 -0
  22. package/content-builder/forms/content-builder-seo-form.js +22 -0
  23. package/content-builder/index.d.ts +4 -0
  24. package/content-builder/index.js +20 -0
  25. package/content-builder/map-content-response-to-form-data.d.ts +3 -0
  26. package/content-builder/map-content-response-to-form-data.js +44 -0
  27. package/content-builder/map-form-data-to-content-request.d.ts +2 -0
  28. package/content-builder/map-form-data-to-content-request.js +28 -0
  29. package/content-builder/translations.d.ts +127 -0
  30. package/content-builder/translations.js +128 -0
  31. package/content-builder/types.d.ts +186 -0
  32. package/content-builder/types.js +2 -0
  33. package/content-builder/use-content-builder-form-api.d.ts +3 -0
  34. package/content-builder/use-content-builder-form-api.js +7 -0
  35. package/context/cms-provider.d.ts +7 -0
  36. package/context/cms-provider.js +18 -0
  37. package/deprecated/api/api-client.d.ts +15 -0
  38. package/deprecated/api/api-client.js +86 -0
  39. package/deprecated/hoc/with-authenticate.d.ts +6 -0
  40. package/deprecated/hoc/with-authenticate.js +61 -0
  41. package/deprecated/redux/configure-store.d.ts +3 -0
  42. package/deprecated/redux/configure-store.js +16 -0
  43. package/deprecated/redux/entities/actions.d.ts +30 -0
  44. package/deprecated/redux/entities/actions.js +15 -0
  45. package/deprecated/redux/entities/index.d.ts +2 -0
  46. package/deprecated/redux/entities/index.js +18 -0
  47. package/deprecated/redux/entities/reducer.d.ts +3 -0
  48. package/deprecated/redux/entities/reducer.js +36 -0
  49. package/deprecated/redux/entities/selectors.d.ts +10 -0
  50. package/deprecated/redux/entities/selectors.js +16 -0
  51. package/deprecated/redux/index.d.ts +3 -0
  52. package/deprecated/redux/index.js +22 -0
  53. package/deprecated/redux/redux-helper.d.ts +15 -0
  54. package/deprecated/redux/redux-helper.js +6 -0
  55. package/deprecated/redux/types.d.ts +7 -0
  56. package/deprecated/redux/types.js +2 -0
  57. package/deprecated/redux/user/actions.d.ts +19 -0
  58. package/deprecated/redux/user/actions.js +14 -0
  59. package/deprecated/redux/user/index.d.ts +2 -0
  60. package/deprecated/redux/user/index.js +18 -0
  61. package/deprecated/redux/user/reducer.d.ts +3 -0
  62. package/deprecated/redux/user/reducer.js +21 -0
  63. package/deprecated/redux/user/selectors.d.ts +3 -0
  64. package/deprecated/redux/user/selectors.js +5 -0
  65. package/deprecated/redux/with-redux-store.d.ts +1 -0
  66. package/deprecated/redux/with-redux-store.js +70 -0
  67. package/deprecated/security/cms-authorizator.d.ts +3 -0
  68. package/deprecated/security/cms-authorizator.js +8 -0
  69. package/deprecated/types/app.d.ts +6 -0
  70. package/deprecated/types/app.js +2 -0
  71. package/deprecated/types/form.d.ts +25 -0
  72. package/deprecated/types/form.js +16 -0
  73. package/errors/BadRequestError.d.ts +18 -0
  74. package/errors/BadRequestError.js +14 -0
  75. package/errors/ForbiddenError.d.ts +4 -0
  76. package/errors/ForbiddenError.js +13 -0
  77. package/errors/NetworkError.d.ts +4 -0
  78. package/errors/NetworkError.js +13 -0
  79. package/errors/UnauthorizedError.d.ts +4 -0
  80. package/errors/UnauthorizedError.js +13 -0
  81. package/errors/ValidationError.d.ts +7 -0
  82. package/errors/ValidationError.js +17 -0
  83. package/form-renderer/field/content-dynamic.d.ts +8 -0
  84. package/form-renderer/field/content-dynamic.js +15 -0
  85. package/form-renderer/field/content.d.ts +5 -0
  86. package/form-renderer/field/content.js +38 -0
  87. package/forms/change-password-form/change-password-form.d.ts +3 -0
  88. package/forms/change-password-form/change-password-form.js +31 -0
  89. package/forms/change-password-form/index.d.ts +2 -0
  90. package/forms/change-password-form/index.js +18 -0
  91. package/forms/change-password-form/translations.d.ts +35 -0
  92. package/forms/change-password-form/translations.js +36 -0
  93. package/forms/change-password-form/types.d.ts +13 -0
  94. package/forms/change-password-form/types.js +2 -0
  95. package/forms/components/wysiwyg-input/index.d.ts +1 -0
  96. package/forms/components/wysiwyg-input/index.js +17 -0
  97. package/forms/components/wysiwyg-input/wysiwyg-input.d.ts +26 -0
  98. package/forms/components/wysiwyg-input/wysiwyg-input.js +83 -0
  99. package/forms/forgotten-password-form/forgotten-password-form.d.ts +3 -0
  100. package/forms/forgotten-password-form/forgotten-password-form.js +52 -0
  101. package/forms/forgotten-password-form/index.d.ts +2 -0
  102. package/forms/forgotten-password-form/index.js +18 -0
  103. package/forms/forgotten-password-form/translations.d.ts +17 -0
  104. package/forms/forgotten-password-form/translations.js +18 -0
  105. package/forms/forgotten-password-form/types.d.ts +10 -0
  106. package/forms/forgotten-password-form/types.js +2 -0
  107. package/forms/invite-user-form/index.d.ts +2 -0
  108. package/forms/invite-user-form/index.js +18 -0
  109. package/forms/invite-user-form/invite-user-form.d.ts +3 -0
  110. package/forms/invite-user-form/invite-user-form.js +33 -0
  111. package/forms/invite-user-form/translations.d.ts +35 -0
  112. package/forms/invite-user-form/translations.js +36 -0
  113. package/forms/invite-user-form/types.d.ts +15 -0
  114. package/forms/invite-user-form/types.js +2 -0
  115. package/forms/login-form/index.d.ts +2 -0
  116. package/forms/login-form/index.js +18 -0
  117. package/forms/login-form/login-form.d.ts +3 -0
  118. package/forms/login-form/login-form.js +51 -0
  119. package/forms/login-form/translations.d.ts +23 -0
  120. package/forms/login-form/translations.js +24 -0
  121. package/forms/login-form/types.d.ts +11 -0
  122. package/forms/login-form/types.js +2 -0
  123. package/forms/renew-password-form/index.d.ts +2 -0
  124. package/forms/renew-password-form/index.js +18 -0
  125. package/forms/renew-password-form/renew-password-form.d.ts +3 -0
  126. package/forms/renew-password-form/renew-password-form.js +53 -0
  127. package/forms/renew-password-form/translations.d.ts +29 -0
  128. package/forms/renew-password-form/translations.js +30 -0
  129. package/forms/renew-password-form/types.d.ts +11 -0
  130. package/forms/renew-password-form/types.js +2 -0
  131. package/lib/api/create-axios-instance.d.ts +6 -0
  132. package/lib/api/create-axios-instance.js +17 -0
  133. package/lib/api/create-axios-request.d.ts +3 -0
  134. package/lib/api/create-axios-request.js +39 -0
  135. package/lib/api/create-use-axios-request.d.ts +5 -0
  136. package/lib/api/create-use-axios-request.js +35 -0
  137. package/lib/api/index.d.ts +2 -0
  138. package/lib/api/index.js +19 -0
  139. package/lib/api/types.d.ts +18 -0
  140. package/lib/api/types.js +2 -0
  141. package/lib/layout/breadcrumbs.d.ts +9 -0
  142. package/lib/layout/breadcrumbs.js +21 -0
  143. package/lib/layout/index.d.ts +3 -0
  144. package/lib/layout/index.js +19 -0
  145. package/lib/layout/layout-container.d.ts +3 -0
  146. package/lib/layout/layout-container.js +22 -0
  147. package/lib/layout/layout.d.ts +3 -0
  148. package/lib/layout/layout.js +47 -0
  149. package/lib/layout/sidebar.d.ts +3 -0
  150. package/lib/layout/sidebar.js +77 -0
  151. package/lib/layout/styles.d.ts +1 -0
  152. package/lib/layout/styles.js +4 -0
  153. package/lib/layout/types.d.ts +36 -0
  154. package/lib/layout/types.js +2 -0
  155. package/lib/login-layout/index.d.ts +2 -0
  156. package/lib/login-layout/index.js +18 -0
  157. package/lib/login-layout/login-layout.d.ts +3 -0
  158. package/lib/login-layout/login-layout.js +19 -0
  159. package/lib/login-layout/types.d.ts +9 -0
  160. package/lib/login-layout/types.js +2 -0
  161. package/lib/menu/active-item-resolver.d.ts +7 -0
  162. package/lib/menu/active-item-resolver.js +42 -0
  163. package/lib/menu/factory.d.ts +10 -0
  164. package/lib/menu/factory.js +40 -0
  165. package/lib/menu/index.d.ts +5 -0
  166. package/lib/menu/index.js +21 -0
  167. package/lib/menu/mobile-bar.d.ts +8 -0
  168. package/lib/menu/mobile-bar.js +54 -0
  169. package/lib/menu/model.d.ts +56 -0
  170. package/lib/menu/model.js +112 -0
  171. package/lib/menu/types.d.ts +5 -0
  172. package/lib/menu/types.js +2 -0
  173. package/lib/menu/ui/list-item/index.d.ts +2 -0
  174. package/lib/menu/ui/list-item/index.js +18 -0
  175. package/lib/menu/ui/list-item/list-item.d.ts +3 -0
  176. package/lib/menu/ui/list-item/list-item.js +37 -0
  177. package/lib/menu/ui/list-item/types.d.ts +19 -0
  178. package/lib/menu/ui/list-item/types.js +2 -0
  179. package/lib/menu/ui/menu-custom-item.d.ts +6 -0
  180. package/lib/menu/ui/menu-custom-item.js +17 -0
  181. package/lib/menu/ui/menu-item.d.ts +6 -0
  182. package/lib/menu/ui/menu-item.js +55 -0
  183. package/lib/menu/ui/menu-super-section-item.d.ts +6 -0
  184. package/lib/menu/ui/menu-super-section-item.js +40 -0
  185. package/lib/menu/ui/menu.d.ts +6 -0
  186. package/lib/menu/ui/menu.js +37 -0
  187. package/lib/menu/ui/sub-menu/sub-menu-item.d.ts +7 -0
  188. package/lib/menu/ui/sub-menu/sub-menu-item.js +23 -0
  189. package/lib/menu/ui/sub-menu/sub-menu-mobile.d.ts +8 -0
  190. package/lib/menu/ui/sub-menu/sub-menu-mobile.js +48 -0
  191. package/lib/menu/ui/sub-menu/sub-menu.d.ts +7 -0
  192. package/lib/menu/ui/sub-menu/sub-menu.js +46 -0
  193. package/lib/menu/ui/sub-menu/use-sub-menu.d.ts +49 -0
  194. package/lib/menu/ui/sub-menu/use-sub-menu.js +45 -0
  195. package/lib/menu/ui/translations.d.ts +17 -0
  196. package/lib/menu/ui/translations.js +18 -0
  197. package/lib/menu/ui/user-menu.d.ts +6 -0
  198. package/lib/menu/ui/user-menu.js +55 -0
  199. package/package.json +6 -6
  200. package/pages/content-builder/components/form-content.d.ts +12 -0
  201. package/pages/content-builder/components/form-content.js +64 -0
  202. package/pages/content-builder/components/form-root-fields.d.ts +16 -0
  203. package/pages/content-builder/components/form-root-fields.js +62 -0
  204. package/pages/content-builder/components/form.d.ts +12 -0
  205. package/pages/content-builder/components/form.js +83 -0
  206. package/pages/content-builder/components/header.d.ts +6 -0
  207. package/pages/content-builder/components/header.js +18 -0
  208. package/pages/content-builder/constants.d.ts +6 -0
  209. package/pages/content-builder/constants.js +10 -0
  210. package/pages/content-builder/content/feature-section.d.ts +17 -0
  211. package/pages/content-builder/content/feature-section.js +62 -0
  212. package/pages/content-builder/content/gallery.d.ts +9 -0
  213. package/pages/content-builder/content/gallery.js +29 -0
  214. package/pages/content-builder/content/hero-section.d.ts +12 -0
  215. package/pages/content-builder/content/hero-section.js +35 -0
  216. package/pages/content-builder/content/people.d.ts +17 -0
  217. package/pages/content-builder/content/people.js +61 -0
  218. package/pages/content-builder/content/wysiwyg.d.ts +15 -0
  219. package/pages/content-builder/content/wysiwyg.js +32 -0
  220. package/pages/content-builder/content-builder-page.d.ts +3 -0
  221. package/pages/content-builder/content-builder-page.js +107 -0
  222. package/pages/content-builder/content-field.d.ts +10 -0
  223. package/pages/content-builder/content-field.js +62 -0
  224. package/pages/content-builder/content-header.d.ts +3 -0
  225. package/pages/content-builder/content-header.js +55 -0
  226. package/pages/content-builder/context/details-visibility-context.d.ts +4 -0
  227. package/pages/content-builder/context/details-visibility-context.js +58 -0
  228. package/pages/content-builder/hooks/use-sortable.d.ts +15 -0
  229. package/pages/content-builder/hooks/use-sortable.js +57 -0
  230. package/pages/content-builder/index.d.ts +5 -0
  231. package/pages/content-builder/index.js +21 -0
  232. package/pages/content-builder/mapper.d.ts +4 -0
  233. package/pages/content-builder/mapper.js +69 -0
  234. package/pages/content-builder/types.d.ts +94 -0
  235. package/pages/content-builder/types.js +2 -0
  236. package/pages/forgotten-password-page/forgotten-password-page.d.ts +5 -0
  237. package/pages/forgotten-password-page/forgotten-password-page.js +49 -0
  238. package/pages/forgotten-password-page/index.d.ts +2 -0
  239. package/pages/forgotten-password-page/index.js +18 -0
  240. package/pages/forgotten-password-page/types.d.ts +11 -0
  241. package/pages/forgotten-password-page/types.js +2 -0
  242. package/pages/grid-page/get-initial-props-helper.d.ts +4 -0
  243. package/pages/grid-page/get-initial-props-helper.js +20 -0
  244. package/pages/grid-page/grid-page.d.ts +6 -0
  245. package/pages/grid-page/grid-page.js +161 -0
  246. package/pages/grid-page/index.d.ts +1 -0
  247. package/pages/grid-page/index.js +5 -0
  248. package/pages/grid-page/types.d.ts +65 -0
  249. package/pages/grid-page/types.js +2 -0
  250. package/pages/grid-page/use-hidden-columns.d.ts +4 -0
  251. package/pages/grid-page/use-hidden-columns.js +17 -0
  252. package/pages/invite-user-page/index.d.ts +2 -0
  253. package/pages/invite-user-page/index.js +18 -0
  254. package/pages/invite-user-page/invite-user-page.d.ts +2 -0
  255. package/pages/invite-user-page/invite-user-page.js +57 -0
  256. package/pages/invite-user-page/types.d.ts +12 -0
  257. package/pages/invite-user-page/types.js +2 -0
  258. package/pages/login-page/index.d.ts +2 -0
  259. package/pages/login-page/index.js +18 -0
  260. package/pages/login-page/login-page.d.ts +5 -0
  261. package/pages/login-page/login-page.js +80 -0
  262. package/pages/login-page/types.d.ts +21 -0
  263. package/pages/login-page/types.js +2 -0
  264. package/pages/renew-password-page/index.d.ts +2 -0
  265. package/pages/renew-password-page/index.js +18 -0
  266. package/pages/renew-password-page/renew-password-page.d.ts +9 -0
  267. package/pages/renew-password-page/renew-password-page.js +53 -0
  268. package/pages/renew-password-page/types.d.ts +14 -0
  269. package/pages/renew-password-page/types.js +2 -0
  270. package/pages/translations.d.ts +93 -0
  271. package/pages/translations.js +94 -0
  272. package/security/restricted-page.d.ts +10 -0
  273. package/security/restricted-page.js +40 -0
  274. package/security/translations.d.ts +29 -0
  275. package/security/translations.js +30 -0
  276. package/security/use-logged-user.d.ts +5 -0
  277. package/security/use-logged-user.js +17 -0
  278. package/translations/cs.json +125 -0
  279. package/translations/de.json +83 -0
  280. package/translations/en.json +83 -0
  281. package/translations/sk.json +83 -0
  282. package/ui/avatar/avatar.d.ts +11 -0
  283. package/ui/avatar/avatar.js +47 -0
  284. package/ui/avatar/get-avatar-user-letters.d.ts +1 -0
  285. package/ui/avatar/get-avatar-user-letters.js +18 -0
  286. package/ui/avatar/index.d.ts +3 -0
  287. package/ui/avatar/index.js +5 -0
  288. package/ui/avatar/theme.d.ts +11 -0
  289. package/ui/avatar/theme.js +2 -0
  290. package/ui/copy-to-clipboard/copy-to-clipboard.d.ts +3 -0
  291. package/ui/copy-to-clipboard/copy-to-clipboard.js +47 -0
  292. package/ui/copy-to-clipboard/index.d.ts +2 -0
  293. package/ui/copy-to-clipboard/index.js +18 -0
  294. package/ui/copy-to-clipboard/translations.d.ts +17 -0
  295. package/ui/copy-to-clipboard/translations.js +18 -0
  296. package/ui/copy-to-clipboard/types.d.ts +7 -0
  297. package/ui/copy-to-clipboard/types.js +2 -0
  298. package/ui/copy-to-clipboard-button/copy-to-clipboard-button.d.ts +3 -0
  299. package/ui/copy-to-clipboard-button/copy-to-clipboard-button.js +48 -0
  300. package/ui/copy-to-clipboard-button/index.d.ts +2 -0
  301. package/ui/copy-to-clipboard-button/index.js +18 -0
  302. package/ui/copy-to-clipboard-button/translations.d.ts +17 -0
  303. package/ui/copy-to-clipboard-button/translations.js +18 -0
  304. package/ui/copy-to-clipboard-button/types.d.ts +6 -0
  305. package/ui/copy-to-clipboard-button/types.js +2 -0
  306. package/ui/index.d.ts +1 -0
  307. package/ui/index.js +6 -0
  308. package/ui/tw-tokens/tw-box-shadow.d.ts +12 -0
  309. package/ui/tw-tokens/tw-box-shadow.js +15 -0
  310. package/ui/tw-tokens/tw-colors.d.ts +475 -0
  311. package/ui/tw-tokens/tw-colors.js +474 -0
  312. package/ui/tw-tokens/tw-containers.d.ts +8 -0
  313. package/ui/tw-tokens/tw-containers.js +5 -0
  314. package/ui/tw-tokens/tw-font-size.d.ts +55 -0
  315. package/ui/tw-tokens/tw-font-size.js +32 -0
  316. package/ui/tw-tokens/tw-font-weight.d.ts +12 -0
  317. package/ui/tw-tokens/tw-font-weight.js +15 -0
  318. package/ui/tw-tokens/tw-line-height.d.ts +17 -0
  319. package/ui/tw-tokens/tw-line-height.js +20 -0
  320. package/ui/tw-tokens/tw-screens.d.ts +8 -0
  321. package/ui/tw-tokens/tw-screens.js +5 -0
  322. package/ui/tw-tokens/tw-spacing.d.ts +39 -0
  323. package/ui/tw-tokens/tw-spacing.js +42 -0
  324. package/ui/tw-tokens/tw-z-index.d.ts +21 -0
  325. package/ui/tw-tokens/tw-z-index.js +24 -0
  326. package/ui/widget/index.d.ts +2 -0
  327. package/ui/widget/index.js +18 -0
  328. package/ui/widget/types.d.ts +6 -0
  329. package/ui/widget/types.js +2 -0
  330. package/ui/widget/widget.d.ts +3 -0
  331. package/ui/widget/widget.js +15 -0
  332. package/utils/remove-confirm-handler.d.ts +1 -0
  333. package/utils/remove-confirm-handler.js +31 -0
  334. package/utils/translations.d.ts +23 -0
  335. package/utils/translations.js +24 -0
  336. package/utils/use-viewport-height.d.ts +3 -0
  337. package/utils/use-viewport-height.js +28 -0
@@ -0,0 +1,112 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.MenuItem = void 0;
4
+ const empty_array_1 = require("@uxf/core/constants/empty-array");
5
+ class MenuItem {
6
+ static create(title, type) {
7
+ return new MenuItem(title, type);
8
+ }
9
+ constructor(title, type) {
10
+ this._title = title;
11
+ this._type = type;
12
+ this._children = [];
13
+ }
14
+ setContent(content) {
15
+ this._content = content;
16
+ return this;
17
+ }
18
+ setIcon(icon) {
19
+ this._icon = icon;
20
+ return this;
21
+ }
22
+ setEndElement(endElement) {
23
+ this._endElement = endElement;
24
+ return this;
25
+ }
26
+ setChildren(children) {
27
+ this._children = children !== null && children !== void 0 ? children : empty_array_1.EMPTY_ARRAY;
28
+ return this;
29
+ }
30
+ setRoute(route, routeParams) {
31
+ this._route = route;
32
+ this._routeParams = routeParams;
33
+ return this;
34
+ }
35
+ setUrl(url) {
36
+ this._url = url;
37
+ return this;
38
+ }
39
+ setIsExternal(isExternal) {
40
+ this._isExternal = isExternal;
41
+ return this;
42
+ }
43
+ setUserMenuData(userMenuData) {
44
+ this._userMenuData = userMenuData;
45
+ return this;
46
+ }
47
+ setActiveResolver(resolver) {
48
+ this._activeItemResolver = resolver ? resolver(this) : undefined;
49
+ return this;
50
+ }
51
+ setAllowedRoles(roles) {
52
+ this._allowedRoles = roles;
53
+ return this;
54
+ }
55
+ isActive(router, activeRoute) {
56
+ return Boolean(this._activeItemResolver && this._activeItemResolver(router, activeRoute));
57
+ }
58
+ hasActiveChildren(router, activeRoute) {
59
+ return this.children.some((item) => item.isActive(router, activeRoute));
60
+ }
61
+ isVisible(loggedUser) {
62
+ if (this._allowedRoles === undefined) {
63
+ return true;
64
+ }
65
+ for (const allowedRole of this._allowedRoles) {
66
+ if (loggedUser.roles.includes(allowedRole)) {
67
+ return true;
68
+ }
69
+ }
70
+ return false;
71
+ }
72
+ hasVisibleChildren(loggedUser) {
73
+ return this.children.some((item) => item.isVisible(loggedUser));
74
+ }
75
+ get type() {
76
+ return this._type;
77
+ }
78
+ get title() {
79
+ return this._title;
80
+ }
81
+ get children() {
82
+ return this._children;
83
+ }
84
+ get url() {
85
+ return this._url;
86
+ }
87
+ get route() {
88
+ return this._route;
89
+ }
90
+ get routeParams() {
91
+ return this._routeParams;
92
+ }
93
+ get isExternal() {
94
+ return this._isExternal;
95
+ }
96
+ get icon() {
97
+ return this._icon;
98
+ }
99
+ get endElement() {
100
+ return this._endElement;
101
+ }
102
+ get allowedRoles() {
103
+ return this._allowedRoles;
104
+ }
105
+ get content() {
106
+ return this._content;
107
+ }
108
+ get userMenuData() {
109
+ return this._userMenuData;
110
+ }
111
+ }
112
+ exports.MenuItem = MenuItem;
@@ -0,0 +1,5 @@
1
+ import { NextRouter } from "next/router";
2
+ import { MenuItem } from "./model";
3
+ export type RouterResolver = (router: NextRouter, activeRoute: string) => boolean;
4
+ export type Resolver = (item: MenuItem) => RouterResolver;
5
+ export type MenuConfiguration = MenuItem[];
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,2 @@
1
+ export * from "./list-item";
2
+ export * from "./types";
@@ -0,0 +1,18 @@
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./list-item"), exports);
18
+ __exportStar(require("./types"), exports);
@@ -0,0 +1,3 @@
1
+ import { ReactElement } from "react";
2
+ import { ListItemProps } from "./types";
3
+ export declare function ListItem<T extends Record<string, any>>(props: ListItemProps<T>): ReactElement;
@@ -0,0 +1,37 @@
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.ListItem = ListItem;
7
+ const classes_1 = require("@uxf/core/constants/classes");
8
+ const is_not_nil_1 = require("@uxf/core/utils/is-not-nil");
9
+ const icon_1 = require("@uxf/ui/icon");
10
+ const link_1 = __importDefault(require("next/link"));
11
+ const react_1 = __importDefault(require("react"));
12
+ const config_1 = require("../../../../config");
13
+ const sub_menu_1 = require("../sub-menu/sub-menu");
14
+ function ListItem(props) {
15
+ var _a, _b, _c, _d;
16
+ const hasSubMenu = Boolean((_a = props.subMenu) === null || _a === void 0 ? void 0 : _a.length);
17
+ const Content = (_b = props.children) !== null && _b !== void 0 ? _b : (react_1.default.createElement("div", { className: `uxf-cms-menu__item uxf-cms-menu__item--basic ${props.selected ? classes_1.CLASSES.IS_SELECTED : ""}` },
18
+ react_1.default.createElement("div", { className: `uxf-cms-menu__icon-wrapper ${props.level === 1 ? "uxf-cms-menu__icon-wrapper--level-one" : ""}` }, (0, is_not_nil_1.isNotNil)(props.icon) && props.level !== 1 && react_1.default.createElement(icon_1.Icon, { name: props.icon, size: 16 })),
19
+ react_1.default.createElement("div", { className: "uxf-cms-menu__item-label" }, props.label),
20
+ react_1.default.createElement("div", { className: "uxf-cms-menu__item-end-element" }, props.endElement),
21
+ hasSubMenu && (react_1.default.createElement(icon_1.Icon, { className: `uxf-cms-menu__caret ${!props.isOpen ? classes_1.CLASSES.IS_OPEN : ""}`, name: "caretDown", size: 16 }))));
22
+ // eslint-disable-next-line react/destructuring-assignment
23
+ const Button = ({ className }) => (react_1.default.createElement("button", { className: className, onClick: props.toggle, type: "button" }, Content));
24
+ if (props.href || props.route) {
25
+ if (props.subMenu && hasSubMenu && !props.isInitiallyOpen) {
26
+ return (react_1.default.createElement(react_1.default.Fragment, null,
27
+ react_1.default.createElement(sub_menu_1.SubMenu, { content: props.subMenu },
28
+ react_1.default.createElement(link_1.default, { href: (_c = props.href) !== null && _c !== void 0 ? _c : config_1.container.get("route")(props.route, props.params), rel: props.isExternal ? "noreferrer noopener" : undefined, target: props.isExternal ? "_blank" : undefined }, Content)),
29
+ react_1.default.createElement(Button, { className: "uxf-cms-menu__submenu-button uxf-cms-menu__submenu-button--initially-closed" })));
30
+ }
31
+ if (hasSubMenu) {
32
+ return react_1.default.createElement(Button, { className: "uxf-cms-menu__submenu-button uxf-cms-menu__submenu-button--initially-open" });
33
+ }
34
+ return (react_1.default.createElement(link_1.default, { href: (_d = props.href) !== null && _d !== void 0 ? _d : config_1.container.get("route")(props.route, props.params), rel: props.isExternal ? "noreferrer noopener" : undefined, target: props.isExternal ? "_blank" : undefined }, Content));
35
+ }
36
+ return Content;
37
+ }
@@ -0,0 +1,19 @@
1
+ import { IconName } from "@uxf/ui/icon/types";
2
+ import { ReactElement } from "react";
3
+ import { MenuItem } from "../../model";
4
+ export interface ListItemProps<RouteList> {
5
+ children?: ReactElement;
6
+ endElement?: ReactElement;
7
+ href?: string;
8
+ icon?: IconName;
9
+ isExternal?: boolean;
10
+ isInitiallyOpen?: boolean;
11
+ isOpen?: boolean;
12
+ label: string;
13
+ level?: number;
14
+ params?: any;
15
+ route?: keyof RouteList;
16
+ selected?: boolean;
17
+ subMenu?: MenuItem[];
18
+ toggle?: () => void;
19
+ }
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
@@ -0,0 +1,6 @@
1
+ import { FC } from "react";
2
+ import { MenuItem as Model } from "../model";
3
+ export interface MenuCustomItemProps {
4
+ item: Model;
5
+ }
6
+ export declare const MenuCustomItem: FC<MenuCustomItemProps>;
@@ -0,0 +1,17 @@
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.MenuCustomItem = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const config_1 = require("../../../config");
9
+ const MenuCustomItem = (props) => {
10
+ const useLoggedUser = config_1.container.get("useLoggedUser");
11
+ const loggedUser = useLoggedUser();
12
+ if (!props.item.isVisible(loggedUser)) {
13
+ return null;
14
+ }
15
+ return react_1.default.createElement("div", { className: "uxf-cms-menu__item-wrapper uxf-cms-menu__item-wrapper--custom" }, props.item.content);
16
+ };
17
+ exports.MenuCustomItem = MenuCustomItem;
@@ -0,0 +1,6 @@
1
+ import { FC } from "react";
2
+ import { MenuItem as Model } from "../model";
3
+ export interface MenuItemProps {
4
+ item: Model;
5
+ }
6
+ export declare const MenuItem: FC<MenuItemProps>;
@@ -0,0 +1,55 @@
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 (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.MenuItem = void 0;
27
+ const router_1 = require("next/router");
28
+ const react_1 = __importStar(require("react"));
29
+ const config_1 = require("../../../config");
30
+ const list_item_1 = require("./list-item");
31
+ const MenuItem = (props) => {
32
+ var _a, _b, _c, _d;
33
+ const router = (0, router_1.useRouter)();
34
+ const activeRoute = config_1.container.get("useActiveRoute")();
35
+ const isActive = props.item.isActive(router, activeRoute);
36
+ const hasActiveChildren = props.item.hasActiveChildren(router, activeRoute);
37
+ const useLoggedUser = config_1.container.get("useLoggedUser");
38
+ const loggedUser = useLoggedUser();
39
+ const visibleChildren = props.item.children.filter((i) => i.isVisible(loggedUser));
40
+ const firstVisibleChild = visibleChildren.at(0);
41
+ const isInitiallyOpen = (isActive || hasActiveChildren) && props.item.children.length > 0;
42
+ const [isSubmenuOpen, setIsSubmenuOpen] = (0, react_1.useState)(isInitiallyOpen);
43
+ const toggle = () => setIsSubmenuOpen((prev) => !prev);
44
+ if (!props.item.isVisible(loggedUser) ||
45
+ (props.item.children.length !== 0 && !props.item.hasVisibleChildren(loggedUser))) {
46
+ return null;
47
+ }
48
+ return (react_1.default.createElement("div", { className: "uxf-cms-menu__item-wrapper uxf-cms-menu__item-wrapper--basic" },
49
+ react_1.default.createElement(list_item_1.ListItem, { endElement: props.item.endElement, href: (_a = props.item.url) !== null && _a !== void 0 ? _a : firstVisibleChild === null || firstVisibleChild === void 0 ? void 0 : firstVisibleChild.url, icon: props.item.icon, isExternal: props.item.isExternal, isInitiallyOpen: isInitiallyOpen, isOpen: isSubmenuOpen, label: props.item.title, params: (_c = (_b = props.item.routeParams) !== null && _b !== void 0 ? _b : firstVisibleChild === null || firstVisibleChild === void 0 ? void 0 : firstVisibleChild.routeParams) !== null && _c !== void 0 ? _c : null, route: (_d = props.item.route) !== null && _d !== void 0 ? _d : firstVisibleChild === null || firstVisibleChild === void 0 ? void 0 : firstVisibleChild.route, selected: isActive, subMenu: props.item.children, toggle: toggle }),
50
+ isSubmenuOpen && (react_1.default.createElement("div", { className: "uxf-cms-menu__submenu-list" }, visibleChildren.map((i) => {
51
+ const isSelected = i.isActive(router, activeRoute);
52
+ return (react_1.default.createElement(list_item_1.ListItem, { endElement: i.endElement, href: i.url, icon: i.icon, isExternal: i.isExternal, key: i.title, label: i.title, level: 1, params: i.routeParams, route: i.route, selected: isSelected }));
53
+ })))));
54
+ };
55
+ exports.MenuItem = MenuItem;
@@ -0,0 +1,6 @@
1
+ import { FC } from "react";
2
+ import { MenuItem as Model } from "../model";
3
+ export interface MenuSuperSectionItemProps {
4
+ item: Model;
5
+ }
6
+ export declare const MenuSuperSectionItem: FC<MenuSuperSectionItemProps>;
@@ -0,0 +1,40 @@
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 (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.MenuSuperSectionItem = void 0;
27
+ const react_1 = __importStar(require("react"));
28
+ const config_1 = require("../../../config");
29
+ const menu_custom_item_1 = require("./menu-custom-item");
30
+ const menu_item_1 = require("./menu-item");
31
+ const MenuSuperSectionItem = (props) => {
32
+ const useLoggedUser = config_1.container.get("useLoggedUser");
33
+ const loggedUser = useLoggedUser();
34
+ return (react_1.default.createElement("div", { className: `uxf-cms-menu__item-wrapper uxf-cms-menu__item-wrapper--super ${props.item.userMenuData ? "uxf-cms-menu__item-wrapper--user-menu" : ""}` },
35
+ props.item.isVisible(loggedUser) && (react_1.default.createElement("p", { className: "uxf-cms-menu__item uxf-cms-menu__item--super" }, props.item.title)),
36
+ props.item.children.map((i, index) => (react_1.default.createElement(react_1.Fragment, { key: index },
37
+ i.type === "custom" && react_1.default.createElement(menu_custom_item_1.MenuCustomItem, { item: i }),
38
+ (i.type === "section" || i.type === "link") && react_1.default.createElement(menu_item_1.MenuItem, { item: i }))))));
39
+ };
40
+ exports.MenuSuperSectionItem = MenuSuperSectionItem;
@@ -0,0 +1,6 @@
1
+ import { FC } from "react";
2
+ import { MenuItem as Model } from "../model";
3
+ export interface MenuProps {
4
+ menu: Model[];
5
+ }
6
+ export declare const Menu: FC<MenuProps>;
@@ -0,0 +1,37 @@
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 (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.Menu = void 0;
27
+ const react_1 = __importStar(require("react"));
28
+ const menu_custom_item_1 = require("./menu-custom-item");
29
+ const menu_item_1 = require("./menu-item");
30
+ const menu_super_section_item_1 = require("./menu-super-section-item");
31
+ const Menu = (props) => {
32
+ return (react_1.default.createElement("div", { className: "uxf-cms-menu" }, props.menu.map((item, index) => (react_1.default.createElement(react_1.Fragment, { key: index },
33
+ item.type === "custom" && react_1.default.createElement(menu_custom_item_1.MenuCustomItem, { item: item }),
34
+ item.type === "super-section" && react_1.default.createElement(menu_super_section_item_1.MenuSuperSectionItem, { item: item }),
35
+ (item.type === "section" || item.type === "link") && react_1.default.createElement(menu_item_1.MenuItem, { item: item }))))));
36
+ };
37
+ exports.Menu = Menu;
@@ -0,0 +1,7 @@
1
+ import { FC } from "react";
2
+ import { MenuItem as Model } from "../../model";
3
+ export interface MenuItemProps {
4
+ idPrefix?: string;
5
+ item: Model;
6
+ }
7
+ export declare const SubMenuItem: FC<MenuItemProps>;
@@ -0,0 +1,23 @@
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.SubMenuItem = void 0;
7
+ const link_1 = __importDefault(require("next/link"));
8
+ const react_1 = __importDefault(require("react"));
9
+ const config_1 = require("../../../../config");
10
+ const SubMenuItem = (props) => {
11
+ var _a;
12
+ const useLoggedUser = config_1.container.get("useLoggedUser");
13
+ const loggedUser = useLoggedUser();
14
+ if (!props.item.isVisible(loggedUser)) {
15
+ return null;
16
+ }
17
+ const Content = react_1.default.createElement("div", { className: "uxf-cms-sub-menu__item" }, props.item.title);
18
+ if (props.item.url || props.item.route) {
19
+ return (react_1.default.createElement(link_1.default, { href: (_a = props.item.url) !== null && _a !== void 0 ? _a : config_1.container.get("route")(props.item.route, props.item.routeParams), rel: props.item.isExternal ? "noreferrer noopener" : undefined, target: props.item.isExternal ? "_blank" : undefined }, Content));
20
+ }
21
+ return Content;
22
+ };
23
+ exports.SubMenuItem = SubMenuItem;
@@ -0,0 +1,8 @@
1
+ import React, { ReactElement } from "react";
2
+ import { MenuItem as Model } from "../../model";
3
+ export interface SubMenuProps {
4
+ children: ReactElement;
5
+ content: Model[];
6
+ title: string;
7
+ }
8
+ export declare const SubMenuMobile: React.ForwardRefExoticComponent<SubMenuProps & React.RefAttributes<HTMLElement>>;
@@ -0,0 +1,48 @@
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 (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.SubMenuMobile = void 0;
27
+ const compose_refs_1 = require("@uxf/core-react/utils/compose-refs");
28
+ const react_1 = __importStar(require("react"));
29
+ const sub_menu_item_1 = require("./sub-menu-item");
30
+ const use_sub_menu_1 = require("./use-sub-menu");
31
+ exports.SubMenuMobile = (0, react_1.forwardRef)(({ children, content, title }, ref) => {
32
+ const subMenu = (0, use_sub_menu_1.useSubMenu)({ isMobile: true });
33
+ const stableRef = (0, react_1.useMemo)(() => (0, compose_refs_1.composeRefs)(ref, subMenu.refs.setReference, children.ref), [ref, subMenu.refs.setReference, children]);
34
+ return (react_1.default.createElement(react_1.default.Fragment, null,
35
+ (0, react_1.cloneElement)(children, subMenu.getReferenceProps({
36
+ ref: stableRef,
37
+ ...children.props,
38
+ "data-state": subMenu.open ? "open" : "closed",
39
+ })),
40
+ subMenu.open && (react_1.default.createElement("div", { ...subMenu.getFloatingProps({
41
+ className: "uxf-cms-sidebar__scrollbar uxf-cms-sub-menu__wrapper-mobile",
42
+ ref: subMenu.refs.setFloating,
43
+ style: subMenu.floatingStyles,
44
+ }) },
45
+ react_1.default.createElement("div", { className: "uxf-cms-sub-menu__title" }, title),
46
+ content.map((item, index) => (react_1.default.createElement(sub_menu_item_1.SubMenuItem, { item: item, key: index })))))));
47
+ });
48
+ exports.SubMenuMobile.displayName = "SubMenuMobile";
@@ -0,0 +1,7 @@
1
+ import React, { ReactElement } from "react";
2
+ import { MenuItem as Model } from "../../model";
3
+ export interface SubMenuProps {
4
+ children: ReactElement;
5
+ content: Model[];
6
+ }
7
+ export declare const SubMenu: React.ForwardRefExoticComponent<SubMenuProps & React.RefAttributes<HTMLElement>>;
@@ -0,0 +1,46 @@
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 (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ exports.SubMenu = void 0;
27
+ const compose_refs_1 = require("@uxf/core-react/utils/compose-refs");
28
+ const react_1 = __importStar(require("react"));
29
+ const sub_menu_item_1 = require("./sub-menu-item");
30
+ const use_sub_menu_1 = require("./use-sub-menu");
31
+ exports.SubMenu = (0, react_1.forwardRef)(({ children, content }, ref) => {
32
+ const subMenu = (0, use_sub_menu_1.useSubMenu)({ isMobile: false });
33
+ const stableRef = (0, react_1.useMemo)(() => (0, compose_refs_1.composeRefs)(ref, subMenu.refs.setReference, children.ref), [ref, subMenu.refs.setReference, children]);
34
+ return (react_1.default.createElement("div", { className: "uxf-cms-sub-menu" },
35
+ (0, react_1.cloneElement)(children, subMenu.getReferenceProps({
36
+ ref: stableRef,
37
+ ...children.props,
38
+ "data-state": subMenu.open ? "open" : "closed",
39
+ })),
40
+ subMenu.open && (react_1.default.createElement("div", { ...subMenu.getFloatingProps({
41
+ ref: subMenu.refs.setFloating,
42
+ style: subMenu.floatingStyles,
43
+ className: "uxf-cms-sidebar__scrollbar uxf-cms-sub-menu__wrapper",
44
+ }) }, content.map((item, index) => (react_1.default.createElement(sub_menu_item_1.SubMenuItem, { item: item, key: index })))))));
45
+ });
46
+ exports.SubMenu.displayName = "SubMenu";
@@ -0,0 +1,49 @@
1
+ export interface SubMenuOptions {
2
+ isMobile?: boolean;
3
+ }
4
+ export declare function useSubMenu(options: SubMenuOptions): {
5
+ placement: import("@floating-ui/utils").Placement;
6
+ strategy: import("@floating-ui/utils").Strategy;
7
+ middlewareData: import("@floating-ui/core").MiddlewareData;
8
+ x: number;
9
+ y: number;
10
+ isPositioned: boolean;
11
+ update: () => void;
12
+ floatingStyles: React.CSSProperties;
13
+ refs: {
14
+ reference: import("react").MutableRefObject<import("@floating-ui/react-dom").ReferenceType | null>;
15
+ floating: React.MutableRefObject<HTMLElement | null>;
16
+ setReference: (node: import("@floating-ui/react-dom").ReferenceType | null) => void;
17
+ setFloating: (node: HTMLElement | null) => void;
18
+ } & import("@floating-ui/react").ExtendedRefs<import("@floating-ui/react").ReferenceType>;
19
+ elements: {
20
+ reference: import("@floating-ui/react-dom").ReferenceType | null;
21
+ floating: HTMLElement | null;
22
+ } & import("@floating-ui/react").ExtendedElements<import("@floating-ui/react").ReferenceType>;
23
+ context: {
24
+ x: number;
25
+ y: number;
26
+ strategy: import("@floating-ui/utils").Strategy;
27
+ placement: import("@floating-ui/utils").Placement;
28
+ middlewareData: import("@floating-ui/core").MiddlewareData;
29
+ isPositioned: boolean;
30
+ update: () => void;
31
+ floatingStyles: React.CSSProperties;
32
+ open: boolean;
33
+ onOpenChange: (open: boolean, event?: Event, reason?: import("@floating-ui/react").OpenChangeReason) => void;
34
+ events: import("@floating-ui/react").FloatingEvents;
35
+ dataRef: React.MutableRefObject<import("@floating-ui/react").ContextData>;
36
+ nodeId: string | undefined;
37
+ floatingId: string;
38
+ refs: import("@floating-ui/react").ExtendedRefs<import("@floating-ui/react").ReferenceType>;
39
+ elements: import("@floating-ui/react").ExtendedElements<import("@floating-ui/react").ReferenceType>;
40
+ };
41
+ getReferenceProps: (userProps?: React.HTMLProps<Element>) => Record<string, unknown>;
42
+ getFloatingProps: (userProps?: React.HTMLProps<HTMLElement>) => Record<string, unknown>;
43
+ getItemProps: (userProps?: Omit<React.HTMLProps<HTMLElement>, "selected" | "active"> & {
44
+ active?: boolean;
45
+ selected?: boolean;
46
+ }) => Record<string, unknown>;
47
+ open: boolean;
48
+ setOpen: import("react").Dispatch<import("react").SetStateAction<boolean>>;
49
+ };
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useSubMenu = useSubMenu;
4
+ const react_1 = require("@floating-ui/react");
5
+ const react_2 = require("react");
6
+ function useSubMenu(options) {
7
+ const [open, setOpen] = (0, react_2.useState)(false);
8
+ const data = (0, react_1.useFloating)({
9
+ middleware: [
10
+ (0, react_1.offset)(options.isMobile ? 12 : 16),
11
+ (0, react_1.flip)(),
12
+ (0, react_1.shift)({ padding: 8 }),
13
+ (0, react_1.size)({
14
+ apply({ availableHeight, elements }) {
15
+ Object.assign(elements.floating.style, {
16
+ maxHeight: Math.max(240, availableHeight) + "px",
17
+ });
18
+ },
19
+ }),
20
+ ],
21
+ onOpenChange: setOpen,
22
+ open,
23
+ placement: options.isMobile ? "top" : "right-start",
24
+ whileElementsMounted: (reference, floating, update) => (0, react_1.autoUpdate)(reference, floating, update, {
25
+ elementResize: typeof ResizeObserver !== "undefined",
26
+ }),
27
+ });
28
+ const context = data.context;
29
+ const hover = (0, react_1.useHover)(context, {
30
+ move: false,
31
+ delay: 200,
32
+ handleClose: (0, react_1.safePolygon)(),
33
+ enabled: !options.isMobile,
34
+ });
35
+ const click = (0, react_1.useClick)(context, { enabled: Boolean(options.isMobile) });
36
+ const focus = (0, react_1.useFocus)(context);
37
+ const dismiss = (0, react_1.useDismiss)(context);
38
+ const interactions = (0, react_1.useInteractions)([hover, click, focus, dismiss]);
39
+ return (0, react_2.useMemo)(() => ({
40
+ open,
41
+ setOpen,
42
+ ...interactions,
43
+ ...data,
44
+ }), [open, setOpen, interactions, data]);
45
+ }