mirror of
https://github.com/nuxt/nuxt.git
synced 2024-11-22 05:35:13 +00:00
fix(nuxt): don't try to override computed layouts in definePageMeta
(#9161)
This commit is contained in:
parent
f4ba7ec82d
commit
5b19a0dc34
@ -1,4 +1,4 @@
|
|||||||
import { reactive, h } from 'vue'
|
import { reactive, h, isReadonly } from 'vue'
|
||||||
import { parseURL, stringifyParsedURL, parseQuery, stringifyQuery, withoutBase, isEqual, joinURL } from 'ufo'
|
import { parseURL, stringifyParsedURL, parseQuery, stringifyQuery, withoutBase, isEqual, joinURL } from 'ufo'
|
||||||
import { createError } from 'h3'
|
import { createError } from 'h3'
|
||||||
import { defineNuxtPlugin, clearError, navigateTo, showError, useRuntimeConfig, useState } from '..'
|
import { defineNuxtPlugin, clearError, navigateTo, showError, useRuntimeConfig, useState } from '..'
|
||||||
@ -222,8 +222,8 @@ export default defineNuxtPlugin<{ route: Route, router: Router }>((nuxtApp) => {
|
|||||||
nuxtApp.hooks.hookOnce('app:created', async () => {
|
nuxtApp.hooks.hookOnce('app:created', async () => {
|
||||||
router.beforeEach(async (to, from) => {
|
router.beforeEach(async (to, from) => {
|
||||||
to.meta = reactive(to.meta || {})
|
to.meta = reactive(to.meta || {})
|
||||||
if (nuxtApp.isHydrating) {
|
if (nuxtApp.isHydrating && initialLayout.value && !isReadonly(to.meta.layout)) {
|
||||||
to.meta.layout = initialLayout.value ?? to.meta.layout
|
to.meta.layout = initialLayout.value
|
||||||
}
|
}
|
||||||
nuxtApp._processingMiddleware = true
|
nuxtApp._processingMiddleware = true
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
import { computed, reactive, shallowRef } from 'vue'
|
import { computed, isReadonly, reactive, shallowRef } from 'vue'
|
||||||
import type {
|
import type {
|
||||||
NavigationGuard,
|
NavigationGuard,
|
||||||
RouteLocation
|
RouteLocation
|
||||||
@ -119,8 +119,8 @@ export default defineNuxtPlugin(async (nuxtApp) => {
|
|||||||
const initialLayout = useState('_layout')
|
const initialLayout = useState('_layout')
|
||||||
router.beforeEach(async (to, from) => {
|
router.beforeEach(async (to, from) => {
|
||||||
to.meta = reactive(to.meta)
|
to.meta = reactive(to.meta)
|
||||||
if (nuxtApp.isHydrating) {
|
if (nuxtApp.isHydrating && initialLayout.value && !isReadonly(to.meta.layout)) {
|
||||||
to.meta.layout = initialLayout.value ?? to.meta.layout
|
to.meta.layout = initialLayout.value
|
||||||
}
|
}
|
||||||
nuxtApp._processingMiddleware = true
|
nuxtApp._processingMiddleware = true
|
||||||
|
|
||||||
|
@ -410,6 +410,16 @@ describe('layouts', () => {
|
|||||||
expect(html).toContain('Custom Layout:')
|
expect(html).toContain('Custom Layout:')
|
||||||
await expectNoClientErrors('/with-dynamic-layout')
|
await expectNoClientErrors('/with-dynamic-layout')
|
||||||
})
|
})
|
||||||
|
it('should work with a computed layout', async () => {
|
||||||
|
const html = await $fetch('/with-computed-layout')
|
||||||
|
|
||||||
|
// Snapshot
|
||||||
|
// expect(html).toMatchInlineSnapshot()
|
||||||
|
|
||||||
|
expect(html).toContain('with-computed-layout')
|
||||||
|
expect(html).toContain('Custom Layout')
|
||||||
|
await expectNoClientErrors('/with-computed-layout')
|
||||||
|
})
|
||||||
it('should allow passing custom props to a layout', async () => {
|
it('should allow passing custom props to a layout', async () => {
|
||||||
const html = await $fetch('/layouts/with-props')
|
const html = await $fetch('/layouts/with-props')
|
||||||
expect(html).toContain('some prop was passed')
|
expect(html).toContain('some prop was passed')
|
||||||
|
11
test/fixtures/basic/pages/with-computed-layout.vue
vendored
Normal file
11
test/fixtures/basic/pages/with-computed-layout.vue
vendored
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
<script setup>
|
||||||
|
definePageMeta({
|
||||||
|
layout: computed(() => 'custom')
|
||||||
|
})
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<div>with-computed-layout.vue</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
Loading…
Reference in New Issue
Block a user