From 0a72f41c8ff39f8be5da2622baf5d017569821f8 Mon Sep 17 00:00:00 2001 From: Carlos Rodrigues Date: Tue, 14 Nov 2023 10:41:23 +0000 Subject: [PATCH 1/2] WIP: preparation for vue utility types PR --- test-workspace/tsc/vue3/components/main.vue | 66 ++++++++++----------- 1 file changed, 33 insertions(+), 33 deletions(-) diff --git a/test-workspace/tsc/vue3/components/main.vue b/test-workspace/tsc/vue3/components/main.vue index c95d0a01c3..bf6efb6c30 100644 --- a/test-workspace/tsc/vue3/components/main.vue +++ b/test-workspace/tsc/vue3/components/main.vue @@ -1,24 +1,24 @@ From 485cb129a278e6e1df05679bbe047a84f7655011 Mon Sep 17 00:00:00 2001 From: Carlos Rodrigues Date: Tue, 14 Nov 2023 10:44:16 +0000 Subject: [PATCH 2/2] update snapshots --- .../tsc/tests/__snapshots__/dts.spec.ts.snap | 402 ++++++++---------- test-workspace/tsc/vue3/#3518/main.vue | 1 - 2 files changed, 167 insertions(+), 236 deletions(-) diff --git a/packages/tsc/tests/__snapshots__/dts.spec.ts.snap b/packages/tsc/tests/__snapshots__/dts.spec.ts.snap index 7e5d5676e7..5a82a0a037 100644 --- a/packages/tsc/tests/__snapshots__/dts.spec.ts.snap +++ b/packages/tsc/tests/__snapshots__/dts.spec.ts.snap @@ -17,7 +17,9 @@ export default _default; `; exports[`vue-tsc-dts > Input: empty-component/component.vue, Output: empty-component/component.vue.d.ts 1`] = ` -"declare const _default: import(\\"vue\\").DefineComponent<{}, {}, {}, {}, {}, import(\\"vue\\").ComponentOptionsMixin, import(\\"vue\\").ComponentOptionsMixin, {}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly>, {}, {}>; +"declare const _default: import(\\"vue\\").DefineComponent<{}, {}, {}, {}, {}, import(\\"vue\\").ComponentOptionsMixin, import(\\"vue\\").ComponentOptionsMixin, {}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly<{} & {}>, {}, {}, string, {}, { + setup(this: void): {}; +}>; export default _default; " `; @@ -39,78 +41,57 @@ exports[`vue-tsc-dts > Input: options-api/component.ts, Output: options-api/comp */ password: string; } -declare const _default: import(\\"vue\\").DefineComponent<{ - /** - * Default number - */ - numberDefault: { - type: NumberConstructor; - default: number; - }; - /** - * Default function Object - */ - objectDefault: { - type: ObjectConstructor; - default: () => { - foo: string; - }; - }; - /** - * Default function Array - */ - arrayDefault: { - type: ArrayConstructor; - default: () => number[]; - }; - /** - * Default function more complex - */ - complexDefault: { - type: ArrayConstructor; - default: (props: any) => any[]; - }; -}, unknown, unknown, {}, {}, import(\\"vue\\").ComponentOptionsMixin, import(\\"vue\\").ComponentOptionsMixin, { +declare const _default: import(\\"vue\\").DefineComponent<{}, {}, {}, {}, {}, import(\\"vue\\").ComponentOptionsMixin, import(\\"vue\\").ComponentOptionsMixin, { submit: ({ email, password }: SubmitPayload) => boolean; -}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly { - foo: string; - }; - }; - /** - * Default function Array - */ - arrayDefault: { - type: ArrayConstructor; - default: () => number[]; - }; - /** - * Default function more complex - */ - complexDefault: { - type: ArrayConstructor; - default: (props: any) => any[]; - }; -}>> & { +}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly<{ + numberDefault: number; + objectDefault: Record; + arrayDefault: unknown[]; + complexDefault: unknown[]; +} & {} & { onSubmit?: (args_0: SubmitPayload) => any; -}, { +}>, { numberDefault: number; objectDefault: Record; arrayDefault: unknown[]; complexDefault: unknown[]; -}, {}>; +}, {}, string, {}, { + emits: { + submit: ({ email, password }: SubmitPayload) => boolean; + }; + props: { + /** + * Default number + */ + numberDefault: { + type: NumberConstructor; + default: number; + }; + /** + * Default function Object + */ + objectDefault: { + type: ObjectConstructor; + default: () => { + foo: string; + }; + }; + /** + * Default function Array + */ + arrayDefault: { + type: ArrayConstructor; + default: () => number[]; + }; + /** + * Default function more complex + */ + complexDefault: { + type: ArrayConstructor; + default: (props: any) => any[]; + }; + }; +}>; export default _default; " `; @@ -125,7 +106,7 @@ exports[`vue-tsc-dts > Input: reference-type-events/component.vue, Output: refer arg2?: any; }) => void; baz: () => void; -}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly> & { +}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly<{} & {} & { onBar?: (value: { arg1: number; arg2?: any; @@ -134,7 +115,19 @@ exports[`vue-tsc-dts > Input: reference-type-events/component.vue, Output: refer foo: string; }) => any; onBaz?: () => any; -}, {}, {}>; +}>, {}, {}, string, {}, { + emits: { + foo: (data?: { + foo: string; + }) => void; + bar: (value: { + arg1: number; + arg2?: any; + }) => void; + baz: () => void; + }; + setup(this: void): {}; +}>; export default _default; " `; @@ -164,185 +157,120 @@ exports[`vue-tsc-dts > Input: reference-type-exposed/component.vue, Output: refe * a counter string */ counter: import(\\"vue\\").Ref; -}, {}, {}, {}, import(\\"vue\\").ComponentOptionsMixin, import(\\"vue\\").ComponentOptionsMixin, {}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly>, {}, {}>; -export default _default; -" -`; - -exports[`vue-tsc-dts > Input: reference-type-props/component.vue, Output: reference-type-props/component.vue.d.ts 1`] = ` -"import { MyProps } from './my-props'; -declare const _default: import(\\"vue\\").DefineComponent<__VLS_WithDefaults<__VLS_TypePropsToRuntimeProps, { - bar: number; - baz: () => string[]; -}>, {}, unknown, {}, {}, import(\\"vue\\").ComponentOptionsMixin, import(\\"vue\\").ComponentOptionsMixin, {}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly, { - bar: number; - baz: () => string[]; -}>>>, { - bar: number; - baz: string[]; -}, {}>; -export default _default; -type __VLS_NonUndefinedable = T extends undefined ? never : T; -type __VLS_TypePropsToRuntimeProps = { - [K in keyof T]-?: {} extends Pick ? { - type: import('vue').PropType<__VLS_NonUndefinedable>; - } : { - type: import('vue').PropType; - required: true; +}, {}, {}, {}, import(\\"vue\\").ComponentOptionsMixin, import(\\"vue\\").ComponentOptionsMixin, {}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly<{} & {}>, {}, {}, string, {}, { + setup(this: void): { + /** + * a counter string + */ + counter: import(\\"vue\\").Ref; }; -}; -type __VLS_WithDefaults = { - [K in keyof Pick]: K extends keyof D ? __VLS_Prettify : P[K]; -}; -type __VLS_Prettify = { - [K in keyof T]: T[K]; -} & {}; +}>; +export default _default; " `; exports[`vue-tsc-dts > Input: reference-type-props/component-js.vue, Output: reference-type-props/component-js.vue.d.ts 1`] = ` -"declare const _default: import(\\"vue\\").DefineComponent<{ - foo: { - type: StringConstructor; - required: true; - }; - bar: { - type: StringConstructor; - default: string; - }; - baz: { - type: StringConstructor; - }; - xfoo: { - readonly type: StringConstructor; - readonly required: true; - }; - xbar: { - readonly type: StringConstructor; - readonly value: \\"\\"; - }; - xbaz: { - readonly type: StringConstructor; - }; -}, unknown, unknown, {}, {}, import(\\"vue\\").ComponentOptionsMixin, import(\\"vue\\").ComponentOptionsMixin, {}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly>, { +"declare const _default: import(\\"vue\\").DefineComponent<{}, {}, {}, {}, {}, import(\\"vue\\").ComponentOptionsMixin, import(\\"vue\\").ComponentOptionsMixin, {}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly<{ + bar: string; + foo: string; + xfoo: string; +} & { + baz?: string; + xbar?: string; + xbaz?: string; +}>, { bar: string; -}, {}>; +}, {}, string, {}, { + props: { + foo: { + type: StringConstructor; + required: true; + }; + bar: { + type: StringConstructor; + default: string; + }; + baz: { + type: StringConstructor; + }; + xfoo: { + readonly type: StringConstructor; + readonly required: true; + }; + xbar: { + readonly type: StringConstructor; + readonly value: \\"\\"; + }; + xbaz: { + readonly type: StringConstructor; + }; + }; +}>; export default _default; " `; exports[`vue-tsc-dts > Input: reference-type-props/component-js-setup.vue, Output: reference-type-props/component-js-setup.vue.d.ts 1`] = ` -"declare const _default: import(\\"vue\\").DefineComponent<{ - foo: { - type: StringConstructor; - required: true; - }; - bar: { - type: StringConstructor; - default: string; - }; - baz: { - type: StringConstructor; - }; - xfoo: { - readonly type: StringConstructor; - readonly required: true; - }; - xbar: { - readonly type: StringConstructor; - readonly value: \\"\\"; - }; - xbaz: { - readonly type: StringConstructor; - }; - /** - * The hello property. - * - * @since v1.0.0 - */ - hello: { - type: StringConstructor; - default: string; - }; - numberOrStringProp: { - type: (NumberConstructor | StringConstructor)[]; - default: number; - }; - arrayProps: { - type: ArrayConstructor; - default: () => number[]; - }; -}, {}, unknown, {}, {}, import(\\"vue\\").ComponentOptionsMixin, import(\\"vue\\").ComponentOptionsMixin, {}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly number[]; - }; -}>>, { +"declare const _default: import(\\"vue\\").DefineComponent<{}, {}, {}, {}, {}, import(\\"vue\\").ComponentOptionsMixin, import(\\"vue\\").ComponentOptionsMixin, {}, string, import(\\"vue\\").VNodeProps & import(\\"vue\\").AllowedComponentProps & import(\\"vue\\").ComponentCustomProps, Readonly<{ + bar: string; + foo: string; + xfoo: string; + hello: string; + numberOrStringProp: string | number; + arrayProps: unknown[]; +} & { + baz?: string; + xbar?: string; + xbaz?: string; +}>, { bar: string; hello: string; numberOrStringProp: string | number; arrayProps: unknown[]; -}, {}>; +}, {}, string, {}, { + props: { + foo: { + type: StringConstructor; + required: true; + }; + bar: { + type: StringConstructor; + default: string; + }; + baz: { + type: StringConstructor; + }; + xfoo: { + readonly type: StringConstructor; + readonly required: true; + }; + xbar: { + readonly type: StringConstructor; + readonly value: \\"\\"; + }; + xbaz: { + readonly type: StringConstructor; + }; + /** + * The hello property. + * + * @since v1.0.0 + */ + hello: { + type: StringConstructor; + default: string; + }; + numberOrStringProp: { + type: (NumberConstructor | StringConstructor)[]; + default: number; + }; + arrayProps: { + type: ArrayConstructor; + default: () => number[]; + }; + }; + setup(this: void): {}; +}>; export default _default; " `; @@ -452,7 +380,9 @@ export {}; `; exports[`vue-tsc-dts > Input: template-slots/component.vue, Output: template-slots/component.vue.d.ts 1`] = ` -"declare const _default: __VLS_WithTemplateSlots>, {}, {}>, { +"declare const _default: __VLS_WithTemplateSlots, {}, {}, string, {}, { + setup(this: void): {}; +}>, { \\"no-bind\\"?(_: {}): any; default?(_: { num: number; @@ -475,7 +405,9 @@ type __VLS_WithTemplateSlots = T & { `; exports[`vue-tsc-dts > Input: template-slots/component-no-script.vue, Output: template-slots/component-no-script.vue.d.ts 1`] = ` -"declare const _default: __VLS_WithTemplateSlots>, {}, {}>, { +"declare const _default: __VLS_WithTemplateSlots, {}, {}, string, {}, { + setup(this: void): {}; +}>, { \\"no-bind\\"?(_: {}): any; default?(_: { num: number; diff --git a/test-workspace/tsc/vue3/#3518/main.vue b/test-workspace/tsc/vue3/#3518/main.vue index 0c3570d6b9..3561495e79 100644 --- a/test-workspace/tsc/vue3/#3518/main.vue +++ b/test-workspace/tsc/vue3/#3518/main.vue @@ -11,7 +11,6 @@ defineExpose({ bar: 1 });