@descope/sdk-mixins 0.0.0-next-cd745c61-20250421 → 0.0.0-next-26df9ba9-20250424
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/constants.js +6 -0
- package/dist/cjs/constants.js.map +1 -0
- package/dist/cjs/index.js +43 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/mixins/baseUrlMixin.js +14 -0
- package/dist/cjs/mixins/baseUrlMixin.js.map +1 -0
- package/dist/cjs/mixins/configMixin/configMixin.js +53 -0
- package/dist/cjs/mixins/configMixin/configMixin.js.map +1 -0
- package/dist/cjs/mixins/configMixin/constants.js +6 -0
- package/dist/cjs/mixins/configMixin/constants.js.map +1 -0
- package/dist/cjs/mixins/cookieConfigMixin.js +14 -0
- package/dist/cjs/mixins/cookieConfigMixin.js.map +1 -0
- package/dist/cjs/mixins/createStateManagementMixin.js +47 -0
- package/dist/cjs/mixins/createStateManagementMixin.js.map +1 -0
- package/dist/cjs/mixins/createValidateAttributesMixin/commonValidators.js +7 -0
- package/dist/cjs/mixins/createValidateAttributesMixin/commonValidators.js.map +1 -0
- package/dist/cjs/mixins/createValidateAttributesMixin/createValidateAttributesMixin.js +40 -0
- package/dist/cjs/mixins/createValidateAttributesMixin/createValidateAttributesMixin.js.map +1 -0
- package/dist/cjs/mixins/debuggerMixin/debugger-wc.js +237 -0
- package/dist/cjs/mixins/debuggerMixin/debugger-wc.js.map +1 -0
- package/dist/cjs/mixins/debuggerMixin/debuggerMixin.js +73 -0
- package/dist/cjs/mixins/debuggerMixin/debuggerMixin.js.map +1 -0
- package/dist/cjs/mixins/debuggerMixin/helpers.js +76 -0
- package/dist/cjs/mixins/debuggerMixin/helpers.js.map +1 -0
- package/dist/cjs/mixins/descopeUiMixin/constants.js +14 -0
- package/dist/cjs/mixins/descopeUiMixin/constants.js.map +1 -0
- package/dist/cjs/mixins/descopeUiMixin/descopeUiMixin.js +96 -0
- package/dist/cjs/mixins/descopeUiMixin/descopeUiMixin.js.map +1 -0
- package/dist/cjs/mixins/descopeUiMixin/helpers.js +8 -0
- package/dist/cjs/mixins/descopeUiMixin/helpers.js.map +1 -0
- package/dist/cjs/mixins/formMixin.js +57 -0
- package/dist/cjs/mixins/formMixin.js.map +1 -0
- package/dist/cjs/mixins/initElementMixin.js +39 -0
- package/dist/cjs/mixins/initElementMixin.js.map +1 -0
- package/dist/cjs/mixins/initLifecycleMixin.js +29 -0
- package/dist/cjs/mixins/initLifecycleMixin.js.map +1 -0
- package/dist/cjs/mixins/injectNpmLibMixin/constants.js +10 -0
- package/dist/cjs/mixins/injectNpmLibMixin/constants.js.map +1 -0
- package/dist/cjs/mixins/injectNpmLibMixin/helpers.js +112 -0
- package/dist/cjs/mixins/injectNpmLibMixin/helpers.js.map +1 -0
- package/dist/cjs/mixins/injectNpmLibMixin/injectNpmLibMixin.js +28 -0
- package/dist/cjs/mixins/injectNpmLibMixin/injectNpmLibMixin.js.map +1 -0
- package/dist/cjs/mixins/loggerMixin/loggerMixin.js +37 -0
- package/dist/cjs/mixins/loggerMixin/loggerMixin.js.map +1 -0
- package/dist/cjs/mixins/modalMixin/constants.js +6 -0
- package/dist/cjs/mixins/modalMixin/constants.js.map +1 -0
- package/dist/cjs/mixins/modalMixin/helpers.js +14 -0
- package/dist/cjs/mixins/modalMixin/helpers.js.map +1 -0
- package/dist/cjs/mixins/modalMixin/modalMixin.js +47 -0
- package/dist/cjs/mixins/modalMixin/modalMixin.js.map +1 -0
- package/dist/cjs/mixins/notificationsMixin/constants.js +6 -0
- package/dist/cjs/mixins/notificationsMixin/constants.js.map +1 -0
- package/dist/cjs/mixins/notificationsMixin/helpers.js +14 -0
- package/dist/cjs/mixins/notificationsMixin/helpers.js.map +1 -0
- package/dist/cjs/mixins/notificationsMixin/notificationsMixin.js +50 -0
- package/dist/cjs/mixins/notificationsMixin/notificationsMixin.js.map +1 -0
- package/dist/cjs/mixins/observeAttributesMixin/helpers.js +17 -0
- package/dist/cjs/mixins/observeAttributesMixin/helpers.js.map +1 -0
- package/dist/cjs/mixins/observeAttributesMixin/observeAttributesMixin.js +47 -0
- package/dist/cjs/mixins/observeAttributesMixin/observeAttributesMixin.js.map +1 -0
- package/dist/cjs/mixins/projectIdMixin.js +17 -0
- package/dist/cjs/mixins/projectIdMixin.js.map +1 -0
- package/dist/cjs/mixins/resetMixin.js +47 -0
- package/dist/cjs/mixins/resetMixin.js.map +1 -0
- package/dist/cjs/mixins/staticResourcesMixin/constants.js +13 -0
- package/dist/cjs/mixins/staticResourcesMixin/constants.js.map +1 -0
- package/dist/cjs/mixins/staticResourcesMixin/fetchWithFallbacks.js +43 -0
- package/dist/cjs/mixins/staticResourcesMixin/fetchWithFallbacks.js.map +1 -0
- package/dist/cjs/mixins/staticResourcesMixin/index.js +9 -0
- package/dist/cjs/mixins/staticResourcesMixin/index.js.map +1 -0
- package/dist/cjs/mixins/staticResourcesMixin/staticResourcesMixin.js +101 -0
- package/dist/cjs/mixins/staticResourcesMixin/staticResourcesMixin.js.map +1 -0
- package/dist/cjs/mixins/themeMixin/constants.js +7 -0
- package/dist/cjs/mixins/themeMixin/constants.js.map +1 -0
- package/dist/cjs/mixins/themeMixin/helpers.js +34 -0
- package/dist/cjs/mixins/themeMixin/helpers.js.map +1 -0
- package/dist/cjs/mixins/themeMixin/index.js +8 -0
- package/dist/cjs/mixins/themeMixin/index.js.map +1 -0
- package/dist/cjs/mixins/themeMixin/themeMixin.js +179 -0
- package/dist/cjs/mixins/themeMixin/themeMixin.js.map +1 -0
- package/dist/cjs/package.json +1 -0
- package/dist/esm/constants.js +4 -0
- package/dist/esm/constants.js.map +1 -0
- package/dist/esm/index.js +19 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/mixins/baseUrlMixin.js +12 -0
- package/dist/esm/mixins/baseUrlMixin.js.map +1 -0
- package/dist/esm/mixins/configMixin/configMixin.js +51 -0
- package/dist/esm/mixins/configMixin/configMixin.js.map +1 -0
- package/dist/esm/mixins/configMixin/constants.js +4 -0
- package/dist/esm/mixins/configMixin/constants.js.map +1 -0
- package/dist/esm/mixins/cookieConfigMixin.js +12 -0
- package/dist/esm/mixins/cookieConfigMixin.js.map +1 -0
- package/dist/esm/mixins/createStateManagementMixin.js +45 -0
- package/dist/esm/mixins/createStateManagementMixin.js.map +1 -0
- package/dist/esm/mixins/createValidateAttributesMixin/commonValidators.js +5 -0
- package/dist/esm/mixins/createValidateAttributesMixin/commonValidators.js.map +1 -0
- package/dist/esm/mixins/createValidateAttributesMixin/createValidateAttributesMixin.js +38 -0
- package/dist/esm/mixins/createValidateAttributesMixin/createValidateAttributesMixin.js.map +1 -0
- package/dist/esm/mixins/debuggerMixin/debugger-wc.js +233 -0
- package/dist/esm/mixins/debuggerMixin/debugger-wc.js.map +1 -0
- package/dist/esm/mixins/debuggerMixin/debuggerMixin.js +71 -0
- package/dist/esm/mixins/debuggerMixin/debuggerMixin.js.map +1 -0
- package/dist/esm/mixins/debuggerMixin/helpers.js +72 -0
- package/dist/esm/mixins/debuggerMixin/helpers.js.map +1 -0
- package/dist/esm/mixins/descopeUiMixin/constants.js +9 -0
- package/dist/esm/mixins/descopeUiMixin/constants.js.map +1 -0
- package/dist/esm/mixins/descopeUiMixin/descopeUiMixin.js +94 -0
- package/dist/esm/mixins/descopeUiMixin/descopeUiMixin.js.map +1 -0
- package/dist/esm/mixins/descopeUiMixin/helpers.js +6 -0
- package/dist/esm/mixins/descopeUiMixin/helpers.js.map +1 -0
- package/dist/esm/mixins/formMixin.js +55 -0
- package/dist/esm/mixins/formMixin.js.map +1 -0
- package/dist/esm/mixins/initElementMixin.js +37 -0
- package/dist/esm/mixins/initElementMixin.js.map +1 -0
- package/dist/esm/mixins/initLifecycleMixin.js +27 -0
- package/dist/esm/mixins/initLifecycleMixin.js.map +1 -0
- package/dist/esm/mixins/injectNpmLibMixin/constants.js +8 -0
- package/dist/esm/mixins/injectNpmLibMixin/constants.js.map +1 -0
- package/dist/esm/mixins/injectNpmLibMixin/helpers.js +109 -0
- package/dist/esm/mixins/injectNpmLibMixin/helpers.js.map +1 -0
- package/dist/esm/mixins/injectNpmLibMixin/injectNpmLibMixin.js +26 -0
- package/dist/esm/mixins/injectNpmLibMixin/injectNpmLibMixin.js.map +1 -0
- package/dist/esm/mixins/loggerMixin/loggerMixin.js +35 -0
- package/dist/esm/mixins/loggerMixin/loggerMixin.js.map +1 -0
- package/dist/esm/mixins/modalMixin/constants.js +4 -0
- package/dist/esm/mixins/modalMixin/constants.js.map +1 -0
- package/dist/esm/mixins/modalMixin/helpers.js +12 -0
- package/dist/esm/mixins/modalMixin/helpers.js.map +1 -0
- package/dist/esm/mixins/modalMixin/modalMixin.js +45 -0
- package/dist/esm/mixins/modalMixin/modalMixin.js.map +1 -0
- package/dist/esm/mixins/notificationsMixin/constants.js +4 -0
- package/dist/esm/mixins/notificationsMixin/constants.js.map +1 -0
- package/dist/esm/mixins/notificationsMixin/helpers.js +12 -0
- package/dist/esm/mixins/notificationsMixin/helpers.js.map +1 -0
- package/dist/esm/mixins/notificationsMixin/notificationsMixin.js +48 -0
- package/dist/esm/mixins/notificationsMixin/notificationsMixin.js.map +1 -0
- package/dist/esm/mixins/observeAttributesMixin/helpers.js +15 -0
- package/dist/esm/mixins/observeAttributesMixin/helpers.js.map +1 -0
- package/dist/esm/mixins/observeAttributesMixin/observeAttributesMixin.js +45 -0
- package/dist/esm/mixins/observeAttributesMixin/observeAttributesMixin.js.map +1 -0
- package/dist/esm/mixins/projectIdMixin.js +15 -0
- package/dist/esm/mixins/projectIdMixin.js.map +1 -0
- package/dist/esm/mixins/resetMixin.js +45 -0
- package/dist/esm/mixins/resetMixin.js.map +1 -0
- package/dist/esm/mixins/staticResourcesMixin/constants.js +9 -0
- package/dist/esm/mixins/staticResourcesMixin/constants.js.map +1 -0
- package/dist/esm/mixins/staticResourcesMixin/fetchWithFallbacks.js +41 -0
- package/dist/esm/mixins/staticResourcesMixin/fetchWithFallbacks.js.map +1 -0
- package/dist/esm/mixins/staticResourcesMixin/index.js +2 -0
- package/dist/esm/mixins/staticResourcesMixin/index.js.map +1 -0
- package/dist/esm/mixins/staticResourcesMixin/staticResourcesMixin.js +98 -0
- package/dist/esm/mixins/staticResourcesMixin/staticResourcesMixin.js.map +1 -0
- package/dist/esm/mixins/themeMixin/constants.js +5 -0
- package/dist/esm/mixins/themeMixin/constants.js.map +1 -0
- package/dist/esm/mixins/themeMixin/helpers.js +31 -0
- package/dist/esm/mixins/themeMixin/helpers.js.map +1 -0
- package/dist/esm/mixins/themeMixin/index.js +2 -0
- package/dist/esm/mixins/themeMixin/index.js.map +1 -0
- package/dist/esm/mixins/themeMixin/themeMixin.js +177 -0
- package/dist/esm/mixins/themeMixin/themeMixin.js.map +1 -0
- package/dist/index.d.ts +6503 -0
- package/dist/types/constants.d.ts +1 -0
- package/dist/types/index.d.ts +24 -0
- package/dist/types/mixins/baseUrlMixin.d.ts +331 -0
- package/dist/types/mixins/configMixin/configMixin.d.ts +363 -0
- package/dist/types/mixins/configMixin/constants.d.ts +1 -0
- package/dist/types/mixins/configMixin/index.d.ts +2 -0
- package/dist/types/mixins/configMixin/types.d.ts +66 -0
- package/dist/types/mixins/cookieConfigMixin.d.ts +331 -0
- package/dist/types/mixins/createStateManagementMixin.d.ts +341 -0
- package/dist/types/mixins/createValidateAttributesMixin/commonValidators.d.ts +1 -0
- package/dist/types/mixins/createValidateAttributesMixin/createValidateAttributesMixin.d.ts +346 -0
- package/dist/types/mixins/createValidateAttributesMixin/index.d.ts +1 -0
- package/dist/types/mixins/debuggerMixin/debugger-wc.d.ts +9 -0
- package/dist/types/mixins/debuggerMixin/debuggerMixin.d.ts +347 -0
- package/dist/types/mixins/debuggerMixin/helpers.d.ts +4 -0
- package/dist/types/mixins/debuggerMixin/index.d.ts +1 -0
- package/dist/types/mixins/debuggerMixin/types.d.ts +12 -0
- package/dist/types/mixins/descopeUiMixin/constants.d.ts +4 -0
- package/dist/types/mixins/descopeUiMixin/descopeUiMixin.d.ts +373 -0
- package/dist/types/mixins/descopeUiMixin/helpers.d.ts +2 -0
- package/dist/types/mixins/descopeUiMixin/index.d.ts +1 -0
- package/dist/types/mixins/formMixin.d.ts +345 -0
- package/dist/types/mixins/initElementMixin.d.ts +332 -0
- package/dist/types/mixins/initLifecycleMixin.d.ts +332 -0
- package/dist/types/mixins/injectNpmLibMixin/constants.d.ts +1 -0
- package/dist/types/mixins/injectNpmLibMixin/helpers.d.ts +7 -0
- package/dist/types/mixins/injectNpmLibMixin/index.d.ts +1 -0
- package/dist/types/mixins/injectNpmLibMixin/injectNpmLibMixin.d.ts +343 -0
- package/dist/types/mixins/loggerMixin/index.d.ts +2 -0
- package/dist/types/mixins/loggerMixin/loggerMixin.d.ts +339 -0
- package/dist/types/mixins/loggerMixin/types.d.ts +6 -0
- package/dist/types/mixins/modalMixin/constants.d.ts +1 -0
- package/dist/types/mixins/modalMixin/helpers.d.ts +1 -0
- package/dist/types/mixins/modalMixin/index.d.ts +1 -0
- package/dist/types/mixins/modalMixin/modalMixin.d.ts +406 -0
- package/dist/types/mixins/notificationsMixin/constants.d.ts +1 -0
- package/dist/types/mixins/notificationsMixin/helpers.d.ts +1 -0
- package/dist/types/mixins/notificationsMixin/index.d.ts +1 -0
- package/dist/types/mixins/notificationsMixin/notificationsMixin.d.ts +425 -0
- package/dist/types/mixins/observeAttributesMixin/helpers.d.ts +1 -0
- package/dist/types/mixins/observeAttributesMixin/index.d.ts +1 -0
- package/dist/types/mixins/observeAttributesMixin/observeAttributesMixin.d.ts +342 -0
- package/dist/types/mixins/projectIdMixin.d.ts +342 -0
- package/dist/types/mixins/resetMixin.d.ts +344 -0
- package/dist/types/mixins/staticResourcesMixin/constants.d.ts +4 -0
- package/dist/types/mixins/staticResourcesMixin/fetchWithFallbacks.d.ts +7 -0
- package/dist/types/mixins/staticResourcesMixin/index.d.ts +1 -0
- package/dist/types/mixins/staticResourcesMixin/staticResourcesMixin.d.ts +362 -0
- package/dist/types/mixins/themeMixin/constants.d.ts +2 -0
- package/dist/types/mixins/themeMixin/helpers.d.ts +5 -0
- package/dist/types/mixins/themeMixin/index.d.ts +1 -0
- package/dist/types/mixins/themeMixin/themeMixin.d.ts +406 -0
- package/package.json +10 -10
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"debuggerMixin.js","sources":["../../../../src/mixins/debuggerMixin/debuggerMixin.ts"],"sourcesContent":["import { compose, createSingletonMixin } from '@descope/sdk-helpers';\nimport { initLifecycleMixin } from '../initLifecycleMixin';\nimport { LogLevel, loggerMixin } from '../loggerMixin';\nimport { DebuggerMessage } from './types';\n\nexport const debuggerMixin = createSingletonMixin(\n <T extends CustomElementConstructor>(superclass: T) =>\n class DebuggerMixinClass extends compose(\n initLifecycleMixin,\n loggerMixin,\n )(superclass) {\n #debuggerEle:\n | (HTMLElement & {\n updateData: (data: DebuggerMessage | DebuggerMessage[]) => void;\n })\n | null;\n\n #disableDebugger() {\n this.#debuggerEle?.remove();\n this.#debuggerEle = null;\n }\n\n async #enableDebugger() {\n this.#debuggerEle = document.createElement(\n 'descope-debugger',\n ) as HTMLElement & {\n updateData: (data: DebuggerMessage | DebuggerMessage[]) => void;\n };\n\n Object.assign(this.#debuggerEle.style, {\n position: 'fixed',\n top: '0',\n right: '0',\n height: '100vh',\n width: '100vw',\n pointerEvents: 'none',\n zIndex: 99999,\n });\n\n // we are importing the debugger dynamically so we won't load it when it's not needed\n await import('./debugger-wc');\n\n document.body.appendChild(this.#debuggerEle);\n }\n\n attributeChangedCallback = (\n attrName: string,\n oldValue: string | null,\n newValue: string | null,\n ) => {\n super.attributeChangedCallback?.(attrName, oldValue, newValue);\n\n if (attrName === 'debug') {\n this.#handleDebugMode();\n }\n };\n\n get debug() {\n return this.getAttribute('debug') === 'true';\n }\n\n #handleDebugMode() {\n if (this.debug) this.#enableDebugger();\n else this.#disableDebugger();\n }\n\n onLogEvent(logLevel: LogLevel, args: any[]) {\n super.onLogEvent?.(logLevel, args);\n if (logLevel === 'error') {\n this.#updateDebuggerMessages(args[0] || 'Error', args[1]);\n }\n }\n\n async init() {\n await super.init?.();\n\n this.#handleDebugMode();\n }\n\n #updateDebuggerMessages(title: string, description: string) {\n if (title) this.#debuggerEle?.updateData({ title, description });\n }\n },\n);\n"],"names":["createSingletonMixin","compose","initLifecycleMixin","loggerMixin","__classPrivateFieldGet","__classPrivateFieldSet"],"mappings":"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"}
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const limitCoordinateToScreenBoundaries = (ele, x, y, boundaries = {}) => {
|
|
4
|
+
var _a, _b, _c, _d;
|
|
5
|
+
return [
|
|
6
|
+
Math.min(Math.max(x, (boundaries.left === 'all' ? ele.offsetWidth : (_a = boundaries.left) !== null && _a !== void 0 ? _a : 0) -
|
|
7
|
+
ele.offsetWidth), window.innerWidth -
|
|
8
|
+
(boundaries.right === 'all' ? ele.offsetWidth : (_b = boundaries.right) !== null && _b !== void 0 ? _b : 0)),
|
|
9
|
+
Math.min(Math.max(y, (boundaries.top === 'all' ? ele.offsetHeight : (_c = boundaries.top) !== null && _c !== void 0 ? _c : 0) -
|
|
10
|
+
ele.offsetHeight), window.innerHeight -
|
|
11
|
+
(boundaries.bottom === 'all' ? ele.offsetHeight : (_d = boundaries.bottom) !== null && _d !== void 0 ? _d : 0)),
|
|
12
|
+
];
|
|
13
|
+
};
|
|
14
|
+
const dragElement = (ele, triggerEle, keepVisible) => {
|
|
15
|
+
let deltaX = 0;
|
|
16
|
+
let deltaY = 0;
|
|
17
|
+
let currentX = 0;
|
|
18
|
+
let currentY = 0;
|
|
19
|
+
function elementDrag(e) {
|
|
20
|
+
e.preventDefault();
|
|
21
|
+
// calculate the new cursor position:
|
|
22
|
+
deltaX = currentX - e.clientX;
|
|
23
|
+
deltaY = currentY - e.clientY;
|
|
24
|
+
currentX = e.clientX;
|
|
25
|
+
currentY = e.clientY;
|
|
26
|
+
// set the element's new position:
|
|
27
|
+
const [left, top] = limitCoordinateToScreenBoundaries(ele, ele.offsetLeft - deltaX, ele.offsetTop - deltaY, keepVisible);
|
|
28
|
+
// eslint-disable-next-line no-param-reassign
|
|
29
|
+
ele.style.top = `${top}px`;
|
|
30
|
+
// eslint-disable-next-line no-param-reassign
|
|
31
|
+
ele.style.left = `${left}px`;
|
|
32
|
+
}
|
|
33
|
+
function closeDragElement() {
|
|
34
|
+
// stop moving when mouse button is released:
|
|
35
|
+
document.onmouseup = null;
|
|
36
|
+
document.onmousemove = null;
|
|
37
|
+
}
|
|
38
|
+
function dragMouseDown(e) {
|
|
39
|
+
e.preventDefault();
|
|
40
|
+
// get the mouse cursor position at startup:
|
|
41
|
+
currentX = e.clientX;
|
|
42
|
+
currentY = e.clientY;
|
|
43
|
+
document.onmouseup = closeDragElement;
|
|
44
|
+
// call a function whenever the cursor moves:
|
|
45
|
+
document.onmousemove = elementDrag;
|
|
46
|
+
}
|
|
47
|
+
if (triggerEle) {
|
|
48
|
+
// if provided, the triggerEle is where you move the div from
|
|
49
|
+
// eslint-disable-next-line no-param-reassign
|
|
50
|
+
triggerEle.onmousedown = dragMouseDown;
|
|
51
|
+
}
|
|
52
|
+
else {
|
|
53
|
+
// otherwise, move the DIV from anywhere inside the DIV:
|
|
54
|
+
// eslint-disable-next-line no-param-reassign
|
|
55
|
+
ele.onmousedown = dragMouseDown;
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
const addOnResize = (ele) => {
|
|
59
|
+
// eslint-disable-next-line no-param-reassign
|
|
60
|
+
ele.onmousemove = (e) => {
|
|
61
|
+
var _a;
|
|
62
|
+
// eslint-disable-next-line prefer-destructuring
|
|
63
|
+
const target = e.target;
|
|
64
|
+
if ((target.w && target.w !== target.offsetWidth) ||
|
|
65
|
+
(target.h && target.h !== target.offsetHeight)) {
|
|
66
|
+
(_a = ele.onresize) === null || _a === void 0 ? void 0 : _a.call(ele, e);
|
|
67
|
+
}
|
|
68
|
+
target.w = target.offsetWidth;
|
|
69
|
+
target.h = target.offsetHeight;
|
|
70
|
+
};
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
exports.addOnResize = addOnResize;
|
|
74
|
+
exports.dragElement = dragElement;
|
|
75
|
+
exports.limitCoordinateToScreenBoundaries = limitCoordinateToScreenBoundaries;
|
|
76
|
+
//# sourceMappingURL=helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.js","sources":["../../../../src/mixins/debuggerMixin/helpers.ts"],"sourcesContent":["import { Boundaries } from './types';\n\ntype Target = {\n w: number;\n h: number;\n offsetWidth: number;\n offsetHeight: number;\n};\n\nexport const limitCoordinateToScreenBoundaries = (\n ele: HTMLElement,\n x: number,\n y: number,\n boundaries: Boundaries = {},\n) => [\n Math.min(\n Math.max(\n x,\n (boundaries.left === 'all' ? ele.offsetWidth : boundaries.left ?? 0) -\n ele.offsetWidth,\n ),\n window.innerWidth -\n (boundaries.right === 'all' ? ele.offsetWidth : boundaries.right ?? 0),\n ),\n Math.min(\n Math.max(\n y,\n (boundaries.top === 'all' ? ele.offsetHeight : boundaries.top ?? 0) -\n ele.offsetHeight,\n ),\n window.innerHeight -\n (boundaries.bottom === 'all' ? ele.offsetHeight : boundaries.bottom ?? 0),\n ),\n];\n\nexport const dragElement = (\n ele: HTMLElement,\n triggerEle?: HTMLElement,\n keepVisible?: Boundaries,\n) => {\n let deltaX = 0;\n let deltaY = 0;\n let currentX = 0;\n let currentY = 0;\n\n function elementDrag(e: MouseEvent) {\n e.preventDefault();\n // calculate the new cursor position:\n deltaX = currentX - e.clientX;\n deltaY = currentY - e.clientY;\n currentX = e.clientX;\n currentY = e.clientY;\n // set the element's new position:\n const [left, top] = limitCoordinateToScreenBoundaries(\n ele,\n ele.offsetLeft - deltaX,\n ele.offsetTop - deltaY,\n keepVisible,\n );\n // eslint-disable-next-line no-param-reassign\n ele.style.top = `${top}px`;\n // eslint-disable-next-line no-param-reassign\n ele.style.left = `${left}px`;\n }\n\n function closeDragElement() {\n // stop moving when mouse button is released:\n document.onmouseup = null;\n document.onmousemove = null;\n }\n\n function dragMouseDown(e: MouseEvent) {\n e.preventDefault();\n // get the mouse cursor position at startup:\n currentX = e.clientX;\n currentY = e.clientY;\n document.onmouseup = closeDragElement;\n // call a function whenever the cursor moves:\n document.onmousemove = elementDrag;\n }\n\n if (triggerEle) {\n // if provided, the triggerEle is where you move the div from\n // eslint-disable-next-line no-param-reassign\n triggerEle.onmousedown = dragMouseDown;\n } else {\n // otherwise, move the DIV from anywhere inside the DIV:\n\n // eslint-disable-next-line no-param-reassign\n ele.onmousedown = dragMouseDown;\n }\n};\n\nexport const addOnResize = (ele: HTMLElement) => {\n // eslint-disable-next-line no-param-reassign\n ele.onmousemove = (e) => {\n // eslint-disable-next-line prefer-destructuring\n const target: Target = e.target! as EventTarget & Target;\n if (\n (target.w && target.w !== target.offsetWidth) ||\n (target.h && target.h !== target.offsetHeight)\n ) {\n ele.onresize?.(e);\n }\n target.w = target.offsetWidth;\n target.h = target.offsetHeight;\n };\n};\n"],"names":[],"mappings":";;AASO,MAAM,iCAAiC,GAAG,CAC/C,GAAgB,EAChB,CAAS,EACT,CAAS,EACT,UAAyB,GAAA,EAAE,KACzB;;IAAC,OAAA;AACH,QAAA,IAAI,CAAC,GAAG,CACN,IAAI,CAAC,GAAG,CACN,CAAC,EACD,CAAC,UAAU,CAAC,IAAI,KAAK,KAAK,GAAG,GAAG,CAAC,WAAW,GAAG,CAAA,EAAA,GAAA,UAAU,CAAC,IAAI,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,GAAI,CAAC;AACjE,YAAA,GAAG,CAAC,WAAW,CAClB,EACD,MAAM,CAAC,UAAU;aACd,UAAU,CAAC,KAAK,KAAK,KAAK,GAAG,GAAG,CAAC,WAAW,GAAG,CAAA,EAAA,GAAA,UAAU,CAAC,KAAK,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,GAAI,CAAC,CAAC,CACzE;AACD,QAAA,IAAI,CAAC,GAAG,CACN,IAAI,CAAC,GAAG,CACN,CAAC,EACD,CAAC,UAAU,CAAC,GAAG,KAAK,KAAK,GAAG,GAAG,CAAC,YAAY,GAAG,CAAA,EAAA,GAAA,UAAU,CAAC,GAAG,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,GAAI,CAAC;AAChE,YAAA,GAAG,CAAC,YAAY,CACnB,EACD,MAAM,CAAC,WAAW;aACf,UAAU,CAAC,MAAM,KAAK,KAAK,GAAG,GAAG,CAAC,YAAY,GAAG,CAAA,EAAA,GAAA,UAAU,CAAC,MAAM,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,GAAI,CAAC,CAAC,CAC5E;KACF,CAAA;EAAC;AAEW,MAAA,WAAW,GAAG,CACzB,GAAgB,EAChB,UAAwB,EACxB,WAAwB,KACtB;IACF,IAAI,MAAM,GAAG,CAAC,CAAC;IACf,IAAI,MAAM,GAAG,CAAC,CAAC;IACf,IAAI,QAAQ,GAAG,CAAC,CAAC;IACjB,IAAI,QAAQ,GAAG,CAAC,CAAC;IAEjB,SAAS,WAAW,CAAC,CAAa,EAAA;QAChC,CAAC,CAAC,cAAc,EAAE,CAAC;;AAEnB,QAAA,MAAM,GAAG,QAAQ,GAAG,CAAC,CAAC,OAAO,CAAC;AAC9B,QAAA,MAAM,GAAG,QAAQ,GAAG,CAAC,CAAC,OAAO,CAAC;AAC9B,QAAA,QAAQ,GAAG,CAAC,CAAC,OAAO,CAAC;AACrB,QAAA,QAAQ,GAAG,CAAC,CAAC,OAAO,CAAC;;QAErB,MAAM,CAAC,IAAI,EAAE,GAAG,CAAC,GAAG,iCAAiC,CACnD,GAAG,EACH,GAAG,CAAC,UAAU,GAAG,MAAM,EACvB,GAAG,CAAC,SAAS,GAAG,MAAM,EACtB,WAAW,CACZ,CAAC;;QAEF,GAAG,CAAC,KAAK,CAAC,GAAG,GAAG,CAAG,EAAA,GAAG,IAAI,CAAC;;QAE3B,GAAG,CAAC,KAAK,CAAC,IAAI,GAAG,CAAG,EAAA,IAAI,IAAI,CAAC;KAC9B;AAED,IAAA,SAAS,gBAAgB,GAAA;;AAEvB,QAAA,QAAQ,CAAC,SAAS,GAAG,IAAI,CAAC;AAC1B,QAAA,QAAQ,CAAC,WAAW,GAAG,IAAI,CAAC;KAC7B;IAED,SAAS,aAAa,CAAC,CAAa,EAAA;QAClC,CAAC,CAAC,cAAc,EAAE,CAAC;;AAEnB,QAAA,QAAQ,GAAG,CAAC,CAAC,OAAO,CAAC;AACrB,QAAA,QAAQ,GAAG,CAAC,CAAC,OAAO,CAAC;AACrB,QAAA,QAAQ,CAAC,SAAS,GAAG,gBAAgB,CAAC;;AAEtC,QAAA,QAAQ,CAAC,WAAW,GAAG,WAAW,CAAC;KACpC;IAED,IAAI,UAAU,EAAE;;;AAGd,QAAA,UAAU,CAAC,WAAW,GAAG,aAAa,CAAC;KACxC;SAAM;;;AAIL,QAAA,GAAG,CAAC,WAAW,GAAG,aAAa,CAAC;KACjC;AACH,EAAE;AAEW,MAAA,WAAW,GAAG,CAAC,GAAgB,KAAI;;AAE9C,IAAA,GAAG,CAAC,WAAW,GAAG,CAAC,CAAC,KAAI;;;AAEtB,QAAA,MAAM,MAAM,GAAW,CAAC,CAAC,MAA+B,CAAC;AACzD,QAAA,IACE,CAAC,MAAM,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,KAAK,MAAM,CAAC,WAAW;AAC5C,aAAC,MAAM,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,KAAK,MAAM,CAAC,YAAY,CAAC,EAC9C;AACA,YAAA,CAAA,EAAA,GAAA,GAAG,CAAC,QAAQ,MAAG,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,IAAA,CAAA,GAAA,EAAA,CAAC,CAAC,CAAC;SACnB;AACD,QAAA,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,WAAW,CAAC;AAC9B,QAAA,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,YAAY,CAAC;AACjC,KAAC,CAAC;AACJ;;;;;;"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var constants = require('../../constants.js');
|
|
4
|
+
|
|
5
|
+
const UI_COMPONENTS_URL_KEY = 'base.ui.components.url';
|
|
6
|
+
const LOCAL_STORAGE_OVERRIDE = constants.IS_LOCAL_STORAGE && localStorage.getItem(UI_COMPONENTS_URL_KEY);
|
|
7
|
+
const JS_FILE_PATH = 'dist/umd/index.js';
|
|
8
|
+
const WEB_COMPONENTS_UI_LIB_NAME = '@descope/web-components-ui';
|
|
9
|
+
|
|
10
|
+
exports.JS_FILE_PATH = JS_FILE_PATH;
|
|
11
|
+
exports.LOCAL_STORAGE_OVERRIDE = LOCAL_STORAGE_OVERRIDE;
|
|
12
|
+
exports.UI_COMPONENTS_URL_KEY = UI_COMPONENTS_URL_KEY;
|
|
13
|
+
exports.WEB_COMPONENTS_UI_LIB_NAME = WEB_COMPONENTS_UI_LIB_NAME;
|
|
14
|
+
//# sourceMappingURL=constants.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sources":["../../../../src/mixins/descopeUiMixin/constants.ts"],"sourcesContent":["import { IS_LOCAL_STORAGE } from '../../constants';\n\nexport const UI_COMPONENTS_URL_KEY = 'base.ui.components.url';\nexport const LOCAL_STORAGE_OVERRIDE =\n IS_LOCAL_STORAGE && localStorage.getItem(UI_COMPONENTS_URL_KEY);\nexport const JS_FILE_PATH = 'dist/umd/index.js';\nexport const WEB_COMPONENTS_UI_LIB_NAME = '@descope/web-components-ui';\n"],"names":["IS_LOCAL_STORAGE"],"mappings":";;;;AAEO,MAAM,qBAAqB,GAAG,yBAAyB;AACvD,MAAM,sBAAsB,GACjCA,0BAAgB,IAAI,YAAY,CAAC,OAAO,CAAC,qBAAqB,EAAE;AAC3D,MAAM,YAAY,GAAG,oBAAoB;AACzC,MAAM,0BAA0B,GAAG;;;;;;;"}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var tslib = require('tslib');
|
|
4
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
5
|
+
var configMixin = require('../configMixin/configMixin.js');
|
|
6
|
+
var injectNpmLibMixin = require('../injectNpmLibMixin/injectNpmLibMixin.js');
|
|
7
|
+
var loggerMixin = require('../loggerMixin/loggerMixin.js');
|
|
8
|
+
var helpers = require('./helpers.js');
|
|
9
|
+
var constants = require('./constants.js');
|
|
10
|
+
|
|
11
|
+
const descopeUiMixin = sdkHelpers.createSingletonMixin((superclass) => {
|
|
12
|
+
var _DescopeUiMixinClass_instances, _DescopeUiMixinClass_getComponentsVersion, _DescopeUiMixinClass_descopeUi, _DescopeUiMixinClass_loadDescopeUiComponent, _DescopeUiMixinClass_getDescopeUi, _a;
|
|
13
|
+
const BaseClass = sdkHelpers.compose(loggerMixin.loggerMixin, configMixin.configMixin, injectNpmLibMixin.injectNpmLibMixin)(superclass);
|
|
14
|
+
return _a = class DescopeUiMixinClass extends BaseClass {
|
|
15
|
+
constructor() {
|
|
16
|
+
super(...arguments);
|
|
17
|
+
_DescopeUiMixinClass_instances.add(this);
|
|
18
|
+
_DescopeUiMixinClass_descopeUi.set(this, void 0);
|
|
19
|
+
}
|
|
20
|
+
get descopeUi() {
|
|
21
|
+
if (!tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_descopeUi, "f")) {
|
|
22
|
+
tslib.__classPrivateFieldSet(this, _DescopeUiMixinClass_descopeUi, tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_instances, "m", _DescopeUiMixinClass_getDescopeUi).call(this), "f");
|
|
23
|
+
}
|
|
24
|
+
return tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_descopeUi, "f");
|
|
25
|
+
}
|
|
26
|
+
async loadDescopeUiComponents(templateOrComponentNames) {
|
|
27
|
+
const descopeUiComponentsList = Array.isArray(templateOrComponentNames)
|
|
28
|
+
? templateOrComponentNames
|
|
29
|
+
: helpers.getDescopeUiComponentsList(templateOrComponentNames);
|
|
30
|
+
return Promise.all(descopeUiComponentsList.map((componentName) => tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_instances, "m", _DescopeUiMixinClass_loadDescopeUiComponent).call(this, componentName)));
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
_DescopeUiMixinClass_descopeUi = new WeakMap(),
|
|
34
|
+
_DescopeUiMixinClass_instances = new WeakSet(),
|
|
35
|
+
_DescopeUiMixinClass_getComponentsVersion =
|
|
36
|
+
// eslint-disable-next-line class-methods-use-this
|
|
37
|
+
async function _DescopeUiMixinClass_getComponentsVersion() {
|
|
38
|
+
var _b;
|
|
39
|
+
const config = await this.config;
|
|
40
|
+
const componentsVersion = (_b = config === null || config === void 0 ? void 0 : config.projectConfig) === null || _b === void 0 ? void 0 : _b.componentsVersion;
|
|
41
|
+
if (!componentsVersion) {
|
|
42
|
+
this.logger.error('Could not get components version');
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
this.logger.debug(`Got component version "${componentsVersion}"`);
|
|
46
|
+
}
|
|
47
|
+
return componentsVersion;
|
|
48
|
+
},
|
|
49
|
+
_DescopeUiMixinClass_loadDescopeUiComponent = async function _DescopeUiMixinClass_loadDescopeUiComponent(componentName) {
|
|
50
|
+
const isComponentAlreadyDefined = !!customElements.get(componentName);
|
|
51
|
+
if (isComponentAlreadyDefined) {
|
|
52
|
+
this.logger.debug(`Loading component "${componentName}" is skipped as it is already defined`);
|
|
53
|
+
return undefined;
|
|
54
|
+
}
|
|
55
|
+
const descopeUI = await this.descopeUi;
|
|
56
|
+
if (!descopeUI[componentName]) {
|
|
57
|
+
this.logger.error(`Cannot load UI component "${componentName}"`, `Descope UI does not have a component named "${componentName}", available components are: "${Object.keys(descopeUI).join(', ')}"`);
|
|
58
|
+
return undefined;
|
|
59
|
+
}
|
|
60
|
+
try {
|
|
61
|
+
// eslint-disable-next-line @typescript-eslint/return-await
|
|
62
|
+
return await descopeUI[componentName]();
|
|
63
|
+
}
|
|
64
|
+
catch (e) {
|
|
65
|
+
// this error is thrown when trying to register a component which is already registered
|
|
66
|
+
// when running 2 flows on the same page, it might happen that the register fn is called twice
|
|
67
|
+
// in case it happens, we are silently ignore the error
|
|
68
|
+
if (e.name === 'NotSupportedError') {
|
|
69
|
+
// eslint-disable-next-line no-console
|
|
70
|
+
console.debug(`Encountered an error while attempting to define the "${componentName}" component, it is likely that this component is already defined`);
|
|
71
|
+
}
|
|
72
|
+
else {
|
|
73
|
+
throw e;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return undefined;
|
|
77
|
+
},
|
|
78
|
+
_DescopeUiMixinClass_getDescopeUi = async function _DescopeUiMixinClass_getDescopeUi() {
|
|
79
|
+
if (globalThis.DescopeUI) {
|
|
80
|
+
return globalThis.DescopeUI;
|
|
81
|
+
}
|
|
82
|
+
try {
|
|
83
|
+
await this.injectNpmLib(constants.WEB_COMPONENTS_UI_LIB_NAME, await tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_instances, "m", _DescopeUiMixinClass_getComponentsVersion).call(this), constants.JS_FILE_PATH, [constants.LOCAL_STORAGE_OVERRIDE]);
|
|
84
|
+
this.logger.debug('DescopeUI was loaded');
|
|
85
|
+
return globalThis.DescopeUI;
|
|
86
|
+
}
|
|
87
|
+
catch (error) {
|
|
88
|
+
this.logger.error(error);
|
|
89
|
+
throw new Error('DescopeUI was not loaded');
|
|
90
|
+
}
|
|
91
|
+
},
|
|
92
|
+
_a;
|
|
93
|
+
});
|
|
94
|
+
|
|
95
|
+
exports.descopeUiMixin = descopeUiMixin;
|
|
96
|
+
//# sourceMappingURL=descopeUiMixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"descopeUiMixin.js","sources":["../../../../src/mixins/descopeUiMixin/descopeUiMixin.ts"],"sourcesContent":["import { compose, createSingletonMixin } from '@descope/sdk-helpers';\nimport { configMixin } from '../configMixin';\nimport { injectNpmLibMixin } from '../injectNpmLibMixin';\nimport { loggerMixin } from '../loggerMixin';\nimport { getDescopeUiComponentsList } from './helpers';\nimport {\n JS_FILE_PATH,\n LOCAL_STORAGE_OVERRIDE,\n WEB_COMPONENTS_UI_LIB_NAME,\n} from './constants';\n\nexport const descopeUiMixin = createSingletonMixin(\n <T extends CustomElementConstructor>(superclass: T) => {\n const BaseClass = compose(\n loggerMixin,\n configMixin,\n injectNpmLibMixin,\n )(superclass);\n\n return class DescopeUiMixinClass extends BaseClass {\n // eslint-disable-next-line class-methods-use-this\n async #getComponentsVersion() {\n const config = await this.config;\n const componentsVersion = config?.projectConfig?.componentsVersion;\n\n if (!componentsVersion) {\n this.logger.error('Could not get components version');\n } else {\n this.logger.debug(`Got component version \"${componentsVersion}\"`);\n }\n\n return componentsVersion;\n }\n\n #descopeUi: Promise<any>;\n\n get descopeUi() {\n if (!this.#descopeUi) {\n this.#descopeUi = this.#getDescopeUi();\n }\n\n return this.#descopeUi;\n }\n\n async #loadDescopeUiComponent(componentName: string) {\n const isComponentAlreadyDefined = !!customElements.get(componentName);\n\n if (isComponentAlreadyDefined) {\n this.logger.debug(\n `Loading component \"${componentName}\" is skipped as it is already defined`,\n );\n return undefined;\n }\n\n const descopeUI = await this.descopeUi;\n\n if (!descopeUI[componentName]) {\n this.logger.error(\n `Cannot load UI component \"${componentName}\"`,\n `Descope UI does not have a component named \"${componentName}\", available components are: \"${Object.keys(\n descopeUI,\n ).join(', ')}\"`,\n );\n return undefined;\n }\n\n try {\n // eslint-disable-next-line @typescript-eslint/return-await\n return await descopeUI[componentName]();\n } catch (e) {\n // this error is thrown when trying to register a component which is already registered\n // when running 2 flows on the same page, it might happen that the register fn is called twice\n // in case it happens, we are silently ignore the error\n if (e.name === 'NotSupportedError') {\n // eslint-disable-next-line no-console\n console.debug(\n `Encountered an error while attempting to define the \"${componentName}\" component, it is likely that this component is already defined`,\n );\n } else {\n throw e;\n }\n }\n\n return undefined;\n }\n\n async #getDescopeUi() {\n if (globalThis.DescopeUI) {\n return globalThis.DescopeUI;\n }\n\n try {\n await this.injectNpmLib(\n WEB_COMPONENTS_UI_LIB_NAME,\n await this.#getComponentsVersion(),\n JS_FILE_PATH,\n [LOCAL_STORAGE_OVERRIDE],\n );\n this.logger.debug('DescopeUI was loaded');\n return globalThis.DescopeUI;\n } catch (error) {\n this.logger.error(error);\n throw new Error('DescopeUI was not loaded');\n }\n }\n\n async loadDescopeUiComponents(\n templateOrComponentNames: HTMLTemplateElement | string[],\n ) {\n const descopeUiComponentsList = Array.isArray(templateOrComponentNames)\n ? templateOrComponentNames\n : getDescopeUiComponentsList(templateOrComponentNames);\n\n return Promise.all(\n descopeUiComponentsList.map((componentName: string) =>\n this.#loadDescopeUiComponent(componentName),\n ),\n );\n }\n };\n },\n);\n"],"names":["createSingletonMixin","compose","loggerMixin","configMixin","injectNpmLibMixin","__classPrivateFieldGet","__classPrivateFieldSet","getDescopeUiComponentsList","WEB_COMPONENTS_UI_LIB_NAME","JS_FILE_PATH","LOCAL_STORAGE_OVERRIDE"],"mappings":";;;;;;;;;;MAWa,cAAc,GAAGA,+BAAoB,CAChD,CAAqC,UAAa,KAAI;;AACpD,IAAA,MAAM,SAAS,GAAGC,kBAAO,CACvBC,uBAAW,EACXC,uBAAW,EACXC,mCAAiB,CAClB,CAAC,UAAU,CAAC,CAAC;IAEd,OAAO,EAAA,GAAA,MAAM,mBAAoB,SAAQ,SAAS,CAAA;AAA3C,YAAA,WAAA,GAAA;;;gBAeL,8BAAyB,CAAA,GAAA,CAAA,IAAA,EAAA,KAAA,CAAA,CAAA,CAAA;aAqF1B;AAnFC,YAAA,IAAI,SAAS,GAAA;AACX,gBAAA,IAAI,CAACC,4BAAA,CAAA,IAAI,EAAA,8BAAA,EAAA,GAAA,CAAW,EAAE;oBACpBC,4BAAA,CAAA,IAAI,kCAAcD,4BAAA,CAAA,IAAI,yEAAc,CAAlB,IAAA,CAAA,IAAI,CAAgB,EAAA,GAAA,CAAA,CAAC;iBACxC;gBAED,OAAOA,4BAAA,CAAA,IAAI,EAAA,8BAAA,EAAA,GAAA,CAAW,CAAC;aACxB;YAgED,MAAM,uBAAuB,CAC3B,wBAAwD,EAAA;AAExD,gBAAA,MAAM,uBAAuB,GAAG,KAAK,CAAC,OAAO,CAAC,wBAAwB,CAAC;AACrE,sBAAE,wBAAwB;AAC1B,sBAAEE,kCAA0B,CAAC,wBAAwB,CAAC,CAAC;gBAEzD,OAAO,OAAO,CAAC,GAAG,CAChB,uBAAuB,CAAC,GAAG,CAAC,CAAC,aAAqB,KAChDF,4BAAA,CAAA,IAAI,EAAA,8BAAA,EAAA,GAAA,EAAA,2CAAA,CAAwB,CAA5B,IAAA,CAAA,IAAI,EAAyB,aAAa,CAAC,CAC5C,CACF,CAAC;aACH;AACF,SAAA;;;;;QAlGC,eAAK,yCAAA,GAAA;;AACH,YAAA,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC;AACjC,YAAA,MAAM,iBAAiB,GAAG,CAAA,EAAA,GAAA,MAAM,KAAN,IAAA,IAAA,MAAM,KAAN,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,MAAM,CAAE,aAAa,MAAE,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,iBAAiB,CAAC;YAEnE,IAAI,CAAC,iBAAiB,EAAE;AACtB,gBAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,kCAAkC,CAAC,CAAC;aACvD;iBAAM;gBACL,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAA0B,uBAAA,EAAA,iBAAiB,CAAG,CAAA,CAAA,CAAC,CAAC;aACnE;AAED,YAAA,OAAO,iBAAiB,CAAC;SAC1B;AAYD,QAAA,2CAAA,GAAA,2DAA8B,aAAqB,EAAA;YACjD,MAAM,yBAAyB,GAAG,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;YAEtE,IAAI,yBAAyB,EAAE;gBAC7B,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,CAAsB,mBAAA,EAAA,aAAa,CAAuC,qCAAA,CAAA,CAC3E,CAAC;AACF,gBAAA,OAAO,SAAS,CAAC;aAClB;AAED,YAAA,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC;AAEvC,YAAA,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,EAAE;gBAC7B,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,6BAA6B,aAAa,CAAA,CAAA,CAAG,EAC7C,CAAA,4CAAA,EAA+C,aAAa,CAAA,8BAAA,EAAiC,MAAM,CAAC,IAAI,CACtG,SAAS,CACV,CAAC,IAAI,CAAC,IAAI,CAAC,CAAG,CAAA,CAAA,CAChB,CAAC;AACF,gBAAA,OAAO,SAAS,CAAC;aAClB;AAED,YAAA,IAAI;;AAEF,gBAAA,OAAO,MAAM,SAAS,CAAC,aAAa,CAAC,EAAE,CAAC;aACzC;YAAC,OAAO,CAAC,EAAE;;;;AAIV,gBAAA,IAAI,CAAC,CAAC,IAAI,KAAK,mBAAmB,EAAE;;AAElC,oBAAA,OAAO,CAAC,KAAK,CACX,wDAAwD,aAAa,CAAA,gEAAA,CAAkE,CACxI,CAAC;iBACH;qBAAM;AACL,oBAAA,MAAM,CAAC,CAAC;iBACT;aACF;AAED,YAAA,OAAO,SAAS,CAAC;SAClB;4CAED,eAAK,iCAAA,GAAA;AACH,YAAA,IAAI,UAAU,CAAC,SAAS,EAAE;gBACxB,OAAO,UAAU,CAAC,SAAS,CAAC;aAC7B;AAED,YAAA,IAAI;gBACF,MAAM,IAAI,CAAC,YAAY,CACrBG,oCAA0B,EAC1B,MAAMH,6BAAA,IAAI,EAAA,8BAAA,EAAA,GAAA,EAAA,yCAAA,CAAsB,MAA1B,IAAI,CAAwB,EAClCI,sBAAY,EACZ,CAACC,gCAAsB,CAAC,CACzB,CAAC;AACF,gBAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAAC;gBAC1C,OAAO,UAAU,CAAC,SAAS,CAAC;aAC7B;YAAC,OAAO,KAAK,EAAE;AACd,gBAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;AACzB,gBAAA,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;aAC7C;SACF;AAeD,QAAA,EAAA,CAAA;AACJ,CAAC;;;;"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const getDescopeUiComponentsList = (template) => [
|
|
4
|
+
...Array.from(template.content.querySelectorAll('*')).reduce((acc, el) => el.localName.startsWith('descope-') ? acc.add(el.localName) : acc, new Set()),
|
|
5
|
+
];
|
|
6
|
+
|
|
7
|
+
exports.getDescopeUiComponentsList = getDescopeUiComponentsList;
|
|
8
|
+
//# sourceMappingURL=helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.js","sources":["../../../../src/mixins/descopeUiMixin/helpers.ts"],"sourcesContent":["export const setupScript = (id: string) => {\n const scriptEle = document.createElement('script');\n scriptEle.id = id;\n\n return scriptEle;\n};\n\nexport const getDescopeUiComponentsList = (template: HTMLTemplateElement) => [\n ...Array.from(template.content.querySelectorAll('*')).reduce<Set<string>>(\n (acc, el: Element) =>\n el.localName.startsWith('descope-') ? acc.add(el.localName) : acc,\n new Set(),\n ),\n];\n"],"names":[],"mappings":";;MAOa,0BAA0B,GAAG,CAAC,QAA6B,KAAK;IAC3E,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,CAC1D,CAAC,GAAG,EAAE,EAAW,KACf,EAAE,CAAC,SAAS,CAAC,UAAU,CAAC,UAAU,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,SAAS,CAAC,GAAG,GAAG,EACnE,IAAI,GAAG,EAAE,CACV;;;;;"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
4
|
+
var loggerMixin = require('./loggerMixin/loggerMixin.js');
|
|
5
|
+
|
|
6
|
+
const formMixin = sdkHelpers.createSingletonMixin((superclass) => class FormMixinClass extends loggerMixin.loggerMixin(superclass) {
|
|
7
|
+
validateForm(rootEle) {
|
|
8
|
+
return this.getFormInputs(rootEle).every((input) => {
|
|
9
|
+
var _a, _b;
|
|
10
|
+
(_a = input.reportValidity) === null || _a === void 0 ? void 0 : _a.call(input);
|
|
11
|
+
return (_b = input.checkValidity) === null || _b === void 0 ? void 0 : _b.call(input);
|
|
12
|
+
});
|
|
13
|
+
}
|
|
14
|
+
// eslint-disable-next-line class-methods-use-this
|
|
15
|
+
getFormInputs(rootEle) {
|
|
16
|
+
if (!rootEle) {
|
|
17
|
+
this.logger.debug('cannot get form inputs, no root element was received');
|
|
18
|
+
return [];
|
|
19
|
+
}
|
|
20
|
+
return Array.from(rootEle.querySelectorAll('[name]'));
|
|
21
|
+
}
|
|
22
|
+
getFormData(rootEle) {
|
|
23
|
+
return this.getFormInputs(rootEle).reduce((acc, input) => Object.assign(acc, { [input.getAttribute('name')]: input.value }), {});
|
|
24
|
+
}
|
|
25
|
+
setFormData(rootEle, data) {
|
|
26
|
+
this.getFormInputs(rootEle).forEach((input) => {
|
|
27
|
+
// eslint-disable-next-line no-prototype-builtins
|
|
28
|
+
if (data.hasOwnProperty(input.getAttribute('name'))) {
|
|
29
|
+
// eslint-disable-next-line no-param-reassign
|
|
30
|
+
input.value = data[input.getAttribute('name')];
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
resetFormData(rootEle) {
|
|
35
|
+
this.getFormInputs(rootEle).forEach((input) => {
|
|
36
|
+
// eslint-disable-next-line no-param-reassign
|
|
37
|
+
input.value = '';
|
|
38
|
+
input.checked = false;
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
getFormFieldNames(rootEle) {
|
|
42
|
+
return this.getFormInputs(rootEle).map((ele) => ele.name);
|
|
43
|
+
}
|
|
44
|
+
disableFormField(rootEle, name) {
|
|
45
|
+
var _a;
|
|
46
|
+
(_a = this.getFormInputs(rootEle)
|
|
47
|
+
.find((input) => input.name === name)) === null || _a === void 0 ? void 0 : _a.setAttribute('disabled', 'true');
|
|
48
|
+
}
|
|
49
|
+
removeFormField(rootEle, name) {
|
|
50
|
+
var _a;
|
|
51
|
+
(_a = this.getFormInputs(rootEle)
|
|
52
|
+
.find((input) => input.name === name)) === null || _a === void 0 ? void 0 : _a.remove();
|
|
53
|
+
}
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
exports.formMixin = formMixin;
|
|
57
|
+
//# sourceMappingURL=formMixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formMixin.js","sources":["../../../src/mixins/formMixin.ts"],"sourcesContent":["import { createSingletonMixin } from '@descope/sdk-helpers';\nimport { loggerMixin } from './loggerMixin';\n\ntype ElementOrEmpty = Element | null | undefined;\n\nexport const formMixin = createSingletonMixin(\n <T extends CustomElementConstructor>(superclass: T) =>\n class FormMixinClass extends loggerMixin(superclass) {\n validateForm(rootEle: ElementOrEmpty) {\n return this.getFormInputs(rootEle).every((input: HTMLInputElement) => {\n input.reportValidity?.();\n return input.checkValidity?.();\n });\n }\n\n // eslint-disable-next-line class-methods-use-this\n getFormInputs(rootEle: ElementOrEmpty): HTMLInputElement[] {\n if (!rootEle) {\n this.logger.debug(\n 'cannot get form inputs, no root element was received',\n );\n return [];\n }\n return Array.from(\n rootEle.querySelectorAll('[name]'),\n ) as HTMLInputElement[];\n }\n\n getFormData(rootEle: ElementOrEmpty): any {\n return this.getFormInputs(rootEle).reduce(\n (acc, input) =>\n Object.assign(acc, { [input.getAttribute('name')!]: input.value }),\n {},\n );\n }\n\n setFormData(rootEle: ElementOrEmpty, data: Record<string, any>) {\n this.getFormInputs(rootEle).forEach((input) => {\n // eslint-disable-next-line no-prototype-builtins\n if (data.hasOwnProperty(input.getAttribute('name')!)) {\n // eslint-disable-next-line no-param-reassign\n input.value = data[input.getAttribute('name')!];\n }\n });\n }\n\n resetFormData(rootEle: ElementOrEmpty) {\n this.getFormInputs(rootEle).forEach((input) => {\n // eslint-disable-next-line no-param-reassign\n input.value = '';\n input.checked = false;\n });\n }\n\n getFormFieldNames(rootEle: ElementOrEmpty) {\n return this.getFormInputs(rootEle).map((ele) => ele.name);\n }\n\n disableFormField(rootEle: ElementOrEmpty, name: string) {\n this.getFormInputs(rootEle)\n .find((input) => input.name === name)\n ?.setAttribute('disabled', 'true');\n }\n\n removeFormField(rootEle: ElementOrEmpty, name: string) {\n this.getFormInputs(rootEle)\n .find((input) => input.name === name)\n ?.remove();\n }\n },\n);\n"],"names":["createSingletonMixin","loggerMixin"],"mappings":";;;;;AAKa,MAAA,SAAS,GAAGA,+BAAoB,CAC3C,CAAqC,UAAa,KAChD,MAAM,cAAe,SAAQC,uBAAW,CAAC,UAAU,CAAC,CAAA;AAClD,IAAA,YAAY,CAAC,OAAuB,EAAA;AAClC,QAAA,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,KAAK,CAAC,CAAC,KAAuB,KAAI;;AACnE,YAAA,CAAA,EAAA,GAAA,KAAK,CAAC,cAAc,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,IAAA,CAAA,KAAA,CAAI,CAAC;AACzB,YAAA,OAAO,CAAA,EAAA,GAAA,KAAK,CAAC,aAAa,qDAAI,CAAC;AACjC,SAAC,CAAC,CAAC;KACJ;;AAGD,IAAA,aAAa,CAAC,OAAuB,EAAA;QACnC,IAAI,CAAC,OAAO,EAAE;AACZ,YAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,sDAAsD,CACvD,CAAC;AACF,YAAA,OAAO,EAAE,CAAC;SACX;QACD,OAAO,KAAK,CAAC,IAAI,CACf,OAAO,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CACb,CAAC;KACzB;AAED,IAAA,WAAW,CAAC,OAAuB,EAAA;AACjC,QAAA,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,MAAM,CACvC,CAAC,GAAG,EAAE,KAAK,KACT,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,EAAE,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAE,GAAG,KAAK,CAAC,KAAK,EAAE,CAAC,EACpE,EAAE,CACH,CAAC;KACH;IAED,WAAW,CAAC,OAAuB,EAAE,IAAyB,EAAA;QAC5D,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,KAAI;;AAE5C,YAAA,IAAI,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAE,CAAC,EAAE;;AAEpD,gBAAA,KAAK,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,CAAE,CAAC,CAAC;aACjD;AACH,SAAC,CAAC,CAAC;KACJ;AAED,IAAA,aAAa,CAAC,OAAuB,EAAA;QACnC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,KAAI;;AAE5C,YAAA,KAAK,CAAC,KAAK,GAAG,EAAE,CAAC;AACjB,YAAA,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC;AACxB,SAAC,CAAC,CAAC;KACJ;AAED,IAAA,iBAAiB,CAAC,OAAuB,EAAA;AACvC,QAAA,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,KAAK,GAAG,CAAC,IAAI,CAAC,CAAC;KAC3D;IAED,gBAAgB,CAAC,OAAuB,EAAE,IAAY,EAAA;;AACpD,QAAA,CAAA,EAAA,GAAA,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC;AACxB,aAAA,IAAI,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC,0CACnC,YAAY,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;KACtC;IAED,eAAe,CAAC,OAAuB,EAAE,IAAY,EAAA;;AACnD,QAAA,CAAA,EAAA,GAAA,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC;AACxB,aAAA,IAAI,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,IAAI,KAAK,IAAI,CAAC,MACnC,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,MAAM,EAAE,CAAC;KACd;AACF,CAAA;;;;"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
4
|
+
|
|
5
|
+
const CONTENT_ROOT_ID = 'content-root';
|
|
6
|
+
const ROOT_ID = 'root';
|
|
7
|
+
const initElementMixin = sdkHelpers.createSingletonMixin((superclass) => class InitElementMixinClass extends superclass {
|
|
8
|
+
constructor(...rest) {
|
|
9
|
+
var _a, _b, _c;
|
|
10
|
+
var _d;
|
|
11
|
+
super(...rest);
|
|
12
|
+
this.attachShadow({ mode: 'open' }).innerHTML = `
|
|
13
|
+
<div id="${ROOT_ID}">
|
|
14
|
+
<div id="${CONTENT_ROOT_ID}"></div>
|
|
15
|
+
</div>
|
|
16
|
+
`;
|
|
17
|
+
const sheet = new CSSStyleSheet();
|
|
18
|
+
sheet.replaceSync(`
|
|
19
|
+
#${ROOT_ID}, #${CONTENT_ROOT_ID} {
|
|
20
|
+
height: 100%;
|
|
21
|
+
}
|
|
22
|
+
#${ROOT_ID} {
|
|
23
|
+
position: relative;
|
|
24
|
+
height: fit-content;
|
|
25
|
+
}
|
|
26
|
+
`);
|
|
27
|
+
(_a = (_d = this.shadowRoot).adoptedStyleSheets) !== null && _a !== void 0 ? _a : (_d.adoptedStyleSheets = []);
|
|
28
|
+
this.shadowRoot.adoptedStyleSheets = [
|
|
29
|
+
...this.shadowRoot.adoptedStyleSheets,
|
|
30
|
+
sheet,
|
|
31
|
+
];
|
|
32
|
+
this.contentRootElement =
|
|
33
|
+
(_b = this.shadowRoot) === null || _b === void 0 ? void 0 : _b.getElementById(CONTENT_ROOT_ID);
|
|
34
|
+
this.rootElement = (_c = this.shadowRoot) === null || _c === void 0 ? void 0 : _c.getElementById(ROOT_ID);
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
|
|
38
|
+
exports.initElementMixin = initElementMixin;
|
|
39
|
+
//# sourceMappingURL=initElementMixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"initElementMixin.js","sources":["../../../src/mixins/initElementMixin.ts"],"sourcesContent":["import { createSingletonMixin } from '@descope/sdk-helpers';\n\nconst CONTENT_ROOT_ID = 'content-root';\nconst ROOT_ID = 'root';\n\nexport const initElementMixin = createSingletonMixin(\n <T extends CustomElementConstructor>(superclass: T) =>\n class InitElementMixinClass extends superclass {\n // the content of contentRootElement is being replaced dynamically\n // do not place content which is not dynamic inside\n contentRootElement: HTMLElement;\n\n rootElement: HTMLElement;\n\n constructor(...rest) {\n super(...rest);\n\n this.attachShadow({ mode: 'open' }).innerHTML = `\n <div id=\"${ROOT_ID}\">\n <div id=\"${CONTENT_ROOT_ID}\"></div>\n </div>\n `;\n\n const sheet = new CSSStyleSheet();\n sheet.replaceSync(`\n #${ROOT_ID}, #${CONTENT_ROOT_ID} {\n height: 100%;\n }\n #${ROOT_ID} {\n position: relative;\n height: fit-content;\n }\n `);\n\n this.shadowRoot.adoptedStyleSheets ??= [];\n this.shadowRoot.adoptedStyleSheets = [\n ...this.shadowRoot.adoptedStyleSheets,\n sheet,\n ];\n\n this.contentRootElement =\n this.shadowRoot?.getElementById(CONTENT_ROOT_ID)!;\n this.rootElement = this.shadowRoot?.getElementById(ROOT_ID)!;\n }\n },\n);\n"],"names":["createSingletonMixin"],"mappings":";;;;AAEA,MAAM,eAAe,GAAG,cAAc,CAAC;AACvC,MAAM,OAAO,GAAG,MAAM,CAAC;AAEhB,MAAM,gBAAgB,GAAGA,+BAAoB,CAClD,CAAqC,UAAa,KAChD,MAAM,qBAAsB,SAAQ,UAAU,CAAA;AAO5C,IAAA,WAAA,CAAY,GAAG,IAAI,EAAA;;;AACjB,QAAA,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;QAEf,IAAI,CAAC,YAAY,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC,CAAC,SAAS,GAAG,CAAA;qBACnC,OAAO,CAAA;uBACL,eAAe,CAAA;;WAE3B,CAAC;AAEJ,QAAA,MAAM,KAAK,GAAG,IAAI,aAAa,EAAE,CAAC;QAClC,KAAK,CAAC,WAAW,CAAC,CAAA;AACX,aAAA,EAAA,OAAO,MAAM,eAAe,CAAA;;;eAG5B,OAAO,CAAA;;;;AAIX,UAAA,CAAA,CAAC,CAAC;QAEL,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,IAAI,CAAC,UAAU,EAAC,kBAAkB,MAAlB,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,EAAA,IAAA,EAAA,CAAA,kBAAkB,GAAK,EAAE,CAAC,CAAA;AAC1C,QAAA,IAAI,CAAC,UAAU,CAAC,kBAAkB,GAAG;AACnC,YAAA,GAAG,IAAI,CAAC,UAAU,CAAC,kBAAkB;YACrC,KAAK;SACN,CAAC;AAEF,QAAA,IAAI,CAAC,kBAAkB;YACrB,CAAA,EAAA,GAAA,IAAI,CAAC,UAAU,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAE,cAAc,CAAC,eAAe,CAAE,CAAC;AACpD,QAAA,IAAI,CAAC,WAAW,GAAG,CAAA,EAAA,GAAA,IAAI,CAAC,UAAU,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAE,cAAc,CAAC,OAAO,CAAE,CAAC;KAC9D;AACF,CAAA;;;;"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var tslib = require('tslib');
|
|
4
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
5
|
+
|
|
6
|
+
const initLifecycleMixin = sdkHelpers.createSingletonMixin((superclass) => { var _InitLifecycleMixinClass_isInit, _a; return _a = class InitLifecycleMixinClass extends superclass {
|
|
7
|
+
constructor() {
|
|
8
|
+
super(...arguments);
|
|
9
|
+
_InitLifecycleMixinClass_isInit.set(this, true);
|
|
10
|
+
}
|
|
11
|
+
connectedCallback() {
|
|
12
|
+
var _b, _c;
|
|
13
|
+
(_b = super.connectedCallback) === null || _b === void 0 ? void 0 : _b.call(this);
|
|
14
|
+
if ((_c = this.shadowRoot) === null || _c === void 0 ? void 0 : _c.isConnected) {
|
|
15
|
+
// the init function is running once, on the first time the component is connected
|
|
16
|
+
if (tslib.__classPrivateFieldGet(this, _InitLifecycleMixinClass_isInit, "f")) {
|
|
17
|
+
tslib.__classPrivateFieldSet(this, _InitLifecycleMixinClass_isInit, false, "f");
|
|
18
|
+
this.init();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
// eslint-disable-next-line class-methods-use-this, @typescript-eslint/no-empty-function
|
|
23
|
+
async init() { }
|
|
24
|
+
},
|
|
25
|
+
_InitLifecycleMixinClass_isInit = new WeakMap(),
|
|
26
|
+
_a; });
|
|
27
|
+
|
|
28
|
+
exports.initLifecycleMixin = initLifecycleMixin;
|
|
29
|
+
//# sourceMappingURL=initLifecycleMixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"initLifecycleMixin.js","sources":["../../../src/mixins/initLifecycleMixin.ts"],"sourcesContent":["import { createSingletonMixin } from '@descope/sdk-helpers';\n\nexport const initLifecycleMixin = createSingletonMixin(\n <T extends CustomElementConstructor>(superclass: T) =>\n class InitLifecycleMixinClass extends superclass {\n #isInit = true;\n\n connectedCallback() {\n super.connectedCallback?.();\n\n if (this.shadowRoot?.isConnected) {\n // the init function is running once, on the first time the component is connected\n if (this.#isInit) {\n this.#isInit = false;\n this.init();\n }\n }\n }\n\n // eslint-disable-next-line class-methods-use-this, @typescript-eslint/no-empty-function\n async init() {}\n },\n);\n"],"names":["createSingletonMixin","__classPrivateFieldGet","__classPrivateFieldSet"],"mappings":";;;;;AAEO,MAAM,kBAAkB,GAAGA,+BAAoB,CACpD,CAAqC,UAAa,KAAI,EAAA,IAAA,+BAAA,EAAA,EAAA,CAAA,CAAA,OAAA,EAAA,GACpD,MAAM,uBAAwB,SAAQ,UAAU,CAAA;AAAhD,QAAA,WAAA,GAAA;;AACE,YAAA,+BAAA,CAAA,GAAA,CAAA,IAAA,EAAU,IAAI,CAAC,CAAA;SAgBhB;QAdC,iBAAiB,GAAA;;AACf,YAAA,CAAA,EAAA,GAAA,KAAK,CAAC,iBAAiB,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,IAAA,CAAA,IAAA,CAAI,CAAC;AAE5B,YAAA,IAAI,MAAA,IAAI,CAAC,UAAU,MAAE,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,WAAW,EAAE;;AAEhC,gBAAA,IAAIC,4BAAA,CAAA,IAAI,EAAQ,+BAAA,EAAA,GAAA,CAAA,EAAE;AAChB,oBAAAC,4BAAA,CAAA,IAAI,EAAA,+BAAA,EAAW,KAAK,EAAA,GAAA,CAAA,CAAC;oBACrB,IAAI,CAAC,IAAI,EAAE,CAAC;iBACb;aACF;SACF;;QAGD,MAAM,IAAI,GAAA,GAAK;AAChB,KAAA;;AAAA,IAAA,EAAA,CAAA,EAAA;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sources":["../../../../src/mixins/injectNpmLibMixin/constants.ts"],"sourcesContent":["export const BASE_URLS = [\n 'https://descopecdn.com',\n 'https://static.descope.com',\n 'https://cdn.jsdelivr.net',\n];\n"],"names":[],"mappings":";;AAAa,MAAA,SAAS,GAAG;IACvB,wBAAwB;IACxB,4BAA4B;IAC5B,0BAA0B;;;;;"}
|
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const getExistingScript = (scriptId) => {
|
|
4
|
+
return document.querySelector(`script#${scriptId}`);
|
|
5
|
+
};
|
|
6
|
+
const isScriptLoaded = (script) => {
|
|
7
|
+
return script.getAttribute('status') === 'loaded';
|
|
8
|
+
};
|
|
9
|
+
const isScriptError = (script) => {
|
|
10
|
+
return script.getAttribute('status') === 'error';
|
|
11
|
+
};
|
|
12
|
+
const hashUrl = (url) => {
|
|
13
|
+
let hash = 0;
|
|
14
|
+
const urlStr = url.toString();
|
|
15
|
+
for (let i = 0; i < urlStr.length; i++) {
|
|
16
|
+
const char = urlStr.charCodeAt(i);
|
|
17
|
+
hash = (hash << 5) - hash + char;
|
|
18
|
+
hash = hash & hash; // Convert to 32-bit integer
|
|
19
|
+
}
|
|
20
|
+
return `${Math.abs(hash).toString()}`;
|
|
21
|
+
};
|
|
22
|
+
const setupScript = (id) => {
|
|
23
|
+
const scriptEle = document.createElement('script');
|
|
24
|
+
scriptEle.id = id;
|
|
25
|
+
return scriptEle;
|
|
26
|
+
};
|
|
27
|
+
const injectScript = (scriptId, url) => {
|
|
28
|
+
return new Promise((res, rej) => {
|
|
29
|
+
const scriptEle = setupScript(scriptId);
|
|
30
|
+
scriptEle.onerror = (error) => {
|
|
31
|
+
scriptEle.setAttribute('status', 'error');
|
|
32
|
+
rej(error);
|
|
33
|
+
};
|
|
34
|
+
scriptEle.onload = () => {
|
|
35
|
+
scriptEle.setAttribute('status', 'loaded');
|
|
36
|
+
res(scriptEle);
|
|
37
|
+
};
|
|
38
|
+
scriptEle.src = url.toString();
|
|
39
|
+
document.body.appendChild(scriptEle);
|
|
40
|
+
});
|
|
41
|
+
};
|
|
42
|
+
const handleExistingScript = (existingScript) => {
|
|
43
|
+
if (isScriptLoaded(existingScript)) {
|
|
44
|
+
return Promise.resolve(existingScript);
|
|
45
|
+
}
|
|
46
|
+
if (isScriptError(existingScript)) {
|
|
47
|
+
return Promise.reject();
|
|
48
|
+
}
|
|
49
|
+
return new Promise((res, rej) => {
|
|
50
|
+
existingScript.addEventListener('load', () => {
|
|
51
|
+
res(existingScript);
|
|
52
|
+
});
|
|
53
|
+
existingScript.addEventListener('error', (error) => {
|
|
54
|
+
rej(error);
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
};
|
|
58
|
+
const injectScriptWithFallbacks = async (scriptsData, onError) => {
|
|
59
|
+
for (const scriptData of scriptsData) {
|
|
60
|
+
const { id, url } = scriptData;
|
|
61
|
+
const existingScript = getExistingScript(id);
|
|
62
|
+
if (existingScript) {
|
|
63
|
+
try {
|
|
64
|
+
await handleExistingScript(existingScript);
|
|
65
|
+
return scriptData;
|
|
66
|
+
}
|
|
67
|
+
catch (e) {
|
|
68
|
+
onError(scriptData, true);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
try {
|
|
73
|
+
await injectScript(id, url);
|
|
74
|
+
return scriptData;
|
|
75
|
+
}
|
|
76
|
+
catch (e) {
|
|
77
|
+
onError(scriptData, false);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
throw new Error('All scripts failed to load');
|
|
82
|
+
};
|
|
83
|
+
const generateLibUrls = (baseUrls, libName, version, path = '') => baseUrls.reduce((prev, curr) => {
|
|
84
|
+
const baseUrl = curr;
|
|
85
|
+
if (!baseUrl) {
|
|
86
|
+
return prev;
|
|
87
|
+
}
|
|
88
|
+
let url;
|
|
89
|
+
try {
|
|
90
|
+
url = new URL(baseUrl);
|
|
91
|
+
}
|
|
92
|
+
catch (e) {
|
|
93
|
+
throw new Error(`Invalid URL: ${baseUrl}`);
|
|
94
|
+
}
|
|
95
|
+
const isUrlIncludesPath = url.pathname !== '/';
|
|
96
|
+
if (!isUrlIncludesPath) {
|
|
97
|
+
url.pathname = `/npm/${libName}@${version}/${path}`;
|
|
98
|
+
}
|
|
99
|
+
return [
|
|
100
|
+
...prev,
|
|
101
|
+
{
|
|
102
|
+
url: url,
|
|
103
|
+
id: `npmlib-${libName
|
|
104
|
+
.replaceAll('@', '')
|
|
105
|
+
.replaceAll('/', '_')}-${hashUrl(url)}`,
|
|
106
|
+
},
|
|
107
|
+
];
|
|
108
|
+
}, []);
|
|
109
|
+
|
|
110
|
+
exports.generateLibUrls = generateLibUrls;
|
|
111
|
+
exports.injectScriptWithFallbacks = injectScriptWithFallbacks;
|
|
112
|
+
//# sourceMappingURL=helpers.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"helpers.js","sources":["../../../../src/mixins/injectNpmLibMixin/helpers.ts"],"sourcesContent":["const getExistingScript = (scriptId: string): HTMLScriptElement => {\n return document.querySelector(`script#${scriptId}`);\n};\n\nconst isScriptLoaded = (script: HTMLScriptElement) => {\n return script.getAttribute('status') === 'loaded';\n};\n\nconst isScriptError = (script: HTMLScriptElement) => {\n return script.getAttribute('status') === 'error';\n};\n\nconst hashUrl = (url: URL) => {\n let hash = 0;\n const urlStr = url.toString();\n\n for (let i = 0; i < urlStr.length; i++) {\n const char = urlStr.charCodeAt(i);\n hash = (hash << 5) - hash + char;\n hash = hash & hash; // Convert to 32-bit integer\n }\n\n return `${Math.abs(hash).toString()}`;\n};\n\nconst setupScript = (id: string) => {\n const scriptEle = document.createElement('script');\n scriptEle.id = id;\n\n return scriptEle;\n};\n\ntype ScriptData = {\n id: string;\n url: URL;\n};\n\nconst injectScript = (scriptId: string, url: URL) => {\n return new Promise((res, rej) => {\n const scriptEle = setupScript(scriptId);\n\n scriptEle.onerror = (error) => {\n scriptEle.setAttribute('status', 'error');\n rej(error);\n };\n scriptEle.onload = () => {\n scriptEle.setAttribute('status', 'loaded');\n res(scriptEle);\n };\n\n scriptEle.src = url.toString();\n\n document.body.appendChild(scriptEle);\n });\n};\n\nconst handleExistingScript = (existingScript: HTMLScriptElement) => {\n if (isScriptLoaded(existingScript)) {\n return Promise.resolve(existingScript);\n }\n\n if (isScriptError(existingScript)) {\n return Promise.reject();\n }\n\n return new Promise((res, rej) => {\n existingScript.addEventListener('load', () => {\n res(existingScript);\n });\n\n existingScript.addEventListener('error', (error) => {\n rej(error);\n });\n });\n};\n\nexport const injectScriptWithFallbacks = async (\n scriptsData: ScriptData[],\n onError: (scriptData: ScriptData, existingScript: boolean) => void,\n) => {\n for (const scriptData of scriptsData) {\n const { id, url } = scriptData;\n const existingScript = getExistingScript(id);\n if (existingScript) {\n try {\n await handleExistingScript(existingScript);\n return scriptData;\n } catch (e) {\n onError(scriptData, true);\n }\n } else {\n try {\n await injectScript(id, url);\n return scriptData;\n } catch (e) {\n onError(scriptData, false);\n }\n }\n }\n throw new Error('All scripts failed to load');\n};\n\nexport const generateLibUrls = (\n baseUrls: string[],\n libName: string,\n version: string,\n path = '',\n) =>\n baseUrls.reduce((prev, curr) => {\n const baseUrl = curr;\n if (!baseUrl) {\n return prev;\n }\n\n let url: URL;\n try {\n url = new URL(baseUrl);\n } catch (e) {\n throw new Error(`Invalid URL: ${baseUrl}`);\n }\n\n const isUrlIncludesPath = url.pathname !== '/';\n\n if (!isUrlIncludesPath) {\n url.pathname = `/npm/${libName}@${version}/${path}`;\n }\n\n return [\n ...prev,\n {\n url: url,\n id: `npmlib-${libName\n .replaceAll('@', '')\n .replaceAll('/', '_')}-${hashUrl(url)}`,\n },\n ];\n }, []);\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
4
|
+
var loggerMixin = require('../loggerMixin/loggerMixin.js');
|
|
5
|
+
var constants = require('./constants.js');
|
|
6
|
+
var helpers = require('./helpers.js');
|
|
7
|
+
|
|
8
|
+
const injectNpmLibMixin = sdkHelpers.createSingletonMixin((superclass) => {
|
|
9
|
+
const BaseClass = sdkHelpers.compose(loggerMixin.loggerMixin)(superclass);
|
|
10
|
+
return class InjectNpmLibMixinClass extends BaseClass {
|
|
11
|
+
get baseCdnUrl() {
|
|
12
|
+
return this.getAttribute('base-cdn-url');
|
|
13
|
+
}
|
|
14
|
+
injectNpmLib(libName, version, filePath = '', overrides = []) {
|
|
15
|
+
this.logger.debug(`Injecting npm lib: "${libName}" with version: "${version}"`);
|
|
16
|
+
return helpers.injectScriptWithFallbacks(helpers.generateLibUrls([...overrides, this.baseCdnUrl, ...constants.BASE_URLS], libName, version, filePath), (scriptData, existingScript) => {
|
|
17
|
+
if (existingScript) {
|
|
18
|
+
this.logger.error(`Existing script cannot be loaded: "${scriptData.url}"`);
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
this.logger.error(`Cannot load script from URL, Make sure this URL is valid and return the correct script: "${scriptData.url}"`);
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
});
|
|
26
|
+
|
|
27
|
+
exports.injectNpmLibMixin = injectNpmLibMixin;
|
|
28
|
+
//# sourceMappingURL=injectNpmLibMixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"injectNpmLibMixin.js","sources":["../../../../src/mixins/injectNpmLibMixin/injectNpmLibMixin.ts"],"sourcesContent":["import { compose, createSingletonMixin } from '@descope/sdk-helpers';\nimport { loggerMixin } from '../loggerMixin';\nimport { BASE_URLS } from './constants';\nimport { generateLibUrls, injectScriptWithFallbacks } from './helpers';\n\n// scripts load to window under descope object\ndeclare global {\n var descope: any;\n}\n\nexport const injectNpmLibMixin = createSingletonMixin(\n <T extends CustomElementConstructor>(superclass: T) => {\n const BaseClass = compose(loggerMixin)(superclass);\n\n return class InjectNpmLibMixinClass extends BaseClass {\n get baseCdnUrl() {\n return this.getAttribute('base-cdn-url');\n }\n\n injectNpmLib(\n libName: string,\n version: string,\n filePath = '',\n overrides: string[] = [],\n ) {\n this.logger.debug(\n `Injecting npm lib: \"${libName}\" with version: \"${version}\"`,\n );\n return injectScriptWithFallbacks(\n generateLibUrls(\n [...overrides, this.baseCdnUrl, ...BASE_URLS],\n libName,\n version,\n filePath,\n ),\n (scriptData, existingScript) => {\n if (existingScript) {\n this.logger.error(\n `Existing script cannot be loaded: \"${scriptData.url}\"`,\n );\n return;\n }\n this.logger.error(\n `Cannot load script from URL, Make sure this URL is valid and return the correct script: \"${scriptData.url}\"`,\n );\n },\n );\n }\n };\n },\n);\n"],"names":["createSingletonMixin","compose","loggerMixin","injectScriptWithFallbacks","generateLibUrls","BASE_URLS"],"mappings":";;;;;;;MAUa,iBAAiB,GAAGA,+BAAoB,CACnD,CAAqC,UAAa,KAAI;IACpD,MAAM,SAAS,GAAGC,kBAAO,CAACC,uBAAW,CAAC,CAAC,UAAU,CAAC,CAAC;IAEnD,OAAO,MAAM,sBAAuB,SAAQ,SAAS,CAAA;AACnD,QAAA,IAAI,UAAU,GAAA;AACZ,YAAA,OAAO,IAAI,CAAC,YAAY,CAAC,cAAc,CAAC,CAAC;SAC1C;QAED,YAAY,CACV,OAAe,EACf,OAAe,EACf,QAAQ,GAAG,EAAE,EACb,SAAA,GAAsB,EAAE,EAAA;YAExB,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,CAAuB,oBAAA,EAAA,OAAO,CAAoB,iBAAA,EAAA,OAAO,CAAG,CAAA,CAAA,CAC7D,CAAC;AACF,YAAA,OAAOC,iCAAyB,CAC9BC,uBAAe,CACb,CAAC,GAAG,SAAS,EAAE,IAAI,CAAC,UAAU,EAAE,GAAGC,mBAAS,CAAC,EAC7C,OAAO,EACP,OAAO,EACP,QAAQ,CACT,EACD,CAAC,UAAU,EAAE,cAAc,KAAI;gBAC7B,IAAI,cAAc,EAAE;oBAClB,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,CAAsC,mCAAA,EAAA,UAAU,CAAC,GAAG,CAAG,CAAA,CAAA,CACxD,CAAC;oBACF,OAAO;iBACR;gBACD,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,CAA4F,yFAAA,EAAA,UAAU,CAAC,GAAG,CAAG,CAAA,CAAA,CAC9G,CAAC;AACJ,aAAC,CACF,CAAC;SACH;KACF,CAAC;AACJ,CAAC;;;;"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var tslib = require('tslib');
|
|
4
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
5
|
+
|
|
6
|
+
const logLevels = ['error', 'warn', 'info', 'debug'];
|
|
7
|
+
const loggerMixin = sdkHelpers.createSingletonMixin((superclass) => { var _LoggerMixinClass_instances, _LoggerMixinClass_logger, _LoggerMixinClass_wrapLogger, _a; return _a = class LoggerMixinClass extends superclass {
|
|
8
|
+
constructor() {
|
|
9
|
+
super(...arguments);
|
|
10
|
+
_LoggerMixinClass_instances.add(this);
|
|
11
|
+
_LoggerMixinClass_logger.set(this, tslib.__classPrivateFieldGet(this, _LoggerMixinClass_instances, "m", _LoggerMixinClass_wrapLogger).call(this, console));
|
|
12
|
+
}
|
|
13
|
+
set logger(logger) {
|
|
14
|
+
tslib.__classPrivateFieldSet(this, _LoggerMixinClass_logger, tslib.__classPrivateFieldGet(this, _LoggerMixinClass_instances, "m", _LoggerMixinClass_wrapLogger).call(this, logger || console), "f");
|
|
15
|
+
}
|
|
16
|
+
get logger() {
|
|
17
|
+
return tslib.__classPrivateFieldGet(this, _LoggerMixinClass_logger, "f");
|
|
18
|
+
}
|
|
19
|
+
// eslint-disable-next-line class-methods-use-this, @typescript-eslint/no-unused-vars
|
|
20
|
+
onLogEvent(logLevel, data) { }
|
|
21
|
+
},
|
|
22
|
+
_LoggerMixinClass_logger = new WeakMap(),
|
|
23
|
+
_LoggerMixinClass_instances = new WeakSet(),
|
|
24
|
+
_LoggerMixinClass_wrapLogger = function _LoggerMixinClass_wrapLogger(logger) {
|
|
25
|
+
return logLevels.reduce((acc, logLevel) => {
|
|
26
|
+
acc[logLevel] = (...args) => {
|
|
27
|
+
var _b;
|
|
28
|
+
this.onLogEvent(logLevel, args);
|
|
29
|
+
(_b = logger[logLevel]) === null || _b === void 0 ? void 0 : _b.call(logger, ...args);
|
|
30
|
+
};
|
|
31
|
+
return acc;
|
|
32
|
+
}, {});
|
|
33
|
+
},
|
|
34
|
+
_a; });
|
|
35
|
+
|
|
36
|
+
exports.loggerMixin = loggerMixin;
|
|
37
|
+
//# sourceMappingURL=loggerMixin.js.map
|