@descope/sdk-mixins 0.4.0 → 0.5.1

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.
Files changed (188) hide show
  1. package/dist/cjs/constants.js +6 -0
  2. package/dist/cjs/constants.js.map +1 -0
  3. package/dist/cjs/index.js +41 -0
  4. package/dist/cjs/index.js.map +1 -0
  5. package/dist/cjs/mixins/baseStaticUrlMixin.js +14 -0
  6. package/dist/cjs/mixins/baseStaticUrlMixin.js.map +1 -0
  7. package/dist/cjs/mixins/baseUrlMixin.js +14 -0
  8. package/dist/cjs/mixins/baseUrlMixin.js.map +1 -0
  9. package/dist/cjs/mixins/configMixin/configMixin.js +42 -0
  10. package/dist/cjs/mixins/configMixin/configMixin.js.map +1 -0
  11. package/dist/cjs/mixins/configMixin/constants.js +6 -0
  12. package/dist/cjs/mixins/configMixin/constants.js.map +1 -0
  13. package/dist/cjs/mixins/createStateManagementMixin.js +47 -0
  14. package/dist/cjs/mixins/createStateManagementMixin.js.map +1 -0
  15. package/dist/cjs/mixins/createValidateAttributesMixin/commonValidators.js +7 -0
  16. package/dist/cjs/mixins/createValidateAttributesMixin/commonValidators.js.map +1 -0
  17. package/dist/cjs/mixins/createValidateAttributesMixin/createValidateAttributesMixin.js +40 -0
  18. package/dist/cjs/mixins/createValidateAttributesMixin/createValidateAttributesMixin.js.map +1 -0
  19. package/dist/cjs/mixins/debuggerMixin/debugger-wc.js +229 -0
  20. package/dist/cjs/mixins/debuggerMixin/debugger-wc.js.map +1 -0
  21. package/dist/cjs/mixins/debuggerMixin/debuggerMixin.js +73 -0
  22. package/dist/cjs/mixins/debuggerMixin/debuggerMixin.js.map +1 -0
  23. package/dist/cjs/mixins/debuggerMixin/helpers.js +76 -0
  24. package/dist/cjs/mixins/debuggerMixin/helpers.js.map +1 -0
  25. package/dist/cjs/mixins/descopeUiMixin/constants.js +25 -0
  26. package/dist/cjs/mixins/descopeUiMixin/constants.js.map +1 -0
  27. package/dist/cjs/mixins/descopeUiMixin/descopeUiMixin.js +165 -0
  28. package/dist/cjs/mixins/descopeUiMixin/descopeUiMixin.js.map +1 -0
  29. package/dist/cjs/mixins/descopeUiMixin/helpers.js +18 -0
  30. package/dist/cjs/mixins/descopeUiMixin/helpers.js.map +1 -0
  31. package/dist/cjs/mixins/formMixin.js +57 -0
  32. package/dist/cjs/mixins/formMixin.js.map +1 -0
  33. package/dist/cjs/mixins/initElementMixin.js +33 -0
  34. package/dist/cjs/mixins/initElementMixin.js.map +1 -0
  35. package/dist/cjs/mixins/initLifecycleMixin.js +29 -0
  36. package/dist/cjs/mixins/initLifecycleMixin.js.map +1 -0
  37. package/dist/cjs/mixins/loggerMixin/loggerMixin.js +37 -0
  38. package/dist/cjs/mixins/loggerMixin/loggerMixin.js.map +1 -0
  39. package/dist/cjs/mixins/modalMixin/constants.js +6 -0
  40. package/dist/cjs/mixins/modalMixin/constants.js.map +1 -0
  41. package/dist/cjs/mixins/modalMixin/helpers.js +14 -0
  42. package/dist/cjs/mixins/modalMixin/helpers.js.map +1 -0
  43. package/dist/cjs/mixins/modalMixin/modalMixin.js +47 -0
  44. package/dist/cjs/mixins/modalMixin/modalMixin.js.map +1 -0
  45. package/dist/cjs/mixins/notificationsMixin/constants.js +6 -0
  46. package/dist/cjs/mixins/notificationsMixin/constants.js.map +1 -0
  47. package/dist/cjs/mixins/notificationsMixin/helpers.js +14 -0
  48. package/dist/cjs/mixins/notificationsMixin/helpers.js.map +1 -0
  49. package/dist/cjs/mixins/notificationsMixin/notificationsMixin.js +50 -0
  50. package/dist/cjs/mixins/notificationsMixin/notificationsMixin.js.map +1 -0
  51. package/dist/cjs/mixins/observeAttributesMixin/helpers.js +17 -0
  52. package/dist/cjs/mixins/observeAttributesMixin/helpers.js.map +1 -0
  53. package/dist/cjs/mixins/observeAttributesMixin/observeAttributesMixin.js +47 -0
  54. package/dist/cjs/mixins/observeAttributesMixin/observeAttributesMixin.js.map +1 -0
  55. package/dist/cjs/mixins/projectIdMixin.js +17 -0
  56. package/dist/cjs/mixins/projectIdMixin.js.map +1 -0
  57. package/dist/cjs/mixins/staticResourcesMixin/constants.js +13 -0
  58. package/dist/cjs/mixins/staticResourcesMixin/constants.js.map +1 -0
  59. package/dist/cjs/mixins/staticResourcesMixin/staticResourcesMixin.js +40 -0
  60. package/dist/cjs/mixins/staticResourcesMixin/staticResourcesMixin.js.map +1 -0
  61. package/dist/cjs/mixins/themeMixin/constants.js +7 -0
  62. package/dist/cjs/mixins/themeMixin/constants.js.map +1 -0
  63. package/dist/cjs/mixins/themeMixin/helpers.js +34 -0
  64. package/dist/cjs/mixins/themeMixin/helpers.js.map +1 -0
  65. package/dist/cjs/mixins/themeMixin/index.js +8 -0
  66. package/dist/cjs/mixins/themeMixin/index.js.map +1 -0
  67. package/dist/cjs/mixins/themeMixin/themeMixin.js +176 -0
  68. package/dist/cjs/mixins/themeMixin/themeMixin.js.map +1 -0
  69. package/dist/esm/constants.js +4 -0
  70. package/dist/esm/constants.js.map +1 -0
  71. package/dist/esm/index.js +18 -0
  72. package/dist/esm/index.js.map +1 -0
  73. package/dist/esm/mixins/baseStaticUrlMixin.js +12 -0
  74. package/dist/esm/mixins/baseStaticUrlMixin.js.map +1 -0
  75. package/dist/esm/mixins/baseUrlMixin.js +12 -0
  76. package/dist/esm/mixins/baseUrlMixin.js.map +1 -0
  77. package/dist/esm/mixins/configMixin/configMixin.js +40 -0
  78. package/dist/esm/mixins/configMixin/configMixin.js.map +1 -0
  79. package/dist/esm/mixins/configMixin/constants.js +4 -0
  80. package/dist/esm/mixins/configMixin/constants.js.map +1 -0
  81. package/dist/esm/mixins/createStateManagementMixin.js +45 -0
  82. package/dist/esm/mixins/createStateManagementMixin.js.map +1 -0
  83. package/dist/esm/mixins/createValidateAttributesMixin/commonValidators.js +5 -0
  84. package/dist/esm/mixins/createValidateAttributesMixin/commonValidators.js.map +1 -0
  85. package/dist/esm/mixins/createValidateAttributesMixin/createValidateAttributesMixin.js +38 -0
  86. package/dist/esm/mixins/createValidateAttributesMixin/createValidateAttributesMixin.js.map +1 -0
  87. package/dist/esm/mixins/debuggerMixin/debugger-wc.js +225 -0
  88. package/dist/esm/mixins/debuggerMixin/debugger-wc.js.map +1 -0
  89. package/dist/esm/mixins/debuggerMixin/debuggerMixin.js +71 -0
  90. package/dist/esm/mixins/debuggerMixin/debuggerMixin.js.map +1 -0
  91. package/dist/esm/mixins/debuggerMixin/helpers.js +72 -0
  92. package/dist/esm/mixins/debuggerMixin/helpers.js.map +1 -0
  93. package/dist/esm/mixins/descopeUiMixin/constants.js +16 -0
  94. package/dist/esm/mixins/descopeUiMixin/constants.js.map +1 -0
  95. package/dist/esm/mixins/descopeUiMixin/descopeUiMixin.js +163 -0
  96. package/dist/esm/mixins/descopeUiMixin/descopeUiMixin.js.map +1 -0
  97. package/dist/esm/mixins/descopeUiMixin/helpers.js +14 -0
  98. package/dist/esm/mixins/descopeUiMixin/helpers.js.map +1 -0
  99. package/dist/esm/mixins/formMixin.js +55 -0
  100. package/dist/esm/mixins/formMixin.js.map +1 -0
  101. package/dist/esm/mixins/initElementMixin.js +31 -0
  102. package/dist/esm/mixins/initElementMixin.js.map +1 -0
  103. package/dist/esm/mixins/initLifecycleMixin.js +27 -0
  104. package/dist/esm/mixins/initLifecycleMixin.js.map +1 -0
  105. package/dist/esm/mixins/loggerMixin/loggerMixin.js +35 -0
  106. package/dist/esm/mixins/loggerMixin/loggerMixin.js.map +1 -0
  107. package/dist/esm/mixins/modalMixin/constants.js +4 -0
  108. package/dist/esm/mixins/modalMixin/constants.js.map +1 -0
  109. package/dist/esm/mixins/modalMixin/helpers.js +12 -0
  110. package/dist/esm/mixins/modalMixin/helpers.js.map +1 -0
  111. package/dist/esm/mixins/modalMixin/modalMixin.js +45 -0
  112. package/dist/esm/mixins/modalMixin/modalMixin.js.map +1 -0
  113. package/dist/esm/mixins/notificationsMixin/constants.js +4 -0
  114. package/dist/esm/mixins/notificationsMixin/constants.js.map +1 -0
  115. package/dist/esm/mixins/notificationsMixin/helpers.js +12 -0
  116. package/dist/esm/mixins/notificationsMixin/helpers.js.map +1 -0
  117. package/dist/esm/mixins/notificationsMixin/notificationsMixin.js +48 -0
  118. package/dist/esm/mixins/notificationsMixin/notificationsMixin.js.map +1 -0
  119. package/dist/esm/mixins/observeAttributesMixin/helpers.js +15 -0
  120. package/dist/esm/mixins/observeAttributesMixin/helpers.js.map +1 -0
  121. package/dist/esm/mixins/observeAttributesMixin/observeAttributesMixin.js +45 -0
  122. package/dist/esm/mixins/observeAttributesMixin/observeAttributesMixin.js.map +1 -0
  123. package/dist/esm/mixins/projectIdMixin.js +15 -0
  124. package/dist/esm/mixins/projectIdMixin.js.map +1 -0
  125. package/dist/esm/mixins/staticResourcesMixin/constants.js +9 -0
  126. package/dist/esm/mixins/staticResourcesMixin/constants.js.map +1 -0
  127. package/dist/esm/mixins/staticResourcesMixin/staticResourcesMixin.js +37 -0
  128. package/dist/esm/mixins/staticResourcesMixin/staticResourcesMixin.js.map +1 -0
  129. package/dist/esm/mixins/themeMixin/constants.js +5 -0
  130. package/dist/esm/mixins/themeMixin/constants.js.map +1 -0
  131. package/dist/esm/mixins/themeMixin/helpers.js +31 -0
  132. package/dist/esm/mixins/themeMixin/helpers.js.map +1 -0
  133. package/dist/esm/mixins/themeMixin/index.js +2 -0
  134. package/dist/esm/mixins/themeMixin/index.js.map +1 -0
  135. package/dist/esm/mixins/themeMixin/themeMixin.js +174 -0
  136. package/dist/esm/mixins/themeMixin/themeMixin.js.map +1 -0
  137. package/dist/index.d.ts +543 -540
  138. package/dist/types/constants.d.ts +1 -0
  139. package/dist/types/index.d.ts +23 -0
  140. package/dist/types/mixins/baseStaticUrlMixin.d.ts +331 -0
  141. package/dist/types/mixins/baseUrlMixin.d.ts +331 -0
  142. package/dist/types/mixins/configMixin/configMixin.d.ts +357 -0
  143. package/dist/types/mixins/configMixin/constants.d.ts +1 -0
  144. package/dist/types/mixins/configMixin/index.d.ts +2 -0
  145. package/dist/types/mixins/configMixin/types.d.ts +43 -0
  146. package/dist/types/mixins/createStateManagementMixin.d.ts +341 -0
  147. package/dist/types/mixins/createValidateAttributesMixin/commonValidators.d.ts +1 -0
  148. package/dist/types/mixins/createValidateAttributesMixin/createValidateAttributesMixin.d.ts +346 -0
  149. package/dist/types/mixins/createValidateAttributesMixin/index.d.ts +1 -0
  150. package/dist/types/mixins/debuggerMixin/debugger-wc.d.ts +9 -0
  151. package/dist/types/mixins/debuggerMixin/debuggerMixin.d.ts +347 -0
  152. package/dist/types/mixins/debuggerMixin/helpers.d.ts +4 -0
  153. package/dist/types/mixins/debuggerMixin/index.d.ts +1 -0
  154. package/dist/types/mixins/debuggerMixin/types.d.ts +12 -0
  155. package/dist/types/mixins/descopeUiMixin/constants.d.ts +8 -0
  156. package/dist/types/mixins/descopeUiMixin/descopeUiMixin.d.ts +371 -0
  157. package/dist/types/mixins/descopeUiMixin/helpers.d.ts +3 -0
  158. package/dist/types/mixins/descopeUiMixin/index.d.ts +1 -0
  159. package/dist/types/mixins/formMixin.d.ts +345 -0
  160. package/dist/types/mixins/initElementMixin.d.ts +332 -0
  161. package/dist/types/mixins/initLifecycleMixin.d.ts +332 -0
  162. package/dist/types/mixins/loggerMixin/index.d.ts +2 -0
  163. package/dist/types/mixins/loggerMixin/loggerMixin.d.ts +339 -0
  164. package/dist/types/mixins/loggerMixin/types.d.ts +6 -0
  165. package/dist/types/mixins/modalMixin/constants.d.ts +1 -0
  166. package/dist/types/mixins/modalMixin/helpers.d.ts +1 -0
  167. package/dist/types/mixins/modalMixin/index.d.ts +1 -0
  168. package/dist/types/mixins/modalMixin/modalMixin.d.ts +401 -0
  169. package/dist/types/mixins/notificationsMixin/constants.d.ts +1 -0
  170. package/dist/types/mixins/notificationsMixin/helpers.d.ts +1 -0
  171. package/dist/types/mixins/notificationsMixin/index.d.ts +1 -0
  172. package/dist/types/mixins/notificationsMixin/notificationsMixin.d.ts +420 -0
  173. package/dist/types/mixins/observeAttributesMixin/helpers.d.ts +1 -0
  174. package/dist/types/mixins/observeAttributesMixin/index.d.ts +1 -0
  175. package/dist/types/mixins/observeAttributesMixin/observeAttributesMixin.d.ts +342 -0
  176. package/dist/types/mixins/projectIdMixin.d.ts +342 -0
  177. package/dist/types/mixins/staticResourcesMixin/constants.d.ts +4 -0
  178. package/dist/types/mixins/staticResourcesMixin/index.d.ts +1 -0
  179. package/dist/types/mixins/staticResourcesMixin/staticResourcesMixin.d.ts +356 -0
  180. package/dist/types/mixins/themeMixin/constants.d.ts +2 -0
  181. package/dist/types/mixins/themeMixin/helpers.d.ts +5 -0
  182. package/dist/types/mixins/themeMixin/index.d.ts +1 -0
  183. package/dist/types/mixins/themeMixin/themeMixin.d.ts +398 -0
  184. package/package.json +24 -11
  185. package/dist/cjs/index.cjs.js +0 -1172
  186. package/dist/cjs/index.cjs.js.map +0 -1
  187. package/dist/index.esm.js +0 -1153
  188. package/dist/index.esm.js.map +0 -1
@@ -1,1172 +0,0 @@
1
- 'use strict';
2
-
3
- var tslib = require('tslib');
4
- var sdkHelpers = require('@descope/sdk-helpers');
5
- var sdkComponentDrivers = require('@descope/sdk-component-drivers');
6
- var toolkit = require('@reduxjs/toolkit');
7
-
8
- const logLevels = ['error', 'warn', 'info', 'debug'];
9
- const loggerMixin = sdkHelpers.createSingletonMixin((superclass) => { var _LoggerMixinClass_instances, _LoggerMixinClass_logger, _LoggerMixinClass_wrapLogger, _a; return _a = class LoggerMixinClass extends superclass {
10
- constructor() {
11
- super(...arguments);
12
- _LoggerMixinClass_instances.add(this);
13
- _LoggerMixinClass_logger.set(this, tslib.__classPrivateFieldGet(this, _LoggerMixinClass_instances, "m", _LoggerMixinClass_wrapLogger).call(this, console));
14
- }
15
- set logger(logger) {
16
- tslib.__classPrivateFieldSet(this, _LoggerMixinClass_logger, tslib.__classPrivateFieldGet(this, _LoggerMixinClass_instances, "m", _LoggerMixinClass_wrapLogger).call(this, logger), "f");
17
- }
18
- get logger() {
19
- return tslib.__classPrivateFieldGet(this, _LoggerMixinClass_logger, "f");
20
- }
21
- // eslint-disable-next-line class-methods-use-this, @typescript-eslint/no-unused-vars
22
- onLogEvent(logLevel, data) { }
23
- },
24
- _LoggerMixinClass_logger = new WeakMap(),
25
- _LoggerMixinClass_instances = new WeakSet(),
26
- _LoggerMixinClass_wrapLogger = function _LoggerMixinClass_wrapLogger(logger) {
27
- return logLevels.reduce((acc, logLevel) => {
28
- acc[logLevel] = (...args) => {
29
- var _b;
30
- this.onLogEvent(logLevel, args);
31
- (_b = logger[logLevel]) === null || _b === void 0 ? void 0 : _b.call(logger, ...args);
32
- };
33
- return acc;
34
- }, {});
35
- },
36
- _a; });
37
-
38
- const IS_LOCAL_STORAGE = typeof localStorage !== 'undefined';
39
-
40
- const BASE_CONTENT_URL_KEY = 'base.content.url';
41
- const BASE_CONTENT_URL = 'https://static.descope.com/pages';
42
- const OVERRIDE_CONTENT_URL = (IS_LOCAL_STORAGE && localStorage.getItem(BASE_CONTENT_URL_KEY)) || '';
43
- const ASSETS_FOLDER = 'v2-beta';
44
-
45
- const missingAttrValidator = (attrName, value) => !value &&
46
- `${attrName} cannot be empty, please make sure to set this attribute`;
47
-
48
- const initLifecycleMixin = sdkHelpers.createSingletonMixin((superclass) => { var _InitLifecycleMixinClass_isInit, _a; return _a = class InitLifecycleMixinClass extends superclass {
49
- constructor() {
50
- super(...arguments);
51
- _InitLifecycleMixinClass_isInit.set(this, true);
52
- }
53
- connectedCallback() {
54
- var _b, _c;
55
- (_b = super.connectedCallback) === null || _b === void 0 ? void 0 : _b.call(this);
56
- if ((_c = this.shadowRoot) === null || _c === void 0 ? void 0 : _c.isConnected) {
57
- // the init function is running once, on the first time the component is connected
58
- if (tslib.__classPrivateFieldGet(this, _InitLifecycleMixinClass_isInit, "f")) {
59
- tslib.__classPrivateFieldSet(this, _InitLifecycleMixinClass_isInit, false, "f");
60
- this.init();
61
- }
62
- }
63
- }
64
- // eslint-disable-next-line class-methods-use-this, @typescript-eslint/no-empty-function
65
- async init() { }
66
- },
67
- _InitLifecycleMixinClass_isInit = new WeakMap(),
68
- _a; });
69
-
70
- const attributesObserver = (ele, callback) => {
71
- // sync all attrs on init
72
- Array.from(ele.attributes).forEach((attr) => callback(attr.name));
73
- const observer = new MutationObserver((mutationsList) => {
74
- mutationsList.forEach((mutation) => {
75
- if (mutation.type === 'attributes') {
76
- callback(mutation.attributeName);
77
- }
78
- });
79
- });
80
- observer.observe(ele, { attributes: true });
81
- };
82
-
83
- const observeAttributesMixin = sdkHelpers.createSingletonMixin((superclass) => {
84
- var _ObserveAttributesMixinClass_observeMappings, _a;
85
- const BaseClass = sdkHelpers.compose(loggerMixin, initLifecycleMixin)(superclass);
86
- return _a = class ObserveAttributesMixinClass extends BaseClass {
87
- constructor() {
88
- super(...arguments);
89
- _ObserveAttributesMixinClass_observeMappings.set(this, {});
90
- }
91
- async init() {
92
- var _b;
93
- await ((_b = super.init) === null || _b === void 0 ? void 0 : _b.call(this));
94
- attributesObserver(this, (attrName) => {
95
- var _b;
96
- (_b = tslib.__classPrivateFieldGet(this, _ObserveAttributesMixinClass_observeMappings, "f")[attrName]) === null || _b === void 0 ? void 0 : _b.forEach((cb) => {
97
- cb(attrName, this.getAttribute(attrName));
98
- });
99
- });
100
- }
101
- observeAttribute(attrName, onAttrChange) {
102
- if (!tslib.__classPrivateFieldGet(this, _ObserveAttributesMixinClass_observeMappings, "f")[attrName]) {
103
- tslib.__classPrivateFieldGet(this, _ObserveAttributesMixinClass_observeMappings, "f")[attrName] = [];
104
- }
105
- const idx = tslib.__classPrivateFieldGet(this, _ObserveAttributesMixinClass_observeMappings, "f")[attrName].push(onAttrChange);
106
- return () => tslib.__classPrivateFieldGet(this, _ObserveAttributesMixinClass_observeMappings, "f")[attrName].splice(idx, 1);
107
- }
108
- observeAttributes(attrs, cb) {
109
- const unobserveList = attrs.reduce((acc, attrName) => {
110
- acc.push(this.observeAttribute(attrName, cb));
111
- return acc;
112
- }, []);
113
- return () => unobserveList.forEach((unobserve) => unobserve());
114
- }
115
- },
116
- _ObserveAttributesMixinClass_observeMappings = new WeakMap(),
117
- _a;
118
- });
119
-
120
- const createValidateAttributesMixin = (mappings) => (superclass) => {
121
- var _ValidateAttributesMixinClass_instances, _ValidateAttributesMixinClass_handleError, _a;
122
- const BaseClass = sdkHelpers.compose(loggerMixin, initLifecycleMixin, observeAttributesMixin)(superclass);
123
- const mappingsNames = Object.keys(mappings);
124
- return _a = class ValidateAttributesMixinClass extends BaseClass {
125
- constructor(...args) {
126
- super(...args);
127
- _ValidateAttributesMixinClass_instances.add(this);
128
- this.observeAttributes(mappingsNames, tslib.__classPrivateFieldGet(this, _ValidateAttributesMixinClass_instances, "m", _ValidateAttributesMixinClass_handleError).bind(this));
129
- }
130
- async init() {
131
- var _b;
132
- await ((_b = super.init) === null || _b === void 0 ? void 0 : _b.call(this));
133
- // check attributes initial values
134
- mappingsNames.forEach((attr) => tslib.__classPrivateFieldGet(this, _ValidateAttributesMixinClass_instances, "m", _ValidateAttributesMixinClass_handleError).call(this, attr, this.getAttribute(attr)));
135
- }
136
- },
137
- _ValidateAttributesMixinClass_instances = new WeakSet(),
138
- _ValidateAttributesMixinClass_handleError = function _ValidateAttributesMixinClass_handleError(attrName, newValue) {
139
- const onError = mappings[attrName];
140
- const error = typeof onError === 'function' ? onError(attrName, newValue) : onError;
141
- if (error) {
142
- this.logger.error(error);
143
- }
144
- },
145
- _a;
146
- };
147
- createValidateAttributesMixin.missingAttrValidator = missingAttrValidator;
148
-
149
- const projectIdMixin = sdkHelpers.createSingletonMixin((superclass) => {
150
- const BaseClass = sdkHelpers.compose(createValidateAttributesMixin({ 'project-id': missingAttrValidator }))(superclass);
151
- return class ProjectIdMixinClass extends BaseClass {
152
- get projectId() {
153
- return this.getAttribute('project-id');
154
- }
155
- };
156
- });
157
-
158
- const baseUrlMixin = sdkHelpers.createSingletonMixin((superclass) => {
159
- return class BaseUrlMixinClass extends superclass {
160
- get baseUrl() {
161
- return this.getAttribute('base-url') || '';
162
- }
163
- };
164
- });
165
-
166
- function getResourceUrl({ projectId, filename, assetsFolder = ASSETS_FOLDER, baseUrl, }) {
167
- const url = new URL(OVERRIDE_CONTENT_URL || baseUrl || BASE_CONTENT_URL);
168
- url.pathname = sdkHelpers.pathJoin(url.pathname, projectId, assetsFolder, filename);
169
- return url.toString();
170
- }
171
- const staticResourcesMixin = sdkHelpers.createSingletonMixin((superclass) => {
172
- const BaseClass = sdkHelpers.compose(loggerMixin, projectIdMixin, baseUrlMixin)(superclass);
173
- return class StaticResourcesMixinClass extends BaseClass {
174
- async fetchStaticResource(filename, format) {
175
- const resourceUrl = getResourceUrl({
176
- projectId: this.projectId,
177
- filename,
178
- baseUrl: this.baseStaticUrl,
179
- });
180
- const res = await fetch(resourceUrl, { cache: 'default' });
181
- if (!res.ok) {
182
- this.logger.error(`Error fetching URL ${resourceUrl} [${res.status}]`);
183
- }
184
- return {
185
- body: await res[format](),
186
- headers: Object.fromEntries(res.headers.entries()),
187
- };
188
- }
189
- get baseStaticUrl() {
190
- return this.getAttribute('base-static-url');
191
- }
192
- };
193
- });
194
-
195
- const CONFIG_FILENAME = 'config.json';
196
-
197
- const configMixin = sdkHelpers.createSingletonMixin((superclass) => {
198
- var _ConfigMixinClass__configResource, _ConfigMixinClass_fetchConfig, _a;
199
- const BaseClass = sdkHelpers.compose(staticResourcesMixin)(superclass);
200
- return _a = class ConfigMixinClass extends BaseClass {
201
- constructor() {
202
- super(...arguments);
203
- _ConfigMixinClass__configResource.set(this, void 0);
204
- _ConfigMixinClass_fetchConfig.set(this, async () => {
205
- try {
206
- const { body, headers } = await this.fetchStaticResource(CONFIG_FILENAME, 'json');
207
- return {
208
- projectConfig: body,
209
- executionContext: { geo: headers['x-geo'] },
210
- };
211
- }
212
- catch (e) {
213
- this.logger.error('Cannot fetch config file', 'make sure that your projectId & flowId are correct');
214
- }
215
- return undefined;
216
- });
217
- }
218
- get config() {
219
- if (!tslib.__classPrivateFieldGet(this, _ConfigMixinClass__configResource, "f")) {
220
- tslib.__classPrivateFieldSet(this, _ConfigMixinClass__configResource, tslib.__classPrivateFieldGet(this, _ConfigMixinClass_fetchConfig, "f").call(this), "f");
221
- }
222
- return tslib.__classPrivateFieldGet(this, _ConfigMixinClass__configResource, "f");
223
- }
224
- },
225
- _ConfigMixinClass__configResource = new WeakMap(),
226
- _ConfigMixinClass_fetchConfig = new WeakMap(),
227
- _a;
228
- });
229
-
230
- 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, loggerMixin)(superclass) {
231
- constructor() {
232
- super(...arguments);
233
- _DebuggerMixinClass_instances.add(this);
234
- _DebuggerMixinClass_debuggerEle.set(this, void 0);
235
- this.attributeChangedCallback = (attrName, oldValue, newValue) => {
236
- var _b;
237
- (_b = super.attributeChangedCallback) === null || _b === void 0 ? void 0 : _b.call(this, attrName, oldValue, newValue);
238
- if (attrName === 'debug') {
239
- tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_instances, "m", _DebuggerMixinClass_handleDebugMode).call(this);
240
- }
241
- };
242
- }
243
- get debug() {
244
- return this.getAttribute('debug') === 'true';
245
- }
246
- onLogEvent(logLevel, args) {
247
- var _b;
248
- (_b = super.onLogEvent) === null || _b === void 0 ? void 0 : _b.call(this, logLevel, args);
249
- if (logLevel === 'error') {
250
- tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_instances, "m", _DebuggerMixinClass_updateDebuggerMessages).call(this, args[0] || 'Error', args[1]);
251
- }
252
- }
253
- async init() {
254
- var _b;
255
- await ((_b = super.init) === null || _b === void 0 ? void 0 : _b.call(this));
256
- tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_instances, "m", _DebuggerMixinClass_handleDebugMode).call(this);
257
- }
258
- },
259
- _DebuggerMixinClass_debuggerEle = new WeakMap(),
260
- _DebuggerMixinClass_instances = new WeakSet(),
261
- _DebuggerMixinClass_disableDebugger = function _DebuggerMixinClass_disableDebugger() {
262
- var _b;
263
- (_b = tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_debuggerEle, "f")) === null || _b === void 0 ? void 0 : _b.remove();
264
- tslib.__classPrivateFieldSet(this, _DebuggerMixinClass_debuggerEle, null, "f");
265
- },
266
- _DebuggerMixinClass_enableDebugger = async function _DebuggerMixinClass_enableDebugger() {
267
- tslib.__classPrivateFieldSet(this, _DebuggerMixinClass_debuggerEle, document.createElement('descope-debugger'), "f");
268
- Object.assign(tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_debuggerEle, "f").style, {
269
- position: 'fixed',
270
- top: '0',
271
- right: '0',
272
- height: '100vh',
273
- width: '100vw',
274
- pointerEvents: 'none',
275
- zIndex: 99999,
276
- });
277
- // we are importing the debugger dynamically so we won't load it when it's not needed
278
- await Promise.resolve().then(function () { return debuggerWc; });
279
- document.body.appendChild(tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_debuggerEle, "f"));
280
- },
281
- _DebuggerMixinClass_handleDebugMode = function _DebuggerMixinClass_handleDebugMode() {
282
- if (this.debug)
283
- tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_instances, "m", _DebuggerMixinClass_enableDebugger).call(this);
284
- else
285
- tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_instances, "m", _DebuggerMixinClass_disableDebugger).call(this);
286
- },
287
- _DebuggerMixinClass_updateDebuggerMessages = function _DebuggerMixinClass_updateDebuggerMessages(title, description) {
288
- var _b;
289
- if (title)
290
- (_b = tslib.__classPrivateFieldGet(this, _DebuggerMixinClass_debuggerEle, "f")) === null || _b === void 0 ? void 0 : _b.updateData({ title, description });
291
- },
292
- _a; });
293
-
294
- const DESCOPE_UI_SCRIPT_ID = 'load-descope-ui';
295
- const DESCOPE_UI_FALLBACK_SCRIPT_ID = 'load-descope-ui-fallback-script';
296
- const DESCOPE_UI_FALLBACK_2_SCRIPT_ID = 'load-descope-ui-fallback-script-2';
297
- const UI_COMPONENTS_URL_KEY = 'base.ui.components.url';
298
- const UI_COMPONENTS_URL = (IS_LOCAL_STORAGE && localStorage.getItem(UI_COMPONENTS_URL_KEY)) ||
299
- 'https://descopecdn.com/npm/@descope/web-components-ui@<version>/dist/umd/index.js';
300
- const UI_COMPONENTS_FALLBACK_URL = (IS_LOCAL_STORAGE && localStorage.getItem(UI_COMPONENTS_URL_KEY)) ||
301
- 'https://static.descope.com/npm/@descope/web-components-ui@<version>/dist/umd/index.js';
302
- const UI_COMPONENTS_FALLBACK_2_URL = (IS_LOCAL_STORAGE && localStorage.getItem(UI_COMPONENTS_URL_KEY)) ||
303
- 'https://cdn.jsdelivr.net/npm/@descope/web-components-ui@<version>/dist/umd/index.js';
304
- const UI_COMPONENTS_URL_VERSION_PLACEHOLDER = '<version>';
305
-
306
- const setupScript = (id) => {
307
- const scriptEle = document.createElement('script');
308
- scriptEle.id = id;
309
- return scriptEle;
310
- };
311
- const generateScriptUrl = (urlTemplate, componentsVersion) => urlTemplate.replace(UI_COMPONENTS_URL_VERSION_PLACEHOLDER, componentsVersion);
312
- const getDescopeUiComponentsList = (template) => [
313
- ...Array.from(template.content.querySelectorAll('*')).reduce((acc, el) => el.localName.startsWith('descope-') ? acc.add(el.localName) : acc, new Set()),
314
- ];
315
-
316
- const descopeUiMixin = sdkHelpers.createSingletonMixin((superclass) => {
317
- var _DescopeUiMixinClass_instances, _DescopeUiMixinClass_errorCbsSym, _DescopeUiMixinClass_loadCbsSym, _DescopeUiMixinClass_getComponentsVersion, _DescopeUiMixinClass_exposeAlternateEvents, _DescopeUiMixinClass_handleFallbackScript, _DescopeUiMixinClass_registerEvents, _DescopeUiMixinClass_getDescopeUiLoadingScript, _DescopeUiMixinClass_descopeUi, _DescopeUiMixinClass_loadDescopeUiComponent, _DescopeUiMixinClass_getDescopeUi, _a;
318
- const BaseClass = sdkHelpers.compose(loggerMixin, configMixin)(superclass);
319
- return _a = class DescopeUiMixinClass extends BaseClass {
320
- constructor() {
321
- super(...arguments);
322
- _DescopeUiMixinClass_instances.add(this);
323
- _DescopeUiMixinClass_errorCbsSym.set(this, Symbol('errorCbs'));
324
- _DescopeUiMixinClass_loadCbsSym.set(this, Symbol('loadCbs'));
325
- _DescopeUiMixinClass_descopeUi.set(this, void 0);
326
- }
327
- get descopeUi() {
328
- if (!tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_descopeUi, "f")) {
329
- tslib.__classPrivateFieldSet(this, _DescopeUiMixinClass_descopeUi, tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_instances, "m", _DescopeUiMixinClass_getDescopeUi).call(this), "f");
330
- }
331
- return tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_descopeUi, "f");
332
- }
333
- async loadDescopeUiComponents(templateOrComponentNames) {
334
- const descopeUiComponentsList = Array.isArray(templateOrComponentNames)
335
- ? templateOrComponentNames
336
- : getDescopeUiComponentsList(templateOrComponentNames);
337
- return Promise.all(descopeUiComponentsList.map((componentName) => tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_instances, "m", _DescopeUiMixinClass_loadDescopeUiComponent).call(this, componentName)));
338
- }
339
- },
340
- _DescopeUiMixinClass_errorCbsSym = new WeakMap(),
341
- _DescopeUiMixinClass_loadCbsSym = new WeakMap(),
342
- _DescopeUiMixinClass_descopeUi = new WeakMap(),
343
- _DescopeUiMixinClass_instances = new WeakSet(),
344
- _DescopeUiMixinClass_getComponentsVersion =
345
- // eslint-disable-next-line class-methods-use-this
346
- async function _DescopeUiMixinClass_getComponentsVersion() {
347
- var _b;
348
- const config = await this.config;
349
- const componentsVersion = (_b = config === null || config === void 0 ? void 0 : config.projectConfig) === null || _b === void 0 ? void 0 : _b.componentsVersion;
350
- if (!componentsVersion) {
351
- this.logger.error('Could not get components version');
352
- }
353
- else {
354
- this.logger.debug(`Got component version "${componentsVersion}"`);
355
- }
356
- return componentsVersion;
357
- },
358
- _DescopeUiMixinClass_exposeAlternateEvents = function _DescopeUiMixinClass_exposeAlternateEvents(scriptEle) {
359
- const errorCbsSym = tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_errorCbsSym, "f");
360
- const loadCbsSym = tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_loadCbsSym, "f");
361
- // eslint-disable-next-line no-param-reassign
362
- scriptEle[errorCbsSym] = [];
363
- // eslint-disable-next-line no-param-reassign
364
- scriptEle[loadCbsSym] = [];
365
- Object.defineProperty(scriptEle, 'onerror', {
366
- set(cb) {
367
- scriptEle[errorCbsSym].push(cb);
368
- },
369
- });
370
- Object.defineProperty(scriptEle, 'onload', {
371
- set(cb) {
372
- scriptEle[loadCbsSym].push(cb);
373
- },
374
- });
375
- },
376
- _DescopeUiMixinClass_handleFallbackScript = async function _DescopeUiMixinClass_handleFallbackScript(errorCbs, loadCbs, elemId, scriptUrl) {
377
- this.logger.debug('Trying to load DescopeUI from a fallback URL');
378
- const fallbackScriptEle = setupScript(elemId);
379
- document.body.append(fallbackScriptEle);
380
- fallbackScriptEle.addEventListener('error', () => {
381
- errorCbs.forEach((cb) => cb(`Cannot load DescopeUI from fallback URL, Make sure this URL is valid and return the correct script: "${fallbackScriptEle.src}"`));
382
- });
383
- fallbackScriptEle.addEventListener('load', () => {
384
- loadCbs.forEach((cb) => cb());
385
- });
386
- fallbackScriptEle.src = generateScriptUrl(scriptUrl, await tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_instances, "m", _DescopeUiMixinClass_getComponentsVersion).call(this));
387
- },
388
- _DescopeUiMixinClass_registerEvents = function _DescopeUiMixinClass_registerEvents(scriptEle) {
389
- scriptEle.addEventListener('error', () => {
390
- scriptEle[tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_errorCbsSym, "f")].forEach((cb) => cb(`Cannot load DescopeUI from main URL, Make sure this URL is valid and return the correct script: "${scriptEle.src}"`));
391
- // in case we could not load DescopeUI from the main URL, we are trying to load it from a fallback URL
392
- tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_instances, "m", _DescopeUiMixinClass_handleFallbackScript).call(this, [
393
- // we are adding a second fallback
394
- tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_instances, "m", _DescopeUiMixinClass_handleFallbackScript).bind(this, scriptEle[tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_errorCbsSym, "f")], scriptEle[tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_loadCbsSym, "f")], DESCOPE_UI_FALLBACK_2_SCRIPT_ID, UI_COMPONENTS_FALLBACK_2_URL),
395
- ...scriptEle[tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_errorCbsSym, "f")],
396
- ], scriptEle[tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_loadCbsSym, "f")], DESCOPE_UI_FALLBACK_SCRIPT_ID, UI_COMPONENTS_FALLBACK_URL);
397
- });
398
- scriptEle.addEventListener('load', () => {
399
- scriptEle[tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_loadCbsSym, "f")].forEach((cb) => cb());
400
- });
401
- },
402
- _DescopeUiMixinClass_getDescopeUiLoadingScript = async function _DescopeUiMixinClass_getDescopeUiLoadingScript() {
403
- if (!document.querySelector(`script#${DESCOPE_UI_SCRIPT_ID}`)) {
404
- this.logger.debug('DescopeUI loading script does not exist, creating it', this);
405
- const scriptEle = setupScript(DESCOPE_UI_SCRIPT_ID);
406
- document.body.append(scriptEle);
407
- tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_instances, "m", _DescopeUiMixinClass_exposeAlternateEvents).call(this, scriptEle);
408
- tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_instances, "m", _DescopeUiMixinClass_registerEvents).call(this, scriptEle);
409
- scriptEle.src = generateScriptUrl(UI_COMPONENTS_URL, await tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_instances, "m", _DescopeUiMixinClass_getComponentsVersion).call(this));
410
- }
411
- else {
412
- this.logger.debug('DescopeUI loading script already exists', this);
413
- }
414
- return document.getElementById(DESCOPE_UI_SCRIPT_ID);
415
- },
416
- _DescopeUiMixinClass_loadDescopeUiComponent = async function _DescopeUiMixinClass_loadDescopeUiComponent(componentName) {
417
- const isComponentAlreadyDefined = !!customElements.get(componentName);
418
- if (isComponentAlreadyDefined) {
419
- this.logger.debug(`Loading component "${componentName}" is skipped as it is already defined`);
420
- return undefined;
421
- }
422
- const descopeUI = await this.descopeUi;
423
- if (!descopeUI[componentName]) {
424
- this.logger.error(`Cannot load UI component "${componentName}"`, `Descope UI does not have a component named "${componentName}", available components are: "${Object.keys(descopeUI).join(', ')}"`);
425
- return undefined;
426
- }
427
- try {
428
- // eslint-disable-next-line @typescript-eslint/return-await
429
- return await descopeUI[componentName]();
430
- }
431
- catch (e) {
432
- // this error is thrown when trying to register a component which is already registered
433
- // when running 2 flows on the same page, it might happen that the register fn is called twice
434
- // in case it happens, we are silently ignore the error
435
- if (e.name === 'NotSupportedError') {
436
- // eslint-disable-next-line no-console
437
- console.debug(`Encountered an error while attempting to define the "${componentName}" component, it is likely that this component is already defined`);
438
- }
439
- else {
440
- throw e;
441
- }
442
- }
443
- return undefined;
444
- },
445
- _DescopeUiMixinClass_getDescopeUi = function _DescopeUiMixinClass_getDescopeUi() {
446
- return new Promise((res) => {
447
- if (globalThis.DescopeUI) {
448
- res(globalThis.DescopeUI);
449
- }
450
- tslib.__classPrivateFieldGet(this, _DescopeUiMixinClass_instances, "m", _DescopeUiMixinClass_getDescopeUiLoadingScript).call(this).then((scriptEle) => {
451
- // eslint-disable-next-line no-param-reassign
452
- scriptEle.onerror = this.logger.error;
453
- // eslint-disable-next-line no-param-reassign
454
- scriptEle.onload = () => {
455
- this.logger.debug('DescopeUI was loaded');
456
- res(globalThis.DescopeUI);
457
- };
458
- // in case the load event was dispatched before we registered, we have a fallback
459
- setTimeout(() => {
460
- if (globalThis.DescopeUI) {
461
- res(globalThis.DescopeUI);
462
- }
463
- });
464
- });
465
- });
466
- },
467
- _a;
468
- });
469
-
470
- const CONTENT_ROOT_ID = 'content-root';
471
- const ROOT_ID = 'root';
472
- const initElementMixin = sdkHelpers.createSingletonMixin((superclass) => class InitElementMixinClass extends superclass {
473
- constructor(...rest) {
474
- var _a, _b;
475
- super(...rest);
476
- this.attachShadow({ mode: 'open' }).innerHTML = `
477
-
478
- <style>
479
- #${ROOT_ID}, #${CONTENT_ROOT_ID} {
480
- height: 100%;
481
- }
482
- #${ROOT_ID} {
483
- position: relative;
484
- height: fit-content;
485
- }
486
- </style>
487
- <div id="${ROOT_ID}">
488
- <div id="${CONTENT_ROOT_ID}"></div>
489
- </div>
490
- `;
491
- this.contentRootElement =
492
- (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.getElementById(CONTENT_ROOT_ID);
493
- this.rootElement = (_b = this.shadowRoot) === null || _b === void 0 ? void 0 : _b.getElementById(ROOT_ID);
494
- }
495
- });
496
-
497
- const MODAL_ELE_TAG = 'descope-modal';
498
-
499
- const createModalEle = (config = {}) => {
500
- const modal = document.createElement(MODAL_ELE_TAG);
501
- Object.keys(config).forEach((key) => {
502
- modal.setAttribute(key, config[key]);
503
- });
504
- return modal;
505
- };
506
-
507
- const modalMixin = sdkHelpers.createSingletonMixin((superclass) => {
508
- var _ModalMixinClass_ModalDriverWrapper, _a;
509
- const BaseClass = sdkHelpers.compose(initLifecycleMixin, initElementMixin, descopeUiMixin)(superclass);
510
- return _a = class ModalMixinClass extends BaseClass {
511
- constructor() {
512
- super(...arguments);
513
- _ModalMixinClass_ModalDriverWrapper.set(this, (() => {
514
- const loadDescopeUiComponents = this.loadDescopeUiComponents.bind(this);
515
- return class ModalDriverWrapper extends sdkComponentDrivers.ModalDriver {
516
- setContent(template) {
517
- loadDescopeUiComponents(template);
518
- super.setContent(template);
519
- }
520
- };
521
- })());
522
- }
523
- createModal(config) {
524
- const baseConfig = {};
525
- const modal = createModalEle(Object.assign(Object.assign({}, baseConfig), config));
526
- this.rootElement.append(modal);
527
- return new (tslib.__classPrivateFieldGet(this, _ModalMixinClass_ModalDriverWrapper, "f"))(modal, {
528
- logger: this.logger,
529
- });
530
- }
531
- async init() {
532
- var _b;
533
- this.loadDescopeUiComponents([MODAL_ELE_TAG]);
534
- await ((_b = super.init) === null || _b === void 0 ? void 0 : _b.call(this));
535
- }
536
- },
537
- _ModalMixinClass_ModalDriverWrapper = new WeakMap(),
538
- _a;
539
- });
540
-
541
- const NOTIFICATION_ELE_TAG = 'descope-notification';
542
-
543
- const createNotificationEle = (config = {}) => {
544
- const notification = document.createElement(NOTIFICATION_ELE_TAG);
545
- Object.keys(config).forEach((key) => {
546
- notification.setAttribute(key, config[key]);
547
- });
548
- return notification;
549
- };
550
-
551
- const notificationsMixin = sdkHelpers.createSingletonMixin((superclass) => {
552
- var _NotificationsMixinClass_NotificationDriverWrapper, _a;
553
- const BaseClass = sdkHelpers.compose(initLifecycleMixin, initElementMixin, descopeUiMixin)(superclass);
554
- return _a = class NotificationsMixinClass extends BaseClass {
555
- constructor() {
556
- super(...arguments);
557
- _NotificationsMixinClass_NotificationDriverWrapper.set(this, (() => {
558
- const loadDescopeUiComponents = this.loadDescopeUiComponents.bind(this);
559
- return class NotificationDriverWrapper extends sdkComponentDrivers.NotificationDriver {
560
- setContent(templateOrString) {
561
- const template = typeof templateOrString === 'string'
562
- ? sdkHelpers.createTemplate(templateOrString)
563
- : templateOrString;
564
- loadDescopeUiComponents(template);
565
- super.setContent(template);
566
- }
567
- };
568
- })());
569
- }
570
- createNotification(config) {
571
- const baseConfig = {};
572
- const notification = createNotificationEle(Object.assign(Object.assign({}, baseConfig), config));
573
- this.rootElement.append(notification);
574
- return new (tslib.__classPrivateFieldGet(this, _NotificationsMixinClass_NotificationDriverWrapper, "f"))(notification, {
575
- logger: this.logger,
576
- });
577
- }
578
- async init() {
579
- var _b;
580
- await ((_b = super.init) === null || _b === void 0 ? void 0 : _b.call(this));
581
- this.loadDescopeUiComponents([NOTIFICATION_ELE_TAG]);
582
- }
583
- },
584
- _NotificationsMixinClass_NotificationDriverWrapper = new WeakMap(),
585
- _a;
586
- });
587
-
588
- // Those files are saved on a new folder to prevent breaking changes
589
- const DEFAULT_STYLE_ID = 'theme';
590
-
591
- const loadFont = (url) => {
592
- const font = document.createElement('link');
593
- font.href = url;
594
- font.rel = 'stylesheet';
595
- document.head.appendChild(font);
596
- };
597
- const loadDevTheme = async () => {
598
- const componentsUrl = localStorage.getItem(UI_COMPONENTS_URL_KEY);
599
- const descopeDevUrl = componentsUrl === null || componentsUrl === void 0 ? void 0 : componentsUrl.replace(/[^\/]+$/, 'DescopeDev.js');
600
- // eslint-disable-next-line no-console
601
- console.warn('Trying to load DescopeDev.js from', descopeDevUrl);
602
- const scriptEle = document.createElement('script');
603
- scriptEle.src = descopeDevUrl;
604
- document.body.appendChild(scriptEle);
605
- await new Promise((resolve, reject) => {
606
- scriptEle.onload = resolve;
607
- scriptEle.onerror = reject;
608
- });
609
- if (globalThis.DescopeDev) {
610
- const { themeToStyle, defaultTheme, darkTheme } = globalThis.DescopeDev;
611
- return {
612
- light: themeToStyle(defaultTheme),
613
- dark: themeToStyle(darkTheme),
614
- };
615
- }
616
- };
617
-
618
- const themeValidation = (_, theme) => (theme || false) &&
619
- theme !== 'light' &&
620
- theme !== 'dark' &&
621
- 'Supported theme values are "light", "dark", or leave empty for using the OS theme';
622
- const themeMixin = sdkHelpers.createSingletonMixin((superclass) => {
623
- var _ThemeMixinClass_instances, _ThemeMixinClass_globalStyleTag, _ThemeMixinClass__themeResource, _ThemeMixinClass_fetchTheme, _ThemeMixinClass_themeResource_get, _ThemeMixinClass_loadGlobalStyle, _ThemeMixinClass_loadComponentsStyle, _ThemeMixinClass_getFontsConfig, _ThemeMixinClass_loadFonts, _ThemeMixinClass_applyTheme, _a;
624
- const BaseClass = sdkHelpers.compose(createValidateAttributesMixin({ theme: themeValidation }), staticResourcesMixin, initLifecycleMixin, descopeUiMixin, configMixin, initElementMixin, observeAttributesMixin)(superclass);
625
- return _a = class ThemeMixinClass extends BaseClass {
626
- constructor() {
627
- super(...arguments);
628
- _ThemeMixinClass_instances.add(this);
629
- _ThemeMixinClass_globalStyleTag.set(this, void 0);
630
- _ThemeMixinClass__themeResource.set(this, void 0);
631
- }
632
- get theme() {
633
- var _b, _c;
634
- const theme = this.getAttribute('theme');
635
- if (theme === 'os') {
636
- const isOsDark = window.matchMedia &&
637
- ((_c = (_b = window.matchMedia) === null || _b === void 0 ? void 0 : _b.call(window, '(prefers-color-scheme: dark)')) === null || _c === void 0 ? void 0 : _c.matches);
638
- return isOsDark ? 'dark' : 'light';
639
- }
640
- return theme || 'light';
641
- }
642
- get styleId() {
643
- return this.getAttribute('style-id') || DEFAULT_STYLE_ID;
644
- }
645
- async init() {
646
- var _b;
647
- await ((_b = super.init) === null || _b === void 0 ? void 0 : _b.call(this));
648
- tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadGlobalStyle).call(this);
649
- tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadComponentsStyle).call(this);
650
- tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadFonts).call(this);
651
- tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_applyTheme).call(this);
652
- this.observeAttributes(['theme'], () => {
653
- tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadFonts).call(this);
654
- tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_applyTheme).call(this);
655
- });
656
- this.observeAttributes(['style-id'], () => {
657
- tslib.__classPrivateFieldSet(this, _ThemeMixinClass__themeResource, null, "f");
658
- tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadFonts).call(this);
659
- tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadGlobalStyle).call(this);
660
- tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadComponentsStyle).call(this);
661
- });
662
- }
663
- },
664
- _ThemeMixinClass_globalStyleTag = new WeakMap(),
665
- _ThemeMixinClass__themeResource = new WeakMap(),
666
- _ThemeMixinClass_instances = new WeakSet(),
667
- _ThemeMixinClass_fetchTheme = async function _ThemeMixinClass_fetchTheme() {
668
- try {
669
- const { body: fetchedTheme } = await this.fetchStaticResource(`${this.styleId}.json`, 'json');
670
- // In development mode, we sometimes want to override the UI components URL
671
- // The override components might have a different theme, so we need to merge it with the project theme in order to see the components correctly
672
- if (process.env.NODE_ENV === 'development') {
673
- if (localStorage === null || localStorage === void 0 ? void 0 : localStorage.getItem(UI_COMPONENTS_URL_KEY)) {
674
- try {
675
- this.logger.warn('You are in DEV mode, and UI components override URL was found\ntrying to merge project theme with the default theme of the UI components');
676
- const devTheme = await loadDevTheme();
677
- if (devTheme) {
678
- fetchedTheme.light.components = Object.assign(Object.assign({}, fetchedTheme.light.components), devTheme.light.components);
679
- fetchedTheme.dark.components = Object.assign(Object.assign({}, fetchedTheme.dark.components), devTheme.dark.components);
680
- this.logger.warn('Theme was merged successfully');
681
- // eslint-disable-next-line no-console
682
- console.log('%cNOTICE! This is not the theme that will be used in production!\n\nMake sure to test it without the override UI components URL!', 'color: black; background-color:yellow; font-size: x-large');
683
- }
684
- }
685
- catch (e) {
686
- this.logger.error('Failed to merge UI components theme\n', e);
687
- }
688
- }
689
- }
690
- return fetchedTheme;
691
- }
692
- catch (e) {
693
- this.logger.error('Cannot fetch theme file', 'make sure that your projectId & flowId are correct');
694
- }
695
- return undefined;
696
- },
697
- _ThemeMixinClass_themeResource_get = function _ThemeMixinClass_themeResource_get() {
698
- if (!tslib.__classPrivateFieldGet(this, _ThemeMixinClass__themeResource, "f")) {
699
- tslib.__classPrivateFieldSet(this, _ThemeMixinClass__themeResource, tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_fetchTheme).call(this), "f");
700
- tslib.__classPrivateFieldGet(this, _ThemeMixinClass__themeResource, "f").then((theme) => this.logger.debug('Fetched theme', theme));
701
- }
702
- // eslint-disable-next-line no-underscore-dangle
703
- return tslib.__classPrivateFieldGet(this, _ThemeMixinClass__themeResource, "f");
704
- },
705
- _ThemeMixinClass_loadGlobalStyle = async function _ThemeMixinClass_loadGlobalStyle() {
706
- var _b, _c;
707
- const theme = await tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "a", _ThemeMixinClass_themeResource_get);
708
- if (!theme)
709
- return;
710
- if (!tslib.__classPrivateFieldGet(this, _ThemeMixinClass_globalStyleTag, "f")) {
711
- tslib.__classPrivateFieldSet(this, _ThemeMixinClass_globalStyleTag, document.createElement('style'), "f");
712
- tslib.__classPrivateFieldGet(this, _ThemeMixinClass_globalStyleTag, "f").id = 'global-style';
713
- this.shadowRoot.appendChild(tslib.__classPrivateFieldGet(this, _ThemeMixinClass_globalStyleTag, "f"));
714
- }
715
- tslib.__classPrivateFieldGet(this, _ThemeMixinClass_globalStyleTag, "f").innerText =
716
- (((_b = theme === null || theme === void 0 ? void 0 : theme.light) === null || _b === void 0 ? void 0 : _b.globals) || '') + (((_c = theme === null || theme === void 0 ? void 0 : theme.dark) === null || _c === void 0 ? void 0 : _c.globals) || '');
717
- },
718
- _ThemeMixinClass_loadComponentsStyle = async function _ThemeMixinClass_loadComponentsStyle() {
719
- var _b, _c;
720
- const theme = Object.assign({}, (await tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "a", _ThemeMixinClass_themeResource_get)));
721
- if (!theme)
722
- return;
723
- const descopeUi = await this.descopeUi;
724
- if (descopeUi === null || descopeUi === void 0 ? void 0 : descopeUi.componentsThemeManager) {
725
- descopeUi.componentsThemeManager.themes = {
726
- light: (_b = theme === null || theme === void 0 ? void 0 : theme.light) === null || _b === void 0 ? void 0 : _b.components,
727
- dark: (_c = theme === null || theme === void 0 ? void 0 : theme.dark) === null || _c === void 0 ? void 0 : _c.components,
728
- };
729
- }
730
- },
731
- _ThemeMixinClass_getFontsConfig = async function _ThemeMixinClass_getFontsConfig() {
732
- var _b, _c;
733
- const { projectConfig } = (await this.config) || {};
734
- const newConfig = (_b = projectConfig === null || projectConfig === void 0 ? void 0 : projectConfig.styles) === null || _b === void 0 ? void 0 : _b[this.styleId];
735
- const oldConfig = projectConfig === null || projectConfig === void 0 ? void 0 : projectConfig.cssTemplate;
736
- const config = newConfig || oldConfig;
737
- const fonts = (_c = config === null || config === void 0 ? void 0 : config[this.theme]) === null || _c === void 0 ? void 0 : _c.fonts;
738
- return fonts;
739
- },
740
- _ThemeMixinClass_loadFonts = async function _ThemeMixinClass_loadFonts() {
741
- const fonts = await tslib.__classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_getFontsConfig).call(this);
742
- if (fonts) {
743
- Object.values(fonts).forEach((font) => {
744
- if (font.url) {
745
- this.logger.debug(`Loading font from URL "${font.url}"`);
746
- loadFont(font.url);
747
- }
748
- });
749
- }
750
- else {
751
- this.logger.debug('No fonts to load');
752
- }
753
- },
754
- _ThemeMixinClass_applyTheme = async function _ThemeMixinClass_applyTheme() {
755
- this.rootElement.setAttribute('data-theme', this.theme);
756
- const descopeUi = await this.descopeUi;
757
- if (descopeUi === null || descopeUi === void 0 ? void 0 : descopeUi.componentsThemeManager) {
758
- descopeUi.componentsThemeManager.currentThemeName = this.theme;
759
- }
760
- },
761
- _a;
762
- });
763
-
764
- /* eslint-disable no-param-reassign */
765
- const createStateManagementMixin = (options) => sdkHelpers.createSingletonMixin((superclass) => {
766
- const slice = toolkit.createSlice(options);
767
- const allActions = Object.assign(Object.assign({}, slice.actions), options.asyncActions);
768
- return class StateManagementMixinClass extends sdkHelpers.compose(loggerMixin)(superclass) {
769
- constructor(...args) {
770
- super(...args);
771
- const store = toolkit.configureStore({
772
- reducer: slice.reducer,
773
- middleware: (getDefaultMiddleware) => getDefaultMiddleware({
774
- thunk: {
775
- extraArgument: this,
776
- },
777
- serializableCheck: false,
778
- }),
779
- // change to true if we want to debug redux
780
- devTools: false,
781
- });
782
- const wrapAction = (action) => (async (...arg) => {
783
- const result = await store.dispatch(action(...arg));
784
- // we want to unwrap the result, so in case of an error we can log it
785
- try {
786
- toolkit.unwrapResult(result);
787
- }
788
- catch (e) {
789
- this.logger.error(e.message, result.type, e.stack);
790
- }
791
- return result;
792
- });
793
- const actions = Object.keys(allActions).reduce((acc, actionName) => {
794
- acc[actionName] = wrapAction(allActions[actionName]);
795
- return acc;
796
- }, {});
797
- this.actions = actions;
798
- this.subscribe = (cb, selector = (state) => state) => store.subscribe(() => cb(selector(store.getState())));
799
- }
800
- };
801
- });
802
-
803
- const formMixin = sdkHelpers.createSingletonMixin((superclass) => class FormMixinClass extends loggerMixin(superclass) {
804
- validateForm(rootEle) {
805
- return this.getFormInputs(rootEle).every((input) => {
806
- var _a, _b;
807
- (_a = input.reportValidity) === null || _a === void 0 ? void 0 : _a.call(input);
808
- return (_b = input.checkValidity) === null || _b === void 0 ? void 0 : _b.call(input);
809
- });
810
- }
811
- // eslint-disable-next-line class-methods-use-this
812
- getFormInputs(rootEle) {
813
- if (!rootEle) {
814
- this.logger.debug('cannot get form inputs, no root element was received');
815
- return [];
816
- }
817
- return Array.from(rootEle.querySelectorAll('[name]'));
818
- }
819
- getFormData(rootEle) {
820
- return this.getFormInputs(rootEle).reduce((acc, input) => Object.assign(acc, { [input.getAttribute('name')]: input.value }), {});
821
- }
822
- setFormData(rootEle, data) {
823
- this.getFormInputs(rootEle).forEach((input) => {
824
- // eslint-disable-next-line no-prototype-builtins
825
- if (data.hasOwnProperty(input.getAttribute('name'))) {
826
- // eslint-disable-next-line no-param-reassign
827
- input.value = data[input.getAttribute('name')];
828
- }
829
- });
830
- }
831
- resetFormData(rootEle) {
832
- this.getFormInputs(rootEle).forEach((input) => {
833
- // eslint-disable-next-line no-param-reassign
834
- input.value = '';
835
- input.checked = false;
836
- });
837
- }
838
- getFormFieldNames(rootEle) {
839
- return this.getFormInputs(rootEle).map((ele) => ele.name);
840
- }
841
- disableFormField(rootEle, name) {
842
- var _a;
843
- (_a = this.getFormInputs(rootEle)
844
- .find((input) => input.name === name)) === null || _a === void 0 ? void 0 : _a.setAttribute('disabled', 'true');
845
- }
846
- removeFormField(rootEle, name) {
847
- var _a;
848
- (_a = this.getFormInputs(rootEle)
849
- .find((input) => input.name === name)) === null || _a === void 0 ? void 0 : _a.remove();
850
- }
851
- });
852
-
853
- const baseStaticUrlMixin = sdkHelpers.createSingletonMixin((superclass) => {
854
- return class BaseStaticUrlMixinClass extends superclass {
855
- get baseStaticUrl() {
856
- return this.getAttribute('base-static-url') || '';
857
- }
858
- };
859
- });
860
-
861
- const limitCoordinateToScreenBoundaries = (ele, x, y, boundaries = {}) => {
862
- var _a, _b, _c, _d;
863
- return [
864
- Math.min(Math.max(x, (boundaries.left === 'all' ? ele.offsetWidth : (_a = boundaries.left) !== null && _a !== void 0 ? _a : 0) -
865
- ele.offsetWidth), window.innerWidth -
866
- (boundaries.right === 'all' ? ele.offsetWidth : (_b = boundaries.right) !== null && _b !== void 0 ? _b : 0)),
867
- Math.min(Math.max(y, (boundaries.top === 'all' ? ele.offsetHeight : (_c = boundaries.top) !== null && _c !== void 0 ? _c : 0) -
868
- ele.offsetHeight), window.innerHeight -
869
- (boundaries.bottom === 'all' ? ele.offsetHeight : (_d = boundaries.bottom) !== null && _d !== void 0 ? _d : 0)),
870
- ];
871
- };
872
- const dragElement = (ele, triggerEle, keepVisible) => {
873
- let deltaX = 0;
874
- let deltaY = 0;
875
- let currentX = 0;
876
- let currentY = 0;
877
- function elementDrag(e) {
878
- e.preventDefault();
879
- // calculate the new cursor position:
880
- deltaX = currentX - e.clientX;
881
- deltaY = currentY - e.clientY;
882
- currentX = e.clientX;
883
- currentY = e.clientY;
884
- // set the element's new position:
885
- const [left, top] = limitCoordinateToScreenBoundaries(ele, ele.offsetLeft - deltaX, ele.offsetTop - deltaY, keepVisible);
886
- // eslint-disable-next-line no-param-reassign
887
- ele.style.top = `${top}px`;
888
- // eslint-disable-next-line no-param-reassign
889
- ele.style.left = `${left}px`;
890
- }
891
- function closeDragElement() {
892
- // stop moving when mouse button is released:
893
- document.onmouseup = null;
894
- document.onmousemove = null;
895
- }
896
- function dragMouseDown(e) {
897
- e.preventDefault();
898
- // get the mouse cursor position at startup:
899
- currentX = e.clientX;
900
- currentY = e.clientY;
901
- document.onmouseup = closeDragElement;
902
- // call a function whenever the cursor moves:
903
- document.onmousemove = elementDrag;
904
- }
905
- if (triggerEle) {
906
- // if provided, the triggerEle is where you move the div from
907
- // eslint-disable-next-line no-param-reassign
908
- triggerEle.onmousedown = dragMouseDown;
909
- }
910
- else {
911
- // otherwise, move the DIV from anywhere inside the DIV:
912
- // eslint-disable-next-line no-param-reassign
913
- ele.onmousedown = dragMouseDown;
914
- }
915
- };
916
- const addOnResize = (ele) => {
917
- // eslint-disable-next-line no-param-reassign
918
- ele.onmousemove = (e) => {
919
- var _a;
920
- // eslint-disable-next-line prefer-destructuring
921
- const target = e.target;
922
- if ((target.w && target.w !== target.offsetWidth) ||
923
- (target.h && target.h !== target.offsetHeight)) {
924
- (_a = ele.onresize) === null || _a === void 0 ? void 0 : _a.call(ele, e);
925
- }
926
- target.w = target.offsetWidth;
927
- target.h = target.offsetHeight;
928
- };
929
- };
930
-
931
- var _Debugger_instances, _Debugger_messagesState, _Debugger_rootEle, _Debugger_contentEle, _Debugger_headerEle, _Debugger_eventsCbRefs, _Debugger_onNewMessages, _Debugger_renderMessages, _Debugger_setCollapsibleMessages, _Debugger_onWindowResize;
932
- const INITIAL_POS_THRESHOLD = 32;
933
- const INITIAL_WIDTH = 300;
934
- const INITIAL_HEIGHT = 200;
935
- const MIN_SIZE = 200;
936
- const template = document.createElement('template');
937
- template.innerHTML = `
938
- <style>
939
- .debugger {
940
- width: ${INITIAL_WIDTH}px;
941
- height: ${INITIAL_HEIGHT}px;
942
- background-color: #FAFAFA;
943
- position: fixed;
944
- font-family: "Helvetica Neue", sans-serif;
945
- box-shadow: rgba(0, 0, 0, 0.1) 0px 5px 10px;
946
- border-radius: 8px;
947
- overflow: hidden;
948
- border: 1px solid lightgrey;
949
- pointer-events: initial;
950
- display: flex;
951
- flex-direction: column;
952
- min-width: ${MIN_SIZE}px;
953
- max-width: 600px;
954
- max-height: calc(100% - ${INITIAL_POS_THRESHOLD * 2}px);
955
- min-height: ${MIN_SIZE}px;
956
- resize: both;
957
- }
958
-
959
- .header {
960
- padding: 8px 16px;
961
- display: flex;
962
- align-items: center;
963
- background-color: #EEEEEE;
964
- cursor: move;
965
- border-bottom: 1px solid #e0e0e0;
966
- }
967
-
968
- .content {
969
- font-size: 14px;
970
- flex-grow: 1;
971
- overflow: auto;
972
- }
973
-
974
- .msg {
975
- border-bottom: 1px solid lightgrey;
976
- padding: 8px 16px;
977
- display: flex;
978
- gap: 5px;
979
- background-color: #FAFAFA;
980
- }
981
-
982
- .msg.collapsible {
983
- cursor: pointer;
984
- }
985
-
986
- .empty-state {
987
- padding: 8px 16px;
988
- background-color: #FAFAFA;
989
- }
990
-
991
-
992
- .msg.collapsible:not(.collapsed) {
993
- background-color: #F5F5F5;
994
- }
995
-
996
- .msg_title {
997
- padding-bottom: 5px;
998
- display: flex;
999
- gap: 8px;
1000
- font-weight: 500;
1001
- }
1002
-
1003
- .msg svg {
1004
- padding: 1px;
1005
- flex-shrink: 0;
1006
- margin-top: -2px;
1007
- }
1008
-
1009
- .msg_content {
1010
- overflow: hidden;
1011
- flex-grow: 1;
1012
- margin-right:5px;
1013
- }
1014
-
1015
- .msg_desc {
1016
- color: #646464;
1017
- cursor: initial;
1018
- word-wrap: break-word;
1019
- }
1020
-
1021
- .msg.collapsed .msg_desc {
1022
- overflow: hidden;
1023
- text-overflow: ellipsis;
1024
- white-space: nowrap;
1025
- }
1026
-
1027
- .msg.collapsible.collapsed .chevron {
1028
- transform: rotate(-45deg) translateX(-2px);
1029
- }
1030
-
1031
- .msg.collapsible .chevron {
1032
- content: "";
1033
- width:6px;
1034
- height:6px;
1035
- border-bottom: 2px solid grey;
1036
- border-right: 2px solid grey;
1037
- transform: rotate(45deg) translateX(-1px);
1038
- margin: 5px;
1039
- flex-shrink:0;
1040
- }
1041
- </style>
1042
-
1043
- <div style="top:${INITIAL_POS_THRESHOLD}px; left:${window.innerWidth - INITIAL_WIDTH - INITIAL_POS_THRESHOLD}px;" class="debugger">
1044
- <div class="header">
1045
- <span>Debugger messages</span>
1046
- </div>
1047
- <div class="content">
1048
- <div class="empty-state">
1049
- No errors detected 👀
1050
- </div>
1051
- </div>
1052
- </div>
1053
- `;
1054
- const icon = `<svg width="18" height="18" viewBox="0 0 18 18" fill="none" xmlns="http://www.w3.org/2000/svg">
1055
- <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"/>
1056
- </svg>
1057
- `;
1058
- class Debugger extends HTMLElement {
1059
- constructor() {
1060
- var _a;
1061
- super();
1062
- _Debugger_instances.add(this);
1063
- _Debugger_messagesState.set(this, new sdkHelpers.State({ messages: [] }));
1064
- _Debugger_rootEle.set(this, void 0);
1065
- _Debugger_contentEle.set(this, void 0);
1066
- _Debugger_headerEle.set(this, void 0);
1067
- _Debugger_eventsCbRefs.set(this, {
1068
- resize: tslib.__classPrivateFieldGet(this, _Debugger_instances, "m", _Debugger_onWindowResize).bind(this),
1069
- });
1070
- this.attachShadow({ mode: 'open' });
1071
- (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.appendChild(template.content.cloneNode(true));
1072
- tslib.__classPrivateFieldSet(this, _Debugger_rootEle, this.shadowRoot.querySelector('.debugger'), "f");
1073
- tslib.__classPrivateFieldSet(this, _Debugger_contentEle, tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f").querySelector('.content'), "f");
1074
- tslib.__classPrivateFieldSet(this, _Debugger_headerEle, tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f").querySelector('.header'), "f");
1075
- }
1076
- updateData(data) {
1077
- tslib.__classPrivateFieldGet(this, _Debugger_messagesState, "f").update((state) => ({
1078
- messages: state.messages.concat(data),
1079
- }));
1080
- }
1081
- connectedCallback() {
1082
- dragElement(tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f"), tslib.__classPrivateFieldGet(this, _Debugger_headerEle, "f"), {
1083
- top: 'all',
1084
- bottom: 100,
1085
- left: 100,
1086
- right: 100,
1087
- });
1088
- window.addEventListener('resize', tslib.__classPrivateFieldGet(this, _Debugger_eventsCbRefs, "f").resize);
1089
- addOnResize(tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f"));
1090
- tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f").onresize = tslib.__classPrivateFieldGet(this, _Debugger_instances, "m", _Debugger_setCollapsibleMessages).bind(this);
1091
- tslib.__classPrivateFieldGet(this, _Debugger_messagesState, "f").subscribe(tslib.__classPrivateFieldGet(this, _Debugger_instances, "m", _Debugger_onNewMessages).bind(this));
1092
- }
1093
- disconnectedCallback() {
1094
- tslib.__classPrivateFieldGet(this, _Debugger_messagesState, "f").unsubscribeAll();
1095
- window.removeEventListener('resize', tslib.__classPrivateFieldGet(this, _Debugger_eventsCbRefs, "f").resize);
1096
- }
1097
- }
1098
- _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) {
1099
- tslib.__classPrivateFieldGet(this, _Debugger_instances, "m", _Debugger_renderMessages).call(this, data);
1100
- tslib.__classPrivateFieldGet(this, _Debugger_instances, "m", _Debugger_setCollapsibleMessages).call(this);
1101
- }, _Debugger_renderMessages = function _Debugger_renderMessages(data) {
1102
- tslib.__classPrivateFieldGet(this, _Debugger_contentEle, "f").innerHTML = data.messages
1103
- .map((message) => `
1104
- <div class="msg">
1105
- ${icon}
1106
- <div class="msg_content">
1107
- <div class="msg_title">
1108
- ${message.title}
1109
- </div>
1110
- <div class="msg_desc">
1111
- ${message.description || ''}
1112
- </div>
1113
- </div>
1114
- <div class="chevron"></div>
1115
- </div>
1116
- `)
1117
- .join('');
1118
- }, _Debugger_setCollapsibleMessages = function _Debugger_setCollapsibleMessages() {
1119
- tslib.__classPrivateFieldGet(this, _Debugger_contentEle, "f").querySelectorAll('.msg').forEach((element) => {
1120
- const ele = element;
1121
- const descEle = ele.querySelector('.msg_desc');
1122
- const lineHeight = 20;
1123
- const isScroll = descEle.scrollWidth > descEle.clientWidth;
1124
- const isMultiLine = descEle.clientHeight > lineHeight;
1125
- const isCollapsible = isScroll || isMultiLine;
1126
- if (isCollapsible) {
1127
- ele.classList.add('collapsible');
1128
- ele.onclick = (e) => {
1129
- // message description should not toggle collapse
1130
- if (!e.target.classList.contains('msg_desc')) {
1131
- ele.classList.toggle('collapsed');
1132
- }
1133
- };
1134
- }
1135
- else {
1136
- ele.classList.remove('collapsible');
1137
- ele.onclick = null;
1138
- }
1139
- });
1140
- }, _Debugger_onWindowResize = function _Debugger_onWindowResize() {
1141
- // when window is resizing we want to make sure debugger is still visible
1142
- const [left, top] = 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 });
1143
- tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f").style.top = `${top}px`;
1144
- tslib.__classPrivateFieldGet(this, _Debugger_rootEle, "f").style.left = `${left}px`;
1145
- };
1146
- if (!customElements.get('descope-debugger')) {
1147
- customElements.define('descope-debugger', Debugger);
1148
- }
1149
-
1150
- var debuggerWc = /*#__PURE__*/Object.freeze({
1151
- __proto__: null
1152
- });
1153
-
1154
- exports.baseStaticUrlMixin = baseStaticUrlMixin;
1155
- exports.baseUrlMixin = baseUrlMixin;
1156
- exports.configMixin = configMixin;
1157
- exports.createStateManagementMixin = createStateManagementMixin;
1158
- exports.createValidateAttributesMixin = createValidateAttributesMixin;
1159
- exports.debuggerMixin = debuggerMixin;
1160
- exports.descopeUiMixin = descopeUiMixin;
1161
- exports.formMixin = formMixin;
1162
- exports.getResourceUrl = getResourceUrl;
1163
- exports.initElementMixin = initElementMixin;
1164
- exports.initLifecycleMixin = initLifecycleMixin;
1165
- exports.loggerMixin = loggerMixin;
1166
- exports.modalMixin = modalMixin;
1167
- exports.notificationsMixin = notificationsMixin;
1168
- exports.observeAttributesMixin = observeAttributesMixin;
1169
- exports.projectIdMixin = projectIdMixin;
1170
- exports.staticResourcesMixin = staticResourcesMixin;
1171
- exports.themeMixin = themeMixin;
1172
- //# sourceMappingURL=index.cjs.js.map