mirror of
https://github.com/n8n-io/n8n.git
synced 2024-11-16 01:24:05 -08:00
7d1d1f7872
* Setup versionized node
* Fix node naming
* Set all possible actions
* Add Current Date operation
* Add timezone to current date
* feat add to date operator
* Change output field name to camel case
* Fix info box for luxons tip
* Feat subtract to date operation
* Feat format date operation
* Fix to node field for format date
* Feat rounding operation
* Feat get in between date operation
* Feat add extract date operation
* Add generic function for parsing date
* Remove moment methods from operations
* Change moment to luxon for the rest of the operations
* Fix Format date operation
* Fix format value
* Add timezone option for current date
* Add tests, improve workflow settings for testing, toString the results
* Change icon for V2
* Revert "Change icon for V2"
This reverts commit 46b59bea2e
.
* Change workflow test name
* Fix ui bug for custom format
* Fix default value for format operation
* Fix info box for rounding operation
* Change default for units for between time operation
* Inprove fields and resort time units
* Fix extract week number
* Resolve issue with formating and timezones
* Fix field name and unit order
* ⚡ restored removed test case, sync v1 with curent master
* ⚡ parseDate update to support timestamps, tests
* Keep same field for substract and add time
* Update unit test
* Improve visibility, add iso to string option
* Update option naming
---------
Co-authored-by: Michael Kret <michael.k@radency.com>
123 lines
2.1 KiB
TypeScript
123 lines
2.1 KiB
TypeScript
import type { INodeProperties } from 'n8n-workflow';
|
|
|
|
export const RoundDateDescription: INodeProperties[] = [
|
|
{
|
|
displayName:
|
|
"You can also do this using an expression, e.g. <code>{{ your_date.beginningOf('month') }}</code> or <code>{{ your_date.endOfMonth() }}</code>. <a target='_blank' href='https://docs.n8n.io/code-examples/expressions/luxon/'>More info</a>",
|
|
name: 'notice',
|
|
type: 'notice',
|
|
default: '',
|
|
displayOptions: {
|
|
show: {
|
|
operation: ['roundDate'],
|
|
},
|
|
},
|
|
},
|
|
{
|
|
displayName: 'Date',
|
|
name: 'date',
|
|
type: 'string',
|
|
description: 'The date that you want to round',
|
|
default: '',
|
|
displayOptions: {
|
|
show: {
|
|
operation: ['roundDate'],
|
|
},
|
|
},
|
|
},
|
|
{
|
|
displayName: 'Mode',
|
|
name: 'mode',
|
|
type: 'options',
|
|
options: [
|
|
{
|
|
name: 'Round Down',
|
|
value: 'roundDown',
|
|
},
|
|
{
|
|
name: 'Round Up',
|
|
value: 'roundUp',
|
|
},
|
|
],
|
|
default: 'roundDown',
|
|
displayOptions: {
|
|
show: {
|
|
operation: ['roundDate'],
|
|
},
|
|
},
|
|
},
|
|
{
|
|
displayName: 'To Nearest',
|
|
name: 'toNearest',
|
|
type: 'options',
|
|
// eslint-disable-next-line n8n-nodes-base/node-param-options-type-unsorted-items
|
|
options: [
|
|
{
|
|
name: 'Year',
|
|
value: 'year',
|
|
},
|
|
{
|
|
name: 'Month',
|
|
value: 'month',
|
|
},
|
|
{
|
|
name: 'Week',
|
|
value: 'week',
|
|
},
|
|
{
|
|
name: 'Day',
|
|
value: 'day',
|
|
},
|
|
{
|
|
name: 'Hour',
|
|
value: 'hour',
|
|
},
|
|
{
|
|
name: 'Minute',
|
|
value: 'minute',
|
|
},
|
|
{
|
|
name: 'Second',
|
|
value: 'second',
|
|
},
|
|
],
|
|
default: 'month',
|
|
displayOptions: {
|
|
show: {
|
|
operation: ['roundDate'],
|
|
mode: ['roundDown'],
|
|
},
|
|
},
|
|
},
|
|
{
|
|
displayName: 'To',
|
|
name: 'to',
|
|
type: 'options',
|
|
options: [
|
|
{
|
|
name: 'End of Month',
|
|
value: 'month',
|
|
},
|
|
],
|
|
default: 'month',
|
|
displayOptions: {
|
|
show: {
|
|
operation: ['roundDate'],
|
|
mode: ['roundUp'],
|
|
},
|
|
},
|
|
},
|
|
{
|
|
displayName: 'Output Field Name',
|
|
name: 'outputFieldName',
|
|
type: 'string',
|
|
default: 'roundedDate',
|
|
description: 'Name of the field to put the output in',
|
|
displayOptions: {
|
|
show: {
|
|
operation: ['roundDate'],
|
|
},
|
|
},
|
|
},
|
|
];
|