@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,180 +0,0 @@
1
- import { ImageFileInputModel } from './ImageFileInputModel';
2
- import { ImageFileInputView } from './ImageFileInputView';
3
- export class ImageFileInput {
4
- constructor(options) {
5
- /**
6
- * 파일 선택 버튼 클릭 핸들러
7
- */
8
- this.handleBrowseClick = () => {
9
- if (!this.model.isDisabled()) {
10
- this.view.getFileInputElement().click();
11
- }
12
- };
13
- /**
14
- * 파일 변경 핸들러
15
- */
16
- this.handleFileChange = (event) => {
17
- const target = event.target;
18
- const selectedFiles = target.files;
19
- if (!selectedFiles || selectedFiles.length === 0)
20
- return;
21
- const { validFiles, invalidFiles } = this.model.validateFiles(Array.from(selectedFiles));
22
- const options = this.model.getOptions();
23
- // 유효한 파일에 대한 콜백 호출
24
- if (validFiles.length > 0) {
25
- // 파일 추가 (maxFileCount가 1이면 교체)
26
- this.model.addFiles(validFiles);
27
- // 콜백을 통해 선택된 파일 정보 전달
28
- if (this.model.isControlled()) {
29
- options.onChange?.(this.model.getFiles());
30
- }
31
- else {
32
- options.onFileSelect?.(this.model.getFiles());
33
- }
34
- // 자동 렌더링 (uncontrolled mode)
35
- if (!this.model.isControlled()) {
36
- this.render();
37
- }
38
- }
39
- // 유효하지 않은 파일 처리
40
- if (invalidFiles.length > 0) {
41
- options.onFail?.(invalidFiles);
42
- }
43
- // Reset input value to allow re-selecting the same file
44
- target.value = '';
45
- };
46
- /**
47
- * 파일 제거 핸들러
48
- */
49
- this.handleRemoveFile = (index) => {
50
- this.model.removeFile(index);
51
- this.notifyChange();
52
- };
53
- this.model = new ImageFileInputModel(options);
54
- this.view = new ImageFileInputView(this.model.getOptions(), this.model);
55
- this.setupEventListeners();
56
- // 초기 렌더링 (빈 슬롯 버튼 생성)
57
- this.render();
58
- // 컨테이너가 지정되면 자동으로 추가
59
- if (options.container) {
60
- this.appendToContainer(options.container);
61
- }
62
- }
63
- /**
64
- * 컨테이너에 요소 추가
65
- */
66
- appendToContainer(container) {
67
- let containerElement = null;
68
- if (typeof container === 'string') {
69
- // ID로 찾기 (# 없이)
70
- containerElement = document.getElementById(container);
71
- // ID로 못 찾으면 CSS 셀렉터로 찾기
72
- if (!containerElement) {
73
- containerElement = document.querySelector(container);
74
- }
75
- }
76
- else {
77
- containerElement = container;
78
- }
79
- if (containerElement) {
80
- containerElement.appendChild(this.getElement());
81
- }
82
- else {
83
- console.warn(`ImageFileInput: Container not found:`, container);
84
- }
85
- }
86
- /**
87
- * 이벤트 리스너 설정
88
- */
89
- setupEventListeners() {
90
- const fileInput = this.view.getFileInputElement();
91
- const button = this.view.getButtonElement();
92
- // 파일 선택 이벤트
93
- fileInput.addEventListener('change', this.handleFileChange);
94
- // 버튼 클릭 이벤트
95
- button.addEventListener('click', this.handleBrowseClick);
96
- }
97
- /**
98
- * 변경 알림 (onChange/onFileSelect 호출)
99
- */
100
- notifyChange() {
101
- const options = this.model.getOptions();
102
- const files = this.model.getFiles();
103
- if (this.model.isControlled()) {
104
- // Controlled mode: onChange 호출
105
- options.onChange?.(files);
106
- this.render();
107
- }
108
- else {
109
- // Uncontrolled mode: onFileSelect 호출 및 렌더링
110
- options.onFileSelect?.(files);
111
- this.render();
112
- }
113
- }
114
- /**
115
- * 뷰 렌더링 (내부용)
116
- */
117
- render() {
118
- const files = this.model.getFiles();
119
- this.view.renderImagePreviews(files, this.handleRemoveFile, this.handleBrowseClick);
120
- }
121
- /**
122
- * 이미지 프리뷰를 수동으로 렌더링
123
- * 사용자가 콜백에서 직접 호출하여 프리뷰를 렌더링할 수 있음
124
- */
125
- renderImagePreviews() {
126
- this.render();
127
- }
128
- /**
129
- * DOM 요소 반환
130
- */
131
- getElement() {
132
- return this.view.getElement();
133
- }
134
- /**
135
- * 현재 파일 목록 반환
136
- */
137
- getFiles() {
138
- return this.model.getFiles();
139
- }
140
- /**
141
- * 초기 업로드된 파일 목록 설정
142
- */
143
- setFiles(uploadedFiles) {
144
- this.model.setFiles(uploadedFiles);
145
- const options = this.model.getOptions();
146
- if (this.model.isControlled()) {
147
- const allFiles = this.model.getFiles();
148
- options.onChange?.(allFiles);
149
- }
150
- else {
151
- this.render();
152
- }
153
- }
154
- /**
155
- * 모든 파일 제거
156
- */
157
- clearFiles() {
158
- this.model.clearFiles();
159
- this.notifyChange();
160
- }
161
- /**
162
- * disabled 상태 설정
163
- */
164
- setDisabled(disabled) {
165
- this.model.setDisabled(disabled);
166
- this.view.setButtonDisabled(disabled);
167
- }
168
- /**
169
- * 리소스 정리
170
- */
171
- destroy() {
172
- // 이벤트 리스너 제거
173
- const fileInput = this.view.getFileInputElement();
174
- const button = this.view.getButtonElement();
175
- fileInput.removeEventListener('change', this.handleFileChange);
176
- button.removeEventListener('click', this.handleBrowseClick);
177
- // View 리소스 정리
178
- this.view.destroy();
179
- }
180
- }
@@ -1,73 +0,0 @@
1
- import { BaseImageFileInputOptions, InvalidFile, RequiredImageFileInputProps, UploadedFile } from './const/types';
2
- export declare class ImageFileInputModel {
3
- private options;
4
- private internalFiles;
5
- private initialFiles;
6
- private newlyAddedFiles;
7
- private deletedInitialFiles;
8
- constructor(options: BaseImageFileInputOptions);
9
- /**
10
- * 옵션 반환
11
- */
12
- getOptions(): RequiredImageFileInputProps;
13
- /**
14
- * 현재 파일 목록 반환 (초기 파일 + 새로 추가된 파일, 삭제 표시된 파일 제외)
15
- */
16
- getFiles(): File[];
17
- /**
18
- * 파일명에서 MIME 타입 추론
19
- */
20
- private getMimeTypeFromFileName;
21
- /**
22
- * 초기 업로드된 파일 목록 설정 (UploadedFile[] 타입만 허용)
23
- */
24
- setFiles(uploadedFiles: UploadedFile[]): void;
25
- /**
26
- * 파일 추가
27
- */
28
- addFiles(files: File[]): void;
29
- /**
30
- * 특정 인덱스의 파일 제거
31
- */
32
- removeFile(index: number): void;
33
- /**
34
- * 모든 파일 제거
35
- */
36
- clearFiles(): void;
37
- /**
38
- * 파일 유효성 검사
39
- */
40
- validateFiles(fileList: File[]): {
41
- validFiles: File[];
42
- invalidFiles: InvalidFile[];
43
- };
44
- /**
45
- * disabled 상태 설정
46
- */
47
- setDisabled(disabled: boolean): void;
48
- /**
49
- * disabled 상태 반환
50
- */
51
- isDisabled(): boolean;
52
- /**
53
- * Controlled mode 여부 확인
54
- * onChange가 있으면 Controlled mode로 판단
55
- */
56
- isControlled(): boolean;
57
- /**
58
- * 파일이 초기 파일인지 확인 (UploadedFile로 설정된 기존 파일)
59
- */
60
- isInitialFile(file: File): boolean;
61
- /**
62
- * 파일이 새로 추가된 파일인지 확인
63
- */
64
- isNewlyAddedFile(file: File): boolean;
65
- /**
66
- * 파일이 삭제 표시된 초기 파일인지 확인
67
- */
68
- isDeletedInitialFile(file: File): boolean;
69
- /**
70
- * 초기 파일의 이미지 URL 반환
71
- */
72
- getInitialFileImageUrl(file: File): string | undefined;
73
- }
@@ -1,214 +0,0 @@
1
- import { ImageFileInputErrorType, } from './const/types';
2
- export class ImageFileInputModel {
3
- constructor(options) {
4
- this.internalFiles = [];
5
- this.initialFiles = []; // 초기 파일 목록 (렌더링 시점의 파일)
6
- this.newlyAddedFiles = new Set(); // 새로 추가된 파일 추적
7
- this.deletedInitialFiles = new Set(); // 삭제 표시된 초기 파일들 (파일명으로 추적)
8
- this.options = {
9
- size: 'sm',
10
- multiple: false,
11
- buttonLabel: '파일 찾기',
12
- imagePreviewTooltipLabel: '이미지 업로드',
13
- disabled: false,
14
- ...options,
15
- };
16
- // 초기 파일 설정
17
- if (this.options.value && this.options.value.length > 0) {
18
- this.internalFiles = [...this.options.value];
19
- // value로 들어온 File[]은 새로 추가된 파일로 처리 (initialFiles는 별도로 setFiles(UploadedFile[])로 설정)
20
- }
21
- }
22
- /**
23
- * 옵션 반환
24
- */
25
- getOptions() {
26
- return this.options;
27
- }
28
- /**
29
- * 현재 파일 목록 반환 (초기 파일 + 새로 추가된 파일, 삭제 표시된 파일 제외)
30
- */
31
- getFiles() {
32
- const newFiles = this.options.value !== undefined ? this.options.value : this.internalFiles;
33
- // UploadedFile을 File 객체로 변환 (삭제 표시되지 않은 것만)
34
- const initialFilesAsFiles = this.initialFiles
35
- .filter((uploadedFile) => !this.deletedInitialFiles.has(uploadedFile.fileName))
36
- .map((uploadedFile) => {
37
- // UploadedFile을 File 객체로 변환 (빈 데이터지만 이름과 타입 정보 유지)
38
- const mimeType = this.getMimeTypeFromFileName(uploadedFile.fileName);
39
- return new File([], uploadedFile.fileName, { type: mimeType });
40
- });
41
- // 초기 파일 + 새로 추가된 파일 합치기
42
- return [...initialFilesAsFiles, ...newFiles];
43
- }
44
- /**
45
- * 파일명에서 MIME 타입 추론
46
- */
47
- getMimeTypeFromFileName(fileName) {
48
- const extension = fileName.split('.').pop()?.toLowerCase();
49
- const mimeTypes = {
50
- jpg: 'image/jpeg',
51
- jpeg: 'image/jpeg',
52
- png: 'image/png',
53
- gif: 'image/gif',
54
- webp: 'image/webp',
55
- svg: 'image/svg+xml',
56
- bmp: 'image/bmp',
57
- };
58
- return mimeTypes[extension || ''] || 'application/octet-stream';
59
- }
60
- /**
61
- * 초기 업로드된 파일 목록 설정 (UploadedFile[] 타입만 허용)
62
- */
63
- setFiles(uploadedFiles) {
64
- this.initialFiles = [...uploadedFiles];
65
- }
66
- /**
67
- * 파일 추가
68
- */
69
- addFiles(files) {
70
- // maxFileCount가 1이면 기존 파일 교체
71
- if (this.options.maxFileCount === 1) {
72
- // 기존 초기 파일들을 삭제 표시
73
- this.initialFiles.forEach((uploadedFile) => {
74
- this.deletedInitialFiles.add(uploadedFile.fileName);
75
- });
76
- // 새로 추가된 파일로 표시
77
- files.forEach((file) => this.newlyAddedFiles.add(file));
78
- const isControlled = this.options.value !== undefined;
79
- if (isControlled) {
80
- this.options.value = files;
81
- }
82
- else {
83
- this.internalFiles = files;
84
- }
85
- return;
86
- }
87
- // getFiles()를 사용하지 않고 새로 추가된 파일만 관리
88
- const currentNewFiles = this.options.value !== undefined ? this.options.value : this.internalFiles;
89
- const newFiles = [...currentNewFiles, ...files];
90
- // 새로 추가된 파일로 표시
91
- files.forEach((file) => this.newlyAddedFiles.add(file));
92
- const isControlled = this.options.value !== undefined;
93
- if (isControlled) {
94
- this.options.value = newFiles;
95
- }
96
- else {
97
- this.internalFiles = newFiles;
98
- }
99
- }
100
- /**
101
- * 특정 인덱스의 파일 제거
102
- */
103
- removeFile(index) {
104
- const visibleFiles = this.getFiles(); // 현재 보이는 파일들
105
- const fileToRemove = visibleFiles[index];
106
- if (!fileToRemove)
107
- return;
108
- // 초기 파일인지 확인
109
- const isInitialFile = this.isInitialFile(fileToRemove);
110
- if (isInitialFile) {
111
- // 초기 파일: 삭제 표시만 함 (실제 제거하지 않음)
112
- this.deletedInitialFiles.add(fileToRemove.name);
113
- }
114
- else {
115
- // 새로 추가된 파일: 실제 제거
116
- const currentFiles = this.options.value !== undefined ? this.options.value : this.internalFiles;
117
- const newFiles = currentFiles.filter((file) => file !== fileToRemove);
118
- // newlyAddedFiles Set에서도 제거
119
- this.newlyAddedFiles.delete(fileToRemove);
120
- const isControlled = this.options.value !== undefined;
121
- if (isControlled) {
122
- this.options.value = newFiles;
123
- }
124
- else {
125
- this.internalFiles = newFiles;
126
- }
127
- }
128
- }
129
- /**
130
- * 모든 파일 제거
131
- */
132
- clearFiles() {
133
- // 초기 파일들은 모두 삭제 표시
134
- this.initialFiles.forEach((uploadedFile) => {
135
- this.deletedInitialFiles.add(uploadedFile.fileName);
136
- });
137
- this.newlyAddedFiles.clear();
138
- const isControlled = this.options.value !== undefined;
139
- if (isControlled) {
140
- this.options.value = [];
141
- }
142
- else {
143
- this.internalFiles = [];
144
- }
145
- }
146
- /**
147
- * 파일 유효성 검사
148
- */
149
- validateFiles(fileList) {
150
- const validFiles = [];
151
- const invalidFiles = [];
152
- const currentFiles = this.getFiles();
153
- for (const file of fileList) {
154
- // 파일 크기 체크
155
- if (this.options.maxFileSize && file.size > this.options.maxFileSize) {
156
- invalidFiles.push({ ...file, errorType: ImageFileInputErrorType.EXCEED_MAX_FILE_SIZE });
157
- continue;
158
- }
159
- // 파일 개수 체크 (maxFileCount가 1이면 교체 가능하므로 체크하지 않음)
160
- if (this.options.maxFileCount &&
161
- this.options.maxFileCount !== 1 &&
162
- currentFiles.length + validFiles.length >= this.options.maxFileCount) {
163
- invalidFiles.push({ ...file, errorType: ImageFileInputErrorType.EXCEED_MAX_FILE_COUNT });
164
- continue;
165
- }
166
- validFiles.push(file);
167
- }
168
- return { validFiles, invalidFiles };
169
- }
170
- /**
171
- * disabled 상태 설정
172
- */
173
- setDisabled(disabled) {
174
- this.options.disabled = disabled;
175
- }
176
- /**
177
- * disabled 상태 반환
178
- */
179
- isDisabled() {
180
- return this.options.disabled;
181
- }
182
- /**
183
- * Controlled mode 여부 확인
184
- * onChange가 있으면 Controlled mode로 판단
185
- */
186
- isControlled() {
187
- return this.options.onChange !== undefined;
188
- }
189
- /**
190
- * 파일이 초기 파일인지 확인 (UploadedFile로 설정된 기존 파일)
191
- */
192
- isInitialFile(file) {
193
- return this.initialFiles.some((uploadedFile) => uploadedFile.fileName === file.name);
194
- }
195
- /**
196
- * 파일이 새로 추가된 파일인지 확인
197
- */
198
- isNewlyAddedFile(file) {
199
- return this.newlyAddedFiles.has(file);
200
- }
201
- /**
202
- * 파일이 삭제 표시된 초기 파일인지 확인
203
- */
204
- isDeletedInitialFile(file) {
205
- return this.deletedInitialFiles.has(file.name);
206
- }
207
- /**
208
- * 초기 파일의 이미지 URL 반환
209
- */
210
- getInitialFileImageUrl(file) {
211
- const uploadedFile = this.initialFiles.find((f) => f.fileName === file.name);
212
- return uploadedFile?.fileImageUrl;
213
- }
214
- }
@@ -1,79 +0,0 @@
1
- import { RequiredImageFileInputProps } from './const/types';
2
- import { ImageFileInputModel } from './ImageFileInputModel';
3
- export declare class ImageFileInputView {
4
- private element;
5
- private fileInputElement;
6
- private buttonElement;
7
- private previewsContainer;
8
- private options;
9
- private model;
10
- private renderedFiles;
11
- private previewUrls;
12
- constructor(options: RequiredImageFileInputProps, model: ImageFileInputModel);
13
- /**
14
- * 메인 DOM 요소 생성
15
- */
16
- private createElement;
17
- /**
18
- * Hidden file input 생성
19
- */
20
- private createFileInput;
21
- /**
22
- * Input container 생성
23
- */
24
- private createInputContainer;
25
- /**
26
- * Label container 생성
27
- */
28
- private createLabelContainer;
29
- /**
30
- * Help icon 생성
31
- */
32
- private createHelpIcon;
33
- /**
34
- * Button 생성 (파일 찾기)
35
- */
36
- private createButton;
37
- /**
38
- * Share icon (업로드 아이콘) 생성
39
- */
40
- private createShareIcon;
41
- /**
42
- * Trash icon (삭제 아이콘) 생성
43
- */
44
- private createTrashIcon;
45
- /**
46
- * Hint text 생성
47
- */
48
- private createHintText;
49
- /**
50
- * Hint list 생성
51
- * Note: 힌트 리스트는 컴포넌트 size와 관계없이 항상 xs 사이즈로 고정됨
52
- */
53
- private createHintList;
54
- /**
55
- * 이미지 프리뷰 렌더링
56
- */
57
- renderImagePreviews(files: File[], onRemove: (index: number) => void, onBrowseClick: () => void): void;
58
- /**
59
- * 이미지 프리뷰 생성
60
- */
61
- private createImagePreview;
62
- /**
63
- * 빈 슬롯 생성 (파일 찾기 버튼)
64
- */
65
- private createEmptySlot;
66
- /**
67
- * Tooltip 생성
68
- */
69
- private createTooltip;
70
- /**
71
- * 기존 프리뷰 정리
72
- */
73
- private cleanupPreviews;
74
- setButtonDisabled(disabled: boolean): void;
75
- getElement(): HTMLDivElement;
76
- getFileInputElement(): HTMLInputElement;
77
- getButtonElement(): HTMLButtonElement;
78
- destroy(): void;
79
- }