@capillarytech/creatives-library 7.17.192 → 7.17.193-alpha.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/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@capillarytech/creatives-library",
3
3
  "author": "meharaj",
4
- "version": "7.17.192",
4
+ "version": "7.17.193-alpha.1",
5
5
  "description": "Capillary creatives ui",
6
6
  "main": "./index.js",
7
7
  "module": "./index.es.js",
@@ -153,6 +153,7 @@ export function SlideBoxContent(props) {
153
153
  hideTestAndPreviewBtn,
154
154
  getCmsTemplatesInProgress = false,
155
155
  moduleType,
156
+ creativesMode,
156
157
  } = props;
157
158
  const type = (messageDetails.type || '').toLowerCase(); // type is context in get tags values : outbound | dvs | referral | loyalty | coupons
158
159
  const query = { type: !isFullMode && 'embedded', module: isFullMode ? 'default' : 'library', isEditFromCampaigns: (templateData || {}).isEditFromCampaigns};
@@ -652,6 +653,7 @@ export function SlideBoxContent(props) {
652
653
  onTestContentClicked={onTestContentClicked}
653
654
  type={type}
654
655
  hideTestAndPreviewBtn={hideTestAndPreviewBtn}
656
+ creativesMode={creativesMode}
655
657
  />
656
658
  }
657
659
  {isCreateMPush &&
@@ -917,5 +919,6 @@ SlideBoxContent.propTypes = {
917
919
  smsRegister: PropTypes.any,
918
920
  getCmsTemplatesInProgress: PropTypes.bool,
919
921
  moduleType: PropTypes.string,
922
+ creativesMode: PropTypes.string,
920
923
  };
921
924
  export default SlideBoxContent;
@@ -1274,6 +1274,7 @@ export class Creatives extends React.Component {
1274
1274
  hideTestAndPreviewBtn={this.props.hideTestAndPreviewBtn}
1275
1275
  getCmsTemplatesInProgress={this.props.Templates?.getCmsTemplatesInProgress}
1276
1276
  moduleType={this.props.messageDetails?.type}
1277
+ creativesMode={creativesMode}
1277
1278
  />
1278
1279
  }
1279
1280
  footer={this.shouldShowFooter() &&
@@ -105,8 +105,23 @@ export class Edit extends React.Component { // eslint-disable-line react/prefer-
105
105
  } else if (nextProps.isGetFormData && this.props.isGetFormData !== nextProps.isGetFormData && this.props.isFullMode && !this.props.Create.createTemplateInProgress) {
106
106
  this.startValidation();
107
107
  }
108
- const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount :
109
- (!_.isEmpty(this.props.Edit.selectedWeChatAccount) ? this.props.Edit.selectedWeChatAccount : nextProps.Edit.selectedWeChatAccount));
108
+ console.log('this.props--->', this.props.creativesMode);
109
+ let selectedWeChatAccount = {};
110
+ if (this.props.creativesMode === 'edit' || this.props.creativesMode === 'preview') {
111
+ if (!_.isEmpty(this.props.Edit.selectedWeChatAccount)) {
112
+ selectedWeChatAccount = this.props.Edit.selectedWeChatAccount;
113
+ console.log('selectedWeChatAccount---> if 112', selectedWeChatAccount);
114
+ } else {
115
+ selectedWeChatAccount = nextProps.Templates.selectedWeChatAccount;
116
+ console.log('selectedWeChatAccount---> else 115', selectedWeChatAccount);
117
+ }
118
+ } else if (!_.isEmpty(this.props.Templates.selectedWeChatAccount)) {
119
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
120
+ console.log('selectedWeChatAccount---> else if 119', selectedWeChatAccount);
121
+ }
122
+
123
+ // const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount :
124
+ // (!_.isEmpty(this.props.Edit.selectedWeChatAccount) ? this.props.Edit.selectedWeChatAccount : nextProps.Edit.selectedWeChatAccount));
110
125
  if (this.props.location.query.type === 'embedded' && !nextProps.Edit.fetchingWeCrmAccounts && !_.isEqual(this.props.Edit.weCrmAccounts, nextProps.Edit.weCrmAccounts) && (!selectedWeChatAccount || _.isEmpty(selectedWeChatAccount))) {
111
126
  this.setMobilePushAccountOptions(nextProps.Edit.weCrmAccounts, get(this.props, "templateData.definition.accountId"));
112
127
  }
@@ -214,7 +229,20 @@ export class Edit extends React.Component { // eslint-disable-line react/prefer-
214
229
  };
215
230
 
216
231
  onLinkTypeChange = (eventTriggered, formData, field, currentTab, inputSchema) => {
217
- const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
232
+ let selectedWeChatAccount = {};
233
+ if (this.props.creativesMode === 'edit' || this.props.creativesMode === 'preview') {
234
+ if (!_.isEmpty(this.props.Edit.selectedWeChatAccount)) {
235
+ selectedWeChatAccount = this.props.Edit.selectedWeChatAccount;
236
+ console.log('selectedWeChatAccount---> if 235', selectedWeChatAccount);
237
+ } else {
238
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
239
+ console.log('selectedWeChatAccount---> else 239', selectedWeChatAccount);
240
+ }
241
+ } else if (!_.isEmpty(this.props.Templates.selectedWeChatAccount)) {
242
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
243
+ console.log('selectedWeChatAccount---> else 239', selectedWeChatAccount);
244
+ }
245
+ //const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
218
246
  const schema = inputSchema ? _.cloneDeep(inputSchema) : _.cloneDeep(this.state.schema);
219
247
  const tabIndex = currentTab || this.state.currentTab;
220
248
  const inputFields = get(schema, `containers[0].panes[${tabIndex - 1}].sections[0].childSections[0].childSections[0].inputFields`);
@@ -331,14 +359,24 @@ export class Edit extends React.Component { // eslint-disable-line react/prefer-
331
359
  };
332
360
 
333
361
  getTransformedData = (formData) => {
334
- const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
362
+ let selectedWeChatAccount = {};
363
+ if (this.props.creativesMode === 'edit' || this.props.creativesMode === 'preview') {
364
+ if (!_.isEmpty(this.props.Edit.selectedWeChatAccount)) {
365
+ selectedWeChatAccount = this.props.Edit.selectedWeChatAccount;
366
+ console.log('selectedWeChatAccount---> if 362', selectedWeChatAccount);
367
+ }
368
+ } else if (!_.isEmpty(this.props.Templates.selectedWeChatAccount)) {
369
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
370
+ console.log('selectedWeChatAccount---> else 366', selectedWeChatAccount);
371
+ }
372
+ //const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
335
373
  const obj = _.cloneDeep(this.state.editData);
336
374
  obj.versions = {
337
375
  base: {},
338
376
  };
339
377
  obj.type = 'MOBILEPUSH';
340
378
  obj.name = formData['template-name'];
341
- if(this.props?.Templates?.selectedWeChatAccount?.sourceTypeName === 'MAPP_SDK') {
379
+ if (selectedWeChatAccount?.sourceTypeName === 'MAPP_SDK') {
342
380
  obj.definition = {
343
381
  accountId: selectedWeChatAccount.id,
344
382
  licenseCode: selectedWeChatAccount.sourceAccountIdentifier,
@@ -561,7 +599,17 @@ export class Edit extends React.Component { // eslint-disable-line react/prefer-
561
599
  };
562
600
 
563
601
  getLinkName = (link) => {
564
- const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
602
+ let selectedWeChatAccount = {};
603
+ if (this.props.creativesMode === 'edit' || this.props.creativesMode === 'preview') {
604
+ if (!_.isEmpty(this.props.Edit.selectedWeChatAccount)) {
605
+ selectedWeChatAccount = this.props.Edit.selectedWeChatAccount;
606
+ console.log('selectedWeChatAccount---> if 602', selectedWeChatAccount);
607
+ }
608
+ } else if (!_.isEmpty(this.props.Templates.selectedWeChatAccount)) {
609
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
610
+ console.log('selectedWeChatAccount---> else 606', selectedWeChatAccount);
611
+ }
612
+ // const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
565
613
  const ck = selectedWeChatAccount.configs ? !!selectedWeChatAccount.configs.deeplink : false;
566
614
  const deepLinkOptions = _.filter(JSON.parse(ck ? selectedWeChatAccount.configs.deeplink : '[]'), (l) => l.link === link);
567
615
  if (deepLinkOptions[0]) {
@@ -960,7 +1008,17 @@ export class Edit extends React.Component { // eslint-disable-line react/prefer-
960
1008
  showSelectedIosCta = (inputSchema, field, tab, selectedConfig) => {
961
1009
  const currentTab = tab || this.state.currentTab;
962
1010
  const schema = inputSchema ? _.cloneDeep(inputSchema) : _.cloneDeep(this.state.schema);
963
- const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
1011
+ let selectedWeChatAccount = {};
1012
+ if (this.props.creativesMode === 'edit' || this.props.creativesMode === 'preview') {
1013
+ if (!_.isEmpty(this.props.Edit.selectedWeChatAccount)) {
1014
+ selectedWeChatAccount = this.props.Edit.selectedWeChatAccount;
1015
+ console.log('selectedWeChatAccount---> if 1011', selectedWeChatAccount);
1016
+ }
1017
+ } else if (!_.isEmpty(this.props.Templates.selectedWeChatAccount)) {
1018
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
1019
+ console.log('selectedWeChatAccount---> else 1015', selectedWeChatAccount);
1020
+ }
1021
+ // const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
964
1022
  const ck = selectedWeChatAccount.configs ? !!selectedWeChatAccount.configs.deeplink : false;
965
1023
  const deepLinkOptions = _.map(JSON.parse(ck ? selectedWeChatAccount.configs.deeplink : '[]'), (link) => ({label: link.name, value: link.link, title: link.link }) );
966
1024
 
@@ -1088,7 +1146,17 @@ export class Edit extends React.Component { // eslint-disable-line react/prefer-
1088
1146
  };
1089
1147
 
1090
1148
  deletePrimaryCTA = (event) => {
1091
- const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
1149
+ let selectedWeChatAccount = {};
1150
+ if (this.props.creativesMode === 'edit' || this.props.creativesMode === 'preview') {
1151
+ if (!_.isEmpty(this.props.Edit.selectedWeChatAccount)) {
1152
+ selectedWeChatAccount = this.props.Edit.selectedWeChatAccount;
1153
+ console.log('selectedWeChatAccount---> if 1149', selectedWeChatAccount);
1154
+ }
1155
+ } else if (!_.isEmpty(this.props.Templates.selectedWeChatAccount)) {
1156
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
1157
+ console.log('selectedWeChatAccount---> else 1153', selectedWeChatAccount);
1158
+ }
1159
+ // const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
1092
1160
  const id = event.currentTarget.id;
1093
1161
  const schema = _.cloneDeep(this.state.schema);
1094
1162
  // const eventsMap = _.cloneDeep(this.state.eventsMap);
@@ -1188,7 +1256,17 @@ export class Edit extends React.Component { // eslint-disable-line react/prefer-
1188
1256
  };
1189
1257
 
1190
1258
  deleteSecondaryCTA = (event) => {
1191
- const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
1259
+ let selectedWeChatAccount = {};
1260
+ if (this.props.creativesMode === 'edit' || this.props.creativesMode === 'preview') {
1261
+ if (!_.isEmpty(this.props.Edit.selectedWeChatAccount)) {
1262
+ selectedWeChatAccount = this.props.Edit.selectedWeChatAccount;
1263
+ console.log('selectedWeChatAccount---> if 1259', selectedWeChatAccount);
1264
+ }
1265
+ } else if (!_.isEmpty(this.props.Templates.selectedWeChatAccount)) {
1266
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
1267
+ console.log('selectedWeChatAccount---> else 1263', selectedWeChatAccount);
1268
+ }
1269
+ //const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
1192
1270
  const id = event.currentTarget.id;
1193
1271
  if (id === "secondary-cta-0-delete") {
1194
1272
  const secCta2 = document.getElementById("secondary-cta-1-delete");
@@ -1475,8 +1553,12 @@ export class Edit extends React.Component { // eslint-disable-line react/prefer-
1475
1553
  if (this.props.location.query.type === 'embedded' && temp.id === "mobilepush-accounts" ) {
1476
1554
  temp.options = this.state.templateOptions ? this.state.accountsOptions : [];
1477
1555
  }
1478
- if (temp.id === "mobile-push-preview" && this.props.Templates.selectedWeChatAccount && !_.isEmpty(this.props.Templates.selectedWeChatAccount)) {
1479
- temp.content.appName = this.props.Templates.selectedWeChatAccount.name;
1556
+ if (temp.id === "mobile-push-preview") {
1557
+ if ((this.props.creativesMode === 'edit' || this.props.creativesMode === 'preview') && this.props.Edit.selectedWeChatAccount && !_.isEmpty(this.props.Edit.selectedWeChatAccount)) {
1558
+ temp.content.appName = this.props.Edit.selectedWeChatAccount.name;
1559
+ } else if (this.props.Templates.selectedWeChatAccount && !_.isEmpty(this.props.Templates.selectedWeChatAccount)) {
1560
+ temp.content.appName = this.props.Templates.selectedWeChatAccount.name;
1561
+ }
1480
1562
  }
1481
1563
  _.forEach(col.supportedEvents, (event) => {
1482
1564
  temp.injectedEvents[event] = this.getMappedEvent(col.id, event);
@@ -1561,7 +1643,19 @@ export class Edit extends React.Component { // eslint-disable-line react/prefer-
1561
1643
  };
1562
1644
 
1563
1645
  showCtaKeys = (eventTriggered, formData, field, tabIndex, schemaInput) => {
1564
- const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
1646
+ let selectedWeChatAccount = {};
1647
+ if (this.props.creativesMode === 'edit' || this.props.creativesMode === 'preview') {
1648
+ if (!_.isEmpty(this.props.Edit.selectedWeChatAccount)) {
1649
+ selectedWeChatAccount = this.props.Edit.selectedWeChatAccount;
1650
+ console.log('selectedWeChatAccount---> if 1642', selectedWeChatAccount);
1651
+ } else {
1652
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
1653
+ }
1654
+ } else if (!_.isEmpty(this.props.Templates.selectedWeChatAccount)) {
1655
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
1656
+ console.log('selectedWeChatAccount---> else 1646', selectedWeChatAccount);
1657
+ }
1658
+ // const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
1565
1659
  const currentTab = tabIndex || this.state.currentTab;
1566
1660
  const schema = _.cloneDeep(schemaInput || this.state.schema);
1567
1661
  const eventsMap = _.cloneDeep(this.state.eventsMap);
@@ -1616,11 +1710,26 @@ export class Edit extends React.Component { // eslint-disable-line react/prefer-
1616
1710
  return schema;
1617
1711
  };
1618
1712
  addPrimaryCta = (flag, formData, field, inputSchema, currentTab) => {
1619
- const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
1713
+ let selectedWeChatAccount = {};
1714
+ if (this.props.creativesMode === 'edit' || this.props.creativesMode === 'preview') {
1715
+ if (!_.isEmpty(this.props.Edit.selectedWeChatAccount)) {
1716
+ selectedWeChatAccount = this.props.Edit.selectedWeChatAccount;
1717
+ console.log('selectedWeChatAccount---> if 1707', selectedWeChatAccount);
1718
+ } else {
1719
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
1720
+ }
1721
+ } else if (!_.isEmpty(this.props.Templates.selectedWeChatAccount)) {
1722
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
1723
+ console.log('selectedWeChatAccount---> else 1711', selectedWeChatAccount);
1724
+ }
1725
+ // const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
1620
1726
  const id = field.id;
1621
1727
  const schema = inputSchema ? _.cloneDeep(inputSchema) : _.cloneDeep(this.state.schema);
1728
+ console.log('schema--->', selectedWeChatAccount);
1622
1729
  const ck = selectedWeChatAccount.configs ? !!selectedWeChatAccount.configs.deeplink : false;
1730
+ console.log('ck---->', ck);
1623
1731
  const deepLinkOptions = selectedWeChatAccount ? _.map(JSON.parse(ck ? selectedWeChatAccount.configs.deeplink : '[]'), (link) => ({label: link.name, value: link.link, title: link.link }) ) : [];
1732
+ console.log('deepLinkOptions--->', deepLinkOptions);
1624
1733
  // const eventsMap = _.cloneDeep(this.state.eventsMap);
1625
1734
  const tabIndex = currentTab || this.state.currentTab;
1626
1735
  const inputFields = get(schema, `containers[0].panes[${tabIndex - 1}].sections[0].childSections[0].childSections[0].inputFields`);
@@ -1649,7 +1758,19 @@ export class Edit extends React.Component { // eslint-disable-line react/prefer-
1649
1758
  const tabIndex = currentTab || this.state.currentTab;
1650
1759
  const formDataCopy = cloneDeep(formData);
1651
1760
  const schema = inputSchema ? _.cloneDeep(inputSchema) : _.cloneDeep(this.state.schema);
1652
- const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
1761
+ let selectedWeChatAccount = {};
1762
+ if (this.props.creativesMode === 'edit' || this.props.creativesMode === 'preview') {
1763
+ if (!_.isEmpty(this.props.Edit.selectedWeChatAccount)) {
1764
+ selectedWeChatAccount = this.props.Edit.selectedWeChatAccount;
1765
+ console.log('selectedWeChatAccount---> if 1746', selectedWeChatAccount);
1766
+ } else {
1767
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
1768
+ }
1769
+ } else if (!_.isEmpty(this.props.Templates.selectedWeChatAccount)) {
1770
+ selectedWeChatAccount = this.props.Templates.selectedWeChatAccount;
1771
+ console.log('selectedWeChatAccount---> else 1754', selectedWeChatAccount);
1772
+ }
1773
+ //const selectedWeChatAccount = (!_.isEmpty(this.props.Templates.selectedWeChatAccount) ? this.props.Templates.selectedWeChatAccount : this.props.Edit.selectedWeChatAccount);
1653
1774
  const ck = selectedWeChatAccount.configs ? !!selectedWeChatAccount.configs.deeplink : false;
1654
1775
  const deepLinkOptions = selectedWeChatAccount ? _.map(JSON.parse(ck ? selectedWeChatAccount.configs.deeplink : '[]'), (link) => ({label: link.name, value: link.link, title: link.link }) ) : [];
1655
1776
  const inputFields = get(schema, `containers[0].panes[${tabIndex - 1}].sections[0].childSections[0].childSections[0].inputFields`);
@@ -1698,7 +1819,12 @@ export class Edit extends React.Component { // eslint-disable-line react/prefer-
1698
1819
  if (!_.isEmpty(actionText)) {
1699
1820
  this.deleteSecondaryCtaIos();
1700
1821
  }
1701
- this.props.actions.getIosCtas(this.props.Templates.selectedWeChatAccount.sourceAccountIdentifier);//TODO: need to get license code of accoutn and send as arg
1822
+ if ((this.props.creativesMode === 'edit' || this.props.creativesMode === 'preview')) {
1823
+ this.props.actions.getIosCtas(this.props.Edit.selectedWeChatAccount.sourceAccountIdentifier);
1824
+ } else {
1825
+ this.props.actions.getIosCtas(this.props.Templates.selectedWeChatAccount.sourceAccountIdentifier);
1826
+ }
1827
+ //TODO: need to get license code of accoutn and send as arg
1702
1828
  } else {
1703
1829
  this.deleteSecondaryCtaIos(() => { // oncick of change
1704
1830
  this.setState({showIosCtaTable: true});
@@ -1953,6 +2079,7 @@ Edit.propTypes = {
1953
2079
  onValidationFail: PropTypes.bool,
1954
2080
  onPreviewContentClicked: PropTypes.func,
1955
2081
  onTestContentClicked: PropTypes.func,
2082
+ creativesMode: PropTypes.string,
1956
2083
  };
1957
2084
 
1958
2085
  const mapStateToProps = createStructuredSelector({