@datatechsolutions/ui 3.8.0 → 3.9.0

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 (97) hide show
  1. package/dist/astrlabe/index.js +107 -107
  2. package/dist/astrlabe/index.mjs +3 -3
  3. package/dist/astrlabe/workflow-canvas.js +3 -3
  4. package/dist/astrlabe/workflow-canvas.mjs +2 -2
  5. package/dist/{chunk-KKXI7CPF.mjs → chunk-2E7HYTS7.mjs} +3 -3
  6. package/dist/{chunk-KKXI7CPF.mjs.map → chunk-2E7HYTS7.mjs.map} +1 -1
  7. package/dist/{chunk-EWYAM4WJ.mjs → chunk-2ZY3IQ2I.mjs} +3 -3
  8. package/dist/{chunk-EWYAM4WJ.mjs.map → chunk-2ZY3IQ2I.mjs.map} +1 -1
  9. package/dist/{chunk-VPFVW7ZF.js → chunk-6E2YH67A.js} +35 -35
  10. package/dist/{chunk-VPFVW7ZF.js.map → chunk-6E2YH67A.js.map} +1 -1
  11. package/dist/{chunk-A4A3SQTV.mjs → chunk-6QJI5YOJ.mjs} +3 -3
  12. package/dist/{chunk-A4A3SQTV.mjs.map → chunk-6QJI5YOJ.mjs.map} +1 -1
  13. package/dist/{chunk-3X3IYDG6.js → chunk-7AM2SXEF.js} +68 -68
  14. package/dist/{chunk-3X3IYDG6.js.map → chunk-7AM2SXEF.js.map} +1 -1
  15. package/dist/{chunk-H37VDL7Y.js → chunk-A2RIX2RK.js} +4 -4
  16. package/dist/{chunk-H37VDL7Y.js.map → chunk-A2RIX2RK.js.map} +1 -1
  17. package/dist/{chunk-32DHEVOH.mjs → chunk-ARLYOLSO.mjs} +3 -3
  18. package/dist/{chunk-32DHEVOH.mjs.map → chunk-ARLYOLSO.mjs.map} +1 -1
  19. package/dist/{chunk-5YVOLHSW.mjs → chunk-AXBD6OAF.mjs} +4 -4
  20. package/dist/{chunk-5YVOLHSW.mjs.map → chunk-AXBD6OAF.mjs.map} +1 -1
  21. package/dist/{chunk-ZP37M2QK.mjs → chunk-BWUFLW5W.mjs} +6 -6
  22. package/dist/{chunk-ZP37M2QK.mjs.map → chunk-BWUFLW5W.mjs.map} +1 -1
  23. package/dist/{chunk-HBOORO52.js → chunk-CLTNCBSP.js} +4 -4
  24. package/dist/{chunk-HBOORO52.js.map → chunk-CLTNCBSP.js.map} +1 -1
  25. package/dist/{chunk-F35GFICG.js → chunk-CRBGZA6Y.js} +13 -13
  26. package/dist/{chunk-F35GFICG.js.map → chunk-CRBGZA6Y.js.map} +1 -1
  27. package/dist/{chunk-7JZFNKJD.js → chunk-DQIEVLA3.js} +35 -35
  28. package/dist/{chunk-7JZFNKJD.js.map → chunk-DQIEVLA3.js.map} +1 -1
  29. package/dist/{chunk-57E4TCB2.mjs → chunk-EAIE4QGD.mjs} +3 -3
  30. package/dist/{chunk-57E4TCB2.mjs.map → chunk-EAIE4QGD.mjs.map} +1 -1
  31. package/dist/{chunk-5W6LMDXV.mjs → chunk-GQWC4EKE.mjs} +4 -4
  32. package/dist/{chunk-5W6LMDXV.mjs.map → chunk-GQWC4EKE.mjs.map} +1 -1
  33. package/dist/{chunk-FKUIVS6I.js → chunk-IVKFXPLO.js} +28 -28
  34. package/dist/{chunk-FKUIVS6I.js.map → chunk-IVKFXPLO.js.map} +1 -1
  35. package/dist/{chunk-FNA66TT4.js → chunk-MT66VKLS.js} +163 -219
  36. package/dist/chunk-MT66VKLS.js.map +1 -0
  37. package/dist/{chunk-74BU2EBZ.mjs → chunk-OEZ7GAJY.mjs} +6 -6
  38. package/dist/{chunk-74BU2EBZ.mjs.map → chunk-OEZ7GAJY.mjs.map} +1 -1
  39. package/dist/{chunk-CZZOCKEA.mjs → chunk-OVQ4MKCV.mjs} +3 -3
  40. package/dist/{chunk-CZZOCKEA.mjs.map → chunk-OVQ4MKCV.mjs.map} +1 -1
  41. package/dist/{chunk-WDBVIU7W.mjs → chunk-PD3JLDA5.mjs} +3 -3
  42. package/dist/{chunk-WDBVIU7W.mjs.map → chunk-PD3JLDA5.mjs.map} +1 -1
  43. package/dist/{chunk-TJPPZU77.js → chunk-R6GEJBFC.js} +34 -34
  44. package/dist/{chunk-TJPPZU77.js.map → chunk-R6GEJBFC.js.map} +1 -1
  45. package/dist/{chunk-Q4QORAMH.js → chunk-RFUSH7WD.js} +10 -10
  46. package/dist/{chunk-Q4QORAMH.js.map → chunk-RFUSH7WD.js.map} +1 -1
  47. package/dist/{chunk-VS6PTRQ7.mjs → chunk-SJ6SUS7H.mjs} +3 -3
  48. package/dist/{chunk-VS6PTRQ7.mjs.map → chunk-SJ6SUS7H.mjs.map} +1 -1
  49. package/dist/{chunk-E57RZXOR.js → chunk-T4IYOKHR.js} +25 -25
  50. package/dist/{chunk-E57RZXOR.js.map → chunk-T4IYOKHR.js.map} +1 -1
  51. package/dist/{chunk-3H5CFLVK.js → chunk-U6VFS3RD.js} +135 -135
  52. package/dist/{chunk-3H5CFLVK.js.map → chunk-U6VFS3RD.js.map} +1 -1
  53. package/dist/{chunk-RCHTRG7R.js → chunk-UZIICTIY.js} +55 -55
  54. package/dist/{chunk-RCHTRG7R.js.map → chunk-UZIICTIY.js.map} +1 -1
  55. package/dist/{chunk-TCP45Q4B.js → chunk-WJENX6KB.js} +9 -9
  56. package/dist/{chunk-TCP45Q4B.js.map → chunk-WJENX6KB.js.map} +1 -1
  57. package/dist/{chunk-PYNXIDG3.mjs → chunk-WS3IJFPW.mjs} +3 -3
  58. package/dist/{chunk-PYNXIDG3.mjs.map → chunk-WS3IJFPW.mjs.map} +1 -1
  59. package/dist/{chunk-Q7HRCCFT.js → chunk-ZDXEGSCF.js} +45 -45
  60. package/dist/{chunk-Q7HRCCFT.js.map → chunk-ZDXEGSCF.js.map} +1 -1
  61. package/dist/{chunk-PCUINUIC.mjs → chunk-ZQEMKEEH.mjs} +3 -3
  62. package/dist/{chunk-PCUINUIC.mjs.map → chunk-ZQEMKEEH.mjs.map} +1 -1
  63. package/dist/{chunk-E6C7MFHJ.mjs → chunk-ZQRUAXGP.mjs} +164 -218
  64. package/dist/chunk-ZQRUAXGP.mjs.map +1 -0
  65. package/dist/index.d.mts +43 -42
  66. package/dist/index.d.ts +43 -42
  67. package/dist/index.js +662 -670
  68. package/dist/index.mjs +1 -1
  69. package/dist/platform/admin/index.js +9 -9
  70. package/dist/platform/admin/index.mjs +3 -3
  71. package/dist/platform/agents-workspace.js +6 -6
  72. package/dist/platform/agents-workspace.mjs +5 -5
  73. package/dist/platform/app-shell.js +3 -3
  74. package/dist/platform/app-shell.mjs +2 -2
  75. package/dist/platform/auth/index.js +21 -21
  76. package/dist/platform/auth/index.mjs +3 -3
  77. package/dist/platform/billing/index.js +3 -3
  78. package/dist/platform/billing/index.mjs +2 -2
  79. package/dist/platform/impersonation/index.js +3 -3
  80. package/dist/platform/impersonation/index.mjs +2 -2
  81. package/dist/platform/index.d.mts +1 -1
  82. package/dist/platform/index.d.ts +1 -1
  83. package/dist/platform/index.js +74 -74
  84. package/dist/platform/index.mjs +17 -17
  85. package/dist/platform/pages/index.d.mts +93 -4
  86. package/dist/platform/pages/index.d.ts +93 -4
  87. package/dist/platform/pages/index.js +1009 -575
  88. package/dist/platform/pages/index.js.map +1 -1
  89. package/dist/platform/pages/index.mjs +805 -372
  90. package/dist/platform/pages/index.mjs.map +1 -1
  91. package/dist/platform/settings/index.js +6 -6
  92. package/dist/platform/settings/index.mjs +5 -5
  93. package/dist/platform/workflow-canvas-shell.js +4 -4
  94. package/dist/platform/workflow-canvas-shell.mjs +3 -3
  95. package/package.json +1 -1
  96. package/dist/chunk-E6C7MFHJ.mjs.map +0 -1
  97. package/dist/chunk-FNA66TT4.js.map +0 -1
@@ -3019,16 +3019,20 @@ function SearchBar({
3019
3019
  onRemoveFilter,
3020
3020
  onClearAll,
3021
3021
  endContent,
3022
+ actions,
3022
3023
  noBorder = false,
3023
3024
  showCancelButton = false,
3024
3025
  onCancel,
3025
- filterChipStyleConfig
3026
+ filterChipStyleConfig,
3027
+ filtersModal
3026
3028
  }) {
3027
3029
  const t = chunkYXN2K77G_js.useTranslations("common");
3028
3030
  const [isFocused, setIsFocused] = React9.useState(false);
3029
3031
  const inputRef = React9.useRef(null);
3030
3032
  const hasFilters = activeFilters.length > 0 || searchTerm.length > 0;
3031
3033
  const defaultPlaceholder = placeholder || t("searchPlaceholder");
3034
+ const filtersModalCount = filtersModal?.count ?? 0;
3035
+ const resolvedFiltersTitle = filtersModal?.title ?? t("filters");
3032
3036
  const handleFocus = React9.useCallback(() => {
3033
3037
  setIsFocused(true);
3034
3038
  chunkUZ3CMNUJ_js.triggerHaptic("light");
@@ -3051,85 +3055,166 @@ function SearchBar({
3051
3055
  const containerClasses = noBorder ? "flex flex-wrap items-center gap-2 p-3 bg-transparent" : `liquid-surface flex flex-wrap items-center gap-2 p-3 rounded-2xl
3052
3056
  transition-all duration-200
3053
3057
  ${isFocused ? "ring-2 ring-indigo-500/70 ring-offset-1" : ""}`;
3054
- return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex items-center gap-2", children: [
3055
- /* @__PURE__ */ jsxRuntime.jsxs(
3056
- framerMotion.motion.div,
3057
- {
3058
- className: containerClasses,
3059
- layout: true,
3060
- transition: { duration: 0.2 },
3061
- style: { flex: 1 },
3062
- children: [
3063
- /* @__PURE__ */ jsxRuntime.jsx(
3064
- ActiveFilterChips,
3065
- {
3066
- filters: activeFilters,
3067
- onRemoveFilter,
3068
- styleConfig: filterChipStyleConfig ?? defaultFilterTypeConfig
3069
- }
3070
- ),
3071
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex-1 min-w-[200px] relative", children: [
3072
- /* @__PURE__ */ jsxRuntime.jsx(
3073
- HeroIcons.MagnifyingGlassIcon,
3074
- {
3075
- className: `absolute left-3 top-1/2 -translate-y-1/2 h-5 w-5 transition-colors duration-200
3076
- ${isFocused ? "text-indigo-600 dark:text-indigo-400" : "text-slate-400"}`
3077
- }
3078
- ),
3058
+ return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
3059
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { role: "search", "data-testid": "search-toolbar", className: "flex items-center gap-2", children: [
3060
+ /* @__PURE__ */ jsxRuntime.jsxs(
3061
+ framerMotion.motion.div,
3062
+ {
3063
+ className: containerClasses,
3064
+ layout: true,
3065
+ transition: { duration: 0.2 },
3066
+ style: { flex: 1 },
3067
+ children: [
3079
3068
  /* @__PURE__ */ jsxRuntime.jsx(
3080
- "input",
3069
+ ActiveFilterChips,
3081
3070
  {
3082
- ref: inputRef,
3083
- type: "text",
3084
- placeholder: activeFilters.length > 0 ? t("refineSearch") : defaultPlaceholder,
3085
- value: searchTerm,
3086
- onChange: (e) => onSearchChange(e.target.value),
3087
- onFocus: handleFocus,
3088
- onBlur: handleBlur,
3089
- className: "w-full h-11 pl-10 pr-10 text-base bg-transparent\n text-slate-900 dark:text-white\n placeholder:text-slate-400 dark:placeholder:text-slate-500\n focus:outline-none"
3071
+ filters: activeFilters,
3072
+ onRemoveFilter,
3073
+ styleConfig: filterChipStyleConfig ?? defaultFilterTypeConfig
3090
3074
  }
3091
3075
  ),
3092
- /* @__PURE__ */ jsxRuntime.jsx(framerMotion.AnimatePresence, { children: searchTerm && /* @__PURE__ */ jsxRuntime.jsx(
3093
- framerMotion.motion.button,
3076
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex-1 min-w-[200px] relative", children: [
3077
+ /* @__PURE__ */ jsxRuntime.jsx(
3078
+ HeroIcons.MagnifyingGlassIcon,
3079
+ {
3080
+ className: `absolute left-3 top-1/2 -translate-y-1/2 h-5 w-5 transition-colors duration-200
3081
+ ${isFocused ? "text-indigo-600 dark:text-indigo-400" : "text-slate-400"}`
3082
+ }
3083
+ ),
3084
+ /* @__PURE__ */ jsxRuntime.jsx(
3085
+ "input",
3086
+ {
3087
+ ref: inputRef,
3088
+ type: "text",
3089
+ placeholder: activeFilters.length > 0 ? t("refineSearch") : defaultPlaceholder,
3090
+ value: searchTerm,
3091
+ onChange: (e) => onSearchChange(e.target.value),
3092
+ onFocus: handleFocus,
3093
+ onBlur: handleBlur,
3094
+ "data-testid": "search-input",
3095
+ className: "w-full h-11 pl-10 pr-10 text-base bg-transparent\n text-slate-900 dark:text-white\n placeholder:text-slate-400 dark:placeholder:text-slate-500\n focus:outline-none"
3096
+ }
3097
+ ),
3098
+ /* @__PURE__ */ jsxRuntime.jsx(framerMotion.AnimatePresence, { children: searchTerm && /* @__PURE__ */ jsxRuntime.jsx(
3099
+ framerMotion.motion.button,
3100
+ {
3101
+ initial: { opacity: 0, scale: 0.8 },
3102
+ animate: { opacity: 1, scale: 1 },
3103
+ exit: { opacity: 0, scale: 0.8 },
3104
+ transition: { duration: 0.15 },
3105
+ onClick: handleClear,
3106
+ className: "absolute right-2 top-1/2 -translate-y-1/2 p-1.5 rounded-full\n bg-white/40 dark:bg-white/[0.08]\n text-slate-500 dark:text-slate-300\n hover:bg-white/60 dark:hover:bg-white/[0.12]\n transition-colors",
3107
+ children: /* @__PURE__ */ jsxRuntime.jsx(HeroIcons.XMarkIcon, { className: "h-4 w-4" })
3108
+ }
3109
+ ) })
3110
+ ] }),
3111
+ endContent,
3112
+ hasFilters && onClearAll && !showCancelButton && /* @__PURE__ */ jsxRuntime.jsx(
3113
+ "button",
3094
3114
  {
3095
- initial: { opacity: 0, scale: 0.8 },
3096
- animate: { opacity: 1, scale: 1 },
3097
- exit: { opacity: 0, scale: 0.8 },
3098
- transition: { duration: 0.15 },
3099
- onClick: handleClear,
3100
- className: "absolute right-2 top-1/2 -translate-y-1/2 p-1.5 rounded-full\n bg-white/40 dark:bg-white/[0.08]\n text-slate-500 dark:text-slate-300\n hover:bg-white/60 dark:hover:bg-white/[0.12]\n transition-colors",
3101
- children: /* @__PURE__ */ jsxRuntime.jsx(HeroIcons.XMarkIcon, { className: "h-4 w-4" })
3115
+ onClick: () => {
3116
+ chunkUZ3CMNUJ_js.triggerHaptic("light");
3117
+ onClearAll();
3118
+ },
3119
+ className: "p-2 rounded-xl text-slate-400 hover:text-slate-600 dark:hover:text-white\n hover:bg-white/40 dark:hover:bg-white/[0.08] transition-colors",
3120
+ title: t("clearFilters"),
3121
+ children: /* @__PURE__ */ jsxRuntime.jsx(HeroIcons.XMarkIcon, { className: "h-5 w-5" })
3102
3122
  }
3103
- ) })
3104
- ] }),
3105
- endContent,
3106
- hasFilters && onClearAll && !showCancelButton && /* @__PURE__ */ jsxRuntime.jsx(
3107
- "button",
3108
- {
3109
- onClick: () => {
3110
- chunkUZ3CMNUJ_js.triggerHaptic("light");
3111
- onClearAll();
3112
- },
3113
- className: "p-2 rounded-xl text-slate-400 hover:text-slate-600 dark:hover:text-white\n hover:bg-white/40 dark:hover:bg-white/[0.08] transition-colors",
3114
- title: t("clearFilters"),
3115
- children: /* @__PURE__ */ jsxRuntime.jsx(HeroIcons.XMarkIcon, { className: "h-5 w-5" })
3116
- }
3117
- )
3118
- ]
3119
- }
3120
- ),
3121
- /* @__PURE__ */ jsxRuntime.jsx(framerMotion.AnimatePresence, { children: showCancelButton && isFocused && /* @__PURE__ */ jsxRuntime.jsx(
3122
- framerMotion.motion.button,
3123
- {
3124
- initial: { opacity: 0, x: -10, width: 0 },
3125
- animate: { opacity: 1, x: 0, width: "auto" },
3126
- exit: { opacity: 0, x: -10, width: 0 },
3127
- transition: { duration: 0.2 },
3128
- onClick: handleCancel,
3129
- className: "text-indigo-600 dark:text-indigo-400 font-medium whitespace-nowrap px-2",
3130
- children: t("cancel")
3131
- }
3132
- ) })
3123
+ )
3124
+ ]
3125
+ }
3126
+ ),
3127
+ filtersModal && /* @__PURE__ */ jsxRuntime.jsxs(
3128
+ chunkBHOT22QL_js.Button,
3129
+ {
3130
+ type: "button",
3131
+ onClick: filtersModal.onOpen,
3132
+ outline: true,
3133
+ className: "h-12",
3134
+ children: [
3135
+ /* @__PURE__ */ jsxRuntime.jsx(HeroIcons.FunnelIcon, { className: "h-4 w-4" }),
3136
+ /* @__PURE__ */ jsxRuntime.jsx("span", { children: resolvedFiltersTitle }),
3137
+ filtersModalCount > 0 && /* @__PURE__ */ jsxRuntime.jsx("span", { className: "rounded-full bg-blue-500 px-1.5 py-0.5 text-[10px] font-bold text-white", children: filtersModalCount })
3138
+ ]
3139
+ }
3140
+ ),
3141
+ actions,
3142
+ /* @__PURE__ */ jsxRuntime.jsx(framerMotion.AnimatePresence, { children: showCancelButton && isFocused && /* @__PURE__ */ jsxRuntime.jsx(
3143
+ framerMotion.motion.button,
3144
+ {
3145
+ initial: { opacity: 0, x: -10, width: 0 },
3146
+ animate: { opacity: 1, x: 0, width: "auto" },
3147
+ exit: { opacity: 0, x: -10, width: 0 },
3148
+ transition: { duration: 0.2 },
3149
+ onClick: handleCancel,
3150
+ className: "text-indigo-600 dark:text-indigo-400 font-medium whitespace-nowrap px-2",
3151
+ children: t("cancel")
3152
+ }
3153
+ ) })
3154
+ ] }),
3155
+ filtersModal && /* @__PURE__ */ jsxRuntime.jsx(Headless3.Transition, { show: filtersModal.open, as: React9.Fragment, children: /* @__PURE__ */ jsxRuntime.jsxs(Headless3.Dialog, { as: "div", className: "relative z-50", onClose: filtersModal.onClose, children: [
3156
+ /* @__PURE__ */ jsxRuntime.jsx(
3157
+ Headless3.TransitionChild,
3158
+ {
3159
+ as: React9.Fragment,
3160
+ enter: "ease-out duration-200",
3161
+ enterFrom: "opacity-0",
3162
+ enterTo: "opacity-100",
3163
+ leave: "ease-in duration-150",
3164
+ leaveFrom: "opacity-100",
3165
+ leaveTo: "opacity-0",
3166
+ children: /* @__PURE__ */ jsxRuntime.jsx(Headless3.DialogBackdrop, { className: "fixed inset-0 bg-slate-900/35 backdrop-blur-md" })
3167
+ }
3168
+ ),
3169
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: "fixed inset-0 overflow-y-auto p-3 sm:p-6", children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "mx-auto flex min-h-full max-w-2xl items-start justify-center pt-[8vh]", children: /* @__PURE__ */ jsxRuntime.jsx(
3170
+ Headless3.TransitionChild,
3171
+ {
3172
+ as: React9.Fragment,
3173
+ enter: "ease-out duration-250",
3174
+ enterFrom: "opacity-0 scale-95",
3175
+ enterTo: "opacity-100 scale-100",
3176
+ leave: "ease-in duration-180",
3177
+ leaveFrom: "opacity-100 scale-100",
3178
+ leaveTo: "opacity-0 scale-95",
3179
+ children: /* @__PURE__ */ jsxRuntime.jsxs(Headless3.DialogPanel, { className: "liquid-surface-strong w-full overflow-hidden rounded-2xl", children: [
3180
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "border-b liquid-divider px-5 py-4", children: [
3181
+ filtersModal.context ? /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "mb-2 flex items-center gap-2 text-slate-600 dark:text-white/70", children: [
3182
+ /* @__PURE__ */ jsxRuntime.jsx("span", { children: filtersModal.context.icon ?? /* @__PURE__ */ jsxRuntime.jsx(HeroIcons.FunnelIcon, { className: "h-3.5 w-3.5" }) }),
3183
+ /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-sm font-medium", children: filtersModal.context.label }),
3184
+ filtersModal.context.countLabel ? /* @__PURE__ */ jsxRuntime.jsxs("span", { className: "text-xs text-slate-400 dark:text-white/50", children: [
3185
+ "\xB7 ",
3186
+ filtersModal.context.countLabel
3187
+ ] }) : null
3188
+ ] }) : null,
3189
+ /* @__PURE__ */ jsxRuntime.jsx("h3", { className: "text-lg font-semibold tracking-tight text-slate-900 dark:text-slate-100", children: resolvedFiltersTitle })
3190
+ ] }),
3191
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: "max-h-[72vh] overflow-y-auto p-4 sm:p-5", children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "space-y-6", children: filtersModal.children }) }),
3192
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex items-center justify-end gap-2 border-t liquid-divider p-4", children: [
3193
+ filtersModal.onClear && filtersModalCount > 0 && /* @__PURE__ */ jsxRuntime.jsx(
3194
+ chunkBHOT22QL_js.Button,
3195
+ {
3196
+ type: "button",
3197
+ onClick: filtersModal.onClear,
3198
+ outline: true,
3199
+ size: "sm",
3200
+ children: t("clearFilters")
3201
+ }
3202
+ ),
3203
+ /* @__PURE__ */ jsxRuntime.jsx(
3204
+ chunkBHOT22QL_js.Button,
3205
+ {
3206
+ type: "button",
3207
+ onClick: filtersModal.onClose,
3208
+ color: "ios-glass-blue",
3209
+ size: "sm",
3210
+ children: t("done")
3211
+ }
3212
+ )
3213
+ ] })
3214
+ ] })
3215
+ }
3216
+ ) }) })
3217
+ ] }) })
3133
3218
  ] });
3134
3219
  }
3135
3220
  function InfoPopover({ title, content, triggerLabel = "Info" }) {
@@ -6404,7 +6489,7 @@ var sizes2 = {
6404
6489
  "4xl": "sm:max-w-4xl",
6405
6490
  "5xl": "sm:max-w-5xl"
6406
6491
  };
6407
- function Dialog4({
6492
+ function Dialog5({
6408
6493
  size = "lg",
6409
6494
  className,
6410
6495
  children,
@@ -7875,128 +7960,6 @@ function StepNavigationButtons({
7875
7960
  )
7876
7961
  ] });
7877
7962
  }
7878
- function SearchFilterToolbar({
7879
- label,
7880
- query,
7881
- onQueryChange,
7882
- placeholder,
7883
- filtersOpen = false,
7884
- onOpenFilters,
7885
- onCloseFilters,
7886
- filtersTitle,
7887
- activeFiltersCount = 0,
7888
- onClearFilters,
7889
- actions,
7890
- filterPills,
7891
- filtersContext,
7892
- filtersHeaderIcon,
7893
- children
7894
- }) {
7895
- const tCommon = chunkYXN2K77G_js.useTranslations("common");
7896
- const resolvedFiltersTitle = filtersTitle || tCommon("filters");
7897
- const resolvedFiltersContext = filtersContext ?? {
7898
- icon: filtersHeaderIcon ?? /* @__PURE__ */ jsxRuntime.jsx(HeroIcons.FunnelIcon, { className: "h-3.5 w-3.5" }),
7899
- label
7900
- };
7901
- return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
7902
- /* @__PURE__ */ jsxRuntime.jsxs("div", { role: "search", "data-testid": "search-toolbar", className: "flex items-center gap-3", children: [
7903
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "liquid-surface flex flex-1 items-center gap-2 flex-wrap min-h-12 rounded-xl px-3.5 py-1.5 transition-colors duration-200 focus-within:ring-2 focus-within:ring-offset-2 focus-within:ring-indigo-500/70 dark:focus-within:ring-offset-gray-900", children: [
7904
- /* @__PURE__ */ jsxRuntime.jsx(HeroIcons.MagnifyingGlassIcon, { className: "h-5 w-5 shrink-0 text-slate-400 dark:text-slate-500" }),
7905
- filterPills,
7906
- /* @__PURE__ */ jsxRuntime.jsx(
7907
- "input",
7908
- {
7909
- type: "text",
7910
- value: query,
7911
- onChange: (event) => onQueryChange(event.target.value),
7912
- placeholder,
7913
- "aria-label": label,
7914
- "data-testid": "search-input",
7915
- className: "min-w-[100px] flex-1 bg-transparent py-1 text-base text-gray-900 outline-none focus-visible:ring-2 focus-visible:ring-indigo-500/70 placeholder:text-slate-400 dark:text-white dark:placeholder:text-slate-500"
7916
- }
7917
- )
7918
- ] }),
7919
- !!children && onOpenFilters && /* @__PURE__ */ jsxRuntime.jsxs(
7920
- chunkBHOT22QL_js.Button,
7921
- {
7922
- type: "button",
7923
- onClick: onOpenFilters,
7924
- outline: true,
7925
- className: "h-12",
7926
- children: [
7927
- /* @__PURE__ */ jsxRuntime.jsx(HeroIcons.FunnelIcon, { className: "h-4 w-4" }),
7928
- /* @__PURE__ */ jsxRuntime.jsx("span", { children: tCommon("filters") }),
7929
- activeFiltersCount > 0 && /* @__PURE__ */ jsxRuntime.jsx("span", { className: "rounded-full bg-blue-500 px-1.5 py-0.5 text-[10px] font-bold text-white", children: activeFiltersCount })
7930
- ]
7931
- }
7932
- ),
7933
- actions
7934
- ] }),
7935
- !!children && onCloseFilters && /* @__PURE__ */ jsxRuntime.jsx(Headless3.Transition, { show: filtersOpen, as: React9.Fragment, children: /* @__PURE__ */ jsxRuntime.jsxs(Headless3.Dialog, { as: "div", className: "relative z-50", onClose: onCloseFilters, children: [
7936
- /* @__PURE__ */ jsxRuntime.jsx(
7937
- Headless3.TransitionChild,
7938
- {
7939
- as: React9.Fragment,
7940
- enter: "ease-out duration-200",
7941
- enterFrom: "opacity-0",
7942
- enterTo: "opacity-100",
7943
- leave: "ease-in duration-150",
7944
- leaveFrom: "opacity-100",
7945
- leaveTo: "opacity-0",
7946
- children: /* @__PURE__ */ jsxRuntime.jsx(Headless3.DialogBackdrop, { className: "fixed inset-0 bg-slate-900/35 backdrop-blur-md" })
7947
- }
7948
- ),
7949
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: "fixed inset-0 overflow-y-auto p-3 sm:p-6", children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "mx-auto flex min-h-full max-w-2xl items-start justify-center pt-[8vh]", children: /* @__PURE__ */ jsxRuntime.jsx(
7950
- Headless3.TransitionChild,
7951
- {
7952
- as: React9.Fragment,
7953
- enter: "ease-out duration-250",
7954
- enterFrom: "opacity-0 scale-95",
7955
- enterTo: "opacity-100 scale-100",
7956
- leave: "ease-in duration-180",
7957
- leaveFrom: "opacity-100 scale-100",
7958
- leaveTo: "opacity-0 scale-95",
7959
- children: /* @__PURE__ */ jsxRuntime.jsxs(Headless3.DialogPanel, { className: "liquid-surface-strong w-full overflow-hidden rounded-2xl", children: [
7960
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "border-b border-white/30 px-5 py-4 dark:border-white/10", children: [
7961
- resolvedFiltersContext ? /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "mb-2 flex items-center gap-2 text-slate-600 dark:text-white/70", children: [
7962
- /* @__PURE__ */ jsxRuntime.jsx("span", { children: resolvedFiltersContext.icon }),
7963
- /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-sm font-medium", children: resolvedFiltersContext.label }),
7964
- resolvedFiltersContext.countLabel ? /* @__PURE__ */ jsxRuntime.jsxs("span", { className: "text-xs text-slate-400 dark:text-white/50", children: [
7965
- "\xB7 ",
7966
- resolvedFiltersContext.countLabel
7967
- ] }) : null
7968
- ] }) : null,
7969
- /* @__PURE__ */ jsxRuntime.jsx("h3", { className: "text-lg font-semibold tracking-tight text-slate-900 dark:text-slate-100", children: resolvedFiltersTitle })
7970
- ] }),
7971
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: "max-h-[72vh] overflow-y-auto p-4 sm:p-5", children: /* @__PURE__ */ jsxRuntime.jsx("div", { className: "space-y-6", children }) }),
7972
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex items-center justify-end gap-2 border-t border-white/30 p-4 dark:border-white/10", children: [
7973
- onClearFilters && activeFiltersCount > 0 && /* @__PURE__ */ jsxRuntime.jsx(
7974
- chunkBHOT22QL_js.Button,
7975
- {
7976
- type: "button",
7977
- onClick: onClearFilters,
7978
- outline: true,
7979
- size: "sm",
7980
- children: tCommon("clearFilters")
7981
- }
7982
- ),
7983
- /* @__PURE__ */ jsxRuntime.jsx(
7984
- chunkBHOT22QL_js.Button,
7985
- {
7986
- type: "button",
7987
- onClick: onCloseFilters,
7988
- color: "ios-glass-blue",
7989
- size: "sm",
7990
- children: tCommon("done")
7991
- }
7992
- )
7993
- ] })
7994
- ] })
7995
- }
7996
- ) }) })
7997
- ] }) })
7998
- ] });
7999
- }
8000
7963
  var COLOR_MAP = {
8001
7964
  blue: {
8002
7965
  activeGradient: "bg-gradient-to-br from-blue-500 to-blue-600 ring-2 ring-indigo-500/70 shadow-lg",
@@ -9767,23 +9730,6 @@ function ManagementSurface({ children, className = "", ...props }) {
9767
9730
  }
9768
9731
  );
9769
9732
  }
9770
- function ManagementPageLayout({
9771
- hero,
9772
- summary,
9773
- content,
9774
- mobileAction,
9775
- children,
9776
- testId,
9777
- className
9778
- }) {
9779
- return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: className ?? "space-y-4", "data-testid": testId, children: [
9780
- hero,
9781
- summary,
9782
- content,
9783
- mobileAction,
9784
- children
9785
- ] });
9786
- }
9787
9733
  var dateFnsLocales2 = {
9788
9734
  "pt-BR": locale.ptBR,
9789
9735
  "en": locale.enUS,
@@ -20109,7 +20055,7 @@ exports.DeleteSwipeAction = DeleteSwipeAction;
20109
20055
  exports.Description = Description3;
20110
20056
  exports.DetailsPopover = DetailsPopover;
20111
20057
  exports.DevModeBanner = DevModeBanner;
20112
- exports.Dialog = Dialog4;
20058
+ exports.Dialog = Dialog5;
20113
20059
  exports.DialogActions = DialogActions;
20114
20060
  exports.DialogBody = DialogBody;
20115
20061
  exports.DialogDescription = DialogDescription;
@@ -20237,7 +20183,6 @@ exports.MEXICO_MAP_CENTER = MEXICO_MAP_CENTER;
20237
20183
  exports.MEXICO_STATE_COORDINATES = MEXICO_STATE_COORDINATES;
20238
20184
  exports.MEXICO_STATE_PALETTES = MEXICO_STATE_PALETTES;
20239
20185
  exports.MX_THEME_CONFIG = MX_THEME_CONFIG;
20240
- exports.ManagementPageLayout = ManagementPageLayout;
20241
20186
  exports.ManagementSurface = ManagementSurface;
20242
20187
  exports.MapZoomControls = MapZoomControls;
20243
20188
  exports.MarketPricesCard = MarketPricesCard;
@@ -20354,7 +20299,6 @@ exports.SafeArea = SafeArea;
20354
20299
  exports.SafeAreaSpacer = SafeAreaSpacer;
20355
20300
  exports.SafeAreaView = SafeAreaView;
20356
20301
  exports.SearchBar = SearchBar;
20357
- exports.SearchFilterToolbar = SearchFilterToolbar;
20358
20302
  exports.SearchInput = SearchInput;
20359
20303
  exports.SectionCard = SectionCard;
20360
20304
  exports.SectionHeader = SectionHeader;
@@ -20684,5 +20628,5 @@ exports.useSocialProviders = useSocialProviders;
20684
20628
  exports.validateDashboardSpec = validateDashboardSpec;
20685
20629
  exports.xScale = xScale;
20686
20630
  exports.yScale = yScale;
20687
- //# sourceMappingURL=chunk-FNA66TT4.js.map
20688
- //# sourceMappingURL=chunk-FNA66TT4.js.map
20631
+ //# sourceMappingURL=chunk-MT66VKLS.js.map
20632
+ //# sourceMappingURL=chunk-MT66VKLS.js.map