NET-Web-API-w-Angular/my-app/node_modules/inquirer/lib/utils/events.js

53 lines
1.3 KiB
JavaScript
Raw Normal View History

2024-02-09 00:38:41 +00:00
import { fromEvent, filter, map, share, takeUntil } from 'rxjs';
function normalizeKeypressEvents(value, key) {
return { value, key: key || {} };
}
export default function (rl) {
const keypress = fromEvent(rl.input, 'keypress', normalizeKeypressEvents)
.pipe(takeUntil(fromEvent(rl, 'close')))
// Ignore `enter` key. On the readline, we only care about the `line` event.
.pipe(filter(({ key }) => key.name !== 'enter' && key.name !== 'return'));
return {
line: fromEvent(rl, 'line'),
keypress,
normalizedUpKey: keypress.pipe(
filter(
({ key }) =>
key.name === 'up' || key.name === 'k' || (key.name === 'p' && key.ctrl),
),
share(),
),
normalizedDownKey: keypress.pipe(
filter(
({ key }) =>
key.name === 'down' || key.name === 'j' || (key.name === 'n' && key.ctrl),
),
share(),
),
numberKey: keypress.pipe(
filter((e) => e.value && '123456789'.indexOf(e.value) >= 0),
map((e) => Number(e.value)),
share(),
),
spaceKey: keypress.pipe(
filter(({ key }) => key && key.name === 'space'),
share(),
),
aKey: keypress.pipe(
filter(({ key }) => key && key.name === 'a'),
share(),
),
iKey: keypress.pipe(
filter(({ key }) => key && key.name === 'i'),
share(),
),
};
}