one 1.1.538 → 1.1.539

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 (462) hide show
  1. package/dist/cjs/Root.native.js +83 -61
  2. package/dist/cjs/Root.native.js.map +1 -6
  3. package/dist/cjs/babel-plugins/one-router-metro.native.js +31 -20
  4. package/dist/cjs/babel-plugins/one-router-metro.native.js.map +1 -6
  5. package/dist/cjs/cli/build.native.js +340 -277
  6. package/dist/cjs/cli/build.native.js.map +1 -6
  7. package/dist/cjs/cli/buildPage.native.js +65 -36
  8. package/dist/cjs/cli/buildPage.native.js.map +1 -6
  9. package/dist/cjs/cli/checkNodeVersion.native.js +17 -14
  10. package/dist/cjs/cli/checkNodeVersion.native.js.map +1 -6
  11. package/dist/cjs/cli/dev.native.js +55 -37
  12. package/dist/cjs/cli/dev.native.js.map +1 -6
  13. package/dist/cjs/cli/label-process.native.js +20 -16
  14. package/dist/cjs/cli/label-process.native.js.map +1 -6
  15. package/dist/cjs/cli/main.native.js +37 -22
  16. package/dist/cjs/cli/main.native.js.map +1 -6
  17. package/dist/cjs/cli/patch.native.js +28 -19
  18. package/dist/cjs/cli/patch.native.js.map +1 -6
  19. package/dist/cjs/cli/prebuild.native.js +26 -18
  20. package/dist/cjs/cli/prebuild.native.js.map +1 -6
  21. package/dist/cjs/cli/runAndroid.native.js +26 -18
  22. package/dist/cjs/cli/runAndroid.native.js.map +1 -6
  23. package/dist/cjs/cli/runIos.native.js +26 -18
  24. package/dist/cjs/cli/runIos.native.js.map +1 -6
  25. package/dist/cjs/cli.native.js +281 -220
  26. package/dist/cjs/cli.native.js.map +1 -6
  27. package/dist/cjs/clientLoaderResolver.native.js +21 -19
  28. package/dist/cjs/clientLoaderResolver.native.js.map +1 -6
  29. package/dist/cjs/config.native.js +26 -21
  30. package/dist/cjs/config.native.js.map +1 -6
  31. package/dist/cjs/constants.native.js +36 -30
  32. package/dist/cjs/constants.native.js.map +1 -6
  33. package/dist/cjs/createApp.native.js +26 -21
  34. package/dist/cjs/createApp.native.js.map +1 -6
  35. package/dist/cjs/createHandleRequest.native.js +94 -85
  36. package/dist/cjs/createHandleRequest.native.js.map +1 -6
  37. package/dist/cjs/createMiddleware.native.js +17 -14
  38. package/dist/cjs/createMiddleware.native.js.map +1 -6
  39. package/dist/cjs/fallbackViews/Sitemap.native.js +21 -17
  40. package/dist/cjs/fallbackViews/Sitemap.native.js.map +1 -6
  41. package/dist/cjs/fallbackViews/Unmatched.native.js +27 -19
  42. package/dist/cjs/fallbackViews/Unmatched.native.js.map +1 -6
  43. package/dist/cjs/fork/NavigationContainer.native.js +93 -64
  44. package/dist/cjs/fork/NavigationContainer.native.js.map +1 -6
  45. package/dist/cjs/fork/__tests__/getPathFromState.test.cjs +9 -10
  46. package/dist/cjs/fork/__tests__/getPathFromState.test.js +3 -3
  47. package/dist/cjs/fork/__tests__/getPathFromState.test.js.map +1 -1
  48. package/dist/cjs/fork/__tests__/getPathFromState.test.native.js +1144 -1288
  49. package/dist/cjs/fork/__tests__/getPathFromState.test.native.js.map +1 -6
  50. package/dist/cjs/fork/__tests__/getStateFromPath.test.cjs +5 -7
  51. package/dist/cjs/fork/__tests__/getStateFromPath.test.js +5 -5
  52. package/dist/cjs/fork/__tests__/getStateFromPath.test.js.map +1 -1
  53. package/dist/cjs/fork/__tests__/getStateFromPath.test.native.js +1881 -2104
  54. package/dist/cjs/fork/__tests__/getStateFromPath.test.native.js.map +1 -6
  55. package/dist/cjs/fork/_shared.native.js +19 -19
  56. package/dist/cjs/fork/_shared.native.js.map +1 -6
  57. package/dist/cjs/fork/createMemoryHistory.native.js +131 -109
  58. package/dist/cjs/fork/createMemoryHistory.native.js.map +1 -6
  59. package/dist/cjs/fork/extractPathFromURL.native.js +43 -41
  60. package/dist/cjs/fork/extractPathFromURL.native.js.map +1 -6
  61. package/dist/cjs/fork/findFocusedRoute.native.js +20 -16
  62. package/dist/cjs/fork/findFocusedRoute.native.js.map +1 -6
  63. package/dist/cjs/fork/getPathFromState-mods.native.js +37 -25
  64. package/dist/cjs/fork/getPathFromState-mods.native.js.map +1 -6
  65. package/dist/cjs/fork/getPathFromState.native.js +112 -107
  66. package/dist/cjs/fork/getPathFromState.native.js.map +1 -6
  67. package/dist/cjs/fork/getPathFromState.test.native.js +63 -74
  68. package/dist/cjs/fork/getPathFromState.test.native.js.map +1 -6
  69. package/dist/cjs/fork/getStateFromPath-mods.native.js +126 -131
  70. package/dist/cjs/fork/getStateFromPath-mods.native.js.map +1 -6
  71. package/dist/cjs/fork/getStateFromPath.native.js +271 -240
  72. package/dist/cjs/fork/getStateFromPath.native.js.map +1 -6
  73. package/dist/cjs/fork/getStateFromPath.test.native.js +167 -306
  74. package/dist/cjs/fork/getStateFromPath.test.native.js.map +1 -6
  75. package/dist/cjs/fork/useBackButton.native.js +28 -23
  76. package/dist/cjs/fork/useBackButton.native.js.map +1 -6
  77. package/dist/cjs/fork/useDocumentTitle.native.js +17 -15
  78. package/dist/cjs/fork/useDocumentTitle.native.js.map +1 -6
  79. package/dist/cjs/fork/useLinking.native.js +111 -100
  80. package/dist/cjs/fork/useLinking.native.js.map +1 -6
  81. package/dist/cjs/fork/useThenable.native.js +41 -44
  82. package/dist/cjs/fork/useThenable.native.js.map +1 -6
  83. package/dist/cjs/fork/validatePathConfig.native.js +48 -49
  84. package/dist/cjs/fork/validatePathConfig.native.js.map +1 -6
  85. package/dist/cjs/getReactNavigationConfig.native.js +36 -39
  86. package/dist/cjs/getReactNavigationConfig.native.js.map +1 -6
  87. package/dist/cjs/getURL.native.js +25 -17
  88. package/dist/cjs/getURL.native.js.map +1 -6
  89. package/dist/cjs/head/Head.android.js +20 -16
  90. package/dist/cjs/head/Head.android.js.map +1 -6
  91. package/dist/cjs/head/Head.ios.js +162 -156
  92. package/dist/cjs/head/Head.ios.js.map +1 -6
  93. package/dist/cjs/head/Head.native.js +24 -18
  94. package/dist/cjs/head/Head.native.js.map +1 -6
  95. package/dist/cjs/head/HeadModule.native.js +21 -16
  96. package/dist/cjs/head/HeadModule.native.js.map +1 -6
  97. package/dist/cjs/head/index.native.js +13 -12
  98. package/dist/cjs/head/index.native.js.map +1 -6
  99. package/dist/cjs/head/types.native.js +9 -5
  100. package/dist/cjs/head/types.native.js.map +1 -6
  101. package/dist/cjs/head/url.js +2 -2
  102. package/dist/cjs/head/url.js.map +1 -1
  103. package/dist/cjs/head/url.native.js +23 -20
  104. package/dist/cjs/head/url.native.js.map +1 -6
  105. package/dist/cjs/hooks.native.js +62 -67
  106. package/dist/cjs/hooks.native.js.map +1 -6
  107. package/dist/cjs/href.native.js +18 -16
  108. package/dist/cjs/href.native.js.map +1 -6
  109. package/dist/cjs/import-mode/index.android.js +18 -10
  110. package/dist/cjs/import-mode/index.android.js.map +1 -6
  111. package/dist/cjs/import-mode/index.ios.js +18 -10
  112. package/dist/cjs/import-mode/index.ios.js.map +1 -6
  113. package/dist/cjs/import-mode/index.native.js +16 -9
  114. package/dist/cjs/import-mode/index.native.js.map +1 -6
  115. package/dist/cjs/index.native.js +57 -63
  116. package/dist/cjs/index.native.js.map +1 -6
  117. package/dist/cjs/interfaces/router.native.js +17 -14
  118. package/dist/cjs/interfaces/router.native.js.map +1 -6
  119. package/dist/cjs/layouts/Drawer.native.js +22 -15
  120. package/dist/cjs/layouts/Drawer.native.js.map +1 -6
  121. package/dist/cjs/layouts/Stack.native.js +22 -15
  122. package/dist/cjs/layouts/Stack.native.js.map +1 -6
  123. package/dist/cjs/layouts/Tabs.native.js +76 -63
  124. package/dist/cjs/layouts/Tabs.native.js.map +1 -6
  125. package/dist/cjs/layouts/withLayoutContext.native.js +67 -56
  126. package/dist/cjs/layouts/withLayoutContext.native.js.map +1 -6
  127. package/dist/cjs/link/Link.native.js +94 -89
  128. package/dist/cjs/link/Link.native.js.map +1 -6
  129. package/dist/cjs/link/Redirect.native.js +25 -20
  130. package/dist/cjs/link/Redirect.native.js.map +1 -6
  131. package/dist/cjs/link/href.native.js +42 -38
  132. package/dist/cjs/link/href.native.js.map +1 -6
  133. package/dist/cjs/link/linking.native.js +63 -61
  134. package/dist/cjs/link/linking.native.js.map +1 -6
  135. package/dist/cjs/link/path.native.js +34 -38
  136. package/dist/cjs/link/path.native.js.map +1 -6
  137. package/dist/cjs/link/useLinkTo.native.js +36 -30
  138. package/dist/cjs/link/useLinkTo.native.js.map +1 -6
  139. package/dist/cjs/link/useLoadedNavigation.native.js +40 -40
  140. package/dist/cjs/link/useLoadedNavigation.native.js.map +1 -6
  141. package/dist/cjs/metro-config/getViteMetroPluginOptions.native.js +115 -112
  142. package/dist/cjs/metro-config/getViteMetroPluginOptions.native.js.map +1 -6
  143. package/dist/cjs/polyfills-mobile.native.js +28 -15
  144. package/dist/cjs/polyfills-mobile.native.js.map +1 -6
  145. package/dist/cjs/polyfills-server.native.js +19 -13
  146. package/dist/cjs/polyfills-server.native.js.map +1 -6
  147. package/dist/cjs/render.native.js +16 -13
  148. package/dist/cjs/render.native.js.map +1 -6
  149. package/dist/cjs/router/FlagsContext.native.js +19 -15
  150. package/dist/cjs/router/FlagsContext.native.js.map +1 -6
  151. package/dist/cjs/router/Route.native.js +39 -28
  152. package/dist/cjs/router/Route.native.js.map +1 -6
  153. package/dist/cjs/router/RouteInfoContext.native.js +37 -21
  154. package/dist/cjs/router/RouteInfoContext.native.js.map +1 -6
  155. package/dist/cjs/router/RouterStore.native.js +9 -5
  156. package/dist/cjs/router/RouterStore.native.js.map +1 -6
  157. package/dist/cjs/router/createRoute.native.js +31 -26
  158. package/dist/cjs/router/createRoute.native.js.map +1 -6
  159. package/dist/cjs/router/filterRootHTML.native.js +40 -24
  160. package/dist/cjs/router/filterRootHTML.native.js.map +1 -6
  161. package/dist/cjs/router/getLinkingConfig.native.js +24 -21
  162. package/dist/cjs/router/getLinkingConfig.native.js.map +1 -6
  163. package/dist/cjs/router/getNormalizedStatePath.native.js +32 -28
  164. package/dist/cjs/router/getNormalizedStatePath.native.js.map +1 -6
  165. package/dist/cjs/router/getRoutes.native.js +261 -273
  166. package/dist/cjs/router/getRoutes.native.js.map +1 -6
  167. package/dist/cjs/router/glob-patterns.native.js +21 -24
  168. package/dist/cjs/router/glob-patterns.native.js.map +1 -6
  169. package/dist/cjs/router/imperative-api.native.js +39 -32
  170. package/dist/cjs/router/imperative-api.native.js.map +1 -6
  171. package/dist/cjs/router/lastAction.native.js +24 -20
  172. package/dist/cjs/router/lastAction.native.js.map +1 -6
  173. package/dist/cjs/router/matchers.native.js +18 -26
  174. package/dist/cjs/router/matchers.native.js.map +1 -6
  175. package/dist/cjs/router/matchers.test.native.js +19 -17
  176. package/dist/cjs/router/matchers.test.native.js.map +1 -6
  177. package/dist/cjs/router/router.native.js +156 -150
  178. package/dist/cjs/router/router.native.js.map +1 -6
  179. package/dist/cjs/router/serverLocationContext.native.js +19 -15
  180. package/dist/cjs/router/serverLocationContext.native.js.map +1 -6
  181. package/dist/cjs/router/sortRoutes.native.js +37 -44
  182. package/dist/cjs/router/sortRoutes.native.js.map +1 -6
  183. package/dist/cjs/router/useInitializeOneRouter.native.js +28 -20
  184. package/dist/cjs/router/useInitializeOneRouter.native.js.map +1 -6
  185. package/dist/cjs/router/useNavigation.native.js +42 -35
  186. package/dist/cjs/router/useNavigation.native.js.map +1 -6
  187. package/dist/cjs/router/useScreens.native.js +280 -248
  188. package/dist/cjs/router/useScreens.native.js.map +1 -6
  189. package/dist/cjs/router/useViteRoutes.native.js +36 -31
  190. package/dist/cjs/router/useViteRoutes.native.js.map +1 -6
  191. package/dist/cjs/router/utils/getNavigateAction.native.js +33 -23
  192. package/dist/cjs/router/utils/getNavigateAction.native.js.map +1 -6
  193. package/dist/cjs/router/utils/getNavigateAction.test.native.js +142 -197
  194. package/dist/cjs/router/utils/getNavigateAction.test.native.js.map +1 -6
  195. package/dist/cjs/serve-worker.native.js +25 -16
  196. package/dist/cjs/serve-worker.native.js.map +1 -6
  197. package/dist/cjs/serve.native.js +50 -25
  198. package/dist/cjs/serve.native.js.map +1 -6
  199. package/dist/cjs/server/ServerContextScript.native.js +31 -26
  200. package/dist/cjs/server/ServerContextScript.native.js.map +1 -6
  201. package/dist/cjs/server/createRoutesManifest.native.js +26 -23
  202. package/dist/cjs/server/createRoutesManifest.native.js.map +1 -6
  203. package/dist/cjs/server/getServerManifest.native.js +107 -87
  204. package/dist/cjs/server/getServerManifest.native.js.map +1 -6
  205. package/dist/cjs/server/oneServe.native.js +199 -132
  206. package/dist/cjs/server/oneServe.native.js.map +1 -6
  207. package/dist/cjs/server/setServerGlobals.native.js +17 -14
  208. package/dist/cjs/server/setServerGlobals.native.js.map +1 -6
  209. package/dist/cjs/server/setupBuildOptions.native.js +17 -14
  210. package/dist/cjs/server/setupBuildOptions.native.js.map +1 -6
  211. package/dist/cjs/server/setupServerGlobals.native.js +3 -2
  212. package/dist/cjs/server/setupServerGlobals.native.js.map +1 -6
  213. package/dist/cjs/server-render.native.js +39 -29
  214. package/dist/cjs/server-render.native.js.map +1 -6
  215. package/dist/cjs/setup.native.js.map +1 -6
  216. package/dist/cjs/testing-utils.native.js +39 -41
  217. package/dist/cjs/testing-utils.native.js.map +1 -6
  218. package/dist/cjs/typed-routes/generateRouteTypes.native.js +36 -22
  219. package/dist/cjs/typed-routes/generateRouteTypes.native.js.map +1 -6
  220. package/dist/cjs/typed-routes/getTypedRoutesDeclarationFile.native.js +53 -47
  221. package/dist/cjs/typed-routes/getTypedRoutesDeclarationFile.native.js.map +1 -6
  222. package/dist/cjs/types.native.js +9 -5
  223. package/dist/cjs/types.native.js.map +1 -6
  224. package/dist/cjs/useFocusEffect.native.js +39 -36
  225. package/dist/cjs/useFocusEffect.native.js.map +1 -6
  226. package/dist/cjs/useLoader.native.js +67 -52
  227. package/dist/cjs/useLoader.native.js.map +1 -6
  228. package/dist/cjs/useServerHeadInsertion.native.js +32 -25
  229. package/dist/cjs/useServerHeadInsertion.native.js.map +1 -6
  230. package/dist/cjs/utils/assertIsReady.native.js +18 -16
  231. package/dist/cjs/utils/assertIsReady.native.js.map +1 -6
  232. package/dist/cjs/utils/cleanUrl.native.js +26 -19
  233. package/dist/cjs/utils/cleanUrl.native.js.map +1 -6
  234. package/dist/cjs/utils/dynamicImport.native.js +18 -15
  235. package/dist/cjs/utils/dynamicImport.native.js.map +1 -6
  236. package/dist/cjs/utils/ensureExists.native.js +18 -16
  237. package/dist/cjs/utils/ensureExists.native.js.map +1 -6
  238. package/dist/cjs/utils/existsAsync.native.js +27 -23
  239. package/dist/cjs/utils/existsAsync.native.js.map +1 -6
  240. package/dist/cjs/utils/getPageExport.native.js +34 -30
  241. package/dist/cjs/utils/getPageExport.native.js.map +1 -6
  242. package/dist/cjs/utils/getPathnameFromFilePath.native.js +36 -27
  243. package/dist/cjs/utils/getPathnameFromFilePath.native.js.map +1 -6
  244. package/dist/cjs/utils/getRouterRootFromOneOptions.native.js +17 -14
  245. package/dist/cjs/utils/getRouterRootFromOneOptions.native.js.map +1 -6
  246. package/dist/cjs/utils/globDir.native.js +24 -18
  247. package/dist/cjs/utils/globDir.native.js.map +1 -6
  248. package/dist/cjs/utils/hashString.native.js +23 -17
  249. package/dist/cjs/utils/hashString.native.js.map +1 -6
  250. package/dist/cjs/utils/isResponse.native.js +21 -15
  251. package/dist/cjs/utils/isResponse.native.js.map +1 -6
  252. package/dist/cjs/utils/isRolldown.native.js +24 -19
  253. package/dist/cjs/utils/isRolldown.native.js.map +1 -6
  254. package/dist/cjs/utils/isStatus.native.js +17 -14
  255. package/dist/cjs/utils/isStatus.native.js.map +1 -6
  256. package/dist/cjs/utils/platform.native.js +17 -14
  257. package/dist/cjs/utils/platform.native.js.map +1 -6
  258. package/dist/cjs/utils/promiseWithResolvers.native.js +22 -17
  259. package/dist/cjs/utils/promiseWithResolvers.native.js.map +1 -6
  260. package/dist/cjs/utils/rand.native.js +18 -15
  261. package/dist/cjs/utils/rand.native.js.map +1 -6
  262. package/dist/cjs/utils/redirect.native.js +26 -21
  263. package/dist/cjs/utils/redirect.native.js.map +1 -6
  264. package/dist/cjs/utils/removeSearch.native.js +17 -14
  265. package/dist/cjs/utils/removeSearch.native.js.map +1 -6
  266. package/dist/cjs/utils/removeUndefined.native.js +18 -16
  267. package/dist/cjs/utils/removeUndefined.native.js.map +1 -6
  268. package/dist/cjs/utils/toAbsolute.native.js +21 -17
  269. package/dist/cjs/utils/toAbsolute.native.js.map +1 -6
  270. package/dist/cjs/utils/url.native.js +17 -16
  271. package/dist/cjs/utils/url.native.js.map +1 -6
  272. package/dist/cjs/utils/useConstant.native.js +26 -21
  273. package/dist/cjs/utils/useConstant.native.js.map +1 -6
  274. package/dist/cjs/utils/weakKey.native.js +25 -21
  275. package/dist/cjs/utils/weakKey.native.js.map +1 -6
  276. package/dist/cjs/utils/weakMemo.native.js +23 -18
  277. package/dist/cjs/utils/weakMemo.native.js.map +1 -6
  278. package/dist/cjs/utils/withStaticProperties.native.js +48 -35
  279. package/dist/cjs/utils/withStaticProperties.native.js.map +1 -6
  280. package/dist/cjs/vercel/build/buildVercelOutputDirectory.native.js +120 -95
  281. package/dist/cjs/vercel/build/buildVercelOutputDirectory.native.js.map +1 -6
  282. package/dist/cjs/vercel/build/config/vc-build-output-config-base.native.js +17 -14
  283. package/dist/cjs/vercel/build/config/vc-build-output-config-base.native.js.map +1 -6
  284. package/dist/cjs/vercel/build/config/vc-config-base.native.js +17 -14
  285. package/dist/cjs/vercel/build/config/vc-config-base.native.js.map +1 -6
  286. package/dist/cjs/vercel/build/config/vc-package-base.native.js +17 -14
  287. package/dist/cjs/vercel/build/config/vc-package-base.native.js.map +1 -6
  288. package/dist/cjs/vercel/build/generate/createApiServerlessFunction.native.js +60 -71
  289. package/dist/cjs/vercel/build/generate/createApiServerlessFunction.native.js.map +1 -6
  290. package/dist/cjs/vercel/build/generate/createSsrServerlessFunction.native.js +36 -24
  291. package/dist/cjs/vercel/build/generate/createSsrServerlessFunction.native.js.map +1 -6
  292. package/dist/cjs/vercel/build/getPathFromRoute.native.js +18 -15
  293. package/dist/cjs/vercel/build/getPathFromRoute.native.js.map +1 -6
  294. package/dist/cjs/views/EmptyRoute.native.js +19 -15
  295. package/dist/cjs/views/EmptyRoute.native.js.map +1 -6
  296. package/dist/cjs/views/ErrorBoundary.native.js +33 -19
  297. package/dist/cjs/views/ErrorBoundary.native.js.map +1 -6
  298. package/dist/cjs/views/LoadProgressBar.native.js +75 -67
  299. package/dist/cjs/views/LoadProgressBar.native.js.map +1 -6
  300. package/dist/cjs/views/Navigator.native.js +99 -64
  301. package/dist/cjs/views/Navigator.native.js.map +1 -6
  302. package/dist/cjs/views/OneStackRouter.native.js +27 -23
  303. package/dist/cjs/views/OneStackRouter.native.js.map +1 -6
  304. package/dist/cjs/views/PreloadLinks.native.js +16 -13
  305. package/dist/cjs/views/PreloadLinks.native.js.map +1 -6
  306. package/dist/cjs/views/RootErrorBoundary.native.js +54 -53
  307. package/dist/cjs/views/RootErrorBoundary.native.js.map +1 -6
  308. package/dist/cjs/views/Screen.native.js +28 -22
  309. package/dist/cjs/views/Screen.native.js.map +1 -6
  310. package/dist/cjs/views/ScrollBehavior.native.js +54 -43
  311. package/dist/cjs/views/ScrollBehavior.native.js.map +1 -6
  312. package/dist/cjs/views/Try.native.js +60 -54
  313. package/dist/cjs/views/Try.native.js.map +1 -6
  314. package/dist/cjs/vite/DevHead.native.js +19 -15
  315. package/dist/cjs/vite/DevHead.native.js.map +1 -6
  316. package/dist/cjs/vite/constants.native.js +20 -17
  317. package/dist/cjs/vite/constants.native.js.map +1 -6
  318. package/dist/cjs/vite/customNodeExternals.native.js +35 -25
  319. package/dist/cjs/vite/customNodeExternals.native.js.map +1 -6
  320. package/dist/cjs/vite/ensureTsConfig.native.js +21 -16
  321. package/dist/cjs/vite/ensureTsConfig.native.js.map +1 -6
  322. package/dist/cjs/vite/findDepsToOptimize.native.js +46 -43
  323. package/dist/cjs/vite/findDepsToOptimize.native.js.map +1 -6
  324. package/dist/cjs/vite/getManifest.native.js +23 -16
  325. package/dist/cjs/vite/getManifest.native.js.map +1 -6
  326. package/dist/cjs/vite/loadConfig.native.js +22 -22
  327. package/dist/cjs/vite/loadConfig.native.js.map +1 -6
  328. package/dist/cjs/vite/makePluginWebOnly.native.js +20 -19
  329. package/dist/cjs/vite/makePluginWebOnly.native.js.map +1 -6
  330. package/dist/cjs/vite/one-server-only.native.js +24 -33
  331. package/dist/cjs/vite/one-server-only.native.js.map +1 -6
  332. package/dist/cjs/vite/one.native.js +202 -181
  333. package/dist/cjs/vite/one.native.js.map +1 -6
  334. package/dist/cjs/vite/plugins/SSRCSSPlugin.native.js +75 -74
  335. package/dist/cjs/vite/plugins/SSRCSSPlugin.native.js.map +1 -6
  336. package/dist/cjs/vite/plugins/clientTreeShakePlugin.native.js +69 -56
  337. package/dist/cjs/vite/plugins/clientTreeShakePlugin.native.js.map +1 -6
  338. package/dist/cjs/vite/plugins/fileSystemRouterPlugin.native.js +154 -108
  339. package/dist/cjs/vite/plugins/fileSystemRouterPlugin.native.js.map +1 -6
  340. package/dist/cjs/vite/plugins/fixDependenciesPlugin.native.js +25 -16
  341. package/dist/cjs/vite/plugins/fixDependenciesPlugin.native.js.map +1 -6
  342. package/dist/cjs/vite/plugins/generateFileSystemRouteTypesPlugin.native.js +33 -24
  343. package/dist/cjs/vite/plugins/generateFileSystemRouteTypesPlugin.native.js.map +1 -6
  344. package/dist/cjs/vite/plugins/removeReactNativeWebAnimatedPlugin.native.js +26 -24
  345. package/dist/cjs/vite/plugins/removeReactNativeWebAnimatedPlugin.native.js.map +1 -6
  346. package/dist/cjs/vite/plugins/useDomPlugin.native.js +32 -26
  347. package/dist/cjs/vite/plugins/useDomPlugin.native.js.map +1 -6
  348. package/dist/cjs/vite/plugins/virtualEntryConstants.native.js +24 -20
  349. package/dist/cjs/vite/plugins/virtualEntryConstants.native.js.map +1 -6
  350. package/dist/cjs/vite/plugins/virtualEntryPlugin.native.js +38 -45
  351. package/dist/cjs/vite/plugins/virtualEntryPlugin.native.js.map +1 -6
  352. package/dist/cjs/vite/replaceLoader.native.js +26 -20
  353. package/dist/cjs/vite/replaceLoader.native.js.map +1 -6
  354. package/dist/cjs/vite/resolveResponse.native.js +59 -42
  355. package/dist/cjs/vite/resolveResponse.native.js.map +1 -6
  356. package/dist/cjs/vite/types.native.js +9 -5
  357. package/dist/cjs/vite/types.native.js.map +1 -6
  358. package/dist/cjs/vite.native.js +26 -22
  359. package/dist/cjs/vite.native.js.map +1 -6
  360. package/dist/cjs/zero/getQueryKey.native.js +18 -15
  361. package/dist/cjs/zero/getQueryKey.native.js.map +1 -6
  362. package/dist/cjs/zero/isZeroQuery.native.js +23 -15
  363. package/dist/cjs/zero/isZeroQuery.native.js.map +1 -6
  364. package/dist/cjs/zero/resolveQuery.native.js +23 -19
  365. package/dist/cjs/zero/resolveQuery.native.js.map +1 -6
  366. package/dist/cjs/zero/subscribeToQuery.native.js +18 -15
  367. package/dist/cjs/zero/subscribeToQuery.native.js.map +1 -6
  368. package/dist/cjs/zero/types.native.js +9 -5
  369. package/dist/cjs/zero/types.native.js.map +1 -6
  370. package/dist/cjs/zero/useQuery.js +2 -2
  371. package/dist/cjs/zero/useQuery.js.map +1 -1
  372. package/dist/cjs/zero/useQuery.native.js +30 -19
  373. package/dist/cjs/zero/useQuery.native.js.map +1 -6
  374. package/dist/cjs/zero/useQueryZero.native.js +35 -34
  375. package/dist/cjs/zero/useQueryZero.native.js.map +1 -6
  376. package/dist/cjs/zero.native.js +20 -17
  377. package/dist/cjs/zero.native.js.map +1 -6
  378. package/dist/esm/cli/build.native.js +2 -2
  379. package/dist/esm/cli/build.native.js.map +1 -1
  380. package/dist/esm/cli/buildPage.native.js +5 -2
  381. package/dist/esm/cli/buildPage.native.js.map +1 -1
  382. package/dist/esm/cli/label-process.native.js +1 -1
  383. package/dist/esm/cli/main.native.js +2 -2
  384. package/dist/esm/cli.native.js +3 -3
  385. package/dist/esm/createApp.native.js.map +1 -1
  386. package/dist/esm/fork/__tests__/getPathFromState.test.js +3 -3
  387. package/dist/esm/fork/__tests__/getPathFromState.test.js.map +1 -1
  388. package/dist/esm/fork/__tests__/getPathFromState.test.mjs +9 -10
  389. package/dist/esm/fork/__tests__/getPathFromState.test.mjs.map +1 -1
  390. package/dist/esm/fork/__tests__/getPathFromState.test.native.js.map +1 -1
  391. package/dist/esm/fork/__tests__/getStateFromPath.test.js +5 -5
  392. package/dist/esm/fork/__tests__/getStateFromPath.test.js.map +1 -1
  393. package/dist/esm/fork/__tests__/getStateFromPath.test.mjs +5 -7
  394. package/dist/esm/fork/__tests__/getStateFromPath.test.mjs.map +1 -1
  395. package/dist/esm/fork/__tests__/getStateFromPath.test.native.js.map +1 -1
  396. package/dist/esm/fork/getStateFromPath.native.js +6 -1
  397. package/dist/esm/fork/getStateFromPath.native.js.map +1 -1
  398. package/dist/esm/fork/useBackButton.native.js.map +1 -1
  399. package/dist/esm/fork/useDocumentTitle.native.js.map +1 -1
  400. package/dist/esm/fork/useLinking.native.js +6 -1
  401. package/dist/esm/fork/useLinking.native.js.map +1 -1
  402. package/dist/esm/fork/validatePathConfig.native.js +7 -2
  403. package/dist/esm/fork/validatePathConfig.native.js.map +1 -1
  404. package/dist/esm/getURL.native.js.map +1 -1
  405. package/dist/esm/head/Head.android.js.map +1 -1
  406. package/dist/esm/head/Head.ios.js +7 -2
  407. package/dist/esm/head/Head.ios.js.map +1 -1
  408. package/dist/esm/head/url.js +2 -2
  409. package/dist/esm/head/url.js.map +1 -1
  410. package/dist/esm/head/url.native.js.map +1 -1
  411. package/dist/esm/import-mode/index.android.js.map +1 -1
  412. package/dist/esm/import-mode/index.ios.js.map +1 -1
  413. package/dist/esm/import-mode/index.native.js.map +1 -1
  414. package/dist/esm/metro-config/getViteMetroPluginOptions.native.js +2 -2
  415. package/dist/esm/metro-config/getViteMetroPluginOptions.native.js.map +1 -1
  416. package/dist/esm/render.native.js.map +1 -1
  417. package/dist/esm/router/filterRootHTML.native.js +6 -1
  418. package/dist/esm/router/filterRootHTML.native.js.map +1 -1
  419. package/dist/esm/router/router.native.js +6 -1
  420. package/dist/esm/router/router.native.js.map +1 -1
  421. package/dist/esm/router/useScreens.native.js +7 -4
  422. package/dist/esm/router/useScreens.native.js.map +1 -1
  423. package/dist/esm/server/oneServe.native.js +1 -1
  424. package/dist/esm/testing-utils.native.js +1 -1
  425. package/dist/esm/typed-routes/generateRouteTypes.native.js +2 -2
  426. package/dist/esm/useLoader.native.js +5 -2
  427. package/dist/esm/useLoader.native.js.map +1 -1
  428. package/dist/esm/utils/existsAsync.native.js +1 -1
  429. package/dist/esm/utils/getPathnameFromFilePath.native.js +1 -1
  430. package/dist/esm/utils/isResponse.native.js +4 -1
  431. package/dist/esm/utils/isResponse.native.js.map +1 -1
  432. package/dist/esm/utils/toAbsolute.native.js +1 -1
  433. package/dist/esm/utils/withStaticProperties.native.js +6 -1
  434. package/dist/esm/utils/withStaticProperties.native.js.map +1 -1
  435. package/dist/esm/vercel/build/buildVercelOutputDirectory.native.js +1 -1
  436. package/dist/esm/vercel/build/generate/createApiServerlessFunction.native.js +1 -1
  437. package/dist/esm/vercel/build/generate/createSsrServerlessFunction.native.js +1 -1
  438. package/dist/esm/views/PreloadLinks.native.js.map +1 -1
  439. package/dist/esm/views/RootErrorBoundary.native.js +4 -1
  440. package/dist/esm/vite/customNodeExternals.native.js +2 -2
  441. package/dist/esm/vite/ensureTsConfig.native.js +1 -1
  442. package/dist/esm/vite/findDepsToOptimize.native.js +3 -3
  443. package/dist/esm/vite/one-server-only.native.js.map +1 -1
  444. package/dist/esm/vite/one.native.js +8 -3
  445. package/dist/esm/vite/one.native.js.map +1 -1
  446. package/dist/esm/vite/plugins/clientTreeShakePlugin.native.js +8 -5
  447. package/dist/esm/vite/plugins/clientTreeShakePlugin.native.js.map +1 -1
  448. package/dist/esm/vite/plugins/fileSystemRouterPlugin.native.js +8 -5
  449. package/dist/esm/vite/plugins/fileSystemRouterPlugin.native.js.map +1 -1
  450. package/dist/esm/vite/plugins/fixDependenciesPlugin.native.js +6 -1
  451. package/dist/esm/vite/plugins/fixDependenciesPlugin.native.js.map +1 -1
  452. package/dist/esm/vite/plugins/generateFileSystemRouteTypesPlugin.native.js +1 -1
  453. package/dist/esm/vite/plugins/generateFileSystemRouteTypesPlugin.native.js.map +1 -1
  454. package/dist/esm/vite/plugins/useDomPlugin.native.js +1 -1
  455. package/dist/esm/vite/resolveResponse.native.js +9 -1
  456. package/dist/esm/vite/resolveResponse.native.js.map +1 -1
  457. package/dist/esm/zero/isZeroQuery.native.js +6 -1
  458. package/dist/esm/zero/isZeroQuery.native.js.map +1 -1
  459. package/dist/esm/zero/useQuery.js +2 -2
  460. package/dist/esm/zero/useQuery.js.map +1 -1
  461. package/dist/esm/zero/useQuery.native.js.map +1 -1
  462. package/package.json +10 -10
@@ -1,68 +1,67 @@
1
1
  "use strict";
2
- var import_vitest = require("vitest"), import_getPathFromState = require("../getPathFromState"), import_getStateFromPath = require("../getStateFromPath");
3
- (0, import_vitest.test)("converts state to path string", function() {
2
+
3
+ var import_vitest = require("vitest"),
4
+ import_getPathFromState = require("../getPathFromState.native.js"),
5
+ import_getStateFromPath = require("../getStateFromPath.native.js");
6
+ (0, import_vitest.test)("converts state to path string", function () {
4
7
  var state = {
5
- routes: [
6
- {
8
+ routes: [{
7
9
  name: "foo",
8
10
  state: {
9
11
  index: 1,
10
- routes: [
11
- {
12
- name: "boo"
12
+ routes: [{
13
+ name: "boo"
14
+ }, {
15
+ name: "bar",
16
+ params: {
17
+ fruit: "apple"
13
18
  },
14
- {
15
- name: "bar",
16
- params: {
17
- fruit: "apple"
18
- },
19
- state: {
20
- routes: [
21
- {
22
- name: "baz qux",
23
- params: {
24
- author: "jane",
25
- valid: !0
26
- }
27
- }
28
- ]
29
- }
19
+ state: {
20
+ routes: [{
21
+ name: "baz qux",
22
+ params: {
23
+ author: "jane",
24
+ valid: !0
25
+ }
26
+ }]
30
27
  }
31
- ]
28
+ }]
32
29
  }
33
- }
34
- ]
35
- }, path = "/foo/bar/baz%20qux?author=jane&valid=true";
30
+ }]
31
+ },
32
+ path = "/foo/bar/baz%20qux?author=jane&valid=true";
36
33
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path))).toBe(path);
37
34
  });
38
- (0, import_vitest.test)("converts state to path string with config", function() {
39
- var path = "/few/bar/sweet/apple/baz/jane?id=x10&valid=true", config = {
40
- screens: {
41
- Foo: {
42
- path: "few",
43
- screens: {
44
- Bar: {
45
- path: "bar/:type/:fruit",
46
- screens: {
47
- Baz: {
48
- path: "baz/:author",
49
- parse: {
50
- author: function(author) {
51
- return author.replace(/^\w/, function(c) {
52
- return c.toUpperCase();
53
- });
54
- },
55
- id: function(id) {
56
- return Number(id.replace(/^x/, ""));
57
- },
58
- valid: Boolean
59
- },
60
- stringify: {
61
- author: function(author) {
62
- return author.toLowerCase();
35
+ (0, import_vitest.test)("converts state to path string with config", function () {
36
+ var path = "/few/bar/sweet/apple/baz/jane?id=x10&valid=true",
37
+ config = {
38
+ screens: {
39
+ Foo: {
40
+ path: "few",
41
+ screens: {
42
+ Bar: {
43
+ path: "bar/:type/:fruit",
44
+ screens: {
45
+ Baz: {
46
+ path: "baz/:author",
47
+ parse: {
48
+ author: function (author) {
49
+ return author.replace(/^\w/, function (c) {
50
+ return c.toUpperCase();
51
+ });
52
+ },
53
+ id: function (id) {
54
+ return Number(id.replace(/^x/, ""));
55
+ },
56
+ valid: Boolean
63
57
  },
64
- id: function(id) {
65
- return `x${id}`;
58
+ stringify: {
59
+ author: function (author) {
60
+ return author.toLowerCase();
61
+ },
62
+ id: function (id) {
63
+ return `x${id}`;
64
+ }
66
65
  }
67
66
  }
68
67
  }
@@ -70,134 +69,117 @@ var import_vitest = require("vitest"), import_getPathFromState = require("../get
70
69
  }
71
70
  }
72
71
  }
73
- }
74
- }, state = {
75
- routes: [
76
- {
72
+ },
73
+ state = {
74
+ routes: [{
77
75
  name: "Foo",
78
76
  state: {
79
77
  index: 1,
80
- routes: [
81
- {
82
- name: "boo"
78
+ routes: [{
79
+ name: "boo"
80
+ }, {
81
+ name: "Bar",
82
+ params: {
83
+ fruit: "apple",
84
+ type: "sweet",
85
+ avaliable: !1
83
86
  },
84
- {
85
- name: "Bar",
86
- params: {
87
- fruit: "apple",
88
- type: "sweet",
89
- avaliable: !1
90
- },
91
- state: {
92
- routes: [
93
- {
94
- name: "Baz",
95
- params: {
96
- author: "Jane",
97
- id: 10,
98
- valid: !0
99
- }
100
- }
101
- ]
102
- }
87
+ state: {
88
+ routes: [{
89
+ name: "Baz",
90
+ params: {
91
+ author: "Jane",
92
+ id: 10,
93
+ valid: !0
94
+ }
95
+ }]
103
96
  }
104
- ]
97
+ }]
105
98
  }
106
- }
107
- ]
108
- };
99
+ }]
100
+ };
109
101
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
110
102
  });
111
- (0, import_vitest.test)("prepends trailing slash to path", function() {
103
+ (0, import_vitest.test)("prepends trailing slash to path", function () {
112
104
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)({
113
- routes: [
114
- {
115
- name: "foo",
116
- state: {
117
- routes: [
118
- {
119
- name: "bar"
120
- }
121
- ]
122
- }
105
+ routes: [{
106
+ name: "foo",
107
+ state: {
108
+ routes: [{
109
+ name: "bar"
110
+ }]
123
111
  }
124
- ]
112
+ }]
125
113
  })).toBe("/foo/bar"), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)({
126
- routes: [
127
- {
128
- name: "foo",
129
- state: {
130
- routes: [
131
- {
132
- name: "bar",
133
- path: "foo/bar"
134
- }
135
- ]
136
- }
137
- }
138
- ]
114
+ routes: [{
115
+ name: "foo",
116
+ state: {
117
+ routes: [{
118
+ name: "bar",
119
+ path: "foo/bar"
120
+ }]
121
+ }
122
+ }]
139
123
  })).toBe("/foo/bar");
140
124
  });
141
- (0, import_vitest.test)("handles route without param", function() {
142
- var path = "/foo/bar", state = {
143
- routes: [
144
- {
125
+ (0, import_vitest.test)("handles route without param", function () {
126
+ var path = "/foo/bar",
127
+ state = {
128
+ routes: [{
145
129
  name: "foo",
146
130
  state: {
147
- routes: [
148
- {
149
- name: "bar"
150
- }
151
- ]
131
+ routes: [{
132
+ name: "bar"
133
+ }]
152
134
  }
153
- }
154
- ]
155
- };
135
+ }]
136
+ };
156
137
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path))).toBe(path);
157
138
  });
158
- (0, import_vitest.test)("doesn't add query param for empty params", function() {
159
- var path = "/foo", state = {
160
- routes: [
161
- {
139
+ (0, import_vitest.test)("doesn't add query param for empty params", function () {
140
+ var path = "/foo",
141
+ state = {
142
+ routes: [{
162
143
  name: "foo",
163
144
  params: {}
164
- }
165
- ]
166
- };
145
+ }]
146
+ };
167
147
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path))).toBe(path);
168
148
  });
169
- (0, import_vitest.test)("handles state with config with nested screens", function() {
170
- var path = "/foo/foe/bar/sweet/apple/baz/jane?answer=42&count=10&valid=true", config = {
171
- screens: {
172
- Foo: {
173
- path: "foo",
174
- screens: {
175
- Foe: {
176
- path: "foe",
177
- screens: {
178
- Bar: {
179
- path: "bar/:type/:fruit",
180
- screens: {
181
- Baz: {
182
- path: "baz/:author",
183
- parse: {
184
- author: function(author) {
185
- return author.replace(/^\w/, function(c) {
186
- return c.toUpperCase();
187
- });
188
- },
189
- count: Number,
190
- valid: Boolean
191
- },
192
- stringify: {
193
- author: function(author) {
194
- return author.toLowerCase();
195
- },
196
- id: function(id) {
197
- return `x${id}`;
149
+ (0, import_vitest.test)("handles state with config with nested screens", function () {
150
+ var path = "/foo/foe/bar/sweet/apple/baz/jane?answer=42&count=10&valid=true",
151
+ config = {
152
+ screens: {
153
+ Foo: {
154
+ path: "foo",
155
+ screens: {
156
+ Foe: {
157
+ path: "foe",
158
+ screens: {
159
+ Bar: {
160
+ path: "bar/:type/:fruit",
161
+ screens: {
162
+ Baz: {
163
+ path: "baz/:author",
164
+ parse: {
165
+ author: function (author) {
166
+ return author.replace(/^\w/, function (c) {
167
+ return c.toUpperCase();
168
+ });
169
+ },
170
+ count: Number,
171
+ valid: Boolean
198
172
  },
199
- unknown: function(_) {
200
- return "x";
173
+ stringify: {
174
+ author: function (author) {
175
+ return author.toLowerCase();
176
+ },
177
+ id: function (id) {
178
+ return `x${id}`;
179
+ },
180
+ unknown: function (_) {
181
+ return "x";
182
+ }
201
183
  }
202
184
  }
203
185
  }
@@ -207,80 +189,74 @@ var import_vitest = require("vitest"), import_getPathFromState = require("../get
207
189
  }
208
190
  }
209
191
  }
210
- }
211
- }, state = {
212
- routes: [
213
- {
192
+ },
193
+ state = {
194
+ routes: [{
214
195
  name: "Foo",
215
196
  state: {
216
- routes: [
217
- {
218
- name: "Foe",
219
- state: {
220
- routes: [
221
- {
222
- name: "Bar",
197
+ routes: [{
198
+ name: "Foe",
199
+ state: {
200
+ routes: [{
201
+ name: "Bar",
202
+ params: {
203
+ fruit: "apple",
204
+ type: "sweet"
205
+ },
206
+ state: {
207
+ routes: [{
208
+ name: "Baz",
223
209
  params: {
224
- fruit: "apple",
225
- type: "sweet"
226
- },
227
- state: {
228
- routes: [
229
- {
230
- name: "Baz",
231
- params: {
232
- answer: "42",
233
- author: "Jane",
234
- count: "10",
235
- valid: !0
236
- }
237
- }
238
- ]
210
+ answer: "42",
211
+ author: "Jane",
212
+ count: "10",
213
+ valid: !0
239
214
  }
240
- }
241
- ]
242
- }
215
+ }]
216
+ }
217
+ }]
243
218
  }
244
- ]
219
+ }]
245
220
  }
246
- }
247
- ]
248
- };
221
+ }]
222
+ };
249
223
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
250
224
  });
251
- (0, import_vitest.test)("handles state with config with nested screens and exact", function() {
252
- var path = "/foe/bar/sweet/apple/baz/jane?answer=42&count=10&valid=true", config = {
253
- screens: {
254
- Foo: {
255
- path: "foo",
256
- screens: {
257
- Foe: {
258
- path: "foe",
259
- exact: !0,
260
- screens: {
261
- Bar: {
262
- path: "bar/:type/:fruit",
263
- screens: {
264
- Baz: {
265
- path: "baz/:author",
266
- parse: {
267
- author: function(author) {
268
- return author.replace(/^\w/, function(c) {
269
- return c.toUpperCase();
270
- });
271
- },
272
- count: Number,
273
- valid: Boolean
274
- },
275
- stringify: {
276
- author: function(author) {
277
- return author.toLowerCase();
225
+ (0, import_vitest.test)("handles state with config with nested screens and exact", function () {
226
+ var path = "/foe/bar/sweet/apple/baz/jane?answer=42&count=10&valid=true",
227
+ config = {
228
+ screens: {
229
+ Foo: {
230
+ path: "foo",
231
+ screens: {
232
+ Foe: {
233
+ path: "foe",
234
+ exact: !0,
235
+ screens: {
236
+ Bar: {
237
+ path: "bar/:type/:fruit",
238
+ screens: {
239
+ Baz: {
240
+ path: "baz/:author",
241
+ parse: {
242
+ author: function (author) {
243
+ return author.replace(/^\w/, function (c) {
244
+ return c.toUpperCase();
245
+ });
246
+ },
247
+ count: Number,
248
+ valid: Boolean
278
249
  },
279
- id: function(id) {
280
- return `x${id}`;
281
- },
282
- unknown: function(_) {
283
- return "x";
250
+ stringify: {
251
+ author: function (author) {
252
+ return author.toLowerCase();
253
+ },
254
+ id: function (id) {
255
+ return `x${id}`;
256
+ },
257
+ unknown: function (_) {
258
+ return "x";
259
+ }
284
260
  }
285
261
  }
286
262
  }
@@ -290,75 +266,69 @@ var import_vitest = require("vitest"), import_getPathFromState = require("../get
290
266
  }
291
267
  }
292
268
  }
293
- }
294
- }, state = {
295
- routes: [
296
- {
269
+ },
270
+ state = {
271
+ routes: [{
297
272
  name: "Foo",
298
273
  state: {
299
- routes: [
300
- {
301
- name: "Foe",
302
- state: {
303
- routes: [
304
- {
305
- name: "Bar",
274
+ routes: [{
275
+ name: "Foe",
276
+ state: {
277
+ routes: [{
278
+ name: "Bar",
279
+ params: {
280
+ fruit: "apple",
281
+ type: "sweet"
282
+ },
283
+ state: {
284
+ routes: [{
285
+ name: "Baz",
306
286
  params: {
307
- fruit: "apple",
308
- type: "sweet"
309
- },
310
- state: {
311
- routes: [
312
- {
313
- name: "Baz",
314
- params: {
315
- answer: "42",
316
- author: "Jane",
317
- count: "10",
318
- valid: !0
319
- }
320
- }
321
- ]
287
+ answer: "42",
288
+ author: "Jane",
289
+ count: "10",
290
+ valid: !0
322
291
  }
323
- }
324
- ]
325
- }
292
+ }]
293
+ }
294
+ }]
326
295
  }
327
- ]
296
+ }]
328
297
  }
329
- }
330
- ]
331
- };
298
+ }]
299
+ };
332
300
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
333
301
  });
334
- (0, import_vitest.test)("handles state with config with nested screens and unused configs", function() {
335
- var path = "/foo/foe/baz/jane?answer=42&count=10&valid=true", config = {
336
- screens: {
337
- Foo: {
338
- path: "foo",
339
- screens: {
340
- Foe: {
341
- path: "foe",
342
- screens: {
343
- Baz: {
344
- path: "baz/:author",
345
- parse: {
346
- author: function(author) {
347
- return author.replace(/^\w/, function(c) {
348
- return c.toUpperCase();
349
- });
350
- },
351
- count: Number,
352
- valid: Boolean
353
- },
354
- stringify: {
355
- author: function(author) {
356
- return author.replace(/^\w/, function(c) {
357
- return c.toLowerCase();
358
- });
302
+ (0, import_vitest.test)("handles state with config with nested screens and unused configs", function () {
303
+ var path = "/foo/foe/baz/jane?answer=42&count=10&valid=true",
304
+ config = {
305
+ screens: {
306
+ Foo: {
307
+ path: "foo",
308
+ screens: {
309
+ Foe: {
310
+ path: "foe",
311
+ screens: {
312
+ Baz: {
313
+ path: "baz/:author",
314
+ parse: {
315
+ author: function (author) {
316
+ return author.replace(/^\w/, function (c) {
317
+ return c.toUpperCase();
318
+ });
319
+ },
320
+ count: Number,
321
+ valid: Boolean
359
322
  },
360
- unknown: function(_) {
361
- return "x";
323
+ stringify: {
324
+ author: function (author) {
325
+ return author.replace(/^\w/, function (c) {
326
+ return c.toLowerCase();
327
+ });
328
+ },
329
+ unknown: function (_) {
330
+ return "x";
331
+ }
362
332
  }
363
333
  }
364
334
  }
@@ -366,65 +336,61 @@ var import_vitest = require("vitest"), import_getPathFromState = require("../get
366
336
  }
367
337
  }
368
338
  }
369
- }
370
- }, state = {
371
- routes: [
372
- {
339
+ },
340
+ state = {
341
+ routes: [{
373
342
  name: "Foo",
374
343
  state: {
375
- routes: [
376
- {
377
- name: "Foe",
378
- state: {
379
- routes: [
380
- {
381
- name: "Baz",
382
- params: {
383
- answer: "42",
384
- author: "Jane",
385
- count: 10,
386
- valid: !0
387
- }
388
- }
389
- ]
390
- }
344
+ routes: [{
345
+ name: "Foe",
346
+ state: {
347
+ routes: [{
348
+ name: "Baz",
349
+ params: {
350
+ answer: "42",
351
+ author: "Jane",
352
+ count: 10,
353
+ valid: !0
354
+ }
355
+ }]
391
356
  }
392
- ]
357
+ }]
393
358
  }
394
- }
395
- ]
396
- };
359
+ }]
360
+ };
397
361
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
398
362
  });
399
- (0, import_vitest.test)("handles state with config with nested screens and unused configs with exact", function() {
400
- var path = "/foe/baz/jane?answer=42&count=10&valid=true", config = {
401
- screens: {
402
- Foo: {
403
- path: "foo",
404
- screens: {
405
- Foe: {
406
- path: "foe",
407
- exact: !0,
408
- screens: {
409
- Baz: {
410
- path: "baz/:author",
411
- parse: {
412
- author: function(author) {
413
- return author.replace(/^\w/, function(c) {
414
- return c.toUpperCase();
415
- });
416
- },
417
- count: Number,
418
- valid: Boolean
419
- },
420
- stringify: {
421
- author: function(author) {
422
- return author.replace(/^\w/, function(c) {
423
- return c.toLowerCase();
424
- });
363
+ (0, import_vitest.test)("handles state with config with nested screens and unused configs with exact", function () {
364
+ var path = "/foe/baz/jane?answer=42&count=10&valid=true",
365
+ config = {
366
+ screens: {
367
+ Foo: {
368
+ path: "foo",
369
+ screens: {
370
+ Foe: {
371
+ path: "foe",
372
+ exact: !0,
373
+ screens: {
374
+ Baz: {
375
+ path: "baz/:author",
376
+ parse: {
377
+ author: function (author) {
378
+ return author.replace(/^\w/, function (c) {
379
+ return c.toUpperCase();
380
+ });
381
+ },
382
+ count: Number,
383
+ valid: Boolean
425
384
  },
426
- unknown: function(_) {
427
- return "x";
385
+ stringify: {
386
+ author: function (author) {
387
+ return author.replace(/^\w/, function (c) {
388
+ return c.toLowerCase();
389
+ });
390
+ },
391
+ unknown: function (_) {
392
+ return "x";
393
+ }
428
394
  }
429
395
  }
430
396
  }
@@ -432,68 +398,64 @@ var import_vitest = require("vitest"), import_getPathFromState = require("../get
432
398
  }
433
399
  }
434
400
  }
435
- }
436
- }, state = {
437
- routes: [
438
- {
401
+ },
402
+ state = {
403
+ routes: [{
439
404
  name: "Foo",
440
405
  state: {
441
- routes: [
442
- {
443
- name: "Foe",
444
- state: {
445
- routes: [
446
- {
447
- name: "Baz",
448
- params: {
449
- answer: "42",
450
- author: "Jane",
451
- count: 10,
452
- valid: !0
453
- }
454
- }
455
- ]
456
- }
406
+ routes: [{
407
+ name: "Foe",
408
+ state: {
409
+ routes: [{
410
+ name: "Baz",
411
+ params: {
412
+ answer: "42",
413
+ author: "Jane",
414
+ count: 10,
415
+ valid: !0
416
+ }
417
+ }]
457
418
  }
458
- ]
419
+ }]
459
420
  }
460
- }
461
- ]
462
- };
421
+ }]
422
+ };
463
423
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
464
424
  });
465
- (0, import_vitest.test)("handles nested object with stringify in it", function() {
466
- var path = "/bar/sweet/apple/foo/bis/jane?answer=42&count=10&valid=true", config = {
467
- screens: {
468
- Bar: {
469
- path: "bar/:type/:fruit",
470
- screens: {
471
- Foo: {
472
- path: "foo",
473
- screens: {
474
- Foe: {
475
- path: "foe"
476
- },
477
- Baz: {
478
- screens: {
479
- Bos: "bos",
480
- Bis: {
481
- path: "bis/:author",
482
- stringify: {
483
- author: function(author) {
484
- return author.replace(/^\w/, function(c) {
485
- return c.toLowerCase();
486
- });
487
- }
488
- },
489
- parse: {
490
- author: function(author) {
491
- return author.replace(/^\w/, function(c) {
492
- return c.toUpperCase();
493
- });
425
+ (0, import_vitest.test)("handles nested object with stringify in it", function () {
426
+ var path = "/bar/sweet/apple/foo/bis/jane?answer=42&count=10&valid=true",
427
+ config = {
428
+ screens: {
429
+ Bar: {
430
+ path: "bar/:type/:fruit",
431
+ screens: {
432
+ Foo: {
433
+ path: "foo",
434
+ screens: {
435
+ Foe: {
436
+ path: "foe"
437
+ },
438
+ Baz: {
439
+ screens: {
440
+ Bos: "bos",
441
+ Bis: {
442
+ path: "bis/:author",
443
+ stringify: {
444
+ author: function (author) {
445
+ return author.replace(/^\w/, function (c) {
446
+ return c.toLowerCase();
447
+ });
448
+ }
494
449
  },
495
- count: Number,
496
- valid: Boolean
450
+ parse: {
451
+ author: function (author) {
452
+ return author.replace(/^\w/, function (c) {
453
+ return c.toUpperCase();
454
+ });
455
+ },
456
+ count: Number,
457
+ valid: Boolean
458
+ }
497
459
  }
498
460
  }
499
461
  }
@@ -502,81 +464,75 @@ var import_vitest = require("vitest"), import_getPathFromState = require("../get
502
464
  }
503
465
  }
504
466
  }
505
- }
506
- }, state = {
507
- routes: [
508
- {
467
+ },
468
+ state = {
469
+ routes: [{
509
470
  name: "Bar",
510
471
  params: {
511
472
  fruit: "apple",
512
473
  type: "sweet"
513
474
  },
514
475
  state: {
515
- routes: [
516
- {
517
- name: "Foo",
518
- state: {
519
- routes: [
520
- {
521
- name: "Baz",
522
- state: {
523
- routes: [
524
- {
525
- name: "Bis",
526
- params: {
527
- answer: "42",
528
- author: "Jane",
529
- count: 10,
530
- valid: !0
531
- }
532
- }
533
- ]
476
+ routes: [{
477
+ name: "Foo",
478
+ state: {
479
+ routes: [{
480
+ name: "Baz",
481
+ state: {
482
+ routes: [{
483
+ name: "Bis",
484
+ params: {
485
+ answer: "42",
486
+ author: "Jane",
487
+ count: 10,
488
+ valid: !0
534
489
  }
535
- }
536
- ]
537
- }
490
+ }]
491
+ }
492
+ }]
538
493
  }
539
- ]
494
+ }]
540
495
  }
541
- }
542
- ]
543
- };
496
+ }]
497
+ };
544
498
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
545
499
  });
546
- (0, import_vitest.test)("handles nested object with stringify in it with exact", function() {
547
- var path = "/bis/jane?answer=42&count=10&valid=true", config = {
548
- screens: {
549
- Bar: {
550
- path: "bar/:type/:fruit",
551
- screens: {
552
- Foo: {
553
- path: "foo",
554
- screens: {
555
- Foe: {
556
- path: "foe"
557
- },
558
- Baz: {
559
- path: "baz",
560
- screens: {
561
- Bos: "bos",
562
- Bis: {
563
- path: "bis/:author",
564
- exact: !0,
565
- stringify: {
566
- author: function(author) {
567
- return author.replace(/^\w/, function(c) {
568
- return c.toLowerCase();
569
- });
570
- }
571
- },
572
- parse: {
573
- author: function(author) {
574
- return author.replace(/^\w/, function(c) {
575
- return c.toUpperCase();
576
- });
500
+ (0, import_vitest.test)("handles nested object with stringify in it with exact", function () {
501
+ var path = "/bis/jane?answer=42&count=10&valid=true",
502
+ config = {
503
+ screens: {
504
+ Bar: {
505
+ path: "bar/:type/:fruit",
506
+ screens: {
507
+ Foo: {
508
+ path: "foo",
509
+ screens: {
510
+ Foe: {
511
+ path: "foe"
512
+ },
513
+ Baz: {
514
+ path: "baz",
515
+ screens: {
516
+ Bos: "bos",
517
+ Bis: {
518
+ path: "bis/:author",
519
+ exact: !0,
520
+ stringify: {
521
+ author: function (author) {
522
+ return author.replace(/^\w/, function (c) {
523
+ return c.toLowerCase();
524
+ });
525
+ }
577
526
  },
578
- count: Number,
579
- valid: Boolean
527
+ parse: {
528
+ author: function (author) {
529
+ return author.replace(/^\w/, function (c) {
530
+ return c.toUpperCase();
531
+ });
532
+ },
533
+ count: Number,
534
+ valid: Boolean
535
+ }
580
536
  }
581
537
  }
582
538
  }
@@ -585,554 +541,506 @@ var import_vitest = require("vitest"), import_getPathFromState = require("../get
585
541
  }
586
542
  }
587
543
  }
588
- }
589
- }, state = {
590
- routes: [
591
- {
544
+ },
545
+ state = {
546
+ routes: [{
592
547
  name: "Bar",
593
548
  params: {
594
549
  fruit: "apple",
595
550
  type: "sweet"
596
551
  },
597
552
  state: {
598
- routes: [
599
- {
600
- name: "Foo",
601
- state: {
602
- routes: [
603
- {
604
- name: "Baz",
605
- state: {
606
- routes: [
607
- {
608
- name: "Bis",
609
- params: {
610
- answer: "42",
611
- author: "Jane",
612
- count: 10,
613
- valid: !0
614
- }
615
- }
616
- ]
553
+ routes: [{
554
+ name: "Foo",
555
+ state: {
556
+ routes: [{
557
+ name: "Baz",
558
+ state: {
559
+ routes: [{
560
+ name: "Bis",
561
+ params: {
562
+ answer: "42",
563
+ author: "Jane",
564
+ count: 10,
565
+ valid: !0
617
566
  }
618
- }
619
- ]
620
- }
567
+ }]
568
+ }
569
+ }]
621
570
  }
622
- ]
571
+ }]
623
572
  }
624
- }
625
- ]
626
- };
573
+ }]
574
+ };
627
575
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
628
576
  });
629
- (0, import_vitest.test)("handles nested object for second route depth", function() {
630
- var path = "/foo/bar/baz", config = {
631
- screens: {
632
- Foo: {
633
- path: "foo",
634
- screens: {
635
- Foe: "foe",
636
- Bar: {
637
- path: "bar",
638
- screens: {
639
- Baz: "baz"
577
+ (0, import_vitest.test)("handles nested object for second route depth", function () {
578
+ var path = "/foo/bar/baz",
579
+ config = {
580
+ screens: {
581
+ Foo: {
582
+ path: "foo",
583
+ screens: {
584
+ Foe: "foe",
585
+ Bar: {
586
+ path: "bar",
587
+ screens: {
588
+ Baz: "baz"
589
+ }
640
590
  }
641
591
  }
642
592
  }
643
593
  }
644
- }
645
- }, state = {
646
- routes: [
647
- {
594
+ },
595
+ state = {
596
+ routes: [{
648
597
  name: "Foo",
649
598
  state: {
650
- routes: [
651
- {
652
- name: "Bar",
653
- state: {
654
- routes: [
655
- {
656
- name: "Baz"
657
- }
658
- ]
659
- }
599
+ routes: [{
600
+ name: "Bar",
601
+ state: {
602
+ routes: [{
603
+ name: "Baz"
604
+ }]
660
605
  }
661
- ]
606
+ }]
662
607
  }
663
- }
664
- ]
665
- };
608
+ }]
609
+ };
666
610
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
667
611
  });
668
- (0, import_vitest.test)("handles nested object for second route depth with exact", function() {
669
- var path = "/baz", config = {
670
- screens: {
671
- Foo: {
672
- path: "foo",
673
- screens: {
674
- Foe: "foe",
675
- Bar: {
676
- path: "bar",
677
- screens: {
678
- Baz: {
679
- path: "baz",
680
- exact: !0
612
+ (0, import_vitest.test)("handles nested object for second route depth with exact", function () {
613
+ var path = "/baz",
614
+ config = {
615
+ screens: {
616
+ Foo: {
617
+ path: "foo",
618
+ screens: {
619
+ Foe: "foe",
620
+ Bar: {
621
+ path: "bar",
622
+ screens: {
623
+ Baz: {
624
+ path: "baz",
625
+ exact: !0
626
+ }
681
627
  }
682
628
  }
683
629
  }
684
630
  }
685
631
  }
686
- }
687
- }, state = {
688
- routes: [
689
- {
632
+ },
633
+ state = {
634
+ routes: [{
690
635
  name: "Foo",
691
636
  state: {
692
- routes: [
693
- {
694
- name: "Bar",
695
- state: {
696
- routes: [
697
- {
698
- name: "Baz"
699
- }
700
- ]
701
- }
637
+ routes: [{
638
+ name: "Bar",
639
+ state: {
640
+ routes: [{
641
+ name: "Baz"
642
+ }]
702
643
  }
703
- ]
644
+ }]
704
645
  }
705
- }
706
- ]
707
- };
646
+ }]
647
+ };
708
648
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
709
649
  });
710
- (0, import_vitest.test)("handles nested object for second route depth and path and stringify in roots", function() {
711
- var path = "/foo/dathomir/bar/42/baz", config = {
712
- screens: {
713
- Foo: {
714
- path: "foo/:planet",
715
- stringify: {
716
- id: function(id) {
717
- return `planet=${id}`;
718
- }
719
- },
720
- screens: {
721
- Foe: "foe",
722
- Bar: {
723
- path: "bar/:id",
724
- parse: {
725
- id: Number
726
- },
727
- screens: {
728
- Baz: "baz"
650
+ (0, import_vitest.test)("handles nested object for second route depth and path and stringify in roots", function () {
651
+ var path = "/foo/dathomir/bar/42/baz",
652
+ config = {
653
+ screens: {
654
+ Foo: {
655
+ path: "foo/:planet",
656
+ stringify: {
657
+ id: function (id) {
658
+ return `planet=${id}`;
659
+ }
660
+ },
661
+ screens: {
662
+ Foe: "foe",
663
+ Bar: {
664
+ path: "bar/:id",
665
+ parse: {
666
+ id: Number
667
+ },
668
+ screens: {
669
+ Baz: "baz"
670
+ }
729
671
  }
730
672
  }
731
673
  }
732
674
  }
733
- }
734
- }, state = {
735
- routes: [
736
- {
675
+ },
676
+ state = {
677
+ routes: [{
737
678
  name: "Foo",
738
679
  params: {
739
680
  planet: "dathomir"
740
681
  },
741
682
  state: {
742
- routes: [
743
- {
744
- name: "Bar",
745
- state: {
746
- routes: [
747
- {
748
- name: "Baz",
749
- params: {
750
- id: 42
751
- }
752
- }
753
- ]
754
- }
683
+ routes: [{
684
+ name: "Bar",
685
+ state: {
686
+ routes: [{
687
+ name: "Baz",
688
+ params: {
689
+ id: 42
690
+ }
691
+ }]
755
692
  }
756
- ]
693
+ }]
757
694
  }
758
- }
759
- ]
760
- };
695
+ }]
696
+ };
761
697
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
762
698
  });
763
- (0, import_vitest.test)("handles nested object for second route depth and path and stringify in roots with exact", function() {
764
- var path = "/baz", config = {
765
- screens: {
766
- Foo: {
767
- path: "foo/:id",
768
- stringify: {
769
- id: function(id) {
770
- return `id=${id}`;
771
- }
772
- },
773
- screens: {
774
- Foe: "foe",
775
- Bar: {
776
- path: "bar/:id",
777
- stringify: {
778
- id: function(id) {
779
- return `id=${id}`;
780
- }
781
- },
782
- parse: {
783
- id: Number
784
- },
785
- screens: {
786
- Baz: {
787
- path: "baz",
788
- exact: !0
699
+ (0, import_vitest.test)("handles nested object for second route depth and path and stringify in roots with exact", function () {
700
+ var path = "/baz",
701
+ config = {
702
+ screens: {
703
+ Foo: {
704
+ path: "foo/:id",
705
+ stringify: {
706
+ id: function (id) {
707
+ return `id=${id}`;
708
+ }
709
+ },
710
+ screens: {
711
+ Foe: "foe",
712
+ Bar: {
713
+ path: "bar/:id",
714
+ stringify: {
715
+ id: function (id) {
716
+ return `id=${id}`;
717
+ }
718
+ },
719
+ parse: {
720
+ id: Number
721
+ },
722
+ screens: {
723
+ Baz: {
724
+ path: "baz",
725
+ exact: !0
726
+ }
789
727
  }
790
728
  }
791
729
  }
792
730
  }
793
731
  }
794
- }
795
- }, state = {
796
- routes: [
797
- {
732
+ },
733
+ state = {
734
+ routes: [{
798
735
  name: "Foo",
799
736
  state: {
800
- routes: [
801
- {
802
- name: "Bar",
803
- state: {
804
- routes: [
805
- {
806
- name: "Baz"
807
- }
808
- ]
809
- }
737
+ routes: [{
738
+ name: "Bar",
739
+ state: {
740
+ routes: [{
741
+ name: "Baz"
742
+ }]
810
743
  }
811
- ]
744
+ }]
812
745
  }
813
- }
814
- ]
815
- };
746
+ }]
747
+ };
816
748
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
817
749
  });
818
- (0, import_vitest.test)("ignores empty string paths", function() {
819
- var path = "/bar", config = {
820
- screens: {
821
- Foo: {
822
- path: "",
823
- screens: {
824
- Foe: "foe"
825
- }
826
- },
827
- Bar: "bar"
828
- }
829
- }, state = {
830
- routes: [
831
- {
750
+ (0, import_vitest.test)("ignores empty string paths", function () {
751
+ var path = "/bar",
752
+ config = {
753
+ screens: {
754
+ Foo: {
755
+ path: "",
756
+ screens: {
757
+ Foe: "foe"
758
+ }
759
+ },
760
+ Bar: "bar"
761
+ }
762
+ },
763
+ state = {
764
+ routes: [{
832
765
  name: "Foo",
833
766
  state: {
834
- routes: [
835
- {
836
- name: "Bar"
837
- }
838
- ]
767
+ routes: [{
768
+ name: "Bar"
769
+ }]
839
770
  }
840
- }
841
- ]
842
- };
771
+ }]
772
+ };
843
773
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
844
774
  });
845
- (0, import_vitest.test)("keeps query params if path is empty", function() {
846
- var path = "/?foo=42", config = {
847
- screens: {
848
- Foo: {
849
- screens: {
850
- Foe: "foe",
851
- Bar: {
852
- screens: {
853
- Qux: {
854
- path: "",
855
- parse: {
856
- foo: Number
857
- }
858
- },
859
- Baz: "baz"
775
+ (0, import_vitest.test)("keeps query params if path is empty", function () {
776
+ var path = "/?foo=42",
777
+ config = {
778
+ screens: {
779
+ Foo: {
780
+ screens: {
781
+ Foe: "foe",
782
+ Bar: {
783
+ screens: {
784
+ Qux: {
785
+ path: "",
786
+ parse: {
787
+ foo: Number
788
+ }
789
+ },
790
+ Baz: "baz"
791
+ }
860
792
  }
861
793
  }
862
794
  }
863
795
  }
864
- }
865
- }, state = {
866
- routes: [
867
- {
796
+ },
797
+ state = {
798
+ routes: [{
868
799
  name: "Foo",
869
800
  state: {
870
- routes: [
871
- {
872
- name: "Bar",
873
- state: {
874
- routes: [
875
- {
876
- name: "Qux",
877
- params: {
878
- foo: 42
879
- }
880
- }
881
- ]
882
- }
801
+ routes: [{
802
+ name: "Bar",
803
+ state: {
804
+ routes: [{
805
+ name: "Qux",
806
+ params: {
807
+ foo: 42
808
+ }
809
+ }]
883
810
  }
884
- ]
811
+ }]
885
812
  }
886
- }
887
- ]
888
- };
813
+ }]
814
+ };
889
815
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toEqual(path);
890
816
  });
891
- (0, import_vitest.test)("does not use Object.prototype properties as parsing functions", function() {
892
- var path = "/?toString=42", config = {
893
- screens: {
894
- Foo: {
895
- screens: {
896
- Foe: "foe",
897
- Bar: {
898
- screens: {
899
- Qux: {
900
- path: "",
901
- parse: {}
902
- },
903
- Baz: "baz"
817
+ (0, import_vitest.test)("does not use Object.prototype properties as parsing functions", function () {
818
+ var path = "/?toString=42",
819
+ config = {
820
+ screens: {
821
+ Foo: {
822
+ screens: {
823
+ Foe: "foe",
824
+ Bar: {
825
+ screens: {
826
+ Qux: {
827
+ path: "",
828
+ parse: {}
829
+ },
830
+ Baz: "baz"
831
+ }
904
832
  }
905
833
  }
906
834
  }
907
835
  }
908
- }
909
- }, state = {
910
- routes: [
911
- {
836
+ },
837
+ state = {
838
+ routes: [{
912
839
  name: "Foo",
913
840
  state: {
914
- routes: [
915
- {
916
- name: "Bar",
917
- state: {
918
- routes: [
919
- {
920
- name: "Qux",
921
- params: {
922
- toString: 42
923
- }
924
- }
925
- ]
926
- }
841
+ routes: [{
842
+ name: "Bar",
843
+ state: {
844
+ routes: [{
845
+ name: "Qux",
846
+ params: {
847
+ toString: 42
848
+ }
849
+ }]
927
850
  }
928
- ]
851
+ }]
929
852
  }
930
- }
931
- ]
932
- };
853
+ }]
854
+ };
933
855
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toEqual(path);
934
856
  });
935
- (0, import_vitest.test)("cuts nested configs too", function() {
936
- var path = "/foo/baz", config = {
937
- screens: {
938
- Foo: {
939
- path: "foo",
940
- screens: {
941
- Bar: {
942
- path: "",
943
- screens: {
944
- Baz: {
945
- path: "baz"
857
+ (0, import_vitest.test)("cuts nested configs too", function () {
858
+ var path = "/foo/baz",
859
+ config = {
860
+ screens: {
861
+ Foo: {
862
+ path: "foo",
863
+ screens: {
864
+ Bar: {
865
+ path: "",
866
+ screens: {
867
+ Baz: {
868
+ path: "baz"
869
+ }
946
870
  }
947
871
  }
948
872
  }
949
873
  }
950
874
  }
951
- }
952
- }, state = {
953
- routes: [
954
- {
875
+ },
876
+ state = {
877
+ routes: [{
955
878
  name: "Foo",
956
879
  state: {
957
- routes: [
958
- {
959
- name: "Bar",
960
- state: {
961
- routes: [
962
- {
963
- name: "Baz"
964
- }
965
- ]
966
- }
880
+ routes: [{
881
+ name: "Bar",
882
+ state: {
883
+ routes: [{
884
+ name: "Baz"
885
+ }]
967
886
  }
968
- ]
887
+ }]
969
888
  }
970
- }
971
- ]
972
- };
889
+ }]
890
+ };
973
891
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
974
892
  });
975
- (0, import_vitest.test)("cuts nested configs too with exact", function() {
976
- var path = "/baz", config = {
977
- screens: {
978
- Foo: {
979
- path: "foo",
980
- screens: {
981
- Bar: {
982
- path: "",
983
- exact: !0,
984
- screens: {
985
- Baz: {
986
- path: "baz"
893
+ (0, import_vitest.test)("cuts nested configs too with exact", function () {
894
+ var path = "/baz",
895
+ config = {
896
+ screens: {
897
+ Foo: {
898
+ path: "foo",
899
+ screens: {
900
+ Bar: {
901
+ path: "",
902
+ exact: !0,
903
+ screens: {
904
+ Baz: {
905
+ path: "baz"
906
+ }
987
907
  }
988
908
  }
989
909
  }
990
910
  }
991
911
  }
992
- }
993
- }, state = {
994
- routes: [
995
- {
912
+ },
913
+ state = {
914
+ routes: [{
996
915
  name: "Foo",
997
916
  state: {
998
- routes: [
999
- {
1000
- name: "Bar",
1001
- state: {
1002
- routes: [
1003
- {
1004
- name: "Baz"
1005
- }
1006
- ]
1007
- }
917
+ routes: [{
918
+ name: "Bar",
919
+ state: {
920
+ routes: [{
921
+ name: "Baz"
922
+ }]
1008
923
  }
1009
- ]
924
+ }]
1010
925
  }
1011
- }
1012
- ]
1013
- };
926
+ }]
927
+ };
1014
928
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
1015
929
  });
1016
- (0, import_vitest.test)("handles empty path at the end", function() {
1017
- var path = "/foo/bar", config = {
1018
- screens: {
1019
- Foo: {
1020
- path: "foo",
1021
- screens: {
1022
- Bar: "bar"
930
+ (0, import_vitest.test)("handles empty path at the end", function () {
931
+ var path = "/foo/bar",
932
+ config = {
933
+ screens: {
934
+ Foo: {
935
+ path: "foo",
936
+ screens: {
937
+ Bar: "bar"
938
+ }
939
+ },
940
+ Baz: {
941
+ path: ""
1023
942
  }
1024
- },
1025
- Baz: {
1026
- path: ""
1027
943
  }
1028
- }
1029
- }, state = {
1030
- routes: [
1031
- {
944
+ },
945
+ state = {
946
+ routes: [{
1032
947
  name: "Foo",
1033
948
  state: {
1034
- routes: [
1035
- {
1036
- name: "Bar",
1037
- state: {
1038
- routes: [
1039
- {
1040
- name: "Baz"
1041
- }
1042
- ]
1043
- }
949
+ routes: [{
950
+ name: "Bar",
951
+ state: {
952
+ routes: [{
953
+ name: "Baz"
954
+ }]
1044
955
  }
1045
- ]
956
+ }]
1046
957
  }
1047
- }
1048
- ]
1049
- };
958
+ }]
959
+ };
1050
960
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
1051
961
  });
1052
- (0, import_vitest.test)('returns "/" for empty path', function() {
1053
- var path = "/", config = {
1054
- screens: {
1055
- Foo: {
1056
- path: "",
1057
- screens: {
1058
- Bar: ""
962
+ (0, import_vitest.test)('returns "/" for empty path', function () {
963
+ var path = "/",
964
+ config = {
965
+ screens: {
966
+ Foo: {
967
+ path: "",
968
+ screens: {
969
+ Bar: ""
970
+ }
1059
971
  }
1060
972
  }
1061
- }
1062
- }, state = {
1063
- routes: [
1064
- {
973
+ },
974
+ state = {
975
+ routes: [{
1065
976
  name: "Foo",
1066
977
  state: {
1067
- routes: [
1068
- {
1069
- name: "Bar"
1070
- }
1071
- ]
978
+ routes: [{
979
+ name: "Bar"
980
+ }]
1072
981
  }
1073
- }
1074
- ]
1075
- };
982
+ }]
983
+ };
1076
984
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
1077
985
  });
1078
- (0, import_vitest.test)("parses no path specified", function() {
1079
- var path = "/bar", config = {
1080
- screens: {
1081
- Foo: {
1082
- screens: {
1083
- Foe: {},
1084
- Bar: "bar"
986
+ (0, import_vitest.test)("parses no path specified", function () {
987
+ var path = "/bar",
988
+ config = {
989
+ screens: {
990
+ Foo: {
991
+ screens: {
992
+ Foe: {},
993
+ Bar: "bar"
994
+ }
1085
995
  }
1086
996
  }
1087
- }
1088
- }, state = {
1089
- routes: [
1090
- {
997
+ },
998
+ state = {
999
+ routes: [{
1091
1000
  name: "Foo",
1092
1001
  state: {
1093
- routes: [
1094
- {
1095
- name: "Bar"
1096
- }
1097
- ]
1002
+ routes: [{
1003
+ name: "Bar"
1004
+ }]
1098
1005
  }
1099
- }
1100
- ]
1101
- };
1006
+ }]
1007
+ };
1102
1008
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
1103
1009
  });
1104
- (0, import_vitest.test)("strips undefined query params", function() {
1105
- var path = "/bar/sweet/apple/foo/bis/jane?count=10&valid=true", config = {
1106
- screens: {
1107
- Bar: {
1108
- path: "bar/:type/:fruit",
1109
- screens: {
1110
- Foo: {
1111
- path: "foo",
1112
- screens: {
1113
- Foe: {
1114
- path: "foe"
1115
- },
1116
- Baz: {
1117
- screens: {
1118
- Bos: "bos",
1119
- Bis: {
1120
- path: "bis/:author",
1121
- stringify: {
1122
- author: function(author) {
1123
- return author.replace(/^\w/, function(c) {
1124
- return c.toLowerCase();
1125
- });
1126
- }
1127
- },
1128
- parse: {
1129
- author: function(author) {
1130
- return author.replace(/^\w/, function(c) {
1131
- return c.toUpperCase();
1132
- });
1010
+ (0, import_vitest.test)("strips undefined query params", function () {
1011
+ var path = "/bar/sweet/apple/foo/bis/jane?count=10&valid=true",
1012
+ config = {
1013
+ screens: {
1014
+ Bar: {
1015
+ path: "bar/:type/:fruit",
1016
+ screens: {
1017
+ Foo: {
1018
+ path: "foo",
1019
+ screens: {
1020
+ Foe: {
1021
+ path: "foe"
1022
+ },
1023
+ Baz: {
1024
+ screens: {
1025
+ Bos: "bos",
1026
+ Bis: {
1027
+ path: "bis/:author",
1028
+ stringify: {
1029
+ author: function (author) {
1030
+ return author.replace(/^\w/, function (c) {
1031
+ return c.toLowerCase();
1032
+ });
1033
+ }
1133
1034
  },
1134
- count: Number,
1135
- valid: Boolean
1035
+ parse: {
1036
+ author: function (author) {
1037
+ return author.replace(/^\w/, function (c) {
1038
+ return c.toUpperCase();
1039
+ });
1040
+ },
1041
+ count: Number,
1042
+ valid: Boolean
1043
+ }
1136
1044
  }
1137
1045
  }
1138
1046
  }
@@ -1141,79 +1049,73 @@ var import_vitest = require("vitest"), import_getPathFromState = require("../get
1141
1049
  }
1142
1050
  }
1143
1051
  }
1144
- }
1145
- }, state = {
1146
- routes: [
1147
- {
1052
+ },
1053
+ state = {
1054
+ routes: [{
1148
1055
  name: "Bar",
1149
1056
  params: {
1150
1057
  fruit: "apple",
1151
1058
  type: "sweet"
1152
1059
  },
1153
1060
  state: {
1154
- routes: [
1155
- {
1156
- name: "Foo",
1157
- state: {
1158
- routes: [
1159
- {
1160
- name: "Baz",
1161
- state: {
1162
- routes: [
1163
- {
1164
- name: "Bis",
1165
- params: {
1166
- author: "Jane",
1167
- count: 10,
1168
- valid: !0
1169
- }
1170
- }
1171
- ]
1061
+ routes: [{
1062
+ name: "Foo",
1063
+ state: {
1064
+ routes: [{
1065
+ name: "Baz",
1066
+ state: {
1067
+ routes: [{
1068
+ name: "Bis",
1069
+ params: {
1070
+ author: "Jane",
1071
+ count: 10,
1072
+ valid: !0
1172
1073
  }
1173
- }
1174
- ]
1175
- }
1074
+ }]
1075
+ }
1076
+ }]
1176
1077
  }
1177
- ]
1078
+ }]
1178
1079
  }
1179
- }
1180
- ]
1181
- };
1080
+ }]
1081
+ };
1182
1082
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
1183
1083
  });
1184
- (0, import_vitest.test)("strips undefined query params with exact", function() {
1185
- var path = "/bis/jane?count=10&valid=true", config = {
1186
- screens: {
1187
- Bar: {
1188
- path: "bar/:type/:fruit",
1189
- screens: {
1190
- Foo: {
1191
- path: "foo",
1192
- screens: {
1193
- Foe: {
1194
- path: "foe"
1195
- },
1196
- Baz: {
1197
- screens: {
1198
- Bos: "bos",
1199
- Bis: {
1200
- path: "bis/:author",
1201
- exact: !0,
1202
- stringify: {
1203
- author: function(author) {
1204
- return author.replace(/^\w/, function(c) {
1205
- return c.toLowerCase();
1206
- });
1207
- }
1208
- },
1209
- parse: {
1210
- author: function(author) {
1211
- return author.replace(/^\w/, function(c) {
1212
- return c.toUpperCase();
1213
- });
1084
+ (0, import_vitest.test)("strips undefined query params with exact", function () {
1085
+ var path = "/bis/jane?count=10&valid=true",
1086
+ config = {
1087
+ screens: {
1088
+ Bar: {
1089
+ path: "bar/:type/:fruit",
1090
+ screens: {
1091
+ Foo: {
1092
+ path: "foo",
1093
+ screens: {
1094
+ Foe: {
1095
+ path: "foe"
1096
+ },
1097
+ Baz: {
1098
+ screens: {
1099
+ Bos: "bos",
1100
+ Bis: {
1101
+ path: "bis/:author",
1102
+ exact: !0,
1103
+ stringify: {
1104
+ author: function (author) {
1105
+ return author.replace(/^\w/, function (c) {
1106
+ return c.toLowerCase();
1107
+ });
1108
+ }
1214
1109
  },
1215
- count: Number,
1216
- valid: Boolean
1110
+ parse: {
1111
+ author: function (author) {
1112
+ return author.replace(/^\w/, function (c) {
1113
+ return c.toUpperCase();
1114
+ });
1115
+ },
1116
+ count: Number,
1117
+ valid: Boolean
1118
+ }
1217
1119
  }
1218
1120
  }
1219
1121
  }
@@ -1222,78 +1124,72 @@ var import_vitest = require("vitest"), import_getPathFromState = require("../get
1222
1124
  }
1223
1125
  }
1224
1126
  }
1225
- }
1226
- }, state = {
1227
- routes: [
1228
- {
1127
+ },
1128
+ state = {
1129
+ routes: [{
1229
1130
  name: "Bar",
1230
1131
  params: {
1231
1132
  fruit: "apple",
1232
1133
  type: "sweet"
1233
1134
  },
1234
1135
  state: {
1235
- routes: [
1236
- {
1237
- name: "Foo",
1238
- state: {
1239
- routes: [
1240
- {
1241
- name: "Baz",
1242
- state: {
1243
- routes: [
1244
- {
1245
- name: "Bis",
1246
- params: {
1247
- author: "Jane",
1248
- count: 10,
1249
- valid: !0
1250
- }
1251
- }
1252
- ]
1136
+ routes: [{
1137
+ name: "Foo",
1138
+ state: {
1139
+ routes: [{
1140
+ name: "Baz",
1141
+ state: {
1142
+ routes: [{
1143
+ name: "Bis",
1144
+ params: {
1145
+ author: "Jane",
1146
+ count: 10,
1147
+ valid: !0
1253
1148
  }
1254
- }
1255
- ]
1256
- }
1149
+ }]
1150
+ }
1151
+ }]
1257
1152
  }
1258
- ]
1153
+ }]
1259
1154
  }
1260
- }
1261
- ]
1262
- };
1155
+ }]
1156
+ };
1263
1157
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
1264
1158
  });
1265
- (0, import_vitest.test)("handles stripping all query params", function() {
1266
- var path = "/bar/sweet/apple/foo/bis/jane", config = {
1267
- screens: {
1268
- Bar: {
1269
- path: "bar/:type/:fruit",
1270
- screens: {
1271
- Foo: {
1272
- path: "foo",
1273
- screens: {
1274
- Foe: {
1275
- path: "foe"
1276
- },
1277
- Baz: {
1278
- screens: {
1279
- Bos: "bos",
1280
- Bis: {
1281
- path: "bis/:author",
1282
- stringify: {
1283
- author: function(author) {
1284
- return author.replace(/^\w/, function(c) {
1285
- return c.toLowerCase();
1286
- });
1287
- }
1288
- },
1289
- parse: {
1290
- author: function(author) {
1291
- return author.replace(/^\w/, function(c) {
1292
- return c.toUpperCase();
1293
- });
1159
+ (0, import_vitest.test)("handles stripping all query params", function () {
1160
+ var path = "/bar/sweet/apple/foo/bis/jane",
1161
+ config = {
1162
+ screens: {
1163
+ Bar: {
1164
+ path: "bar/:type/:fruit",
1165
+ screens: {
1166
+ Foo: {
1167
+ path: "foo",
1168
+ screens: {
1169
+ Foe: {
1170
+ path: "foe"
1171
+ },
1172
+ Baz: {
1173
+ screens: {
1174
+ Bos: "bos",
1175
+ Bis: {
1176
+ path: "bis/:author",
1177
+ stringify: {
1178
+ author: function (author) {
1179
+ return author.replace(/^\w/, function (c) {
1180
+ return c.toLowerCase();
1181
+ });
1182
+ }
1294
1183
  },
1295
- count: Number,
1296
- valid: Boolean
1184
+ parse: {
1185
+ author: function (author) {
1186
+ return author.replace(/^\w/, function (c) {
1187
+ return c.toUpperCase();
1188
+ });
1189
+ },
1190
+ count: Number,
1191
+ valid: Boolean
1192
+ }
1297
1193
  }
1298
1194
  }
1299
1195
  }
@@ -1302,78 +1198,72 @@ var import_vitest = require("vitest"), import_getPathFromState = require("../get
1302
1198
  }
1303
1199
  }
1304
1200
  }
1305
- }
1306
- }, state = {
1307
- routes: [
1308
- {
1201
+ },
1202
+ state = {
1203
+ routes: [{
1309
1204
  name: "Bar",
1310
1205
  params: {
1311
1206
  fruit: "apple",
1312
1207
  type: "sweet"
1313
1208
  },
1314
1209
  state: {
1315
- routes: [
1316
- {
1317
- name: "Foo",
1318
- state: {
1319
- routes: [
1320
- {
1321
- name: "Baz",
1322
- state: {
1323
- routes: [
1324
- {
1325
- name: "Bis",
1326
- params: {
1327
- author: "Jane"
1328
- }
1329
- }
1330
- ]
1210
+ routes: [{
1211
+ name: "Foo",
1212
+ state: {
1213
+ routes: [{
1214
+ name: "Baz",
1215
+ state: {
1216
+ routes: [{
1217
+ name: "Bis",
1218
+ params: {
1219
+ author: "Jane"
1331
1220
  }
1332
- }
1333
- ]
1334
- }
1221
+ }]
1222
+ }
1223
+ }]
1335
1224
  }
1336
- ]
1225
+ }]
1337
1226
  }
1338
- }
1339
- ]
1340
- };
1227
+ }]
1228
+ };
1341
1229
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
1342
1230
  });
1343
- (0, import_vitest.test)("handles stripping all query params with exact", function() {
1344
- var path = "/bis/jane", config = {
1345
- screens: {
1346
- Bar: {
1347
- path: "bar/:type/:fruit",
1348
- screens: {
1349
- Foo: {
1350
- path: "foo",
1351
- screens: {
1352
- Foe: {
1353
- path: "foe"
1354
- },
1355
- Baz: {
1356
- path: "baz",
1357
- screens: {
1358
- Bos: "bos",
1359
- Bis: {
1360
- path: "bis/:author",
1361
- exact: !0,
1362
- stringify: {
1363
- author: function(author) {
1364
- return author.replace(/^\w/, function(c) {
1365
- return c.toLowerCase();
1366
- });
1367
- }
1368
- },
1369
- parse: {
1370
- author: function(author) {
1371
- return author.replace(/^\w/, function(c) {
1372
- return c.toUpperCase();
1373
- });
1231
+ (0, import_vitest.test)("handles stripping all query params with exact", function () {
1232
+ var path = "/bis/jane",
1233
+ config = {
1234
+ screens: {
1235
+ Bar: {
1236
+ path: "bar/:type/:fruit",
1237
+ screens: {
1238
+ Foo: {
1239
+ path: "foo",
1240
+ screens: {
1241
+ Foe: {
1242
+ path: "foe"
1243
+ },
1244
+ Baz: {
1245
+ path: "baz",
1246
+ screens: {
1247
+ Bos: "bos",
1248
+ Bis: {
1249
+ path: "bis/:author",
1250
+ exact: !0,
1251
+ stringify: {
1252
+ author: function (author) {
1253
+ return author.replace(/^\w/, function (c) {
1254
+ return c.toLowerCase();
1255
+ });
1256
+ }
1374
1257
  },
1375
- count: Number,
1376
- valid: Boolean
1258
+ parse: {
1259
+ author: function (author) {
1260
+ return author.replace(/^\w/, function (c) {
1261
+ return c.toUpperCase();
1262
+ });
1263
+ },
1264
+ count: Number,
1265
+ valid: Boolean
1266
+ }
1377
1267
  }
1378
1268
  }
1379
1269
  }
@@ -1382,265 +1272,241 @@ var import_vitest = require("vitest"), import_getPathFromState = require("../get
1382
1272
  }
1383
1273
  }
1384
1274
  }
1385
- }
1386
- }, state = {
1387
- routes: [
1388
- {
1275
+ },
1276
+ state = {
1277
+ routes: [{
1389
1278
  name: "Bar",
1390
1279
  params: {
1391
1280
  fruit: "apple",
1392
1281
  type: "sweet"
1393
1282
  },
1394
1283
  state: {
1395
- routes: [
1396
- {
1397
- name: "Foo",
1398
- state: {
1399
- routes: [
1400
- {
1401
- name: "Baz",
1402
- state: {
1403
- routes: [
1404
- {
1405
- name: "Bis",
1406
- params: {
1407
- author: "Jane"
1408
- }
1409
- }
1410
- ]
1284
+ routes: [{
1285
+ name: "Foo",
1286
+ state: {
1287
+ routes: [{
1288
+ name: "Baz",
1289
+ state: {
1290
+ routes: [{
1291
+ name: "Bis",
1292
+ params: {
1293
+ author: "Jane"
1411
1294
  }
1412
- }
1413
- ]
1414
- }
1295
+ }]
1296
+ }
1297
+ }]
1415
1298
  }
1416
- ]
1299
+ }]
1417
1300
  }
1418
- }
1419
- ]
1420
- };
1301
+ }]
1302
+ };
1421
1303
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
1422
1304
  });
1423
- (0, import_vitest.test)("replaces undefined query params", function() {
1424
- var path = "/bar/undefined/apple", config = {
1425
- screens: {
1426
- Bar: "bar/:type/:fruit"
1427
- }
1428
- }, state = {
1429
- routes: [
1430
- {
1305
+ (0, import_vitest.test)("replaces undefined query params", function () {
1306
+ var path = "/bar/undefined/apple",
1307
+ config = {
1308
+ screens: {
1309
+ Bar: "bar/:type/:fruit"
1310
+ }
1311
+ },
1312
+ state = {
1313
+ routes: [{
1431
1314
  name: "Bar",
1432
1315
  params: {
1433
1316
  fruit: "apple"
1434
1317
  }
1435
- }
1436
- ]
1437
- };
1318
+ }]
1319
+ };
1438
1320
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
1439
1321
  });
1440
- import_vitest.test.skip("matches wildcard patterns at root", function() {
1441
- var path = "/test/bar/42/whatever", config = {
1442
- screens: {
1443
- 404: "*",
1444
- Foo: {
1445
- screens: {
1446
- Bar: {
1447
- path: "/bar/:id/"
1322
+ import_vitest.test.skip("matches wildcard patterns at root", function () {
1323
+ var path = "/test/bar/42/whatever",
1324
+ config = {
1325
+ screens: {
1326
+ 404: "*",
1327
+ Foo: {
1328
+ screens: {
1329
+ Bar: {
1330
+ path: "/bar/:id/"
1331
+ }
1448
1332
  }
1449
1333
  }
1450
1334
  }
1451
- }
1452
- }, state = {
1453
- routes: [
1454
- {
1335
+ },
1336
+ state = {
1337
+ routes: [{
1455
1338
  name: "404"
1456
- }
1457
- ]
1458
- };
1339
+ }]
1340
+ };
1459
1341
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe("/404"), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe("/404");
1460
1342
  });
1461
- import_vitest.test.skip("matches wildcard patterns at nested level", function() {
1462
- var path = "/bar/42/whatever/baz/initt", config = {
1463
- screens: {
1464
- Foo: {
1465
- screens: {
1466
- Bar: {
1467
- path: "/bar/:id/",
1468
- screens: {
1469
- 404: "*"
1343
+ import_vitest.test.skip("matches wildcard patterns at nested level", function () {
1344
+ var path = "/bar/42/whatever/baz/initt",
1345
+ config = {
1346
+ screens: {
1347
+ Foo: {
1348
+ screens: {
1349
+ Bar: {
1350
+ path: "/bar/:id/",
1351
+ screens: {
1352
+ 404: "*"
1353
+ }
1470
1354
  }
1471
1355
  }
1472
1356
  }
1473
1357
  }
1474
- }
1475
- }, state = {
1476
- routes: [
1477
- {
1358
+ },
1359
+ state = {
1360
+ routes: [{
1478
1361
  name: "Foo",
1479
1362
  state: {
1480
- routes: [
1481
- {
1482
- name: "Bar",
1483
- params: {
1484
- id: "42"
1485
- },
1486
- state: {
1487
- routes: [
1488
- {
1489
- name: "404"
1490
- }
1491
- ]
1492
- }
1363
+ routes: [{
1364
+ name: "Bar",
1365
+ params: {
1366
+ id: "42"
1367
+ },
1368
+ state: {
1369
+ routes: [{
1370
+ name: "404"
1371
+ }]
1493
1372
  }
1494
- ]
1373
+ }]
1495
1374
  }
1496
- }
1497
- ]
1498
- };
1375
+ }]
1376
+ };
1499
1377
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe("/bar/42/404"), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe("/bar/42/404");
1500
1378
  });
1501
- import_vitest.test.skip("matches wildcard patterns at nested level with exact", function() {
1502
- var path = "/whatever", config = {
1503
- screens: {
1504
- Foo: {
1505
- screens: {
1506
- Bar: {
1507
- path: "/bar/:id/",
1508
- screens: {
1509
- 404: {
1510
- path: "*",
1511
- exact: !0
1379
+ import_vitest.test.skip("matches wildcard patterns at nested level with exact", function () {
1380
+ var path = "/whatever",
1381
+ config = {
1382
+ screens: {
1383
+ Foo: {
1384
+ screens: {
1385
+ Bar: {
1386
+ path: "/bar/:id/",
1387
+ screens: {
1388
+ 404: {
1389
+ path: "*",
1390
+ exact: !0
1391
+ }
1512
1392
  }
1513
- }
1514
- },
1515
- Baz: {}
1393
+ },
1394
+ Baz: {}
1395
+ }
1516
1396
  }
1517
1397
  }
1518
- }
1519
- }, state = {
1520
- routes: [
1521
- {
1398
+ },
1399
+ state = {
1400
+ routes: [{
1522
1401
  name: "Foo",
1523
1402
  state: {
1524
- routes: [
1525
- {
1526
- name: "Bar",
1527
- state: {
1528
- routes: [
1529
- {
1530
- name: "404"
1531
- }
1532
- ]
1533
- }
1403
+ routes: [{
1404
+ name: "Bar",
1405
+ state: {
1406
+ routes: [{
1407
+ name: "404"
1408
+ }]
1534
1409
  }
1535
- ]
1410
+ }]
1536
1411
  }
1537
- }
1538
- ]
1539
- };
1412
+ }]
1413
+ };
1540
1414
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe("/404"), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe("/404");
1541
1415
  });
1542
- (0, import_vitest.test)("tries to match wildcard patterns at the end", function() {
1543
- var path = "/bar/42/test", config = {
1544
- screens: {
1545
- Foo: {
1546
- screens: {
1547
- Bar: {
1548
- path: "/bar/:id/",
1549
- screens: {
1550
- 404: "*",
1551
- Test: "test"
1416
+ (0, import_vitest.test)("tries to match wildcard patterns at the end", function () {
1417
+ var path = "/bar/42/test",
1418
+ config = {
1419
+ screens: {
1420
+ Foo: {
1421
+ screens: {
1422
+ Bar: {
1423
+ path: "/bar/:id/",
1424
+ screens: {
1425
+ 404: "*",
1426
+ Test: "test"
1427
+ }
1552
1428
  }
1553
1429
  }
1554
1430
  }
1555
1431
  }
1556
- }
1557
- }, state = {
1558
- routes: [
1559
- {
1432
+ },
1433
+ state = {
1434
+ routes: [{
1560
1435
  name: "Foo",
1561
1436
  state: {
1562
- routes: [
1563
- {
1564
- name: "Bar",
1565
- params: {
1566
- id: "42"
1567
- },
1568
- state: {
1569
- routes: [
1570
- {
1571
- name: "Test"
1572
- }
1573
- ]
1574
- }
1437
+ routes: [{
1438
+ name: "Bar",
1439
+ params: {
1440
+ id: "42"
1441
+ },
1442
+ state: {
1443
+ routes: [{
1444
+ name: "Test"
1445
+ }]
1575
1446
  }
1576
- ]
1447
+ }]
1577
1448
  }
1578
- }
1579
- ]
1580
- };
1449
+ }]
1450
+ };
1581
1451
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(path), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(path);
1582
1452
  });
1583
- import_vitest.test.skip("uses nearest parent wildcard match for unmatched paths", function() {
1584
- var path = "/bar/42/baz/test", config = {
1585
- screens: {
1586
- Foo: {
1587
- screens: {
1588
- Bar: {
1589
- path: "/bar/:id/",
1590
- screens: {
1591
- Baz: "baz"
1592
- }
1593
- },
1594
- 404: "*"
1453
+ import_vitest.test.skip("uses nearest parent wildcard match for unmatched paths", function () {
1454
+ var path = "/bar/42/baz/test",
1455
+ config = {
1456
+ screens: {
1457
+ Foo: {
1458
+ screens: {
1459
+ Bar: {
1460
+ path: "/bar/:id/",
1461
+ screens: {
1462
+ Baz: "baz"
1463
+ }
1464
+ },
1465
+ 404: "*"
1466
+ }
1595
1467
  }
1596
1468
  }
1597
- }
1598
- }, state = {
1599
- routes: [
1600
- {
1469
+ },
1470
+ state = {
1471
+ routes: [{
1601
1472
  name: "Foo",
1602
1473
  state: {
1603
- routes: [
1604
- {
1605
- name: "404"
1606
- }
1607
- ]
1474
+ routes: [{
1475
+ name: "404"
1476
+ }]
1608
1477
  }
1609
- }
1610
- ]
1611
- };
1478
+ }]
1479
+ };
1612
1480
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe("/404"), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe("/404");
1613
1481
  });
1614
- import_vitest.test.skip("handles path at top level", function() {
1615
- var path = "foo/fruits/apple", config = {
1616
- path: "foo",
1617
- screens: {
1618
- Foo: {
1619
- screens: {
1620
- Fruits: "fruits/:fruit"
1482
+ import_vitest.test.skip("handles path at top level", function () {
1483
+ var path = "foo/fruits/apple",
1484
+ config = {
1485
+ path: "foo",
1486
+ screens: {
1487
+ Foo: {
1488
+ screens: {
1489
+ Fruits: "fruits/:fruit"
1490
+ }
1621
1491
  }
1622
1492
  }
1623
- }
1624
- }, state = {
1625
- routes: [
1626
- {
1493
+ },
1494
+ state = {
1495
+ routes: [{
1627
1496
  name: "Foo",
1628
1497
  state: {
1629
- routes: [
1630
- {
1631
- name: "Fruits",
1632
- params: {
1633
- fruit: "apple"
1634
- }
1498
+ routes: [{
1499
+ name: "Fruits",
1500
+ params: {
1501
+ fruit: "apple"
1635
1502
  }
1636
- ]
1503
+ }]
1637
1504
  }
1638
- }
1639
- ]
1640
- };
1505
+ }]
1506
+ };
1641
1507
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)(state, config)).toBe(`/${path}`), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)((0, import_getStateFromPath.getStateFromPath)(path, config), config)).toBe(`/${path}`);
1642
1508
  });
1643
- import_vitest.test.skip("ignores regexp patterns when provided", function() {
1509
+ import_vitest.test.skip("ignores regexp patterns when provided", function () {
1644
1510
  var config = {
1645
1511
  screens: {
1646
1512
  Foo: {
@@ -1658,7 +1524,7 @@ import_vitest.test.skip("ignores regexp patterns when provided", function() {
1658
1524
  Qux: {
1659
1525
  path: "foo/:id(@[a-z]+)",
1660
1526
  stringify: {
1661
- id: function(id) {
1527
+ id: function (id) {
1662
1528
  return `@${id}`;
1663
1529
  }
1664
1530
  }
@@ -1666,45 +1532,37 @@ import_vitest.test.skip("ignores regexp patterns when provided", function() {
1666
1532
  }
1667
1533
  };
1668
1534
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)({
1669
- routes: [
1670
- {
1671
- name: "Foo",
1672
- params: {
1673
- id: 42
1674
- }
1535
+ routes: [{
1536
+ name: "Foo",
1537
+ params: {
1538
+ id: 42
1675
1539
  }
1676
- ]
1540
+ }]
1677
1541
  }, config)).toBe("/foo/42"), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)({
1678
- routes: [
1679
- {
1680
- name: "Bar",
1681
- params: {
1682
- id: "bar"
1683
- }
1542
+ routes: [{
1543
+ name: "Bar",
1544
+ params: {
1545
+ id: "bar"
1684
1546
  }
1685
- ]
1547
+ }]
1686
1548
  }, config)).toBe("/foo/bar"), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)({
1687
- routes: [
1688
- {
1689
- name: "Baz",
1690
- params: {
1691
- id: 42,
1692
- name: "bar"
1693
- }
1549
+ routes: [{
1550
+ name: "Baz",
1551
+ params: {
1552
+ id: 42,
1553
+ name: "bar"
1694
1554
  }
1695
- ]
1555
+ }]
1696
1556
  }, config)).toBe("/foo/42/bar"), (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)({
1697
- routes: [
1698
- {
1699
- name: "Qux",
1700
- params: {
1701
- id: "bar"
1702
- }
1557
+ routes: [{
1558
+ name: "Qux",
1559
+ params: {
1560
+ id: "bar"
1703
1561
  }
1704
- ]
1562
+ }]
1705
1563
  }, config)).toBe("/foo/@bar");
1706
1564
  });
1707
- import_vitest.test.skip("correctly handles regex pattern with slash", function() {
1565
+ import_vitest.test.skip("correctly handles regex pattern with slash", function () {
1708
1566
  var config = {
1709
1567
  screens: {
1710
1568
  Foo: {
@@ -1713,14 +1571,12 @@ import_vitest.test.skip("correctly handles regex pattern with slash", function()
1713
1571
  }
1714
1572
  };
1715
1573
  (0, import_vitest.expect)((0, import_getPathFromState.getPathFromState)({
1716
- routes: [
1717
- {
1718
- name: "Foo",
1719
- params: {
1720
- id: "bar"
1721
- }
1574
+ routes: [{
1575
+ name: "Foo",
1576
+ params: {
1577
+ id: "bar"
1722
1578
  }
1723
- ]
1579
+ }]
1724
1580
  }, config)).toBe("/foo/bar");
1725
1581
  });
1726
- //# sourceMappingURL=getPathFromState.test.js.map
1582
+ //# sourceMappingURL=getPathFromState.test.native.js.map