2021-09-05 10:24:56 -07:00
import {
INodeProperties ,
} from 'n8n-workflow' ;
2021-12-03 00:44:16 -08:00
export const agentGroupOperations : INodeProperties [ ] = [
2021-09-05 10:24:56 -07:00
{
displayName : 'Operation' ,
name : 'operation' ,
type : 'options' ,
2022-05-20 14:47:24 -07:00
noDataExpression : true ,
2021-09-05 10:24:56 -07:00
displayOptions : {
show : {
resource : [
'agentGroup' ,
] ,
} ,
} ,
options : [
{
name : 'Create' ,
value : 'create' ,
description : 'Create an agent group' ,
2022-07-10 13:50:51 -07:00
action : 'Create an agent group' ,
2021-09-05 10:24:56 -07:00
} ,
{
name : 'Delete' ,
value : 'delete' ,
description : 'Delete an agent group' ,
2022-07-10 13:50:51 -07:00
action : 'Delete an agent group' ,
2021-09-05 10:24:56 -07:00
} ,
{
name : 'Get' ,
value : 'get' ,
description : 'Retrieve an agent group' ,
2022-07-10 13:50:51 -07:00
action : 'Get an agent group' ,
2021-09-05 10:24:56 -07:00
} ,
{
name : 'Get All' ,
value : 'getAll' ,
description : 'Retrieve all agent groups' ,
2022-07-10 13:50:51 -07:00
action : 'Get all agent groups' ,
2021-09-05 10:24:56 -07:00
} ,
{
name : 'Update' ,
value : 'update' ,
description : 'Update an agent group' ,
2022-07-10 13:50:51 -07:00
action : 'Update an agent group' ,
2021-09-05 10:24:56 -07:00
} ,
] ,
default : 'create' ,
} ,
2021-12-03 00:44:16 -08:00
] ;
2021-09-05 10:24:56 -07:00
2021-12-03 00:44:16 -08:00
export const agentGroupFields : INodeProperties [ ] = [
2021-09-05 10:24:56 -07:00
// ----------------------------------------
// agentGroup: create
// ----------------------------------------
{
displayName : 'Name' ,
name : 'name' ,
type : 'string' ,
required : true ,
default : '' ,
displayOptions : {
show : {
resource : [
'agentGroup' ,
] ,
operation : [
'create' ,
] ,
} ,
} ,
} ,
{
displayName : 'Additional Fields' ,
name : 'additionalFields' ,
type : 'collection' ,
placeholder : 'Add Field' ,
default : { } ,
displayOptions : {
show : {
resource : [
'agentGroup' ,
] ,
operation : [
'create' ,
] ,
} ,
} ,
options : [
{
displayName : 'Description' ,
name : 'description' ,
type : 'string' ,
default : '' ,
} ,
{
2022-06-03 10:23:49 -07:00
displayName : 'Escalate to Agent Name or ID' ,
2021-09-05 10:24:56 -07:00
name : 'escalate_to' ,
type : 'options' ,
default : '' ,
typeOptions : {
2021-12-03 00:44:16 -08:00
loadOptionsMethod : 'getAgents' ,
2021-09-05 10:24:56 -07:00
} ,
2022-07-14 13:05:11 -07:00
description : 'ID of the user to whom an escalation email is sent if a ticket in this group is unassigned. Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>.' ,
2021-09-05 10:24:56 -07:00
} ,
{
2022-06-20 07:54:01 -07:00
displayName : 'Member Names or IDs' ,
2021-09-05 10:24:56 -07:00
name : 'members' ,
type : 'multiOptions' ,
default : [ ] ,
2022-07-14 13:05:11 -07:00
description : 'Comma-separated IDs of agents who are members of this group. Choose from the list or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>. Choose from the list, or specify IDs using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>.' ,
2021-09-05 10:24:56 -07:00
typeOptions : {
2021-12-03 00:44:16 -08:00
loadOptionsMethod : 'getAgents' ,
2021-09-05 10:24:56 -07:00
} ,
} ,
{
2022-06-20 07:54:01 -07:00
displayName : 'Observer Names or IDs' ,
2021-09-05 10:24:56 -07:00
name : 'observers' ,
type : 'multiOptions' ,
default : [ ] ,
2022-07-14 13:05:11 -07:00
description : 'Comma-separated agent IDs who are observers of this group. Choose from the list or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>. Choose from the list, or specify IDs using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>.' ,
2021-09-05 10:24:56 -07:00
typeOptions : {
2021-12-03 00:44:16 -08:00
loadOptionsMethod : 'getAgents' ,
2021-09-05 10:24:56 -07:00
} ,
} ,
{
displayName : 'Unassigned For' ,
name : 'unassigned_for' ,
description : 'Time after which an escalation email is sent if a ticket in the group remains unassigned' ,
type : 'options' ,
default : '30m' ,
options : [
{
2022-06-03 10:23:49 -07:00
name : '1 Day' ,
value : '1d' ,
2021-09-05 10:24:56 -07:00
} ,
{
name : '1 Hour' ,
value : '1h' ,
} ,
{
name : '12 Hours' ,
value : '12h' ,
} ,
{
name : '2 Days' ,
value : '2d' ,
} ,
2022-06-03 10:23:49 -07:00
{
name : '2 Hours' ,
value : '2h' ,
} ,
2021-09-05 10:24:56 -07:00
{
name : '3 Days' ,
value : '3d' ,
} ,
2022-06-03 10:23:49 -07:00
{
name : '30 Minutes' ,
value : '30m' ,
} ,
{
name : '8 Hours' ,
value : '8h' ,
} ,
2021-09-05 10:24:56 -07:00
] ,
} ,
] ,
} ,
// ----------------------------------------
// agentGroup: delete
// ----------------------------------------
{
displayName : 'Agent Group ID' ,
name : 'agentGroupId' ,
description : 'ID of the agent group to delete' ,
type : 'string' ,
required : true ,
default : '' ,
displayOptions : {
show : {
resource : [
'agentGroup' ,
] ,
operation : [
'delete' ,
] ,
} ,
} ,
} ,
// ----------------------------------------
// agentGroup: get
// ----------------------------------------
{
displayName : 'Agent Group ID' ,
name : 'agentGroupId' ,
description : 'ID of the agent group to retrieve' ,
type : 'string' ,
required : true ,
default : '' ,
displayOptions : {
show : {
resource : [
'agentGroup' ,
] ,
operation : [
'get' ,
] ,
} ,
} ,
} ,
// ----------------------------------------
// agentGroup: 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 : [
'agentGroup' ,
] ,
operation : [
'getAll' ,
] ,
} ,
} ,
} ,
{
displayName : 'Limit' ,
name : 'limit' ,
type : 'number' ,
default : 50 ,
2022-05-06 14:01:25 -07:00
description : 'Max number of results to return' ,
2021-09-05 10:24:56 -07:00
typeOptions : {
minValue : 1 ,
} ,
displayOptions : {
show : {
resource : [
'agentGroup' ,
] ,
operation : [
'getAll' ,
] ,
returnAll : [
false ,
] ,
} ,
} ,
} ,
// ----------------------------------------
// agentGroup: update
// ----------------------------------------
{
displayName : 'Agent Group ID' ,
name : 'agentGroupId' ,
description : 'ID of the agent group to update' ,
type : 'string' ,
required : true ,
default : '' ,
displayOptions : {
show : {
resource : [
'agentGroup' ,
] ,
operation : [
'update' ,
] ,
} ,
} ,
} ,
{
displayName : 'Update Fields' ,
name : 'updateFields' ,
type : 'collection' ,
placeholder : 'Add Field' ,
default : { } ,
displayOptions : {
show : {
resource : [
'agentGroup' ,
] ,
operation : [
'update' ,
] ,
} ,
} ,
options : [
{
displayName : 'Description' ,
name : 'description' ,
type : 'string' ,
default : '' ,
} ,
{
2022-06-03 10:23:49 -07:00
displayName : 'Escalate to Agent Name or ID' ,
2021-09-05 10:24:56 -07:00
name : 'escalate_to' ,
type : 'options' ,
default : '' ,
2022-07-14 13:05:11 -07:00
description : 'ID of the agent to whom an escalation email is sent if a ticket in this group is unassigned. Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>.' ,
2021-09-05 10:24:56 -07:00
typeOptions : {
2021-12-03 00:44:16 -08:00
loadOptionsMethod : 'getAgents' ,
2021-09-05 10:24:56 -07:00
} ,
} ,
{
2022-06-20 07:54:01 -07:00
displayName : 'Member Names or IDs' ,
2021-09-05 10:24:56 -07:00
name : 'members' ,
type : 'multiOptions' ,
default : [ ] ,
2022-07-14 13:05:11 -07:00
description : 'Comma-separated IDs of agents who are members of this group. Choose from the list or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>. Choose from the list, or specify IDs using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>.' ,
2021-09-05 10:24:56 -07:00
typeOptions : {
2021-12-03 00:44:16 -08:00
loadOptionsMethod : 'getAgents' ,
2021-09-05 10:24:56 -07:00
} ,
} ,
{
displayName : 'Name' ,
name : 'name' ,
type : 'string' ,
default : '' ,
} ,
{
2022-06-20 07:54:01 -07:00
displayName : 'Observer Names or IDs' ,
2021-09-05 10:24:56 -07:00
name : 'observers' ,
type : 'multiOptions' ,
default : [ ] ,
2022-07-14 13:05:11 -07:00
description : 'Comma-separated agent user IDs who are observers of this group. Choose from the list or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>. Choose from the list, or specify IDs using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>.' ,
2021-09-05 10:24:56 -07:00
typeOptions : {
2021-12-03 00:44:16 -08:00
loadOptionsMethod : 'getAgents' ,
2021-09-05 10:24:56 -07:00
} ,
} ,
{
displayName : 'Unassigned For' ,
name : 'unassigned_for' ,
description : 'Time after which an escalation email is sent if a ticket in the group remains unassigned' ,
type : 'options' ,
default : '30m' ,
options : [
{
2022-06-03 10:23:49 -07:00
name : '1 Day' ,
value : '1d' ,
2021-09-05 10:24:56 -07:00
} ,
{
name : '1 Hour' ,
value : '1h' ,
} ,
{
name : '12 Hours' ,
value : '12h' ,
} ,
{
name : '2 Days' ,
value : '2d' ,
} ,
2022-06-03 10:23:49 -07:00
{
name : '2 Hours' ,
value : '2h' ,
} ,
2021-09-05 10:24:56 -07:00
{
name : '3 Days' ,
value : '3d' ,
} ,
2022-06-03 10:23:49 -07:00
{
name : '30 Minutes' ,
value : '30m' ,
} ,
{
name : '8 Hours' ,
value : '8h' ,
} ,
2021-09-05 10:24:56 -07:00
] ,
} ,
] ,
} ,
2021-12-03 00:44:16 -08:00
] ;