2021-02-22 04:11:51 -08:00
import {
INodeProperties ,
} from 'n8n-workflow' ;
2021-12-03 00:44:16 -08:00
export const collectionOperations : INodeProperties [ ] = [
2021-02-22 04:11:51 -08:00
{
displayName : 'Operation' ,
name : 'operation' ,
type : 'options' ,
2022-05-20 14:47:24 -07:00
noDataExpression : true ,
2021-02-22 04:11:51 -08:00
default : 'get' ,
options : [
{
name : 'Create' ,
value : 'create' ,
2022-07-10 13:50:51 -07:00
action : 'Create a collection' ,
2021-02-22 04:11:51 -08:00
} ,
{
name : 'Delete' ,
value : 'delete' ,
2022-07-10 13:50:51 -07:00
action : 'Delete a collection' ,
2021-02-22 04:11:51 -08:00
} ,
{
name : 'Get' ,
value : 'get' ,
2022-07-10 13:50:51 -07:00
action : 'Get a collection' ,
2021-02-22 04:11:51 -08:00
} ,
{
name : 'Get All' ,
value : 'getAll' ,
2022-07-10 13:50:51 -07:00
action : 'Get all collections' ,
2021-02-22 04:11:51 -08:00
} ,
{
name : 'Update' ,
value : 'update' ,
2022-07-10 13:50:51 -07:00
action : 'Update a collection' ,
2021-02-22 04:11:51 -08:00
} ,
] ,
displayOptions : {
show : {
resource : [
'collection' ,
] ,
} ,
} ,
} ,
2021-12-03 00:44:16 -08:00
] ;
2021-02-22 04:11:51 -08:00
2021-12-03 00:44:16 -08:00
export const collectionFields : INodeProperties [ ] = [
2021-02-22 04:11:51 -08:00
// ----------------------------------
// collection: create
// ----------------------------------
{
displayName : 'Title' ,
name : 'title' ,
type : 'string' ,
required : true ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'Title of the collection to create' ,
2021-02-22 04:11:51 -08:00
displayOptions : {
show : {
resource : [
'collection' ,
] ,
operation : [
'create' ,
] ,
} ,
} ,
} ,
{
displayName : 'Additional Fields' ,
name : 'additionalFields' ,
type : 'collection' ,
placeholder : 'Add Field' ,
default : { } ,
displayOptions : {
show : {
resource : [
'collection' ,
] ,
operation : [
'create' ,
] ,
} ,
} ,
options : [
{
displayName : 'Cover' ,
name : 'cover' ,
type : 'string' ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'URL of an image to use as cover for the collection' ,
2021-02-22 04:11:51 -08:00
} ,
{
displayName : 'Public' ,
name : 'public' ,
type : 'boolean' ,
default : false ,
2022-05-06 14:01:25 -07:00
description : 'Whether the collection will be accessible without authentication' ,
2021-02-22 04:11:51 -08:00
} ,
{
displayName : 'Parent ID' ,
name : 'parentId' ,
type : 'string' ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'ID of this collection\'s parent collection, if it is a child collection' ,
2021-02-22 04:11:51 -08:00
} ,
{
displayName : 'Sort Order' ,
name : 'sort' ,
type : 'number' ,
default : 1 ,
2021-11-25 09:10:06 -08:00
description : 'Descending sort order of this collection. The number is the position of the collection among all the collections with the same parent ID.' ,
2021-02-22 04:11:51 -08:00
} ,
{
displayName : 'View' ,
name : 'view' ,
type : 'options' ,
default : 'list' ,
2022-05-06 14:01:25 -07:00
description : 'View style of this collection' ,
2021-02-22 04:11:51 -08:00
options : [
{
name : 'List' ,
value : 'list' ,
} ,
{
name : 'Simple' ,
value : 'simple' ,
} ,
{
name : 'Grid' ,
value : 'grid' ,
} ,
{
name : 'Masonry' ,
value : 'Masonry' ,
} ,
] ,
} ,
] ,
} ,
// ----------------------------------
// collection: delete
// ----------------------------------
{
displayName : 'Collection ID' ,
name : 'collectionId' ,
type : 'string' ,
default : '' ,
required : true ,
2022-05-06 14:01:25 -07:00
description : 'The ID of the collection to delete' ,
2021-02-22 04:11:51 -08:00
displayOptions : {
show : {
resource : [
'collection' ,
] ,
operation : [
'delete' ,
] ,
} ,
} ,
} ,
// ----------------------------------
// collection: get
// ----------------------------------
{
displayName : 'Collection ID' ,
name : 'collectionId' ,
type : 'string' ,
default : '' ,
required : true ,
2022-05-06 14:01:25 -07:00
description : 'The ID of the collection to retrieve' ,
2021-02-22 04:11:51 -08:00
displayOptions : {
show : {
resource : [
'collection' ,
] ,
operation : [
'get' ,
] ,
} ,
} ,
} ,
// ----------------------------------
// collection: getAll
// ----------------------------------
{
displayName : 'Type' ,
name : 'type' ,
type : 'options' ,
required : true ,
default : 'parent' ,
displayOptions : {
show : {
resource : [
'collection' ,
] ,
operation : [
'getAll' ,
] ,
} ,
} ,
options : [
{
name : 'Parent' ,
value : 'parent' ,
2022-05-06 14:01:25 -07:00
description : 'Root-level collections' ,
2021-02-22 04:11:51 -08:00
} ,
{
name : 'Children' ,
value : 'children' ,
2022-05-06 14:01:25 -07:00
description : 'Nested collections' ,
2021-02-22 04:11:51 -08:00
} ,
] ,
} ,
{
displayName : 'Return All' ,
name : 'returnAll' ,
type : 'boolean' ,
displayOptions : {
show : {
resource : [
'collection' ,
] ,
operation : [
'getAll' ,
] ,
} ,
} ,
default : false ,
2022-05-06 14:01:25 -07:00
description : 'Whether to return all results or only up to a given limit' ,
2021-02-22 04:11:51 -08:00
} ,
{
displayName : 'Limit' ,
name : 'limit' ,
type : 'number' ,
displayOptions : {
show : {
resource : [
'collection' ,
] ,
operation : [
'getAll' ,
] ,
returnAll : [
false ,
] ,
} ,
} ,
typeOptions : {
minValue : 1 ,
maxValue : 10 ,
} ,
default : 5 ,
2022-05-06 14:01:25 -07:00
description : 'Max number of results to return' ,
2021-02-22 04:11:51 -08:00
} ,
// ----------------------------------
// collection: update
// ----------------------------------
{
displayName : 'Collection ID' ,
name : 'collectionId' ,
type : 'string' ,
default : '' ,
required : true ,
2022-05-06 14:01:25 -07:00
description : 'The ID of the collection to update' ,
2021-02-22 04:11:51 -08:00
displayOptions : {
show : {
resource : [
'collection' ,
] ,
operation : [
'update' ,
] ,
} ,
} ,
} ,
{
displayName : 'Update Fields' ,
name : 'updateFields' ,
type : 'collection' ,
placeholder : 'Add Field' ,
default : { } ,
displayOptions : {
show : {
resource : [
'collection' ,
] ,
operation : [
'update' ,
] ,
} ,
} ,
options : [
{
displayName : 'Cover' ,
name : 'cover' ,
type : 'string' ,
default : 'data' ,
placeholder : '' ,
2022-05-06 14:01:25 -07:00
description : 'Name of the binary property containing the data for the image to upload as a cover' ,
2021-02-22 04:11:51 -08:00
} ,
{
displayName : 'Public' ,
name : 'public' ,
type : 'boolean' ,
default : false ,
2022-05-06 14:01:25 -07:00
description : 'Whether the collection will be accessible without authentication' ,
2021-02-22 04:11:51 -08:00
} ,
{
displayName : 'Parent ID' ,
name : 'parentId' ,
type : 'string' ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'ID of this collection\'s parent collection, if it is a child collection' ,
2021-02-22 04:11:51 -08:00
} ,
{
displayName : 'Sort Order' ,
name : 'sort' ,
type : 'number' ,
default : 1 ,
2021-11-25 09:10:06 -08:00
description : 'Descending sort order of this collection. The number is the position of the collection among all the collections with the same parent ID.' ,
2021-02-22 04:11:51 -08:00
} ,
{
displayName : 'Title' ,
name : 'title' ,
type : 'string' ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'Title of the collection to update' ,
2021-02-22 04:11:51 -08:00
} ,
{
displayName : 'View' ,
name : 'view' ,
type : 'options' ,
default : 'list' ,
2022-05-06 14:01:25 -07:00
description : 'View style of this collection' ,
2021-02-22 04:11:51 -08:00
options : [
{
name : 'List' ,
value : 'list' ,
} ,
{
name : 'Simple' ,
value : 'simple' ,
} ,
{
name : 'Grid' ,
value : 'grid' ,
} ,
{
name : 'Masonry' ,
value : 'Masonry' ,
} ,
] ,
} ,
] ,
} ,
2021-12-03 00:44:16 -08:00
] ;