2023-07-12 02:15:38 -07:00
|
|
|
import type { IExecuteFunctions, INodeExecutionData } from 'n8n-workflow';
|
2023-05-02 02:44:25 -07:00
|
|
|
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`);
|
|
|
|
}
|
|
|
|
|
2023-09-05 03:59:02 -07:00
|
|
|
return [returnData];
|
2023-05-02 02:44:25 -07:00
|
|
|
}
|