@capillarytech/creatives-library 8.0.353-alpha.6 → 8.0.354
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/constants/unified.js +0 -29
- package/index.html +1 -0
- package/package.json +1 -1
- package/services/tests/api.test.js +20 -35
- package/utils/cdnTransformation.js +63 -3
- package/utils/commonUtils.js +1 -19
- package/utils/tests/cdnTransformation.test.js +111 -0
- package/v2Components/CapActionButton/constants.js +0 -7
- package/v2Components/CapActionButton/index.js +108 -166
- package/v2Components/CapActionButton/index.scss +6 -157
- package/v2Components/CapActionButton/messages.js +3 -19
- package/v2Components/CapActionButton/tests/index.test.js +17 -41
- package/v2Components/CapTagList/index.js +0 -10
- package/v2Components/CommonTestAndPreview/CustomValuesEditor.js +49 -72
- package/v2Components/CommonTestAndPreview/DeliverySettings/DeliverySettings.scss +2 -8
- package/v2Components/CommonTestAndPreview/DeliverySettings/ModifyDeliverySettings.js +21 -213
- package/v2Components/CommonTestAndPreview/DeliverySettings/constants.js +0 -16
- package/v2Components/CommonTestAndPreview/DeliverySettings/index.js +10 -85
- package/v2Components/CommonTestAndPreview/DeliverySettings/messages.js +0 -30
- package/v2Components/CommonTestAndPreview/DeliverySettings/utils/parseSenderDetailsResponse.js +11 -79
- package/v2Components/CommonTestAndPreview/SendTestMessage.js +5 -10
- package/v2Components/CommonTestAndPreview/UnifiedPreview/RcsPreviewContent.js +15 -157
- package/v2Components/CommonTestAndPreview/UnifiedPreview/_unifiedPreview.scss +76 -346
- package/v2Components/CommonTestAndPreview/UnifiedPreview/index.js +4 -133
- package/v2Components/CommonTestAndPreview/_commonTestAndPreview.scss +0 -11
- package/v2Components/CommonTestAndPreview/constants.js +2 -38
- package/v2Components/CommonTestAndPreview/index.js +186 -691
- package/v2Components/CommonTestAndPreview/messages.js +3 -45
- package/v2Components/CommonTestAndPreview/sagas.js +6 -25
- package/v2Components/CommonTestAndPreview/tests/CustomValuesEditor.test.js +284 -308
- package/v2Components/CommonTestAndPreview/tests/DeliverySettings/ModifyDeliverySettings.test.js +65 -231
- package/v2Components/CommonTestAndPreview/tests/DeliverySettings/index.test.js +5 -118
- package/v2Components/CommonTestAndPreview/tests/DeliverySettings/utils/parseSenderDetailsResponse.test.js +0 -341
- package/v2Components/CommonTestAndPreview/tests/PreviewSection.test.js +1 -8
- package/v2Components/CommonTestAndPreview/tests/SendTestMessage.test.js +13 -34
- package/v2Components/CommonTestAndPreview/tests/UnifiedPreview/RcsPreviewContent.test.js +283 -281
- package/v2Components/CommonTestAndPreview/tests/UnifiedPreview/index.test.js +1 -199
- package/v2Components/CommonTestAndPreview/tests/index.test.js +4 -132
- package/v2Components/CommonTestAndPreview/tests/sagas.test.js +26 -36
- package/v2Components/FormBuilder/index.js +6 -11
- package/v2Components/TemplatePreview/_templatePreview.scss +23 -38
- package/v2Components/TemplatePreview/index.js +31 -143
- package/v2Components/TemplatePreview/tests/index.test.js +0 -142
- package/v2Components/TestAndPreviewSlidebox/index.js +1 -13
- package/v2Components/TestAndPreviewSlidebox/sagas.js +4 -11
- package/v2Components/TestAndPreviewSlidebox/tests/saga.test.js +1 -3
- package/v2Containers/CreativesContainer/SlideBoxContent.js +4 -36
- package/v2Containers/CreativesContainer/SlideBoxFooter.js +1 -10
- package/v2Containers/CreativesContainer/SlideBoxHeader.js +4 -29
- package/v2Containers/CreativesContainer/constants.js +0 -9
- package/v2Containers/CreativesContainer/index.js +103 -322
- package/v2Containers/CreativesContainer/index.scss +1 -51
- package/v2Containers/CreativesContainer/tests/SlideBoxFooter.test.js +34 -78
- package/v2Containers/CreativesContainer/tests/SlideBoxHeader.test.js +16 -79
- package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +0 -8
- package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxHeader.test.js.snap +98 -357
- package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +15 -20
- package/v2Containers/CreativesContainer/tests/index.test.js +9 -71
- package/v2Containers/MobilePush/Create/test/saga.test.js +2 -2
- package/v2Containers/Rcs/constants.js +10 -119
- package/v2Containers/Rcs/index.js +818 -2450
- package/v2Containers/Rcs/index.scss +8 -280
- package/v2Containers/Rcs/messages.js +3 -34
- package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +70073 -98018
- package/v2Containers/Rcs/tests/__snapshots__/utils.test.js.snap +5 -0
- package/v2Containers/Rcs/tests/index.test.js +121 -152
- package/v2Containers/Rcs/tests/mockData.js +0 -38
- package/v2Containers/Rcs/tests/utils.test.js +30 -646
- package/v2Containers/Rcs/utils.js +11 -478
- package/v2Containers/Sms/Create/index.js +40 -106
- package/v2Containers/SmsTrai/Create/index.js +4 -9
- package/v2Containers/SmsTrai/Edit/constants.js +0 -2
- package/v2Containers/SmsTrai/Edit/index.js +130 -640
- package/v2Containers/SmsTrai/Edit/messages.js +4 -14
- package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +2296 -4249
- package/v2Containers/SmsWrapper/index.js +8 -37
- package/v2Containers/TagList/index.js +0 -6
- package/v2Containers/Templates/_templates.scss +9 -166
- package/v2Containers/Templates/actions.js +0 -11
- package/v2Containers/Templates/constants.js +0 -2
- package/v2Containers/Templates/index.js +52 -120
- package/v2Containers/Templates/sagas.js +18 -57
- package/v2Containers/Templates/tests/__snapshots__/index.test.js.snap +1017 -1062
- package/v2Containers/Templates/tests/sagas.test.js +39 -205
- package/v2Containers/TemplatesV2/TemplatesV2.style.js +1 -72
- package/v2Containers/TemplatesV2/index.js +23 -86
- package/v2Containers/WeChat/MapTemplates/test/saga.test.js +9 -9
- package/v2Containers/Whatsapp/index.js +20 -3
- package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +34 -578
- package/utils/rcsPayloadUtils.js +0 -92
- package/utils/templateVarUtils.js +0 -201
- package/utils/tests/rcsPayloadUtils.test.js +0 -226
- package/utils/tests/templateVarUtils.test.js +0 -204
- package/v2Components/CommonTestAndPreview/previewApiUtils.js +0 -59
- package/v2Components/CommonTestAndPreview/tests/previewApiUtils.test.js +0 -67
- package/v2Components/SmsFallback/SmsFallbackLocalSelector.js +0 -91
- package/v2Components/SmsFallback/constants.js +0 -73
- package/v2Components/SmsFallback/index.js +0 -956
- package/v2Components/SmsFallback/index.scss +0 -265
- package/v2Components/SmsFallback/messages.js +0 -78
- package/v2Components/SmsFallback/smsFallbackUtils.js +0 -119
- package/v2Components/SmsFallback/tests/SmsFallbackLocalSelector.test.js +0 -50
- package/v2Components/SmsFallback/tests/rcsSmsFallback.acceptance.test.js +0 -147
- package/v2Components/SmsFallback/tests/smsFallbackHandlers.test.js +0 -304
- package/v2Components/SmsFallback/tests/smsFallbackUi.test.js +0 -223
- package/v2Components/SmsFallback/tests/smsFallbackUtils.test.js +0 -309
- package/v2Components/SmsFallback/tests/useLocalTemplateList.test.js +0 -422
- package/v2Components/SmsFallback/useLocalTemplateList.js +0 -92
- package/v2Components/TemplatePreview/constants.js +0 -2
- package/v2Components/VarSegmentMessageEditor/constants.js +0 -2
- package/v2Components/VarSegmentMessageEditor/index.js +0 -125
- package/v2Components/VarSegmentMessageEditor/index.scss +0 -46
- package/v2Containers/CreativesContainer/CreativesSlideBoxWrapper.js +0 -43
- package/v2Containers/CreativesContainer/embeddedSlideboxUtils.js +0 -79
- package/v2Containers/CreativesContainer/tests/SlideBoxContent.localTemplates.test.js +0 -90
- package/v2Containers/CreativesContainer/tests/embeddedSlideboxUtils.test.js +0 -258
- package/v2Containers/CreativesContainer/tests/useLocalTemplatesProp.test.js +0 -125
- package/v2Containers/Rcs/rcsLibraryHydrationUtils.js +0 -225
- package/v2Containers/Rcs/tests/rcsLibraryHydrationUtils.test.js +0 -318
- package/v2Containers/Sms/smsFormDataHelpers.js +0 -67
- package/v2Containers/Sms/tests/smsFormDataHelpers.test.js +0 -253
- package/v2Containers/SmsTrai/Edit/index.scss +0 -121
- package/v2Containers/Templates/TemplatesActionBar.js +0 -101
- package/v2Containers/Templates/tests/TemplatesActionBar.test.js +0 -120
- package/v2Containers/Templates/tests/smsTemplatesListApi.test.js +0 -180
- package/v2Containers/Templates/utils/smsTemplatesListApi.js +0 -79
- package/v2Containers/TemplatesV2/tests/TemplatesV2.localTemplates.test.js +0 -131
|
@@ -1,180 +0,0 @@
|
|
|
1
|
-
import * as Api from '../../../services/api';
|
|
2
|
-
import { isTraiDLTEnable } from '../../../utils/common';
|
|
3
|
-
|
|
4
|
-
jest.mock('../../../services/api', () => ({
|
|
5
|
-
getAllTemplates: jest.fn(),
|
|
6
|
-
}));
|
|
7
|
-
|
|
8
|
-
jest.mock('../../../utils/common', () => ({
|
|
9
|
-
isTraiDLTEnable: jest.fn(),
|
|
10
|
-
}));
|
|
11
|
-
|
|
12
|
-
import {
|
|
13
|
-
buildSmsTemplatesListQueryParams,
|
|
14
|
-
fetchSmsTemplatesFromQuery,
|
|
15
|
-
fetchSmsTemplatesListPage,
|
|
16
|
-
SMS_TEMPLATES_LIST_SORT_MOST_RECENT,
|
|
17
|
-
} from '../utils/smsTemplatesListApi';
|
|
18
|
-
|
|
19
|
-
describe('smsTemplatesListApi', () => {
|
|
20
|
-
beforeEach(() => {
|
|
21
|
-
jest.clearAllMocks();
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
describe('buildSmsTemplatesListQueryParams', () => {
|
|
25
|
-
it('includes traiEnable when TRAI DLT is enabled', () => {
|
|
26
|
-
isTraiDLTEnable.mockReturnValue(true);
|
|
27
|
-
const q = buildSmsTemplatesListQueryParams({
|
|
28
|
-
page: 1,
|
|
29
|
-
perPage: 25,
|
|
30
|
-
name: 'x',
|
|
31
|
-
sortBy: SMS_TEMPLATES_LIST_SORT_MOST_RECENT,
|
|
32
|
-
isFullMode: true,
|
|
33
|
-
smsRegister: {},
|
|
34
|
-
});
|
|
35
|
-
expect(q).toEqual({
|
|
36
|
-
page: 1,
|
|
37
|
-
perPage: 25,
|
|
38
|
-
sortBy: SMS_TEMPLATES_LIST_SORT_MOST_RECENT,
|
|
39
|
-
name: 'x',
|
|
40
|
-
traiEnable: true,
|
|
41
|
-
});
|
|
42
|
-
});
|
|
43
|
-
|
|
44
|
-
it('omits traiEnable when TRAI DLT is disabled', () => {
|
|
45
|
-
isTraiDLTEnable.mockReturnValue(false);
|
|
46
|
-
const q = buildSmsTemplatesListQueryParams({
|
|
47
|
-
page: 2,
|
|
48
|
-
perPage: 10,
|
|
49
|
-
isFullMode: false,
|
|
50
|
-
smsRegister: null,
|
|
51
|
-
});
|
|
52
|
-
expect(q.traiEnable).toBeUndefined();
|
|
53
|
-
expect(q.name).toBe('');
|
|
54
|
-
expect(q.sortBy).toBe(SMS_TEMPLATES_LIST_SORT_MOST_RECENT);
|
|
55
|
-
});
|
|
56
|
-
});
|
|
57
|
-
|
|
58
|
-
describe('fetchSmsTemplatesFromQuery', () => {
|
|
59
|
-
it('returns channelTemplates, weCRMTemplate, and raw; maps intl copy on names', async () => {
|
|
60
|
-
Api.getAllTemplates.mockResolvedValue({
|
|
61
|
-
response: {
|
|
62
|
-
templates: [{ name: 'Copy of A', _id: '1' }],
|
|
63
|
-
unMapped: { u: 1 },
|
|
64
|
-
totalCount: 5,
|
|
65
|
-
},
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
const out = await fetchSmsTemplatesFromQuery(
|
|
69
|
-
{ page: 1, perPage: 25 },
|
|
70
|
-
'Kopie',
|
|
71
|
-
);
|
|
72
|
-
|
|
73
|
-
expect(Api.getAllTemplates).toHaveBeenCalledWith({
|
|
74
|
-
channel: 'Sms',
|
|
75
|
-
queryParams: { page: 1, perPage: 25 },
|
|
76
|
-
});
|
|
77
|
-
expect(out.weCRMTemplate).toEqual({ u: 1 });
|
|
78
|
-
expect(out.raw.response.templates[0].name).toBe('Copy of A');
|
|
79
|
-
expect(out.channelTemplates.templates[0].name).toBe('Kopie A');
|
|
80
|
-
expect(out.channelTemplates.totalCount).toBe(5);
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
it('skips name mapping when intlCopyOf is empty', async () => {
|
|
84
|
-
Api.getAllTemplates.mockResolvedValue({
|
|
85
|
-
response: {
|
|
86
|
-
templates: [{ name: 'Copy of A' }],
|
|
87
|
-
},
|
|
88
|
-
});
|
|
89
|
-
const out = await fetchSmsTemplatesFromQuery({ page: 1 }, '');
|
|
90
|
-
expect(out.channelTemplates.templates[0].name).toBe('Copy of A');
|
|
91
|
-
});
|
|
92
|
-
|
|
93
|
-
it('handles missing response.templates', async () => {
|
|
94
|
-
Api.getAllTemplates.mockResolvedValue({ response: {} });
|
|
95
|
-
const out = await fetchSmsTemplatesFromQuery({}, '');
|
|
96
|
-
expect(out.channelTemplates.templates).toEqual([]);
|
|
97
|
-
});
|
|
98
|
-
|
|
99
|
-
it('uses empty response when raw.response is missing', async () => {
|
|
100
|
-
Api.getAllTemplates.mockResolvedValue({});
|
|
101
|
-
const out = await fetchSmsTemplatesFromQuery({}, '');
|
|
102
|
-
expect(out.channelTemplates.templates).toEqual([]);
|
|
103
|
-
expect(out.weCRMTemplate).toBeUndefined();
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
it('does not map names when intlCopyOf is set but templates list is empty', async () => {
|
|
107
|
-
Api.getAllTemplates.mockResolvedValue({
|
|
108
|
-
response: { templates: [] },
|
|
109
|
-
});
|
|
110
|
-
const out = await fetchSmsTemplatesFromQuery({ page: 1 }, 'X');
|
|
111
|
-
expect(out.channelTemplates.templates).toEqual([]);
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
it('uses empty string when template name is missing during intl mapping', async () => {
|
|
115
|
-
Api.getAllTemplates.mockResolvedValue({
|
|
116
|
-
response: {
|
|
117
|
-
templates: [{ _id: 'n', name: undefined }],
|
|
118
|
-
},
|
|
119
|
-
});
|
|
120
|
-
const out = await fetchSmsTemplatesFromQuery({ page: 1 }, 'Lbl');
|
|
121
|
-
expect(out.channelTemplates.templates[0].name).toBe('');
|
|
122
|
-
});
|
|
123
|
-
});
|
|
124
|
-
|
|
125
|
-
describe('fetchSmsTemplatesListPage', () => {
|
|
126
|
-
it('falls back to total when totalCount is absent', async () => {
|
|
127
|
-
isTraiDLTEnable.mockReturnValue(false);
|
|
128
|
-
Api.getAllTemplates.mockResolvedValue({
|
|
129
|
-
response: {
|
|
130
|
-
templates: [{ _id: 'a' }],
|
|
131
|
-
total: 7,
|
|
132
|
-
},
|
|
133
|
-
});
|
|
134
|
-
|
|
135
|
-
const page = await fetchSmsTemplatesListPage({
|
|
136
|
-
page: 1,
|
|
137
|
-
perPage: 25,
|
|
138
|
-
name: '',
|
|
139
|
-
sortBy: SMS_TEMPLATES_LIST_SORT_MOST_RECENT,
|
|
140
|
-
isFullMode: true,
|
|
141
|
-
smsRegister: {},
|
|
142
|
-
intlCopyOf: '',
|
|
143
|
-
});
|
|
144
|
-
|
|
145
|
-
expect(page.templates).toEqual([{ _id: 'a' }]);
|
|
146
|
-
expect(page.totalCount).toBe(7);
|
|
147
|
-
});
|
|
148
|
-
|
|
149
|
-
it('uses totalCount when set', async () => {
|
|
150
|
-
isTraiDLTEnable.mockReturnValue(false);
|
|
151
|
-
Api.getAllTemplates.mockResolvedValue({
|
|
152
|
-
response: {
|
|
153
|
-
templates: [],
|
|
154
|
-
totalCount: 12,
|
|
155
|
-
},
|
|
156
|
-
});
|
|
157
|
-
const page = await fetchSmsTemplatesListPage({
|
|
158
|
-
page: 1,
|
|
159
|
-
perPage: 25,
|
|
160
|
-
isFullMode: false,
|
|
161
|
-
smsRegister: {},
|
|
162
|
-
});
|
|
163
|
-
expect(page.totalCount).toBe(12);
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
it('normalizes total to 0 when missing counts', async () => {
|
|
167
|
-
isTraiDLTEnable.mockReturnValue(false);
|
|
168
|
-
Api.getAllTemplates.mockResolvedValue({
|
|
169
|
-
response: { templates: [] },
|
|
170
|
-
});
|
|
171
|
-
const page = await fetchSmsTemplatesListPage({
|
|
172
|
-
page: 1,
|
|
173
|
-
perPage: 25,
|
|
174
|
-
isFullMode: false,
|
|
175
|
-
smsRegister: {},
|
|
176
|
-
});
|
|
177
|
-
expect(page.totalCount).toBe(0);
|
|
178
|
-
});
|
|
179
|
-
});
|
|
180
|
-
});
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
import get from 'lodash/get';
|
|
2
|
-
import * as Api from '../../../services/api';
|
|
3
|
-
import { COPY_OF } from '../../../constants/unified';
|
|
4
|
-
import { isTraiDLTEnable } from '../../../utils/common';
|
|
5
|
-
|
|
6
|
-
/** Matches Templates `getAllTemplates` default for SMS. */
|
|
7
|
-
export const SMS_TEMPLATES_LIST_SORT_MOST_RECENT = 'Most Recent';
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Same query shape as Redux `GET_ALL_TEMPLATES` for channel Sms (DLT vs non-DLT via traiEnable).
|
|
11
|
-
*/
|
|
12
|
-
export function buildSmsTemplatesListQueryParams({
|
|
13
|
-
page,
|
|
14
|
-
perPage,
|
|
15
|
-
name = '',
|
|
16
|
-
sortBy = SMS_TEMPLATES_LIST_SORT_MOST_RECENT,
|
|
17
|
-
isFullMode,
|
|
18
|
-
smsRegister,
|
|
19
|
-
}) {
|
|
20
|
-
const traiDlt = isTraiDLTEnable(isFullMode, smsRegister);
|
|
21
|
-
return {
|
|
22
|
-
page,
|
|
23
|
-
perPage,
|
|
24
|
-
sortBy,
|
|
25
|
-
name: name || '',
|
|
26
|
-
...(traiDlt ? { traiEnable: true } : {}),
|
|
27
|
-
};
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* SMS list for Redux saga: uses queryParams already built by Templates (incl. traiEnable).
|
|
32
|
-
* Applies the same "Copy of" → intl label as the former inline saga logic.
|
|
33
|
-
*/
|
|
34
|
-
export async function fetchSmsTemplatesFromQuery(queryParams, intlCopyOf = '') {
|
|
35
|
-
const raw = await Api.getAllTemplates({ channel: 'Sms', queryParams });
|
|
36
|
-
const response = raw.response || {};
|
|
37
|
-
let templates = get(response, 'templates', []) || [];
|
|
38
|
-
if (intlCopyOf && templates.length) {
|
|
39
|
-
templates = templates.map((template) => ({
|
|
40
|
-
...template,
|
|
41
|
-
name: (template.name || '').replace(new RegExp(COPY_OF, 'g'), intlCopyOf),
|
|
42
|
-
}));
|
|
43
|
-
}
|
|
44
|
-
const channelTemplates = { ...response, templates };
|
|
45
|
-
return {
|
|
46
|
-
channelTemplates,
|
|
47
|
-
weCRMTemplate: response.unMapped,
|
|
48
|
-
raw,
|
|
49
|
-
};
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* SMS list for the RCS SMS fallback picker only.
|
|
54
|
-
* Called from `useLocalTemplateList` in SmsFallback — keeps data in component state and pairs with
|
|
55
|
-
* `localTemplatesConfig` / `useLocalTemplates` in TemplatesV2. Does **not** use GET_ALL_TEMPLATES saga.
|
|
56
|
-
* Same HTTP call shape as `fetchSmsTemplatesFromQuery` (used by the main SMS GET_ALL_TEMPLATES saga).
|
|
57
|
-
*/
|
|
58
|
-
export async function fetchSmsTemplatesListPage({
|
|
59
|
-
page,
|
|
60
|
-
perPage,
|
|
61
|
-
name,
|
|
62
|
-
sortBy,
|
|
63
|
-
isFullMode,
|
|
64
|
-
smsRegister,
|
|
65
|
-
intlCopyOf = '',
|
|
66
|
-
}) {
|
|
67
|
-
const queryParams = buildSmsTemplatesListQueryParams({
|
|
68
|
-
page,
|
|
69
|
-
perPage,
|
|
70
|
-
name,
|
|
71
|
-
sortBy,
|
|
72
|
-
isFullMode,
|
|
73
|
-
smsRegister,
|
|
74
|
-
});
|
|
75
|
-
const { channelTemplates } = await fetchSmsTemplatesFromQuery(queryParams, intlCopyOf);
|
|
76
|
-
const templates = channelTemplates.templates || [];
|
|
77
|
-
const totalCount = get(channelTemplates, 'totalCount', get(channelTemplates, 'total', 0)) || 0;
|
|
78
|
-
return { templates, totalCount };
|
|
79
|
-
}
|
|
@@ -1,131 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Embedded SMS template list: localTemplatesConfig + SMS-only channel visibility (RCS SMS fallback).
|
|
3
|
-
*/
|
|
4
|
-
import React from 'react';
|
|
5
|
-
import { injectIntl } from 'react-intl';
|
|
6
|
-
import '@testing-library/jest-dom';
|
|
7
|
-
import cloneDeep from 'lodash/cloneDeep';
|
|
8
|
-
import { Provider } from 'react-redux';
|
|
9
|
-
import { configureStore } from '@capillarytech/vulcan-react-sdk/utils';
|
|
10
|
-
import history from '../../../utils/history';
|
|
11
|
-
import { initialReducer } from '../../../initialReducer';
|
|
12
|
-
import { render, screen } from '../../../utils/test-utils';
|
|
13
|
-
import { TemplatesV2 } from '../index';
|
|
14
|
-
import { Templates, authData, currentOrgDetails as currentOrgDetailsMock } from './mockData';
|
|
15
|
-
import { CHANNELS_TO_HIDE_FOR_SMS_ONLY } from '../../../v2Components/SmsFallback/constants';
|
|
16
|
-
|
|
17
|
-
const mockTemplates = jest.fn(() => <div data-testid="templates-mock">Templates</div>);
|
|
18
|
-
jest.mock('v2Containers/Templates', () => ({
|
|
19
|
-
__esModule: true,
|
|
20
|
-
default: (props) => mockTemplates(props),
|
|
21
|
-
}));
|
|
22
|
-
|
|
23
|
-
jest.mock('../../../utils/authWrapper', () => ({
|
|
24
|
-
UserIsAuthenticated: jest.fn((config) => config),
|
|
25
|
-
}));
|
|
26
|
-
|
|
27
|
-
const ComponentToRender = injectIntl(TemplatesV2);
|
|
28
|
-
const renderComponent = (p) => {
|
|
29
|
-
const store = configureStore({}, initialReducer, history);
|
|
30
|
-
return render(
|
|
31
|
-
<Provider store={store}>
|
|
32
|
-
<ComponentToRender {...p} />
|
|
33
|
-
</Provider>,
|
|
34
|
-
);
|
|
35
|
-
};
|
|
36
|
-
|
|
37
|
-
describe('TemplatesV2 local SMS templates (embedded)', () => {
|
|
38
|
-
const templateActions = {
|
|
39
|
-
templateActions: jest.fn(),
|
|
40
|
-
deleteTemplate: jest.fn(),
|
|
41
|
-
getAccountsSettings: jest.fn(),
|
|
42
|
-
getAllTemplates: jest.fn(),
|
|
43
|
-
getCdnTransformationConfig: jest.fn(),
|
|
44
|
-
getDefaultBeeTemplates: jest.fn(),
|
|
45
|
-
getSenderDetails: jest.fn(),
|
|
46
|
-
getTemplateDetails: jest.fn(),
|
|
47
|
-
getUserList: jest.fn(),
|
|
48
|
-
getWeCrmAccounts: jest.fn(),
|
|
49
|
-
handleHtmlUpload: jest.fn(),
|
|
50
|
-
handleZipUpload: jest.fn(),
|
|
51
|
-
resetAccount: jest.fn(),
|
|
52
|
-
resetTemplate: jest.fn(),
|
|
53
|
-
resetTemplateData: jest.fn(),
|
|
54
|
-
resetTemplateStoreData: jest.fn(),
|
|
55
|
-
resetUploadData: jest.fn(),
|
|
56
|
-
setBEETemplate: jest.fn(),
|
|
57
|
-
setChannelAccount: jest.fn(),
|
|
58
|
-
setEdmTemplate: jest.fn(),
|
|
59
|
-
setFacebookAccount: jest.fn(),
|
|
60
|
-
setViberAccount: jest.fn(),
|
|
61
|
-
setWeChatAccount: jest.fn(),
|
|
62
|
-
};
|
|
63
|
-
|
|
64
|
-
const baseProps = {
|
|
65
|
-
cap: {
|
|
66
|
-
user: { accessiblePermissions: ['CREATIVES_UI_VIEW'] },
|
|
67
|
-
},
|
|
68
|
-
actions: { defaultAction: jest.fn(), getTemplates: jest.fn() },
|
|
69
|
-
Templates,
|
|
70
|
-
TemplatesList: Templates?.templates,
|
|
71
|
-
authData,
|
|
72
|
-
templateActions,
|
|
73
|
-
isFullMode: false,
|
|
74
|
-
className: 'embed-test',
|
|
75
|
-
channel: 'sms',
|
|
76
|
-
channelsToHide: CHANNELS_TO_HIDE_FOR_SMS_ONLY,
|
|
77
|
-
channelsToDisable: [],
|
|
78
|
-
onChannelChange: jest.fn(),
|
|
79
|
-
enableNewChannels: [],
|
|
80
|
-
/** Without JP_LOCALE_HIDE_FEATURE so SMS panes are not stripped to Email/Line/Gallery only */
|
|
81
|
-
currentOrgDetails: {
|
|
82
|
-
...currentOrgDetailsMock,
|
|
83
|
-
accessibleFeatures: (currentOrgDetailsMock.accessibleFeatures || []).filter(
|
|
84
|
-
(f) => f !== 'JP_LOCALE_HIDE_FEATURE',
|
|
85
|
-
),
|
|
86
|
-
},
|
|
87
|
-
location: {
|
|
88
|
-
pathname: 'v2',
|
|
89
|
-
basename: '/creatives/ui/',
|
|
90
|
-
query: {},
|
|
91
|
-
},
|
|
92
|
-
router: { push: jest.fn() },
|
|
93
|
-
};
|
|
94
|
-
|
|
95
|
-
beforeEach(() => {
|
|
96
|
-
mockTemplates.mockClear();
|
|
97
|
-
});
|
|
98
|
-
|
|
99
|
-
it('adds local-sms container class and single-pane layout when only SMS is visible', () => {
|
|
100
|
-
const p = cloneDeep(baseProps);
|
|
101
|
-
p.localTemplatesConfig = {
|
|
102
|
-
useLocalTemplates: true,
|
|
103
|
-
localTemplates: [],
|
|
104
|
-
localTemplatesLoading: false,
|
|
105
|
-
};
|
|
106
|
-
renderComponent(p);
|
|
107
|
-
|
|
108
|
-
const wrapper = screen.getByTestId('cap-wrapper');
|
|
109
|
-
expect(wrapper).toHaveClass('creatives-templates-container--local-sms');
|
|
110
|
-
expect(document.querySelector('.templates-v2-local-sms-pane')).toBeTruthy();
|
|
111
|
-
expect(mockTemplates).toHaveBeenCalled();
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
it('passes localTemplatesConfig into Templates for the SMS pane', () => {
|
|
115
|
-
const localConfig = {
|
|
116
|
-
useLocalTemplates: true,
|
|
117
|
-
localTemplates: [{ _id: '1', name: 'A' }],
|
|
118
|
-
localTemplatesLoading: false,
|
|
119
|
-
};
|
|
120
|
-
const p = cloneDeep(baseProps);
|
|
121
|
-
p.localTemplatesConfig = localConfig;
|
|
122
|
-
renderComponent(p);
|
|
123
|
-
|
|
124
|
-
expect(mockTemplates).toHaveBeenCalled();
|
|
125
|
-
const passed = mockTemplates.mock.calls.find(
|
|
126
|
-
(call) => call[0] && call[0].localTemplatesConfig && call[0].localTemplatesConfig.useLocalTemplates,
|
|
127
|
-
);
|
|
128
|
-
expect(passed).toBeTruthy();
|
|
129
|
-
expect(passed[0].localTemplatesConfig).toMatchObject(localConfig);
|
|
130
|
-
});
|
|
131
|
-
});
|