@hewliyang/headless-spreadjs 0.0.1 → 0.0.2

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 (78) hide show
  1. package/README.md +6 -4
  2. package/dist/cli/a1.d.ts +28 -0
  3. package/dist/cli/a1.d.ts.map +1 -0
  4. package/dist/cli/a1.js +66 -0
  5. package/dist/cli/a1.js.map +1 -0
  6. package/dist/cli/commands/clear.d.ts +2 -0
  7. package/dist/cli/commands/clear.d.ts.map +1 -0
  8. package/dist/cli/commands/clear.js +24 -0
  9. package/dist/cli/commands/clear.js.map +1 -0
  10. package/dist/cli/commands/copy.d.ts +2 -0
  11. package/dist/cli/commands/copy.d.ts.map +1 -0
  12. package/dist/cli/commands/copy.js +51 -0
  13. package/dist/cli/commands/copy.js.map +1 -0
  14. package/dist/cli/commands/create.d.ts +2 -0
  15. package/dist/cli/commands/create.d.ts.map +1 -0
  16. package/dist/cli/commands/create.js +7 -0
  17. package/dist/cli/commands/create.js.map +1 -0
  18. package/dist/cli/commands/csv.d.ts +2 -0
  19. package/dist/cli/commands/csv.d.ts.map +1 -0
  20. package/dist/cli/commands/csv.js +33 -0
  21. package/dist/cli/commands/csv.js.map +1 -0
  22. package/dist/cli/commands/eval.d.ts +2 -0
  23. package/dist/cli/commands/eval.d.ts.map +1 -0
  24. package/dist/cli/commands/eval.js +45 -0
  25. package/dist/cli/commands/eval.js.map +1 -0
  26. package/dist/cli/commands/get.d.ts +4 -0
  27. package/dist/cli/commands/get.d.ts.map +1 -0
  28. package/dist/cli/commands/get.js +55 -0
  29. package/dist/cli/commands/get.js.map +1 -0
  30. package/dist/cli/commands/info.d.ts +2 -0
  31. package/dist/cli/commands/info.d.ts.map +1 -0
  32. package/dist/cli/commands/info.js +34 -0
  33. package/dist/cli/commands/info.js.map +1 -0
  34. package/dist/cli/commands/objects.d.ts +2 -0
  35. package/dist/cli/commands/objects.d.ts.map +1 -0
  36. package/dist/cli/commands/objects.js +71 -0
  37. package/dist/cli/commands/objects.js.map +1 -0
  38. package/dist/cli/commands/resize.d.ts +7 -0
  39. package/dist/cli/commands/resize.d.ts.map +1 -0
  40. package/dist/cli/commands/resize.js +51 -0
  41. package/dist/cli/commands/resize.js.map +1 -0
  42. package/dist/cli/commands/rows-cols.d.ts +8 -0
  43. package/dist/cli/commands/rows-cols.d.ts.map +1 -0
  44. package/dist/cli/commands/rows-cols.js +77 -0
  45. package/dist/cli/commands/rows-cols.js.map +1 -0
  46. package/dist/cli/commands/search.d.ts +7 -0
  47. package/dist/cli/commands/search.d.ts.map +1 -0
  48. package/dist/cli/commands/search.js +67 -0
  49. package/dist/cli/commands/search.js.map +1 -0
  50. package/dist/cli/commands/set.d.ts +2 -0
  51. package/dist/cli/commands/set.d.ts.map +1 -0
  52. package/dist/cli/commands/set.js +67 -0
  53. package/dist/cli/commands/set.js.map +1 -0
  54. package/dist/cli/commands/sheet.d.ts +3 -0
  55. package/dist/cli/commands/sheet.d.ts.map +1 -0
  56. package/dist/cli/commands/sheet.js +62 -0
  57. package/dist/cli/commands/sheet.js.map +1 -0
  58. package/dist/cli/context.d.ts +15 -0
  59. package/dist/cli/context.d.ts.map +1 -0
  60. package/dist/cli/context.js +34 -0
  61. package/dist/cli/context.js.map +1 -0
  62. package/dist/cli/index.d.ts +3 -0
  63. package/dist/cli/index.d.ts.map +1 -0
  64. package/dist/cli/index.js +183 -0
  65. package/dist/cli/index.js.map +1 -0
  66. package/dist/cli/output.d.ts +10 -0
  67. package/dist/cli/output.d.ts.map +1 -0
  68. package/dist/cli/output.js +28 -0
  69. package/dist/cli/output.js.map +1 -0
  70. package/dist/cli/styles.d.ts +27 -0
  71. package/dist/cli/styles.d.ts.map +1 -0
  72. package/dist/cli/styles.js +105 -0
  73. package/dist/cli/styles.js.map +1 -0
  74. package/package.json +20 -10
  75. package/dist/workbook.d.ts +0 -19
  76. package/dist/workbook.d.ts.map +0 -1
  77. package/dist/workbook.js +0 -177
  78. package/dist/workbook.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resize.js","sourceRoot":"","sources":["../../../src/cli/commands/resize.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ export type RcOp = "insert" | "delete" | "hide" | "unhide" | "freeze" | "unfreeze";
2
+ export type RcDim = "rows" | "columns";
3
+ export declare function rowsCols(filePath: string, op: RcOp, dim: RcDim, options: {
4
+ sheet?: string;
5
+ ref?: string;
6
+ count?: number;
7
+ }): Promise<void>;
8
+ //# sourceMappingURL=rows-cols.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rows-cols.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/rows-cols.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,IAAI,GACZ,QAAQ,GACR,QAAQ,GACR,MAAM,GACN,QAAQ,GACR,QAAQ,GACR,UAAU,CAAC;AACf,MAAM,MAAM,KAAK,GAAG,MAAM,GAAG,SAAS,CAAC;AAEvC,wBAAsB,QAAQ,CAC5B,QAAQ,EAAE,MAAM,EAChB,EAAE,EAAE,IAAI,EACR,GAAG,EAAE,KAAK,EACV,OAAO,EAAE;IACP,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,GACA,OAAO,CAAC,IAAI,CAAC,CAgFf"}
@@ -0,0 +1,77 @@
1
+ import { colToIndex } from "../a1.js";
2
+ import { withFile } from "../context.js";
3
+ import { fail, ok } from "../output.js";
4
+ export async function rowsCols(filePath, op, dim, options) {
5
+ await withFile(filePath, ({ workbook }) => {
6
+ const sheet = options.sheet
7
+ ? workbook.getSheetFromName(options.sheet)
8
+ : workbook.getActiveSheet();
9
+ if (!sheet)
10
+ fail(`Sheet not found: ${options.sheet ?? "(active)"}`);
11
+ if (op === "unfreeze") {
12
+ sheet.frozenRowCount(0);
13
+ sheet.frozenColumnCount(0);
14
+ ok({ operation: "unfreeze" });
15
+ return;
16
+ }
17
+ if (op === "freeze") {
18
+ if (!options.ref)
19
+ fail("freeze requires --ref (e.g. --ref 2 for rows or --ref C for columns)");
20
+ if (dim === "rows") {
21
+ sheet.frozenRowCount(parseInt(options.ref, 10));
22
+ }
23
+ else {
24
+ sheet.frozenColumnCount(colToIndex(options.ref) + 1);
25
+ }
26
+ ok({ operation: "freeze", dimension: dim, ref: options.ref });
27
+ return;
28
+ }
29
+ if (!options.ref)
30
+ fail(`${op} requires --ref`);
31
+ const count = options.count ?? 1;
32
+ const isRow = dim === "rows";
33
+ const index = isRow
34
+ ? parseInt(options.ref, 10) - 1
35
+ : colToIndex(options.ref);
36
+ switch (op) {
37
+ case "insert":
38
+ if (isRow) {
39
+ sheet.addRows(index, count);
40
+ }
41
+ else {
42
+ sheet.addColumns(index, count);
43
+ }
44
+ break;
45
+ case "delete":
46
+ if (isRow) {
47
+ sheet.deleteRows(index, count);
48
+ }
49
+ else {
50
+ sheet.deleteColumns(index, count);
51
+ }
52
+ break;
53
+ case "hide":
54
+ for (let i = 0; i < count; i++) {
55
+ if (isRow) {
56
+ sheet.setRowVisible(index + i, false);
57
+ }
58
+ else {
59
+ sheet.setColumnVisible(index + i, false);
60
+ }
61
+ }
62
+ break;
63
+ case "unhide":
64
+ for (let i = 0; i < count; i++) {
65
+ if (isRow) {
66
+ sheet.setRowVisible(index + i, true);
67
+ }
68
+ else {
69
+ sheet.setColumnVisible(index + i, true);
70
+ }
71
+ }
72
+ break;
73
+ }
74
+ ok({ operation: op, dimension: dim, ref: options.ref, count });
75
+ }, { save: true });
76
+ }
77
+ //# sourceMappingURL=rows-cols.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rows-cols.js","sourceRoot":"","sources":["../../../src/cli/commands/rows-cols.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AACtC,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAWxC,MAAM,CAAC,KAAK,UAAU,QAAQ,CAC5B,QAAgB,EAChB,EAAQ,EACR,GAAU,EACV,OAIC;IAED,MAAM,QAAQ,CACZ,QAAQ,EACR,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;QACf,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK;YACzB,CAAC,CAAC,QAAQ,CAAC,gBAAgB,CAAC,OAAO,CAAC,KAAK,CAAC;YAC1C,CAAC,CAAC,QAAQ,CAAC,cAAc,EAAE,CAAC;QAE9B,IAAI,CAAC,KAAK;YAAE,IAAI,CAAC,oBAAoB,OAAO,CAAC,KAAK,IAAI,UAAU,EAAE,CAAC,CAAC;QAEpE,IAAI,EAAE,KAAK,UAAU,EAAE,CAAC;YACtB,KAAK,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;YACxB,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC;YAC3B,EAAE,CAAC,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC,CAAC;YAC9B,OAAO;QACT,CAAC;QAED,IAAI,EAAE,KAAK,QAAQ,EAAE,CAAC;YACpB,IAAI,CAAC,OAAO,CAAC,GAAG;gBACd,IAAI,CACF,sEAAsE,CACvE,CAAC;YACJ,IAAI,GAAG,KAAK,MAAM,EAAE,CAAC;gBACnB,KAAK,CAAC,cAAc,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC;YAClD,CAAC;iBAAM,CAAC;gBACN,KAAK,CAAC,iBAAiB,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;YACvD,CAAC;YACD,EAAE,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE,CAAC,CAAC;YAC9D,OAAO;QACT,CAAC;QAED,IAAI,CAAC,OAAO,CAAC,GAAG;YAAE,IAAI,CAAC,GAAG,EAAE,iBAAiB,CAAC,CAAC;QAC/C,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,CAAC,CAAC;QACjC,MAAM,KAAK,GAAG,GAAG,KAAK,MAAM,CAAC;QAC7B,MAAM,KAAK,GAAG,KAAK;YACjB,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC;YAC/B,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;QAE5B,QAAQ,EAAE,EAAE,CAAC;YACX,KAAK,QAAQ;gBACX,IAAI,KAAK,EAAE,CAAC;oBACV,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;gBAC9B,CAAC;qBAAM,CAAC;oBACN,KAAK,CAAC,UAAU,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;gBACjC,CAAC;gBACD,MAAM;YAER,KAAK,QAAQ;gBACX,IAAI,KAAK,EAAE,CAAC;oBACV,KAAK,CAAC,UAAU,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;gBACjC,CAAC;qBAAM,CAAC;oBACN,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;gBACpC,CAAC;gBACD,MAAM;YAER,KAAK,MAAM;gBACT,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;oBAC/B,IAAI,KAAK,EAAE,CAAC;wBACV,KAAK,CAAC,aAAa,CAAC,KAAK,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC;oBACxC,CAAC;yBAAM,CAAC;wBACN,KAAK,CAAC,gBAAgB,CAAC,KAAK,GAAG,CAAC,EAAE,KAAK,CAAC,CAAC;oBAC3C,CAAC;gBACH,CAAC;gBACD,MAAM;YAER,KAAK,QAAQ;gBACX,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC;oBAC/B,IAAI,KAAK,EAAE,CAAC;wBACV,KAAK,CAAC,aAAa,CAAC,KAAK,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC;oBACvC,CAAC;yBAAM,CAAC;wBACN,KAAK,CAAC,gBAAgB,CAAC,KAAK,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC;oBAC1C,CAAC;gBACH,CAAC;gBACD,MAAM;QACV,CAAC;QAED,EAAE,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE,SAAS,EAAE,GAAG,EAAE,GAAG,EAAE,OAAO,CAAC,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC;IACjE,CAAC,EACD,EAAE,IAAI,EAAE,IAAI,EAAE,CACf,CAAC;AACJ,CAAC"}
@@ -0,0 +1,7 @@
1
+ export declare function search(filePath: string, term: string, options: {
2
+ sheet?: string;
3
+ matchCase?: boolean;
4
+ regex?: boolean;
5
+ maxResults?: number;
6
+ }): Promise<void>;
7
+ //# sourceMappingURL=search.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/search.ts"],"names":[],"mappings":"AAWA,wBAAsB,MAAM,CAC1B,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,MAAM,EACZ,OAAO,EAAE;IACP,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,GACA,OAAO,CAAC,IAAI,CAAC,CAoEf"}
@@ -0,0 +1,67 @@
1
+ import { cellToA1 } from "../a1.js";
2
+ import { withFile } from "../context.js";
3
+ import { ok } from "../output.js";
4
+ export async function search(filePath, term, options) {
5
+ await withFile(filePath, ({ workbook }) => {
6
+ const matches = [];
7
+ const max = options.maxResults ?? 500;
8
+ const pattern = options.regex
9
+ ? new RegExp(term, options.matchCase ? "" : "i")
10
+ : null;
11
+ const sheetCount = workbook.getSheetCount();
12
+ for (let si = 0; si < sheetCount && matches.length < max; si++) {
13
+ const ws = workbook.getSheet(si);
14
+ const sheetName = ws.name();
15
+ if (options.sheet && sheetName !== options.sheet)
16
+ continue;
17
+ let usedRows = 0;
18
+ let usedCols = 0;
19
+ try {
20
+ const range = ws.getUsedRange(16 | 32); // data | formula
21
+ if (range && range.rowCount > 0) {
22
+ usedRows = range.row + range.rowCount;
23
+ usedCols = range.col + range.colCount;
24
+ }
25
+ }
26
+ catch {
27
+ continue;
28
+ }
29
+ for (let r = 0; r < usedRows && matches.length < max; r++) {
30
+ for (let c = 0; c < usedCols && matches.length < max; c++) {
31
+ const value = ws.getValue(r, c);
32
+ const formula = ws.getFormula(r, c);
33
+ if (value === null || value === undefined) {
34
+ if (!formula)
35
+ continue;
36
+ }
37
+ const text = String(value ?? "");
38
+ let isMatch = false;
39
+ if (pattern) {
40
+ isMatch = pattern.test(text);
41
+ }
42
+ else if (options.matchCase) {
43
+ isMatch = text.includes(term);
44
+ }
45
+ else {
46
+ isMatch = text.toLowerCase().includes(term.toLowerCase());
47
+ }
48
+ if (!isMatch)
49
+ continue;
50
+ matches.push({
51
+ sheet: sheetName,
52
+ cell: cellToA1(r, c),
53
+ value,
54
+ formula: formula || null,
55
+ });
56
+ }
57
+ }
58
+ }
59
+ ok({
60
+ matches,
61
+ totalFound: matches.length,
62
+ hasMore: matches.length >= max,
63
+ searchTerm: term,
64
+ });
65
+ });
66
+ }
67
+ //# sourceMappingURL=search.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search.js","sourceRoot":"","sources":["../../../src/cli/commands/search.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function set(filePath: string, ref: string, jsonArg: string | undefined): Promise<void>;
2
+ //# sourceMappingURL=set.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"set.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/set.ts"],"names":[],"mappings":"AAWA,wBAAsB,GAAG,CACvB,QAAQ,EAAE,MAAM,EAChB,GAAG,EAAE,MAAM,EACX,OAAO,EAAE,MAAM,GAAG,SAAS,GAC1B,OAAO,CAAC,IAAI,CAAC,CA8Ef"}
@@ -0,0 +1,67 @@
1
+ import { parseRef, rangeDimensions } from "../a1.js";
2
+ import { withFile } from "../context.js";
3
+ import { fail, ok, readInput } from "../output.js";
4
+ import { applyStyles } from "../styles.js";
5
+ export async function set(filePath, ref, jsonArg) {
6
+ const input = await readInput(jsonArg);
7
+ let cells;
8
+ try {
9
+ cells = JSON.parse(input);
10
+ }
11
+ catch {
12
+ fail("Invalid JSON input for cells.");
13
+ return;
14
+ }
15
+ if (!Array.isArray(cells) || !Array.isArray(cells[0])) {
16
+ fail("Cells must be a 2D array: [[{value: ...}, ...], ...]");
17
+ return;
18
+ }
19
+ const parsed = parseRef(ref);
20
+ const { rows, cols } = rangeDimensions(parsed);
21
+ if (cells.length !== rows) {
22
+ fail(`Row count mismatch: range has ${rows} rows but got ${cells.length} rows.`);
23
+ return;
24
+ }
25
+ for (let r = 0; r < cells.length; r++) {
26
+ if (cells[r].length !== cols) {
27
+ fail(`Column count mismatch in row ${r}: range has ${cols} cols but got ${cells[r].length} cols.`);
28
+ return;
29
+ }
30
+ }
31
+ await withFile(filePath, ({ file, workbook, GC }) => {
32
+ const sheet = parsed.sheet
33
+ ? workbook.getSheetFromName(parsed.sheet)
34
+ : workbook.getActiveSheet();
35
+ if (!sheet) {
36
+ fail(`Sheet not found: ${parsed.sheet ?? "(active)"}`);
37
+ }
38
+ let written = 0;
39
+ file.batch(() => {
40
+ for (let r = 0; r < rows; r++) {
41
+ for (let c = 0; c < cols; c++) {
42
+ const cell = cells[r][c];
43
+ if (!cell)
44
+ continue;
45
+ const row = parsed.start.row + r;
46
+ const col = parsed.start.col + c;
47
+ if (cell.formula) {
48
+ const f = cell.formula.startsWith("=")
49
+ ? cell.formula.slice(1)
50
+ : cell.formula;
51
+ sheet.setFormula(row, col, f);
52
+ written++;
53
+ }
54
+ else if (cell.value !== undefined) {
55
+ sheet.setValue(row, col, cell.value);
56
+ written++;
57
+ }
58
+ if (cell.cellStyles) {
59
+ applyStyles(sheet, row, col, cell.cellStyles, GC);
60
+ }
61
+ }
62
+ }
63
+ });
64
+ ok({ written, range: ref });
65
+ }, { save: true });
66
+ }
67
+ //# sourceMappingURL=set.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"set.js","sourceRoot":"","sources":["../../../src/cli/commands/set.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export type SheetOp = "list" | "create" | "delete" | "rename";
2
+ export declare function sheet(filePath: string, op: SheetOp, args: string[]): Promise<void>;
3
+ //# sourceMappingURL=sheet.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sheet.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/sheet.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,OAAO,GAAG,MAAM,GAAG,QAAQ,GAAG,QAAQ,GAAG,QAAQ,CAAC;AAE9D,wBAAsB,KAAK,CACzB,QAAQ,EAAE,MAAM,EAChB,EAAE,EAAE,OAAO,EACX,IAAI,EAAE,MAAM,EAAE,GACb,OAAO,CAAC,IAAI,CAAC,CAwDf"}
@@ -0,0 +1,62 @@
1
+ import { withFile } from "../context.js";
2
+ import { fail, ok } from "../output.js";
3
+ export async function sheet(filePath, op, args) {
4
+ const needsSave = op !== "list";
5
+ await withFile(filePath, ({ workbook, GC }) => {
6
+ switch (op) {
7
+ case "list": {
8
+ const sheets = [];
9
+ for (let i = 0; i < workbook.getSheetCount(); i++) {
10
+ sheets.push({ index: i, name: workbook.getSheet(i).name() });
11
+ }
12
+ ok({ sheets });
13
+ break;
14
+ }
15
+ case "create": {
16
+ const name = args[0];
17
+ if (!name)
18
+ fail("Usage: hsx sheet <file> create <name>");
19
+ const ws = new GC.Spread.Sheets.Worksheet(name);
20
+ workbook.addSheet(workbook.getSheetCount(), ws);
21
+ ok({ created: name, index: workbook.getSheetCount() - 1 });
22
+ break;
23
+ }
24
+ case "delete": {
25
+ const name = args[0];
26
+ if (!name)
27
+ fail("Usage: hsx sheet <file> delete <name>");
28
+ const index = findSheet(workbook, name);
29
+ if (index === -1)
30
+ fail(`Sheet not found: ${name}`);
31
+ if (workbook.getSheetCount() <= 1) {
32
+ fail("Cannot delete the only sheet.");
33
+ }
34
+ workbook.removeSheet(index);
35
+ ok({ deleted: name });
36
+ break;
37
+ }
38
+ case "rename": {
39
+ const [oldName, newName] = args;
40
+ if (!oldName || !newName) {
41
+ fail("Usage: hsx sheet <file> rename <old> <new>");
42
+ }
43
+ const index = findSheet(workbook, oldName);
44
+ if (index === -1)
45
+ fail(`Sheet not found: ${oldName}`);
46
+ workbook.getSheet(index).name(newName);
47
+ ok({ renamed: { from: oldName, to: newName } });
48
+ break;
49
+ }
50
+ default:
51
+ fail(`Unknown sheet operation: ${op}`);
52
+ }
53
+ }, { save: needsSave });
54
+ }
55
+ function findSheet(workbook, name) {
56
+ for (let i = 0; i < workbook.getSheetCount(); i++) {
57
+ if (workbook.getSheet(i).name() === name)
58
+ return i;
59
+ }
60
+ return -1;
61
+ }
62
+ //# sourceMappingURL=sheet.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sheet.js","sourceRoot":"","sources":["../../../src/cli/commands/sheet.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ /**
2
+ * Lifecycle wrapper: init → open/create → execute → save → dispose.
3
+ */
4
+ import { type ExcelFile } from "../index.js";
5
+ import type { GCNamespace, SpreadWorkbook } from "../types.js";
6
+ export interface FileContext {
7
+ file: ExcelFile;
8
+ workbook: SpreadWorkbook;
9
+ GC: GCNamespace;
10
+ }
11
+ export declare function withFile<T>(filePath: string, fn: (ctx: FileContext) => T | Promise<T>, options?: {
12
+ save?: boolean;
13
+ }): Promise<T>;
14
+ export declare function withNewFile<T>(filePath: string, fn?: (ctx: FileContext) => T | Promise<T>): Promise<T | undefined>;
15
+ //# sourceMappingURL=context.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context.d.ts","sourceRoot":"","sources":["../../src/cli/context.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,KAAK,SAAS,EAAQ,MAAM,aAAa,CAAC;AACnD,OAAO,KAAK,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAE/D,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,SAAS,CAAC;IAChB,QAAQ,EAAE,cAAc,CAAC;IACzB,EAAE,EAAE,WAAW,CAAC;CACjB;AAED,wBAAsB,QAAQ,CAAC,CAAC,EAC9B,QAAQ,EAAE,MAAM,EAChB,EAAE,EAAE,CAAC,GAAG,EAAE,WAAW,KAAK,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,EACxC,OAAO,CAAC,EAAE;IAAE,IAAI,CAAC,EAAE,OAAO,CAAA;CAAE,GAC3B,OAAO,CAAC,CAAC,CAAC,CAYZ;AAED,wBAAsB,WAAW,CAAC,CAAC,EACjC,QAAQ,EAAE,MAAM,EAChB,EAAE,CAAC,EAAE,CAAC,GAAG,EAAE,WAAW,KAAK,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,GACxC,OAAO,CAAC,CAAC,GAAG,SAAS,CAAC,CAaxB"}
@@ -0,0 +1,34 @@
1
+ /**
2
+ * Lifecycle wrapper: init → open/create → execute → save → dispose.
3
+ */
4
+ import { init } from "../index.js";
5
+ export async function withFile(filePath, fn, options) {
6
+ const { GC, ExcelFile: EF, dispose } = await init();
7
+ try {
8
+ const file = await EF.open(filePath);
9
+ const result = await fn({ file, workbook: file.workbook, GC });
10
+ if (options?.save) {
11
+ await file.save(filePath);
12
+ }
13
+ return result;
14
+ }
15
+ finally {
16
+ dispose();
17
+ }
18
+ }
19
+ export async function withNewFile(filePath, fn) {
20
+ const { GC, ExcelFile: EF, dispose } = await init();
21
+ try {
22
+ const file = new EF();
23
+ let result;
24
+ if (fn) {
25
+ result = await fn({ file, workbook: file.workbook, GC });
26
+ }
27
+ await file.save(filePath);
28
+ return result;
29
+ }
30
+ finally {
31
+ dispose();
32
+ }
33
+ }
34
+ //# sourceMappingURL=context.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"context.js","sourceRoot":"","sources":["../../src/cli/context.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAkB,IAAI,EAAE,MAAM,aAAa,CAAC;AASnD,MAAM,CAAC,KAAK,UAAU,QAAQ,CAC5B,QAAgB,EAChB,EAAwC,EACxC,OAA4B;IAE5B,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,EAAE,CAAC;IACpD,IAAI,CAAC;QACH,MAAM,IAAI,GAAG,MAAM,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACrC,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;QAC/D,IAAI,OAAO,EAAE,IAAI,EAAE,CAAC;YAClB,MAAM,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5B,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;YAAS,CAAC;QACT,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,WAAW,CAC/B,QAAgB,EAChB,EAAyC;IAEzC,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,EAAE,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,EAAE,CAAC;IACpD,IAAI,CAAC;QACH,MAAM,IAAI,GAAG,IAAI,EAAE,EAAE,CAAC;QACtB,IAAI,MAAqB,CAAC;QAC1B,IAAI,EAAE,EAAE,CAAC;YACP,MAAM,GAAG,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC;QAC3D,CAAC;QACD,MAAM,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC1B,OAAO,MAAW,CAAC;IACrB,CAAC;YAAS,CAAC;QACT,OAAO,EAAE,CAAC;IACZ,CAAC;AACH,CAAC"}
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env node
2
+ export {};
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":""}
@@ -0,0 +1,183 @@
1
+ #!/usr/bin/env node
2
+ import { clear } from "./commands/clear.js";
3
+ import { copy } from "./commands/copy.js";
4
+ import { create } from "./commands/create.js";
5
+ import { csv } from "./commands/csv.js";
6
+ import { evalCode } from "./commands/eval.js";
7
+ import { get } from "./commands/get.js";
8
+ import { info } from "./commands/info.js";
9
+ import { objects } from "./commands/objects.js";
10
+ import { resize } from "./commands/resize.js";
11
+ import { rowsCols } from "./commands/rows-cols.js";
12
+ import { search } from "./commands/search.js";
13
+ import { set } from "./commands/set.js";
14
+ import { sheet } from "./commands/sheet.js";
15
+ const USAGE = `Usage: hsx <command> [args]
16
+
17
+ Commands:
18
+ create <file> Create a new Excel file
19
+ info <file> Show workbook metadata
20
+ get <file> <ref> Read cells (Sheet1!A1:C10)
21
+ csv <file> <ref> Read range as CSV
22
+ set <file> <ref> [json] Write cells (JSON from arg or stdin)
23
+ clear <file> <ref> [--type all|styles] Clear a range (default: values only)
24
+ search <file> <term> [--sheet S] [--regex] Search for values across sheets
25
+ copy <file> <src> <dst> Copy range (formulas + styles)
26
+ sheet <file> <op> [args] list | create | delete | rename
27
+ rc <file> <op> <dim> [--ref R] [--count N] Insert/delete/hide/freeze rows or columns
28
+ resize <file> [--columns A:D] [--width N] Resize column widths or row heights
29
+ objects <file> [--sheet <name>] List charts, tables, pivots
30
+ eval <file> [code] Execute arbitrary JS (code from arg or stdin)
31
+
32
+ Reference format:
33
+ Sheet1!A1:C10 range on named sheet
34
+ A1:C10 range on active sheet
35
+ A1 single cell
36
+
37
+ Globals available in eval:
38
+ workbook SpreadJS Workbook instance
39
+ sheet Active worksheet
40
+ GC GC.Spread.Sheets namespace
41
+ file ExcelFile wrapper (batch, save, toJSON)`;
42
+ function flag(args, name) {
43
+ const idx = args.indexOf(name);
44
+ return idx !== -1 ? args[idx + 1] : undefined;
45
+ }
46
+ function hasFlag(args, name) {
47
+ return args.includes(name);
48
+ }
49
+ async function main() {
50
+ const args = process.argv.slice(2);
51
+ if (args.length === 0 || args[0] === "--help" || args[0] === "-h") {
52
+ console.log(USAGE);
53
+ process.exit(0);
54
+ }
55
+ const command = args[0];
56
+ const rest = args.slice(1);
57
+ try {
58
+ switch (command) {
59
+ case "create": {
60
+ const file = requireArg(rest, 0, "create <file>");
61
+ await create(file);
62
+ break;
63
+ }
64
+ case "info": {
65
+ const file = requireArg(rest, 0, "info <file>");
66
+ await info(file);
67
+ break;
68
+ }
69
+ case "get": {
70
+ const file = requireArg(rest, 0, "get <file> <ref>");
71
+ const ref = requireArg(rest, 1, "get <file> <ref>");
72
+ const styles = !hasFlag(rest, "--no-styles");
73
+ await get(file, ref, { styles });
74
+ break;
75
+ }
76
+ case "csv": {
77
+ const file = requireArg(rest, 0, "csv <file> <ref>");
78
+ const ref = requireArg(rest, 1, "csv <file> <ref>");
79
+ await csv(file, ref);
80
+ break;
81
+ }
82
+ case "set": {
83
+ const file = requireArg(rest, 0, "set <file> <ref> [json]");
84
+ const ref = requireArg(rest, 1, "set <file> <ref> [json]");
85
+ const json = rest[2]; // optional, reads stdin if missing
86
+ await set(file, ref, json);
87
+ break;
88
+ }
89
+ case "clear": {
90
+ const file = requireArg(rest, 0, "clear <file> <ref>");
91
+ const ref = requireArg(rest, 1, "clear <file> <ref>");
92
+ const clearType = (flag(rest, "--type") ?? "values");
93
+ await clear(file, ref, clearType);
94
+ break;
95
+ }
96
+ case "search": {
97
+ const file = requireArg(rest, 0, "search <file> <term>");
98
+ const term = requireArg(rest, 1, "search <file> <term>");
99
+ await search(file, term, {
100
+ sheet: flag(rest, "--sheet"),
101
+ matchCase: hasFlag(rest, "--match-case"),
102
+ regex: hasFlag(rest, "--regex"),
103
+ maxResults: flag(rest, "--max")
104
+ ? parseInt(flag(rest, "--max"), 10)
105
+ : undefined,
106
+ });
107
+ break;
108
+ }
109
+ case "copy": {
110
+ const file = requireArg(rest, 0, "copy <file> <src> <dst>");
111
+ const src = requireArg(rest, 1, "copy <file> <src> <dst>");
112
+ const dst = requireArg(rest, 2, "copy <file> <src> <dst>");
113
+ await copy(file, src, dst);
114
+ break;
115
+ }
116
+ case "sheet": {
117
+ const file = requireArg(rest, 0, "sheet <file> <op> [args]");
118
+ const op = requireArg(rest, 1, "sheet <file> <op> [args]");
119
+ const opArgs = rest.slice(2);
120
+ await sheet(file, op, opArgs);
121
+ break;
122
+ }
123
+ case "rc": {
124
+ const file = requireArg(rest, 0, "rc <file> <op> <dim>");
125
+ const op = requireArg(rest, 1, "rc <file> <op> <dim>");
126
+ const dim = requireArg(rest, 2, "rc <file> <op> <dim>");
127
+ await rowsCols(file, op, dim, {
128
+ sheet: flag(rest, "--sheet"),
129
+ ref: flag(rest, "--ref"),
130
+ count: flag(rest, "--count")
131
+ ? parseInt(flag(rest, "--count"), 10)
132
+ : undefined,
133
+ });
134
+ break;
135
+ }
136
+ case "resize": {
137
+ const file = requireArg(rest, 0, "resize <file> [options]");
138
+ await resize(file, flag(rest, "--sheet"), {
139
+ columns: flag(rest, "--columns"),
140
+ rows: flag(rest, "--rows"),
141
+ width: flag(rest, "--width")
142
+ ? parseFloat(flag(rest, "--width"))
143
+ : undefined,
144
+ height: flag(rest, "--height")
145
+ ? parseFloat(flag(rest, "--height"))
146
+ : undefined,
147
+ });
148
+ break;
149
+ }
150
+ case "objects": {
151
+ const file = requireArg(rest, 0, "objects <file>");
152
+ await objects(file, flag(rest, "--sheet"));
153
+ break;
154
+ }
155
+ case "eval": {
156
+ const file = requireArg(rest, 0, "eval <file> [code]");
157
+ const code = rest[1]; // optional, reads stdin if missing
158
+ await evalCode(file, code);
159
+ break;
160
+ }
161
+ default:
162
+ console.error(`Unknown command: ${command}\n`);
163
+ console.log(USAGE);
164
+ process.exit(1);
165
+ }
166
+ process.exit(0);
167
+ }
168
+ catch (err) {
169
+ const message = err instanceof Error ? err.message : String(err);
170
+ process.stderr.write(`${JSON.stringify({ error: message })}\n`);
171
+ process.exit(1);
172
+ }
173
+ }
174
+ function requireArg(args, index, usage) {
175
+ const value = args[index];
176
+ if (!value || value.startsWith("--")) {
177
+ console.error(`Usage: hsx ${usage}`);
178
+ process.exit(1);
179
+ }
180
+ return value;
181
+ }
182
+ main();
183
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Structured JSON output helpers for CLI commands.
3
+ */
4
+ export declare function ok(data: unknown): void;
5
+ export declare function fail(message: string): never;
6
+ /**
7
+ * Read input from last positional arg or stdin.
8
+ */
9
+ export declare function readInput(argValue: string | undefined): Promise<string>;
10
+ //# sourceMappingURL=output.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"output.d.ts","sourceRoot":"","sources":["../../src/cli/output.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,wBAAgB,EAAE,CAAC,IAAI,EAAE,OAAO,GAAG,IAAI,CAEtC;AAED,wBAAgB,IAAI,CAAC,OAAO,EAAE,MAAM,GAAG,KAAK,CAE3C;AAED;;GAEG;AACH,wBAAsB,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,CAe7E"}