digital-tools 2.1.1 → 2.3.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 (293) hide show
  1. package/CHANGELOG.md +17 -0
  2. package/README.md +2 -0
  3. package/dist/client.d.ts +109 -0
  4. package/dist/client.d.ts.map +1 -0
  5. package/dist/client.js +69 -0
  6. package/dist/client.js.map +1 -0
  7. package/dist/define.d.ts +2 -2
  8. package/dist/define.d.ts.map +1 -1
  9. package/dist/define.js +22 -20
  10. package/dist/define.js.map +1 -1
  11. package/dist/function-ref.d.ts +229 -0
  12. package/dist/function-ref.d.ts.map +1 -0
  13. package/dist/function-ref.js +28 -0
  14. package/dist/function-ref.js.map +1 -0
  15. package/dist/function-sugar.d.ts +57 -0
  16. package/dist/function-sugar.d.ts.map +1 -0
  17. package/dist/function-sugar.js +79 -0
  18. package/dist/function-sugar.js.map +1 -0
  19. package/dist/index.d.ts +10 -3
  20. package/dist/index.d.ts.map +1 -1
  21. package/dist/index.js +24 -4
  22. package/dist/index.js.map +1 -1
  23. package/dist/providers/analytics/mixpanel.d.ts.map +1 -1
  24. package/dist/providers/analytics/mixpanel.js +21 -18
  25. package/dist/providers/analytics/mixpanel.js.map +1 -1
  26. package/dist/providers/calendar/cal-com.d.ts.map +1 -1
  27. package/dist/providers/calendar/cal-com.js +10 -10
  28. package/dist/providers/calendar/cal-com.js.map +1 -1
  29. package/dist/providers/calendar/google-calendar.d.ts.map +1 -1
  30. package/dist/providers/calendar/google-calendar.js +4 -4
  31. package/dist/providers/calendar/google-calendar.js.map +1 -1
  32. package/dist/providers/crm/hubspot.d.ts.map +1 -1
  33. package/dist/providers/crm/hubspot.js +107 -85
  34. package/dist/providers/crm/hubspot.js.map +1 -1
  35. package/dist/providers/development/github.d.ts.map +1 -1
  36. package/dist/providers/development/github.js +40 -43
  37. package/dist/providers/development/github.js.map +1 -1
  38. package/dist/providers/ecommerce/shopify.d.ts.map +1 -1
  39. package/dist/providers/ecommerce/shopify.js +79 -62
  40. package/dist/providers/ecommerce/shopify.js.map +1 -1
  41. package/dist/providers/email/resend.d.ts.map +1 -1
  42. package/dist/providers/email/resend.js +20 -16
  43. package/dist/providers/email/resend.js.map +1 -1
  44. package/dist/providers/email/sendgrid.d.ts.map +1 -1
  45. package/dist/providers/email/sendgrid.js +12 -9
  46. package/dist/providers/email/sendgrid.js.map +1 -1
  47. package/dist/providers/finance/stripe.d.ts.map +1 -1
  48. package/dist/providers/finance/stripe.js +44 -42
  49. package/dist/providers/finance/stripe.js.map +1 -1
  50. package/dist/providers/forms/typeform.d.ts.map +1 -1
  51. package/dist/providers/forms/typeform.js +68 -58
  52. package/dist/providers/forms/typeform.js.map +1 -1
  53. package/dist/providers/knowledge/notion.d.ts.map +1 -1
  54. package/dist/providers/knowledge/notion.js +75 -41
  55. package/dist/providers/knowledge/notion.js.map +1 -1
  56. package/dist/providers/marketing/mailchimp.d.ts.map +1 -1
  57. package/dist/providers/marketing/mailchimp.js +74 -61
  58. package/dist/providers/marketing/mailchimp.js.map +1 -1
  59. package/dist/providers/media/cloudinary.d.ts.map +1 -1
  60. package/dist/providers/media/cloudinary.js +30 -28
  61. package/dist/providers/media/cloudinary.js.map +1 -1
  62. package/dist/providers/messaging/slack.d.ts.map +1 -1
  63. package/dist/providers/messaging/slack.js +75 -58
  64. package/dist/providers/messaging/slack.js.map +1 -1
  65. package/dist/providers/messaging/twilio-sms.d.ts.map +1 -1
  66. package/dist/providers/messaging/twilio-sms.js +33 -15
  67. package/dist/providers/messaging/twilio-sms.js.map +1 -1
  68. package/dist/providers/project-management/linear.d.ts.map +1 -1
  69. package/dist/providers/project-management/linear.js +31 -27
  70. package/dist/providers/project-management/linear.js.map +1 -1
  71. package/dist/providers/spreadsheet/google-sheets.d.ts.map +1 -1
  72. package/dist/providers/spreadsheet/google-sheets.js +21 -18
  73. package/dist/providers/spreadsheet/google-sheets.js.map +1 -1
  74. package/dist/providers/spreadsheet/xlsx.d.ts.map +1 -1
  75. package/dist/providers/spreadsheet/xlsx.js +4 -4
  76. package/dist/providers/spreadsheet/xlsx.js.map +1 -1
  77. package/dist/providers/storage/index.js +1 -0
  78. package/dist/providers/storage/index.js.map +1 -1
  79. package/dist/providers/storage/s3.d.ts.map +1 -1
  80. package/dist/providers/storage/s3.js +36 -27
  81. package/dist/providers/storage/s3.js.map +1 -1
  82. package/dist/providers/support/zendesk.d.ts.map +1 -1
  83. package/dist/providers/support/zendesk.js +24 -25
  84. package/dist/providers/support/zendesk.js.map +1 -1
  85. package/dist/providers/tasks/todoist.d.ts.map +1 -1
  86. package/dist/providers/tasks/todoist.js +18 -18
  87. package/dist/providers/tasks/todoist.js.map +1 -1
  88. package/dist/providers/video-conferencing/google-meet.d.ts.map +1 -1
  89. package/dist/providers/video-conferencing/google-meet.js +11 -11
  90. package/dist/providers/video-conferencing/google-meet.js.map +1 -1
  91. package/dist/providers/video-conferencing/jitsi.js +14 -14
  92. package/dist/providers/video-conferencing/jitsi.js.map +1 -1
  93. package/dist/providers/video-conferencing/teams.d.ts.map +1 -1
  94. package/dist/providers/video-conferencing/teams.js +9 -7
  95. package/dist/providers/video-conferencing/teams.js.map +1 -1
  96. package/dist/providers/video-conferencing/zoom.d.ts.map +1 -1
  97. package/dist/providers/video-conferencing/zoom.js +26 -24
  98. package/dist/providers/video-conferencing/zoom.js.map +1 -1
  99. package/dist/tools/data.d.ts.map +1 -1
  100. package/dist/tools/data.js +5 -12
  101. package/dist/tools/data.js.map +1 -1
  102. package/dist/tools/index.d.ts +1 -0
  103. package/dist/tools/index.d.ts.map +1 -1
  104. package/dist/tools/index.js +1 -0
  105. package/dist/tools/index.js.map +1 -1
  106. package/dist/tools/system.d.ts +289 -0
  107. package/dist/tools/system.d.ts.map +1 -0
  108. package/dist/tools/system.js +752 -0
  109. package/dist/tools/system.js.map +1 -0
  110. package/dist/tools/web.d.ts.map +1 -1
  111. package/dist/tools/web.js +22 -10
  112. package/dist/tools/web.js.map +1 -1
  113. package/dist/track-record.d.ts +101 -0
  114. package/dist/track-record.d.ts.map +1 -0
  115. package/dist/track-record.js +17 -0
  116. package/dist/track-record.js.map +1 -0
  117. package/dist/types.d.ts +210 -9
  118. package/dist/types.d.ts.map +1 -1
  119. package/dist/verb-registration.d.ts +122 -0
  120. package/dist/verb-registration.d.ts.map +1 -0
  121. package/dist/verb-registration.js +176 -0
  122. package/dist/verb-registration.js.map +1 -0
  123. package/dist/worker.d.ts +93 -0
  124. package/dist/worker.d.ts.map +1 -0
  125. package/dist/worker.js +315 -0
  126. package/dist/worker.js.map +1 -0
  127. package/dist/wrap.d.ts +89 -0
  128. package/dist/wrap.d.ts.map +1 -0
  129. package/dist/wrap.js +225 -0
  130. package/dist/wrap.js.map +1 -0
  131. package/package.json +21 -4
  132. package/src/client.ts +136 -0
  133. package/src/define.ts +31 -37
  134. package/src/function-ref.ts +264 -0
  135. package/src/function-sugar.ts +134 -0
  136. package/src/index.ts +132 -10
  137. package/src/providers/analytics/mixpanel.ts +19 -18
  138. package/src/providers/calendar/cal-com.ts +29 -18
  139. package/src/providers/calendar/google-calendar.ts +20 -14
  140. package/src/providers/crm/hubspot.ts +225 -99
  141. package/src/providers/development/github.ts +206 -135
  142. package/src/providers/ecommerce/shopify.ts +250 -89
  143. package/src/providers/email/resend.ts +101 -28
  144. package/src/providers/email/sendgrid.ts +12 -9
  145. package/src/providers/finance/stripe.ts +128 -49
  146. package/src/providers/forms/typeform.ts +74 -58
  147. package/src/providers/knowledge/notion.ts +340 -88
  148. package/src/providers/marketing/mailchimp.ts +86 -70
  149. package/src/providers/media/cloudinary.ts +99 -41
  150. package/src/providers/messaging/slack.ts +283 -85
  151. package/src/providers/messaging/twilio-sms.ts +35 -15
  152. package/src/providers/project-management/linear.ts +143 -55
  153. package/src/providers/spreadsheet/google-sheets.ts +222 -56
  154. package/src/providers/spreadsheet/xlsx.ts +47 -16
  155. package/src/providers/storage/s3.ts +119 -47
  156. package/src/providers/support/zendesk.ts +196 -46
  157. package/src/providers/tasks/todoist.ts +20 -26
  158. package/src/providers/video-conferencing/google-meet.ts +17 -20
  159. package/src/providers/video-conferencing/jitsi.ts +14 -14
  160. package/src/providers/video-conferencing/teams.ts +14 -13
  161. package/src/providers/video-conferencing/zoom.ts +54 -49
  162. package/src/tools/data.ts +6 -16
  163. package/src/tools/index.ts +1 -0
  164. package/src/tools/system.ts +887 -0
  165. package/src/tools/web.ts +22 -10
  166. package/src/track-record.ts +106 -0
  167. package/src/types.ts +241 -13
  168. package/src/verb-registration.ts +197 -0
  169. package/src/worker.ts +370 -0
  170. package/src/wrap.ts +260 -0
  171. package/test/client.test.ts +146 -0
  172. package/test/communication-tools-extended.test.ts +734 -0
  173. package/test/data-tools-extended.test.ts +743 -0
  174. package/test/define-extended.test.ts +819 -0
  175. package/test/define.test.ts +150 -41
  176. package/test/entities.test.ts +623 -0
  177. package/test/extended-entities.test.ts +1228 -0
  178. package/test/provider-implementations.test.ts +725 -0
  179. package/test/provider-registry-extended.test.ts +583 -0
  180. package/test/providers/google-sheets.test.ts +851 -0
  181. package/test/providers/helpers.ts +554 -0
  182. package/test/providers/hubspot.test.ts +576 -0
  183. package/test/providers/slack.test.ts +932 -0
  184. package/test/providers/stripe.test.ts +701 -0
  185. package/test/providers.test.ts +578 -0
  186. package/test/system-tools-extended.test.ts +632 -0
  187. package/test/system.test.ts +673 -0
  188. package/test/tools.test.ts +15 -11
  189. package/test/types.test.ts +402 -0
  190. package/test/verb-registration.test.ts +395 -0
  191. package/test/web-tools.test.ts +553 -0
  192. package/test/worker-extended.test.ts +699 -0
  193. package/test/worker.test.ts +576 -0
  194. package/test/wrap.test.ts +366 -0
  195. package/tsconfig.json +3 -13
  196. package/vitest.config.ts +37 -0
  197. package/wrangler.jsonc +9 -0
  198. package/.turbo/turbo-build.log +0 -5
  199. package/dist/providers/voice/vapi.d.ts +0 -27
  200. package/dist/providers/voice/vapi.d.ts.map +0 -1
  201. package/dist/providers/voice/vapi.js +0 -440
  202. package/dist/providers/voice/vapi.js.map +0 -1
  203. package/src/define.js +0 -267
  204. package/src/entities/advertising.js +0 -999
  205. package/src/entities/ai.js +0 -756
  206. package/src/entities/analytics.js +0 -1588
  207. package/src/entities/automation.js +0 -601
  208. package/src/entities/communication.js +0 -1150
  209. package/src/entities/crm.js +0 -1386
  210. package/src/entities/design.js +0 -546
  211. package/src/entities/development.js +0 -2212
  212. package/src/entities/document.js +0 -874
  213. package/src/entities/ecommerce.js +0 -1429
  214. package/src/entities/experiment.js +0 -1039
  215. package/src/entities/finance.js +0 -3478
  216. package/src/entities/forms.js +0 -1892
  217. package/src/entities/hr.js +0 -661
  218. package/src/entities/identity.js +0 -997
  219. package/src/entities/index.js +0 -282
  220. package/src/entities/infrastructure.js +0 -1153
  221. package/src/entities/knowledge.js +0 -1438
  222. package/src/entities/marketing.js +0 -1610
  223. package/src/entities/media.js +0 -1634
  224. package/src/entities/notification.js +0 -1199
  225. package/src/entities/presentation.js +0 -1274
  226. package/src/entities/productivity.js +0 -1317
  227. package/src/entities/project-management.js +0 -1136
  228. package/src/entities/recruiting.js +0 -736
  229. package/src/entities/shipping.js +0 -509
  230. package/src/entities/signature.js +0 -1102
  231. package/src/entities/site.js +0 -222
  232. package/src/entities/spreadsheet.js +0 -1341
  233. package/src/entities/storage.js +0 -1198
  234. package/src/entities/support.js +0 -1166
  235. package/src/entities/video-conferencing.js +0 -1750
  236. package/src/entities/video.js +0 -950
  237. package/src/entities.js +0 -1663
  238. package/src/index.js +0 -74
  239. package/src/providers/analytics/index.js +0 -17
  240. package/src/providers/analytics/mixpanel.js +0 -255
  241. package/src/providers/calendar/cal-com.js +0 -303
  242. package/src/providers/calendar/google-calendar.js +0 -335
  243. package/src/providers/calendar/index.js +0 -20
  244. package/src/providers/crm/hubspot.js +0 -566
  245. package/src/providers/crm/index.js +0 -17
  246. package/src/providers/development/github.js +0 -472
  247. package/src/providers/development/index.js +0 -17
  248. package/src/providers/ecommerce/index.js +0 -17
  249. package/src/providers/ecommerce/shopify.js +0 -378
  250. package/src/providers/email/index.js +0 -20
  251. package/src/providers/email/resend.js +0 -258
  252. package/src/providers/email/sendgrid.js +0 -161
  253. package/src/providers/finance/index.js +0 -17
  254. package/src/providers/finance/stripe.js +0 -549
  255. package/src/providers/forms/index.js +0 -17
  256. package/src/providers/forms/typeform.js +0 -500
  257. package/src/providers/index.js +0 -123
  258. package/src/providers/knowledge/index.js +0 -17
  259. package/src/providers/knowledge/notion.js +0 -389
  260. package/src/providers/marketing/index.js +0 -17
  261. package/src/providers/marketing/mailchimp.js +0 -443
  262. package/src/providers/media/cloudinary.js +0 -318
  263. package/src/providers/media/index.js +0 -17
  264. package/src/providers/messaging/index.js +0 -20
  265. package/src/providers/messaging/slack.js +0 -393
  266. package/src/providers/messaging/twilio-sms.js +0 -249
  267. package/src/providers/project-management/index.js +0 -17
  268. package/src/providers/project-management/linear.js +0 -575
  269. package/src/providers/registry.js +0 -86
  270. package/src/providers/spreadsheet/google-sheets.js +0 -375
  271. package/src/providers/spreadsheet/index.js +0 -20
  272. package/src/providers/spreadsheet/xlsx.js +0 -423
  273. package/src/providers/storage/index.js +0 -24
  274. package/src/providers/storage/s3.js +0 -419
  275. package/src/providers/support/index.js +0 -17
  276. package/src/providers/support/zendesk.js +0 -373
  277. package/src/providers/tasks/index.js +0 -17
  278. package/src/providers/tasks/todoist.js +0 -286
  279. package/src/providers/types.js +0 -9
  280. package/src/providers/video-conferencing/google-meet.js +0 -286
  281. package/src/providers/video-conferencing/index.js +0 -31
  282. package/src/providers/video-conferencing/jitsi.js +0 -254
  283. package/src/providers/video-conferencing/teams.js +0 -270
  284. package/src/providers/video-conferencing/zoom.js +0 -332
  285. package/src/registry.js +0 -128
  286. package/src/tools/communication.js +0 -184
  287. package/src/tools/data.js +0 -205
  288. package/src/tools/index.js +0 -11
  289. package/src/tools/web.js +0 -137
  290. package/src/types.js +0 -10
  291. package/test/define.test.js +0 -306
  292. package/test/registry.test.js +0 -357
  293. package/test/tools.test.js +0 -363
@@ -1,423 +0,0 @@
1
- /**
2
- * XLSX Spreadsheet Provider
3
- *
4
- * Concrete implementation of SpreadsheetProvider using SheetJS (xlsx) library.
5
- * Works with local .xlsx, .xls, .csv files.
6
- *
7
- * @packageDocumentation
8
- */
9
- import { defineProvider } from '../registry.js';
10
- /**
11
- * XLSX provider info
12
- */
13
- export const xlsxInfo = {
14
- id: 'spreadsheet.xlsx',
15
- name: 'XLSX (SheetJS)',
16
- description: 'Local spreadsheet files using SheetJS library (.xlsx, .xls, .csv)',
17
- category: 'spreadsheet',
18
- website: 'https://sheetjs.com',
19
- docsUrl: 'https://docs.sheetjs.com',
20
- requiredConfig: [],
21
- optionalConfig: ['basePath'],
22
- };
23
- // In-memory storage for spreadsheets (in real impl, would use filesystem)
24
- const spreadsheets = new Map();
25
- /**
26
- * Create XLSX spreadsheet provider
27
- */
28
- export function createXlsxProvider(config) {
29
- let basePath;
30
- function generateId() {
31
- return `xlsx_${Date.now()}_${Math.random().toString(36).slice(2, 9)}`;
32
- }
33
- function parseRange(range) {
34
- // Parse A1 notation like "Sheet1!A1:C10" or just "A1:C10"
35
- let sheetName;
36
- let cellRange = range;
37
- if (range.includes('!')) {
38
- const parts = range.split('!');
39
- sheetName = parts[0].replace(/^'|'$/g, '');
40
- cellRange = parts[1];
41
- }
42
- const [start, end] = cellRange.split(':');
43
- const startCell = parseCell(start);
44
- const endCell = end ? parseCell(end) : startCell;
45
- return {
46
- sheet: sheetName,
47
- startRow: startCell.row,
48
- startCol: startCell.col,
49
- endRow: endCell.row,
50
- endCol: endCell.col,
51
- };
52
- }
53
- function parseCell(cell) {
54
- const match = cell.match(/^([A-Z]+)(\d+)$/);
55
- if (!match) {
56
- throw new Error(`Invalid cell reference: ${cell}`);
57
- }
58
- const colStr = match[1];
59
- const row = parseInt(match[2], 10);
60
- // Convert column letters to number (A=1, B=2, ..., Z=26, AA=27, etc.)
61
- let col = 0;
62
- for (let i = 0; i < colStr.length; i++) {
63
- col = col * 26 + (colStr.charCodeAt(i) - 64);
64
- }
65
- return { row, col };
66
- }
67
- function colToLetter(col) {
68
- let letter = '';
69
- while (col > 0) {
70
- const remainder = (col - 1) % 26;
71
- letter = String.fromCharCode(65 + remainder) + letter;
72
- col = Math.floor((col - 1) / 26);
73
- }
74
- return letter;
75
- }
76
- return {
77
- info: xlsxInfo,
78
- async initialize(cfg) {
79
- basePath = cfg.basePath || './spreadsheets';
80
- },
81
- async healthCheck() {
82
- return {
83
- healthy: true,
84
- latencyMs: 0,
85
- message: 'XLSX provider ready (in-memory)',
86
- checkedAt: new Date(),
87
- };
88
- },
89
- async dispose() {
90
- // Clear in-memory storage if needed
91
- },
92
- async create(name, options) {
93
- const id = generateId();
94
- const now = new Date();
95
- const workbook = {
96
- id,
97
- name,
98
- sheets: new Map(),
99
- createdAt: now,
100
- modifiedAt: now,
101
- };
102
- // Create default sheet or sheets from options
103
- const sheetNames = options?.sheets?.map((s) => s.name) || ['Sheet1'];
104
- sheetNames.forEach((sheetName, index) => {
105
- workbook.sheets.set(sheetName, {
106
- name: sheetName,
107
- index,
108
- data: [],
109
- });
110
- });
111
- spreadsheets.set(id, workbook);
112
- return {
113
- id,
114
- name,
115
- sheets: Array.from(workbook.sheets.values()).map((s) => ({
116
- id: s.name,
117
- name: s.name,
118
- index: s.index,
119
- rowCount: s.data.length,
120
- columnCount: s.data[0]?.length || 0,
121
- })),
122
- createdAt: now,
123
- modifiedAt: now,
124
- };
125
- },
126
- async get(spreadsheetId) {
127
- const workbook = spreadsheets.get(spreadsheetId);
128
- if (!workbook)
129
- return null;
130
- return {
131
- id: workbook.id,
132
- name: workbook.name,
133
- sheets: Array.from(workbook.sheets.values()).map((s) => ({
134
- id: s.name,
135
- name: s.name,
136
- index: s.index,
137
- rowCount: s.data.length,
138
- columnCount: s.data[0]?.length || 0,
139
- })),
140
- createdAt: workbook.createdAt,
141
- modifiedAt: workbook.modifiedAt,
142
- };
143
- },
144
- async list(options) {
145
- let items = Array.from(spreadsheets.values()).map((wb) => ({
146
- id: wb.id,
147
- name: wb.name,
148
- sheets: Array.from(wb.sheets.values()).map((s) => ({
149
- id: s.name,
150
- name: s.name,
151
- index: s.index,
152
- })),
153
- createdAt: wb.createdAt,
154
- modifiedAt: wb.modifiedAt,
155
- }));
156
- if (options?.query) {
157
- const q = options.query.toLowerCase();
158
- items = items.filter((i) => i.name.toLowerCase().includes(q));
159
- }
160
- const offset = options?.offset || 0;
161
- const limit = options?.limit || 100;
162
- return {
163
- items: items.slice(offset, offset + limit),
164
- total: items.length,
165
- hasMore: offset + limit < items.length,
166
- };
167
- },
168
- async delete(spreadsheetId) {
169
- return spreadsheets.delete(spreadsheetId);
170
- },
171
- async getSheet(spreadsheetId, sheetId) {
172
- const workbook = spreadsheets.get(spreadsheetId);
173
- if (!workbook)
174
- return null;
175
- let sheet;
176
- if (typeof sheetId === 'number') {
177
- sheet = Array.from(workbook.sheets.values()).find((s) => s.index === sheetId);
178
- }
179
- else {
180
- sheet = workbook.sheets.get(sheetId);
181
- }
182
- if (!sheet)
183
- return null;
184
- return {
185
- id: sheet.name,
186
- name: sheet.name,
187
- index: sheet.index,
188
- rowCount: sheet.data.length,
189
- columnCount: sheet.data[0]?.length || 0,
190
- data: sheet.data,
191
- frozenRows: sheet.frozenRows,
192
- frozenColumns: sheet.frozenColumns,
193
- };
194
- },
195
- async addSheet(spreadsheetId, name, options) {
196
- const workbook = spreadsheets.get(spreadsheetId);
197
- if (!workbook) {
198
- throw new Error(`Spreadsheet ${spreadsheetId} not found`);
199
- }
200
- if (workbook.sheets.has(name)) {
201
- throw new Error(`Sheet ${name} already exists`);
202
- }
203
- const index = options?.index ?? workbook.sheets.size;
204
- const sheet = {
205
- name,
206
- index,
207
- data: [],
208
- };
209
- workbook.sheets.set(name, sheet);
210
- workbook.modifiedAt = new Date();
211
- return {
212
- id: name,
213
- name,
214
- index,
215
- rowCount: 0,
216
- columnCount: 0,
217
- };
218
- },
219
- async deleteSheet(spreadsheetId, sheetId) {
220
- const workbook = spreadsheets.get(spreadsheetId);
221
- if (!workbook)
222
- return false;
223
- let sheetName;
224
- if (typeof sheetId === 'number') {
225
- const sheet = Array.from(workbook.sheets.values()).find((s) => s.index === sheetId);
226
- sheetName = sheet?.name;
227
- }
228
- else {
229
- sheetName = sheetId;
230
- }
231
- if (!sheetName)
232
- return false;
233
- const deleted = workbook.sheets.delete(sheetName);
234
- if (deleted) {
235
- workbook.modifiedAt = new Date();
236
- }
237
- return deleted;
238
- },
239
- async renameSheet(spreadsheetId, sheetId, name) {
240
- const workbook = spreadsheets.get(spreadsheetId);
241
- if (!workbook)
242
- return false;
243
- let oldName;
244
- if (typeof sheetId === 'number') {
245
- const sheet = Array.from(workbook.sheets.values()).find((s) => s.index === sheetId);
246
- oldName = sheet?.name;
247
- }
248
- else {
249
- oldName = sheetId;
250
- }
251
- if (!oldName || !workbook.sheets.has(oldName))
252
- return false;
253
- const sheet = workbook.sheets.get(oldName);
254
- workbook.sheets.delete(oldName);
255
- sheet.name = name;
256
- workbook.sheets.set(name, sheet);
257
- workbook.modifiedAt = new Date();
258
- return true;
259
- },
260
- async readRange(spreadsheetId, range) {
261
- const workbook = spreadsheets.get(spreadsheetId);
262
- if (!workbook) {
263
- throw new Error(`Spreadsheet ${spreadsheetId} not found`);
264
- }
265
- const { sheet: sheetName, startRow, startCol, endRow, endCol } = parseRange(range);
266
- // Get sheet (default to first sheet)
267
- const sheet = sheetName
268
- ? workbook.sheets.get(sheetName)
269
- : Array.from(workbook.sheets.values())[0];
270
- if (!sheet) {
271
- throw new Error(`Sheet not found`);
272
- }
273
- const result = [];
274
- for (let row = startRow; row <= endRow; row++) {
275
- const rowData = [];
276
- for (let col = startCol; col <= endCol; col++) {
277
- const value = sheet.data[row - 1]?.[col - 1] ?? null;
278
- rowData.push(value);
279
- }
280
- result.push(rowData);
281
- }
282
- return result;
283
- },
284
- async writeRange(spreadsheetId, range, values) {
285
- const workbook = spreadsheets.get(spreadsheetId);
286
- if (!workbook) {
287
- throw new Error(`Spreadsheet ${spreadsheetId} not found`);
288
- }
289
- const { sheet: sheetName, startRow, startCol } = parseRange(range);
290
- // Get sheet (default to first sheet)
291
- const sheet = sheetName
292
- ? workbook.sheets.get(sheetName)
293
- : Array.from(workbook.sheets.values())[0];
294
- if (!sheet) {
295
- throw new Error(`Sheet not found`);
296
- }
297
- let updatedCells = 0;
298
- values.forEach((rowValues, rowOffset) => {
299
- const row = startRow + rowOffset - 1;
300
- if (!sheet.data[row]) {
301
- sheet.data[row] = [];
302
- }
303
- rowValues.forEach((value, colOffset) => {
304
- const col = startCol + colOffset - 1;
305
- sheet.data[row][col] = value;
306
- updatedCells++;
307
- });
308
- });
309
- workbook.modifiedAt = new Date();
310
- const endRow = startRow + values.length - 1;
311
- const endCol = startCol + (values[0]?.length || 0) - 1;
312
- return {
313
- updatedRange: `${sheetName || sheet.name}!${colToLetter(startCol)}${startRow}:${colToLetter(endCol)}${endRow}`,
314
- updatedRows: values.length,
315
- updatedColumns: values[0]?.length || 0,
316
- updatedCells,
317
- };
318
- },
319
- async appendRows(spreadsheetId, range, values) {
320
- const workbook = spreadsheets.get(spreadsheetId);
321
- if (!workbook) {
322
- throw new Error(`Spreadsheet ${spreadsheetId} not found`);
323
- }
324
- const { sheet: sheetName, startCol } = parseRange(range);
325
- const sheet = sheetName
326
- ? workbook.sheets.get(sheetName)
327
- : Array.from(workbook.sheets.values())[0];
328
- if (!sheet) {
329
- throw new Error(`Sheet not found`);
330
- }
331
- const startRow = sheet.data.length + 1;
332
- values.forEach((rowValues, rowOffset) => {
333
- const row = startRow + rowOffset - 1;
334
- if (!sheet.data[row]) {
335
- sheet.data[row] = [];
336
- }
337
- rowValues.forEach((value, colOffset) => {
338
- const col = startCol + colOffset - 1;
339
- sheet.data[row][col] = value;
340
- });
341
- });
342
- workbook.modifiedAt = new Date();
343
- const endRow = startRow + values.length - 1;
344
- const endCol = startCol + (values[0]?.length || 0) - 1;
345
- return {
346
- spreadsheetId,
347
- updatedRange: `${sheetName || sheet.name}!${colToLetter(startCol)}${startRow}:${colToLetter(endCol)}${endRow}`,
348
- updatedRows: values.length,
349
- };
350
- },
351
- async clearRange(spreadsheetId, range) {
352
- const workbook = spreadsheets.get(spreadsheetId);
353
- if (!workbook)
354
- return false;
355
- const { sheet: sheetName, startRow, startCol, endRow, endCol } = parseRange(range);
356
- const sheet = sheetName
357
- ? workbook.sheets.get(sheetName)
358
- : Array.from(workbook.sheets.values())[0];
359
- if (!sheet)
360
- return false;
361
- for (let row = startRow; row <= endRow; row++) {
362
- if (sheet.data[row - 1]) {
363
- for (let col = startCol; col <= endCol; col++) {
364
- sheet.data[row - 1][col - 1] = null;
365
- }
366
- }
367
- }
368
- workbook.modifiedAt = new Date();
369
- return true;
370
- },
371
- async batchRead(spreadsheetId, ranges) {
372
- const result = new Map();
373
- for (const range of ranges) {
374
- const data = await this.readRange(spreadsheetId, range);
375
- result.set(range, data);
376
- }
377
- return result;
378
- },
379
- async batchWrite(spreadsheetId, data) {
380
- let totalCells = 0;
381
- let totalRows = 0;
382
- let totalCols = 0;
383
- for (const { range, values } of data) {
384
- const result = await this.writeRange(spreadsheetId, range, values);
385
- totalCells += result.updatedCells;
386
- totalRows += result.updatedRows;
387
- totalCols = Math.max(totalCols, result.updatedColumns);
388
- }
389
- return {
390
- updatedRange: 'batch',
391
- updatedRows: totalRows,
392
- updatedColumns: totalCols,
393
- updatedCells: totalCells,
394
- };
395
- },
396
- async export(spreadsheetId, format) {
397
- // In a real implementation, this would use SheetJS to generate the file
398
- const workbook = spreadsheets.get(spreadsheetId);
399
- if (!workbook) {
400
- throw new Error(`Spreadsheet ${spreadsheetId} not found`);
401
- }
402
- // Placeholder - would use xlsx.write() in real implementation
403
- const content = JSON.stringify({
404
- name: workbook.name,
405
- sheets: Array.from(workbook.sheets.entries()).map(([name, sheet]) => ({
406
- name,
407
- data: sheet.data,
408
- })),
409
- });
410
- return Buffer.from(content, 'utf-8');
411
- },
412
- async import(file, format, options) {
413
- // In a real implementation, this would use SheetJS to parse the file
414
- // For now, create an empty spreadsheet
415
- const name = options?.name || `Imported_${Date.now()}`;
416
- return this.create(name);
417
- },
418
- };
419
- }
420
- /**
421
- * XLSX provider definition
422
- */
423
- export const xlsxProvider = defineProvider(xlsxInfo, async (config) => createXlsxProvider(config));
@@ -1,24 +0,0 @@
1
- /**
2
- * Storage Providers
3
- *
4
- * Concrete implementations for storage providers (S3, Google Cloud Storage, etc.)
5
- *
6
- * @packageDocumentation
7
- */
8
- import { s3Provider, s3Info, createS3Provider } from './s3.js';
9
- /**
10
- * All storage providers
11
- */
12
- export const storageProviders = [s3Provider];
13
- /**
14
- * Register all storage providers in the global registry
15
- */
16
- export function registerStorageProviders() {
17
- for (const provider of storageProviders) {
18
- provider.register();
19
- }
20
- }
21
- /**
22
- * Re-export provider info and factories
23
- */
24
- export { s3Provider, s3Info, createS3Provider };