1d596ca90c
Bailout to client rendering when using useSearchParams and usePathName during SSG. ## Bug - [ ] Related issues linked using `fixes #number` - [ ] Integration tests added - [ ] Errors have a helpful link attached, see `contributing.md` ## Feature - [ ] Implements an existing feature request or RFC. Make sure the feature request has been accepted for implementation before opening a PR. - [ ] Related issues linked using `fixes #number` - [ ] Integration tests added - [ ] Documentation added - [ ] Telemetry added. In case of a feature if it's used or not. - [ ] Errors have a helpful link attached, see `contributing.md` ## Documentation / Examples - [ ] Make sure the linting passes by running `pnpm lint` - [ ] The "examples guidelines" are followed from [our contributing doc](https://github.com/vercel/next.js/blob/canary/contributing/examples/adding-examples.md)
31 lines
896 B
TypeScript
31 lines
896 B
TypeScript
import { requestAsyncStorage } from './request-async-storage'
|
|
import { staticGenerationBailout } from './static-generation-bailout'
|
|
|
|
export function headers() {
|
|
staticGenerationBailout('headers')
|
|
const requestStore =
|
|
requestAsyncStorage && 'getStore' in requestAsyncStorage
|
|
? requestAsyncStorage.getStore()!
|
|
: requestAsyncStorage
|
|
|
|
return requestStore.headers
|
|
}
|
|
|
|
export function previewData() {
|
|
staticGenerationBailout('previewData')
|
|
const requestStore =
|
|
requestAsyncStorage && 'getStore' in requestAsyncStorage
|
|
? requestAsyncStorage.getStore()!
|
|
: requestAsyncStorage
|
|
return requestStore.previewData
|
|
}
|
|
|
|
export function cookies() {
|
|
staticGenerationBailout('cookies')
|
|
const requestStore =
|
|
requestAsyncStorage && 'getStore' in requestAsyncStorage
|
|
? requestAsyncStorage.getStore()!
|
|
: requestAsyncStorage
|
|
|
|
return requestStore.cookies
|
|
}
|