@mcp-z/mcp-sheets 1.0.0 → 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +32 -3
- package/bin/server.js +1 -1
- package/dist/cjs/constants.js.map +1 -1
- package/dist/cjs/index.js +13 -13
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/lib/create-store.js.map +1 -1
- package/dist/cjs/mcp/index.js +6 -6
- package/dist/cjs/mcp/index.js.map +1 -1
- package/dist/cjs/mcp/prompts/a1-notation.js.map +1 -1
- package/dist/cjs/mcp/prompts/index.js +2 -2
- package/dist/cjs/mcp/prompts/index.js.map +1 -1
- package/dist/cjs/mcp/resources/index.js +2 -2
- package/dist/cjs/mcp/resources/index.js.map +1 -1
- package/dist/cjs/mcp/resources/spreadsheet.js.map +1 -1
- package/dist/cjs/mcp/tools/cells-format.js +8 -8
- package/dist/cjs/mcp/tools/cells-format.js.map +1 -1
- package/dist/cjs/mcp/tools/chart-create.js +8 -8
- package/dist/cjs/mcp/tools/chart-create.js.map +1 -1
- package/dist/cjs/mcp/tools/columns-get.js +3 -3
- package/dist/cjs/mcp/tools/columns-get.js.map +1 -1
- package/dist/cjs/mcp/tools/columns-update.js +10 -10
- package/dist/cjs/mcp/tools/columns-update.js.map +1 -1
- package/dist/cjs/mcp/tools/csv-get-columns.js +2 -2
- package/dist/cjs/mcp/tools/csv-get-columns.js.map +1 -1
- package/dist/cjs/mcp/tools/dimensions-batch-update.js +16 -16
- package/dist/cjs/mcp/tools/dimensions-batch-update.js.map +1 -1
- package/dist/cjs/mcp/tools/dimensions-move.js +5 -5
- package/dist/cjs/mcp/tools/dimensions-move.js.map +1 -1
- package/dist/cjs/mcp/tools/index.js +52 -52
- package/dist/cjs/mcp/tools/index.js.map +1 -1
- package/dist/cjs/mcp/tools/lib/dimension-operations.js.map +1 -1
- package/dist/cjs/mcp/tools/rows-append.js +10 -10
- package/dist/cjs/mcp/tools/rows-append.js.map +1 -1
- package/dist/cjs/mcp/tools/rows-csv-append.js +13 -13
- package/dist/cjs/mcp/tools/rows-csv-append.js.map +1 -1
- package/dist/cjs/mcp/tools/rows-get.js +4 -4
- package/dist/cjs/mcp/tools/rows-get.js.map +1 -1
- package/dist/cjs/mcp/tools/sheet-copy-to.js +4 -4
- package/dist/cjs/mcp/tools/sheet-copy-to.js.map +1 -1
- package/dist/cjs/mcp/tools/sheet-copy.js +5 -5
- package/dist/cjs/mcp/tools/sheet-copy.js.map +1 -1
- package/dist/cjs/mcp/tools/sheet-create.js +4 -4
- package/dist/cjs/mcp/tools/sheet-create.js.map +1 -1
- package/dist/cjs/mcp/tools/sheet-delete.js +4 -4
- package/dist/cjs/mcp/tools/sheet-delete.js.map +1 -1
- package/dist/cjs/mcp/tools/sheet-find.js +7 -7
- package/dist/cjs/mcp/tools/sheet-find.js.map +1 -1
- package/dist/cjs/mcp/tools/sheet-rename.js +5 -5
- package/dist/cjs/mcp/tools/sheet-rename.js.map +1 -1
- package/dist/cjs/mcp/tools/spreadsheet-copy.js +2 -2
- package/dist/cjs/mcp/tools/spreadsheet-copy.js.map +1 -1
- package/dist/cjs/mcp/tools/spreadsheet-create.js +2 -2
- package/dist/cjs/mcp/tools/spreadsheet-create.js.map +1 -1
- package/dist/cjs/mcp/tools/spreadsheet-find.js +6 -6
- package/dist/cjs/mcp/tools/spreadsheet-find.js.map +1 -1
- package/dist/cjs/mcp/tools/spreadsheet-rename.js +3 -3
- package/dist/cjs/mcp/tools/spreadsheet-rename.js.map +1 -1
- package/dist/cjs/mcp/tools/validation-set.js +8 -8
- package/dist/cjs/mcp/tools/validation-set.js.map +1 -1
- package/dist/cjs/mcp/tools/values-batch-update.js +8 -8
- package/dist/cjs/mcp/tools/values-batch-update.js.map +1 -1
- package/dist/cjs/mcp/tools/values-clear.js +6 -6
- package/dist/cjs/mcp/tools/values-clear.js.map +1 -1
- package/dist/cjs/mcp/tools/values-csv-update.js +8 -8
- package/dist/cjs/mcp/tools/values-csv-update.js.map +1 -1
- package/dist/cjs/mcp/tools/values-replace.js +8 -8
- package/dist/cjs/mcp/tools/values-replace.js.map +1 -1
- package/dist/cjs/mcp/tools/values-search.js +5 -5
- package/dist/cjs/mcp/tools/values-search.js.map +1 -1
- package/dist/cjs/schemas/index.js.map +1 -1
- package/dist/cjs/setup/config.js +11 -1
- package/dist/cjs/setup/config.js.map +1 -1
- package/dist/cjs/setup/http.js +6 -2
- package/dist/cjs/setup/http.js.map +1 -1
- package/dist/cjs/setup/index.js +9 -9
- package/dist/cjs/setup/index.js.map +1 -1
- package/dist/cjs/setup/oauth-google.d.cts +3 -2
- package/dist/cjs/setup/oauth-google.d.ts +3 -2
- package/dist/cjs/setup/oauth-google.js +15 -12
- package/dist/cjs/setup/oauth-google.js.map +1 -1
- package/dist/cjs/setup/runtime.js +9 -9
- package/dist/cjs/setup/runtime.js.map +1 -1
- package/dist/cjs/setup/stdio.js +2 -2
- package/dist/cjs/setup/stdio.js.map +1 -1
- package/dist/cjs/spreadsheet/column-utilities.js.map +1 -1
- package/dist/cjs/spreadsheet/csv-streaming.js.map +1 -1
- package/dist/cjs/spreadsheet/data-operations.js +9 -9
- package/dist/cjs/spreadsheet/data-operations.js.map +1 -1
- package/dist/cjs/spreadsheet/deduplication-utils.js.map +1 -1
- package/dist/cjs/spreadsheet/range-operations.js +2 -2
- package/dist/cjs/spreadsheet/range-operations.js.map +1 -1
- package/dist/cjs/spreadsheet/sheet-operations.js +3 -3
- package/dist/cjs/spreadsheet/sheet-operations.js.map +1 -1
- package/dist/cjs/spreadsheet/spreadsheet-management.js.map +1 -1
- package/dist/esm/constants.js.map +1 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/lib/create-store.js.map +1 -1
- package/dist/esm/mcp/index.js.map +1 -1
- package/dist/esm/mcp/prompts/a1-notation.js.map +1 -1
- package/dist/esm/mcp/prompts/index.js.map +1 -1
- package/dist/esm/mcp/resources/index.js.map +1 -1
- package/dist/esm/mcp/resources/spreadsheet.js.map +1 -1
- package/dist/esm/mcp/tools/cells-format.js.map +1 -1
- package/dist/esm/mcp/tools/chart-create.js.map +1 -1
- package/dist/esm/mcp/tools/columns-get.js.map +1 -1
- package/dist/esm/mcp/tools/columns-update.js.map +1 -1
- package/dist/esm/mcp/tools/csv-get-columns.js.map +1 -1
- package/dist/esm/mcp/tools/dimensions-batch-update.js.map +1 -1
- package/dist/esm/mcp/tools/dimensions-move.js.map +1 -1
- package/dist/esm/mcp/tools/index.js.map +1 -1
- package/dist/esm/mcp/tools/lib/dimension-operations.js.map +1 -1
- package/dist/esm/mcp/tools/rows-append.js.map +1 -1
- package/dist/esm/mcp/tools/rows-csv-append.js.map +1 -1
- package/dist/esm/mcp/tools/rows-get.js.map +1 -1
- package/dist/esm/mcp/tools/sheet-copy-to.js.map +1 -1
- package/dist/esm/mcp/tools/sheet-copy.js.map +1 -1
- package/dist/esm/mcp/tools/sheet-create.js.map +1 -1
- package/dist/esm/mcp/tools/sheet-delete.js.map +1 -1
- package/dist/esm/mcp/tools/sheet-find.js.map +1 -1
- package/dist/esm/mcp/tools/sheet-rename.js.map +1 -1
- package/dist/esm/mcp/tools/spreadsheet-copy.js.map +1 -1
- package/dist/esm/mcp/tools/spreadsheet-create.js.map +1 -1
- package/dist/esm/mcp/tools/spreadsheet-find.js.map +1 -1
- package/dist/esm/mcp/tools/spreadsheet-rename.js.map +1 -1
- package/dist/esm/mcp/tools/validation-set.js.map +1 -1
- package/dist/esm/mcp/tools/values-batch-update.js.map +1 -1
- package/dist/esm/mcp/tools/values-clear.js.map +1 -1
- package/dist/esm/mcp/tools/values-csv-update.js.map +1 -1
- package/dist/esm/mcp/tools/values-replace.js.map +1 -1
- package/dist/esm/mcp/tools/values-search.js.map +1 -1
- package/dist/esm/schemas/index.js.map +1 -1
- package/dist/esm/setup/config.js +12 -2
- package/dist/esm/setup/config.js.map +1 -1
- package/dist/esm/setup/http.js +4 -0
- package/dist/esm/setup/http.js.map +1 -1
- package/dist/esm/setup/index.js.map +1 -1
- package/dist/esm/setup/oauth-google.d.ts +3 -2
- package/dist/esm/setup/oauth-google.js +8 -11
- package/dist/esm/setup/oauth-google.js.map +1 -1
- package/dist/esm/setup/runtime.js.map +1 -1
- package/dist/esm/setup/stdio.js.map +1 -1
- package/dist/esm/spreadsheet/column-utilities.js.map +1 -1
- package/dist/esm/spreadsheet/csv-streaming.js.map +1 -1
- package/dist/esm/spreadsheet/data-operations.js.map +1 -1
- package/dist/esm/spreadsheet/deduplication-utils.js.map +1 -1
- package/dist/esm/spreadsheet/range-operations.js.map +1 -1
- package/dist/esm/spreadsheet/sheet-operations.js.map +1 -1
- package/dist/esm/spreadsheet/spreadsheet-management.js.map +1 -1
- package/dist/esm/types.js.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/dimensions-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 { SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\nimport { buildDimensionRequest, calculateAffectedCount, DEFAULT_COLUMN_COUNT, DEFAULT_ROW_COUNT, type DimensionRequest, MAX_COLUMN_COUNT, MAX_ROW_COUNT, sortOperations } from './lib/dimension-operations.js';\n\n// Input schema for dimension batch update requests\nconst DimensionRequestSchema = z.object({\n operation: z.enum(['insertDimension', 'deleteDimension', 'appendDimension']).describe('Type of dimension operation to perform'),\n dimension: z.enum(['ROWS', 'COLUMNS']).describe('Whether to operate on rows or columns'),\n startIndex: z.number().int().nonnegative().describe('Starting index for the operation (0-based)'),\n endIndex: z.number().int().nonnegative().optional().describe('Ending index for the operation (0-based, exclusive). Optional - if omitted, the range is unbounded (extends to the end of the sheet)'),\n inheritFromBefore: z.boolean().optional().describe('For insertDimension: whether new rows/columns inherit properties from the row/column before the insertion point'),\n});\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n requests: z.array(DimensionRequestSchema).min(1).describe('Array of dimension update requests'),\n});\n\n// Success branch schema\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 totalOperations: z.number().int().nonnegative().describe('Total number of dimension operations performed'),\n operationResults: z\n .array(\n z.object({\n operation: z.enum(['insertDimension', 'deleteDimension', 'appendDimension']).describe('Type of operation that was performed'),\n dimension: z.enum(['ROWS', 'COLUMNS']).describe('Dimension that was operated on'),\n startIndex: z.number().int().nonnegative().describe('Starting index of the operation'),\n endIndex: z.number().int().nonnegative().optional().describe('Ending index of the operation (for insert/delete)'),\n affectedCount: z.number().int().nonnegative().describe('Number of rows/columns affected by this operation'),\n })\n )\n .describe('Detailed results for each dimension operation'),\n updatedDimensions: z\n .object({\n rows: z.number().int().nonnegative().describe('Total number of rows in the sheet after all operations'),\n columns: z.number().int().nonnegative().describe('Total number of columns in the sheet after all operations'),\n })\n .describe('Final dimensions of the sheet after all operations'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Batch update sheet dimensions by inserting, deleting, or appending rows/columns. Operations are atomic (all succeed or all fail) and execute in optimal order automatically.',\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 }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.debug?.('sheets.dimensions.batchUpdate called', {\n id,\n gid,\n requestCount: requests.length,\n operations: requests.map((r) => ({ operation: r.operation, dimension: r.dimension, startIndex: r.startIndex, endIndex: r.endIndex })),\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,sheets.properties.gridProperties',\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.warn?.('Sheet not found for dimensions 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 sheetId = sheet.properties.sheetId;\n\n if (sheetId === undefined || sheetId === null) {\n logger.error?.('Sheet ID not available for dimensions batch update', { id, gid, sheetTitle });\n throw new McpError(ErrorCode.InternalError, `Sheet ID not available for ${gid}. Cannot perform dimension operations without valid sheet ID.`);\n }\n\n const sheetUrl = `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${sheetId}`;\n\n // Get current sheet dimensions for response calculation\n // Note: Google Sheets API may not always provide gridProperties for older sheets\n // Fall back to Google's documented defaults for new sheets\n const currentRowCount = sheet.properties.gridProperties?.rowCount ?? DEFAULT_ROW_COUNT;\n const currentColumnCount = sheet.properties.gridProperties?.columnCount ?? DEFAULT_COLUMN_COUNT;\n\n // Sort operations for optimal execution order to prevent index conflicts\n // Delete operations are processed first (high to low index) to avoid shifting issues\n // Insert/append operations are processed after (low to high index)\n const sortedRequests = sortOperations(requests as DimensionRequest[]);\n\n // Build Google Sheets API batch update requests\n const batchRequests = sortedRequests.map((operation) => buildDimensionRequest(operation, sheetId));\n\n logger.debug?.('sheets.dimensions.batchUpdate executing batch request', {\n spreadsheetId: id,\n sheetTitle,\n sheetId,\n totalOperations: batchRequests.length,\n operationTypes: sortedRequests.map((r) => r.operation),\n operationDetails: sortedRequests.map((r, i) => ({\n index: i,\n operation: r.operation,\n dimension: r.dimension,\n startIndex: r.startIndex,\n endIndex: r.endIndex,\n affectedCount: calculateAffectedCount(r),\n })),\n currentDimensions: { rows: currentRowCount, columns: currentColumnCount },\n });\n\n // Execute the atomic batch update\n const batchUpdateResponse = await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: batchRequests,\n includeSpreadsheetInResponse: false, // We don't need the full spreadsheet data back\n },\n });\n\n const updateResult = batchUpdateResponse.data;\n\n // Comprehensive validation of batch update results\n if (!updateResult) {\n logger.error?.('Dimensions batch update failed - no response data', {\n spreadsheetId: id,\n sheetTitle,\n requestCount: requests.length,\n });\n throw new McpError(ErrorCode.InternalError, 'Batch update failed: no response data received from Google Sheets API');\n }\n\n const replies = updateResult.replies || [];\n const expectedCount = requests.length;\n const actualCount = replies.length;\n\n // Validate operation count matches expectations\n if (actualCount !== expectedCount) {\n logger.error?.('Dimensions batch update failed - operation count mismatch', {\n expectedOperations: expectedCount,\n actualReplies: actualCount,\n spreadsheetId: id,\n sheetTitle,\n receivedReplies: replies.map((reply, index) => ({\n index,\n replyType: Object.keys(reply || {})[0] || 'empty',\n })),\n });\n\n throw new McpError(ErrorCode.InternalError, `Batch operation failed: expected ${expectedCount} operations, received ${actualCount} replies. This may indicate a partial failure or Google API issue.`);\n }\n\n // Validate each reply exists - Google Sheets API may return empty objects for successful operations\n for (let i = 0; i < replies.length; i++) {\n const reply = replies[i];\n const request = sortedRequests[i];\n\n if (!request) {\n logger.error?.('Dimensions batch update failed - missing request', {\n replyIndex: i,\n hasReply: !!reply,\n hasRequest: !!request,\n spreadsheetId: id,\n sheetTitle,\n });\n throw new McpError(ErrorCode.InternalError, `Operation ${i} failed: missing request data`);\n }\n\n // Note: Google Sheets API often returns empty objects {} for successful dimension operations\n // This is normal behavior and indicates success, not failure\n // We validate that the reply exists (even if empty) rather than checking specific keys\n if (reply === null || reply === undefined) {\n logger.error?.('Dimensions batch update failed - null reply', {\n operationIndex: i,\n expectedOperation: request.operation,\n spreadsheetId: id,\n sheetTitle,\n });\n throw new McpError(ErrorCode.InternalError, `Operation ${i} (${request.operation}) failed: null reply from Google Sheets API`);\n }\n }\n\n // Calculate final dimensions and operation results\n // Note: We calculate based on the operations we performed, but actual dimensions\n // may vary slightly due to Google Sheets internal behavior (e.g., minimum dimensions)\n let finalRowCount = currentRowCount;\n let finalColumnCount = currentColumnCount;\n\n const operationResults = sortedRequests.map((operation, _index) => {\n const affectedCount = calculateAffectedCount(operation);\n\n // Update dimension counts based on operation\n // Operations are applied in sorted order, so this should match actual result\n if (operation.dimension === 'ROWS') {\n if (operation.operation === 'insertDimension') {\n finalRowCount += affectedCount;\n } else if (operation.operation === 'appendDimension') {\n finalRowCount += affectedCount;\n } else if (operation.operation === 'deleteDimension') {\n finalRowCount = Math.max(1, finalRowCount - affectedCount); // Google Sheets minimum 1 row\n }\n } else if (operation.dimension === 'COLUMNS') {\n if (operation.operation === 'insertDimension') {\n finalColumnCount += affectedCount;\n } else if (operation.operation === 'appendDimension') {\n finalColumnCount += affectedCount;\n } else if (operation.operation === 'deleteDimension') {\n finalColumnCount = Math.max(1, finalColumnCount - affectedCount); // Google Sheets minimum 1 column\n }\n }\n\n return {\n operation: operation.operation,\n dimension: operation.dimension,\n startIndex: operation.startIndex,\n endIndex: operation.endIndex,\n affectedCount,\n };\n });\n\n // Validate final dimensions are within Google Sheets limits\n if (finalRowCount > MAX_ROW_COUNT) {\n logger.warn?.('Final row count exceeds Google Sheets maximum', {\n finalRowCount,\n maxRowCount: MAX_ROW_COUNT,\n spreadsheetId: id,\n sheetTitle,\n });\n }\n if (finalColumnCount > MAX_COLUMN_COUNT) {\n logger.warn?.('Final column count exceeds Google Sheets maximum', {\n finalColumnCount,\n maxColumnCount: MAX_COLUMN_COUNT,\n spreadsheetId: id,\n sheetTitle,\n });\n }\n\n logger.debug?.('sheets.dimensions.batchUpdate completed successfully', {\n totalOperations: requests.length,\n finalRowCount,\n finalColumnCount,\n operationResults: operationResults.length,\n });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid: String(sheetId),\n spreadsheetTitle: spreadsheetTitle || '',\n spreadsheetUrl: spreadsheetUrl || '',\n sheetTitle,\n sheetUrl,\n totalOperations: requests.length,\n operationResults,\n updatedDimensions: {\n rows: finalRowCount,\n columns: finalColumnCount,\n },\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?.('sheets.dimensions.batchUpdate error', { error: message });\n throw new McpError(ErrorCode.InternalError, `Error batch updating dimensions: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'dimensions-batch-update',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","DimensionRequestSchema","z","object","operation","enum","describe","dimension","startIndex","number","int","nonnegative","endIndex","optional","inheritFromBefore","boolean","inputSchema","id","SpreadsheetIdSchema","gid","SheetGidSchema","requests","array","min","successBranchSchema","type","literal","SpreadsheetIdOutput","SheetGidOutput","spreadsheetTitle","string","spreadsheetUrl","sheetTitle","sheetUrl","totalOperations","operationResults","affectedCount","updatedDimensions","rows","columns","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetData","sheet","sheets","spreadsheetResponse","sheetId","currentRowCount","currentColumnCount","sortedRequests","batchRequests","batchUpdateResponse","updateResult","replies","expectedCount","actualCount","i","reply","request","finalRowCount","finalColumnCount","error","message","debug","requestCount","length","operations","map","r","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","properties","title","find","s","String","warn","McpError","ErrorCode","InvalidParams","undefined","InternalError","gridProperties","rowCount","DEFAULT_ROW_COUNT","columnCount","DEFAULT_COLUMN_COUNT","sortOperations","buildDimensionRequest","operationTypes","operationDetails","index","calculateAffectedCount","currentDimensions","batchUpdate","requestBody","includeSpreadsheetInResponse","expectedOperations","actualReplies","receivedReplies","replyType","Object","keys","replyIndex","hasReply","hasRequest","operationIndex","expectedOperation","_index","Math","max","MAX_ROW_COUNT","maxRowCount","MAX_COLUMN_COUNT","maxColumnCount","content","text","JSON","stringify","structuredContent","Error","stack","name"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/dimensions-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 { SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.ts';\nimport { buildDimensionRequest, calculateAffectedCount, DEFAULT_COLUMN_COUNT, DEFAULT_ROW_COUNT, type DimensionRequest, MAX_COLUMN_COUNT, MAX_ROW_COUNT, sortOperations } from './lib/dimension-operations.ts';\n\n// Input schema for dimension batch update requests\nconst DimensionRequestSchema = z.object({\n operation: z.enum(['insertDimension', 'deleteDimension', 'appendDimension']).describe('Type of dimension operation to perform'),\n dimension: z.enum(['ROWS', 'COLUMNS']).describe('Whether to operate on rows or columns'),\n startIndex: z.number().int().nonnegative().describe('Starting index for the operation (0-based)'),\n endIndex: z.number().int().nonnegative().optional().describe('Ending index for the operation (0-based, exclusive). Optional - if omitted, the range is unbounded (extends to the end of the sheet)'),\n inheritFromBefore: z.boolean().optional().describe('For insertDimension: whether new rows/columns inherit properties from the row/column before the insertion point'),\n});\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n requests: z.array(DimensionRequestSchema).min(1).describe('Array of dimension update requests'),\n});\n\n// Success branch schema\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 totalOperations: z.number().int().nonnegative().describe('Total number of dimension operations performed'),\n operationResults: z\n .array(\n z.object({\n operation: z.enum(['insertDimension', 'deleteDimension', 'appendDimension']).describe('Type of operation that was performed'),\n dimension: z.enum(['ROWS', 'COLUMNS']).describe('Dimension that was operated on'),\n startIndex: z.number().int().nonnegative().describe('Starting index of the operation'),\n endIndex: z.number().int().nonnegative().optional().describe('Ending index of the operation (for insert/delete)'),\n affectedCount: z.number().int().nonnegative().describe('Number of rows/columns affected by this operation'),\n })\n )\n .describe('Detailed results for each dimension operation'),\n updatedDimensions: z\n .object({\n rows: z.number().int().nonnegative().describe('Total number of rows in the sheet after all operations'),\n columns: z.number().int().nonnegative().describe('Total number of columns in the sheet after all operations'),\n })\n .describe('Final dimensions of the sheet after all operations'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Batch update sheet dimensions by inserting, deleting, or appending rows/columns. Operations are atomic (all succeed or all fail) and execute in optimal order automatically.',\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 }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.debug?.('sheets.dimensions.batchUpdate called', {\n id,\n gid,\n requestCount: requests.length,\n operations: requests.map((r) => ({ operation: r.operation, dimension: r.dimension, startIndex: r.startIndex, endIndex: r.endIndex })),\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,sheets.properties.gridProperties',\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.warn?.('Sheet not found for dimensions 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 sheetId = sheet.properties.sheetId;\n\n if (sheetId === undefined || sheetId === null) {\n logger.error?.('Sheet ID not available for dimensions batch update', { id, gid, sheetTitle });\n throw new McpError(ErrorCode.InternalError, `Sheet ID not available for ${gid}. Cannot perform dimension operations without valid sheet ID.`);\n }\n\n const sheetUrl = `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${sheetId}`;\n\n // Get current sheet dimensions for response calculation\n // Note: Google Sheets API may not always provide gridProperties for older sheets\n // Fall back to Google's documented defaults for new sheets\n const currentRowCount = sheet.properties.gridProperties?.rowCount ?? DEFAULT_ROW_COUNT;\n const currentColumnCount = sheet.properties.gridProperties?.columnCount ?? DEFAULT_COLUMN_COUNT;\n\n // Sort operations for optimal execution order to prevent index conflicts\n // Delete operations are processed first (high to low index) to avoid shifting issues\n // Insert/append operations are processed after (low to high index)\n const sortedRequests = sortOperations(requests as DimensionRequest[]);\n\n // Build Google Sheets API batch update requests\n const batchRequests = sortedRequests.map((operation) => buildDimensionRequest(operation, sheetId));\n\n logger.debug?.('sheets.dimensions.batchUpdate executing batch request', {\n spreadsheetId: id,\n sheetTitle,\n sheetId,\n totalOperations: batchRequests.length,\n operationTypes: sortedRequests.map((r) => r.operation),\n operationDetails: sortedRequests.map((r, i) => ({\n index: i,\n operation: r.operation,\n dimension: r.dimension,\n startIndex: r.startIndex,\n endIndex: r.endIndex,\n affectedCount: calculateAffectedCount(r),\n })),\n currentDimensions: { rows: currentRowCount, columns: currentColumnCount },\n });\n\n // Execute the atomic batch update\n const batchUpdateResponse = await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: batchRequests,\n includeSpreadsheetInResponse: false, // We don't need the full spreadsheet data back\n },\n });\n\n const updateResult = batchUpdateResponse.data;\n\n // Comprehensive validation of batch update results\n if (!updateResult) {\n logger.error?.('Dimensions batch update failed - no response data', {\n spreadsheetId: id,\n sheetTitle,\n requestCount: requests.length,\n });\n throw new McpError(ErrorCode.InternalError, 'Batch update failed: no response data received from Google Sheets API');\n }\n\n const replies = updateResult.replies || [];\n const expectedCount = requests.length;\n const actualCount = replies.length;\n\n // Validate operation count matches expectations\n if (actualCount !== expectedCount) {\n logger.error?.('Dimensions batch update failed - operation count mismatch', {\n expectedOperations: expectedCount,\n actualReplies: actualCount,\n spreadsheetId: id,\n sheetTitle,\n receivedReplies: replies.map((reply, index) => ({\n index,\n replyType: Object.keys(reply || {})[0] || 'empty',\n })),\n });\n\n throw new McpError(ErrorCode.InternalError, `Batch operation failed: expected ${expectedCount} operations, received ${actualCount} replies. This may indicate a partial failure or Google API issue.`);\n }\n\n // Validate each reply exists - Google Sheets API may return empty objects for successful operations\n for (let i = 0; i < replies.length; i++) {\n const reply = replies[i];\n const request = sortedRequests[i];\n\n if (!request) {\n logger.error?.('Dimensions batch update failed - missing request', {\n replyIndex: i,\n hasReply: !!reply,\n hasRequest: !!request,\n spreadsheetId: id,\n sheetTitle,\n });\n throw new McpError(ErrorCode.InternalError, `Operation ${i} failed: missing request data`);\n }\n\n // Note: Google Sheets API often returns empty objects {} for successful dimension operations\n // This is normal behavior and indicates success, not failure\n // We validate that the reply exists (even if empty) rather than checking specific keys\n if (reply === null || reply === undefined) {\n logger.error?.('Dimensions batch update failed - null reply', {\n operationIndex: i,\n expectedOperation: request.operation,\n spreadsheetId: id,\n sheetTitle,\n });\n throw new McpError(ErrorCode.InternalError, `Operation ${i} (${request.operation}) failed: null reply from Google Sheets API`);\n }\n }\n\n // Calculate final dimensions and operation results\n // Note: We calculate based on the operations we performed, but actual dimensions\n // may vary slightly due to Google Sheets internal behavior (e.g., minimum dimensions)\n let finalRowCount = currentRowCount;\n let finalColumnCount = currentColumnCount;\n\n const operationResults = sortedRequests.map((operation, _index) => {\n const affectedCount = calculateAffectedCount(operation);\n\n // Update dimension counts based on operation\n // Operations are applied in sorted order, so this should match actual result\n if (operation.dimension === 'ROWS') {\n if (operation.operation === 'insertDimension') {\n finalRowCount += affectedCount;\n } else if (operation.operation === 'appendDimension') {\n finalRowCount += affectedCount;\n } else if (operation.operation === 'deleteDimension') {\n finalRowCount = Math.max(1, finalRowCount - affectedCount); // Google Sheets minimum 1 row\n }\n } else if (operation.dimension === 'COLUMNS') {\n if (operation.operation === 'insertDimension') {\n finalColumnCount += affectedCount;\n } else if (operation.operation === 'appendDimension') {\n finalColumnCount += affectedCount;\n } else if (operation.operation === 'deleteDimension') {\n finalColumnCount = Math.max(1, finalColumnCount - affectedCount); // Google Sheets minimum 1 column\n }\n }\n\n return {\n operation: operation.operation,\n dimension: operation.dimension,\n startIndex: operation.startIndex,\n endIndex: operation.endIndex,\n affectedCount,\n };\n });\n\n // Validate final dimensions are within Google Sheets limits\n if (finalRowCount > MAX_ROW_COUNT) {\n logger.warn?.('Final row count exceeds Google Sheets maximum', {\n finalRowCount,\n maxRowCount: MAX_ROW_COUNT,\n spreadsheetId: id,\n sheetTitle,\n });\n }\n if (finalColumnCount > MAX_COLUMN_COUNT) {\n logger.warn?.('Final column count exceeds Google Sheets maximum', {\n finalColumnCount,\n maxColumnCount: MAX_COLUMN_COUNT,\n spreadsheetId: id,\n sheetTitle,\n });\n }\n\n logger.debug?.('sheets.dimensions.batchUpdate completed successfully', {\n totalOperations: requests.length,\n finalRowCount,\n finalColumnCount,\n operationResults: operationResults.length,\n });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid: String(sheetId),\n spreadsheetTitle: spreadsheetTitle || '',\n spreadsheetUrl: spreadsheetUrl || '',\n sheetTitle,\n sheetUrl,\n totalOperations: requests.length,\n operationResults,\n updatedDimensions: {\n rows: finalRowCount,\n columns: finalColumnCount,\n },\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?.('sheets.dimensions.batchUpdate error', { error: message });\n throw new McpError(ErrorCode.InternalError, `Error batch updating dimensions: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'dimensions-batch-update',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","DimensionRequestSchema","z","object","operation","enum","describe","dimension","startIndex","number","int","nonnegative","endIndex","optional","inheritFromBefore","boolean","inputSchema","id","SpreadsheetIdSchema","gid","SheetGidSchema","requests","array","min","successBranchSchema","type","literal","SpreadsheetIdOutput","SheetGidOutput","spreadsheetTitle","string","spreadsheetUrl","sheetTitle","sheetUrl","totalOperations","operationResults","affectedCount","updatedDimensions","rows","columns","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetData","sheet","sheets","spreadsheetResponse","sheetId","currentRowCount","currentColumnCount","sortedRequests","batchRequests","batchUpdateResponse","updateResult","replies","expectedCount","actualCount","i","reply","request","finalRowCount","finalColumnCount","error","message","debug","requestCount","length","operations","map","r","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","properties","title","find","s","String","warn","McpError","ErrorCode","InvalidParams","undefined","InternalError","gridProperties","rowCount","DEFAULT_ROW_COUNT","columnCount","DEFAULT_COLUMN_COUNT","sortOperations","buildDimensionRequest","operationTypes","operationDetails","index","calculateAffectedCount","currentDimensions","batchUpdate","requestBody","includeSpreadsheetInResponse","expectedOperations","actualReplies","receivedReplies","replyType","Object","keys","replyIndex","hasReply","hasRequest","operationIndex","expectedOperation","_index","Math","max","MAX_ROW_COUNT","maxRowCount","MAX_COLUMN_COUNT","maxColumnCount","content","text","JSON","stringify","structuredContent","Error","stack","name"],"mappings":"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"}
|
|
@@ -12,7 +12,7 @@ var _oauthgoogle = require("@mcp-z/oauth-google");
|
|
|
12
12
|
var _types = require("@modelcontextprotocol/sdk/types.js");
|
|
13
13
|
var _googleapis = require("googleapis");
|
|
14
14
|
var _zod = require("zod");
|
|
15
|
-
var
|
|
15
|
+
var _indexts = require("../../schemas/index.js");
|
|
16
16
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
17
17
|
try {
|
|
18
18
|
var info = gen[key](arg);
|
|
@@ -150,8 +150,8 @@ function _ts_generator(thisArg, body) {
|
|
|
150
150
|
}
|
|
151
151
|
var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
|
|
152
152
|
var inputSchema = _zod.z.object({
|
|
153
|
-
id:
|
|
154
|
-
gid:
|
|
153
|
+
id: _indexts.SpreadsheetIdSchema,
|
|
154
|
+
gid: _indexts.SheetGidSchema,
|
|
155
155
|
dimension: _zod.z.enum([
|
|
156
156
|
'ROWS',
|
|
157
157
|
'COLUMNS'
|
|
@@ -162,8 +162,8 @@ var inputSchema = _zod.z.object({
|
|
|
162
162
|
});
|
|
163
163
|
var successBranchSchema = _zod.z.object({
|
|
164
164
|
type: _zod.z.literal('success'),
|
|
165
|
-
id:
|
|
166
|
-
gid:
|
|
165
|
+
id: _indexts.SpreadsheetIdOutput,
|
|
166
|
+
gid: _indexts.SheetGidOutput,
|
|
167
167
|
spreadsheetTitle: _zod.z.string().describe('Title of the spreadsheet'),
|
|
168
168
|
spreadsheetUrl: _zod.z.string().describe('URL of the spreadsheet'),
|
|
169
169
|
sheetTitle: _zod.z.string().describe('Title of the sheet'),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/dimensions-move.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 { SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n dimension: z.enum(['ROWS', 'COLUMNS']).describe('Whether to move rows or columns'),\n startIndex: z.number().int().nonnegative().describe('Starting index of the range to move (0-based)'),\n endIndex: z.number().int().positive().describe('Ending index of the range to move (0-based, exclusive)'),\n destinationIndex: z.number().int().nonnegative().describe('Index where the rows/columns will be moved to (0-based)'),\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 spreadsheet'),\n spreadsheetUrl: z.string().describe('URL of the spreadsheet'),\n sheetTitle: z.string().describe('Title of the sheet'),\n sheetUrl: z.string().describe('URL of the sheet'),\n dimension: z.enum(['ROWS', 'COLUMNS']).describe('Dimension that was moved'),\n sourceRange: z.object({\n startIndex: z.number().describe('Starting index of the moved range'),\n endIndex: z.number().describe('Ending index of the moved range'),\n }),\n destinationIndex: z.number().describe('Index where the range was moved to'),\n movedCount: z.number().describe('Number of rows/columns moved'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Move rows or columns within a sheet to a new position. Use 0-based indices. The destinationIndex is where the rows/columns will be moved TO.',\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, dimension, startIndex, endIndex, destinationIndex }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.dimensions.move called', { id, gid, dimension, startIndex, endIndex, destinationIndex });\n\n // Validate indices\n if (startIndex >= endIndex) {\n throw new McpError(ErrorCode.InvalidParams, `startIndex (${startIndex}) must be less than endIndex (${endIndex})`);\n }\n\n // Check if destination is within source range (invalid move)\n if (destinationIndex > startIndex && destinationIndex < endIndex) {\n throw new McpError(ErrorCode.InvalidParams, `destinationIndex (${destinationIndex}) cannot be within the source range (${startIndex}-${endIndex})`);\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 move', { id, gid, dimension });\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 logger.info('sheets.dimensions.move executing', { spreadsheetId: id, sheetTitle, dimension, startIndex, endIndex, destinationIndex });\n\n // Execute the move dimension request\n await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: [\n {\n moveDimension: {\n source: {\n sheetId: sheetGid,\n dimension,\n startIndex,\n endIndex,\n },\n destinationIndex,\n },\n },\n ],\n },\n });\n\n const movedCount = endIndex - startIndex;\n\n logger.info('sheets.dimensions.move completed successfully', {\n spreadsheetId: id,\n sheetTitle,\n dimension,\n movedCount,\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 dimension,\n sourceRange: {\n startIndex,\n endIndex,\n },\n destinationIndex,\n movedCount,\n };\n\n return {\n content: [{ type: 'text' as const, text: JSON.stringify(result) }],\n structuredContent: { result },\n };\n } catch (error) {\n if (error instanceof McpError) {\n throw error;\n }\n const message = error instanceof Error ? error.message : String(error);\n logger.error('Move operation failed', { id, gid, dimension, startIndex, endIndex, destinationIndex, error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error moving ${dimension.toLowerCase()}: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'dimensions-move',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","gid","SheetGidSchema","dimension","enum","describe","startIndex","number","int","nonnegative","endIndex","positive","destinationIndex","successBranchSchema","type","literal","SpreadsheetIdOutput","SheetGidOutput","spreadsheetTitle","string","spreadsheetUrl","sheetTitle","sheetUrl","sourceRange","movedCount","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetData","sheet","sheets","spreadsheetResponse","sheetGid","error","message","info","McpError","ErrorCode","InvalidParams","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","properties","title","find","s","String","sheetId","batchUpdate","requestBody","requests","moveDimension","source","content","text","JSON","stringify","structuredContent","Error","InternalError","toLowerCase","stack","undefined","name"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/dimensions-move.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 { SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.ts';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n dimension: z.enum(['ROWS', 'COLUMNS']).describe('Whether to move rows or columns'),\n startIndex: z.number().int().nonnegative().describe('Starting index of the range to move (0-based)'),\n endIndex: z.number().int().positive().describe('Ending index of the range to move (0-based, exclusive)'),\n destinationIndex: z.number().int().nonnegative().describe('Index where the rows/columns will be moved to (0-based)'),\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 spreadsheet'),\n spreadsheetUrl: z.string().describe('URL of the spreadsheet'),\n sheetTitle: z.string().describe('Title of the sheet'),\n sheetUrl: z.string().describe('URL of the sheet'),\n dimension: z.enum(['ROWS', 'COLUMNS']).describe('Dimension that was moved'),\n sourceRange: z.object({\n startIndex: z.number().describe('Starting index of the moved range'),\n endIndex: z.number().describe('Ending index of the moved range'),\n }),\n destinationIndex: z.number().describe('Index where the range was moved to'),\n movedCount: z.number().describe('Number of rows/columns moved'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Move rows or columns within a sheet to a new position. Use 0-based indices. The destinationIndex is where the rows/columns will be moved TO.',\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, dimension, startIndex, endIndex, destinationIndex }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.dimensions.move called', { id, gid, dimension, startIndex, endIndex, destinationIndex });\n\n // Validate indices\n if (startIndex >= endIndex) {\n throw new McpError(ErrorCode.InvalidParams, `startIndex (${startIndex}) must be less than endIndex (${endIndex})`);\n }\n\n // Check if destination is within source range (invalid move)\n if (destinationIndex > startIndex && destinationIndex < endIndex) {\n throw new McpError(ErrorCode.InvalidParams, `destinationIndex (${destinationIndex}) cannot be within the source range (${startIndex}-${endIndex})`);\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 move', { id, gid, dimension });\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 logger.info('sheets.dimensions.move executing', { spreadsheetId: id, sheetTitle, dimension, startIndex, endIndex, destinationIndex });\n\n // Execute the move dimension request\n await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: [\n {\n moveDimension: {\n source: {\n sheetId: sheetGid,\n dimension,\n startIndex,\n endIndex,\n },\n destinationIndex,\n },\n },\n ],\n },\n });\n\n const movedCount = endIndex - startIndex;\n\n logger.info('sheets.dimensions.move completed successfully', {\n spreadsheetId: id,\n sheetTitle,\n dimension,\n movedCount,\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 dimension,\n sourceRange: {\n startIndex,\n endIndex,\n },\n destinationIndex,\n movedCount,\n };\n\n return {\n content: [{ type: 'text' as const, text: JSON.stringify(result) }],\n structuredContent: { result },\n };\n } catch (error) {\n if (error instanceof McpError) {\n throw error;\n }\n const message = error instanceof Error ? error.message : String(error);\n logger.error('Move operation failed', { id, gid, dimension, startIndex, endIndex, destinationIndex, error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error moving ${dimension.toLowerCase()}: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'dimensions-move',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","gid","SheetGidSchema","dimension","enum","describe","startIndex","number","int","nonnegative","endIndex","positive","destinationIndex","successBranchSchema","type","literal","SpreadsheetIdOutput","SheetGidOutput","spreadsheetTitle","string","spreadsheetUrl","sheetTitle","sheetUrl","sourceRange","movedCount","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetData","sheet","sheets","spreadsheetResponse","sheetGid","error","message","info","McpError","ErrorCode","InvalidParams","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","properties","title","find","s","String","sheetId","batchUpdate","requestBody","requests","moveDimension","source","content","text","JSON","stringify","structuredContent","Error","InternalError","toLowerCase","stack","undefined","name"],"mappings":"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"}
|
|
@@ -10,110 +10,110 @@ function _export(target, all) {
|
|
|
10
10
|
}
|
|
11
11
|
_export(exports, {
|
|
12
12
|
get cellsFormat () {
|
|
13
|
-
return
|
|
13
|
+
return _cellsformatts.default;
|
|
14
14
|
},
|
|
15
15
|
get chartCreate () {
|
|
16
|
-
return
|
|
16
|
+
return _chartcreatets.default;
|
|
17
17
|
},
|
|
18
18
|
get columnsGet () {
|
|
19
|
-
return
|
|
19
|
+
return _columnsgetts.default;
|
|
20
20
|
},
|
|
21
21
|
get columnsUpdate () {
|
|
22
|
-
return
|
|
22
|
+
return _columnsupdatets.default;
|
|
23
23
|
},
|
|
24
24
|
get csvGetColumns () {
|
|
25
|
-
return
|
|
25
|
+
return _csvgetcolumnsts.default;
|
|
26
26
|
},
|
|
27
27
|
get dimensionsBatchUpdate () {
|
|
28
|
-
return
|
|
28
|
+
return _dimensionsbatchupdatets.default;
|
|
29
29
|
},
|
|
30
30
|
get dimensionsMove () {
|
|
31
|
-
return
|
|
31
|
+
return _dimensionsmovets.default;
|
|
32
32
|
},
|
|
33
33
|
get rowsAppend () {
|
|
34
|
-
return
|
|
34
|
+
return _rowsappendts.default;
|
|
35
35
|
},
|
|
36
36
|
get rowsCsvAppend () {
|
|
37
|
-
return
|
|
37
|
+
return _rowscsvappendts.default;
|
|
38
38
|
},
|
|
39
39
|
get rowsGet () {
|
|
40
|
-
return
|
|
40
|
+
return _rowsgetts.default;
|
|
41
41
|
},
|
|
42
42
|
get sheetCopy () {
|
|
43
|
-
return
|
|
43
|
+
return _sheetcopyts.default;
|
|
44
44
|
},
|
|
45
45
|
get sheetCopyTo () {
|
|
46
|
-
return
|
|
46
|
+
return _sheetcopytots.default;
|
|
47
47
|
},
|
|
48
48
|
get sheetCreate () {
|
|
49
|
-
return
|
|
49
|
+
return _sheetcreatets.default;
|
|
50
50
|
},
|
|
51
51
|
get sheetDelete () {
|
|
52
|
-
return
|
|
52
|
+
return _sheetdeletets.default;
|
|
53
53
|
},
|
|
54
54
|
get sheetFind () {
|
|
55
|
-
return
|
|
55
|
+
return _sheetfindts.default;
|
|
56
56
|
},
|
|
57
57
|
get sheetRename () {
|
|
58
|
-
return
|
|
58
|
+
return _sheetrenamets.default;
|
|
59
59
|
},
|
|
60
60
|
get spreadsheetCopy () {
|
|
61
|
-
return
|
|
61
|
+
return _spreadsheetcopyts.default;
|
|
62
62
|
},
|
|
63
63
|
get spreadsheetCreate () {
|
|
64
|
-
return
|
|
64
|
+
return _spreadsheetcreatets.default;
|
|
65
65
|
},
|
|
66
66
|
get spreadsheetFind () {
|
|
67
|
-
return
|
|
67
|
+
return _spreadsheetfindts.default;
|
|
68
68
|
},
|
|
69
69
|
get spreadsheetRename () {
|
|
70
|
-
return
|
|
70
|
+
return _spreadsheetrenamets.default;
|
|
71
71
|
},
|
|
72
72
|
get validationSet () {
|
|
73
|
-
return
|
|
73
|
+
return _validationsetts.default;
|
|
74
74
|
},
|
|
75
75
|
get valuesBatchUpdate () {
|
|
76
|
-
return
|
|
76
|
+
return _valuesbatchupdatets.default;
|
|
77
77
|
},
|
|
78
78
|
get valuesClear () {
|
|
79
|
-
return
|
|
79
|
+
return _valuesclearts.default;
|
|
80
80
|
},
|
|
81
81
|
get valuesCsvUpdate () {
|
|
82
|
-
return
|
|
82
|
+
return _valuescsvupdatets.default;
|
|
83
83
|
},
|
|
84
84
|
get valuesReplace () {
|
|
85
|
-
return
|
|
85
|
+
return _valuesreplacets.default;
|
|
86
86
|
},
|
|
87
87
|
get valuesSearch () {
|
|
88
|
-
return
|
|
88
|
+
return _valuessearchts.default;
|
|
89
89
|
}
|
|
90
90
|
});
|
|
91
|
-
var
|
|
92
|
-
var
|
|
93
|
-
var
|
|
94
|
-
var
|
|
95
|
-
var
|
|
96
|
-
var
|
|
97
|
-
var
|
|
98
|
-
var
|
|
99
|
-
var
|
|
100
|
-
var
|
|
101
|
-
var
|
|
102
|
-
var
|
|
103
|
-
var
|
|
104
|
-
var
|
|
105
|
-
var
|
|
106
|
-
var
|
|
107
|
-
var
|
|
108
|
-
var
|
|
109
|
-
var
|
|
110
|
-
var
|
|
111
|
-
var
|
|
112
|
-
var
|
|
113
|
-
var
|
|
114
|
-
var
|
|
115
|
-
var
|
|
116
|
-
var
|
|
91
|
+
var _cellsformatts = /*#__PURE__*/ _interop_require_default(require("./cells-format.js"));
|
|
92
|
+
var _chartcreatets = /*#__PURE__*/ _interop_require_default(require("./chart-create.js"));
|
|
93
|
+
var _columnsgetts = /*#__PURE__*/ _interop_require_default(require("./columns-get.js"));
|
|
94
|
+
var _columnsupdatets = /*#__PURE__*/ _interop_require_default(require("./columns-update.js"));
|
|
95
|
+
var _csvgetcolumnsts = /*#__PURE__*/ _interop_require_default(require("./csv-get-columns.js"));
|
|
96
|
+
var _dimensionsbatchupdatets = /*#__PURE__*/ _interop_require_default(require("./dimensions-batch-update.js"));
|
|
97
|
+
var _dimensionsmovets = /*#__PURE__*/ _interop_require_default(require("./dimensions-move.js"));
|
|
98
|
+
var _rowsappendts = /*#__PURE__*/ _interop_require_default(require("./rows-append.js"));
|
|
99
|
+
var _rowscsvappendts = /*#__PURE__*/ _interop_require_default(require("./rows-csv-append.js"));
|
|
100
|
+
var _rowsgetts = /*#__PURE__*/ _interop_require_default(require("./rows-get.js"));
|
|
101
|
+
var _sheetcopyts = /*#__PURE__*/ _interop_require_default(require("./sheet-copy.js"));
|
|
102
|
+
var _sheetcopytots = /*#__PURE__*/ _interop_require_default(require("./sheet-copy-to.js"));
|
|
103
|
+
var _sheetcreatets = /*#__PURE__*/ _interop_require_default(require("./sheet-create.js"));
|
|
104
|
+
var _sheetdeletets = /*#__PURE__*/ _interop_require_default(require("./sheet-delete.js"));
|
|
105
|
+
var _sheetfindts = /*#__PURE__*/ _interop_require_default(require("./sheet-find.js"));
|
|
106
|
+
var _sheetrenamets = /*#__PURE__*/ _interop_require_default(require("./sheet-rename.js"));
|
|
107
|
+
var _spreadsheetcopyts = /*#__PURE__*/ _interop_require_default(require("./spreadsheet-copy.js"));
|
|
108
|
+
var _spreadsheetcreatets = /*#__PURE__*/ _interop_require_default(require("./spreadsheet-create.js"));
|
|
109
|
+
var _spreadsheetfindts = /*#__PURE__*/ _interop_require_default(require("./spreadsheet-find.js"));
|
|
110
|
+
var _spreadsheetrenamets = /*#__PURE__*/ _interop_require_default(require("./spreadsheet-rename.js"));
|
|
111
|
+
var _validationsetts = /*#__PURE__*/ _interop_require_default(require("./validation-set.js"));
|
|
112
|
+
var _valuesbatchupdatets = /*#__PURE__*/ _interop_require_default(require("./values-batch-update.js"));
|
|
113
|
+
var _valuesclearts = /*#__PURE__*/ _interop_require_default(require("./values-clear.js"));
|
|
114
|
+
var _valuescsvupdatets = /*#__PURE__*/ _interop_require_default(require("./values-csv-update.js"));
|
|
115
|
+
var _valuesreplacets = /*#__PURE__*/ _interop_require_default(require("./values-replace.js"));
|
|
116
|
+
var _valuessearchts = /*#__PURE__*/ _interop_require_default(require("./values-search.js"));
|
|
117
117
|
function _interop_require_default(obj) {
|
|
118
118
|
return obj && obj.__esModule ? obj : {
|
|
119
119
|
default: obj
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/Projects/
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/index.ts"],"sourcesContent":["export { default as cellsFormat } from './cells-format.ts';\nexport { default as chartCreate } from './chart-create.ts';\nexport { default as columnsGet } from './columns-get.ts';\nexport { default as columnsUpdate } from './columns-update.ts';\nexport { default as csvGetColumns } from './csv-get-columns.ts';\nexport { default as dimensionsBatchUpdate } from './dimensions-batch-update.ts';\nexport { default as dimensionsMove } from './dimensions-move.ts';\nexport { default as rowsAppend } from './rows-append.ts';\nexport { default as rowsCsvAppend } from './rows-csv-append.ts';\nexport { default as rowsGet } from './rows-get.ts';\nexport { default as sheetCopy } from './sheet-copy.ts';\nexport { default as sheetCopyTo } from './sheet-copy-to.ts';\nexport { default as sheetCreate } from './sheet-create.ts';\nexport { default as sheetDelete } from './sheet-delete.ts';\nexport { default as sheetFind } from './sheet-find.ts';\nexport { default as sheetRename } from './sheet-rename.ts';\nexport { default as spreadsheetCopy } from './spreadsheet-copy.ts';\nexport { default as spreadsheetCreate } from './spreadsheet-create.ts';\nexport { default as spreadsheetFind } from './spreadsheet-find.ts';\nexport { default as spreadsheetRename } from './spreadsheet-rename.ts';\nexport { default as validationSet } from './validation-set.ts';\nexport { default as valuesBatchUpdate } from './values-batch-update.ts';\nexport { default as valuesClear } from './values-clear.ts';\nexport { default as valuesCsvUpdate } from './values-csv-update.ts';\nexport { default as valuesReplace } from './values-replace.ts';\nexport { default as valuesSearch } from './values-search.ts';\n"],"names":["cellsFormat","chartCreate","columnsGet","columnsUpdate","csvGetColumns","dimensionsBatchUpdate","dimensionsMove","rowsAppend","rowsCsvAppend","rowsGet","sheetCopy","sheetCopyTo","sheetCreate","sheetDelete","sheetFind","sheetRename","spreadsheetCopy","spreadsheetCreate","spreadsheetFind","spreadsheetRename","validationSet","valuesBatchUpdate","valuesClear","valuesCsvUpdate","valuesReplace","valuesSearch"],"mappings":";;;;;;;;;;;QAAoBA;eAAAA,sBAAW;;QACXC;eAAAA,sBAAW;;QACXC;eAAAA,qBAAU;;QACVC;eAAAA,wBAAa;;QACbC;eAAAA,wBAAa;;QACbC;eAAAA,gCAAqB;;QACrBC;eAAAA,yBAAc;;QACdC;eAAAA,qBAAU;;QACVC;eAAAA,wBAAa;;QACbC;eAAAA,kBAAO;;QACPC;eAAAA,oBAAS;;QACTC;eAAAA,sBAAW;;QACXC;eAAAA,sBAAW;;QACXC;eAAAA,sBAAW;;QACXC;eAAAA,oBAAS;;QACTC;eAAAA,sBAAW;;QACXC;eAAAA,0BAAe;;QACfC;eAAAA,4BAAiB;;QACjBC;eAAAA,0BAAe;;QACfC;eAAAA,4BAAiB;;QACjBC;eAAAA,wBAAa;;QACbC;eAAAA,4BAAiB;;QACjBC;eAAAA,sBAAW;;QACXC;eAAAA,0BAAe;;QACfC;eAAAA,wBAAa;;QACbC;eAAAA,uBAAY;;;oEAzBO;oEACA;mEACD;sEACG;sEACA;8EACQ;uEACP;mEACJ;sEACG;gEACN;kEACE;oEACE;oEACA;oEACA;kEACF;oEACE;wEACI;0EACE;wEACF;0EACE;sEACJ;0EACI;oEACN;wEACI;sEACF;qEACD"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/Projects/
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/lib/dimension-operations.ts"],"sourcesContent":["// Google Sheets dimension constants\nexport const DEFAULT_APPEND_COUNT = 1; // Default number of rows/columns to append\nexport const DEFAULT_ROW_COUNT = 1000; // Google Sheets default for new sheets\nexport const DEFAULT_COLUMN_COUNT = 26; // Google Sheets default for new sheets (A-Z)\nexport const MAX_ROW_COUNT = 10000000; // Google Sheets maximum\nexport const MAX_COLUMN_COUNT = 18278; // Google Sheets maximum (ZZZ in base-26)\n\n// Type definitions for dimension operations\nexport type DimensionOperation = 'insertDimension' | 'deleteDimension' | 'appendDimension';\nexport type DimensionType = 'ROWS' | 'COLUMNS';\n\nexport interface DimensionRequest {\n operation: DimensionOperation;\n dimension: DimensionType;\n startIndex: number;\n endIndex?: number;\n inheritFromBefore?: boolean;\n}\n\n// Helper function to sort operations for optimal execution order\nexport function sortOperations(requests: DimensionRequest[]): DimensionRequest[] {\n // Sort by: 1) operation type (delete -> insert -> append), 2) proper index ordering to prevent conflicts\n return [...requests].sort((a, b) => {\n // Operation type priority: deleteDimension (0), insertDimension (1), appendDimension (2)\n const operationPriority = {\n deleteDimension: 0,\n insertDimension: 1,\n appendDimension: 2,\n };\n\n const aPriority = operationPriority[a.operation];\n const bPriority = operationPriority[b.operation];\n\n if (aPriority !== bPriority) {\n return aPriority - bPriority;\n }\n\n // Within same operation type, sort by appropriate index\n if (a.operation === 'deleteDimension') {\n // For deletes, process higher START indices first to avoid index shifting issues\n // This ensures we delete from the end towards the beginning\n const aStart = a.startIndex;\n const bStart = b.startIndex;\n if (aStart !== bStart) {\n return bStart - aStart; // Higher start index first\n }\n // If start indices are equal, process higher end index first for consistency\n const aEnd = a.endIndex ?? a.startIndex + 1;\n const bEnd = b.endIndex ?? b.startIndex + 1;\n return bEnd - aEnd;\n }\n // For inserts and appends, process lower indices first\n // This ensures we modify from the beginning towards the end\n return a.startIndex - b.startIndex;\n });\n}\n\n// Helper function to build Google Sheets API dimension request\nexport function buildDimensionRequest(operation: DimensionRequest, sheetId: number) {\n const { operation: operationType, dimension, startIndex, endIndex, inheritFromBefore } = operation;\n\n const dimensionRange = {\n sheetId,\n dimension,\n startIndex,\n ...(endIndex !== undefined && { endIndex }),\n };\n\n switch (operationType) {\n case 'insertDimension':\n return {\n insertDimension: {\n range: dimensionRange,\n inheritFromBefore: inheritFromBefore ?? false,\n },\n };\n case 'deleteDimension':\n return {\n deleteDimension: {\n range: dimensionRange,\n },\n };\n case 'appendDimension':\n return {\n appendDimension: {\n sheetId,\n dimension,\n length: DEFAULT_APPEND_COUNT,\n },\n };\n default:\n throw new Error(`Unsupported operation type: ${operationType}`);\n }\n}\n\n// Helper function to calculate affected count for each operation\nexport function calculateAffectedCount(operation: DimensionRequest): number {\n const { operation: operationType, startIndex, endIndex } = operation;\n\n switch (operationType) {\n case 'insertDimension':\n case 'deleteDimension':\n return endIndex !== undefined ? endIndex - startIndex : 1;\n case 'appendDimension':\n return DEFAULT_APPEND_COUNT;\n default:\n return 0;\n }\n}\n"],"names":["DEFAULT_APPEND_COUNT","DEFAULT_COLUMN_COUNT","DEFAULT_ROW_COUNT","MAX_COLUMN_COUNT","MAX_ROW_COUNT","buildDimensionRequest","calculateAffectedCount","sortOperations","requests","sort","a","b","operationPriority","deleteDimension","insertDimension","appendDimension","aPriority","operation","bPriority","aStart","startIndex","bStart","aEnd","endIndex","bEnd","sheetId","operationType","dimension","inheritFromBefore","dimensionRange","undefined","range","length","Error"],"mappings":"AAAA,oCAAoC;;;;;;;;;;;;QACvBA;eAAAA;;QAEAC;eAAAA;;QADAC;eAAAA;;QAGAC;eAAAA;;QADAC;eAAAA;;QAsDGC;eAAAA;;QAsCAC;eAAAA;;QA5EAC;eAAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAnBT,IAAMP,uBAAuB,GAAG,2CAA2C;AAC3E,IAAME,oBAAoB,MAAM,uCAAuC;AACvE,IAAMD,uBAAuB,IAAI,6CAA6C;AAC9E,IAAMG,gBAAgB,UAAU,wBAAwB;AACxD,IAAMD,mBAAmB,OAAO,yCAAyC;AAezE,SAASI,eAAeC,QAA4B;IACzD,yGAAyG;IACzG,OAAO,AAAC,qBAAGA,UAAUC,IAAI,CAAC,SAACC,GAAGC;QAC5B,yFAAyF;QACzF,IAAMC,oBAAoB;YACxBC,iBAAiB;YACjBC,iBAAiB;YACjBC,iBAAiB;QACnB;QAEA,IAAMC,YAAYJ,iBAAiB,CAACF,EAAEO,SAAS,CAAC;QAChD,IAAMC,YAAYN,iBAAiB,CAACD,EAAEM,SAAS,CAAC;QAEhD,IAAID,cAAcE,WAAW;YAC3B,OAAOF,YAAYE;QACrB;QAEA,wDAAwD;QACxD,IAAIR,EAAEO,SAAS,KAAK,mBAAmB;gBASxBP,aACAC;YATb,iFAAiF;YACjF,4DAA4D;YAC5D,IAAMQ,SAAST,EAAEU,UAAU;YAC3B,IAAMC,SAASV,EAAES,UAAU;YAC3B,IAAID,WAAWE,QAAQ;gBACrB,OAAOA,SAASF,QAAQ,2BAA2B;YACrD;YACA,6EAA6E;YAC7E,IAAMG,QAAOZ,cAAAA,EAAEa,QAAQ,cAAVb,yBAAAA,cAAcA,EAAEU,UAAU,GAAG;YAC1C,IAAMI,QAAOb,cAAAA,EAAEY,QAAQ,cAAVZ,yBAAAA,cAAcA,EAAES,UAAU,GAAG;YAC1C,OAAOI,OAAOF;QAChB;QACA,uDAAuD;QACvD,4DAA4D;QAC5D,OAAOZ,EAAEU,UAAU,GAAGT,EAAES,UAAU;IACpC;AACF;AAGO,SAASf,sBAAsBY,SAA2B,EAAEQ,OAAe;IAChF,IAAQR,AAAWS,gBAAsET,UAAjFA,WAA0BU,YAAuDV,UAAvDU,WAAWP,aAA4CH,UAA5CG,YAAYG,WAAgCN,UAAhCM,UAAUK,oBAAsBX,UAAtBW;IAEnE,IAAMC,iBAAiB;QACrBJ,SAAAA;QACAE,WAAAA;QACAP,YAAAA;OACIG,aAAaO,aAAa;QAAEP,UAAAA;IAAS;IAG3C,OAAQG;QACN,KAAK;YACH,OAAO;gBACLZ,iBAAiB;oBACfiB,OAAOF;oBACPD,iBAAiB,EAAEA,8BAAAA,+BAAAA,oBAAqB;gBAC1C;YACF;QACF,KAAK;YACH,OAAO;gBACLf,iBAAiB;oBACfkB,OAAOF;gBACT;YACF;QACF,KAAK;YACH,OAAO;gBACLd,iBAAiB;oBACfU,SAAAA;oBACAE,WAAAA;oBACAK,QAAQhC;gBACV;YACF;QACF;YACE,MAAM,IAAIiC,MAAM,AAAC,+BAA4C,OAAdP;IACnD;AACF;AAGO,SAASpB,uBAAuBW,SAA2B;IAChE,IAAQA,AAAWS,gBAAwCT,UAAnDA,WAA0BG,aAAyBH,UAAzBG,YAAYG,WAAaN,UAAbM;IAE9C,OAAQG;QACN,KAAK;QACL,KAAK;YACH,OAAOH,aAAaO,YAAYP,WAAWH,aAAa;QAC1D,KAAK;YACH,OAAOpB;QACT;YACE,OAAO;IACX;AACF"}
|
|
@@ -12,9 +12,9 @@ var _oauthgoogle = require("@mcp-z/oauth-google");
|
|
|
12
12
|
var _types = require("@modelcontextprotocol/sdk/types.js");
|
|
13
13
|
var _googleapis = require("googleapis");
|
|
14
14
|
var _zod = require("zod");
|
|
15
|
-
var
|
|
16
|
-
var
|
|
17
|
-
var
|
|
15
|
+
var _indexts = require("../../schemas/index.js");
|
|
16
|
+
var _dataoperationsts = require("../../spreadsheet/data-operations.js");
|
|
17
|
+
var _sheetoperationsts = require("../../spreadsheet/sheet-operations.js");
|
|
18
18
|
function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
|
|
19
19
|
try {
|
|
20
20
|
var info = gen[key](arg);
|
|
@@ -152,8 +152,8 @@ function _ts_generator(thisArg, body) {
|
|
|
152
152
|
}
|
|
153
153
|
var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
|
|
154
154
|
var inputSchema = _zod.z.object({
|
|
155
|
-
id:
|
|
156
|
-
gid:
|
|
155
|
+
id: _indexts.SpreadsheetIdSchema,
|
|
156
|
+
gid: _indexts.SheetGidSchema,
|
|
157
157
|
rows: _zod.z.array(_zod.z.array(_zod.z.union([
|
|
158
158
|
_zod.z.string(),
|
|
159
159
|
_zod.z.number(),
|
|
@@ -165,8 +165,8 @@ var inputSchema = _zod.z.object({
|
|
|
165
165
|
});
|
|
166
166
|
var successBranchSchema = _zod.z.object({
|
|
167
167
|
type: _zod.z.literal('success'),
|
|
168
|
-
id:
|
|
169
|
-
gid:
|
|
168
|
+
id: _indexts.SpreadsheetIdOutput,
|
|
169
|
+
gid: _indexts.SheetGidOutput,
|
|
170
170
|
sheetTitle: _zod.z.string().describe('Sheet tab name'),
|
|
171
171
|
updatedRows: _zod.z.number().describe('Number of rows appended'),
|
|
172
172
|
rowsSkipped: _zod.z.number().optional().describe('Number of duplicate rows skipped'),
|
|
@@ -238,7 +238,7 @@ function handler(_0, _1) {
|
|
|
238
238
|
];
|
|
239
239
|
return [
|
|
240
240
|
4,
|
|
241
|
-
(0,
|
|
241
|
+
(0, _sheetoperationsts.ensureTabAndHeaders)(sheets, {
|
|
242
242
|
spreadsheetId: id,
|
|
243
243
|
sheetTitle: sheetTitle,
|
|
244
244
|
requiredHeader: headers,
|
|
@@ -251,7 +251,7 @@ function handler(_0, _1) {
|
|
|
251
251
|
currentHeaders = headerResult.header;
|
|
252
252
|
existingKeySet = headerResult.keySet;
|
|
253
253
|
// Map data rows to match current header order
|
|
254
|
-
processedRows = (0,
|
|
254
|
+
processedRows = (0, _dataoperationsts.mapRowsToHeader)({
|
|
255
255
|
rows: rows,
|
|
256
256
|
header: currentHeaders,
|
|
257
257
|
canonical: headers
|
|
@@ -263,7 +263,7 @@ function handler(_0, _1) {
|
|
|
263
263
|
effectiveKeyColumns = currentHeaders.length === 0 && deduplicateBy && deduplicateBy.length > 0 ? [] : deduplicateBy || [];
|
|
264
264
|
return [
|
|
265
265
|
4,
|
|
266
|
-
(0,
|
|
266
|
+
(0, _dataoperationsts.appendRows)(sheets, {
|
|
267
267
|
spreadsheetId: id,
|
|
268
268
|
sheetTitle: sheetTitle,
|
|
269
269
|
rows: processedRows,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/rows-append.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 { SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\nimport { appendRows, mapRowsToHeader } from '../../spreadsheet/data-operations.js';\nimport { ensureTabAndHeaders } from '../../spreadsheet/sheet-operations.js';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n rows: z\n .array(z.array(z.union([z.string(), z.number(), z.boolean(), z.null()])).min(1))\n .min(1)\n .describe('Array of rows, where each row is an array of cell values. Use null to skip a cell (preserve existing value), empty string \"\" to clear it.'),\n headers: z.array(z.string()).optional().describe('Column order/names - used for blank sheets or column mapping'),\n deduplicateBy: z.array(z.string()).optional().describe('Column names to use as composite key for deduplication'),\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n sheetTitle: z.string().describe('Sheet tab name'),\n updatedRows: z.number().describe('Number of rows appended'),\n rowsSkipped: z.number().optional().describe('Number of duplicate rows skipped'),\n sheetUrl: z.string().optional().describe('URL to view the sheet'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Add new rows to the bottom of an existing sheet with smart header handling and optional deduplication. BEST FOR: Structured database operations where spreadsheet has headers defining schema and rows represent records.',\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, rows, headers, deduplicateBy }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.rows.append called', { id, gid, rowCount: rows.length, headers, deduplicateBy });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // Get sheet details using the gid\n const spreadsheetResponse = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'sheets.properties.sheetId,sheets.properties.title',\n });\n\n const sheet = spreadsheetResponse.data.sheets?.find((s) => String(s.properties?.sheetId) === gid);\n\n if (!sheet) {\n throw new McpError(ErrorCode.InvalidParams, 'Sheet not found');\n }\n\n const sheetTitle = sheet?.properties?.title ?? '';\n\n // Smart header handling and data processing\n let processedRows = rows;\n let currentHeaders: string[] = [];\n let rowsSkipped = 0;\n let existingKeySet: Set<string> = new Set();\n\n if (headers && headers.length > 0) {\n // Use ensureTabAndHeaders to handle header logic\n const headerResult = await ensureTabAndHeaders(sheets, {\n spreadsheetId: id,\n sheetTitle,\n requiredHeader: headers,\n keyColumns: deduplicateBy || [],\n logger,\n });\n\n currentHeaders = headerResult.header;\n existingKeySet = headerResult.keySet;\n\n // Map data rows to match current header order\n processedRows = mapRowsToHeader({ rows, header: currentHeaders, canonical: headers }) as (string | number | boolean | null)[][];\n }\n\n // Append rows with optional deduplication\n // If headers are empty but deduplication is requested, skip deduplication for empty spreadsheets\n const effectiveKeyColumns = currentHeaders.length === 0 && deduplicateBy && deduplicateBy.length > 0 ? [] : deduplicateBy || [];\n\n const appendResult = await appendRows(sheets, {\n spreadsheetId: id,\n sheetTitle,\n rows: processedRows,\n keySet: existingKeySet,\n keyColumns: effectiveKeyColumns,\n header: currentHeaders,\n logger,\n });\n\n rowsSkipped = appendResult.rowsSkipped || 0;\n // Only count data rows, not headers - headers are metadata, not items\n const updatedRows = appendResult.updatedRows || 0;\n\n const sheetUrl = `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${gid}`;\n\n logger.info('sheets.rows.append completed', { id, gid, updatedRows, rowsSkipped });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid,\n sheetTitle,\n updatedRows,\n rowsSkipped, // Always include rowsSkipped, even when 0\n sheetUrl,\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('sheets.rows.append error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error appending rows: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'rows-append',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","gid","SheetGidSchema","rows","array","union","string","number","boolean","null","min","describe","headers","optional","deduplicateBy","successBranchSchema","type","literal","SpreadsheetIdOutput","SheetGidOutput","sheetTitle","updatedRows","rowsSkipped","sheetUrl","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetResponse","sheet","sheets","processedRows","currentHeaders","existingKeySet","headerResult","effectiveKeyColumns","appendResult","error","message","info","rowCount","length","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","find","s","String","properties","sheetId","McpError","ErrorCode","InvalidParams","title","Set","ensureTabAndHeaders","requiredHeader","keyColumns","header","keySet","mapRowsToHeader","canonical","appendRows","content","text","JSON","stringify","structuredContent","Error","InternalError","stack","undefined","name"],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/rows-append.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 { SheetGidOutput, SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.ts';\nimport { appendRows, mapRowsToHeader } from '../../spreadsheet/data-operations.ts';\nimport { ensureTabAndHeaders } from '../../spreadsheet/sheet-operations.ts';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gid: SheetGidSchema,\n rows: z\n .array(z.array(z.union([z.string(), z.number(), z.boolean(), z.null()])).min(1))\n .min(1)\n .describe('Array of rows, where each row is an array of cell values. Use null to skip a cell (preserve existing value), empty string \"\" to clear it.'),\n headers: z.array(z.string()).optional().describe('Column order/names - used for blank sheets or column mapping'),\n deduplicateBy: z.array(z.string()).optional().describe('Column names to use as composite key for deduplication'),\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n sheetTitle: z.string().describe('Sheet tab name'),\n updatedRows: z.number().describe('Number of rows appended'),\n rowsSkipped: z.number().optional().describe('Number of duplicate rows skipped'),\n sheetUrl: z.string().optional().describe('URL to view the sheet'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Add new rows to the bottom of an existing sheet with smart header handling and optional deduplication. BEST FOR: Structured database operations where spreadsheet has headers defining schema and rows represent records.',\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, rows, headers, deduplicateBy }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.rows.append called', { id, gid, rowCount: rows.length, headers, deduplicateBy });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // Get sheet details using the gid\n const spreadsheetResponse = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'sheets.properties.sheetId,sheets.properties.title',\n });\n\n const sheet = spreadsheetResponse.data.sheets?.find((s) => String(s.properties?.sheetId) === gid);\n\n if (!sheet) {\n throw new McpError(ErrorCode.InvalidParams, 'Sheet not found');\n }\n\n const sheetTitle = sheet?.properties?.title ?? '';\n\n // Smart header handling and data processing\n let processedRows = rows;\n let currentHeaders: string[] = [];\n let rowsSkipped = 0;\n let existingKeySet: Set<string> = new Set();\n\n if (headers && headers.length > 0) {\n // Use ensureTabAndHeaders to handle header logic\n const headerResult = await ensureTabAndHeaders(sheets, {\n spreadsheetId: id,\n sheetTitle,\n requiredHeader: headers,\n keyColumns: deduplicateBy || [],\n logger,\n });\n\n currentHeaders = headerResult.header;\n existingKeySet = headerResult.keySet;\n\n // Map data rows to match current header order\n processedRows = mapRowsToHeader({ rows, header: currentHeaders, canonical: headers }) as (string | number | boolean | null)[][];\n }\n\n // Append rows with optional deduplication\n // If headers are empty but deduplication is requested, skip deduplication for empty spreadsheets\n const effectiveKeyColumns = currentHeaders.length === 0 && deduplicateBy && deduplicateBy.length > 0 ? [] : deduplicateBy || [];\n\n const appendResult = await appendRows(sheets, {\n spreadsheetId: id,\n sheetTitle,\n rows: processedRows,\n keySet: existingKeySet,\n keyColumns: effectiveKeyColumns,\n header: currentHeaders,\n logger,\n });\n\n rowsSkipped = appendResult.rowsSkipped || 0;\n // Only count data rows, not headers - headers are metadata, not items\n const updatedRows = appendResult.updatedRows || 0;\n\n const sheetUrl = `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${gid}`;\n\n logger.info('sheets.rows.append completed', { id, gid, updatedRows, rowsSkipped });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid,\n sheetTitle,\n updatedRows,\n rowsSkipped, // Always include rowsSkipped, even when 0\n sheetUrl,\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('sheets.rows.append error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error appending rows: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'rows-append',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","gid","SheetGidSchema","rows","array","union","string","number","boolean","null","min","describe","headers","optional","deduplicateBy","successBranchSchema","type","literal","SpreadsheetIdOutput","SheetGidOutput","sheetTitle","updatedRows","rowsSkipped","sheetUrl","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetResponse","sheet","sheets","processedRows","currentHeaders","existingKeySet","headerResult","effectiveKeyColumns","appendResult","error","message","info","rowCount","length","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","find","s","String","properties","sheetId","McpError","ErrorCode","InvalidParams","title","Set","ensureTabAndHeaders","requiredHeader","keyColumns","header","keySet","mapRowsToHeader","canonical","appendRows","content","text","JSON","stringify","structuredContent","Error","InternalError","stack","undefined","name"],"mappings":"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"}
|