svelte-common 4.17.3 → 4.17.6
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/package.json +1 -1
- package/src/filter.mjs +2 -0
- package/src/index.svelte +1 -6
- package/src/sorting.mjs +12 -29
- package/src/components/DataGrid.svelte +0 -28
- package/src/components/DataGridColumn.svelte +0 -18
- package/src/data-grid.mjs +0 -10
package/package.json
CHANGED
package/src/filter.mjs
CHANGED
package/src/index.svelte
CHANGED
|
@@ -9,8 +9,6 @@
|
|
|
9
9
|
import ServerDetails from "./components/ServerDetails.svelte";
|
|
10
10
|
import ServiceWorkerDetails from "./components/ServiceWorkerDetails.svelte";
|
|
11
11
|
import ServiceWorkerRegistrationDetails from "./components/ServiceWorkerRegistrationDetails.svelte";
|
|
12
|
-
import DataGrid from "./components/DataGrid.svelte";
|
|
13
|
-
import DataGridColumn from "./components/DataGridColumn.svelte";
|
|
14
12
|
import TopNav from "./components/TopNav.svelte";
|
|
15
13
|
import Menue from "./components/Menue.svelte";
|
|
16
14
|
import Collapse from "./components/Collapse.svelte";
|
|
@@ -23,8 +21,6 @@
|
|
|
23
21
|
Duration,
|
|
24
22
|
TopNav,
|
|
25
23
|
Menue,
|
|
26
|
-
DataGrid,
|
|
27
|
-
DataGridColumn,
|
|
28
24
|
Collapse,
|
|
29
25
|
Modal,
|
|
30
26
|
Peer,
|
|
@@ -53,7 +49,6 @@
|
|
|
53
49
|
SORT_ASCENDING,
|
|
54
50
|
SORT_DESCENDING
|
|
55
51
|
} from "./sorting.mjs";
|
|
56
|
-
export { filter } from "./filter.mjs";
|
|
57
|
-
|
|
52
|
+
export { filter } from "./filter.mjs";
|
|
58
53
|
export { initializeServiceWorker } from "./service-worker.mjs";
|
|
59
54
|
</script>
|
package/src/sorting.mjs
CHANGED
|
@@ -26,13 +26,15 @@ export function toggleOrderBy(orderBy) {
|
|
|
26
26
|
* @param {WritableStore} to keep in sync with sorting properties
|
|
27
27
|
*/
|
|
28
28
|
export function sortable(th, store) {
|
|
29
|
-
|
|
30
29
|
store.subscribe(orderBy =>
|
|
31
30
|
th.setAttribute("aria-sort", orderBy[th.id] || SORT_NONE)
|
|
32
31
|
);
|
|
33
32
|
|
|
34
33
|
const button = document.createElement("button");
|
|
34
|
+
button.setAttribute("aria-label", `sortable ${th.id}`);
|
|
35
35
|
const img = document.createElement("img");
|
|
36
|
+
img.setAttribute("alt", "sorting order indicator");
|
|
37
|
+
|
|
36
38
|
button.appendChild(img);
|
|
37
39
|
|
|
38
40
|
button.onclick = () => {
|
|
@@ -71,51 +73,32 @@ export function sorter(sortBy, getters = {}) {
|
|
|
71
73
|
for (const [key, value] of Object.entries(sortBy)) {
|
|
72
74
|
const getter = getters[key] || (object => object[key]);
|
|
73
75
|
|
|
76
|
+
let rev = 1;
|
|
77
|
+
|
|
74
78
|
switch (value) {
|
|
79
|
+
case SORT_DESCENDING: rev = -1;
|
|
80
|
+
|
|
75
81
|
case SORT_ASCENDING:
|
|
76
82
|
return (a, b) => {
|
|
77
83
|
const av = getter(a);
|
|
78
84
|
const bv = getter(b);
|
|
79
85
|
if (av === undefined) {
|
|
80
|
-
return -
|
|
81
|
-
}
|
|
82
|
-
if (bv === undefined) {
|
|
83
|
-
return 1;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
if (typeof av === "string") {
|
|
87
|
-
return typeof bv === "string" ? av.localeCompare(bv) : 1;
|
|
88
|
-
}
|
|
89
|
-
if (av instanceof Date) {
|
|
90
|
-
const avt = av.getTime();
|
|
91
|
-
const bvt = bv.getTime();
|
|
92
|
-
return avt > bvt ? 1 : avt === bvt ? 0 : -1;
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
return av > bv ? 1 : av == bv ? 0 : -1;
|
|
96
|
-
};
|
|
97
|
-
|
|
98
|
-
case SORT_DESCENDING:
|
|
99
|
-
return (b, a) => {
|
|
100
|
-
const av = getter(a);
|
|
101
|
-
const bv = getter(b);
|
|
102
|
-
if (av === undefined) {
|
|
103
|
-
return -1;
|
|
86
|
+
return -rev;
|
|
104
87
|
}
|
|
105
88
|
if (bv === undefined) {
|
|
106
|
-
return
|
|
89
|
+
return rev;
|
|
107
90
|
}
|
|
108
91
|
|
|
109
92
|
if (typeof av === "string") {
|
|
110
|
-
return typeof bv === "string" ? av.localeCompare(bv) :
|
|
93
|
+
return typeof bv === "string" ? av.localeCompare(bv) : rev;
|
|
111
94
|
}
|
|
112
95
|
if (av instanceof Date) {
|
|
113
96
|
const avt = av.getTime();
|
|
114
97
|
const bvt = bv.getTime();
|
|
115
|
-
return avt > bvt ?
|
|
98
|
+
return avt > bvt ? rev : avt === bvt ? 0 : -rev;
|
|
116
99
|
}
|
|
117
100
|
|
|
118
|
-
return av > bv ?
|
|
101
|
+
return av > bv ? rev : av == bv ? 0 : -rev;
|
|
119
102
|
};
|
|
120
103
|
}
|
|
121
104
|
}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
import { setContext } from "svelte";
|
|
3
|
-
import { DataGrid, DATA_GRID} from "../data-grid.mjs";
|
|
4
|
-
|
|
5
|
-
export let source = { entries: [] };
|
|
6
|
-
|
|
7
|
-
const dataGrid = new DataGrid();
|
|
8
|
-
setContext(DATA_GRID, dataGrid);
|
|
9
|
-
</script>
|
|
10
|
-
|
|
11
|
-
<table>
|
|
12
|
-
<!--<slot/>-->
|
|
13
|
-
<thead>
|
|
14
|
-
{#each dataGrid.columns as column}
|
|
15
|
-
{column.id} {column.headerComponent}
|
|
16
|
-
<svelte:component this={column.headerComponent} />
|
|
17
|
-
{/each}
|
|
18
|
-
</thead>
|
|
19
|
-
<tbody>
|
|
20
|
-
{#each source.entries as entry}
|
|
21
|
-
<tr>
|
|
22
|
-
{#each dataGrid.columns as column}
|
|
23
|
-
<td>{entry[column.id]}</td>
|
|
24
|
-
{/each}
|
|
25
|
-
</tr>
|
|
26
|
-
{/each}
|
|
27
|
-
</tbody>
|
|
28
|
-
</table>
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
<script>
|
|
2
|
-
import { getContext } from "svelte";
|
|
3
|
-
import { DATA_GRID} from "../data-grid.mjs";
|
|
4
|
-
|
|
5
|
-
export let id;
|
|
6
|
-
|
|
7
|
-
const dataGrid = getContext(DATA_GRID);
|
|
8
|
-
|
|
9
|
-
let headerComponent;
|
|
10
|
-
|
|
11
|
-
dataGrid.addColumn({ id, headerComponent });
|
|
12
|
-
</script>
|
|
13
|
-
|
|
14
|
-
<th {id} bind:this={headerComponent}>
|
|
15
|
-
<slot name="header">
|
|
16
|
-
{id}
|
|
17
|
-
</slot>
|
|
18
|
-
</th>
|