svelte-common 6.8.6 → 6.9.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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "svelte-common",
3
- "version": "6.8.6",
3
+ "version": "6.9.0",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -32,7 +32,7 @@
32
32
  "start": "vite",
33
33
  "test": "npm run test:ava && npm run test:cafe",
34
34
  "test:cafe": "testcafe $BROWSER:headless tests/cafe/*-cafe.mjs -s build/test --page-request-timeout 5000 --app-init-delay 8000 --app vite",
35
- "test:ava": "ava --timeout 2m tests/*-ava.mjs tests/*-ava-node.mjs && ava --timeout 4m tests/*-ava.mjs tests/*-ava-node.mjs",
35
+ "test:ava": "ava --timeout 4m tests/*-ava.mjs tests/*-ava-node.mjs",
36
36
  "cover": "c8 -x 'tests/**/*' --temp-directory build/tmp ava --timeout 4m tests/*-ava.mjs tests/*-ava-node.mjs && c8 report -r lcov -o build/coverage --temp-directory build/tmp",
37
37
  "docs": "documentation readme --section=API ./src/**/*.mjs",
38
38
  "lint": "npm run lint:css && npm run lint:docs",
@@ -41,20 +41,21 @@
41
41
  "preview": "vite preview"
42
42
  },
43
43
  "dependencies": {
44
+ "pacc": "^2.0.0",
44
45
  "svelte-command": "^1.1.50",
45
46
  "svelte-entitlement": "^1.2.66"
46
47
  },
47
48
  "devDependencies": {
48
- "@semantic-release/commit-analyzer": "^11.0.0",
49
+ "@semantic-release/commit-analyzer": "^11.1.0",
49
50
  "@semantic-release/exec": "^6.0.3",
50
- "@semantic-release/release-notes-generator": "^12.0.0",
51
+ "@semantic-release/release-notes-generator": "^12.1.0",
51
52
  "@sveltejs/vite-plugin-svelte": "^2.4.6",
52
53
  "ava": "^5.3.1",
53
54
  "c8": "^8.0.1",
54
55
  "documentation": "^14.0.2",
55
- "mf-styling": "^3.0.6",
56
- "npm-pkgbuild": "^12.3.1",
57
- "semantic-release": "^22.0.5",
56
+ "mf-styling": "^3.1.1",
57
+ "npm-pkgbuild": "^13.0.2",
58
+ "semantic-release": "^22.0.7",
58
59
  "stylelint": "^15.11.0",
59
60
  "stylelint-config-standard": "^34.0.0",
60
61
  "svelte": "^4.2.2",
package/src/filter.mjs CHANGED
@@ -1,4 +1,12 @@
1
- import { getAttributeAndOperator } from "./attribute.mjs";
1
+ import {
2
+ getAttributeAndOperator,
3
+ EQUAL,
4
+ NOT_EQUAL,
5
+ LESS,
6
+ LESS_EQUAL,
7
+ GREATER,
8
+ GREATER_EQUAL
9
+ } from "pacc";
2
10
 
3
11
  function dateOp(value, against, op) {
4
12
  return numberOp(value.getTime(), against.getTime(), op);
@@ -74,7 +82,7 @@ function allOp(value, against, op) {
74
82
  return numberOp(value.length !== 0, against, op);
75
83
  case "string":
76
84
  if (
77
- op === "=" &&
85
+ op === EQUAL &&
78
86
  (against.length === 0 || value.indexOf(against) >= 0)
79
87
  ) {
80
88
  return true;
@@ -166,17 +174,17 @@ function allOp(value, against, op) {
166
174
 
167
175
  function numberOp(value, against, op) {
168
176
  switch (op) {
169
- case "!=":
177
+ case NOT_EQUAL:
170
178
  return value != against;
171
- case "=":
179
+ case EQUAL:
172
180
  return value == against;
173
- case ">":
181
+ case GREATER:
174
182
  return value > against;
175
- case "<":
183
+ case LESS:
176
184
  return value < against;
177
- case ">=":
185
+ case GREATER_EQUAL:
178
186
  return value >= against;
179
- case "<=":
187
+ case LESS_EQUAL:
180
188
  return value <= against;
181
189
  }
182
190
  }
package/src/sorting.mjs CHANGED
@@ -1,4 +1,4 @@
1
- import { getAttribute } from "./attribute.mjs";
1
+ import { getAttribute } from "pacc";
2
2
 
3
3
  export const SORT_NONE = "none";
4
4
  export const SORT_ASCENDING = "ascending";
package/src/attribute.mjs DELETED
@@ -1,295 +0,0 @@
1
- /**
2
- * @typedef {Object} AttributeDefinition
3
- *
4
- * @property {string} type
5
- * @property {boolean} writable
6
- * @property {boolean} [private] should the value be shown
7
- * @property {string} [depends] name of an attribute we depend on
8
- * @property {string[]} additionalAttributes extra attributes that are present in case our attribute is set
9
- * @property {string} description
10
- * @property {any} [default] the default value
11
- * @property {Function} [set] set the value
12
- * @property {Function} [get] get the value can be used to calculate default values
13
- * @property {string[]|string} [env] environment variable use to provide the value
14
- */
15
-
16
- /**
17
- * Split property path into tokens
18
- * @generator
19
- * @param {string} string
20
- * @yields {string}
21
- */
22
- export function* tokens(string) {
23
- let state, buffer;
24
-
25
- for (const c of string) {
26
- switch (state) {
27
- case "string-escaping":
28
- const esc = {
29
- "\\": "\\",
30
- t: "\t",
31
- b: "\b",
32
- r: "\r",
33
- n: "\n",
34
- f: "\f"
35
- };
36
- buffer += esc[c];
37
- state = "string";
38
- continue;
39
- }
40
-
41
- switch (c) {
42
- case "\t":
43
- case " ":
44
- switch (state) {
45
- case undefined:
46
- break;
47
- case "string":
48
- buffer += c;
49
- break;
50
- case "identifier":
51
- yield buffer;
52
- buffer = "";
53
- state = undefined;
54
- break;
55
- default:
56
- yield state;
57
- state = undefined;
58
- }
59
- break;
60
-
61
- case "\\":
62
- switch (state) {
63
- case "string":
64
- state = "string-escaping";
65
- break;
66
- }
67
- break;
68
- case '"':
69
- case "'":
70
- switch (state) {
71
- case undefined:
72
- buffer = "";
73
- state = "string";
74
- break;
75
- case "string":
76
- yield buffer;
77
- state = undefined;
78
- break;
79
- case "identifier":
80
- yield buffer;
81
- buffer = "";
82
- state = "string";
83
- break;
84
- default:
85
- yield state;
86
- buffer = "";
87
- state = "string";
88
- }
89
- break;
90
- case "!":
91
- case ">":
92
- case "<":
93
- switch (state) {
94
- case undefined:
95
- state = c;
96
- break;
97
- case "string":
98
- buffer += c;
99
- break;
100
- case "identifier":
101
- yield buffer;
102
- state = c;
103
- break;
104
- default:
105
- yield state;
106
- state = c;
107
- }
108
- break;
109
-
110
- case "=":
111
- switch (state) {
112
- case undefined:
113
- state = c;
114
- break;
115
- case "string":
116
- buffer += c;
117
- break;
118
- case "identifier":
119
- yield buffer;
120
- state = c;
121
- break;
122
- default:
123
- state += c;
124
- }
125
- break;
126
- case ".":
127
- case "+":
128
- case "-":
129
- case "*":
130
- case "/":
131
- case "(":
132
- case ")":
133
- case "[":
134
- case "]":
135
- switch (state) {
136
- case undefined:
137
- state = c;
138
- break;
139
- case "string":
140
- buffer += c;
141
- break;
142
- case "identifier":
143
- yield buffer;
144
- state = c;
145
- break;
146
- default:
147
- yield state;
148
- state = c;
149
- }
150
- break;
151
- default:
152
- switch (state) {
153
- case undefined:
154
- buffer = c;
155
- state = "identifier";
156
- break;
157
- case "string":
158
- case "identifier":
159
- buffer += c;
160
- break;
161
- default:
162
- if (
163
- (c >= "a" && c <= "z") ||
164
- (c >= "A" && c <= "Z") ||
165
- (c >= "0" && c <= "9") ||
166
- c === "_"
167
- ) {
168
- yield state;
169
- state = "identifier";
170
- buffer = c;
171
- } else {
172
- state += c;
173
- }
174
- }
175
- }
176
- }
177
-
178
- switch (state) {
179
- case undefined:
180
- break;
181
- case "string":
182
- throw new Error("unterminated string");
183
- case "identifier":
184
- yield buffer;
185
- break;
186
- default:
187
- yield state;
188
- }
189
- }
190
-
191
- /**
192
- * Set Object attribute.
193
- * The name may be a property path like 'a.b.c'.
194
- * @param {Object} object
195
- * @param {string} expression
196
- * @param {any} value
197
- */
198
- export function setAttribute(object, expression, value) {
199
- let lastObject = object;
200
- let lastKey;
201
-
202
- for (const token of tokens(expression)) {
203
- switch (token) {
204
- case ">":
205
- case "<":
206
- case ".":
207
- case "[":
208
- case "]":
209
- break;
210
-
211
- default:
212
- if (object[token] === undefined || typeof object[token] !== "object") {
213
- object[token] = {};
214
- }
215
-
216
- lastObject = object;
217
- lastKey = token;
218
-
219
- object = object[token];
220
- }
221
- }
222
-
223
- if (lastKey) {
224
- lastObject[lastKey] = value;
225
- }
226
- }
227
-
228
- /**
229
- * Deliver attribute value.
230
- * The name may be a property path like 'a.b.c' or a[2]
231
- * @param {Object} object
232
- * @param {string} expression
233
- * @returns {any} value associated with the given property name
234
- */
235
- export function getAttribute(object, expression) {
236
- return getAttributeAndOperator(object, expression)[0];
237
- }
238
-
239
- /**
240
- * Deliver attribute value and operator.
241
- * The name may be a property path like 'a.b.c <='.
242
- * @param {Object} object
243
- * @param {string} expression
244
- * @returns {[any,string]} value associated with the given property name
245
- */
246
- export function getAttributeAndOperator(object, expression, getters = {}) {
247
- let op = "=";
248
- let predicateTokens;
249
-
250
- for (const token of tokens(expression)) {
251
- switch (token) {
252
- case ">=":
253
- case "<=":
254
- case ">":
255
- case "<":
256
- case "=":
257
- case "!=":
258
- op = token;
259
- break;
260
- case ".":
261
- case "[":
262
- predicateTokens = [];
263
- break;
264
- case "]":
265
- // TODO: should loop over array actually getAttribute api should deliver iterators
266
- if (object[Symbol.iterator]) {
267
- object = [...object][0];
268
- }
269
-
270
- predicateTokens = undefined;
271
- break;
272
- case "*":
273
- predicateTokens.push(token);
274
- break;
275
-
276
- default:
277
- if (object === undefined) {
278
- break;
279
- }
280
-
281
- const g = getters[token];
282
- if (g) {
283
- object = g(object);
284
- } else {
285
- if (object[token] !== undefined) {
286
- object = object[token];
287
- } else {
288
- return [undefined, op];
289
- }
290
- }
291
- }
292
- }
293
-
294
- return [object, op];
295
- }