@spectrum-web-components/table 0.0.2-table.2695 → 0.1.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 (146) hide show
  1. package/README.md +5 -5
  2. package/custom-elements.json +20 -0
  3. package/elements.dev.js +9 -0
  4. package/elements.dev.js.map +7 -0
  5. package/elements.js +2 -19
  6. package/elements.js.map +7 -1
  7. package/package.json +80 -18
  8. package/sp-table-body.dev.js +4 -0
  9. package/sp-table-body.dev.js.map +7 -0
  10. package/sp-table-body.js +2 -14
  11. package/sp-table-body.js.map +7 -1
  12. package/sp-table-cell.dev.js +4 -0
  13. package/sp-table-cell.dev.js.map +7 -0
  14. package/sp-table-cell.js +2 -14
  15. package/sp-table-cell.js.map +7 -1
  16. package/sp-table-checkbox-cell.dev.js +4 -0
  17. package/sp-table-checkbox-cell.dev.js.map +7 -0
  18. package/sp-table-checkbox-cell.js +2 -14
  19. package/sp-table-checkbox-cell.js.map +7 -1
  20. package/sp-table-head-cell.dev.js +4 -0
  21. package/sp-table-head-cell.dev.js.map +7 -0
  22. package/sp-table-head-cell.js +2 -14
  23. package/sp-table-head-cell.js.map +7 -1
  24. package/sp-table-head.dev.js +4 -0
  25. package/sp-table-head.dev.js.map +7 -0
  26. package/sp-table-head.js +2 -14
  27. package/sp-table-head.js.map +7 -1
  28. package/sp-table-row.dev.js +4 -0
  29. package/sp-table-row.dev.js.map +7 -0
  30. package/sp-table-row.js +2 -14
  31. package/sp-table-row.js.map +7 -1
  32. package/sp-table.dev.js +4 -0
  33. package/sp-table.dev.js.map +7 -0
  34. package/sp-table.js +2 -14
  35. package/sp-table.js.map +7 -1
  36. package/src/Table.d.ts +1 -0
  37. package/src/Table.dev.js +392 -0
  38. package/src/Table.dev.js.map +7 -0
  39. package/src/Table.js +13 -383
  40. package/src/Table.js.map +7 -1
  41. package/src/TableBody.d.ts +2 -0
  42. package/src/TableBody.dev.js +55 -0
  43. package/src/TableBody.dev.js.map +7 -0
  44. package/src/TableBody.js +3 -35
  45. package/src/TableBody.js.map +7 -1
  46. package/src/TableCell.dev.js +36 -0
  47. package/src/TableCell.dev.js.map +7 -0
  48. package/src/TableCell.js +3 -35
  49. package/src/TableCell.js.map +7 -1
  50. package/src/TableCheckboxCell.dev.js +71 -0
  51. package/src/TableCheckboxCell.dev.js.map +7 -0
  52. package/src/TableCheckboxCell.js +4 -62
  53. package/src/TableCheckboxCell.js.map +7 -1
  54. package/src/TableHead.dev.js +55 -0
  55. package/src/TableHead.dev.js.map +7 -0
  56. package/src/TableHead.js +3 -52
  57. package/src/TableHead.js.map +7 -1
  58. package/src/TableHeadCell.dev.js +93 -0
  59. package/src/TableHeadCell.dev.js.map +7 -0
  60. package/src/TableHeadCell.js +5 -92
  61. package/src/TableHeadCell.js.map +7 -1
  62. package/src/TableRow.dev.js +104 -0
  63. package/src/TableRow.dev.js.map +7 -0
  64. package/src/TableRow.js +3 -96
  65. package/src/TableRow.js.map +7 -1
  66. package/src/index.d.ts +6 -0
  67. package/src/index.dev.js +9 -0
  68. package/src/index.dev.js.map +7 -0
  69. package/src/index.js +2 -13
  70. package/src/index.js.map +7 -1
  71. package/src/spectrum-table-body.css.dev.js +17 -0
  72. package/src/spectrum-table-body.css.dev.js.map +7 -0
  73. package/src/spectrum-table-body.css.js +3 -16
  74. package/src/spectrum-table-body.css.js.map +7 -1
  75. package/src/spectrum-table-cell.css.dev.js +27 -0
  76. package/src/spectrum-table-cell.css.dev.js.map +7 -0
  77. package/src/spectrum-table-cell.css.js +3 -16
  78. package/src/spectrum-table-cell.css.js.map +7 -1
  79. package/src/spectrum-table-checkbox-cell.css.dev.js +13 -0
  80. package/src/spectrum-table-checkbox-cell.css.dev.js.map +7 -0
  81. package/src/spectrum-table-checkbox-cell.css.js +3 -16
  82. package/src/spectrum-table-checkbox-cell.css.js.map +7 -1
  83. package/src/spectrum-table-head-cell.css.dev.js +61 -0
  84. package/src/spectrum-table-head-cell.css.dev.js.map +7 -0
  85. package/src/spectrum-table-head-cell.css.js +3 -16
  86. package/src/spectrum-table-head-cell.css.js.map +7 -1
  87. package/src/spectrum-table-head.css.dev.js +7 -0
  88. package/src/spectrum-table-head.css.dev.js.map +7 -0
  89. package/src/spectrum-table-head.css.js +3 -16
  90. package/src/spectrum-table-head.css.js.map +7 -1
  91. package/src/spectrum-table-row.css.dev.js +33 -0
  92. package/src/spectrum-table-row.css.dev.js.map +7 -0
  93. package/src/spectrum-table-row.css.js +3 -16
  94. package/src/spectrum-table-row.css.js.map +7 -1
  95. package/src/spectrum-table.css.dev.js +513 -0
  96. package/src/spectrum-table.css.dev.js.map +7 -0
  97. package/src/spectrum-table.css.js +3 -16
  98. package/src/spectrum-table.css.js.map +7 -1
  99. package/src/table-body.css.dev.js +17 -0
  100. package/src/table-body.css.dev.js.map +7 -0
  101. package/src/table-body.css.js +4 -17
  102. package/src/table-body.css.js.map +7 -1
  103. package/src/table-cell.css.dev.js +27 -0
  104. package/src/table-cell.css.dev.js.map +7 -0
  105. package/src/table-cell.css.js +3 -16
  106. package/src/table-cell.css.js.map +7 -1
  107. package/src/table-checkbox-cell.css.dev.js +13 -0
  108. package/src/table-checkbox-cell.css.dev.js.map +7 -0
  109. package/src/table-checkbox-cell.css.js +3 -16
  110. package/src/table-checkbox-cell.css.js.map +7 -1
  111. package/src/table-head-cell.css.dev.js +61 -0
  112. package/src/table-head-cell.css.dev.js.map +7 -0
  113. package/src/table-head-cell.css.js +3 -16
  114. package/src/table-head-cell.css.js.map +7 -1
  115. package/src/table-head.css.dev.js +7 -0
  116. package/src/table-head.css.dev.js.map +7 -0
  117. package/src/table-head.css.js +3 -16
  118. package/src/table-head.css.js.map +7 -1
  119. package/src/table-row.css.dev.js +33 -0
  120. package/src/table-row.css.dev.js.map +7 -0
  121. package/src/table-row.css.js +3 -16
  122. package/src/table-row.css.js.map +7 -1
  123. package/src/table.css.dev.js +513 -0
  124. package/src/table.css.dev.js.map +7 -0
  125. package/src/table.css.js +4 -17
  126. package/src/table.css.js.map +7 -1
  127. package/stories/index.js +17 -27
  128. package/stories/index.js.map +7 -1
  129. package/stories/table-elements.stories.js +58 -102
  130. package/stories/table-elements.stories.js.map +7 -1
  131. package/stories/table-virtualized.stories.js +142 -128
  132. package/stories/table-virtualized.stories.js.map +7 -1
  133. package/test/benchmark/basic-test.js +7 -17
  134. package/test/benchmark/basic-test.js.map +7 -1
  135. package/test/table-elements.test-vrt.js +5 -15
  136. package/test/table-elements.test-vrt.js.map +7 -1
  137. package/test/table-selects.test.js +193 -170
  138. package/test/table-selects.test.js.map +7 -1
  139. package/test/table-virtualized.test-vrt.js +5 -15
  140. package/test/table-virtualized.test-vrt.js.map +7 -1
  141. package/test/table.test.js +117 -101
  142. package/test/table.test.js.map +7 -1
  143. package/test/virtualized-table-selects.test.js +386 -300
  144. package/test/virtualized-table-selects.test.js.map +7 -1
  145. package/test/virtualized-table.test.js +213 -182
  146. package/test/virtualized-table.test.js.map +7 -1
@@ -0,0 +1,392 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __decorateClass = (decorators, target, key, kind) => {
5
+ var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
6
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
7
+ if (decorator = decorators[i])
8
+ result = (kind ? decorator(target, key, result) : decorator(result)) || result;
9
+ if (kind && result)
10
+ __defProp(target, key, result);
11
+ return result;
12
+ };
13
+ import {
14
+ html,
15
+ render,
16
+ SizedMixin,
17
+ SpectrumElement
18
+ } from "@spectrum-web-components/base";
19
+ import "../sp-table-row.dev.js";
20
+ import "../sp-table-checkbox-cell.dev.js";
21
+ import "../sp-table-body.dev.js";
22
+ import { property } from "@spectrum-web-components/base/src/decorators.js";
23
+ import styles from "./table.css.js";
24
+ import {
25
+ virtualize
26
+ } from "@lit-labs/virtualizer/virtualize.js";
27
+ export var RowType = /* @__PURE__ */ ((RowType2) => {
28
+ RowType2[RowType2["ITEM"] = 0] = "ITEM";
29
+ RowType2[RowType2["INFORMATION"] = 1] = "INFORMATION";
30
+ return RowType2;
31
+ })(RowType || {});
32
+ const _RangeChangedEvent = class extends Event {
33
+ constructor(range) {
34
+ super(_RangeChangedEvent.eventName, { bubbles: true });
35
+ this.first = range.first;
36
+ this.last = range.last;
37
+ }
38
+ };
39
+ export let RangeChangedEvent = _RangeChangedEvent;
40
+ RangeChangedEvent.eventName = "rangeChanged";
41
+ export class Table extends SizedMixin(SpectrumElement, {
42
+ validSizes: ["s", "m"],
43
+ defaultSize: "m"
44
+ }) {
45
+ constructor() {
46
+ super(...arguments);
47
+ this._renderItem = () => html``;
48
+ this.role = "grid";
49
+ this.selected = [];
50
+ this.selectedSet = /* @__PURE__ */ new Set();
51
+ this.items = [];
52
+ this.itemValue = (_item, index) => {
53
+ return `${index}`;
54
+ };
55
+ this.scroller = false;
56
+ }
57
+ static get styles() {
58
+ return [styles];
59
+ }
60
+ get renderItem() {
61
+ return this._renderItem;
62
+ }
63
+ set renderItem(fn) {
64
+ this._renderItem = (item, index) => {
65
+ const value = this.itemValue(item, index);
66
+ const selected = this.selected.includes(value);
67
+ const hasCheckbox = this.selects && (item == null ? void 0 : item._$rowType$) !== 1;
68
+ return html`
69
+ <sp-table-row
70
+ value=${value}
71
+ aria-rowindex=${index + 1}
72
+ ?selected=${selected}
73
+ >
74
+ ${hasCheckbox ? html`
75
+ <sp-table-checkbox-cell
76
+ ?checked=${selected}
77
+ ></sp-table-checkbox-cell>
78
+ ` : html``}
79
+ ${fn(item, index)}
80
+ </sp-table-row>
81
+ `;
82
+ };
83
+ }
84
+ get tableHead() {
85
+ return this.querySelector("sp-table-head");
86
+ }
87
+ get tableRows() {
88
+ if (this.isVirtualized) {
89
+ return [];
90
+ }
91
+ return [...this.querySelectorAll("sp-table-row")];
92
+ }
93
+ get isVirtualized() {
94
+ return !!this.items.length;
95
+ }
96
+ focus() {
97
+ const sortableHeadCell = this.querySelector(
98
+ "sp-table-head-cell[sortable]"
99
+ );
100
+ if (sortableHeadCell) {
101
+ sortableHeadCell.focus();
102
+ }
103
+ }
104
+ selectAllRows() {
105
+ if (this.isVirtualized) {
106
+ this.items.forEach((item, index) => {
107
+ if (item._$rowType$ !== 1) {
108
+ this.selectedSet.add(this.itemValue(item, index));
109
+ }
110
+ });
111
+ } else {
112
+ this.tableRows.forEach((row) => {
113
+ row.selected = true;
114
+ this.selectedSet.add(row.value);
115
+ });
116
+ }
117
+ this.selected = [...this.selectedSet];
118
+ if (!this.tableHeadCheckboxCell)
119
+ return;
120
+ this.tableHeadCheckboxCell.checked = true;
121
+ this.tableHeadCheckboxCell.indeterminate = false;
122
+ }
123
+ deselectAllRows() {
124
+ this.selectedSet.clear();
125
+ this.selected = [];
126
+ if (!this.isVirtualized) {
127
+ const selectedRows = [
128
+ ...this.querySelectorAll("[selected]")
129
+ ];
130
+ selectedRows.forEach((row) => {
131
+ row.selected = false;
132
+ });
133
+ }
134
+ if (!this.tableHeadCheckboxCell)
135
+ return;
136
+ this.tableHeadCheckboxCell.checked = false;
137
+ this.tableHeadCheckboxCell.indeterminate = false;
138
+ }
139
+ manageSelects() {
140
+ const checkboxes = this.querySelectorAll("sp-table-checkbox-cell");
141
+ const checkbox = document.createElement("sp-table-checkbox-cell");
142
+ if (!!this.selects) {
143
+ let allSelected = false;
144
+ if (this.isVirtualized) {
145
+ allSelected = this.selected.length > 0 && this.selected.length === this.items.length;
146
+ } else {
147
+ this.tableRows.forEach((row) => {
148
+ row.selected = this.selectedSet.has(row.value);
149
+ if (!row.querySelector(":scope > sp-table-checkbox-cell")) {
150
+ const clonedCheckbox = checkbox.cloneNode();
151
+ row.insertAdjacentElement("afterbegin", clonedCheckbox);
152
+ checkbox.checked = row.selected;
153
+ }
154
+ });
155
+ allSelected = this.selected.length === this.tableRows.length;
156
+ }
157
+ if (!this.tableHeadCheckboxCell) {
158
+ this.tableHeadCheckboxCell = document.createElement(
159
+ "sp-table-checkbox-cell"
160
+ );
161
+ this.tableHead.insertAdjacentElement(
162
+ "afterbegin",
163
+ this.tableHeadCheckboxCell
164
+ );
165
+ }
166
+ this.manageHeadCheckbox(allSelected);
167
+ } else {
168
+ checkboxes.forEach((box) => {
169
+ box.remove();
170
+ });
171
+ delete this.tableHeadCheckboxCell;
172
+ }
173
+ }
174
+ validateSelected() {
175
+ const rowValues = /* @__PURE__ */ new Set();
176
+ if (this.isVirtualized) {
177
+ this.items.forEach((item, index) => {
178
+ const value = this.itemValue(item, index);
179
+ rowValues.add(value);
180
+ });
181
+ } else {
182
+ this.tableRows.forEach((row) => {
183
+ rowValues.add(row.value);
184
+ });
185
+ }
186
+ const oldSelectedCount = this.selected.length;
187
+ this.selected = this.selected.filter(
188
+ (selectedItem) => rowValues.has(selectedItem)
189
+ );
190
+ if (oldSelectedCount !== this.selected.length) {
191
+ this.dispatchEvent(
192
+ new Event("change", {
193
+ cancelable: true,
194
+ bubbles: true,
195
+ composed: true
196
+ })
197
+ );
198
+ }
199
+ this.selectedSet = new Set(this.selected);
200
+ }
201
+ manageSelected() {
202
+ this.validateSelected();
203
+ if (this.isVirtualized)
204
+ return;
205
+ this.tableRows.forEach((row) => {
206
+ row.selected = this.selectedSet.has(row.value);
207
+ });
208
+ if (this.tableHeadCheckboxCell) {
209
+ this.tableHeadCheckboxCell.checked = this.selected.length === this.tableRows.length;
210
+ }
211
+ }
212
+ manageCheckboxes() {
213
+ var _a;
214
+ if (!!this.selects) {
215
+ this.tableHeadCheckboxCell = document.createElement(
216
+ "sp-table-checkbox-cell"
217
+ );
218
+ const allSelected = this.selected.length === this.tableRows.length;
219
+ this.manageHeadCheckbox(allSelected);
220
+ this.tableHead.insertAdjacentElement(
221
+ "afterbegin",
222
+ this.tableHeadCheckboxCell
223
+ );
224
+ this.tableRows.forEach((row) => {
225
+ const checkbox = document.createElement(
226
+ "sp-table-checkbox-cell"
227
+ );
228
+ row.insertAdjacentElement("afterbegin", checkbox);
229
+ row.selected = this.selectedSet.has(row.value);
230
+ checkbox.checked = row.selected;
231
+ });
232
+ } else {
233
+ (_a = this.tableHead.querySelector("sp-table-checkbox-cell")) == null ? void 0 : _a.remove();
234
+ this.tableRows.forEach((row) => {
235
+ var _a2;
236
+ (_a2 = row.checkboxCells[0]) == null ? void 0 : _a2.remove();
237
+ if (this.selected.length) {
238
+ row.selected = this.selectedSet.has(row.value);
239
+ }
240
+ });
241
+ }
242
+ }
243
+ manageHeadCheckbox(allSelected) {
244
+ if (!this.tableHeadCheckboxCell)
245
+ return;
246
+ this.tableHeadCheckboxCell.selectsSingle = this.selects === "single";
247
+ this.tableHeadCheckboxCell.checked = allSelected;
248
+ this.tableHeadCheckboxCell.indeterminate = this.selected.length > 0 && !allSelected;
249
+ }
250
+ handleChange(event) {
251
+ event.stopPropagation();
252
+ const previousSelectedSet = new Set(this.selectedSet);
253
+ const previousSelected = [...this.selected];
254
+ const { target } = event;
255
+ const { parentElement: rowItem } = target;
256
+ if (!rowItem.value) {
257
+ const { checkbox } = target;
258
+ if (checkbox.checked || checkbox.indeterminate) {
259
+ this.selectAllRows();
260
+ } else {
261
+ this.deselectAllRows();
262
+ }
263
+ } else {
264
+ switch (this.selects) {
265
+ case "single": {
266
+ this.deselectAllRows();
267
+ if (rowItem.selected) {
268
+ this.selectedSet.add(rowItem.value);
269
+ this.selected = [...this.selectedSet];
270
+ }
271
+ break;
272
+ }
273
+ case "multiple": {
274
+ if (rowItem.selected) {
275
+ this.selectedSet.add(rowItem.value);
276
+ } else {
277
+ this.selectedSet.delete(rowItem.value);
278
+ }
279
+ this.selected = [...this.selectedSet];
280
+ const allSelected = this.selected.length === this.tableRows.length;
281
+ if (!this.tableHeadCheckboxCell)
282
+ return;
283
+ this.tableHeadCheckboxCell.checked = allSelected;
284
+ this.tableHeadCheckboxCell.indeterminate = this.selected.length > 0 && !allSelected;
285
+ break;
286
+ }
287
+ default: {
288
+ break;
289
+ }
290
+ }
291
+ }
292
+ const applyDefault = this.dispatchEvent(
293
+ new Event("change", {
294
+ cancelable: true,
295
+ bubbles: true,
296
+ composed: true
297
+ })
298
+ );
299
+ if (!applyDefault) {
300
+ event.preventDefault();
301
+ this.selectedSet = previousSelectedSet;
302
+ this.selected = previousSelected;
303
+ }
304
+ }
305
+ scrollToIndex(index) {
306
+ if (index) {
307
+ this.renderVirtualizedItems(index);
308
+ }
309
+ }
310
+ render() {
311
+ return html`
312
+ <slot @change=${this.handleChange}></slot>
313
+ `;
314
+ }
315
+ willUpdate(changed) {
316
+ if (!this.hasUpdated) {
317
+ this.validateSelected();
318
+ this.manageCheckboxes();
319
+ }
320
+ if (changed.has("selects")) {
321
+ this.manageSelects();
322
+ }
323
+ if (changed.has("selected") && this.hasUpdated) {
324
+ this.manageSelected();
325
+ }
326
+ }
327
+ updated() {
328
+ if (this.items.length) {
329
+ this.renderVirtualizedItems();
330
+ }
331
+ }
332
+ renderVirtualizedItems(index) {
333
+ if (!this.isConnected)
334
+ return;
335
+ if (!this.tableBody) {
336
+ this.tableBody = this.querySelector("sp-table-body");
337
+ if (!this.tableBody) {
338
+ this.tableBody = document.createElement("sp-table-body");
339
+ this.append(this.tableBody);
340
+ }
341
+ this.tableBody.addEventListener(
342
+ "rangeChanged",
343
+ (event) => {
344
+ this.dispatchEvent(
345
+ new RangeChangedEvent({
346
+ first: event.first,
347
+ last: event.last
348
+ })
349
+ );
350
+ }
351
+ );
352
+ }
353
+ const config = {
354
+ items: this.items,
355
+ renderItem: this.renderItem,
356
+ scroller: this.scroller
357
+ };
358
+ if (index) {
359
+ config.scrollToIndex = {
360
+ index
361
+ };
362
+ }
363
+ render(
364
+ html`
365
+ ${virtualize(config)}
366
+ `,
367
+ this.tableBody
368
+ );
369
+ }
370
+ disconnectedCallback() {
371
+ super.disconnectedCallback();
372
+ }
373
+ }
374
+ __decorateClass([
375
+ property({ reflect: true })
376
+ ], Table.prototype, "role", 2);
377
+ __decorateClass([
378
+ property({ type: String, reflect: true })
379
+ ], Table.prototype, "selects", 2);
380
+ __decorateClass([
381
+ property({ type: Array })
382
+ ], Table.prototype, "selected", 2);
383
+ __decorateClass([
384
+ property({ type: Array })
385
+ ], Table.prototype, "items", 2);
386
+ __decorateClass([
387
+ property({ type: Object })
388
+ ], Table.prototype, "itemValue", 2);
389
+ __decorateClass([
390
+ property({ type: Boolean, reflect: true })
391
+ ], Table.prototype, "scroller", 2);
392
+ //# sourceMappingURL=Table.dev.js.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["Table.ts"],
4
+ "sourcesContent": ["/*\nCopyright 2022 Adobe. All rights reserved.\nThis file is licensed to you under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License. You may obtain a copy\nof the License at http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software distributed under\nthe License is distributed on an \"AS IS\" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS\nOF ANY KIND, either express or implied. See the License for the specific language\ngoverning permissions and limitations under the License.\n*/\n\nimport {\n CSSResultArray,\n html,\n PropertyValues,\n render,\n SizedMixin,\n SpectrumElement,\n TemplateResult,\n} from '@spectrum-web-components/base';\nimport '../sp-table-row.dev.js'\nimport '../sp-table-checkbox-cell.dev.js'\nimport '../sp-table-body.dev.js'\nimport { property } from '@spectrum-web-components/base/src/decorators.js';\nimport styles from './table.css.js';\nimport { TableBody } from './TableBody.dev.js'\nimport type { TableCheckboxCell } from './TableCheckboxCell.dev.js'\nimport type { TableHead } from './TableHead.dev.js'\nimport type { TableHeadCell } from './TableHeadCell.dev.js'\nimport type { TableRow } from './TableRow.dev.js'\nimport {\n virtualize,\n VirtualizeDirectiveConfig,\n} from '@lit-labs/virtualizer/virtualize.js';\n\ninterface Range {\n first: number;\n last: number;\n}\n\nexport enum RowType {\n ITEM = 0,\n INFORMATION = 1,\n}\n\nexport interface TableItem extends Record<string, unknown> {\n _$rowType$?: RowType;\n}\n\nexport class RangeChangedEvent extends Event {\n static eventName = 'rangeChanged';\n\n first: number;\n last: number;\n\n constructor(range: Range) {\n super(RangeChangedEvent.eventName, { bubbles: true });\n this.first = range.first;\n this.last = range.last;\n }\n}\n\n/**\n * @element sp-table\n *\n * @fires rangeChanged - Announces a change in the range of visible cells on the table body\n * @event change - Announces a change in the `selected` property of a table row\n */\n\nexport class Table extends SizedMixin(SpectrumElement, {\n validSizes: ['s', 'm'],\n defaultSize: 'm',\n}) {\n public static override get styles(): CSSResultArray {\n return [styles];\n }\n\n get renderItem(): (\n item: Record<string, unknown>,\n index: number\n ) => TemplateResult {\n return this._renderItem;\n }\n\n set renderItem(\n fn: (item: Record<string, unknown>, index: number) => TemplateResult\n ) {\n this._renderItem = (\n item: Record<string, unknown>,\n index: number\n ): TemplateResult => {\n const value = this.itemValue(item, index);\n const selected = this.selected.includes(value);\n const hasCheckbox = this.selects && item?._$rowType$ !== 1;\n\n return html`\n <sp-table-row\n value=${value}\n aria-rowindex=${index + 1}\n ?selected=${selected}\n >\n ${hasCheckbox\n ? html`\n <sp-table-checkbox-cell\n ?checked=${selected}\n ></sp-table-checkbox-cell>\n `\n : html``}\n ${fn(item, index)}\n </sp-table-row>\n `;\n };\n }\n\n private _renderItem: (\n item: Record<string, unknown>,\n index: number\n ) => TemplateResult = /* c8 ignore next */ () => html``;\n\n @property({ reflect: true })\n public role = 'grid';\n\n /**\n * Whether the Table allows users to select a row or rows, and thus controls whether or not the Table also renders checkboxes.\n */\n @property({ type: String, reflect: true })\n public selects: undefined | 'single' | 'multiple';\n\n /**\n * An array of <sp-row> values that have been selected.\n */\n @property({ type: Array })\n public selected: string[] = [];\n\n private selectedSet = new Set<string>();\n\n /**\n * The content of the rows rendered by the virtualized table. The key is the value of the sp-table-row, and the value is the sp-table-row's content (not the row itself).\n */\n @property({ type: Array })\n public items: Record<string, unknown>[] = [];\n\n /**\n * The value of an item. By default, it is set to the index of the sp-table-row.\n */\n @property({ type: Object })\n public itemValue = (_item: unknown, index: number): string => {\n return `${index}`;\n };\n\n /**\n * Whether or not the virtualized table has a scroll bar. If this is set to true, make sure to specify a height in the sp-table's inline styles.\n */\n @property({ type: Boolean, reflect: true })\n public scroller = false;\n\n private tableBody?: TableBody;\n\n private tableHeadCheckboxCell?: TableCheckboxCell;\n\n private get tableHead(): TableHead {\n return this.querySelector('sp-table-head') as TableHead;\n }\n\n private get tableRows(): TableRow[] {\n if (this.isVirtualized) {\n return [];\n }\n return [...this.querySelectorAll('sp-table-row')] as TableRow[];\n }\n\n private get isVirtualized(): boolean {\n return !!this.items.length;\n }\n\n public override focus(): void {\n const sortableHeadCell = this.querySelector(\n 'sp-table-head-cell[sortable]'\n ) as TableHeadCell;\n if (sortableHeadCell) {\n sortableHeadCell.focus();\n }\n }\n\n private selectAllRows(): void {\n if (this.isVirtualized) {\n this.items.forEach((item, index: number) => {\n if (item._$rowType$ !== 1) {\n this.selectedSet.add(this.itemValue(item, index));\n }\n });\n } else {\n this.tableRows.forEach((row) => {\n row.selected = true; // Visually\n this.selectedSet.add(row.value); // Prepares table state\n });\n }\n this.selected = [...this.selectedSet];\n\n if (!this.tableHeadCheckboxCell) /* c8 ignore next */ return;\n this.tableHeadCheckboxCell.checked = true;\n this.tableHeadCheckboxCell.indeterminate = false;\n }\n\n private deselectAllRows(): void {\n this.selectedSet.clear();\n this.selected = [];\n\n if (!this.isVirtualized) {\n const selectedRows = [\n ...this.querySelectorAll('[selected]'),\n ] as TableRow[];\n\n selectedRows.forEach((row) => {\n row.selected = false;\n });\n }\n\n if (!this.tableHeadCheckboxCell) /* c8 ignore next */ return;\n this.tableHeadCheckboxCell.checked = false;\n this.tableHeadCheckboxCell.indeterminate = false;\n }\n\n protected manageSelects(): void {\n const checkboxes = this.querySelectorAll('sp-table-checkbox-cell');\n const checkbox = document.createElement('sp-table-checkbox-cell');\n if (!!this.selects) {\n let allSelected = false;\n if (this.isVirtualized) {\n allSelected =\n this.selected.length > 0 &&\n this.selected.length === this.items.length;\n } else {\n this.tableRows.forEach((row) => {\n row.selected = this.selectedSet.has(row.value);\n if (!row.querySelector(':scope > sp-table-checkbox-cell')) {\n const clonedCheckbox =\n checkbox.cloneNode() as TableCheckboxCell;\n row.insertAdjacentElement('afterbegin', clonedCheckbox);\n checkbox.checked = row.selected;\n }\n });\n allSelected = this.selected.length === this.tableRows.length;\n }\n\n if (!this.tableHeadCheckboxCell) {\n this.tableHeadCheckboxCell = document.createElement(\n 'sp-table-checkbox-cell'\n ) as TableCheckboxCell;\n this.tableHead.insertAdjacentElement(\n 'afterbegin',\n this.tableHeadCheckboxCell\n );\n }\n this.manageHeadCheckbox(allSelected);\n } else {\n checkboxes.forEach((box) => {\n box.remove();\n });\n delete this.tableHeadCheckboxCell;\n }\n }\n\n protected validateSelected(): void {\n const rowValues = new Set<string>();\n\n if (this.isVirtualized) {\n this.items.forEach((item, index) => {\n const value = this.itemValue(item, index);\n rowValues.add(value);\n });\n } else {\n this.tableRows.forEach((row) => {\n rowValues.add(row.value);\n });\n }\n\n const oldSelectedCount = this.selected.length;\n\n this.selected = this.selected.filter((selectedItem) =>\n rowValues.has(selectedItem)\n );\n if (oldSelectedCount !== this.selected.length) {\n this.dispatchEvent(\n new Event('change', {\n cancelable: true,\n bubbles: true,\n composed: true,\n })\n );\n }\n this.selectedSet = new Set(this.selected);\n }\n\n protected manageSelected(): void {\n this.validateSelected();\n\n if (this.isVirtualized) return;\n\n this.tableRows.forEach((row) => {\n row.selected = this.selectedSet.has(row.value);\n });\n if (this.tableHeadCheckboxCell) {\n this.tableHeadCheckboxCell.checked =\n this.selected.length === this.tableRows.length;\n }\n }\n\n protected manageCheckboxes(): void {\n if (!!this.selects) {\n this.tableHeadCheckboxCell = document.createElement(\n 'sp-table-checkbox-cell'\n );\n const allSelected = this.selected.length === this.tableRows.length;\n\n this.manageHeadCheckbox(allSelected);\n\n this.tableHead.insertAdjacentElement(\n 'afterbegin',\n this.tableHeadCheckboxCell\n );\n\n this.tableRows.forEach((row) => {\n const checkbox = document.createElement(\n 'sp-table-checkbox-cell'\n );\n row.insertAdjacentElement('afterbegin', checkbox);\n row.selected = this.selectedSet.has(row.value);\n checkbox.checked = row.selected;\n });\n } else {\n this.tableHead.querySelector('sp-table-checkbox-cell')?.remove();\n this.tableRows.forEach((row) => {\n row.checkboxCells[0]?.remove();\n if (this.selected.length) {\n row.selected = this.selectedSet.has(row.value);\n }\n });\n }\n }\n\n protected manageHeadCheckbox(allSelected: boolean): void {\n if (!this.tableHeadCheckboxCell) /* c8 ignore next */ return;\n\n this.tableHeadCheckboxCell.selectsSingle = this.selects === 'single';\n this.tableHeadCheckboxCell.checked = allSelected;\n this.tableHeadCheckboxCell.indeterminate =\n this.selected.length > 0 && !allSelected;\n }\n\n protected handleChange(event: Event): void {\n event.stopPropagation();\n\n const previousSelectedSet = new Set(this.selectedSet);\n const previousSelected = [...this.selected];\n\n const { target } = event;\n const { parentElement: rowItem } = target as HTMLElement & {\n parentElement: TableRow;\n };\n if (!rowItem.value) {\n const { checkbox } = target as TableCheckboxCell;\n if (checkbox.checked || checkbox.indeterminate) {\n this.selectAllRows();\n } else {\n this.deselectAllRows();\n }\n } else {\n switch (this.selects) {\n case 'single': {\n this.deselectAllRows();\n if (rowItem.selected) {\n this.selectedSet.add(rowItem.value);\n this.selected = [...this.selectedSet];\n }\n break;\n }\n case 'multiple': {\n if (rowItem.selected) {\n this.selectedSet.add(rowItem.value);\n } else {\n this.selectedSet.delete(rowItem.value);\n }\n this.selected = [...this.selectedSet];\n\n const allSelected =\n this.selected.length === this.tableRows.length;\n\n if (!this.tableHeadCheckboxCell)\n /* c8 ignore next */ return;\n this.tableHeadCheckboxCell.checked = allSelected;\n this.tableHeadCheckboxCell.indeterminate =\n this.selected.length > 0 && !allSelected;\n break;\n }\n default: {\n break;\n }\n }\n }\n const applyDefault = this.dispatchEvent(\n new Event('change', {\n cancelable: true,\n bubbles: true,\n composed: true,\n })\n );\n if (!applyDefault) {\n event.preventDefault();\n this.selectedSet = previousSelectedSet;\n this.selected = previousSelected;\n }\n }\n\n public scrollToIndex(index?: number): void {\n if (index) {\n this.renderVirtualizedItems(index);\n }\n }\n\n protected override render(): TemplateResult {\n return html`\n <slot @change=${this.handleChange}></slot>\n `;\n }\n\n protected override willUpdate(changed: PropertyValues<this>): void {\n if (!this.hasUpdated) {\n this.validateSelected();\n this.manageCheckboxes();\n }\n if (changed.has('selects')) {\n this.manageSelects();\n }\n\n if (changed.has('selected') && this.hasUpdated) {\n this.manageSelected();\n }\n }\n\n protected override updated(): void {\n if (this.items.length) {\n this.renderVirtualizedItems();\n }\n }\n\n protected renderVirtualizedItems(index?: number): void {\n // Rendering updates into the table while disconnected can\n // cause runaway event binding in ancestor elements.\n if (!this.isConnected) return;\n if (!this.tableBody) {\n this.tableBody = this.querySelector('sp-table-body') as TableBody;\n if (!this.tableBody) {\n this.tableBody = document.createElement('sp-table-body');\n this.append(this.tableBody);\n }\n this.tableBody.addEventListener(\n 'rangeChanged',\n (event: RangeChangedEvent) => {\n this.dispatchEvent(\n new RangeChangedEvent({\n first: event.first,\n last: event.last,\n })\n );\n }\n );\n }\n const config: VirtualizeDirectiveConfig<Record<string, unknown>> = {\n items: this.items,\n renderItem: this.renderItem,\n scroller: this.scroller,\n };\n if (index) {\n config.scrollToIndex = {\n index,\n };\n }\n render(\n html`\n ${virtualize(config)}\n `,\n this.tableBody\n );\n }\n\n public override disconnectedCallback(): void {\n super.disconnectedCallback();\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["RowType", "_a"]
7
+ }