mirror of
https://github.com/n8n-io/n8n.git
synced 2025-01-06 18:37:27 -08:00
52dd2c7619
Some checks are pending
Test Master / install-and-build (push) Waiting to run
Test Master / Unit tests (18.x) (push) Blocked by required conditions
Test Master / Unit tests (20.x) (push) Blocked by required conditions
Test Master / Unit tests (22.4) (push) Blocked by required conditions
Test Master / Lint (push) Blocked by required conditions
Test Master / Notify Slack on failure (push) Blocked by required conditions
Benchmark Docker Image CI / build (push) Waiting to run
Co-authored-by: Jan Oberhauser <jan@n8n.io> Co-authored-by: Giulio Andreini <g.andreini@gmail.com> Co-authored-by: Tomi Turtiainen <10324676+tomi@users.noreply.github.com> Co-authored-by: Elias Meire <elias@meire.dev>
279 lines
7 KiB
TypeScript
279 lines
7 KiB
TypeScript
import type { INodeProperties } from 'n8n-workflow';
|
||
const operationOptions = [
|
||
{
|
||
name: 'Remove Items Repeated Within Current Input',
|
||
value: 'removeDuplicateInputItems',
|
||
description: 'Remove duplicates from incoming items',
|
||
action: 'Remove items repeated within current input',
|
||
},
|
||
{
|
||
name: 'Remove Items Processed in Previous Executions',
|
||
value: 'removeItemsSeenInPreviousExecutions',
|
||
description: 'Deduplicate items already seen in previous executions',
|
||
action: 'Remove items processed in previous executions',
|
||
},
|
||
{
|
||
name: 'Clear Deduplication History',
|
||
value: 'clearDeduplicationHistory',
|
||
description: 'Wipe the store of previous items',
|
||
action: 'Clear deduplication history',
|
||
},
|
||
];
|
||
const compareOptions = [
|
||
{
|
||
name: 'All Fields',
|
||
value: 'allFields',
|
||
},
|
||
{
|
||
name: 'All Fields Except',
|
||
value: 'allFieldsExcept',
|
||
},
|
||
{
|
||
name: 'Selected Fields',
|
||
value: 'selectedFields',
|
||
},
|
||
];
|
||
const logicOptions = [
|
||
{
|
||
name: 'Value Is New',
|
||
value: 'removeItemsWithAlreadySeenKeyValues',
|
||
description: 'Remove all input items with values matching those already processed',
|
||
},
|
||
{
|
||
name: 'Value Is Higher than Any Previous Value',
|
||
value: 'removeItemsUpToStoredIncrementalKey',
|
||
description:
|
||
'Works with incremental values, removes all input items with values up to the stored value',
|
||
},
|
||
{
|
||
name: 'Value Is a Date Later than Any Previous Date',
|
||
value: 'removeItemsUpToStoredDate',
|
||
description:
|
||
'Works with date values, removes all input items with values up to the stored date',
|
||
},
|
||
];
|
||
const manageDatabaseModeOptions = [
|
||
{
|
||
name: 'Clean Database',
|
||
value: 'cleanDatabase',
|
||
description: 'Clear all values stored for a key in the database',
|
||
},
|
||
];
|
||
|
||
export const removeDuplicatesNodeFields: INodeProperties[] = [
|
||
{
|
||
displayName: 'Operation',
|
||
name: 'operation',
|
||
type: 'options',
|
||
noDataExpression: true,
|
||
options: operationOptions,
|
||
default: 'removeDuplicateInputItems',
|
||
},
|
||
{
|
||
displayName: 'Compare',
|
||
name: 'compare',
|
||
type: 'options',
|
||
options: compareOptions,
|
||
default: 'allFields',
|
||
description: 'The fields of the input items to compare to see if they are the same',
|
||
displayOptions: {
|
||
show: {
|
||
operation: ['removeDuplicateInputItems'],
|
||
},
|
||
},
|
||
},
|
||
{
|
||
displayName: 'Fields To Exclude',
|
||
name: 'fieldsToExclude',
|
||
type: 'string',
|
||
placeholder: 'e.g. email, name',
|
||
requiresDataPath: 'multiple',
|
||
description: 'Fields in the input to exclude from the comparison',
|
||
default: '',
|
||
displayOptions: {
|
||
show: {
|
||
compare: ['allFieldsExcept'],
|
||
},
|
||
},
|
||
},
|
||
{
|
||
displayName: 'Fields To Compare',
|
||
name: 'fieldsToCompare',
|
||
type: 'string',
|
||
placeholder: 'e.g. email, name',
|
||
requiresDataPath: 'multiple',
|
||
description: 'Fields in the input to add to the comparison',
|
||
default: '',
|
||
displayOptions: {
|
||
show: {
|
||
compare: ['selectedFields'],
|
||
},
|
||
},
|
||
},
|
||
|
||
// ----------------------------------
|
||
{
|
||
displayName: 'Keep Items Where',
|
||
name: 'logic',
|
||
type: 'options',
|
||
noDataExpression: true,
|
||
options: logicOptions,
|
||
default: 'removeItemsWithAlreadySeenKeyValues',
|
||
description:
|
||
'How to select input items to remove by comparing them with key values previously processed',
|
||
displayOptions: {
|
||
show: {
|
||
operation: ['removeItemsSeenInPreviousExecutions'],
|
||
},
|
||
},
|
||
},
|
||
{
|
||
displayName: 'Value to Dedupe On',
|
||
name: 'dedupeValue',
|
||
type: 'string',
|
||
default: '',
|
||
description: 'Use an input field (or a combination of fields) that has a unique ID value',
|
||
hint: 'The input field value to compare between items',
|
||
placeholder: 'e.g. ID',
|
||
required: true,
|
||
displayOptions: {
|
||
show: {
|
||
logic: ['removeItemsWithAlreadySeenKeyValues'],
|
||
'/operation': ['removeItemsSeenInPreviousExecutions'],
|
||
},
|
||
},
|
||
},
|
||
{
|
||
displayName: 'Value to Dedupe On',
|
||
name: 'incrementalDedupeValue',
|
||
type: 'number',
|
||
default: '',
|
||
description: 'Use an input field (or a combination of fields) that has an incremental value',
|
||
hint: 'The input field value to compare between items, an incremental value is expected',
|
||
placeholder: 'e.g. ID',
|
||
displayOptions: {
|
||
show: {
|
||
logic: ['removeItemsUpToStoredIncrementalKey'],
|
||
'/operation': ['removeItemsSeenInPreviousExecutions'],
|
||
},
|
||
},
|
||
},
|
||
{
|
||
displayName: 'Value to Dedupe On',
|
||
name: 'dateDedupeValue',
|
||
type: 'dateTime',
|
||
default: '',
|
||
description: 'Use an input field that has a date value in ISO format',
|
||
hint: 'The input field value to compare between items, a date is expected',
|
||
placeholder: ' e.g. 2024-08-09T13:44:16Z',
|
||
displayOptions: {
|
||
show: {
|
||
logic: ['removeItemsUpToStoredDate'],
|
||
'/operation': ['removeItemsSeenInPreviousExecutions'],
|
||
},
|
||
},
|
||
},
|
||
{
|
||
displayName: 'Mode',
|
||
name: 'mode',
|
||
type: 'options',
|
||
default: 'cleanDatabase',
|
||
description:
|
||
'How you want to modify the key values stored on the database. None of these modes removes input items.',
|
||
displayOptions: {
|
||
show: {
|
||
operation: ['clearDeduplicationHistory'],
|
||
},
|
||
},
|
||
options: manageDatabaseModeOptions,
|
||
},
|
||
{
|
||
displayName: 'Options',
|
||
name: 'options',
|
||
type: 'collection',
|
||
placeholder: 'Add Field',
|
||
default: {},
|
||
displayOptions: {
|
||
show: {
|
||
operation: [
|
||
'removeDuplicateInputItems',
|
||
'removeItemsSeenInPreviousExecutions',
|
||
'clearDeduplicationHistory',
|
||
],
|
||
},
|
||
},
|
||
options: [
|
||
{
|
||
displayName: 'Disable Dot Notation',
|
||
name: 'disableDotNotation',
|
||
type: 'boolean',
|
||
default: false,
|
||
displayOptions: {
|
||
show: {
|
||
'/operation': ['removeDuplicateInputItems'],
|
||
},
|
||
hide: {
|
||
'/compare': ['allFields'],
|
||
},
|
||
},
|
||
description:
|
||
'Whether to disallow referencing child fields using `parent.child` in the field name',
|
||
},
|
||
{
|
||
displayName: 'Remove Other Fields',
|
||
name: 'removeOtherFields',
|
||
type: 'boolean',
|
||
default: false,
|
||
displayOptions: {
|
||
show: {
|
||
'/operation': ['removeDuplicateInputItems'],
|
||
},
|
||
hide: {
|
||
'/compare': ['allFields'],
|
||
},
|
||
},
|
||
description:
|
||
'Whether to remove any fields that are not being compared. If disabled, will keep the values from the first of the duplicates.',
|
||
},
|
||
{
|
||
displayName: 'Scope',
|
||
name: 'scope',
|
||
type: 'options',
|
||
default: 'node',
|
||
displayOptions: {
|
||
show: {
|
||
'/operation': ['clearDeduplicationHistory', 'removeItemsSeenInPreviousExecutions'],
|
||
},
|
||
},
|
||
description:
|
||
'If set to ‘workflow,’ key values will be shared across all nodes in the workflow. If set to ‘node,’ key values will be specific to this node.',
|
||
options: [
|
||
{
|
||
name: 'Workflow',
|
||
value: 'workflow',
|
||
description: 'Deduplication info will be shared by all the nodes in the workflow',
|
||
},
|
||
{
|
||
name: 'Node',
|
||
value: 'node',
|
||
description: 'Deduplication info will be stored only for this node',
|
||
},
|
||
],
|
||
},
|
||
{
|
||
displayName: 'History Size',
|
||
name: 'historySize',
|
||
type: 'number',
|
||
default: 10000,
|
||
hint: 'The max number of past items to store for deduplication',
|
||
displayOptions: {
|
||
show: {
|
||
'/logic': ['removeItemsWithAlreadySeenKeyValues'],
|
||
'/operation': ['removeItemsSeenInPreviousExecutions'],
|
||
},
|
||
},
|
||
},
|
||
],
|
||
},
|
||
];
|