From ab50e8e1da2f4f944af683252481728485fedf16 Mon Sep 17 00:00:00 2001 From: katashin Date: Thu, 25 Apr 2019 11:18:07 +0800 Subject: [PATCH] fix(types): fix global namespace declaration for UMD bundle (#9912) --- types/index.d.ts | 3 +-- types/test/tsconfig.json | 14 +++--------- types/test/umd-test.ts | 7 ++++++ types/umd.d.ts | 48 ++++++++++++++++++++++++++++++++++++++++ 4 files changed, 59 insertions(+), 13 deletions(-) create mode 100644 types/test/umd-test.ts create mode 100644 types/umd.d.ts diff --git a/types/index.d.ts b/types/index.d.ts index b0e24d767e..58ceb209e5 100644 --- a/types/index.d.ts +++ b/types/index.d.ts @@ -1,9 +1,8 @@ import { Vue } from "./vue"; +import "./umd"; export default Vue; -export as namespace Vue; - export { CreateElement, VueConstructor diff --git a/types/test/tsconfig.json b/types/test/tsconfig.json index b816ce07cd..dab30a608b 100644 --- a/types/test/tsconfig.json +++ b/types/test/tsconfig.json @@ -14,17 +14,9 @@ "vue": ["../index.d.ts"] } }, - "files": [ - "../index.d.ts", - "../options.d.ts", - "../plugin.d.ts", - "../vnode.d.ts", - "../vue.d.ts", - "options-test.ts", - "plugin-test.ts", - "vue-test.ts", - "augmentation-test.ts", - "ssr-test.ts" + "include": [ + "../*.d.ts", + "*.ts" ], "compileOnSave": false } diff --git a/types/test/umd-test.ts b/types/test/umd-test.ts new file mode 100644 index 0000000000..ffdc7046f9 --- /dev/null +++ b/types/test/umd-test.ts @@ -0,0 +1,7 @@ +const vm = new Vue({ + template: "
hi
" +}); + +const options: Vue.ComponentOptions = { + template: "
test
" +}; diff --git a/types/umd.d.ts b/types/umd.d.ts new file mode 100644 index 0000000000..618d484e48 --- /dev/null +++ b/types/umd.d.ts @@ -0,0 +1,48 @@ +import * as V from "./index"; +import { + DefaultData, + DefaultProps, + DefaultMethods, + DefaultComputed, + PropsDefinition +} from "./options"; + +// Expose some types for backword compatibility... +declare namespace Vue { + // vue.d.ts + export type CreateElement = V.CreateElement; + export type VueConstructor = V.VueConstructor; + + // options.d.ts + export type Component, Methods=DefaultMethods, Computed=DefaultComputed, Props=DefaultProps> = V.Component; + export type AsyncComponent, Methods=DefaultMethods, Computed=DefaultComputed, Props=DefaultProps> = V.AsyncComponent; + export type ComponentOptions, Methods=DefaultMethods, Computed=DefaultComputed, PropsDef=PropsDefinition, Props=DefaultProps> = V.ComponentOptions; + export type FunctionalComponentOptions> = V.FunctionalComponentOptions; + export type RenderContext = V.RenderContext; + export type PropType = V.PropType; + export type PropOptions = V.PropOptions; + export type ComputedOptions = V.ComputedOptions; + export type WatchHandler = V.WatchHandler; + export type WatchOptions = V.WatchOptions; + export type WatchOptionsWithHandler = V.WatchOptionsWithHandler; + export type DirectiveFunction = V.DirectiveFunction; + export type DirectiveOptions = V.DirectiveOptions; + + // plugin.d.ts + export type PluginFunction = V.PluginFunction; + export type PluginObject = V.PluginObject; + + // vnode.d.ts + export type VNodeChildren = V.VNodeChildren; + export type VNodeChildrenArrayContents = V.VNodeChildrenArrayContents; + export type VNode = V.VNode; + export type VNodeComponentOptions = V.VNodeComponentOptions; + export type VNodeData = V.VNodeData; + export type VNodeDirective = V.VNodeDirective; +} + +declare class Vue extends V.default {} + +export = Vue; + +export as namespace Vue;