@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,48 @@
1
+ import { IDashAutoAdminAttribute } from 'dash-auto-admin';
2
+ import PermissionsSelector from '../components/permission/PermissionsSelector';
3
+
4
+ const roleSchema: IDashAutoAdminAttribute[] = [
5
+ {
6
+ label: 'Nombre',
7
+ attribute: 'name',
8
+ type: String,
9
+ },
10
+ {
11
+ label: 'Nivel',
12
+ attribute: 'level',
13
+ type: Number,
14
+ inList: false,
15
+ // @TODO Agregar validador que no se pueda seleccionar un nivel superior
16
+ },
17
+ {
18
+ label: 'Redirección',
19
+ attribute: 'redirect',
20
+ type: String,
21
+ inList: false,
22
+ fieldProps: {
23
+ placeholder: '/tab/kitchentab',
24
+ },
25
+ // Ensure redirect starts with /
26
+ validate: (value: string) => {
27
+ if (value && !value.startsWith('/')) {
28
+ throw Error('La ruta debe comenzar con /');
29
+ }
30
+ },
31
+ },
32
+ {
33
+ label: 'Grupo (web)',
34
+ attribute: 'guard_name',
35
+ type: String,
36
+ inList: false,
37
+ },
38
+ {
39
+ label: 'Permisos',
40
+ attribute: 'permission_ids',
41
+ type: String,
42
+ custom: true,
43
+ component: PermissionsSelector,
44
+ inList: false,
45
+ },
46
+ ];
47
+
48
+ export default roleSchema;
@@ -0,0 +1,48 @@
1
+ import { IDashAutoAdminAttribute } from 'dash-auto-admin';
2
+ import PermissionsSelectorList from '../components/permission/PermissionsSelectorList';
3
+
4
+ const roleSchemaDataGrid: IDashAutoAdminAttribute[] = [
5
+ {
6
+ label: 'Nombre',
7
+ attribute: 'name',
8
+ type: String,
9
+ },
10
+ {
11
+ label: 'Nivel',
12
+ attribute: 'level',
13
+ type: Number,
14
+ inList: false,
15
+ // @TODO Agregar validador que no se pueda seleccionar un nivel superior
16
+ },
17
+ {
18
+ label: 'Redirección',
19
+ attribute: 'redirect',
20
+ type: String,
21
+ inList: false,
22
+ fieldProps: {
23
+ placeholder: '/tab/kitchentab',
24
+ },
25
+ // Ensure redirect starts with /
26
+ validate: (value: string) => {
27
+ if (value && !value.startsWith('/')) {
28
+ throw Error('La ruta debe comenzar con /');
29
+ }
30
+ },
31
+ },
32
+ {
33
+ label: 'Grupo (web)',
34
+ attribute: 'guard_name',
35
+ type: String,
36
+ inList: false,
37
+ },
38
+ {
39
+ label: 'Permisos',
40
+ attribute: 'permission_ids',
41
+ type: String,
42
+ custom: true,
43
+ component: PermissionsSelectorList,
44
+ inList: false,
45
+ },
46
+ ];
47
+
48
+ export default roleSchemaDataGrid;
@@ -0,0 +1,153 @@
1
+ import React, { useState } from 'react';
2
+ import {
3
+ Button,
4
+ ButtonGroup,
5
+ Dialog,
6
+ DialogTitle,
7
+ DialogContent,
8
+ DialogActions,
9
+ Typography,
10
+ Alert,
11
+ Box
12
+ } from '@mui/material';
13
+ import {
14
+ Cancel as CancelIcon,
15
+ Refresh as RefreshIcon,
16
+ Upgrade as UpgradeIcon
17
+ } from '@mui/icons-material';
18
+ import { useRecordContext, useDataProvider, useNotify, useRefresh } from 'react-admin';
19
+ import { IDashAutoAdminCustomFieldComponent } from "dash-auto-admin";
20
+
21
+ const ActionComponent: React.FC<IDashAutoAdminCustomFieldComponent> = ({ method, attribute, resourceConfig }) => {
22
+ const record = useRecordContext();
23
+ const dataProvider = useDataProvider();
24
+ const notify = useNotify();
25
+ const refresh = useRefresh();
26
+ const [loading, setLoading] = useState(false);
27
+ const [cancelDialogOpen, setCancelDialogOpen] = useState(false);
28
+
29
+ if (!record) return null;
30
+
31
+ const handleCancelSubscription = async () => {
32
+ try {
33
+ setLoading(true);
34
+ await dataProvider.create('system/subscription/cancel/subscription', {
35
+ data: { subscription_id: record.id }
36
+ });
37
+ notify('Suscripción cancelada exitosamente', { type: 'success' });
38
+ refresh();
39
+ setCancelDialogOpen(false);
40
+ } catch (error) {
41
+ notify('Error al cancelar la suscripción', { type: 'error' });
42
+ } finally {
43
+ setLoading(false);
44
+ }
45
+ };
46
+
47
+ const handleReactivateSubscription = async () => {
48
+ try {
49
+ setLoading(true);
50
+ await dataProvider.update('system/subscription',{
51
+ id: record.id,
52
+ data: { status: 'active' },
53
+ previousData: {}
54
+ });
55
+ notify('Suscripción reactivada exitosamente', { type: 'success' });
56
+ refresh();
57
+ } catch (error) {
58
+ notify('Error al reactivar la suscripción', { type: 'error' });
59
+ } finally {
60
+ setLoading(false);
61
+ }
62
+ };
63
+
64
+ const canCancel = ['active', 'trial'].includes(record.status);
65
+ const canReactivate = record.status === 'cancelled';
66
+
67
+ return (
68
+ <Box>
69
+ <ButtonGroup variant="outlined" size="small">
70
+ {canCancel && (
71
+ <Button
72
+ startIcon={<CancelIcon />}
73
+ color="error"
74
+ onClick={() => setCancelDialogOpen(true)}
75
+ disabled={loading}
76
+ >
77
+ Cancelar
78
+ </Button>
79
+ )}
80
+
81
+ {canReactivate && (
82
+ <Button
83
+ startIcon={<RefreshIcon />}
84
+ color="success"
85
+ onClick={handleReactivateSubscription}
86
+ disabled={loading}
87
+ >
88
+ Reactivar
89
+ </Button>
90
+ )}
91
+
92
+ <Button
93
+ startIcon={<UpgradeIcon />}
94
+ color="primary"
95
+ disabled={loading || record.status === 'expired'}
96
+ >
97
+ Cambiar Plan
98
+ </Button>
99
+ </ButtonGroup>
100
+
101
+ <Dialog
102
+ open={cancelDialogOpen}
103
+ onClose={() => setCancelDialogOpen(false)}
104
+ maxWidth="sm"
105
+ fullWidth
106
+ >
107
+ <DialogTitle>Confirmar Cancelación</DialogTitle>
108
+ <DialogContent>
109
+ <Alert severity="warning" sx={{ mb: 2 }}>
110
+ Esta acción cancelará la suscripción inmediatamente.
111
+ </Alert>
112
+ <Typography>
113
+ ¿Estás seguro de que deseas cancelar la suscripción de{' '}
114
+ <strong>{record.subscription_plan?.name}</strong>?
115
+ </Typography>
116
+ <Typography variant="body2" color="textSecondary" sx={{ mt: 1 }}>
117
+ El usuario perderá acceso a las funcionalidades premium al final del período actual.
118
+ </Typography>
119
+ </DialogContent>
120
+ <DialogActions>
121
+ <Button
122
+ onClick={() => setCancelDialogOpen(false)}
123
+ disabled={loading}
124
+ >
125
+ Cancelar
126
+ </Button>
127
+ <Button
128
+ onClick={handleCancelSubscription}
129
+ color="error"
130
+ variant="contained"
131
+ disabled={loading}
132
+ >
133
+ Confirmar Cancelación
134
+ </Button>
135
+ </DialogActions>
136
+ </Dialog>
137
+ </Box>
138
+ );
139
+ };
140
+
141
+ const SubscriptionActions = ({ method, attribute, resourceConfig }: IDashAutoAdminCustomFieldComponent) => {
142
+ switch (method) {
143
+ case "edit":
144
+ case "create":
145
+ case "view":
146
+ case "list":
147
+ return <ActionComponent attribute={attribute} method={method} resourceConfig={resourceConfig} />
148
+ default:
149
+ return <></>;
150
+ }
151
+ }
152
+
153
+ export default SubscriptionActions;
@@ -0,0 +1,120 @@
1
+ import React, { useState, useEffect } from 'react';
2
+ import {
3
+ Table,
4
+ TableBody,
5
+ TableCell,
6
+ TableContainer,
7
+ TableHead,
8
+ TableRow,
9
+ Paper,
10
+ Typography,
11
+ CircularProgress,
12
+ Box
13
+ } from '@mui/material';
14
+ import { useRecordContext, useDataProvider } from 'react-admin';
15
+ import { IDashAutoAdminCustomFieldComponent } from "dash-auto-admin";
16
+ import { priceFormatter } from 'dash-utils';
17
+
18
+ interface Payment {
19
+ id: number;
20
+ amount: number;
21
+ status: string;
22
+ transaction_id: string;
23
+ created_at: string;
24
+ }
25
+
26
+ const PaymentHistoryView: React.FC<IDashAutoAdminCustomFieldComponent> = () => {
27
+ const record = useRecordContext();
28
+ const dataProvider = useDataProvider();
29
+ const [payments, setPayments] = useState<Payment[]>([]);
30
+ const [loading, setLoading] = useState(true);
31
+
32
+ useEffect(() => {
33
+ if (record?.id) {
34
+ fetchPayments();
35
+ }
36
+ }, [record?.id]);
37
+
38
+ const fetchPayments = async () => {
39
+ try {
40
+ setLoading(true);
41
+ const { data } = await dataProvider.getList('payments', {
42
+ filter: { subscription_id: record.id },
43
+ sort: { field: 'created_at', order: 'DESC' },
44
+ pagination: { page: 1, perPage: 10 },
45
+ });
46
+ setPayments(data);
47
+ } catch (error) {
48
+ console.error('Error fetching payments:', error);
49
+ } finally {
50
+ setLoading(false);
51
+ }
52
+ };
53
+
54
+ if (loading) {
55
+ return (
56
+ <Box display="flex" justifyContent="center" p={2}>
57
+ <CircularProgress />
58
+ </Box>
59
+ );
60
+ }
61
+
62
+ if (payments.length === 0) {
63
+ return (
64
+ <Typography variant="body2" color="textSecondary">
65
+ No hay historial de pagos disponible
66
+ </Typography>
67
+ );
68
+ }
69
+
70
+ return (
71
+ <TableContainer component={Paper} variant="outlined">
72
+ <Table size="small">
73
+ <TableHead>
74
+ <TableRow>
75
+ <TableCell>Fecha</TableCell>
76
+ <TableCell>Monto</TableCell>
77
+ <TableCell>Estado</TableCell>
78
+ <TableCell>ID Transacción</TableCell>
79
+ </TableRow>
80
+ </TableHead>
81
+ <TableBody>
82
+ {payments.map((payment) => (
83
+ <TableRow key={payment.id}>
84
+ <TableCell>
85
+ {new Date(payment.created_at).toLocaleDateString()}
86
+ </TableCell>
87
+ <TableCell>
88
+ {priceFormatter(payment.amount, 'CLP')}
89
+ </TableCell>
90
+ <TableCell>
91
+ <Typography
92
+ variant="body2"
93
+ color={payment.status === 'completed' ? 'success.main' : 'error.main'}
94
+ >
95
+ {payment.status === 'completed' ? 'Completado' : 'Fallido'}
96
+ </Typography>
97
+ </TableCell>
98
+ <TableCell>
99
+ <Typography variant="body2" fontFamily="monospace">
100
+ {payment.transaction_id}
101
+ </Typography>
102
+ </TableCell>
103
+ </TableRow>
104
+ ))}
105
+ </TableBody>
106
+ </Table>
107
+ </TableContainer>
108
+ );
109
+ };
110
+
111
+ const SubscriptionPaymentHistory = ({ method, attribute, resourceConfig }: IDashAutoAdminCustomFieldComponent) => {
112
+ switch (method) {
113
+ case "view":
114
+ return <PaymentHistoryView attribute={attribute} method={method} resourceConfig={resourceConfig} />;
115
+ default:
116
+ return <></>;
117
+ }
118
+ };
119
+
120
+ export default SubscriptionPaymentHistory;
@@ -0,0 +1,155 @@
1
+ import React, { useState } from 'react';
2
+ import {
3
+ Box,
4
+ TextField,
5
+ Button,
6
+ Typography,
7
+ IconButton,
8
+ Paper,
9
+ List,
10
+ ListItem,
11
+ ListItemText,
12
+ ListItemSecondaryAction
13
+ } from '@mui/material';
14
+ import { Add as AddIcon, Delete as DeleteIcon } from '@mui/icons-material';
15
+ import { useRecordContext, useInput } from 'react-admin';
16
+ import { IDashAutoAdminCustomFieldComponent } from "dash-auto-admin";
17
+
18
+ const EditComponent: React.FC<IDashAutoAdminCustomFieldComponent> = ({ method, attribute, resourceConfig }) => {
19
+ const record = useRecordContext();
20
+ const { field } = useInput({ source: 'features' });
21
+ const [newFeature, setNewFeature] = useState('');
22
+ const [features, setFeatures] = useState<string[]>(record?.features || []);
23
+
24
+ const handleAddFeature = () => {
25
+ if (newFeature.trim() && !features.includes(newFeature.trim())) {
26
+ const updatedFeatures = [...features, newFeature.trim()];
27
+ setFeatures(updatedFeatures);
28
+ field.onChange(updatedFeatures);
29
+ setNewFeature('');
30
+ }
31
+ };
32
+
33
+ const handleRemoveFeature = (featureToRemove: string) => {
34
+ const updatedFeatures = features.filter(feature => feature !== featureToRemove);
35
+ setFeatures(updatedFeatures);
36
+ field.onChange(updatedFeatures);
37
+ };
38
+
39
+ const handleKeyPress = (event: React.KeyboardEvent) => {
40
+ if (event.key === 'Enter') {
41
+ event.preventDefault();
42
+ handleAddFeature();
43
+ }
44
+ };
45
+
46
+ return (
47
+ <Box>
48
+ <Typography variant="h6" gutterBottom>
49
+ Características del Plan
50
+ </Typography>
51
+
52
+ <Box display="flex" gap={1} mb={2}>
53
+ <TextField
54
+ fullWidth
55
+ size="small"
56
+ label="Nueva característica"
57
+ value={newFeature}
58
+ onChange={(e) => setNewFeature(e.target.value)}
59
+ onKeyPress={handleKeyPress}
60
+ placeholder="Ej: Acceso ilimitado, Soporte 24/7"
61
+ />
62
+ <Button
63
+ variant="contained"
64
+ startIcon={<AddIcon />}
65
+ onClick={handleAddFeature}
66
+ disabled={!newFeature.trim()}
67
+ >
68
+ Agregar
69
+ </Button>
70
+ </Box>
71
+
72
+ {features.length > 0 ? (
73
+ <Paper variant="outlined">
74
+ <List dense>
75
+ {features.map((feature, index) => (
76
+ <ListItem key={index}>
77
+ <ListItemText primary={feature} />
78
+ <ListItemSecondaryAction>
79
+ <IconButton
80
+ edge="end"
81
+ size="small"
82
+ onClick={() => handleRemoveFeature(feature)}
83
+ color="error"
84
+ >
85
+ <DeleteIcon />
86
+ </IconButton>
87
+ </ListItemSecondaryAction>
88
+ </ListItem>
89
+ ))}
90
+ </List>
91
+ </Paper>
92
+ ) : (
93
+ <Typography variant="body2" color="textSecondary" style={{ fontStyle: 'italic' }}>
94
+ No hay características definidas para este plan
95
+ </Typography>
96
+ )}
97
+
98
+ <Box mt={2}>
99
+ <Typography variant="body2" color="textSecondary">
100
+ Las características se mostrarán a los usuarios al seleccionar este plan de suscripción.
101
+ </Typography>
102
+ </Box>
103
+ </Box>
104
+ );
105
+ };
106
+
107
+ const ViewComponent: React.FC<IDashAutoAdminCustomFieldComponent> = ({ method, attribute, resourceConfig }) => {
108
+ const record = useRecordContext();
109
+ const features = record?.features || [];
110
+
111
+ return (
112
+ <Box>
113
+ <Typography variant="h6" gutterBottom>
114
+ Características del Plan
115
+ </Typography>
116
+
117
+ {features.length > 0 ? (
118
+ <Paper variant="outlined">
119
+ <List dense>
120
+ {features.map((feature: string, index: number) => (
121
+ <ListItem key={index}>
122
+ <ListItemText primary={feature} />
123
+ </ListItem>
124
+ ))}
125
+ </List>
126
+ </Paper>
127
+ ) : (
128
+ <Typography variant="body2" color="textSecondary" style={{ fontStyle: 'italic' }}>
129
+ No hay características definidas para este plan
130
+ </Typography>
131
+ )}
132
+ </Box>
133
+ );
134
+ };
135
+
136
+ const ListComponent: React.FC<IDashAutoAdminCustomFieldComponent> = ({ method, attribute, resourceConfig }) => {
137
+ const record = useRecordContext();
138
+ return <>{record?.features?.length || 0} características</>;
139
+ };
140
+
141
+ const SubscriptionPlanFeatures = ({ method, attribute, resourceConfig }: IDashAutoAdminCustomFieldComponent) => {
142
+ switch (method) {
143
+ case "edit":
144
+ case "create":
145
+ return <EditComponent attribute={attribute} method={method} resourceConfig={resourceConfig} />;
146
+ case "view":
147
+ return <ViewComponent attribute={attribute} method={method} resourceConfig={resourceConfig} />;
148
+ case "list":
149
+ return <ListComponent attribute={attribute} method={method} resourceConfig={resourceConfig} />;
150
+ default:
151
+ return <></>;
152
+ }
153
+ };
154
+
155
+ export default SubscriptionPlanFeatures;
@@ -0,0 +1,128 @@
1
+ import React from 'react';
2
+ import {
3
+ Card,
4
+ CardContent,
5
+ Typography,
6
+ Box,
7
+ Chip,
8
+ List,
9
+ ListItem,
10
+ ListItemIcon,
11
+ ListItemText,
12
+ Button,
13
+ Divider
14
+ } from '@mui/material';
15
+ import { Check as CheckIcon, Star as StarIcon } from '@mui/icons-material';
16
+ import { useRecordContext } from 'react-admin';
17
+ import { IDashAutoAdminCustomFieldComponent } from "dash-auto-admin";
18
+ import { priceFormatter } from 'dash-utils';
19
+
20
+ const SubscriptionPlanPreview: React.FC<IDashAutoAdminCustomFieldComponent> = ({ method, attribute, resourceConfig }) => {
21
+ const record = useRecordContext();
22
+
23
+ if (!record) return null;
24
+
25
+ const formatPrice = (price: number) => {
26
+ return priceFormatter(price, 'CLP');
27
+ };
28
+
29
+ const getBillingCycleText = (cycle: string) => {
30
+ return cycle === 'monthly' ? 'mes' : 'año';
31
+ };
32
+
33
+ return (
34
+ <Box maxWidth={400}>
35
+ <Card elevation={3}>
36
+ <CardContent>
37
+ {/* Header */}
38
+ <Box textAlign="center" mb={2}>
39
+ <Typography variant="h5" component="h2" gutterBottom>
40
+ {record.name}
41
+ </Typography>
42
+
43
+ {record.has_trial && (
44
+ <Chip
45
+ icon={<StarIcon />}
46
+ label={`${record.trial_days} días gratis`}
47
+ color="primary"
48
+ size="small"
49
+ sx={{ mb: 1 }}
50
+ />
51
+ )}
52
+
53
+ <Typography variant="h3" component="div" color="primary">
54
+ {formatPrice(record.price)}
55
+ </Typography>
56
+
57
+ <Typography variant="body2" color="textSecondary">
58
+ por {getBillingCycleText(record.billing_cycle)}
59
+ </Typography>
60
+
61
+ {record.billing_cycle === 'yearly' && (
62
+ <Typography variant="body2" color="success.main">
63
+ {formatPrice(record.price_per_month)} por mes
64
+ </Typography>
65
+ )}
66
+ </Box>
67
+
68
+ <Divider sx={{ my: 2 }} />
69
+
70
+ {/* Description */}
71
+ {record.description && (
72
+ <Typography variant="body2" color="textSecondary" paragraph>
73
+ {record.description}
74
+ </Typography>
75
+ )}
76
+
77
+ {/* Features */}
78
+ {record.features && record.features.length > 0 && (
79
+ <Box>
80
+ <Typography variant="h6" gutterBottom>
81
+ Características incluidas:
82
+ </Typography>
83
+ <List dense>
84
+ {record.features.map((feature: string, index: number) => (
85
+ <ListItem key={index} disableGutters>
86
+ <ListItemIcon sx={{ minWidth: 32 }}>
87
+ <CheckIcon color="success" fontSize="small" />
88
+ </ListItemIcon>
89
+ <ListItemText
90
+ primary={feature}
91
+ primaryTypographyProps={{ variant: 'body2' }}
92
+ />
93
+ </ListItem>
94
+ ))}
95
+ </List>
96
+ </Box>
97
+ )}
98
+
99
+ <Divider sx={{ my: 2 }} />
100
+
101
+ {/* Action Button */}
102
+ <Button
103
+ variant="contained"
104
+ fullWidth
105
+ size="large"
106
+ disabled={!record.is_active}
107
+ >
108
+ {record.has_trial ? 'Comenzar Prueba Gratis' : 'Suscribirse Ahora'}
109
+ </Button>
110
+
111
+ {!record.is_active && (
112
+ <Typography
113
+ variant="caption"
114
+ color="error"
115
+ display="block"
116
+ textAlign="center"
117
+ mt={1}
118
+ >
119
+ Plan no disponible
120
+ </Typography>
121
+ )}
122
+ </CardContent>
123
+ </Card>
124
+ </Box>
125
+ );
126
+ };
127
+
128
+ export default SubscriptionPlanPreview;