@achmadya-dev/mcp-excel-query 0.3.0
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/LICENSE +21 -0
- package/README.md +123 -0
- package/dist/excel/cell.d.ts +12 -0
- package/dist/excel/cell.d.ts.map +1 -0
- package/dist/excel/cell.js +136 -0
- package/dist/excel/cell.js.map +1 -0
- package/dist/excel/date.d.ts +6 -0
- package/dist/excel/date.d.ts.map +1 -0
- package/dist/excel/date.js +132 -0
- package/dist/excel/date.js.map +1 -0
- package/dist/excel/excel.d.ts +29 -0
- package/dist/excel/excel.d.ts.map +1 -0
- package/dist/excel/excel.js +94 -0
- package/dist/excel/excel.js.map +1 -0
- package/dist/excel/range.d.ts +15 -0
- package/dist/excel/range.d.ts.map +1 -0
- package/dist/excel/range.js +70 -0
- package/dist/excel/range.js.map +1 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +44 -0
- package/dist/index.js.map +1 -0
- package/dist/tools/excel_copy_range.d.ts +2 -0
- package/dist/tools/excel_copy_range.d.ts.map +1 -0
- package/dist/tools/excel_copy_range.js +56 -0
- package/dist/tools/excel_copy_range.js.map +1 -0
- package/dist/tools/excel_copy_sheet.d.ts +2 -0
- package/dist/tools/excel_copy_sheet.d.ts.map +1 -0
- package/dist/tools/excel_copy_sheet.js +56 -0
- package/dist/tools/excel_copy_sheet.js.map +1 -0
- package/dist/tools/excel_create_file.d.ts +2 -0
- package/dist/tools/excel_create_file.d.ts.map +1 -0
- package/dist/tools/excel_create_file.js +31 -0
- package/dist/tools/excel_create_file.js.map +1 -0
- package/dist/tools/excel_create_table.d.ts +2 -0
- package/dist/tools/excel_create_table.d.ts.map +1 -0
- package/dist/tools/excel_create_table.js +73 -0
- package/dist/tools/excel_create_table.js.map +1 -0
- package/dist/tools/excel_delete_range.d.ts +2 -0
- package/dist/tools/excel_delete_range.d.ts.map +1 -0
- package/dist/tools/excel_delete_range.js +55 -0
- package/dist/tools/excel_delete_range.js.map +1 -0
- package/dist/tools/excel_delete_sheet.d.ts +2 -0
- package/dist/tools/excel_delete_sheet.d.ts.map +1 -0
- package/dist/tools/excel_delete_sheet.js +32 -0
- package/dist/tools/excel_delete_sheet.js.map +1 -0
- package/dist/tools/excel_format_range.d.ts +2 -0
- package/dist/tools/excel_format_range.d.ts.map +1 -0
- package/dist/tools/excel_format_range.js +157 -0
- package/dist/tools/excel_format_range.js.map +1 -0
- package/dist/tools/excel_get_metadata.d.ts +2 -0
- package/dist/tools/excel_get_metadata.d.ts.map +1 -0
- package/dist/tools/excel_get_metadata.js +71 -0
- package/dist/tools/excel_get_metadata.js.map +1 -0
- package/dist/tools/excel_insert_columns.d.ts +2 -0
- package/dist/tools/excel_insert_columns.d.ts.map +1 -0
- package/dist/tools/excel_insert_columns.js +44 -0
- package/dist/tools/excel_insert_columns.js.map +1 -0
- package/dist/tools/excel_insert_rows.d.ts +2 -0
- package/dist/tools/excel_insert_rows.d.ts.map +1 -0
- package/dist/tools/excel_insert_rows.js +39 -0
- package/dist/tools/excel_insert_rows.js.map +1 -0
- package/dist/tools/excel_read_sheet.d.ts +2 -0
- package/dist/tools/excel_read_sheet.d.ts.map +1 -0
- package/dist/tools/excel_read_sheet.js +147 -0
- package/dist/tools/excel_read_sheet.js.map +1 -0
- package/dist/tools/excel_rename_sheet.d.ts +2 -0
- package/dist/tools/excel_rename_sheet.d.ts.map +1 -0
- package/dist/tools/excel_rename_sheet.js +37 -0
- package/dist/tools/excel_rename_sheet.js.map +1 -0
- package/dist/tools/excel_set_data_validation.d.ts +2 -0
- package/dist/tools/excel_set_data_validation.d.ts.map +1 -0
- package/dist/tools/excel_set_data_validation.js +126 -0
- package/dist/tools/excel_set_data_validation.js.map +1 -0
- package/dist/tools/excel_set_dimensions.d.ts +2 -0
- package/dist/tools/excel_set_dimensions.d.ts.map +1 -0
- package/dist/tools/excel_set_dimensions.js +134 -0
- package/dist/tools/excel_set_dimensions.js.map +1 -0
- package/dist/tools/excel_set_sheet_visibility.d.ts +2 -0
- package/dist/tools/excel_set_sheet_visibility.d.ts.map +1 -0
- package/dist/tools/excel_set_sheet_visibility.js +39 -0
- package/dist/tools/excel_set_sheet_visibility.js.map +1 -0
- package/dist/tools/excel_unmerge_cells.d.ts +2 -0
- package/dist/tools/excel_unmerge_cells.d.ts.map +1 -0
- package/dist/tools/excel_unmerge_cells.js +42 -0
- package/dist/tools/excel_unmerge_cells.js.map +1 -0
- package/dist/tools/excel_write_range.d.ts +2 -0
- package/dist/tools/excel_write_range.d.ts.map +1 -0
- package/dist/tools/excel_write_range.js +156 -0
- package/dist/tools/excel_write_range.js.map +1 -0
- package/package.json +54 -0
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
import { defineTool, ToolError } from "@achmadya-dev/mcp-core";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
import { Cell } from "../excel/cell.js";
|
|
4
|
+
import { Excel } from "../excel/excel.js";
|
|
5
|
+
const filePathField = z.string().describe("Absolute path to the local Excel file (.xlsx)");
|
|
6
|
+
const sheetNameOptional = z
|
|
7
|
+
.string()
|
|
8
|
+
.optional()
|
|
9
|
+
.describe("Name of the worksheet (defaults to the first sheet)");
|
|
10
|
+
const borderSideSchema = z
|
|
11
|
+
.object({
|
|
12
|
+
style: z.string().optional(),
|
|
13
|
+
color: z.string().optional(),
|
|
14
|
+
})
|
|
15
|
+
.optional();
|
|
16
|
+
const cellStyleSchema = z.object({
|
|
17
|
+
font: z
|
|
18
|
+
.object({
|
|
19
|
+
name: z.string().optional(),
|
|
20
|
+
size: z.number().optional(),
|
|
21
|
+
bold: z.boolean().optional(),
|
|
22
|
+
italic: z.boolean().optional(),
|
|
23
|
+
underline: z.boolean().optional(),
|
|
24
|
+
color: z.string().optional(),
|
|
25
|
+
})
|
|
26
|
+
.optional(),
|
|
27
|
+
fill: z
|
|
28
|
+
.object({
|
|
29
|
+
type: z.enum(["pattern", "gradient"]).optional(),
|
|
30
|
+
pattern: z.string().optional(),
|
|
31
|
+
fgColor: z.string().optional(),
|
|
32
|
+
bgColor: z.string().optional(),
|
|
33
|
+
})
|
|
34
|
+
.optional(),
|
|
35
|
+
alignment: z
|
|
36
|
+
.object({
|
|
37
|
+
horizontal: z.enum(["left", "center", "right", "justify", "distributed"]).optional(),
|
|
38
|
+
vertical: z.enum(["top", "middle", "bottom", "justify", "distributed"]).optional(),
|
|
39
|
+
wrapText: z.boolean().optional(),
|
|
40
|
+
})
|
|
41
|
+
.optional(),
|
|
42
|
+
border: z
|
|
43
|
+
.object({
|
|
44
|
+
top: borderSideSchema,
|
|
45
|
+
left: borderSideSchema,
|
|
46
|
+
bottom: borderSideSchema,
|
|
47
|
+
right: borderSideSchema,
|
|
48
|
+
})
|
|
49
|
+
.optional(),
|
|
50
|
+
numFmt: z.string().optional(),
|
|
51
|
+
});
|
|
52
|
+
const formatRangeInputSchema = z.object({
|
|
53
|
+
filePath: filePathField,
|
|
54
|
+
sheetName: sheetNameOptional,
|
|
55
|
+
startCell: z.string(),
|
|
56
|
+
endCell: z.string().optional(),
|
|
57
|
+
range: z.string().optional(),
|
|
58
|
+
bold: z.boolean().optional(),
|
|
59
|
+
italic: z.boolean().optional(),
|
|
60
|
+
underline: z.boolean().optional(),
|
|
61
|
+
fontSize: z.number().optional(),
|
|
62
|
+
fontColor: z.string().optional(),
|
|
63
|
+
bgColor: z.string().optional(),
|
|
64
|
+
borderStyle: z.string().optional(),
|
|
65
|
+
borderColor: z.string().optional(),
|
|
66
|
+
numberFormat: z.string().optional(),
|
|
67
|
+
alignment: z.string().optional(),
|
|
68
|
+
wrapText: z.boolean().optional(),
|
|
69
|
+
mergeCells: z.boolean().optional().describe("Merge the range while applying format"),
|
|
70
|
+
styles: z.array(z.array(cellStyleSchema.nullable())).optional(),
|
|
71
|
+
});
|
|
72
|
+
const operationResultOutputShape = z.object({
|
|
73
|
+
success: z.boolean(),
|
|
74
|
+
message: z.string(),
|
|
75
|
+
});
|
|
76
|
+
export const excel_format_range = defineTool({
|
|
77
|
+
name: "excel_format_range",
|
|
78
|
+
description: "Format a cell range (font, fill, border, alignment, numFmt). Set mergeCells:true to merge. Use for styling after excel_write_range.",
|
|
79
|
+
inputSchema: formatRangeInputSchema,
|
|
80
|
+
outputSchema: operationResultOutputShape,
|
|
81
|
+
handler: async (args) => {
|
|
82
|
+
try {
|
|
83
|
+
const excel = await Excel.open(args.filePath);
|
|
84
|
+
const sheet = excel.sheet(args.sheetName);
|
|
85
|
+
const bounds = args.range
|
|
86
|
+
? sheet.range(args.range)
|
|
87
|
+
: args.endCell
|
|
88
|
+
? sheet.range(args.startCell, args.endCell)
|
|
89
|
+
: sheet.range(args.startCell);
|
|
90
|
+
const worksheet = sheet.raw;
|
|
91
|
+
const flatStyle = {};
|
|
92
|
+
if (args.bold !== undefined ||
|
|
93
|
+
args.italic !== undefined ||
|
|
94
|
+
args.underline !== undefined ||
|
|
95
|
+
args.fontSize !== undefined ||
|
|
96
|
+
args.fontColor) {
|
|
97
|
+
flatStyle.font = {
|
|
98
|
+
...(args.bold !== undefined ? { bold: args.bold } : {}),
|
|
99
|
+
...(args.italic !== undefined ? { italic: args.italic } : {}),
|
|
100
|
+
...(args.underline !== undefined ? { underline: args.underline } : {}),
|
|
101
|
+
...(args.fontSize !== undefined ? { size: args.fontSize } : {}),
|
|
102
|
+
...(args.fontColor ? { color: args.fontColor } : {}),
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
if (args.bgColor) {
|
|
106
|
+
flatStyle.fill = { fgColor: args.bgColor };
|
|
107
|
+
}
|
|
108
|
+
if (args.borderStyle) {
|
|
109
|
+
const side = {
|
|
110
|
+
style: args.borderStyle,
|
|
111
|
+
...(args.borderColor ? { color: args.borderColor } : {}),
|
|
112
|
+
};
|
|
113
|
+
flatStyle.border = { top: side, left: side, bottom: side, right: side };
|
|
114
|
+
}
|
|
115
|
+
if (args.alignment || args.wrapText !== undefined) {
|
|
116
|
+
flatStyle.alignment = {
|
|
117
|
+
...(args.alignment ? { horizontal: args.alignment } : {}),
|
|
118
|
+
...(args.wrapText !== undefined ? { wrapText: args.wrapText } : {}),
|
|
119
|
+
};
|
|
120
|
+
}
|
|
121
|
+
if (args.numberFormat) {
|
|
122
|
+
flatStyle.numFmt = args.numberFormat;
|
|
123
|
+
}
|
|
124
|
+
const rowCount = bounds.endRow - bounds.startRow + 1;
|
|
125
|
+
const colCount = bounds.endCol - bounds.startCol + 1;
|
|
126
|
+
if (args.mergeCells) {
|
|
127
|
+
worksheet.mergeCells(bounds.startRow, bounds.startCol, bounds.endRow, bounds.endCol);
|
|
128
|
+
}
|
|
129
|
+
for (let r = 0; r < rowCount; r++) {
|
|
130
|
+
for (let c = 0; c < colCount; c++) {
|
|
131
|
+
const cell = worksheet.getCell(bounds.startRow + r, bounds.startCol + c);
|
|
132
|
+
let styleToApply = flatStyle;
|
|
133
|
+
if (args.styles) {
|
|
134
|
+
const gridStyle = args.styles[r]?.[c];
|
|
135
|
+
if (gridStyle === null)
|
|
136
|
+
continue;
|
|
137
|
+
if (gridStyle)
|
|
138
|
+
styleToApply = gridStyle;
|
|
139
|
+
}
|
|
140
|
+
if (styleToApply && Object.keys(styleToApply).length > 0) {
|
|
141
|
+
Cell.applyStyle(cell, styleToApply);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
await excel.save();
|
|
146
|
+
return {
|
|
147
|
+
success: true,
|
|
148
|
+
message: `Formatted range ${bounds.startRow},${bounds.startCol}:${bounds.endRow},${bounds.endCol} on sheet '${worksheet.name}'`,
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
catch (error) {
|
|
152
|
+
const msg = error instanceof Error ? error.message : String(error);
|
|
153
|
+
throw new ToolError("Failed to format range: " + msg);
|
|
154
|
+
}
|
|
155
|
+
},
|
|
156
|
+
});
|
|
157
|
+
//# sourceMappingURL=excel_format_range.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excel_format_range.js","sourceRoot":"","sources":["../../src/tools/excel_format_range.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excel_get_metadata.d.ts","sourceRoot":"","sources":["../../src/tools/excel_get_metadata.ts"],"names":[],"mappings":"AA8BA,eAAO,MAAM,kBAAkB,mDAgD7B,CAAC"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { defineTool, ToolError } from "@achmadya-dev/mcp-core";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
import { Excel } from "../excel/excel.js";
|
|
4
|
+
import { Range } from "../excel/range.js";
|
|
5
|
+
const filePathField = z.string().describe("Absolute path to the local Excel file (.xlsx)");
|
|
6
|
+
const getMetadataInputSchema = z.object({
|
|
7
|
+
filePath: filePathField,
|
|
8
|
+
includeRanges: z.boolean().optional().describe("Include usedRange and mergedCells per sheet"),
|
|
9
|
+
});
|
|
10
|
+
const getMetadataOutputShape = z.object({
|
|
11
|
+
filePath: z.string(),
|
|
12
|
+
creator: z.string().nullable(),
|
|
13
|
+
lastModifiedBy: z.string().nullable(),
|
|
14
|
+
created: z.string().nullable(),
|
|
15
|
+
modified: z.string().nullable(),
|
|
16
|
+
sheets: z.array(z.object({
|
|
17
|
+
name: z.string(),
|
|
18
|
+
rowCount: z.number(),
|
|
19
|
+
columnCount: z.number(),
|
|
20
|
+
state: z.enum(["visible", "hidden", "veryHidden"]).optional(),
|
|
21
|
+
usedRange: z.string().nullable().optional(),
|
|
22
|
+
mergedCells: z.array(z.string()).optional(),
|
|
23
|
+
})),
|
|
24
|
+
});
|
|
25
|
+
export const excel_get_metadata = defineTool({
|
|
26
|
+
name: "excel_get_metadata",
|
|
27
|
+
description: "Workbook metadata: sheet names, dimensions, creator, dates. Use includeRanges for usedRange and mergedCells per sheet (replaces list_sheets).",
|
|
28
|
+
inputSchema: getMetadataInputSchema,
|
|
29
|
+
outputSchema: getMetadataOutputShape,
|
|
30
|
+
handler: async (args) => {
|
|
31
|
+
try {
|
|
32
|
+
const { filePath, includeRanges = false } = args;
|
|
33
|
+
const excel = await Excel.open(filePath);
|
|
34
|
+
const workbook = excel.workbook;
|
|
35
|
+
const sheets = workbook.worksheets.map((ws) => {
|
|
36
|
+
const base = {
|
|
37
|
+
name: ws.name,
|
|
38
|
+
rowCount: ws.rowCount,
|
|
39
|
+
columnCount: ws.actualColumnCount || 0,
|
|
40
|
+
state: ws.state ?? "visible",
|
|
41
|
+
};
|
|
42
|
+
if (!includeRanges)
|
|
43
|
+
return base;
|
|
44
|
+
let usedRange = null;
|
|
45
|
+
if (ws.rowCount > 0 && (ws.actualColumnCount || 0) > 0) {
|
|
46
|
+
usedRange = Range.toA1({
|
|
47
|
+
startRow: 1,
|
|
48
|
+
startCol: 1,
|
|
49
|
+
endRow: ws.rowCount,
|
|
50
|
+
endCol: ws.actualColumnCount || 1,
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
const mergedCells = (ws.model.merges ?? []).map((m) => String(m));
|
|
54
|
+
return { ...base, usedRange, mergedCells };
|
|
55
|
+
});
|
|
56
|
+
return {
|
|
57
|
+
filePath,
|
|
58
|
+
creator: workbook.creator || null,
|
|
59
|
+
lastModifiedBy: workbook.lastModifiedBy || null,
|
|
60
|
+
created: workbook.created ? workbook.created.toISOString() : null,
|
|
61
|
+
modified: workbook.modified ? workbook.modified.toISOString() : null,
|
|
62
|
+
sheets,
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
catch (error) {
|
|
66
|
+
const msg = error instanceof Error ? error.message : String(error);
|
|
67
|
+
throw new ToolError("Failed to get metadata: " + msg);
|
|
68
|
+
}
|
|
69
|
+
},
|
|
70
|
+
});
|
|
71
|
+
//# sourceMappingURL=excel_get_metadata.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excel_get_metadata.js","sourceRoot":"","sources":["../../src/tools/excel_get_metadata.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excel_insert_columns.d.ts","sourceRoot":"","sources":["../../src/tools/excel_insert_columns.ts"],"names":[],"mappings":"AAuBA,eAAO,MAAM,oBAAoB,mDAyB/B,CAAC"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { defineTool, ToolError } from "@achmadya-dev/mcp-core";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
import { Excel } from "../excel/excel.js";
|
|
4
|
+
const filePathField = z.string().describe("Absolute path to the local Excel file (.xlsx)");
|
|
5
|
+
const sheetNameOptional = z
|
|
6
|
+
.string()
|
|
7
|
+
.optional()
|
|
8
|
+
.describe("Name of the worksheet (defaults to the first sheet)");
|
|
9
|
+
const insertColumnsInputSchema = z.object({
|
|
10
|
+
filePath: filePathField,
|
|
11
|
+
sheetName: sheetNameOptional,
|
|
12
|
+
startCol: z.number(),
|
|
13
|
+
count: z.number().optional(),
|
|
14
|
+
});
|
|
15
|
+
const operationResultOutputShape = z.object({
|
|
16
|
+
success: z.boolean(),
|
|
17
|
+
message: z.string(),
|
|
18
|
+
});
|
|
19
|
+
export const excel_insert_columns = defineTool({
|
|
20
|
+
name: "excel_insert_columns",
|
|
21
|
+
description: "Insert empty columns at a 1-based column index.",
|
|
22
|
+
inputSchema: insertColumnsInputSchema,
|
|
23
|
+
outputSchema: operationResultOutputShape,
|
|
24
|
+
handler: async (args) => {
|
|
25
|
+
try {
|
|
26
|
+
const { filePath, sheetName, startCol, count = 1 } = args;
|
|
27
|
+
const excel = await Excel.open(filePath);
|
|
28
|
+
const sheet = excel.sheet(sheetName);
|
|
29
|
+
sheet.raw.eachRow((row) => {
|
|
30
|
+
row.splice(startCol, 0, ...Array(count).fill(null));
|
|
31
|
+
});
|
|
32
|
+
await excel.save();
|
|
33
|
+
return {
|
|
34
|
+
success: true,
|
|
35
|
+
message: `Inserted ${count} column(s) at column ${startCol}`,
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
catch (error) {
|
|
39
|
+
const msg = error instanceof Error ? error.message : String(error);
|
|
40
|
+
throw new ToolError("Failed to insert columns: " + msg);
|
|
41
|
+
}
|
|
42
|
+
},
|
|
43
|
+
});
|
|
44
|
+
//# sourceMappingURL=excel_insert_columns.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excel_insert_columns.js","sourceRoot":"","sources":["../../src/tools/excel_insert_columns.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAE1C,MAAM,aAAa,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,+CAA+C,CAAC,CAAC;AAE3F,MAAM,iBAAiB,GAAG,CAAC;KACxB,MAAM,EAAE;KACR,QAAQ,EAAE;KACV,QAAQ,CAAC,qDAAqD,CAAC,CAAC;AAEnE,MAAM,wBAAwB,GAAG,CAAC,CAAC,MAAM,CAAC;IACxC,QAAQ,EAAE,aAAa;IACvB,SAAS,EAAE,iBAAiB;IAC5B,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE;IACpB,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CAC7B,CAAC,CAAC;AAEH,MAAM,0BAA0B,GAAG,CAAC,CAAC,MAAM,CAAC;IAC1C,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE;IACpB,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE;CACpB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,oBAAoB,GAAG,UAAU,CAAC;IAC7C,IAAI,EAAE,sBAAsB;IAC5B,WAAW,EAAE,iDAAiD;IAC9D,WAAW,EAAE,wBAAwB;IACrC,YAAY,EAAE,0BAA0B;IACxC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;QACtB,IAAI,CAAC;YACH,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,GAAG,CAAC,EAAE,GAAG,IAAI,CAAC;YAC1D,MAAM,KAAK,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACzC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YAErC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;gBACxB,GAAG,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;YACtD,CAAC,CAAC,CAAC;YAEH,MAAM,KAAK,CAAC,IAAI,EAAE,CAAC;YACnB,OAAO;gBACL,OAAO,EAAE,IAAa;gBACtB,OAAO,EAAE,YAAY,KAAK,wBAAwB,QAAQ,EAAE;aAC7D,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,GAAG,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACnE,MAAM,IAAI,SAAS,CAAC,4BAA4B,GAAG,GAAG,CAAC,CAAC;QAC1D,CAAC;IACH,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excel_insert_rows.d.ts","sourceRoot":"","sources":["../../src/tools/excel_insert_rows.ts"],"names":[],"mappings":"AAuBA,eAAO,MAAM,iBAAiB,mDAkB5B,CAAC"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { defineTool, ToolError } from "@achmadya-dev/mcp-core";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
import { Excel } from "../excel/excel.js";
|
|
4
|
+
const filePathField = z.string().describe("Absolute path to the local Excel file (.xlsx)");
|
|
5
|
+
const sheetNameOptional = z
|
|
6
|
+
.string()
|
|
7
|
+
.optional()
|
|
8
|
+
.describe("Name of the worksheet (defaults to the first sheet)");
|
|
9
|
+
const insertRowsInputSchema = z.object({
|
|
10
|
+
filePath: filePathField,
|
|
11
|
+
sheetName: sheetNameOptional,
|
|
12
|
+
startRow: z.number(),
|
|
13
|
+
count: z.number().optional(),
|
|
14
|
+
});
|
|
15
|
+
const operationResultOutputShape = z.object({
|
|
16
|
+
success: z.boolean(),
|
|
17
|
+
message: z.string(),
|
|
18
|
+
});
|
|
19
|
+
export const excel_insert_rows = defineTool({
|
|
20
|
+
name: "excel_insert_rows",
|
|
21
|
+
description: "Insert empty rows at a 1-based row index.",
|
|
22
|
+
inputSchema: insertRowsInputSchema,
|
|
23
|
+
outputSchema: operationResultOutputShape,
|
|
24
|
+
handler: async (args) => {
|
|
25
|
+
try {
|
|
26
|
+
const { filePath, sheetName, startRow, count = 1 } = args;
|
|
27
|
+
const excel = await Excel.open(filePath);
|
|
28
|
+
const sheet = excel.sheet(sheetName);
|
|
29
|
+
sheet.raw.spliceRows(startRow, 0, ...Array.from({ length: count }, () => []));
|
|
30
|
+
await excel.save();
|
|
31
|
+
return { success: true, message: `Inserted ${count} row(s) at row ${startRow}` };
|
|
32
|
+
}
|
|
33
|
+
catch (error) {
|
|
34
|
+
const msg = error instanceof Error ? error.message : String(error);
|
|
35
|
+
throw new ToolError("Failed to insert rows: " + msg);
|
|
36
|
+
}
|
|
37
|
+
},
|
|
38
|
+
});
|
|
39
|
+
//# sourceMappingURL=excel_insert_rows.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excel_insert_rows.js","sourceRoot":"","sources":["../../src/tools/excel_insert_rows.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAE1C,MAAM,aAAa,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,+CAA+C,CAAC,CAAC;AAE3F,MAAM,iBAAiB,GAAG,CAAC;KACxB,MAAM,EAAE;KACR,QAAQ,EAAE;KACV,QAAQ,CAAC,qDAAqD,CAAC,CAAC;AAEnE,MAAM,qBAAqB,GAAG,CAAC,CAAC,MAAM,CAAC;IACrC,QAAQ,EAAE,aAAa;IACvB,SAAS,EAAE,iBAAiB;IAC5B,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE;IACpB,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CAC7B,CAAC,CAAC;AAEH,MAAM,0BAA0B,GAAG,CAAC,CAAC,MAAM,CAAC;IAC1C,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE;IACpB,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE;CACpB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,iBAAiB,GAAG,UAAU,CAAC;IAC1C,IAAI,EAAE,mBAAmB;IACzB,WAAW,EAAE,2CAA2C;IACxD,WAAW,EAAE,qBAAqB;IAClC,YAAY,EAAE,0BAA0B;IACxC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;QACtB,IAAI,CAAC;YACH,MAAM,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,GAAG,CAAC,EAAE,GAAG,IAAI,CAAC;YAC1D,MAAM,KAAK,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACzC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YACrC,KAAK,CAAC,GAAG,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC,EAAE,GAAG,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;YAC9E,MAAM,KAAK,CAAC,IAAI,EAAE,CAAC;YACnB,OAAO,EAAE,OAAO,EAAE,IAAa,EAAE,OAAO,EAAE,YAAY,KAAK,kBAAkB,QAAQ,EAAE,EAAE,CAAC;QAC5F,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,GAAG,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACnE,MAAM,IAAI,SAAS,CAAC,yBAAyB,GAAG,GAAG,CAAC,CAAC;QACvD,CAAC;IACH,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excel_read_sheet.d.ts","sourceRoot":"","sources":["../../src/tools/excel_read_sheet.ts"],"names":[],"mappings":"AA4DA,eAAO,MAAM,gBAAgB,mDAiI3B,CAAC"}
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
import { defineTool, ToolError } from "@achmadya-dev/mcp-core";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
import { Cell } from "../excel/cell.js";
|
|
4
|
+
import { Excel } from "../excel/excel.js";
|
|
5
|
+
import { Range } from "../excel/range.js";
|
|
6
|
+
const filePathField = z.string().describe("Absolute path to the local Excel file (.xlsx)");
|
|
7
|
+
const sheetNameOptional = z
|
|
8
|
+
.string()
|
|
9
|
+
.optional()
|
|
10
|
+
.describe("Name of the worksheet (defaults to the first sheet)");
|
|
11
|
+
const readSheetInputSchema = z.object({
|
|
12
|
+
filePath: filePathField,
|
|
13
|
+
sheetName: sheetNameOptional,
|
|
14
|
+
range: z.string().optional().describe("Cell range in A1 notation (e.g., 'A1:C10')"),
|
|
15
|
+
startCell: z.string().optional(),
|
|
16
|
+
endCell: z.string().optional(),
|
|
17
|
+
headerRow: z
|
|
18
|
+
.number()
|
|
19
|
+
.optional()
|
|
20
|
+
.describe("Row number containing headers, 1-indexed (defaults to 1). Set to 0 if there are no headers."),
|
|
21
|
+
limit: z.number().optional(),
|
|
22
|
+
offset: z.number().optional(),
|
|
23
|
+
showFormula: z.boolean().optional(),
|
|
24
|
+
showStyle: z.boolean().optional(),
|
|
25
|
+
previewOnly: z.boolean().optional(),
|
|
26
|
+
dateFormat: z
|
|
27
|
+
.string()
|
|
28
|
+
.optional()
|
|
29
|
+
.describe('Format date cells for output. Use Excel-style tokens (e.g. "dd mmm yyyy") or "cell" to use each cell numFmt. Defaults to ISO when omitted.'),
|
|
30
|
+
});
|
|
31
|
+
const readSheetOutputShape = z.object({
|
|
32
|
+
sheetName: z.string(),
|
|
33
|
+
headers: z.array(z.string()).nullable(),
|
|
34
|
+
rows: z.array(z.record(z.string(), z.any())),
|
|
35
|
+
totalRows: z.number(),
|
|
36
|
+
mergedCells: z.array(z.string()).optional(),
|
|
37
|
+
previewOnly: z.boolean().optional(),
|
|
38
|
+
});
|
|
39
|
+
function buildRangeFromParams(range, startCell, endCell) {
|
|
40
|
+
if (range)
|
|
41
|
+
return range;
|
|
42
|
+
if (startCell && endCell)
|
|
43
|
+
return `${startCell}:${endCell}`;
|
|
44
|
+
if (startCell)
|
|
45
|
+
return startCell;
|
|
46
|
+
return undefined;
|
|
47
|
+
}
|
|
48
|
+
export const excel_read_sheet = defineTool({
|
|
49
|
+
name: "excel_read_sheet",
|
|
50
|
+
description: "Read worksheet data as JSON rows. Supports range, pagination, showFormula, showStyle, dateFormat (or dateFormat: cell for per-cell numFmt). Returns mergedCells and per-cell validation metadata when present.",
|
|
51
|
+
inputSchema: readSheetInputSchema,
|
|
52
|
+
outputSchema: readSheetOutputShape,
|
|
53
|
+
handler: async (args) => {
|
|
54
|
+
try {
|
|
55
|
+
const { filePath, sheetName, headerRow = 1, limit, offset, showFormula = false, showStyle = false, previewOnly = false, dateFormat, } = args;
|
|
56
|
+
const rangeStr = buildRangeFromParams(args.range, args.startCell, args.endCell);
|
|
57
|
+
const excel = await Excel.open(filePath);
|
|
58
|
+
const sheet = excel.sheet(sheetName);
|
|
59
|
+
const worksheet = sheet.raw;
|
|
60
|
+
let startRow = 1;
|
|
61
|
+
let endRow = worksheet.rowCount;
|
|
62
|
+
let startCol = 1;
|
|
63
|
+
let endCol = worksheet.actualColumnCount || 1;
|
|
64
|
+
if (rangeStr) {
|
|
65
|
+
const parsedRange = Range.parse(rangeStr);
|
|
66
|
+
startRow = parsedRange.startRow;
|
|
67
|
+
endRow = parsedRange.endRow;
|
|
68
|
+
startCol = parsedRange.startCol;
|
|
69
|
+
endCol = parsedRange.endCol;
|
|
70
|
+
}
|
|
71
|
+
const cellCount = (endRow - startRow + 1) * (endCol - startCol + 1);
|
|
72
|
+
const pagingLimit = Excel.pagingLimit();
|
|
73
|
+
if (cellCount > pagingLimit && !previewOnly && limit === undefined) {
|
|
74
|
+
throw new Error(`Range exceeds paging limit (${cellCount} cells > ${pagingLimit}). ` +
|
|
75
|
+
`Use limit/offset, previewOnly, or set EXCEL_PAGING_CELLS_LIMIT.`);
|
|
76
|
+
}
|
|
77
|
+
const headers = [];
|
|
78
|
+
const headerRowIdx = headerRow;
|
|
79
|
+
if (headerRowIdx > 0 && headerRowIdx <= worksheet.rowCount) {
|
|
80
|
+
const row = worksheet.getRow(headerRowIdx);
|
|
81
|
+
for (let c = startCol; c <= endCol; c++) {
|
|
82
|
+
const cellVal = Cell.readDisplay(row.getCell(c).value, showFormula);
|
|
83
|
+
headers.push(cellVal !== null && cellVal !== undefined && cellVal !== ""
|
|
84
|
+
? String(cellVal)
|
|
85
|
+
: Range.colToLetter(c));
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
for (let c = startCol; c <= endCol; c++) {
|
|
90
|
+
headers.push(Range.colToLetter(c));
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
const allRows = [];
|
|
94
|
+
const startDataRow = headerRowIdx > 0 ? Math.max(startRow, headerRowIdx + 1) : startRow;
|
|
95
|
+
const effectiveEndRow = previewOnly ? Math.min(endRow, startDataRow + 9) : endRow;
|
|
96
|
+
for (let r = startDataRow; r <= effectiveEndRow; r++) {
|
|
97
|
+
const row = worksheet.getRow(r);
|
|
98
|
+
const rowData = {};
|
|
99
|
+
let hasValue = false;
|
|
100
|
+
for (let c = startCol; c <= endCol; c++) {
|
|
101
|
+
const excelCell = row.getCell(c);
|
|
102
|
+
const headerKey = headers[c - startCol];
|
|
103
|
+
const cellVal = Cell.readDisplay(excelCell.value, showFormula, {
|
|
104
|
+
dateFormat,
|
|
105
|
+
cellNumFmt: excelCell.numFmt,
|
|
106
|
+
});
|
|
107
|
+
rowData[headerKey] = cellVal;
|
|
108
|
+
if (showStyle) {
|
|
109
|
+
const style = Cell.extractStyle(excelCell);
|
|
110
|
+
if (style) {
|
|
111
|
+
rowData[`__style_${headerKey}`] = JSON.parse(JSON.stringify(style));
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
const validation = excelCell
|
|
115
|
+
.dataValidation;
|
|
116
|
+
if (validation) {
|
|
117
|
+
rowData[`__validation_${headerKey}`] = JSON.parse(JSON.stringify(validation));
|
|
118
|
+
}
|
|
119
|
+
if (cellVal !== null && cellVal !== undefined && cellVal !== "") {
|
|
120
|
+
hasValue = true;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
if (hasValue || rangeStr) {
|
|
124
|
+
allRows.push(rowData);
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
const totalRows = allRows.length;
|
|
128
|
+
const off = offset ?? 0;
|
|
129
|
+
const lim = limit ?? totalRows;
|
|
130
|
+
const paginatedRows = allRows.slice(off, off + lim);
|
|
131
|
+
const mergedCells = (worksheet.model.merges ?? []).map((m) => String(m));
|
|
132
|
+
return {
|
|
133
|
+
sheetName: worksheet.name,
|
|
134
|
+
headers: headerRowIdx > 0 ? headers : null,
|
|
135
|
+
rows: paginatedRows,
|
|
136
|
+
totalRows,
|
|
137
|
+
mergedCells,
|
|
138
|
+
previewOnly,
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
catch (error) {
|
|
142
|
+
const msg = error instanceof Error ? error.message : String(error);
|
|
143
|
+
throw new ToolError("Failed to read sheet: " + msg);
|
|
144
|
+
}
|
|
145
|
+
},
|
|
146
|
+
});
|
|
147
|
+
//# sourceMappingURL=excel_read_sheet.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excel_read_sheet.js","sourceRoot":"","sources":["../../src/tools/excel_read_sheet.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excel_rename_sheet.d.ts","sourceRoot":"","sources":["../../src/tools/excel_rename_sheet.ts"],"names":[],"mappings":"AAiBA,eAAO,MAAM,kBAAkB,mDAuB7B,CAAC"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { defineTool, ToolError } from "@achmadya-dev/mcp-core";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
import { Excel } from "../excel/excel.js";
|
|
4
|
+
const filePathField = z.string().describe("Absolute path to the local Excel file (.xlsx)");
|
|
5
|
+
const renameSheetInputSchema = z.object({
|
|
6
|
+
filePath: filePathField,
|
|
7
|
+
oldName: z.string(),
|
|
8
|
+
newName: z.string(),
|
|
9
|
+
});
|
|
10
|
+
const operationResultOutputShape = z.object({
|
|
11
|
+
success: z.boolean(),
|
|
12
|
+
message: z.string(),
|
|
13
|
+
});
|
|
14
|
+
export const excel_rename_sheet = defineTool({
|
|
15
|
+
name: "excel_rename_sheet",
|
|
16
|
+
description: "Rename a worksheet.",
|
|
17
|
+
inputSchema: renameSheetInputSchema,
|
|
18
|
+
outputSchema: operationResultOutputShape,
|
|
19
|
+
handler: async (args) => {
|
|
20
|
+
try {
|
|
21
|
+
const { filePath, oldName, newName } = args;
|
|
22
|
+
const excel = await Excel.open(filePath);
|
|
23
|
+
const sheet = excel.sheet(oldName);
|
|
24
|
+
if (excel.hasSheet(newName)) {
|
|
25
|
+
throw new Error(`Worksheet already exists: "${newName}"`);
|
|
26
|
+
}
|
|
27
|
+
sheet.raw.name = newName;
|
|
28
|
+
await excel.save();
|
|
29
|
+
return { success: true, message: `Sheet renamed from '${oldName}' to '${newName}'` };
|
|
30
|
+
}
|
|
31
|
+
catch (error) {
|
|
32
|
+
const msg = error instanceof Error ? error.message : String(error);
|
|
33
|
+
throw new ToolError("Failed to rename sheet: " + msg);
|
|
34
|
+
}
|
|
35
|
+
},
|
|
36
|
+
});
|
|
37
|
+
//# sourceMappingURL=excel_rename_sheet.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excel_rename_sheet.js","sourceRoot":"","sources":["../../src/tools/excel_rename_sheet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AAC/D,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAE1C,MAAM,aAAa,GAAG,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,+CAA+C,CAAC,CAAC;AAE3F,MAAM,sBAAsB,GAAG,CAAC,CAAC,MAAM,CAAC;IACtC,QAAQ,EAAE,aAAa;IACvB,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE;IACnB,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE;CACpB,CAAC,CAAC;AAEH,MAAM,0BAA0B,GAAG,CAAC,CAAC,MAAM,CAAC;IAC1C,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE;IACpB,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE;CACpB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,kBAAkB,GAAG,UAAU,CAAC;IAC3C,IAAI,EAAE,oBAAoB;IAC1B,WAAW,EAAE,qBAAqB;IAClC,WAAW,EAAE,sBAAsB;IACnC,YAAY,EAAE,0BAA0B;IACxC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;QACtB,IAAI,CAAC;YACH,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;YAC5C,MAAM,KAAK,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YACzC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAEnC,IAAI,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;gBAC5B,MAAM,IAAI,KAAK,CAAC,8BAA8B,OAAO,GAAG,CAAC,CAAC;YAC5D,CAAC;YAED,KAAK,CAAC,GAAG,CAAC,IAAI,GAAG,OAAO,CAAC;YACzB,MAAM,KAAK,CAAC,IAAI,EAAE,CAAC;YACnB,OAAO,EAAE,OAAO,EAAE,IAAa,EAAE,OAAO,EAAE,uBAAuB,OAAO,SAAS,OAAO,GAAG,EAAE,CAAC;QAChG,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,GAAG,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YACnE,MAAM,IAAI,SAAS,CAAC,0BAA0B,GAAG,GAAG,CAAC,CAAC;QACxD,CAAC;IACH,CAAC;CACF,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"excel_set_data_validation.d.ts","sourceRoot":"","sources":["../../src/tools/excel_set_data_validation.ts"],"names":[],"mappings":"AA4GA,eAAO,MAAM,yBAAyB,mDAgEpC,CAAC"}
|