@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 +0,0 @@
1
- export {};
@@ -1,6 +0,0 @@
1
- import { Tooltip } from './Tooltip';
2
- export { Tooltip } from './Tooltip';
3
- export type { TooltipOptions, CalculatedPosition } from './const';
4
- export { calculateOptimalPosition } from './utils';
5
- export { SVG_ICONS, MARGIN, DEFAULT_TOOLTIP_WIDTH, DEFAULT_TOOLTIP_HEIGHT, POSITION_PRIORITY } from './const';
6
- export default Tooltip;
@@ -1,10 +0,0 @@
1
- import { Tooltip } from './Tooltip';
2
- export { Tooltip } from './Tooltip';
3
- export { calculateOptimalPosition } from './utils';
4
- export { SVG_ICONS, MARGIN, DEFAULT_TOOLTIP_WIDTH, DEFAULT_TOOLTIP_HEIGHT, POSITION_PRIORITY } from './const';
5
- // 전역 등록 ( 추후 index.ts와 개별동작 할 수 있게끔 대비 )
6
- if (typeof window !== 'undefined') {
7
- window.ncua = window.ncua || {};
8
- window.ncua.Tooltip = Tooltip;
9
- }
10
- export default Tooltip;
@@ -1,2 +0,0 @@
1
- import { CalculatedPosition } from './const';
2
- export declare function calculateOptimalPosition(triggerElement: HTMLElement, tooltipElement: HTMLElement, preferredPosition?: string): CalculatedPosition;
@@ -1,33 +0,0 @@
1
- import { MARGIN, DEFAULT_TOOLTIP_WIDTH, DEFAULT_TOOLTIP_HEIGHT, POSITION_PRIORITY } from './const';
2
- export function calculateOptimalPosition(triggerElement, tooltipElement, preferredPosition = 'bottom') {
3
- const triggerRect = triggerElement.getBoundingClientRect();
4
- const tooltipRect = tooltipElement.getBoundingClientRect();
5
- const { innerWidth: viewportWidth, innerHeight: viewportHeight } = window;
6
- const spaces = {
7
- top: triggerRect.top,
8
- bottom: viewportHeight - triggerRect.bottom,
9
- left: triggerRect.left,
10
- right: viewportWidth - triggerRect.right,
11
- };
12
- const tooltipWidth = tooltipRect.width || DEFAULT_TOOLTIP_WIDTH;
13
- const tooltipHeight = tooltipRect.height || DEFAULT_TOOLTIP_HEIGHT;
14
- for (const position of POSITION_PRIORITY) {
15
- const hasSpace = position === 'bottom' || position === 'top'
16
- ? spaces[position] >= tooltipHeight + MARGIN
17
- : spaces[position] >= tooltipWidth + MARGIN;
18
- if (hasSpace) {
19
- if (position === 'bottom' || position === 'top') {
20
- const centerX = triggerRect.left + triggerRect.width / 2;
21
- const tooltipHalfWidth = tooltipWidth / 2;
22
- if (centerX - tooltipHalfWidth < MARGIN) {
23
- return `${position}-left`;
24
- }
25
- else if (centerX + tooltipHalfWidth > viewportWidth - MARGIN) {
26
- return `${position}-right`;
27
- }
28
- }
29
- return position;
30
- }
31
- }
32
- return preferredPosition;
33
- }
@@ -1,8 +0,0 @@
1
- /**
2
- * 디바운스 유틸리티
3
- * 마지막 호출 후 지정된 시간이 지나야 콜백이 실행됨
4
- */
5
- export declare function debounce<T extends (...args: any[]) => any>(fn: T, ms: number): {
6
- (...args: Parameters<T>): void;
7
- cancel: () => void;
8
- };
@@ -1,23 +0,0 @@
1
- /**
2
- * 디바운스 유틸리티
3
- * 마지막 호출 후 지정된 시간이 지나야 콜백이 실행됨
4
- */
5
- export function debounce(fn, ms) {
6
- let timer;
7
- const debounced = (...args) => {
8
- if (timer !== undefined) {
9
- clearTimeout(timer);
10
- }
11
- timer = window.setTimeout(() => {
12
- timer = undefined;
13
- fn(...args);
14
- }, ms);
15
- };
16
- debounced.cancel = () => {
17
- if (timer !== undefined) {
18
- clearTimeout(timer);
19
- timer = undefined;
20
- }
21
- };
22
- return debounced;
23
- }
@@ -1,107 +0,0 @@
1
- export interface RenderableOption {
2
- id: string | number;
3
- label: string;
4
- disabled?: boolean;
5
- selected?: boolean;
6
- focused?: boolean;
7
- }
8
- export interface DropdownRenderConfig {
9
- maxHeight: number;
10
- size: 'xs' | 'sm' | 'md';
11
- listboxId: string;
12
- noResultsText?: string;
13
- }
14
- export interface OptionElementData {
15
- element: HTMLLIElement;
16
- option: RenderableOption;
17
- index: number;
18
- }
19
- export declare class DOMRenderer {
20
- private optionElementCache;
21
- /**
22
- * 드롭다운 컨테이너 생성 (구조만)
23
- */
24
- createDropdownStructure(config: DropdownRenderConfig): {
25
- dropdown: HTMLDivElement;
26
- content: HTMLDivElement;
27
- optionsList: HTMLUListElement;
28
- };
29
- /**
30
- * 단일 옵션 엘리먼트 생성 (재사용 가능)
31
- */
32
- createOptionElement(option: RenderableOption, index: number, config: DropdownRenderConfig): HTMLLIElement;
33
- /**
34
- * 옵션 엘리먼트 상태 업데이트 (DOM 조작 최소화)
35
- */
36
- updateOptionElement(element: HTMLLIElement, option: RenderableOption, index: number, config: DropdownRenderConfig): void;
37
- /**
38
- * "결과 없음" 엘리먼트 생성
39
- */
40
- createNoResultsElement(text?: string): HTMLLIElement;
41
- /**
42
- * 옵션 리스트 효율적 업데이트 (Differential Rendering)
43
- */
44
- updateOptionsList(container: HTMLUListElement, newOptions: RenderableOption[], config: DropdownRenderConfig, showNoResults?: boolean): HTMLLIElement[];
45
- /**
46
- * 컨테이너 자식 엘리먼트 효율적 업데이트
47
- */
48
- private updateContainerChildren;
49
- /**
50
- * 클래스 토글 (변경이 필요한 경우에만)
51
- */
52
- private toggleClass;
53
- /**
54
- * 입력 필드 생성 (InputFieldUtils에서 이동)
55
- */
56
- createInputField(config: {
57
- placeholder?: string;
58
- disabled?: boolean;
59
- size?: 'xs' | 'sm' | 'md';
60
- showSearchIcon?: boolean;
61
- onInput?: (value: string) => void;
62
- onClick?: () => void;
63
- onShowAll?: () => void;
64
- onClear?: () => void;
65
- }): {
66
- container: HTMLElement;
67
- input: HTMLInputElement;
68
- setValue: (value: string) => void;
69
- focus: () => void;
70
- blur: () => void;
71
- };
72
- /**
73
- * 캐시 정리
74
- */
75
- clearCache(): void;
76
- /**
77
- * 특정 옵션 캐시 제거
78
- */
79
- removeCachedOption(optionId: string | number): void;
80
- /**
81
- * 공통 DOM 생성 유틸리티
82
- */
83
- static createElementWithClass(tagName: string, className: string, textContent?: string): HTMLElement;
84
- /**
85
- * 버튼 엘리먼트 생성
86
- */
87
- static createButton(className: string, textContent: string, onClick?: (e: Event) => void): HTMLButtonElement;
88
- /**
89
- * SVG 아이콘 생성
90
- */
91
- static createSvgIcon(iconName: string, size?: number): SVGElement;
92
- /**
93
- * 푸터 생성
94
- */
95
- createFooter(config: {
96
- multiple?: boolean;
97
- showFooterButtons?: boolean;
98
- onSelectAll?: () => void;
99
- onEdit?: () => void;
100
- onComplete?: () => void;
101
- selectAllButtonText?: string;
102
- }): HTMLElement;
103
- /**
104
- * 전체 선택 버튼 텍스트 업데이트
105
- */
106
- updateSelectAllButtonText(footerElement: HTMLElement, text: string): void;
107
- }
@@ -1,367 +0,0 @@
1
- export class DOMRenderer {
2
- constructor() {
3
- this.optionElementCache = new Map();
4
- }
5
- /**
6
- * 드롭다운 컨테이너 생성 (구조만)
7
- */
8
- createDropdownStructure(config) {
9
- const dropdown = document.createElement('div');
10
- dropdown.className = `ncua-select-dropdown ncua-select-dropdown--down ncua-select-dropdown--${config.size}`;
11
- dropdown.style.display = 'none';
12
- const content = document.createElement('div');
13
- content.className = 'ncua-select-dropdown__content';
14
- const optionsList = document.createElement('ul');
15
- optionsList.className = 'ncua-select-dropdown__options';
16
- optionsList.setAttribute('role', 'listbox');
17
- optionsList.setAttribute('id', config.listboxId);
18
- optionsList.style.maxHeight = `${config.maxHeight}px`;
19
- optionsList.style.overflowY = 'auto'; // 스크롤 활성화
20
- content.appendChild(optionsList);
21
- dropdown.appendChild(content);
22
- return { dropdown, content, optionsList };
23
- }
24
- /**
25
- * 단일 옵션 엘리먼트 생성 (재사용 가능)
26
- */
27
- createOptionElement(option, index, config) {
28
- const cached = this.optionElementCache.get(option.id);
29
- if (cached) {
30
- this.updateOptionElement(cached, option, index, config);
31
- return cached;
32
- }
33
- const element = document.createElement('li');
34
- element.className = 'ncua-select-dropdown__option';
35
- element.setAttribute('data-value', String(option.id));
36
- element.setAttribute('data-index', String(index));
37
- element.setAttribute('role', 'option');
38
- element.id = `${config.listboxId}-${option.id}`;
39
- const span = document.createElement('span');
40
- span.className = 'ncua-select-dropdown__option-text';
41
- span.textContent = option.label;
42
- element.appendChild(span);
43
- this.updateOptionElement(element, option, index, config);
44
- this.optionElementCache.set(option.id, element);
45
- return element;
46
- }
47
- /**
48
- * 옵션 엘리먼트 상태 업데이트 (DOM 조작 최소화)
49
- */
50
- updateOptionElement(element, option, index, config) {
51
- // 클래스 업데이트 (필요한 경우에만)
52
- const shouldHaveSelected = option.selected || false;
53
- const shouldHaveFocused = option.focused || false;
54
- const shouldHaveDisabled = option.disabled || false;
55
- this.toggleClass(element, 'ncua-select-dropdown__option--selected', shouldHaveSelected);
56
- this.toggleClass(element, 'ncua-select-dropdown__option--focused', shouldHaveFocused);
57
- this.toggleClass(element, 'ncua-select-dropdown__option--disabled', shouldHaveDisabled);
58
- // 속성 업데이트 (필요한 경우에만)
59
- element.setAttribute('aria-selected', String(shouldHaveSelected));
60
- element.setAttribute('data-index', String(index));
61
- }
62
- /**
63
- * "결과 없음" 엘리먼트 생성
64
- */
65
- createNoResultsElement(text = '일치하는 결과가 없습니다.') {
66
- const noResults = document.createElement('li');
67
- noResults.className = 'ncua-select-dropdown__no-results';
68
- noResults.textContent = text;
69
- return noResults;
70
- }
71
- /**
72
- * 옵션 리스트 효율적 업데이트 (Differential Rendering)
73
- */
74
- updateOptionsList(container, newOptions, config, showNoResults = false) {
75
- // 스크롤 위치 저장
76
- const scrollTop = container.scrollTop;
77
- // 결과 없음 처리
78
- if (showNoResults) {
79
- container.innerHTML = '';
80
- container.appendChild(this.createNoResultsElement(config.noResultsText));
81
- return [];
82
- }
83
- const newElements = [];
84
- // 새 옵션들로 엘리먼트 생성/업데이트
85
- newOptions.forEach((option, index) => {
86
- const element = this.createOptionElement(option, index, config);
87
- newElements.push(element);
88
- });
89
- // DOM 업데이트 최소화 - 변경된 부분만 업데이트
90
- this.updateContainerChildren(container, newElements);
91
- // 스크롤 위치 복원 (다음 프레임에서 실행)
92
- requestAnimationFrame(() => {
93
- container.scrollTop = scrollTop;
94
- });
95
- return newElements;
96
- }
97
- /**
98
- * 컨테이너 자식 엘리먼트 효율적 업데이트
99
- */
100
- updateContainerChildren(container, newChildren) {
101
- // 기존 엘리먼트 제거 (새 리스트에 없는 것들)
102
- Array.from(container.children).forEach((child) => {
103
- if (!newChildren.includes(child)) {
104
- child.remove();
105
- }
106
- });
107
- // 새 엘리먼트 추가 (순서 유지)
108
- newChildren.forEach((child, index) => {
109
- const currentChild = container.children[index];
110
- if (currentChild !== child) {
111
- if (currentChild) {
112
- container.insertBefore(child, currentChild);
113
- }
114
- else {
115
- container.appendChild(child);
116
- }
117
- }
118
- });
119
- }
120
- /**
121
- * 클래스 토글 (변경이 필요한 경우에만)
122
- */
123
- toggleClass(element, className, shouldHave) {
124
- const hasClass = element.classList.contains(className);
125
- if (shouldHave && !hasClass) {
126
- element.classList.add(className);
127
- }
128
- else if (!shouldHave && hasClass) {
129
- element.classList.remove(className);
130
- }
131
- }
132
- /**
133
- * 입력 필드 생성 (InputFieldUtils에서 이동)
134
- */
135
- createInputField(config) {
136
- const actualSize = config.size === 'md' ? 'sm' : config.size || 'sm';
137
- // 최상위 ncua-input 컨테이너 (React 버전과 동일)
138
- const inputContainer = document.createElement('div');
139
- inputContainer.className = `ncua-input ncua-input--${actualSize}`;
140
- if (config.disabled)
141
- inputContainer.classList.add('is-disabled');
142
- // ncua-input__content 래퍼 (React 버전과 동일)
143
- const inputContent = document.createElement('div');
144
- inputContent.className = 'ncua-input__content';
145
- // ncua-input__field 래퍼 (React 버전과 동일, size 포함)
146
- const inputField = document.createElement('div');
147
- inputField.className = `ncua-input__field ncua-input__field--${actualSize}`;
148
- // 실제 입력 필드 (React 버전과 동일)
149
- const input = document.createElement('input');
150
- input.type = 'text';
151
- input.placeholder = config.placeholder || '';
152
- if (config.disabled)
153
- input.disabled = true;
154
- // 이벤트 리스너
155
- if (config.onInput) {
156
- input.addEventListener('input', (e) => {
157
- config.onInput(e.target.value);
158
- });
159
- }
160
- if (config.onClick) {
161
- input.addEventListener('click', (event) => {
162
- event.stopPropagation(); // 이벤트 버블링 방지
163
- config.onClick();
164
- });
165
- }
166
- // 클리어 버튼 (React 버전의 renderClearButton과 동일)
167
- let clearButton = null;
168
- if (config.onClear) {
169
- clearButton = document.createElement('button');
170
- clearButton.type = 'button';
171
- clearButton.className = 'ncua-input__icon-wrap ncua-input__right-icon ncua-input__clear';
172
- clearButton.style.display = 'none'; // 초기에는 숨김
173
- clearButton.addEventListener('click', config.onClear);
174
- // 클리어 아이콘 (React와 동일한 크기)
175
- const iconSize = actualSize === 'xs' ? 14 : 16;
176
- const clearIcon = DOMRenderer.createSvgIcon('close', iconSize);
177
- clearIcon.setAttribute('class', 'ncua-input__clear-icon');
178
- clearButton.appendChild(clearIcon);
179
- // 입력값 변경 시 클리어 버튼 표시/숨김
180
- input.addEventListener('input', () => {
181
- if (clearButton) {
182
- clearButton.style.display = input.value ? 'flex' : 'none';
183
- }
184
- });
185
- }
186
- // 전체 보기 버튼 (React 버전의 trailingElement와 동일)
187
- let showAllButton = null;
188
- if (config.onShowAll) {
189
- showAllButton = document.createElement('div');
190
- showAllButton.className = 'ncua-input__icon-wrap ncua-input__right-icon';
191
- showAllButton.addEventListener('click', config.onShowAll);
192
- // 전체 버튼 (React Button 컴포넌트와 유사한 구조)
193
- const button = document.createElement('button');
194
- button.type = 'button';
195
- button.className = 'ncua-btn ncua-btn--xxs ncua-btn--text';
196
- // 아이콘
197
- const iconSize = 14;
198
- const showAllIcon = DOMRenderer.createSvgIcon('chevron-selector-vertical', iconSize);
199
- button.appendChild(showAllIcon);
200
- // 텍스트
201
- const label = document.createElement('span');
202
- label.className = 'ncua-btn__label';
203
- label.textContent = '전체';
204
- button.appendChild(label);
205
- showAllButton.appendChild(button);
206
- }
207
- // 검색 아이콘 (React 버전의 leadingElement와 동일)
208
- let searchIcon = null;
209
- if (config.showSearchIcon) {
210
- searchIcon = document.createElement('div');
211
- searchIcon.className = 'ncua-input__icon-wrap ncua-input__left-icon';
212
- // 검색 아이콘 (React와 동일한 크기와 색상)
213
- const searchSvg = DOMRenderer.createSvgIcon('search', 14);
214
- searchSvg.style.color = '#98a2b3'; // gray300에 해당하는 색상
215
- searchIcon.appendChild(searchSvg);
216
- }
217
- // 구조 조립 (React 버전과 동일한 순서)
218
- if (searchIcon)
219
- inputField.appendChild(searchIcon);
220
- inputField.appendChild(input);
221
- if (clearButton)
222
- inputField.appendChild(clearButton);
223
- if (showAllButton)
224
- inputField.appendChild(showAllButton);
225
- inputContent.appendChild(inputField);
226
- inputContainer.appendChild(inputContent);
227
- return {
228
- container: inputContainer,
229
- input,
230
- setValue: (value) => {
231
- input.value = value;
232
- // 클리어 버튼 표시 상태 업데이트
233
- if (clearButton) {
234
- clearButton.style.display = value ? 'flex' : 'none';
235
- }
236
- },
237
- focus: () => input.focus(),
238
- blur: () => input.blur(),
239
- };
240
- }
241
- /**
242
- * 캐시 정리
243
- */
244
- clearCache() {
245
- this.optionElementCache.clear();
246
- }
247
- /**
248
- * 특정 옵션 캐시 제거
249
- */
250
- removeCachedOption(optionId) {
251
- this.optionElementCache.delete(optionId);
252
- }
253
- /**
254
- * 공통 DOM 생성 유틸리티
255
- */
256
- static createElementWithClass(tagName, className, textContent) {
257
- const element = document.createElement(tagName);
258
- element.className = className;
259
- if (textContent) {
260
- element.textContent = textContent;
261
- }
262
- return element;
263
- }
264
- /**
265
- * 버튼 엘리먼트 생성
266
- */
267
- static createButton(className, textContent, onClick) {
268
- const button = document.createElement('button');
269
- button.className = className;
270
- // React 컴포넌트와 일치하도록 span.ncua-btn__label 구조 사용
271
- const label = document.createElement('span');
272
- label.className = 'ncua-btn__label';
273
- label.textContent = textContent;
274
- button.appendChild(label);
275
- if (onClick) {
276
- button.addEventListener('click', onClick);
277
- }
278
- return button;
279
- }
280
- /**
281
- * SVG 아이콘 생성
282
- */
283
- static createSvgIcon(iconName, size = 16) {
284
- const svg = document.createElementNS('http://www.w3.org/2000/svg', 'svg');
285
- svg.setAttribute('width', size.toString());
286
- svg.setAttribute('height', size.toString());
287
- svg.setAttribute('viewBox', '0 0 24 24');
288
- svg.setAttribute('fill', 'none');
289
- // 기본 아이콘들
290
- switch (iconName) {
291
- case 'close':
292
- svg.innerHTML =
293
- '<path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M17 7 7 17M7 7l10 10"/>';
294
- break;
295
- case 'chevron-down':
296
- svg.innerHTML =
297
- '<path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M19 9l-7 7-7-7"/>';
298
- break;
299
- case 'chevron-selector-vertical':
300
- svg.innerHTML =
301
- '<path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="m7 15 5 5 5-5M7 9l5-5 5 5"/>';
302
- break;
303
- case 'search':
304
- svg.innerHTML =
305
- '<path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="m21 21-3.5-3.5m2.5-6a8.5 8.5 0 1 1-17 0 8.5 8.5 0 0 1 17 0"></path>';
306
- break;
307
- }
308
- return svg;
309
- }
310
- /**
311
- * 푸터 생성
312
- */
313
- createFooter(config) {
314
- // 푸터 생성
315
- const footer = document.createElement('div');
316
- footer.className = 'ncua-select-dropdown__footer';
317
- const footerButtons = document.createElement('div');
318
- footerButtons.className = 'ncua-select-dropdown__footer-buttons';
319
- const footerLeft = document.createElement('div');
320
- footerLeft.className = 'ncua-select-dropdown__footer-left';
321
- const footerRight = document.createElement('div');
322
- footerRight.className = 'ncua-select-dropdown__footer-right';
323
- // 다중 선택인 경우 전체 선택 버튼 추가
324
- if (config.multiple) {
325
- const selectAllButton = DOMRenderer.createButton('ncua-btn ncua-btn--xs ncua-btn--text has-underline', config.selectAllButtonText || '전체 선택', (e) => {
326
- e.preventDefault();
327
- e.stopPropagation();
328
- config.onSelectAll?.();
329
- });
330
- footerLeft.appendChild(selectAllButton);
331
- }
332
- // 편집 버튼 (showFooterButtons가 true이고 onEdit가 있는 경우)
333
- if (config.showFooterButtons && config.onEdit) {
334
- const editButton = DOMRenderer.createButton('ncua-btn ncua-btn--xs ncua-btn--secondary-gray', '편집', (e) => {
335
- e.preventDefault();
336
- e.stopPropagation();
337
- config.onEdit?.();
338
- });
339
- footerRight.appendChild(editButton);
340
- }
341
- // 선택 완료 버튼 (다중 선택이거나 showFooterButtons가 true인 경우)
342
- if (config.multiple || config.showFooterButtons) {
343
- const completeButton = DOMRenderer.createButton('ncua-btn ncua-btn--xs ncua-btn--secondary', '선택 완료', (e) => {
344
- e.preventDefault();
345
- e.stopPropagation();
346
- config.onComplete?.();
347
- });
348
- footerRight.appendChild(completeButton);
349
- }
350
- footerButtons.appendChild(footerLeft);
351
- footerButtons.appendChild(footerRight);
352
- footer.appendChild(footerButtons);
353
- return footer;
354
- }
355
- /**
356
- * 전체 선택 버튼 텍스트 업데이트
357
- */
358
- updateSelectAllButtonText(footerElement, text) {
359
- const selectAllButton = footerElement.querySelector('.ncua-select-dropdown__footer-left .ncua-btn');
360
- if (selectAllButton) {
361
- const label = selectAllButton.querySelector('.ncua-btn__label');
362
- if (label) {
363
- label.textContent = text;
364
- }
365
- }
366
- }
367
- }