@symbo.ls/sdk 3.1.2 → 3.2.6
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 +143 -2
- package/dist/cjs/config/environment.js +98 -30
- package/dist/cjs/index.js +144 -24
- package/dist/cjs/services/AdminService.js +351 -0
- package/dist/cjs/services/AuthService.js +738 -305
- package/dist/cjs/services/BaseService.js +158 -6
- package/dist/cjs/services/BranchService.js +484 -0
- package/dist/cjs/services/CollabService.js +743 -0
- package/dist/cjs/services/DnsService.js +340 -0
- package/dist/cjs/services/FeatureFlagService.js +175 -0
- package/dist/cjs/services/FileService.js +201 -0
- package/dist/cjs/services/IntegrationService.js +538 -0
- package/dist/cjs/services/MetricsService.js +62 -0
- package/dist/cjs/services/PaymentService.js +271 -0
- package/dist/cjs/services/PlanService.js +426 -0
- package/dist/cjs/services/ProjectService.js +1207 -0
- package/dist/cjs/services/PullRequestService.js +503 -0
- package/dist/cjs/services/ScreenshotService.js +304 -0
- package/dist/cjs/services/SubscriptionService.js +396 -0
- package/dist/cjs/services/TrackingService.js +661 -0
- package/dist/cjs/services/WaitlistService.js +148 -0
- package/dist/cjs/services/index.js +64 -16
- package/dist/cjs/state/RootStateManager.js +65 -0
- package/dist/cjs/state/rootEventBus.js +74 -0
- package/dist/cjs/utils/CollabClient.js +223 -0
- package/dist/cjs/utils/TokenManager.js +78 -30
- package/dist/cjs/utils/changePreprocessor.js +199 -0
- package/dist/cjs/utils/jsonDiff.js +145 -0
- package/dist/cjs/utils/ordering.js +309 -0
- package/dist/cjs/utils/services.js +301 -103
- package/dist/cjs/utils/validation.js +0 -3
- package/dist/esm/config/environment.js +98 -30
- package/dist/esm/index.js +49505 -8718
- package/dist/esm/services/AdminService.js +1132 -0
- package/dist/esm/services/AuthService.js +1493 -386
- package/dist/esm/services/BaseService.js +757 -6
- package/dist/esm/services/BranchService.js +1265 -0
- package/dist/esm/services/CollabService.js +26895 -0
- package/dist/esm/services/DnsService.js +1121 -0
- package/dist/esm/services/FeatureFlagService.js +956 -0
- package/dist/esm/services/FileService.js +982 -0
- package/dist/esm/services/IntegrationService.js +1319 -0
- package/dist/esm/services/MetricsService.js +843 -0
- package/dist/esm/services/PaymentService.js +1052 -0
- package/dist/esm/services/PlanService.js +1207 -0
- package/dist/esm/services/ProjectService.js +2526 -0
- package/dist/esm/services/PullRequestService.js +1284 -0
- package/dist/esm/services/ScreenshotService.js +1085 -0
- package/dist/esm/services/SubscriptionService.js +1177 -0
- package/dist/esm/services/TrackingService.js +18454 -0
- package/dist/esm/services/WaitlistService.js +929 -0
- package/dist/esm/services/index.js +49062 -8569
- package/dist/esm/state/RootStateManager.js +90 -0
- package/dist/esm/state/rootEventBus.js +56 -0
- package/dist/esm/utils/CollabClient.js +18889 -0
- package/dist/esm/utils/TokenManager.js +78 -30
- package/dist/esm/utils/changePreprocessor.js +542 -0
- package/dist/esm/utils/jsonDiff.js +7011 -0
- package/dist/esm/utils/ordering.js +291 -0
- package/dist/esm/utils/services.js +301 -103
- package/dist/esm/utils/validation.js +116 -50
- package/dist/node/config/environment.js +98 -30
- package/dist/node/index.js +175 -32
- package/dist/node/services/AdminService.js +332 -0
- package/dist/node/services/AuthService.js +742 -310
- package/dist/node/services/BaseService.js +148 -6
- package/dist/node/services/BranchService.js +465 -0
- package/dist/node/services/CollabService.js +724 -0
- package/dist/node/services/DnsService.js +321 -0
- package/dist/node/services/FeatureFlagService.js +156 -0
- package/dist/node/services/FileService.js +182 -0
- package/dist/node/services/IntegrationService.js +519 -0
- package/dist/node/services/MetricsService.js +43 -0
- package/dist/node/services/PaymentService.js +252 -0
- package/dist/node/services/PlanService.js +407 -0
- package/dist/node/services/ProjectService.js +1188 -0
- package/dist/node/services/PullRequestService.js +484 -0
- package/dist/node/services/ScreenshotService.js +285 -0
- package/dist/node/services/SubscriptionService.js +377 -0
- package/dist/node/services/TrackingService.js +632 -0
- package/dist/node/services/WaitlistService.js +129 -0
- package/dist/node/services/index.js +64 -16
- package/dist/node/state/RootStateManager.js +36 -0
- package/dist/node/state/rootEventBus.js +55 -0
- package/dist/node/utils/CollabClient.js +194 -0
- package/dist/node/utils/TokenManager.js +78 -30
- package/dist/node/utils/changePreprocessor.js +180 -0
- package/dist/node/utils/jsonDiff.js +116 -0
- package/dist/node/utils/ordering.js +290 -0
- package/dist/node/utils/services.js +301 -103
- package/dist/node/utils/validation.js +0 -3
- package/package.json +39 -21
- package/src/config/environment.js +99 -28
- package/src/index.js +181 -36
- package/src/services/AdminService.js +374 -0
- package/src/services/AuthService.js +874 -328
- package/src/services/BaseService.js +166 -6
- package/src/services/BranchService.js +536 -0
- package/src/services/CollabService.js +900 -0
- package/src/services/DnsService.js +366 -0
- package/src/services/FeatureFlagService.js +174 -0
- package/src/services/FileService.js +213 -0
- package/src/services/IntegrationService.js +548 -0
- package/src/services/MetricsService.js +40 -0
- package/src/services/PaymentService.js +287 -0
- package/src/services/PlanService.js +468 -0
- package/src/services/ProjectService.js +1366 -0
- package/src/services/PullRequestService.js +537 -0
- package/src/services/ScreenshotService.js +258 -0
- package/src/services/SubscriptionService.js +425 -0
- package/src/services/TrackingService.js +853 -0
- package/src/services/WaitlistService.js +130 -0
- package/src/services/index.js +80 -13
- package/src/services/tests/BranchService/createBranch.test.js +153 -0
- package/src/services/tests/BranchService/deleteBranch.test.js +173 -0
- package/src/services/tests/BranchService/getBranchChanges.test.js +146 -0
- package/src/services/tests/BranchService/listBranches.test.js +87 -0
- package/src/services/tests/BranchService/mergeBranch.test.js +210 -0
- package/src/services/tests/BranchService/publishVersion.test.js +183 -0
- package/src/services/tests/BranchService/renameBranch.test.js +240 -0
- package/src/services/tests/BranchService/resetBranch.test.js +152 -0
- package/src/services/tests/FeatureFlagService/adminFeatureFlags.test.js +67 -0
- package/src/services/tests/FeatureFlagService/getFeatureFlags.test.js +75 -0
- package/src/services/tests/FileService/createFileFormData.test.js +74 -0
- package/src/services/tests/FileService/getFileUrl.test.js +69 -0
- package/src/services/tests/FileService/updateProjectIcon.test.js +109 -0
- package/src/services/tests/FileService/uploadDocument.test.js +36 -0
- package/src/services/tests/FileService/uploadFile.test.js +78 -0
- package/src/services/tests/FileService/uploadFileWithValidation.test.js +114 -0
- package/src/services/tests/FileService/uploadImage.test.js +36 -0
- package/src/services/tests/FileService/uploadMultipleFiles.test.js +111 -0
- package/src/services/tests/FileService/validateFile.test.js +63 -0
- package/src/services/tests/PlanService/createPlan.test.js +104 -0
- package/src/services/tests/PlanService/createPlanWithValidation.test.js +523 -0
- package/src/services/tests/PlanService/deletePlan.test.js +92 -0
- package/src/services/tests/PlanService/getActivePlans.test.js +123 -0
- package/src/services/tests/PlanService/getAdminPlans.test.js +84 -0
- package/src/services/tests/PlanService/getPlan.test.js +50 -0
- package/src/services/tests/PlanService/getPlanByKey.test.js +109 -0
- package/src/services/tests/PlanService/getPlanWithValidation.test.js +85 -0
- package/src/services/tests/PlanService/getPlans.test.js +53 -0
- package/src/services/tests/PlanService/getPlansByPriceRange.test.js +109 -0
- package/src/services/tests/PlanService/getPlansWithValidation.test.js +48 -0
- package/src/services/tests/PlanService/initializePlans.test.js +75 -0
- package/src/services/tests/PlanService/updatePlan.test.js +111 -0
- package/src/services/tests/PlanService/updatePlanWithValidation.test.js +556 -0
- package/src/state/RootStateManager.js +76 -0
- package/src/state/rootEventBus.js +67 -0
- package/src/utils/CollabClient.js +248 -0
- package/src/utils/TokenManager.js +88 -33
- package/src/utils/changePreprocessor.js +239 -0
- package/src/utils/jsonDiff.js +144 -0
- package/src/utils/ordering.js +271 -0
- package/src/utils/services.js +326 -107
- package/src/utils/validation.js +0 -3
- package/dist/cjs/services/AIService.js +0 -155
- package/dist/cjs/services/BasedService.js +0 -1185
- package/dist/cjs/services/CoreService.js +0 -1751
- package/dist/cjs/services/SocketIOService.js +0 -307
- package/dist/cjs/services/SocketService.js +0 -161
- package/dist/cjs/services/SymstoryService.js +0 -571
- package/dist/cjs/utils/basedQuerys.js +0 -181
- package/dist/cjs/utils/symstoryClient.js +0 -259
- package/dist/esm/services/AIService.js +0 -185
- package/dist/esm/services/BasedService.js +0 -5278
- package/dist/esm/services/CoreService.js +0 -2264
- package/dist/esm/services/SocketIOService.js +0 -470
- package/dist/esm/services/SocketService.js +0 -191
- package/dist/esm/services/SymstoryService.js +0 -7041
- package/dist/esm/utils/basedQuerys.js +0 -163
- package/dist/esm/utils/symstoryClient.js +0 -370
- package/dist/node/services/AIService.js +0 -136
- package/dist/node/services/BasedService.js +0 -1156
- package/dist/node/services/CoreService.js +0 -1722
- package/dist/node/services/SocketIOService.js +0 -278
- package/dist/node/services/SocketService.js +0 -142
- package/dist/node/services/SymstoryService.js +0 -542
- package/dist/node/utils/basedQuerys.js +0 -162
- package/dist/node/utils/symstoryClient.js +0 -230
- package/src/services/AIService.js +0 -150
- package/src/services/BasedService.js +0 -1301
- package/src/services/CoreService.js +0 -1943
- package/src/services/SocketIOService.js +0 -334
- package/src/services/SocketService.js +0 -168
- package/src/services/SymstoryService.js +0 -649
- package/src/utils/basedQuerys.js +0 -164
- package/src/utils/symstoryClient.js +0 -252
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __export = (target, all) => {
|
|
6
|
+
for (var name in all)
|
|
7
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
+
};
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
14
|
+
}
|
|
15
|
+
return to;
|
|
16
|
+
};
|
|
17
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
|
+
var WaitlistService_exports = {};
|
|
19
|
+
__export(WaitlistService_exports, {
|
|
20
|
+
WaitlistService: () => WaitlistService
|
|
21
|
+
});
|
|
22
|
+
module.exports = __toCommonJS(WaitlistService_exports);
|
|
23
|
+
var import_BaseService = require("./BaseService.js");
|
|
24
|
+
class WaitlistService extends import_BaseService.BaseService {
|
|
25
|
+
// ==================== WAITLIST METHODS ====================
|
|
26
|
+
/**
|
|
27
|
+
* Join a waitlist campaign (public).
|
|
28
|
+
*
|
|
29
|
+
* Mirrors: POST /waitlist (WaitlistController.join)
|
|
30
|
+
*/
|
|
31
|
+
async joinWaitlist(data = {}) {
|
|
32
|
+
this._requireReady("joinWaitlist");
|
|
33
|
+
if (!data || typeof data !== "object") {
|
|
34
|
+
throw new Error("Waitlist join payload is required");
|
|
35
|
+
}
|
|
36
|
+
if (!data.email) {
|
|
37
|
+
throw new Error("Email is required");
|
|
38
|
+
}
|
|
39
|
+
try {
|
|
40
|
+
const response = await this._request("/waitlist", {
|
|
41
|
+
method: "POST",
|
|
42
|
+
body: JSON.stringify(data),
|
|
43
|
+
methodName: "joinWaitlist"
|
|
44
|
+
});
|
|
45
|
+
if (response.success) {
|
|
46
|
+
return response.data;
|
|
47
|
+
}
|
|
48
|
+
throw new Error(response.message);
|
|
49
|
+
} catch (error) {
|
|
50
|
+
throw new Error(`Failed to join waitlist: ${error.message}`, { cause: error });
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* List waitlist entries (admin).
|
|
55
|
+
*
|
|
56
|
+
* Mirrors: GET /waitlist (WaitlistController.list)
|
|
57
|
+
*/
|
|
58
|
+
async listWaitlistEntries(options = {}) {
|
|
59
|
+
this._requireReady("listWaitlistEntries");
|
|
60
|
+
const {
|
|
61
|
+
campaignKey,
|
|
62
|
+
status,
|
|
63
|
+
search,
|
|
64
|
+
page,
|
|
65
|
+
limit
|
|
66
|
+
} = options || {};
|
|
67
|
+
const queryParams = new URLSearchParams();
|
|
68
|
+
if (campaignKey != null) {
|
|
69
|
+
queryParams.append("campaignKey", String(campaignKey));
|
|
70
|
+
}
|
|
71
|
+
if (status != null) {
|
|
72
|
+
queryParams.append("status", String(status));
|
|
73
|
+
}
|
|
74
|
+
if (search != null) {
|
|
75
|
+
queryParams.append("search", String(search));
|
|
76
|
+
}
|
|
77
|
+
if (page != null) {
|
|
78
|
+
queryParams.append("page", String(page));
|
|
79
|
+
}
|
|
80
|
+
if (limit != null) {
|
|
81
|
+
queryParams.append("limit", String(limit));
|
|
82
|
+
}
|
|
83
|
+
const queryString = queryParams.toString();
|
|
84
|
+
const url = `/waitlist${queryString ? `?${queryString}` : ""}`;
|
|
85
|
+
try {
|
|
86
|
+
const response = await this._request(url, {
|
|
87
|
+
method: "GET",
|
|
88
|
+
methodName: "listWaitlistEntries"
|
|
89
|
+
});
|
|
90
|
+
if (response.success) {
|
|
91
|
+
return response.data;
|
|
92
|
+
}
|
|
93
|
+
throw new Error(response.message);
|
|
94
|
+
} catch (error) {
|
|
95
|
+
throw new Error(`Failed to list waitlist entries: ${error.message}`, { cause: error });
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Update a waitlist entry (admin).
|
|
100
|
+
*
|
|
101
|
+
* Mirrors: PATCH /waitlist/:id (WaitlistController.update)
|
|
102
|
+
*/
|
|
103
|
+
async updateWaitlistEntry(id, update = {}) {
|
|
104
|
+
this._requireReady("updateWaitlistEntry");
|
|
105
|
+
if (!id) {
|
|
106
|
+
throw new Error("Waitlist entry ID is required");
|
|
107
|
+
}
|
|
108
|
+
if (!update || typeof update !== "object") {
|
|
109
|
+
throw new Error("Update payload is required");
|
|
110
|
+
}
|
|
111
|
+
try {
|
|
112
|
+
const response = await this._request(`/waitlist/${id}`, {
|
|
113
|
+
method: "PATCH",
|
|
114
|
+
body: JSON.stringify(update),
|
|
115
|
+
methodName: "updateWaitlistEntry"
|
|
116
|
+
});
|
|
117
|
+
if (response.success) {
|
|
118
|
+
return response.data;
|
|
119
|
+
}
|
|
120
|
+
throw new Error(response.message);
|
|
121
|
+
} catch (error) {
|
|
122
|
+
throw new Error(`Failed to update waitlist entry: ${error.message}`, { cause: error });
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Send an invitation email for a waitlist entry (admin).
|
|
127
|
+
*
|
|
128
|
+
* Mirrors: POST /waitlist/:id/invite (WaitlistController.invite)
|
|
129
|
+
*/
|
|
130
|
+
async inviteWaitlistEntry(id) {
|
|
131
|
+
this._requireReady("inviteWaitlistEntry");
|
|
132
|
+
if (!id) {
|
|
133
|
+
throw new Error("Waitlist entry ID is required");
|
|
134
|
+
}
|
|
135
|
+
try {
|
|
136
|
+
const response = await this._request(`/waitlist/${id}/invite`, {
|
|
137
|
+
method: "POST",
|
|
138
|
+
methodName: "inviteWaitlistEntry"
|
|
139
|
+
});
|
|
140
|
+
if (response.success) {
|
|
141
|
+
return response.data;
|
|
142
|
+
}
|
|
143
|
+
throw new Error(response.message);
|
|
144
|
+
} catch (error) {
|
|
145
|
+
throw new Error(`Failed to invite waitlist entry: ${error.message}`, { cause: error });
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
}
|
|
@@ -17,26 +17,74 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
17
17
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
18
|
var services_exports = {};
|
|
19
19
|
__export(services_exports, {
|
|
20
|
-
|
|
20
|
+
AdminService: () => import_AdminService.AdminService,
|
|
21
21
|
AuthService: () => import_AuthService.AuthService,
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
22
|
+
BranchService: () => import_BranchService.BranchService,
|
|
23
|
+
CollabService: () => import_CollabService.CollabService,
|
|
24
|
+
DnsService: () => import_DnsService.DnsService,
|
|
25
|
+
FeatureFlagService: () => import_FeatureFlagService.FeatureFlagService,
|
|
26
|
+
FileService: () => import_FileService.FileService,
|
|
27
|
+
IntegrationService: () => import_IntegrationService.IntegrationService,
|
|
28
|
+
MetricsService: () => import_MetricsService.MetricsService,
|
|
29
|
+
PaymentService: () => import_PaymentService.PaymentService,
|
|
30
|
+
PlanService: () => import_PlanService.PlanService,
|
|
31
|
+
ProjectService: () => import_ProjectService.ProjectService,
|
|
32
|
+
PullRequestService: () => import_PullRequestService.PullRequestService,
|
|
33
|
+
ScreenshotService: () => import_ScreenshotService.ScreenshotService,
|
|
34
|
+
SubscriptionService: () => import_SubscriptionService.SubscriptionService,
|
|
35
|
+
TrackingService: () => import_TrackingService.TrackingService,
|
|
36
|
+
WaitlistService: () => import_WaitlistService.WaitlistService,
|
|
37
|
+
createAdminService: () => createAdminService,
|
|
26
38
|
createAuthService: () => createAuthService,
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
39
|
+
createBranchService: () => createBranchService,
|
|
40
|
+
createCollabService: () => createCollabService,
|
|
41
|
+
createDnsService: () => createDnsService,
|
|
42
|
+
createFeatureFlagService: () => createFeatureFlagService,
|
|
43
|
+
createFileService: () => createFileService,
|
|
44
|
+
createIntegrationService: () => createIntegrationService,
|
|
45
|
+
createMetricsService: () => createMetricsService,
|
|
46
|
+
createPaymentService: () => createPaymentService,
|
|
47
|
+
createPlanService: () => createPlanService,
|
|
48
|
+
createProjectService: () => createProjectService,
|
|
49
|
+
createPullRequestService: () => createPullRequestService,
|
|
50
|
+
createScreenshotService: () => createScreenshotService,
|
|
51
|
+
createSubscriptionService: () => createSubscriptionService,
|
|
52
|
+
createTrackingService: () => createTrackingService,
|
|
53
|
+
createWaitlistService: () => createWaitlistService
|
|
30
54
|
});
|
|
31
55
|
module.exports = __toCommonJS(services_exports);
|
|
32
|
-
var import_SymstoryService = require("./SymstoryService.js");
|
|
33
56
|
var import_AuthService = require("./AuthService.js");
|
|
34
|
-
var
|
|
35
|
-
var
|
|
36
|
-
var
|
|
57
|
+
var import_CollabService = require("./CollabService.js");
|
|
58
|
+
var import_ProjectService = require("./ProjectService.js");
|
|
59
|
+
var import_PlanService = require("./PlanService.js");
|
|
60
|
+
var import_SubscriptionService = require("./SubscriptionService.js");
|
|
61
|
+
var import_FileService = require("./FileService.js");
|
|
62
|
+
var import_PaymentService = require("./PaymentService.js");
|
|
63
|
+
var import_DnsService = require("./DnsService.js");
|
|
64
|
+
var import_BranchService = require("./BranchService.js");
|
|
65
|
+
var import_PullRequestService = require("./PullRequestService.js");
|
|
66
|
+
var import_AdminService = require("./AdminService.js");
|
|
67
|
+
var import_ScreenshotService = require("./ScreenshotService.js");
|
|
68
|
+
var import_TrackingService = require("./TrackingService.js");
|
|
69
|
+
var import_WaitlistService = require("./WaitlistService.js");
|
|
70
|
+
var import_MetricsService = require("./MetricsService.js");
|
|
71
|
+
var import_IntegrationService = require("./IntegrationService.js");
|
|
72
|
+
var import_FeatureFlagService = require("./FeatureFlagService.js");
|
|
37
73
|
const createService = (ServiceClass, config) => new ServiceClass(config);
|
|
38
|
-
const createSymstoryService = (config) => createService(import_SymstoryService.SymstoryService, config);
|
|
39
74
|
const createAuthService = (config) => createService(import_AuthService.AuthService, config);
|
|
40
|
-
const
|
|
41
|
-
const
|
|
42
|
-
const
|
|
75
|
+
const createCollabService = (config) => createService(import_CollabService.CollabService, config);
|
|
76
|
+
const createProjectService = (config) => createService(import_ProjectService.ProjectService, config);
|
|
77
|
+
const createPlanService = (config) => createService(import_PlanService.PlanService, config);
|
|
78
|
+
const createSubscriptionService = (config) => createService(import_SubscriptionService.SubscriptionService, config);
|
|
79
|
+
const createFileService = (config) => createService(import_FileService.FileService, config);
|
|
80
|
+
const createPaymentService = (config) => createService(import_PaymentService.PaymentService, config);
|
|
81
|
+
const createDnsService = (config) => createService(import_DnsService.DnsService, config);
|
|
82
|
+
const createBranchService = (config) => createService(import_BranchService.BranchService, config);
|
|
83
|
+
const createPullRequestService = (config) => createService(import_PullRequestService.PullRequestService, config);
|
|
84
|
+
const createAdminService = (config) => createService(import_AdminService.AdminService, config);
|
|
85
|
+
const createScreenshotService = (config) => createService(import_ScreenshotService.ScreenshotService, config);
|
|
86
|
+
const createTrackingService = (config) => createService(import_TrackingService.TrackingService, config);
|
|
87
|
+
const createWaitlistService = (config) => createService(import_WaitlistService.WaitlistService, config);
|
|
88
|
+
const createMetricsService = (config) => createService(import_MetricsService.MetricsService, config);
|
|
89
|
+
const createIntegrationService = (config) => createService(import_IntegrationService.IntegrationService, config);
|
|
90
|
+
const createFeatureFlagService = (config) => createService(import_FeatureFlagService.FeatureFlagService, config);
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
21
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
22
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
23
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
24
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
25
|
+
mod
|
|
26
|
+
));
|
|
27
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
28
|
+
var RootStateManager_exports = {};
|
|
29
|
+
__export(RootStateManager_exports, {
|
|
30
|
+
RootStateManager: () => RootStateManager
|
|
31
|
+
});
|
|
32
|
+
module.exports = __toCommonJS(RootStateManager_exports);
|
|
33
|
+
var utils = __toESM(require("@domql/utils"), 1);
|
|
34
|
+
var import_rootEventBus = require("./rootEventBus.js");
|
|
35
|
+
const { isFunction } = utils.default || utils;
|
|
36
|
+
class RootStateManager {
|
|
37
|
+
constructor(rootState) {
|
|
38
|
+
this._rootState = rootState;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Apply change tuples to the root state using the built-in setPathCollection
|
|
42
|
+
* of Symbo.ls APP state tree.
|
|
43
|
+
*
|
|
44
|
+
* @param {Array} changes – eg. ['update', ['foo'], 'bar']
|
|
45
|
+
* @param {Object} opts – forwarded to setPathCollection
|
|
46
|
+
*/
|
|
47
|
+
async applyChanges(changes = [], opts = {}) {
|
|
48
|
+
if (!this._rootState || !isFunction(this._rootState.setPathCollection)) {
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
const result = await this._rootState.setPathCollection(changes, {
|
|
52
|
+
preventUpdate: true,
|
|
53
|
+
...opts
|
|
54
|
+
});
|
|
55
|
+
return result;
|
|
56
|
+
}
|
|
57
|
+
setVersion(v) {
|
|
58
|
+
if (this._rootState) {
|
|
59
|
+
this._rootState.version = v;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
get root() {
|
|
63
|
+
return this._rootState;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
4
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
|
+
var __export = (target, all) => {
|
|
6
|
+
for (var name in all)
|
|
7
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
8
|
+
};
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
13
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
14
|
+
}
|
|
15
|
+
return to;
|
|
16
|
+
};
|
|
17
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
18
|
+
var rootEventBus_exports = {};
|
|
19
|
+
__export(rootEventBus_exports, {
|
|
20
|
+
default: () => rootEventBus_default,
|
|
21
|
+
rootBus: () => rootBus
|
|
22
|
+
});
|
|
23
|
+
module.exports = __toCommonJS(rootEventBus_exports);
|
|
24
|
+
const getGlobalBus = () => {
|
|
25
|
+
if (globalThis.__SMBLS_ROOT_BUS__) {
|
|
26
|
+
return globalThis.__SMBLS_ROOT_BUS__;
|
|
27
|
+
}
|
|
28
|
+
const events = {};
|
|
29
|
+
const lastPayloads = {};
|
|
30
|
+
const bus = {
|
|
31
|
+
on(event, handler) {
|
|
32
|
+
(events[event] ||= []).push(handler);
|
|
33
|
+
if (Object.hasOwn(lastPayloads, event)) {
|
|
34
|
+
try {
|
|
35
|
+
handler(lastPayloads[event]);
|
|
36
|
+
} catch (err) {
|
|
37
|
+
console.error("[rootBus] handler error for (replay)", event, err);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
},
|
|
41
|
+
off(event, handler) {
|
|
42
|
+
const list = events[event];
|
|
43
|
+
if (!list) {
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
const idx = list.indexOf(handler);
|
|
47
|
+
if (idx !== -1) {
|
|
48
|
+
list.splice(idx, 1);
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
emit(event, payload) {
|
|
52
|
+
lastPayloads[event] = payload;
|
|
53
|
+
const list = events[event];
|
|
54
|
+
if (!list || !list.length) {
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
list.slice().forEach((fn) => {
|
|
58
|
+
try {
|
|
59
|
+
fn(payload);
|
|
60
|
+
} catch (err) {
|
|
61
|
+
console.error("[rootBus] handler error for", event, err);
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
Object.defineProperty(bus, "_listeners", {
|
|
67
|
+
value: events,
|
|
68
|
+
enumerable: false
|
|
69
|
+
});
|
|
70
|
+
globalThis.__SMBLS_ROOT_BUS__ = bus;
|
|
71
|
+
return bus;
|
|
72
|
+
};
|
|
73
|
+
const rootBus = getGlobalBus();
|
|
74
|
+
var rootEventBus_default = rootBus;
|
|
@@ -0,0 +1,223 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
6
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all)
|
|
9
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
10
|
+
};
|
|
11
|
+
var __copyProps = (to, from, except, desc) => {
|
|
12
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
13
|
+
for (let key of __getOwnPropNames(from))
|
|
14
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
15
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
16
|
+
}
|
|
17
|
+
return to;
|
|
18
|
+
};
|
|
19
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
20
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
21
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
22
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
23
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
24
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
25
|
+
mod
|
|
26
|
+
));
|
|
27
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
28
|
+
var CollabClient_exports = {};
|
|
29
|
+
__export(CollabClient_exports, {
|
|
30
|
+
CollabClient: () => CollabClient
|
|
31
|
+
});
|
|
32
|
+
module.exports = __toCommonJS(CollabClient_exports);
|
|
33
|
+
var import_socket = require("socket.io-client");
|
|
34
|
+
var Y = __toESM(require("yjs"), 1);
|
|
35
|
+
var import_nanoid = require("nanoid");
|
|
36
|
+
var import_environment = __toESM(require("../config/environment.js"), 1);
|
|
37
|
+
var import_jsonDiff = require("./jsonDiff.js");
|
|
38
|
+
class CollabClient {
|
|
39
|
+
/* public fields */
|
|
40
|
+
socket = null;
|
|
41
|
+
ydoc = null;
|
|
42
|
+
branch = "main";
|
|
43
|
+
live = false;
|
|
44
|
+
projectId = null;
|
|
45
|
+
jwt = null;
|
|
46
|
+
/* private state */
|
|
47
|
+
_buffer = [];
|
|
48
|
+
_flushTimer = null;
|
|
49
|
+
_clientId = (0, import_nanoid.nanoid)();
|
|
50
|
+
_outboxStore = createMemoryOutbox();
|
|
51
|
+
// Dexie table fallback
|
|
52
|
+
_readyResolve;
|
|
53
|
+
ready = new Promise((res) => this._readyResolve = res);
|
|
54
|
+
constructor({ jwt, projectId, branch = "main", live = false }) {
|
|
55
|
+
Object.assign(this, { jwt, projectId, branch, live });
|
|
56
|
+
this.ydoc = new Y.Doc();
|
|
57
|
+
const hasIndexedDB = typeof globalThis.indexedDB !== "undefined";
|
|
58
|
+
if (typeof window === "undefined" || !hasIndexedDB) {
|
|
59
|
+
console.log("[CollabClient] IndexedDB not available \u2013 skipping offline persistence");
|
|
60
|
+
} else {
|
|
61
|
+
import("y-indexeddb").then(({ IndexeddbPersistence }) => {
|
|
62
|
+
new IndexeddbPersistence(`${projectId}:${branch}`, this.ydoc);
|
|
63
|
+
}).catch((err) => {
|
|
64
|
+
console.warn("[CollabClient] Failed to load IndexeddbPersistence:", err);
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
if (typeof window !== "undefined" && hasIndexedDB) {
|
|
68
|
+
createDexieOutbox(`${projectId}:${branch}`).then((outboxStore) => {
|
|
69
|
+
this._outboxStore = outboxStore;
|
|
70
|
+
}).catch((err) => {
|
|
71
|
+
console.warn("[CollabClient] Failed to load Dexie:", err);
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
this.socket = (0, import_socket.io)(import_environment.default.socketUrl, {
|
|
75
|
+
path: "/collab-socket",
|
|
76
|
+
transports: ["websocket"],
|
|
77
|
+
auth: { token: jwt, projectId, branch, live },
|
|
78
|
+
reconnectionAttempts: Infinity,
|
|
79
|
+
reconnectionDelayMax: 4e3
|
|
80
|
+
});
|
|
81
|
+
this.socket.on("snapshot", this._onSnapshot).on("ops", this._onOps).on("commit", this._onCommit).on("liveMode", this._onLiveMode).on("connect", this._onConnect).on("error", this._onError);
|
|
82
|
+
this._prevJson = this.ydoc.getMap("root").toJSON();
|
|
83
|
+
this.ydoc.on("afterTransaction", (tr) => {
|
|
84
|
+
if (tr.origin === "remote") {
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
const currentJson = this.ydoc.getMap("root").toJSON();
|
|
88
|
+
const ops = (0, import_jsonDiff.diffJson)(this._prevJson, currentJson);
|
|
89
|
+
this._prevJson = currentJson;
|
|
90
|
+
if (!ops.length) {
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
this._queueOps(ops);
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
/* ---------- public helpers ---------- */
|
|
97
|
+
toggleLive(flag) {
|
|
98
|
+
this.socket.emit("toggleLive", Boolean(flag));
|
|
99
|
+
}
|
|
100
|
+
sendCursor(data) {
|
|
101
|
+
this.socket.emit("cursor", data);
|
|
102
|
+
}
|
|
103
|
+
sendPresence(d) {
|
|
104
|
+
this.socket.emit("presence", d);
|
|
105
|
+
}
|
|
106
|
+
/* ---------- private handlers ---------- */
|
|
107
|
+
_onSnapshot = ({
|
|
108
|
+
data
|
|
109
|
+
/* Uint8Array */
|
|
110
|
+
}) => {
|
|
111
|
+
if (Array.isArray(data) ? data.length : data && data.byteLength) {
|
|
112
|
+
Y.applyUpdate(this.ydoc, Uint8Array.from(data));
|
|
113
|
+
} else {
|
|
114
|
+
console.warn("[collab] Received empty snapshot \u2013 skipping applyUpdate");
|
|
115
|
+
}
|
|
116
|
+
this._prevJson = this.ydoc.getMap("root").toJSON();
|
|
117
|
+
if (typeof this._readyResolve === "function") {
|
|
118
|
+
this._readyResolve();
|
|
119
|
+
this._readyResolve = null;
|
|
120
|
+
}
|
|
121
|
+
};
|
|
122
|
+
_onOps = ({ changes }) => {
|
|
123
|
+
(0, import_jsonDiff.applyOpsToJson)(changes, this.ydoc);
|
|
124
|
+
this._prevJson = this.ydoc.getMap("root").toJSON();
|
|
125
|
+
};
|
|
126
|
+
_onCommit = async ({ version }) => {
|
|
127
|
+
await this._outboxStore.clear();
|
|
128
|
+
console.info("[collab] committed", version);
|
|
129
|
+
};
|
|
130
|
+
_onConnect = async () => {
|
|
131
|
+
if (typeof this._readyResolve === "function") {
|
|
132
|
+
this._readyResolve();
|
|
133
|
+
this._readyResolve = null;
|
|
134
|
+
}
|
|
135
|
+
const queued = await this._outboxStore.toArray();
|
|
136
|
+
if (queued.length) {
|
|
137
|
+
this.socket.emit("ops", {
|
|
138
|
+
changes: queued.flatMap((e) => e.ops),
|
|
139
|
+
ts: Date.now(),
|
|
140
|
+
clientId: this._clientId
|
|
141
|
+
});
|
|
142
|
+
await this._outboxStore.clear();
|
|
143
|
+
}
|
|
144
|
+
};
|
|
145
|
+
/* ---------- buffering & debounce ---------- */
|
|
146
|
+
_queueOps(ops) {
|
|
147
|
+
this._buffer.push(...ops);
|
|
148
|
+
this._outboxStore.put({ id: (0, import_nanoid.nanoid)(), ops });
|
|
149
|
+
if (this.live && this.socket.connected) {
|
|
150
|
+
this._flushNow();
|
|
151
|
+
} else {
|
|
152
|
+
clearTimeout(this._flushTimer);
|
|
153
|
+
this._flushTimer = setTimeout(() => this._flushNow(), 40);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
_flushNow() {
|
|
157
|
+
if (!this._buffer.length || !this.socket.connected) {
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
160
|
+
this.socket.emit("ops", {
|
|
161
|
+
changes: this._buffer,
|
|
162
|
+
ts: Date.now(),
|
|
163
|
+
clientId: this._clientId
|
|
164
|
+
});
|
|
165
|
+
this._buffer.length = 0;
|
|
166
|
+
}
|
|
167
|
+
dispose() {
|
|
168
|
+
var _a;
|
|
169
|
+
clearTimeout(this._flushTimer);
|
|
170
|
+
this._flushTimer = null;
|
|
171
|
+
this._buffer.length = 0;
|
|
172
|
+
if ((_a = this._outboxStore) == null ? void 0 : _a.clear) {
|
|
173
|
+
try {
|
|
174
|
+
const result = this._outboxStore.clear();
|
|
175
|
+
if (result && typeof result.catch === "function") {
|
|
176
|
+
result.catch(() => {
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
} catch (error) {
|
|
180
|
+
console.warn("[CollabClient] Failed to clear outbox store during dispose:", error);
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
if (this.socket) {
|
|
184
|
+
this.socket.off("snapshot", this._onSnapshot);
|
|
185
|
+
this.socket.off("ops", this._onOps);
|
|
186
|
+
this.socket.off("commit", this._onCommit);
|
|
187
|
+
this.socket.off("liveMode", this._onLiveMode);
|
|
188
|
+
this.socket.off("connect", this._onConnect);
|
|
189
|
+
this.socket.off("error", this._onError);
|
|
190
|
+
this.socket.removeAllListeners();
|
|
191
|
+
this.socket.disconnect();
|
|
192
|
+
this.socket = null;
|
|
193
|
+
}
|
|
194
|
+
if (this.ydoc) {
|
|
195
|
+
this.ydoc.destroy();
|
|
196
|
+
this.ydoc = null;
|
|
197
|
+
}
|
|
198
|
+
if (typeof this._readyResolve === "function") {
|
|
199
|
+
this._readyResolve();
|
|
200
|
+
this._readyResolve = null;
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
_onLiveMode = (flag) => {
|
|
204
|
+
this.live = flag;
|
|
205
|
+
};
|
|
206
|
+
_onError = (e) => {
|
|
207
|
+
console.warn("[collab] socket error", e);
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
function createMemoryOutbox() {
|
|
211
|
+
const store = /* @__PURE__ */ new Map();
|
|
212
|
+
return {
|
|
213
|
+
put: (item) => store.set(item.id, item),
|
|
214
|
+
toArray: () => Array.from(store.values()),
|
|
215
|
+
clear: () => store.clear()
|
|
216
|
+
};
|
|
217
|
+
}
|
|
218
|
+
async function createDexieOutbox(name) {
|
|
219
|
+
const { default: Dexie } = await import("dexie");
|
|
220
|
+
const db = new Dexie(`collab-${name}`);
|
|
221
|
+
db.version(1).stores({ outbox: "id, ops" });
|
|
222
|
+
return db.table("outbox");
|
|
223
|
+
}
|