@dashadmin/dash-admin 1.3.24 → 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,229 @@
1
+ import React, { useEffect, useRef, useState } from 'react';
2
+
3
+ export interface IMultiLevelTableAction {
4
+ name: string;
5
+ callback: () => any;
6
+ }
7
+ export interface IMultiLevelTable {
8
+ data: any;
9
+ structure: any;
10
+ actionLabel?: string;
11
+ actions?: IMultiLevelTableAction[];
12
+ className?: {
13
+ table?: string;
14
+ head?: string;
15
+ body?: string;
16
+ };
17
+ }
18
+
19
+ const getFields = (structure) => [
20
+ ...structure.children.map((child) => child.display),
21
+ ...(structure.array ? getFields(structure.array) : []),
22
+ ];
23
+
24
+ const addSelfToFirstChild = (childRows, structure, row) => {
25
+ childRows[0] = [
26
+ ...structure.children.map((child) => ({
27
+ text: row[child.field],
28
+ span: childRows.length,
29
+ })),
30
+ ...childRows[0],
31
+ ];
32
+ };
33
+
34
+ const dropdown =
35
+ (getChain, actions, actionLabel) =>
36
+ ({ indices }) => {
37
+ const [show, setShow] = useState<boolean>(false);
38
+ const ref = useRef<HTMLElement>(null);
39
+
40
+ useEffect(() => {
41
+ const listener = (event) => {
42
+ if (!ref.current) return;
43
+ if (ref.current.contains(event.target)) return;
44
+ setShow(false);
45
+ };
46
+
47
+ document.addEventListener('click', listener);
48
+
49
+ return () => {
50
+ document.removeEventListener('click', listener);
51
+ };
52
+ }, [ref]);
53
+
54
+ const getClickHandler = (action) => () => {
55
+ action.callback(getChain(indices));
56
+ setShow(false);
57
+ };
58
+
59
+ return (
60
+ <span ref={ref}>
61
+ <span
62
+ onClick={(_) => setShow(!show)}
63
+ className='flex flex-row items-center justify-center cursor-pointer'
64
+ >
65
+ {actionLabel}
66
+ {show ? <span>↑</span> : <span>↓</span>}
67
+ </span>
68
+ {show && (
69
+ <div className='flex flex-col absolute right-0 bg-white rounded-md shadow-md gap-2 p-2 whitespace-nowrap border border-gray-300'>
70
+ {actions &&
71
+ actions.map((action) => (
72
+ <span
73
+ key={action.name}
74
+ onClick={getClickHandler(action)}
75
+ className='flex flex-row items-center cursor-pointer text-md hover:bg-gray-300 p-2 rounded-md'
76
+ >
77
+ {action.name}
78
+ </span>
79
+ ))}
80
+ </div>
81
+ )}
82
+ </span>
83
+ );
84
+ };
85
+ const createGetColumns = (getChain, actions, actionLabel) => {
86
+
87
+ const Dropdown = dropdown(getChain, actions, actionLabel);
88
+ return (structure, data, indices) => [
89
+ ...structure.children.map((child) => ({
90
+ text: data[child.field],
91
+ span: 1,
92
+ })),
93
+ ...(actions.length
94
+ ? [
95
+ {
96
+ text: <Dropdown indices={indices} />,
97
+ span: 1,
98
+ },
99
+ ]
100
+ : []),
101
+ ];
102
+ };
103
+
104
+ const createGetRows = (getColumns) => {
105
+ const getRows = (structure, rows, memoizedIndices) =>
106
+ rows && !structure.array
107
+ ? rows.map((row, i) =>
108
+ getColumns(structure, row, [...memoizedIndices, i]),
109
+ )
110
+ : rows
111
+ ? rows.flatMap((row, i) => {
112
+ const childRows = getRows(
113
+ structure.array,
114
+ row[structure.array.name],
115
+ [...memoizedIndices, i], // Use a linked list of a wrapper to optimise this
116
+ );
117
+ childRows && addSelfToFirstChild(childRows, structure, row);
118
+ return childRows;
119
+ })
120
+ : null;
121
+
122
+ return getRows;
123
+ };
124
+
125
+ const getChain = (indices, structure, data) => {
126
+ const chain = {};
127
+ indices.forEach((i) => {
128
+ chain[structure.name] = data[i];
129
+ structure = structure.array;
130
+ data = structure && data[i][structure.name];
131
+ });
132
+ return chain;
133
+ };
134
+
135
+ const createGetChain = (structure, data) => (indices) =>
136
+ getChain(indices, structure, data);
137
+
138
+ const TableHeader = ({ classNames, fields }) => (
139
+ <thead className={classNames?.head}>
140
+ <tr>
141
+ {fields.map((name) => (
142
+ <th className={classNames?.headCell + ' p-2 py-3'} key={name}>
143
+ {name}
144
+ </th>
145
+ ))}
146
+ </tr>
147
+ </thead>
148
+ );
149
+
150
+ const TableBody = ({ classNames, rows }) => (
151
+ <tbody className={classNames?.tableBody}>
152
+ {rows &&
153
+ rows.map((row, i) => (
154
+ <tr className={classNames?.tableRow} key={i}>
155
+ {row &&
156
+ row.map((col, j) => (
157
+ <td key={j} rowSpan={col.span}>
158
+ {col.text}
159
+ </td>
160
+ ))}
161
+ </tr>
162
+ ))}
163
+ </tbody>
164
+ );
165
+
166
+ const MultiLevelTable: React.FC<IMultiLevelTable> = ({
167
+ data,
168
+ structure,
169
+ actions,
170
+ actionLabel,
171
+ className,
172
+ }) => {
173
+
174
+
175
+ const _actions = actions || [];
176
+ const _actionLabel = actionLabel || 'Action';
177
+
178
+
179
+ const getChain = createGetChain(structure, data);
180
+ const getColumns = createGetColumns(getChain, _actions, _actionLabel);
181
+ const getRows = createGetRows(getColumns);
182
+
183
+ const rows = getRows(structure, data, []);
184
+ const fields = [
185
+ ...getFields(structure),
186
+ ...(_actions.length ? [_actionLabel] : []),
187
+ ];
188
+
189
+ return (
190
+ rows && (
191
+ <table className={className?.table}>
192
+ <TableHeader fields={fields} classNames={className} />
193
+ <TableBody rows={rows} classNames={className} />
194
+ </table>
195
+ )
196
+ );
197
+ };
198
+
199
+ export default MultiLevelTable;
200
+
201
+ /*
202
+ MultiLevelTable.propTypes = {
203
+ data: PropTypes.arrayOf(PropTypes.object).isRequired,
204
+ structure: PropTypes.object.isRequired,
205
+ actionLabel: PropTypes.string,
206
+ actions: PropTypes.arrayOf(
207
+ PropTypes.exact({
208
+ name: PropTypes.string.isRequired,
209
+ callback: PropTypes.func.isRequired
210
+ })
211
+ ),
212
+ className: PropTypes.exact({
213
+ table: PropTypes.string,
214
+ head: PropTypes.string,
215
+ body: PropTypes.string
216
+ })
217
+ }
218
+ */
219
+ /*
220
+ MultiLevelTable.defaultProps = {
221
+ actionLabel: 'Action',
222
+ actions: [],
223
+ className: {
224
+ table: 'w-full shadow-sm overflow-hidden rounded-lg text-center',
225
+ head: 'text-white bg-gray-700 text-center',
226
+ body: 'p-2 border-solid border border-light-blue-300',
227
+ },
228
+ };
229
+ */
@@ -0,0 +1,25 @@
1
+ import * as React from 'react';
2
+
3
+ import { Card, CardContent, Typography } from '@mui/material';
4
+ import InfoIcon from '@mui/icons-material/Info'
5
+
6
+ export interface INoResults extends React.PropsWithChildren {
7
+ title?: string;
8
+ description?: string;
9
+ }
10
+ export const NoResults: React.FC<INoResults> = (props) => {
11
+
12
+ const { title, description, children } = props;
13
+
14
+ return (
15
+ <Card sx={{ p: 0 }}>
16
+ <CardContent sx={{ display: 'flex', flexDirection: 'column', alignItems: 'left', gap: 2 }}>
17
+ <div style={{ display: 'flex', alignItems: 'center', gap: 2 }}>
18
+ <InfoIcon sx={{ fontSize: 32 }} />
19
+ {title ? <Typography variant="h5">{title}</Typography> : "No hay registros"}
20
+ </div>
21
+ {description && <Typography variant="body1" color="text.secondary">{description}</Typography>}
22
+ {children ? children : <></>}
23
+ </CardContent>
24
+ </Card> );
25
+ };
@@ -0,0 +1,85 @@
1
+ import { Button } from '@mui/material';
2
+ import React, { useEffect, useState } from 'react';
3
+ import { useRecordContext } from 'react-admin';
4
+ import { Loading } from 'react-admin';
5
+ import { initAxios } from '../../hooks/axios';
6
+ import { saveAs } from 'file-saver';
7
+ import { IDashAutoAdminCustomFieldComponent } from 'dash-auto-admin';
8
+
9
+ const PDFViewerView: React.FC<IDashAutoAdminCustomFieldComponent> = ({
10
+ method,
11
+ attribute,
12
+ }) => {
13
+ const record = useRecordContext();
14
+
15
+ const axios = initAxios();
16
+
17
+ const [PDFFile, setPDFFile] = useState<string>(null);
18
+
19
+ const filePath =
20
+ record && record[attribute.attribute] ? record[attribute.attribute] : null;
21
+ const fileName = 'nota-venta-' + record.id + '.pdf';
22
+
23
+ useEffect(() => {
24
+ record && record[attribute.attribute] && displayDocument();
25
+ }, [record]);
26
+
27
+ const displayDocument = async () => {
28
+ const { data } = await axios.get(filePath, {
29
+ responseType: 'blob',
30
+ });
31
+
32
+ const file = new Blob([data], {
33
+ type: 'application/pdf',
34
+ });
35
+
36
+ const fileURL = URL.createObjectURL(file);
37
+
38
+ setPDFFile(fileURL);
39
+ };
40
+
41
+ const downloadDocument = async () => {
42
+ const { data } = await axios.get(filePath, {
43
+ responseType: 'blob',
44
+ });
45
+
46
+ const file = new Blob([data], {
47
+ type: '',
48
+ });
49
+
50
+ saveAs(file, fileName);
51
+ };
52
+
53
+ return (
54
+ <>
55
+ {PDFFile ? (
56
+ <div>
57
+ <object
58
+ className='embed-pdf'
59
+ data={PDFFile}
60
+ type='application/pdf'
61
+ style={{ minHeight: 800, minWidth: 600 }}
62
+ >
63
+ <embed src={PDFFile} type='application/pdf' />
64
+ </object>
65
+ <hr />
66
+ <Button onClick={downloadDocument}>Descargar</Button>
67
+ </div>
68
+ ) : (
69
+ <Loading />
70
+ )}
71
+ </>
72
+ );
73
+ };
74
+
75
+ const PDFViewer = ({ method, attribute, resourceConfig }: IDashAutoAdminCustomFieldComponent) => {
76
+ switch (method) {
77
+ case 'edit':
78
+ case 'create':
79
+ return <>edit</>;
80
+ case 'view':
81
+ return <PDFViewerView attribute={attribute} method={method} resourceConfig={resourceConfig} />;
82
+ }
83
+ };
84
+
85
+ export default PDFViewer;
@@ -0,0 +1,220 @@
1
+ import React, { JSX, useMemo } from 'react';
2
+ import { Box, Typography } from '@mui/material';
3
+ import { Link } from 'react-router-dom';
4
+ import { useSelector } from 'react-redux';
5
+ import NavigateNextIcon from '@mui/icons-material/NavigateNext';
6
+ import HomeIcon from '@mui/icons-material/Home';
7
+ import { IBreadcrumbItem, IDASHAppState, IPageState } from 'dash-admin-state';
8
+ import { IDashAutoAdminResourceConfig } from 'dash-auto-admin';
9
+
10
+ // ============================================================================
11
+ // TYPES & INTERFACES
12
+ // ============================================================================
13
+
14
+ export interface BreadcrumbsProps {
15
+ /** Override the breadcrumbs from Redux state */
16
+ items?: IBreadcrumbItem[];
17
+ /** Custom separator between breadcrumb items */
18
+ separator?: React.ReactNode;
19
+ /** Maximum number of items to show (others will be collapsed) */
20
+ maxItems?: number;
21
+ /** Custom class name */
22
+ className?: string;
23
+ /** Show home icon as first item */
24
+ showHomeIcon?: boolean;
25
+ /** Home path (default: '/') */
26
+ homePath?: string;
27
+ /** Home label (default: 'Home') */
28
+ homeLabel?: string;
29
+ /** Custom styles */
30
+ sx?: Record<string, any>;
31
+ }
32
+
33
+ // ============================================================================
34
+ // BREADCRUMB ITEM COMPONENT
35
+ // ============================================================================
36
+
37
+ interface BreadcrumbItemProps {
38
+ item: IBreadcrumbItem;
39
+ isLast: boolean;
40
+ }
41
+
42
+ const BreadcrumbItem: React.FC<BreadcrumbItemProps> = ({ item, isLast }) => {
43
+ const content = (
44
+ <Box
45
+ component="span"
46
+ className={`dash-breadcrumb-item ${isLast ? 'dash-breadcrumb-item--active' : ''}`}
47
+ sx={{
48
+ display: 'inline-flex',
49
+ flexDirection: 'row',
50
+ alignItems: 'center',
51
+ gap: '2px',
52
+ flexShrink: 0,
53
+ }}
54
+ >
55
+ {item.icon && (
56
+ <Box
57
+ component="span"
58
+ className="dash-breadcrumb-icon"
59
+ sx={{
60
+ display: 'inline-flex',
61
+ alignItems: 'center',
62
+ flexShrink: 0,
63
+ '& svg': {
64
+ fontSize: '12px',
65
+ },
66
+ }}
67
+ >
68
+ {item.icon}
69
+ </Box>
70
+ )}
71
+ <Typography
72
+ component="span"
73
+ className="dash-breadcrumb-label"
74
+ sx={{
75
+ fontSize: '11px',
76
+ fontWeight: isLast ? 500 : 400,
77
+ lineHeight: 1.2,
78
+ color: isLast
79
+ ? 'var(--text-header, #ffffff)'
80
+ : 'var(--text-header-muted, rgba(255, 255, 255, 0.7))',
81
+ whiteSpace: 'nowrap',
82
+ overflow: 'hidden',
83
+ textOverflow: 'ellipsis',
84
+ maxWidth: '120px',
85
+ }}
86
+ >
87
+ {item.label}
88
+ </Typography>
89
+ </Box>
90
+ );
91
+
92
+ // If it's the last item or no path, don't make it a link
93
+ if (isLast || !item.path) {
94
+ return content;
95
+ }
96
+
97
+ // Ensure path starts with / to avoid relative navigation issues
98
+ const path = !item.path.startsWith('/') ? `/${item.path}` : item.path;
99
+
100
+ // Use React Router's Link for client-side navigation
101
+ return (
102
+ <Link
103
+ to={path}
104
+ className="dash-breadcrumb-link"
105
+ style={{
106
+ textDecoration: 'none',
107
+ display: 'inline-flex',
108
+ alignItems: 'center',
109
+ }}
110
+ >
111
+ {content}
112
+ </Link>
113
+ );
114
+ };
115
+
116
+ // ============================================================================
117
+ // MAIN BREADCRUMBS COMPONENT
118
+ // ============================================================================
119
+
120
+ export const Breadcrumbs: React.FC<BreadcrumbsProps> = ({
121
+ items: propItems,
122
+ separator,
123
+ maxItems,
124
+ className = '',
125
+ showHomeIcon = false,
126
+ homePath = '/',
127
+ homeLabel = 'Home',
128
+ sx = {},
129
+ }): JSX.Element | null => {
130
+ // Create default separator inside component to avoid hook issues
131
+ const defaultSeparator = <NavigateNextIcon sx={{ fontSize: '12px', color: 'var(--text-header-muted, rgba(255, 255, 255, 0.5))' }} />;
132
+ const actualSeparator = separator ?? defaultSeparator;
133
+ // Get breadcrumbs from Redux state if not provided via props
134
+ const pageState: IPageState = useSelector(
135
+ (state: IDASHAppState<any, any, IDashAutoAdminResourceConfig>) => state.page
136
+ );
137
+
138
+ const breadcrumbs = propItems || pageState.breadcrumbs;
139
+
140
+ // Build final items list
141
+ const displayItems = useMemo(() => {
142
+ if (!breadcrumbs || breadcrumbs.length === 0) {
143
+ return [];
144
+ }
145
+
146
+ let items = [...breadcrumbs];
147
+
148
+ // Add home item if requested
149
+ if (showHomeIcon) {
150
+ const homeItem: IBreadcrumbItem = {
151
+ label: homeLabel,
152
+ path: homePath,
153
+ icon: <HomeIcon />,
154
+ };
155
+ items = [homeItem, ...items];
156
+ }
157
+
158
+ // Apply maxItems limit if specified
159
+ if (maxItems && items.length > maxItems) {
160
+ const start = items.slice(0, 1);
161
+ const end = items.slice(-(maxItems - 2));
162
+ const ellipsis: IBreadcrumbItem = {
163
+ label: '...',
164
+ path: undefined,
165
+ };
166
+ items = [...start, ellipsis, ...end];
167
+ }
168
+
169
+ return items;
170
+ }, [breadcrumbs, showHomeIcon, homeLabel, homePath, maxItems]);
171
+
172
+ // Don't render if no items
173
+ if (displayItems.length === 0) {
174
+ return null;
175
+ }
176
+
177
+ return (
178
+ <Box
179
+ component="nav"
180
+ aria-label="breadcrumb"
181
+ className={`dash-breadcrumbs ${className}`}
182
+ sx={{
183
+ display: 'flex',
184
+ flexDirection: 'row',
185
+ alignItems: 'center',
186
+ flexWrap: 'nowrap',
187
+ gap: '2px',
188
+ padding: 0,
189
+ margin: 0,
190
+ ...sx,
191
+ }}
192
+ >
193
+ {displayItems.map((item, index) => {
194
+ const isLast = index === displayItems.length - 1;
195
+
196
+ return (
197
+ <React.Fragment key={`breadcrumb-${index}-${item.label}`}>
198
+ <BreadcrumbItem item={item} isLast={isLast} />
199
+ {!isLast && (
200
+ <Box
201
+ component="span"
202
+ className="dash-breadcrumb-separator"
203
+ sx={{
204
+ display: 'inline-flex',
205
+ alignItems: 'center',
206
+ mx: '1px',
207
+ flexShrink: 0,
208
+ }}
209
+ >
210
+ {actualSeparator}
211
+ </Box>
212
+ )}
213
+ </React.Fragment>
214
+ );
215
+ })}
216
+ </Box>
217
+ );
218
+ };
219
+
220
+ export default Breadcrumbs;