mirror of
https://github.com/nuxt/nuxt.git
synced 2025-01-18 17:35:57 +00:00
fix(nuxt): remove unused prop in NuxtTeleportIslandComponent
(#27093)
This commit is contained in:
parent
4bf6060db6
commit
a4d0958727
@ -27,14 +27,6 @@ export default defineComponent({
|
||||
type: Boolean,
|
||||
default: false,
|
||||
},
|
||||
/**
|
||||
* ONLY used in dev mode since we use build:manifest result in production
|
||||
* do not pass any value in production
|
||||
*/
|
||||
rootDir: {
|
||||
type: String,
|
||||
default: null,
|
||||
},
|
||||
},
|
||||
setup (props, { slots }) {
|
||||
const nuxtApp = useNuxtApp()
|
||||
|
@ -13,12 +13,6 @@ import { isVue } from '../core/utils'
|
||||
|
||||
interface ServerOnlyComponentTransformPluginOptions {
|
||||
getComponents: () => Component[]
|
||||
/**
|
||||
* passed down to `NuxtTeleportIslandComponent`
|
||||
* should be done only in dev mode as we use build:manifest result in production
|
||||
*/
|
||||
rootDir?: string
|
||||
isDev?: boolean
|
||||
/**
|
||||
* allow using `nuxt-client` attribute on components
|
||||
*/
|
||||
@ -43,7 +37,6 @@ function wrapWithVForDiv (code: string, vfor: string): string {
|
||||
|
||||
export const islandsTransform = createUnplugin((options: ServerOnlyComponentTransformPluginOptions, meta) => {
|
||||
const isVite = meta.framework === 'vite'
|
||||
const { isDev, rootDir } = options
|
||||
return {
|
||||
name: 'server-only-component-transform',
|
||||
enforce: 'pre',
|
||||
@ -115,7 +108,7 @@ export const islandsTransform = createUnplugin((options: ServerOnlyComponentTran
|
||||
startTag = startTag.replaceAll(EXTRACTED_ATTRS_RE, '')
|
||||
}
|
||||
|
||||
s.appendLeft(startingIndex + loc[0].start, `<NuxtTeleportIslandComponent${attributeToString(wrapperAttributes)} to="${node.name}-${uid}" ${rootDir && isDev ? `root-dir="${rootDir}"` : ''} :nuxt-client="${attributeValue}">`)
|
||||
s.appendLeft(startingIndex + loc[0].start, `<NuxtTeleportIslandComponent${attributeToString(wrapperAttributes)} to="${node.name}-${uid}" :nuxt-client="${attributeValue}">`)
|
||||
s.overwrite(startingIndex + loc[0].start, startingIndex + loc[0].end, startTag)
|
||||
s.appendRight(startingIndex + loc[1].end, '</NuxtTeleportIslandComponent>')
|
||||
}
|
||||
|
@ -260,8 +260,6 @@ export default defineNuxtModule<ComponentsOptions>({
|
||||
if (isServer) {
|
||||
config.plugins.push(islandsTransform.vite({
|
||||
getComponents,
|
||||
rootDir: nuxt.options.rootDir,
|
||||
isDev: nuxt.options.dev,
|
||||
selectiveClient,
|
||||
}))
|
||||
}
|
||||
|
@ -23,11 +23,9 @@ const pluginWebpack = islandsTransform.raw({
|
||||
selectiveClient: true,
|
||||
}, { framework: 'webpack', webpack: { compiler: {} as any } })
|
||||
|
||||
const viteTransform = async (source: string, id: string, isDev = false, selectiveClient = false) => {
|
||||
const viteTransform = async (source: string, id: string, selectiveClient = false) => {
|
||||
const vitePlugin = islandsTransform.raw({
|
||||
getComponents,
|
||||
rootDir: '/root',
|
||||
isDev,
|
||||
selectiveClient,
|
||||
}, { framework: 'vite' }) as Plugin
|
||||
|
||||
@ -193,7 +191,7 @@ describe('islandTransform - server and island components', () => {
|
||||
<slot v-else-if="test" />
|
||||
<slot v-else />
|
||||
</template>
|
||||
`, 'WithVif.vue', false, true)
|
||||
`, 'WithVif.vue', true)
|
||||
|
||||
expect(normalizeLineEndings(result)).toMatchInlineSnapshot(`
|
||||
"<script setup lang="ts">
|
||||
@ -214,12 +212,10 @@ describe('islandTransform - server and island components', () => {
|
||||
|
||||
describe('nuxt-client', () => {
|
||||
describe('vite', () => {
|
||||
it('test transform with vite in dev', async () => {
|
||||
it('test transform with vite', async () => {
|
||||
const result = await viteTransform(`<template>
|
||||
<div>
|
||||
<!-- should not be wrapped by NuxtTeleportIslandComponent -->
|
||||
<HelloWorld />
|
||||
<!-- should be wrapped by NuxtTeleportIslandComponent with a rootDir attr -->
|
||||
<HelloWorld nuxt-client />
|
||||
</div>
|
||||
</template>
|
||||
@ -227,15 +223,13 @@ describe('islandTransform - server and island components', () => {
|
||||
<script setup lang="ts">
|
||||
import HelloWorld from './HelloWorld.vue'
|
||||
</script>
|
||||
`, 'hello.server.vue', true, true)
|
||||
`, 'hello.server.vue', true)
|
||||
|
||||
expect(normalizeLineEndings(result)).toMatchInlineSnapshot(`
|
||||
"<template>
|
||||
<div>
|
||||
<!-- should not be wrapped by NuxtTeleportIslandComponent -->
|
||||
<HelloWorld />
|
||||
<!-- should be wrapped by NuxtTeleportIslandComponent with a rootDir attr -->
|
||||
<NuxtTeleportIslandComponent to="HelloWorld-ZsRS8qEyqK" root-dir="/root" :nuxt-client="true"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
<NuxtTeleportIslandComponent to="HelloWorld-CyH3UXLuYA" :nuxt-client="true"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
@ -247,42 +241,6 @@ describe('islandTransform - server and island components', () => {
|
||||
</script>
|
||||
"
|
||||
`)
|
||||
// root-dir prop should never be used in production
|
||||
expect(result).toContain('root-dir="/root"')
|
||||
})
|
||||
|
||||
it('test transform with vite in prod', async () => {
|
||||
const result = await viteTransform(`<template>
|
||||
<div>
|
||||
<HelloWorld />
|
||||
<HelloWorld nuxt-client />
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
import HelloWorld from './HelloWorld.vue'
|
||||
</script>
|
||||
`, 'hello.server.vue', false, true)
|
||||
|
||||
expect(normalizeLineEndings(result)).toMatchInlineSnapshot(`
|
||||
"<template>
|
||||
<div>
|
||||
<HelloWorld />
|
||||
<NuxtTeleportIslandComponent to="HelloWorld-CyH3UXLuYA" :nuxt-client="true"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
import { vforToArray as __vforToArray } from '#app/components/utils'
|
||||
import NuxtTeleportIslandComponent from '#app/components/nuxt-teleport-island-component'
|
||||
import NuxtTeleportSsrSlot from '#app/components/nuxt-teleport-island-slot'
|
||||
import HelloWorld from './HelloWorld.vue'
|
||||
</script>
|
||||
"
|
||||
`)
|
||||
|
||||
// root-dir prop should never be used in production
|
||||
expect(result).not.toContain('root-dir="')
|
||||
})
|
||||
|
||||
it('test dynamic nuxt-client', async () => {
|
||||
@ -298,13 +256,13 @@ describe('islandTransform - server and island components', () => {
|
||||
|
||||
const nuxtClient = false
|
||||
</script>
|
||||
`, 'hello.server.vue', false, true)
|
||||
`, 'hello.server.vue', true)
|
||||
|
||||
expect(normalizeLineEndings(result)).toMatchInlineSnapshot(`
|
||||
"<template>
|
||||
<div>
|
||||
<HelloWorld />
|
||||
<NuxtTeleportIslandComponent to="HelloWorld-eo0XycWCUV" :nuxt-client="nuxtClient"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
<NuxtTeleportIslandComponent to="HelloWorld-eo0XycWCUV" :nuxt-client="nuxtClient"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
@ -333,7 +291,7 @@ describe('islandTransform - server and island components', () => {
|
||||
|
||||
const nuxtClient = false
|
||||
</script>
|
||||
`, 'hello.server.vue', false, false)
|
||||
`, 'hello.server.vue', false)
|
||||
|
||||
expect(normalizeLineEndings(result)).toMatchInlineSnapshot(`
|
||||
"<template>
|
||||
@ -363,21 +321,21 @@ describe('islandTransform - server and island components', () => {
|
||||
</div>
|
||||
</template>
|
||||
|
||||
`, 'hello.server.vue', false, true)
|
||||
`, 'hello.server.vue', true)
|
||||
|
||||
expect(result).toMatchInlineSnapshot(`
|
||||
"<script setup>
|
||||
import { vforToArray as __vforToArray } from '#app/components/utils'
|
||||
import NuxtTeleportIslandComponent from '#app/components/nuxt-teleport-island-component'
|
||||
import NuxtTeleportSsrSlot from '#app/components/nuxt-teleport-island-slot'</script><template>
|
||||
<div>
|
||||
<HelloWorld />
|
||||
<NuxtTeleportIslandComponent to="HelloWorld-CyH3UXLuYA" :nuxt-client="true"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
</div>
|
||||
</template>
|
||||
"<script setup>
|
||||
import { vforToArray as __vforToArray } from '#app/components/utils'
|
||||
import NuxtTeleportIslandComponent from '#app/components/nuxt-teleport-island-component'
|
||||
import NuxtTeleportSsrSlot from '#app/components/nuxt-teleport-island-slot'</script><template>
|
||||
<div>
|
||||
<HelloWorld />
|
||||
<NuxtTeleportIslandComponent to="HelloWorld-CyH3UXLuYA" :nuxt-client="true"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
"
|
||||
`)
|
||||
"
|
||||
`)
|
||||
expect(result).toContain('import NuxtTeleportIslandComponent from \'#app/components/nuxt-teleport-island-component\'')
|
||||
})
|
||||
|
||||
@ -389,7 +347,7 @@ describe('islandTransform - server and island components', () => {
|
||||
<HelloWorld v-else nuxt-client />
|
||||
</div>
|
||||
</template>
|
||||
`, 'hello.server.vue', false, true)
|
||||
`, 'hello.server.vue', true)
|
||||
|
||||
expect(result).toMatchInlineSnapshot(`
|
||||
"<script setup>
|
||||
@ -397,9 +355,9 @@ describe('islandTransform - server and island components', () => {
|
||||
import NuxtTeleportIslandComponent from '#app/components/nuxt-teleport-island-component'
|
||||
import NuxtTeleportSsrSlot from '#app/components/nuxt-teleport-island-slot'</script><template>
|
||||
<div>
|
||||
<NuxtTeleportIslandComponent v-if="false" to="HelloWorld-D9uaHyzL7X" :nuxt-client="true"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
<NuxtTeleportIslandComponent v-else-if="true" to="HelloWorld-o4RZMtArnE" :nuxt-client="true"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
<NuxtTeleportIslandComponent v-else to="HelloWorld-m1IbXHdd8O" :nuxt-client="true"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
<NuxtTeleportIslandComponent v-if="false" to="HelloWorld-D9uaHyzL7X" :nuxt-client="true"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
<NuxtTeleportIslandComponent v-else-if="true" to="HelloWorld-o4RZMtArnE" :nuxt-client="true"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
<NuxtTeleportIslandComponent v-else to="HelloWorld-m1IbXHdd8O" :nuxt-client="true"><HelloWorld /></NuxtTeleportIslandComponent>
|
||||
</div>
|
||||
</template>
|
||||
"
|
||||
|
Loading…
Reference in New Issue
Block a user