@ncds/ui-admin 1.6.4 → 1.8.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 (1003) hide show
  1. package/dist/cjs/assets/scripts/baseBox.js +146 -0
  2. package/dist/cjs/assets/scripts/comboBox.js +61 -204
  3. package/dist/cjs/assets/scripts/datePicker.js +290 -325
  4. package/dist/cjs/assets/scripts/featuredIcon.js +42 -50
  5. package/dist/cjs/assets/scripts/fileInput/const/classNames.js +5 -15
  6. package/dist/cjs/assets/scripts/fileInput/fileInput.js +78 -0
  7. package/dist/cjs/assets/scripts/fileInput/fileInputModel.js +53 -0
  8. package/dist/cjs/assets/scripts/fileInput/fileInputView.js +152 -0
  9. package/dist/cjs/assets/scripts/fileInput/index.js +3 -3
  10. package/dist/cjs/assets/scripts/imageFileInput/ImageFileInput.js +61 -64
  11. package/dist/cjs/assets/scripts/imageFileInput/ImageFileInputModel.js +79 -112
  12. package/dist/cjs/assets/scripts/imageFileInput/ImageFileInputView.js +108 -106
  13. package/dist/cjs/assets/scripts/imageFileInput/const/classNames.js +6 -16
  14. package/dist/cjs/assets/scripts/index.js +2 -0
  15. package/dist/cjs/assets/scripts/modal/Modal.js +43 -55
  16. package/dist/cjs/assets/scripts/modal/ModalActions.js +40 -52
  17. package/dist/cjs/assets/scripts/modal/ModalContent.js +22 -22
  18. package/dist/cjs/assets/scripts/modal/ModalHeader.js +37 -48
  19. package/dist/cjs/assets/scripts/modal/const/classNames.js +5 -13
  20. package/dist/cjs/assets/scripts/modal/utils/contentUtils.js +1 -1
  21. package/dist/cjs/assets/scripts/notification/FloatingNotification.js +91 -93
  22. package/dist/cjs/assets/scripts/notification/FullWidthNotification.js +92 -80
  23. package/dist/cjs/assets/scripts/notification/MessageNotification.js +92 -79
  24. package/dist/cjs/assets/scripts/notification/Notification.js +50 -65
  25. package/dist/cjs/assets/scripts/notification/const/classNames.js +1 -1
  26. package/dist/cjs/assets/scripts/notification/const/icons.js +11 -25
  27. package/dist/cjs/assets/scripts/notification/const/sizes.js +11 -19
  28. package/dist/cjs/assets/scripts/notification/const/types.js +1 -1
  29. package/dist/cjs/assets/scripts/notification/utils.js +28 -23
  30. package/dist/cjs/assets/scripts/progress-bar/ProgressBar.js +140 -141
  31. package/dist/cjs/assets/scripts/selectBox.js +77 -227
  32. package/dist/cjs/assets/scripts/shared/ButtonCloseX.js +18 -19
  33. package/dist/cjs/assets/scripts/slider.js +104 -122
  34. package/dist/cjs/assets/scripts/tab.js +8 -8
  35. package/dist/cjs/assets/scripts/table/Table.js +377 -0
  36. package/dist/cjs/assets/scripts/table/const/classNames.js +33 -0
  37. package/dist/cjs/assets/scripts/table/const/index.js +27 -0
  38. package/dist/cjs/assets/scripts/table/const/types.js +5 -0
  39. package/dist/cjs/assets/scripts/table/index.js +43 -0
  40. package/dist/cjs/assets/scripts/tag/Tag.js +108 -115
  41. package/dist/cjs/assets/scripts/tag/const/classNames.js +3 -7
  42. package/dist/cjs/assets/scripts/tag/const/sizes.js +4 -4
  43. package/dist/cjs/assets/scripts/tooltip/Tooltip.js +155 -182
  44. package/dist/cjs/assets/scripts/tooltip/TooltipLayerManager.js +23 -25
  45. package/dist/cjs/assets/scripts/tooltip/const/classNames.js +1 -1
  46. package/dist/cjs/assets/scripts/tooltip/const/constants.js +14 -14
  47. package/dist/cjs/assets/scripts/tooltip/const/icons.js +7 -7
  48. package/dist/cjs/assets/scripts/tooltip/const/templates.js +42 -25
  49. package/dist/cjs/assets/scripts/tooltip/utils.js +17 -18
  50. package/dist/cjs/assets/scripts/utils/debounce.js +32 -0
  51. package/dist/cjs/assets/scripts/utils/unifiedBox/{DOMRenderer.js → domRenderer.js} +102 -116
  52. package/dist/cjs/assets/scripts/utils/unifiedBox/dropdownModel.js +285 -0
  53. package/dist/cjs/assets/scripts/utils/unifiedBox/{UnifiedBoxController.js → unifiedBoxController.js} +187 -246
  54. package/dist/cjs/assets/scripts/utils/unifiedBox/unifiedBoxManager.js +473 -0
  55. package/dist/cjs/constant/color.js +1 -1
  56. package/dist/cjs/index.js +0 -297
  57. package/dist/cjs/src/components/badge/Badge.js +17 -30
  58. package/dist/cjs/src/components/badge/index.js +0 -11
  59. package/dist/cjs/src/components/badge/utils.js +11 -10
  60. package/dist/cjs/src/components/badge-group/BadgeGroup.js +42 -0
  61. package/dist/cjs/src/components/badge-group/index.js +16 -0
  62. package/dist/cjs/src/components/bread-crumb/BreadCrumb.js +55 -0
  63. package/dist/cjs/src/components/button/Button.js +42 -55
  64. package/dist/cjs/src/components/button/ButtonCloseX.js +12 -22
  65. package/dist/cjs/src/components/button/ButtonStepper.js +9 -7
  66. package/dist/cjs/src/components/button/index.js +0 -11
  67. package/dist/cjs/src/components/button-group/ButtonGroup.js +97 -0
  68. package/dist/cjs/src/components/button-group/index.js +16 -0
  69. package/dist/cjs/src/components/carousel-arrow/CarouselArrow.js +34 -0
  70. package/dist/cjs/src/components/carousel-arrow/index.js +16 -0
  71. package/dist/cjs/src/components/carousel-number-group/CarouselNumberGroup.js +33 -0
  72. package/dist/cjs/src/components/{carousel → carousel-number-group}/index.js +0 -11
  73. package/dist/cjs/src/components/checkbox/Checkbox.js +28 -49
  74. package/dist/cjs/src/components/checkbox/CheckboxInput.js +24 -43
  75. package/dist/cjs/src/components/combo-box/ComboBox.js +290 -0
  76. package/dist/cjs/src/components/data-grid/DataGrid.js +182 -0
  77. package/dist/cjs/src/components/data-grid/DataGrid.types.js +5 -0
  78. package/dist/cjs/src/components/data-grid/index.js +27 -0
  79. package/dist/cjs/src/components/date-picker/CustomInput.js +16 -30
  80. package/dist/cjs/src/components/date-picker/DatePicker.js +420 -240
  81. package/dist/cjs/src/components/date-picker/index.js +0 -22
  82. package/dist/cjs/src/components/date-picker/utils.js +2 -4
  83. package/dist/cjs/src/components/divider/Divider.js +15 -26
  84. package/dist/cjs/src/components/dot/Dot.js +11 -28
  85. package/dist/cjs/src/components/dropdown/Dropdown.js +90 -131
  86. package/dist/cjs/src/components/empty-state/EmptyState.js +28 -45
  87. package/dist/cjs/src/components/featured-icon/FeaturedIcon.js +14 -33
  88. package/dist/cjs/src/components/file-input/FileInput.js +102 -148
  89. package/dist/cjs/src/components/horizontal-tab/HorizontalTab.js +53 -0
  90. package/dist/cjs/src/components/horizontal-tab/index.js +16 -0
  91. package/dist/cjs/src/components/image-file-input/ImageFileInput.js +109 -167
  92. package/dist/cjs/src/components/image-file-input/components/ImagePreview.js +8 -17
  93. package/dist/cjs/src/components/index.js +156 -24
  94. package/dist/cjs/src/components/input-base/InputBase.js +195 -0
  95. package/dist/cjs/src/components/input-base/index.js +16 -0
  96. package/dist/cjs/src/components/modal/Modal.js +76 -105
  97. package/dist/cjs/src/components/notification/FloatingNotification.js +52 -80
  98. package/dist/cjs/src/components/notification/FullWidthNotification.js +67 -101
  99. package/dist/cjs/src/components/notification/MessageNotification.js +60 -89
  100. package/dist/cjs/src/components/notification/Notification.js +18 -36
  101. package/dist/cjs/src/components/notification/index.js +11 -11
  102. package/dist/cjs/src/components/number-input/NumberInput.js +112 -0
  103. package/dist/cjs/src/components/number-input/index.js +16 -0
  104. package/dist/cjs/src/components/pagination/NavButton.js +29 -41
  105. package/dist/cjs/src/components/pagination/Pagination.js +68 -109
  106. package/dist/cjs/src/components/password-input/PasswordInput.js +55 -0
  107. package/dist/cjs/src/components/password-input/index.js +16 -0
  108. package/dist/cjs/src/components/progress-bar/ProgressBar.js +50 -61
  109. package/dist/cjs/src/components/progress-bar/components/SegmentBar.js +11 -9
  110. package/dist/cjs/src/components/progress-bar/components/SegmentLabels.js +32 -43
  111. package/dist/cjs/src/components/progress-bar/hooks/useProgressBar.js +59 -77
  112. package/dist/cjs/src/components/progress-bar/utils.js +10 -9
  113. package/dist/cjs/src/components/progress-circle/ProgressCircle.js +65 -88
  114. package/dist/cjs/src/components/radio/Radio.js +24 -43
  115. package/dist/cjs/src/components/radio/RadioInput.js +18 -36
  116. package/dist/cjs/src/components/range-date-picker/RangeDatePicker.js +147 -0
  117. package/dist/cjs/src/components/range-date-picker/index.js +16 -0
  118. package/dist/cjs/src/components/range-date-picker-with-buttons/RangeDatePickerWithButtons.js +81 -0
  119. package/dist/cjs/src/components/range-date-picker-with-buttons/index.js +16 -0
  120. package/dist/cjs/src/components/select/Select.js +36 -63
  121. package/dist/cjs/src/components/select-box/SelectBox.js +260 -0
  122. package/dist/cjs/src/components/select-dropdown/SelectDropdown.js +64 -100
  123. package/dist/cjs/src/components/shared/hintText/HintText.js +13 -30
  124. package/dist/cjs/src/components/shared/label/Label.js +12 -29
  125. package/dist/cjs/src/components/slider/Slider.js +25 -28
  126. package/dist/cjs/src/components/spinner/Spinner.js +22 -35
  127. package/dist/cjs/src/components/spinner/index.js +0 -11
  128. package/dist/cjs/src/components/switch/Switch.js +44 -64
  129. package/dist/cjs/src/components/tab/TabButton.js +41 -61
  130. package/dist/cjs/src/components/tab/index.js +0 -22
  131. package/dist/cjs/src/components/table/Table.js +269 -0
  132. package/dist/cjs/src/components/table/index.js +16 -0
  133. package/dist/cjs/src/components/table/types.js +5 -0
  134. package/dist/cjs/src/components/tag/Tag.js +65 -85
  135. package/dist/cjs/src/components/textarea/Textarea.js +79 -0
  136. package/dist/cjs/src/components/textarea/index.js +16 -0
  137. package/dist/cjs/src/components/toggle/Toggle.js +29 -55
  138. package/dist/cjs/src/components/tooltip/Tooltip.js +90 -108
  139. package/dist/cjs/src/components/vertical-tab/VerticalTab.js +48 -0
  140. package/dist/cjs/src/components/vertical-tab/index.js +16 -0
  141. package/dist/cjs/src/constant/breakpoint.js +3 -3
  142. package/dist/cjs/src/constant/date-picker.js +1 -1
  143. package/dist/cjs/src/constant/index.js +8 -8
  144. package/dist/cjs/src/constant/size.js +1 -1
  145. package/dist/cjs/src/hooks/dropdown/useDropdown.js +58 -60
  146. package/dist/cjs/src/hooks/dropdown/useDropdownKeyboard.js +69 -81
  147. package/dist/cjs/src/hooks/dropdown/useDropdownPosition.js +7 -9
  148. package/dist/cjs/src/hooks/dropdown/useOutsideClick.js +11 -11
  149. package/dist/cjs/src/hooks/dropdown/useScrollLock.js +43 -32
  150. package/dist/cjs/src/hooks/dropdown/useWindowResize.js +12 -13
  151. package/dist/cjs/src/hooks/index.js +4 -4
  152. package/dist/cjs/src/hooks/useCallbackRef.js +2 -2
  153. package/dist/cjs/src/hooks/useMediaQuery.js +8 -11
  154. package/dist/cjs/src/hooks/useMergeRefs.js +2 -2
  155. package/dist/cjs/src/utils/date-picker.js +31 -25
  156. package/dist/cjs/src/utils/dropdown/dropdownUtils.js +43 -41
  157. package/dist/cjs/src/utils/dropdown/multiSelect.js +25 -45
  158. package/dist/esm/assets/scripts/baseBox.js +139 -0
  159. package/dist/esm/assets/scripts/comboBox.js +59 -204
  160. package/dist/esm/assets/scripts/datePicker.js +289 -325
  161. package/dist/esm/assets/scripts/featuredIcon.js +41 -51
  162. package/dist/esm/assets/scripts/fileInput/const/classNames.js +4 -13
  163. package/dist/esm/assets/scripts/fileInput/fileInput.js +71 -0
  164. package/dist/esm/assets/scripts/fileInput/fileInputModel.js +46 -0
  165. package/dist/esm/assets/scripts/fileInput/fileInputView.js +145 -0
  166. package/dist/esm/assets/scripts/fileInput/index.js +2 -2
  167. package/dist/esm/assets/scripts/imageFileInput/ImageFileInput.js +60 -65
  168. package/dist/esm/assets/scripts/imageFileInput/ImageFileInputModel.js +78 -113
  169. package/dist/esm/assets/scripts/imageFileInput/ImageFileInputView.js +108 -108
  170. package/dist/esm/assets/scripts/imageFileInput/const/classNames.js +6 -16
  171. package/dist/esm/assets/scripts/index.js +2 -0
  172. package/dist/esm/assets/scripts/modal/Modal.js +43 -55
  173. package/dist/esm/assets/scripts/modal/ModalActions.js +39 -53
  174. package/dist/esm/assets/scripts/modal/ModalContent.js +21 -23
  175. package/dist/esm/assets/scripts/modal/ModalHeader.js +36 -49
  176. package/dist/esm/assets/scripts/modal/const/classNames.js +5 -13
  177. package/dist/esm/assets/scripts/modal/utils/contentUtils.js +1 -1
  178. package/dist/esm/assets/scripts/notification/FloatingNotification.js +90 -94
  179. package/dist/esm/assets/scripts/notification/FullWidthNotification.js +91 -81
  180. package/dist/esm/assets/scripts/notification/MessageNotification.js +91 -80
  181. package/dist/esm/assets/scripts/notification/Notification.js +49 -66
  182. package/dist/esm/assets/scripts/notification/const/classNames.js +1 -1
  183. package/dist/esm/assets/scripts/notification/const/icons.js +11 -25
  184. package/dist/esm/assets/scripts/notification/const/sizes.js +11 -19
  185. package/dist/esm/assets/scripts/notification/const/types.js +1 -1
  186. package/dist/esm/assets/scripts/notification/utils.js +28 -23
  187. package/dist/esm/assets/scripts/progress-bar/ProgressBar.js +139 -142
  188. package/dist/esm/assets/scripts/selectBox.js +75 -227
  189. package/dist/esm/assets/scripts/shared/ButtonCloseX.js +18 -19
  190. package/dist/esm/assets/scripts/slider.js +103 -123
  191. package/dist/esm/assets/scripts/tab.js +7 -9
  192. package/dist/esm/assets/scripts/table/Table.js +370 -0
  193. package/dist/esm/assets/scripts/table/const/classNames.js +27 -0
  194. package/dist/esm/assets/scripts/table/const/index.js +2 -0
  195. package/dist/esm/assets/scripts/table/const/types.js +1 -0
  196. package/dist/esm/assets/scripts/table/index.js +8 -0
  197. package/dist/esm/assets/scripts/tag/Tag.js +107 -116
  198. package/dist/esm/assets/scripts/tag/const/classNames.js +3 -7
  199. package/dist/esm/assets/scripts/tag/const/sizes.js +4 -4
  200. package/dist/esm/assets/scripts/tooltip/Tooltip.js +154 -183
  201. package/dist/esm/assets/scripts/tooltip/TooltipLayerManager.js +22 -26
  202. package/dist/esm/assets/scripts/tooltip/const/classNames.js +1 -1
  203. package/dist/esm/assets/scripts/tooltip/const/constants.js +14 -14
  204. package/dist/esm/assets/scripts/tooltip/const/icons.js +7 -7
  205. package/dist/esm/assets/scripts/tooltip/const/templates.js +42 -25
  206. package/dist/esm/assets/scripts/tooltip/utils.js +17 -18
  207. package/dist/esm/assets/scripts/utils/debounce.js +26 -0
  208. package/dist/esm/assets/scripts/utils/unifiedBox/{DOMRenderer.js → domRenderer.js} +101 -117
  209. package/dist/esm/assets/scripts/utils/unifiedBox/dropdownModel.js +279 -0
  210. package/dist/esm/assets/scripts/utils/unifiedBox/{UnifiedBoxController.js → unifiedBoxController.js} +186 -247
  211. package/dist/esm/assets/scripts/utils/unifiedBox/unifiedBoxManager.js +466 -0
  212. package/dist/esm/constant/color.js +1 -1
  213. package/dist/esm/index.js +0 -27
  214. package/dist/esm/src/components/badge/Badge.js +19 -31
  215. package/dist/esm/src/components/badge/index.js +1 -2
  216. package/dist/esm/src/components/badge/utils.js +13 -11
  217. package/dist/esm/src/components/badge-group/BadgeGroup.js +35 -0
  218. package/dist/esm/src/components/badge-group/index.js +1 -0
  219. package/dist/esm/src/components/bread-crumb/BreadCrumb.js +48 -0
  220. package/dist/esm/src/components/button/Button.js +42 -55
  221. package/dist/esm/src/components/button/ButtonCloseX.js +14 -23
  222. package/dist/esm/src/components/button/ButtonStepper.js +9 -7
  223. package/dist/esm/src/components/button/index.js +0 -1
  224. package/dist/esm/src/components/button-group/ButtonGroup.js +89 -0
  225. package/dist/esm/src/components/button-group/index.js +1 -0
  226. package/dist/esm/src/components/carousel-arrow/CarouselArrow.js +26 -0
  227. package/dist/esm/src/components/carousel-arrow/index.js +1 -0
  228. package/dist/esm/src/components/carousel-number-group/CarouselNumberGroup.js +25 -0
  229. package/dist/esm/src/components/carousel-number-group/index.js +1 -0
  230. package/dist/esm/src/components/checkbox/Checkbox.js +28 -49
  231. package/dist/esm/src/components/checkbox/CheckboxInput.js +24 -43
  232. package/dist/esm/src/components/combo-box/ComboBox.js +284 -0
  233. package/dist/esm/src/components/data-grid/DataGrid.js +175 -0
  234. package/dist/esm/src/components/data-grid/DataGrid.types.js +1 -0
  235. package/dist/esm/src/components/data-grid/index.js +2 -0
  236. package/dist/esm/src/components/date-picker/CustomInput.js +18 -31
  237. package/dist/esm/src/components/date-picker/DatePicker.js +425 -243
  238. package/dist/esm/src/components/date-picker/index.js +0 -2
  239. package/dist/esm/src/components/date-picker/utils.js +2 -4
  240. package/dist/esm/src/components/divider/Divider.js +15 -26
  241. package/dist/esm/src/components/dot/Dot.js +13 -29
  242. package/dist/esm/src/components/dropdown/Dropdown.js +90 -131
  243. package/dist/esm/src/components/empty-state/EmptyState.js +30 -46
  244. package/dist/esm/src/components/featured-icon/FeaturedIcon.js +16 -34
  245. package/dist/esm/src/components/file-input/FileInput.js +102 -148
  246. package/dist/esm/src/components/horizontal-tab/HorizontalTab.js +46 -0
  247. package/dist/esm/src/components/horizontal-tab/index.js +1 -0
  248. package/dist/esm/src/components/image-file-input/ImageFileInput.js +110 -168
  249. package/dist/esm/src/components/image-file-input/components/ImagePreview.js +8 -17
  250. package/dist/esm/src/components/index.js +18 -6
  251. package/dist/esm/src/components/input-base/InputBase.js +189 -0
  252. package/dist/esm/src/components/input-base/index.js +1 -0
  253. package/dist/esm/src/components/modal/Modal.js +78 -106
  254. package/dist/esm/src/components/notification/FloatingNotification.js +54 -81
  255. package/dist/esm/src/components/notification/FullWidthNotification.js +69 -102
  256. package/dist/esm/src/components/notification/MessageNotification.js +62 -90
  257. package/dist/esm/src/components/notification/Notification.js +20 -37
  258. package/dist/esm/src/components/notification/index.js +2 -2
  259. package/dist/esm/src/components/number-input/NumberInput.js +106 -0
  260. package/dist/esm/src/components/number-input/index.js +1 -0
  261. package/dist/esm/src/components/pagination/NavButton.js +29 -41
  262. package/dist/esm/src/components/pagination/Pagination.js +68 -109
  263. package/dist/esm/src/components/password-input/PasswordInput.js +48 -0
  264. package/dist/esm/src/components/password-input/index.js +1 -0
  265. package/dist/esm/src/components/progress-bar/ProgressBar.js +50 -61
  266. package/dist/esm/src/components/progress-bar/components/SegmentBar.js +11 -9
  267. package/dist/esm/src/components/progress-bar/components/SegmentLabels.js +34 -44
  268. package/dist/esm/src/components/progress-bar/hooks/useProgressBar.js +59 -77
  269. package/dist/esm/src/components/progress-bar/utils.js +11 -9
  270. package/dist/esm/src/components/progress-circle/ProgressCircle.js +65 -88
  271. package/dist/esm/src/components/radio/Radio.js +24 -43
  272. package/dist/esm/src/components/radio/RadioInput.js +18 -36
  273. package/dist/esm/src/components/range-date-picker/RangeDatePicker.js +141 -0
  274. package/dist/esm/src/components/range-date-picker/index.js +1 -0
  275. package/dist/esm/src/components/range-date-picker-with-buttons/RangeDatePickerWithButtons.js +75 -0
  276. package/dist/esm/src/components/range-date-picker-with-buttons/index.js +1 -0
  277. package/dist/esm/src/components/select/Select.js +36 -63
  278. package/dist/esm/src/components/select-box/SelectBox.js +254 -0
  279. package/dist/esm/src/components/select-dropdown/SelectDropdown.js +66 -101
  280. package/dist/esm/src/components/shared/hintText/HintText.js +13 -30
  281. package/dist/esm/src/components/shared/label/Label.js +12 -29
  282. package/dist/esm/src/components/slider/Slider.js +25 -28
  283. package/dist/esm/src/components/spinner/Spinner.js +22 -35
  284. package/dist/esm/src/components/spinner/index.js +1 -2
  285. package/dist/esm/src/components/switch/Switch.js +47 -66
  286. package/dist/esm/src/components/tab/TabButton.js +43 -62
  287. package/dist/esm/src/components/tab/index.js +1 -3
  288. package/dist/esm/src/components/table/Table.js +262 -0
  289. package/dist/esm/src/components/table/index.js +1 -0
  290. package/dist/esm/src/components/table/types.js +1 -0
  291. package/dist/esm/src/components/tag/Tag.js +67 -86
  292. package/dist/esm/src/components/textarea/Textarea.js +72 -0
  293. package/dist/esm/src/components/textarea/index.js +1 -0
  294. package/dist/esm/src/components/toggle/Toggle.js +30 -56
  295. package/dist/esm/src/components/tooltip/Tooltip.js +92 -110
  296. package/dist/esm/src/components/vertical-tab/VerticalTab.js +40 -0
  297. package/dist/esm/src/components/vertical-tab/index.js +1 -0
  298. package/dist/esm/src/constant/breakpoint.js +3 -3
  299. package/dist/esm/src/constant/date-picker.js +1 -1
  300. package/dist/esm/src/constant/index.js +2 -2
  301. package/dist/esm/src/constant/size.js +1 -1
  302. package/dist/esm/src/hooks/dropdown/useDropdown.js +58 -60
  303. package/dist/esm/src/hooks/dropdown/useDropdownKeyboard.js +69 -81
  304. package/dist/esm/src/hooks/dropdown/useDropdownPosition.js +7 -9
  305. package/dist/esm/src/hooks/dropdown/useOutsideClick.js +11 -11
  306. package/dist/esm/src/hooks/dropdown/useScrollLock.js +43 -32
  307. package/dist/esm/src/hooks/dropdown/useWindowResize.js +12 -13
  308. package/dist/esm/src/hooks/index.js +3 -3
  309. package/dist/esm/src/hooks/useCallbackRef.js +2 -2
  310. package/dist/esm/src/hooks/useMediaQuery.js +8 -11
  311. package/dist/esm/src/hooks/useMergeRefs.js +2 -2
  312. package/dist/esm/src/utils/date-picker.js +31 -25
  313. package/dist/esm/src/utils/dropdown/dropdownUtils.js +43 -41
  314. package/dist/esm/src/utils/dropdown/multiSelect.js +25 -45
  315. package/dist/temp/assets/scripts/baseBox.d.ts +55 -0
  316. package/dist/temp/assets/scripts/baseBox.js +140 -0
  317. package/dist/temp/assets/scripts/comboBox.d.ts +60 -0
  318. package/dist/temp/assets/scripts/comboBox.js +132 -0
  319. package/dist/temp/assets/scripts/datePicker.d.ts +86 -0
  320. package/dist/temp/assets/scripts/datePicker.js +699 -0
  321. package/dist/temp/assets/scripts/featuredIcon.d.ts +22 -0
  322. package/dist/temp/assets/scripts/featuredIcon.js +79 -0
  323. package/dist/temp/assets/scripts/fileInput/const/classNames.d.ts +15 -0
  324. package/dist/temp/assets/scripts/fileInput/const/classNames.js +16 -0
  325. package/dist/temp/assets/scripts/fileInput/const/index.d.ts +2 -0
  326. package/dist/temp/assets/scripts/fileInput/const/index.js +2 -0
  327. package/dist/temp/assets/scripts/fileInput/const/types.d.ts +88 -0
  328. package/dist/temp/assets/scripts/fileInput/const/types.js +7 -0
  329. package/dist/temp/assets/scripts/fileInput/fileInput.d.ts +13 -0
  330. package/dist/temp/assets/scripts/fileInput/fileInput.js +71 -0
  331. package/dist/temp/assets/scripts/fileInput/fileInputModel.d.ts +12 -0
  332. package/dist/temp/assets/scripts/fileInput/fileInputModel.js +37 -0
  333. package/dist/temp/assets/scripts/fileInput/fileInputView.d.ts +42 -0
  334. package/dist/temp/assets/scripts/fileInput/fileInputView.js +145 -0
  335. package/dist/temp/assets/scripts/fileInput/index.d.ts +3 -0
  336. package/dist/temp/assets/scripts/fileInput/index.js +9 -0
  337. package/dist/{types/assets/scripts/fileInput/FileInput.d.ts → temp/assets/scripts/imageFileInput/ImageFileInput.d.ts} +6 -10
  338. package/dist/temp/assets/scripts/imageFileInput/ImageFileInput.js +180 -0
  339. package/dist/{types/assets/scripts/fileInput/FileInputModel.d.ts → temp/assets/scripts/imageFileInput/ImageFileInputModel.d.ts} +8 -5
  340. package/dist/temp/assets/scripts/imageFileInput/ImageFileInputModel.js +214 -0
  341. package/dist/{types/assets/scripts/fileInput/FileInputView.d.ts → temp/assets/scripts/imageFileInput/ImageFileInputView.d.ts} +27 -25
  342. package/dist/temp/assets/scripts/imageFileInput/ImageFileInputView.js +350 -0
  343. package/dist/temp/assets/scripts/imageFileInput/const/classNames.d.ts +19 -0
  344. package/dist/temp/assets/scripts/imageFileInput/const/classNames.js +20 -0
  345. package/dist/temp/assets/scripts/imageFileInput/const/index.d.ts +2 -0
  346. package/dist/temp/assets/scripts/imageFileInput/const/index.js +2 -0
  347. package/dist/temp/assets/scripts/imageFileInput/const/types.d.ts +125 -0
  348. package/dist/temp/assets/scripts/imageFileInput/const/types.js +7 -0
  349. package/dist/temp/assets/scripts/imageFileInput/index.d.ts +3 -0
  350. package/dist/temp/assets/scripts/imageFileInput/index.js +9 -0
  351. package/dist/temp/assets/scripts/index.d.ts +34 -0
  352. package/dist/temp/assets/scripts/index.js +30 -0
  353. package/dist/temp/assets/scripts/modal/Modal.d.ts +27 -0
  354. package/dist/temp/assets/scripts/modal/Modal.js +100 -0
  355. package/dist/temp/assets/scripts/modal/ModalActions.d.ts +18 -0
  356. package/dist/temp/assets/scripts/modal/ModalActions.js +117 -0
  357. package/dist/temp/assets/scripts/modal/ModalContent.d.ts +13 -0
  358. package/dist/temp/assets/scripts/modal/ModalContent.js +39 -0
  359. package/dist/temp/assets/scripts/modal/ModalHeader.d.ts +15 -0
  360. package/dist/temp/assets/scripts/modal/ModalHeader.js +96 -0
  361. package/dist/temp/assets/scripts/modal/const/classNames.d.ts +22 -0
  362. package/dist/temp/assets/scripts/modal/const/classNames.js +23 -0
  363. package/dist/temp/assets/scripts/modal/const/index.d.ts +2 -0
  364. package/dist/temp/assets/scripts/modal/const/index.js +2 -0
  365. package/dist/temp/assets/scripts/modal/const/types.d.ts +61 -0
  366. package/dist/temp/assets/scripts/modal/const/types.js +1 -0
  367. package/dist/temp/assets/scripts/modal/index.d.ts +7 -0
  368. package/dist/temp/assets/scripts/modal/index.js +15 -0
  369. package/dist/temp/assets/scripts/modal/utils/contentUtils.d.ts +10 -0
  370. package/dist/temp/assets/scripts/modal/utils/contentUtils.js +29 -0
  371. package/dist/temp/assets/scripts/notification/FloatingNotification.d.ts +24 -0
  372. package/dist/temp/assets/scripts/notification/FloatingNotification.js +157 -0
  373. package/dist/temp/assets/scripts/notification/FullWidthNotification.d.ts +21 -0
  374. package/dist/temp/assets/scripts/notification/FullWidthNotification.js +110 -0
  375. package/dist/temp/assets/scripts/notification/MessageNotification.d.ts +22 -0
  376. package/dist/temp/assets/scripts/notification/MessageNotification.js +140 -0
  377. package/dist/temp/assets/scripts/notification/Notification.d.ts +21 -0
  378. package/dist/temp/assets/scripts/notification/Notification.js +94 -0
  379. package/dist/temp/assets/scripts/notification/const/classNames.d.ts +43 -0
  380. package/dist/temp/assets/scripts/notification/const/classNames.js +44 -0
  381. package/dist/temp/assets/scripts/notification/const/icons.d.ts +25 -0
  382. package/dist/temp/assets/scripts/notification/const/icons.js +25 -0
  383. package/dist/temp/assets/scripts/notification/const/index.d.ts +5 -0
  384. package/dist/temp/assets/scripts/notification/const/index.js +4 -0
  385. package/dist/temp/assets/scripts/notification/const/sizes.d.ts +32 -0
  386. package/dist/temp/assets/scripts/notification/const/sizes.js +40 -0
  387. package/dist/temp/assets/scripts/notification/const/types.d.ts +19 -0
  388. package/dist/temp/assets/scripts/notification/const/types.js +8 -0
  389. package/dist/temp/assets/scripts/notification/index.d.ts +7 -0
  390. package/dist/temp/assets/scripts/notification/index.js +11 -0
  391. package/dist/temp/assets/scripts/notification/utils.d.ts +8 -0
  392. package/dist/temp/assets/scripts/notification/utils.js +89 -0
  393. package/dist/temp/assets/scripts/progress-bar/ProgressBar.d.ts +67 -0
  394. package/dist/temp/assets/scripts/progress-bar/ProgressBar.js +263 -0
  395. package/dist/temp/assets/scripts/progress-bar/index.d.ts +1 -0
  396. package/dist/temp/assets/scripts/progress-bar/index.js +1 -0
  397. package/dist/temp/assets/scripts/selectBox.d.ts +50 -0
  398. package/dist/temp/assets/scripts/selectBox.js +170 -0
  399. package/dist/temp/assets/scripts/shared/ButtonCloseX.d.ts +5 -0
  400. package/dist/temp/assets/scripts/shared/ButtonCloseX.js +33 -0
  401. package/dist/temp/assets/scripts/slider.d.ts +41 -0
  402. package/dist/temp/assets/scripts/slider.js +323 -0
  403. package/dist/temp/assets/scripts/tab.d.ts +7 -0
  404. package/dist/temp/assets/scripts/tab.js +33 -0
  405. package/dist/temp/assets/scripts/table/Table.d.ts +41 -0
  406. package/dist/temp/assets/scripts/table/Table.js +378 -0
  407. package/dist/temp/assets/scripts/table/const/classNames.d.ts +27 -0
  408. package/dist/temp/assets/scripts/table/const/classNames.js +27 -0
  409. package/dist/temp/assets/scripts/table/const/index.d.ts +2 -0
  410. package/dist/temp/assets/scripts/table/const/index.js +2 -0
  411. package/dist/temp/assets/scripts/table/const/types.d.ts +23 -0
  412. package/dist/temp/assets/scripts/table/const/types.js +1 -0
  413. package/dist/temp/assets/scripts/table/index.d.ts +3 -0
  414. package/dist/temp/assets/scripts/table/index.js +8 -0
  415. package/dist/temp/assets/scripts/tag/Tag.d.ts +27 -0
  416. package/dist/temp/assets/scripts/tag/Tag.js +259 -0
  417. package/dist/temp/assets/scripts/tag/const/classNames.d.ts +11 -0
  418. package/dist/temp/assets/scripts/tag/const/classNames.js +12 -0
  419. package/dist/temp/assets/scripts/tag/const/index.d.ts +3 -0
  420. package/dist/temp/assets/scripts/tag/const/index.js +3 -0
  421. package/dist/temp/assets/scripts/tag/const/sizes.d.ts +7 -0
  422. package/dist/temp/assets/scripts/tag/const/sizes.js +7 -0
  423. package/dist/temp/assets/scripts/tag/const/types.d.ts +33 -0
  424. package/dist/temp/assets/scripts/tag/const/types.js +1 -0
  425. package/dist/temp/assets/scripts/tag/index.d.ts +3 -0
  426. package/dist/temp/assets/scripts/tag/index.js +9 -0
  427. package/dist/temp/assets/scripts/tooltip/Tooltip.d.ts +54 -0
  428. package/dist/temp/assets/scripts/tooltip/Tooltip.js +335 -0
  429. package/dist/temp/assets/scripts/tooltip/TooltipLayerManager.d.ts +21 -0
  430. package/dist/temp/assets/scripts/tooltip/TooltipLayerManager.js +71 -0
  431. package/dist/temp/assets/scripts/tooltip/const/classNames.d.ts +17 -0
  432. package/dist/temp/assets/scripts/tooltip/const/classNames.js +23 -0
  433. package/dist/temp/assets/scripts/tooltip/const/constants.d.ts +33 -0
  434. package/dist/temp/assets/scripts/tooltip/const/constants.js +46 -0
  435. package/dist/temp/assets/scripts/tooltip/const/icons.d.ts +4 -0
  436. package/dist/temp/assets/scripts/tooltip/const/icons.js +9 -0
  437. package/dist/temp/assets/scripts/tooltip/const/index.d.ts +5 -0
  438. package/dist/temp/assets/scripts/tooltip/const/index.js +4 -0
  439. package/dist/temp/assets/scripts/tooltip/const/templates.d.ts +16 -0
  440. package/dist/temp/assets/scripts/tooltip/const/templates.js +59 -0
  441. package/dist/temp/assets/scripts/tooltip/const/types.d.ts +14 -0
  442. package/dist/temp/assets/scripts/tooltip/const/types.js +1 -0
  443. package/dist/temp/assets/scripts/tooltip/index.d.ts +6 -0
  444. package/dist/temp/assets/scripts/tooltip/index.js +10 -0
  445. package/dist/temp/assets/scripts/tooltip/utils.d.ts +2 -0
  446. package/dist/temp/assets/scripts/tooltip/utils.js +33 -0
  447. package/dist/temp/assets/scripts/utils/debounce.d.ts +8 -0
  448. package/dist/temp/assets/scripts/utils/debounce.js +23 -0
  449. package/dist/{types/assets/scripts/utils/unifiedBox/DOMRenderer.d.ts → temp/assets/scripts/utils/unifiedBox/domRenderer.d.ts} +0 -1
  450. package/dist/temp/assets/scripts/utils/unifiedBox/domRenderer.js +367 -0
  451. package/dist/{types/assets/scripts/utils/unifiedBox/DropdownModel.d.ts → temp/assets/scripts/utils/unifiedBox/dropdownModel.d.ts} +7 -23
  452. package/dist/temp/assets/scripts/utils/unifiedBox/dropdownModel.js +286 -0
  453. package/dist/{types/assets/scripts/utils/unifiedBox/UnifiedBoxController.d.ts → temp/assets/scripts/utils/unifiedBox/unifiedBoxController.d.ts} +3 -18
  454. package/dist/temp/assets/scripts/utils/unifiedBox/unifiedBoxController.js +604 -0
  455. package/dist/{types/assets/scripts/utils/unifiedBox/UnifiedBoxManager.d.ts → temp/assets/scripts/utils/unifiedBox/unifiedBoxManager.d.ts} +4 -8
  456. package/dist/temp/assets/scripts/utils/unifiedBox/unifiedBoxManager.js +482 -0
  457. package/dist/temp/constant/color.d.ts +36 -0
  458. package/dist/temp/constant/color.js +34 -0
  459. package/dist/temp/constant/size.d.ts +1 -0
  460. package/dist/temp/constant/size.js +1 -0
  461. package/dist/temp/index.d.ts +2 -0
  462. package/dist/temp/index.js +2 -0
  463. package/dist/temp/src/components/badge/Badge.d.ts +18 -0
  464. package/dist/temp/src/components/badge/Badge.js +11 -0
  465. package/dist/temp/src/components/badge/index.d.ts +1 -0
  466. package/dist/temp/src/components/badge/index.js +1 -0
  467. package/dist/temp/src/components/badge/utils.d.ts +8 -0
  468. package/dist/temp/src/components/badge/utils.js +15 -0
  469. package/dist/temp/src/components/badge-group/BadgeGroup.d.ts +18 -0
  470. package/dist/temp/src/components/badge-group/BadgeGroup.js +13 -0
  471. package/dist/temp/src/components/badge-group/index.d.ts +1 -0
  472. package/dist/temp/src/components/badge-group/index.js +1 -0
  473. package/dist/temp/src/components/bread-crumb/BreadCrumb.d.ts +11 -0
  474. package/dist/temp/src/components/bread-crumb/BreadCrumb.js +20 -0
  475. package/dist/temp/src/components/bread-crumb/index.d.ts +1 -0
  476. package/dist/temp/src/components/bread-crumb/index.js +1 -0
  477. package/dist/temp/src/components/button/Button.d.ts +35 -0
  478. package/dist/temp/src/components/button/Button.js +52 -0
  479. package/dist/temp/src/components/button/ButtonCloseX.d.ts +10 -0
  480. package/dist/temp/src/components/button/ButtonCloseX.js +13 -0
  481. package/dist/temp/src/components/button/ButtonStepper.d.ts +9 -0
  482. package/dist/temp/src/components/button/ButtonStepper.js +5 -0
  483. package/dist/temp/src/components/button/index.d.ts +3 -0
  484. package/dist/temp/src/components/button/index.js +3 -0
  485. package/dist/{types/src/components/button → temp/src/components/button-group}/ButtonGroup.d.ts +12 -13
  486. package/dist/temp/src/components/button-group/ButtonGroup.js +51 -0
  487. package/dist/temp/src/components/button-group/index.d.ts +1 -0
  488. package/dist/temp/src/components/button-group/index.js +1 -0
  489. package/dist/temp/src/components/carousel-arrow/CarouselArrow.d.ts +8 -0
  490. package/dist/temp/src/components/carousel-arrow/CarouselArrow.js +9 -0
  491. package/dist/temp/src/components/carousel-arrow/index.d.ts +1 -0
  492. package/dist/temp/src/components/carousel-arrow/index.js +1 -0
  493. package/dist/temp/src/components/carousel-number-group/CarouselNumberGroup.d.ts +8 -0
  494. package/dist/temp/src/components/carousel-number-group/CarouselNumberGroup.js +10 -0
  495. package/dist/temp/src/components/carousel-number-group/index.d.ts +1 -0
  496. package/dist/temp/src/components/carousel-number-group/index.js +1 -0
  497. package/dist/temp/src/components/checkbox/Checkbox.d.ts +7 -0
  498. package/dist/temp/src/components/checkbox/Checkbox.js +7 -0
  499. package/dist/temp/src/components/checkbox/CheckboxInput.d.ts +9 -0
  500. package/dist/temp/src/components/checkbox/CheckboxInput.js +23 -0
  501. package/dist/temp/src/components/checkbox/index.d.ts +2 -0
  502. package/dist/temp/src/components/checkbox/index.js +2 -0
  503. package/dist/{types/src/components/combobox → temp/src/components/combo-box}/ComboBox.d.ts +7 -6
  504. package/dist/temp/src/components/combo-box/ComboBox.js +165 -0
  505. package/dist/{types/src/components/combobox → temp/src/components/combo-box}/index.d.ts +1 -2
  506. package/dist/temp/src/components/combo-box/index.js +1 -0
  507. package/dist/temp/src/components/data-grid/DataGrid.d.ts +28 -0
  508. package/dist/temp/src/components/data-grid/DataGrid.js +88 -0
  509. package/dist/temp/src/components/data-grid/DataGrid.types.d.ts +35 -0
  510. package/dist/temp/src/components/data-grid/DataGrid.types.js +1 -0
  511. package/dist/temp/src/components/data-grid/index.d.ts +2 -0
  512. package/dist/temp/src/components/data-grid/index.js +2 -0
  513. package/dist/temp/src/components/date-picker/CustomInput.d.ts +10 -0
  514. package/dist/temp/src/components/date-picker/CustomInput.js +11 -0
  515. package/dist/temp/src/components/date-picker/DatePicker.d.ts +28 -0
  516. package/dist/temp/src/components/date-picker/DatePicker.js +499 -0
  517. package/dist/temp/src/components/date-picker/index.d.ts +2 -0
  518. package/dist/temp/src/components/date-picker/index.js +2 -0
  519. package/dist/temp/src/components/date-picker/utils.d.ts +2 -0
  520. package/dist/temp/src/components/date-picker/utils.js +7 -0
  521. package/dist/temp/src/components/divider/Divider.d.ts +15 -0
  522. package/dist/temp/src/components/divider/Divider.js +9 -0
  523. package/dist/temp/src/components/divider/index.d.ts +1 -0
  524. package/dist/temp/src/components/divider/index.js +1 -0
  525. package/dist/temp/src/components/dot/Dot.d.ts +24 -0
  526. package/dist/temp/src/components/dot/Dot.js +8 -0
  527. package/dist/temp/src/components/dot/index.d.ts +1 -0
  528. package/dist/temp/src/components/dot/index.js +1 -0
  529. package/dist/temp/src/components/dropdown/Dropdown.d.ts +52 -0
  530. package/dist/temp/src/components/dropdown/Dropdown.js +74 -0
  531. package/dist/temp/src/components/dropdown/index.d.ts +1 -0
  532. package/dist/temp/src/components/dropdown/index.js +1 -0
  533. package/dist/temp/src/components/empty-state/EmptyState.d.ts +14 -0
  534. package/dist/temp/src/components/empty-state/EmptyState.js +7 -0
  535. package/dist/temp/src/components/empty-state/index.d.ts +1 -0
  536. package/dist/temp/src/components/empty-state/index.js +1 -0
  537. package/dist/temp/src/components/featured-icon/FeaturedIcon.d.ts +15 -0
  538. package/dist/temp/src/components/featured-icon/FeaturedIcon.js +13 -0
  539. package/dist/temp/src/components/featured-icon/index.d.ts +1 -0
  540. package/dist/temp/src/components/featured-icon/index.js +1 -0
  541. package/dist/temp/src/components/file-input/FileInput.d.ts +61 -0
  542. package/dist/temp/src/components/file-input/FileInput.js +87 -0
  543. package/dist/temp/src/components/file-input/index.d.ts +1 -0
  544. package/dist/temp/src/components/file-input/index.js +1 -0
  545. package/dist/temp/src/components/horizontal-tab/HorizontalTab.d.ts +12 -0
  546. package/dist/temp/src/components/horizontal-tab/HorizontalTab.js +24 -0
  547. package/dist/temp/src/components/horizontal-tab/index.d.ts +1 -0
  548. package/dist/temp/src/components/horizontal-tab/index.js +1 -0
  549. package/dist/temp/src/components/image-file-input/ImageFileInput.d.ts +70 -0
  550. package/dist/temp/src/components/image-file-input/ImageFileInput.js +96 -0
  551. package/dist/temp/src/components/image-file-input/components/ImagePreview.d.ts +5 -0
  552. package/dist/temp/src/components/image-file-input/components/ImagePreview.js +6 -0
  553. package/dist/temp/src/components/image-file-input/index.d.ts +1 -0
  554. package/dist/temp/src/components/image-file-input/index.js +1 -0
  555. package/dist/temp/src/components/index.d.ts +45 -0
  556. package/dist/temp/src/components/index.js +44 -0
  557. package/dist/{types/src/components/input → temp/src/components/input-base}/InputBase.d.ts +5 -4
  558. package/dist/temp/src/components/input-base/InputBase.js +96 -0
  559. package/dist/temp/src/components/input-base/index.d.ts +1 -0
  560. package/dist/temp/src/components/input-base/index.js +1 -0
  561. package/dist/temp/src/components/modal/Modal.d.ts +79 -0
  562. package/dist/temp/src/components/modal/Modal.js +75 -0
  563. package/dist/temp/src/components/modal/index.d.ts +1 -0
  564. package/dist/temp/src/components/modal/index.js +1 -0
  565. package/dist/temp/src/components/notification/FloatingNotification.d.ts +37 -0
  566. package/dist/temp/src/components/notification/FloatingNotification.js +56 -0
  567. package/dist/temp/src/components/notification/FullWidthNotification.d.ts +46 -0
  568. package/dist/temp/src/components/notification/FullWidthNotification.js +56 -0
  569. package/dist/temp/src/components/notification/MessageNotification.d.ts +41 -0
  570. package/dist/temp/src/components/notification/MessageNotification.js +34 -0
  571. package/dist/temp/src/components/notification/Notification.d.ts +72 -0
  572. package/dist/temp/src/components/notification/Notification.js +19 -0
  573. package/dist/temp/src/components/notification/index.d.ts +4 -0
  574. package/dist/temp/src/components/notification/index.js +4 -0
  575. package/dist/{types/src/components/input → temp/src/components/number-input}/NumberInput.d.ts +1 -2
  576. package/dist/temp/src/components/number-input/NumberInput.js +68 -0
  577. package/dist/temp/src/components/number-input/index.d.ts +1 -0
  578. package/dist/temp/src/components/number-input/index.js +1 -0
  579. package/dist/temp/src/components/pagination/NavButton.d.ts +31 -0
  580. package/dist/temp/src/components/pagination/NavButton.js +54 -0
  581. package/dist/temp/src/components/pagination/Pagination.d.ts +11 -0
  582. package/dist/temp/src/components/pagination/Pagination.js +66 -0
  583. package/dist/temp/src/components/pagination/index.d.ts +2 -0
  584. package/dist/temp/src/components/pagination/index.js +2 -0
  585. package/dist/{types/src/components/input → temp/src/components/password-input}/PasswordInput.d.ts +1 -2
  586. package/dist/temp/src/components/password-input/PasswordInput.js +28 -0
  587. package/dist/temp/src/components/password-input/index.d.ts +1 -0
  588. package/dist/temp/src/components/password-input/index.js +1 -0
  589. package/dist/temp/src/components/progress-bar/ProgressBar.d.ts +2 -0
  590. package/dist/temp/src/components/progress-bar/ProgressBar.js +19 -0
  591. package/dist/temp/src/components/progress-bar/components/SegmentBar.d.ts +7 -0
  592. package/dist/temp/src/components/progress-bar/components/SegmentBar.js +9 -0
  593. package/dist/temp/src/components/progress-bar/components/SegmentLabels.d.ts +15 -0
  594. package/dist/temp/src/components/progress-bar/components/SegmentLabels.js +32 -0
  595. package/dist/temp/src/components/progress-bar/hooks/useProgressBar.d.ts +13 -0
  596. package/dist/temp/src/components/progress-bar/hooks/useProgressBar.js +87 -0
  597. package/dist/temp/src/components/progress-bar/index.d.ts +2 -0
  598. package/dist/temp/src/components/progress-bar/index.js +2 -0
  599. package/dist/temp/src/components/progress-bar/types.d.ts +15 -0
  600. package/dist/temp/src/components/progress-bar/types.js +1 -0
  601. package/dist/temp/src/components/progress-bar/utils.d.ts +13 -0
  602. package/dist/temp/src/components/progress-bar/utils.js +26 -0
  603. package/dist/temp/src/components/progress-circle/ProgressCircle.d.ts +7 -0
  604. package/dist/temp/src/components/progress-circle/ProgressCircle.js +9 -0
  605. package/dist/temp/src/components/progress-circle/index.d.ts +1 -0
  606. package/dist/temp/src/components/progress-circle/index.js +1 -0
  607. package/dist/temp/src/components/radio/Radio.d.ts +7 -0
  608. package/dist/temp/src/components/radio/Radio.js +7 -0
  609. package/dist/temp/src/components/radio/RadioInput.d.ts +8 -0
  610. package/dist/temp/src/components/radio/RadioInput.js +6 -0
  611. package/dist/temp/src/components/radio/index.d.ts +2 -0
  612. package/dist/temp/src/components/radio/index.js +2 -0
  613. package/dist/{types/src/components/date-picker → temp/src/components/range-date-picker}/RangeDatePicker.d.ts +6 -5
  614. package/dist/temp/src/components/range-date-picker/RangeDatePicker.js +104 -0
  615. package/dist/temp/src/components/range-date-picker/index.d.ts +1 -0
  616. package/dist/temp/src/components/range-date-picker/index.js +1 -0
  617. package/dist/{types/src/components/date-picker → temp/src/components/range-date-picker-with-buttons}/RangeDatePickerWithButtons.d.ts +5 -5
  618. package/dist/temp/src/components/range-date-picker-with-buttons/RangeDatePickerWithButtons.js +43 -0
  619. package/dist/temp/src/components/range-date-picker-with-buttons/index.d.ts +1 -0
  620. package/dist/temp/src/components/range-date-picker-with-buttons/index.js +1 -0
  621. package/dist/temp/src/components/select/Select.d.ts +16 -0
  622. package/dist/temp/src/components/select/Select.js +10 -0
  623. package/dist/temp/src/components/select/index.d.ts +1 -0
  624. package/dist/temp/src/components/select/index.js +1 -0
  625. package/dist/{types/src/components/selectbox → temp/src/components/select-box}/SelectBox.d.ts +5 -4
  626. package/dist/temp/src/components/select-box/SelectBox.js +130 -0
  627. package/dist/{types/src/components/selectbox → temp/src/components/select-box}/index.d.ts +0 -1
  628. package/dist/temp/src/components/select-box/index.js +1 -0
  629. package/dist/temp/src/components/select-dropdown/SelectDropdown.d.ts +29 -0
  630. package/dist/temp/src/components/select-dropdown/SelectDropdown.js +26 -0
  631. package/dist/temp/src/components/select-dropdown/index.d.ts +1 -0
  632. package/dist/temp/src/components/select-dropdown/index.js +1 -0
  633. package/dist/temp/src/components/shared/hintText/HintText.d.ts +7 -0
  634. package/dist/temp/src/components/shared/hintText/HintText.js +5 -0
  635. package/dist/temp/src/components/shared/hintText/index.d.ts +1 -0
  636. package/dist/temp/src/components/shared/hintText/index.js +1 -0
  637. package/dist/temp/src/components/shared/index.d.ts +2 -0
  638. package/dist/temp/src/components/shared/index.js +2 -0
  639. package/dist/temp/src/components/shared/label/Label.d.ts +7 -0
  640. package/dist/temp/src/components/shared/label/Label.js +5 -0
  641. package/dist/temp/src/components/shared/label/index.d.ts +1 -0
  642. package/dist/temp/src/components/shared/label/index.js +1 -0
  643. package/dist/temp/src/components/slider/Slider.d.ts +14 -0
  644. package/dist/temp/src/components/slider/Slider.js +43 -0
  645. package/dist/temp/src/components/slider/index.d.ts +1 -0
  646. package/dist/temp/src/components/slider/index.js +1 -0
  647. package/dist/temp/src/components/spinner/Spinner.d.ts +9 -0
  648. package/dist/temp/src/components/spinner/Spinner.js +8 -0
  649. package/dist/temp/src/components/spinner/index.d.ts +1 -0
  650. package/dist/temp/src/components/spinner/index.js +1 -0
  651. package/dist/temp/src/components/switch/Switch.d.ts +22 -0
  652. package/dist/temp/src/components/switch/Switch.js +55 -0
  653. package/dist/temp/src/components/switch/index.d.ts +2 -0
  654. package/dist/temp/src/components/switch/index.js +1 -0
  655. package/dist/temp/src/components/tab/TabButton.d.ts +23 -0
  656. package/dist/temp/src/components/tab/TabButton.js +14 -0
  657. package/dist/temp/src/components/tab/index.d.ts +1 -0
  658. package/dist/temp/src/components/tab/index.js +1 -0
  659. package/dist/temp/src/components/table/Table.d.ts +46 -0
  660. package/dist/temp/src/components/table/Table.js +115 -0
  661. package/dist/temp/src/components/table/index.d.ts +1 -0
  662. package/dist/temp/src/components/table/index.js +1 -0
  663. package/dist/temp/src/components/table/types.d.ts +45 -0
  664. package/dist/temp/src/components/table/types.js +1 -0
  665. package/dist/temp/src/components/tag/Tag.d.ts +17 -0
  666. package/dist/temp/src/components/tag/Tag.js +96 -0
  667. package/dist/temp/src/components/tag/index.d.ts +1 -0
  668. package/dist/temp/src/components/tag/index.js +1 -0
  669. package/dist/{types/src/components/input → temp/src/components/textarea}/Textarea.d.ts +2 -3
  670. package/dist/temp/src/components/textarea/Textarea.js +34 -0
  671. package/dist/temp/src/components/textarea/index.d.ts +1 -0
  672. package/dist/temp/src/components/textarea/index.js +1 -0
  673. package/dist/temp/src/components/toggle/Toggle.d.ts +10 -0
  674. package/dist/temp/src/components/toggle/Toggle.js +7 -0
  675. package/dist/temp/src/components/toggle/index.d.ts +1 -0
  676. package/dist/temp/src/components/toggle/index.js +1 -0
  677. package/dist/temp/src/components/tooltip/Tooltip.d.ts +15 -0
  678. package/dist/temp/src/components/tooltip/Tooltip.js +104 -0
  679. package/dist/temp/src/components/tooltip/index.d.ts +1 -0
  680. package/dist/temp/src/components/tooltip/index.js +1 -0
  681. package/dist/{types/src/components/tab → temp/src/components/vertical-tab}/VerticalTab.d.ts +2 -3
  682. package/dist/temp/src/components/vertical-tab/VerticalTab.js +20 -0
  683. package/dist/temp/src/components/vertical-tab/index.d.ts +1 -0
  684. package/dist/temp/src/components/vertical-tab/index.js +1 -0
  685. package/dist/temp/src/constant/breakpoint.d.ts +6 -0
  686. package/dist/temp/src/constant/breakpoint.js +6 -0
  687. package/dist/temp/src/constant/date-picker.d.ts +63 -0
  688. package/dist/temp/src/constant/date-picker.js +53 -0
  689. package/dist/temp/src/constant/index.d.ts +2 -0
  690. package/dist/temp/src/constant/index.js +2 -0
  691. package/dist/temp/src/constant/size.d.ts +1 -0
  692. package/dist/temp/src/constant/size.js +1 -0
  693. package/dist/temp/src/hooks/dropdown/index.d.ts +6 -0
  694. package/dist/temp/src/hooks/dropdown/index.js +6 -0
  695. package/dist/temp/src/hooks/dropdown/useDropdown.d.ts +29 -0
  696. package/dist/temp/src/hooks/dropdown/useDropdown.js +84 -0
  697. package/dist/temp/src/hooks/dropdown/useDropdownKeyboard.d.ts +10 -0
  698. package/dist/temp/src/hooks/dropdown/useDropdownKeyboard.js +107 -0
  699. package/dist/temp/src/hooks/dropdown/useDropdownPosition.d.ts +9 -0
  700. package/dist/temp/src/hooks/dropdown/useDropdownPosition.js +18 -0
  701. package/dist/temp/src/hooks/dropdown/useOutsideClick.d.ts +5 -0
  702. package/dist/temp/src/hooks/dropdown/useOutsideClick.js +23 -0
  703. package/dist/temp/src/hooks/dropdown/useScrollLock.d.ts +4 -0
  704. package/dist/temp/src/hooks/dropdown/useScrollLock.js +72 -0
  705. package/dist/temp/src/hooks/dropdown/useWindowResize.d.ts +7 -0
  706. package/dist/temp/src/hooks/dropdown/useWindowResize.js +43 -0
  707. package/dist/temp/src/hooks/index.d.ts +4 -0
  708. package/dist/temp/src/hooks/index.js +6 -0
  709. package/dist/temp/src/hooks/useCallbackRef.d.ts +27 -0
  710. package/dist/temp/src/hooks/useCallbackRef.js +44 -0
  711. package/dist/temp/src/hooks/useMediaQuery.d.ts +5 -0
  712. package/dist/temp/src/hooks/useMediaQuery.js +19 -0
  713. package/dist/temp/src/hooks/useMergeRefs.d.ts +20 -0
  714. package/dist/temp/src/hooks/useMergeRefs.js +31 -0
  715. package/dist/temp/src/types/dropdown/dropdown.d.ts +39 -0
  716. package/dist/temp/src/types/dropdown/dropdown.js +1 -0
  717. package/dist/temp/src/types/dropdown/index.d.ts +2 -0
  718. package/dist/temp/src/types/dropdown/index.js +2 -0
  719. package/dist/temp/src/types/dropdown/option.d.ts +23 -0
  720. package/dist/temp/src/types/dropdown/option.js +1 -0
  721. package/dist/temp/src/types/index.d.ts +2 -0
  722. package/dist/temp/src/types/index.js +2 -0
  723. package/dist/temp/src/types/side-slot.d.ts +25 -0
  724. package/dist/temp/src/types/side-slot.js +1 -0
  725. package/dist/temp/src/utils/date-picker.d.ts +11 -0
  726. package/dist/temp/src/utils/date-picker.js +49 -0
  727. package/dist/temp/src/utils/dropdown/dropdownUtils.d.ts +17 -0
  728. package/dist/temp/src/utils/dropdown/dropdownUtils.js +78 -0
  729. package/dist/temp/src/utils/dropdown/index.d.ts +2 -0
  730. package/dist/temp/src/utils/dropdown/index.js +2 -0
  731. package/dist/temp/src/utils/dropdown/multiSelect.d.ts +31 -0
  732. package/dist/temp/src/utils/dropdown/multiSelect.js +66 -0
  733. package/dist/temp/src/utils/index.d.ts +2 -0
  734. package/dist/temp/src/utils/index.js +4 -0
  735. package/dist/types/assets/scripts/baseBox.d.ts +55 -0
  736. package/dist/types/assets/scripts/comboBox.d.ts +7 -38
  737. package/dist/types/assets/scripts/datePicker.d.ts +0 -1
  738. package/dist/types/assets/scripts/featuredIcon.d.ts +0 -1
  739. package/dist/types/assets/scripts/fileInput/const/classNames.d.ts +0 -2
  740. package/dist/types/assets/scripts/fileInput/const/index.d.ts +0 -1
  741. package/dist/types/assets/scripts/fileInput/const/types.d.ts +4 -48
  742. package/dist/types/assets/scripts/fileInput/fileInput.d.ts +13 -0
  743. package/dist/types/assets/scripts/fileInput/fileInputModel.d.ts +12 -0
  744. package/dist/types/assets/scripts/fileInput/fileInputView.d.ts +42 -0
  745. package/dist/types/assets/scripts/fileInput/index.d.ts +1 -2
  746. package/dist/types/assets/scripts/imageFileInput/ImageFileInput.d.ts +0 -1
  747. package/dist/types/assets/scripts/imageFileInput/ImageFileInputModel.d.ts +0 -1
  748. package/dist/types/assets/scripts/imageFileInput/ImageFileInputView.d.ts +0 -1
  749. package/dist/types/assets/scripts/imageFileInput/const/classNames.d.ts +0 -1
  750. package/dist/types/assets/scripts/imageFileInput/const/index.d.ts +0 -1
  751. package/dist/types/assets/scripts/imageFileInput/const/types.d.ts +0 -1
  752. package/dist/types/assets/scripts/imageFileInput/index.d.ts +0 -1
  753. package/dist/types/assets/scripts/index.d.ts +2 -1
  754. package/dist/types/assets/scripts/modal/Modal.d.ts +0 -1
  755. package/dist/types/assets/scripts/modal/ModalActions.d.ts +0 -1
  756. package/dist/types/assets/scripts/modal/ModalContent.d.ts +0 -1
  757. package/dist/types/assets/scripts/modal/ModalHeader.d.ts +0 -1
  758. package/dist/types/assets/scripts/modal/const/classNames.d.ts +0 -1
  759. package/dist/types/assets/scripts/modal/const/index.d.ts +0 -1
  760. package/dist/types/assets/scripts/modal/const/types.d.ts +0 -1
  761. package/dist/types/assets/scripts/modal/index.d.ts +0 -1
  762. package/dist/types/assets/scripts/modal/utils/contentUtils.d.ts +0 -1
  763. package/dist/types/assets/scripts/notification/FloatingNotification.d.ts +0 -1
  764. package/dist/types/assets/scripts/notification/FullWidthNotification.d.ts +0 -1
  765. package/dist/types/assets/scripts/notification/MessageNotification.d.ts +0 -1
  766. package/dist/types/assets/scripts/notification/Notification.d.ts +0 -1
  767. package/dist/types/assets/scripts/notification/const/classNames.d.ts +0 -1
  768. package/dist/types/assets/scripts/notification/const/icons.d.ts +0 -1
  769. package/dist/types/assets/scripts/notification/const/index.d.ts +0 -1
  770. package/dist/types/assets/scripts/notification/const/sizes.d.ts +0 -1
  771. package/dist/types/assets/scripts/notification/const/types.d.ts +0 -1
  772. package/dist/types/assets/scripts/notification/index.d.ts +0 -1
  773. package/dist/types/assets/scripts/notification/utils.d.ts +0 -1
  774. package/dist/types/assets/scripts/progress-bar/ProgressBar.d.ts +0 -1
  775. package/dist/types/assets/scripts/progress-bar/index.d.ts +0 -1
  776. package/dist/types/assets/scripts/selectBox.d.ts +6 -33
  777. package/dist/types/assets/scripts/shared/ButtonCloseX.d.ts +0 -1
  778. package/dist/types/assets/scripts/slider.d.ts +0 -1
  779. package/dist/types/assets/scripts/tab.d.ts +0 -1
  780. package/dist/types/assets/scripts/table/Table.d.ts +41 -0
  781. package/dist/types/assets/scripts/table/const/classNames.d.ts +27 -0
  782. package/dist/types/assets/scripts/table/const/index.d.ts +2 -0
  783. package/dist/types/assets/scripts/table/const/types.d.ts +23 -0
  784. package/dist/types/assets/scripts/table/index.d.ts +3 -0
  785. package/dist/types/assets/scripts/tag/Tag.d.ts +0 -1
  786. package/dist/types/assets/scripts/tag/const/classNames.d.ts +0 -1
  787. package/dist/types/assets/scripts/tag/const/index.d.ts +0 -1
  788. package/dist/types/assets/scripts/tag/const/sizes.d.ts +0 -1
  789. package/dist/types/assets/scripts/tag/const/types.d.ts +0 -1
  790. package/dist/types/assets/scripts/tag/index.d.ts +0 -1
  791. package/dist/types/assets/scripts/tooltip/Tooltip.d.ts +0 -1
  792. package/dist/types/assets/scripts/tooltip/TooltipLayerManager.d.ts +0 -1
  793. package/dist/types/assets/scripts/tooltip/const/classNames.d.ts +0 -1
  794. package/dist/types/assets/scripts/tooltip/const/constants.d.ts +1 -2
  795. package/dist/types/assets/scripts/tooltip/const/icons.d.ts +0 -1
  796. package/dist/types/assets/scripts/tooltip/const/index.d.ts +0 -1
  797. package/dist/types/assets/scripts/tooltip/const/templates.d.ts +0 -1
  798. package/dist/types/assets/scripts/tooltip/const/types.d.ts +0 -1
  799. package/dist/types/assets/scripts/tooltip/index.d.ts +0 -1
  800. package/dist/types/assets/scripts/tooltip/utils.d.ts +0 -1
  801. package/dist/types/assets/scripts/utils/debounce.d.ts +8 -0
  802. package/dist/types/assets/scripts/utils/unifiedBox/domRenderer.d.ts +107 -0
  803. package/dist/types/assets/scripts/utils/unifiedBox/dropdownModel.d.ts +142 -0
  804. package/dist/types/assets/scripts/utils/unifiedBox/unifiedBoxController.d.ts +156 -0
  805. package/dist/types/assets/scripts/utils/unifiedBox/unifiedBoxManager.d.ts +95 -0
  806. package/dist/types/constant/color.d.ts +0 -1
  807. package/dist/types/constant/size.d.ts +0 -1
  808. package/dist/types/index.d.ts +0 -28
  809. package/dist/types/src/components/badge/Badge.d.ts +10 -9
  810. package/dist/types/src/components/badge/index.d.ts +0 -2
  811. package/dist/types/src/components/badge/utils.d.ts +4 -3
  812. package/dist/types/src/components/badge-group/BadgeGroup.d.ts +18 -0
  813. package/dist/types/src/components/badge-group/index.d.ts +1 -0
  814. package/dist/types/src/components/bread-crumb/BreadCrumb.d.ts +11 -0
  815. package/dist/types/src/components/bread-crumb/index.d.ts +1 -0
  816. package/dist/types/src/components/button/Button.d.ts +2 -1
  817. package/dist/types/src/components/button/ButtonCloseX.d.ts +4 -3
  818. package/dist/types/src/components/button/ButtonStepper.d.ts +1 -2
  819. package/dist/types/src/components/button/index.d.ts +0 -2
  820. package/dist/types/src/components/button-group/ButtonGroup.d.ts +312 -0
  821. package/dist/types/src/components/button-group/index.d.ts +1 -0
  822. package/dist/types/src/components/carousel-arrow/CarouselArrow.d.ts +8 -0
  823. package/dist/types/src/components/carousel-arrow/index.d.ts +1 -0
  824. package/dist/types/src/components/carousel-number-group/CarouselNumberGroup.d.ts +8 -0
  825. package/dist/types/src/components/carousel-number-group/index.d.ts +1 -0
  826. package/dist/types/src/components/checkbox/Checkbox.d.ts +2 -3
  827. package/dist/types/src/components/checkbox/CheckboxInput.d.ts +2 -3
  828. package/dist/types/src/components/checkbox/index.d.ts +0 -1
  829. package/dist/types/src/components/combo-box/ComboBox.d.ts +28 -0
  830. package/dist/types/src/components/combo-box/index.d.ts +2 -0
  831. package/dist/types/src/components/data-grid/DataGrid.d.ts +28 -0
  832. package/dist/types/src/components/data-grid/DataGrid.types.d.ts +35 -0
  833. package/dist/types/src/components/data-grid/index.d.ts +2 -0
  834. package/dist/types/src/components/date-picker/CustomInput.d.ts +2 -3
  835. package/dist/types/src/components/date-picker/DatePicker.d.ts +11 -6
  836. package/dist/types/src/components/date-picker/index.d.ts +0 -3
  837. package/dist/types/src/components/date-picker/utils.d.ts +0 -1
  838. package/dist/types/src/components/divider/Divider.d.ts +1 -2
  839. package/dist/types/src/components/divider/index.d.ts +0 -1
  840. package/dist/types/src/components/dot/Dot.d.ts +9 -8
  841. package/dist/types/src/components/dot/index.d.ts +0 -1
  842. package/dist/types/src/components/dropdown/Dropdown.d.ts +0 -1
  843. package/dist/types/src/components/dropdown/index.d.ts +0 -1
  844. package/dist/types/src/components/empty-state/EmptyState.d.ts +5 -5
  845. package/dist/types/src/components/empty-state/index.d.ts +0 -1
  846. package/dist/types/src/components/featured-icon/FeaturedIcon.d.ts +8 -7
  847. package/dist/types/src/components/featured-icon/index.d.ts +0 -1
  848. package/dist/types/src/components/file-input/FileInput.d.ts +1 -2
  849. package/dist/types/src/components/file-input/index.d.ts +0 -1
  850. package/dist/types/src/components/horizontal-tab/HorizontalTab.d.ts +12 -0
  851. package/dist/types/src/components/horizontal-tab/index.d.ts +1 -0
  852. package/dist/types/src/components/image-file-input/ImageFileInput.d.ts +1 -2
  853. package/dist/types/src/components/image-file-input/components/ImagePreview.d.ts +0 -1
  854. package/dist/types/src/components/image-file-input/index.d.ts +0 -1
  855. package/dist/types/src/components/index.d.ts +18 -7
  856. package/dist/types/src/components/input-base/InputBase.d.ts +55 -0
  857. package/dist/types/src/components/input-base/index.d.ts +1 -0
  858. package/dist/types/src/components/modal/Modal.d.ts +13 -12
  859. package/dist/types/src/components/modal/index.d.ts +0 -1
  860. package/dist/types/src/components/notification/FloatingNotification.d.ts +6 -5
  861. package/dist/types/src/components/notification/FullWidthNotification.d.ts +6 -5
  862. package/dist/types/src/components/notification/MessageNotification.d.ts +6 -5
  863. package/dist/types/src/components/notification/Notification.d.ts +11 -10
  864. package/dist/types/src/components/notification/index.d.ts +1 -2
  865. package/dist/types/src/components/number-input/NumberInput.d.ts +9 -0
  866. package/dist/types/src/components/number-input/index.d.ts +1 -0
  867. package/dist/types/src/components/pagination/NavButton.d.ts +0 -1
  868. package/dist/types/src/components/pagination/Pagination.d.ts +0 -1
  869. package/dist/types/src/components/pagination/index.d.ts +0 -1
  870. package/dist/types/src/components/password-input/PasswordInput.d.ts +2 -0
  871. package/dist/types/src/components/password-input/index.d.ts +1 -0
  872. package/dist/types/src/components/progress-bar/ProgressBar.d.ts +0 -1
  873. package/dist/types/src/components/progress-bar/components/SegmentBar.d.ts +0 -1
  874. package/dist/types/src/components/progress-bar/components/SegmentLabels.d.ts +3 -4
  875. package/dist/types/src/components/progress-bar/hooks/useProgressBar.d.ts +1 -2
  876. package/dist/types/src/components/progress-bar/index.d.ts +0 -1
  877. package/dist/types/src/components/progress-bar/types.d.ts +0 -1
  878. package/dist/types/src/components/progress-bar/utils.d.ts +4 -4
  879. package/dist/types/src/components/progress-circle/ProgressCircle.d.ts +0 -1
  880. package/dist/types/src/components/progress-circle/index.d.ts +0 -1
  881. package/dist/types/src/components/radio/Radio.d.ts +2 -3
  882. package/dist/types/src/components/radio/RadioInput.d.ts +2 -3
  883. package/dist/types/src/components/radio/index.d.ts +0 -1
  884. package/dist/types/src/components/range-date-picker/RangeDatePicker.d.ts +26 -0
  885. package/dist/types/src/components/range-date-picker/index.d.ts +1 -0
  886. package/dist/types/src/components/range-date-picker-with-buttons/RangeDatePickerWithButtons.d.ts +71 -0
  887. package/dist/types/src/components/range-date-picker-with-buttons/index.d.ts +1 -0
  888. package/dist/types/src/components/select/Select.d.ts +4 -5
  889. package/dist/types/src/components/select/index.d.ts +0 -1
  890. package/dist/types/src/components/select-box/SelectBox.d.ts +27 -0
  891. package/dist/types/src/components/select-box/index.d.ts +1 -0
  892. package/dist/types/src/components/select-dropdown/SelectDropdown.d.ts +6 -6
  893. package/dist/types/src/components/select-dropdown/index.d.ts +1 -2
  894. package/dist/types/src/components/shared/hintText/HintText.d.ts +0 -1
  895. package/dist/types/src/components/shared/hintText/index.d.ts +0 -1
  896. package/dist/types/src/components/shared/index.d.ts +0 -1
  897. package/dist/types/src/components/shared/label/Label.d.ts +0 -1
  898. package/dist/types/src/components/shared/label/index.d.ts +0 -1
  899. package/dist/types/src/components/slider/Slider.d.ts +1 -2
  900. package/dist/types/src/components/slider/index.d.ts +0 -1
  901. package/dist/types/src/components/spinner/Spinner.d.ts +1 -2
  902. package/dist/types/src/components/spinner/index.d.ts +0 -2
  903. package/dist/types/src/components/switch/Switch.d.ts +7 -7
  904. package/dist/types/src/components/switch/index.d.ts +1 -2
  905. package/dist/types/src/components/tab/TabButton.d.ts +8 -8
  906. package/dist/types/src/components/tab/index.d.ts +0 -3
  907. package/dist/types/src/components/table/Table.d.ts +46 -0
  908. package/dist/types/src/components/table/index.d.ts +1 -0
  909. package/dist/types/src/components/table/types.d.ts +45 -0
  910. package/dist/types/src/components/tag/Tag.d.ts +4 -4
  911. package/dist/types/src/components/tag/index.d.ts +0 -1
  912. package/dist/types/src/components/textarea/Textarea.d.ts +14 -0
  913. package/dist/types/src/components/textarea/index.d.ts +1 -0
  914. package/dist/types/src/components/toggle/Toggle.d.ts +1 -2
  915. package/dist/types/src/components/toggle/index.d.ts +0 -1
  916. package/dist/types/src/components/tooltip/Tooltip.d.ts +0 -1
  917. package/dist/types/src/components/tooltip/index.d.ts +0 -1
  918. package/dist/types/src/components/vertical-tab/VerticalTab.d.ts +9 -0
  919. package/dist/types/src/components/vertical-tab/index.d.ts +1 -0
  920. package/dist/types/src/constant/breakpoint.d.ts +0 -1
  921. package/dist/types/src/constant/date-picker.d.ts +0 -1
  922. package/dist/types/src/constant/index.d.ts +1 -2
  923. package/dist/types/src/constant/size.d.ts +0 -1
  924. package/dist/types/src/hooks/dropdown/index.d.ts +0 -1
  925. package/dist/types/src/hooks/dropdown/useDropdown.d.ts +1 -2
  926. package/dist/types/src/hooks/dropdown/useDropdownKeyboard.d.ts +2 -3
  927. package/dist/types/src/hooks/dropdown/useDropdownPosition.d.ts +1 -2
  928. package/dist/types/src/hooks/dropdown/useOutsideClick.d.ts +1 -2
  929. package/dist/types/src/hooks/dropdown/useScrollLock.d.ts +0 -1
  930. package/dist/types/src/hooks/dropdown/useWindowResize.d.ts +0 -1
  931. package/dist/types/src/hooks/index.d.ts +1 -2
  932. package/dist/types/src/hooks/useCallbackRef.d.ts +0 -1
  933. package/dist/types/src/hooks/useMediaQuery.d.ts +0 -1
  934. package/dist/types/src/hooks/useMergeRefs.d.ts +1 -2
  935. package/dist/types/src/types/dropdown/dropdown.d.ts +1 -2
  936. package/dist/types/src/types/dropdown/index.d.ts +0 -1
  937. package/dist/types/src/types/dropdown/option.d.ts +0 -1
  938. package/dist/types/src/types/index.d.ts +0 -1
  939. package/dist/types/src/types/side-slot.d.ts +0 -1
  940. package/dist/types/src/utils/date-picker.d.ts +1 -2
  941. package/dist/types/src/utils/dropdown/dropdownUtils.d.ts +2 -3
  942. package/dist/types/src/utils/dropdown/index.d.ts +0 -1
  943. package/dist/types/src/utils/dropdown/multiSelect.d.ts +1 -2
  944. package/dist/types/src/utils/index.d.ts +0 -1
  945. package/dist/ui-admin/assets/styles/style.css +776 -228
  946. package/package.json +50 -53
  947. package/dist/cjs/assets/scripts/fileInput/FileInput.js +0 -183
  948. package/dist/cjs/assets/scripts/fileInput/FileInputModel.js +0 -246
  949. package/dist/cjs/assets/scripts/fileInput/FileInputView.js +0 -455
  950. package/dist/cjs/assets/scripts/utils/unifiedBox/DropdownModel.js +0 -368
  951. package/dist/cjs/assets/scripts/utils/unifiedBox/UnifiedBoxManager.js +0 -711
  952. package/dist/cjs/src/components/badge/BadgeGroup.js +0 -62
  953. package/dist/cjs/src/components/breadcrumb/BreadCrumb.js +0 -66
  954. package/dist/cjs/src/components/button/ButtonGroup.js +0 -117
  955. package/dist/cjs/src/components/carousel/CarouselArrow.js +0 -41
  956. package/dist/cjs/src/components/carousel/CarouselNumberGroup.js +0 -46
  957. package/dist/cjs/src/components/combobox/ComboBox.js +0 -338
  958. package/dist/cjs/src/components/date-picker/RangeDatePicker.js +0 -145
  959. package/dist/cjs/src/components/date-picker/RangeDatePickerWithButtons.js +0 -99
  960. package/dist/cjs/src/components/input/InputBase.js +0 -229
  961. package/dist/cjs/src/components/input/NumberInput.js +0 -132
  962. package/dist/cjs/src/components/input/PasswordInput.js +0 -72
  963. package/dist/cjs/src/components/input/Textarea.js +0 -107
  964. package/dist/cjs/src/components/input/index.js +0 -49
  965. package/dist/cjs/src/components/selectbox/SelectBox.js +0 -306
  966. package/dist/cjs/src/components/tab/HorizontalTab.js +0 -66
  967. package/dist/cjs/src/components/tab/VerticalTab.js +0 -60
  968. package/dist/esm/assets/scripts/fileInput/FileInput.js +0 -178
  969. package/dist/esm/assets/scripts/fileInput/FileInputModel.js +0 -241
  970. package/dist/esm/assets/scripts/fileInput/FileInputView.js +0 -450
  971. package/dist/esm/assets/scripts/utils/unifiedBox/DropdownModel.js +0 -363
  972. package/dist/esm/assets/scripts/utils/unifiedBox/UnifiedBoxManager.js +0 -706
  973. package/dist/esm/src/components/badge/BadgeGroup.js +0 -54
  974. package/dist/esm/src/components/breadcrumb/BreadCrumb.js +0 -58
  975. package/dist/esm/src/components/button/ButtonGroup.js +0 -107
  976. package/dist/esm/src/components/carousel/CarouselArrow.js +0 -33
  977. package/dist/esm/src/components/carousel/CarouselNumberGroup.js +0 -38
  978. package/dist/esm/src/components/carousel/index.js +0 -2
  979. package/dist/esm/src/components/combobox/ComboBox.js +0 -331
  980. package/dist/esm/src/components/date-picker/RangeDatePicker.js +0 -138
  981. package/dist/esm/src/components/date-picker/RangeDatePickerWithButtons.js +0 -92
  982. package/dist/esm/src/components/input/InputBase.js +0 -222
  983. package/dist/esm/src/components/input/NumberInput.js +0 -126
  984. package/dist/esm/src/components/input/PasswordInput.js +0 -65
  985. package/dist/esm/src/components/input/Textarea.js +0 -100
  986. package/dist/esm/src/components/input/index.js +0 -4
  987. package/dist/esm/src/components/selectbox/SelectBox.js +0 -299
  988. package/dist/esm/src/components/tab/HorizontalTab.js +0 -58
  989. package/dist/esm/src/components/tab/VerticalTab.js +0 -52
  990. package/dist/types/src/components/badge/BadgeGroup.d.ts +0 -17
  991. package/dist/types/src/components/breadcrumb/BreadCrumb.d.ts +0 -10
  992. package/dist/types/src/components/breadcrumb/index.d.ts +0 -2
  993. package/dist/types/src/components/carousel/CarouselArrow.d.ts +0 -10
  994. package/dist/types/src/components/carousel/CarouselNumberGroup.d.ts +0 -10
  995. package/dist/types/src/components/carousel/index.d.ts +0 -3
  996. package/dist/types/src/components/input/index.d.ts +0 -5
  997. package/dist/types/src/components/tab/HorizontalTab.d.ts +0 -11
  998. /package/dist/cjs/src/components/{breadcrumb → bread-crumb}/index.js +0 -0
  999. /package/dist/cjs/src/components/{combobox → combo-box}/index.js +0 -0
  1000. /package/dist/cjs/src/components/{selectbox → select-box}/index.js +0 -0
  1001. /package/dist/esm/src/components/{breadcrumb → bread-crumb}/index.js +0 -0
  1002. /package/dist/esm/src/components/{combobox → combo-box}/index.js +0 -0
  1003. /package/dist/esm/src/components/{selectbox → select-box}/index.js +0 -0
@@ -0,0 +1,604 @@
1
+ /**
2
+ * SelectBox 통합 컨트롤러
3
+ * 이벤트 처리, UI 상태 제어, 사용자 인터랙션 담당
4
+ */
5
+ export class UnifiedBoxController {
6
+ constructor(config) {
7
+ this.isOpen = false;
8
+ this.focusedIndex = -1;
9
+ this.isKeyboardNavigation = false;
10
+ this.scrollLockHandlers = null;
11
+ // DOM 요소들
12
+ this.optionElements = [];
13
+ this.handlerMap = new WeakMap();
14
+ this.scrollPosition = 0;
15
+ this.mouseMoveHandlerAttached = false;
16
+ this.lastFilteredOptionsCount = 0; // 이전 필터링된 옵션 개수 (성능 최적화)
17
+ this.lastFilteredOptionsHash = ''; // 이전 필터링된 옵션 해시 (성능 최적화)
18
+ this.lastScrollBottomTime = 0;
19
+ this.config = config;
20
+ this.setupEventHandlers();
21
+ this.config.model.addListener(this);
22
+ }
23
+ /**
24
+ * 상태 변경 리스너 (Observer Pattern)
25
+ */
26
+ onStateChange(newState, changedFields) {
27
+ // 드롭다운 열기/닫기 상태 동기화
28
+ if (changedFields.includes('isOpen')) {
29
+ this.isOpen = newState.isOpen;
30
+ this.updateDropdownVisibility(newState.isOpen);
31
+ }
32
+ // 포커스 상태 동기화
33
+ if (changedFields.includes('focusedIndex')) {
34
+ this.focusedIndex = newState.focusedIndex;
35
+ this.updateFocusedOption(newState.focusedIndex);
36
+ }
37
+ // 옵션 리스트 업데이트
38
+ if (this.shouldUpdateOptions(changedFields)) {
39
+ this.updateOptionsDisplay(newState);
40
+ }
41
+ // 선택 상태 변경 알림
42
+ if (changedFields.includes('selectedValues')) {
43
+ this.config.onSelectionChange?.(newState.selectedValues);
44
+ }
45
+ // 검색어 변경 알림은 UnifiedSelectBox에서 디바운싱 적용 후 처리하므로 여기서는 호출하지 않음
46
+ // (디바운싱이 적용되지 않은 즉시 호출을 방지하기 위해)
47
+ }
48
+ /**
49
+ * 이벤트 핸들러 설정
50
+ */
51
+ setupEventHandlers() {
52
+ // 외부 클릭 핸들러
53
+ this.outsideClickHandler = (e) => {
54
+ const target = e.target;
55
+ const isInsideTrigger = this.config.triggerElement.contains(target);
56
+ const isInsideDropdown = this.config.dropdownElement.contains(target);
57
+ if (isInsideTrigger || isInsideDropdown) {
58
+ return;
59
+ }
60
+ this.close();
61
+ };
62
+ // 키보드 핸들러
63
+ this.keyDownHandler = (e) => {
64
+ this.handleKeyDown(e);
65
+ };
66
+ if (this.config.type !== 'combobox') {
67
+ this.config.triggerElement.addEventListener('click', () => {
68
+ if (!this.config.disabled && this.config.canToggle?.() !== false) {
69
+ this.toggle();
70
+ }
71
+ });
72
+ }
73
+ // 키보드 이벤트
74
+ this.config.triggerElement.addEventListener('keydown', this.keyDownHandler);
75
+ }
76
+ /**
77
+ * 드롭다운 열기
78
+ */
79
+ open() {
80
+ if (this.config.disabled || this.isOpen)
81
+ return;
82
+ this.config.model.setOpen(true);
83
+ this.adjustDropdownPosition();
84
+ this.enableOutsideClick();
85
+ this.enableScrollLock();
86
+ this.enableScrollBottomDetection(); // 스크롤 감지 활성화
87
+ this.config.onOpen?.();
88
+ }
89
+ /**
90
+ * 드롭다운 닫기
91
+ */
92
+ close() {
93
+ if (!this.isOpen)
94
+ return;
95
+ this.config.model.setOpen(false);
96
+ this.disableOutsideClick();
97
+ this.disableScrollLock();
98
+ this.disableScrollBottomDetection(); // 스크롤 감지 비활성화
99
+ this.isKeyboardNavigation = false;
100
+ this.config.onClose?.();
101
+ }
102
+ /**
103
+ * 드롭다운 토글
104
+ */
105
+ toggle() {
106
+ if (this.isOpen) {
107
+ this.close();
108
+ }
109
+ else {
110
+ this.open();
111
+ }
112
+ }
113
+ /**
114
+ * 키보드 입력 처리
115
+ */
116
+ handleKeyDown(event) {
117
+ const state = this.config.model.getState();
118
+ switch (event.key) {
119
+ case 'ArrowDown':
120
+ event.preventDefault();
121
+ this.isKeyboardNavigation = true;
122
+ if (!state.isOpen) {
123
+ this.open();
124
+ }
125
+ else {
126
+ this.config.model.setFocusedIndex(state.focusedIndex + 1);
127
+ }
128
+ break;
129
+ case 'ArrowUp':
130
+ event.preventDefault();
131
+ this.isKeyboardNavigation = true;
132
+ if (state.isOpen) {
133
+ this.config.model.setFocusedIndex(state.focusedIndex - 1);
134
+ }
135
+ break;
136
+ case 'Enter':
137
+ event.preventDefault();
138
+ if (state.isOpen && state.focusedIndex >= 0 && state.focusedIndex < state.filteredOptions.length) {
139
+ const focusedOption = state.filteredOptions[state.focusedIndex];
140
+ this.config.model.toggleOption(focusedOption.id);
141
+ }
142
+ break;
143
+ case 'Escape':
144
+ event.preventDefault();
145
+ if (state.isOpen) {
146
+ this.close();
147
+ }
148
+ break;
149
+ default:
150
+ // 문자 입력으로 옵션 검색
151
+ if (event.key.length === 1 && !event.ctrlKey && !event.metaKey) {
152
+ this.searchOption(event.key);
153
+ }
154
+ break;
155
+ }
156
+ }
157
+ /**
158
+ * 옵션 검색
159
+ */
160
+ searchOption(char) {
161
+ const state = this.config.model.getState();
162
+ const options = state.filteredOptions;
163
+ const startIndex = this.focusedIndex >= 0 ? this.focusedIndex + 1 : 0;
164
+ for (let i = 0; i < options.length; i++) {
165
+ const index = (startIndex + i) % options.length;
166
+ const option = options[index];
167
+ // option.label이 존재하고 문자열인지 확인
168
+ if (option && option.label && typeof option.label === 'string') {
169
+ if (option.label.toLowerCase().startsWith(char.toLowerCase())) {
170
+ this.config.model.setFocusedIndex(index);
171
+ break;
172
+ }
173
+ }
174
+ }
175
+ }
176
+ /**
177
+ * 드롭다운 표시/숨김 업데이트
178
+ */
179
+ updateDropdownVisibility(isOpen) {
180
+ this.config.dropdownElement.style.display = isOpen ? 'block' : 'none';
181
+ }
182
+ /**
183
+ * 옵션 표시 업데이트
184
+ */
185
+ updateOptionsDisplay(state) {
186
+ const hasFilteredOptions = state.filteredOptions.length > 0;
187
+ const countChanged = this.lastFilteredOptionsCount !== state.filteredOptions.length;
188
+ // 빈 옵션일 때 해시 초기화 및 전체 렌더링
189
+ if (!hasFilteredOptions) {
190
+ this.lastFilteredOptionsHash = '';
191
+ this.lastFilteredOptionsCount = 0;
192
+ }
193
+ else {
194
+ // 옵션 개수가 변경되었는지 먼저 확인 (빠른 체크)
195
+ let optionsChanged = countChanged;
196
+ // 개수가 변경되지 않았을 때만 해시 계산 (O(n) 연산 최소화)
197
+ if (!optionsChanged) {
198
+ const currentHash = state.filteredOptions.map((opt) => opt.id).join(',');
199
+ optionsChanged = this.lastFilteredOptionsHash !== currentHash;
200
+ if (optionsChanged) {
201
+ this.lastFilteredOptionsHash = currentHash;
202
+ }
203
+ }
204
+ else {
205
+ // 개수가 변경되었으면 해시도 재계산
206
+ this.lastFilteredOptionsHash = state.filteredOptions.map((opt) => opt.id).join(',');
207
+ }
208
+ // 옵션이 변경되지 않았고 선택 상태만 변경된 경우 DOM 조작만 수행
209
+ if (!optionsChanged) {
210
+ // 선택 상태만 업데이트 (전체 재렌더링 방지)
211
+ this.optionElements.forEach((element, index) => {
212
+ const optionId = state.filteredOptions[index]?.id;
213
+ if (!optionId)
214
+ return;
215
+ const isSelected = state.selectedValues.includes(optionId);
216
+ const isFocused = index === state.focusedIndex;
217
+ // 선택 상태 업데이트
218
+ if (isSelected) {
219
+ element.classList.add('ncua-select-dropdown__option--selected');
220
+ element.setAttribute('aria-selected', 'true');
221
+ }
222
+ else {
223
+ element.classList.remove('ncua-select-dropdown__option--selected');
224
+ element.setAttribute('aria-selected', 'false');
225
+ }
226
+ // 포커스 상태 업데이트
227
+ if (isFocused) {
228
+ element.classList.add('ncua-select-dropdown__option--focused');
229
+ }
230
+ else {
231
+ element.classList.remove('ncua-select-dropdown__option--focused');
232
+ }
233
+ });
234
+ return; // 전체 재렌더링 불필요
235
+ }
236
+ }
237
+ // 옵션이 변경되었거나 빈 경우에만 전체 렌더링
238
+ const renderableOptions = state.filteredOptions.map((option, index) => ({
239
+ ...option,
240
+ selected: state.selectedValues.includes(option.id),
241
+ focused: index === state.focusedIndex,
242
+ }));
243
+ const showNoResults = state.filteredOptions.length === 0 && (state.showAllItems || state.searchValue.length > 0);
244
+ const optionsList = this.config.dropdownElement.querySelector('.ncua-select-dropdown__options');
245
+ if (optionsList) {
246
+ this.optionElements = this.config.renderer.updateOptionsList(optionsList, renderableOptions, this.config.renderConfig, showNoResults);
247
+ // 옵션 클릭 이벤트 등록
248
+ this.attachOptionEventHandlers();
249
+ // 캐시 업데이트 (이미 위에서 업데이트했으면 다시 업데이트하지 않음)
250
+ if (!this.lastFilteredOptionsHash) {
251
+ this.lastFilteredOptionsHash = state.filteredOptions.map((opt) => opt.id).join(',');
252
+ }
253
+ this.lastFilteredOptionsCount = state.filteredOptions.length;
254
+ }
255
+ }
256
+ /**
257
+ * 포커스된 옵션 업데이트
258
+ */
259
+ updateFocusedOption(focusedIndex) {
260
+ this.optionElements.forEach((element, index) => {
261
+ if (index === focusedIndex) {
262
+ element.classList.add('ncua-select-dropdown__option--focused');
263
+ element.scrollIntoView({ block: 'nearest' });
264
+ }
265
+ else {
266
+ element.classList.remove('ncua-select-dropdown__option--focused');
267
+ }
268
+ });
269
+ }
270
+ /**
271
+ * 옵션 클릭 이벤트 핸들러 등록
272
+ */
273
+ attachOptionEventHandlers() {
274
+ // 기존 이벤트 리스너 제거
275
+ this.removeOptionEventHandlers();
276
+ this.optionElements.forEach((element, index) => {
277
+ const optionId = element.getAttribute('data-value');
278
+ // data-value가 없거나 빈 문자열인 경우에도 처리
279
+ if (optionId === null)
280
+ return;
281
+ // 클릭 이벤트 핸들러 생성 및 저장
282
+ const clickHandler = (event) => {
283
+ event.preventDefault();
284
+ event.stopPropagation();
285
+ this.config.model.toggleOption(optionId);
286
+ // 단일 선택 모드에서는 선택 후 드롭다운 닫기
287
+ if (!this.config.model.isMultiple()) {
288
+ setTimeout(() => this.close(), 100);
289
+ }
290
+ };
291
+ const hoverHandler = () => {
292
+ if (!this.isKeyboardNavigation) {
293
+ this.config.model.setFocusedIndex(index);
294
+ }
295
+ };
296
+ // 이벤트 리스너 등록
297
+ element.addEventListener('click', clickHandler);
298
+ element.addEventListener('mouseenter', hoverHandler);
299
+ // 나중에 제거할 수 있도록 핸들러 저장
300
+ this.handlerMap.set(element, { click: clickHandler, hover: hoverHandler });
301
+ });
302
+ // 마우스 이동 감지 (한 번만 등록)
303
+ if (!this.mouseMoveHandlerAttached) {
304
+ this.config.dropdownElement.addEventListener('mousemove', () => {
305
+ this.isKeyboardNavigation = false;
306
+ });
307
+ this.mouseMoveHandlerAttached = true;
308
+ }
309
+ }
310
+ /**
311
+ * 옵션 이벤트 핸들러 제거
312
+ */
313
+ removeOptionEventHandlers() {
314
+ this.optionElements.forEach((element) => {
315
+ const handlers = this.handlerMap.get(element);
316
+ if (handlers) {
317
+ element.removeEventListener('click', handlers.click);
318
+ element.removeEventListener('mouseenter', handlers.hover);
319
+ this.handlerMap.delete(element);
320
+ }
321
+ });
322
+ }
323
+ /**
324
+ * 옵션 업데이트가 필요한지 판단
325
+ */
326
+ shouldUpdateOptions(changedFields) {
327
+ return changedFields.some((field) => ['options', 'filteredOptions', 'selectedValues', 'showAllItems'].includes(field));
328
+ }
329
+ /**
330
+ * 외부 클릭 감지 활성화
331
+ */
332
+ enableOutsideClick() {
333
+ document.addEventListener('mousedown', this.outsideClickHandler);
334
+ }
335
+ /**
336
+ * 외부 클릭 감지 비활성화
337
+ */
338
+ disableOutsideClick() {
339
+ document.removeEventListener('mousedown', this.outsideClickHandler);
340
+ }
341
+ /**
342
+ * 스크롤 잠금 활성화 (드롭다운 내부 스크롤은 허용)
343
+ * ComboBox 또는 multiple 모드에서는 스크롤 잠금 비활성화
344
+ */
345
+ enableScrollLock() {
346
+ // ComboBox 또는 multiple 모드에서는 스크롤 잠금 비활성화
347
+ if (this.config.type === 'combobox' || this.config.model.isMultiple()) {
348
+ return;
349
+ }
350
+ this.scrollPosition = window.pageYOffset;
351
+ this.scrollLockHandlers = {
352
+ wheel: (e) => {
353
+ // 드롭다운 내부에서 발생한 이벤트 처리
354
+ if (this.config.dropdownElement && this.config.dropdownElement.contains(e.target)) {
355
+ // 드롭다운 내부의 스크롤 가능한 요소 찾기
356
+ const scrollableElement = this.findScrollableParent(e.target, this.config.dropdownElement);
357
+ if (scrollableElement) {
358
+ const { deltaY } = e;
359
+ const { scrollTop, scrollHeight, clientHeight } = scrollableElement;
360
+ // 스크롤이 위쪽 끝에 도달했고 위로 스크롤하려는 경우
361
+ if (scrollTop === 0 && deltaY < 0) {
362
+ e.preventDefault();
363
+ return;
364
+ }
365
+ // 스크롤이 아래쪽 끝에 도달했고 아래로 스크롤하려는 경우
366
+ if (scrollTop + clientHeight >= scrollHeight && deltaY > 0) {
367
+ e.preventDefault();
368
+ return;
369
+ }
370
+ // 드롭다운 내부 스크롤 허용
371
+ return;
372
+ }
373
+ }
374
+ // 드롭다운 외부의 모든 스크롤 방지
375
+ e.preventDefault();
376
+ },
377
+ touchmove: (e) => {
378
+ // 드롭다운 내부에서의 터치 스크롤 처리
379
+ if (this.config.dropdownElement && this.config.dropdownElement.contains(e.target)) {
380
+ const scrollableElement = this.findScrollableParent(e.target, this.config.dropdownElement);
381
+ if (scrollableElement) {
382
+ // 터치 스크롤은 브라우저가 자동으로 처리하도록 허용
383
+ return;
384
+ }
385
+ }
386
+ // 드롭다운 외부의 터치 스크롤 방지
387
+ e.preventDefault();
388
+ },
389
+ keydown: (e) => {
390
+ // 페이지 스크롤 키만 막기 (화살표 키는 드롭다운 네비게이션에서 처리)
391
+ const keys = ['PageUp', 'PageDown', 'Home', 'End', 'Space'];
392
+ if (keys.includes(e.key) || e.key === ' ') {
393
+ e.preventDefault();
394
+ }
395
+ },
396
+ };
397
+ document.addEventListener('wheel', this.scrollLockHandlers.wheel, { passive: false });
398
+ document.addEventListener('touchmove', this.scrollLockHandlers.touchmove, { passive: false });
399
+ document.addEventListener('keydown', this.scrollLockHandlers.keydown);
400
+ }
401
+ /**
402
+ * 스크롤 가능한 부모 요소 찾기
403
+ */
404
+ findScrollableParent(element, boundary) {
405
+ let current = element;
406
+ while (current && current !== boundary && boundary.contains(current)) {
407
+ const computedStyle = window.getComputedStyle(current);
408
+ const overflowY = computedStyle.overflowY;
409
+ if (overflowY === 'auto' || overflowY === 'scroll') {
410
+ const { scrollHeight, clientHeight } = current;
411
+ if (scrollHeight > clientHeight) {
412
+ return current;
413
+ }
414
+ }
415
+ current = current.parentElement;
416
+ }
417
+ return null;
418
+ }
419
+ /**
420
+ * 스크롤 잠금 해제
421
+ */
422
+ disableScrollLock() {
423
+ if (this.scrollLockHandlers) {
424
+ document.removeEventListener('wheel', this.scrollLockHandlers.wheel);
425
+ document.removeEventListener('touchmove', this.scrollLockHandlers.touchmove);
426
+ document.removeEventListener('keydown', this.scrollLockHandlers.keydown);
427
+ this.scrollLockHandlers = null;
428
+ }
429
+ }
430
+ /**
431
+ * 마우스 호버 처리 (외부에서 호출용)
432
+ */
433
+ handleMouseHover(index) {
434
+ if (!this.isKeyboardNavigation) {
435
+ this.config.model.setFocusedIndex(index);
436
+ }
437
+ }
438
+ /**
439
+ * 옵션 배열 업데이트
440
+ */
441
+ updateOptions(options) {
442
+ this.config.model.updateOptions(options);
443
+ // 스크롤 리스너는 이미 등록되어 있으므로 제거/재등록 불필요
444
+ // DOM이 완전히 교체되는 경우에만 재등록 필요 (현재는 updateContainerChildren에서 요소 재사용)
445
+ // 옵션 업데이트 후 스크롤 감지가 필요한 경우에만 확인
446
+ if (this.isOpen && this.config.onScrollBottom && !this.scrollBottomHandler) {
447
+ // 스크롤 리스너가 없을 때만 등록 (드롭다운이 열려있고 리스너가 없는 경우)
448
+ requestAnimationFrame(() => {
449
+ this.enableScrollBottomDetection();
450
+ });
451
+ }
452
+ }
453
+ getIsOpen() {
454
+ return this.config.model.getState().isOpen;
455
+ }
456
+ setFocus(index) {
457
+ this.config.model.setFocusedIndex(index);
458
+ }
459
+ getFocusedIndex() {
460
+ return this.config.model.getState().focusedIndex;
461
+ }
462
+ /**
463
+ * 드롭다운 위치 조정 (화면 크기에 따라 up/down 방향 결정)
464
+ * 단일 선택 모드에서만 적용
465
+ */
466
+ adjustDropdownPosition() {
467
+ if (!this.config.dropdownElement || !this.config.triggerElement)
468
+ return;
469
+ // ComboBox 또는 multiple 모드에서는 위치 조정 비활성화
470
+ if (this.config.type === 'combobox' || this.config.model.isMultiple()) {
471
+ return;
472
+ }
473
+ // 일시적으로 드롭다운을 보이게 해서 크기 측정
474
+ const dropdown = this.config.dropdownElement;
475
+ const originalDisplay = dropdown.style.display;
476
+ const originalVisibility = dropdown.style.visibility;
477
+ dropdown.style.display = 'block';
478
+ dropdown.style.visibility = 'hidden';
479
+ const result = this.calculateDropdownPosition();
480
+ // 방향에 따른 클래스 설정
481
+ dropdown.classList.remove('ncua-select-dropdown--up', 'ncua-select-dropdown--down');
482
+ dropdown.classList.add(`ncua-select-dropdown--${result.direction}`);
483
+ // 미세 위치 조정
484
+ this.adjustDropdownPositionDetails(dropdown);
485
+ // 원래 상태로 복원
486
+ dropdown.style.display = originalDisplay;
487
+ dropdown.style.visibility = originalVisibility;
488
+ }
489
+ /**
490
+ * 드롭다운 위치 계산 (React dropdownUtils.ts 로직 참고)
491
+ */
492
+ calculateDropdownPosition() {
493
+ if (!this.config.triggerElement || !this.config.dropdownElement) {
494
+ return { direction: 'down', maxHeight: this.config.renderConfig.maxHeight };
495
+ }
496
+ const triggerRect = this.config.triggerElement.getBoundingClientRect();
497
+ const viewportHeight = window.innerHeight;
498
+ const dropdownHeight = Math.min(this.config.renderConfig.maxHeight, this.estimateDropdownHeight());
499
+ const offset = 20; // 여유 공간
500
+ // 아래쪽 공간이 충분한지 확인
501
+ const spaceBelow = viewportHeight - triggerRect.bottom;
502
+ if (spaceBelow < dropdownHeight + offset) {
503
+ return { direction: 'up', maxHeight: this.config.renderConfig.maxHeight };
504
+ }
505
+ else {
506
+ return { direction: 'down', maxHeight: this.config.renderConfig.maxHeight };
507
+ }
508
+ }
509
+ /**
510
+ * 드롭다운 예상 높이 계산
511
+ */
512
+ estimateDropdownHeight() {
513
+ const itemHeight = 40; // 대략적인 옵션 항목 높이
514
+ const itemCount = this.config.model.getState().filteredOptions.length || this.config.model.getState().options.length;
515
+ return Math.min(itemCount * itemHeight, this.config.renderConfig.maxHeight);
516
+ }
517
+ /**
518
+ * 드롭다운 세부 위치 조정 (뷰포트 경계 처리)
519
+ */
520
+ adjustDropdownPositionDetails(dropdownElement) {
521
+ const dropdownRect = dropdownElement.getBoundingClientRect();
522
+ const viewportWidth = window.innerWidth;
523
+ const viewportHeight = window.innerHeight;
524
+ // 좌우 위치 조정
525
+ if (dropdownRect.right > viewportWidth) {
526
+ const overflow = dropdownRect.right - viewportWidth;
527
+ const currentLeft = parseInt(dropdownElement.style.left || '0');
528
+ dropdownElement.style.left = `${currentLeft - overflow - 10}px`;
529
+ }
530
+ if (dropdownRect.left < 0) {
531
+ dropdownElement.style.left = '10px';
532
+ }
533
+ // 상하 위치 조정 (이미 up/down 방향이 결정된 후 미세 조정)
534
+ if (dropdownRect.bottom > viewportHeight) {
535
+ const overflow = dropdownRect.bottom - viewportHeight;
536
+ const currentMaxHeight = parseInt(dropdownElement.style.maxHeight || String(this.config.renderConfig.maxHeight));
537
+ dropdownElement.style.maxHeight = `${currentMaxHeight - overflow - 10}px`;
538
+ }
539
+ }
540
+ /**
541
+ * 스크롤 바닥 감지 활성화
542
+ */
543
+ enableScrollBottomDetection() {
544
+ if (!this.config.onScrollBottom)
545
+ return;
546
+ // 이미 리스너가 등록되어 있으면 중복 등록 방지
547
+ if (this.scrollBottomHandler)
548
+ return;
549
+ const optionsList = this.config.dropdownElement.querySelector('.ncua-select-dropdown__options');
550
+ if (!optionsList)
551
+ return;
552
+ this.scrollBottomHandler = (e) => {
553
+ const target = e.target;
554
+ const scrollTop = target.scrollTop;
555
+ const scrollHeight = target.scrollHeight;
556
+ const clientHeight = target.clientHeight;
557
+ // 바닥에서 10px 이내에 도달했을 때
558
+ const threshold = 10;
559
+ const isAtBottom = scrollTop + clientHeight >= scrollHeight - threshold;
560
+ if (isAtBottom) {
561
+ const now = Date.now();
562
+ // 500ms 디바운스 (중복 호출 방지)
563
+ if (now - this.lastScrollBottomTime > 100) {
564
+ this.lastScrollBottomTime = now;
565
+ this.config.onScrollBottom?.();
566
+ }
567
+ }
568
+ };
569
+ optionsList.addEventListener('scroll', this.scrollBottomHandler);
570
+ }
571
+ /**
572
+ * 스크롤 바닥 감지 비활성화
573
+ */
574
+ disableScrollBottomDetection() {
575
+ if (this.scrollBottomHandler) {
576
+ const optionsList = this.config.dropdownElement.querySelector('.ncua-select-dropdown__options');
577
+ if (optionsList) {
578
+ optionsList.removeEventListener('scroll', this.scrollBottomHandler);
579
+ }
580
+ this.scrollBottomHandler = undefined;
581
+ }
582
+ }
583
+ /**
584
+ * disabled 상태 설정
585
+ */
586
+ setDisabled(disabled) {
587
+ this.config.disabled = disabled;
588
+ // disabled로 설정될 때 드롭다운이 열려있으면 닫기
589
+ if (disabled && this.isOpen) {
590
+ this.close();
591
+ }
592
+ }
593
+ /**
594
+ * 정리
595
+ */
596
+ destroy() {
597
+ this.config.model.removeListener(this);
598
+ this.disableOutsideClick();
599
+ this.disableScrollLock();
600
+ this.removeOptionEventHandlers();
601
+ this.disableScrollBottomDetection(); // 스크롤 감지 정리
602
+ this.config.triggerElement.removeEventListener('keydown', this.keyDownHandler);
603
+ }
604
+ }
@@ -1,5 +1,5 @@
1
1
  import { OptionValue } from '../../../../src/types';
2
- import { DropdownOption } from './DropdownModel';
2
+ import { DropdownOption } from './dropdownModel';
3
3
  export interface UnifiedBoxManagerConfig {
4
4
  options?: DropdownOption[];
5
5
  placeholder?: string;
@@ -32,10 +32,11 @@ export declare class UnifiedBoxManager {
32
32
  private renderer;
33
33
  private controller;
34
34
  private inputField?;
35
- private searchDebounceTimer?;
36
- private currentDebounceTimerId?;
35
+ private debouncedSearch;
37
36
  private lastSearchValue;
38
37
  private hasInitialOptions;
38
+ private isComboBox;
39
+ private baseClass;
39
40
  private dropdownElement?;
40
41
  private triggerElement?;
41
42
  private footerElement?;
@@ -48,10 +49,6 @@ export declare class UnifiedBoxManager {
48
49
  private createSelectBoxUI;
49
50
  private createDropdown;
50
51
  private setupController;
51
- /**
52
- * 디바운싱 타이머 취소
53
- */
54
- private cancelDebounceTimer;
55
52
  private handleInput;
56
53
  private handleInputClick;
57
54
  private handleClearInput;
@@ -96,4 +93,3 @@ export declare class UnifiedBoxManager {
96
93
  */
97
94
  setFocusIndex(index: number): void;
98
95
  }
99
- //# sourceMappingURL=UnifiedBoxManager.d.ts.map