@botonic/plugin-flow-builder 0.22.0-beta.3 → 0.22.1
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/lib/cjs/action.d.ts +16 -2
- package/lib/cjs/action.js +21 -19
- package/lib/cjs/action.js.map +1 -1
- package/lib/cjs/api.d.ts +19 -0
- package/lib/cjs/api.js +108 -0
- package/lib/cjs/api.js.map +1 -0
- package/lib/cjs/content-fields/content-fields-base.d.ts +4 -4
- package/lib/cjs/content-fields/content-fields-base.js.map +1 -1
- package/lib/cjs/content-fields/flow-button.d.ts +6 -3
- package/lib/cjs/content-fields/flow-button.js +28 -21
- package/lib/cjs/content-fields/flow-button.js.map +1 -1
- package/lib/cjs/content-fields/flow-carousel.d.ts +3 -2
- package/lib/cjs/content-fields/flow-carousel.js +3 -10
- package/lib/cjs/content-fields/flow-carousel.js.map +1 -1
- package/lib/cjs/content-fields/flow-element.d.ts +6 -3
- package/lib/cjs/content-fields/flow-element.js +16 -5
- package/lib/cjs/content-fields/flow-element.js.map +1 -1
- package/lib/cjs/content-fields/flow-image.d.ts +2 -2
- package/lib/cjs/content-fields/flow-image.js.map +1 -1
- package/lib/cjs/content-fields/flow-text.d.ts +4 -3
- package/lib/cjs/content-fields/flow-text.js +9 -9
- package/lib/cjs/content-fields/flow-text.js.map +1 -1
- package/lib/cjs/content-fields/flow-video.d.ts +2 -2
- package/lib/cjs/content-fields/flow-video.js +0 -1
- package/lib/cjs/content-fields/flow-video.js.map +1 -1
- package/lib/cjs/content-fields/hubtype-fields/button.d.ts +9 -0
- package/lib/cjs/content-fields/hubtype-fields/button.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/button.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/carousel.d.ts +16 -0
- package/lib/cjs/content-fields/hubtype-fields/carousel.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/carousel.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/common.d.ts +55 -0
- package/lib/cjs/content-fields/hubtype-fields/common.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/common.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/fallback.d.ts +9 -0
- package/lib/cjs/content-fields/hubtype-fields/fallback.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/fallback.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/function.d.ts +28 -0
- package/lib/cjs/content-fields/hubtype-fields/function.js +10 -0
- package/lib/cjs/content-fields/hubtype-fields/function.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/handoff.d.ts +10 -0
- package/lib/cjs/content-fields/hubtype-fields/handoff.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/handoff.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/image.d.ts +8 -0
- package/lib/cjs/content-fields/{types.js → hubtype-fields/image.js} +1 -1
- package/lib/cjs/content-fields/hubtype-fields/image.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/index.d.ts +17 -0
- package/lib/cjs/content-fields/hubtype-fields/index.js +21 -0
- package/lib/cjs/content-fields/hubtype-fields/index.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/intent.d.ts +10 -0
- package/lib/cjs/content-fields/hubtype-fields/intent.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/intent.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/keyword.d.ts +9 -0
- package/lib/cjs/content-fields/hubtype-fields/keyword.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/keyword.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/node-types.d.ts +23 -0
- package/lib/cjs/content-fields/hubtype-fields/node-types.js +31 -0
- package/lib/cjs/content-fields/hubtype-fields/node-types.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/nodes.d.ts +16 -0
- package/lib/cjs/content-fields/hubtype-fields/nodes.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/nodes.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/payload.d.ts +8 -0
- package/lib/cjs/content-fields/hubtype-fields/payload.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/payload.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/start.d.ts +7 -0
- package/lib/cjs/content-fields/hubtype-fields/start.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/start.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/text.d.ts +11 -0
- package/lib/cjs/content-fields/hubtype-fields/text.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/text.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/url.d.ts +8 -0
- package/lib/cjs/content-fields/hubtype-fields/url.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/url.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/video.d.ts +8 -0
- package/lib/cjs/content-fields/hubtype-fields/video.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/video.js.map +1 -0
- package/lib/cjs/content-fields/hubtype-fields/whatsapp-button-list.d.ts +21 -0
- package/lib/cjs/content-fields/hubtype-fields/whatsapp-button-list.js +3 -0
- package/lib/cjs/content-fields/hubtype-fields/whatsapp-button-list.js.map +1 -0
- package/lib/cjs/content-fields/index.d.ts +7 -5
- package/lib/cjs/content-fields/index.js +11 -9
- package/lib/cjs/content-fields/index.js.map +1 -1
- package/lib/cjs/content-fields/whatsapp-button-list/flow-whatsapp-button-list-row.d.ts +10 -0
- package/lib/cjs/content-fields/whatsapp-button-list/flow-whatsapp-button-list-row.js +32 -0
- package/lib/cjs/content-fields/whatsapp-button-list/flow-whatsapp-button-list-row.js.map +1 -0
- package/lib/cjs/content-fields/whatsapp-button-list/flow-whatsapp-button-list-section.d.ts +10 -0
- package/lib/cjs/content-fields/whatsapp-button-list/flow-whatsapp-button-list-section.js +29 -0
- package/lib/cjs/content-fields/whatsapp-button-list/flow-whatsapp-button-list-section.js.map +1 -0
- package/lib/cjs/content-fields/whatsapp-button-list/flow-whatsapp-button-list.d.ts +12 -0
- package/lib/cjs/content-fields/whatsapp-button-list/flow-whatsapp-button-list.js +33 -0
- package/lib/cjs/content-fields/whatsapp-button-list/flow-whatsapp-button-list.js.map +1 -0
- package/lib/cjs/functions/conditional-provider.d.ts +2 -2
- package/lib/cjs/functions/conditional-provider.js +2 -2
- package/lib/cjs/functions/conditional-provider.js.map +1 -1
- package/lib/cjs/functions/conditional-queue-status.d.ts +7 -2
- package/lib/cjs/functions/conditional-queue-status.js +11 -1
- package/lib/cjs/functions/conditional-queue-status.js.map +1 -1
- package/lib/cjs/handoff.d.ts +2 -2
- package/lib/cjs/handoff.js +17 -9
- package/lib/cjs/handoff.js.map +1 -1
- package/lib/cjs/helpers.d.ts +2 -1
- package/lib/cjs/helpers.js +5 -13
- package/lib/cjs/helpers.js.map +1 -1
- package/lib/cjs/index.d.ts +10 -21
- package/lib/cjs/index.js +36 -151
- package/lib/cjs/index.js.map +1 -1
- package/lib/cjs/types.d.ts +8 -2
- package/lib/cjs/types.js.map +1 -1
- package/lib/esm/action.d.ts +16 -2
- package/lib/esm/action.js +21 -19
- package/lib/esm/action.js.map +1 -1
- package/lib/esm/api.d.ts +19 -0
- package/lib/esm/api.js +103 -0
- package/lib/esm/api.js.map +1 -0
- package/lib/esm/content-fields/content-fields-base.d.ts +4 -4
- package/lib/esm/content-fields/content-fields-base.js.map +1 -1
- package/lib/esm/content-fields/flow-button.d.ts +6 -3
- package/lib/esm/content-fields/flow-button.js +28 -21
- package/lib/esm/content-fields/flow-button.js.map +1 -1
- package/lib/esm/content-fields/flow-carousel.d.ts +3 -2
- package/lib/esm/content-fields/flow-carousel.js +4 -11
- package/lib/esm/content-fields/flow-carousel.js.map +1 -1
- package/lib/esm/content-fields/flow-element.d.ts +6 -3
- package/lib/esm/content-fields/flow-element.js +15 -5
- package/lib/esm/content-fields/flow-element.js.map +1 -1
- package/lib/esm/content-fields/flow-image.d.ts +2 -2
- package/lib/esm/content-fields/flow-image.js.map +1 -1
- package/lib/esm/content-fields/flow-text.d.ts +4 -3
- package/lib/esm/content-fields/flow-text.js +9 -9
- package/lib/esm/content-fields/flow-text.js.map +1 -1
- package/lib/esm/content-fields/flow-video.d.ts +2 -2
- package/lib/esm/content-fields/flow-video.js +0 -1
- package/lib/esm/content-fields/flow-video.js.map +1 -1
- package/lib/esm/content-fields/hubtype-fields/button.d.ts +9 -0
- package/lib/esm/content-fields/hubtype-fields/button.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/button.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/carousel.d.ts +16 -0
- package/lib/esm/content-fields/hubtype-fields/carousel.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/carousel.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/common.d.ts +55 -0
- package/lib/esm/content-fields/hubtype-fields/common.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/common.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/fallback.d.ts +9 -0
- package/lib/esm/content-fields/hubtype-fields/fallback.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/fallback.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/function.d.ts +28 -0
- package/lib/esm/content-fields/hubtype-fields/function.js +7 -0
- package/lib/esm/content-fields/hubtype-fields/function.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/handoff.d.ts +10 -0
- package/lib/esm/content-fields/hubtype-fields/handoff.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/handoff.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/image.d.ts +8 -0
- package/lib/esm/content-fields/hubtype-fields/image.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/image.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/index.d.ts +17 -0
- package/lib/esm/content-fields/hubtype-fields/index.js +18 -0
- package/lib/esm/content-fields/hubtype-fields/index.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/intent.d.ts +10 -0
- package/lib/esm/content-fields/hubtype-fields/intent.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/intent.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/keyword.d.ts +9 -0
- package/lib/esm/content-fields/hubtype-fields/keyword.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/keyword.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/node-types.d.ts +23 -0
- package/lib/esm/content-fields/hubtype-fields/node-types.js +28 -0
- package/lib/esm/content-fields/hubtype-fields/node-types.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/nodes.d.ts +16 -0
- package/lib/esm/content-fields/hubtype-fields/nodes.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/nodes.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/payload.d.ts +8 -0
- package/lib/esm/content-fields/hubtype-fields/payload.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/payload.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/start.d.ts +7 -0
- package/lib/esm/content-fields/hubtype-fields/start.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/start.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/text.d.ts +11 -0
- package/lib/esm/content-fields/hubtype-fields/text.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/text.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/url.d.ts +8 -0
- package/lib/esm/content-fields/hubtype-fields/url.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/url.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/video.d.ts +8 -0
- package/lib/esm/content-fields/hubtype-fields/video.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/video.js.map +1 -0
- package/lib/esm/content-fields/hubtype-fields/whatsapp-button-list.d.ts +21 -0
- package/lib/esm/content-fields/hubtype-fields/whatsapp-button-list.js +2 -0
- package/lib/esm/content-fields/hubtype-fields/whatsapp-button-list.js.map +1 -0
- package/lib/esm/content-fields/index.d.ts +7 -5
- package/lib/esm/content-fields/index.js +6 -4
- package/lib/esm/content-fields/index.js.map +1 -1
- package/lib/esm/content-fields/whatsapp-button-list/flow-whatsapp-button-list-row.d.ts +10 -0
- package/lib/esm/content-fields/whatsapp-button-list/flow-whatsapp-button-list-row.js +28 -0
- package/lib/esm/content-fields/whatsapp-button-list/flow-whatsapp-button-list-row.js.map +1 -0
- package/lib/esm/content-fields/whatsapp-button-list/flow-whatsapp-button-list-section.d.ts +10 -0
- package/lib/esm/content-fields/whatsapp-button-list/flow-whatsapp-button-list-section.js +25 -0
- package/lib/esm/content-fields/whatsapp-button-list/flow-whatsapp-button-list-section.js.map +1 -0
- package/lib/esm/content-fields/whatsapp-button-list/flow-whatsapp-button-list.d.ts +12 -0
- package/lib/esm/content-fields/whatsapp-button-list/flow-whatsapp-button-list.js +28 -0
- package/lib/esm/content-fields/whatsapp-button-list/flow-whatsapp-button-list.js.map +1 -0
- package/lib/esm/functions/conditional-provider.d.ts +2 -2
- package/lib/esm/functions/conditional-provider.js +2 -2
- package/lib/esm/functions/conditional-provider.js.map +1 -1
- package/lib/esm/functions/conditional-queue-status.d.ts +7 -2
- package/lib/esm/functions/conditional-queue-status.js +11 -1
- package/lib/esm/functions/conditional-queue-status.js.map +1 -1
- package/lib/esm/handoff.d.ts +2 -2
- package/lib/esm/handoff.js +17 -9
- package/lib/esm/handoff.js.map +1 -1
- package/lib/esm/helpers.d.ts +2 -1
- package/lib/esm/helpers.js +3 -11
- package/lib/esm/helpers.js.map +1 -1
- package/lib/esm/index.d.ts +10 -21
- package/lib/esm/index.js +38 -153
- package/lib/esm/index.js.map +1 -1
- package/lib/esm/types.d.ts +8 -2
- package/lib/esm/types.js.map +1 -1
- package/package.json +4 -5
- package/src/action.tsx +31 -22
- package/src/api.ts +162 -0
- package/src/content-fields/content-fields-base.ts +7 -7
- package/src/content-fields/flow-button.tsx +40 -19
- package/src/content-fields/flow-carousel.tsx +10 -18
- package/src/content-fields/flow-element.tsx +26 -9
- package/src/content-fields/flow-image.tsx +2 -2
- package/src/content-fields/flow-text.tsx +15 -12
- package/src/content-fields/flow-video.tsx +2 -3
- package/src/content-fields/hubtype-fields/button.ts +15 -0
- package/src/content-fields/hubtype-fields/carousel.ts +18 -0
- package/src/content-fields/hubtype-fields/common.ts +65 -0
- package/src/content-fields/hubtype-fields/fallback.ts +10 -0
- package/src/content-fields/hubtype-fields/function.ts +33 -0
- package/src/content-fields/hubtype-fields/handoff.ts +11 -0
- package/src/content-fields/hubtype-fields/image.ts +9 -0
- package/src/content-fields/hubtype-fields/index.ts +17 -0
- package/src/content-fields/hubtype-fields/intent.ts +11 -0
- package/src/content-fields/hubtype-fields/keyword.ts +10 -0
- package/src/content-fields/hubtype-fields/node-types.ts +26 -0
- package/src/content-fields/hubtype-fields/nodes.ts +32 -0
- package/src/content-fields/hubtype-fields/payload.ts +9 -0
- package/src/content-fields/hubtype-fields/start.ts +8 -0
- package/src/content-fields/hubtype-fields/text.ts +12 -0
- package/src/content-fields/hubtype-fields/url.ts +9 -0
- package/src/content-fields/hubtype-fields/video.ts +9 -0
- package/src/content-fields/hubtype-fields/whatsapp-button-list.ts +25 -0
- package/src/content-fields/index.ts +14 -5
- package/src/content-fields/whatsapp-button-list/flow-whatsapp-button-list-row.tsx +33 -0
- package/src/content-fields/whatsapp-button-list/flow-whatsapp-button-list-section.tsx +35 -0
- package/src/content-fields/whatsapp-button-list/flow-whatsapp-button-list.tsx +46 -0
- package/src/functions/conditional-provider.ts +2 -2
- package/src/functions/conditional-queue-status.ts +22 -3
- package/src/handoff.ts +27 -14
- package/src/helpers.ts +8 -19
- package/src/index.ts +55 -197
- package/src/types.ts +14 -2
- package/lib/cjs/content-fields/types.d.ts +0 -5
- package/lib/cjs/content-fields/types.js.map +0 -1
- package/lib/cjs/flow-builder-models.d.ts +0 -196
- package/lib/cjs/flow-builder-models.js +0 -24
- package/lib/cjs/flow-builder-models.js.map +0 -1
- package/lib/esm/content-fields/types.d.ts +0 -5
- package/lib/esm/content-fields/types.js +0 -2
- package/lib/esm/content-fields/types.js.map +0 -1
- package/lib/esm/flow-builder-models.d.ts +0 -196
- package/lib/esm/flow-builder-models.js +0 -21
- package/lib/esm/flow-builder-models.js.map +0 -1
- package/src/.DS_Store +0 -0
- package/src/content-fields/types.ts +0 -6
- package/src/flow-builder-models.ts +0 -249
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { WhatsappButtonList } from '@botonic/react';
|
|
2
|
+
import React from 'react';
|
|
3
|
+
import { ContentFieldsBase } from './../content-fields-base';
|
|
4
|
+
import { FlowWhatsappButtonListSection } from './flow-whatsapp-button-list-section';
|
|
5
|
+
export class FlowWhatsappButtonList extends ContentFieldsBase {
|
|
6
|
+
constructor() {
|
|
7
|
+
super(...arguments);
|
|
8
|
+
this.code = '';
|
|
9
|
+
this.text = '';
|
|
10
|
+
this.listButtonText = '';
|
|
11
|
+
this.sections = [];
|
|
12
|
+
}
|
|
13
|
+
static fromHubtypeCMS(component, locale) {
|
|
14
|
+
const newWhatsappButtonList = new FlowWhatsappButtonList(component.id);
|
|
15
|
+
newWhatsappButtonList.code = component.code;
|
|
16
|
+
newWhatsappButtonList.text = this.getTextByLocale(locale, component.content.text);
|
|
17
|
+
newWhatsappButtonList.listButtonText = this.getTextByLocale(locale, component.content.button_text);
|
|
18
|
+
newWhatsappButtonList.sections = component.content.sections.map(section => FlowWhatsappButtonListSection.fromHubtypeCMS(section, locale));
|
|
19
|
+
return newWhatsappButtonList;
|
|
20
|
+
}
|
|
21
|
+
toBotonic(id) {
|
|
22
|
+
return (React.createElement(WhatsappButtonList, { key: id, body: this.text, action: {
|
|
23
|
+
button: this.listButtonText,
|
|
24
|
+
sections: this.sections.map(section => section.toBotonic()),
|
|
25
|
+
} }));
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=flow-whatsapp-button-list.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"flow-whatsapp-button-list.js","sourceRoot":"","sources":["../../../../src/content-fields/whatsapp-button-list/flow-whatsapp-button-list.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAA;AACnD,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAA;AAC5D,OAAO,EAAE,6BAA6B,EAAE,MAAM,qCAAqC,CAAA;AAEnF,MAAM,OAAO,sBAAuB,SAAQ,iBAAiB;IAA7D;;QACS,SAAI,GAAG,EAAE,CAAA;QACT,SAAI,GAAG,EAAE,CAAA;QACT,mBAAc,GAAG,EAAE,CAAA;QACnB,aAAQ,GAAoC,EAAE,CAAA;IAkCvD,CAAC;IAhCC,MAAM,CAAC,cAAc,CACnB,SAAmC,EACnC,MAAc;QAEd,MAAM,qBAAqB,GAAG,IAAI,sBAAsB,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QACtE,qBAAqB,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAA;QAC3C,qBAAqB,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,CAC/C,MAAM,EACN,SAAS,CAAC,OAAO,CAAC,IAAI,CACvB,CAAA;QACD,qBAAqB,CAAC,cAAc,GAAG,IAAI,CAAC,eAAe,CACzD,MAAM,EACN,SAAS,CAAC,OAAO,CAAC,WAAW,CAC9B,CAAA;QACD,qBAAqB,CAAC,QAAQ,GAAG,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CACxE,6BAA6B,CAAC,cAAc,CAAC,OAAO,EAAE,MAAM,CAAC,CAC9D,CAAA;QACD,OAAO,qBAAqB,CAAA;IAC9B,CAAC;IAED,SAAS,CAAC,EAAU;QAClB,OAAO,CACL,oBAAC,kBAAkB,IACjB,GAAG,EAAE,EAAE,EACP,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,MAAM,EAAE;gBACN,MAAM,EAAE,IAAI,CAAC,cAAc;gBAC3B,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC;aAC5D,GACmB,CACvB,CAAA;IACH,CAAC;CACF"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
export function conditionalProvider({
|
|
2
|
-
const provider = session.user.provider;
|
|
1
|
+
export function conditionalProvider({ request, results }) {
|
|
2
|
+
const provider = request.session.user.provider;
|
|
3
3
|
if (results.includes(provider))
|
|
4
4
|
return provider;
|
|
5
5
|
return 'default';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"conditional-provider.js","sourceRoot":"","sources":["../../../src/functions/conditional-provider.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,mBAAmB,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE;IACtD,MAAM,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAA;
|
|
1
|
+
{"version":3,"file":"conditional-provider.js","sourceRoot":"","sources":["../../../src/functions/conditional-provider.ts"],"names":[],"mappings":"AAAA,MAAM,UAAU,mBAAmB,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE;IACtD,MAAM,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAA;IAC9C,IAAI,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAAE,OAAO,QAAQ,CAAA;IAC/C,OAAO,SAAS,CAAA;AAClB,CAAC"}
|
|
@@ -1,3 +1,8 @@
|
|
|
1
|
-
|
|
1
|
+
import { ActionRequest } from '@botonic/react';
|
|
2
|
+
type ConditionalQueueStatusArgs = {
|
|
3
|
+
request: ActionRequest;
|
|
2
4
|
queue_id: string;
|
|
3
|
-
|
|
5
|
+
queue_name: string;
|
|
6
|
+
};
|
|
7
|
+
export declare function conditionalQueueStatus({ request, queue_id, queue_name, }: ConditionalQueueStatusArgs): Promise<string>;
|
|
8
|
+
export {};
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import axios from 'axios';
|
|
2
|
+
import { getFlowBuilderPlugin } from '../helpers';
|
|
2
3
|
import { getWebpackEnvVar } from '../utils';
|
|
3
4
|
const _HUBTYPE_API_URL_ = getWebpackEnvVar(
|
|
4
5
|
// @ts-ignore
|
|
5
6
|
typeof HUBTYPE_API_URL !== 'undefined' && HUBTYPE_API_URL, 'HUBTYPE_API_URL', 'https://api.hubtype.com');
|
|
6
|
-
export async function conditionalQueueStatus({ queue_id, }) {
|
|
7
|
+
export async function conditionalQueueStatus({ request, queue_id, queue_name, }) {
|
|
7
8
|
const response = await axios.get(`${_HUBTYPE_API_URL_}/v1/queues/${queue_id}/availability/`,
|
|
8
9
|
// TODO: Make it configurable in the future
|
|
9
10
|
{
|
|
@@ -14,6 +15,15 @@ export async function conditionalQueueStatus({ queue_id, }) {
|
|
|
14
15
|
},
|
|
15
16
|
});
|
|
16
17
|
const isAvailable = response.data.available;
|
|
18
|
+
const flowBuilderPlugin = getFlowBuilderPlugin(request.plugins);
|
|
19
|
+
if (flowBuilderPlugin.trackEvent) {
|
|
20
|
+
const eventName = `QUEUE_${isAvailable ? 'OPEN' : 'CLOSED'}`;
|
|
21
|
+
const args = {
|
|
22
|
+
queue_id,
|
|
23
|
+
queue_name,
|
|
24
|
+
};
|
|
25
|
+
await flowBuilderPlugin.trackEvent(request, eventName, args);
|
|
26
|
+
}
|
|
17
27
|
return isAvailable ? 'open' : 'closed';
|
|
18
28
|
}
|
|
19
29
|
//# sourceMappingURL=conditional-queue-status.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"conditional-queue-status.js","sourceRoot":"","sources":["../../../src/functions/conditional-queue-status.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"conditional-queue-status.js","sourceRoot":"","sources":["../../../src/functions/conditional-queue-status.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,OAAO,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAA;AACjD,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAA;AAE3C,MAAM,iBAAiB,GAAG,gBAAgB;AACxC,aAAa;AACb,OAAO,eAAe,KAAK,WAAW,IAAI,eAAe,EACzD,iBAAiB,EACjB,yBAAyB,CAC1B,CAAA;AAQD,MAAM,CAAC,KAAK,UAAU,sBAAsB,CAAC,EAC3C,OAAO,EACP,QAAQ,EACR,UAAU,GACiB;IAC3B,MAAM,QAAQ,GAAG,MAAM,KAAK,CAAC,GAAG,CAC9B,GAAG,iBAAiB,cAAc,QAAQ,gBAAgB;IAC1D,2CAA2C;IAC3C;QACE,MAAM,EAAE;YACN,oBAAoB,EAAE,IAAI;YAC1B,mBAAmB,EAAE,KAAK;YAC1B,sBAAsB,EAAE,KAAK;SAC9B;KACF,CACF,CAAA;IACD,MAAM,WAAW,GAAG,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAA;IAE3C,MAAM,iBAAiB,GAAG,oBAAoB,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;IAC/D,IAAI,iBAAiB,CAAC,UAAU,EAAE;QAChC,MAAM,SAAS,GAAG,SAAS,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAA;QAC5D,MAAM,IAAI,GAAG;YACX,QAAQ;YACR,UAAU;SACX,CAAA;QACD,MAAM,iBAAiB,CAAC,UAAU,CAAC,OAAO,EAAE,SAAS,EAAE,IAAI,CAAC,CAAA;KAC7D;IAED,OAAO,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAA;AACxC,CAAC"}
|
package/lib/esm/handoff.d.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { ActionRequest } from '@botonic/react';
|
|
2
|
-
import {
|
|
3
|
-
export declare function doHandoff(request: ActionRequest, locale: string, handoffNode:
|
|
2
|
+
import { HtHandoffNode } from './content-fields/hubtype-fields';
|
|
3
|
+
export declare function doHandoff(request: ActionRequest, locale: string, handoffNode: HtHandoffNode): Promise<void>;
|
package/lib/esm/handoff.js
CHANGED
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
import { HandOffBuilder } from '@botonic/core';
|
|
2
2
|
import { getFlowBuilderPlugin } from './helpers';
|
|
3
3
|
export async function doHandoff(request, locale, handoffNode) {
|
|
4
|
+
const flowBuilderPlugin = getFlowBuilderPlugin(request.plugins);
|
|
4
5
|
// @ts-ignore
|
|
5
6
|
const handOffBuilder = new HandOffBuilder(request.session);
|
|
6
7
|
const handoffQueues = handoffNode.content.queue;
|
|
7
8
|
const queueFound = handoffQueues.find(q => q.locale === locale);
|
|
8
9
|
if (queueFound)
|
|
9
10
|
handOffBuilder.withQueue(queueFound.id);
|
|
10
|
-
const onFinishPayload = await getOnFinishPayload(handoffNode, locale
|
|
11
|
+
const onFinishPayload = await getOnFinishPayload(flowBuilderPlugin, handoffNode, locale);
|
|
11
12
|
if (onFinishPayload)
|
|
12
13
|
handOffBuilder.withOnFinishPayload(onFinishPayload);
|
|
13
14
|
if (handoffNode.content.has_auto_assign) {
|
|
@@ -25,17 +26,24 @@ export async function doHandoff(request, locale, handoffNode) {
|
|
|
25
26
|
// handOffBuilder.withAgentEmail(handoffParams.agentEmail)
|
|
26
27
|
// }
|
|
27
28
|
await handOffBuilder.handOff();
|
|
29
|
+
if (flowBuilderPlugin.trackEvent) {
|
|
30
|
+
await flowBuilderPlugin.trackEvent(request, 'HANDOFF_SUCCESSFULL', {
|
|
31
|
+
queue_id: queueFound === null || queueFound === void 0 ? void 0 : queueFound.id,
|
|
32
|
+
queue_name: queueFound === null || queueFound === void 0 ? void 0 : queueFound.name,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
28
35
|
}
|
|
29
|
-
async function getOnFinishPayload(handoffNode, locale
|
|
30
|
-
var _a, _b;
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
+
async function getOnFinishPayload(flowBuilderPlugin, handoffNode, locale) {
|
|
37
|
+
var _a, _b, _c;
|
|
38
|
+
if ((_a = handoffNode.target) === null || _a === void 0 ? void 0 : _a.id) {
|
|
39
|
+
const handoffTargetNode = flowBuilderPlugin.cmsApi.getNode((_b = handoffNode.target) === null || _b === void 0 ? void 0 : _b.id);
|
|
40
|
+
if (handoffTargetNode === null || handoffTargetNode === void 0 ? void 0 : handoffTargetNode.id)
|
|
41
|
+
return handoffTargetNode === null || handoffTargetNode === void 0 ? void 0 : handoffTargetNode.id;
|
|
42
|
+
}
|
|
43
|
+
const payloadId = (_c = handoffNode.content.payload.find(payload => payload.locale === locale)) === null || _c === void 0 ? void 0 : _c.id;
|
|
36
44
|
if (!payloadId)
|
|
37
45
|
return undefined;
|
|
38
|
-
const actionPayload =
|
|
46
|
+
const actionPayload = flowBuilderPlugin.cmsApi.getNode(payloadId);
|
|
39
47
|
return actionPayload.content.payload;
|
|
40
48
|
}
|
|
41
49
|
//# sourceMappingURL=handoff.js.map
|
package/lib/esm/handoff.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handoff.js","sourceRoot":"","sources":["../../src/handoff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAI9C,OAAO,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAA;
|
|
1
|
+
{"version":3,"file":"handoff.js","sourceRoot":"","sources":["../../src/handoff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAI9C,OAAO,EAAE,oBAAoB,EAAE,MAAM,WAAW,CAAA;AAGhD,MAAM,CAAC,KAAK,UAAU,SAAS,CAC7B,OAAsB,EACtB,MAAc,EACd,WAA0B;IAE1B,MAAM,iBAAiB,GAAG,oBAAoB,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;IAC/D,aAAa;IACb,MAAM,cAAc,GAAG,IAAI,cAAc,CAAC,OAAO,CAAC,OAAO,CAAC,CAAA;IAC1D,MAAM,aAAa,GAAG,WAAW,CAAC,OAAO,CAAC,KAAK,CAAA;IAC/C,MAAM,UAAU,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,CAAA;IAC/D,IAAI,UAAU;QAAE,cAAc,CAAC,SAAS,CAAC,UAAU,CAAC,EAAE,CAAC,CAAA;IAEvD,MAAM,eAAe,GAAG,MAAM,kBAAkB,CAC9C,iBAAiB,EACjB,WAAW,EACX,MAAM,CACP,CAAA;IACD,IAAI,eAAe;QAAE,cAAc,CAAC,mBAAmB,CAAC,eAAe,CAAC,CAAA;IACxE,IAAI,WAAW,CAAC,OAAO,CAAC,eAAe,EAAE;QACvC,cAAc,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAA;KAC7C;IAED,yCAAyC;IACzC,0BAA0B;IAC1B,kCAAkC;IAClC,4EAA4E;IAC5E,IAAI;IAEJ,4BAA4B;IAC5B,gDAAgD;IAChD,IAAI;IAEJ,kCAAkC;IAClC,4DAA4D;IAC5D,IAAI;IAEJ,MAAM,cAAc,CAAC,OAAO,EAAE,CAAA;IAE9B,IAAI,iBAAiB,CAAC,UAAU,EAAE;QAChC,MAAM,iBAAiB,CAAC,UAAU,CAAC,OAAO,EAAE,qBAAqB,EAAE;YACjE,QAAQ,EAAE,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,EAAE;YACxB,UAAU,EAAE,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,IAAI;SAC7B,CAAC,CAAA;KACH;AACH,CAAC;AAED,KAAK,UAAU,kBAAkB,CAC/B,iBAA2C,EAC3C,WAA0B,EAC1B,MAAc;;IAEd,IAAI,MAAA,WAAW,CAAC,MAAM,0CAAE,EAAE,EAAE;QAC1B,MAAM,iBAAiB,GAAG,iBAAiB,CAAC,MAAM,CAAC,OAAO,CACxD,MAAA,WAAW,CAAC,MAAM,0CAAE,EAAE,CACvB,CAAA;QACD,IAAI,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAE,EAAE;YAAE,OAAO,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAE,EAAE,CAAA;KACxD;IAED,MAAM,SAAS,GAAG,MAAA,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAChD,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,MAAM,KAAK,MAAM,CACrC,0CAAE,EAAE,CAAA;IAEL,IAAI,CAAC,SAAS;QAAE,OAAO,SAAS,CAAA;IAEhC,MAAM,aAAa,GAAG,iBAAiB,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAA;IAEjE,OAAQ,aAA+B,CAAC,OAAO,CAAC,OAAO,CAAA;AACzD,CAAC"}
|
package/lib/esm/helpers.d.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Plugin } from '@botonic/core';
|
|
2
|
+
import { HtHandoffNode, HtNodeWithContent } from './content-fields/hubtype-fields';
|
|
2
3
|
import BotonicPluginFlowBuilder from './index';
|
|
3
4
|
export declare function getFlowBuilderPlugin(plugins: {
|
|
4
5
|
[id: string]: Plugin;
|
|
5
6
|
}): BotonicPluginFlowBuilder;
|
|
6
|
-
export declare function
|
|
7
|
+
export declare function isHandoffNode(node: HtNodeWithContent): node is HtHandoffNode;
|
package/lib/esm/helpers.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { HtNodeWithContentType, } from './content-fields/hubtype-fields';
|
|
1
2
|
const FLOW_BUILDER_PLUGIN_NAME = 'BotonicPluginFlowBuilder';
|
|
2
3
|
export function getFlowBuilderPlugin(plugins) {
|
|
3
4
|
const flowBuilderPlugin = Object.values(plugins).find(
|
|
@@ -7,16 +8,7 @@ export function getFlowBuilderPlugin(plugins) {
|
|
|
7
8
|
throw new Error(`You must include '@botonic/plugin-flow-builder' in your plugins file.`);
|
|
8
9
|
return flowBuilderPlugin;
|
|
9
10
|
}
|
|
10
|
-
export
|
|
11
|
-
|
|
12
|
-
for (const i in hubtypeContent.content[contentKey]) {
|
|
13
|
-
const button = hubtypeContent.content[contentKey][i].button;
|
|
14
|
-
if (button === null || button === void 0 ? void 0 : button.url) {
|
|
15
|
-
for (const j in button.url) {
|
|
16
|
-
button.url[j] = Object.assign(Object.assign({}, button.url[j]), (await getContentFn(button.url[j].id)));
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
}
|
|
11
|
+
export function isHandoffNode(node) {
|
|
12
|
+
return node.type === HtNodeWithContentType.HANDOFF;
|
|
21
13
|
}
|
|
22
14
|
//# sourceMappingURL=helpers.js.map
|
package/lib/esm/helpers.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../src/helpers.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../src/helpers.ts"],"names":[],"mappings":"AAEA,OAAO,EAGL,qBAAqB,GACtB,MAAM,iCAAiC,CAAA;AAGxC,MAAM,wBAAwB,GAAG,0BAA0B,CAAA;AAE3D,MAAM,UAAU,oBAAoB,CAAC,OAEpC;IACC,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI;IACnD,aAAa;IACb,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,wBAAwB,CAAC,CAC7B,CAAA;IAC7B,IAAI,CAAC,iBAAiB;QACpB,MAAM,IAAI,KAAK,CACb,uEAAuE,CACxE,CAAA;IACH,OAAO,iBAAiB,CAAA;AAC1B,CAAC;AAED,MAAM,UAAU,aAAa,CAAC,IAAuB;IACnD,OAAO,IAAI,CAAC,IAAI,KAAK,qBAAqB,CAAC,OAAO,CAAA;AACpD,CAAC"}
|
package/lib/esm/index.d.ts
CHANGED
|
@@ -1,36 +1,25 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Plugin, PluginPostRequest, PluginPreRequest, Session } from '@botonic/core';
|
|
2
|
+
import { ActionRequest } from '@botonic/react';
|
|
3
|
+
import { FlowBuilderApi } from './api';
|
|
2
4
|
import { FlowContent } from './content-fields';
|
|
3
|
-
import {
|
|
5
|
+
import { HtFunctionNode, HtHandoffNode, HtNodeWithContent } from './content-fields/hubtype-fields';
|
|
4
6
|
import { BotonicPluginFlowBuilderOptions } from './types';
|
|
5
7
|
export default class BotonicPluginFlowBuilder implements Plugin {
|
|
6
8
|
readonly options: BotonicPluginFlowBuilderOptions;
|
|
7
|
-
|
|
8
|
-
private flow;
|
|
9
|
+
cmsApi: FlowBuilderApi;
|
|
9
10
|
private functions;
|
|
10
11
|
private currentRequest;
|
|
11
12
|
private getAccessToken;
|
|
12
13
|
getLocale: (session: Session) => string;
|
|
14
|
+
trackEvent?: (request: ActionRequest, eventName: string, args?: Record<string, any>) => Promise<void>;
|
|
13
15
|
constructor(options: BotonicPluginFlowBuilderOptions);
|
|
14
|
-
readFlowContent(session: Session): Promise<FlowBuilderData>;
|
|
15
16
|
pre(request: PluginPreRequest): Promise<void>;
|
|
16
17
|
post(_request: PluginPostRequest): Promise<void>;
|
|
17
|
-
getContent(
|
|
18
|
-
getContentByCode(code: string): Promise<NodeComponent>;
|
|
19
|
-
getHandoffContent(handoffTargetId: string | undefined): Promise<HandoffNode | undefined>;
|
|
20
|
-
getFlowContent(hubtypeContent: NodeComponent, locale: string): FlowContent | undefined;
|
|
21
|
-
getStartId(): Promise<string>;
|
|
22
|
-
getFallbackId(alternate: boolean): Promise<string>;
|
|
23
|
-
getContents(id: string, locale: string, prevContents?: FlowContent[]): Promise<{
|
|
18
|
+
getContent(nodeOrId: HtNodeWithContent | string, locale: string, prevContents?: FlowContent[]): Promise<{
|
|
24
19
|
contents: FlowContent[];
|
|
25
|
-
handoffNode
|
|
20
|
+
handoffNode?: HtHandoffNode;
|
|
26
21
|
}>;
|
|
27
|
-
private
|
|
28
|
-
|
|
29
|
-
hasIntent(node: IntentNode, intent: string, locale: string): boolean;
|
|
30
|
-
hasMetConfidenceThreshold(node: IntentNode, predictedConfidence: number): boolean;
|
|
31
|
-
getPayloadByKeyword(input: Input, locale: string): Promise<string | undefined>;
|
|
32
|
-
matchKeywords(node: KeywordNode, input: string, locale: string): boolean;
|
|
33
|
-
containsAnyKeywords(input: string, keywords: string[]): boolean;
|
|
34
|
-
callFunction(functionNode: FunctionNode, locale: string): Promise<string>;
|
|
22
|
+
private getFlowContent;
|
|
23
|
+
callFunction(functionNode: HtFunctionNode, locale: string): Promise<string>;
|
|
35
24
|
}
|
|
36
25
|
export * from './action';
|
package/lib/esm/index.js
CHANGED
|
@@ -1,177 +1,62 @@
|
|
|
1
|
-
import
|
|
2
|
-
import { FlowCarousel, FlowImage, FlowText, FlowVideo, } from './content-fields';
|
|
3
|
-
import {
|
|
1
|
+
import { FlowBuilderApi } from './api';
|
|
2
|
+
import { FlowCarousel, FlowImage, FlowText, FlowVideo, FlowWhatsappButtonList, } from './content-fields';
|
|
3
|
+
import { HtNodeWithContentType, } from './content-fields/hubtype-fields';
|
|
4
4
|
import { DEFAULT_FUNCTIONS } from './functions';
|
|
5
|
-
import {
|
|
5
|
+
import { isHandoffNode } from './helpers';
|
|
6
6
|
import { resolveGetAccessToken } from './utils';
|
|
7
7
|
export default class BotonicPluginFlowBuilder {
|
|
8
8
|
constructor(options) {
|
|
9
9
|
this.options = options;
|
|
10
|
+
this.cmsApi = new FlowBuilderApi({
|
|
11
|
+
url: options.flowUrl,
|
|
12
|
+
flow: options.flow,
|
|
13
|
+
});
|
|
10
14
|
this.getLocale = options.getLocale;
|
|
11
15
|
this.getAccessToken = resolveGetAccessToken(options);
|
|
12
|
-
this.
|
|
13
|
-
if (options.flow)
|
|
14
|
-
this.flow = options.flow;
|
|
16
|
+
this.trackEvent = options.trackEvent;
|
|
15
17
|
const customFunctions = options.customFunctions || {};
|
|
16
18
|
this.functions = Object.assign(Object.assign({}, DEFAULT_FUNCTIONS), customFunctions);
|
|
17
19
|
}
|
|
18
|
-
async readFlowContent(session) {
|
|
19
|
-
const { data } = await axios.get(this.flowUrl, {
|
|
20
|
-
headers: { Authorization: `Bearer ${this.getAccessToken(session)}` },
|
|
21
|
-
});
|
|
22
|
-
return data;
|
|
23
|
-
}
|
|
24
20
|
async pre(request) {
|
|
25
21
|
this.currentRequest = request;
|
|
26
|
-
|
|
22
|
+
await this.cmsApi.init(this.getAccessToken(request.session));
|
|
27
23
|
}
|
|
28
24
|
async post(_request) { }
|
|
29
|
-
async getContent(
|
|
30
|
-
const flow = await this.flow;
|
|
31
|
-
const content = flow.nodes.find(node => node.id === id);
|
|
32
|
-
if (!content)
|
|
33
|
-
throw Error(`Node with id: '${id}' not found`);
|
|
34
|
-
return content;
|
|
35
|
-
}
|
|
36
|
-
async getContentByCode(code) {
|
|
37
|
-
const flow = await this.flow;
|
|
38
|
-
const content = flow.nodes.find(node => {
|
|
39
|
-
if ('code' in node)
|
|
40
|
-
return node.code === code;
|
|
41
|
-
return undefined;
|
|
42
|
-
});
|
|
43
|
-
if (!content)
|
|
44
|
-
throw Error(`Node with code: '${code}' not found`);
|
|
45
|
-
return content;
|
|
46
|
-
}
|
|
47
|
-
async getHandoffContent(handoffTargetId) {
|
|
48
|
-
if (!handoffTargetId)
|
|
49
|
-
return undefined;
|
|
50
|
-
return (await this.getContent(handoffTargetId));
|
|
51
|
-
}
|
|
52
|
-
getFlowContent(hubtypeContent, locale) {
|
|
53
|
-
switch (hubtypeContent.type) {
|
|
54
|
-
case NodeType.TEXT:
|
|
55
|
-
return FlowText.fromHubtypeCMS(hubtypeContent, locale);
|
|
56
|
-
case NodeType.IMAGE:
|
|
57
|
-
return FlowImage.fromHubtypeCMS(hubtypeContent, locale);
|
|
58
|
-
case NodeType.CAROUSEL:
|
|
59
|
-
return FlowCarousel.fromHubtypeCMS(hubtypeContent, locale);
|
|
60
|
-
case NodeType.VIDEO:
|
|
61
|
-
return FlowVideo.fromHubtypeCMS(hubtypeContent, locale);
|
|
62
|
-
default:
|
|
63
|
-
return undefined;
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
async getStartId() {
|
|
67
|
-
const flow = await this.flow;
|
|
68
|
-
const startNode = flow.nodes.find(node => node.type === NodeType.START_UP);
|
|
69
|
-
if (!startNode)
|
|
70
|
-
throw new Error('start-up id must be defined');
|
|
71
|
-
return startNode.target.id;
|
|
72
|
-
}
|
|
73
|
-
async getFallbackId(alternate) {
|
|
74
|
-
const flow = await this.flow;
|
|
75
|
-
const fallbackNode = flow.nodes.find(node => node.type === NodeType.FALLBACK);
|
|
76
|
-
if (!fallbackNode)
|
|
77
|
-
throw new Error('fallback node must be defined');
|
|
78
|
-
const fallbackFirstMessage = fallbackNode.content.first_message;
|
|
79
|
-
const fallbackSecondMessage = fallbackNode.content.second_message;
|
|
80
|
-
if (!fallbackSecondMessage)
|
|
81
|
-
return fallbackFirstMessage.id;
|
|
82
|
-
return alternate ? fallbackFirstMessage.id : fallbackSecondMessage.id;
|
|
83
|
-
}
|
|
84
|
-
async getContents(id, locale, prevContents) {
|
|
25
|
+
async getContent(nodeOrId, locale, prevContents) {
|
|
85
26
|
const contents = prevContents || [];
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
await
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
const targetId = await this.callFunction(hubtypeContent, locale);
|
|
95
|
-
return this.getContents(targetId, locale, contents);
|
|
27
|
+
let node = nodeOrId;
|
|
28
|
+
if (typeof nodeOrId === 'string') {
|
|
29
|
+
node = this.cmsApi.getNode(nodeOrId);
|
|
30
|
+
}
|
|
31
|
+
const content = await this.getFlowContent(node, locale);
|
|
32
|
+
if (node.type === HtNodeWithContentType.FUNCTION) {
|
|
33
|
+
const targetId = await this.callFunction(node, locale);
|
|
34
|
+
return this.getContent(targetId, locale, contents);
|
|
96
35
|
}
|
|
97
36
|
else {
|
|
98
37
|
if (content)
|
|
99
38
|
contents.push(content);
|
|
100
39
|
// TODO: prevent infinite recursive calls
|
|
101
|
-
if (
|
|
102
|
-
return this.
|
|
40
|
+
if (node.follow_up)
|
|
41
|
+
return this.getContent(node.follow_up.id, locale, contents);
|
|
103
42
|
}
|
|
104
|
-
|
|
105
|
-
// return this.getContents(function result_mapping target, locale, contents)
|
|
106
|
-
return { contents, handoffNode: isHandoff && hubtypeContent };
|
|
43
|
+
return { contents, handoffNode: isHandoffNode(node) ? node : undefined };
|
|
107
44
|
}
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
try {
|
|
123
|
-
const flow = await this.flow;
|
|
124
|
-
const intents = flow.nodes.filter(node => node.type === NodeType.INTENT);
|
|
125
|
-
const inputIntent = input.intent;
|
|
126
|
-
const inputConfidence = input.confidence;
|
|
127
|
-
if (inputIntent) {
|
|
128
|
-
const matchedIntentNode = intents.find(node => inputIntent &&
|
|
129
|
-
this.hasIntent(node, inputIntent, locale) &&
|
|
130
|
-
inputConfidence &&
|
|
131
|
-
this.hasMetConfidenceThreshold(node, inputConfidence));
|
|
132
|
-
return (_a = matchedIntentNode === null || matchedIntentNode === void 0 ? void 0 : matchedIntentNode.target) === null || _a === void 0 ? void 0 : _a.id;
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
catch (error) {
|
|
136
|
-
console.error('Error getting payload by input: ', error);
|
|
137
|
-
}
|
|
138
|
-
return undefined;
|
|
139
|
-
}
|
|
140
|
-
hasIntent(node, intent, locale) {
|
|
141
|
-
return node.content.intents.some(i => i.locale === locale && i.values.includes(intent));
|
|
142
|
-
}
|
|
143
|
-
hasMetConfidenceThreshold(node, predictedConfidence) {
|
|
144
|
-
const nodeConfidence = node.content.confidence / 100;
|
|
145
|
-
return predictedConfidence >= nodeConfidence;
|
|
146
|
-
}
|
|
147
|
-
async getPayloadByKeyword(input, locale) {
|
|
148
|
-
var _a;
|
|
149
|
-
try {
|
|
150
|
-
const flow = await this.flow;
|
|
151
|
-
const keywordNodes = flow.nodes.filter(node => node.type == NodeType.KEYWORD);
|
|
152
|
-
const matchedKeywordNodes = keywordNodes.filter(node =>
|
|
153
|
-
//@ts-ignore
|
|
154
|
-
this.matchKeywords(node, input.data, locale));
|
|
155
|
-
if (matchedKeywordNodes.length > 0) {
|
|
156
|
-
return (_a = matchedKeywordNodes[0].target) === null || _a === void 0 ? void 0 : _a.id;
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
catch (error) {
|
|
160
|
-
console.error('Error getting payload by input: ', error);
|
|
161
|
-
}
|
|
162
|
-
return undefined;
|
|
163
|
-
}
|
|
164
|
-
matchKeywords(node, input, locale) {
|
|
165
|
-
const result = node.content.keywords.find(i => i.locale === locale && this.containsAnyKeywords(input, i.values));
|
|
166
|
-
return Boolean(result);
|
|
167
|
-
}
|
|
168
|
-
containsAnyKeywords(input, keywords) {
|
|
169
|
-
for (let i = 0; i < keywords.length; i++) {
|
|
170
|
-
if (input.includes(keywords[i])) {
|
|
171
|
-
return true;
|
|
172
|
-
}
|
|
45
|
+
getFlowContent(hubtypeContent, locale) {
|
|
46
|
+
switch (hubtypeContent.type) {
|
|
47
|
+
case HtNodeWithContentType.TEXT:
|
|
48
|
+
return FlowText.fromHubtypeCMS(hubtypeContent, locale, this.cmsApi);
|
|
49
|
+
case HtNodeWithContentType.IMAGE:
|
|
50
|
+
return FlowImage.fromHubtypeCMS(hubtypeContent, locale);
|
|
51
|
+
case HtNodeWithContentType.CAROUSEL:
|
|
52
|
+
return FlowCarousel.fromHubtypeCMS(hubtypeContent, locale, this.cmsApi);
|
|
53
|
+
case HtNodeWithContentType.VIDEO:
|
|
54
|
+
return FlowVideo.fromHubtypeCMS(hubtypeContent, locale);
|
|
55
|
+
case HtNodeWithContentType.WHATSAPP_BUTTON_LIST:
|
|
56
|
+
return FlowWhatsappButtonList.fromHubtypeCMS(hubtypeContent, locale);
|
|
57
|
+
default:
|
|
58
|
+
return undefined;
|
|
173
59
|
}
|
|
174
|
-
return false;
|
|
175
60
|
}
|
|
176
61
|
async callFunction(functionNode, locale) {
|
|
177
62
|
var _a;
|
|
@@ -179,13 +64,13 @@ export default class BotonicPluginFlowBuilder {
|
|
|
179
64
|
const nameValues = ((_a = functionNode.content.arguments
|
|
180
65
|
.find(arg => arg.locale === locale)) === null || _a === void 0 ? void 0 : _a.values.map(value => ({ [value.name]: value.value }))) || [];
|
|
181
66
|
const args = Object.assign({
|
|
182
|
-
|
|
67
|
+
request: this.currentRequest,
|
|
183
68
|
results: [functionNode.content.result_mapping.map(r => r.result)],
|
|
184
69
|
}, ...nameValues);
|
|
185
70
|
const functionResult = await this.functions[functionNode.content.action](args);
|
|
186
71
|
// TODO define result_mapping per locale??
|
|
187
72
|
const result = functionNode.content.result_mapping.find(r => r.result === functionResult);
|
|
188
|
-
if (!result) {
|
|
73
|
+
if (!(result === null || result === void 0 ? void 0 : result.target)) {
|
|
189
74
|
throw new Error(`No result found for result_mapping for node with id: ${functionNodeId}`);
|
|
190
75
|
}
|
|
191
76
|
return result.target.id;
|
package/lib/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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"}
|
package/lib/esm/types.d.ts
CHANGED
|
@@ -1,11 +1,17 @@
|
|
|
1
1
|
import { Session } from '@botonic/core';
|
|
2
|
-
import {
|
|
2
|
+
import { ActionRequest } from '@botonic/react';
|
|
3
|
+
import { HtFlowBuilderData } from './content-fields/hubtype-fields';
|
|
3
4
|
export interface BotonicPluginFlowBuilderOptions {
|
|
4
5
|
flowUrl: string;
|
|
5
|
-
flow?:
|
|
6
|
+
flow?: HtFlowBuilderData;
|
|
6
7
|
customFunctions?: Record<any, any>;
|
|
7
8
|
getLocale: (session: Session) => string;
|
|
8
9
|
getAccessToken: () => string;
|
|
10
|
+
trackEvent?: (request: ActionRequest, eventName: string, args?: Record<string, any>) => Promise<void>;
|
|
11
|
+
}
|
|
12
|
+
export interface FlowBuilderApiOptions {
|
|
13
|
+
url: string;
|
|
14
|
+
flow?: HtFlowBuilderData;
|
|
9
15
|
}
|
|
10
16
|
export declare enum ProcessEnvNodeEnvs {
|
|
11
17
|
PRODUCTION = "production",
|
package/lib/esm/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"AAwBA,MAAM,CAAN,IAAY,kBAGX;AAHD,WAAY,kBAAkB;IAC5B,+CAAyB,CAAA;IACzB,iDAA2B,CAAA;AAC7B,CAAC,EAHW,kBAAkB,KAAlB,kBAAkB,QAG7B"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@botonic/plugin-flow-builder",
|
|
3
|
-
"version": "0.22.
|
|
3
|
+
"version": "0.22.1",
|
|
4
4
|
"main": "./lib/cjs/index.js",
|
|
5
5
|
"module": "./lib/esm/index.js",
|
|
6
6
|
"description": "Use Flow Builder to show your contents",
|
|
@@ -30,9 +30,8 @@
|
|
|
30
30
|
],
|
|
31
31
|
"devDependencies": {
|
|
32
32
|
"@types/minipass": "^3.3.5",
|
|
33
|
-
"@types/node": "^16.0
|
|
34
|
-
"@types/react": "^16.
|
|
35
|
-
"typescript": "^5.0.4"
|
|
33
|
+
"@types/node": "^18.16.0",
|
|
34
|
+
"@types/react": "^16.14.43"
|
|
36
35
|
},
|
|
37
36
|
"keywords": [
|
|
38
37
|
"bot-framework",
|
|
@@ -48,7 +47,7 @@
|
|
|
48
47
|
},
|
|
49
48
|
"dependencies": {
|
|
50
49
|
"@babel/runtime": "^7.21.0",
|
|
51
|
-
"@botonic/react": "^0.22.0
|
|
50
|
+
"@botonic/react": "^0.22.0",
|
|
52
51
|
"axios": "^1.3.6"
|
|
53
52
|
}
|
|
54
53
|
}
|