svelte-common 4.17.5 → 4.18.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 CHANGED
@@ -70,7 +70,7 @@ Synchronizes store value with node "aria-sort" attribute.
70
70
 
71
71
  ## sorter
72
72
 
73
- Generate a sort function for a given sort by set.
73
+ Generate a sort function for a given sort-by set.
74
74
 
75
75
  ### Parameters
76
76
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "svelte-common",
3
- "version": "4.17.5",
3
+ "version": "4.18.0",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -39,16 +39,16 @@
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.2",
42
+ "@sveltejs/vite-plugin-svelte": "^1.0.3",
43
43
  "ava": "^4.3.3",
44
44
  "documentation": "^14.0.0",
45
- "mf-styling": "^1.7.5",
45
+ "mf-styling": "^1.7.6",
46
46
  "npm-pkgbuild": "^10.14.8",
47
47
  "semantic-release": "^19.0.5",
48
48
  "stylelint": "^14.11.0",
49
49
  "stylelint-config-standard": "^28.0.0",
50
50
  "svelte": "^3.49.0",
51
- "testcafe": "^1.20.1",
51
+ "testcafe": "^2.0.0",
52
52
  "vite": "^3.0.9"
53
53
  },
54
54
  "optionalDependencies": {
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,
@@ -42,7 +38,8 @@
42
38
  formatBytes,
43
39
  formatDuration,
44
40
  formatDurationISO,
45
- formatSecondsSinceEpoch
41
+ formatSecondsSinceEpoch,
42
+ keyPrefixStore
46
43
  } from "./util.mjs";
47
44
  export {
48
45
  sorter,
@@ -53,7 +50,6 @@
53
50
  SORT_ASCENDING,
54
51
  SORT_DESCENDING
55
52
  } from "./sorting.mjs";
56
- export { filter } from "./filter.mjs";
57
-
53
+ export { filter } from "./filter.mjs";
58
54
  export { initializeServiceWorker } from "./service-worker.mjs";
59
55
  </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 by set.
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
@@ -76,12 +76,13 @@ export function sorter(sortBy, getters = {}) {
76
76
  let rev = 1;
77
77
 
78
78
  switch (value) {
79
- case SORT_DESCENDING: rev = -1;
80
-
79
+ case SORT_DESCENDING:
80
+ rev = -1;
81
+
81
82
  case SORT_ASCENDING:
82
83
  return (a, b) => {
83
- const av = getter(a);
84
- const bv = getter(b);
84
+ let av = getter(a);
85
+ let bv = getter(b);
85
86
  if (av === undefined) {
86
87
  return -rev;
87
88
  }
@@ -89,13 +90,14 @@ export function sorter(sortBy, getters = {}) {
89
90
  return rev;
90
91
  }
91
92
 
92
- if (typeof av === "string") {
93
- return typeof bv === "string" ? av.localeCompare(bv) : rev;
93
+ switch (typeof av) {
94
+ case "string":
95
+ return typeof bv === "string" ? av.localeCompare(bv) : rev;
94
96
  }
97
+
95
98
  if (av instanceof Date) {
96
- const avt = av.getTime();
97
- const bvt = bv.getTime();
98
- return avt > bvt ? rev : avt === bvt ? 0 : -rev;
99
+ av = av.getTime();
100
+ bv = bv.getTime();
99
101
  }
100
102
 
101
103
  return av > bv ? rev : av == bv ? 0 : -rev;
package/src/util.mjs CHANGED
@@ -94,3 +94,38 @@ function liveDuration(seconds) {
94
94
  }
95
95
 
96
96
  */
97
+
98
+ /**
99
+ * Create a store where al the object keys are prefixed
100
+ * @param {WriteableStore} store
101
+ * @param {string} prefix
102
+ * @returns {WriteableStore}
103
+ */
104
+ export function keyPrefixStore(store, prefix) {
105
+ const subscriptions = new Set();
106
+
107
+ store.subscribe(prefixedKeyObject => {
108
+ const object = Object.fromEntries(
109
+ Object.entries(prefixedKeyObject).map(([k, v]) => [
110
+ k.substring(prefix.length),
111
+ v
112
+ ])
113
+ );
114
+
115
+ subscriptions.forEach(subscription => subscription(object));
116
+ });
117
+
118
+ return {
119
+ set: object => {
120
+ const prefixedKeyObject = Object.fromEntries(
121
+ Object.entries(object).map(([k, v]) => [prefix + k, v])
122
+ );
123
+ store.set(prefixedKeyObject);
124
+ },
125
+
126
+ subscribe: s => {
127
+ subscriptions.add(s);
128
+ return () => subscriptions.delete(s);
129
+ }
130
+ };
131
+ }
@@ -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>
package/src/data-grid.mjs DELETED
@@ -1,10 +0,0 @@
1
-
2
- export const DATA_GRID = "DATA_GRID";
3
-
4
- export class DataGrid {
5
- columns = [];
6
-
7
- addColumn(c) {
8
- this.columns.push(c);
9
- }
10
- }