From 57ee5df364f03816e548f4f3bf05edc7a089c362 Mon Sep 17 00:00:00 2001 From: Evan You Date: Sat, 15 Feb 2020 21:04:29 -0500 Subject: [PATCH] fix(types): app.component should accept defineComponent return type fix #730 --- packages/runtime-core/src/apiCreateApp.ts | 16 +++++++++------- packages/runtime-core/src/apiOptions.ts | 9 +++------ packages/runtime-core/src/component.ts | 7 +++++++ 3 files changed, 19 insertions(+), 13 deletions(-) diff --git a/packages/runtime-core/src/apiCreateApp.ts b/packages/runtime-core/src/apiCreateApp.ts index e022d92f955..f8189f25e90 100644 --- a/packages/runtime-core/src/apiCreateApp.ts +++ b/packages/runtime-core/src/apiCreateApp.ts @@ -1,4 +1,9 @@ -import { Component, Data, validateComponentName } from './component' +import { + Component, + Data, + validateComponentName, + PublicAPIComponent +} from './component' import { ComponentOptions } from './apiOptions' import { ComponentPublicInstance } from './componentProxy' import { Directive, validateDirectiveName } from './directives' @@ -82,10 +87,7 @@ export function createAppContext(): AppContext { } export type CreateAppFunction = ( - rootComponent: - | Component - // for compatibility with defineComponent() return types - | { new (): ComponentPublicInstance }, + rootComponent: PublicAPIComponent, rootProps?: Data | null ) => App @@ -156,7 +158,7 @@ export function createAppAPI( return app }, - component(name: string, component?: Component): any { + component(name: string, component?: PublicAPIComponent): any { if (__DEV__) { validateComponentName(name, context.config) } @@ -166,7 +168,7 @@ export function createAppAPI( if (__DEV__ && context.components[name]) { warn(`Component "${name}" has already been registered in target app.`) } - context.components[name] = component + context.components[name] = component as Component return app }, diff --git a/packages/runtime-core/src/apiOptions.ts b/packages/runtime-core/src/apiOptions.ts index 767f5950c14..3ba88f7eda9 100644 --- a/packages/runtime-core/src/apiOptions.ts +++ b/packages/runtime-core/src/apiOptions.ts @@ -1,10 +1,10 @@ import { ComponentInternalInstance, Data, - Component, SetupContext, RenderFunction, - SFCInternalOptions + SFCInternalOptions, + PublicAPIComponent } from './component' import { isFunction, @@ -70,10 +70,7 @@ export interface ComponentOptionsBase< push: (item: any) => void, parentInstance: ComponentInternalInstance ) => void - components?: Record< - string, - Component | { new (): ComponentPublicInstance } - > + components?: Record directives?: Record inheritAttrs?: boolean diff --git a/packages/runtime-core/src/component.ts b/packages/runtime-core/src/component.ts index 538ca470ceb..d90249a9823 100644 --- a/packages/runtime-core/src/component.ts +++ b/packages/runtime-core/src/component.ts @@ -53,6 +53,13 @@ export interface FunctionalComponent

extends SFCInternalOptions { } export type Component = ComponentOptions | FunctionalComponent + +// A type used in public APIs where a component type is expected. +// The constructor type is an artificial type returned by defineComponent(). +export type PublicAPIComponent = + | Component + | { new (): ComponentPublicInstance } + export { ComponentOptions } type LifecycleHook = Function[] | null