@joelbarron/react-web-dev-kit 0.1.5 → 0.1.7

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 (105) hide show
  1. package/dist/auth/fuse/fuseIntegration.d.ts +2 -0
  2. package/dist/auth/fuse/fuseIntegration.d.ts.map +1 -1
  3. package/dist/auth/fuse/fuseIntegration.js +18 -0
  4. package/dist/auth/social/providerAuth.d.ts.map +1 -1
  5. package/dist/auth/social/providerAuth.js +12 -4
  6. package/dist/config/createConfig.d.ts.map +1 -1
  7. package/dist/config/createConfig.js +38 -1
  8. package/dist/config/defaults.js +1 -1
  9. package/dist/core/buttons/JBButton.d.ts +8 -0
  10. package/dist/core/buttons/JBButton.d.ts.map +1 -0
  11. package/dist/core/buttons/JBButton.js +55 -0
  12. package/dist/core/buttons/index.d.ts +2 -0
  13. package/dist/core/buttons/index.d.ts.map +1 -0
  14. package/dist/core/buttons/index.js +1 -0
  15. package/dist/core/dialogs/JBConfirmDialog.d.ts +15 -0
  16. package/dist/core/dialogs/JBConfirmDialog.d.ts.map +1 -0
  17. package/dist/core/dialogs/JBConfirmDialog.js +6 -0
  18. package/dist/core/dialogs/index.d.ts +2 -0
  19. package/dist/core/dialogs/index.d.ts.map +1 -0
  20. package/dist/core/dialogs/index.js +1 -0
  21. package/dist/core/index.d.ts +5 -0
  22. package/dist/core/index.d.ts.map +1 -0
  23. package/dist/core/index.js +4 -0
  24. package/dist/core/layout/JBContentContainer.d.ts +31 -0
  25. package/dist/core/layout/JBContentContainer.d.ts.map +1 -0
  26. package/dist/core/layout/JBContentContainer.js +50 -0
  27. package/dist/core/layout/JBFormHeader.d.ts +3 -0
  28. package/dist/core/layout/JBFormHeader.d.ts.map +1 -0
  29. package/dist/core/layout/JBFormHeader.js +131 -0
  30. package/dist/core/layout/index.d.ts +3 -0
  31. package/dist/core/layout/index.d.ts.map +1 -0
  32. package/dist/core/layout/index.js +2 -0
  33. package/dist/core/skeletons/JBFormContentSkeleton.d.ts +5 -0
  34. package/dist/core/skeletons/JBFormContentSkeleton.d.ts.map +1 -0
  35. package/dist/core/skeletons/JBFormContentSkeleton.js +12 -0
  36. package/dist/core/skeletons/JBFormHeaderSkeleton.d.ts +6 -0
  37. package/dist/core/skeletons/JBFormHeaderSkeleton.d.ts.map +1 -0
  38. package/dist/core/skeletons/JBFormHeaderSkeleton.js +19 -0
  39. package/dist/core/skeletons/index.d.ts +3 -0
  40. package/dist/core/skeletons/index.d.ts.map +1 -0
  41. package/dist/core/skeletons/index.js +2 -0
  42. package/dist/forms/JBAutocompleteField.d.ts +12 -0
  43. package/dist/forms/JBAutocompleteField.d.ts.map +1 -0
  44. package/dist/forms/JBAutocompleteField.js +20 -0
  45. package/dist/forms/index.d.ts +2 -0
  46. package/dist/forms/index.d.ts.map +1 -1
  47. package/dist/forms/index.js +2 -0
  48. package/dist/forms/zod.d.ts +4 -0
  49. package/dist/forms/zod.d.ts.map +1 -0
  50. package/dist/forms/zod.js +9 -0
  51. package/dist/grid/JBGrid.d.ts.map +1 -1
  52. package/dist/grid/JBGrid.js +262 -18
  53. package/dist/grid/JBGridHeader.d.ts.map +1 -1
  54. package/dist/grid/JBGridHeader.js +86 -15
  55. package/dist/grid/JBGridLoading.d.ts +9 -0
  56. package/dist/grid/JBGridLoading.d.ts.map +1 -0
  57. package/dist/grid/JBGridLoading.js +14 -0
  58. package/dist/grid/JBGridProviders.d.ts +3 -0
  59. package/dist/grid/JBGridProviders.d.ts.map +1 -1
  60. package/dist/grid/JBGridProviders.js +16 -0
  61. package/dist/grid/JBGridSkeleton.d.ts +7 -0
  62. package/dist/grid/JBGridSkeleton.d.ts.map +1 -0
  63. package/dist/grid/JBGridSkeleton.js +6 -0
  64. package/dist/grid/defaults.d.ts +4 -0
  65. package/dist/grid/defaults.d.ts.map +1 -0
  66. package/dist/grid/defaults.js +28 -0
  67. package/dist/grid/index.d.ts +3 -0
  68. package/dist/grid/index.d.ts.map +1 -1
  69. package/dist/grid/index.js +3 -0
  70. package/dist/grid/types.d.ts +120 -5
  71. package/dist/grid/types.d.ts.map +1 -1
  72. package/dist/hooks/index.d.ts +1 -0
  73. package/dist/hooks/index.d.ts.map +1 -1
  74. package/dist/hooks/index.js +1 -0
  75. package/dist/hooks/useJBEntityFormController.d.ts +54 -0
  76. package/dist/hooks/useJBEntityFormController.d.ts.map +1 -0
  77. package/dist/hooks/useJBEntityFormController.js +156 -0
  78. package/dist/index.d.ts +1 -0
  79. package/dist/index.d.ts.map +1 -1
  80. package/dist/index.js +1 -0
  81. package/dist/query/index.d.ts +1 -0
  82. package/dist/query/index.d.ts.map +1 -1
  83. package/dist/query/index.js +1 -0
  84. package/dist/query/types.d.ts +7 -0
  85. package/dist/query/types.d.ts.map +1 -0
  86. package/dist/query/types.js +1 -0
  87. package/dist/utils/errors.d.ts +10 -0
  88. package/dist/utils/errors.d.ts.map +1 -0
  89. package/dist/utils/errors.js +55 -0
  90. package/dist/utils/geo.d.ts +9 -0
  91. package/dist/utils/geo.d.ts.map +1 -0
  92. package/dist/utils/geo.js +186 -0
  93. package/dist/utils/index.d.ts +2 -0
  94. package/dist/utils/index.d.ts.map +1 -1
  95. package/dist/utils/index.js +2 -0
  96. package/package.json +7 -1
  97. package/dist/auth/ui/SignInPageTitle.d.ts +0 -6
  98. package/dist/auth/ui/SignInPageTitle.d.ts.map +0 -1
  99. package/dist/auth/ui/SignInPageTitle.js +0 -7
  100. package/dist/auth/ui/SignOutPageTitle.d.ts +0 -6
  101. package/dist/auth/ui/SignOutPageTitle.d.ts.map +0 -1
  102. package/dist/auth/ui/SignOutPageTitle.js +0 -7
  103. package/dist/auth/ui/SignUpPageTitle.d.ts +0 -6
  104. package/dist/auth/ui/SignUpPageTitle.d.ts.map +0 -1
  105. package/dist/auth/ui/SignUpPageTitle.js +0 -7
@@ -16,6 +16,8 @@ export declare const fuseAuthRoles: {
16
16
  readonly user: readonly ["admin", "staff", "user"];
17
17
  readonly onlyGuest: readonly [];
18
18
  };
19
+ export type FuseAuthRolesMap = Record<string, string[]>;
20
+ export declare function createFuseAuthRoles(customRoles?: FuseAuthRolesMap): FuseAuthRolesMap;
19
21
  export declare function createFuseUserModel<TUser extends FuseUser>(): (data?: Partial<TUser>) => TUser;
20
22
  type CreateFuseUseUserOptions<TUser extends FuseUser> = {
21
23
  useAuth: () => {
@@ -1 +1 @@
1
- {"version":3,"file":"fuseIntegration.d.ts","sourceRoot":"","sources":["../../../src/auth/fuse/fuseIntegration.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAW,MAAM,OAAO,CAAC;AAElD,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAKvC,MAAM,MAAM,QAAQ,GAAG;IACrB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,IAAI,CAAC;IAC/B,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACnC,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B,CAAC;AAEF,eAAO,MAAM,aAAa;;;;;CAKhB,CAAC;AAEX,wBAAgB,mBAAmB,CAAC,KAAK,SAAS,QAAQ,MAChD,OAAO,OAAO,CAAC,KAAK,CAAC,KAAG,KAAK,CAetC;AAED,KAAK,wBAAwB,CAAC,KAAK,SAAS,QAAQ,IAAI;IACtD,OAAO,EAAE,MAAM;QACb,SAAS,EAAE;YAAE,IAAI,EAAE,KAAK,GAAG,IAAI,CAAA;SAAE,GAAG,IAAI,CAAC;QACzC,OAAO,EAAE,MAAM,IAAI,CAAC;QACpB,UAAU,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC;KAC5D,CAAC;IACF,KAAK,EAAE,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,KAAK,OAAO,CAAC;CAChE,CAAC;AAEF,wBAAgB,iBAAiB,CAAC,KAAK,SAAS,QAAQ,EAAE,OAAO,EAAE,wBAAwB,CAAC,KAAK,CAAC;;;;uBAQxD,OAAO,CAAC,KAAK,CAAC;sCAWC,KAAK,CAAC,UAAU,CAAC;EAuBzE;AAED,wBAAgB,cAAc,CAAC,MAAM,SAAS,MAAM,EAAE,eAAe,EACnE,WAAW,EAAE,MAAM,eAAe,IAET,WAAW,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,eAAe,CAAC,MAC9C,OAAO,MAAM,6CAUjD;AAED,KAAK,+BAA+B,CAAC,KAAK,SAAS,QAAQ,IAAI;IAC7D,UAAU,EAAE,UAAU,CAAC;IACvB,gBAAgB,EAAE,KAAK,CAAC,aAAa,CAAC;QACpC,SAAS,EAAE,KAAK,CAAC;YACf,IAAI,EAAE,MAAM,CAAC;YACb,QAAQ,EAAE,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,yBAAyB,CAAC,GAAG,CAAC,CAAC;SAC3E,CAAC,CAAC;QACH,QAAQ,EAAE,CAAC,SAAS,EAAE;YAAE,IAAI,CAAC,EAAE,KAAK,GAAG,IAAI,CAAA;SAAE,GAAG,IAAI,KAAK,SAAS,CAAC;KACpE,CAAC,CAAC;IACH,iBAAiB,EAAE,KAAK,CAAC,aAAa,CAAC;QACrC,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC,GAAG,SAAS,CAAC;QACpC,QAAQ,EAAE,SAAS,CAAC;KACrB,CAAC,CAAC;IACH,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,wBAAgB,wBAAwB,CAAC,KAAK,SAAS,QAAQ,EAAE,OAAO,EAAE,+BAA+B,CAAC,KAAK,CAAC,IAW/E,OAAO;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,6CAY9D"}
1
+ {"version":3,"file":"fuseIntegration.d.ts","sourceRoot":"","sources":["../../../src/auth/fuse/fuseIntegration.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAW,MAAM,OAAO,CAAC;AAElD,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAKvC,MAAM,MAAM,QAAQ,GAAG;IACrB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,EAAE,GAAG,MAAM,GAAG,IAAI,CAAC;IAC/B,WAAW,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACnC,gBAAgB,CAAC,EAAE,MAAM,CAAC;CAC3B,CAAC;AAEF,eAAO,MAAM,aAAa;;;;;CAKhB,CAAC;AAEX,MAAM,MAAM,gBAAgB,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;AAExD,wBAAgB,mBAAmB,CAAC,WAAW,CAAC,EAAE,gBAAgB,GAAG,gBAAgB,CAwBpF;AAED,wBAAgB,mBAAmB,CAAC,KAAK,SAAS,QAAQ,MAChD,OAAO,OAAO,CAAC,KAAK,CAAC,KAAG,KAAK,CAetC;AAED,KAAK,wBAAwB,CAAC,KAAK,SAAS,QAAQ,IAAI;IACtD,OAAO,EAAE,MAAM;QACb,SAAS,EAAE;YAAE,IAAI,EAAE,KAAK,GAAG,IAAI,CAAA;SAAE,GAAG,IAAI,CAAC;QACzC,OAAO,EAAE,MAAM,IAAI,CAAC;QACpB,UAAU,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC;KAC5D,CAAC;IACF,KAAK,EAAE,CAAC,GAAG,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,KAAK,OAAO,CAAC;CAChE,CAAC;AAEF,wBAAgB,iBAAiB,CAAC,KAAK,SAAS,QAAQ,EAAE,OAAO,EAAE,wBAAwB,CAAC,KAAK,CAAC;;;;uBAQxD,OAAO,CAAC,KAAK,CAAC;sCAWC,KAAK,CAAC,UAAU,CAAC;EAuBzE;AAED,wBAAgB,cAAc,CAAC,MAAM,SAAS,MAAM,EAAE,eAAe,EACnE,WAAW,EAAE,MAAM,eAAe,IAET,WAAW,KAAK,CAAC,aAAa,CAAC,MAAM,GAAG,eAAe,CAAC,MAC9C,OAAO,MAAM,6CAUjD;AAED,KAAK,+BAA+B,CAAC,KAAK,SAAS,QAAQ,IAAI;IAC7D,UAAU,EAAE,UAAU,CAAC;IACvB,gBAAgB,EAAE,KAAK,CAAC,aAAa,CAAC;QACpC,SAAS,EAAE,KAAK,CAAC;YACf,IAAI,EAAE,MAAM,CAAC;YACb,QAAQ,EAAE,KAAK,CAAC,aAAa,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC,yBAAyB,CAAC,GAAG,CAAC,CAAC;SAC3E,CAAC,CAAC;QACH,QAAQ,EAAE,CAAC,SAAS,EAAE;YAAE,IAAI,CAAC,EAAE,KAAK,GAAG,IAAI,CAAA;SAAE,GAAG,IAAI,KAAK,SAAS,CAAC;KACpE,CAAC,CAAC;IACH,iBAAiB,EAAE,KAAK,CAAC,aAAa,CAAC;QACrC,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC,GAAG,SAAS,CAAC;QACpC,QAAQ,EAAE,SAAS,CAAC;KACrB,CAAC,CAAC;IACH,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAEF,wBAAgB,wBAAwB,CAAC,KAAK,SAAS,QAAQ,EAAE,OAAO,EAAE,+BAA+B,CAAC,KAAK,CAAC,IAW/E,OAAO;IAAE,QAAQ,EAAE,SAAS,CAAA;CAAE,6CAY9D"}
@@ -8,6 +8,24 @@ export const fuseAuthRoles = {
8
8
  user: ['admin', 'staff', 'user'],
9
9
  onlyGuest: []
10
10
  };
11
+ export function createFuseAuthRoles(customRoles) {
12
+ const mergedRoles = Object.entries(fuseAuthRoles).reduce((accumulator, [roleKey, roleValues]) => {
13
+ accumulator[roleKey] = [...roleValues];
14
+ return accumulator;
15
+ }, {});
16
+ if (!customRoles) {
17
+ return mergedRoles;
18
+ }
19
+ Object.entries(customRoles).forEach(([roleKey, roleValues]) => {
20
+ const normalizedRoleValues = Array.from(new Set(roleValues ?? []));
21
+ if (!mergedRoles[roleKey]) {
22
+ mergedRoles[roleKey] = normalizedRoleValues;
23
+ return;
24
+ }
25
+ mergedRoles[roleKey] = Array.from(new Set([...mergedRoles[roleKey], ...normalizedRoleValues]));
26
+ });
27
+ return mergedRoles;
28
+ }
11
29
  export function createFuseUserModel() {
12
30
  return (data) => {
13
31
  const userData = data || {};
@@ -1 +1 @@
1
- {"version":3,"file":"providerAuth.d.ts","sourceRoot":"","sources":["../../../src/auth/social/providerAuth.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"providerAuth.d.ts","sourceRoot":"","sources":["../../../src/auth/social/providerAuth.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AAE9D,KAAK,0BAA0B,GAAG;IAChC,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,YAAY,CAAC,EAAE,aAAa,GAAG,WAAW,GAAG,OAAO,GAAG,UAAU,CAAC;IAClE,YAAY,CAAC,EAAE,MAAM,GAAG,UAAU,GAAG,eAAe,CAAC;IACrD,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB,CAAC;AAEF,KAAK,kBAAkB,GAAG;IACxB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,KAAK,wBAAwB,GAAG;IAC9B,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,KAAK,8BAA8B,GAAG;IACpC,cAAc,CAAC,EAAE,MAAM,OAAO,CAAC;IAC/B,eAAe,CAAC,EAAE,MAAM,OAAO,CAAC;IAChC,iBAAiB,CAAC,EAAE,MAAM,OAAO,CAAC;IAClC,qBAAqB,CAAC,EAAE,MAAM,MAAM,CAAC;IACrC,gBAAgB,CAAC,EAAE,MAAM,MAAM,CAAC;IAChC,kBAAkB,CAAC,EAAE,MAAM,MAAM,CAAC;CACnC,CAAC;AAEF,KAAK,mBAAmB,GAAG;IACzB,aAAa,CAAC,EAAE;QACd,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,iBAAiB,CAAC,EAAE,MAAM,CAAC;QAC3B,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;KAC3B,CAAC;CACH,CAAC;AAEF,KAAK,qBAAqB,GAAG;IAC3B,YAAY,CAAC,EAAE;QACb,WAAW,CAAC,EAAE,MAAM,CAAC;KACtB,CAAC;CACH,CAAC;AAEF,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,MAAM;QACd,MAAM,CAAC,EAAE;YACP,QAAQ,CAAC,EAAE;gBACT,EAAE,CAAC,EAAE;oBACH,UAAU,EAAE,CAAC,OAAO,EAAE;wBACpB,SAAS,EAAE,MAAM,CAAC;wBAClB,QAAQ,EAAE,CAAC,QAAQ,EAAE,wBAAwB,KAAK,IAAI,CAAC;qBACxD,KAAK,IAAI,CAAC;oBACX,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,YAAY,EAAE,8BAA8B,KAAK,IAAI,KAAK,IAAI,CAAC;oBACpF,MAAM,EAAE,MAAM,IAAI,CAAC;iBACpB,CAAC;gBACF,MAAM,CAAC,EAAE;oBACP,cAAc,EAAE,CAAC,OAAO,EAAE;wBACxB,SAAS,EAAE,MAAM,CAAC;wBAClB,KAAK,EAAE,MAAM,CAAC;wBACd,YAAY,CAAC,EAAE,MAAM,CAAC;wBACtB,OAAO,EAAE,OAAO,CAAC;wBACjB,QAAQ,EAAE,CAAC,QAAQ,EAAE,kBAAkB,KAAK,IAAI,CAAC;qBAClD,KAAK;wBAAE,WAAW,EAAE,MAAM,IAAI,CAAA;qBAAE,CAAC;iBACnC,CAAC;aACH,CAAC;SACH,CAAC;QACF,OAAO,CAAC,EAAE;YACR,IAAI,EAAE;gBACJ,IAAI,EAAE,CAAC,OAAO,EAAE;oBACd,QAAQ,EAAE,MAAM,CAAC;oBACjB,KAAK,EAAE,MAAM,CAAC;oBACd,WAAW,EAAE,MAAM,CAAC;oBACpB,QAAQ,EAAE,OAAO,CAAC;oBAClB,YAAY,CAAC,EAAE,aAAa,GAAG,WAAW,GAAG,OAAO,GAAG,UAAU,CAAC;oBAClE,YAAY,CAAC,EAAE,MAAM,GAAG,UAAU,GAAG,eAAe,CAAC;oBACrD,KAAK,CAAC,EAAE,MAAM,CAAC;oBACf,KAAK,CAAC,EAAE,MAAM,CAAC;iBAChB,KAAK,IAAI,CAAC;gBACX,MAAM,EAAE,MAAM,OAAO,CAAC,mBAAmB,CAAC,CAAC;aAC5C,CAAC;SACH,CAAC;QACF,EAAE,CAAC,EAAE;YACH,IAAI,EAAE,CAAC,OAAO,EAAE;gBACd,KAAK,EAAE,MAAM,CAAC;gBACd,MAAM,EAAE,OAAO,CAAC;gBAChB,KAAK,EAAE,OAAO,CAAC;gBACf,OAAO,EAAE,MAAM,CAAC;aACjB,KAAK,IAAI,CAAC;YACX,KAAK,EAAE,CACL,QAAQ,EAAE,CAAC,QAAQ,EAAE,qBAAqB,KAAK,IAAI,EACnD,OAAO,CAAC,EAAE;gBACR,KAAK,CAAC,EAAE,MAAM,CAAC;gBACf,OAAO,CAAC,EAAE,OAAO,GAAG,OAAO,GAAG,MAAM,CAAC;aACtC,KACE,IAAI,CAAC;SACX,CAAC;KACH;CACF;AAiPD,eAAO,MAAM,8BAA8B,GACzC,UAAU,cAAc,EACxB,QAAQ,0BAA0B,KACjC,OAAO,CAAC,IAAI,CAAC,kBAAkB,EAAE,UAAU,GAAG,mBAAmB,GAAG,SAAS,GAAG,aAAa,GAAG,aAAa,GAAG,UAAU,CAAC,CAc7H,CAAC"}
@@ -45,11 +45,18 @@ const ensureFacebookSdk = async (clientId) => {
45
45
  });
46
46
  };
47
47
  const isLikelyMobileBrowser = () => {
48
- if (typeof navigator === 'undefined') {
48
+ if (typeof navigator === 'undefined' || typeof window === 'undefined') {
49
49
  return false;
50
50
  }
51
51
  const userAgent = navigator.userAgent || '';
52
- return /Android|iPhone|iPad|iPod|IEMobile|Opera Mini/i.test(userAgent);
52
+ const hasTouch = (navigator.maxTouchPoints ?? 0) > 0;
53
+ const hasCoarsePointer = typeof window.matchMedia === 'function'
54
+ ? window.matchMedia('(pointer: coarse)').matches
55
+ : false;
56
+ const smallViewport = typeof window.innerWidth === 'number' ? window.innerWidth <= 1024 : false;
57
+ const isMobileUserAgent = /Android|iPhone|iPad|iPod|IEMobile|Opera Mini|Mobile/i.test(userAgent);
58
+ const isIpadOsDesktopMode = /Macintosh/i.test(userAgent) && hasTouch;
59
+ return isMobileUserAgent || isIpadOsDesktopMode || ((hasTouch || hasCoarsePointer) && smallViewport);
53
60
  };
54
61
  const logSocialDebug = (enabled, message, payload) => {
55
62
  if (!enabled) {
@@ -157,10 +164,11 @@ const authenticateWithApple = async (config) => {
157
164
  };
158
165
  };
159
166
  const authenticateWithFacebook = async (config) => {
160
- const shouldUsePopup = config.usePopup ?? !isLikelyMobileBrowser();
167
+ const mobileBrowser = isLikelyMobileBrowser();
168
+ const shouldUsePopup = config.usePopup ?? !mobileBrowser;
161
169
  const resolvedDisplay = shouldUsePopup
162
170
  ? 'popup'
163
- : isLikelyMobileBrowser()
171
+ : mobileBrowser
164
172
  ? 'touch'
165
173
  : 'page';
166
174
  logSocialDebug(config.debug, 'facebook provider auth start', {
@@ -1 +1 @@
1
- {"version":3,"file":"createConfig.d.ts","sourceRoot":"","sources":["../../src/config/createConfig.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,eAAe,EACf,WAAW,EACX,oBAAoB,EACpB,UAAU,EAEV,uBAAuB,EACvB,kBAAkB,EAElB,eAAe,EAChB,MAAM,SAAS,CAAC;AAEjB,eAAO,MAAM,iBAAiB,GAC5B,aAAa,oBAAoB,EACjC,YAAY,oBAAoB,KAC/B,WA6BF,CAAC;AAEF,eAAO,MAAM,qBAAqB,GAAI,YAAY,eAAe,EAAE,OAAO,UAAU,KAAG,MAEtF,CAAC;AAEF,eAAO,MAAM,aAAa,GAAI,CAAC,EAC7B,UAAU,eAAe,CAAC,CAAC,CAAC,GAAG,SAAS,EACxC,OAAO,UAAU,EACjB,WAAW,CAAC,KACX,CAAC,GAAG,SAQN,CAAC;AAEF,eAAO,MAAM,aAAa,GAAI,QAAQ,WAAW,KAAG,MAEnD,CAAC;AAEF,eAAO,MAAM,mBAAmB,GAAI,CAAC,EACnC,QAAQ,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,EAClC,UAAU,eAAe,CAAC,CAAC,CAAC,GAAG,SAAS,EACxC,WAAW,CAAC,KACX,CAAC,GAAG,SAEN,CAAC;AAEF,eAAO,MAAM,wBAAwB,GACnC,aAAa,oBAAoB,EACjC,MAAM,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,KACvC,WA+FF,CAAC;AAEF,eAAO,MAAM,eAAe,GAAI,QAAQ,WAAW,KAAG,MAErD,CAAC;AAEF,eAAO,MAAM,mBAAmB,GAAI,QAAQ,WAAW,KAAG,uBAAuB,EAEhF,CAAC;AAEF,eAAO,MAAM,yBAAyB,GAAI,QAAQ,WAAW,KAAG,uBAAuB,EAEtF,CAAC;AAEF,eAAO,MAAM,yBAAyB,GAAI,QAAQ,WAAW,KAAG,MAAM,GAAG,SAExE,CAAC;AAEF,eAAO,MAAM,mBAAmB,GAAI,QAAQ,WAAW,KAAG,kBAEzD,CAAC;AAEF,eAAO,MAAM,sBAAsB,GAAI,QAAQ,WAAW,KAAG,OAE5D,CAAC"}
1
+ {"version":3,"file":"createConfig.d.ts","sourceRoot":"","sources":["../../src/config/createConfig.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,eAAe,EACf,WAAW,EACX,oBAAoB,EACpB,UAAU,EAEV,uBAAuB,EACvB,kBAAkB,EAElB,eAAe,EAChB,MAAM,SAAS,CAAC;AAEjB,eAAO,MAAM,iBAAiB,GAC5B,aAAa,oBAAoB,EACjC,YAAY,oBAAoB,KAC/B,WA6BF,CAAC;AAEF,eAAO,MAAM,qBAAqB,GAAI,YAAY,eAAe,EAAE,OAAO,UAAU,KAAG,MAEtF,CAAC;AAEF,eAAO,MAAM,aAAa,GAAI,CAAC,EAC7B,UAAU,eAAe,CAAC,CAAC,CAAC,GAAG,SAAS,EACxC,OAAO,UAAU,EACjB,WAAW,CAAC,KACX,CAAC,GAAG,SAQN,CAAC;AAEF,eAAO,MAAM,aAAa,GAAI,QAAQ,WAAW,KAAG,MAEnD,CAAC;AAEF,eAAO,MAAM,mBAAmB,GAAI,CAAC,EACnC,QAAQ,IAAI,CAAC,WAAW,EAAE,OAAO,CAAC,EAClC,UAAU,eAAe,CAAC,CAAC,CAAC,GAAG,SAAS,EACxC,WAAW,CAAC,KACX,CAAC,GAAG,SAEN,CAAC;AAEF,eAAO,MAAM,wBAAwB,GACnC,aAAa,oBAAoB,EACjC,MAAM,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,KACvC,WA2IF,CAAC;AAEF,eAAO,MAAM,eAAe,GAAI,QAAQ,WAAW,KAAG,MAErD,CAAC;AAEF,eAAO,MAAM,mBAAmB,GAAI,QAAQ,WAAW,KAAG,uBAAuB,EAEhF,CAAC;AAEF,eAAO,MAAM,yBAAyB,GAAI,QAAQ,WAAW,KAAG,uBAAuB,EAEtF,CAAC;AAEF,eAAO,MAAM,yBAAyB,GAAI,QAAQ,WAAW,KAAG,MAAM,GAAG,SAExE,CAAC;AAEF,eAAO,MAAM,mBAAmB,GAAI,QAAQ,WAAW,KAAG,kBAEzD,CAAC;AAEF,eAAO,MAAM,sBAAsB,GAAI,QAAQ,WAAW,KAAG,OAE5D,CAAC"}
@@ -40,7 +40,28 @@ export const getConfigStageValue = (config, stageMap, fallback) => {
40
40
  return getStageValue(stageMap, config.stage, fallback);
41
41
  };
42
42
  export const createJBWebConfigFromEnv = (baseConfig, env) => {
43
- const runtimeEnv = env ?? {};
43
+ const resolveRuntimeEnv = () => {
44
+ if (env) {
45
+ return env;
46
+ }
47
+ try {
48
+ const importMetaEnv = import.meta.env;
49
+ if (importMetaEnv && typeof importMetaEnv === 'object') {
50
+ return importMetaEnv;
51
+ }
52
+ }
53
+ catch {
54
+ // Ignore import.meta access errors outside of ESM/runtime contexts.
55
+ }
56
+ if (typeof globalThis !== 'undefined') {
57
+ const globalEnv = globalThis.__ENV__;
58
+ if (globalEnv && typeof globalEnv === 'object') {
59
+ return globalEnv;
60
+ }
61
+ }
62
+ return {};
63
+ };
64
+ const runtimeEnv = resolveRuntimeEnv();
44
65
  const parseEnvList = (value) => {
45
66
  if (!value) {
46
67
  return undefined;
@@ -82,9 +103,25 @@ export const createJBWebConfigFromEnv = (baseConfig, env) => {
82
103
  const googleEnabled = parseBooleanEnv(runtimeEnv.VITE_AUTH_SOCIAL_GOOGLE_ENABLED);
83
104
  const facebookEnabled = parseBooleanEnv(runtimeEnv.VITE_AUTH_SOCIAL_FACEBOOK_ENABLED);
84
105
  const appleEnabled = parseBooleanEnv(runtimeEnv.VITE_AUTH_SOCIAL_APPLE_ENABLED);
106
+ const apiHostOverrides = {};
107
+ const setApiHost = (stage, value) => {
108
+ if (!value) {
109
+ return;
110
+ }
111
+ const normalizedValue = value.trim();
112
+ if (!normalizedValue) {
113
+ return;
114
+ }
115
+ apiHostOverrides[stage] = normalizedValue;
116
+ };
117
+ setApiHost('PRODUCTION', runtimeEnv.VITE_API_HOST_PRODUCTION);
118
+ setApiHost('QA', runtimeEnv.VITE_API_HOST_QA);
119
+ setApiHost('DEVELOPMENT', runtimeEnv.VITE_API_HOST_DEVELOPMENT);
120
+ setApiHost('LOCAL', runtimeEnv.VITE_API_HOST_LOCAL);
85
121
  return createJBWebConfig(baseConfig, {
86
122
  debug: runtimeEnv.VITE_DEBUG === 'true' ? true : undefined,
87
123
  stage: runtimeEnv.VITE_STAGE,
124
+ api: Object.keys(apiHostOverrides).length > 0 ? { host: apiHostOverrides } : undefined,
88
125
  integrations: {
89
126
  mapboxToken: runtimeEnv.VITE_MAPBOX_TOKEN
90
127
  },
@@ -2,7 +2,7 @@ export const defaultJBAppConfig = {
2
2
  debug: false,
3
3
  forceHideStage: false,
4
4
  stage: 'DEVELOPMENT',
5
- defaultRows: 10,
5
+ defaultRows: 30,
6
6
  maxRows: 999999999,
7
7
  momentLocale: 'es-mx',
8
8
  defaultLocaleDate: 'es',
@@ -0,0 +1,8 @@
1
+ import { ButtonProps } from '@mui/material';
2
+ export type JBButtonAction = 'save' | 'edit' | 'cancel' | 'delete' | 'primary' | 'secondary';
3
+ export type JBButtonProps = Omit<ButtonProps, 'size' | 'action'> & {
4
+ action?: JBButtonAction;
5
+ size?: ButtonProps['size'];
6
+ };
7
+ export declare function JBButton(props: JBButtonProps): import("react/jsx-runtime").JSX.Element;
8
+ //# sourceMappingURL=JBButton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JBButton.d.ts","sourceRoot":"","sources":["../../../src/core/buttons/JBButton.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAU,WAAW,EAAE,MAAM,eAAe,CAAC;AAGpD,MAAM,MAAM,cAAc,GAAG,MAAM,GAAG,MAAM,GAAG,QAAQ,GAAG,QAAQ,GAAG,SAAS,GAAG,WAAW,CAAC;AAE7F,MAAM,MAAM,aAAa,GAAG,IAAI,CAAC,WAAW,EAAE,MAAM,GAAG,QAAQ,CAAC,GAAG;IACjE,MAAM,CAAC,EAAE,cAAc,CAAC;IACxB,IAAI,CAAC,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;CAC5B,CAAC;AA6BF,wBAAgB,QAAQ,CAAC,KAAK,EAAE,aAAa,2CA6C5C"}
@@ -0,0 +1,55 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import CloseRoundedIcon from '@mui/icons-material/CloseRounded';
3
+ import DeleteRoundedIcon from '@mui/icons-material/DeleteRounded';
4
+ import EditRoundedIcon from '@mui/icons-material/EditRounded';
5
+ import SaveRoundedIcon from '@mui/icons-material/SaveRounded';
6
+ import { Button } from '@mui/material';
7
+ const ACTION_VARIANT = {
8
+ save: 'contained',
9
+ edit: 'contained',
10
+ cancel: 'outlined',
11
+ delete: 'contained',
12
+ primary: 'contained',
13
+ secondary: 'contained'
14
+ };
15
+ const ACTION_COLOR = {
16
+ save: 'primary',
17
+ edit: 'warning',
18
+ cancel: undefined,
19
+ delete: 'error',
20
+ primary: 'primary',
21
+ secondary: 'secondary'
22
+ };
23
+ const ACTION_ICON = {
24
+ save: _jsx(SaveRoundedIcon, { fontSize: "small" }),
25
+ edit: _jsx(EditRoundedIcon, { fontSize: "small" }),
26
+ cancel: _jsx(CloseRoundedIcon, { fontSize: "small" }),
27
+ delete: _jsx(DeleteRoundedIcon, { fontSize: "small" }),
28
+ primary: undefined,
29
+ secondary: undefined
30
+ };
31
+ export function JBButton(props) {
32
+ const { action, size = 'large', variant, color, startIcon, sx, children, ...rest } = props;
33
+ const resolvedVariant = variant ?? (action ? ACTION_VARIANT[action] : 'contained');
34
+ const resolvedColor = color ?? (action ? ACTION_COLOR[action] : 'primary');
35
+ const resolvedStartIcon = startIcon ?? (action ? ACTION_ICON[action] : undefined);
36
+ return (_jsx(Button, { ...rest, size: size, variant: resolvedVariant, color: resolvedColor, startIcon: resolvedStartIcon, sx: [
37
+ () => ({
38
+ borderRadius: 1.5,
39
+ minHeight: 42,
40
+ px: 2.25,
41
+ fontWeight: 700,
42
+ ...(resolvedVariant === 'contained'
43
+ ? {
44
+ boxShadow: 'none',
45
+ backgroundImage: 'none',
46
+ '&:hover': {
47
+ boxShadow: 'none',
48
+ backgroundImage: 'none'
49
+ }
50
+ }
51
+ : {})
52
+ }),
53
+ ...(Array.isArray(sx) ? sx : sx ? [sx] : [])
54
+ ], children: children }));
55
+ }
@@ -0,0 +1,2 @@
1
+ export * from './JBButton';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/buttons/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAC"}
@@ -0,0 +1 @@
1
+ export * from './JBButton';
@@ -0,0 +1,15 @@
1
+ import { ReactNode } from 'react';
2
+ export type JBConfirmDialogProps = {
3
+ open: boolean;
4
+ title?: ReactNode;
5
+ description?: ReactNode;
6
+ confirmLabel?: string;
7
+ cancelLabel?: string;
8
+ loading?: boolean;
9
+ maxWidth?: 'xs' | 'sm' | 'md' | 'lg' | 'xl';
10
+ confirmColor?: 'primary' | 'secondary' | 'error' | 'info' | 'success' | 'warning';
11
+ onConfirm: () => void;
12
+ onClose: () => void;
13
+ };
14
+ export declare function JBConfirmDialog(props: JBConfirmDialogProps): import("react/jsx-runtime").JSX.Element;
15
+ //# sourceMappingURL=JBConfirmDialog.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JBConfirmDialog.d.ts","sourceRoot":"","sources":["../../../src/core/dialogs/JBConfirmDialog.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAElC,MAAM,MAAM,oBAAoB,GAAG;IACjC,IAAI,EAAE,OAAO,CAAC;IACd,KAAK,CAAC,EAAE,SAAS,CAAC;IAClB,WAAW,CAAC,EAAE,SAAS,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,QAAQ,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;IAC5C,YAAY,CAAC,EAAE,SAAS,GAAG,WAAW,GAAG,OAAO,GAAG,MAAM,GAAG,SAAS,GAAG,SAAS,CAAC;IAClF,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB,CAAC;AAEF,wBAAgB,eAAe,CAAC,KAAK,EAAE,oBAAoB,2CA8C1D"}
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Button, Dialog, DialogActions, DialogContent, DialogTitle, Typography } from '@mui/material';
3
+ export function JBConfirmDialog(props) {
4
+ const { open, title = 'Confirmar', description, confirmLabel = 'Confirmar', cancelLabel = 'Cancelar', loading = false, maxWidth = 'xs', confirmColor = 'primary', onConfirm, onClose } = props;
5
+ return (_jsxs(Dialog, { open: open, onClose: loading ? undefined : onClose, maxWidth: maxWidth, fullWidth: true, children: [_jsx(DialogTitle, { children: title }), description ? (_jsx(DialogContent, { children: typeof description === 'string' ? _jsx(Typography, { variant: "body2", children: description }) : description })) : null, _jsxs(DialogActions, { sx: { px: 3, pb: 2 }, children: [_jsx(Button, { variant: "outlined", onClick: onClose, disabled: loading, children: cancelLabel }), _jsx(Button, { variant: "contained", color: confirmColor, onClick: onConfirm, disabled: loading, children: confirmLabel })] })] }));
6
+ }
@@ -0,0 +1,2 @@
1
+ export * from './JBConfirmDialog';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/dialogs/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC"}
@@ -0,0 +1 @@
1
+ export * from './JBConfirmDialog';
@@ -0,0 +1,5 @@
1
+ export * from './dialogs';
2
+ export * from './layout';
3
+ export * from './skeletons';
4
+ export * from './buttons';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,aAAa,CAAC;AAC5B,cAAc,WAAW,CAAC"}
@@ -0,0 +1,4 @@
1
+ export * from './dialogs';
2
+ export * from './layout';
3
+ export * from './skeletons';
4
+ export * from './buttons';
@@ -0,0 +1,31 @@
1
+ import { SxProps, Theme } from '@mui/material';
2
+ import { KeyboardEventHandler, ReactNode } from 'react';
3
+ export type JBContentContainerProps = {
4
+ children: ReactNode;
5
+ header?: ReactNode;
6
+ stickyHeader?: boolean;
7
+ stickyHeaderTop?: number | string;
8
+ stickyHeaderZIndex?: number;
9
+ onKeyDown?: KeyboardEventHandler<HTMLDivElement>;
10
+ animated?: boolean;
11
+ animationDelayMs?: number;
12
+ animationDurationMs?: number;
13
+ padding?: number | string | {
14
+ xs?: number | string;
15
+ sm?: number | string;
16
+ md?: number | string;
17
+ lg?: number | string;
18
+ };
19
+ contentPadding?: number | string | {
20
+ xs?: number | string;
21
+ sm?: number | string;
22
+ md?: number | string;
23
+ lg?: number | string;
24
+ };
25
+ withGradient?: boolean;
26
+ paperSx?: SxProps<Theme>;
27
+ headerSx?: SxProps<Theme>;
28
+ contentSx?: SxProps<Theme>;
29
+ };
30
+ export declare function JBContentContainer(props: JBContentContainerProps): import("react/jsx-runtime").JSX.Element;
31
+ //# sourceMappingURL=JBContentContainer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JBContentContainer.d.ts","sourceRoot":"","sources":["../../../src/core/layout/JBContentContainer.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAc,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAE3D,OAAO,EAAE,oBAAoB,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAExD,MAAM,MAAM,uBAAuB,GAAG;IACpC,QAAQ,EAAE,SAAS,CAAC;IACpB,MAAM,CAAC,EAAE,SAAS,CAAC;IACnB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,eAAe,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAClC,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,SAAS,CAAC,EAAE,oBAAoB,CAAC,cAAc,CAAC,CAAC;IACjD,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,OAAO,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG;QAAE,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;QAAC,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;QAAC,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;QAAC,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,CAAC;IACvH,cAAc,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG;QAAE,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;QAAC,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;QAAC,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;QAAC,EAAE,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,CAAC;IAE9H,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,OAAO,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IAC1B,SAAS,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;CAC5B,CAAC;AAKF,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,uBAAuB,2CA2FhE"}
@@ -0,0 +1,50 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Paper } from '@mui/material';
3
+ import { alpha } from '@mui/material/styles';
4
+ const defaultOuterPadding = { xs: 1.5, sm: 2.5, md: 3 };
5
+ const defaultContentPadding = { xs: 2.5, sm: 3, md: 4 };
6
+ export function JBContentContainer(props) {
7
+ const { children, header, stickyHeader = false, stickyHeaderTop = 0, stickyHeaderZIndex = 2, onKeyDown, animated = true, animationDelayMs = 0, animationDurationMs = 260, padding = defaultOuterPadding, contentPadding = defaultContentPadding,
8
+ // borderRadius = 3,
9
+ withGradient = false, paperSx, headerSx, contentSx } = props;
10
+ return (_jsx(Box, { className: "w-full h-full", sx: { p: padding }, onKeyDown: onKeyDown, children: _jsx(Box, { sx: animated
11
+ ? {
12
+ '@keyframes jbFadeSlideIn': {
13
+ from: { opacity: 0, transform: 'translateY(14px)' },
14
+ to: { opacity: 1, transform: 'translateY(0)' }
15
+ },
16
+ animation: `jbFadeSlideIn ${animationDurationMs}ms ease-out ${animationDelayMs}ms both`
17
+ }
18
+ : undefined, children: _jsxs(Paper, { elevation: 0, sx: [
19
+ (theme) => ({
20
+ position: 'relative',
21
+ overflow: stickyHeader ? 'visible' : 'hidden',
22
+ // borderRadius,
23
+ // border: `1px solid ${theme.palette.divider}`,
24
+ background: withGradient
25
+ ? `linear-gradient(180deg, ${alpha(theme.palette.background.paper, 0.96)} 0%, ${alpha(theme.palette.background.default, 0.9)} 100%)`
26
+ : theme.palette.background.paper
27
+ }),
28
+ ...(Array.isArray(paperSx) ? paperSx : paperSx ? [paperSx] : [])
29
+ ], children: [header ? (_jsx(Box, { sx: [
30
+ {
31
+ px: { xs: 2, sm: 3, md: 4 },
32
+ pt: { xs: 2, sm: 2.5 },
33
+ pb: 0.75,
34
+ borderBottom: '1px solid',
35
+ borderColor: 'divider',
36
+ ...(stickyHeader
37
+ ? {
38
+ position: 'sticky',
39
+ top: stickyHeaderTop,
40
+ zIndex: stickyHeaderZIndex,
41
+ bgcolor: 'background.paper'
42
+ }
43
+ : {})
44
+ },
45
+ ...(Array.isArray(headerSx) ? headerSx : headerSx ? [headerSx] : [])
46
+ ], children: header })) : null, _jsx(Box, { sx: [
47
+ { px: contentPadding, py: contentPadding },
48
+ ...(Array.isArray(contentSx) ? contentSx : contentSx ? [contentSx] : [])
49
+ ], children: children })] }) }) }));
50
+ }
@@ -0,0 +1,3 @@
1
+ import { JBFormHeaderProps } from '../../grid/types';
2
+ export declare function JBFormHeader(props: JBFormHeaderProps): import("react/jsx-runtime").JSX.Element;
3
+ //# sourceMappingURL=JBFormHeader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JBFormHeader.d.ts","sourceRoot":"","sources":["../../../src/core/layout/JBFormHeader.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAErD,wBAAgB,YAAY,CAAC,KAAK,EAAE,iBAAiB,2CA+PpD"}
@@ -0,0 +1,131 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Typography } from '@mui/material';
3
+ import { alpha } from '@mui/material/styles';
4
+ import { JBButton } from '../buttons';
5
+ export function JBFormHeader(props) {
6
+ const { moduleConfig, iconNameRenderer, animated = true, animationDurationMs = 260, animationStaggerMs = 70, animationPreset = 'vertical', breadcrumb, showBackButton = false, backLabel, onBackClick, backContent, isNew = false, recordId, title, dynamicTitle, formValues, getDynamicTitle, subtitle, dynamicSubtitle, getDynamicSubtitle, icon, actions, rightContent } = props;
7
+ const dynamicTitleFromResolver = getDynamicTitle?.({ isNew, values: formValues });
8
+ const dynamicSubtitleFromResolver = getDynamicSubtitle?.({ isNew, values: formValues });
9
+ const resolvedDynamicTitle = (!isNew ? dynamicTitle : undefined) ?? dynamicTitleFromResolver;
10
+ const moduleTitle = title ??
11
+ (isNew ? moduleConfig?.texts?.newText : moduleConfig?.texts?.editText) ??
12
+ moduleConfig?.texts?.moduleName ??
13
+ '';
14
+ const hasStaticTitle = Boolean(moduleTitle);
15
+ const dynamicSubtitleCandidate = dynamicSubtitle ??
16
+ dynamicSubtitleFromResolver ??
17
+ (hasStaticTitle ? resolvedDynamicTitle : undefined);
18
+ const staticSubtitleCandidate = subtitle ??
19
+ moduleConfig?.texts?.formHeaderSubtitle ??
20
+ '';
21
+ const baseSubtitle = dynamicSubtitleCandidate ?? staticSubtitleCandidate;
22
+ const recordPrefix = moduleConfig?.texts?.formHeaderRecordPrefix;
23
+ const canApplyRecordPrefix = !isNew &&
24
+ Boolean(recordPrefix) &&
25
+ recordId !== undefined &&
26
+ recordId !== null &&
27
+ String(recordId).trim() !== '' &&
28
+ Boolean(dynamicSubtitleCandidate);
29
+ const resolvedTitle = (hasStaticTitle ? moduleTitle : undefined) ||
30
+ resolvedDynamicTitle ||
31
+ '';
32
+ const resolvedSubtitle = canApplyRecordPrefix
33
+ ? [`${recordPrefix}-${recordId}`, baseSubtitle].filter(Boolean).join(' / ')
34
+ : baseSubtitle;
35
+ const resolvedBackLabel = backLabel ?? moduleConfig?.texts?.goBackToGrid ?? 'Volver';
36
+ const resolvedIcon = icon ??
37
+ (moduleConfig?.texts?.iconName && iconNameRenderer
38
+ ? iconNameRenderer(moduleConfig.texts.iconName)
39
+ : null);
40
+ const formDisabled = actions?.formDisabled ?? false;
41
+ const allowEdit = actions?.allowEdit ?? false;
42
+ const allowDelete = actions?.allowDelete ?? false;
43
+ const showDeleteWhenEditing = actions?.showDeleteWhenEditing ?? false;
44
+ const defaultActions = actions ? (_jsxs(Box, { sx: {
45
+ display: 'flex',
46
+ gap: 1,
47
+ flexWrap: 'wrap',
48
+ justifyContent: { xs: 'center', md: 'flex-end' },
49
+ alignItems: 'center',
50
+ width: { xs: '100%', md: 'auto' }
51
+ }, children: [!isNew && allowEdit && formDisabled && actions.onStartEdit ? (_jsx(JBButton, { action: "edit", size: "large", disabled: actions.disableEdit, startIcon: actions.editIcon, onClick: actions.onStartEdit, children: actions.editLabel ?? 'Editar' })) : null, (isNew || !formDisabled) && actions.onCancel ? (_jsx(JBButton, { action: "cancel", size: "large", disabled: actions.disableCancel, startIcon: actions.cancelIcon, onClick: actions.onCancel, children: actions.cancelLabel ?? 'Cancelar' })) : null, (isNew || !formDisabled) && actions.onSave ? (_jsx(JBButton, { action: "save", size: "large", disabled: actions.disableSave, startIcon: actions.saveIcon, onClick: actions.onSave, children: actions.saveLabel ?? (isNew ? 'Guardar' : 'Guardar cambios') })) : null, allowDelete &&
52
+ actions.onDelete &&
53
+ (formDisabled || showDeleteWhenEditing) ? (_jsx(JBButton, { action: "delete", size: "large", disabled: actions.disableDelete, startIcon: actions.deleteIcon, onClick: actions.onDelete, children: actions.deleteLabel ?? 'Eliminar' })) : null] })) : null;
54
+ const resolvedRightContent = rightContent ?? defaultActions;
55
+ const animateSx = (delayMs) => animated
56
+ ? {
57
+ animation: `jbHeaderFadeIn ${animationDurationMs}ms ease-out ${delayMs}ms both`
58
+ }
59
+ : undefined;
60
+ const animateFromLeftSx = (delayMs) => animated && animationPreset === 'sides'
61
+ ? {
62
+ animation: `jbHeaderFadeInLeft ${animationDurationMs}ms ease-out ${delayMs}ms both`
63
+ }
64
+ : animateSx(delayMs);
65
+ const animateFromRightSx = (delayMs) => animated && animationPreset === 'sides'
66
+ ? {
67
+ animation: `jbHeaderFadeInRight ${animationDurationMs}ms ease-out ${delayMs}ms both`
68
+ }
69
+ : animateSx(delayMs);
70
+ return (_jsxs(Box, { sx: {
71
+ width: '100%',
72
+ display: 'flex',
73
+ flexDirection: 'column',
74
+ gap: 2,
75
+ p: { xs: 2, sm: 3 },
76
+ '@keyframes jbHeaderFadeIn': {
77
+ from: { opacity: 0, transform: 'translateY(10px)' },
78
+ to: { opacity: 1, transform: 'translateY(0)' }
79
+ },
80
+ '@keyframes jbHeaderFadeInLeft': {
81
+ from: { opacity: 0, transform: 'translateX(-16px)' },
82
+ to: { opacity: 1, transform: 'translateX(0)' }
83
+ },
84
+ '@keyframes jbHeaderFadeInRight': {
85
+ from: { opacity: 0, transform: 'translateX(16px)' },
86
+ to: { opacity: 1, transform: 'translateX(0)' }
87
+ }
88
+ }, children: [breadcrumb ? _jsx(Box, { sx: animateSx(0), children: breadcrumb }) : null, backContent ? _jsx(Box, { sx: animateSx(animationStaggerMs), children: backContent }) : null, showBackButton && onBackClick ? (_jsx(Typography, { role: "button", color: "text.primary", sx: {
89
+ display: 'inline-flex',
90
+ alignItems: 'center',
91
+ gap: 0.75,
92
+ width: 'fit-content',
93
+ alignSelf: { xs: 'center', md: 'flex-start' },
94
+ fontWeight: 500,
95
+ fontSize: { xs: '0.95rem', md: '1rem' },
96
+ cursor: 'pointer',
97
+ opacity: 0.9,
98
+ transition: 'all .16s ease',
99
+ '&:hover': { opacity: 1, color: 'primary.main' },
100
+ ...animateSx(animationStaggerMs * 2)
101
+ }, onClick: onBackClick, children: `← ${resolvedBackLabel}` })) : null, _jsxs(Box, { sx: {
102
+ display: { xs: 'flex', md: 'grid' },
103
+ flexDirection: { xs: 'column', md: 'row' },
104
+ gridTemplateColumns: { md: 'minmax(0, 1fr) auto' },
105
+ alignItems: { xs: 'center', md: 'center' },
106
+ width: '100%',
107
+ gap: 2
108
+ }, children: [_jsxs(Box, { sx: {
109
+ display: 'flex',
110
+ alignItems: 'center',
111
+ justifyContent: { xs: 'center', md: 'flex-start' },
112
+ gap: 1.25,
113
+ minWidth: 0,
114
+ width: '100%',
115
+ ...animateFromLeftSx(animationStaggerMs * 3)
116
+ }, children: [resolvedIcon ? _jsx(Box, { sx: { display: 'inline-flex', alignItems: 'center' }, children: resolvedIcon }) : null, _jsxs(Box, { sx: { minWidth: 0, textAlign: { xs: 'center', md: 'left' } }, children: [_jsx(Typography, { variant: "h5", sx: { fontWeight: 700, lineHeight: 1.15 }, children: resolvedTitle }), resolvedSubtitle ? (_jsx(Typography, { variant: "body2", sx: (theme) => ({
117
+ mt: 0.4,
118
+ fontWeight: 500,
119
+ lineHeight: 1.1,
120
+ color: theme.palette.mode === 'dark'
121
+ ? alpha(theme.palette.common.white, 0.9)
122
+ : theme.palette.primary.dark
123
+ }), children: resolvedSubtitle })) : null] })] }), _jsx(Box, { sx: {
124
+ width: { xs: '100%', md: 'auto' },
125
+ display: 'flex',
126
+ justifySelf: { md: 'end' },
127
+ justifyContent: { xs: 'center', md: 'flex-end' },
128
+ alignItems: 'center',
129
+ ...animateFromRightSx(animationStaggerMs * 4)
130
+ }, children: resolvedRightContent })] })] }));
131
+ }
@@ -0,0 +1,3 @@
1
+ export * from './JBContentContainer';
2
+ export * from './JBFormHeader';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/layout/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,gBAAgB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export * from './JBContentContainer';
2
+ export * from './JBFormHeader';
@@ -0,0 +1,5 @@
1
+ export type JBFormContentSkeletonProps = {
2
+ fieldCount?: number;
3
+ };
4
+ export declare function JBFormContentSkeleton(props: JBFormContentSkeletonProps): import("react/jsx-runtime").JSX.Element;
5
+ //# sourceMappingURL=JBFormContentSkeleton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JBFormContentSkeleton.d.ts","sourceRoot":"","sources":["../../../src/core/skeletons/JBFormContentSkeleton.tsx"],"names":[],"mappings":"AAEA,MAAM,MAAM,0BAA0B,GAAG;IACvC,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,wBAAgB,qBAAqB,CAAC,KAAK,EAAE,0BAA0B,2CA8BtE"}
@@ -0,0 +1,12 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Skeleton } from '@mui/material';
3
+ export function JBFormContentSkeleton(props) {
4
+ const { fieldCount = 4 } = props;
5
+ const fields = Array.from({ length: fieldCount });
6
+ return (_jsx(Box, { sx: {
7
+ width: '100%',
8
+ display: 'flex',
9
+ flexDirection: 'column',
10
+ gap: 3
11
+ }, children: fields.map((_, index) => (_jsxs(Box, { sx: { display: 'flex', flexDirection: 'column', gap: 1 }, children: [_jsx(Skeleton, { variant: "text", width: 140, height: 24 }), _jsx(Skeleton, { variant: "rounded", width: "100%", height: 44 })] }, index))) }));
12
+ }
@@ -0,0 +1,6 @@
1
+ export type JBFormHeaderSkeletonProps = {
2
+ showBackLink?: boolean;
3
+ showActions?: boolean;
4
+ };
5
+ export declare function JBFormHeaderSkeleton(props: JBFormHeaderSkeletonProps): import("react/jsx-runtime").JSX.Element;
6
+ //# sourceMappingURL=JBFormHeaderSkeleton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JBFormHeaderSkeleton.d.ts","sourceRoot":"","sources":["../../../src/core/skeletons/JBFormHeaderSkeleton.tsx"],"names":[],"mappings":"AAEA,MAAM,MAAM,yBAAyB,GAAG;IACtC,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB,CAAC;AAEF,wBAAgB,oBAAoB,CAAC,KAAK,EAAE,yBAAyB,2CAwEpE"}
@@ -0,0 +1,19 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Box, Skeleton } from '@mui/material';
3
+ export function JBFormHeaderSkeleton(props) {
4
+ const { showBackLink = true, showActions = true } = props;
5
+ return (_jsxs(Box, { sx: {
6
+ width: '100%',
7
+ display: 'flex',
8
+ flexDirection: 'column',
9
+ gap: 2,
10
+ p: { xs: 2, sm: 3 }
11
+ }, children: [_jsx(Skeleton, { variant: "rounded", width: 300, height: 28 }), showBackLink ? (_jsx(Skeleton, { variant: "text", width: 170, height: 30 })) : null, _jsxs(Box, { sx: {
12
+ display: { xs: 'flex', sm: 'grid' },
13
+ flexDirection: { xs: 'column', sm: 'row' },
14
+ gridTemplateColumns: { sm: 'minmax(0, 1fr) auto' },
15
+ alignItems: { xs: 'stretch', sm: 'center' },
16
+ width: '100%',
17
+ gap: 2
18
+ }, children: [_jsxs(Box, { sx: { display: 'flex', alignItems: 'center', gap: 1.25, minWidth: 0 }, children: [_jsx(Skeleton, { variant: "circular", width: 30, height: 30 }), _jsxs(Box, { sx: { minWidth: 0 }, children: [_jsx(Skeleton, { variant: "text", width: 280, height: 52 }), _jsx(Skeleton, { variant: "text", width: 240, height: 30 })] })] }), showActions ? (_jsxs(Box, { sx: { display: 'flex', gap: 1, justifySelf: { sm: 'end' } }, children: [_jsx(Skeleton, { variant: "rounded", width: 116, height: 42 }), _jsx(Skeleton, { variant: "rounded", width: 116, height: 42 })] })) : null] })] }));
19
+ }
@@ -0,0 +1,3 @@
1
+ export * from './JBFormHeaderSkeleton';
2
+ export * from './JBFormContentSkeleton';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/skeletons/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAC;AACvC,cAAc,yBAAyB,CAAC"}