@sellmate/design-system 0.0.55 → 1.0.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 (495) hide show
  1. package/dist/cjs/{select-keyboard-navigation-6fO_V4En.js → base-dropdown-event-Dc6AuxR4.js} +26 -26
  2. package/dist/cjs/base-dropdown-event-Dc6AuxR4.js.map +1 -0
  3. package/dist/cjs/design-system.cjs.js +2 -2
  4. package/dist/cjs/{index-B7tkxTye.js → index-D_J8ScR5.js} +3 -3
  5. package/dist/cjs/index-D_J8ScR5.js.map +1 -0
  6. package/dist/cjs/loader.cjs.js +2 -2
  7. package/dist/cjs/{resolveColor-DxvExwgo.js → resolveColor-B7Ku3IGq.js} +4 -5
  8. package/dist/{esm/resolveColor-BYf-ybt2.js.map → cjs/resolveColor-B7Ku3IGq.js.map} +1 -1
  9. package/dist/cjs/sd-badge.cjs.entry.js +4 -4
  10. package/dist/cjs/{sd-button_24.cjs.entry.js → sd-button_6.cjs.entry.js} +292 -2842
  11. package/dist/cjs/sd-card.cjs.entry.js +4 -4
  12. package/dist/cjs/sd-checkbox.cjs.entry.js +89 -0
  13. package/dist/cjs/sd-date-box.cjs.entry.js +10 -10
  14. package/dist/cjs/sd-date-picker.cjs.entry.js +5 -5
  15. package/dist/cjs/sd-date-range-picker.cjs.entry.js +8 -8
  16. package/dist/cjs/sd-field_3.cjs.entry.js +422 -0
  17. package/dist/cjs/sd-file-picker.cjs.entry.js +121 -0
  18. package/dist/cjs/sd-form.cjs.entry.js +74 -0
  19. package/dist/cjs/sd-guide.cjs.entry.js +81 -0
  20. package/dist/cjs/sd-loading-spinner_2.cjs.entry.js +195 -0
  21. package/dist/cjs/sd-modal-card.cjs.entry.js +8 -8
  22. package/dist/cjs/sd-number-input.cjs.entry.js +261 -0
  23. package/dist/cjs/sd-popover.cjs.entry.js +7 -7
  24. package/dist/cjs/sd-progress.cjs.entry.js +1 -1
  25. package/dist/cjs/sd-radio-button-group.cjs.entry.js +8 -21
  26. package/dist/cjs/sd-radio-group.cjs.entry.js +71 -0
  27. package/dist/cjs/sd-select-dropdown_3.cjs.entry.js +266 -0
  28. package/dist/cjs/sd-select-multiple-group.cjs.entry.js +446 -0
  29. package/dist/cjs/sd-select-multiple.cjs.entry.js +74 -152
  30. package/dist/cjs/sd-select-option-group.cjs.entry.js +69 -0
  31. package/dist/cjs/sd-table.cjs.entry.js +515 -85
  32. package/dist/cjs/sd-tabs.cjs.entry.js +66 -0
  33. package/dist/cjs/sd-tag.cjs.entry.js +57 -0
  34. package/dist/cjs/sd-toast-message.cjs.entry.js +61 -0
  35. package/dist/cjs/sd-toggle-button.cjs.entry.js +50 -0
  36. package/dist/cjs/sd-toggle.cjs.entry.js +46 -0
  37. package/dist/cjs/{tooltipArrow-8I9A3AOE.js → tooltipArrow-DU2DB2AD.js} +3 -3
  38. package/dist/cjs/{tooltipArrow-8I9A3AOE.js.map → tooltipArrow-DU2DB2AD.js.map} +1 -1
  39. package/dist/collection/collection-manifest.json +7 -8
  40. package/dist/collection/components/sd-badge/sd-badge.css +8 -9
  41. package/dist/collection/components/sd-badge/sd-badge.js +1 -2
  42. package/dist/collection/components/sd-badge/sd-badge.js.map +1 -1
  43. package/dist/collection/components/sd-button/sd-button.css +2 -1
  44. package/dist/collection/components/sd-button/sd-button.js +2 -34
  45. package/dist/collection/components/sd-button/sd-button.js.map +1 -1
  46. package/dist/collection/components/sd-card/sd-card.css +1 -3
  47. package/dist/collection/components/sd-card/sd-card.js +6 -6
  48. package/dist/collection/components/sd-card/sd-card.js.map +1 -1
  49. package/dist/collection/components/sd-checkbox/sd-checkbox.js +16 -16
  50. package/dist/collection/components/sd-checkbox/sd-checkbox.js.map +1 -1
  51. package/dist/collection/components/sd-date-box/sd-date-box.css +1 -0
  52. package/dist/collection/components/sd-date-box/sd-date-box.js +8 -8
  53. package/dist/collection/components/sd-date-box/sd-date-box.js.map +1 -1
  54. package/dist/collection/components/sd-date-picker/sd-date-picker.js +5 -5
  55. package/dist/collection/components/sd-date-picker/sd-date-picker.js.map +1 -1
  56. package/dist/collection/components/sd-date-range-picker/sd-date-range-picker.css +9 -6
  57. package/dist/collection/components/sd-date-range-picker/sd-date-range-picker.js +8 -8
  58. package/dist/collection/components/sd-date-range-picker/sd-date-range-picker.js.map +1 -1
  59. package/dist/collection/components/sd-field/sd-field.css +100 -0
  60. package/dist/collection/components/sd-field/sd-field.js +472 -0
  61. package/dist/collection/components/sd-field/sd-field.js.map +1 -0
  62. package/dist/collection/components/sd-file-picker/sd-file-picker.css +6 -0
  63. package/dist/collection/components/sd-file-picker/sd-file-picker.js +8 -8
  64. package/dist/collection/components/sd-file-picker/sd-file-picker.js.map +1 -1
  65. package/dist/collection/components/sd-floating-portal/sd-floating-portal.css +103 -0
  66. package/dist/collection/components/{sd-tooltip-portal/sd-tooltip-portal.js → sd-floating-portal/sd-floating-portal.js} +18 -9
  67. package/dist/collection/components/sd-floating-portal/sd-floating-portal.js.map +1 -0
  68. package/dist/collection/components/sd-form/sd-form.js +200 -0
  69. package/dist/collection/components/sd-form/sd-form.js.map +1 -0
  70. package/dist/collection/components/sd-guide/sd-guide.css +3 -2
  71. package/dist/collection/components/sd-guide/sd-guide.js +7 -8
  72. package/dist/collection/components/sd-guide/sd-guide.js.map +1 -1
  73. package/dist/collection/components/sd-icon/sd-icon.js +1 -1
  74. package/dist/collection/components/sd-input/sd-input.css +43 -100
  75. package/dist/collection/components/sd-input/sd-input.js +285 -114
  76. package/dist/collection/components/sd-input/sd-input.js.map +1 -1
  77. package/dist/collection/components/sd-modal-card/sd-modal-card.css +1 -0
  78. package/dist/collection/components/sd-modal-card/sd-modal-card.js +5 -5
  79. package/dist/collection/components/sd-modal-card/sd-modal-card.js.map +1 -1
  80. package/dist/collection/components/sd-number-input/sd-number-input.js +18 -84
  81. package/dist/collection/components/sd-number-input/sd-number-input.js.map +1 -1
  82. package/dist/collection/components/sd-pagination/sd-pagination.js +4 -3
  83. package/dist/collection/components/sd-pagination/sd-pagination.js.map +1 -1
  84. package/dist/collection/components/sd-popover/sd-popover.css +2 -2
  85. package/dist/collection/components/sd-popover/sd-popover.js +4 -5
  86. package/dist/collection/components/sd-popover/sd-popover.js.map +1 -1
  87. package/dist/collection/components/sd-portal/sd-portal.js +4 -4
  88. package/dist/collection/components/sd-portal/sd-portal.js.map +1 -1
  89. package/dist/collection/components/sd-radio-button-group/sd-radio-button-group.js +9 -30
  90. package/dist/collection/components/sd-radio-button-group/sd-radio-button-group.js.map +1 -1
  91. package/dist/collection/components/sd-radio-group/sd-radio-group.js +5 -5
  92. package/dist/collection/components/sd-radio-group/sd-radio-group.js.map +1 -1
  93. package/dist/collection/components/sd-select/sd-select-dropdown/sd-select-dropdown.css +52 -0
  94. package/dist/collection/components/sd-select/sd-select-dropdown/sd-select-dropdown.js +441 -0
  95. package/dist/collection/components/sd-select/sd-select-dropdown/sd-select-dropdown.js.map +1 -0
  96. package/dist/collection/components/sd-select/sd-select-option/sd-select-option.js +4 -4
  97. package/dist/collection/components/sd-select/sd-select-option/sd-select-option.js.map +1 -1
  98. package/dist/collection/components/sd-select/sd-select-search-input/sd-select-search-input.css +11 -3
  99. package/dist/collection/components/sd-select/sd-select-search-input/sd-select-search-input.js +15 -15
  100. package/dist/collection/components/sd-select/sd-select-search-input/sd-select-search-input.js.map +1 -1
  101. package/dist/collection/components/sd-select/sd-select.css +9 -97
  102. package/dist/collection/components/sd-select/sd-select.js +320 -219
  103. package/dist/collection/components/sd-select/sd-select.js.map +1 -1
  104. package/dist/collection/components/sd-select-multiple/sd-select-multiple.css +16 -102
  105. package/dist/collection/components/sd-select-multiple/sd-select-multiple.js +328 -179
  106. package/dist/collection/components/sd-select-multiple/sd-select-multiple.js.map +1 -1
  107. package/dist/collection/components/sd-select-multiple-group/sd-select-multiple-group.css +8 -45
  108. package/dist/collection/components/sd-select-multiple-group/sd-select-multiple-group.js +265 -47
  109. package/dist/collection/components/sd-select-multiple-group/sd-select-multiple-group.js.map +1 -1
  110. package/dist/collection/components/sd-select-multiple-group/sd-select-option-group/sd-select-option-group.js +3 -3
  111. package/dist/collection/components/sd-select-multiple-group/sd-select-option-group/sd-select-option-group.js.map +1 -1
  112. package/dist/collection/components/sd-table/sd-table.css +121 -30
  113. package/dist/collection/components/sd-table/sd-table.js +629 -92
  114. package/dist/collection/components/sd-table/sd-table.js.map +1 -1
  115. package/dist/collection/components/sd-tabs/sd-tabs.css +10 -7
  116. package/dist/collection/components/sd-tabs/sd-tabs.js +10 -17
  117. package/dist/collection/components/sd-tabs/sd-tabs.js.map +1 -1
  118. package/dist/collection/components/sd-tag/sd-tag.js +1 -1
  119. package/dist/collection/components/sd-textarea/sd-textarea.css +66 -0
  120. package/dist/collection/components/sd-textarea/sd-textarea.js +400 -0
  121. package/dist/collection/components/sd-textarea/sd-textarea.js.map +1 -0
  122. package/dist/collection/components/sd-toast-message/sd-toast-message.js +11 -11
  123. package/dist/collection/components/sd-toast-message/sd-toast-message.js.map +1 -1
  124. package/dist/collection/components/sd-toggle/sd-toggle.js +8 -14
  125. package/dist/collection/components/sd-toggle/sd-toggle.js.map +1 -1
  126. package/dist/collection/components/sd-toggle-button/sd-toggle-button.js +5 -5
  127. package/dist/collection/components/sd-toggle-button/sd-toggle-button.js.map +1 -1
  128. package/dist/collection/components/sd-tooltip/sd-tooltip.css +6 -65
  129. package/dist/collection/components/sd-tooltip/sd-tooltip.js +12 -29
  130. package/dist/collection/components/sd-tooltip/sd-tooltip.js.map +1 -1
  131. package/dist/collection/types/select.js.map +1 -1
  132. package/dist/components/index.js +1 -1
  133. package/dist/components/p-7xekTQRB.js +104 -0
  134. package/dist/components/p-7xekTQRB.js.map +1 -0
  135. package/dist/components/{p-BDkKpeVz.js → p-BKSlQGJv.js} +3 -3
  136. package/dist/components/{p-BDkKpeVz.js.map → p-BKSlQGJv.js.map} +1 -1
  137. package/dist/components/{p-njRAT-yp.js → p-CVMprLsE.js} +17 -15
  138. package/dist/components/p-CVMprLsE.js.map +1 -0
  139. package/dist/components/p-CdGD6AqM.js +92 -0
  140. package/dist/components/p-CdGD6AqM.js.map +1 -0
  141. package/dist/components/p-CpRkV7pg.js +201 -0
  142. package/dist/components/p-CpRkV7pg.js.map +1 -0
  143. package/dist/components/p-D2movWkD.js +289 -0
  144. package/dist/components/p-D2movWkD.js.map +1 -0
  145. package/dist/components/p-D54IEoI6.js +238 -0
  146. package/dist/components/p-D54IEoI6.js.map +1 -0
  147. package/dist/components/{p-D5BkkT2U.js → p-DbebUQwg.js} +7 -7
  148. package/dist/components/{p-D5BkkT2U.js.map → p-DbebUQwg.js.map} +1 -1
  149. package/dist/components/{p-BYf-ybt2.js → p-DcGvp3RM.js} +5 -5
  150. package/dist/components/p-DcGvp3RM.js.map +1 -0
  151. package/dist/components/{p-nqDJZ_gy.js → p-DdKGhMHk.js} +4 -4
  152. package/dist/components/{p-nqDJZ_gy.js.map → p-DdKGhMHk.js.map} +1 -1
  153. package/dist/components/{p-BxPT3VKO.js → p-DlJtPR_C.js} +12 -12
  154. package/dist/components/p-DlJtPR_C.js.map +1 -0
  155. package/dist/components/{p-vhe6g4Qt.js → p-DnQF6htq.js} +5 -5
  156. package/dist/components/{p-vhe6g4Qt.js.map → p-DnQF6htq.js.map} +1 -1
  157. package/dist/components/{p-BA38jFi5.js → p-DssRJcAn.js} +4 -4
  158. package/dist/components/{p-BA38jFi5.js.map → p-DssRJcAn.js.map} +1 -1
  159. package/dist/components/{p-B3H_uLbl.js → p-Dt-KAeBx.js} +3 -3
  160. package/dist/components/{p-B3H_uLbl.js.map → p-Dt-KAeBx.js.map} +1 -1
  161. package/dist/components/{p-DRGcUx0C.js → p-DxSmO6Tr.js} +8 -7
  162. package/dist/components/p-DxSmO6Tr.js.map +1 -0
  163. package/dist/components/{p-CWwMpVqI.js → p-JF61vPAh.js} +9 -9
  164. package/dist/components/p-JF61vPAh.js.map +1 -0
  165. package/dist/components/p-RhBqdixM.js +102 -0
  166. package/dist/components/p-RhBqdixM.js.map +1 -0
  167. package/dist/components/{p-CKhzpdPk.js → p-UZEmuyIR.js} +19 -19
  168. package/dist/components/p-UZEmuyIR.js.map +1 -0
  169. package/dist/components/{p-CQBrru3e.js → p-YLoygqPr.js} +3 -3
  170. package/dist/components/p-YLoygqPr.js.map +1 -0
  171. package/dist/components/p-s4Mg_xSz.js +260 -0
  172. package/dist/components/p-s4Mg_xSz.js.map +1 -0
  173. package/dist/components/{p-MRYVk6Qh.js → p-zvZtN3nR.js} +8 -8
  174. package/dist/components/{p-MRYVk6Qh.js.map → p-zvZtN3nR.js.map} +1 -1
  175. package/dist/components/sd-badge.js +5 -5
  176. package/dist/components/sd-badge.js.map +1 -1
  177. package/dist/components/sd-button.js +1 -1
  178. package/dist/components/sd-card.js +5 -5
  179. package/dist/components/sd-card.js.map +1 -1
  180. package/dist/components/sd-checkbox.js +1 -1
  181. package/dist/components/sd-date-box.js +1 -1
  182. package/dist/components/sd-date-picker.js +37 -13
  183. package/dist/components/sd-date-picker.js.map +1 -1
  184. package/dist/components/sd-date-range-picker.js +41 -17
  185. package/dist/components/sd-date-range-picker.js.map +1 -1
  186. package/dist/components/{sd-td.d.ts → sd-field.d.ts} +4 -4
  187. package/dist/components/sd-field.js +9 -0
  188. package/dist/components/sd-field.js.map +1 -0
  189. package/dist/components/sd-file-picker.js +10 -10
  190. package/dist/components/sd-file-picker.js.map +1 -1
  191. package/dist/components/{sd-table-backup.d.ts → sd-floating-portal.d.ts} +4 -4
  192. package/dist/components/sd-floating-portal.js +9 -0
  193. package/dist/components/sd-floating-portal.js.map +1 -0
  194. package/dist/components/{sd-th.d.ts → sd-form.d.ts} +4 -4
  195. package/dist/components/sd-form.js +99 -0
  196. package/dist/components/sd-form.js.map +1 -0
  197. package/dist/components/sd-guide.js +12 -13
  198. package/dist/components/sd-guide.js.map +1 -1
  199. package/dist/components/sd-icon.js +1 -1
  200. package/dist/components/sd-input.js +1 -1
  201. package/dist/components/sd-loading-spinner.js +1 -1
  202. package/dist/components/sd-modal-card.js +10 -10
  203. package/dist/components/sd-modal-card.js.map +1 -1
  204. package/dist/components/sd-number-input.js +19 -43
  205. package/dist/components/sd-number-input.js.map +1 -1
  206. package/dist/components/sd-pagination.js +1 -1
  207. package/dist/components/sd-popover.js +14 -15
  208. package/dist/components/sd-popover.js.map +1 -1
  209. package/dist/components/sd-portal.js +1 -1
  210. package/dist/components/sd-progress.js +1 -1
  211. package/dist/components/sd-radio-button-group.js +10 -26
  212. package/dist/components/sd-radio-button-group.js.map +1 -1
  213. package/dist/components/sd-radio-group.js +5 -5
  214. package/dist/components/sd-radio-group.js.map +1 -1
  215. package/dist/components/{sd-tbody.d.ts → sd-select-dropdown.d.ts} +4 -4
  216. package/dist/components/sd-select-dropdown.js +9 -0
  217. package/dist/components/sd-select-dropdown.js.map +1 -0
  218. package/dist/components/sd-select-multiple-group.js +97 -40
  219. package/dist/components/sd-select-multiple-group.js.map +1 -1
  220. package/dist/components/sd-select-multiple.js +133 -168
  221. package/dist/components/sd-select-multiple.js.map +1 -1
  222. package/dist/components/sd-select-option-group.js +1 -1
  223. package/dist/components/sd-select-option.js +1 -1
  224. package/dist/components/sd-select-search-input.js +1 -1
  225. package/dist/components/sd-select.js +1 -1
  226. package/dist/components/sd-table.js +555 -113
  227. package/dist/components/sd-table.js.map +1 -1
  228. package/dist/components/sd-tabs.js +13 -16
  229. package/dist/components/sd-tabs.js.map +1 -1
  230. package/dist/components/sd-tag.js +1 -1
  231. package/dist/components/{sd-tr.d.ts → sd-textarea.d.ts} +4 -4
  232. package/dist/components/sd-textarea.js +145 -0
  233. package/dist/components/sd-textarea.js.map +1 -0
  234. package/dist/components/sd-toast-message.js +14 -14
  235. package/dist/components/sd-toast-message.js.map +1 -1
  236. package/dist/components/sd-toggle-button.js +5 -5
  237. package/dist/components/sd-toggle-button.js.map +1 -1
  238. package/dist/components/sd-toggle.js +9 -11
  239. package/dist/components/sd-toggle.js.map +1 -1
  240. package/dist/components/sd-tooltip.js +1 -1
  241. package/dist/design-system/design-system.css +1 -1
  242. package/dist/design-system/design-system.esm.js +1 -1
  243. package/dist/design-system/p-02e23509.entry.js +2 -0
  244. package/dist/design-system/p-02e23509.entry.js.map +1 -0
  245. package/dist/design-system/p-0a2f733d.entry.js +2 -0
  246. package/dist/design-system/p-0a2f733d.entry.js.map +1 -0
  247. package/dist/design-system/p-0d3f019d.entry.js +2 -0
  248. package/dist/design-system/p-0d3f019d.entry.js.map +1 -0
  249. package/dist/design-system/p-15dd1289.entry.js +2 -0
  250. package/dist/design-system/p-15dd1289.entry.js.map +1 -0
  251. package/dist/design-system/p-216c6543.entry.js +2 -0
  252. package/dist/design-system/p-216c6543.entry.js.map +1 -0
  253. package/dist/design-system/p-2400d67b.entry.js +2 -0
  254. package/dist/design-system/p-2400d67b.entry.js.map +1 -0
  255. package/dist/design-system/p-282f4087.entry.js +2 -0
  256. package/dist/design-system/p-282f4087.entry.js.map +1 -0
  257. package/dist/design-system/{p-7b94b34e.entry.js → p-388d5b9f.entry.js} +2 -2
  258. package/dist/design-system/p-4d7bb5b6.entry.js +2 -0
  259. package/dist/design-system/p-4d7bb5b6.entry.js.map +1 -0
  260. package/dist/design-system/p-53972259.entry.js +2 -0
  261. package/dist/design-system/p-53972259.entry.js.map +1 -0
  262. package/dist/design-system/p-6277b220.entry.js +2 -0
  263. package/dist/design-system/p-6277b220.entry.js.map +1 -0
  264. package/dist/design-system/p-652c4d37.entry.js +2 -0
  265. package/dist/design-system/p-652c4d37.entry.js.map +1 -0
  266. package/dist/design-system/p-661c4553.entry.js +2 -0
  267. package/dist/design-system/p-661c4553.entry.js.map +1 -0
  268. package/dist/design-system/p-686958c5.entry.js +2 -0
  269. package/dist/design-system/p-686958c5.entry.js.map +1 -0
  270. package/dist/design-system/p-811c5aa4.entry.js +2 -0
  271. package/dist/design-system/p-811c5aa4.entry.js.map +1 -0
  272. package/dist/design-system/p-827ca975.entry.js +2 -0
  273. package/dist/design-system/p-827ca975.entry.js.map +1 -0
  274. package/dist/design-system/p-8df72aa2.entry.js +2 -0
  275. package/dist/design-system/p-8df72aa2.entry.js.map +1 -0
  276. package/dist/design-system/p-9d2459ed.entry.js +2 -0
  277. package/dist/design-system/p-9d2459ed.entry.js.map +1 -0
  278. package/dist/design-system/p-BShXSO5x.js +2 -0
  279. package/dist/design-system/p-BShXSO5x.js.map +1 -0
  280. package/dist/design-system/{p-7X2nzJWz.js → p-C3qNZ7Qh.js} +3 -3
  281. package/dist/design-system/p-C3qNZ7Qh.js.map +1 -0
  282. package/dist/design-system/{p-CdbtuKYR.js → p-DPxE68eG.js} +2 -2
  283. package/dist/design-system/{p-CdbtuKYR.js.map → p-DPxE68eG.js.map} +1 -1
  284. package/dist/design-system/{p-BYf-ybt2.js → p-DcGvp3RM.js} +2 -2
  285. package/dist/design-system/{p-BYf-ybt2.js.map → p-DcGvp3RM.js.map} +1 -1
  286. package/dist/design-system/p-a7d4c6bd.entry.js +2 -0
  287. package/dist/design-system/p-a7d4c6bd.entry.js.map +1 -0
  288. package/dist/design-system/p-ac29c52c.entry.js +2 -0
  289. package/dist/design-system/p-ac29c52c.entry.js.map +1 -0
  290. package/dist/design-system/{p-7a424f6b.entry.js → p-b0277422.entry.js} +2 -2
  291. package/dist/design-system/p-b0277422.entry.js.map +1 -0
  292. package/dist/design-system/p-c25c4bd6.entry.js +2 -0
  293. package/dist/design-system/p-c25c4bd6.entry.js.map +1 -0
  294. package/dist/design-system/p-c3061828.entry.js +2 -0
  295. package/dist/design-system/p-c3061828.entry.js.map +1 -0
  296. package/dist/design-system/p-cde56c79.entry.js +2 -0
  297. package/dist/design-system/{p-2c57bdea.entry.js.map → p-cde56c79.entry.js.map} +1 -1
  298. package/dist/design-system/p-d77422e4.entry.js +2 -0
  299. package/dist/design-system/p-d77422e4.entry.js.map +1 -0
  300. package/dist/design-system/p-dc410414.entry.js +2 -0
  301. package/dist/design-system/p-dc410414.entry.js.map +1 -0
  302. package/dist/design-system/p-f254b09a.entry.js +2 -0
  303. package/dist/design-system/p-f254b09a.entry.js.map +1 -0
  304. package/dist/design-system/p-f3287206.entry.js +2 -0
  305. package/dist/design-system/p-f3287206.entry.js.map +1 -0
  306. package/dist/esm/{select-keyboard-navigation-C2JaR3A6.js → base-dropdown-event-BShXSO5x.js} +26 -26
  307. package/dist/esm/base-dropdown-event-BShXSO5x.js.map +1 -0
  308. package/dist/esm/design-system.js +3 -3
  309. package/dist/esm/{index-7X2nzJWz.js → index-C3qNZ7Qh.js} +3 -3
  310. package/dist/esm/index-C3qNZ7Qh.js.map +1 -0
  311. package/dist/esm/loader.js +3 -3
  312. package/dist/esm/{resolveColor-BYf-ybt2.js → resolveColor-DcGvp3RM.js} +5 -5
  313. package/dist/{cjs/resolveColor-DxvExwgo.js.map → esm/resolveColor-DcGvp3RM.js.map} +1 -1
  314. package/dist/esm/sd-badge.entry.js +4 -4
  315. package/dist/esm/sd-badge.entry.js.map +1 -1
  316. package/dist/esm/{sd-button_24.entry.js → sd-button_6.entry.js} +291 -2823
  317. package/dist/esm/sd-card.entry.js +4 -4
  318. package/dist/esm/sd-card.entry.js.map +1 -1
  319. package/dist/esm/sd-checkbox.entry.js +87 -0
  320. package/dist/esm/sd-checkbox.entry.js.map +1 -0
  321. package/dist/esm/sd-date-box.entry.js +10 -10
  322. package/dist/esm/sd-date-box.entry.js.map +1 -1
  323. package/dist/esm/sd-date-picker.entry.js +5 -5
  324. package/dist/esm/sd-date-picker.entry.js.map +1 -1
  325. package/dist/esm/sd-date-range-picker.entry.js +8 -8
  326. package/dist/esm/sd-date-range-picker.entry.js.map +1 -1
  327. package/dist/esm/sd-field_3.entry.js +418 -0
  328. package/dist/esm/sd-file-picker.entry.js +119 -0
  329. package/dist/esm/sd-file-picker.entry.js.map +1 -0
  330. package/dist/esm/sd-form.entry.js +72 -0
  331. package/dist/esm/sd-form.entry.js.map +1 -0
  332. package/dist/esm/sd-guide.entry.js +79 -0
  333. package/dist/esm/sd-guide.entry.js.map +1 -0
  334. package/dist/esm/sd-loading-spinner_2.entry.js +192 -0
  335. package/dist/esm/sd-modal-card.entry.js +8 -8
  336. package/dist/esm/sd-modal-card.entry.js.map +1 -1
  337. package/dist/esm/sd-number-input.entry.js +259 -0
  338. package/dist/esm/sd-number-input.entry.js.map +1 -0
  339. package/dist/esm/sd-popover.entry.js +7 -7
  340. package/dist/esm/sd-popover.entry.js.map +1 -1
  341. package/dist/esm/sd-progress.entry.js +1 -1
  342. package/dist/esm/sd-radio-button-group.entry.js +8 -21
  343. package/dist/esm/sd-radio-button-group.entry.js.map +1 -1
  344. package/dist/esm/sd-radio-group.entry.js +69 -0
  345. package/dist/esm/sd-radio-group.entry.js.map +1 -0
  346. package/dist/esm/sd-select-dropdown_3.entry.js +262 -0
  347. package/dist/esm/sd-select-multiple-group.entry.js +444 -0
  348. package/dist/esm/sd-select-multiple-group.entry.js.map +1 -0
  349. package/dist/esm/sd-select-multiple.entry.js +72 -150
  350. package/dist/esm/sd-select-multiple.entry.js.map +1 -1
  351. package/dist/esm/sd-select-option-group.entry.js +67 -0
  352. package/dist/esm/sd-select-option-group.entry.js.map +1 -0
  353. package/dist/esm/sd-table.entry.js +515 -85
  354. package/dist/esm/sd-table.entry.js.map +1 -1
  355. package/dist/esm/sd-tabs.entry.js +64 -0
  356. package/dist/esm/sd-tabs.entry.js.map +1 -0
  357. package/dist/esm/sd-tag.entry.js +55 -0
  358. package/dist/esm/sd-tag.entry.js.map +1 -0
  359. package/dist/esm/sd-toast-message.entry.js +59 -0
  360. package/dist/esm/sd-toast-message.entry.js.map +1 -0
  361. package/dist/esm/sd-toggle-button.entry.js +48 -0
  362. package/dist/esm/sd-toggle-button.entry.js.map +1 -0
  363. package/dist/esm/sd-toggle.entry.js +44 -0
  364. package/dist/esm/sd-toggle.entry.js.map +1 -0
  365. package/dist/esm/{tooltipArrow-DFRZWz6D.js → tooltipArrow-Ck_14rXC.js} +3 -3
  366. package/dist/esm/{tooltipArrow-DFRZWz6D.js.map → tooltipArrow-Ck_14rXC.js.map} +1 -1
  367. package/dist/types/components/sd-button/sd-button.d.ts +0 -3
  368. package/dist/types/components/sd-card/sd-card.d.ts +1 -1
  369. package/dist/types/components/sd-checkbox/sd-checkbox.d.ts +2 -2
  370. package/dist/types/components/sd-date-box/sd-date-box.d.ts +2 -2
  371. package/dist/types/components/sd-date-picker/sd-date-picker.d.ts +1 -1
  372. package/dist/types/components/sd-date-range-picker/sd-date-range-picker.d.ts +1 -1
  373. package/dist/types/components/sd-field/sd-field.d.ts +34 -0
  374. package/dist/types/components/sd-file-picker/sd-file-picker.d.ts +1 -1
  375. package/dist/types/components/{sd-tooltip-portal/sd-tooltip-portal.d.ts → sd-floating-portal/sd-floating-portal.d.ts} +2 -2
  376. package/dist/types/components/sd-form/sd-form.d.ts +23 -0
  377. package/dist/types/components/sd-input/sd-input.d.ts +23 -14
  378. package/dist/types/components/sd-modal-card/sd-modal-card.d.ts +2 -2
  379. package/dist/types/components/sd-number-input/sd-number-input.d.ts +4 -14
  380. package/dist/types/components/sd-portal/sd-portal.d.ts +1 -1
  381. package/dist/types/components/sd-radio-button-group/sd-radio-button-group.d.ts +2 -4
  382. package/dist/types/components/sd-radio-group/sd-radio-group.d.ts +1 -1
  383. package/dist/types/components/sd-select/sd-select-dropdown/sd-select-dropdown.d.ts +41 -0
  384. package/dist/types/components/sd-select/sd-select-option/sd-select-option.d.ts +1 -1
  385. package/dist/types/components/sd-select/sd-select-search-input/sd-select-search-input.d.ts +4 -4
  386. package/dist/types/components/sd-select/sd-select.d.ts +28 -21
  387. package/dist/types/components/sd-select-multiple/sd-select-multiple.d.ts +26 -20
  388. package/dist/types/components/sd-select-multiple-group/sd-select-multiple-group.d.ts +19 -4
  389. package/dist/types/components/sd-table/sd-table.d.ts +62 -3
  390. package/dist/types/components/sd-tabs/sd-tabs.d.ts +1 -2
  391. package/dist/types/components/sd-textarea/sd-textarea.d.ts +32 -0
  392. package/dist/types/components/sd-toast-message/sd-toast-message.d.ts +3 -3
  393. package/dist/types/components/sd-toggle/sd-toggle.d.ts +1 -2
  394. package/dist/types/components/sd-toggle-button/sd-toggle-button.d.ts +1 -1
  395. package/dist/types/components/sd-tooltip/sd-tooltip.d.ts +14 -2
  396. package/dist/types/components.d.ts +705 -399
  397. package/dist/types/types/form.d.ts +1 -0
  398. package/dist/types/types/select.d.ts +1 -1
  399. package/hydrate/index.js +1394 -1322
  400. package/hydrate/index.mjs +1394 -1322
  401. package/package.json +4 -3
  402. package/dist/cjs/index-B7tkxTye.js.map +0 -1
  403. package/dist/cjs/sd-tbody_3.cjs.entry.js +0 -44
  404. package/dist/cjs/sd-td.cjs.entry.js +0 -26
  405. package/dist/cjs/select-keyboard-navigation-6fO_V4En.js.map +0 -1
  406. package/dist/collection/components/sd-table/sd-tbody/sd-tbody.css +0 -3
  407. package/dist/collection/components/sd-table/sd-tbody/sd-tbody.js +0 -18
  408. package/dist/collection/components/sd-table/sd-tbody/sd-tbody.js.map +0 -1
  409. package/dist/collection/components/sd-table/sd-td/sd-td.css +0 -9
  410. package/dist/collection/components/sd-table/sd-td/sd-td.js +0 -111
  411. package/dist/collection/components/sd-table/sd-td/sd-td.js.map +0 -1
  412. package/dist/collection/components/sd-table/sd-th/sd-th.css +0 -8
  413. package/dist/collection/components/sd-table/sd-th/sd-th.js +0 -18
  414. package/dist/collection/components/sd-table/sd-th/sd-th.js.map +0 -1
  415. package/dist/collection/components/sd-table/sd-tr/sd-tr.css +0 -3
  416. package/dist/collection/components/sd-table/sd-tr/sd-tr.js +0 -18
  417. package/dist/collection/components/sd-table/sd-tr/sd-tr.js.map +0 -1
  418. package/dist/collection/components/sd-table-backup/sd-table-backup.css +0 -309
  419. package/dist/collection/components/sd-table-backup/sd-table-backup.js +0 -1219
  420. package/dist/collection/components/sd-table-backup/sd-table-backup.js.map +0 -1
  421. package/dist/collection/components/sd-tooltip-portal/sd-tooltip-portal.js.map +0 -1
  422. package/dist/components/p-BESbtjDi.js +0 -102
  423. package/dist/components/p-BESbtjDi.js.map +0 -1
  424. package/dist/components/p-BLidMbc_.js +0 -34
  425. package/dist/components/p-BLidMbc_.js.map +0 -1
  426. package/dist/components/p-BYf-ybt2.js.map +0 -1
  427. package/dist/components/p-BxPT3VKO.js.map +0 -1
  428. package/dist/components/p-CKhzpdPk.js.map +0 -1
  429. package/dist/components/p-CQBrru3e.js.map +0 -1
  430. package/dist/components/p-CWwMpVqI.js.map +0 -1
  431. package/dist/components/p-CfKJNKMH.js +0 -175
  432. package/dist/components/p-CfKJNKMH.js.map +0 -1
  433. package/dist/components/p-DD9g6GYA.js +0 -34
  434. package/dist/components/p-DD9g6GYA.js.map +0 -1
  435. package/dist/components/p-DKoWHxRI.js +0 -34
  436. package/dist/components/p-DKoWHxRI.js.map +0 -1
  437. package/dist/components/p-DMqinLuj.js +0 -326
  438. package/dist/components/p-DMqinLuj.js.map +0 -1
  439. package/dist/components/p-DRGcUx0C.js.map +0 -1
  440. package/dist/components/p-DroKiQ6J.js +0 -121
  441. package/dist/components/p-DroKiQ6J.js.map +0 -1
  442. package/dist/components/p-QNYqIsvU.js +0 -78
  443. package/dist/components/p-QNYqIsvU.js.map +0 -1
  444. package/dist/components/p-njRAT-yp.js.map +0 -1
  445. package/dist/components/sd-table-backup.js +0 -802
  446. package/dist/components/sd-table-backup.js.map +0 -1
  447. package/dist/components/sd-tbody.js +0 -9
  448. package/dist/components/sd-tbody.js.map +0 -1
  449. package/dist/components/sd-td.js +0 -50
  450. package/dist/components/sd-td.js.map +0 -1
  451. package/dist/components/sd-th.js +0 -9
  452. package/dist/components/sd-th.js.map +0 -1
  453. package/dist/components/sd-tooltip-portal.d.ts +0 -11
  454. package/dist/components/sd-tooltip-portal.js +0 -9
  455. package/dist/components/sd-tooltip-portal.js.map +0 -1
  456. package/dist/components/sd-tr.js +0 -9
  457. package/dist/components/sd-tr.js.map +0 -1
  458. package/dist/design-system/p-0d2814dc.entry.js +0 -2
  459. package/dist/design-system/p-0d2814dc.entry.js.map +0 -1
  460. package/dist/design-system/p-27985b84.entry.js +0 -2
  461. package/dist/design-system/p-27985b84.entry.js.map +0 -1
  462. package/dist/design-system/p-2c57bdea.entry.js +0 -2
  463. package/dist/design-system/p-3bc4effa.entry.js +0 -2
  464. package/dist/design-system/p-3bc4effa.entry.js.map +0 -1
  465. package/dist/design-system/p-5acdd14a.entry.js +0 -2
  466. package/dist/design-system/p-5acdd14a.entry.js.map +0 -1
  467. package/dist/design-system/p-665c5c48.entry.js +0 -2
  468. package/dist/design-system/p-665c5c48.entry.js.map +0 -1
  469. package/dist/design-system/p-7X2nzJWz.js.map +0 -1
  470. package/dist/design-system/p-7a424f6b.entry.js.map +0 -1
  471. package/dist/design-system/p-97b271a7.entry.js +0 -2
  472. package/dist/design-system/p-97b271a7.entry.js.map +0 -1
  473. package/dist/design-system/p-9ade8cd7.entry.js +0 -2
  474. package/dist/design-system/p-9ade8cd7.entry.js.map +0 -1
  475. package/dist/design-system/p-C2JaR3A6.js +0 -2
  476. package/dist/design-system/p-C2JaR3A6.js.map +0 -1
  477. package/dist/design-system/p-b1b828e6.entry.js +0 -2
  478. package/dist/design-system/p-b1b828e6.entry.js.map +0 -1
  479. package/dist/design-system/p-de826a92.entry.js +0 -2
  480. package/dist/design-system/p-de826a92.entry.js.map +0 -1
  481. package/dist/design-system/p-e5065700.entry.js +0 -2
  482. package/dist/design-system/p-e5065700.entry.js.map +0 -1
  483. package/dist/design-system/p-fc3580fd.entry.js +0 -2
  484. package/dist/design-system/p-fc3580fd.entry.js.map +0 -1
  485. package/dist/esm/index-7X2nzJWz.js.map +0 -1
  486. package/dist/esm/sd-tbody_3.entry.js +0 -40
  487. package/dist/esm/sd-td.entry.js +0 -24
  488. package/dist/esm/sd-td.entry.js.map +0 -1
  489. package/dist/esm/select-keyboard-navigation-C2JaR3A6.js.map +0 -1
  490. package/dist/types/components/sd-table/sd-tbody/sd-tbody.d.ts +0 -3
  491. package/dist/types/components/sd-table/sd-td/sd-td.d.ts +0 -7
  492. package/dist/types/components/sd-table/sd-th/sd-th.d.ts +0 -3
  493. package/dist/types/components/sd-table/sd-tr/sd-tr.d.ts +0 -3
  494. package/dist/types/components/sd-table-backup/sd-table-backup.d.ts +0 -135
  495. /package/dist/design-system/{p-7b94b34e.entry.js.map → p-388d5b9f.entry.js.map} +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"sd-table.entry.js","sources":["src/components/sd-table/sd-table.scss?tag=sd-table","src/components/sd-table/sd-table.tsx"],"sourcesContent":["@import 'variables.scss';\n@import 'extend.scss';\n\n.sd-table__wrapper {\n height: var(--table-height, auto);\n width: var(--table-width, 100%);\n color: $grey_95;\n\n .sd-table__container {\n width: 100%;\n height: auto;\n border: 1px solid $grey_30;\n border-radius: 8px;\n font-size: 12px;\n overflow: hidden;\n\n .sd-table__middle {\n overflow: auto;\n will-change: scroll-position;\n height: var(--table-height, auto);\n @extend %scrollBar;\n\n .sd-table {\n background-color: white;\n display: table;\n width: 100%;\n border-collapse: separate;\n border-spacing: 0;\n table-layout: fixed;\n position: relative;\n\n &--selectable {\n td.sd-td--selected,\n th.sd-th--selected {\n width: 52px !important;\n max-width: 52px !important;\n min-width: 52px !important;\n padding: 0 10px 0 24px;\n text-align: left;\n }\n }\n\n &--sticky-header {\n thead {\n position: sticky;\n top: 0;\n z-index: 120;\n }\n }\n\n &--sticky-column {\n th.sticky-left,\n th.sticky-right {\n position: sticky;\n background-color: $th-bg;\n z-index: 110 !important;\n }\n td.sticky-left,\n td.sticky-right {\n position: sticky;\n background-color: white;\n z-index: 100 !important;\n }\n\n .sticky-left {\n left: var(--sticky-left-offset, 0);\n }\n .sticky-right {\n right: var(--sticky-right-offset, 0);\n }\n\n th.sticky-cell {\n position: sticky;\n z-index: 102;\n background-color: $th-bg;\n }\n td.sticky-cell {\n position: sticky;\n z-index: 101;\n background-color: white;\n }\n }\n\n &--scrolled-left {\n th.sticky-left-edge,\n td.sticky-left-edge {\n overflow: visible;\n &:after {\n content: '';\n position: absolute;\n top: 0;\n left: 100%;\n right: -20px;\n width: 20px;\n height: 100%;\n z-index: 101 !important;\n box-shadow: inset 12px 0 20px -25px;\n opacity: 1;\n pointer-events: none;\n }\n }\n }\n\n &--scrolled-right {\n th.sticky-right-edge,\n td.sticky-right-edge {\n overflow: visible;\n\n &:after {\n content: '';\n position: absolute;\n top: 0;\n left: -20px;\n width: 20px;\n height: 100%;\n z-index: 101 !important;\n box-shadow: inset -12px 0 20px -25px;\n opacity: 1;\n pointer-events: none;\n }\n }\n }\n\n &--no-data {\n thead {\n opacity: 0.4;\n tr {\n th {\n &.sd-th {\n border-bottom: 1px solid rgba(225, 225, 225, 0.4) !important;\n }\n }\n }\n }\n }\n\n sd-td,\n sd-th,\n .sd-th__content--label {\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n word-break: keep-all;\n }\n\n thead {\n height: 36px;\n\n sd-tr {\n width: 100%;\n\n sd-th {\n background: $th-bg;\n height: 36px;\n padding: 0 16px;\n font-weight: 500;\n vertical-align: middle;\n border-bottom: 1px solid $grey_30;\n -webkit-user-select: none;\n user-select: none;\n position: relative;\n\n &.sd-th {\n .sd-th__content {\n display: flex;\n flex-flow: row nowrap;\n align-items: center;\n gap: 4px;\n\n &--left {\n justify-content: flex-start;\n }\n &--center {\n justify-content: center;\n }\n &--right {\n justify-content: flex-end;\n }\n }\n\n .sd-th__resizer {\n position: absolute;\n top: 50%;\n right: 0;\n transform: translateY(-50%);\n width: 4px;\n height: 16px;\n cursor: col-resize;\n z-index: 3;\n border-left: 1px solid $grey_45;\n border-right: 1px solid $grey_45;\n }\n }\n }\n }\n }\n\n sd-tbody {\n .sd-table__loading {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: calc(var(--table-height, auto) - 36px);\n min-height: calc(100% - 36px);\n background: rgba(255, 255, 255, 0.6);\n z-index: 200;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n\n sd-tr {\n &:last-of-type {\n sd-td {\n border-bottom: none;\n }\n }\n sd-td {\n height: 44px;\n padding: 0 16px;\n border-bottom: 1px solid $grey_30;\n background: white;\n vertical-align: middle;\n\n &.sd-td {\n &--left {\n text-align: left;\n }\n &--center {\n text-align: center;\n }\n &--right {\n text-align: right;\n }\n }\n }\n }\n }\n }\n }\n\n .sd-table__bottom {\n background: white;\n text-align: center;\n }\n }\n\n .sd-table__pagination {\n position: relative;\n background: $grey_05;\n height: 48px;\n display: flex;\n align-items: center;\n justify-content: center;\n border: 1px solid $grey_30;\n border-top: none;\n border-radius: 8px;\n\n sd-select {\n position: absolute;\n right: 10px;\n top: 50%;\n transform: translateY(-50%);\n\n .sd-select {\n }\n }\n }\n}\n","import {\n Component,\n Element,\n Prop,\n State,\n Event,\n Watch,\n h,\n EventEmitter,\n Host,\n} from '@stencil/core';\nimport { CheckedType } from '../sd-checkbox/sd-checkbox';\nimport { SelectOption } from '../sd-select/sd-select';\nimport { SdSelectCustomEvent } from '../../components';\n\nexport type SdTableSortDir = 'asc' | 'desc' | 'none';\n\nexport interface SdTableColumn {\n name: string;\n label: string;\n field: string | ((row: any) => any);\n align?: 'left' | 'center' | 'right';\n width?: string;\n format?: (value: any, row: any) => string;\n visible?: boolean;\n usePageMoveIcon?: boolean;\n tooltip?: string[];\n tooltipOptions?: Record<string, any>;\n tdClass?: string;\n thClass?: string;\n}\n\nexport interface Row {\n [key: string]: any;\n}\n\n@Component({\n tag: 'sd-table',\n styleUrl: 'sd-table.scss',\n})\nexport class SdTable {\n @Element() el!: HTMLElement;\n\n @Prop() columns!: SdTableColumn[];\n @Prop({ mutable: true }) rows!: Row[];\n @Prop({ mutable: true }) selected: Set<Row> = new Set();\n @Prop() rowKey: string = 'id';\n @Prop() selectable: boolean = false;\n @Prop() resizable: boolean = false;\n @Prop() width?: string;\n @Prop() height?: string;\n @Prop() stickyHeader: boolean = false;\n @Prop() stickyColumn: { left?: number; right?: number } = { left: 0, right: 0 };\n @Prop() noDataLabel: string = '데이터가 없습니다.';\n @Prop() isLoading: boolean = false;\n @Prop() pagination?: {\n page: number;\n rowsPerPage: number;\n lastPage?: number;\n };\n @Prop() bodyCellRenderer?: (\n column: SdTableColumn,\n row: Row,\n ) => HTMLElement | string | null | undefined;\n @Prop() useInternalPagination: boolean = false;\n @Prop() useRowsPerPageSelect: boolean = false;\n @Prop() rowsPerPageOption: SelectOption[] = [\n { label: '10개씩 보기', value: 10 },\n { label: '25개씩 보기', value: 25 },\n { label: '50개씩 보기', value: 50 },\n { label: '100개씩 보기', value: 100 },\n ];\n\n @Event() sdSelectChange!: EventEmitter<Row[]>;\n @Event() sdPageChange!: EventEmitter<number>;\n @Event() sdRowsPerPageChange!: EventEmitter<number>;\n\n @State() currentPage: number = this.pagination?.page || 1;\n @State() innerRows: Row[] = [];\n @State() innerSelected: Set<Row> = new Set();\n @State() columnWidths: number[] = [];\n @State() scrolledLeft: boolean = false;\n @State() scrolledRight: boolean = false;\n\n @Watch('columns')\n handleColumnsChange(newCols: SdTableColumn[]) {\n this.columnWidths = newCols.map(c => parseInt(c.width || '120', 10));\n }\n\n @Watch('rows')\n handleRowsChange(newRows: Row[]) {\n this.innerRows = [...newRows];\n }\n\n @Watch('selected')\n handleSelectedChange(newSelected: Set<Row>) {\n this.innerSelected = new Set(newSelected);\n }\n\n @Watch('pagination')\n handlePaginationChange(\n newVal?: { page: number; rowsPerPage: number; lastPage?: number } | undefined,\n ) {\n if (newVal?.page && newVal.page !== this.currentPage) this.currentPage = newVal.page;\n }\n\n componentWillLoad() {\n this.innerRows = [...(this.rows || [])];\n this.innerSelected = new Set(this.selected);\n this.columnWidths = (this.columns || []).map(c => parseInt(c.width || '120', 10));\n }\n\n componentDidLoad() {\n // SSR 환경 체크\n if (typeof window === 'undefined') return;\n\n const middle = this.el.querySelector('.sd-table__middle');\n if (!middle) return;\n\n const onScroll = () => {\n const { scrollLeft, scrollWidth, clientWidth } = middle as HTMLElement;\n this.scrolledLeft = scrollLeft > 0;\n this.scrolledRight = scrollLeft + clientWidth < scrollWidth;\n };\n middle.addEventListener('scroll', onScroll, { passive: true });\n onScroll();\n }\n\n // ----- Derived getters -----\n private get visibleColumns(): SdTableColumn[] {\n return this.columns.filter(col => col.visible !== false);\n }\n\n private get paginatedRows(): Row[] {\n if (!this.pagination || !this.useInternalPagination) return this.innerRows;\n\n const { rowsPerPage = this.rows.length } = this.pagination || {};\n\n const result = this.innerRows.slice(\n (this.currentPage - 1) * rowsPerPage,\n this.currentPage * rowsPerPage,\n );\n\n return result;\n }\n\n private get lastPageNumber(): number {\n const { lastPage, rowsPerPage = this.rows.length } = this.pagination || {};\n\n return lastPage ?? Math.max(1, Math.ceil(this.rows.length / rowsPerPage));\n }\n\n private get sdTableClasses() {\n return [\n 'sd-table',\n this.stickyHeader && 'sd-table--sticky-header',\n this.selectable && 'sd-table--selectable',\n this.resizable && 'sd-table--resizable',\n !this.innerRows.length && 'sd-table--no-data',\n ((this.stickyColumn?.left ?? 0) > 0 || (this.stickyColumn?.right ?? 0) > 0) &&\n 'sd-table--sticky-column',\n this.scrolledLeft && 'sd-table--scrolled-left',\n this.scrolledRight && 'sd-table--scrolled-right',\n ]\n .filter(Boolean)\n .join(' ');\n }\n\n // ----- Selection -----\n // private isRowSelected(row: Row): boolean {\n // return Array.from(this.innerSelected).some(r => r[this.rowKey] === row[this.rowKey]);\n // }\n\n // private updateRowSelect(row: Row) {\n // const selectedArray = Array.from(this.innerSelected);\n // const exists = this.isRowSelected(row);\n // const newSelected = exists\n // ? selectedArray.filter(r => r[this.rowKey] !== row[this.rowKey])\n // : [...selectedArray, row];\n\n // // 동일 상태면 set하지 않음 → 불필요 렌더 방지\n // if (newSelected.length === selectedArray.length) return;\n\n // this.innerSelected = new Set(newSelected);\n // this.sdSelectChange.emit(Array.from(this.innerSelected));\n // }\n\n private toggleSelectAll(checked: CheckedType) {\n if (checked) {\n const pageRows = new Set([...this.paginatedRows]);\n this.innerSelected = new Set([...this.innerSelected, ...pageRows]);\n } else {\n const currentPageKeys = this.paginatedRows.map(r => r[this.rowKey]);\n this.innerSelected = new Set(\n [...this.innerSelected].filter(r => !currentPageKeys.includes(r[this.rowKey])),\n );\n }\n\n this.sdSelectChange.emit(Array.from(this.innerSelected));\n }\n\n private get isAllChecked(): boolean | null {\n const total = this.paginatedRows.length;\n const selectedCount = this.paginatedRows.filter(row =>\n Array.from(this.innerSelected).some(\n selectedRow => selectedRow[this.rowKey] === row[this.rowKey],\n ),\n ).length;\n\n if (selectedCount === 0) return false; // 아무것도 안 선택됨\n if (selectedCount === total) return true; // 전부 선택됨\n return null; // 일부만 선택됨\n }\n\n // ----- Helpers -----\n private getStickyStyle(colIdx: number) {\n const leftOffset =\n this.columnWidths.slice(0, colIdx).reduce((a, b) => a + b, 0) + (this.selectable ? 52 : 0);\n const rightOffset = this.columnWidths\n .filter((_, i) => i >= this.visibleColumns.length - (this.stickyColumn.right || 0) && i > colIdx)\n .reduce((a, b) => a + b, 0);\n return {\n '--sticky-left-offset': `${leftOffset}px`,\n '--sticky-right-offset': `${rightOffset}px`,\n 'width': `${this.columnWidths[colIdx]}px`,\n 'minWidth': `${this.columnWidths[colIdx]}px`,\n 'maxWidth': `${this.columnWidths[colIdx]}px`,\n };\n }\n\n private handleResize(index: number, event: MouseEvent) {\n // SSR 환경 체크\n if (typeof document === 'undefined') return;\n\n const startX = event.clientX;\n const startWidth = this.columnWidths[index];\n\n const handleMouseMove = (moveEvent: MouseEvent) => {\n const newWidth = Math.max(startWidth + moveEvent.clientX - startX, 50);\n\n this.columnWidths = this.columnWidths.map((width, idx) => (idx === index ? newWidth : width));\n };\n\n const handleMouseUp = () => {\n document.removeEventListener('mousemove', handleMouseMove);\n document.removeEventListener('mouseup', handleMouseUp);\n };\n\n document.addEventListener('mousemove', handleMouseMove);\n document.addEventListener('mouseup', handleMouseUp);\n }\n\n // private getCellValue(column: SdTableColumn, row: Row) {\n // const { field, format, name } = column;\n // const value = typeof field === 'function' ? field(row) : field ? row[field] : row[name];\n // return format ? format(value, row) : value;\n // }\n\n // ----- Render -----\n private renderHeader() {\n return (\n <thead>\n <sd-tr>\n {this.selectable && (\n <sd-th\n class={{\n 'sd-th': true,\n 'sd-th--selected': true,\n 'sticky-left': Boolean(this.stickyColumn.left && this.stickyColumn.left > 0),\n }}\n style={{\n '--sticky-left-offset': '0px',\n }}\n >\n <sd-checkbox\n checked={this.isAllChecked}\n disabled={!this.paginatedRows.length}\n onSdChange={(e: CustomEvent<CheckedType>) => this.toggleSelectAll(e.detail)}\n ></sd-checkbox>\n </sd-th>\n )}\n {this.visibleColumns.map((col, colIdx) => (\n <sd-th\n key={col.name}\n class={{\n 'sd-th': true,\n [`${col.thClass}`]: Boolean(col.thClass),\n 'sticky-left': Boolean(this.stickyColumn.left && colIdx < this.stickyColumn.left),\n 'sticky-right': Boolean(\n this.stickyColumn.right && colIdx >= this.visibleColumns.length - this.stickyColumn.right!,\n ),\n 'sticky-left-edge': Boolean(\n this.stickyColumn.left && colIdx === this.stickyColumn.left - 1,\n ),\n 'sticky-right-edge': Boolean(\n this.stickyColumn.right &&\n colIdx === this.visibleColumns.length - this.stickyColumn.right!,\n ),\n }}\n style={this.getStickyStyle(colIdx)}\n >\n <div class={`sd-th__content sd-th__content--${col.align || 'left'}`}>\n <slot name={`header-cell-${col.name}`}>\n <div class=\"sd-th__content--label\">{col.label}</div>\n </slot>\n\n {col.usePageMoveIcon && <sd-icon name=\"pageMove\" size=\"12\" color=\"#006AC1\" />}\n\n {col.tooltip && (\n <sd-tooltip {...col.tooltipOptions}>\n <div slot=\"content\">\n {col.tooltip.map(text => (\n <p>{text}</p>\n ))}\n </div>\n </sd-tooltip>\n )}\n </div>\n\n {this.resizable && typeof window !== 'undefined' && (\n <div\n class=\"sd-th__resizer\"\n onMouseDown={(evt: MouseEvent) => this.handleResize(colIdx, evt)}\n ></div>\n )}\n </sd-th>\n ))}\n </sd-tr>\n </thead>\n );\n }\n\n render() {\n return (\n <Host>\n <div\n class=\"sd-table__wrapper\"\n style={{\n '--table-width': this.width,\n '--table-height': this.height,\n }}\n >\n <div class=\"sd-table__container\">\n <div class=\"sd-table__middle\" role=\"table\">\n <div part=\"table\" class={this.sdTableClasses}>\n {this.renderHeader()}\n <sd-tbody>\n <slot></slot>\n </sd-tbody>\n </div>\n </div>\n\n <div class=\"sd-table__bottom\"></div>\n </div>\n {this.pagination && this.innerRows.length > 0 && (\n <div class=\"sd-table__pagination\">\n <sd-pagination\n currentPage={!this.useInternalPagination ? this.pagination.page : this.currentPage}\n lastPage={!this.useInternalPagination ? this.pagination.lastPage : this.lastPageNumber}\n onPageChange={(e: CustomEvent<number>) => {\n if (!this.useInternalPagination) {\n this.sdPageChange.emit(e.detail);\n } else {\n this.currentPage = e.detail;\n this.sdPageChange.emit(this.currentPage);\n }\n }}\n ></sd-pagination>\n\n {this.useRowsPerPageSelect && (\n <sd-select\n value={this.pagination.rowsPerPage}\n options={this.rowsPerPageOption}\n width=\"128px\"\n onSdChange={(e: SdSelectCustomEvent<{ value: string | number | null }>) => {\n const changedRowsPerPage = e.detail.value ? Number(e.detail.value) : 0;\n if (!this.useInternalPagination) {\n this.sdRowsPerPageChange.emit(changedRowsPerPage);\n } else {\n const newRowsPerPage = Number(e.detail.value || 0);\n let newLastPage = Math.max(1, Math.ceil(this.innerRows.length / newRowsPerPage));\n let newCurrentPage = this.currentPage;\n\n if (newCurrentPage > newLastPage) {\n newCurrentPage = newLastPage;\n }\n\n this.pagination = {\n page: newCurrentPage,\n rowsPerPage: newRowsPerPage,\n lastPage: newLastPage,\n };\n this.currentPage = newCurrentPage;\n this.sdRowsPerPageChange.emit(changedRowsPerPage);\n }\n }}\n ></sd-select>\n )}\n </div>\n )}\n </div>\n </Host>\n );\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"sd-table.entry.js","sources":["src/components/sd-table/sd-table.scss?tag=sd-table","src/components/sd-table/sd-table.tsx"],"sourcesContent":["@import 'variables.scss';\n@import 'extend.scss';\n\n.sd-table__wrapper {\n height: var(--table-height, auto);\n width: var(--table-width, 100%);\n color: $grey_95;\n\n .sd-table__container {\n width: 100%;\n height: var(--table-container-height, auto);\n display: flex;\n flex-direction: column;\n position: relative;\n border: 1px solid $grey_30;\n border-radius: 8px;\n font-size: 12px;\n overflow: hidden;\n background: $white;\n\n .sd-table__middle {\n overflow: auto;\n will-change: scroll-position;\n min-height: var(--table-container-height, auto);\n @extend %scrollBar;\n\n &--scrollable {\n height: var(--table-container-height, auto);\n }\n\n &--loading {\n overflow: hidden !important;\n pointer-events: none;\n &__spinner {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: var(--table-container-height, 100%);\n min-height: var(--table-container-height, 100%);\n background: rgba(255, 255, 255, 0.6);\n z-index: 200;\n display: flex;\n align-items: center;\n justify-content: center;\n }\n }\n\n .sd-table {\n background-color: white;\n display: table;\n width: 100%;\n border-collapse: separate;\n border-spacing: 0;\n table-layout: fixed;\n\n tbody {\n &.sd-table-tbody--virtual-scroll {\n position: relative;\n height: var(--total-virtual-height, --table-container-height, auto);\n\n tr {\n &:not([aria-hidden='true']) {\n width: 100%;\n }\n &[aria-hidden='true'] {\n padding: 0;\n border: none;\n\n &:not(.sd-table__virtual-row-spacer) {\n td {\n display: none;\n }\n }\n }\n }\n }\n }\n\n &--selectable {\n td.sd-td--selected,\n th.sd-th--selected {\n position: relative;\n width: 52px !important;\n max-width: 52px !important;\n min-width: 52px !important;\n padding: 0 10px 0 24px;\n text-align: left;\n\n sd-checkbox label {\n position: relative;\n\n &:before {\n content: '';\n position: absolute;\n inset: -6px;\n }\n }\n }\n }\n\n &--sticky-header {\n thead {\n position: sticky;\n top: 0;\n z-index: 120;\n }\n }\n\n &--sticky-column {\n th.sticky-left,\n th.sticky-right {\n position: sticky;\n background-color: $th-bg;\n z-index: 110 !important;\n }\n td.sticky-left,\n td.sticky-right {\n position: sticky;\n background-color: white;\n z-index: 100 !important;\n }\n\n .sticky-left {\n left: var(--sticky-left-offset, 0);\n }\n .sticky-right {\n right: var(--sticky-right-offset, 0);\n }\n\n th.sticky-cell {\n position: sticky;\n z-index: 102;\n background-color: $th-bg;\n }\n td.sticky-cell {\n position: sticky;\n z-index: 101;\n background-color: white;\n }\n }\n\n &--scrolled-left {\n th.sticky-left-edge,\n td.sticky-left-edge {\n overflow: visible;\n &:after {\n content: '';\n position: absolute;\n top: 0;\n left: 100%;\n right: -20px;\n width: 20px;\n height: 100%;\n z-index: 101 !important;\n box-shadow: inset 12px 0 20px -25px;\n opacity: 1;\n pointer-events: none;\n }\n }\n }\n\n &--scrolled-right {\n th.sticky-right-edge,\n td.sticky-right-edge {\n overflow: visible;\n\n &:after {\n content: '';\n position: absolute;\n top: 0;\n left: -20px;\n width: 20px;\n height: 100%;\n z-index: 101 !important;\n box-shadow: inset -12px 0 20px -25px;\n opacity: 1;\n pointer-events: none;\n }\n }\n }\n\n &--no-data {\n thead {\n opacity: 0.4;\n tr {\n th {\n &.sd-th {\n border-bottom: 1px solid rgba(225, 225, 225, 0.4) !important;\n }\n }\n }\n }\n }\n\n sd-td,\n sd-th,\n .sd-th__content--label {\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n word-break: keep-all;\n }\n\n thead {\n height: 36px;\n\n tr {\n width: 100%;\n\n th {\n background: $th-bg;\n height: 36px;\n padding: 0 16px;\n font-weight: 500;\n vertical-align: middle;\n border-bottom: 1px solid $grey_30;\n -webkit-user-select: none;\n user-select: none;\n position: relative;\n\n &.sd-th {\n .sd-th__content {\n display: flex;\n flex-flow: row nowrap;\n align-items: center;\n gap: 4px;\n\n &--left {\n justify-content: flex-start;\n }\n &--center {\n justify-content: center;\n }\n &--right {\n justify-content: flex-end;\n }\n }\n\n .sd-th__resizer {\n position: absolute;\n top: 50%;\n right: 0;\n transform: translateY(-50%);\n width: 4px;\n height: 16px;\n cursor: col-resize;\n z-index: 3;\n border-left: 1px solid $grey_45;\n border-right: 1px solid $grey_45;\n }\n }\n }\n }\n }\n\n tbody {\n tr {\n td {\n height: 44px;\n padding: 0 16px;\n border-bottom: 1px solid $grey_30;\n background: white;\n vertical-align: middle;\n\n &.sd-td {\n &--left {\n text-align: left;\n }\n &--center {\n text-align: center;\n }\n &--right {\n text-align: right;\n }\n }\n }\n }\n }\n }\n }\n\n .sd-table__bottom {\n background: transparent;\n text-align: center;\n display: flex;\n align-items: center;\n justify-content: center;\n flex: 1;\n min-height: 240px;\n translate: 0 -10%;\n pointer-events: none;\n\n .sd-table__no-data {\n font-size: 12px;\n color: $grey_65;\n }\n }\n }\n\n .sd-table__pagination {\n position: relative;\n background: $grey_05;\n height: 48px;\n display: flex;\n align-items: center;\n justify-content: center;\n border: 1px solid $grey_30;\n border-top: none;\n border-radius: 8px;\n\n sd-select {\n position: absolute;\n right: 10px;\n top: 50%;\n transform: translateY(-50%);\n }\n }\n\n // 가상 스크롤 스켈레톤 스타일\n .sd-table__virtual-spacer,\n .sd-table__virtual-row-spacer {\n padding: 0 !important;\n\n td {\n padding: 0 !important;\n border: none;\n }\n\n .sd-table__skeleton {\n width: 100%;\n height: 100%;\n background-image: repeating-linear-gradient(\n 0deg,\n rgba($grey_10, 0.3) 0px,\n rgba($grey_30, 0.5) calc(var(--row-height, 44px) / 2),\n rgba($grey_10, 0.3) var(--row-height, 44px)\n );\n background-size: 100% 200%;\n animation: skeleton-loading 1.5s ease-in-out infinite;\n position: relative;\n\n // 행 구분선\n &::before {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background-image: repeating-linear-gradient(\n to bottom,\n transparent 0,\n transparent calc(var(--row-height, 44px) - 1px),\n $grey_30 calc(var(--row-height, 44px) - 1px),\n $grey_30 var(--row-height, 44px)\n );\n pointer-events: none;\n }\n }\n }\n\n // 열 구분선\n .sd-table__skeleton-cell {\n width: 100%;\n height: 20px;\n background: linear-gradient(\n 90deg,\n rgba($grey_10, 0.3) 0%,\n rgba($grey_30, 0.5) 50%,\n rgba($grey_10, 0.3) 100%\n );\n background-size: 200% 100%;\n animation: skeleton-loading 1.5s ease-in-out infinite;\n border-radius: 4px;\n }\n\n @keyframes skeleton-loading {\n 0% {\n background-position: 0% 0%;\n }\n 50% {\n background-position: 100% 100%;\n }\n 100% {\n background-position: 0% 0%;\n }\n }\n}\n","import {\n Component,\n Element,\n Prop,\n State,\n Event,\n Watch,\n h,\n EventEmitter,\n Host,\n readTask,\n} from '@stencil/core';\nimport { CheckedType } from '../sd-checkbox/sd-checkbox';\nimport { SelectOption } from '../sd-select/sd-select';\nimport { SdSelectCustomEvent } from '../../components';\n\nexport type SdTableSortDir = 'asc' | 'desc' | 'none';\n\nexport interface SdTableColumn {\n name: string;\n label: string;\n field: string | ((row: any) => any);\n align?: 'left' | 'center' | 'right';\n width?: string;\n format?: (value: any, row: any) => string;\n visible?: boolean;\n usePageMoveIcon?: boolean;\n tooltip?: string[];\n tooltipOptions?: Record<string, any>;\n tdClass?: string;\n minWidth?: number;\n maxWidth?: number;\n thStyle?: Record<string, any>;\n thClass?: string;\n}\n\nexport interface Row {\n [key: string]: any;\n}\n\n@Component({\n tag: 'sd-table',\n styleUrl: 'sd-table.scss',\n})\nexport class SdTable {\n @Element() el!: HTMLElement;\n\n @Prop() columns!: SdTableColumn[];\n @Prop({ mutable: true }) rows!: Row[];\n @Prop({ mutable: true }) selected: Row[] = [];\n @Prop() rowKey: string = 'id';\n @Prop() selectable: boolean = false;\n @Prop() resizable: boolean = false;\n @Prop() width?: string;\n @Prop() height?: string;\n @Prop() stickyHeader: boolean = false;\n @Prop() stickyColumn: { left?: number; right?: number } = { left: 0, right: 0 };\n @Prop() noDataLabel: string = '데이터가 없습니다.';\n @Prop() isLoading: boolean = false;\n @Prop() pagination?: {\n page: number;\n rowsPerPage: number;\n lastPage?: number;\n };\n @Prop() headerCellRenderer?: (column: SdTableColumn) => HTMLElement | string | null | undefined;\n @Prop() bodyCellRenderer?: (\n column: SdTableColumn,\n row: Row,\n ) => HTMLElement | string | null | undefined;\n @Prop() useInternalPagination: boolean = false;\n @Prop() useRowsPerPageSelect: boolean = false;\n @Prop() rowsPerPageOption: SelectOption[] = [\n { label: '10개씩 보기', value: 10 },\n { label: '25개씩 보기', value: 25 },\n { label: '50개씩 보기', value: 50 },\n { label: '100개씩 보기', value: 100 },\n ];\n @Prop() useVirtualScroll: { vertical?: boolean; horizontal?: boolean } = {}; // 가상 스크롤 사용 여부\n @Prop() virtualRowHeight: number = 44; // 가상 스크롤 사용시 각 행의 높이 - 세로 가상 스크롤 사용시 필수값\n // 가상 스크롤 사용시 각 열의 너비 - 가로 가상 스크롤 사용시 필수값\n // 가상화하려는 컬럼의 넓이는 무조건 고정(resizable의 경우 넓이가 변동되는데 이때에는 고려 x)\n @Prop() virtualColumnWidth: number = 120;\n @Prop() virtualBufferSize: { vertical?: number; horizontal?: number } = {\n vertical: 5,\n horizontal: 5,\n }; // 가상 스크롤 위아래 버퍼 크기\n\n @Event() sdSelectChange!: EventEmitter<Row[]>;\n @Event() sdPageChange!: EventEmitter<number>;\n @Event() sdRowsPerPageChange!: EventEmitter<number>;\n\n @State() currentPage: number = this.pagination?.page || 1;\n @State() innerRows: Row[] = [];\n @State() innerSelected: Set<Row> = new Set();\n @State() columnWidths: number[] = [];\n @State() scrolledLeft: boolean = false;\n @State() scrolledRight: boolean = false;\n // 세로 가상 스크롤 상태값\n @State() virtualStartIndex: number = 0;\n @State() virtualEndIndex: number = 0;\n @State() scrollTopPosition: number = 0;\n // 가로 가상 스크롤 상태값\n @State() virtualStartColIdx: number = 0;\n @State() virtualEndColIdx: number = 0;\n @State() scrollLeftPosition: number = 0;\n\n // 가상 스크롤 Raf(Request Animation Frame) 관리\n private scrollRequestAnimationFrame: number | null = null;\n private scrollContainer: HTMLElement | null = null;\n private rafScheduled = false;\n private pendingUpdates = {\n vertical: false,\n horizontal: false,\n };\n\n // 상태 캐시값\n private cachedVisibleColumns: SdTableColumn[] | null = null;\n private lastColumnsRef: SdTableColumn[] | null = null;\n private cachedVirtualRows: { row: Row; actualIndex: number }[] | null = null;\n private cachedVirtualIndexKey: string = '';\n private cachedColumnOrder: {\n stickyLeftCount: number;\n stickyRightCount: number;\n stickyLeftCols: SdTableColumn[];\n middleCols: SdTableColumn[];\n stickyRightCols: SdTableColumn[];\n } | null = null;\n private lastColumnOrderKey: string = '';\n\n // DOM 측정 캐시값\n private cachedContainerHeight: number = 0;\n private cachedContainerWidth: number = 0;\n\n // 스타일 캐시\n private stickyStyleCache: Map<number, Record<string, any>> = new Map();\n\n // isAllChecked 캐시\n private cachedIsAllChecked: boolean | null | undefined;\n private lastSelectionKey: string = '';\n\n private onScroll?: () => void;\n\n @Watch('columns')\n handleColumnsChange(newCols: SdTableColumn[]) {\n this.columnWidths = newCols.map(c => parseInt(c.width || '120', 10));\n this.cleanUpVirtualCache();\n this.stickyStyleCache.clear();\n\n if (this.useVirtualScroll.horizontal) {\n this.scheduleUpdate('horizontal');\n }\n }\n\n @Watch('columnWidths')\n handleColumnWidthsChange() {\n this.stickyStyleCache.clear();\n\n if (this.useVirtualScroll.horizontal) {\n this.scheduleUpdate('horizontal');\n }\n }\n\n @Watch('rows')\n handleRowsChange(newRows: Row[]) {\n this.innerRows = [...newRows];\n this.cleanUpVirtualCache();\n\n if (this.useVirtualScroll.vertical) {\n this.scheduleUpdate('vertical');\n }\n }\n\n @Watch('selected')\n handleSelectedChange(newSelected: Row[]) {\n this.innerSelected = new Set(newSelected);\n }\n\n private cleanUpVirtualCache() {\n this.cachedVisibleColumns = null;\n this.lastColumnsRef = null;\n this.cachedVirtualRows = null;\n this.cachedVirtualIndexKey = '';\n this.cachedColumnOrder = null;\n this.lastColumnOrderKey = '';\n }\n\n @Watch('pagination')\n handlePaginationChange(\n newVal?: { page: number; rowsPerPage: number; lastPage?: number } | undefined,\n ) {\n if (newVal?.page && newVal.page !== this.currentPage) {\n this.currentPage = newVal.page;\n if (this.useVirtualScroll.vertical && this.scrollContainer) {\n this.scrollContainer.scrollTo({ top: 0, behavior: 'instant' });\n this.scrollTopPosition = 0;\n this.calculateVisibleRange();\n }\n }\n }\n\n componentWillLoad() {\n this.innerRows = [...(this.rows || [])];\n this.innerSelected = new Set(this.selected || []);\n this.columnWidths = (this.columns || []).map(c => parseInt(c.width || '120', 10));\n\n if (this.pagination?.page) {\n this.currentPage = this.pagination.page;\n }\n }\n\n componentDidLoad() {\n readTask(() => {\n const middle = this.el.querySelector('.sd-table__middle');\n\n if (!middle) return;\n\n this.onScroll = () => {\n const scrollLeft = middle.scrollLeft;\n const scrollWidth = middle.scrollWidth;\n const clientWidth = middle.clientWidth;\n const scrollTop = middle.scrollTop;\n\n const verticalChanged = this.useVirtualScroll.vertical && this.scrollTopPosition !== scrollTop;\n const horizontalChanged =\n this.useVirtualScroll.horizontal && this.scrollLeftPosition !== scrollLeft;\n\n const newScrolledLeft = scrollLeft > 0;\n const newScrolledRight = scrollLeft + clientWidth < scrollWidth;\n\n if (this.scrolledLeft !== newScrolledLeft || this.scrolledRight !== newScrolledRight) {\n this.scrolledLeft = newScrolledLeft;\n this.scrolledRight = newScrolledRight;\n }\n\n if (verticalChanged || horizontalChanged) {\n if (this.scrollRequestAnimationFrame !== null) {\n cancelAnimationFrame(this.scrollRequestAnimationFrame);\n }\n\n this.scrollRequestAnimationFrame = requestAnimationFrame(() => {\n if (verticalChanged) {\n this.scrollTopPosition = scrollTop;\n this.calculateVisibleRange();\n }\n if (horizontalChanged) {\n this.scrollLeftPosition = scrollLeft;\n this.calculateVisibleColumnRange();\n }\n this.scrollRequestAnimationFrame = null;\n });\n }\n };\n\n this.scrollContainer = middle as HTMLElement;\n requestAnimationFrame(() => {\n if (this.scrollContainer && this.onScroll) {\n this.cachedContainerHeight = this.scrollContainer.clientHeight;\n this.cachedContainerWidth = this.scrollContainer.clientWidth;\n\n middle.addEventListener('scroll', this.onScroll, { passive: true });\n\n if (this.useVirtualScroll.vertical) {\n this.calculateVisibleRange();\n }\n if (this.useVirtualScroll.horizontal) {\n this.calculateVisibleColumnRange();\n }\n\n this.onScroll();\n }\n });\n });\n }\n\n private changePage(page: number) {\n if (!this.useInternalPagination) {\n this.sdPageChange.emit(page);\n return;\n }\n\n this.currentPage = page;\n this.sdPageChange.emit(this.currentPage);\n }\n\n private changeRowsPerPage(perPage: string | number | null) {\n const changedRowsPerPage = perPage ? Number(perPage) : 0;\n\n if (!this.useInternalPagination) {\n this.sdRowsPerPageChange.emit(changedRowsPerPage);\n return;\n }\n\n const newRowsPerPage = Number(perPage || 0);\n let newLastPage = Math.max(1, Math.ceil(this.innerRows.length / newRowsPerPage));\n let newCurrentPage = this.currentPage;\n\n if (newCurrentPage > newLastPage) {\n newCurrentPage = newLastPage;\n }\n\n this.pagination = {\n page: newCurrentPage,\n rowsPerPage: newRowsPerPage,\n lastPage: newLastPage,\n };\n this.currentPage = newCurrentPage;\n this.sdRowsPerPageChange.emit(changedRowsPerPage);\n }\n\n disconnectedCallback() {\n if (this.scrollContainer && this.onScroll) {\n this.scrollContainer.removeEventListener('scroll', this.onScroll);\n }\n\n if (this.scrollRequestAnimationFrame !== null) {\n cancelAnimationFrame(this.scrollRequestAnimationFrame);\n }\n }\n\n // ----- Derived getters -----\n private get visibleColumns(): SdTableColumn[] {\n if (this.cachedVisibleColumns && this.lastColumnsRef === this.columns) {\n return this.cachedVisibleColumns;\n }\n this.lastColumnsRef = this.columns;\n this.cachedVisibleColumns = this.columns.filter(col => col.visible !== false);\n return this.cachedVisibleColumns;\n }\n\n private get paginatedRows(): Row[] {\n if (!this.pagination || !this.useInternalPagination) return this.innerRows;\n\n const { rowsPerPage = this.rows.length } = this.pagination || {};\n\n return this.innerRows.slice((this.currentPage - 1) * rowsPerPage, this.currentPage * rowsPerPage);\n }\n\n private get virtualRows(): { row: Row; actualIndex: number }[] {\n const newVirtualIndexKey = `${this.virtualStartIndex}-${this.virtualEndIndex}`;\n\n if (this.cachedVirtualRows && this.cachedVirtualIndexKey === newVirtualIndexKey) {\n return this.cachedVirtualRows;\n }\n\n this.cachedVirtualIndexKey = newVirtualIndexKey;\n\n if (!this.useVirtualScroll.vertical) {\n this.cachedVirtualRows = this.paginatedRows.map((row, idx) => ({ row, actualIndex: idx }));\n } else {\n this.cachedVirtualRows = this.paginatedRows\n .slice(this.virtualStartIndex, this.virtualEndIndex + 1)\n .map((row, relativeIdx) => ({\n row,\n actualIndex: this.virtualStartIndex + relativeIdx,\n }));\n }\n\n return this.cachedVirtualRows;\n }\n\n private get topSpacerHeight(): number {\n if (!this.useVirtualScroll.vertical || this.virtualStartIndex === 0) return 0;\n return this.virtualStartIndex * this.virtualRowHeight;\n }\n\n private get bottomSpacerHeight(): number {\n if (!this.useVirtualScroll.vertical) return 0;\n const remainingRows = this.paginatedRows.length - this.virtualEndIndex - 1;\n return remainingRows > 0 ? remainingRows * this.virtualRowHeight : 0;\n }\n\n private getHorizontalSpacerWidth(position: 'left' | 'right'): number {\n const stickyLeftCount = this.stickyColumn.left || 0;\n const stickyRightCount = this.stickyColumn.right || 0;\n const virtualColumnWidths = this.columnWidths.slice(\n stickyLeftCount,\n this.visibleColumns.length - stickyRightCount,\n );\n const remainingCols = virtualColumnWidths.length - this.virtualEndColIdx - 1;\n if (position === 'right' && remainingCols <= 0) return 0;\n\n const targetIndex =\n position === 'left' ? [0, this.virtualStartColIdx] : [this.virtualEndColIdx + 1];\n return virtualColumnWidths.slice(...targetIndex).reduce((sum, width) => sum + width, 0);\n }\n\n private get leftSpacerWidth(): number {\n if (!this.useVirtualScroll.horizontal || this.virtualStartColIdx === 0) {\n return 0;\n }\n\n return this.getHorizontalSpacerWidth('left');\n }\n\n private get rightSpacerWidth(): number {\n if (!this.useVirtualScroll.horizontal) {\n return 0;\n }\n\n return this.getHorizontalSpacerWidth('right');\n }\n\n private get totalVirtualHeight(): number {\n if (!this.useVirtualScroll.vertical) return 0;\n return this.paginatedRows.length * this.virtualRowHeight;\n }\n\n private get lastPageNumber(): number {\n const { lastPage, rowsPerPage = this.rows.length } = this.pagination || {};\n\n return lastPage ?? Math.max(1, Math.ceil(this.rows.length / rowsPerPage));\n }\n\n private get sdTableClasses() {\n return [\n 'sd-table',\n this.stickyHeader && 'sd-table--sticky-header',\n this.selectable && 'sd-table--selectable',\n this.resizable && 'sd-table--resizable',\n !this.innerRows.length && 'sd-table--no-data',\n ((this.stickyColumn?.left ?? 0) > 0 || (this.stickyColumn?.right ?? 0) > 0) &&\n 'sd-table--sticky-column',\n this.scrolledLeft && 'sd-table--scrolled-left',\n this.scrolledRight && 'sd-table--scrolled-right',\n ]\n .filter(Boolean)\n .join(' ');\n }\n\n // ----- Selection -----\n private isRowSelected(row: Row): boolean {\n return Array.from(this.innerSelected).some(r => r[this.rowKey] === row[this.rowKey]);\n }\n\n private updateRowSelect(row: Row) {\n const selectedArray = Array.from(this.innerSelected);\n const exists = this.isRowSelected(row);\n const newSelected = exists\n ? selectedArray.filter(r => r[this.rowKey] !== row[this.rowKey])\n : [...selectedArray, row];\n\n // 동일 상태면 set하지 않음 → 불필요 렌더 방지\n if (newSelected.length === selectedArray.length) return;\n\n this.innerSelected = new Set(newSelected);\n this.cachedIsAllChecked = undefined;\n\n this.selected = Array.from(this.innerSelected);\n this.sdSelectChange.emit(Array.from(this.innerSelected));\n }\n\n private toggleSelectAll(checked: CheckedType) {\n if (checked) {\n const pageRows = new Set([...this.paginatedRows]);\n this.innerSelected = new Set([...this.innerSelected, ...pageRows]);\n } else {\n const currentPageKeys = this.paginatedRows.map(r => r[this.rowKey]);\n this.innerSelected = new Set(\n [...this.innerSelected].filter(r => !currentPageKeys.includes(r[this.rowKey])),\n );\n }\n\n this.cachedIsAllChecked = undefined;\n\n this.selected = Array.from(this.innerSelected);\n this.sdSelectChange.emit(Array.from(this.innerSelected));\n }\n\n private get isAllChecked(): boolean | null {\n const selectionKey = `${this.paginatedRows.length}-${this.innerSelected.size}`;\n\n if (this.cachedIsAllChecked !== undefined && this.lastSelectionKey === selectionKey) {\n return this.cachedIsAllChecked;\n }\n\n const total = this.paginatedRows.length;\n const selectedCount = this.paginatedRows.filter(row =>\n Array.from(this.innerSelected).some(\n selectedRow => selectedRow[this.rowKey] === row[this.rowKey],\n ),\n ).length;\n\n let result: boolean | null;\n if (selectedCount === 0) {\n result = false; // 아무것도 안 선택됨\n } else if (selectedCount === total) {\n result = true; // 전부 선택됨\n } else {\n result = null; // 일부만 선택됨\n }\n\n this.cachedIsAllChecked = result;\n this.lastSelectionKey = selectionKey;\n\n return result;\n }\n\n // RAF 통합 관리\n private scheduleUpdate(type: 'vertical' | 'horizontal') {\n this.pendingUpdates[type] = true;\n\n if (!this.rafScheduled) {\n this.rafScheduled = true;\n this.scrollRequestAnimationFrame = requestAnimationFrame(() => {\n if (this.pendingUpdates.vertical) this.calculateVisibleRange();\n if (this.pendingUpdates.horizontal) this.calculateVisibleColumnRange();\n\n this.pendingUpdates = { vertical: false, horizontal: false };\n this.rafScheduled = false;\n this.scrollRequestAnimationFrame = null;\n });\n }\n }\n\n // 세로 가상 스크롤 렌더링 계산\n private calculateVisibleRange() {\n if (!this.useVirtualScroll.vertical) {\n this.virtualStartIndex = 0;\n this.virtualEndIndex = this.paginatedRows.length - 1;\n return;\n }\n\n const scrollTop = this.scrollTopPosition;\n let containerHeight = this.cachedContainerHeight;\n\n if (containerHeight === 0 && this.scrollContainer) {\n containerHeight = this.scrollContainer.clientHeight;\n this.cachedContainerHeight = containerHeight;\n }\n\n const bufferSize = this.virtualBufferSize.vertical || 5;\n const startIndex = Math.floor(scrollTop / this.virtualRowHeight);\n const visibleCount = Math.ceil(containerHeight / this.virtualRowHeight);\n const endIndex = startIndex + visibleCount - 1;\n\n const newStartIndex = Math.max(0, startIndex - bufferSize);\n const newEndIndex = Math.min(this.paginatedRows.length - 1, endIndex + bufferSize);\n\n // 실제로 변경된 경우에만 상태 업데이트\n if (this.virtualStartIndex !== newStartIndex || this.virtualEndIndex !== newEndIndex) {\n this.virtualStartIndex = newStartIndex;\n this.virtualEndIndex = newEndIndex;\n }\n }\n\n // 가로 가상 스크롤 렌더링 계산\n private calculateVisibleColumnRange() {\n if (!this.useVirtualScroll.horizontal) {\n this.virtualStartColIdx = 0;\n this.virtualEndColIdx = this.visibleColumns.length - 1;\n return;\n }\n\n const scrollLeft = this.scrollLeftPosition;\n // 캐시된 값 사용, 없으면 측정 후 캐시\n let containerWidth = this.cachedContainerWidth;\n if (containerWidth === 0 && this.scrollContainer) {\n containerWidth = this.scrollContainer.clientWidth;\n this.cachedContainerWidth = containerWidth;\n }\n\n const stickyLeftCount = this.stickyColumn.left || 0;\n const stickyRightCount = this.stickyColumn.right || 0;\n\n // 가상 스크롤 컬럼 - sticky column 제외\n const virtualColumns = this.visibleColumns.slice(\n stickyLeftCount,\n this.visibleColumns.length - stickyRightCount,\n );\n\n if (virtualColumns.length === 0) {\n this.virtualStartColIdx = 0;\n this.virtualEndColIdx = 0;\n return;\n }\n\n const stickyLeftWidth =\n this.columnWidths.slice(0, stickyLeftCount).reduce((sum, width) => sum + width, 0) +\n (this.selectable ? 52 : 0);\n const stickyRightWidth = this.columnWidths\n .slice(this.visibleColumns.length - stickyRightCount)\n .reduce((sum, width) => sum + width, 0);\n\n // 가상 스크롤 영역의 너비 계산\n const virtualScrollableWidth = containerWidth - stickyLeftWidth - stickyRightWidth;\n const virtualColumnWidths = this.columnWidths.slice(\n stickyLeftCount,\n this.visibleColumns.length - stickyRightCount,\n );\n const virtualScrollLeft = Math.max(0, scrollLeft - stickyLeftWidth);\n\n const reducedVirtualWidth = virtualColumnWidths.reduce((acc, width, idx) => {\n acc.push((acc[idx - 1] || 0) + width);\n return acc;\n }, [] as number[]);\n\n let startIdx = 0; // 가상 스크롤 시작 인덱스\n let endIdx = virtualColumns.length - 1; // 가상 스크롤 종료 인덱스\n\n // sticky left 영역 제외한 스크롤 위치\n for (let i = 0; i < reducedVirtualWidth.length; i++) {\n if (reducedVirtualWidth[i] > virtualScrollLeft) {\n startIdx = Math.max(0, i);\n break;\n }\n }\n\n const scrollRight = virtualScrollLeft + virtualScrollableWidth;\n for (let i = startIdx; i < reducedVirtualWidth.length; i++) {\n if (reducedVirtualWidth[i] >= scrollRight) {\n endIdx = Math.min(virtualColumns.length - 1, i);\n break;\n }\n }\n\n const bufferSize = this.virtualBufferSize.horizontal || 5;\n const newStartColIdx = Math.max(0, startIdx - bufferSize);\n const newEndColIdx = Math.min(virtualColumns.length - 1, endIdx + bufferSize);\n\n // 실제로 변경된 경우에만 상태 업데이트\n if (this.virtualStartColIdx !== newStartColIdx || this.virtualEndColIdx !== newEndColIdx) {\n this.virtualStartColIdx = newStartColIdx;\n this.virtualEndColIdx = newEndColIdx;\n }\n }\n\n // ----- Helpers -----\n private getStickyStyle(colIdx: number) {\n // 캐시된 스타일이 있으면 반환\n if (this.stickyStyleCache.has(colIdx)) {\n return this.stickyStyleCache.get(colIdx)!;\n }\n\n const leftOffset =\n this.columnWidths.slice(0, colIdx).reduce((a, b) => a + b, 0) + (this.selectable ? 52 : 0);\n const rightOffset = this.columnWidths\n .filter((_, i) => i >= this.visibleColumns.length - (this.stickyColumn.right || 0) && i > colIdx)\n .reduce((a, b) => a + b, 0);\n\n const style = {\n '--sticky-left-offset': `${leftOffset}px`,\n '--sticky-right-offset': `${rightOffset}px`,\n 'width': `${this.columnWidths[colIdx]}px`,\n 'minWidth': `${this.columnWidths[colIdx]}px`,\n 'maxWidth': `${this.columnWidths[colIdx]}px`,\n };\n\n // 스타일 캐시에 저장\n this.stickyStyleCache.set(colIdx, style);\n return style;\n }\n\n private handleResize(index: number, event: MouseEvent) {\n // SSR 환경 체크\n if (typeof document === 'undefined') return;\n\n const startX = event.clientX;\n const startWidth = this.columnWidths[index];\n\n const handleMouseMove = (moveEvent: MouseEvent) => {\n const targetColumn = this.columnWidths[index];\n if (!targetColumn) return;\n const minWidth = this.columns[index]?.minWidth || 50;\n const maxWidth = this.columns[index]?.maxWidth || 9999;\n const newWidth = Math.min(Math.max(startWidth + moveEvent.clientX - startX, minWidth), maxWidth);\n\n this.columnWidths = this.columnWidths.map((width, idx) => (idx === index ? newWidth : width));\n };\n\n const handleMouseUp = () => {\n document.removeEventListener('mousemove', handleMouseMove);\n document.removeEventListener('mouseup', handleMouseUp);\n };\n\n document.addEventListener('mousemove', handleMouseMove);\n document.addEventListener('mouseup', handleMouseUp);\n }\n\n private getCellValue(column: SdTableColumn, row: Row) {\n const { field, format, name } = column;\n const value = typeof field === 'function' ? field(row) : field ? row[field] : row[name];\n return format ? format(value, row) : value;\n }\n\n private getColumnRenderedInOrder() {\n const orderKey = `${this.visibleColumns.length}-${this.virtualStartColIdx}-${this.virtualEndColIdx}`;\n\n if (this.cachedColumnOrder && this.lastColumnOrderKey === orderKey) {\n return this.cachedColumnOrder;\n }\n\n const stickyLeftCount = this.stickyColumn.left || 0;\n const stickyRightCount = this.stickyColumn.right || 0;\n\n // Sticky left 컬럼들\n const stickyLeftCols = this.visibleColumns.slice(0, stickyLeftCount);\n const stickyRightCols = this.visibleColumns.slice(this.visibleColumns.length - stickyRightCount);\n const middleCols = this.useVirtualScroll.horizontal\n ? this.visibleColumns\n .slice(stickyLeftCount, this.visibleColumns.length - stickyRightCount)\n .slice(this.virtualStartColIdx, this.virtualEndColIdx + 1)\n : this.visibleColumns.slice(stickyLeftCount, this.visibleColumns.length - stickyRightCount);\n\n this.cachedColumnOrder = {\n stickyLeftCount,\n stickyRightCount,\n stickyLeftCols,\n middleCols,\n stickyRightCols,\n };\n this.lastColumnOrderKey = orderKey;\n\n return this.cachedColumnOrder;\n }\n\n // ----- Render -----\n private renderHead() {\n const { stickyLeftCount, stickyRightCount, stickyLeftCols, middleCols, stickyRightCols } =\n this.getColumnRenderedInOrder();\n\n return (\n <thead>\n <tr>\n {this.selectable && (\n <th\n class={{\n 'sd-th': true,\n 'sd-th--selected': true,\n 'sticky-left': Boolean(this.stickyColumn.left && this.stickyColumn.left > 0),\n }}\n style={{\n '--sticky-left-offset': '0px',\n }}\n >\n <sd-checkbox\n value={this.isAllChecked}\n disabled={!this.paginatedRows.length}\n onSdUpdate={(e: CustomEvent<CheckedType>) => this.toggleSelectAll(e.detail)}\n ></sd-checkbox>\n </th>\n )}\n\n {/* Sticky Left 컬럼 - 가상 스크롤과 함께 렌더링시에 매번 재렌더링 후 위치를 조정하여 ux가 이상하기에 분리 */}\n {stickyLeftCols.map((col, idx) => {\n const rendered = this.headerCellRenderer?.(col);\n\n return (\n <th\n key={col.name}\n class={{\n 'sd-th': true,\n [`${col.thClass}`]: Boolean(col.thClass),\n 'sticky-left': true,\n 'sticky-left-edge': idx === stickyLeftCount - 1,\n }}\n style={{ ...col.thStyle, ...this.getStickyStyle(idx) }}\n >\n <div class={`sd-th__content sd-th__content--${col.align || 'left'}`}>\n <slot name={`header-cell-${col.name}`}>\n <div class=\"sd-th__content--label\">\n {rendered ? (\n typeof rendered === 'string' ? (\n <span innerHTML={rendered}></span>\n ) : (\n rendered\n )\n ) : (\n col.label\n )}\n </div>\n </slot>\n\n {col.usePageMoveIcon && <sd-icon name=\"pageMove\" size=\"12\" color=\"#006AC1\" />}\n\n {col.tooltip && (\n <sd-tooltip {...col.tooltipOptions}>\n <div slot=\"content\">\n {col.tooltip.map(text => (\n <p>{text}</p>\n ))}\n </div>\n </sd-tooltip>\n )}\n </div>\n\n {this.resizable && typeof window !== 'undefined' && (\n <div\n class=\"sd-th__resizer\"\n onMouseDown={(evt: MouseEvent) => this.handleResize(idx, evt)}\n ></div>\n )}\n </th>\n );\n })}\n\n {/* 가로 가상 스크롤 왼쪽 Spacer */}\n {this.renderSpacerTd('left', -1)}\n\n {/* 중간 컬럼 */}\n {middleCols.map((col, relativeIdx) => {\n const actualColIdx = stickyLeftCount + this.virtualStartColIdx + relativeIdx;\n const rendered = this.headerCellRenderer?.(col);\n\n return (\n <th\n key={col.name}\n class={{\n 'sd-th': true,\n [`${col.thClass}`]: Boolean(col.thClass),\n }}\n style={{ ...col.thStyle, ...this.getStickyStyle(actualColIdx) }}\n >\n <div class={`sd-th__content sd-th__content--${col.align || 'left'}`}>\n <slot name={`header-cell-${col.name}`}>\n <div class=\"sd-th__content--label\">\n {rendered ? (\n typeof rendered === 'string' ? (\n <span innerHTML={rendered}></span>\n ) : (\n rendered\n )\n ) : (\n col.label\n )}\n </div>\n </slot>\n\n {col.usePageMoveIcon && <sd-icon name=\"pageMove\" size=\"12\" color=\"#006AC1\" />}\n\n {col.tooltip && (\n <sd-tooltip {...col.tooltipOptions}>\n <div slot=\"content\">\n {col.tooltip.map(text => (\n <p>{text}</p>\n ))}\n </div>\n </sd-tooltip>\n )}\n </div>\n\n {this.resizable && typeof window !== 'undefined' && (\n <div\n class=\"sd-th__resizer\"\n onMouseDown={(evt: MouseEvent) => this.handleResize(actualColIdx, evt)}\n ></div>\n )}\n </th>\n );\n })}\n\n {/* 가로 가상 스크롤 오른쪽 Spacer */}\n {this.renderSpacerTd('right', -1)}\n\n {/* Sticky Right 컬럼 - left와 동일 */}\n {stickyRightCols.map((col, relativeIdx) => {\n const actualColIdx = this.visibleColumns.length - stickyRightCount + relativeIdx;\n const rendered = this.headerCellRenderer?.(col);\n\n return (\n <th\n key={col.name}\n class={{\n 'sd-th': true,\n [`${col.thClass}`]: Boolean(col.thClass),\n 'sticky-right': true,\n 'sticky-right-edge': relativeIdx === 0,\n }}\n style={{ ...col.thStyle, ...this.getStickyStyle(actualColIdx) }}\n >\n <div class={`sd-th__content sd-th__content--${col.align || 'left'}`}>\n <slot name={`header-cell-${col.name}`}>\n <div class=\"sd-th__content--label\">\n {rendered ? (\n typeof rendered === 'string' ? (\n <span innerHTML={rendered}></span>\n ) : (\n rendered\n )\n ) : (\n col.label\n )}\n </div>\n </slot>\n\n {col.usePageMoveIcon && <sd-icon name=\"pageMove\" size=\"12\" color=\"#006AC1\" />}\n\n {col.tooltip && (\n <sd-tooltip {...col.tooltipOptions}>\n <div slot=\"content\">\n {col.tooltip.map(text => (\n <p>{text}</p>\n ))}\n </div>\n </sd-tooltip>\n )}\n </div>\n\n {this.resizable && typeof window !== 'undefined' && (\n <div\n class=\"sd-th__resizer\"\n onMouseDown={(evt: MouseEvent) => this.handleResize(actualColIdx, evt)}\n ></div>\n )}\n </th>\n );\n })}\n </tr>\n </thead>\n );\n }\n\n private renderBody() {\n return (\n <tbody\n {...(!this.paginatedRows.length && { part: 'tbody-empty' })}\n class={`sd-table-tbody ${this.useVirtualScroll.vertical ? 'sd-table-tbody--virtual-scroll' : ''}`}\n style={{ '--total-virtual-height': `${this.totalVirtualHeight}px` }}\n >\n {/* {this.isLoading && (\n <div class=\"sd-table__loading\">\n <sd-loading-spinner />\n </div>\n )} */}\n\n {/* 세로 가상 스크롤 상단 여백 */}\n {this.useVirtualScroll.vertical && this.topSpacerHeight > 0 && this.renderSpacerRow('top')}\n\n {this.paginatedRows.length > 0 &&\n this.virtualRows.map(({ row, actualIndex }) => this.renderRow(row, actualIndex))}\n\n {/* 세로 가상 스크롤 하단 여백 */}\n {this.useVirtualScroll.vertical &&\n this.bottomSpacerHeight > 0 &&\n this.renderSpacerRow('bottom')}\n </tbody>\n );\n }\n\n private renderRow(row: Row, rowIdx: number) {\n const { stickyLeftCount, stickyRightCount, stickyLeftCols, middleCols, stickyRightCols } =\n this.getColumnRenderedInOrder();\n\n return (\n <tr\n key={row[this.rowKey]}\n class=\"hover:bg-Grey_Lighten-6\"\n style={\n this.useVirtualScroll.vertical\n ? {\n height: `${this.virtualRowHeight}px`,\n }\n : {}\n }\n >\n {this.selectable && (\n <td\n class={{\n 'sd-td': true,\n 'sd-td--selected': true,\n 'sticky-left': Boolean(this.stickyColumn.left && this.stickyColumn.left > 0),\n }}\n style={{\n '--sticky-left-offset': '0px',\n }}\n >\n <sd-checkbox\n value={this.isRowSelected(row)}\n disabled={!this.paginatedRows.length}\n onSdUpdate={() => this.updateRowSelect(row)}\n ></sd-checkbox>\n </td>\n )}\n\n {/* Sticky Left 컬럼 - 가상 스크롤과 함께 렌더링시에 매번 재렌더링 후 위치를 조정하여 ux가 이상하기에 분리 */}\n {stickyLeftCols.map((column, idx) => {\n const rendered = this.bodyCellRenderer?.(column, row);\n\n return (\n <td\n key={column.name}\n part={`td-${column.name}`}\n class={{\n 'sd-td': true,\n [`sd-td--${column.align || 'left'}`]: true,\n 'sticky-left': true,\n 'sticky-left-edge': idx === stickyLeftCount - 1,\n [`${column.tdClass}`]: Boolean(column.tdClass),\n }}\n style={this.getStickyStyle(idx)}\n >\n <slot name={`body-cell-${column.name}-${rowIdx}`}>\n {rendered ? (\n typeof rendered === 'string' ? (\n <span innerHTML={rendered}></span>\n ) : (\n rendered\n )\n ) : (\n this.getCellValue(column, row)\n )}\n </slot>\n </td>\n );\n })}\n\n {/* 가로 가상 스크롤 왼쪽 Spacer */}\n {this.renderSpacerTd('left', rowIdx)}\n\n {/* 가상 스크롤 중간 컬럼들 */}\n {middleCols.map((column, relativeIdx) => {\n const actualColIdx = stickyLeftCount + this.virtualStartColIdx + relativeIdx;\n const rendered = this.bodyCellRenderer?.(column, row);\n\n return (\n <td\n key={column.name}\n part={`td-${column.name}`}\n class={{\n 'sd-td': true,\n [`sd-td--${column.align || 'left'}`]: true,\n [`${column.tdClass}`]: Boolean(column.tdClass),\n }}\n style={this.getStickyStyle(actualColIdx)}\n >\n <slot name={`body-cell-${column.name}-${rowIdx}`}>\n {rendered ? (\n typeof rendered === 'string' ? (\n <span innerHTML={rendered}></span>\n ) : (\n rendered\n )\n ) : (\n this.getCellValue(column, row)\n )}\n </slot>\n </td>\n );\n })}\n\n {/* 가로 가상 스크롤 오른쪽 Spacer */}\n {this.renderSpacerTd('right', rowIdx)}\n\n {/* Sticky Right 컬럼 - left와 동일 */}\n {stickyRightCols.map((column, relativeIdx) => {\n const actualColIdx = this.visibleColumns.length - stickyRightCount + relativeIdx;\n const rendered = this.bodyCellRenderer?.(column, row);\n\n return (\n <td\n key={column.name}\n part={`td-${column.name}`}\n class={{\n 'sd-td': true,\n [`sd-td--${column.align || 'left'}`]: true,\n 'sticky-right': true,\n 'sticky-right-edge': relativeIdx === 0,\n [`${column.tdClass}`]: Boolean(column.tdClass),\n }}\n style={this.getStickyStyle(actualColIdx)}\n >\n <slot name={`body-cell-${column.name}-${rowIdx}`}>\n {rendered ? (\n typeof rendered === 'string' ? (\n <span innerHTML={rendered}></span>\n ) : (\n rendered\n )\n ) : (\n this.getCellValue(column, row)\n )}\n </slot>\n </td>\n );\n })}\n </tr>\n );\n }\n\n private renderSpacerRow(position: 'top' | 'bottom') {\n const spacerHeight = position === 'top' ? this.topSpacerHeight : this.bottomSpacerHeight;\n\n return (\n <tr\n key={`virtual-${position}-spacer`}\n class=\"sd-table__virtual-row-spacer\"\n style={{\n height: `${spacerHeight}px`,\n }}\n aria-hidden=\"true\"\n >\n <td colSpan={this.visibleColumns.length + (this.selectable ? 1 : 0)}>\n <div\n class=\"sd-table__skeleton\"\n style={{\n '--row-height': `${this.virtualRowHeight}px`,\n }}\n ></div>\n </td>\n </tr>\n );\n }\n\n private renderSpacerTd(position: 'left' | 'right', rowIdx: number) {\n const spacerWidth = position === 'left' ? this.leftSpacerWidth : this.rightSpacerWidth;\n const showSpacer =\n position === 'left'\n ? this.useVirtualScroll.horizontal && this.leftSpacerWidth > 0\n : this.useVirtualScroll.horizontal && this.rightSpacerWidth > 0;\n\n if (!showSpacer) return null;\n\n return (\n <td\n key={`virtual-${position}-spacer-${rowIdx}`}\n class=\"sd-table__virtual-spacer\"\n style={{\n width: `${spacerWidth}px`,\n minWidth: `${spacerWidth}px`,\n maxWidth: `${spacerWidth}px`,\n padding: '0',\n border: 'none',\n }}\n aria-hidden=\"true\"\n >\n <div class=\"sd-table__skeleton-cell\"></div>\n </td>\n );\n }\n\n render() {\n return (\n <Host>\n <div\n class=\"sd-table__wrapper\"\n style={{\n '--table-width': this.width,\n '--table-height': this.height,\n }}\n >\n <div\n class=\"sd-table__container\"\n style={{\n '--table-container-height': `calc(${this.height} - ${this.pagination && this.innerRows.length > 0 ? 48 : 0}px)`,\n }}\n >\n <div\n class={{\n 'sd-table__middle': true,\n 'sd-table__middle--scrollable': this.paginatedRows.length > 0,\n 'sd-table__middle--loading': this.isLoading,\n }}\n >\n {this.isLoading && (\n <div class=\"sd-table__middle--loading__spinner\">\n <sd-loading-spinner />\n </div>\n )}\n <table part=\"table\" class={this.sdTableClasses}>\n {this.renderHead()}\n\n {this.renderBody()}\n </table>\n </div>\n\n {!this.paginatedRows.length && (\n <div class=\"sd-table__bottom\">\n <div class=\"sd-table__no-data\">\n <slot name=\"no-data\">{this.noDataLabel}</slot>\n </div>\n </div>\n )}\n </div>\n\n {this.pagination && this.innerRows.length > 0 && (\n <div class=\"sd-table__pagination\">\n <sd-pagination\n currentPage={!this.useInternalPagination ? this.pagination.page : this.currentPage}\n lastPage={!this.useInternalPagination ? this.pagination.lastPage : this.lastPageNumber}\n onSdPageChange={(e: CustomEvent<number>) => this.changePage(e.detail)}\n />\n\n {this.useRowsPerPageSelect && (\n <sd-select\n value={this.pagination.rowsPerPage}\n options={this.rowsPerPageOption}\n width=\"128px\"\n onSdUpdate={(e: SdSelectCustomEvent<{ value: string | number | null }>) =>\n this.changeRowsPerPage(e.detail.value)\n }\n />\n )}\n </div>\n )}\n </div>\n </Host>\n );\n }\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,64 @@
1
+ import { r as registerInstance, c as createEvent, h } from './index-C3qNZ7Qh.js';
2
+
3
+ const sdTabsCss = () => `sd-tabs{display:inline-block}sd-tabs .sd-tabs{display:flex;flex-direction:row;gap:4px;border-bottom:1px solid #0075ff}sd-tabs .sd-tabs__tab{display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;border:1px solid #cccccc;border-bottom:none;border-radius:4px 4px 0 0;background-color:#f6f6f6;color:#888888;font-weight:400;transition:all 0.2s ease;position:relative;user-select:none}sd-tabs .sd-tabs__tab::before{content:"";position:absolute;inset:0;opacity:0;transition:all 0.3s}sd-tabs .sd-tabs__tab--selected{border-color:#0075ff;color:#0075ff;background-color:white}sd-tabs .sd-tabs__tab--selected .sd-tabs__label::before{font-weight:700}sd-tabs .sd-tabs__tab--selected:hover::before{background-color:#0075ff;opacity:0.15}sd-tabs .sd-tabs__tab--unselected:hover::before{background-color:#888888;opacity:0.15}sd-tabs .sd-tabs__label{user-select:none;font-weight:700;visibility:hidden;position:relative}sd-tabs .sd-tabs__label::before{content:attr(data-label);visibility:visible;position:absolute;inset:0;font-weight:400;transition:font-weight 0.2s ease}sd-tabs .sd-tabs--md .sd-tabs__tab{padding:12px 32px;font-size:12px;line-height:20px}sd-tabs .sd-tabs--sm .sd-tabs__tab{padding:8px 20px;font-size:12px;line-height:16px}sd-tabs .sd-tabs--sub{gap:32px;border-bottom:none}sd-tabs .sd-tabs--sub .sd-tabs__tab{border:none;border-radius:0;background-color:transparent;color:#222222;font-weight:400;padding:0 0 2px 0;position:relative}sd-tabs .sd-tabs--sub .sd-tabs__tab::before{content:"";position:absolute;top:100%;left:0;right:0;height:1px;width:100%;background-color:#0075ff;opacity:0;transition:opacity 0.2s ease}sd-tabs .sd-tabs--sub .sd-tabs__tab::after{font-weight:400}sd-tabs .sd-tabs--sub .sd-tabs__tab--selected{color:#0075ff;background-color:transparent}sd-tabs .sd-tabs--sub .sd-tabs__tab--selected::before{opacity:1}sd-tabs .sd-tabs--sub .sd-tabs__tab--selected::after{font-weight:700}`;
4
+
5
+ const SdTabs = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ this.update = createEvent(this, "sdUpdate");
9
+ }
10
+ value;
11
+ tabs = [];
12
+ size = 'md';
13
+ isSub = false;
14
+ update;
15
+ componentWillLoad() {
16
+ if (this.value !== undefined && this.value !== null) {
17
+ this.value = this.value;
18
+ }
19
+ }
20
+ valueChanged(newValue) {
21
+ this.value = newValue;
22
+ }
23
+ handleTabClick = (tabValue) => {
24
+ this.value = tabValue;
25
+ this.value = tabValue;
26
+ this.update.emit(tabValue);
27
+ };
28
+ isTabSelected(tab) {
29
+ return this.value === tab.value;
30
+ }
31
+ getTabClasses(tab) {
32
+ const classes = [
33
+ 'sd-tabs__tab',
34
+ this.isTabSelected(tab) ? 'sd-tabs__tab--selected' : 'sd-tabs__tab--unselected',
35
+ ];
36
+ return classes.join(' ');
37
+ }
38
+ getContainerClasses() {
39
+ const classes = ['sd-tabs', `sd-tabs--${this.size}`];
40
+ if (this.isSub) {
41
+ classes.push('sd-tabs--sub');
42
+ }
43
+ return classes.join(' ');
44
+ }
45
+ getBadgeColors(tab) {
46
+ if (this.isTabSelected(tab)) {
47
+ return { bgColor: '#E6F1FF', textColor: '#0075FF' };
48
+ }
49
+ return { bgColor: '#E5E5E5', textColor: '#737373' };
50
+ }
51
+ render() {
52
+ return (h("div", { key: '1f9b39d82a7a98bb9dffd522d9f703b41682ae71', class: this.getContainerClasses() }, this.tabs.map((tab, index) => {
53
+ const badgeColors = this.getBadgeColors(tab);
54
+ return (h("div", { key: `tab-${index}`, class: this.getTabClasses(tab), "aria-label": tab.label || 'tab', onClick: () => this.handleTabClick(tab.value) }, h("span", { "data-label": tab.label, class: "sd-tabs__label" }, tab.label), tab.badge && (h("sd-tag", { size: this.size, label: tab.badge.toString(), bgColor: badgeColors.bgColor, textColor: badgeColors.textColor, rounded: false }))));
55
+ })));
56
+ }
57
+ static get watchers() { return {
58
+ "value": ["valueChanged"]
59
+ }; }
60
+ };
61
+ SdTabs.style = sdTabsCss();
62
+
63
+ export { SdTabs as sd_tabs };
64
+ //# sourceMappingURL=sd-tabs.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sd-tabs.entry.js","sources":["src/components/sd-tabs/sd-tabs.scss?tag=sd-tabs","src/components/sd-tabs/sd-tabs.tsx"],"sourcesContent":["@import 'variables';\n\nsd-tabs {\n display: inline-block;\n\n .sd-tabs {\n display: flex;\n flex-direction: row;\n gap: 4px;\n border-bottom: 1px solid $brilliantblue_75;\n\n &__tab {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 8px;\n cursor: pointer;\n border: 1px solid $grey_45;\n border-bottom: none;\n border-radius: 4px 4px 0 0;\n background-color: $grey_10;\n color: $grey_65;\n font-weight: 400;\n transition: all 0.2s ease;\n position: relative;\n user-select: none;\n\n &::before {\n content: '';\n position: absolute;\n inset: 0;\n opacity: 0;\n transition: all 0.3s;\n }\n\n // Selected/Active state\n &--selected {\n border-color: $brilliantblue_75;\n color: $brilliantblue_75;\n background-color: white;\n\n .sd-tabs__label::before {\n font-weight: 700;\n }\n\n // Hover state for selected tab\n &:hover::before {\n background-color: $brilliantblue_75;\n opacity: 0.15;\n }\n }\n\n // Unselected state hover\n &--unselected {\n &:hover::before {\n background-color: $grey_65;\n opacity: 0.15;\n }\n }\n }\n\n &__label {\n user-select: none;\n font-weight: 700;\n visibility: hidden;\n position: relative;\n\n &::before {\n content: attr(data-label);\n visibility: visible;\n position: absolute;\n inset: 0;\n font-weight: 400;\n transition: font-weight 0.2s ease;\n }\n }\n\n // Size: Medium (default)\n &--md {\n .sd-tabs__tab {\n padding: 12px 32px;\n font-size: 12px;\n line-height: 20px;\n }\n }\n\n // Size: Small\n &--sm {\n .sd-tabs__tab {\n padding: 8px 20px;\n font-size: 12px;\n line-height: 16px;\n }\n }\n\n &--sub {\n gap: 32px;\n border-bottom: none;\n\n .sd-tabs__tab {\n border: none;\n border-radius: 0;\n background-color: transparent;\n color: $grey_95;\n font-weight: 400;\n padding: 0 0 2px 0;\n position: relative;\n\n &::before {\n content: '';\n position: absolute;\n top: 100%;\n left: 0;\n right: 0;\n height: 1px;\n width: 100%;\n background-color: $brilliantblue_75;\n opacity: 0;\n transition: opacity 0.2s ease;\n }\n\n &::after {\n font-weight: 400;\n }\n\n &--selected {\n color: $brilliantblue_75;\n background-color: transparent;\n\n &::before {\n opacity: 1;\n }\n\n &::after {\n font-weight: 700;\n }\n }\n }\n }\n }\n}","import { Component, Prop, h, EventEmitter, Event, Watch } from '@stencil/core';\n\nexport type TabOption = {\n label: string;\n value: string;\n badge?: string | number;\n};\n\n@Component({\n tag: 'sd-tabs',\n styleUrl: 'sd-tabs.scss',\n})\nexport class SdTabs {\n @Prop({ mutable: true, reflect: true }) value!: string;\n\n @Prop({ mutable: true }) tabs: TabOption[] = [];\n\n @Prop() size: 'sm' | 'md' = 'md';\n\n @Prop() isSub: boolean = false;\n\n @Event({ eventName: 'sdUpdate' })\n update!: EventEmitter<string>;\n\n componentWillLoad() {\n if (this.value !== undefined && this.value !== null) {\n this.value = this.value;\n }\n }\n\n @Watch('value')\n valueChanged(newValue: string) {\n this.value = newValue;\n }\n\n private handleTabClick = (tabValue: string) => {\n this.value = tabValue;\n this.value = tabValue;\n this.update.emit(tabValue);\n };\n\n private isTabSelected(tab: TabOption): boolean {\n return this.value === tab.value;\n }\n\n private getTabClasses(tab: TabOption): string {\n const classes = [\n 'sd-tabs__tab',\n this.isTabSelected(tab) ? 'sd-tabs__tab--selected' : 'sd-tabs__tab--unselected',\n ];\n\n return classes.join(' ');\n }\n\n private getContainerClasses(): string {\n const classes = ['sd-tabs', `sd-tabs--${this.size}`];\n\n if (this.isSub) {\n classes.push('sd-tabs--sub');\n }\n\n return classes.join(' ');\n }\n\n private getBadgeColors(tab: TabOption): { bgColor: string; textColor: string } {\n if (this.isTabSelected(tab)) {\n return { bgColor: '#E6F1FF', textColor: '#0075FF' };\n }\n return { bgColor: '#E5E5E5', textColor: '#737373' };\n }\n\n render() {\n return (\n <div\n class={this.getContainerClasses()}\n // role=\"tablist\"\n >\n {this.tabs.map((tab, index) => {\n const badgeColors = this.getBadgeColors(tab);\n\n return (\n <div\n key={`tab-${index}`}\n class={this.getTabClasses(tab)}\n // role=\"tab\"\n // aria-selected={isSelected.toString()}\n aria-label={tab.label || 'tab'}\n onClick={() => this.handleTabClick(tab.value)}\n >\n <span data-label={tab.label} class=\"sd-tabs__label\">\n {tab.label}\n </span>\n {tab.badge && (\n <sd-tag\n size={this.size}\n label={tab.badge.toString()}\n bgColor={badgeColors.bgColor}\n textColor={badgeColors.textColor}\n rounded={false}\n />\n )}\n </div>\n );\n })}\n </div>\n );\n }\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,55 @@
1
+ import { r as registerInstance, a as getElement, h } from './index-C3qNZ7Qh.js';
2
+
3
+ const sdTagCss = () => `:host{display:inline-block}:host([full-width]){display:block}.sd-tag{display:inline-flex;width:100%;align-items:center;justify-content:center;gap:8px;text-decoration:none;border:1px solid transparent;border-radius:4px;transition:all 0.2s ease-in-out;position:relative;overflow:hidden;white-space:nowrap;-webkit-user-select:none;user-select:none;box-sizing:border-box}.sd-tag__content{display:inline-block;width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.sd-tag--custom-color{background:var(--tag-bg-color);color:var(--tag-text-color)}.sd-tag--sm{padding:0 6px;font-size:11px;line-height:18px;height:20px;border-radius:4px}.sd-tag--md{padding:0 8px;font-size:12px;font-weight:700;line-height:20px;height:24px;border-radius:4px}.sd-tag--lg{padding:0 10px;font-size:14px;font-weight:700;line-height:24px;min-height:28px;border-radius:5px}.sd-tag--rounded.sd-tag--sm{border-radius:20px}.sd-tag--rounded.sd-tag--md{border-radius:20px}.sd-tag--rounded.sd-tag--lg{border-radius:15px}`;
4
+
5
+ const TAG_COLORS = {
6
+ grey: 'bg-grey_20 text-grey_70',
7
+ red: 'bg-red_15 text-red_70',
8
+ orange: 'bg-orange_10 text-orange_65',
9
+ yellow: 'bg-yellow_10 text-yellow_70',
10
+ green: 'bg-green_15 text-green_75',
11
+ blue: 'bg-brilliantblue_20 text-brilliantblue_75',
12
+ darkblue: 'bg-oceanblue_15 text-oceanblue_70',
13
+ indigo: 'bg-brilliantblue_10 text-brilliantblue_85',
14
+ };
15
+ const SdTag = class {
16
+ constructor(hostRef) {
17
+ registerInstance(this, hostRef);
18
+ }
19
+ get el() { return getElement(this); }
20
+ size = 'md';
21
+ color = 'grey';
22
+ rounded = false;
23
+ label = '';
24
+ bgColor;
25
+ textColor;
26
+ getTagClasses() {
27
+ const classes = ['sd-tag', `sd-tag--${this.size}`];
28
+ if (this.rounded) {
29
+ classes.push('sd-tag--rounded');
30
+ }
31
+ if (this.color && !this.bgColor && !this.textColor) {
32
+ classes.push(TAG_COLORS[this.color]);
33
+ }
34
+ if (this.bgColor || this.textColor) {
35
+ classes.push('sd-tag--custom-color');
36
+ }
37
+ return classes.join(' ');
38
+ }
39
+ renderContent() {
40
+ return [
41
+ h("span", { class: "sd-tag__content" }, h("slot", null, this.label)),
42
+ ];
43
+ }
44
+ render() {
45
+ const tagClasses = this.getTagClasses();
46
+ return (h("span", { key: '2a25443d15ad9d0c9205455e80cf236d02cec6d9', class: tagClasses, style: {
47
+ '--tag-bg-color': this.bgColor,
48
+ '--tag-text-color': this.textColor,
49
+ }, "aria-label": this.label || 'tag' }, this.renderContent()));
50
+ }
51
+ };
52
+ SdTag.style = sdTagCss();
53
+
54
+ export { SdTag as sd_tag };
55
+ //# sourceMappingURL=sd-tag.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sd-tag.entry.js","sources":["src/components/sd-tag/sd-tag.scss?tag=sd-tag&encapsulation=shadow","src/components/sd-tag/sd-tag.tsx"],"sourcesContent":[":host {\n display: inline-block;\n}\n\n:host([full-width]) {\n display: block;\n}\n\n.sd-tag {\n display: inline-flex;\n width: 100%;\n align-items: center;\n justify-content: center;\n gap: 8px;\n text-decoration: none;\n border: 1px solid transparent;\n border-radius: 4px;\n transition: all 0.2s ease-in-out;\n position: relative;\n overflow: hidden;\n white-space: nowrap;\n -webkit-user-select: none;\n user-select: none;\n box-sizing: border-box;\n\n &__content {\n display: inline-block;\n width: 100%;\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n }\n\n &--custom-color {\n background: var(--tag-bg-color);\n color: var(--tag-text-color);\n }\n\n &--sm {\n padding: 0 6px;\n font-size: 11px;\n line-height: 18px;\n height: 20px;\n border-radius: 4px;\n }\n &--md {\n padding: 0 8px;\n font-size: 12px;\n font-weight: 700;\n line-height: 20px;\n height: 24px;\n border-radius: 4px;\n }\n &--lg {\n padding: 0 10px;\n font-size: 14px;\n font-weight: 700;\n line-height: 24px;\n min-height: 28px;\n border-radius: 5px;\n }\n &--rounded {\n &.sd-tag--sm {\n border-radius: 20px;\n }\n &.sd-tag--md {\n border-radius: 20px;\n }\n &.sd-tag--lg {\n border-radius: 15px;\n }\n }\n}\n","import { Component, Prop, h, Element } from '@stencil/core';\n\nexport type TagColor =\n | 'grey'\n | 'red'\n | 'orange'\n | 'yellow'\n | 'green'\n | 'blue'\n | 'darkblue'\n | 'indigo';\n\nexport type TagSize = 'sm' | 'md' | 'lg';\n\nconst TAG_COLORS = {\n grey: 'bg-grey_20 text-grey_70',\n red: 'bg-red_15 text-red_70',\n orange: 'bg-orange_10 text-orange_65',\n yellow: 'bg-yellow_10 text-yellow_70',\n green: 'bg-green_15 text-green_75',\n blue: 'bg-brilliantblue_20 text-brilliantblue_75',\n darkblue: 'bg-oceanblue_15 text-oceanblue_70',\n indigo: 'bg-brilliantblue_10 text-brilliantblue_85',\n};\n\n@Component({\n tag: 'sd-tag',\n styleUrl: 'sd-tag.scss',\n shadow: true,\n})\nexport class SdTag {\n @Element() el!: HTMLElement;\n\n @Prop() size: TagSize = 'md';\n @Prop() color: TagColor = 'grey';\n @Prop() rounded: boolean = false;\n @Prop() label: string = '';\n @Prop() bgColor?: string;\n @Prop() textColor?: string;\n\n private getTagClasses(): string {\n const classes = ['sd-tag', `sd-tag--${this.size}`];\n\n if (this.rounded) {\n classes.push('sd-tag--rounded');\n }\n\n if (this.color && !this.bgColor && !this.textColor) {\n classes.push(TAG_COLORS[this.color]);\n }\n\n if (this.bgColor || this.textColor) {\n classes.push('sd-tag--custom-color');\n }\n\n return classes.join(' ');\n }\n\n private renderContent() {\n return [\n <span class=\"sd-tag__content\">\n <slot>{this.label}</slot>\n </span>,\n ];\n }\n\n render() {\n const tagClasses = this.getTagClasses();\n\n return (\n <span\n class={tagClasses}\n style={{\n '--tag-bg-color': this.bgColor,\n '--tag-text-color': this.textColor,\n }}\n aria-label={this.label || 'tag'}\n >\n {this.renderContent()}\n </span>\n );\n }\n}\n"],"names":[],"mappings":";;AAAA,MAAM,QAAQ,GAAG,MAAM,CAAC,q+BAAq+B,CAAC;;ACc9/B,MAAM,UAAU,GAAG;AAClB,IAAA,IAAI,EAAE,yBAAyB;AAC/B,IAAA,GAAG,EAAE,uBAAuB;AAC5B,IAAA,MAAM,EAAE,6BAA6B;AACrC,IAAA,MAAM,EAAE,6BAA6B;AACrC,IAAA,KAAK,EAAE,2BAA2B;AAClC,IAAA,IAAI,EAAE,2CAA2C;AACjD,IAAA,QAAQ,EAAE,mCAAmC;AAC7C,IAAA,MAAM,EAAE,2CAA2C;CACnD;MAOY,KAAK,GAAA,MAAA;;;;;IAGT,IAAI,GAAY,IAAI;IACpB,KAAK,GAAa,MAAM;IACxB,OAAO,GAAY,KAAK;IACxB,KAAK,GAAW,EAAE;AAClB,IAAA,OAAO;AACP,IAAA,SAAS;IAET,aAAa,GAAA;QACpB,MAAM,OAAO,GAAG,CAAC,QAAQ,EAAE,CAAW,QAAA,EAAA,IAAI,CAAC,IAAI,CAAE,CAAA,CAAC;AAElD,QAAA,IAAI,IAAI,CAAC,OAAO,EAAE;AACjB,YAAA,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC;;AAGhC,QAAA,IAAI,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnD,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;;QAGrC,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,EAAE;AACnC,YAAA,OAAO,CAAC,IAAI,CAAC,sBAAsB,CAAC;;AAGrC,QAAA,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC;;IAGjB,aAAa,GAAA;QACpB,OAAO;AACN,YAAA,CAAM,CAAA,MAAA,EAAA,EAAA,KAAK,EAAC,iBAAiB,EAAA,EAC5B,CAAA,CAAA,MAAA,EAAA,IAAA,EAAO,IAAI,CAAC,KAAK,CAAQ,CACnB;SACP;;IAGF,MAAM,GAAA;AACL,QAAA,MAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE;AAEvC,QAAA,QACC,CACC,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,UAAU,EACjB,KAAK,EAAE;gBACN,gBAAgB,EAAE,IAAI,CAAC,OAAO;gBAC9B,kBAAkB,EAAE,IAAI,CAAC,SAAS;AAClC,aAAA,EAAA,YAAA,EACW,IAAI,CAAC,KAAK,IAAI,KAAK,EAAA,EAE9B,IAAI,CAAC,aAAa,EAAE,CACf;;;;;;;"}
@@ -0,0 +1,59 @@
1
+ import { r as registerInstance, c as createEvent, h, H as Host } from './index-C3qNZ7Qh.js';
2
+ import { r as resolveColor } from './resolveColor-DcGvp3RM.js';
3
+
4
+ const sdToastMessageCss = () => `.sd-toast-message.sc-sd-toast-message{display:flex;width:fit-content;align-items:center;gap:16px;padding:12px 24px;border-radius:4px;background-color:var(--sd-toast-bg);color:var(--sd-toast-text);transition:opacity 0.2s ease, visibility 0.2s ease;box-shadow:2px 2px 8px 2px rgba(0, 0, 0, 0.2)}.sd-toast-message--hidden.sc-sd-toast-message{opacity:0;visibility:hidden;pointer-events:none}.sd-toast-message__icon.sc-sd-toast-message{display:flex;align-items:center;flex-shrink:0}.sd-toast-message__content.sc-sd-toast-message{display:flex;flex:1}.sd-toast-message__message.sc-sd-toast-message{font-size:14px;line-height:20px;font-weight:400}.sd-toast-message__link.sc-sd-toast-message{font-size:14px;line-height:20px;color:var(--sd-toast-text);text-decoration:underline;cursor:pointer;transition:opacity 0.2s ease;margin-left:4px}.sd-toast-message__link.sc-sd-toast-message:hover{opacity:0.8}.sd-toast-message__button.sc-sd-toast-message{flex-shrink:0}.sd-toast-message__button.sc-sd-toast-message button.sc-sd-toast-message{color:var(--button-text-color, inherit) !important}.sd-toast-message__close.sc-sd-toast-message{display:flex;align-items:center;justify-content:center;padding:4px;background-color:transparent;border:none;cursor:pointer;transition:opacity 0.2s ease;flex-shrink:0}.sd-toast-message__close.sc-sd-toast-message:hover{opacity:0.7}.sd-toast-message__close.sc-sd-toast-message:active{opacity:0.5}`;
5
+
6
+ const SdToastMessage = class {
7
+ constructor(hostRef) {
8
+ registerInstance(this, hostRef);
9
+ this.close = createEvent(this, "sdClose");
10
+ this.buttonClick = createEvent(this, "sdButtonClick");
11
+ }
12
+ icon;
13
+ message;
14
+ link;
15
+ linkLabel;
16
+ buttonLabel;
17
+ useClose = false;
18
+ type = 'basicDark';
19
+ close;
20
+ buttonClick;
21
+ isVisible = true;
22
+ static COLOR_OF_TYPE = {
23
+ basicLight: { background: 'white', text: 'grey_95' },
24
+ basicDark: { background: 'steelblue_90', text: 'white' },
25
+ error: { background: 'red_70', text: 'white' },
26
+ caution: { background: 'yellow_40', text: 'grey_90' },
27
+ complete: { background: 'green_75', text: 'white' },
28
+ progress: { background: 'brilliantblue_80', text: 'white' },
29
+ };
30
+ handleClose = () => {
31
+ this.isVisible = false;
32
+ this.close.emit();
33
+ };
34
+ handleButtonClick = () => {
35
+ this.buttonClick.emit();
36
+ };
37
+ getContainerClasses() {
38
+ const classes = ['sd-toast-message', `sd-toast-message--${this.type}`];
39
+ if (!this.isVisible) {
40
+ classes.push('sd-toast-message--hidden');
41
+ }
42
+ return classes.join(' ');
43
+ }
44
+ render() {
45
+ const colorTokens = SdToastMessage.COLOR_OF_TYPE[this.type];
46
+ const colors = {
47
+ background: resolveColor(colorTokens.background),
48
+ text: resolveColor(colorTokens.text),
49
+ };
50
+ return (h(Host, { key: 'edd60b2a74bae15c88131baedaa3e913dc5326ae', style: {
51
+ '--sd-toast-bg': colors.background,
52
+ '--sd-toast-text': colors.text,
53
+ } }, h("div", { key: 'b41ad15e9fe7520ee8fbf683f6d95e327c59ac6c', class: this.getContainerClasses(), role: "status", "aria-live": "polite", "aria-atomic": "true" }, this.icon && (h("div", { key: 'def78fc8bc05ead9b97144dccc4f105fad953477', class: "sd-toast-message__icon" }, h("sd-icon", { key: 'a01368892d295aee0339fa027663bffe31fb2c2b', name: this.icon, size: 16, color: colors.text }))), h("div", { key: 'f0c6d32da360c2135aee2374b1091c27bddf4d22', class: "sd-toast-message__content" }, h("span", { key: '0f1f7d81154470ad9bcc3d8d4c1ed0c0994da7bb', class: "sd-toast-message__message" }, this.message)), this.link && (h("a", { key: '2a4f7b21940e2234653a18e8a677aba9586d18e3', href: this.link, class: "sd-toast-message__link", target: "_blank", rel: "noopener noreferrer" }, this.linkLabel || this.link)), this.buttonLabel && (h("sd-button", { key: 'd399961349429bee81fa395c555879fabef86136', class: `sd-toast-message__button ${this.type === 'basicLight' ? 'text-white' : ''}`, label: this.buttonLabel, variant: "primary", color: this.type === 'basicLight' ? 'oceanblue_75' : 'white', size: "sm", onClick: this.handleButtonClick, style: this.type !== 'basicLight' ? { '--button-text-color': resolveColor('grey_95') } : {} })), this.useClose && (h("button", { key: '4bfae7573d5a5204c29d5ef0e2dc71e9a7622d62', type: "button", class: "sd-toast-message__close", onClick: this.handleClose, "aria-label": "Close", title: "Close" }, h("sd-icon", { key: '7ac20a34965ee46c8af76c6c862a69269a73f1a2', name: "close", size: 12, color: colors.text }))))));
54
+ }
55
+ };
56
+ SdToastMessage.style = sdToastMessageCss();
57
+
58
+ export { SdToastMessage as sd_toast_message };
59
+ //# sourceMappingURL=sd-toast-message.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sd-toast-message.entry.js","sources":["src/components/sd-toast-message/sd-toast-message.scss?tag=sd-toast-message&encapsulation=scoped","src/components/sd-toast-message/sd-toast-message.tsx"],"sourcesContent":["@import 'variables';\n\n.sd-toast-message {\n display: flex;\n width: fit-content;\n align-items: center;\n gap: 16px;\n padding: 12px 24px;\n border-radius: 4px;\n background-color: var(--sd-toast-bg);\n color: var(--sd-toast-text);\n transition: opacity 0.2s ease, visibility 0.2s ease;\n box-shadow: 2px 2px 8px 2px #00000033;\n\n &--hidden {\n opacity: 0;\n visibility: hidden;\n pointer-events: none;\n }\n\n &__icon {\n display: flex;\n align-items: center;\n flex-shrink: 0;\n }\n\n &__content {\n display: flex;\n flex: 1;\n }\n\n &__message {\n font-size: 14px;\n line-height: 20px;\n font-weight: 400;\n }\n\n &__link {\n font-size: 14px;\n line-height: 20px;\n color: var(--sd-toast-text);\n text-decoration: underline;\n cursor: pointer;\n transition: opacity 0.2s ease;\n margin-left: 4px;\n\n &:hover {\n opacity: 0.8;\n }\n }\n\n &__button {\n flex-shrink: 0;\n\n button {\n color: var(--button-text-color, inherit) !important;\n }\n }\n\n &__close {\n display: flex;\n align-items: center;\n justify-content: center;\n padding: 4px;\n background-color: transparent;\n border: none;\n cursor: pointer;\n transition: opacity 0.2s ease;\n flex-shrink: 0;\n\n &:hover {\n opacity: 0.7;\n }\n\n &:active {\n opacity: 0.5;\n }\n }\n}","import { Component, Prop, h, Event, EventEmitter, State, Host } from '@stencil/core';\nimport { resolveColor } from '../../utils/color';\n\nexport type ToastType = 'basicLight' | 'basicDark' | 'error' | 'caution' | 'complete' | 'progress';\n\n@Component({\n tag: 'sd-toast-message',\n styleUrl: 'sd-toast-message.scss',\n scoped: true,\n})\nexport class SdToastMessage {\n @Prop() icon?: IconName;\n\n @Prop() message!: string;\n\n @Prop() link?: string;\n\n @Prop() linkLabel?: string;\n\n @Prop() buttonLabel?: string;\n\n @Prop() useClose: boolean = false;\n\n @Prop() type: ToastType = 'basicDark';\n\n @Event({ eventName: 'sdClose' })\n close!: EventEmitter<void>;\n\n @Event({ eventName: 'sdButtonClick' })\n buttonClick!: EventEmitter<void>;\n\n @State() private isVisible: boolean = true;\n\n private static readonly COLOR_OF_TYPE = {\n basicLight: { background: 'white', text: 'grey_95' },\n basicDark: { background: 'steelblue_90', text: 'white' },\n error: { background: 'red_70', text: 'white' },\n caution: { background: 'yellow_40', text: 'grey_90' },\n complete: { background: 'green_75', text: 'white' },\n progress: { background: 'brilliantblue_80', text: 'white' },\n };\n\n private handleClose = () => {\n this.isVisible = false;\n this.close.emit();\n };\n\n private handleButtonClick = () => {\n this.buttonClick.emit();\n };\n\n private getContainerClasses(): string {\n const classes = ['sd-toast-message', `sd-toast-message--${this.type}`];\n\n if (!this.isVisible) {\n classes.push('sd-toast-message--hidden');\n }\n\n return classes.join(' ');\n }\n\n render() {\n const colorTokens = SdToastMessage.COLOR_OF_TYPE[this.type];\n const colors = {\n background: resolveColor(colorTokens.background),\n text: resolveColor(colorTokens.text),\n };\n\n return (\n <Host\n style={{\n '--sd-toast-bg': colors.background,\n '--sd-toast-text': colors.text,\n }}\n >\n <div class={this.getContainerClasses()} role=\"status\" aria-live=\"polite\" aria-atomic=\"true\">\n {this.icon && (\n <div class=\"sd-toast-message__icon\">\n <sd-icon name={this.icon} size={16} color={colors.text}></sd-icon>\n </div>\n )}\n\n <div class=\"sd-toast-message__content\">\n <span class=\"sd-toast-message__message\">{this.message}</span>\n </div>\n\n {this.link && (\n <a href={this.link} class=\"sd-toast-message__link\" target=\"_blank\" rel=\"noopener noreferrer\">\n {this.linkLabel || this.link}\n </a>\n )}\n\n {this.buttonLabel && (\n <sd-button\n class={`sd-toast-message__button ${this.type === 'basicLight' ? 'text-white' : ''}`}\n label={this.buttonLabel}\n variant=\"primary\"\n color={this.type === 'basicLight' ? 'oceanblue_75' : 'white'}\n size=\"sm\"\n onClick={this.handleButtonClick}\n style={this.type !== 'basicLight' ? { '--button-text-color': resolveColor('grey_95') } : {}}\n ></sd-button>\n )}\n\n {this.useClose && (\n <button\n type=\"button\"\n class=\"sd-toast-message__close\"\n onClick={this.handleClose}\n aria-label=\"Close\"\n title=\"Close\"\n >\n <sd-icon name=\"close\" size={12} color={colors.text}></sd-icon>\n </button>\n )}\n </div>\n </Host>\n );\n }\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,48 @@
1
+ import { r as registerInstance, c as createEvent, h } from './index-C3qNZ7Qh.js';
2
+
3
+ const sdToggleButtonCss = () => `sd-toggle-button{display:inline-block;line-height:0}.sd-toggle-button{display:inline-flex;align-items:center;justify-content:center;height:28px;padding:4px 12px;gap:6px;border-radius:14px;border:1px solid #888888;background-color:#ffffff;color:#737373;font-size:12px;line-height:20px;font-weight:400;cursor:pointer;transition:border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease;white-space:nowrap;user-select:none;box-sizing:border-box}.sd-toggle-button--active{border-color:#0075ff;color:#0075ff}.sd-toggle-button--disabled{background-color:#eeeeee;border-color:#cccccc;color:#888888;cursor:not-allowed}.sd-toggle-button--disabled.sd-toggle-button--active{background-color:#eeeeee;border-color:#cccccc;color:#888888}.sd-toggle-button:hover:not(.sd-toggle-button--disabled):not(.sd-toggle-button--active){border-color:#737373}.sd-toggle-button:hover:not(.sd-toggle-button--disabled).sd-toggle-button--active{border-color:#005cc9;color:#005cc9}`;
4
+
5
+ const SdToggleButton = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ this.change = createEvent(this, "sdUpdate");
9
+ }
10
+ value = false;
11
+ label = '';
12
+ disabled = false;
13
+ isActive = false;
14
+ change;
15
+ componentWillLoad() {
16
+ this.updateActiveState(this.value);
17
+ }
18
+ componentWillRender() {
19
+ this.updateActiveState(this.value);
20
+ }
21
+ updateActiveState(value) {
22
+ this.isActive = value;
23
+ }
24
+ get buttonClasses() {
25
+ const classes = ['sd-toggle-button'];
26
+ if (this.isActive) {
27
+ classes.push('sd-toggle-button--active');
28
+ }
29
+ if (this.disabled) {
30
+ classes.push('sd-toggle-button--disabled');
31
+ }
32
+ return classes.join(' ');
33
+ }
34
+ handleChange = () => {
35
+ if (this.disabled)
36
+ return;
37
+ const newValue = !this.value;
38
+ this.value = newValue;
39
+ this.change.emit(newValue);
40
+ };
41
+ render() {
42
+ return (h("label", { key: '9eb4abcfe8f3894198c8d8643150daa507e6f0e9', class: this.buttonClasses, "aria-label": this.label || 'toggle button' }, this.label, h("input", { key: 'e3d952af461da0fac978b8ce6bd55a6990907fb3', style: { display: 'none' }, type: "checkbox", onInput: this.handleChange })));
43
+ }
44
+ };
45
+ SdToggleButton.style = sdToggleButtonCss();
46
+
47
+ export { SdToggleButton as sd_toggle_button };
48
+ //# sourceMappingURL=sd-toggle-button.entry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sd-toggle-button.entry.js","sources":["src/components/sd-toggle-button/sd-toggle-button.scss?tag=sd-toggle-button","src/components/sd-toggle-button/sd-toggle-button.tsx"],"sourcesContent":["@import 'variables';\n\nsd-toggle-button {\n display: inline-block;\n line-height: 0;\n}\n\n.sd-toggle-button {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n height: 28px;\n padding: 4px 12px;\n gap: 6px;\n border-radius: 14px;\n border: 1px solid $grey_65;\n background-color: $white;\n color: $grey_70;\n font-size: 12px;\n line-height: 20px;\n font-weight: 400;\n cursor: pointer;\n transition: border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease;\n white-space: nowrap;\n user-select: none;\n box-sizing: border-box;\n\n &--active {\n border-color: $brilliantblue_75;\n color: $brilliantblue_75;\n }\n\n &--disabled {\n background-color: $grey_20;\n border-color: $grey_45;\n color: $grey_65;\n cursor: not-allowed;\n\n &.sd-toggle-button--active {\n background-color: $grey_20;\n border-color: $grey_45;\n color: $grey_65;\n }\n }\n\n &:hover:not(.sd-toggle-button--disabled) {\n &:not(.sd-toggle-button--active) {\n border-color: $grey_70;\n }\n\n &.sd-toggle-button--active {\n border-color: $brilliantblue_80;\n color: $brilliantblue_80;\n }\n }\n}","import { Component, Prop, h, Event, EventEmitter, State } from '@stencil/core';\n\n@Component({\n tag: 'sd-toggle-button',\n styleUrl: 'sd-toggle-button.scss',\n})\nexport class SdToggleButton {\n @Prop({ mutable: true, reflect: true }) value: boolean = false;\n\n @Prop() label: string = '';\n\n @Prop() disabled: boolean = false;\n\n @State() private isActive: boolean = false;\n\n @Event({ eventName: 'sdUpdate' }) change!: EventEmitter<boolean>;\n\n componentWillLoad() {\n this.updateActiveState(this.value);\n }\n\n componentWillRender() {\n this.updateActiveState(this.value);\n }\n\n private updateActiveState(value: boolean) {\n this.isActive = value;\n }\n\n private get buttonClasses(): string {\n const classes = ['sd-toggle-button'];\n\n if (this.isActive) {\n classes.push('sd-toggle-button--active');\n }\n\n if (this.disabled) {\n classes.push('sd-toggle-button--disabled');\n }\n\n return classes.join(' ');\n }\n\n private handleChange = () => {\n if (this.disabled) return;\n\n const newValue = !this.value;\n this.value = newValue;\n this.change.emit(newValue);\n };\n\n render() {\n return (\n <label\n class={this.buttonClasses}\n // role=\"button\"\n // aria-pressed={this.isActive.toString()}\n // aria-disabled={this.disabled.toString()}\n aria-label={this.label || 'toggle button'}\n >\n {this.label}\n <input style={{ display: 'none' }} type=\"checkbox\" onInput={this.handleChange} />\n </label>\n );\n }\n}\n"],"names":[],"mappings":";;AAAA,MAAM,iBAAiB,GAAG,MAAM,CAAC,+7BAA+7B,CAAC;;MCMp9B,cAAc,GAAA,MAAA;;;;;IACc,KAAK,GAAY,KAAK;IAEtD,KAAK,GAAW,EAAE;IAElB,QAAQ,GAAY,KAAK;IAEhB,QAAQ,GAAY,KAAK;AAER,IAAA,MAAM;IAExC,iBAAiB,GAAA;AAChB,QAAA,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC;;IAGnC,mBAAmB,GAAA;AAClB,QAAA,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC;;AAG3B,IAAA,iBAAiB,CAAC,KAAc,EAAA;AACvC,QAAA,IAAI,CAAC,QAAQ,GAAG,KAAK;;AAGtB,IAAA,IAAY,aAAa,GAAA;AACxB,QAAA,MAAM,OAAO,GAAG,CAAC,kBAAkB,CAAC;AAEpC,QAAA,IAAI,IAAI,CAAC,QAAQ,EAAE;AAClB,YAAA,OAAO,CAAC,IAAI,CAAC,0BAA0B,CAAC;;AAGzC,QAAA,IAAI,IAAI,CAAC,QAAQ,EAAE;AAClB,YAAA,OAAO,CAAC,IAAI,CAAC,4BAA4B,CAAC;;AAG3C,QAAA,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC;;IAGjB,YAAY,GAAG,MAAK;QAC3B,IAAI,IAAI,CAAC,QAAQ;YAAE;AAEnB,QAAA,MAAM,QAAQ,GAAG,CAAC,IAAI,CAAC,KAAK;AAC5B,QAAA,IAAI,CAAC,KAAK,GAAG,QAAQ;AACrB,QAAA,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;AAC3B,KAAC;IAED,MAAM,GAAA;QACL,QACC,CAAA,CAAA,OAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EACC,KAAK,EAAE,IAAI,CAAC,aAAa,EAAA,YAAA,EAIb,IAAI,CAAC,KAAK,IAAI,eAAe,EAAA,EAExC,IAAI,CAAC,KAAK,EACX,CAAO,CAAA,OAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,EAAE,IAAI,EAAC,UAAU,EAAC,OAAO,EAAE,IAAI,CAAC,YAAY,EAAI,CAAA,CAC1E;;;;;;;"}
@@ -0,0 +1,44 @@
1
+ import { r as registerInstance, c as createEvent, h } from './index-C3qNZ7Qh.js';
2
+
3
+ const sdToggleCss = () => `sd-toggle{display:inline-block;height:20px;line-height:0}sd-toggle .sd-toggle{cursor:pointer;display:inline-flex;align-items:center;gap:8px;height:20px}sd-toggle .sd-toggle>input{display:none}sd-toggle .sd-toggle__label{font-size:12px;color:#333333;line-height:20px}sd-toggle .sd-toggle__track{width:36px;height:20px;border-radius:12px;background:#cccccc;position:relative;transition:background-color 0.2s ease}sd-toggle .sd-toggle__thumb{width:16px;height:16px;border-radius:50%;background:white;position:absolute;top:2px;left:2px;transition:transform 0.2s ease}sd-toggle .sd-toggle--checked .sd-toggle__track{background:#0075ff}sd-toggle .sd-toggle--checked .sd-toggle__thumb{transform:translateX(16px)}sd-toggle .sd-toggle--disabled{cursor:not-allowed}sd-toggle .sd-toggle--disabled.sd-toggle--checked .sd-toggle__track{background:#bbdaff}sd-toggle .sd-toggle--disabled.sd-toggle--unchecked .sd-toggle__track{background:#eeeeee}sd-toggle .sd-toggle:hover:not(.sd-toggle--disabled).sd-toggle--checked .sd-toggle__track{background:#005cc9}sd-toggle .sd-toggle:hover:not(.sd-toggle--disabled).sd-toggle--unchecked .sd-toggle__track{background:#bbbbbb}`;
4
+
5
+ const SdToggle = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ this.change = createEvent(this, "sdUpdate");
9
+ }
10
+ value = false;
11
+ label = '';
12
+ disabled = false;
13
+ change;
14
+ componentWillLoad() {
15
+ this.updateCheckedState(this.value);
16
+ }
17
+ componentWillRender() {
18
+ this.updateCheckedState(this.value);
19
+ }
20
+ updateCheckedState(value) {
21
+ this.value = value;
22
+ }
23
+ get toggleClasses() {
24
+ const classes = ['sd-toggle', this.value ? 'sd-toggle--checked' : 'sd-toggle--unchecked'];
25
+ if (this.disabled) {
26
+ classes.push('sd-toggle--disabled');
27
+ }
28
+ return classes.join(' ');
29
+ }
30
+ handleChange = () => {
31
+ if (this.disabled)
32
+ return;
33
+ const newValue = !this.value;
34
+ this.value = newValue;
35
+ this.change.emit(newValue);
36
+ };
37
+ render() {
38
+ return (h("label", { key: 'ca85bc0493aff9ff17108696ddb8af29734b00f5', "aria-label": this.label || 'toggle', class: this.toggleClasses }, h("input", { key: 'b99a4fa0d557968e50b302332778faaf1b46f8cc', type: "checkbox", checked: this.value, disabled: this.disabled, onInput: this.handleChange }), this.label && h("span", { key: 'e62ca806b95463c7807f82ace61b4aa0affec962', class: "sd-toggle__label" }, this.label), h("div", { key: '6923da9a043df0d0d7fc0ecf2fe175857279e9b3', class: "sd-toggle__track" }, h("div", { key: '090dfbcf308f26b8e200d0e2cd69d44b0f5cb8bf', class: "sd-toggle__thumb" }))));
39
+ }
40
+ };
41
+ SdToggle.style = sdToggleCss();
42
+
43
+ export { SdToggle as sd_toggle };
44
+ //# sourceMappingURL=sd-toggle.entry.js.map