@capillarytech/creatives-library 8.0.246-alpha.0 → 8.0.246
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 +1 -2
- package/initialReducer.js +0 -2
- package/package.json +1 -1
- package/services/api.js +0 -10
- package/services/tests/api.test.js +0 -18
- package/utils/common.js +0 -5
- package/utils/commonUtils.js +5 -28
- package/utils/tests/commonUtil.test.js +0 -224
- package/utils/transformTemplateConfig.js +10 -0
- package/v2Components/CapDeviceContent/index.js +56 -61
- package/v2Components/CapTagList/index.js +1 -6
- package/v2Components/CapTagListWithInput/index.js +1 -5
- package/v2Components/CapTagListWithInput/messages.js +1 -1
- package/v2Components/CapWhatsappCTA/tests/index.test.js +0 -5
- package/v2Components/ErrorInfoNote/index.js +72 -447
- package/v2Components/ErrorInfoNote/messages.js +0 -22
- package/v2Components/ErrorInfoNote/style.scss +4 -280
- package/v2Components/FormBuilder/tests/index.test.js +4 -13
- package/v2Components/HtmlEditor/HTMLEditor.js +94 -642
- package/v2Components/HtmlEditor/__tests__/HTMLEditor.test.js +133 -1135
- package/v2Components/HtmlEditor/__tests__/index.lazy.test.js +16 -27
- package/v2Components/HtmlEditor/_htmlEditor.scss +45 -108
- package/v2Components/HtmlEditor/_index.lazy.scss +1 -1
- package/v2Components/HtmlEditor/components/CodeEditorPane/_codeEditorPane.scss +101 -13
- package/v2Components/HtmlEditor/components/CodeEditorPane/index.js +139 -148
- package/v2Components/HtmlEditor/components/DeviceToggle/_deviceToggle.scss +1 -2
- package/v2Components/HtmlEditor/components/DeviceToggle/index.js +3 -3
- package/v2Components/HtmlEditor/components/EditorToolbar/_editorToolbar.scss +0 -9
- package/v2Components/HtmlEditor/components/EditorToolbar/index.js +1 -1
- package/v2Components/HtmlEditor/components/FullscreenModal/_fullscreenModal.scss +0 -22
- package/v2Components/HtmlEditor/components/InAppPreviewPane/DeviceFrame.js +7 -4
- package/v2Components/HtmlEditor/components/InAppPreviewPane/__tests__/DeviceFrame.test.js +45 -35
- package/v2Components/HtmlEditor/components/InAppPreviewPane/_inAppPreviewPane.scss +3 -1
- package/v2Components/HtmlEditor/components/InAppPreviewPane/constants.js +33 -33
- package/v2Components/HtmlEditor/components/InAppPreviewPane/index.js +6 -7
- package/v2Components/HtmlEditor/components/PreviewPane/_previewPane.scss +6 -3
- package/v2Components/HtmlEditor/components/PreviewPane/index.js +13 -11
- package/v2Components/HtmlEditor/components/SplitContainer/_splitContainer.scss +1 -1
- package/v2Components/HtmlEditor/components/ValidationErrorDisplay/__tests__/index.test.js +152 -0
- package/v2Components/HtmlEditor/components/ValidationErrorDisplay/index.js +31 -49
- package/v2Components/HtmlEditor/constants.js +20 -29
- package/v2Components/HtmlEditor/hooks/__tests__/useInAppContent.test.js +16 -373
- package/v2Components/HtmlEditor/hooks/useEditorContent.js +2 -5
- package/v2Components/HtmlEditor/hooks/useInAppContent.js +146 -88
- package/v2Components/HtmlEditor/hooks/useValidation.js +45 -150
- package/v2Components/HtmlEditor/index.js +1 -1
- package/v2Components/HtmlEditor/messages.js +85 -95
- package/v2Components/HtmlEditor/utils/liquidTemplateSupport.js +102 -134
- package/v2Components/HtmlEditor/utils/properSyntaxHighlighting.js +25 -23
- package/v2Components/HtmlEditor/utils/validationAdapter.js +41 -66
- package/v2Components/MobilePushPreviewV2/index.js +7 -32
- package/v2Components/TemplatePreview/_templatePreview.scss +24 -44
- package/v2Components/TemplatePreview/index.js +32 -47
- package/v2Components/TemplatePreview/messages.js +0 -4
- package/v2Components/TestAndPreviewSlidebox/_testAndPreviewSlidebox.scss +0 -1
- package/v2Components/TestAndPreviewSlidebox/index.js +25 -31
- package/v2Containers/BeeEditor/index.js +90 -172
- package/v2Containers/CreativesContainer/SlideBoxContent.js +51 -128
- package/v2Containers/CreativesContainer/SlideBoxFooter.js +12 -113
- package/v2Containers/CreativesContainer/SlideBoxHeader.js +1 -2
- package/v2Containers/CreativesContainer/constants.js +0 -1
- package/v2Containers/CreativesContainer/index.js +46 -238
- package/v2Containers/CreativesContainer/messages.js +0 -8
- package/v2Containers/CreativesContainer/tests/SlideBoxFooter.test.js +2 -11
- package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +50 -38
- package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +0 -91
- package/v2Containers/Email/actions.js +0 -7
- package/v2Containers/Email/constants.js +1 -5
- package/v2Containers/Email/index.js +30 -229
- package/v2Containers/Email/messages.js +0 -32
- package/v2Containers/Email/reducer.js +1 -12
- package/v2Containers/Email/sagas.js +7 -61
- package/v2Containers/Email/tests/__snapshots__/reducer.test.js.snap +0 -2
- package/v2Containers/Email/tests/sagas.test.js +1 -1
- package/v2Containers/EmailWrapper/components/EmailWrapperView.js +15 -210
- package/v2Containers/EmailWrapper/components/HTMLEditorTesting.js +74 -40
- package/v2Containers/EmailWrapper/components/__tests__/HTMLEditorTesting.test.js +67 -2
- package/v2Containers/EmailWrapper/constants.js +0 -2
- package/v2Containers/EmailWrapper/hooks/useEmailWrapper.js +77 -629
- package/v2Containers/EmailWrapper/index.js +23 -103
- package/v2Containers/EmailWrapper/messages.js +1 -61
- package/v2Containers/EmailWrapper/tests/EmailWrapperView.test.js +214 -0
- package/v2Containers/EmailWrapper/tests/useEmailWrapper.test.js +77 -509
- package/v2Containers/InApp/actions.js +0 -7
- package/v2Containers/InApp/constants.js +4 -20
- package/v2Containers/InApp/index.js +357 -801
- package/v2Containers/InApp/index.scss +3 -4
- package/v2Containers/InApp/messages.js +3 -7
- package/v2Containers/InApp/reducer.js +3 -21
- package/v2Containers/InApp/sagas.js +9 -29
- package/v2Containers/InApp/selectors.js +5 -25
- package/v2Containers/InApp/tests/index.test.js +50 -154
- package/v2Containers/InApp/tests/reducer.test.js +0 -34
- package/v2Containers/InApp/tests/sagas.test.js +9 -61
- package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/content.test.js.snap +0 -3
- package/v2Containers/Line/Container/ImageCarousel/tests/__snapshots__/index.test.js.snap +0 -2
- package/v2Containers/Line/Container/Wrapper/tests/__snapshots__/index.test.js.snap +0 -2
- package/v2Containers/Line/Container/tests/__snapshots__/index.test.js.snap +0 -9
- package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +0 -12
- package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +0 -4
- package/v2Containers/TagList/index.js +19 -62
- package/v2Containers/Templates/_templates.scss +1 -60
- package/v2Containers/Templates/index.js +4 -89
- package/v2Containers/Templates/messages.js +0 -4
- package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +0 -35
- package/v2Components/HtmlEditor/__tests__/HTMLEditor.apiErrors.test.js +0 -874
- package/v2Components/HtmlEditor/components/ValidationTabs/_validationTabs.scss +0 -254
- package/v2Components/HtmlEditor/components/ValidationTabs/index.js +0 -363
- package/v2Components/HtmlEditor/components/ValidationTabs/messages.js +0 -51
- package/v2Components/HtmlEditor/hooks/__tests__/useValidation.apiErrors.test.js +0 -630
- package/v2Containers/BeePopupEditor/constants.js +0 -10
- package/v2Containers/BeePopupEditor/index.js +0 -193
- package/v2Containers/BeePopupEditor/tests/index.test.js +0 -627
- package/v2Containers/EmailWrapper/components/EmailHTMLEditor.js +0 -1317
- package/v2Containers/EmailWrapper/components/__tests__/EmailHTMLEditor.test.js +0 -1605
- package/v2Containers/EmailWrapper/components/__tests__/EmailWrapperView.test.js +0 -520
- package/v2Containers/EmailWrapper/tests/useEmailWrapper.edgeCases.test.js +0 -643
- package/v2Containers/InApp/__tests__/InAppHTMLEditor.test.js +0 -376
- package/v2Containers/InApp/__tests__/sagas.test.js +0 -363
- package/v2Containers/InApp/tests/selectors.test.js +0 -612
- package/v2Containers/InAppWrapper/components/InAppWrapperView.js +0 -162
- package/v2Containers/InAppWrapper/components/__tests__/InAppWrapperView.test.js +0 -267
- package/v2Containers/InAppWrapper/components/inAppWrapperView.scss +0 -9
- package/v2Containers/InAppWrapper/constants.js +0 -16
- package/v2Containers/InAppWrapper/hooks/__tests__/useInAppWrapper.test.js +0 -473
- package/v2Containers/InAppWrapper/hooks/useInAppWrapper.js +0 -198
- package/v2Containers/InAppWrapper/index.js +0 -148
- package/v2Containers/InAppWrapper/messages.js +0 -49
- package/v2Containers/InappAdvance/index.js +0 -1099
- package/v2Containers/InappAdvance/index.scss +0 -10
- package/v2Containers/InappAdvance/tests/index.test.js +0 -448
|
@@ -9,7 +9,6 @@ import { connect } from 'react-redux';
|
|
|
9
9
|
import { injectIntl, intlShape } from 'react-intl';
|
|
10
10
|
import { createStructuredSelector } from 'reselect';
|
|
11
11
|
import { bindActionCreators } from 'redux';
|
|
12
|
-
import { compose } from 'redux';
|
|
13
12
|
import { UserIsAuthenticated } from '../../utils/authWrapper';
|
|
14
13
|
import {
|
|
15
14
|
selectEmailLayout,
|
|
@@ -19,17 +18,10 @@ import {
|
|
|
19
18
|
selectCmsTemplatesLoader,
|
|
20
19
|
} from '../Templates/selectors';
|
|
21
20
|
import * as templatesActionsCreators from '../Templates/actions';
|
|
22
|
-
import { selectCurrentOrgDetails
|
|
23
|
-
import { makeSelectEmail, selectLoadingStatus, makeSelectFetchingCmsData } from '../Email/selectors';
|
|
24
|
-
import * as emailActionsCreators from '../Email/actions';
|
|
25
|
-
import * as globalActions from '../Cap/actions';
|
|
21
|
+
import { selectCurrentOrgDetails } from "../../v2Containers/Cap/selectors";
|
|
26
22
|
import EmailWrapperView from './components/EmailWrapperView';
|
|
27
23
|
import useEmailWrapper from './hooks/useEmailWrapper';
|
|
28
24
|
import HTMLEditorTesting from './components/HTMLEditorTesting';
|
|
29
|
-
import injectReducer from '../../utils/injectReducer';
|
|
30
|
-
import injectSaga from '../../utils/injectSaga';
|
|
31
|
-
import v2EmailReducer from '../Email/reducer';
|
|
32
|
-
import { v2EmailSagas } from '../Email/sagas';
|
|
33
25
|
|
|
34
26
|
|
|
35
27
|
const EmailWrapper = (props) => {
|
|
@@ -72,19 +64,6 @@ const EmailWrapper = (props) => {
|
|
|
72
64
|
handleTestAndPreview,
|
|
73
65
|
handleCloseTestAndPreview,
|
|
74
66
|
isTestAndPreviewMode,
|
|
75
|
-
location,
|
|
76
|
-
emailActions,
|
|
77
|
-
Email,
|
|
78
|
-
metaEntities,
|
|
79
|
-
loadingTags,
|
|
80
|
-
injectedTags,
|
|
81
|
-
globalActions: globalActionsProp,
|
|
82
|
-
templateData,
|
|
83
|
-
params,
|
|
84
|
-
fetchingLiquidTags,
|
|
85
|
-
createTemplateInProgress,
|
|
86
|
-
fetchingCmsData,
|
|
87
|
-
onHtmlEditorValidationStateChange,
|
|
88
67
|
} = props;
|
|
89
68
|
|
|
90
69
|
// Pass destructured props to the custom hook
|
|
@@ -138,70 +117,32 @@ const EmailWrapper = (props) => {
|
|
|
138
117
|
handleTestAndPreview,
|
|
139
118
|
handleCloseTestAndPreview,
|
|
140
119
|
isTestAndPreviewMode,
|
|
141
|
-
location,
|
|
142
|
-
emailActions,
|
|
143
|
-
Email,
|
|
144
|
-
templateData,
|
|
145
|
-
params,
|
|
146
120
|
});
|
|
147
121
|
|
|
148
122
|
// Render using the presentation component with data from the hook
|
|
149
123
|
return (
|
|
150
124
|
<div>
|
|
151
125
|
<EmailWrapperView
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
// These props are needed for EmailHTMLEditor component (tag loading, validation, etc.)
|
|
173
|
-
metaEntities={metaEntities}
|
|
174
|
-
loadingTags={loadingTags}
|
|
175
|
-
injectedTags={injectedTags}
|
|
176
|
-
globalActions={globalActionsProp}
|
|
177
|
-
supportedTags={props.supportedTags}
|
|
178
|
-
getDefaultTags={type}
|
|
179
|
-
location={location}
|
|
180
|
-
currentOrgDetails={currentOrgDetails}
|
|
181
|
-
onValidationFail={onValidationFail}
|
|
182
|
-
forwardedTags={forwardedTags}
|
|
183
|
-
selectedOfferDetails={selectedOfferDetails}
|
|
184
|
-
eventContextTags={eventContextTags}
|
|
185
|
-
getFormdata={getFormdata}
|
|
186
|
-
isGetFormData={isGetFormData}
|
|
187
|
-
getLiquidTags={globalActionsProp?.getLiquidTags}
|
|
188
|
-
showLiquidErrorInFooter={showLiquidErrorInFooter}
|
|
189
|
-
intl={intl}
|
|
190
|
-
emailActions={emailActions}
|
|
191
|
-
showTestAndPreviewSlidebox={showTestAndPreviewSlidebox}
|
|
192
|
-
handleTestAndPreview={handleTestAndPreview}
|
|
193
|
-
handleCloseTestAndPreview={handleCloseTestAndPreview}
|
|
194
|
-
Email={Email}
|
|
195
|
-
setIsLoadingContent={setIsLoadingContent}
|
|
196
|
-
templateData={templateData}
|
|
197
|
-
params={params}
|
|
198
|
-
showTemplateName={showTemplateName}
|
|
199
|
-
fetchingLiquidTags={fetchingLiquidTags}
|
|
200
|
-
createTemplateInProgress={createTemplateInProgress}
|
|
201
|
-
fetchingCmsData={fetchingCmsData}
|
|
202
|
-
onHtmlEditorValidationStateChange={onHtmlEditorValidationStateChange}
|
|
203
|
-
moduleType={moduleType}
|
|
204
|
-
/>
|
|
126
|
+
isUploading={isUploading}
|
|
127
|
+
emailCreateMode={emailCreateMode}
|
|
128
|
+
step={step}
|
|
129
|
+
isFullMode={isFullMode}
|
|
130
|
+
templateName={templateName}
|
|
131
|
+
onTemplateNameChange={onTemplateNameChange}
|
|
132
|
+
isTemplateNameEmpty={isTemplateNameEmpty}
|
|
133
|
+
modes={modes}
|
|
134
|
+
onChange={onChange}
|
|
135
|
+
EmailLayout={EmailLayout}
|
|
136
|
+
modeContent={modeContent}
|
|
137
|
+
useFileUpload={useFileUpload}
|
|
138
|
+
uploadButtonLabel={uploadButtonLabel}
|
|
139
|
+
isShowEmailCreate={isShowEmailCreate}
|
|
140
|
+
emailProps={emailProps}
|
|
141
|
+
cmsTemplatesProps={cmsTemplatesProps}
|
|
142
|
+
onPreviewContentClicked={onPreviewContentClicked}
|
|
143
|
+
onTestContentClicked={onTestContentClicked}
|
|
144
|
+
editor={editor}
|
|
145
|
+
/>
|
|
205
146
|
|
|
206
147
|
{/* HTMLEditor Testing Component - Console Controlled */}
|
|
207
148
|
<HTMLEditorTesting />
|
|
@@ -218,7 +159,7 @@ EmailWrapper.propTypes = {
|
|
|
218
159
|
templatesActions: PropTypes.object,
|
|
219
160
|
CmsTemplates: PropTypes.arrayOf(PropTypes.object),
|
|
220
161
|
SelectedEdmDefaultTemplate: PropTypes.object,
|
|
221
|
-
step: PropTypes.
|
|
162
|
+
step: PropTypes.string,
|
|
222
163
|
showNextStep: PropTypes.func,
|
|
223
164
|
getFormdata: PropTypes.func,
|
|
224
165
|
intl: intlShape,
|
|
@@ -246,8 +187,6 @@ EmailWrapper.propTypes = {
|
|
|
246
187
|
handleTestAndPreview: PropTypes.func,
|
|
247
188
|
handleCloseTestAndPreview: PropTypes.func,
|
|
248
189
|
isTestAndPreviewMode: PropTypes.bool,
|
|
249
|
-
location: PropTypes.object,
|
|
250
|
-
onHtmlEditorValidationStateChange: PropTypes.func,
|
|
251
190
|
};
|
|
252
191
|
|
|
253
192
|
const mapStateToProps = createStructuredSelector({
|
|
@@ -257,31 +196,12 @@ const mapStateToProps = createStructuredSelector({
|
|
|
257
196
|
isUploading: uploadSelector(),
|
|
258
197
|
cmsTemplatesLoader: selectCmsTemplatesLoader(),
|
|
259
198
|
currentOrgDetails: selectCurrentOrgDetails(),
|
|
260
|
-
Email: makeSelectEmail(),
|
|
261
|
-
metaEntities: makeSelectMetaEntities(),
|
|
262
|
-
loadingTags: isLoadingMetaEntities(),
|
|
263
|
-
injectedTags: setInjectedTags(),
|
|
264
|
-
fetchingLiquidTags: selectLiquidStateDetails(),
|
|
265
|
-
createTemplateInProgress: selectLoadingStatus(),
|
|
266
|
-
fetchingCmsData: makeSelectFetchingCmsData(),
|
|
267
199
|
});
|
|
268
200
|
|
|
269
201
|
function mapDispatchToProps(dispatch) {
|
|
270
202
|
return {
|
|
271
203
|
templatesActions: bindActionCreators(templatesActionsCreators, dispatch),
|
|
272
|
-
emailActions: bindActionCreators(emailActionsCreators, dispatch),
|
|
273
|
-
globalActions: bindActionCreators(globalActions, dispatch),
|
|
274
204
|
};
|
|
275
205
|
}
|
|
276
206
|
|
|
277
|
-
|
|
278
|
-
const withReducer = injectReducer({ key: 'email', reducer: v2EmailReducer });
|
|
279
|
-
const withEmailSaga = injectSaga({ key: 'email', saga: v2EmailSagas });
|
|
280
|
-
|
|
281
|
-
const ConnectedEmailWrapper = connect(mapStateToProps, mapDispatchToProps)(injectIntl(EmailWrapper));
|
|
282
|
-
|
|
283
|
-
export default compose(
|
|
284
|
-
UserIsAuthenticated,
|
|
285
|
-
withReducer,
|
|
286
|
-
withEmailSaga,
|
|
287
|
-
)(ConnectedEmailWrapper);
|
|
207
|
+
export default UserIsAuthenticated(connect(mapStateToProps, mapDispatchToProps)(injectIntl(EmailWrapper)));
|
|
@@ -60,66 +60,6 @@ export default defineMessages({
|
|
|
60
60
|
},
|
|
61
61
|
emptyTemplateName: {
|
|
62
62
|
id: `creatives.containersV2.EmailWrapper.emptyTemplateName`,
|
|
63
|
-
defaultMessage: `Please enter template name
|
|
64
|
-
},
|
|
65
|
-
htmlEditorTitle: {
|
|
66
|
-
id: 'creatives.EmailWrapper.htmlEditorTitle',
|
|
67
|
-
defaultMessage: 'HTML editor',
|
|
68
|
-
},
|
|
69
|
-
htmlEditorDesc: {
|
|
70
|
-
id: 'creatives.EmailWrapper.htmlEditorDesc',
|
|
71
|
-
defaultMessage: 'Use a basic HTML editor to write and format your content. Suitable if you are familiar with HTML.',
|
|
72
|
-
},
|
|
73
|
-
dragDropEditorTitle: {
|
|
74
|
-
id: 'creatives.EmailWrapper.dragDropEditorTitle',
|
|
75
|
-
defaultMessage: 'Drag & drop editor',
|
|
76
|
-
},
|
|
77
|
-
dragDropEditorDesc: {
|
|
78
|
-
id: 'creatives.EmailWrapper.dragDropEditorDesc',
|
|
79
|
-
defaultMessage: 'Create your content visually by dragging blocks — no coding needed. Great for quick, easy designs.',
|
|
80
|
-
},
|
|
81
|
-
uploadZipTitle: {
|
|
82
|
-
id: 'creatives.EmailWrapper.uploadZipTitle',
|
|
83
|
-
defaultMessage: 'Upload zip file',
|
|
84
|
-
},
|
|
85
|
-
uploadZipDesc: {
|
|
86
|
-
id: 'creatives.EmailWrapper.uploadZipDesc',
|
|
87
|
-
defaultMessage: 'Upload a ZIP containing your custom HTML, images, and assets. Ideal if your content is already built.',
|
|
88
|
-
},
|
|
89
|
-
next: {
|
|
90
|
-
id: 'creatives.EmailWrapper.next',
|
|
91
|
-
defaultMessage: 'Next',
|
|
92
|
-
},
|
|
93
|
-
beeEditorDisabledTooltip: {
|
|
94
|
-
id: 'creatives.EmailWrapper.beeEditorDisabledTooltip',
|
|
95
|
-
defaultMessage: 'Please get the drag & drop editor enabled for your brand',
|
|
96
|
-
},
|
|
97
|
-
emailContent: {
|
|
98
|
-
id: 'creatives.containersV2.Email.emailContent',
|
|
99
|
-
defaultMessage: 'Email content',
|
|
100
|
-
},
|
|
101
|
-
create: {
|
|
102
|
-
id: 'creatives.containersV2.EmailWrapper.create',
|
|
103
|
-
defaultMessage: 'Create',
|
|
104
|
-
},
|
|
105
|
-
update: {
|
|
106
|
-
id: 'creatives.containersV2.EmailWrapper.update',
|
|
107
|
-
defaultMessage: 'Update',
|
|
108
|
-
},
|
|
109
|
-
previewAndTest: {
|
|
110
|
-
id: 'creatives.containersV2.EmailWrapper.previewAndTest',
|
|
111
|
-
defaultMessage: 'Preview and Test',
|
|
112
|
-
},
|
|
113
|
-
required: {
|
|
114
|
-
id: 'creatives.containersV2.EmailWrapper.required',
|
|
115
|
-
defaultMessage: 'Required',
|
|
116
|
-
},
|
|
117
|
-
subject: {
|
|
118
|
-
id: 'creatives.containersV2.EmailWrapper.subject',
|
|
119
|
-
defaultMessage: 'Subject',
|
|
120
|
-
},
|
|
121
|
-
enterEmailSubject: {
|
|
122
|
-
id: 'creatives.containersV2.EmailWrapper.enterEmailSubject',
|
|
123
|
-
defaultMessage: 'Enter Email Subject',
|
|
63
|
+
defaultMessage: `Please enter template name.`
|
|
124
64
|
},
|
|
125
65
|
});
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { render, fireEvent, within, screen } from '@testing-library/react';
|
|
3
|
+
import '@testing-library/jest-dom';
|
|
4
|
+
import { IntlProvider } from 'react-intl';
|
|
5
|
+
import { Provider } from 'react-redux';
|
|
6
|
+
import { configureStore } from '@capillarytech/vulcan-react-sdk/utils'
|
|
7
|
+
import { initialReducer } from '../../../initialReducer';
|
|
8
|
+
import EmailWrapperView from '../components/EmailWrapperView';
|
|
9
|
+
import { EmailWrapperViewMockProps } from '../mockdata/mockdata';
|
|
10
|
+
import { EMAIL_CREATE_MODES } from '../constants';
|
|
11
|
+
import history from '../../../utils/history';
|
|
12
|
+
|
|
13
|
+
// This mock needs to be before any imports
|
|
14
|
+
jest.mock('../../../v2Containers/Email', () => ({
|
|
15
|
+
__esModule: true,
|
|
16
|
+
default: () => <div data-testid="email-create-container" />,
|
|
17
|
+
}));
|
|
18
|
+
|
|
19
|
+
// Mock react-router
|
|
20
|
+
jest.mock('react-router-dom', () => ({
|
|
21
|
+
...jest.requireActual('react-router-dom'),
|
|
22
|
+
useHistory: () => ({
|
|
23
|
+
push: jest.fn(),
|
|
24
|
+
replace: jest.fn(),
|
|
25
|
+
go: jest.fn(),
|
|
26
|
+
goBack: jest.fn(),
|
|
27
|
+
goForward: jest.fn(),
|
|
28
|
+
location: { search: '' }
|
|
29
|
+
}),
|
|
30
|
+
}));
|
|
31
|
+
|
|
32
|
+
// Mock redux-auth-wrapper
|
|
33
|
+
jest.mock('redux-auth-wrapper/history4/redirect', () => ({
|
|
34
|
+
connectedRouterRedirect: () => (Component) => Component,
|
|
35
|
+
}));
|
|
36
|
+
|
|
37
|
+
// Mock react-router
|
|
38
|
+
jest.mock('connected-react-router', () => ({
|
|
39
|
+
push: jest.fn(),
|
|
40
|
+
replace: jest.fn(),
|
|
41
|
+
go: jest.fn(),
|
|
42
|
+
goBack: jest.fn(),
|
|
43
|
+
goForward: jest.fn(),
|
|
44
|
+
}));
|
|
45
|
+
|
|
46
|
+
// Mock the saga injector
|
|
47
|
+
jest.mock('@capillarytech/vulcan-react-sdk/utils/injectSaga', () => ({
|
|
48
|
+
__esModule: true,
|
|
49
|
+
default: () => (Component) => Component,
|
|
50
|
+
}));
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
const initialState = {
|
|
54
|
+
cap: { loading: false, error: null },
|
|
55
|
+
router: { location: { pathname: '/' } }
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
describe('EmailWrapperView', () => {
|
|
59
|
+
let store;
|
|
60
|
+
|
|
61
|
+
beforeAll(() => {
|
|
62
|
+
store = configureStore(initialState, initialReducer, history);
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
const renderWithProviders = (component) => {
|
|
66
|
+
return render(
|
|
67
|
+
<Provider store={store}>
|
|
68
|
+
<IntlProvider locale="en" messages={{}}>
|
|
69
|
+
{component}
|
|
70
|
+
</IntlProvider>
|
|
71
|
+
</Provider>
|
|
72
|
+
);
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
it('renders mode selection UI when step is modeSelection', () => {
|
|
76
|
+
const props = {
|
|
77
|
+
...EmailWrapperViewMockProps,
|
|
78
|
+
step: 'modeSelection',
|
|
79
|
+
};
|
|
80
|
+
|
|
81
|
+
const { getByText } = renderWithProviders(<EmailWrapperView {...props} />);
|
|
82
|
+
expect(getByText('Create using editor')).toBeInTheDocument();
|
|
83
|
+
expect(getByText('Upload zip file')).toBeInTheDocument();
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
it('shows template name input in full mode', () => {
|
|
87
|
+
const props = {
|
|
88
|
+
...EmailWrapperViewMockProps,
|
|
89
|
+
isFullMode: true,
|
|
90
|
+
step: 'modeSelection',
|
|
91
|
+
};
|
|
92
|
+
|
|
93
|
+
const { container } = renderWithProviders(<EmailWrapperView {...props} />);
|
|
94
|
+
const input = container.querySelector('.ant-input');
|
|
95
|
+
expect(input).toBeInTheDocument();
|
|
96
|
+
expect(input.value).toBe(props.templateName);
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
it('handles template name changes', () => {
|
|
100
|
+
const props = {
|
|
101
|
+
...EmailWrapperViewMockProps,
|
|
102
|
+
isFullMode: true,
|
|
103
|
+
step: 'modeSelection',
|
|
104
|
+
onTemplateNameChange: jest.fn(),
|
|
105
|
+
};
|
|
106
|
+
|
|
107
|
+
const { container } = renderWithProviders(<EmailWrapperView {...props} />);
|
|
108
|
+
const input = container.querySelector('.ant-input');
|
|
109
|
+
expect(input).toBeInTheDocument();
|
|
110
|
+
|
|
111
|
+
// Create a change event and fire it
|
|
112
|
+
fireEvent.change(input, { target: { value: 'New Template Name' } });
|
|
113
|
+
|
|
114
|
+
// Just verify that the function was called
|
|
115
|
+
expect(props.onTemplateNameChange).toHaveBeenCalled();
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
it('shows upload button when in upload mode', () => {
|
|
119
|
+
const props = {
|
|
120
|
+
...EmailWrapperViewMockProps,
|
|
121
|
+
step: 'modeSelection',
|
|
122
|
+
emailCreateMode: EMAIL_CREATE_MODES.UPLOAD,
|
|
123
|
+
uploadButtonLabel: 'Upload',
|
|
124
|
+
};
|
|
125
|
+
|
|
126
|
+
const { getByText, container } = renderWithProviders(<EmailWrapperView {...props} />);
|
|
127
|
+
|
|
128
|
+
// Find the "Upload zip file" section
|
|
129
|
+
const modeSelectionSection = getByText('Upload zip file').closest('div');
|
|
130
|
+
|
|
131
|
+
// Find any button in the upload section
|
|
132
|
+
const uploadButton = container.querySelector('.ant-btn');
|
|
133
|
+
|
|
134
|
+
// Verify that we found an upload button
|
|
135
|
+
expect(uploadButton).toBeInTheDocument();
|
|
136
|
+
expect(uploadButton.textContent).toContain('Upload');
|
|
137
|
+
});
|
|
138
|
+
|
|
139
|
+
it('shows loading spinner when uploading', () => {
|
|
140
|
+
const props = {
|
|
141
|
+
...EmailWrapperViewMockProps,
|
|
142
|
+
isUploading: true,
|
|
143
|
+
emailCreateMode: EMAIL_CREATE_MODES.UPLOAD,
|
|
144
|
+
step: 'modeSelection',
|
|
145
|
+
};
|
|
146
|
+
|
|
147
|
+
const { container } = renderWithProviders(<EmailWrapperView {...props} />);
|
|
148
|
+
const spinner = container.querySelector('.ant-spin');
|
|
149
|
+
expect(spinner).toBeInTheDocument();
|
|
150
|
+
});
|
|
151
|
+
|
|
152
|
+
it('shows content creation UI when not in mode selection', () => {
|
|
153
|
+
const props = {
|
|
154
|
+
...EmailWrapperViewMockProps,
|
|
155
|
+
step: 'contentCreation',
|
|
156
|
+
isShowEmailCreate: true,
|
|
157
|
+
};
|
|
158
|
+
|
|
159
|
+
const { getByTestId } = renderWithProviders(<EmailWrapperView {...props} />);
|
|
160
|
+
expect(getByTestId('email-create-container')).toBeInTheDocument();
|
|
161
|
+
});
|
|
162
|
+
|
|
163
|
+
it('disables upload button when template name is empty in full mode', () => {
|
|
164
|
+
const props = {
|
|
165
|
+
...EmailWrapperViewMockProps,
|
|
166
|
+
isFullMode: true,
|
|
167
|
+
step: 'modeSelection',
|
|
168
|
+
emailCreateMode: EMAIL_CREATE_MODES.UPLOAD,
|
|
169
|
+
templateName: '',
|
|
170
|
+
isTemplateNameEmpty: true,
|
|
171
|
+
uploadButtonLabel: 'Upload',
|
|
172
|
+
};
|
|
173
|
+
|
|
174
|
+
const { getByText, container } = renderWithProviders(<EmailWrapperView {...props} />);
|
|
175
|
+
|
|
176
|
+
// Find the Upload section
|
|
177
|
+
getByText('Upload zip file');
|
|
178
|
+
|
|
179
|
+
// Find button in the container
|
|
180
|
+
const uploadButton = container.querySelector('.ant-btn');
|
|
181
|
+
|
|
182
|
+
// Check if the button is disabled
|
|
183
|
+
expect(uploadButton).toBeDisabled();
|
|
184
|
+
});
|
|
185
|
+
|
|
186
|
+
it('shows error message when template name is empty during upload', () => {
|
|
187
|
+
const props = {
|
|
188
|
+
...EmailWrapperViewMockProps,
|
|
189
|
+
isFullMode: true,
|
|
190
|
+
step: 'modeSelection',
|
|
191
|
+
emailCreateMode: EMAIL_CREATE_MODES.UPLOAD,
|
|
192
|
+
templateName: '',
|
|
193
|
+
isTemplateNameEmpty: true,
|
|
194
|
+
// Add errorMessage directly to the props
|
|
195
|
+
errorMessage: 'Please enter template name',
|
|
196
|
+
intl: {
|
|
197
|
+
formatMessage: () => 'Please enter template name',
|
|
198
|
+
},
|
|
199
|
+
};
|
|
200
|
+
|
|
201
|
+
const { container } = renderWithProviders(<EmailWrapperView {...props} />);
|
|
202
|
+
|
|
203
|
+
// Look for error feedback in the Ant Design form
|
|
204
|
+
const errorElement = container.querySelector('.ant-form-item-explain');
|
|
205
|
+
|
|
206
|
+
if (errorElement) {
|
|
207
|
+
expect(errorElement.textContent).toContain('Please enter template name');
|
|
208
|
+
} else {
|
|
209
|
+
// If the standard error element is not found, look for any element containing the error text
|
|
210
|
+
const allText = container.textContent;
|
|
211
|
+
expect(allText).toContain('Please enter template name');
|
|
212
|
+
}
|
|
213
|
+
});
|
|
214
|
+
});
|