import { INodeProperties, } from 'n8n-workflow'; export const entryOperations = [ { displayName: 'Operation', name: 'operation', type: 'options', displayOptions: { show: { resource: [ 'entry', ], }, }, options: [ { name: 'Create', value: 'create', description: 'Create an entry', }, { name: 'Delete', value: 'delete', description: 'Delete an entry', }, { name: 'Get', value: 'get', description: 'Get an entry', }, { name: 'Get All', value: 'getAll', description: 'Get all entries', }, { name: 'Update', value: 'update', description: 'Update an entry', }, ], default: 'get', description: 'The operation to perform.', }, ] as INodeProperties[]; export const entryFields = [ /* -------------------------------------------------------------------------- */ /* entry:create */ /* -------------------------------------------------------------------------- */ { displayName: 'Content Type', name: 'contentType', type: 'string', default: '', required: true, displayOptions: { show: { resource: [ 'entry', ], operation: [ 'create', ], }, }, description: 'Name of the content type.', }, { displayName: 'Columns', name: 'columns', type: 'string', displayOptions: { show: { resource: [ 'entry', ], operation: [ 'create', ], }, }, default: '', placeholder: 'id,name,description', description: 'Comma separated list of the properties which should used as columns for the new rows.', }, /* -------------------------------------------------------------------------- */ /* entry:delete */ /* -------------------------------------------------------------------------- */ { displayName: 'Content Type', name: 'contentType', type: 'string', default: '', required: true, displayOptions: { show: { resource: [ 'entry', ], operation: [ 'delete', ], }, }, description: 'Name of the content type.', }, { displayName: 'Entry ID', name: 'entryId', type: 'string', default: '', required: true, displayOptions: { show: { resource: [ 'entry', ], operation: [ 'delete', ], }, }, description: 'The ID of the entry to delete.', }, /* -------------------------------------------------------------------------- */ /* entry:get */ /* -------------------------------------------------------------------------- */ { displayName: 'Content Type', name: 'contentType', type: 'string', default: '', required: true, displayOptions: { show: { resource: [ 'entry', ], operation: [ 'get', ], }, }, description: 'Name of the content type.', }, { displayName: 'Entry ID', name: 'entryId', type: 'string', default: '', required: true, displayOptions: { show: { resource: [ 'entry', ], operation: [ 'get', ], }, }, description: 'The ID of the entry to get.', }, /* -------------------------------------------------------------------------- */ /* entry:getAll */ /* -------------------------------------------------------------------------- */ { displayName: 'Content Type', name: 'contentType', type: 'string', default: '', required: true, displayOptions: { show: { resource: [ 'entry', ], operation: [ 'getAll', ], }, }, description: 'Name of the content type', }, { displayName: 'Return All', name: 'returnAll', type: 'boolean', displayOptions: { show: { resource: [ 'entry', ], operation: [ 'getAll', ], }, }, default: false, description: 'Returns a list of your user contacts.', }, { displayName: 'Limit', name: 'limit', type: 'number', displayOptions: { show: { resource: [ 'entry', ], operation: [ 'getAll', ], returnAll: [ false, ], }, }, typeOptions: { minValue: 1, maxValue: 100, }, default: 50, description: 'How many results to return.', }, { displayName: 'Options', name: 'options', type: 'collection', placeholder: 'Add Field', default: {}, displayOptions: { show: { resource: [ 'entry', ], operation: [ 'getAll', ], }, }, options: [ { displayName: 'Publication State', name: 'publicationState', type: 'options', options: [ { name: 'Live', value: 'live', }, { name: 'Preview', value: 'preview', }, ], default: '', description: 'Only select entries matching the publication state provided.', }, { displayName: 'Sort Fields', name: 'sort', type: 'string', typeOptions: { multipleValues: true, multipleValueButtonText: 'Add Sort Field', }, default: '', placeholder: 'name:asc', description: `Name of the fields to sort the data by. By default will be sorted ascendingly.<br> To modify that behavior, you have to add the sort direction after the name of sort field preceded by a colon. For example: name:asc`, }, { displayName: 'Where (JSON)', name: 'where', type: 'string', typeOptions: { alwaysOpenEditWindow: true, }, default: '', description: 'JSON query to filter the data. <a href="https://strapi.io/documentation/developer-docs/latest/developer-resources/content-api/content-api.html#filters">More info</a>.', }, ], }, /* -------------------------------------------------------------------------- */ /* entry:update */ /* -------------------------------------------------------------------------- */ { displayName: 'Content Type', name: 'contentType', type: 'string', default: '', required: true, displayOptions: { show: { resource: [ 'entry', ], operation: [ 'update', ], }, }, description: 'Name of the content type.', }, { displayName: 'Update Key', name: 'updateKey', type: 'string', displayOptions: { show: { resource: [ 'entry', ], operation: [ 'update', ], }, }, default: 'id', required: true, description: 'Name of the property which decides which rows in the database should be updated. Normally that would be "id".', }, { displayName: 'Columns', name: 'columns', type: 'string', displayOptions: { show: { resource: [ 'entry', ], operation: [ 'update', ], }, }, default: '', placeholder: 'id,name,description', description: 'Comma separated list of the properties which should used as columns for the new rows.', }, ] as INodeProperties[];