mirror of
https://github.com/n8n-io/n8n.git
synced 2024-11-14 00:24:07 -08:00
38 lines
1.2 KiB
TypeScript
38 lines
1.2 KiB
TypeScript
import type { IExecuteFunctions } from 'n8n-core';
|
|
import type { INodeExecutionData } from 'n8n-workflow';
|
|
import { NodeOperationError } from 'n8n-workflow';
|
|
import type { MicrosoftExcel } from './node.type';
|
|
|
|
import * as table from './table/Table.resource';
|
|
import * as workbook from './workbook/Workbook.resource';
|
|
import * as worksheet from './worksheet/Worksheet.resource';
|
|
|
|
export async function router(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
|
|
const items = this.getInputData();
|
|
let returnData: INodeExecutionData[] = [];
|
|
|
|
const resource = this.getNodeParameter<MicrosoftExcel>('resource', 0);
|
|
const operation = this.getNodeParameter('operation', 0);
|
|
|
|
const microsoftExcel = {
|
|
resource,
|
|
operation,
|
|
} as MicrosoftExcel;
|
|
|
|
switch (microsoftExcel.resource) {
|
|
case 'table':
|
|
returnData = await table[microsoftExcel.operation].execute.call(this, items);
|
|
break;
|
|
case 'workbook':
|
|
returnData = await workbook[microsoftExcel.operation].execute.call(this, items);
|
|
break;
|
|
case 'worksheet':
|
|
returnData = await worksheet[microsoftExcel.operation].execute.call(this, items);
|
|
break;
|
|
default:
|
|
throw new NodeOperationError(this.getNode(), `The resource "${resource}" is not known`);
|
|
}
|
|
|
|
return this.prepareOutputData(returnData);
|
|
}
|