feat: Add listForms dynamic data to Typeform app
This commit is contained in:
3
packages/backend/src/apps/typeform/dynamic-data/index.ts
Normal file
3
packages/backend/src/apps/typeform/dynamic-data/index.ts
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
import listForms from './list-forms';
|
||||||
|
|
||||||
|
export default [listForms];
|
@@ -0,0 +1,25 @@
|
|||||||
|
import { IGlobalVariable, IJSONObject } from '@automatisch/types';
|
||||||
|
|
||||||
|
export default {
|
||||||
|
name: 'List forms',
|
||||||
|
key: 'listForms',
|
||||||
|
|
||||||
|
async run($: IGlobalVariable) {
|
||||||
|
const forms: {
|
||||||
|
data: IJSONObject[];
|
||||||
|
} = {
|
||||||
|
data: [],
|
||||||
|
};
|
||||||
|
|
||||||
|
const response = await $.http.get('/forms');
|
||||||
|
|
||||||
|
forms.data = response.data.items.map((form: IJSONObject) => {
|
||||||
|
return {
|
||||||
|
value: form.id,
|
||||||
|
name: form.title,
|
||||||
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
return forms;
|
||||||
|
},
|
||||||
|
};
|
@@ -1,6 +1,8 @@
|
|||||||
import defineApp from '../../helpers/define-app';
|
import defineApp from '../../helpers/define-app';
|
||||||
import addAuthHeader from './common/add-auth-header';
|
import addAuthHeader from './common/add-auth-header';
|
||||||
import auth from './auth';
|
import auth from './auth';
|
||||||
|
import triggers from './triggers';
|
||||||
|
import dynamicData from './dynamic-data';
|
||||||
|
|
||||||
export default defineApp({
|
export default defineApp({
|
||||||
name: 'Typeform',
|
name: 'Typeform',
|
||||||
@@ -13,4 +15,6 @@ export default defineApp({
|
|||||||
primaryColor: '000000',
|
primaryColor: '000000',
|
||||||
beforeRequest: [addAuthHeader],
|
beforeRequest: [addAuthHeader],
|
||||||
auth,
|
auth,
|
||||||
|
triggers,
|
||||||
|
dynamicData,
|
||||||
});
|
});
|
||||||
|
3
packages/backend/src/apps/typeform/triggers/index.ts
Normal file
3
packages/backend/src/apps/typeform/triggers/index.ts
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
import newEntry from './new-entry';
|
||||||
|
|
||||||
|
export default [newEntry];
|
@@ -0,0 +1,32 @@
|
|||||||
|
import defineTrigger from '../../../../helpers/define-trigger';
|
||||||
|
|
||||||
|
export default defineTrigger({
|
||||||
|
name: 'New entry',
|
||||||
|
key: 'newEntry',
|
||||||
|
pollInterval: 15,
|
||||||
|
description: 'Triggers when a new form submitted.',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
label: 'Form',
|
||||||
|
key: 'form',
|
||||||
|
type: 'dropdown' as const,
|
||||||
|
required: true,
|
||||||
|
description: 'Pick a form to receive submissions.',
|
||||||
|
variables: false,
|
||||||
|
source: {
|
||||||
|
type: 'query',
|
||||||
|
name: 'getDynamicData',
|
||||||
|
arguments: [
|
||||||
|
{
|
||||||
|
name: 'key',
|
||||||
|
value: 'listForms',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
],
|
||||||
|
|
||||||
|
async run($) {
|
||||||
|
// await getUserTweets($, { currentUser: true });
|
||||||
|
},
|
||||||
|
});
|
Reference in New Issue
Block a user