import { Vue } from "./vue"; import { VNode, VNodeData, VNodeDirective } from "./vnode"; type Constructor = { new (...args: any[]): any; } type $createElement = typeof Vue.prototype.$createElement; export interface ComponentOptions { data?: Object | ((this: V) => Object); props?: string[] | { [key: string]: PropOptions | Constructor | Constructor[] }; propsData?: Object; computed?: { [key: string]: ((this: V) => any) | ComputedOptions }; methods?: { [key: string]: Function }; watch?: { [key: string]: ({ handler: WatchHandler } & WatchOptions) | WatchHandler | string }; el?: Element | String; template?: string; render?(this: V, createElement: $createElement): VNode; staticRenderFns?: ((createElement: $createElement) => VNode)[]; beforeCreate?(this: V): void; created?(this: V): void; beforeDestroy?(this: V): void; destroyed?(this: V): void; beforeMount?(this: V): void; mounted?(this: V): void; beforeUpdate?(this: V): void; updated?(this: V): void; directives?: { [key: string]: DirectiveOptions | DirectiveFunction }; components?: { [key: string]: ComponentOptions | FunctionalComponentOptions | typeof Vue }; transitions?: { [key: string]: Object }; filters?: { [key: string]: Function }; parent?: Vue; mixins?: (ComponentOptions | typeof Vue)[]; name?: string; extends?: ComponentOptions | typeof Vue; delimiters?: [string, string]; } export interface FunctionalComponentOptions { props?: string[] | { [key: string]: PropOptions | Constructor | Constructor[] }; functional: boolean; render(this: never, createElement: $createElement, context: RenderContext): VNode; name?: string; } export interface RenderContext { props: any; children: VNode[]; slots: any; data: VNodeData; parent: Vue; } export interface PropOptions { type?: Constructor | Constructor[] | null; required?: boolean; default?: any; validator?(value: any): boolean; } export interface ComputedOptions { get?(this: V): any; set?(this: V, value: any): void; cache?: boolean; } export type WatchHandler = (this: V, val: any, oldVal: any) => void; export interface WatchOptions { deep?: boolean; immediate?: boolean; } export type DirectiveFunction = ( el: HTMLElement, binding: VNodeDirective, vnode: VNode, oldVnode: VNode ) => void; export interface DirectiveOptions { bind?: DirectiveFunction; inserted?: DirectiveFunction; update?: DirectiveFunction; componentUpdated?: DirectiveFunction; unbind?: DirectiveFunction; }