@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,591 @@
1
+ /**
2
+ * Range Operations Utilities for Google Sheets
3
+ *
4
+ * This module provides comprehensive utilities for working with A1 notation,
5
+ * range parsing, batch operations, and range validation in Google Sheets.
6
+ *
7
+ * Key features:
8
+ * - A1 notation validation and parsing
9
+ * - Range manipulation and calculation utilities
10
+ * - Batch operation builders for Google Sheets API
11
+ * - Cell count and dimension calculations
12
+ * - Range conflict detection for batch operations
13
+ * - Google Sheets limits validation and enforcement
14
+ */ import { a1Col } from './column-utilities.js';
15
+ // Google Sheets constants and limits
16
+ export const GOOGLE_SHEETS_LIMITS = {
17
+ MAX_ROWS: 10000000,
18
+ MAX_COLUMNS: 18278,
19
+ MAX_CELLS: 10000000,
20
+ MAX_BATCH_REQUESTS: 1000,
21
+ MAX_DIMENSION_BATCH_REQUESTS: 100
22
+ };
23
+ /**
24
+ * A1 Notation Validation Utilities
25
+ */ /**
26
+ * Validates if a string is a valid A1 notation
27
+ */ export function isValidA1Notation(notation) {
28
+ if (!notation || typeof notation !== 'string') {
29
+ return false;
30
+ }
31
+ // Use the same regex pattern as in the schema
32
+ const a1Pattern = /^(?:[A-Z]{1,3}(?:[1-9]\d{0,6}|10000000)(?::[A-Z]{1,3}(?:[1-9]\d{0,6}|10000000))?|[A-Z]{1,3}:[A-Z]{1,3}|(?:[1-9]\d{0,6}|10000000):(?:[1-9]\d{0,6}|10000000))$/;
33
+ if (!a1Pattern.test(notation)) {
34
+ return false;
35
+ }
36
+ // Additional validation for Google Sheets limits
37
+ const parts = notation.split(':');
38
+ for (const part of parts){
39
+ // Check cell reference
40
+ const cellMatch = part.match(/^([A-Z]{1,3})([1-9]\d{0,6}|10000000)$/);
41
+ if (cellMatch && cellMatch[1] && cellMatch[2]) {
42
+ const [, colStr, rowStr] = cellMatch;
43
+ // Validate column
44
+ const colNum = columnStringToIndex(colStr);
45
+ if (colNum > GOOGLE_SHEETS_LIMITS.MAX_COLUMNS) {
46
+ return false;
47
+ }
48
+ // Validate row
49
+ const rowNum = parseInt(rowStr, 10);
50
+ if (rowNum > GOOGLE_SHEETS_LIMITS.MAX_ROWS) {
51
+ return false;
52
+ }
53
+ }
54
+ // Check column reference
55
+ const colMatch = part.match(/^([A-Z]{1,3})$/);
56
+ if (colMatch && colMatch[1]) {
57
+ const colNum = columnStringToIndex(colMatch[1]);
58
+ if (colNum > GOOGLE_SHEETS_LIMITS.MAX_COLUMNS) {
59
+ return false;
60
+ }
61
+ }
62
+ // Check row reference
63
+ const rowMatch = part.match(/^([1-9]\d{0,6}|10000000)$/);
64
+ if (rowMatch && rowMatch[1]) {
65
+ const rowNum = parseInt(rowMatch[1], 10);
66
+ if (rowNum > GOOGLE_SHEETS_LIMITS.MAX_ROWS) {
67
+ return false;
68
+ }
69
+ }
70
+ }
71
+ return true;
72
+ }
73
+ /**
74
+ * Validates A1 notation and throws detailed error if invalid
75
+ */ export function validateA1Notation(notation) {
76
+ if (!isValidA1Notation(notation)) {
77
+ throw new Error(`Invalid A1 notation: "${notation}". Valid formats: A1, A1:B2, A:B, 1:2`);
78
+ }
79
+ }
80
+ /**
81
+ * Range Parsing and Manipulation Functions
82
+ */ /**
83
+ * Converts column string (A, B, AA, etc.) to 1-based index
84
+ */ export function columnStringToIndex(colStr) {
85
+ let colNum = 0;
86
+ for(let i = 0; i < colStr.length; i++){
87
+ colNum = colNum * 26 + (colStr.charCodeAt(i) - 64);
88
+ }
89
+ return colNum;
90
+ }
91
+ /**
92
+ * Converts 1-based column index to column string (A, B, AA, etc.)
93
+ */ export function columnIndexToString(colIndex) {
94
+ return a1Col(colIndex);
95
+ }
96
+ /**
97
+ * Parses a cell reference (e.g., "A1", "Z999") into its components
98
+ */ export function parseCellReference(cellRef) {
99
+ const match = cellRef.match(/^([A-Z]{1,3})([1-9]\d{0,6}|10000000)$/);
100
+ if (!match || !match[1] || !match[2]) {
101
+ throw new Error(`Invalid cell reference: ${cellRef}`);
102
+ }
103
+ const [, column, rowStr] = match;
104
+ const row = parseInt(rowStr, 10);
105
+ const columnIndex = columnStringToIndex(column);
106
+ return {
107
+ column,
108
+ columnIndex,
109
+ row
110
+ };
111
+ }
112
+ /**
113
+ * Parses A1 notation into a structured range reference
114
+ */ export function parseA1Notation(notation) {
115
+ validateA1Notation(notation);
116
+ const parts = notation.split(':');
117
+ if (parts.length === 1) {
118
+ const part = parts[0];
119
+ if (!part) {
120
+ throw new Error('Invalid A1 notation: empty part after split');
121
+ }
122
+ // Single cell reference (e.g., A1)
123
+ const cellMatch = part.match(/^([A-Z]{1,3})([1-9]\d{0,6}|10000000)$/);
124
+ if (cellMatch && cellMatch[1] && cellMatch[2]) {
125
+ const startCell = parseCellReference(part);
126
+ return {
127
+ type: 'cell',
128
+ startCell,
129
+ endCell: startCell
130
+ };
131
+ }
132
+ // Single column reference (e.g., A)
133
+ const colMatch = part.match(/^([A-Z]{1,3})$/);
134
+ if (colMatch && colMatch[1]) {
135
+ const column = colMatch[1];
136
+ const columnIndex = columnStringToIndex(column);
137
+ return {
138
+ type: 'column',
139
+ startColumn: column,
140
+ endColumn: column,
141
+ startColumnIndex: columnIndex,
142
+ endColumnIndex: columnIndex
143
+ };
144
+ }
145
+ // Single row reference (e.g., 1)
146
+ const rowMatch = part.match(/^([1-9]\d{0,6}|10000000)$/);
147
+ if (rowMatch && rowMatch[1]) {
148
+ const row = parseInt(rowMatch[1], 10);
149
+ return {
150
+ type: 'row',
151
+ startRow: row,
152
+ endRow: row
153
+ };
154
+ }
155
+ }
156
+ if (parts.length === 2 && parts[0] && parts[1]) {
157
+ const [start, end] = parts;
158
+ // Cell range (e.g., A1:B5)
159
+ const startCellMatch = start.match(/^([A-Z]{1,3})([1-9]\d{0,6}|10000000)$/);
160
+ const endCellMatch = end.match(/^([A-Z]{1,3})([1-9]\d{0,6}|10000000)$/);
161
+ if (startCellMatch && endCellMatch && startCellMatch[1] && startCellMatch[2] && endCellMatch[1] && endCellMatch[2]) {
162
+ const startCell = parseCellReference(start);
163
+ const endCell = parseCellReference(end);
164
+ return {
165
+ type: 'range',
166
+ startCell,
167
+ endCell
168
+ };
169
+ }
170
+ // Column range (e.g., A:B)
171
+ const startColMatch = start.match(/^([A-Z]{1,3})$/);
172
+ const endColMatch = end.match(/^([A-Z]{1,3})$/);
173
+ if (startColMatch && endColMatch && startColMatch[1] && endColMatch[1]) {
174
+ const startColumn = startColMatch[1];
175
+ const endColumn = endColMatch[1];
176
+ const startColumnIndex = columnStringToIndex(startColumn);
177
+ const endColumnIndex = columnStringToIndex(endColumn);
178
+ return {
179
+ type: 'column',
180
+ startColumn,
181
+ endColumn,
182
+ startColumnIndex,
183
+ endColumnIndex
184
+ };
185
+ }
186
+ // Row range (e.g., 1:5)
187
+ const startRowMatch = start.match(/^([1-9]\d{0,6}|10000000)$/);
188
+ const endRowMatch = end.match(/^([1-9]\d{0,6}|10000000)$/);
189
+ if (startRowMatch && endRowMatch && startRowMatch[1] && endRowMatch[1]) {
190
+ const startRow = parseInt(startRowMatch[1], 10);
191
+ const endRow = parseInt(endRowMatch[1], 10);
192
+ return {
193
+ type: 'row',
194
+ startRow,
195
+ endRow
196
+ };
197
+ }
198
+ }
199
+ throw new Error(`Unable to parse A1 notation: ${notation}`);
200
+ }
201
+ /**
202
+ * Converts a range reference back to A1 notation
203
+ */ export function rangeToA1Notation(range) {
204
+ switch(range.type){
205
+ case 'cell':
206
+ if (!range.startCell) throw new Error('Invalid cell range: missing startCell');
207
+ return `${range.startCell.column}${range.startCell.row}`;
208
+ case 'range':
209
+ if (!range.startCell || !range.endCell) throw new Error('Invalid range: missing start or end cell');
210
+ return `${range.startCell.column}${range.startCell.row}:${range.endCell.column}${range.endCell.row}`;
211
+ case 'column':
212
+ if (!range.startColumn || !range.endColumn) throw new Error('Invalid column range: missing start or end column');
213
+ if (range.startColumn === range.endColumn) {
214
+ return range.startColumn;
215
+ }
216
+ return `${range.startColumn}:${range.endColumn}`;
217
+ case 'row':
218
+ if (range.startRow === undefined || range.endRow === undefined) throw new Error('Invalid row range: missing start or end row');
219
+ if (range.startRow === range.endRow) {
220
+ return range.startRow.toString();
221
+ }
222
+ return `${range.startRow}:${range.endRow}`;
223
+ default:
224
+ throw new Error(`Unknown range type: ${range.type}`);
225
+ }
226
+ }
227
+ /**
228
+ * Cell Count and Dimension Calculation Utilities
229
+ */ /**
230
+ * Calculates the dimensions of a range
231
+ */ export function calculateRangeDimensions(notation) {
232
+ const range = parseA1Notation(notation);
233
+ switch(range.type){
234
+ case 'cell':
235
+ return {
236
+ rows: 1,
237
+ columns: 1,
238
+ cells: 1
239
+ };
240
+ case 'range':
241
+ {
242
+ if (!range.startCell || !range.endCell) throw new Error('Invalid range: missing cells');
243
+ const rows = range.endCell.row - range.startCell.row + 1;
244
+ const columns = range.endCell.columnIndex - range.startCell.columnIndex + 1;
245
+ return {
246
+ rows,
247
+ columns,
248
+ cells: rows * columns
249
+ };
250
+ }
251
+ case 'column':
252
+ {
253
+ if (range.startColumnIndex === undefined || range.endColumnIndex === undefined) {
254
+ throw new Error('Invalid column range: missing column indices');
255
+ }
256
+ const columnCount = range.endColumnIndex - range.startColumnIndex + 1;
257
+ return {
258
+ rows: GOOGLE_SHEETS_LIMITS.MAX_ROWS,
259
+ columns: columnCount,
260
+ cells: GOOGLE_SHEETS_LIMITS.MAX_ROWS * columnCount
261
+ };
262
+ }
263
+ case 'row':
264
+ {
265
+ if (range.startRow === undefined || range.endRow === undefined) {
266
+ throw new Error('Invalid row range: missing row numbers');
267
+ }
268
+ const rowCount = range.endRow - range.startRow + 1;
269
+ return {
270
+ rows: rowCount,
271
+ columns: GOOGLE_SHEETS_LIMITS.MAX_COLUMNS,
272
+ cells: rowCount * GOOGLE_SHEETS_LIMITS.MAX_COLUMNS
273
+ };
274
+ }
275
+ default:
276
+ throw new Error(`Unknown range type: ${range.type}`);
277
+ }
278
+ }
279
+ /**
280
+ * Calculates total cells affected by multiple ranges
281
+ */ export function calculateTotalCells(ranges) {
282
+ return ranges.reduce((total, range)=>{
283
+ const dimensions = calculateRangeDimensions(range);
284
+ return total + dimensions.cells;
285
+ }, 0);
286
+ }
287
+ /**
288
+ * Batch Operation Builders for Google API
289
+ */ /**
290
+ * Builds a values batch update request for Google Sheets API
291
+ */ export function buildValuesBatchUpdateRequest(requests, sheetTitle, options = {}) {
292
+ // Validate all ranges first
293
+ requests.forEach((req, index)=>{
294
+ try {
295
+ validateA1Notation(req.range);
296
+ } catch (error) {
297
+ throw new Error(`Invalid range in request ${index}: ${error}`);
298
+ }
299
+ });
300
+ // Calculate total cells for validation
301
+ const totalCells = calculateTotalCells(requests.map((r)=>r.range));
302
+ if (totalCells > GOOGLE_SHEETS_LIMITS.MAX_CELLS) {
303
+ throw new Error(`Batch update exceeds maximum cells limit: ${totalCells} > ${GOOGLE_SHEETS_LIMITS.MAX_CELLS}`);
304
+ }
305
+ // Build the request
306
+ const data = requests.map((req)=>({
307
+ range: `${sheetTitle}!${req.range}`,
308
+ values: req.values,
309
+ majorDimension: req.majorDimension || 'ROWS'
310
+ }));
311
+ return {
312
+ valueInputOption: options.valueInputOption || 'USER_ENTERED',
313
+ data,
314
+ includeValuesInResponse: options.includeValuesInResponse || false,
315
+ responseDateTimeRenderOption: options.responseDateTimeRenderOption || 'FORMATTED_STRING',
316
+ responseValueRenderOption: options.responseValueRenderOption || 'FORMATTED_VALUE'
317
+ };
318
+ }
319
+ /**
320
+ * Range Conflict Detection
321
+ */ /**
322
+ * Checks if two ranges overlap
323
+ */ export function rangesOverlap(range1, range2) {
324
+ try {
325
+ const parsed1 = parseA1Notation(range1);
326
+ const parsed2 = parseA1Notation(range2);
327
+ // Different types might still overlap, so we need to normalize to cell ranges
328
+ const normalized1 = normalizeRangeToBounds(parsed1);
329
+ const normalized2 = normalizeRangeToBounds(parsed2);
330
+ // Check for overlap
331
+ return !(normalized1.endRow < normalized2.startRow || normalized2.endRow < normalized1.startRow || normalized1.endCol < normalized2.startCol || normalized2.endCol < normalized1.startCol);
332
+ } catch {
333
+ // If we can't parse the ranges, assume no overlap
334
+ return false;
335
+ }
336
+ }
337
+ /**
338
+ * Normalizes a range to bounds for overlap checking
339
+ */ function normalizeRangeToBounds(range) {
340
+ switch(range.type){
341
+ case 'cell':
342
+ if (!range.startCell) throw new Error('Invalid cell range');
343
+ return {
344
+ startRow: range.startCell.row,
345
+ endRow: range.startCell.row,
346
+ startCol: range.startCell.columnIndex,
347
+ endCol: range.startCell.columnIndex
348
+ };
349
+ case 'range':
350
+ if (!range.startCell || !range.endCell) throw new Error('Invalid range');
351
+ return {
352
+ startRow: range.startCell.row,
353
+ endRow: range.endCell.row,
354
+ startCol: range.startCell.columnIndex,
355
+ endCol: range.endCell.columnIndex
356
+ };
357
+ case 'column':
358
+ if (range.startColumnIndex === undefined || range.endColumnIndex === undefined) {
359
+ throw new Error('Invalid column range');
360
+ }
361
+ return {
362
+ startRow: 1,
363
+ endRow: GOOGLE_SHEETS_LIMITS.MAX_ROWS,
364
+ startCol: range.startColumnIndex,
365
+ endCol: range.endColumnIndex
366
+ };
367
+ case 'row':
368
+ if (range.startRow === undefined || range.endRow === undefined) {
369
+ throw new Error('Invalid row range');
370
+ }
371
+ return {
372
+ startRow: range.startRow,
373
+ endRow: range.endRow,
374
+ startCol: 1,
375
+ endCol: GOOGLE_SHEETS_LIMITS.MAX_COLUMNS
376
+ };
377
+ default:
378
+ throw new Error(`Unknown range type: ${range.type}`);
379
+ }
380
+ }
381
+ /**
382
+ * Detects conflicts between multiple ranges
383
+ */ export function detectRangeConflicts(ranges) {
384
+ const conflicts = [];
385
+ for(let i = 0; i < ranges.length; i++){
386
+ for(let j = i + 1; j < ranges.length; j++){
387
+ const range1 = ranges[i];
388
+ const range2 = ranges[j];
389
+ if (!range1 || !range2) continue;
390
+ if (rangesOverlap(range1, range2)) {
391
+ conflicts.push({
392
+ range1,
393
+ range2,
394
+ conflictType: 'overlap',
395
+ description: `Ranges ${range1} and ${range2} overlap`
396
+ });
397
+ }
398
+ }
399
+ }
400
+ return conflicts;
401
+ }
402
+ /**
403
+ * Validates that a batch of ranges doesn't exceed Google Sheets limits
404
+ */ export function validateBatchRanges(ranges) {
405
+ const errors = [];
406
+ const warnings = [];
407
+ let totalCells = 0;
408
+ // Validate each range
409
+ ranges.forEach((range, index)=>{
410
+ try {
411
+ validateA1Notation(range);
412
+ const dimensions = calculateRangeDimensions(range);
413
+ totalCells += dimensions.cells;
414
+ // Check for very large ranges that might cause performance issues
415
+ if (dimensions.cells > 1000000) {
416
+ warnings.push(`Range ${index + 1} (${range}) affects ${dimensions.cells.toLocaleString()} cells, which may impact performance`);
417
+ }
418
+ } catch (error) {
419
+ errors.push(`Range ${index + 1} (${range}): ${error}`);
420
+ }
421
+ });
422
+ // Check batch size limits
423
+ if (ranges.length > GOOGLE_SHEETS_LIMITS.MAX_BATCH_REQUESTS) {
424
+ errors.push(`Too many ranges: ${ranges.length} > ${GOOGLE_SHEETS_LIMITS.MAX_BATCH_REQUESTS}`);
425
+ }
426
+ // Check total cells limit
427
+ if (totalCells > GOOGLE_SHEETS_LIMITS.MAX_CELLS) {
428
+ errors.push(`Total cells exceed limit: ${totalCells.toLocaleString()} > ${GOOGLE_SHEETS_LIMITS.MAX_CELLS.toLocaleString()}`);
429
+ }
430
+ // Check for conflicts
431
+ const conflicts = detectRangeConflicts(ranges);
432
+ conflicts.forEach((conflict)=>{
433
+ warnings.push(conflict.description);
434
+ });
435
+ return {
436
+ valid: errors.length === 0,
437
+ errors,
438
+ warnings,
439
+ totalCells
440
+ };
441
+ }
442
+ /**
443
+ * Utility Functions for Common Range Operations
444
+ */ /**
445
+ * Expands a range by a specified number of rows and columns
446
+ */ export function expandRange(notation, expandRows, expandCols) {
447
+ const range = parseA1Notation(notation);
448
+ if (range.type === 'cell' && range.startCell) {
449
+ const newEndRow = Math.min(range.startCell.row + expandRows, GOOGLE_SHEETS_LIMITS.MAX_ROWS);
450
+ const newEndCol = Math.min(range.startCell.columnIndex + expandCols, GOOGLE_SHEETS_LIMITS.MAX_COLUMNS);
451
+ const newEndColStr = columnIndexToString(newEndCol);
452
+ if (expandRows === 0 && expandCols === 0) {
453
+ return notation;
454
+ }
455
+ return `${range.startCell.column}${range.startCell.row}:${newEndColStr}${newEndRow}`;
456
+ }
457
+ if (range.type === 'range' && range.startCell && range.endCell) {
458
+ const newEndRow = Math.min(range.endCell.row + expandRows, GOOGLE_SHEETS_LIMITS.MAX_ROWS);
459
+ const newEndCol = Math.min(range.endCell.columnIndex + expandCols, GOOGLE_SHEETS_LIMITS.MAX_COLUMNS);
460
+ const newEndColStr = columnIndexToString(newEndCol);
461
+ return `${range.startCell.column}${range.startCell.row}:${newEndColStr}${newEndRow}`;
462
+ }
463
+ // For row and column ranges, expansion doesn't make sense in the same way
464
+ return notation;
465
+ }
466
+ /**
467
+ * Gets the intersection of two ranges
468
+ */ export function getRangeIntersection(range1, range2) {
469
+ try {
470
+ const parsed1 = parseA1Notation(range1);
471
+ const parsed2 = parseA1Notation(range2);
472
+ const bounds1 = normalizeRangeToBounds(parsed1);
473
+ const bounds2 = normalizeRangeToBounds(parsed2);
474
+ // Check if they overlap
475
+ if (!rangesOverlap(range1, range2)) {
476
+ return null;
477
+ }
478
+ // Calculate intersection bounds
479
+ const startRow = Math.max(bounds1.startRow, bounds2.startRow);
480
+ const endRow = Math.min(bounds1.endRow, bounds2.endRow);
481
+ const startCol = Math.max(bounds1.startCol, bounds2.startCol);
482
+ const endCol = Math.min(bounds1.endCol, bounds2.endCol);
483
+ const startColStr = columnIndexToString(startCol);
484
+ const endColStr = columnIndexToString(endCol);
485
+ if (startRow === endRow && startCol === endCol) {
486
+ return `${startColStr}${startRow}`;
487
+ }
488
+ return `${startColStr}${startRow}:${endColStr}${endRow}`;
489
+ } catch {
490
+ return null;
491
+ }
492
+ }
493
+ /**
494
+ * Splits a large range into smaller chunks for batch processing
495
+ */ export function splitRangeIntoChunks(notation, maxCellsPerChunk = 100000) {
496
+ const range = parseA1Notation(notation);
497
+ const dimensions = calculateRangeDimensions(notation);
498
+ if (dimensions.cells <= maxCellsPerChunk) {
499
+ return [
500
+ notation
501
+ ];
502
+ }
503
+ const chunks = [];
504
+ if (range.type === 'range' && range.startCell && range.endCell) {
505
+ const totalRows = range.endCell.row - range.startCell.row + 1;
506
+ const totalCols = range.endCell.columnIndex - range.startCell.columnIndex + 1;
507
+ // Calculate chunk size based on max cells
508
+ const cellsPerRow = totalCols;
509
+ const maxRowsPerChunk = Math.floor(maxCellsPerChunk / cellsPerRow);
510
+ if (maxRowsPerChunk >= 1) {
511
+ // Split by rows
512
+ for(let currentRow = range.startCell.row; currentRow <= range.endCell.row; currentRow += maxRowsPerChunk){
513
+ const chunkEndRow = Math.min(currentRow + maxRowsPerChunk - 1, range.endCell.row);
514
+ const chunkRange = `${range.startCell.column}${currentRow}:${range.endCell.column}${chunkEndRow}`;
515
+ chunks.push(chunkRange);
516
+ }
517
+ } else {
518
+ // If even one row is too big, split by columns
519
+ const maxColsPerChunk = Math.floor(maxCellsPerChunk / totalRows);
520
+ for(let currentCol = range.startCell.columnIndex; currentCol <= range.endCell.columnIndex; currentCol += maxColsPerChunk){
521
+ const chunkEndCol = Math.min(currentCol + maxColsPerChunk - 1, range.endCell.columnIndex);
522
+ const startColStr = columnIndexToString(currentCol);
523
+ const endColStr = columnIndexToString(chunkEndCol);
524
+ const chunkRange = `${startColStr}${range.startCell.row}:${endColStr}${range.endCell.row}`;
525
+ chunks.push(chunkRange);
526
+ }
527
+ }
528
+ } else {
529
+ // For other range types, just return the original range
530
+ // (column and row ranges are already at their limits)
531
+ chunks.push(notation);
532
+ }
533
+ return chunks;
534
+ }
535
+ /**
536
+ * Converts a RangeReference to Google Sheets API GridRange format
537
+ *
538
+ * This handles the different range types correctly:
539
+ * - 'cell' and 'range' types: Extract indices from startCell/endCell
540
+ * - 'row' types: Use startRow/endRow, omit column indices for full row
541
+ * - 'column' types: Use startColumnIndex/endColumnIndex, omit row indices for full column
542
+ *
543
+ * Important: Google Sheets API uses 0-based indices, while A1 notation uses 1-based indices.
544
+ * This function handles the conversion properly for each range type.
545
+ */ export function rangeReferenceToGridRange(rangeRef, sheetId) {
546
+ if (rangeRef.type === 'cell' || rangeRef.type === 'range') {
547
+ // For cell and range types, extract from startCell/endCell
548
+ if (!rangeRef.startCell || !rangeRef.endCell) {
549
+ throw new Error(`Invalid ${rangeRef.type} range: missing start or end cell`);
550
+ }
551
+ return {
552
+ sheetId,
553
+ // Convert 1-based row to 0-based startRowIndex
554
+ startRowIndex: rangeRef.startCell.row - 1,
555
+ // endRowIndex is exclusive (so row 5 becomes endRowIndex 5)
556
+ endRowIndex: rangeRef.endCell.row,
557
+ // Convert 1-based column index to 0-based startColumnIndex
558
+ startColumnIndex: rangeRef.startCell.columnIndex - 1,
559
+ // endColumnIndex is exclusive
560
+ endColumnIndex: rangeRef.endCell.columnIndex
561
+ };
562
+ }
563
+ if (rangeRef.type === 'row') {
564
+ // For row types, use startRow/endRow and omit column indices for full row width
565
+ if (rangeRef.startRow === undefined || rangeRef.endRow === undefined) {
566
+ throw new Error('Invalid row range: missing start or end row');
567
+ }
568
+ return {
569
+ sheetId,
570
+ // Convert 1-based row to 0-based startRowIndex
571
+ startRowIndex: rangeRef.startRow - 1,
572
+ // endRowIndex is exclusive
573
+ endRowIndex: rangeRef.endRow
574
+ };
575
+ }
576
+ if (rangeRef.type === 'column') {
577
+ // For column types, use startColumnIndex/endColumnIndex and omit row indices for full column height
578
+ if (rangeRef.startColumnIndex === undefined || rangeRef.endColumnIndex === undefined) {
579
+ throw new Error('Invalid column range: missing start or end column index');
580
+ }
581
+ return {
582
+ sheetId,
583
+ // Omit startRowIndex and endRowIndex to apply to all rows
584
+ // Convert 1-based column index to 0-based startColumnIndex
585
+ startColumnIndex: rangeRef.startColumnIndex - 1,
586
+ // endColumnIndex is exclusive
587
+ endColumnIndex: rangeRef.endColumnIndex
588
+ };
589
+ }
590
+ throw new Error(`Unknown range type: ${rangeRef.type}`);
591
+ }