@skalfa/skalfa-component 1.0.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 (231) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +79 -0
  3. package/dist/accordion/Accordion.component.d.ts +13 -0
  4. package/dist/accordion/Accordion.component.js +25 -0
  5. package/dist/breadcrumb/Breadcrumb.component.d.ts +14 -0
  6. package/dist/breadcrumb/Breadcrumb.component.js +21 -0
  7. package/dist/button/Button.component.d.ts +21 -0
  8. package/dist/button/Button.component.js +19 -0
  9. package/dist/card/AlertCard.component.d.ts +11 -0
  10. package/dist/card/AlertCard.component.js +9 -0
  11. package/dist/card/Card.component.d.ts +5 -0
  12. package/dist/card/Card.component.js +9 -0
  13. package/dist/card/DashboardCard.component.d.ts +9 -0
  14. package/dist/card/DashboardCard.component.js +13 -0
  15. package/dist/card/GalleryCard.component.d.ts +7 -0
  16. package/dist/card/GalleryCard.component.js +13 -0
  17. package/dist/card/ProductCard.component.d.ts +9 -0
  18. package/dist/card/ProductCard.component.js +13 -0
  19. package/dist/card/ProfileCard.component.d.ts +10 -0
  20. package/dist/card/ProfileCard.component.js +13 -0
  21. package/dist/carousel/Carousel.component.d.ts +13 -0
  22. package/dist/carousel/Carousel.component.js +37 -0
  23. package/dist/chip/Chip.component.d.ts +6 -0
  24. package/dist/chip/Chip.component.js +12 -0
  25. package/dist/index.d.ts +56 -0
  26. package/dist/index.js +85 -0
  27. package/dist/input/Checkbox.component.d.ts +13 -0
  28. package/dist/input/Checkbox.component.js +23 -0
  29. package/dist/input/Input.component.d.ts +23 -0
  30. package/dist/input/Input.component.js +134 -0
  31. package/dist/input/InputCheckbox.component.d.ts +27 -0
  32. package/dist/input/InputCheckbox.component.js +53 -0
  33. package/dist/input/InputCurrency.component.d.ts +21 -0
  34. package/dist/input/InputCurrency.component.js +30 -0
  35. package/dist/input/InputDate.component.d.ts +24 -0
  36. package/dist/input/InputDate.component.js +107 -0
  37. package/dist/input/InputDatetime.component.d.ts +17 -0
  38. package/dist/input/InputDatetime.component.js +75 -0
  39. package/dist/input/InputDocument.component.d.ts +22 -0
  40. package/dist/input/InputDocument.component.js +88 -0
  41. package/dist/input/InputImage.component.d.ts +23 -0
  42. package/dist/input/InputImage.component.js +260 -0
  43. package/dist/input/InputMap.component.d.ts +25 -0
  44. package/dist/input/InputMap.component.js +103 -0
  45. package/dist/input/InputNumber.component.d.ts +19 -0
  46. package/dist/input/InputNumber.component.js +40 -0
  47. package/dist/input/InputOtp.component.d.ts +14 -0
  48. package/dist/input/InputOtp.component.js +65 -0
  49. package/dist/input/InputPassword.component.d.ts +17 -0
  50. package/dist/input/InputPassword.component.js +59 -0
  51. package/dist/input/InputRadio.component.d.ts +27 -0
  52. package/dist/input/InputRadio.component.js +56 -0
  53. package/dist/input/InputTime.component.d.ts +23 -0
  54. package/dist/input/InputTime.component.js +73 -0
  55. package/dist/input/InputValues.component.d.ts +9 -0
  56. package/dist/input/InputValues.component.js +19 -0
  57. package/dist/input/Radio.component.d.ts +12 -0
  58. package/dist/input/Radio.component.js +22 -0
  59. package/dist/input/Select.component.d.ts +47 -0
  60. package/dist/input/Select.component.js +275 -0
  61. package/dist/modal/BottomSheet.component.d.ts +12 -0
  62. package/dist/modal/BottomSheet.component.js +161 -0
  63. package/dist/modal/FloatingPage.component.d.ts +12 -0
  64. package/dist/modal/FloatingPage.component.js +27 -0
  65. package/dist/modal/Modal.component.d.ts +12 -0
  66. package/dist/modal/Modal.component.js +27 -0
  67. package/dist/modal/ModalConfirm.component.d.ts +26 -0
  68. package/dist/modal/ModalConfirm.component.js +68 -0
  69. package/dist/modal/Toast.component.d.ts +11 -0
  70. package/dist/modal/Toast.component.js +58 -0
  71. package/dist/nav/Bottombar.component.d.ts +12 -0
  72. package/dist/nav/Bottombar.component.js +32 -0
  73. package/dist/nav/Footer.component.d.ts +37 -0
  74. package/dist/nav/Footer.component.js +49 -0
  75. package/dist/nav/Headbar.component.d.ts +14 -0
  76. package/dist/nav/Headbar.component.js +32 -0
  77. package/dist/nav/Navbar.component.d.ts +22 -0
  78. package/dist/nav/Navbar.component.js +26 -0
  79. package/dist/nav/Sidebar.component.d.ts +33 -0
  80. package/dist/nav/Sidebar.component.js +87 -0
  81. package/dist/nav/Tabbar.component.d.ts +13 -0
  82. package/dist/nav/Tabbar.component.js +17 -0
  83. package/dist/nav/Wizard.component.d.ts +9 -0
  84. package/dist/nav/Wizard.component.js +24 -0
  85. package/dist/src/accordion/Accordion.component.d.ts +13 -0
  86. package/dist/src/accordion/Accordion.component.js +25 -0
  87. package/dist/src/breadcrumb/Breadcrumb.component.d.ts +14 -0
  88. package/dist/src/breadcrumb/Breadcrumb.component.js +21 -0
  89. package/dist/src/button/Button.component.d.ts +21 -0
  90. package/dist/src/button/Button.component.js +19 -0
  91. package/dist/src/card/AlertCard.component.d.ts +11 -0
  92. package/dist/src/card/AlertCard.component.js +9 -0
  93. package/dist/src/card/Card.component.d.ts +5 -0
  94. package/dist/src/card/Card.component.js +9 -0
  95. package/dist/src/card/DashboardCard.component.d.ts +9 -0
  96. package/dist/src/card/DashboardCard.component.js +13 -0
  97. package/dist/src/card/GalleryCard.component.d.ts +7 -0
  98. package/dist/src/card/GalleryCard.component.js +13 -0
  99. package/dist/src/card/ProductCard.component.d.ts +9 -0
  100. package/dist/src/card/ProductCard.component.js +13 -0
  101. package/dist/src/card/ProfileCard.component.d.ts +10 -0
  102. package/dist/src/card/ProfileCard.component.js +13 -0
  103. package/dist/src/carousel/Carousel.component.d.ts +13 -0
  104. package/dist/src/carousel/Carousel.component.js +37 -0
  105. package/dist/src/chip/Chip.component.d.ts +6 -0
  106. package/dist/src/chip/Chip.component.js +12 -0
  107. package/dist/src/index.d.ts +13 -0
  108. package/dist/src/index.js +29 -0
  109. package/dist/src/input/Checkbox.component.d.ts +13 -0
  110. package/dist/src/input/Checkbox.component.js +23 -0
  111. package/dist/src/input/Input.component.d.ts +23 -0
  112. package/dist/src/input/Input.component.js +134 -0
  113. package/dist/src/input/InputCheckbox.component.d.ts +27 -0
  114. package/dist/src/input/InputCheckbox.component.js +53 -0
  115. package/dist/src/input/InputCurrency.component.d.ts +21 -0
  116. package/dist/src/input/InputCurrency.component.js +30 -0
  117. package/dist/src/input/InputDate.component.d.ts +24 -0
  118. package/dist/src/input/InputDate.component.js +107 -0
  119. package/dist/src/input/InputDatetime.component.d.ts +17 -0
  120. package/dist/src/input/InputDatetime.component.js +75 -0
  121. package/dist/src/input/InputDocument.component.d.ts +22 -0
  122. package/dist/src/input/InputDocument.component.js +88 -0
  123. package/dist/src/input/InputImage.component.d.ts +23 -0
  124. package/dist/src/input/InputImage.component.js +260 -0
  125. package/dist/src/input/InputMap.component.d.ts +25 -0
  126. package/dist/src/input/InputMap.component.js +101 -0
  127. package/dist/src/input/InputNumber.component.d.ts +19 -0
  128. package/dist/src/input/InputNumber.component.js +40 -0
  129. package/dist/src/input/InputOtp.component.d.ts +14 -0
  130. package/dist/src/input/InputOtp.component.js +65 -0
  131. package/dist/src/input/InputPassword.component.d.ts +17 -0
  132. package/dist/src/input/InputPassword.component.js +59 -0
  133. package/dist/src/input/InputRadio.component.d.ts +27 -0
  134. package/dist/src/input/InputRadio.component.js +56 -0
  135. package/dist/src/input/InputTime.component.d.ts +23 -0
  136. package/dist/src/input/InputTime.component.js +73 -0
  137. package/dist/src/input/InputValues.component.d.ts +9 -0
  138. package/dist/src/input/InputValues.component.js +19 -0
  139. package/dist/src/input/Radio.component.d.ts +12 -0
  140. package/dist/src/input/Radio.component.js +22 -0
  141. package/dist/src/input/Select.component.d.ts +47 -0
  142. package/dist/src/input/Select.component.js +275 -0
  143. package/dist/src/modal/BottomSheet.component.d.ts +12 -0
  144. package/dist/src/modal/BottomSheet.component.js +161 -0
  145. package/dist/src/modal/FloatingPage.component.d.ts +12 -0
  146. package/dist/src/modal/FloatingPage.component.js +27 -0
  147. package/dist/src/modal/Modal.component.d.ts +12 -0
  148. package/dist/src/modal/Modal.component.js +27 -0
  149. package/dist/src/modal/ModalConfirm.component.d.ts +26 -0
  150. package/dist/src/modal/ModalConfirm.component.js +68 -0
  151. package/dist/src/modal/Toast.component.d.ts +11 -0
  152. package/dist/src/modal/Toast.component.js +58 -0
  153. package/dist/src/nav/Bottombar.component.d.ts +12 -0
  154. package/dist/src/nav/Bottombar.component.js +32 -0
  155. package/dist/src/nav/Footer.component.d.ts +37 -0
  156. package/dist/src/nav/Footer.component.js +49 -0
  157. package/dist/src/nav/Headbar.component.d.ts +14 -0
  158. package/dist/src/nav/Headbar.component.js +32 -0
  159. package/dist/src/nav/Navbar.component.d.ts +22 -0
  160. package/dist/src/nav/Navbar.component.js +26 -0
  161. package/dist/src/nav/Sidebar.component.d.ts +33 -0
  162. package/dist/src/nav/Sidebar.component.js +87 -0
  163. package/dist/src/nav/Tabbar.component.d.ts +13 -0
  164. package/dist/src/nav/Tabbar.component.js +17 -0
  165. package/dist/src/nav/Wizard.component.d.ts +9 -0
  166. package/dist/src/nav/Wizard.component.js +24 -0
  167. package/dist/src/supervision/FormSupervision.component.d.ts +93 -0
  168. package/dist/src/supervision/FormSupervision.component.js +168 -0
  169. package/dist/src/supervision/TableSupervision.component.d.ts +78 -0
  170. package/dist/src/supervision/TableSupervision.component.js +273 -0
  171. package/dist/src/table/ControlBar.component.d.ts +34 -0
  172. package/dist/src/table/ControlBar.component.js +205 -0
  173. package/dist/src/table/FilterComponent.d.ts +45 -0
  174. package/dist/src/table/FilterComponent.js +132 -0
  175. package/dist/src/table/Pagination.component.d.ts +8 -0
  176. package/dist/src/table/Pagination.component.js +32 -0
  177. package/dist/src/table/Table.component.d.ts +61 -0
  178. package/dist/src/table/Table.component.js +101 -0
  179. package/dist/src/typography/TypographyArticle.component.d.ts +8 -0
  180. package/dist/src/typography/TypographyArticle.component.js +7 -0
  181. package/dist/src/typography/TypographyColumn.component.d.ts +6 -0
  182. package/dist/src/typography/TypographyColumn.component.js +7 -0
  183. package/dist/src/typography/TypographyContent.component.d.ts +6 -0
  184. package/dist/src/typography/TypographyContent.component.js +7 -0
  185. package/dist/src/typography/TypographyTips.component.d.ts +6 -0
  186. package/dist/src/typography/TypographyTips.component.js +7 -0
  187. package/dist/src/wrap/Draggable.component.d.ts +34 -0
  188. package/dist/src/wrap/Draggable.component.js +214 -0
  189. package/dist/src/wrap/Image.component.d.ts +2 -0
  190. package/dist/src/wrap/Image.component.js +13 -0
  191. package/dist/src/wrap/OutsideClick.component.d.ts +6 -0
  192. package/dist/src/wrap/OutsideClick.component.js +34 -0
  193. package/dist/src/wrap/ScrollContainer.component.d.ts +10 -0
  194. package/dist/src/wrap/ScrollContainer.component.js +54 -0
  195. package/dist/src/wrap/ShortcutProvider.d.ts +1 -0
  196. package/dist/src/wrap/ShortcutProvider.js +42 -0
  197. package/dist/src/wrap/Swipe.component.d.ts +14 -0
  198. package/dist/src/wrap/Swipe.component.js +61 -0
  199. package/dist/supervision/FormSupervision.component.d.ts +93 -0
  200. package/dist/supervision/FormSupervision.component.js +168 -0
  201. package/dist/supervision/TableSupervision.component.d.ts +78 -0
  202. package/dist/supervision/TableSupervision.component.js +273 -0
  203. package/dist/table/ControlBar.component.d.ts +34 -0
  204. package/dist/table/ControlBar.component.js +205 -0
  205. package/dist/table/FilterComponent.d.ts +45 -0
  206. package/dist/table/FilterComponent.js +132 -0
  207. package/dist/table/Pagination.component.d.ts +8 -0
  208. package/dist/table/Pagination.component.js +32 -0
  209. package/dist/table/Table.component.d.ts +61 -0
  210. package/dist/table/Table.component.js +101 -0
  211. package/dist/typography/TypographyArticle.component.d.ts +8 -0
  212. package/dist/typography/TypographyArticle.component.js +7 -0
  213. package/dist/typography/TypographyColumn.component.d.ts +6 -0
  214. package/dist/typography/TypographyColumn.component.js +7 -0
  215. package/dist/typography/TypographyContent.component.d.ts +6 -0
  216. package/dist/typography/TypographyContent.component.js +7 -0
  217. package/dist/typography/TypographyTips.component.d.ts +6 -0
  218. package/dist/typography/TypographyTips.component.js +7 -0
  219. package/dist/wrap/Draggable.component.d.ts +1 -0
  220. package/dist/wrap/Draggable.component.js +214 -0
  221. package/dist/wrap/Image.component.d.ts +2 -0
  222. package/dist/wrap/Image.component.js +13 -0
  223. package/dist/wrap/OutsideClick.component.d.ts +6 -0
  224. package/dist/wrap/OutsideClick.component.js +34 -0
  225. package/dist/wrap/ScrollContainer.component.d.ts +10 -0
  226. package/dist/wrap/ScrollContainer.component.js +54 -0
  227. package/dist/wrap/ShortcutProvider.d.ts +1 -0
  228. package/dist/wrap/ShortcutProvider.js +42 -0
  229. package/dist/wrap/Swipe.component.d.ts +14 -0
  230. package/dist/wrap/Swipe.component.js +61 -0
  231. package/package.json +44 -0
@@ -0,0 +1,23 @@
1
+ "use client";
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.CheckboxComponent = CheckboxComponent;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const react_1 = require("react");
7
+ const react_fontawesome_1 = require("@fortawesome/react-fontawesome");
8
+ const free_solid_svg_icons_1 = require("@fortawesome/free-solid-svg-icons");
9
+ const _utils_1 = require("@utils");
10
+ function CheckboxComponent({ name, label, value, disabled = false, checked = false, invalid, onChange, className = "", }) {
11
+ // =========================>
12
+ // ## Initial
13
+ // =========================>
14
+ const randomId = (0, _utils_1.useInputRandomId)();
15
+ const [invalidMessage, setInvalidMessage] = (0, react_1.useState)("");
16
+ // =========================>
17
+ // ## Invalid handler
18
+ // =========================>
19
+ (0, react_1.useEffect)(() => {
20
+ setInvalidMessage(invalid || "");
21
+ }, [invalid]);
22
+ return ((0, jsx_runtime_1.jsxs)("div", { className: "checkbox-container", children: [(0, jsx_runtime_1.jsx)("input", { type: "checkbox", className: "hidden", id: randomId, name: name, onChange: onChange, defaultChecked: checked, value: value, disabled: disabled }), (0, jsx_runtime_1.jsxs)("label", { htmlFor: randomId, className: (0, _utils_1.cn)("checkbox-wrapper", disabled && "checkbox-wrapper-disabled"), children: [(0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("div", { className: (0, _utils_1.cn)("checkbox-input", checked && "checkbox-input-checked", checked && (0, _utils_1.pcn)(className, "checked"), (0, _utils_1.pcn)(className, "base")), children: checked && (0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { icon: free_solid_svg_icons_1.faCheck, className: "text-sm" }) }) }), (0, jsx_runtime_1.jsx)("span", { className: (0, _utils_1.cn)("checkbox-label", checked && "checkbox-label-checked", (0, _utils_1.pcn)(className, "label"), checked && (0, _utils_1.pcn)(className, "label", "checked"), disabled && (0, _utils_1.pcn)(className, "label", "disabled")), children: label })] }), invalidMessage && ((0, jsx_runtime_1.jsx)("small", { className: (0, _utils_1.cn)("input-error-message", (0, _utils_1.pcn)(className, "error")), children: invalidMessage }))] }));
23
+ }
@@ -0,0 +1,23 @@
1
+ import { InputHTMLAttributes, ReactNode, Ref } from "react";
2
+ import { ValidationRules } from "@utils";
3
+ export interface InputProps extends Omit<InputHTMLAttributes<HTMLInputElement>, "onChange"> {
4
+ label?: string;
5
+ tip?: string | ReactNode;
6
+ leftIcon?: any;
7
+ rightIcon?: any;
8
+ value?: any;
9
+ invalid?: string;
10
+ suggestions?: string[];
11
+ validations?: ValidationRules;
12
+ onlyAlphabet?: boolean;
13
+ uppercase?: boolean;
14
+ lowercase?: boolean;
15
+ multiple?: boolean;
16
+ onChange?: (value: any) => any;
17
+ register?: (name: string, validations?: ValidationRules) => void;
18
+ unregister?: (name: string) => void;
19
+ ref?: Ref<HTMLInputElement>;
20
+ /** Use custom class with: "label::", "tip::", "error::", "icon::", "suggest::", "suggest-item::". */
21
+ className?: string;
22
+ }
23
+ export declare function InputComponent({ label, tip, leftIcon, rightIcon, className, value, invalid, suggestions, validations, onlyAlphabet, uppercase, lowercase, multiple, register, unregister, onChange, ref, ...props }: InputProps): import("react").JSX.Element;
@@ -0,0 +1,134 @@
1
+ "use client";
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.InputComponent = InputComponent;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const react_1 = require("react");
7
+ const react_fontawesome_1 = require("@fortawesome/react-fontawesome");
8
+ const _utils_1 = require("@utils");
9
+ const InputValues_component_1 = require("./InputValues.component");
10
+ function InputComponent({ label, tip, leftIcon, rightIcon, className = "", value, invalid, suggestions, validations, onlyAlphabet, uppercase, lowercase, multiple, register, unregister, onChange, ref, ...props }) {
11
+ const [activeSuggestion, setActiveSuggestion] = (0, react_1.useState)(0);
12
+ const [showSuggestions, setShowSuggestions] = (0, react_1.useState)(false);
13
+ const [dataSuggestions, setDataSuggestions] = (0, react_1.useState)([]);
14
+ const [filteredSuggestions, setFilteredSuggestions] = (0, react_1.useState)([]);
15
+ // =========================>
16
+ // ## Initial
17
+ // =========================>
18
+ const inputHandler = (0, _utils_1.useInputHandler)(props.name, value, validations, register, unregister, props.type == "file");
19
+ const randomId = (0, _utils_1.useInputRandomId)();
20
+ // =========================>
21
+ // ## Invalid handler
22
+ // =========================>
23
+ const [invalidMessage] = (0, _utils_1.useValidation)(inputHandler.value, validations, invalid, inputHandler.idle);
24
+ // =========================>
25
+ // ## Change value handler
26
+ // =========================>
27
+ (0, react_1.useEffect)(() => {
28
+ if (inputHandler.value && typeof inputHandler.value === "string") {
29
+ let newVal = onlyAlphabet ? inputHandler.value.replace(/[^A-Za-z ]+/g, "") : inputHandler.value;
30
+ if (uppercase)
31
+ newVal = newVal.toUpperCase();
32
+ if (lowercase)
33
+ newVal = newVal.toLowerCase();
34
+ if (validations && _utils_1.validation.hasRules(validations, "max"))
35
+ newVal = newVal.slice(0, parseInt(_utils_1.validation.getRules(validations, "max") || "0"));
36
+ inputHandler.setValue(newVal);
37
+ }
38
+ }, [inputHandler.value, onlyAlphabet, uppercase, lowercase, validations]);
39
+ // =========================>
40
+ // ## suggestions handler
41
+ // =========================>
42
+ (0, react_1.useEffect)(() => {
43
+ setDataSuggestions(suggestions);
44
+ }, [suggestions]);
45
+ const filterSuggestion = (e) => {
46
+ if (dataSuggestions?.length) {
47
+ let filteredSuggestion = [];
48
+ if (e.target.value) {
49
+ filteredSuggestion = dataSuggestions
50
+ .filter((suggestion) => suggestion.toLowerCase().indexOf(e.target.value.toLowerCase()) > -1)
51
+ .slice(0, 10);
52
+ }
53
+ else {
54
+ filteredSuggestion = dataSuggestions.slice(0, 10);
55
+ }
56
+ setActiveSuggestion(-1);
57
+ setFilteredSuggestions(filteredSuggestion);
58
+ setShowSuggestions(true);
59
+ }
60
+ };
61
+ const onKeyDownSuggestion = (e) => {
62
+ if (dataSuggestions?.length) {
63
+ if (e.keyCode === 13) {
64
+ const resultValue = filteredSuggestions?.at(activeSuggestion);
65
+ setActiveSuggestion(-1);
66
+ setFilteredSuggestions([]);
67
+ setShowSuggestions(false);
68
+ inputHandler.setValue(resultValue ? resultValue : inputHandler.value);
69
+ if (onChange) {
70
+ onChange(resultValue ? resultValue : inputHandler.value);
71
+ }
72
+ e.preventDefault();
73
+ }
74
+ else if (e.keyCode === 38) {
75
+ if (activeSuggestion === 0) {
76
+ return;
77
+ }
78
+ setActiveSuggestion(activeSuggestion - 1);
79
+ }
80
+ else if (e.keyCode === 40) {
81
+ if (activeSuggestion + 1 >= (filteredSuggestions?.length || 0)) {
82
+ return;
83
+ }
84
+ setActiveSuggestion(activeSuggestion + 1);
85
+ }
86
+ }
87
+ };
88
+ return ((0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: (0, jsx_runtime_1.jsxs)("div", { className: "relative flex flex-col gap-y-0.5", children: [(0, jsx_runtime_1.jsxs)("label", { htmlFor: randomId, className: (0, _utils_1.cn)("input-label", props.disabled && "input-label-disabled", inputHandler.focus && "input-label-focus", !!invalidMessage && "input-label-error", (0, _utils_1.pcn)(className, "label"), props.disabled && (0, _utils_1.pcn)(className, "label", "disabled"), inputHandler.focus && (0, _utils_1.pcn)(className, "label", "focus"), !!invalidMessage && (0, _utils_1.pcn)(className, "label", "error")), children: [label, validations && _utils_1.validation.hasRules(validations, "required") && (0, jsx_runtime_1.jsx)("span", { className: "text-danger ml-1", children: "*" })] }), tip && ((0, jsx_runtime_1.jsx)("small", { className: (0, _utils_1.cn)("input-tip", props.disabled && "input-tip-disabled", (0, _utils_1.pcn)(className, "tip"), props.disabled && (0, _utils_1.pcn)(className, "tip", "disabled")), children: tip })), (0, jsx_runtime_1.jsxs)("div", { className: "relative", children: [(0, jsx_runtime_1.jsx)("input", { ...props, ref: ref, id: randomId, placeholder: !multiple || (multiple && !inputHandler.value?.length) ? props.placeholder : "", className: (0, _utils_1.cn)("input", props.type == "file" && "input-file", leftIcon && "input-with-left-icon", rightIcon && "input-with-right-icon", !!invalidMessage && "input-error", (0, _utils_1.pcn)(className, "base"), !!invalidMessage && (0, _utils_1.pcn)(className, "base", "error")), value: !multiple ? inputHandler.value : undefined, onChange: (e) => {
89
+ if (!multiple) {
90
+ inputHandler.setValue(e.target.value);
91
+ inputHandler.setIdle(false);
92
+ onChange?.(props.type == "file" ? e.target?.files && e.target?.files[0] : e.target.value);
93
+ dataSuggestions?.length && filterSuggestion(e);
94
+ }
95
+ }, onFocus: (e) => {
96
+ props.onFocus?.(e);
97
+ inputHandler.setFocus(true);
98
+ dataSuggestions?.length && filterSuggestion(e);
99
+ }, onBlur: (e) => {
100
+ props.onBlur?.(e);
101
+ setTimeout(() => inputHandler.setFocus(false), 100);
102
+ }, onKeyDown: (e) => {
103
+ dataSuggestions?.length && onKeyDownSuggestion(e);
104
+ if (multiple && e.key === "Enter" || e.key === ",") {
105
+ e.preventDefault();
106
+ const currentValue = e.currentTarget.value.trim();
107
+ if (!currentValue)
108
+ return;
109
+ const currentValues = Array.isArray(inputHandler.value) ? [...inputHandler.value] : [];
110
+ if (!currentValues.includes(currentValue)) {
111
+ const newValues = [...currentValues, currentValue];
112
+ onChange?.(newValues);
113
+ inputHandler.setValue(newValues);
114
+ e.currentTarget.value = "";
115
+ }
116
+ }
117
+ }, autoComplete: props.autoComplete || dataSuggestions?.length ? "off" : "" }), (multiple) && ((0, jsx_runtime_1.jsx)(InputValues_component_1.InputValues, { value: inputHandler.value || [], isFocus: inputHandler.focus, onFocus: () => setTimeout(() => inputHandler.setFocus(true), 110), onDelete: (_, index) => {
118
+ const values = Array().concat(inputHandler.value);
119
+ const newValues = values.filter((_, val) => val != index);
120
+ inputHandler.setValue(newValues);
121
+ onChange?.(newValues);
122
+ }, className: `${!inputHandler.focus && (leftIcon ? "ml-[2.5rem]" : "ml-[1rem]")}`, style: { maxWidth: `calc(100% - ${leftIcon ? "5.2rem" : "2rem"})` } })), leftIcon && ((0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { className: (0, _utils_1.cn)("input-icon", "input-icon-left", props.disabled && "input-icon-disabled", inputHandler.focus && "input-icon-focus", (0, _utils_1.pcn)(className, "icon"), props.disabled && (0, _utils_1.pcn)(className, "icon", "disabled"), inputHandler.focus && (0, _utils_1.pcn)(className, "icon", "focus")), icon: leftIcon })), rightIcon && ((0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { className: (0, _utils_1.cn)("input-icon", "input-icon-right", props.disabled && "input-icon-disabled", inputHandler.focus && "input-icon-focus", (0, _utils_1.pcn)(className, "icon"), props.disabled && (0, _utils_1.pcn)(className, "icon", "disabled"), inputHandler.focus && (0, _utils_1.pcn)(className, "icon", "focus")), icon: rightIcon }))] }), !!dataSuggestions?.length && showSuggestions && !!filteredSuggestions?.length && ((0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("ul", { className: (0, _utils_1.cn)("input-suggest-container", inputHandler.focus && "input-suggest-container-active", (0, _utils_1.pcn)(className, "suggest")), children: filteredSuggestions.map((suggestion, key) => {
123
+ return ((0, jsx_runtime_1.jsx)("li", { className: (0, _utils_1.cn)("input-suggest", inputHandler.value == suggestion && "input-suggest-active", (0, _utils_1.pcn)(className, "suggest-item"), inputHandler.value == suggestion && (0, _utils_1.pcn)(className, "suggest-item", "active")), onMouseDown: () => {
124
+ setTimeout(() => inputHandler.setFocus(true), 110);
125
+ }, onMouseUp: () => {
126
+ setActiveSuggestion(key);
127
+ setFilteredSuggestions([]);
128
+ setShowSuggestions(false);
129
+ inputHandler.setValue(filteredSuggestions[key] || inputHandler.value);
130
+ onChange?.(filteredSuggestions[key] || inputHandler.value);
131
+ setTimeout(() => inputHandler.setFocus(false), 120);
132
+ }, children: suggestion }, suggestion));
133
+ }) }) })), invalidMessage && ((0, jsx_runtime_1.jsx)("small", { className: (0, _utils_1.cn)("input-error-message", (0, _utils_1.pcn)(className, "error")), children: invalidMessage }))] }) }));
134
+ }
@@ -0,0 +1,27 @@
1
+ import { ReactNode } from "react";
2
+ import { ApiType, ValidationRules } from "@utils";
3
+ export interface InputCheckboxOptionProps {
4
+ value: string | number;
5
+ label: string;
6
+ }
7
+ export interface InputCheckboxProps {
8
+ name: string;
9
+ label?: string;
10
+ tip?: string | ReactNode;
11
+ vertical?: boolean;
12
+ value?: string[] | number[];
13
+ disabled?: boolean;
14
+ invalid?: string;
15
+ options?: InputCheckboxOptionProps[];
16
+ serverOptionControl?: ApiType;
17
+ customOptions?: any;
18
+ validations?: ValidationRules;
19
+ onChange?: (value: string[] | number[]) => any;
20
+ register?: (name: string, validations?: ValidationRules) => void;
21
+ unregister?: (name: string) => void;
22
+ /** Use custom class with: "label::", "tip::", "error::", "icon::". */
23
+ className?: string;
24
+ /** Use custom class with: "label::", "checked::", "error::". */
25
+ classNameCheckbox?: string;
26
+ }
27
+ export declare function InputCheckboxComponent({ name, label, tip, vertical, className, classNameCheckbox, value, disabled, invalid, options, serverOptionControl, customOptions, validations, register, unregister, onChange, }: InputCheckboxProps): import("react").JSX.Element;
@@ -0,0 +1,53 @@
1
+ "use client";
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.InputCheckboxComponent = InputCheckboxComponent;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const react_1 = require("react");
7
+ const _utils_1 = require("@utils");
8
+ const _components_1 = require("@components");
9
+ ;
10
+ ;
11
+ function InputCheckboxComponent({ name, label, tip, vertical, className = "", classNameCheckbox = "", value, disabled, invalid, options, serverOptionControl, customOptions, validations, register, unregister, onChange, }) {
12
+ const [dataOptions, setDataOptions] = (0, react_1.useState)([]);
13
+ const [loading, setLoading] = (0, react_1.useState)(false);
14
+ // =========================>
15
+ // ## initial
16
+ // =========================>
17
+ const inputHandler = (0, _utils_1.useInputHandler)(name, value, validations, register, unregister, false);
18
+ // =========================>
19
+ // ## Invalid handler
20
+ // =========================>
21
+ const [invalidMessage] = (0, _utils_1.useValidation)(inputHandler.value, validations, invalid, inputHandler.idle);
22
+ // =========================>
23
+ // ## fetch option
24
+ // =========================>
25
+ (0, react_1.useEffect)(() => {
26
+ const fetchOptions = async () => {
27
+ setLoading(true);
28
+ const mutateOptions = await (0, _utils_1.api)(serverOptionControl || {});
29
+ if (mutateOptions?.status == 200) {
30
+ customOptions ? setDataOptions([customOptions, ...mutateOptions.data]) : setDataOptions(mutateOptions.data);
31
+ setLoading(false);
32
+ }
33
+ };
34
+ if (serverOptionControl?.path || serverOptionControl?.url) {
35
+ fetchOptions();
36
+ }
37
+ else {
38
+ !options && setDataOptions([]);
39
+ }
40
+ }, [serverOptionControl?.path, serverOptionControl?.url]);
41
+ return ((0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: (0, jsx_runtime_1.jsxs)("div", { className: "input-container w-full", children: [(0, jsx_runtime_1.jsxs)("label", { className: (0, _utils_1.cn)("input-label", disabled && "input-label-disabled", invalidMessage && "input-label-error", (0, _utils_1.pcn)(className, "label"), disabled && (0, _utils_1.pcn)(className, "label", "disabled"), invalidMessage && (0, _utils_1.pcn)(className, "label", "focus")), children: [label, validations && _utils_1.validation.hasRules(validations, "required") && (0, jsx_runtime_1.jsx)("span", { className: "text-danger ml-1", children: "*" })] }), tip && ((0, jsx_runtime_1.jsx)("small", { className: (0, _utils_1.cn)("input-tip", disabled && "input-tip-disabled", (0, _utils_1.pcn)(className, "tip"), disabled && (0, _utils_1.pcn)(className, "tip", "disabled")), children: tip })), (0, jsx_runtime_1.jsxs)("div", { className: (0, _utils_1.cn)("input input-checkbox-list", vertical && "input-checkbox-list-vertical", (0, _utils_1.pcn)(className, "input"), invalidMessage && "input-error", invalidMessage && (0, _utils_1.pcn)(className, "input", "error")), children: [loading && (vertical ? [1, 2, 3, 4, 5, 6, 7, 8, 9] : [1, 2, 3]).map((_, key) => {
42
+ return (0, jsx_runtime_1.jsx)("div", { className: "w-1/3 h-6 rounded-lg" }, key);
43
+ }), (options || dataOptions) && (options || dataOptions)?.map((option, key) => {
44
+ const checked = Array().concat(inputHandler.value).find((val) => val == option.value);
45
+ return ((0, jsx_runtime_1.jsx)(_components_1.CheckboxComponent, { label: option.label, name: `option[${option.value}]#${name}`, checked: !!checked, disabled: disabled, className: classNameCheckbox, onChange: () => {
46
+ const newVal = (Array.isArray(inputHandler.value) ? inputHandler.value : [])
47
+ .filter((val) => val !== option.value)
48
+ .concat(checked ? [] : [option.value]);
49
+ inputHandler.setValue(newVal);
50
+ onChange?.(newVal);
51
+ } }, key));
52
+ })] }), invalidMessage && ((0, jsx_runtime_1.jsx)("small", { className: (0, _utils_1.cn)("input-error-message", (0, _utils_1.pcn)(className, "error")), children: invalidMessage }))] }) }));
53
+ }
@@ -0,0 +1,21 @@
1
+ import { InputHTMLAttributes, ReactNode } from "react";
2
+ import { ValidationRules } from "@utils";
3
+ export interface InputCurrencyProps extends Omit<InputHTMLAttributes<HTMLInputElement>, "onChange"> {
4
+ label?: string;
5
+ tip?: string | ReactNode;
6
+ leftIcon?: any;
7
+ rightIcon?: any;
8
+ value?: number;
9
+ invalid?: string;
10
+ validations?: ValidationRules;
11
+ format?: {
12
+ locale?: string;
13
+ currency?: string;
14
+ };
15
+ onChange?: (value: number) => any;
16
+ register?: (name: string, validations?: ValidationRules) => void;
17
+ unregister?: (name: string) => void;
18
+ /** Use custom class with: "label::", "tip::", "error::", "icon::". */
19
+ className?: string;
20
+ }
21
+ export declare function InputCurrencyComponent({ label, tip, leftIcon, rightIcon, value, invalid, validations, format, register, unregister, onChange, className, ...props }: InputCurrencyProps): import("react").JSX.Element;
@@ -0,0 +1,30 @@
1
+ "use client";
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.InputCurrencyComponent = InputCurrencyComponent;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const react_fontawesome_1 = require("@fortawesome/react-fontawesome");
7
+ const _utils_1 = require("@utils");
8
+ function InputCurrencyComponent({ label, tip, leftIcon, rightIcon, value, invalid, validations, format, register, unregister, onChange, className = "", ...props }) {
9
+ // =========================>
10
+ // ## Initial
11
+ // =========================>
12
+ const inputHandler = (0, _utils_1.useInputHandler)(props.name, value, validations, register, unregister, false);
13
+ const randomId = (0, _utils_1.useInputRandomId)();
14
+ // =========================>
15
+ // ## Invalid handler
16
+ // =========================>
17
+ const [invalidMessage] = (0, _utils_1.useValidation)(inputHandler.value, validations, invalid, inputHandler.idle);
18
+ return ((0, jsx_runtime_1.jsxs)("div", { className: "input-container", children: [(0, jsx_runtime_1.jsxs)("label", { htmlFor: randomId, className: (0, _utils_1.cn)("input-label", props.disabled && "input-label-disabled", inputHandler.focus && "input-label-focus", !!invalidMessage && "input-label-error", (0, _utils_1.pcn)(className, "label"), props.disabled && (0, _utils_1.pcn)(className, "label", "disabled"), inputHandler.focus && (0, _utils_1.pcn)(className, "label", "focus"), !!invalidMessage && (0, _utils_1.pcn)(className, "label", "focus")), children: [label, validations && _utils_1.validation.hasRules(validations, "required") && (0, jsx_runtime_1.jsx)("span", { className: "text-danger ml-1", children: "*" })] }), tip && ((0, jsx_runtime_1.jsx)("small", { className: (0, _utils_1.cn)("input-tip", props.disabled && "input-tip-disabled", (0, _utils_1.pcn)(className, "tip"), props.disabled && (0, _utils_1.pcn)(className, "tip", "disabled")), children: tip })), (0, jsx_runtime_1.jsxs)("div", { className: "relative", children: [(0, jsx_runtime_1.jsx)("input", { ...props, id: randomId, className: (0, _utils_1.cn)("input", leftIcon && "input-with-left-icon", rightIcon && "input-with-right-icon", (0, _utils_1.pcn)(className, "input"), !!invalidMessage && "input-error", !!invalidMessage && (0, _utils_1.pcn)(className, "input", "error")), value: inputHandler.value ? _utils_1.conversion.currency(inputHandler.value, format?.locale, format?.currency) : "", onChange: (e) => {
19
+ const val = Number(e.target.value.replace(/[^0-9]/g, ""));
20
+ inputHandler.setValue(val);
21
+ inputHandler.setIdle(false);
22
+ onChange?.(val);
23
+ }, onFocus: (e) => {
24
+ props.onFocus?.(e);
25
+ inputHandler.setFocus(true);
26
+ }, onBlur: (e) => {
27
+ props.onBlur?.(e);
28
+ setTimeout(() => inputHandler.setFocus(false), 100);
29
+ }, autoComplete: "off" }), leftIcon && ((0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { className: (0, _utils_1.cn)("input-icon", "input-icon-left", props.disabled && "input-icon-disabled", inputHandler.focus && "input-icon-focus", (0, _utils_1.pcn)(className, "icon"), props.disabled && (0, _utils_1.pcn)(className, "icon", "disabled"), inputHandler.focus && (0, _utils_1.pcn)(className, "icon", "focus")), icon: leftIcon })), rightIcon && ((0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { className: (0, _utils_1.cn)("input-icon", "input-icon-right", props.disabled && "input-icon-disabled", inputHandler.focus && "input-icon-focus", (0, _utils_1.pcn)(className, "icon"), props.disabled && (0, _utils_1.pcn)(className, "icon", "disabled"), inputHandler.focus && (0, _utils_1.pcn)(className, "icon", "focus")), icon: rightIcon }))] }), invalidMessage && ((0, jsx_runtime_1.jsx)("small", { className: (0, _utils_1.cn)("input-error-message", (0, _utils_1.pcn)(className, "error")), children: invalidMessage }))] }));
30
+ }
@@ -0,0 +1,24 @@
1
+ import { InputHTMLAttributes, ReactNode } from "react";
2
+ import { ValidationRules } from "@utils";
3
+ export interface InputDateProps extends Omit<InputHTMLAttributes<HTMLInputElement>, "onChange"> {
4
+ label?: string;
5
+ tip?: string | ReactNode;
6
+ leftIcon?: any;
7
+ rightIcon?: any;
8
+ value?: string;
9
+ invalid?: string;
10
+ validations?: ValidationRules;
11
+ onChange?: (value: string) => any;
12
+ register?: (name: string, validations?: ValidationRules) => void;
13
+ unregister?: (name: string) => void;
14
+ /** Use custom class with: "label::", "tip::", "error::", "icon::". */
15
+ className?: string;
16
+ }
17
+ export declare function InputDateComponent({ label, tip, leftIcon, rightIcon, value, invalid, validations, register, unregister, onChange, className, ...props }: InputDateProps): import("react").JSX.Element;
18
+ export interface InputDatePickerProps {
19
+ onChange?: (date: string) => void;
20
+ minDate?: string;
21
+ maxDate?: string;
22
+ rightElement?: ReactNode;
23
+ }
24
+ export declare const InputDatePickerComponent: React.FC<InputDatePickerProps>;
@@ -0,0 +1,107 @@
1
+ "use client";
2
+ "use strict";
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod };
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.InputDatePickerComponent = void 0;
8
+ exports.InputDateComponent = InputDateComponent;
9
+ const jsx_runtime_1 = require("react/jsx-runtime");
10
+ const react_1 = require("react");
11
+ const moment_1 = __importDefault(require("moment"));
12
+ const react_fontawesome_1 = require("@fortawesome/react-fontawesome");
13
+ const free_solid_svg_icons_1 = require("@fortawesome/free-solid-svg-icons");
14
+ const _utils_1 = require("@utils");
15
+ const _components_1 = require("@components");
16
+ function InputDateComponent({ label, tip, leftIcon, rightIcon, value, invalid, validations, register, unregister, onChange, className = "", ...props }) {
17
+ const { isSm } = (0, _utils_1.useResponsive)();
18
+ // =========================>
19
+ // ## Initial
20
+ // =========================>
21
+ const inputHandler = (0, _utils_1.useInputHandler)(props.name, value, validations, register, unregister, false);
22
+ const randomId = (0, _utils_1.useInputRandomId)();
23
+ // =========================>
24
+ // ## Invalid handler
25
+ // =========================>
26
+ const [invalidMessage] = (0, _utils_1.useValidation)(inputHandler.value, validations, invalid, inputHandler.idle);
27
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsxs)("div", { className: "input-container", children: [(0, jsx_runtime_1.jsxs)("label", { htmlFor: randomId, className: (0, _utils_1.cn)("input-label", props.disabled && "input-label-disabled", inputHandler.focus && "input-label-focus", !!invalidMessage && "input-label-error", (0, _utils_1.pcn)(className, "label"), props.disabled && (0, _utils_1.pcn)(className, "label", "disabled"), inputHandler.focus && (0, _utils_1.pcn)(className, "label", "focus"), !!invalidMessage && (0, _utils_1.pcn)(className, "label", "error")), children: [label, validations && _utils_1.validation.hasRules(validations, "required") && (0, jsx_runtime_1.jsx)("span", { className: "text-danger ml-1", children: "*" })] }), tip && ((0, jsx_runtime_1.jsx)("small", { className: (0, _utils_1.cn)("input-tip", props.disabled && "input-tip-disabled", (0, _utils_1.pcn)(className, "tip"), props.disabled && (0, _utils_1.pcn)(className, "tip", "disabled")), children: tip })), (0, jsx_runtime_1.jsx)(_components_1.OutsideClickComponent, { onOutsideClick: !isSm ? () => inputHandler.setFocus(false) : undefined, children: (0, jsx_runtime_1.jsxs)("div", { className: "relative", children: [(0, jsx_runtime_1.jsx)("input", { ...props, id: randomId, className: (0, _utils_1.cn)("input", leftIcon && "input-with-left-icon", rightIcon && "input-with-right-icon", (0, _utils_1.pcn)(className, "input"), !!invalidMessage && "input-error", !!invalidMessage && (0, _utils_1.pcn)(className, "input", "error")), value: inputHandler.value, onChange: (e) => {
28
+ inputHandler.setValue(e.target.value);
29
+ inputHandler.setValue(false);
30
+ onChange?.(e.target.value);
31
+ }, onFocus: (e) => {
32
+ props.onFocus?.(e);
33
+ inputHandler.setFocus(true);
34
+ }, onBlur: (e) => {
35
+ props.onBlur?.(e);
36
+ }, autoComplete: "off", inputMode: isSm ? "none" : undefined }), leftIcon && ((0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { className: (0, _utils_1.cn)("input-icon", "input-icon-left", props.disabled && "input-icon-disabled", inputHandler.focus && "input-icon-focus", (0, _utils_1.pcn)(className, "icon"), props.disabled && (0, _utils_1.pcn)(className, "icon", "disabled"), inputHandler.focus && (0, _utils_1.pcn)(className, "icon", "focus")), icon: leftIcon })), rightIcon && ((0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { className: (0, _utils_1.cn)("input-icon", "input-icon-right", props.disabled && "input-icon-disabled", inputHandler.focus && "input-icon-focus", (0, _utils_1.pcn)(className, "icon"), props.disabled && (0, _utils_1.pcn)(className, "icon", "disabled"), inputHandler.focus && (0, _utils_1.pcn)(className, "icon", "focus")), icon: rightIcon })), !isSm && inputHandler.focus && ((0, jsx_runtime_1.jsx)("div", { className: "input-date-picker-popover", children: (0, jsx_runtime_1.jsx)(exports.InputDatePickerComponent, { onChange: (e) => {
37
+ inputHandler.setValue(e);
38
+ onChange?.(e);
39
+ } }) }))] }) }), invalidMessage && ((0, jsx_runtime_1.jsx)("small", { className: (0, _utils_1.cn)("input-error-message", (0, _utils_1.pcn)(className, "error")), children: invalidMessage }))] }), isSm && ((0, jsx_runtime_1.jsx)(_components_1.BottomSheetComponent, { show: inputHandler.focus, onClose: () => inputHandler.setFocus(false), size: 380, footer: (0, jsx_runtime_1.jsx)("div", { className: "p-4", children: (0, jsx_runtime_1.jsx)(_components_1.ButtonComponent, { label: "Selesai", variant: "outline", onClick: () => inputHandler.setFocus(false), block: true }) }), children: (0, jsx_runtime_1.jsx)("div", { className: "p-4", children: (0, jsx_runtime_1.jsx)(exports.InputDatePickerComponent, { onChange: (e) => {
40
+ inputHandler.setValue(e);
41
+ onChange?.(e);
42
+ } }) }) }))] }));
43
+ }
44
+ ;
45
+ const InputDatePickerComponent = ({ onChange, minDate, maxDate, rightElement, }) => {
46
+ const activeYearRef = (0, react_1.useRef)(null);
47
+ const containerYearRef = (0, react_1.useRef)(null);
48
+ const [currentDate, setCurrentDate] = (0, react_1.useState)((0, moment_1.default)());
49
+ const [selectedDate, setSelectedDate] = (0, react_1.useState)((0, moment_1.default)());
50
+ const startDate = (0, moment_1.default)(currentDate).startOf("month").startOf("week");
51
+ const endDate = (0, moment_1.default)(currentDate).endOf("month").endOf("week");
52
+ const handlePrevMonth = () => setCurrentDate((0, moment_1.default)(currentDate).subtract(1, "month"));
53
+ const handleNextMonth = () => setCurrentDate((0, moment_1.default)(currentDate).add(1, "month"));
54
+ const handleDateClick = (date) => {
55
+ if ((minDate && date.isBefore((0, moment_1.default)(minDate))) || (maxDate && date.isAfter((0, moment_1.default)(maxDate)))) {
56
+ return;
57
+ }
58
+ setSelectedDate(date);
59
+ onChange?.(date.format("YYYY-MM-DD"));
60
+ };
61
+ const renderDays = () => {
62
+ const days = [];
63
+ const startDay = (0, moment_1.default)(startDate);
64
+ for (let i = 0; i < 7; i++) {
65
+ days.push((0, jsx_runtime_1.jsx)("div", { className: "text-center font-bold", children: startDay.add(i, "days").format("dd") }, i));
66
+ }
67
+ return days;
68
+ };
69
+ const renderCells = () => {
70
+ const rows = [];
71
+ let days = [];
72
+ const day = (0, moment_1.default)(startDate);
73
+ while (day.isBefore(endDate) || day.isSame(endDate, "day")) {
74
+ for (let i = 0; i < 7; i++) {
75
+ const cloneDay = (0, moment_1.default)(day);
76
+ days.push((0, jsx_runtime_1.jsx)("div", { className: `w-8 aspect-square flex items-center justify-center text-center rounded-lg transition-all
77
+ ${day.isSame(currentDate, "month") ? "text-foreground" : "text-light-foreground"}
78
+ ${day.isSame(selectedDate, "day") ? "bg-primary text-background" : "hover:bg-light-primary"}
79
+ ${day.isSame((0, moment_1.default)(), "day") ? "border !border-primary" : "hover:bg-light-primary"}
80
+ ${(minDate && day.isBefore((0, moment_1.default)(minDate))) || (maxDate && day.isAfter((0, moment_1.default)(maxDate))) ? "opacity-10 cursor-not-allowed" : "cursor-pointer"}`, onClick: () => handleDateClick(cloneDay), children: day.format("D") }, day.toString()));
81
+ day.add(1, "day");
82
+ }
83
+ rows.push((0, jsx_runtime_1.jsx)("div", { className: "grid grid-cols-7 gap-1", children: days }, day.toString()));
84
+ days = [];
85
+ }
86
+ return rows;
87
+ };
88
+ const years = (0, react_1.useMemo)(() => {
89
+ const dumpYears = [];
90
+ for (let i = 1945; i <= (0, moment_1.default)().year(); i++) {
91
+ dumpYears.push(i);
92
+ }
93
+ return dumpYears;
94
+ }, []);
95
+ (0, react_1.useEffect)(() => {
96
+ if (activeYearRef.current && containerYearRef.current) {
97
+ containerYearRef.current.scrollTo({
98
+ top: activeYearRef.current.offsetTop - containerYearRef.current.offsetTop,
99
+ });
100
+ }
101
+ }, []);
102
+ return ((0, jsx_runtime_1.jsxs)("div", { className: "w-full flex gap-2 max-h-[260]", children: [(0, jsx_runtime_1.jsx)("div", { className: "w-1/5 overflow-y-auto input-scroll pr-1", ref: containerYearRef, children: (0, jsx_runtime_1.jsx)("div", { className: "flex flex-col", children: years?.map((item) => {
103
+ const isActive = currentDate?.year() === item;
104
+ return ((0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: (0, jsx_runtime_1.jsx)("div", { ref: isActive ? activeYearRef : null, className: `py-1 px-2 font-semibold rounded-[6px] cursor-pointer ${isActive && "bg-light-primary"}`, onClick: () => setCurrentDate((0, moment_1.default)().set("year", item)), children: item }, item) }));
105
+ }) }) }), (0, jsx_runtime_1.jsxs)("div", { className: "w-4/5", children: [(0, jsx_runtime_1.jsxs)("div", { className: "flex justify-between items-center mb-2", children: [(0, jsx_runtime_1.jsx)("button", { onClick: handlePrevMonth, className: "w-8 text-sm aspect-square rounded-full cursor-pointer", children: (0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { icon: free_solid_svg_icons_1.faChevronLeft }) }), (0, jsx_runtime_1.jsx)("h2", { className: "font-semibold", children: currentDate.format("MMMM") }), (0, jsx_runtime_1.jsx)("button", { onClick: handleNextMonth, className: "w-8 text-sm aspect-square rounded-full cursor-pointer", children: (0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { icon: free_solid_svg_icons_1.faChevronRight }) })] }), (0, jsx_runtime_1.jsx)("div", { className: "grid grid-cols-7 gap-1 mb-2", children: renderDays() }), (0, jsx_runtime_1.jsx)("div", { children: renderCells() })] }), rightElement && (0, jsx_runtime_1.jsx)("div", { children: rightElement })] }));
106
+ };
107
+ exports.InputDatePickerComponent = InputDatePickerComponent;
@@ -0,0 +1,17 @@
1
+ import { InputHTMLAttributes, ReactNode } from "react";
2
+ import { ValidationRules } from "@utils";
3
+ export interface InputDateTimeProps extends Omit<InputHTMLAttributes<HTMLInputElement>, "onChange"> {
4
+ label?: string;
5
+ tip?: string | ReactNode;
6
+ leftIcon?: any;
7
+ rightIcon?: any;
8
+ value?: string;
9
+ invalid?: string;
10
+ validations?: ValidationRules;
11
+ onChange?: (value: string) => any;
12
+ register?: (name: string, validations?: ValidationRules) => void;
13
+ unregister?: (name: string) => void;
14
+ /** Use custom class with: "label::", "tip::", "error::", "icon::", "suggest::", "suggest-item::". */
15
+ className?: string;
16
+ }
17
+ export declare function InputDatetimeComponent({ label, tip, leftIcon, rightIcon, value, invalid, validations, register, unregister, onChange, className, ...props }: InputDateTimeProps): import("react").JSX.Element;
@@ -0,0 +1,75 @@
1
+ "use client";
2
+ "use strict";
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.InputDatetimeComponent = InputDatetimeComponent;
5
+ const jsx_runtime_1 = require("react/jsx-runtime");
6
+ const react_1 = require("react");
7
+ const react_fontawesome_1 = require("@fortawesome/react-fontawesome");
8
+ const _utils_1 = require("@utils");
9
+ const _components_1 = require("@components");
10
+ function InputDatetimeComponent({ label, tip, leftIcon, rightIcon, value, invalid, validations, register, unregister, onChange, className = "", ...props }) {
11
+ const { isSm } = (0, _utils_1.useResponsive)();
12
+ const [pickerType, setPickerType] = (0, react_1.useState)("date");
13
+ const [dateValue, setDateValue] = (0, react_1.useState)("");
14
+ const [timeValue, setTimeValue] = (0, react_1.useState)("");
15
+ // =========================>
16
+ // ## Initial
17
+ // =========================>
18
+ const inputHandler = (0, _utils_1.useInputHandler)(props.name, value, validations, register, unregister, false);
19
+ const randomId = (0, _utils_1.useInputRandomId)();
20
+ // =========================>
21
+ // ## Invalid handler
22
+ // =========================>
23
+ const [invalidMessage] = (0, _utils_1.useValidation)(inputHandler.value, validations, invalid, inputHandler.idle);
24
+ // =========================>
25
+ // ## change value handler
26
+ // =========================>
27
+ (0, react_1.useEffect)(() => {
28
+ inputHandler.setValue(value || "");
29
+ value && inputHandler.setValue(false);
30
+ if (value) {
31
+ const [d, t] = value.split(" ");
32
+ setDateValue(d || "");
33
+ setTimeValue(t || "");
34
+ }
35
+ }, [value]);
36
+ const handleChange = (date, time) => {
37
+ const newVal = `${date} ${time}`;
38
+ inputHandler.setValue(newVal.trim());
39
+ onChange?.(newVal.trim());
40
+ };
41
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsxs)("div", { className: "input-container", children: [(0, jsx_runtime_1.jsxs)("label", { htmlFor: randomId, className: (0, _utils_1.cn)("input-label", props.disabled && "input-label-disabled", inputHandler.focus && "input-label-focus", !!invalidMessage && "input-label-error", (0, _utils_1.pcn)(className, "label")), children: [label, validations && _utils_1.validation.hasRules(validations, "required") && (0, jsx_runtime_1.jsx)("span", { className: "text-danger ml-1", children: "*" })] }), tip && ((0, jsx_runtime_1.jsx)("small", { className: (0, _utils_1.cn)("input-tip", props.disabled && "input-tip-disabled", (0, _utils_1.pcn)(className, "tip")), children: tip })), (0, jsx_runtime_1.jsx)(_components_1.OutsideClickComponent, { onOutsideClick: !isSm ? () => inputHandler.setFocus(false) : undefined, children: (0, jsx_runtime_1.jsxs)("div", { className: "relative", children: [(0, jsx_runtime_1.jsx)("input", { ...props, id: randomId, readOnly: true, className: (0, _utils_1.cn)("input", leftIcon && "input-with-left-icon", rightIcon && "input-with-right-icon", (0, _utils_1.pcn)(className, "input"), !!invalidMessage && "input-error"), value: inputHandler.value, onFocus: (e) => {
42
+ props.onFocus?.(e);
43
+ inputHandler.setFocus(true);
44
+ }, autoComplete: "off", inputMode: isSm ? "none" : undefined }), leftIcon && ((0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { className: (0, _utils_1.cn)("input-icon", "input-icon-left", props.disabled && "input-icon-disabled", inputHandler.focus && "input-icon-focus", (0, _utils_1.pcn)(className, "icon")), icon: leftIcon })), rightIcon && ((0, jsx_runtime_1.jsx)(react_fontawesome_1.FontAwesomeIcon, { className: (0, _utils_1.cn)("input-icon", "input-icon-right", props.disabled && "input-icon-disabled", inputHandler.focus && "input-icon-focus", (0, _utils_1.pcn)(className, "icon")), icon: rightIcon })), !isSm && inputHandler.focus && ((0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: (0, jsx_runtime_1.jsxs)("div", { className: "input-datetime-picker-popover", children: [(0, jsx_runtime_1.jsx)(_components_1.TabbarComponent, { items: [
45
+ {
46
+ label: "Tanggal",
47
+ value: 'date'
48
+ },
49
+ {
50
+ label: "Jam",
51
+ value: 'time'
52
+ },
53
+ ], active: pickerType, onChange: (e) => setPickerType(e), className: "mb-4" }), pickerType === "date" ? ((0, jsx_runtime_1.jsx)(_components_1.InputDatePickerComponent, { onChange: (e) => {
54
+ setDateValue(e);
55
+ handleChange(e, timeValue);
56
+ } })) : ((0, jsx_runtime_1.jsx)(_components_1.InputTimePickerComponent, { onChange: (e) => {
57
+ setTimeValue(e);
58
+ handleChange(dateValue, e);
59
+ } }))] }) }))] }) }), invalidMessage && ((0, jsx_runtime_1.jsx)("small", { className: (0, _utils_1.cn)("input-error-message", (0, _utils_1.pcn)(className, "error")), children: invalidMessage }))] }), isSm && ((0, jsx_runtime_1.jsx)(_components_1.BottomSheetComponent, { show: inputHandler.focus, onClose: () => inputHandler.setFocus(false), size: 430, footer: (0, jsx_runtime_1.jsx)("div", { className: "p-4", children: (0, jsx_runtime_1.jsx)(_components_1.ButtonComponent, { label: "Selesai", variant: "outline", onClick: () => inputHandler.setFocus(false), block: true }) }), children: (0, jsx_runtime_1.jsxs)("div", { className: "p-4", children: [(0, jsx_runtime_1.jsx)(_components_1.TabbarComponent, { items: [
60
+ {
61
+ label: "Tanggal",
62
+ value: 'date'
63
+ },
64
+ {
65
+ label: "Jam",
66
+ value: 'time'
67
+ },
68
+ ], active: pickerType, onChange: (e) => setPickerType(e), className: "mb-4" }), pickerType === "date" ? ((0, jsx_runtime_1.jsx)(_components_1.InputDatePickerComponent, { onChange: (e) => {
69
+ setDateValue(e);
70
+ handleChange(e, timeValue);
71
+ } })) : ((0, jsx_runtime_1.jsx)(_components_1.InputTimePickerComponent, { onChange: (e) => {
72
+ setTimeValue(e);
73
+ handleChange(dateValue, e);
74
+ } }))] }) }))] }));
75
+ }
@@ -0,0 +1,22 @@
1
+ import { InputHTMLAttributes, ReactNode } from "react";
2
+ import { ValidationRules } from "@utils";
3
+ export interface InputDocumentProps extends Omit<InputHTMLAttributes<HTMLInputElement>, "onChange"> {
4
+ label?: string;
5
+ tip?: string | ReactNode;
6
+ leftIcon?: any;
7
+ rightIcon?: any;
8
+ value?: any;
9
+ invalid?: string;
10
+ validations?: ValidationRules;
11
+ onChange?: (value: any) => any;
12
+ register?: (name: string, validations?: ValidationRules) => void;
13
+ unregister?: (name: string) => void;
14
+ /** Use custom class with: "label::", "tip::", "error::", "icon::", "suggest::", "suggest-item::". */
15
+ className?: string;
16
+ }
17
+ export declare function InputDocumentComponent({ label, tip, leftIcon, rightIcon, className, value, invalid, validations, register, unregister, onChange, ...props }: InputDocumentProps): import("react").JSX.Element;
18
+ export interface InputDocumentPickerProps {
19
+ value?: any[];
20
+ onChange?: (value: any[]) => void;
21
+ }
22
+ export declare const InputDocumentPicker: React.FC<InputDocumentPickerProps>;