n8n/packages/nodes-base/nodes/PhilipsHue/LightDescription.ts

345 lines
7.6 KiB
TypeScript
Raw Normal View History

2020-07-31 13:26:23 -07:00
import {
INodeProperties,
} from 'n8n-workflow';
export const lightOperations: INodeProperties[] = [
2020-07-31 13:26:23 -07:00
{
displayName: 'Operation',
name: 'operation',
type: 'options',
displayOptions: {
show: {
resource: [
'light',
],
},
},
options: [
{
name: 'Delete',
value: 'delete',
description: 'Delete a light',
2020-07-31 13:26:23 -07:00
},
{
name: 'Get',
value: 'get',
description: 'Retrieve a light',
2020-07-31 13:26:23 -07:00
},
{
name: 'Get All',
value: 'getAll',
description: 'Retrieve all lights',
},
{
name: 'Update',
value: 'update',
description: 'Update a light',
2020-10-22 06:46:03 -07:00
},
2020-07-31 13:26:23 -07:00
],
default: 'update',
2020-10-22 06:46:03 -07:00
description: 'The operation to perform.',
},
];
2020-07-31 13:26:23 -07:00
export const lightFields: INodeProperties[] = [
2020-08-03 01:06:46 -07:00
2020-07-31 13:26:23 -07:00
/* -------------------------------------------------------------------------- */
/* light:delete */
/* -------------------------------------------------------------------------- */
{
displayName: 'Light ID',
name: 'lightId',
type: 'string',
required: true,
displayOptions: {
show: {
operation: [
'delete',
],
resource: [
'light',
],
},
},
default: '',
},
2020-08-03 01:06:46 -07:00
2020-07-31 13:26:23 -07:00
/* -------------------------------------------------------------------------- */
/* light:getAll */
/* -------------------------------------------------------------------------- */
{
displayName: 'Return All',
name: 'returnAll',
type: 'boolean',
displayOptions: {
show: {
operation: [
'getAll',
],
resource: [
'light',
],
},
},
default: false,
description: 'If all results should be returned or only up to a given limit.',
},
{
displayName: 'Limit',
name: 'limit',
type: 'number',
displayOptions: {
show: {
operation: [
'getAll',
],
resource: [
'light',
],
returnAll: [
false,
],
},
},
typeOptions: {
minValue: 1,
maxValue: 500,
},
default: 100,
description: 'How many results to return.',
},
2020-08-03 01:06:46 -07:00
2020-07-31 13:26:23 -07:00
/* -------------------------------------------------------------------------- */
/* light:get */
/* -------------------------------------------------------------------------- */
{
displayName: 'Light ID',
name: 'lightId',
type: 'string',
required: true,
displayOptions: {
show: {
operation: [
'get',
],
resource: [
'light',
],
},
},
default: '',
},
2020-08-03 01:06:46 -07:00
2020-07-31 13:26:23 -07:00
/* -------------------------------------------------------------------------- */
/* light:update */
/* -------------------------------------------------------------------------- */
{
displayName: 'Light ID',
name: 'lightId',
type: 'options',
typeOptions: {
loadOptionsMethod: 'getLights',
},
required: true,
displayOptions: {
show: {
operation: [
'update',
],
resource: [
'light',
],
},
},
default: '',
},
{
displayName: 'On',
name: 'on',
type: 'boolean',
required: true,
displayOptions: {
show: {
operation: [
'update',
],
resource: [
'light',
],
},
},
2020-08-03 01:06:46 -07:00
default: true,
description: 'On/Off state of the light.',
2020-07-31 13:26:23 -07:00
},
{
displayName: 'Additional Fields',
name: 'additionalFields',
type: 'collection',
placeholder: 'Add Field',
displayOptions: {
show: {
resource: [
'light',
],
operation: [
'update',
],
},
},
default: {},
options: [
{
displayName: 'Alert Effect',
name: 'alert',
type: 'options',
options: [
{
name: 'None',
2020-07-31 13:26:23 -07:00
value: 'none',
description: 'The light is not performing an alert effect',
2020-07-31 13:26:23 -07:00
},
{
name: 'Select',
value: 'select',
description: 'The light is performing one breathe cycle.',
},
{
name: 'LSelect',
value: 'lselect',
description: 'The light is performing breathe cycles for 15 seconds or until an "alert": "none" command is received',
},
],
default: '',
2020-08-03 01:06:46 -07:00
description: 'The alert effect, is a temporary change to the bulbs state',
2020-07-31 13:26:23 -07:00
},
{
displayName: 'Brightness',
name: 'bri',
type: 'number',
typeOptions: {
minValue: 1,
maxValue: 254,
},
default: 100,
description: 'The brightness value to set the light to.Brightness is a scale from 1 (the minimum the light is capable of) to 254 (the maximum).',
},
{
displayName: 'Brightness Increments',
name: 'bri_inc',
type: 'number',
typeOptions: {
minValue: -254,
maxValue: 254,
},
default: 0,
2020-08-03 01:06:46 -07:00
description: 'Increments or decrements the value of the brightness. This value is ignored if the Brightness attribute is provided.',
2020-07-31 13:26:23 -07:00
},
{
displayName: 'Color Temperature',
name: 'ct',
type: 'number',
default: 0,
description: 'The Mired color temperature of the light. 2012 connected lights are capable of 153 (6500K) to 500 (2000K).',
},
{
displayName: 'Color Temperature Increments',
name: 'ct_inc',
type: 'number',
typeOptions: {
minValue: -65534,
maxValue: 65534,
},
default: 0,
refactor: Apply `eslint-plugin-n8n-nodes-base` autofixable rules (#3174) * :zap: Initial setup * :shirt: Update `.eslintignore` * :shirt: Autofix node-param-default-missing (#3173) * :fire: Remove duplicate key * :shirt: Add exceptions * :package: Update package-lock.json * :shirt: Apply `node-class-description-inputs-wrong-trigger-node` (#3176) * :shirt: Apply `node-class-description-inputs-wrong-regular-node` (#3177) * :shirt: Apply `node-class-description-outputs-wrong` (#3178) * :shirt: Apply `node-execute-block-double-assertion-for-items` (#3179) * :shirt: Apply `node-param-default-wrong-for-collection` (#3180) * :shirt: Apply node-param-default-wrong-for-boolean (#3181) * Autofixed default missing * Autofixed booleans, worked well * :zap: Fix params * :rewind: Undo exempted autofixes * :package: Update package-lock.json * :shirt: Apply node-class-description-missing-subtitle (#3182) * :zap: Fix missing comma * :shirt: Apply `node-param-default-wrong-for-fixed-collection` (#3184) * :shirt: Add exception for `node-class-description-missing-subtitle` * :shirt: Apply `node-param-default-wrong-for-multi-options` (#3185) * :shirt: Apply `node-param-collection-type-unsorted-items` (#3186) * Missing coma * :shirt: Apply `node-param-default-wrong-for-simplify` (#3187) * :shirt: Apply `node-param-description-comma-separated-hyphen` (#3190) * :shirt: Apply `node-param-description-empty-string` (#3189) * :shirt: Apply `node-param-description-excess-inner-whitespace` (#3191) * Rule looks good * Add whitespace rule in eslint config * :zao: fix * :shirt: Apply `node-param-description-identical-to-display-name` (#3193) * :shirt: Apply `node-param-description-missing-for-ignore-ssl-issues` (#3195) * :rewind: Revert ":zao: fix" This reverts commit ef8a76f3dfedffd1bdccf3178af8a8d90cf5a55c. * :shirt: Apply `node-param-description-missing-for-simplify` (#3196) * :shirt: Apply `node-param-description-missing-final-period` (#3194) * Rule working as intended * Add rule to eslint * :shirt: Apply node-param-description-missing-for-return-all (#3197) * :zap: Restore `lintfix` command Co-authored-by: agobrech <45268029+agobrech@users.noreply.github.com> Co-authored-by: Omar Ajoue <krynble@gmail.com> Co-authored-by: agobrech <ael.gobrecht@gmail.com> Co-authored-by: Michael Kret <michael.k@radency.com>
2022-04-22 09:29:51 -07:00
description: 'Increments or decrements the value of the ct. ct_inc is ignored if the ct attribute is provided.',
2020-07-31 13:26:23 -07:00
},
2020-08-03 01:06:46 -07:00
{
displayName: 'Coordinates',
name: 'xy',
type: 'string',
default: '',
placeholder: '0.64394,0.33069',
description: `The x and y coordinates of a color in CIE color space. The first entry is the x coordinate and the second entry is the y coordinate. Both x and y are between 0 and 1`,
2020-08-03 01:06:46 -07:00
},
{
displayName: 'Coordinates Increments',
name: 'xy_inc',
type: 'string',
default: '',
placeholder: '0.5,0.5',
description: `Increments or decrements the value of the xy. This value is ignored if the Coordinates attribute is provided. Any ongoing color transition is stopped. Max value [0.5, 0.5]`,
},
2020-07-31 13:26:23 -07:00
{
displayName: 'Dynamic Effect',
name: 'effect',
type: 'options',
options: [
{
name: 'None',
2020-07-31 13:26:23 -07:00
value: 'none',
},
{
name: 'Color Loop',
value: 'colorloop',
},
],
default: '',
description: 'The dynamic effect of the light.',
},
{
displayName: 'Hue',
name: 'hue',
type: 'number',
typeOptions: {
minValue: 0,
maxValue: 65535,
},
default: 0,
description: 'The hue value to set light to.The hue value is a wrapping value between 0 and 65535. Both 0 and 65535 are red, 25500 is green and 46920 is blue.',
},
{
displayName: 'Hue Increments',
name: 'hue_inc',
type: 'number',
typeOptions: {
minValue: -65534,
maxValue: 65534,
},
default: 0,
2020-08-03 01:06:46 -07:00
description: 'Increments or decrements the value of the hue. Hue Increments is ignored if the Hue attribute is provided.',
2020-07-31 13:26:23 -07:00
},
{
displayName: 'Saturation',
name: 'sat',
type: 'number',
typeOptions: {
minValue: 0,
maxValue: 254,
},
default: 0,
description: 'Saturation of the light. 254 is the most saturated (colored) and 0 is the least saturated (white).',
},
{
displayName: 'Saturation Increments',
name: 'sat_inc',
type: 'number',
typeOptions: {
minValue: -254,
maxValue: 254,
},
default: 0,
2020-08-03 01:06:46 -07:00
description: 'Increments or decrements the value of the sat. This value is ignored if the Saturation attribute is provided.',
2020-07-31 13:26:23 -07:00
},
{
displayName: 'Transition Time',
name: 'transitiontime',
type: 'number',
typeOptions: {
minVale: 1,
},
default: 4,
description: 'The duration in seconds of the transition from the lights current state to the new state',
},
],
},
];