digital-tools 2.1.3 → 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 (294) hide show
  1. package/CHANGELOG.md +9 -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 +21 -11
  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 +31 -14
  132. package/src/client.ts +136 -0
  133. package/src/define.ts +30 -24
  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 -4
  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,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 };