@descope/sdk-mixins 0.0.0-next-cd745c61-20250421 → 0.0.0-next-26df9ba9-20250424

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (215) 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 +43 -0
  4. package/dist/cjs/index.js.map +1 -0
  5. package/dist/cjs/mixins/baseUrlMixin.js +14 -0
  6. package/dist/cjs/mixins/baseUrlMixin.js.map +1 -0
  7. package/dist/cjs/mixins/configMixin/configMixin.js +53 -0
  8. package/dist/cjs/mixins/configMixin/configMixin.js.map +1 -0
  9. package/dist/cjs/mixins/configMixin/constants.js +6 -0
  10. package/dist/cjs/mixins/configMixin/constants.js.map +1 -0
  11. package/dist/cjs/mixins/cookieConfigMixin.js +14 -0
  12. package/dist/cjs/mixins/cookieConfigMixin.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 +237 -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 +14 -0
  26. package/dist/cjs/mixins/descopeUiMixin/constants.js.map +1 -0
  27. package/dist/cjs/mixins/descopeUiMixin/descopeUiMixin.js +96 -0
  28. package/dist/cjs/mixins/descopeUiMixin/descopeUiMixin.js.map +1 -0
  29. package/dist/cjs/mixins/descopeUiMixin/helpers.js +8 -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 +39 -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/injectNpmLibMixin/constants.js +10 -0
  38. package/dist/cjs/mixins/injectNpmLibMixin/constants.js.map +1 -0
  39. package/dist/cjs/mixins/injectNpmLibMixin/helpers.js +112 -0
  40. package/dist/cjs/mixins/injectNpmLibMixin/helpers.js.map +1 -0
  41. package/dist/cjs/mixins/injectNpmLibMixin/injectNpmLibMixin.js +28 -0
  42. package/dist/cjs/mixins/injectNpmLibMixin/injectNpmLibMixin.js.map +1 -0
  43. package/dist/cjs/mixins/loggerMixin/loggerMixin.js +37 -0
  44. package/dist/cjs/mixins/loggerMixin/loggerMixin.js.map +1 -0
  45. package/dist/cjs/mixins/modalMixin/constants.js +6 -0
  46. package/dist/cjs/mixins/modalMixin/constants.js.map +1 -0
  47. package/dist/cjs/mixins/modalMixin/helpers.js +14 -0
  48. package/dist/cjs/mixins/modalMixin/helpers.js.map +1 -0
  49. package/dist/cjs/mixins/modalMixin/modalMixin.js +47 -0
  50. package/dist/cjs/mixins/modalMixin/modalMixin.js.map +1 -0
  51. package/dist/cjs/mixins/notificationsMixin/constants.js +6 -0
  52. package/dist/cjs/mixins/notificationsMixin/constants.js.map +1 -0
  53. package/dist/cjs/mixins/notificationsMixin/helpers.js +14 -0
  54. package/dist/cjs/mixins/notificationsMixin/helpers.js.map +1 -0
  55. package/dist/cjs/mixins/notificationsMixin/notificationsMixin.js +50 -0
  56. package/dist/cjs/mixins/notificationsMixin/notificationsMixin.js.map +1 -0
  57. package/dist/cjs/mixins/observeAttributesMixin/helpers.js +17 -0
  58. package/dist/cjs/mixins/observeAttributesMixin/helpers.js.map +1 -0
  59. package/dist/cjs/mixins/observeAttributesMixin/observeAttributesMixin.js +47 -0
  60. package/dist/cjs/mixins/observeAttributesMixin/observeAttributesMixin.js.map +1 -0
  61. package/dist/cjs/mixins/projectIdMixin.js +17 -0
  62. package/dist/cjs/mixins/projectIdMixin.js.map +1 -0
  63. package/dist/cjs/mixins/resetMixin.js +47 -0
  64. package/dist/cjs/mixins/resetMixin.js.map +1 -0
  65. package/dist/cjs/mixins/staticResourcesMixin/constants.js +13 -0
  66. package/dist/cjs/mixins/staticResourcesMixin/constants.js.map +1 -0
  67. package/dist/cjs/mixins/staticResourcesMixin/fetchWithFallbacks.js +43 -0
  68. package/dist/cjs/mixins/staticResourcesMixin/fetchWithFallbacks.js.map +1 -0
  69. package/dist/cjs/mixins/staticResourcesMixin/index.js +9 -0
  70. package/dist/cjs/mixins/staticResourcesMixin/index.js.map +1 -0
  71. package/dist/cjs/mixins/staticResourcesMixin/staticResourcesMixin.js +101 -0
  72. package/dist/cjs/mixins/staticResourcesMixin/staticResourcesMixin.js.map +1 -0
  73. package/dist/cjs/mixins/themeMixin/constants.js +7 -0
  74. package/dist/cjs/mixins/themeMixin/constants.js.map +1 -0
  75. package/dist/cjs/mixins/themeMixin/helpers.js +34 -0
  76. package/dist/cjs/mixins/themeMixin/helpers.js.map +1 -0
  77. package/dist/cjs/mixins/themeMixin/index.js +8 -0
  78. package/dist/cjs/mixins/themeMixin/index.js.map +1 -0
  79. package/dist/cjs/mixins/themeMixin/themeMixin.js +179 -0
  80. package/dist/cjs/mixins/themeMixin/themeMixin.js.map +1 -0
  81. package/dist/cjs/package.json +1 -0
  82. package/dist/esm/constants.js +4 -0
  83. package/dist/esm/constants.js.map +1 -0
  84. package/dist/esm/index.js +19 -0
  85. package/dist/esm/index.js.map +1 -0
  86. package/dist/esm/mixins/baseUrlMixin.js +12 -0
  87. package/dist/esm/mixins/baseUrlMixin.js.map +1 -0
  88. package/dist/esm/mixins/configMixin/configMixin.js +51 -0
  89. package/dist/esm/mixins/configMixin/configMixin.js.map +1 -0
  90. package/dist/esm/mixins/configMixin/constants.js +4 -0
  91. package/dist/esm/mixins/configMixin/constants.js.map +1 -0
  92. package/dist/esm/mixins/cookieConfigMixin.js +12 -0
  93. package/dist/esm/mixins/cookieConfigMixin.js.map +1 -0
  94. package/dist/esm/mixins/createStateManagementMixin.js +45 -0
  95. package/dist/esm/mixins/createStateManagementMixin.js.map +1 -0
  96. package/dist/esm/mixins/createValidateAttributesMixin/commonValidators.js +5 -0
  97. package/dist/esm/mixins/createValidateAttributesMixin/commonValidators.js.map +1 -0
  98. package/dist/esm/mixins/createValidateAttributesMixin/createValidateAttributesMixin.js +38 -0
  99. package/dist/esm/mixins/createValidateAttributesMixin/createValidateAttributesMixin.js.map +1 -0
  100. package/dist/esm/mixins/debuggerMixin/debugger-wc.js +233 -0
  101. package/dist/esm/mixins/debuggerMixin/debugger-wc.js.map +1 -0
  102. package/dist/esm/mixins/debuggerMixin/debuggerMixin.js +71 -0
  103. package/dist/esm/mixins/debuggerMixin/debuggerMixin.js.map +1 -0
  104. package/dist/esm/mixins/debuggerMixin/helpers.js +72 -0
  105. package/dist/esm/mixins/debuggerMixin/helpers.js.map +1 -0
  106. package/dist/esm/mixins/descopeUiMixin/constants.js +9 -0
  107. package/dist/esm/mixins/descopeUiMixin/constants.js.map +1 -0
  108. package/dist/esm/mixins/descopeUiMixin/descopeUiMixin.js +94 -0
  109. package/dist/esm/mixins/descopeUiMixin/descopeUiMixin.js.map +1 -0
  110. package/dist/esm/mixins/descopeUiMixin/helpers.js +6 -0
  111. package/dist/esm/mixins/descopeUiMixin/helpers.js.map +1 -0
  112. package/dist/esm/mixins/formMixin.js +55 -0
  113. package/dist/esm/mixins/formMixin.js.map +1 -0
  114. package/dist/esm/mixins/initElementMixin.js +37 -0
  115. package/dist/esm/mixins/initElementMixin.js.map +1 -0
  116. package/dist/esm/mixins/initLifecycleMixin.js +27 -0
  117. package/dist/esm/mixins/initLifecycleMixin.js.map +1 -0
  118. package/dist/esm/mixins/injectNpmLibMixin/constants.js +8 -0
  119. package/dist/esm/mixins/injectNpmLibMixin/constants.js.map +1 -0
  120. package/dist/esm/mixins/injectNpmLibMixin/helpers.js +109 -0
  121. package/dist/esm/mixins/injectNpmLibMixin/helpers.js.map +1 -0
  122. package/dist/esm/mixins/injectNpmLibMixin/injectNpmLibMixin.js +26 -0
  123. package/dist/esm/mixins/injectNpmLibMixin/injectNpmLibMixin.js.map +1 -0
  124. package/dist/esm/mixins/loggerMixin/loggerMixin.js +35 -0
  125. package/dist/esm/mixins/loggerMixin/loggerMixin.js.map +1 -0
  126. package/dist/esm/mixins/modalMixin/constants.js +4 -0
  127. package/dist/esm/mixins/modalMixin/constants.js.map +1 -0
  128. package/dist/esm/mixins/modalMixin/helpers.js +12 -0
  129. package/dist/esm/mixins/modalMixin/helpers.js.map +1 -0
  130. package/dist/esm/mixins/modalMixin/modalMixin.js +45 -0
  131. package/dist/esm/mixins/modalMixin/modalMixin.js.map +1 -0
  132. package/dist/esm/mixins/notificationsMixin/constants.js +4 -0
  133. package/dist/esm/mixins/notificationsMixin/constants.js.map +1 -0
  134. package/dist/esm/mixins/notificationsMixin/helpers.js +12 -0
  135. package/dist/esm/mixins/notificationsMixin/helpers.js.map +1 -0
  136. package/dist/esm/mixins/notificationsMixin/notificationsMixin.js +48 -0
  137. package/dist/esm/mixins/notificationsMixin/notificationsMixin.js.map +1 -0
  138. package/dist/esm/mixins/observeAttributesMixin/helpers.js +15 -0
  139. package/dist/esm/mixins/observeAttributesMixin/helpers.js.map +1 -0
  140. package/dist/esm/mixins/observeAttributesMixin/observeAttributesMixin.js +45 -0
  141. package/dist/esm/mixins/observeAttributesMixin/observeAttributesMixin.js.map +1 -0
  142. package/dist/esm/mixins/projectIdMixin.js +15 -0
  143. package/dist/esm/mixins/projectIdMixin.js.map +1 -0
  144. package/dist/esm/mixins/resetMixin.js +45 -0
  145. package/dist/esm/mixins/resetMixin.js.map +1 -0
  146. package/dist/esm/mixins/staticResourcesMixin/constants.js +9 -0
  147. package/dist/esm/mixins/staticResourcesMixin/constants.js.map +1 -0
  148. package/dist/esm/mixins/staticResourcesMixin/fetchWithFallbacks.js +41 -0
  149. package/dist/esm/mixins/staticResourcesMixin/fetchWithFallbacks.js.map +1 -0
  150. package/dist/esm/mixins/staticResourcesMixin/index.js +2 -0
  151. package/dist/esm/mixins/staticResourcesMixin/index.js.map +1 -0
  152. package/dist/esm/mixins/staticResourcesMixin/staticResourcesMixin.js +98 -0
  153. package/dist/esm/mixins/staticResourcesMixin/staticResourcesMixin.js.map +1 -0
  154. package/dist/esm/mixins/themeMixin/constants.js +5 -0
  155. package/dist/esm/mixins/themeMixin/constants.js.map +1 -0
  156. package/dist/esm/mixins/themeMixin/helpers.js +31 -0
  157. package/dist/esm/mixins/themeMixin/helpers.js.map +1 -0
  158. package/dist/esm/mixins/themeMixin/index.js +2 -0
  159. package/dist/esm/mixins/themeMixin/index.js.map +1 -0
  160. package/dist/esm/mixins/themeMixin/themeMixin.js +177 -0
  161. package/dist/esm/mixins/themeMixin/themeMixin.js.map +1 -0
  162. package/dist/index.d.ts +6503 -0
  163. package/dist/types/constants.d.ts +1 -0
  164. package/dist/types/index.d.ts +24 -0
  165. package/dist/types/mixins/baseUrlMixin.d.ts +331 -0
  166. package/dist/types/mixins/configMixin/configMixin.d.ts +363 -0
  167. package/dist/types/mixins/configMixin/constants.d.ts +1 -0
  168. package/dist/types/mixins/configMixin/index.d.ts +2 -0
  169. package/dist/types/mixins/configMixin/types.d.ts +66 -0
  170. package/dist/types/mixins/cookieConfigMixin.d.ts +331 -0
  171. package/dist/types/mixins/createStateManagementMixin.d.ts +341 -0
  172. package/dist/types/mixins/createValidateAttributesMixin/commonValidators.d.ts +1 -0
  173. package/dist/types/mixins/createValidateAttributesMixin/createValidateAttributesMixin.d.ts +346 -0
  174. package/dist/types/mixins/createValidateAttributesMixin/index.d.ts +1 -0
  175. package/dist/types/mixins/debuggerMixin/debugger-wc.d.ts +9 -0
  176. package/dist/types/mixins/debuggerMixin/debuggerMixin.d.ts +347 -0
  177. package/dist/types/mixins/debuggerMixin/helpers.d.ts +4 -0
  178. package/dist/types/mixins/debuggerMixin/index.d.ts +1 -0
  179. package/dist/types/mixins/debuggerMixin/types.d.ts +12 -0
  180. package/dist/types/mixins/descopeUiMixin/constants.d.ts +4 -0
  181. package/dist/types/mixins/descopeUiMixin/descopeUiMixin.d.ts +373 -0
  182. package/dist/types/mixins/descopeUiMixin/helpers.d.ts +2 -0
  183. package/dist/types/mixins/descopeUiMixin/index.d.ts +1 -0
  184. package/dist/types/mixins/formMixin.d.ts +345 -0
  185. package/dist/types/mixins/initElementMixin.d.ts +332 -0
  186. package/dist/types/mixins/initLifecycleMixin.d.ts +332 -0
  187. package/dist/types/mixins/injectNpmLibMixin/constants.d.ts +1 -0
  188. package/dist/types/mixins/injectNpmLibMixin/helpers.d.ts +7 -0
  189. package/dist/types/mixins/injectNpmLibMixin/index.d.ts +1 -0
  190. package/dist/types/mixins/injectNpmLibMixin/injectNpmLibMixin.d.ts +343 -0
  191. package/dist/types/mixins/loggerMixin/index.d.ts +2 -0
  192. package/dist/types/mixins/loggerMixin/loggerMixin.d.ts +339 -0
  193. package/dist/types/mixins/loggerMixin/types.d.ts +6 -0
  194. package/dist/types/mixins/modalMixin/constants.d.ts +1 -0
  195. package/dist/types/mixins/modalMixin/helpers.d.ts +1 -0
  196. package/dist/types/mixins/modalMixin/index.d.ts +1 -0
  197. package/dist/types/mixins/modalMixin/modalMixin.d.ts +406 -0
  198. package/dist/types/mixins/notificationsMixin/constants.d.ts +1 -0
  199. package/dist/types/mixins/notificationsMixin/helpers.d.ts +1 -0
  200. package/dist/types/mixins/notificationsMixin/index.d.ts +1 -0
  201. package/dist/types/mixins/notificationsMixin/notificationsMixin.d.ts +425 -0
  202. package/dist/types/mixins/observeAttributesMixin/helpers.d.ts +1 -0
  203. package/dist/types/mixins/observeAttributesMixin/index.d.ts +1 -0
  204. package/dist/types/mixins/observeAttributesMixin/observeAttributesMixin.d.ts +342 -0
  205. package/dist/types/mixins/projectIdMixin.d.ts +342 -0
  206. package/dist/types/mixins/resetMixin.d.ts +344 -0
  207. package/dist/types/mixins/staticResourcesMixin/constants.d.ts +4 -0
  208. package/dist/types/mixins/staticResourcesMixin/fetchWithFallbacks.d.ts +7 -0
  209. package/dist/types/mixins/staticResourcesMixin/index.d.ts +1 -0
  210. package/dist/types/mixins/staticResourcesMixin/staticResourcesMixin.d.ts +362 -0
  211. package/dist/types/mixins/themeMixin/constants.d.ts +2 -0
  212. package/dist/types/mixins/themeMixin/helpers.d.ts +5 -0
  213. package/dist/types/mixins/themeMixin/index.d.ts +1 -0
  214. package/dist/types/mixins/themeMixin/themeMixin.d.ts +406 -0
  215. package/package.json +10 -10
@@ -0,0 +1,45 @@
1
+ import { __classPrivateFieldGet } from 'tslib';
2
+ import { createSingletonMixin, compose } from '@descope/sdk-helpers';
3
+ import { missingAttrValidator } from './createValidateAttributesMixin/commonValidators.js';
4
+ import { createValidateAttributesMixin } from './createValidateAttributesMixin/createValidateAttributesMixin.js';
5
+
6
+ const resetMixin = createSingletonMixin((superclass) => {
7
+ var _ResetMixinClass_callbacks, _a;
8
+ const BaseClass = compose(createValidateAttributesMixin({ 'project-id': missingAttrValidator }))(superclass);
9
+ return _a = class ResetMixinClass extends BaseClass {
10
+ constructor() {
11
+ super(...arguments);
12
+ _ResetMixinClass_callbacks.set(this, new Map());
13
+ }
14
+ onReset(sectionId, callback) {
15
+ if (!__classPrivateFieldGet(this, _ResetMixinClass_callbacks, "f").has(sectionId)) {
16
+ __classPrivateFieldGet(this, _ResetMixinClass_callbacks, "f").set(sectionId, callback);
17
+ return () => {
18
+ __classPrivateFieldGet(this, _ResetMixinClass_callbacks, "f").delete(sectionId);
19
+ };
20
+ }
21
+ else {
22
+ throw new Error(`Callback for sectionId ${sectionId} already exists`);
23
+ }
24
+ }
25
+ async reset(...sectionIds) {
26
+ if (sectionIds.length === 0) {
27
+ await Promise.all(Array.from(__classPrivateFieldGet(this, _ResetMixinClass_callbacks, "f").values()).map((callback) => callback()));
28
+ }
29
+ else {
30
+ await Promise.all(sectionIds.map((sectionId) => {
31
+ var _b;
32
+ if (!__classPrivateFieldGet(this, _ResetMixinClass_callbacks, "f").has(sectionId)) {
33
+ throw new Error(`Callback for sectionId ${sectionId} does not exist`);
34
+ }
35
+ return (_b = __classPrivateFieldGet(this, _ResetMixinClass_callbacks, "f").get(sectionId)) === null || _b === void 0 ? void 0 : _b();
36
+ }));
37
+ }
38
+ }
39
+ },
40
+ _ResetMixinClass_callbacks = new WeakMap(),
41
+ _a;
42
+ });
43
+
44
+ export { resetMixin };
45
+ //# sourceMappingURL=resetMixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resetMixin.js","sources":["../../../src/mixins/resetMixin.ts"],"sourcesContent":["import { createSingletonMixin, compose } from '@descope/sdk-helpers';\nimport { missingAttrValidator } from './createValidateAttributesMixin/commonValidators';\nimport { createValidateAttributesMixin } from './createValidateAttributesMixin';\n\nexport const resetMixin = createSingletonMixin(\n <T extends CustomElementConstructor>(superclass: T) => {\n const BaseClass = compose(\n createValidateAttributesMixin({ 'project-id': missingAttrValidator }),\n )(superclass);\n\n return class ResetMixinClass extends BaseClass {\n #callbacks = new Map<string, () => void>();\n\n onReset(sectionId: string, callback: () => void | Promise<void>) {\n if (!this.#callbacks.has(sectionId)) {\n this.#callbacks.set(sectionId, callback);\n return () => {\n this.#callbacks.delete(sectionId);\n };\n } else {\n throw new Error(`Callback for sectionId ${sectionId} already exists`);\n }\n }\n\n async reset(...sectionIds: string[]) {\n if (sectionIds.length === 0) {\n await Promise.all(\n Array.from(this.#callbacks.values()).map((callback) => callback()),\n );\n } else {\n await Promise.all(\n sectionIds.map((sectionId) => {\n if (!this.#callbacks.has(sectionId)) {\n throw new Error(\n `Callback for sectionId ${sectionId} does not exist`,\n );\n }\n return this.#callbacks.get(sectionId)?.();\n }),\n );\n }\n }\n };\n },\n);\n"],"names":[],"mappings":";;;;;MAIa,UAAU,GAAG,oBAAoB,CAC5C,CAAqC,UAAa,KAAI;;AACpD,IAAA,MAAM,SAAS,GAAG,OAAO,CACvB,6BAA6B,CAAC,EAAE,YAAY,EAAE,oBAAoB,EAAE,CAAC,CACtE,CAAC,UAAU,CAAC,CAAC;IAEd,OAAO,EAAA,GAAA,MAAM,eAAgB,SAAQ,SAAS,CAAA;AAAvC,YAAA,WAAA,GAAA;;gBACL,0BAAa,CAAA,GAAA,CAAA,IAAA,EAAA,IAAI,GAAG,EAAsB,CAAC,CAAA;aA+B5C;YA7BC,OAAO,CAAC,SAAiB,EAAE,QAAoC,EAAA;gBAC7D,IAAI,CAAC,sBAAA,CAAA,IAAI,EAAW,0BAAA,EAAA,GAAA,CAAA,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE;oBACnC,sBAAA,CAAA,IAAI,kCAAW,CAAC,GAAG,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;AACzC,oBAAA,OAAO,MAAK;AACV,wBAAA,sBAAA,CAAA,IAAI,EAAW,0BAAA,EAAA,GAAA,CAAA,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;AACpC,qBAAC,CAAC;iBACH;qBAAM;AACL,oBAAA,MAAM,IAAI,KAAK,CAAC,0BAA0B,SAAS,CAAA,eAAA,CAAiB,CAAC,CAAC;iBACvE;aACF;AAED,YAAA,MAAM,KAAK,CAAC,GAAG,UAAoB,EAAA;AACjC,gBAAA,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE;oBAC3B,MAAM,OAAO,CAAC,GAAG,CACf,KAAK,CAAC,IAAI,CAAC,sBAAA,CAAA,IAAI,EAAA,0BAAA,EAAA,GAAA,CAAW,CAAC,MAAM,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,QAAQ,KAAK,QAAQ,EAAE,CAAC,CACnE,CAAC;iBACH;qBAAM;oBACL,MAAM,OAAO,CAAC,GAAG,CACf,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,KAAI;;wBAC3B,IAAI,CAAC,sBAAA,CAAA,IAAI,EAAW,0BAAA,EAAA,GAAA,CAAA,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE;AACnC,4BAAA,MAAM,IAAI,KAAK,CACb,0BAA0B,SAAS,CAAA,eAAA,CAAiB,CACrD,CAAC;yBACH;wBACD,OAAO,CAAA,EAAA,GAAA,sBAAA,CAAA,IAAI,EAAW,0BAAA,EAAA,GAAA,CAAA,CAAC,GAAG,CAAC,SAAS,CAAC,MAAA,IAAA,IAAA,EAAA,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,EAAA,EAAI,CAAC;qBAC3C,CAAC,CACH,CAAC;iBACH;aACF;AACF,SAAA;;AAAC,QAAA,EAAA,CAAA;AACJ,CAAC;;;;"}
@@ -0,0 +1,9 @@
1
+ import { IS_LOCAL_STORAGE } from '../../constants.js';
2
+
3
+ const BASE_CONTENT_URL_KEY = 'base.content.url';
4
+ const BASE_CONTENT_URL = 'https://static.descope.com/pages';
5
+ const OVERRIDE_CONTENT_URL = (IS_LOCAL_STORAGE && localStorage.getItem(BASE_CONTENT_URL_KEY)) || '';
6
+ const ASSETS_FOLDER = 'v2-beta';
7
+
8
+ export { ASSETS_FOLDER, BASE_CONTENT_URL, OVERRIDE_CONTENT_URL };
9
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sources":["../../../../src/mixins/staticResourcesMixin/constants.ts"],"sourcesContent":["import { IS_LOCAL_STORAGE } from '../../constants';\n\nconst BASE_CONTENT_URL_KEY = 'base.content.url';\n\nexport const BASE_CONTENT_URL = 'https://static.descope.com/pages';\n\nexport const OVERRIDE_CONTENT_URL =\n (IS_LOCAL_STORAGE && localStorage.getItem(BASE_CONTENT_URL_KEY)) || '';\n\nexport const ASSETS_FOLDER = 'v2-beta';\nexport const PREV_VER_ASSETS_FOLDER = 'v2-alpha';\n"],"names":[],"mappings":";;AAEA,MAAM,oBAAoB,GAAG,kBAAkB,CAAC;AAEzC,MAAM,gBAAgB,GAAG,mCAAmC;AAEtD,MAAA,oBAAoB,GAC/B,CAAC,gBAAgB,IAAI,YAAY,CAAC,OAAO,CAAC,oBAAoB,CAAC,KAAK,GAAG;AAElE,MAAM,aAAa,GAAG;;;;"}
@@ -0,0 +1,41 @@
1
+ const notLastMsgSuffix = 'Trying the next fallback URL...';
2
+ // reties in case on network error
3
+ const fetchWithRetry = async (url, init, { logger } = {}) => {
4
+ try {
5
+ return await fetch(url, init);
6
+ }
7
+ catch (e) {
8
+ // if there is an exception, we want to retry
9
+ // so we can overcome network errors
10
+ logger === null || logger === void 0 ? void 0 : logger.debug(`Network error fetching URL ${url} [${e.message}], retrying...`);
11
+ return fetch(url, init);
12
+ }
13
+ };
14
+ const fetchWithFallbacks = async (fallbacks, init, { logger, onSuccess, } = {}) => {
15
+ const fallbacksArr = Array.isArray(fallbacks) ? fallbacks : [fallbacks];
16
+ for (let index = 0; index < fallbacksArr.length; index++) {
17
+ const url = fallbacksArr[index];
18
+ const isLast = index === fallbacksArr.length - 1;
19
+ try {
20
+ const res = await fetchWithRetry(url.toString(), init, { logger });
21
+ if (res.ok) {
22
+ onSuccess === null || onSuccess === void 0 ? void 0 : onSuccess(index);
23
+ logger === null || logger === void 0 ? void 0 : logger.debug(`Successfully fetched URL ${url}`);
24
+ return res;
25
+ }
26
+ const errMsg = `Error fetching URL ${url} [${res.status}]`;
27
+ if (isLast)
28
+ throw new Error(errMsg);
29
+ logger === null || logger === void 0 ? void 0 : logger.debug(`${errMsg}. ${notLastMsgSuffix}`);
30
+ }
31
+ catch (e) {
32
+ const errMsg = `Error fetching URL ${url} [${e.message}]`;
33
+ if (isLast)
34
+ throw new Error(errMsg);
35
+ logger === null || logger === void 0 ? void 0 : logger.debug(`${errMsg}. ${notLastMsgSuffix}`);
36
+ }
37
+ }
38
+ };
39
+
40
+ export { fetchWithFallbacks };
41
+ //# sourceMappingURL=fetchWithFallbacks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fetchWithFallbacks.js","sources":["../../../../src/mixins/staticResourcesMixin/fetchWithFallbacks.ts"],"sourcesContent":["import { Logger } from '../loggerMixin';\n\ntype FetchParams = Parameters<typeof fetch>;\nconst notLastMsgSuffix = 'Trying the next fallback URL...';\n\n// reties in case on network error\nconst fetchWithRetry = async (\n url: string,\n init: FetchParams['1'],\n { logger }: { logger?: Logger } = {},\n) => {\n try {\n return await fetch(url, init);\n } catch (e) {\n // if there is an exception, we want to retry\n // so we can overcome network errors\n logger?.debug(\n `Network error fetching URL ${url} [${e.message}], retrying...`,\n );\n return fetch(url, init);\n }\n};\n\nexport const fetchWithFallbacks = async (\n fallbacks: FetchParams['0'] | FetchParams['0'][],\n init: FetchParams['1'],\n {\n logger,\n onSuccess,\n }: { logger?: Logger; onSuccess?: (urlIndex: number) => void } = {},\n): ReturnType<typeof fetch> => {\n const fallbacksArr = Array.isArray(fallbacks) ? fallbacks : [fallbacks];\n\n for (let index = 0; index < fallbacksArr.length; index++) {\n const url = fallbacksArr[index];\n const isLast = index === fallbacksArr.length - 1;\n\n try {\n const res = await fetchWithRetry(url.toString(), init, { logger });\n if (res.ok) {\n onSuccess?.(index);\n logger?.debug(`Successfully fetched URL ${url}`);\n return res;\n }\n\n const errMsg = `Error fetching URL ${url} [${res.status}]`;\n\n if (isLast) throw new Error(errMsg);\n\n logger?.debug(`${errMsg}. ${notLastMsgSuffix}`);\n } catch (e) {\n const errMsg = `Error fetching URL ${url} [${e.message}]`;\n\n if (isLast) throw new Error(errMsg);\n\n logger?.debug(`${errMsg}. ${notLastMsgSuffix}`);\n }\n }\n};\n"],"names":[],"mappings":"AAGA,MAAM,gBAAgB,GAAG,iCAAiC,CAAC;AAE3D;AACA,MAAM,cAAc,GAAG,OACrB,GAAW,EACX,IAAsB,EACtB,EAAE,MAAM,EAA0B,GAAA,EAAE,KAClC;AACF,IAAA,IAAI;AACF,QAAA,OAAO,MAAM,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;KAC/B;IAAC,OAAO,CAAC,EAAE;;;AAGV,QAAA,MAAM,KAAN,IAAA,IAAA,MAAM,KAAN,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,MAAM,CAAE,KAAK,CACX,CAA8B,2BAAA,EAAA,GAAG,KAAK,CAAC,CAAC,OAAO,CAAA,cAAA,CAAgB,CAChE,CAAC;AACF,QAAA,OAAO,KAAK,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;KACzB;AACH,CAAC,CAAC;AAEW,MAAA,kBAAkB,GAAG,OAChC,SAAgD,EAChD,IAAsB,EACtB,EACE,MAAM,EACN,SAAS,GACsD,GAAA,EAAE,KACvC;AAC5B,IAAA,MAAM,YAAY,GAAG,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,SAAS,GAAG,CAAC,SAAS,CAAC,CAAC;AAExE,IAAA,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,YAAY,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;AACxD,QAAA,MAAM,GAAG,GAAG,YAAY,CAAC,KAAK,CAAC,CAAC;QAChC,MAAM,MAAM,GAAG,KAAK,KAAK,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;AAEjD,QAAA,IAAI;AACF,YAAA,MAAM,GAAG,GAAG,MAAM,cAAc,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;AACnE,YAAA,IAAI,GAAG,CAAC,EAAE,EAAE;AACV,gBAAA,SAAS,aAAT,SAAS,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAT,SAAS,CAAG,KAAK,CAAC,CAAC;gBACnB,MAAM,KAAA,IAAA,IAAN,MAAM,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAN,MAAM,CAAE,KAAK,CAAC,CAA4B,yBAAA,EAAA,GAAG,CAAE,CAAA,CAAC,CAAC;AACjD,gBAAA,OAAO,GAAG,CAAC;aACZ;YAED,MAAM,MAAM,GAAG,CAAsB,mBAAA,EAAA,GAAG,KAAK,GAAG,CAAC,MAAM,CAAA,CAAA,CAAG,CAAC;AAE3D,YAAA,IAAI,MAAM;AAAE,gBAAA,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC;AAEpC,YAAA,MAAM,KAAN,IAAA,IAAA,MAAM,KAAN,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,MAAM,CAAE,KAAK,CAAC,CAAA,EAAG,MAAM,CAAA,EAAA,EAAK,gBAAgB,CAAA,CAAE,CAAC,CAAC;SACjD;QAAC,OAAO,CAAC,EAAE;YACV,MAAM,MAAM,GAAG,CAAsB,mBAAA,EAAA,GAAG,KAAK,CAAC,CAAC,OAAO,CAAA,CAAA,CAAG,CAAC;AAE1D,YAAA,IAAI,MAAM;AAAE,gBAAA,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,CAAC;AAEpC,YAAA,MAAM,KAAN,IAAA,IAAA,MAAM,KAAN,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,MAAM,CAAE,KAAK,CAAC,CAAA,EAAG,MAAM,CAAA,EAAA,EAAK,gBAAgB,CAAA,CAAE,CAAC,CAAC;SACjD;KACF;AACH;;;;"}
@@ -0,0 +1,2 @@
1
+ export { getResourceUrl, staticResourcesMixin } from './staticResourcesMixin.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,98 @@
1
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from 'tslib';
2
+ import { createSingletonMixin, compose, pathJoin } from '@descope/sdk-helpers';
3
+ import { loggerMixin } from '../loggerMixin/loggerMixin.js';
4
+ import { ASSETS_FOLDER, BASE_CONTENT_URL, OVERRIDE_CONTENT_URL } from './constants.js';
5
+ import { projectIdMixin } from '../projectIdMixin.js';
6
+ import { baseUrlMixin } from '../baseUrlMixin.js';
7
+ import { fetchWithFallbacks } from './fetchWithFallbacks.js';
8
+
9
+ function getResourceUrl({ projectId, filename, assetsFolder = ASSETS_FOLDER, baseUrl = BASE_CONTENT_URL, }) {
10
+ const url = new URL(baseUrl);
11
+ url.pathname = pathJoin(url.pathname, projectId, assetsFolder, filename);
12
+ // we want to keep the baseUrl so we can use it later
13
+ url.baseUrl = baseUrl;
14
+ return url;
15
+ }
16
+ const staticResourcesMixin = createSingletonMixin((superclass) => {
17
+ var _StaticResourcesMixinClass_instances, _StaticResourcesMixinClass_lastBaseUrl, _StaticResourcesMixinClass_workingBaseUrl, _StaticResourcesMixinClass_getResourceUrls, _a;
18
+ const BaseClass = compose(loggerMixin, projectIdMixin, baseUrlMixin)(superclass);
19
+ // the logic should be as following:
20
+ // if there is a local storage override, use it
21
+ // otherwise, if there is a base-static-url attribute, use it
22
+ // otherwise, try to use base-url, and check if it's working
23
+ // if it's working, use it
24
+ // if not, use the default content url
25
+ return _a = class StaticResourcesMixinClass extends BaseClass {
26
+ constructor() {
27
+ super(...arguments);
28
+ _StaticResourcesMixinClass_instances.add(this);
29
+ _StaticResourcesMixinClass_lastBaseUrl.set(this, void 0);
30
+ _StaticResourcesMixinClass_workingBaseUrl.set(this, void 0);
31
+ }
32
+ async fetchStaticResource(filename, format) {
33
+ const resourceUrls = __classPrivateFieldGet(this, _StaticResourcesMixinClass_instances, "m", _StaticResourcesMixinClass_getResourceUrls).call(this, filename);
34
+ // if there are multiple resource urls, it means that there are fallbacks,
35
+ // if one of the options (which is not the last) is working, we want to keep using it by updating the workingBaseUrl
36
+ const onSuccess = !Array.isArray(resourceUrls)
37
+ ? null
38
+ : (index) => {
39
+ if (index !== resourceUrls.length - 1) {
40
+ const { baseUrl } = resourceUrls[index];
41
+ __classPrivateFieldSet(this, _StaticResourcesMixinClass_workingBaseUrl, baseUrl, "f");
42
+ }
43
+ };
44
+ try {
45
+ const res = await fetchWithFallbacks(resourceUrls, { cache: 'default' }, { logger: this.logger, onSuccess });
46
+ return {
47
+ body: await res[format](),
48
+ headers: Object.fromEntries(res.headers.entries()),
49
+ };
50
+ }
51
+ catch (e) {
52
+ this.logger.error(e.message);
53
+ }
54
+ }
55
+ get baseStaticUrl() {
56
+ return this.getAttribute('base-static-url');
57
+ }
58
+ },
59
+ _StaticResourcesMixinClass_lastBaseUrl = new WeakMap(),
60
+ _StaticResourcesMixinClass_workingBaseUrl = new WeakMap(),
61
+ _StaticResourcesMixinClass_instances = new WeakSet(),
62
+ _StaticResourcesMixinClass_getResourceUrls = function _StaticResourcesMixinClass_getResourceUrls(filename) {
63
+ const overrideUrl = OVERRIDE_CONTENT_URL || this.baseStaticUrl;
64
+ if (overrideUrl) {
65
+ return getResourceUrl({
66
+ projectId: this.projectId,
67
+ filename,
68
+ baseUrl: overrideUrl,
69
+ });
70
+ }
71
+ const isBaseUrlUpdated = __classPrivateFieldGet(this, _StaticResourcesMixinClass_lastBaseUrl, "f") !== this.baseUrl;
72
+ const shouldFallbackFetch = isBaseUrlUpdated && !!this.baseUrl;
73
+ // if the base url has changed, reset the working base url
74
+ if (isBaseUrlUpdated) {
75
+ __classPrivateFieldSet(this, _StaticResourcesMixinClass_lastBaseUrl, this.baseUrl, "f");
76
+ __classPrivateFieldSet(this, _StaticResourcesMixinClass_workingBaseUrl, undefined, "f");
77
+ }
78
+ const resourceUrl = getResourceUrl({
79
+ projectId: this.projectId,
80
+ filename,
81
+ baseUrl: __classPrivateFieldGet(this, _StaticResourcesMixinClass_workingBaseUrl, "f"),
82
+ });
83
+ // if there is no reason to check the baseUrl, generate the resource url according to the priority
84
+ if (!shouldFallbackFetch) {
85
+ return resourceUrl;
86
+ }
87
+ const resourceUrlFromBaseUrl = getResourceUrl({
88
+ projectId: this.projectId,
89
+ filename,
90
+ baseUrl: this.baseUrl + '/pages',
91
+ });
92
+ return [resourceUrlFromBaseUrl, resourceUrl];
93
+ },
94
+ _a;
95
+ });
96
+
97
+ export { getResourceUrl, staticResourcesMixin };
98
+ //# sourceMappingURL=staticResourcesMixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"staticResourcesMixin.js","sources":["../../../../src/mixins/staticResourcesMixin/staticResourcesMixin.ts"],"sourcesContent":["import { pathJoin, compose, createSingletonMixin } from '@descope/sdk-helpers';\nimport { loggerMixin } from '../loggerMixin';\nimport {\n ASSETS_FOLDER,\n BASE_CONTENT_URL,\n OVERRIDE_CONTENT_URL,\n} from './constants';\nimport { projectIdMixin } from '../projectIdMixin';\nimport { baseUrlMixin } from '../baseUrlMixin';\nimport { fetchWithFallbacks } from './fetchWithFallbacks';\n\ntype Format = 'text' | 'json';\n\ntype CustomUrl = URL & { baseUrl: string };\n\nexport function getResourceUrl({\n projectId,\n filename,\n assetsFolder = ASSETS_FOLDER,\n baseUrl = BASE_CONTENT_URL,\n}: {\n projectId: string;\n filename: string;\n assetsFolder?: string;\n baseUrl?: string;\n}) {\n const url: CustomUrl = new URL(baseUrl) as any;\n url.pathname = pathJoin(url.pathname, projectId, assetsFolder, filename);\n // we want to keep the baseUrl so we can use it later\n url.baseUrl = baseUrl;\n\n return url;\n}\n\nexport const staticResourcesMixin = createSingletonMixin(\n <T extends CustomElementConstructor>(superclass: T) => {\n const BaseClass = compose(\n loggerMixin,\n projectIdMixin,\n baseUrlMixin,\n )(superclass);\n\n // the logic should be as following:\n // if there is a local storage override, use it\n // otherwise, if there is a base-static-url attribute, use it\n // otherwise, try to use base-url, and check if it's working\n // if it's working, use it\n // if not, use the default content url\n return class StaticResourcesMixinClass extends BaseClass {\n #lastBaseUrl?: string;\n #workingBaseUrl?: string;\n\n #getResourceUrls(filename: string): CustomUrl[] | CustomUrl {\n const overrideUrl = OVERRIDE_CONTENT_URL || this.baseStaticUrl;\n\n if (overrideUrl) {\n return getResourceUrl({\n projectId: this.projectId,\n filename,\n baseUrl: overrideUrl,\n });\n }\n\n const isBaseUrlUpdated = this.#lastBaseUrl !== this.baseUrl;\n const shouldFallbackFetch = isBaseUrlUpdated && !!this.baseUrl;\n\n // if the base url has changed, reset the working base url\n if (isBaseUrlUpdated) {\n this.#lastBaseUrl = this.baseUrl;\n this.#workingBaseUrl = undefined;\n }\n\n const resourceUrl = getResourceUrl({\n projectId: this.projectId,\n filename,\n baseUrl: this.#workingBaseUrl,\n });\n\n // if there is no reason to check the baseUrl, generate the resource url according to the priority\n if (!shouldFallbackFetch) {\n return resourceUrl;\n }\n\n const resourceUrlFromBaseUrl = getResourceUrl({\n projectId: this.projectId,\n filename,\n baseUrl: this.baseUrl + '/pages',\n });\n\n return [resourceUrlFromBaseUrl, resourceUrl];\n }\n\n async fetchStaticResource<F extends Format>(\n filename: string,\n format: F,\n ): Promise<{\n body: F extends 'json' ? Record<string, any> : string;\n headers: Record<string, string>;\n }> {\n const resourceUrls = this.#getResourceUrls(filename);\n\n // if there are multiple resource urls, it means that there are fallbacks,\n // if one of the options (which is not the last) is working, we want to keep using it by updating the workingBaseUrl\n const onSuccess = !Array.isArray(resourceUrls)\n ? null\n : (index: number) => {\n if (index !== resourceUrls.length - 1) {\n const { baseUrl } = resourceUrls[index];\n this.#workingBaseUrl = baseUrl;\n }\n };\n\n try {\n const res = await fetchWithFallbacks(\n resourceUrls,\n { cache: 'default' },\n { logger: this.logger, onSuccess },\n );\n\n return {\n body: await res[format](),\n headers: Object.fromEntries(res.headers.entries()),\n };\n } catch (e) {\n this.logger.error(e.message);\n }\n }\n\n get baseStaticUrl() {\n return this.getAttribute('base-static-url');\n }\n };\n },\n);\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ // Those files are saved on a new folder to prevent breaking changes
2
+ const DEFAULT_STYLE_ID = 'theme';
3
+
4
+ export { DEFAULT_STYLE_ID };
5
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sources":["../../../../src/mixins/themeMixin/constants.ts"],"sourcesContent":["// Those files are saved on a new folder to prevent breaking changes\nexport const DEFAULT_STYLE_ID = 'theme';\nexport const CONFIG_FILENAME = 'config.json';\n"],"names":[],"mappings":"AAAA;AACO,MAAM,gBAAgB,GAAG;;;;"}
@@ -0,0 +1,31 @@
1
+ import { UI_COMPONENTS_URL_KEY } from '../descopeUiMixin/constants.js';
2
+
3
+ const loadFont = (url) => {
4
+ const font = document.createElement('link');
5
+ font.href = url;
6
+ font.rel = 'stylesheet';
7
+ document.head.appendChild(font);
8
+ };
9
+ const loadDevTheme = async () => {
10
+ const componentsUrl = localStorage.getItem(UI_COMPONENTS_URL_KEY);
11
+ const descopeDevUrl = componentsUrl === null || componentsUrl === void 0 ? void 0 : componentsUrl.replace(/[^\/]+$/, 'DescopeDev.js');
12
+ // eslint-disable-next-line no-console
13
+ console.warn('Trying to load DescopeDev.js from', descopeDevUrl);
14
+ const scriptEle = document.createElement('script');
15
+ scriptEle.src = descopeDevUrl;
16
+ document.body.appendChild(scriptEle);
17
+ await new Promise((resolve, reject) => {
18
+ scriptEle.onload = resolve;
19
+ scriptEle.onerror = reject;
20
+ });
21
+ if (globalThis.DescopeDev) {
22
+ const { themeToStyle, defaultTheme, darkTheme } = globalThis.DescopeDev;
23
+ return {
24
+ light: themeToStyle(defaultTheme),
25
+ dark: themeToStyle(darkTheme),
26
+ };
27
+ }
28
+ };
29
+
30
+ export { loadDevTheme, loadFont };
31
+ //# sourceMappingURL=helpers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"helpers.js","sources":["../../../../src/mixins/themeMixin/helpers.ts"],"sourcesContent":["import { UI_COMPONENTS_URL_KEY } from '../descopeUiMixin/constants';\n\nexport const loadFont = (url: string) => {\n const font = document.createElement('link');\n font.href = url;\n font.rel = 'stylesheet';\n document.head.appendChild(font);\n};\n\nexport const loadDevTheme = async () => {\n const componentsUrl = localStorage.getItem(UI_COMPONENTS_URL_KEY);\n const descopeDevUrl = componentsUrl?.replace(/[^\\/]+$/, 'DescopeDev.js');\n\n // eslint-disable-next-line no-console\n console.warn('Trying to load DescopeDev.js from', descopeDevUrl);\n const scriptEle = document.createElement('script');\n scriptEle.src = descopeDevUrl;\n document.body.appendChild(scriptEle);\n\n await new Promise((resolve, reject) => {\n scriptEle.onload = resolve;\n scriptEle.onerror = reject;\n });\n\n if (globalThis.DescopeDev) {\n const { themeToStyle, defaultTheme, darkTheme } = globalThis.DescopeDev;\n\n return {\n light: themeToStyle(defaultTheme),\n dark: themeToStyle(darkTheme),\n };\n }\n};\n"],"names":[],"mappings":";;AAEa,MAAA,QAAQ,GAAG,CAAC,GAAW,KAAI;IACtC,MAAM,IAAI,GAAG,QAAQ,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;AAC5C,IAAA,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC;AAChB,IAAA,IAAI,CAAC,GAAG,GAAG,YAAY,CAAC;AACxB,IAAA,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;AAClC,EAAE;AAEW,MAAA,YAAY,GAAG,YAAW;IACrC,MAAM,aAAa,GAAG,YAAY,CAAC,OAAO,CAAC,qBAAqB,CAAC,CAAC;AAClE,IAAA,MAAM,aAAa,GAAG,aAAa,KAAA,IAAA,IAAb,aAAa,KAAb,KAAA,CAAA,GAAA,KAAA,CAAA,GAAA,aAAa,CAAE,OAAO,CAAC,SAAS,EAAE,eAAe,CAAC,CAAC;;AAGzE,IAAA,OAAO,CAAC,IAAI,CAAC,mCAAmC,EAAE,aAAa,CAAC,CAAC;IACjE,MAAM,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;AACnD,IAAA,SAAS,CAAC,GAAG,GAAG,aAAa,CAAC;AAC9B,IAAA,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;IAErC,MAAM,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,KAAI;AACpC,QAAA,SAAS,CAAC,MAAM,GAAG,OAAO,CAAC;AAC3B,QAAA,SAAS,CAAC,OAAO,GAAG,MAAM,CAAC;AAC7B,KAAC,CAAC,CAAC;AAEH,IAAA,IAAI,UAAU,CAAC,UAAU,EAAE;QACzB,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,SAAS,EAAE,GAAG,UAAU,CAAC,UAAU,CAAC;QAExE,OAAO;AACL,YAAA,KAAK,EAAE,YAAY,CAAC,YAAY,CAAC;AACjC,YAAA,IAAI,EAAE,YAAY,CAAC,SAAS,CAAC;SAC9B,CAAC;KACH;AACH;;;;"}
@@ -0,0 +1,2 @@
1
+ export { themeMixin } from './themeMixin.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":""}
@@ -0,0 +1,177 @@
1
+ import { __classPrivateFieldGet, __classPrivateFieldSet } from 'tslib';
2
+ import { createSingletonMixin, compose } from '@descope/sdk-helpers';
3
+ import { configMixin } from '../configMixin/configMixin.js';
4
+ import { createValidateAttributesMixin } from '../createValidateAttributesMixin/createValidateAttributesMixin.js';
5
+ import { descopeUiMixin } from '../descopeUiMixin/descopeUiMixin.js';
6
+ import { initElementMixin } from '../initElementMixin.js';
7
+ import { initLifecycleMixin } from '../initLifecycleMixin.js';
8
+ import { staticResourcesMixin } from '../staticResourcesMixin/staticResourcesMixin.js';
9
+ import { DEFAULT_STYLE_ID } from './constants.js';
10
+ import { loadFont, loadDevTheme } from './helpers.js';
11
+ import { observeAttributesMixin } from '../observeAttributesMixin/observeAttributesMixin.js';
12
+ import { UI_COMPONENTS_URL_KEY } from '../descopeUiMixin/constants.js';
13
+
14
+ const themeValidation = (_, theme) => (theme || false) &&
15
+ theme !== 'light' &&
16
+ theme !== 'dark' &&
17
+ 'Supported theme values are "light", "dark", or leave empty for using the OS theme';
18
+ const themeMixin = createSingletonMixin((superclass) => {
19
+ var _ThemeMixinClass_instances, _ThemeMixinClass_globalStyle, _ThemeMixinClass__themeResource, _ThemeMixinClass_fetchTheme, _ThemeMixinClass_themeResource_get, _ThemeMixinClass_loadGlobalStyle, _ThemeMixinClass_loadComponentsStyle, _ThemeMixinClass_getFontsConfig, _ThemeMixinClass_loadFonts, _ThemeMixinClass_applyTheme, _ThemeMixinClass_onThemeChange, _ThemeMixinClass_loadTheme, _ThemeMixinClass_toggleOsThemeChangeListener, _a;
20
+ const BaseClass = compose(createValidateAttributesMixin({ theme: themeValidation }), staticResourcesMixin, initLifecycleMixin, descopeUiMixin, configMixin, initElementMixin, observeAttributesMixin)(superclass);
21
+ return _a = class ThemeMixinClass extends BaseClass {
22
+ constructor() {
23
+ super(...arguments);
24
+ _ThemeMixinClass_instances.add(this);
25
+ _ThemeMixinClass_globalStyle.set(this, void 0);
26
+ _ThemeMixinClass__themeResource.set(this, void 0);
27
+ _ThemeMixinClass_onThemeChange.set(this, () => {
28
+ __classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadTheme).call(this);
29
+ __classPrivateFieldGet(this, _ThemeMixinClass_toggleOsThemeChangeListener, "f").call(this, this.getAttribute('theme') === 'os');
30
+ });
31
+ // add or remove os theme change listener
32
+ _ThemeMixinClass_toggleOsThemeChangeListener.set(this, (listen) => {
33
+ var _b, _c, _d;
34
+ const method = listen ? 'addEventListener' : 'removeEventListener';
35
+ (_d = (_c = (_b = window
36
+ .matchMedia) === null || _b === void 0 ? void 0 : _b.call(window, '(prefers-color-scheme: dark)')) === null || _c === void 0 ? void 0 : _c[method]) === null || _d === void 0 ? void 0 : _d.call(_c, 'change', () => __classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadTheme).call(this));
37
+ });
38
+ }
39
+ get theme() {
40
+ var _b, _c;
41
+ const theme = this.getAttribute('theme');
42
+ if (theme === 'os') {
43
+ const isOsDark = window.matchMedia &&
44
+ ((_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);
45
+ return isOsDark ? 'dark' : 'light';
46
+ }
47
+ return theme || 'light';
48
+ }
49
+ get styleId() {
50
+ return this.getAttribute('style-id') || DEFAULT_STYLE_ID;
51
+ }
52
+ async init() {
53
+ var _b;
54
+ await ((_b = super.init) === null || _b === void 0 ? void 0 : _b.call(this));
55
+ __classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadGlobalStyle).call(this);
56
+ __classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadComponentsStyle).call(this);
57
+ __classPrivateFieldGet(this, _ThemeMixinClass_onThemeChange, "f").call(this);
58
+ this.observeAttributes(['theme'], __classPrivateFieldGet(this, _ThemeMixinClass_onThemeChange, "f"));
59
+ this.observeAttributes(['style-id'], () => {
60
+ __classPrivateFieldSet(this, _ThemeMixinClass__themeResource, null, "f");
61
+ __classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadFonts).call(this);
62
+ __classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadGlobalStyle).call(this);
63
+ __classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadComponentsStyle).call(this);
64
+ });
65
+ }
66
+ },
67
+ _ThemeMixinClass_globalStyle = new WeakMap(),
68
+ _ThemeMixinClass__themeResource = new WeakMap(),
69
+ _ThemeMixinClass_onThemeChange = new WeakMap(),
70
+ _ThemeMixinClass_toggleOsThemeChangeListener = new WeakMap(),
71
+ _ThemeMixinClass_instances = new WeakSet(),
72
+ _ThemeMixinClass_fetchTheme = async function _ThemeMixinClass_fetchTheme() {
73
+ try {
74
+ const { body: fetchedTheme } = await this.fetchStaticResource(`${this.styleId}.json`, 'json');
75
+ // In development mode, we sometimes want to override the UI components URL
76
+ // 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
77
+ if (process.env.NODE_ENV === 'development') {
78
+ if (localStorage === null || localStorage === void 0 ? void 0 : localStorage.getItem(UI_COMPONENTS_URL_KEY)) {
79
+ try {
80
+ 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');
81
+ const devTheme = await loadDevTheme();
82
+ if (devTheme) {
83
+ fetchedTheme.light.components = Object.assign(Object.assign({}, fetchedTheme.light.components), devTheme.light.components);
84
+ fetchedTheme.dark.components = Object.assign(Object.assign({}, fetchedTheme.dark.components), devTheme.dark.components);
85
+ this.logger.warn('Theme was merged successfully');
86
+ // eslint-disable-next-line no-console
87
+ 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');
88
+ }
89
+ }
90
+ catch (e) {
91
+ this.logger.error('Failed to merge UI components theme\n', e);
92
+ }
93
+ }
94
+ }
95
+ return fetchedTheme;
96
+ }
97
+ catch (e) {
98
+ this.logger.error('Cannot fetch theme file', 'make sure that your projectId & flowId are correct');
99
+ }
100
+ return undefined;
101
+ },
102
+ _ThemeMixinClass_themeResource_get = function _ThemeMixinClass_themeResource_get() {
103
+ if (!__classPrivateFieldGet(this, _ThemeMixinClass__themeResource, "f")) {
104
+ __classPrivateFieldSet(this, _ThemeMixinClass__themeResource, __classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_fetchTheme).call(this), "f");
105
+ __classPrivateFieldGet(this, _ThemeMixinClass__themeResource, "f").then((theme) => this.logger.debug('Fetched theme', theme));
106
+ }
107
+ // eslint-disable-next-line no-underscore-dangle
108
+ return __classPrivateFieldGet(this, _ThemeMixinClass__themeResource, "f");
109
+ },
110
+ _ThemeMixinClass_loadGlobalStyle = async function _ThemeMixinClass_loadGlobalStyle() {
111
+ var _b, _c, _d;
112
+ var _e;
113
+ const theme = await __classPrivateFieldGet(this, _ThemeMixinClass_instances, "a", _ThemeMixinClass_themeResource_get);
114
+ if (!theme)
115
+ return;
116
+ if (!__classPrivateFieldGet(this, _ThemeMixinClass_globalStyle, "f")) {
117
+ __classPrivateFieldSet(this, _ThemeMixinClass_globalStyle, new CSSStyleSheet(), "f");
118
+ (_b = (_e = this.shadowRoot).adoptedStyleSheets) !== null && _b !== void 0 ? _b : (_e.adoptedStyleSheets = []);
119
+ this.shadowRoot.adoptedStyleSheets = [
120
+ ...this.shadowRoot.adoptedStyleSheets,
121
+ __classPrivateFieldGet(this, _ThemeMixinClass_globalStyle, "f"),
122
+ ];
123
+ }
124
+ __classPrivateFieldGet(this, _ThemeMixinClass_globalStyle, "f").replaceSync((((_c = theme === null || theme === void 0 ? void 0 : theme.light) === null || _c === void 0 ? void 0 : _c.globals) || '') + (((_d = theme === null || theme === void 0 ? void 0 : theme.dark) === null || _d === void 0 ? void 0 : _d.globals) || ''));
125
+ },
126
+ _ThemeMixinClass_loadComponentsStyle = async function _ThemeMixinClass_loadComponentsStyle() {
127
+ var _b, _c;
128
+ const theme = Object.assign({}, (await __classPrivateFieldGet(this, _ThemeMixinClass_instances, "a", _ThemeMixinClass_themeResource_get)));
129
+ if (!theme)
130
+ return;
131
+ const descopeUi = await this.descopeUi;
132
+ if (descopeUi === null || descopeUi === void 0 ? void 0 : descopeUi.componentsThemeManager) {
133
+ descopeUi.componentsThemeManager.themes = {
134
+ light: (_b = theme === null || theme === void 0 ? void 0 : theme.light) === null || _b === void 0 ? void 0 : _b.components,
135
+ dark: (_c = theme === null || theme === void 0 ? void 0 : theme.dark) === null || _c === void 0 ? void 0 : _c.components,
136
+ };
137
+ }
138
+ },
139
+ _ThemeMixinClass_getFontsConfig = async function _ThemeMixinClass_getFontsConfig() {
140
+ var _b, _c;
141
+ const { projectConfig } = (await this.config) || {};
142
+ const newConfig = (_b = projectConfig === null || projectConfig === void 0 ? void 0 : projectConfig.styles) === null || _b === void 0 ? void 0 : _b[this.styleId];
143
+ const oldConfig = projectConfig === null || projectConfig === void 0 ? void 0 : projectConfig.cssTemplate;
144
+ const config = newConfig || oldConfig;
145
+ const fonts = (_c = config === null || config === void 0 ? void 0 : config[this.theme]) === null || _c === void 0 ? void 0 : _c.fonts;
146
+ return fonts;
147
+ },
148
+ _ThemeMixinClass_loadFonts = async function _ThemeMixinClass_loadFonts() {
149
+ const fonts = await __classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_getFontsConfig).call(this);
150
+ if (fonts) {
151
+ Object.values(fonts).forEach((font) => {
152
+ if (font.url) {
153
+ this.logger.debug(`Loading font from URL "${font.url}"`);
154
+ loadFont(font.url);
155
+ }
156
+ });
157
+ }
158
+ else {
159
+ this.logger.debug('No fonts to load');
160
+ }
161
+ },
162
+ _ThemeMixinClass_applyTheme = async function _ThemeMixinClass_applyTheme() {
163
+ this.rootElement.setAttribute('data-theme', this.theme);
164
+ const descopeUi = await this.descopeUi;
165
+ if (descopeUi === null || descopeUi === void 0 ? void 0 : descopeUi.componentsThemeManager) {
166
+ descopeUi.componentsThemeManager.currentThemeName = this.theme;
167
+ }
168
+ },
169
+ _ThemeMixinClass_loadTheme = function _ThemeMixinClass_loadTheme() {
170
+ __classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_loadFonts).call(this);
171
+ __classPrivateFieldGet(this, _ThemeMixinClass_instances, "m", _ThemeMixinClass_applyTheme).call(this);
172
+ },
173
+ _a;
174
+ });
175
+
176
+ export { themeMixin };
177
+ //# sourceMappingURL=themeMixin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"themeMixin.js","sources":["../../../../src/mixins/themeMixin/themeMixin.ts"],"sourcesContent":["/* eslint-disable no-underscore-dangle */\nimport { createSingletonMixin, compose } from '@descope/sdk-helpers';\nimport { configMixin } from '../configMixin';\nimport { createValidateAttributesMixin } from '../createValidateAttributesMixin';\nimport { descopeUiMixin } from '../descopeUiMixin';\nimport { initElementMixin } from '../initElementMixin';\nimport { initLifecycleMixin } from '../initLifecycleMixin';\nimport { staticResourcesMixin } from '../staticResourcesMixin';\nimport { DEFAULT_STYLE_ID } from './constants';\nimport { loadDevTheme, loadFont } from './helpers';\nimport { observeAttributesMixin } from '../observeAttributesMixin';\nimport { UI_COMPONENTS_URL_KEY } from '../descopeUiMixin/constants';\n\nconst themeValidation = (_: string, theme: string | null) =>\n (theme || false) &&\n theme !== 'light' &&\n theme !== 'dark' &&\n 'Supported theme values are \"light\", \"dark\", or leave empty for using the OS theme';\n\nexport type ThemeOptions = 'light' | 'dark' | 'os';\n\nexport const themeMixin = createSingletonMixin(\n <T extends CustomElementConstructor>(superclass: T) => {\n const BaseClass = compose(\n createValidateAttributesMixin({ theme: themeValidation }),\n staticResourcesMixin,\n initLifecycleMixin,\n descopeUiMixin,\n configMixin,\n initElementMixin,\n observeAttributesMixin,\n )(superclass);\n\n return class ThemeMixinClass extends BaseClass {\n #globalStyle: CSSStyleSheet;\n\n get theme(): ThemeOptions {\n const theme = this.getAttribute('theme') as ThemeOptions | null;\n\n if (theme === 'os') {\n const isOsDark =\n window.matchMedia &&\n window.matchMedia?.('(prefers-color-scheme: dark)')?.matches;\n\n return isOsDark ? 'dark' : 'light';\n }\n\n return theme || 'light';\n }\n\n get styleId(): string {\n return this.getAttribute('style-id') || DEFAULT_STYLE_ID;\n }\n\n #_themeResource: Promise<void | Record<string, any>>;\n\n async #fetchTheme() {\n try {\n const { body: fetchedTheme } = await this.fetchStaticResource(\n `${this.styleId}.json`,\n 'json',\n );\n\n // In development mode, we sometimes want to override the UI components URL\n // 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\n if (process.env.NODE_ENV === 'development') {\n if (localStorage?.getItem(UI_COMPONENTS_URL_KEY)) {\n try {\n this.logger.warn(\n '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',\n );\n const devTheme = await loadDevTheme();\n\n if (devTheme) {\n fetchedTheme.light.components = {\n ...fetchedTheme.light.components,\n ...devTheme.light.components,\n };\n fetchedTheme.dark.components = {\n ...fetchedTheme.dark.components,\n ...devTheme.dark.components,\n };\n\n this.logger.warn('Theme was merged successfully');\n\n // eslint-disable-next-line no-console\n console.log(\n '%cNOTICE! This is not the theme that will be used in production!\\n\\nMake sure to test it without the override UI components URL!',\n 'color: black; background-color:yellow; font-size: x-large',\n );\n }\n } catch (e) {\n this.logger.error('Failed to merge UI components theme\\n', e);\n }\n }\n }\n\n return fetchedTheme;\n } catch (e) {\n this.logger.error(\n 'Cannot fetch theme file',\n 'make sure that your projectId & flowId are correct',\n );\n }\n\n return undefined;\n }\n\n get #themeResource() {\n if (!this.#_themeResource) {\n this.#_themeResource = this.#fetchTheme();\n this.#_themeResource.then((theme) =>\n this.logger.debug('Fetched theme', theme),\n );\n }\n\n // eslint-disable-next-line no-underscore-dangle\n return this.#_themeResource;\n }\n\n async #loadGlobalStyle() {\n const theme = await this.#themeResource;\n if (!theme) return;\n\n if (!this.#globalStyle) {\n this.#globalStyle = new CSSStyleSheet();\n this.shadowRoot.adoptedStyleSheets ??= [];\n this.shadowRoot.adoptedStyleSheets = [\n ...this.shadowRoot.adoptedStyleSheets,\n this.#globalStyle,\n ];\n }\n\n this.#globalStyle.replaceSync(\n (theme?.light?.globals || '') + (theme?.dark?.globals || ''),\n );\n }\n\n async #loadComponentsStyle() {\n const theme = { ...(await this.#themeResource) } as Record<string, any>;\n if (!theme) return;\n\n const descopeUi = await this.descopeUi;\n if (descopeUi?.componentsThemeManager) {\n descopeUi.componentsThemeManager.themes = {\n light: theme?.light?.components,\n dark: theme?.dark?.components,\n };\n }\n }\n\n async #getFontsConfig() {\n const { projectConfig } = (await this.config) || {};\n\n const newConfig = projectConfig?.styles?.[this.styleId];\n const oldConfig = projectConfig?.cssTemplate;\n\n const config = newConfig || oldConfig;\n\n const fonts: Record<string, { url?: string }> | undefined =\n config?.[this.theme]?.fonts;\n\n return fonts;\n }\n\n async #loadFonts() {\n const fonts = await this.#getFontsConfig();\n if (fonts) {\n Object.values(fonts).forEach((font) => {\n if (font.url) {\n this.logger.debug(`Loading font from URL \"${font.url}\"`);\n loadFont(font.url);\n }\n });\n } else {\n this.logger.debug('No fonts to load');\n }\n }\n\n async #applyTheme() {\n this.rootElement.setAttribute('data-theme', this.theme);\n const descopeUi = await this.descopeUi;\n if (descopeUi?.componentsThemeManager) {\n descopeUi.componentsThemeManager.currentThemeName = this.theme;\n }\n }\n\n #onThemeChange = () => {\n this.#loadTheme();\n this.#toggleOsThemeChangeListener(this.getAttribute('theme') === 'os');\n };\n\n #loadTheme() {\n this.#loadFonts();\n this.#applyTheme();\n }\n\n // add or remove os theme change listener\n #toggleOsThemeChangeListener = (listen: boolean) => {\n const method = listen ? 'addEventListener' : 'removeEventListener';\n window\n .matchMedia?.('(prefers-color-scheme: dark)')\n ?.[method]?.('change', () => this.#loadTheme());\n };\n\n async init() {\n await super.init?.();\n\n this.#loadGlobalStyle();\n this.#loadComponentsStyle();\n this.#onThemeChange();\n\n this.observeAttributes(['theme'], this.#onThemeChange);\n\n this.observeAttributes(['style-id'], () => {\n this.#_themeResource = null;\n this.#loadFonts();\n this.#loadGlobalStyle();\n this.#loadComponentsStyle();\n });\n }\n };\n },\n);\n"],"names":[],"mappings":"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"}