Skip to content

Commit

Permalink
fix(plugin-vue): setup jsx script no hmr (#6568)
Browse files Browse the repository at this point in the history
  • Loading branch information
poyoho authored Feb 23, 2022
1 parent c7aad02 commit c84601c
Show file tree
Hide file tree
Showing 4 changed files with 33 additions and 3 deletions.
7 changes: 7 additions & 0 deletions packages/playground/vue-jsx/__tests__/vue-jsx.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -102,4 +102,11 @@ if (!isBuild) {

expect(await page.textContent('.script')).toMatch('5')
})

test('hmr: setup jsx in .vue', async () => {
editFile('setup-syntax-jsx.vue', (code) =>
code.replace('let count = ref(100)', 'let count = ref(1000)')
)
await untilUpdated(() => page.textContent('.setup-jsx'), '1000')
})
}
3 changes: 2 additions & 1 deletion packages/playground/vue-jsx/main.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { default as TsxDefault } from './Comp'
import OtherExt from './OtherExt.tesx'
import JsxScript from './Script.vue'
import JsxSrcImport from './SrcImport.vue'

import JsxSetupSyntax from './setup-syntax-jsx.vue'
function App() {
return (
<>
Expand All @@ -15,6 +15,7 @@ function App() {
<OtherExt />
<JsxScript />
<JsxSrcImport />
<JsxSetupSyntax />
</>
)
}
Expand Down
17 changes: 17 additions & 0 deletions packages/playground/vue-jsx/setup-syntax-jsx.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
<script setup lang="jsx">
import { ref } from 'vue'
let count = ref(100)
const increment = () => {
count.value++
}
const Render = () => (
<div>
<button onClick={increment}> click!!! </button>
</div>
)
</script>

<template>
<p class="setup-jsx">{{ count }}</p>
<Render />
</template>
9 changes: 7 additions & 2 deletions packages/plugin-vue/src/handleHotUpdate.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,9 +40,14 @@ export async function handleHotUpdate(

if (hasScriptChanged(prevDescriptor, descriptor)) {
let scriptModule: ModuleNode | undefined
if (descriptor.script?.lang && !descriptor.script.src) {
if (
(descriptor.scriptSetup?.lang && !descriptor.scriptSetup.src) ||
(descriptor.script?.lang && !descriptor.script.src)
) {
const scriptModuleRE = new RegExp(
`type=script.*&lang\.${descriptor.script.lang}$`
`type=script.*&lang\.${
descriptor.scriptSetup?.lang || descriptor.script?.lang
}$`
)
scriptModule = modules.find((m) => scriptModuleRE.test(m.url))
}
Expand Down

0 comments on commit c84601c

Please sign in to comment.