@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.
- package/README.md +5 -5
- package/custom-elements.json +20 -0
- package/elements.dev.js +9 -0
- package/elements.dev.js.map +7 -0
- package/elements.js +2 -19
- package/elements.js.map +7 -1
- package/package.json +80 -18
- package/sp-table-body.dev.js +4 -0
- package/sp-table-body.dev.js.map +7 -0
- package/sp-table-body.js +2 -14
- package/sp-table-body.js.map +7 -1
- package/sp-table-cell.dev.js +4 -0
- package/sp-table-cell.dev.js.map +7 -0
- package/sp-table-cell.js +2 -14
- package/sp-table-cell.js.map +7 -1
- package/sp-table-checkbox-cell.dev.js +4 -0
- package/sp-table-checkbox-cell.dev.js.map +7 -0
- package/sp-table-checkbox-cell.js +2 -14
- package/sp-table-checkbox-cell.js.map +7 -1
- package/sp-table-head-cell.dev.js +4 -0
- package/sp-table-head-cell.dev.js.map +7 -0
- package/sp-table-head-cell.js +2 -14
- package/sp-table-head-cell.js.map +7 -1
- package/sp-table-head.dev.js +4 -0
- package/sp-table-head.dev.js.map +7 -0
- package/sp-table-head.js +2 -14
- package/sp-table-head.js.map +7 -1
- package/sp-table-row.dev.js +4 -0
- package/sp-table-row.dev.js.map +7 -0
- package/sp-table-row.js +2 -14
- package/sp-table-row.js.map +7 -1
- package/sp-table.dev.js +4 -0
- package/sp-table.dev.js.map +7 -0
- package/sp-table.js +2 -14
- package/sp-table.js.map +7 -1
- package/src/Table.d.ts +1 -0
- package/src/Table.dev.js +392 -0
- package/src/Table.dev.js.map +7 -0
- package/src/Table.js +13 -383
- package/src/Table.js.map +7 -1
- package/src/TableBody.d.ts +2 -0
- package/src/TableBody.dev.js +55 -0
- package/src/TableBody.dev.js.map +7 -0
- package/src/TableBody.js +3 -35
- package/src/TableBody.js.map +7 -1
- package/src/TableCell.dev.js +36 -0
- package/src/TableCell.dev.js.map +7 -0
- package/src/TableCell.js +3 -35
- package/src/TableCell.js.map +7 -1
- package/src/TableCheckboxCell.dev.js +71 -0
- package/src/TableCheckboxCell.dev.js.map +7 -0
- package/src/TableCheckboxCell.js +4 -62
- package/src/TableCheckboxCell.js.map +7 -1
- package/src/TableHead.dev.js +55 -0
- package/src/TableHead.dev.js.map +7 -0
- package/src/TableHead.js +3 -52
- package/src/TableHead.js.map +7 -1
- package/src/TableHeadCell.dev.js +93 -0
- package/src/TableHeadCell.dev.js.map +7 -0
- package/src/TableHeadCell.js +5 -92
- package/src/TableHeadCell.js.map +7 -1
- package/src/TableRow.dev.js +104 -0
- package/src/TableRow.dev.js.map +7 -0
- package/src/TableRow.js +3 -96
- package/src/TableRow.js.map +7 -1
- package/src/index.d.ts +6 -0
- package/src/index.dev.js +9 -0
- package/src/index.dev.js.map +7 -0
- package/src/index.js +2 -13
- package/src/index.js.map +7 -1
- package/src/spectrum-table-body.css.dev.js +17 -0
- package/src/spectrum-table-body.css.dev.js.map +7 -0
- package/src/spectrum-table-body.css.js +3 -16
- package/src/spectrum-table-body.css.js.map +7 -1
- package/src/spectrum-table-cell.css.dev.js +27 -0
- package/src/spectrum-table-cell.css.dev.js.map +7 -0
- package/src/spectrum-table-cell.css.js +3 -16
- package/src/spectrum-table-cell.css.js.map +7 -1
- package/src/spectrum-table-checkbox-cell.css.dev.js +13 -0
- package/src/spectrum-table-checkbox-cell.css.dev.js.map +7 -0
- package/src/spectrum-table-checkbox-cell.css.js +3 -16
- package/src/spectrum-table-checkbox-cell.css.js.map +7 -1
- package/src/spectrum-table-head-cell.css.dev.js +61 -0
- package/src/spectrum-table-head-cell.css.dev.js.map +7 -0
- package/src/spectrum-table-head-cell.css.js +3 -16
- package/src/spectrum-table-head-cell.css.js.map +7 -1
- package/src/spectrum-table-head.css.dev.js +7 -0
- package/src/spectrum-table-head.css.dev.js.map +7 -0
- package/src/spectrum-table-head.css.js +3 -16
- package/src/spectrum-table-head.css.js.map +7 -1
- package/src/spectrum-table-row.css.dev.js +33 -0
- package/src/spectrum-table-row.css.dev.js.map +7 -0
- package/src/spectrum-table-row.css.js +3 -16
- package/src/spectrum-table-row.css.js.map +7 -1
- package/src/spectrum-table.css.dev.js +513 -0
- package/src/spectrum-table.css.dev.js.map +7 -0
- package/src/spectrum-table.css.js +3 -16
- package/src/spectrum-table.css.js.map +7 -1
- package/src/table-body.css.dev.js +17 -0
- package/src/table-body.css.dev.js.map +7 -0
- package/src/table-body.css.js +4 -17
- package/src/table-body.css.js.map +7 -1
- package/src/table-cell.css.dev.js +27 -0
- package/src/table-cell.css.dev.js.map +7 -0
- package/src/table-cell.css.js +3 -16
- package/src/table-cell.css.js.map +7 -1
- package/src/table-checkbox-cell.css.dev.js +13 -0
- package/src/table-checkbox-cell.css.dev.js.map +7 -0
- package/src/table-checkbox-cell.css.js +3 -16
- package/src/table-checkbox-cell.css.js.map +7 -1
- package/src/table-head-cell.css.dev.js +61 -0
- package/src/table-head-cell.css.dev.js.map +7 -0
- package/src/table-head-cell.css.js +3 -16
- package/src/table-head-cell.css.js.map +7 -1
- package/src/table-head.css.dev.js +7 -0
- package/src/table-head.css.dev.js.map +7 -0
- package/src/table-head.css.js +3 -16
- package/src/table-head.css.js.map +7 -1
- package/src/table-row.css.dev.js +33 -0
- package/src/table-row.css.dev.js.map +7 -0
- package/src/table-row.css.js +3 -16
- package/src/table-row.css.js.map +7 -1
- package/src/table.css.dev.js +513 -0
- package/src/table.css.dev.js.map +7 -0
- package/src/table.css.js +4 -17
- package/src/table.css.js.map +7 -1
- package/stories/index.js +17 -27
- package/stories/index.js.map +7 -1
- package/stories/table-elements.stories.js +58 -102
- package/stories/table-elements.stories.js.map +7 -1
- package/stories/table-virtualized.stories.js +142 -128
- package/stories/table-virtualized.stories.js.map +7 -1
- package/test/benchmark/basic-test.js +7 -17
- package/test/benchmark/basic-test.js.map +7 -1
- package/test/table-elements.test-vrt.js +5 -15
- package/test/table-elements.test-vrt.js.map +7 -1
- package/test/table-selects.test.js +193 -170
- package/test/table-selects.test.js.map +7 -1
- package/test/table-virtualized.test-vrt.js +5 -15
- package/test/table-virtualized.test-vrt.js.map +7 -1
- package/test/table.test.js +117 -101
- package/test/table.test.js.map +7 -1
- package/test/virtualized-table-selects.test.js +386 -300
- package/test/virtualized-table-selects.test.js.map +7 -1
- package/test/virtualized-table.test.js +213 -182
- package/test/virtualized-table.test.js.map +7 -1
package/src/Table.dev.js
ADDED
|
@@ -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
|
+
}
|