appscms-tools-theme 5.1.8 → 5.2.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.
- checksums.yaml +4 -4
- data/_data/.DS_Store +0 -0
- data/_data/aitools/en/ai-article-writer.json +184 -0
- data/_data/aitools/en/all-in-one-social-post.json +217 -0
- data/_data/aitools/en/amazon-product-bullet-points-generator.json +224 -0
- data/_data/aitools/en/amazon-product-description-generator.json +237 -0
- data/_data/aitools/en/blog-conclusion-generator.json +253 -0
- data/_data/aitools/en/blog-content-calendar.json +232 -0
- data/_data/aitools/en/blog-introduction-generator.json +246 -0
- data/_data/aitools/en/blog-outline-generator.json +232 -0
- data/_data/aitools/en/blog-section-generator.json +253 -0
- data/_data/aitools/en/blog-title-generator.json +232 -0
- data/_data/aitools/en/blog-topic-ideas.json +232 -0
- data/_data/aitools/en/brand-name-generator.json +215 -0
- data/_data/aitools/en/caption-generator.json +271 -0
- data/_data/aitools/en/engagement-post-generator.json +251 -0
- data/_data/aitools/en/facebook-post.json +232 -0
- data/_data/aitools/en/hidden-fact-finder.json +232 -0
- data/_data/aitools/en/human-written-blog-post.json +232 -0
- data/_data/aitools/en/instagram-bio-generator.json +246 -0
- data/_data/aitools/en/instagram-caption.json +232 -0
- data/_data/aitools/en/instagram-carousel.json +250 -0
- data/_data/aitools/en/instagram-hashtag-generator.json +246 -0
- data/_data/aitools/en/instagram-name-generator.json +239 -0
- data/_data/aitools/en/instagram-threads-generator.json +239 -0
- data/_data/aitools/en/interactive-content-creator.json +252 -0
- data/_data/aitools/en/linkedin-hashtag-generator.json +239 -0
- data/_data/aitools/en/linkedin-post.json +232 -0
- data/_data/aitools/en/motivational-posts.json +239 -0
- data/_data/aitools/en/pinterest-pin.json +217 -0
- data/_data/aitools/en/platform-specific-content-generator.json +246 -0
- data/_data/aitools/en/product-description.json +222 -0
- data/_data/aitools/en/quick-article-writer.json +253 -0
- data/_data/aitools/en/replies-for-facebook.json +239 -0
- data/_data/aitools/en/replies-for-instagram.json +239 -0
- data/_data/aitools/en/replies-for-linkedin.json +239 -0
- data/_data/aitools/en/replies-for-twitter.json +239 -0
- data/_data/aitools/en/rewrite-article-with-keywords.json +246 -0
- data/_data/aitools/en/script-for-instagram-reel.json +246 -0
- data/_data/aitools/en/script-for-tiktok-video.json +246 -0
- data/_data/aitools/en/seo-optimized-blog-post.json +239 -0
- data/_data/aitools/en/snapchat-caption-maker.json +245 -0
- data/_data/aitools/en/social-media-bio-creator.json +274 -0
- data/_data/aitools/en/social-media-bio-generator.json +246 -0
- data/_data/aitools/en/social-media-calendar.json +250 -0
- data/_data/aitools/en/tiktok-caption.json +232 -0
- data/_data/aitools/en/tiktok-username-generator.json +239 -0
- data/_data/aitools/en/twitter-poll-generator.json +250 -0
- data/_data/aitools/en/twitter-post.json +272 -0
- data/_data/contenttool/en/features.json +217 -10
- data/_includes/.DS_Store +0 -0
- data/_includes/appscms/.DS_Store +0 -0
- data/_includes/appscms/customblog/pageRelatedPosts.html +1 -1
- data/_layouts/appscms-feature.html +1 -1
- data/_layouts/content-tool-ai copy 2.html +6611 -0
- data/_layouts/content-tool-ai.html +305 -44
- data/assets/.DS_Store +0 -0
- data/assets/css/content-tool-ai.css +815 -11
- metadata +50 -67
- data/assets/js/.DS_Store +0 -0
- data/assets/js/TopScroll.js +0 -8
- data/assets/js/adBlocker.js +0 -68
- data/assets/js/ads.js +0 -8
- data/assets/js/append-div.js +0 -10
- data/assets/js/appscms-infographics.js +0 -0
- data/assets/js/appscms-login.js +0 -447
- data/assets/js/appscms-search-home1.js +0 -136
- data/assets/js/appscms-search.js +0 -133
- data/assets/js/appscms-theme.js +0 -459
- data/assets/js/batch.js +0 -219
- data/assets/js/blog-topic-ideas.js +0 -57
- data/assets/js/calculator-tooltip.js +0 -3
- data/assets/js/devtools.js +0 -82
- data/assets/js/face-api.js +0 -38064
- data/assets/js/face-detection.js +0 -303
- data/assets/js/faceSystem.js +0 -0
- data/assets/js/featureResult.js +0 -48
- data/assets/js/frame.js +0 -264
- data/assets/js/googledrive.js +0 -158
- data/assets/js/homeResult.js +0 -37
- data/assets/js/human-written-blog-post.js +0 -57
- data/assets/js/instagram-caption.js +0 -57
- data/assets/js/instagram-hashtag-generator.js +0 -10
- data/assets/js/instagram-name-generator.js +0 -61
- data/assets/js/manifest.json +0 -17
- data/assets/js/models/age_gender_model-shard1 +0 -0
- data/assets/js/models/age_gender_model-weights_manifest.json +0 -1
- data/assets/js/models/face_expression_model-shard1 +0 -0
- data/assets/js/models/face_expression_model-weights_manifest.json +0 -1
- data/assets/js/models/face_landmark_68_model-shard1 +0 -0
- data/assets/js/models/face_landmark_68_model-weights_manifest.json +0 -1
- data/assets/js/models/face_landmark_68_tiny_model-shard1 +0 -0
- data/assets/js/models/face_landmark_68_tiny_model-weights_manifest.json +0 -1
- data/assets/js/models/face_recognition_model-shard1 +0 -0
- data/assets/js/models/face_recognition_model-shard2 +0 -6
- data/assets/js/models/face_recognition_model-weights_manifest.json +0 -1
- data/assets/js/models/mtcnn_model-shard1 +0 -0
- data/assets/js/models/mtcnn_model-weights_manifest.json +0 -1
- data/assets/js/models/ssd_mobilenetv1_model-shard1 +0 -0
- data/assets/js/models/ssd_mobilenetv1_model-shard2 +8 -137
- data/assets/js/models/ssd_mobilenetv1_model-weights_manifest.json +0 -1
- data/assets/js/models/tiny_face_detector_model-shard1 +0 -0
- data/assets/js/models/tiny_face_detector_model-weights_manifest.json +0 -1
- data/assets/js/multiselect.js +0 -185
- data/assets/js/partytown/debug/partytown-atomics.js +0 -929
- data/assets/js/partytown/debug/partytown-media.js +0 -374
- data/assets/js/partytown/debug/partytown-sandbox-sw.js +0 -920
- data/assets/js/partytown/debug/partytown-sw.js +0 -59
- data/assets/js/partytown/debug/partytown-ww-atomics.js +0 -2699
- data/assets/js/partytown/debug/partytown-ww-sw.js +0 -2691
- data/assets/js/partytown/debug/partytown.js +0 -114
- data/assets/js/partytown/partytown-atomics.js +0 -600
- data/assets/js/partytown/partytown-media.js +0 -2
- data/assets/js/partytown/partytown-sw.js +0 -50
- data/assets/js/perspective.min.js +0 -182
- data/assets/js/photo-effects.json +0 -85
- data/assets/js/redirectResult.js +0 -10
- data/assets/js/sharePage.js +0 -65
- data/assets/js/testing-batch.js +0 -39
- data/assets/js/theme.js +0 -104
- data/assets/js/usageTracking.js +0 -143
- data/assets/js/usageTrackingEvents.js +0 -6
- data/assets/js/userUsageCount.js +0 -0
- data/assets/js/webvitals.js +0 -5
@@ -1,920 +0,0 @@
|
|
1
|
-
/* Partytown 0.7.5 - MIT builder.io */
|
2
|
-
((window) => {
|
3
|
-
const isPromise = (v) => "object" == typeof v && v && v.then;
|
4
|
-
const noop = () => {};
|
5
|
-
const len = (obj) => obj.length;
|
6
|
-
const getConstructorName = (obj) => {
|
7
|
-
var _a, _b, _c;
|
8
|
-
try {
|
9
|
-
const constructorName =
|
10
|
-
null === (_a = null == obj ? void 0 : obj.constructor) || void 0 === _a
|
11
|
-
? void 0
|
12
|
-
: _a.name;
|
13
|
-
if (constructorName) {
|
14
|
-
return constructorName;
|
15
|
-
}
|
16
|
-
} catch (e) {}
|
17
|
-
try {
|
18
|
-
const zoneJsConstructorName =
|
19
|
-
null ===
|
20
|
-
(_c =
|
21
|
-
null ===
|
22
|
-
(_b =
|
23
|
-
null == obj ? void 0 : obj.__zone_symbol__originalInstance) ||
|
24
|
-
void 0 === _b
|
25
|
-
? void 0
|
26
|
-
: _b.constructor) || void 0 === _c
|
27
|
-
? void 0
|
28
|
-
: _c.name;
|
29
|
-
if (zoneJsConstructorName) {
|
30
|
-
return zoneJsConstructorName;
|
31
|
-
}
|
32
|
-
} catch (e) {}
|
33
|
-
return "";
|
34
|
-
};
|
35
|
-
const startsWith = (str, val) => str.startsWith(val);
|
36
|
-
const isValidMemberName = (memberName) =>
|
37
|
-
!(
|
38
|
-
startsWith(memberName, "webkit") ||
|
39
|
-
startsWith(memberName, "toJSON") ||
|
40
|
-
startsWith(memberName, "constructor") ||
|
41
|
-
startsWith(memberName, "toString") ||
|
42
|
-
startsWith(memberName, "_")
|
43
|
-
);
|
44
|
-
const getNodeName = (node) =>
|
45
|
-
11 === node.nodeType && node.host ? "#s" : node.nodeName;
|
46
|
-
const randomId = () =>
|
47
|
-
Math.round(Math.random() * Number.MAX_SAFE_INTEGER).toString(36);
|
48
|
-
const defineConstructorName = (Cstr, value) =>
|
49
|
-
((obj, memberName, descriptor) =>
|
50
|
-
Object.defineProperty(obj, memberName, {
|
51
|
-
...descriptor,
|
52
|
-
configurable: true,
|
53
|
-
}))(Cstr, "name", {
|
54
|
-
value: value,
|
55
|
-
});
|
56
|
-
const htmlConstructorTags = {
|
57
|
-
Anchor: "a",
|
58
|
-
DList: "dl",
|
59
|
-
Image: "img",
|
60
|
-
OList: "ol",
|
61
|
-
Paragraph: "p",
|
62
|
-
Quote: "q",
|
63
|
-
TableCaption: "caption",
|
64
|
-
TableCell: "td",
|
65
|
-
TableCol: "colgroup",
|
66
|
-
TableRow: "tr",
|
67
|
-
TableSection: "tbody",
|
68
|
-
UList: "ul",
|
69
|
-
};
|
70
|
-
const svgConstructorTags = {
|
71
|
-
Graphics: "g",
|
72
|
-
SVG: "svg",
|
73
|
-
};
|
74
|
-
const InstanceIdKey = Symbol();
|
75
|
-
const CreatedKey = Symbol();
|
76
|
-
const instances = new Map();
|
77
|
-
const mainRefs = new Map();
|
78
|
-
const winCtxs = {};
|
79
|
-
const windowIds = new WeakMap();
|
80
|
-
const getAndSetInstanceId = (instance, instanceId) => {
|
81
|
-
if (instance) {
|
82
|
-
if ((instanceId = windowIds.get(instance))) {
|
83
|
-
return instanceId;
|
84
|
-
}
|
85
|
-
(instanceId = instance[InstanceIdKey]) ||
|
86
|
-
setInstanceId(instance, (instanceId = randomId()));
|
87
|
-
return instanceId;
|
88
|
-
}
|
89
|
-
};
|
90
|
-
const getInstance = (winId, instanceId, win, doc, docId) => {
|
91
|
-
if ((win = winCtxs[winId]) && win.$window$) {
|
92
|
-
if (winId === instanceId) {
|
93
|
-
return win.$window$;
|
94
|
-
}
|
95
|
-
doc = win.$window$.document;
|
96
|
-
docId = instanceId.split(".").pop();
|
97
|
-
if ("d" === docId) {
|
98
|
-
return doc;
|
99
|
-
}
|
100
|
-
if ("e" === docId) {
|
101
|
-
return doc.documentElement;
|
102
|
-
}
|
103
|
-
if ("h" === docId) {
|
104
|
-
return doc.head;
|
105
|
-
}
|
106
|
-
if ("b" === docId) {
|
107
|
-
return doc.body;
|
108
|
-
}
|
109
|
-
}
|
110
|
-
return instances.get(instanceId);
|
111
|
-
};
|
112
|
-
const setInstanceId = (instance, instanceId, now) => {
|
113
|
-
if (instance) {
|
114
|
-
instances.set(instanceId, instance);
|
115
|
-
instance[InstanceIdKey] = instanceId;
|
116
|
-
instance[CreatedKey] = now = Date.now();
|
117
|
-
if (now > lastCleanup + 5e3) {
|
118
|
-
instances.forEach((storedInstance, instanceId) => {
|
119
|
-
storedInstance[CreatedKey] < lastCleanup &&
|
120
|
-
storedInstance.nodeType &&
|
121
|
-
!storedInstance.isConnected &&
|
122
|
-
instances.delete(instanceId);
|
123
|
-
});
|
124
|
-
lastCleanup = now;
|
125
|
-
}
|
126
|
-
}
|
127
|
-
};
|
128
|
-
let lastCleanup = 0;
|
129
|
-
const mainWindow = window.parent;
|
130
|
-
const docImpl = document.implementation.createHTMLDocument();
|
131
|
-
const config = mainWindow.partytown || {};
|
132
|
-
const libPath = (config.lib || "/partytown/") + "debug/";
|
133
|
-
const logMain = (msg) => {
|
134
|
-
console.debug.apply(console, [
|
135
|
-
"%cMain 🌎",
|
136
|
-
"background: #717171; color: white; padding: 2px 3px; border-radius: 2px; font-size: 0.8em;",
|
137
|
-
msg,
|
138
|
-
]);
|
139
|
-
};
|
140
|
-
const winIds = [];
|
141
|
-
const normalizedWinId = (winId) => {
|
142
|
-
winIds.includes(winId) || winIds.push(winId);
|
143
|
-
return winIds.indexOf(winId) + 1;
|
144
|
-
};
|
145
|
-
const defineCustomElement = (winId, worker, ceData) => {
|
146
|
-
const Cstr = defineConstructorName(
|
147
|
-
class extends winCtxs[winId].$window$.HTMLElement {},
|
148
|
-
ceData[0]
|
149
|
-
);
|
150
|
-
const ceCallbackMethods =
|
151
|
-
"connectedCallback,disconnectedCallback,attributeChangedCallback,adoptedCallback".split(
|
152
|
-
","
|
153
|
-
);
|
154
|
-
ceCallbackMethods.map(
|
155
|
-
(callbackMethodName) =>
|
156
|
-
(Cstr.prototype[callbackMethodName] = function (...args) {
|
157
|
-
worker.postMessage([
|
158
|
-
15,
|
159
|
-
winId,
|
160
|
-
getAndSetInstanceId(this),
|
161
|
-
callbackMethodName,
|
162
|
-
args,
|
163
|
-
]);
|
164
|
-
})
|
165
|
-
);
|
166
|
-
Cstr.observedAttributes = ceData[1];
|
167
|
-
return Cstr;
|
168
|
-
};
|
169
|
-
const serializeForWorker = ($winId$, value, added, type, cstrName) =>
|
170
|
-
void 0 !== value && (type = typeof value)
|
171
|
-
? "string" === type ||
|
172
|
-
"number" === type ||
|
173
|
-
"boolean" === type ||
|
174
|
-
null == value
|
175
|
-
? [0, value]
|
176
|
-
: "function" === type
|
177
|
-
? [6]
|
178
|
-
: (added = added || new Set()) && Array.isArray(value)
|
179
|
-
? added.has(value)
|
180
|
-
? [1, []]
|
181
|
-
: added.add(value) && [
|
182
|
-
1,
|
183
|
-
value.map((v) => serializeForWorker($winId$, v, added)),
|
184
|
-
]
|
185
|
-
: "object" === type
|
186
|
-
? serializedValueIsError(value)
|
187
|
-
? [
|
188
|
-
14,
|
189
|
-
{
|
190
|
-
name: value.name,
|
191
|
-
message: value.message,
|
192
|
-
stack: value.stack,
|
193
|
-
},
|
194
|
-
]
|
195
|
-
: "" === (cstrName = getConstructorName(value))
|
196
|
-
? [2, {}]
|
197
|
-
: "Window" === cstrName
|
198
|
-
? [3, [$winId$, $winId$]]
|
199
|
-
: "HTMLCollection" === cstrName || "NodeList" === cstrName
|
200
|
-
? [
|
201
|
-
7,
|
202
|
-
Array.from(value).map(
|
203
|
-
(v) => serializeForWorker($winId$, v, added)[1]
|
204
|
-
),
|
205
|
-
]
|
206
|
-
: cstrName.endsWith("Event")
|
207
|
-
? [5, serializeObjectForWorker($winId$, value, added)]
|
208
|
-
: "CSSRuleList" === cstrName
|
209
|
-
? [12, Array.from(value).map(serializeCssRuleForWorker)]
|
210
|
-
: startsWith(cstrName, "CSS") && cstrName.endsWith("Rule")
|
211
|
-
? [11, serializeCssRuleForWorker(value)]
|
212
|
-
: "CSSStyleDeclaration" === cstrName
|
213
|
-
? [13, serializeObjectForWorker($winId$, value, added)]
|
214
|
-
: "Attr" === cstrName
|
215
|
-
? [10, [value.name, value.value]]
|
216
|
-
: value.nodeType
|
217
|
-
? [3, [$winId$, getAndSetInstanceId(value), getNodeName(value)]]
|
218
|
-
: [2, serializeObjectForWorker($winId$, value, added, true, true)]
|
219
|
-
: void 0
|
220
|
-
: value;
|
221
|
-
const serializeObjectForWorker = (
|
222
|
-
winId,
|
223
|
-
obj,
|
224
|
-
added,
|
225
|
-
includeFunctions,
|
226
|
-
includeEmptyStrings,
|
227
|
-
serializedObj,
|
228
|
-
propName,
|
229
|
-
propValue
|
230
|
-
) => {
|
231
|
-
serializedObj = {};
|
232
|
-
if (!added.has(obj)) {
|
233
|
-
added.add(obj);
|
234
|
-
for (propName in obj) {
|
235
|
-
if (isValidMemberName(propName)) {
|
236
|
-
propValue =
|
237
|
-
"path" === propName && getConstructorName(obj).endsWith("Event")
|
238
|
-
? obj.composedPath()
|
239
|
-
: obj[propName];
|
240
|
-
(includeFunctions || "function" != typeof propValue) &&
|
241
|
-
(includeEmptyStrings || "" !== propValue) &&
|
242
|
-
(serializedObj[propName] = serializeForWorker(
|
243
|
-
winId,
|
244
|
-
propValue,
|
245
|
-
added
|
246
|
-
));
|
247
|
-
}
|
248
|
-
}
|
249
|
-
}
|
250
|
-
return serializedObj;
|
251
|
-
};
|
252
|
-
const serializeCssRuleForWorker = (cssRule) => {
|
253
|
-
let obj = {};
|
254
|
-
let key;
|
255
|
-
for (key in cssRule) {
|
256
|
-
validCssRuleProps.includes(key) && (obj[key] = String(cssRule[key]));
|
257
|
-
}
|
258
|
-
return obj;
|
259
|
-
};
|
260
|
-
const serializedValueIsError = (value) => value instanceof window.top.Error;
|
261
|
-
const deserializeFromWorker = (
|
262
|
-
worker,
|
263
|
-
serializedTransfer,
|
264
|
-
serializedType,
|
265
|
-
serializedValue
|
266
|
-
) => {
|
267
|
-
if (serializedTransfer) {
|
268
|
-
serializedType = serializedTransfer[0];
|
269
|
-
serializedValue = serializedTransfer[1];
|
270
|
-
return 0 === serializedType
|
271
|
-
? serializedValue
|
272
|
-
: 4 === serializedType
|
273
|
-
? deserializeRefFromWorker(worker, serializedValue)
|
274
|
-
: 1 === serializedType
|
275
|
-
? serializedValue.map((v) => deserializeFromWorker(worker, v))
|
276
|
-
: 3 === serializedType
|
277
|
-
? getInstance(serializedValue[0], serializedValue[1])
|
278
|
-
: 5 === serializedType
|
279
|
-
? constructEvent(deserializeObjectFromWorker(worker, serializedValue))
|
280
|
-
: 2 === serializedType
|
281
|
-
? deserializeObjectFromWorker(worker, serializedValue)
|
282
|
-
: 8 === serializedType
|
283
|
-
? serializedValue
|
284
|
-
: 9 === serializedType
|
285
|
-
? new window[serializedTransfer[2]](serializedValue)
|
286
|
-
: void 0;
|
287
|
-
}
|
288
|
-
};
|
289
|
-
const deserializeRefFromWorker = (
|
290
|
-
worker,
|
291
|
-
{ $winId$: $winId$, $instanceId$: $instanceId$, $refId$: $refId$ },
|
292
|
-
ref
|
293
|
-
) => {
|
294
|
-
ref = mainRefs.get($refId$);
|
295
|
-
if (!ref) {
|
296
|
-
ref = function (...args) {
|
297
|
-
worker.postMessage([
|
298
|
-
9,
|
299
|
-
{
|
300
|
-
$winId$: $winId$,
|
301
|
-
$instanceId$: $instanceId$,
|
302
|
-
$refId$: $refId$,
|
303
|
-
$thisArg$: serializeForWorker($winId$, this),
|
304
|
-
$args$: serializeForWorker($winId$, args),
|
305
|
-
},
|
306
|
-
]);
|
307
|
-
};
|
308
|
-
mainRefs.set($refId$, ref);
|
309
|
-
}
|
310
|
-
return ref;
|
311
|
-
};
|
312
|
-
const constructEvent = (eventProps) =>
|
313
|
-
new ("detail" in eventProps ? CustomEvent : Event)(
|
314
|
-
eventProps.type,
|
315
|
-
eventProps
|
316
|
-
);
|
317
|
-
const deserializeObjectFromWorker = (worker, serializedValue, obj, key) => {
|
318
|
-
obj = {};
|
319
|
-
for (key in serializedValue) {
|
320
|
-
obj[key] = deserializeFromWorker(worker, serializedValue[key]);
|
321
|
-
}
|
322
|
-
return obj;
|
323
|
-
};
|
324
|
-
const validCssRuleProps =
|
325
|
-
"cssText,selectorText,href,media,namespaceURI,prefix,name,conditionText".split(
|
326
|
-
","
|
327
|
-
);
|
328
|
-
const mainAccessHandler = async (worker, accessReq) => {
|
329
|
-
let accessRsp = {
|
330
|
-
$msgId$: accessReq.$msgId$,
|
331
|
-
};
|
332
|
-
let totalTasks = len(accessReq.$tasks$);
|
333
|
-
let i = 0;
|
334
|
-
let task;
|
335
|
-
let winId;
|
336
|
-
let applyPath;
|
337
|
-
let instance;
|
338
|
-
let rtnValue;
|
339
|
-
let isLast;
|
340
|
-
for (; i < totalTasks; i++) {
|
341
|
-
try {
|
342
|
-
isLast = i === totalTasks - 1;
|
343
|
-
task = accessReq.$tasks$[i];
|
344
|
-
winId = task.$winId$;
|
345
|
-
applyPath = task.$applyPath$;
|
346
|
-
!winCtxs[winId] &&
|
347
|
-
winId.startsWith("f_") &&
|
348
|
-
(await new Promise((resolve) => {
|
349
|
-
let check = 0;
|
350
|
-
let callback = () => {
|
351
|
-
winCtxs[winId] || check++ > 1e3
|
352
|
-
? resolve()
|
353
|
-
: requestAnimationFrame(callback);
|
354
|
-
};
|
355
|
-
callback();
|
356
|
-
}));
|
357
|
-
if (1 === applyPath[0] && applyPath[1] in winCtxs[winId].$window$) {
|
358
|
-
setInstanceId(
|
359
|
-
new winCtxs[winId].$window$[applyPath[1]](
|
360
|
-
...deserializeFromWorker(worker, applyPath[2])
|
361
|
-
),
|
362
|
-
task.$instanceId$
|
363
|
-
);
|
364
|
-
} else {
|
365
|
-
instance = getInstance(winId, task.$instanceId$);
|
366
|
-
if (instance) {
|
367
|
-
rtnValue = applyToInstance(
|
368
|
-
worker,
|
369
|
-
winId,
|
370
|
-
instance,
|
371
|
-
applyPath,
|
372
|
-
isLast,
|
373
|
-
task.$groupedGetters$
|
374
|
-
);
|
375
|
-
task.$assignInstanceId$ &&
|
376
|
-
("string" == typeof task.$assignInstanceId$
|
377
|
-
? setInstanceId(rtnValue, task.$assignInstanceId$)
|
378
|
-
: (winCtxs[task.$assignInstanceId$.$winId$] = {
|
379
|
-
$winId$: task.$assignInstanceId$.$winId$,
|
380
|
-
$window$: {
|
381
|
-
document: rtnValue,
|
382
|
-
},
|
383
|
-
}));
|
384
|
-
if (isPromise(rtnValue)) {
|
385
|
-
rtnValue = await rtnValue;
|
386
|
-
isLast && (accessRsp.$isPromise$ = true);
|
387
|
-
}
|
388
|
-
isLast &&
|
389
|
-
(accessRsp.$rtnValue$ = serializeForWorker(winId, rtnValue));
|
390
|
-
} else {
|
391
|
-
accessRsp.$error$ = `Error finding instance "${
|
392
|
-
task.$instanceId$
|
393
|
-
}" on window ${normalizedWinId(winId)}`;
|
394
|
-
console.error(accessRsp.$error$, task);
|
395
|
-
}
|
396
|
-
}
|
397
|
-
} catch (e) {
|
398
|
-
isLast ? (accessRsp.$error$ = String(e.stack || e)) : console.error(e);
|
399
|
-
}
|
400
|
-
}
|
401
|
-
return accessRsp;
|
402
|
-
};
|
403
|
-
const applyToInstance = (
|
404
|
-
worker,
|
405
|
-
winId,
|
406
|
-
instance,
|
407
|
-
applyPath,
|
408
|
-
isLast,
|
409
|
-
groupedGetters
|
410
|
-
) => {
|
411
|
-
let i = 0;
|
412
|
-
let l = len(applyPath);
|
413
|
-
let next;
|
414
|
-
let current;
|
415
|
-
let previous;
|
416
|
-
let args;
|
417
|
-
let groupedRtnValues;
|
418
|
-
for (; i < l; i++) {
|
419
|
-
current = applyPath[i];
|
420
|
-
next = applyPath[i + 1];
|
421
|
-
previous = applyPath[i - 1];
|
422
|
-
try {
|
423
|
-
if (!Array.isArray(next)) {
|
424
|
-
if ("string" == typeof current || "number" == typeof current) {
|
425
|
-
if (i + 1 === l && groupedGetters) {
|
426
|
-
groupedRtnValues = {};
|
427
|
-
groupedGetters.map(
|
428
|
-
(propName) => (groupedRtnValues[propName] = instance[propName])
|
429
|
-
);
|
430
|
-
return groupedRtnValues;
|
431
|
-
}
|
432
|
-
instance = instance[current];
|
433
|
-
} else {
|
434
|
-
if (0 === next) {
|
435
|
-
instance[previous] = deserializeFromWorker(worker, current);
|
436
|
-
return;
|
437
|
-
}
|
438
|
-
if ("function" == typeof instance[previous]) {
|
439
|
-
args = deserializeFromWorker(worker, current);
|
440
|
-
"define" === previous &&
|
441
|
-
"CustomElementRegistry" === getConstructorName(instance) &&
|
442
|
-
(args[1] = defineCustomElement(winId, worker, args[1]));
|
443
|
-
"insertRule" === previous &&
|
444
|
-
args[1] > len(instance.cssRules) &&
|
445
|
-
(args[1] = len(instance.cssRules));
|
446
|
-
instance = instance[previous].apply(instance, args);
|
447
|
-
if ("play" === previous) {
|
448
|
-
return Promise.resolve();
|
449
|
-
}
|
450
|
-
}
|
451
|
-
}
|
452
|
-
}
|
453
|
-
} catch (err) {
|
454
|
-
if (isLast) {
|
455
|
-
throw err;
|
456
|
-
}
|
457
|
-
console.debug("Non-blocking setter error:", err);
|
458
|
-
}
|
459
|
-
}
|
460
|
-
return instance;
|
461
|
-
};
|
462
|
-
const readNextScript = (worker, winCtx) => {
|
463
|
-
let $winId$ = winCtx.$winId$;
|
464
|
-
let win = winCtx.$window$;
|
465
|
-
let doc = win.document;
|
466
|
-
let scriptSelector =
|
467
|
-
'script[type="text/partytown"]:not([data-ptid]):not([data-pterror])';
|
468
|
-
let scriptElm;
|
469
|
-
let $instanceId$;
|
470
|
-
let scriptData;
|
471
|
-
if (doc && doc.body) {
|
472
|
-
scriptElm = doc.querySelector(
|
473
|
-
'script[type="text/partytown"]:not([data-ptid]):not([data-pterror]):not([async]):not([defer])'
|
474
|
-
);
|
475
|
-
scriptElm || (scriptElm = doc.querySelector(scriptSelector));
|
476
|
-
if (scriptElm) {
|
477
|
-
scriptElm.dataset.ptid = $instanceId$ = getAndSetInstanceId(
|
478
|
-
scriptElm,
|
479
|
-
$winId$
|
480
|
-
);
|
481
|
-
scriptData = {
|
482
|
-
$winId$: $winId$,
|
483
|
-
$instanceId$: $instanceId$,
|
484
|
-
};
|
485
|
-
if (scriptElm.src) {
|
486
|
-
scriptData.$url$ = scriptElm.src;
|
487
|
-
scriptData.$orgUrl$ = scriptElm.dataset.ptsrc || scriptElm.src;
|
488
|
-
} else {
|
489
|
-
scriptData.$content$ = scriptElm.innerHTML;
|
490
|
-
}
|
491
|
-
worker.postMessage([7, scriptData]);
|
492
|
-
} else {
|
493
|
-
if (!winCtx.$isInitialized$) {
|
494
|
-
winCtx.$isInitialized$ = 1;
|
495
|
-
((worker, $winId$, win) => {
|
496
|
-
let queuedForwardCalls = win._ptf;
|
497
|
-
let forwards = (win.partytown || {}).forward || [];
|
498
|
-
let i;
|
499
|
-
let mainForwardFn;
|
500
|
-
let forwardCall = ($forward$, args) =>
|
501
|
-
worker.postMessage([
|
502
|
-
10,
|
503
|
-
{
|
504
|
-
$winId$: $winId$,
|
505
|
-
$forward$: $forward$,
|
506
|
-
$args$: serializeForWorker($winId$, Array.from(args)),
|
507
|
-
},
|
508
|
-
]);
|
509
|
-
win._ptf = void 0;
|
510
|
-
forwards.map((forwardProps) => {
|
511
|
-
mainForwardFn = win;
|
512
|
-
forwardProps.split(".").map((_, i, arr) => {
|
513
|
-
mainForwardFn = mainForwardFn[arr[i]] =
|
514
|
-
i + 1 < len(arr)
|
515
|
-
? mainForwardFn[arr[i]] || ("push" === arr[i + 1] ? [] : {})
|
516
|
-
: (...args) => forwardCall(arr, args);
|
517
|
-
});
|
518
|
-
});
|
519
|
-
if (queuedForwardCalls) {
|
520
|
-
for (i = 0; i < len(queuedForwardCalls); i += 2) {
|
521
|
-
forwardCall(queuedForwardCalls[i], queuedForwardCalls[i + 1]);
|
522
|
-
}
|
523
|
-
}
|
524
|
-
})(worker, $winId$, win);
|
525
|
-
doc.dispatchEvent(new CustomEvent("pt0"));
|
526
|
-
{
|
527
|
-
const winType = win === win.top ? "top" : "input";
|
528
|
-
logMain(
|
529
|
-
`Executed ${winType} window ${normalizedWinId(
|
530
|
-
$winId$
|
531
|
-
)} environment scripts in ${(
|
532
|
-
performance.now() - winCtx.$startTime$
|
533
|
-
).toFixed(1)}ms`
|
534
|
-
);
|
535
|
-
}
|
536
|
-
}
|
537
|
-
worker.postMessage([8, $winId$]);
|
538
|
-
}
|
539
|
-
} else {
|
540
|
-
requestAnimationFrame(() => readNextScript(worker, winCtx));
|
541
|
-
}
|
542
|
-
};
|
543
|
-
const registerWindow = (worker, $winId$, $window$) => {
|
544
|
-
if (!windowIds.has($window$)) {
|
545
|
-
windowIds.set($window$, $winId$);
|
546
|
-
const doc = $window$.document;
|
547
|
-
const history = $window$.history;
|
548
|
-
const $parentWinId$ = windowIds.get($window$.parent);
|
549
|
-
let initialised = false;
|
550
|
-
const onInitialisedQueue = [];
|
551
|
-
const onInitialised = (callback) => {
|
552
|
-
initialised ? callback() : onInitialisedQueue.push(callback);
|
553
|
-
};
|
554
|
-
const sendInitEnvData = () => {
|
555
|
-
worker.postMessage([
|
556
|
-
5,
|
557
|
-
{
|
558
|
-
$winId$: $winId$,
|
559
|
-
$parentWinId$: $parentWinId$,
|
560
|
-
$url$: doc.baseURI,
|
561
|
-
$visibilityState$: doc.visibilityState,
|
562
|
-
},
|
563
|
-
]);
|
564
|
-
setTimeout(() => {
|
565
|
-
initialised = true;
|
566
|
-
onInitialisedQueue.forEach((callback) => {
|
567
|
-
callback();
|
568
|
-
});
|
569
|
-
});
|
570
|
-
};
|
571
|
-
const pushState = history.pushState.bind(history);
|
572
|
-
const replaceState = history.replaceState.bind(history);
|
573
|
-
const onLocationChange = (type, state, newUrl, oldUrl) => () => {
|
574
|
-
setTimeout(() => {
|
575
|
-
worker.postMessage([
|
576
|
-
13,
|
577
|
-
{
|
578
|
-
$winId$: $winId$,
|
579
|
-
type: type,
|
580
|
-
state: state,
|
581
|
-
url: doc.baseURI,
|
582
|
-
newUrl: newUrl,
|
583
|
-
oldUrl: oldUrl,
|
584
|
-
},
|
585
|
-
]);
|
586
|
-
});
|
587
|
-
};
|
588
|
-
history.pushState = (state, _, newUrl) => {
|
589
|
-
pushState(state, _, newUrl);
|
590
|
-
onInitialised(
|
591
|
-
onLocationChange(
|
592
|
-
0,
|
593
|
-
state,
|
594
|
-
null == newUrl ? void 0 : newUrl.toString()
|
595
|
-
)
|
596
|
-
);
|
597
|
-
};
|
598
|
-
history.replaceState = (state, _, newUrl) => {
|
599
|
-
replaceState(state, _, newUrl);
|
600
|
-
onInitialised(
|
601
|
-
onLocationChange(
|
602
|
-
1,
|
603
|
-
state,
|
604
|
-
null == newUrl ? void 0 : newUrl.toString()
|
605
|
-
)
|
606
|
-
);
|
607
|
-
};
|
608
|
-
$window$.addEventListener("popstate", (event) => {
|
609
|
-
onInitialised(onLocationChange(2, event.state));
|
610
|
-
});
|
611
|
-
$window$.addEventListener("hashchange", (event) => {
|
612
|
-
onInitialised(onLocationChange(3, {}, event.newURL, event.oldURL));
|
613
|
-
});
|
614
|
-
$window$.addEventListener("ptupdate", () => {
|
615
|
-
readNextScript(worker, winCtxs[$winId$]);
|
616
|
-
});
|
617
|
-
doc.addEventListener("visibilitychange", () =>
|
618
|
-
worker.postMessage([14, $winId$, doc.visibilityState])
|
619
|
-
);
|
620
|
-
winCtxs[$winId$] = {
|
621
|
-
$winId$: $winId$,
|
622
|
-
$window$: $window$,
|
623
|
-
};
|
624
|
-
winCtxs[$winId$].$startTime$ = performance.now();
|
625
|
-
{
|
626
|
-
const winType = $winId$ === $parentWinId$ ? "top" : "input";
|
627
|
-
logMain(`Registered ${winType} window ${normalizedWinId($winId$)}`);
|
628
|
-
}
|
629
|
-
"complete" === doc.readyState
|
630
|
-
? sendInitEnvData()
|
631
|
-
: $window$.addEventListener("load", sendInitEnvData);
|
632
|
-
}
|
633
|
-
};
|
634
|
-
const onMessageFromWebWorker = (worker, msg, winCtx) => {
|
635
|
-
if (4 === msg[0]) {
|
636
|
-
registerWindow(worker, randomId(), mainWindow);
|
637
|
-
} else {
|
638
|
-
winCtx = winCtxs[msg[1]];
|
639
|
-
winCtx &&
|
640
|
-
(7 === msg[0]
|
641
|
-
? requestAnimationFrame(() => readNextScript(worker, winCtx))
|
642
|
-
: 6 === msg[0] &&
|
643
|
-
((worker, winCtx, instanceId, errorMsg, scriptElm) => {
|
644
|
-
scriptElm = winCtx.$window$.document.querySelector(
|
645
|
-
`[data-ptid="${instanceId}"]`
|
646
|
-
);
|
647
|
-
if (scriptElm) {
|
648
|
-
errorMsg
|
649
|
-
? (scriptElm.dataset.pterror = errorMsg)
|
650
|
-
: (scriptElm.type += "-x");
|
651
|
-
delete scriptElm.dataset.ptid;
|
652
|
-
}
|
653
|
-
readNextScript(worker, winCtx);
|
654
|
-
})(worker, winCtx, msg[2], msg[3]));
|
655
|
-
}
|
656
|
-
};
|
657
|
-
const readMainPlatform = () => {
|
658
|
-
const elm = docImpl.createElement("i");
|
659
|
-
const textNode = docImpl.createTextNode("");
|
660
|
-
const comment = docImpl.createComment("");
|
661
|
-
const frag = docImpl.createDocumentFragment();
|
662
|
-
const shadowRoot = docImpl.createElement("p").attachShadow({
|
663
|
-
mode: "open",
|
664
|
-
});
|
665
|
-
const intersectionObserver = getGlobalConstructor(
|
666
|
-
mainWindow,
|
667
|
-
"IntersectionObserver"
|
668
|
-
);
|
669
|
-
const mutationObserver = getGlobalConstructor(
|
670
|
-
mainWindow,
|
671
|
-
"MutationObserver"
|
672
|
-
);
|
673
|
-
const resizeObserver = getGlobalConstructor(mainWindow, "ResizeObserver");
|
674
|
-
const perf = mainWindow.performance;
|
675
|
-
const screen = mainWindow.screen;
|
676
|
-
const impls = [
|
677
|
-
[mainWindow.history],
|
678
|
-
[perf],
|
679
|
-
[perf.navigation],
|
680
|
-
[perf.timing],
|
681
|
-
[screen],
|
682
|
-
[screen.orientation],
|
683
|
-
[mainWindow.visualViewport],
|
684
|
-
[intersectionObserver, 12],
|
685
|
-
[mutationObserver, 12],
|
686
|
-
[resizeObserver, 12],
|
687
|
-
[textNode],
|
688
|
-
[comment],
|
689
|
-
[frag],
|
690
|
-
[shadowRoot],
|
691
|
-
[elm],
|
692
|
-
[elm.attributes],
|
693
|
-
[elm.classList],
|
694
|
-
[elm.dataset],
|
695
|
-
[elm.style],
|
696
|
-
[docImpl],
|
697
|
-
[docImpl.doctype],
|
698
|
-
];
|
699
|
-
const initialInterfaces = [
|
700
|
-
readImplementation("Window", mainWindow),
|
701
|
-
readImplementation("Node", textNode),
|
702
|
-
];
|
703
|
-
const $config$ = JSON.stringify(config, (k, v) => {
|
704
|
-
if ("function" == typeof v) {
|
705
|
-
v = String(v);
|
706
|
-
v.startsWith(k + "(") && (v = "function " + v);
|
707
|
-
}
|
708
|
-
return v;
|
709
|
-
});
|
710
|
-
const initWebWorkerData = {
|
711
|
-
$config$: $config$,
|
712
|
-
$interfaces$: readImplementations(impls, initialInterfaces),
|
713
|
-
$libPath$: new URL(libPath, mainWindow.location) + "",
|
714
|
-
$origin$: origin,
|
715
|
-
$localStorage$: readStorage("localStorage"),
|
716
|
-
$sessionStorage$: readStorage("sessionStorage"),
|
717
|
-
};
|
718
|
-
addGlobalConstructorUsingPrototype(
|
719
|
-
initWebWorkerData.$interfaces$,
|
720
|
-
mainWindow,
|
721
|
-
"IntersectionObserverEntry"
|
722
|
-
);
|
723
|
-
return initWebWorkerData;
|
724
|
-
};
|
725
|
-
const readMainInterfaces = () => {
|
726
|
-
const elms = Object.getOwnPropertyNames(mainWindow)
|
727
|
-
.map((interfaceName) =>
|
728
|
-
((doc, interfaceName, r, tag) => {
|
729
|
-
r = interfaceName.match(/^(HTML|SVG)(.+)Element$/);
|
730
|
-
if (r) {
|
731
|
-
tag = r[2];
|
732
|
-
return "S" == interfaceName[0]
|
733
|
-
? doc.createElementNS(
|
734
|
-
"http://www.w3.org/2000/svg",
|
735
|
-
svgConstructorTags[tag] ||
|
736
|
-
tag.slice(0, 2).toLowerCase() + tag.slice(2)
|
737
|
-
)
|
738
|
-
: doc.createElement(htmlConstructorTags[tag] || tag);
|
739
|
-
}
|
740
|
-
})(docImpl, interfaceName)
|
741
|
-
)
|
742
|
-
.filter((elm) => elm)
|
743
|
-
.map((elm) => [elm]);
|
744
|
-
return readImplementations(elms, []);
|
745
|
-
};
|
746
|
-
const cstrs = new Set(["Object"]);
|
747
|
-
const readImplementations = (impls, interfaces) => {
|
748
|
-
const cstrImpls = impls
|
749
|
-
.filter((implData) => implData[0])
|
750
|
-
.map((implData) => {
|
751
|
-
const impl = implData[0];
|
752
|
-
const interfaceType = implData[1];
|
753
|
-
const cstrName = getConstructorName(impl);
|
754
|
-
const CstrPrototype = mainWindow[cstrName].prototype;
|
755
|
-
return [cstrName, CstrPrototype, impl, interfaceType];
|
756
|
-
});
|
757
|
-
cstrImpls.map(([cstrName, CstrPrototype, impl, intefaceType]) =>
|
758
|
-
readOwnImplementation(
|
759
|
-
cstrs,
|
760
|
-
interfaces,
|
761
|
-
cstrName,
|
762
|
-
CstrPrototype,
|
763
|
-
impl,
|
764
|
-
intefaceType
|
765
|
-
)
|
766
|
-
);
|
767
|
-
return interfaces;
|
768
|
-
};
|
769
|
-
const readImplementation = (cstrName, impl, memberName) => {
|
770
|
-
let interfaceMembers = [];
|
771
|
-
let interfaceInfo = [cstrName, "Object", interfaceMembers];
|
772
|
-
for (memberName in impl) {
|
773
|
-
readImplementationMember(interfaceMembers, impl, memberName);
|
774
|
-
}
|
775
|
-
return interfaceInfo;
|
776
|
-
};
|
777
|
-
const readOwnImplementation = (
|
778
|
-
cstrs,
|
779
|
-
interfaces,
|
780
|
-
cstrName,
|
781
|
-
CstrPrototype,
|
782
|
-
impl,
|
783
|
-
interfaceType
|
784
|
-
) => {
|
785
|
-
if (!cstrs.has(cstrName)) {
|
786
|
-
cstrs.add(cstrName);
|
787
|
-
const SuperCstr = Object.getPrototypeOf(CstrPrototype);
|
788
|
-
const superCstrName = getConstructorName(SuperCstr);
|
789
|
-
const interfaceMembers = [];
|
790
|
-
const propDescriptors = Object.getOwnPropertyDescriptors(CstrPrototype);
|
791
|
-
readOwnImplementation(
|
792
|
-
cstrs,
|
793
|
-
interfaces,
|
794
|
-
superCstrName,
|
795
|
-
SuperCstr,
|
796
|
-
impl,
|
797
|
-
interfaceType
|
798
|
-
);
|
799
|
-
for (const memberName in propDescriptors) {
|
800
|
-
readImplementationMember(interfaceMembers, impl, memberName);
|
801
|
-
}
|
802
|
-
interfaces.push([
|
803
|
-
cstrName,
|
804
|
-
superCstrName,
|
805
|
-
interfaceMembers,
|
806
|
-
interfaceType,
|
807
|
-
getNodeName(impl),
|
808
|
-
]);
|
809
|
-
}
|
810
|
-
};
|
811
|
-
const readImplementationMember = (
|
812
|
-
interfaceMembers,
|
813
|
-
implementation,
|
814
|
-
memberName,
|
815
|
-
value,
|
816
|
-
memberType,
|
817
|
-
cstrName
|
818
|
-
) => {
|
819
|
-
try {
|
820
|
-
if (
|
821
|
-
isValidMemberName(memberName) &&
|
822
|
-
isNaN(memberName[0]) &&
|
823
|
-
"all" !== memberName
|
824
|
-
) {
|
825
|
-
value = implementation[memberName];
|
826
|
-
memberType = typeof value;
|
827
|
-
if ("function" === memberType) {
|
828
|
-
(String(value).includes("[native") ||
|
829
|
-
Object.getPrototypeOf(implementation)[memberName]) &&
|
830
|
-
interfaceMembers.push([memberName, 5]);
|
831
|
-
} else if ("object" === memberType && null != value) {
|
832
|
-
cstrName = getConstructorName(value);
|
833
|
-
"Object" !== cstrName &&
|
834
|
-
self[cstrName] &&
|
835
|
-
interfaceMembers.push([memberName, value.nodeType || cstrName]);
|
836
|
-
} else {
|
837
|
-
"symbol" !== memberType &&
|
838
|
-
(memberName.toUpperCase() === memberName
|
839
|
-
? interfaceMembers.push([memberName, 6, value])
|
840
|
-
: interfaceMembers.push([memberName, 6]));
|
841
|
-
}
|
842
|
-
}
|
843
|
-
} catch (e) {
|
844
|
-
console.warn(e);
|
845
|
-
}
|
846
|
-
};
|
847
|
-
const readStorage = (storageName) => {
|
848
|
-
let items = [];
|
849
|
-
let i = 0;
|
850
|
-
let l = len(mainWindow[storageName]);
|
851
|
-
let key;
|
852
|
-
for (; i < l; i++) {
|
853
|
-
key = mainWindow[storageName].key(i);
|
854
|
-
items.push([key, mainWindow[storageName].getItem(key)]);
|
855
|
-
}
|
856
|
-
return items;
|
857
|
-
};
|
858
|
-
const getGlobalConstructor = (mainWindow, cstrName) =>
|
859
|
-
void 0 !== mainWindow[cstrName] ? new mainWindow[cstrName](noop) : 0;
|
860
|
-
const addGlobalConstructorUsingPrototype = (
|
861
|
-
$interfaces$,
|
862
|
-
mainWindow,
|
863
|
-
cstrName
|
864
|
-
) => {
|
865
|
-
void 0 !== mainWindow[cstrName] &&
|
866
|
-
$interfaces$.push([
|
867
|
-
cstrName,
|
868
|
-
"Object",
|
869
|
-
Object.keys(mainWindow[cstrName].prototype).map((propName) => [
|
870
|
-
propName,
|
871
|
-
6,
|
872
|
-
]),
|
873
|
-
12,
|
874
|
-
]);
|
875
|
-
};
|
876
|
-
let worker;
|
877
|
-
((receiveMessage) => {
|
878
|
-
const swContainer = window.navigator.serviceWorker;
|
879
|
-
return swContainer.getRegistration().then((swRegistration) => {
|
880
|
-
swContainer.addEventListener("message", (ev) =>
|
881
|
-
receiveMessage(
|
882
|
-
ev.data,
|
883
|
-
(accessRsp) =>
|
884
|
-
swRegistration.active &&
|
885
|
-
swRegistration.active.postMessage(accessRsp)
|
886
|
-
)
|
887
|
-
);
|
888
|
-
return (worker, msg) => {
|
889
|
-
0 === msg[0]
|
890
|
-
? worker.postMessage([1, readMainPlatform()])
|
891
|
-
: 2 === msg[0]
|
892
|
-
? worker.postMessage([3, readMainInterfaces()])
|
893
|
-
: onMessageFromWebWorker(worker, msg);
|
894
|
-
};
|
895
|
-
});
|
896
|
-
})((accessReq, responseCallback) =>
|
897
|
-
mainAccessHandler(worker, accessReq).then(responseCallback)
|
898
|
-
).then((onMessageHandler) => {
|
899
|
-
if (onMessageHandler) {
|
900
|
-
worker = new Worker(libPath + "partytown-ww-sw.js?v=0.7.5", {
|
901
|
-
name: "Partytown 🎉",
|
902
|
-
});
|
903
|
-
worker.onmessage = (ev) => {
|
904
|
-
const msg = ev.data;
|
905
|
-
12 === msg[0]
|
906
|
-
? mainAccessHandler(worker, msg[1])
|
907
|
-
: onMessageHandler(worker, msg);
|
908
|
-
};
|
909
|
-
logMain("Created Partytown web worker (0.7.5)");
|
910
|
-
worker.onerror = (ev) => console.error("Web Worker Error", ev);
|
911
|
-
mainWindow.addEventListener("pt1", (ev) =>
|
912
|
-
registerWindow(
|
913
|
-
worker,
|
914
|
-
getAndSetInstanceId(ev.detail.frameElement),
|
915
|
-
ev.detail
|
916
|
-
)
|
917
|
-
);
|
918
|
-
}
|
919
|
-
});
|
920
|
-
})(window);
|