first commit
This commit is contained in:
10
node_modules/@inquirer/password/dist/esm/index.d.ts
generated
vendored
Normal file
10
node_modules/@inquirer/password/dist/esm/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,10 @@
|
||||
import { type Theme } from '@inquirer/core';
|
||||
import type { PartialDeep } from '@inquirer/type';
|
||||
type PasswordConfig = {
|
||||
message: string;
|
||||
mask?: boolean | string;
|
||||
validate?: (value: string) => boolean | string | Promise<string | boolean>;
|
||||
theme?: PartialDeep<Theme>;
|
||||
};
|
||||
declare const _default: import("@inquirer/type").Prompt<string, PasswordConfig>;
|
||||
export default _default;
|
||||
55
node_modules/@inquirer/password/dist/esm/index.js
generated
vendored
Normal file
55
node_modules/@inquirer/password/dist/esm/index.js
generated
vendored
Normal file
@@ -0,0 +1,55 @@
|
||||
import { createPrompt, useState, useKeypress, usePrefix, isEnterKey, makeTheme, } from '@inquirer/core';
|
||||
import { cursorHide } from '@inquirer/ansi';
|
||||
export default createPrompt((config, done) => {
|
||||
const { validate = () => true } = config;
|
||||
const theme = makeTheme(config.theme);
|
||||
const [status, setStatus] = useState('idle');
|
||||
const [errorMsg, setError] = useState();
|
||||
const [value, setValue] = useState('');
|
||||
const prefix = usePrefix({ status, theme });
|
||||
useKeypress(async (key, rl) => {
|
||||
// Ignore keypress while our prompt is doing other processing.
|
||||
if (status !== 'idle') {
|
||||
return;
|
||||
}
|
||||
if (isEnterKey(key)) {
|
||||
const answer = value;
|
||||
setStatus('loading');
|
||||
const isValid = await validate(answer);
|
||||
if (isValid === true) {
|
||||
setValue(answer);
|
||||
setStatus('done');
|
||||
done(answer);
|
||||
}
|
||||
else {
|
||||
// Reset the readline line value to the previous value. On line event, the value
|
||||
// get cleared, forcing the user to re-enter the value instead of fixing it.
|
||||
rl.write(value);
|
||||
setError(isValid || 'You must provide a valid value');
|
||||
setStatus('idle');
|
||||
}
|
||||
}
|
||||
else {
|
||||
setValue(rl.line);
|
||||
setError(undefined);
|
||||
}
|
||||
});
|
||||
const message = theme.style.message(config.message, status);
|
||||
let formattedValue = '';
|
||||
let helpTip;
|
||||
if (config.mask) {
|
||||
const maskChar = typeof config.mask === 'string' ? config.mask : '*';
|
||||
formattedValue = maskChar.repeat(value.length);
|
||||
}
|
||||
else if (status !== 'done') {
|
||||
helpTip = `${theme.style.help('[input is masked]')}${cursorHide}`;
|
||||
}
|
||||
if (status === 'done') {
|
||||
formattedValue = theme.style.answer(formattedValue);
|
||||
}
|
||||
let error = '';
|
||||
if (errorMsg) {
|
||||
error = theme.style.error(errorMsg);
|
||||
}
|
||||
return [[prefix, message, config.mask ? formattedValue : helpTip].join(' '), error];
|
||||
});
|
||||
3
node_modules/@inquirer/password/dist/esm/package.json
generated
vendored
Normal file
3
node_modules/@inquirer/password/dist/esm/package.json
generated
vendored
Normal file
@@ -0,0 +1,3 @@
|
||||
{
|
||||
"type": "module"
|
||||
}
|
||||
Reference in New Issue
Block a user