@progressive-development/pd-spa-helper 1.0.0 → 1.0.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 (269) hide show
  1. package/dist/auth/AuthController.d.ts +37 -0
  2. package/dist/auth/AuthController.d.ts.map +1 -0
  3. package/dist/auth/AuthController.js +65 -0
  4. package/dist/auth/auth-directives.d.ts +59 -0
  5. package/dist/auth/auth-directives.d.ts.map +1 -0
  6. package/dist/auth/auth-directives.js +81 -0
  7. package/dist/auth/auth-utils.d.ts +45 -0
  8. package/dist/auth/auth-utils.d.ts.map +1 -0
  9. package/dist/auth/auth-utils.js +42 -0
  10. package/dist/auth/index.d.ts +7 -0
  11. package/dist/auth/index.d.ts.map +1 -0
  12. package/dist/components/default-login/DefaultLogin.d.ts +15 -0
  13. package/dist/components/default-login/DefaultLogin.d.ts.map +1 -0
  14. package/dist/components/default-login/DefaultLogin.js +120 -0
  15. package/dist/components/default-not-found/DefaultNotFound.d.ts +6 -0
  16. package/dist/components/default-not-found/DefaultNotFound.d.ts.map +1 -0
  17. package/dist/{defaultpage/default-not-found.js → components/default-not-found/DefaultNotFound.js} +10 -3
  18. package/dist/components/pd-section-page/PdSectionPage.d.ts +55 -0
  19. package/dist/components/pd-section-page/PdSectionPage.d.ts.map +1 -0
  20. package/dist/components/pd-section-page/PdSectionPage.js +37 -0
  21. package/dist/components/pd-spa-helper/PdSpaHelper.d.ts +196 -0
  22. package/dist/components/pd-spa-helper/PdSpaHelper.d.ts.map +1 -0
  23. package/dist/components/pd-spa-helper/PdSpaHelper.js +603 -0
  24. package/dist/components/pd-spa-helper/controllers/ScrollController.d.ts +77 -0
  25. package/dist/components/pd-spa-helper/controllers/ScrollController.d.ts.map +1 -0
  26. package/dist/components/pd-spa-helper/controllers/ScrollController.js +102 -0
  27. package/dist/components/pd-spa-helper/spa-config.d.ts +95 -0
  28. package/dist/components/pd-spa-helper/spa-config.d.ts.map +1 -0
  29. package/dist/components/pd-spa-helper/spa-config.js +175 -0
  30. package/dist/components/pd-spa-helper/spa-events.d.ts +132 -0
  31. package/dist/components/pd-spa-helper/spa-events.d.ts.map +1 -0
  32. package/dist/components/pd-spa-helper/spa-events.js +18 -0
  33. package/dist/db/index.d.ts +3 -0
  34. package/dist/db/index.d.ts.map +1 -0
  35. package/dist/{store → db}/indexDB.d.ts +9 -9
  36. package/dist/db/indexDB.d.ts.map +1 -0
  37. package/dist/{store → db}/indexDB.js +14 -12
  38. package/dist/generated/locales/be.d.ts +1 -15
  39. package/dist/generated/locales/be.d.ts.map +1 -1
  40. package/dist/generated/locales/be.js +1 -15
  41. package/dist/generated/locales/de.d.ts +1 -15
  42. package/dist/generated/locales/de.d.ts.map +1 -1
  43. package/dist/generated/locales/de.js +1 -15
  44. package/dist/generated/locales/en.d.ts +1 -15
  45. package/dist/generated/locales/en.d.ts.map +1 -1
  46. package/dist/generated/locales/en.js +1 -15
  47. package/dist/helper/logger.d.ts +11 -12
  48. package/dist/helper/logger.d.ts.map +1 -1
  49. package/dist/helper/logger.js +10 -49
  50. package/dist/helper/refresh-id-token.d.ts.map +1 -1
  51. package/dist/helper/refresh-id-token.js +6 -4
  52. package/dist/index.d.ts +31 -29
  53. package/dist/index.d.ts.map +1 -1
  54. package/dist/index.js +27 -50
  55. package/dist/model/index.d.ts +4 -0
  56. package/dist/model/index.d.ts.map +1 -0
  57. package/dist/model/spa-model.d.ts +14 -15
  58. package/dist/model/spa-model.d.ts.map +1 -1
  59. package/dist/router/PdRouterService.d.ts +4 -1
  60. package/dist/router/PdRouterService.d.ts.map +1 -1
  61. package/dist/router/PdRouterService.js +40 -16
  62. package/dist/router/index.d.ts +3 -0
  63. package/dist/router/index.d.ts.map +1 -0
  64. package/dist/screen-size/ScreenSizeController.d.ts +34 -0
  65. package/dist/screen-size/ScreenSizeController.d.ts.map +1 -0
  66. package/dist/screen-size/ScreenSizeController.js +58 -0
  67. package/dist/screen-size/ScreenSizeService.d.ts +49 -0
  68. package/dist/screen-size/ScreenSizeService.d.ts.map +1 -0
  69. package/dist/screen-size/ScreenSizeService.js +107 -0
  70. package/dist/screen-size/index.d.ts +13 -0
  71. package/dist/screen-size/index.d.ts.map +1 -0
  72. package/dist/screen-size/responsive-directives.d.ts +59 -0
  73. package/dist/screen-size/responsive-directives.d.ts.map +1 -0
  74. package/dist/screen-size/responsive-directives.js +71 -0
  75. package/dist/screen-size/types.d.ts +44 -0
  76. package/dist/screen-size/types.d.ts.map +1 -0
  77. package/dist/service-provider/ServiceRegistry.d.ts +67 -0
  78. package/dist/service-provider/ServiceRegistry.d.ts.map +1 -0
  79. package/dist/service-provider/ServiceRegistry.js +76 -0
  80. package/dist/service-provider/function-utils.d.ts +55 -0
  81. package/dist/service-provider/function-utils.d.ts.map +1 -0
  82. package/dist/service-provider/function-utils.js +30 -0
  83. package/dist/service-provider/index.d.ts +10 -0
  84. package/dist/service-provider/index.d.ts.map +1 -0
  85. package/dist/service-provider/interfaces/IAuthProvider.d.ts +68 -0
  86. package/dist/service-provider/interfaces/IAuthProvider.d.ts.map +1 -0
  87. package/dist/service-provider/interfaces/IDatabaseProvider.d.ts +75 -0
  88. package/dist/service-provider/interfaces/IDatabaseProvider.d.ts.map +1 -0
  89. package/dist/service-provider/interfaces/IFunctionProvider.d.ts +49 -0
  90. package/dist/service-provider/interfaces/IFunctionProvider.d.ts.map +1 -0
  91. package/dist/service-provider/interfaces/IStorageProvider.d.ts +118 -0
  92. package/dist/service-provider/interfaces/IStorageProvider.d.ts.map +1 -0
  93. package/dist/service-provider/interfaces/ServiceProvider.d.ts +24 -0
  94. package/dist/service-provider/interfaces/ServiceProvider.d.ts.map +1 -0
  95. package/dist/service-provider/interfaces/common.d.ts +5 -0
  96. package/dist/service-provider/interfaces/common.d.ts.map +1 -0
  97. package/dist/service-provider/service-provider-model.d.ts +55 -10
  98. package/dist/service-provider/service-provider-model.d.ts.map +1 -1
  99. package/dist/services/fire-once-service.d.ts +35 -0
  100. package/dist/services/fire-once-service.d.ts.map +1 -0
  101. package/dist/services/fire-once-service.js +61 -0
  102. package/dist/store/async-action-effects.d.ts +179 -0
  103. package/dist/store/async-action-effects.d.ts.map +1 -0
  104. package/dist/store/async-action-effects.js +98 -0
  105. package/dist/store/async-action-utils.d.ts +154 -0
  106. package/dist/store/async-action-utils.d.ts.map +1 -0
  107. package/dist/store/async-action-utils.js +42 -0
  108. package/dist/store/index.d.ts +9 -0
  109. package/dist/store/index.d.ts.map +1 -0
  110. package/dist/store/mini-rx.store.d.ts.map +1 -1
  111. package/dist/store/mini-rx.store.js +1 -3
  112. package/dist/store/spa-app-actions.d.ts +5 -22
  113. package/dist/store/spa-app-actions.d.ts.map +1 -1
  114. package/dist/store/spa-app-actions.js +4 -8
  115. package/dist/store/spa-app-effects.d.ts +0 -17
  116. package/dist/store/spa-app-effects.d.ts.map +1 -1
  117. package/dist/store/spa-app-effects.js +2 -40
  118. package/dist/store/spa-app-reducer.d.ts +5 -10
  119. package/dist/store/spa-app-reducer.d.ts.map +1 -1
  120. package/dist/store/spa-app-reducer.js +13 -8
  121. package/dist/store/spa-app-selector.d.ts +2 -2
  122. package/dist/store/spa-app-selector.d.ts.map +1 -1
  123. package/dist/store/spa-app-selector.js +1 -1
  124. package/dist/stories/introduction.stories.d.ts +11 -0
  125. package/dist/stories/introduction.stories.d.ts.map +1 -0
  126. package/package.json +14 -9
  127. package/dist/PdSpaHelper.d.ts +0 -83
  128. package/dist/PdSpaHelper.d.ts.map +0 -1
  129. package/dist/PdSpaHelper.js +0 -492
  130. package/dist/defaultpage/default-confirm-popup.d.ts +0 -19
  131. package/dist/defaultpage/default-confirm-popup.d.ts.map +0 -1
  132. package/dist/defaultpage/default-confirm-popup.js +0 -70
  133. package/dist/defaultpage/default-dialog-popup.d.ts +0 -19
  134. package/dist/defaultpage/default-dialog-popup.d.ts.map +0 -1
  135. package/dist/defaultpage/default-dialog-popup.js +0 -103
  136. package/dist/defaultpage/default-login.d.ts +0 -6
  137. package/dist/defaultpage/default-login.d.ts.map +0 -1
  138. package/dist/defaultpage/default-login.js +0 -33
  139. package/dist/defaultpage/default-not-found.d.ts +0 -6
  140. package/dist/defaultpage/default-not-found.d.ts.map +0 -1
  141. package/dist/defaultpage/default-popup.d.ts +0 -7
  142. package/dist/defaultpage/default-popup.d.ts.map +0 -1
  143. package/dist/defaultpage/default-popup.js +0 -24
  144. package/dist/defaultpage/default-step-address.d.ts +0 -14
  145. package/dist/defaultpage/default-step-address.d.ts.map +0 -1
  146. package/dist/defaultpage/default-step-address.js +0 -77
  147. package/dist/defaultpage/default-step-summary.d.ts +0 -28
  148. package/dist/defaultpage/default-step-summary.d.ts.map +0 -1
  149. package/dist/defaultpage/default-step-summary.js +0 -67
  150. package/dist/defaultpage/default-view-page.d.ts +0 -10
  151. package/dist/defaultpage/default-view-page.d.ts.map +0 -1
  152. package/dist/defaultpage/default-view-page.js +0 -70
  153. package/dist/defaultpage/default-wizard.d.ts +0 -37
  154. package/dist/defaultpage/default-wizard.d.ts.map +0 -1
  155. package/dist/defaultpage/default-wizard.js +0 -255
  156. package/dist/defaultpage/pd-default-wizard-step.d.ts +0 -60
  157. package/dist/defaultpage/pd-default-wizard-step.d.ts.map +0 -1
  158. package/dist/defaultpage/pd-default-wizard-step.js +0 -144
  159. package/dist/generated/locale-wrapper/be-wrapper.d.ts +0 -63
  160. package/dist/generated/locale-wrapper/be-wrapper.d.ts.map +0 -1
  161. package/dist/generated/locale-wrapper/de-wrapper.d.ts +0 -63
  162. package/dist/generated/locale-wrapper/de-wrapper.d.ts.map +0 -1
  163. package/dist/generated/locale-wrapper/en-wrapper.d.ts +0 -63
  164. package/dist/generated/locale-wrapper/en-wrapper.d.ts.map +0 -1
  165. package/dist/helper/blob-helper.d.ts +0 -3
  166. package/dist/helper/blob-helper.d.ts.map +0 -1
  167. package/dist/helper/blob-helper.js +0 -35
  168. package/dist/helper/date-helper.d.ts +0 -27
  169. package/dist/helper/date-helper.d.ts.map +0 -1
  170. package/dist/helper/date-helper.js +0 -129
  171. package/dist/helper/locale-format.d.ts +0 -4
  172. package/dist/helper/locale-format.d.ts.map +0 -1
  173. package/dist/helper/locale-format.js +0 -16
  174. package/dist/helper/number-helper.d.ts +0 -2
  175. package/dist/helper/number-helper.d.ts.map +0 -1
  176. package/dist/helper/number-helper.js +0 -13
  177. package/dist/helper/price-helper.d.ts +0 -5
  178. package/dist/helper/price-helper.d.ts.map +0 -1
  179. package/dist/helper/price-helper.js +0 -22
  180. package/dist/helper/text-helper.d.ts +0 -3
  181. package/dist/helper/text-helper.d.ts.map +0 -1
  182. package/dist/helper/text-helper.js +0 -4
  183. package/dist/popup/wizard-close-popup.d.ts +0 -11
  184. package/dist/popup/wizard-close-popup.d.ts.map +0 -1
  185. package/dist/popup/wizard-close-popup.js +0 -63
  186. package/dist/popup/wizard-reload-popup.d.ts +0 -14
  187. package/dist/popup/wizard-reload-popup.d.ts.map +0 -1
  188. package/dist/popup/wizard-reload-popup.js +0 -76
  189. package/dist/service-provider/firebase/auth.d.ts +0 -19
  190. package/dist/service-provider/firebase/auth.d.ts.map +0 -1
  191. package/dist/service-provider/firebase/auth.js +0 -62
  192. package/dist/service-provider/firebase/firestorage-client.d.ts +0 -22
  193. package/dist/service-provider/firebase/firestorage-client.d.ts.map +0 -1
  194. package/dist/service-provider/firebase/firestorage-client.js +0 -226
  195. package/dist/service-provider/firebase/firestore-client.d.ts +0 -12
  196. package/dist/service-provider/firebase/firestore-client.d.ts.map +0 -1
  197. package/dist/service-provider/firebase/firestore-client.js +0 -25
  198. package/dist/service-provider/firebase/functions-client.d.ts +0 -10
  199. package/dist/service-provider/firebase/functions-client.d.ts.map +0 -1
  200. package/dist/service-provider/firebase/functions-client.js +0 -63
  201. package/dist/service-provider/firebase/messagingFirebaseClient.d.ts +0 -9
  202. package/dist/service-provider/firebase/messagingFirebaseClient.d.ts.map +0 -1
  203. package/dist/service-provider/firebase/messagingFirebaseClient.js +0 -69
  204. package/dist/service-provider/mock/auth.d.ts +0 -6
  205. package/dist/service-provider/mock/auth.d.ts.map +0 -1
  206. package/dist/service-provider/mock/auth.js +0 -60
  207. package/dist/service-provider/mock/function-client.d.ts +0 -7
  208. package/dist/service-provider/mock/function-client.d.ts.map +0 -1
  209. package/dist/service-provider/mock/function-client.js +0 -30
  210. package/dist/service-provider/mock/storage-client.d.ts +0 -11
  211. package/dist/service-provider/mock/storage-client.d.ts.map +0 -1
  212. package/dist/service-provider/mock/storage-client.js +0 -106
  213. package/dist/service-provider/service-provider-impl.d.ts +0 -27
  214. package/dist/service-provider/service-provider-impl.d.ts.map +0 -1
  215. package/dist/service-provider/service-provider-impl.js +0 -222
  216. package/dist/store/indexDB.d.ts.map +0 -1
  217. package/dist/stories/address-edit.stories.d.ts +0 -27
  218. package/dist/stories/address-edit.stories.d.ts.map +0 -1
  219. package/dist/stories/address-new.stories.d.ts +0 -33
  220. package/dist/stories/address-new.stories.d.ts.map +0 -1
  221. package/dist/stories/default-confirm-popup.stories.d.ts +0 -24
  222. package/dist/stories/default-confirm-popup.stories.d.ts.map +0 -1
  223. package/dist/stories/default-dialog-popup.stories.d.ts +0 -23
  224. package/dist/stories/default-dialog-popup.stories.d.ts.map +0 -1
  225. package/dist/stories/default-login.stories.d.ts +0 -10
  226. package/dist/stories/default-login.stories.d.ts.map +0 -1
  227. package/dist/stories/default-popup.stories.d.ts +0 -9
  228. package/dist/stories/default-popup.stories.d.ts.map +0 -1
  229. package/dist/stories/pd-loading-state.stories.d.ts +0 -30
  230. package/dist/stories/pd-loading-state.stories.d.ts.map +0 -1
  231. package/dist/stories/pd-toast.stories.d.ts +0 -27
  232. package/dist/stories/pd-toast.stories.d.ts.map +0 -1
  233. package/dist/stories/routing.stories.d.ts +0 -24
  234. package/dist/stories/routing.stories.d.ts.map +0 -1
  235. package/dist/stories/test-impls/address-test.d.ts +0 -6
  236. package/dist/stories/test-impls/address-test.d.ts.map +0 -1
  237. package/dist/stories/test-impls/test-mock-app.d.ts +0 -15
  238. package/dist/stories/test-impls/test-mock-app.d.ts.map +0 -1
  239. package/dist/stories/test-impls/test-pages/test-home-page.d.ts +0 -7
  240. package/dist/stories/test-impls/test-pages/test-home-page.d.ts.map +0 -1
  241. package/dist/stories/test-impls/test-pages/test-not-found-page.d.ts +0 -5
  242. package/dist/stories/test-impls/test-pages/test-not-found-page.d.ts.map +0 -1
  243. package/dist/stories/test-impls/test-pages/test-wizard-step.d.ts +0 -17
  244. package/dist/stories/test-impls/test-pages/test-wizard-step.d.ts.map +0 -1
  245. package/dist/stories/test-impls/test-pages/test-wizard.d.ts +0 -16
  246. package/dist/stories/test-impls/test-pages/test-wizard.d.ts.map +0 -1
  247. package/dist/stories/test-impls/test-popups/default-confirm-popup-test-error.d.ts +0 -8
  248. package/dist/stories/test-impls/test-popups/default-confirm-popup-test-error.d.ts.map +0 -1
  249. package/dist/stories/test-impls/test-popups/default-confirm-popup-test-info.d.ts +0 -8
  250. package/dist/stories/test-impls/test-popups/default-confirm-popup-test-info.d.ts.map +0 -1
  251. package/dist/stories/test-impls/test-popups/default-confirm-popup-test-warn.d.ts +0 -8
  252. package/dist/stories/test-impls/test-popups/default-confirm-popup-test-warn.d.ts.map +0 -1
  253. package/dist/stories/test-impls/test-popups/default-dialog-popup-test.d.ts +0 -13
  254. package/dist/stories/test-impls/test-popups/default-dialog-popup-test.d.ts.map +0 -1
  255. package/dist/stories/test-impls/test-popups/default-popup-test.d.ts +0 -5
  256. package/dist/stories/test-impls/test-popups/default-popup-test.d.ts.map +0 -1
  257. package/dist/stories/test-wizard-step.stories.d.ts +0 -11
  258. package/dist/stories/test-wizard-step.stories.d.ts.map +0 -1
  259. package/dist/stories/test-wizard.stories.d.ts +0 -9
  260. package/dist/stories/test-wizard.stories.d.ts.map +0 -1
  261. package/dist/tmpown/pd-loading-state.d.ts +0 -9
  262. package/dist/tmpown/pd-loading-state.d.ts.map +0 -1
  263. package/dist/tmpown/pd-loading-state.js +0 -196
  264. package/dist/tmpown/pd-login.d.ts +0 -13
  265. package/dist/tmpown/pd-login.d.ts.map +0 -1
  266. package/dist/tmpown/pd-login.js +0 -165
  267. package/dist/tmpown/pd-toast.d.ts +0 -13
  268. package/dist/tmpown/pd-toast.d.ts.map +0 -1
  269. package/dist/tmpown/pd-toast.js +0 -127
@@ -4,16 +4,22 @@ import { selectAuthUser } from '../store/spa-app-selector.js';
4
4
  import { pdStore } from '../store/mini-rx.store.js';
5
5
  import { createLogger } from '../helper/logger.js';
6
6
 
7
+ const POST_LOGIN_REDIRECT_KEY = "postLoginRedirect";
7
8
  const routingLogger = createLogger("PdRouterService");
8
9
  class PdRouterService {
9
10
  constructor() {
11
+ // UniversalRouter generic typing is complex; using explicit result type
10
12
  this.router = null;
11
13
  this.onChangeHandlers = [];
12
- this.currentRoute = "";
14
+ this._currentRoute = "";
15
+ this._previousRoute = "";
13
16
  window.addEventListener("popstate", () => {
14
17
  this.resolve(location.pathname + location.search);
15
18
  });
16
19
  }
20
+ get previousRoute() {
21
+ return this._previousRoute;
22
+ }
17
23
  /**
18
24
  * Setzt die Routen-Konfiguration. Muss vor Verwendung von navigate() aufgerufen werden.
19
25
  */
@@ -25,24 +31,36 @@ class PdRouterService {
25
31
  const universalRoutes = definitions.flatMap((def) => {
26
32
  return {
27
33
  path: def.pattern,
34
+ // Context type from UniversalRouter extended with userCheck
28
35
  action: async (context) => {
29
- if (def.auth) {
30
- let authResult;
36
+ const requiresAuth = def.auth || def.roles && def.roles.length > 0;
37
+ if (requiresAuth) {
31
38
  if (!context.userCheck?.loginCheckFinish) {
32
39
  routingLogger.debug("Check login is running, wait for result...");
33
- authResult = await waitForFinalAuthState();
40
+ const authResult = await waitForFinalAuthState();
34
41
  routingLogger.debug("Check login is done, go on");
35
42
  context.userCheck = authResult;
36
43
  }
37
44
  if (!context.userCheck?.user) {
38
45
  const fallbackRoute = def.authFallback ?? "login";
46
+ const currentPath = context.pathname || window.location.pathname;
47
+ if (currentPath && currentPath !== "/" + fallbackRoute) {
48
+ sessionStorage.setItem(POST_LOGIN_REDIRECT_KEY, currentPath);
49
+ routingLogger.debug(
50
+ "Stored redirect route for after login:",
51
+ currentPath
52
+ );
53
+ }
39
54
  return { redirect: fallbackRoute };
40
55
  }
41
- }
42
- if (def.roles && !def.roles.some(
43
- (role) => context.userCheck.user.claims?.[role] === true
44
- )) {
45
- return { redirect: "unauthorized" };
56
+ if (def.roles && def.roles.length > 0 && !def.roles.some(
57
+ (role) => context.userCheck?.user?.claims?.[role] === true
58
+ )) {
59
+ routingLogger.debug(
60
+ "User lacks required role, redirecting to unauthorized"
61
+ );
62
+ return { redirect: "unauthorized" };
63
+ }
46
64
  }
47
65
  if (def.action) {
48
66
  const result = await def.action();
@@ -92,10 +110,6 @@ class PdRouterService {
92
110
  const pathname = url.pathname;
93
111
  const query = Object.fromEntries(url.searchParams.entries());
94
112
  try {
95
- routingLogger.debug(
96
- "Bevore resolve current location:",
97
- location.pathname
98
- );
99
113
  const userCheck = await firstValueFrom(
100
114
  pdStore().select(selectAuthUser).pipe(first())
101
115
  );
@@ -103,12 +117,16 @@ class PdRouterService {
103
117
  pathname,
104
118
  userCheck
105
119
  });
120
+ if (!result) {
121
+ routingLogger.warn("No route result for path:", path);
122
+ return;
123
+ }
106
124
  if (result.redirect) {
107
125
  history.replaceState({}, "", result.redirect);
108
126
  await this.resolve(result.redirect);
109
127
  return;
110
128
  }
111
- if (!result || typeof result !== "object" || !result.route) {
129
+ if (typeof result !== "object" || !result.route) {
112
130
  routingLogger.warn("Invalid route result:", result);
113
131
  return;
114
132
  }
@@ -118,7 +136,13 @@ class PdRouterService {
118
136
  params: result.params ?? {},
119
137
  query
120
138
  };
121
- this.currentRoute = routeInfo.route;
139
+ if (routeInfo.route !== "login" && !userCheck?.user && sessionStorage.getItem(POST_LOGIN_REDIRECT_KEY)) {
140
+ sessionStorage.removeItem(POST_LOGIN_REDIRECT_KEY);
141
+ }
142
+ if (this._currentRoute && this._currentRoute !== "login") {
143
+ this._previousRoute = this._currentRoute;
144
+ }
145
+ this._currentRoute = routeInfo.route;
122
146
  this.onChangeHandlers.forEach((fn) => fn(routeInfo));
123
147
  } catch (err) {
124
148
  routingLogger.error("Routing error:", err);
@@ -135,4 +159,4 @@ async function waitForFinalAuthState() {
135
159
  }
136
160
  const pdRouterService = new PdRouterService();
137
161
 
138
- export { pdRouterService };
162
+ export { POST_LOGIN_REDIRECT_KEY, pdRouterService };
@@ -0,0 +1,3 @@
1
+ export { pdRouterService } from './PdRouterService.js';
2
+ export type { RouteDefinition, RouteChangeInfo } from './rout-types.js';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/router/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAEvD,YAAY,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC"}
@@ -0,0 +1,34 @@
1
+ import { ReactiveController, ReactiveControllerHost } from 'lit';
2
+ import { Breakpoint } from './types.js';
3
+ export declare class ScreenSizeController implements ReactiveController {
4
+ private _host;
5
+ private _unsubscribe?;
6
+ constructor(host: ReactiveControllerHost);
7
+ /** Current breakpoint name */
8
+ get breakpoint(): Breakpoint;
9
+ /** Current viewport width in pixels */
10
+ get width(): number;
11
+ /** True if viewport is extra small or small (< 768px) */
12
+ get isMobile(): boolean;
13
+ /** True if viewport is medium (768px - 1023px) */
14
+ get isTablet(): boolean;
15
+ /** True if viewport is large or extra large (>= 1024px) */
16
+ get isDesktop(): boolean;
17
+ /**
18
+ * Check if the current breakpoint matches the given breakpoint.
19
+ */
20
+ is(breakpoint: Breakpoint): boolean;
21
+ /**
22
+ * Check if the current breakpoint is at least the given breakpoint.
23
+ * E.g., isAtLeast('md') returns true for md, lg, xl.
24
+ */
25
+ isAtLeast(breakpoint: Breakpoint): boolean;
26
+ /**
27
+ * Check if the current breakpoint is at most the given breakpoint.
28
+ * E.g., isAtMost('md') returns true for xs, sm, md.
29
+ */
30
+ isAtMost(breakpoint: Breakpoint): boolean;
31
+ hostConnected(): void;
32
+ hostDisconnected(): void;
33
+ }
34
+ //# sourceMappingURL=ScreenSizeController.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScreenSizeController.d.ts","sourceRoot":"","sources":["../../src/screen-size/ScreenSizeController.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8BG;AAEH,OAAO,KAAK,EAAE,kBAAkB,EAAE,sBAAsB,EAAE,MAAM,KAAK,CAAC;AAEtE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAE7C,qBAAa,oBAAqB,YAAW,kBAAkB;IAC7D,OAAO,CAAC,KAAK,CAAyB;IACtC,OAAO,CAAC,YAAY,CAAC,CAAa;gBAEtB,IAAI,EAAE,sBAAsB;IAKxC,8BAA8B;IAC9B,IAAI,UAAU,IAAI,UAAU,CAE3B;IAED,uCAAuC;IACvC,IAAI,KAAK,IAAI,MAAM,CAElB;IAED,yDAAyD;IACzD,IAAI,QAAQ,IAAI,OAAO,CAEtB;IAED,kDAAkD;IAClD,IAAI,QAAQ,IAAI,OAAO,CAEtB;IAED,2DAA2D;IAC3D,IAAI,SAAS,IAAI,OAAO,CAEvB;IAED;;OAEG;IACH,EAAE,CAAC,UAAU,EAAE,UAAU,GAAG,OAAO;IAInC;;;OAGG;IACH,SAAS,CAAC,UAAU,EAAE,UAAU,GAAG,OAAO;IAI1C;;;OAGG;IACH,QAAQ,CAAC,UAAU,EAAE,UAAU,GAAG,OAAO;IAIzC,aAAa,IAAI,IAAI;IAMrB,gBAAgB,IAAI,IAAI;CAGzB"}
@@ -0,0 +1,58 @@
1
+ import { screenSizeService } from './ScreenSizeService.js';
2
+
3
+ class ScreenSizeController {
4
+ constructor(host) {
5
+ this._host = host;
6
+ host.addController(this);
7
+ }
8
+ /** Current breakpoint name */
9
+ get breakpoint() {
10
+ return screenSizeService.breakpoint;
11
+ }
12
+ /** Current viewport width in pixels */
13
+ get width() {
14
+ return screenSizeService.width;
15
+ }
16
+ /** True if viewport is extra small or small (< 768px) */
17
+ get isMobile() {
18
+ return screenSizeService.isMobile;
19
+ }
20
+ /** True if viewport is medium (768px - 1023px) */
21
+ get isTablet() {
22
+ return screenSizeService.isTablet;
23
+ }
24
+ /** True if viewport is large or extra large (>= 1024px) */
25
+ get isDesktop() {
26
+ return screenSizeService.isDesktop;
27
+ }
28
+ /**
29
+ * Check if the current breakpoint matches the given breakpoint.
30
+ */
31
+ is(breakpoint) {
32
+ return screenSizeService.is(breakpoint);
33
+ }
34
+ /**
35
+ * Check if the current breakpoint is at least the given breakpoint.
36
+ * E.g., isAtLeast('md') returns true for md, lg, xl.
37
+ */
38
+ isAtLeast(breakpoint) {
39
+ return screenSizeService.isAtLeast(breakpoint);
40
+ }
41
+ /**
42
+ * Check if the current breakpoint is at most the given breakpoint.
43
+ * E.g., isAtMost('md') returns true for xs, sm, md.
44
+ */
45
+ isAtMost(breakpoint) {
46
+ return screenSizeService.isAtMost(breakpoint);
47
+ }
48
+ hostConnected() {
49
+ this._unsubscribe = screenSizeService.subscribe(() => {
50
+ this._host.requestUpdate();
51
+ });
52
+ }
53
+ hostDisconnected() {
54
+ this._unsubscribe?.();
55
+ }
56
+ }
57
+
58
+ export { ScreenSizeController };
@@ -0,0 +1,49 @@
1
+ import { Breakpoint, BreakpointConfig } from './types.js';
2
+ declare class ScreenSizeServiceImpl {
3
+ private _listeners;
4
+ private _currentBreakpoint;
5
+ private _width;
6
+ private _breakpoints;
7
+ constructor(breakpoints?: BreakpointConfig);
8
+ /** Current breakpoint name */
9
+ get breakpoint(): Breakpoint;
10
+ /** Current viewport width in pixels */
11
+ get width(): number;
12
+ /** True if viewport is extra small or small (< 768px) */
13
+ get isMobile(): boolean;
14
+ /** True if viewport is medium (768px - 1023px) */
15
+ get isTablet(): boolean;
16
+ /** True if viewport is large or extra large (>= 1024px) */
17
+ get isDesktop(): boolean;
18
+ /** Breakpoint order for fallback resolution */
19
+ get breakpointOrder(): readonly Breakpoint[];
20
+ /**
21
+ * Subscribe to breakpoint changes.
22
+ * Callback is called when the breakpoint changes (not on every resize).
23
+ *
24
+ * @param callback - Function to call when breakpoint changes
25
+ * @returns Unsubscribe function
26
+ */
27
+ subscribe(callback: () => void): () => void;
28
+ /**
29
+ * Check if the current breakpoint matches the given breakpoint.
30
+ */
31
+ is(breakpoint: Breakpoint): boolean;
32
+ /**
33
+ * Check if the current breakpoint is at least the given breakpoint.
34
+ * E.g., isAtLeast('md') returns true for md, lg, xl.
35
+ */
36
+ isAtLeast(breakpoint: Breakpoint): boolean;
37
+ /**
38
+ * Check if the current breakpoint is at most the given breakpoint.
39
+ * E.g., isAtMost('md') returns true for xs, sm, md.
40
+ */
41
+ isAtMost(breakpoint: Breakpoint): boolean;
42
+ private _handleResize;
43
+ private _updateSize;
44
+ private _notifyListeners;
45
+ }
46
+ /** Singleton instance of the screen size service */
47
+ export declare const screenSizeService: ScreenSizeServiceImpl;
48
+ export {};
49
+ //# sourceMappingURL=ScreenSizeService.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScreenSizeService.d.ts","sourceRoot":"","sources":["../../src/screen-size/ScreenSizeService.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;GAsBG;AAEH,OAAO,KAAK,EAAE,UAAU,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAc/D,cAAM,qBAAqB;IACzB,OAAO,CAAC,UAAU,CAAyB;IAC3C,OAAO,CAAC,kBAAkB,CAAoB;IAC9C,OAAO,CAAC,MAAM,CAAK;IACnB,OAAO,CAAC,YAAY,CAAmB;gBAE3B,WAAW,GAAE,gBAAsC;IAS/D,8BAA8B;IAC9B,IAAI,UAAU,IAAI,UAAU,CAE3B;IAED,uCAAuC;IACvC,IAAI,KAAK,IAAI,MAAM,CAElB;IAED,yDAAyD;IACzD,IAAI,QAAQ,IAAI,OAAO,CAEtB;IAED,kDAAkD;IAClD,IAAI,QAAQ,IAAI,OAAO,CAEtB;IAED,2DAA2D;IAC3D,IAAI,SAAS,IAAI,OAAO,CAEvB;IAED,+CAA+C;IAC/C,IAAI,eAAe,IAAI,SAAS,UAAU,EAAE,CAE3C;IAED;;;;;;OAMG;IACH,SAAS,CAAC,QAAQ,EAAE,MAAM,IAAI,GAAG,MAAM,IAAI;IAK3C;;OAEG;IACH,EAAE,CAAC,UAAU,EAAE,UAAU,GAAG,OAAO;IAInC;;;OAGG;IACH,SAAS,CAAC,UAAU,EAAE,UAAU,GAAG,OAAO;IAM1C;;;OAGG;IACH,QAAQ,CAAC,UAAU,EAAE,UAAU,GAAG,OAAO;IAMzC,OAAO,CAAC,aAAa,CAOnB;IAEF,OAAO,CAAC,WAAW;IAiBnB,OAAO,CAAC,gBAAgB;CAGzB;AAED,oDAAoD;AACpD,eAAO,MAAM,iBAAiB,uBAA8B,CAAC"}
@@ -0,0 +1,107 @@
1
+ const DEFAULT_BREAKPOINTS = {
2
+ xs: 0,
3
+ sm: 640,
4
+ md: 768,
5
+ lg: 1024,
6
+ xl: 1280
7
+ };
8
+ const BREAKPOINT_ORDER = ["xs", "sm", "md", "lg", "xl"];
9
+ class ScreenSizeServiceImpl {
10
+ constructor(breakpoints = DEFAULT_BREAKPOINTS) {
11
+ this._listeners = /* @__PURE__ */ new Set();
12
+ this._currentBreakpoint = "lg";
13
+ this._width = 0;
14
+ this._handleResize = () => {
15
+ const oldBreakpoint = this._currentBreakpoint;
16
+ this._updateSize();
17
+ if (oldBreakpoint !== this._currentBreakpoint) {
18
+ this._notifyListeners();
19
+ }
20
+ };
21
+ this._breakpoints = breakpoints;
22
+ if (typeof window !== "undefined") {
23
+ this._updateSize();
24
+ window.addEventListener("resize", this._handleResize);
25
+ }
26
+ }
27
+ /** Current breakpoint name */
28
+ get breakpoint() {
29
+ return this._currentBreakpoint;
30
+ }
31
+ /** Current viewport width in pixels */
32
+ get width() {
33
+ return this._width;
34
+ }
35
+ /** True if viewport is extra small or small (< 768px) */
36
+ get isMobile() {
37
+ return this._currentBreakpoint === "xs" || this._currentBreakpoint === "sm";
38
+ }
39
+ /** True if viewport is medium (768px - 1023px) */
40
+ get isTablet() {
41
+ return this._currentBreakpoint === "md";
42
+ }
43
+ /** True if viewport is large or extra large (>= 1024px) */
44
+ get isDesktop() {
45
+ return this._currentBreakpoint === "lg" || this._currentBreakpoint === "xl";
46
+ }
47
+ /** Breakpoint order for fallback resolution */
48
+ get breakpointOrder() {
49
+ return BREAKPOINT_ORDER;
50
+ }
51
+ /**
52
+ * Subscribe to breakpoint changes.
53
+ * Callback is called when the breakpoint changes (not on every resize).
54
+ *
55
+ * @param callback - Function to call when breakpoint changes
56
+ * @returns Unsubscribe function
57
+ */
58
+ subscribe(callback) {
59
+ this._listeners.add(callback);
60
+ return () => this._listeners.delete(callback);
61
+ }
62
+ /**
63
+ * Check if the current breakpoint matches the given breakpoint.
64
+ */
65
+ is(breakpoint) {
66
+ return this._currentBreakpoint === breakpoint;
67
+ }
68
+ /**
69
+ * Check if the current breakpoint is at least the given breakpoint.
70
+ * E.g., isAtLeast('md') returns true for md, lg, xl.
71
+ */
72
+ isAtLeast(breakpoint) {
73
+ const currentIndex = BREAKPOINT_ORDER.indexOf(this._currentBreakpoint);
74
+ const targetIndex = BREAKPOINT_ORDER.indexOf(breakpoint);
75
+ return currentIndex >= targetIndex;
76
+ }
77
+ /**
78
+ * Check if the current breakpoint is at most the given breakpoint.
79
+ * E.g., isAtMost('md') returns true for xs, sm, md.
80
+ */
81
+ isAtMost(breakpoint) {
82
+ const currentIndex = BREAKPOINT_ORDER.indexOf(this._currentBreakpoint);
83
+ const targetIndex = BREAKPOINT_ORDER.indexOf(breakpoint);
84
+ return currentIndex <= targetIndex;
85
+ }
86
+ _updateSize() {
87
+ this._width = window.innerWidth;
88
+ const bp = this._breakpoints;
89
+ if (this._width >= bp.xl) {
90
+ this._currentBreakpoint = "xl";
91
+ } else if (this._width >= bp.lg) {
92
+ this._currentBreakpoint = "lg";
93
+ } else if (this._width >= bp.md) {
94
+ this._currentBreakpoint = "md";
95
+ } else if (this._width >= bp.sm) {
96
+ this._currentBreakpoint = "sm";
97
+ } else {
98
+ this._currentBreakpoint = "xs";
99
+ }
100
+ }
101
+ _notifyListeners() {
102
+ this._listeners.forEach((cb) => cb());
103
+ }
104
+ }
105
+ const screenSizeService = new ScreenSizeServiceImpl();
106
+
107
+ export { screenSizeService };
@@ -0,0 +1,13 @@
1
+ /**
2
+ * Screen Size module - Utilities for responsive behavior in Lit applications
3
+ *
4
+ * Provides:
5
+ * - ScreenSizeService: Singleton service for tracking viewport size
6
+ * - ScreenSizeController: Reactive controller for Lit components
7
+ * - responsiveText/responsiveValue: Directives for responsive values in templates
8
+ */
9
+ export { screenSizeService } from './ScreenSizeService.js';
10
+ export { ScreenSizeController } from './ScreenSizeController.js';
11
+ export { responsiveText, responsiveValue } from './responsive-directives.js';
12
+ export type { Breakpoint, BreakpointConfig, ResponsiveTextOptions, ResponsiveValueOptions, } from './types.js';
13
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/screen-size/index.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAGH,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAG3D,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAGjE,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAG7E,YAAY,EACV,UAAU,EACV,gBAAgB,EAChB,qBAAqB,EACrB,sBAAsB,GACvB,MAAM,YAAY,CAAC"}
@@ -0,0 +1,59 @@
1
+ import { AsyncDirective } from 'lit/async-directive.js';
2
+ import { ResponsiveTextOptions, ResponsiveValueOptions } from './types.js';
3
+ /**
4
+ * ResponsiveTextDirective - Returns different text based on screen size
5
+ */
6
+ declare class ResponsiveTextDirective extends AsyncDirective {
7
+ private _options?;
8
+ private _unsubscribe?;
9
+ render(options: ResponsiveTextOptions): string;
10
+ disconnected(): void;
11
+ reconnected(): void;
12
+ private _getText;
13
+ }
14
+ /**
15
+ * ResponsiveValueDirective - Returns different values based on screen size (generic)
16
+ */
17
+ declare class ResponsiveValueDirective<T> extends AsyncDirective {
18
+ private _options?;
19
+ private _unsubscribe?;
20
+ render(options: ResponsiveValueOptions<T>): T;
21
+ disconnected(): void;
22
+ reconnected(): void;
23
+ private _getValue;
24
+ }
25
+ /**
26
+ * Directive for responsive text values.
27
+ * Returns different text based on the current screen size breakpoint.
28
+ *
29
+ * @param options - Object with default and optional breakpoint-specific texts
30
+ * @returns The text for the current breakpoint (with fallback to smaller breakpoints)
31
+ *
32
+ * @example
33
+ * ```typescript
34
+ * html`<pd-button text="${responsiveText({
35
+ * default: 'Click here to continue',
36
+ * sm: 'Continue',
37
+ * xs: 'Go'
38
+ * })}"></pd-button>`
39
+ * ```
40
+ */
41
+ export declare const responsiveText: (options: ResponsiveTextOptions) => import('lit/async-directive.js').DirectiveResult<typeof ResponsiveTextDirective>;
42
+ /**
43
+ * Directive for responsive generic values.
44
+ * Returns different values based on the current screen size breakpoint.
45
+ *
46
+ * @param options - Object with default and optional breakpoint-specific values
47
+ * @returns The value for the current breakpoint (with fallback to smaller breakpoints)
48
+ *
49
+ * @example
50
+ * ```typescript
51
+ * html`<my-component
52
+ * columns="${responsiveValue({ default: 4, md: 2, sm: 1 })}"
53
+ * .showSidebar="${responsiveValue({ default: true, sm: false })}"
54
+ * ></my-component>`
55
+ * ```
56
+ */
57
+ export declare const responsiveValue: (options: ResponsiveValueOptions<unknown>) => import('lit/async-directive.js').DirectiveResult<typeof ResponsiveValueDirective>;
58
+ export {};
59
+ //# sourceMappingURL=responsive-directives.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"responsive-directives.d.ts","sourceRoot":"","sources":["../../src/screen-size/responsive-directives.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AAEH,OAAO,EAAE,cAAc,EAAa,MAAM,wBAAwB,CAAC;AAEnE,OAAO,KAAK,EAEV,qBAAqB,EACrB,sBAAsB,EACvB,MAAM,YAAY,CAAC;AAgCpB;;GAEG;AACH,cAAM,uBAAwB,SAAQ,cAAc;IAClD,OAAO,CAAC,QAAQ,CAAC,CAAwB;IACzC,OAAO,CAAC,YAAY,CAAC,CAAa;IAElC,MAAM,CAAC,OAAO,EAAE,qBAAqB,GAAG,MAAM;IAa9C,YAAY,IAAI,IAAI;IAKpB,WAAW,IAAI,IAAI;IASnB,OAAO,CAAC,QAAQ;CAIjB;AAED;;GAEG;AACH,cAAM,wBAAwB,CAAC,CAAC,CAAE,SAAQ,cAAc;IACtD,OAAO,CAAC,QAAQ,CAAC,CAA4B;IAC7C,OAAO,CAAC,YAAY,CAAC,CAAa;IAElC,MAAM,CAAC,OAAO,EAAE,sBAAsB,CAAC,CAAC,CAAC,GAAG,CAAC;IAa7C,YAAY,IAAI,IAAI;IAKpB,WAAW,IAAI,IAAI;IASnB,OAAO,CAAC,SAAS;CAIlB;AAED;;;;;;;;;;;;;;;GAeG;AACH,eAAO,MAAM,cAAc,sHAAqC,CAAC;AAEjE;;;;;;;;;;;;;;GAcG;AACH,eAAO,MAAM,eAAe,iIAAsC,CAAC"}
@@ -0,0 +1,71 @@
1
+ import { directive, AsyncDirective } from 'lit/async-directive.js';
2
+ import { screenSizeService } from './ScreenSizeService.js';
3
+
4
+ function resolveResponsiveValue(options, currentBreakpoint) {
5
+ const breakpointOrder = screenSizeService.breakpointOrder;
6
+ const currentIndex = breakpointOrder.indexOf(currentBreakpoint);
7
+ for (let i = currentIndex; i < breakpointOrder.length; i++) {
8
+ const bp = breakpointOrder[i];
9
+ const value = options[bp];
10
+ if (value !== void 0) {
11
+ return value;
12
+ }
13
+ }
14
+ return options.default;
15
+ }
16
+ class ResponsiveTextDirective extends AsyncDirective {
17
+ render(options) {
18
+ this._options = options;
19
+ if (!this._unsubscribe) {
20
+ this._unsubscribe = screenSizeService.subscribe(() => {
21
+ this.setValue(this._getText());
22
+ });
23
+ }
24
+ return this._getText();
25
+ }
26
+ disconnected() {
27
+ this._unsubscribe?.();
28
+ this._unsubscribe = void 0;
29
+ }
30
+ reconnected() {
31
+ if (!this._unsubscribe) {
32
+ this._unsubscribe = screenSizeService.subscribe(() => {
33
+ this.setValue(this._getText());
34
+ });
35
+ }
36
+ }
37
+ _getText() {
38
+ if (!this._options) return "";
39
+ return resolveResponsiveValue(this._options, screenSizeService.breakpoint);
40
+ }
41
+ }
42
+ class ResponsiveValueDirective extends AsyncDirective {
43
+ render(options) {
44
+ this._options = options;
45
+ if (!this._unsubscribe) {
46
+ this._unsubscribe = screenSizeService.subscribe(() => {
47
+ this.setValue(this._getValue());
48
+ });
49
+ }
50
+ return this._getValue();
51
+ }
52
+ disconnected() {
53
+ this._unsubscribe?.();
54
+ this._unsubscribe = void 0;
55
+ }
56
+ reconnected() {
57
+ if (!this._unsubscribe) {
58
+ this._unsubscribe = screenSizeService.subscribe(() => {
59
+ this.setValue(this._getValue());
60
+ });
61
+ }
62
+ }
63
+ _getValue() {
64
+ if (!this._options) return void 0;
65
+ return resolveResponsiveValue(this._options, screenSizeService.breakpoint);
66
+ }
67
+ }
68
+ const responsiveText = directive(ResponsiveTextDirective);
69
+ const responsiveValue = directive(ResponsiveValueDirective);
70
+
71
+ export { responsiveText, responsiveValue };
@@ -0,0 +1,44 @@
1
+ /**
2
+ * Screen size types and interfaces
3
+ */
4
+ /** Available breakpoint names (mobile-first) */
5
+ export type Breakpoint = "xs" | "sm" | "md" | "lg" | "xl";
6
+ /** Breakpoint threshold configuration (min-width values in pixels) */
7
+ export interface BreakpointConfig {
8
+ xs: number;
9
+ sm: number;
10
+ md: number;
11
+ lg: number;
12
+ xl: number;
13
+ }
14
+ /** Options for responsive text directive */
15
+ export interface ResponsiveTextOptions {
16
+ /** Default text (used when no breakpoint-specific text matches) */
17
+ default: string;
18
+ /** Text for extra small screens (< 640px) */
19
+ xs?: string;
20
+ /** Text for small screens (640px - 767px) */
21
+ sm?: string;
22
+ /** Text for medium screens (768px - 1023px) */
23
+ md?: string;
24
+ /** Text for large screens (1024px - 1279px) */
25
+ lg?: string;
26
+ /** Text for extra large screens (>= 1280px) */
27
+ xl?: string;
28
+ }
29
+ /** Options for responsive value directive (generic version) */
30
+ export interface ResponsiveValueOptions<T> {
31
+ /** Default value (used when no breakpoint-specific value matches) */
32
+ default: T;
33
+ /** Value for extra small screens */
34
+ xs?: T;
35
+ /** Value for small screens */
36
+ sm?: T;
37
+ /** Value for medium screens */
38
+ md?: T;
39
+ /** Value for large screens */
40
+ lg?: T;
41
+ /** Value for extra large screens */
42
+ xl?: T;
43
+ }
44
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/screen-size/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,gDAAgD;AAChD,MAAM,MAAM,UAAU,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AAE1D,sEAAsE;AACtE,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAC;IACX,EAAE,EAAE,MAAM,CAAC;IACX,EAAE,EAAE,MAAM,CAAC;IACX,EAAE,EAAE,MAAM,CAAC;IACX,EAAE,EAAE,MAAM,CAAC;CACZ;AAED,4CAA4C;AAC5C,MAAM,WAAW,qBAAqB;IACpC,mEAAmE;IACnE,OAAO,EAAE,MAAM,CAAC;IAChB,6CAA6C;IAC7C,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,6CAA6C;IAC7C,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,+CAA+C;IAC/C,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,+CAA+C;IAC/C,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,+CAA+C;IAC/C,EAAE,CAAC,EAAE,MAAM,CAAC;CACb;AAED,+DAA+D;AAC/D,MAAM,WAAW,sBAAsB,CAAC,CAAC;IACvC,qEAAqE;IACrE,OAAO,EAAE,CAAC,CAAC;IACX,oCAAoC;IACpC,EAAE,CAAC,EAAE,CAAC,CAAC;IACP,8BAA8B;IAC9B,EAAE,CAAC,EAAE,CAAC,CAAC;IACP,+BAA+B;IAC/B,EAAE,CAAC,EAAE,CAAC,CAAC;IACP,8BAA8B;IAC9B,EAAE,CAAC,EAAE,CAAC,CAAC;IACP,oCAAoC;IACpC,EAAE,CAAC,EAAE,CAAC,CAAC;CACR"}
@@ -0,0 +1,67 @@
1
+ import { ServiceProvider, IAuthProvider, IFunctionProvider, IStorageProvider, IDatabaseProvider } from '@progressive-development/pd-provider-interfaces';
2
+ /**
3
+ * Central service container for dependency injection
4
+ *
5
+ * Usage:
6
+ * ```typescript
7
+ * // In app initialization (e.g., main.ts)
8
+ * import { services } from "pd-helper-app";
9
+ * import { createFirebaseProvider } from "pd-provider-firebase";
10
+ *
11
+ * services.initialize(createFirebaseProvider(firebaseConfig));
12
+ *
13
+ * // In components/services
14
+ * import { services } from "pd-helper-app";
15
+ *
16
+ * const user = services.auth.getCurrentUser();
17
+ * ```
18
+ */
19
+ export declare class ServiceRegistry {
20
+ private provider;
21
+ /**
22
+ * Initialize the service registry with a provider
23
+ * @param provider The service provider to use
24
+ * @throws Error if already initialized
25
+ */
26
+ initialize(provider: ServiceProvider): void;
27
+ /**
28
+ * Check if the registry has been initialized
29
+ */
30
+ get isInitialized(): boolean;
31
+ /**
32
+ * Ensure the registry is initialized before accessing providers
33
+ * @throws Error if not initialized
34
+ */
35
+ private ensureInitialized;
36
+ /**
37
+ * Get the auth provider
38
+ */
39
+ get auth(): IAuthProvider;
40
+ /**
41
+ * Get the functions provider
42
+ */
43
+ get functions(): IFunctionProvider;
44
+ /**
45
+ * Get the storage provider
46
+ */
47
+ get storage(): IStorageProvider;
48
+ /**
49
+ * Get the database provider (optional)
50
+ * @returns Database provider or undefined if not configured
51
+ */
52
+ get database(): IDatabaseProvider | undefined;
53
+ /**
54
+ * Reset the registry (primarily for testing)
55
+ *
56
+ * Warning: This should only be used in tests.
57
+ * In production, providers should be initialized once at app startup.
58
+ */
59
+ reset(): void;
60
+ }
61
+ /**
62
+ * Global service registry instance
63
+ *
64
+ * This is the main entry point for accessing services throughout the application.
65
+ */
66
+ export declare const services: ServiceRegistry;
67
+ //# sourceMappingURL=ServiceRegistry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ServiceRegistry.d.ts","sourceRoot":"","sources":["../../src/service-provider/ServiceRegistry.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EACV,eAAe,EACf,aAAa,EACb,iBAAiB,EACjB,gBAAgB,EAChB,iBAAiB,EAClB,MAAM,iDAAiD,CAAC;AAEzD;;;;;;;;;;;;;;;;GAgBG;AACH,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAgC;IAEhD;;;;OAIG;IACH,UAAU,CAAC,QAAQ,EAAE,eAAe,GAAG,IAAI;IAS3C;;OAEG;IACH,IAAI,aAAa,IAAI,OAAO,CAE3B;IAED;;;OAGG;IACH,OAAO,CAAC,iBAAiB;IAQzB;;OAEG;IACH,IAAI,IAAI,IAAI,aAAa,CAGxB;IAED;;OAEG;IACH,IAAI,SAAS,IAAI,iBAAiB,CAGjC;IAED;;OAEG;IACH,IAAI,OAAO,IAAI,gBAAgB,CAG9B;IAED;;;OAGG;IACH,IAAI,QAAQ,IAAI,iBAAiB,GAAG,SAAS,CAG5C;IAED;;;;;OAKG;IACH,KAAK,IAAI,IAAI;CAGd;AAED;;;;GAIG;AACH,eAAO,MAAM,QAAQ,iBAAwB,CAAC"}