attio 0.0.1-experimental.20240724.2 → 0.0.1-experimental.20240809

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.
Files changed (83) hide show
  1. package/lib/api/add-connection-definition.d.ts +21 -0
  2. package/lib/api/add-connection-definition.d.ts.map +1 -0
  3. package/lib/api/add-connection-definition.js +24 -0
  4. package/lib/api/add-connection-definition.js.map +1 -0
  5. package/lib/api/create-dev-version.d.ts +3 -3
  6. package/lib/api/create-dev-version.d.ts.map +1 -1
  7. package/lib/api/create-dev-version.js +2 -2
  8. package/lib/api/create-dev-version.js.map +1 -1
  9. package/lib/api/remove-connection-definition.d.ts +16 -0
  10. package/lib/api/remove-connection-definition.d.ts.map +1 -0
  11. package/lib/api/remove-connection-definition.js +8 -0
  12. package/lib/api/remove-connection-definition.js.map +1 -0
  13. package/lib/attio.d.ts +1 -1
  14. package/lib/attio.js +1 -1
  15. package/lib/commands/build.js +5 -5
  16. package/lib/commands/build.js.map +1 -1
  17. package/lib/commands/connection/add.d.ts +22 -0
  18. package/lib/commands/connection/add.d.ts.map +1 -0
  19. package/lib/commands/connection/add.js +66 -0
  20. package/lib/commands/connection/add.js.map +1 -0
  21. package/lib/commands/connection/index.d.ts +2 -0
  22. package/lib/commands/connection/index.d.ts.map +1 -0
  23. package/lib/commands/connection/index.js +2 -0
  24. package/lib/commands/connection/index.js.map +1 -0
  25. package/lib/commands/connection/remove.d.ts +16 -0
  26. package/lib/commands/connection/remove.d.ts.map +1 -0
  27. package/lib/commands/connection/remove.js +42 -0
  28. package/lib/commands/connection/remove.js.map +1 -0
  29. package/lib/commands/dev.d.ts.map +1 -1
  30. package/lib/commands/dev.js +65 -76
  31. package/lib/commands/dev.js.map +1 -1
  32. package/lib/components/BuildError.d.ts +1 -9
  33. package/lib/components/BuildError.d.ts.map +1 -1
  34. package/lib/components/BuildError.js +35 -50
  35. package/lib/components/BuildError.js.map +1 -1
  36. package/lib/components/ScrollBox.d.ts +4 -0
  37. package/lib/components/ScrollBox.d.ts.map +1 -0
  38. package/lib/components/ScrollBox.js +88 -0
  39. package/lib/components/ScrollBox.js.map +1 -0
  40. package/lib/components/ScrollBox.store.d.ts +15 -0
  41. package/lib/components/ScrollBox.store.d.ts.map +1 -0
  42. package/lib/components/ScrollBox.store.js +37 -0
  43. package/lib/components/ScrollBox.store.js.map +1 -0
  44. package/lib/components/ScrollBox.util.d.ts +4 -0
  45. package/lib/components/ScrollBox.util.d.ts.map +1 -0
  46. package/lib/components/ScrollBox.util.js +28 -0
  47. package/lib/components/ScrollBox.util.js.map +1 -0
  48. package/lib/components/TypeScriptErrors.d.ts +1 -8
  49. package/lib/components/TypeScriptErrors.d.ts.map +1 -1
  50. package/lib/components/TypeScriptErrors.js +7 -15
  51. package/lib/components/TypeScriptErrors.js.map +1 -1
  52. package/lib/hooks/useFullScreen.d.ts.map +1 -1
  53. package/lib/hooks/useFullScreen.js +13 -7
  54. package/lib/hooks/useFullScreen.js.map +1 -1
  55. package/lib/hooks/useTerminalTitle.d.ts +2 -0
  56. package/lib/hooks/useTerminalTitle.d.ts.map +1 -0
  57. package/lib/hooks/useTerminalTitle.js +12 -0
  58. package/lib/hooks/useTerminalTitle.js.map +1 -0
  59. package/lib/machines/add-connection-machine.d.ts +159 -0
  60. package/lib/machines/add-connection-machine.d.ts.map +1 -0
  61. package/lib/machines/add-connection-machine.js +224 -0
  62. package/lib/machines/add-connection-machine.js.map +1 -0
  63. package/lib/machines/dev-machine.d.ts.map +1 -1
  64. package/lib/machines/dev-machine.js +3 -3
  65. package/lib/machines/dev-machine.js.map +1 -1
  66. package/lib/machines/remove-connection-machine.d.ts +106 -0
  67. package/lib/machines/remove-connection-machine.d.ts.map +1 -0
  68. package/lib/machines/remove-connection-machine.js +161 -0
  69. package/lib/machines/remove-connection-machine.js.map +1 -0
  70. package/lib/schema.d.ts +5 -5
  71. package/lib/schema.d.ts.map +1 -1
  72. package/lib/schema.js +10 -7
  73. package/lib/schema.js.map +1 -1
  74. package/lib/schema.json +32 -31
  75. package/lib/util/app-config.d.ts +11 -0
  76. package/lib/util/app-config.d.ts.map +1 -0
  77. package/lib/util/app-config.js +52 -0
  78. package/lib/util/app-config.js.map +1 -0
  79. package/package.json +3 -1
  80. package/lib/util/load-extension-config.d.ts +0 -3
  81. package/lib/util/load-extension-config.d.ts.map +0 -1
  82. package/lib/util/load-extension-config.js +0 -32
  83. package/lib/util/load-extension-config.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"BuildError.d.ts","sourceRoot":"","sources":["../../src/components/BuildError.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAC,UAAU,EAAC,MAAM,aAAa,CAAA;AAEtC,wBAAgB,KAAK,CAAC,EAClB,OAAO,EACP,KAAK,GACR,EAAE;IACC,OAAO,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAA;IACrC,KAAK,EAAE,OAAO,GAAG,SAAS,CAAA;CAC7B,qBA2CA;AAED,UAAU,eAAe;IACrB,KAAK,EAAE,UAAU,CAAA;CACpB;AACD,wBAAgB,UAAU,CAAC,EAAC,KAAK,EAAE,EAAC,MAAM,EAAE,QAAQ,EAAC,EAAC,EAAE,eAAe,qBA6BtE"}
1
+ {"version":3,"file":"BuildError.d.ts","sourceRoot":"","sources":["../../src/components/BuildError.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAC,UAAU,EAAC,MAAM,aAAa,CAAA;AAgDtC,wBAAgB,iBAAiB,CAAC,EAAC,MAAM,EAAE,QAAQ,EAAC,EAAE,UAAU,uBAS/D"}
@@ -1,56 +1,41 @@
1
1
  import { Box, Text } from "ink";
2
2
  import React from "react";
3
- export function Error({ message, level, }) {
4
- return (React.createElement(Box, { flexDirection: "column" },
5
- React.createElement(Box, null,
6
- React.createElement(Text, { color: level === "error" ? "red" : "yellow" },
7
- level === "error" ? "❌" : "⚠️",
3
+ const Error = React.forwardRef(({ message, level }, ref) => (React.createElement(Box, { flexDirection: "column", ref: ref },
4
+ React.createElement(Box, null,
5
+ React.createElement(Text, { color: level === "error" ? "red" : "yellow" },
6
+ level === "error" ? "" : "⚠️",
7
+ " ",
8
+ React.createElement(Text, { backgroundColor: level === "error" ? "red" : "yellow", color: "white" },
8
9
  " ",
9
- React.createElement(Text, { backgroundColor: level === "error" ? "red" : "yellow", color: "white" },
10
- " ",
11
- level === "error" ? "ERROR" : "WARNING",
12
- " ")),
13
- React.createElement(Text, { bold: true }, message.text)),
14
- React.createElement(Box, { paddingTop: 1, flexDirection: "column" },
15
- React.createElement(Box, { marginLeft: 4 },
10
+ level === "error" ? "ERROR" : "WARNING",
11
+ " ")),
12
+ React.createElement(Text, { bold: true }, message.text)),
13
+ React.createElement(Box, { paddingTop: 1, flexDirection: "column" },
14
+ React.createElement(Box, { marginLeft: 4 },
15
+ React.createElement(Text, null,
16
+ message.location.file,
17
+ ":",
18
+ message.location.line,
19
+ ":",
20
+ message.location.column)),
21
+ React.createElement(Box, { marginLeft: 4, marginTop: 1 },
22
+ React.createElement(Box, { flexDirection: "column", marginRight: 1 },
23
+ React.createElement(Text, null, message.location.line)),
24
+ React.createElement(Box, { flexDirection: "column" },
16
25
  React.createElement(Text, null,
17
- message.location.file,
18
- ":",
19
- message.location.line,
20
- ":",
21
- message.location.column)),
22
- React.createElement(Box, { marginLeft: 4, marginTop: 1 },
23
- React.createElement(Box, { flexDirection: "column", marginRight: 1 },
24
- React.createElement(Text, null, message.location.line)),
25
- React.createElement(Box, { flexDirection: "column" },
26
- React.createElement(Text, null,
27
- "| ",
28
- message.location.lineText.trim()),
29
- React.createElement(Box, null,
30
- React.createElement(Text, null, "|"),
31
- React.createElement(Box, { paddingLeft: message.location.column +
32
- message.location.lineText.trim().length -
33
- message.location.lineText.length +
34
- 1 },
35
- React.createElement(Text, { color: "greenBright" }, "^"))))))));
36
- }
37
- export function BuildError({ error: { errors, warnings } }) {
38
- return (React.createElement(Box, { flexDirection: "column" },
39
- errors.length > 0 && (React.createElement(Box, { flexDirection: "column" },
40
- React.createElement(Text, { color: "red" },
41
- errors.length,
42
- " ERROR",
43
- errors.length === 1 ? "" : "S",
44
- ":"),
45
- errors.map((error, index) => (React.createElement(Box, { key: index, marginY: 1 },
46
- React.createElement(Error, { message: error, level: "error" })))))),
47
- warnings.length > 0 && (React.createElement(Box, { flexDirection: "column" },
48
- React.createElement(Text, { color: "red" },
49
- warnings.length,
50
- " WARNING",
51
- warnings.length === 1 ? "" : "S",
52
- ":"),
53
- warnings.map((warning, index) => (React.createElement(Box, { key: index, marginY: 1 },
54
- React.createElement(Error, { message: warning, level: "warning" }))))))));
26
+ "| ",
27
+ message.location.lineText.trim()),
28
+ React.createElement(Box, null,
29
+ React.createElement(Text, null, "|"),
30
+ React.createElement(Box, { paddingLeft: message.location.column +
31
+ message.location.lineText.trim().length -
32
+ message.location.lineText.length +
33
+ 1 },
34
+ React.createElement(Text, { color: "greenBright" }, "^")))))))));
35
+ export function renderBuildErrors({ errors, warnings }) {
36
+ return [
37
+ ...errors.map((error, index) => (React.createElement(Error, { key: `BuildError-${index}`, message: error, level: "error" }))),
38
+ ...warnings.map((error, index) => (React.createElement(Error, { key: `BuildError-${index}`, message: error, level: "warning" }))),
39
+ ];
55
40
  }
56
41
  //# sourceMappingURL=BuildError.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"BuildError.js","sourceRoot":"","sources":["../../src/components/BuildError.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"BuildError.js","sourceRoot":"","sources":["../../src/components/BuildError.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAC,GAAG,EAAE,IAAI,EAAC,MAAM,KAAK,CAAA;AAC7B,OAAO,KAAK,MAAM,OAAO,CAAA;AAIzB,MAAM,KAAK,GAAG,KAAK,CAAC,UAAU,CAG5B,CAAC,EAAC,OAAO,EAAE,KAAK,EAAC,EAAE,GAAG,EAAE,EAAE,CAAC,CACzB,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,GAAG,EAAE,GAAG;IAChC,oBAAC,GAAG;QACA,oBAAC,IAAI,IAAC,KAAK,EAAE,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ;YAC5C,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI;YAAE,GAAG;YACpC,oBAAC,IAAI,IAAC,eAAe,EAAE,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAC,OAAO;gBACrE,GAAG;gBACH,KAAK,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS;gBAAE,GAAG,CAC1C,CACJ;QACP,oBAAC,IAAI,IAAC,IAAI,UAAE,OAAO,CAAC,IAAI,CAAQ,CAC9B;IACN,oBAAC,GAAG,IAAC,UAAU,EAAE,CAAC,EAAE,aAAa,EAAC,QAAQ;QACtC,oBAAC,GAAG,IAAC,UAAU,EAAE,CAAC;YACd,oBAAC,IAAI;gBACA,OAAO,CAAC,QAAQ,CAAC,IAAI;;gBAAG,OAAO,CAAC,QAAQ,CAAC,IAAI;;gBAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CACrE,CACL;QACN,oBAAC,GAAG,IAAC,UAAU,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC;YAC5B,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,WAAW,EAAE,CAAC;gBACtC,oBAAC,IAAI,QAAE,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAQ,CAClC;YACN,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ;gBACvB,oBAAC,IAAI;;oBAAI,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAQ;gBACjD,oBAAC,GAAG;oBACA,oBAAC,IAAI,YAAS;oBACd,oBAAC,GAAG,IACA,WAAW,EACP,OAAO,CAAC,QAAQ,CAAC,MAAM;4BACvB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,MAAM;4BACvC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM;4BAChC,CAAC;wBAGL,oBAAC,IAAI,IAAC,KAAK,EAAC,aAAa,QAAS,CAChC,CACJ,CACJ,CACJ,CACJ,CACJ,CACT,CAAC,CAAA;AAEF,MAAM,UAAU,iBAAiB,CAAC,EAAC,MAAM,EAAE,QAAQ,EAAa;IAC5D,OAAO;QACH,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CAC5B,oBAAC,KAAK,IAAC,GAAG,EAAE,cAAc,KAAK,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAC,OAAO,GAAG,CACtE,CAAC;QACF,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CAC9B,oBAAC,KAAK,IAAC,GAAG,EAAE,cAAc,KAAK,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAC,SAAS,GAAG,CACxE,CAAC;KACL,CAAA;AACL,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { Box } from "ink";
2
+ import React from "react";
3
+ export declare const ScrollBox: React.MemoExoticComponent<({ padding, ...props }: React.ComponentPropsWithoutRef<typeof Box>) => React.JSX.Element>;
4
+ //# sourceMappingURL=ScrollBox.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollBox.d.ts","sourceRoot":"","sources":["../../src/components/ScrollBox.tsx"],"names":[],"mappings":"AACA,OAAO,EAAC,GAAG,EAAiC,MAAM,KAAK,CAAA;AACvD,OAAO,KAAK,MAAM,OAAO,CAAA;AAezB,eAAO,MAAM,SAAS,oDACI,MAAM,wBAAwB,CAAC,UAAU,CAAC,uBAwGnE,CAAA"}
@@ -0,0 +1,88 @@
1
+ import { useSelector } from "@xstate/react";
2
+ import { Box, Text, measureElement, useInput } from "ink";
3
+ import React from "react";
4
+ import { useFullScreen } from "../hooks/useFullScreen.js";
5
+ import { useScrollBoxStore } from "./ScrollBox.store.js";
6
+ import { calculateChildRange } from "./ScrollBox.util.js";
7
+ const GAP = 1;
8
+ export const ScrollBox = React.memo(({ padding, ...props }) => {
9
+ const { height: screenHeight, width } = useFullScreen();
10
+ const [top, setTop] = React.useState(0);
11
+ const height = Number(screenHeight) - top;
12
+ const availableHeight = height - (props.borderStyle ? 2 : 0) - (padding ?? 0) * 2;
13
+ const children = React.useMemo(() => React.Children.toArray(props.children).filter((element) => Boolean(element) && React.isValidElement(element)), [props.children]);
14
+ const store = useScrollBoxStore(children.length, availableHeight, Number(width ?? ""));
15
+ const boxRef = React.useCallback((element) => setTop(element?.yogaNode?.getComputedTop() ?? 0), []);
16
+ const heights = useSelector(store, (state) => state.context.heights);
17
+ const offset = useSelector(store, (state) => state.context.offset);
18
+ const allMeasured = heights.length === children.length;
19
+ const haveOverflow = allMeasured && heights.reduce((a, b) => a + b, 0) > availableHeight;
20
+ const childRange = calculateChildRange(heights, offset, availableHeight);
21
+ const itemsShown = childRange[1] - childRange[0];
22
+ const hiddenAbove = offset;
23
+ const hiddenBelow = children.length - (offset + itemsShown);
24
+ useInput((input, key) => {
25
+ if (input === "j" || key.downArrow) {
26
+ if (key.meta) {
27
+ store.send({ type: "Page Down" });
28
+ }
29
+ else {
30
+ store.send({ type: "Down" });
31
+ }
32
+ }
33
+ else if (input === "k" || key.upArrow) {
34
+ if (key.meta) {
35
+ store.send({ type: "Page Up" });
36
+ }
37
+ else {
38
+ store.send({ type: "Up" });
39
+ }
40
+ }
41
+ else if (input === " " || (input === "d" && key.ctrl)) {
42
+ store.send({ type: "Page Down" });
43
+ }
44
+ else if (input === "b" || (input === "u" && key.ctrl)) {
45
+ store.send({ type: "Page Up" });
46
+ }
47
+ else if (input === "G") {
48
+ store.send({ type: "Bottom" });
49
+ }
50
+ });
51
+ return (React.createElement(Box, { ...props, height: height, ref: boxRef, flexDirection: "column" },
52
+ haveOverflow && (React.createElement(Box, { flexDirection: "column", alignItems: "center", marginBottom: -1 }, hiddenAbove > 0 ? (React.createElement(Text, null,
53
+ "+ ",
54
+ hiddenAbove,
55
+ " item",
56
+ hiddenAbove === 1 ? "" : "s",
57
+ " ... press \u2191 to scroll",
58
+ " ")) : (React.createElement(Text, null, " ")))),
59
+ React.createElement(Box, { flexDirection: "column", gap: GAP, flexGrow: 1, padding: padding }, allMeasured
60
+ ? children.map((child, index) => index >= childRange[0] && index < childRange[1]
61
+ ? React.cloneElement(child, {
62
+ ref: (element) => {
63
+ const height = element
64
+ ? measureElement(element).height + GAP
65
+ : 0;
66
+ if (!height)
67
+ return;
68
+ store.send({ type: "Item Measured", index, height });
69
+ },
70
+ })
71
+ : null)
72
+ :
73
+ React.cloneElement(children[heights.length], {
74
+ ref: (element) => {
75
+ const height = element ? measureElement(element).height + GAP : 0;
76
+ if (!height)
77
+ return;
78
+ store.send({ type: "Item Measured", index: heights.length, height });
79
+ },
80
+ })),
81
+ haveOverflow && (React.createElement(Box, { flexDirection: "column", alignItems: "center", marginTop: -1 }, hiddenBelow > 0 ? (React.createElement(Text, null,
82
+ "+ ",
83
+ hiddenBelow,
84
+ " item",
85
+ hiddenBelow === 1 ? "" : "s",
86
+ " ... press \u2193 to scroll")) : (React.createElement(Text, null, " "))))));
87
+ });
88
+ //# sourceMappingURL=ScrollBox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollBox.js","sourceRoot":"","sources":["../../src/components/ScrollBox.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ export declare function useScrollBoxStore(numChildren: number, availableHeight: number, width: number): import("@xstate/store").Store<{
2
+ offset: number;
3
+ heights: number[];
4
+ }, import("@xstate/store").ExtractEventsFromPayloadMap<{
5
+ Down: unknown;
6
+ Up: unknown;
7
+ "Page Down": unknown;
8
+ "Page Up": unknown;
9
+ Bottom: unknown;
10
+ "Item Measured": {
11
+ index: number;
12
+ height: number;
13
+ };
14
+ }>>;
15
+ //# sourceMappingURL=ScrollBox.store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollBox.store.d.ts","sourceRoot":"","sources":["../../src/components/ScrollBox.store.ts"],"names":[],"mappings":"AAeA,wBAAgB,iBAAiB,CAAC,WAAW,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM;;;;;;;;;;eAyCzB,MAAM;gBAAU,MAAM;;IAQzF"}
@@ -0,0 +1,37 @@
1
+ import { createStoreWithProducer } from "@xstate/store";
2
+ import { produce } from "immer";
3
+ import React from "react";
4
+ import { calculateChildRange, calculateLastPageOffset, calculatePreviousPageOffset, } from "./ScrollBox.util.js";
5
+ const initial = {
6
+ offset: 0,
7
+ heights: [],
8
+ };
9
+ export function useScrollBoxStore(numChildren, availableHeight, width) {
10
+ return React.useMemo(() => createStoreWithProducer(produce, initial, {
11
+ "Down": (context) => {
12
+ const [, end] = calculateChildRange(context.heights, context.offset, availableHeight);
13
+ if (end < numChildren) {
14
+ context.offset = Math.min(context.offset + 1, numChildren - 1);
15
+ }
16
+ },
17
+ "Up": (context) => {
18
+ context.offset = Math.max(context.offset - 1, 0);
19
+ },
20
+ "Page Down": (context) => {
21
+ const [, end] = calculateChildRange(context.heights, context.offset, availableHeight);
22
+ if (end < numChildren - 1) {
23
+ context.offset = end;
24
+ }
25
+ },
26
+ "Page Up": (context) => {
27
+ context.offset = calculatePreviousPageOffset(context.heights, context.offset, availableHeight);
28
+ },
29
+ "Bottom": (context) => {
30
+ context.offset = calculateLastPageOffset(context.heights, context.offset, availableHeight);
31
+ },
32
+ "Item Measured": (context, { index, height }) => {
33
+ context.heights[index] = height;
34
+ },
35
+ }), [availableHeight, numChildren, width]);
36
+ }
37
+ //# sourceMappingURL=ScrollBox.store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollBox.store.js","sourceRoot":"","sources":["../../src/components/ScrollBox.store.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,uBAAuB,EAAC,MAAM,eAAe,CAAA;AACrD,OAAO,EAAC,OAAO,EAAC,MAAM,OAAO,CAAA;AAC7B,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EACH,mBAAmB,EACnB,uBAAuB,EACvB,2BAA2B,GAC9B,MAAM,qBAAqB,CAAA;AAE5B,MAAM,OAAO,GAAG;IACZ,MAAM,EAAE,CAAC;IACT,OAAO,EAAE,EAAmB;CAC/B,CAAA;AAED,MAAM,UAAU,iBAAiB,CAAC,WAAmB,EAAE,eAAuB,EAAE,KAAa;IACzF,OAAO,KAAK,CAAC,OAAO,CAChB,GAAG,EAAE,CACD,uBAAuB,CAAC,OAAO,EAAE,OAAO,EAAE;QACtC,MAAM,EAAE,CAAC,OAAO,EAAE,EAAE;YAChB,MAAM,CAAC,EAAE,GAAG,CAAC,GAAG,mBAAmB,CAC/B,OAAO,CAAC,OAAO,EACf,OAAO,CAAC,MAAM,EACd,eAAe,CAClB,CAAA;YACD,IAAI,GAAG,GAAG,WAAW,EAAE,CAAC;gBACpB,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,WAAW,GAAG,CAAC,CAAC,CAAA;YAClE,CAAC;QACL,CAAC;QACD,IAAI,EAAE,CAAC,OAAO,EAAE,EAAE;YACd,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC,CAAC,CAAA;QACpD,CAAC;QACD,WAAW,EAAE,CAAC,OAAO,EAAE,EAAE;YACrB,MAAM,CAAC,EAAE,GAAG,CAAC,GAAG,mBAAmB,CAC/B,OAAO,CAAC,OAAO,EACf,OAAO,CAAC,MAAM,EACd,eAAe,CAClB,CAAA;YACD,IAAI,GAAG,GAAG,WAAW,GAAG,CAAC,EAAE,CAAC;gBACxB,OAAO,CAAC,MAAM,GAAG,GAAG,CAAA;YACxB,CAAC;QACL,CAAC;QACD,SAAS,EAAE,CAAC,OAAO,EAAE,EAAE;YACnB,OAAO,CAAC,MAAM,GAAG,2BAA2B,CACxC,OAAO,CAAC,OAAO,EACf,OAAO,CAAC,MAAM,EACd,eAAe,CAClB,CAAA;QACL,CAAC;QACD,QAAQ,EAAE,CAAC,OAAO,EAAE,EAAE;YAClB,OAAO,CAAC,MAAM,GAAG,uBAAuB,CACpC,OAAO,CAAC,OAAO,EACf,OAAO,CAAC,MAAM,EACd,eAAe,CAClB,CAAA;QACL,CAAC;QACD,eAAe,EAAE,CAAC,OAAO,EAAE,EAAC,KAAK,EAAE,MAAM,EAAkC,EAAE,EAAE;YAC3E,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,MAAM,CAAA;QACnC,CAAC;KACJ,CAAC,EAGN,CAAC,eAAe,EAAE,WAAW,EAAE,KAAK,CAAC,CACxC,CAAA;AACL,CAAC"}
@@ -0,0 +1,4 @@
1
+ export declare function calculateChildRange(heights: Array<number>, offset: number, availableHeight: number): [number, number];
2
+ export declare function calculatePreviousPageOffset(heights: Array<number>, offset: number, availableHeight: number): number;
3
+ export declare function calculateLastPageOffset(heights: Array<number>, offset: number, availableHeight: number): number;
4
+ //# sourceMappingURL=ScrollBox.util.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollBox.util.d.ts","sourceRoot":"","sources":["../../src/components/ScrollBox.util.ts"],"names":[],"mappings":"AAIA,wBAAgB,mBAAmB,CAC/B,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,EACtB,MAAM,EAAE,MAAM,EACd,eAAe,EAAE,MAAM,GACxB,CAAC,MAAM,EAAE,MAAM,CAAC,CAQlB;AAMD,wBAAgB,2BAA2B,CACvC,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,EACtB,MAAM,EAAE,MAAM,EACd,eAAe,EAAE,MAAM,GACxB,MAAM,CAQR;AAMD,wBAAgB,uBAAuB,CACnC,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,EACtB,MAAM,EAAE,MAAM,EACd,eAAe,EAAE,MAAM,GACxB,MAAM,CAQR"}
@@ -0,0 +1,28 @@
1
+ export function calculateChildRange(heights, offset, availableHeight) {
2
+ let heightUsed = 0;
3
+ for (let index = offset; index < heights.length; index++) {
4
+ heightUsed += heights[index];
5
+ if (heightUsed > availableHeight)
6
+ return [offset, Math.max(index, 1)];
7
+ }
8
+ return [offset, heights.length];
9
+ }
10
+ export function calculatePreviousPageOffset(heights, offset, availableHeight) {
11
+ let heightUsed = 0;
12
+ for (let index = offset - 1; index > 0; index--) {
13
+ heightUsed += heights[index];
14
+ if (heightUsed > availableHeight)
15
+ return index + 1;
16
+ }
17
+ return 0;
18
+ }
19
+ export function calculateLastPageOffset(heights, offset, availableHeight) {
20
+ let heightUsed = 0;
21
+ for (let index = heights.length - 1; index > 0; index--) {
22
+ heightUsed += heights[index];
23
+ if (heightUsed > availableHeight)
24
+ return index + 1;
25
+ }
26
+ return 0;
27
+ }
28
+ //# sourceMappingURL=ScrollBox.util.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScrollBox.util.js","sourceRoot":"","sources":["../../src/components/ScrollBox.util.ts"],"names":[],"mappings":"AAIA,MAAM,UAAU,mBAAmB,CAC/B,OAAsB,EACtB,MAAc,EACd,eAAuB;IAEvB,IAAI,UAAU,GAAG,CAAC,CAAA;IAClB,KAAK,IAAI,KAAK,GAAG,MAAM,EAAE,KAAK,GAAG,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC;QACvD,UAAU,IAAI,OAAO,CAAC,KAAK,CAAC,CAAA;QAC5B,IAAI,UAAU,GAAG,eAAe;YAAE,OAAO,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAA;IACzE,CAAC;IAED,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,MAAM,CAAC,CAAA;AACnC,CAAC;AAMD,MAAM,UAAU,2BAA2B,CACvC,OAAsB,EACtB,MAAc,EACd,eAAuB;IAEvB,IAAI,UAAU,GAAG,CAAC,CAAA;IAClB,KAAK,IAAI,KAAK,GAAG,MAAM,GAAG,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC;QAC9C,UAAU,IAAI,OAAO,CAAC,KAAK,CAAC,CAAA;QAC5B,IAAI,UAAU,GAAG,eAAe;YAAE,OAAO,KAAK,GAAG,CAAC,CAAA;IACtD,CAAC;IAED,OAAO,CAAC,CAAA;AACZ,CAAC;AAMD,MAAM,UAAU,uBAAuB,CACnC,OAAsB,EACtB,MAAc,EACd,eAAuB;IAEvB,IAAI,UAAU,GAAG,CAAC,CAAA;IAClB,KAAK,IAAI,KAAK,GAAG,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC;QACtD,UAAU,IAAI,OAAO,CAAC,KAAK,CAAC,CAAA;QAC5B,IAAI,UAAU,GAAG,eAAe;YAAE,OAAO,KAAK,GAAG,CAAC,CAAA;IACtD,CAAC;IAED,OAAO,CAAC,CAAA;AACZ,CAAC"}
@@ -1,11 +1,4 @@
1
1
  import React from "react";
2
2
  import { type TypeScriptError } from "../util/typescript.js";
3
- export declare function Error({ error }: {
4
- error: TypeScriptError;
5
- }): React.JSX.Element;
6
- interface TypeScriptErrorsProps {
7
- errors: Array<TypeScriptError>;
8
- }
9
- export declare function TypeScriptErrors({ errors }: TypeScriptErrorsProps): React.JSX.Element;
10
- export {};
3
+ export declare function renderTypeScriptErrors(errors: Array<TypeScriptError>): React.JSX.Element[];
11
4
  //# sourceMappingURL=TypeScriptErrors.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"TypeScriptErrors.d.ts","sourceRoot":"","sources":["../../src/components/TypeScriptErrors.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAC,KAAK,eAAe,EAAC,MAAM,uBAAuB,CAAA;AAE1D,wBAAgB,KAAK,CAAC,EAAC,KAAK,EAAC,EAAE;IAAC,KAAK,EAAE,eAAe,CAAA;CAAC,qBA6CtD;AAED,UAAU,qBAAqB;IAC3B,MAAM,EAAE,KAAK,CAAC,eAAe,CAAC,CAAA;CACjC;AACD,wBAAgB,gBAAgB,CAAC,EAAC,MAAM,EAAC,EAAE,qBAAqB,qBAiB/D"}
1
+ {"version":3,"file":"TypeScriptErrors.d.ts","sourceRoot":"","sources":["../../src/components/TypeScriptErrors.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAC,KAAK,eAAe,EAAC,MAAM,uBAAuB,CAAA;AAgD1D,wBAAgB,sBAAsB,CAAC,MAAM,EAAE,KAAK,CAAC,eAAe,CAAC,uBAEpE"}
@@ -1,15 +1,14 @@
1
1
  import { Box, Text } from "ink";
2
2
  import React from "react";
3
- export function Error({ error }) {
4
- return (React.createElement(Box, { flexDirection: "column" },
3
+ const Error = React.forwardRef(({ error }, ref) => {
4
+ return (React.createElement(Box, { flexDirection: "column", ref: ref },
5
5
  React.createElement(Box, null,
6
6
  React.createElement(Text, { color: "red" },
7
- "\u274C",
8
- " ",
9
7
  React.createElement(Text, { backgroundColor: "red", color: "white" },
10
8
  " ",
11
9
  "TYPESCRIPT ERROR",
12
- " ")),
10
+ " "),
11
+ " "),
13
12
  React.createElement(Text, { bold: true }, error.text)),
14
13
  error.location && (React.createElement(Box, { paddingTop: 1, flexDirection: "column" },
15
14
  React.createElement(Box, { marginLeft: 4 },
@@ -33,15 +32,8 @@ export function Error({ error }) {
33
32
  error.location.lineText.length +
34
33
  1 },
35
34
  React.createElement(Text, { color: "greenBright" }, "^")))))))));
36
- }
37
- export function TypeScriptErrors({ errors }) {
38
- return (React.createElement(Box, { flexDirection: "column" }, errors.length > 0 && (React.createElement(Box, { flexDirection: "column" },
39
- React.createElement(Text, { color: "red" },
40
- errors.length,
41
- " ERROR",
42
- errors.length === 1 ? "" : "S",
43
- ":"),
44
- errors.map((error, index) => (React.createElement(Box, { key: index, marginY: 1 },
45
- React.createElement(Error, { error: error }))))))));
35
+ });
36
+ export function renderTypeScriptErrors(errors) {
37
+ return errors.map((error, index) => React.createElement(Error, { key: `TypeScriptError-${index}`, error: error }));
46
38
  }
47
39
  //# sourceMappingURL=TypeScriptErrors.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TypeScriptErrors.js","sourceRoot":"","sources":["../../src/components/TypeScriptErrors.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAC,GAAG,EAAE,IAAI,EAAC,MAAM,KAAK,CAAA;AAC7B,OAAO,KAAK,MAAM,OAAO,CAAA;AAIzB,MAAM,UAAU,KAAK,CAAC,EAAC,KAAK,EAA2B;IACnD,OAAO,CACH,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ;QACvB,oBAAC,GAAG;YACA,oBAAC,IAAI,IAAC,KAAK,EAAC,KAAK;;gBACX,GAAG;gBACL,oBAAC,IAAI,IAAC,eAAe,EAAC,KAAK,EAAC,KAAK,EAAC,OAAO;oBACpC,GAAG;;oBACa,GAAG,CACjB,CACJ;YACP,oBAAC,IAAI,IAAC,IAAI,UAAE,KAAK,CAAC,IAAI,CAAQ,CAC5B;QACL,KAAK,CAAC,QAAQ,IAAI,CACf,oBAAC,GAAG,IAAC,UAAU,EAAE,CAAC,EAAE,aAAa,EAAC,QAAQ;YACtC,oBAAC,GAAG,IAAC,UAAU,EAAE,CAAC;gBACd,oBAAC,IAAI;oBACA,KAAK,CAAC,QAAQ,CAAC,IAAI;;oBAAG,KAAK,CAAC,QAAQ,CAAC,IAAI;;oBAAG,KAAK,CAAC,QAAQ,CAAC,SAAS,CAClE,CACL;YACN,oBAAC,GAAG,IAAC,UAAU,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC;gBAC5B,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,WAAW,EAAE,CAAC;oBACtC,oBAAC,IAAI,QAAE,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAQ,CAChC;gBACN,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ;oBACvB,oBAAC,IAAI;;wBAAI,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAQ;oBAC/C,oBAAC,GAAG;wBACA,oBAAC,IAAI,YAAS;wBACd,oBAAC,GAAG,IACA,WAAW,EACP,KAAK,CAAC,QAAQ,CAAC,SAAS;gCACxB,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,MAAM;gCACrC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM;gCAC9B,CAAC;4BAGL,oBAAC,IAAI,IAAC,KAAK,EAAC,aAAa,QAAS,CAChC,CACJ,CACJ,CACJ,CACJ,CACT,CACC,CACT,CAAA;AACL,CAAC;AAKD,MAAM,UAAU,gBAAgB,CAAC,EAAC,MAAM,EAAwB;IAC5D,OAAO,CACH,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,IACtB,MAAM,CAAC,MAAM,GAAG,CAAC,IAAI,CAClB,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ;QACvB,oBAAC,IAAI,IAAC,KAAK,EAAC,KAAK;YACZ,MAAM,CAAC,MAAM;;YAAQ,MAAM,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG;gBACjD;QACN,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CAC1B,oBAAC,GAAG,IAAC,GAAG,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC;YACvB,oBAAC,KAAK,IAAC,KAAK,EAAE,KAAK,GAAI,CACrB,CACT,CAAC,CACA,CACT,CACC,CACT,CAAA;AACL,CAAC"}
1
+ {"version":3,"file":"TypeScriptErrors.js","sourceRoot":"","sources":["../../src/components/TypeScriptErrors.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAC,GAAG,EAAE,IAAI,EAAC,MAAM,KAAK,CAAA;AAC7B,OAAO,KAAK,MAAM,OAAO,CAAA;AAIzB,MAAM,KAAK,GAAG,KAAK,CAAC,UAAU,CAAgC,CAAC,EAAC,KAAK,EAAC,EAAE,GAAG,EAAE,EAAE;IAC3E,OAAO,CACH,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,GAAG,EAAE,GAAG;QAChC,oBAAC,GAAG;YACA,oBAAC,IAAI,IAAC,KAAK,EAAC,KAAK;gBACb,oBAAC,IAAI,IAAC,eAAe,EAAC,KAAK,EAAC,KAAK,EAAC,OAAO;oBACpC,GAAG;;oBACa,GAAG,CACjB;gBAAC,GAAG,CACR;YACP,oBAAC,IAAI,IAAC,IAAI,UAAE,KAAK,CAAC,IAAI,CAAQ,CAC5B;QACL,KAAK,CAAC,QAAQ,IAAI,CACf,oBAAC,GAAG,IAAC,UAAU,EAAE,CAAC,EAAE,aAAa,EAAC,QAAQ;YACtC,oBAAC,GAAG,IAAC,UAAU,EAAE,CAAC;gBACd,oBAAC,IAAI;oBACA,KAAK,CAAC,QAAQ,CAAC,IAAI;;oBAAG,KAAK,CAAC,QAAQ,CAAC,IAAI;;oBAAG,KAAK,CAAC,QAAQ,CAAC,SAAS,CAClE,CACL;YACN,oBAAC,GAAG,IAAC,UAAU,EAAE,CAAC,EAAE,SAAS,EAAE,CAAC;gBAC5B,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ,EAAC,WAAW,EAAE,CAAC;oBACtC,oBAAC,IAAI,QAAE,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAQ,CAChC;gBACN,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ;oBACvB,oBAAC,IAAI;;wBAAI,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAQ;oBAC/C,oBAAC,GAAG;wBACA,oBAAC,IAAI,YAAS;wBACd,oBAAC,GAAG,IACA,WAAW,EACP,KAAK,CAAC,QAAQ,CAAC,SAAS;gCACxB,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC,MAAM;gCACrC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM;gCAC9B,CAAC;4BAGL,oBAAC,IAAI,IAAC,KAAK,EAAC,aAAa,QAAS,CAChC,CACJ,CACJ,CACJ,CACJ,CACT,CACC,CACT,CAAA;AACL,CAAC,CAAC,CAAA;AAEF,MAAM,UAAU,sBAAsB,CAAC,MAA8B;IACjE,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,oBAAC,KAAK,IAAC,GAAG,EAAE,mBAAmB,KAAK,EAAE,EAAE,KAAK,EAAE,KAAK,GAAI,CAAC,CAAA;AACjG,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"useFullScreen.d.ts","sourceRoot":"","sources":["../../src/hooks/useFullScreen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,KAAK,CAAA;AAG5B,eAAO,MAAM,aAAa,QAAO,KAAK,QAAQ,EAAE,OAAO,GAAG,QAAQ,CAkBjE,CAAA"}
1
+ {"version":3,"file":"useFullScreen.d.ts","sourceRoot":"","sources":["../../src/hooks/useFullScreen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAY,MAAM,KAAK,CAAA;AAGvC,eAAO,MAAM,aAAa,QAAO,KAAK,QAAQ,EAAE,OAAO,GAAG,QAAQ,CAuBjE,CAAA"}
@@ -1,17 +1,23 @@
1
+ import { useStdout } from "ink";
1
2
  import React from "react";
2
3
  export const useFullScreen = () => {
3
- const [columns, setColumns] = React.useState(process.stdout.columns);
4
- const [rows, setRows] = React.useState(process.stdout.rows);
4
+ const { stdout } = useStdout();
5
+ const [columns, setColumns] = React.useState(stdout.columns);
6
+ const [rows, setRows] = React.useState(stdout.rows);
5
7
  React.useEffect(() => {
6
8
  const handleResize = () => {
7
- setColumns(process.stdout.columns);
8
- setRows(process.stdout.rows);
9
+ setColumns(stdout.columns);
10
+ setRows(stdout.rows);
9
11
  };
10
- process.stdout.addListener("resize", handleResize);
12
+ stdout.addListener("resize", handleResize);
13
+ stdout.write("\x1b[?1049h");
14
+ process.on("beforeExit", () => {
15
+ stdout.write("\x1b[?1049l");
16
+ });
11
17
  return () => {
12
- process.stdout.removeListener("resize", handleResize);
18
+ stdout.removeListener("resize", handleResize);
13
19
  };
14
20
  }, []);
15
- return { width: columns, height: rows - 1 };
21
+ return { width: columns, height: rows };
16
22
  };
17
23
  //# sourceMappingURL=useFullScreen.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useFullScreen.js","sourceRoot":"","sources":["../../src/hooks/useFullScreen.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,MAAM,CAAC,MAAM,aAAa,GAAG,GAAuC,EAAE;IAClE,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;IACpE,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;IAC3D,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACjB,MAAM,YAAY,GAAG,GAAG,EAAE;YACtB,UAAU,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;YAClC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;QAChC,CAAC,CAAA;QACD,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;QAElD,OAAO,GAAG,EAAE;YACR,OAAO,CAAC,MAAM,CAAC,cAAc,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;QACzD,CAAC,CAAA;IACL,CAAC,EAAE,EAAE,CAAC,CAAA;IAIN,OAAO,EAAC,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,GAAG,CAAC,EAAC,CAAA;AAC7C,CAAC,CAAA"}
1
+ {"version":3,"file":"useFullScreen.js","sourceRoot":"","sources":["../../src/hooks/useFullScreen.ts"],"names":[],"mappings":"AAAA,OAAO,EAAW,SAAS,EAAC,MAAM,KAAK,CAAA;AACvC,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,MAAM,CAAC,MAAM,aAAa,GAAG,GAAuC,EAAE;IAClE,MAAM,EAAC,MAAM,EAAC,GAAG,SAAS,EAAE,CAAA;IAC5B,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;IAC5D,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;IACnD,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACjB,MAAM,YAAY,GAAG,GAAG,EAAE;YACtB,UAAU,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;YAC1B,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;QACxB,CAAC,CAAA;QACD,MAAM,CAAC,WAAW,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;QAE1C,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;QAC3B,OAAO,CAAC,EAAE,CAAC,YAAY,EAAE,GAAG,EAAE;YAC1B,MAAM,CAAC,KAAK,CAAC,aAAa,CAAC,CAAA;QAC/B,CAAC,CAAC,CAAA;QAEF,OAAO,GAAG,EAAE;YACR,MAAM,CAAC,cAAc,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAA;QACjD,CAAC,CAAA;IAEL,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,EAAC,KAAK,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAC,CAAA;AACzC,CAAC,CAAA"}
@@ -0,0 +1,2 @@
1
+ export declare function useTerminalTitle(title: string): void;
2
+ //# sourceMappingURL=useTerminalTitle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useTerminalTitle.d.ts","sourceRoot":"","sources":["../../src/hooks/useTerminalTitle.ts"],"names":[],"mappings":"AAEA,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAQpD"}
@@ -0,0 +1,12 @@
1
+ import React from "react";
2
+ export function useTerminalTitle(title) {
3
+ React.useEffect(() => {
4
+ if (process.platform === "win32") {
5
+ process.title = title;
6
+ }
7
+ else {
8
+ process.stdout.write(`\x1B]2;${title}\x1B\x5C`);
9
+ }
10
+ }, [title]);
11
+ }
12
+ //# sourceMappingURL=useTerminalTitle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useTerminalTitle.js","sourceRoot":"","sources":["../../src/hooks/useTerminalTitle.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,MAAM,UAAU,gBAAgB,CAAC,KAAa;IAC1C,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACjB,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,EAAE,CAAC;YAC/B,OAAO,CAAC,KAAK,GAAG,KAAK,CAAA;QACzB,CAAC;aAAM,CAAC;YACJ,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,UAAU,KAAK,UAAU,CAAC,CAAA;QACnD,CAAC;IACL,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAA;AACf,CAAC"}