pickem 0.1.0 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +89 -0
- package/README.md +64 -3
- package/checkbox.d.ts +3 -0
- package/checkbox.d.ts.map +1 -0
- package/checkbox.js +77 -0
- package/checkbox.js.map +1 -0
- package/core/ansi.d.ts +16 -0
- package/core/ansi.d.ts.map +1 -0
- package/core/ansi.js +21 -0
- package/core/ansi.js.map +1 -0
- package/core/chrome.d.ts +37 -0
- package/core/chrome.d.ts.map +1 -0
- package/core/chrome.js +51 -0
- package/core/chrome.js.map +1 -0
- package/core/cleanup.d.ts +5 -0
- package/core/cleanup.d.ts.map +1 -0
- package/core/cleanup.js +31 -0
- package/core/cleanup.js.map +1 -0
- package/core/colors.d.ts +24 -0
- package/core/colors.d.ts.map +1 -0
- package/core/colors.js +67 -0
- package/core/colors.js.map +1 -0
- package/core/hooks.d.ts +26 -0
- package/core/hooks.d.ts.map +1 -0
- package/core/hooks.js +80 -0
- package/core/hooks.js.map +1 -0
- package/core/index.d.ts +9 -0
- package/core/index.d.ts.map +1 -0
- package/core/index.js +9 -0
- package/core/index.js.map +1 -0
- package/core/key-reader.d.ts +6 -0
- package/core/key-reader.d.ts.map +1 -0
- package/core/key-reader.js +29 -0
- package/core/key-reader.js.map +1 -0
- package/core/keys.d.ts +17 -0
- package/core/keys.d.ts.map +1 -0
- package/core/keys.js +17 -0
- package/core/keys.js.map +1 -0
- package/core/pagination.d.ts +14 -0
- package/core/pagination.d.ts.map +1 -0
- package/core/pagination.js +36 -0
- package/core/pagination.js.map +1 -0
- package/core/runtime.d.ts +20 -0
- package/core/runtime.d.ts.map +1 -0
- package/core/runtime.js +74 -0
- package/core/runtime.js.map +1 -0
- package/core/screen.d.ts +14 -0
- package/core/screen.d.ts.map +1 -0
- package/core/screen.js +50 -0
- package/core/screen.js.map +1 -0
- package/core/status-glyph.d.ts +10 -0
- package/core/status-glyph.d.ts.map +1 -0
- package/core/status-glyph.js +18 -0
- package/core/status-glyph.js.map +1 -0
- package/core/symbols.d.ts +27 -0
- package/core/symbols.d.ts.map +1 -0
- package/core/symbols.js +41 -0
- package/core/symbols.js.map +1 -0
- package/core/testing.d.ts +15 -0
- package/core/testing.d.ts.map +1 -0
- package/core/testing.js +47 -0
- package/core/testing.js.map +1 -0
- package/core/theme.d.ts +14 -0
- package/core/theme.d.ts.map +1 -0
- package/core/theme.js +10 -0
- package/core/theme.js.map +1 -0
- package/core/width.d.ts +7 -0
- package/core/width.d.ts.map +1 -0
- package/core/width.js +46 -0
- package/core/width.js.map +1 -0
- package/display/format.d.ts +1 -3
- package/display/format.d.ts.map +1 -1
- package/display/format.js +4 -1
- package/display/format.js.map +1 -1
- package/index.d.ts +1 -1
- package/index.d.ts.map +1 -1
- package/internal/track.d.ts +3 -0
- package/internal/track.d.ts.map +1 -0
- package/internal/track.js +8 -0
- package/internal/track.js.map +1 -0
- package/package.json +17 -4
- package/pickem.d.ts +2 -0
- package/pickem.d.ts.map +1 -1
- package/pickem.js +37 -32
- package/pickem.js.map +1 -1
- package/prompts/checkbox.d.ts +14 -0
- package/prompts/checkbox.d.ts.map +1 -0
- package/prompts/checkbox.js +56 -0
- package/prompts/checkbox.js.map +1 -0
- package/prompts/confirm.d.ts +6 -0
- package/prompts/confirm.d.ts.map +1 -0
- package/prompts/confirm.js +32 -0
- package/prompts/confirm.js.map +1 -0
- package/prompts/input.d.ts +7 -0
- package/prompts/input.d.ts.map +1 -0
- package/prompts/input.js +52 -0
- package/prompts/input.js.map +1 -0
- package/prompts/search.d.ts +12 -0
- package/prompts/search.d.ts.map +1 -0
- package/prompts/search.js +67 -0
- package/prompts/search.js.map +1 -0
- package/prompts/searchable-checkbox.d.ts +14 -0
- package/prompts/searchable-checkbox.d.ts.map +1 -0
- package/prompts/searchable-checkbox.js +150 -0
- package/prompts/searchable-checkbox.js.map +1 -0
- package/prompts/select.d.ts +12 -0
- package/prompts/select.d.ts.map +1 -0
- package/prompts/select.js +40 -0
- package/prompts/select.js.map +1 -0
- package/types.d.ts +25 -2
- package/types.d.ts.map +1 -1
- package/wizard.d.ts.map +1 -1
- package/wizard.js +17 -5
- package/wizard.js.map +1 -1
package/core/hooks.js
ADDED
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { AsyncLocalStorage } from 'node:async_hooks';
|
|
2
|
+
const als = new AsyncLocalStorage();
|
|
3
|
+
export function createHookStore(scheduleRender) {
|
|
4
|
+
const store = {
|
|
5
|
+
slots: [],
|
|
6
|
+
cursor: 0,
|
|
7
|
+
scheduleRender,
|
|
8
|
+
keypressHandlers: [],
|
|
9
|
+
effects: [],
|
|
10
|
+
reset() {
|
|
11
|
+
this.cursor = 0;
|
|
12
|
+
this.keypressHandlers = [];
|
|
13
|
+
this.effects = [];
|
|
14
|
+
},
|
|
15
|
+
};
|
|
16
|
+
return store;
|
|
17
|
+
}
|
|
18
|
+
export function withHookStore(store, fn) {
|
|
19
|
+
return als.run(store, fn);
|
|
20
|
+
}
|
|
21
|
+
function current() {
|
|
22
|
+
const s = als.getStore();
|
|
23
|
+
if (!s)
|
|
24
|
+
throw new Error('hook called outside of a picker render');
|
|
25
|
+
return s;
|
|
26
|
+
}
|
|
27
|
+
function nextSlot() {
|
|
28
|
+
const s = current();
|
|
29
|
+
const slot = (s.slots[s.cursor] ??= {});
|
|
30
|
+
s.cursor += 1;
|
|
31
|
+
return slot;
|
|
32
|
+
}
|
|
33
|
+
export function useState(initial) {
|
|
34
|
+
const store = current();
|
|
35
|
+
const slot = nextSlot();
|
|
36
|
+
if (!('value' in slot))
|
|
37
|
+
slot.value = initial;
|
|
38
|
+
const set = (next) => {
|
|
39
|
+
if (slot.value === next)
|
|
40
|
+
return;
|
|
41
|
+
slot.value = next;
|
|
42
|
+
store.scheduleRender();
|
|
43
|
+
};
|
|
44
|
+
return [slot.value, set];
|
|
45
|
+
}
|
|
46
|
+
export function useRef(initial) {
|
|
47
|
+
const slot = nextSlot();
|
|
48
|
+
if (!('value' in slot))
|
|
49
|
+
slot.value = { current: initial };
|
|
50
|
+
return slot.value;
|
|
51
|
+
}
|
|
52
|
+
function depsChanged(a, b) {
|
|
53
|
+
if (!a || a.length !== b.length)
|
|
54
|
+
return true;
|
|
55
|
+
return a.some((v, i) => !Object.is(v, b[i]));
|
|
56
|
+
}
|
|
57
|
+
export function useMemo(factory, deps) {
|
|
58
|
+
const slot = nextSlot();
|
|
59
|
+
if (depsChanged(slot.deps, deps)) {
|
|
60
|
+
slot.value = factory();
|
|
61
|
+
slot.deps = deps;
|
|
62
|
+
}
|
|
63
|
+
return slot.value;
|
|
64
|
+
}
|
|
65
|
+
export function useEffect(effect, deps) {
|
|
66
|
+
const store = current();
|
|
67
|
+
const slot = nextSlot();
|
|
68
|
+
if (depsChanged(slot.deps, deps)) {
|
|
69
|
+
slot.deps = deps;
|
|
70
|
+
store.effects.push(() => {
|
|
71
|
+
slot.cleanup?.();
|
|
72
|
+
const cleanup = effect();
|
|
73
|
+
slot.cleanup = typeof cleanup === 'function' ? cleanup : undefined;
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
export function useKeypress(handler) {
|
|
78
|
+
current().keypressHandlers.push(handler);
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hooks.js","sourceRoot":"","sources":["../../src/core/hooks.ts"],"names":[],"mappings":"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"}
|
package/core/index.d.ts
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export { createPicker, CancelError, type PickerInput, type Status, type View } from './runtime.js';
|
|
2
|
+
export { useState, useRef, useMemo, useEffect, useKeypress } from './hooks.js';
|
|
3
|
+
export { usePagination, type RenderItemArgs } from './pagination.js';
|
|
4
|
+
export { useStatusGlyph } from './status-glyph.js';
|
|
5
|
+
export { makeTheme, type Theme } from './theme.js';
|
|
6
|
+
export * from './keys.js';
|
|
7
|
+
export { displayWidth, truncateToWidth, wrapToWidth, stripAnsi } from './width.js';
|
|
8
|
+
export { renderTest, type TestHandle } from './testing.js';
|
|
9
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,WAAW,EAAE,KAAK,MAAM,EAAE,KAAK,IAAI,EAAE,MAAM,cAAc,CAAA;AAClG,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,YAAY,CAAA;AAC9E,OAAO,EAAE,aAAa,EAAE,KAAK,cAAc,EAAE,MAAM,iBAAiB,CAAA;AACpE,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAClD,OAAO,EAAE,SAAS,EAAE,KAAK,KAAK,EAAE,MAAM,YAAY,CAAA;AAClD,cAAc,WAAW,CAAA;AACzB,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,YAAY,CAAA;AAClF,OAAO,EAAE,UAAU,EAAE,KAAK,UAAU,EAAE,MAAM,cAAc,CAAA"}
|
package/core/index.js
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export { createPicker, CancelError } from './runtime.js';
|
|
2
|
+
export { useState, useRef, useMemo, useEffect, useKeypress } from './hooks.js';
|
|
3
|
+
export { usePagination } from './pagination.js';
|
|
4
|
+
export { useStatusGlyph } from './status-glyph.js';
|
|
5
|
+
export { makeTheme } from './theme.js';
|
|
6
|
+
export * from './keys.js';
|
|
7
|
+
export { displayWidth, truncateToWidth, wrapToWidth, stripAnsi } from './width.js';
|
|
8
|
+
export { renderTest } from './testing.js';
|
|
9
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,WAAW,EAA4C,MAAM,cAAc,CAAA;AAClG,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,WAAW,EAAE,MAAM,YAAY,CAAA;AAC9E,OAAO,EAAE,aAAa,EAAuB,MAAM,iBAAiB,CAAA;AACpE,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAClD,OAAO,EAAE,SAAS,EAAc,MAAM,YAAY,CAAA;AAClD,cAAc,WAAW,CAAA;AACzB,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,YAAY,CAAA;AAClF,OAAO,EAAE,UAAU,EAAmB,MAAM,cAAc,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"key-reader.d.ts","sourceRoot":"","sources":["../../src/core/key-reader.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAG1C,MAAM,WAAW,SAAU,SAAQ,YAAY;IAC7C,KAAK,IAAI,IAAI,CAAA;CACd;AAED,wBAAgB,eAAe,CAAC,KAAK,EAAE,MAAM,CAAC,UAAU,GAAG,SAAS,CAyBnE"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import readline from 'node:readline';
|
|
2
|
+
import { EventEmitter } from 'node:events';
|
|
3
|
+
export function createKeyReader(input) {
|
|
4
|
+
const emitter = new EventEmitter();
|
|
5
|
+
readline.emitKeypressEvents(input);
|
|
6
|
+
const wasRaw = input.isTTY ? input.isRaw : false;
|
|
7
|
+
if (input.isTTY)
|
|
8
|
+
input.setRawMode(true);
|
|
9
|
+
const onKeypress = (str, key) => {
|
|
10
|
+
const event = {
|
|
11
|
+
name: key?.name ?? '',
|
|
12
|
+
sequence: key?.sequence ?? str ?? '',
|
|
13
|
+
ctrl: key?.ctrl ?? false,
|
|
14
|
+
meta: key?.meta ?? false,
|
|
15
|
+
shift: key?.shift ?? false,
|
|
16
|
+
};
|
|
17
|
+
emitter.emit('key', event);
|
|
18
|
+
};
|
|
19
|
+
input.on('keypress', onKeypress);
|
|
20
|
+
if (input.isTTY)
|
|
21
|
+
input.resume();
|
|
22
|
+
emitter.close = () => {
|
|
23
|
+
input.off('keypress', onKeypress);
|
|
24
|
+
if (input.isTTY)
|
|
25
|
+
input.setRawMode(wasRaw);
|
|
26
|
+
};
|
|
27
|
+
return emitter;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=key-reader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"key-reader.js","sourceRoot":"","sources":["../../src/core/key-reader.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,eAAe,CAAA;AACpC,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAO1C,MAAM,UAAU,eAAe,CAAC,KAAwB;IACtD,MAAM,OAAO,GAAG,IAAI,YAAY,EAAe,CAAA;IAC/C,QAAQ,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAA;IAClC,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAA;IAChD,IAAI,KAAK,CAAC,KAAK;QAAE,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAA;IAEvC,MAAM,UAAU,GAAG,CAAC,GAAuB,EAAE,GAA6B,EAAE,EAAE;QAC5E,MAAM,KAAK,GAAa;YACtB,IAAI,EAAE,GAAG,EAAE,IAAI,IAAI,EAAE;YACrB,QAAQ,EAAE,GAAG,EAAE,QAAQ,IAAI,GAAG,IAAI,EAAE;YACpC,IAAI,EAAE,GAAG,EAAE,IAAI,IAAI,KAAK;YACxB,IAAI,EAAE,GAAG,EAAE,IAAI,IAAI,KAAK;YACxB,KAAK,EAAE,GAAG,EAAE,KAAK,IAAI,KAAK;SAC3B,CAAA;QACD,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,KAAK,CAAC,CAAA;IAC5B,CAAC,CAAA;IAED,KAAK,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,CAAC,CAAA;IAChC,IAAI,KAAK,CAAC,KAAK;QAAE,KAAK,CAAC,MAAM,EAAE,CAAA;IAE/B,OAAO,CAAC,KAAK,GAAG,GAAG,EAAE;QACnB,KAAK,CAAC,GAAG,CAAC,UAAU,EAAE,UAAU,CAAC,CAAA;QACjC,IAAI,KAAK,CAAC,KAAK;YAAE,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;IAC3C,CAAC,CAAA;IACD,OAAO,OAAO,CAAA;AAChB,CAAC"}
|
package/core/keys.d.ts
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export interface KeyEvent {
|
|
2
|
+
name: string;
|
|
3
|
+
sequence: string;
|
|
4
|
+
ctrl: boolean;
|
|
5
|
+
meta: boolean;
|
|
6
|
+
shift: boolean;
|
|
7
|
+
}
|
|
8
|
+
export declare const isEnter: (k: KeyEvent) => boolean;
|
|
9
|
+
export declare const isUp: (k: KeyEvent) => boolean;
|
|
10
|
+
export declare const isDown: (k: KeyEvent) => boolean;
|
|
11
|
+
export declare const isSpace: (k: KeyEvent) => boolean;
|
|
12
|
+
export declare const isBackspace: (k: KeyEvent) => boolean;
|
|
13
|
+
export declare const isEscape: (k: KeyEvent) => boolean;
|
|
14
|
+
export declare const isTab: (k: KeyEvent) => boolean;
|
|
15
|
+
export declare const isCtrlC: (k: KeyEvent) => boolean;
|
|
16
|
+
export declare function isPrintable(k: KeyEvent): boolean;
|
|
17
|
+
//# sourceMappingURL=keys.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"keys.d.ts","sourceRoot":"","sources":["../../src/core/keys.ts"],"names":[],"mappings":"AACA,MAAM,WAAW,QAAQ;IACvB,IAAI,EAAE,MAAM,CAAA;IACZ,QAAQ,EAAE,MAAM,CAAA;IAChB,IAAI,EAAE,OAAO,CAAA;IACb,IAAI,EAAE,OAAO,CAAA;IACb,KAAK,EAAE,OAAO,CAAA;CACf;AAED,eAAO,MAAM,OAAO,GAAI,GAAG,QAAQ,YAA8C,CAAA;AACjF,eAAO,MAAM,IAAI,GAAI,GAAG,QAAQ,YAAoE,CAAA;AACpG,eAAO,MAAM,MAAM,GAAI,GAAG,QAAQ,YAAsE,CAAA;AACxG,eAAO,MAAM,OAAO,GAAI,GAAG,QAAQ,YAA6C,CAAA;AAChF,eAAO,MAAM,WAAW,GAAI,GAAG,QAAQ,YAA2B,CAAA;AAClE,eAAO,MAAM,QAAQ,GAAI,GAAG,QAAQ,YAAwB,CAAA;AAC5D,eAAO,MAAM,KAAK,GAAI,GAAG,QAAQ,YAAqB,CAAA;AACtD,eAAO,MAAM,OAAO,GAAI,GAAG,QAAQ,YAA6B,CAAA;AAEhE,wBAAgB,WAAW,CAAC,CAAC,EAAE,QAAQ,GAAG,OAAO,CAKhD"}
|
package/core/keys.js
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export const isEnter = (k) => k.name === 'enter' || k.name === 'return';
|
|
2
|
+
export const isUp = (k) => k.name === 'up' || k.name === 'k' || (k.ctrl && k.name === 'p');
|
|
3
|
+
export const isDown = (k) => k.name === 'down' || k.name === 'j' || (k.ctrl && k.name === 'n');
|
|
4
|
+
export const isSpace = (k) => k.name === 'space' || k.sequence === ' ';
|
|
5
|
+
export const isBackspace = (k) => k.name === 'backspace';
|
|
6
|
+
export const isEscape = (k) => k.name === 'escape';
|
|
7
|
+
export const isTab = (k) => k.name === 'tab';
|
|
8
|
+
export const isCtrlC = (k) => k.ctrl && k.name === 'c';
|
|
9
|
+
export function isPrintable(k) {
|
|
10
|
+
if (k.ctrl || k.meta)
|
|
11
|
+
return false;
|
|
12
|
+
if (!k.sequence || k.sequence.length !== 1)
|
|
13
|
+
return false;
|
|
14
|
+
const code = k.sequence.codePointAt(0) ?? 0;
|
|
15
|
+
return code >= 0x20 && code !== 0x7f; // printable, not DEL
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=keys.js.map
|
package/core/keys.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"keys.js","sourceRoot":"","sources":["../../src/core/keys.ts"],"names":[],"mappings":"AASA,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,CAAW,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,IAAI,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAA;AACjF,MAAM,CAAC,MAAM,IAAI,GAAG,CAAC,CAAW,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,IAAI,CAAC,CAAC,IAAI,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,KAAK,GAAG,CAAC,CAAA;AACpG,MAAM,CAAC,MAAM,MAAM,GAAG,CAAC,CAAW,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,MAAM,IAAI,CAAC,CAAC,IAAI,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,KAAK,GAAG,CAAC,CAAA;AACxG,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,CAAW,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,OAAO,IAAI,CAAC,CAAC,QAAQ,KAAK,GAAG,CAAA;AAChF,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,CAAW,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,WAAW,CAAA;AAClE,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,CAAW,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAA;AAC5D,MAAM,CAAC,MAAM,KAAK,GAAG,CAAC,CAAW,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,KAAK,CAAA;AACtD,MAAM,CAAC,MAAM,OAAO,GAAG,CAAC,CAAW,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,KAAK,GAAG,CAAA;AAEhE,MAAM,UAAU,WAAW,CAAC,CAAW;IACrC,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI;QAAE,OAAO,KAAK,CAAA;IAClC,IAAI,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,KAAK,CAAA;IACxD,MAAM,IAAI,GAAG,CAAC,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;IAC3C,OAAO,IAAI,IAAI,IAAI,IAAI,IAAI,KAAK,IAAI,CAAA,CAAC,qBAAqB;AAC5D,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export interface RenderItemArgs<T> {
|
|
2
|
+
item: T;
|
|
3
|
+
index: number;
|
|
4
|
+
isActive: boolean;
|
|
5
|
+
}
|
|
6
|
+
export interface PaginationArgs<T> {
|
|
7
|
+
items: readonly T[];
|
|
8
|
+
active: number;
|
|
9
|
+
pageSize: number;
|
|
10
|
+
loop?: boolean;
|
|
11
|
+
renderItem: (args: RenderItemArgs<T>) => string;
|
|
12
|
+
}
|
|
13
|
+
export declare function usePagination<T>({ items, active, pageSize, loop, renderItem, }: PaginationArgs<T>): string;
|
|
14
|
+
//# sourceMappingURL=pagination.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pagination.d.ts","sourceRoot":"","sources":["../../src/core/pagination.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,cAAc,CAAC,CAAC;IAC/B,IAAI,EAAE,CAAC,CAAA;IACP,KAAK,EAAE,MAAM,CAAA;IACb,QAAQ,EAAE,OAAO,CAAA;CAClB;AAED,MAAM,WAAW,cAAc,CAAC,CAAC;IAC/B,KAAK,EAAE,SAAS,CAAC,EAAE,CAAA;IACnB,MAAM,EAAE,MAAM,CAAA;IACd,QAAQ,EAAE,MAAM,CAAA;IAChB,IAAI,CAAC,EAAE,OAAO,CAAA;IACd,UAAU,EAAE,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC,KAAK,MAAM,CAAA;CAChD;AAED,wBAAgB,aAAa,CAAC,CAAC,EAAE,EAC/B,KAAK,EACL,MAAM,EACN,QAAQ,EACR,IAAW,EACX,UAAU,GACX,EAAE,cAAc,CAAC,CAAC,CAAC,GAAG,MAAM,CA8B5B"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { useRef } from './hooks.js';
|
|
2
|
+
export function usePagination({ items, active, pageSize, loop = true, renderItem, }) {
|
|
3
|
+
const pointer = useRef(0); // active row position within the visible window
|
|
4
|
+
const size = Math.min(pageSize, items.length);
|
|
5
|
+
if (items.length === 0)
|
|
6
|
+
return '';
|
|
7
|
+
// Keep the active row's window position stable, clamping at list edges (non-loop).
|
|
8
|
+
if (size < items.length) {
|
|
9
|
+
if (loop) {
|
|
10
|
+
// Center-ish: move the pointer with the active item, wrapping.
|
|
11
|
+
pointer.current = Math.floor(size / 2);
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
const half = Math.floor(size / 2);
|
|
15
|
+
if (active < half)
|
|
16
|
+
pointer.current = active;
|
|
17
|
+
else if (active >= items.length - half)
|
|
18
|
+
pointer.current = size - (items.length - active);
|
|
19
|
+
else
|
|
20
|
+
pointer.current = half;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
pointer.current = active;
|
|
25
|
+
}
|
|
26
|
+
const top = loop
|
|
27
|
+
? (active - pointer.current + items.length) % items.length
|
|
28
|
+
: Math.max(0, Math.min(active - pointer.current, items.length - size));
|
|
29
|
+
const lines = [];
|
|
30
|
+
for (let i = 0; i < size; i++) {
|
|
31
|
+
const index = loop ? (top + i) % items.length : top + i;
|
|
32
|
+
lines.push(renderItem({ item: items[index], index, isActive: index === active }));
|
|
33
|
+
}
|
|
34
|
+
return lines.join('\n');
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=pagination.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pagination.js","sourceRoot":"","sources":["../../src/core/pagination.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,YAAY,CAAA;AAgBnC,MAAM,UAAU,aAAa,CAAI,EAC/B,KAAK,EACL,MAAM,EACN,QAAQ,EACR,IAAI,GAAG,IAAI,EACX,UAAU,GACQ;IAClB,MAAM,OAAO,GAAG,MAAM,CAAC,CAAC,CAAC,CAAA,CAAC,gDAAgD;IAC1E,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,MAAM,CAAC,CAAA;IAC7C,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,EAAE,CAAA;IAEjC,mFAAmF;IACnF,IAAI,IAAI,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC;QACxB,IAAI,IAAI,EAAE,CAAC;YACT,+DAA+D;YAC/D,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC,CAAA;QACxC,CAAC;aAAM,CAAC;YACN,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,CAAC,CAAC,CAAA;YACjC,IAAI,MAAM,GAAG,IAAI;gBAAE,OAAO,CAAC,OAAO,GAAG,MAAM,CAAA;iBACtC,IAAI,MAAM,IAAI,KAAK,CAAC,MAAM,GAAG,IAAI;gBAAE,OAAO,CAAC,OAAO,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC,CAAA;;gBACnF,OAAO,CAAC,OAAO,GAAG,IAAI,CAAA;QAC7B,CAAC;IACH,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,OAAO,GAAG,MAAM,CAAA;IAC1B,CAAC;IAED,MAAM,GAAG,GAAG,IAAI;QACd,CAAC,CAAC,CAAC,MAAM,GAAG,OAAO,CAAC,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,MAAM;QAC1D,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,OAAO,CAAC,OAAO,EAAE,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC,CAAA;IAExE,MAAM,KAAK,GAAa,EAAE,CAAA;IAC1B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC;QAC9B,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAA;QACvD,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,IAAI,EAAE,KAAK,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,KAAK,KAAK,MAAM,EAAE,CAAC,CAAC,CAAA;IACnF,CAAC;IACD,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;AACzB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
export type Status = 'idle' | 'loading' | 'done' | 'canceled';
|
|
2
|
+
/** The input-buffer controller passed to keypress handlers (pickem's `rl` replacement). */
|
|
3
|
+
export interface PickerInput {
|
|
4
|
+
line: string;
|
|
5
|
+
setLine(value: string): void;
|
|
6
|
+
clearLine(): void;
|
|
7
|
+
}
|
|
8
|
+
export interface PickerContext {
|
|
9
|
+
status: Status;
|
|
10
|
+
}
|
|
11
|
+
export type View<Config, Value> = (config: Config, done: (value: Value) => void) => string | [string, string];
|
|
12
|
+
export interface RunOptions {
|
|
13
|
+
input?: NodeJS.ReadStream;
|
|
14
|
+
output?: NodeJS.WriteStream;
|
|
15
|
+
}
|
|
16
|
+
export declare class CancelError extends Error {
|
|
17
|
+
constructor();
|
|
18
|
+
}
|
|
19
|
+
export declare function createPicker<Config, Value>(view: View<Config, Value>): (config: Config, opts?: RunOptions) => Promise<Value>;
|
|
20
|
+
//# sourceMappingURL=runtime.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime.d.ts","sourceRoot":"","sources":["../../src/core/runtime.ts"],"names":[],"mappings":"AAMA,MAAM,MAAM,MAAM,GAAG,MAAM,GAAG,SAAS,GAAG,MAAM,GAAG,UAAU,CAAA;AAE7D,2FAA2F;AAC3F,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAA;IACZ,OAAO,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;IAC5B,SAAS,IAAI,IAAI,CAAA;CAClB;AAED,MAAM,WAAW,aAAa;IAC5B,MAAM,EAAE,MAAM,CAAA;CACf;AAED,MAAM,MAAM,IAAI,CAAC,MAAM,EAAE,KAAK,IAAI,CAChC,MAAM,EAAE,MAAM,EACd,IAAI,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,KACzB,MAAM,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;AAE9B,MAAM,WAAW,UAAU;IACzB,KAAK,CAAC,EAAE,MAAM,CAAC,UAAU,CAAA;IACzB,MAAM,CAAC,EAAE,MAAM,CAAC,WAAW,CAAA;CAC5B;AAED,qBAAa,WAAY,SAAQ,KAAK;;CAKrC;AAED,wBAAgB,YAAY,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE,KAAK,CAAC,IAC3D,QAAQ,MAAM,EAAE,OAAM,UAAe,KAAG,OAAO,CAAC,KAAK,CAAC,CAgE/D"}
|
package/core/runtime.js
ADDED
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { createKeyReader } from './key-reader.js';
|
|
2
|
+
import { Screen } from './screen.js';
|
|
3
|
+
import { createHookStore, withHookStore } from './hooks.js';
|
|
4
|
+
import { isCtrlC } from './keys.js';
|
|
5
|
+
export class CancelError extends Error {
|
|
6
|
+
constructor() {
|
|
7
|
+
super('Picker canceled');
|
|
8
|
+
this.name = 'CancelError';
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
export function createPicker(view) {
|
|
12
|
+
return (config, opts = {}) => {
|
|
13
|
+
const input = opts.input ?? process.stdin;
|
|
14
|
+
const output = opts.output ?? process.stdout;
|
|
15
|
+
const screen = new Screen(output);
|
|
16
|
+
const reader = createKeyReader(input);
|
|
17
|
+
return new Promise((resolve, reject) => {
|
|
18
|
+
let store;
|
|
19
|
+
let inputBuffer = '';
|
|
20
|
+
let finished = false;
|
|
21
|
+
const pickerInput = {
|
|
22
|
+
get line() {
|
|
23
|
+
return inputBuffer;
|
|
24
|
+
},
|
|
25
|
+
setLine(value) {
|
|
26
|
+
inputBuffer = value;
|
|
27
|
+
},
|
|
28
|
+
clearLine() {
|
|
29
|
+
inputBuffer = '';
|
|
30
|
+
},
|
|
31
|
+
};
|
|
32
|
+
const cleanup = () => {
|
|
33
|
+
reader.close();
|
|
34
|
+
screen.done();
|
|
35
|
+
};
|
|
36
|
+
const done = (value) => {
|
|
37
|
+
if (finished)
|
|
38
|
+
return;
|
|
39
|
+
finished = true;
|
|
40
|
+
render(); // final frame (status 'done')
|
|
41
|
+
cleanup();
|
|
42
|
+
resolve(value);
|
|
43
|
+
};
|
|
44
|
+
const render = () => {
|
|
45
|
+
store.reset();
|
|
46
|
+
const frame = withHookStore(store, () => view(config, done));
|
|
47
|
+
// Flush effects queued during render.
|
|
48
|
+
for (const effect of store.effects)
|
|
49
|
+
effect();
|
|
50
|
+
const [body, bottom] = Array.isArray(frame) ? frame : [frame, ''];
|
|
51
|
+
screen.render(body, bottom);
|
|
52
|
+
};
|
|
53
|
+
store = createHookStore(() => {
|
|
54
|
+
if (!finished)
|
|
55
|
+
render();
|
|
56
|
+
});
|
|
57
|
+
reader.on('key', (key) => {
|
|
58
|
+
if (isCtrlC(key)) {
|
|
59
|
+
finished = true;
|
|
60
|
+
cleanup();
|
|
61
|
+
reject(new CancelError());
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
for (const handler of store.keypressHandlers)
|
|
65
|
+
handler(key, pickerInput);
|
|
66
|
+
if (!finished)
|
|
67
|
+
render();
|
|
68
|
+
});
|
|
69
|
+
screen.start();
|
|
70
|
+
render();
|
|
71
|
+
});
|
|
72
|
+
};
|
|
73
|
+
}
|
|
74
|
+
//# sourceMappingURL=runtime.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtime.js","sourceRoot":"","sources":["../../src/core/runtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AACpC,OAAO,EAAE,eAAe,EAAE,aAAa,EAAkB,MAAM,YAAY,CAAA;AAE3E,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAyBnC,MAAM,OAAO,WAAY,SAAQ,KAAK;IACpC;QACE,KAAK,CAAC,iBAAiB,CAAC,CAAA;QACxB,IAAI,CAAC,IAAI,GAAG,aAAa,CAAA;IAC3B,CAAC;CACF;AAED,MAAM,UAAU,YAAY,CAAgB,IAAyB;IACnE,OAAO,CAAC,MAAc,EAAE,OAAmB,EAAE,EAAkB,EAAE;QAC/D,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,OAAO,CAAC,KAAK,CAAA;QACzC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,OAAO,CAAC,MAAM,CAAA;QAC5C,MAAM,MAAM,GAAG,IAAI,MAAM,CAAC,MAAM,CAAC,CAAA;QACjC,MAAM,MAAM,GAAG,eAAe,CAAC,KAAK,CAAC,CAAA;QAErC,OAAO,IAAI,OAAO,CAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC5C,IAAI,KAAgB,CAAA;YACpB,IAAI,WAAW,GAAG,EAAE,CAAA;YACpB,IAAI,QAAQ,GAAG,KAAK,CAAA;YAEpB,MAAM,WAAW,GAAgB;gBAC/B,IAAI,IAAI;oBACN,OAAO,WAAW,CAAA;gBACpB,CAAC;gBACD,OAAO,CAAC,KAAa;oBACnB,WAAW,GAAG,KAAK,CAAA;gBACrB,CAAC;gBACD,SAAS;oBACP,WAAW,GAAG,EAAE,CAAA;gBAClB,CAAC;aACF,CAAA;YAED,MAAM,OAAO,GAAG,GAAG,EAAE;gBACnB,MAAM,CAAC,KAAK,EAAE,CAAA;gBACd,MAAM,CAAC,IAAI,EAAE,CAAA;YACf,CAAC,CAAA;YAED,MAAM,IAAI,GAAG,CAAC,KAAY,EAAE,EAAE;gBAC5B,IAAI,QAAQ;oBAAE,OAAM;gBACpB,QAAQ,GAAG,IAAI,CAAA;gBACf,MAAM,EAAE,CAAA,CAAC,8BAA8B;gBACvC,OAAO,EAAE,CAAA;gBACT,OAAO,CAAC,KAAK,CAAC,CAAA;YAChB,CAAC,CAAA;YAED,MAAM,MAAM,GAAG,GAAG,EAAE;gBAClB,KAAK,CAAC,KAAK,EAAE,CAAA;gBACb,MAAM,KAAK,GAAG,aAAa,CAAC,KAAK,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,CAAA;gBAC5D,sCAAsC;gBACtC,KAAK,MAAM,MAAM,IAAI,KAAK,CAAC,OAAO;oBAAE,MAAM,EAAE,CAAA;gBAC5C,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,GAAG,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAA;gBACjE,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;YAC7B,CAAC,CAAA;YAED,KAAK,GAAG,eAAe,CAAC,GAAG,EAAE;gBAC3B,IAAI,CAAC,QAAQ;oBAAE,MAAM,EAAE,CAAA;YACzB,CAAC,CAAC,CAAA;YAEF,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC,GAAa,EAAE,EAAE;gBACjC,IAAI,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;oBACjB,QAAQ,GAAG,IAAI,CAAA;oBACf,OAAO,EAAE,CAAA;oBACT,MAAM,CAAC,IAAI,WAAW,EAAE,CAAC,CAAA;oBACzB,OAAM;gBACR,CAAC;gBACD,KAAK,MAAM,OAAO,IAAI,KAAK,CAAC,gBAAgB;oBAAE,OAAO,CAAC,GAAG,EAAE,WAAW,CAAC,CAAA;gBACvE,IAAI,CAAC,QAAQ;oBAAE,MAAM,EAAE,CAAA;YACzB,CAAC,CAAC,CAAA;YAEF,MAAM,CAAC,KAAK,EAAE,CAAA;YACd,MAAM,EAAE,CAAA;QACV,CAAC,CAAC,CAAA;IACJ,CAAC,CAAA;AACH,CAAC"}
|
package/core/screen.d.ts
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export declare class Screen {
|
|
2
|
+
private readonly out;
|
|
3
|
+
private height;
|
|
4
|
+
private offExit;
|
|
5
|
+
private onResize;
|
|
6
|
+
private lastRender;
|
|
7
|
+
constructor(out: NodeJS.WriteStream);
|
|
8
|
+
private get columns();
|
|
9
|
+
start(): void;
|
|
10
|
+
private wrap;
|
|
11
|
+
render(body: string, bottom?: string): void;
|
|
12
|
+
done(): void;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=screen.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"screen.d.ts","sourceRoot":"","sources":["../../src/core/screen.ts"],"names":[],"mappings":"AAIA,qBAAa,MAAM;IAML,OAAO,CAAC,QAAQ,CAAC,GAAG;IALhC,OAAO,CAAC,MAAM,CAAI;IAClB,OAAO,CAAC,OAAO,CAA4B;IAC3C,OAAO,CAAC,QAAQ,CAA+E;IAC/F,OAAO,CAAC,UAAU,CAAgC;gBAErB,GAAG,EAAE,MAAM,CAAC,WAAW;IAEpD,OAAO,KAAK,OAAO,GAElB;IAED,KAAK,IAAI,IAAI;IAMb,OAAO,CAAC,IAAI;IAMZ,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,SAAK,GAAG,IAAI;IAgBvC,IAAI,IAAI,IAAI;CAOb"}
|
package/core/screen.js
ADDED
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { ansi } from './ansi.js';
|
|
2
|
+
import { onExit } from './cleanup.js';
|
|
3
|
+
import { wrapToWidth } from './width.js';
|
|
4
|
+
export class Screen {
|
|
5
|
+
out;
|
|
6
|
+
height = 0;
|
|
7
|
+
offExit = null;
|
|
8
|
+
onResize = () => this.lastRender && this.render(this.lastRender[0], this.lastRender[1]);
|
|
9
|
+
lastRender = null;
|
|
10
|
+
constructor(out) {
|
|
11
|
+
this.out = out;
|
|
12
|
+
}
|
|
13
|
+
get columns() {
|
|
14
|
+
return this.out.columns || 80;
|
|
15
|
+
}
|
|
16
|
+
start() {
|
|
17
|
+
this.out.write(ansi.hideCursor);
|
|
18
|
+
this.offExit = onExit(() => this.out.write(ansi.showCursor));
|
|
19
|
+
this.out.on?.('resize', this.onResize);
|
|
20
|
+
}
|
|
21
|
+
wrap(frame) {
|
|
22
|
+
return frame
|
|
23
|
+
.split('\n')
|
|
24
|
+
.flatMap((line) => (line === '' ? [''] : wrapToWidth(line, this.columns)));
|
|
25
|
+
}
|
|
26
|
+
render(body, bottom = '') {
|
|
27
|
+
this.lastRender = [body, bottom];
|
|
28
|
+
const frame = bottom ? `${body}\n${bottom}` : body;
|
|
29
|
+
const lines = this.wrap(frame);
|
|
30
|
+
let buf = ansi.beginSync;
|
|
31
|
+
if (this.height > 0) {
|
|
32
|
+
buf += ansi.cursorTo(0);
|
|
33
|
+
if (this.height > 1)
|
|
34
|
+
buf += ansi.cursorUp(this.height - 1);
|
|
35
|
+
buf += ansi.eraseDown;
|
|
36
|
+
}
|
|
37
|
+
buf += lines.join('\n');
|
|
38
|
+
buf += ansi.endSync;
|
|
39
|
+
this.out.write(buf);
|
|
40
|
+
this.height = lines.length;
|
|
41
|
+
}
|
|
42
|
+
done() {
|
|
43
|
+
this.out.write(`${ansi.showCursor}\n`);
|
|
44
|
+
this.out.off?.('resize', this.onResize);
|
|
45
|
+
this.offExit?.();
|
|
46
|
+
this.height = 0;
|
|
47
|
+
this.lastRender = null;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=screen.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"screen.js","sourceRoot":"","sources":["../../src/core/screen.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Status } from './runtime.js';
|
|
2
|
+
import type { Colors } from './colors.js';
|
|
3
|
+
import type { Symbols } from './symbols.js';
|
|
4
|
+
export interface StatusGlyphArgs {
|
|
5
|
+
status: Status;
|
|
6
|
+
colors: Colors;
|
|
7
|
+
symbols: Symbols;
|
|
8
|
+
}
|
|
9
|
+
export declare function useStatusGlyph({ status, colors, symbols }: StatusGlyphArgs): string;
|
|
10
|
+
//# sourceMappingURL=status-glyph.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status-glyph.d.ts","sourceRoot":"","sources":["../../src/core/status-glyph.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AAC1C,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAA;AACzC,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAE3C,MAAM,WAAW,eAAe;IAC9B,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,EAAE,MAAM,CAAA;IACd,OAAO,EAAE,OAAO,CAAA;CACjB;AAED,wBAAgB,cAAc,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,eAAe,GAAG,MAAM,CAYnF"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { useState, useEffect } from './hooks.js';
|
|
2
|
+
export function useStatusGlyph({ status, colors, symbols }) {
|
|
3
|
+
const [frame, setFrame] = useState(0);
|
|
4
|
+
useEffect(() => {
|
|
5
|
+
if (status !== 'loading')
|
|
6
|
+
return;
|
|
7
|
+
const id = setInterval(() => setFrame((frame + 1) % symbols.spinnerFrames.length), 80);
|
|
8
|
+
return () => clearInterval(id);
|
|
9
|
+
}, [status]);
|
|
10
|
+
if (status === 'loading')
|
|
11
|
+
return colors.cyan(symbols.spinnerFrames[frame]);
|
|
12
|
+
if (status === 'done')
|
|
13
|
+
return colors.green(symbols.stepDone);
|
|
14
|
+
if (status === 'canceled')
|
|
15
|
+
return colors.red(symbols.stepCancel);
|
|
16
|
+
return colors.cyan(symbols.stepActive);
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=status-glyph.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"status-glyph.js","sourceRoot":"","sources":["../../src/core/status-glyph.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,YAAY,CAAA;AAWhD,MAAM,UAAU,cAAc,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAmB;IACzE,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAA;IACrC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,MAAM,KAAK,SAAS;YAAE,OAAM;QAChC,MAAM,EAAE,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,EAAE,EAAE,CAAC,CAAA;QACtF,OAAO,GAAG,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC,CAAA;IAChC,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAA;IAEZ,IAAI,MAAM,KAAK,SAAS;QAAE,OAAO,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC,CAAA;IAC1E,IAAI,MAAM,KAAK,MAAM;QAAE,OAAO,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;IAC5D,IAAI,MAAM,KAAK,UAAU;QAAE,OAAO,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,UAAU,CAAC,CAAA;IAChE,OAAO,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAA;AACxC,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export declare function isUnicodeSupported(env?: NodeJS.ProcessEnv): boolean;
|
|
2
|
+
export declare function makeSymbols(unicode?: boolean): {
|
|
3
|
+
railBar: string;
|
|
4
|
+
railEnd: string;
|
|
5
|
+
railStart: string;
|
|
6
|
+
stepActive: string;
|
|
7
|
+
stepDone: string;
|
|
8
|
+
stepCancel: string;
|
|
9
|
+
stepError: string;
|
|
10
|
+
radioOn: string;
|
|
11
|
+
radioOff: string;
|
|
12
|
+
checkOn: string;
|
|
13
|
+
checkOff: string;
|
|
14
|
+
pointer: string;
|
|
15
|
+
cornerTL: string;
|
|
16
|
+
cornerTR: string;
|
|
17
|
+
cornerBL: string;
|
|
18
|
+
cornerBR: string;
|
|
19
|
+
line: string;
|
|
20
|
+
boxV: string;
|
|
21
|
+
search: string;
|
|
22
|
+
moreBelow: string;
|
|
23
|
+
moreAbove: string;
|
|
24
|
+
spinnerFrames: string[];
|
|
25
|
+
};
|
|
26
|
+
export type Symbols = ReturnType<typeof makeSymbols>;
|
|
27
|
+
//# sourceMappingURL=symbols.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"symbols.d.ts","sourceRoot":"","sources":["../../src/core/symbols.ts"],"names":[],"mappings":"AAGA,wBAAgB,kBAAkB,CAAC,GAAG,GAAE,MAAM,CAAC,UAAwB,GAAG,OAAO,CAUhF;AAED,wBAAgB,WAAW,CAAC,OAAO,UAAuB;;;;;;;;;;;;;;;;;;;;;;;EA2BzD;AAED,MAAM,MAAM,OAAO,GAAG,UAAU,CAAC,OAAO,WAAW,CAAC,CAAA"}
|
package/core/symbols.js
ADDED
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
// src/core/symbols.ts
|
|
2
|
+
// Conservative Unicode-capability check (Windows legacy consoles excluded).
|
|
3
|
+
export function isUnicodeSupported(env = process.env) {
|
|
4
|
+
if (process.platform !== 'win32')
|
|
5
|
+
return env.TERM !== 'linux';
|
|
6
|
+
return (Boolean(env.WT_SESSION) || // Windows Terminal
|
|
7
|
+
Boolean(env.TERMINUS_SUBLIME) ||
|
|
8
|
+
env.ConEmuTask === '{cmd::Cmder}' ||
|
|
9
|
+
env.TERM_PROGRAM === 'vscode' ||
|
|
10
|
+
env.TERM === 'xterm-256color' ||
|
|
11
|
+
env.TERM === 'alacritty');
|
|
12
|
+
}
|
|
13
|
+
export function makeSymbols(unicode = isUnicodeSupported()) {
|
|
14
|
+
const u = (uni, ascii) => (unicode ? uni : ascii);
|
|
15
|
+
return {
|
|
16
|
+
railBar: u('│', '|'),
|
|
17
|
+
railEnd: u('└', '—'),
|
|
18
|
+
railStart: u('◆', '*'),
|
|
19
|
+
stepActive: u('◆', '*'),
|
|
20
|
+
stepDone: u('◇', 'o'),
|
|
21
|
+
stepCancel: u('■', 'x'),
|
|
22
|
+
stepError: u('▲', '!'),
|
|
23
|
+
radioOn: u('●', '>'),
|
|
24
|
+
radioOff: u('○', ' '),
|
|
25
|
+
checkOn: u('◼', '[x]'),
|
|
26
|
+
checkOff: u('◻', '[ ]'),
|
|
27
|
+
pointer: u('❯', '>'),
|
|
28
|
+
cornerTL: u('╭', '+'),
|
|
29
|
+
cornerTR: u('╮', '+'),
|
|
30
|
+
cornerBL: u('╰', '+'),
|
|
31
|
+
cornerBR: u('╯', '+'),
|
|
32
|
+
line: u('─', '-'),
|
|
33
|
+
boxV: u('│', '|'),
|
|
34
|
+
// selector UI glyphs (docs/standards/selector-ui.md)
|
|
35
|
+
search: u('⌕', '/'),
|
|
36
|
+
moreBelow: u('↓', 'v'),
|
|
37
|
+
moreAbove: u('↑', '^'),
|
|
38
|
+
spinnerFrames: unicode ? ['⠋', '⠙', '⠹', '⠸', '⠼', '⠴', '⠦', '⠧', '⠇', '⠏'] : ['-', '\\', '|', '/'],
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=symbols.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"symbols.js","sourceRoot":"","sources":["../../src/core/symbols.ts"],"names":[],"mappings":"AAAA,sBAAsB;AAEtB,4EAA4E;AAC5E,MAAM,UAAU,kBAAkB,CAAC,MAAyB,OAAO,CAAC,GAAG;IACrE,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO;QAAE,OAAO,GAAG,CAAC,IAAI,KAAK,OAAO,CAAA;IAC7D,OAAO,CACL,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,mBAAmB;QAC9C,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC;QAC7B,GAAG,CAAC,UAAU,KAAK,cAAc;QACjC,GAAG,CAAC,YAAY,KAAK,QAAQ;QAC7B,GAAG,CAAC,IAAI,KAAK,gBAAgB;QAC7B,GAAG,CAAC,IAAI,KAAK,WAAW,CACzB,CAAA;AACH,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,OAAO,GAAG,kBAAkB,EAAE;IACxD,MAAM,CAAC,GAAG,CAAI,GAAM,EAAE,KAAQ,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAA;IAC1D,OAAO;QACL,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACpB,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACpB,SAAS,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACtB,UAAU,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACvB,QAAQ,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACrB,UAAU,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACvB,SAAS,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACtB,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACpB,QAAQ,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACrB,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC;QACtB,QAAQ,EAAE,CAAC,CAAC,GAAG,EAAE,KAAK,CAAC;QACvB,OAAO,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACpB,QAAQ,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACrB,QAAQ,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACrB,QAAQ,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACrB,QAAQ,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACrB,IAAI,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACjB,IAAI,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACjB,qDAAqD;QACrD,MAAM,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACnB,SAAS,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACtB,SAAS,EAAE,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC;QACtB,aAAa,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,CAAC;KACpG,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { KeyEvent } from './keys.js';
|
|
2
|
+
export interface TestEvents {
|
|
3
|
+
keypress(name: string, mods?: Partial<KeyEvent>): void;
|
|
4
|
+
type(text: string): void;
|
|
5
|
+
}
|
|
6
|
+
export interface TestHandle<V> {
|
|
7
|
+
answer: Promise<V>;
|
|
8
|
+
events: TestEvents;
|
|
9
|
+
getScreen(): string;
|
|
10
|
+
}
|
|
11
|
+
export declare function renderTest<Config, V>(picker: (config: Config, opts: {
|
|
12
|
+
input?: any;
|
|
13
|
+
output?: any;
|
|
14
|
+
}) => Promise<V>, config: Config): Promise<TestHandle<V>>;
|
|
15
|
+
//# sourceMappingURL=testing.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"testing.d.ts","sourceRoot":"","sources":["../../src/core/testing.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,WAAW,CAAA;AA+BzC,MAAM,WAAW,UAAU;IACzB,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAA;IACtD,IAAI,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;CACzB;AAED,MAAM,WAAW,UAAU,CAAC,CAAC;IAC3B,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC,CAAA;IAClB,MAAM,EAAE,UAAU,CAAA;IAClB,SAAS,IAAI,MAAM,CAAA;CACpB;AAED,wBAAsB,UAAU,CAAC,MAAM,EAAE,CAAC,EACxC,MAAM,EAAE,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE;IAAE,KAAK,CAAC,EAAE,GAAG,CAAC;IAAC,MAAM,CAAC,EAAE,GAAG,CAAA;CAAE,KAAK,OAAO,CAAC,CAAC,CAAC,EAC3E,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAgBxB"}
|