import { INodeProperties, } from 'n8n-workflow'; export const teamOperations: INodeProperties[] = [ { displayName: 'Operation', name: 'operation', type: 'options', noDataExpression: true, displayOptions: { show: { resource: [ 'team', ], }, }, options: [ { name: 'Create', value: 'create', description: 'Create a new team', }, { name: 'Delete', value: 'delete', description: 'Delete a team', }, { name: 'Get', value: 'get', description: 'Get team by slug', }, { name: 'Get All', value: 'getAll', description: 'Get all teams', }, { name: 'Update', value: 'update', description: 'Update a team', }, ], default: 'get', }, ]; export const teamFields: INodeProperties[] = [ /* -------------------------------------------------------------------------- */ /* team:getAll */ /* -------------------------------------------------------------------------- */ { displayName: 'Organization Slug Name or ID', name: 'organizationSlug', type: 'options', typeOptions: { loadOptionsMethod: 'getOrganizations', }, default: '', displayOptions: { show: { resource: [ 'team', ], operation: [ 'getAll', ], }, }, required: true, description: 'The slug of the organization for which the teams should be listed. Choose from the list, or specify an ID using an expression.', }, { displayName: 'Return All', name: 'returnAll', type: 'boolean', displayOptions: { show: { operation: [ 'getAll', ], resource: [ 'team', ], }, }, default: false, description: 'Whether to return all results or only up to a given limit', }, { displayName: 'Limit', name: 'limit', type: 'number', displayOptions: { show: { operation: [ 'getAll', ], resource: [ 'team', ], returnAll: [ false, ], }, }, typeOptions: { minValue: 1, maxValue: 500, }, default: 100, description: 'Max number of results to return', }, /* -------------------------------------------------------------------------- */ /* team:get */ /* -------------------------------------------------------------------------- */ { displayName: 'Organization Slug Name or ID', name: 'organizationSlug', type: 'options', typeOptions: { loadOptionsMethod: 'getOrganizations', }, default: '', displayOptions: { show: { resource: [ 'team', ], operation: [ 'get', ], }, }, required: true, description: 'The slug of the organization the team belongs to. Choose from the list, or specify an ID using an expression.', }, { displayName: 'Team Slug Name or ID', name: 'teamSlug', type: 'options', typeOptions: { loadOptionsMethod: 'getTeams', loadOptionsDependsOn: [ 'organizationSlug', ], }, default: '', displayOptions: { show: { resource: [ 'team', ], operation: [ 'get', ], }, }, required: true, description: 'The slug of the team to get. Choose from the list, or specify an ID using an expression.', }, /* -------------------------------------------------------------------------- */ /* team:create */ /* -------------------------------------------------------------------------- */ { displayName: 'Organization Slug Name or ID', name: 'organizationSlug', type: 'options', typeOptions: { loadOptionsMethod: 'getOrganizations', }, default: '', displayOptions: { show: { resource: [ 'team', ], operation: [ 'create', ], }, }, required: true, description: 'The slug of the organization the team belongs to. Choose from the list, or specify an ID using an expression.', }, { displayName: 'Name', name: 'name', type: 'string', default: '', displayOptions: { show: { resource: [ 'team', ], operation: [ 'create', ], }, }, required: true, description: 'The name of the team', }, { displayName: 'Additional Fields', name: 'additionalFields', type: 'collection', placeholder: 'Add Field', default: {}, displayOptions: { show: { resource: [ 'team', ], operation: [ 'create', ], }, }, options: [ { displayName: 'Slug', name: 'slug', type: 'string', default: '', description: 'The optional slug for this team. If not provided it will be auto generated from the name.', }, ], }, /* -------------------------------------------------------------------------- */ /* team:update */ /* -------------------------------------------------------------------------- */ { displayName: 'Organization Slug Name or ID', name: 'organizationSlug', type: 'options', typeOptions: { loadOptionsMethod: 'getOrganizations', }, default: '', displayOptions: { show: { resource: [ 'team', ], operation: [ 'update', ], }, }, required: true, description: 'The slug of the organization the team belongs to. Choose from the list, or specify an ID using an expression.', }, { displayName: 'Team Slug Name or ID', name: 'teamSlug', type: 'options', typeOptions: { loadOptionsMethod: 'getTeams', loadOptionsDependsOn: [ 'organizationSlug', ], }, default: '', displayOptions: { show: { resource: [ 'team', ], operation: [ 'update', ], }, }, required: true, description: 'The slug of the team to update. Choose from the list, or specify an ID using an expression.', }, { displayName: 'Update Fields', name: 'updateFields', type: 'collection', placeholder: 'Add Field', default: {}, displayOptions: { show: { resource: [ 'team', ], operation: [ 'update', ], }, }, options: [ { displayName: 'Name', name: 'name', type: 'string', default: '', description: 'The new name of the team', }, { displayName: 'Slug', name: 'slug', type: 'string', default: '', description: 'The new slug of the team. Must be unique and available.', }, ], }, /* -------------------------------------------------------------------------- */ /* team:delete */ /* -------------------------------------------------------------------------- */ { displayName: 'Organization Slug Name or ID', name: 'organizationSlug', type: 'options', typeOptions: { loadOptionsMethod: 'getOrganizations', }, default: '', displayOptions: { show: { resource: [ 'team', ], operation: [ 'delete', ], }, }, required: true, description: 'The slug of the organization the team belongs to. Choose from the list, or specify an ID using an expression.', }, { displayName: 'Team Slug Name or ID', name: 'teamSlug', type: 'options', typeOptions: { loadOptionsMethod: 'getTeams', loadOptionsDependsOn: [ 'organizationSlug', ], }, default: '', displayOptions: { show: { resource: [ 'team', ], operation: [ 'delete', ], }, }, required: true, description: 'The slug of the team to delete. Choose from the list, or specify an ID using an expression.', }, ];