@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,87 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.FeaturedIcon = void 0;
7
- // React 컴포넌트와 동일하게 구성
8
- const iconSizeMap = {
9
- sm: 16,
10
- md: 20,
11
- lg: 24,
12
- xl: 28
13
- };
14
- class FeaturedIcon {
15
- constructor(options) {
16
- this.options = {
17
- theme: 'light-circle',
18
- color: 'neutral',
19
- size: 'sm',
20
- className: '',
21
- ...options
22
- };
23
- this.element = this.createElement();
24
- }
25
- // svgString ( ICON SVG ) 을 받아서 요소를 생성
26
- createElement() {
27
- const {
28
- theme,
29
- color,
30
- size,
31
- className,
32
- svgString
33
- } = this.options;
34
- // React FeaturedIcon과 동일한 클래스 구조
35
- const classes = ['ncua-featured-icon', `ncua-featured-icon--${theme}`, `ncua-featured-icon--${color}`, `ncua-featured-icon--${size}`];
36
- if (className) {
37
- classes.push(className);
38
- }
39
- const div = document.createElement('div');
40
- div.className = classes.join(' ');
41
- // outline-circle 테마일 때 추가 요소들 (React 컴포넌트와 동일)
42
- if (theme === 'outline-circle') {
43
- const innerOutline = document.createElement('div');
44
- innerOutline.className = 'ncua-featured-icon__outline ncua-featured-icon__outline--inner';
45
- div.appendChild(innerOutline);
46
- const outerOutline = document.createElement('div');
47
- outerOutline.className = 'ncua-featured-icon__outline ncua-featured-icon__outline--outer';
48
- div.appendChild(outerOutline);
49
- }
50
- // SVG 아이콘 추가
51
- const iconSize = iconSizeMap[size];
52
- const svgWithSize = this.addSizeToSvg(svgString, iconSize);
53
- div.innerHTML += svgWithSize;
54
- return div;
55
- }
56
- addSizeToSvg(svgString, size) {
57
- return svgString.replace(/<svg([^>]*)>/, `<svg$1 width="${size}" height="${size}">`);
58
- }
59
- // Public methods
60
- getElement() {
61
- return this.element;
62
- }
63
- updateColor(color) {
64
- this.element.className = this.element.className.replace(/ncua-featured-icon--(neutral|error|warning|success)/, `ncua-featured-icon--${color}`);
65
- this.options.color = color;
66
- }
67
- updateSize(size) {
68
- const iconSize = iconSizeMap[size];
69
- this.element.className = this.element.className.replace(/ncua-featured-icon--(sm|md|lg|xl)/, `ncua-featured-icon--${size}`);
70
- const svgIcon = this.element.querySelector('svg');
71
- if (svgIcon) {
72
- svgIcon.setAttribute('width', String(iconSize));
73
- svgIcon.setAttribute('height', String(iconSize));
74
- }
75
- this.options.size = size;
76
- }
77
- destroy() {
78
- if (this.element.parentNode) {
79
- this.element.parentNode.removeChild(this.element);
80
- }
81
- }
82
- // Static factory method
83
- static create(options) {
84
- return new FeaturedIcon(options);
85
- }
86
- }
87
- exports.FeaturedIcon = FeaturedIcon;
@@ -1,25 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.getLabelClassName = exports.getHintTextClassName = exports.getFileInputSizeClassName = exports.FILE_INPUT_CLASS_NAMES = void 0;
7
- // FileInput 관련 CSS 클래스명 상수
8
- const FILE_INPUT_CLASS_NAMES = exports.FILE_INPUT_CLASS_NAMES = {
9
- fileInput: 'ncua-file-input',
10
- inputContainer: 'ncua-file-input__input-container',
11
- label: 'ncua-file-input__label',
12
- helpIcon: 'ncua-input__help-icon',
13
- hintText: 'ncua-input__hint-text',
14
- hintList: 'ncua-file-input__hint-list',
15
- hintItem: 'ncua-file-input__hint-item',
16
- fileTags: 'ncua-file-input__file-tags',
17
- fileTagContainer: 'ncua-file-input__file-tag-container',
18
- fileImage: 'ncua-file-input__file-image'
19
- };
20
- const getFileInputSizeClassName = size => `ncua-file-input--${size}`;
21
- exports.getFileInputSizeClassName = getFileInputSizeClassName;
22
- const getLabelClassName = isRequired => isRequired ? 'ncua-label ncua-label--required' : 'ncua-label';
23
- exports.getLabelClassName = getLabelClassName;
24
- const getHintTextClassName = destructive => destructive ? 'ncua-input__hint-text ncua-input__hint-text--destructive' : 'ncua-input__hint-text';
25
- exports.getHintTextClassName = getHintTextClassName;
@@ -1,27 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- var _classNames = require("./classNames");
7
- Object.keys(_classNames).forEach(function (key) {
8
- if (key === "default" || key === "__esModule") return;
9
- if (key in exports && exports[key] === _classNames[key]) return;
10
- Object.defineProperty(exports, key, {
11
- enumerable: true,
12
- get: function () {
13
- return _classNames[key];
14
- }
15
- });
16
- });
17
- var _types = require("./types");
18
- Object.keys(_types).forEach(function (key) {
19
- if (key === "default" || key === "__esModule") return;
20
- if (key in exports && exports[key] === _types[key]) return;
21
- Object.defineProperty(exports, key, {
22
- enumerable: true,
23
- get: function () {
24
- return _types[key];
25
- }
26
- });
27
- });
@@ -1,13 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.FileInputErrorType = void 0;
7
- // FileInput 관련 타입 정의 (React FileInput.tsx와 동일)
8
- var FileInputErrorType;
9
- (function (FileInputErrorType) {
10
- FileInputErrorType["ALREADY_UPLOADED"] = "ALREADY_UPLOADED";
11
- FileInputErrorType["EXCEED_MAX_FILE_SIZE"] = "EXCEED_MAX_FILE_SIZE";
12
- FileInputErrorType["EXCEED_MAX_FILE_COUNT"] = "EXCEED_MAX_FILE_COUNT";
13
- })(FileInputErrorType || (exports.FileInputErrorType = FileInputErrorType = {}));
@@ -1,78 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.FileInput = void 0;
7
- var _fileInputModel = require("./fileInputModel");
8
- var _fileInputView = require("./fileInputView");
9
- class FileInput {
10
- constructor(options) {
11
- this.handleBrowseClick = () => {
12
- if (!this.model.isDisabled()) {
13
- this.view.getFileInputElement().click();
14
- }
15
- };
16
- this.handleFileChange = event => {
17
- const target = event.target;
18
- const selectedFiles = target.files;
19
- if (!selectedFiles || selectedFiles.length === 0) return;
20
- const {
21
- validFiles,
22
- invalidFiles
23
- } = this.model.validateFiles(Array.from(selectedFiles));
24
- const options = this.model.getOptions();
25
- if (validFiles.length > 0) {
26
- options.onChange?.(validFiles);
27
- }
28
- if (invalidFiles.length > 0) {
29
- options.onFail?.(invalidFiles);
30
- }
31
- target.value = '';
32
- };
33
- this.model = new _fileInputModel.FileInputModel(options);
34
- this.view = new _fileInputView.FileInputView(this.model.getOptions());
35
- this.setupEventListeners();
36
- if (options.container) {
37
- this.appendToContainer(options.container);
38
- }
39
- }
40
- appendToContainer(container) {
41
- let containerElement = null;
42
- if (typeof container === 'string') {
43
- containerElement = document.getElementById(container);
44
- if (!containerElement) {
45
- containerElement = document.querySelector(container);
46
- }
47
- } else {
48
- containerElement = container;
49
- }
50
- if (containerElement) {
51
- containerElement.appendChild(this.getElement());
52
- } else {
53
- console.warn(`FileInput: Container not found:`, container);
54
- }
55
- }
56
- setupEventListeners() {
57
- const fileInput = this.view.getFileInputElement();
58
- const button = this.view.getButtonElement();
59
- fileInput.addEventListener('change', this.handleFileChange);
60
- button.addEventListener('click', this.handleBrowseClick);
61
- }
62
- // Public API
63
- getElement() {
64
- return this.view.getElement();
65
- }
66
- setDisabled(disabled) {
67
- this.model.setDisabled(disabled);
68
- this.view.setButtonDisabled(disabled);
69
- }
70
- destroy() {
71
- const fileInput = this.view.getFileInputElement();
72
- const button = this.view.getButtonElement();
73
- fileInput.removeEventListener('change', this.handleFileChange);
74
- button.removeEventListener('click', this.handleBrowseClick);
75
- this.view.destroy();
76
- }
77
- }
78
- exports.FileInput = FileInput;
@@ -1,53 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.FileInputModel = void 0;
7
- var _types = require("./const/types");
8
- class FileInputModel {
9
- constructor(options) {
10
- this.options = {
11
- size: 'xs',
12
- multiple: false,
13
- buttonLabel: '파일 찾기',
14
- disabled: false,
15
- ...options
16
- };
17
- }
18
- getOptions() {
19
- return this.options;
20
- }
21
- validateFiles(fileList) {
22
- const validFiles = [];
23
- const invalidFiles = [];
24
- for (const file of fileList) {
25
- if (this.options.maxFileSize && file.size > this.options.maxFileSize) {
26
- invalidFiles.push({
27
- ...file,
28
- errorType: _types.FileInputErrorType.EXCEED_MAX_FILE_SIZE
29
- });
30
- continue;
31
- }
32
- if (this.options.maxFileCount && validFiles.length >= this.options.maxFileCount) {
33
- invalidFiles.push({
34
- ...file,
35
- errorType: _types.FileInputErrorType.EXCEED_MAX_FILE_COUNT
36
- });
37
- continue;
38
- }
39
- validFiles.push(file);
40
- }
41
- return {
42
- validFiles,
43
- invalidFiles
44
- };
45
- }
46
- setDisabled(disabled) {
47
- this.options.disabled = disabled;
48
- }
49
- isDisabled() {
50
- return this.options.disabled;
51
- }
52
- }
53
- exports.FileInputModel = FileInputModel;
@@ -1,152 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.FileInputView = void 0;
7
- var _classNames = require("./const/classNames");
8
- const HELP_ICON_SVG = `<svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor">
9
- <circle cx="12" cy="12" r="10" stroke-width="2"/>
10
- <path d="M9.09 9a3 3 0 0 1 5.83 1c0 2-3 3-3 3" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
11
- <line x1="12" y1="17" x2="12.01" y2="17" stroke-width="2" stroke-linecap="round"/>
12
- </svg>`;
13
- const SHARE_ICON_SVG = `<svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="none" class="ncua-btn__icon">
14
- <path stroke="currentColor" stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M21 12v4.2c0 1.68 0 2.52-.327 3.162a3 3 0 0 1-1.311 1.311C18.72 21 17.88 21 16.2 21H7.8c-1.68 0-2.52 0-3.162-.327a3 3 0 0 1-1.311-1.311C3 18.72 3 17.88 3 16.2V12m13-5-4-4m0 0L8 7m4-4v12"/>
15
- </svg>`;
16
- class FileInputView {
17
- constructor(options) {
18
- this.options = options;
19
- this.element = this.createElement();
20
- this.fileInputElement = this.element.querySelector('input[type="file"]');
21
- this.buttonElement = this.element.querySelector('button');
22
- }
23
- /**
24
- * 메인 DOM 요소 생성
25
- */
26
- createElement() {
27
- const container = document.createElement('div');
28
- const baseClasses = `${_classNames.FILE_INPUT_CLASS_NAMES.fileInput} ${(0, _classNames.getFileInputSizeClassName)(this.options.size)}`;
29
- const customClasses = this.options.className ? ` ${this.options.className}` : '';
30
- container.className = baseClasses + customClasses;
31
- // Hidden file input 생성
32
- container.appendChild(this.createFileInput());
33
- // Input container
34
- container.appendChild(this.createInputContainer());
35
- // Hint list
36
- if (this.options.hintItems && this.options.hintItems.length > 0) {
37
- container.appendChild(this.createHintList());
38
- }
39
- return container;
40
- }
41
- /**
42
- * Hidden file input 생성
43
- */
44
- createFileInput() {
45
- const input = document.createElement('input');
46
- input.type = 'file';
47
- input.hidden = true;
48
- input.tabIndex = -1;
49
- input.setAttribute('aria-hidden', 'true');
50
- input.classList.add('no-filestyle');
51
- if (this.options.accept) {
52
- input.accept = this.options.accept;
53
- }
54
- if (this.options.multiple) {
55
- input.multiple = true;
56
- }
57
- return input;
58
- }
59
- /**
60
- * Input container 생성
61
- */
62
- createInputContainer() {
63
- const container = document.createElement('div');
64
- container.className = _classNames.FILE_INPUT_CLASS_NAMES.inputContainer;
65
- // Label
66
- if (this.options.label) {
67
- container.appendChild(this.createLabelContainer());
68
- }
69
- // Button
70
- container.appendChild(this.createButton());
71
- // Hint text
72
- if (this.options.hintText) {
73
- container.appendChild(this.createHintText());
74
- }
75
- return container;
76
- }
77
- /**
78
- * Label container 생성
79
- */
80
- createLabelContainer() {
81
- const container = document.createElement('div');
82
- container.className = _classNames.FILE_INPUT_CLASS_NAMES.label;
83
- const label = document.createElement('label');
84
- label.className = (0, _classNames.getLabelClassName)(this.options.isRequired);
85
- label.textContent = this.options.label;
86
- container.appendChild(label);
87
- if (this.options.showHelpIcon) {
88
- container.appendChild(this.createHelpIcon());
89
- }
90
- return container;
91
- }
92
- /**
93
- * Help icon 생성
94
- */
95
- createHelpIcon() {
96
- const iconContainer = document.createElement('span');
97
- iconContainer.className = _classNames.FILE_INPUT_CLASS_NAMES.helpIcon;
98
- iconContainer.innerHTML = HELP_ICON_SVG;
99
- return iconContainer;
100
- }
101
- createButton() {
102
- const button = document.createElement('button');
103
- button.type = 'button';
104
- button.className = `ncua-btn ncua-btn--${this.options.size} ncua-btn--secondary-gray`;
105
- button.disabled = this.options.disabled;
106
- button.insertAdjacentHTML('beforeend', SHARE_ICON_SVG);
107
- const label = document.createElement('span');
108
- label.className = 'ncua-btn__label';
109
- label.textContent = this.options.buttonLabel;
110
- button.appendChild(label);
111
- return button;
112
- }
113
- /**
114
- * Hint text 생성
115
- */
116
- createHintText() {
117
- const hintText = document.createElement('div');
118
- hintText.className = (0, _classNames.getHintTextClassName)(this.options.destructive);
119
- hintText.textContent = this.options.hintText;
120
- return hintText;
121
- }
122
- /**
123
- * Hint list 생성
124
- */
125
- createHintList() {
126
- const ul = document.createElement('ul');
127
- ul.className = _classNames.FILE_INPUT_CLASS_NAMES.hintList;
128
- this.options.hintItems?.forEach(hint => {
129
- const li = document.createElement('li');
130
- li.className = _classNames.FILE_INPUT_CLASS_NAMES.hintItem;
131
- li.textContent = hint;
132
- ul.appendChild(li);
133
- });
134
- return ul;
135
- }
136
- setButtonDisabled(disabled) {
137
- this.buttonElement.disabled = disabled;
138
- }
139
- getElement() {
140
- return this.element;
141
- }
142
- getFileInputElement() {
143
- return this.fileInputElement;
144
- }
145
- getButtonElement() {
146
- return this.buttonElement;
147
- }
148
- destroy() {
149
- // View 리소스 정리 - 이벤트 리스너는 FileInput에서 관리
150
- }
151
- }
152
- exports.FileInputView = FileInputView;
@@ -1,44 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- var _exportNames = {
7
- FileInput: true
8
- };
9
- Object.defineProperty(exports, "FileInput", {
10
- enumerable: true,
11
- get: function () {
12
- return _fileInput.FileInput;
13
- }
14
- });
15
- var _fileInput = require("./fileInput");
16
- var _classNames = require("./const/classNames");
17
- Object.keys(_classNames).forEach(function (key) {
18
- if (key === "default" || key === "__esModule") return;
19
- if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
20
- if (key in exports && exports[key] === _classNames[key]) return;
21
- Object.defineProperty(exports, key, {
22
- enumerable: true,
23
- get: function () {
24
- return _classNames[key];
25
- }
26
- });
27
- });
28
- var _types = require("./const/types");
29
- Object.keys(_types).forEach(function (key) {
30
- if (key === "default" || key === "__esModule") return;
31
- if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
32
- if (key in exports && exports[key] === _types[key]) return;
33
- Object.defineProperty(exports, key, {
34
- enumerable: true,
35
- get: function () {
36
- return _types[key];
37
- }
38
- });
39
- });
40
- // 전역 등록 (추후 index.ts와 개별동작 할 수 있게끔 대비)
41
- if (typeof window !== 'undefined') {
42
- window.ncua = window.ncua || {};
43
- window.ncua.FileInput = _fileInput.FileInput;
44
- }
@@ -1,184 +0,0 @@
1
- "use strict";
2
-
3
- Object.defineProperty(exports, "__esModule", {
4
- value: true
5
- });
6
- exports.ImageFileInput = void 0;
7
- var _ImageFileInputModel = require("./ImageFileInputModel");
8
- var _ImageFileInputView = require("./ImageFileInputView");
9
- class ImageFileInput {
10
- constructor(options) {
11
- /**
12
- * 파일 선택 버튼 클릭 핸들러
13
- */
14
- this.handleBrowseClick = () => {
15
- if (!this.model.isDisabled()) {
16
- this.view.getFileInputElement().click();
17
- }
18
- };
19
- /**
20
- * 파일 변경 핸들러
21
- */
22
- this.handleFileChange = event => {
23
- const target = event.target;
24
- const selectedFiles = target.files;
25
- if (!selectedFiles || selectedFiles.length === 0) return;
26
- const {
27
- validFiles,
28
- invalidFiles
29
- } = this.model.validateFiles(Array.from(selectedFiles));
30
- const options = this.model.getOptions();
31
- // 유효한 파일에 대한 콜백 호출
32
- if (validFiles.length > 0) {
33
- // 파일 추가 (maxFileCount가 1이면 교체)
34
- this.model.addFiles(validFiles);
35
- // 콜백을 통해 선택된 파일 정보 전달
36
- if (this.model.isControlled()) {
37
- options.onChange?.(this.model.getFiles());
38
- } else {
39
- options.onFileSelect?.(this.model.getFiles());
40
- }
41
- // 자동 렌더링 (uncontrolled mode)
42
- if (!this.model.isControlled()) {
43
- this.render();
44
- }
45
- }
46
- // 유효하지 않은 파일 처리
47
- if (invalidFiles.length > 0) {
48
- options.onFail?.(invalidFiles);
49
- }
50
- // Reset input value to allow re-selecting the same file
51
- target.value = '';
52
- };
53
- /**
54
- * 파일 제거 핸들러
55
- */
56
- this.handleRemoveFile = index => {
57
- this.model.removeFile(index);
58
- this.notifyChange();
59
- };
60
- this.model = new _ImageFileInputModel.ImageFileInputModel(options);
61
- this.view = new _ImageFileInputView.ImageFileInputView(this.model.getOptions(), this.model);
62
- this.setupEventListeners();
63
- // 초기 렌더링 (빈 슬롯 버튼 생성)
64
- this.render();
65
- // 컨테이너가 지정되면 자동으로 추가
66
- if (options.container) {
67
- this.appendToContainer(options.container);
68
- }
69
- }
70
- /**
71
- * 컨테이너에 요소 추가
72
- */
73
- appendToContainer(container) {
74
- let containerElement = null;
75
- if (typeof container === 'string') {
76
- // ID로 찾기 (# 없이)
77
- containerElement = document.getElementById(container);
78
- // ID로 못 찾으면 CSS 셀렉터로 찾기
79
- if (!containerElement) {
80
- containerElement = document.querySelector(container);
81
- }
82
- } else {
83
- containerElement = container;
84
- }
85
- if (containerElement) {
86
- containerElement.appendChild(this.getElement());
87
- } else {
88
- console.warn(`ImageFileInput: Container not found:`, container);
89
- }
90
- }
91
- /**
92
- * 이벤트 리스너 설정
93
- */
94
- setupEventListeners() {
95
- const fileInput = this.view.getFileInputElement();
96
- const button = this.view.getButtonElement();
97
- // 파일 선택 이벤트
98
- fileInput.addEventListener('change', this.handleFileChange);
99
- // 버튼 클릭 이벤트
100
- button.addEventListener('click', this.handleBrowseClick);
101
- }
102
- /**
103
- * 변경 알림 (onChange/onFileSelect 호출)
104
- */
105
- notifyChange() {
106
- const options = this.model.getOptions();
107
- const files = this.model.getFiles();
108
- if (this.model.isControlled()) {
109
- // Controlled mode: onChange 호출
110
- options.onChange?.(files);
111
- this.render();
112
- } else {
113
- // Uncontrolled mode: onFileSelect 호출 및 렌더링
114
- options.onFileSelect?.(files);
115
- this.render();
116
- }
117
- }
118
- /**
119
- * 뷰 렌더링 (내부용)
120
- */
121
- render() {
122
- const files = this.model.getFiles();
123
- this.view.renderImagePreviews(files, this.handleRemoveFile, this.handleBrowseClick);
124
- }
125
- /**
126
- * 이미지 프리뷰를 수동으로 렌더링
127
- * 사용자가 콜백에서 직접 호출하여 프리뷰를 렌더링할 수 있음
128
- */
129
- renderImagePreviews() {
130
- this.render();
131
- }
132
- /**
133
- * DOM 요소 반환
134
- */
135
- getElement() {
136
- return this.view.getElement();
137
- }
138
- /**
139
- * 현재 파일 목록 반환
140
- */
141
- getFiles() {
142
- return this.model.getFiles();
143
- }
144
- /**
145
- * 초기 업로드된 파일 목록 설정
146
- */
147
- setFiles(uploadedFiles) {
148
- this.model.setFiles(uploadedFiles);
149
- const options = this.model.getOptions();
150
- if (this.model.isControlled()) {
151
- const allFiles = this.model.getFiles();
152
- options.onChange?.(allFiles);
153
- } else {
154
- this.render();
155
- }
156
- }
157
- /**
158
- * 모든 파일 제거
159
- */
160
- clearFiles() {
161
- this.model.clearFiles();
162
- this.notifyChange();
163
- }
164
- /**
165
- * disabled 상태 설정
166
- */
167
- setDisabled(disabled) {
168
- this.model.setDisabled(disabled);
169
- this.view.setButtonDisabled(disabled);
170
- }
171
- /**
172
- * 리소스 정리
173
- */
174
- destroy() {
175
- // 이벤트 리스너 제거
176
- const fileInput = this.view.getFileInputElement();
177
- const button = this.view.getButtonElement();
178
- fileInput.removeEventListener('change', this.handleFileChange);
179
- button.removeEventListener('click', this.handleBrowseClick);
180
- // View 리소스 정리
181
- this.view.destroy();
182
- }
183
- }
184
- exports.ImageFileInput = ImageFileInput;