* ⚡ enabled array-type * ⚡ await-thenable on * ⚡ ban-types on * ⚡ default-param-last on * ⚡ dot-notation on * ⚡ member-delimiter-style on * ⚡ no-duplicate-imports on * ⚡ no-empty-interface on * ⚡ no-floating-promises on * ⚡ no-for-in-array on * ⚡ no-invalid-void-type on * ⚡ no-loop-func on * ⚡ no-shadow on * ⚡ ban-ts-comment re enabled * ⚡ @typescript-eslint/lines-between-class-members on * address my own comment * @typescript-eslint/return-await on * @typescript-eslint/promise-function-async on * @typescript-eslint/no-unnecessary-boolean-literal-compare on * @typescript-eslint/no-unnecessary-type-assertion on * prefer-const on * @typescript-eslint/prefer-optional-chain on Co-authored-by: कारतोफ्फेलस्क्रिप्ट™ <aditya@netroy.in>
35 lines
893 B
TypeScript
35 lines
893 B
TypeScript
import { IExecuteFunctions } from 'n8n-core';
|
|
import { IDataObject, INodeExecutionData } from 'n8n-workflow';
|
|
import { apiRequest } from '../../transport';
|
|
import { GoogleSheet } from '../../helpers/GoogleSheet';
|
|
|
|
export async function execute(
|
|
this: IExecuteFunctions,
|
|
sheet: GoogleSheet,
|
|
sheetName: string,
|
|
): Promise<INodeExecutionData[]> {
|
|
const returnData: IDataObject[] = [];
|
|
const items = this.getInputData();
|
|
for (let i = 0; i < items.length; i++) {
|
|
const [spreadsheetId, sheetWithinDocument] = sheetName.split('||');
|
|
const requests = [
|
|
{
|
|
deleteSheet: {
|
|
sheetId: sheetWithinDocument,
|
|
},
|
|
},
|
|
];
|
|
|
|
const responseData = await apiRequest.call(
|
|
this,
|
|
'POST',
|
|
`/v4/spreadsheets/${spreadsheetId}:batchUpdate`,
|
|
{ requests },
|
|
);
|
|
delete responseData.replies;
|
|
returnData.push(responseData);
|
|
}
|
|
|
|
return this.helpers.returnJsonArray(returnData);
|
|
}
|