@marketing-sdk/google-sheets 0.1.1-experimental.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.
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2024 Cody
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -0,0 +1,41 @@
1
+ import { CreateResponse, IRecordProvider } from '@marketing-sdk/core';
2
+ import { GoogleSheets } from './types';
3
+ export declare class GoogleSheetsClient implements IRecordProvider<GoogleSheets.ValueRange, GoogleSheets.UpdateValuesResponse, GoogleSheets.GetValuesResponse> {
4
+ private sheets;
5
+ private config;
6
+ constructor(config: {
7
+ credentials?: {
8
+ client_email?: string;
9
+ private_key?: string;
10
+ };
11
+ spreadsheetId?: string;
12
+ scopes?: string[];
13
+ });
14
+ private getClient;
15
+ private getSpreadsheetId;
16
+ appendValues(range: string, values: GoogleSheets.ValueRange): Promise<CreateResponse<GoogleSheets.UpdateValuesResponse>>;
17
+ getValues(range: string, params?: {
18
+ majorDimension?: "ROWS" | "COLUMNS";
19
+ valueRenderOption?: "FORMATTED_VALUE" | "UNFORMATTED_VALUE" | "FORMULA";
20
+ }): Promise<CreateResponse<GoogleSheets.GetValuesResponse>>;
21
+ updateValues(range: string, values: GoogleSheets.ValueRange): Promise<CreateResponse<GoogleSheets.UpdateValuesResponse>>;
22
+ clearValues(range: string): Promise<CreateResponse<GoogleSheets.ClearResponse>>;
23
+ getSpreadsheet(spreadsheetId?: string): Promise<CreateResponse<GoogleSheets.SpreadsheetResponse>>;
24
+ getSheets(spreadsheetId?: string): Promise<CreateResponse<GoogleSheets.SheetsResponse>>;
25
+ getSheet(sheetNameOrId: string, spreadsheetId?: string): Promise<CreateResponse<GoogleSheets.SheetResponse>>;
26
+ createSheet(title: string, spreadsheetId?: string): Promise<CreateResponse<GoogleSheets.CreateSheetResponse>>;
27
+ deleteSheet(sheetId: number, spreadsheetId?: string): Promise<CreateResponse<GoogleSheets.DeleteSheetResponse>>;
28
+ /** @deprecated Use appendValues() instead */
29
+ createRecord(record: GoogleSheets.ValueRange, sheetName: string): Promise<CreateResponse<GoogleSheets.UpdateValuesResponse>>;
30
+ /** @deprecated Use getValues() instead */
31
+ getRecords(sheetName: string, params?: {
32
+ range?: string;
33
+ majorDimension?: "ROWS" | "COLUMNS";
34
+ valueRenderOption?: "FORMATTED_VALUE" | "UNFORMATTED_VALUE" | "FORMULA";
35
+ }): Promise<CreateResponse<GoogleSheets.GetValuesResponse>>;
36
+ /** @deprecated Use updateValues() instead */
37
+ updateRecord(range: string, record: GoogleSheets.ValueRange, sheetName: string): Promise<CreateResponse<GoogleSheets.UpdateValuesResponse>>;
38
+ /** @deprecated Use clearValues() instead */
39
+ deleteRecord(range: string, sheetName: string): Promise<CreateResponse<GoogleSheets.ClearResponse>>;
40
+ }
41
+ //# sourceMappingURL=client.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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"}
package/dist/client.js ADDED
@@ -0,0 +1,302 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.GoogleSheetsClient = void 0;
4
+ const googleapis_1 = require("googleapis");
5
+ class GoogleSheetsClient {
6
+ constructor(config) {
7
+ this.config = config;
8
+ }
9
+ async getClient() {
10
+ if (this.sheets) {
11
+ return this.sheets;
12
+ }
13
+ if (!this.config.credentials?.client_email ||
14
+ !this.config.credentials?.private_key ||
15
+ !this.config.spreadsheetId) {
16
+ throw new Error("Google Sheets client is not configured. Missing credentials or spreadsheetId.");
17
+ }
18
+ try {
19
+ const auth = new googleapis_1.google.auth.JWT(this.config.credentials.client_email, undefined, this.config.credentials.private_key.replace(/\\n/g, "\n"), this.config.scopes || [
20
+ "https://www.googleapis.com/auth/spreadsheets",
21
+ ]);
22
+ await auth.authorize();
23
+ this.sheets = googleapis_1.google.sheets({ version: "v4", auth });
24
+ return this.sheets;
25
+ }
26
+ catch (error) {
27
+ throw new Error(`Google Sheets authentication failed: ${error.message}`);
28
+ }
29
+ }
30
+ getSpreadsheetId(spreadsheetId) {
31
+ const id = spreadsheetId || this.config.spreadsheetId;
32
+ if (!id) {
33
+ throw new Error("Google Sheets spreadsheetId is required but was not provided in config or method call.");
34
+ }
35
+ return id;
36
+ }
37
+ async appendValues(range, values) {
38
+ try {
39
+ const sheets = await this.getClient();
40
+ const spreadsheetId = this.getSpreadsheetId();
41
+ const res = await sheets.spreadsheets.values.append({
42
+ spreadsheetId,
43
+ range,
44
+ valueInputOption: "USER_ENTERED",
45
+ requestBody: {
46
+ values: values.values,
47
+ },
48
+ });
49
+ return {
50
+ data: {
51
+ spreadsheetId: res.data.spreadsheetId || "",
52
+ updatedRange: res.data.updates?.updatedRange || "",
53
+ updatedRows: res.data.updates?.updatedRows || 0,
54
+ updatedColumns: res.data.updates?.updatedColumns || 0,
55
+ updatedCells: res.data.updates?.updatedCells || 0,
56
+ },
57
+ error: null,
58
+ };
59
+ }
60
+ catch (err) {
61
+ return {
62
+ data: null,
63
+ error: err.response?.data?.error || err.message,
64
+ };
65
+ }
66
+ }
67
+ async getValues(range, params) {
68
+ try {
69
+ const sheets = await this.getClient();
70
+ const spreadsheetId = this.getSpreadsheetId();
71
+ const res = await sheets.spreadsheets.values.get({
72
+ spreadsheetId,
73
+ range,
74
+ majorDimension: params?.majorDimension || "ROWS",
75
+ valueRenderOption: params?.valueRenderOption || "FORMATTED_VALUE",
76
+ });
77
+ return {
78
+ data: {
79
+ values: res.data.values || [],
80
+ range: res.data.range || "",
81
+ },
82
+ error: null,
83
+ };
84
+ }
85
+ catch (err) {
86
+ return {
87
+ data: null,
88
+ error: err.response?.data?.error || err.message,
89
+ };
90
+ }
91
+ }
92
+ async updateValues(range, values) {
93
+ try {
94
+ const sheets = await this.getClient();
95
+ const spreadsheetId = this.getSpreadsheetId();
96
+ const res = await sheets.spreadsheets.values.update({
97
+ spreadsheetId,
98
+ range,
99
+ valueInputOption: "USER_ENTERED",
100
+ requestBody: {
101
+ values: values.values,
102
+ },
103
+ });
104
+ return {
105
+ data: {
106
+ spreadsheetId: res.data.spreadsheetId || "",
107
+ updatedRange: res.data.updatedRange || "",
108
+ updatedRows: res.data.updatedRows || 0,
109
+ updatedColumns: res.data.updatedColumns || 0,
110
+ updatedCells: res.data.updatedCells || 0,
111
+ },
112
+ error: null,
113
+ };
114
+ }
115
+ catch (err) {
116
+ return {
117
+ data: null,
118
+ error: err.response?.data?.error || err.message,
119
+ };
120
+ }
121
+ }
122
+ async clearValues(range) {
123
+ try {
124
+ const sheets = await this.getClient();
125
+ const spreadsheetId = this.getSpreadsheetId();
126
+ const res = await sheets.spreadsheets.values.clear({
127
+ spreadsheetId,
128
+ range,
129
+ });
130
+ return {
131
+ data: {
132
+ clearedRange: res.data.clearedRange || "",
133
+ },
134
+ error: null,
135
+ };
136
+ }
137
+ catch (err) {
138
+ return {
139
+ data: null,
140
+ error: err.response?.data?.error || err.message,
141
+ };
142
+ }
143
+ }
144
+ async getSpreadsheet(spreadsheetId) {
145
+ try {
146
+ const sheets = await this.getClient();
147
+ const idToUse = this.getSpreadsheetId(spreadsheetId);
148
+ const res = await sheets.spreadsheets.get({
149
+ spreadsheetId: idToUse,
150
+ });
151
+ return {
152
+ data: {
153
+ spreadsheetId: res.data.spreadsheetId || "",
154
+ properties: res.data.properties || {},
155
+ sheets: res.data.sheets || [],
156
+ },
157
+ error: null,
158
+ };
159
+ }
160
+ catch (err) {
161
+ return {
162
+ data: null,
163
+ error: err.response?.data?.error || err.message,
164
+ };
165
+ }
166
+ }
167
+ async getSheets(spreadsheetId) {
168
+ try {
169
+ const sheets = await this.getClient();
170
+ const idToUse = this.getSpreadsheetId(spreadsheetId);
171
+ const res = await sheets.spreadsheets.get({
172
+ spreadsheetId: idToUse,
173
+ fields: "sheets(properties)",
174
+ });
175
+ return {
176
+ data: {
177
+ sheets: res.data.sheets || [],
178
+ },
179
+ error: null,
180
+ };
181
+ }
182
+ catch (err) {
183
+ return {
184
+ data: null,
185
+ error: err.response?.data?.error || err.message,
186
+ };
187
+ }
188
+ }
189
+ async getSheet(sheetNameOrId, spreadsheetId) {
190
+ try {
191
+ const sheets = await this.getClient();
192
+ const idToUse = this.getSpreadsheetId(spreadsheetId);
193
+ const res = await sheets.spreadsheets.get({
194
+ spreadsheetId: idToUse,
195
+ fields: "sheets(properties)",
196
+ });
197
+ const foundSheet = (res.data.sheets || []).find((sheet) => sheet.properties?.title === sheetNameOrId ||
198
+ sheet.properties?.sheetId?.toString() === sheetNameOrId);
199
+ if (!foundSheet) {
200
+ return {
201
+ data: null,
202
+ error: new Error(`Sheet '${sheetNameOrId}' not found.`),
203
+ };
204
+ }
205
+ return { data: foundSheet, error: null };
206
+ }
207
+ catch (err) {
208
+ return {
209
+ data: null,
210
+ error: err.response?.data?.error || err.message,
211
+ };
212
+ }
213
+ }
214
+ async createSheet(title, spreadsheetId) {
215
+ try {
216
+ const sheets = await this.getClient();
217
+ const idToUse = this.getSpreadsheetId(spreadsheetId);
218
+ const res = await sheets.spreadsheets.batchUpdate({
219
+ spreadsheetId: idToUse,
220
+ requestBody: {
221
+ requests: [
222
+ {
223
+ addSheet: {
224
+ properties: {
225
+ title,
226
+ },
227
+ },
228
+ },
229
+ ],
230
+ },
231
+ });
232
+ const addSheetResponse = res.data.replies?.[0]?.addSheet;
233
+ if (!addSheetResponse) {
234
+ return {
235
+ data: null,
236
+ error: new Error("Failed to create sheet, no response received."),
237
+ };
238
+ }
239
+ return { data: addSheetResponse, error: null };
240
+ }
241
+ catch (err) {
242
+ return {
243
+ data: null,
244
+ error: err.response?.data?.error || err.message,
245
+ };
246
+ }
247
+ }
248
+ async deleteSheet(sheetId, spreadsheetId) {
249
+ try {
250
+ const sheets = await this.getClient();
251
+ const idToUse = this.getSpreadsheetId(spreadsheetId);
252
+ await sheets.spreadsheets.batchUpdate({
253
+ spreadsheetId: idToUse,
254
+ requestBody: {
255
+ requests: [
256
+ {
257
+ deleteSheet: {
258
+ sheetId: sheetId,
259
+ },
260
+ },
261
+ ],
262
+ },
263
+ });
264
+ return {
265
+ data: { success: true },
266
+ error: null,
267
+ };
268
+ }
269
+ catch (err) {
270
+ return {
271
+ data: null,
272
+ error: err.response?.data?.error || err.message,
273
+ };
274
+ }
275
+ }
276
+ /** @deprecated Use appendValues() instead */
277
+ async createRecord(record, sheetName) {
278
+ return this.appendValues(sheetName, record);
279
+ }
280
+ /** @deprecated Use getValues() instead */
281
+ async getRecords(sheetName, params) {
282
+ const range = params?.range
283
+ ? `${sheetName}!${params.range}`
284
+ : sheetName;
285
+ return this.getValues(range, {
286
+ majorDimension: params?.majorDimension,
287
+ valueRenderOption: params?.valueRenderOption,
288
+ });
289
+ }
290
+ /** @deprecated Use updateValues() instead */
291
+ async updateRecord(range, record, sheetName) {
292
+ const fullRange = `${sheetName}!${range}`;
293
+ return this.updateValues(fullRange, record);
294
+ }
295
+ /** @deprecated Use clearValues() instead */
296
+ async deleteRecord(range, sheetName) {
297
+ const fullRange = `${sheetName}!${range}`;
298
+ return this.clearValues(fullRange);
299
+ }
300
+ }
301
+ exports.GoogleSheetsClient = GoogleSheetsClient;
302
+ //# sourceMappingURL=client.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client.js","sourceRoot":"","sources":["../src/client.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export { GoogleSheetsClient } from './client';
2
+ export type { GoogleSheets } from './types';
3
+ export { GoogleSheetsValidators, ValidationError } from './validators';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAC9C,YAAY,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAC5C,OAAO,EAAE,sBAAsB,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,9 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ValidationError = exports.GoogleSheetsValidators = exports.GoogleSheetsClient = void 0;
4
+ var client_1 = require("./client");
5
+ Object.defineProperty(exports, "GoogleSheetsClient", { enumerable: true, get: function () { return client_1.GoogleSheetsClient; } });
6
+ var validators_1 = require("./validators");
7
+ Object.defineProperty(exports, "GoogleSheetsValidators", { enumerable: true, get: function () { return validators_1.GoogleSheetsValidators; } });
8
+ Object.defineProperty(exports, "ValidationError", { enumerable: true, get: function () { return validators_1.ValidationError; } });
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;AAAA,mCAA8C;AAArC,4GAAA,kBAAkB,OAAA;AAE3B,2CAAuE;AAA9D,oHAAA,sBAAsB,OAAA;AAAE,6GAAA,eAAe,OAAA"}
@@ -0,0 +1,40 @@
1
+ import { sheets_v4 } from 'googleapis';
2
+ export declare namespace GoogleSheets {
3
+ type ValueRange = {
4
+ values: any[][];
5
+ };
6
+ type UpdateValuesResponse = {
7
+ spreadsheetId: string;
8
+ updatedRange: string;
9
+ updatedRows: number;
10
+ updatedColumns: number;
11
+ updatedCells: number;
12
+ };
13
+ type GetValuesResponse = {
14
+ values: any[][];
15
+ range: string;
16
+ };
17
+ type SpreadsheetResponse = {
18
+ spreadsheetId: string;
19
+ properties: sheets_v4.Schema$SpreadsheetProperties;
20
+ sheets: sheets_v4.Schema$Sheet[];
21
+ };
22
+ type SheetsResponse = {
23
+ sheets: sheets_v4.Schema$Sheet[];
24
+ };
25
+ type SheetResponse = sheets_v4.Schema$Sheet;
26
+ type ClearResponse = {
27
+ clearedRange: string;
28
+ };
29
+ type CreateSheetResponse = sheets_v4.Schema$AddSheetResponse;
30
+ type DeleteSheetResponse = {
31
+ success: boolean;
32
+ };
33
+ /** @deprecated Use ValueRange instead */
34
+ type RecordPayload = ValueRange;
35
+ /** @deprecated Use UpdateValuesResponse instead */
36
+ type RecordResponse = UpdateValuesResponse;
37
+ /** @deprecated Use GetValuesResponse instead */
38
+ type RecordsResponse = GetValuesResponse;
39
+ }
40
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAEvC,yBAAiB,YAAY,CAAC;IAC5B,KAAY,UAAU,GAAG;QACvB,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC;KACjB,CAAC;IAEF,KAAY,oBAAoB,GAAG;QACjC,aAAa,EAAE,MAAM,CAAC;QACtB,YAAY,EAAE,MAAM,CAAC;QACrB,WAAW,EAAE,MAAM,CAAC;QACpB,cAAc,EAAE,MAAM,CAAC;QACvB,YAAY,EAAE,MAAM,CAAC;KACtB,CAAC;IAEF,KAAY,iBAAiB,GAAG;QAC9B,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC;QAChB,KAAK,EAAE,MAAM,CAAC;KACf,CAAC;IAEF,KAAY,mBAAmB,GAAG;QAChC,aAAa,EAAE,MAAM,CAAC;QACtB,UAAU,EAAE,SAAS,CAAC,4BAA4B,CAAC;QACnD,MAAM,EAAE,SAAS,CAAC,YAAY,EAAE,CAAC;KAClC,CAAC;IAEF,KAAY,cAAc,GAAG;QAC3B,MAAM,EAAE,SAAS,CAAC,YAAY,EAAE,CAAC;KAClC,CAAC;IAEF,KAAY,aAAa,GAAG,SAAS,CAAC,YAAY,CAAC;IAEnD,KAAY,aAAa,GAAG;QAC1B,YAAY,EAAE,MAAM,CAAC;KACtB,CAAC;IAEF,KAAY,mBAAmB,GAAG,SAAS,CAAC,uBAAuB,CAAC;IAEpE,KAAY,mBAAmB,GAAG;QAChC,OAAO,EAAE,OAAO,CAAC;KAClB,CAAC;IAEF,yCAAyC;IACzC,KAAY,aAAa,GAAG,UAAU,CAAC;IACvC,mDAAmD;IACnD,KAAY,cAAc,GAAG,oBAAoB,CAAC;IAClD,gDAAgD;IAChD,KAAY,eAAe,GAAG,iBAAiB,CAAC;CACjD"}
package/dist/types.js ADDED
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,7 @@
1
+ import { ValidationError } from '@marketing-sdk/core';
2
+ import { GoogleSheets } from './types';
3
+ export { ValidationError };
4
+ export declare class GoogleSheetsValidators {
5
+ static validateRecordPayload(payload: GoogleSheets.RecordPayload): void;
6
+ }
7
+ //# sourceMappingURL=validators.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validators.d.ts","sourceRoot":"","sources":["../src/validators.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAEvC,OAAO,EAAE,eAAe,EAAE,CAAC;AAE3B,qBAAa,sBAAsB;IACjC,MAAM,CAAC,qBAAqB,CAAC,OAAO,EAAE,YAAY,CAAC,aAAa,GAAG,IAAI;CAexE"}
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.GoogleSheetsValidators = exports.ValidationError = void 0;
4
+ const core_1 = require("@marketing-sdk/core");
5
+ Object.defineProperty(exports, "ValidationError", { enumerable: true, get: function () { return core_1.ValidationError; } });
6
+ class GoogleSheetsValidators {
7
+ static validateRecordPayload(payload) {
8
+ if (!payload.values || !Array.isArray(payload.values)) {
9
+ throw new core_1.ValidationError('values', 'Values array is required');
10
+ }
11
+ if (payload.values.length === 0) {
12
+ throw new core_1.ValidationError('values', 'At least one row of values is required');
13
+ }
14
+ payload.values.forEach((row, index) => {
15
+ if (!Array.isArray(row)) {
16
+ throw new core_1.ValidationError(`values[${index}]`, 'Each row must be an array');
17
+ }
18
+ });
19
+ }
20
+ }
21
+ exports.GoogleSheetsValidators = GoogleSheetsValidators;
22
+ //# sourceMappingURL=validators.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validators.js","sourceRoot":"","sources":["../src/validators.ts"],"names":[],"mappings":";;;AAAA,8CAAsD;AAG7C,gGAHA,sBAAe,OAGA;AAExB,MAAa,sBAAsB;IACjC,MAAM,CAAC,qBAAqB,CAAC,OAAmC;QAC9D,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YACtD,MAAM,IAAI,sBAAe,CAAC,QAAQ,EAAE,0BAA0B,CAAC,CAAC;QAClE,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAChC,MAAM,IAAI,sBAAe,CAAC,QAAQ,EAAE,wCAAwC,CAAC,CAAC;QAChF,CAAC;QAED,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,GAAY,EAAE,KAAa,EAAE,EAAE;YACrD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;gBACxB,MAAM,IAAI,sBAAe,CAAC,UAAU,KAAK,GAAG,EAAE,2BAA2B,CAAC,CAAC;YAC7E,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;CACF;AAhBD,wDAgBC"}
package/package.json ADDED
@@ -0,0 +1,40 @@
1
+ {
2
+ "name": "@marketing-sdk/google-sheets",
3
+ "version": "0.1.1-experimental.0",
4
+ "description": "Google Sheets provider for marketing-sdk",
5
+ "main": "dist/index.js",
6
+ "types": "dist/index.d.ts",
7
+ "exports": {
8
+ ".": {
9
+ "types": "./dist/index.d.ts",
10
+ "import": "./dist/index.js",
11
+ "require": "./dist/index.js"
12
+ }
13
+ },
14
+ "files": [
15
+ "dist"
16
+ ],
17
+ "publishConfig": {
18
+ "access": "public"
19
+ },
20
+ "dependencies": {
21
+ "googleapis": "^131.0.0",
22
+ "@marketing-sdk/core": "0.1.1-experimental.0"
23
+ },
24
+ "peerDependencies": {
25
+ "@marketing-sdk/core": ">=0.1.0"
26
+ },
27
+ "devDependencies": {
28
+ "typescript": "^5.3.0",
29
+ "jest": "^29.7.0",
30
+ "ts-jest": "^29.1.0",
31
+ "@types/jest": "^29.5.0",
32
+ "@types/node": "^20.0.0"
33
+ },
34
+ "scripts": {
35
+ "build": "tsc",
36
+ "test": "jest",
37
+ "test:coverage": "jest --coverage",
38
+ "typecheck": "tsc --noEmit"
39
+ }
40
+ }