@progressive-development/pd-spa-helper 0.8.22 → 0.9.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 (276) hide show
  1. package/LICENSE +2 -21
  2. package/dist/auth/AuthController.d.ts +37 -0
  3. package/dist/auth/AuthController.d.ts.map +1 -0
  4. package/dist/auth/AuthController.js +65 -0
  5. package/dist/auth/auth-directives.d.ts +59 -0
  6. package/dist/auth/auth-directives.d.ts.map +1 -0
  7. package/dist/auth/auth-directives.js +81 -0
  8. package/dist/auth/auth-utils.d.ts +45 -0
  9. package/dist/auth/auth-utils.d.ts.map +1 -0
  10. package/dist/auth/auth-utils.js +42 -0
  11. package/dist/auth/index.d.ts +7 -0
  12. package/dist/auth/index.d.ts.map +1 -0
  13. package/dist/components/default-login/DefaultLogin.d.ts +15 -0
  14. package/dist/components/default-login/DefaultLogin.d.ts.map +1 -0
  15. package/dist/components/default-login/DefaultLogin.js +120 -0
  16. package/dist/components/default-not-found/DefaultNotFound.d.ts +6 -0
  17. package/dist/components/default-not-found/DefaultNotFound.d.ts.map +1 -0
  18. package/dist/{defaultpage/default-not-found.js → components/default-not-found/DefaultNotFound.js} +15 -8
  19. package/dist/components/pd-section-page/PdSectionPage.d.ts +55 -0
  20. package/dist/components/pd-section-page/PdSectionPage.d.ts.map +1 -0
  21. package/dist/components/pd-section-page/PdSectionPage.js +40 -0
  22. package/dist/components/pd-spa-helper/PdSpaHelper.d.ts +160 -0
  23. package/dist/components/pd-spa-helper/PdSpaHelper.d.ts.map +1 -0
  24. package/dist/components/pd-spa-helper/PdSpaHelper.js +651 -0
  25. package/dist/components/pd-spa-helper/controllers/ScrollController.d.ts +77 -0
  26. package/dist/components/pd-spa-helper/controllers/ScrollController.d.ts.map +1 -0
  27. package/dist/components/pd-spa-helper/controllers/ScrollController.js +102 -0
  28. package/dist/components/pd-spa-helper/spa-config.d.ts +87 -0
  29. package/dist/components/pd-spa-helper/spa-config.d.ts.map +1 -0
  30. package/dist/components/pd-spa-helper/spa-config.js +167 -0
  31. package/dist/components/pd-spa-helper/spa-events.d.ts +121 -0
  32. package/dist/components/pd-spa-helper/spa-events.d.ts.map +1 -0
  33. package/dist/components/pd-spa-helper/spa-events.js +18 -0
  34. package/dist/db/index.d.ts +3 -0
  35. package/dist/db/index.d.ts.map +1 -0
  36. package/dist/{store → db}/indexDB.d.ts +9 -9
  37. package/dist/db/indexDB.d.ts.map +1 -0
  38. package/dist/{store → db}/indexDB.js +18 -27
  39. package/dist/generated/locale-wrapper/be-wrapper.js +10 -10
  40. package/dist/generated/locale-wrapper/de-wrapper.js +10 -10
  41. package/dist/generated/locale-wrapper/en-wrapper.js +10 -10
  42. package/dist/generated/locales/be.d.ts +1 -15
  43. package/dist/generated/locales/be.d.ts.map +1 -1
  44. package/dist/generated/locales/be.js +3 -18
  45. package/dist/generated/locales/de.d.ts +1 -15
  46. package/dist/generated/locales/de.d.ts.map +1 -1
  47. package/dist/generated/locales/de.js +3 -18
  48. package/dist/generated/locales/en.d.ts +1 -15
  49. package/dist/generated/locales/en.d.ts.map +1 -1
  50. package/dist/generated/locales/en.js +3 -18
  51. package/dist/helper/logger.d.ts +11 -12
  52. package/dist/helper/logger.d.ts.map +1 -1
  53. package/dist/helper/logger.js +12 -53
  54. package/dist/helper/offline-watcher-helper.js +5 -6
  55. package/dist/helper/refresh-id-token.d.ts.map +1 -1
  56. package/dist/helper/refresh-id-token.js +10 -8
  57. package/dist/index.d.ts +31 -29
  58. package/dist/index.d.ts.map +1 -1
  59. package/dist/index.js +32 -91
  60. package/dist/model/index.d.ts +4 -0
  61. package/dist/model/index.d.ts.map +1 -0
  62. package/dist/model/spa-model.d.ts +14 -15
  63. package/dist/model/spa-model.d.ts.map +1 -1
  64. package/dist/model/spa-model.js +2 -4
  65. package/dist/router/PdRouterService.d.ts +4 -1
  66. package/dist/router/PdRouterService.d.ts.map +1 -1
  67. package/dist/router/PdRouterService.js +48 -28
  68. package/dist/router/index.d.ts +3 -0
  69. package/dist/router/index.d.ts.map +1 -0
  70. package/dist/screen-size/ScreenSizeController.d.ts +34 -0
  71. package/dist/screen-size/ScreenSizeController.d.ts.map +1 -0
  72. package/dist/screen-size/ScreenSizeController.js +58 -0
  73. package/dist/screen-size/ScreenSizeService.d.ts +49 -0
  74. package/dist/screen-size/ScreenSizeService.d.ts.map +1 -0
  75. package/dist/screen-size/ScreenSizeService.js +107 -0
  76. package/dist/screen-size/index.d.ts +13 -0
  77. package/dist/screen-size/index.d.ts.map +1 -0
  78. package/dist/screen-size/responsive-directives.d.ts +59 -0
  79. package/dist/screen-size/responsive-directives.d.ts.map +1 -0
  80. package/dist/screen-size/responsive-directives.js +71 -0
  81. package/dist/screen-size/types.d.ts +44 -0
  82. package/dist/screen-size/types.d.ts.map +1 -0
  83. package/dist/service-provider/ServiceRegistry.d.ts +67 -0
  84. package/dist/service-provider/ServiceRegistry.d.ts.map +1 -0
  85. package/dist/service-provider/ServiceRegistry.js +76 -0
  86. package/dist/service-provider/function-utils.d.ts +55 -0
  87. package/dist/service-provider/function-utils.d.ts.map +1 -0
  88. package/dist/service-provider/function-utils.js +30 -0
  89. package/dist/service-provider/index.d.ts +10 -0
  90. package/dist/service-provider/index.d.ts.map +1 -0
  91. package/dist/service-provider/interfaces/IAuthProvider.d.ts +68 -0
  92. package/dist/service-provider/interfaces/IAuthProvider.d.ts.map +1 -0
  93. package/dist/service-provider/interfaces/IDatabaseProvider.d.ts +75 -0
  94. package/dist/service-provider/interfaces/IDatabaseProvider.d.ts.map +1 -0
  95. package/dist/service-provider/interfaces/IFunctionProvider.d.ts +49 -0
  96. package/dist/service-provider/interfaces/IFunctionProvider.d.ts.map +1 -0
  97. package/dist/service-provider/interfaces/IStorageProvider.d.ts +118 -0
  98. package/dist/service-provider/interfaces/IStorageProvider.d.ts.map +1 -0
  99. package/dist/service-provider/interfaces/ServiceProvider.d.ts +24 -0
  100. package/dist/service-provider/interfaces/ServiceProvider.d.ts.map +1 -0
  101. package/dist/service-provider/interfaces/common.d.ts +5 -0
  102. package/dist/service-provider/interfaces/common.d.ts.map +1 -0
  103. package/dist/service-provider/service-provider-model.d.ts +26 -7
  104. package/dist/service-provider/service-provider-model.d.ts.map +1 -1
  105. package/dist/service-provider/service-provider-model.js +2 -5
  106. package/dist/services/fire-once-service.d.ts +35 -0
  107. package/dist/services/fire-once-service.d.ts.map +1 -0
  108. package/dist/services/fire-once-service.js +61 -0
  109. package/dist/store/async-action-effects.d.ts +179 -0
  110. package/dist/store/async-action-effects.d.ts.map +1 -0
  111. package/dist/store/async-action-effects.js +97 -0
  112. package/dist/store/async-action-utils.d.ts +151 -0
  113. package/dist/store/async-action-utils.d.ts.map +1 -0
  114. package/dist/store/async-action-utils.js +41 -0
  115. package/dist/store/index.d.ts +9 -0
  116. package/dist/store/index.d.ts.map +1 -0
  117. package/dist/store/mini-rx.store.d.ts.map +1 -1
  118. package/dist/store/mini-rx.store.js +7 -10
  119. package/dist/store/spa-app-actions.d.ts +5 -22
  120. package/dist/store/spa-app-actions.d.ts.map +1 -1
  121. package/dist/store/spa-app-actions.js +7 -23
  122. package/dist/store/spa-app-effects.d.ts +0 -17
  123. package/dist/store/spa-app-effects.d.ts.map +1 -1
  124. package/dist/store/spa-app-effects.js +8 -49
  125. package/dist/store/spa-app-reducer.d.ts +5 -10
  126. package/dist/store/spa-app-reducer.d.ts.map +1 -1
  127. package/dist/store/spa-app-reducer.js +26 -21
  128. package/dist/store/spa-app-selector.d.ts +2 -2
  129. package/dist/store/spa-app-selector.d.ts.map +1 -1
  130. package/dist/store/spa-app-selector.js +5 -11
  131. package/dist/stories/introduction.stories.d.ts +11 -0
  132. package/dist/stories/introduction.stories.d.ts.map +1 -0
  133. package/package.json +36 -53
  134. package/dist/PdSpaHelper.d.ts +0 -83
  135. package/dist/PdSpaHelper.d.ts.map +0 -1
  136. package/dist/PdSpaHelper.js +0 -496
  137. package/dist/defaultpage/default-confirm-popup.d.ts +0 -19
  138. package/dist/defaultpage/default-confirm-popup.d.ts.map +0 -1
  139. package/dist/defaultpage/default-confirm-popup.js +0 -73
  140. package/dist/defaultpage/default-dialog-popup.d.ts +0 -19
  141. package/dist/defaultpage/default-dialog-popup.d.ts.map +0 -1
  142. package/dist/defaultpage/default-dialog-popup.js +0 -103
  143. package/dist/defaultpage/default-login.d.ts +0 -6
  144. package/dist/defaultpage/default-login.d.ts.map +0 -1
  145. package/dist/defaultpage/default-login.js +0 -33
  146. package/dist/defaultpage/default-not-found.d.ts +0 -6
  147. package/dist/defaultpage/default-not-found.d.ts.map +0 -1
  148. package/dist/defaultpage/default-popup.d.ts +0 -7
  149. package/dist/defaultpage/default-popup.d.ts.map +0 -1
  150. package/dist/defaultpage/default-popup.js +0 -23
  151. package/dist/defaultpage/default-step-address.d.ts +0 -14
  152. package/dist/defaultpage/default-step-address.d.ts.map +0 -1
  153. package/dist/defaultpage/default-step-address.js +0 -78
  154. package/dist/defaultpage/default-step-summary.d.ts +0 -28
  155. package/dist/defaultpage/default-step-summary.d.ts.map +0 -1
  156. package/dist/defaultpage/default-step-summary.js +0 -66
  157. package/dist/defaultpage/default-view-page.d.ts +0 -10
  158. package/dist/defaultpage/default-view-page.d.ts.map +0 -1
  159. package/dist/defaultpage/default-view-page.js +0 -67
  160. package/dist/defaultpage/default-wizard.d.ts +0 -37
  161. package/dist/defaultpage/default-wizard.d.ts.map +0 -1
  162. package/dist/defaultpage/default-wizard.js +0 -264
  163. package/dist/defaultpage/pd-default-wizard-step.d.ts +0 -58
  164. package/dist/defaultpage/pd-default-wizard-step.d.ts.map +0 -1
  165. package/dist/defaultpage/pd-default-wizard-step.js +0 -147
  166. package/dist/generated/locale-wrapper/be-wrapper.d.ts +0 -62
  167. package/dist/generated/locale-wrapper/be-wrapper.d.ts.map +0 -1
  168. package/dist/generated/locale-wrapper/de-wrapper.d.ts +0 -62
  169. package/dist/generated/locale-wrapper/de-wrapper.d.ts.map +0 -1
  170. package/dist/generated/locale-wrapper/en-wrapper.d.ts +0 -62
  171. package/dist/generated/locale-wrapper/en-wrapper.d.ts.map +0 -1
  172. package/dist/helper/blob-helper.d.ts +0 -3
  173. package/dist/helper/blob-helper.d.ts.map +0 -1
  174. package/dist/helper/blob-helper.js +0 -37
  175. package/dist/helper/date-helper.d.ts +0 -27
  176. package/dist/helper/date-helper.d.ts.map +0 -1
  177. package/dist/helper/date-helper.js +0 -138
  178. package/dist/helper/locale-format.d.ts +0 -4
  179. package/dist/helper/locale-format.d.ts.map +0 -1
  180. package/dist/helper/locale-format.js +0 -19
  181. package/dist/helper/number-helper.d.ts +0 -2
  182. package/dist/helper/number-helper.d.ts.map +0 -1
  183. package/dist/helper/number-helper.js +0 -14
  184. package/dist/helper/price-helper.d.ts +0 -5
  185. package/dist/helper/price-helper.d.ts.map +0 -1
  186. package/dist/helper/price-helper.js +0 -25
  187. package/dist/helper/text-helper.d.ts +0 -3
  188. package/dist/helper/text-helper.d.ts.map +0 -1
  189. package/dist/helper/text-helper.js +0 -6
  190. package/dist/popup/wizard-close-popup.d.ts +0 -11
  191. package/dist/popup/wizard-close-popup.d.ts.map +0 -1
  192. package/dist/popup/wizard-close-popup.js +0 -63
  193. package/dist/popup/wizard-reload-popup.d.ts +0 -14
  194. package/dist/popup/wizard-reload-popup.d.ts.map +0 -1
  195. package/dist/popup/wizard-reload-popup.js +0 -76
  196. package/dist/service-provider/firebase/auth.d.ts +0 -19
  197. package/dist/service-provider/firebase/auth.d.ts.map +0 -1
  198. package/dist/service-provider/firebase/auth.js +0 -69
  199. package/dist/service-provider/firebase/firestorage-client.d.ts +0 -22
  200. package/dist/service-provider/firebase/firestorage-client.d.ts.map +0 -1
  201. package/dist/service-provider/firebase/firestorage-client.js +0 -237
  202. package/dist/service-provider/firebase/firestore-client.d.ts +0 -12
  203. package/dist/service-provider/firebase/firestore-client.d.ts.map +0 -1
  204. package/dist/service-provider/firebase/firestore-client.js +0 -26
  205. package/dist/service-provider/firebase/functions-client.d.ts +0 -10
  206. package/dist/service-provider/firebase/functions-client.d.ts.map +0 -1
  207. package/dist/service-provider/firebase/functions-client.js +0 -64
  208. package/dist/service-provider/firebase/messagingFirebaseClient.d.ts +0 -9
  209. package/dist/service-provider/firebase/messagingFirebaseClient.d.ts.map +0 -1
  210. package/dist/service-provider/firebase/messagingFirebaseClient.js +0 -73
  211. package/dist/service-provider/mock/auth.d.ts +0 -6
  212. package/dist/service-provider/mock/auth.d.ts.map +0 -1
  213. package/dist/service-provider/mock/auth.js +0 -65
  214. package/dist/service-provider/mock/function-client.d.ts +0 -7
  215. package/dist/service-provider/mock/function-client.d.ts.map +0 -1
  216. package/dist/service-provider/mock/function-client.js +0 -32
  217. package/dist/service-provider/mock/storage-client.d.ts +0 -11
  218. package/dist/service-provider/mock/storage-client.d.ts.map +0 -1
  219. package/dist/service-provider/mock/storage-client.js +0 -110
  220. package/dist/service-provider/service-provider-impl.d.ts +0 -27
  221. package/dist/service-provider/service-provider-impl.d.ts.map +0 -1
  222. package/dist/service-provider/service-provider-impl.js +0 -241
  223. package/dist/store/indexDB.d.ts.map +0 -1
  224. package/dist/stories/address-edit.stories.d.ts +0 -27
  225. package/dist/stories/address-edit.stories.d.ts.map +0 -1
  226. package/dist/stories/address-new.stories.d.ts +0 -33
  227. package/dist/stories/address-new.stories.d.ts.map +0 -1
  228. package/dist/stories/default-confirm-popup.stories.d.ts +0 -24
  229. package/dist/stories/default-confirm-popup.stories.d.ts.map +0 -1
  230. package/dist/stories/default-dialog-popup.stories.d.ts +0 -23
  231. package/dist/stories/default-dialog-popup.stories.d.ts.map +0 -1
  232. package/dist/stories/default-login.stories.d.ts +0 -10
  233. package/dist/stories/default-login.stories.d.ts.map +0 -1
  234. package/dist/stories/default-popup.stories.d.ts +0 -9
  235. package/dist/stories/default-popup.stories.d.ts.map +0 -1
  236. package/dist/stories/pd-loading-state.stories.d.ts +0 -30
  237. package/dist/stories/pd-loading-state.stories.d.ts.map +0 -1
  238. package/dist/stories/pd-toast.stories.d.ts +0 -27
  239. package/dist/stories/pd-toast.stories.d.ts.map +0 -1
  240. package/dist/stories/routing.stories.d.ts +0 -24
  241. package/dist/stories/routing.stories.d.ts.map +0 -1
  242. package/dist/stories/test-impls/address-test.d.ts +0 -6
  243. package/dist/stories/test-impls/address-test.d.ts.map +0 -1
  244. package/dist/stories/test-impls/test-mock-app.d.ts +0 -15
  245. package/dist/stories/test-impls/test-mock-app.d.ts.map +0 -1
  246. package/dist/stories/test-impls/test-pages/test-home-page.d.ts +0 -7
  247. package/dist/stories/test-impls/test-pages/test-home-page.d.ts.map +0 -1
  248. package/dist/stories/test-impls/test-pages/test-not-found-page.d.ts +0 -5
  249. package/dist/stories/test-impls/test-pages/test-not-found-page.d.ts.map +0 -1
  250. package/dist/stories/test-impls/test-pages/test-wizard-step.d.ts +0 -17
  251. package/dist/stories/test-impls/test-pages/test-wizard-step.d.ts.map +0 -1
  252. package/dist/stories/test-impls/test-pages/test-wizard.d.ts +0 -16
  253. package/dist/stories/test-impls/test-pages/test-wizard.d.ts.map +0 -1
  254. package/dist/stories/test-impls/test-popups/default-confirm-popup-test-error.d.ts +0 -8
  255. package/dist/stories/test-impls/test-popups/default-confirm-popup-test-error.d.ts.map +0 -1
  256. package/dist/stories/test-impls/test-popups/default-confirm-popup-test-info.d.ts +0 -8
  257. package/dist/stories/test-impls/test-popups/default-confirm-popup-test-info.d.ts.map +0 -1
  258. package/dist/stories/test-impls/test-popups/default-confirm-popup-test-warn.d.ts +0 -8
  259. package/dist/stories/test-impls/test-popups/default-confirm-popup-test-warn.d.ts.map +0 -1
  260. package/dist/stories/test-impls/test-popups/default-dialog-popup-test.d.ts +0 -13
  261. package/dist/stories/test-impls/test-popups/default-dialog-popup-test.d.ts.map +0 -1
  262. package/dist/stories/test-impls/test-popups/default-popup-test.d.ts +0 -5
  263. package/dist/stories/test-impls/test-popups/default-popup-test.d.ts.map +0 -1
  264. package/dist/stories/test-wizard-step.stories.d.ts +0 -11
  265. package/dist/stories/test-wizard-step.stories.d.ts.map +0 -1
  266. package/dist/stories/test-wizard.stories.d.ts +0 -9
  267. package/dist/stories/test-wizard.stories.d.ts.map +0 -1
  268. package/dist/tmpown/pd-loading-state.d.ts +0 -9
  269. package/dist/tmpown/pd-loading-state.d.ts.map +0 -1
  270. package/dist/tmpown/pd-loading-state.js +0 -196
  271. package/dist/tmpown/pd-login.d.ts +0 -13
  272. package/dist/tmpown/pd-login.d.ts.map +0 -1
  273. package/dist/tmpown/pd-login.js +0 -165
  274. package/dist/tmpown/pd-toast.d.ts +0 -13
  275. package/dist/tmpown/pd-toast.d.ts.map +0 -1
  276. package/dist/tmpown/pd-toast.js +0 -128
package/dist/index.js CHANGED
@@ -1,91 +1,32 @@
1
- import { PdSpaHelper, startInit } from "./PdSpaHelper.js";
2
- import * as serviceProviderModel from "./service-provider/service-provider-model.js";
3
- import * as spaModel from "./model/spa-model.js";
4
- import * as offlineWatcherHelper from "./helper/offline-watcher-helper.js";
5
- import * as blobHelper from "./helper/blob-helper.js";
6
- import * as dateHelper from "./helper/date-helper.js";
7
- import * as priceHelper from "./helper/price-helper.js";
8
- import * as numberHelper from "./helper/number-helper.js";
9
- import * as textHelper from "./helper/text-helper.js";
10
- import { DefaultViewPage } from "./defaultpage/default-view-page.js";
11
- import { ABORT_EVENT_NAME, DefaultConfirmPopup, STORE_EVENT_NAME } from "./defaultpage/default-confirm-popup.js";
12
- import { DefaultDialogPopup } from "./defaultpage/default-dialog-popup.js";
13
- import { DefaultPopup } from "./defaultpage/default-popup.js";
14
- import { DefaultWizard } from "./defaultpage/default-wizard.js";
15
- import { PdDefaultWizardStep } from "./defaultpage/pd-default-wizard-step.js";
16
- import { DefaultStepAddress } from "./defaultpage/default-step-address.js";
17
- import { createLogger, defaultLogger } from "./helper/logger.js";
18
- import { DefaultStepSummary } from "./defaultpage/default-step-summary.js";
19
- import { activateCollectionListener, callFunctionImpl, deleteFile, downloadFile, getApp, getMessagingImpl, getStorageConfiguration, getStorageFile, getStorageFileList, getUser, getUserIdToken, isAuthenticatedImpl, loginImpl, logoutImpl, registerAppDeviceForNotification, uploadFile } from "./service-provider/service-provider-impl.js";
20
- import { refreshAndPersistUserIdToken } from "./helper/refresh-id-token.js";
21
- import { pdStore } from "./store/mini-rx.store.js";
22
- import { setRouteElement } from "./store/spa-app-effects.js";
23
- import * as spaAppActions from "./store/spa-app-actions.js";
24
- import * as spaAppSelector from "./store/spa-app-selector.js";
25
- import * as indexDB from "./store/indexDB.js";
26
- import { templates } from "./generated/locale-wrapper/be-wrapper.js";
27
- import { templates as templates2 } from "./generated/locale-wrapper/de-wrapper.js";
28
- import { templates as templates3 } from "./generated/locale-wrapper/en-wrapper.js";
29
- const dispatchToastEvent = (element, txt, isSuccess, isError) => {
30
- element.dispatchEvent(
31
- new CustomEvent("toast-event", {
32
- detail: {
33
- txt,
34
- isSuccess,
35
- isError
36
- },
37
- bubbles: true,
38
- composed: true
39
- })
40
- );
41
- };
42
- export {
43
- ABORT_EVENT_NAME,
44
- DefaultConfirmPopup,
45
- DefaultDialogPopup,
46
- DefaultPopup,
47
- DefaultStepAddress,
48
- DefaultStepSummary,
49
- DefaultViewPage,
50
- DefaultWizard,
51
- PdDefaultWizardStep,
52
- PdSpaHelper,
53
- STORE_EVENT_NAME,
54
- activateCollectionListener,
55
- templates as beTemplaes,
56
- callFunctionImpl,
57
- createLogger,
58
- templates2 as deTemplaes,
59
- defaultLogger,
60
- deleteFile,
61
- dispatchToastEvent,
62
- downloadFile,
63
- templates3 as enTemplaes,
64
- getApp,
65
- getMessagingImpl,
66
- getStorageConfiguration,
67
- getStorageFile,
68
- getStorageFileList,
69
- getUser,
70
- getUserIdToken,
71
- isAuthenticatedImpl,
72
- loginImpl,
73
- logoutImpl,
74
- spaAppActions as pdAction,
75
- indexDB as pdDB,
76
- dateHelper as pdDateHelper,
77
- blobHelper as pdFileHelper,
78
- numberHelper as pdNumberHelper,
79
- offlineWatcherHelper as pdOfflineWatcher,
80
- priceHelper as pdPriceHelper,
81
- spaAppSelector as pdSelector,
82
- serviceProviderModel as pdSpaModel,
83
- spaModel as pdSpaModel2,
84
- pdStore,
85
- textHelper as pdTextHelper,
86
- refreshAndPersistUserIdToken,
87
- registerAppDeviceForNotification,
88
- setRouteElement,
89
- startInit,
90
- uploadFile
91
- };
1
+ export { PdSpaHelper, startInit } from './components/pd-spa-helper/PdSpaHelper.js';
2
+ export { PdSectionPage } from './components/pd-section-page/PdSectionPage.js';
3
+ export { createLogger, defaultLogger } from './helper/logger.js';
4
+ export { refreshAndPersistUserIdToken } from './helper/refresh-id-token.js';
5
+ import * as offlineWatcherHelper from './helper/offline-watcher-helper.js';
6
+ export { offlineWatcherHelper as offlineWatcher };
7
+ export { ServiceRegistry, services } from './service-provider/ServiceRegistry.js';
8
+ export { BusinessError, SC_INVALID_USER, SC_TECHNICAL_FAILURE } from './service-provider/service-provider-model.js';
9
+ export { extractErrorInfo, isBusinessError, validateFunctionResult, validateResult } from './service-provider/function-utils.js';
10
+ export { initializeStore, pdStore } from './store/mini-rx.store.js';
11
+ export { setRouteElement } from './store/spa-app-effects.js';
12
+ import * as spaAppActions from './store/spa-app-actions.js';
13
+ export { spaAppActions as SpaActions };
14
+ export { addLoadingState, loginSuccess, logoutSuccess, removeLoadingState, routeAction } from './store/spa-app-actions.js';
15
+ import * as spaAppSelector from './store/spa-app-selector.js';
16
+ export { spaAppSelector as SpaSelectors };
17
+ export { getLoadingSelector, getOfflineSelector, selectAuthUser } from './store/spa-app-selector.js';
18
+ export { createAsyncAction, createAsyncActionGroup, getConfigForAction, isActionFromGroup } from './store/async-action-utils.js';
19
+ export { createAllLoadingEffects, createErrorToastEffect, createLoadingEffect, createRemoveLoadingEffect, createSuccessToastEffect } from './store/async-action-effects.js';
20
+ export { POST_LOGIN_REDIRECT_KEY, pdRouterService } from './router/PdRouterService.js';
21
+ export { USER_COLLECTION, add, addAll, deleteAll, deleteAllEl, get, getAll, getAllIds, initDB, removeDatabase, update, updateAll } from './db/indexDB.js';
22
+ export { APP_CONF_EVENT, UNDEF } from './model/spa-model.js';
23
+ export { getCurrentUser, getUserClaims, getUserEmail, getUserId, hasAllRoles, hasAnyRole, hasRole, isLoggedIn } from './auth/auth-utils.js';
24
+ export { AuthController } from './auth/AuthController.js';
25
+ export { ifAuth, ifNotAuth, ifRole } from './auth/auth-directives.js';
26
+ export { screenSizeService } from './screen-size/ScreenSizeService.js';
27
+ export { ScreenSizeController } from './screen-size/ScreenSizeController.js';
28
+ export { responsiveText, responsiveValue } from './screen-size/responsive-directives.js';
29
+ export { fireOnceService } from './services/fire-once-service.js';
30
+ export { templates as beTemplates } from './generated/locale-wrapper/be-wrapper.js';
31
+ export { templates as deTemplates } from './generated/locale-wrapper/de-wrapper.js';
32
+ export { templates as enTemplates } from './generated/locale-wrapper/en-wrapper.js';
@@ -0,0 +1,4 @@
1
+ export { APP_CONF_EVENT, UNDEF } from './spa-model.js';
2
+ export type { AppUser } from './spa-model.js';
3
+ export type { LoadingState, LoadingSubTask, } from '@progressive-development/pd-content';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/model/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAEvD,YAAY,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAG9C,YAAY,EACV,YAAY,EACZ,cAAc,GACf,MAAM,qCAAqC,CAAC"}
@@ -1,24 +1,23 @@
1
1
  export declare const APP_CONF_EVENT = "get-app-conf";
2
2
  export declare const UNDEF = "UNDEF";
3
+ /**
4
+ * Minimal auth user interface for both Firebase and Mock providers.
5
+ * Used for auth state change callbacks.
6
+ */
7
+ export interface AuthUser {
8
+ uid: string;
9
+ email?: string | null;
10
+ displayName?: string | null;
11
+ emailVerified?: boolean;
12
+ }
13
+ /**
14
+ * Application user with claims after successful login.
15
+ */
3
16
  export interface AppUser {
4
17
  uid: string;
5
18
  email: string | null;
6
19
  emailVerified: boolean;
7
20
  providerId: string;
8
- claims: Record<string, any>;
9
- }
10
- export interface LoadingSubTask {
11
- actionKey: string;
12
- completed: boolean;
13
- loadingTxt: string;
14
- }
15
- export interface LoadingState {
16
- creation?: Date;
17
- isLoading: boolean;
18
- actionKey: string;
19
- modal?: boolean;
20
- smallBackground?: boolean;
21
- loadingTxt?: string;
22
- subTask?: LoadingSubTask[];
21
+ claims: Record<string, unknown>;
23
22
  }
24
23
  //# sourceMappingURL=spa-model.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"spa-model.d.ts","sourceRoot":"","sources":["../../src/model/spa-model.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,cAAc,iBAAiB,CAAC;AAE7C,eAAO,MAAM,KAAK,UAAU,CAAC;AAE7B,MAAM,WAAW,OAAO;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,aAAa,EAAE,OAAO,CAAC;IACvB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAC7B;AAED,MAAM,WAAW,cAAc;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,OAAO,CAAC;IACnB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,YAAY;IAC3B,QAAQ,CAAC,EAAE,IAAI,CAAC;IAChB,SAAS,EAAE,OAAO,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,cAAc,EAAE,CAAC;CAC5B"}
1
+ {"version":3,"file":"spa-model.d.ts","sourceRoot":"","sources":["../../src/model/spa-model.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,cAAc,iBAAiB,CAAC;AAE7C,eAAO,MAAM,KAAK,UAAU,CAAC;AAE7B;;;GAGG;AACH,MAAM,WAAW,QAAQ;IACvB,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB;AAED;;GAEG;AACH,MAAM,WAAW,OAAO;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,aAAa,EAAE,OAAO,CAAC;IACvB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACjC"}
@@ -1,6 +1,4 @@
1
1
  const APP_CONF_EVENT = "get-app-conf";
2
2
  const UNDEF = "UNDEF";
3
- export {
4
- APP_CONF_EVENT,
5
- UNDEF
6
- };
3
+
4
+ export { APP_CONF_EVENT, UNDEF };
@@ -1,9 +1,12 @@
1
1
  import { RouteChangeInfo, RouteDefinition } from './rout-types.js';
2
+ export declare const POST_LOGIN_REDIRECT_KEY = "postLoginRedirect";
2
3
  type RouteChangeHandler = (info: RouteChangeInfo) => void;
3
4
  declare class PdRouterService {
4
5
  private router;
5
6
  private onChangeHandlers;
6
- private currentRoute;
7
+ private _currentRoute;
8
+ private _previousRoute;
9
+ get previousRoute(): string;
7
10
  constructor();
8
11
  /**
9
12
  * Setzt die Routen-Konfiguration. Muss vor Verwendung von navigate() aufgerufen werden.
@@ -1 +1 @@
1
- {"version":3,"file":"PdRouterService.d.ts","sourceRoot":"","sources":["../../src/router/PdRouterService.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAMnE,KAAK,kBAAkB,GAAG,CAAC,IAAI,EAAE,eAAe,KAAK,IAAI,CAAC;AAE1D,cAAM,eAAe;IACnB,OAAO,CAAC,MAAM,CAAqC;IAEnD,OAAO,CAAC,gBAAgB,CAA4B;IAEpD,OAAO,CAAC,YAAY,CAAc;;IAQlC;;OAEG;IACI,eAAe,CAAC,WAAW,EAAE,eAAe,EAAE;IAgErD;;OAEG;IACU,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,UAAQ;IAejD;;OAEG;IACI,aAAa,CAAC,OAAO,EAAE,kBAAkB;IAIhD;;OAEG;YACW,OAAO;CAwDtB;AAaD,eAAO,MAAM,eAAe,iBAAwB,CAAC"}
1
+ {"version":3,"file":"PdRouterService.d.ts","sourceRoot":"","sources":["../../src/router/PdRouterService.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAKnE,eAAO,MAAM,uBAAuB,sBAAsB,CAAC;AAI3D,KAAK,kBAAkB,GAAG,CAAC,IAAI,EAAE,eAAe,KAAK,IAAI,CAAC;AAmB1D,cAAM,eAAe;IAEnB,OAAO,CAAC,MAAM,CAAmD;IAEjE,OAAO,CAAC,gBAAgB,CAA4B;IAEpD,OAAO,CAAC,aAAa,CAAc;IACnC,OAAO,CAAC,cAAc,CAAc;IAEpC,IAAW,aAAa,IAAI,MAAM,CAEjC;;IAQD;;OAEG;IACI,eAAe,CAAC,WAAW,EAAE,eAAe,EAAE;IAiFrD;;OAEG;IACU,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,UAAQ;IAejD;;OAEG;IACI,aAAa,CAAC,OAAO,EAAE,kBAAkB;IAIhD;;OAEG;YACW,OAAO;CAiEtB;AAaD,eAAO,MAAM,eAAe,iBAAwB,CAAC"}
@@ -1,18 +1,25 @@
1
- import UniversalRouter from "universal-router";
2
- import { firstValueFrom, first, filter } from "rxjs";
3
- import { selectAuthUser } from "../store/spa-app-selector.js";
4
- import { pdStore } from "../store/mini-rx.store.js";
5
- import { createLogger } from "../helper/logger.js";
1
+ import UniversalRouter from 'universal-router';
2
+ import { firstValueFrom, first, filter } from 'rxjs';
3
+ import { selectAuthUser } from '../store/spa-app-selector.js';
4
+ import { pdStore } from '../store/mini-rx.store.js';
5
+ import { createLogger } from '../helper/logger.js';
6
+
7
+ const POST_LOGIN_REDIRECT_KEY = "postLoginRedirect";
6
8
  const routingLogger = createLogger("PdRouterService");
7
9
  class PdRouterService {
8
10
  constructor() {
11
+ // UniversalRouter generic typing is complex; using explicit result type
9
12
  this.router = null;
10
13
  this.onChangeHandlers = [];
11
- this.currentRoute = "";
14
+ this._currentRoute = "";
15
+ this._previousRoute = "";
12
16
  window.addEventListener("popstate", () => {
13
17
  this.resolve(location.pathname + location.search);
14
18
  });
15
19
  }
20
+ get previousRoute() {
21
+ return this._previousRoute;
22
+ }
16
23
  /**
17
24
  * Setzt die Routen-Konfiguration. Muss vor Verwendung von navigate() aufgerufen werden.
18
25
  */
@@ -24,28 +31,36 @@ class PdRouterService {
24
31
  const universalRoutes = definitions.flatMap((def) => {
25
32
  return {
26
33
  path: def.pattern,
34
+ // Context type from UniversalRouter extended with userCheck
27
35
  action: async (context) => {
28
- var _a, _b;
29
- if (def.auth) {
30
- let authResult;
31
- if (!((_a = context.userCheck) == null ? void 0 : _a.loginCheckFinish)) {
36
+ const requiresAuth = def.auth || def.roles && def.roles.length > 0;
37
+ if (requiresAuth) {
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
- if (!((_b = context.userCheck) == null ? void 0 : _b.user)) {
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) => {
44
- var _a2;
45
- return ((_a2 = context.userCheck.user.claims) == null ? void 0 : _a2[role]) === true;
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" };
46
63
  }
47
- )) {
48
- return { redirect: "unauthorized" };
49
64
  }
50
65
  if (def.action) {
51
66
  const result = await def.action();
@@ -95,10 +110,6 @@ class PdRouterService {
95
110
  const pathname = url.pathname;
96
111
  const query = Object.fromEntries(url.searchParams.entries());
97
112
  try {
98
- routingLogger.debug(
99
- "Bevore resolve current location:",
100
- location.pathname
101
- );
102
113
  const userCheck = await firstValueFrom(
103
114
  pdStore().select(selectAuthUser).pipe(first())
104
115
  );
@@ -106,12 +117,16 @@ class PdRouterService {
106
117
  pathname,
107
118
  userCheck
108
119
  });
120
+ if (!result) {
121
+ routingLogger.warn("No route result for path:", path);
122
+ return;
123
+ }
109
124
  if (result.redirect) {
110
125
  history.replaceState({}, "", result.redirect);
111
126
  await this.resolve(result.redirect);
112
127
  return;
113
128
  }
114
- if (!result || typeof result !== "object" || !result.route) {
129
+ if (typeof result !== "object" || !result.route) {
115
130
  routingLogger.warn("Invalid route result:", result);
116
131
  return;
117
132
  }
@@ -121,7 +136,13 @@ class PdRouterService {
121
136
  params: result.params ?? {},
122
137
  query
123
138
  };
124
- 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;
125
146
  this.onChangeHandlers.forEach((fn) => fn(routeInfo));
126
147
  } catch (err) {
127
148
  routingLogger.error("Routing error:", err);
@@ -137,6 +158,5 @@ async function waitForFinalAuthState() {
137
158
  );
138
159
  }
139
160
  const pdRouterService = new PdRouterService();
140
- export {
141
- pdRouterService
142
- };
161
+
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"}