vue/types/test/async-component-test.ts
2022-05-27 17:26:55 +08:00

45 lines
932 B
TypeScript

import Vue, { AsyncComponent, Component } from '../index'
const a: AsyncComponent = () => ({
component: new Promise<Component>((res, rej) => {
res({ template: '' })
})
})
const b: AsyncComponent = () => ({
// @ts-expect-error component has to be a Promise that resolves to a component
component: () =>
new Promise<Component>((res, rej) => {
res({ template: '' })
})
})
const c: AsyncComponent = () =>
new Promise<Component>((res, rej) => {
res({
template: ''
})
})
const d: AsyncComponent = () =>
new Promise<{ default: Component }>((res, rej) => {
res({
default: {
template: ''
}
})
})
const e: AsyncComponent = () => ({
component: new Promise<{ default: Component }>((res, rej) => {
res({
default: {
template: ''
}
})
})
})
// Test that Vue.component accepts any AsyncComponent
Vue.component('async-compponent1', a)