@hewliyang/headless-spreadjs 0.0.2 → 0.0.4
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 +78 -50
- package/dist/cli/abort.d.ts +7 -0
- package/dist/cli/abort.d.ts.map +1 -0
- package/dist/cli/abort.js +35 -0
- package/dist/cli/abort.js.map +1 -0
- package/dist/cli/client.d.ts +9 -0
- package/dist/cli/client.d.ts.map +1 -0
- package/dist/cli/client.js +122 -0
- package/dist/cli/client.js.map +1 -0
- package/dist/cli/commands/clear.d.ts +3 -1
- package/dist/cli/commands/clear.d.ts.map +1 -1
- package/dist/cli/commands/clear.js +11 -9
- package/dist/cli/commands/clear.js.map +1 -1
- package/dist/cli/commands/copy.d.ts +3 -1
- package/dist/cli/commands/copy.d.ts.map +1 -1
- package/dist/cli/commands/copy.js +5 -2
- package/dist/cli/commands/copy.js.map +1 -1
- package/dist/cli/commands/create.d.ts +3 -1
- package/dist/cli/commands/create.d.ts.map +1 -1
- package/dist/cli/commands/create.js +2 -2
- package/dist/cli/commands/create.js.map +1 -1
- package/dist/cli/commands/csv.d.ts +5 -1
- package/dist/cli/commands/csv.d.ts.map +1 -1
- package/dist/cli/commands/csv.js +38 -13
- package/dist/cli/commands/csv.js.map +1 -1
- package/dist/cli/commands/deps.d.ts +11 -0
- package/dist/cli/commands/deps.d.ts.map +1 -0
- package/dist/cli/commands/deps.js +329 -0
- package/dist/cli/commands/deps.js.map +1 -0
- package/dist/cli/commands/diff.d.ts +7 -0
- package/dist/cli/commands/diff.d.ts.map +1 -0
- package/dist/cli/commands/diff.js +235 -0
- package/dist/cli/commands/diff.js.map +1 -0
- package/dist/cli/commands/eval.d.ts +3 -1
- package/dist/cli/commands/eval.d.ts.map +1 -1
- package/dist/cli/commands/eval.js +23 -8
- package/dist/cli/commands/eval.js.map +1 -1
- package/dist/cli/commands/get.d.ts +1 -0
- package/dist/cli/commands/get.d.ts.map +1 -1
- package/dist/cli/commands/get.js +5 -2
- package/dist/cli/commands/get.js.map +1 -1
- package/dist/cli/commands/info.d.ts +3 -1
- package/dist/cli/commands/info.d.ts.map +1 -1
- package/dist/cli/commands/info.js +5 -2
- package/dist/cli/commands/info.js.map +1 -1
- package/dist/cli/commands/objects.d.ts +3 -1
- package/dist/cli/commands/objects.d.ts.map +1 -1
- package/dist/cli/commands/objects.js +5 -6
- package/dist/cli/commands/objects.js.map +1 -1
- package/dist/cli/commands/resize.d.ts +1 -0
- package/dist/cli/commands/resize.d.ts.map +1 -1
- package/dist/cli/commands/resize.js +67 -29
- package/dist/cli/commands/resize.js.map +1 -1
- package/dist/cli/commands/rows-cols.d.ts +1 -0
- package/dist/cli/commands/rows-cols.d.ts.map +1 -1
- package/dist/cli/commands/rows-cols.js +101 -45
- package/dist/cli/commands/rows-cols.js.map +1 -1
- package/dist/cli/commands/screenshot.d.ts +8 -0
- package/dist/cli/commands/screenshot.d.ts.map +1 -0
- package/dist/cli/commands/screenshot.js +260 -0
- package/dist/cli/commands/screenshot.js.map +1 -0
- package/dist/cli/commands/search.d.ts +1 -0
- package/dist/cli/commands/search.d.ts.map +1 -1
- package/dist/cli/commands/search.js +16 -8
- package/dist/cli/commands/search.js.map +1 -1
- package/dist/cli/commands/set.d.ts +3 -1
- package/dist/cli/commands/set.d.ts.map +1 -1
- package/dist/cli/commands/set.js +72 -25
- package/dist/cli/commands/set.js.map +1 -1
- package/dist/cli/commands/sheet.d.ts +3 -1
- package/dist/cli/commands/sheet.d.ts.map +1 -1
- package/dist/cli/commands/sheet.js +20 -10
- package/dist/cli/commands/sheet.js.map +1 -1
- package/dist/cli/context.d.ts +18 -6
- package/dist/cli/context.d.ts.map +1 -1
- package/dist/cli/context.js +93 -8
- package/dist/cli/context.js.map +1 -1
- package/dist/cli/daemon-entry.d.ts +3 -0
- package/dist/cli/daemon-entry.d.ts.map +1 -0
- package/dist/cli/daemon-entry.js +4 -0
- package/dist/cli/daemon-entry.js.map +1 -0
- package/dist/cli/daemon.d.ts +4 -0
- package/dist/cli/daemon.d.ts.map +1 -0
- package/dist/cli/daemon.js +330 -0
- package/dist/cli/daemon.js.map +1 -0
- package/dist/cli/dispatch.d.ts +5 -0
- package/dist/cli/dispatch.d.ts.map +1 -0
- package/dist/cli/dispatch.js +353 -0
- package/dist/cli/dispatch.js.map +1 -0
- package/dist/cli/file-cache.d.ts +23 -0
- package/dist/cli/file-cache.d.ts.map +1 -0
- package/dist/cli/file-cache.js +102 -0
- package/dist/cli/file-cache.js.map +1 -0
- package/dist/cli/index.js +34 -175
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/main.d.ts +2 -0
- package/dist/cli/main.d.ts.map +1 -0
- package/dist/cli/main.js +210 -0
- package/dist/cli/main.js.map +1 -0
- package/dist/cli/output.d.ts +9 -6
- package/dist/cli/output.d.ts.map +1 -1
- package/dist/cli/output.js +36 -8
- package/dist/cli/output.js.map +1 -1
- package/dist/cli/styles.d.ts +14 -19
- package/dist/cli/styles.d.ts.map +1 -1
- package/dist/cli/styles.js +65 -39
- package/dist/cli/styles.js.map +1 -1
- package/dist/excel-file.d.ts +3 -1
- package/dist/excel-file.d.ts.map +1 -1
- package/dist/excel-file.js +50 -6
- package/dist/excel-file.js.map +1 -1
- package/dist/shims.d.ts.map +1 -1
- package/dist/shims.js +52 -0
- package/dist/shims.js.map +1 -1
- package/package.json +9 -1
|
@@ -1,9 +1,28 @@
|
|
|
1
|
+
import { parseRef } from "../a1.js";
|
|
1
2
|
import { withFile } from "../context.js";
|
|
2
3
|
import { fail, ok, readInput } from "../output.js";
|
|
3
|
-
export async function evalCode(filePath, codeArg) {
|
|
4
|
+
export async function evalCode(filePath, codeArg, options) {
|
|
4
5
|
const code = await readInput(codeArg);
|
|
5
6
|
await withFile(filePath, async ({ file, workbook, GC }) => {
|
|
6
7
|
const sheet = workbook.getActiveSheet();
|
|
8
|
+
const range = (ref) => {
|
|
9
|
+
if (typeof ref !== "string" || ref.trim().length === 0) {
|
|
10
|
+
throw new Error("range(ref) expects a non-empty A1 reference string.");
|
|
11
|
+
}
|
|
12
|
+
const parsed = parseRef(ref.trim());
|
|
13
|
+
const targetSheet = parsed.sheet
|
|
14
|
+
? workbook.getSheetFromName(parsed.sheet)
|
|
15
|
+
: workbook.getActiveSheet();
|
|
16
|
+
if (!targetSheet) {
|
|
17
|
+
throw new Error(`Sheet not found: ${parsed.sheet ?? "(active)"}`);
|
|
18
|
+
}
|
|
19
|
+
const rowCount = parsed.end.row - parsed.start.row + 1;
|
|
20
|
+
const colCount = parsed.end.col - parsed.start.col + 1;
|
|
21
|
+
if (rowCount < 1 || colCount < 1) {
|
|
22
|
+
throw new Error(`Invalid range reference: ${ref}`);
|
|
23
|
+
}
|
|
24
|
+
return targetSheet.getRange(parsed.start.row, parsed.start.col, rowCount, colCount);
|
|
25
|
+
};
|
|
7
26
|
// Capture console.log output
|
|
8
27
|
const logs = [];
|
|
9
28
|
const origLog = console.log;
|
|
@@ -14,8 +33,8 @@ export async function evalCode(filePath, codeArg) {
|
|
|
14
33
|
console.error = (...args) => logs.push(`[error] ${args.map(String).join(" ")}`);
|
|
15
34
|
try {
|
|
16
35
|
const AsyncFunction = Object.getPrototypeOf(async () => { }).constructor;
|
|
17
|
-
const fn = new AsyncFunction("workbook", "sheet", "GC", "file", code);
|
|
18
|
-
const result = await fn(workbook, sheet, GC, file);
|
|
36
|
+
const fn = new AsyncFunction("workbook", "sheet", "GC", "file", "range", code);
|
|
37
|
+
const result = await fn(workbook, sheet, GC, file, range);
|
|
19
38
|
const output = {};
|
|
20
39
|
if (result !== undefined) {
|
|
21
40
|
output.result = result;
|
|
@@ -29,10 +48,6 @@ export async function evalCode(filePath, codeArg) {
|
|
|
29
48
|
ok(output);
|
|
30
49
|
}
|
|
31
50
|
catch (err) {
|
|
32
|
-
// Restore console before failing
|
|
33
|
-
console.log = origLog;
|
|
34
|
-
console.warn = origWarn;
|
|
35
|
-
console.error = origError;
|
|
36
51
|
fail(err instanceof Error ? err.message : String(err));
|
|
37
52
|
}
|
|
38
53
|
finally {
|
|
@@ -40,6 +55,6 @@ export async function evalCode(filePath, codeArg) {
|
|
|
40
55
|
console.warn = origWarn;
|
|
41
56
|
console.error = origError;
|
|
42
57
|
}
|
|
43
|
-
}, { save: true });
|
|
58
|
+
}, { save: true, signal: options?.signal });
|
|
44
59
|
}
|
|
45
60
|
//# sourceMappingURL=eval.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"eval.js","sourceRoot":"","sources":["../../../src/cli/commands/eval.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEnD,MAAM,CAAC,KAAK,UAAU,QAAQ,CAC5B,QAAgB,EAChB,OAA2B;
|
|
1
|
+
{"version":3,"file":"eval.js","sourceRoot":"","sources":["../../../src/cli/commands/eval.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/get.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"get.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/get.ts"],"names":[],"mappings":"AAMA,wBAAsB,GAAG,CACvB,QAAQ,EAAE,MAAM,EAChB,GAAG,EAAE,MAAM,EACX,OAAO,EAAE;IAAE,MAAM,CAAC,EAAE,OAAO,CAAC;IAAC,MAAM,CAAC,EAAE,WAAW,GAAG,IAAI,CAAA;CAAE,GACzD,OAAO,CAAC,IAAI,CAAC,CAwEf"}
|
package/dist/cli/commands/get.js
CHANGED
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
import { cellToA1, parseRef, rangeDimensions } from "../a1.js";
|
|
2
|
+
import { throwIfAborted } from "../abort.js";
|
|
2
3
|
import { withFile } from "../context.js";
|
|
3
4
|
import { fail, ok } from "../output.js";
|
|
4
5
|
import { serializeStyle } from "../styles.js";
|
|
5
6
|
export async function get(filePath, ref, options) {
|
|
6
7
|
const parsed = parseRef(ref);
|
|
8
|
+
const signal = options.signal;
|
|
7
9
|
await withFile(filePath, ({ workbook }) => {
|
|
8
10
|
const sheet = parsed.sheet
|
|
9
11
|
? workbook.getSheetFromName(parsed.sheet)
|
|
@@ -15,6 +17,7 @@ export async function get(filePath, ref, options) {
|
|
|
15
17
|
const cells = {};
|
|
16
18
|
let cellCount = 0;
|
|
17
19
|
for (let r = 0; r < rows; r++) {
|
|
20
|
+
throwIfAborted(signal);
|
|
18
21
|
for (let c = 0; c < cols; c++) {
|
|
19
22
|
const row = parsed.start.row + r;
|
|
20
23
|
const col = parsed.start.col + c;
|
|
@@ -36,7 +39,7 @@ export async function get(filePath, ref, options) {
|
|
|
36
39
|
if (style) {
|
|
37
40
|
const serialized = serializeStyle(style);
|
|
38
41
|
if (serialized) {
|
|
39
|
-
cell.
|
|
42
|
+
cell.style = serialized;
|
|
40
43
|
}
|
|
41
44
|
}
|
|
42
45
|
}
|
|
@@ -50,6 +53,6 @@ export async function get(filePath, ref, options) {
|
|
|
50
53
|
cellCount,
|
|
51
54
|
cells,
|
|
52
55
|
});
|
|
53
|
-
});
|
|
56
|
+
}, { signal });
|
|
54
57
|
}
|
|
55
58
|
//# sourceMappingURL=get.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"get.js","sourceRoot":"","sources":["../../../src/cli/commands/get.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AAC/D,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AACxC,OAAO,
|
|
1
|
+
{"version":3,"file":"get.js","sourceRoot":"","sources":["../../../src/cli/commands/get.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"info.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/info.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"info.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/info.ts"],"names":[],"mappings":"AAKA,wBAAsB,IAAI,CACxB,QAAQ,EAAE,MAAM,EAChB,OAAO,CAAC,EAAE;IAAE,MAAM,CAAC,EAAE,WAAW,GAAG,IAAI,CAAA;CAAE,GACxC,OAAO,CAAC,IAAI,CAAC,CAiDf"}
|
|
@@ -1,12 +1,15 @@
|
|
|
1
1
|
import { cellToA1 } from "../a1.js";
|
|
2
|
+
import { throwIfAborted } from "../abort.js";
|
|
2
3
|
import { withFile } from "../context.js";
|
|
3
4
|
import { ok } from "../output.js";
|
|
4
|
-
export async function info(filePath) {
|
|
5
|
+
export async function info(filePath, options) {
|
|
6
|
+
const signal = options?.signal;
|
|
5
7
|
await withFile(filePath, ({ workbook, GC }) => {
|
|
6
8
|
const sheetCount = workbook.getSheetCount();
|
|
7
9
|
const activeIndex = workbook.getActiveSheetIndex();
|
|
8
10
|
const sheets = [];
|
|
9
11
|
for (let i = 0; i < sheetCount; i++) {
|
|
12
|
+
throwIfAborted(signal);
|
|
10
13
|
const sheet = workbook.getSheet(i);
|
|
11
14
|
let usedRange = null;
|
|
12
15
|
try {
|
|
@@ -29,6 +32,6 @@ export async function info(filePath) {
|
|
|
29
32
|
});
|
|
30
33
|
}
|
|
31
34
|
ok({ sheets });
|
|
32
|
-
});
|
|
35
|
+
}, { signal });
|
|
33
36
|
}
|
|
34
37
|
//# sourceMappingURL=info.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"info.js","sourceRoot":"","sources":["../../../src/cli/commands/info.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAElC,MAAM,CAAC,KAAK,UAAU,IAAI,
|
|
1
|
+
{"version":3,"file":"info.js","sourceRoot":"","sources":["../../../src/cli/commands/info.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,UAAU,CAAC;AACpC,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAElC,MAAM,CAAC,KAAK,UAAU,IAAI,CACxB,QAAgB,EAChB,OAAyC;IAEzC,MAAM,MAAM,GAAG,OAAO,EAAE,MAAM,CAAC;IAE/B,MAAM,QAAQ,CACZ,QAAQ,EACR,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,EAAE,EAAE;QACnB,MAAM,UAAU,GAAG,QAAQ,CAAC,aAAa,EAAE,CAAC;QAC5C,MAAM,WAAW,GAAG,QAAQ,CAAC,mBAAmB,EAAE,CAAC;QACnD,MAAM,MAAM,GAKN,EAAE,CAAC;QAET,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,EAAE,CAAC,EAAE,EAAE,CAAC;YACpC,cAAc,CAAC,MAAM,CAAC,CAAC;YACvB,MAAM,KAAK,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YACnC,IAAI,SAAS,GAAkB,IAAI,CAAC;YAEpC,IAAI,CAAC;gBACH,MAAM,KAAK,GAAG,KAAK,CAAC,YAAY,CAC9B,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,IAAI;oBACjC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,OAAO,CACzC,CAAC;gBACF,IAAI,KAAK,IAAI,KAAK,CAAC,QAAQ,GAAG,CAAC,IAAI,KAAK,CAAC,QAAQ,GAAG,CAAC,EAAE,CAAC;oBACtD,MAAM,OAAO,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;oBAC/C,MAAM,KAAK,GAAG,QAAQ,CACpB,KAAK,CAAC,GAAG,GAAG,KAAK,CAAC,QAAQ,GAAG,CAAC,EAC9B,KAAK,CAAC,GAAG,GAAG,KAAK,CAAC,QAAQ,GAAG,CAAC,CAC/B,CAAC;oBACF,SAAS,GAAG,GAAG,OAAO,IAAI,KAAK,EAAE,CAAC;gBACpC,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,wCAAwC;YAC1C,CAAC;YAED,MAAM,CAAC,IAAI,CAAC;gBACV,KAAK,EAAE,CAAC;gBACR,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE;gBAClB,SAAS;gBACT,MAAM,EAAE,CAAC,KAAK,WAAW;aAC1B,CAAC,CAAC;QACL,CAAC;QAED,EAAE,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IACjB,CAAC,EACD,EAAE,MAAM,EAAE,CACX,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"objects.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/objects.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"objects.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/objects.ts"],"names":[],"mappings":"AAUA,wBAAsB,OAAO,CAC3B,QAAQ,EAAE,MAAM,EAChB,WAAW,CAAC,EAAE,MAAM,EACpB,OAAO,CAAC,EAAE;IAAE,MAAM,CAAC,EAAE,WAAW,GAAG,IAAI,CAAA;CAAE,GACxC,OAAO,CAAC,IAAI,CAAC,CAwEf"}
|
|
@@ -1,14 +1,16 @@
|
|
|
1
|
+
import { throwIfAborted } from "../abort.js";
|
|
1
2
|
import { withFile } from "../context.js";
|
|
2
3
|
import { ok } from "../output.js";
|
|
3
|
-
export async function objects(filePath, sheetFilter) {
|
|
4
|
+
export async function objects(filePath, sheetFilter, options) {
|
|
5
|
+
const signal = options?.signal;
|
|
4
6
|
await withFile(filePath, ({ workbook }) => {
|
|
5
7
|
const result = [];
|
|
6
8
|
for (let i = 0; i < workbook.getSheetCount(); i++) {
|
|
9
|
+
throwIfAborted(signal);
|
|
7
10
|
const sheet = workbook.getSheet(i);
|
|
8
11
|
const sheetName = sheet.name();
|
|
9
12
|
if (sheetFilter && sheetName !== sheetFilter)
|
|
10
13
|
continue;
|
|
11
|
-
// Charts
|
|
12
14
|
try {
|
|
13
15
|
const charts = sheet.charts?.all?.() ?? [];
|
|
14
16
|
for (const chart of charts) {
|
|
@@ -22,7 +24,6 @@ export async function objects(filePath, sheetFilter) {
|
|
|
22
24
|
catch {
|
|
23
25
|
// charts extension may not be loaded
|
|
24
26
|
}
|
|
25
|
-
// Tables
|
|
26
27
|
try {
|
|
27
28
|
const tables = sheet.tables?.all?.() ?? [];
|
|
28
29
|
for (const table of tables) {
|
|
@@ -36,7 +37,6 @@ export async function objects(filePath, sheetFilter) {
|
|
|
36
37
|
catch {
|
|
37
38
|
// tables may not be available
|
|
38
39
|
}
|
|
39
|
-
// Pivot tables
|
|
40
40
|
try {
|
|
41
41
|
const pivots = sheet.pivotTables?.all?.() ?? [];
|
|
42
42
|
for (const pivot of pivots) {
|
|
@@ -50,7 +50,6 @@ export async function objects(filePath, sheetFilter) {
|
|
|
50
50
|
catch {
|
|
51
51
|
// pivot extension may not be loaded
|
|
52
52
|
}
|
|
53
|
-
// Slicers
|
|
54
53
|
try {
|
|
55
54
|
const slicers = sheet.slicers?.all?.() ?? [];
|
|
56
55
|
for (const slicer of slicers) {
|
|
@@ -66,6 +65,6 @@ export async function objects(filePath, sheetFilter) {
|
|
|
66
65
|
}
|
|
67
66
|
}
|
|
68
67
|
ok({ objects: result });
|
|
69
|
-
});
|
|
68
|
+
}, { signal });
|
|
70
69
|
}
|
|
71
70
|
//# sourceMappingURL=objects.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"objects.js","sourceRoot":"","sources":["../../../src/cli/commands/objects.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAQlC,MAAM,CAAC,KAAK,UAAU,OAAO,CAC3B,QAAgB,EAChB,WAAoB;
|
|
1
|
+
{"version":3,"file":"objects.js","sourceRoot":"","sources":["../../../src/cli/commands/objects.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAQlC,MAAM,CAAC,KAAK,UAAU,OAAO,CAC3B,QAAgB,EAChB,WAAoB,EACpB,OAAyC;IAEzC,MAAM,MAAM,GAAG,OAAO,EAAE,MAAM,CAAC;IAE/B,MAAM,QAAQ,CACZ,QAAQ,EACR,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;QACf,MAAM,MAAM,GAAiB,EAAE,CAAC;QAEhC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,QAAQ,CAAC,aAAa,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;YAClD,cAAc,CAAC,MAAM,CAAC,CAAC;YACvB,MAAM,KAAK,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;YACnC,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC;YAE/B,IAAI,WAAW,IAAI,SAAS,KAAK,WAAW;gBAAE,SAAS;YAEvD,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE,IAAI,EAAE,CAAC;gBAC3C,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;oBAC3B,MAAM,CAAC,IAAI,CAAC;wBACV,KAAK,EAAE,SAAS;wBAChB,IAAI,EAAE,OAAO;wBACb,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE;qBACnB,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,qCAAqC;YACvC,CAAC;YAED,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE,IAAI,EAAE,CAAC;gBAC3C,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;oBAC3B,MAAM,CAAC,IAAI,CAAC;wBACV,KAAK,EAAE,SAAS;wBAChB,IAAI,EAAE,OAAO;wBACb,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;qBAC3B,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,8BAA8B;YAChC,CAAC;YAED,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,KAAK,CAAC,WAAW,EAAE,GAAG,EAAE,EAAE,IAAI,EAAE,CAAC;gBAChD,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;oBAC3B,MAAM,CAAC,IAAI,CAAC;wBACV,KAAK,EAAE,SAAS;wBAChB,IAAI,EAAE,YAAY;wBAClB,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;qBAC3B,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,oCAAoC;YACtC,CAAC;YAED,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,EAAE,GAAG,EAAE,EAAE,IAAI,EAAE,CAAC;gBAC7C,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;oBAC7B,MAAM,CAAC,IAAI,CAAC;wBACV,KAAK,EAAE,SAAS;wBAChB,IAAI,EAAE,QAAQ;wBACd,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;qBAC5B,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YAAC,MAAM,CAAC;gBACP,sCAAsC;YACxC,CAAC;QACH,CAAC;QAED,EAAE,CAAC,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC,CAAC;IAC1B,CAAC,EACD,EAAE,MAAM,EAAE,CACX,CAAC;AACJ,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"resize.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/resize.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"resize.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/resize.ts"],"names":[],"mappings":"AAuCA,wBAAsB,MAAM,CAC1B,QAAQ,EAAE,MAAM,EAChB,SAAS,EAAE,MAAM,GAAG,SAAS,EAC7B,OAAO,EAAE;IACP,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,WAAW,GAAG,IAAI,CAAC;CAC7B,GACA,OAAO,CAAC,IAAI,CAAC,CA+Df"}
|
|
@@ -1,51 +1,89 @@
|
|
|
1
1
|
import { colToIndex } from "../a1.js";
|
|
2
|
+
import { throwIfAborted } from "../abort.js";
|
|
2
3
|
import { withFile } from "../context.js";
|
|
3
4
|
import { fail, ok } from "../output.js";
|
|
5
|
+
const USED_RANGE_TYPE_DATA_FORMULA = 16 | 32;
|
|
6
|
+
function parseColumnSpan(ref) {
|
|
7
|
+
const trimmed = ref.trim();
|
|
8
|
+
const match = trimmed.match(/^([A-Za-z]+)(?::([A-Za-z]+))?$/);
|
|
9
|
+
if (!match) {
|
|
10
|
+
fail(`Invalid --columns reference: ${ref}`);
|
|
11
|
+
}
|
|
12
|
+
const start = colToIndex(match[1]);
|
|
13
|
+
const end = match[2] ? colToIndex(match[2]) : start;
|
|
14
|
+
if (start < 0 || end < 0 || end < start) {
|
|
15
|
+
fail(`Invalid --columns reference: ${ref}`);
|
|
16
|
+
}
|
|
17
|
+
return { start, end };
|
|
18
|
+
}
|
|
19
|
+
function parseRowSpan(ref) {
|
|
20
|
+
const trimmed = ref.trim();
|
|
21
|
+
const match = trimmed.match(/^(\d+)(?::(\d+))?$/);
|
|
22
|
+
if (!match) {
|
|
23
|
+
fail(`Invalid --rows reference: ${ref}`);
|
|
24
|
+
}
|
|
25
|
+
const start = Number.parseInt(match[1], 10) - 1;
|
|
26
|
+
const end = match[2] ? Number.parseInt(match[2], 10) - 1 : start;
|
|
27
|
+
if (start < 0 || end < 0 || end < start) {
|
|
28
|
+
fail(`Invalid --rows reference: ${ref}`);
|
|
29
|
+
}
|
|
30
|
+
return { start, end };
|
|
31
|
+
}
|
|
4
32
|
export async function resize(filePath, sheetName, options) {
|
|
5
33
|
if (!options.width && !options.height) {
|
|
6
34
|
fail("Specify --width and/or --height.");
|
|
7
35
|
}
|
|
8
|
-
|
|
36
|
+
const signal = options.signal;
|
|
37
|
+
await withFile(filePath, ({ file, workbook }) => {
|
|
9
38
|
const sheet = sheetName
|
|
10
39
|
? workbook.getSheetFromName(sheetName)
|
|
11
40
|
: workbook.getActiveSheet();
|
|
12
41
|
if (!sheet)
|
|
13
42
|
fail(`Sheet not found: ${sheetName ?? "(active)"}`);
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
for (let c = startCol; c <= endCol; c++) {
|
|
20
|
-
sheet.setColumnWidth(c, options.width);
|
|
43
|
+
file.batch(() => {
|
|
44
|
+
let usedRange = null;
|
|
45
|
+
if (!options.columns || !options.rows) {
|
|
46
|
+
try {
|
|
47
|
+
usedRange = sheet.getUsedRange(USED_RANGE_TYPE_DATA_FORMULA);
|
|
21
48
|
}
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
// All columns
|
|
25
|
-
const colCount = sheet.getColumnCount();
|
|
26
|
-
for (let c = 0; c < colCount; c++) {
|
|
27
|
-
sheet.setColumnWidth(c, options.width);
|
|
49
|
+
catch {
|
|
50
|
+
usedRange = null;
|
|
28
51
|
}
|
|
29
52
|
}
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
53
|
+
if (options.width !== undefined) {
|
|
54
|
+
if (options.columns) {
|
|
55
|
+
const span = parseColumnSpan(options.columns);
|
|
56
|
+
for (let c = span.start; c <= span.end; c++) {
|
|
57
|
+
throwIfAborted(signal);
|
|
58
|
+
sheet.setColumnWidth(c, options.width);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
else if (usedRange && usedRange.colCount > 0) {
|
|
62
|
+
const endCol = usedRange.col + usedRange.colCount;
|
|
63
|
+
for (let c = usedRange.col; c < endCol; c++) {
|
|
64
|
+
throwIfAborted(signal);
|
|
65
|
+
sheet.setColumnWidth(c, options.width);
|
|
66
|
+
}
|
|
38
67
|
}
|
|
39
68
|
}
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
69
|
+
if (options.height !== undefined) {
|
|
70
|
+
if (options.rows) {
|
|
71
|
+
const span = parseRowSpan(options.rows);
|
|
72
|
+
for (let r = span.start; r <= span.end; r++) {
|
|
73
|
+
throwIfAborted(signal);
|
|
74
|
+
sheet.setRowHeight(r, options.height);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
else if (usedRange && usedRange.rowCount > 0) {
|
|
78
|
+
const endRow = usedRange.row + usedRange.rowCount;
|
|
79
|
+
for (let r = usedRange.row; r < endRow; r++) {
|
|
80
|
+
throwIfAborted(signal);
|
|
81
|
+
sheet.setRowHeight(r, options.height);
|
|
82
|
+
}
|
|
45
83
|
}
|
|
46
84
|
}
|
|
47
|
-
}
|
|
85
|
+
});
|
|
48
86
|
ok({ resized: true });
|
|
49
|
-
}, { save: true });
|
|
87
|
+
}, { save: true, signal });
|
|
50
88
|
}
|
|
51
89
|
//# sourceMappingURL=resize.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"resize.js","sourceRoot":"","sources":["../../../src/cli/commands/resize.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;AAExC,MAAM,
|
|
1
|
+
{"version":3,"file":"resize.js","sourceRoot":"","sources":["../../../src/cli/commands/resize.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"rows-cols.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/rows-cols.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"rows-cols.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/rows-cols.ts"],"names":[],"mappings":"AA4CA,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;IACf,MAAM,CAAC,EAAE,WAAW,GAAG,IAAI,CAAC;CAC7B,GACA,OAAO,CAAC,IAAI,CAAC,CA2Gf"}
|
|
@@ -1,77 +1,133 @@
|
|
|
1
1
|
import { colToIndex } from "../a1.js";
|
|
2
|
+
import { throwIfAborted } from "../abort.js";
|
|
2
3
|
import { withFile } from "../context.js";
|
|
3
4
|
import { fail, ok } from "../output.js";
|
|
5
|
+
function splitQualifiedRef(ref) {
|
|
6
|
+
const quotedMatch = ref.match(/^'([^']+)'!(.+)$/);
|
|
7
|
+
if (quotedMatch) {
|
|
8
|
+
return { sheet: quotedMatch[1], localRef: quotedMatch[2] };
|
|
9
|
+
}
|
|
10
|
+
const bangIndex = ref.indexOf("!");
|
|
11
|
+
if (bangIndex === -1) {
|
|
12
|
+
return { localRef: ref };
|
|
13
|
+
}
|
|
14
|
+
return {
|
|
15
|
+
sheet: ref.slice(0, bangIndex),
|
|
16
|
+
localRef: ref.slice(bangIndex + 1),
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
function parseRowRef(ref) {
|
|
20
|
+
if (!/^\d+$/.test(ref)) {
|
|
21
|
+
fail(`Invalid row reference: ${ref}`);
|
|
22
|
+
}
|
|
23
|
+
const parsed = Number.parseInt(ref, 10);
|
|
24
|
+
if (!Number.isFinite(parsed) || parsed <= 0) {
|
|
25
|
+
fail(`Invalid row reference: ${ref}`);
|
|
26
|
+
}
|
|
27
|
+
return parsed;
|
|
28
|
+
}
|
|
29
|
+
function parseColumnRef(ref) {
|
|
30
|
+
if (!/^[A-Za-z]+$/.test(ref)) {
|
|
31
|
+
fail(`Invalid column reference: ${ref}`);
|
|
32
|
+
}
|
|
33
|
+
const index = colToIndex(ref);
|
|
34
|
+
if (!Number.isFinite(index) || index < 0) {
|
|
35
|
+
fail(`Invalid column reference: ${ref}`);
|
|
36
|
+
}
|
|
37
|
+
return index;
|
|
38
|
+
}
|
|
4
39
|
export async function rowsCols(filePath, op, dim, options) {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
40
|
+
const signal = options.signal;
|
|
41
|
+
await withFile(filePath, ({ file, workbook }) => {
|
|
42
|
+
const qualified = options.ref ? splitQualifiedRef(options.ref) : null;
|
|
43
|
+
if (options.sheet &&
|
|
44
|
+
qualified?.sheet &&
|
|
45
|
+
options.sheet !== qualified.sheet) {
|
|
46
|
+
fail(`Sheet mismatch: --sheet ${options.sheet} does not match ref sheet ${qualified.sheet}`);
|
|
47
|
+
}
|
|
48
|
+
const effectiveSheetName = options.sheet ?? qualified?.sheet;
|
|
49
|
+
const sheet = effectiveSheetName
|
|
50
|
+
? workbook.getSheetFromName(effectiveSheetName)
|
|
8
51
|
: workbook.getActiveSheet();
|
|
9
52
|
if (!sheet)
|
|
10
|
-
fail(`Sheet not found: ${
|
|
53
|
+
fail(`Sheet not found: ${effectiveSheetName ?? "(active)"}`);
|
|
11
54
|
if (op === "unfreeze") {
|
|
12
|
-
|
|
13
|
-
|
|
55
|
+
file.batch(() => {
|
|
56
|
+
sheet.frozenRowCount(0);
|
|
57
|
+
sheet.frozenColumnCount(0);
|
|
58
|
+
});
|
|
14
59
|
ok({ operation: "unfreeze" });
|
|
15
60
|
return;
|
|
16
61
|
}
|
|
17
62
|
if (op === "freeze") {
|
|
18
63
|
if (!options.ref)
|
|
19
64
|
fail("freeze requires --ref (e.g. --ref 2 for rows or --ref C for columns)");
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
65
|
+
const ref = qualified?.localRef ?? options.ref;
|
|
66
|
+
file.batch(() => {
|
|
67
|
+
if (dim === "rows") {
|
|
68
|
+
sheet.frozenRowCount(parseRowRef(ref));
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
sheet.frozenColumnCount(parseColumnRef(ref) + 1);
|
|
72
|
+
}
|
|
73
|
+
});
|
|
26
74
|
ok({ operation: "freeze", dimension: dim, ref: options.ref });
|
|
27
75
|
return;
|
|
28
76
|
}
|
|
29
77
|
if (!options.ref)
|
|
30
78
|
fail(`${op} requires --ref`);
|
|
31
79
|
const count = options.count ?? 1;
|
|
80
|
+
if (!Number.isInteger(count) || count <= 0) {
|
|
81
|
+
fail(`Invalid --count value: ${options.count}`);
|
|
82
|
+
}
|
|
83
|
+
const localRef = qualified?.localRef ?? options.ref;
|
|
32
84
|
const isRow = dim === "rows";
|
|
33
85
|
const index = isRow
|
|
34
|
-
?
|
|
35
|
-
:
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
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++) {
|
|
86
|
+
? parseRowRef(localRef) - 1
|
|
87
|
+
: parseColumnRef(localRef);
|
|
88
|
+
file.batch(() => {
|
|
89
|
+
switch (op) {
|
|
90
|
+
case "insert":
|
|
55
91
|
if (isRow) {
|
|
56
|
-
sheet.
|
|
92
|
+
sheet.addRows(index, count);
|
|
57
93
|
}
|
|
58
94
|
else {
|
|
59
|
-
sheet.
|
|
95
|
+
sheet.addColumns(index, count);
|
|
60
96
|
}
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
case "unhide":
|
|
64
|
-
for (let i = 0; i < count; i++) {
|
|
97
|
+
break;
|
|
98
|
+
case "delete":
|
|
65
99
|
if (isRow) {
|
|
66
|
-
sheet.
|
|
100
|
+
sheet.deleteRows(index, count);
|
|
67
101
|
}
|
|
68
102
|
else {
|
|
69
|
-
sheet.
|
|
103
|
+
sheet.deleteColumns(index, count);
|
|
70
104
|
}
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
105
|
+
break;
|
|
106
|
+
case "hide":
|
|
107
|
+
for (let i = 0; i < count; i++) {
|
|
108
|
+
throwIfAborted(signal);
|
|
109
|
+
if (isRow) {
|
|
110
|
+
sheet.setRowVisible(index + i, false);
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
sheet.setColumnVisible(index + i, false);
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
break;
|
|
117
|
+
case "unhide":
|
|
118
|
+
for (let i = 0; i < count; i++) {
|
|
119
|
+
throwIfAborted(signal);
|
|
120
|
+
if (isRow) {
|
|
121
|
+
sheet.setRowVisible(index + i, true);
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
sheet.setColumnVisible(index + i, true);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
});
|
|
74
130
|
ok({ operation: op, dimension: dim, ref: options.ref, count });
|
|
75
|
-
}, { save: true });
|
|
131
|
+
}, { save: true, signal });
|
|
76
132
|
}
|
|
77
133
|
//# sourceMappingURL=rows-cols.js.map
|