@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,522 @@
1
+ import { DashAutoFormTabs, IDashAutoAdminCustomFieldComponent } from "dash-auto-admin";
2
+ import React, { useState, useEffect, useCallback } from "react";
3
+ import { Loading, useRecordContext } from "react-admin";
4
+ import { useFormContext, useWatch, Controller } from "react-hook-form";
5
+ import MUISimpleJsonTable from "../misc/MuiSimpleJsonTable";
6
+ import { useSubscriptionPlanFormats } from "../../contexts/SubscriptionPlanFormatsProvider";
7
+ import {
8
+ Box,
9
+ Switch,
10
+ FormControlLabel,
11
+ TextField,
12
+ Typography,
13
+ Paper,
14
+ Grid,
15
+ Chip,
16
+ InputAdornment,
17
+ Collapse,
18
+ Divider
19
+ } from "@mui/material";
20
+ import { priceFormatter } from 'dash-utils';
21
+
22
+ /**
23
+ * PlanAddonsSettings Component
24
+ *
25
+ * A dynamic form component for managing subscription plan add-ons with pricing.
26
+ * Add-ons are specific integrations (marketplaces, POS systems) that can be
27
+ * individually enabled/disabled per subscription plan, with configurable prices per currency.
28
+ *
29
+ * Usage:
30
+ * - In edit mode: Renders form fields for each add-on defined in subscription_plans.addon_formats
31
+ * with toggle switch and price inputs for each currency
32
+ * - In view mode: Displays the current add-ons with their prices as a table
33
+ * - In create mode: Renders form fields with default values
34
+ *
35
+ * Add-on naming convention:
36
+ * - marketplace_{name}: Marketplace integrations (e.g., marketplace_ubereats)
37
+ * - pos_{name}: Point of Sale integrations (e.g., pos_transbank)
38
+ */
39
+
40
+ interface AddonFormat {
41
+ id: string;
42
+ group: string;
43
+ tab: string;
44
+ attribute: string;
45
+ label: string;
46
+ visible: boolean;
47
+ required: boolean;
48
+ type: 'boolean' | 'integer' | 'string' | 'select';
49
+ editable: boolean;
50
+ rules: string;
51
+ default_value: any;
52
+ description?: string;
53
+ service_class?: string | null;
54
+ icon?: string;
55
+ prices?: Record<string, number>;
56
+ }
57
+
58
+ interface SubscriptionPlan {
59
+ id: number;
60
+ name: string;
61
+ slug: string;
62
+ addons?: Record<string, boolean>;
63
+ addon_prices?: Record<string, Record<string, number>>;
64
+ flow_addon_items?: Record<string, number>;
65
+ [key: string]: any;
66
+ }
67
+
68
+ // Default currencies - should match backend config
69
+ const AVAILABLE_CURRENCIES = ['CLP', 'USD'];
70
+ const DEFAULT_CURRENCY = 'CLP';
71
+
72
+ // Currency display configuration
73
+ const CURRENCY_CONFIG: Record<string, { symbol: string; decimals: number; name: string }> = {
74
+ CLP: { symbol: '$', decimals: 0, name: 'Chilean Peso' },
75
+ USD: { symbol: '$', decimals: 2, name: 'US Dollar' },
76
+ };
77
+
78
+ /**
79
+ * Single addon row component with toggle and price inputs
80
+ */
81
+ interface AddonRowProps {
82
+ addonId: string;
83
+ entry: AddonFormat;
84
+ plan?: SubscriptionPlan;
85
+ mode: 'edit' | 'create' | 'view';
86
+ }
87
+
88
+ const AddonRow: React.FC<AddonRowProps> = ({ addonId, entry, plan, mode }) => {
89
+ const { control, setValue, watch } = useFormContext();
90
+
91
+ // Watch the enabled state for this addon
92
+ const isEnabled = watch(`addons.${addonId}`) ?? entry.default_value ?? false;
93
+
94
+ // Watch prices for this addon
95
+ const addonPrices = watch(`addon_prices.${addonId}`) ?? plan?.addon_prices?.[addonId] ?? {};
96
+
97
+ const handleToggle = useCallback((checked: boolean) => {
98
+ setValue(`addons.${addonId}`, checked, { shouldDirty: true });
99
+
100
+ // Initialize prices if enabling for the first time
101
+ if (checked && Object.keys(addonPrices).length === 0) {
102
+ const defaultPrices: Record<string, number> = {};
103
+ AVAILABLE_CURRENCIES.forEach(currency => {
104
+ defaultPrices[currency] = entry.prices?.[currency] ?? 0;
105
+ });
106
+ setValue(`addon_prices.${addonId}`, defaultPrices, { shouldDirty: true });
107
+ }
108
+ }, [addonId, addonPrices, entry.prices, setValue]);
109
+
110
+ const handlePriceChange = useCallback((currency: string, value: string) => {
111
+ const numericValue = parseInt(value.replace(/[^0-9]/g, ''), 10) || 0;
112
+ setValue(`addon_prices.${addonId}.${currency}`, numericValue, { shouldDirty: true });
113
+ }, [addonId, setValue]);
114
+
115
+ const formatPrice = (price: number, currency: string): string => {
116
+ return priceFormatter(price, currency);
117
+ };
118
+
119
+ const isReadOnly = mode === 'view';
120
+
121
+ return (
122
+ <Paper
123
+ elevation={1}
124
+ sx={{
125
+ p: 2,
126
+ mb: 2,
127
+ borderLeft: isEnabled ? '4px solid #4caf50' : '4px solid #e0e0e0',
128
+ transition: 'border-color 0.3s'
129
+ }}
130
+ >
131
+ <Grid container spacing={2} alignItems="flex-start">
132
+ {/* Toggle and Label */}
133
+ <Grid item xs={12} md={4}>
134
+ <Controller
135
+ name={`addons.${addonId}`}
136
+ control={control}
137
+ defaultValue={entry.default_value ?? false}
138
+ render={({ field }) => (
139
+ <FormControlLabel
140
+ control={
141
+ <Switch
142
+ checked={field.value ?? false}
143
+ onChange={(e) => {
144
+ field.onChange(e.target.checked);
145
+ handleToggle(e.target.checked);
146
+ }}
147
+ disabled={isReadOnly}
148
+ color="primary"
149
+ />
150
+ }
151
+ label={
152
+ <Box>
153
+ <Typography variant="subtitle1" fontWeight="medium">
154
+ {entry.icon && <span style={{ marginRight: 8 }}>{entry.icon}</span>}
155
+ {entry.label}
156
+ </Typography>
157
+ {entry.description && (
158
+ <Typography variant="caption" color="text.secondary">
159
+ {entry.description}
160
+ </Typography>
161
+ )}
162
+ </Box>
163
+ }
164
+ />
165
+ )}
166
+ />
167
+ {entry.service_class && (
168
+ <Chip
169
+ label="Has Service Class"
170
+ size="small"
171
+ variant="outlined"
172
+ sx={{ mt: 1 }}
173
+ />
174
+ )}
175
+ </Grid>
176
+
177
+ {/* Price Inputs - Show when enabled */}
178
+ <Grid item xs={12} md={8}>
179
+ <Collapse in={isEnabled}>
180
+ <Box sx={{ display: 'flex', gap: 2, flexWrap: 'wrap' }}>
181
+ {AVAILABLE_CURRENCIES.map((currency) => {
182
+ const config = CURRENCY_CONFIG[currency];
183
+ const currentPrice = addonPrices[currency] ?? entry.prices?.[currency] ?? 0;
184
+
185
+ return (
186
+ <Controller
187
+ key={currency}
188
+ name={`addon_prices.${addonId}.${currency}`}
189
+ control={control}
190
+ defaultValue={currentPrice}
191
+ render={({ field }) => (
192
+ <TextField
193
+ {...field}
194
+ label={`Price (${currency})`}
195
+ type="text"
196
+ size="small"
197
+ disabled={isReadOnly}
198
+ InputProps={{
199
+ startAdornment: (
200
+ <InputAdornment position="start">
201
+ {config.symbol}
202
+ </InputAdornment>
203
+ ),
204
+ }}
205
+ sx={{ width: 150 }}
206
+ value={formatPrice(field.value ?? 0, currency)}
207
+ onChange={(e) => handlePriceChange(currency, e.target.value)}
208
+ helperText={config.name}
209
+ />
210
+ )}
211
+ />
212
+ );
213
+ })}
214
+ </Box>
215
+ {plan?.flow_addon_items?.[addonId] && (
216
+ <Typography variant="caption" color="text.secondary" sx={{ mt: 1, display: 'block' }}>
217
+ Flow Item ID: {plan.flow_addon_items[addonId]}
218
+ </Typography>
219
+ )}
220
+ </Collapse>
221
+ </Grid>
222
+ </Grid>
223
+ </Paper>
224
+ );
225
+ };
226
+
227
+ const PlanAddonsSettingsEdit: React.FC<IDashAutoAdminCustomFieldComponent> = ({ method, attribute }) => {
228
+ const plan: SubscriptionPlan = useRecordContext();
229
+ const formContext = useFormContext();
230
+ const { setValue, watch } = formContext;
231
+
232
+ // Watch for changes in addons to ensure it remains an object
233
+ const currentAddons = watch('addons');
234
+ const currentAddonPrices = watch('addon_prices');
235
+
236
+ useEffect(() => {
237
+ // Fix: Ensure addons is always an object, not an array
238
+ if (Array.isArray(currentAddons)) {
239
+ console.warn('PlanAddonsSettings: Detected addons as array, converting to object');
240
+ setValue('addons', { ...currentAddons });
241
+ }
242
+ }, [currentAddons, setValue]);
243
+
244
+ useEffect(() => {
245
+ // Fix: Ensure addon_prices is always an object, not an array
246
+ if (Array.isArray(currentAddonPrices)) {
247
+ console.warn('PlanAddonsSettings: Detected addon_prices as array, converting to object');
248
+ setValue('addon_prices', {});
249
+ } else if (!currentAddonPrices && plan?.addon_prices && !Array.isArray(plan.addon_prices)) {
250
+ // Initialize addon_prices from plan if not set
251
+ setValue('addon_prices', plan.addon_prices);
252
+ } else if (!currentAddonPrices || (typeof currentAddonPrices === 'object' && Object.keys(currentAddonPrices).length === 0)) {
253
+ // Initialize as empty object if not set
254
+ setValue('addon_prices', {});
255
+ }
256
+ }, [currentAddonPrices, plan, setValue]);
257
+
258
+ useWatch({
259
+ control: formContext.control
260
+ });
261
+
262
+ const { addonFormats: formatsData, loading } = useSubscriptionPlanFormats();
263
+
264
+ if (loading) return <Loading />;
265
+
266
+ const formats = (formatsData?.formats as AddonFormat[]) || [];
267
+ const visibleFormats = formats.filter((entry) => entry.visible !== false);
268
+
269
+ // Group addons by tab
270
+ const groupedByTab = visibleFormats.reduce((acc, entry) => {
271
+ const tab = entry.tab || 'General';
272
+ if (!acc[tab]) acc[tab] = [];
273
+ acc[tab].push(entry);
274
+ return acc;
275
+ }, {} as Record<string, AddonFormat[]>);
276
+
277
+ return (
278
+ <Box sx={{ p: 2 }}>
279
+ <Typography variant="h6" gutterBottom>
280
+ Plan Add-ons Configuration
281
+ </Typography>
282
+ <Typography variant="body2" color="text.secondary" sx={{ mb: 3 }}>
283
+ Enable add-ons and set prices per currency. Prices are in the smallest currency unit (e.g., cents for USD, pesos for CLP).
284
+ </Typography>
285
+
286
+ {Object.entries(groupedByTab).map(([tabName, entries]) => (
287
+ <Box key={tabName} sx={{ mb: 4 }}>
288
+ <Typography variant="subtitle1" fontWeight="bold" sx={{ mb: 2 }}>
289
+ {tabName}
290
+ </Typography>
291
+ <Divider sx={{ mb: 2 }} />
292
+ {entries.map((entry) => {
293
+ const addonId = entry.attribute
294
+ ? entry.attribute.replace('addons.', '')
295
+ : entry.id;
296
+ return (
297
+ <AddonRow
298
+ key={addonId}
299
+ addonId={addonId}
300
+ entry={entry}
301
+ plan={plan}
302
+ mode="edit"
303
+ />
304
+ );
305
+ })}
306
+ </Box>
307
+ ))}
308
+ </Box>
309
+ );
310
+ };
311
+
312
+ const PlanAddonsSettingsCreate: React.FC<IDashAutoAdminCustomFieldComponent> = ({ method, attribute }) => {
313
+ const formContext = useFormContext();
314
+ const { setValue, watch } = formContext;
315
+
316
+ // Watch for changes in addons to ensure it remains an object
317
+ const currentAddons = watch('addons');
318
+
319
+ useEffect(() => {
320
+ // Fix: Ensure addons is always an object, not an array
321
+ if (Array.isArray(currentAddons)) {
322
+ console.warn('PlanAddonsSettings: Detected addons as array, converting to object');
323
+ setValue('addons', { ...currentAddons });
324
+ }
325
+ }, [currentAddons, setValue]);
326
+
327
+ // Initialize addon_prices structure for create mode
328
+ useEffect(() => {
329
+ const addonPrices = watch('addon_prices');
330
+ // Fix: Ensure addon_prices is always an object, not an array
331
+ if (Array.isArray(addonPrices)) {
332
+ console.warn('PlanAddonsSettings: Detected addon_prices as array, converting to object');
333
+ setValue('addon_prices', {});
334
+ } else if (!addonPrices) {
335
+ setValue('addon_prices', {});
336
+ }
337
+ }, [setValue, watch]);
338
+
339
+ useWatch({
340
+ control: formContext.control
341
+ });
342
+
343
+ const { addonFormats: formatsData, loading } = useSubscriptionPlanFormats();
344
+
345
+ if (loading) return <Loading />;
346
+
347
+ const formats = (formatsData?.formats as AddonFormat[]) || [];
348
+ const visibleFormats = formats.filter((entry) => entry.visible !== false);
349
+
350
+ // Group addons by tab
351
+ const groupedByTab = visibleFormats.reduce((acc, entry) => {
352
+ const tab = entry.tab || 'General';
353
+ if (!acc[tab]) acc[tab] = [];
354
+ acc[tab].push(entry);
355
+ return acc;
356
+ }, {} as Record<string, AddonFormat[]>);
357
+
358
+ return (
359
+ <Box sx={{ p: 2 }}>
360
+ <Typography variant="h6" gutterBottom>
361
+ Plan Add-ons Configuration
362
+ </Typography>
363
+ <Typography variant="body2" color="text.secondary" sx={{ mb: 3 }}>
364
+ Enable add-ons and set prices per currency. Prices are in the smallest currency unit.
365
+ </Typography>
366
+
367
+ {Object.entries(groupedByTab).map(([tabName, entries]) => (
368
+ <Box key={tabName} sx={{ mb: 4 }}>
369
+ <Typography variant="subtitle1" fontWeight="bold" sx={{ mb: 2 }}>
370
+ {tabName}
371
+ </Typography>
372
+ <Divider sx={{ mb: 2 }} />
373
+ {entries.map((entry) => {
374
+ const addonId = entry.attribute
375
+ ? entry.attribute.replace('addons.', '')
376
+ : entry.id;
377
+ return (
378
+ <AddonRow
379
+ key={addonId}
380
+ addonId={addonId}
381
+ entry={entry}
382
+ mode="create"
383
+ />
384
+ );
385
+ })}
386
+ </Box>
387
+ ))}
388
+ </Box>
389
+ );
390
+ };
391
+
392
+ const PlanAddonsSettingsView: React.FC<IDashAutoAdminCustomFieldComponent> = ({ method, attribute }) => {
393
+ const plan: SubscriptionPlan = useRecordContext();
394
+
395
+ const { addonFormats: formatsData, loading } = useSubscriptionPlanFormats();
396
+
397
+ const formatPrice = (price: number, currency: string): string => {
398
+ return priceFormatter(price, currency);
399
+ };
400
+
401
+ if (loading) return <Loading />;
402
+
403
+ const formats = (formatsData?.formats as AddonFormat[]) || [];
404
+ const visibleFormats = formats.filter((entry) => entry.visible !== false);
405
+
406
+ // Group addons by tab
407
+ const groupedByTab = visibleFormats.reduce((acc, entry) => {
408
+ const tab = entry.tab || 'General';
409
+ if (!acc[tab]) acc[tab] = [];
410
+ acc[tab].push(entry);
411
+ return acc;
412
+ }, {} as Record<string, AddonFormat[]>);
413
+
414
+ return (
415
+ <Box sx={{ p: 2 }}>
416
+ <Typography variant="h6" gutterBottom>
417
+ Plan Add-ons
418
+ </Typography>
419
+
420
+ {Object.entries(groupedByTab).map(([tabName, entries]) => (
421
+ <Box key={tabName} sx={{ mb: 3 }}>
422
+ <Typography variant="subtitle1" fontWeight="bold" sx={{ mb: 2 }}>
423
+ {tabName}
424
+ </Typography>
425
+ <Divider sx={{ mb: 2 }} />
426
+
427
+ {entries.map((entry) => {
428
+ const addonId = entry.attribute
429
+ ? entry.attribute.replace('addons.', '')
430
+ : entry.id;
431
+ const isEnabled = plan?.addons?.[addonId] ?? false;
432
+ const addonPrices = plan?.addon_prices?.[addonId] ?? {};
433
+ const flowItemId = plan?.flow_addon_items?.[addonId];
434
+
435
+ return (
436
+ <Paper
437
+ key={addonId}
438
+ elevation={0}
439
+ sx={{
440
+ p: 2,
441
+ mb: 1,
442
+ backgroundColor: isEnabled ? 'action.selected' : 'background.default',
443
+ borderLeft: isEnabled ? '4px solid #4caf50' : '4px solid #e0e0e0',
444
+ }}
445
+ >
446
+ <Box sx={{ display: 'flex', justifyContent: 'space-between', alignItems: 'center' }}>
447
+ <Box>
448
+ <Typography variant="subtitle2">
449
+ {entry.icon && <span style={{ marginRight: 8 }}>{entry.icon}</span>}
450
+ {entry.label}
451
+ </Typography>
452
+ <Chip
453
+ label={isEnabled ? 'Enabled' : 'Disabled'}
454
+ size="small"
455
+ color={isEnabled ? 'success' : 'default'}
456
+ sx={{ mt: 0.5 }}
457
+ />
458
+ </Box>
459
+
460
+ {isEnabled && (
461
+ <Box sx={{ textAlign: 'right' }}>
462
+ {AVAILABLE_CURRENCIES.map((currency) => {
463
+ const price = addonPrices[currency] ?? 0;
464
+ return (
465
+ <Typography key={currency} variant="body2">
466
+ {currency}: {formatPrice(price, currency)}
467
+ </Typography>
468
+ );
469
+ })}
470
+ {flowItemId && (
471
+ <Typography variant="caption" color="text.secondary">
472
+ Flow ID: {flowItemId}
473
+ </Typography>
474
+ )}
475
+ </Box>
476
+ )}
477
+ </Box>
478
+ </Paper>
479
+ );
480
+ })}
481
+ </Box>
482
+ ))}
483
+ </Box>
484
+ );
485
+ };
486
+
487
+ /**
488
+ * Main PlanAddonsSettings component
489
+ * Renders the appropriate sub-component based on the form mode (edit, view, create)
490
+ */
491
+ const PlanAddonsSettings: React.FC<IDashAutoAdminCustomFieldComponent> = ({
492
+ method,
493
+ attribute,
494
+ resourceConfig
495
+ }) => {
496
+ switch (method) {
497
+ case "edit":
498
+ return <PlanAddonsSettingsEdit
499
+ attribute={attribute}
500
+ method={method}
501
+ resourceConfig={resourceConfig}
502
+ />;
503
+ case "view":
504
+ return <PlanAddonsSettingsView
505
+ attribute={attribute}
506
+ method={method}
507
+ resourceConfig={resourceConfig}
508
+ />;
509
+ case "create":
510
+ return <PlanAddonsSettingsCreate
511
+ attribute={attribute}
512
+ method={method}
513
+ resourceConfig={resourceConfig}
514
+ />;
515
+ case "list":
516
+ return null;
517
+ default:
518
+ return null;
519
+ }
520
+ };
521
+
522
+ export default PlanAddonsSettings;