@mcp-z/mcp-sheets 1.0.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 +181 -0
- package/bin/server.js +5 -0
- package/dist/cjs/constants.d.cts +7 -0
- package/dist/cjs/constants.d.ts +7 -0
- package/dist/cjs/constants.js +18 -0
- package/dist/cjs/constants.js.map +1 -0
- package/dist/cjs/index.d.cts +8 -0
- package/dist/cjs/index.d.ts +8 -0
- package/dist/cjs/index.js +314 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/lib/create-store.d.cts +2 -0
- package/dist/cjs/lib/create-store.d.ts +2 -0
- package/dist/cjs/lib/create-store.js +166 -0
- package/dist/cjs/lib/create-store.js.map +1 -0
- package/dist/cjs/mcp/index.d.cts +3 -0
- package/dist/cjs/mcp/index.d.ts +3 -0
- package/dist/cjs/mcp/index.js +66 -0
- package/dist/cjs/mcp/index.js.map +1 -0
- package/dist/cjs/mcp/prompts/a1-notation.d.cts +19 -0
- package/dist/cjs/mcp/prompts/a1-notation.d.ts +19 -0
- package/dist/cjs/mcp/prompts/a1-notation.js +169 -0
- package/dist/cjs/mcp/prompts/a1-notation.js.map +1 -0
- package/dist/cjs/mcp/prompts/index.d.cts +1 -0
- package/dist/cjs/mcp/prompts/index.d.ts +1 -0
- package/dist/cjs/mcp/prompts/index.js +17 -0
- package/dist/cjs/mcp/prompts/index.js.map +1 -0
- package/dist/cjs/mcp/resources/index.d.cts +1 -0
- package/dist/cjs/mcp/resources/index.d.ts +1 -0
- package/dist/cjs/mcp/resources/index.js +17 -0
- package/dist/cjs/mcp/resources/index.js.map +1 -0
- package/dist/cjs/mcp/resources/spreadsheet.d.cts +2 -0
- package/dist/cjs/mcp/resources/spreadsheet.d.ts +2 -0
- package/dist/cjs/mcp/resources/spreadsheet.js +258 -0
- package/dist/cjs/mcp/resources/spreadsheet.js.map +1 -0
- package/dist/cjs/mcp/tools/cells-format.d.cts +144 -0
- package/dist/cjs/mcp/tools/cells-format.d.ts +144 -0
- package/dist/cjs/mcp/tools/cells-format.js +484 -0
- package/dist/cjs/mcp/tools/cells-format.js.map +1 -0
- package/dist/cjs/mcp/tools/chart-create.d.cts +94 -0
- package/dist/cjs/mcp/tools/chart-create.d.ts +94 -0
- package/dist/cjs/mcp/tools/chart-create.js +575 -0
- package/dist/cjs/mcp/tools/chart-create.js.map +1 -0
- package/dist/cjs/mcp/tools/columns-get.d.cts +55 -0
- package/dist/cjs/mcp/tools/columns-get.d.ts +55 -0
- package/dist/cjs/mcp/tools/columns-get.js +289 -0
- package/dist/cjs/mcp/tools/columns-get.js.map +1 -0
- package/dist/cjs/mcp/tools/columns-update.d.cts +86 -0
- package/dist/cjs/mcp/tools/columns-update.d.ts +86 -0
- package/dist/cjs/mcp/tools/columns-update.js +482 -0
- package/dist/cjs/mcp/tools/columns-update.js.map +1 -0
- package/dist/cjs/mcp/tools/csv-get-columns.d.cts +43 -0
- package/dist/cjs/mcp/tools/csv-get-columns.d.ts +43 -0
- package/dist/cjs/mcp/tools/csv-get-columns.js +386 -0
- package/dist/cjs/mcp/tools/csv-get-columns.js.map +1 -0
- package/dist/cjs/mcp/tools/dimensions-batch-update.d.cts +118 -0
- package/dist/cjs/mcp/tools/dimensions-batch-update.d.ts +118 -0
- package/dist/cjs/mcp/tools/dimensions-batch-update.js +504 -0
- package/dist/cjs/mcp/tools/dimensions-batch-update.js.map +1 -0
- package/dist/cjs/mcp/tools/dimensions-move.d.cts +86 -0
- package/dist/cjs/mcp/tools/dimensions-move.d.ts +86 -0
- package/dist/cjs/mcp/tools/dimensions-move.js +359 -0
- package/dist/cjs/mcp/tools/dimensions-move.js.map +1 -0
- package/dist/cjs/mcp/tools/index.d.cts +26 -0
- package/dist/cjs/mcp/tools/index.d.ts +26 -0
- package/dist/cjs/mcp/tools/index.js +122 -0
- package/dist/cjs/mcp/tools/index.js.map +1 -0
- package/dist/cjs/mcp/tools/lib/dimension-operations.d.cts +48 -0
- package/dist/cjs/mcp/tools/lib/dimension-operations.d.ts +48 -0
- package/dist/cjs/mcp/tools/lib/dimension-operations.js +177 -0
- package/dist/cjs/mcp/tools/lib/dimension-operations.js.map +1 -0
- package/dist/cjs/mcp/tools/rows-append.d.cts +58 -0
- package/dist/cjs/mcp/tools/rows-append.d.ts +58 -0
- package/dist/cjs/mcp/tools/rows-append.js +335 -0
- package/dist/cjs/mcp/tools/rows-append.js.map +1 -0
- package/dist/cjs/mcp/tools/rows-csv-append.d.cts +67 -0
- package/dist/cjs/mcp/tools/rows-csv-append.d.ts +67 -0
- package/dist/cjs/mcp/tools/rows-csv-append.js +859 -0
- package/dist/cjs/mcp/tools/rows-csv-append.js.map +1 -0
- package/dist/cjs/mcp/tools/rows-get.d.cts +56 -0
- package/dist/cjs/mcp/tools/rows-get.d.ts +56 -0
- package/dist/cjs/mcp/tools/rows-get.js +292 -0
- package/dist/cjs/mcp/tools/rows-get.js.map +1 -0
- package/dist/cjs/mcp/tools/sheet-copy-to.d.cts +68 -0
- package/dist/cjs/mcp/tools/sheet-copy-to.d.ts +68 -0
- package/dist/cjs/mcp/tools/sheet-copy-to.js +341 -0
- package/dist/cjs/mcp/tools/sheet-copy-to.js.map +1 -0
- package/dist/cjs/mcp/tools/sheet-copy.d.cts +80 -0
- package/dist/cjs/mcp/tools/sheet-copy.d.ts +80 -0
- package/dist/cjs/mcp/tools/sheet-copy.js +394 -0
- package/dist/cjs/mcp/tools/sheet-copy.js.map +1 -0
- package/dist/cjs/mcp/tools/sheet-create.d.cts +56 -0
- package/dist/cjs/mcp/tools/sheet-create.d.ts +56 -0
- package/dist/cjs/mcp/tools/sheet-create.js +283 -0
- package/dist/cjs/mcp/tools/sheet-create.js.map +1 -0
- package/dist/cjs/mcp/tools/sheet-delete.d.cts +62 -0
- package/dist/cjs/mcp/tools/sheet-delete.d.ts +62 -0
- package/dist/cjs/mcp/tools/sheet-delete.js +341 -0
- package/dist/cjs/mcp/tools/sheet-delete.js.map +1 -0
- package/dist/cjs/mcp/tools/sheet-find.d.cts +48 -0
- package/dist/cjs/mcp/tools/sheet-find.d.ts +48 -0
- package/dist/cjs/mcp/tools/sheet-find.js +261 -0
- package/dist/cjs/mcp/tools/sheet-find.js.map +1 -0
- package/dist/cjs/mcp/tools/sheet-rename.d.cts +60 -0
- package/dist/cjs/mcp/tools/sheet-rename.d.ts +60 -0
- package/dist/cjs/mcp/tools/sheet-rename.js +305 -0
- package/dist/cjs/mcp/tools/sheet-rename.js.map +1 -0
- package/dist/cjs/mcp/tools/spreadsheet-copy.d.cts +58 -0
- package/dist/cjs/mcp/tools/spreadsheet-copy.d.ts +58 -0
- package/dist/cjs/mcp/tools/spreadsheet-copy.js +319 -0
- package/dist/cjs/mcp/tools/spreadsheet-copy.js.map +1 -0
- package/dist/cjs/mcp/tools/spreadsheet-create.d.cts +52 -0
- package/dist/cjs/mcp/tools/spreadsheet-create.d.ts +52 -0
- package/dist/cjs/mcp/tools/spreadsheet-create.js +270 -0
- package/dist/cjs/mcp/tools/spreadsheet-create.js.map +1 -0
- package/dist/cjs/mcp/tools/spreadsheet-find.d.cts +58 -0
- package/dist/cjs/mcp/tools/spreadsheet-find.d.ts +58 -0
- package/dist/cjs/mcp/tools/spreadsheet-find.js +334 -0
- package/dist/cjs/mcp/tools/spreadsheet-find.js.map +1 -0
- package/dist/cjs/mcp/tools/spreadsheet-rename.d.cts +56 -0
- package/dist/cjs/mcp/tools/spreadsheet-rename.d.ts +56 -0
- package/dist/cjs/mcp/tools/spreadsheet-rename.js +289 -0
- package/dist/cjs/mcp/tools/spreadsheet-rename.js.map +1 -0
- package/dist/cjs/mcp/tools/validation-set.d.cts +144 -0
- package/dist/cjs/mcp/tools/validation-set.d.ts +144 -0
- package/dist/cjs/mcp/tools/validation-set.js +564 -0
- package/dist/cjs/mcp/tools/validation-set.js.map +1 -0
- package/dist/cjs/mcp/tools/values-batch-update.d.cts +102 -0
- package/dist/cjs/mcp/tools/values-batch-update.d.ts +102 -0
- package/dist/cjs/mcp/tools/values-batch-update.js +409 -0
- package/dist/cjs/mcp/tools/values-batch-update.js.map +1 -0
- package/dist/cjs/mcp/tools/values-clear.d.cts +56 -0
- package/dist/cjs/mcp/tools/values-clear.d.ts +56 -0
- package/dist/cjs/mcp/tools/values-clear.js +308 -0
- package/dist/cjs/mcp/tools/values-clear.js.map +1 -0
- package/dist/cjs/mcp/tools/values-csv-update.d.cts +75 -0
- package/dist/cjs/mcp/tools/values-csv-update.d.ts +75 -0
- package/dist/cjs/mcp/tools/values-csv-update.js +500 -0
- package/dist/cjs/mcp/tools/values-csv-update.js.map +1 -0
- package/dist/cjs/mcp/tools/values-replace.d.cts +68 -0
- package/dist/cjs/mcp/tools/values-replace.d.ts +68 -0
- package/dist/cjs/mcp/tools/values-replace.js +378 -0
- package/dist/cjs/mcp/tools/values-replace.js.map +1 -0
- package/dist/cjs/mcp/tools/values-search.d.cts +74 -0
- package/dist/cjs/mcp/tools/values-search.d.ts +74 -0
- package/dist/cjs/mcp/tools/values-search.js +470 -0
- package/dist/cjs/mcp/tools/values-search.js.map +1 -0
- package/dist/cjs/package.json +1 -0
- package/dist/cjs/schemas/index.d.cts +14 -0
- package/dist/cjs/schemas/index.d.ts +14 -0
- package/dist/cjs/schemas/index.js +64 -0
- package/dist/cjs/schemas/index.js.map +1 -0
- package/dist/cjs/setup/config.d.cts +44 -0
- package/dist/cjs/setup/config.d.ts +44 -0
- package/dist/cjs/setup/config.js +201 -0
- package/dist/cjs/setup/config.js.map +1 -0
- package/dist/cjs/setup/http.d.cts +8 -0
- package/dist/cjs/setup/http.d.ts +8 -0
- package/dist/cjs/setup/http.js +260 -0
- package/dist/cjs/setup/http.js.map +1 -0
- package/dist/cjs/setup/index.d.cts +5 -0
- package/dist/cjs/setup/index.d.ts +5 -0
- package/dist/cjs/setup/index.js +46 -0
- package/dist/cjs/setup/index.js.map +1 -0
- package/dist/cjs/setup/oauth-google.d.cts +54 -0
- package/dist/cjs/setup/oauth-google.d.ts +54 -0
- package/dist/cjs/setup/oauth-google.js +332 -0
- package/dist/cjs/setup/oauth-google.js.map +1 -0
- package/dist/cjs/setup/runtime.d.cts +10 -0
- package/dist/cjs/setup/runtime.d.ts +10 -0
- package/dist/cjs/setup/runtime.js +353 -0
- package/dist/cjs/setup/runtime.js.map +1 -0
- package/dist/cjs/setup/stdio.d.cts +7 -0
- package/dist/cjs/setup/stdio.d.ts +7 -0
- package/dist/cjs/setup/stdio.js +239 -0
- package/dist/cjs/setup/stdio.js.map +1 -0
- package/dist/cjs/spreadsheet/column-utilities.d.cts +1 -0
- package/dist/cjs/spreadsheet/column-utilities.d.ts +1 -0
- package/dist/cjs/spreadsheet/column-utilities.js +21 -0
- package/dist/cjs/spreadsheet/column-utilities.js.map +1 -0
- package/dist/cjs/spreadsheet/csv-streaming.d.cts +19 -0
- package/dist/cjs/spreadsheet/csv-streaming.d.ts +19 -0
- package/dist/cjs/spreadsheet/csv-streaming.js +188 -0
- package/dist/cjs/spreadsheet/csv-streaming.js.map +1 -0
- package/dist/cjs/spreadsheet/data-operations.d.cts +115 -0
- package/dist/cjs/spreadsheet/data-operations.d.ts +115 -0
- package/dist/cjs/spreadsheet/data-operations.js +1515 -0
- package/dist/cjs/spreadsheet/data-operations.js.map +1 -0
- package/dist/cjs/spreadsheet/deduplication-utils.d.cts +31 -0
- package/dist/cjs/spreadsheet/deduplication-utils.d.ts +31 -0
- package/dist/cjs/spreadsheet/deduplication-utils.js +65 -0
- package/dist/cjs/spreadsheet/deduplication-utils.js.map +1 -0
- package/dist/cjs/spreadsheet/range-operations.d.cts +184 -0
- package/dist/cjs/spreadsheet/range-operations.d.ts +184 -0
- package/dist/cjs/spreadsheet/range-operations.js +672 -0
- package/dist/cjs/spreadsheet/range-operations.js.map +1 -0
- package/dist/cjs/spreadsheet/sheet-operations.d.cts +30 -0
- package/dist/cjs/spreadsheet/sheet-operations.d.ts +30 -0
- package/dist/cjs/spreadsheet/sheet-operations.js +811 -0
- package/dist/cjs/spreadsheet/sheet-operations.js.map +1 -0
- package/dist/cjs/spreadsheet/spreadsheet-management.d.cts +21 -0
- package/dist/cjs/spreadsheet/spreadsheet-management.d.ts +21 -0
- package/dist/cjs/spreadsheet/spreadsheet-management.js +310 -0
- package/dist/cjs/spreadsheet/spreadsheet-management.js.map +1 -0
- package/dist/cjs/types.d.cts +53 -0
- package/dist/cjs/types.d.ts +53 -0
- package/dist/cjs/types.js +5 -0
- package/dist/cjs/types.js.map +1 -0
- package/dist/esm/constants.d.ts +7 -0
- package/dist/esm/constants.js +7 -0
- package/dist/esm/constants.js.map +1 -0
- package/dist/esm/index.d.ts +8 -0
- package/dist/esm/index.js +34 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/create-store.d.ts +2 -0
- package/dist/esm/lib/create-store.js +6 -0
- package/dist/esm/lib/create-store.js.map +1 -0
- package/dist/esm/mcp/index.d.ts +3 -0
- package/dist/esm/mcp/index.js +6 -0
- package/dist/esm/mcp/index.js.map +1 -0
- package/dist/esm/mcp/prompts/a1-notation.d.ts +19 -0
- package/dist/esm/mcp/prompts/a1-notation.js +49 -0
- package/dist/esm/mcp/prompts/a1-notation.js.map +1 -0
- package/dist/esm/mcp/prompts/index.d.ts +1 -0
- package/dist/esm/mcp/prompts/index.js +1 -0
- package/dist/esm/mcp/prompts/index.js.map +1 -0
- package/dist/esm/mcp/resources/index.d.ts +1 -0
- package/dist/esm/mcp/resources/index.js +1 -0
- package/dist/esm/mcp/resources/index.js.map +1 -0
- package/dist/esm/mcp/resources/spreadsheet.d.ts +2 -0
- package/dist/esm/mcp/resources/spreadsheet.js +88 -0
- package/dist/esm/mcp/resources/spreadsheet.js.map +1 -0
- package/dist/esm/mcp/tools/cells-format.d.ts +144 -0
- package/dist/esm/mcp/tools/cells-format.js +288 -0
- package/dist/esm/mcp/tools/cells-format.js.map +1 -0
- package/dist/esm/mcp/tools/chart-create.d.ts +94 -0
- package/dist/esm/mcp/tools/chart-create.js +408 -0
- package/dist/esm/mcp/tools/chart-create.js.map +1 -0
- package/dist/esm/mcp/tools/columns-get.d.ts +55 -0
- package/dist/esm/mcp/tools/columns-get.js +113 -0
- package/dist/esm/mcp/tools/columns-get.js.map +1 -0
- package/dist/esm/mcp/tools/columns-update.d.ts +86 -0
- package/dist/esm/mcp/tools/columns-update.js +296 -0
- package/dist/esm/mcp/tools/columns-update.js.map +1 -0
- package/dist/esm/mcp/tools/csv-get-columns.d.ts +43 -0
- package/dist/esm/mcp/tools/csv-get-columns.js +95 -0
- package/dist/esm/mcp/tools/csv-get-columns.js.map +1 -0
- package/dist/esm/mcp/tools/dimensions-batch-update.d.ts +118 -0
- package/dist/esm/mcp/tools/dimensions-batch-update.js +321 -0
- package/dist/esm/mcp/tools/dimensions-batch-update.js.map +1 -0
- package/dist/esm/mcp/tools/dimensions-move.d.ts +86 -0
- package/dist/esm/mcp/tools/dimensions-move.js +183 -0
- package/dist/esm/mcp/tools/dimensions-move.js.map +1 -0
- package/dist/esm/mcp/tools/index.d.ts +26 -0
- package/dist/esm/mcp/tools/index.js +26 -0
- package/dist/esm/mcp/tools/index.js.map +1 -0
- package/dist/esm/mcp/tools/lib/dimension-operations.d.ts +48 -0
- package/dist/esm/mcp/tools/lib/dimension-operations.js +93 -0
- package/dist/esm/mcp/tools/lib/dimension-operations.js.map +1 -0
- package/dist/esm/mcp/tools/rows-append.d.ts +58 -0
- package/dist/esm/mcp/tools/rows-append.js +151 -0
- package/dist/esm/mcp/tools/rows-append.js.map +1 -0
- package/dist/esm/mcp/tools/rows-csv-append.d.ts +67 -0
- package/dist/esm/mcp/tools/rows-csv-append.js +342 -0
- package/dist/esm/mcp/tools/rows-csv-append.js.map +1 -0
- package/dist/esm/mcp/tools/rows-get.d.ts +56 -0
- package/dist/esm/mcp/tools/rows-get.js +116 -0
- package/dist/esm/mcp/tools/rows-get.js.map +1 -0
- package/dist/esm/mcp/tools/sheet-copy-to.d.ts +68 -0
- package/dist/esm/mcp/tools/sheet-copy-to.js +156 -0
- package/dist/esm/mcp/tools/sheet-copy-to.js.map +1 -0
- package/dist/esm/mcp/tools/sheet-copy.d.ts +80 -0
- package/dist/esm/mcp/tools/sheet-copy.js +177 -0
- package/dist/esm/mcp/tools/sheet-copy.js.map +1 -0
- package/dist/esm/mcp/tools/sheet-create.d.ts +56 -0
- package/dist/esm/mcp/tools/sheet-create.js +110 -0
- package/dist/esm/mcp/tools/sheet-create.js.map +1 -0
- package/dist/esm/mcp/tools/sheet-delete.d.ts +62 -0
- package/dist/esm/mcp/tools/sheet-delete.js +125 -0
- package/dist/esm/mcp/tools/sheet-delete.js.map +1 -0
- package/dist/esm/mcp/tools/sheet-find.d.ts +48 -0
- package/dist/esm/mcp/tools/sheet-find.js +90 -0
- package/dist/esm/mcp/tools/sheet-find.js.map +1 -0
- package/dist/esm/mcp/tools/sheet-rename.d.ts +60 -0
- package/dist/esm/mcp/tools/sheet-rename.js +128 -0
- package/dist/esm/mcp/tools/sheet-rename.js.map +1 -0
- package/dist/esm/mcp/tools/spreadsheet-copy.d.ts +58 -0
- package/dist/esm/mcp/tools/spreadsheet-copy.js +117 -0
- package/dist/esm/mcp/tools/spreadsheet-copy.js.map +1 -0
- package/dist/esm/mcp/tools/spreadsheet-create.d.ts +52 -0
- package/dist/esm/mcp/tools/spreadsheet-create.js +97 -0
- package/dist/esm/mcp/tools/spreadsheet-create.js.map +1 -0
- package/dist/esm/mcp/tools/spreadsheet-find.d.ts +58 -0
- package/dist/esm/mcp/tools/spreadsheet-find.js +113 -0
- package/dist/esm/mcp/tools/spreadsheet-find.js.map +1 -0
- package/dist/esm/mcp/tools/spreadsheet-rename.d.ts +56 -0
- package/dist/esm/mcp/tools/spreadsheet-rename.js +112 -0
- package/dist/esm/mcp/tools/spreadsheet-rename.js.map +1 -0
- package/dist/esm/mcp/tools/validation-set.d.ts +144 -0
- package/dist/esm/mcp/tools/validation-set.js +366 -0
- package/dist/esm/mcp/tools/validation-set.js.map +1 -0
- package/dist/esm/mcp/tools/values-batch-update.d.ts +102 -0
- package/dist/esm/mcp/tools/values-batch-update.js +224 -0
- package/dist/esm/mcp/tools/values-batch-update.js.map +1 -0
- package/dist/esm/mcp/tools/values-clear.d.ts +56 -0
- package/dist/esm/mcp/tools/values-clear.js +131 -0
- package/dist/esm/mcp/tools/values-clear.js.map +1 -0
- package/dist/esm/mcp/tools/values-csv-update.d.ts +75 -0
- package/dist/esm/mcp/tools/values-csv-update.js +202 -0
- package/dist/esm/mcp/tools/values-csv-update.js.map +1 -0
- package/dist/esm/mcp/tools/values-replace.d.ts +68 -0
- package/dist/esm/mcp/tools/values-replace.js +171 -0
- package/dist/esm/mcp/tools/values-replace.js.map +1 -0
- package/dist/esm/mcp/tools/values-search.d.ts +74 -0
- package/dist/esm/mcp/tools/values-search.js +229 -0
- package/dist/esm/mcp/tools/values-search.js.map +1 -0
- package/dist/esm/package.json +1 -0
- package/dist/esm/schemas/index.d.ts +14 -0
- package/dist/esm/schemas/index.js +35 -0
- package/dist/esm/schemas/index.js.map +1 -0
- package/dist/esm/setup/config.d.ts +44 -0
- package/dist/esm/setup/config.js +151 -0
- package/dist/esm/setup/config.js.map +1 -0
- package/dist/esm/setup/http.d.ts +8 -0
- package/dist/esm/setup/http.js +54 -0
- package/dist/esm/setup/http.js.map +1 -0
- package/dist/esm/setup/index.d.ts +5 -0
- package/dist/esm/setup/index.js +5 -0
- package/dist/esm/setup/index.js.map +1 -0
- package/dist/esm/setup/oauth-google.d.ts +54 -0
- package/dist/esm/setup/oauth-google.js +142 -0
- package/dist/esm/setup/oauth-google.js.map +1 -0
- package/dist/esm/setup/runtime.d.ts +10 -0
- package/dist/esm/setup/runtime.js +84 -0
- package/dist/esm/setup/runtime.js.map +1 -0
- package/dist/esm/setup/stdio.d.ts +7 -0
- package/dist/esm/setup/stdio.js +38 -0
- package/dist/esm/setup/stdio.js.map +1 -0
- package/dist/esm/spreadsheet/column-utilities.d.ts +1 -0
- package/dist/esm/spreadsheet/column-utilities.js +10 -0
- package/dist/esm/spreadsheet/column-utilities.js.map +1 -0
- package/dist/esm/spreadsheet/csv-streaming.d.ts +19 -0
- package/dist/esm/spreadsheet/csv-streaming.js +43 -0
- package/dist/esm/spreadsheet/csv-streaming.js.map +1 -0
- package/dist/esm/spreadsheet/data-operations.d.ts +115 -0
- package/dist/esm/spreadsheet/data-operations.js +712 -0
- package/dist/esm/spreadsheet/data-operations.js.map +1 -0
- package/dist/esm/spreadsheet/deduplication-utils.d.ts +31 -0
- package/dist/esm/spreadsheet/deduplication-utils.js +54 -0
- package/dist/esm/spreadsheet/deduplication-utils.js.map +1 -0
- package/dist/esm/spreadsheet/range-operations.d.ts +184 -0
- package/dist/esm/spreadsheet/range-operations.js +591 -0
- package/dist/esm/spreadsheet/range-operations.js.map +1 -0
- package/dist/esm/spreadsheet/sheet-operations.d.ts +30 -0
- package/dist/esm/spreadsheet/sheet-operations.js +359 -0
- package/dist/esm/spreadsheet/sheet-operations.js.map +1 -0
- package/dist/esm/spreadsheet/spreadsheet-management.d.ts +21 -0
- package/dist/esm/spreadsheet/spreadsheet-management.js +73 -0
- package/dist/esm/spreadsheet/spreadsheet-management.js.map +1 -0
- package/dist/esm/types.d.ts +53 -0
- package/dist/esm/types.js +1 -0
- package/dist/esm/types.js.map +1 -0
- package/package.json +108 -0
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import type { EnrichedExtra } from '@mcp-z/oauth-google';
|
|
2
|
+
import type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';
|
|
3
|
+
import { z } from 'zod';
|
|
4
|
+
declare const inputSchema: z.ZodObject<{
|
|
5
|
+
id: z.ZodString;
|
|
6
|
+
gid: z.ZodCoercedString<unknown>;
|
|
7
|
+
requests: z.ZodArray<z.ZodObject<{
|
|
8
|
+
range: z.ZodString;
|
|
9
|
+
values: z.ZodArray<z.ZodArray<z.ZodUnion<readonly [z.ZodString, z.ZodNumber, z.ZodLiteral<number>, z.ZodLiteral<number>, z.ZodBoolean, z.ZodNull]>>>;
|
|
10
|
+
majorDimension: z.ZodEnum<{
|
|
11
|
+
ROWS: "ROWS";
|
|
12
|
+
COLUMNS: "COLUMNS";
|
|
13
|
+
}>;
|
|
14
|
+
}, z.core.$strip>>;
|
|
15
|
+
valueInputOption: z.ZodEnum<{
|
|
16
|
+
RAW: "RAW";
|
|
17
|
+
USER_ENTERED: "USER_ENTERED";
|
|
18
|
+
}>;
|
|
19
|
+
includeData: z.ZodBoolean;
|
|
20
|
+
}, z.core.$strip>;
|
|
21
|
+
declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
22
|
+
type: z.ZodLiteral<"success">;
|
|
23
|
+
id: z.ZodString;
|
|
24
|
+
gid: z.ZodString;
|
|
25
|
+
spreadsheetTitle: z.ZodString;
|
|
26
|
+
spreadsheetUrl: z.ZodString;
|
|
27
|
+
sheetTitle: z.ZodString;
|
|
28
|
+
sheetUrl: z.ZodString;
|
|
29
|
+
totalUpdatedRows: z.ZodNumber;
|
|
30
|
+
totalUpdatedColumns: z.ZodNumber;
|
|
31
|
+
totalUpdatedCells: z.ZodNumber;
|
|
32
|
+
updatedRanges: z.ZodArray<z.ZodString>;
|
|
33
|
+
updatedData: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
34
|
+
range: z.ZodString;
|
|
35
|
+
majorDimension: z.ZodEnum<{
|
|
36
|
+
ROWS: "ROWS";
|
|
37
|
+
COLUMNS: "COLUMNS";
|
|
38
|
+
}>;
|
|
39
|
+
values: z.ZodOptional<z.ZodArray<z.ZodArray<z.ZodUnion<readonly [z.ZodString, z.ZodNumber, z.ZodLiteral<number>, z.ZodLiteral<number>, z.ZodBoolean, z.ZodNull]>>>>;
|
|
40
|
+
}, z.core.$strip>>>;
|
|
41
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
42
|
+
type: z.ZodLiteral<"auth_required">;
|
|
43
|
+
provider: z.ZodString;
|
|
44
|
+
message: z.ZodString;
|
|
45
|
+
url: z.ZodOptional<z.ZodString>;
|
|
46
|
+
}, z.core.$strip>], "type">;
|
|
47
|
+
export type Input = z.infer<typeof inputSchema>;
|
|
48
|
+
export type Output = z.infer<typeof outputSchema>;
|
|
49
|
+
declare function handler({ id, gid, requests, valueInputOption, includeData }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
|
|
50
|
+
export default function createTool(): {
|
|
51
|
+
name: string;
|
|
52
|
+
config: {
|
|
53
|
+
readonly description: "Batch update multiple cell ranges. RAW=exact values, USER_ENTERED=parsed like user input. Use a1-notation prompt for range syntax.";
|
|
54
|
+
readonly inputSchema: z.ZodObject<{
|
|
55
|
+
id: z.ZodString;
|
|
56
|
+
gid: z.ZodCoercedString<unknown>;
|
|
57
|
+
requests: z.ZodArray<z.ZodObject<{
|
|
58
|
+
range: z.ZodString;
|
|
59
|
+
values: z.ZodArray<z.ZodArray<z.ZodUnion<readonly [z.ZodString, z.ZodNumber, z.ZodLiteral<number>, z.ZodLiteral<number>, z.ZodBoolean, z.ZodNull]>>>;
|
|
60
|
+
majorDimension: z.ZodEnum<{
|
|
61
|
+
ROWS: "ROWS";
|
|
62
|
+
COLUMNS: "COLUMNS";
|
|
63
|
+
}>;
|
|
64
|
+
}, z.core.$strip>>;
|
|
65
|
+
valueInputOption: z.ZodEnum<{
|
|
66
|
+
RAW: "RAW";
|
|
67
|
+
USER_ENTERED: "USER_ENTERED";
|
|
68
|
+
}>;
|
|
69
|
+
includeData: z.ZodBoolean;
|
|
70
|
+
}, z.core.$strip>;
|
|
71
|
+
readonly outputSchema: z.ZodObject<{
|
|
72
|
+
result: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
73
|
+
type: z.ZodLiteral<"success">;
|
|
74
|
+
id: z.ZodString;
|
|
75
|
+
gid: z.ZodString;
|
|
76
|
+
spreadsheetTitle: z.ZodString;
|
|
77
|
+
spreadsheetUrl: z.ZodString;
|
|
78
|
+
sheetTitle: z.ZodString;
|
|
79
|
+
sheetUrl: z.ZodString;
|
|
80
|
+
totalUpdatedRows: z.ZodNumber;
|
|
81
|
+
totalUpdatedColumns: z.ZodNumber;
|
|
82
|
+
totalUpdatedCells: z.ZodNumber;
|
|
83
|
+
updatedRanges: z.ZodArray<z.ZodString>;
|
|
84
|
+
updatedData: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
85
|
+
range: z.ZodString;
|
|
86
|
+
majorDimension: z.ZodEnum<{
|
|
87
|
+
ROWS: "ROWS";
|
|
88
|
+
COLUMNS: "COLUMNS";
|
|
89
|
+
}>;
|
|
90
|
+
values: z.ZodOptional<z.ZodArray<z.ZodArray<z.ZodUnion<readonly [z.ZodString, z.ZodNumber, z.ZodLiteral<number>, z.ZodLiteral<number>, z.ZodBoolean, z.ZodNull]>>>>;
|
|
91
|
+
}, z.core.$strip>>>;
|
|
92
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
93
|
+
type: z.ZodLiteral<"auth_required">;
|
|
94
|
+
provider: z.ZodString;
|
|
95
|
+
message: z.ZodString;
|
|
96
|
+
url: z.ZodOptional<z.ZodString>;
|
|
97
|
+
}, z.core.$strip>], "type">;
|
|
98
|
+
}, z.core.$strip>;
|
|
99
|
+
};
|
|
100
|
+
handler: typeof handler;
|
|
101
|
+
};
|
|
102
|
+
export {};
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import type { EnrichedExtra } from '@mcp-z/oauth-google';
|
|
2
|
+
import type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';
|
|
3
|
+
import { z } from 'zod';
|
|
4
|
+
declare const inputSchema: z.ZodObject<{
|
|
5
|
+
id: z.ZodString;
|
|
6
|
+
gid: z.ZodCoercedString<unknown>;
|
|
7
|
+
requests: z.ZodArray<z.ZodObject<{
|
|
8
|
+
range: z.ZodString;
|
|
9
|
+
values: z.ZodArray<z.ZodArray<z.ZodUnion<readonly [z.ZodString, z.ZodNumber, z.ZodLiteral<number>, z.ZodLiteral<number>, z.ZodBoolean, z.ZodNull]>>>;
|
|
10
|
+
majorDimension: z.ZodEnum<{
|
|
11
|
+
ROWS: "ROWS";
|
|
12
|
+
COLUMNS: "COLUMNS";
|
|
13
|
+
}>;
|
|
14
|
+
}, z.core.$strip>>;
|
|
15
|
+
valueInputOption: z.ZodEnum<{
|
|
16
|
+
RAW: "RAW";
|
|
17
|
+
USER_ENTERED: "USER_ENTERED";
|
|
18
|
+
}>;
|
|
19
|
+
includeData: z.ZodBoolean;
|
|
20
|
+
}, z.core.$strip>;
|
|
21
|
+
declare const outputSchema: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
22
|
+
type: z.ZodLiteral<"success">;
|
|
23
|
+
id: z.ZodString;
|
|
24
|
+
gid: z.ZodString;
|
|
25
|
+
spreadsheetTitle: z.ZodString;
|
|
26
|
+
spreadsheetUrl: z.ZodString;
|
|
27
|
+
sheetTitle: z.ZodString;
|
|
28
|
+
sheetUrl: z.ZodString;
|
|
29
|
+
totalUpdatedRows: z.ZodNumber;
|
|
30
|
+
totalUpdatedColumns: z.ZodNumber;
|
|
31
|
+
totalUpdatedCells: z.ZodNumber;
|
|
32
|
+
updatedRanges: z.ZodArray<z.ZodString>;
|
|
33
|
+
updatedData: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
34
|
+
range: z.ZodString;
|
|
35
|
+
majorDimension: z.ZodEnum<{
|
|
36
|
+
ROWS: "ROWS";
|
|
37
|
+
COLUMNS: "COLUMNS";
|
|
38
|
+
}>;
|
|
39
|
+
values: z.ZodOptional<z.ZodArray<z.ZodArray<z.ZodUnion<readonly [z.ZodString, z.ZodNumber, z.ZodLiteral<number>, z.ZodLiteral<number>, z.ZodBoolean, z.ZodNull]>>>>;
|
|
40
|
+
}, z.core.$strip>>>;
|
|
41
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
42
|
+
type: z.ZodLiteral<"auth_required">;
|
|
43
|
+
provider: z.ZodString;
|
|
44
|
+
message: z.ZodString;
|
|
45
|
+
url: z.ZodOptional<z.ZodString>;
|
|
46
|
+
}, z.core.$strip>], "type">;
|
|
47
|
+
export type Input = z.infer<typeof inputSchema>;
|
|
48
|
+
export type Output = z.infer<typeof outputSchema>;
|
|
49
|
+
declare function handler({ id, gid, requests, valueInputOption, includeData }: Input, extra: EnrichedExtra): Promise<CallToolResult>;
|
|
50
|
+
export default function createTool(): {
|
|
51
|
+
name: string;
|
|
52
|
+
config: {
|
|
53
|
+
readonly description: "Batch update multiple cell ranges. RAW=exact values, USER_ENTERED=parsed like user input. Use a1-notation prompt for range syntax.";
|
|
54
|
+
readonly inputSchema: z.ZodObject<{
|
|
55
|
+
id: z.ZodString;
|
|
56
|
+
gid: z.ZodCoercedString<unknown>;
|
|
57
|
+
requests: z.ZodArray<z.ZodObject<{
|
|
58
|
+
range: z.ZodString;
|
|
59
|
+
values: z.ZodArray<z.ZodArray<z.ZodUnion<readonly [z.ZodString, z.ZodNumber, z.ZodLiteral<number>, z.ZodLiteral<number>, z.ZodBoolean, z.ZodNull]>>>;
|
|
60
|
+
majorDimension: z.ZodEnum<{
|
|
61
|
+
ROWS: "ROWS";
|
|
62
|
+
COLUMNS: "COLUMNS";
|
|
63
|
+
}>;
|
|
64
|
+
}, z.core.$strip>>;
|
|
65
|
+
valueInputOption: z.ZodEnum<{
|
|
66
|
+
RAW: "RAW";
|
|
67
|
+
USER_ENTERED: "USER_ENTERED";
|
|
68
|
+
}>;
|
|
69
|
+
includeData: z.ZodBoolean;
|
|
70
|
+
}, z.core.$strip>;
|
|
71
|
+
readonly outputSchema: z.ZodObject<{
|
|
72
|
+
result: z.ZodDiscriminatedUnion<[z.ZodObject<{
|
|
73
|
+
type: z.ZodLiteral<"success">;
|
|
74
|
+
id: z.ZodString;
|
|
75
|
+
gid: z.ZodString;
|
|
76
|
+
spreadsheetTitle: z.ZodString;
|
|
77
|
+
spreadsheetUrl: z.ZodString;
|
|
78
|
+
sheetTitle: z.ZodString;
|
|
79
|
+
sheetUrl: z.ZodString;
|
|
80
|
+
totalUpdatedRows: z.ZodNumber;
|
|
81
|
+
totalUpdatedColumns: z.ZodNumber;
|
|
82
|
+
totalUpdatedCells: z.ZodNumber;
|
|
83
|
+
updatedRanges: z.ZodArray<z.ZodString>;
|
|
84
|
+
updatedData: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
85
|
+
range: z.ZodString;
|
|
86
|
+
majorDimension: z.ZodEnum<{
|
|
87
|
+
ROWS: "ROWS";
|
|
88
|
+
COLUMNS: "COLUMNS";
|
|
89
|
+
}>;
|
|
90
|
+
values: z.ZodOptional<z.ZodArray<z.ZodArray<z.ZodUnion<readonly [z.ZodString, z.ZodNumber, z.ZodLiteral<number>, z.ZodLiteral<number>, z.ZodBoolean, z.ZodNull]>>>>;
|
|
91
|
+
}, z.core.$strip>>>;
|
|
92
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
93
|
+
type: z.ZodLiteral<"auth_required">;
|
|
94
|
+
provider: z.ZodString;
|
|
95
|
+
message: z.ZodString;
|
|
96
|
+
url: z.ZodOptional<z.ZodString>;
|
|
97
|
+
}, z.core.$strip>], "type">;
|
|
98
|
+
}, z.core.$strip>;
|
|
99
|
+
};
|
|
100
|
+
handler: typeof handler;
|
|
101
|
+
};
|
|
102
|
+
export {};
|
|
@@ -0,0 +1,409 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", {
|
|
3
|
+
value: true
|
|
4
|
+
});
|
|
5
|
+
Object.defineProperty(exports, "default", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return createTool;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
var _oauthgoogle = require("@mcp-z/oauth-google");
|
|
12
|
+
var _types = require("@modelcontextprotocol/sdk/types.js");
|
|
13
|
+
var _googleapis = require("googleapis");
|
|
14
|
+
var _zod = require("zod");
|
|
15
|
+
var _index = require("../../schemas/index.js");
|
|
16
|
+
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
17
|
+
try {
|
|
18
|
+
var info = gen[key](arg);
|
|
19
|
+
var value = info.value;
|
|
20
|
+
} catch (error) {
|
|
21
|
+
reject(error);
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
if (info.done) {
|
|
25
|
+
resolve(value);
|
|
26
|
+
} else {
|
|
27
|
+
Promise.resolve(value).then(_next, _throw);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
function _async_to_generator(fn) {
|
|
31
|
+
return function() {
|
|
32
|
+
var self = this, args = arguments;
|
|
33
|
+
return new Promise(function(resolve, reject) {
|
|
34
|
+
var gen = fn.apply(self, args);
|
|
35
|
+
function _next(value) {
|
|
36
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
|
|
37
|
+
}
|
|
38
|
+
function _throw(err) {
|
|
39
|
+
asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
|
|
40
|
+
}
|
|
41
|
+
_next(undefined);
|
|
42
|
+
});
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
function _instanceof(left, right) {
|
|
46
|
+
if (right != null && typeof Symbol !== "undefined" && right[Symbol.hasInstance]) {
|
|
47
|
+
return !!right[Symbol.hasInstance](left);
|
|
48
|
+
} else {
|
|
49
|
+
return left instanceof right;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
function _ts_generator(thisArg, body) {
|
|
53
|
+
var f, y, t, _ = {
|
|
54
|
+
label: 0,
|
|
55
|
+
sent: function() {
|
|
56
|
+
if (t[0] & 1) throw t[1];
|
|
57
|
+
return t[1];
|
|
58
|
+
},
|
|
59
|
+
trys: [],
|
|
60
|
+
ops: []
|
|
61
|
+
}, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype), d = Object.defineProperty;
|
|
62
|
+
return d(g, "next", {
|
|
63
|
+
value: verb(0)
|
|
64
|
+
}), d(g, "throw", {
|
|
65
|
+
value: verb(1)
|
|
66
|
+
}), d(g, "return", {
|
|
67
|
+
value: verb(2)
|
|
68
|
+
}), typeof Symbol === "function" && d(g, Symbol.iterator, {
|
|
69
|
+
value: function() {
|
|
70
|
+
return this;
|
|
71
|
+
}
|
|
72
|
+
}), g;
|
|
73
|
+
function verb(n) {
|
|
74
|
+
return function(v) {
|
|
75
|
+
return step([
|
|
76
|
+
n,
|
|
77
|
+
v
|
|
78
|
+
]);
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
function step(op) {
|
|
82
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
83
|
+
while(g && (g = 0, op[0] && (_ = 0)), _)try {
|
|
84
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
85
|
+
if (y = 0, t) op = [
|
|
86
|
+
op[0] & 2,
|
|
87
|
+
t.value
|
|
88
|
+
];
|
|
89
|
+
switch(op[0]){
|
|
90
|
+
case 0:
|
|
91
|
+
case 1:
|
|
92
|
+
t = op;
|
|
93
|
+
break;
|
|
94
|
+
case 4:
|
|
95
|
+
_.label++;
|
|
96
|
+
return {
|
|
97
|
+
value: op[1],
|
|
98
|
+
done: false
|
|
99
|
+
};
|
|
100
|
+
case 5:
|
|
101
|
+
_.label++;
|
|
102
|
+
y = op[1];
|
|
103
|
+
op = [
|
|
104
|
+
0
|
|
105
|
+
];
|
|
106
|
+
continue;
|
|
107
|
+
case 7:
|
|
108
|
+
op = _.ops.pop();
|
|
109
|
+
_.trys.pop();
|
|
110
|
+
continue;
|
|
111
|
+
default:
|
|
112
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
|
|
113
|
+
_ = 0;
|
|
114
|
+
continue;
|
|
115
|
+
}
|
|
116
|
+
if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
|
|
117
|
+
_.label = op[1];
|
|
118
|
+
break;
|
|
119
|
+
}
|
|
120
|
+
if (op[0] === 6 && _.label < t[1]) {
|
|
121
|
+
_.label = t[1];
|
|
122
|
+
t = op;
|
|
123
|
+
break;
|
|
124
|
+
}
|
|
125
|
+
if (t && _.label < t[2]) {
|
|
126
|
+
_.label = t[2];
|
|
127
|
+
_.ops.push(op);
|
|
128
|
+
break;
|
|
129
|
+
}
|
|
130
|
+
if (t[2]) _.ops.pop();
|
|
131
|
+
_.trys.pop();
|
|
132
|
+
continue;
|
|
133
|
+
}
|
|
134
|
+
op = body.call(thisArg, _);
|
|
135
|
+
} catch (e) {
|
|
136
|
+
op = [
|
|
137
|
+
6,
|
|
138
|
+
e
|
|
139
|
+
];
|
|
140
|
+
y = 0;
|
|
141
|
+
} finally{
|
|
142
|
+
f = t = 0;
|
|
143
|
+
}
|
|
144
|
+
if (op[0] & 5) throw op[1];
|
|
145
|
+
return {
|
|
146
|
+
value: op[0] ? op[1] : void 0,
|
|
147
|
+
done: true
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
|
|
152
|
+
// Input schema for values batch update requests
|
|
153
|
+
var ValuesBatchUpdateRequestSchema = _zod.z.object({
|
|
154
|
+
range: _index.A1NotationSchema.describe('A1 notation range defining the bounded target area. Data dimensions must match range dimensions. Example: D1:D100 requires exactly 100 rows of data. Use open-ended ranges like D1:D to write any number of rows.'),
|
|
155
|
+
values: _zod.z.array(_zod.z.array(_index.SheetCellSchema)).min(1).describe('2D array of values. Row count must match range height, column count must match range width. Use null to skip a cell (preserve existing value), empty string "" to clear it.'),
|
|
156
|
+
majorDimension: _zod.z.enum([
|
|
157
|
+
'ROWS',
|
|
158
|
+
'COLUMNS'
|
|
159
|
+
]).describe('Whether values represent rows or columns')
|
|
160
|
+
});
|
|
161
|
+
var inputSchema = _zod.z.object({
|
|
162
|
+
id: _index.SpreadsheetIdSchema,
|
|
163
|
+
gid: _index.SheetGidSchema,
|
|
164
|
+
requests: _zod.z.array(ValuesBatchUpdateRequestSchema).min(1).describe('Array of value update requests'),
|
|
165
|
+
valueInputOption: _zod.z.enum([
|
|
166
|
+
'RAW',
|
|
167
|
+
'USER_ENTERED'
|
|
168
|
+
]).describe('How input data should be interpreted (RAW = exact values, USER_ENTERED = parsed like user input)'),
|
|
169
|
+
includeData: _zod.z.boolean().describe('Whether to include updated cell values in the response')
|
|
170
|
+
});
|
|
171
|
+
var successBranchSchema = _zod.z.object({
|
|
172
|
+
type: _zod.z.literal('success'),
|
|
173
|
+
id: _index.SpreadsheetIdOutput,
|
|
174
|
+
gid: _index.SheetGidOutput,
|
|
175
|
+
spreadsheetTitle: _zod.z.string().describe('Title of the updated spreadsheet'),
|
|
176
|
+
spreadsheetUrl: _zod.z.string().describe('URL of the updated spreadsheet'),
|
|
177
|
+
sheetTitle: _zod.z.string().describe('Title of the updated sheet'),
|
|
178
|
+
sheetUrl: _zod.z.string().describe('URL of the updated sheet'),
|
|
179
|
+
totalUpdatedRows: _zod.z.number().int().nonnegative().describe('Total number of rows updated across all requests'),
|
|
180
|
+
totalUpdatedColumns: _zod.z.number().int().nonnegative().describe('Total number of columns updated across all requests'),
|
|
181
|
+
totalUpdatedCells: _zod.z.number().int().nonnegative().describe('Total number of cells updated across all requests'),
|
|
182
|
+
updatedRanges: _zod.z.array(_zod.z.string()).describe('A1 notation ranges that were updated'),
|
|
183
|
+
updatedData: _zod.z.array(_zod.z.object({
|
|
184
|
+
range: _zod.z.string().describe('A1 notation range that was updated'),
|
|
185
|
+
majorDimension: _zod.z.enum([
|
|
186
|
+
'ROWS',
|
|
187
|
+
'COLUMNS'
|
|
188
|
+
]).describe('Dimension of the updated data'),
|
|
189
|
+
values: _zod.z.array(_zod.z.array(_index.SheetCellSchema)).optional().describe('Updated values (if includeData was true)')
|
|
190
|
+
})).optional().describe('Detailed information about updated data (if includeData was true)')
|
|
191
|
+
});
|
|
192
|
+
var outputSchema = _zod.z.discriminatedUnion('type', [
|
|
193
|
+
successBranchSchema,
|
|
194
|
+
AuthRequiredBranchSchema
|
|
195
|
+
]);
|
|
196
|
+
var config = {
|
|
197
|
+
description: 'Batch update multiple cell ranges. RAW=exact values, USER_ENTERED=parsed like user input. Use a1-notation prompt for range syntax.',
|
|
198
|
+
inputSchema: inputSchema,
|
|
199
|
+
outputSchema: _zod.z.object({
|
|
200
|
+
result: outputSchema
|
|
201
|
+
})
|
|
202
|
+
};
|
|
203
|
+
function handler(_0, _1) {
|
|
204
|
+
return _async_to_generator(function(param, extra) {
|
|
205
|
+
var id, gid, requests, _param_valueInputOption, valueInputOption, _param_includeData, includeData, logger, _ref, _spreadsheetData_spreadsheetUrl, _sheet_properties_title, _sheet_properties_sheetId, _spreadsheetData_properties, _spreadsheetData_sheets, sheets, spreadsheetResponse, spreadsheetData, spreadsheetTitle, spreadsheetUrl, sheet, sheetTitle, sheetGid, sheetUrl, batchUpdateData, batchUpdateResponse, updateResult, responses, expectedCount, actualCount, failedOperations, updatedRanges, totalUpdatedRows, totalUpdatedColumns, totalUpdatedCells, updatedData, result, error, message;
|
|
206
|
+
return _ts_generator(this, function(_state) {
|
|
207
|
+
switch(_state.label){
|
|
208
|
+
case 0:
|
|
209
|
+
id = param.id, gid = param.gid, requests = param.requests, _param_valueInputOption = param.valueInputOption, valueInputOption = _param_valueInputOption === void 0 ? 'USER_ENTERED' : _param_valueInputOption, _param_includeData = param.includeData, includeData = _param_includeData === void 0 ? false : _param_includeData;
|
|
210
|
+
logger = extra.logger;
|
|
211
|
+
logger.info('sheets.values.batchUpdate called', {
|
|
212
|
+
id: id,
|
|
213
|
+
gid: gid,
|
|
214
|
+
requestCount: requests.length,
|
|
215
|
+
valueInputOption: valueInputOption,
|
|
216
|
+
includeData: includeData
|
|
217
|
+
});
|
|
218
|
+
_state.label = 1;
|
|
219
|
+
case 1:
|
|
220
|
+
_state.trys.push([
|
|
221
|
+
1,
|
|
222
|
+
4,
|
|
223
|
+
,
|
|
224
|
+
5
|
|
225
|
+
]);
|
|
226
|
+
sheets = _googleapis.google.sheets({
|
|
227
|
+
version: 'v4',
|
|
228
|
+
auth: extra.authContext.auth
|
|
229
|
+
});
|
|
230
|
+
return [
|
|
231
|
+
4,
|
|
232
|
+
sheets.spreadsheets.get({
|
|
233
|
+
spreadsheetId: id,
|
|
234
|
+
fields: 'properties.title,spreadsheetUrl,sheets.properties.sheetId,sheets.properties.title'
|
|
235
|
+
})
|
|
236
|
+
];
|
|
237
|
+
case 2:
|
|
238
|
+
spreadsheetResponse = _state.sent();
|
|
239
|
+
spreadsheetData = spreadsheetResponse.data;
|
|
240
|
+
spreadsheetTitle = (_ref = (_spreadsheetData_properties = spreadsheetData.properties) === null || _spreadsheetData_properties === void 0 ? void 0 : _spreadsheetData_properties.title) !== null && _ref !== void 0 ? _ref : '';
|
|
241
|
+
spreadsheetUrl = (_spreadsheetData_spreadsheetUrl = spreadsheetData.spreadsheetUrl) !== null && _spreadsheetData_spreadsheetUrl !== void 0 ? _spreadsheetData_spreadsheetUrl : '';
|
|
242
|
+
// Find sheet by gid
|
|
243
|
+
sheet = (_spreadsheetData_sheets = spreadsheetData.sheets) === null || _spreadsheetData_sheets === void 0 ? void 0 : _spreadsheetData_sheets.find(function(s) {
|
|
244
|
+
var _s_properties;
|
|
245
|
+
return String((_s_properties = s.properties) === null || _s_properties === void 0 ? void 0 : _s_properties.sheetId) === gid;
|
|
246
|
+
});
|
|
247
|
+
if (!(sheet === null || sheet === void 0 ? void 0 : sheet.properties)) {
|
|
248
|
+
logger.info('Sheet not found for batch update', {
|
|
249
|
+
id: id,
|
|
250
|
+
gid: gid,
|
|
251
|
+
requestCount: requests.length
|
|
252
|
+
});
|
|
253
|
+
throw new _types.McpError(_types.ErrorCode.InvalidParams, "Sheet not found: ".concat(gid));
|
|
254
|
+
}
|
|
255
|
+
sheetTitle = (_sheet_properties_title = sheet.properties.title) !== null && _sheet_properties_title !== void 0 ? _sheet_properties_title : gid;
|
|
256
|
+
sheetGid = (_sheet_properties_sheetId = sheet.properties.sheetId) !== null && _sheet_properties_sheetId !== void 0 ? _sheet_properties_sheetId : 0;
|
|
257
|
+
sheetUrl = "https://docs.google.com/spreadsheets/d/".concat(id, "/edit#gid=").concat(sheetGid);
|
|
258
|
+
// Build batch update request with prefixed ranges
|
|
259
|
+
batchUpdateData = requests.map(function(req) {
|
|
260
|
+
return {
|
|
261
|
+
range: "".concat(sheetTitle, "!").concat(req.range),
|
|
262
|
+
values: req.values,
|
|
263
|
+
majorDimension: req.majorDimension || 'ROWS'
|
|
264
|
+
};
|
|
265
|
+
});
|
|
266
|
+
logger.info('sheets.values.batchUpdate executing batch request', {
|
|
267
|
+
spreadsheetId: id,
|
|
268
|
+
sheetTitle: sheetTitle,
|
|
269
|
+
batchUpdateDataCount: batchUpdateData.length
|
|
270
|
+
});
|
|
271
|
+
return [
|
|
272
|
+
4,
|
|
273
|
+
sheets.spreadsheets.values.batchUpdate({
|
|
274
|
+
spreadsheetId: id,
|
|
275
|
+
requestBody: {
|
|
276
|
+
valueInputOption: valueInputOption,
|
|
277
|
+
data: batchUpdateData,
|
|
278
|
+
includeValuesInResponse: includeData,
|
|
279
|
+
responseDateTimeRenderOption: 'FORMATTED_STRING',
|
|
280
|
+
responseValueRenderOption: 'FORMATTED_VALUE'
|
|
281
|
+
}
|
|
282
|
+
})
|
|
283
|
+
];
|
|
284
|
+
case 3:
|
|
285
|
+
batchUpdateResponse = _state.sent();
|
|
286
|
+
updateResult = batchUpdateResponse.data;
|
|
287
|
+
// Validate batch operation results and detect partial failures
|
|
288
|
+
responses = updateResult.responses || [];
|
|
289
|
+
expectedCount = requests.length;
|
|
290
|
+
actualCount = responses.length;
|
|
291
|
+
if (actualCount !== expectedCount) {
|
|
292
|
+
logger.error('Partial batch failure detected', {
|
|
293
|
+
expectedOperations: expectedCount,
|
|
294
|
+
completedOperations: actualCount,
|
|
295
|
+
spreadsheetId: id,
|
|
296
|
+
sheetTitle: sheetTitle
|
|
297
|
+
});
|
|
298
|
+
throw new _types.McpError(_types.ErrorCode.InternalError, "Batch operation partially failed: ".concat(actualCount, "/").concat(expectedCount, " operations completed"));
|
|
299
|
+
}
|
|
300
|
+
// Check for any failed operations (empty or null responses)
|
|
301
|
+
failedOperations = responses.filter(function(response, index) {
|
|
302
|
+
if (!response || !response.updatedRange) {
|
|
303
|
+
var _requests_index;
|
|
304
|
+
logger.error('Failed operation detected', {
|
|
305
|
+
operationIndex: index,
|
|
306
|
+
requestedRange: (_requests_index = requests[index]) === null || _requests_index === void 0 ? void 0 : _requests_index.range,
|
|
307
|
+
spreadsheetId: id,
|
|
308
|
+
sheetTitle: sheetTitle
|
|
309
|
+
});
|
|
310
|
+
return true;
|
|
311
|
+
}
|
|
312
|
+
return false;
|
|
313
|
+
});
|
|
314
|
+
if (failedOperations.length > 0) {
|
|
315
|
+
throw new _types.McpError(_types.ErrorCode.InternalError, "".concat(failedOperations.length, " operations failed to update ranges"));
|
|
316
|
+
}
|
|
317
|
+
// Extract updated ranges and calculate totals
|
|
318
|
+
updatedRanges = responses.map(function(response) {
|
|
319
|
+
return response.updatedRange || '';
|
|
320
|
+
}).filter(function(range) {
|
|
321
|
+
return range;
|
|
322
|
+
});
|
|
323
|
+
totalUpdatedRows = updateResult.totalUpdatedRows || 0;
|
|
324
|
+
totalUpdatedColumns = updateResult.totalUpdatedColumns || 0;
|
|
325
|
+
totalUpdatedCells = updateResult.totalUpdatedCells || 0;
|
|
326
|
+
if (includeData && updateResult.responses) {
|
|
327
|
+
updatedData = updateResult.responses.filter(function(response) {
|
|
328
|
+
return response.updatedData;
|
|
329
|
+
}).map(function(response) {
|
|
330
|
+
var _response_updatedData, _response_updatedData1;
|
|
331
|
+
var item = {
|
|
332
|
+
range: response.updatedRange || '',
|
|
333
|
+
majorDimension: ((_response_updatedData = response.updatedData) === null || _response_updatedData === void 0 ? void 0 : _response_updatedData.majorDimension) || 'ROWS'
|
|
334
|
+
};
|
|
335
|
+
var values = (_response_updatedData1 = response.updatedData) === null || _response_updatedData1 === void 0 ? void 0 : _response_updatedData1.values;
|
|
336
|
+
if (values !== undefined) {
|
|
337
|
+
// Map undefined values to null for JSON Schema compatibility
|
|
338
|
+
item.values = values.map(function(row) {
|
|
339
|
+
return row.map(function(cell) {
|
|
340
|
+
return cell === undefined ? null : cell;
|
|
341
|
+
});
|
|
342
|
+
});
|
|
343
|
+
}
|
|
344
|
+
return item;
|
|
345
|
+
});
|
|
346
|
+
}
|
|
347
|
+
logger.info('sheets.values.batchUpdate completed successfully', {
|
|
348
|
+
totalUpdatedRows: totalUpdatedRows,
|
|
349
|
+
totalUpdatedColumns: totalUpdatedColumns,
|
|
350
|
+
totalUpdatedCells: totalUpdatedCells,
|
|
351
|
+
updatedRangesCount: updatedRanges.length
|
|
352
|
+
});
|
|
353
|
+
result = {
|
|
354
|
+
type: 'success',
|
|
355
|
+
id: id,
|
|
356
|
+
gid: String(sheetGid),
|
|
357
|
+
spreadsheetTitle: spreadsheetTitle || '',
|
|
358
|
+
spreadsheetUrl: spreadsheetUrl || '',
|
|
359
|
+
sheetTitle: sheetTitle,
|
|
360
|
+
sheetUrl: sheetUrl,
|
|
361
|
+
totalUpdatedRows: totalUpdatedRows,
|
|
362
|
+
totalUpdatedColumns: totalUpdatedColumns,
|
|
363
|
+
totalUpdatedCells: totalUpdatedCells,
|
|
364
|
+
updatedRanges: updatedRanges,
|
|
365
|
+
updatedData: updatedData
|
|
366
|
+
};
|
|
367
|
+
return [
|
|
368
|
+
2,
|
|
369
|
+
{
|
|
370
|
+
content: [
|
|
371
|
+
{
|
|
372
|
+
type: 'text',
|
|
373
|
+
text: JSON.stringify(result)
|
|
374
|
+
}
|
|
375
|
+
],
|
|
376
|
+
structuredContent: {
|
|
377
|
+
result: result
|
|
378
|
+
}
|
|
379
|
+
}
|
|
380
|
+
];
|
|
381
|
+
case 4:
|
|
382
|
+
error = _state.sent();
|
|
383
|
+
message = _instanceof(error, Error) ? error.message : String(error);
|
|
384
|
+
logger.error('Batch update operation failed', {
|
|
385
|
+
id: id,
|
|
386
|
+
gid: gid,
|
|
387
|
+
requestCount: requests.length,
|
|
388
|
+
valueInputOption: valueInputOption,
|
|
389
|
+
error: message
|
|
390
|
+
});
|
|
391
|
+
throw new _types.McpError(_types.ErrorCode.InternalError, "Error batch updating values: ".concat(message), {
|
|
392
|
+
stack: _instanceof(error, Error) ? error.stack : undefined
|
|
393
|
+
});
|
|
394
|
+
case 5:
|
|
395
|
+
return [
|
|
396
|
+
2
|
|
397
|
+
];
|
|
398
|
+
}
|
|
399
|
+
});
|
|
400
|
+
}).apply(this, arguments);
|
|
401
|
+
}
|
|
402
|
+
function createTool() {
|
|
403
|
+
return {
|
|
404
|
+
name: 'values-batch-update',
|
|
405
|
+
config: config,
|
|
406
|
+
handler: handler
|
|
407
|
+
};
|
|
408
|
+
}
|
|
409
|
+
/* CJS INTEROP */ if (exports.__esModule && exports.default) { try { Object.defineProperty(exports.default, '__esModule', { value: true }); for (var key in exports) { exports.default[key] = exports[key]; } } catch (_) {}; module.exports = exports.default; }
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/values-batch-update.ts"],"sourcesContent":["import type { EnrichedExtra } from '@mcp-z/oauth-google';\nimport { schemas } from '@mcp-z/oauth-google';\n\nconst { AuthRequiredBranchSchema } = schemas;\n\nimport type { ToolModule } from '@mcp-z/server';\nimport type { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\nimport { ErrorCode, McpError } from '@modelcontextprotocol/sdk/types.js';\nimport { google } from 'googleapis';\nimport { z } from 'zod';\nimport { A1NotationSchema, SheetCellSchema, SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\n\n// Types for updated data response\ninterface UpdatedDataItem {\n range: string;\n majorDimension: 'ROWS' | 'COLUMNS';\n values?: (string | number | boolean | null)[][];\n}\n\n// Input schema for values batch update requests\nconst ValuesBatchUpdateRequestSchema = z.object({\n range: A1NotationSchema.describe('A1 notation range defining the bounded target area. Data dimensions must match range dimensions. Example: D1:D100 requires exactly 100 rows of data. Use open-ended ranges like D1:D to write any number of rows.'),\n values: z.array(z.array(SheetCellSchema)).min(1).describe('2D array of values. Row count must match range height, column count must match range width. Use null to skip a cell (preserve existing value), empty string \"\" to clear it.'),\n majorDimension: z.enum(['ROWS', 'COLUMNS']).describe('Whether values represent rows or columns'),\n});\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n requests: z.array(ValuesBatchUpdateRequestSchema).min(1).describe('Array of value update requests'),\n valueInputOption: z.enum(['RAW', 'USER_ENTERED']).describe('How input data should be interpreted (RAW = exact values, USER_ENTERED = parsed like user input)'),\n includeData: z.boolean().describe('Whether to include updated cell values in the response'),\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n spreadsheetTitle: z.string().describe('Title of the updated spreadsheet'),\n spreadsheetUrl: z.string().describe('URL of the updated spreadsheet'),\n sheetTitle: z.string().describe('Title of the updated sheet'),\n sheetUrl: z.string().describe('URL of the updated sheet'),\n totalUpdatedRows: z.number().int().nonnegative().describe('Total number of rows updated across all requests'),\n totalUpdatedColumns: z.number().int().nonnegative().describe('Total number of columns updated across all requests'),\n totalUpdatedCells: z.number().int().nonnegative().describe('Total number of cells updated across all requests'),\n updatedRanges: z.array(z.string()).describe('A1 notation ranges that were updated'),\n updatedData: z\n .array(\n z.object({\n range: z.string().describe('A1 notation range that was updated'),\n majorDimension: z.enum(['ROWS', 'COLUMNS']).describe('Dimension of the updated data'),\n values: z.array(z.array(SheetCellSchema)).optional().describe('Updated values (if includeData was true)'),\n })\n )\n .optional()\n .describe('Detailed information about updated data (if includeData was true)'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Batch update multiple cell ranges. RAW=exact values, USER_ENTERED=parsed like user input. Use a1-notation prompt for range syntax.',\n inputSchema,\n outputSchema: z.object({\n result: outputSchema,\n }),\n} as const;\n\nexport type Input = z.infer<typeof inputSchema>;\nexport type Output = z.infer<typeof outputSchema>;\n\nasync function handler({ id, gid, requests, valueInputOption = 'USER_ENTERED', includeData = false }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.values.batchUpdate called', {\n id,\n gid,\n requestCount: requests.length,\n valueInputOption,\n includeData,\n });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // Get spreadsheet and sheet info in single API call\n const spreadsheetResponse = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'properties.title,spreadsheetUrl,sheets.properties.sheetId,sheets.properties.title',\n });\n\n const spreadsheetData = spreadsheetResponse.data;\n const spreadsheetTitle = spreadsheetData.properties?.title ?? '';\n const spreadsheetUrl = spreadsheetData.spreadsheetUrl ?? '';\n\n // Find sheet by gid\n const sheet = spreadsheetData.sheets?.find((s) => String(s.properties?.sheetId) === gid);\n if (!sheet?.properties) {\n logger.info('Sheet not found for batch update', { id, gid, requestCount: requests.length });\n throw new McpError(ErrorCode.InvalidParams, `Sheet not found: ${gid}`);\n }\n\n const sheetTitle = sheet.properties.title ?? gid;\n const sheetGid = sheet.properties.sheetId ?? 0;\n const sheetUrl = `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${sheetGid}`;\n\n // Build batch update request with prefixed ranges\n const batchUpdateData = requests.map((req) => ({\n range: `${sheetTitle}!${req.range}`,\n values: req.values,\n majorDimension: req.majorDimension || 'ROWS',\n }));\n\n logger.info('sheets.values.batchUpdate executing batch request', {\n spreadsheetId: id,\n sheetTitle,\n batchUpdateDataCount: batchUpdateData.length,\n });\n\n // Execute the batch update\n const batchUpdateResponse = await sheets.spreadsheets.values.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n valueInputOption,\n data: batchUpdateData,\n includeValuesInResponse: includeData,\n responseDateTimeRenderOption: 'FORMATTED_STRING',\n responseValueRenderOption: 'FORMATTED_VALUE',\n },\n });\n\n const updateResult = batchUpdateResponse.data;\n\n // Validate batch operation results and detect partial failures\n const responses = updateResult.responses || [];\n const expectedCount = requests.length;\n const actualCount = responses.length;\n\n if (actualCount !== expectedCount) {\n logger.error('Partial batch failure detected', {\n expectedOperations: expectedCount,\n completedOperations: actualCount,\n spreadsheetId: id,\n sheetTitle,\n });\n\n throw new McpError(ErrorCode.InternalError, `Batch operation partially failed: ${actualCount}/${expectedCount} operations completed`);\n }\n\n // Check for any failed operations (empty or null responses)\n const failedOperations = responses.filter((response, index) => {\n if (!response || !response.updatedRange) {\n logger.error('Failed operation detected', {\n operationIndex: index,\n requestedRange: requests[index]?.range,\n spreadsheetId: id,\n sheetTitle,\n });\n return true;\n }\n return false;\n });\n\n if (failedOperations.length > 0) {\n throw new McpError(ErrorCode.InternalError, `${failedOperations.length} operations failed to update ranges`);\n }\n\n // Extract updated ranges and calculate totals\n const updatedRanges = responses.map((response) => response.updatedRange || '').filter((range) => range);\n const totalUpdatedRows = updateResult.totalUpdatedRows || 0;\n const totalUpdatedColumns = updateResult.totalUpdatedColumns || 0;\n const totalUpdatedCells = updateResult.totalUpdatedCells || 0;\n\n // Build updated data response if requested\n let updatedData: UpdatedDataItem[] | undefined;\n if (includeData && updateResult.responses) {\n updatedData = updateResult.responses\n .filter((response) => response.updatedData)\n .map((response) => {\n const item: UpdatedDataItem = {\n range: response.updatedRange || '',\n majorDimension: (response.updatedData?.majorDimension as 'ROWS' | 'COLUMNS' | undefined) || 'ROWS',\n };\n const values = response.updatedData?.values as (string | number | boolean | null | undefined)[][] | undefined;\n if (values !== undefined) {\n // Map undefined values to null for JSON Schema compatibility\n item.values = values.map((row) => row.map((cell) => (cell === undefined ? null : cell)));\n }\n return item;\n });\n }\n\n logger.info('sheets.values.batchUpdate completed successfully', {\n totalUpdatedRows,\n totalUpdatedColumns,\n totalUpdatedCells,\n updatedRangesCount: updatedRanges.length,\n });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid: String(sheetGid),\n spreadsheetTitle: spreadsheetTitle || '',\n spreadsheetUrl: spreadsheetUrl || '',\n sheetTitle,\n sheetUrl,\n totalUpdatedRows,\n totalUpdatedColumns,\n totalUpdatedCells,\n updatedRanges,\n updatedData,\n };\n\n return {\n content: [{ type: 'text' as const, text: JSON.stringify(result) }],\n structuredContent: { result },\n };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error('Batch update operation failed', {\n id,\n gid,\n requestCount: requests.length,\n valueInputOption,\n error: message,\n });\n\n throw new McpError(ErrorCode.InternalError, `Error batch updating values: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'values-batch-update',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","ValuesBatchUpdateRequestSchema","z","object","range","A1NotationSchema","describe","values","array","SheetCellSchema","min","majorDimension","enum","inputSchema","id","SpreadsheetIdSchema","gid","SheetGidSchema","requests","valueInputOption","includeData","boolean","successBranchSchema","type","literal","SpreadsheetIdOutput","SheetGidOutput","spreadsheetTitle","string","spreadsheetUrl","sheetTitle","sheetUrl","totalUpdatedRows","number","int","nonnegative","totalUpdatedColumns","totalUpdatedCells","updatedRanges","updatedData","optional","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetData","sheet","sheets","spreadsheetResponse","sheetGid","batchUpdateData","batchUpdateResponse","updateResult","responses","expectedCount","actualCount","failedOperations","error","message","info","requestCount","length","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","properties","title","find","s","String","sheetId","McpError","ErrorCode","InvalidParams","map","req","batchUpdateDataCount","batchUpdate","requestBody","includeValuesInResponse","responseDateTimeRenderOption","responseValueRenderOption","expectedOperations","completedOperations","InternalError","filter","response","index","updatedRange","operationIndex","requestedRange","item","undefined","row","cell","updatedRangesCount","content","text","JSON","stringify","structuredContent","Error","stack","name"],"mappings":"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"}
|