digital-tools 2.1.3 → 2.4.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 (294) hide show
  1. package/.turbo/turbo-build.log +1 -1
  2. package/CHANGELOG.md +19 -0
  3. package/README.md +2 -0
  4. package/dist/client.d.ts +109 -0
  5. package/dist/client.d.ts.map +1 -0
  6. package/dist/client.js +69 -0
  7. package/dist/client.js.map +1 -0
  8. package/dist/define.d.ts +2 -2
  9. package/dist/define.d.ts.map +1 -1
  10. package/dist/define.js +21 -11
  11. package/dist/define.js.map +1 -1
  12. package/dist/function-ref.d.ts +229 -0
  13. package/dist/function-ref.d.ts.map +1 -0
  14. package/dist/function-ref.js +28 -0
  15. package/dist/function-ref.js.map +1 -0
  16. package/dist/function-sugar.d.ts +57 -0
  17. package/dist/function-sugar.d.ts.map +1 -0
  18. package/dist/function-sugar.js +79 -0
  19. package/dist/function-sugar.js.map +1 -0
  20. package/dist/index.d.ts +10 -3
  21. package/dist/index.d.ts.map +1 -1
  22. package/dist/index.js +24 -4
  23. package/dist/index.js.map +1 -1
  24. package/dist/providers/analytics/mixpanel.d.ts.map +1 -1
  25. package/dist/providers/analytics/mixpanel.js +21 -18
  26. package/dist/providers/analytics/mixpanel.js.map +1 -1
  27. package/dist/providers/calendar/cal-com.d.ts.map +1 -1
  28. package/dist/providers/calendar/cal-com.js +10 -10
  29. package/dist/providers/calendar/cal-com.js.map +1 -1
  30. package/dist/providers/calendar/google-calendar.d.ts.map +1 -1
  31. package/dist/providers/calendar/google-calendar.js +4 -4
  32. package/dist/providers/calendar/google-calendar.js.map +1 -1
  33. package/dist/providers/crm/hubspot.d.ts.map +1 -1
  34. package/dist/providers/crm/hubspot.js +107 -85
  35. package/dist/providers/crm/hubspot.js.map +1 -1
  36. package/dist/providers/development/github.d.ts.map +1 -1
  37. package/dist/providers/development/github.js +40 -43
  38. package/dist/providers/development/github.js.map +1 -1
  39. package/dist/providers/ecommerce/shopify.d.ts.map +1 -1
  40. package/dist/providers/ecommerce/shopify.js +79 -62
  41. package/dist/providers/ecommerce/shopify.js.map +1 -1
  42. package/dist/providers/email/resend.d.ts.map +1 -1
  43. package/dist/providers/email/resend.js +20 -16
  44. package/dist/providers/email/resend.js.map +1 -1
  45. package/dist/providers/email/sendgrid.d.ts.map +1 -1
  46. package/dist/providers/email/sendgrid.js +12 -9
  47. package/dist/providers/email/sendgrid.js.map +1 -1
  48. package/dist/providers/finance/stripe.d.ts.map +1 -1
  49. package/dist/providers/finance/stripe.js +44 -42
  50. package/dist/providers/finance/stripe.js.map +1 -1
  51. package/dist/providers/forms/typeform.d.ts.map +1 -1
  52. package/dist/providers/forms/typeform.js +68 -58
  53. package/dist/providers/forms/typeform.js.map +1 -1
  54. package/dist/providers/knowledge/notion.d.ts.map +1 -1
  55. package/dist/providers/knowledge/notion.js +75 -41
  56. package/dist/providers/knowledge/notion.js.map +1 -1
  57. package/dist/providers/marketing/mailchimp.d.ts.map +1 -1
  58. package/dist/providers/marketing/mailchimp.js +74 -61
  59. package/dist/providers/marketing/mailchimp.js.map +1 -1
  60. package/dist/providers/media/cloudinary.d.ts.map +1 -1
  61. package/dist/providers/media/cloudinary.js +30 -28
  62. package/dist/providers/media/cloudinary.js.map +1 -1
  63. package/dist/providers/messaging/slack.d.ts.map +1 -1
  64. package/dist/providers/messaging/slack.js +75 -58
  65. package/dist/providers/messaging/slack.js.map +1 -1
  66. package/dist/providers/messaging/twilio-sms.d.ts.map +1 -1
  67. package/dist/providers/messaging/twilio-sms.js +33 -15
  68. package/dist/providers/messaging/twilio-sms.js.map +1 -1
  69. package/dist/providers/project-management/linear.d.ts.map +1 -1
  70. package/dist/providers/project-management/linear.js +31 -27
  71. package/dist/providers/project-management/linear.js.map +1 -1
  72. package/dist/providers/spreadsheet/google-sheets.d.ts.map +1 -1
  73. package/dist/providers/spreadsheet/google-sheets.js +21 -18
  74. package/dist/providers/spreadsheet/google-sheets.js.map +1 -1
  75. package/dist/providers/spreadsheet/xlsx.d.ts.map +1 -1
  76. package/dist/providers/spreadsheet/xlsx.js +4 -4
  77. package/dist/providers/spreadsheet/xlsx.js.map +1 -1
  78. package/dist/providers/storage/index.js +1 -0
  79. package/dist/providers/storage/index.js.map +1 -1
  80. package/dist/providers/storage/s3.d.ts.map +1 -1
  81. package/dist/providers/storage/s3.js +36 -27
  82. package/dist/providers/storage/s3.js.map +1 -1
  83. package/dist/providers/support/zendesk.d.ts.map +1 -1
  84. package/dist/providers/support/zendesk.js +24 -25
  85. package/dist/providers/support/zendesk.js.map +1 -1
  86. package/dist/providers/tasks/todoist.d.ts.map +1 -1
  87. package/dist/providers/tasks/todoist.js +18 -18
  88. package/dist/providers/tasks/todoist.js.map +1 -1
  89. package/dist/providers/video-conferencing/google-meet.d.ts.map +1 -1
  90. package/dist/providers/video-conferencing/google-meet.js +11 -11
  91. package/dist/providers/video-conferencing/google-meet.js.map +1 -1
  92. package/dist/providers/video-conferencing/jitsi.js +14 -14
  93. package/dist/providers/video-conferencing/jitsi.js.map +1 -1
  94. package/dist/providers/video-conferencing/teams.d.ts.map +1 -1
  95. package/dist/providers/video-conferencing/teams.js +9 -7
  96. package/dist/providers/video-conferencing/teams.js.map +1 -1
  97. package/dist/providers/video-conferencing/zoom.d.ts.map +1 -1
  98. package/dist/providers/video-conferencing/zoom.js +26 -24
  99. package/dist/providers/video-conferencing/zoom.js.map +1 -1
  100. package/dist/tools/data.d.ts.map +1 -1
  101. package/dist/tools/data.js +5 -12
  102. package/dist/tools/data.js.map +1 -1
  103. package/dist/tools/index.d.ts +1 -0
  104. package/dist/tools/index.d.ts.map +1 -1
  105. package/dist/tools/index.js +1 -0
  106. package/dist/tools/index.js.map +1 -1
  107. package/dist/tools/system.d.ts +289 -0
  108. package/dist/tools/system.d.ts.map +1 -0
  109. package/dist/tools/system.js +752 -0
  110. package/dist/tools/system.js.map +1 -0
  111. package/dist/tools/web.d.ts.map +1 -1
  112. package/dist/tools/web.js +22 -10
  113. package/dist/tools/web.js.map +1 -1
  114. package/dist/track-record.d.ts +101 -0
  115. package/dist/track-record.d.ts.map +1 -0
  116. package/dist/track-record.js +17 -0
  117. package/dist/track-record.js.map +1 -0
  118. package/dist/types.d.ts +210 -9
  119. package/dist/types.d.ts.map +1 -1
  120. package/dist/verb-registration.d.ts +122 -0
  121. package/dist/verb-registration.d.ts.map +1 -0
  122. package/dist/verb-registration.js +176 -0
  123. package/dist/verb-registration.js.map +1 -0
  124. package/dist/worker.d.ts +93 -0
  125. package/dist/worker.d.ts.map +1 -0
  126. package/dist/worker.js +315 -0
  127. package/dist/worker.js.map +1 -0
  128. package/dist/wrap.d.ts +89 -0
  129. package/dist/wrap.d.ts.map +1 -0
  130. package/dist/wrap.js +225 -0
  131. package/dist/wrap.js.map +1 -0
  132. package/package.json +31 -14
  133. package/src/client.ts +136 -0
  134. package/src/define.ts +30 -24
  135. package/src/function-ref.ts +264 -0
  136. package/src/function-sugar.ts +134 -0
  137. package/src/index.ts +132 -10
  138. package/src/providers/analytics/mixpanel.ts +19 -18
  139. package/src/providers/calendar/cal-com.ts +29 -18
  140. package/src/providers/calendar/google-calendar.ts +20 -14
  141. package/src/providers/crm/hubspot.ts +225 -99
  142. package/src/providers/development/github.ts +206 -135
  143. package/src/providers/ecommerce/shopify.ts +250 -89
  144. package/src/providers/email/resend.ts +101 -28
  145. package/src/providers/email/sendgrid.ts +12 -9
  146. package/src/providers/finance/stripe.ts +128 -49
  147. package/src/providers/forms/typeform.ts +74 -58
  148. package/src/providers/knowledge/notion.ts +340 -88
  149. package/src/providers/marketing/mailchimp.ts +86 -70
  150. package/src/providers/media/cloudinary.ts +99 -41
  151. package/src/providers/messaging/slack.ts +283 -85
  152. package/src/providers/messaging/twilio-sms.ts +35 -15
  153. package/src/providers/project-management/linear.ts +143 -55
  154. package/src/providers/spreadsheet/google-sheets.ts +222 -56
  155. package/src/providers/spreadsheet/xlsx.ts +47 -16
  156. package/src/providers/storage/s3.ts +119 -47
  157. package/src/providers/support/zendesk.ts +196 -46
  158. package/src/providers/tasks/todoist.ts +20 -26
  159. package/src/providers/video-conferencing/google-meet.ts +17 -20
  160. package/src/providers/video-conferencing/jitsi.ts +14 -14
  161. package/src/providers/video-conferencing/teams.ts +14 -13
  162. package/src/providers/video-conferencing/zoom.ts +54 -49
  163. package/src/tools/data.ts +6 -16
  164. package/src/tools/index.ts +1 -0
  165. package/src/tools/system.ts +887 -0
  166. package/src/tools/web.ts +22 -10
  167. package/src/track-record.ts +106 -0
  168. package/src/types.ts +241 -13
  169. package/src/verb-registration.ts +197 -0
  170. package/src/worker.ts +370 -0
  171. package/src/wrap.ts +260 -0
  172. package/test/client.test.ts +146 -0
  173. package/test/communication-tools-extended.test.ts +734 -0
  174. package/test/data-tools-extended.test.ts +743 -0
  175. package/test/define-extended.test.ts +819 -0
  176. package/test/define.test.ts +150 -41
  177. package/test/entities.test.ts +623 -0
  178. package/test/extended-entities.test.ts +1228 -0
  179. package/test/provider-implementations.test.ts +725 -0
  180. package/test/provider-registry-extended.test.ts +583 -0
  181. package/test/providers/google-sheets.test.ts +851 -0
  182. package/test/providers/helpers.ts +554 -0
  183. package/test/providers/hubspot.test.ts +576 -0
  184. package/test/providers/slack.test.ts +932 -0
  185. package/test/providers/stripe.test.ts +701 -0
  186. package/test/providers.test.ts +578 -0
  187. package/test/system-tools-extended.test.ts +632 -0
  188. package/test/system.test.ts +673 -0
  189. package/test/tools.test.ts +15 -11
  190. package/test/types.test.ts +402 -0
  191. package/test/verb-registration.test.ts +395 -0
  192. package/test/web-tools.test.ts +553 -0
  193. package/test/worker-extended.test.ts +699 -0
  194. package/test/worker.test.ts +576 -0
  195. package/test/wrap.test.ts +366 -0
  196. package/tsconfig.json +3 -13
  197. package/vitest.config.ts +37 -0
  198. package/wrangler.jsonc +9 -0
  199. package/LICENSE +0 -21
  200. package/dist/providers/voice/vapi.d.ts +0 -27
  201. package/dist/providers/voice/vapi.d.ts.map +0 -1
  202. package/dist/providers/voice/vapi.js +0 -440
  203. package/dist/providers/voice/vapi.js.map +0 -1
  204. package/src/define.js +0 -259
  205. package/src/entities/advertising.js +0 -999
  206. package/src/entities/ai.js +0 -756
  207. package/src/entities/analytics.js +0 -1588
  208. package/src/entities/automation.js +0 -601
  209. package/src/entities/communication.js +0 -1150
  210. package/src/entities/crm.js +0 -1386
  211. package/src/entities/design.js +0 -546
  212. package/src/entities/development.js +0 -2212
  213. package/src/entities/document.js +0 -874
  214. package/src/entities/ecommerce.js +0 -1429
  215. package/src/entities/experiment.js +0 -1039
  216. package/src/entities/finance.js +0 -3478
  217. package/src/entities/forms.js +0 -1892
  218. package/src/entities/hr.js +0 -661
  219. package/src/entities/identity.js +0 -997
  220. package/src/entities/index.js +0 -282
  221. package/src/entities/infrastructure.js +0 -1153
  222. package/src/entities/knowledge.js +0 -1438
  223. package/src/entities/marketing.js +0 -1610
  224. package/src/entities/media.js +0 -1634
  225. package/src/entities/notification.js +0 -1199
  226. package/src/entities/presentation.js +0 -1274
  227. package/src/entities/productivity.js +0 -1317
  228. package/src/entities/project-management.js +0 -1136
  229. package/src/entities/recruiting.js +0 -736
  230. package/src/entities/shipping.js +0 -509
  231. package/src/entities/signature.js +0 -1102
  232. package/src/entities/site.js +0 -222
  233. package/src/entities/spreadsheet.js +0 -1341
  234. package/src/entities/storage.js +0 -1198
  235. package/src/entities/support.js +0 -1166
  236. package/src/entities/video-conferencing.js +0 -1750
  237. package/src/entities/video.js +0 -950
  238. package/src/entities.js +0 -1663
  239. package/src/index.js +0 -74
  240. package/src/providers/analytics/index.js +0 -17
  241. package/src/providers/analytics/mixpanel.js +0 -255
  242. package/src/providers/calendar/cal-com.js +0 -303
  243. package/src/providers/calendar/google-calendar.js +0 -335
  244. package/src/providers/calendar/index.js +0 -20
  245. package/src/providers/crm/hubspot.js +0 -566
  246. package/src/providers/crm/index.js +0 -17
  247. package/src/providers/development/github.js +0 -472
  248. package/src/providers/development/index.js +0 -17
  249. package/src/providers/ecommerce/index.js +0 -17
  250. package/src/providers/ecommerce/shopify.js +0 -378
  251. package/src/providers/email/index.js +0 -20
  252. package/src/providers/email/resend.js +0 -258
  253. package/src/providers/email/sendgrid.js +0 -161
  254. package/src/providers/finance/index.js +0 -17
  255. package/src/providers/finance/stripe.js +0 -549
  256. package/src/providers/forms/index.js +0 -17
  257. package/src/providers/forms/typeform.js +0 -500
  258. package/src/providers/index.js +0 -123
  259. package/src/providers/knowledge/index.js +0 -17
  260. package/src/providers/knowledge/notion.js +0 -389
  261. package/src/providers/marketing/index.js +0 -17
  262. package/src/providers/marketing/mailchimp.js +0 -443
  263. package/src/providers/media/cloudinary.js +0 -318
  264. package/src/providers/media/index.js +0 -17
  265. package/src/providers/messaging/index.js +0 -20
  266. package/src/providers/messaging/slack.js +0 -393
  267. package/src/providers/messaging/twilio-sms.js +0 -249
  268. package/src/providers/project-management/index.js +0 -17
  269. package/src/providers/project-management/linear.js +0 -575
  270. package/src/providers/registry.js +0 -86
  271. package/src/providers/spreadsheet/google-sheets.js +0 -375
  272. package/src/providers/spreadsheet/index.js +0 -20
  273. package/src/providers/spreadsheet/xlsx.js +0 -423
  274. package/src/providers/storage/index.js +0 -24
  275. package/src/providers/storage/s3.js +0 -419
  276. package/src/providers/support/index.js +0 -17
  277. package/src/providers/support/zendesk.js +0 -373
  278. package/src/providers/tasks/index.js +0 -17
  279. package/src/providers/tasks/todoist.js +0 -286
  280. package/src/providers/types.js +0 -9
  281. package/src/providers/video-conferencing/google-meet.js +0 -286
  282. package/src/providers/video-conferencing/index.js +0 -31
  283. package/src/providers/video-conferencing/jitsi.js +0 -254
  284. package/src/providers/video-conferencing/teams.js +0 -270
  285. package/src/providers/video-conferencing/zoom.js +0 -332
  286. package/src/registry.js +0 -128
  287. package/src/tools/communication.js +0 -184
  288. package/src/tools/data.js +0 -205
  289. package/src/tools/index.js +0 -11
  290. package/src/tools/web.js +0 -137
  291. package/src/types.js +0 -10
  292. package/test/define.test.js +0 -306
  293. package/test/registry.test.js +0 -357
  294. package/test/tools.test.js +0 -363
@@ -1,375 +0,0 @@
1
- /**
2
- * Google Sheets Provider
3
- *
4
- * Concrete implementation of SpreadsheetProvider using Google Sheets API.
5
- *
6
- * @packageDocumentation
7
- */
8
- import { defineProvider } from '../registry.js';
9
- const SHEETS_API_URL = 'https://sheets.googleapis.com/v4/spreadsheets';
10
- const DRIVE_API_URL = 'https://www.googleapis.com/drive/v3/files';
11
- /**
12
- * Google Sheets provider info
13
- */
14
- export const googleSheetsInfo = {
15
- id: 'spreadsheet.google-sheets',
16
- name: 'Google Sheets',
17
- description: 'Google Sheets cloud spreadsheet service',
18
- category: 'spreadsheet',
19
- website: 'https://sheets.google.com',
20
- docsUrl: 'https://developers.google.com/sheets/api',
21
- requiredConfig: ['accessToken'],
22
- optionalConfig: ['refreshToken', 'clientId', 'clientSecret'],
23
- };
24
- /**
25
- * Create Google Sheets provider
26
- */
27
- export function createGoogleSheetsProvider(config) {
28
- let accessToken;
29
- async function sheetsApi(path, method = 'GET', body, baseUrl = SHEETS_API_URL) {
30
- const url = path.startsWith('http') ? path : `${baseUrl}${path}`;
31
- const response = await fetch(url, {
32
- method,
33
- headers: {
34
- 'Content-Type': 'application/json',
35
- Authorization: `Bearer ${accessToken}`,
36
- },
37
- body: body ? JSON.stringify(body) : undefined,
38
- });
39
- if (!response.ok) {
40
- const error = await response.json().catch(() => ({}));
41
- throw new Error(error?.error?.message || `HTTP ${response.status}`);
42
- }
43
- return response.json();
44
- }
45
- return {
46
- info: googleSheetsInfo,
47
- async initialize(cfg) {
48
- accessToken = cfg.accessToken;
49
- if (!accessToken) {
50
- throw new Error('Google Sheets access token is required');
51
- }
52
- },
53
- async healthCheck() {
54
- const start = Date.now();
55
- try {
56
- // Test with a minimal API call
57
- await sheetsApi('', 'GET', undefined, 'https://www.googleapis.com/oauth2/v1/tokeninfo');
58
- return {
59
- healthy: true,
60
- latencyMs: Date.now() - start,
61
- message: 'Connected',
62
- checkedAt: new Date(),
63
- };
64
- }
65
- catch (error) {
66
- return {
67
- healthy: false,
68
- latencyMs: Date.now() - start,
69
- message: error instanceof Error ? error.message : 'Unknown error',
70
- checkedAt: new Date(),
71
- };
72
- }
73
- },
74
- async dispose() {
75
- // No cleanup needed
76
- },
77
- async create(name, options) {
78
- const sheets = options?.sheets || [{ name: 'Sheet1' }];
79
- const body = {
80
- properties: {
81
- title: name,
82
- locale: options?.locale,
83
- timeZone: options?.timeZone,
84
- },
85
- sheets: sheets.map((s, index) => ({
86
- properties: {
87
- title: s.name,
88
- index,
89
- },
90
- })),
91
- };
92
- const data = await sheetsApi('', 'POST', body);
93
- return mapSpreadsheet(data);
94
- },
95
- async get(spreadsheetId) {
96
- try {
97
- const data = await sheetsApi(`/${spreadsheetId}?includeGridData=false`);
98
- return mapSpreadsheet(data);
99
- }
100
- catch {
101
- return null;
102
- }
103
- },
104
- async list(options) {
105
- const params = new URLSearchParams({
106
- q: `mimeType='application/vnd.google-apps.spreadsheet'${options?.query ? ` and name contains '${options.query}'` : ''}`,
107
- pageSize: (options?.limit || 100).toString(),
108
- fields: 'files(id,name,createdTime,modifiedTime),nextPageToken',
109
- });
110
- if (options?.cursor) {
111
- params.append('pageToken', options.cursor);
112
- }
113
- const data = await sheetsApi(`?${params.toString()}`, 'GET', undefined, DRIVE_API_URL);
114
- return {
115
- items: data.files?.map((f) => ({
116
- id: f.id,
117
- name: f.name,
118
- sheets: [], // Would need separate API call to get sheets
119
- createdAt: f.createdTime ? new Date(f.createdTime) : undefined,
120
- modifiedAt: f.modifiedTime ? new Date(f.modifiedTime) : undefined,
121
- url: `https://docs.google.com/spreadsheets/d/${f.id}`,
122
- })) || [],
123
- hasMore: !!data.nextPageToken,
124
- nextCursor: data.nextPageToken,
125
- };
126
- },
127
- async delete(spreadsheetId) {
128
- try {
129
- await sheetsApi(`/${spreadsheetId}`, 'DELETE', undefined, DRIVE_API_URL);
130
- return true;
131
- }
132
- catch {
133
- return false;
134
- }
135
- },
136
- async getSheet(spreadsheetId, sheetId) {
137
- try {
138
- const spreadsheet = await sheetsApi(`/${spreadsheetId}?includeGridData=true`);
139
- const sheet = typeof sheetId === 'number'
140
- ? spreadsheet.sheets.find((s) => s.properties.sheetId === sheetId)
141
- : spreadsheet.sheets.find((s) => s.properties.title === sheetId);
142
- if (!sheet)
143
- return null;
144
- // Extract data from grid
145
- const gridData = sheet.data?.[0];
146
- const data = [];
147
- if (gridData?.rowData) {
148
- for (const row of gridData.rowData) {
149
- const rowValues = [];
150
- if (row.values) {
151
- for (const cell of row.values) {
152
- rowValues.push(extractCellValue(cell));
153
- }
154
- }
155
- data.push(rowValues);
156
- }
157
- }
158
- return {
159
- id: sheet.properties.sheetId.toString(),
160
- name: sheet.properties.title,
161
- index: sheet.properties.index,
162
- rowCount: sheet.properties.gridProperties?.rowCount || 0,
163
- columnCount: sheet.properties.gridProperties?.columnCount || 0,
164
- data,
165
- frozenRows: sheet.properties.gridProperties?.frozenRowCount,
166
- frozenColumns: sheet.properties.gridProperties?.frozenColumnCount,
167
- };
168
- }
169
- catch {
170
- return null;
171
- }
172
- },
173
- async addSheet(spreadsheetId, name, options) {
174
- const body = {
175
- requests: [
176
- {
177
- addSheet: {
178
- properties: {
179
- title: name,
180
- index: options?.index,
181
- gridProperties: {
182
- rowCount: options?.rowCount || 1000,
183
- columnCount: options?.columnCount || 26,
184
- },
185
- },
186
- },
187
- },
188
- ],
189
- };
190
- const data = await sheetsApi(`/${spreadsheetId}:batchUpdate`, 'POST', body);
191
- const reply = data.replies[0].addSheet;
192
- return {
193
- id: reply.properties.sheetId.toString(),
194
- name: reply.properties.title,
195
- index: reply.properties.index,
196
- rowCount: reply.properties.gridProperties?.rowCount || 0,
197
- columnCount: reply.properties.gridProperties?.columnCount || 0,
198
- };
199
- },
200
- async deleteSheet(spreadsheetId, sheetId) {
201
- try {
202
- // If sheetId is a string (name), we need to look up the actual sheet ID
203
- let actualSheetId = typeof sheetId === 'number' ? sheetId : parseInt(sheetId, 10);
204
- if (isNaN(actualSheetId)) {
205
- // Look up by name
206
- const spreadsheet = await sheetsApi(`/${spreadsheetId}`);
207
- const sheet = spreadsheet.sheets.find((s) => s.properties.title === sheetId);
208
- if (!sheet)
209
- return false;
210
- actualSheetId = sheet.properties.sheetId;
211
- }
212
- const body = {
213
- requests: [
214
- {
215
- deleteSheet: {
216
- sheetId: actualSheetId,
217
- },
218
- },
219
- ],
220
- };
221
- await sheetsApi(`/${spreadsheetId}:batchUpdate`, 'POST', body);
222
- return true;
223
- }
224
- catch {
225
- return false;
226
- }
227
- },
228
- async renameSheet(spreadsheetId, sheetId, name) {
229
- try {
230
- let actualSheetId = typeof sheetId === 'number' ? sheetId : parseInt(sheetId, 10);
231
- if (isNaN(actualSheetId)) {
232
- const spreadsheet = await sheetsApi(`/${spreadsheetId}`);
233
- const sheet = spreadsheet.sheets.find((s) => s.properties.title === sheetId);
234
- if (!sheet)
235
- return false;
236
- actualSheetId = sheet.properties.sheetId;
237
- }
238
- const body = {
239
- requests: [
240
- {
241
- updateSheetProperties: {
242
- properties: {
243
- sheetId: actualSheetId,
244
- title: name,
245
- },
246
- fields: 'title',
247
- },
248
- },
249
- ],
250
- };
251
- await sheetsApi(`/${spreadsheetId}:batchUpdate`, 'POST', body);
252
- return true;
253
- }
254
- catch {
255
- return false;
256
- }
257
- },
258
- async readRange(spreadsheetId, range) {
259
- const data = await sheetsApi(`/${spreadsheetId}/values/${encodeURIComponent(range)}?valueRenderOption=UNFORMATTED_VALUE`);
260
- return data.values || [];
261
- },
262
- async writeRange(spreadsheetId, range, values) {
263
- const body = {
264
- values,
265
- };
266
- const data = await sheetsApi(`/${spreadsheetId}/values/${encodeURIComponent(range)}?valueInputOption=USER_ENTERED`, 'PUT', body);
267
- return {
268
- updatedRange: data.updatedRange,
269
- updatedRows: data.updatedRows || 0,
270
- updatedColumns: data.updatedColumns || 0,
271
- updatedCells: data.updatedCells || 0,
272
- };
273
- },
274
- async appendRows(spreadsheetId, range, values) {
275
- const body = {
276
- values,
277
- };
278
- const data = await sheetsApi(`/${spreadsheetId}/values/${encodeURIComponent(range)}:append?valueInputOption=USER_ENTERED&insertDataOption=INSERT_ROWS`, 'POST', body);
279
- return {
280
- spreadsheetId: data.spreadsheetId,
281
- updatedRange: data.updates?.updatedRange || range,
282
- updatedRows: data.updates?.updatedRows || values.length,
283
- };
284
- },
285
- async clearRange(spreadsheetId, range) {
286
- try {
287
- await sheetsApi(`/${spreadsheetId}/values/${encodeURIComponent(range)}:clear`, 'POST', {});
288
- return true;
289
- }
290
- catch {
291
- return false;
292
- }
293
- },
294
- async batchRead(spreadsheetId, ranges) {
295
- const params = ranges.map((r) => `ranges=${encodeURIComponent(r)}`).join('&');
296
- const data = await sheetsApi(`/${spreadsheetId}/values:batchGet?${params}&valueRenderOption=UNFORMATTED_VALUE`);
297
- const result = new Map();
298
- data.valueRanges?.forEach((vr) => {
299
- result.set(vr.range, vr.values || []);
300
- });
301
- return result;
302
- },
303
- async batchWrite(spreadsheetId, data) {
304
- const body = {
305
- valueInputOption: 'USER_ENTERED',
306
- data: data.map((d) => ({
307
- range: d.range,
308
- values: d.values,
309
- })),
310
- };
311
- const response = await sheetsApi(`/${spreadsheetId}/values:batchUpdate`, 'POST', body);
312
- return {
313
- updatedRange: 'batch',
314
- updatedRows: response.totalUpdatedRows || 0,
315
- updatedColumns: response.totalUpdatedColumns || 0,
316
- updatedCells: response.totalUpdatedCells || 0,
317
- };
318
- },
319
- async export(spreadsheetId, format) {
320
- const mimeTypes = {
321
- xlsx: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
322
- csv: 'text/csv',
323
- pdf: 'application/pdf',
324
- };
325
- const response = await fetch(`${DRIVE_API_URL}/${spreadsheetId}/export?mimeType=${encodeURIComponent(mimeTypes[format])}`, {
326
- headers: {
327
- Authorization: `Bearer ${accessToken}`,
328
- },
329
- });
330
- if (!response.ok) {
331
- throw new Error(`Export failed: HTTP ${response.status}`);
332
- }
333
- const arrayBuffer = await response.arrayBuffer();
334
- return Buffer.from(arrayBuffer);
335
- },
336
- };
337
- }
338
- function mapSpreadsheet(data) {
339
- return {
340
- id: data.spreadsheetId,
341
- name: data.properties.title,
342
- sheets: data.sheets?.map((s) => ({
343
- id: s.properties.sheetId.toString(),
344
- name: s.properties.title,
345
- index: s.properties.index,
346
- rowCount: s.properties.gridProperties?.rowCount,
347
- columnCount: s.properties.gridProperties?.columnCount,
348
- })) || [],
349
- createdAt: undefined, // Not available from Sheets API
350
- modifiedAt: undefined,
351
- url: data.spreadsheetUrl,
352
- };
353
- }
354
- function extractCellValue(cell) {
355
- if (!cell)
356
- return null;
357
- const ev = cell.effectiveValue;
358
- if (!ev)
359
- return null;
360
- if ('numberValue' in ev)
361
- return ev.numberValue;
362
- if ('stringValue' in ev)
363
- return ev.stringValue;
364
- if ('boolValue' in ev)
365
- return ev.boolValue;
366
- if ('formulaValue' in ev)
367
- return ev.formulaValue;
368
- if ('errorValue' in ev)
369
- return `#ERROR: ${ev.errorValue.message}`;
370
- return null;
371
- }
372
- /**
373
- * Google Sheets provider definition
374
- */
375
- export const googleSheetsProvider = defineProvider(googleSheetsInfo, async (config) => createGoogleSheetsProvider(config));
@@ -1,20 +0,0 @@
1
- /**
2
- * Spreadsheet Providers
3
- *
4
- * @packageDocumentation
5
- */
6
- export { xlsxInfo, xlsxProvider, createXlsxProvider } from './xlsx.js';
7
- export { googleSheetsInfo, googleSheetsProvider, createGoogleSheetsProvider } from './google-sheets.js';
8
- import { xlsxProvider } from './xlsx.js';
9
- import { googleSheetsProvider } from './google-sheets.js';
10
- /**
11
- * Register all spreadsheet providers
12
- */
13
- export function registerSpreadsheetProviders() {
14
- xlsxProvider.register();
15
- googleSheetsProvider.register();
16
- }
17
- /**
18
- * All spreadsheet providers
19
- */
20
- export const spreadsheetProviders = [xlsxProvider, googleSheetsProvider];