2020-07-09 01:11:57 +00:00
// Jest Snapshot v1, https://goo.gl/fbAQLP
2020-11-19 21:17:54 +00:00
exports[`SFC compile <script setup> <script> and <script setup> co-usage script first 1`] = `
"import { x } from './x'
export const n = 1
export default {
2021-06-25 17:14:49 +00:00
setup(__props, { expose }) {
expose()
2020-11-19 21:17:54 +00:00
x()
return { x }
}
}"
`;
exports[`SFC compile <script setup> <script> and <script setup> co-usage script setup first 1`] = `
"import { x } from './x'
export default {
2021-06-25 17:14:49 +00:00
setup(__props, { expose }) {
expose()
2020-11-19 21:17:54 +00:00
x()
return { x }
}
}
export const n = 1"
`;
2021-06-22 19:02:56 +00:00
exports[`SFC compile <script setup> defineEmits() 1`] = `
2020-11-13 22:38:28 +00:00
"export default {
2020-11-24 20:12:59 +00:00
emits: ['foo', 'bar'],
2021-06-25 17:14:49 +00:00
setup(__props, { expose, emit: myEmit }) {
expose()
2020-11-24 20:12:59 +00:00
2020-11-13 22:38:28 +00:00
2020-11-24 20:12:59 +00:00
return { myEmit }
}
}"
`;
2021-06-25 17:14:49 +00:00
exports[`SFC compile <script setup> defineExpose() 1`] = `
"export default {
setup(__props, { expose }) {
expose({ foo: 123 })
return { }
}
}"
`;
2021-06-25 18:05:59 +00:00
exports[`SFC compile <script setup> defineProps w/ external definition 1`] = `
"import { propsModel } from './props'
export default {
props: propsModel,
setup(__props, { expose }) {
expose()
const props = __props
return { props, propsModel }
}
}"
`;
2020-11-24 20:12:59 +00:00
exports[`SFC compile <script setup> defineProps() 1`] = `
"export default {
props: {
foo: String
},
2021-06-25 17:14:49 +00:00
setup(__props, { expose }) {
expose()
2020-11-24 20:12:59 +00:00
const props = __props
2020-11-13 22:38:28 +00:00
const bar = 1
2020-11-24 20:12:59 +00:00
return { props, bar }
2020-11-13 22:38:28 +00:00
}
}"
`;
2021-06-28 20:27:30 +00:00
exports[`SFC compile <script setup> defineProps/defineEmits in multi-variable decalration (full removal) 1`] = `
"export default {
props: ['item'],
emits: ['a'],
setup(__props, { expose, emit }) {
expose()
const props = __props
return { props, emit }
}
}"
`;
exports[`SFC compile <script setup> defineProps/defineEmits in multi-variable decalration 1`] = `
"export default {
props: ['item'],
emits: ['a'],
setup(__props, { expose, emit }) {
expose()
const props = __props
const a = 1;
return { props, a, emit }
}
}"
`;
2020-11-24 20:12:59 +00:00
exports[`SFC compile <script setup> errors should allow defineProps/Emit() referencing imported binding 1`] = `
2020-11-12 23:11:25 +00:00
"import { bar } from './bar'
2020-11-24 20:12:59 +00:00
2020-11-12 23:11:25 +00:00
export default {
props: {
2020-11-24 20:12:59 +00:00
foo: {
default: () => bar
}
},
emits: {
foo: () => bar > 1
},
2021-06-25 17:14:49 +00:00
setup(__props, { expose }) {
expose()
2020-07-09 01:11:57 +00:00
2020-11-24 20:12:59 +00:00
2020-11-12 23:11:25 +00:00
2020-10-29 19:03:39 +00:00
return { bar }
2020-07-09 01:11:57 +00:00
}
2020-11-12 23:11:25 +00:00
}"
`;
2020-11-24 20:12:59 +00:00
exports[`SFC compile <script setup> errors should allow defineProps/Emit() referencing scope var 1`] = `
2020-11-12 23:11:25 +00:00
"export default {
props: {
2020-11-24 20:12:59 +00:00
foo: {
default: bar => bar + 1
}
},
emits: {
foo: bar => bar > 1
},
2021-06-25 17:14:49 +00:00
setup(__props, { expose }) {
expose()
2020-07-09 01:11:57 +00:00
2020-11-12 23:11:25 +00:00
const bar = 1
2020-11-24 20:12:59 +00:00
2020-11-12 23:11:25 +00:00
return { bar }
2020-07-09 01:11:57 +00:00
}
2020-11-12 23:11:25 +00:00
}"
2020-07-09 01:11:57 +00:00
`;
2020-10-29 19:03:39 +00:00
exports[`SFC compile <script setup> imports dedupe between user & helper 1`] = `
2020-11-16 16:35:30 +00:00
"import { ref as _ref } from 'vue'
import { ref } from 'vue'
2020-11-12 23:11:25 +00:00
export default {
2021-06-25 17:14:49 +00:00
setup(__props, { expose }) {
expose()
2020-07-09 01:11:57 +00:00
2021-07-14 19:40:09 +00:00
let foo = _ref(1)
2020-11-12 23:11:25 +00:00
return { foo, ref }
2020-07-09 01:11:57 +00:00
}
2020-11-12 23:11:25 +00:00
}"
2020-07-09 01:11:57 +00:00
`;
2020-10-29 19:03:39 +00:00
exports[`SFC compile <script setup> imports import dedupe between <script> and <script setup> 1`] = `
"import { x } from './x'
2020-11-12 23:11:25 +00:00
export default {
2021-06-25 17:14:49 +00:00
setup(__props, { expose }) {
expose()
2020-07-09 01:11:57 +00:00
2020-10-29 19:03:39 +00:00
x()
return { x }
2020-07-09 01:11:57 +00:00
}
2020-11-12 23:11:25 +00:00
}"
2020-07-09 01:11:57 +00:00
`;
2021-07-22 16:04:46 +00:00
exports[`SFC compile <script setup> imports imports not used in <template> should not be exposed 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
2021-07-22 16:53:08 +00:00
import { FooBar, FooBaz, FooQux, vMyDir, x, y, z } from './x'
2021-07-22 16:04:46 +00:00
export default _defineComponent({
setup(__props, { expose }) {
expose()
const fooBar: FooBar = 1
2021-07-22 16:53:08 +00:00
return { fooBar, FooBaz, FooQux, vMyDir, x, z }
2021-07-22 16:04:46 +00:00
}
})"
`;
2021-02-13 09:06:34 +00:00
exports[`SFC compile <script setup> imports should allow defineProps/Emit at the start of imports 1`] = `
"import { ref } from 'vue'
export default {
props: ['foo'],
emits: ['bar'],
2021-06-25 17:14:49 +00:00
setup(__props, { expose }) {
expose()
2021-02-13 09:06:34 +00:00
const r = ref(0)
return { r, ref }
}
}"
`;
2020-10-29 19:03:39 +00:00
exports[`SFC compile <script setup> imports should extract comment for import or type declarations 1`] = `
"import a from 'a' // comment
2020-11-12 23:11:25 +00:00
import b from 'b'
export default {
2021-06-25 17:14:49 +00:00
setup(__props, { expose }) {
expose()
2020-07-09 01:11:57 +00:00
2020-11-12 23:11:25 +00:00
2020-10-29 19:03:39 +00:00
return { a, b }
2020-07-09 01:11:57 +00:00
}
2020-11-12 23:11:25 +00:00
}"
2020-07-09 01:11:57 +00:00
`;
2020-10-29 19:03:39 +00:00
exports[`SFC compile <script setup> imports should hoist and expose imports 1`] = `
"import { ref } from 'vue'
2020-11-28 18:51:32 +00:00
import 'foo/css'
2020-11-12 23:11:25 +00:00
export default {
2021-06-25 17:14:49 +00:00
setup(__props, { expose }) {
expose()
2020-07-09 01:11:57 +00:00
2020-11-28 18:51:32 +00:00
2020-10-29 19:03:39 +00:00
return { ref }
2020-07-09 01:11:57 +00:00
}
2020-11-12 23:11:25 +00:00
}"
`;
exports[`SFC compile <script setup> inlineTemplate mode avoid unref() when necessary 1`] = `
2021-06-22 23:15:20 +00:00
"import { unref as _unref, toDisplayString as _toDisplayString, createTextVNode as _createTextVNode, withCtx as _withCtx, createVNode as _createVNode, createElementVNode as _createElementVNode, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock } from \\"vue\\"
2020-11-12 23:11:25 +00:00
import { ref } from 'vue'
2020-12-01 16:52:29 +00:00
import Foo, { bar } from './Foo.vue'
2020-11-12 23:11:25 +00:00
import other from './util'
export default {
2020-11-16 23:27:15 +00:00
setup(__props) {
2020-11-12 23:11:25 +00:00
const count = ref(0)
const constant = {}
2020-11-19 03:39:08 +00:00
const maybe = foo()
let lett = 1
2020-11-12 23:11:25 +00:00
function fn() {}
2020-11-16 23:27:15 +00:00
return (_ctx, _cache) => {
2021-06-22 23:15:20 +00:00
return (_openBlock(), _createElementBlock(_Fragment, null, [
2020-12-01 16:52:29 +00:00
_createVNode(Foo, null, {
default: _withCtx(() => [
_createTextVNode(_toDisplayString(_unref(bar)), 1 /* TEXT */)
]),
_: 1 /* STABLE */
}),
2021-06-22 23:15:20 +00:00
_createElementVNode(\\"div\\", { onClick: fn }, _toDisplayString(count.value) + \\" \\" + _toDisplayString(constant) + \\" \\" + _toDisplayString(_unref(maybe)) + \\" \\" + _toDisplayString(_unref(lett)) + \\" \\" + _toDisplayString(_unref(other)), 1 /* TEXT */)
2020-11-12 23:11:25 +00:00
], 64 /* STABLE_FRAGMENT */))
}
}
}"
`;
2020-11-23 21:32:24 +00:00
exports[`SFC compile <script setup> inlineTemplate mode referencing scope components and directives 1`] = `
2021-06-22 23:15:20 +00:00
"import { unref as _unref, createElementVNode as _createElementVNode, withDirectives as _withDirectives, createVNode as _createVNode, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock } from \\"vue\\"
2020-11-23 21:32:24 +00:00
import ChildComp from './Child.vue'
import SomeOtherComp from './Other.vue'
2021-06-28 22:55:27 +00:00
import vMyDir from './my-dir'
2020-11-23 21:32:24 +00:00
export default {
setup(__props) {
return (_ctx, _cache) => {
2021-06-22 23:15:20 +00:00
return (_openBlock(), _createElementBlock(_Fragment, null, [
_withDirectives(_createElementVNode(\\"div\\", null, null, 512 /* NEED_PATCH */), [
2021-06-28 22:55:27 +00:00
[_unref(vMyDir)]
2020-11-23 21:32:24 +00:00
]),
_createVNode(ChildComp),
_createVNode(SomeOtherComp)
], 64 /* STABLE_FRAGMENT */))
}
}
}"
`;
2020-11-12 23:11:25 +00:00
exports[`SFC compile <script setup> inlineTemplate mode should work 1`] = `
2021-06-22 23:15:20 +00:00
"import { toDisplayString as _toDisplayString, createElementVNode as _createElementVNode, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock } from \\"vue\\"
2020-11-12 23:11:25 +00:00
2021-06-22 23:15:20 +00:00
const _hoisted_1 = /*#__PURE__*/_createElementVNode(\\"div\\", null, \\"static\\", -1 /* HOISTED */)
2020-11-12 23:11:25 +00:00
import { ref } from 'vue'
export default {
2020-11-16 23:27:15 +00:00
setup(__props) {
2020-11-12 23:11:25 +00:00
const count = ref(0)
2020-11-16 23:27:15 +00:00
return (_ctx, _cache) => {
2021-06-22 23:15:20 +00:00
return (_openBlock(), _createElementBlock(_Fragment, null, [
_createElementVNode(\\"div\\", null, _toDisplayString(count.value), 1 /* TEXT */),
2020-11-12 23:11:25 +00:00
_hoisted_1
], 64 /* STABLE_FRAGMENT */))
}
}
}"
2020-07-09 01:11:57 +00:00
`;
2020-11-20 19:22:51 +00:00
exports[`SFC compile <script setup> inlineTemplate mode ssr codegen 1`] = `
"import { useCssVars as _useCssVars, unref as _unref } from 'vue'
import { ssrRenderAttrs as _ssrRenderAttrs, ssrInterpolate as _ssrInterpolate } from \\"@vue/server-renderer\\"
import { ref } from 'vue'
export default {
__ssrInlineRender: true,
setup(__props) {
_useCssVars(_ctx => ({
\\"xxxxxxxx-count\\": (count.value)
}))
const count = ref(0)
return (_ctx, _push, _parent, _attrs) => {
const _cssVars = { style: {
\\"xxxxxxxx-count\\": (count.value)
}}
_push(\`<!--[--><div\${
_ssrRenderAttrs(_cssVars)
}>\${
_ssrInterpolate(count.value)
}</div><div\${
_ssrRenderAttrs(_cssVars)
}>static</div><!--]-->\`)
}
}
}"
`;
2020-11-19 00:38:18 +00:00
exports[`SFC compile <script setup> inlineTemplate mode template assignment expression codegen 1`] = `
2021-06-22 23:15:20 +00:00
"import { createElementVNode as _createElementVNode, isRef as _isRef, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock } from \\"vue\\"
2020-11-17 20:59:09 +00:00
import { ref } from 'vue'
export default {
setup(__props) {
const count = ref(0)
2020-11-19 00:38:18 +00:00
const maybe = foo()
let lett = 1
2021-05-28 21:58:46 +00:00
let v = ref(1)
2020-11-17 20:59:09 +00:00
return (_ctx, _cache) => {
2021-06-22 23:15:20 +00:00
return (_openBlock(), _createElementBlock(_Fragment, null, [
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[0] || (_cache[0] = $event => (count.value = 1))
2020-11-19 00:38:18 +00:00
}),
2021-06-22 23:15:20 +00:00
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[1] || (_cache[1] = $event => (maybe.value = count.value))
2020-11-19 03:39:08 +00:00
}),
2021-06-22 23:15:20 +00:00
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[2] || (_cache[2] = $event => (_isRef(lett) ? lett.value = count.value : lett = count.value))
2021-05-28 21:58:46 +00:00
}),
2021-06-22 23:15:20 +00:00
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[3] || (_cache[3] = $event => (_isRef(v) ? v.value += 1 : v += 1))
2021-05-28 21:58:46 +00:00
}),
2021-06-22 23:15:20 +00:00
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[4] || (_cache[4] = $event => (_isRef(v) ? v.value -= 1 : v -= 1))
2020-11-19 03:39:08 +00:00
})
], 64 /* STABLE_FRAGMENT */))
}
}
}"
`;
exports[`SFC compile <script setup> inlineTemplate mode template destructure assignment codegen 1`] = `
2021-06-22 23:15:20 +00:00
"import { createElementVNode as _createElementVNode, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock } from \\"vue\\"
2020-11-19 03:39:08 +00:00
import { ref } from 'vue'
export default {
setup(__props) {
const val = {}
const count = ref(0)
const maybe = foo()
let lett = 1
return (_ctx, _cache) => {
2021-06-22 23:15:20 +00:00
return (_openBlock(), _createElementBlock(_Fragment, null, [
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[0] || (_cache[0] = $event => (({ count: count.value } = val)))
2020-11-19 03:39:08 +00:00
}),
2021-06-22 23:15:20 +00:00
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[1] || (_cache[1] = $event => ([maybe.value] = val))
2020-11-19 00:38:18 +00:00
}),
2021-06-22 23:15:20 +00:00
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[2] || (_cache[2] = $event => (({ lett: lett } = val)))
2020-11-19 00:38:18 +00:00
})
], 64 /* STABLE_FRAGMENT */))
}
}
}"
`;
exports[`SFC compile <script setup> inlineTemplate mode template update expression codegen 1`] = `
2021-06-22 23:15:20 +00:00
"import { createElementVNode as _createElementVNode, isRef as _isRef, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock } from \\"vue\\"
2020-11-19 00:38:18 +00:00
import { ref } from 'vue'
export default {
setup(__props) {
const count = ref(0)
const maybe = foo()
let lett = 1
return (_ctx, _cache) => {
2021-06-22 23:15:20 +00:00
return (_openBlock(), _createElementBlock(_Fragment, null, [
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[0] || (_cache[0] = $event => (count.value++))
2020-11-19 00:38:18 +00:00
}),
2021-06-22 23:15:20 +00:00
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[1] || (_cache[1] = $event => (--count.value))
2020-11-19 00:38:18 +00:00
}),
2021-06-22 23:15:20 +00:00
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[2] || (_cache[2] = $event => (maybe.value++))
2020-11-19 00:38:18 +00:00
}),
2021-06-22 23:15:20 +00:00
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[3] || (_cache[3] = $event => (--maybe.value))
2020-11-19 00:38:18 +00:00
}),
2021-06-22 23:15:20 +00:00
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[4] || (_cache[4] = $event => (_isRef(lett) ? lett.value++ : lett++))
2020-11-19 00:38:18 +00:00
}),
2021-06-22 23:15:20 +00:00
_createElementVNode(\\"div\\", {
2021-07-10 01:41:44 +00:00
onClick: _cache[5] || (_cache[5] = $event => (_isRef(lett) ? --lett.value : --lett))
2020-11-19 00:38:18 +00:00
})
], 64 /* STABLE_FRAGMENT */))
}
}
}"
`;
exports[`SFC compile <script setup> inlineTemplate mode v-model codegen 1`] = `
2021-06-22 23:15:20 +00:00
"import { vModelText as _vModelText, createElementVNode as _createElementVNode, withDirectives as _withDirectives, unref as _unref, isRef as _isRef, Fragment as _Fragment, openBlock as _openBlock, createElementBlock as _createElementBlock } from \\"vue\\"
2020-11-19 00:38:18 +00:00
import { ref } from 'vue'
export default {
setup(__props) {
const count = ref(0)
const maybe = foo()
let lett = 1
return (_ctx, _cache) => {
2021-06-22 23:15:20 +00:00
return (_openBlock(), _createElementBlock(_Fragment, null, [
_withDirectives(_createElementVNode(\\"input\\", {
2021-07-10 01:41:44 +00:00
\\"onUpdate:modelValue\\": _cache[0] || (_cache[0] = $event => (count.value = $event))
2020-11-19 00:38:18 +00:00
}, null, 512 /* NEED_PATCH */), [
2020-11-19 03:39:08 +00:00
[_vModelText, count.value]
2020-11-19 00:38:18 +00:00
]),
2021-06-22 23:15:20 +00:00
_withDirectives(_createElementVNode(\\"input\\", {
2021-07-10 01:41:44 +00:00
\\"onUpdate:modelValue\\": _cache[1] || (_cache[1] = $event => (_isRef(maybe) ? maybe.value = $event : null))
2020-11-19 00:38:18 +00:00
}, null, 512 /* NEED_PATCH */), [
[_vModelText, _unref(maybe)]
]),
2021-06-22 23:15:20 +00:00
_withDirectives(_createElementVNode(\\"input\\", {
2021-07-10 01:41:44 +00:00
\\"onUpdate:modelValue\\": _cache[2] || (_cache[2] = $event => (_isRef(lett) ? lett.value = $event : lett = $event))
2020-11-19 00:38:18 +00:00
}, null, 512 /* NEED_PATCH */), [
[_vModelText, _unref(lett)]
])
], 64 /* STABLE_FRAGMENT */))
2020-11-17 20:59:09 +00:00
}
}
}"
`;
2021-06-25 17:14:49 +00:00
exports[`SFC compile <script setup> inlineTemplate mode with defineExpose() 1`] = `
"export default {
setup(__props, { expose }) {
const count = ref(0)
expose({ count })
return () => {}
}
}"
`;
2020-10-29 19:03:39 +00:00
exports[`SFC compile <script setup> should expose top level declarations 1`] = `
"import { x } from './x'
2020-11-12 23:11:25 +00:00
export default {
2021-06-25 17:14:49 +00:00
setup(__props, { expose }) {
expose()
2020-07-09 01:11:57 +00:00
2020-10-29 19:03:39 +00:00
let a = 1
const b = 2
function c() {}
class d {}
2020-11-12 23:11:25 +00:00
return { a, b, c, d, x }
}
}"
`;
2021-07-19 21:31:13 +00:00
exports[`SFC compile <script setup> with TypeScript const Enum 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
const enum Foo { A = 123 }
export default _defineComponent({
setup(__props, { expose }) {
expose()
return { Foo }
}
})"
`;
2021-06-28 20:03:27 +00:00
exports[`SFC compile <script setup> with TypeScript defineEmits w/ type (exported interface) 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
export interface Emits { (e: 'foo' | 'bar'): void }
export default _defineComponent({
emits: [\\"foo\\", \\"bar\\"] as unknown as undefined,
setup(__props, { expose, emit }: { emit: ({ (e: 'foo' | 'bar'): void }), expose: any, slots: any, attrs: any }) {
expose()
return { emit }
}
})"
`;
exports[`SFC compile <script setup> with TypeScript defineEmits w/ type (exported type alias) 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
export type Emits = { (e: 'foo' | 'bar'): void }
export default _defineComponent({
emits: [\\"foo\\", \\"bar\\"] as unknown as undefined,
setup(__props, { expose, emit }: { emit: ({ (e: 'foo' | 'bar'): void }), expose: any, slots: any, attrs: any }) {
expose()
return { emit }
}
})"
`;
exports[`SFC compile <script setup> with TypeScript defineEmits w/ type (interface) 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
interface Emits { (e: 'foo' | 'bar'): void }
export default _defineComponent({
emits: [\\"foo\\", \\"bar\\"] as unknown as undefined,
setup(__props, { expose, emit }: { emit: ({ (e: 'foo' | 'bar'): void }), expose: any, slots: any, attrs: any }) {
expose()
return { emit }
}
})"
`;
exports[`SFC compile <script setup> with TypeScript defineEmits w/ type (referenced exported function type) 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
export type Emits = (e: 'foo' | 'bar') => void
export default _defineComponent({
emits: [\\"foo\\", \\"bar\\"] as unknown as undefined,
setup(__props, { expose, emit }: { emit: ((e: 'foo' | 'bar') => void), expose: any, slots: any, attrs: any }) {
expose()
return { emit }
}
})"
`;
exports[`SFC compile <script setup> with TypeScript defineEmits w/ type (referenced function type) 1`] = `
2020-11-16 16:35:30 +00:00
"import { defineComponent as _defineComponent } from 'vue'
2021-06-28 20:03:27 +00:00
type Emits = (e: 'foo' | 'bar') => void
export default _defineComponent({
emits: [\\"foo\\", \\"bar\\"] as unknown as undefined,
setup(__props, { expose, emit }: { emit: ((e: 'foo' | 'bar') => void), expose: any, slots: any, attrs: any }) {
expose()
2020-11-12 23:11:25 +00:00
2021-06-28 20:03:27 +00:00
return { emit }
}
})"
`;
exports[`SFC compile <script setup> with TypeScript defineEmits w/ type (type alias) 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
type Emits = { (e: 'foo' | 'bar'): void }
export default _defineComponent({
emits: [\\"foo\\", \\"bar\\"] as unknown as undefined,
setup(__props, { expose, emit }: { emit: ({ (e: 'foo' | 'bar'): void }), expose: any, slots: any, attrs: any }) {
expose()
return { emit }
}
})"
`;
exports[`SFC compile <script setup> with TypeScript defineEmits w/ type (type literal w/ call signatures) 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
2020-11-16 16:35:30 +00:00
export default _defineComponent({
2020-11-12 23:11:25 +00:00
emits: [\\"foo\\", \\"bar\\", \\"baz\\"] as unknown as undefined,
2021-06-25 17:14:49 +00:00
setup(__props, { expose, emit }: { emit: ({(e: 'foo' | 'bar'): void; (e: 'baz', id: number): void;}), expose: any, slots: any, attrs: any }) {
expose()
2020-11-12 23:11:25 +00:00
return { emit }
}
})"
`;
2021-06-22 19:02:56 +00:00
exports[`SFC compile <script setup> with TypeScript defineEmits w/ type 1`] = `
2020-11-24 20:12:59 +00:00
"import { defineComponent as _defineComponent } from 'vue'
2020-11-12 23:11:25 +00:00
2020-11-16 16:35:30 +00:00
export default _defineComponent({
2020-11-12 23:11:25 +00:00
emits: [\\"foo\\", \\"bar\\"] as unknown as undefined,
2021-06-25 17:14:49 +00:00
setup(__props, { expose, emit }: { emit: ((e: 'foo' | 'bar') => void), expose: any, slots: any, attrs: any }) {
expose()
2020-11-12 23:11:25 +00:00
return { emit }
}
})"
`;
2021-06-28 15:39:24 +00:00
exports[`SFC compile <script setup> with TypeScript defineProps w/ exported interface 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
export interface Props { x?: number }
export default _defineComponent({
props: {
x: { type: Number, required: false }
} as unknown as undefined,
setup(__props: { x?: number }, { expose }) {
expose()
return { }
}
})"
`;
exports[`SFC compile <script setup> with TypeScript defineProps w/ exported type alias 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
export type Props = { x?: number }
export default _defineComponent({
props: {
x: { type: Number, required: false }
} as unknown as undefined,
setup(__props: { x?: number }, { expose }) {
expose()
return { }
}
})"
`;
exports[`SFC compile <script setup> with TypeScript defineProps w/ interface 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
interface Props { x?: number }
export default _defineComponent({
props: {
x: { type: Number, required: false }
} as unknown as undefined,
setup(__props: { x?: number }, { expose }) {
expose()
return { }
}
})"
`;
2020-11-24 20:12:59 +00:00
exports[`SFC compile <script setup> with TypeScript defineProps w/ type 1`] = `
2020-11-16 16:35:30 +00:00
"import { defineComponent as _defineComponent } from 'vue'
2021-06-28 20:03:27 +00:00
interface Test {}
2020-11-12 23:11:25 +00:00
type Alias = number[]
2020-11-16 16:35:30 +00:00
export default _defineComponent({
2020-11-12 23:11:25 +00:00
props: {
string: { type: String, required: true },
number: { type: Number, required: true },
boolean: { type: Boolean, required: true },
object: { type: Object, required: true },
objectLiteral: { type: Object, required: true },
fn: { type: Function, required: true },
functionRef: { type: Function, required: true },
objectRef: { type: Object, required: true },
array: { type: Array, required: true },
arrayRef: { type: Array, required: true },
tuple: { type: Array, required: true },
set: { type: Set, required: true },
literal: { type: String, required: true },
optional: { type: null, required: false },
recordRef: { type: Object, required: true },
interface: { type: Object, required: true },
alias: { type: Array, required: true },
2021-06-28 19:39:04 +00:00
method: { type: Function, required: true },
2020-11-12 23:11:25 +00:00
union: { type: [String, Number], required: true },
literalUnion: { type: [String, String], required: true },
literalUnionMixed: { type: [String, Number, Boolean], required: true },
2021-07-19 15:09:24 +00:00
intersection: { type: Object, required: true },
foo: { type: [Function, null], required: true }
2020-11-12 23:11:25 +00:00
} as unknown as undefined,
2020-11-24 20:12:59 +00:00
setup(__props: {
string: string
number: number
boolean: boolean
object: object
objectLiteral: { a: number }
fn: (n: number) => void
functionRef: Function
objectRef: Object
array: string[]
arrayRef: Array<any>
tuple: [number, number]
set: Set<string>
literal: 'foo'
optional?: any
recordRef: Record<string, null>
interface: Test
alias: Alias
2021-06-28 19:39:04 +00:00
method(): void
2020-11-24 20:12:59 +00:00
union: string | number
literalUnion: 'foo' | 'bar'
literalUnionMixed: 'foo' | 1 | boolean
intersection: Test & {}
2021-07-19 15:09:24 +00:00
foo: ((item: any) => boolean) | null
2021-06-25 17:14:49 +00:00
}, { expose }) {
expose()
2020-11-12 23:11:25 +00:00
2021-06-28 15:39:24 +00:00
return { }
}
})"
`;
exports[`SFC compile <script setup> with TypeScript defineProps w/ type alias 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
type Props = { x?: number }
export default _defineComponent({
props: {
x: { type: Number, required: false }
} as unknown as undefined,
setup(__props: { x?: number }, { expose }) {
expose()
2020-11-13 22:38:28 +00:00
return { }
}
})"
`;
2020-11-24 20:12:59 +00:00
exports[`SFC compile <script setup> with TypeScript defineProps/Emit w/ runtime options 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
export default _defineComponent({
props: { foo: String },
emits: ['a', 'b'],
2021-06-25 17:14:49 +00:00
setup(__props, { expose, emit }) {
expose()
2020-11-24 20:12:59 +00:00
const props = __props
return { props, emit }
}
})"
`;
2020-11-13 22:38:28 +00:00
exports[`SFC compile <script setup> with TypeScript hoist type declarations 1`] = `
2020-11-16 16:35:30 +00:00
"import { defineComponent as _defineComponent } from 'vue'
2020-11-13 22:38:28 +00:00
export interface Foo {}
type Bar = {}
2020-11-16 16:35:30 +00:00
export default _defineComponent({
2021-06-25 17:14:49 +00:00
setup(__props, { expose }) {
expose()
2020-11-13 22:38:28 +00:00
2020-11-12 23:11:25 +00:00
return { }
}
})"
2020-07-09 01:11:57 +00:00
`;
2021-06-27 01:11:57 +00:00
2021-06-30 16:03:42 +00:00
exports[`SFC compile <script setup> with TypeScript runtime Enum 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
enum Foo { A = 123 }
export default _defineComponent({
setup(__props, { expose }) {
expose()
return { Foo }
}
})"
`;
2021-06-27 01:11:57 +00:00
exports[`SFC compile <script setup> with TypeScript withDefaults (dynamic) 1`] = `
"import { mergeDefaults as _mergeDefaults, defineComponent as _defineComponent } from 'vue'
import { defaults } from './foo'
export default _defineComponent({
props: _mergeDefaults({
foo: { type: String, required: false },
bar: { type: Number, required: false }
}, { ...defaults }) as unknown as undefined,
setup(__props: {
foo?: string
bar?: number
}, { expose }) {
expose()
const props = __props
return { props, defaults }
}
})"
`;
exports[`SFC compile <script setup> with TypeScript withDefaults (static) 1`] = `
"import { defineComponent as _defineComponent } from 'vue'
export default _defineComponent({
props: {
foo: { type: String, required: false, default: 'hi' },
bar: { type: Number, required: false }
} as unknown as undefined,
setup(__props: {
foo?: string
bar?: number
}, { expose }) {
expose()
const props = __props
return { props }
}
})"
`;