@sellmate/design-system 0.0.34 → 0.0.35

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 (193) hide show
  1. package/dist/cjs/design-system.cjs.js +1 -1
  2. package/dist/cjs/loader.cjs.js +1 -1
  3. package/dist/cjs/sd-badge.cjs.entry.js +1 -1
  4. package/dist/cjs/sd-button.sd-checkbox.sd-guide.sd-icon.sd-input.sd-pagination.sd-portal.sd-select.sd-select-option.sd-table.sd-tbody.sd-th.sd-tooltip.sd-tooltip-portal.sd-tr.entry.cjs.js.map +1 -0
  5. package/dist/cjs/{sd-button_13.cjs.entry.js → sd-button_15.cjs.entry.js} +81 -78
  6. package/dist/cjs/sd-card.cjs.entry.js +1 -1
  7. package/dist/cjs/sd-date-picker.cjs.entry.js +2 -2
  8. package/dist/cjs/sd-date-range-picker.cjs.entry.js +2 -2
  9. package/dist/cjs/sd-loading-spinner.cjs.entry.js +18 -0
  10. package/dist/cjs/sd-loading-spinner.entry.cjs.js.map +1 -0
  11. package/dist/cjs/sd-popover.cjs.entry.js +2 -2
  12. package/dist/cjs/sd-progress.cjs.entry.js +2 -2
  13. package/dist/cjs/sd-select-multiple.cjs.entry.js +2 -2
  14. package/dist/cjs/sd-select-option-group.cjs.entry.js +3 -3
  15. package/dist/cjs/sd-table-backup.cjs.entry.js +265 -0
  16. package/dist/cjs/sd-table-backup.entry.cjs.js.map +1 -0
  17. package/dist/cjs/sd-tag.cjs.entry.js +1 -1
  18. package/dist/cjs/sd-td.cjs.entry.js +26 -0
  19. package/dist/cjs/sd-td.entry.cjs.js.map +1 -0
  20. package/dist/collection/collection-manifest.json +5 -0
  21. package/dist/collection/components/sd-badge/sd-badge.js +1 -1
  22. package/dist/collection/components/sd-card/sd-card.js +1 -1
  23. package/dist/collection/components/sd-date-picker/sd-date-picker.js +2 -2
  24. package/dist/collection/components/sd-date-range-picker/sd-date-range-picker.js +2 -2
  25. package/dist/collection/components/sd-guide/sd-guide.js +3 -3
  26. package/dist/collection/components/sd-icon/sd-icon.js +1 -1
  27. package/dist/collection/components/sd-input/sd-input.js +2 -2
  28. package/dist/collection/components/sd-loading-spinner/sd-loading-spinner.js +1 -1
  29. package/dist/collection/components/sd-pagination/sd-pagination.js +2 -2
  30. package/dist/collection/components/sd-popover/sd-popover.js +2 -2
  31. package/dist/collection/components/sd-portal/sd-portal.js +1 -1
  32. package/dist/collection/components/sd-progress/sd-progress.js +2 -2
  33. package/dist/collection/components/sd-select/sd-select-option/sd-select-option.js +1 -1
  34. package/dist/collection/components/sd-select-multiple/sd-select-multiple.js +2 -2
  35. package/dist/collection/components/sd-select-multiple-group/sd-select-option-group/sd-select-option-group.js +3 -3
  36. package/dist/collection/components/sd-table/sd-table-backup.js +2743 -0
  37. package/dist/collection/components/sd-table/sd-table-backup.js.map +1 -0
  38. package/dist/collection/components/sd-table/sd-table.css +17 -15
  39. package/dist/collection/components/sd-table/sd-table.js +24 -2087
  40. package/dist/collection/components/sd-table/sd-table.js.map +1 -1
  41. package/dist/collection/components/sd-table/sd-tbody/sd-tbody.css +3 -0
  42. package/dist/collection/components/sd-table/sd-tbody/sd-tbody.js +18 -0
  43. package/dist/collection/components/sd-table/sd-tbody/sd-tbody.js.map +1 -0
  44. package/dist/collection/components/sd-table/sd-td/sd-td.css +9 -0
  45. package/dist/collection/components/sd-table/sd-td/sd-td.js +111 -0
  46. package/dist/collection/components/sd-table/sd-td/sd-td.js.map +1 -0
  47. package/dist/collection/components/sd-table/sd-th/sd-th.css +8 -0
  48. package/dist/collection/components/sd-table/sd-th/sd-th.js +18 -0
  49. package/dist/collection/components/sd-table/sd-th/sd-th.js.map +1 -0
  50. package/dist/collection/components/sd-table/sd-tr/sd-tr.css +3 -0
  51. package/dist/collection/components/sd-table/sd-tr/sd-tr.js +18 -0
  52. package/dist/collection/components/sd-table/sd-tr/sd-tr.js.map +1 -0
  53. package/dist/collection/components/sd-tag/sd-tag.js +1 -1
  54. package/dist/collection/components/sd-tooltip/sd-tooltip.js +4 -5
  55. package/dist/collection/components/sd-tooltip/sd-tooltip.js.map +1 -1
  56. package/dist/collection/components/sd-tooltip-portal/sd-tooltip-portal.js +1 -1
  57. package/dist/components/{p-Bry2vtXF.js → p-5yzkkdZ2.js} +3 -3
  58. package/dist/components/{p-Bry2vtXF.js.map → p-5yzkkdZ2.js.map} +1 -1
  59. package/dist/components/{p-B5jkeFCb.js → p-B8lMIjWB.js} +7 -7
  60. package/dist/components/{p-B5jkeFCb.js.map → p-B8lMIjWB.js.map} +1 -1
  61. package/dist/components/{p-BoIp700J.js → p-BEDQ2CIp.js} +5 -5
  62. package/dist/components/{p-BoIp700J.js.map → p-BEDQ2CIp.js.map} +1 -1
  63. package/dist/components/{p-DXyjyA0e.js → p-BEq3cGoC.js} +3 -3
  64. package/dist/components/{p-DXyjyA0e.js.map → p-BEq3cGoC.js.map} +1 -1
  65. package/dist/components/{p-BLVHOrsi.js → p-BG0UE2wL.js} +3 -3
  66. package/dist/components/{p-BLVHOrsi.js.map → p-BG0UE2wL.js.map} +1 -1
  67. package/dist/components/p-BeBw4eSm.js +34 -0
  68. package/dist/components/p-BeBw4eSm.js.map +1 -0
  69. package/dist/components/{p-DKW5kNQD.js → p-BzdIpn5T.js} +11 -11
  70. package/dist/components/p-BzdIpn5T.js.map +1 -0
  71. package/dist/components/{p-cZZiWgpx.js → p-CSnKPDQz.js} +5 -5
  72. package/dist/components/{p-cZZiWgpx.js.map → p-CSnKPDQz.js.map} +1 -1
  73. package/dist/components/{p-CHw7bav7.js → p-CqpahWAy.js} +3 -3
  74. package/dist/components/{p-CHw7bav7.js.map → p-CqpahWAy.js.map} +1 -1
  75. package/dist/components/p-CrmdI2cD.js +34 -0
  76. package/dist/components/p-CrmdI2cD.js.map +1 -0
  77. package/dist/components/p-D-s8kK6P.js +34 -0
  78. package/dist/components/p-D-s8kK6P.js.map +1 -0
  79. package/dist/components/{p-DR6QXFmO.js → p-Du8-vyL0.js} +3 -3
  80. package/dist/components/{p-DR6QXFmO.js.map → p-Du8-vyL0.js.map} +1 -1
  81. package/dist/components/{p-CsP5aJ3N.js → p-GNK9vrin.js} +3 -3
  82. package/dist/components/{p-CsP5aJ3N.js.map → p-GNK9vrin.js.map} +1 -1
  83. package/dist/components/{p-D60I2CpC.js → p-ntW8MKYi.js} +5 -5
  84. package/dist/components/{p-D60I2CpC.js.map → p-ntW8MKYi.js.map} +1 -1
  85. package/dist/components/{p-CVmIv1LY.js → p-ybbnPl4X.js} +7 -7
  86. package/dist/components/{p-CVmIv1LY.js.map → p-ybbnPl4X.js.map} +1 -1
  87. package/dist/components/sd-badge.js +1 -1
  88. package/dist/components/sd-button.js +1 -1
  89. package/dist/components/sd-card.js +1 -1
  90. package/dist/components/sd-checkbox.js +1 -1
  91. package/dist/components/sd-date-picker.js +5 -5
  92. package/dist/components/sd-date-range-picker.js +5 -5
  93. package/dist/components/sd-guide.js +6 -6
  94. package/dist/components/sd-icon.js +1 -1
  95. package/dist/components/sd-input.js +1 -1
  96. package/dist/components/sd-loading-spinner.js +1 -1
  97. package/dist/components/sd-pagination.js +1 -1
  98. package/dist/components/sd-popover.js +5 -5
  99. package/dist/components/sd-portal.js +1 -1
  100. package/dist/components/sd-progress.js +2 -2
  101. package/dist/components/sd-select-multiple-group.js +5 -5
  102. package/dist/components/sd-select-multiple.js +7 -7
  103. package/dist/components/sd-select-option-group.js +1 -1
  104. package/dist/components/sd-select-option.js +1 -1
  105. package/dist/components/sd-select.js +1 -1
  106. package/dist/components/sd-table-backup.d.ts +11 -0
  107. package/dist/components/sd-table-backup.js +379 -0
  108. package/dist/components/sd-table-backup.js.map +1 -0
  109. package/dist/components/sd-table.js +59 -70
  110. package/dist/components/sd-table.js.map +1 -1
  111. package/dist/components/sd-tag.js +1 -1
  112. package/dist/components/sd-tbody.d.ts +11 -0
  113. package/dist/components/sd-tbody.js +9 -0
  114. package/dist/components/sd-tbody.js.map +1 -0
  115. package/dist/components/sd-td.d.ts +11 -0
  116. package/dist/components/sd-td.js +50 -0
  117. package/dist/components/sd-td.js.map +1 -0
  118. package/dist/components/sd-th.d.ts +11 -0
  119. package/dist/components/sd-th.js +9 -0
  120. package/dist/components/sd-th.js.map +1 -0
  121. package/dist/components/sd-tooltip-portal.js +1 -1
  122. package/dist/components/sd-tooltip.js +1 -1
  123. package/dist/components/sd-tr.d.ts +11 -0
  124. package/dist/components/sd-tr.js +9 -0
  125. package/dist/components/sd-tr.js.map +1 -0
  126. package/dist/design-system/design-system.esm.js +1 -1
  127. package/dist/design-system/{p-ac7dbf3c.entry.js → p-01f44c51.entry.js} +2 -2
  128. package/dist/design-system/p-49f98f09.entry.js +2 -0
  129. package/dist/design-system/p-671a08a6.entry.js +2 -0
  130. package/dist/design-system/p-671a08a6.entry.js.map +1 -0
  131. package/dist/design-system/p-6a624672.entry.js +2 -0
  132. package/dist/design-system/{p-e9800353.entry.js → p-78f90517.entry.js} +2 -2
  133. package/dist/design-system/{p-048f83bb.entry.js → p-7e18d4cf.entry.js} +2 -2
  134. package/dist/design-system/p-7e18d4cf.entry.js.map +1 -0
  135. package/dist/design-system/{p-6d769a19.entry.js → p-88745dfe.entry.js} +2 -2
  136. package/dist/design-system/{p-eeed34eb.entry.js → p-8b60af66.entry.js} +2 -2
  137. package/dist/design-system/p-985be35d.entry.js +2 -0
  138. package/dist/design-system/{p-d492a315.entry.js.map → p-985be35d.entry.js.map} +1 -1
  139. package/dist/design-system/{p-cdc6b2c8.entry.js → p-a72c4b0c.entry.js} +2 -2
  140. package/dist/design-system/{p-56b88d9b.entry.js → p-d003ee3d.entry.js} +2 -2
  141. package/dist/design-system/p-d74bfbe4.entry.js +2 -0
  142. package/dist/design-system/p-d74bfbe4.entry.js.map +1 -0
  143. package/dist/design-system/p-ef5ffaa2.entry.js +2 -0
  144. package/dist/design-system/p-ef5ffaa2.entry.js.map +1 -0
  145. package/dist/design-system/sd-button.sd-checkbox.sd-guide.sd-icon.sd-input.sd-pagination.sd-portal.sd-select.sd-select-option.sd-table.sd-tbody.sd-th.sd-tooltip.sd-tooltip-portal.sd-tr.entry.esm.js.map +1 -0
  146. package/dist/design-system/sd-loading-spinner.entry.esm.js.map +1 -0
  147. package/dist/design-system/sd-table-backup.entry.esm.js.map +1 -0
  148. package/dist/design-system/sd-td.entry.esm.js.map +1 -0
  149. package/dist/esm/design-system.js +1 -1
  150. package/dist/esm/loader.js +1 -1
  151. package/dist/esm/sd-badge.entry.js +1 -1
  152. package/dist/esm/sd-button.sd-checkbox.sd-guide.sd-icon.sd-input.sd-pagination.sd-portal.sd-select.sd-select-option.sd-table.sd-tbody.sd-th.sd-tooltip.sd-tooltip-portal.sd-tr.entry.js.map +1 -0
  153. package/dist/esm/{sd-button_13.entry.js → sd-button_15.entry.js} +79 -78
  154. package/dist/esm/sd-card.entry.js +1 -1
  155. package/dist/esm/sd-date-picker.entry.js +2 -2
  156. package/dist/esm/sd-date-range-picker.entry.js +2 -2
  157. package/dist/esm/sd-loading-spinner.entry.js +16 -0
  158. package/dist/esm/sd-loading-spinner.entry.js.map +1 -0
  159. package/dist/esm/sd-popover.entry.js +2 -2
  160. package/dist/esm/sd-progress.entry.js +2 -2
  161. package/dist/esm/sd-select-multiple.entry.js +2 -2
  162. package/dist/esm/sd-select-option-group.entry.js +3 -3
  163. package/dist/esm/sd-table-backup.entry.js +263 -0
  164. package/dist/esm/sd-table-backup.entry.js.map +1 -0
  165. package/dist/esm/sd-tag.entry.js +1 -1
  166. package/dist/esm/sd-td.entry.js +24 -0
  167. package/dist/esm/sd-td.entry.js.map +1 -0
  168. package/dist/types/components/sd-table/sd-table-backup.d.ts +80 -0
  169. package/dist/types/components/sd-table/sd-table.d.ts +0 -4
  170. package/dist/types/components/sd-table/sd-tbody/sd-tbody.d.ts +3 -0
  171. package/dist/types/components/sd-table/sd-td/sd-td.d.ts +7 -0
  172. package/dist/types/components/sd-table/sd-th/sd-th.d.ts +3 -0
  173. package/dist/types/components/sd-table/sd-tr/sd-tr.d.ts +3 -0
  174. package/dist/types/components.d.ts +221 -0
  175. package/hydrate/index.js +405 -39
  176. package/hydrate/index.mjs +405 -39
  177. package/package.json +2 -2
  178. package/dist/cjs/sd-button.sd-checkbox.sd-guide.sd-icon.sd-input.sd-loading-spinner.sd-pagination.sd-portal.sd-select.sd-select-option.sd-table.sd-tooltip.sd-tooltip-portal.entry.cjs.js.map +0 -1
  179. package/dist/components/p-DKW5kNQD.js.map +0 -1
  180. package/dist/design-system/p-048f83bb.entry.js.map +0 -1
  181. package/dist/design-system/p-c1e64ba9.entry.js +0 -2
  182. package/dist/design-system/p-ce01c171.entry.js +0 -2
  183. package/dist/design-system/p-d492a315.entry.js +0 -2
  184. package/dist/design-system/sd-button.sd-checkbox.sd-guide.sd-icon.sd-input.sd-loading-spinner.sd-pagination.sd-portal.sd-select.sd-select-option.sd-table.sd-tooltip.sd-tooltip-portal.entry.esm.js.map +0 -1
  185. package/dist/esm/sd-button.sd-checkbox.sd-guide.sd-icon.sd-input.sd-loading-spinner.sd-pagination.sd-portal.sd-select.sd-select-option.sd-table.sd-tooltip.sd-tooltip-portal.entry.js.map +0 -1
  186. /package/dist/design-system/{p-ac7dbf3c.entry.js.map → p-01f44c51.entry.js.map} +0 -0
  187. /package/dist/design-system/{p-ce01c171.entry.js.map → p-49f98f09.entry.js.map} +0 -0
  188. /package/dist/design-system/{p-c1e64ba9.entry.js.map → p-6a624672.entry.js.map} +0 -0
  189. /package/dist/design-system/{p-e9800353.entry.js.map → p-78f90517.entry.js.map} +0 -0
  190. /package/dist/design-system/{p-6d769a19.entry.js.map → p-88745dfe.entry.js.map} +0 -0
  191. /package/dist/design-system/{p-eeed34eb.entry.js.map → p-8b60af66.entry.js.map} +0 -0
  192. /package/dist/design-system/{p-cdc6b2c8.entry.js.map → p-a72c4b0c.entry.js.map} +0 -0
  193. /package/dist/design-system/{p-56b88d9b.entry.js.map → p-d003ee3d.entry.js.map} +0 -0
@@ -0,0 +1,11 @@
1
+ import type { Components, JSX } from "../types/components";
2
+
3
+ interface SdTableBackup extends Components.SdTableBackup, HTMLElement {}
4
+ export const SdTableBackup: {
5
+ prototype: SdTableBackup;
6
+ new (): SdTableBackup;
7
+ };
8
+ /**
9
+ * Used to define this component and all nested components recursively.
10
+ */
11
+ export const defineCustomElement: () => void;
@@ -0,0 +1,379 @@
1
+ import { p as proxyCustomElement, H, d as createEvent, h, c as Host } from './p-CbnL1UUF.js';
2
+ import { d as defineCustomElement$c } from './p-CqpahWAy.js';
3
+ import { d as defineCustomElement$b } from './p-Du8-vyL0.js';
4
+ import { d as defineCustomElement$a } from './p-GNK9vrin.js';
5
+ import { d as defineCustomElement$9 } from './p-ntW8MKYi.js';
6
+ import { d as defineCustomElement$8 } from './p-5yzkkdZ2.js';
7
+ import { d as defineCustomElement$7 } from './p-CSnKPDQz.js';
8
+ import { d as defineCustomElement$6 } from './p-BEq3cGoC.js';
9
+ import { d as defineCustomElement$5 } from './p-ybbnPl4X.js';
10
+ import { d as defineCustomElement$4 } from './p-BEDQ2CIp.js';
11
+ import { d as defineCustomElement$3 } from './p-BzdIpn5T.js';
12
+ import { d as defineCustomElement$2 } from './p-BG0UE2wL.js';
13
+
14
+ const sdTableCss = ".sd-table__wrapper .sd-table__container .sd-table__middle{overflow-y:auto;overflow-x:hidden;scroll-behavior:smooth}.sd-table__wrapper .sd-table__container .sd-table__middle::-webkit-scrollbar{opacity:0;background:#e5e5e5}.sd-table__wrapper .sd-table__container .sd-table__middle::-webkit-scrollbar:horizontal{height:8px}.sd-table__wrapper .sd-table__container .sd-table__middle::-webkit-scrollbar:vertical{width:8px}.sd-table__wrapper .sd-table__container .sd-table__middle::-webkit-scrollbar-thumb{height:80px;background-color:#cccccc;border-radius:4px}.sd-table__wrapper .sd-table__container .sd-table__middle::-webkit-scrollbar-track{background-color:transparent}.sd-table__wrapper{height:var(--table-height, auto);width:var(--table-width, 100%);color:#222222}.sd-table__wrapper .sd-table__container{width:100%;height:auto;border:1px solid #e1e1e1;border-radius:8px;font-size:12px;overflow:hidden}.sd-table__wrapper .sd-table__container .sd-table__middle{overflow:auto;will-change:scroll-position;height:var(--table-height, auto)}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table{background-color:white;display:table;width:100%;border-collapse:separate;border-spacing:0;table-layout:fixed;position:relative}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--selectable td.sd-td--selected,.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--selectable th.sd-th--selected{width:52px !important;max-width:52px !important;min-width:52px !important;padding:0 10px 0 24px;text-align:left}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--sticky-header thead{position:sticky;top:0;z-index:120}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--sticky-column th.sticky-left,.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--sticky-column th.sticky-right{position:sticky;background-color:#f5faff;z-index:110 !important}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--sticky-column td.sticky-left,.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--sticky-column td.sticky-right{position:sticky;background-color:white;z-index:100 !important}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--sticky-column .sticky-left{left:var(--sticky-left-offset, 0)}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--sticky-column .sticky-right{right:var(--sticky-right-offset, 0)}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--sticky-column th.sticky-cell{position:sticky;z-index:102;background-color:#f5faff}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--sticky-column td.sticky-cell{position:sticky;z-index:101;background-color:white}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--scrolled-left th.sticky-left-edge,.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--scrolled-left td.sticky-left-edge{overflow:visible}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--scrolled-left th.sticky-left-edge:after,.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--scrolled-left td.sticky-left-edge:after{content:\"\";position:absolute;top:0;left:100%;right:-20px;width:20px;height:100%;z-index:101 !important;box-shadow:inset 12px 0 20px -25px;opacity:1;pointer-events:none}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--scrolled-right th.sticky-right-edge,.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--scrolled-right td.sticky-right-edge{overflow:visible}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--scrolled-right th.sticky-right-edge:after,.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--scrolled-right td.sticky-right-edge:after{content:\"\";position:absolute;top:0;left:-20px;width:20px;height:100%;z-index:101 !important;box-shadow:inset -12px 0 20px -25px;opacity:1;pointer-events:none}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--no-data thead{opacity:0.4}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table--no-data thead tr th.sd-th{border-bottom:1px solid rgba(225, 225, 225, 0.4) !important}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table sd-td,.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table sd-th,.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table .sd-th__content--label{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;word-break:keep-all}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table thead{height:36px}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table thead sd-tr{width:100%}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table thead sd-tr sd-th{background:#f5faff;height:36px;padding:0 16px;font-weight:500;vertical-align:middle;border-bottom:1px solid #e1e1e1;-webkit-user-select:none;user-select:none;position:relative}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table thead sd-tr sd-th.sd-th .sd-th__content{display:flex;flex-flow:row nowrap;align-items:center;gap:4px}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table thead sd-tr sd-th.sd-th .sd-th__content--left{justify-content:flex-start}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table thead sd-tr sd-th.sd-th .sd-th__content--center{justify-content:center}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table thead sd-tr sd-th.sd-th .sd-th__content--right{justify-content:flex-end}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table thead sd-tr sd-th.sd-th .sd-th__resizer{position:absolute;top:50%;right:0;transform:translateY(-50%);width:4px;height:16px;cursor:col-resize;z-index:3;border-left:1px solid #cccccc;border-right:1px solid #cccccc}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table sd-tbody .sd-table__loading{position:absolute;top:0;left:0;width:100%;height:calc(var(--table-height, auto) - 36px);min-height:calc(100% - 36px);background:rgba(255, 255, 255, 0.6);z-index:200;display:flex;align-items:center;justify-content:center}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table sd-tbody sd-tr:last-of-type sd-td{border-bottom:none}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table sd-tbody sd-tr sd-td{height:44px;padding:0 16px;border-bottom:1px solid #e1e1e1;background:white;vertical-align:middle}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table sd-tbody sd-tr sd-td.sd-td--left{text-align:left}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table sd-tbody sd-tr sd-td.sd-td--center{text-align:center}.sd-table__wrapper .sd-table__container .sd-table__middle .sd-table sd-tbody sd-tr sd-td.sd-td--right{text-align:right}.sd-table__wrapper .sd-table__container .sd-table__bottom{background:white;text-align:center}.sd-table__wrapper .sd-table__pagination{position:relative;background:#f9f9f9;height:48px;display:flex;align-items:center;justify-content:center;border:1px solid #e1e1e1;border-top:none;border-radius:8px}.sd-table__wrapper .sd-table__pagination sd-select{position:absolute;right:10px;top:50%;transform:translateY(-50%)}";
15
+
16
+ const SdTable = /*@__PURE__*/ proxyCustomElement(class SdTable extends H {
17
+ constructor(registerHost) {
18
+ super();
19
+ if (registerHost !== false) {
20
+ this.__registerHost();
21
+ }
22
+ this.sdSelectChange = createEvent(this, "sdSelectChange");
23
+ this.sdPageChange = createEvent(this, "sdPageChange");
24
+ this.sdRowsPerPageChange = createEvent(this, "sdRowsPerPageChange");
25
+ }
26
+ get el() { return this; }
27
+ columns;
28
+ rows;
29
+ selected = new Set();
30
+ rowKey = 'id';
31
+ selectable = false;
32
+ resizable = false;
33
+ width;
34
+ height;
35
+ stickyHeader = false;
36
+ stickyColumn = { left: 0, right: 0 };
37
+ noDataLabel = '데이터가 없습니다.';
38
+ isLoading = false;
39
+ pagination;
40
+ bodyCellRenderer;
41
+ useInternalPagination = false;
42
+ useRowsPerPageSelect = false;
43
+ rowsPerPageOption = [
44
+ { label: '10개씩 보기', value: 10 },
45
+ { label: '25개씩 보기', value: 25 },
46
+ { label: '50개씩 보기', value: 50 },
47
+ { label: '100개씩 보기', value: 100 },
48
+ ];
49
+ sdSelectChange;
50
+ sdPageChange;
51
+ sdRowsPerPageChange;
52
+ currentPage = this.pagination?.page || 1;
53
+ innerRows = [];
54
+ innerSelected = new Set();
55
+ columnWidths = [];
56
+ scrolledLeft = false;
57
+ scrolledRight = false;
58
+ handleColumnsChange(newCols) {
59
+ this.columnWidths = newCols.map(c => parseInt(c.width || '120', 10));
60
+ }
61
+ handleRowsChange(newRows) {
62
+ this.innerRows = [...newRows];
63
+ }
64
+ handleSelectedChange(newSelected) {
65
+ this.innerSelected = new Set(newSelected);
66
+ }
67
+ handlePaginationChange(newVal) {
68
+ if (newVal?.page && newVal.page !== this.currentPage)
69
+ this.currentPage = newVal.page;
70
+ }
71
+ componentWillLoad() {
72
+ this.innerRows = [...(this.rows || [])];
73
+ this.innerSelected = new Set(this.selected);
74
+ this.columnWidths = (this.columns || []).map(c => parseInt(c.width || '120', 10));
75
+ }
76
+ componentDidLoad() {
77
+ // SSR 환경 체크
78
+ if (typeof window === 'undefined')
79
+ return;
80
+ const middle = this.el.querySelector('.sd-table__middle');
81
+ if (!middle)
82
+ return;
83
+ const onScroll = () => {
84
+ const { scrollLeft, scrollWidth, clientWidth } = middle;
85
+ this.scrolledLeft = scrollLeft > 0;
86
+ this.scrolledRight = scrollLeft + clientWidth < scrollWidth;
87
+ };
88
+ middle.addEventListener('scroll', onScroll, { passive: true });
89
+ onScroll();
90
+ }
91
+ // ----- Derived getters -----
92
+ get visibleColumns() {
93
+ return this.columns.filter(col => col.visible !== false);
94
+ }
95
+ get paginatedRows() {
96
+ if (!this.pagination || !this.useInternalPagination)
97
+ return this.innerRows;
98
+ const { rowsPerPage = this.rows.length } = this.pagination || {};
99
+ const result = this.innerRows.slice((this.currentPage - 1) * rowsPerPage, this.currentPage * rowsPerPage);
100
+ return result;
101
+ }
102
+ get lastPageNumber() {
103
+ const { lastPage, rowsPerPage = this.rows.length } = this.pagination || {};
104
+ return lastPage ?? Math.max(1, Math.ceil(this.rows.length / rowsPerPage));
105
+ }
106
+ get sdTableClasses() {
107
+ return [
108
+ 'sd-table',
109
+ this.stickyHeader && 'sd-table--sticky-header',
110
+ this.selectable && 'sd-table--selectable',
111
+ this.resizable && 'sd-table--resizable',
112
+ !this.innerRows.length && 'sd-table--no-data',
113
+ ((this.stickyColumn?.left ?? 0) > 0 || (this.stickyColumn?.right ?? 0) > 0) &&
114
+ 'sd-table--sticky-column',
115
+ this.scrolledLeft && 'sd-table--scrolled-left',
116
+ this.scrolledRight && 'sd-table--scrolled-right',
117
+ ]
118
+ .filter(Boolean)
119
+ .join(' ');
120
+ }
121
+ // ----- Selection -----
122
+ isRowSelected(row) {
123
+ return Array.from(this.innerSelected).some(r => r[this.rowKey] === row[this.rowKey]);
124
+ }
125
+ updateRowSelect(row) {
126
+ const selectedArray = Array.from(this.innerSelected);
127
+ const exists = this.isRowSelected(row);
128
+ const newSelected = exists
129
+ ? selectedArray.filter(r => r[this.rowKey] !== row[this.rowKey])
130
+ : [...selectedArray, row];
131
+ // 동일 상태면 set하지 않음 → 불필요 렌더 방지
132
+ if (newSelected.length === selectedArray.length)
133
+ return;
134
+ this.innerSelected = new Set(newSelected);
135
+ this.sdSelectChange.emit(Array.from(this.innerSelected));
136
+ }
137
+ toggleSelectAll(checked) {
138
+ if (checked) {
139
+ const pageRows = new Set([...this.paginatedRows]);
140
+ this.innerSelected = new Set([...this.innerSelected, ...pageRows]);
141
+ }
142
+ else {
143
+ const currentPageKeys = this.paginatedRows.map(r => r[this.rowKey]);
144
+ this.innerSelected = new Set([...this.innerSelected].filter(r => !currentPageKeys.includes(r[this.rowKey])));
145
+ }
146
+ this.sdSelectChange.emit(Array.from(this.innerSelected));
147
+ }
148
+ get isAllChecked() {
149
+ const total = this.paginatedRows.length;
150
+ const selectedCount = this.paginatedRows.filter(row => Array.from(this.innerSelected).some(selectedRow => selectedRow[this.rowKey] === row[this.rowKey])).length;
151
+ if (selectedCount === 0)
152
+ return false; // 아무것도 안 선택됨
153
+ if (selectedCount === total)
154
+ return true; // 전부 선택됨
155
+ return null; // 일부만 선택됨
156
+ }
157
+ // ----- Helpers -----
158
+ getStickyStyle(colIdx) {
159
+ const leftOffset = this.columnWidths.slice(0, colIdx).reduce((a, b) => a + b, 0) + (this.selectable ? 52 : 0);
160
+ const rightOffset = this.columnWidths
161
+ .filter((_, i) => i >= this.visibleColumns.length - (this.stickyColumn.right || 0) && i > colIdx)
162
+ .reduce((a, b) => a + b, 0);
163
+ return {
164
+ '--sticky-left-offset': `${leftOffset}px`,
165
+ '--sticky-right-offset': `${rightOffset}px`,
166
+ 'width': `${this.columnWidths[colIdx]}px`,
167
+ 'minWidth': `${this.columnWidths[colIdx]}px`,
168
+ 'maxWidth': `${this.columnWidths[colIdx]}px`,
169
+ };
170
+ }
171
+ handleResize(index, event) {
172
+ // SSR 환경 체크
173
+ if (typeof document === 'undefined')
174
+ return;
175
+ const startX = event.clientX;
176
+ const startWidth = this.columnWidths[index];
177
+ const handleMouseMove = (moveEvent) => {
178
+ const newWidth = Math.max(startWidth + moveEvent.clientX - startX, 50);
179
+ this.columnWidths = this.columnWidths.map((width, idx) => (idx === index ? newWidth : width));
180
+ };
181
+ const handleMouseUp = () => {
182
+ document.removeEventListener('mousemove', handleMouseMove);
183
+ document.removeEventListener('mouseup', handleMouseUp);
184
+ };
185
+ document.addEventListener('mousemove', handleMouseMove);
186
+ document.addEventListener('mouseup', handleMouseUp);
187
+ }
188
+ getCellValue(column, row) {
189
+ const { field, format, name } = column;
190
+ const value = typeof field === 'function' ? field(row) : field ? row[field] : row[name];
191
+ return format ? format(value, row) : value;
192
+ }
193
+ // ----- Render -----
194
+ renderHeader() {
195
+ return (h("thead", null, h("tr", null, this.selectable && (h("th", { class: {
196
+ 'sd-th': true,
197
+ 'sd-th--selected': true,
198
+ 'sticky-left': Boolean(this.stickyColumn.left && this.stickyColumn.left > 0),
199
+ }, style: {
200
+ '--sticky-left-offset': '0px',
201
+ } }, h("sd-checkbox", { checked: this.isAllChecked, disabled: !this.paginatedRows.length, onSdChange: (e) => this.toggleSelectAll(e.detail) }))), this.visibleColumns.map((col, colIdx) => (h("th", { key: col.name, class: {
202
+ 'sd-th': true,
203
+ [`${col.thClass}`]: Boolean(col.thClass),
204
+ 'sticky-left': Boolean(this.stickyColumn.left && colIdx < this.stickyColumn.left),
205
+ 'sticky-right': Boolean(this.stickyColumn.right && colIdx >= this.visibleColumns.length - this.stickyColumn.right),
206
+ 'sticky-left-edge': Boolean(this.stickyColumn.left && colIdx === this.stickyColumn.left - 1),
207
+ 'sticky-right-edge': Boolean(this.stickyColumn.right &&
208
+ colIdx === this.visibleColumns.length - this.stickyColumn.right),
209
+ }, style: this.getStickyStyle(colIdx) }, h("div", { class: `sd-th__content sd-th__content--${col.align || 'left'}` }, h("slot", { name: `header-cell-${col.name}` }, h("div", { class: "sd-th__content--label" }, col.label)), col.usePageMoveIcon && h("sd-icon", { name: "pageMove", size: "12", color: "#006AC1" }), col.tooltip && (h("sd-tooltip", { ...col.tooltipOptions }, h("div", { slot: "content" }, col.tooltip.map(text => (h("p", null, text))))))), this.resizable && typeof window !== 'undefined' && (h("div", { class: "sd-th__resizer", onMouseDown: (evt) => this.handleResize(colIdx, evt) }))))))));
210
+ }
211
+ renderBody() {
212
+ return (h("tbody", { ...(!this.paginatedRows.length && { part: 'tbody-empty' }) }, this.isLoading && (h("div", { class: "sd-table__loading" }, h("sd-loading-spinner", null))), !this.paginatedRows.length ? (h("tr", null, h("td", { colSpan: this.visibleColumns.length + (this.selectable ? 1 : 0) }, h("slot", { name: "no-data" }, this.noDataLabel)))) : (this.paginatedRows.map((row, rowIdx) => (h("tr", { key: row[this.rowKey], class: "hover:bg-Grey_Lighten-6" }, this.selectable && (h("td", { class: {
213
+ 'sd-td': true,
214
+ 'sd-td--selected': true,
215
+ 'sticky-left': Boolean(this.stickyColumn.left && this.stickyColumn.left > 0),
216
+ }, style: {
217
+ '--sticky-left-offset': '0px',
218
+ } }, h("sd-checkbox", { checked: this.isRowSelected(row), disabled: !this.paginatedRows.length, onSdChange: () => this.updateRowSelect(row) }))), this.visibleColumns.map((column, colIdx) => {
219
+ const rendered = this.bodyCellRenderer?.(column, row);
220
+ return (h("td", { key: column.name, part: `td-${column.name}`, class: {
221
+ 'sd-td': true,
222
+ [`sd-td--${column.align || 'left'}`]: true,
223
+ 'sticky-left': Boolean(this.stickyColumn.left && colIdx < this.stickyColumn.left),
224
+ 'sticky-right': Boolean(this.stickyColumn.right &&
225
+ colIdx >= this.visibleColumns.length - this.stickyColumn.right),
226
+ 'sticky-left-edge': Boolean(this.stickyColumn.left && colIdx === this.stickyColumn.left - 1),
227
+ 'sticky-right-edge': Boolean(this.stickyColumn.right &&
228
+ colIdx === this.visibleColumns.length - this.stickyColumn.right),
229
+ [`${column.tdClass}`]: Boolean(column.tdClass),
230
+ }, style: this.getStickyStyle(colIdx) }, h("slot", { name: `body-cell-${column.name}-${rowIdx}` }, rendered ? (typeof rendered === 'string' ? (h("span", { innerHTML: rendered })) : (rendered)) : (this.getCellValue(column, row)))));
231
+ })))))));
232
+ }
233
+ render() {
234
+ return (h(Host, { key: '0ac0006dea3c0e4cde082f8b396513234ac60749' }, h("div", { key: '36aa811fed020945b72ab21c9318a03c3595d0d2', class: "sd-table__wrapper", style: {
235
+ '--table-width': this.width,
236
+ '--table-height': this.height,
237
+ } }, h("div", { key: 'd785153b7c08bbe1250dcb389b66c624382bdfd2', class: "sd-table__container" }, h("div", { key: '034db5c0eb677a87d6fa3a84d824c6e5078676ea', class: "sd-table__middle" }, h("table", { key: '43841e0ed748a887156b3ba80038602ddb8fd207', part: "table", class: this.sdTableClasses }, this.renderHeader(), this.renderBody())), h("div", { key: '391f134001037c03a39f1c428681053aa8004a11', class: "sd-table__bottom" })), this.pagination && this.innerRows.length > 0 && (h("div", { key: '73e38e427afc2ff69fd5adea0057d30351ade0fc', class: "sd-table__pagination" }, h("sd-pagination", { key: '61e9c37239109c493d03d731bd0643670325cf97', currentPage: !this.useInternalPagination ? this.pagination.page : this.currentPage, lastPage: !this.useInternalPagination ? this.pagination.lastPage : this.lastPageNumber, onPageChange: (e) => {
238
+ if (!this.useInternalPagination) {
239
+ this.sdPageChange.emit(e.detail);
240
+ }
241
+ else {
242
+ this.currentPage = e.detail;
243
+ this.sdPageChange.emit(this.currentPage);
244
+ }
245
+ } }), this.useRowsPerPageSelect && (h("sd-select", { key: 'ce5ea8221b621ab7f67558a2be228f473c22cca6', value: this.pagination.rowsPerPage, options: this.rowsPerPageOption, width: "128px", onSdChange: (e) => {
246
+ const changedRowsPerPage = e.detail.value ? Number(e.detail.value) : 0;
247
+ if (!this.useInternalPagination) {
248
+ this.sdRowsPerPageChange.emit(changedRowsPerPage);
249
+ }
250
+ else {
251
+ const newRowsPerPage = Number(e.detail.value || 0);
252
+ let newLastPage = Math.max(1, Math.ceil(this.innerRows.length / newRowsPerPage));
253
+ let newCurrentPage = this.currentPage;
254
+ if (newCurrentPage > newLastPage) {
255
+ newCurrentPage = newLastPage;
256
+ }
257
+ this.pagination = {
258
+ page: newCurrentPage,
259
+ rowsPerPage: newRowsPerPage,
260
+ lastPage: newLastPage,
261
+ };
262
+ this.currentPage = newCurrentPage;
263
+ this.sdRowsPerPageChange.emit(changedRowsPerPage);
264
+ }
265
+ } })))))));
266
+ }
267
+ static get watchers() { return {
268
+ "columns": ["handleColumnsChange"],
269
+ "rows": ["handleRowsChange"],
270
+ "selected": ["handleSelectedChange"],
271
+ "pagination": ["handlePaginationChange"]
272
+ }; }
273
+ static get style() { return sdTableCss; }
274
+ }, [772, "sd-table-backup", {
275
+ "columns": [16],
276
+ "rows": [1040],
277
+ "selected": [1040],
278
+ "rowKey": [1, "row-key"],
279
+ "selectable": [4],
280
+ "resizable": [4],
281
+ "width": [1],
282
+ "height": [1],
283
+ "stickyHeader": [4, "sticky-header"],
284
+ "stickyColumn": [16],
285
+ "noDataLabel": [1, "no-data-label"],
286
+ "isLoading": [4, "is-loading"],
287
+ "pagination": [16],
288
+ "bodyCellRenderer": [16],
289
+ "useInternalPagination": [4, "use-internal-pagination"],
290
+ "useRowsPerPageSelect": [4, "use-rows-per-page-select"],
291
+ "rowsPerPageOption": [16],
292
+ "currentPage": [32],
293
+ "innerRows": [32],
294
+ "innerSelected": [32],
295
+ "columnWidths": [32],
296
+ "scrolledLeft": [32],
297
+ "scrolledRight": [32]
298
+ }, undefined, {
299
+ "columns": ["handleColumnsChange"],
300
+ "rows": ["handleRowsChange"],
301
+ "selected": ["handleSelectedChange"],
302
+ "pagination": ["handlePaginationChange"]
303
+ }]);
304
+ function defineCustomElement$1() {
305
+ if (typeof customElements === "undefined") {
306
+ return;
307
+ }
308
+ const components = ["sd-table-backup", "sd-button", "sd-checkbox", "sd-icon", "sd-input", "sd-loading-spinner", "sd-pagination", "sd-portal", "sd-select", "sd-select-option", "sd-tooltip", "sd-tooltip-portal"];
309
+ components.forEach(tagName => { switch (tagName) {
310
+ case "sd-table-backup":
311
+ if (!customElements.get(tagName)) {
312
+ customElements.define(tagName, SdTable);
313
+ }
314
+ break;
315
+ case "sd-button":
316
+ if (!customElements.get(tagName)) {
317
+ defineCustomElement$c();
318
+ }
319
+ break;
320
+ case "sd-checkbox":
321
+ if (!customElements.get(tagName)) {
322
+ defineCustomElement$b();
323
+ }
324
+ break;
325
+ case "sd-icon":
326
+ if (!customElements.get(tagName)) {
327
+ defineCustomElement$a();
328
+ }
329
+ break;
330
+ case "sd-input":
331
+ if (!customElements.get(tagName)) {
332
+ defineCustomElement$9();
333
+ }
334
+ break;
335
+ case "sd-loading-spinner":
336
+ if (!customElements.get(tagName)) {
337
+ defineCustomElement$8();
338
+ }
339
+ break;
340
+ case "sd-pagination":
341
+ if (!customElements.get(tagName)) {
342
+ defineCustomElement$7();
343
+ }
344
+ break;
345
+ case "sd-portal":
346
+ if (!customElements.get(tagName)) {
347
+ defineCustomElement$6();
348
+ }
349
+ break;
350
+ case "sd-select":
351
+ if (!customElements.get(tagName)) {
352
+ defineCustomElement$5();
353
+ }
354
+ break;
355
+ case "sd-select-option":
356
+ if (!customElements.get(tagName)) {
357
+ defineCustomElement$4();
358
+ }
359
+ break;
360
+ case "sd-tooltip":
361
+ if (!customElements.get(tagName)) {
362
+ defineCustomElement$3();
363
+ }
364
+ break;
365
+ case "sd-tooltip-portal":
366
+ if (!customElements.get(tagName)) {
367
+ defineCustomElement$2();
368
+ }
369
+ break;
370
+ } });
371
+ }
372
+
373
+ const SdTableBackup = SdTable;
374
+ const defineCustomElement = defineCustomElement$1;
375
+
376
+ export { SdTableBackup, defineCustomElement };
377
+ //# sourceMappingURL=sd-table-backup.js.map
378
+
379
+ //# sourceMappingURL=sd-table-backup.js.map