@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.
Files changed (91) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +123 -0
  3. package/dist/excel/cell.d.ts +12 -0
  4. package/dist/excel/cell.d.ts.map +1 -0
  5. package/dist/excel/cell.js +136 -0
  6. package/dist/excel/cell.js.map +1 -0
  7. package/dist/excel/date.d.ts +6 -0
  8. package/dist/excel/date.d.ts.map +1 -0
  9. package/dist/excel/date.js +132 -0
  10. package/dist/excel/date.js.map +1 -0
  11. package/dist/excel/excel.d.ts +29 -0
  12. package/dist/excel/excel.d.ts.map +1 -0
  13. package/dist/excel/excel.js +94 -0
  14. package/dist/excel/excel.js.map +1 -0
  15. package/dist/excel/range.d.ts +15 -0
  16. package/dist/excel/range.d.ts.map +1 -0
  17. package/dist/excel/range.js +70 -0
  18. package/dist/excel/range.js.map +1 -0
  19. package/dist/index.d.ts +3 -0
  20. package/dist/index.d.ts.map +1 -0
  21. package/dist/index.js +44 -0
  22. package/dist/index.js.map +1 -0
  23. package/dist/tools/excel_copy_range.d.ts +2 -0
  24. package/dist/tools/excel_copy_range.d.ts.map +1 -0
  25. package/dist/tools/excel_copy_range.js +56 -0
  26. package/dist/tools/excel_copy_range.js.map +1 -0
  27. package/dist/tools/excel_copy_sheet.d.ts +2 -0
  28. package/dist/tools/excel_copy_sheet.d.ts.map +1 -0
  29. package/dist/tools/excel_copy_sheet.js +56 -0
  30. package/dist/tools/excel_copy_sheet.js.map +1 -0
  31. package/dist/tools/excel_create_file.d.ts +2 -0
  32. package/dist/tools/excel_create_file.d.ts.map +1 -0
  33. package/dist/tools/excel_create_file.js +31 -0
  34. package/dist/tools/excel_create_file.js.map +1 -0
  35. package/dist/tools/excel_create_table.d.ts +2 -0
  36. package/dist/tools/excel_create_table.d.ts.map +1 -0
  37. package/dist/tools/excel_create_table.js +73 -0
  38. package/dist/tools/excel_create_table.js.map +1 -0
  39. package/dist/tools/excel_delete_range.d.ts +2 -0
  40. package/dist/tools/excel_delete_range.d.ts.map +1 -0
  41. package/dist/tools/excel_delete_range.js +55 -0
  42. package/dist/tools/excel_delete_range.js.map +1 -0
  43. package/dist/tools/excel_delete_sheet.d.ts +2 -0
  44. package/dist/tools/excel_delete_sheet.d.ts.map +1 -0
  45. package/dist/tools/excel_delete_sheet.js +32 -0
  46. package/dist/tools/excel_delete_sheet.js.map +1 -0
  47. package/dist/tools/excel_format_range.d.ts +2 -0
  48. package/dist/tools/excel_format_range.d.ts.map +1 -0
  49. package/dist/tools/excel_format_range.js +157 -0
  50. package/dist/tools/excel_format_range.js.map +1 -0
  51. package/dist/tools/excel_get_metadata.d.ts +2 -0
  52. package/dist/tools/excel_get_metadata.d.ts.map +1 -0
  53. package/dist/tools/excel_get_metadata.js +71 -0
  54. package/dist/tools/excel_get_metadata.js.map +1 -0
  55. package/dist/tools/excel_insert_columns.d.ts +2 -0
  56. package/dist/tools/excel_insert_columns.d.ts.map +1 -0
  57. package/dist/tools/excel_insert_columns.js +44 -0
  58. package/dist/tools/excel_insert_columns.js.map +1 -0
  59. package/dist/tools/excel_insert_rows.d.ts +2 -0
  60. package/dist/tools/excel_insert_rows.d.ts.map +1 -0
  61. package/dist/tools/excel_insert_rows.js +39 -0
  62. package/dist/tools/excel_insert_rows.js.map +1 -0
  63. package/dist/tools/excel_read_sheet.d.ts +2 -0
  64. package/dist/tools/excel_read_sheet.d.ts.map +1 -0
  65. package/dist/tools/excel_read_sheet.js +147 -0
  66. package/dist/tools/excel_read_sheet.js.map +1 -0
  67. package/dist/tools/excel_rename_sheet.d.ts +2 -0
  68. package/dist/tools/excel_rename_sheet.d.ts.map +1 -0
  69. package/dist/tools/excel_rename_sheet.js +37 -0
  70. package/dist/tools/excel_rename_sheet.js.map +1 -0
  71. package/dist/tools/excel_set_data_validation.d.ts +2 -0
  72. package/dist/tools/excel_set_data_validation.d.ts.map +1 -0
  73. package/dist/tools/excel_set_data_validation.js +126 -0
  74. package/dist/tools/excel_set_data_validation.js.map +1 -0
  75. package/dist/tools/excel_set_dimensions.d.ts +2 -0
  76. package/dist/tools/excel_set_dimensions.d.ts.map +1 -0
  77. package/dist/tools/excel_set_dimensions.js +134 -0
  78. package/dist/tools/excel_set_dimensions.js.map +1 -0
  79. package/dist/tools/excel_set_sheet_visibility.d.ts +2 -0
  80. package/dist/tools/excel_set_sheet_visibility.d.ts.map +1 -0
  81. package/dist/tools/excel_set_sheet_visibility.js +39 -0
  82. package/dist/tools/excel_set_sheet_visibility.js.map +1 -0
  83. package/dist/tools/excel_unmerge_cells.d.ts +2 -0
  84. package/dist/tools/excel_unmerge_cells.d.ts.map +1 -0
  85. package/dist/tools/excel_unmerge_cells.js +42 -0
  86. package/dist/tools/excel_unmerge_cells.js.map +1 -0
  87. package/dist/tools/excel_write_range.d.ts +2 -0
  88. package/dist/tools/excel_write_range.d.ts.map +1 -0
  89. package/dist/tools/excel_write_range.js +156 -0
  90. package/dist/tools/excel_write_range.js.map +1 -0
  91. 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,2 @@
1
+ export declare const excel_get_metadata: import("@achmadya-dev/mcp-core").RegisterableTool;
2
+ //# sourceMappingURL=excel_get_metadata.d.ts.map
@@ -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,2 @@
1
+ export declare const excel_insert_columns: import("@achmadya-dev/mcp-core").RegisterableTool;
2
+ //# sourceMappingURL=excel_insert_columns.d.ts.map
@@ -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,2 @@
1
+ export declare const excel_insert_rows: import("@achmadya-dev/mcp-core").RegisterableTool;
2
+ //# sourceMappingURL=excel_insert_rows.d.ts.map
@@ -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,2 @@
1
+ export declare const excel_read_sheet: import("@achmadya-dev/mcp-core").RegisterableTool;
2
+ //# sourceMappingURL=excel_read_sheet.d.ts.map
@@ -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,2 @@
1
+ export declare const excel_rename_sheet: import("@achmadya-dev/mcp-core").RegisterableTool;
2
+ //# sourceMappingURL=excel_rename_sheet.d.ts.map
@@ -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,2 @@
1
+ export declare const excel_set_data_validation: import("@achmadya-dev/mcp-core").RegisterableTool;
2
+ //# sourceMappingURL=excel_set_data_validation.d.ts.map
@@ -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"}