import { INodeProperties, } from 'n8n-workflow'; export const assetOperations: INodeProperties[] = [ { displayName: 'Operation', name: 'operation', type: 'options', displayOptions: { show: { resource: [ 'asset', ], }, }, options: [ { name: 'Create', value: 'create', description: 'Create an asset', }, { name: 'Delete', value: 'delete', description: 'Delete an asset', }, { name: 'Get', value: 'get', description: 'Retrieve an asset', }, { name: 'Get All', value: 'getAll', description: 'Retrieve all assets', }, { name: 'Update', value: 'update', description: 'Update an asset', }, ], default: 'create', }, ]; export const assetFields: INodeProperties[] = [ // ---------------------------------------- // asset: create // ---------------------------------------- { displayName: 'Asset Name', name: 'name', type: 'string', required: true, default: '', displayOptions: { show: { resource: [ 'asset', ], operation: [ 'create', ], }, }, }, { displayName: 'Asset Type Name/ID', name: 'assetTypeId', type: 'options', description: 'Choose from the list or specify an ID. You can also specify the ID using an expression.', required: true, default: '', typeOptions: { loadOptionsMethod: 'getAssetTypes', }, displayOptions: { show: { resource: [ 'asset', ], operation: [ 'create', ], }, }, }, { displayName: 'Asset Fields', name: 'assetFieldsUi', placeholder: 'Add Asset Field', type: 'fixedCollection', typeOptions: { multipleValues: true, }, displayOptions: { show: { resource: [ 'asset', ], operation: [ 'create', ], }, }, default: {}, options: [ { name: 'assetFieldValue', displayName: 'Asset Field', values: [ { displayName: 'Name/ID', name: 'name', type: 'options', typeOptions: { loadOptionsDependsOn: [ 'assetTypeId', ], loadOptionsMethod: 'getAssetTypeFields', }, default: '', description: 'The ID of the field to add custom field to.', }, { displayName: 'Value', name: 'value', type: 'string', default: '', description: 'The value to set on custom field.', }, ], }, ], }, // ---------------------------------------- // asset: delete // ---------------------------------------- { displayName: 'Asset Display ID', name: 'assetDisplayId', description: 'Display ID of the asset to delete. Do not confuse with asset ID.', type: 'string', required: true, default: '', displayOptions: { show: { resource: [ 'asset', ], operation: [ 'delete', ], }, }, }, // ---------------------------------------- // asset: get // ---------------------------------------- { displayName: 'Asset Display ID', name: 'assetDisplayId', description: 'Display ID of the asset to retrieve. Do not confuse with asset ID.', type: 'string', required: true, default: '', displayOptions: { show: { resource: [ 'asset', ], operation: [ 'get', ], }, }, }, // ---------------------------------------- // asset: getAll // ---------------------------------------- { displayName: 'Return All', name: 'returnAll', type: 'boolean', default: false, description: 'Whether to return all results or only up to a given limit', displayOptions: { show: { resource: [ 'asset', ], operation: [ 'getAll', ], }, }, }, { displayName: 'Limit', name: 'limit', type: 'number', default: 50, description: 'How many results to return', typeOptions: { minValue: 1, }, displayOptions: { show: { resource: [ 'asset', ], operation: [ 'getAll', ], returnAll: [ false, ], }, }, }, { displayName: 'Filters', name: 'filters', type: 'collection', placeholder: 'Add Filter', default: {}, displayOptions: { show: { resource: [ 'asset', ], operation: [ 'getAll', ], }, }, options: [ { displayName: 'Agent Name/ID', name: 'agent_id', type: 'options', default: '', description: 'ID of the agent by whom the asset is managed. Choose from the list or specify an ID. You can also specify the ID using an expression.', typeOptions: { loadOptionsMethod: 'getAgents', }, }, { displayName: 'Asset State', name: 'asset_state', type: 'string', default: '', description: 'Status of the asset to filter by. For example, "In use".', }, { displayName: 'Asset Type Name/ID', name: 'asset_type_id', type: 'options', default: '', description: 'ID of the asset type to filter by. Choose from the list or specify an ID. You can also specify the ID using an expression.', typeOptions: { loadOptionsMethod: 'getAssetTypes', }, }, { displayName: 'Department Name/ID', name: 'department_id', type: 'options', default: '', description: 'ID of the department to which the asset belongs. Choose from the list or specify an ID. You can also specify the ID using an expression.', typeOptions: { loadOptionsMethod: 'getDepartments', }, }, { displayName: 'Location Name/ID', name: 'location_id', type: 'options', default: '', description: 'ID of the location to filter by. Choose from the list or specify an ID. You can also specify the ID using an expression.', typeOptions: { loadOptionsMethod: 'getLocations', }, }, { displayName: 'Name', name: 'name', type: 'string', default: '', description: 'Display name of the asset to filter by', }, ], }, // ---------------------------------------- // asset: update // ---------------------------------------- { displayName: 'Asset Display ID', name: 'assetDisplayId', description: 'Display ID of the asset to update. Do not confuse with asset ID.', type: 'string', required: true, default: '', displayOptions: { show: { resource: [ 'asset', ], operation: [ 'update', ], }, }, }, { displayName: 'Asset Fields', name: 'assetFieldsUi', placeholder: 'Add Asset Field', type: 'fixedCollection', typeOptions: { multipleValues: true, }, displayOptions: { show: { resource: [ 'asset', ], operation: [ 'update', ], }, }, default: {}, options: [ { name: 'assetFieldValue', displayName: 'Asset Field', values: [ { displayName: 'Name/ID', name: 'name', type: 'options', typeOptions: { loadOptionsDependsOn: [ 'assetTypeId', ], loadOptionsMethod: 'getAssetTypeFields', }, default: '', description: 'The ID of the field to add custom field to.', }, { displayName: 'Value', name: 'value', type: 'string', default: '', description: 'The value to set on custom field.', }, ], }, ], }, ];