@mcp-z/mcp-sheets 1.0.0

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