Open
Description
Search Terms
type level jsdoc
computed jsdoc
reference jsdoc from other type
Suggestion
Add a utility type Docs<T>
, which, given type T = U & Docs<V>
, results in a type T
with the type of U
, but with the JSDoc annotations of V
(overriding any U
might have). This should also add V
's go to definition results to T
's (maybe prioritized?).
This could either be implemented as a magic type like ThisType
(e.g. type Docs<T> = unknown
in lib.d.ts
), or as an intrinsic
type, as introduced in #40580.
Use Cases
This is useful to preserve context when manipulating types (see example below).
Examples
interface Person {
id: string;
/**
* The date this person was born
*/
birthDate: Date;
/**
* The date this person died; `null` indicates that the person is still alive.
*/
deathDate: Date | null;
/**
* This person's age in milliseconds. Calculated as `deathDate - birthDate`
* when dead (`deathDate === null`), `currentDate - birthDate` when not.
*/
age: number;
name: string;
}
const alice: Person = {
id: "12345",
birthDate: new Date(),
deathDate: null,
age: 0,
name: "Alice"
};
alice.deathDate // Hover `deathDate`; we can clearly see what this field means and why it might be null
type Lazy<T> = {
[K in keyof T & string as `get${Capitalize<K>}`]: () => Promise<T[K]>
// Proposed syntax:
// [K in keyof T & string as `get${Capitalize<K>}`]: (() => Promise<T[K]>) & Docs<T[K]>
}
type LazyPerson = Lazy<Person>;
declare const getLazyPerson: (id: string) => LazyPerson;
const bob = getLazyPerson("1111");
bob.getDeathDate // Hover `getDeathDate`; we've lost all information about what this field means. Why could it be null?
Checklist
My suggestion meets these guidelines:
- This wouldn't be a breaking change in existing TypeScript/JavaScript code
- This wouldn't change the runtime behavior of existing JavaScript code
- This could be implemented without emitting different JS based on the types of the expressions
- This isn't a runtime feature (e.g. library functionality, non-ECMAScript syntax with JavaScript output, etc.)
- This feature would agree with the rest of TypeScript's Design Goals.