aboutsummaryrefslogtreecommitdiff
path: root/node_modules/jest-watcher/build/lib/Prompt.js
diff options
context:
space:
mode:
authorJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
committerJoel Kronqvist <work.joelkronqvist@pm.me>2022-03-11 20:46:06 +0200
commit080c5819d87b933816d724a83f3bf4f1686770a7 (patch)
tree4a2ccc68b27edf7d4cbc586c932cc7542b655e19 /node_modules/jest-watcher/build/lib/Prompt.js
parent5ac7049a9d30733165cc212dee308163c2a14644 (diff)
parentd003b82235a9329f912522a2f70aa950dfce4998 (diff)
downloadLYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.tar.gz
LYLLRuoka-080c5819d87b933816d724a83f3bf4f1686770a7.zip
Merge branch 'master' of https://github.com/JoelHMikael/FoodJS
Updating remote changes
Diffstat (limited to 'node_modules/jest-watcher/build/lib/Prompt.js')
-rw-r--r--node_modules/jest-watcher/build/lib/Prompt.js158
1 files changed, 158 insertions, 0 deletions
diff --git a/node_modules/jest-watcher/build/lib/Prompt.js b/node_modules/jest-watcher/build/lib/Prompt.js
new file mode 100644
index 0000000..1adf550
--- /dev/null
+++ b/node_modules/jest-watcher/build/lib/Prompt.js
@@ -0,0 +1,158 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', {
+ value: true
+});
+exports.default = void 0;
+
+var _constants = require('../constants');
+
+function _defineProperty(obj, key, value) {
+ if (key in obj) {
+ Object.defineProperty(obj, key, {
+ value: value,
+ enumerable: true,
+ configurable: true,
+ writable: true
+ });
+ } else {
+ obj[key] = value;
+ }
+ return obj;
+}
+
+class Prompt {
+ constructor() {
+ _defineProperty(this, '_entering', void 0);
+
+ _defineProperty(this, '_value', void 0);
+
+ _defineProperty(this, '_onChange', void 0);
+
+ _defineProperty(this, '_onSuccess', void 0);
+
+ _defineProperty(this, '_onCancel', void 0);
+
+ _defineProperty(this, '_offset', void 0);
+
+ _defineProperty(this, '_promptLength', void 0);
+
+ _defineProperty(this, '_selection', void 0);
+
+ _defineProperty(this, '_onResize', () => {
+ this._onChange();
+ });
+
+ // Copied from `enter` to satisfy TS
+ this._entering = true;
+ this._value = '';
+ this._selection = null;
+ this._offset = -1;
+ this._promptLength = 0;
+
+ this._onChange = () => {};
+
+ this._onSuccess = () => {};
+
+ this._onCancel = () => {};
+ }
+
+ enter(onChange, onSuccess, onCancel) {
+ this._entering = true;
+ this._value = '';
+ this._onSuccess = onSuccess;
+ this._onCancel = onCancel;
+ this._selection = null;
+ this._offset = -1;
+ this._promptLength = 0;
+
+ this._onChange = () =>
+ onChange(this._value, {
+ max: 10,
+ offset: this._offset
+ });
+
+ this._onChange();
+
+ process.stdout.on('resize', this._onResize);
+ }
+
+ setPromptLength(length) {
+ this._promptLength = length;
+ }
+
+ setPromptSelection(selected) {
+ this._selection = selected;
+ }
+
+ put(key) {
+ switch (key) {
+ case _constants.KEYS.ENTER:
+ this._entering = false;
+
+ this._onSuccess(this._selection || this._value);
+
+ this.abort();
+ break;
+
+ case _constants.KEYS.ESCAPE:
+ this._entering = false;
+
+ this._onCancel(this._value);
+
+ this.abort();
+ break;
+
+ case _constants.KEYS.ARROW_DOWN:
+ this._offset = Math.min(this._offset + 1, this._promptLength - 1);
+
+ this._onChange();
+
+ break;
+
+ case _constants.KEYS.ARROW_UP:
+ this._offset = Math.max(this._offset - 1, -1);
+
+ this._onChange();
+
+ break;
+
+ case _constants.KEYS.ARROW_LEFT:
+ case _constants.KEYS.ARROW_RIGHT:
+ break;
+
+ case _constants.KEYS.CONTROL_U:
+ this._value = '';
+ this._offset = -1;
+ this._selection = null;
+
+ this._onChange();
+
+ break;
+
+ default:
+ this._value =
+ key === _constants.KEYS.BACKSPACE
+ ? this._value.slice(0, -1)
+ : this._value + key;
+ this._offset = -1;
+ this._selection = null;
+
+ this._onChange();
+
+ break;
+ }
+ }
+
+ abort() {
+ this._entering = false;
+ this._value = '';
+ process.stdout.removeListener('resize', this._onResize);
+ }
+
+ isEntering() {
+ return this._entering;
+ }
+}
+
+exports.default = Prompt;