From 0b30c0bc486c054d93e385da78a9cd98d4f78791 Mon Sep 17 00:00:00 2001 From: dhryshyn Date: Tue, 19 Sep 2023 15:48:53 +0300 Subject: [PATCH] add ablity to open settings for private codmeods --- src/selectors/selectCodemodTree.ts | 30 +++++++++++++++++++----------- 1 file changed, 19 insertions(+), 11 deletions(-) diff --git a/src/selectors/selectCodemodTree.ts b/src/selectors/selectCodemodTree.ts index 9fff9d44..595e7e43 100644 --- a/src/selectors/selectCodemodTree.ts +++ b/src/selectors/selectCodemodTree.ts @@ -1,5 +1,5 @@ import { CodemodEntry, PrivateCodemodEntry } from '../codemods/types'; -import { buildHash, capitalize, isNeitherNullNorUndefined } from '../utilities'; +import { buildHash, capitalize } from '../utilities'; import { RootState } from '../data'; import * as t from 'io-ts'; import * as T from 'fp-ts/These'; @@ -118,15 +118,24 @@ export const selectPrivateCodemods = ( const executionPath = executionPaths[codemod.hashDigest] ?? rootPath ?? '/'; + const args = selectCodemodArguments( + state, + codemod.hashDigest as CodemodNodeHashDigest, + ); + const node = buildCodemodNode( codemod, name, executionPath, executionQueue.includes(codemod.hashDigest as CodemodHash), true, - [], + args, ); + const argumentsExpanded = + state.codemodDiscoveryView.codemodArgumentsPopupHashDigest === + hashDigest; + return { node, depth: 0, @@ -136,7 +145,7 @@ export const selectPrivateCodemods = ( hashDigest, collapsable: false, reviewed: false, - argumentsExpanded: false, + argumentsExpanded, }; }); @@ -352,17 +361,16 @@ export const selectCodemodArguments = ( return []; } - const args = - Object.values(state.codemod.entities) - .filter(isNeitherNullNorUndefined) - .find((codemodEntry) => codemodEntry.hashDigest === hashDigest) - ?.arguments ?? []; + const argumentsSchema = + Object.values(state.codemod.entities).find( + (codemodEntry) => codemodEntry?.hashDigest === hashDigest, + )?.arguments ?? []; - const savedArgsValues = + const codemodArgumentsValues = state.codemodDiscoveryView.codemodArguments[hashDigest] ?? null; - return args.map((arg) => { - const value = savedArgsValues?.[arg.name] ?? arg.default ?? ''; + return argumentsSchema.map((arg) => { + const value = codemodArgumentsValues?.[arg.name] ?? arg.default ?? ''; switch (arg.kind) { case 'string': {