@ncds/ui-admin 1.8.1 → 1.8.2

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 (438) hide show
  1. package/dist/cjs/src/components/badge/index.js +11 -0
  2. package/dist/cjs/src/components/date-picker/index.js +11 -0
  3. package/dist/cjs/src/components/image-file-input/components/index.js +16 -0
  4. package/dist/cjs/src/components/image-file-input/index.js +11 -0
  5. package/dist/cjs/src/components/progress-bar/components/index.js +27 -0
  6. package/dist/cjs/src/components/progress-bar/hooks/index.js +16 -0
  7. package/dist/cjs/src/components/progress-bar/index.js +33 -0
  8. package/dist/cjs/src/components/select/Select.js +0 -1
  9. package/dist/cjs/src/components/select-dropdown/index.js +11 -7
  10. package/dist/cjs/src/components/switch/index.js +11 -7
  11. package/dist/cjs/src/components/tooltip/Tooltip.js +170 -104
  12. package/dist/cjs/src/hooks/dropdown/index.js +61 -37
  13. package/dist/cjs/src/hooks/index.js +31 -25
  14. package/dist/cjs/vitest.config.js +13 -0
  15. package/dist/esm/src/components/badge/index.js +2 -1
  16. package/dist/esm/src/components/date-picker/index.js +1 -0
  17. package/dist/esm/src/components/empty-state/EmptyState.js +2 -3
  18. package/dist/esm/src/components/image-file-input/components/index.js +1 -0
  19. package/dist/esm/src/components/image-file-input/index.js +2 -1
  20. package/dist/esm/src/components/progress-bar/components/index.js +2 -0
  21. package/dist/esm/src/components/progress-bar/hooks/index.js +1 -0
  22. package/dist/esm/src/components/progress-bar/index.js +4 -1
  23. package/dist/esm/src/components/select/Select.js +0 -1
  24. package/dist/esm/src/components/select-dropdown/index.js +1 -1
  25. package/dist/esm/src/components/switch/index.js +1 -1
  26. package/dist/esm/src/components/tag/Tag.js +2 -3
  27. package/dist/esm/src/components/tooltip/Tooltip.js +172 -106
  28. package/dist/esm/src/hooks/dropdown/index.js +6 -6
  29. package/dist/esm/src/hooks/index.js +3 -3
  30. package/dist/esm/src/types/component-meta.js +2 -0
  31. package/dist/esm/vitest.config.js +7 -0
  32. package/dist/temp/src/components/badge/index.d.ts +1 -0
  33. package/dist/temp/src/components/badge/index.js +1 -0
  34. package/dist/temp/src/components/date-picker/index.d.ts +1 -0
  35. package/dist/temp/src/components/date-picker/index.js +1 -0
  36. package/dist/temp/src/components/empty-state/EmptyState.d.ts +3 -5
  37. package/dist/temp/src/components/empty-state/EmptyState.js +1 -2
  38. package/dist/temp/src/components/image-file-input/components/index.d.ts +1 -0
  39. package/dist/temp/src/components/image-file-input/components/index.js +1 -0
  40. package/dist/temp/src/components/image-file-input/index.d.ts +1 -0
  41. package/dist/temp/src/components/image-file-input/index.js +1 -0
  42. package/dist/temp/src/components/progress-bar/components/index.d.ts +2 -0
  43. package/dist/temp/src/components/progress-bar/components/index.js +2 -0
  44. package/dist/temp/src/components/progress-bar/hooks/index.d.ts +1 -0
  45. package/dist/temp/src/components/progress-bar/hooks/index.js +1 -0
  46. package/dist/temp/src/components/progress-bar/index.d.ts +3 -0
  47. package/dist/temp/src/components/progress-bar/index.js +3 -0
  48. package/dist/temp/src/components/select/Select.js +1 -1
  49. package/dist/temp/src/components/select-dropdown/index.d.ts +1 -1
  50. package/dist/temp/src/components/select-dropdown/index.js +1 -1
  51. package/dist/temp/src/components/spinner/Spinner.d.ts +1 -2
  52. package/dist/temp/src/components/switch/index.d.ts +1 -2
  53. package/dist/temp/src/components/switch/index.js +1 -1
  54. package/dist/temp/src/components/tag/Tag.d.ts +3 -5
  55. package/dist/temp/src/components/tag/Tag.js +1 -2
  56. package/dist/temp/src/components/tooltip/Tooltip.d.ts +4 -2
  57. package/dist/temp/src/components/tooltip/Tooltip.js +126 -68
  58. package/dist/temp/src/hooks/dropdown/index.d.ts +6 -6
  59. package/dist/temp/src/hooks/dropdown/index.js +6 -6
  60. package/dist/temp/src/hooks/index.d.ts +3 -3
  61. package/dist/temp/src/hooks/index.js +3 -3
  62. package/dist/temp/src/types/component-meta.d.ts +26 -0
  63. package/dist/temp/src/types/component-meta.js +2 -0
  64. package/dist/temp/src/types/dropdown/option.d.ts +2 -4
  65. package/dist/temp/src/types/side-slot.d.ts +9 -1
  66. package/dist/temp/vitest.config.d.ts +2 -0
  67. package/dist/temp/vitest.config.js +7 -0
  68. package/dist/types/src/components/badge/index.d.ts +1 -0
  69. package/dist/types/src/components/date-picker/index.d.ts +1 -0
  70. package/dist/types/src/components/empty-state/EmptyState.d.ts +3 -5
  71. package/dist/types/src/components/image-file-input/components/index.d.ts +1 -0
  72. package/dist/types/src/components/image-file-input/index.d.ts +1 -0
  73. package/dist/types/src/components/progress-bar/components/index.d.ts +2 -0
  74. package/dist/types/src/components/progress-bar/hooks/index.d.ts +1 -0
  75. package/dist/types/src/components/progress-bar/index.d.ts +3 -0
  76. package/dist/types/src/components/select-dropdown/index.d.ts +1 -1
  77. package/dist/types/src/components/spinner/Spinner.d.ts +1 -2
  78. package/dist/types/src/components/switch/index.d.ts +1 -2
  79. package/dist/types/src/components/tag/Tag.d.ts +3 -5
  80. package/dist/types/src/components/tooltip/Tooltip.d.ts +4 -2
  81. package/dist/types/src/hooks/dropdown/index.d.ts +6 -6
  82. package/dist/types/src/hooks/index.d.ts +3 -3
  83. package/dist/types/src/types/component-meta.d.ts +26 -0
  84. package/dist/types/src/types/dropdown/option.d.ts +2 -4
  85. package/dist/types/src/types/side-slot.d.ts +9 -1
  86. package/dist/types/vitest.config.d.ts +2 -0
  87. package/dist/ui-admin/assets/styles/style.css +18 -7
  88. package/package.json +6 -1
  89. package/dist/cjs/assets/scripts/baseBox.js +0 -146
  90. package/dist/cjs/assets/scripts/comboBox.js +0 -137
  91. package/dist/cjs/assets/scripts/datePicker.js +0 -671
  92. package/dist/cjs/assets/scripts/featuredIcon.js +0 -87
  93. package/dist/cjs/assets/scripts/fileInput/const/classNames.js +0 -25
  94. package/dist/cjs/assets/scripts/fileInput/const/index.js +0 -27
  95. package/dist/cjs/assets/scripts/fileInput/const/types.js +0 -13
  96. package/dist/cjs/assets/scripts/fileInput/fileInput.js +0 -78
  97. package/dist/cjs/assets/scripts/fileInput/fileInputModel.js +0 -53
  98. package/dist/cjs/assets/scripts/fileInput/fileInputView.js +0 -152
  99. package/dist/cjs/assets/scripts/fileInput/index.js +0 -44
  100. package/dist/cjs/assets/scripts/imageFileInput/ImageFileInput.js +0 -184
  101. package/dist/cjs/assets/scripts/imageFileInput/ImageFileInputModel.js +0 -222
  102. package/dist/cjs/assets/scripts/imageFileInput/ImageFileInputView.js +0 -356
  103. package/dist/cjs/assets/scripts/imageFileInput/const/classNames.js +0 -31
  104. package/dist/cjs/assets/scripts/imageFileInput/const/index.js +0 -27
  105. package/dist/cjs/assets/scripts/imageFileInput/const/types.js +0 -13
  106. package/dist/cjs/assets/scripts/imageFileInput/index.js +0 -44
  107. package/dist/cjs/assets/scripts/index.js +0 -32
  108. package/dist/cjs/assets/scripts/modal/Modal.js +0 -104
  109. package/dist/cjs/assets/scripts/modal/ModalActions.js +0 -116
  110. package/dist/cjs/assets/scripts/modal/ModalContent.js +0 -46
  111. package/dist/cjs/assets/scripts/modal/ModalHeader.js +0 -104
  112. package/dist/cjs/assets/scripts/modal/const/classNames.js +0 -33
  113. package/dist/cjs/assets/scripts/modal/const/index.js +0 -27
  114. package/dist/cjs/assets/scripts/modal/index.js +0 -61
  115. package/dist/cjs/assets/scripts/modal/utils/contentUtils.js +0 -35
  116. package/dist/cjs/assets/scripts/notification/FloatingNotification.js +0 -178
  117. package/dist/cjs/assets/scripts/notification/FullWidthNotification.js +0 -132
  118. package/dist/cjs/assets/scripts/notification/MessageNotification.js +0 -159
  119. package/dist/cjs/assets/scripts/notification/Notification.js +0 -101
  120. package/dist/cjs/assets/scripts/notification/const/classNames.js +0 -50
  121. package/dist/cjs/assets/scripts/notification/const/icons.js +0 -31
  122. package/dist/cjs/assets/scripts/notification/const/index.js +0 -87
  123. package/dist/cjs/assets/scripts/notification/const/sizes.js +0 -46
  124. package/dist/cjs/assets/scripts/notification/const/types.js +0 -14
  125. package/dist/cjs/assets/scripts/notification/index.js +0 -92
  126. package/dist/cjs/assets/scripts/notification/utils.js +0 -97
  127. package/dist/cjs/assets/scripts/progress-bar/ProgressBar.js +0 -271
  128. package/dist/cjs/assets/scripts/progress-bar/index.js +0 -12
  129. package/dist/cjs/assets/scripts/selectBox.js +0 -169
  130. package/dist/cjs/assets/scripts/shared/ButtonCloseX.js +0 -45
  131. package/dist/cjs/assets/scripts/tab.js +0 -40
  132. package/dist/cjs/assets/scripts/table/Table.js +0 -377
  133. package/dist/cjs/assets/scripts/table/const/classNames.js +0 -33
  134. package/dist/cjs/assets/scripts/table/const/index.js +0 -27
  135. package/dist/cjs/assets/scripts/table/const/types.js +0 -5
  136. package/dist/cjs/assets/scripts/table/index.js +0 -43
  137. package/dist/cjs/assets/scripts/tag/Tag.js +0 -261
  138. package/dist/cjs/assets/scripts/tag/const/classNames.js +0 -20
  139. package/dist/cjs/assets/scripts/tag/const/index.js +0 -38
  140. package/dist/cjs/assets/scripts/tag/const/sizes.js +0 -13
  141. package/dist/cjs/assets/scripts/tag/const/types.js +0 -5
  142. package/dist/cjs/assets/scripts/tag/index.js +0 -44
  143. package/dist/cjs/assets/scripts/tooltip/Tooltip.js +0 -353
  144. package/dist/cjs/assets/scripts/tooltip/TooltipLayerManager.js +0 -82
  145. package/dist/cjs/assets/scripts/tooltip/const/classNames.js +0 -29
  146. package/dist/cjs/assets/scripts/tooltip/const/constants.js +0 -56
  147. package/dist/cjs/assets/scripts/tooltip/const/icons.js +0 -15
  148. package/dist/cjs/assets/scripts/tooltip/const/index.js +0 -123
  149. package/dist/cjs/assets/scripts/tooltip/const/templates.js +0 -66
  150. package/dist/cjs/assets/scripts/tooltip/const/types.js +0 -5
  151. package/dist/cjs/assets/scripts/tooltip/index.js +0 -57
  152. package/dist/cjs/assets/scripts/tooltip/utils.js +0 -40
  153. package/dist/cjs/assets/scripts/utils/debounce.js +0 -32
  154. package/dist/cjs/assets/scripts/utils/unifiedBox/domRenderer.js +0 -370
  155. package/dist/cjs/assets/scripts/utils/unifiedBox/dropdownModel.js +0 -285
  156. package/dist/cjs/assets/scripts/utils/unifiedBox/unifiedBoxController.js +0 -622
  157. package/dist/cjs/assets/scripts/utils/unifiedBox/unifiedBoxManager.js +0 -473
  158. package/dist/esm/assets/scripts/baseBox.js +0 -139
  159. package/dist/esm/assets/scripts/comboBox.js +0 -130
  160. package/dist/esm/assets/scripts/datePicker.js +0 -663
  161. package/dist/esm/assets/scripts/featuredIcon.js +0 -80
  162. package/dist/esm/assets/scripts/fileInput/const/classNames.js +0 -16
  163. package/dist/esm/assets/scripts/fileInput/const/index.js +0 -2
  164. package/dist/esm/assets/scripts/fileInput/const/types.js +0 -7
  165. package/dist/esm/assets/scripts/fileInput/fileInput.js +0 -71
  166. package/dist/esm/assets/scripts/fileInput/fileInputModel.js +0 -46
  167. package/dist/esm/assets/scripts/fileInput/fileInputView.js +0 -145
  168. package/dist/esm/assets/scripts/fileInput/index.js +0 -9
  169. package/dist/esm/assets/scripts/imageFileInput/ImageFileInput.js +0 -177
  170. package/dist/esm/assets/scripts/imageFileInput/ImageFileInputModel.js +0 -215
  171. package/dist/esm/assets/scripts/imageFileInput/ImageFileInputView.js +0 -349
  172. package/dist/esm/assets/scripts/imageFileInput/const/classNames.js +0 -20
  173. package/dist/esm/assets/scripts/imageFileInput/const/index.js +0 -2
  174. package/dist/esm/assets/scripts/imageFileInput/const/types.js +0 -7
  175. package/dist/esm/assets/scripts/imageFileInput/index.js +0 -9
  176. package/dist/esm/assets/scripts/index.js +0 -30
  177. package/dist/esm/assets/scripts/modal/Modal.js +0 -98
  178. package/dist/esm/assets/scripts/modal/ModalActions.js +0 -109
  179. package/dist/esm/assets/scripts/modal/ModalContent.js +0 -39
  180. package/dist/esm/assets/scripts/modal/ModalHeader.js +0 -97
  181. package/dist/esm/assets/scripts/modal/const/classNames.js +0 -23
  182. package/dist/esm/assets/scripts/modal/const/index.js +0 -2
  183. package/dist/esm/assets/scripts/modal/const/types.js +0 -1
  184. package/dist/esm/assets/scripts/modal/index.js +0 -15
  185. package/dist/esm/assets/scripts/modal/utils/contentUtils.js +0 -28
  186. package/dist/esm/assets/scripts/notification/FloatingNotification.js +0 -172
  187. package/dist/esm/assets/scripts/notification/FullWidthNotification.js +0 -125
  188. package/dist/esm/assets/scripts/notification/MessageNotification.js +0 -152
  189. package/dist/esm/assets/scripts/notification/Notification.js +0 -94
  190. package/dist/esm/assets/scripts/notification/const/classNames.js +0 -44
  191. package/dist/esm/assets/scripts/notification/const/icons.js +0 -25
  192. package/dist/esm/assets/scripts/notification/const/index.js +0 -4
  193. package/dist/esm/assets/scripts/notification/const/sizes.js +0 -40
  194. package/dist/esm/assets/scripts/notification/const/types.js +0 -8
  195. package/dist/esm/assets/scripts/notification/index.js +0 -11
  196. package/dist/esm/assets/scripts/notification/utils.js +0 -84
  197. package/dist/esm/assets/scripts/progress-bar/ProgressBar.js +0 -264
  198. package/dist/esm/assets/scripts/progress-bar/index.js +0 -1
  199. package/dist/esm/assets/scripts/selectBox.js +0 -162
  200. package/dist/esm/assets/scripts/shared/ButtonCloseX.js +0 -37
  201. package/dist/esm/assets/scripts/tab.js +0 -33
  202. package/dist/esm/assets/scripts/table/Table.js +0 -370
  203. package/dist/esm/assets/scripts/table/const/classNames.js +0 -27
  204. package/dist/esm/assets/scripts/table/const/index.js +0 -2
  205. package/dist/esm/assets/scripts/table/const/types.js +0 -1
  206. package/dist/esm/assets/scripts/table/index.js +0 -8
  207. package/dist/esm/assets/scripts/tag/Tag.js +0 -254
  208. package/dist/esm/assets/scripts/tag/const/classNames.js +0 -12
  209. package/dist/esm/assets/scripts/tag/const/index.js +0 -3
  210. package/dist/esm/assets/scripts/tag/const/sizes.js +0 -7
  211. package/dist/esm/assets/scripts/tag/const/types.js +0 -1
  212. package/dist/esm/assets/scripts/tag/index.js +0 -9
  213. package/dist/esm/assets/scripts/tooltip/Tooltip.js +0 -346
  214. package/dist/esm/assets/scripts/tooltip/TooltipLayerManager.js +0 -75
  215. package/dist/esm/assets/scripts/tooltip/const/classNames.js +0 -23
  216. package/dist/esm/assets/scripts/tooltip/const/constants.js +0 -50
  217. package/dist/esm/assets/scripts/tooltip/const/icons.js +0 -9
  218. package/dist/esm/assets/scripts/tooltip/const/index.js +0 -4
  219. package/dist/esm/assets/scripts/tooltip/const/templates.js +0 -59
  220. package/dist/esm/assets/scripts/tooltip/const/types.js +0 -1
  221. package/dist/esm/assets/scripts/tooltip/index.js +0 -10
  222. package/dist/esm/assets/scripts/tooltip/utils.js +0 -34
  223. package/dist/esm/assets/scripts/utils/debounce.js +0 -26
  224. package/dist/esm/assets/scripts/utils/unifiedBox/domRenderer.js +0 -363
  225. package/dist/esm/assets/scripts/utils/unifiedBox/dropdownModel.js +0 -279
  226. package/dist/esm/assets/scripts/utils/unifiedBox/unifiedBoxController.js +0 -615
  227. package/dist/esm/assets/scripts/utils/unifiedBox/unifiedBoxManager.js +0 -466
  228. package/dist/temp/assets/scripts/baseBox.d.ts +0 -55
  229. package/dist/temp/assets/scripts/baseBox.js +0 -140
  230. package/dist/temp/assets/scripts/comboBox.d.ts +0 -60
  231. package/dist/temp/assets/scripts/comboBox.js +0 -132
  232. package/dist/temp/assets/scripts/datePicker.d.ts +0 -86
  233. package/dist/temp/assets/scripts/datePicker.js +0 -699
  234. package/dist/temp/assets/scripts/featuredIcon.d.ts +0 -22
  235. package/dist/temp/assets/scripts/featuredIcon.js +0 -79
  236. package/dist/temp/assets/scripts/fileInput/const/classNames.d.ts +0 -15
  237. package/dist/temp/assets/scripts/fileInput/const/classNames.js +0 -16
  238. package/dist/temp/assets/scripts/fileInput/const/index.d.ts +0 -2
  239. package/dist/temp/assets/scripts/fileInput/const/index.js +0 -2
  240. package/dist/temp/assets/scripts/fileInput/const/types.d.ts +0 -88
  241. package/dist/temp/assets/scripts/fileInput/const/types.js +0 -7
  242. package/dist/temp/assets/scripts/fileInput/fileInput.d.ts +0 -13
  243. package/dist/temp/assets/scripts/fileInput/fileInput.js +0 -71
  244. package/dist/temp/assets/scripts/fileInput/fileInputModel.d.ts +0 -12
  245. package/dist/temp/assets/scripts/fileInput/fileInputModel.js +0 -37
  246. package/dist/temp/assets/scripts/fileInput/fileInputView.d.ts +0 -42
  247. package/dist/temp/assets/scripts/fileInput/fileInputView.js +0 -145
  248. package/dist/temp/assets/scripts/fileInput/index.d.ts +0 -3
  249. package/dist/temp/assets/scripts/fileInput/index.js +0 -9
  250. package/dist/temp/assets/scripts/imageFileInput/ImageFileInput.d.ts +0 -63
  251. package/dist/temp/assets/scripts/imageFileInput/ImageFileInput.js +0 -180
  252. package/dist/temp/assets/scripts/imageFileInput/ImageFileInputModel.d.ts +0 -73
  253. package/dist/temp/assets/scripts/imageFileInput/ImageFileInputModel.js +0 -214
  254. package/dist/temp/assets/scripts/imageFileInput/ImageFileInputView.d.ts +0 -79
  255. package/dist/temp/assets/scripts/imageFileInput/ImageFileInputView.js +0 -350
  256. package/dist/temp/assets/scripts/imageFileInput/const/classNames.d.ts +0 -19
  257. package/dist/temp/assets/scripts/imageFileInput/const/classNames.js +0 -20
  258. package/dist/temp/assets/scripts/imageFileInput/const/index.d.ts +0 -2
  259. package/dist/temp/assets/scripts/imageFileInput/const/index.js +0 -2
  260. package/dist/temp/assets/scripts/imageFileInput/const/types.d.ts +0 -125
  261. package/dist/temp/assets/scripts/imageFileInput/const/types.js +0 -7
  262. package/dist/temp/assets/scripts/imageFileInput/index.d.ts +0 -3
  263. package/dist/temp/assets/scripts/imageFileInput/index.js +0 -9
  264. package/dist/temp/assets/scripts/index.d.ts +0 -34
  265. package/dist/temp/assets/scripts/index.js +0 -30
  266. package/dist/temp/assets/scripts/modal/Modal.d.ts +0 -27
  267. package/dist/temp/assets/scripts/modal/Modal.js +0 -100
  268. package/dist/temp/assets/scripts/modal/ModalActions.d.ts +0 -18
  269. package/dist/temp/assets/scripts/modal/ModalActions.js +0 -117
  270. package/dist/temp/assets/scripts/modal/ModalContent.d.ts +0 -13
  271. package/dist/temp/assets/scripts/modal/ModalContent.js +0 -39
  272. package/dist/temp/assets/scripts/modal/ModalHeader.d.ts +0 -15
  273. package/dist/temp/assets/scripts/modal/ModalHeader.js +0 -96
  274. package/dist/temp/assets/scripts/modal/const/classNames.d.ts +0 -22
  275. package/dist/temp/assets/scripts/modal/const/classNames.js +0 -23
  276. package/dist/temp/assets/scripts/modal/const/index.d.ts +0 -2
  277. package/dist/temp/assets/scripts/modal/const/index.js +0 -2
  278. package/dist/temp/assets/scripts/modal/const/types.d.ts +0 -61
  279. package/dist/temp/assets/scripts/modal/const/types.js +0 -1
  280. package/dist/temp/assets/scripts/modal/index.d.ts +0 -7
  281. package/dist/temp/assets/scripts/modal/index.js +0 -15
  282. package/dist/temp/assets/scripts/modal/utils/contentUtils.d.ts +0 -10
  283. package/dist/temp/assets/scripts/modal/utils/contentUtils.js +0 -29
  284. package/dist/temp/assets/scripts/notification/FloatingNotification.d.ts +0 -24
  285. package/dist/temp/assets/scripts/notification/FloatingNotification.js +0 -157
  286. package/dist/temp/assets/scripts/notification/FullWidthNotification.d.ts +0 -21
  287. package/dist/temp/assets/scripts/notification/FullWidthNotification.js +0 -110
  288. package/dist/temp/assets/scripts/notification/MessageNotification.d.ts +0 -22
  289. package/dist/temp/assets/scripts/notification/MessageNotification.js +0 -140
  290. package/dist/temp/assets/scripts/notification/Notification.d.ts +0 -21
  291. package/dist/temp/assets/scripts/notification/Notification.js +0 -94
  292. package/dist/temp/assets/scripts/notification/const/classNames.d.ts +0 -43
  293. package/dist/temp/assets/scripts/notification/const/classNames.js +0 -44
  294. package/dist/temp/assets/scripts/notification/const/icons.d.ts +0 -25
  295. package/dist/temp/assets/scripts/notification/const/icons.js +0 -25
  296. package/dist/temp/assets/scripts/notification/const/index.d.ts +0 -5
  297. package/dist/temp/assets/scripts/notification/const/index.js +0 -4
  298. package/dist/temp/assets/scripts/notification/const/sizes.d.ts +0 -32
  299. package/dist/temp/assets/scripts/notification/const/sizes.js +0 -40
  300. package/dist/temp/assets/scripts/notification/const/types.d.ts +0 -19
  301. package/dist/temp/assets/scripts/notification/const/types.js +0 -8
  302. package/dist/temp/assets/scripts/notification/index.d.ts +0 -7
  303. package/dist/temp/assets/scripts/notification/index.js +0 -11
  304. package/dist/temp/assets/scripts/notification/utils.d.ts +0 -8
  305. package/dist/temp/assets/scripts/notification/utils.js +0 -89
  306. package/dist/temp/assets/scripts/progress-bar/ProgressBar.d.ts +0 -67
  307. package/dist/temp/assets/scripts/progress-bar/ProgressBar.js +0 -263
  308. package/dist/temp/assets/scripts/progress-bar/index.d.ts +0 -1
  309. package/dist/temp/assets/scripts/progress-bar/index.js +0 -1
  310. package/dist/temp/assets/scripts/selectBox.d.ts +0 -50
  311. package/dist/temp/assets/scripts/selectBox.js +0 -170
  312. package/dist/temp/assets/scripts/shared/ButtonCloseX.d.ts +0 -5
  313. package/dist/temp/assets/scripts/shared/ButtonCloseX.js +0 -33
  314. package/dist/temp/assets/scripts/tab.d.ts +0 -7
  315. package/dist/temp/assets/scripts/tab.js +0 -33
  316. package/dist/temp/assets/scripts/table/Table.d.ts +0 -41
  317. package/dist/temp/assets/scripts/table/Table.js +0 -378
  318. package/dist/temp/assets/scripts/table/const/classNames.d.ts +0 -27
  319. package/dist/temp/assets/scripts/table/const/classNames.js +0 -27
  320. package/dist/temp/assets/scripts/table/const/index.d.ts +0 -2
  321. package/dist/temp/assets/scripts/table/const/index.js +0 -2
  322. package/dist/temp/assets/scripts/table/const/types.d.ts +0 -23
  323. package/dist/temp/assets/scripts/table/const/types.js +0 -1
  324. package/dist/temp/assets/scripts/table/index.d.ts +0 -3
  325. package/dist/temp/assets/scripts/table/index.js +0 -8
  326. package/dist/temp/assets/scripts/tag/Tag.d.ts +0 -27
  327. package/dist/temp/assets/scripts/tag/Tag.js +0 -259
  328. package/dist/temp/assets/scripts/tag/const/classNames.d.ts +0 -11
  329. package/dist/temp/assets/scripts/tag/const/classNames.js +0 -12
  330. package/dist/temp/assets/scripts/tag/const/index.d.ts +0 -3
  331. package/dist/temp/assets/scripts/tag/const/index.js +0 -3
  332. package/dist/temp/assets/scripts/tag/const/sizes.d.ts +0 -7
  333. package/dist/temp/assets/scripts/tag/const/sizes.js +0 -7
  334. package/dist/temp/assets/scripts/tag/const/types.d.ts +0 -33
  335. package/dist/temp/assets/scripts/tag/const/types.js +0 -1
  336. package/dist/temp/assets/scripts/tag/index.d.ts +0 -3
  337. package/dist/temp/assets/scripts/tag/index.js +0 -9
  338. package/dist/temp/assets/scripts/tooltip/Tooltip.d.ts +0 -54
  339. package/dist/temp/assets/scripts/tooltip/Tooltip.js +0 -335
  340. package/dist/temp/assets/scripts/tooltip/TooltipLayerManager.d.ts +0 -21
  341. package/dist/temp/assets/scripts/tooltip/TooltipLayerManager.js +0 -71
  342. package/dist/temp/assets/scripts/tooltip/const/classNames.d.ts +0 -17
  343. package/dist/temp/assets/scripts/tooltip/const/classNames.js +0 -23
  344. package/dist/temp/assets/scripts/tooltip/const/constants.d.ts +0 -33
  345. package/dist/temp/assets/scripts/tooltip/const/constants.js +0 -46
  346. package/dist/temp/assets/scripts/tooltip/const/icons.d.ts +0 -4
  347. package/dist/temp/assets/scripts/tooltip/const/icons.js +0 -9
  348. package/dist/temp/assets/scripts/tooltip/const/index.d.ts +0 -5
  349. package/dist/temp/assets/scripts/tooltip/const/index.js +0 -4
  350. package/dist/temp/assets/scripts/tooltip/const/templates.d.ts +0 -16
  351. package/dist/temp/assets/scripts/tooltip/const/templates.js +0 -59
  352. package/dist/temp/assets/scripts/tooltip/const/types.d.ts +0 -14
  353. package/dist/temp/assets/scripts/tooltip/const/types.js +0 -1
  354. package/dist/temp/assets/scripts/tooltip/index.d.ts +0 -6
  355. package/dist/temp/assets/scripts/tooltip/index.js +0 -10
  356. package/dist/temp/assets/scripts/tooltip/utils.d.ts +0 -2
  357. package/dist/temp/assets/scripts/tooltip/utils.js +0 -33
  358. package/dist/temp/assets/scripts/utils/debounce.d.ts +0 -8
  359. package/dist/temp/assets/scripts/utils/debounce.js +0 -23
  360. package/dist/temp/assets/scripts/utils/unifiedBox/domRenderer.d.ts +0 -107
  361. package/dist/temp/assets/scripts/utils/unifiedBox/domRenderer.js +0 -367
  362. package/dist/temp/assets/scripts/utils/unifiedBox/dropdownModel.d.ts +0 -142
  363. package/dist/temp/assets/scripts/utils/unifiedBox/dropdownModel.js +0 -286
  364. package/dist/temp/assets/scripts/utils/unifiedBox/unifiedBoxController.d.ts +0 -156
  365. package/dist/temp/assets/scripts/utils/unifiedBox/unifiedBoxController.js +0 -604
  366. package/dist/temp/assets/scripts/utils/unifiedBox/unifiedBoxManager.d.ts +0 -95
  367. package/dist/temp/assets/scripts/utils/unifiedBox/unifiedBoxManager.js +0 -482
  368. package/dist/types/assets/scripts/baseBox.d.ts +0 -55
  369. package/dist/types/assets/scripts/comboBox.d.ts +0 -60
  370. package/dist/types/assets/scripts/datePicker.d.ts +0 -86
  371. package/dist/types/assets/scripts/featuredIcon.d.ts +0 -22
  372. package/dist/types/assets/scripts/fileInput/const/classNames.d.ts +0 -15
  373. package/dist/types/assets/scripts/fileInput/const/index.d.ts +0 -2
  374. package/dist/types/assets/scripts/fileInput/const/types.d.ts +0 -88
  375. package/dist/types/assets/scripts/fileInput/fileInput.d.ts +0 -13
  376. package/dist/types/assets/scripts/fileInput/fileInputModel.d.ts +0 -12
  377. package/dist/types/assets/scripts/fileInput/fileInputView.d.ts +0 -42
  378. package/dist/types/assets/scripts/fileInput/index.d.ts +0 -3
  379. package/dist/types/assets/scripts/imageFileInput/ImageFileInput.d.ts +0 -63
  380. package/dist/types/assets/scripts/imageFileInput/ImageFileInputModel.d.ts +0 -73
  381. package/dist/types/assets/scripts/imageFileInput/ImageFileInputView.d.ts +0 -79
  382. package/dist/types/assets/scripts/imageFileInput/const/classNames.d.ts +0 -19
  383. package/dist/types/assets/scripts/imageFileInput/const/index.d.ts +0 -2
  384. package/dist/types/assets/scripts/imageFileInput/const/types.d.ts +0 -125
  385. package/dist/types/assets/scripts/imageFileInput/index.d.ts +0 -3
  386. package/dist/types/assets/scripts/index.d.ts +0 -34
  387. package/dist/types/assets/scripts/modal/Modal.d.ts +0 -27
  388. package/dist/types/assets/scripts/modal/ModalActions.d.ts +0 -18
  389. package/dist/types/assets/scripts/modal/ModalContent.d.ts +0 -13
  390. package/dist/types/assets/scripts/modal/ModalHeader.d.ts +0 -15
  391. package/dist/types/assets/scripts/modal/const/classNames.d.ts +0 -22
  392. package/dist/types/assets/scripts/modal/const/index.d.ts +0 -2
  393. package/dist/types/assets/scripts/modal/const/types.d.ts +0 -61
  394. package/dist/types/assets/scripts/modal/index.d.ts +0 -7
  395. package/dist/types/assets/scripts/modal/utils/contentUtils.d.ts +0 -10
  396. package/dist/types/assets/scripts/notification/FloatingNotification.d.ts +0 -24
  397. package/dist/types/assets/scripts/notification/FullWidthNotification.d.ts +0 -21
  398. package/dist/types/assets/scripts/notification/MessageNotification.d.ts +0 -22
  399. package/dist/types/assets/scripts/notification/Notification.d.ts +0 -21
  400. package/dist/types/assets/scripts/notification/const/classNames.d.ts +0 -43
  401. package/dist/types/assets/scripts/notification/const/icons.d.ts +0 -25
  402. package/dist/types/assets/scripts/notification/const/index.d.ts +0 -5
  403. package/dist/types/assets/scripts/notification/const/sizes.d.ts +0 -32
  404. package/dist/types/assets/scripts/notification/const/types.d.ts +0 -19
  405. package/dist/types/assets/scripts/notification/index.d.ts +0 -7
  406. package/dist/types/assets/scripts/notification/utils.d.ts +0 -8
  407. package/dist/types/assets/scripts/progress-bar/ProgressBar.d.ts +0 -67
  408. package/dist/types/assets/scripts/progress-bar/index.d.ts +0 -1
  409. package/dist/types/assets/scripts/selectBox.d.ts +0 -50
  410. package/dist/types/assets/scripts/shared/ButtonCloseX.d.ts +0 -5
  411. package/dist/types/assets/scripts/tab.d.ts +0 -7
  412. package/dist/types/assets/scripts/table/Table.d.ts +0 -41
  413. package/dist/types/assets/scripts/table/const/classNames.d.ts +0 -27
  414. package/dist/types/assets/scripts/table/const/index.d.ts +0 -2
  415. package/dist/types/assets/scripts/table/const/types.d.ts +0 -23
  416. package/dist/types/assets/scripts/table/index.d.ts +0 -3
  417. package/dist/types/assets/scripts/tag/Tag.d.ts +0 -27
  418. package/dist/types/assets/scripts/tag/const/classNames.d.ts +0 -11
  419. package/dist/types/assets/scripts/tag/const/index.d.ts +0 -3
  420. package/dist/types/assets/scripts/tag/const/sizes.d.ts +0 -7
  421. package/dist/types/assets/scripts/tag/const/types.d.ts +0 -33
  422. package/dist/types/assets/scripts/tag/index.d.ts +0 -3
  423. package/dist/types/assets/scripts/tooltip/Tooltip.d.ts +0 -54
  424. package/dist/types/assets/scripts/tooltip/TooltipLayerManager.d.ts +0 -21
  425. package/dist/types/assets/scripts/tooltip/const/classNames.d.ts +0 -17
  426. package/dist/types/assets/scripts/tooltip/const/constants.d.ts +0 -33
  427. package/dist/types/assets/scripts/tooltip/const/icons.d.ts +0 -4
  428. package/dist/types/assets/scripts/tooltip/const/index.d.ts +0 -5
  429. package/dist/types/assets/scripts/tooltip/const/templates.d.ts +0 -16
  430. package/dist/types/assets/scripts/tooltip/const/types.d.ts +0 -14
  431. package/dist/types/assets/scripts/tooltip/index.d.ts +0 -6
  432. package/dist/types/assets/scripts/tooltip/utils.d.ts +0 -2
  433. package/dist/types/assets/scripts/utils/debounce.d.ts +0 -8
  434. package/dist/types/assets/scripts/utils/unifiedBox/domRenderer.d.ts +0 -107
  435. package/dist/types/assets/scripts/utils/unifiedBox/dropdownModel.d.ts +0 -142
  436. package/dist/types/assets/scripts/utils/unifiedBox/unifiedBoxController.d.ts +0 -156
  437. package/dist/types/assets/scripts/utils/unifiedBox/unifiedBoxManager.d.ts +0 -95
  438. /package/dist/cjs/{assets/scripts/modal/const/types.js → src/types/component-meta.js} +0 -0
@@ -1,604 +0,0 @@
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,95 +0,0 @@
1
- import { OptionValue } from '../../../../src/types';
2
- import { DropdownOption } from './dropdownModel';
3
- export interface UnifiedBoxManagerConfig {
4
- options?: DropdownOption[];
5
- placeholder?: string;
6
- value?: OptionValue;
7
- onChange?: (value: OptionValue) => void;
8
- onSearch?: (searchValue: string) => void | Promise<void>;
9
- onEdit?: () => void;
10
- onSelectAll?: () => void;
11
- onSearchAll?: () => void;
12
- onComplete?: () => void;
13
- onScrollBottom?: () => void;
14
- searchDebounceMs?: number;
15
- maxHeight?: number;
16
- disabled?: boolean;
17
- size?: 'xs' | 'sm' | 'md';
18
- multiple?: boolean;
19
- showFooterButtons?: boolean;
20
- label?: string;
21
- required?: boolean;
22
- type?: 'selectbox' | 'combobox';
23
- }
24
- /**
25
- * 통합된 UnifiedBox 클래스
26
- * SelectBox와 ComboBox의 기능을 모두 포함
27
- */
28
- export declare class UnifiedBoxManager {
29
- private element;
30
- private config;
31
- private model;
32
- private renderer;
33
- private controller;
34
- private inputField?;
35
- private debouncedSearch;
36
- private lastSearchValue;
37
- private hasInitialOptions;
38
- private isComboBox;
39
- private baseClass;
40
- private dropdownElement?;
41
- private triggerElement?;
42
- private footerElement?;
43
- private arrowElement?;
44
- constructor(element: HTMLElement, config?: UnifiedBoxManagerConfig);
45
- private initialize;
46
- private setupElementClasses;
47
- private createUI;
48
- private createComboBoxUI;
49
- private createSelectBoxUI;
50
- private createDropdown;
51
- private setupController;
52
- private handleInput;
53
- private handleInputClick;
54
- private handleClearInput;
55
- private handleShowAll;
56
- private handleSelectionChange;
57
- private updateSelectBoxValue;
58
- private canToggleDropdown;
59
- private handleSelectAll;
60
- private handleComplete;
61
- private updateSelectAllButtonText;
62
- getValues(): DropdownOption[];
63
- getOptions(): DropdownOption[];
64
- setValues(value: DropdownOption[]): void;
65
- updateOptions(newOptions: DropdownOption[]): void;
66
- setDisabled(disabled: boolean): void;
67
- open(): void;
68
- close(): void;
69
- focus(): void;
70
- destroy(): void;
71
- selectAll(): void;
72
- deselectAll(): void;
73
- isMultiple(): boolean;
74
- toggleSelectAll(): void;
75
- getDebugInfo(): {
76
- config: UnifiedBoxManagerConfig;
77
- modelState: any;
78
- isOpen: boolean;
79
- };
80
- /**
81
- * 드롭다운을 스크롤의 바닥으로 이동
82
- * 전체 선택 시 추가 데이터 로드를 트리거하기 위해 사용
83
- */
84
- scrollToBottom(): void;
85
- /**
86
- * 전체 선택 버튼의 텍스트를 외부에서 변경
87
- * @param text 버튼에 표시할 텍스트
88
- */
89
- setSelectAllButtonText(text: string): void;
90
- /**
91
- * 특정 인덱스의 옵션으로 포커스 이동
92
- * @param index 포커스를 이동할 옵션의 인덱스
93
- */
94
- setFocusIndex(index: number): void;
95
- }