@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.
Files changed (150) hide show
  1. package/README.md +32 -3
  2. package/bin/server.js +1 -1
  3. package/dist/cjs/constants.js.map +1 -1
  4. package/dist/cjs/index.js +13 -13
  5. package/dist/cjs/index.js.map +1 -1
  6. package/dist/cjs/lib/create-store.js.map +1 -1
  7. package/dist/cjs/mcp/index.js +6 -6
  8. package/dist/cjs/mcp/index.js.map +1 -1
  9. package/dist/cjs/mcp/prompts/a1-notation.js.map +1 -1
  10. package/dist/cjs/mcp/prompts/index.js +2 -2
  11. package/dist/cjs/mcp/prompts/index.js.map +1 -1
  12. package/dist/cjs/mcp/resources/index.js +2 -2
  13. package/dist/cjs/mcp/resources/index.js.map +1 -1
  14. package/dist/cjs/mcp/resources/spreadsheet.js.map +1 -1
  15. package/dist/cjs/mcp/tools/cells-format.js +8 -8
  16. package/dist/cjs/mcp/tools/cells-format.js.map +1 -1
  17. package/dist/cjs/mcp/tools/chart-create.js +8 -8
  18. package/dist/cjs/mcp/tools/chart-create.js.map +1 -1
  19. package/dist/cjs/mcp/tools/columns-get.js +3 -3
  20. package/dist/cjs/mcp/tools/columns-get.js.map +1 -1
  21. package/dist/cjs/mcp/tools/columns-update.js +10 -10
  22. package/dist/cjs/mcp/tools/columns-update.js.map +1 -1
  23. package/dist/cjs/mcp/tools/csv-get-columns.js +2 -2
  24. package/dist/cjs/mcp/tools/csv-get-columns.js.map +1 -1
  25. package/dist/cjs/mcp/tools/dimensions-batch-update.js +16 -16
  26. package/dist/cjs/mcp/tools/dimensions-batch-update.js.map +1 -1
  27. package/dist/cjs/mcp/tools/dimensions-move.js +5 -5
  28. package/dist/cjs/mcp/tools/dimensions-move.js.map +1 -1
  29. package/dist/cjs/mcp/tools/index.js +52 -52
  30. package/dist/cjs/mcp/tools/index.js.map +1 -1
  31. package/dist/cjs/mcp/tools/lib/dimension-operations.js.map +1 -1
  32. package/dist/cjs/mcp/tools/rows-append.js +10 -10
  33. package/dist/cjs/mcp/tools/rows-append.js.map +1 -1
  34. package/dist/cjs/mcp/tools/rows-csv-append.js +13 -13
  35. package/dist/cjs/mcp/tools/rows-csv-append.js.map +1 -1
  36. package/dist/cjs/mcp/tools/rows-get.js +4 -4
  37. package/dist/cjs/mcp/tools/rows-get.js.map +1 -1
  38. package/dist/cjs/mcp/tools/sheet-copy-to.js +4 -4
  39. package/dist/cjs/mcp/tools/sheet-copy-to.js.map +1 -1
  40. package/dist/cjs/mcp/tools/sheet-copy.js +5 -5
  41. package/dist/cjs/mcp/tools/sheet-copy.js.map +1 -1
  42. package/dist/cjs/mcp/tools/sheet-create.js +4 -4
  43. package/dist/cjs/mcp/tools/sheet-create.js.map +1 -1
  44. package/dist/cjs/mcp/tools/sheet-delete.js +4 -4
  45. package/dist/cjs/mcp/tools/sheet-delete.js.map +1 -1
  46. package/dist/cjs/mcp/tools/sheet-find.js +7 -7
  47. package/dist/cjs/mcp/tools/sheet-find.js.map +1 -1
  48. package/dist/cjs/mcp/tools/sheet-rename.js +5 -5
  49. package/dist/cjs/mcp/tools/sheet-rename.js.map +1 -1
  50. package/dist/cjs/mcp/tools/spreadsheet-copy.js +2 -2
  51. package/dist/cjs/mcp/tools/spreadsheet-copy.js.map +1 -1
  52. package/dist/cjs/mcp/tools/spreadsheet-create.js +2 -2
  53. package/dist/cjs/mcp/tools/spreadsheet-create.js.map +1 -1
  54. package/dist/cjs/mcp/tools/spreadsheet-find.js +6 -6
  55. package/dist/cjs/mcp/tools/spreadsheet-find.js.map +1 -1
  56. package/dist/cjs/mcp/tools/spreadsheet-rename.js +3 -3
  57. package/dist/cjs/mcp/tools/spreadsheet-rename.js.map +1 -1
  58. package/dist/cjs/mcp/tools/validation-set.js +8 -8
  59. package/dist/cjs/mcp/tools/validation-set.js.map +1 -1
  60. package/dist/cjs/mcp/tools/values-batch-update.js +8 -8
  61. package/dist/cjs/mcp/tools/values-batch-update.js.map +1 -1
  62. package/dist/cjs/mcp/tools/values-clear.js +6 -6
  63. package/dist/cjs/mcp/tools/values-clear.js.map +1 -1
  64. package/dist/cjs/mcp/tools/values-csv-update.js +8 -8
  65. package/dist/cjs/mcp/tools/values-csv-update.js.map +1 -1
  66. package/dist/cjs/mcp/tools/values-replace.js +8 -8
  67. package/dist/cjs/mcp/tools/values-replace.js.map +1 -1
  68. package/dist/cjs/mcp/tools/values-search.js +5 -5
  69. package/dist/cjs/mcp/tools/values-search.js.map +1 -1
  70. package/dist/cjs/schemas/index.js.map +1 -1
  71. package/dist/cjs/setup/config.js +11 -1
  72. package/dist/cjs/setup/config.js.map +1 -1
  73. package/dist/cjs/setup/http.js +6 -2
  74. package/dist/cjs/setup/http.js.map +1 -1
  75. package/dist/cjs/setup/index.js +9 -9
  76. package/dist/cjs/setup/index.js.map +1 -1
  77. package/dist/cjs/setup/oauth-google.d.cts +3 -2
  78. package/dist/cjs/setup/oauth-google.d.ts +3 -2
  79. package/dist/cjs/setup/oauth-google.js +15 -12
  80. package/dist/cjs/setup/oauth-google.js.map +1 -1
  81. package/dist/cjs/setup/runtime.js +9 -9
  82. package/dist/cjs/setup/runtime.js.map +1 -1
  83. package/dist/cjs/setup/stdio.js +2 -2
  84. package/dist/cjs/setup/stdio.js.map +1 -1
  85. package/dist/cjs/spreadsheet/column-utilities.js.map +1 -1
  86. package/dist/cjs/spreadsheet/csv-streaming.js.map +1 -1
  87. package/dist/cjs/spreadsheet/data-operations.js +9 -9
  88. package/dist/cjs/spreadsheet/data-operations.js.map +1 -1
  89. package/dist/cjs/spreadsheet/deduplication-utils.js.map +1 -1
  90. package/dist/cjs/spreadsheet/range-operations.js +2 -2
  91. package/dist/cjs/spreadsheet/range-operations.js.map +1 -1
  92. package/dist/cjs/spreadsheet/sheet-operations.js +3 -3
  93. package/dist/cjs/spreadsheet/sheet-operations.js.map +1 -1
  94. package/dist/cjs/spreadsheet/spreadsheet-management.js.map +1 -1
  95. package/dist/esm/constants.js.map +1 -1
  96. package/dist/esm/index.js.map +1 -1
  97. package/dist/esm/lib/create-store.js.map +1 -1
  98. package/dist/esm/mcp/index.js.map +1 -1
  99. package/dist/esm/mcp/prompts/a1-notation.js.map +1 -1
  100. package/dist/esm/mcp/prompts/index.js.map +1 -1
  101. package/dist/esm/mcp/resources/index.js.map +1 -1
  102. package/dist/esm/mcp/resources/spreadsheet.js.map +1 -1
  103. package/dist/esm/mcp/tools/cells-format.js.map +1 -1
  104. package/dist/esm/mcp/tools/chart-create.js.map +1 -1
  105. package/dist/esm/mcp/tools/columns-get.js.map +1 -1
  106. package/dist/esm/mcp/tools/columns-update.js.map +1 -1
  107. package/dist/esm/mcp/tools/csv-get-columns.js.map +1 -1
  108. package/dist/esm/mcp/tools/dimensions-batch-update.js.map +1 -1
  109. package/dist/esm/mcp/tools/dimensions-move.js.map +1 -1
  110. package/dist/esm/mcp/tools/index.js.map +1 -1
  111. package/dist/esm/mcp/tools/lib/dimension-operations.js.map +1 -1
  112. package/dist/esm/mcp/tools/rows-append.js.map +1 -1
  113. package/dist/esm/mcp/tools/rows-csv-append.js.map +1 -1
  114. package/dist/esm/mcp/tools/rows-get.js.map +1 -1
  115. package/dist/esm/mcp/tools/sheet-copy-to.js.map +1 -1
  116. package/dist/esm/mcp/tools/sheet-copy.js.map +1 -1
  117. package/dist/esm/mcp/tools/sheet-create.js.map +1 -1
  118. package/dist/esm/mcp/tools/sheet-delete.js.map +1 -1
  119. package/dist/esm/mcp/tools/sheet-find.js.map +1 -1
  120. package/dist/esm/mcp/tools/sheet-rename.js.map +1 -1
  121. package/dist/esm/mcp/tools/spreadsheet-copy.js.map +1 -1
  122. package/dist/esm/mcp/tools/spreadsheet-create.js.map +1 -1
  123. package/dist/esm/mcp/tools/spreadsheet-find.js.map +1 -1
  124. package/dist/esm/mcp/tools/spreadsheet-rename.js.map +1 -1
  125. package/dist/esm/mcp/tools/validation-set.js.map +1 -1
  126. package/dist/esm/mcp/tools/values-batch-update.js.map +1 -1
  127. package/dist/esm/mcp/tools/values-clear.js.map +1 -1
  128. package/dist/esm/mcp/tools/values-csv-update.js.map +1 -1
  129. package/dist/esm/mcp/tools/values-replace.js.map +1 -1
  130. package/dist/esm/mcp/tools/values-search.js.map +1 -1
  131. package/dist/esm/schemas/index.js.map +1 -1
  132. package/dist/esm/setup/config.js +12 -2
  133. package/dist/esm/setup/config.js.map +1 -1
  134. package/dist/esm/setup/http.js +4 -0
  135. package/dist/esm/setup/http.js.map +1 -1
  136. package/dist/esm/setup/index.js.map +1 -1
  137. package/dist/esm/setup/oauth-google.d.ts +3 -2
  138. package/dist/esm/setup/oauth-google.js +8 -11
  139. package/dist/esm/setup/oauth-google.js.map +1 -1
  140. package/dist/esm/setup/runtime.js.map +1 -1
  141. package/dist/esm/setup/stdio.js.map +1 -1
  142. package/dist/esm/spreadsheet/column-utilities.js.map +1 -1
  143. package/dist/esm/spreadsheet/csv-streaming.js.map +1 -1
  144. package/dist/esm/spreadsheet/data-operations.js.map +1 -1
  145. package/dist/esm/spreadsheet/deduplication-utils.js.map +1 -1
  146. package/dist/esm/spreadsheet/range-operations.js.map +1 -1
  147. package/dist/esm/spreadsheet/sheet-operations.js.map +1 -1
  148. package/dist/esm/spreadsheet/spreadsheet-management.js.map +1 -1
  149. package/dist/esm/types.js.map +1 -1
  150. package/package.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/sheet-delete.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 { SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\n\nconst MAX_BATCH_SIZE = 1000;\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gids: z.array(SheetGidSchema).min(1).max(MAX_BATCH_SIZE).describe('Sheet grid IDs to permanently delete'),\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Human-readable summary of the operation'),\n itemsProcessed: z.number().describe('Total sheets attempted to delete'),\n itemsChanged: z.number().describe('Number of sheets successfully deleted'),\n completedAt: z.string().describe('ISO timestamp when operation completed'),\n recoverable: z.literal(false).describe('Whether deletion can be undone (always false)'),\n id: SpreadsheetIdOutput,\n spreadsheetUrl: z.string().optional().describe('URL to view the spreadsheet'),\n failures: z\n .array(\n z.object({\n gid: z.string().describe('Grid ID of sheet that failed to delete'),\n error: z.string().describe('Error message explaining the failure'),\n })\n )\n .optional()\n .describe('Details of any sheets that failed to delete'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Permanently delete sheets from a spreadsheet. Cannot delete the last remaining sheet.',\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, gids }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.sheet.delete called', { id, count: gids.length });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n const results = await Promise.allSettled(\n gids.map(async (gid) => {\n await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: [{ deleteSheet: { sheetId: Number(gid) } }],\n },\n });\n return gid;\n })\n );\n\n // Separate successes and failures\n const failures: Array<{ gid: string; error: string }> = [];\n\n results.forEach((result, index) => {\n const gid = gids[index];\n if (!gid) return;\n\n if (result.status === 'rejected') {\n const errorMessage = result.reason instanceof Error ? result.reason.message : String(result.reason);\n failures.push({ gid, error: errorMessage });\n }\n });\n\n const successCount = gids.length - failures.length;\n const failureCount = failures.length;\n const totalCount = gids.length;\n\n const summary = failureCount === 0 ? `Permanently deleted ${successCount} sheet${successCount === 1 ? '' : 's'}` : `Deleted ${successCount} of ${totalCount} sheet${totalCount === 1 ? '' : 's'} (${failureCount} failed)`;\n\n logger.info('sheets.sheet.delete completed', {\n totalCount,\n successCount,\n failureCount,\n });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: summary,\n itemsProcessed: totalCount,\n itemsChanged: successCount,\n completedAt: new Date().toISOString(),\n recoverable: false as const,\n id,\n spreadsheetUrl: `https://docs.google.com/spreadsheets/d/${id}`,\n ...(failures.length > 0 && { failures }),\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.sheet.delete error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error deleting sheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'sheet-delete',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","MAX_BATCH_SIZE","inputSchema","z","object","id","SpreadsheetIdSchema","gids","array","SheetGidSchema","min","max","describe","successBranchSchema","type","literal","operationSummary","string","itemsProcessed","number","itemsChanged","completedAt","recoverable","SpreadsheetIdOutput","spreadsheetUrl","optional","failures","gid","error","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","sheets","results","successCount","failureCount","totalCount","summary","message","info","count","length","google","version","auth","authContext","Promise","allSettled","map","spreadsheets","batchUpdate","spreadsheetId","requestBody","requests","deleteSheet","sheetId","Number","forEach","index","status","errorMessage","reason","Error","String","push","Date","toISOString","content","text","JSON","stringify","structuredContent","McpError","ErrorCode","InternalError","stack","undefined","name"],"mappings":"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"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/sheet-delete.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 { SheetGidSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.ts';\n\nconst MAX_BATCH_SIZE = 1000;\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n gids: z.array(SheetGidSchema).min(1).max(MAX_BATCH_SIZE).describe('Sheet grid IDs to permanently delete'),\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Human-readable summary of the operation'),\n itemsProcessed: z.number().describe('Total sheets attempted to delete'),\n itemsChanged: z.number().describe('Number of sheets successfully deleted'),\n completedAt: z.string().describe('ISO timestamp when operation completed'),\n recoverable: z.literal(false).describe('Whether deletion can be undone (always false)'),\n id: SpreadsheetIdOutput,\n spreadsheetUrl: z.string().optional().describe('URL to view the spreadsheet'),\n failures: z\n .array(\n z.object({\n gid: z.string().describe('Grid ID of sheet that failed to delete'),\n error: z.string().describe('Error message explaining the failure'),\n })\n )\n .optional()\n .describe('Details of any sheets that failed to delete'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Permanently delete sheets from a spreadsheet. Cannot delete the last remaining sheet.',\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, gids }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.sheet.delete called', { id, count: gids.length });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n const results = await Promise.allSettled(\n gids.map(async (gid) => {\n await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: [{ deleteSheet: { sheetId: Number(gid) } }],\n },\n });\n return gid;\n })\n );\n\n // Separate successes and failures\n const failures: Array<{ gid: string; error: string }> = [];\n\n results.forEach((result, index) => {\n const gid = gids[index];\n if (!gid) return;\n\n if (result.status === 'rejected') {\n const errorMessage = result.reason instanceof Error ? result.reason.message : String(result.reason);\n failures.push({ gid, error: errorMessage });\n }\n });\n\n const successCount = gids.length - failures.length;\n const failureCount = failures.length;\n const totalCount = gids.length;\n\n const summary = failureCount === 0 ? `Permanently deleted ${successCount} sheet${successCount === 1 ? '' : 's'}` : `Deleted ${successCount} of ${totalCount} sheet${totalCount === 1 ? '' : 's'} (${failureCount} failed)`;\n\n logger.info('sheets.sheet.delete completed', {\n totalCount,\n successCount,\n failureCount,\n });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: summary,\n itemsProcessed: totalCount,\n itemsChanged: successCount,\n completedAt: new Date().toISOString(),\n recoverable: false as const,\n id,\n spreadsheetUrl: `https://docs.google.com/spreadsheets/d/${id}`,\n ...(failures.length > 0 && { failures }),\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.sheet.delete error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error deleting sheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'sheet-delete',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","MAX_BATCH_SIZE","inputSchema","z","object","id","SpreadsheetIdSchema","gids","array","SheetGidSchema","min","max","describe","successBranchSchema","type","literal","operationSummary","string","itemsProcessed","number","itemsChanged","completedAt","recoverable","SpreadsheetIdOutput","spreadsheetUrl","optional","failures","gid","error","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","sheets","results","successCount","failureCount","totalCount","summary","message","info","count","length","google","version","auth","authContext","Promise","allSettled","map","spreadsheets","batchUpdate","spreadsheetId","requestBody","requests","deleteSheet","sheetId","Number","forEach","index","status","errorMessage","reason","Error","String","push","Date","toISOString","content","text","JSON","stringify","structuredContent","McpError","ErrorCode","InternalError","stack","undefined","name"],"mappings":";;;;+BA0HA;;;eAAwBA;;;2BAzHA;qBAMY;0BACb;mBACL;uBACuD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAPzE,IAAM,AAAEC,2BAA6BC,oBAAO,CAApCD;AASR,IAAME,iBAAiB;AAEvB,IAAMC,cAAcC,MAAC,CAACC,MAAM,CAAC;IAC3BC,IAAIC,4BAAmB;IACvBC,MAAMJ,MAAC,CAACK,KAAK,CAACC,uBAAc,EAAEC,GAAG,CAAC,GAAGC,GAAG,CAACV,gBAAgBW,QAAQ,CAAC;AACpE;AAEA,IAAMC,sBAAsBV,MAAC,CAACC,MAAM,CAAC;IACnCU,MAAMX,MAAC,CAACY,OAAO,CAAC;IAChBC,kBAAkBb,MAAC,CAACc,MAAM,GAAGL,QAAQ,CAAC;IACtCM,gBAAgBf,MAAC,CAACgB,MAAM,GAAGP,QAAQ,CAAC;IACpCQ,cAAcjB,MAAC,CAACgB,MAAM,GAAGP,QAAQ,CAAC;IAClCS,aAAalB,MAAC,CAACc,MAAM,GAAGL,QAAQ,CAAC;IACjCU,aAAanB,MAAC,CAACY,OAAO,CAAC,OAAOH,QAAQ,CAAC;IACvCP,IAAIkB,4BAAmB;IACvBC,gBAAgBrB,MAAC,CAACc,MAAM,GAAGQ,QAAQ,GAAGb,QAAQ,CAAC;IAC/Cc,UAAUvB,MAAC,CACRK,KAAK,CACJL,MAAC,CAACC,MAAM,CAAC;QACPuB,KAAKxB,MAAC,CAACc,MAAM,GAAGL,QAAQ,CAAC;QACzBgB,OAAOzB,MAAC,CAACc,MAAM,GAAGL,QAAQ,CAAC;IAC7B,IAEDa,QAAQ,GACRb,QAAQ,CAAC;AACd;AAEA,IAAMiB,eAAe1B,MAAC,CAAC2B,kBAAkB,CAAC,QAAQ;IAACjB;IAAqBd;CAAyB;AAEjG,IAAMgC,SAAS;IACbC,aAAa;IACb9B,aAAAA;IACA2B,cAAc1B,MAAC,CAACC,MAAM,CAAC;QACrB6B,QAAQJ;IACV;AACF;AAKA,SAAeK;wCAAQ,KAAmB,EAAEC,KAAoB;YAAvC9B,IAAIE,MACrB6B,QAIEC,QAEAC,SAaAZ,UAYAa,cACAC,cACAC,YAEAC,SAQAT,QAgBCL,OACDe;;;;oBA7DetC,KAAF,MAAEA,IAAIE,OAAN,MAAMA;oBACrB6B,SAASD,MAAMC,MAAM;oBAC3BA,OAAOQ,IAAI,CAAC,8BAA8B;wBAAEvC,IAAAA;wBAAIwC,OAAOtC,KAAKuC,MAAM;oBAAC;;;;;;;;;oBAG3DT,SAASU,kBAAM,CAACV,MAAM,CAAC;wBAAEW,SAAS;wBAAMC,MAAMd,MAAMe,WAAW,CAACD,IAAI;oBAAC;oBAE3D;;wBAAME,QAAQC,UAAU,CACtC7C,KAAK8C,GAAG,CAAC,SAAO1B;;;;;4CACd;;gDAAMU,OAAOiB,YAAY,CAACC,WAAW,CAAC;oDACpCC,eAAenD;oDACfoD,aAAa;wDACXC,QAAQ;4DAAG;gEAAEC,aAAa;oEAAEC,SAASC,OAAOlC;gEAAK;4DAAE;;oDACrD;gDACF;;;4CALA;4CAMA;;gDAAOA;;;;4BACT;;;;oBATIW,UAAU;oBAYhB,kCAAkC;oBAC5BZ;oBAENY,QAAQwB,OAAO,CAAC,SAAC7B,QAAQ8B;wBACvB,IAAMpC,MAAMpB,IAAI,CAACwD,MAAM;wBACvB,IAAI,CAACpC,KAAK;wBAEV,IAAIM,OAAO+B,MAAM,KAAK,YAAY;4BAChC,IAAMC,eAAehC,AAAa,YAAbA,OAAOiC,MAAM,EAAYC,SAAQlC,OAAOiC,MAAM,CAACvB,OAAO,GAAGyB,OAAOnC,OAAOiC,MAAM;4BAClGxC,SAAS2C,IAAI,CAAC;gCAAE1C,KAAAA;gCAAKC,OAAOqC;4BAAa;wBAC3C;oBACF;oBAEM1B,eAAehC,KAAKuC,MAAM,GAAGpB,SAASoB,MAAM;oBAC5CN,eAAed,SAASoB,MAAM;oBAC9BL,aAAalC,KAAKuC,MAAM;oBAExBJ,UAAUF,iBAAiB,IAAI,AAAC,uBAA2CD,OAArBA,cAAa,UAAsC,OAA9BA,iBAAiB,IAAI,KAAK,OAAQ,AAAC,WAA6BE,OAAnBF,cAAa,QAAyBE,OAAnBA,YAAW,UAAwCD,OAAhCC,eAAe,IAAI,KAAK,KAAI,MAAiB,OAAbD,cAAa;oBAEjNJ,OAAOQ,IAAI,CAAC,iCAAiC;wBAC3CH,YAAAA;wBACAF,cAAAA;wBACAC,cAAAA;oBACF;oBAEMP,SAAiB;wBACrBnB,MAAM;wBACNE,kBAAkB0B;wBAClBxB,gBAAgBuB;wBAChBrB,cAAcmB;wBACdlB,aAAa,IAAIiD,OAAOC,WAAW;wBACnCjD,aAAa;wBACbjB,IAAAA;wBACAmB,gBAAgB,AAAC,0CAA4C,OAAHnB;uBACtDqB,SAASoB,MAAM,GAAG,KAAK;wBAAEpB,UAAAA;oBAAS;oBAGxC;;wBAAO;4BACL8C,OAAO;gCAAG;oCAAE1D,MAAM;oCAAiB2D,MAAMC,KAAKC,SAAS,CAAC1C;gCAAQ;;4BAChE2C,mBAAmB;gCAAE3C,QAAAA;4BAAO;wBAC9B;;;oBACOL;oBACDe,UAAUf,AAAK,YAALA,OAAiBuC,SAAQvC,MAAMe,OAAO,GAAGyB,OAAOxC;oBAChEQ,OAAOR,KAAK,CAAC,6BAA6B;wBAAEA,OAAOe;oBAAQ;oBAE3D,MAAM,IAAIkC,eAAQ,CAACC,gBAAS,CAACC,aAAa,EAAE,AAAC,yBAAgC,OAARpC,UAAW;wBAC9EqC,OAAOpD,AAAK,YAALA,OAAiBuC,SAAQvC,MAAMoD,KAAK,GAAGC;oBAChD;;;;;;;IAEJ;;AAEe,SAASnF;IACtB,OAAO;QACLoF,MAAM;QACNnD,QAAAA;QACAG,SAAAA;IACF;AACF"}
@@ -12,8 +12,8 @@ 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 _index = require("../../schemas/index.js");
16
- var _sheetoperations = require("../../spreadsheet/sheet-operations.js");
15
+ var _indexts = require("../../schemas/index.js");
16
+ var _sheetoperationsts = require("../../spreadsheet/sheet-operations.js");
17
17
  function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
18
18
  try {
19
19
  var info = gen[key](arg);
@@ -151,13 +151,13 @@ function _ts_generator(thisArg, body) {
151
151
  }
152
152
  var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
153
153
  var inputSchema = _zod.z.object({
154
- id: _index.SpreadsheetIdSchema,
155
- sheetRef: _index.SheetRefSchema
154
+ id: _indexts.SpreadsheetIdSchema,
155
+ sheetRef: _indexts.SheetRefSchema
156
156
  });
157
157
  var successBranchSchema = _zod.z.object({
158
158
  type: _zod.z.literal('success'),
159
- id: _index.SpreadsheetIdOutput,
160
- gid: _index.SheetGidOutput,
159
+ id: _indexts.SpreadsheetIdOutput,
160
+ gid: _indexts.SheetGidOutput,
161
161
  title: _zod.z.string().describe('Sheet tab name'),
162
162
  sheetUrl: _zod.z.string().optional().describe('URL to view the sheet')
163
163
  });
@@ -198,7 +198,7 @@ function handler(_0, _1) {
198
198
  });
199
199
  return [
200
200
  4,
201
- (0, _sheetoperations.findSheetByRef)(sheets, id, sheetRef, logger)
201
+ (0, _sheetoperationsts.findSheetByRef)(sheets, id, sheetRef, logger)
202
202
  ];
203
203
  case 2:
204
204
  sheet = _state.sent();
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/sheet-find.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, SheetRefSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\nimport { findSheetByRef } from '../../spreadsheet/sheet-operations.js';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n sheetRef: SheetRefSchema,\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n title: z.string().describe('Sheet tab name'),\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: 'Find an existing sheet/tab within a known spreadsheet by title or GUID',\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, sheetRef }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.sheet.find called', { id, sheetRef });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // Find sheet within the known spreadsheet\n const sheet = await findSheetByRef(sheets, id, sheetRef, logger);\n if (!sheet) {\n throw new McpError(ErrorCode.InvalidParams, 'Sheet not found');\n }\n\n const title = sheet?.properties?.title ?? String(sheetRef);\n const gid = sheet?.properties?.sheetId != null ? String(sheet.properties.sheetId) : '';\n const sheetUrl = gid ? `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${gid}` : `https://docs.google.com/spreadsheets/d/${id}`;\n\n logger.info('sheets.sheet.find success', { id, gid, title });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid,\n title,\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.sheet.find error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error finding sheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'sheet-find',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","sheetRef","SheetRefSchema","successBranchSchema","type","literal","SpreadsheetIdOutput","gid","SheetGidOutput","title","string","describe","sheetUrl","optional","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","sheet","sheets","error","message","info","google","version","auth","authContext","findSheetByRef","McpError","ErrorCode","InvalidParams","properties","String","sheetId","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/sheet-find.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, SheetRefSchema, SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.ts';\nimport { findSheetByRef } from '../../spreadsheet/sheet-operations.ts';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n sheetRef: SheetRefSchema,\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n title: z.string().describe('Sheet tab name'),\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: 'Find an existing sheet/tab within a known spreadsheet by title or GUID',\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, sheetRef }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.sheet.find called', { id, sheetRef });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // Find sheet within the known spreadsheet\n const sheet = await findSheetByRef(sheets, id, sheetRef, logger);\n if (!sheet) {\n throw new McpError(ErrorCode.InvalidParams, 'Sheet not found');\n }\n\n const title = sheet?.properties?.title ?? String(sheetRef);\n const gid = sheet?.properties?.sheetId != null ? String(sheet.properties.sheetId) : '';\n const sheetUrl = gid ? `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${gid}` : `https://docs.google.com/spreadsheets/d/${id}`;\n\n logger.info('sheets.sheet.find success', { id, gid, title });\n\n const result: Output = {\n type: 'success' as const,\n id,\n gid,\n title,\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.sheet.find error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error finding sheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'sheet-find',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","sheetRef","SheetRefSchema","successBranchSchema","type","literal","SpreadsheetIdOutput","gid","SheetGidOutput","title","string","describe","sheetUrl","optional","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","sheet","sheets","error","message","info","google","version","auth","authContext","findSheetByRef","McpError","ErrorCode","InvalidParams","properties","String","sheetId","content","text","JSON","stringify","structuredContent","Error","InternalError","stack","undefined","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 _index = require("../../schemas/index.js");
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: _index.SpreadsheetIdSchema,
154
- gid: _index.SheetGidSchema,
153
+ id: _indexts.SpreadsheetIdSchema,
154
+ gid: _indexts.SheetGidSchema,
155
155
  newTitle: _zod.z.coerce.string().trim().min(1).describe('New name for the sheet tab')
156
156
  });
157
157
  // Success branch schema
@@ -161,8 +161,8 @@ var successBranchSchema = _zod.z.object({
161
161
  itemsProcessed: _zod.z.number().describe('Total items attempted (always 1 for single sheet)'),
162
162
  itemsChanged: _zod.z.number().describe('Successfully renamed sheets (always 1 on success)'),
163
163
  completedAt: _zod.z.string().describe('ISO datetime when operation completed'),
164
- id: _index.SpreadsheetIdOutput,
165
- gid: _index.SheetGidOutput,
164
+ id: _indexts.SpreadsheetIdOutput,
165
+ gid: _indexts.SheetGidOutput,
166
166
  sheetUrl: _zod.z.string().describe('URL of the renamed sheet'),
167
167
  oldTitle: _zod.z.string().describe('Previous title of the sheet'),
168
168
  newTitle: _zod.z.string().describe('New title of the sheet')
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/sheet-rename.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 newTitle: z.coerce.string().trim().min(1).describe('New name for the sheet tab'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the rename operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1 for single sheet)'),\n itemsChanged: z.number().describe('Successfully renamed sheets (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n sheetUrl: z.string().describe('URL of the renamed sheet'),\n oldTitle: z.string().describe('Previous title of the sheet'),\n newTitle: z.string().describe('New title of the sheet'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Rename a sheet within a spreadsheet.',\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, newTitle }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.sheet.rename called', { id, gid, newTitle });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // First, get the current sheet title\n const spreadsheetInfo = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'sheets.properties.sheetId,sheets.properties.title',\n });\n\n const sheetInfo = spreadsheetInfo.data.sheets?.find((s) => String(s.properties?.sheetId) === gid);\n if (!sheetInfo?.properties) {\n throw new McpError(ErrorCode.InvalidParams, `Sheet with gid \"${gid}\" not found in spreadsheet`);\n }\n\n const oldTitle = sheetInfo.properties.title || '';\n\n // Rename the sheet\n await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: [\n {\n updateSheetProperties: {\n properties: { sheetId: Number(gid), title: newTitle },\n fields: 'title',\n },\n },\n ],\n },\n });\n\n logger.info('sheets.sheet.rename success', { id, gid, oldTitle, newTitle });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Renamed sheet \"${oldTitle}\" to \"${newTitle}\"`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n id,\n gid,\n sheetUrl: `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${gid}`,\n oldTitle,\n newTitle,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\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('sheets.sheet.rename error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error renaming sheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'sheet-rename',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","gid","SheetGidSchema","newTitle","coerce","string","trim","min","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","SpreadsheetIdOutput","SheetGidOutput","sheetUrl","oldTitle","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetInfo","sheets","sheetInfo","error","message","info","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","find","s","String","properties","sheetId","McpError","ErrorCode","InvalidParams","title","batchUpdate","requestBody","requests","updateSheetProperties","Number","Date","toISOString","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/sheet-rename.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 newTitle: z.coerce.string().trim().min(1).describe('New name for the sheet tab'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the rename operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1 for single sheet)'),\n itemsChanged: z.number().describe('Successfully renamed sheets (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n id: SpreadsheetIdOutput,\n gid: SheetGidOutput,\n sheetUrl: z.string().describe('URL of the renamed sheet'),\n oldTitle: z.string().describe('Previous title of the sheet'),\n newTitle: z.string().describe('New title of the sheet'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Rename a sheet within a spreadsheet.',\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, newTitle }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.sheet.rename called', { id, gid, newTitle });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // First, get the current sheet title\n const spreadsheetInfo = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'sheets.properties.sheetId,sheets.properties.title',\n });\n\n const sheetInfo = spreadsheetInfo.data.sheets?.find((s) => String(s.properties?.sheetId) === gid);\n if (!sheetInfo?.properties) {\n throw new McpError(ErrorCode.InvalidParams, `Sheet with gid \"${gid}\" not found in spreadsheet`);\n }\n\n const oldTitle = sheetInfo.properties.title || '';\n\n // Rename the sheet\n await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: [\n {\n updateSheetProperties: {\n properties: { sheetId: Number(gid), title: newTitle },\n fields: 'title',\n },\n },\n ],\n },\n });\n\n logger.info('sheets.sheet.rename success', { id, gid, oldTitle, newTitle });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Renamed sheet \"${oldTitle}\" to \"${newTitle}\"`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n id,\n gid,\n sheetUrl: `https://docs.google.com/spreadsheets/d/${id}/edit#gid=${gid}`,\n oldTitle,\n newTitle,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\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('sheets.sheet.rename error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error renaming sheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'sheet-rename',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","gid","SheetGidSchema","newTitle","coerce","string","trim","min","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","SpreadsheetIdOutput","SheetGidOutput","sheetUrl","oldTitle","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetInfo","sheets","sheetInfo","error","message","info","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","find","s","String","properties","sheetId","McpError","ErrorCode","InvalidParams","title","batchUpdate","requestBody","requests","updateSheetProperties","Number","Date","toISOString","content","text","JSON","stringify","structuredContent","Error","InternalError","stack","undefined","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 _index = require("../../schemas/index.js");
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);
@@ -179,7 +179,7 @@ function _ts_generator(thisArg, body) {
179
179
  var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
180
180
  // Note: Using contextual descriptions for sourceId/newId since they describe different spreadsheets
181
181
  var inputSchema = _zod.z.object({
182
- id: _index.SpreadsheetIdSchema,
182
+ id: _indexts.SpreadsheetIdSchema,
183
183
  newTitle: _zod.z.coerce.string().trim().min(1).optional().describe('Name for the copy (optional, defaults to "Copy of [original]")')
184
184
  });
185
185
  // Success branch schema
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/spreadsheet-copy.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 { SpreadsheetIdSchema } from '../../schemas/index.js';\n\n// Note: Using contextual descriptions for sourceId/newId since they describe different spreadsheets\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n newTitle: z.coerce.string().trim().min(1).optional().describe('Name for the copy (optional, defaults to \"Copy of [original]\")'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the copy operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1)'),\n itemsChanged: z.number().describe('Successfully copied (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n sourceId: z.string().describe('Source spreadsheet ID'),\n sourceTitle: z.string().describe('Source spreadsheet title'),\n newId: z.string().describe('Copied spreadsheet ID'),\n newTitle: z.string().describe('Title of the copied spreadsheet'),\n spreadsheetUrl: z.string().describe('URL of the copied spreadsheet'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Copy an entire spreadsheet/workbook (all sheets, formatting, charts, named ranges, etc.). Creates in the same folder as the original. Uses Google Drive API.',\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, newTitle }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.spreadsheet.copy called', { id, newTitle });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // Get the original spreadsheet title\n const sourceInfo = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'properties.title',\n });\n\n const sourceTitle = sourceInfo.data.properties?.title || '';\n\n // Copy the spreadsheet using Drive API\n const copyResponse = await drive.files.copy({\n fileId: id,\n requestBody: {\n ...(newTitle && { name: newTitle }),\n },\n });\n\n const newId = copyResponse.data.id;\n const resultTitle = copyResponse.data.name || '';\n\n if (!newId) {\n throw new Error('Failed to retrieve new spreadsheet ID from API response');\n }\n\n logger.info('sheets.spreadsheet.copy success', { sourceId: id, newId, newTitle: resultTitle });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Copied spreadsheet \"${sourceTitle}\" to \"${resultTitle}\"`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n sourceId: id,\n sourceTitle,\n newId,\n newTitle: resultTitle,\n spreadsheetUrl: `https://docs.google.com/spreadsheets/d/${newId}`,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\n structuredContent: { result },\n };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error('sheets.spreadsheet.copy error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error copying spreadsheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'spreadsheet-copy',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","newTitle","coerce","string","trim","min","optional","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","sourceId","sourceTitle","newId","spreadsheetUrl","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","sourceInfo","drive","sheets","copyResponse","resultTitle","error","message","info","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","properties","title","files","copy","fileId","requestBody","name","Error","Date","toISOString","content","text","JSON","stringify","structuredContent","String","McpError","ErrorCode","InternalError","stack","undefined"],"mappings":"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"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/spreadsheet-copy.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 { SpreadsheetIdSchema } from '../../schemas/index.ts';\n\n// Note: Using contextual descriptions for sourceId/newId since they describe different spreadsheets\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n newTitle: z.coerce.string().trim().min(1).optional().describe('Name for the copy (optional, defaults to \"Copy of [original]\")'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the copy operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1)'),\n itemsChanged: z.number().describe('Successfully copied (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n sourceId: z.string().describe('Source spreadsheet ID'),\n sourceTitle: z.string().describe('Source spreadsheet title'),\n newId: z.string().describe('Copied spreadsheet ID'),\n newTitle: z.string().describe('Title of the copied spreadsheet'),\n spreadsheetUrl: z.string().describe('URL of the copied spreadsheet'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Copy an entire spreadsheet/workbook (all sheets, formatting, charts, named ranges, etc.). Creates in the same folder as the original. Uses Google Drive API.',\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, newTitle }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.spreadsheet.copy called', { id, newTitle });\n\n try {\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // Get the original spreadsheet title\n const sourceInfo = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'properties.title',\n });\n\n const sourceTitle = sourceInfo.data.properties?.title || '';\n\n // Copy the spreadsheet using Drive API\n const copyResponse = await drive.files.copy({\n fileId: id,\n requestBody: {\n ...(newTitle && { name: newTitle }),\n },\n });\n\n const newId = copyResponse.data.id;\n const resultTitle = copyResponse.data.name || '';\n\n if (!newId) {\n throw new Error('Failed to retrieve new spreadsheet ID from API response');\n }\n\n logger.info('sheets.spreadsheet.copy success', { sourceId: id, newId, newTitle: resultTitle });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Copied spreadsheet \"${sourceTitle}\" to \"${resultTitle}\"`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n sourceId: id,\n sourceTitle,\n newId,\n newTitle: resultTitle,\n spreadsheetUrl: `https://docs.google.com/spreadsheets/d/${newId}`,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\n structuredContent: { result },\n };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error('sheets.spreadsheet.copy error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error copying spreadsheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'spreadsheet-copy',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","newTitle","coerce","string","trim","min","optional","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","sourceId","sourceTitle","newId","spreadsheetUrl","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","sourceInfo","drive","sheets","copyResponse","resultTitle","error","message","info","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","properties","title","files","copy","fileId","requestBody","name","Error","Date","toISOString","content","text","JSON","stringify","structuredContent","String","McpError","ErrorCode","InternalError","stack","undefined"],"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 _index = require("../../schemas/index.js");
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);
@@ -159,7 +159,7 @@ var successBranchSchema = _zod.z.object({
159
159
  itemsProcessed: _zod.z.number().describe('Total items attempted (always 1 for single spreadsheet)'),
160
160
  itemsChanged: _zod.z.number().describe('Successfully created spreadsheets (always 1 on success)'),
161
161
  completedAt: _zod.z.string().describe('ISO datetime when operation completed'),
162
- id: _index.SpreadsheetIdOutput,
162
+ id: _indexts.SpreadsheetIdOutput,
163
163
  spreadsheetUrl: _zod.z.string().describe('URL of the created spreadsheet'),
164
164
  title: _zod.z.string().describe('Title of the created spreadsheet')
165
165
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/spreadsheet-create.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 { SpreadsheetIdOutput } from '../../schemas/index.js';\n\nconst inputSchema = z.object({\n title: z.coerce.string().trim().min(1).describe('Title for the new spreadsheet'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the spreadsheet creation operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1 for single spreadsheet)'),\n itemsChanged: z.number().describe('Successfully created spreadsheets (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n id: SpreadsheetIdOutput,\n spreadsheetUrl: z.string().describe('URL of the created spreadsheet'),\n title: z.string().describe('Title of the created spreadsheet'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Create a new spreadsheet',\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({ title }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.spreadsheet.create called', { title });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n const response = await sheets.spreadsheets.create({\n requestBody: {\n properties: {\n title: title,\n },\n },\n });\n const res = response.data;\n const id = res.spreadsheetId ?? '';\n const url = res.spreadsheetUrl ?? '';\n\n logger.info('sheets.spreadsheet.create success', { id, title, url });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Created spreadsheet \"${title}\"`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n id,\n spreadsheetUrl: url,\n title,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\n structuredContent: { result },\n };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error('sheets.spreadsheet.create error', { error: message });\n\n // Throw McpError for proper MCP error handling\n throw new McpError(ErrorCode.InternalError, `Error creating spreadsheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'spreadsheet-create',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","title","coerce","string","trim","min","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","id","SpreadsheetIdOutput","spreadsheetUrl","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","res","sheets","response","url","error","message","info","google","version","auth","authContext","spreadsheets","create","requestBody","properties","data","spreadsheetId","Date","toISOString","content","text","JSON","stringify","structuredContent","Error","String","McpError","ErrorCode","InternalError","stack","undefined","name"],"mappings":"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"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/spreadsheet-create.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 { SpreadsheetIdOutput } from '../../schemas/index.ts';\n\nconst inputSchema = z.object({\n title: z.coerce.string().trim().min(1).describe('Title for the new spreadsheet'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the spreadsheet creation operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1 for single spreadsheet)'),\n itemsChanged: z.number().describe('Successfully created spreadsheets (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n id: SpreadsheetIdOutput,\n spreadsheetUrl: z.string().describe('URL of the created spreadsheet'),\n title: z.string().describe('Title of the created spreadsheet'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Create a new spreadsheet',\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({ title }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.spreadsheet.create called', { title });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n const response = await sheets.spreadsheets.create({\n requestBody: {\n properties: {\n title: title,\n },\n },\n });\n const res = response.data;\n const id = res.spreadsheetId ?? '';\n const url = res.spreadsheetUrl ?? '';\n\n logger.info('sheets.spreadsheet.create success', { id, title, url });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Created spreadsheet \"${title}\"`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n id,\n spreadsheetUrl: url,\n title,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\n structuredContent: { result },\n };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error('sheets.spreadsheet.create error', { error: message });\n\n // Throw McpError for proper MCP error handling\n throw new McpError(ErrorCode.InternalError, `Error creating spreadsheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'spreadsheet-create',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","title","coerce","string","trim","min","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","id","SpreadsheetIdOutput","spreadsheetUrl","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","res","sheets","response","url","error","message","info","google","version","auth","authContext","spreadsheets","create","requestBody","properties","data","spreadsheetId","Date","toISOString","content","text","JSON","stringify","structuredContent","Error","String","McpError","ErrorCode","InternalError","stack","undefined","name"],"mappings":"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"}
@@ -12,8 +12,8 @@ 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 _index = require("../../schemas/index.js");
16
- var _spreadsheetmanagement = require("../../spreadsheet/spreadsheet-management.js");
15
+ var _indexts = require("../../schemas/index.js");
16
+ var _spreadsheetmanagementts = require("../../spreadsheet/spreadsheet-management.js");
17
17
  function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
18
18
  try {
19
19
  var info = gen[key](arg);
@@ -179,17 +179,17 @@ function _ts_generator(thisArg, body) {
179
179
  }
180
180
  var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
181
181
  var inputSchema = _zod.z.object({
182
- spreadsheetRef: _index.SpreadsheetRefSchema
182
+ spreadsheetRef: _indexts.SpreadsheetRefSchema
183
183
  });
184
184
  var successBranchSchema = _zod.z.object({
185
185
  type: _zod.z.literal('success'),
186
186
  items: _zod.z.array(_zod.z.object({
187
- id: _index.SpreadsheetIdOutput,
187
+ id: _indexts.SpreadsheetIdOutput,
188
188
  spreadsheetTitle: _zod.z.string().describe('Name of the spreadsheet'),
189
189
  spreadsheetUrl: _zod.z.string().optional().describe('URL to view the spreadsheet'),
190
190
  modifiedTime: _zod.z.string().optional().describe('Last modified timestamp (ISO format)'),
191
191
  sheets: _zod.z.array(_zod.z.object({
192
- gid: _index.SheetGidOutput,
192
+ gid: _indexts.SheetGidOutput,
193
193
  sheetTitle: _zod.z.string().describe('Sheet tab name')
194
194
  })).describe('All sheets/tabs in this spreadsheet')
195
195
  })).describe('Matching spreadsheets sorted by modification time')
@@ -234,7 +234,7 @@ function handler(_0, _1) {
234
234
  });
235
235
  return [
236
236
  4,
237
- (0, _spreadsheetmanagement.findSpreadsheetsByRef)(sheets, drive, spreadsheetRef)
237
+ (0, _spreadsheetmanagementts.findSpreadsheetsByRef)(sheets, drive, spreadsheetRef)
238
238
  ];
239
239
  case 2:
240
240
  matches = _state.sent();
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/spreadsheet-find.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, SpreadsheetIdOutput, SpreadsheetRefSchema } from '../../schemas/index.js';\nimport { findSpreadsheetsByRef } from '../../spreadsheet/spreadsheet-management.js';\n\n/** Spreadsheet match result from findSpreadsheetsByRef */\ninterface SpreadsheetMatch {\n id: string;\n spreadsheetTitle: string | undefined;\n url: string | undefined;\n modifiedTime: string | null | undefined;\n}\n\nconst inputSchema = z.object({\n spreadsheetRef: SpreadsheetRefSchema,\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n items: z\n .array(\n z.object({\n id: SpreadsheetIdOutput,\n spreadsheetTitle: z.string().describe('Name of the spreadsheet'),\n spreadsheetUrl: z.string().optional().describe('URL to view the spreadsheet'),\n modifiedTime: z.string().optional().describe('Last modified timestamp (ISO format)'),\n sheets: z\n .array(\n z.object({\n gid: SheetGidOutput,\n sheetTitle: z.string().describe('Sheet tab name'),\n })\n )\n .describe('All sheets/tabs in this spreadsheet'),\n })\n )\n .describe('Matching spreadsheets sorted by modification time'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Find spreadsheet by ID, URL, or name. Returns all sheets/tabs in response.',\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({ spreadsheetRef }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.spreadsheet.find called', { spreadsheetRef });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n const matches = (await findSpreadsheetsByRef(sheets, drive, spreadsheetRef)) as SpreadsheetMatch[];\n\n const sorted = (matches || []).slice().sort((a: SpreadsheetMatch, b: SpreadsheetMatch) => (b.modifiedTime ? new Date(b.modifiedTime).getTime() : 0) - (a.modifiedTime ? new Date(a.modifiedTime).getTime() : 0));\n\n const items = await Promise.all(\n sorted.map(async (m: SpreadsheetMatch) => {\n // Fetch sheet metadata for each spreadsheet\n const spreadsheetResponse = await sheets.spreadsheets.get({\n spreadsheetId: m.id,\n fields: 'sheets.properties.sheetId,sheets.properties.title',\n });\n\n const sheetsData = (spreadsheetResponse.data.sheets || []).map((sheet) => {\n const gid = String(sheet.properties?.sheetId ?? '');\n return {\n gid,\n sheetTitle: sheet.properties?.title ?? '',\n };\n });\n\n return {\n id: m.id,\n spreadsheetTitle: m.spreadsheetTitle ?? '',\n sheets: sheetsData,\n ...(m.url && { spreadsheetUrl: m.url }),\n ...(m.modifiedTime && { modifiedTime: m.modifiedTime }),\n };\n })\n );\n\n logger.info('sheets.spreadsheet.find success', { count: items.length });\n\n const result: Output = {\n type: 'success' as const,\n items,\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.spreadsheet.find error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error finding spreadsheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'spreadsheet-find',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","spreadsheetRef","SpreadsheetRefSchema","successBranchSchema","type","literal","items","array","id","SpreadsheetIdOutput","spreadsheetTitle","string","describe","spreadsheetUrl","optional","modifiedTime","sheets","gid","SheetGidOutput","sheetTitle","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","drive","matches","sorted","error","message","info","google","version","auth","authContext","findSpreadsheetsByRef","slice","sort","a","b","Date","getTime","Promise","all","map","m","spreadsheetResponse","sheetsData","spreadsheets","get","spreadsheetId","fields","data","sheet","String","properties","sheetId","title","url","count","length","content","text","JSON","stringify","structuredContent","Error","McpError","ErrorCode","InternalError","stack","undefined","name"],"mappings":"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"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/spreadsheet-find.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, SpreadsheetIdOutput, SpreadsheetRefSchema } from '../../schemas/index.ts';\nimport { findSpreadsheetsByRef } from '../../spreadsheet/spreadsheet-management.ts';\n\n/** Spreadsheet match result from findSpreadsheetsByRef */\ninterface SpreadsheetMatch {\n id: string;\n spreadsheetTitle: string | undefined;\n url: string | undefined;\n modifiedTime: string | null | undefined;\n}\n\nconst inputSchema = z.object({\n spreadsheetRef: SpreadsheetRefSchema,\n});\n\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n items: z\n .array(\n z.object({\n id: SpreadsheetIdOutput,\n spreadsheetTitle: z.string().describe('Name of the spreadsheet'),\n spreadsheetUrl: z.string().optional().describe('URL to view the spreadsheet'),\n modifiedTime: z.string().optional().describe('Last modified timestamp (ISO format)'),\n sheets: z\n .array(\n z.object({\n gid: SheetGidOutput,\n sheetTitle: z.string().describe('Sheet tab name'),\n })\n )\n .describe('All sheets/tabs in this spreadsheet'),\n })\n )\n .describe('Matching spreadsheets sorted by modification time'),\n});\n\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Find spreadsheet by ID, URL, or name. Returns all sheets/tabs in response.',\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({ spreadsheetRef }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.spreadsheet.find called', { spreadsheetRef });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n const drive = google.drive({ version: 'v3', auth: extra.authContext.auth });\n\n const matches = (await findSpreadsheetsByRef(sheets, drive, spreadsheetRef)) as SpreadsheetMatch[];\n\n const sorted = (matches || []).slice().sort((a: SpreadsheetMatch, b: SpreadsheetMatch) => (b.modifiedTime ? new Date(b.modifiedTime).getTime() : 0) - (a.modifiedTime ? new Date(a.modifiedTime).getTime() : 0));\n\n const items = await Promise.all(\n sorted.map(async (m: SpreadsheetMatch) => {\n // Fetch sheet metadata for each spreadsheet\n const spreadsheetResponse = await sheets.spreadsheets.get({\n spreadsheetId: m.id,\n fields: 'sheets.properties.sheetId,sheets.properties.title',\n });\n\n const sheetsData = (spreadsheetResponse.data.sheets || []).map((sheet) => {\n const gid = String(sheet.properties?.sheetId ?? '');\n return {\n gid,\n sheetTitle: sheet.properties?.title ?? '',\n };\n });\n\n return {\n id: m.id,\n spreadsheetTitle: m.spreadsheetTitle ?? '',\n sheets: sheetsData,\n ...(m.url && { spreadsheetUrl: m.url }),\n ...(m.modifiedTime && { modifiedTime: m.modifiedTime }),\n };\n })\n );\n\n logger.info('sheets.spreadsheet.find success', { count: items.length });\n\n const result: Output = {\n type: 'success' as const,\n items,\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.spreadsheet.find error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error finding spreadsheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'spreadsheet-find',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","spreadsheetRef","SpreadsheetRefSchema","successBranchSchema","type","literal","items","array","id","SpreadsheetIdOutput","spreadsheetTitle","string","describe","spreadsheetUrl","optional","modifiedTime","sheets","gid","SheetGidOutput","sheetTitle","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","drive","matches","sorted","error","message","info","google","version","auth","authContext","findSpreadsheetsByRef","slice","sort","a","b","Date","getTime","Promise","all","map","m","spreadsheetResponse","sheetsData","spreadsheets","get","spreadsheetId","fields","data","sheet","String","properties","sheetId","title","url","count","length","content","text","JSON","stringify","structuredContent","Error","McpError","ErrorCode","InternalError","stack","undefined","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 _index = require("../../schemas/index.js");
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,7 +150,7 @@ function _ts_generator(thisArg, body) {
150
150
  }
151
151
  var AuthRequiredBranchSchema = _oauthgoogle.schemas.AuthRequiredBranchSchema;
152
152
  var inputSchema = _zod.z.object({
153
- id: _index.SpreadsheetIdSchema,
153
+ id: _indexts.SpreadsheetIdSchema,
154
154
  newTitle: _zod.z.coerce.string().trim().min(1).describe('New name for the spreadsheet')
155
155
  });
156
156
  // Success branch schema
@@ -160,7 +160,7 @@ var successBranchSchema = _zod.z.object({
160
160
  itemsProcessed: _zod.z.number().describe('Total items attempted (always 1)'),
161
161
  itemsChanged: _zod.z.number().describe('Successfully renamed (always 1 on success)'),
162
162
  completedAt: _zod.z.string().describe('ISO datetime when operation completed'),
163
- id: _index.SpreadsheetIdOutput,
163
+ id: _indexts.SpreadsheetIdOutput,
164
164
  spreadsheetUrl: _zod.z.string().describe('URL of the renamed spreadsheet'),
165
165
  oldTitle: _zod.z.string().describe('Previous title of the spreadsheet'),
166
166
  newTitle: _zod.z.string().describe('New title of the spreadsheet')
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/servers/mcp-sheets/src/mcp/tools/spreadsheet-rename.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 { SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.js';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n newTitle: z.coerce.string().trim().min(1).describe('New name for the spreadsheet'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the rename operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1)'),\n itemsChanged: z.number().describe('Successfully renamed (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n id: SpreadsheetIdOutput,\n spreadsheetUrl: z.string().describe('URL of the renamed spreadsheet'),\n oldTitle: z.string().describe('Previous title of the spreadsheet'),\n newTitle: z.string().describe('New title of the spreadsheet'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Rename a spreadsheet/workbook (the entire document, not individual sheets/tabs)',\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, newTitle }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.spreadsheet.rename called', { id, newTitle });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // First, get the current spreadsheet title\n const spreadsheetInfo = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'properties.title',\n });\n\n const oldTitle = spreadsheetInfo.data.properties?.title || '';\n\n // Rename the spreadsheet\n await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: [\n {\n updateSpreadsheetProperties: {\n properties: { title: newTitle },\n fields: 'title',\n },\n },\n ],\n },\n });\n\n logger.info('sheets.spreadsheet.rename success', { id, oldTitle, newTitle });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Renamed spreadsheet \"${oldTitle}\" to \"${newTitle}\"`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n id,\n spreadsheetUrl: `https://docs.google.com/spreadsheets/d/${id}`,\n oldTitle,\n newTitle,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\n structuredContent: { result },\n };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error('sheets.spreadsheet.rename error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error renaming spreadsheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'spreadsheet-rename',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","newTitle","coerce","string","trim","min","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","SpreadsheetIdOutput","spreadsheetUrl","oldTitle","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetInfo","sheets","error","message","info","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","properties","title","batchUpdate","requestBody","requests","updateSpreadsheetProperties","Date","toISOString","content","text","JSON","stringify","structuredContent","Error","String","McpError","ErrorCode","InternalError","stack","undefined","name"],"mappings":"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"}
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/mcp-z/mcp-sheets/src/mcp/tools/spreadsheet-rename.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 { SpreadsheetIdOutput, SpreadsheetIdSchema } from '../../schemas/index.ts';\n\nconst inputSchema = z.object({\n id: SpreadsheetIdSchema,\n newTitle: z.coerce.string().trim().min(1).describe('New name for the spreadsheet'),\n});\n\n// Success branch schema\nconst successBranchSchema = z.object({\n type: z.literal('success'),\n operationSummary: z.string().describe('Summary of the rename operation'),\n itemsProcessed: z.number().describe('Total items attempted (always 1)'),\n itemsChanged: z.number().describe('Successfully renamed (always 1 on success)'),\n completedAt: z.string().describe('ISO datetime when operation completed'),\n id: SpreadsheetIdOutput,\n spreadsheetUrl: z.string().describe('URL of the renamed spreadsheet'),\n oldTitle: z.string().describe('Previous title of the spreadsheet'),\n newTitle: z.string().describe('New title of the spreadsheet'),\n});\n\n// Output schema with auth_required support\nconst outputSchema = z.discriminatedUnion('type', [successBranchSchema, AuthRequiredBranchSchema]);\n\nconst config = {\n description: 'Rename a spreadsheet/workbook (the entire document, not individual sheets/tabs)',\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, newTitle }: Input, extra: EnrichedExtra): Promise<CallToolResult> {\n const logger = extra.logger;\n logger.info('sheets.spreadsheet.rename called', { id, newTitle });\n\n try {\n const sheets = google.sheets({ version: 'v4', auth: extra.authContext.auth });\n\n // First, get the current spreadsheet title\n const spreadsheetInfo = await sheets.spreadsheets.get({\n spreadsheetId: id,\n fields: 'properties.title',\n });\n\n const oldTitle = spreadsheetInfo.data.properties?.title || '';\n\n // Rename the spreadsheet\n await sheets.spreadsheets.batchUpdate({\n spreadsheetId: id,\n requestBody: {\n requests: [\n {\n updateSpreadsheetProperties: {\n properties: { title: newTitle },\n fields: 'title',\n },\n },\n ],\n },\n });\n\n logger.info('sheets.spreadsheet.rename success', { id, oldTitle, newTitle });\n\n const result: Output = {\n type: 'success' as const,\n operationSummary: `Renamed spreadsheet \"${oldTitle}\" to \"${newTitle}\"`,\n itemsProcessed: 1,\n itemsChanged: 1,\n completedAt: new Date().toISOString(),\n id,\n spreadsheetUrl: `https://docs.google.com/spreadsheets/d/${id}`,\n oldTitle,\n newTitle,\n };\n\n return {\n content: [\n {\n type: 'text' as const,\n text: JSON.stringify(result),\n },\n ],\n structuredContent: { result },\n };\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n logger.error('sheets.spreadsheet.rename error', { error: message });\n\n throw new McpError(ErrorCode.InternalError, `Error renaming spreadsheet: ${message}`, {\n stack: error instanceof Error ? error.stack : undefined,\n });\n }\n}\n\nexport default function createTool() {\n return {\n name: 'spreadsheet-rename',\n config,\n handler,\n } satisfies ToolModule;\n}\n"],"names":["createTool","AuthRequiredBranchSchema","schemas","inputSchema","z","object","id","SpreadsheetIdSchema","newTitle","coerce","string","trim","min","describe","successBranchSchema","type","literal","operationSummary","itemsProcessed","number","itemsChanged","completedAt","SpreadsheetIdOutput","spreadsheetUrl","oldTitle","outputSchema","discriminatedUnion","config","description","result","handler","extra","logger","spreadsheetInfo","sheets","error","message","info","google","version","auth","authContext","spreadsheets","get","spreadsheetId","fields","data","properties","title","batchUpdate","requestBody","requests","updateSpreadsheetProperties","Date","toISOString","content","text","JSON","stringify","structuredContent","Error","String","McpError","ErrorCode","InternalError","stack","undefined","name"],"mappings":"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"}
@@ -12,8 +12,8 @@ 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 _index = require("../../schemas/index.js");
16
- var _rangeoperations = require("../../spreadsheet/range-operations.js");
15
+ var _indexts = require("../../schemas/index.js");
16
+ var _rangeoperationsts = require("../../spreadsheet/range-operations.js");
17
17
  function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
18
18
  try {
19
19
  var info = gen[key](arg);
@@ -210,14 +210,14 @@ var ValidationRequestSchema = _zod.z.object({
210
210
  inputMessage: _zod.z.string().optional().describe('Help text shown when cell is selected')
211
211
  });
212
212
  var inputSchema = _zod.z.object({
213
- id: _index.SpreadsheetIdSchema,
214
- gid: _index.SheetGidSchema,
213
+ id: _indexts.SpreadsheetIdSchema,
214
+ gid: _indexts.SheetGidSchema,
215
215
  requests: _zod.z.array(ValidationRequestSchema).min(1).max(50).describe('Array of validation rules. Batch multiple ranges for efficiency.')
216
216
  });
217
217
  var successBranchSchema = _zod.z.object({
218
218
  type: _zod.z.literal('success'),
219
- id: _index.SpreadsheetIdOutput,
220
- gid: _index.SheetGidOutput,
219
+ id: _indexts.SpreadsheetIdOutput,
220
+ gid: _indexts.SheetGidOutput,
221
221
  sheetTitle: _zod.z.string().describe('Title of the sheet with validation'),
222
222
  sheetUrl: _zod.z.string().describe('URL of the sheet with validation'),
223
223
  successCount: _zod.z.number().int().nonnegative().describe('Number of validation rules successfully applied'),
@@ -419,9 +419,9 @@ function handler(_0, _1) {
419
419
  request = _step.value;
420
420
  try {
421
421
  // Parse A1 notation to range reference
422
- rangeRef = (0, _rangeoperations.parseA1Notation)(request.range);
422
+ rangeRef = (0, _rangeoperationsts.parseA1Notation)(request.range);
423
423
  // Build grid range from range reference using helper function
424
- gridRange = (0, _rangeoperations.rangeReferenceToGridRange)(rangeRef, sheetId);
424
+ gridRange = (0, _rangeoperationsts.rangeReferenceToGridRange)(rangeRef, sheetId);
425
425
  // Build validation rule
426
426
  condition = buildCondition(request.rule);
427
427
  // Build data validation rule - structure matches Schema$DataValidationRule