From 230e7bd42f6d2e15dd94627620eb0c09402b90cc Mon Sep 17 00:00:00 2001 From: bigopon Date: Tue, 27 Aug 2024 16:36:08 +1000 Subject: [PATCH] fix: correctly resolve infer type from abstract classes --- src/api-test.ts | 11 +++++++++++ src/container.ts | 34 ++++++++++++++++++---------------- 2 files changed, 29 insertions(+), 16 deletions(-) diff --git a/src/api-test.ts b/src/api-test.ts index b92a7cf..53e0927 100644 --- a/src/api-test.ts +++ b/src/api-test.ts @@ -6,6 +6,17 @@ declare const assertType: (result: [R] extends U ? R : never) => voi function testResolve() { + function testAbstractClass() { + abstract class A { + a = 1; + } + + const a = resolve(A); + if (a.a === 2) { + + } + } + function testResolveSingle() { class A { a = 1 } class B { b = '2' } diff --git a/src/container.ts b/src/container.ts index 744793c..1f35f19 100644 --- a/src/container.ts +++ b/src/container.ts @@ -608,23 +608,25 @@ export class Container { } export type ResolvedValue = - T extends { new (...args: any[]): infer R } + T extends (new (...args: any[]) => infer R) ? R - : T extends Factory - ? (...args: unknown[]) => R - : T extends Lazy - ? () => R - : T extends NewInstance - ? R - : T extends Optional - ? R | null - : T extends All - ? R[] - : T extends Parent - ? R | null - : T extends [infer T1, ...infer T2] - ? [ResolvedValue, ...ResolvedValue] - : T; + : T extends (abstract new (...args: any[]) => infer R) + ? R + : T extends Factory + ? (...args: unknown[]) => R + : T extends Lazy + ? () => R + : T extends NewInstance + ? R + : T extends Optional + ? R | null + : T extends All + ? R[] + : T extends Parent + ? R | null + : T extends [infer T1, ...infer T2] + ? [ResolvedValue, ...ResolvedValue] + : T; /** * Resolve a key, or list of keys based on the current container.