n8n-nodes-base 1.106.0 → 1.108.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/known/nodes.json +4 -0
- package/dist/methods/defined.json +4 -0
- package/dist/methods/referenced.json +4 -0
- package/dist/nodes/Affinity/__schema__/v1.0.0/organization/get.json +1 -4
- package/dist/nodes/Affinity/__schema__/v1.0.0/person/getAll.json +24 -0
- package/dist/nodes/Airtop/__schema__/v1.0.0/extraction/getPaginated.json +7 -1
- package/dist/nodes/Airtop/__schema__/v1.0.0/extraction/scrape.json +7 -1
- package/dist/nodes/Airtop/__schema__/v1.0.0/interaction/click.json +42 -0
- package/dist/nodes/Airtop/__schema__/v1.0.0/session/create.json +60 -1
- package/dist/nodes/Airtop/__schema__/v1.0.0/session/terminate.json +9 -0
- package/dist/nodes/Airtop/__schema__/v1.0.0/window/create.json +1 -4
- package/dist/nodes/Aws/DynamoDB/__schema__/v1.0.0/item/getAll.json +9 -0
- package/dist/nodes/BambooHr/__schema__/v1.0.0/companyReport/get.json +1 -7
- package/dist/nodes/BambooHr/__schema__/v1.0.0/employee/getAll.json +10 -1
- package/dist/nodes/Bitly/__schema__/v1.0.0/link/create.json +7 -1
- package/dist/nodes/Box/__schema__/v1.0.0/file/download.json +7 -1
- package/dist/nodes/ClickUp/__schema__/v1.0.0/folder/create.json +74 -1
- package/dist/nodes/ClickUp/__schema__/v1.0.0/list/customFields.json +26 -1
- package/dist/nodes/Coda/__schema__/v1.1.0/table/getAllRows.json +4 -1
- package/dist/nodes/Code/Code.node.d.ts.map +1 -1
- package/dist/nodes/Code/Code.node.js +3 -0
- package/dist/nodes/Code/Code.node.js.map +1 -1
- package/dist/nodes/Code/PythonTaskRunnerSandbox.d.ts.map +1 -1
- package/dist/nodes/Code/PythonTaskRunnerSandbox.js +8 -0
- package/dist/nodes/Code/PythonTaskRunnerSandbox.js.map +1 -1
- package/dist/nodes/Code/descriptions/PythonCodeDescription.js +1 -1
- package/dist/nodes/Code/descriptions/PythonCodeDescription.js.map +1 -1
- package/dist/nodes/CoinGecko/__schema__/v1.0.0/coin/candlestick.json +9 -0
- package/dist/nodes/Contentful/__schema__/v1.0.0/contentType/get.json +27 -0
- package/dist/nodes/DataTable/DataTable.node.d.ts +19 -0
- package/dist/nodes/DataTable/DataTable.node.d.ts.map +1 -0
- package/dist/nodes/DataTable/DataTable.node.js +94 -0
- package/dist/nodes/DataTable/DataTable.node.js.map +1 -0
- package/dist/nodes/DataTable/DataTable.node.json +18 -0
- package/dist/nodes/DataTable/actions/router.d.ts +3 -0
- package/dist/nodes/DataTable/actions/router.d.ts.map +1 -0
- package/dist/nodes/DataTable/actions/router.js +77 -0
- package/dist/nodes/DataTable/actions/router.js.map +1 -0
- package/dist/nodes/DataTable/actions/row/Row.resource.d.ts +9 -0
- package/dist/nodes/DataTable/actions/row/Row.resource.d.ts.map +1 -0
- package/dist/nodes/DataTable/actions/row/Row.resource.js +123 -0
- package/dist/nodes/DataTable/actions/row/Row.resource.js.map +1 -0
- package/dist/nodes/DataTable/actions/row/delete.operation.d.ts +5 -0
- package/dist/nodes/DataTable/actions/row/delete.operation.d.ts.map +1 -0
- package/dist/nodes/DataTable/actions/row/delete.operation.js +44 -0
- package/dist/nodes/DataTable/actions/row/delete.operation.js.map +1 -0
- package/dist/nodes/DataTable/actions/row/get.operation.d.ts +5 -0
- package/dist/nodes/DataTable/actions/row/get.operation.d.ts.map +1 -0
- package/dist/nodes/DataTable/actions/row/get.operation.js +19 -0
- package/dist/nodes/DataTable/actions/row/get.operation.js.map +1 -0
- package/dist/nodes/DataTable/actions/row/insert.operation.d.ts +5 -0
- package/dist/nodes/DataTable/actions/row/insert.operation.d.ts.map +1 -0
- package/dist/nodes/DataTable/actions/row/insert.operation.js +21 -0
- package/dist/nodes/DataTable/actions/row/insert.operation.js.map +1 -0
- package/dist/nodes/DataTable/actions/row/update.operation.d.ts +5 -0
- package/dist/nodes/DataTable/actions/row/update.operation.d.ts.map +1 -0
- package/dist/nodes/DataTable/actions/row/update.operation.js +41 -0
- package/dist/nodes/DataTable/actions/row/update.operation.js.map +1 -0
- package/dist/nodes/DataTable/actions/row/upsert.operation.d.ts +5 -0
- package/dist/nodes/DataTable/actions/row/upsert.operation.d.ts.map +1 -0
- package/dist/nodes/DataTable/actions/row/upsert.operation.js +47 -0
- package/dist/nodes/DataTable/actions/row/upsert.operation.js.map +1 -0
- package/dist/nodes/DataTable/common/addRow.d.ts +29 -0
- package/dist/nodes/DataTable/common/addRow.d.ts.map +1 -0
- package/dist/nodes/DataTable/common/addRow.js +54 -0
- package/dist/nodes/DataTable/common/addRow.js.map +1 -0
- package/dist/nodes/DataTable/common/constants.d.ts +13 -0
- package/dist/nodes/DataTable/common/constants.d.ts.map +1 -0
- package/dist/nodes/DataTable/common/constants.js +6 -0
- package/dist/nodes/DataTable/common/constants.js.map +1 -0
- package/dist/nodes/DataTable/common/fields.d.ts +9 -0
- package/dist/nodes/DataTable/common/fields.d.ts.map +1 -0
- package/dist/nodes/DataTable/common/fields.js +12 -0
- package/dist/nodes/DataTable/common/fields.js.map +1 -0
- package/dist/nodes/DataTable/common/methods.d.ts +8 -0
- package/dist/nodes/DataTable/common/methods.d.ts.map +1 -0
- package/dist/nodes/DataTable/common/methods.js +124 -0
- package/dist/nodes/DataTable/common/methods.js.map +1 -0
- package/dist/nodes/DataTable/common/selectMany.d.ts +7 -0
- package/dist/nodes/DataTable/common/selectMany.d.ts.map +1 -0
- package/dist/nodes/DataTable/common/selectMany.js +128 -0
- package/dist/nodes/DataTable/common/selectMany.js.map +1 -0
- package/dist/nodes/DataTable/common/utils.d.ts +11 -0
- package/dist/nodes/DataTable/common/utils.d.ts.map +1 -0
- package/dist/nodes/DataTable/common/utils.js +109 -0
- package/dist/nodes/DataTable/common/utils.js.map +1 -0
- package/dist/nodes/Dropbox/__schema__/v1.0.0/file/download.json +1 -19
- package/dist/nodes/Dropcontact/__schema__/v1.0.0/contact/enrich.json +1 -19
- package/dist/nodes/Elastic/Elasticsearch/__schema__/v1.0.0/document/getAll.json +4 -1
- package/dist/nodes/EmailSend/__schema__/v2.1.0/email/send.json +1 -7
- package/dist/nodes/Files/ExtractFromFile/actions/moveTo.operation.js +1 -1
- package/dist/nodes/Files/ExtractFromFile/actions/moveTo.operation.js.map +1 -1
- package/dist/nodes/Files/ReadWriteFile/helpers/utils.d.ts.map +1 -1
- package/dist/nodes/Files/ReadWriteFile/helpers/utils.js +18 -16
- package/dist/nodes/Files/ReadWriteFile/helpers/utils.js.map +1 -1
- package/dist/nodes/FreshworksCrm/__schema__/v1.0.0/search/query.json +35 -0
- package/dist/nodes/Github/GithubTrigger.node.js +3 -3
- package/dist/nodes/Github/GithubTrigger.node.js.map +1 -1
- package/dist/nodes/Github/__schema__/v1.1.0/file/get.json +1 -42
- package/dist/nodes/Gitlab/__schema__/v1.0.0/file/get.json +4 -1
- package/dist/nodes/Google/Analytics/__schema__/v2.0.0/report/get.json +71 -2
- package/dist/nodes/Google/Calendar/GoogleCalendar.node.js +2 -2
- package/dist/nodes/Google/Calendar/GoogleCalendar.node.js.map +1 -1
- package/dist/nodes/Google/Calendar/__schema__/v1.3.0/event/create.json +4 -1
- package/dist/nodes/Google/Calendar/__schema__/v1.3.0/event/getAll.json +1 -4
- package/dist/nodes/Google/Chat/__schema__/v1.0.0/message/create.json +30 -1
- package/dist/nodes/Google/Chat/__schema__/v1.0.0/message/get.json +1 -63
- package/dist/nodes/Google/CloudStorage/__schema__/v1.0.0/object/getAll.json +7 -1
- package/dist/nodes/Google/Contacts/__schema__/v1.0.0/contact/getAll.json +21 -1
- package/dist/nodes/Google/Drive/__schema__/v3.0.0/file/upload.json +34 -1
- package/dist/nodes/Google/Firebase/CloudFirestore/__schema__/v1.1.0/document/create.json +1 -4
- package/dist/nodes/Google/Firebase/CloudFirestore/__schema__/v1.1.0/document/getAll.json +1 -4
- package/dist/nodes/Google/GSuiteAdmin/__schema__/v1.0.0/user/get.json +1 -65
- package/dist/nodes/Google/GSuiteAdmin/__schema__/v1.0.0/user/getAll.json +1 -22
- package/dist/nodes/Google/Gmail/__schema__/v2.1.0/message/getAll.json +27 -123
- package/dist/nodes/Google/Task/__schema__/v1.0.0/task/getAll.json +4 -4
- package/dist/nodes/HighLevel/__schema__/v2.0.0/calendar/bookAppointment.json +36 -0
- package/dist/nodes/HomeAssistant/__schema__/v1.0.0/state/get.json +1 -7
- package/dist/nodes/HttpRequest/V1/HttpRequestV1.node.d.ts.map +1 -1
- package/dist/nodes/HttpRequest/V1/HttpRequestV1.node.js +31 -0
- package/dist/nodes/HttpRequest/V1/HttpRequestV1.node.js.map +1 -1
- package/dist/nodes/HttpRequest/V2/HttpRequestV2.node.d.ts.map +1 -1
- package/dist/nodes/HttpRequest/V2/HttpRequestV2.node.js +46 -0
- package/dist/nodes/HttpRequest/V2/HttpRequestV2.node.js.map +1 -1
- package/dist/nodes/HttpRequest/V3/HttpRequestV3.node.d.ts.map +1 -1
- package/dist/nodes/HttpRequest/V3/HttpRequestV3.node.js +239 -180
- package/dist/nodes/HttpRequest/V3/HttpRequestV3.node.js.map +1 -1
- package/dist/nodes/Hubspot/Hubspot.node.d.ts.map +1 -1
- package/dist/nodes/Hubspot/Hubspot.node.js +2 -1
- package/dist/nodes/Hubspot/Hubspot.node.js.map +1 -1
- package/dist/nodes/Hubspot/V2/EngagementDescription.d.ts.map +1 -1
- package/dist/nodes/Hubspot/V2/EngagementDescription.js +32 -0
- package/dist/nodes/Hubspot/V2/EngagementDescription.js.map +1 -1
- package/dist/nodes/Hubspot/V2/HubspotV2.node.d.ts.map +1 -1
- package/dist/nodes/Hubspot/V2/HubspotV2.node.js +14 -1
- package/dist/nodes/Hubspot/V2/HubspotV2.node.js.map +1 -1
- package/dist/nodes/Hubspot/V2/utils/parseToTimestamp.d.ts +2 -0
- package/dist/nodes/Hubspot/V2/utils/parseToTimestamp.d.ts.map +1 -0
- package/dist/nodes/Hubspot/V2/utils/parseToTimestamp.js +18 -0
- package/dist/nodes/Hubspot/V2/utils/parseToTimestamp.js.map +1 -0
- package/dist/nodes/Hubspot/__schema__/v2.1.0/company/getAll.json +4 -1
- package/dist/nodes/Hubspot/__schema__/v2.1.0/deal/getAll.json +1 -257
- package/dist/nodes/Hubspot/__schema__/v2.1.0/deal/search.json +10 -1
- package/dist/nodes/Hubspot/__schema__/v2.1.0/ticket/get.json +67 -1
- package/dist/nodes/Hubspot/__schema__/v2.1.0/ticket/getAll.json +61 -1
- package/dist/nodes/Jenkins/__schema__/v1.0.0/job/trigger.json +9 -0
- package/dist/nodes/Jenkins/__schema__/v1.0.0/job/triggerParams.json +9 -0
- package/dist/nodes/JinaAI/__schema__/v1.0.0/reader/read.json +9 -1
- package/dist/nodes/Jira/__schema__/v1.0.0/issue/get.json +121 -1
- package/dist/nodes/Jira/__schema__/v1.0.0/issue/getAll.json +310 -1
- package/dist/nodes/Lemlist/__schema__/v2.0.0/campaign/getStats.json +39 -0
- package/dist/nodes/Lemlist/__schema__/v2.0.0/enrich/get.json +3 -18
- package/dist/nodes/Lemlist/__schema__/v2.0.0/lead/get.json +1 -4
- package/dist/nodes/Mailchimp/__schema__/v1.0.0/member/create.json +15 -1
- package/dist/nodes/Mailchimp/__schema__/v1.0.0/member/get.json +7 -4
- package/dist/nodes/Marketstack/__schema__/v1.0.0/endOfDayData/getAll.json +1 -4
- package/dist/nodes/Matrix/__schema__/v1.0.0/message/getAll.json +4 -1
- package/dist/nodes/Metabase/__schema__/v1.0.0/databases/getAll.json +21 -0
- package/dist/nodes/Metabase/__schema__/v1.0.0/databases/getFields.json +9 -13
- package/dist/nodes/Metabase/__schema__/v1.0.0/questions/get.json +85 -12
- package/dist/nodes/Microsoft/AzureCosmosDb/__schema__/v1.0.0/item/getAll.json +12 -0
- package/dist/nodes/Microsoft/Entra/__schema__/v1.0.0/group/getAll.json +27 -0
- package/dist/nodes/Microsoft/Entra/__schema__/v1.0.0/user/create.json +13 -18
- package/dist/nodes/Microsoft/Entra/__schema__/v1.0.0/user/getAll.json +1 -4
- package/dist/nodes/Microsoft/OneDrive/__schema__/v1.0.0/file/download.json +10 -23
- package/dist/nodes/Microsoft/OneDrive/__schema__/v1.0.0/folder/create.json +15 -7
- package/dist/nodes/Microsoft/Outlook/__schema__/v2.0.0/message/get.json +39 -4
- package/dist/nodes/Microsoft/Outlook/__schema__/v2.0.0/message/getAll.json +1 -4
- package/dist/nodes/Microsoft/Outlook/__schema__/v2.0.0/messageAttachment/get.json +1 -25
- package/dist/nodes/Microsoft/SharePoint/__schema__/v1.0.0/item/get.json +71 -0
- package/dist/nodes/Microsoft/SharePoint/__schema__/v1.0.0/item/getAll.json +1 -70
- package/dist/nodes/Microsoft/SharePoint/__schema__/v1.0.0/list/get.json +27 -0
- package/dist/nodes/Microsoft/SharePoint/__schema__/v1.0.0/list/getAll.json +27 -0
- package/dist/nodes/Microsoft/Sql/MicrosoftSql.node.js +1 -1
- package/dist/nodes/Microsoft/Sql/MicrosoftSql.node.js.map +1 -1
- package/dist/nodes/Microsoft/ToDo/__schema__/v1.0.0/task/getAll.json +18 -1
- package/dist/nodes/N8nTrainingCustomerDatastore/__schema__/v1.0.0/execution/get.json +1 -4
- package/dist/nodes/N8nTrainingCustomerDatastore/__schema__/v1.0.0/execution/getAll.json +1 -4
- package/dist/nodes/N8nTrainingCustomerDatastore/__schema__/v1.0.0/workflow/create.json +10 -1
- package/dist/nodes/Nasa/__schema__/v1.0.0/donkiSolarFlare/get.json +1 -7
- package/dist/nodes/NextCloud/__schema__/v1.0.0/file/download.json +2 -32
- package/dist/nodes/Odoo/__schema__/v1.0.0/contact/get.json +1 -4
- package/dist/nodes/Odoo/__schema__/v1.0.0/opportunity/getAll.json +4 -1
- package/dist/nodes/Okta/__schema__/v1.0.0/user/getAll.json +1 -37
- package/dist/nodes/Perplexity/__schema__/v1.0.0/chat/complete.json +12 -1
- package/dist/nodes/Phantombuster/__schema__/v1.0.0/agent/getOutput.json +1 -10
- package/dist/nodes/Reddit/__schema__/v1.0.0/post/getAll.json +78 -4
- package/dist/nodes/RenameKeys/RenameKeys.node.d.ts.map +1 -1
- package/dist/nodes/RenameKeys/RenameKeys.node.js +37 -18
- package/dist/nodes/RenameKeys/RenameKeys.node.js.map +1 -1
- package/dist/nodes/RespondToWebhook/RespondToWebhook.node.d.ts.map +1 -1
- package/dist/nodes/RespondToWebhook/RespondToWebhook.node.js +1 -15
- package/dist/nodes/RespondToWebhook/RespondToWebhook.node.js.map +1 -1
- package/dist/nodes/RespondToWebhook/utils/binary.d.ts +1 -1
- package/dist/nodes/RespondToWebhook/utils/binary.d.ts.map +1 -1
- package/dist/nodes/RespondToWebhook/utils/binary.js +2 -17
- package/dist/nodes/RespondToWebhook/utils/binary.js.map +1 -1
- package/dist/nodes/S3/__schema__/v1.0.0/file/download.json +10 -1
- package/dist/nodes/Salesforce/__schema__/v1.0.0/case/getAll.json +4 -1
- package/dist/nodes/Salesforce/__schema__/v1.0.0/customObject/create.json +15 -1
- package/dist/nodes/Salesforce/__schema__/v1.0.0/customObject/getAll.json +4 -1
- package/dist/nodes/Salesforce/__schema__/v1.0.0/customObject/upsert.json +4 -4
- package/dist/nodes/Salesforce/__schema__/v1.0.0/opportunity/getAll.json +5 -2
- package/dist/nodes/Salesforce/__schema__/v1.0.0/task/getAll.json +10 -4
- package/dist/nodes/Salesforce/__schema__/v1.0.0/user/getAll.json +1 -4
- package/dist/nodes/SeaTable/__schema__/v2.0.0/row/create.json +24 -0
- package/dist/nodes/Shopify/__schema__/v1.0.0/order/getAll.json +4 -45
- package/dist/nodes/Shopify/__schema__/v1.0.0/product/get.json +1 -4
- package/dist/nodes/Slack/SlackTrigger.node.d.ts.map +1 -1
- package/dist/nodes/Slack/SlackTrigger.node.js +2 -1
- package/dist/nodes/Slack/SlackTrigger.node.js.map +1 -1
- package/dist/nodes/Slack/V2/MessageDescription.js +1 -1
- package/dist/nodes/Slack/V2/MessageDescription.js.map +1 -1
- package/dist/nodes/Slack/__schema__/v2.3.0/channel/history.json +3 -3
- package/dist/nodes/Slack/__schema__/v2.3.0/channel/join.json +2 -174
- package/dist/nodes/Slack/__schema__/v2.3.0/channel/replies.json +44 -4
- package/dist/nodes/Stripe/__schema__/v1.0.0/balance/get.json +34 -1
- package/dist/nodes/Telegram/Telegram.node.js +1 -1
- package/dist/nodes/Telegram/Telegram.node.js.map +1 -1
- package/dist/nodes/Telegram/__schema__/v1.2.0/chat/get.json +1 -4
- package/dist/nodes/Telegram/__schema__/v1.2.0/chat/member.json +4 -4
- package/dist/nodes/Telegram/__schema__/v1.2.0/message/editMessageText.json +4 -1
- package/dist/nodes/Telegram/__schema__/v1.2.0/message/sendMessage.json +1 -12
- package/dist/nodes/Trello/__schema__/v1.0.0/attachment/get.json +4 -1
- package/dist/nodes/Trello/__schema__/v1.0.0/label/getAll.json +18 -0
- package/dist/nodes/Trello/__schema__/v1.0.0/list/getAll.json +1 -4
- package/dist/nodes/Trello/__schema__/v1.0.0/list/getCards.json +11 -2
- package/dist/nodes/Twilio/__schema__/v1.0.0/sms/send.json +7 -1
- package/dist/nodes/Wise/__schema__/v1.0.0/exchangeRate/get.json +4 -1
- package/dist/nodes/Wordpress/__schema__/v1.0.0/post/getAll.json +15 -1
- package/dist/nodes/Xero/__schema__/v1.0.0/contact/getAll.json +1 -4
- package/dist/nodes/Zoho/__schema__/v1.0.0/contact/getAll.json +15 -14
- package/dist/nodes/Zoho/__schema__/v1.0.0/lead/getAll.json +10 -32
- package/dist/typecheck.tsbuildinfo +1 -1
- package/dist/types/nodes.json +10 -9
- package/package.json +7 -6
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"addRow.d.ts","sourceRoot":"","sources":["../../../../nodes/DataTable/common/addRow.ts"],"names":[],"mappings":"AAAA,OAAO,EAGN,KAAK,eAAe,EACpB,KAAK,iBAAiB,EAEtB,MAAM,cAAc,CAAC;AAKtB,wBAAgB,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,cAAc,EAAE,eAAe;;;;;;;;;;;;;;;;;;;;;;;;;EA2B5E;AAED,wBAAgB,SAAS,CAAC,GAAG,EAAE,iBAAiB,EAAE,KAAK,EAAE,MAAM,gEAoB9D"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.makeAddRow = makeAddRow;
|
|
4
|
+
exports.getAddRow = getAddRow;
|
|
5
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
6
|
+
const fields_1 = require("./fields");
|
|
7
|
+
const utils_1 = require("./utils");
|
|
8
|
+
function makeAddRow(operation, displayOptions) {
|
|
9
|
+
return {
|
|
10
|
+
displayName: 'Columns',
|
|
11
|
+
name: 'columns',
|
|
12
|
+
type: 'resourceMapper',
|
|
13
|
+
default: {
|
|
14
|
+
mappingMode: 'defineBelow',
|
|
15
|
+
value: null,
|
|
16
|
+
},
|
|
17
|
+
noDataExpression: true,
|
|
18
|
+
required: true,
|
|
19
|
+
typeOptions: {
|
|
20
|
+
loadOptionsDependsOn: [`${fields_1.DATA_TABLE_ID_FIELD}.value`],
|
|
21
|
+
resourceMapper: {
|
|
22
|
+
valuesLabel: `Columns to ${operation}`,
|
|
23
|
+
resourceMapperMethod: 'getDataTables',
|
|
24
|
+
mode: 'add',
|
|
25
|
+
fieldWords: {
|
|
26
|
+
singular: 'column',
|
|
27
|
+
plural: 'columns',
|
|
28
|
+
},
|
|
29
|
+
addAllFields: true,
|
|
30
|
+
multiKeyMatch: true,
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
displayOptions,
|
|
34
|
+
};
|
|
35
|
+
}
|
|
36
|
+
function getAddRow(ctx, index) {
|
|
37
|
+
const items = ctx.getInputData();
|
|
38
|
+
const dataMode = ctx.getNodeParameter('columns.mappingMode', index);
|
|
39
|
+
let data;
|
|
40
|
+
if (dataMode === 'autoMapInputData') {
|
|
41
|
+
data = { ...items[index].json };
|
|
42
|
+
// We automatically remove our system columns for better UX when feeding Data Table outputs
|
|
43
|
+
// into another Data Table node
|
|
44
|
+
for (const systemColumn of n8n_workflow_1.DATA_TABLE_SYSTEM_COLUMNS) {
|
|
45
|
+
delete data[systemColumn];
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
const fields = ctx.getNodeParameter('columns.value', index, {});
|
|
50
|
+
data = fields;
|
|
51
|
+
}
|
|
52
|
+
return (0, utils_1.dataObjectToApiInput)(data, ctx.getNode(), index);
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=addRow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"addRow.js","sourceRoot":"","sources":["../../../../nodes/DataTable/common/addRow.ts"],"names":[],"mappings":";;AAWA,gCA2BC;AAED,8BAoBC;AA5DD,+CAMsB;AAEtB,qCAA+C;AAC/C,mCAA+C;AAE/C,SAAgB,UAAU,CAAC,SAAiB,EAAE,cAA+B;IAC5E,OAAO;QACN,WAAW,EAAE,SAAS;QACtB,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,gBAAgB;QACtB,OAAO,EAAE;YACR,WAAW,EAAE,aAAa;YAC1B,KAAK,EAAE,IAAI;SACX;QACD,gBAAgB,EAAE,IAAI;QACtB,QAAQ,EAAE,IAAI;QACd,WAAW,EAAE;YACZ,oBAAoB,EAAE,CAAC,GAAG,4BAAmB,QAAQ,CAAC;YACtD,cAAc,EAAE;gBACf,WAAW,EAAE,cAAc,SAAS,EAAE;gBACtC,oBAAoB,EAAE,eAAe;gBACrC,IAAI,EAAE,KAAK;gBACX,UAAU,EAAE;oBACX,QAAQ,EAAE,QAAQ;oBAClB,MAAM,EAAE,SAAS;iBACjB;gBACD,YAAY,EAAE,IAAI;gBAClB,aAAa,EAAE,IAAI;aACnB;SACD;QACD,cAAc;KACY,CAAC;AAC7B,CAAC;AAED,SAAgB,SAAS,CAAC,GAAsB,EAAE,KAAa;IAC9D,MAAM,KAAK,GAAG,GAAG,CAAC,YAAY,EAAE,CAAC;IACjC,MAAM,QAAQ,GAAG,GAAG,CAAC,gBAAgB,CAAC,qBAAqB,EAAE,KAAK,CAAW,CAAC;IAE9E,IAAI,IAAiB,CAAC;IAEtB,IAAI,QAAQ,KAAK,kBAAkB,EAAE,CAAC;QACrC,IAAI,GAAG,EAAE,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,CAAC;QAChC,2FAA2F;QAC3F,+BAA+B;QAC/B,KAAK,MAAM,YAAY,IAAI,wCAAyB,EAAE,CAAC;YACtD,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC;QAC3B,CAAC;IACF,CAAC;SAAM,CAAC;QACP,MAAM,MAAM,GAAG,GAAG,CAAC,gBAAgB,CAAC,eAAe,EAAE,KAAK,EAAE,EAAE,CAAgB,CAAC;QAE/E,IAAI,GAAG,MAAM,CAAC;IACf,CAAC;IAED,OAAO,IAAA,4BAAoB,EAAC,IAAI,EAAE,GAAG,CAAC,OAAO,EAAE,EAAE,KAAK,CAAC,CAAC;AACzD,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { DataStoreColumnJsType } from 'n8n-workflow';
|
|
2
|
+
export declare const ANY_CONDITION = "anyCondition";
|
|
3
|
+
export declare const ALL_CONDITIONS = "allConditions";
|
|
4
|
+
export type FilterType = typeof ANY_CONDITION | typeof ALL_CONDITIONS;
|
|
5
|
+
export type FieldEntry = {
|
|
6
|
+
keyName: string;
|
|
7
|
+
condition: 'isEmpty' | 'isNotEmpty';
|
|
8
|
+
} | {
|
|
9
|
+
keyName: string;
|
|
10
|
+
condition: 'eq' | 'neq' | 'like' | 'ilike' | 'gt' | 'gte' | 'lt' | 'lte';
|
|
11
|
+
keyValue: DataStoreColumnJsType;
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=constants.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../../nodes/DataTable/common/constants.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AAE1D,eAAO,MAAM,aAAa,iBAAiB,CAAC;AAC5C,eAAO,MAAM,cAAc,kBAAkB,CAAC;AAE9C,MAAM,MAAM,UAAU,GAAG,OAAO,aAAa,GAAG,OAAO,cAAc,CAAC;AAEtE,MAAM,MAAM,UAAU,GACnB;IACA,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,SAAS,GAAG,YAAY,CAAC;CACnC,GACD;IACA,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,IAAI,GAAG,KAAK,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,GAAG,KAAK,GAAG,IAAI,GAAG,KAAK,CAAC;IACzE,QAAQ,EAAE,qBAAqB,CAAC;CAC/B,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../nodes/DataTable/common/constants.ts"],"names":[],"mappings":";;;AAEa,QAAA,aAAa,GAAG,cAAc,CAAC;AAC/B,QAAA,cAAc,GAAG,eAAe,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fields.d.ts","sourceRoot":"","sources":["../../../../nodes/DataTable/common/fields.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,mBAAmB,gBAAgB,CAAC;AAEjD,eAAO,MAAM,OAAO;;;;;;CAOO,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DRY_RUN = exports.DATA_TABLE_ID_FIELD = void 0;
|
|
4
|
+
exports.DATA_TABLE_ID_FIELD = 'dataTableId';
|
|
5
|
+
exports.DRY_RUN = {
|
|
6
|
+
displayName: 'Dry Run',
|
|
7
|
+
name: 'dryRun',
|
|
8
|
+
type: 'boolean',
|
|
9
|
+
default: false,
|
|
10
|
+
description: 'Whether the operation should only be simulated, returning the rows that would have been affected',
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=fields.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fields.js","sourceRoot":"","sources":["../../../../nodes/DataTable/common/fields.ts"],"names":[],"mappings":";;;AAEa,QAAA,mBAAmB,GAAG,aAAa,CAAC;AAEpC,QAAA,OAAO,GAAG;IACtB,WAAW,EAAE,SAAS;IACtB,IAAI,EAAE,QAAQ;IACd,IAAI,EAAE,SAAS;IACf,OAAO,EAAE,KAAK;IACd,WAAW,EACV,kGAAkG;CACzE,CAAC"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { ILoadOptionsFunctions, INodeListSearchResult, INodePropertyOptions, ResourceMapperFields } from 'n8n-workflow';
|
|
2
|
+
export declare function tableSearch(this: ILoadOptionsFunctions, filterString?: string, prevPaginationToken?: string): Promise<INodeListSearchResult>;
|
|
3
|
+
export declare function getDataTableColumns(this: ILoadOptionsFunctions): Promise<(INodePropertyOptions & {
|
|
4
|
+
type: string;
|
|
5
|
+
})[]>;
|
|
6
|
+
export declare function getConditionsForColumn(this: ILoadOptionsFunctions): Promise<INodePropertyOptions[]>;
|
|
7
|
+
export declare function getDataTables(this: ILoadOptionsFunctions): Promise<ResourceMapperFields>;
|
|
8
|
+
//# sourceMappingURL=methods.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"methods.d.ts","sourceRoot":"","sources":["../../../../nodes/DataTable/common/methods.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACX,qBAAqB,EACrB,qBAAqB,EACrB,oBAAoB,EAEpB,oBAAoB,EACpB,MAAM,cAAc,CAAC;AAKtB,wBAAsB,WAAW,CAChC,IAAI,EAAE,qBAAqB,EAC3B,YAAY,CAAC,EAAE,MAAM,EACrB,mBAAmB,CAAC,EAAE,MAAM,GAC1B,OAAO,CAAC,qBAAqB,CAAC,CA0BhC;AAED,wBAAsB,mBAAmB,CAAC,IAAI,EAAE,qBAAqB;UACb,MAAM;MAkB7D;AAQD,wBAAsB,sBAAsB,CAAC,IAAI,EAAE,qBAAqB,mCA+DvE;AAED,wBAAsB,aAAa,CAAC,IAAI,EAAE,qBAAqB,GAAG,OAAO,CAAC,oBAAoB,CAAC,CAsB9F"}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.tableSearch = tableSearch;
|
|
4
|
+
exports.getDataTableColumns = getDataTableColumns;
|
|
5
|
+
exports.getConditionsForColumn = getConditionsForColumn;
|
|
6
|
+
exports.getDataTables = getDataTables;
|
|
7
|
+
const utils_1 = require("./utils");
|
|
8
|
+
// @ADO-3904: Pagination here does not work until a filter is entered or removed, suspected bug in ResourceLocator
|
|
9
|
+
async function tableSearch(filterString, prevPaginationToken) {
|
|
10
|
+
const proxy = await (0, utils_1.getDataTableAggregateProxy)(this);
|
|
11
|
+
const skip = prevPaginationToken === undefined ? 0 : parseInt(prevPaginationToken, 10);
|
|
12
|
+
const take = 100;
|
|
13
|
+
const filter = filterString === undefined ? {} : { filter: { name: filterString.toLowerCase() } };
|
|
14
|
+
const result = await proxy.getManyAndCount({
|
|
15
|
+
skip,
|
|
16
|
+
take,
|
|
17
|
+
...filter,
|
|
18
|
+
});
|
|
19
|
+
const results = result.data.map((row) => {
|
|
20
|
+
return {
|
|
21
|
+
name: row.name,
|
|
22
|
+
value: row.id,
|
|
23
|
+
url: `/projects/${proxy.getProjectId()}/datatables/${row.id}`,
|
|
24
|
+
};
|
|
25
|
+
});
|
|
26
|
+
const paginationToken = results.length === take ? `${skip + take}` : undefined;
|
|
27
|
+
return {
|
|
28
|
+
results,
|
|
29
|
+
paginationToken,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
async function getDataTableColumns() {
|
|
33
|
+
const returnData = [
|
|
34
|
+
// eslint-disable-next-line n8n-nodes-base/node-param-display-name-miscased-id, n8n-nodes-base/node-param-display-name-miscased
|
|
35
|
+
{ name: 'id - (number)', value: 'id', type: 'number' },
|
|
36
|
+
// eslint-disable-next-line n8n-nodes-base/node-param-display-name-miscased
|
|
37
|
+
{ name: 'createdAt - (date)', value: 'createdAt', type: 'date' },
|
|
38
|
+
// eslint-disable-next-line n8n-nodes-base/node-param-display-name-miscased
|
|
39
|
+
{ name: 'updatedAt - (date)', value: 'updatedAt', type: 'date' },
|
|
40
|
+
];
|
|
41
|
+
const proxy = await (0, utils_1.getDataTableProxyLoadOptions)(this);
|
|
42
|
+
const columns = await proxy.getColumns();
|
|
43
|
+
for (const column of columns) {
|
|
44
|
+
returnData.push({
|
|
45
|
+
name: `${column.name} - (${column.type})`,
|
|
46
|
+
value: column.name,
|
|
47
|
+
type: column.type,
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
return returnData;
|
|
51
|
+
}
|
|
52
|
+
const systemColumns = [
|
|
53
|
+
{ name: 'id', type: 'number' },
|
|
54
|
+
{ name: 'createdAt', type: 'date' },
|
|
55
|
+
{ name: 'updatedAt', type: 'date' },
|
|
56
|
+
];
|
|
57
|
+
async function getConditionsForColumn() {
|
|
58
|
+
const keyName = this.getCurrentNodeParameter('&keyName');
|
|
59
|
+
// Base conditions available for all column types
|
|
60
|
+
const baseConditions = [
|
|
61
|
+
{ name: 'Equals', value: 'eq' },
|
|
62
|
+
{ name: 'Not Equals', value: 'neq' },
|
|
63
|
+
{ name: 'Is Empty', value: 'isEmpty' },
|
|
64
|
+
{ name: 'Is Not Empty', value: 'isNotEmpty' },
|
|
65
|
+
];
|
|
66
|
+
const comparableConditions = [
|
|
67
|
+
{ name: 'Greater Than', value: 'gt' },
|
|
68
|
+
{ name: 'Greater Than or Equal', value: 'gte' },
|
|
69
|
+
{ name: 'Less Than', value: 'lt' },
|
|
70
|
+
{ name: 'Less Than or Equal', value: 'lte' },
|
|
71
|
+
];
|
|
72
|
+
const stringConditions = [
|
|
73
|
+
{
|
|
74
|
+
name: 'LIKE operator',
|
|
75
|
+
value: 'like',
|
|
76
|
+
description: 'Case-sensitive pattern matching. Use % as wildcard (e.g., "%Mar%" to match "Anne-Marie").',
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
name: 'ILIKE operator',
|
|
80
|
+
value: 'ilike',
|
|
81
|
+
description: 'Case-insensitive pattern matching. Use % as wildcard (e.g., "%mar%" to match "Anne-Marie").',
|
|
82
|
+
},
|
|
83
|
+
];
|
|
84
|
+
const allConditions = [...baseConditions, ...comparableConditions, ...stringConditions];
|
|
85
|
+
// If no column is selected yet, return all conditions
|
|
86
|
+
if (!keyName) {
|
|
87
|
+
return allConditions;
|
|
88
|
+
}
|
|
89
|
+
// Get column type to determine available conditions
|
|
90
|
+
const column = systemColumns.find((col) => col.name === keyName) ??
|
|
91
|
+
(await (await (0, utils_1.getDataTableProxyLoadOptions)(this)).getColumns()).find((col) => col.name === keyName);
|
|
92
|
+
if (!column) {
|
|
93
|
+
return baseConditions;
|
|
94
|
+
}
|
|
95
|
+
const conditions = baseConditions;
|
|
96
|
+
// String columns get LIKE operators
|
|
97
|
+
if (column.type === 'string') {
|
|
98
|
+
conditions.push.apply(conditions, stringConditions);
|
|
99
|
+
}
|
|
100
|
+
if (['number', 'date', 'string'].includes(column.type)) {
|
|
101
|
+
conditions.push.apply(conditions, comparableConditions);
|
|
102
|
+
}
|
|
103
|
+
return conditions;
|
|
104
|
+
}
|
|
105
|
+
async function getDataTables() {
|
|
106
|
+
const proxy = await (0, utils_1.getDataTableProxyLoadOptions)(this);
|
|
107
|
+
const result = await proxy.getColumns();
|
|
108
|
+
const fields = [];
|
|
109
|
+
for (const field of result) {
|
|
110
|
+
const type = field.type === 'date' ? 'dateTime' : field.type;
|
|
111
|
+
fields.push({
|
|
112
|
+
id: field.name,
|
|
113
|
+
displayName: field.name,
|
|
114
|
+
required: false,
|
|
115
|
+
defaultMatch: false,
|
|
116
|
+
display: true,
|
|
117
|
+
type,
|
|
118
|
+
readOnly: false,
|
|
119
|
+
removed: false,
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
return { fields };
|
|
123
|
+
}
|
|
124
|
+
//# sourceMappingURL=methods.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"methods.js","sourceRoot":"","sources":["../../../../nodes/DataTable/common/methods.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { DataStoreRowReturn, IDataStoreProjectService, IDisplayOptions, IExecuteFunctions, INodeProperties } from 'n8n-workflow';
|
|
2
|
+
export declare function getSelectFields(displayOptions: IDisplayOptions, requireCondition?: boolean): INodeProperties[];
|
|
3
|
+
export declare function getSelectFilter(ctx: IExecuteFunctions, index: number): import("n8n-workflow").ListDataStoreContentFilter;
|
|
4
|
+
export declare function executeSelectMany(ctx: IExecuteFunctions, index: number, dataStoreProxy: IDataStoreProjectService, rejectEmpty?: boolean): Promise<Array<{
|
|
5
|
+
json: DataStoreRowReturn;
|
|
6
|
+
}>>;
|
|
7
|
+
//# sourceMappingURL=selectMany.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"selectMany.d.ts","sourceRoot":"","sources":["../../../../nodes/DataTable/common/selectMany.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACX,kBAAkB,EAClB,wBAAwB,EACxB,eAAe,EACf,iBAAiB,EACjB,eAAe,EACf,MAAM,cAAc,CAAC;AAMtB,wBAAgB,eAAe,CAC9B,cAAc,EAAE,eAAe,EAC/B,gBAAgB,UAAQ,GACtB,eAAe,EAAE,CA8EnB;AAED,wBAAgB,eAAe,CAAC,GAAG,EAAE,iBAAiB,EAAE,KAAK,EAAE,MAAM,qDAapE;AAED,wBAAsB,iBAAiB,CACtC,GAAG,EAAE,iBAAiB,EACtB,KAAK,EAAE,MAAM,EACb,cAAc,EAAE,wBAAwB,EACxC,WAAW,UAAQ,GACjB,OAAO,CAAC,KAAK,CAAC;IAAE,IAAI,EAAE,kBAAkB,CAAA;CAAE,CAAC,CAAC,CAoC9C"}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getSelectFields = getSelectFields;
|
|
4
|
+
exports.getSelectFilter = getSelectFilter;
|
|
5
|
+
exports.executeSelectMany = executeSelectMany;
|
|
6
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
7
|
+
const constants_1 = require("./constants");
|
|
8
|
+
const fields_1 = require("./fields");
|
|
9
|
+
const utils_1 = require("./utils");
|
|
10
|
+
function getSelectFields(displayOptions, requireCondition = false) {
|
|
11
|
+
return [
|
|
12
|
+
{
|
|
13
|
+
displayName: 'Must Match',
|
|
14
|
+
name: 'matchType',
|
|
15
|
+
type: 'options',
|
|
16
|
+
options: [
|
|
17
|
+
{
|
|
18
|
+
name: 'Any Condition',
|
|
19
|
+
value: constants_1.ANY_CONDITION,
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
name: 'All Conditions',
|
|
23
|
+
value: constants_1.ALL_CONDITIONS,
|
|
24
|
+
},
|
|
25
|
+
],
|
|
26
|
+
displayOptions,
|
|
27
|
+
default: constants_1.ANY_CONDITION,
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
displayName: 'Conditions',
|
|
31
|
+
name: 'filters',
|
|
32
|
+
type: 'fixedCollection',
|
|
33
|
+
typeOptions: {
|
|
34
|
+
multipleValues: true,
|
|
35
|
+
minRequiredFields: requireCondition ? 1 : 0,
|
|
36
|
+
},
|
|
37
|
+
displayOptions,
|
|
38
|
+
default: {},
|
|
39
|
+
placeholder: 'Add Condition',
|
|
40
|
+
options: [
|
|
41
|
+
{
|
|
42
|
+
displayName: 'Conditions',
|
|
43
|
+
name: 'conditions',
|
|
44
|
+
values: [
|
|
45
|
+
{
|
|
46
|
+
// eslint-disable-next-line n8n-nodes-base/node-param-display-name-wrong-for-dynamic-options
|
|
47
|
+
displayName: 'Column',
|
|
48
|
+
name: 'keyName',
|
|
49
|
+
type: 'options',
|
|
50
|
+
// eslint-disable-next-line n8n-nodes-base/node-param-description-wrong-for-dynamic-options
|
|
51
|
+
description: 'Choose from the list, or specify using an <a href="https://docs.n8n.io/code/expressions/">expression</a>',
|
|
52
|
+
typeOptions: {
|
|
53
|
+
loadOptionsDependsOn: [fields_1.DATA_TABLE_ID_FIELD],
|
|
54
|
+
loadOptionsMethod: 'getDataTableColumns',
|
|
55
|
+
},
|
|
56
|
+
default: 'id',
|
|
57
|
+
},
|
|
58
|
+
{
|
|
59
|
+
// eslint-disable-next-line n8n-nodes-base/node-param-display-name-wrong-for-dynamic-options
|
|
60
|
+
displayName: 'Condition',
|
|
61
|
+
name: 'condition',
|
|
62
|
+
// eslint-disable-next-line n8n-nodes-base/node-param-description-missing-from-dynamic-options
|
|
63
|
+
type: 'options',
|
|
64
|
+
typeOptions: {
|
|
65
|
+
loadOptionsDependsOn: ['&keyName'],
|
|
66
|
+
loadOptionsMethod: 'getConditionsForColumn',
|
|
67
|
+
},
|
|
68
|
+
default: 'eq',
|
|
69
|
+
},
|
|
70
|
+
{
|
|
71
|
+
displayName: 'Value',
|
|
72
|
+
name: 'keyValue',
|
|
73
|
+
type: 'string',
|
|
74
|
+
default: '',
|
|
75
|
+
displayOptions: {
|
|
76
|
+
hide: {
|
|
77
|
+
condition: ['isEmpty', 'isNotEmpty'],
|
|
78
|
+
},
|
|
79
|
+
},
|
|
80
|
+
},
|
|
81
|
+
],
|
|
82
|
+
},
|
|
83
|
+
],
|
|
84
|
+
description: 'Filter to decide which rows get',
|
|
85
|
+
},
|
|
86
|
+
];
|
|
87
|
+
}
|
|
88
|
+
function getSelectFilter(ctx, index) {
|
|
89
|
+
const fields = ctx.getNodeParameter('filters.conditions', index, []);
|
|
90
|
+
const matchType = ctx.getNodeParameter('matchType', index, constants_1.ANY_CONDITION);
|
|
91
|
+
const node = ctx.getNode();
|
|
92
|
+
if (!(0, utils_1.isMatchType)(matchType)) {
|
|
93
|
+
throw new n8n_workflow_1.NodeOperationError(node, 'unexpected match type');
|
|
94
|
+
}
|
|
95
|
+
if (!(0, utils_1.isFieldArray)(fields)) {
|
|
96
|
+
throw new n8n_workflow_1.NodeOperationError(node, 'unexpected fields input');
|
|
97
|
+
}
|
|
98
|
+
return (0, utils_1.buildGetManyFilter)(fields, matchType);
|
|
99
|
+
}
|
|
100
|
+
async function executeSelectMany(ctx, index, dataStoreProxy, rejectEmpty = false) {
|
|
101
|
+
const filter = getSelectFilter(ctx, index);
|
|
102
|
+
if (rejectEmpty && filter.filters.length === 0) {
|
|
103
|
+
throw new n8n_workflow_1.NodeOperationError(ctx.getNode(), 'At least one condition is required');
|
|
104
|
+
}
|
|
105
|
+
let take = 1000;
|
|
106
|
+
const result = [];
|
|
107
|
+
let totalCount = undefined;
|
|
108
|
+
do {
|
|
109
|
+
const response = await dataStoreProxy.getManyRowsAndCount({
|
|
110
|
+
skip: result.length,
|
|
111
|
+
take,
|
|
112
|
+
filter,
|
|
113
|
+
});
|
|
114
|
+
const data = response.data.map((json) => ({ json }));
|
|
115
|
+
// Optimize common path of <1000 results
|
|
116
|
+
if (response.count === response.data.length) {
|
|
117
|
+
return data;
|
|
118
|
+
}
|
|
119
|
+
if (totalCount !== undefined && response.count !== totalCount) {
|
|
120
|
+
throw new n8n_workflow_1.NodeOperationError(ctx.getNode(), 'synchronization error: result count changed during pagination');
|
|
121
|
+
}
|
|
122
|
+
totalCount = response.count;
|
|
123
|
+
result.push.apply(result, data);
|
|
124
|
+
take = Math.min(take, response.count - result.length);
|
|
125
|
+
} while (take > 0);
|
|
126
|
+
return result;
|
|
127
|
+
}
|
|
128
|
+
//# sourceMappingURL=selectMany.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"selectMany.js","sourceRoot":"","sources":["../../../../nodes/DataTable/common/selectMany.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { IDataObject, INode, ListDataStoreContentFilter, IDataStoreProjectAggregateService, IDataStoreProjectService, IExecuteFunctions, ILoadOptionsFunctions, DataStoreColumnJsType } from 'n8n-workflow';
|
|
2
|
+
import type { FieldEntry, FilterType } from './constants';
|
|
3
|
+
export declare function getDataTableProxyExecute(ctx: IExecuteFunctions, index?: number): Promise<IDataStoreProjectService>;
|
|
4
|
+
export declare function getDataTableProxyLoadOptions(ctx: ILoadOptionsFunctions): Promise<IDataStoreProjectService>;
|
|
5
|
+
export declare function getDataTableAggregateProxy(ctx: IExecuteFunctions | ILoadOptionsFunctions): Promise<IDataStoreProjectAggregateService>;
|
|
6
|
+
export declare function isFieldEntry(obj: unknown): obj is FieldEntry;
|
|
7
|
+
export declare function isMatchType(obj: unknown): obj is FilterType;
|
|
8
|
+
export declare function buildGetManyFilter(fieldEntries: FieldEntry[], matchType: FilterType): ListDataStoreContentFilter;
|
|
9
|
+
export declare function isFieldArray(value: unknown): value is FieldEntry[];
|
|
10
|
+
export declare function dataObjectToApiInput(data: IDataObject, node: INode, row: number): Record<string, DataStoreColumnJsType>;
|
|
11
|
+
//# sourceMappingURL=utils.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../nodes/DataTable/common/utils.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACX,WAAW,EACX,KAAK,EACL,0BAA0B,EAC1B,iCAAiC,EACjC,wBAAwB,EACxB,iBAAiB,EACjB,qBAAqB,EACrB,qBAAqB,EACrB,MAAM,cAAc,CAAC;AAGtB,OAAO,KAAK,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAc1D,wBAAsB,wBAAwB,CAC7C,GAAG,EAAE,iBAAiB,EACtB,KAAK,GAAE,MAAU,GACf,OAAO,CAAC,wBAAwB,CAAC,CAYnC;AAED,wBAAsB,4BAA4B,CACjD,GAAG,EAAE,qBAAqB,GACxB,OAAO,CAAC,wBAAwB,CAAC,CAYnC;AAED,wBAAsB,0BAA0B,CAC/C,GAAG,EAAE,iBAAiB,GAAG,qBAAqB,GAC5C,OAAO,CAAC,iCAAiC,CAAC,CAQ5C;AAED,wBAAgB,YAAY,CAAC,GAAG,EAAE,OAAO,GAAG,GAAG,IAAI,UAAU,CAG5D;AAED,wBAAgB,WAAW,CAAC,GAAG,EAAE,OAAO,GAAG,GAAG,IAAI,UAAU,CAE3D;AAED,wBAAgB,kBAAkB,CACjC,YAAY,EAAE,UAAU,EAAE,EAC1B,SAAS,EAAE,UAAU,GACnB,0BAA0B,CAwB5B;AAED,wBAAgB,YAAY,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI,UAAU,EAAE,CAIlE;AAED,wBAAgB,oBAAoB,CACnC,IAAI,EAAE,WAAW,EACjB,IAAI,EAAE,KAAK,EACX,GAAG,EAAE,MAAM,GACT,MAAM,CAAC,MAAM,EAAE,qBAAqB,CAAC,CA2CvC"}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.getDataTableProxyExecute = getDataTableProxyExecute;
|
|
4
|
+
exports.getDataTableProxyLoadOptions = getDataTableProxyLoadOptions;
|
|
5
|
+
exports.getDataTableAggregateProxy = getDataTableAggregateProxy;
|
|
6
|
+
exports.isFieldEntry = isFieldEntry;
|
|
7
|
+
exports.isMatchType = isMatchType;
|
|
8
|
+
exports.buildGetManyFilter = buildGetManyFilter;
|
|
9
|
+
exports.isFieldArray = isFieldArray;
|
|
10
|
+
exports.dataObjectToApiInput = dataObjectToApiInput;
|
|
11
|
+
const luxon_1 = require("luxon");
|
|
12
|
+
const n8n_workflow_1 = require("n8n-workflow");
|
|
13
|
+
const constants_1 = require("./constants");
|
|
14
|
+
const fields_1 = require("./fields");
|
|
15
|
+
function isDateLike(v) {
|
|
16
|
+
return (v !== null && typeof v === 'object' && 'toISOString' in v && typeof v.toISOString === 'function');
|
|
17
|
+
}
|
|
18
|
+
// We need two functions here since the available getNodeParameter
|
|
19
|
+
// overloads vary with the index
|
|
20
|
+
async function getDataTableProxyExecute(ctx, index = 0) {
|
|
21
|
+
if (ctx.helpers.getDataStoreProxy === undefined)
|
|
22
|
+
throw new n8n_workflow_1.NodeOperationError(ctx.getNode(), 'Attempted to use Data Table node but the module is disabled');
|
|
23
|
+
const dataStoreId = ctx.getNodeParameter(fields_1.DATA_TABLE_ID_FIELD, index, undefined, {
|
|
24
|
+
extractValue: true,
|
|
25
|
+
});
|
|
26
|
+
return await ctx.helpers.getDataStoreProxy(dataStoreId);
|
|
27
|
+
}
|
|
28
|
+
async function getDataTableProxyLoadOptions(ctx) {
|
|
29
|
+
if (ctx.helpers.getDataStoreProxy === undefined)
|
|
30
|
+
throw new n8n_workflow_1.NodeOperationError(ctx.getNode(), 'Attempted to use Data Table node but the module is disabled');
|
|
31
|
+
const dataStoreId = ctx.getNodeParameter(fields_1.DATA_TABLE_ID_FIELD, undefined, {
|
|
32
|
+
extractValue: true,
|
|
33
|
+
});
|
|
34
|
+
return await ctx.helpers.getDataStoreProxy(dataStoreId);
|
|
35
|
+
}
|
|
36
|
+
async function getDataTableAggregateProxy(ctx) {
|
|
37
|
+
if (ctx.helpers.getDataStoreAggregateProxy === undefined)
|
|
38
|
+
throw new n8n_workflow_1.NodeOperationError(ctx.getNode(), 'Attempted to use Data Table node but the module is disabled');
|
|
39
|
+
return await ctx.helpers.getDataStoreAggregateProxy();
|
|
40
|
+
}
|
|
41
|
+
function isFieldEntry(obj) {
|
|
42
|
+
if (obj === null || typeof obj !== 'object')
|
|
43
|
+
return false;
|
|
44
|
+
return 'keyName' in obj && 'condition' in obj; // keyValue is optional
|
|
45
|
+
}
|
|
46
|
+
function isMatchType(obj) {
|
|
47
|
+
return typeof obj === 'string' && (obj === constants_1.ANY_CONDITION || obj === constants_1.ALL_CONDITIONS);
|
|
48
|
+
}
|
|
49
|
+
function buildGetManyFilter(fieldEntries, matchType) {
|
|
50
|
+
const filters = fieldEntries.map((x) => {
|
|
51
|
+
switch (x.condition) {
|
|
52
|
+
case 'isEmpty':
|
|
53
|
+
return {
|
|
54
|
+
columnName: x.keyName,
|
|
55
|
+
condition: 'eq',
|
|
56
|
+
value: null,
|
|
57
|
+
};
|
|
58
|
+
case 'isNotEmpty':
|
|
59
|
+
return {
|
|
60
|
+
columnName: x.keyName,
|
|
61
|
+
condition: 'neq',
|
|
62
|
+
value: null,
|
|
63
|
+
};
|
|
64
|
+
default:
|
|
65
|
+
return {
|
|
66
|
+
columnName: x.keyName,
|
|
67
|
+
condition: x.condition,
|
|
68
|
+
value: x.keyValue,
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
return { type: matchType === constants_1.ALL_CONDITIONS ? 'and' : 'or', filters };
|
|
73
|
+
}
|
|
74
|
+
function isFieldArray(value) {
|
|
75
|
+
return (value !== null && typeof value === 'object' && Array.isArray(value) && value.every(isFieldEntry));
|
|
76
|
+
}
|
|
77
|
+
function dataObjectToApiInput(data, node, row) {
|
|
78
|
+
return Object.fromEntries(Object.entries(data).map(([k, v]) => {
|
|
79
|
+
if (v === undefined || v === null)
|
|
80
|
+
return [k, null];
|
|
81
|
+
if (Array.isArray(v)) {
|
|
82
|
+
throw new n8n_workflow_1.NodeOperationError(node, `unexpected array input '${JSON.stringify(v)}' in row ${row}`);
|
|
83
|
+
}
|
|
84
|
+
if (v instanceof Date) {
|
|
85
|
+
return [k, v];
|
|
86
|
+
}
|
|
87
|
+
if (typeof v === 'object') {
|
|
88
|
+
// Luxon DateTime
|
|
89
|
+
if (luxon_1.DateTime.isDateTime(v)) {
|
|
90
|
+
return [k, v.toJSDate()];
|
|
91
|
+
}
|
|
92
|
+
if (isDateLike(v)) {
|
|
93
|
+
try {
|
|
94
|
+
const dateObj = new Date(v.toISOString());
|
|
95
|
+
if (isNaN(dateObj.getTime())) {
|
|
96
|
+
throw new Error('Invalid date');
|
|
97
|
+
}
|
|
98
|
+
return [k, dateObj];
|
|
99
|
+
}
|
|
100
|
+
catch {
|
|
101
|
+
// Fall through
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
throw new n8n_workflow_1.NodeOperationError(node, `unexpected object input '${JSON.stringify(v)}' in row ${row}`);
|
|
105
|
+
}
|
|
106
|
+
return [k, v];
|
|
107
|
+
}));
|
|
108
|
+
}
|
|
109
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../nodes/DataTable/common/utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,24 +1,9 @@
|
|
|
1
1
|
{
|
|
2
2
|
"type": "object",
|
|
3
3
|
"properties": {
|
|
4
|
-
"contentHash": {
|
|
5
|
-
"type": "string"
|
|
6
|
-
},
|
|
7
|
-
"contentSize": {
|
|
8
|
-
"type": "integer"
|
|
9
|
-
},
|
|
10
4
|
"id": {
|
|
11
5
|
"type": "string"
|
|
12
6
|
},
|
|
13
|
-
"isDownloadable": {
|
|
14
|
-
"type": "boolean"
|
|
15
|
-
},
|
|
16
|
-
"lastModifiedClient": {
|
|
17
|
-
"type": "string"
|
|
18
|
-
},
|
|
19
|
-
"lastModifiedServer": {
|
|
20
|
-
"type": "string"
|
|
21
|
-
},
|
|
22
7
|
"name": {
|
|
23
8
|
"type": "string"
|
|
24
9
|
},
|
|
@@ -28,12 +13,9 @@
|
|
|
28
13
|
"pathLower": {
|
|
29
14
|
"type": "string"
|
|
30
15
|
},
|
|
31
|
-
"rev": {
|
|
32
|
-
"type": "string"
|
|
33
|
-
},
|
|
34
16
|
"type": {
|
|
35
17
|
"type": "string"
|
|
36
18
|
}
|
|
37
19
|
},
|
|
38
|
-
"version":
|
|
20
|
+
"version": 4
|
|
39
21
|
}
|
|
@@ -39,33 +39,15 @@
|
|
|
39
39
|
"linkedin": {
|
|
40
40
|
"type": "string"
|
|
41
41
|
},
|
|
42
|
-
"naf5_code": {
|
|
43
|
-
"type": "string"
|
|
44
|
-
},
|
|
45
|
-
"naf5_des": {
|
|
46
|
-
"type": "string"
|
|
47
|
-
},
|
|
48
42
|
"nb_employees": {
|
|
49
43
|
"type": "string"
|
|
50
44
|
},
|
|
51
45
|
"phone": {
|
|
52
46
|
"type": "string"
|
|
53
47
|
},
|
|
54
|
-
"siren": {
|
|
55
|
-
"type": "string"
|
|
56
|
-
},
|
|
57
|
-
"siret": {
|
|
58
|
-
"type": "string"
|
|
59
|
-
},
|
|
60
|
-
"siret_address": {
|
|
61
|
-
"type": "string"
|
|
62
|
-
},
|
|
63
|
-
"vat": {
|
|
64
|
-
"type": "string"
|
|
65
|
-
},
|
|
66
48
|
"website": {
|
|
67
49
|
"type": "string"
|
|
68
50
|
}
|
|
69
51
|
},
|
|
70
|
-
"version":
|
|
52
|
+
"version": 4
|
|
71
53
|
}
|