@tanstack/solid-router 2.0.0-alpha.6 → 2.0.0-alpha.7
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.
- package/dist/cjs/Asset.cjs +2 -2
- package/dist/cjs/Asset.cjs.map +1 -1
- package/dist/cjs/HeadContent.cjs +11 -1
- package/dist/cjs/HeadContent.cjs.map +1 -1
- package/dist/cjs/HeadContent.dev.cjs +11 -1
- package/dist/cjs/HeadContent.dev.cjs.map +1 -1
- package/dist/cjs/Match.cjs +265 -248
- package/dist/cjs/Match.cjs.map +1 -1
- package/dist/cjs/Match.d.cts +1 -3
- package/dist/cjs/Matches.cjs +35 -34
- package/dist/cjs/Matches.cjs.map +1 -1
- package/dist/cjs/RouterProvider.cjs +12 -8
- package/dist/cjs/RouterProvider.cjs.map +1 -1
- package/dist/cjs/RouterProvider.d.cts +1 -1
- package/dist/cjs/Scripts.cjs +23 -12
- package/dist/cjs/Scripts.cjs.map +1 -1
- package/dist/cjs/Scripts.d.cts +2 -1
- package/dist/cjs/Transitioner.cjs +55 -34
- package/dist/cjs/Transitioner.cjs.map +1 -1
- package/dist/cjs/headContentUtils.cjs +26 -23
- package/dist/cjs/headContentUtils.cjs.map +1 -1
- package/dist/cjs/headContentUtils.d.cts +2 -1
- package/dist/cjs/index.cjs +1 -1
- package/dist/cjs/index.dev.cjs +1 -1
- package/dist/cjs/link.cjs +143 -101
- package/dist/cjs/link.cjs.map +1 -1
- package/dist/cjs/matchContext.cjs +7 -5
- package/dist/cjs/matchContext.cjs.map +1 -1
- package/dist/cjs/matchContext.d.cts +8 -2
- package/dist/cjs/not-found.cjs +8 -4
- package/dist/cjs/not-found.cjs.map +1 -1
- package/dist/cjs/not-found.d.cts +1 -1
- package/dist/cjs/router.cjs +2 -1
- package/dist/cjs/router.cjs.map +1 -1
- package/dist/cjs/routerStores.cjs +75 -0
- package/dist/cjs/routerStores.cjs.map +1 -0
- package/dist/cjs/routerStores.d.cts +10 -0
- package/dist/cjs/ssr/RouterClient.cjs +1 -1
- package/dist/cjs/ssr/RouterClient.cjs.map +1 -1
- package/dist/cjs/ssr/renderRouterToStream.cjs +1 -1
- package/dist/cjs/ssr/renderRouterToStream.cjs.map +1 -1
- package/dist/cjs/ssr/renderRouterToString.cjs +1 -1
- package/dist/cjs/ssr/renderRouterToString.cjs.map +1 -1
- package/dist/cjs/useBlocker.cjs +12 -3
- package/dist/cjs/useBlocker.cjs.map +1 -1
- package/dist/cjs/useCanGoBack.cjs +6 -2
- package/dist/cjs/useCanGoBack.cjs.map +1 -1
- package/dist/cjs/useCanGoBack.d.cts +2 -1
- package/dist/cjs/useLoaderDeps.cjs +2 -3
- package/dist/cjs/useLoaderDeps.cjs.map +1 -1
- package/dist/cjs/useLocation.cjs +13 -2
- package/dist/cjs/useLocation.cjs.map +1 -1
- package/dist/cjs/useMatch.cjs +27 -15
- package/dist/cjs/useMatch.cjs.map +1 -1
- package/dist/cjs/useParams.cjs +1 -1
- package/dist/cjs/useParams.cjs.map +1 -1
- package/dist/cjs/useRouterState.cjs +12 -30
- package/dist/cjs/useRouterState.cjs.map +1 -1
- package/dist/cjs/useSearch.cjs +2 -1
- package/dist/cjs/useSearch.cjs.map +1 -1
- package/dist/cjs/utils.cjs +3 -17
- package/dist/cjs/utils.cjs.map +1 -1
- package/dist/cjs/utils.d.cts +0 -5
- package/dist/esm/Asset.js +6 -6
- package/dist/esm/Asset.js.map +1 -1
- package/dist/esm/HeadContent.dev.js +12 -2
- package/dist/esm/HeadContent.dev.js.map +1 -1
- package/dist/esm/HeadContent.js +12 -2
- package/dist/esm/HeadContent.js.map +1 -1
- package/dist/esm/Match.d.ts +1 -3
- package/dist/esm/Match.js +267 -250
- package/dist/esm/Match.js.map +1 -1
- package/dist/esm/Matches.js +40 -39
- package/dist/esm/Matches.js.map +1 -1
- package/dist/esm/RouterProvider.d.ts +1 -1
- package/dist/esm/RouterProvider.js +10 -7
- package/dist/esm/RouterProvider.js.map +1 -1
- package/dist/esm/ScriptOnce.js +2 -2
- package/dist/esm/ScriptOnce.js.map +1 -1
- package/dist/esm/Scripts.d.ts +2 -1
- package/dist/esm/Scripts.js +21 -11
- package/dist/esm/Scripts.js.map +1 -1
- package/dist/esm/Transitioner.js +56 -35
- package/dist/esm/Transitioner.js.map +1 -1
- package/dist/esm/headContentUtils.d.ts +2 -1
- package/dist/esm/headContentUtils.js +26 -23
- package/dist/esm/headContentUtils.js.map +1 -1
- package/dist/esm/index.dev.js +1 -1
- package/dist/esm/index.js +1 -1
- package/dist/esm/link.js +146 -104
- package/dist/esm/link.js.map +1 -1
- package/dist/esm/matchContext.d.ts +8 -2
- package/dist/esm/matchContext.js +7 -4
- package/dist/esm/matchContext.js.map +1 -1
- package/dist/esm/not-found.d.ts +1 -1
- package/dist/esm/not-found.js +6 -3
- package/dist/esm/not-found.js.map +1 -1
- package/dist/esm/router.js +2 -1
- package/dist/esm/router.js.map +1 -1
- package/dist/esm/routerStores.d.ts +10 -0
- package/dist/esm/routerStores.js +73 -0
- package/dist/esm/routerStores.js.map +1 -0
- package/dist/esm/scroll-restoration.js +2 -2
- package/dist/esm/scroll-restoration.js.map +1 -1
- package/dist/esm/ssr/RouterClient.js +1 -1
- package/dist/esm/ssr/RouterClient.js.map +1 -1
- package/dist/esm/ssr/renderRouterToStream.js +1 -1
- package/dist/esm/ssr/renderRouterToStream.js.map +1 -1
- package/dist/esm/ssr/renderRouterToString.js +1 -1
- package/dist/esm/ssr/renderRouterToString.js.map +1 -1
- package/dist/esm/useBlocker.js +12 -3
- package/dist/esm/useBlocker.js.map +1 -1
- package/dist/esm/useCanGoBack.d.ts +2 -1
- package/dist/esm/useCanGoBack.js +4 -2
- package/dist/esm/useCanGoBack.js.map +1 -1
- package/dist/esm/useLoaderDeps.js +2 -3
- package/dist/esm/useLoaderDeps.js.map +1 -1
- package/dist/esm/useLocation.js +11 -2
- package/dist/esm/useLocation.js.map +1 -1
- package/dist/esm/useMatch.js +28 -16
- package/dist/esm/useMatch.js.map +1 -1
- package/dist/esm/useParams.js +1 -1
- package/dist/esm/useParams.js.map +1 -1
- package/dist/esm/useRouterState.js +11 -30
- package/dist/esm/useRouterState.js.map +1 -1
- package/dist/esm/useSearch.js +2 -1
- package/dist/esm/useSearch.js.map +1 -1
- package/dist/esm/utils.d.ts +0 -5
- package/dist/esm/utils.js +4 -17
- package/dist/esm/utils.js.map +1 -1
- package/dist/source/Asset.jsx +3 -3
- package/dist/source/Asset.jsx.map +1 -1
- package/dist/source/HeadContent.dev.jsx +5 -1
- package/dist/source/HeadContent.dev.jsx.map +1 -1
- package/dist/source/HeadContent.jsx +5 -1
- package/dist/source/HeadContent.jsx.map +1 -1
- package/dist/source/Match.d.ts +1 -3
- package/dist/source/Match.jsx +260 -264
- package/dist/source/Match.jsx.map +1 -1
- package/dist/source/Matches.jsx +46 -46
- package/dist/source/Matches.jsx.map +1 -1
- package/dist/source/RouterProvider.d.ts +1 -1
- package/dist/source/RouterProvider.jsx +13 -9
- package/dist/source/RouterProvider.jsx.map +1 -1
- package/dist/source/Scripts.d.ts +2 -1
- package/dist/source/Scripts.jsx +46 -47
- package/dist/source/Scripts.jsx.map +1 -1
- package/dist/source/Transitioner.jsx +78 -42
- package/dist/source/Transitioner.jsx.map +1 -1
- package/dist/source/headContentUtils.d.ts +2 -1
- package/dist/source/headContentUtils.jsx +79 -80
- package/dist/source/headContentUtils.jsx.map +1 -1
- package/dist/source/link.jsx +145 -112
- package/dist/source/link.jsx.map +1 -1
- package/dist/source/matchContext.d.ts +8 -2
- package/dist/source/matchContext.jsx +7 -3
- package/dist/source/matchContext.jsx.map +1 -1
- package/dist/source/not-found.d.ts +1 -1
- package/dist/source/not-found.jsx +6 -5
- package/dist/source/not-found.jsx.map +1 -1
- package/dist/source/router.js +2 -1
- package/dist/source/router.js.map +1 -1
- package/dist/source/routerStores.d.ts +10 -0
- package/dist/source/routerStores.js +82 -0
- package/dist/source/routerStores.js.map +1 -0
- package/dist/source/ssr/RouterClient.jsx +1 -1
- package/dist/source/ssr/RouterClient.jsx.map +1 -1
- package/dist/source/ssr/renderRouterToStream.jsx +1 -1
- package/dist/source/ssr/renderRouterToStream.jsx.map +1 -1
- package/dist/source/ssr/renderRouterToString.jsx +1 -1
- package/dist/source/ssr/renderRouterToString.jsx.map +1 -1
- package/dist/source/useBlocker.jsx +19 -8
- package/dist/source/useBlocker.jsx.map +1 -1
- package/dist/source/useCanGoBack.d.ts +2 -1
- package/dist/source/useCanGoBack.js +4 -2
- package/dist/source/useCanGoBack.js.map +1 -1
- package/dist/source/useLoaderDeps.jsx +2 -3
- package/dist/source/useLoaderDeps.jsx.map +1 -1
- package/dist/source/useLocation.jsx +13 -3
- package/dist/source/useLocation.jsx.map +1 -1
- package/dist/source/useMatch.jsx +33 -23
- package/dist/source/useMatch.jsx.map +1 -1
- package/dist/source/useParams.jsx +1 -1
- package/dist/source/useParams.jsx.map +1 -1
- package/dist/source/useRouterState.jsx +14 -55
- package/dist/source/useRouterState.jsx.map +1 -1
- package/dist/source/useSearch.jsx +2 -1
- package/dist/source/useSearch.jsx.map +1 -1
- package/dist/source/utils.d.ts +0 -5
- package/dist/source/utils.js +2 -15
- package/dist/source/utils.js.map +1 -1
- package/package.json +2 -2
- package/skills/solid-router/SKILL.md +2 -0
- package/src/Asset.tsx +3 -3
- package/src/HeadContent.dev.tsx +10 -1
- package/src/HeadContent.tsx +10 -1
- package/src/Match.tsx +395 -349
- package/src/Matches.tsx +55 -54
- package/src/RouterProvider.tsx +13 -10
- package/src/Scripts.tsx +55 -54
- package/src/Transitioner.tsx +101 -58
- package/src/headContentUtils.tsx +104 -96
- package/src/link.tsx +188 -146
- package/src/matchContext.tsx +16 -7
- package/src/not-found.tsx +6 -6
- package/src/router.ts +2 -1
- package/src/routerStores.ts +119 -0
- package/src/ssr/RouterClient.tsx +1 -1
- package/src/ssr/renderRouterToStream.tsx +1 -1
- package/src/ssr/renderRouterToString.tsx +1 -1
- package/src/useBlocker.tsx +80 -63
- package/src/useCanGoBack.ts +6 -2
- package/src/useLoaderDeps.tsx +2 -3
- package/src/useLocation.tsx +18 -5
- package/src/useMatch.tsx +37 -38
- package/src/useParams.tsx +2 -3
- package/src/useRouterState.tsx +21 -67
- package/src/useSearch.tsx +2 -1
- package/src/utils.ts +2 -24
package/src/headContentUtils.tsx
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import * as Solid from 'solid-js'
|
|
2
2
|
import { escapeHtml } from '@tanstack/router-core'
|
|
3
3
|
import { useRouter } from './useRouter'
|
|
4
|
-
import { useRouterState } from './useRouterState'
|
|
5
4
|
import type { RouterManagedTag } from '@tanstack/router-core'
|
|
6
5
|
|
|
7
6
|
/**
|
|
@@ -11,11 +10,15 @@ import type { RouterManagedTag } from '@tanstack/router-core'
|
|
|
11
10
|
export const useTags = () => {
|
|
12
11
|
const router = useRouter()
|
|
13
12
|
const nonce = router.options.ssr?.nonce
|
|
14
|
-
const
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
13
|
+
const getTagKey = (tag: RouterManagedTag) => JSON.stringify(tag)
|
|
14
|
+
const activeMatches = Solid.createMemo(
|
|
15
|
+
() => router.stores.activeMatchesSnapshot.state,
|
|
16
|
+
)
|
|
17
|
+
const routeMeta = Solid.createMemo(() =>
|
|
18
|
+
activeMatches()
|
|
19
|
+
.map((match) => match.meta!)
|
|
20
|
+
.filter(Boolean),
|
|
21
|
+
)
|
|
19
22
|
|
|
20
23
|
const meta: Solid.Accessor<Array<RouterManagedTag>> = Solid.createMemo(() => {
|
|
21
24
|
const resultMeta: Array<RouterManagedTag> = []
|
|
@@ -89,100 +92,96 @@ export const useTags = () => {
|
|
|
89
92
|
return resultMeta
|
|
90
93
|
})
|
|
91
94
|
|
|
92
|
-
const links =
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
attrs: {
|
|
101
|
-
...link,
|
|
102
|
-
nonce,
|
|
103
|
-
},
|
|
104
|
-
})) satisfies Array<RouterManagedTag>
|
|
105
|
-
|
|
106
|
-
const manifest = router.ssr?.manifest
|
|
107
|
-
|
|
108
|
-
const assets = state.matches
|
|
109
|
-
.map((match) => manifest?.routes[match.routeId]?.assets ?? [])
|
|
110
|
-
.filter(Boolean)
|
|
111
|
-
.flat(1)
|
|
112
|
-
.filter((asset) => asset.tag === 'link')
|
|
113
|
-
.map(
|
|
114
|
-
(asset) =>
|
|
115
|
-
({
|
|
116
|
-
tag: 'link',
|
|
117
|
-
attrs: { ...asset.attrs, nonce },
|
|
118
|
-
}) satisfies RouterManagedTag,
|
|
119
|
-
)
|
|
120
|
-
|
|
121
|
-
return [...constructed, ...assets]
|
|
122
|
-
},
|
|
123
|
-
})
|
|
124
|
-
|
|
125
|
-
const preloadLinks = useRouterState({
|
|
126
|
-
select: (state) => {
|
|
127
|
-
const preloadLinks: Array<RouterManagedTag> = []
|
|
128
|
-
|
|
129
|
-
state.matches
|
|
130
|
-
.map((match) => router.looseRoutesById[match.routeId]!)
|
|
131
|
-
.forEach((route) =>
|
|
132
|
-
router.ssr?.manifest?.routes[route.id]?.preloads
|
|
133
|
-
?.filter(Boolean)
|
|
134
|
-
.forEach((preload) => {
|
|
135
|
-
preloadLinks.push({
|
|
136
|
-
tag: 'link',
|
|
137
|
-
attrs: {
|
|
138
|
-
rel: 'modulepreload',
|
|
139
|
-
href: preload,
|
|
140
|
-
nonce,
|
|
141
|
-
},
|
|
142
|
-
})
|
|
143
|
-
}),
|
|
144
|
-
)
|
|
145
|
-
|
|
146
|
-
return preloadLinks
|
|
147
|
-
},
|
|
148
|
-
})
|
|
149
|
-
|
|
150
|
-
const styles = useRouterState({
|
|
151
|
-
select: (state) =>
|
|
152
|
-
(
|
|
153
|
-
state.matches
|
|
154
|
-
.map((match) => match.styles!)
|
|
155
|
-
.flat(1)
|
|
156
|
-
.filter(Boolean) as Array<RouterManagedTag>
|
|
157
|
-
).map(({ children, ...style }) => ({
|
|
158
|
-
tag: 'style',
|
|
95
|
+
const links = Solid.createMemo(() => {
|
|
96
|
+
const matches = activeMatches()
|
|
97
|
+
const constructed = matches
|
|
98
|
+
.map((match) => match.links!)
|
|
99
|
+
.filter(Boolean)
|
|
100
|
+
.flat(1)
|
|
101
|
+
.map((link) => ({
|
|
102
|
+
tag: 'link',
|
|
159
103
|
attrs: {
|
|
160
|
-
...
|
|
104
|
+
...link,
|
|
161
105
|
nonce,
|
|
162
106
|
},
|
|
163
|
-
|
|
164
|
-
|
|
107
|
+
})) satisfies Array<RouterManagedTag>
|
|
108
|
+
|
|
109
|
+
const manifest = router.ssr?.manifest
|
|
110
|
+
|
|
111
|
+
const assets = matches
|
|
112
|
+
.map((match) => manifest?.routes[match.routeId]?.assets ?? [])
|
|
113
|
+
.filter(Boolean)
|
|
114
|
+
.flat(1)
|
|
115
|
+
.filter((asset) => asset.tag === 'link')
|
|
116
|
+
.map(
|
|
117
|
+
(asset) =>
|
|
118
|
+
({
|
|
119
|
+
tag: 'link',
|
|
120
|
+
attrs: { ...asset.attrs, nonce },
|
|
121
|
+
}) satisfies RouterManagedTag,
|
|
122
|
+
)
|
|
123
|
+
|
|
124
|
+
return [...constructed, ...assets]
|
|
165
125
|
})
|
|
166
126
|
|
|
167
|
-
const
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
127
|
+
const preloadLinks = Solid.createMemo(() => {
|
|
128
|
+
const matches = activeMatches()
|
|
129
|
+
const preloadLinks: Array<RouterManagedTag> = []
|
|
130
|
+
|
|
131
|
+
matches
|
|
132
|
+
.map((match) => router.looseRoutesById[match.routeId]!)
|
|
133
|
+
.forEach((route) =>
|
|
134
|
+
router.ssr?.manifest?.routes[route.id]?.preloads
|
|
135
|
+
?.filter(Boolean)
|
|
136
|
+
.forEach((preload) => {
|
|
137
|
+
preloadLinks.push({
|
|
138
|
+
tag: 'link',
|
|
139
|
+
attrs: {
|
|
140
|
+
rel: 'modulepreload',
|
|
141
|
+
href: preload,
|
|
142
|
+
nonce,
|
|
143
|
+
},
|
|
144
|
+
})
|
|
145
|
+
}),
|
|
146
|
+
)
|
|
147
|
+
|
|
148
|
+
return preloadLinks
|
|
182
149
|
})
|
|
183
150
|
|
|
184
|
-
|
|
185
|
-
|
|
151
|
+
const styles = Solid.createMemo(() =>
|
|
152
|
+
(
|
|
153
|
+
activeMatches()
|
|
154
|
+
.map((match) => match.styles!)
|
|
155
|
+
.flat(1)
|
|
156
|
+
.filter(Boolean) as Array<RouterManagedTag>
|
|
157
|
+
).map(({ children, ...style }) => ({
|
|
158
|
+
tag: 'style',
|
|
159
|
+
attrs: {
|
|
160
|
+
...style,
|
|
161
|
+
nonce,
|
|
162
|
+
},
|
|
163
|
+
children,
|
|
164
|
+
})),
|
|
165
|
+
)
|
|
166
|
+
|
|
167
|
+
const headScripts = Solid.createMemo(() =>
|
|
168
|
+
(
|
|
169
|
+
activeMatches()
|
|
170
|
+
.map((match) => match.headScripts!)
|
|
171
|
+
.flat(1)
|
|
172
|
+
.filter(Boolean) as Array<RouterManagedTag>
|
|
173
|
+
).map(({ children, ...script }) => ({
|
|
174
|
+
tag: 'script',
|
|
175
|
+
attrs: {
|
|
176
|
+
...script,
|
|
177
|
+
nonce,
|
|
178
|
+
},
|
|
179
|
+
children,
|
|
180
|
+
})),
|
|
181
|
+
)
|
|
182
|
+
|
|
183
|
+
return Solid.createMemo((prev: Array<RouterManagedTag> | undefined) => {
|
|
184
|
+
const next = uniqBy(
|
|
186
185
|
[
|
|
187
186
|
...meta(),
|
|
188
187
|
...preloadLinks(),
|
|
@@ -190,10 +189,19 @@ export const useTags = () => {
|
|
|
190
189
|
...styles(),
|
|
191
190
|
...headScripts(),
|
|
192
191
|
] as Array<RouterManagedTag>,
|
|
193
|
-
|
|
194
|
-
return JSON.stringify(d)
|
|
195
|
-
},
|
|
192
|
+
getTagKey,
|
|
196
193
|
)
|
|
194
|
+
|
|
195
|
+
if (
|
|
196
|
+
prev &&
|
|
197
|
+
prev.length === next.length &&
|
|
198
|
+
prev.every((tag, index) => getTagKey(tag) === getTagKey(next[index]!))
|
|
199
|
+
) {
|
|
200
|
+
return prev
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
return next
|
|
204
|
+
})
|
|
197
205
|
}
|
|
198
206
|
|
|
199
207
|
export function uniqBy<T>(arr: Array<T>, fn: (item: T) => string) {
|