Merge pull request #1299 from automatisch/pipedrive-new-lead
feat(pipedrive): add new leads trigger
This commit is contained in:
@@ -1,5 +1,6 @@
|
||||
import newActivities from './new-activities';
|
||||
import newDeals from './new-deals';
|
||||
import newLeads from './new-leads';
|
||||
import newNotes from './new-notes';
|
||||
|
||||
export default [newActivities, newDeals, newNotes];
|
||||
export default [newActivities, newDeals, newLeads, newNotes];
|
||||
|
@@ -0,0 +1,56 @@
|
||||
import defineTrigger from '../../../../helpers/define-trigger';
|
||||
|
||||
type Payload = {
|
||||
start: number;
|
||||
limit: number;
|
||||
sort: string;
|
||||
};
|
||||
|
||||
type ResponseData = {
|
||||
data: {
|
||||
id: number;
|
||||
}[];
|
||||
additional_data: {
|
||||
pagination: {
|
||||
next_start: number;
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
export default defineTrigger({
|
||||
name: 'New leads',
|
||||
key: 'newLeads',
|
||||
pollInterval: 15,
|
||||
description: 'Triggers when a new lead is created.',
|
||||
arguments: [],
|
||||
|
||||
async run($) {
|
||||
const params: Payload = {
|
||||
start: 0,
|
||||
limit: 100,
|
||||
sort: 'add_time DESC',
|
||||
};
|
||||
|
||||
do {
|
||||
const { data } = await $.http.get<ResponseData>(
|
||||
`${$.auth.data.apiDomain}/api/v1/leads`,
|
||||
{ params }
|
||||
);
|
||||
|
||||
if (!data?.data?.length) {
|
||||
return;
|
||||
}
|
||||
|
||||
params.start = data.additional_data?.pagination?.next_start;
|
||||
|
||||
for (const lead of data.data) {
|
||||
$.pushTriggerItem({
|
||||
raw: lead,
|
||||
meta: {
|
||||
internalId: lead.id.toString(),
|
||||
},
|
||||
});
|
||||
}
|
||||
} while (params.start);
|
||||
},
|
||||
});
|
@@ -5,6 +5,8 @@ items:
|
||||
desc: Triggers when a new activity is created.
|
||||
- name: New deals
|
||||
desc: Triggers when a new deal is created.
|
||||
- name: New leads
|
||||
desc: Triggers when a new lead is created.
|
||||
- name: New notes
|
||||
desc: Triggers when a new note is created.
|
||||
---
|
||||
|
Reference in New Issue
Block a user