Merge pull request #1524 from automatisch/AUT-528
feat(vtiger-crm): add new todos trigger
This commit is contained in:
@@ -3,5 +3,13 @@ import newContacts from './new-contacts/index.js';
|
||||
import newInvoices from './new-invoices/index.js';
|
||||
import newLeads from './new-leads/index.js';
|
||||
import newOpportunities from './new-opportunities/index.js';
|
||||
import newTodos from './new-todos/index.js';
|
||||
|
||||
export default [newCases, newContacts, newInvoices, newLeads, newOpportunities];
|
||||
export default [
|
||||
newCases,
|
||||
newContacts,
|
||||
newInvoices,
|
||||
newLeads,
|
||||
newOpportunities,
|
||||
newTodos,
|
||||
];
|
||||
|
@@ -0,0 +1,41 @@
|
||||
import defineTrigger from '../../../../helpers/define-trigger.js';
|
||||
|
||||
export default defineTrigger({
|
||||
name: 'New todos',
|
||||
key: 'newTodos',
|
||||
pollInterval: 15,
|
||||
description: 'Triggers when a new todo is created.',
|
||||
|
||||
async run($) {
|
||||
let offset = 0;
|
||||
const limit = 100;
|
||||
let hasMore = true;
|
||||
|
||||
const params = {
|
||||
operation: 'query',
|
||||
sessionName: $.auth.data.sessionName,
|
||||
query: `SELECT * FROM Calendar ORDER BY createdtime DESC LIMIT ${offset}, ${limit};`,
|
||||
};
|
||||
|
||||
do {
|
||||
const { data } = await $.http.get('/webservice.php', {
|
||||
params,
|
||||
});
|
||||
offset = limit + offset;
|
||||
|
||||
if (!data?.result?.length) {
|
||||
hasMore = false;
|
||||
return;
|
||||
}
|
||||
|
||||
for (const item of data.result) {
|
||||
$.pushTriggerItem({
|
||||
raw: item,
|
||||
meta: {
|
||||
internalId: item.id,
|
||||
},
|
||||
});
|
||||
}
|
||||
} while (hasMore);
|
||||
},
|
||||
});
|
@@ -11,6 +11,8 @@ items:
|
||||
desc: Triggers when a new lead is created.
|
||||
- name: New opportunities
|
||||
desc: Triggers when a new opportunity is created.
|
||||
- name: New todos
|
||||
desc: Triggers when a new todo is created.
|
||||
---
|
||||
|
||||
<script setup>
|
||||
|
Reference in New Issue
Block a user