TypeScript: How to conditionally make properties required in a type, based on another object's type?

360 Views Asked by At

Assuming this situation:

interface A {
  a: string;
  b?: string;
  c?: string;
}

const myobj = {
  a: "test",
  b: "test2"
}

I'm trying to use generics to dynamically contruct a type like below, containing only those properties from A that are not defined on myobj:

interface AA {
  c: string;
}

How can this be done? I've attempted various strategies, e.g. using Exclude<>, Omit<> and "-?" but gotten nowhere so far.

2

There are 2 best solutions below

1
On BEST ANSWER

Try

interface A {
  a: string;
  b?: string;
  c?: string;
}

const myobj = {
  a: "test",
  b: "test2"
}

type B = Omit<A, keyof typeof myobj>;

const b: B = {
    a: 'a', // fails as required
    c: 'c'
};
2
On

Please take look on next example:

interface A {
  a: string;
  b?: string;
  c?: string;
}

const myobj = {
  a: "test",
  b: "test2"
}

type MyObj = typeof myobj;

type Intersection<T,I> = keyof A & keyof MyObj;

type Helper<T,U>={
    [P in Exclude<keyof T,U>]: T[P]
}

type Result = Helper<A,Intersection<A,MyObj>> // same as AA interface