From 3c9bc53a79e442448e56bc5e56c4809933d9c25f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?R=C4=B1dvan=20Akca?= Date: Fri, 23 Jun 2023 19:47:04 +0300 Subject: [PATCH] feat(google-sheets): add create spreadsheet action --- .../actions/create-spreadsheet/index.ts | 105 ++++++++++++++++++ .../src/apps/google-sheets/actions/index.ts | 3 +- .../docs/pages/apps/google-sheets/actions.md | 4 +- 3 files changed, 110 insertions(+), 2 deletions(-) create mode 100644 packages/backend/src/apps/google-sheets/actions/create-spreadsheet/index.ts diff --git a/packages/backend/src/apps/google-sheets/actions/create-spreadsheet/index.ts b/packages/backend/src/apps/google-sheets/actions/create-spreadsheet/index.ts new file mode 100644 index 00000000..b072cb7a --- /dev/null +++ b/packages/backend/src/apps/google-sheets/actions/create-spreadsheet/index.ts @@ -0,0 +1,105 @@ +import defineAction from '../../../../helpers/define-action'; + +type THeaders = { + __id: string; + header: string; +}[]; + +export default defineAction({ + name: 'Create spreadsheet', + key: 'createSpreadsheet', + description: + 'Create a blank spreadsheet or duplicate an existing spreadsheet. Optionally, provide headers.', + arguments: [ + { + label: 'Title', + key: 'title', + type: 'string' as const, + required: true, + description: '', + variables: true, + }, + { + label: 'Spreadsheet to copy', + key: 'spreadsheetId', + type: 'dropdown' as const, + required: false, + description: 'Choose a spreadsheet to copy its data.', + variables: true, + source: { + type: 'query', + name: 'getDynamicData', + arguments: [ + { + name: 'key', + value: 'listSpreadsheets', + }, + ], + }, + }, + { + label: 'Headers', + key: 'headers', + type: 'dynamic' as const, + required: false, + description: + 'These headers are ignored if "Spreadsheet to Copy" is selected.', + fields: [ + { + label: 'Header', + key: 'header', + type: 'string' as const, + required: true, + variables: true, + }, + ], + }, + ], + + async run($) { + if ($.step.parameters.spreadsheetId) { + const body = { name: $.step.parameters.title }; + + const { data } = await $.http.post( + `https://www.googleapis.com/drive/v3/files/${$.step.parameters.spreadsheetId}/copy`, + body + ); + + $.setActionItem({ + raw: data, + }); + } else { + const headers = $.step.parameters.headers as THeaders; + const values = headers.map((entry) => entry.header); + + const spreadsheetBody = { + properties: { + title: $.step.parameters.title, + }, + sheets: [ + { + data: [ + { + startRow: 0, + startColumn: 0, + rowData: [ + { + values: values.map((header) => ({ + userEnteredValue: { stringValue: header }, + })), + }, + ], + }, + ], + }, + ], + }; + + const { data } = await $.http.post('/v4/spreadsheets', spreadsheetBody); + + $.setActionItem({ + raw: data, + }); + } + }, +}); diff --git a/packages/backend/src/apps/google-sheets/actions/index.ts b/packages/backend/src/apps/google-sheets/actions/index.ts index 7b0c8d2d..98d4a649 100644 --- a/packages/backend/src/apps/google-sheets/actions/index.ts +++ b/packages/backend/src/apps/google-sheets/actions/index.ts @@ -1,3 +1,4 @@ import createSpreadsheetRow from './create-spreadsheet-row'; +import createSpreadsheet from './create-spreadsheet'; -export default [createSpreadsheetRow]; +export default [createSpreadsheetRow, createSpreadsheet]; diff --git a/packages/docs/pages/apps/google-sheets/actions.md b/packages/docs/pages/apps/google-sheets/actions.md index 87e5ebfe..a9bcc86d 100644 --- a/packages/docs/pages/apps/google-sheets/actions.md +++ b/packages/docs/pages/apps/google-sheets/actions.md @@ -2,7 +2,9 @@ favicon: /favicons/google-sheets.svg items: - name: Create Spreadsheet Row - desc: Creates a new row in a specific spreadsheet + desc: Creates a new row in a specific spreadsheet. + - name: Create Spreadsheet + desc: Create a blank spreadsheet or duplicate an existing spreadsheet. Optionally, provide headers. ---