95 lines
2.5 KiB
TypeScript
Executable File
95 lines
2.5 KiB
TypeScript
Executable File
/* eslint-disable n8n-nodes-base/node-param-display-name-wrong-for-dynamic-options */
|
|
/* eslint-disable n8n-nodes-base/node-param-description-wrong-for-dynamic-options */
|
|
import {
|
|
type IDataObject,
|
|
type INodeExecutionData,
|
|
type INodeProperties,
|
|
type IExecuteFunctions,
|
|
updateDisplayOptions,
|
|
} from 'n8n-workflow';
|
|
|
|
import { seaTableApiRequest } from '../../GenericFunctions';
|
|
|
|
export const properties: INodeProperties[] = [
|
|
{
|
|
displayName: 'Table Name (Source)',
|
|
name: 'tableName',
|
|
type: 'options',
|
|
placeholder: 'Name of table',
|
|
required: true,
|
|
typeOptions: {
|
|
loadOptionsMethod: 'getTableNameAndId',
|
|
},
|
|
default: '',
|
|
description:
|
|
'Choose from the list, of specify by using an expression. Provide it in the way "table_name:::table_id".',
|
|
},
|
|
{
|
|
displayName: 'Link Column',
|
|
name: 'linkColumn',
|
|
type: 'options',
|
|
typeOptions: {
|
|
loadOptionsDependsOn: ['tableName'],
|
|
loadOptionsMethod: 'getLinkColumns',
|
|
},
|
|
required: true,
|
|
default: '',
|
|
description:
|
|
'Choose from the list of specify the Link Column by using an expression. You have to provide it in the way "column_name:::link_id:::other_table_id".',
|
|
},
|
|
{
|
|
displayName: 'Row ID From the Source Table',
|
|
name: 'linkColumnSourceId',
|
|
type: 'string',
|
|
required: true,
|
|
default: '',
|
|
description: 'Provide the row ID of table you selected',
|
|
},
|
|
{
|
|
displayName: 'Row ID From the Target Table',
|
|
name: 'linkColumnTargetId',
|
|
type: 'string',
|
|
required: true,
|
|
default: '',
|
|
description: 'Provide the row ID of table you want to link',
|
|
},
|
|
];
|
|
|
|
const displayOptions = {
|
|
show: {
|
|
resource: ['link'],
|
|
operation: ['remove'],
|
|
},
|
|
};
|
|
|
|
export const description = updateDisplayOptions(displayOptions, properties);
|
|
|
|
export async function execute(
|
|
this: IExecuteFunctions,
|
|
index: number,
|
|
): Promise<INodeExecutionData[]> {
|
|
const tableName = this.getNodeParameter('tableName', index) as string;
|
|
const linkColumn = this.getNodeParameter('linkColumn', index) as any;
|
|
const linkColumnSourceId = this.getNodeParameter('linkColumnSourceId', index) as string;
|
|
const linkColumnTargetId = this.getNodeParameter('linkColumnTargetId', index) as string;
|
|
|
|
const body = {
|
|
link_id: linkColumn.split(':::')[1],
|
|
table_id: tableName.split(':::')[1],
|
|
other_table_id: linkColumn.split(':::')[2],
|
|
other_rows_ids_map: {
|
|
[linkColumnSourceId]: [linkColumnTargetId],
|
|
},
|
|
};
|
|
|
|
const responseData = await seaTableApiRequest.call(
|
|
this,
|
|
{},
|
|
'DELETE',
|
|
'/api-gateway/api/v2/dtables/{{dtable_uuid}}/links/',
|
|
body,
|
|
);
|
|
|
|
return this.helpers.returnJsonArray(responseData as IDataObject[]);
|
|
}
|