@descope/sdk-mixins 0.0.0-next-cd745c61-20250421 → 0.0.0-next-bd24a0f1-20250505
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":"constants.js","sources":["../../src/constants.ts"],"sourcesContent":["export const IS_LOCAL_STORAGE = typeof localStorage !== 'undefined';\n"],"names":[],"mappings":";;MAAa,gBAAgB,GAAG,OAAO,YAAY,KAAK;;;;"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var configMixin = require('./mixins/configMixin/configMixin.js');
|
|
4
|
+
var createValidateAttributesMixin = require('./mixins/createValidateAttributesMixin/createValidateAttributesMixin.js');
|
|
5
|
+
var debuggerMixin = require('./mixins/debuggerMixin/debuggerMixin.js');
|
|
6
|
+
var descopeUiMixin = require('./mixins/descopeUiMixin/descopeUiMixin.js');
|
|
7
|
+
var loggerMixin = require('./mixins/loggerMixin/loggerMixin.js');
|
|
8
|
+
var modalMixin = require('./mixins/modalMixin/modalMixin.js');
|
|
9
|
+
var notificationsMixin = require('./mixins/notificationsMixin/notificationsMixin.js');
|
|
10
|
+
var observeAttributesMixin = require('./mixins/observeAttributesMixin/observeAttributesMixin.js');
|
|
11
|
+
var staticResourcesMixin = require('./mixins/staticResourcesMixin/staticResourcesMixin.js');
|
|
12
|
+
var themeMixin = require('./mixins/themeMixin/themeMixin.js');
|
|
13
|
+
var createStateManagementMixin = require('./mixins/createStateManagementMixin.js');
|
|
14
|
+
var formMixin = require('./mixins/formMixin.js');
|
|
15
|
+
var initElementMixin = require('./mixins/initElementMixin.js');
|
|
16
|
+
var initLifecycleMixin = require('./mixins/initLifecycleMixin.js');
|
|
17
|
+
var projectIdMixin = require('./mixins/projectIdMixin.js');
|
|
18
|
+
var baseUrlMixin = require('./mixins/baseUrlMixin.js');
|
|
19
|
+
var cookieConfigMixin = require('./mixins/cookieConfigMixin.js');
|
|
20
|
+
var injectNpmLibMixin = require('./mixins/injectNpmLibMixin/injectNpmLibMixin.js');
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
exports.configMixin = configMixin.configMixin;
|
|
25
|
+
exports.createValidateAttributesMixin = createValidateAttributesMixin.createValidateAttributesMixin;
|
|
26
|
+
exports.debuggerMixin = debuggerMixin.debuggerMixin;
|
|
27
|
+
exports.descopeUiMixin = descopeUiMixin.descopeUiMixin;
|
|
28
|
+
exports.loggerMixin = loggerMixin.loggerMixin;
|
|
29
|
+
exports.modalMixin = modalMixin.modalMixin;
|
|
30
|
+
exports.notificationsMixin = notificationsMixin.notificationsMixin;
|
|
31
|
+
exports.observeAttributesMixin = observeAttributesMixin.observeAttributesMixin;
|
|
32
|
+
exports.getResourceUrl = staticResourcesMixin.getResourceUrl;
|
|
33
|
+
exports.staticResourcesMixin = staticResourcesMixin.staticResourcesMixin;
|
|
34
|
+
exports.themeMixin = themeMixin.themeMixin;
|
|
35
|
+
exports.createStateManagementMixin = createStateManagementMixin.createStateManagementMixin;
|
|
36
|
+
exports.formMixin = formMixin.formMixin;
|
|
37
|
+
exports.initElementMixin = initElementMixin.initElementMixin;
|
|
38
|
+
exports.initLifecycleMixin = initLifecycleMixin.initLifecycleMixin;
|
|
39
|
+
exports.projectIdMixin = projectIdMixin.projectIdMixin;
|
|
40
|
+
exports.baseUrlMixin = baseUrlMixin.baseUrlMixin;
|
|
41
|
+
exports.cookieConfigMixin = cookieConfigMixin.cookieConfigMixin;
|
|
42
|
+
exports.injectNpmLibMixin = injectNpmLibMixin.injectNpmLibMixin;
|
|
43
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
4
|
+
|
|
5
|
+
const baseUrlMixin = sdkHelpers.createSingletonMixin((superclass) => {
|
|
6
|
+
return class BaseUrlMixinClass extends superclass {
|
|
7
|
+
get baseUrl() {
|
|
8
|
+
return this.getAttribute('base-url') || '';
|
|
9
|
+
}
|
|
10
|
+
};
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
exports.baseUrlMixin = baseUrlMixin;
|
|
14
|
+
//# sourceMappingURL=baseUrlMixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"baseUrlMixin.js","sources":["../../../src/mixins/baseUrlMixin.ts"],"sourcesContent":["import { createSingletonMixin } from '@descope/sdk-helpers';\n\nexport const baseUrlMixin = createSingletonMixin(\n <T extends CustomElementConstructor>(superclass: T) => {\n return class BaseUrlMixinClass extends superclass {\n get baseUrl() {\n return this.getAttribute('base-url') || '';\n }\n };\n },\n);\n"],"names":["createSingletonMixin"],"mappings":";;;;MAEa,YAAY,GAAGA,+BAAoB,CAC9C,CAAqC,UAAa,KAAI;IACpD,OAAO,MAAM,iBAAkB,SAAQ,UAAU,CAAA;AAC/C,QAAA,IAAI,OAAO,GAAA;YACT,OAAO,IAAI,CAAC,YAAY,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;SAC5C;KACF,CAAC;AACJ,CAAC;;;;"}
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var tslib = require('tslib');
|
|
4
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
5
|
+
var staticResourcesMixin = require('../staticResourcesMixin/staticResourcesMixin.js');
|
|
6
|
+
var constants = require('./constants.js');
|
|
7
|
+
var resetMixin = require('../resetMixin.js');
|
|
8
|
+
var initLifecycleMixin = require('../initLifecycleMixin.js');
|
|
9
|
+
|
|
10
|
+
const configMixin = sdkHelpers.createSingletonMixin((superclass) => {
|
|
11
|
+
var _ConfigMixinClass_instances, _ConfigMixinClass_configCacheClear, _ConfigMixinClass__configResource, _ConfigMixinClass_fetchConfig, _a;
|
|
12
|
+
const BaseClass = sdkHelpers.compose(staticResourcesMixin.staticResourcesMixin, resetMixin.resetMixin, initLifecycleMixin.initLifecycleMixin)(superclass);
|
|
13
|
+
return _a = class ConfigMixinClass extends BaseClass {
|
|
14
|
+
constructor() {
|
|
15
|
+
super(...arguments);
|
|
16
|
+
_ConfigMixinClass_instances.add(this);
|
|
17
|
+
_ConfigMixinClass__configResource.set(this, void 0);
|
|
18
|
+
_ConfigMixinClass_fetchConfig.set(this, async () => {
|
|
19
|
+
try {
|
|
20
|
+
const { body, headers, } = await this.fetchStaticResource(constants.CONFIG_FILENAME, 'json');
|
|
21
|
+
return {
|
|
22
|
+
projectConfig: body,
|
|
23
|
+
executionContext: { geo: headers['x-geo'] },
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
catch (e) {
|
|
27
|
+
this.logger.error('Cannot fetch config file', 'make sure that your projectId & flowId are correct');
|
|
28
|
+
}
|
|
29
|
+
return undefined;
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
async init() {
|
|
33
|
+
await super.init();
|
|
34
|
+
this.onReset('config', tslib.__classPrivateFieldGet(this, _ConfigMixinClass_instances, "m", _ConfigMixinClass_configCacheClear).bind(this));
|
|
35
|
+
}
|
|
36
|
+
get config() {
|
|
37
|
+
if (!tslib.__classPrivateFieldGet(this, _ConfigMixinClass__configResource, "f")) {
|
|
38
|
+
tslib.__classPrivateFieldSet(this, _ConfigMixinClass__configResource, tslib.__classPrivateFieldGet(this, _ConfigMixinClass_fetchConfig, "f").call(this), "f");
|
|
39
|
+
}
|
|
40
|
+
return tslib.__classPrivateFieldGet(this, _ConfigMixinClass__configResource, "f");
|
|
41
|
+
}
|
|
42
|
+
},
|
|
43
|
+
_ConfigMixinClass__configResource = new WeakMap(),
|
|
44
|
+
_ConfigMixinClass_fetchConfig = new WeakMap(),
|
|
45
|
+
_ConfigMixinClass_instances = new WeakSet(),
|
|
46
|
+
_ConfigMixinClass_configCacheClear = function _ConfigMixinClass_configCacheClear() {
|
|
47
|
+
tslib.__classPrivateFieldSet(this, _ConfigMixinClass__configResource, undefined, "f");
|
|
48
|
+
},
|
|
49
|
+
_a;
|
|
50
|
+
});
|
|
51
|
+
|
|
52
|
+
exports.configMixin = configMixin;
|
|
53
|
+
//# sourceMappingURL=configMixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"configMixin.js","sources":["../../../../src/mixins/configMixin/configMixin.ts"],"sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport { compose, createSingletonMixin } from '@descope/sdk-helpers';\nimport { staticResourcesMixin } from '../staticResourcesMixin';\nimport { CONFIG_FILENAME } from './constants';\nimport { Config, ProjectConfiguration } from './types';\nimport { resetMixin } from '../resetMixin';\nimport { initLifecycleMixin } from '../initLifecycleMixin';\n\nexport const configMixin = createSingletonMixin(\n <T extends CustomElementConstructor>(superclass: T) => {\n const BaseClass = compose(\n staticResourcesMixin,\n resetMixin,\n initLifecycleMixin,\n )(superclass);\n\n return class ConfigMixinClass extends BaseClass {\n async init() {\n await super.init();\n this.onReset('config', this.#configCacheClear.bind(this));\n }\n\n get config() {\n if (!this.#_configResource) {\n this.#_configResource = this.#fetchConfig();\n }\n\n return this.#_configResource;\n }\n\n #configCacheClear() {\n this.#_configResource = undefined;\n }\n\n #_configResource: Promise<Config>;\n\n #fetchConfig: () => Promise<Config> = async () => {\n try {\n const {\n body,\n headers,\n }: { body: ProjectConfiguration; headers: Record<string, any> } =\n await (<any>this.fetchStaticResource(CONFIG_FILENAME, 'json'));\n return {\n projectConfig: body as ProjectConfiguration,\n executionContext: { geo: headers['x-geo'] },\n };\n } catch (e) {\n this.logger.error(\n 'Cannot fetch config file',\n 'make sure that your projectId & flowId are correct',\n );\n }\n\n return undefined;\n };\n };\n },\n);\n"],"names":["createSingletonMixin","compose","staticResourcesMixin","resetMixin","initLifecycleMixin","CONFIG_FILENAME","__classPrivateFieldGet","__classPrivateFieldSet"],"mappings":";;;;;;;;;MAQa,WAAW,GAAGA,+BAAoB,CAC7C,CAAqC,UAAa,KAAI;;AACpD,IAAA,MAAM,SAAS,GAAGC,kBAAO,CACvBC,yCAAoB,EACpBC,qBAAU,EACVC,qCAAkB,CACnB,CAAC,UAAU,CAAC,CAAC;IAEd,OAAO,EAAA,GAAA,MAAM,gBAAiB,SAAQ,SAAS,CAAA;AAAxC,YAAA,WAAA,GAAA;;;gBAkBL,iCAAkC,CAAA,GAAA,CAAA,IAAA,EAAA,KAAA,CAAA,CAAA,CAAA;gBAElC,6BAAsC,CAAA,GAAA,CAAA,IAAA,EAAA,YAAW;AAC/C,oBAAA,IAAI;AACF,wBAAA,MAAM,EACJ,IAAI,EACJ,OAAO,GACR,GACC,MAAY,IAAI,CAAC,mBAAmB,CAACC,yBAAe,EAAE,MAAM,CAAE,CAAC;wBACjE,OAAO;AACL,4BAAA,aAAa,EAAE,IAA4B;4BAC3C,gBAAgB,EAAE,EAAE,GAAG,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE;yBAC5C,CAAC;qBACH;oBAAC,OAAO,CAAC,EAAE;wBACV,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,0BAA0B,EAC1B,oDAAoD,CACrD,CAAC;qBACH;AAED,oBAAA,OAAO,SAAS,CAAC;AACnB,iBAAC,CAAC,CAAA;aACH;AAvCC,YAAA,MAAM,IAAI,GAAA;AACR,gBAAA,MAAM,KAAK,CAAC,IAAI,EAAE,CAAC;AACnB,gBAAA,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAEC,4BAAA,CAAA,IAAI,EAAkB,2BAAA,EAAA,GAAA,EAAA,kCAAA,CAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;aAC3D;AAED,YAAA,IAAI,MAAM,GAAA;AACR,gBAAA,IAAI,CAACA,4BAAA,CAAA,IAAI,EAAA,iCAAA,EAAA,GAAA,CAAiB,EAAE;oBAC1BC,4BAAA,CAAA,IAAI,qCAAoBD,4BAAA,CAAA,IAAI,qCAAa,CAAjB,IAAA,CAAA,IAAI,CAAe,EAAA,GAAA,CAAA,CAAC;iBAC7C;gBAED,OAAOA,4BAAA,CAAA,IAAI,EAAA,iCAAA,EAAA,GAAA,CAAiB,CAAC;aAC9B;AA4BF,SAAA;;;;;AAzBG,YAAAC,4BAAA,CAAA,IAAI,EAAA,iCAAA,EAAoB,SAAS,EAAA,GAAA,CAAA,CAAC;SACnC;AAwBD,QAAA,EAAA,CAAA;AACJ,CAAC;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sources":["../../../../src/mixins/configMixin/constants.ts"],"sourcesContent":["export const CONFIG_FILENAME = 'config.json';\n"],"names":[],"mappings":";;AAAO,MAAM,eAAe,GAAG;;;;"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
4
|
+
|
|
5
|
+
const cookieConfigMixin = sdkHelpers.createSingletonMixin((superclass) => {
|
|
6
|
+
return class CookieConfigMixinClass extends superclass {
|
|
7
|
+
get refreshCookieName() {
|
|
8
|
+
return this.getAttribute('refresh-cookie-name') || '';
|
|
9
|
+
}
|
|
10
|
+
};
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
exports.cookieConfigMixin = cookieConfigMixin;
|
|
14
|
+
//# sourceMappingURL=cookieConfigMixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cookieConfigMixin.js","sources":["../../../src/mixins/cookieConfigMixin.ts"],"sourcesContent":["import { createSingletonMixin } from '@descope/sdk-helpers';\n\nexport const cookieConfigMixin = createSingletonMixin(\n <T extends CustomElementConstructor>(superclass: T) => {\n return class CookieConfigMixinClass extends superclass {\n get refreshCookieName() {\n return this.getAttribute('refresh-cookie-name') || '';\n }\n };\n },\n);\n"],"names":["createSingletonMixin"],"mappings":";;;;MAEa,iBAAiB,GAAGA,+BAAoB,CACnD,CAAqC,UAAa,KAAI;IACpD,OAAO,MAAM,sBAAuB,SAAQ,UAAU,CAAA;AACpD,QAAA,IAAI,iBAAiB,GAAA;YACnB,OAAO,IAAI,CAAC,YAAY,CAAC,qBAAqB,CAAC,IAAI,EAAE,CAAC;SACvD;KACF,CAAC;AACJ,CAAC;;;;"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
4
|
+
var toolkit = require('@reduxjs/toolkit');
|
|
5
|
+
var loggerMixin = require('./loggerMixin/loggerMixin.js');
|
|
6
|
+
|
|
7
|
+
/* eslint-disable no-param-reassign */
|
|
8
|
+
const createStateManagementMixin = (options) => sdkHelpers.createSingletonMixin((superclass) => {
|
|
9
|
+
const slice = toolkit.createSlice(options);
|
|
10
|
+
const allActions = Object.assign(Object.assign({}, slice.actions), options.asyncActions);
|
|
11
|
+
return class StateManagementMixinClass extends sdkHelpers.compose(loggerMixin.loggerMixin)(superclass) {
|
|
12
|
+
constructor(...args) {
|
|
13
|
+
super(...args);
|
|
14
|
+
const store = toolkit.configureStore({
|
|
15
|
+
reducer: slice.reducer,
|
|
16
|
+
middleware: (getDefaultMiddleware) => getDefaultMiddleware({
|
|
17
|
+
thunk: {
|
|
18
|
+
extraArgument: this,
|
|
19
|
+
},
|
|
20
|
+
serializableCheck: false,
|
|
21
|
+
}),
|
|
22
|
+
// change to true if we want to debug redux
|
|
23
|
+
devTools: false,
|
|
24
|
+
});
|
|
25
|
+
const wrapAction = (action) => (async (...arg) => {
|
|
26
|
+
const result = await store.dispatch(action(...arg));
|
|
27
|
+
// we want to unwrap the result, so in case of an error we can log it
|
|
28
|
+
try {
|
|
29
|
+
toolkit.unwrapResult(result);
|
|
30
|
+
}
|
|
31
|
+
catch (e) {
|
|
32
|
+
this.logger.error(e.message, result.type, e.stack);
|
|
33
|
+
}
|
|
34
|
+
return result;
|
|
35
|
+
});
|
|
36
|
+
const actions = Object.keys(allActions).reduce((acc, actionName) => {
|
|
37
|
+
acc[actionName] = wrapAction(allActions[actionName]);
|
|
38
|
+
return acc;
|
|
39
|
+
}, {});
|
|
40
|
+
this.actions = actions;
|
|
41
|
+
this.subscribe = (cb, selector = (state) => state) => store.subscribe(() => cb(selector(store.getState())));
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
exports.createStateManagementMixin = createStateManagementMixin;
|
|
47
|
+
//# sourceMappingURL=createStateManagementMixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createStateManagementMixin.js","sources":["../../../src/mixins/createStateManagementMixin.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport { compose, createSingletonMixin } from '@descope/sdk-helpers';\nimport type {\n CreateSliceOptions,\n Draft,\n SliceCaseReducers,\n SliceSelectors,\n} from '@reduxjs/toolkit';\nimport { configureStore, createSlice, unwrapResult } from '@reduxjs/toolkit';\nimport type { Unsubscribe } from 'redux'; // workaround for https://github.com/microsoft/TypeScript/issues/42873\nimport { loggerMixin } from './loggerMixin';\n\nexport const createStateManagementMixin = <\n State,\n CaseReducers extends SliceCaseReducers<State>,\n Name extends string,\n Selectors extends SliceSelectors<State>,\n ReducerPath extends string = Name,\n AsyncActions extends Record<string, any> = {},\n>(\n options: CreateSliceOptions<\n State,\n CaseReducers,\n Name,\n ReducerPath,\n Selectors\n > & { asyncActions?: AsyncActions },\n) =>\n createSingletonMixin(<T extends CustomElementConstructor>(superclass: T) => {\n const slice = createSlice(options);\n\n const allActions = { ...slice.actions, ...options.asyncActions };\n\n return class StateManagementMixinClass extends compose(loggerMixin)(\n superclass,\n ) {\n actions: typeof allActions;\n\n subscribe: <SelectorR = State extends Draft<infer S> ? S : State>(\n cb: (state: SelectorR) => void,\n selector?: (state: State) => SelectorR,\n ) => Unsubscribe;\n\n constructor(...args: any) {\n super(...args);\n\n const store = configureStore({\n reducer: slice.reducer,\n middleware: (getDefaultMiddleware) =>\n getDefaultMiddleware({\n thunk: {\n extraArgument: this,\n },\n serializableCheck: false,\n }),\n // change to true if we want to debug redux\n devTools: false,\n });\n\n const wrapAction = <F extends (...args: any[]) => any>(action: F) =>\n (async (...arg: any[]) => {\n const result = await store.dispatch(action(...arg));\n\n // we want to unwrap the result, so in case of an error we can log it\n try {\n unwrapResult(result);\n } catch (e) {\n this.logger.error(e.message, result.type, e.stack);\n }\n\n return result;\n }) as F;\n\n const actions = Object.keys(allActions).reduce((acc, actionName) => {\n acc[actionName] = wrapAction(allActions[actionName]);\n\n return acc;\n }, {}) as typeof slice.actions & typeof options.asyncActions;\n\n this.actions = actions;\n\n this.subscribe = (cb, selector = (state) => state as any) =>\n store.subscribe(() => cb(selector(store.getState())));\n }\n };\n });\n"],"names":["createSingletonMixin","createSlice","compose","loggerMixin","configureStore","unwrapResult"],"mappings":";;;;;;AAAA;AAYO,MAAM,0BAA0B,GAAG,CAQxC,OAMmC,KAEnCA,+BAAoB,CAAC,CAAqC,UAAa,KAAI;AACzE,IAAA,MAAM,KAAK,GAAGC,mBAAW,CAAC,OAAO,CAAC,CAAC;IAEnC,MAAM,UAAU,GAAQ,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,MAAA,CAAA,EAAA,EAAA,KAAK,CAAC,OAAO,GAAK,OAAO,CAAC,YAAY,CAAE,CAAC;IAEjE,OAAO,MAAM,yBAA0B,SAAQC,kBAAO,CAACC,uBAAW,CAAC,CACjE,UAAU,CACX,CAAA;AAQC,QAAA,WAAA,CAAY,GAAG,IAAS,EAAA;AACtB,YAAA,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;YAEf,MAAM,KAAK,GAAGC,sBAAc,CAAC;gBAC3B,OAAO,EAAE,KAAK,CAAC,OAAO;AACtB,gBAAA,UAAU,EAAE,CAAC,oBAAoB,KAC/B,oBAAoB,CAAC;AACnB,oBAAA,KAAK,EAAE;AACL,wBAAA,aAAa,EAAE,IAAI;AACpB,qBAAA;AACD,oBAAA,iBAAiB,EAAE,KAAK;iBACzB,CAAC;;AAEJ,gBAAA,QAAQ,EAAE,KAAK;AAChB,aAAA,CAAC,CAAC;AAEH,YAAA,MAAM,UAAU,GAAG,CAAoC,MAAS,MAC7D,OAAO,GAAG,GAAU,KAAI;AACvB,gBAAA,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC;;AAGpD,gBAAA,IAAI;oBACFC,oBAAY,CAAC,MAAM,CAAC,CAAC;iBACtB;gBAAC,OAAO,CAAC,EAAE;AACV,oBAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;iBACpD;AAED,gBAAA,OAAO,MAAM,CAAC;AAChB,aAAC,CAAM,CAAC;AAEV,YAAA,MAAM,OAAO,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,UAAU,KAAI;gBACjE,GAAG,CAAC,UAAU,CAAC,GAAG,UAAU,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC;AAErD,gBAAA,OAAO,GAAG,CAAC;aACZ,EAAE,EAAE,CAAuD,CAAC;AAE7D,YAAA,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;AAEvB,YAAA,IAAI,CAAC,SAAS,GAAG,CAAC,EAAE,EAAE,QAAA,GAAW,CAAC,KAAK,KAAK,KAAY,KACtD,KAAK,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC;SACzD;KACF,CAAC;AACJ,CAAC;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"commonValidators.js","sources":["../../../../src/mixins/createValidateAttributesMixin/commonValidators.ts"],"sourcesContent":["export const missingAttrValidator = (attrName: string, value: string | null) =>\n !value &&\n `${attrName} cannot be empty, please make sure to set this attribute`;\n"],"names":[],"mappings":";;AAAO,MAAM,oBAAoB,GAAG,CAAC,QAAgB,EAAE,KAAoB,KACzE,CAAC,KAAK;IACN,CAAG,EAAA,QAAQ;;;;"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var tslib = require('tslib');
|
|
4
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
5
|
+
var observeAttributesMixin = require('../observeAttributesMixin/observeAttributesMixin.js');
|
|
6
|
+
var initLifecycleMixin = require('../initLifecycleMixin.js');
|
|
7
|
+
var loggerMixin = require('../loggerMixin/loggerMixin.js');
|
|
8
|
+
var commonValidators = require('./commonValidators.js');
|
|
9
|
+
|
|
10
|
+
const createValidateAttributesMixin = (mappings) => (superclass) => {
|
|
11
|
+
var _ValidateAttributesMixinClass_instances, _ValidateAttributesMixinClass_handleError, _a;
|
|
12
|
+
const BaseClass = sdkHelpers.compose(loggerMixin.loggerMixin, initLifecycleMixin.initLifecycleMixin, observeAttributesMixin.observeAttributesMixin)(superclass);
|
|
13
|
+
const mappingsNames = Object.keys(mappings);
|
|
14
|
+
return _a = class ValidateAttributesMixinClass extends BaseClass {
|
|
15
|
+
constructor(...args) {
|
|
16
|
+
super(...args);
|
|
17
|
+
_ValidateAttributesMixinClass_instances.add(this);
|
|
18
|
+
this.observeAttributes(mappingsNames, tslib.__classPrivateFieldGet(this, _ValidateAttributesMixinClass_instances, "m", _ValidateAttributesMixinClass_handleError).bind(this));
|
|
19
|
+
}
|
|
20
|
+
async init() {
|
|
21
|
+
var _b;
|
|
22
|
+
// check attributes initial values
|
|
23
|
+
mappingsNames.forEach((attr) => tslib.__classPrivateFieldGet(this, _ValidateAttributesMixinClass_instances, "m", _ValidateAttributesMixinClass_handleError).call(this, attr, this.getAttribute(attr)));
|
|
24
|
+
await ((_b = super.init) === null || _b === void 0 ? void 0 : _b.call(this));
|
|
25
|
+
}
|
|
26
|
+
},
|
|
27
|
+
_ValidateAttributesMixinClass_instances = new WeakSet(),
|
|
28
|
+
_ValidateAttributesMixinClass_handleError = function _ValidateAttributesMixinClass_handleError(attrName, newValue) {
|
|
29
|
+
const onError = mappings[attrName];
|
|
30
|
+
const error = typeof onError === 'function' ? onError(attrName, newValue) : onError;
|
|
31
|
+
if (error) {
|
|
32
|
+
this.logger.error(error);
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
_a;
|
|
36
|
+
};
|
|
37
|
+
createValidateAttributesMixin.missingAttrValidator = commonValidators.missingAttrValidator;
|
|
38
|
+
|
|
39
|
+
exports.createValidateAttributesMixin = createValidateAttributesMixin;
|
|
40
|
+
//# sourceMappingURL=createValidateAttributesMixin.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createValidateAttributesMixin.js","sources":["../../../../src/mixins/createValidateAttributesMixin/createValidateAttributesMixin.ts"],"sourcesContent":["import { compose } from '@descope/sdk-helpers';\nimport { observeAttributesMixin } from '../observeAttributesMixin';\nimport { initLifecycleMixin } from '../initLifecycleMixin';\nimport { loggerMixin } from '../loggerMixin';\nimport { missingAttrValidator } from './commonValidators';\n\nconst createValidateAttributesMixin =\n (mappings: Record<string, CheckValueFn | string>) =>\n <T extends CustomElementConstructor>(superclass: T) => {\n const BaseClass = compose(\n loggerMixin,\n initLifecycleMixin,\n observeAttributesMixin,\n )(superclass);\n const mappingsNames = Object.keys(mappings);\n\n return class ValidateAttributesMixinClass extends BaseClass {\n #handleError(attrName: string, newValue: string | null) {\n const onError = mappings[attrName];\n\n const error =\n typeof onError === 'function' ? onError(attrName, newValue) : onError;\n\n if (error) {\n this.logger.error(error);\n }\n }\n\n constructor(...args: any) {\n super(...args);\n\n this.observeAttributes(mappingsNames, this.#handleError.bind(this));\n }\n\n async init() {\n // check attributes initial values\n mappingsNames.forEach((attr) =>\n this.#handleError(attr, this.getAttribute(attr)),\n );\n await super.init?.();\n }\n };\n };\n\ncreateValidateAttributesMixin.missingAttrValidator = missingAttrValidator;\n\nexport type CheckValueFn = (\n attrName: string,\n value: string | null,\n) => false | string;\n\nexport { createValidateAttributesMixin };\n"],"names":["compose","loggerMixin","initLifecycleMixin","observeAttributesMixin","__classPrivateFieldGet","missingAttrValidator"],"mappings":";;;;;;;;;AAMM,MAAA,6BAA6B,GACjC,CAAC,QAA+C,KAChD,CAAqC,UAAa,KAAI;;AACpD,IAAA,MAAM,SAAS,GAAGA,kBAAO,CACvBC,uBAAW,EACXC,qCAAkB,EAClBC,6CAAsB,CACvB,CAAC,UAAU,CAAC,CAAC;IACd,MAAM,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAE5C,OAAO,EAAA,GAAA,MAAM,4BAA6B,SAAQ,SAAS,CAAA;AAYzD,YAAA,WAAA,CAAY,GAAG,IAAS,EAAA;AACtB,gBAAA,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;;AAEf,gBAAA,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAEC,4BAAA,CAAA,IAAI,EAAa,uCAAA,EAAA,GAAA,EAAA,yCAAA,CAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;aACrE;AAED,YAAA,MAAM,IAAI,GAAA;;;gBAER,aAAa,CAAC,OAAO,CAAC,CAAC,IAAI,KACzBA,4BAAA,CAAA,IAAI,EAAa,uCAAA,EAAA,GAAA,EAAA,yCAAA,CAAA,CAAA,IAAA,CAAjB,IAAI,EAAc,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CACjD,CAAC;AACF,gBAAA,OAAM,CAAA,EAAA,GAAA,KAAK,CAAC,IAAI,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAA,IAAA,CAAA,IAAA,CAAI,CAAA,CAAC;aACtB;AACF,SAAA;;AAxBc,QAAA,yCAAA,GAAA,SAAA,yCAAA,CAAA,QAAgB,EAAE,QAAuB,EAAA;AACpD,YAAA,MAAM,OAAO,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC;AAEnC,YAAA,MAAM,KAAK,GACT,OAAO,OAAO,KAAK,UAAU,GAAG,OAAO,CAAC,QAAQ,EAAE,QAAQ,CAAC,GAAG,OAAO,CAAC;YAExE,IAAI,KAAK,EAAE;AACT,gBAAA,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;aAC1B;SACF;AAeD,QAAA,EAAA,CAAA;AACJ,EAAE;AAEJ,6BAA6B,CAAC,oBAAoB,GAAGC,qCAAoB;;;;"}
|
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var tslib = require('tslib');
|
|
6
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
7
|
+
var helpers = require('./helpers.js');
|
|
8
|
+
|
|
9
|
+
var _Debugger_instances, _Debugger_messagesState, _Debugger_rootEle, _Debugger_contentEle, _Debugger_headerEle, _Debugger_eventsCbRefs, _Debugger_onNewMessages, _Debugger_renderMessages, _Debugger_setCollapsibleMessages, _Debugger_onWindowResize;
|
|
10
|
+
const INITIAL_POS_THRESHOLD = 32;
|
|
11
|
+
const INITIAL_WIDTH = 300;
|
|
12
|
+
const INITIAL_HEIGHT = 200;
|
|
13
|
+
const MIN_SIZE = 200;
|
|
14
|
+
const template = document.createElement('template');
|
|
15
|
+
template.innerHTML = `
|
|
16
|
+
<div style="top:${INITIAL_POS_THRESHOLD}px; left:${window.innerWidth - INITIAL_WIDTH - INITIAL_POS_THRESHOLD}px;" class="debugger">
|
|
17
|
+
<div class="header">
|
|
18
|
+
<span>Debugger messages</span>
|
|
19
|
+
</div>
|
|
20
|
+
<div class="content">
|
|
21
|
+
<div class="empty-state">
|
|
22
|
+
No errors detected 👀
|
|
23
|
+
</div>
|
|
24
|
+
</div>
|
|
25
|
+
</div>
|
|
26
|
+
`;
|
|
27
|
+
const icon = `<svg width="18" height="18" viewBox="0 0 18 18" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
28
|
+
<path d="M5.99984 13.167L8.99984 10.167L11.9998 13.167L13.1665 12.0003L10.1665 9.00033L13.1665 6.00033L11.9998 4.83366L8.99984 7.83366L5.99984 4.83366L4.83317 6.00033L7.83317 9.00033L4.83317 12.0003L5.99984 13.167ZM8.99984 17.3337C7.84706 17.3337 6.76373 17.1148 5.74984 16.677C4.73595 16.2398 3.854 15.6462 3.104 14.8962C2.354 14.1462 1.76039 13.2642 1.32317 12.2503C0.885393 11.2364 0.666504 10.1531 0.666504 9.00033C0.666504 7.84755 0.885393 6.76421 1.32317 5.75033C1.76039 4.73644 2.354 3.85449 3.104 3.10449C3.854 2.35449 4.73595 1.7606 5.74984 1.32283C6.76373 0.885603 7.84706 0.666992 8.99984 0.666992C10.1526 0.666992 11.2359 0.885603 12.2498 1.32283C13.2637 1.7606 14.1457 2.35449 14.8957 3.10449C15.6457 3.85449 16.2393 4.73644 16.6765 5.75033C17.1143 6.76421 17.3332 7.84755 17.3332 9.00033C17.3332 10.1531 17.1143 11.2364 16.6765 12.2503C16.2393 13.2642 15.6457 14.1462 14.8957 14.8962C14.1457 15.6462 13.2637 16.2398 12.2498 16.677C11.2359 17.1148 10.1526 17.3337 8.99984 17.3337ZM8.99984 15.667C10.8609 15.667 12.4373 15.0212 13.729 13.7295C15.0207 12.4378 15.6665 10.8614 15.6665 9.00033C15.6665 7.13921 15.0207 5.56283 13.729 4.27116C12.4373 2.97949 10.8609 2.33366 8.99984 2.33366C7.13873 2.33366 5.56234 2.97949 4.27067 4.27116C2.979 5.56283 2.33317 7.13921 2.33317 9.00033C2.33317 10.8614 2.979 12.4378 4.27067 13.7295C5.56234 15.0212 7.13873 15.667 8.99984 15.667Z" fill="#ED404A"/>
|
|
29
|
+
</svg>
|
|
30
|
+
`;
|
|
31
|
+
const style = `
|
|
32
|
+
.debugger {
|
|
33
|
+
all: initial;
|
|
34
|
+
width: ${INITIAL_WIDTH}px;
|
|
35
|
+
height: ${INITIAL_HEIGHT}px;
|
|
36
|
+
background-color: #FAFAFA;
|
|
37
|
+
position: fixed;
|
|
38
|
+
font-family: "Helvetica Neue", sans-serif;
|
|
39
|
+
box-shadow: rgba(0, 0, 0, 0.1) 0px 5px 10px;
|
|
40
|
+
border-radius: 8px;
|
|
41
|
+
overflow: hidden;
|
|
42
|
+
border: 1px solid lightgrey;
|
|
43
|
+
pointer-events: initial;
|
|
44
|
+
display: flex;
|
|
45
|
+
flex-direction: column;
|
|
46
|
+
min-width: ${MIN_SIZE}px;
|
|
47
|
+
max-width: 600px;
|
|
48
|
+
max-height: calc(100% - ${INITIAL_POS_THRESHOLD * 2}px);
|
|
49
|
+
min-height: ${MIN_SIZE}px;
|
|
50
|
+
resize: both;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
.header {
|
|
54
|
+
padding: 8px 16px;
|
|
55
|
+
display: flex;
|
|
56
|
+
align-items: center;
|
|
57
|
+
background-color: #EEEEEE;
|
|
58
|
+
cursor: move;
|
|
59
|
+
border-bottom: 1px solid #e0e0e0;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.content {
|
|
63
|
+
font-size: 14px;
|
|
64
|
+
flex-grow: 1;
|
|
65
|
+
overflow: auto;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
.msg {
|
|
69
|
+
border-bottom: 1px solid lightgrey;
|
|
70
|
+
padding: 8px 16px;
|
|
71
|
+
display: flex;
|
|
72
|
+
gap: 5px;
|
|
73
|
+
background-color: #FAFAFA;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
.msg.collapsible {
|
|
77
|
+
cursor: pointer;
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
.empty-state {
|
|
81
|
+
padding: 8px 16px;
|
|
82
|
+
background-color: #FAFAFA;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
|
|
86
|
+
.msg.collapsible:not(.collapsed) {
|
|
87
|
+
background-color: #F5F5F5;
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
.msg_title {
|
|
91
|
+
padding-bottom: 5px;
|
|
92
|
+
display: flex;
|
|
93
|
+
gap: 8px;
|
|
94
|
+
font-weight: 500;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
.msg svg {
|
|
98
|
+
padding: 1px;
|
|
99
|
+
flex-shrink: 0;
|
|
100
|
+
margin-top: -2px;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
.msg_content {
|
|
104
|
+
overflow: hidden;
|
|
105
|
+
flex-grow: 1;
|
|
106
|
+
margin-right:5px;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
.msg_desc {
|
|
110
|
+
color: #646464;
|
|
111
|
+
cursor: initial;
|
|
112
|
+
word-wrap: break-word;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
.msg.collapsed .msg_desc {
|
|
116
|
+
overflow: hidden;
|
|
117
|
+
text-overflow: ellipsis;
|
|
118
|
+
white-space: nowrap;
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
.msg.collapsible.collapsed .chevron {
|
|
122
|
+
transform: rotate(-45deg) translateX(-2px);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
.msg.collapsible .chevron {
|
|
126
|
+
content: "";
|
|
127
|
+
width:6px;
|
|
128
|
+
height:6px;
|
|
129
|
+
border-bottom: 2px solid grey;
|
|
130
|
+
border-right: 2px solid grey;
|
|
131
|
+
transform: rotate(45deg) translateX(-1px);
|
|
132
|
+
margin: 5px;
|
|
133
|
+
flex-shrink:0;
|
|
134
|
+
}
|
|
135
|
+
`;
|
|
136
|
+
class Debugger extends HTMLElement {
|
|
137
|
+
constructor() {
|
|
138
|
+
var _a, _b;
|
|
139
|
+
var _c;
|
|
140
|
+
super();
|
|
141
|
+
_Debugger_instances.add(this);
|
|
142
|
+
_Debugger_messagesState.set(this, new sdkHelpers.State({ messages: [] }));
|
|
143
|
+
_Debugger_rootEle.set(this, void 0);
|
|
144
|
+
_Debugger_contentEle.set(this, void 0);
|
|
145
|
+
_Debugger_headerEle.set(this, void 0);
|
|
146
|
+
_Debugger_eventsCbRefs.set(this, {
|
|
147
|
+
resize: tslib.__classPrivateFieldGet(this, _Debugger_instances, "m", _Debugger_onWindowResize).bind(this),
|
|
148
|
+
});
|
|
149
|
+
this.attachShadow({ mode: 'open' });
|
|
150
|
+
(_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.appendChild(template.content.cloneNode(true));
|
|
151
|
+
const sheet = new CSSStyleSheet();
|
|
152
|
+
sheet.replaceSync(style);
|
|
153
|
+
(_b = (_c = this.shadowRoot).adoptedStyleSheets) !== null && _b !== void 0 ? _b : (_c.adoptedStyleSheets = []);
|
|
154
|
+
this.shadowRoot.adoptedStyleSheets = [
|
|
155
|
+
...this.shadowRoot.adoptedStyleSheets,
|
|
156
|
+
sheet,
|
|
157
|
+
];
|
|
158
|
+
tslib.__classPrivateFieldSet(this, _Debugger_rootEle, this.shadowRoot.querySelector('.debugger'), "f");
|
|
159
|
+
tslib.__classPrivateFieldSet(this, _Debugger_contentEle, tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f").querySelector('.content'), "f");
|
|
160
|
+
tslib.__classPrivateFieldSet(this, _Debugger_headerEle, tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f").querySelector('.header'), "f");
|
|
161
|
+
}
|
|
162
|
+
updateData(data) {
|
|
163
|
+
tslib.__classPrivateFieldGet(this, _Debugger_messagesState, "f").update((state) => ({
|
|
164
|
+
messages: state.messages.concat(data),
|
|
165
|
+
}));
|
|
166
|
+
}
|
|
167
|
+
connectedCallback() {
|
|
168
|
+
helpers.dragElement(tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f"), tslib.__classPrivateFieldGet(this, _Debugger_headerEle, "f"), {
|
|
169
|
+
top: 'all',
|
|
170
|
+
bottom: 100,
|
|
171
|
+
left: 100,
|
|
172
|
+
right: 100,
|
|
173
|
+
});
|
|
174
|
+
window.addEventListener('resize', tslib.__classPrivateFieldGet(this, _Debugger_eventsCbRefs, "f").resize);
|
|
175
|
+
helpers.addOnResize(tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f"));
|
|
176
|
+
tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f").onresize = tslib.__classPrivateFieldGet(this, _Debugger_instances, "m", _Debugger_setCollapsibleMessages).bind(this);
|
|
177
|
+
tslib.__classPrivateFieldGet(this, _Debugger_messagesState, "f").subscribe(tslib.__classPrivateFieldGet(this, _Debugger_instances, "m", _Debugger_onNewMessages).bind(this));
|
|
178
|
+
}
|
|
179
|
+
disconnectedCallback() {
|
|
180
|
+
tslib.__classPrivateFieldGet(this, _Debugger_messagesState, "f").unsubscribeAll();
|
|
181
|
+
window.removeEventListener('resize', tslib.__classPrivateFieldGet(this, _Debugger_eventsCbRefs, "f").resize);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
_Debugger_messagesState = new WeakMap(), _Debugger_rootEle = new WeakMap(), _Debugger_contentEle = new WeakMap(), _Debugger_headerEle = new WeakMap(), _Debugger_eventsCbRefs = new WeakMap(), _Debugger_instances = new WeakSet(), _Debugger_onNewMessages = function _Debugger_onNewMessages(data) {
|
|
185
|
+
tslib.__classPrivateFieldGet(this, _Debugger_instances, "m", _Debugger_renderMessages).call(this, data);
|
|
186
|
+
tslib.__classPrivateFieldGet(this, _Debugger_instances, "m", _Debugger_setCollapsibleMessages).call(this);
|
|
187
|
+
}, _Debugger_renderMessages = function _Debugger_renderMessages(data) {
|
|
188
|
+
tslib.__classPrivateFieldGet(this, _Debugger_contentEle, "f").innerHTML = data.messages
|
|
189
|
+
.map((message) => `
|
|
190
|
+
<div class="msg">
|
|
191
|
+
${icon}
|
|
192
|
+
<div class="msg_content">
|
|
193
|
+
<div class="msg_title">
|
|
194
|
+
${message.title}
|
|
195
|
+
</div>
|
|
196
|
+
<div class="msg_desc">
|
|
197
|
+
${message.description || ''}
|
|
198
|
+
</div>
|
|
199
|
+
</div>
|
|
200
|
+
<div class="chevron"></div>
|
|
201
|
+
</div>
|
|
202
|
+
`)
|
|
203
|
+
.join('');
|
|
204
|
+
}, _Debugger_setCollapsibleMessages = function _Debugger_setCollapsibleMessages() {
|
|
205
|
+
tslib.__classPrivateFieldGet(this, _Debugger_contentEle, "f").querySelectorAll('.msg').forEach((element) => {
|
|
206
|
+
const ele = element;
|
|
207
|
+
const descEle = ele.querySelector('.msg_desc');
|
|
208
|
+
const lineHeight = 20;
|
|
209
|
+
const isScroll = descEle.scrollWidth > descEle.clientWidth;
|
|
210
|
+
const isMultiLine = descEle.clientHeight > lineHeight;
|
|
211
|
+
const isCollapsible = isScroll || isMultiLine;
|
|
212
|
+
if (isCollapsible) {
|
|
213
|
+
ele.classList.add('collapsible');
|
|
214
|
+
ele.onclick = (e) => {
|
|
215
|
+
// message description should not toggle collapse
|
|
216
|
+
if (!e.target.classList.contains('msg_desc')) {
|
|
217
|
+
ele.classList.toggle('collapsed');
|
|
218
|
+
}
|
|
219
|
+
};
|
|
220
|
+
}
|
|
221
|
+
else {
|
|
222
|
+
ele.classList.remove('collapsible');
|
|
223
|
+
ele.onclick = null;
|
|
224
|
+
}
|
|
225
|
+
});
|
|
226
|
+
}, _Debugger_onWindowResize = function _Debugger_onWindowResize() {
|
|
227
|
+
// when window is resizing we want to make sure debugger is still visible
|
|
228
|
+
const [left, top] = helpers.limitCoordinateToScreenBoundaries(tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f"), Number.parseInt(tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f").style.left, 10), Number.parseInt(tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f").style.top, 10), { top: 'all', bottom: 100, left: 100, right: 100 });
|
|
229
|
+
tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f").style.top = `${top}px`;
|
|
230
|
+
tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f").style.left = `${left}px`;
|
|
231
|
+
};
|
|
232
|
+
if (!customElements.get('descope-debugger')) {
|
|
233
|
+
customElements.define('descope-debugger', Debugger);
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
exports.default = Debugger;
|
|
237
|
+
//# sourceMappingURL=debugger-wc.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"debugger-wc.js","sources":["../../../../src/mixins/debuggerMixin/debugger-wc.ts"],"sourcesContent":["/* eslint-disable no-param-reassign */\nimport { State } from '@descope/sdk-helpers';\nimport {\n addOnResize,\n dragElement,\n limitCoordinateToScreenBoundaries,\n} from './helpers';\nimport { DebuggerMessage } from './types';\n\nconst INITIAL_POS_THRESHOLD = 32;\nconst INITIAL_WIDTH = 300;\nconst INITIAL_HEIGHT = 200;\nconst MIN_SIZE = 200;\n\nconst template = document.createElement('template');\ntemplate.innerHTML = `\n<div style=\"top:${INITIAL_POS_THRESHOLD}px; left:${\n window.innerWidth - INITIAL_WIDTH - INITIAL_POS_THRESHOLD\n}px;\" class=\"debugger\">\n <div class=\"header\">\n <span>Debugger messages</span>\n </div>\n <div class=\"content\">\n <div class=\"empty-state\">\n No errors detected 👀\n </div>\n </div>\n</div>\n`;\n\nconst icon = `<svg width=\"18\" height=\"18\" viewBox=\"0 0 18 18\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n<path d=\"M5.99984 13.167L8.99984 10.167L11.9998 13.167L13.1665 12.0003L10.1665 9.00033L13.1665 6.00033L11.9998 4.83366L8.99984 7.83366L5.99984 4.83366L4.83317 6.00033L7.83317 9.00033L4.83317 12.0003L5.99984 13.167ZM8.99984 17.3337C7.84706 17.3337 6.76373 17.1148 5.74984 16.677C4.73595 16.2398 3.854 15.6462 3.104 14.8962C2.354 14.1462 1.76039 13.2642 1.32317 12.2503C0.885393 11.2364 0.666504 10.1531 0.666504 9.00033C0.666504 7.84755 0.885393 6.76421 1.32317 5.75033C1.76039 4.73644 2.354 3.85449 3.104 3.10449C3.854 2.35449 4.73595 1.7606 5.74984 1.32283C6.76373 0.885603 7.84706 0.666992 8.99984 0.666992C10.1526 0.666992 11.2359 0.885603 12.2498 1.32283C13.2637 1.7606 14.1457 2.35449 14.8957 3.10449C15.6457 3.85449 16.2393 4.73644 16.6765 5.75033C17.1143 6.76421 17.3332 7.84755 17.3332 9.00033C17.3332 10.1531 17.1143 11.2364 16.6765 12.2503C16.2393 13.2642 15.6457 14.1462 14.8957 14.8962C14.1457 15.6462 13.2637 16.2398 12.2498 16.677C11.2359 17.1148 10.1526 17.3337 8.99984 17.3337ZM8.99984 15.667C10.8609 15.667 12.4373 15.0212 13.729 13.7295C15.0207 12.4378 15.6665 10.8614 15.6665 9.00033C15.6665 7.13921 15.0207 5.56283 13.729 4.27116C12.4373 2.97949 10.8609 2.33366 8.99984 2.33366C7.13873 2.33366 5.56234 2.97949 4.27067 4.27116C2.979 5.56283 2.33317 7.13921 2.33317 9.00033C2.33317 10.8614 2.979 12.4378 4.27067 13.7295C5.56234 15.0212 7.13873 15.667 8.99984 15.667Z\" fill=\"#ED404A\"/>\n</svg>\n`;\n\nconst style = `\n.debugger {\n all: initial;\n width: ${INITIAL_WIDTH}px;\n height: ${INITIAL_HEIGHT}px;\n background-color: #FAFAFA;\n position: fixed;\n font-family: \"Helvetica Neue\", sans-serif;\n box-shadow: rgba(0, 0, 0, 0.1) 0px 5px 10px;\n border-radius: 8px;\n overflow: hidden;\n border: 1px solid lightgrey;\n pointer-events: initial;\n display: flex;\n flex-direction: column;\n min-width: ${MIN_SIZE}px;\n max-width: 600px;\n max-height: calc(100% - ${INITIAL_POS_THRESHOLD * 2}px);\n min-height: ${MIN_SIZE}px;\n resize: both;\n }\n\n .header {\n padding: 8px 16px;\n display: flex;\n align-items: center;\n background-color: #EEEEEE;\n cursor: move;\n border-bottom: 1px solid #e0e0e0;\n }\n\n .content {\n font-size: 14px;\n flex-grow: 1;\n overflow: auto;\n }\n\n .msg {\n border-bottom: 1px solid lightgrey;\n padding: 8px 16px;\n display: flex;\n gap: 5px;\n background-color: #FAFAFA;\n }\n\n .msg.collapsible {\n cursor: pointer;\n }\n\n .empty-state {\n padding: 8px 16px;\n background-color: #FAFAFA;\n }\n\n\n .msg.collapsible:not(.collapsed) {\n background-color: #F5F5F5;\n }\n\n .msg_title {\n padding-bottom: 5px;\n display: flex;\n gap: 8px;\n font-weight: 500;\n }\n\n .msg svg {\n padding: 1px;\n flex-shrink: 0;\n margin-top: -2px;\n }\n\n .msg_content {\n overflow: hidden;\n flex-grow: 1;\n margin-right:5px;\n }\n\n .msg_desc {\n color: #646464;\n cursor: initial;\n word-wrap: break-word;\n }\n\n .msg.collapsed .msg_desc {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n }\n\n .msg.collapsible.collapsed .chevron {\n transform: rotate(-45deg) translateX(-2px);\n }\n\n .msg.collapsible .chevron {\n content: \"\";\n width:6px;\n height:6px;\n border-bottom: 2px solid grey;\n border-right: 2px solid grey;\n transform: rotate(45deg) translateX(-1px);\n margin: 5px;\n flex-shrink:0;\n }\n`;\n\ntype MessagesState = { messages: DebuggerMessage[] };\n\nclass Debugger extends HTMLElement {\n #messagesState = new State<MessagesState>({ messages: [] });\n\n #rootEle: HTMLDivElement;\n\n #contentEle: HTMLDivElement;\n\n #headerEle: HTMLDivElement;\n\n #eventsCbRefs = {\n resize: this.#onWindowResize.bind(this),\n };\n\n constructor() {\n super();\n\n this.attachShadow({ mode: 'open' });\n this.shadowRoot?.appendChild(template.content.cloneNode(true));\n const sheet = new CSSStyleSheet();\n sheet.replaceSync(style);\n this.shadowRoot.adoptedStyleSheets ??= [];\n this.shadowRoot.adoptedStyleSheets = [\n ...this.shadowRoot.adoptedStyleSheets,\n sheet,\n ];\n\n this.#rootEle =\n this.shadowRoot!.querySelector<HTMLDivElement>('.debugger')!;\n this.#contentEle = this.#rootEle.querySelector<HTMLDivElement>('.content')!;\n this.#headerEle = this.#rootEle.querySelector<HTMLDivElement>('.header')!;\n }\n\n updateData(data: DebuggerMessage | DebuggerMessage[]) {\n this.#messagesState.update((state) => ({\n messages: state.messages.concat(data),\n }));\n }\n\n #onNewMessages(data: MessagesState) {\n this.#renderMessages(data);\n this.#setCollapsibleMessages();\n }\n\n #renderMessages(data: MessagesState) {\n this.#contentEle.innerHTML = data.messages\n .map(\n (message) => `\n <div class=\"msg\">\n ${icon}\n <div class=\"msg_content\">\n <div class=\"msg_title\">\n ${message.title}\n </div>\n <div class=\"msg_desc\">\n ${message.description || ''}\n </div>\n </div>\n <div class=\"chevron\"></div>\n </div>\n `,\n )\n .join('');\n }\n\n #setCollapsibleMessages() {\n this.#contentEle.querySelectorAll('.msg').forEach((element: Element) => {\n const ele = element as HTMLElement;\n const descEle = ele.querySelector('.msg_desc');\n const lineHeight = 20;\n const isScroll = descEle!.scrollWidth > descEle!.clientWidth;\n const isMultiLine = descEle!.clientHeight > lineHeight;\n const isCollapsible = isScroll || isMultiLine;\n\n if (isCollapsible) {\n ele.classList.add('collapsible');\n ele.onclick = (e: MouseEvent) => {\n // message description should not toggle collapse\n if (!(e.target as HTMLElement).classList.contains('msg_desc')) {\n ele.classList.toggle('collapsed');\n }\n };\n } else {\n ele.classList.remove('collapsible');\n ele.onclick = null;\n }\n });\n }\n\n #onWindowResize() {\n // when window is resizing we want to make sure debugger is still visible\n const [left, top] = limitCoordinateToScreenBoundaries(\n this.#rootEle,\n Number.parseInt(this.#rootEle.style.left, 10),\n Number.parseInt(this.#rootEle.style.top, 10),\n { top: 'all', bottom: 100, left: 100, right: 100 },\n );\n this.#rootEle.style.top = `${top}px`;\n this.#rootEle.style.left = `${left}px`;\n }\n\n connectedCallback() {\n dragElement(this.#rootEle, this.#headerEle, {\n top: 'all',\n bottom: 100,\n left: 100,\n right: 100,\n });\n\n window.addEventListener('resize', this.#eventsCbRefs.resize);\n\n addOnResize(this.#rootEle);\n this.#rootEle.onresize = this.#setCollapsibleMessages.bind(this);\n\n this.#messagesState.subscribe(this.#onNewMessages.bind(this));\n }\n\n disconnectedCallback() {\n this.#messagesState.unsubscribeAll();\n window.removeEventListener('resize', this.#eventsCbRefs.resize);\n }\n}\n\nif (!customElements.get('descope-debugger')) {\n customElements.define('descope-debugger', Debugger);\n}\n\nexport default Debugger;\n"],"names":["State","__classPrivateFieldGet","__classPrivateFieldSet","dragElement","addOnResize","limitCoordinateToScreenBoundaries"],"mappings":"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"}
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var tslib = require('tslib');
|
|
4
|
+
var sdkHelpers = require('@descope/sdk-helpers');
|
|
5
|
+
var initLifecycleMixin = require('../initLifecycleMixin.js');
|
|
6
|
+
var loggerMixin = require('../loggerMixin/loggerMixin.js');
|
|
7
|
+
|
|
8
|
+
const debuggerMixin = sdkHelpers.createSingletonMixin((superclass) => { var _DebuggerMixinClass_instances, _DebuggerMixinClass_debuggerEle, _DebuggerMixinClass_disableDebugger, _DebuggerMixinClass_enableDebugger, _DebuggerMixinClass_handleDebugMode, _DebuggerMixinClass_updateDebuggerMessages, _a; return _a = class DebuggerMixinClass extends sdkHelpers.compose(initLifecycleMixin.initLifecycleMixin, loggerMixin.loggerMixin)(superclass) {
|
|
9
|
+
constructor() {
|
|
10
|
+
super(...arguments);
|
|
11
|
+
_DebuggerMixinClass_instances.add(this);
|
|
12
|
+
_DebuggerMixinClass_debuggerEle.set(this, void 0);
|
|
13
|
+
this.attributeChangedCallback = (attrName, oldValue, newValue) => {
|
|
14
|
+
var _b;
|
|
15
|
+
(_b = super.attributeChangedCallback) === null || _b === void 0 ? void 0 : _b.call(this, attrName, oldValue, newValue);
|
|
16
|
+
if (attrName === 'debug') {
|
|
17
|
+
tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_instances, "m", _DebuggerMixinClass_handleDebugMode).call(this);
|
|
18
|
+
}
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
get debug() {
|
|
22
|
+
return this.getAttribute('debug') === 'true';
|
|
23
|
+
}
|
|
24
|
+
onLogEvent(logLevel, args) {
|
|
25
|
+
var _b;
|
|
26
|
+
(_b = super.onLogEvent) === null || _b === void 0 ? void 0 : _b.call(this, logLevel, args);
|
|
27
|
+
if (logLevel === 'error') {
|
|
28
|
+
tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_instances, "m", _DebuggerMixinClass_updateDebuggerMessages).call(this, args[0] || 'Error', args[1]);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
async init() {
|
|
32
|
+
var _b;
|
|
33
|
+
await ((_b = super.init) === null || _b === void 0 ? void 0 : _b.call(this));
|
|
34
|
+
tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_instances, "m", _DebuggerMixinClass_handleDebugMode).call(this);
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
_DebuggerMixinClass_debuggerEle = new WeakMap(),
|
|
38
|
+
_DebuggerMixinClass_instances = new WeakSet(),
|
|
39
|
+
_DebuggerMixinClass_disableDebugger = function _DebuggerMixinClass_disableDebugger() {
|
|
40
|
+
var _b;
|
|
41
|
+
(_b = tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_debuggerEle, "f")) === null || _b === void 0 ? void 0 : _b.remove();
|
|
42
|
+
tslib.__classPrivateFieldSet(this, _DebuggerMixinClass_debuggerEle, null, "f");
|
|
43
|
+
},
|
|
44
|
+
_DebuggerMixinClass_enableDebugger = async function _DebuggerMixinClass_enableDebugger() {
|
|
45
|
+
tslib.__classPrivateFieldSet(this, _DebuggerMixinClass_debuggerEle, document.createElement('descope-debugger'), "f");
|
|
46
|
+
Object.assign(tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_debuggerEle, "f").style, {
|
|
47
|
+
position: 'fixed',
|
|
48
|
+
top: '0',
|
|
49
|
+
right: '0',
|
|
50
|
+
height: '100vh',
|
|
51
|
+
width: '100vw',
|
|
52
|
+
pointerEvents: 'none',
|
|
53
|
+
zIndex: 99999,
|
|
54
|
+
});
|
|
55
|
+
// we are importing the debugger dynamically so we won't load it when it's not needed
|
|
56
|
+
await Promise.resolve().then(function () { return require('./debugger-wc.js'); });
|
|
57
|
+
document.body.appendChild(tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_debuggerEle, "f"));
|
|
58
|
+
},
|
|
59
|
+
_DebuggerMixinClass_handleDebugMode = function _DebuggerMixinClass_handleDebugMode() {
|
|
60
|
+
if (this.debug)
|
|
61
|
+
tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_instances, "m", _DebuggerMixinClass_enableDebugger).call(this);
|
|
62
|
+
else
|
|
63
|
+
tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_instances, "m", _DebuggerMixinClass_disableDebugger).call(this);
|
|
64
|
+
},
|
|
65
|
+
_DebuggerMixinClass_updateDebuggerMessages = function _DebuggerMixinClass_updateDebuggerMessages(title, description) {
|
|
66
|
+
var _b;
|
|
67
|
+
if (title)
|
|
68
|
+
(_b = tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_debuggerEle, "f")) === null || _b === void 0 ? void 0 : _b.updateData({ title, description });
|
|
69
|
+
},
|
|
70
|
+
_a; });
|
|
71
|
+
|
|
72
|
+
exports.debuggerMixin = debuggerMixin;
|
|
73
|
+
//# sourceMappingURL=debuggerMixin.js.map
|