mirror of
https://github.com/n8n-io/n8n.git
synced 2025-03-05 20:50:17 -08:00
Add Current Date operation
This commit is contained in:
parent
83d17cbe4d
commit
0597929f1d
|
@ -0,0 +1,40 @@
|
||||||
|
import type { INodeProperties } from 'n8n-workflow';
|
||||||
|
|
||||||
|
export const CurrentDateDescription: INodeProperties[] = [
|
||||||
|
{
|
||||||
|
displayName:
|
||||||
|
'You can also refer to the current date in n8n expressions by using {{ $now }} or {{ $today }}. More info',
|
||||||
|
name: 'notice',
|
||||||
|
type: 'notice',
|
||||||
|
default: '',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
operation: ['getCurrentDate'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Include Current Time',
|
||||||
|
name: 'includeTime',
|
||||||
|
type: 'boolean',
|
||||||
|
default: true,
|
||||||
|
description: 'Whether deactivated, the time will be set to midnight',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
operation: ['getCurrentDate'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
displayName: 'Output Field Name',
|
||||||
|
name: 'outputFieldName',
|
||||||
|
type: 'string',
|
||||||
|
default: 'current_date',
|
||||||
|
description: 'Name of the field to put the output in',
|
||||||
|
displayOptions: {
|
||||||
|
show: {
|
||||||
|
operation: ['getCurrentDate'],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
];
|
|
@ -1,4 +1,5 @@
|
||||||
import type {
|
import type {
|
||||||
|
IDataObject,
|
||||||
IExecuteFunctions,
|
IExecuteFunctions,
|
||||||
ILoadOptionsFunctions,
|
ILoadOptionsFunctions,
|
||||||
INodeExecutionData,
|
INodeExecutionData,
|
||||||
|
@ -7,40 +8,10 @@ import type {
|
||||||
INodeTypeBaseDescription,
|
INodeTypeBaseDescription,
|
||||||
INodeTypeDescription,
|
INodeTypeDescription,
|
||||||
} from 'n8n-workflow';
|
} from 'n8n-workflow';
|
||||||
import { deepCopy, NodeOperationError } from 'n8n-workflow';
|
|
||||||
|
|
||||||
import moment from 'moment-timezone';
|
import moment from 'moment-timezone';
|
||||||
|
import { CurrentDateDescription } from './CurrentDateDescription';
|
||||||
function parseDateByFormat(this: IExecuteFunctions, value: string, fromFormat: string) {
|
import { AddToDateDescription } from './AddToDateDescription';
|
||||||
const date = moment(value, fromFormat, true);
|
|
||||||
if (moment(date).isValid()) return date;
|
|
||||||
|
|
||||||
throw new NodeOperationError(
|
|
||||||
this.getNode(),
|
|
||||||
'Date input cannot be parsed. Please recheck the value and the "From Format" field.',
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
function getIsoValue(this: IExecuteFunctions, value: string) {
|
|
||||||
try {
|
|
||||||
return new Date(value).toISOString(); // may throw due to unpredictable input
|
|
||||||
} catch (error) {
|
|
||||||
throw new NodeOperationError(
|
|
||||||
this.getNode(),
|
|
||||||
'Unrecognized date input. Please specify a format in the "From Format" field.',
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function parseDateByDefault(this: IExecuteFunctions, value: string) {
|
|
||||||
const isoValue = getIsoValue.call(this, value);
|
|
||||||
if (moment(isoValue).isValid()) return moment(isoValue);
|
|
||||||
|
|
||||||
throw new NodeOperationError(
|
|
||||||
this.getNode(),
|
|
||||||
'Unrecognized date input. Please specify a format in the "From Format" field.',
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
export class DateTimeV2 implements INodeType {
|
export class DateTimeV2 implements INodeType {
|
||||||
description: INodeTypeDescription;
|
description: INodeTypeDescription;
|
||||||
|
@ -57,9 +28,10 @@ export class DateTimeV2 implements INodeType {
|
||||||
outputs: ['main'],
|
outputs: ['main'],
|
||||||
properties: [
|
properties: [
|
||||||
{
|
{
|
||||||
displayName: 'Action',
|
displayName: 'Operation',
|
||||||
name: 'action',
|
name: 'operation',
|
||||||
type: 'options',
|
type: 'options',
|
||||||
|
noDataExpression: true,
|
||||||
options: [
|
options: [
|
||||||
{
|
{
|
||||||
name: 'Add to a Date',
|
name: 'Add to a Date',
|
||||||
|
@ -92,6 +64,8 @@ export class DateTimeV2 implements INodeType {
|
||||||
],
|
],
|
||||||
default: 'getCurrentDate',
|
default: 'getCurrentDate',
|
||||||
},
|
},
|
||||||
|
...CurrentDateDescription,
|
||||||
|
// ...AddToDateDescription,
|
||||||
],
|
],
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -115,5 +89,29 @@ export class DateTimeV2 implements INodeType {
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
async execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {}
|
async execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
|
||||||
|
const items = this.getInputData();
|
||||||
|
const returnData: INodeExecutionData[] = [];
|
||||||
|
const responseData = [];
|
||||||
|
const operation = this.getNodeParameter('operation', 0);
|
||||||
|
for (let i = 0; i < items.length; i++) {
|
||||||
|
if (operation === 'getCurrentDate') {
|
||||||
|
const includeTime = this.getNodeParameter('includeTime', i) as boolean;
|
||||||
|
const outputFieldName = this.getNodeParameter('outputFieldName', i) as string;
|
||||||
|
responseData.push(
|
||||||
|
includeTime
|
||||||
|
? { [outputFieldName]: moment() }
|
||||||
|
: { [outputFieldName]: moment().startOf('day') },
|
||||||
|
);
|
||||||
|
}
|
||||||
|
const executionData = this.helpers.constructExecutionMetaData(
|
||||||
|
this.helpers.returnJsonArray(responseData as IDataObject[]),
|
||||||
|
{
|
||||||
|
itemData: { item: i },
|
||||||
|
},
|
||||||
|
);
|
||||||
|
returnData.push(...executionData);
|
||||||
|
}
|
||||||
|
return this.prepareOutputData(returnData);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue