spawn-term 3.2.2 → 3.2.3

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.
@@ -17,6 +17,7 @@ var ENTER_ALT_SCREEN = '\x1b[?1049h';
17
17
  var EXIT_ALT_SCREEN = '\x1b[?1049l';
18
18
  var CLEAR_SCREEN = '\x1b[2J';
19
19
  var CURSOR_HOME = '\x1b[H';
20
+ var HIDE_CURSOR = '\x1b[?25l';
20
21
  var _default = /*#__PURE__*/ (0, _react.memo)(function FullscreenOverlay(param) {
21
22
  var title = param.title, lines = param.lines, scrollOffset = param.scrollOffset;
22
23
  var stdout = (0, _ink.useStdout)().stdout;
@@ -28,11 +29,13 @@ var _default = /*#__PURE__*/ (0, _react.memo)(function FullscreenOverlay(param)
28
29
  // Enter alternate screen on mount, exit on unmount
29
30
  (0, _react.useEffect)(function() {
30
31
  if (stdout) {
31
- stdout.write(ENTER_ALT_SCREEN + CLEAR_SCREEN + CURSOR_HOME);
32
+ stdout.write(ENTER_ALT_SCREEN + CLEAR_SCREEN + CURSOR_HOME + HIDE_CURSOR);
32
33
  }
33
34
  return function() {
34
35
  if (stdout) {
35
- stdout.write(EXIT_ALT_SCREEN);
36
+ // Exit alternate screen, then clear main screen and reset cursor
37
+ // This helps ink re-render cleanly to a known position
38
+ stdout.write(EXIT_ALT_SCREEN + CLEAR_SCREEN + CURSOR_HOME + HIDE_CURSOR);
36
39
  }
37
40
  };
38
41
  }, [
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/OpenSource/node/spawn-term/src/components/FullscreenOverlay.tsx"],"sourcesContent":["import { Box, Text, useStdout } from 'ink';\nimport { memo, useEffect } from 'react';\nimport type { Line } from '../types.ts';\n\nconst isMac = process.platform === 'darwin';\n\n// ANSI escape codes for alternate screen buffer\nconst ENTER_ALT_SCREEN = '\\x1b[?1049h';\nconst EXIT_ALT_SCREEN = '\\x1b[?1049l';\nconst CLEAR_SCREEN = '\\x1b[2J';\nconst CURSOR_HOME = '\\x1b[H';\n\ntype Props = {\n title: string;\n lines: Line[];\n scrollOffset: number;\n onExit: () => void;\n};\n\nexport default memo(function FullscreenOverlay({ title, lines, scrollOffset }: Props) {\n const { stdout } = useStdout();\n const terminalHeight = stdout?.rows || 24;\n\n // Reserve lines for header (title + divider) and footer (scroll hint)\n const headerLines = 2;\n const footerLines = 1;\n const maxVisible = Math.max(1, terminalHeight - headerLines - footerLines);\n\n // Enter alternate screen on mount, exit on unmount\n useEffect(() => {\n if (stdout) {\n stdout.write(ENTER_ALT_SCREEN + CLEAR_SCREEN + CURSOR_HOME);\n }\n return () => {\n if (stdout) {\n stdout.write(EXIT_ALT_SCREEN);\n }\n };\n }, [stdout]);\n\n const visibleLines = lines.slice(scrollOffset, scrollOffset + maxVisible);\n const totalLines = lines.length;\n const currentLine = scrollOffset + 1;\n const endLine = Math.min(scrollOffset + maxVisible, totalLines);\n\n return (\n <Box flexDirection=\"column\" height={terminalHeight}>\n {/* Header */}\n <Text bold color=\"cyan\">\n {title}\n </Text>\n <Text dimColor>{'─'.repeat(Math.min(80, stdout?.columns || 80))}</Text>\n\n {/* Content */}\n <Box flexDirection=\"column\" flexGrow={1}>\n {lines.length === 0 ? (\n <Text dimColor>(no output)</Text>\n ) : (\n visibleLines.map((line, i) => (\n // biome-ignore lint/suspicious/noArrayIndexKey: Lines have no unique ID, index is stable for this scrolling view\n <Text key={scrollOffset + i}>{line.text}</Text>\n ))\n )}\n </Box>\n\n {/* Footer */}\n <Text dimColor>\n Lines {currentLine}-{endLine} of {totalLines} | j/k scroll | Tab/⇧Tab page | {isMac ? '⌥↑/↓' : 'g/G'} top/bottom | ↵/q exit\n </Text>\n </Box>\n );\n});\n"],"names":["isMac","process","platform","ENTER_ALT_SCREEN","EXIT_ALT_SCREEN","CLEAR_SCREEN","CURSOR_HOME","memo","FullscreenOverlay","title","lines","scrollOffset","stdout","useStdout","terminalHeight","rows","headerLines","footerLines","maxVisible","Math","max","useEffect","write","visibleLines","slice","totalLines","length","currentLine","endLine","min","Box","flexDirection","height","Text","bold","color","dimColor","repeat","columns","flexGrow","map","line","i","text"],"mappings":";;;;+BAmBA;;;eAAA;;;;mBAnBqC;qBACL;AAGhC,IAAMA,QAAQC,QAAQC,QAAQ,KAAK;AAEnC,gDAAgD;AAChD,IAAMC,mBAAmB;AACzB,IAAMC,kBAAkB;AACxB,IAAMC,eAAe;AACrB,IAAMC,cAAc;IASpB,yBAAeC,IAAAA,WAAI,EAAC,SAASC,kBAAkB,KAAqC;QAAnCC,QAAF,MAAEA,OAAOC,QAAT,MAASA,OAAOC,eAAhB,MAAgBA;IAC7D,IAAM,AAAEC,SAAWC,IAAAA,cAAS,IAApBD;IACR,IAAME,iBAAiBF,CAAAA,mBAAAA,6BAAAA,OAAQG,IAAI,KAAI;IAEvC,sEAAsE;IACtE,IAAMC,cAAc;IACpB,IAAMC,cAAc;IACpB,IAAMC,aAAaC,KAAKC,GAAG,CAAC,GAAGN,iBAAiBE,cAAcC;IAE9D,mDAAmD;IACnDI,IAAAA,gBAAS,EAAC;QACR,IAAIT,QAAQ;YACVA,OAAOU,KAAK,CAACnB,mBAAmBE,eAAeC;QACjD;QACA,OAAO;YACL,IAAIM,QAAQ;gBACVA,OAAOU,KAAK,CAAClB;YACf;QACF;IACF,GAAG;QAACQ;KAAO;IAEX,IAAMW,eAAeb,MAAMc,KAAK,CAACb,cAAcA,eAAeO;IAC9D,IAAMO,aAAaf,MAAMgB,MAAM;IAC/B,IAAMC,cAAchB,eAAe;IACnC,IAAMiB,UAAUT,KAAKU,GAAG,CAAClB,eAAeO,YAAYO;IAEpD,qBACE,sBAACK,QAAG;QAACC,eAAc;QAASC,QAAQlB;;0BAElC,qBAACmB,SAAI;gBAACC,IAAI;gBAACC,OAAM;0BACd1B;;0BAEH,qBAACwB,SAAI;gBAACG,QAAQ;0BAAE,IAAIC,MAAM,CAAClB,KAAKU,GAAG,CAAC,IAAIjB,CAAAA,mBAAAA,6BAAAA,OAAQ0B,OAAO,KAAI;;0BAG3D,qBAACR,QAAG;gBAACC,eAAc;gBAASQ,UAAU;0BACnC7B,MAAMgB,MAAM,KAAK,kBAChB,qBAACO,SAAI;oBAACG,QAAQ;8BAAC;qBAEfb,aAAaiB,GAAG,CAAC,SAACC,MAAMC;2BACtB,iHAAiH;kCACjH,qBAACT,SAAI;kCAAyBQ,KAAKE,IAAI;uBAA5BhC,eAAe+B;;;0BAMhC,sBAACT,SAAI;gBAACG,QAAQ;;oBAAC;oBACNT;oBAAY;oBAAEC;oBAAQ;oBAAKH;oBAAW;oBAAiCzB,QAAQ,SAAS;oBAAM;;;;;AAI7G"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/OpenSource/node/spawn-term/src/components/FullscreenOverlay.tsx"],"sourcesContent":["import { Box, Text, useStdout } from 'ink';\nimport { memo, useEffect } from 'react';\nimport type { Line } from '../types.ts';\n\nconst isMac = process.platform === 'darwin';\n\n// ANSI escape codes for alternate screen buffer\nconst ENTER_ALT_SCREEN = '\\x1b[?1049h';\nconst EXIT_ALT_SCREEN = '\\x1b[?1049l';\nconst CLEAR_SCREEN = '\\x1b[2J';\nconst CURSOR_HOME = '\\x1b[H';\nconst HIDE_CURSOR = '\\x1b[?25l';\n\ntype Props = {\n title: string;\n lines: Line[];\n scrollOffset: number;\n onExit: () => void;\n};\n\nexport default memo(function FullscreenOverlay({ title, lines, scrollOffset }: Props) {\n const { stdout } = useStdout();\n const terminalHeight = stdout?.rows || 24;\n\n // Reserve lines for header (title + divider) and footer (scroll hint)\n const headerLines = 2;\n const footerLines = 1;\n const maxVisible = Math.max(1, terminalHeight - headerLines - footerLines);\n\n // Enter alternate screen on mount, exit on unmount\n useEffect(() => {\n if (stdout) {\n stdout.write(ENTER_ALT_SCREEN + CLEAR_SCREEN + CURSOR_HOME + HIDE_CURSOR);\n }\n return () => {\n if (stdout) {\n // Exit alternate screen, then clear main screen and reset cursor\n // This helps ink re-render cleanly to a known position\n stdout.write(EXIT_ALT_SCREEN + CLEAR_SCREEN + CURSOR_HOME + HIDE_CURSOR);\n }\n };\n }, [stdout]);\n\n const visibleLines = lines.slice(scrollOffset, scrollOffset + maxVisible);\n const totalLines = lines.length;\n const currentLine = scrollOffset + 1;\n const endLine = Math.min(scrollOffset + maxVisible, totalLines);\n\n return (\n <Box flexDirection=\"column\" height={terminalHeight}>\n {/* Header */}\n <Text bold color=\"cyan\">\n {title}\n </Text>\n <Text dimColor>{'─'.repeat(Math.min(80, stdout?.columns || 80))}</Text>\n\n {/* Content */}\n <Box flexDirection=\"column\" flexGrow={1}>\n {lines.length === 0 ? (\n <Text dimColor>(no output)</Text>\n ) : (\n visibleLines.map((line, i) => (\n // biome-ignore lint/suspicious/noArrayIndexKey: Lines have no unique ID, index is stable for this scrolling view\n <Text key={scrollOffset + i}>{line.text}</Text>\n ))\n )}\n </Box>\n\n {/* Footer */}\n <Text dimColor>\n Lines {currentLine}-{endLine} of {totalLines} | j/k scroll | Tab/⇧Tab page | {isMac ? '⌥↑/↓' : 'g/G'} top/bottom | ↵/q exit\n </Text>\n </Box>\n );\n});\n"],"names":["isMac","process","platform","ENTER_ALT_SCREEN","EXIT_ALT_SCREEN","CLEAR_SCREEN","CURSOR_HOME","HIDE_CURSOR","memo","FullscreenOverlay","title","lines","scrollOffset","stdout","useStdout","terminalHeight","rows","headerLines","footerLines","maxVisible","Math","max","useEffect","write","visibleLines","slice","totalLines","length","currentLine","endLine","min","Box","flexDirection","height","Text","bold","color","dimColor","repeat","columns","flexGrow","map","line","i","text"],"mappings":";;;;+BAoBA;;;eAAA;;;;mBApBqC;qBACL;AAGhC,IAAMA,QAAQC,QAAQC,QAAQ,KAAK;AAEnC,gDAAgD;AAChD,IAAMC,mBAAmB;AACzB,IAAMC,kBAAkB;AACxB,IAAMC,eAAe;AACrB,IAAMC,cAAc;AACpB,IAAMC,cAAc;IASpB,yBAAeC,IAAAA,WAAI,EAAC,SAASC,kBAAkB,KAAqC;QAAnCC,QAAF,MAAEA,OAAOC,QAAT,MAASA,OAAOC,eAAhB,MAAgBA;IAC7D,IAAM,AAAEC,SAAWC,IAAAA,cAAS,IAApBD;IACR,IAAME,iBAAiBF,CAAAA,mBAAAA,6BAAAA,OAAQG,IAAI,KAAI;IAEvC,sEAAsE;IACtE,IAAMC,cAAc;IACpB,IAAMC,cAAc;IACpB,IAAMC,aAAaC,KAAKC,GAAG,CAAC,GAAGN,iBAAiBE,cAAcC;IAE9D,mDAAmD;IACnDI,IAAAA,gBAAS,EAAC;QACR,IAAIT,QAAQ;YACVA,OAAOU,KAAK,CAACpB,mBAAmBE,eAAeC,cAAcC;QAC/D;QACA,OAAO;YACL,IAAIM,QAAQ;gBACV,iEAAiE;gBACjE,uDAAuD;gBACvDA,OAAOU,KAAK,CAACnB,kBAAkBC,eAAeC,cAAcC;YAC9D;QACF;IACF,GAAG;QAACM;KAAO;IAEX,IAAMW,eAAeb,MAAMc,KAAK,CAACb,cAAcA,eAAeO;IAC9D,IAAMO,aAAaf,MAAMgB,MAAM;IAC/B,IAAMC,cAAchB,eAAe;IACnC,IAAMiB,UAAUT,KAAKU,GAAG,CAAClB,eAAeO,YAAYO;IAEpD,qBACE,sBAACK,QAAG;QAACC,eAAc;QAASC,QAAQlB;;0BAElC,qBAACmB,SAAI;gBAACC,IAAI;gBAACC,OAAM;0BACd1B;;0BAEH,qBAACwB,SAAI;gBAACG,QAAQ;0BAAE,IAAIC,MAAM,CAAClB,KAAKU,GAAG,CAAC,IAAIjB,CAAAA,mBAAAA,6BAAAA,OAAQ0B,OAAO,KAAI;;0BAG3D,qBAACR,QAAG;gBAACC,eAAc;gBAASQ,UAAU;0BACnC7B,MAAMgB,MAAM,KAAK,kBAChB,qBAACO,SAAI;oBAACG,QAAQ;8BAAC;qBAEfb,aAAaiB,GAAG,CAAC,SAACC,MAAMC;2BACtB,iHAAiH;kCACjH,qBAACT,SAAI;kCAAyBQ,KAAKE,IAAI;uBAA5BhC,eAAe+B;;;0BAMhC,sBAACT,SAAI;gBAACG,QAAQ;;oBAAC;oBACNT;oBAAY;oBAAEC;oBAAQ;oBAAKH;oBAAW;oBAAiC1B,QAAQ,SAAS;oBAAM;;;;;AAI7G"}
@@ -7,6 +7,7 @@ const ENTER_ALT_SCREEN = '\x1b[?1049h';
7
7
  const EXIT_ALT_SCREEN = '\x1b[?1049l';
8
8
  const CLEAR_SCREEN = '\x1b[2J';
9
9
  const CURSOR_HOME = '\x1b[H';
10
+ const HIDE_CURSOR = '\x1b[?25l';
10
11
  export default /*#__PURE__*/ memo(function FullscreenOverlay({ title, lines, scrollOffset }) {
11
12
  const { stdout } = useStdout();
12
13
  const terminalHeight = (stdout === null || stdout === void 0 ? void 0 : stdout.rows) || 24;
@@ -17,11 +18,13 @@ export default /*#__PURE__*/ memo(function FullscreenOverlay({ title, lines, scr
17
18
  // Enter alternate screen on mount, exit on unmount
18
19
  useEffect(()=>{
19
20
  if (stdout) {
20
- stdout.write(ENTER_ALT_SCREEN + CLEAR_SCREEN + CURSOR_HOME);
21
+ stdout.write(ENTER_ALT_SCREEN + CLEAR_SCREEN + CURSOR_HOME + HIDE_CURSOR);
21
22
  }
22
23
  return ()=>{
23
24
  if (stdout) {
24
- stdout.write(EXIT_ALT_SCREEN);
25
+ // Exit alternate screen, then clear main screen and reset cursor
26
+ // This helps ink re-render cleanly to a known position
27
+ stdout.write(EXIT_ALT_SCREEN + CLEAR_SCREEN + CURSOR_HOME + HIDE_CURSOR);
25
28
  }
26
29
  };
27
30
  }, [
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/OpenSource/node/spawn-term/src/components/FullscreenOverlay.tsx"],"sourcesContent":["import { Box, Text, useStdout } from 'ink';\nimport { memo, useEffect } from 'react';\nimport type { Line } from '../types.ts';\n\nconst isMac = process.platform === 'darwin';\n\n// ANSI escape codes for alternate screen buffer\nconst ENTER_ALT_SCREEN = '\\x1b[?1049h';\nconst EXIT_ALT_SCREEN = '\\x1b[?1049l';\nconst CLEAR_SCREEN = '\\x1b[2J';\nconst CURSOR_HOME = '\\x1b[H';\n\ntype Props = {\n title: string;\n lines: Line[];\n scrollOffset: number;\n onExit: () => void;\n};\n\nexport default memo(function FullscreenOverlay({ title, lines, scrollOffset }: Props) {\n const { stdout } = useStdout();\n const terminalHeight = stdout?.rows || 24;\n\n // Reserve lines for header (title + divider) and footer (scroll hint)\n const headerLines = 2;\n const footerLines = 1;\n const maxVisible = Math.max(1, terminalHeight - headerLines - footerLines);\n\n // Enter alternate screen on mount, exit on unmount\n useEffect(() => {\n if (stdout) {\n stdout.write(ENTER_ALT_SCREEN + CLEAR_SCREEN + CURSOR_HOME);\n }\n return () => {\n if (stdout) {\n stdout.write(EXIT_ALT_SCREEN);\n }\n };\n }, [stdout]);\n\n const visibleLines = lines.slice(scrollOffset, scrollOffset + maxVisible);\n const totalLines = lines.length;\n const currentLine = scrollOffset + 1;\n const endLine = Math.min(scrollOffset + maxVisible, totalLines);\n\n return (\n <Box flexDirection=\"column\" height={terminalHeight}>\n {/* Header */}\n <Text bold color=\"cyan\">\n {title}\n </Text>\n <Text dimColor>{'─'.repeat(Math.min(80, stdout?.columns || 80))}</Text>\n\n {/* Content */}\n <Box flexDirection=\"column\" flexGrow={1}>\n {lines.length === 0 ? (\n <Text dimColor>(no output)</Text>\n ) : (\n visibleLines.map((line, i) => (\n // biome-ignore lint/suspicious/noArrayIndexKey: Lines have no unique ID, index is stable for this scrolling view\n <Text key={scrollOffset + i}>{line.text}</Text>\n ))\n )}\n </Box>\n\n {/* Footer */}\n <Text dimColor>\n Lines {currentLine}-{endLine} of {totalLines} | j/k scroll | Tab/⇧Tab page | {isMac ? '⌥↑/↓' : 'g/G'} top/bottom | ↵/q exit\n </Text>\n </Box>\n );\n});\n"],"names":["Box","Text","useStdout","memo","useEffect","isMac","process","platform","ENTER_ALT_SCREEN","EXIT_ALT_SCREEN","CLEAR_SCREEN","CURSOR_HOME","FullscreenOverlay","title","lines","scrollOffset","stdout","terminalHeight","rows","headerLines","footerLines","maxVisible","Math","max","write","visibleLines","slice","totalLines","length","currentLine","endLine","min","flexDirection","height","bold","color","dimColor","repeat","columns","flexGrow","map","line","i","text"],"mappings":";AAAA,SAASA,GAAG,EAAEC,IAAI,EAAEC,SAAS,QAAQ,MAAM;AAC3C,SAASC,IAAI,EAAEC,SAAS,QAAQ,QAAQ;AAGxC,MAAMC,QAAQC,QAAQC,QAAQ,KAAK;AAEnC,gDAAgD;AAChD,MAAMC,mBAAmB;AACzB,MAAMC,kBAAkB;AACxB,MAAMC,eAAe;AACrB,MAAMC,cAAc;AASpB,6BAAeR,KAAK,SAASS,kBAAkB,EAAEC,KAAK,EAAEC,KAAK,EAAEC,YAAY,EAAS;IAClF,MAAM,EAAEC,MAAM,EAAE,GAAGd;IACnB,MAAMe,iBAAiBD,CAAAA,mBAAAA,6BAAAA,OAAQE,IAAI,KAAI;IAEvC,sEAAsE;IACtE,MAAMC,cAAc;IACpB,MAAMC,cAAc;IACpB,MAAMC,aAAaC,KAAKC,GAAG,CAAC,GAAGN,iBAAiBE,cAAcC;IAE9D,mDAAmD;IACnDhB,UAAU;QACR,IAAIY,QAAQ;YACVA,OAAOQ,KAAK,CAAChB,mBAAmBE,eAAeC;QACjD;QACA,OAAO;YACL,IAAIK,QAAQ;gBACVA,OAAOQ,KAAK,CAACf;YACf;QACF;IACF,GAAG;QAACO;KAAO;IAEX,MAAMS,eAAeX,MAAMY,KAAK,CAACX,cAAcA,eAAeM;IAC9D,MAAMM,aAAab,MAAMc,MAAM;IAC/B,MAAMC,cAAcd,eAAe;IACnC,MAAMe,UAAUR,KAAKS,GAAG,CAAChB,eAAeM,YAAYM;IAEpD,qBACE,MAAC3B;QAAIgC,eAAc;QAASC,QAAQhB;;0BAElC,KAAChB;gBAAKiC,IAAI;gBAACC,OAAM;0BACdtB;;0BAEH,KAACZ;gBAAKmC,QAAQ;0BAAE,IAAIC,MAAM,CAACf,KAAKS,GAAG,CAAC,IAAIf,CAAAA,mBAAAA,6BAAAA,OAAQsB,OAAO,KAAI;;0BAG3D,KAACtC;gBAAIgC,eAAc;gBAASO,UAAU;0BACnCzB,MAAMc,MAAM,KAAK,kBAChB,KAAC3B;oBAAKmC,QAAQ;8BAAC;qBAEfX,aAAae,GAAG,CAAC,CAACC,MAAMC,IACtB,iHAAiH;kCACjH,KAACzC;kCAA6BwC,KAAKE,IAAI;uBAA5B5B,eAAe2B;;0BAMhC,MAACzC;gBAAKmC,QAAQ;;oBAAC;oBACNP;oBAAY;oBAAEC;oBAAQ;oBAAKH;oBAAW;oBAAiCtB,QAAQ,SAAS;oBAAM;;;;;AAI7G,GAAG"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/OpenSource/node/spawn-term/src/components/FullscreenOverlay.tsx"],"sourcesContent":["import { Box, Text, useStdout } from 'ink';\nimport { memo, useEffect } from 'react';\nimport type { Line } from '../types.ts';\n\nconst isMac = process.platform === 'darwin';\n\n// ANSI escape codes for alternate screen buffer\nconst ENTER_ALT_SCREEN = '\\x1b[?1049h';\nconst EXIT_ALT_SCREEN = '\\x1b[?1049l';\nconst CLEAR_SCREEN = '\\x1b[2J';\nconst CURSOR_HOME = '\\x1b[H';\nconst HIDE_CURSOR = '\\x1b[?25l';\n\ntype Props = {\n title: string;\n lines: Line[];\n scrollOffset: number;\n onExit: () => void;\n};\n\nexport default memo(function FullscreenOverlay({ title, lines, scrollOffset }: Props) {\n const { stdout } = useStdout();\n const terminalHeight = stdout?.rows || 24;\n\n // Reserve lines for header (title + divider) and footer (scroll hint)\n const headerLines = 2;\n const footerLines = 1;\n const maxVisible = Math.max(1, terminalHeight - headerLines - footerLines);\n\n // Enter alternate screen on mount, exit on unmount\n useEffect(() => {\n if (stdout) {\n stdout.write(ENTER_ALT_SCREEN + CLEAR_SCREEN + CURSOR_HOME + HIDE_CURSOR);\n }\n return () => {\n if (stdout) {\n // Exit alternate screen, then clear main screen and reset cursor\n // This helps ink re-render cleanly to a known position\n stdout.write(EXIT_ALT_SCREEN + CLEAR_SCREEN + CURSOR_HOME + HIDE_CURSOR);\n }\n };\n }, [stdout]);\n\n const visibleLines = lines.slice(scrollOffset, scrollOffset + maxVisible);\n const totalLines = lines.length;\n const currentLine = scrollOffset + 1;\n const endLine = Math.min(scrollOffset + maxVisible, totalLines);\n\n return (\n <Box flexDirection=\"column\" height={terminalHeight}>\n {/* Header */}\n <Text bold color=\"cyan\">\n {title}\n </Text>\n <Text dimColor>{'─'.repeat(Math.min(80, stdout?.columns || 80))}</Text>\n\n {/* Content */}\n <Box flexDirection=\"column\" flexGrow={1}>\n {lines.length === 0 ? (\n <Text dimColor>(no output)</Text>\n ) : (\n visibleLines.map((line, i) => (\n // biome-ignore lint/suspicious/noArrayIndexKey: Lines have no unique ID, index is stable for this scrolling view\n <Text key={scrollOffset + i}>{line.text}</Text>\n ))\n )}\n </Box>\n\n {/* Footer */}\n <Text dimColor>\n Lines {currentLine}-{endLine} of {totalLines} | j/k scroll | Tab/⇧Tab page | {isMac ? '⌥↑/↓' : 'g/G'} top/bottom | ↵/q exit\n </Text>\n </Box>\n );\n});\n"],"names":["Box","Text","useStdout","memo","useEffect","isMac","process","platform","ENTER_ALT_SCREEN","EXIT_ALT_SCREEN","CLEAR_SCREEN","CURSOR_HOME","HIDE_CURSOR","FullscreenOverlay","title","lines","scrollOffset","stdout","terminalHeight","rows","headerLines","footerLines","maxVisible","Math","max","write","visibleLines","slice","totalLines","length","currentLine","endLine","min","flexDirection","height","bold","color","dimColor","repeat","columns","flexGrow","map","line","i","text"],"mappings":";AAAA,SAASA,GAAG,EAAEC,IAAI,EAAEC,SAAS,QAAQ,MAAM;AAC3C,SAASC,IAAI,EAAEC,SAAS,QAAQ,QAAQ;AAGxC,MAAMC,QAAQC,QAAQC,QAAQ,KAAK;AAEnC,gDAAgD;AAChD,MAAMC,mBAAmB;AACzB,MAAMC,kBAAkB;AACxB,MAAMC,eAAe;AACrB,MAAMC,cAAc;AACpB,MAAMC,cAAc;AASpB,6BAAeT,KAAK,SAASU,kBAAkB,EAAEC,KAAK,EAAEC,KAAK,EAAEC,YAAY,EAAS;IAClF,MAAM,EAAEC,MAAM,EAAE,GAAGf;IACnB,MAAMgB,iBAAiBD,CAAAA,mBAAAA,6BAAAA,OAAQE,IAAI,KAAI;IAEvC,sEAAsE;IACtE,MAAMC,cAAc;IACpB,MAAMC,cAAc;IACpB,MAAMC,aAAaC,KAAKC,GAAG,CAAC,GAAGN,iBAAiBE,cAAcC;IAE9D,mDAAmD;IACnDjB,UAAU;QACR,IAAIa,QAAQ;YACVA,OAAOQ,KAAK,CAACjB,mBAAmBE,eAAeC,cAAcC;QAC/D;QACA,OAAO;YACL,IAAIK,QAAQ;gBACV,iEAAiE;gBACjE,uDAAuD;gBACvDA,OAAOQ,KAAK,CAAChB,kBAAkBC,eAAeC,cAAcC;YAC9D;QACF;IACF,GAAG;QAACK;KAAO;IAEX,MAAMS,eAAeX,MAAMY,KAAK,CAACX,cAAcA,eAAeM;IAC9D,MAAMM,aAAab,MAAMc,MAAM;IAC/B,MAAMC,cAAcd,eAAe;IACnC,MAAMe,UAAUR,KAAKS,GAAG,CAAChB,eAAeM,YAAYM;IAEpD,qBACE,MAAC5B;QAAIiC,eAAc;QAASC,QAAQhB;;0BAElC,KAACjB;gBAAKkC,IAAI;gBAACC,OAAM;0BACdtB;;0BAEH,KAACb;gBAAKoC,QAAQ;0BAAE,IAAIC,MAAM,CAACf,KAAKS,GAAG,CAAC,IAAIf,CAAAA,mBAAAA,6BAAAA,OAAQsB,OAAO,KAAI;;0BAG3D,KAACvC;gBAAIiC,eAAc;gBAASO,UAAU;0BACnCzB,MAAMc,MAAM,KAAK,kBAChB,KAAC5B;oBAAKoC,QAAQ;8BAAC;qBAEfX,aAAae,GAAG,CAAC,CAACC,MAAMC,IACtB,iHAAiH;kCACjH,KAAC1C;kCAA6ByC,KAAKE,IAAI;uBAA5B5B,eAAe2B;;0BAMhC,MAAC1C;gBAAKoC,QAAQ;;oBAAC;oBACNP;oBAAY;oBAAEC;oBAAQ;oBAAKH;oBAAW;oBAAiCvB,QAAQ,SAAS;oBAAM;;;;;AAI7G,GAAG"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "spawn-term",
3
- "version": "3.2.2",
3
+ "version": "3.2.3",
4
4
  "description": "Formats spawn with for terminal grouping",
5
5
  "keywords": [
6
6
  "spawn",