@godxjp/ui 5.0.2 → 6.0.1

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 (242) hide show
  1. package/README.md +101 -142
  2. package/dist/app/index.d.ts +140 -0
  3. package/dist/app/index.js +38 -0
  4. package/dist/app.prop-IobwLwaM.d.ts +90 -0
  5. package/dist/checkbox-NkFkqsQ8.d.ts +13 -0
  6. package/dist/chunk-2XW7J3EI.js +226 -0
  7. package/dist/chunk-3F2AKYRD.js +416 -0
  8. package/dist/chunk-3KPEZ5CF.js +37 -0
  9. package/dist/chunk-3UGU5TYP.js +89 -0
  10. package/dist/chunk-6RA3KSVK.js +588 -0
  11. package/dist/chunk-7NZFVD24.js +122 -0
  12. package/dist/chunk-7PWBC4BY.js +25 -0
  13. package/dist/chunk-7S7MYFXE.js +61 -0
  14. package/dist/chunk-7WRZG2IG.js +71 -0
  15. package/dist/chunk-B775Y6BE.js +1 -0
  16. package/dist/chunk-BHV2FUOA.js +111 -0
  17. package/dist/chunk-BI3HERR7.js +70 -0
  18. package/dist/chunk-BPSKQUL2.js +68 -0
  19. package/dist/chunk-CDWPQ5RP.js +187 -0
  20. package/dist/chunk-CP2LET6N.js +244 -0
  21. package/dist/chunk-CQBADMFG.js +20 -0
  22. package/dist/chunk-CRERCLIZ.js +33 -0
  23. package/dist/chunk-DU6ZYZRP.js +238 -0
  24. package/dist/chunk-DY5C44UP.js +55 -0
  25. package/dist/chunk-E4HJNQ62.js +117 -0
  26. package/dist/chunk-E76QIYSY.js +93 -0
  27. package/dist/chunk-F7PG4OEV.js +37 -0
  28. package/dist/chunk-GDSVW62T.js +171 -0
  29. package/dist/chunk-H2FHJOLU.js +178 -0
  30. package/dist/chunk-HJEBRCXL.js +55 -0
  31. package/dist/chunk-ICM6XBST.js +16 -0
  32. package/dist/chunk-IK7I3ABN.js +88 -0
  33. package/dist/chunk-L6J44O74.js +144 -0
  34. package/dist/chunk-LDSLS6HE.js +1 -0
  35. package/dist/chunk-LVNUHUEZ.js +191 -0
  36. package/dist/chunk-M64MVRLS.js +92 -0
  37. package/dist/chunk-NGQW3KEM.js +402 -0
  38. package/dist/chunk-NZ4FOC5N.js +559 -0
  39. package/dist/chunk-PIIRNAXA.js +26 -0
  40. package/dist/chunk-S66TJXJU.js +33 -0
  41. package/dist/chunk-SMLKNECP.js +133 -0
  42. package/dist/chunk-TAHBM3F2.js +66 -0
  43. package/dist/chunk-TO33OY4L.js +150 -0
  44. package/dist/chunk-TO7URV7U.js +51 -0
  45. package/dist/chunk-TOO5AEKL.js +81 -0
  46. package/dist/chunk-U3GHAOIJ.js +299 -0
  47. package/dist/chunk-U7N2A7A3.js +9 -0
  48. package/dist/chunk-UX634MYF.js +123 -0
  49. package/dist/chunk-V6UWJKZF.js +28 -0
  50. package/dist/chunk-VOHTRR5X.js +28 -0
  51. package/dist/chunk-WRFKVUPW.js +332 -0
  52. package/dist/chunk-WXW43RK5.js +24 -0
  53. package/dist/chunk-XG7XDYIM.js +60 -0
  54. package/dist/chunk-YFCQKO3B.js +842 -0
  55. package/dist/chunk-ZDWXGWLY.js +73 -0
  56. package/dist/chunk-ZLK5SPT6.js +11 -0
  57. package/dist/chunk-ZS6DTAM2.js +31 -0
  58. package/dist/chunk-ZT5UEUBO.js +1 -0
  59. package/dist/components/admin/index.d.ts +80 -0
  60. package/dist/components/admin/index.js +38 -0
  61. package/dist/components/data-display/badge.d.ts +12 -0
  62. package/dist/components/data-display/badge.js +3 -0
  63. package/dist/components/data-display/card.d.ts +87 -0
  64. package/dist/components/data-display/card.js +2 -0
  65. package/dist/components/data-display/index.d.ts +72 -0
  66. package/dist/components/data-display/index.js +89 -0
  67. package/dist/components/data-display/popover.d.ts +13 -0
  68. package/dist/components/data-display/popover.js +2 -0
  69. package/dist/components/data-display/scroll-area.d.ts +7 -0
  70. package/dist/components/data-display/scroll-area.js +2 -0
  71. package/dist/components/data-display/table.d.ts +10 -0
  72. package/dist/components/data-display/table.js +3 -0
  73. package/dist/components/data-entry/autocomplete.d.ts +16 -0
  74. package/dist/components/data-entry/autocomplete.js +8 -0
  75. package/dist/components/data-entry/calendar.d.ts +16 -0
  76. package/dist/components/data-entry/calendar.js +4 -0
  77. package/dist/components/data-entry/cascader.d.ts +32 -0
  78. package/dist/components/data-entry/cascader.js +13 -0
  79. package/dist/components/data-entry/checkbox.d.ts +13 -0
  80. package/dist/components/data-entry/checkbox.js +4 -0
  81. package/dist/components/data-entry/color-picker.d.ts +16 -0
  82. package/dist/components/data-entry/color-picker.js +6 -0
  83. package/dist/components/data-entry/command.d.ts +69 -0
  84. package/dist/components/data-entry/command.js +3 -0
  85. package/dist/components/data-entry/date-picker.d.ts +16 -0
  86. package/dist/components/data-entry/date-picker.js +8 -0
  87. package/dist/components/data-entry/date-range-picker.d.ts +16 -0
  88. package/dist/components/data-entry/date-range-picker.js +8 -0
  89. package/dist/components/data-entry/index.d.ts +53 -0
  90. package/dist/components/data-entry/index.js +152 -0
  91. package/dist/components/data-entry/input.d.ts +6 -0
  92. package/dist/components/data-entry/input.js +2 -0
  93. package/dist/components/data-entry/label.d.ts +8 -0
  94. package/dist/components/data-entry/label.js +2 -0
  95. package/dist/components/data-entry/radio.d.ts +24 -0
  96. package/dist/components/data-entry/radio.js +4 -0
  97. package/dist/components/data-entry/select.d.ts +18 -0
  98. package/dist/components/data-entry/select.js +3 -0
  99. package/dist/components/data-entry/slider.d.ts +16 -0
  100. package/dist/components/data-entry/slider.js +2 -0
  101. package/dist/components/data-entry/switch.d.ts +17 -0
  102. package/dist/components/data-entry/switch.js +2 -0
  103. package/dist/components/data-entry/textarea.d.ts +6 -0
  104. package/dist/components/data-entry/textarea.js +3 -0
  105. package/dist/components/data-entry/time-picker.d.ts +16 -0
  106. package/dist/components/data-entry/time-picker.js +7 -0
  107. package/dist/components/data-entry/transfer.d.ts +17 -0
  108. package/dist/components/data-entry/transfer.js +11 -0
  109. package/dist/components/data-entry/tree-select.d.ts +26 -0
  110. package/dist/components/data-entry/tree-select.js +13 -0
  111. package/dist/components/data-entry/upload.d.ts +42 -0
  112. package/dist/components/data-entry/upload.js +11 -0
  113. package/dist/components/feedback/alert.d.ts +60 -0
  114. package/dist/components/feedback/alert.js +7 -0
  115. package/dist/components/feedback/dialog.d.ts +64 -0
  116. package/dist/components/feedback/dialog.js +7 -0
  117. package/dist/components/feedback/index.d.ts +16 -0
  118. package/dist/components/feedback/index.js +14 -0
  119. package/dist/components/feedback/sheet.d.ts +24 -0
  120. package/dist/components/feedback/sheet.js +2 -0
  121. package/dist/components/feedback/sonner.d.ts +6 -0
  122. package/dist/components/feedback/sonner.js +1 -0
  123. package/dist/components/general/button.d.ts +20 -0
  124. package/dist/components/general/button.js +2 -0
  125. package/dist/components/general/index.d.ts +6 -0
  126. package/dist/components/general/index.js +2 -0
  127. package/dist/components/layout/index.d.ts +71 -0
  128. package/dist/components/layout/index.js +5 -0
  129. package/dist/components/navigation/dropdown-menu.d.ts +28 -0
  130. package/dist/components/navigation/dropdown-menu.js +2 -0
  131. package/dist/components/navigation/index.d.ts +32 -0
  132. package/dist/components/navigation/index.js +12 -0
  133. package/dist/components/navigation/pagination.d.ts +11 -0
  134. package/dist/components/navigation/pagination.js +7 -0
  135. package/dist/components/navigation/steps.d.ts +12 -0
  136. package/dist/components/navigation/steps.js +3 -0
  137. package/dist/components/navigation/tabs-items.d.ts +12 -0
  138. package/dist/components/navigation/tabs-items.js +3 -0
  139. package/dist/components/navigation/tabs.d.ts +12 -0
  140. package/dist/components/navigation/tabs.js +2 -0
  141. package/dist/components/query/index.d.ts +43 -0
  142. package/dist/components/query/index.js +8 -0
  143. package/dist/components/ui/index.d.ts +57 -0
  144. package/dist/components/ui/index.js +37 -0
  145. package/dist/content.prop-D1Dd3TAc.d.ts +31 -0
  146. package/dist/data-display.prop-DNTAzmDy.d.ts +58 -0
  147. package/dist/data-entry.prop-BEGA1lTq.d.ts +323 -0
  148. package/dist/data-table-D1u_rKLK.d.ts +83 -0
  149. package/dist/data.prop-BVvfKC_g.d.ts +41 -0
  150. package/dist/feedback.prop-BmxUlpAW.d.ts +64 -0
  151. package/dist/filter-bar-B7OGFO9S.d.ts +10 -0
  152. package/dist/form/index.d.ts +21 -0
  153. package/dist/form/index.js +4 -0
  154. package/dist/form.prop-BHgpuFFm.d.ts +41 -0
  155. package/dist/format-date-ByyZoqI5.d.ts +51 -0
  156. package/dist/general.prop-D7brMPNL.d.ts +16 -0
  157. package/dist/i18n/index.d.ts +217 -0
  158. package/dist/i18n/index.js +2 -0
  159. package/dist/index.d.ts +46 -26
  160. package/dist/index.js +39 -13062
  161. package/dist/inline-C5u6ptJV.d.ts +10 -0
  162. package/dist/interaction.prop-Cdn7wOtq.d.ts +25 -0
  163. package/dist/layout.prop-4TCNvyQZ.d.ts +20 -0
  164. package/dist/layout.prop-C795F0qg.d.ts +112 -0
  165. package/dist/lib/datetime/index.d.ts +31 -0
  166. package/dist/lib/datetime/index.js +1 -0
  167. package/dist/lib/utils.d.ts +5 -0
  168. package/dist/lib/utils.js +1 -0
  169. package/dist/navigation.prop-DpZqcXey.d.ts +78 -0
  170. package/dist/navigation.prop-DxBiClEH.d.ts +20 -0
  171. package/dist/props/components/index.d.ts +27 -0
  172. package/dist/props/components/index.js +1 -0
  173. package/dist/props/index.d.ts +28 -0
  174. package/dist/props/index.js +3 -0
  175. package/dist/props/registry.d.ts +649 -0
  176. package/dist/props/registry.js +1 -0
  177. package/dist/props/vocabulary/index.d.ts +7 -0
  178. package/dist/props/vocabulary/index.js +1 -0
  179. package/dist/query.prop-hIPrk2zI.d.ts +71 -0
  180. package/dist/search-input-uP01rY1L.d.ts +22 -0
  181. package/dist/shared.prop-BNRJc9K0.d.ts +45 -0
  182. package/dist/styles/alert-layout.css +191 -0
  183. package/dist/styles/badge-layout.css +22 -0
  184. package/dist/styles/card-layout.css +373 -0
  185. package/dist/styles/control.css +504 -0
  186. package/dist/styles/data-display-layout.css +246 -0
  187. package/dist/styles/density.css +43 -0
  188. package/dist/styles/dialog-layout.css +84 -0
  189. package/dist/styles/index.css +105 -0
  190. package/dist/styles/layout.css +479 -0
  191. package/dist/styles/shell-layout.css +604 -0
  192. package/dist/styles/table-layout.css +109 -0
  193. package/dist/theme/example.service.css +37 -0
  194. package/dist/tokens/base.css +13 -0
  195. package/dist/tokens/foundation.css +151 -0
  196. package/dist/tokens/primitives/badge.css +13 -0
  197. package/dist/tokens/primitives/card.css +29 -0
  198. package/dist/tokens/primitives/control.css +55 -0
  199. package/dist/tokens/primitives/feedback.css +17 -0
  200. package/dist/tokens/primitives/layout.css +20 -0
  201. package/dist/tokens/primitives/navigation.css +13 -0
  202. package/dist/tokens/primitives/table.css +10 -0
  203. package/dist/types-mvzYGrma.d.ts +37 -0
  204. package/dist/use-toast-Dol5bdY3.d.ts +34 -0
  205. package/package.json +279 -117
  206. package/scripts/ui-audit.mjs +179 -0
  207. package/BRAND.md +0 -296
  208. package/CHANGELOG.md +0 -668
  209. package/config/eslint.js +0 -54
  210. package/config/prettier.cjs +0 -20
  211. package/config/tsconfig.base.json +0 -22
  212. package/config/vitest.base.ts +0 -26
  213. package/dist/MiniMonth-YAmPGEpC.d.ts +0 -143
  214. package/dist/Table.types-BbsxoIYE.d.ts +0 -352
  215. package/dist/color-DO0qqUAb.d.ts +0 -38
  216. package/dist/components/composites.d.ts +0 -963
  217. package/dist/components/composites.js +0 -7343
  218. package/dist/components/composites.js.map +0 -1
  219. package/dist/components/primitives.d.ts +0 -2744
  220. package/dist/components/primitives.js +0 -7356
  221. package/dist/components/primitives.js.map +0 -1
  222. package/dist/components/shell.d.ts +0 -182
  223. package/dist/components/shell.js +0 -774
  224. package/dist/components/shell.js.map +0 -1
  225. package/dist/hooks.d.ts +0 -100
  226. package/dist/hooks.js +0 -558
  227. package/dist/hooks.js.map +0 -1
  228. package/dist/i18n.d.ts +0 -61
  229. package/dist/i18n.js +0 -860
  230. package/dist/i18n.js.map +0 -1
  231. package/dist/index.js.map +0 -1
  232. package/dist/padding-DY0JV5Ja.d.ts +0 -16
  233. package/dist/preferences.d.ts +0 -132
  234. package/dist/preferences.js +0 -262
  235. package/dist/preferences.js.map +0 -1
  236. package/dist/props.d.ts +0 -86
  237. package/dist/props.js +0 -16
  238. package/dist/props.js.map +0 -1
  239. package/dist/size-CQwNvOWd.d.ts +0 -19
  240. package/dist/types-LTj-2bl-.d.ts +0 -30
  241. package/dist/useTableViews-D5NIAJ7h.d.ts +0 -154
  242. package/src/tokens/tailwind.css +0 -158
@@ -0,0 +1,122 @@
1
+ import { cn } from './chunk-U7N2A7A3.js';
2
+ import * as React from 'react';
3
+ import { cva } from 'class-variance-authority';
4
+ import { jsx, jsxs } from 'react/jsx-runtime';
5
+
6
+ var cardVariants = cva("group/card border", {
7
+ variants: {
8
+ size: {
9
+ default: "",
10
+ compact: ""
11
+ }
12
+ },
13
+ defaultVariants: { size: "default" }
14
+ });
15
+ var Card = React.forwardRef(
16
+ ({ className, size = "default", accent, variant, density, ...props }, ref) => /* @__PURE__ */ jsx(
17
+ "div",
18
+ {
19
+ ref,
20
+ className: cn(cardVariants({ size }), className),
21
+ "data-slot": "card",
22
+ "data-size": size === "compact" ? "compact" : void 0,
23
+ "data-accent": accent,
24
+ "data-variant": variant && variant !== "default" ? variant : void 0,
25
+ "data-density": density,
26
+ ...props
27
+ }
28
+ )
29
+ );
30
+ Card.displayName = "Card";
31
+ var CardCover = React.forwardRef(
32
+ ({ className, ...props }, ref) => /* @__PURE__ */ jsx("div", { ref, "data-slot": "card-cover", className: cn("ui-card-cover", className), ...props })
33
+ );
34
+ CardCover.displayName = "CardCover";
35
+ var CardHeader = React.forwardRef(
36
+ ({ className, banded, ...props }, ref) => /* @__PURE__ */ jsx(
37
+ "div",
38
+ {
39
+ ref,
40
+ "data-slot": "card-header",
41
+ "data-banded": banded ? "" : void 0,
42
+ className: cn(banded && "ui-card-header--banded", className),
43
+ ...props
44
+ }
45
+ )
46
+ );
47
+ CardHeader.displayName = "CardHeader";
48
+ var CardTitle = React.forwardRef(({ className, children, ...props }, ref) => /* @__PURE__ */ jsx("h3", { ref, "data-slot": "card-title", className, ...props, children }));
49
+ CardTitle.displayName = "CardTitle";
50
+ var CardDescription = React.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx("p", { ref, "data-slot": "card-description", className, ...props }));
51
+ CardDescription.displayName = "CardDescription";
52
+ var CardContent = React.forwardRef(
53
+ ({ className, flush, tight, solo, ...props }, ref) => /* @__PURE__ */ jsx(
54
+ "div",
55
+ {
56
+ ref,
57
+ "data-slot": "card-content",
58
+ "data-flush": flush ? "" : void 0,
59
+ "data-tight": tight ? "" : void 0,
60
+ "data-solo": solo ? "" : void 0,
61
+ className,
62
+ ...props
63
+ }
64
+ )
65
+ );
66
+ CardContent.displayName = "CardContent";
67
+ var CardFooter = React.forwardRef(
68
+ ({ className, separated, flush, ...props }, ref) => /* @__PURE__ */ jsx(
69
+ "div",
70
+ {
71
+ ref,
72
+ "data-slot": "card-footer",
73
+ "data-separated": separated ? "" : void 0,
74
+ "data-flush": flush ? "" : void 0,
75
+ className,
76
+ ...props
77
+ }
78
+ )
79
+ );
80
+ CardFooter.displayName = "CardFooter";
81
+ function CardStat({
82
+ label,
83
+ value,
84
+ hint,
85
+ delta,
86
+ layout = "stacked",
87
+ align = "start",
88
+ className,
89
+ size = "compact",
90
+ ...props
91
+ }) {
92
+ return /* @__PURE__ */ jsxs(
93
+ Card,
94
+ {
95
+ size: size ?? "compact",
96
+ className,
97
+ "data-stat-card": "",
98
+ "data-stat-layout": layout,
99
+ "data-stat-align": align,
100
+ ...props,
101
+ children: [
102
+ /* @__PURE__ */ jsxs("div", { "data-slot": "card-stat-body", children: [
103
+ /* @__PURE__ */ jsx("div", { "data-slot": "card-stat-label", children: label }),
104
+ hint && layout === "inline" ? /* @__PURE__ */ jsx("div", { "data-slot": "card-stat-hint", children: hint }) : null
105
+ ] }),
106
+ /* @__PURE__ */ jsxs("div", { children: [
107
+ /* @__PURE__ */ jsxs("div", { "data-slot": "card-stat-value-row", children: [
108
+ /* @__PURE__ */ jsx("span", { "data-slot": "card-stat-value", children: value }),
109
+ delta ? /* @__PURE__ */ jsx("span", { "data-slot": "card-stat-delta", children: delta }) : null
110
+ ] }),
111
+ hint && layout !== "inline" ? /* @__PURE__ */ jsx("div", { "data-slot": "card-stat-hint", children: hint }) : null
112
+ ] })
113
+ ]
114
+ }
115
+ );
116
+ }
117
+ var CardAction = React.forwardRef(
118
+ ({ className, ...props }, ref) => /* @__PURE__ */ jsx("div", { ref, "data-slot": "card-action", className, ...props })
119
+ );
120
+ CardAction.displayName = "CardAction";
121
+
122
+ export { Card, CardAction, CardContent, CardCover, CardDescription, CardFooter, CardHeader, CardStat, CardTitle };
@@ -0,0 +1,25 @@
1
+ import { cn } from './chunk-U7N2A7A3.js';
2
+ import * as React from 'react';
3
+ import * as LabelPrimitive from '@radix-ui/react-label';
4
+ import { cva } from 'class-variance-authority';
5
+ import { jsx } from 'react/jsx-runtime';
6
+
7
+ var labelVariants = cva(
8
+ "text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70"
9
+ );
10
+ var Label = React.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx(
11
+ LabelPrimitive.Root,
12
+ {
13
+ ref,
14
+ "data-slot": "label",
15
+ className: cn(
16
+ "flex items-center gap-2 select-none group-data-[disabled=true]:pointer-events-none group-data-[disabled=true]:opacity-50",
17
+ labelVariants(),
18
+ className
19
+ ),
20
+ ...props
21
+ }
22
+ ));
23
+ Label.displayName = LabelPrimitive.Root.displayName;
24
+
25
+ export { Label };
@@ -0,0 +1,61 @@
1
+ import { formatDate, translateCurrent } from './chunk-YFCQKO3B.js';
2
+
3
+ // src/lib/format.ts
4
+ function formatDateTime(value, options) {
5
+ return formatDate(value, { ...options, kind: "datetime" });
6
+ }
7
+ function formatDateLong(value, options) {
8
+ return formatDate(value, { ...options, kind: "long" });
9
+ }
10
+ function formatRelative(value, options) {
11
+ return formatDate(value, { ...options, kind: "relative" });
12
+ }
13
+ function formatBytes(n) {
14
+ if (n == null) return "\u2014";
15
+ if (n < 1024) return `${n} B`;
16
+ if (n < 1024 * 1024) return `${(n / 1024).toFixed(1)} KB`;
17
+ if (n < 1024 * 1024 * 1024) return `${(n / 1024 / 1024).toFixed(1)} MB`;
18
+ return `${(n / 1024 / 1024 / 1024).toFixed(2)} GB`;
19
+ }
20
+ function formatCurrency(amountMinor, currency) {
21
+ if (amountMinor == null || !currency) return "\u2014";
22
+ const zeroDecimal = [
23
+ "JPY",
24
+ "VND",
25
+ "KRW",
26
+ "CLP",
27
+ "ISK",
28
+ "BIF",
29
+ "DJF",
30
+ "GNF",
31
+ "KMF",
32
+ "RWF",
33
+ "XAF",
34
+ "XOF",
35
+ "XPF"
36
+ ];
37
+ const minorUnitDigits = zeroDecimal.includes(currency.toUpperCase()) ? 0 : 2;
38
+ const major = amountMinor / Math.pow(10, minorUnitDigits);
39
+ return new Intl.NumberFormat("en-US", {
40
+ style: "currency",
41
+ currency,
42
+ minimumFractionDigits: minorUnitDigits,
43
+ maximumFractionDigits: minorUnitDigits
44
+ }).format(major);
45
+ }
46
+ function shortId(id) {
47
+ if (!id) return "\u2014";
48
+ if (id.length <= 12) return id;
49
+ return id.slice(0, 8) + "\u2026";
50
+ }
51
+ function humanError(err) {
52
+ if (err instanceof Error) {
53
+ const msg = err.message;
54
+ const cleaned = msg.replace(/^\d{3}[^:]*:\s*/, "");
55
+ if (cleaned && cleaned !== "(empty)") return cleaned;
56
+ return translateCurrent("feedback.genericError");
57
+ }
58
+ return translateCurrent("feedback.genericError");
59
+ }
60
+
61
+ export { formatBytes, formatCurrency, formatDateLong, formatDateTime, formatRelative, humanError, shortId };
@@ -0,0 +1,71 @@
1
+ import { FormField } from './chunk-F7PG4OEV.js';
2
+ import { cn } from './chunk-U7N2A7A3.js';
3
+ import { useForm, FormProvider, useFormContext, Controller } from 'react-hook-form';
4
+ import { zodResolver } from '@hookform/resolvers/zod';
5
+ import { jsx } from 'react/jsx-runtime';
6
+
7
+ function useZodForm(schema, options) {
8
+ return useForm({
9
+ ...options,
10
+ // zodResolver + Zod 4 inference gap — runtime types are correct.
11
+ resolver: zodResolver(schema)
12
+ });
13
+ }
14
+ function FormRoot({
15
+ form,
16
+ onSubmit,
17
+ children,
18
+ className,
19
+ id
20
+ }) {
21
+ return /* @__PURE__ */ jsx(FormProvider, { ...form, children: /* @__PURE__ */ jsx(
22
+ "form",
23
+ {
24
+ id,
25
+ className: cn("ui-stack-md", className),
26
+ onSubmit: (event) => {
27
+ void form.handleSubmit((values) => onSubmit(values))(event);
28
+ },
29
+ noValidate: true,
30
+ children
31
+ }
32
+ ) });
33
+ }
34
+ function FormFieldControl({
35
+ name,
36
+ label,
37
+ required,
38
+ helper,
39
+ className,
40
+ children
41
+ }) {
42
+ const { control } = useFormContext();
43
+ return /* @__PURE__ */ jsx(
44
+ Controller,
45
+ {
46
+ name,
47
+ control,
48
+ render: ({ field, fieldState }) => /* @__PURE__ */ jsx(
49
+ FormField,
50
+ {
51
+ id: String(name),
52
+ label,
53
+ required,
54
+ helper,
55
+ error: fieldState.error?.message,
56
+ className,
57
+ children: children({
58
+ id: String(name),
59
+ name: field.name,
60
+ value: field.value,
61
+ onChange: field.onChange,
62
+ onBlur: field.onBlur,
63
+ ref: field.ref
64
+ })
65
+ }
66
+ )
67
+ }
68
+ );
69
+ }
70
+
71
+ export { FormFieldControl, FormRoot, useZodForm };
@@ -0,0 +1 @@
1
+
@@ -0,0 +1,111 @@
1
+ import { cn } from './chunk-U7N2A7A3.js';
2
+ import * as React from 'react';
3
+ import * as DialogPrimitive from '@radix-ui/react-dialog';
4
+ import { cva } from 'class-variance-authority';
5
+ import { X } from 'lucide-react';
6
+ import { jsx, jsxs } from 'react/jsx-runtime';
7
+
8
+ function Sheet(props) {
9
+ return /* @__PURE__ */ jsx(DialogPrimitive.Root, { "data-slot": "sheet", ...props });
10
+ }
11
+ function SheetTrigger(props) {
12
+ return /* @__PURE__ */ jsx(DialogPrimitive.Trigger, { "data-slot": "sheet-trigger", ...props });
13
+ }
14
+ function SheetClose(props) {
15
+ return /* @__PURE__ */ jsx(DialogPrimitive.Close, { "data-slot": "sheet-close", ...props });
16
+ }
17
+ function SheetPortal(props) {
18
+ return /* @__PURE__ */ jsx(DialogPrimitive.Portal, { "data-slot": "sheet-portal", ...props });
19
+ }
20
+ var SheetOverlay = React.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx(
21
+ DialogPrimitive.Overlay,
22
+ {
23
+ ref,
24
+ "data-slot": "sheet-overlay",
25
+ className: cn(
26
+ "data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:animate-in data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/50",
27
+ className
28
+ ),
29
+ ...props
30
+ }
31
+ ));
32
+ SheetOverlay.displayName = DialogPrimitive.Overlay.displayName;
33
+ var sheetVariants = cva(
34
+ "fixed z-50 flex flex-col gap-4 bg-background p-6 shadow-lg transition ease-in-out data-[state=closed]:animate-out data-[state=closed]:duration-300 data-[state=open]:animate-in data-[state=open]:duration-500",
35
+ {
36
+ variants: {
37
+ side: {
38
+ right: "inset-y-0 right-0 h-full w-3/4 border-l data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right sm:max-w-md",
39
+ left: "inset-y-0 left-0 h-full w-3/4 border-r data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left sm:max-w-md",
40
+ top: "inset-x-0 top-0 h-auto border-b data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top",
41
+ bottom: "inset-x-0 bottom-0 h-auto border-t data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom"
42
+ }
43
+ },
44
+ defaultVariants: { side: "right" }
45
+ }
46
+ );
47
+ var SheetContent = React.forwardRef(({ side = "right", className, children, showCloseButton = true, ...props }, ref) => /* @__PURE__ */ jsxs(SheetPortal, { children: [
48
+ /* @__PURE__ */ jsx(SheetOverlay, {}),
49
+ /* @__PURE__ */ jsxs(
50
+ DialogPrimitive.Content,
51
+ {
52
+ ref,
53
+ "data-slot": "sheet-content",
54
+ className: cn(sheetVariants({ side }), className),
55
+ ...props,
56
+ children: [
57
+ children,
58
+ showCloseButton ? /* @__PURE__ */ jsxs(
59
+ DialogPrimitive.Close,
60
+ {
61
+ "data-slot": "sheet-close",
62
+ className: "ring-offset-background focus:ring-ring absolute end-4 top-4 rounded-sm opacity-70 transition-opacity hover:opacity-100 focus:ring-2 focus:ring-offset-2 focus:outline-hidden disabled:pointer-events-none",
63
+ children: [
64
+ /* @__PURE__ */ jsx(X, { className: "size-4", "aria-hidden": "true" }),
65
+ /* @__PURE__ */ jsx("span", { className: "sr-only", children: "Close" })
66
+ ]
67
+ }
68
+ ) : null
69
+ ]
70
+ }
71
+ )
72
+ ] }));
73
+ SheetContent.displayName = DialogPrimitive.Content.displayName;
74
+ var SheetHeader = ({ className, ...props }) => /* @__PURE__ */ jsx(
75
+ "div",
76
+ {
77
+ "data-slot": "sheet-header",
78
+ className: cn("flex flex-col gap-1.5 text-center sm:text-left", className),
79
+ ...props
80
+ }
81
+ );
82
+ var SheetFooter = ({ className, ...props }) => /* @__PURE__ */ jsx(
83
+ "div",
84
+ {
85
+ "data-slot": "sheet-footer",
86
+ className: cn("mt-auto flex flex-col gap-2", className),
87
+ ...props
88
+ }
89
+ );
90
+ var SheetTitle = React.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx(
91
+ DialogPrimitive.Title,
92
+ {
93
+ ref,
94
+ "data-slot": "sheet-title",
95
+ className: cn("text-foreground text-lg font-semibold", className),
96
+ ...props
97
+ }
98
+ ));
99
+ SheetTitle.displayName = DialogPrimitive.Title.displayName;
100
+ var SheetDescription = React.forwardRef(({ className, ...props }, ref) => /* @__PURE__ */ jsx(
101
+ DialogPrimitive.Description,
102
+ {
103
+ ref,
104
+ "data-slot": "sheet-description",
105
+ className: cn("text-muted-foreground text-sm", className),
106
+ ...props
107
+ }
108
+ ));
109
+ SheetDescription.displayName = DialogPrimitive.Description.displayName;
110
+
111
+ export { Sheet, SheetClose, SheetContent, SheetDescription, SheetFooter, SheetHeader, SheetOverlay, SheetPortal, SheetTitle, SheetTrigger };
@@ -0,0 +1,70 @@
1
+ import { Calendar } from './chunk-IK7I3ABN.js';
2
+ import { Popover, PopoverTrigger, PopoverContent } from './chunk-DY5C44UP.js';
3
+ import { Button } from './chunk-HJEBRCXL.js';
4
+ import { useTranslation, usePickerLocales } from './chunk-3F2AKYRD.js';
5
+ import { formatDate } from './chunk-YFCQKO3B.js';
6
+ import { cn } from './chunk-U7N2A7A3.js';
7
+ import * as React from 'react';
8
+ import { CalendarIcon } from 'lucide-react';
9
+ import { jsxs, jsx } from 'react/jsx-runtime';
10
+
11
+ function formatRange(range) {
12
+ if (!range?.from) return "";
13
+ const fmt = (d) => formatDate(d, { kind: "calendar" });
14
+ if (!range.to) return fmt(range.from);
15
+ return `${fmt(range.from)} \u2013 ${fmt(range.to)}`;
16
+ }
17
+ function DateRangePicker({
18
+ value,
19
+ onChange,
20
+ placeholder,
21
+ disabled,
22
+ className,
23
+ id,
24
+ locale: localeProp,
25
+ fromDate,
26
+ toDate
27
+ }) {
28
+ const { t } = useTranslation();
29
+ const { dayPickerLocale } = usePickerLocales(localeProp);
30
+ const [open, setOpen] = React.useState(false);
31
+ const label = formatRange(value);
32
+ const resolvedPlaceholder = placeholder ?? t("dataEntry.dateRangePicker.placeholder");
33
+ return /* @__PURE__ */ jsxs(Popover, { open, onOpenChange: setOpen, children: [
34
+ /* @__PURE__ */ jsx(PopoverTrigger, { asChild: true, children: /* @__PURE__ */ jsxs(
35
+ Button,
36
+ {
37
+ id,
38
+ type: "button",
39
+ variant: "outline",
40
+ disabled,
41
+ className: cn(
42
+ "w-full justify-start text-left font-normal",
43
+ !label && "text-muted-foreground",
44
+ className
45
+ ),
46
+ children: [
47
+ /* @__PURE__ */ jsx(CalendarIcon, { className: "mr-2 size-4 shrink-0", "aria-hidden": "true" }),
48
+ label || resolvedPlaceholder
49
+ ]
50
+ }
51
+ ) }),
52
+ /* @__PURE__ */ jsx(PopoverContent, { className: "w-auto p-0", align: "start", children: /* @__PURE__ */ jsx(
53
+ Calendar,
54
+ {
55
+ mode: "range",
56
+ selected: value,
57
+ onSelect: onChange,
58
+ locale: dayPickerLocale,
59
+ disabled: [
60
+ ...fromDate ? [{ before: fromDate }] : [],
61
+ ...toDate ? [{ after: toDate }] : []
62
+ ],
63
+ startMonth: fromDate,
64
+ endMonth: toDate
65
+ }
66
+ ) })
67
+ ] });
68
+ }
69
+
70
+ export { DateRangePicker };
@@ -0,0 +1,68 @@
1
+ import { Tabs, TabsList, TabsTrigger, TabsContent } from './chunk-XG7XDYIM.js';
2
+ import { cn } from './chunk-U7N2A7A3.js';
3
+ import { jsxs, jsx } from 'react/jsx-runtime';
4
+
5
+ function TabsItems({
6
+ items,
7
+ value,
8
+ defaultValue,
9
+ onValueChange,
10
+ variant = "default",
11
+ className,
12
+ listClassName,
13
+ contentClassName
14
+ }) {
15
+ const firstKey = items[0]?.key;
16
+ const resolvedDefault = defaultValue ?? firstKey;
17
+ return /* @__PURE__ */ jsxs(
18
+ Tabs,
19
+ {
20
+ value,
21
+ defaultValue: value === void 0 ? resolvedDefault : void 0,
22
+ onValueChange,
23
+ className,
24
+ "data-slot": "tabs",
25
+ children: [
26
+ /* @__PURE__ */ jsx(
27
+ TabsList,
28
+ {
29
+ "data-slot": "tabs-list",
30
+ className: cn(
31
+ variant === "line" && "h-auto w-full justify-start rounded-none border-b bg-transparent p-0",
32
+ variant === "card" && "w-full justify-start",
33
+ listClassName
34
+ ),
35
+ children: items.map((item) => /* @__PURE__ */ jsxs(
36
+ TabsTrigger,
37
+ {
38
+ value: item.key,
39
+ disabled: item.disabled,
40
+ className: cn(
41
+ variant === "line" && "data-[state=active]:border-primary rounded-none border-b-2 border-transparent bg-transparent px-4 py-2 shadow-none data-[state=active]:bg-transparent data-[state=active]:shadow-none",
42
+ variant === "card" && "data-[state=active]:shadow-sm"
43
+ ),
44
+ children: [
45
+ item.icon && /* @__PURE__ */ jsx("span", { className: "mr-1.5 inline-flex", children: item.icon }),
46
+ item.label
47
+ ]
48
+ },
49
+ item.key
50
+ ))
51
+ }
52
+ ),
53
+ items.map((item) => /* @__PURE__ */ jsx(
54
+ TabsContent,
55
+ {
56
+ value: item.key,
57
+ "data-slot": "tabs-panel",
58
+ className: cn(variant === "line" && "mt-0", contentClassName),
59
+ children: item.children
60
+ },
61
+ item.key
62
+ ))
63
+ ]
64
+ }
65
+ );
66
+ }
67
+
68
+ export { TabsItems };