Allow enum keys accessed with bracket notation as computed properties #62892
+858
−8
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Summary
This PR fixes #25083 where enum keys accessed with bracket notation (e.g.,
Type['3x14']) were not recognized as valid computed property names in type literals, even when they resolved to literal types.The problem
The error occurred because
isLateBindableASTonly recognizedEntityNameExpression(Identifier or PropertyAccessExpression) but notElementAccessExpressionwith literal keys.The fix
Introduced
isLateBindableAccessExpression, a helper function that recursively validates access expressions:skipParenthesesThis supports:
obj.a.b.cobj['a']['b']['c']obj.a['b'].c['d'](obj.a)['b']obj[('a')]Also updated
checkGrammarForInvalidDynamicNameto use the new helper (it handlesskipParenthesesinternally now).Testing
Added test case
enumKeysAsComputedPropertiesWithBracketNotation.tscovering:Type['3x14'])Type['Foo'])obj['a']['b'])obj['a'].b,obj.a['b'])deep.a['b'].c['d'])(obj.a).b,(obj['a']).b)obj[('a')],deep[('a')][('b')].c['d'])Baseline changes
enumKeysAsComputedPropertiesWithBracketNotation.*
isolatedDeclarationLazySymbols.errors.txt
Direction['Up']in[Direction['Up']]: numberDirection['Up']wasn't recognized as a valid late-bindable name"UP"isolatedDeclarationLazySymbols.types
[Direction['Up']]now correctly resolves to"UP"instead of showingerrorAll 99,161 tests pass.