svelte-common 4.17.4 → 4.17.7
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 +2 -2
- package/src/filter.mjs +2 -0
- package/src/index.svelte +1 -6
- package/src/sorting.mjs +16 -33
- 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
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "svelte-common",
|
|
3
|
-
"version": "4.17.
|
|
3
|
+
"version": "4.17.7",
|
|
4
4
|
"publishConfig": {
|
|
5
5
|
"access": "public"
|
|
6
6
|
},
|
|
@@ -39,7 +39,7 @@
|
|
|
39
39
|
"@semantic-release/commit-analyzer": "^9.0.2",
|
|
40
40
|
"@semantic-release/exec": "^6.0.3",
|
|
41
41
|
"@semantic-release/release-notes-generator": "^10.0.3",
|
|
42
|
-
"@sveltejs/vite-plugin-svelte": "^1.0.
|
|
42
|
+
"@sveltejs/vite-plugin-svelte": "^1.0.3",
|
|
43
43
|
"ava": "^4.3.3",
|
|
44
44
|
"documentation": "^14.0.0",
|
|
45
45
|
"mf-styling": "^1.7.5",
|
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
|
@@ -63,7 +63,7 @@ export function sortable(th, store) {
|
|
|
63
63
|
}
|
|
64
64
|
|
|
65
65
|
/**
|
|
66
|
-
* Generate a sort function for a given sort
|
|
66
|
+
* Generate a sort function for a given sort-by set.
|
|
67
67
|
* @param {Object} sortBy
|
|
68
68
|
* @param {Object} getters
|
|
69
69
|
* @return {Function} sorter
|
|
@@ -73,51 +73,34 @@ export function sorter(sortBy, getters = {}) {
|
|
|
73
73
|
for (const [key, value] of Object.entries(sortBy)) {
|
|
74
74
|
const getter = getters[key] || (object => object[key]);
|
|
75
75
|
|
|
76
|
+
let rev = 1;
|
|
77
|
+
|
|
76
78
|
switch (value) {
|
|
79
|
+
case SORT_DESCENDING:
|
|
80
|
+
rev = -1;
|
|
81
|
+
|
|
77
82
|
case SORT_ASCENDING:
|
|
78
83
|
return (a, b) => {
|
|
79
|
-
|
|
80
|
-
|
|
84
|
+
let av = getter(a);
|
|
85
|
+
let bv = getter(b);
|
|
81
86
|
if (av === undefined) {
|
|
82
|
-
return -
|
|
87
|
+
return -rev;
|
|
83
88
|
}
|
|
84
89
|
if (bv === undefined) {
|
|
85
|
-
return
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
if (typeof av === "string") {
|
|
89
|
-
return typeof bv === "string" ? av.localeCompare(bv) : 1;
|
|
90
|
-
}
|
|
91
|
-
if (av instanceof Date) {
|
|
92
|
-
const avt = av.getTime();
|
|
93
|
-
const bvt = bv.getTime();
|
|
94
|
-
return avt > bvt ? 1 : avt === bvt ? 0 : -1;
|
|
90
|
+
return rev;
|
|
95
91
|
}
|
|
96
92
|
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
case SORT_DESCENDING:
|
|
101
|
-
return (b, a) => {
|
|
102
|
-
const av = getter(a);
|
|
103
|
-
const bv = getter(b);
|
|
104
|
-
if (av === undefined) {
|
|
105
|
-
return -1;
|
|
106
|
-
}
|
|
107
|
-
if (bv === undefined) {
|
|
108
|
-
return 1;
|
|
93
|
+
switch (typeof av) {
|
|
94
|
+
case "string":
|
|
95
|
+
return typeof bv === "string" ? av.localeCompare(bv) : rev;
|
|
109
96
|
}
|
|
110
97
|
|
|
111
|
-
if (typeof av === "string") {
|
|
112
|
-
return typeof bv === "string" ? av.localeCompare(bv) : 1;
|
|
113
|
-
}
|
|
114
98
|
if (av instanceof Date) {
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
return avt > bvt ? 1 : avt === bvt ? 0 : -1;
|
|
99
|
+
av = av.getTime();
|
|
100
|
+
bv = bv.getTime();
|
|
118
101
|
}
|
|
119
102
|
|
|
120
|
-
return av > bv ?
|
|
103
|
+
return av > bv ? rev : av == bv ? 0 : -rev;
|
|
121
104
|
};
|
|
122
105
|
}
|
|
123
106
|
}
|
|
@@ -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>
|