@capillarytech/creatives-library 8.0.271 → 8.0.273
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/assets/Android.png +0 -0
- package/assets/iOS.png +0 -0
- package/constants/unified.js +2 -1
- package/initialReducer.js +2 -0
- package/package.json +1 -1
- package/services/api.js +10 -0
- package/services/tests/api.test.js +34 -0
- package/tests/integration/TemplateCreation/TemplateCreation.integration.test.js +17 -35
- package/tests/integration/TemplateCreation/api-response.js +31 -1
- package/tests/integration/TemplateCreation/msw-handler.js +2 -0
- package/utils/common.js +5 -0
- package/utils/commonUtils.js +28 -5
- package/utils/imageUrlUpload.js +13 -14
- package/utils/tests/commonUtil.test.js +224 -0
- package/utils/tests/imageUrlUpload.test.js +298 -0
- package/utils/transformTemplateConfig.js +0 -10
- package/v2Components/CapDeviceContent/index.js +61 -56
- package/v2Components/CapTagList/index.js +6 -1
- package/v2Components/CapTagListWithInput/index.js +5 -1
- package/v2Components/CapTagListWithInput/messages.js +1 -1
- package/v2Components/CapWhatsappCTA/tests/index.test.js +5 -0
- package/v2Components/ErrorInfoNote/constants.js +1 -0
- package/v2Components/ErrorInfoNote/index.js +402 -72
- package/v2Components/ErrorInfoNote/messages.js +32 -6
- package/v2Components/ErrorInfoNote/style.scss +278 -6
- package/v2Components/FormBuilder/tests/index.test.js +13 -4
- package/v2Components/HtmlEditor/HTMLEditor.js +418 -99
- package/v2Components/HtmlEditor/__tests__/HTMLEditor.apiErrors.test.js +870 -0
- package/v2Components/HtmlEditor/__tests__/HTMLEditor.test.js +1882 -133
- package/v2Components/HtmlEditor/__tests__/index.lazy.test.js +27 -16
- package/v2Components/HtmlEditor/_htmlEditor.scss +108 -45
- package/v2Components/HtmlEditor/_index.lazy.scss +0 -1
- package/v2Components/HtmlEditor/components/CodeEditorPane/_codeEditorPane.scss +23 -102
- package/v2Components/HtmlEditor/components/CodeEditorPane/index.js +148 -140
- package/v2Components/HtmlEditor/components/DeviceToggle/_deviceToggle.scss +2 -1
- package/v2Components/HtmlEditor/components/DeviceToggle/index.js +3 -3
- package/v2Components/HtmlEditor/components/EditorToolbar/_editorToolbar.scss +9 -1
- package/v2Components/HtmlEditor/components/EditorToolbar/index.js +31 -6
- package/v2Components/HtmlEditor/components/FullscreenModal/_fullscreenModal.scss +22 -0
- package/v2Components/HtmlEditor/components/InAppPreviewPane/DeviceFrame.js +4 -7
- package/v2Components/HtmlEditor/components/InAppPreviewPane/__tests__/DeviceFrame.test.js +35 -45
- package/v2Components/HtmlEditor/components/InAppPreviewPane/_inAppPreviewPane.scss +1 -3
- package/v2Components/HtmlEditor/components/InAppPreviewPane/constants.js +33 -33
- package/v2Components/HtmlEditor/components/InAppPreviewPane/index.js +7 -6
- package/v2Components/HtmlEditor/components/PreviewPane/_previewPane.scss +7 -10
- package/v2Components/HtmlEditor/components/PreviewPane/index.js +22 -43
- package/v2Components/HtmlEditor/components/SplitContainer/_splitContainer.scss +1 -1
- package/v2Components/HtmlEditor/components/ValidationErrorDisplay/_validationErrorDisplay.scss +18 -0
- package/v2Components/HtmlEditor/components/ValidationErrorDisplay/index.js +36 -31
- package/v2Components/HtmlEditor/components/ValidationPanel/_validationPanel.scss +46 -34
- package/v2Components/HtmlEditor/components/ValidationPanel/constants.js +6 -0
- package/v2Components/HtmlEditor/components/ValidationPanel/index.js +52 -46
- package/v2Components/HtmlEditor/components/ValidationTabs/_validationTabs.scss +277 -0
- package/v2Components/HtmlEditor/components/ValidationTabs/index.js +295 -0
- package/v2Components/HtmlEditor/components/ValidationTabs/messages.js +51 -0
- package/v2Components/HtmlEditor/constants.js +45 -20
- package/v2Components/HtmlEditor/hooks/__tests__/useInAppContent.test.js +373 -16
- package/v2Components/HtmlEditor/hooks/__tests__/useValidation.test.js +351 -16
- package/v2Components/HtmlEditor/hooks/useEditorContent.js +5 -2
- package/v2Components/HtmlEditor/hooks/useInAppContent.js +88 -146
- package/v2Components/HtmlEditor/hooks/useValidation.js +213 -56
- package/v2Components/HtmlEditor/index.js +1 -1
- package/v2Components/HtmlEditor/messages.js +102 -94
- package/v2Components/HtmlEditor/utils/__tests__/htmlValidator.enhanced.test.js +214 -45
- package/v2Components/HtmlEditor/utils/__tests__/validationAdapter.test.js +134 -0
- package/v2Components/HtmlEditor/utils/contentSanitizer.js +40 -41
- package/v2Components/HtmlEditor/utils/htmlValidator.js +71 -72
- package/v2Components/HtmlEditor/utils/liquidTemplateSupport.js +158 -124
- package/v2Components/HtmlEditor/utils/properSyntaxHighlighting.js +23 -25
- package/v2Components/HtmlEditor/utils/validationAdapter.js +66 -41
- package/v2Components/HtmlEditor/utils/validationConstants.js +38 -0
- package/v2Components/MobilePushPreviewV2/constants.js +6 -0
- package/v2Components/MobilePushPreviewV2/index.js +33 -7
- package/v2Components/TemplatePreview/_templatePreview.scss +55 -24
- package/v2Components/TemplatePreview/index.js +47 -32
- package/v2Components/TemplatePreview/messages.js +4 -0
- package/v2Components/TestAndPreviewSlidebox/_testAndPreviewSlidebox.scss +1 -0
- package/v2Containers/BeeEditor/index.js +172 -90
- package/v2Containers/BeePopupEditor/_beePopupEditor.scss +14 -0
- package/v2Containers/BeePopupEditor/constants.js +10 -0
- package/v2Containers/BeePopupEditor/index.js +194 -0
- package/v2Containers/BeePopupEditor/tests/index.test.js +627 -0
- package/v2Containers/CreativesContainer/SlideBoxContent.js +127 -51
- package/v2Containers/CreativesContainer/SlideBoxFooter.js +156 -13
- package/v2Containers/CreativesContainer/SlideBoxHeader.js +2 -1
- package/v2Containers/CreativesContainer/constants.js +1 -0
- package/v2Containers/CreativesContainer/index.js +251 -47
- package/v2Containers/CreativesContainer/messages.js +8 -0
- package/v2Containers/CreativesContainer/tests/SlideBoxFooter.test.js +11 -2
- package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +38 -50
- package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +103 -0
- package/v2Containers/Email/actions.js +7 -0
- package/v2Containers/Email/constants.js +5 -1
- package/v2Containers/Email/index.js +234 -29
- package/v2Containers/Email/messages.js +32 -0
- package/v2Containers/Email/reducer.js +12 -1
- package/v2Containers/Email/sagas.js +61 -7
- package/v2Containers/Email/tests/__snapshots__/reducer.test.js.snap +2 -0
- package/v2Containers/Email/tests/reducer.test.js +46 -0
- package/v2Containers/Email/tests/sagas.test.js +320 -29
- package/v2Containers/EmailWrapper/components/EmailHTMLEditor.js +1246 -0
- package/v2Containers/EmailWrapper/components/EmailWrapperView.js +212 -21
- package/v2Containers/EmailWrapper/components/HTMLEditorTesting.js +40 -74
- package/v2Containers/EmailWrapper/components/__tests__/EmailHTMLEditor.test.js +2614 -0
- package/v2Containers/EmailWrapper/components/__tests__/EmailWrapperView.test.js +520 -0
- package/v2Containers/EmailWrapper/components/__tests__/HTMLEditorTesting.test.js +2 -67
- package/v2Containers/EmailWrapper/constants.js +2 -0
- package/v2Containers/EmailWrapper/hooks/useEmailWrapper.js +627 -79
- package/v2Containers/EmailWrapper/index.js +103 -23
- package/v2Containers/EmailWrapper/messages.js +65 -1
- package/v2Containers/EmailWrapper/tests/useEmailWrapper.edgeCases.test.js +955 -0
- package/v2Containers/EmailWrapper/tests/useEmailWrapper.test.js +596 -82
- package/v2Containers/InApp/__tests__/InAppHTMLEditor.test.js +376 -0
- package/v2Containers/InApp/__tests__/sagas.test.js +363 -0
- package/v2Containers/InApp/actions.js +7 -0
- package/v2Containers/InApp/constants.js +20 -4
- package/v2Containers/InApp/index.js +802 -360
- package/v2Containers/InApp/index.scss +4 -3
- package/v2Containers/InApp/messages.js +7 -3
- package/v2Containers/InApp/reducer.js +21 -3
- package/v2Containers/InApp/sagas.js +29 -9
- package/v2Containers/InApp/selectors.js +25 -5
- package/v2Containers/InApp/tests/index.test.js +154 -50
- package/v2Containers/InApp/tests/reducer.test.js +34 -0
- package/v2Containers/InApp/tests/sagas.test.js +61 -9
- package/v2Containers/InApp/tests/selectors.test.js +612 -0
- package/v2Containers/InAppWrapper/components/InAppWrapperView.js +151 -0
- package/v2Containers/InAppWrapper/components/__tests__/InAppWrapperView.test.js +267 -0
- package/v2Containers/InAppWrapper/components/inAppWrapperView.scss +23 -0
- package/v2Containers/InAppWrapper/constants.js +16 -0
- package/v2Containers/InAppWrapper/hooks/__tests__/useInAppWrapper.test.js +473 -0
- package/v2Containers/InAppWrapper/hooks/useInAppWrapper.js +198 -0
- package/v2Containers/InAppWrapper/index.js +148 -0
- package/v2Containers/InAppWrapper/messages.js +49 -0
- package/v2Containers/InappAdvance/index.js +1099 -0
- package/v2Containers/InappAdvance/index.scss +10 -0
- package/v2Containers/InappAdvance/tests/index.test.js +448 -0
- package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/content.test.js.snap +3 -0
- package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/index.test.js.snap +2 -0
- package/v2Containers/Line/Container/Wrapper/tests/__snapshots__/index.test.js.snap +2 -0
- package/v2Containers/Line/Container/tests/__snapshots__/index.test.js.snap +9 -0
- package/v2Containers/MobilePush/Create/index.js +1 -1
- package/v2Containers/MobilePush/Edit/index.js +10 -6
- package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +12 -0
- package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +4 -0
- package/v2Containers/TagList/index.js +62 -19
- package/v2Containers/Templates/_templates.scss +60 -1
- package/v2Containers/Templates/index.js +89 -4
- package/v2Containers/Templates/messages.js +4 -0
- package/v2Containers/TemplatesV2/TemplatesV2.style.js +4 -2
- package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +34 -0
- package/v2Components/HtmlEditor/components/ValidationErrorDisplay/__tests__/index.test.js +0 -152
- package/v2Containers/EmailWrapper/tests/EmailWrapperView.test.js +0 -214
|
@@ -0,0 +1,363 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* InApp Sagas Tests
|
|
3
|
+
*
|
|
4
|
+
* Tests for InApp sagas including HTML content create/edit flows
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import { call, put } from 'redux-saga/effects';
|
|
8
|
+
import * as Api from '../../../services/api';
|
|
9
|
+
import {
|
|
10
|
+
inAppTemplateCreate,
|
|
11
|
+
editTemplate,
|
|
12
|
+
getTemplateDetails,
|
|
13
|
+
uploadInAppAsset,
|
|
14
|
+
} from '../sagas';
|
|
15
|
+
import {
|
|
16
|
+
INAPP_TEMPLATE_CREATE_SUCCESS,
|
|
17
|
+
INAPP_TEMPLATE_CREATE_FAILURE,
|
|
18
|
+
INAPP_EDIT_TEMPLATE_SUCCESS,
|
|
19
|
+
INAPP_EDIT_TEMPLATE_FAILURE,
|
|
20
|
+
GET_INAPP_TEMPLATE_DETAILS_SUCCESS,
|
|
21
|
+
GET_INAPP_TEMPLATE_DETAILS_FAILURE,
|
|
22
|
+
UPLOAD_INAPP_ASSET_SUCCESS,
|
|
23
|
+
UPLOAD_INAPP_ASSET_FAILURE,
|
|
24
|
+
} from '../constants';
|
|
25
|
+
import { INAPP } from '../../CreativesContainer/constants';
|
|
26
|
+
|
|
27
|
+
describe('InApp Sagas', () => {
|
|
28
|
+
describe('inAppTemplateCreate', () => {
|
|
29
|
+
const payload = {
|
|
30
|
+
name: 'Test Template',
|
|
31
|
+
versions: {
|
|
32
|
+
base: {
|
|
33
|
+
content: {
|
|
34
|
+
ANDROID: {
|
|
35
|
+
title: 'Android Title',
|
|
36
|
+
message: '<p>Android HTML Content</p>',
|
|
37
|
+
bodyType: 'MODAL',
|
|
38
|
+
},
|
|
39
|
+
IOS: {
|
|
40
|
+
title: 'iOS Title',
|
|
41
|
+
message: '<p>iOS HTML Content</p>',
|
|
42
|
+
bodyType: 'MODAL',
|
|
43
|
+
},
|
|
44
|
+
},
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
type: INAPP,
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
test('creates template successfully with HTML content', () => {
|
|
51
|
+
const generator = inAppTemplateCreate({
|
|
52
|
+
payload,
|
|
53
|
+
callback: jest.fn(),
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
const mockResponse = {
|
|
57
|
+
response: {
|
|
58
|
+
id: 'template-123',
|
|
59
|
+
name: 'Test Template',
|
|
60
|
+
},
|
|
61
|
+
status: {
|
|
62
|
+
code: 201,
|
|
63
|
+
},
|
|
64
|
+
};
|
|
65
|
+
|
|
66
|
+
expect(generator.next().value).toEqual(
|
|
67
|
+
call(Api.createChannelWiseTemplate, { channel: INAPP, template: payload })
|
|
68
|
+
);
|
|
69
|
+
|
|
70
|
+
expect(generator.next(mockResponse).value).toEqual(
|
|
71
|
+
put({
|
|
72
|
+
type: INAPP_TEMPLATE_CREATE_SUCCESS,
|
|
73
|
+
data: mockResponse.response,
|
|
74
|
+
statusCode: 201,
|
|
75
|
+
errorMsg: undefined,
|
|
76
|
+
})
|
|
77
|
+
);
|
|
78
|
+
|
|
79
|
+
const callback = generator.next().value;
|
|
80
|
+
expect(callback).toBeUndefined(); // Callback is called but not yielded
|
|
81
|
+
|
|
82
|
+
expect(generator.next().done).toBe(true);
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
test('handles API error when creating template', () => {
|
|
86
|
+
const generator = inAppTemplateCreate({
|
|
87
|
+
payload,
|
|
88
|
+
callback: jest.fn(),
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
const mockError = {
|
|
92
|
+
response: null,
|
|
93
|
+
status: {
|
|
94
|
+
code: 400,
|
|
95
|
+
},
|
|
96
|
+
message: 'Validation error',
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
expect(generator.next().value).toEqual(
|
|
100
|
+
call(Api.createChannelWiseTemplate, { channel: INAPP, template: payload })
|
|
101
|
+
);
|
|
102
|
+
|
|
103
|
+
expect(generator.next(mockError).value).toEqual(
|
|
104
|
+
put({
|
|
105
|
+
type: INAPP_TEMPLATE_CREATE_FAILURE,
|
|
106
|
+
error: 'Validation error',
|
|
107
|
+
errorMsg: 'Validation error',
|
|
108
|
+
})
|
|
109
|
+
);
|
|
110
|
+
|
|
111
|
+
const callback = generator.next().value;
|
|
112
|
+
expect(callback).toBeUndefined();
|
|
113
|
+
|
|
114
|
+
expect(generator.next().done).toBe(true);
|
|
115
|
+
});
|
|
116
|
+
|
|
117
|
+
test('handles exception during template creation', () => {
|
|
118
|
+
const generator = inAppTemplateCreate({
|
|
119
|
+
payload,
|
|
120
|
+
callback: jest.fn(),
|
|
121
|
+
});
|
|
122
|
+
|
|
123
|
+
const error = new Error('Network error');
|
|
124
|
+
|
|
125
|
+
expect(generator.next().value).toEqual(
|
|
126
|
+
call(Api.createChannelWiseTemplate, { channel: INAPP, template: payload })
|
|
127
|
+
);
|
|
128
|
+
|
|
129
|
+
expect(generator.throw(error).value).toEqual(
|
|
130
|
+
put({
|
|
131
|
+
type: INAPP_TEMPLATE_CREATE_FAILURE,
|
|
132
|
+
error,
|
|
133
|
+
errorMsg: undefined,
|
|
134
|
+
})
|
|
135
|
+
);
|
|
136
|
+
|
|
137
|
+
expect(generator.next().done).toBe(true);
|
|
138
|
+
});
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
describe('editTemplate', () => {
|
|
142
|
+
const payload = {
|
|
143
|
+
_id: 'template-123',
|
|
144
|
+
name: 'Updated Template',
|
|
145
|
+
versions: {
|
|
146
|
+
base: {
|
|
147
|
+
content: {
|
|
148
|
+
ANDROID: {
|
|
149
|
+
title: 'Updated Android Title',
|
|
150
|
+
message: '<p>Updated Android HTML</p>',
|
|
151
|
+
bodyType: 'MODAL',
|
|
152
|
+
},
|
|
153
|
+
IOS: {
|
|
154
|
+
title: 'Updated iOS Title',
|
|
155
|
+
message: '<p>Updated iOS HTML</p>',
|
|
156
|
+
bodyType: 'MODAL',
|
|
157
|
+
},
|
|
158
|
+
},
|
|
159
|
+
},
|
|
160
|
+
},
|
|
161
|
+
type: INAPP,
|
|
162
|
+
};
|
|
163
|
+
|
|
164
|
+
test('edits template successfully with HTML content', () => {
|
|
165
|
+
const generator = editTemplate({
|
|
166
|
+
payload,
|
|
167
|
+
callback: jest.fn(),
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
const mockResponse = {
|
|
171
|
+
response: {
|
|
172
|
+
id: 'template-123',
|
|
173
|
+
name: 'Updated Template',
|
|
174
|
+
},
|
|
175
|
+
status: {
|
|
176
|
+
code: 200,
|
|
177
|
+
},
|
|
178
|
+
};
|
|
179
|
+
|
|
180
|
+
expect(generator.next().value).toEqual(
|
|
181
|
+
call(Api.createChannelWiseTemplate, { channel: INAPP, template: payload })
|
|
182
|
+
);
|
|
183
|
+
|
|
184
|
+
expect(generator.next(mockResponse).value).toEqual(
|
|
185
|
+
put({
|
|
186
|
+
type: INAPP_EDIT_TEMPLATE_SUCCESS,
|
|
187
|
+
data: mockResponse.response,
|
|
188
|
+
statusCode: 200,
|
|
189
|
+
errorMsg: undefined,
|
|
190
|
+
})
|
|
191
|
+
);
|
|
192
|
+
|
|
193
|
+
expect(generator.next().done).toBe(true);
|
|
194
|
+
});
|
|
195
|
+
|
|
196
|
+
test('handles API error when editing template', () => {
|
|
197
|
+
const generator = editTemplate({
|
|
198
|
+
payload,
|
|
199
|
+
callback: jest.fn(),
|
|
200
|
+
});
|
|
201
|
+
|
|
202
|
+
const mockError = {
|
|
203
|
+
response: null,
|
|
204
|
+
status: {
|
|
205
|
+
code: 404,
|
|
206
|
+
},
|
|
207
|
+
message: 'Template not found',
|
|
208
|
+
};
|
|
209
|
+
|
|
210
|
+
expect(generator.next().value).toEqual(
|
|
211
|
+
call(Api.createChannelWiseTemplate, { channel: INAPP, template: payload })
|
|
212
|
+
);
|
|
213
|
+
|
|
214
|
+
expect(generator.next(mockError).value).toEqual(
|
|
215
|
+
put({
|
|
216
|
+
type: INAPP_EDIT_TEMPLATE_FAILURE,
|
|
217
|
+
error: 'Template not found',
|
|
218
|
+
errorMsg: 'Template not found',
|
|
219
|
+
})
|
|
220
|
+
);
|
|
221
|
+
|
|
222
|
+
expect(generator.next().done).toBe(true);
|
|
223
|
+
});
|
|
224
|
+
});
|
|
225
|
+
|
|
226
|
+
describe('getTemplateDetails', () => {
|
|
227
|
+
test('fetches template details successfully', () => {
|
|
228
|
+
const generator = getTemplateDetails({
|
|
229
|
+
id: 'template-123',
|
|
230
|
+
callback: jest.fn(),
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
const mockResponse = {
|
|
234
|
+
response: {
|
|
235
|
+
id: 'template-123',
|
|
236
|
+
name: 'Test Template',
|
|
237
|
+
versions: {
|
|
238
|
+
base: {
|
|
239
|
+
content: {
|
|
240
|
+
ANDROID: {
|
|
241
|
+
title: 'Android Title',
|
|
242
|
+
message: '<p>Android HTML Content</p>',
|
|
243
|
+
},
|
|
244
|
+
IOS: {
|
|
245
|
+
title: 'iOS Title',
|
|
246
|
+
message: '<p>iOS HTML Content</p>',
|
|
247
|
+
},
|
|
248
|
+
},
|
|
249
|
+
},
|
|
250
|
+
},
|
|
251
|
+
},
|
|
252
|
+
};
|
|
253
|
+
|
|
254
|
+
expect(generator.next().value).toEqual(
|
|
255
|
+
call(Api.getTemplateDetails, {
|
|
256
|
+
id: 'template-123',
|
|
257
|
+
channel: INAPP,
|
|
258
|
+
})
|
|
259
|
+
);
|
|
260
|
+
|
|
261
|
+
expect(generator.next(mockResponse).value).toEqual(
|
|
262
|
+
put({
|
|
263
|
+
type: GET_INAPP_TEMPLATE_DETAILS_SUCCESS,
|
|
264
|
+
data: mockResponse.response,
|
|
265
|
+
})
|
|
266
|
+
);
|
|
267
|
+
|
|
268
|
+
expect(generator.next().done).toBe(true);
|
|
269
|
+
});
|
|
270
|
+
|
|
271
|
+
test('handles error when fetching template details', () => {
|
|
272
|
+
const generator = getTemplateDetails({
|
|
273
|
+
id: 'template-123',
|
|
274
|
+
callback: jest.fn(),
|
|
275
|
+
});
|
|
276
|
+
|
|
277
|
+
const error = new Error('Not found');
|
|
278
|
+
|
|
279
|
+
expect(generator.next().value).toEqual(
|
|
280
|
+
call(Api.getTemplateDetails, {
|
|
281
|
+
id: 'template-123',
|
|
282
|
+
channel: INAPP,
|
|
283
|
+
})
|
|
284
|
+
);
|
|
285
|
+
|
|
286
|
+
expect(generator.throw(error).value).toEqual(
|
|
287
|
+
put({
|
|
288
|
+
type: GET_INAPP_TEMPLATE_DETAILS_FAILURE,
|
|
289
|
+
error,
|
|
290
|
+
})
|
|
291
|
+
);
|
|
292
|
+
|
|
293
|
+
expect(generator.next().done).toBe(true);
|
|
294
|
+
});
|
|
295
|
+
});
|
|
296
|
+
|
|
297
|
+
describe('uploadInAppAsset', () => {
|
|
298
|
+
test('uploads asset successfully', () => {
|
|
299
|
+
const params = {
|
|
300
|
+
file: new File(['test'], 'test.jpg'),
|
|
301
|
+
assetType: 'image',
|
|
302
|
+
fileParams: {},
|
|
303
|
+
templateType: INAPP,
|
|
304
|
+
};
|
|
305
|
+
|
|
306
|
+
const generator = uploadInAppAsset(params);
|
|
307
|
+
|
|
308
|
+
const mockResponse = {
|
|
309
|
+
response: {
|
|
310
|
+
asset: {
|
|
311
|
+
url: 'https://cdn.example.com/image.jpg',
|
|
312
|
+
id: 'asset-123',
|
|
313
|
+
},
|
|
314
|
+
},
|
|
315
|
+
status: {
|
|
316
|
+
code: 200,
|
|
317
|
+
},
|
|
318
|
+
};
|
|
319
|
+
|
|
320
|
+
expect(generator.next().value).toEqual(
|
|
321
|
+
call(Api.uploadFile, params)
|
|
322
|
+
);
|
|
323
|
+
|
|
324
|
+
expect(generator.next(mockResponse).value).toEqual(
|
|
325
|
+
put({
|
|
326
|
+
type: UPLOAD_INAPP_ASSET_SUCCESS,
|
|
327
|
+
data: mockResponse.response.asset,
|
|
328
|
+
statusCode: 200,
|
|
329
|
+
templateType: INAPP,
|
|
330
|
+
})
|
|
331
|
+
);
|
|
332
|
+
|
|
333
|
+
expect(generator.next().done).toBe(true);
|
|
334
|
+
});
|
|
335
|
+
|
|
336
|
+
test('handles error when uploading asset', () => {
|
|
337
|
+
const params = {
|
|
338
|
+
file: new File(['test'], 'test.jpg'),
|
|
339
|
+
assetType: 'image',
|
|
340
|
+
fileParams: {},
|
|
341
|
+
templateType: INAPP,
|
|
342
|
+
};
|
|
343
|
+
|
|
344
|
+
const generator = uploadInAppAsset(params);
|
|
345
|
+
|
|
346
|
+
const error = new Error('Upload failed');
|
|
347
|
+
|
|
348
|
+
expect(generator.next().value).toEqual(
|
|
349
|
+
call(Api.uploadFile, params)
|
|
350
|
+
);
|
|
351
|
+
|
|
352
|
+
expect(generator.throw(error).value).toEqual(
|
|
353
|
+
put({
|
|
354
|
+
type: UPLOAD_INAPP_ASSET_FAILURE,
|
|
355
|
+
error,
|
|
356
|
+
})
|
|
357
|
+
);
|
|
358
|
+
|
|
359
|
+
expect(generator.next().done).toBe(true);
|
|
360
|
+
});
|
|
361
|
+
});
|
|
362
|
+
});
|
|
363
|
+
|
|
@@ -7,6 +7,7 @@ import {
|
|
|
7
7
|
UPLOAD_INAPP_ASSET_REQUEST,
|
|
8
8
|
CLEAR_INAPP_ASSET,
|
|
9
9
|
INAPP_EDIT_TEMPLATE_REQUEST,
|
|
10
|
+
GET_BEE_POPUP_BUILDER_TOKEN_REQUEST,
|
|
10
11
|
} from "./constants";
|
|
11
12
|
|
|
12
13
|
export function createInAppTemplate(payload, callback) {
|
|
@@ -62,3 +63,9 @@ export const clearInAppAsset = (templateType) => ({
|
|
|
62
63
|
type: CLEAR_INAPP_ASSET,
|
|
63
64
|
templateType,
|
|
64
65
|
});
|
|
66
|
+
|
|
67
|
+
export function getBeePopupBuilderToken() {
|
|
68
|
+
return {
|
|
69
|
+
type: GET_BEE_POPUP_BUILDER_TOKEN_REQUEST,
|
|
70
|
+
};
|
|
71
|
+
}
|
|
@@ -34,12 +34,18 @@ export const UPLOAD_INAPP_ASSET_SUCCESS = `${prefix}/UPLOAD_INAPP_ASSET_SUCCESS`
|
|
|
34
34
|
export const UPLOAD_INAPP_ASSET_FAILURE = `${prefix}/UPLOAD_INAPP_ASSET_FAILURE`;
|
|
35
35
|
export const CLEAR_INAPP_ASSET = `${prefix}/CLEAR_INAPP_ASSET`;
|
|
36
36
|
|
|
37
|
+
export const GET_BEE_POPUP_BUILDER_TOKEN_REQUEST = `${prefix}/GET_BEE_POPUP_BUILDER_TOKEN_REQUEST`;
|
|
38
|
+
export const GET_BEE_POPUP_BUILDER_TOKEN_SUCCESS = `${prefix}/GET_BEE_POPUP_BUILDER_TOKEN_SUCCESS`;
|
|
39
|
+
export const GET_BEE_POPUP_BUILDER_TOKEN_FAILURE = `${prefix}/GET_BEE_POPUP_BUILDER_TOKEN_FAILURE`;
|
|
40
|
+
|
|
37
41
|
export const INAPP_MEDIA_TYPES = {
|
|
38
42
|
TEXT: "TEXT",
|
|
39
43
|
IMAGE: "IMAGE",
|
|
44
|
+
HTML: "HTML",
|
|
40
45
|
};
|
|
41
46
|
export const BIG_TEXT = 'BIG_TEXT';
|
|
42
47
|
export const BIG_PICTURE = 'BIG_PICTURE';
|
|
48
|
+
export const BIG_HTML = 'BIG_HTML';
|
|
43
49
|
export const NONE = "NONE";
|
|
44
50
|
export const CTA = "CTA";
|
|
45
51
|
export const MAPP_SDK = "MAPP_SDK";
|
|
@@ -70,14 +76,16 @@ export const INAPP_IMG_SIZE = 5000000; // 5MB
|
|
|
70
76
|
export const TEMPLATE_MESSAGE_MAX_LENGTH = 1024;
|
|
71
77
|
|
|
72
78
|
export const INAPP_MESSAGE_LAYOUT_TYPES = {
|
|
73
|
-
MODAL: "
|
|
79
|
+
MODAL: "MODAL",
|
|
74
80
|
TOPBANNER: "HEADER",
|
|
75
81
|
BOTTOMBANNER: "FOOTER",
|
|
76
82
|
FULLSCREEN: "FULLSCREEN",
|
|
83
|
+
POPUP: "POPUP",
|
|
77
84
|
};
|
|
78
85
|
|
|
79
86
|
export const ANDROID = "ANDROID";
|
|
80
87
|
export const IOS = "iOS";
|
|
88
|
+
export const IOS_CAPITAL = "IOS";
|
|
81
89
|
export const LAYOUT_RADIO_OPTIONS = [
|
|
82
90
|
{
|
|
83
91
|
value: INAPP_MESSAGE_LAYOUT_TYPES.MODAL,
|
|
@@ -136,6 +144,11 @@ export const BUTTON_RADIO_OPTIONS = [
|
|
|
136
144
|
];
|
|
137
145
|
|
|
138
146
|
export const INAPP_LAYOUT_DETAILS = {
|
|
147
|
+
MODAL: {
|
|
148
|
+
tagColor: CAP_ORANGE01,
|
|
149
|
+
tagTextColor: CAP_ORANGE,
|
|
150
|
+
text: <FormattedMessage {...messages.layoutModal} />,
|
|
151
|
+
},
|
|
139
152
|
POPUP: {
|
|
140
153
|
tagColor: CAP_ORANGE01,
|
|
141
154
|
tagTextColor: CAP_ORANGE,
|
|
@@ -144,12 +157,12 @@ export const INAPP_LAYOUT_DETAILS = {
|
|
|
144
157
|
HEADER: {
|
|
145
158
|
tagColor: CAP_PURPLE03,
|
|
146
159
|
tagTextColor: CAP_PURPLE02,
|
|
147
|
-
text: <FormattedMessage {...messages.
|
|
160
|
+
text: <FormattedMessage {...messages.layoutTopBanner} />,
|
|
148
161
|
},
|
|
149
162
|
FOOTER: {
|
|
150
163
|
tagColor: CAP_PALE_GREY,
|
|
151
164
|
tagTextColor: FONT_COLOR_05,
|
|
152
|
-
text: <FormattedMessage {...messages.
|
|
165
|
+
text: <FormattedMessage {...messages.layoutBottomBanner} />,
|
|
153
166
|
},
|
|
154
167
|
FULLSCREEN: {
|
|
155
168
|
tagColor: CAP_GREEN02,
|
|
@@ -159,4 +172,7 @@ export const INAPP_LAYOUT_DETAILS = {
|
|
|
159
172
|
};
|
|
160
173
|
|
|
161
174
|
export const DEVICE_SUPPORTED = '1';
|
|
162
|
-
export const AI_CONTENT_BOT_DISABLED = "AI_CONTENT_BOT_DISABLED";
|
|
175
|
+
export const AI_CONTENT_BOT_DISABLED = "AI_CONTENT_BOT_DISABLED";
|
|
176
|
+
export const MODE_SELECTION = "modeSelection";
|
|
177
|
+
export const BASIC_EDITOR = "basicEditor";
|
|
178
|
+
export const BEE_EDITOR = "beeEditor";
|