n8n/packages/nodes-base/nodes/Paddle/PaymentDescription.ts
Rupenieks 72102faed5
Add Paddle Integration (#726)
* 🚧 Resource descriptions

* 🚧 Node logic / Genericfunctions setup

* 🚧 Tests / changes

* 🚧 Changes

- Added loadOptions to Payments / Coupon properties for easier item selection
- Added exemptions for how data is returned due to inconsistent data return object from API
- Other small fixes in main node

* 🚧 Simplified HTTPS error response

* 🚧 Added RAW Data options

* 🔥 Removed order resource

- Cannot fetch order without a checkout ID, which can only be obtained via a custom implementation which involves a callback function when a user goes through their checkout process.

*  Improvement to Paddle-Node

*  Improvements

*  Added all currencies, discount grouped properties to coupon update

Co-authored-by: ricardo <ricardoespinoza105@gmail.com>
2020-08-25 10:50:39 +02:00

249 lines
4.5 KiB
TypeScript

import {
INodeProperties,
} from 'n8n-workflow';
export const paymentOperations = [
{
displayName: 'Operation',
name: 'operation',
type: 'options',
displayOptions: {
show: {
resource: [
'payment',
],
},
},
options: [
{
name: 'Get All',
value: 'getAll',
description: 'Get all payment.',
},
{
name: 'Reschedule',
value: 'reschedule',
description: 'Reschedule payment.',
}
],
default: 'getAll',
description: 'The operation to perform.',
},
] as INodeProperties[];
export const paymentFields = [
/* -------------------------------------------------------------------------- */
/* payment:getAll */
/* -------------------------------------------------------------------------- */
{
displayName: 'Return All',
name: 'returnAll',
type: 'boolean',
displayOptions: {
show: {
operation: [
'getAll',
],
resource: [
'payment',
],
},
},
default: false,
description: 'If all results should be returned or only up to a given limit.',
},
{
displayName: 'Limit',
name: 'limit',
type: 'number',
displayOptions: {
show: {
operation: [
'getAll',
],
resource: [
'payment',
],
returnAll: [
false,
],
},
},
typeOptions: {
minValue: 1,
maxValue: 500,
},
default: 100,
description: 'How many results to return.',
},
{
displayName: 'JSON Parameters',
name: 'jsonParameters',
type: 'boolean',
default: false,
description: '',
displayOptions: {
show: {
resource: [
'payment',
],
operation: [
'getAll',
],
},
},
},
{
displayName: ' Additional Fields',
name: 'additionalFieldsJson',
type: 'json',
typeOptions: {
alwaysOpenEditWindow: true,
},
default: '',
displayOptions: {
show: {
resource: [
'payment',
],
operation: [
'getAll',
],
jsonParameters: [
true,
],
},
},
description: `Attributes in JSON form.`,
},
{
displayName: 'Additional Fields',
name: 'additionalFields',
type: 'collection',
placeholder: 'Add Field',
displayOptions: {
show: {
resource: [
'payment',
],
operation: [
'getAll',
],
jsonParameters: [
false
]
},
},
default: {},
options: [
{
displayName: 'Date From',
name: 'from',
type: 'dateTime',
default: '',
description: 'payment starting from date.',
},
{
displayName: 'Date To',
name: 'to',
type: 'dateTime',
default: '',
description: 'payment up until date.',
},
{
displayName: 'Is Paid',
name: 'isPaid',
type: 'boolean',
default: false,
description: 'payment is paid.',
},
{
displayName: 'Plan ID',
name: 'plan',
type: 'string',
default: '',
description: 'Filter: The product/plan ID (single or comma-separated values).',
},
{
displayName: 'Subscription ID',
name: 'subscriptionId',
type: 'number',
default: '',
description: 'A specific user subscription ID.',
},
{
displayName: 'State',
name: 'state',
type: 'options',
default: 'active',
description: 'Filter: The user subscription status. Returns all active, past_due, trialing and paused subscription plans if not specified.',
options: [
{
name: 'Active',
value: 'active'
},
{
name: 'Past Due',
value: 'past_due'
},
{
name: 'Paused',
value: 'paused'
},
{
name: 'Trialing',
value: 'trialing'
},
]
},
{
displayName: 'One off charge',
name: 'isOneOffCharge',
type: 'boolean',
default: false,
},
],
},
/* -------------------------------------------------------------------------- */
/* payment:reschedule */
/* -------------------------------------------------------------------------- */
{
displayName: 'Payment ID',
name: 'paymentId',
type: 'options',
typeOptions: {
loadOptionsMethod: 'getpayment',
},
default: '',
required: true,
displayOptions: {
show: {
resource: [
'payment',
],
operation: [
'reschedule',
],
},
},
description: 'The upcoming subscription payment ID.',
},
{
displayName: 'Date',
name: 'date',
type: 'dateTime',
default: '',
displayOptions: {
show: {
resource: [
'payment',
],
operation: [
'reschedule',
],
},
},
description: 'Date you want to move the payment to.',
},
] as INodeProperties[];