piral-core 1.0.0-pre.2296 → 1.0.1-beta.5640

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 (672) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +12 -4
  3. package/app.codegen +36 -0
  4. package/app.codegen.d.ts +29 -0
  5. package/dist/codegen.js +5308 -0
  6. package/esm/Piral.d.ts +4 -4
  7. package/esm/Piral.js +8 -11
  8. package/esm/Piral.js.map +1 -1
  9. package/esm/PiralContext.d.ts +21 -0
  10. package/esm/PiralContext.js +34 -0
  11. package/esm/PiralContext.js.map +1 -0
  12. package/esm/RootListener.d.ts +2 -0
  13. package/esm/RootListener.js +23 -0
  14. package/esm/RootListener.js.map +1 -0
  15. package/esm/actions/app.d.ts +7 -4
  16. package/esm/actions/app.js +24 -14
  17. package/esm/actions/app.js.map +1 -1
  18. package/esm/actions/components.js +5 -6
  19. package/esm/actions/components.js.map +1 -1
  20. package/esm/actions/data.js +16 -17
  21. package/esm/actions/data.js.map +1 -1
  22. package/esm/actions/define.js +2 -3
  23. package/esm/actions/define.js.map +1 -1
  24. package/esm/actions/portal.d.ts +2 -0
  25. package/esm/actions/portal.js +9 -4
  26. package/esm/actions/portal.js.map +1 -1
  27. package/esm/actions/state.js +7 -4
  28. package/esm/actions/state.js.map +1 -1
  29. package/esm/components/ErrorBoundary.d.ts +14 -31
  30. package/esm/components/ErrorBoundary.js +22 -28
  31. package/esm/components/ErrorBoundary.js.map +1 -1
  32. package/esm/components/ExtensionSlot.d.ts +1 -0
  33. package/esm/components/ExtensionSlot.js +34 -11
  34. package/esm/components/ExtensionSlot.js.map +1 -1
  35. package/esm/components/ForeignComponentContainer.d.ts +19 -0
  36. package/esm/components/ForeignComponentContainer.js +46 -0
  37. package/esm/components/ForeignComponentContainer.js.map +1 -0
  38. package/esm/components/Mediator.js +15 -12
  39. package/esm/components/Mediator.js.map +1 -1
  40. package/esm/components/PiralGlobals.d.ts +6 -0
  41. package/esm/components/PiralGlobals.js +13 -0
  42. package/esm/components/PiralGlobals.js.map +1 -0
  43. package/esm/components/PiralRoutes.d.ts +5 -0
  44. package/esm/components/PiralRoutes.js +6 -11
  45. package/esm/components/PiralRoutes.js.map +1 -1
  46. package/esm/components/PiralSuspense.d.ts +5 -0
  47. package/esm/components/PiralSuspense.js +8 -0
  48. package/esm/components/PiralSuspense.js.map +1 -0
  49. package/esm/components/PiralView.d.ts +10 -1
  50. package/esm/components/PiralView.js +12 -25
  51. package/esm/components/PiralView.js.map +1 -1
  52. package/esm/components/PortalRenderer.d.ts +5 -0
  53. package/esm/components/PortalRenderer.js +7 -0
  54. package/esm/components/PortalRenderer.js.map +1 -0
  55. package/esm/components/ResponsiveLayout.d.ts +9 -1
  56. package/esm/components/ResponsiveLayout.js +5 -13
  57. package/esm/components/ResponsiveLayout.js.map +1 -1
  58. package/esm/components/SwitchErrorInfo.js +12 -10
  59. package/esm/components/SwitchErrorInfo.js.map +1 -1
  60. package/esm/components/components.d.ts +18 -6
  61. package/esm/components/components.js +21 -9
  62. package/esm/components/components.js.map +1 -1
  63. package/esm/components/index.d.ts +4 -10
  64. package/esm/components/index.js +4 -10
  65. package/esm/components/index.js.map +1 -1
  66. package/esm/components/wrapComponent.d.ts +7 -0
  67. package/esm/components/wrapComponent.js +42 -0
  68. package/esm/components/wrapComponent.js.map +1 -0
  69. package/esm/createInstance.d.ts +2 -2
  70. package/esm/createInstance.js +34 -30
  71. package/esm/createInstance.js.map +1 -1
  72. package/esm/defaults/DefaultErrorInfo.js +10 -0
  73. package/esm/defaults/DefaultErrorInfo.js.map +1 -0
  74. package/esm/{components → defaults}/DefaultLayout.js +1 -4
  75. package/esm/defaults/DefaultLayout.js.map +1 -0
  76. package/esm/{components/DefaultLoader.js → defaults/DefaultLoadingIndicator.js} +2 -2
  77. package/esm/defaults/DefaultLoadingIndicator.js.map +1 -0
  78. package/esm/defaults/DefaultRouteSwitch_v5.d.ts +3 -0
  79. package/esm/defaults/DefaultRouteSwitch_v5.js +11 -0
  80. package/esm/defaults/DefaultRouteSwitch_v5.js.map +1 -0
  81. package/esm/defaults/DefaultRouteSwitch_v6.d.ts +3 -0
  82. package/esm/defaults/DefaultRouteSwitch_v6.js +15 -0
  83. package/esm/defaults/DefaultRouteSwitch_v6.js.map +1 -0
  84. package/esm/defaults/DefaultRouter_v5.d.ts +3 -0
  85. package/esm/defaults/DefaultRouter_v5.js +7 -0
  86. package/esm/defaults/DefaultRouter_v5.js.map +1 -0
  87. package/esm/defaults/DefaultRouter_v6.d.ts +3 -0
  88. package/esm/defaults/DefaultRouter_v6.js +7 -0
  89. package/esm/defaults/DefaultRouter_v6.js.map +1 -0
  90. package/esm/defaults/navigator_none.d.ts +5 -0
  91. package/esm/defaults/navigator_none.js +30 -0
  92. package/esm/defaults/navigator_none.js.map +1 -0
  93. package/esm/defaults/navigator_v5.d.ts +6 -0
  94. package/esm/defaults/navigator_v5.js +81 -0
  95. package/esm/defaults/navigator_v5.js.map +1 -0
  96. package/esm/defaults/navigator_v6.d.ts +6 -0
  97. package/esm/defaults/navigator_v6.js +77 -0
  98. package/esm/defaults/navigator_v6.js.map +1 -0
  99. package/esm/helpers.d.ts +12 -26
  100. package/esm/helpers.js +14 -72
  101. package/esm/helpers.js.map +1 -1
  102. package/esm/hooks/action.js +2 -3
  103. package/esm/hooks/action.js.map +1 -1
  104. package/esm/hooks/actions.js +1 -1
  105. package/esm/hooks/actions.js.map +1 -1
  106. package/esm/hooks/globalState.d.ts +7 -0
  107. package/esm/hooks/globalState.js +10 -8
  108. package/esm/hooks/globalState.js.map +1 -1
  109. package/esm/hooks/index.d.ts +2 -5
  110. package/esm/hooks/index.js +2 -5
  111. package/esm/hooks/index.js.map +1 -1
  112. package/esm/hooks/media.js +8 -7
  113. package/esm/hooks/media.js.map +1 -1
  114. package/esm/hooks/piletApi.d.ts +7 -0
  115. package/esm/hooks/piletApi.js +14 -0
  116. package/esm/hooks/piletApi.js.map +1 -0
  117. package/esm/hooks/routes.d.ts +2 -0
  118. package/esm/hooks/routes.js +11 -0
  119. package/esm/hooks/routes.js.map +1 -0
  120. package/esm/hooks/setter.js +3 -2
  121. package/esm/hooks/setter.js.map +1 -1
  122. package/esm/hooks/sharedData.js +2 -2
  123. package/esm/hooks/sharedData.js.map +1 -1
  124. package/esm/index.d.ts +3 -1
  125. package/esm/index.js +3 -1
  126. package/esm/index.js.map +1 -1
  127. package/esm/modules/api.d.ts +2 -5
  128. package/esm/modules/api.js +9 -69
  129. package/esm/modules/api.js.map +1 -1
  130. package/esm/modules/core.d.ts +3 -0
  131. package/esm/modules/core.js +50 -0
  132. package/esm/modules/core.js.map +1 -0
  133. package/esm/modules/dependencies.d.ts +5 -6
  134. package/esm/modules/dependencies.js +9 -24
  135. package/esm/modules/dependencies.js.map +1 -1
  136. package/esm/modules/element.d.ts +5 -0
  137. package/esm/modules/element.js +169 -0
  138. package/esm/modules/element.js.map +1 -0
  139. package/esm/modules/index.d.ts +1 -0
  140. package/esm/modules/index.js +1 -0
  141. package/esm/modules/index.js.map +1 -1
  142. package/esm/setters/SetComponent.js +11 -0
  143. package/esm/setters/SetComponent.js.map +1 -0
  144. package/esm/setters/SetError.js +11 -0
  145. package/esm/setters/SetError.js.map +1 -0
  146. package/esm/setters/SetErrors.js +9 -0
  147. package/esm/setters/SetErrors.js.map +1 -0
  148. package/esm/setters/SetLayout.js +9 -0
  149. package/esm/setters/SetLayout.js.map +1 -0
  150. package/esm/setters/SetProvider.js +11 -0
  151. package/esm/setters/SetProvider.js.map +1 -0
  152. package/esm/setters/SetRedirect.js +12 -0
  153. package/esm/setters/SetRedirect.js.map +1 -0
  154. package/{lib/components → esm/setters}/SetRoute.d.ts +6 -2
  155. package/esm/setters/SetRoute.js +11 -0
  156. package/esm/setters/SetRoute.js.map +1 -0
  157. package/esm/setters/index.d.ts +7 -0
  158. package/esm/setters/index.js +8 -0
  159. package/esm/setters/index.js.map +1 -0
  160. package/esm/state/createActions.d.ts +2 -2
  161. package/esm/state/createActions.js +8 -12
  162. package/esm/state/createActions.js.map +1 -1
  163. package/esm/state/createGlobalState.d.ts +1 -2
  164. package/esm/state/createGlobalState.js +9 -34
  165. package/esm/state/createGlobalState.js.map +1 -1
  166. package/esm/state/stateContext.js +1 -1
  167. package/esm/state/stateContext.js.map +1 -1
  168. package/esm/state/withApi.d.ts +1 -1
  169. package/esm/state/withApi.js +19 -104
  170. package/esm/state/withApi.js.map +1 -1
  171. package/esm/tools/codegen.d.ts +21 -0
  172. package/esm/tools/codegen.js +145 -0
  173. package/esm/tools/codegen.js.map +1 -0
  174. package/esm/tools/debugger.d.ts +4 -0
  175. package/esm/tools/debugger.js +54 -0
  176. package/esm/tools/debugger.js.map +1 -0
  177. package/esm/tools/emulator.d.ts +3 -0
  178. package/esm/tools/emulator.js +11 -0
  179. package/esm/tools/emulator.js.map +1 -0
  180. package/esm/types/api.d.ts +34 -9
  181. package/esm/types/common.d.ts +11 -11
  182. package/esm/types/components.d.ts +74 -8
  183. package/esm/types/config.d.ts +24 -17
  184. package/esm/types/data.d.ts +2 -2
  185. package/esm/types/extension.d.ts +31 -4
  186. package/esm/types/index.d.ts +1 -0
  187. package/esm/types/index.js +1 -0
  188. package/esm/types/index.js.map +1 -1
  189. package/esm/types/instance.d.ts +26 -4
  190. package/esm/types/layout.d.ts +3 -3
  191. package/esm/types/navigation.d.ts +94 -0
  192. package/esm/types/navigation.js +2 -0
  193. package/esm/types/navigation.js.map +1 -0
  194. package/esm/types/plugin.d.ts +1 -14
  195. package/esm/types/state.d.ts +66 -27
  196. package/esm/types/utils.d.ts +1 -1
  197. package/esm/utils/compare.d.ts +1 -1
  198. package/esm/utils/compare.js +24 -7
  199. package/esm/utils/compare.js.map +1 -1
  200. package/esm/utils/data.js +6 -7
  201. package/esm/utils/data.js.map +1 -1
  202. package/esm/utils/extension.d.ts +16 -0
  203. package/esm/utils/extension.js +37 -0
  204. package/esm/utils/extension.js.map +1 -0
  205. package/esm/utils/foreign.d.ts +7 -2
  206. package/esm/utils/foreign.js +20 -9
  207. package/esm/utils/foreign.js.map +1 -1
  208. package/esm/utils/guid.js +3 -3
  209. package/esm/utils/guid.js.map +1 -1
  210. package/esm/utils/helpers.d.ts +11 -8
  211. package/esm/utils/helpers.js +29 -18
  212. package/esm/utils/helpers.js.map +1 -1
  213. package/esm/utils/index.d.ts +3 -1
  214. package/esm/utils/index.js +3 -1
  215. package/esm/utils/index.js.map +1 -1
  216. package/esm/utils/media.js +8 -8
  217. package/esm/utils/media.js.map +1 -1
  218. package/esm/utils/state.d.ts +57 -0
  219. package/esm/utils/state.js +83 -0
  220. package/esm/utils/state.js.map +1 -0
  221. package/esm/utils/storage.js +13 -14
  222. package/esm/utils/storage.js.map +1 -1
  223. package/lib/Piral.d.ts +4 -4
  224. package/lib/Piral.js +11 -13
  225. package/lib/Piral.js.map +1 -1
  226. package/lib/PiralContext.d.ts +21 -0
  227. package/lib/PiralContext.js +38 -0
  228. package/lib/PiralContext.js.map +1 -0
  229. package/lib/RootListener.d.ts +2 -0
  230. package/lib/RootListener.js +27 -0
  231. package/lib/RootListener.js.map +1 -0
  232. package/lib/actions/app.d.ts +7 -4
  233. package/lib/actions/app.js +27 -16
  234. package/lib/actions/app.js.map +1 -1
  235. package/lib/actions/components.js +5 -6
  236. package/lib/actions/components.js.map +1 -1
  237. package/lib/actions/data.js +17 -18
  238. package/lib/actions/data.js.map +1 -1
  239. package/lib/actions/define.js +2 -3
  240. package/lib/actions/define.js.map +1 -1
  241. package/lib/actions/index.js +1 -1
  242. package/lib/actions/portal.d.ts +2 -0
  243. package/lib/actions/portal.js +12 -5
  244. package/lib/actions/portal.js.map +1 -1
  245. package/lib/actions/state.js +7 -4
  246. package/lib/actions/state.js.map +1 -1
  247. package/lib/components/ErrorBoundary.d.ts +14 -31
  248. package/lib/components/ErrorBoundary.js +23 -28
  249. package/lib/components/ErrorBoundary.js.map +1 -1
  250. package/lib/components/ExtensionSlot.d.ts +1 -0
  251. package/lib/components/ExtensionSlot.js +37 -14
  252. package/lib/components/ExtensionSlot.js.map +1 -1
  253. package/lib/components/ForeignComponentContainer.d.ts +19 -0
  254. package/lib/components/ForeignComponentContainer.js +50 -0
  255. package/lib/components/ForeignComponentContainer.js.map +1 -0
  256. package/lib/components/Mediator.js +18 -14
  257. package/lib/components/Mediator.js.map +1 -1
  258. package/lib/components/PiralGlobals.d.ts +6 -0
  259. package/lib/components/PiralGlobals.js +17 -0
  260. package/lib/components/PiralGlobals.js.map +1 -0
  261. package/lib/components/PiralRoutes.d.ts +5 -0
  262. package/lib/components/PiralRoutes.js +8 -12
  263. package/lib/components/PiralRoutes.js.map +1 -1
  264. package/lib/components/PiralSuspense.d.ts +5 -0
  265. package/lib/components/PiralSuspense.js +12 -0
  266. package/lib/components/PiralSuspense.js.map +1 -0
  267. package/lib/components/PiralView.d.ts +10 -1
  268. package/lib/components/PiralView.js +15 -27
  269. package/lib/components/PiralView.js.map +1 -1
  270. package/lib/components/PortalRenderer.d.ts +5 -0
  271. package/lib/components/PortalRenderer.js +11 -0
  272. package/lib/components/PortalRenderer.js.map +1 -0
  273. package/lib/components/ResponsiveLayout.d.ts +9 -1
  274. package/lib/components/ResponsiveLayout.js +7 -14
  275. package/lib/components/ResponsiveLayout.js.map +1 -1
  276. package/lib/components/SwitchErrorInfo.js +15 -12
  277. package/lib/components/SwitchErrorInfo.js.map +1 -1
  278. package/lib/components/components.d.ts +18 -6
  279. package/lib/components/components.js +24 -12
  280. package/lib/components/components.js.map +1 -1
  281. package/lib/components/index.d.ts +4 -10
  282. package/lib/components/index.js +5 -11
  283. package/lib/components/index.js.map +1 -1
  284. package/lib/components/wrapComponent.d.ts +7 -0
  285. package/lib/components/wrapComponent.js +46 -0
  286. package/lib/components/wrapComponent.js.map +1 -0
  287. package/lib/createInstance.d.ts +2 -2
  288. package/lib/createInstance.js +40 -36
  289. package/lib/createInstance.js.map +1 -1
  290. package/lib/defaults/DefaultErrorInfo.js +14 -0
  291. package/lib/defaults/DefaultErrorInfo.js.map +1 -0
  292. package/lib/{components → defaults}/DefaultLayout.js +3 -5
  293. package/lib/defaults/DefaultLayout.js.map +1 -0
  294. package/lib/{components/DefaultLoader.js → defaults/DefaultLoadingIndicator.js} +4 -3
  295. package/lib/defaults/DefaultLoadingIndicator.js.map +1 -0
  296. package/lib/defaults/DefaultRouteSwitch_v5.d.ts +3 -0
  297. package/lib/defaults/DefaultRouteSwitch_v5.js +15 -0
  298. package/lib/defaults/DefaultRouteSwitch_v5.js.map +1 -0
  299. package/lib/defaults/DefaultRouteSwitch_v6.d.ts +3 -0
  300. package/lib/defaults/DefaultRouteSwitch_v6.js +19 -0
  301. package/lib/defaults/DefaultRouteSwitch_v6.js.map +1 -0
  302. package/lib/defaults/DefaultRouter_v5.d.ts +3 -0
  303. package/lib/defaults/DefaultRouter_v5.js +11 -0
  304. package/lib/defaults/DefaultRouter_v5.js.map +1 -0
  305. package/lib/defaults/DefaultRouter_v6.d.ts +3 -0
  306. package/lib/defaults/DefaultRouter_v6.js +11 -0
  307. package/lib/defaults/DefaultRouter_v6.js.map +1 -0
  308. package/lib/defaults/navigator_none.d.ts +5 -0
  309. package/lib/defaults/navigator_none.js +37 -0
  310. package/lib/defaults/navigator_none.js.map +1 -0
  311. package/lib/defaults/navigator_v5.d.ts +6 -0
  312. package/lib/defaults/navigator_v5.js +88 -0
  313. package/lib/defaults/navigator_v5.js.map +1 -0
  314. package/lib/defaults/navigator_v6.d.ts +6 -0
  315. package/lib/defaults/navigator_v6.js +84 -0
  316. package/lib/defaults/navigator_v6.js.map +1 -0
  317. package/lib/helpers.d.ts +12 -26
  318. package/lib/helpers.js +15 -75
  319. package/lib/helpers.js.map +1 -1
  320. package/lib/hooks/action.js +2 -3
  321. package/lib/hooks/action.js.map +1 -1
  322. package/lib/hooks/actions.js +4 -4
  323. package/lib/hooks/actions.js.map +1 -1
  324. package/lib/hooks/globalState.d.ts +7 -0
  325. package/lib/hooks/globalState.js +14 -11
  326. package/lib/hooks/globalState.js.map +1 -1
  327. package/lib/hooks/index.d.ts +2 -5
  328. package/lib/hooks/index.js +3 -6
  329. package/lib/hooks/index.js.map +1 -1
  330. package/lib/hooks/media.js +10 -9
  331. package/lib/hooks/media.js.map +1 -1
  332. package/lib/hooks/piletApi.d.ts +7 -0
  333. package/lib/hooks/piletApi.js +18 -0
  334. package/lib/hooks/piletApi.js.map +1 -0
  335. package/lib/hooks/routes.d.ts +2 -0
  336. package/lib/hooks/routes.js +15 -0
  337. package/lib/hooks/routes.js.map +1 -0
  338. package/lib/hooks/setter.js +4 -3
  339. package/lib/hooks/setter.js.map +1 -1
  340. package/lib/hooks/sharedData.js +3 -3
  341. package/lib/hooks/sharedData.js.map +1 -1
  342. package/lib/index.d.ts +3 -1
  343. package/lib/index.js +4 -2
  344. package/lib/index.js.map +1 -1
  345. package/lib/modules/api.d.ts +2 -5
  346. package/lib/modules/api.js +12 -75
  347. package/lib/modules/api.js.map +1 -1
  348. package/lib/modules/core.d.ts +3 -0
  349. package/lib/modules/core.js +54 -0
  350. package/lib/modules/core.js.map +1 -0
  351. package/lib/modules/dependencies.d.ts +5 -6
  352. package/lib/modules/dependencies.js +12 -27
  353. package/lib/modules/dependencies.js.map +1 -1
  354. package/lib/modules/element.d.ts +5 -0
  355. package/lib/modules/element.js +173 -0
  356. package/lib/modules/element.js.map +1 -0
  357. package/lib/modules/index.d.ts +1 -0
  358. package/lib/modules/index.js +2 -1
  359. package/lib/modules/index.js.map +1 -1
  360. package/lib/setters/SetComponent.js +15 -0
  361. package/lib/setters/SetComponent.js.map +1 -0
  362. package/lib/setters/SetError.js +15 -0
  363. package/lib/setters/SetError.js.map +1 -0
  364. package/lib/setters/SetErrors.js +13 -0
  365. package/lib/setters/SetErrors.js.map +1 -0
  366. package/lib/setters/SetLayout.js +13 -0
  367. package/lib/setters/SetLayout.js.map +1 -0
  368. package/lib/{components → setters}/SetProvider.js +4 -5
  369. package/lib/setters/SetProvider.js.map +1 -0
  370. package/lib/setters/SetRedirect.js +16 -0
  371. package/lib/setters/SetRedirect.js.map +1 -0
  372. package/{esm/components → lib/setters}/SetRoute.d.ts +6 -2
  373. package/lib/setters/SetRoute.js +15 -0
  374. package/lib/setters/SetRoute.js.map +1 -0
  375. package/lib/setters/index.d.ts +7 -0
  376. package/lib/setters/index.js +11 -0
  377. package/lib/setters/index.js.map +1 -0
  378. package/lib/state/createActions.d.ts +2 -2
  379. package/lib/state/createActions.js +9 -13
  380. package/lib/state/createActions.js.map +1 -1
  381. package/lib/state/createGlobalState.d.ts +1 -2
  382. package/lib/state/createGlobalState.js +9 -34
  383. package/lib/state/createGlobalState.js.map +1 -1
  384. package/lib/state/index.js +1 -1
  385. package/lib/state/stateContext.js +1 -1
  386. package/lib/state/stateContext.js.map +1 -1
  387. package/lib/state/withApi.d.ts +1 -1
  388. package/lib/state/withApi.js +20 -105
  389. package/lib/state/withApi.js.map +1 -1
  390. package/lib/tools/codegen.d.ts +21 -0
  391. package/lib/tools/codegen.js +152 -0
  392. package/lib/tools/codegen.js.map +1 -0
  393. package/lib/tools/debugger.d.ts +4 -0
  394. package/lib/tools/debugger.js +58 -0
  395. package/lib/tools/debugger.js.map +1 -0
  396. package/lib/tools/emulator.d.ts +3 -0
  397. package/lib/tools/emulator.js +15 -0
  398. package/lib/tools/emulator.js.map +1 -0
  399. package/lib/types/api.d.ts +34 -9
  400. package/lib/types/common.d.ts +11 -11
  401. package/lib/types/components.d.ts +74 -8
  402. package/lib/types/config.d.ts +24 -17
  403. package/lib/types/data.d.ts +2 -2
  404. package/lib/types/extension.d.ts +31 -4
  405. package/lib/types/index.d.ts +1 -0
  406. package/lib/types/index.js +2 -1
  407. package/lib/types/index.js.map +1 -1
  408. package/lib/types/instance.d.ts +26 -4
  409. package/lib/types/layout.d.ts +3 -3
  410. package/lib/types/navigation.d.ts +94 -0
  411. package/lib/types/navigation.js +3 -0
  412. package/lib/types/navigation.js.map +1 -0
  413. package/lib/types/plugin.d.ts +1 -14
  414. package/lib/types/state.d.ts +66 -27
  415. package/lib/types/utils.d.ts +1 -1
  416. package/lib/utils/compare.d.ts +1 -1
  417. package/lib/utils/compare.js +26 -9
  418. package/lib/utils/compare.js.map +1 -1
  419. package/lib/utils/data.js +6 -7
  420. package/lib/utils/data.js.map +1 -1
  421. package/lib/utils/extension.d.ts +16 -0
  422. package/lib/utils/extension.js +42 -0
  423. package/lib/utils/extension.js.map +1 -0
  424. package/lib/utils/foreign.d.ts +7 -2
  425. package/lib/utils/foreign.js +25 -12
  426. package/lib/utils/foreign.js.map +1 -1
  427. package/lib/utils/guid.js +3 -3
  428. package/lib/utils/guid.js.map +1 -1
  429. package/lib/utils/helpers.d.ts +11 -8
  430. package/lib/utils/helpers.js +31 -18
  431. package/lib/utils/helpers.js.map +1 -1
  432. package/lib/utils/index.d.ts +3 -1
  433. package/lib/utils/index.js +7 -2
  434. package/lib/utils/index.js.map +1 -1
  435. package/lib/utils/media.js +7 -7
  436. package/lib/utils/media.js.map +1 -1
  437. package/lib/utils/react.js +1 -1
  438. package/lib/utils/react.js.map +1 -1
  439. package/lib/utils/state.d.ts +57 -0
  440. package/lib/utils/state.js +94 -0
  441. package/lib/utils/state.js.map +1 -0
  442. package/lib/utils/storage.js +11 -12
  443. package/lib/utils/storage.js.map +1 -1
  444. package/package.json +51 -20
  445. package/src/Piral.test.tsx +7 -16
  446. package/src/Piral.tsx +12 -11
  447. package/src/PiralContext.tsx +43 -0
  448. package/src/RootListener.test.tsx +46 -0
  449. package/src/RootListener.tsx +26 -0
  450. package/src/actions/app.test.ts +114 -44
  451. package/src/actions/app.ts +33 -23
  452. package/src/actions/components.test.ts +11 -11
  453. package/src/actions/components.ts +5 -33
  454. package/src/actions/data.test.ts +50 -50
  455. package/src/actions/define.test.ts +2 -2
  456. package/src/actions/portal.test.ts +62 -17
  457. package/src/actions/portal.ts +19 -1
  458. package/src/actions/state.test.ts +3 -3
  459. package/src/actions/state.ts +8 -4
  460. package/src/components/ErrorBoundary.tsx +22 -49
  461. package/src/components/ExtensionSlot.test.tsx +115 -30
  462. package/src/components/ExtensionSlot.tsx +57 -18
  463. package/src/components/ForeignComponentContainer.test.tsx +100 -0
  464. package/src/components/ForeignComponentContainer.tsx +63 -0
  465. package/src/components/Mediator.test.tsx +16 -14
  466. package/src/components/Mediator.tsx +17 -9
  467. package/src/components/PiralGlobals.tsx +16 -0
  468. package/src/components/PiralRoutes.test.tsx +65 -57
  469. package/src/components/PiralRoutes.tsx +10 -17
  470. package/src/components/PiralSuspense.tsx +19 -0
  471. package/src/components/PiralView-server.test.tsx +61 -0
  472. package/src/components/PiralView.test.tsx +27 -26
  473. package/src/components/PiralView.tsx +28 -35
  474. package/src/components/PortalRenderer.tsx +12 -0
  475. package/src/components/ResponsiveLayout.test.tsx +18 -37
  476. package/src/components/ResponsiveLayout.tsx +18 -15
  477. package/src/components/SwitchErrorInfo.test.tsx +36 -0
  478. package/src/components/SwitchErrorInfo.tsx +5 -1
  479. package/src/components/components.tsx +20 -6
  480. package/src/components/index.ts +4 -10
  481. package/src/components/wrapComponent.tsx +74 -0
  482. package/src/createInstance.test.tsx +10 -0
  483. package/src/createInstance.tsx +19 -14
  484. package/src/{components → defaults}/DefaultErrorInfo.test.tsx +15 -18
  485. package/src/{components → defaults}/DefaultErrorInfo.tsx +2 -3
  486. package/src/defaults/DefaultLayout.test.tsx +23 -0
  487. package/src/defaults/DefaultLoadingIndicator.test.tsx +10 -0
  488. package/src/defaults/DefaultRouteSwitch_v5.tsx +15 -0
  489. package/src/defaults/DefaultRouteSwitch_v6.tsx +20 -0
  490. package/src/defaults/DefaultRouter_v5.tsx +8 -0
  491. package/src/defaults/DefaultRouter_v6.tsx +8 -0
  492. package/src/defaults/navigator_none.tsx +35 -0
  493. package/src/defaults/navigator_v5.tsx +99 -0
  494. package/src/defaults/navigator_v6.tsx +96 -0
  495. package/src/helpers.test.tsx +30 -49
  496. package/src/helpers.tsx +31 -108
  497. package/src/hooks/action.ts +2 -3
  498. package/src/hooks/globalState.ts +10 -9
  499. package/src/hooks/index.ts +2 -5
  500. package/src/hooks/media.ts +2 -1
  501. package/src/hooks/piletApi.ts +14 -0
  502. package/src/hooks/routes.ts +14 -0
  503. package/src/hooks/setter-server.test.ts +22 -0
  504. package/src/hooks/setter.test.ts +18 -0
  505. package/src/hooks/setter.ts +2 -1
  506. package/src/index.tsx +3 -1
  507. package/src/modules/api.test.ts +15 -26
  508. package/src/modules/api.ts +3 -66
  509. package/src/modules/core.test.ts +148 -0
  510. package/src/modules/core.ts +52 -0
  511. package/src/modules/dependencies.test.ts +16 -5
  512. package/src/modules/dependencies.ts +13 -31
  513. package/src/modules/element-server.test.ts +29 -0
  514. package/src/modules/element.test.ts +67 -0
  515. package/src/modules/element.ts +212 -0
  516. package/src/modules/index.ts +1 -0
  517. package/src/{components → setters}/SetComponent.test.tsx +9 -8
  518. package/src/{components → setters}/SetComponent.tsx +2 -2
  519. package/src/{components → setters}/SetError.test.tsx +9 -8
  520. package/src/{components → setters}/SetError.tsx +2 -2
  521. package/src/{components → setters}/SetErrors.test.tsx +9 -8
  522. package/src/{components → setters}/SetLayout.test.tsx +9 -8
  523. package/src/{components → setters}/SetProvider.test.tsx +9 -8
  524. package/src/{components → setters}/SetProvider.tsx +2 -2
  525. package/src/{components → setters}/SetRedirect.test.tsx +9 -8
  526. package/src/{components → setters}/SetRedirect.tsx +4 -4
  527. package/src/{components → setters}/SetRoute.test.tsx +9 -8
  528. package/src/{components → setters}/SetRoute.tsx +7 -4
  529. package/src/setters/index.ts +7 -0
  530. package/src/state/createActions.test.ts +2 -2
  531. package/src/state/createActions.ts +5 -3
  532. package/src/state/createGlobalState.test.ts +55 -54
  533. package/src/state/createGlobalState.ts +4 -28
  534. package/src/state/withApi.test.tsx +87 -40
  535. package/src/state/withApi.tsx +31 -165
  536. package/src/tools/codegen.ts +193 -0
  537. package/src/tools/debugger.ts +84 -0
  538. package/src/tools/emulator.ts +13 -0
  539. package/src/types/api.ts +47 -10
  540. package/src/types/components.ts +76 -7
  541. package/src/types/config.ts +23 -17
  542. package/src/types/extension.ts +38 -5
  543. package/src/types/index.ts +1 -0
  544. package/src/types/instance.ts +28 -4
  545. package/src/types/navigation.ts +101 -0
  546. package/src/types/plugin.ts +1 -15
  547. package/src/types/state.ts +65 -25
  548. package/src/types/utils.ts +1 -1
  549. package/src/utils/compare.test.ts +15 -15
  550. package/src/utils/compare.ts +23 -3
  551. package/src/utils/extension.test.tsx +21 -0
  552. package/src/utils/extension.tsx +48 -0
  553. package/src/utils/foreign.test.ts +29 -11
  554. package/src/utils/foreign.ts +34 -7
  555. package/src/utils/guid.test.ts +6 -1
  556. package/src/utils/helpers.test.ts +52 -0
  557. package/src/utils/helpers.ts +22 -8
  558. package/src/utils/index.ts +4 -1
  559. package/src/utils/media-server.test.ts +13 -0
  560. package/src/utils/media.ts +2 -2
  561. package/src/utils/state.test.ts +37 -0
  562. package/src/utils/state.ts +131 -0
  563. package/dependencies.codegen +0 -9
  564. package/dependencies.codegen.native.js +0 -2
  565. package/esm/components/DefaultErrorInfo.js +0 -12
  566. package/esm/components/DefaultErrorInfo.js.map +0 -1
  567. package/esm/components/DefaultLayout.js.map +0 -1
  568. package/esm/components/DefaultLoader.js.map +0 -1
  569. package/esm/components/SetComponent.js +0 -12
  570. package/esm/components/SetComponent.js.map +0 -1
  571. package/esm/components/SetError.js +0 -12
  572. package/esm/components/SetError.js.map +0 -1
  573. package/esm/components/SetErrors.js +0 -10
  574. package/esm/components/SetErrors.js.map +0 -1
  575. package/esm/components/SetLayout.js +0 -10
  576. package/esm/components/SetLayout.js.map +0 -1
  577. package/esm/components/SetProvider.js +0 -12
  578. package/esm/components/SetProvider.js.map +0 -1
  579. package/esm/components/SetRedirect.js +0 -14
  580. package/esm/components/SetRedirect.js.map +0 -1
  581. package/esm/components/SetRoute.js +0 -12
  582. package/esm/components/SetRoute.js.map +0 -1
  583. package/esm/hooks/debounce.d.ts +0 -8
  584. package/esm/hooks/debounce.js +0 -18
  585. package/esm/hooks/debounce.js.map +0 -1
  586. package/esm/hooks/lockBodyScroll.d.ts +0 -6
  587. package/esm/hooks/lockBodyScroll.js +0 -13
  588. package/esm/hooks/lockBodyScroll.js.map +0 -1
  589. package/esm/hooks/onClickOutside.d.ts +0 -8
  590. package/esm/hooks/onClickOutside.js +0 -23
  591. package/esm/hooks/onClickOutside.js.map +0 -1
  592. package/esm/hooks/onScreenVisible.d.ts +0 -11
  593. package/esm/hooks/onScreenVisible.js +0 -28
  594. package/esm/hooks/onScreenVisible.js.map +0 -1
  595. package/esm/hooks/promise.d.ts +0 -13
  596. package/esm/hooks/promise.js +0 -21
  597. package/esm/hooks/promise.js.map +0 -1
  598. package/esm/utils/events.d.ts +0 -3
  599. package/esm/utils/events.js +0 -35
  600. package/esm/utils/events.js.map +0 -1
  601. package/lib/components/DefaultErrorInfo.js +0 -15
  602. package/lib/components/DefaultErrorInfo.js.map +0 -1
  603. package/lib/components/DefaultLayout.js.map +0 -1
  604. package/lib/components/DefaultLoader.js.map +0 -1
  605. package/lib/components/SetComponent.js +0 -16
  606. package/lib/components/SetComponent.js.map +0 -1
  607. package/lib/components/SetError.js +0 -16
  608. package/lib/components/SetError.js.map +0 -1
  609. package/lib/components/SetErrors.js +0 -14
  610. package/lib/components/SetErrors.js.map +0 -1
  611. package/lib/components/SetLayout.js +0 -14
  612. package/lib/components/SetLayout.js.map +0 -1
  613. package/lib/components/SetProvider.js.map +0 -1
  614. package/lib/components/SetRedirect.js +0 -18
  615. package/lib/components/SetRedirect.js.map +0 -1
  616. package/lib/components/SetRoute.js +0 -16
  617. package/lib/components/SetRoute.js.map +0 -1
  618. package/lib/hooks/debounce.d.ts +0 -8
  619. package/lib/hooks/debounce.js +0 -22
  620. package/lib/hooks/debounce.js.map +0 -1
  621. package/lib/hooks/lockBodyScroll.d.ts +0 -6
  622. package/lib/hooks/lockBodyScroll.js +0 -17
  623. package/lib/hooks/lockBodyScroll.js.map +0 -1
  624. package/lib/hooks/onClickOutside.d.ts +0 -8
  625. package/lib/hooks/onClickOutside.js +0 -27
  626. package/lib/hooks/onClickOutside.js.map +0 -1
  627. package/lib/hooks/onScreenVisible.d.ts +0 -11
  628. package/lib/hooks/onScreenVisible.js +0 -32
  629. package/lib/hooks/onScreenVisible.js.map +0 -1
  630. package/lib/hooks/promise.d.ts +0 -13
  631. package/lib/hooks/promise.js +0 -25
  632. package/lib/hooks/promise.js.map +0 -1
  633. package/lib/utils/events.d.ts +0 -3
  634. package/lib/utils/events.js +0 -39
  635. package/lib/utils/events.js.map +0 -1
  636. package/src/components/DefaultLayout.test.tsx +0 -23
  637. package/src/components/DefaultLoader.test.tsx +0 -10
  638. package/src/hooks/debounce.test.ts +0 -67
  639. package/src/hooks/debounce.ts +0 -19
  640. package/src/hooks/globalState.test.ts +0 -47
  641. package/src/hooks/lockBodyScroll.test.ts +0 -24
  642. package/src/hooks/lockBodyScroll.ts +0 -13
  643. package/src/hooks/onClickOutside.test.ts +0 -113
  644. package/src/hooks/onClickOutside.ts +0 -25
  645. package/src/hooks/onScreenVisible.test.ts +0 -68
  646. package/src/hooks/onScreenVisible.ts +0 -28
  647. package/src/hooks/promise.test.ts +0 -76
  648. package/src/hooks/promise.ts +0 -35
  649. package/src/utils/events.test.ts +0 -65
  650. package/src/utils/events.ts +0 -39
  651. package/esm/{components → defaults}/DefaultErrorInfo.d.ts +0 -0
  652. package/esm/{components → defaults}/DefaultLayout.d.ts +0 -0
  653. package/esm/{components/DefaultLoader.d.ts → defaults/DefaultLoadingIndicator.d.ts} +0 -0
  654. package/esm/{components → setters}/SetComponent.d.ts +0 -0
  655. package/esm/{components → setters}/SetError.d.ts +0 -0
  656. package/esm/{components → setters}/SetErrors.d.ts +0 -0
  657. package/esm/{components → setters}/SetLayout.d.ts +0 -0
  658. package/esm/{components → setters}/SetProvider.d.ts +0 -0
  659. package/esm/{components → setters}/SetRedirect.d.ts +0 -0
  660. package/lib/{components → defaults}/DefaultErrorInfo.d.ts +0 -0
  661. package/lib/{components → defaults}/DefaultLayout.d.ts +0 -0
  662. package/lib/{components/DefaultLoader.d.ts → defaults/DefaultLoadingIndicator.d.ts} +0 -0
  663. package/lib/{components → setters}/SetComponent.d.ts +0 -0
  664. package/lib/{components → setters}/SetError.d.ts +0 -0
  665. package/lib/{components → setters}/SetErrors.d.ts +0 -0
  666. package/lib/{components → setters}/SetLayout.d.ts +0 -0
  667. package/lib/{components → setters}/SetProvider.d.ts +0 -0
  668. package/lib/{components → setters}/SetRedirect.d.ts +0 -0
  669. package/src/{components → defaults}/DefaultLayout.tsx +1 -1
  670. /package/src/{components/DefaultLoader.tsx → defaults/DefaultLoadingIndicator.tsx} +0 -0
  671. /package/src/{components → setters}/SetErrors.tsx +0 -0
  672. /package/src/{components → setters}/SetLayout.tsx +0 -0
package/src/helpers.tsx CHANGED
@@ -1,135 +1,58 @@
1
- import { addChangeHandler } from '@dbeining/react-atom';
2
1
  import {
3
2
  PiletApiCreator,
4
3
  LoadPiletsOptions,
5
4
  CustomSpecLoaders,
6
5
  DefaultLoaderConfig,
7
- PiletDependencyFetcher,
8
- getDependencyResolver,
9
6
  getDefaultLoader,
10
7
  extendLoader,
11
8
  PiletLoader,
9
+ PiletLifecycleHooks,
12
10
  } from 'piral-base';
13
- import { globalDependencies, getLocalDependencies } from './modules';
14
- import type {
15
- AvailableDependencies,
16
- Pilet,
17
- PiletRequester,
18
- GlobalStateContext,
19
- PiletDependencyGetter,
20
- PiletLoadingStrategy,
21
- } from './types';
22
-
23
- /**
24
- * Creates a dependency getter that sets the shared dependencies explicitly.
25
- * Overrides the potentially set shared dependencies from the Piral CLI, but
26
- * keeps all global dependencies such as react, react-dom, ...
27
- * @param sharedDependencies The shared dependencies to declare.
28
- */
29
- export function setSharedDependencies(sharedDependencies: AvailableDependencies) {
30
- const dependencies = {
31
- ...globalDependencies,
32
- ...sharedDependencies,
33
- };
34
- return () => dependencies;
35
- }
36
-
37
- /**
38
- * Creates a dependency getter that extends the shared dependencies with additional dependencies.
39
- * @param additionalDependencies The additional dependencies to declare.
40
- */
41
- export function extendSharedDependencies(additionalDependencies: AvailableDependencies) {
42
- const dependencies = {
43
- ...getLocalDependencies(),
44
- ...additionalDependencies,
45
- };
46
- return () => dependencies;
47
- }
11
+ import type { DebuggerExtensionOptions } from 'piral-debug-utils';
12
+ import { globalDependencies } from './modules';
13
+ import type { Pilet, PiletRequester, GlobalStateContext, PiletLoadingStrategy, DependencySelector } from './types';
14
+ import { integrateDebugger, integrateEmulator } from '../app.codegen';
48
15
 
49
16
  export interface PiletOptionsConfig {
17
+ context: GlobalStateContext;
18
+ hooks?: PiletLifecycleHooks;
19
+ loaders?: CustomSpecLoaders;
20
+ loaderConfig?: DefaultLoaderConfig;
50
21
  availablePilets: Array<Pilet>;
51
- createApi: PiletApiCreator;
52
- fetchDependency: PiletDependencyFetcher;
53
- getDependencies: PiletDependencyGetter;
54
22
  strategy: PiletLoadingStrategy;
55
- requestPilets: PiletRequester;
56
- loaderConfig?: DefaultLoaderConfig;
57
- loaders?: CustomSpecLoaders;
23
+ createApi: PiletApiCreator;
58
24
  loadPilet: PiletLoader;
59
- context: GlobalStateContext;
25
+ requestPilets: PiletRequester;
26
+ shareDependencies: DependencySelector;
27
+ debug?: DebuggerExtensionOptions;
60
28
  }
61
29
 
62
30
  export function createPiletOptions({
31
+ hooks,
63
32
  context,
64
- createApi,
65
- availablePilets,
66
- fetchDependency,
67
- getDependencies,
33
+ loaders,
68
34
  loaderConfig,
69
- loadPilet,
35
+ availablePilets,
70
36
  strategy,
71
- loaders,
37
+ createApi,
38
+ loadPilet,
72
39
  requestPilets,
73
- }: PiletOptionsConfig): LoadPiletsOptions {
74
- getDependencies = getDependencyResolver(globalDependencies, getDependencies);
75
- loadPilet = extendLoader(loadPilet ?? getDefaultLoader(getDependencies, fetchDependency, loaderConfig), loaders);
76
-
77
- // if we build the debug version of piral (debug and emulator build)
78
- if (process.env.DEBUG_PIRAL) {
79
- const { installPiralDebug } = require('piral-debug-utils');
80
-
81
- installPiralDebug({
82
- context,
83
- createApi,
84
- getDependencies,
85
- loadPilet,
86
- requestPilets,
87
- });
88
-
89
- // we watch the state container for changes
90
- addChangeHandler(context.state, 'debugging', ({ current, previous }) => {
91
- const viewState = sessionStorage.getItem('dbg:view-state') !== 'off';
92
-
93
- if (viewState) {
94
- const infos = new Error().stack;
95
-
96
- if (infos) {
97
- // Chrome, Firefox, ... (full capability)
98
- const action = infos.split('\n')[7].replace(/^\s+at\s+(Atom\.|Object\.)?/, '');
99
- console.group(
100
- `%c Piral State Change %c ${new Date().toLocaleTimeString()}`,
101
- 'color: gray; font-weight: lighter;',
102
- 'color: black; font-weight: bold;',
103
- );
104
- console.log('%c Previous', `color: #9E9E9E; font-weight: bold`, previous);
105
- console.log('%c Action', `color: #03A9F4; font-weight: bold`, action);
106
- console.log('%c Next', `color: #4CAF50; font-weight: bold`, current);
107
- console.groupEnd();
108
- } else {
109
- // IE 11, ... (does not know colors etc.)
110
- console.log('Changed state', previous, current);
111
- }
112
- }
113
- });
114
- }
115
-
116
- if (process.env.DEBUG_PILET) {
117
- const { withEmulatorPilets } = require('piral-debug-utils');
118
-
119
- requestPilets = withEmulatorPilets(requestPilets, {
120
- inject: context.injectPilet,
121
- createApi,
122
- loadPilet,
123
- });
124
- }
125
-
126
- return {
40
+ shareDependencies,
41
+ debug,
42
+ }: PiletOptionsConfig) {
43
+ const options: LoadPiletsOptions = {
44
+ config: loaderConfig,
127
45
  strategy,
128
- loadPilet,
46
+ loadPilet: extendLoader(loadPilet ?? getDefaultLoader(loaderConfig), loaders),
129
47
  createApi,
130
- getDependencies,
131
48
  pilets: availablePilets,
132
49
  fetchPilets: requestPilets,
133
- dependencies: globalDependencies,
50
+ hooks,
51
+ dependencies: shareDependencies(globalDependencies),
134
52
  };
53
+
54
+ integrateDebugger(context, options, debug);
55
+ integrateEmulator(context, options, debug);
56
+
57
+ return options;
135
58
  }
@@ -1,5 +1,4 @@
1
- import { useContext } from 'react';
2
- import { StateContext } from '../state/stateContext';
1
+ import { useGlobalStateContext } from './globalState';
3
2
  import { PiralActions, GlobalStateContext } from '../types';
4
3
 
5
4
  /**
@@ -7,6 +6,6 @@ import { PiralActions, GlobalStateContext } from '../types';
7
6
  * @param action The name of the action to retrieve.
8
7
  */
9
8
  export function useAction<T extends keyof PiralActions>(action: T): GlobalStateContext[T] {
10
- const ctx = useContext(StateContext);
9
+ const ctx = useGlobalStateContext();
11
10
  return ctx[action];
12
11
  }
@@ -1,14 +1,15 @@
1
1
  import { useContext } from 'react';
2
- import { useAtom, deref } from '@dbeining/react-atom';
3
2
  import { StateContext } from '../state/stateContext';
4
3
  import { GlobalState } from '../types';
5
4
 
6
- const useGlobalAtom = typeof window !== 'undefined' ? useAtom : useDirectAtom;
7
-
8
- function useDirectAtom(atom: any, opts: any) {
9
- const state = deref(atom);
10
- const select = opts && opts.select;
11
- return typeof select === 'function' ? select(state) : state;
5
+ /**
6
+ * Hook to obtain the global state context, which gives you directly
7
+ * all actions, state, and more of the Piral instance.
8
+ * If you are only interested in reading out the state, use the
9
+ * `useGlobalState` hook instead.
10
+ */
11
+ export function useGlobalStateContext() {
12
+ return useContext(StateContext);
12
13
  }
13
14
 
14
15
  /**
@@ -25,6 +26,6 @@ export function useGlobalState(): GlobalState;
25
26
  export function useGlobalState<R>(select: (state: GlobalState) => R): R;
26
27
 
27
28
  export function useGlobalState<R>(select?: (state: GlobalState) => R) {
28
- const { state } = useContext(StateContext);
29
- return useGlobalAtom(state, select && { select });
29
+ const { state: useState } = useGlobalStateContext();
30
+ return useState(select);
30
31
  }
@@ -1,11 +1,8 @@
1
1
  export * from './action';
2
2
  export * from './actions';
3
- export * from './debounce';
4
3
  export * from './globalState';
5
- export * from './lockBodyScroll';
4
+ export * from './piletApi';
6
5
  export * from './media';
7
- export * from './onClickOutside';
8
- export * from './onScreenVisible';
9
- export * from './promise';
6
+ export * from './routes';
10
7
  export * from './setter';
11
8
  export * from './sharedData';
@@ -1,4 +1,5 @@
1
1
  import { useState, useEffect } from 'react';
2
+ import { none } from '../utils/helpers';
2
3
  import { getCurrentLayout } from '../utils/media';
3
4
 
4
5
  /**
@@ -17,7 +18,7 @@ export function useMedia<T>(queries: Array<string>, values: Array<T>, defaultVal
17
18
  window.addEventListener('resize', handler);
18
19
  return () => window.removeEventListener('resize', handler);
19
20
  }
20
- }, []);
21
+ }, none);
21
22
 
22
23
  return value;
23
24
  }
@@ -0,0 +1,14 @@
1
+ import { useState } from "react";
2
+ import { useGlobalStateContext } from "./globalState";
3
+
4
+ /**
5
+ * Uses the global state context to retrieve the pilet API stored
6
+ * for the root pilet. This allows interaction with the pilet API
7
+ * from the app shell.
8
+ * @returns The pilet API object of the root pilet.
9
+ */
10
+ export function usePiletApi() {
11
+ const context = useGlobalStateContext();
12
+ const [api] = useState(() => Object.values(context.apis).shift());
13
+ return api;
14
+ }
@@ -0,0 +1,14 @@
1
+ import { useGlobalState } from './globalState';
2
+ import { useRouteFilter } from '../../app.codegen';
3
+ import { AppPath } from '../types';
4
+
5
+ export function useRoutes() {
6
+ const routes = useGlobalState((s) => s.routes);
7
+ const pages = useGlobalState((s) => s.registry.pages);
8
+ const paths: Array<AppPath> = [];
9
+
10
+ Object.keys(routes).map((path) => paths.push({ path, Component: routes[path] }));
11
+ Object.keys(pages).map((path) => paths.push({ path, Component: pages[path].component }));
12
+
13
+ return useRouteFilter(paths);
14
+ }
@@ -0,0 +1,22 @@
1
+ /**
2
+ * @jest-environment node
3
+ */
4
+
5
+ import * as React from 'react';
6
+ import { renderToString } from 'react-dom/server';
7
+ import { useSetter } from './setter';
8
+
9
+ describe('UseSetter Hook Module', () => {
10
+ it('UseSetter', () => {
11
+ const cb = jest.fn();
12
+
13
+ const MyComponent = () => {
14
+ useSetter(cb);
15
+ return null;
16
+ };
17
+
18
+ const result = renderToString(React.createElement(MyComponent));
19
+ expect(result).toEqual('');
20
+ expect(cb).toHaveBeenCalled();
21
+ });
22
+ });
@@ -0,0 +1,18 @@
1
+ import * as React from 'react';
2
+ import { render, act } from '@testing-library/react';
3
+ import { useSetter } from './setter';
4
+
5
+ describe('UseSetter Hook Module', () => {
6
+ it('UseSetter', async () => {
7
+ const cb = jest.fn();
8
+
9
+ const MyComponent = () => {
10
+ useSetter(cb);
11
+ return null;
12
+ };
13
+
14
+ render(React.createElement(MyComponent));
15
+ await act(() => new Promise((resolve) => setTimeout(resolve, 5)));
16
+ expect(cb).toHaveBeenCalled();
17
+ });
18
+ });
@@ -1,4 +1,5 @@
1
1
  import { useEffect as useSideEffect } from 'react';
2
+ import { none } from '../utils/helpers';
2
3
 
3
4
  function useMainEffect(cb: () => void) {
4
5
  cb();
@@ -11,5 +12,5 @@ const useEffect = typeof window !== 'undefined' ? useSideEffect : useMainEffect;
11
12
  * @param cb The callback to be invoked on mounting.
12
13
  */
13
14
  export function useSetter(cb: () => void) {
14
- useEffect(cb, []);
15
+ useEffect(cb, none);
15
16
  }
package/src/index.tsx CHANGED
@@ -1,8 +1,10 @@
1
1
  export * from './createInstance';
2
- export * from './Piral';
3
2
  export * from './helpers';
4
3
  export * from './components';
5
4
  export * from './hooks';
5
+ export * from './setters';
6
6
  export * from './state';
7
7
  export * from './utils';
8
+ export * from './Piral';
9
+ export * from './PiralContext';
8
10
  export * from './types';
@@ -1,6 +1,5 @@
1
- import * as hooks from '../hooks';
2
1
  import { createElement, FC } from 'react';
3
- import { createCoreApi, initializeApi } from './api';
2
+ import { defaultApiFactory } from './api';
4
3
 
5
4
  jest.mock('../hooks');
6
5
 
@@ -22,31 +21,21 @@ function createMockContainer() {
22
21
  off: jest.fn(),
23
22
  emit: jest.fn(),
24
23
  converters: {},
24
+ apis: {},
25
25
  readState() {
26
26
  return undefined;
27
27
  },
28
28
  } as any,
29
- api: {} as any,
30
29
  };
31
30
  }
32
31
 
33
- function createApi(container) {
34
- Object.assign(container.api, createCoreApi(container.context)(container.api, moduleMetadata));
35
- return container.api;
32
+ function createApi(container, apis = []) {
33
+ const api = defaultApiFactory(container.context, apis);
34
+ return api(moduleMetadata);
36
35
  }
37
36
 
38
37
  describe('API Module', () => {
39
- it('createCoreApi pluginMeta returns the metadata', () => {
40
- const container = createMockContainer();
41
- const api = initializeApi(moduleMetadata, container.context);
42
- expect(api.meta).toEqual({
43
- name: moduleMetadata.name,
44
- version: moduleMetadata.version,
45
- hash: moduleMetadata.hash,
46
- });
47
- });
48
-
49
- it('createCoreApi can register and unregister a page', () => {
38
+ it('defaultApiFactory can register and unregister a page', () => {
50
39
  const container = createMockContainer();
51
40
  container.context.registerPage = jest.fn();
52
41
  container.context.unregisterPage = jest.fn();
@@ -59,7 +48,7 @@ describe('API Module', () => {
59
48
  expect(container.context.unregisterPage.mock.calls[0][0]).toBe(container.context.registerPage.mock.calls[0][0]);
60
49
  });
61
50
 
62
- it('createCoreApi can dispose a registered page', () => {
51
+ it('defaultApiFactory can dispose a registered page', () => {
63
52
  const container = createMockContainer();
64
53
  container.context.registerPage = jest.fn();
65
54
  container.context.unregisterPage = jest.fn();
@@ -72,7 +61,7 @@ describe('API Module', () => {
72
61
  expect(container.context.unregisterPage.mock.calls[0][0]).toBe(container.context.registerPage.mock.calls[0][0]);
73
62
  });
74
63
 
75
- it('createCoreApi can register and unregister an extension', () => {
64
+ it('defaultApiFactory can register and unregister an extension', () => {
76
65
  const container = createMockContainer();
77
66
  container.context.registerExtension = jest.fn();
78
67
  container.context.unregisterExtension = jest.fn();
@@ -87,7 +76,7 @@ describe('API Module', () => {
87
76
  );
88
77
  });
89
78
 
90
- it('createCoreApi can dispose an registered extension', () => {
79
+ it('defaultApiFactory can dispose an registered extension', () => {
91
80
  const container = createMockContainer();
92
81
  container.context.registerExtension = jest.fn();
93
82
  container.context.unregisterExtension = jest.fn();
@@ -102,7 +91,7 @@ describe('API Module', () => {
102
91
  );
103
92
  });
104
93
 
105
- it('createCoreApi read data by its name', () => {
94
+ it('defaultApiFactory read data by its name', () => {
106
95
  const container = createMockContainer();
107
96
  container.context.readDataValue = jest.fn((name) => name);
108
97
  const api = createApi(container);
@@ -111,7 +100,7 @@ describe('API Module', () => {
111
100
  expect(container.context.readDataValue).toHaveBeenCalled();
112
101
  });
113
102
 
114
- it('createCoreApi write data without options shall pass, but memory should not emit events', () => {
103
+ it('defaultApiFactory write data without options shall pass, but memory should not emit events', () => {
115
104
  const container = createMockContainer();
116
105
  container.context.tryWriteDataItem = jest.fn(() => true);
117
106
  const api = createApi(container);
@@ -120,7 +109,7 @@ describe('API Module', () => {
120
109
  expect(container.context.emit).not.toHaveBeenCalled();
121
110
  });
122
111
 
123
- it('createCoreApi write data with empty options shall pass, but memory should not emit events', () => {
112
+ it('defaultApiFactory write data with empty options shall pass, but memory should not emit events', () => {
124
113
  const container = createMockContainer();
125
114
  container.context.tryWriteDataItem = jest.fn(() => true);
126
115
  const api = createApi(container);
@@ -129,7 +118,7 @@ describe('API Module', () => {
129
118
  expect(container.context.emit).not.toHaveBeenCalled();
130
119
  });
131
120
 
132
- it('createCoreApi write data by the simple option should not pass, never emitting events', () => {
121
+ it('defaultApiFactory write data by the simple option should not pass, never emitting events', () => {
133
122
  const container = createMockContainer();
134
123
  container.context.tryWriteDataItem = jest.fn(() => false);
135
124
  const api = createApi(container);
@@ -138,7 +127,7 @@ describe('API Module', () => {
138
127
  expect(container.context.emit).not.toHaveBeenCalled();
139
128
  });
140
129
 
141
- it('createCoreApi write data by the simple option shall pass with remote', () => {
130
+ it('defaultApiFactory write data by the simple option shall pass with remote', () => {
142
131
  const container = createMockContainer();
143
132
  container.context.tryWriteDataItem = jest.fn(() => true);
144
133
  const api = createApi(container);
@@ -146,7 +135,7 @@ describe('API Module', () => {
146
135
  expect(container.context.tryWriteDataItem).toHaveBeenCalled();
147
136
  });
148
137
 
149
- it('createCoreApi write data by the object options shall pass with remote', () => {
138
+ it('defaultApiFactory write data by the object options shall pass with remote', () => {
150
139
  const container = createMockContainer();
151
140
  container.context.tryWriteDataItem = jest.fn(() => true);
152
141
  const api = createApi(container);
@@ -1,70 +1,7 @@
1
- import { isfunc, PiletApiCreator } from 'piral-base';
1
+ import { isfunc, PiletApiCreator, initializeApi, mergeApis } from 'piral-base';
2
2
  import { __assign } from 'tslib';
3
- import { withApi } from '../state';
4
- import { ExtensionSlot } from '../components';
5
- import { createDataOptions, getDataExpiration, renderInDom } from '../utils';
6
- import { PiletApi, PiletMetadata, GlobalStateContext, PiletCoreApi, PiralPlugin, PiletApiExtender } from '../types';
7
-
8
- export function createCoreApi(context: GlobalStateContext): PiletApiExtender<PiletCoreApi> {
9
- return (api, target) => {
10
- const pilet = target.name;
11
- return {
12
- getData(name) {
13
- return context.readDataValue(name);
14
- },
15
- setData(name, value, options) {
16
- const { target = 'memory', expires } = createDataOptions(options);
17
- const expiration = getDataExpiration(expires);
18
- return context.tryWriteDataItem(name, value, pilet, target, expiration);
19
- },
20
- registerPage(route, arg, meta) {
21
- context.registerPage(route, {
22
- pilet,
23
- meta,
24
- component: withApi(context, arg, api, 'page'),
25
- });
26
- return () => api.unregisterPage(route);
27
- },
28
- unregisterPage(route) {
29
- context.unregisterPage(route);
30
- },
31
- registerExtension(name, arg, defaults) {
32
- context.registerExtension(name as string, {
33
- pilet,
34
- component: withApi(context, arg, api, 'extension'),
35
- reference: arg,
36
- defaults,
37
- });
38
- return () => api.unregisterExtension(name, arg);
39
- },
40
- unregisterExtension(name, arg) {
41
- context.unregisterExtension(name as string, arg);
42
- },
43
- renderHtmlExtension(element, props) {
44
- const id = renderInDom(context, element, ExtensionSlot, props);
45
- return () => context.destroyPortal(id);
46
- },
47
- Extension: ExtensionSlot,
48
- };
49
- };
50
- }
51
-
52
- export function initializeApi(target: PiletMetadata, context: GlobalStateContext) {
53
- return {
54
- on: context.on,
55
- off: context.off,
56
- emit: context.emit,
57
- meta: {
58
- ...target,
59
- },
60
- } as PiletApi;
61
- }
62
-
63
- export function mergeApis(api: PiletApi, extenders: Array<PiletApiExtender<Partial<PiletApi>>>, target: PiletMetadata) {
64
- const frags = extenders.map((extender) => extender(api, target));
65
- __assign(api, ...frags);
66
- return api;
67
- }
3
+ import { createCoreApi } from './core';
4
+ import { GlobalStateContext, PiralPlugin } from '../types';
68
5
 
69
6
  export function createExtenders(context: GlobalStateContext, apis: Array<PiralPlugin>) {
70
7
  const creators: Array<PiralPlugin> = [createCoreApi, ...apis.filter(isfunc)];