Skip to content

Commit 4dcf7d3

Browse files
committed
GetContact limited output if defined in inspector
exclude hardcoded properties from additional properties
1 parent ee26967 commit 4dcf7d3

File tree

4 files changed

+20
-7
lines changed

4 files changed

+20
-7
lines changed

Diff for: src/appmixer/hubspot/bundle.json

+1-1
Original file line numberDiff line numberDiff line change
@@ -64,7 +64,7 @@
6464
"4.1.0": [
6565
"Added custom properties and additional properties to the following components: `CreateContact`, `CreateDeal`, `UpdateContact` and `UpdateDeal`. Custom properties are new properties that are not part of the default HubSpot properties. Additional properties default HubSpot properties but were not part of the default properties list before.",
6666
"Added caching of Contact and Deal properties, which can be further configured in the connector settings.",
67-
"Improved listing output variables for `GetContact` MAYBE OTHERS to make it consistent with the selected properties in the input."
67+
"Improved listing output variables for `GetContact` to make it consistent with the selected properties in the input."
6868
]
6969
}
7070
}

Diff for: src/appmixer/hubspot/crm/GetContact/component.json

+4-1
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,7 @@
33
"author": "Zulkafil Tabish <[email protected]>",
44
"icon": "",
55
"description": "Get a contact by Email or ID.",
6-
"version": "1.0.2",
6+
"version": "1.0.3",
77
"private": false,
88
"auth": {
99
"service": "appmixer:hubspot"
@@ -73,6 +73,9 @@
7373
"source": {
7474
"url": "/component/appmixer/hubspot/crm/GetContactsProperties?outPort=out",
7575
"data": {
76+
"messages": {
77+
"in/properties": "inputs/in/properties"
78+
},
7679
"transform": "./transformers#contactToSelectArray"
7780
}
7881
}

Diff for: src/appmixer/hubspot/crm/GetContactsProperties/GetContactsProperties.js

+10
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,5 @@
11
'use strict';
2+
23
const Hubspot = require('../../Hubspot');
34
const { getObjectProperties, WATCHED_PROPERTIES_CONTACT } = require('../../commons');
45

@@ -10,6 +11,15 @@ module.exports = {
1011
const hs = new Hubspot(auth.accessToken, context.config);
1112
const properties = await getObjectProperties(context, hs, 'contacts', 'all');
1213

14+
const propertiesToOutput = context.messages.in.content?.properties;
15+
if (propertiesToOutput) {
16+
// We have a set of properties defined in the inspector.
17+
// We only want to return these properties. See GetContact/component.json - outPorts
18+
const propertiesToReturn = properties.filter((property) => propertiesToOutput.includes(property.name));
19+
20+
return context.sendJson(propertiesToReturn, 'out');
21+
}
22+
1323
return context.sendJson(properties, 'out');
1424
},
1525

Diff for: src/appmixer/hubspot/crm/GetDealsProperties/GetDealsProperties.js

+5-5
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
'use strict';
22
const Hubspot = require('../../Hubspot');
3-
const { getObjectProperties } = require('../../commons');
3+
const { getObjectProperties, WATCHED_PROPERTIES_DEAL } = require('../../commons');
44

55
module.exports = {
66

@@ -65,12 +65,12 @@ module.exports = {
6565
return inspector;
6666
},
6767

68-
/** Only returns properties where `createdUserId` exists. */
69-
customFieldsToSelectArray(contactsProperties) {
68+
/** Returns properties that not hardcoded into the component. Both custom and HubSpot properties. */
69+
additionalFieldsToSelectArray(dealsProperties) {
7070

71-
return contactsProperties
72-
.filter((property) => property.createdUserId)
71+
return dealsProperties
7372
.filter((property) => property.formField)
73+
.filter((property) => !WATCHED_PROPERTIES_DEAL.includes(property.name))
7474
.map((property) => {
7575
return { label: property.label, value: property.name };
7676
});

0 commit comments

Comments
 (0)