@seedgrid/fe-components 0.2.4

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 (270) hide show
  1. package/dist/blocked-email-domains.json +41 -0
  2. package/dist/buttons/SgButton.d.ts +43 -0
  3. package/dist/buttons/SgButton.d.ts.map +1 -0
  4. package/dist/buttons/SgButton.js +123 -0
  5. package/dist/buttons/SgFloatActionButton.d.ts +60 -0
  6. package/dist/buttons/SgFloatActionButton.d.ts.map +1 -0
  7. package/dist/buttons/SgFloatActionButton.js +532 -0
  8. package/dist/buttons/SgSpeedDial.d.ts +40 -0
  9. package/dist/buttons/SgSpeedDial.d.ts.map +1 -0
  10. package/dist/buttons/SgSpeedDial.js +149 -0
  11. package/dist/buttons/SgSplitButton.d.ts +32 -0
  12. package/dist/buttons/SgSplitButton.d.ts.map +1 -0
  13. package/dist/buttons/SgSplitButton.js +81 -0
  14. package/dist/clock/SgClock.d.ts +28 -0
  15. package/dist/clock/SgClock.d.ts.map +1 -0
  16. package/dist/clock/SgClock.js +280 -0
  17. package/dist/clock/SgTimeProvider.d.ts +13 -0
  18. package/dist/clock/SgTimeProvider.d.ts.map +1 -0
  19. package/dist/clock/SgTimeProvider.js +44 -0
  20. package/dist/clock/themes/SgClockThemePicker.d.ts +14 -0
  21. package/dist/clock/themes/SgClockThemePicker.d.ts.map +1 -0
  22. package/dist/clock/themes/SgClockThemePicker.js +71 -0
  23. package/dist/clock/themes/SgClockThemePreview.d.ts +7 -0
  24. package/dist/clock/themes/SgClockThemePreview.d.ts.map +1 -0
  25. package/dist/clock/themes/SgClockThemePreview.js +11 -0
  26. package/dist/clock/themes/builtins.d.ts +3 -0
  27. package/dist/clock/themes/builtins.d.ts.map +1 -0
  28. package/dist/clock/themes/builtins.js +241 -0
  29. package/dist/clock/themes/index.d.ts +9 -0
  30. package/dist/clock/themes/index.d.ts.map +1 -0
  31. package/dist/clock/themes/index.js +7 -0
  32. package/dist/clock/themes/provider.d.ts +19 -0
  33. package/dist/clock/themes/provider.d.ts.map +1 -0
  34. package/dist/clock/themes/provider.js +54 -0
  35. package/dist/clock/themes/registry.d.ts +9 -0
  36. package/dist/clock/themes/registry.d.ts.map +1 -0
  37. package/dist/clock/themes/registry.js +25 -0
  38. package/dist/clock/themes/renderTheme.d.ts +7 -0
  39. package/dist/clock/themes/renderTheme.d.ts.map +1 -0
  40. package/dist/clock/themes/renderTheme.js +41 -0
  41. package/dist/clock/themes/types.d.ts +21 -0
  42. package/dist/clock/themes/types.d.ts.map +1 -0
  43. package/dist/clock/themes/types.js +1 -0
  44. package/dist/clock/themes/urlThemeCache.d.ts +2 -0
  45. package/dist/clock/themes/urlThemeCache.d.ts.map +1 -0
  46. package/dist/clock/themes/urlThemeCache.js +11 -0
  47. package/dist/clock/themes/useDarkFlag.d.ts +2 -0
  48. package/dist/clock/themes/useDarkFlag.d.ts.map +1 -0
  49. package/dist/clock/themes/useDarkFlag.js +14 -0
  50. package/dist/commons/SgBadge.d.ts +51 -0
  51. package/dist/commons/SgBadge.d.ts.map +1 -0
  52. package/dist/commons/SgBadge.js +141 -0
  53. package/dist/commons/SgBadgeOverlay.d.ts +13 -0
  54. package/dist/commons/SgBadgeOverlay.d.ts.map +1 -0
  55. package/dist/commons/SgBadgeOverlay.js +20 -0
  56. package/dist/commons/SgButton.d.ts +39 -0
  57. package/dist/commons/SgButton.d.ts.map +1 -0
  58. package/dist/commons/SgButton.js +116 -0
  59. package/dist/commons/SgPopup.d.ts +42 -0
  60. package/dist/commons/SgPopup.d.ts.map +1 -0
  61. package/dist/commons/SgPopup.js +218 -0
  62. package/dist/commons/SgToast.d.ts +44 -0
  63. package/dist/commons/SgToast.d.ts.map +1 -0
  64. package/dist/commons/SgToast.js +97 -0
  65. package/dist/commons/SgToaster.d.ts +11 -0
  66. package/dist/commons/SgToaster.d.ts.map +1 -0
  67. package/dist/commons/SgToaster.js +85 -0
  68. package/dist/commons/common-passwords.d.ts +2 -0
  69. package/dist/commons/common-passwords.d.ts.map +1 -0
  70. package/dist/commons/common-passwords.js +167 -0
  71. package/dist/environment/SgEnvironmentProvider.d.ts +31 -0
  72. package/dist/environment/SgEnvironmentProvider.d.ts.map +1 -0
  73. package/dist/environment/SgEnvironmentProvider.js +120 -0
  74. package/dist/environment/persistence.d.ts +44 -0
  75. package/dist/environment/persistence.d.ts.map +1 -0
  76. package/dist/environment/persistence.js +149 -0
  77. package/dist/gadgets/clock/SgClock.d.ts +18 -0
  78. package/dist/gadgets/clock/SgClock.d.ts.map +1 -0
  79. package/dist/gadgets/clock/SgClock.js +407 -0
  80. package/dist/gadgets/clock/SgTimeProvider.d.ts +13 -0
  81. package/dist/gadgets/clock/SgTimeProvider.d.ts.map +1 -0
  82. package/dist/gadgets/clock/SgTimeProvider.js +44 -0
  83. package/dist/gadgets/clock/themes/SgClockThemePicker.d.ts +14 -0
  84. package/dist/gadgets/clock/themes/SgClockThemePicker.d.ts.map +1 -0
  85. package/dist/gadgets/clock/themes/SgClockThemePicker.js +71 -0
  86. package/dist/gadgets/clock/themes/SgClockThemePreview.d.ts +7 -0
  87. package/dist/gadgets/clock/themes/SgClockThemePreview.d.ts.map +1 -0
  88. package/dist/gadgets/clock/themes/SgClockThemePreview.js +11 -0
  89. package/dist/gadgets/clock/themes/builtins.d.ts +3 -0
  90. package/dist/gadgets/clock/themes/builtins.d.ts.map +1 -0
  91. package/dist/gadgets/clock/themes/builtins.js +241 -0
  92. package/dist/gadgets/clock/themes/index.d.ts +9 -0
  93. package/dist/gadgets/clock/themes/index.d.ts.map +1 -0
  94. package/dist/gadgets/clock/themes/index.js +7 -0
  95. package/dist/gadgets/clock/themes/provider.d.ts +19 -0
  96. package/dist/gadgets/clock/themes/provider.d.ts.map +1 -0
  97. package/dist/gadgets/clock/themes/provider.js +54 -0
  98. package/dist/gadgets/clock/themes/registry.d.ts +9 -0
  99. package/dist/gadgets/clock/themes/registry.d.ts.map +1 -0
  100. package/dist/gadgets/clock/themes/registry.js +25 -0
  101. package/dist/gadgets/clock/themes/renderTheme.d.ts +7 -0
  102. package/dist/gadgets/clock/themes/renderTheme.d.ts.map +1 -0
  103. package/dist/gadgets/clock/themes/renderTheme.js +41 -0
  104. package/dist/gadgets/clock/themes/types.d.ts +21 -0
  105. package/dist/gadgets/clock/themes/types.d.ts.map +1 -0
  106. package/dist/gadgets/clock/themes/types.js +1 -0
  107. package/dist/gadgets/clock/themes/urlThemeCache.d.ts +2 -0
  108. package/dist/gadgets/clock/themes/urlThemeCache.d.ts.map +1 -0
  109. package/dist/gadgets/clock/themes/urlThemeCache.js +11 -0
  110. package/dist/gadgets/clock/themes/useDarkFlag.d.ts +2 -0
  111. package/dist/gadgets/clock/themes/useDarkFlag.d.ts.map +1 -0
  112. package/dist/gadgets/clock/themes/useDarkFlag.js +14 -0
  113. package/dist/gadgets/flip-digit/SgFlipDigit.d.ts +23 -0
  114. package/dist/gadgets/flip-digit/SgFlipDigit.d.ts.map +1 -0
  115. package/dist/gadgets/flip-digit/SgFlipDigit.js +118 -0
  116. package/dist/gadgets/flip-digit/index.d.ts +3 -0
  117. package/dist/gadgets/flip-digit/index.d.ts.map +1 -0
  118. package/dist/gadgets/flip-digit/index.js +1 -0
  119. package/dist/i18n/en-US.json +76 -0
  120. package/dist/i18n/es.json +76 -0
  121. package/dist/i18n/index.d.ts +328 -0
  122. package/dist/i18n/index.d.ts.map +1 -0
  123. package/dist/i18n/index.js +87 -0
  124. package/dist/i18n/pt-BR.json +76 -0
  125. package/dist/i18n/pt-PT.json +76 -0
  126. package/dist/index.d.ts +88 -0
  127. package/dist/index.d.ts.map +1 -0
  128. package/dist/index.js +46 -0
  129. package/dist/inputs/FloatingInput.d.ts +13 -0
  130. package/dist/inputs/FloatingInput.d.ts.map +1 -0
  131. package/dist/inputs/FloatingInput.js +53 -0
  132. package/dist/inputs/FloatingSelect.d.ts +15 -0
  133. package/dist/inputs/FloatingSelect.d.ts.map +1 -0
  134. package/dist/inputs/FloatingSelect.js +52 -0
  135. package/dist/inputs/FloatingTextArea.d.ts +11 -0
  136. package/dist/inputs/FloatingTextArea.d.ts.map +1 -0
  137. package/dist/inputs/FloatingTextArea.js +34 -0
  138. package/dist/inputs/InputBirthDate.d.ts +13 -0
  139. package/dist/inputs/InputBirthDate.d.ts.map +1 -0
  140. package/dist/inputs/InputBirthDate.js +46 -0
  141. package/dist/inputs/InputDate.d.ts +8 -0
  142. package/dist/inputs/InputDate.d.ts.map +1 -0
  143. package/dist/inputs/InputDate.js +23 -0
  144. package/dist/inputs/InputEmail.d.ts +14 -0
  145. package/dist/inputs/InputEmail.d.ts.map +1 -0
  146. package/dist/inputs/InputEmail.js +43 -0
  147. package/dist/inputs/InputPassword.d.ts +12 -0
  148. package/dist/inputs/InputPassword.d.ts.map +1 -0
  149. package/dist/inputs/InputPassword.js +42 -0
  150. package/dist/inputs/MaskedInputs.d.ts +27 -0
  151. package/dist/inputs/MaskedInputs.d.ts.map +1 -0
  152. package/dist/inputs/MaskedInputs.js +161 -0
  153. package/dist/inputs/SgAutocomplete.d.ts +42 -0
  154. package/dist/inputs/SgAutocomplete.d.ts.map +1 -0
  155. package/dist/inputs/SgAutocomplete.js +241 -0
  156. package/dist/inputs/SgCurrencyEdit.d.ts +56 -0
  157. package/dist/inputs/SgCurrencyEdit.d.ts.map +1 -0
  158. package/dist/inputs/SgCurrencyEdit.js +496 -0
  159. package/dist/inputs/SgInputBirthDate.d.ts +13 -0
  160. package/dist/inputs/SgInputBirthDate.d.ts.map +1 -0
  161. package/dist/inputs/SgInputBirthDate.js +48 -0
  162. package/dist/inputs/SgInputCEP.d.ts +33 -0
  163. package/dist/inputs/SgInputCEP.d.ts.map +1 -0
  164. package/dist/inputs/SgInputCEP.js +117 -0
  165. package/dist/inputs/SgInputCNPJ.d.ts +20 -0
  166. package/dist/inputs/SgInputCNPJ.d.ts.map +1 -0
  167. package/dist/inputs/SgInputCNPJ.js +133 -0
  168. package/dist/inputs/SgInputCPF.d.ts +15 -0
  169. package/dist/inputs/SgInputCPF.d.ts.map +1 -0
  170. package/dist/inputs/SgInputCPF.js +70 -0
  171. package/dist/inputs/SgInputCPFCNPJ.d.ts +15 -0
  172. package/dist/inputs/SgInputCPFCNPJ.d.ts.map +1 -0
  173. package/dist/inputs/SgInputCPFCNPJ.js +92 -0
  174. package/dist/inputs/SgInputDate.d.ts +8 -0
  175. package/dist/inputs/SgInputDate.d.ts.map +1 -0
  176. package/dist/inputs/SgInputDate.js +120 -0
  177. package/dist/inputs/SgInputEmail.d.ts +16 -0
  178. package/dist/inputs/SgInputEmail.d.ts.map +1 -0
  179. package/dist/inputs/SgInputEmail.js +74 -0
  180. package/dist/inputs/SgInputFone.d.ts +15 -0
  181. package/dist/inputs/SgInputFone.d.ts.map +1 -0
  182. package/dist/inputs/SgInputFone.js +60 -0
  183. package/dist/inputs/SgInputMasked.d.ts +27 -0
  184. package/dist/inputs/SgInputMasked.d.ts.map +1 -0
  185. package/dist/inputs/SgInputMasked.js +161 -0
  186. package/dist/inputs/SgInputNumber.d.ts +49 -0
  187. package/dist/inputs/SgInputNumber.d.ts.map +1 -0
  188. package/dist/inputs/SgInputNumber.js +438 -0
  189. package/dist/inputs/SgInputPassword.d.ts +26 -0
  190. package/dist/inputs/SgInputPassword.d.ts.map +1 -0
  191. package/dist/inputs/SgInputPassword.js +278 -0
  192. package/dist/inputs/SgInputPhone.d.ts +15 -0
  193. package/dist/inputs/SgInputPhone.d.ts.map +1 -0
  194. package/dist/inputs/SgInputPhone.js +66 -0
  195. package/dist/inputs/SgInputPostalCode.d.ts +37 -0
  196. package/dist/inputs/SgInputPostalCode.d.ts.map +1 -0
  197. package/dist/inputs/SgInputPostalCode.js +193 -0
  198. package/dist/inputs/SgInputSelect.d.ts +16 -0
  199. package/dist/inputs/SgInputSelect.d.ts.map +1 -0
  200. package/dist/inputs/SgInputSelect.js +104 -0
  201. package/dist/inputs/SgInputText.d.ts +49 -0
  202. package/dist/inputs/SgInputText.d.ts.map +1 -0
  203. package/dist/inputs/SgInputText.js +336 -0
  204. package/dist/inputs/SgInputTextArea.d.ts +41 -0
  205. package/dist/inputs/SgInputTextArea.d.ts.map +1 -0
  206. package/dist/inputs/SgInputTextArea.js +216 -0
  207. package/dist/inputs/SgTextEditor.d.ts +27 -0
  208. package/dist/inputs/SgTextEditor.d.ts.map +1 -0
  209. package/dist/inputs/SgTextEditor.js +201 -0
  210. package/dist/integration/module.d.ts +39 -0
  211. package/dist/integration/module.d.ts.map +1 -0
  212. package/dist/integration/module.js +1 -0
  213. package/dist/layout/GroupBox.d.ts +10 -0
  214. package/dist/layout/GroupBox.d.ts.map +1 -0
  215. package/dist/layout/GroupBox.js +14 -0
  216. package/dist/layout/SgCard.d.ts +35 -0
  217. package/dist/layout/SgCard.d.ts.map +1 -0
  218. package/dist/layout/SgCard.js +106 -0
  219. package/dist/layout/SgDockLayout.d.ts +37 -0
  220. package/dist/layout/SgDockLayout.d.ts.map +1 -0
  221. package/dist/layout/SgDockLayout.js +101 -0
  222. package/dist/layout/SgDockZone.d.ts +12 -0
  223. package/dist/layout/SgDockZone.d.ts.map +1 -0
  224. package/dist/layout/SgDockZone.js +20 -0
  225. package/dist/layout/SgGrid.d.ts +18 -0
  226. package/dist/layout/SgGrid.d.ts.map +1 -0
  227. package/dist/layout/SgGrid.js +101 -0
  228. package/dist/layout/SgGroupBox.d.ts +10 -0
  229. package/dist/layout/SgGroupBox.d.ts.map +1 -0
  230. package/dist/layout/SgGroupBox.js +14 -0
  231. package/dist/layout/SgMainPanel.d.ts +11 -0
  232. package/dist/layout/SgMainPanel.d.ts.map +1 -0
  233. package/dist/layout/SgMainPanel.js +70 -0
  234. package/dist/layout/SgPanel.d.ts +22 -0
  235. package/dist/layout/SgPanel.d.ts.map +1 -0
  236. package/dist/layout/SgPanel.js +33 -0
  237. package/dist/layout/SgScreen.d.ts +11 -0
  238. package/dist/layout/SgScreen.d.ts.map +1 -0
  239. package/dist/layout/SgScreen.js +18 -0
  240. package/dist/layout/SgStack.d.ts +15 -0
  241. package/dist/layout/SgStack.d.ts.map +1 -0
  242. package/dist/layout/SgStack.js +32 -0
  243. package/dist/layout/SgToolBar.d.ts +46 -0
  244. package/dist/layout/SgToolBar.d.ts.map +1 -0
  245. package/dist/layout/SgToolBar.js +199 -0
  246. package/dist/layout/SgTreeView.d.ts +80 -0
  247. package/dist/layout/SgTreeView.d.ts.map +1 -0
  248. package/dist/layout/SgTreeView.js +338 -0
  249. package/dist/manifest.d.ts +3 -0
  250. package/dist/manifest.d.ts.map +1 -0
  251. package/dist/manifest.js +19 -0
  252. package/dist/masks.d.ts +14 -0
  253. package/dist/masks.d.ts.map +1 -0
  254. package/dist/masks.js +91 -0
  255. package/dist/overlay/SgDialog.d.ts +39 -0
  256. package/dist/overlay/SgDialog.d.ts.map +1 -0
  257. package/dist/overlay/SgDialog.js +177 -0
  258. package/dist/overlay/SgPopup.d.ts +42 -0
  259. package/dist/overlay/SgPopup.d.ts.map +1 -0
  260. package/dist/overlay/SgPopup.js +218 -0
  261. package/dist/rhf.d.ts +6 -0
  262. package/dist/rhf.d.ts.map +1 -0
  263. package/dist/rhf.js +1 -0
  264. package/dist/validators.d.ts +27 -0
  265. package/dist/validators.d.ts.map +1 -0
  266. package/dist/validators.js +218 -0
  267. package/dist/wizard/SGWizard.d.ts +28 -0
  268. package/dist/wizard/SGWizard.d.ts.map +1 -0
  269. package/dist/wizard/SGWizard.js +124 -0
  270. package/package.json +53 -0
@@ -0,0 +1,496 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import React from "react";
4
+ import { X } from "lucide-react";
5
+ import { Controller } from "react-hook-form";
6
+ import { t, useComponentsI18n } from "../i18n";
7
+ function ErrorText(props) {
8
+ if (!props.message)
9
+ return null;
10
+ return _jsx("p", { "data-sg-error": true, className: "text-xs text-red-600", children: props.message });
11
+ }
12
+ function mergeRefs(...refs) {
13
+ return (node) => {
14
+ for (const ref of refs) {
15
+ if (!ref)
16
+ continue;
17
+ if (typeof ref === "function") {
18
+ ref(node);
19
+ }
20
+ else if (typeof ref === "object" && "current" in ref) {
21
+ ref.current = node;
22
+ }
23
+ }
24
+ };
25
+ }
26
+ function resolveCurrencyMeta(options) {
27
+ const { locale, currency, currencyDisplay, currencySymbolOverride, currencySymbolPlacement, useGrouping } = options;
28
+ try {
29
+ const formatter = new Intl.NumberFormat(locale, {
30
+ style: "currency",
31
+ currency,
32
+ currencyDisplay,
33
+ useGrouping
34
+ });
35
+ const parts = formatter.formatToParts(1000.1);
36
+ const groupSep = parts.find((p) => p.type === "group")?.value ?? ",";
37
+ const decimalSep = parts.find((p) => p.type === "decimal")?.value ?? ".";
38
+ const currencyPart = parts.find((p) => p.type === "currency")?.value ?? currency;
39
+ const integerIndex = parts.findIndex((p) => p.type === "integer");
40
+ const currencyIndex = parts.findIndex((p) => p.type === "currency");
41
+ const placement = currencySymbolPlacement === "auto"
42
+ ? currencyIndex > -1 && currencyIndex < integerIndex
43
+ ? "prefix"
44
+ : "suffix"
45
+ : currencySymbolPlacement;
46
+ const { maximumFractionDigits } = formatter.resolvedOptions();
47
+ return {
48
+ decimalSep,
49
+ groupSep,
50
+ symbol: currencySymbolOverride ?? currencyPart,
51
+ placement,
52
+ minorUnit: typeof maximumFractionDigits === "number" ? maximumFractionDigits : 2
53
+ };
54
+ }
55
+ catch {
56
+ return {
57
+ decimalSep: ".",
58
+ groupSep: ",",
59
+ symbol: currencySymbolOverride ?? currency.toUpperCase(),
60
+ placement: currencySymbolPlacement === "suffix" ? "suffix" : "prefix",
61
+ minorUnit: 2
62
+ };
63
+ }
64
+ }
65
+ function normalizeState(raw, decimals, allowNegative) {
66
+ let text = raw ?? "";
67
+ const isNegative = allowNegative && text.includes("-");
68
+ text = text.replace(/[^0-9.,]/g, "");
69
+ const lastDot = text.lastIndexOf(".");
70
+ const lastComma = text.lastIndexOf(",");
71
+ const decimalIndex = Math.max(lastDot, lastComma);
72
+ let intPart = "";
73
+ let decPart = "";
74
+ let hasDecimal = false;
75
+ if (decimalIndex >= 0) {
76
+ hasDecimal = true;
77
+ intPart = text.slice(0, decimalIndex).replace(/[^0-9]/g, "");
78
+ decPart = text.slice(decimalIndex + 1).replace(/[^0-9]/g, "");
79
+ }
80
+ else {
81
+ intPart = text.replace(/[^0-9]/g, "");
82
+ }
83
+ if (!intPart)
84
+ intPart = "0";
85
+ if (decimals > 0) {
86
+ decPart = decPart.slice(0, decimals);
87
+ }
88
+ else {
89
+ decPart = "";
90
+ hasDecimal = false;
91
+ }
92
+ return {
93
+ negative: isNegative,
94
+ intDigits: intPart,
95
+ decDigits: decPart,
96
+ hasDecimal
97
+ };
98
+ }
99
+ function formatWithGroup(intDigits, group) {
100
+ const clean = intDigits.replace(/^0+(?!$)/, "");
101
+ if (!group)
102
+ return clean;
103
+ return clean.replace(/\B(?=(\d{3})+(?!\d))/g, group);
104
+ }
105
+ function stateToDisplay(state, decimals, decimalSep, group) {
106
+ if (!state)
107
+ return "";
108
+ const intPart = formatWithGroup(state.intDigits, group);
109
+ if (decimals <= 0)
110
+ return `${state.negative ? "-" : ""}${intPart}`;
111
+ const decPart = state.decDigits.padEnd(decimals, "0");
112
+ return `${state.negative ? "-" : ""}${intPart}${decimalSep}${decPart}`;
113
+ }
114
+ function stateToValue(state, decimals) {
115
+ if (!state)
116
+ return "";
117
+ const intPart = state.intDigits.replace(/^0+(?!$)/, "");
118
+ if (decimals <= 0)
119
+ return `${state.negative ? "-" : ""}${intPart || "0"}`;
120
+ const decPart = state.decDigits.padEnd(decimals, "0");
121
+ return `${state.negative ? "-" : ""}${intPart || "0"}.${decPart}`;
122
+ }
123
+ function stateToNumber(state, decimals) {
124
+ if (!state)
125
+ return null;
126
+ const value = stateToValue(state, decimals);
127
+ const num = Number(value);
128
+ if (Number.isNaN(num))
129
+ return null;
130
+ return num;
131
+ }
132
+ function setCaretToEnd(input) {
133
+ if (!input)
134
+ return;
135
+ const length = input.value.length;
136
+ try {
137
+ input.setSelectionRange(length, length);
138
+ }
139
+ catch {
140
+ // ignore
141
+ }
142
+ }
143
+ function combineAffix(symbol, extra, placement) {
144
+ if (!symbol && !extra)
145
+ return undefined;
146
+ if (!symbol)
147
+ return extra;
148
+ if (!extra)
149
+ return symbol;
150
+ return placement === "prefix" ? `${symbol} ${extra}` : `${extra} ${symbol}`;
151
+ }
152
+ function SgCurrencyEditBase(props) {
153
+ const i18n = useComponentsI18n();
154
+ const allowNegative = props.allowNegative ?? true;
155
+ const emptyValue = props.emptyValue ?? "zero";
156
+ const currency = (props.currency ?? "BRL").toUpperCase();
157
+ const locale = props.locale ?? i18n.locale;
158
+ const showCurrencySymbol = props.showCurrencySymbol ?? true;
159
+ const useGrouping = props.useGrouping ?? true;
160
+ const meta = React.useMemo(() => resolveCurrencyMeta({
161
+ locale,
162
+ currency,
163
+ currencyDisplay: props.currencyDisplay ?? "symbol",
164
+ currencySymbolOverride: props.currencySymbolOverride,
165
+ currencySymbolPlacement: props.currencySymbolPlacement ?? "auto",
166
+ useGrouping
167
+ }), [
168
+ locale,
169
+ currency,
170
+ props.currencyDisplay,
171
+ props.currencySymbolOverride,
172
+ props.currencySymbolPlacement,
173
+ useGrouping
174
+ ]);
175
+ const decimals = props.decimals ?? meta.minorUnit;
176
+ const decimalSep = meta.decimalSep;
177
+ const groupSep = useGrouping ? meta.groupSep : "";
178
+ const currencyPrefix = showCurrencySymbol && meta.placement === "prefix" ? meta.symbol : undefined;
179
+ const currencySuffix = showCurrencySymbol && meta.placement === "suffix" ? meta.symbol : undefined;
180
+ const prefixText = combineAffix(currencyPrefix, props.prefixText, "prefix");
181
+ const suffixText = combineAffix(currencySuffix, props.suffixText, "suffix");
182
+ const inputProps = props.inputProps ?? {};
183
+ const { value: _ignoredValue, defaultValue: _ignoredDefault, onChange: inputOnChange, ...restInputProps } = inputProps;
184
+ const labelText = props.labelText ?? props.label ?? "";
185
+ const placeholder = props.placeholder ?? props.hintText ?? labelText;
186
+ const inputRef = React.useRef(null);
187
+ const prefixRef = React.useRef(null);
188
+ const suffixRef = React.useRef(null);
189
+ const [prefixWidth, setPrefixWidth] = React.useState(0);
190
+ const [suffixWidth, setSuffixWidth] = React.useState(0);
191
+ const [internalError, setInternalError] = React.useState(null);
192
+ const [hasInteracted, setHasInteracted] = React.useState(false);
193
+ const initialState = React.useMemo(() => {
194
+ const raw = props.externalValue ?? inputProps.value ?? inputProps.defaultValue ?? "";
195
+ if ((raw === "" || raw == null) && emptyValue === "null")
196
+ return null;
197
+ return normalizeState(String(raw), decimals, allowNegative);
198
+ }, [props.externalValue, inputProps.value, inputProps.defaultValue, emptyValue, decimals, allowNegative]);
199
+ const [state, setState] = React.useState(initialState);
200
+ const stateRef = React.useRef(initialState);
201
+ const lastEmittedRef = React.useRef(null);
202
+ React.useEffect(() => {
203
+ const raw = props.externalValue ?? inputProps.value;
204
+ if (raw === undefined)
205
+ return;
206
+ if (inputRef.current) {
207
+ const isFocused = typeof document !== "undefined" && document.activeElement === inputRef.current;
208
+ if (isFocused && lastEmittedRef.current === String(raw ?? ""))
209
+ return;
210
+ }
211
+ if ((raw === "" || raw == null) && emptyValue === "null") {
212
+ stateRef.current = null;
213
+ setState(null);
214
+ return;
215
+ }
216
+ const next = normalizeState(String(raw), decimals, allowNegative);
217
+ stateRef.current = next;
218
+ setState(next);
219
+ }, [props.externalValue, inputProps.value, emptyValue, decimals, allowNegative]);
220
+ React.useLayoutEffect(() => {
221
+ if (prefixRef.current) {
222
+ const next = prefixRef.current.offsetWidth;
223
+ if (next !== prefixWidth)
224
+ setPrefixWidth(next);
225
+ }
226
+ else if (prefixWidth !== 0) {
227
+ setPrefixWidth(0);
228
+ }
229
+ if (suffixRef.current) {
230
+ const next = suffixRef.current.offsetWidth;
231
+ if (next !== suffixWidth)
232
+ setSuffixWidth(next);
233
+ }
234
+ else if (suffixWidth !== 0) {
235
+ setSuffixWidth(0);
236
+ }
237
+ }, [prefixText, suffixText, prefixWidth, suffixWidth]);
238
+ const displayValue = stateToDisplay(state, decimals, decimalSep, groupSep);
239
+ const isFilled = displayValue.length > 0;
240
+ const runValidation = React.useCallback((valueState) => {
241
+ const required = props.required ?? false;
242
+ const numberValue = stateToNumber(valueState, decimals);
243
+ const isZeroValue = valueState != null &&
244
+ valueState.negative === false &&
245
+ valueState.intDigits.replace(/^0+(?!$)/, "0") === "0" &&
246
+ (decimals <= 0 || valueState.decDigits.replace(/0/g, "") === "");
247
+ if (!valueState || numberValue === null || (emptyValue === "zero" && isZeroValue)) {
248
+ if (required) {
249
+ const message = props.requiredMessage ?? t(i18n, "components.inputs.required");
250
+ setInternalError(message);
251
+ props.onValidation?.(message);
252
+ return;
253
+ }
254
+ setInternalError(null);
255
+ props.onValidation?.(null);
256
+ return;
257
+ }
258
+ if (props.minValue !== undefined && numberValue < props.minValue) {
259
+ const message = props.minValueMessage ?? t(i18n, "components.inputs.number.min", { min: props.minValue });
260
+ setInternalError(message);
261
+ props.onValidation?.(message);
262
+ return;
263
+ }
264
+ if (props.maxValue !== undefined && numberValue > props.maxValue) {
265
+ const message = props.maxValueMessage ?? t(i18n, "components.inputs.number.max", { max: props.maxValue });
266
+ setInternalError(message);
267
+ props.onValidation?.(message);
268
+ return;
269
+ }
270
+ if (props.validation) {
271
+ const message = props.validation(stateToValue(valueState, decimals));
272
+ setInternalError(message);
273
+ props.onValidation?.(message ?? null);
274
+ return;
275
+ }
276
+ setInternalError(null);
277
+ props.onValidation?.(null);
278
+ }, [props, i18n, decimals, emptyValue]);
279
+ const commitState = React.useCallback((next) => {
280
+ stateRef.current = next;
281
+ setState(next);
282
+ setHasInteracted(true);
283
+ const value = stateToValue(next, decimals);
284
+ lastEmittedRef.current = value;
285
+ props.onExternalChange?.(value);
286
+ props.onChange?.(value);
287
+ if (inputOnChange) {
288
+ inputOnChange({
289
+ target: { value },
290
+ currentTarget: { value }
291
+ });
292
+ }
293
+ if (props.validateOnBlur === false) {
294
+ runValidation(next);
295
+ }
296
+ }, [decimals, props, runValidation, inputOnChange]);
297
+ const handleKeyDown = (event) => {
298
+ if (props.readOnly || props.enabled === false || inputProps.readOnly)
299
+ return;
300
+ if (event.ctrlKey || event.metaKey || event.altKey)
301
+ return;
302
+ const key = event.key;
303
+ if (key === "Tab" || key === "ArrowLeft" || key === "ArrowRight" || key === "Home" || key === "End") {
304
+ return;
305
+ }
306
+ event.preventDefault();
307
+ if (key === "Backspace" || key === "Delete") {
308
+ const current = stateRef.current;
309
+ if (!current) {
310
+ if (emptyValue === "zero") {
311
+ commitState({ negative: false, intDigits: "0", decDigits: "", hasDecimal: false });
312
+ }
313
+ return;
314
+ }
315
+ if (current.hasDecimal && current.decDigits.length > 0) {
316
+ commitState({ ...current, decDigits: current.decDigits.slice(0, -1) });
317
+ return;
318
+ }
319
+ if (current.hasDecimal && current.decDigits.length === 0) {
320
+ commitState({ ...current, hasDecimal: false });
321
+ return;
322
+ }
323
+ const nextInt = current.intDigits.slice(0, -1);
324
+ if (!nextInt) {
325
+ if (emptyValue === "null") {
326
+ commitState(null);
327
+ }
328
+ else {
329
+ commitState({ ...current, intDigits: "0" });
330
+ }
331
+ return;
332
+ }
333
+ commitState({ ...current, intDigits: nextInt });
334
+ return;
335
+ }
336
+ if ((key === "-" || key === "_") && allowNegative) {
337
+ const base = stateRef.current ?? { negative: false, intDigits: "0", decDigits: "", hasDecimal: false };
338
+ commitState({ ...base, negative: !base.negative });
339
+ return;
340
+ }
341
+ const isDecimalKey = key === decimalSep || key === "." || key === ",";
342
+ if (isDecimalKey) {
343
+ if (decimals <= 0)
344
+ return;
345
+ const next = stateRef.current ?? { negative: false, intDigits: "0", decDigits: "", hasDecimal: false };
346
+ const decDigits = next.decDigits.length >= decimals ? "" : next.decDigits;
347
+ commitState({ ...next, hasDecimal: true, decDigits });
348
+ return;
349
+ }
350
+ if (/\d/.test(key)) {
351
+ const next = stateRef.current ?? { negative: false, intDigits: "0", decDigits: "", hasDecimal: false };
352
+ if (next.hasDecimal && decimals > 0 && next.decDigits.length < decimals) {
353
+ commitState({ ...next, decDigits: `${next.decDigits}${key}` });
354
+ return;
355
+ }
356
+ const intDigits = next.intDigits === "0" ? key : `${next.intDigits}${key}`;
357
+ commitState({ ...next, intDigits });
358
+ return;
359
+ }
360
+ };
361
+ const handleChange = (event) => {
362
+ if (props.readOnly || props.enabled === false || inputProps.readOnly)
363
+ return;
364
+ const parsed = normalizeState(event.currentTarget.value, decimals, allowNegative);
365
+ commitState(parsed);
366
+ };
367
+ const handlePaste = (event) => {
368
+ if (props.readOnly || props.enabled === false || inputProps.readOnly)
369
+ return;
370
+ const text = event.clipboardData.getData("text");
371
+ if (!text)
372
+ return;
373
+ event.preventDefault();
374
+ const parsed = normalizeState(text, decimals, allowNegative);
375
+ commitState(parsed);
376
+ };
377
+ const handleBlur = (event) => {
378
+ if ((props.validateOnBlur ?? true) || hasInteracted) {
379
+ runValidation(state);
380
+ }
381
+ inputProps.onBlur?.(event);
382
+ props.onExit?.();
383
+ };
384
+ const handleFocus = () => {
385
+ props.onEnter?.();
386
+ };
387
+ const handleClear = () => {
388
+ if (!inputRef.current)
389
+ return;
390
+ const next = emptyValue === "null"
391
+ ? null
392
+ : { negative: false, intDigits: "0", decDigits: "", hasDecimal: false };
393
+ commitState(next);
394
+ inputRef.current.value = stateToDisplay(next, decimals, decimalSep, groupSep);
395
+ setCaretToEnd(inputRef.current);
396
+ props.onClear?.();
397
+ };
398
+ React.useEffect(() => {
399
+ if (!inputRef.current)
400
+ return;
401
+ inputRef.current.value = displayValue;
402
+ setCaretToEnd(inputRef.current);
403
+ }, [displayValue]);
404
+ const isDisabled = props.enabled === false || props.readOnly || inputProps.readOnly;
405
+ const canShowClear = (props.clearButton ?? true) && !isDisabled;
406
+ const iconButtonsCount = props.iconButtons?.length ?? 0;
407
+ const hasSuffix = canShowClear || iconButtonsCount > 0;
408
+ const paddingLeft = props.prefixIcon ? "pl-10" : "px-3";
409
+ const paddingRight = hasSuffix ? "pr-10" : "pr-3";
410
+ const baseClass = "peer h-11 w-full rounded-md text-sm placeholder-transparent focus:outline-none text-right";
411
+ const hasError = Boolean(props.error ?? internalError);
412
+ const borderClass = (props.withBorder ?? true) || hasError
413
+ ? hasError
414
+ ? "border border-[hsl(var(--destructive))] shadow-sm focus:border-[hsl(var(--destructive))] focus:ring-2 focus:ring-[hsl(var(--destructive)/0.25)]"
415
+ : "border border-border shadow-sm focus:border-[hsl(var(--primary))] focus:ring-2 focus:ring-[hsl(var(--primary)/0.25)]"
416
+ : "border border-transparent";
417
+ const bgClass = props.filled ? "bg-muted/40" : "bg-white";
418
+ const finalClass = [
419
+ baseClass,
420
+ borderClass,
421
+ bgClass,
422
+ paddingLeft,
423
+ paddingRight,
424
+ "py-2",
425
+ "leading-[1.2]"
426
+ ].join(" ");
427
+ let resolvedBorderRadius;
428
+ if (props.borderRadius !== undefined) {
429
+ resolvedBorderRadius =
430
+ typeof props.borderRadius === "number"
431
+ ? `${props.borderRadius}px`
432
+ : props.borderRadius;
433
+ }
434
+ const prefixPaddingStyle = prefixText
435
+ ? `calc(${prefixWidth}px + 0.75rem${props.prefixIcon ? " + 0.75rem" : ""})`
436
+ : undefined;
437
+ const iconButtonsPadding = iconButtonsCount > 0 ? `${iconButtonsCount * 1.5}rem` : "0rem";
438
+ const baseRightPadding = canShowClear ? "2rem" : "0.75rem";
439
+ const suffixPaddingStyle = suffixText
440
+ ? `calc(${suffixWidth}px + ${baseRightPadding} + ${iconButtonsPadding})`
441
+ : hasSuffix
442
+ ? `calc(${baseRightPadding} + ${iconButtonsPadding})`
443
+ : undefined;
444
+ const clearRightStyle = suffixText && suffixWidth
445
+ ? `${suffixWidth}px`
446
+ : undefined;
447
+ return (_jsxs("div", { style: { width: props.width ?? "100%" }, children: [_jsxs("div", { className: "relative", children: [prefixText ? (_jsx("span", { ref: prefixRef, className: "pointer-events-none absolute left-0 top-0 z-10 flex h-11 items-center rounded-l-md border border-border bg-muted/40 px-3 text-xs leading-none text-foreground/70", children: prefixText })) : null, props.prefixIcon ? (_jsx("span", { className: "pointer-events-none absolute left-3 top-1/2 z-10 -translate-y-1/2 text-foreground/60", children: props.prefixIcon })) : null, _jsx("input", { id: props.id, type: props.type ?? "text", placeholder: placeholder, className: props.className ?? finalClass, style: {
448
+ borderRadius: resolvedBorderRadius,
449
+ paddingLeft: prefixPaddingStyle,
450
+ paddingRight: suffixPaddingStyle,
451
+ ...(prefixText ? { borderTopLeftRadius: 0, borderBottomLeftRadius: 0, borderLeftWidth: 0 } : {}),
452
+ ...(suffixText ? { borderTopRightRadius: 0, borderBottomRightRadius: 0, borderRightWidth: 0 } : {}),
453
+ ...(inputProps.style ?? {})
454
+ }, inputMode: props.textInputType ?? "decimal", readOnly: props.readOnly, disabled: props.enabled === false, ...restInputProps, ref: mergeRefs(inputRef, inputProps?.ref), onKeyDown: handleKeyDown, onChange: handleChange, onPaste: handlePaste, onBlur: handleBlur, onFocus: handleFocus }), suffixText ? (_jsx("span", { ref: suffixRef, className: "pointer-events-none absolute right-0 top-0 z-10 flex h-11 items-center rounded-r-md border border-border bg-muted/40 px-3 text-xs leading-none text-foreground/70", children: suffixText })) : null, _jsxs("label", { htmlFor: props.id, className: [
455
+ "absolute bg-white px-1 transition-all",
456
+ isFilled
457
+ ? "-top-2 left-3 text-xs"
458
+ : `top-3 text-sm ${props.prefixIcon ? "left-10" : "left-3"}`,
459
+ hasError
460
+ ? "text-[hsl(var(--destructive))]"
461
+ : isFilled
462
+ ? "text-[hsl(var(--primary))]"
463
+ : "text-foreground/60",
464
+ hasError
465
+ ? "peer-focus:-top-2 peer-focus:left-3 peer-focus:text-xs peer-focus:text-[hsl(var(--destructive))]"
466
+ : "peer-focus:-top-2 peer-focus:left-3 peer-focus:text-xs peer-focus:text-[hsl(var(--primary))]",
467
+ props.labelClassName ?? ""
468
+ ].join(" "), style: prefixPaddingStyle ? { left: prefixPaddingStyle } : undefined, children: [_jsx("span", { children: labelText }), props.required ? (_jsx("span", { className: "ml-1 text-[hsl(var(--destructive))]", "aria-hidden": "true", children: "*" })) : null] }), hasSuffix ? (_jsxs("span", { className: "absolute right-2 top-1/2 flex -translate-y-1/2 items-center gap-1", style: clearRightStyle ? { right: clearRightStyle } : undefined, children: [canShowClear ? (_jsx("button", { type: "button", onClick: handleClear, className: "rounded px-1 text-xs text-foreground/60 hover:text-foreground", "aria-label": t(i18n, "components.actions.clear"), children: _jsx(X, { size: 16 }) })) : null, props.iconButtons?.map((node, index) => (_jsx("span", { children: node }, index)))] })) : null] }), _jsx("div", { className: "mt-1 flex items-center justify-between gap-2", children: _jsx(ErrorText, { message: props.error ?? internalError ?? undefined }) })] }));
469
+ }
470
+ export function SgCurrencyEdit(props) {
471
+ const { control, name, register, rules, ...rest } = props;
472
+ if (name && register) {
473
+ const reg = register(name, rules);
474
+ return (_jsx(SgCurrencyEditBase, { ...rest, onExternalChange: (value) => {
475
+ reg.onChange({ target: { name, value } });
476
+ }, inputProps: {
477
+ ...rest.inputProps,
478
+ name,
479
+ ref: mergeRefs(reg.ref, rest.inputProps?.ref),
480
+ onBlur: (event) => {
481
+ reg.onBlur(event);
482
+ rest.inputProps?.onBlur?.(event);
483
+ }
484
+ } }));
485
+ }
486
+ if (control && name) {
487
+ return (_jsx(Controller, { name: name, control: control, render: ({ field, fieldState }) => (_jsx(SgCurrencyEditBase, { ...rest, externalValue: field.value, onExternalChange: (value) => field.onChange(value), error: rest.error ?? fieldState.error?.message, inputProps: {
488
+ ...rest.inputProps,
489
+ onBlur: (event) => {
490
+ field.onBlur();
491
+ rest.inputProps?.onBlur?.(event);
492
+ }
493
+ } })) }));
494
+ }
495
+ return _jsx(SgCurrencyEditBase, { ...rest });
496
+ }
@@ -0,0 +1,13 @@
1
+ import { type SgInputDateProps } from "./SgInputDate";
2
+ import { type BirthDatePolicy } from "../validators";
3
+ export type SgInputBirthDateProps = Omit<SgInputDateProps, "maxDate" | "minDate"> & BirthDatePolicy & {
4
+ maxDate?: string | Date;
5
+ minDate?: string | Date;
6
+ onValidation?: (message: string | null) => void;
7
+ required?: boolean;
8
+ requiredMessage?: string;
9
+ validateOnBlur?: boolean;
10
+ error?: string;
11
+ };
12
+ export declare function SgInputBirthDate(props: SgInputBirthDateProps): import("react/jsx-runtime").JSX.Element;
13
+ //# sourceMappingURL=SgInputBirthDate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SgInputBirthDate.d.ts","sourceRoot":"","sources":["../../src/inputs/SgInputBirthDate.tsx"],"names":[],"mappings":"AAGA,OAAO,EAAe,KAAK,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACnE,OAAO,EAAqB,KAAK,eAAe,EAAE,MAAM,eAAe,CAAC;AAGxE,MAAM,MAAM,qBAAqB,GAAG,IAAI,CAAC,gBAAgB,EAAE,SAAS,GAAG,SAAS,CAAC,GAC/E,eAAe,GAAG;IAChB,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,YAAY,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAC;IAChD,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEJ,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,qBAAqB,2CAuE5D"}
@@ -0,0 +1,48 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import React from "react";
4
+ import { SgInputDate } from "./SgInputDate";
5
+ import { validateBirthDate } from "../validators";
6
+ import { t, useComponentsI18n } from "../i18n";
7
+ export function SgInputBirthDate(props) {
8
+ const i18n = useComponentsI18n();
9
+ const today = new Date();
10
+ const todayStr = today.toISOString().slice(0, 10);
11
+ const { minAge, maxAge, onValidation, inputProps, minDate, maxDate, alwaysFloat, required, requiredMessage, validateOnBlur, error, ...rest } = props;
12
+ const derivedMaxDate = maxAge !== undefined && maxAge >= 0
13
+ ? new Date(today.getFullYear() - maxAge, today.getMonth(), today.getDate()).toISOString().slice(0, 10)
14
+ : undefined;
15
+ const derivedMinDate = minAge !== undefined && minAge >= 0
16
+ ? new Date(today.getFullYear() - minAge, today.getMonth(), today.getDate()).toISOString().slice(0, 10)
17
+ : undefined;
18
+ const [internalError, setInternalError] = React.useState(null);
19
+ const runValidation = React.useCallback((value) => {
20
+ if (!value && !required) {
21
+ setInternalError(null);
22
+ onValidation?.(null);
23
+ return;
24
+ }
25
+ if (!value && required) {
26
+ const message = requiredMessage ?? t(i18n, "components.inputs.birthdate.required");
27
+ setInternalError(message);
28
+ onValidation?.(message);
29
+ return;
30
+ }
31
+ const message = validateBirthDate(value, { minAge, maxAge }, i18n);
32
+ setInternalError(message);
33
+ onValidation?.(message);
34
+ }, [i18n, maxAge, minAge, onValidation, required, requiredMessage]);
35
+ const handleBlur = (event) => {
36
+ runValidation(event.currentTarget.value);
37
+ inputProps?.onBlur?.(event);
38
+ };
39
+ return (_jsx(SgInputDate, { ...rest, error: error ?? internalError ?? undefined, inputProps: {
40
+ ...inputProps,
41
+ onBlur: (event) => {
42
+ if (validateOnBlur ?? true)
43
+ handleBlur(event);
44
+ else
45
+ inputProps?.onBlur?.(event);
46
+ }
47
+ }, alwaysFloat: alwaysFloat ?? true, maxDate: maxDate ?? derivedMinDate ?? todayStr, minDate: minDate ?? derivedMaxDate }));
48
+ }
@@ -0,0 +1,33 @@
1
+ import React from "react";
2
+ import { type SgInputTextProps } from "./SgInputText";
3
+ export type ViaCepResponse = {
4
+ cep?: string;
5
+ logradouro?: string;
6
+ complemento?: string;
7
+ bairro?: string;
8
+ localidade?: string;
9
+ uf?: string;
10
+ ibge?: string;
11
+ gia?: string;
12
+ ddd?: string;
13
+ siafi?: string;
14
+ erro?: boolean;
15
+ };
16
+ export type SgInputCEPProps = Omit<SgInputTextProps, "inputProps" | "error"> & {
17
+ inputProps?: React.InputHTMLAttributes<HTMLInputElement>;
18
+ error?: string;
19
+ required?: boolean;
20
+ requiredMessage?: string;
21
+ lengthMessage?: string;
22
+ invalidMessage?: string;
23
+ validation?: (value: string) => string | null;
24
+ onValidation?: (message: string | null) => void;
25
+ validateOnBlur?: boolean;
26
+ validateWithViaCep?: boolean;
27
+ viaCepErrorMessage?: string;
28
+ viaCepFetch?: (cep: string) => Promise<ViaCepResponse>;
29
+ onViaCepResult?: (data: ViaCepResponse) => void;
30
+ onViaCepError?: (error: unknown) => void;
31
+ };
32
+ export declare function SgInputCEP(props: Readonly<SgInputCEPProps>): import("react/jsx-runtime").JSX.Element;
33
+ //# sourceMappingURL=SgInputCEP.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SgInputCEP.d.ts","sourceRoot":"","sources":["../../src/inputs/SgInputCEP.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAe,KAAK,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAInE,MAAM,MAAM,cAAc,GAAG;IAC3B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,IAAI,CAAC,gBAAgB,EAAE,YAAY,GAAG,OAAO,CAAC,GAAG;IAC7E,UAAU,CAAC,EAAE,KAAK,CAAC,mBAAmB,CAAC,gBAAgB,CAAC,CAAC;IACzD,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,MAAM,GAAG,IAAI,CAAC;IAC9C,YAAY,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,GAAG,IAAI,KAAK,IAAI,CAAC;IAChD,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,kBAAkB,CAAC,EAAE,OAAO,CAAC;IAC7B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,WAAW,CAAC,EAAE,CAAC,GAAG,EAAE,MAAM,KAAK,OAAO,CAAC,cAAc,CAAC,CAAC;IACvD,cAAc,CAAC,EAAE,CAAC,IAAI,EAAE,cAAc,KAAK,IAAI,CAAC;IAChD,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC;CAC1C,CAAC;AAWF,wBAAgB,UAAU,CAAC,KAAK,EAAE,QAAQ,CAAC,eAAe,CAAC,2CAoI1D"}