@capillarytech/creatives-library 8.0.345-alpha.12 → 8.0.345-alpha.13

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.
Files changed (138) hide show
  1. package/constants/unified.js +0 -29
  2. package/package.json +1 -1
  3. package/services/api.js +20 -0
  4. package/services/tests/api.test.js +59 -13
  5. package/utils/commonUtils.js +1 -19
  6. package/v2Components/CapActionButton/constants.js +0 -7
  7. package/v2Components/CapActionButton/index.js +109 -167
  8. package/v2Components/CapActionButton/index.scss +6 -157
  9. package/v2Components/CapActionButton/messages.js +3 -19
  10. package/v2Components/CapActionButton/tests/index.test.js +17 -41
  11. package/v2Components/CapCustomSkeleton/index.js +1 -1
  12. package/v2Components/CapCustomSkeleton/tests/__snapshots__/index.test.js.snap +12 -12
  13. package/v2Components/CapTagList/index.js +0 -10
  14. package/v2Components/CommonTestAndPreview/CustomValuesEditor.js +49 -70
  15. package/v2Components/CommonTestAndPreview/DeliverySettings/DeliverySettings.scss +2 -8
  16. package/v2Components/CommonTestAndPreview/DeliverySettings/ModifyDeliverySettings.js +21 -207
  17. package/v2Components/CommonTestAndPreview/DeliverySettings/constants.js +0 -16
  18. package/v2Components/CommonTestAndPreview/DeliverySettings/index.js +10 -85
  19. package/v2Components/CommonTestAndPreview/DeliverySettings/messages.js +0 -30
  20. package/v2Components/CommonTestAndPreview/DeliverySettings/utils/parseSenderDetailsResponse.js +11 -79
  21. package/v2Components/CommonTestAndPreview/SendTestMessage.js +5 -10
  22. package/v2Components/CommonTestAndPreview/UnifiedPreview/RcsPreviewContent.js +15 -160
  23. package/v2Components/CommonTestAndPreview/UnifiedPreview/_unifiedPreview.scss +76 -341
  24. package/v2Components/CommonTestAndPreview/UnifiedPreview/index.js +4 -133
  25. package/v2Components/CommonTestAndPreview/_commonTestAndPreview.scss +0 -11
  26. package/v2Components/CommonTestAndPreview/constants.js +2 -38
  27. package/v2Components/CommonTestAndPreview/index.js +186 -676
  28. package/v2Components/CommonTestAndPreview/messages.js +3 -49
  29. package/v2Components/CommonTestAndPreview/sagas.js +6 -15
  30. package/v2Components/CommonTestAndPreview/tests/CustomValuesEditor.test.js +284 -308
  31. package/v2Components/CommonTestAndPreview/tests/DeliverySettings/ModifyDeliverySettings.test.js +65 -231
  32. package/v2Components/CommonTestAndPreview/tests/DeliverySettings/index.test.js +5 -118
  33. package/v2Components/CommonTestAndPreview/tests/DeliverySettings/utils/parseSenderDetailsResponse.test.js +0 -341
  34. package/v2Components/CommonTestAndPreview/tests/PreviewSection.test.js +1 -8
  35. package/v2Components/CommonTestAndPreview/tests/SendTestMessage.test.js +13 -34
  36. package/v2Components/CommonTestAndPreview/tests/UnifiedPreview/RcsPreviewContent.test.js +283 -281
  37. package/v2Components/CommonTestAndPreview/tests/UnifiedPreview/index.test.js +1 -199
  38. package/v2Components/CommonTestAndPreview/tests/index.test.js +4 -132
  39. package/v2Components/CommonTestAndPreview/tests/sagas.test.js +2 -2
  40. package/v2Components/FormBuilder/index.js +10 -8
  41. package/v2Components/TemplatePreview/_templatePreview.scss +23 -33
  42. package/v2Components/TemplatePreview/index.js +28 -143
  43. package/v2Components/TemplatePreview/tests/index.test.js +0 -142
  44. package/v2Components/TestAndPreviewSlidebox/index.js +1 -13
  45. package/v2Components/TestAndPreviewSlidebox/sagas.js +4 -11
  46. package/v2Components/TestAndPreviewSlidebox/tests/saga.test.js +1 -3
  47. package/v2Containers/Assets/images/archive_Empty_Illustration.svg +9 -0
  48. package/v2Containers/CreativesContainer/SlideBoxContent.js +4 -36
  49. package/v2Containers/CreativesContainer/SlideBoxFooter.js +4 -11
  50. package/v2Containers/CreativesContainer/SlideBoxHeader.js +4 -29
  51. package/v2Containers/CreativesContainer/constants.js +0 -9
  52. package/v2Containers/CreativesContainer/index.js +108 -300
  53. package/v2Containers/CreativesContainer/index.scss +1 -51
  54. package/v2Containers/CreativesContainer/messages.js +4 -0
  55. package/v2Containers/CreativesContainer/tests/SlideBoxFooter.test.js +34 -78
  56. package/v2Containers/CreativesContainer/tests/SlideBoxHeader.test.js +16 -79
  57. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +0 -8
  58. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxHeader.test.js.snap +98 -357
  59. package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +18 -20
  60. package/v2Containers/CreativesContainer/tests/index.test.js +9 -71
  61. package/v2Containers/Rcs/constants.js +8 -119
  62. package/v2Containers/Rcs/index.js +812 -2375
  63. package/v2Containers/Rcs/index.scss +6 -276
  64. package/v2Containers/Rcs/messages.js +3 -38
  65. package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +70345 -98302
  66. package/v2Containers/Rcs/tests/__snapshots__/utils.test.js.snap +5 -0
  67. package/v2Containers/Rcs/tests/index.test.js +121 -152
  68. package/v2Containers/Rcs/tests/mockData.js +0 -38
  69. package/v2Containers/Rcs/tests/utils.test.js +30 -646
  70. package/v2Containers/Rcs/utils.js +11 -478
  71. package/v2Containers/Sms/Create/index.js +40 -100
  72. package/v2Containers/SmsTrai/Create/index.js +4 -9
  73. package/v2Containers/SmsTrai/Edit/constants.js +0 -2
  74. package/v2Containers/SmsTrai/Edit/index.js +130 -636
  75. package/v2Containers/SmsTrai/Edit/messages.js +4 -14
  76. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +2296 -4249
  77. package/v2Containers/SmsWrapper/index.js +8 -37
  78. package/v2Containers/TagList/index.js +0 -6
  79. package/v2Containers/Templates/ChannelTypeIllustration.js +23 -6
  80. package/v2Containers/Templates/_templates.scss +126 -181
  81. package/v2Containers/Templates/actions.js +36 -11
  82. package/v2Containers/Templates/constants.js +23 -2
  83. package/v2Containers/Templates/index.js +333 -142
  84. package/v2Containers/Templates/messages.js +68 -0
  85. package/v2Containers/Templates/reducer.js +68 -0
  86. package/v2Containers/Templates/sagas.js +98 -55
  87. package/v2Containers/Templates/selectors.js +12 -0
  88. package/v2Containers/Templates/tests/ChannelTypeIllustration.test.js +12 -0
  89. package/v2Containers/Templates/tests/__snapshots__/index.test.js.snap +1256 -1042
  90. package/v2Containers/Templates/tests/index.test.js +6 -0
  91. package/v2Containers/Templates/tests/reducer.test.js +178 -0
  92. package/v2Containers/Templates/tests/sagas.test.js +436 -200
  93. package/v2Containers/Templates/tests/selector.test.js +32 -0
  94. package/v2Containers/TemplatesV2/TemplatesV2.style.js +1 -72
  95. package/v2Containers/TemplatesV2/index.js +23 -86
  96. package/v2Containers/Whatsapp/index.js +20 -3
  97. package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +34 -578
  98. package/utils/rcsPayloadUtils.js +0 -92
  99. package/utils/templateVarUtils.js +0 -201
  100. package/utils/tests/templateVarUtils.test.js +0 -204
  101. package/v2Components/CommonTestAndPreview/UnifiedPreview/RcsPreviewContent.js.rej +0 -18
  102. package/v2Components/CommonTestAndPreview/previewApiUtils.js +0 -59
  103. package/v2Components/CommonTestAndPreview/tests/previewApiUtils.test.js +0 -67
  104. package/v2Components/SmsFallback/SmsFallbackLocalSelector.js +0 -87
  105. package/v2Components/SmsFallback/constants.js +0 -73
  106. package/v2Components/SmsFallback/index.js +0 -955
  107. package/v2Components/SmsFallback/index.scss +0 -265
  108. package/v2Components/SmsFallback/messages.js +0 -78
  109. package/v2Components/SmsFallback/smsFallbackUtils.js +0 -118
  110. package/v2Components/SmsFallback/tests/SmsFallbackLocalSelector.test.js +0 -50
  111. package/v2Components/SmsFallback/tests/rcsSmsFallback.acceptance.test.js +0 -147
  112. package/v2Components/SmsFallback/tests/smsFallbackHandlers.test.js +0 -304
  113. package/v2Components/SmsFallback/tests/smsFallbackUi.test.js +0 -197
  114. package/v2Components/SmsFallback/tests/smsFallbackUtils.test.js +0 -277
  115. package/v2Components/SmsFallback/tests/useLocalTemplateList.test.js +0 -422
  116. package/v2Components/SmsFallback/useLocalTemplateList.js +0 -92
  117. package/v2Components/TemplatePreview/constants.js +0 -2
  118. package/v2Components/VarSegmentMessageEditor/constants.js +0 -2
  119. package/v2Components/VarSegmentMessageEditor/index.js +0 -125
  120. package/v2Components/VarSegmentMessageEditor/index.scss +0 -46
  121. package/v2Containers/CreativesContainer/CreativesSlideBoxWrapper.js +0 -43
  122. package/v2Containers/CreativesContainer/embeddedSlideboxUtils.js +0 -67
  123. package/v2Containers/CreativesContainer/tests/SlideBoxContent.localTemplates.test.js +0 -90
  124. package/v2Containers/CreativesContainer/tests/embeddedSlideboxUtils.test.js +0 -258
  125. package/v2Containers/CreativesContainer/tests/useLocalTemplatesProp.test.js +0 -125
  126. package/v2Containers/Rcs/index.js.rej +0 -1336
  127. package/v2Containers/Rcs/index.scss.rej +0 -74
  128. package/v2Containers/Rcs/rcsLibraryHydrationUtils.js +0 -225
  129. package/v2Containers/Rcs/tests/__snapshots__/utils.test.js.snap.rej +0 -128
  130. package/v2Containers/Rcs/tests/rcsLibraryHydrationUtils.test.js +0 -318
  131. package/v2Containers/Sms/smsFormDataHelpers.js +0 -67
  132. package/v2Containers/Sms/tests/smsFormDataHelpers.test.js +0 -253
  133. package/v2Containers/SmsTrai/Edit/index.scss +0 -121
  134. package/v2Containers/Templates/TemplatesActionBar.js +0 -101
  135. package/v2Containers/Templates/tests/TemplatesActionBar.test.js +0 -120
  136. package/v2Containers/Templates/tests/smsTemplatesListApi.test.js +0 -180
  137. package/v2Containers/Templates/utils/smsTemplatesListApi.js +0 -79
  138. package/v2Containers/TemplatesV2/tests/TemplatesV2.localTemplates.test.js +0 -131
@@ -12,7 +12,7 @@ export default defineMessages({
12
12
  },
13
13
  ctaQr: {
14
14
  id: `${prefix}.ctaQr`,
15
- defaultMessage: 'Quick reply',
15
+ defaultMessage: 'Quick Reply',
16
16
  },
17
17
  ctaPhoneNo: {
18
18
  id: `${prefix}.ctaPhoneNo`,
@@ -47,17 +47,9 @@ export default defineMessages({
47
47
  id: `${prefix}.templateMessageLength`,
48
48
  defaultMessage: 'Characters count: {currentLength}/{maxLength}',
49
49
  },
50
- ctaFieldCharCountInline: {
51
- id: `${prefix}.ctaFieldCharCountInline`,
52
- defaultMessage: '{current}/{max}',
53
- },
54
50
  ctaType: {
55
51
  id: `${prefix}.ctaType`,
56
- defaultMessage: 'Button type',
57
- },
58
- ctaUrlRadio: {
59
- id: `${prefix}.ctaUrlRadio`,
60
- defaultMessage: 'URL',
52
+ defaultMessage: 'Type of action',
61
53
  },
62
54
  templateButtonTextPlaceholder: {
63
55
  id: `${prefix}.templateButtonTextPlaceholder`,
@@ -153,15 +145,7 @@ export default defineMessages({
153
145
  },
154
146
  ctaWebsiteType: {
155
147
  id: `${prefix}.ctaWebsiteType`,
156
- defaultMessage: 'URL type',
157
- },
158
- ctaUrlField: {
159
- id: `${prefix}.ctaUrlField`,
160
- defaultMessage: 'URL',
161
- },
162
- ctaEnterUrlPlaceholder: {
163
- id: `${prefix}.ctaEnterUrlPlaceholder`,
164
- defaultMessage: 'Enter URL',
148
+ defaultMessage: 'URL Type',
165
149
  },
166
150
  ctaWebsiteTypeStatic: {
167
151
  id: `${prefix}.ctaWebsiteTypeStatic`,
@@ -4,7 +4,7 @@ import '@testing-library/jest-dom';
4
4
  import { render, screen, fireEvent } from '../../../utils/test-utils';
5
5
  import { CapActionButton } from '../index';
6
6
  import { BTN_MAX_LENGTH, PHONE_NUMBER_MAX_LENGTH, URL_MAX_LENGTH } from '../constants';
7
- import { RCS_BUTTON_TYPES, HOST_ICS } from '../../../v2Containers/Rcs/constants';
7
+ import { RCS_BUTTON_TYPES } from '../../../v2Containers/Rcs/constants';
8
8
 
9
9
  const updateHandler = jest.fn();
10
10
  const deleteHandler = jest.fn();
@@ -12,7 +12,6 @@ const initializeComponent = (
12
12
  data,
13
13
  isEditFlow = false,
14
14
  maxButtons = 3,
15
- host = '',
16
15
  ) => {
17
16
  // Normalize legacy test data shape to match component props
18
17
  const normalizeType = (legacyType) => {
@@ -38,7 +37,6 @@ const initializeComponent = (
38
37
  isEditFlow={isEditFlow}
39
38
  maxButtons={maxButtons}
40
39
  isFullMode={true}
41
- host={host}
42
40
  />,
43
41
  );
44
42
  };
@@ -61,7 +59,7 @@ describe('CapActionButton', () => {
61
59
  isSaved: false,
62
60
  },
63
61
  ]);
64
- expect(screen.getByText('Button type')).toBeInTheDocument();
62
+ expect(screen.getByText('Type of action')).toBeInTheDocument();
65
63
  expect(screen.getByText('Button text')).toBeInTheDocument();
66
64
  expect(screen.getAllByText('Phone number')[1]).toBeInTheDocument();
67
65
  expect(screen.getByRole('button', { name: /save/i })).toBeDisabled();
@@ -124,7 +122,7 @@ describe('CapActionButton', () => {
124
122
  id: 1,
125
123
  },
126
124
  };
127
- const urlInput = await screen.getByPlaceholderText('Enter URL');
125
+ const urlInput = await screen.getByPlaceholderText('Enter website URL');
128
126
  fireEvent.change(urlInput, urlEvent);
129
127
  expect(updateHandler).toHaveBeenCalledWith(
130
128
  {
@@ -164,27 +162,6 @@ describe('CapActionButton', () => {
164
162
  );
165
163
  });
166
164
 
167
- it('should show delete for quick reply index 0 for non-ICS hosts but hide it for ICS (stop button)', () => {
168
- const button = {
169
- index: 0,
170
- type: RCS_BUTTON_TYPES.QUICK_REPLY,
171
- text: 'Reply',
172
- phoneNumber: '',
173
- url: '',
174
- postback: 'Reply',
175
- isSaved: false,
176
- };
177
-
178
- // Non-ICS (Infobip/others): delete should be available
179
- const { unmount } = initializeComponent([button], false, 3, 'rcsinfobipbulk');
180
- expect(screen.getByRole('button', { name: /delete/i })).toBeInTheDocument();
181
- unmount();
182
-
183
- // ICS: index 0 is reserved; delete should be hidden
184
- initializeComponent([button], false, 3, HOST_ICS);
185
- expect(screen.queryByRole('button', { name: /delete/i })).not.toBeInTheDocument();
186
- });
187
-
188
165
  it('should respect character length limits', async () => {
189
166
  const initialData = {
190
167
  index: 0,
@@ -221,7 +198,7 @@ describe('CapActionButton', () => {
221
198
  isSaved: false,
222
199
  };
223
200
  initializeComponent([initialData]);
224
- const urlInput = await screen.getByPlaceholderText('Enter URL');
201
+ const urlInput = await screen.getByPlaceholderText('Enter website URL');
225
202
  const longUrl = 'https://example.com/' + 'a'.repeat(URL_MAX_LENGTH + 1);
226
203
  fireEvent.change(urlInput, { target: { value: longUrl, id: 0 } });
227
204
  expect(urlInput.value.length).toBeLessThanOrEqual(URL_MAX_LENGTH);
@@ -268,8 +245,7 @@ describe('CapActionButton', () => {
268
245
  { index: 0, ctaType: RCS_BUTTON_TYPES.QUICK_REPLY, displayText: 'stop', phoneNumber: '', url: '', postback: 'stop', isSaved: true },
269
246
  { index: 1, ctaType: RCS_BUTTON_TYPES.QUICK_REPLY, displayText: 'Saved', phoneNumber: '', url: '', postback: 'Saved', isSaved: true },
270
247
  ];
271
- // Use ICS host so index 0 (STOP) stays non-deletable and we only get delete icon for index 1
272
- const { container } = initializeComponent(suggestions, false, 3, HOST_ICS);
248
+ const { container } = initializeComponent(suggestions);
273
249
  const deleteIcons = container.querySelectorAll('.rcs-saved-cta-delete-icon');
274
250
  expect(deleteIcons.length).toBeGreaterThan(0);
275
251
  fireEvent.click(deleteIcons[0]);
@@ -327,8 +303,7 @@ describe('CapActionButton', () => {
327
303
  postback: 'stop',
328
304
  isSaved: true,
329
305
  };
330
- // Only ICS treats index 0 as a mandatory STOP quick reply
331
- const { container } = initializeComponent([stopButton], false, 3, HOST_ICS);
306
+ const { container } = initializeComponent([stopButton]);
332
307
  expect(container.querySelector('.rcs-saved-cta-delete-icon')).not.toBeInTheDocument();
333
308
  });
334
309
 
@@ -449,7 +424,7 @@ describe('CapActionButton', () => {
449
424
  isSaved: false,
450
425
  };
451
426
  initializeComponent([button]);
452
- expect(screen.getByPlaceholderText(/enter url/i)).toBeInTheDocument();
427
+ expect(screen.getByPlaceholderText(/enter website url/i)).toBeInTheDocument();
453
428
  });
454
429
 
455
430
  it('should update both displayText and postback when button text changes (updateDisplayAndPostback)', () => {
@@ -529,7 +504,7 @@ describe('CapActionButton', () => {
529
504
  isSaved: false,
530
505
  };
531
506
  initializeComponent([initial]);
532
- const urlInput = screen.getByPlaceholderText('Enter URL');
507
+ const urlInput = screen.getByPlaceholderText('Enter website URL');
533
508
  fireEvent.change(urlInput, { target: { value: 'http://localhost:3030/creatives/ui/v2', id: 1 } });
534
509
  expect(screen.getByText(/url is not valid/i)).toBeInTheDocument();
535
510
  });
@@ -615,7 +590,7 @@ describe('CapActionButton', () => {
615
590
  isSaved: false,
616
591
  };
617
592
  initializeComponent([initial]);
618
- const urlInput = screen.getByPlaceholderText('Enter URL');
593
+ const urlInput = screen.getByPlaceholderText('Enter website URL');
619
594
  // Enter invalid URL
620
595
  fireEvent.change(urlInput, { target: { value: 'badurl', id: 0 } });
621
596
  expect(screen.getByText(/url is not valid/i)).toBeInTheDocument();
@@ -874,14 +849,15 @@ describe('CapActionButton function logic', () => {
874
849
  expect(renderCtaOptions(label, tooltipLabel, false)).toBe('Test');
875
850
  });
876
851
 
877
- it('inner char count uses current/max format', () => {
878
- const formatMessage = (msg, values) => `${values.current}/${values.max}`;
879
- const renderInnerCharCount = (len, max) => (
880
- <span className="rcs-cta-inner-char-count">
881
- {formatMessage({}, { current: len, max })}
882
- </span>
852
+ it('renderLength returns correct CapHeading', () => {
853
+ const CapHeading = ({ type, className, children }) => <div className={className}>{children}</div>;
854
+ const formatMessage = (msg, values) => `${values.currentLength}/${values.maxLength}`;
855
+ const renderLength = (len, max) => (
856
+ <CapHeading type="label1" className="rcs-render-btn-length">
857
+ {formatMessage({}, { currentLength: len, maxLength: max })}
858
+ </CapHeading>
883
859
  );
884
- const result = renderInnerCharCount(5, 25);
860
+ const result = renderLength(5, 25);
885
861
  expect(result.props.children).toBe('5/25');
886
862
  });
887
863
  });
@@ -28,7 +28,7 @@ export default function CapCustomSkeleton(props) {
28
28
  xs={24}
29
29
  sm={12}
30
30
  md={8}
31
- lg={6}
31
+ lg={8}
32
32
  >
33
33
  <CapSkeleton
34
34
  active
@@ -20,7 +20,7 @@ exports[`CapCustomSkeleton test renders correct CapCustomSkeleton component 1`]
20
20
  >
21
21
  <CapColumn
22
22
  key="0"
23
- lg={6}
23
+ lg={8}
24
24
  md={8}
25
25
  sm={12}
26
26
  xs={24}
@@ -40,7 +40,7 @@ exports[`CapCustomSkeleton test renders correct CapCustomSkeleton component 1`]
40
40
  </CapColumn>
41
41
  <CapColumn
42
42
  key="1"
43
- lg={6}
43
+ lg={8}
44
44
  md={8}
45
45
  sm={12}
46
46
  xs={24}
@@ -60,7 +60,7 @@ exports[`CapCustomSkeleton test renders correct CapCustomSkeleton component 1`]
60
60
  </CapColumn>
61
61
  <CapColumn
62
62
  key="2"
63
- lg={6}
63
+ lg={8}
64
64
  md={8}
65
65
  sm={12}
66
66
  xs={24}
@@ -80,7 +80,7 @@ exports[`CapCustomSkeleton test renders correct CapCustomSkeleton component 1`]
80
80
  </CapColumn>
81
81
  <CapColumn
82
82
  key="3"
83
- lg={6}
83
+ lg={8}
84
84
  md={8}
85
85
  sm={12}
86
86
  xs={24}
@@ -100,7 +100,7 @@ exports[`CapCustomSkeleton test renders correct CapCustomSkeleton component 1`]
100
100
  </CapColumn>
101
101
  <CapColumn
102
102
  key="4"
103
- lg={6}
103
+ lg={8}
104
104
  md={8}
105
105
  sm={12}
106
106
  xs={24}
@@ -120,7 +120,7 @@ exports[`CapCustomSkeleton test renders correct CapCustomSkeleton component 1`]
120
120
  </CapColumn>
121
121
  <CapColumn
122
122
  key="5"
123
- lg={6}
123
+ lg={8}
124
124
  md={8}
125
125
  sm={12}
126
126
  xs={24}
@@ -140,7 +140,7 @@ exports[`CapCustomSkeleton test renders correct CapCustomSkeleton component 1`]
140
140
  </CapColumn>
141
141
  <CapColumn
142
142
  key="6"
143
- lg={6}
143
+ lg={8}
144
144
  md={8}
145
145
  sm={12}
146
146
  xs={24}
@@ -160,7 +160,7 @@ exports[`CapCustomSkeleton test renders correct CapCustomSkeleton component 1`]
160
160
  </CapColumn>
161
161
  <CapColumn
162
162
  key="7"
163
- lg={6}
163
+ lg={8}
164
164
  md={8}
165
165
  sm={12}
166
166
  xs={24}
@@ -180,7 +180,7 @@ exports[`CapCustomSkeleton test renders correct CapCustomSkeleton component 1`]
180
180
  </CapColumn>
181
181
  <CapColumn
182
182
  key="8"
183
- lg={6}
183
+ lg={8}
184
184
  md={8}
185
185
  sm={12}
186
186
  xs={24}
@@ -200,7 +200,7 @@ exports[`CapCustomSkeleton test renders correct CapCustomSkeleton component 1`]
200
200
  </CapColumn>
201
201
  <CapColumn
202
202
  key="9"
203
- lg={6}
203
+ lg={8}
204
204
  md={8}
205
205
  sm={12}
206
206
  xs={24}
@@ -220,7 +220,7 @@ exports[`CapCustomSkeleton test renders correct CapCustomSkeleton component 1`]
220
220
  </CapColumn>
221
221
  <CapColumn
222
222
  key="10"
223
- lg={6}
223
+ lg={8}
224
224
  md={8}
225
225
  sm={12}
226
226
  xs={24}
@@ -240,7 +240,7 @@ exports[`CapCustomSkeleton test renders correct CapCustomSkeleton component 1`]
240
240
  </CapColumn>
241
241
  <CapColumn
242
242
  key="11"
243
- lg={6}
243
+ lg={8}
244
244
  md={8}
245
245
  sm={12}
246
246
  xs={24}
@@ -386,9 +386,6 @@ class CapTagList extends React.Component { // eslint-disable-line react/prefer-s
386
386
  render() {
387
387
  const {
388
388
  hidePopover = false, intl = {}, moduleFilterEnabled, label, modalProps, channel, fetchingSchemaError = false,
389
- overlayStyle,
390
- overlayClassName,
391
- getPopupContainer,
392
389
  } = this.props;
393
390
  const {formatMessage} = intl;
394
391
  const {
@@ -481,9 +478,6 @@ class CapTagList extends React.Component { // eslint-disable-line react/prefer-s
481
478
  content={contentSection}
482
479
  trigger="click"
483
480
  placement={this.props.popoverPlacement || (channel === EMAIL.toUpperCase() ? "leftTop" : "rightTop")}
484
- overlayStyle={overlayStyle}
485
- overlayClassName={overlayClassName}
486
- getPopupContainer={getPopupContainer}
487
481
  >
488
482
  <CapTooltip
489
483
  title={
@@ -555,10 +549,6 @@ CapTagList.propTypes = {
555
549
  disableTooltipMsg: PropTypes.string,
556
550
  fetchingSchemaError: PropTypes.bool,
557
551
  popoverPlacement: PropTypes.string,
558
- overlayStyle: PropTypes.object,
559
- overlayClassName: PropTypes.string,
560
- /** e.g. () => document.body — avoids overflow/stacking issues inside slideboxes */
561
- getPopupContainer: PropTypes.func,
562
552
  };
563
553
 
564
554
  CapTagList.defaultValue = {
@@ -8,7 +8,6 @@ import CapButton from '@capillarytech/cap-ui-library/CapButton';
8
8
  import CapInput from '@capillarytech/cap-ui-library/CapInput';
9
9
  import CapLabel from '@capillarytech/cap-ui-library/CapLabel';
10
10
  import messages from './messages';
11
- import { CUSTOM_VALUES_EDITOR_SECTION_FALLBACK_KEY } from './constants';
12
11
 
13
12
  const CustomValuesEditor = ({
14
13
  isExtractingTags,
@@ -17,16 +16,15 @@ const CustomValuesEditor = ({
17
16
  setShowJSON,
18
17
  customValues,
19
18
  handleJSONTextChange,
20
- sections,
19
+ extractedTags,
20
+ requiredTags,
21
+ optionalTags,
21
22
  handleCustomValueChange,
22
23
  handleDiscardCustomValues,
23
24
  handleUpdatePreview,
24
25
  isUpdatingPreview,
25
26
  formatMessage,
26
27
  }) => {
27
- /** Same as SMS Test & Preview: show token path from extract-tags (fullPath or name). */
28
- const getPersonalizationTagColumnLabel = (tagNode) => tagNode?.fullPath ?? tagNode?.name ?? '';
29
-
30
28
  if (isExtractingTags) {
31
29
  return (
32
30
  <CapRow className="loading-container">
@@ -79,68 +77,52 @@ const CustomValuesEditor = ({
79
77
  </CapRow>
80
78
  ) : (
81
79
  <>
82
- {(sections || []).filter((tagsSection) =>
83
- (tagsSection?.requiredTags?.length || 0) + (tagsSection?.optionalTags?.length || 0) > 0).map((section) => (
84
- <React.Fragment key={section.key || section.title?.id || section.title || CUSTOM_VALUES_EDITOR_SECTION_FALLBACK_KEY}>
85
- {section.title ? (
86
- <CapLabel type="label2" className="tags-section-title">
87
- {typeof section.title === 'string' ? section.title : <FormattedMessage {...section.title} />}
80
+ {extractedTags?.length > 0 && (
81
+ <CapRow className="values-table">
82
+ <CapRow className="table-header">
83
+ <CapLabel type="label31" className="header-cell">
84
+ <FormattedMessage {...messages.personalizationTags} />
88
85
  </CapLabel>
89
- ) : null}
90
- <CapRow className="values-table">
91
- <CapRow className="table-header">
92
- <CapLabel type="label31" className="header-cell">
93
- <FormattedMessage {...messages.personalizationTags} />
94
- </CapLabel>
95
- <CapLabel type="label31" className="header-cell">
96
- <FormattedMessage {...messages.customValues} />
97
- </CapLabel>
98
- </CapRow>
99
- {(section?.requiredTags || []).map((tag, tagIndex) => {
100
- const personalizationTagColumnText = getPersonalizationTagColumnLabel(tag);
101
- return (
102
- <CapRow key={tag?.fullPath ?? `required-${tagIndex}`} className="value-row">
103
- <CapRow className="tag-name">
104
- {personalizationTagColumnText}
105
- <span className="required-tag-indicator">*</span>
106
- </CapRow>
107
- <CapRow className="tag-input">
108
- <CapInput
109
- type="text"
110
- isRequired
111
- className="tag-input-field"
112
- value={customValues?.[tag?.fullPath] ?? ''}
113
- onChange={(e) => handleCustomValueChange(tag?.fullPath, e.target.value)}
114
- placeholder={formatMessage(messages.enterValue)}
115
- size="small"
116
- />
117
- </CapRow>
86
+ <CapLabel type="label31" className="header-cell">
87
+ <FormattedMessage {...messages.customValues} />
88
+ </CapLabel>
89
+ </CapRow>
90
+ {requiredTags.map((tag) => (
91
+ <CapRow key={tag.fullPath} className="value-row">
92
+ <CapRow className="tag-name">
93
+ {tag.fullPath}
94
+ <span className="required-tag-indicator">*</span>
118
95
  </CapRow>
119
- );
120
- })}
121
- {(section?.optionalTags || []).map((tag, tagIndex) => {
122
- const personalizationTagColumnText = getPersonalizationTagColumnLabel(tag);
123
- return (
124
- <CapRow key={tag?.fullPath ?? `optional-${tagIndex}`} className="value-row">
125
- <CapRow className="tag-name">
126
- {personalizationTagColumnText}
127
- </CapRow>
128
- <CapRow className="tag-input">
129
- <CapInput
130
- type="text"
131
- className="tag-input-field"
132
- value={customValues?.[tag?.fullPath] ?? ''}
133
- onChange={(e) => handleCustomValueChange(tag?.fullPath, e.target.value)}
134
- placeholder={formatMessage(messages.enterValue)}
135
- size="small"
136
- />
137
- </CapRow>
96
+ <CapRow className="tag-input">
97
+ <CapInput
98
+ type="text"
99
+ isRequired
100
+ className="tag-input-field"
101
+ value={customValues[tag.fullPath] || ''}
102
+ onChange={(e) => handleCustomValueChange(tag.fullPath, e.target.value)}
103
+ placeholder={formatMessage(messages.enterValue)}
104
+ size="small"
105
+ />
138
106
  </CapRow>
139
- );
140
- })}
141
- </CapRow>
142
- </React.Fragment>
143
- ))}
107
+ </CapRow>
108
+ ))}
109
+ {optionalTags?.map((tag) => (
110
+ <CapRow key={tag.fullPath} className="value-row">
111
+ <CapRow className="tag-name">{tag.fullPath}</CapRow>
112
+ <CapRow className="tag-input">
113
+ <CapInput
114
+ type="text"
115
+ className="tag-input-field"
116
+ value={customValues[tag.fullPath] || ''}
117
+ onChange={(e) => handleCustomValueChange(tag.fullPath, e.target.value)}
118
+ placeholder={formatMessage(messages.enterValue)}
119
+ size="small"
120
+ />
121
+ </CapRow>
122
+ </CapRow>
123
+ ))}
124
+ </CapRow>
125
+ )}
144
126
  </>
145
127
  )}
146
128
  <CapRow className="editor-actions">
@@ -174,12 +156,9 @@ CustomValuesEditor.propTypes = {
174
156
  setShowJSON: PropTypes.func.isRequired,
175
157
  customValues: PropTypes.object.isRequired,
176
158
  handleJSONTextChange: PropTypes.func.isRequired,
177
- sections: PropTypes.arrayOf(PropTypes.shape({
178
- key: PropTypes.string,
179
- title: PropTypes.oneOfType([PropTypes.string, PropTypes.object]),
180
- requiredTags: PropTypes.array,
181
- optionalTags: PropTypes.array,
182
- })).isRequired,
159
+ extractedTags: PropTypes.array.isRequired,
160
+ requiredTags: PropTypes.array.isRequired,
161
+ optionalTags: PropTypes.array.isRequired,
183
162
  handleCustomValueChange: PropTypes.func.isRequired,
184
163
  handleDiscardCustomValues: PropTypes.func.isRequired,
185
164
  handleUpdatePreview: PropTypes.func.isRequired,
@@ -18,17 +18,11 @@
18
18
  }
19
19
 
20
20
  &__summary-entry {
21
- display: flex;
22
- align-items: baseline;
23
- gap: 0;
24
21
  margin-right: $CAP_SPACE_18;
25
22
  }
26
23
 
27
- &__summary-key,
28
- &__summary-value {
29
- line-height: 1.4;
30
- margin-top: 0;
31
- margin-bottom: 0;
24
+ &__summary-key {
25
+ line-height: $CAP_SPACE_16;
32
26
  }
33
27
 
34
28
  &__edit-icon {