svelte-common 6.8.6 → 6.8.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 CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "svelte-common",
3
- "version": "6.8.6",
3
+ "version": "6.8.7",
4
4
  "publishConfig": {
5
5
  "access": "public"
6
6
  },
@@ -41,6 +41,7 @@
41
41
  "preview": "vite preview"
42
42
  },
43
43
  "dependencies": {
44
+ "pacc": "^1.0.0",
44
45
  "svelte-command": "^1.1.50",
45
46
  "svelte-entitlement": "^1.2.66"
46
47
  },
@@ -52,9 +53,9 @@
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
+ "mf-styling": "^3.1.0",
56
57
  "npm-pkgbuild": "^12.3.1",
57
- "semantic-release": "^22.0.5",
58
+ "semantic-release": "^22.0.6",
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,4 @@
1
- import { getAttributeAndOperator } from "./attribute.mjs";
1
+ import { getAttributeAndOperator } from "pacc";
2
2
 
3
3
  function dateOp(value, against, op) {
4
4
  return numberOp(value.getTime(), against.getTime(), op);
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
- }