@dashadmin/dash-admin 1.3.25 → 1.3.26

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 (511) hide show
  1. package/dist/AppAsyncWrapper.js +30 -1
  2. package/dist/AppWrapper.js +35 -1
  3. package/dist/DASHAdmin.js +312 -1
  4. package/dist/RoutingWrapper.js +76 -1
  5. package/dist/classes/DASHStorageClass.js +15 -1
  6. package/dist/components/Input/RichTextField.js +26 -1
  7. package/dist/components/Redirect.js +56 -1
  8. package/dist/components/avatar/Avatar.js +72 -1
  9. package/dist/components/avatar/SingleImageUploader.js +46 -1
  10. package/dist/components/currency/Format.js +71 -1
  11. package/dist/components/custom/Redirect.js +20 -1
  12. package/dist/components/error/Error.js +161 -1
  13. package/dist/components/geocoding/GeocodingField.js +133 -1
  14. package/dist/components/i18n/BridgedLocalesMenuButton.js +126 -1
  15. package/dist/components/i18n/LangSwitcher.js +196 -1
  16. package/dist/components/loader/GlobalLoader.js +71 -1
  17. package/dist/components/logs/LogFile.js +99 -1
  18. package/dist/components/logs/LogFileById.js +75 -1
  19. package/dist/components/logs/LogViewer.js +33 -1
  20. package/dist/components/menu/AppMenu.js +11 -1
  21. package/dist/components/menu/CustomMenuItemLink.js +77 -1
  22. package/dist/components/menu/DarkToggleMode.js +47 -1
  23. package/dist/components/menu/LanguageToggleMode.js +99 -1
  24. package/dist/components/misc/CustomImageInput.js +54 -1
  25. package/dist/components/misc/DASHGlobalErrorHandler.js +159 -1
  26. package/dist/components/misc/DarkModeSwitcher.js +40 -1
  27. package/dist/components/misc/LanguageSwitcher.js +193 -1
  28. package/dist/components/misc/MUIHtmlToolTip.js +50 -1
  29. package/dist/components/misc/MuiSimpleJsonTable.js +178 -1
  30. package/dist/components/misc/MultiLevelTable.js +124 -1
  31. package/dist/components/misc/NoResults.js +17 -1
  32. package/dist/components/misc/PDFViewer.js +86 -1
  33. package/dist/components/navigation/Breadcrumbs.js +178 -1
  34. package/dist/components/navigation/BreadcrumbsManager.js +194 -1
  35. package/dist/components/navigation/index.js +8 -1
  36. package/dist/components/panel/Error.js +161 -1
  37. package/dist/components/permission/AvailablePermissionsContext.js +157 -1
  38. package/dist/components/permission/PermissionsSelector.js +719 -1
  39. package/dist/components/permission/PermissionsSelectorList.js +400 -1
  40. package/dist/components/racustombuttons/CustomRAButton.js +94 -1
  41. package/dist/components/racustombuttons/QuickButton.js +109 -1
  42. package/dist/components/racustombuttons/QuickEditButton.js +114 -1
  43. package/dist/components/racustombuttons/QuickIconButton.js +119 -1
  44. package/dist/components/scrollbar/Scrollbar.js +52 -1
  45. package/dist/components/selects/MultiSelect.js +42 -1
  46. package/dist/components/selects/RASearchableSelect.js +207 -1
  47. package/dist/components/selects/RASearchableSelectChips.js +225 -1
  48. package/dist/components/selects/SearchableSelect.js +128 -1
  49. package/dist/components/subscription/BillingCycleSelectInput.js +50 -1
  50. package/dist/components/subscription/PlanAddonsSettings.js +396 -1
  51. package/dist/components/subscription/PlanAuditLog.js +345 -1
  52. package/dist/components/subscription/PlanFeaturesSettings.js +151 -1
  53. package/dist/components/subscription/PlanLimitsSettings.js +168 -1
  54. package/dist/components/subscription/PlanMetadataSettings.js +219 -1
  55. package/dist/components/subscription/PlanPricesSettings.js +222 -1
  56. package/dist/components/subscription/index.js +12 -1
  57. package/dist/components/svgelements/SvgLoading.js +330 -1
  58. package/dist/components/svgelements/SvgLogo.js +70 -1
  59. package/dist/components/svgelements/SvgLogoMin.js +76 -1
  60. package/dist/components/svgelements/SvgShipping.js +1001 -1
  61. package/dist/components/tenant/TenantAttributes.js +107 -1
  62. package/dist/components/tenant/TenantAttributesContext.js +150 -1
  63. package/dist/components/tenant/TenantSelector.js +160 -1
  64. package/dist/components/tenant/TenantSettings.js +107 -1
  65. package/dist/components/tenant/TenantSettingsContext.js +152 -1
  66. package/dist/components/tenant/TenantTheme.js +112 -1
  67. package/dist/components/user/AvatarComponent.js +270 -1
  68. package/dist/components/user/TenantAvatarComponent.js +83 -1
  69. package/dist/components/user/UserPreferences.js +422 -1
  70. package/dist/config/ACTIONS.js +25 -1
  71. package/dist/config/ConstantsService.js +25 -1
  72. package/dist/config/DASHAdminSystemConstants.js +137 -1
  73. package/dist/config/PARSERS.js +9 -1
  74. package/dist/contexts/DashQueryClientContext.js +78 -1
  75. package/dist/contexts/DashResourceContext.js +21 -1
  76. package/dist/contexts/I18nBridgeContext.js +123 -1
  77. package/dist/contexts/I18nBridgeSetter.js +29 -1
  78. package/dist/contexts/I18nReduxSync.js +16 -1
  79. package/dist/contexts/SubscriptionPlanFormatsProvider.js +175 -1
  80. package/dist/contexts/SystemRequestsCache.js +194 -1
  81. package/dist/contexts/auth/AuthContext.js +396 -1
  82. package/dist/contexts/auth/AuthContextLocalStorage.js +118 -1
  83. package/dist/contexts/auth/DASHAuthenticationService.js +679 -1
  84. package/dist/contexts/auth/WindowContext.js +10 -1
  85. package/dist/contexts/auth/index.js +2 -1
  86. package/dist/contexts/com/FCMContext.js +378 -1
  87. package/dist/contexts/com/LaravelEchoContext.js +45 -1
  88. package/dist/contexts/com/LaravelEchoMgr.js +121 -1
  89. package/dist/contexts/com/components/DefaultNotificationComponent.js +31 -1
  90. package/dist/contexts/com/components/NotificationAttributesTable.js +28 -1
  91. package/dist/contexts/com/components/NotificationRenderer.js +36 -1
  92. package/dist/contexts/com/components/NotificationsWidget.js +142 -1
  93. package/dist/contexts/com/components/notificationFormats.js +15 -1
  94. package/dist/contexts/com/useLaravelEcho.js +340 -1
  95. package/dist/contexts/dictionary/DictionaryContext.js +43 -1
  96. package/dist/default-theme/DASHAppProviders.js +86 -1
  97. package/dist/default-theme/DashThemeContext.js +146 -1
  98. package/dist/default-theme/DashThemeHelperProvider.js +54 -1
  99. package/dist/default-theme/DomainAppLayout.js +126 -1
  100. package/dist/default-theme/DomainHeader.js +114 -1
  101. package/dist/default-theme/DomainTheme.js +60 -1
  102. package/dist/default-theme/FullLayoutMarkup.js +55 -1
  103. package/dist/default-theme/StaticLayout.js +36 -1
  104. package/dist/default-theme/index.js +19 -1
  105. package/dist/default-theme/menu/AppMaterialMenu.js +364 -1
  106. package/dist/default-theme/menu/AppMenuComponents/SubmenuPortal.js +33 -1
  107. package/dist/default-theme/menu/AppMenuComponents/collapsed/CollapsedSidebarItem.js +239 -1
  108. package/dist/default-theme/menu/AppMenuComponents/collapsed/CollapsedSidebarItems.js +22 -1
  109. package/dist/default-theme/menu/AppMenuComponents/expanded/CollapsableSidebarMenu.js +209 -1
  110. package/dist/default-theme/menu/AppMenuComponents/expanded/SidebarItem.js +71 -1
  111. package/dist/default-theme/menu/AppMenuComponents/getItem.js +7 -1
  112. package/dist/default-theme/menu/AppMenuComponents/submenuConstants.js +78 -1
  113. package/dist/default-theme/menu/AppSidebarMaterial.js +232 -1
  114. package/dist/default-theme/menu/SidebarActions.js +75 -1
  115. package/dist/default-theme/updateDomCssVariables.js +134 -1
  116. package/dist/helpers/checkRole.js +14 -1
  117. package/dist/helpers/parseAxiosError.js +28 -2
  118. package/dist/hooks/audio/useAudio.js +24 -1
  119. package/dist/hooks/axios.js +52 -1
  120. package/dist/hooks/data/useDashboardStats.js +88 -1
  121. package/dist/hooks/data/usePackageByClientsStats.js +51 -1
  122. package/dist/hooks/data/usePackageByCommunesStats.js +51 -1
  123. package/dist/hooks/data/usePackageStats.js +88 -1
  124. package/dist/hooks/data/usePackageWithdrawDetails.js +69 -1
  125. package/dist/hooks/data/useStats.js +94 -1
  126. package/dist/hooks/isCurrentPath.js +18 -1
  127. package/dist/hooks/notifications/WSMessagesManager.js +128 -1
  128. package/dist/hooks/notifications/WSPusherManager.js +70 -1
  129. package/dist/hooks/useBreadcrumbs.js +208 -1
  130. package/dist/hooks/useClickOutside.js +18 -1
  131. package/dist/hooks/useFormPersistance.js +129 -1
  132. package/dist/hooks/useGlobalErrorMediator.js +37 -1
  133. package/dist/hooks/useGlobalLoaderMgr.js +20 -1
  134. package/dist/hooks/useHash.js +24 -1
  135. package/dist/hooks/useLocalStorage.js +68 -1
  136. package/dist/hooks/usePolyglotTranslation.js +57 -1
  137. package/dist/hooks/usePrevious.js +12 -1
  138. package/dist/hooks/usePrintSelected.js +30 -1
  139. package/dist/hooks/useVirtualHash.js +28 -1
  140. package/dist/hooks/window/useWindowSize.js +23 -1
  141. package/dist/index.js +120 -97
  142. package/dist/interfaces.js +6 -1
  143. package/dist/layout/AppLayout.js +36 -1
  144. package/dist/layout/ApplicationLayout.js +110 -1
  145. package/dist/layout/MotionWrapper.js +182 -1
  146. package/dist/layout/MotionWrapper.original.js +182 -1
  147. package/dist/layout/ResourceMenu.js +87 -1
  148. package/dist/layout/ResoureLayout.js +47 -1
  149. package/dist/layout/TransitionWrapper.js +83 -2
  150. package/dist/pages/ChangePassword.js +198 -1
  151. package/dist/pages/DASHLanding.js +9 -1
  152. package/dist/pages/DASHLightWeightLogin.js +495 -1
  153. package/dist/pages/DASHSimpleLogin.js +231 -1
  154. package/dist/pages/Login.js +113 -1
  155. package/dist/pages/Profile.js +347 -1
  156. package/dist/pages/RecoverPassword.js +175 -1
  157. package/dist/pages/SingleImageUploader.js +40 -1
  158. package/dist/pages/VerifyAccount.js +129 -1
  159. package/dist/providers/authProvider.js +186 -1
  160. package/dist/providers/dataProvider.js +468 -1
  161. package/dist/providers/i18n/en.js +514 -1
  162. package/dist/providers/i18n/es.js +520 -1
  163. package/dist/providers/i18n/languages.js +8 -1
  164. package/dist/providers/i18nProvider.js +23 -1
  165. package/dist/react-admin-dash/RADashComponent.js +210 -1
  166. package/dist/react-admin-dash/Resource.js +62 -1
  167. package/dist/resources/Brand/BrandResource.js +106 -1
  168. package/dist/resources/DASHResourceLoader.js +104 -1
  169. package/dist/resources/Log/LogResource.js +59 -1
  170. package/dist/resources/Tenant/ImpersonateTenantResource.js +113 -1
  171. package/dist/resources/Trash/TrashTemplate.js +195 -1
  172. package/dist/resources.js +259 -1
  173. package/dist/schemas/log.js +45 -1
  174. package/dist/schemas/notification.js +39 -1
  175. package/dist/schemas/permissions.js +44 -1
  176. package/dist/schemas/roles.js +48 -1
  177. package/dist/schemas/rolesDataGrid.js +48 -1
  178. package/dist/schemas/subscription/components/SubscriptionActions.js +172 -1
  179. package/dist/schemas/subscription/components/SubscriptionPaymentHistory.js +101 -1
  180. package/dist/schemas/subscription/components/SubscriptionPlanFeatures.js +115 -1
  181. package/dist/schemas/subscription/components/SubscriptionPlanPreview.js +92 -1
  182. package/dist/schemas/subscription/components/SubscriptionPlanStats.js +181 -1
  183. package/dist/schemas/subscription/components/SubscriptionStatusIndicator.js +70 -1
  184. package/dist/schemas/subscription/subscriptionPlanSchema.js +184 -1
  185. package/dist/schemas/subscription/subscriptionSchema.js +147 -1
  186. package/dist/schemas/subscriptionPlan.js +397 -1
  187. package/dist/schemas/tenant.js +122 -1
  188. package/dist/schemas/tenantUser.js +94 -1
  189. package/dist/schemas/tenant_superadmin.js +118 -1
  190. package/dist/schemas/user.js +26 -1
  191. package/dist/systemResources.js +1039 -1
  192. package/dist/systemResources.old.js +668 -1
  193. package/dist/templates/ResourceTemplate.js +196 -1
  194. package/dist/templates/ResourceTemplateCreate.js +144 -1
  195. package/dist/templates/ResourceTemplateEdit.js +147 -1
  196. package/dist/templates/ResourceTemplateFull.js +518 -1
  197. package/dist/templates/ResourceTemplateList.js +295 -1
  198. package/dist/templates/ResourceTemplateShow.js +45 -1
  199. package/dist/templates/TrashTemplate.js +175 -1
  200. package/dist/tenantResources.js +206 -1
  201. package/dist/test_portal_bubbles.js +37 -1
  202. package/dist/theme/AppHeader.js +60 -1
  203. package/dist/theme/AppLayoutSetting.js +34 -1
  204. package/dist/theme/AppLogo.js +7 -1
  205. package/dist/theme/AppSidebar.js +30 -1
  206. package/dist/theme/AppSidebarContent.js +84 -1
  207. package/dist/theme/AppSidebarLogo.js +42 -1
  208. package/dist/theme/components/PageTitle.js +61 -1
  209. package/dist/utils/cache/CacheInvalidatorContext.js +100 -1
  210. package/dist/utils/cache/CacheInvalidatorListenerComponent.js +10 -1
  211. package/dist/utils/cache/useCacheInvalidatorListener.js +17 -1
  212. package/dist/utils/convertFileToBase64.js +10 -1
  213. package/dist/utils/convertToFile.js +12 -1
  214. package/dist/utils/cookies.js +45 -1
  215. package/dist/utils/dashDefaultQueryClient.js +15 -1
  216. package/dist/utils/dataUrlToBlob.js +23 -1
  217. package/dist/utils/deepReplace.js +17 -1
  218. package/dist/utils/getProfileMenu.js +31 -1
  219. package/dist/utils/getTenantSettings.js +9 -1
  220. package/dist/utils/getType.js +10 -1
  221. package/dist/utils/getUserSettings.js +9 -1
  222. package/dist/utils/hasCode.js +14 -1
  223. package/dist/utils/index.js +19 -1
  224. package/dist/utils/injectTenantStyles.js +19 -1
  225. package/dist/utils/isComponent.js +23 -1
  226. package/dist/utils/navEvents.js +75 -1
  227. package/dist/utils/prototypes.js +5 -1
  228. package/dist/utils/regexp.js +7 -1
  229. package/dist/utils/resolveObjectPath.js +5 -1
  230. package/dist/utils/setNativeValue.js +17 -1
  231. package/dist/utils/slugify.js +7 -1
  232. package/dist/utils/validators/emailValidator.js +8 -1
  233. package/dist/utils/validators/requiredValidator.js +7 -1
  234. package/dist/utils/validators/rutValidator.js +25 -1
  235. package/dist/utils/validators.js +57 -1
  236. package/package.json +153 -69
  237. package/src/AppAsyncWrapper.tsx +42 -0
  238. package/src/AppWrapper.tsx +45 -0
  239. package/src/DASHAdmin.tsx +501 -0
  240. package/src/RoutingWrapper.tsx +139 -0
  241. package/src/classes/DASHStorageClass.tsx +8 -0
  242. package/src/components/Input/RichTextField.tsx +27 -0
  243. package/src/components/Redirect.tsx +46 -0
  244. package/src/components/avatar/Avatar.tsx +67 -0
  245. package/src/components/avatar/SingleImageUploader.tsx +53 -0
  246. package/src/components/currency/Format.tsx +77 -0
  247. package/src/components/custom/Redirect.tsx +23 -0
  248. package/src/components/error/Error.tsx +168 -0
  249. package/src/components/geocoding/GeocodingField.tsx +167 -0
  250. package/src/components/i18n/BridgedLocalesMenuButton.tsx +159 -0
  251. package/src/components/i18n/LangSwitcher.tsx +204 -0
  252. package/src/components/loader/GlobalLoader.tsx +56 -0
  253. package/src/components/logs/LogFile.tsx +88 -0
  254. package/src/components/logs/LogFileById.tsx +68 -0
  255. package/src/components/logs/LogViewer.tsx +43 -0
  256. package/src/components/menu/AppMenu.tsx +22 -0
  257. package/src/components/menu/CustomMenuItemLink.tsx +61 -0
  258. package/src/components/menu/DarkToggleMode.tsx +65 -0
  259. package/src/components/menu/LanguageToggleMode.tsx +120 -0
  260. package/src/components/misc/CustomImageInput.tsx +62 -0
  261. package/src/components/misc/DASHGlobalErrorHandler.tsx +194 -0
  262. package/src/components/misc/DarkModeSwitcher.tsx +112 -0
  263. package/src/components/misc/LanguageSwitcher.tsx +199 -0
  264. package/src/components/misc/MUIHtmlToolTip.tsx +15 -0
  265. package/src/components/misc/MuiSimpleJsonTable.tsx +279 -0
  266. package/src/components/misc/MultiLevelTable.tsx +229 -0
  267. package/src/components/misc/NoResults.tsx +25 -0
  268. package/src/components/misc/PDFViewer.tsx +85 -0
  269. package/src/components/navigation/Breadcrumbs.tsx +220 -0
  270. package/src/components/navigation/BreadcrumbsManager.tsx +310 -0
  271. package/src/components/navigation/index.tsx +5 -0
  272. package/src/components/panel/Error.tsx +168 -0
  273. package/src/components/permission/AvailablePermissionsContext.tsx +173 -0
  274. package/src/components/permission/PermissionsSelector.tsx +819 -0
  275. package/src/components/permission/PermissionsSelectorList.tsx +468 -0
  276. package/src/components/permission/tsx +0 -0
  277. package/src/components/racustombuttons/CustomRAButton.tsx +87 -0
  278. package/src/components/racustombuttons/QuickButton.tsx +117 -0
  279. package/src/components/racustombuttons/QuickEditButton.tsx +115 -0
  280. package/src/components/racustombuttons/QuickIconButton.tsx +122 -0
  281. package/src/components/scrollbar/Scrollbar.tsx +31 -0
  282. package/src/components/selects/MultiSelect.tsx +53 -0
  283. package/src/components/selects/RASearchableSelect.tsx +279 -0
  284. package/src/components/selects/RASearchableSelectChips.tsx +304 -0
  285. package/src/components/selects/SearchableSelect.tsx +135 -0
  286. package/src/components/subscription/BillingCycleSelectInput.tsx +68 -0
  287. package/src/components/subscription/PlanAddonsSettings.tsx +522 -0
  288. package/src/components/subscription/PlanAuditLog.tsx +439 -0
  289. package/src/components/subscription/PlanFeaturesSettings.tsx +223 -0
  290. package/src/components/subscription/PlanLimitsSettings.tsx +230 -0
  291. package/src/components/subscription/PlanMetadataSettings.tsx +284 -0
  292. package/src/components/subscription/PlanPricesSettings.tsx +295 -0
  293. package/src/components/subscription/index.ts +7 -0
  294. package/src/components/svgelements/SvgLoading.tsx +229 -0
  295. package/src/components/svgelements/SvgLogo.tsx +53 -0
  296. package/src/components/svgelements/SvgLogoMin.tsx +64 -0
  297. package/src/components/svgelements/SvgShipping.tsx +673 -0
  298. package/src/components/tenant/AvailablePermissionsContext.tsx +0 -0
  299. package/src/components/tenant/TenantAttributes.tsx +153 -0
  300. package/src/components/tenant/TenantAttributesContext.tsx +163 -0
  301. package/src/components/tenant/TenantSelector.tsx +139 -0
  302. package/src/components/tenant/TenantSettings.tsx +172 -0
  303. package/src/components/tenant/TenantSettingsContext.tsx +165 -0
  304. package/src/components/tenant/TenantTheme.tsx +172 -0
  305. package/src/components/user/AvatarComponent.tsx +301 -0
  306. package/src/components/user/TenantAvatarComponent.tsx +99 -0
  307. package/src/components/user/UserPreferences.tsx +642 -0
  308. package/src/config/ACTIONS.tsx +26 -0
  309. package/src/config/ConstantsService.tsx +44 -0
  310. package/src/config/DASHAdminSystemConstants.tsx +182 -0
  311. package/src/config/PARSERS.tsx +9 -0
  312. package/src/contexts/DashQueryClientContext.tsx +113 -0
  313. package/src/contexts/DashResourceContext.tsx +34 -0
  314. package/src/contexts/I18nBridgeContext.tsx +156 -0
  315. package/src/contexts/I18nBridgeSetter.tsx +39 -0
  316. package/src/contexts/I18nReduxSync.tsx +27 -0
  317. package/src/contexts/SubscriptionPlanFormatsProvider.tsx +217 -0
  318. package/src/contexts/SystemRequestsCache.tsx +215 -0
  319. package/src/contexts/auth/AuthContext.tsx +553 -0
  320. package/src/contexts/auth/AuthContextLocalStorage.tsx +140 -0
  321. package/src/contexts/auth/DASHAuthenticationService.tsx +917 -0
  322. package/src/contexts/auth/WindowContext.tsx +15 -0
  323. package/src/contexts/auth/index.tsx +3 -0
  324. package/src/contexts/com/FCMContext.tsx +415 -0
  325. package/src/contexts/com/LaravelEchoContext.tsx +41 -0
  326. package/src/contexts/com/LaravelEchoMgr.tsx +155 -0
  327. package/src/contexts/com/components/DefaultNotificationComponent.tsx +20 -0
  328. package/src/contexts/com/components/NotificationAttributesTable.tsx +54 -0
  329. package/src/contexts/com/components/NotificationRenderer.tsx +42 -0
  330. package/src/contexts/com/components/NotificationsWidget.tsx +182 -0
  331. package/src/contexts/com/components/notificationFormats.tsx +50 -0
  332. package/src/contexts/com/useLaravelEcho.tsx +432 -0
  333. package/src/contexts/dictionary/DictionaryContext.tsx +94 -0
  334. package/src/default-theme/DASHAppProviders.tsx +117 -0
  335. package/src/default-theme/DashThemeContext.tsx +218 -0
  336. package/src/default-theme/DashThemeHelperProvider.tsx +98 -0
  337. package/src/default-theme/DomainAppLayout.tsx +166 -0
  338. package/src/default-theme/DomainHeader.tsx +162 -0
  339. package/src/default-theme/DomainTheme.tsx +59 -0
  340. package/src/default-theme/FullLayoutMarkup.tsx +250 -0
  341. package/src/default-theme/StaticLayout.tsx +47 -0
  342. package/src/default-theme/index.tsx +11 -0
  343. package/src/default-theme/menu/AppMaterialMenu.tsx +545 -0
  344. package/src/default-theme/menu/AppMenuComponents/SubmenuPortal.tsx +56 -0
  345. package/src/default-theme/menu/AppMenuComponents/collapsed/CollapsedSidebarItem.tsx +254 -0
  346. package/src/default-theme/menu/AppMenuComponents/collapsed/CollapsedSidebarItems.tsx +31 -0
  347. package/src/default-theme/menu/AppMenuComponents/expanded/CollapsableSidebarMenu.tsx +276 -0
  348. package/src/default-theme/menu/AppMenuComponents/expanded/SidebarItem.tsx +91 -0
  349. package/src/default-theme/menu/AppMenuComponents/getItem.tsx +17 -0
  350. package/src/default-theme/menu/AppMenuComponents/interfaces.tsx +41 -0
  351. package/src/default-theme/menu/AppMenuComponents/submenuConstants.ts +85 -0
  352. package/src/default-theme/menu/AppSidebarMaterial.tsx +339 -0
  353. package/src/default-theme/menu/SidebarActions.tsx +84 -0
  354. package/src/default-theme/updateDomCssVariables.tsx +176 -0
  355. package/src/helpers/checkRole.tsx +66 -0
  356. package/src/helpers/parseAxiosError.tsx +41 -0
  357. package/src/hooks/audio/useAudio.tsx +39 -0
  358. package/src/hooks/axios.tsx +62 -0
  359. package/src/hooks/data/useDashboardStats.tsx +65 -0
  360. package/src/hooks/data/usePackageByClientsStats.tsx +44 -0
  361. package/src/hooks/data/usePackageByCommunesStats.tsx +44 -0
  362. package/src/hooks/data/usePackageStats.tsx +69 -0
  363. package/src/hooks/data/usePackageWithdrawDetails.tsx +61 -0
  364. package/src/hooks/data/useStats.tsx +86 -0
  365. package/src/hooks/isCurrentPath.tsx +22 -0
  366. package/src/hooks/notifications/WSMessagesManager.tsx +152 -0
  367. package/src/hooks/notifications/WSPusherManager.tsx +92 -0
  368. package/src/hooks/useBreadcrumbs.tsx +329 -0
  369. package/src/hooks/useClickOutside.tsx +17 -0
  370. package/src/hooks/useFormPersistance.tsx +150 -0
  371. package/src/hooks/useGlobalErrorMediator.tsx +43 -0
  372. package/src/hooks/useGlobalLoaderMgr.tsx +21 -0
  373. package/src/hooks/useHash.tsx +27 -0
  374. package/src/hooks/useLocalStorage.tsx +196 -0
  375. package/src/hooks/usePolyglotTranslation.tsx +62 -0
  376. package/src/hooks/usePrevious.tsx +9 -0
  377. package/src/hooks/usePrintSelected.tsx +37 -0
  378. package/src/hooks/useVirtualHash.tsx +33 -0
  379. package/src/hooks/window/useWindowSize.tsx +36 -0
  380. package/src/index.tsx +110 -0
  381. package/src/interfaces/IAppResourceConfig.tsx +20 -0
  382. package/src/interfaces/Log.tsx +16 -0
  383. package/src/interfaces/Tenant.tsx +25 -0
  384. package/src/interfaces/communication/IActions.tsx +5 -0
  385. package/src/interfaces/communication/INotification.tsx +21 -0
  386. package/src/interfaces/communication/IPayload.tsx +3 -0
  387. package/src/interfaces/communication/IRequestAction.tsx +10 -0
  388. package/src/interfaces/communication/IRequestPayload.tsx +7 -0
  389. package/src/interfaces/communication/IResponseAction.tsx +7 -0
  390. package/src/interfaces/misc/IAny.tsx +3 -0
  391. package/src/interfaces/misc/IFlashMessage.tsx +10 -0
  392. package/src/interfaces/navigation/IAppMenu.ts +14 -0
  393. package/src/interfaces/navigation/ICollapsableSidebarMenu.ts +12 -0
  394. package/src/interfaces/navigation/IMenuItem.ts +16 -0
  395. package/src/interfaces/notifications/IModel.tsx +6 -0
  396. package/src/interfaces/notifications/IModelField.tsx +8 -0
  397. package/src/interfaces/notifications/IUserNotification.tsx +12 -0
  398. package/src/interfaces/notifications/IUserNotificationData.tsx +13 -0
  399. package/src/interfaces/notifications/IUserNotificationPayload.tsx +8 -0
  400. package/src/interfaces/user/IGetAuth.tsx +92 -0
  401. package/src/interfaces/user/ITenantSettings.tsx +3 -0
  402. package/src/interfaces/user/IUser.tsx +60 -0
  403. package/src/interfaces/user/IUserSettings.tsx +43 -0
  404. package/src/interfaces.tsx +6 -0
  405. package/src/layout/AppLayout.tsx +112 -0
  406. package/src/layout/ApplicationLayout.tsx +197 -0
  407. package/src/layout/MotionWrapper.original.tsx +236 -0
  408. package/src/layout/MotionWrapper.tsx +236 -0
  409. package/src/layout/ResourceMenu.tsx +164 -0
  410. package/src/layout/ResoureLayout.tsx +105 -0
  411. package/src/layout/TransitionWrapper.tsx +125 -0
  412. package/src/pages/ChangePassword.tsx +179 -0
  413. package/src/pages/DASHLanding.tsx +22 -0
  414. package/src/pages/DASHLightWeightLogin.tsx +610 -0
  415. package/src/pages/DASHSimpleLogin.tsx +260 -0
  416. package/src/pages/Login.tsx +111 -0
  417. package/src/pages/Profile.tsx +394 -0
  418. package/src/pages/RecoverPassword.tsx +166 -0
  419. package/src/pages/SingleImageUploader.tsx +55 -0
  420. package/src/pages/VerifyAccount.tsx +128 -0
  421. package/src/providers/authProvider.tsx +210 -0
  422. package/src/providers/dataProvider.tsx +672 -0
  423. package/src/providers/i18n/en.ts +533 -0
  424. package/src/providers/i18n/es.ts +539 -0
  425. package/src/providers/i18n/languages.tsx +5 -0
  426. package/src/providers/i18nProvider.tsx +23 -0
  427. package/src/react-admin-dash/RADashComponent.tsx +240 -0
  428. package/src/react-admin-dash/Resource.tsx +77 -0
  429. package/src/resources/Brand/BrandResource.tsx +130 -0
  430. package/src/resources/DASHResourceLoader.ts +180 -0
  431. package/src/resources/Log/LogResource.tsx +73 -0
  432. package/src/resources/Tenant/ImpersonateTenantResource.tsx +113 -0
  433. package/src/resources/Trash/TrashTemplate.tsx +180 -0
  434. package/src/resources.tsx +280 -0
  435. package/src/schemas/log.tsx +45 -0
  436. package/src/schemas/notification.tsx +42 -0
  437. package/src/schemas/permissions.tsx +44 -0
  438. package/src/schemas/roles.tsx +48 -0
  439. package/src/schemas/rolesDataGrid.tsx +48 -0
  440. package/src/schemas/subscription/components/SubscriptionActions.tsx +153 -0
  441. package/src/schemas/subscription/components/SubscriptionPaymentHistory.tsx +120 -0
  442. package/src/schemas/subscription/components/SubscriptionPlanFeatures.tsx +155 -0
  443. package/src/schemas/subscription/components/SubscriptionPlanPreview.tsx +128 -0
  444. package/src/schemas/subscription/components/SubscriptionPlanStats.tsx +268 -0
  445. package/src/schemas/subscription/components/SubscriptionStatusIndicator.tsx +72 -0
  446. package/src/schemas/subscription/subscriptionPlanSchema.tsx +185 -0
  447. package/src/schemas/subscription/subscriptionSchema.tsx +152 -0
  448. package/src/schemas/subscriptionPlan.ts +422 -0
  449. package/src/schemas/tenant.tsx +129 -0
  450. package/src/schemas/tenantUser.tsx +96 -0
  451. package/src/schemas/tenant_superadmin.tsx +119 -0
  452. package/src/schemas/user.tsx +26 -0
  453. package/src/systemResources.old.tsx +928 -0
  454. package/src/systemResources.tsx +1135 -0
  455. package/src/templates/ResourceTemplate.tsx +240 -0
  456. package/src/templates/ResourceTemplateCreate.tsx +167 -0
  457. package/src/templates/ResourceTemplateEdit.tsx +176 -0
  458. package/src/templates/ResourceTemplateFull.tsx +581 -0
  459. package/src/templates/ResourceTemplateList.tsx +340 -0
  460. package/src/templates/ResourceTemplateShow.tsx +88 -0
  461. package/src/templates/TrashTemplate.tsx +179 -0
  462. package/src/tenantResources.tsx +223 -0
  463. package/src/test_portal_bubbles.tsx +40 -0
  464. package/src/theme/AppHeader.tsx +52 -0
  465. package/src/theme/AppLayoutSetting.tsx +33 -0
  466. package/src/theme/AppLogo.tsx +13 -0
  467. package/src/theme/AppSidebar.tsx +12 -0
  468. package/src/theme/AppSidebarContent.tsx +105 -0
  469. package/src/theme/AppSidebarLogo.tsx +48 -0
  470. package/src/theme/components/PageTitle.tsx +37 -0
  471. package/src/utils/cache/CacheInvalidatorContext.tsx +125 -0
  472. package/src/utils/cache/CacheInvalidatorListenerComponent.tsx +10 -0
  473. package/src/utils/cache/useCacheInvalidatorListener.tsx +27 -0
  474. package/src/utils/convertFileToBase64.tsx +9 -0
  475. package/src/utils/convertToFile.tsx +14 -0
  476. package/src/utils/cookies.tsx +33 -0
  477. package/src/utils/dashDefaultQueryClient.tsx +34 -0
  478. package/src/utils/dataUrlToBlob.tsx +30 -0
  479. package/src/utils/deepReplace.tsx +19 -0
  480. package/src/utils/getProfileMenu.tsx +41 -0
  481. package/src/utils/getTenantSettings.tsx +9 -0
  482. package/src/utils/getType.tsx +8 -0
  483. package/src/utils/getUserSettings.tsx +8 -0
  484. package/src/utils/hasCode.tsx +14 -0
  485. package/src/utils/index.ts +19 -0
  486. package/src/utils/injectTenantStyles.ts +28 -0
  487. package/src/utils/isComponent.tsx +45 -0
  488. package/src/utils/navEvents.tsx +91 -0
  489. package/src/utils/prototypes.tsx +5 -0
  490. package/src/utils/regexp.tsx +4 -0
  491. package/src/utils/resolveObjectPath.tsx +4 -0
  492. package/src/utils/setNativeValue.tsx +24 -0
  493. package/src/utils/slugify.tsx +11 -0
  494. package/src/utils/validators/emailValidator.tsx +6 -0
  495. package/src/utils/validators/requiredValidator.tsx +5 -0
  496. package/src/utils/validators/rutValidator.tsx +31 -0
  497. package/src/utils/validators.tsx +96 -0
  498. package/dist/ChangePassword-DmWAQAX_.js +0 -152
  499. package/dist/Login-t41HMhVT.js +0 -101
  500. package/dist/Profile-By-gdPUd.js +0 -294
  501. package/dist/RecoverPassword-DzPdbkg2.js +0 -149
  502. package/dist/VerifyAccount-Bofaxe5w.js +0 -99
  503. package/dist/index-gfebuoyf.js +0 -21614
  504. /package/dist/{components/permission/tsx → declarations.d.js} +0 -0
  505. /package/{dist → src}/DASHAdmin.tsx.old +0 -0
  506. /package/{dist → src}/declarations.d.ts +0 -0
  507. /package/{dist → src}/default-theme/DashThemeContext.tsx.fast +0 -0
  508. /package/{dist → src}/default-theme/DashThemeContext.tsx.old +0 -0
  509. /package/{dist → src}/templates/ResourceTemplate.tsx.memoized_experiment +0 -0
  510. /package/{dist → src}/templates/ResourceTemplate.tsx.original +0 -0
  511. /package/{dist → src}/templates/ResourceTemplateOld.tsx.bkup +0 -0
@@ -0,0 +1,545 @@
1
+ import * as React from 'react';
2
+
3
+ import { useSelector } from 'react-redux';
4
+ // Remove this import
5
+ // import { usePermissions } from 'react-admin';
6
+
7
+ import { List, IconButton, Box, useMediaQuery, useTheme } from '@mui/material';
8
+ import KeyboardDoubleArrowLeftIcon from '@mui/icons-material/KeyboardDoubleArrowLeft';
9
+ import KeyboardDoubleArrowRightIcon from '@mui/icons-material/KeyboardDoubleArrowRight';
10
+ import MenuOpenIcon from '@mui/icons-material/MenuOpen';
11
+ import { useEffect } from 'react';
12
+ import { IMenuItem, IAppMenu } from './AppMenuComponents/interfaces';
13
+ import SidebarItem from './AppMenuComponents/expanded/SidebarItem';
14
+ import SidebarItemCollapse from './AppMenuComponents/expanded/CollapsableSidebarMenu';
15
+ import CollapsedSidebarItems from './AppMenuComponents/collapsed/CollapsedSidebarItems';
16
+ import { IDashAutoAdminResourceConfig } from 'dash-auto-admin';
17
+
18
+ import { IDASHAppState, usePanelSettings } from 'dash-admin-state';
19
+ import checkRole from '../../helpers/checkRole';
20
+ import { slugify } from '../../utils/slugify';
21
+ // Direct imports to avoid circular barrel imports
22
+ import AvatarComponent from '../../components/user/AvatarComponent';
23
+ import TenantAvatarComponent from '../../components/user/TenantAvatarComponent';
24
+
25
+ import Scrollbar from '../../components/scrollbar/Scrollbar';
26
+ // Add this import
27
+ import { AuthPersistenceService } from 'dash-auth';
28
+ import { useAuthContext } from '../../contexts/auth/AuthContext';
29
+ import DarkToggleMode from '../../components/menu/DarkToggleMode';
30
+ // Use I18nBridgeContext exclusively
31
+ import { useI18nBridge } from '../../contexts/I18nBridgeContext';
32
+ import BridgedLocalesMenuButton from '../../components/i18n/BridgedLocalesMenuButton';
33
+
34
+ import { dashStorage } from 'dash-utils';
35
+ import SidebarActions from './SidebarActions';
36
+ import { useNavigate } from 'react-router';
37
+
38
+ // Update the interface to include new props
39
+ interface IAppMenuExtended extends IAppMenu {
40
+ logos?: {
41
+ horizontalLogo: React.ReactNode;
42
+ squaredLogo: React.ReactNode;
43
+ };
44
+ onToggleDrawer?: (e: React.MouseEvent) => void;
45
+ }
46
+
47
+ // Group icons
48
+ const GenerateItems: React.FC<{ items: IMenuItem[]; navExpanded: boolean, navSize: "large" | "small", level: number, sidebarPosition?: "left" | "top" | "bottom" | "right", translate: (key: string, options?: any) => string }> = ({
49
+ items,
50
+ navExpanded,
51
+ navSize,
52
+ level,
53
+ sidebarPosition = "left",
54
+ translate
55
+ }) => {
56
+ const isHorizontal = sidebarPosition === "top" || sidebarPosition === "bottom";
57
+
58
+ return items &&
59
+ <>
60
+ {navExpanded && navSize === "large" ? (
61
+ <List
62
+ className={'sidebar-list'}
63
+ component='nav'
64
+ sx={isHorizontal ? {
65
+ display: 'flex',
66
+ flexDirection: 'row',
67
+ flexWrap: 'nowrap',
68
+ alignItems: 'center',
69
+ padding: 0,
70
+ margin: 0,
71
+ } : undefined}
72
+ >
73
+ {items.map((item, index) => {
74
+ return item.children && item.children.length ? (
75
+ <SidebarItemCollapse
76
+ navExpanded={navExpanded}
77
+ navSize={navSize}
78
+ item={item}
79
+ key={index}
80
+ level={level + 1}
81
+ sidebarPosition={sidebarPosition}
82
+ />
83
+ ) : (
84
+
85
+ <SidebarItem level={level} navExpanded={navExpanded} navSize={navSize} item={item} key={index} />
86
+ );
87
+ })}
88
+ </List>
89
+ ) : (
90
+ <CollapsedSidebarItems level={level} items={items} navExpanded={navExpanded} navSize={navSize} sidebarPosition={sidebarPosition} />
91
+ )}
92
+ </>
93
+
94
+ };
95
+
96
+
97
+ const AppMaterialMenu: React.FC<IAppMenuExtended> = props => {
98
+
99
+ const DEBUG = true;
100
+ const { menu, debug, navExpanded, navSize, logos, onToggleDrawer, sidebarPosition: propSidebarPosition } = props;
101
+ const navigate = useNavigate();
102
+ const theme = useTheme();
103
+ const isSmallScreen = useMediaQuery(theme.breakpoints.down('sm'));
104
+ const isMediumScreen = useMediaQuery(theme.breakpoints.down('md')); // For logo switching
105
+
106
+ // Get panel settings from Redux (includes dimensions, padding, but NOT sidebarPosition - that comes from prop)
107
+ const { sidebarLargeWidth, sidebarSmallWidth, sidebarHorizontalHeight, logoVerticalMaxWidth, logoVerticalMaxHeight, logoHorizontalMaxWidth, logoHorizontalMaxHeight } = usePanelSettings();
108
+
109
+ // Use sidebarPosition from prop (which is responsive from AppSidebarMaterial) with fallback to 'left'
110
+ const sidebarPosition = propSidebarPosition || 'left';
111
+
112
+ // Get i18n from Bridge context exclusively
113
+ const { i18nProvider, locale: currentLocale } = useI18nBridge();
114
+
115
+ // Use bridged translate
116
+ const translate = React.useCallback((key: string, options?: any) => {
117
+ // Safety check for non-string keys
118
+ if (typeof key !== 'string') {
119
+ return key;
120
+ }
121
+ // Use bridged provider
122
+ if (i18nProvider?.translate) {
123
+ try {
124
+ return i18nProvider.translate(key, options);
125
+ } catch (e) {
126
+ console.warn('Translation error:', e);
127
+ return key;
128
+ }
129
+ }
130
+ return key;
131
+ }, [i18nProvider]);
132
+
133
+ useEffect(() => {
134
+ DEBUG && console.log('🌐 AppMaterialMenu: Bridged i18nProvider:', i18nProvider);
135
+ DEBUG && console.log('🌐 AppMaterialMenu: currentLocale:', currentLocale);
136
+
137
+ // Enhanced debug: test translate with various keys
138
+ DEBUG && console.log('🧪 Translation test:', {
139
+ // Test react-admin built-in keys
140
+ 'ra.action.delete': translate('ra.action.delete'),
141
+ 'ra.action.save': translate('ra.action.save'),
142
+ // Test top-level custom keys
143
+ 'kiosk.total': translate('kiosk.total'),
144
+ // Test nested resource keys
145
+ 'resource.groups.products': translate('resource.groups.products'),
146
+ 'resource.system.tenants.label': translate('resource.system.tenants.label'),
147
+ });
148
+ }, [i18nProvider, currentLocale, translate]);
149
+
150
+ //const resources = useResourceDefinitions()
151
+
152
+ // Replace usePermissions with useAuthContext - add null check
153
+ // const { permissions } = usePermissions();
154
+ const authContext = useAuthContext();
155
+
156
+ const [items, setItems] = React.useState<IMenuItem[]>(null);
157
+
158
+
159
+ // State for tenant logos
160
+ /* const [tenantLogos, setTenantLogos] = React.useState<{
161
+ horizontalLogo: string | null;
162
+ squaredLogo: string | null;
163
+ }>({
164
+ horizontalLogo: null,
165
+ squaredLogo: null
166
+ });*/
167
+
168
+ const resources = useSelector(
169
+ (
170
+ state: IDASHAppState<any, any, IDashAutoAdminResourceConfig>,
171
+ ) => {
172
+ if (debug || menu) {
173
+ return menu;
174
+ }
175
+ return state.resources.items;
176
+ },
177
+ );
178
+
179
+ // Track resource changes for debugging
180
+ const prevResourcesRef = React.useRef<any[]>(null);
181
+ React.useEffect(() => {
182
+ const prevResources = prevResourcesRef.current;
183
+ const prevModels = Array.isArray(prevResources) ? prevResources.map((r: any) => r.model) : [];
184
+ const newModels = Array.isArray(resources) ? resources.map((r: any) => r.model) : [];
185
+ const added = newModels.filter(m => !prevModels.includes(m));
186
+ const removed = prevModels.filter(m => !newModels.includes(m));
187
+ console.log('📊 AppMaterialMenu: Resources from Redux', {
188
+ isSameRef: prevResources === resources,
189
+ prevCount: prevResources?.length || 0,
190
+ newCount: resources?.length || 0,
191
+ added: added.length > 0 ? added : 'none',
192
+ removed: removed.length > 0 ? removed : 'none',
193
+ allModels: newModels,
194
+ });
195
+ prevResourcesRef.current = resources;
196
+ }, [resources]);
197
+
198
+ const panelSettings = useSelector((state: any) => state.common.panelSettings);
199
+ const horizontalLogo = panelSettings?.horizontalLogo;
200
+ const squaredLogo = panelSettings?.squaredLogo;
201
+
202
+ const groupIcons = useSelector(
203
+ (state: IDASHAppState<any, any, IDashAutoAdminResourceConfig>) =>
204
+ state.settings.groupIcons
205
+ );
206
+
207
+ // Load tenant logos from AuthPersistenceService
208
+ /*useEffect(() => {
209
+ const tenantImages = AuthPersistenceService.getTenantImages();
210
+ DEBUG && console.log('AppMaterialMenu Loaded: loading tenant images:', tenantImages);
211
+ if (tenantImages) {
212
+ //console.log('AppMaterialMenu: Loading tenant logos:', tenantImages);
213
+
214
+
215
+
216
+ setTenantLogos({
217
+ horizontalLogo: tenantImages.horizontal_logo?.original || null,
218
+ squaredLogo: tenantImages.squared_logo?.original || null
219
+ });
220
+ } else {
221
+ DEBUG && console.log('AppMaterialMenu: No tenant images found');
222
+ setTenantLogos({
223
+ horizontalLogo: null,
224
+ squaredLogo: null
225
+ });
226
+ }
227
+
228
+
229
+
230
+ //console.log('DASHTRefreshTheme');
231
+ window.dispatchEvent(new CustomEvent("DASHTRefreshTheme", {}));
232
+
233
+
234
+
235
+
236
+ }, []);*/
237
+
238
+ useEffect(() => {
239
+ // Don't process resources if permissions haven't been loaded yet and not in debug mode
240
+
241
+ // Get user roles, defaulting to ["Public"] for unauthenticated users
242
+ const userRoles = authContext?.user?.roles
243
+ ? authContext.user.roles.flatMap(role => role.name)
244
+ : ["Public"];
245
+
246
+ const groups = [
247
+ ...new Set(
248
+ resources
249
+ .map((resource) => resource.group)
250
+ .filter((x) => x !== null && x !== undefined && x !== ''),
251
+ ),
252
+ ];
253
+ //group resources belonging to the group
254
+ const groupedResources = new Object();
255
+ groups.forEach((group) => {
256
+ groupedResources[group as string] = resources.filter((resource) => {
257
+
258
+ //console.log(resource.group + " | ", resource.label + " | ", permissions, resource.roles, checkRole(permissions, resource.roles));
259
+ /* @ts-ignore */
260
+ return (resource.group === group && checkRole(userRoles, resource.roles));
261
+ });
262
+ });
263
+ const _items: IMenuItem[] = [];
264
+
265
+
266
+
267
+ Object.keys(groupedResources).map((groupKey) => {
268
+ const group: IDashAutoAdminResourceConfig[] = groupedResources[groupKey];
269
+ if (!group.length) return;
270
+ const hidden = group[0] && group[0].hidden === true ? true : false;
271
+ if (hidden) return;
272
+
273
+ const _childrens = group
274
+ .filter((resource) => resource.hidden !== true);
275
+
276
+ // Generate paths relative to BrowserRouter basename (don't prepend currentAppPath)
277
+ // React Router's Link components will automatically prepend the basename
278
+ const _children = _childrens
279
+ .map((resource) => {
280
+
281
+ /* debugger;
282
+ const translation = translate(resource.label)
283
+ console.log( translation);
284
+
285
+ debugger;
286
+ */
287
+
288
+ console.log('translating resource label:', resource.label, translate(resource.label));
289
+
290
+ // Add more debug info
291
+ // Use optional chaining carefully since i18nProvider might be null
292
+ const currentLocale = i18nProvider?.getLocale?.() || 'unknown';
293
+ const messages = i18nProvider?.getMessages?.(currentLocale) || {};
294
+ const hasKey = messages[resource.label] !== undefined;
295
+
296
+ console.log('🌐 Translation debug:', {
297
+ key: resource.label,
298
+ currentLocale,
299
+ hasKey,
300
+ translation: messages[resource.label],
301
+ allMessagesKeys: Object.keys(messages).filter(k => k.includes('resource.system')),
302
+ translateResult: translate(resource.label)
303
+ });
304
+
305
+ // For menuOnly resources, use redirect or path directly as the navigation target
306
+ // For regular resources, build the path from model + optional redirect
307
+ const buildMenuPath = () => {
308
+ if (resource.menuOnly) {
309
+ // menuOnly: use redirect, path, or fallback to model
310
+ return resource.redirect || resource.path || `/${resource.model}`;
311
+ }
312
+ // Regular resource: existing logic
313
+ if (resource?.redirect?.startsWith('/')) {
314
+ return resource.redirect;
315
+ }
316
+ if (resource?.redirect) {
317
+ return `/${resource.model}/${resource.redirect}`.replace(/\/+/g, '/');
318
+ }
319
+ return `/${resource.model}`.replace(/\/+/g, '/');
320
+ };
321
+
322
+ return {
323
+ label: translate(resource.label, { _: resource.label }),
324
+ key: resource.label,
325
+ to: buildMenuPath(),
326
+ icon: resource.icon,
327
+ group: slugify(group[0].group),
328
+ model: resource.model,
329
+ menuOnly: resource.menuOnly,
330
+ txtLabel: translate(resource.label, { _: resource.label }),
331
+ };
332
+ });
333
+
334
+ // Generate path relative to BrowserRouter basename (don't prepend currentAppPath)
335
+ // React Router's Link components will automatically prepend the basename
336
+ const _item: IMenuItem = {
337
+ label: translate(group[0].group, { _: group[0].group }),
338
+ key: slugify(group[0].group),
339
+ icon: group[0].icon || groupIcons[group[0].group],
340
+ group: slugify(group[0].group),
341
+ model: group[0].model,
342
+ to: group[0].redirect?.startsWith('/')
343
+ ? group[0].redirect
344
+ : group[0].redirect
345
+ ? `/${group[0].model}/${group[0].redirect}`.replace(/\/+/g, '/')
346
+ : `/${group[0].model}`.replace(/\/+/g, '/'),
347
+ txtLabel: translate(group[0].group, { _: group[0].group }),
348
+ ...(_childrens && _childrens.length > 1 && { children: _children }) as any
349
+ };
350
+
351
+ _items.push(_item);
352
+
353
+ });
354
+
355
+ // Add ungrouped resources as top-level items
356
+ const ungroupedResources = resources.filter((resource) => {
357
+ const hasGroup = resource.group !== null && resource.group !== undefined && resource.group !== '';
358
+ return !hasGroup && checkRole(userRoles, resource.roles) && resource.hidden !== true;
359
+ });
360
+
361
+ ungroupedResources.forEach((resource) => {
362
+ const buildMenuPath = () => {
363
+ if (resource.menuOnly) {
364
+ return resource.redirect || resource.path || `/${resource.model}`;
365
+ }
366
+ if (resource?.redirect?.startsWith('/')) {
367
+ return resource.redirect;
368
+ }
369
+ if (resource?.redirect) {
370
+ return `/${resource.model}/${resource.redirect}`.replace(/\/+/g, '/');
371
+ }
372
+ return `/${resource.model}`.replace(/\/+/g, '/');
373
+ };
374
+
375
+ _items.push({
376
+ label: translate(resource.label, { _: resource.label }),
377
+ key: resource.label || resource.model,
378
+ to: buildMenuPath(),
379
+ icon: resource.icon,
380
+ group: null,
381
+ model: resource.model,
382
+ menuOnly: resource.menuOnly,
383
+ txtLabel: translate(resource.label, { _: resource.label }),
384
+ });
385
+ });
386
+ DEBUG && console.log("MENU ITEMS", _items);
387
+ setItems(_items);
388
+ }, [resources, debug, authContext?.user, translate, i18nProvider, currentLocale]); // Include translate, i18nProvider and currentLocale to rebuild menu when translations change
389
+
390
+ const isHorizontal = sidebarPosition === "top" || sidebarPosition === "bottom";
391
+
392
+ return <>
393
+ <Box className='sidebar-header'
394
+
395
+ sx={{
396
+ display: 'flex',
397
+ flexDirection: isHorizontal ? 'row' : (navExpanded && navSize === 'large' ? 'row' : 'column'),
398
+ alignItems: isHorizontal ? 'center' : undefined,
399
+ }
400
+
401
+ }>
402
+
403
+ <Box sx={{
404
+ paddingRight: '5px',
405
+ //borderRight: navExpanded && navSize === 'large' ? '1px solid rgba(0, 0, 0, 0.12)' : 'none',
406
+ display: 'flex',
407
+ flexDirection: 'column',
408
+ alignItems: 'center',
409
+ gap: 1
410
+ }}>
411
+
412
+ <Box
413
+ sx={{
414
+ display: 'flex',
415
+ alignItems: 'center',
416
+ //gap: 1,
417
+ flexDirection: 'column',
418
+
419
+ }}>
420
+ {/* Toggle icon - burger for mobile, arrows for desktop */}
421
+ {onToggleDrawer && (
422
+ <IconButton
423
+ className='dash-icon-button-color dash-icon-button-bg'
424
+ onClick={onToggleDrawer}
425
+ sx={{
426
+ m:1
427
+ }}
428
+ /*sx={{
429
+ m:1,
430
+ padding: '8px',
431
+ borderRadius: '8px',
432
+ backgroundColor: 'rgba(255,255,255,0.1)',
433
+ '&:hover': {
434
+ backgroundColor: 'rgba(255,255,255,0.2)',
435
+ }
436
+ }}*/
437
+
438
+ >
439
+ {navSize === 'small' ? (
440
+ <MenuOpenIcon sx={{ fontSize: 28, transform: 'scaleX(-1)' }} />
441
+ ) : navExpanded ? (
442
+ <KeyboardDoubleArrowLeftIcon sx={{ fontSize: 28 }} />
443
+ ) : (
444
+ <KeyboardDoubleArrowRightIcon sx={{ fontSize: 28 }} />
445
+ )}
446
+ </IconButton>
447
+ )}
448
+ {!(navExpanded && navSize === 'large') && !isSmallScreen && <TenantAvatarComponent
449
+ navExpanded={navExpanded}
450
+ navSize={navSize}
451
+ imageUrl={isMediumScreen || sidebarPosition === "left" || sidebarPosition === "right" ? squaredLogo : horizontalLogo}
452
+ maxWidth={isHorizontal ? logoHorizontalMaxWidth : logoVerticalMaxWidth}
453
+ maxHeight={isHorizontal ? logoHorizontalMaxHeight : logoVerticalMaxHeight}
454
+ sidebarSmallWidth={sidebarSmallWidth}
455
+ alt="Tenant Logo"
456
+ sidebarPosition={sidebarPosition}
457
+ onClick={() => navigate('/')}
458
+ />}
459
+ </Box>
460
+
461
+
462
+ {(sidebarPosition === "left" || sidebarPosition === "right") && (
463
+ <SidebarActions sidebarPosition={sidebarPosition} navExpanded={navExpanded} />
464
+ )}
465
+
466
+
467
+ </Box>
468
+
469
+ {navExpanded && navSize === 'large' && <Box
470
+ sx={{
471
+ display: 'flex',
472
+ alignItems: 'center',
473
+
474
+ flexDirection: 'column',
475
+
476
+ }}
477
+
478
+ >
479
+
480
+ <TenantAvatarComponent
481
+ navExpanded={navExpanded}
482
+ navSize={navSize}
483
+
484
+ imageUrl={isMediumScreen || sidebarPosition === "left" || sidebarPosition === "right" ? squaredLogo : horizontalLogo}
485
+ maxWidth={isHorizontal ? logoHorizontalMaxWidth : logoVerticalMaxWidth}
486
+ maxHeight={isHorizontal ? logoHorizontalMaxHeight : logoVerticalMaxHeight}
487
+ sidebarSmallWidth={sidebarSmallWidth}
488
+ alt="Tenant Logo"
489
+ sidebarPosition={sidebarPosition}
490
+ onClick={() => navigate('/')}
491
+ />
492
+
493
+
494
+
495
+ </Box>}
496
+
497
+
498
+ </Box>
499
+
500
+ {/* For horizontal mode (top/bottom), use a simple Box instead of Scrollbar
501
+ since react-custom-scrollbars creates nested divs that break flex layout */}
502
+ {(sidebarPosition === "top" || sidebarPosition === "bottom") ? (
503
+ <Box
504
+ className="dash-layout-sider-scrollbar horizontal-mode"
505
+ sx={{
506
+ display: 'flex',
507
+ flexDirection: 'row',
508
+ overflowX: 'auto',
509
+ overflowY: 'hidden',
510
+ flex: 1,
511
+ height: '100%',
512
+ alignItems: 'center',
513
+ }}
514
+ >
515
+ <GenerateItems items={items} navExpanded={navExpanded} navSize={navSize} level={0} sidebarPosition={sidebarPosition} translate={translate} />
516
+ </Box>
517
+ ) : (
518
+ <Scrollbar
519
+ //autoHide={true}
520
+ //autoHideTimeout={1000}
521
+ //autoHideDuration={200}
522
+ className={'dash-layout-sider-scrollbar'}
523
+ >
524
+ <GenerateItems items={items} navExpanded={navExpanded} navSize={navSize} level={0} sidebarPosition={sidebarPosition} translate={translate} />
525
+ </Scrollbar>
526
+ )}
527
+
528
+ {(sidebarPosition === "top" || sidebarPosition === "bottom") && (
529
+ <SidebarActions sidebarPosition={sidebarPosition} navExpanded={navExpanded} />
530
+ )}
531
+
532
+
533
+ </>
534
+
535
+
536
+ };
537
+
538
+ /*export default React.memo(
539
+ AppMaterialMenu,
540
+ (props, nextProps) =>
541
+ props === nextProps
542
+ ) as typeof AppMaterialMenu;
543
+ */
544
+
545
+ export default AppMaterialMenu;
@@ -0,0 +1,56 @@
1
+ import React, { RefObject } from 'react';
2
+ import ReactDOM from 'react-dom';
3
+ import { SidebarPosition } from '../AppSidebarMaterial';
4
+ import { getSubmenuStyle, SUBMENU_SCROLL_THRESHOLD } from './submenuConstants';
5
+
6
+ export interface SubmenuPortalProps {
7
+ /** Whether the submenu is open */
8
+ open: boolean;
9
+ /** Reference to the parent menu item element for position calculation */
10
+ itemRef: RefObject<HTMLElement | null>;
11
+ /** Sidebar position affects where submenu opens relative to item */
12
+ sidebarPosition: SidebarPosition;
13
+ /** Submenu content to render */
14
+ children: React.ReactNode;
15
+ /** Mouse enter handler for hover behavior */
16
+ onMouseEnter?: () => void;
17
+ /** Mouse leave handler for hover behavior */
18
+ onMouseLeave?: () => void;
19
+ /** Number of children items (affects renderAtTop behavior) */
20
+ childrenCount?: number;
21
+ /** Additional CSS class */
22
+ className?: string;
23
+ }
24
+
25
+ /**
26
+ * Shared portal component for rendering submenus.
27
+ * Renders content in a portal attached to document.body with calculated position.
28
+ */
29
+ const SubmenuPortal: React.FC<SubmenuPortalProps> = ({
30
+ open,
31
+ itemRef,
32
+ sidebarPosition,
33
+ children,
34
+ onMouseEnter,
35
+ onMouseLeave,
36
+ childrenCount = 0,
37
+ className = 'sidebar-submenu-portal',
38
+ }) => {
39
+ if (!open) return null;
40
+
41
+ const renderAtTop = childrenCount > SUBMENU_SCROLL_THRESHOLD;
42
+
43
+ return ReactDOM.createPortal(
44
+ <div
45
+ className={className}
46
+ style={getSubmenuStyle(itemRef, sidebarPosition, renderAtTop)}
47
+ onMouseEnter={onMouseEnter}
48
+ onMouseLeave={onMouseLeave}
49
+ >
50
+ {children}
51
+ </div>,
52
+ document.body
53
+ );
54
+ };
55
+
56
+ export default SubmenuPortal;