Skip to content

Commit

Permalink
Refactor inquirer to new package structure. Closes #5510
Browse files Browse the repository at this point in the history
  • Loading branch information
martinlingstuyl committed Sep 21, 2023
1 parent 7ac2f8d commit ce7c99f
Show file tree
Hide file tree
Showing 305 changed files with 3,245 additions and 4,300 deletions.
453 changes: 265 additions & 188 deletions npm-shrinkwrap.json

Large diffs are not rendered by default.

5 changes: 3 additions & 2 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -226,6 +226,9 @@
"dependencies": {
"@azure/msal-common": "^13.2.1",
"@azure/msal-node": "^1.18.1",
"@inquirer/confirm": "^2.0.12",
"@inquirer/input": "^1.2.11",
"@inquirer/select": "^1.2.11",
"@xmldom/xmldom": "^0.8.10",
"adaptive-expressions": "^4.20.0",
"adaptivecards": "^3.0.1",
Expand All @@ -238,7 +241,6 @@
"configstore": "^6.0.0",
"csv-stringify": "^6.4.0",
"easy-table": "^1.2.0",
"inquirer": "^9.2.10",
"jmespath": "^0.16.0",
"json-to-ast": "^2.1.0",
"minimist": "^1.2.8",
Expand All @@ -256,7 +258,6 @@
"devDependencies": {
"@microsoft/microsoft-graph-types": "^2.38.0",
"@types/adm-zip": "^0.5.0",
"@types/inquirer": "^9.0.3",
"@types/jmespath": "^0.15.0",
"@types/json-to-ast": "^2.1.2",
"@types/minimist": "^1.2.2",
Expand Down
32 changes: 7 additions & 25 deletions src/Command.ts
Original file line number Diff line number Diff line change
Expand Up @@ -166,12 +166,9 @@ export default abstract class Command {
Cli.error('🌶️ Provide values for the following parameters:');
}

const missingRequireOptionValue = await prompt.forInput<{ missingRequireOptionValue: string }>({
name: 'missingRequireOptionValue',
message: `${command.options[i].name}: `
}).then(result => result.missingRequireOptionValue);
const answer = await prompt.forInput({ message: `${command.options[i].name}: ` });

args.options[command.options[i].name] = missingRequireOptionValue;
args.options[command.options[i].name] = answer;
}

if (prompted) {
Expand Down Expand Up @@ -222,34 +219,19 @@ export default abstract class Command {
private async promptForOptionSetNameAndValue(args: CommandArgs, optionSet: OptionSet): Promise<void> {
Cli.error(`🌶️ Please specify one of the following options:`);

const resultOptionName = await prompt.forInput<{ missingRequiredOptionName: string }>({
type: 'list',
name: 'missingRequiredOptionName',
message: `Option to use:`,
choices: optionSet.options
});
const missingRequiredOptionName = resultOptionName.missingRequiredOptionName;

const resultOptionValue = await prompt.forInput<{ missingRequiredOptionValue: string }>({
name: 'missingRequiredOptionValue',
message: `${missingRequiredOptionName}:`
});
const selectedOptionName = await prompt.forSelection<string>({ message: `Option to use:`, choices: optionSet.options.map((choice: any) => { return { name: choice, value: choice }; }) });
const optionValue = await prompt.forInput({ message: `${selectedOptionName}:` });

args.options[missingRequiredOptionName] = resultOptionValue.missingRequiredOptionValue;
args.options[selectedOptionName] = optionValue;
Cli.error('');
}

private async promptForSpecificOption(args: CommandArgs, commonOptions: string[]): Promise<void> {
Cli.error(`🌶️ Multiple options for an option set specified. Please specify the correct option that you wish to use.`);

const requiredOptionNameResult = await prompt.forInput<{ missingRequiredOptionName: string }>({
type: 'list',
name: 'missingRequiredOptionName',
message: `Option to use:`,
choices: commonOptions
});
const selectedOptionName = await prompt.forSelection({ message: `Option to use:`, choices: commonOptions.map((choice: any) => { return { name: choice, value: choice }; }) });

commonOptions.filter(y => y !== requiredOptionNameResult.missingRequiredOptionName).map(optionName => args.options[optionName] = undefined);
commonOptions.filter(y => y !== selectedOptionName).map(optionName => args.options[optionName] = undefined);
Cli.error('');
}

Expand Down
Loading

0 comments on commit ce7c99f

Please sign in to comment.