@sellmate/design-system 1.0.78 → 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (483) hide show
  1. package/dist/cjs/component.table-CMqGfEui.js +66 -0
  2. package/dist/cjs/design-system.cjs.js +2 -2
  3. package/dist/cjs/{index--F2wGuAi.js → index-Cw-78mnC.js} +1 -1
  4. package/dist/cjs/index.cjs.js +5 -5
  5. package/dist/cjs/loader.cjs.js +2 -2
  6. package/dist/cjs/{resolveColor-LhfOKtTZ.js → resolveColor-B0hzQNLG.js} +2 -2
  7. package/dist/cjs/sd-action-modal.cjs.entry.js +3 -3
  8. package/dist/cjs/sd-badge.cjs.entry.js +2 -3
  9. package/dist/cjs/sd-barcode-input.cjs.entry.js +3 -3
  10. package/dist/cjs/{sd-button-v2.config-CnqCQQMi.js → sd-button.config-DH08UNfl.js} +114 -28
  11. package/dist/cjs/{sd-button-v2_2.cjs.entry.js → sd-button_2.cjs.entry.js} +102 -85
  12. package/dist/cjs/sd-calendar.cjs.entry.js +15 -15
  13. package/dist/cjs/sd-card.cjs.entry.js +2 -2
  14. package/dist/cjs/sd-checkbox.cjs.entry.js +4 -4
  15. package/dist/cjs/sd-chip.cjs.entry.js +4 -4
  16. package/dist/cjs/sd-circle-progress.cjs.entry.js +3 -3
  17. package/dist/cjs/sd-confirm-modal_2.cjs.entry.js +19 -11
  18. package/dist/cjs/sd-date-box.cjs.entry.js +9 -4
  19. package/dist/cjs/{sd-date-picker-calendar.cjs.entry.js → sd-date-picker-calendar_2.cjs.entry.js} +59 -6
  20. package/dist/cjs/{sd-date-picker.config-CRgCT5dn.js → sd-date-picker.config-CjvrFpYK.js} +1 -2
  21. package/dist/cjs/sd-date-picker_7.cjs.entry.js +1235 -0
  22. package/dist/cjs/sd-date-range-picker-calendar.cjs.entry.js +14 -14
  23. package/dist/cjs/sd-dropdown-button.cjs.entry.js +32 -27
  24. package/dist/cjs/{sd-button_4.cjs.entry.js → sd-field_3.cjs.entry.js} +47 -102
  25. package/dist/cjs/sd-form.cjs.entry.js +5 -5
  26. package/dist/cjs/sd-ghost-button.cjs.entry.js +12 -10
  27. package/dist/cjs/sd-guide.cjs.entry.js +11 -11
  28. package/dist/cjs/sd-key-value-table.cjs.entry.js +230 -0
  29. package/dist/cjs/sd-linear-progress.cjs.entry.js +3 -3
  30. package/dist/cjs/sd-loading-container.cjs.entry.js +3 -3
  31. package/dist/cjs/sd-modal-container.cjs.entry.js +3 -3
  32. package/dist/cjs/{sd-pagination_5.cjs.entry.js → sd-pagination_4.cjs.entry.js} +136 -325
  33. package/dist/cjs/sd-popover.cjs.entry.js +18 -11
  34. package/dist/cjs/sd-popup.cjs.entry.js +112 -0
  35. package/dist/cjs/sd-portal.cjs.entry.js +3 -3
  36. package/dist/cjs/sd-radio-button.cjs.entry.js +9 -6
  37. package/dist/cjs/sd-radio.cjs.entry.js +2 -2
  38. package/dist/cjs/sd-select-list-item_2.cjs.entry.js +159 -0
  39. package/dist/cjs/sd-select.config-B19ptCT2.js +178 -0
  40. package/dist/cjs/{sd-select-list-item_4.cjs.entry.js → sd-select_3.cjs.entry.js} +296 -323
  41. package/dist/cjs/sd-switch.cjs.entry.js +2 -2
  42. package/dist/cjs/sd-table.cjs.entry.js +188 -48
  43. package/dist/cjs/sd-table.config-BIpldZtw.js +76 -0
  44. package/dist/cjs/sd-tabs.cjs.entry.js +8 -3
  45. package/dist/cjs/sd-tag.cjs.entry.js +56 -21
  46. package/dist/cjs/sd-td.cjs.entry.js +52 -10
  47. package/dist/cjs/sd-text-link.cjs.entry.js +13 -5
  48. package/dist/cjs/sd-toast-container.cjs.entry.js +5 -5
  49. package/dist/cjs/sd-toast.cjs.entry.js +35 -5
  50. package/dist/cjs/sd-toggle.cjs.entry.js +2 -2
  51. package/dist/cjs/{system-DpTN1vBC.js → system-VmZRYp6V.js} +4 -2
  52. package/dist/cjs/{tooltipArrow-D1-wcNm1.js → tooltipArrow-BjSFKIUq.js} +1 -1
  53. package/dist/collection/collection-manifest.json +4 -3
  54. package/dist/collection/components/assets/CheckboxCheck.js +5 -0
  55. package/dist/collection/components/assets/CheckboxIndeterminate.js +5 -0
  56. package/dist/collection/components/assets/index.js +4 -0
  57. package/dist/collection/components/sd-action-modal/sd-action-modal.css +1 -1
  58. package/dist/collection/components/sd-action-modal/sd-action-modal.js +7 -7
  59. package/dist/collection/components/sd-badge/sd-badge.config.js +10 -1
  60. package/dist/collection/components/sd-badge/sd-badge.js +1 -22
  61. package/dist/collection/components/sd-barcode-input/sd-barcode-input.js +4 -4
  62. package/dist/collection/components/{sd-button-v2/sd-button-v2.config.js → sd-button/sd-button.config.js} +1 -1
  63. package/dist/collection/components/sd-button/sd-button.css +47 -93
  64. package/dist/collection/components/sd-button/sd-button.js +100 -173
  65. package/dist/collection/components/sd-calendar/sd-calendar.js +14 -14
  66. package/dist/collection/components/sd-card/sd-card.js +1 -1
  67. package/dist/collection/components/sd-checkbox/sd-checkbox.js +3 -3
  68. package/dist/collection/components/sd-chip/sd-chip.js +4 -4
  69. package/dist/collection/components/sd-circle-progress/sd-circle-progress.js +1 -1
  70. package/dist/collection/components/sd-confirm-modal/sd-confirm-modal.js +13 -8
  71. package/dist/collection/components/sd-date-box/sd-date-box.js +8 -3
  72. package/dist/collection/components/sd-date-picker/sd-date-picker-calendar/sd-date-picker-calendar.js +4 -4
  73. package/dist/collection/components/sd-date-picker/sd-date-picker-trigger/sd-date-picker-trigger.css +1 -1
  74. package/dist/collection/components/sd-date-picker/sd-date-picker-trigger/sd-date-picker-trigger.js +13 -6
  75. package/dist/collection/components/sd-date-picker/sd-date-picker.js +4 -4
  76. package/dist/collection/components/sd-date-range-picker/sd-date-range-picker-calendar/sd-date-range-picker-calendar.js +12 -12
  77. package/dist/collection/components/sd-date-range-picker/sd-date-range-picker.js +5 -5
  78. package/dist/collection/components/sd-dropdown-button/sd-dropdown-button.config.js +7 -3
  79. package/dist/collection/components/sd-dropdown-button/sd-dropdown-button.js +13 -11
  80. package/dist/collection/components/sd-field/sd-field.css +6 -2
  81. package/dist/collection/components/sd-field/sd-field.js +48 -22
  82. package/dist/collection/components/sd-file-picker/sd-file-picker.js +10 -5
  83. package/dist/collection/components/sd-floating-portal/sd-floating-portal.css +1 -3
  84. package/dist/collection/components/sd-floating-portal/sd-floating-portal.js +6 -6
  85. package/dist/collection/components/sd-form/sd-form.js +4 -4
  86. package/dist/collection/components/sd-ghost-button/sd-ghost-button.js +12 -10
  87. package/dist/collection/components/sd-guide/sd-guide.css +8 -172
  88. package/dist/collection/components/sd-guide/sd-guide.js +8 -6
  89. package/dist/collection/components/sd-icon/sd-icon.js +4 -4
  90. package/dist/collection/components/sd-input/sd-input.css +4 -2
  91. package/dist/collection/components/sd-input/sd-input.js +6 -6
  92. package/dist/collection/components/sd-key-value-table/sd-key-value-table.config.js +36 -0
  93. package/dist/collection/components/sd-key-value-table/sd-key-value-table.css +119 -0
  94. package/dist/collection/components/sd-key-value-table/sd-key-value-table.js +301 -0
  95. package/dist/collection/components/sd-linear-progress/sd-linear-progress.js +1 -1
  96. package/dist/collection/components/sd-loading-container/sd-loading-container.js +2 -2
  97. package/dist/collection/components/sd-loading-modal/sd-loading-modal.js +6 -3
  98. package/dist/collection/components/sd-modal-container/sd-modal-container.js +2 -2
  99. package/dist/collection/components/sd-number-input/sd-number-input.css +7 -0
  100. package/dist/collection/components/sd-number-input/sd-number-input.js +8 -5
  101. package/dist/collection/components/sd-pagination/sd-pagination.js +3 -3
  102. package/dist/collection/components/sd-popover/sd-popover.js +129 -36
  103. package/dist/collection/components/sd-popup/sd-popup.config.js +34 -0
  104. package/dist/collection/components/sd-popup/sd-popup.css +73 -0
  105. package/dist/collection/components/sd-popup/sd-popup.js +163 -0
  106. package/dist/collection/components/sd-portal/sd-portal.js +2 -2
  107. package/dist/collection/components/sd-radio/sd-radio.js +1 -1
  108. package/dist/collection/components/sd-radio-button/sd-radio-button.js +8 -5
  109. package/dist/collection/components/sd-radio-group/sd-radio-group.js +2 -2
  110. package/dist/collection/components/sd-select/sd-select-list-item/sd-select-list-item.js +7 -3
  111. package/dist/collection/components/sd-select/sd-select-list-item-search/sd-select-list-item-search.css +4 -4
  112. package/dist/collection/components/sd-select/sd-select-list-item-search/sd-select-list-item-search.js +7 -7
  113. package/dist/collection/components/sd-select/sd-select-listbox/sd-select-listbox.js +8 -8
  114. package/dist/collection/components/sd-select/sd-select-trigger/sd-select-trigger.js +9 -4
  115. package/dist/collection/components/sd-select/sd-select.js +6 -6
  116. package/dist/collection/components/sd-switch/sd-switch.js +1 -1
  117. package/dist/collection/components/sd-table/sd-table.config.js +6 -2
  118. package/dist/collection/components/sd-table/sd-table.css +30 -11
  119. package/dist/collection/components/sd-table/sd-table.js +233 -50
  120. package/dist/collection/components/sd-table/sd-table.stories.helpers.js +2 -3
  121. package/dist/collection/components/sd-table/sd-tbody/sd-tbody.js +5 -5
  122. package/dist/collection/components/sd-table/sd-td/sd-td.js +111 -9
  123. package/dist/collection/components/sd-table/sd-thead/sd-thead.js +30 -16
  124. package/dist/collection/components/sd-table/sd-tr/sd-tr.css +24 -1
  125. package/dist/collection/components/sd-table/sd-tr/sd-tr.js +116 -19
  126. package/dist/collection/components/sd-tabs/sd-tabs.js +7 -2
  127. package/dist/collection/components/sd-tag/sd-tag.config.js +43 -11
  128. package/dist/collection/components/sd-tag/sd-tag.js +13 -7
  129. package/dist/collection/components/sd-text-link/sd-text-link.css +1 -0
  130. package/dist/collection/components/sd-text-link/sd-text-link.js +10 -4
  131. package/dist/collection/components/sd-textarea/sd-textarea.css +3 -0
  132. package/dist/collection/components/sd-textarea/sd-textarea.js +2 -2
  133. package/dist/collection/components/sd-toast/sd-toast.config.js +14 -0
  134. package/dist/collection/components/sd-toast/sd-toast.css +3 -5
  135. package/dist/collection/components/sd-toast/sd-toast.js +52 -5
  136. package/dist/collection/components/sd-toast-container/sd-toast-container.js +4 -4
  137. package/dist/collection/components/sd-toggle/sd-toggle.js +1 -1
  138. package/dist/collection/components/sd-tooltip/sd-tooltip.js +77 -30
  139. package/dist/collection/utils/color/resolveColor.js +2 -2
  140. package/dist/collection/utils/dropdown-manager.js +1 -1
  141. package/dist/collection/utils/modal.js +1 -1
  142. package/dist/collection/utils/toast.js +4 -4
  143. package/dist/components/index.js +1 -1
  144. package/dist/components/p-2wB9cing.js +1 -0
  145. package/dist/components/p-B-sK7I83.js +1 -0
  146. package/dist/components/p-B3D43x7F.js +1 -0
  147. package/dist/components/p-B7mpdnNl.js +1 -0
  148. package/dist/components/{p-TwGlKfsC.js → p-BAcmO7w0.js} +1 -1
  149. package/dist/components/p-BL0ZcHK8.js +1 -0
  150. package/dist/components/p-BXCyVrle.js +1 -0
  151. package/dist/components/p-BY1LGlfc.js +1 -0
  152. package/dist/components/p-BjkROjjt.js +1 -0
  153. package/dist/components/p-Bm3W_eBv.js +1 -0
  154. package/dist/components/p-BnfUIhUj.js +1 -0
  155. package/dist/components/{p-Dcc2Vm6z.js → p-BorUSgEK.js} +1 -1
  156. package/dist/components/{p-Bvq0Vpln.js → p-BsM-fwYd.js} +1 -1
  157. package/dist/components/p-C5CH-s6a.js +1 -0
  158. package/dist/components/p-C7WLft_0.js +1 -0
  159. package/dist/components/p-CK9ciBIR.js +1 -0
  160. package/dist/components/p-CQI40kiY.js +1 -0
  161. package/dist/components/p-CRL7TjSB.js +1 -0
  162. package/dist/components/p-CdOHomUp.js +1 -0
  163. package/dist/components/p-Ch5Yu1qd.js +1 -0
  164. package/dist/components/p-Cktiasfd.js +1 -0
  165. package/dist/components/p-CsVAx6KV.js +1 -0
  166. package/dist/components/p-D0Jiw-Zk.js +1 -0
  167. package/dist/components/p-D5F7wCNo.js +1 -0
  168. package/dist/components/p-DBFgk0rX.js +1 -0
  169. package/dist/components/p-DFLCjX1a.js +1 -0
  170. package/dist/components/p-DL1ac1QS.js +1 -0
  171. package/dist/components/p-DdLntfiw.js +1 -0
  172. package/dist/components/p-DeQcDHpn.js +1 -0
  173. package/dist/components/p-DfK4DiDI.js +1 -0
  174. package/dist/components/p-DhTcn6jX.js +1 -0
  175. package/dist/components/p-Dl8TIEQu.js +1 -0
  176. package/dist/components/p-DyAnn9ea.js +1 -0
  177. package/dist/components/p-GBlVDmy4.js +1 -0
  178. package/dist/components/p-Jts7ueOa.js +1 -0
  179. package/dist/components/p-arZfxxPn.js +1 -0
  180. package/dist/components/p-mmdt-WnS.js +1 -0
  181. package/dist/components/p-nOCYbyW4.js +1 -0
  182. package/dist/components/p-teN3CfOr.js +1 -0
  183. package/dist/components/p-u8teDaMa.js +1 -0
  184. package/dist/components/p-wCNRlKLa.js +1 -0
  185. package/dist/components/sd-action-modal.js +1 -1
  186. package/dist/components/sd-badge.js +1 -1
  187. package/dist/components/sd-barcode-input.js +1 -1
  188. package/dist/components/sd-button.js +1 -1
  189. package/dist/components/sd-calendar.js +1 -1
  190. package/dist/components/sd-card.js +1 -1
  191. package/dist/components/sd-checkbox.js +1 -1
  192. package/dist/components/sd-chip.js +1 -1
  193. package/dist/components/sd-circle-progress.js +1 -1
  194. package/dist/components/sd-confirm-modal.js +1 -1
  195. package/dist/components/sd-date-box.js +1 -1
  196. package/dist/components/sd-date-picker-calendar.js +1 -1
  197. package/dist/components/sd-date-picker-trigger.js +1 -1
  198. package/dist/components/sd-date-picker.js +1 -1
  199. package/dist/components/sd-date-range-picker-calendar.js +1 -1
  200. package/dist/components/sd-date-range-picker.js +1 -1
  201. package/dist/components/sd-dropdown-button.js +1 -1
  202. package/dist/components/sd-field.js +1 -1
  203. package/dist/components/sd-file-picker.js +1 -1
  204. package/dist/components/sd-floating-portal.js +1 -1
  205. package/dist/components/sd-form.js +1 -1
  206. package/dist/components/sd-ghost-button.js +1 -1
  207. package/dist/components/sd-guide.js +1 -1
  208. package/dist/components/sd-icon.js +1 -1
  209. package/dist/components/sd-input.js +1 -1
  210. package/dist/components/sd-key-value-table.d.ts +11 -0
  211. package/dist/components/sd-key-value-table.js +1 -0
  212. package/dist/components/sd-linear-progress.js +1 -1
  213. package/dist/components/sd-loading-container.js +1 -1
  214. package/dist/components/sd-loading-modal.js +1 -1
  215. package/dist/components/sd-modal-container.js +1 -1
  216. package/dist/components/sd-number-input.js +1 -1
  217. package/dist/components/sd-pagination.js +1 -1
  218. package/dist/components/sd-popover.js +1 -1
  219. package/dist/components/{sd-button-v2.d.ts → sd-popup.d.ts} +4 -4
  220. package/dist/components/sd-popup.js +1 -0
  221. package/dist/components/sd-portal.js +1 -1
  222. package/dist/components/sd-radio-button.js +1 -1
  223. package/dist/components/sd-radio-group.js +1 -1
  224. package/dist/components/sd-radio.js +1 -1
  225. package/dist/components/sd-select-list-item-search.js +1 -1
  226. package/dist/components/sd-select-list-item.js +1 -1
  227. package/dist/components/sd-select-listbox.js +1 -1
  228. package/dist/components/sd-select-trigger.js +1 -1
  229. package/dist/components/sd-select.js +1 -1
  230. package/dist/components/sd-switch.js +1 -1
  231. package/dist/components/sd-table.js +1 -1
  232. package/dist/components/sd-tabs.js +1 -1
  233. package/dist/components/sd-tag.js +1 -1
  234. package/dist/components/sd-tbody.js +1 -1
  235. package/dist/components/sd-td.js +1 -1
  236. package/dist/components/sd-text-link.js +1 -1
  237. package/dist/components/sd-textarea.js +1 -1
  238. package/dist/components/sd-thead.js +1 -1
  239. package/dist/components/sd-toast-container.js +1 -1
  240. package/dist/components/sd-toast.js +1 -1
  241. package/dist/components/sd-toggle.js +1 -1
  242. package/dist/components/sd-tooltip.js +1 -1
  243. package/dist/components/sd-tr.js +1 -1
  244. package/dist/design-system/design-system.css +1 -1
  245. package/dist/design-system/design-system.esm.js +1 -1
  246. package/dist/design-system/index.esm.js +1 -1
  247. package/dist/design-system/p-04fdb4b1.entry.js +1 -0
  248. package/dist/design-system/p-05611ff7.entry.js +1 -0
  249. package/dist/design-system/p-0U6dRjlq.js +2 -0
  250. package/dist/design-system/{p-fe9cef6a.entry.js → p-0fe603a4.entry.js} +1 -1
  251. package/dist/design-system/p-100f5887.entry.js +1 -0
  252. package/dist/design-system/p-18c5ae1a.entry.js +1 -0
  253. package/dist/design-system/p-1baa05ae.entry.js +1 -0
  254. package/dist/design-system/p-2a1ef965.entry.js +1 -0
  255. package/dist/design-system/p-2c63404f.entry.js +1 -0
  256. package/dist/design-system/{p-33bc3176.entry.js → p-435ae69e.entry.js} +1 -1
  257. package/dist/design-system/p-43e97572.entry.js +1 -0
  258. package/dist/design-system/p-44d05570.entry.js +1 -0
  259. package/dist/design-system/p-501fae20.entry.js +1 -0
  260. package/dist/design-system/{p-ead3e688.entry.js → p-5705e6d6.entry.js} +1 -1
  261. package/dist/design-system/p-5cbaf1db.entry.js +1 -0
  262. package/dist/design-system/p-5ed0becf.entry.js +1 -0
  263. package/dist/design-system/p-5f1c39b8.entry.js +1 -0
  264. package/dist/design-system/p-66af0ba0.entry.js +1 -0
  265. package/dist/design-system/p-77690440.entry.js +1 -0
  266. package/dist/design-system/p-78cc0289.entry.js +1 -0
  267. package/dist/design-system/p-790165f8.entry.js +1 -0
  268. package/dist/design-system/p-80466582.entry.js +1 -0
  269. package/dist/design-system/{p-e5cebccd.entry.js → p-857c44e8.entry.js} +1 -1
  270. package/dist/design-system/{p-f522c91d.entry.js → p-87c868c3.entry.js} +1 -1
  271. package/dist/design-system/p-8db7d8f2.entry.js +1 -0
  272. package/dist/design-system/p-8ee990bd.entry.js +1 -0
  273. package/dist/design-system/p-8f22106e.entry.js +1 -0
  274. package/dist/design-system/p-BDjErF_K.js +1 -0
  275. package/dist/design-system/p-BnfUIhUj.js +1 -0
  276. package/dist/{components/p-DkJqVXpD.js → design-system/p-C29HUShl.js} +1 -1
  277. package/dist/design-system/{p-BxPyZJaz.js → p-Ce0cmS4R.js} +1 -1
  278. package/dist/design-system/p-CxOCk_ge.js +1 -0
  279. package/dist/design-system/p-GBlVDmy4.js +1 -0
  280. package/dist/design-system/p-a6545130.entry.js +1 -0
  281. package/dist/design-system/p-ae2d45a2.entry.js +1 -0
  282. package/dist/design-system/{p-797517b5.entry.js → p-aeccfb2b.entry.js} +1 -1
  283. package/dist/design-system/p-b0aad445.entry.js +1 -0
  284. package/dist/design-system/p-b3c144ff.entry.js +1 -0
  285. package/dist/design-system/p-caee95b0.entry.js +1 -0
  286. package/dist/design-system/p-d30c823e.entry.js +1 -0
  287. package/dist/design-system/{p-3f7bc660.entry.js → p-d3212544.entry.js} +1 -1
  288. package/dist/design-system/p-d8c41313.entry.js +1 -0
  289. package/dist/design-system/{p-6bfe3612.entry.js → p-de8bb9ba.entry.js} +1 -1
  290. package/dist/design-system/p-e2334c1c.entry.js +1 -0
  291. package/dist/design-system/p-f4d73a0c.entry.js +1 -0
  292. package/dist/design-system/p-fc973500.entry.js +1 -0
  293. package/dist/design-system/p-fe0a5368.entry.js +1 -0
  294. package/dist/design-system/p-mmdt-WnS.js +1 -0
  295. package/dist/esm/component.table-BnfUIhUj.js +64 -0
  296. package/dist/esm/design-system.js +3 -3
  297. package/dist/esm/{index-Cnwbjz1F.js → index-0U6dRjlq.js} +1 -1
  298. package/dist/esm/index.js +5 -5
  299. package/dist/esm/loader.js +3 -3
  300. package/dist/esm/{resolveColor-BxPyZJaz.js → resolveColor-Ce0cmS4R.js} +2 -2
  301. package/dist/esm/sd-action-modal.entry.js +3 -3
  302. package/dist/esm/sd-badge.entry.js +2 -3
  303. package/dist/esm/sd-barcode-input.entry.js +3 -3
  304. package/dist/esm/{sd-button-v2.config-CV4xelxV.js → sd-button.config-BDjErF_K.js} +88 -3
  305. package/dist/esm/{sd-button-v2_2.entry.js → sd-button_2.entry.js} +102 -85
  306. package/dist/esm/sd-calendar.entry.js +15 -15
  307. package/dist/esm/sd-card.entry.js +2 -2
  308. package/dist/esm/sd-checkbox.entry.js +4 -4
  309. package/dist/esm/sd-chip.entry.js +4 -4
  310. package/dist/esm/sd-circle-progress.entry.js +3 -3
  311. package/dist/esm/sd-confirm-modal_2.entry.js +19 -11
  312. package/dist/esm/sd-date-box.entry.js +9 -4
  313. package/dist/esm/{sd-date-picker-calendar.entry.js → sd-date-picker-calendar_2.entry.js} +59 -7
  314. package/dist/esm/{sd-date-picker.config-C2fDbE9d.js → sd-date-picker.config-B6cqMQaM.js} +1 -2
  315. package/dist/esm/sd-date-picker_7.entry.js +1227 -0
  316. package/dist/esm/sd-date-range-picker-calendar.entry.js +14 -14
  317. package/dist/esm/sd-dropdown-button.entry.js +21 -16
  318. package/dist/esm/{sd-button_4.entry.js → sd-field_3.entry.js} +48 -102
  319. package/dist/esm/sd-form.entry.js +5 -5
  320. package/dist/esm/sd-ghost-button.entry.js +12 -10
  321. package/dist/esm/sd-guide.entry.js +11 -11
  322. package/dist/esm/sd-key-value-table.entry.js +228 -0
  323. package/dist/esm/sd-linear-progress.entry.js +3 -3
  324. package/dist/esm/sd-loading-container.entry.js +3 -3
  325. package/dist/esm/sd-modal-container.entry.js +3 -3
  326. package/dist/esm/{sd-pagination_5.entry.js → sd-pagination_4.entry.js} +137 -325
  327. package/dist/esm/sd-popover.entry.js +18 -11
  328. package/dist/esm/sd-popup.entry.js +110 -0
  329. package/dist/esm/sd-portal.entry.js +3 -3
  330. package/dist/esm/sd-radio-button.entry.js +9 -6
  331. package/dist/esm/sd-radio.entry.js +2 -2
  332. package/dist/esm/sd-select-list-item_2.entry.js +156 -0
  333. package/dist/esm/sd-select.config-CxOCk_ge.js +165 -0
  334. package/dist/esm/{sd-select-list-item_4.entry.js → sd-select_3.entry.js} +281 -307
  335. package/dist/esm/sd-switch.entry.js +2 -2
  336. package/dist/esm/{sd-table.config-Bj-EEo7N.js → sd-table.config-B-VgXXT7.js} +16 -46
  337. package/dist/esm/sd-table.entry.js +188 -48
  338. package/dist/esm/sd-tabs.entry.js +8 -3
  339. package/dist/esm/sd-tag.entry.js +56 -21
  340. package/dist/esm/sd-td.entry.js +52 -10
  341. package/dist/esm/sd-text-link.entry.js +13 -5
  342. package/dist/esm/sd-toast-container.entry.js +5 -5
  343. package/dist/esm/sd-toast.entry.js +35 -5
  344. package/dist/esm/sd-toggle.entry.js +2 -2
  345. package/dist/esm/{system-CZ4ltUOw.js → system-GBlVDmy4.js} +4 -2
  346. package/dist/esm/{tooltipArrow-D8sr81Xw.js → tooltipArrow-O5LOsHae.js} +1 -1
  347. package/dist/types/components/assets/CheckboxCheck.d.ts +1 -0
  348. package/dist/types/components/assets/CheckboxIndeterminate.d.ts +1 -0
  349. package/dist/types/components/assets/index.d.ts +2 -0
  350. package/dist/types/components/sd-action-modal/sd-action-modal.d.ts +2 -2
  351. package/dist/types/components/sd-badge/sd-badge.d.ts +0 -1
  352. package/dist/types/components/{sd-button-v2/sd-button-v2.config.d.ts → sd-button/sd-button.config.d.ts} +9 -15
  353. package/dist/types/components/sd-button/sd-button.d.ts +11 -13
  354. package/dist/types/components/sd-confirm-modal/sd-confirm-modal.config.d.ts +3 -3
  355. package/dist/types/components/sd-confirm-modal/sd-confirm-modal.d.ts +2 -1
  356. package/dist/types/components/sd-dropdown-button/sd-dropdown-button.config.d.ts +6 -5
  357. package/dist/types/components/sd-dropdown-button/sd-dropdown-button.d.ts +1 -0
  358. package/dist/types/components/sd-field/sd-field.d.ts +1 -0
  359. package/dist/types/components/sd-key-value-table/sd-key-value-table.config.d.ts +105 -0
  360. package/dist/types/components/sd-key-value-table/sd-key-value-table.d.ts +38 -0
  361. package/dist/types/components/sd-loading-modal/sd-loading-modal.config.d.ts +2 -2
  362. package/dist/types/components/sd-loading-modal/sd-loading-modal.d.ts +1 -0
  363. package/dist/types/components/sd-modal-container/sd-modal-container.config.d.ts +1 -1
  364. package/dist/types/components/sd-popover/sd-popover.d.ts +16 -10
  365. package/dist/types/components/sd-popup/sd-popup.config.d.ts +30 -0
  366. package/dist/types/components/sd-popup/sd-popup.d.ts +11 -0
  367. package/dist/types/components/sd-table/constants.d.ts +2 -0
  368. package/dist/types/components/sd-table/sd-table.config.d.ts +4 -0
  369. package/dist/types/components/sd-table/sd-table.d.ts +21 -15
  370. package/dist/types/components/sd-table/sd-td/sd-td.d.ts +6 -0
  371. package/dist/types/components/sd-table/sd-tr/sd-tr.d.ts +9 -0
  372. package/dist/types/components/sd-tag/sd-tag.d.ts +2 -0
  373. package/dist/types/components/sd-toast/sd-toast.config.d.ts +5 -1
  374. package/dist/types/components/sd-toast/sd-toast.d.ts +2 -0
  375. package/dist/types/components/sd-toast-container/sd-toast-container.config.d.ts +2 -0
  376. package/dist/types/components/sd-tooltip/sd-tooltip.config.d.ts +2 -13
  377. package/dist/types/components/sd-tooltip/sd-tooltip.d.ts +6 -4
  378. package/dist/types/components.d.ts +278 -192
  379. package/dist/types/index.d.ts +1 -1
  380. package/dist/types/types/form.d.ts +1 -1
  381. package/dist/types/types/global.d.ts +14 -13
  382. package/dist/types/utils/toast.d.ts +1 -1
  383. package/hydrate/index.js +5513 -4761
  384. package/hydrate/index.mjs +5513 -4761
  385. package/package.json +111 -97
  386. package/readme.md +13 -7
  387. package/dist/cjs/component.button-cqV-iCG5.js +0 -90
  388. package/dist/cjs/sd-date-picker-trigger.cjs.entry.js +0 -51
  389. package/dist/cjs/sd-date-picker.cjs.entry.js +0 -117
  390. package/dist/cjs/sd-date-range-picker.cjs.entry.js +0 -123
  391. package/dist/cjs/sd-file-picker.cjs.entry.js +0 -244
  392. package/dist/cjs/sd-input.cjs.entry.js +0 -175
  393. package/dist/cjs/sd-number-input.cjs.entry.js +0 -409
  394. package/dist/cjs/sd-radio-group.cjs.entry.js +0 -46
  395. package/dist/cjs/sd-table.config-Cb0Ot3C6.js +0 -105
  396. package/dist/cjs/sd-textarea.cjs.entry.js +0 -146
  397. package/dist/collection/components/sd-button-v2/sd-button-v2.css +0 -125
  398. package/dist/collection/components/sd-button-v2/sd-button-v2.js +0 -273
  399. package/dist/components/p-B1XBwjCW.js +0 -1
  400. package/dist/components/p-B8jXOXtJ.js +0 -1
  401. package/dist/components/p-BE6TxbtX.js +0 -1
  402. package/dist/components/p-BJsHakU2.js +0 -1
  403. package/dist/components/p-BStczlLa.js +0 -1
  404. package/dist/components/p-BcMNA89i.js +0 -1
  405. package/dist/components/p-BheX6lAy.js +0 -1
  406. package/dist/components/p-BmYM7-4v.js +0 -1
  407. package/dist/components/p-BppjYHF6.js +0 -1
  408. package/dist/components/p-BwWDMpJc.js +0 -1
  409. package/dist/components/p-C-kw2p2a.js +0 -1
  410. package/dist/components/p-C5qZtNLl.js +0 -1
  411. package/dist/components/p-C7DajKYn.js +0 -1
  412. package/dist/components/p-CZ4ltUOw.js +0 -1
  413. package/dist/components/p-CeVMl_M9.js +0 -1
  414. package/dist/components/p-D1DpOp6M.js +0 -1
  415. package/dist/components/p-D3gjBBCU.js +0 -1
  416. package/dist/components/p-DC-6inj0.js +0 -1
  417. package/dist/components/p-DRF0He-x.js +0 -1
  418. package/dist/components/p-DegvQLTF.js +0 -1
  419. package/dist/components/p-Dey-lS6x.js +0 -1
  420. package/dist/components/p-DfH_fO01.js +0 -1
  421. package/dist/components/p-DngV3MT1.js +0 -1
  422. package/dist/components/p-EbjZr2OA.js +0 -1
  423. package/dist/components/p-LwWOleLJ.js +0 -1
  424. package/dist/components/p-Nvx13YlG.js +0 -1
  425. package/dist/components/p-ZMpCZhXP.js +0 -1
  426. package/dist/components/p-dNJIFthT.js +0 -1
  427. package/dist/components/p-q0VWISKA.js +0 -1
  428. package/dist/components/p-xnLvZ-xn.js +0 -1
  429. package/dist/components/sd-button-v2.js +0 -1
  430. package/dist/design-system/p-0356c195.entry.js +0 -1
  431. package/dist/design-system/p-045bc426.entry.js +0 -1
  432. package/dist/design-system/p-12dfd239.entry.js +0 -1
  433. package/dist/design-system/p-16d3a485.entry.js +0 -1
  434. package/dist/design-system/p-1706ed6f.entry.js +0 -1
  435. package/dist/design-system/p-182548f7.entry.js +0 -1
  436. package/dist/design-system/p-1a79edce.entry.js +0 -1
  437. package/dist/design-system/p-1cf87e87.entry.js +0 -1
  438. package/dist/design-system/p-25a08e98.entry.js +0 -1
  439. package/dist/design-system/p-2812b9ce.entry.js +0 -1
  440. package/dist/design-system/p-38f661ea.entry.js +0 -1
  441. package/dist/design-system/p-429dab5c.entry.js +0 -1
  442. package/dist/design-system/p-455dccf5.entry.js +0 -1
  443. package/dist/design-system/p-59313838.entry.js +0 -1
  444. package/dist/design-system/p-6af01ab0.entry.js +0 -1
  445. package/dist/design-system/p-70d4903f.entry.js +0 -1
  446. package/dist/design-system/p-767e99f9.entry.js +0 -1
  447. package/dist/design-system/p-7c370335.entry.js +0 -1
  448. package/dist/design-system/p-7fe8be6a.entry.js +0 -1
  449. package/dist/design-system/p-83b262dc.entry.js +0 -1
  450. package/dist/design-system/p-881adaa5.entry.js +0 -1
  451. package/dist/design-system/p-88d7303c.entry.js +0 -1
  452. package/dist/design-system/p-8a601e0f.entry.js +0 -1
  453. package/dist/design-system/p-B1XBwjCW.js +0 -1
  454. package/dist/design-system/p-BsrEibf7.js +0 -1
  455. package/dist/design-system/p-C5qZtNLl.js +0 -1
  456. package/dist/design-system/p-CZ4ltUOw.js +0 -1
  457. package/dist/design-system/p-Cnwbjz1F.js +0 -2
  458. package/dist/design-system/p-DnCBBIoq.js +0 -1
  459. package/dist/design-system/p-a82be987.entry.js +0 -1
  460. package/dist/design-system/p-b917c82a.entry.js +0 -1
  461. package/dist/design-system/p-b9f00eef.entry.js +0 -1
  462. package/dist/design-system/p-bcb53788.entry.js +0 -1
  463. package/dist/design-system/p-c24344ac.entry.js +0 -1
  464. package/dist/design-system/p-d76192bd.entry.js +0 -1
  465. package/dist/design-system/p-d9d8c51b.entry.js +0 -1
  466. package/dist/design-system/p-de67937d.entry.js +0 -1
  467. package/dist/design-system/p-ea5e6c2c.entry.js +0 -1
  468. package/dist/design-system/p-eeb1cac2.entry.js +0 -1
  469. package/dist/design-system/p-f1a74359.entry.js +0 -1
  470. package/dist/design-system/p-f44786a9.entry.js +0 -1
  471. package/dist/design-system/p-f69c7539.entry.js +0 -1
  472. package/dist/esm/component.button-B1XBwjCW.js +0 -88
  473. package/dist/esm/sd-date-picker-trigger.entry.js +0 -49
  474. package/dist/esm/sd-date-picker.entry.js +0 -115
  475. package/dist/esm/sd-date-range-picker.entry.js +0 -121
  476. package/dist/esm/sd-file-picker.entry.js +0 -242
  477. package/dist/esm/sd-input.entry.js +0 -173
  478. package/dist/esm/sd-number-input.entry.js +0 -407
  479. package/dist/esm/sd-radio-group.entry.js +0 -44
  480. package/dist/esm/sd-textarea.entry.js +0 -144
  481. package/dist/types/components/sd-button-v2/sd-button-v2.d.ts +0 -19
  482. /package/dist/components/{p-C2fDbE9d.js → p-B6cqMQaM.js} +0 -0
  483. /package/dist/design-system/{p-C2fDbE9d.js → p-B6cqMQaM.js} +0 -0
@@ -1,318 +1,287 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index--F2wGuAi.js');
3
+ var index = require('./index-Cw-78mnC.js');
4
+ var index$1 = require('./index-BUvXpPc3.js');
5
+ var sdSelect_config = require('./sd-select.config-B19ptCT2.js');
4
6
 
5
- const select = {
6
- paddingX: "12",
7
- icon: {
8
- "default": "#888888",
9
- disabled: "#BBBBBB"
10
- },
11
- gap: "8",
12
- typography: {
13
- fontWeight: "400",
14
- fontSize: "12",
15
- lineHeight: "20"},
16
- text: {
17
- "default": "#222222",
18
- disabled: "#888888"
19
- }};
20
- var selectTokens = {
21
- select: select
22
- };
23
-
24
- const listItem = {
25
- paddingY: "4",
26
- paddingRight: "12",
27
- gap: "8",
28
- paddingLeft: {
29
- depth1: "12",
30
- depth2: "20",
31
- depth3: "28"
32
- },
33
- typography: {
34
- "default": {
35
- fontWeight: "400",
36
- fontSize: "12",
37
- lineHeight: "20"},
38
- selected: {
39
- fontWeight: "700"}
40
- },
41
- bg: {
42
- "default": "#FFFFFF",
43
- hover: "#0075FF"
44
- },
45
- content: {
46
- "default": "#222222",
47
- hover: "#FFFFFF",
48
- disabled: "#888888",
49
- selected: "#0075FF"
50
- },
51
- depth1: {
52
- bg: {
53
- "default": "#EFF6FF"},
54
- border: {
55
- color: "#E1E1E1",
56
- width: "1"
57
- }},
58
- depth2: {
59
- middle: {
60
- bg: "#F6F6F6"}
61
- }};
62
- var listItemTokens = {
63
- listItem: listItem
64
- };
7
+ const sdSelectCss = () => `sd-select{display:inline-flex}sd-select sd-portal{display:none}sd-select .sd-select{position:relative;width:100%;height:100%}`;
65
8
 
66
- const listBox = {
67
- radius: "4"};
68
- var listBoxTokens = {
69
- listBox: listBox
70
- };
71
-
72
- // ── Select Trigger Tokens ──
73
- const SELECT_LAYOUT = {
74
- paddingX: selectTokens.select.paddingX,
75
- gap: selectTokens.select.gap};
76
- const SELECT_TYPOGRAPHY = {
77
- fontSize: selectTokens.select.typography.fontSize,
78
- lineHeight: selectTokens.select.typography.lineHeight,
79
- fontWeight: selectTokens.select.typography.fontWeight,
80
- };
81
- const SELECT_COLORS = {
82
- icon: {
83
- default: selectTokens.select.icon.default,
84
- disabled: selectTokens.select.icon.disabled,
85
- },
86
- text: {
87
- default: selectTokens.select.text.default,
88
- disabled: selectTokens.select.text.disabled,
89
- },
90
- };
91
- // ── ListItem Tokens ──
92
- const LIST_ITEM_LAYOUT = {
93
- paddingY: listItemTokens.listItem.paddingY,
94
- paddingRight: listItemTokens.listItem.paddingRight,
95
- paddingLeft: {
96
- depth1: listItemTokens.listItem.paddingLeft.depth1,
97
- depth2: listItemTokens.listItem.paddingLeft.depth2,
98
- depth3: listItemTokens.listItem.paddingLeft.depth3,
99
- },
100
- gap: listItemTokens.listItem.gap,
101
- };
102
- const LIST_ITEM_TYPOGRAPHY = {
103
- fontSize: listItemTokens.listItem.typography.default.fontSize,
104
- lineHeight: listItemTokens.listItem.typography.default.lineHeight,
105
- fontWeight: listItemTokens.listItem.typography.default.fontWeight,
106
- selectedFontWeight: listItemTokens.listItem.typography.selected.fontWeight,
107
- };
108
- const LIST_ITEM_COLORS = {
109
- bg: {
110
- default: listItemTokens.listItem.bg.default,
111
- hover: listItemTokens.listItem.bg.hover,
112
- },
113
- content: {
114
- default: listItemTokens.listItem.content.default,
115
- hover: listItemTokens.listItem.content.hover,
116
- disabled: listItemTokens.listItem.content.disabled,
117
- selected: listItemTokens.listItem.content.selected,
118
- },
119
- depth1: {
120
- bg: listItemTokens.listItem.depth1.bg.default,
121
- border: listItemTokens.listItem.depth1.border.color,
122
- borderWidth: listItemTokens.listItem.depth1.border.width,
123
- },
124
- depth2: {
125
- bg: listItemTokens.listItem.depth2.middle.bg,
126
- }};
127
- // ── ListBox Tokens ──
128
- const LIST_BOX_LAYOUT = {
129
- radius: listBoxTokens.listBox.radius,
130
- };
131
- // ── Constants ──
132
- const SEARCH_THRESHOLD = 11;
133
- const SEARCH_DEBOUNCE_MS = 1000;
134
- const EMPTY_MESSAGE = '표시할 항목이 없습니다.';
135
- // ── Utilities ──
136
- function countLeaves(options) {
137
- return options.reduce((sum, option) => {
138
- if (option.children) {
139
- return sum + countLeaves(option.children);
9
+ const SdSelect = class {
10
+ constructor(hostRef) {
11
+ index.registerInstance(this, hostRef);
12
+ this.update = index.createEvent(this, "sdUpdate", 7);
13
+ this.dropDownShow = index.createEvent(this, "sdDropDownShow", 7);
14
+ }
15
+ static VIEWPORT_PADDING = 20;
16
+ static PORTAL_OFFSET_Y = 4;
17
+ static CLOSE_ANIMATION_DURATION = 150;
18
+ get el() { return index.getElement(this); }
19
+ type = 'default';
20
+ value = null;
21
+ options = [];
22
+ placeholder = '선택';
23
+ maxDropdownWidth = '640px';
24
+ dropdownHeight = '260px';
25
+ disabled = false;
26
+ label = '';
27
+ labelWidth = '';
28
+ addonLabel = '';
29
+ addonAlign = 'start';
30
+ error = false;
31
+ hint = '';
32
+ errorMessage = '';
33
+ rules = [];
34
+ icon = undefined;
35
+ labelTooltip = '';
36
+ labelTooltipProps = null;
37
+ emitValue = false;
38
+ width = '';
39
+ useSearch = false;
40
+ allSelectedLabel = '전체';
41
+ useSelectAll = false;
42
+ isOpen = false;
43
+ isAnimatingOut = false;
44
+ triggerWidth = '200px';
45
+ resolvedDropdownHeight = '260px';
46
+ resolvedMaxDropdownWidth = '640px';
47
+ focused = false;
48
+ hovered = false;
49
+ update;
50
+ dropDownShow;
51
+ async sdFocus() {
52
+ if (this.disabled)
53
+ return;
54
+ await this.triggerComponentRef?.sdFocus();
55
+ }
56
+ async sdOpen() {
57
+ // sdFocus 직후 호출 시 트리거 ref/레이아웃이 안정될 때까지 한 틱 대기
58
+ await new Promise(resolve => setTimeout(resolve, 0));
59
+ if (this.disabled || this.isOpen)
60
+ return;
61
+ this.prepareDropdownGeometry();
62
+ if (this.closeAnimationTimer)
63
+ clearTimeout(this.closeAnimationTimer);
64
+ this.isAnimatingOut = false;
65
+ this.isOpen = true;
66
+ }
67
+ triggerRef;
68
+ triggerComponentRef;
69
+ closeAnimationTimer;
70
+ name = index$1.nanoid();
71
+ triggerHasFocus = false;
72
+ watchIsOpen(newValue) {
73
+ this.syncFocusedState(newValue);
74
+ this.dropDownShow.emit({ isOpen: newValue });
75
+ }
76
+ get isMulti() {
77
+ return this.type === 'multi' || this.type === 'multi_depth';
78
+ }
79
+ get displayText() {
80
+ if (this.isMulti) {
81
+ if (!Array.isArray(this.value) || this.value.length === 0)
82
+ return '';
83
+ const nonDisabledLeaves = this.getNonDisabledLeaves(this.options);
84
+ const selected = this.getSelectedOptions();
85
+ const allSelected = nonDisabledLeaves.length > 0 &&
86
+ nonDisabledLeaves.every(leaf => selected.some(s => s.value === leaf.value));
87
+ if (allSelected)
88
+ return this.allSelectedLabel ?? '전체';
89
+ const flat = this.flattenOptions(this.options);
90
+ return this.value
91
+ .map(item => {
92
+ if (item != null && typeof item === 'object') {
93
+ const opt = item;
94
+ return opt.label ?? flat.find(o => o.value === opt.value)?.label ?? '';
95
+ }
96
+ return flat.find(o => o.value === item)?.label ?? '';
97
+ })
98
+ .filter(Boolean)
99
+ .join(', ');
140
100
  }
141
- return sum + 1;
142
- }, 0);
143
- }
144
- function filterTree(options, keyword) {
145
- const lowerKeyword = keyword.toLowerCase();
146
- return options.reduce((acc, option) => {
147
- const selfMatch = option.label.toLowerCase().includes(lowerKeyword);
148
- if (option.children) {
149
- // 그룹: 자식은 항상 추가로 필터링한다.
150
- // - 자식 중 일치하는 게 있으면 그 자식들만 노출
151
- // - 자식 매칭이 없더라도 그룹명이 매칭되면 그룹 헤더는 그대로 노출
152
- // (이때 children 은 빈 배열로 두고, 선택 동작은 collectVisibleLeaves
153
- // 의 fallback 이 원본 트리를 사용해 처리한다)
154
- const filteredChildren = filterTree(option.children, keyword);
155
- if (filteredChildren.length > 0) {
156
- acc.push({ ...option, children: filteredChildren });
157
- }
158
- else if (selfMatch) {
159
- acc.push({ ...option, children: [] });
160
- }
101
+ if (this.value == null)
102
+ return '';
103
+ if (!this.emitValue && typeof this.value === 'object' && !Array.isArray(this.value)) {
104
+ return this.value.label ?? '';
161
105
  }
162
- else if (selfMatch) {
163
- acc.push({ ...option });
106
+ const flat = this.flattenOptions(this.options);
107
+ const found = flat.find(o => o.value === this.value);
108
+ return found?.label ?? '';
109
+ }
110
+ flattenOptions(options) {
111
+ return options.flatMap(o => (o.children ? this.flattenOptions(o.children) : [o]));
112
+ }
113
+ getNonDisabledLeaves(options) {
114
+ return options.flatMap(o => {
115
+ if (o.disabled)
116
+ return [];
117
+ if (o.children)
118
+ return this.getNonDisabledLeaves(o.children);
119
+ return [o];
120
+ });
121
+ }
122
+ getSelectedOptions() {
123
+ const val = this.value;
124
+ if (val == null || !Array.isArray(val))
125
+ return [];
126
+ if (this.emitValue) {
127
+ return val
128
+ .map(v => this.findOriginalOption(v, this.options))
129
+ .filter((o) => !!o);
164
130
  }
165
- return acc;
166
- }, []);
167
- }
168
-
169
- const sdSelectListItemCss = () => `sd-select-list-item{display:block}sd-select-list-item .sd-select-list-item{display:flex;align-items:center;gap:var(--list-item-gap);padding:var(--list-item-padding-y) var(--list-item-padding-right) var(--list-item-padding-y) var(--list-item-padding-left);font-size:var(--list-item-font-size);line-height:var(--list-item-line-height);font-weight:var(--list-item-font-weight);background:var(--list-item-bg);color:var(--list-item-color);cursor:default;user-select:none}sd-select-list-item .sd-select-list-item--selectable{cursor:pointer}sd-select-list-item .sd-select-list-item--depth1-group{border-top:var(--list-item-border-top);font-weight:700}sd-select-list-item .sd-select-list-item--depth2-group{font-weight:500}sd-select-list-item .sd-select-list-item--focused.sd-select-list-item--selectable:not(.sd-select-list-item--disabled){background:var(--list-item-bg-hover);color:var(--list-item-color-hover)}sd-select-list-item .sd-select-list-item--selected:not(.sd-select-list-item--group){font-weight:var(--list-item-font-weight-selected);color:var(--list-item-color-selected)}sd-select-list-item .sd-select-list-item--selected.sd-select-list-item--focused{color:var(--list-item-color-hover)}sd-select-list-item .sd-select-list-item--disabled{color:var(--list-item-color-disabled);cursor:not-allowed}sd-select-list-item .sd-select-list-item__label{flex:0 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}sd-select-list-item .sd-select-list-item__count{flex-shrink:0;font-weight:500;color:var(--list-item-color-disabled)}sd-select-list-item .sd-select-list-item--group.sd-select-list-item--focused .sd-select-list-item__count{color:#ffffff}sd-select-list-item .sd-select-list-item__checkbox{flex-shrink:0}`;
170
-
171
- const SdSelectListItem = class {
172
- constructor(hostRef) {
173
- index.registerInstance(this, hostRef);
174
- this.listItemClick = index.createEvent(this, "sdListItemClick", 7);
175
- }
176
- option;
177
- depth = 1;
178
- isSelected = false;
179
- isFocused = false;
180
- useCheckbox = false;
181
- countInfo;
182
- listItemClick;
183
- get isGroup() {
184
- return !!this.option.children;
185
- }
186
- get isSelectable() {
187
- return !this.isGroup || this.useCheckbox;
188
- }
189
- get depthKey() {
190
- if (this.depth <= 1)
191
- return 'depth1';
192
- if (this.depth === 2)
193
- return 'depth2';
194
- return 'depth3';
195
- }
196
- get paddingLeft() {
197
- return `${LIST_ITEM_LAYOUT.paddingLeft[this.depthKey]}px`;
198
- }
199
- handleClick = (e) => {
200
- e.stopPropagation();
201
- if (this.option.disabled || !this.isSelectable)
131
+ return val;
132
+ }
133
+ toMultiValue(options) {
134
+ return this.emitValue ? options.map(o => o.value) : options;
135
+ }
136
+ parsePixelValue(value, fallback) {
137
+ const parsed = Number.parseFloat(value);
138
+ return Number.isFinite(parsed) ? parsed : fallback;
139
+ }
140
+ updateDropdownViewportConstraints() {
141
+ if (!this.triggerRef)
202
142
  return;
203
- this.listItemClick.emit(this.option);
204
- };
205
- handleCheckboxClick = (e) => {
206
- e.stopPropagation();
207
- };
208
- handleCheckboxUpdate = (e) => {
209
- e.stopPropagation();
210
- if (this.option.disabled || !this.isSelectable)
143
+ const triggerRect = this.triggerRef.getBoundingClientRect();
144
+ const viewportPadding = SdSelect.VIEWPORT_PADDING;
145
+ const offsetY = SdSelect.PORTAL_OFFSET_Y;
146
+ const preferredHeight = this.parsePixelValue(this.dropdownHeight, 260);
147
+ const preferredWidth = this.parsePixelValue(this.maxDropdownWidth, 640);
148
+ const availableBelow = Math.max(window.innerHeight - triggerRect.bottom - viewportPadding - offsetY, 0);
149
+ const availableAbove = Math.max(triggerRect.top - viewportPadding - offsetY, 0);
150
+ const availableHeight = Math.max(availableBelow, availableAbove);
151
+ const availableWidth = Math.max(window.innerWidth - viewportPadding * 2, 0);
152
+ this.resolvedDropdownHeight = `${Math.min(preferredHeight, availableHeight)}px`;
153
+ this.resolvedMaxDropdownWidth = `${Math.min(preferredWidth, availableWidth)}px`;
154
+ }
155
+ handleViewportResize = () => {
156
+ if (!this.isOpen)
211
157
  return;
212
- this.listItemClick.emit(this.option);
158
+ this.updateDropdownViewportConstraints();
213
159
  };
214
- render() {
215
- const isGroup = this.isGroup;
216
- const isDepth1Group = isGroup && this.depth === 1;
217
- const isDepth2Group = isGroup && this.depth === 2;
218
- const cssVars = {
219
- '--list-item-padding-y': `${LIST_ITEM_LAYOUT.paddingY}px`,
220
- '--list-item-padding-left': this.paddingLeft,
221
- '--list-item-padding-right': `${LIST_ITEM_LAYOUT.paddingRight}px`,
222
- '--list-item-gap': `${LIST_ITEM_LAYOUT.gap}px`,
223
- '--list-item-font-size': `${LIST_ITEM_TYPOGRAPHY.fontSize}px`,
224
- '--list-item-line-height': `${LIST_ITEM_TYPOGRAPHY.lineHeight}px`,
225
- '--list-item-font-weight': LIST_ITEM_TYPOGRAPHY.fontWeight,
226
- '--list-item-bg': isDepth1Group
227
- ? LIST_ITEM_COLORS.depth1.bg
228
- : isDepth2Group
229
- ? LIST_ITEM_COLORS.depth2.bg
230
- : LIST_ITEM_COLORS.bg.default,
231
- '--list-item-bg-hover': LIST_ITEM_COLORS.bg.hover,
232
- '--list-item-color': LIST_ITEM_COLORS.content.default,
233
- '--list-item-color-hover': LIST_ITEM_COLORS.content.hover,
234
- '--list-item-color-disabled': LIST_ITEM_COLORS.content.disabled,
235
- '--list-item-color-selected': LIST_ITEM_COLORS.content.selected,
236
- '--list-item-font-weight-selected': LIST_ITEM_TYPOGRAPHY.selectedFontWeight,
237
- };
238
- if (isDepth1Group) {
239
- cssVars['--list-item-border-top'] = `${LIST_ITEM_COLORS.depth1.borderWidth}px solid ${LIST_ITEM_COLORS.depth1.border}`;
160
+ findOriginalOption(value, options) {
161
+ for (const opt of options) {
162
+ if (opt.value === value)
163
+ return opt;
164
+ if (opt.children) {
165
+ const found = this.findOriginalOption(value, opt.children);
166
+ if (found)
167
+ return found;
168
+ }
240
169
  }
241
- return (index.h("div", { key: 'c6f959e9290213c9003914dbdd696c3c339cce51', class: {
242
- 'sd-select-list-item': true,
243
- 'sd-select-list-item--group': isGroup,
244
- 'sd-select-list-item--depth1-group': isDepth1Group,
245
- 'sd-select-list-item--depth2-group': isDepth2Group,
246
- 'sd-select-list-item--selected': this.isSelected === true,
247
- 'sd-select-list-item--indeterminate': this.isSelected === null,
248
- 'sd-select-list-item--focused': this.isFocused,
249
- 'sd-select-list-item--selectable': this.isSelectable && !this.option.disabled,
250
- 'sd-select-list-item--disabled': !!this.option.disabled,
251
- }, style: cssVars, onClick: this.handleClick }, this.useCheckbox && (index.h("sd-checkbox", { key: 'a884bd82722cd45efc19abd2139d08596f7eda86', value: this.isSelected === null ? null : !!this.isSelected, disabled: this.option.disabled, inverse: this.isFocused && this.isSelected !== false, class: "sd-select-list-item__checkbox", onClick: this.handleCheckboxClick, onSdUpdate: this.handleCheckboxUpdate })), index.h("span", { key: '9aacbeca13e591406454ef7e1c7be40a56a2926b', class: "sd-select-list-item__label" }, this.option.label), this.countInfo && (index.h("span", { key: '76be4eda3799cfa329016c2ea636feaf624e5025', class: "sd-select-list-item__count" }, "(", this.countInfo.selected, "/", this.countInfo.total, ")"))));
170
+ return undefined;
252
171
  }
253
- };
254
- SdSelectListItem.style = sdSelectListItemCss();
255
-
256
- const sdSelectListItemSearchCss = () => `sd-select-list-item-search{display:block}sd-select-list-item-search .sd-select-list-item-search{padding:4px 8px;position:sticky;top:0;z-index:1;background:white}sd-select-list-item-search .sd-select-list-item-search--scrolled{box-shadow:0 2px 4px rgba(0, 0, 0, 0.08)}sd-select-list-item-search .sd-select-list-item-search__inner{display:flex;align-items:center;gap:6px;padding:4px 8px;border:1px solid #CCCCCC;border-radius:4px;background:white}sd-select-list-item-search .sd-select-list-item-search__inner:focus-within{border-color:#0075FF}sd-select-list-item-search .sd-select-list-item-search__icon{flex-shrink:0}sd-select-list-item-search .sd-select-list-item-search__input{flex:1;border:none;outline:none;font-size:12px;line-height:20px;color:#222222;background:transparent;min-width:0}sd-select-list-item-search .sd-select-list-item-search__input::placeholder{color:#AAAAAA}sd-select-list-item-search .sd-select-list-item-search__clear{flex-shrink:0;display:flex;align-items:center;justify-content:center;padding:2px;border:none;background:transparent;cursor:pointer;border-radius:2px}sd-select-list-item-search .sd-select-list-item-search__clear:hover{background:#F0F0F0}sd-select-list-item-search .sd-select-list-item-search__clear--hidden{visibility:hidden;pointer-events:none}`;
257
-
258
- const SdSelectListItemSearch = class {
259
- constructor(hostRef) {
260
- index.registerInstance(this, hostRef);
261
- this.searchFilter = index.createEvent(this, "sdSearchFilter", 7);
262
- this.searchFocus = index.createEvent(this, "sdSearchFocus", 7);
172
+ closeDropdown() {
173
+ if (!this.isOpen)
174
+ return;
175
+ this.isOpen = false;
176
+ this.isAnimatingOut = true;
177
+ if (this.closeAnimationTimer)
178
+ clearTimeout(this.closeAnimationTimer);
179
+ this.closeAnimationTimer = setTimeout(() => {
180
+ this.isAnimatingOut = false;
181
+ }, SdSelect.CLOSE_ANIMATION_DURATION);
182
+ }
183
+ prepareDropdownGeometry() {
184
+ if (this.triggerRef) {
185
+ this.triggerWidth = `${this.triggerRef.offsetWidth}px`;
186
+ }
187
+ this.updateDropdownViewportConstraints();
263
188
  }
264
- isScrolled = false;
265
- searchText = '';
266
- searchFilter;
267
- searchFocus;
268
- inputEl;
269
- debounceTimer;
270
- focusRafId;
271
- componentDidLoad() {
272
- requestAnimationFrame(() => {
273
- this.focusRafId = requestAnimationFrame(() => {
274
- this.inputEl?.focus();
275
- });
276
- });
189
+ syncFocusedState(isOpen = this.isOpen) {
190
+ this.focused = isOpen || this.triggerHasFocus;
277
191
  }
278
- async sdFocus() {
279
- this.inputEl?.focus();
280
- }
281
- handleInput = (e) => {
282
- this.searchText = e.target.value;
283
- if (this.debounceTimer)
284
- clearTimeout(this.debounceTimer);
285
- this.debounceTimer = setTimeout(() => {
286
- this.searchFilter.emit(this.searchText);
287
- }, SEARCH_DEBOUNCE_MS);
192
+ handleTriggerFocus = () => {
193
+ this.triggerHasFocus = true;
194
+ this.syncFocusedState();
288
195
  };
289
- handleClear = (e) => {
290
- e.stopPropagation();
291
- this.searchText = '';
292
- if (this.debounceTimer)
293
- clearTimeout(this.debounceTimer);
294
- this.searchFilter.emit('');
295
- this.inputEl?.focus();
196
+ handleTriggerBlur = () => {
197
+ this.triggerHasFocus = false;
198
+ this.syncFocusedState();
199
+ };
200
+ handleTriggerClick = () => {
201
+ if (this.isOpen) {
202
+ this.closeDropdown();
203
+ return;
204
+ }
205
+ this.prepareDropdownGeometry();
206
+ if (this.closeAnimationTimer)
207
+ clearTimeout(this.closeAnimationTimer);
208
+ this.isAnimatingOut = false;
209
+ this.isOpen = true;
210
+ };
211
+ emitUpdate(value) {
212
+ this.update.emit(value);
213
+ }
214
+ handleOptionSelect = (detail) => {
215
+ const { option, leaves } = detail;
216
+ if (this.isMulti) {
217
+ this.handleMultiSelect(option, leaves);
218
+ }
219
+ else {
220
+ this.closeDropdown();
221
+ this.value = this.emitValue ? option.value : option;
222
+ const nextValue = this.value;
223
+ requestAnimationFrame(() => {
224
+ this.emitUpdate(nextValue);
225
+ });
226
+ }
296
227
  };
228
+ handleMultiSelect(option, leaves) {
229
+ const selected = this.getSelectedOptions();
230
+ const isGroup = !!option.children;
231
+ let newSelected;
232
+ if (isGroup) {
233
+ const allSelected = leaves.every(l => selected.some(s => s.value === l.value));
234
+ if (allSelected) {
235
+ const leafValues = new Set(leaves.map(l => l.value));
236
+ newSelected = selected.filter(s => !leafValues.has(s.value));
237
+ }
238
+ else {
239
+ const existing = new Set(selected.map(s => s.value));
240
+ const toAdd = leaves.filter(l => !existing.has(l.value));
241
+ newSelected = [...selected, ...toAdd];
242
+ }
243
+ }
244
+ else {
245
+ const exists = selected.some(s => s.value === option.value);
246
+ newSelected = exists ? selected.filter(s => s.value !== option.value) : [...selected, option];
247
+ }
248
+ this.value = this.toMultiValue(newSelected);
249
+ this.emitUpdate(this.value);
250
+ }
251
+ connectedCallback() {
252
+ window.addEventListener('resize', this.handleViewportResize);
253
+ }
297
254
  disconnectedCallback() {
298
- if (this.focusRafId)
299
- cancelAnimationFrame(this.focusRafId);
300
- if (this.debounceTimer)
301
- clearTimeout(this.debounceTimer);
255
+ window.removeEventListener('resize', this.handleViewportResize);
256
+ if (this.closeAnimationTimer)
257
+ clearTimeout(this.closeAnimationTimer);
302
258
  }
303
259
  render() {
304
- return (index.h("div", { key: '139aa74cb44baef15a5a75008dd291f11ad2965b', class: {
305
- 'sd-select-list-item-search': true,
306
- 'sd-select-list-item-search--scrolled': this.isScrolled,
307
- } }, index.h("div", { key: '2df6559c3a0e769e50e72ef06828adcf595fc433', class: "sd-select-list-item-search__inner" }, index.h("sd-icon", { key: '20dfe4a309c7879bcdd1e5890f183a9e1eb98fae', name: "search", size: 16, color: "grey_70", class: "sd-select-list-item-search__icon" }), index.h("input", { key: '825724eedf71693ce39a21f413c5a4eb6f1495e3', ref: el => {
308
- this.inputEl = el;
309
- }, type: "text", class: "sd-select-list-item-search__input", placeholder: "\uAC80\uC0C9\uC5B4 \uC785\uB825", value: this.searchText, onInput: this.handleInput, onFocus: () => this.searchFocus.emit() }), index.h("button", { key: '20fb0c745d423b008f482a2e33e7e711ea40b5df', type: "button", class: {
310
- 'sd-select-list-item-search__clear': true,
311
- 'sd-select-list-item-search__clear--hidden': !this.searchText,
312
- }, onClick: this.handleClear, tabindex: this.searchText ? 0 : -1, "aria-hidden": this.searchText ? 'false' : 'true' }, index.h("sd-icon", { key: 'ce6e4f9b5281ebb767d6542a223e425660ec01c9', name: "close", size: 12, color: "#888888" })))));
260
+ const portalProps = {
261
+ open: this.isOpen,
262
+ parentRef: this.triggerRef,
263
+ viewportPadding: SdSelect.VIEWPORT_PADDING,
264
+ onSdClose: () => {
265
+ this.closeDropdown();
266
+ },
267
+ };
268
+ return (index.h("sd-field", { key: '668df27ea03b5c2479f89649c494375bacd762ec', name: this.name, label: this.label, labelWidth: this.labelWidth, addonLabel: this.addonLabel, addonAlign: this.addonAlign, hint: this.hint, errorMessage: this.errorMessage, width: this.width, rules: this.rules, error: this.error, disabled: this.disabled, focused: this.focused, hovered: this.hovered, icon: this.icon, labelTooltip: this.labelTooltip, labelTooltipProps: this.labelTooltipProps, onMouseEnter: () => {
269
+ this.hovered = true;
270
+ }, onMouseLeave: () => {
271
+ this.hovered = false;
272
+ } }, index.h("div", { key: '7d391d2c0719c165e9d19f5fdc34d39c374401e9', class: "sd-select", ref: el => {
273
+ this.triggerRef = el;
274
+ } }, index.h("sd-select-trigger", { key: 'b09a0f9dcb0071b79a21c8184deb7d07ba54185f', ref: el => {
275
+ this.triggerComponentRef = el;
276
+ }, displayText: this.displayText, placeholder: this.placeholder ?? '선택', disabled: this.disabled, isOpen: this.isOpen, onSdTriggerClick: this.handleTriggerClick, onSdTriggerFocus: this.handleTriggerFocus, onSdTriggerBlur: this.handleTriggerBlur })), (this.isOpen || this.isAnimatingOut) && (index.h("sd-portal", { key: '2ae67c5e98c66c2a74ba96f4602ea14d53dd0177', ...portalProps }, index.h("sd-select-listbox", { key: '97ee517fa777abd4926f8105fd046e39dfeeb5ff', type: this.type, options: this.options, value: this.value, emitValue: this.emitValue, useSearch: this.useSearch, useSelectAll: this.useSelectAll, triggerWidth: this.triggerWidth, maxWidth: this.resolvedMaxDropdownWidth, maxHeight: this.resolvedDropdownHeight, onSdOptionSelect: event => this.handleOptionSelect(event.detail) })))));
313
277
  }
278
+ static get watchers() { return {
279
+ "isOpen": [{
280
+ "watchIsOpen": 0
281
+ }]
282
+ }; }
314
283
  };
315
- SdSelectListItemSearch.style = sdSelectListItemSearchCss();
284
+ SdSelect.style = sdSelectCss();
316
285
 
317
286
  const sdSelectListboxCss = () => `:host{display:block}:host .sd-select-listbox{display:flex;flex-direction:column;width:var(--listbox-trigger-width);max-width:var(--listbox-max-width);max-height:var(--listbox-max-height);border-radius:var(--listbox-radius);background:white;box-shadow:2px 2px 12px 2px rgba(0, 0, 0, 0.1);overflow:hidden;outline:none}:host .sd-select-listbox__list{flex:1;min-height:0;overflow-y:auto;padding-bottom:0}:host .sd-select-listbox__empty{padding:12px;text-align:center;font-size:12px;line-height:20px;color:#888888}`;
318
287
 
@@ -378,24 +347,24 @@ const SdSelectListbox = class {
378
347
  get showSearch() {
379
348
  if (!this.useSearch)
380
349
  return false;
381
- const count = this.isDepth ? countLeaves(this.options) : this.options.length;
382
- return count >= SEARCH_THRESHOLD;
350
+ const count = this.isDepth ? sdSelect_config.countLeaves(this.options) : this.options.length;
351
+ return count >= sdSelect_config.SEARCH_THRESHOLD;
383
352
  }
384
353
  get filteredOptions() {
385
- if (!this.searchKeyword)
354
+ if (this.searchKeyword === '')
386
355
  return this.options;
387
356
  if (this.isDepth)
388
- return filterTree(this.options, this.searchKeyword);
357
+ return sdSelect_config.filterTree(this.options, this.searchKeyword);
389
358
  const keyword = this.searchKeyword.toLowerCase();
390
359
  return this.options.filter(o => o.label.toLowerCase().includes(keyword));
391
360
  }
392
361
  get isEmpty() {
393
362
  if (this.isDepth)
394
- return countLeaves(this.filteredOptions) === 0 && this.filteredOptions.length === 0;
363
+ return sdSelect_config.countLeaves(this.filteredOptions) === 0 && this.filteredOptions.length === 0;
395
364
  return this.filteredOptions.length === 0;
396
365
  }
397
366
  getSelectedValues() {
398
- if (!this.value || !Array.isArray(this.value))
367
+ if (this.value == null || !Array.isArray(this.value))
399
368
  return new Set();
400
369
  if (this.emitValue) {
401
370
  return new Set(this.value);
@@ -518,7 +487,7 @@ const SdSelectListbox = class {
518
487
  // filterTree 가 매 호출마다 옵션 객체를 새로 복제하기 때문에 참조 비교
519
488
  // (=== / indexOf) 는 검색이 적용된 동안 항상 실패한다. 고유 식별자인
520
489
  // value 로 비교해야 한다.
521
- return !!focused && focused.value === option.value;
490
+ return focused != null && focused.value === option.value;
522
491
  }
523
492
  resetFocusOnFilter() {
524
493
  // 필터가 바뀌면 이전 인덱스가 가리키던 항목이 사라질 수 있으므로
@@ -663,14 +632,14 @@ const SdSelectListbox = class {
663
632
  }
664
633
  render() {
665
634
  const cssVars = {
666
- '--listbox-trigger-width': this.triggerWidth,
667
- '--listbox-max-width': this.maxWidth,
668
- '--listbox-max-height': this.maxHeight,
669
- '--listbox-radius': `${LIST_BOX_LAYOUT.radius}px`,
635
+ '--listbox-trigger-width': this.triggerWidth ?? '200px',
636
+ '--listbox-max-width': this.maxWidth ?? '640px',
637
+ '--listbox-max-height': this.maxHeight ?? '260px',
638
+ '--listbox-radius': `${sdSelect_config.LIST_BOX_LAYOUT.radius}px`,
670
639
  };
671
- return (index.h("div", { key: 'c1582b1bc6058b78a8581511854f0878e7f39a94', class: "sd-select-listbox", style: cssVars }, this.showSearch && (index.h("sd-select-list-item-search", { key: '4fd2099bf8069f258596479123053a34a41c528d', isScrolled: this.isScrolled, onSdSearchFilter: this.handleSearchFilter })), index.h("div", { key: 'ff8643a308b07dbaebf627c7082a37efa6b72a10', class: "sd-select-listbox__list", onScroll: this.handleScroll, ref: el => {
640
+ return (index.h("div", { key: '8c9b1a4471bf4e535c5f156d087e1b9be76ad903', class: "sd-select-listbox", style: cssVars }, this.showSearch && (index.h("sd-select-list-item-search", { key: '4cc596a1ac21c9b258d5db07ecb15d566179d743', isScrolled: this.isScrolled, onSdSearchFilter: this.handleSearchFilter })), index.h("div", { key: '977e15c7987ca387cf30783741f99b322150627b', class: "sd-select-listbox__list", onScroll: this.handleScroll, ref: el => {
672
641
  this.listEl = el;
673
- } }, this.showSelectAll && (index.h("sd-select-list-item", { key: '30f0cfbc24304af8c704db33d0e51236971226ee', option: SdSelectListbox.SELECT_ALL_OPTION, depth: 1, isSelected: this.selectAllState, isFocused: this.isOptionFocused(SdSelectListbox.SELECT_ALL_OPTION), useCheckbox: true, onSdListItemClick: this.handleSelectAllClick, onMouseEnter: () => this.handleOptionHover(SdSelectListbox.SELECT_ALL_OPTION) })), this.isEmpty ? (index.h("div", { class: "sd-select-listbox__empty" }, EMPTY_MESSAGE)) : this.isDepth ? (this.renderOptions(this.filteredOptions)) : (this.filteredOptions.map(option => (index.h("sd-select-list-item", { option: option, depth: 1, isSelected: this.isOptionSelected(option), isFocused: this.isOptionFocused(option), useCheckbox: this.isMulti, onSdListItemClick: this.handleOptionClick, onMouseEnter: () => this.handleOptionHover(option) })))))));
642
+ } }, this.showSelectAll && (index.h("sd-select-list-item", { key: 'dada5a6662b2d3fa63ed11ab1c82561d5e2d2400', option: SdSelectListbox.SELECT_ALL_OPTION, depth: 1, isSelected: this.selectAllState, isFocused: this.isOptionFocused(SdSelectListbox.SELECT_ALL_OPTION), useCheckbox: true, onSdListItemClick: this.handleSelectAllClick, onMouseEnter: () => this.handleOptionHover(SdSelectListbox.SELECT_ALL_OPTION) })), this.isEmpty ? (index.h("div", { class: "sd-select-listbox__empty" }, sdSelect_config.EMPTY_MESSAGE)) : this.isDepth ? (this.renderOptions(this.filteredOptions)) : (this.filteredOptions.map(option => (index.h("sd-select-list-item", { option: option, depth: 1, isSelected: this.isOptionSelected(option), isFocused: this.isOptionFocused(option), useCheckbox: this.isMulti, onSdListItemClick: this.handleOptionClick, onMouseEnter: () => this.handleOptionHover(option) })))))));
674
643
  }
675
644
  static get watchers() { return {
676
645
  "searchKeyword": [{
@@ -714,29 +683,34 @@ const SdSelectTrigger = class {
714
683
  this.triggerBlur.emit();
715
684
  };
716
685
  render() {
717
- const hasValue = !!this.displayText;
686
+ const hasValue = this.displayText !== '';
718
687
  const cssVars = {
719
- '--trigger-padding-x': `${SELECT_LAYOUT.paddingX}px`,
720
- '--trigger-gap': `${SELECT_LAYOUT.gap}px`,
721
- '--trigger-font-size': `${SELECT_TYPOGRAPHY.fontSize}px`,
722
- '--trigger-line-height': `${SELECT_TYPOGRAPHY.lineHeight}px`,
723
- '--trigger-font-weight': SELECT_TYPOGRAPHY.fontWeight,
688
+ '--trigger-padding-x': `${sdSelect_config.SELECT_LAYOUT.paddingX}px`,
689
+ '--trigger-gap': `${sdSelect_config.SELECT_LAYOUT.gap}px`,
690
+ '--trigger-font-size': `${sdSelect_config.SELECT_TYPOGRAPHY.fontSize}px`,
691
+ '--trigger-line-height': `${sdSelect_config.SELECT_TYPOGRAPHY.lineHeight}px`,
692
+ '--trigger-font-weight': sdSelect_config.SELECT_TYPOGRAPHY.fontWeight,
724
693
  '--trigger-color': this.disabled
725
- ? SELECT_COLORS.text.disabled
694
+ ? sdSelect_config.SELECT_COLORS.text.disabled
726
695
  : hasValue
727
- ? SELECT_COLORS.text.default
728
- : SELECT_COLORS.icon.default,
696
+ ? sdSelect_config.SELECT_COLORS.text.default
697
+ : sdSelect_config.SELECT_COLORS.icon.default,
729
698
  '--trigger-icon-color': this.disabled
730
- ? SELECT_COLORS.icon.disabled
731
- : SELECT_COLORS.icon.default,
699
+ ? sdSelect_config.SELECT_COLORS.icon.disabled
700
+ : sdSelect_config.SELECT_COLORS.icon.default,
732
701
  };
733
- return (index.h("div", { key: 'dddccfd47738e104a9c715a0c93df1882d28d704', ref: el => {
702
+ return (index.h("div", { key: '67cb0ffaf0197a3ad12c402810317801ce69d4a1', ref: el => {
734
703
  this.triggerEl = el;
735
- }, tabindex: this.disabled ? -1 : 0, class: {
704
+ }, role: "button", "aria-haspopup": "listbox", "aria-expanded": this.isOpen ? 'true' : 'false', tabindex: this.disabled ? -1 : 0, class: {
736
705
  'sd-select-trigger': true,
737
706
  'sd-select-trigger--open': this.isOpen,
738
707
  'sd-select-trigger--disabled': this.disabled,
739
- }, style: cssVars, onClick: this.handleClick, onFocus: this.handleFocus, onBlur: this.handleBlur }, index.h("div", { key: '9f8572c4ec3fa02c9f94bb94a8a10358c4d6b3ae', class: "sd-select-trigger__content" }, index.h("span", { key: 'a4b5b27fc3a84adbd2e24981742ca45402993afb', class: "sd-select-trigger__text" }, hasValue ? this.displayText : this.placeholder), index.h("sd-icon", { key: '97bbcda656bae2248ca83fb2bd56373b2dd8dd41', name: "chevronDown", size: 12, color: "var(--trigger-icon-color)", class: {
708
+ }, style: cssVars, onClick: this.handleClick, onKeyDown: e => {
709
+ if (e.key === 'Enter' || e.key === ' ') {
710
+ e.preventDefault();
711
+ this.handleClick();
712
+ }
713
+ }, onFocus: this.handleFocus, onBlur: this.handleBlur }, index.h("div", { key: '4c28c852054fd7b09e5c45c9eb13882540f66553', class: "sd-select-trigger__content" }, index.h("span", { key: 'df415c9ac8d00a58e5539c8c655f12ebd49208a4', class: "sd-select-trigger__text" }, hasValue ? this.displayText : (this.placeholder ?? '선택')), index.h("sd-icon", { key: '429008e1edaf778e8a85f945a681cd675f2489b7', name: "chevronDown", size: 12, color: "var(--trigger-icon-color)", class: {
740
714
  'sd-select-trigger__icon': true,
741
715
  'sd-select-trigger__icon--open': this.isOpen,
742
716
  } }))));
@@ -744,7 +718,6 @@ const SdSelectTrigger = class {
744
718
  };
745
719
  SdSelectTrigger.style = sdSelectTriggerCss();
746
720
 
747
- exports.sd_select_list_item = SdSelectListItem;
748
- exports.sd_select_list_item_search = SdSelectListItemSearch;
721
+ exports.sd_select = SdSelect;
749
722
  exports.sd_select_listbox = SdSelectListbox;
750
723
  exports.sd_select_trigger = SdSelectTrigger;