@symbo.ls/sdk 2.32.2 → 2.32.5
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/dist/cjs/config/environment.js +43 -8
- package/dist/cjs/index.js +12 -4
- package/dist/cjs/services/AdminService.js +4 -4
- package/dist/cjs/services/AuthService.js +36 -149
- package/dist/cjs/services/BaseService.js +5 -18
- package/dist/cjs/services/BranchService.js +10 -10
- package/dist/cjs/services/CollabService.js +94 -61
- package/dist/cjs/services/CoreService.js +19 -19
- package/dist/cjs/services/DnsService.js +4 -4
- package/dist/cjs/services/FileService.js +2 -2
- package/dist/cjs/services/PaymentService.js +2 -2
- package/dist/cjs/services/PlanService.js +12 -12
- package/dist/cjs/services/ProjectService.js +45 -35
- package/dist/cjs/services/PullRequestService.js +7 -7
- package/dist/cjs/services/ScreenshotService.js +304 -0
- package/dist/cjs/services/SubscriptionService.js +14 -14
- package/dist/cjs/services/index.js +4 -0
- package/dist/cjs/utils/TokenManager.js +16 -5
- package/dist/cjs/utils/changePreprocessor.js +134 -0
- package/dist/cjs/utils/jsonDiff.js +46 -4
- package/dist/cjs/utils/ordering.js +274 -0
- package/dist/cjs/utils/services.js +14 -1
- package/dist/esm/config/environment.js +43 -8
- package/dist/esm/index.js +1099 -417
- package/dist/esm/services/AdminService.js +68 -35
- package/dist/esm/services/AuthService.js +100 -168
- package/dist/esm/services/BaseService.js +64 -31
- package/dist/esm/services/BranchService.js +74 -41
- package/dist/esm/services/CollabService.js +570 -97
- package/dist/esm/services/CoreService.js +83 -50
- package/dist/esm/services/DnsService.js +68 -35
- package/dist/esm/services/FileService.js +66 -33
- package/dist/esm/services/PaymentService.js +66 -33
- package/dist/esm/services/PlanService.js +76 -43
- package/dist/esm/services/ProjectService.js +547 -66
- package/dist/esm/services/PullRequestService.js +71 -38
- package/dist/esm/services/ScreenshotService.js +992 -0
- package/dist/esm/services/SubscriptionService.js +78 -45
- package/dist/esm/services/index.js +1076 -412
- package/dist/esm/utils/CollabClient.js +89 -12
- package/dist/esm/utils/TokenManager.js +16 -5
- package/dist/esm/utils/changePreprocessor.js +442 -0
- package/dist/esm/utils/jsonDiff.js +46 -4
- package/dist/esm/utils/ordering.js +256 -0
- package/dist/esm/utils/services.js +14 -1
- package/dist/node/config/environment.js +43 -8
- package/dist/node/index.js +14 -5
- package/dist/node/services/AdminService.js +4 -4
- package/dist/node/services/AuthService.js +36 -139
- package/dist/node/services/BaseService.js +5 -18
- package/dist/node/services/BranchService.js +10 -10
- package/dist/node/services/CollabService.js +95 -62
- package/dist/node/services/CoreService.js +19 -19
- package/dist/node/services/DnsService.js +4 -4
- package/dist/node/services/FileService.js +2 -2
- package/dist/node/services/PaymentService.js +2 -2
- package/dist/node/services/PlanService.js +12 -12
- package/dist/node/services/ProjectService.js +45 -35
- package/dist/node/services/PullRequestService.js +7 -7
- package/dist/node/services/ScreenshotService.js +285 -0
- package/dist/node/services/SubscriptionService.js +14 -14
- package/dist/node/services/index.js +4 -0
- package/dist/node/utils/TokenManager.js +16 -5
- package/dist/node/utils/changePreprocessor.js +115 -0
- package/dist/node/utils/jsonDiff.js +46 -4
- package/dist/node/utils/ordering.js +255 -0
- package/dist/node/utils/services.js +14 -1
- package/package.json +7 -6
- package/src/config/environment.js +48 -9
- package/src/index.js +38 -22
- package/src/services/AdminService.js +4 -4
- package/src/services/AuthService.js +42 -175
- package/src/services/BaseService.js +7 -24
- package/src/services/BranchService.js +10 -10
- package/src/services/CollabService.js +115 -74
- package/src/services/CoreService.js +19 -19
- package/src/services/DnsService.js +4 -4
- package/src/services/FileService.js +2 -2
- package/src/services/PaymentService.js +2 -2
- package/src/services/PlanService.js +12 -12
- package/src/services/ProjectService.js +50 -35
- package/src/services/PullRequestService.js +7 -7
- package/src/services/ScreenshotService.js +258 -0
- package/src/services/SubscriptionService.js +14 -14
- package/src/services/index.js +6 -1
- package/src/utils/TokenManager.js +19 -5
- package/src/utils/changePreprocessor.js +139 -0
- package/src/utils/jsonDiff.js +40 -5
- package/src/utils/ordering.js +244 -0
- package/src/utils/services.js +15 -1
|
@@ -34,7 +34,7 @@ class SubscriptionService extends BaseService {
|
|
|
34
34
|
}
|
|
35
35
|
throw new Error(response.message);
|
|
36
36
|
} catch (error) {
|
|
37
|
-
throw new Error(`Failed to create subscription: ${error.message}
|
|
37
|
+
throw new Error(`Failed to create subscription: ${error.message}`, { cause: error });
|
|
38
38
|
}
|
|
39
39
|
}
|
|
40
40
|
/**
|
|
@@ -55,7 +55,7 @@ class SubscriptionService extends BaseService {
|
|
|
55
55
|
}
|
|
56
56
|
throw new Error(response.message);
|
|
57
57
|
} catch (error) {
|
|
58
|
-
throw new Error(`Failed to get project subscription status: ${error.message}
|
|
58
|
+
throw new Error(`Failed to get project subscription status: ${error.message}`, { cause: error });
|
|
59
59
|
}
|
|
60
60
|
}
|
|
61
61
|
/**
|
|
@@ -76,7 +76,7 @@ class SubscriptionService extends BaseService {
|
|
|
76
76
|
}
|
|
77
77
|
throw new Error(response.message);
|
|
78
78
|
} catch (error) {
|
|
79
|
-
throw new Error(`Failed to get subscription usage: ${error.message}
|
|
79
|
+
throw new Error(`Failed to get subscription usage: ${error.message}`, { cause: error });
|
|
80
80
|
}
|
|
81
81
|
}
|
|
82
82
|
/**
|
|
@@ -97,7 +97,7 @@ class SubscriptionService extends BaseService {
|
|
|
97
97
|
}
|
|
98
98
|
throw new Error(response.message);
|
|
99
99
|
} catch (error) {
|
|
100
|
-
throw new Error(`Failed to cancel subscription: ${error.message}
|
|
100
|
+
throw new Error(`Failed to cancel subscription: ${error.message}`, { cause: error });
|
|
101
101
|
}
|
|
102
102
|
}
|
|
103
103
|
/**
|
|
@@ -134,7 +134,7 @@ class SubscriptionService extends BaseService {
|
|
|
134
134
|
}
|
|
135
135
|
throw new Error(response.message);
|
|
136
136
|
} catch (error) {
|
|
137
|
-
throw new Error(`Failed to list invoices: ${error.message}
|
|
137
|
+
throw new Error(`Failed to list invoices: ${error.message}`, { cause: error });
|
|
138
138
|
}
|
|
139
139
|
}
|
|
140
140
|
/**
|
|
@@ -161,7 +161,7 @@ class SubscriptionService extends BaseService {
|
|
|
161
161
|
}
|
|
162
162
|
throw new Error(response.message);
|
|
163
163
|
} catch (error) {
|
|
164
|
-
throw new Error(`Failed to get portal URL: ${error.message}
|
|
164
|
+
throw new Error(`Failed to get portal URL: ${error.message}`, { cause: error });
|
|
165
165
|
}
|
|
166
166
|
}
|
|
167
167
|
// ==================== SUBSCRIPTION HELPER METHODS ====================
|
|
@@ -196,7 +196,7 @@ class SubscriptionService extends BaseService {
|
|
|
196
196
|
const status = await this.getProjectStatus(projectId);
|
|
197
197
|
return status.hasSubscription === true;
|
|
198
198
|
} catch (error) {
|
|
199
|
-
throw new Error(`Failed to check subscription status: ${error.message}
|
|
199
|
+
throw new Error(`Failed to check subscription status: ${error.message}`, { cause: error });
|
|
200
200
|
}
|
|
201
201
|
}
|
|
202
202
|
/**
|
|
@@ -210,7 +210,7 @@ class SubscriptionService extends BaseService {
|
|
|
210
210
|
}
|
|
211
211
|
return status.subscription;
|
|
212
212
|
} catch (error) {
|
|
213
|
-
throw new Error(`Failed to get project subscription: ${error.message}
|
|
213
|
+
throw new Error(`Failed to get project subscription: ${error.message}`, { cause: error });
|
|
214
214
|
}
|
|
215
215
|
}
|
|
216
216
|
/**
|
|
@@ -224,7 +224,7 @@ class SubscriptionService extends BaseService {
|
|
|
224
224
|
}
|
|
225
225
|
return status.usage;
|
|
226
226
|
} catch (error) {
|
|
227
|
-
throw new Error(`Failed to get project usage: ${error.message}
|
|
227
|
+
throw new Error(`Failed to get project usage: ${error.message}`, { cause: error });
|
|
228
228
|
}
|
|
229
229
|
}
|
|
230
230
|
/**
|
|
@@ -238,7 +238,7 @@ class SubscriptionService extends BaseService {
|
|
|
238
238
|
pagination: result.pagination || {}
|
|
239
239
|
};
|
|
240
240
|
} catch (error) {
|
|
241
|
-
throw new Error(`Failed to get invoices with pagination: ${error.message}
|
|
241
|
+
throw new Error(`Failed to get invoices with pagination: ${error.message}`, { cause: error });
|
|
242
242
|
}
|
|
243
243
|
}
|
|
244
244
|
/**
|
|
@@ -249,7 +249,7 @@ class SubscriptionService extends BaseService {
|
|
|
249
249
|
const usage = await this.getUsage(subscriptionId);
|
|
250
250
|
return usage && usage.subscription && usage.subscription.status === "active";
|
|
251
251
|
} catch (error) {
|
|
252
|
-
throw new Error(`Failed to check subscription status: ${error.message}
|
|
252
|
+
throw new Error(`Failed to check subscription status: ${error.message}`, { cause: error });
|
|
253
253
|
}
|
|
254
254
|
}
|
|
255
255
|
/**
|
|
@@ -260,7 +260,7 @@ class SubscriptionService extends BaseService {
|
|
|
260
260
|
const usage = await this.getUsage(subscriptionId);
|
|
261
261
|
return usage.limits || {};
|
|
262
262
|
} catch (error) {
|
|
263
|
-
throw new Error(`Failed to get subscription limits: ${error.message}
|
|
263
|
+
throw new Error(`Failed to get subscription limits: ${error.message}`, { cause: error });
|
|
264
264
|
}
|
|
265
265
|
}
|
|
266
266
|
/**
|
|
@@ -296,7 +296,7 @@ class SubscriptionService extends BaseService {
|
|
|
296
296
|
}
|
|
297
297
|
throw new Error(response.message);
|
|
298
298
|
} catch (error) {
|
|
299
|
-
throw new Error(`Failed to change subscription: ${error.message}
|
|
299
|
+
throw new Error(`Failed to change subscription: ${error.message}`, { cause: error });
|
|
300
300
|
}
|
|
301
301
|
}
|
|
302
302
|
/**
|
|
@@ -324,7 +324,7 @@ class SubscriptionService extends BaseService {
|
|
|
324
324
|
}
|
|
325
325
|
throw new Error(response.message);
|
|
326
326
|
} catch (error) {
|
|
327
|
-
throw new Error(`Failed to downgrade subscription: ${error.message}
|
|
327
|
+
throw new Error(`Failed to downgrade subscription: ${error.message}`, { cause: error });
|
|
328
328
|
}
|
|
329
329
|
}
|
|
330
330
|
/**
|
|
@@ -10,6 +10,7 @@ import { DnsService } from "./DnsService.js";
|
|
|
10
10
|
import { BranchService } from "./BranchService.js";
|
|
11
11
|
import { PullRequestService } from "./PullRequestService.js";
|
|
12
12
|
import { AdminService } from "./AdminService.js";
|
|
13
|
+
import { ScreenshotService } from "./ScreenshotService.js";
|
|
13
14
|
const createService = (ServiceClass, config) => new ServiceClass(config);
|
|
14
15
|
const createAuthService = (config) => createService(AuthService, config);
|
|
15
16
|
const createCoreService = (config) => createService(CoreService, config);
|
|
@@ -23,6 +24,7 @@ const createDnsService = (config) => createService(DnsService, config);
|
|
|
23
24
|
const createBranchService = (config) => createService(BranchService, config);
|
|
24
25
|
const createPullRequestService = (config) => createService(PullRequestService, config);
|
|
25
26
|
const createAdminService = (config) => createService(AdminService, config);
|
|
27
|
+
const createScreenshotService = (config) => createService(ScreenshotService, config);
|
|
26
28
|
export {
|
|
27
29
|
AdminService,
|
|
28
30
|
AuthService,
|
|
@@ -35,6 +37,7 @@ export {
|
|
|
35
37
|
PlanService,
|
|
36
38
|
ProjectService,
|
|
37
39
|
PullRequestService,
|
|
40
|
+
ScreenshotService,
|
|
38
41
|
SubscriptionService,
|
|
39
42
|
createAdminService,
|
|
40
43
|
createAuthService,
|
|
@@ -47,5 +50,6 @@ export {
|
|
|
47
50
|
createPlanService,
|
|
48
51
|
createProjectService,
|
|
49
52
|
createPullRequestService,
|
|
53
|
+
createScreenshotService,
|
|
50
54
|
createSubscriptionService
|
|
51
55
|
};
|
|
@@ -2,7 +2,7 @@ class TokenManager {
|
|
|
2
2
|
constructor(options = {}) {
|
|
3
3
|
this.config = {
|
|
4
4
|
storagePrefix: "symbols_",
|
|
5
|
-
storageType: typeof window === "undefined" || process.env.NODE_ENV === "test" ? "memory" : "localStorage",
|
|
5
|
+
storageType: typeof window === "undefined" || process.env.NODE_ENV === "test" || process.env.NODE_ENV === "testing" ? "memory" : "localStorage",
|
|
6
6
|
// 'localStorage' | 'sessionStorage' | 'memory'
|
|
7
7
|
refreshBuffer: 60 * 1e3,
|
|
8
8
|
// Refresh 1 minute before expiry
|
|
@@ -42,15 +42,26 @@ class TokenManager {
|
|
|
42
42
|
if (typeof window === "undefined") {
|
|
43
43
|
return this._memoryStorage;
|
|
44
44
|
}
|
|
45
|
-
const
|
|
46
|
-
|
|
45
|
+
const safeGetStorage = (provider) => {
|
|
46
|
+
try {
|
|
47
|
+
const storage = provider();
|
|
48
|
+
const testKey = `${this.config.storagePrefix}__tm_test__`;
|
|
49
|
+
storage.setItem(testKey, "1");
|
|
50
|
+
storage.removeItem(testKey);
|
|
51
|
+
return storage;
|
|
52
|
+
} catch {
|
|
53
|
+
return null;
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
const localStorageInstance = safeGetStorage(() => window.localStorage);
|
|
57
|
+
const sessionStorageInstance = safeGetStorage(() => window.sessionStorage);
|
|
47
58
|
switch (this.config.storageType) {
|
|
48
59
|
case "sessionStorage":
|
|
49
|
-
return
|
|
60
|
+
return sessionStorageInstance || this._memoryStorage;
|
|
50
61
|
case "memory":
|
|
51
62
|
return this._memoryStorage;
|
|
52
63
|
default:
|
|
53
|
-
return
|
|
64
|
+
return localStorageInstance || this._memoryStorage;
|
|
54
65
|
}
|
|
55
66
|
}
|
|
56
67
|
/**
|
|
@@ -0,0 +1,115 @@
|
|
|
1
|
+
import { diffJson } from "./jsonDiff.js";
|
|
2
|
+
import { computeOrdersForTuples } from "./ordering.js";
|
|
3
|
+
function isPlainObject(val) {
|
|
4
|
+
return val && typeof val === "object" && !Array.isArray(val);
|
|
5
|
+
}
|
|
6
|
+
function getByPathSafe(root, path) {
|
|
7
|
+
if (!root || typeof root.getByPath !== "function") {
|
|
8
|
+
return null;
|
|
9
|
+
}
|
|
10
|
+
try {
|
|
11
|
+
return root.getByPath(path);
|
|
12
|
+
} catch {
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
function preprocessChanges(root, tuples = [], options = {}) {
|
|
17
|
+
const expandTuple = (t) => {
|
|
18
|
+
const [action, path, value] = t || [];
|
|
19
|
+
const isSchemaPath = Array.isArray(path) && path[0] === "schema";
|
|
20
|
+
if (action === "delete") {
|
|
21
|
+
return [t];
|
|
22
|
+
}
|
|
23
|
+
const canConsiderExpansion = action === "update" && Array.isArray(path) && (path.length === 1 || path.length === 2 || isSchemaPath && path.length === 3) && isPlainObject(value);
|
|
24
|
+
if (!canConsiderExpansion) {
|
|
25
|
+
return [t];
|
|
26
|
+
}
|
|
27
|
+
const prev = getByPathSafe(root, path) || {};
|
|
28
|
+
const next = value || {};
|
|
29
|
+
if (!isPlainObject(prev) || !isPlainObject(next)) {
|
|
30
|
+
return [t];
|
|
31
|
+
}
|
|
32
|
+
const ops = diffJson(prev, next, []);
|
|
33
|
+
if (!ops.length) {
|
|
34
|
+
return [t];
|
|
35
|
+
}
|
|
36
|
+
const out = [];
|
|
37
|
+
for (let i = 0; i < ops.length; i++) {
|
|
38
|
+
const op = ops[i];
|
|
39
|
+
const fullPath = [...path, ...op.path];
|
|
40
|
+
const last = fullPath[fullPath.length - 1];
|
|
41
|
+
if (op.action === "set") {
|
|
42
|
+
out.push(["update", fullPath, op.value]);
|
|
43
|
+
} else if (op.action === "del") {
|
|
44
|
+
if (last !== "__order") {
|
|
45
|
+
out.push(["delete", fullPath]);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
return out;
|
|
50
|
+
};
|
|
51
|
+
const minimizeTuples = (input) => {
|
|
52
|
+
const out = [];
|
|
53
|
+
const seen2 = /* @__PURE__ */ new Set();
|
|
54
|
+
for (let i = 0; i < input.length; i++) {
|
|
55
|
+
const expanded = expandTuple(input[i]);
|
|
56
|
+
for (let k = 0; k < expanded.length; k++) {
|
|
57
|
+
const tuple = expanded[k];
|
|
58
|
+
const isDelete = Array.isArray(tuple) && tuple[0] === "delete";
|
|
59
|
+
const isOrderKey = isDelete && Array.isArray(tuple[1]) && tuple[1][tuple[1].length - 1] === "__order";
|
|
60
|
+
if (!isOrderKey) {
|
|
61
|
+
const key = JSON.stringify(tuple);
|
|
62
|
+
if (!seen2.has(key)) {
|
|
63
|
+
seen2.add(key);
|
|
64
|
+
out.push(tuple);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
return out;
|
|
70
|
+
};
|
|
71
|
+
const granularChanges = (() => {
|
|
72
|
+
try {
|
|
73
|
+
const res = minimizeTuples(tuples);
|
|
74
|
+
if (options.append && options.append.length) {
|
|
75
|
+
res.push(...options.append);
|
|
76
|
+
}
|
|
77
|
+
return res;
|
|
78
|
+
} catch {
|
|
79
|
+
return Array.isArray(tuples) ? tuples.slice() : [];
|
|
80
|
+
}
|
|
81
|
+
})();
|
|
82
|
+
const baseOrders = computeOrdersForTuples(root, granularChanges);
|
|
83
|
+
const preferOrdersMap = /* @__PURE__ */ new Map();
|
|
84
|
+
for (let i = 0; i < tuples.length; i++) {
|
|
85
|
+
const t = tuples[i];
|
|
86
|
+
if (!Array.isArray(t) || t.length < 3) {
|
|
87
|
+
continue;
|
|
88
|
+
}
|
|
89
|
+
const [action, path, value] = t;
|
|
90
|
+
if (action !== "update" || !Array.isArray(path) || path.length !== 1 && path.length !== 2 || !isPlainObject(value)) {
|
|
91
|
+
continue;
|
|
92
|
+
}
|
|
93
|
+
const keys = Object.keys(value).filter((k) => k !== "__order");
|
|
94
|
+
const key = JSON.stringify(path);
|
|
95
|
+
preferOrdersMap.set(key, { path, keys });
|
|
96
|
+
}
|
|
97
|
+
const mergedOrders = [];
|
|
98
|
+
const seen = /* @__PURE__ */ new Set();
|
|
99
|
+
preferOrdersMap.forEach((v, k) => {
|
|
100
|
+
seen.add(k);
|
|
101
|
+
mergedOrders.push(v);
|
|
102
|
+
});
|
|
103
|
+
for (let i = 0; i < baseOrders.length; i++) {
|
|
104
|
+
const v = baseOrders[i];
|
|
105
|
+
const k = JSON.stringify(v.path);
|
|
106
|
+
if (!seen.has(k)) {
|
|
107
|
+
seen.add(k);
|
|
108
|
+
mergedOrders.push(v);
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
return { granularChanges, orders: mergedOrders };
|
|
112
|
+
}
|
|
113
|
+
export {
|
|
114
|
+
preprocessChanges
|
|
115
|
+
};
|
|
@@ -2,12 +2,54 @@ function isPlainObject(o) {
|
|
|
2
2
|
return o && typeof o === "object" && !Array.isArray(o);
|
|
3
3
|
}
|
|
4
4
|
function deepEqual(a, b) {
|
|
5
|
-
|
|
6
|
-
return
|
|
7
|
-
}
|
|
8
|
-
|
|
5
|
+
if (Object.is(a, b)) {
|
|
6
|
+
return true;
|
|
7
|
+
}
|
|
8
|
+
if (typeof a === "function" && typeof b === "function") {
|
|
9
|
+
try {
|
|
10
|
+
return a.toString() === b.toString();
|
|
11
|
+
} catch {
|
|
12
|
+
return false;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
if (typeof a === "function" || typeof b === "function") {
|
|
9
16
|
return false;
|
|
10
17
|
}
|
|
18
|
+
if (a instanceof Date && b instanceof Date) {
|
|
19
|
+
return a.getTime() === b.getTime();
|
|
20
|
+
}
|
|
21
|
+
if (a instanceof RegExp && b instanceof RegExp) {
|
|
22
|
+
return String(a) === String(b);
|
|
23
|
+
}
|
|
24
|
+
if (Array.isArray(a) && Array.isArray(b)) {
|
|
25
|
+
if (a.length !== b.length) {
|
|
26
|
+
return false;
|
|
27
|
+
}
|
|
28
|
+
for (let i = 0; i < a.length; i++) {
|
|
29
|
+
if (!deepEqual(a[i], b[i])) {
|
|
30
|
+
return false;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
return true;
|
|
34
|
+
}
|
|
35
|
+
if (a && b && typeof a === "object" && typeof b === "object") {
|
|
36
|
+
const aKeys = Object.keys(a);
|
|
37
|
+
const bKeys = Object.keys(b);
|
|
38
|
+
if (aKeys.length !== bKeys.length) {
|
|
39
|
+
return false;
|
|
40
|
+
}
|
|
41
|
+
for (let i = 0; i < aKeys.length; i++) {
|
|
42
|
+
const key = aKeys[i];
|
|
43
|
+
if (!Object.hasOwn(b, key)) {
|
|
44
|
+
return false;
|
|
45
|
+
}
|
|
46
|
+
if (!deepEqual(a[key], b[key])) {
|
|
47
|
+
return false;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
return true;
|
|
51
|
+
}
|
|
52
|
+
return false;
|
|
11
53
|
}
|
|
12
54
|
import * as Y from "yjs";
|
|
13
55
|
function getRootMap(ydoc) {
|
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
function isObjectLike(val) {
|
|
2
|
+
return val && typeof val === "object" && !Array.isArray(val);
|
|
3
|
+
}
|
|
4
|
+
function normalizePath(path) {
|
|
5
|
+
if (Array.isArray(path)) {
|
|
6
|
+
return path;
|
|
7
|
+
}
|
|
8
|
+
if (typeof path === "string") {
|
|
9
|
+
return [path];
|
|
10
|
+
}
|
|
11
|
+
return [];
|
|
12
|
+
}
|
|
13
|
+
function getParentPathsFromTuples(tuples = []) {
|
|
14
|
+
const seen = /* @__PURE__ */ new Set();
|
|
15
|
+
const parents = [];
|
|
16
|
+
const META_KEYS = /* @__PURE__ */ new Set([
|
|
17
|
+
"style",
|
|
18
|
+
"class",
|
|
19
|
+
"text",
|
|
20
|
+
"html",
|
|
21
|
+
"content",
|
|
22
|
+
"data",
|
|
23
|
+
"attr",
|
|
24
|
+
"state",
|
|
25
|
+
"scope",
|
|
26
|
+
"define",
|
|
27
|
+
"on",
|
|
28
|
+
"extend",
|
|
29
|
+
"extends",
|
|
30
|
+
"childExtend",
|
|
31
|
+
"childExtends",
|
|
32
|
+
"children",
|
|
33
|
+
"component",
|
|
34
|
+
"context",
|
|
35
|
+
"tag",
|
|
36
|
+
"key",
|
|
37
|
+
"__order",
|
|
38
|
+
"if"
|
|
39
|
+
]);
|
|
40
|
+
for (let i = 0; i < tuples.length; i++) {
|
|
41
|
+
const tuple = tuples[i];
|
|
42
|
+
if (!Array.isArray(tuple) || tuple.length < 2) {
|
|
43
|
+
continue;
|
|
44
|
+
}
|
|
45
|
+
const path = normalizePath(tuple[1]);
|
|
46
|
+
if (!path.length) {
|
|
47
|
+
continue;
|
|
48
|
+
}
|
|
49
|
+
if (path[0] === "schema") {
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
const immediateParent = path.slice(0, -1);
|
|
53
|
+
if (immediateParent.length) {
|
|
54
|
+
const key = JSON.stringify(immediateParent);
|
|
55
|
+
if (!seen.has(key)) {
|
|
56
|
+
seen.add(key);
|
|
57
|
+
parents.push(immediateParent);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
const last = path[path.length - 1];
|
|
61
|
+
if (META_KEYS.has(last) && path.length >= 2) {
|
|
62
|
+
const containerParent = path.slice(0, -2);
|
|
63
|
+
if (containerParent.length) {
|
|
64
|
+
const key2 = JSON.stringify(containerParent);
|
|
65
|
+
if (!seen.has(key2)) {
|
|
66
|
+
seen.add(key2);
|
|
67
|
+
parents.push(containerParent);
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
for (let j = 0; j < path.length; j++) {
|
|
72
|
+
const seg = path[j];
|
|
73
|
+
if (!META_KEYS.has(seg)) {
|
|
74
|
+
continue;
|
|
75
|
+
}
|
|
76
|
+
const containerParent2 = path.slice(0, j);
|
|
77
|
+
if (!containerParent2.length) {
|
|
78
|
+
continue;
|
|
79
|
+
}
|
|
80
|
+
const key3 = JSON.stringify(containerParent2);
|
|
81
|
+
if (!seen.has(key3)) {
|
|
82
|
+
seen.add(key3);
|
|
83
|
+
parents.push(containerParent2);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
return parents;
|
|
88
|
+
}
|
|
89
|
+
function computeOrdersFromState(root, parentPaths = []) {
|
|
90
|
+
if (!root || typeof root.getByPath !== "function") {
|
|
91
|
+
return [];
|
|
92
|
+
}
|
|
93
|
+
const orders = [];
|
|
94
|
+
const EXCLUDE_KEYS = /* @__PURE__ */ new Set(["__order"]);
|
|
95
|
+
for (let i = 0; i < parentPaths.length; i++) {
|
|
96
|
+
const parentPath = parentPaths[i];
|
|
97
|
+
const obj = (() => {
|
|
98
|
+
try {
|
|
99
|
+
return root.getByPath(parentPath);
|
|
100
|
+
} catch {
|
|
101
|
+
return null;
|
|
102
|
+
}
|
|
103
|
+
})();
|
|
104
|
+
if (!isObjectLike(obj)) {
|
|
105
|
+
continue;
|
|
106
|
+
}
|
|
107
|
+
const keys = Object.keys(obj).filter((k) => !EXCLUDE_KEYS.has(k));
|
|
108
|
+
orders.push({ path: parentPath, keys });
|
|
109
|
+
}
|
|
110
|
+
return orders;
|
|
111
|
+
}
|
|
112
|
+
function normaliseSchemaCode(code) {
|
|
113
|
+
if (typeof code !== "string" || !code.length) {
|
|
114
|
+
return "";
|
|
115
|
+
}
|
|
116
|
+
return code.replaceAll("/////n", "\n").replaceAll("/////tilde", "`");
|
|
117
|
+
}
|
|
118
|
+
function parseExportedObject(code) {
|
|
119
|
+
const src = normaliseSchemaCode(code);
|
|
120
|
+
if (!src) {
|
|
121
|
+
return null;
|
|
122
|
+
}
|
|
123
|
+
const body = src.replace(/^\s*export\s+default\s*/u, "return ");
|
|
124
|
+
try {
|
|
125
|
+
return new Function(body)();
|
|
126
|
+
} catch {
|
|
127
|
+
return null;
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
function extractTopLevelKeysFromCode(code) {
|
|
131
|
+
const obj = parseExportedObject(code);
|
|
132
|
+
if (!obj || typeof obj !== "object") {
|
|
133
|
+
return [];
|
|
134
|
+
}
|
|
135
|
+
return Object.keys(obj);
|
|
136
|
+
}
|
|
137
|
+
function computeOrdersForTuples(root, tuples = []) {
|
|
138
|
+
const pendingChildrenByContainer = /* @__PURE__ */ new Map();
|
|
139
|
+
for (let i = 0; i < tuples.length; i++) {
|
|
140
|
+
const t = tuples[i];
|
|
141
|
+
if (!Array.isArray(t)) {
|
|
142
|
+
continue;
|
|
143
|
+
}
|
|
144
|
+
const [action, path] = t;
|
|
145
|
+
const p = normalizePath(path);
|
|
146
|
+
if (!Array.isArray(p) || p.length < 3) {
|
|
147
|
+
continue;
|
|
148
|
+
}
|
|
149
|
+
if (p[0] === "schema") {
|
|
150
|
+
continue;
|
|
151
|
+
}
|
|
152
|
+
const [typeName, containerKey, childKey] = p;
|
|
153
|
+
const containerPath = [typeName, containerKey];
|
|
154
|
+
const key = JSON.stringify(containerPath);
|
|
155
|
+
if (!pendingChildrenByContainer.has(key)) {
|
|
156
|
+
pendingChildrenByContainer.set(key, /* @__PURE__ */ new Set());
|
|
157
|
+
}
|
|
158
|
+
if (action === "update" || action === "set") {
|
|
159
|
+
pendingChildrenByContainer.get(key).add(childKey);
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
const preferredOrderMap = /* @__PURE__ */ new Map();
|
|
163
|
+
for (let i = 0; i < tuples.length; i++) {
|
|
164
|
+
const t = tuples[i];
|
|
165
|
+
if (!Array.isArray(t)) {
|
|
166
|
+
continue;
|
|
167
|
+
}
|
|
168
|
+
const [action, path, value] = t;
|
|
169
|
+
const p = normalizePath(path);
|
|
170
|
+
if (action !== "update" || !Array.isArray(p) || p.length < 3) {
|
|
171
|
+
continue;
|
|
172
|
+
}
|
|
173
|
+
if (p[0] !== "schema") {
|
|
174
|
+
continue;
|
|
175
|
+
}
|
|
176
|
+
const [, type, key] = p;
|
|
177
|
+
const containerPath = [type, key];
|
|
178
|
+
const uses = value && Array.isArray(value.uses) ? value.uses : null;
|
|
179
|
+
const code = value && value.code;
|
|
180
|
+
const obj = (() => {
|
|
181
|
+
try {
|
|
182
|
+
return root && typeof root.getByPath === "function" ? root.getByPath(containerPath) : null;
|
|
183
|
+
} catch {
|
|
184
|
+
return null;
|
|
185
|
+
}
|
|
186
|
+
})();
|
|
187
|
+
if (!obj) {
|
|
188
|
+
continue;
|
|
189
|
+
}
|
|
190
|
+
const present = new Set(Object.keys(obj));
|
|
191
|
+
const EXCLUDE_KEYS = /* @__PURE__ */ new Set(["__order"]);
|
|
192
|
+
const codeKeys = extractTopLevelKeysFromCode(code);
|
|
193
|
+
let resolved = [];
|
|
194
|
+
const pendingKey = JSON.stringify(containerPath);
|
|
195
|
+
const pendingChildren = pendingChildrenByContainer.get(pendingKey) || /* @__PURE__ */ new Set();
|
|
196
|
+
const eligible = /* @__PURE__ */ new Set([...present, ...pendingChildren]);
|
|
197
|
+
if (Array.isArray(codeKeys) && codeKeys.length) {
|
|
198
|
+
resolved = codeKeys.filter((k) => eligible.has(k) && !EXCLUDE_KEYS.has(k));
|
|
199
|
+
}
|
|
200
|
+
if (Array.isArray(uses) && uses.length) {
|
|
201
|
+
for (let u = 0; u < uses.length; u++) {
|
|
202
|
+
const keyName = uses[u];
|
|
203
|
+
if (eligible.has(keyName) && !EXCLUDE_KEYS.has(keyName) && !resolved.includes(keyName)) {
|
|
204
|
+
resolved.push(keyName);
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
if (pendingChildren.size) {
|
|
209
|
+
for (const child of pendingChildren) {
|
|
210
|
+
if (!EXCLUDE_KEYS.has(child) && !resolved.includes(child)) {
|
|
211
|
+
resolved.push(child);
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
if (resolved.length) {
|
|
216
|
+
preferredOrderMap.set(JSON.stringify(containerPath), { path: containerPath, keys: resolved });
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
const parents = getParentPathsFromTuples(tuples);
|
|
220
|
+
const orders = [];
|
|
221
|
+
const seen = /* @__PURE__ */ new Set();
|
|
222
|
+
preferredOrderMap.forEach((v) => {
|
|
223
|
+
const k = JSON.stringify(v.path);
|
|
224
|
+
if (!seen.has(k)) {
|
|
225
|
+
seen.add(k);
|
|
226
|
+
orders.push(v);
|
|
227
|
+
}
|
|
228
|
+
});
|
|
229
|
+
const fallbackOrders = computeOrdersFromState(root, parents);
|
|
230
|
+
for (let i = 0; i < fallbackOrders.length; i++) {
|
|
231
|
+
const v = fallbackOrders[i];
|
|
232
|
+
const k = JSON.stringify(v.path);
|
|
233
|
+
if (seen.has(k)) {
|
|
234
|
+
continue;
|
|
235
|
+
}
|
|
236
|
+
const pending = pendingChildrenByContainer.get(k);
|
|
237
|
+
if (pending && pending.size) {
|
|
238
|
+
const existing = new Set(v.keys);
|
|
239
|
+
for (const child of pending) {
|
|
240
|
+
if (existing.has(child)) {
|
|
241
|
+
continue;
|
|
242
|
+
}
|
|
243
|
+
v.keys.push(child);
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
seen.add(k);
|
|
247
|
+
orders.push(v);
|
|
248
|
+
}
|
|
249
|
+
return orders;
|
|
250
|
+
}
|
|
251
|
+
export {
|
|
252
|
+
computeOrdersForTuples,
|
|
253
|
+
computeOrdersFromState,
|
|
254
|
+
getParentPathsFromTuples
|
|
255
|
+
};
|
|
@@ -223,7 +223,20 @@ const SERVICE_METHODS = {
|
|
|
223
223
|
promoteToAdmin: "admin",
|
|
224
224
|
demoteFromAdmin: "admin",
|
|
225
225
|
// Utility methods
|
|
226
|
-
getHealthStatus: "core"
|
|
226
|
+
getHealthStatus: "core",
|
|
227
|
+
// Screenshot methods
|
|
228
|
+
createScreenshotProject: "screenshot",
|
|
229
|
+
getProjectScreenshots: "screenshot",
|
|
230
|
+
reprocessProjectScreenshots: "screenshot",
|
|
231
|
+
recreateProjectScreenshots: "screenshot",
|
|
232
|
+
deleteProjectScreenshots: "screenshot",
|
|
233
|
+
getThumbnailCandidate: "screenshot",
|
|
234
|
+
updateProjectThumbnail: "screenshot",
|
|
235
|
+
getPageScreenshot: "screenshot",
|
|
236
|
+
getComponentScreenshot: "screenshot",
|
|
237
|
+
getScreenshotByKey: "screenshot",
|
|
238
|
+
getQueueStatistics: "screenshot",
|
|
239
|
+
refreshThumbnail: "screenshot"
|
|
227
240
|
};
|
|
228
241
|
export {
|
|
229
242
|
SERVICE_METHODS
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@symbo.ls/sdk",
|
|
3
|
-
"version": "2.32.
|
|
3
|
+
"version": "2.32.5",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"main": "dist/esm/index.js",
|
|
6
6
|
"module": "dist/esm/index.js",
|
|
@@ -32,6 +32,7 @@
|
|
|
32
32
|
"prepublish": "rimraf -I dist; npm run build; npm run copy:package:cjs;",
|
|
33
33
|
"test:all": "cross-env NODE_ENV=$NODE_ENV npx tape integration-tests/index.js integration-tests/*.test.js | tap-spec",
|
|
34
34
|
"test:smoke": "cross-env NODE_ENV=$NODE_ENV npx tape integration-tests/index.js integration-tests/smoke/*.test.js | tap-spec",
|
|
35
|
+
"test:auth": "cross-env NODE_ENV=$NODE_ENV npx tape integration-tests/index.js integration-tests/auth/*.test.js | tap-spec",
|
|
35
36
|
"test:branch": "cross-env NODE_ENV=$NODE_ENV npx tape integration-tests/index.js integration-tests/branch/*.test.js | tap-spec",
|
|
36
37
|
"test:dataset": "cross-env NODE_ENV=$NODE_ENV npx tape integration-tests/index.js integration-tests/dataset/*.test.js | tap-spec",
|
|
37
38
|
"test:external": "cross-env NODE_ENV=$NODE_ENV npx tape integration-tests/index.js integration-tests/external/*.test.js | tap-spec",
|
|
@@ -45,10 +46,10 @@
|
|
|
45
46
|
"test:user": "cross-env NODE_ENV=$NODE_ENV npx tape integration-tests/index.js integration-tests/user/*.test.js | tap-spec"
|
|
46
47
|
},
|
|
47
48
|
"dependencies": {
|
|
48
|
-
"@domql/element": "^2.32.
|
|
49
|
-
"@domql/utils": "^2.32.
|
|
50
|
-
"@symbo.ls/router": "^2.32.
|
|
51
|
-
"@symbo.ls/socket": "^2.32.
|
|
49
|
+
"@domql/element": "^2.32.5",
|
|
50
|
+
"@domql/utils": "^2.32.5",
|
|
51
|
+
"@symbo.ls/router": "^2.32.5",
|
|
52
|
+
"@symbo.ls/socket": "^2.32.5",
|
|
52
53
|
"acorn": "^8.14.0",
|
|
53
54
|
"acorn-walk": "^8.3.4",
|
|
54
55
|
"dexie": "^4.0.11",
|
|
@@ -70,5 +71,5 @@
|
|
|
70
71
|
"tap-spec": "^5.0.0",
|
|
71
72
|
"tape": "^5.9.0"
|
|
72
73
|
},
|
|
73
|
-
"gitHead": "
|
|
74
|
+
"gitHead": "037257037dfb4f48d5f6ca381ffa2aea8f753669"
|
|
74
75
|
}
|