@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.
- package/README.md +6 -4
- package/dist/cli/a1.d.ts +28 -0
- package/dist/cli/a1.d.ts.map +1 -0
- package/dist/cli/a1.js +66 -0
- package/dist/cli/a1.js.map +1 -0
- package/dist/cli/commands/clear.d.ts +2 -0
- package/dist/cli/commands/clear.d.ts.map +1 -0
- package/dist/cli/commands/clear.js +24 -0
- package/dist/cli/commands/clear.js.map +1 -0
- package/dist/cli/commands/copy.d.ts +2 -0
- package/dist/cli/commands/copy.d.ts.map +1 -0
- package/dist/cli/commands/copy.js +51 -0
- package/dist/cli/commands/copy.js.map +1 -0
- package/dist/cli/commands/create.d.ts +2 -0
- package/dist/cli/commands/create.d.ts.map +1 -0
- package/dist/cli/commands/create.js +7 -0
- package/dist/cli/commands/create.js.map +1 -0
- package/dist/cli/commands/csv.d.ts +2 -0
- package/dist/cli/commands/csv.d.ts.map +1 -0
- package/dist/cli/commands/csv.js +33 -0
- package/dist/cli/commands/csv.js.map +1 -0
- package/dist/cli/commands/eval.d.ts +2 -0
- package/dist/cli/commands/eval.d.ts.map +1 -0
- package/dist/cli/commands/eval.js +45 -0
- package/dist/cli/commands/eval.js.map +1 -0
- package/dist/cli/commands/get.d.ts +4 -0
- package/dist/cli/commands/get.d.ts.map +1 -0
- package/dist/cli/commands/get.js +55 -0
- package/dist/cli/commands/get.js.map +1 -0
- package/dist/cli/commands/info.d.ts +2 -0
- package/dist/cli/commands/info.d.ts.map +1 -0
- package/dist/cli/commands/info.js +34 -0
- package/dist/cli/commands/info.js.map +1 -0
- package/dist/cli/commands/objects.d.ts +2 -0
- package/dist/cli/commands/objects.d.ts.map +1 -0
- package/dist/cli/commands/objects.js +71 -0
- package/dist/cli/commands/objects.js.map +1 -0
- package/dist/cli/commands/resize.d.ts +7 -0
- package/dist/cli/commands/resize.d.ts.map +1 -0
- package/dist/cli/commands/resize.js +51 -0
- package/dist/cli/commands/resize.js.map +1 -0
- package/dist/cli/commands/rows-cols.d.ts +8 -0
- package/dist/cli/commands/rows-cols.d.ts.map +1 -0
- package/dist/cli/commands/rows-cols.js +77 -0
- package/dist/cli/commands/rows-cols.js.map +1 -0
- package/dist/cli/commands/search.d.ts +7 -0
- package/dist/cli/commands/search.d.ts.map +1 -0
- package/dist/cli/commands/search.js +67 -0
- package/dist/cli/commands/search.js.map +1 -0
- package/dist/cli/commands/set.d.ts +2 -0
- package/dist/cli/commands/set.d.ts.map +1 -0
- package/dist/cli/commands/set.js +67 -0
- package/dist/cli/commands/set.js.map +1 -0
- package/dist/cli/commands/sheet.d.ts +3 -0
- package/dist/cli/commands/sheet.d.ts.map +1 -0
- package/dist/cli/commands/sheet.js +62 -0
- package/dist/cli/commands/sheet.js.map +1 -0
- package/dist/cli/context.d.ts +15 -0
- package/dist/cli/context.d.ts.map +1 -0
- package/dist/cli/context.js +34 -0
- package/dist/cli/context.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +183 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/output.d.ts +10 -0
- package/dist/cli/output.d.ts.map +1 -0
- package/dist/cli/output.js +28 -0
- package/dist/cli/output.js.map +1 -0
- package/dist/cli/styles.d.ts +27 -0
- package/dist/cli/styles.d.ts.map +1 -0
- package/dist/cli/styles.js +105 -0
- package/dist/cli/styles.js.map +1 -0
- package/package.json +20 -10
- package/dist/workbook.d.ts +0 -19
- package/dist/workbook.d.ts.map +0 -1
- package/dist/workbook.js +0 -177
- 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":"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"}
|
|
@@ -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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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"}
|