From d09c6f1ee9e31de56325e8c8934e936ba09d0592 Mon Sep 17 00:00:00 2001 From: Brian Vaughn Date: Wed, 7 Jul 2021 14:29:41 -0400 Subject: [PATCH] DevTools named hooks: Support FLow syntax (#21815) Detect Flow pragma (@flow) and use Flow plug-in instead of TypeScript (default) --- packages/react-devtools-extensions/src/parseHookNames.js | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/packages/react-devtools-extensions/src/parseHookNames.js b/packages/react-devtools-extensions/src/parseHookNames.js index 9d183375e8052..bd4a7e63838e2 100644 --- a/packages/react-devtools-extensions/src/parseHookNames.js +++ b/packages/react-devtools-extensions/src/parseHookNames.js @@ -542,10 +542,15 @@ async function parseSourceAST( hookSourceData.originalSourceAST = sourceMetadata.originalSourceAST; hookSourceData.originalSourceCode = sourceMetadata.originalSourceCode; } else { + // TypeScript is the most commonly used typed JS variant so let's default to it + // unless we detect explicit Flow usage via the "@flow" pragma. + const plugin = + originalSourceCode.indexOf('@flow') > 0 ? 'flow' : 'typescript'; + // TODO (named hooks) Parsing should ideally be done off of the main thread. const originalSourceAST = parse(originalSourceCode, { sourceType: 'unambiguous', - plugins: ['jsx', 'typescript'], + plugins: ['jsx', plugin], }); hookSourceData.originalSourceAST = originalSourceAST; if (__DEBUG__) {