mirror of
https://github.com/Abdulazizzn/n8n-enterprise-unlocked.git
synced 2025-12-17 10:02:05 +00:00
* feat: activator disabled based on thiggers * feat: tooltip over inactive switch * feat: message for trigger types * feat: deactivate on save if trigger is removed * chore: refactor executions modal * feat: calculate service name if possible * feat: alert on activation * chore: fix linting * feat: always enable activator when active * fix: adjust the alert * feat: take disabled state into account * feat: automatically save on activation * feat: rely on nodes name and edit messages * feat: isolate state for each activator instance * feat: create activation modal component * feat: activationModal checkbox and trigger message * feat: add activation messages to node config * chore: style activation modal * chore: style fixes * feat: refactor disabled state * chore: refactor modal * chore: refactor modal * chore: tidy the node config * chore: refactor and styling tweaks * chore: minor fixes * fix: check webhooks from ui nodes * chore: remove saving prompt * chore: explicit current workflow evaluation * feat: add settings link to activation modal * fix: immediately load executions on render * feat: exclude error trigger from trigger nodes * chore: add i18n keys * fix: check localstorage more strictly * fix: handle refresh in execution list * remove unnessary event * remove comment * fix closing executions modal bugs * update closing * update translation key * fix translation keys * fix modal closing * fix closing * fix drawer closing * close all modals when opening executions * update key * close all modals when opening workflow or new page * delete unnessary comment * clean up import * clean up unnessary initial data * clean up activator impl * rewrite * fix open modal bug * simply remove error * refactor activation logic * fix i18n and such * remove changes * revert saving changes * Revert "revert saving changes" 25c29d10553ebcc11939ff29938e8a5ac6b3ffae * add translation * fix new workflows saving * clean up modal impl * clean up impl * refactor common code out * remove active changes from saving * refactor differently * revert unnessary change * set dirty false * fix i18n bug * avoid opening two modals * fix tooltips * add comment * address other comments * address comments Co-authored-by: saintsebastian <tilitidam@gmail.com>
107 lines
2.2 KiB
TypeScript
107 lines
2.2 KiB
TypeScript
import { ITriggerFunctions } from 'n8n-core';
|
|
import {
|
|
INodeType,
|
|
INodeTypeDescription,
|
|
ITriggerResponse,
|
|
NodeOperationError,
|
|
} from 'n8n-workflow';
|
|
|
|
|
|
export class Interval implements INodeType {
|
|
description: INodeTypeDescription = {
|
|
displayName: 'Interval',
|
|
name: 'interval',
|
|
icon: 'fa:hourglass',
|
|
group: ['trigger'],
|
|
version: 1,
|
|
description: 'Triggers the workflow in a given interval',
|
|
eventTriggerDescription: '',
|
|
activationMessage: 'Your interval trigger will now trigger executions on the schedule you have defined.',
|
|
defaults: {
|
|
name: 'Interval',
|
|
color: '#00FF00',
|
|
},
|
|
inputs: [],
|
|
outputs: ['main'],
|
|
properties: [
|
|
{
|
|
displayName: 'Interval',
|
|
name: 'interval',
|
|
type: 'number',
|
|
typeOptions: {
|
|
minValue: 1,
|
|
},
|
|
default: 1,
|
|
description: 'Interval value.',
|
|
},
|
|
{
|
|
displayName: 'Unit',
|
|
name: 'unit',
|
|
type: 'options',
|
|
options: [
|
|
{
|
|
name: 'Seconds',
|
|
value: 'seconds',
|
|
},
|
|
{
|
|
name: 'Minutes',
|
|
value: 'minutes',
|
|
},
|
|
{
|
|
name: 'Hours',
|
|
value: 'hours',
|
|
},
|
|
],
|
|
default: 'seconds',
|
|
description: 'Unit of the interval value.',
|
|
},
|
|
],
|
|
};
|
|
|
|
|
|
|
|
async trigger(this: ITriggerFunctions): Promise<ITriggerResponse> {
|
|
const interval = this.getNodeParameter('interval') as number;
|
|
const unit = this.getNodeParameter('unit') as string;
|
|
|
|
if (interval <= 0) {
|
|
throw new NodeOperationError(this.getNode(), 'The interval has to be set to at least 1 or higher!');
|
|
}
|
|
|
|
let intervalValue = interval;
|
|
if (unit === 'minutes') {
|
|
intervalValue *= 60;
|
|
}
|
|
if (unit === 'hours') {
|
|
intervalValue *= 60 * 60;
|
|
}
|
|
|
|
const executeTrigger = () => {
|
|
this.emit([this.helpers.returnJsonArray([{}])]);
|
|
};
|
|
|
|
intervalValue *= 1000;
|
|
|
|
// Reference: https://nodejs.org/api/timers.html#timers_setinterval_callback_delay_args
|
|
if (intervalValue > 2147483647) {
|
|
throw new Error('The interval value is too large.');
|
|
}
|
|
|
|
const intervalObj = setInterval(executeTrigger, intervalValue);
|
|
|
|
async function closeFunction() {
|
|
clearInterval(intervalObj);
|
|
}
|
|
|
|
async function manualTriggerFunction() {
|
|
executeTrigger();
|
|
}
|
|
|
|
return {
|
|
closeFunction,
|
|
manualTriggerFunction,
|
|
};
|
|
|
|
}
|
|
}
|