-
Notifications
You must be signed in to change notification settings - Fork 13.1k
Open
Labels
BugA bug in TypeScriptA bug in TypeScriptDomain: flag: isolatedDeclarationsRelated to the --isolatedDeclarations compiler flagRelated to the --isolatedDeclarations compiler flagHelp WantedYou can do thisYou can do this
Milestone
Description
π Search Terms
isolated declarations, computed properties
β Viability Checklist
- 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, new syntax sugar for JS, etc.)
- This isn't a request to add a new utility type: https://github.com/microsoft/TypeScript/wiki/No-New-Utility-Types
- This feature would agree with the rest of our Design Goals: https://github.com/Microsoft/TypeScript/wiki/TypeScript-Design-Goals
β Suggestion
Now that #60052 allows for (some) computed properties in in .d.ts files I think the next step is for --isolatedDeclaration to be updated to not error and to emit the computed properties. Opening this issue if helpful to track this work.
I believe the previous plan (#58800) to introduce a new syntactic marker is no longer required.
Related issues: #58533 #60818 #61068
π Motivating Example
export const prop: unique symbol = Symbol();
export class MyClass {
[prop] = () => Math.random();
}@isolatedDeclarations: false
export declare const prop: unique symbol;
export declare class MyClass {
[prop]: () => number;
}@isolatedDeclarations: true (current π)
ts(9038) Computed property names on class or object literals cannot be inferred with --isolatedDeclarations.export declare const prop: unique symbol;
export declare class MyClass {
}@isolatedDeclarations: true (future π )
No error and same emit as @isolatedDeclarations: false
export declare const prop: unique symbol;
export declare class MyClass {
[prop]: () => number;
}π» Use Cases
The primary use case is enabling isolated declarations at scale on large codebases that make heavy use of computed properties.
robpalme, bradzacher, jeremybanka and StevenGBrownTJLSmith0831
Metadata
Metadata
Assignees
Labels
BugA bug in TypeScriptA bug in TypeScriptDomain: flag: isolatedDeclarationsRelated to the --isolatedDeclarations compiler flagRelated to the --isolatedDeclarations compiler flagHelp WantedYou can do thisYou can do this