aboutsummaryrefslogtreecommitdiff
path: root/sandbox/testAppNevena/Front/node_modules/inquirer/lib/utils/events.js
diff options
context:
space:
mode:
authorDanijel Andjelkovic <adanijel99@gmail.com>2022-03-01 21:54:41 +0100
committerDanijel Andjelkovic <adanijel99@gmail.com>2022-03-01 21:54:41 +0100
commit6c8128f9fd5a5d0be115806c35a21b3d683df8d6 (patch)
treef46c2f6b3b9b294ff32bd75c08ccdc9e7a8cc4ef /sandbox/testAppNevena/Front/node_modules/inquirer/lib/utils/events.js
parent2400b84e95913665da6279114168148444b8f9ab (diff)
parent7d3640f824f46490b47bd95f1c5a16644f712068 (diff)
Merge branch 'dev' of http://gitlab.pmf.kg.ac.rs/igrannonica/neuronstellar into logo
Diffstat (limited to 'sandbox/testAppNevena/Front/node_modules/inquirer/lib/utils/events.js')
-rw-r--r--sandbox/testAppNevena/Front/node_modules/inquirer/lib/utils/events.js54
1 files changed, 54 insertions, 0 deletions
diff --git a/sandbox/testAppNevena/Front/node_modules/inquirer/lib/utils/events.js b/sandbox/testAppNevena/Front/node_modules/inquirer/lib/utils/events.js
new file mode 100644
index 00000000..b4b16bb1
--- /dev/null
+++ b/sandbox/testAppNevena/Front/node_modules/inquirer/lib/utils/events.js
@@ -0,0 +1,54 @@
+'use strict';
+const { fromEvent } = require('rxjs');
+const { filter, map, share, takeUntil } = require('rxjs/operators');
+
+function normalizeKeypressEvents(value, key) {
+ return { value, key: key || {} };
+}
+
+module.exports = 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()
+ ),
+ };
+};