@apia/components 1.0.4 → 2.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 (402) hide show
  1. package/dist/components/IconsList/Icon.js +42 -0
  2. package/dist/components/IconsList/Icon.js.map +1 -0
  3. package/dist/components/IconsList/IconWrapper.js +24 -0
  4. package/dist/components/IconsList/IconWrapper.js.map +1 -0
  5. package/dist/components/IconsList/KeyHandler.js +147 -0
  6. package/dist/components/IconsList/KeyHandler.js.map +1 -0
  7. package/dist/components/IconsList/context.js +14 -0
  8. package/dist/components/IconsList/context.js.map +1 -0
  9. package/dist/components/IconsList/index.d.ts +12 -0
  10. package/dist/components/IconsList/index.d.ts.map +1 -0
  11. package/dist/components/IconsList/index.js +119 -0
  12. package/dist/components/IconsList/index.js.map +1 -0
  13. package/dist/components/IconsList/renderers/DefaultIconRenderer.d.ts +7 -0
  14. package/dist/components/IconsList/renderers/DefaultIconRenderer.d.ts.map +1 -0
  15. package/dist/components/IconsList/renderers/DefaultIconRenderer.js +30 -0
  16. package/dist/components/IconsList/renderers/DefaultIconRenderer.js.map +1 -0
  17. package/dist/components/IconsList/store/context.js +9 -0
  18. package/dist/components/IconsList/store/context.js.map +1 -0
  19. package/dist/components/IconsList/store/distinctors.js +42 -0
  20. package/dist/components/IconsList/store/distinctors.js.map +1 -0
  21. package/dist/components/IconsList/store/keysMaker.js +8 -0
  22. package/dist/components/IconsList/store/keysMaker.js.map +1 -0
  23. package/dist/components/IconsList/store/operations.js +138 -0
  24. package/dist/components/IconsList/store/operations.js.map +1 -0
  25. package/dist/components/IconsList/store/state.js +9 -0
  26. package/dist/components/IconsList/store/state.js.map +1 -0
  27. package/dist/components/IconsList/store/useStore.js +52 -0
  28. package/dist/components/IconsList/store/useStore.js.map +1 -0
  29. package/dist/components/IconsList/styles.js +48 -0
  30. package/dist/components/IconsList/styles.js.map +1 -0
  31. package/dist/components/IconsList/types.d.ts +98 -0
  32. package/dist/components/IconsList/types.d.ts.map +1 -0
  33. package/dist/components/IconsList/util.js +46 -0
  34. package/dist/components/IconsList/util.js.map +1 -0
  35. package/dist/components/ListBox/Combobox.js +52 -0
  36. package/dist/components/ListBox/Combobox.js.map +1 -0
  37. package/dist/components/ListBox/ListboxContext.d.ts +35 -0
  38. package/dist/components/ListBox/ListboxContext.d.ts.map +1 -0
  39. package/dist/components/ListBox/ListboxContext.js +6 -0
  40. package/dist/components/ListBox/ListboxContext.js.map +1 -0
  41. package/dist/components/ListBox/ListboxItem.d.ts +17 -0
  42. package/dist/components/ListBox/ListboxItem.d.ts.map +1 -0
  43. package/dist/components/ListBox/ListboxItem.js +67 -0
  44. package/dist/components/ListBox/ListboxItem.js.map +1 -0
  45. package/dist/components/ListBox/ListboxKeyhandler.js +154 -0
  46. package/dist/components/ListBox/ListboxKeyhandler.js.map +1 -0
  47. package/dist/components/ListBox/common.d.ts +46 -0
  48. package/dist/components/ListBox/common.d.ts.map +1 -0
  49. package/dist/components/ListBox/common.js +118 -0
  50. package/dist/components/ListBox/common.js.map +1 -0
  51. package/dist/components/ListBox/index.d.ts +21 -0
  52. package/dist/components/ListBox/index.d.ts.map +1 -0
  53. package/dist/components/ListBox/index.js +71 -0
  54. package/dist/components/ListBox/index.js.map +1 -0
  55. package/dist/components/ListBox/listbox.js +46 -0
  56. package/dist/components/ListBox/listbox.js.map +1 -0
  57. package/dist/components/ListBox/operations.js +330 -0
  58. package/dist/components/ListBox/operations.js.map +1 -0
  59. package/dist/components/ListBox/useIndexedChildren.js +25 -0
  60. package/dist/components/ListBox/useIndexedChildren.js.map +1 -0
  61. package/dist/components/ListBox/useListboxAutofocus.js +48 -0
  62. package/dist/components/ListBox/useListboxAutofocus.js.map +1 -0
  63. package/dist/components/ListBox/useListboxContextValue.js +8 -0
  64. package/dist/components/ListBox/useListboxContextValue.js.map +1 -0
  65. package/dist/components/ListBox/useShoutSelectionChange.js +26 -0
  66. package/dist/components/ListBox/useShoutSelectionChange.js.map +1 -0
  67. package/dist/components/ListBox/useStore.js +36 -0
  68. package/dist/components/ListBox/useStore.js.map +1 -0
  69. package/dist/components/ListBox/useUpdateRowCount.js +19 -0
  70. package/dist/components/ListBox/useUpdateRowCount.js.map +1 -0
  71. package/dist/components/SortableList/SortableListHandler.js +161 -0
  72. package/dist/components/SortableList/SortableListHandler.js.map +1 -0
  73. package/dist/components/SortableList/SortableListItem.d.ts +14 -0
  74. package/dist/components/SortableList/SortableListItem.d.ts.map +1 -0
  75. package/dist/components/SortableList/SortableListItem.js +24 -0
  76. package/dist/components/SortableList/SortableListItem.js.map +1 -0
  77. package/dist/components/SortableList/index.d.ts +21 -0
  78. package/dist/components/SortableList/index.d.ts.map +1 -0
  79. package/dist/components/SortableList/index.js +53 -0
  80. package/dist/components/SortableList/index.js.map +1 -0
  81. package/dist/components/Toolbar/ToolbarController.d.ts +24 -0
  82. package/dist/components/Toolbar/ToolbarController.d.ts.map +1 -0
  83. package/dist/components/Toolbar/ToolbarController.js +50 -0
  84. package/dist/components/Toolbar/ToolbarController.js.map +1 -0
  85. package/dist/components/Toolbar/ToolbarIconButton.d.ts +7 -0
  86. package/dist/components/Toolbar/ToolbarIconButton.d.ts.map +1 -0
  87. package/dist/components/Toolbar/ToolbarIconButton.js +110 -0
  88. package/dist/components/Toolbar/ToolbarIconButton.js.map +1 -0
  89. package/dist/components/Toolbar/ToolbarInput.d.ts +7 -0
  90. package/dist/components/Toolbar/ToolbarInput.d.ts.map +1 -0
  91. package/dist/components/Toolbar/ToolbarInput.js +13 -0
  92. package/dist/components/Toolbar/ToolbarInput.js.map +1 -0
  93. package/dist/components/Toolbar/ToolbarSelect.d.ts +7 -0
  94. package/dist/components/Toolbar/ToolbarSelect.d.ts.map +1 -0
  95. package/dist/components/Toolbar/ToolbarSelect.js +17 -0
  96. package/dist/components/Toolbar/ToolbarSelect.js.map +1 -0
  97. package/dist/components/Toolbar/ToolbarSeparator.d.ts +6 -0
  98. package/dist/components/Toolbar/ToolbarSeparator.d.ts.map +1 -0
  99. package/dist/components/Toolbar/ToolbarSeparator.js +9 -0
  100. package/dist/components/Toolbar/ToolbarSeparator.js.map +1 -0
  101. package/dist/components/Toolbar/ToolbarTextButton.d.ts +9 -0
  102. package/dist/components/Toolbar/ToolbarTextButton.d.ts.map +1 -0
  103. package/dist/components/Toolbar/ToolbarTextButton.js +18 -0
  104. package/dist/components/Toolbar/ToolbarTextButton.js.map +1 -0
  105. package/dist/components/Toolbar/index.d.ts +17 -0
  106. package/dist/components/Toolbar/index.d.ts.map +1 -0
  107. package/dist/components/Toolbar/index.js +26 -0
  108. package/dist/components/Toolbar/index.js.map +1 -0
  109. package/dist/components/Toolbar/styles.js +84 -0
  110. package/dist/components/Toolbar/styles.js.map +1 -0
  111. package/dist/components/Toolbar/types.d.ts +40 -0
  112. package/dist/components/Toolbar/types.d.ts.map +1 -0
  113. package/dist/components/accordion/Accordion.d.ts +20 -0
  114. package/dist/components/accordion/Accordion.d.ts.map +1 -0
  115. package/dist/components/accordion/Accordion.js +60 -0
  116. package/dist/components/accordion/Accordion.js.map +1 -0
  117. package/dist/components/accordion/AccordionItem.d.ts +19 -0
  118. package/dist/components/accordion/AccordionItem.d.ts.map +1 -0
  119. package/dist/components/accordion/AccordionItem.js +22 -0
  120. package/dist/components/accordion/AccordionItem.js.map +1 -0
  121. package/dist/components/accordion/AccordionItemButton.d.ts +10 -0
  122. package/dist/components/accordion/AccordionItemButton.d.ts.map +1 -0
  123. package/dist/components/accordion/AccordionItemButton.js +8 -0
  124. package/dist/components/accordion/AccordionItemButton.js.map +1 -0
  125. package/dist/components/accordion/AccordionItemContent.d.ts +7 -0
  126. package/dist/components/accordion/AccordionItemContent.d.ts.map +1 -0
  127. package/dist/components/accordion/AccordionItemContent.js +50 -0
  128. package/dist/components/accordion/AccordionItemContent.js.map +1 -0
  129. package/dist/components/accordion/KeyHandler.js +77 -0
  130. package/dist/components/accordion/KeyHandler.js.map +1 -0
  131. package/dist/components/accordion/context.d.ts +10 -0
  132. package/dist/components/accordion/context.d.ts.map +1 -0
  133. package/dist/components/accordion/context.js +13 -0
  134. package/dist/components/accordion/context.js.map +1 -0
  135. package/dist/components/accordion/defaultElements/Checkbox.js +22 -0
  136. package/dist/components/accordion/defaultElements/Checkbox.js.map +1 -0
  137. package/dist/components/accordion/defaultElements/DefaultAccordionItemButton.d.ts +40 -0
  138. package/dist/components/accordion/defaultElements/DefaultAccordionItemButton.d.ts.map +1 -0
  139. package/dist/components/accordion/defaultElements/DefaultAccordionItemButton.js +79 -0
  140. package/dist/components/accordion/defaultElements/DefaultAccordionItemButton.js.map +1 -0
  141. package/dist/components/accordion/defaultElements/useIsChecked.js +25 -0
  142. package/dist/components/accordion/defaultElements/useIsChecked.js.map +1 -0
  143. package/dist/components/accordion/handler.d.ts +40 -0
  144. package/dist/components/accordion/handler.d.ts.map +1 -0
  145. package/dist/components/accordion/handler.js +118 -0
  146. package/dist/components/accordion/handler.js.map +1 -0
  147. package/dist/components/accordion/index.d.ts +8 -0
  148. package/dist/components/accordion/index.d.ts.map +1 -0
  149. package/dist/components/accordion/types.d.ts +11 -0
  150. package/dist/components/accordion/types.d.ts.map +1 -0
  151. package/dist/components/apia/ApiaDateFilter.js +57 -0
  152. package/dist/components/apia/ApiaDateFilter.js.map +1 -0
  153. package/dist/components/apia/ApiaFilter.d.ts +13 -0
  154. package/dist/components/apia/ApiaFilter.d.ts.map +1 -0
  155. package/dist/components/apia/ApiaFilter.js +128 -0
  156. package/dist/components/apia/ApiaFilter.js.map +1 -0
  157. package/dist/components/buttons/useOtherTagButton.d.ts +28 -0
  158. package/dist/components/buttons/useOtherTagButton.d.ts.map +1 -0
  159. package/dist/components/buttons/useOtherTagButton.js +38 -0
  160. package/dist/components/buttons/useOtherTagButton.js.map +1 -0
  161. package/dist/components/collapsiblePanel/index.d.ts +7 -0
  162. package/dist/components/collapsiblePanel/index.d.ts.map +1 -0
  163. package/dist/components/collapsiblePanel/index.js +130 -0
  164. package/dist/components/collapsiblePanel/index.js.map +1 -0
  165. package/dist/components/collapsiblePanel/styles.js +4 -0
  166. package/dist/components/collapsiblePanel/styles.js.map +1 -0
  167. package/dist/components/collapsiblePanel/types.d.ts +23 -0
  168. package/dist/components/collapsiblePanel/types.d.ts.map +1 -0
  169. package/dist/components/dialogs/AlertModal.d.ts +11 -0
  170. package/dist/components/dialogs/AlertModal.d.ts.map +1 -0
  171. package/dist/components/dialogs/AlertModal.js +42 -0
  172. package/dist/components/dialogs/AlertModal.js.map +1 -0
  173. package/dist/components/dialogs/ConfirmModal.d.ts +25 -0
  174. package/dist/components/dialogs/ConfirmModal.d.ts.map +1 -0
  175. package/dist/components/dialogs/ConfirmModal.js +45 -0
  176. package/dist/components/dialogs/ConfirmModal.js.map +1 -0
  177. package/dist/components/forms/Captcha.d.ts +12 -0
  178. package/dist/components/forms/Captcha.d.ts.map +1 -0
  179. package/dist/components/forms/Captcha.js +66 -0
  180. package/dist/components/forms/Captcha.js.map +1 -0
  181. package/dist/components/forms/Checkbox.d.ts +21 -0
  182. package/dist/components/forms/Checkbox.d.ts.map +1 -0
  183. package/dist/components/forms/Checkbox.js +124 -0
  184. package/dist/components/forms/Checkbox.js.map +1 -0
  185. package/dist/components/forms/DateInput.d.ts +44 -0
  186. package/dist/components/forms/DateInput.d.ts.map +1 -0
  187. package/dist/components/forms/DateInput.js +246 -0
  188. package/dist/components/forms/DateInput.js.map +1 -0
  189. package/dist/components/forms/FieldErrorMessage.d.ts +10 -0
  190. package/dist/components/forms/FieldErrorMessage.d.ts.map +1 -0
  191. package/dist/components/forms/FieldErrorMessage.js +34 -0
  192. package/dist/components/forms/FieldErrorMessage.js.map +1 -0
  193. package/dist/components/forms/FieldLabel.d.ts +40 -0
  194. package/dist/components/forms/FieldLabel.d.ts.map +1 -0
  195. package/dist/components/forms/FieldLabel.js +66 -0
  196. package/dist/components/forms/FieldLabel.js.map +1 -0
  197. package/dist/components/forms/IconInput.d.ts +28 -0
  198. package/dist/components/forms/IconInput.d.ts.map +1 -0
  199. package/dist/components/forms/IconInput.js +80 -0
  200. package/dist/components/forms/IconInput.js.map +1 -0
  201. package/dist/components/forms/NumberInput.d.ts +37 -0
  202. package/dist/components/forms/NumberInput.d.ts.map +1 -0
  203. package/dist/components/forms/NumberInput.js +149 -0
  204. package/dist/components/forms/NumberInput.js.map +1 -0
  205. package/dist/components/forms/RequiredMark.d.ts +14 -0
  206. package/dist/components/forms/RequiredMark.d.ts.map +1 -0
  207. package/dist/components/forms/RequiredMark.js +13 -0
  208. package/dist/components/forms/RequiredMark.js.map +1 -0
  209. package/dist/components/forms/buttons/BaseButton.d.ts +24 -0
  210. package/dist/components/forms/buttons/BaseButton.d.ts.map +1 -0
  211. package/dist/components/forms/buttons/BaseButton.js +58 -0
  212. package/dist/components/forms/buttons/BaseButton.js.map +1 -0
  213. package/dist/components/forms/buttons/IconButton.d.ts +37 -0
  214. package/dist/components/forms/buttons/IconButton.d.ts.map +1 -0
  215. package/dist/components/forms/buttons/IconButton.js +79 -0
  216. package/dist/components/forms/buttons/IconButton.js.map +1 -0
  217. package/dist/components/forms/buttons/SimpleButton.d.ts +21 -0
  218. package/dist/components/forms/buttons/SimpleButton.d.ts.map +1 -0
  219. package/dist/components/forms/buttons/SimpleButton.js +94 -0
  220. package/dist/components/forms/buttons/SimpleButton.js.map +1 -0
  221. package/dist/components/forms/util/style.d.ts +7 -0
  222. package/dist/components/forms/util/style.d.ts.map +1 -0
  223. package/dist/components/forms/util/style.js +17 -0
  224. package/dist/components/forms/util/style.js.map +1 -0
  225. package/dist/components/importComponent.d.ts +11 -0
  226. package/dist/components/importComponent.d.ts.map +1 -0
  227. package/dist/components/importComponent.js +25 -0
  228. package/dist/components/importComponent.js.map +1 -0
  229. package/dist/components/loaders/LinearLoader.d.ts +6 -0
  230. package/dist/components/loaders/LinearLoader.d.ts.map +1 -0
  231. package/dist/components/loaders/LinearLoader.js +33 -0
  232. package/dist/components/loaders/LinearLoader.js.map +1 -0
  233. package/dist/components/loaders/LoaderSpinner.d.ts +10 -0
  234. package/dist/components/loaders/LoaderSpinner.d.ts.map +1 -0
  235. package/dist/components/loaders/LoaderSpinner.js +26 -0
  236. package/dist/components/loaders/LoaderSpinner.js.map +1 -0
  237. package/dist/components/loaders/ProgressBar.d.ts +11 -0
  238. package/dist/components/loaders/ProgressBar.d.ts.map +1 -0
  239. package/dist/components/loaders/ProgressBar.js +39 -0
  240. package/dist/components/loaders/ProgressBar.js.map +1 -0
  241. package/dist/components/modals/CalendarModal.d.ts +13 -0
  242. package/dist/components/modals/CalendarModal.d.ts.map +1 -0
  243. package/dist/components/modals/CalendarModal.js +43 -0
  244. package/dist/components/modals/CalendarModal.js.map +1 -0
  245. package/dist/components/modals/Modal.d.ts +160 -0
  246. package/dist/components/modals/Modal.d.ts.map +1 -0
  247. package/dist/components/modals/Modal.js +17 -0
  248. package/dist/components/modals/Modal.js.map +1 -0
  249. package/dist/components/modals/ModalContext.d.ts +9 -0
  250. package/dist/components/modals/ModalContext.d.ts.map +1 -0
  251. package/dist/components/modals/ModalContext.js +12 -0
  252. package/dist/components/modals/ModalContext.js.map +1 -0
  253. package/dist/components/modals/Overlay.d.ts +21 -0
  254. package/dist/components/modals/Overlay.d.ts.map +1 -0
  255. package/dist/components/modals/Overlay.js +75 -0
  256. package/dist/components/modals/Overlay.js.map +1 -0
  257. package/dist/components/modals/StaticModal.js +175 -0
  258. package/dist/components/modals/StaticModal.js.map +1 -0
  259. package/dist/components/modals/WindowModal.js +214 -0
  260. package/dist/components/modals/WindowModal.js.map +1 -0
  261. package/dist/components/modals/hooks/useEscapeKey.js +32 -0
  262. package/dist/components/modals/hooks/useEscapeKey.js.map +1 -0
  263. package/dist/components/modals/hooks/useInitialFocus.js +37 -0
  264. package/dist/components/modals/hooks/useInitialFocus.js.map +1 -0
  265. package/dist/components/modals/hooks/useModal.d.ts +97 -0
  266. package/dist/components/modals/hooks/useModal.d.ts.map +1 -0
  267. package/dist/components/modals/hooks/useModal.js +73 -0
  268. package/dist/components/modals/hooks/useModal.js.map +1 -0
  269. package/dist/components/modals/hooks/useStyleState.js +44 -0
  270. package/dist/components/modals/hooks/useStyleState.js.map +1 -0
  271. package/dist/components/modals/layout/Confirm.d.ts +7 -0
  272. package/dist/components/modals/layout/Confirm.d.ts.map +1 -0
  273. package/dist/components/modals/layout/Confirm.js +96 -0
  274. package/dist/components/modals/layout/Confirm.js.map +1 -0
  275. package/dist/components/modals/layout/DialogButtonBar.d.ts +10 -0
  276. package/dist/components/modals/layout/DialogButtonBar.d.ts.map +1 -0
  277. package/dist/components/modals/layout/DialogButtonBar.js +19 -0
  278. package/dist/components/modals/layout/DialogButtonBar.js.map +1 -0
  279. package/dist/components/modals/layout/DialogHeader.d.ts +18 -0
  280. package/dist/components/modals/layout/DialogHeader.d.ts.map +1 -0
  281. package/dist/components/modals/layout/DialogHeader.js +117 -0
  282. package/dist/components/modals/layout/DialogHeader.js.map +1 -0
  283. package/dist/components/responsive/AutoEllipsis.d.ts +21 -0
  284. package/dist/components/responsive/AutoEllipsis.d.ts.map +1 -0
  285. package/dist/components/responsive/AutoEllipsis.js +128 -0
  286. package/dist/components/responsive/AutoEllipsis.js.map +1 -0
  287. package/dist/components/responsive/makeResponsiveComponent.d.ts +38 -0
  288. package/dist/components/responsive/makeResponsiveComponent.d.ts.map +1 -0
  289. package/dist/components/responsive/makeResponsiveComponent.js +88 -0
  290. package/dist/components/responsive/makeResponsiveComponent.js.map +1 -0
  291. package/dist/components/types.d.ts +5 -0
  292. package/dist/components/types.d.ts.map +1 -0
  293. package/dist/components/waiAriaHelpers/typeAhead.d.ts +44 -0
  294. package/dist/components/waiAriaHelpers/typeAhead.d.ts.map +1 -0
  295. package/dist/components/waiAriaHelpers/typeAhead.js +75 -0
  296. package/dist/components/waiAriaHelpers/typeAhead.js.map +1 -0
  297. package/dist/globalFocus.js +95 -0
  298. package/dist/globalFocus.js.map +1 -0
  299. package/dist/hooks/useBodyScrollLock.js +106 -0
  300. package/dist/hooks/useBodyScrollLock.js.map +1 -0
  301. package/dist/index.d.ts +69 -1531
  302. package/dist/index.js +59 -7898
  303. package/dist/index.js.map +1 -1
  304. package/dist/objects/ApiaUtil/dialogs/ApiaUtilDialogs.d.ts +18 -0
  305. package/dist/objects/ApiaUtil/dialogs/ApiaUtilDialogs.d.ts.map +1 -0
  306. package/dist/objects/ApiaUtil/dialogs/ApiaUtilDialogs.js +116 -0
  307. package/dist/objects/ApiaUtil/dialogs/ApiaUtilDialogs.js.map +1 -0
  308. package/dist/objects/ApiaUtil/index.d.ts +27 -0
  309. package/dist/objects/ApiaUtil/index.d.ts.map +1 -0
  310. package/dist/objects/ApiaUtil/index.js +76 -0
  311. package/dist/objects/ApiaUtil/index.js.map +1 -0
  312. package/dist/objects/ApiaUtil/menu/ApiaUtilMenu.d.ts +24 -0
  313. package/dist/objects/ApiaUtil/menu/ApiaUtilMenu.d.ts.map +1 -0
  314. package/dist/objects/ApiaUtil/menu/ApiaUtilMenu.js +110 -0
  315. package/dist/objects/ApiaUtil/menu/ApiaUtilMenu.js.map +1 -0
  316. package/dist/objects/ApiaUtil/modals/ApiaUtilModals.d.ts +17 -0
  317. package/dist/objects/ApiaUtil/modals/ApiaUtilModals.d.ts.map +1 -0
  318. package/dist/objects/ApiaUtil/modals/ApiaUtilModals.js +111 -0
  319. package/dist/objects/ApiaUtil/modals/ApiaUtilModals.js.map +1 -0
  320. package/dist/objects/ApiaUtil/modals/OpenModal.d.ts +8 -0
  321. package/dist/objects/ApiaUtil/modals/OpenModal.d.ts.map +1 -0
  322. package/dist/objects/ApiaUtil/modals/OpenModal.js +19 -0
  323. package/dist/objects/ApiaUtil/modals/OpenModal.js.map +1 -0
  324. package/dist/objects/ApiaUtil/mouse/ApiaUtilMouse.d.ts +19 -0
  325. package/dist/objects/ApiaUtil/mouse/ApiaUtilMouse.d.ts.map +1 -0
  326. package/dist/objects/ApiaUtil/mouse/ApiaUtilMouse.js +26 -0
  327. package/dist/objects/ApiaUtil/mouse/ApiaUtilMouse.js.map +1 -0
  328. package/dist/objects/ApiaUtil/notifications/ApiaUtilNotifications.d.ts +14 -0
  329. package/dist/objects/ApiaUtil/notifications/ApiaUtilNotifications.d.ts.map +1 -0
  330. package/dist/objects/ApiaUtil/notifications/ApiaUtilNotifications.js +33 -0
  331. package/dist/objects/ApiaUtil/notifications/ApiaUtilNotifications.js.map +1 -0
  332. package/dist/objects/ApiaUtil/parsers/ApiaUtilParsers.d.ts +23 -0
  333. package/dist/objects/ApiaUtil/parsers/ApiaUtilParsers.d.ts.map +1 -0
  334. package/dist/objects/ApiaUtil/parsers/ApiaUtilParsers.js +79 -0
  335. package/dist/objects/ApiaUtil/parsers/ApiaUtilParsers.js.map +1 -0
  336. package/dist/objects/ApiaUtil/tabs/ApiaUtilCurrentTab.d.ts +33 -0
  337. package/dist/objects/ApiaUtil/tabs/ApiaUtilCurrentTab.d.ts.map +1 -0
  338. package/dist/objects/ApiaUtil/tabs/ApiaUtilCurrentTab.js +50 -0
  339. package/dist/objects/ApiaUtil/tabs/ApiaUtilCurrentTab.js.map +1 -0
  340. package/dist/objects/ApiaUtil/tabs/ApiaUtilTabsController.d.ts +20 -0
  341. package/dist/objects/ApiaUtil/tabs/ApiaUtilTabsController.d.ts.map +1 -0
  342. package/dist/objects/ApiaUtil/tabs/ApiaUtilTabsController.js +37 -0
  343. package/dist/objects/ApiaUtil/tabs/ApiaUtilTabsController.js.map +1 -0
  344. package/dist/objects/ApiaUtil/tabs/util.js +17 -0
  345. package/dist/objects/ApiaUtil/tabs/util.js.map +1 -0
  346. package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltip.d.ts +11 -0
  347. package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltip.d.ts.map +1 -0
  348. package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltip.js +17 -0
  349. package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltip.js.map +1 -0
  350. package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltips.d.ts +22 -0
  351. package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltips.d.ts.map +1 -0
  352. package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltips.js +104 -0
  353. package/dist/objects/ApiaUtil/tooltips/ApiaUtilTooltips.js.map +1 -0
  354. package/dist/objects/ApiaUtil/tooltips/AutomaticTooltip.d.ts +13 -0
  355. package/dist/objects/ApiaUtil/tooltips/AutomaticTooltip.d.ts.map +1 -0
  356. package/dist/objects/ApiaUtil/tooltips/AutomaticTooltip.js +79 -0
  357. package/dist/objects/ApiaUtil/tooltips/AutomaticTooltip.js.map +1 -0
  358. package/dist/objects/ApiaUtil/tooltips/tooltip/Tooltip.js +62 -0
  359. package/dist/objects/ApiaUtil/tooltips/tooltip/Tooltip.js.map +1 -0
  360. package/dist/objects/ApiaUtil/tooltips/tooltip/types.d.ts +117 -0
  361. package/dist/objects/ApiaUtil/tooltips/tooltip/types.d.ts.map +1 -0
  362. package/dist/objects/ApiaUtil/tooltips/tooltip/util.js +273 -0
  363. package/dist/objects/ApiaUtil/tooltips/tooltip/util.js.map +1 -0
  364. package/dist/objects/ScreenLocker/index.d.ts +37 -0
  365. package/dist/objects/ScreenLocker/index.d.ts.map +1 -0
  366. package/dist/objects/ScreenLocker/index.js +92 -0
  367. package/dist/objects/ScreenLocker/index.js.map +1 -0
  368. package/dist/tabs/Content.d.ts +7 -0
  369. package/dist/tabs/Content.d.ts.map +1 -0
  370. package/dist/tabs/Content.js +52 -0
  371. package/dist/tabs/Content.js.map +1 -0
  372. package/dist/tabs/ContextMenu.js +77 -0
  373. package/dist/tabs/ContextMenu.js.map +1 -0
  374. package/dist/tabs/Item.js +64 -0
  375. package/dist/tabs/Item.js.map +1 -0
  376. package/dist/tabs/Tabs.d.ts +8 -0
  377. package/dist/tabs/Tabs.d.ts.map +1 -0
  378. package/dist/tabs/Tabs.js +78 -0
  379. package/dist/tabs/Tabs.js.map +1 -0
  380. package/dist/tabs/TabsList.d.ts +8 -0
  381. package/dist/tabs/TabsList.d.ts.map +1 -0
  382. package/dist/tabs/TabsList.js +138 -0
  383. package/dist/tabs/TabsList.js.map +1 -0
  384. package/dist/tabs/renderers/DefaultTabsLabelRenderer.d.ts +6 -0
  385. package/dist/tabs/renderers/DefaultTabsLabelRenderer.d.ts.map +1 -0
  386. package/dist/tabs/renderers/DefaultTabsLabelRenderer.js +71 -0
  387. package/dist/tabs/renderers/DefaultTabsLabelRenderer.js.map +1 -0
  388. package/dist/tabs/tabsController.d.ts +41 -0
  389. package/dist/tabs/tabsController.d.ts.map +1 -0
  390. package/dist/tabs/tabsController.js +303 -0
  391. package/dist/tabs/tabsController.js.map +1 -0
  392. package/dist/tabs/types.d.ts +115 -0
  393. package/dist/tabs/types.d.ts.map +1 -0
  394. package/dist/tabs/useTabsList.js +20 -0
  395. package/dist/tabs/useTabsList.js.map +1 -0
  396. package/dist/tabs/util.js +11 -0
  397. package/dist/tabs/util.js.map +1 -0
  398. package/package.json +29 -39
  399. package/LICENSE.md +0 -21
  400. package/README.md +0 -3
  401. package/cleanDist.json +0 -3
  402. package/entries.json +0 -1
@@ -0,0 +1,44 @@
1
+ import { InputProps } from '@apia/theme';
2
+ import { TModify } from '@apia/util';
3
+ import React__default from 'react';
4
+ import { IIconInput } from './IconInput.js';
5
+
6
+ declare global {
7
+ interface Window {
8
+ LANG_CODE: string;
9
+ MSG_INVALID_DATE: string;
10
+ MSG_FEC_FIN_MAY_FEC_INI: string;
11
+ LBL_PICK_DATE: string;
12
+ }
13
+ }
14
+ type TDateProps = TModify<InputProps, {
15
+ allowPickBeforeToday?: boolean;
16
+ error?: string | null;
17
+ /**
18
+ * Con esta propiedad se puede proveer una función que será utilizada para
19
+ * determinar qué máscara debe utilizar el input
20
+ */
21
+ getCustomMask?: () => string;
22
+ isLoading?: boolean;
23
+ /**
24
+ * Recibe la nueva fecha. En caso de devolver
25
+ * false desde este método, el nuevo valor no
26
+ * se persistirá.
27
+ */
28
+ onChange?: (newValue: string) => boolean | string | void;
29
+ /**
30
+ * Es llamado cada vez que alguien presiona el botón de eliminar fecha.
31
+ */
32
+ onDelete?: () => void;
33
+ onError?: (error: string | null) => unknown;
34
+ /**
35
+ * Con esta propiedad se puede proveer una función que recibirá como
36
+ * parámetro el valor actual del cmapo y debe devolver el valor a mostrar.
37
+ */
38
+ renderLabel?: (value: string) => string;
39
+ value?: string;
40
+ }> & Pick<IIconInput, 'buttonProps'>;
41
+ declare const DateInput: React__default.ForwardRefExoticComponent<Omit<TDateProps, "ref"> & React__default.RefAttributes<HTMLInputElement>>;
42
+
43
+ export { DateInput, type TDateProps };
44
+ //# sourceMappingURL=DateInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DateInput.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,246 @@
1
+ import { jsx, jsxs, Fragment } from '@apia/theme/jsx-runtime';
2
+ import { Close, Box, getVariant } from '@apia/theme';
3
+ import { getDateFormat, useUpdateEffect, isChild } from '@apia/util';
4
+ import dayjs from 'dayjs';
5
+ import uniqueId from 'lodash-es/uniqueId';
6
+ import React__default from 'react';
7
+ import { icons } from '@apia/icons';
8
+ import globalFocus from '../../globalFocus.js';
9
+ import { CalendarModal } from '../modals/CalendarModal.js';
10
+ import { FieldErrorMessage } from './FieldErrorMessage.js';
11
+ import { IconInput } from './IconInput.js';
12
+ import { getFieldErrorStyles } from './util/style.js';
13
+ import { useModal } from '../modals/hooks/useModal.js';
14
+
15
+ const DEFAULT_LOCALE = window.LANG_CODE;
16
+ const DEFAULT_MASK_PLACEHOLDER = "_";
17
+ const dateFormat = getDateFormat();
18
+ const getMaskForDateFormat = () => {
19
+ if (dateFormat === "YYYY/MM/DD")
20
+ return "9999/99/99";
21
+ return "99/99/9999";
22
+ };
23
+ const DateInput = React__default.forwardRef(
24
+ ({
25
+ allowPickBeforeToday,
26
+ buttonProps: outerButtonProps,
27
+ className,
28
+ error,
29
+ getCustomMask,
30
+ isLoading,
31
+ onBlur,
32
+ onChange,
33
+ onDelete,
34
+ onError,
35
+ renderLabel,
36
+ value: outerValue,
37
+ ...props
38
+ }, ref) => {
39
+ const id = React__default.useMemo(uniqueId, []);
40
+ const [inputValue, setInputValue] = React__default.useState(outerValue ?? "");
41
+ const [calValue, setCalValue] = React__default.useState();
42
+ const boxRef = React__default.useRef(null);
43
+ const { show, hide, ...modalProps } = useModal({
44
+ preFetcher() {
45
+ globalFocus.focus = () => boxRef.current?.querySelector(".iconButton");
46
+ return new Promise((resolve) => {
47
+ let currentSelectedDate = dayjs(inputValue, dateFormat);
48
+ if (!currentSelectedDate.isValid())
49
+ currentSelectedDate = dayjs(/* @__PURE__ */ new Date());
50
+ setCalValue(currentSelectedDate.toDate());
51
+ resolve();
52
+ });
53
+ }
54
+ });
55
+ const [stateError, setError] = React__default.useState(error ?? null);
56
+ const lastEmittedValue = React__default.useRef(outerValue ?? "");
57
+ useUpdateEffect(() => {
58
+ setInputValue(outerValue ?? "");
59
+ lastEmittedValue.current = outerValue;
60
+ }, [outerValue]);
61
+ useUpdateEffect(() => {
62
+ setError(error ?? null);
63
+ }, [error]);
64
+ useUpdateEffect(() => {
65
+ if (onError)
66
+ onError(stateError);
67
+ }, [stateError]);
68
+ const shoutOnChange = React__default.useCallback(
69
+ (newValue) => {
70
+ if (newValue !== lastEmittedValue.current && onChange) {
71
+ lastEmittedValue.current = newValue;
72
+ return onChange(newValue);
73
+ }
74
+ return true;
75
+ },
76
+ [onChange]
77
+ );
78
+ const setCalendarValue = React__default.useCallback(
79
+ (value, nocheck) => {
80
+ if (value === "") {
81
+ void shoutOnChange("");
82
+ setInputValue("");
83
+ return;
84
+ }
85
+ let newDate;
86
+ if (value !== "") {
87
+ newDate = dayjs(value, dateFormat);
88
+ if (!newDate.isValid())
89
+ newDate = dayjs(/* @__PURE__ */ new Date());
90
+ } else {
91
+ newDate = dayjs(/* @__PURE__ */ new Date());
92
+ }
93
+ const formattedDate = newDate.format(dateFormat);
94
+ const today = /* @__PURE__ */ new Date();
95
+ today.setHours(0, 0, 0, 0);
96
+ if (formattedDate !== inputValue && nocheck !== true) {
97
+ void shoutOnChange("");
98
+ setInputValue("");
99
+ setError(window.MSG_INVALID_DATE);
100
+ } else if (allowPickBeforeToday === false && newDate.isBefore(today)) {
101
+ void shoutOnChange("");
102
+ setInputValue("");
103
+ setError(window.MSG_FEC_FIN_MAY_FEC_INI);
104
+ } else {
105
+ const shoutResult = shoutOnChange(value === "" ? "" : formattedDate);
106
+ if (shoutResult === false) {
107
+ setInputValue(shoutResult || "");
108
+ setError(null);
109
+ } else if (typeof shoutResult === "string") {
110
+ setInputValue("");
111
+ setError(shoutResult);
112
+ } else {
113
+ setInputValue(formattedDate);
114
+ setError(null);
115
+ }
116
+ }
117
+ },
118
+ [allowPickBeforeToday, inputValue, shoutOnChange]
119
+ );
120
+ const selectDate = React__default.useCallback(
121
+ (val) => {
122
+ hide();
123
+ const newValue = dayjs(val).format(dateFormat);
124
+ setCalendarValue(newValue, true);
125
+ },
126
+ [hide, setCalendarValue]
127
+ );
128
+ const onCloseCalendarModal = React__default.useCallback(() => {
129
+ hide();
130
+ }, [hide]);
131
+ const handleBlur = React__default.useCallback(
132
+ (ev) => {
133
+ if (onBlur && !isChild(ev.relatedTarget, (current) => {
134
+ return current.id === `DateModal${id}` || current.id === `DateInput${id}`;
135
+ })) {
136
+ onBlur(ev);
137
+ }
138
+ },
139
+ [id, onBlur]
140
+ );
141
+ const inputProps = React__default.useMemo(
142
+ () => ({
143
+ ...props,
144
+ className: "dateInput",
145
+ value: renderLabel ? renderLabel(inputValue) : inputValue,
146
+ ref,
147
+ onChange: (ev) => {
148
+ setInputValue(ev.target.value);
149
+ if (getMaskForDateFormat().replaceAll("9", DEFAULT_MASK_PLACEHOLDER) !== ev.target.value && ev.target.value !== "")
150
+ setError(null);
151
+ },
152
+ onBlur: (ev) => {
153
+ if (!(props.readOnly || getCustomMask))
154
+ setCalendarValue(ev.target.value);
155
+ handleBlur(ev);
156
+ },
157
+ onKeyDown: (ev) => {
158
+ if (ev.key === "Enter")
159
+ setCalendarValue(inputValue);
160
+ }
161
+ }),
162
+ [
163
+ getCustomMask,
164
+ handleBlur,
165
+ inputValue,
166
+ props,
167
+ ref,
168
+ renderLabel,
169
+ setCalendarValue
170
+ ]
171
+ );
172
+ const buttonProps = React__default.useMemo(
173
+ () => ({
174
+ disabled: props.disabled ?? props.readOnly,
175
+ "aria-label": window.LBL_PICK_DATE,
176
+ ...outerButtonProps
177
+ }),
178
+ [outerButtonProps, props.disabled, props.readOnly]
179
+ );
180
+ const additionalButtons = React__default.useMemo(
181
+ () => /* @__PURE__ */ jsx(
182
+ Close,
183
+ {
184
+ className: "delete_date_button",
185
+ onClick: () => {
186
+ setCalendarValue("");
187
+ onDelete?.();
188
+ document.querySelector(
189
+ `#DateInput${id} input`
190
+ )?.focus();
191
+ },
192
+ type: "button"
193
+ }
194
+ ),
195
+ [id, onDelete, setCalendarValue]
196
+ );
197
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
198
+ /* @__PURE__ */ jsx(
199
+ CalendarModal,
200
+ {
201
+ ...modalProps,
202
+ calValue,
203
+ locale: DEFAULT_LOCALE,
204
+ handleClickDay: selectDate,
205
+ onCancel: onCloseCalendarModal,
206
+ id: `DateModal${id}`
207
+ }
208
+ ),
209
+ /* @__PURE__ */ jsxs(
210
+ Box,
211
+ {
212
+ ...getVariant("forms.dateInput"),
213
+ className: `${className ?? ""} dateInput`,
214
+ id: `DateInput${id}`,
215
+ ref: boxRef,
216
+ children: [
217
+ /* @__PURE__ */ jsx(
218
+ IconInput,
219
+ {
220
+ additionalButtons: inputValue && inputValue !== getMaskForDateFormat().replaceAll(
221
+ "9",
222
+ DEFAULT_MASK_PLACEHOLDER
223
+ ) && !props.readOnly && !props.disabled ? additionalButtons : void 0,
224
+ isLoading,
225
+ maskPlaceholder: DEFAULT_MASK_PLACEHOLDER,
226
+ mask: getCustomMask ? getCustomMask() : getMaskForDateFormat(),
227
+ icon: icons.Calendar,
228
+ onBlur: handleBlur,
229
+ buttonProps,
230
+ inputProps,
231
+ readOnly: props.readOnly,
232
+ sx: getFieldErrorStyles(stateError === null),
233
+ onClick: show
234
+ }
235
+ ),
236
+ stateError && /* @__PURE__ */ jsx(FieldErrorMessage, { children: stateError })
237
+ ]
238
+ }
239
+ )
240
+ ] });
241
+ }
242
+ );
243
+ DateInput.displayName = "DateInput";
244
+
245
+ export { DateInput };
246
+ //# sourceMappingURL=DateInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DateInput.js","sources":["../../../src/components/forms/DateInput.tsx"],"sourcesContent":["import { getVariant, Box, Close, InputProps } from '@apia/theme';\nimport {\n getDateFormat,\n isChild,\n TDateFormat,\n TModify,\n useUpdateEffect,\n} from '@apia/util';\nimport dayjs from 'dayjs';\nimport uniqueId from 'lodash-es/uniqueId';\nimport React from 'react';\nimport { icons } from '@apia/icons';\nimport globalFocus from '../../globalFocus';\nimport { useModal } from '../modals';\nimport { CalendarModal } from '../modals/CalendarModal';\nimport { FieldErrorMessage } from './FieldErrorMessage';\nimport { IconInput, IIconInput } from './IconInput';\nimport { getFieldErrorStyles } from './util/style';\n\ndeclare global {\n interface Window {\n LANG_CODE: string;\n MSG_INVALID_DATE: string;\n MSG_FEC_FIN_MAY_FEC_INI: string;\n LBL_PICK_DATE: string;\n }\n}\n\nconst DEFAULT_LOCALE = window.LANG_CODE;\nconst DEFAULT_MASK_PLACEHOLDER = '_';\n\nconst dateFormat: TDateFormat = getDateFormat();\n\nconst getMaskForDateFormat = (): string => {\n if (dateFormat === 'YYYY/MM/DD') return '9999/99/99';\n return '99/99/9999';\n};\n\nexport type TDateProps = TModify<\n InputProps,\n {\n allowPickBeforeToday?: boolean;\n error?: string | null;\n /**\n * Con esta propiedad se puede proveer una función que será utilizada para\n * determinar qué máscara debe utilizar el input\n */\n getCustomMask?: () => string;\n isLoading?: boolean;\n /**\n * Recibe la nueva fecha. En caso de devolver\n * false desde este método, el nuevo valor no\n * se persistirá.\n */\n onChange?: (newValue: string) => boolean | string | void;\n /**\n * Es llamado cada vez que alguien presiona el botón de eliminar fecha.\n */\n onDelete?: () => void;\n onError?: (error: string | null) => unknown;\n /**\n * Con esta propiedad se puede proveer una función que recibirá como\n * parámetro el valor actual del cmapo y debe devolver el valor a mostrar.\n */\n renderLabel?: (value: string) => string;\n value?: string;\n }\n> &\n Pick<IIconInput, 'buttonProps'>;\n\nexport const DateInput = React.forwardRef<HTMLInputElement, TDateProps>(\n (\n {\n allowPickBeforeToday,\n buttonProps: outerButtonProps,\n className,\n error,\n getCustomMask,\n isLoading,\n onBlur,\n onChange,\n onDelete,\n onError,\n renderLabel,\n value: outerValue,\n ...props\n },\n ref,\n ) => {\n const id = React.useMemo(uniqueId, []);\n const [inputValue, setInputValue] = React.useState(outerValue ?? '');\n const [calValue, setCalValue] = React.useState<Date>();\n const boxRef = React.useRef<HTMLElement | null>(null);\n const { show, hide, ...modalProps } = useModal({\n preFetcher() {\n globalFocus.focus = () =>\n boxRef.current?.querySelector('.iconButton') as HTMLElement;\n return new Promise((resolve) => {\n let currentSelectedDate = dayjs(inputValue, dateFormat);\n if (!currentSelectedDate.isValid())\n currentSelectedDate = dayjs(new Date());\n setCalValue(currentSelectedDate.toDate());\n resolve();\n });\n },\n });\n const [stateError, setError] = React.useState<null | string>(error ?? null);\n\n const lastEmittedValue = React.useRef(outerValue ?? '');\n useUpdateEffect(() => {\n setInputValue(outerValue ?? '');\n lastEmittedValue.current = outerValue as string;\n }, [outerValue]);\n\n useUpdateEffect(() => {\n setError(error ?? null);\n }, [error]);\n\n useUpdateEffect(() => {\n if (onError) onError(stateError);\n }, [stateError]);\n\n const shoutOnChange = React.useCallback(\n (newValue: string) => {\n if (newValue !== lastEmittedValue.current && onChange) {\n lastEmittedValue.current = newValue;\n return onChange(newValue);\n }\n return true;\n },\n [onChange],\n );\n\n const setCalendarValue = React.useCallback(\n (value: string, nocheck?: boolean) => {\n if (value === '') {\n void shoutOnChange('');\n setInputValue('');\n return;\n }\n let newDate: dayjs.Dayjs;\n if (value !== '') {\n // format cal needs: Tue Feb 09 2021 00:00:00 GMT-0300\n newDate = dayjs(value, dateFormat);\n if (!newDate.isValid()) newDate = dayjs(new Date());\n } else {\n newDate = dayjs(new Date());\n }\n const formattedDate = newDate.format(dateFormat);\n const today = new Date();\n today.setHours(0, 0, 0, 0);\n if (formattedDate !== inputValue && nocheck !== true) {\n void shoutOnChange('');\n setInputValue('');\n setError(window.MSG_INVALID_DATE);\n } else if (allowPickBeforeToday === false && newDate.isBefore(today)) {\n void shoutOnChange('');\n setInputValue('');\n setError(window.MSG_FEC_FIN_MAY_FEC_INI);\n } else {\n const shoutResult = shoutOnChange(value === '' ? '' : formattedDate);\n if (shoutResult === false) {\n setInputValue(shoutResult || '');\n setError(null);\n } else if (typeof shoutResult === 'string') {\n setInputValue('');\n setError(shoutResult);\n } else {\n setInputValue(formattedDate);\n setError(null);\n }\n }\n },\n [allowPickBeforeToday, inputValue, shoutOnChange],\n );\n\n const selectDate = React.useCallback(\n (val: Date): void => {\n hide();\n const newValue = dayjs(val).format(dateFormat);\n setCalendarValue(newValue, true);\n },\n [hide, setCalendarValue],\n );\n\n const onCloseCalendarModal = React.useCallback(() => {\n hide();\n }, [hide]);\n\n const handleBlur = React.useCallback(\n (ev: React.FocusEvent<HTMLInputElement>) => {\n if (\n onBlur &&\n !isChild(ev.relatedTarget as HTMLElement, (current) => {\n return (\n current.id === `DateModal${id}` || current.id === `DateInput${id}`\n );\n })\n ) {\n onBlur(ev);\n }\n },\n [id, onBlur],\n );\n\n const inputProps = React.useMemo(\n () => ({\n ...props,\n className: 'dateInput',\n value: renderLabel ? renderLabel(inputValue) : inputValue,\n ref,\n onChange: (ev: React.ChangeEvent<HTMLInputElement>) => {\n setInputValue(ev.target.value);\n if (\n getMaskForDateFormat().replaceAll('9', DEFAULT_MASK_PLACEHOLDER) !==\n ev.target.value &&\n ev.target.value !== ''\n )\n setError(null);\n },\n onBlur: (ev: React.FocusEvent<HTMLInputElement>) => {\n if (!(props.readOnly || getCustomMask))\n setCalendarValue(ev.target.value);\n handleBlur(ev);\n },\n onKeyDown: (ev: React.KeyboardEvent) => {\n if (ev.key === 'Enter') setCalendarValue(inputValue);\n },\n }),\n [\n getCustomMask,\n handleBlur,\n inputValue,\n props,\n ref,\n renderLabel,\n setCalendarValue,\n ],\n );\n\n const buttonProps = React.useMemo(\n () => ({\n disabled: props.disabled ?? props.readOnly,\n 'aria-label': window.LBL_PICK_DATE,\n ...outerButtonProps,\n }),\n [outerButtonProps, props.disabled, props.readOnly],\n );\n\n const additionalButtons = React.useMemo(\n () => (\n <Close\n className=\"delete_date_button\"\n onClick={() => {\n setCalendarValue('');\n onDelete?.();\n (\n document.querySelector(\n `#DateInput${id} input`,\n ) as HTMLInputElement\n )?.focus();\n }}\n type=\"button\"\n />\n ),\n [id, onDelete, setCalendarValue],\n );\n\n return (\n <>\n <CalendarModal\n {...modalProps}\n calValue={calValue}\n locale={DEFAULT_LOCALE}\n handleClickDay={selectDate}\n onCancel={onCloseCalendarModal}\n id={`DateModal${id}`}\n />\n <Box\n {...getVariant('forms.dateInput')}\n className={`${className ?? ''} dateInput`}\n id={`DateInput${id}`}\n ref={boxRef}\n >\n <IconInput\n additionalButtons={\n inputValue &&\n inputValue !==\n getMaskForDateFormat().replaceAll(\n '9',\n DEFAULT_MASK_PLACEHOLDER,\n ) &&\n !props.readOnly &&\n !props.disabled\n ? additionalButtons\n : undefined\n }\n isLoading={isLoading}\n maskPlaceholder={DEFAULT_MASK_PLACEHOLDER}\n mask={getCustomMask ? getCustomMask() : getMaskForDateFormat()}\n icon={icons.Calendar}\n onBlur={handleBlur}\n buttonProps={buttonProps}\n inputProps={inputProps}\n readOnly={props.readOnly}\n sx={getFieldErrorStyles(stateError === null)}\n onClick={show}\n />\n {stateError && <FieldErrorMessage>{stateError}</FieldErrorMessage>}\n </Box>\n </>\n );\n },\n);\n\nDateInput.displayName = 'DateInput';\n"],"names":["React"],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ import * as React from 'react';
2
+
3
+ interface IFieldErrorMessage {
4
+ children: React.ReactNode | string;
5
+ name?: string;
6
+ }
7
+ declare const FieldErrorMessage: ({ children, name }: IFieldErrorMessage) => React.JSX.Element | null;
8
+
9
+ export { FieldErrorMessage, type IFieldErrorMessage };
10
+ //# sourceMappingURL=FieldErrorMessage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FieldErrorMessage.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,34 @@
1
+ import { jsx } from '@apia/theme/jsx-runtime';
2
+ import { customEvents } from '@apia/util';
3
+ import * as React from 'react';
4
+ import { Box } from '@apia/theme';
5
+
6
+ const FieldErrorMessage = ({ children, name }) => {
7
+ const [ref, setRef] = React.useState(null);
8
+ React.useEffect(() => {
9
+ if (children) {
10
+ const event = new CustomEvent(customEvents.focus, { bubbles: true });
11
+ ref?.dispatchEvent(event);
12
+ }
13
+ }, [children, ref]);
14
+ if (children) {
15
+ return /* @__PURE__ */ jsx(
16
+ Box,
17
+ {
18
+ ref: setRef,
19
+ role: "alert",
20
+ "data-testid": name ? `err_${name}` : null,
21
+ sx: {
22
+ mb: "0",
23
+ color: "danger",
24
+ pt: "2"
25
+ },
26
+ children
27
+ }
28
+ );
29
+ }
30
+ return null;
31
+ };
32
+
33
+ export { FieldErrorMessage };
34
+ //# sourceMappingURL=FieldErrorMessage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FieldErrorMessage.js","sources":["../../../src/components/forms/FieldErrorMessage.tsx"],"sourcesContent":["import { customEvents } from '@apia/util';\nimport * as React from 'react';\nimport { Box } from '@apia/theme';\n\nexport interface IFieldErrorMessage {\n children: React.ReactNode | string;\n name?: string;\n}\n\nexport const FieldErrorMessage = ({ children, name }: IFieldErrorMessage) => {\n const [ref, setRef] = React.useState<null | HTMLDivElement>(null);\n\n React.useEffect(() => {\n if (children) {\n const event = new CustomEvent(customEvents.focus, { bubbles: true });\n ref?.dispatchEvent(event);\n }\n }, [children, ref]);\n\n if (children) {\n return (\n <Box\n ref={setRef}\n role=\"alert\"\n data-testid={name ? `err_${name}` : null}\n sx={{\n mb: '0',\n color: 'danger',\n pt: '2',\n }}\n >\n {children}\n </Box>\n );\n }\n return null;\n};\n"],"names":[],"mappings":";;;;;AASO,MAAM,iBAAoB,GAAA,CAAC,EAAE,QAAA,EAAU,MAA+B,KAAA;AAC3E,EAAA,MAAM,CAAC,GAAK,EAAA,MAAM,CAAI,GAAA,KAAA,CAAM,SAAgC,IAAI,CAAA,CAAA;AAEhE,EAAA,KAAA,CAAM,UAAU,MAAM;AACpB,IAAA,IAAI,QAAU,EAAA;AACZ,MAAM,MAAA,KAAA,GAAQ,IAAI,WAAY,CAAA,YAAA,CAAa,OAAO,EAAE,OAAA,EAAS,MAAM,CAAA,CAAA;AACnE,MAAA,GAAA,EAAK,cAAc,KAAK,CAAA,CAAA;AAAA,KAC1B;AAAA,GACC,EAAA,CAAC,QAAU,EAAA,GAAG,CAAC,CAAA,CAAA;AAElB,EAAA,IAAI,QAAU,EAAA;AACZ,IACE,uBAAA,GAAA;AAAA,MAAC,GAAA;AAAA,MAAA;AAAA,QACC,GAAK,EAAA,MAAA;AAAA,QACL,IAAK,EAAA,OAAA;AAAA,QACL,aAAa,EAAA,IAAA,GAAO,CAAO,IAAA,EAAA,IAAI,CAAK,CAAA,GAAA,IAAA;AAAA,QACpC,EAAI,EAAA;AAAA,UACF,EAAI,EAAA,GAAA;AAAA,UACJ,KAAO,EAAA,QAAA;AAAA,UACP,EAAI,EAAA,GAAA;AAAA,SACN;AAAA,QAEC,QAAA;AAAA,OAAA;AAAA,KACH,CAAA;AAAA,GAEJ;AACA,EAAO,OAAA,IAAA,CAAA;AACT;;;;"}
@@ -0,0 +1,40 @@
1
+ import * as React from 'react';
2
+ import { BoxProps } from '@apia/theme';
3
+
4
+ type TFieldLabel = {
5
+ avoidSemicolon?: boolean;
6
+ /**
7
+ * Permite mostrar un mensaje de error debajo del campo
8
+ */
9
+ error?: string;
10
+ hideRequiredMark?: boolean;
11
+ label: string;
12
+ /**
13
+ * La propiedad required se utiliza para mostrar el * de requerido.
14
+ *
15
+ * @see requiredMarkPosition
16
+ * @see hideRequiredMark
17
+ */
18
+ required?: boolean;
19
+ requiredMarkPosition?: 'before' | 'after';
20
+ } & BoxProps;
21
+ declare const FieldLabel: React.ForwardRefExoticComponent<{
22
+ avoidSemicolon?: boolean | undefined;
23
+ /**
24
+ * Permite mostrar un mensaje de error debajo del campo
25
+ */
26
+ error?: string | undefined;
27
+ hideRequiredMark?: boolean | undefined;
28
+ label: string;
29
+ /**
30
+ * La propiedad required se utiliza para mostrar el * de requerido.
31
+ *
32
+ * @see requiredMarkPosition
33
+ * @see hideRequiredMark
34
+ */
35
+ required?: boolean | undefined;
36
+ requiredMarkPosition?: "after" | "before" | undefined;
37
+ } & BoxProps & React.RefAttributes<HTMLDivElement>>;
38
+
39
+ export { FieldLabel, type TFieldLabel };
40
+ //# sourceMappingURL=FieldLabel.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FieldLabel.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,66 @@
1
+ import { jsxs, jsx } from '@apia/theme/jsx-runtime';
2
+ import { injectStyles, Box, getVariant } from '@apia/theme';
3
+ import { forwardRef } from 'react';
4
+ import { RequiredMark } from './RequiredMark.js';
5
+
6
+ injectStyles("layout.common.components.fieldLabel", {
7
+ display: "flex",
8
+ flexDirection: "column",
9
+ gap: 1,
10
+ ".fieldLabel__label": {
11
+ fontWeight: "bold"
12
+ }
13
+ });
14
+ const FieldLabel = forwardRef(
15
+ ({
16
+ as,
17
+ avoidSemicolon,
18
+ children,
19
+ error,
20
+ hideRequiredMark,
21
+ label,
22
+ required,
23
+ requiredMarkPosition = "after",
24
+ ...props
25
+ }, ref) => {
26
+ return /* @__PURE__ */ jsxs(
27
+ Box,
28
+ {
29
+ as: as ?? "label",
30
+ ...props,
31
+ className: `fieldLabel ${props.className ?? ""}`,
32
+ ...getVariant("layout.common.components.fieldLabel"),
33
+ "aria-label": props["aria-label"] ?? label,
34
+ ref,
35
+ children: [
36
+ /* @__PURE__ */ jsxs(Box, { className: "fieldLabel__label", children: [
37
+ requiredMarkPosition === "before" && /* @__PURE__ */ jsx(
38
+ RequiredMark,
39
+ {
40
+ isRequired: required,
41
+ isReadonly: hideRequiredMark,
42
+ isFormReadonly: hideRequiredMark
43
+ }
44
+ ),
45
+ label,
46
+ requiredMarkPosition === "after" && /* @__PURE__ */ jsx(
47
+ RequiredMark,
48
+ {
49
+ isRequired: required,
50
+ isReadonly: hideRequiredMark,
51
+ isFormReadonly: hideRequiredMark
52
+ }
53
+ ),
54
+ !avoidSemicolon && ":"
55
+ ] }),
56
+ /* @__PURE__ */ jsx(Box, { children }),
57
+ error && /* @__PURE__ */ jsx(Box, { className: "fieldLabel__error", children: error })
58
+ ]
59
+ }
60
+ );
61
+ }
62
+ );
63
+ FieldLabel.displayName = "FieldLabel";
64
+
65
+ export { FieldLabel };
66
+ //# sourceMappingURL=FieldLabel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FieldLabel.js","sources":["../../../src/components/forms/FieldLabel.tsx"],"sourcesContent":["import { injectStyles, getVariant, Box, BoxProps } from '@apia/theme';\nimport { forwardRef } from 'react';\nimport { RequiredMark } from './RequiredMark';\n\nexport type TFieldLabel = {\n avoidSemicolon?: boolean;\n /**\n * Permite mostrar un mensaje de error debajo del campo\n */\n error?: string;\n hideRequiredMark?: boolean;\n label: string;\n /**\n * La propiedad required se utiliza para mostrar el * de requerido.\n *\n * @see requiredMarkPosition\n * @see hideRequiredMark\n */\n required?: boolean;\n requiredMarkPosition?: 'before' | 'after';\n} & BoxProps;\n\ninjectStyles('layout.common.components.fieldLabel', {\n display: 'flex',\n flexDirection: 'column',\n gap: 1,\n\n '.fieldLabel__label': {\n fontWeight: 'bold',\n },\n});\n\nexport const FieldLabel = forwardRef<HTMLDivElement, TFieldLabel>(\n (\n {\n as,\n avoidSemicolon,\n children,\n error,\n hideRequiredMark,\n label,\n required,\n requiredMarkPosition = 'after',\n ...props\n },\n ref,\n ) => {\n return (\n <Box\n as={as ?? 'label'}\n {...props}\n className={`fieldLabel ${props.className ?? ''}`}\n {...getVariant('layout.common.components.fieldLabel')}\n aria-label={props['aria-label'] ?? label}\n ref={ref}\n >\n <Box className=\"fieldLabel__label\">\n {requiredMarkPosition === 'before' && (\n <RequiredMark\n isRequired={required}\n isReadonly={hideRequiredMark}\n isFormReadonly={hideRequiredMark}\n />\n )}\n {label}\n {requiredMarkPosition === 'after' && (\n <RequiredMark\n isRequired={required}\n isReadonly={hideRequiredMark}\n isFormReadonly={hideRequiredMark}\n />\n )}\n {!avoidSemicolon && ':'}\n </Box>\n <Box>{children}</Box>\n {error && <Box className=\"fieldLabel__error\">{error}</Box>}\n </Box>\n );\n },\n);\n\nFieldLabel.displayName = 'FieldLabel';\n"],"names":[],"mappings":";;;;;AAsBA,YAAA,CAAa,qCAAuC,EAAA;AAAA,EAClD,OAAS,EAAA,MAAA;AAAA,EACT,aAAe,EAAA,QAAA;AAAA,EACf,GAAK,EAAA,CAAA;AAAA,EAEL,oBAAsB,EAAA;AAAA,IACpB,UAAY,EAAA,MAAA;AAAA,GACd;AACF,CAAC,CAAA,CAAA;AAEM,MAAM,UAAa,GAAA,UAAA;AAAA,EACxB,CACE;AAAA,IACE,EAAA;AAAA,IACA,cAAA;AAAA,IACA,QAAA;AAAA,IACA,KAAA;AAAA,IACA,gBAAA;AAAA,IACA,KAAA;AAAA,IACA,QAAA;AAAA,IACA,oBAAuB,GAAA,OAAA;AAAA,IACvB,GAAG,KAAA;AAAA,KAEL,GACG,KAAA;AACH,IACE,uBAAA,IAAA;AAAA,MAAC,GAAA;AAAA,MAAA;AAAA,QACC,IAAI,EAAM,IAAA,OAAA;AAAA,QACT,GAAG,KAAA;AAAA,QACJ,SAAW,EAAA,CAAA,WAAA,EAAc,KAAM,CAAA,SAAA,IAAa,EAAE,CAAA,CAAA;AAAA,QAC7C,GAAG,WAAW,qCAAqC,CAAA;AAAA,QACpD,YAAA,EAAY,KAAM,CAAA,YAAY,CAAK,IAAA,KAAA;AAAA,QACnC,GAAA;AAAA,QAEA,QAAA,EAAA;AAAA,0BAAC,IAAA,CAAA,GAAA,EAAA,EAAI,WAAU,mBACZ,EAAA,QAAA,EAAA;AAAA,YAAA,oBAAA,KAAyB,QACxB,oBAAA,GAAA;AAAA,cAAC,YAAA;AAAA,cAAA;AAAA,gBACC,UAAY,EAAA,QAAA;AAAA,gBACZ,UAAY,EAAA,gBAAA;AAAA,gBACZ,cAAgB,EAAA,gBAAA;AAAA,eAAA;AAAA,aAClB;AAAA,YAED,KAAA;AAAA,YACA,yBAAyB,OACxB,oBAAA,GAAA;AAAA,cAAC,YAAA;AAAA,cAAA;AAAA,gBACC,UAAY,EAAA,QAAA;AAAA,gBACZ,UAAY,EAAA,gBAAA;AAAA,gBACZ,cAAgB,EAAA,gBAAA;AAAA,eAAA;AAAA,aAClB;AAAA,YAED,CAAC,cAAkB,IAAA,GAAA;AAAA,WACtB,EAAA,CAAA;AAAA,0BACA,GAAA,CAAC,OAAK,QAAS,EAAA,CAAA;AAAA,UACd,KAAS,oBAAA,GAAA,CAAC,GAAI,EAAA,EAAA,SAAA,EAAU,qBAAqB,QAAM,EAAA,KAAA,EAAA,CAAA;AAAA,SAAA;AAAA,OAAA;AAAA,KACtD,CAAA;AAAA,GAEJ;AACF,EAAA;AAEA,UAAA,CAAW,WAAc,GAAA,YAAA;;;;"}
@@ -0,0 +1,28 @@
1
+ import { InputProps } from '@apia/theme';
2
+ import React__default from 'react';
3
+ import { TIconType, TIconName } from '@apia/icons';
4
+ import { IconButton } from './buttons/IconButton.js';
5
+
6
+ interface IField {
7
+ className?: string;
8
+ disabled?: boolean;
9
+ isLoading?: boolean;
10
+ readOnly?: boolean;
11
+ }
12
+ interface IIconInput extends IField {
13
+ additionalButtons?: React__default.ReactNode;
14
+ additionalButtonsPosition?: 'before' | 'after';
15
+ buttonProps?: Partial<React__default.ComponentProps<typeof IconButton>>;
16
+ buttonRef?: React__default.RefObject<HTMLButtonElement>;
17
+ hideButton?: boolean;
18
+ icon?: TIconType | TIconName;
19
+ inputProps?: Partial<InputProps>;
20
+ inputRef?: React__default.RefObject<HTMLInputElement>;
21
+ onClick?: (ev: React__default.MouseEvent) => void;
22
+ onBlur?: React__default.FocusEventHandler;
23
+ [key: string]: unknown;
24
+ }
25
+ declare const IconInput: ({ additionalButtons, additionalButtonsPosition, buttonProps, buttonRef, className, disabled, hideButton, icon, inputProps, inputRef, isLoading, mask, onClick, onBlur, readOnly, ...rest }: IIconInput) => React__default.JSX.Element;
26
+
27
+ export { type IField, type IIconInput, IconInput };
28
+ //# sourceMappingURL=IconInput.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IconInput.d.ts","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,80 @@
1
+ import { jsxs, jsx } from '@apia/theme/jsx-runtime';
2
+ import { Box, getVariant, Input } from '@apia/theme';
3
+ import { useCombinedRefs, isChild } from '@apia/util';
4
+ import React__default from 'react';
5
+ import { IconButton } from './buttons/IconButton.js';
6
+
7
+ const IconInput = ({
8
+ additionalButtons,
9
+ additionalButtonsPosition = "before",
10
+ buttonProps,
11
+ buttonRef,
12
+ className,
13
+ disabled,
14
+ hideButton,
15
+ icon = "Search",
16
+ inputProps,
17
+ inputRef,
18
+ isLoading,
19
+ mask,
20
+ onClick,
21
+ onBlur,
22
+ readOnly,
23
+ ...rest
24
+ }) => {
25
+ const { sx: inputSx, ...actualInputProps } = inputProps ?? {};
26
+ const innerButtonRef = React__default.useRef(null);
27
+ const assignButtonRef = useCombinedRefs(buttonRef, innerButtonRef);
28
+ const innerInputRef = React__default.useRef(null);
29
+ const assignInputRef = useCombinedRefs(inputRef, innerInputRef);
30
+ const parentRef = React__default.useRef(null);
31
+ const handleBlur = React__default.useCallback(
32
+ (ev) => {
33
+ if (onBlur && (!ev.relatedTarget || ev.relatedTarget && !isChild(
34
+ ev.relatedTarget,
35
+ (current) => current === parentRef.current
36
+ )))
37
+ onBlur(ev);
38
+ },
39
+ [onBlur]
40
+ );
41
+ return /* @__PURE__ */ jsxs(
42
+ Box,
43
+ {
44
+ ...getVariant("forms.iconInput"),
45
+ className: `${className ?? ""} iconInput`,
46
+ ref: parentRef,
47
+ onBlur: handleBlur,
48
+ children: [
49
+ /* @__PURE__ */ jsx(
50
+ Input,
51
+ {
52
+ disabled: isLoading ?? disabled,
53
+ ref: assignInputRef,
54
+ readOnly,
55
+ sx: { variant: "forms.input", ...inputSx },
56
+ "data-variant": "forms.input",
57
+ ...rest,
58
+ ...actualInputProps
59
+ }
60
+ ),
61
+ additionalButtonsPosition === "before" && additionalButtons,
62
+ !hideButton && /* @__PURE__ */ jsx(
63
+ IconButton,
64
+ {
65
+ onClick,
66
+ icon,
67
+ disabled: readOnly ?? disabled,
68
+ isLoading,
69
+ ref: assignButtonRef,
70
+ ...buttonProps
71
+ }
72
+ ),
73
+ additionalButtonsPosition === "after" && additionalButtons
74
+ ]
75
+ }
76
+ );
77
+ };
78
+
79
+ export { IconInput };
80
+ //# sourceMappingURL=IconInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"IconInput.js","sources":["../../../src/components/forms/IconInput.tsx"],"sourcesContent":["import { getVariant, Box, Input, InputProps } from '@apia/theme';\nimport { isChild, useCombinedRefs } from '@apia/util';\nimport React from 'react';\nimport { TIconName, TIconType } from '@apia/icons';\nimport { IconButton } from './buttons';\n\nexport interface IField {\n className?: string;\n disabled?: boolean;\n isLoading?: boolean;\n readOnly?: boolean;\n}\n\nexport interface IIconInput extends IField {\n additionalButtons?: React.ReactNode;\n additionalButtonsPosition?: 'before' | 'after';\n buttonProps?: Partial<React.ComponentProps<typeof IconButton>>;\n buttonRef?: React.RefObject<HTMLButtonElement>;\n hideButton?: boolean;\n icon?: TIconType | TIconName;\n inputProps?: Partial<InputProps>;\n inputRef?: React.RefObject<HTMLInputElement>;\n onClick?: (ev: React.MouseEvent) => void;\n onBlur?: React.FocusEventHandler;\n [key: string]: unknown;\n}\n\nexport const IconInput = ({\n additionalButtons,\n additionalButtonsPosition = 'before',\n buttonProps,\n buttonRef,\n className,\n disabled,\n hideButton,\n icon = 'Search',\n inputProps,\n inputRef,\n isLoading,\n mask,\n onClick,\n onBlur,\n readOnly,\n ...rest\n}: IIconInput) => {\n const { sx: inputSx, ...actualInputProps } = inputProps ?? {};\n const innerButtonRef = React.useRef<HTMLButtonElement>(null);\n const assignButtonRef = useCombinedRefs(buttonRef, innerButtonRef);\n\n const innerInputRef = React.useRef<HTMLInputElement>(null);\n const assignInputRef = useCombinedRefs(inputRef, innerInputRef);\n\n const parentRef = React.useRef<HTMLElement | null>(null);\n const handleBlur = React.useCallback(\n (ev: React.FocusEvent) => {\n if (\n onBlur &&\n (!ev.relatedTarget ||\n (ev.relatedTarget &&\n !isChild(\n ev.relatedTarget as HTMLElement,\n (current) => current === parentRef.current,\n )))\n )\n onBlur(ev);\n },\n [onBlur],\n );\n\n return (\n <Box\n {...getVariant('forms.iconInput')}\n className={`${className ?? ''} iconInput`}\n ref={parentRef}\n onBlur={handleBlur}\n >\n <Input\n disabled={isLoading ?? disabled}\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment,@typescript-eslint/no-explicit-any\n ref={assignInputRef as any}\n readOnly={readOnly}\n sx={{ variant: 'forms.input', ...inputSx }}\n data-variant=\"forms.input\"\n {...rest}\n {...actualInputProps}\n />\n {additionalButtonsPosition === 'before' && additionalButtons}\n {!hideButton && (\n <IconButton\n onClick={onClick}\n icon={icon}\n disabled={readOnly ?? disabled}\n isLoading={isLoading}\n ref={assignButtonRef as React.Ref<HTMLButtonElement>}\n {...buttonProps}\n />\n )}\n {additionalButtonsPosition === 'after' && additionalButtons}\n </Box>\n );\n};\n"],"names":["React"],"mappings":";;;;;;AA2BO,MAAM,YAAY,CAAC;AAAA,EACxB,iBAAA;AAAA,EACA,yBAA4B,GAAA,QAAA;AAAA,EAC5B,WAAA;AAAA,EACA,SAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,UAAA;AAAA,EACA,IAAO,GAAA,QAAA;AAAA,EACP,UAAA;AAAA,EACA,QAAA;AAAA,EACA,SAAA;AAAA,EACA,IAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACA,QAAA;AAAA,EACA,GAAG,IAAA;AACL,CAAkB,KAAA;AAChB,EAAA,MAAM,EAAE,EAAI,EAAA,OAAA,EAAS,GAAG,gBAAiB,EAAA,GAAI,cAAc,EAAC,CAAA;AAC5D,EAAM,MAAA,cAAA,GAAiBA,cAAM,CAAA,MAAA,CAA0B,IAAI,CAAA,CAAA;AAC3D,EAAM,MAAA,eAAA,GAAkB,eAAgB,CAAA,SAAA,EAAW,cAAc,CAAA,CAAA;AAEjE,EAAM,MAAA,aAAA,GAAgBA,cAAM,CAAA,MAAA,CAAyB,IAAI,CAAA,CAAA;AACzD,EAAM,MAAA,cAAA,GAAiB,eAAgB,CAAA,QAAA,EAAU,aAAa,CAAA,CAAA;AAE9D,EAAM,MAAA,SAAA,GAAYA,cAAM,CAAA,MAAA,CAA2B,IAAI,CAAA,CAAA;AACvD,EAAA,MAAM,aAAaA,cAAM,CAAA,WAAA;AAAA,IACvB,CAAC,EAAyB,KAAA;AACxB,MAAA,IACE,WACC,CAAC,EAAA,CAAG,aACF,IAAA,EAAA,CAAG,iBACF,CAAC,OAAA;AAAA,QACC,EAAG,CAAA,aAAA;AAAA,QACH,CAAC,OAAY,KAAA,OAAA,KAAY,SAAU,CAAA,OAAA;AAAA,OACrC,CAAA;AAEJ,QAAA,MAAA,CAAO,EAAE,CAAA,CAAA;AAAA,KACb;AAAA,IACA,CAAC,MAAM,CAAA;AAAA,GACT,CAAA;AAEA,EACE,uBAAA,IAAA;AAAA,IAAC,GAAA;AAAA,IAAA;AAAA,MACE,GAAG,WAAW,iBAAiB,CAAA;AAAA,MAChC,SAAA,EAAW,CAAG,EAAA,SAAA,IAAa,EAAE,CAAA,UAAA,CAAA;AAAA,MAC7B,GAAK,EAAA,SAAA;AAAA,MACL,MAAQ,EAAA,UAAA;AAAA,MAER,QAAA,EAAA;AAAA,wBAAA,GAAA;AAAA,UAAC,KAAA;AAAA,UAAA;AAAA,YACC,UAAU,SAAa,IAAA,QAAA;AAAA,YAEvB,GAAK,EAAA,cAAA;AAAA,YACL,QAAA;AAAA,YACA,EAAI,EAAA,EAAE,OAAS,EAAA,aAAA,EAAe,GAAG,OAAQ,EAAA;AAAA,YACzC,cAAa,EAAA,aAAA;AAAA,YACZ,GAAG,IAAA;AAAA,YACH,GAAG,gBAAA;AAAA,WAAA;AAAA,SACN;AAAA,QACC,8BAA8B,QAAY,IAAA,iBAAA;AAAA,QAC1C,CAAC,UACA,oBAAA,GAAA;AAAA,UAAC,UAAA;AAAA,UAAA;AAAA,YACC,OAAA;AAAA,YACA,IAAA;AAAA,YACA,UAAU,QAAY,IAAA,QAAA;AAAA,YACtB,SAAA;AAAA,YACA,GAAK,EAAA,eAAA;AAAA,YACJ,GAAG,WAAA;AAAA,WAAA;AAAA,SACN;AAAA,QAED,8BAA8B,OAAW,IAAA,iBAAA;AAAA,OAAA;AAAA,KAAA;AAAA,GAC5C,CAAA;AAEJ;;;;"}