@capillarytech/creatives-library 8.0.318 → 8.0.320

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 (139) hide show
  1. package/constants/unified.js +15 -0
  2. package/package.json +1 -1
  3. package/services/api.js +6 -0
  4. package/services/tests/api.test.js +7 -0
  5. package/utils/common.js +6 -1
  6. package/utils/templateVarUtils.js +172 -0
  7. package/utils/tests/templateVarUtils.test.js +160 -0
  8. package/v2Components/CapTagList/index.js +10 -0
  9. package/v2Components/CommonTestAndPreview/CustomValuesEditor.js +70 -49
  10. package/v2Components/CommonTestAndPreview/DeliverySettings/DeliverySettings.scss +8 -2
  11. package/v2Components/CommonTestAndPreview/DeliverySettings/ModifyDeliverySettings.js +207 -21
  12. package/v2Components/CommonTestAndPreview/DeliverySettings/constants.js +16 -0
  13. package/v2Components/CommonTestAndPreview/DeliverySettings/index.js +85 -10
  14. package/v2Components/CommonTestAndPreview/DeliverySettings/messages.js +30 -0
  15. package/v2Components/CommonTestAndPreview/DeliverySettings/utils/parseSenderDetailsResponse.js +79 -11
  16. package/v2Components/CommonTestAndPreview/SendTestMessage.js +11 -5
  17. package/v2Components/CommonTestAndPreview/UnifiedPreview/_unifiedPreview.scss +20 -1
  18. package/v2Components/CommonTestAndPreview/UnifiedPreview/index.js +133 -4
  19. package/v2Components/CommonTestAndPreview/_commonTestAndPreview.scss +12 -0
  20. package/v2Components/CommonTestAndPreview/constants.js +38 -0
  21. package/v2Components/CommonTestAndPreview/index.js +693 -155
  22. package/v2Components/CommonTestAndPreview/messages.js +41 -3
  23. package/v2Components/CommonTestAndPreview/previewApiUtils.js +59 -0
  24. package/v2Components/CommonTestAndPreview/sagas.js +15 -6
  25. package/v2Components/CommonTestAndPreview/tests/CustomValuesEditor.test.js +352 -0
  26. package/v2Components/CommonTestAndPreview/tests/DeliverySettings/ModifyDeliverySettings.test.js +269 -1
  27. package/v2Components/CommonTestAndPreview/tests/DeliverySettings/index.test.js +118 -5
  28. package/v2Components/CommonTestAndPreview/tests/DeliverySettings/utils/parseSenderDetailsResponse.test.js +341 -0
  29. package/v2Components/CommonTestAndPreview/tests/SendTestMessage.test.js +25 -4
  30. package/v2Components/CommonTestAndPreview/tests/UnifiedPreview/index.test.js +199 -1
  31. package/v2Components/CommonTestAndPreview/tests/index.test.js +132 -4
  32. package/v2Components/CommonTestAndPreview/tests/previewApiUtils.test.js +67 -0
  33. package/v2Components/CommonTestAndPreview/tests/sagas.test.js +2 -2
  34. package/v2Components/FormBuilder/index.js +7 -1
  35. package/v2Components/SmsFallback/SmsFallbackLocalSelector.js +87 -0
  36. package/v2Components/SmsFallback/constants.js +73 -0
  37. package/v2Components/SmsFallback/index.js +956 -0
  38. package/v2Components/SmsFallback/index.scss +265 -0
  39. package/v2Components/SmsFallback/messages.js +78 -0
  40. package/v2Components/SmsFallback/smsFallbackUtils.js +107 -0
  41. package/v2Components/SmsFallback/tests/SmsFallbackLocalSelector.test.js +50 -0
  42. package/v2Components/SmsFallback/tests/rcsSmsFallback.acceptance.test.js +147 -0
  43. package/v2Components/SmsFallback/tests/smsFallbackHandlers.test.js +304 -0
  44. package/v2Components/SmsFallback/tests/smsFallbackUi.test.js +197 -0
  45. package/v2Components/SmsFallback/tests/smsFallbackUtils.test.js +261 -0
  46. package/v2Components/SmsFallback/tests/useLocalTemplateList.test.js +422 -0
  47. package/v2Components/SmsFallback/useLocalTemplateList.js +92 -0
  48. package/v2Components/TestAndPreviewSlidebox/index.js +8 -1
  49. package/v2Components/TestAndPreviewSlidebox/sagas.js +11 -4
  50. package/v2Components/TestAndPreviewSlidebox/tests/saga.test.js +3 -1
  51. package/v2Components/VarSegmentMessageEditor/constants.js +2 -0
  52. package/v2Components/VarSegmentMessageEditor/index.js +125 -0
  53. package/v2Components/VarSegmentMessageEditor/index.scss +46 -0
  54. package/v2Containers/CommunicationFlow/CommunicationFlow.js +291 -0
  55. package/v2Containers/CommunicationFlow/CommunicationFlow.scss +25 -0
  56. package/v2Containers/CommunicationFlow/Tests/CommunicationFlow.test.js +255 -0
  57. package/v2Containers/CommunicationFlow/constants.js +200 -0
  58. package/v2Containers/CommunicationFlow/index.js +102 -0
  59. package/v2Containers/CommunicationFlow/messages.js +346 -0
  60. package/v2Containers/CommunicationFlow/steps/ChannelSelectionStep/ChannelSelectionStep.js +522 -0
  61. package/v2Containers/CommunicationFlow/steps/ChannelSelectionStep/ChannelSelectionStep.scss +170 -0
  62. package/v2Containers/CommunicationFlow/steps/ChannelSelectionStep/Tests/ChannelSelectionStep.test.js +796 -0
  63. package/v2Containers/CommunicationFlow/steps/ChannelSelectionStep/index.js +5 -0
  64. package/v2Containers/CommunicationFlow/steps/CommunicationStrategyStep/CommunicationStrategyStep.js +95 -0
  65. package/v2Containers/CommunicationFlow/steps/CommunicationStrategyStep/Tests/CommunicationStrategyStep.test.js +133 -0
  66. package/v2Containers/CommunicationFlow/steps/CommunicationStrategyStep/index.js +5 -0
  67. package/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/DeliverySettingsSection.js +289 -0
  68. package/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/DeliverySettingsSection.scss +70 -0
  69. package/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/SenderDetails.js +319 -0
  70. package/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/SenderDetails.scss +69 -0
  71. package/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/Tests/DeliverySettingsSection.test.js +616 -0
  72. package/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/Tests/SenderDetails.test.js +577 -0
  73. package/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/Tests/deliverySettingsConfig.test.js +1111 -0
  74. package/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/deliverySettingsConfig.js +696 -0
  75. package/v2Containers/CommunicationFlow/steps/DeliverySettingsStep/index.js +7 -0
  76. package/v2Containers/CommunicationFlow/steps/DynamicControlsStep/DynamicControlsStep.js +102 -0
  77. package/v2Containers/CommunicationFlow/steps/DynamicControlsStep/DynamicControlsStep.scss +36 -0
  78. package/v2Containers/CommunicationFlow/steps/DynamicControlsStep/Tests/DynamicControlsStep.test.js +91 -0
  79. package/v2Containers/CommunicationFlow/steps/DynamicControlsStep/index.js +5 -0
  80. package/v2Containers/CommunicationFlow/steps/MessageTypeStep/MessageTypeStep.js +86 -0
  81. package/v2Containers/CommunicationFlow/steps/MessageTypeStep/Tests/MessageTypeStep.test.js +100 -0
  82. package/v2Containers/CommunicationFlow/steps/MessageTypeStep/index.js +5 -0
  83. package/v2Containers/CommunicationFlow/utils/getEnabledSteps.js +30 -0
  84. package/v2Containers/CreativesContainer/CreativesSlideBoxWrapper.js +43 -0
  85. package/v2Containers/CreativesContainer/SlideBoxContent.js +36 -4
  86. package/v2Containers/CreativesContainer/SlideBoxFooter.js +10 -1
  87. package/v2Containers/CreativesContainer/SlideBoxHeader.js +29 -4
  88. package/v2Containers/CreativesContainer/constants.js +12 -0
  89. package/v2Containers/CreativesContainer/embeddedSlideboxUtils.js +67 -0
  90. package/v2Containers/CreativesContainer/index.js +289 -99
  91. package/v2Containers/CreativesContainer/index.scss +51 -1
  92. package/v2Containers/CreativesContainer/tests/SlideBoxContent.localTemplates.test.js +90 -0
  93. package/v2Containers/CreativesContainer/tests/SlideBoxFooter.test.js +104 -0
  94. package/v2Containers/CreativesContainer/tests/SlideBoxHeader.test.js +110 -0
  95. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxContent.test.js.snap +8 -0
  96. package/v2Containers/CreativesContainer/tests/__snapshots__/SlideBoxHeader.test.js.snap +363 -0
  97. package/v2Containers/CreativesContainer/tests/__snapshots__/index.test.js.snap +20 -10
  98. package/v2Containers/CreativesContainer/tests/embeddedSlideboxUtils.test.js +258 -0
  99. package/v2Containers/CreativesContainer/tests/index.test.js +71 -9
  100. package/v2Containers/CreativesContainer/tests/useLocalTemplatesProp.test.js +125 -0
  101. package/v2Containers/Rcs/constants.js +32 -1
  102. package/v2Containers/Rcs/index.js +950 -873
  103. package/v2Containers/Rcs/index.scss +85 -6
  104. package/v2Containers/Rcs/messages.js +10 -1
  105. package/v2Containers/Rcs/rcsLibraryHydrationUtils.js +205 -0
  106. package/v2Containers/Rcs/tests/__snapshots__/index.test.js.snap +40834 -1963
  107. package/v2Containers/Rcs/tests/__snapshots__/utils.test.js.snap +0 -5
  108. package/v2Containers/Rcs/tests/index.test.js +41 -38
  109. package/v2Containers/Rcs/tests/mockData.js +38 -0
  110. package/v2Containers/Rcs/tests/rcsLibraryHydrationUtils.test.js +251 -0
  111. package/v2Containers/Rcs/tests/utils.test.js +379 -1
  112. package/v2Containers/Rcs/utils.js +358 -10
  113. package/v2Containers/Sms/Create/index.js +81 -36
  114. package/v2Containers/Sms/smsFormDataHelpers.js +67 -0
  115. package/v2Containers/Sms/tests/smsFormDataHelpers.test.js +253 -0
  116. package/v2Containers/SmsTrai/Create/index.js +9 -4
  117. package/v2Containers/SmsTrai/Edit/constants.js +2 -0
  118. package/v2Containers/SmsTrai/Edit/index.js +609 -128
  119. package/v2Containers/SmsTrai/Edit/index.scss +121 -0
  120. package/v2Containers/SmsTrai/Edit/messages.js +9 -4
  121. package/v2Containers/SmsTrai/Edit/tests/__snapshots__/index.test.js.snap +4327 -2374
  122. package/v2Containers/SmsWrapper/index.js +37 -8
  123. package/v2Containers/TagList/index.js +6 -0
  124. package/v2Containers/Templates/TemplatesActionBar.js +101 -0
  125. package/v2Containers/Templates/_templates.scss +61 -2
  126. package/v2Containers/Templates/actions.js +11 -0
  127. package/v2Containers/Templates/constants.js +2 -0
  128. package/v2Containers/Templates/index.js +90 -40
  129. package/v2Containers/Templates/sagas.js +57 -12
  130. package/v2Containers/Templates/tests/TemplatesActionBar.test.js +120 -0
  131. package/v2Containers/Templates/tests/__snapshots__/index.test.js.snap +1043 -1079
  132. package/v2Containers/Templates/tests/sagas.test.js +193 -12
  133. package/v2Containers/Templates/tests/smsTemplatesListApi.test.js +180 -0
  134. package/v2Containers/Templates/utils/smsTemplatesListApi.js +79 -0
  135. package/v2Containers/TemplatesV2/TemplatesV2.style.js +72 -1
  136. package/v2Containers/TemplatesV2/index.js +86 -23
  137. package/v2Containers/TemplatesV2/tests/TemplatesV2.localTemplates.test.js +131 -0
  138. package/v2Containers/Whatsapp/index.js +3 -20
  139. package/v2Containers/Whatsapp/tests/__snapshots__/index.test.js.snap +578 -34
@@ -0,0 +1,121 @@
1
+ @import '~@capillarytech/cap-ui-library/styles/_variables';
2
+
3
+ .sms-trai-segmented-editor {
4
+ .ant-input {
5
+ margin-bottom: 0.125rem;
6
+ }
7
+ }
8
+
9
+ /*
10
+ * DLT SMS fallback edit only: mirror RCS rich-card message box (`.cap-rcs-creatives` + default
11
+ * VarSegment `rcs-edit-template-message-input` / `rcs-edit-template-message-split`).
12
+ */
13
+ .sms-trai-edit-rcs-fallback {
14
+ width: 100%;
15
+
16
+ .rcs_text_area_wrapper {
17
+ position: relative;
18
+ width: 100%;
19
+ }
20
+
21
+ .rcs_text_area_wrapper .rcs-edit-template-message-input {
22
+ background-color: $CAP_G10;
23
+ padding: $CAP_SPACE_12 $CAP_SPACE_16;
24
+ }
25
+
26
+ .rcs_text_area_wrapper .rcs-edit-template-message-split {
27
+ margin-bottom: $CAP_SPACE_08;
28
+ overflow: hidden;
29
+ text-overflow: ellipsis;
30
+ color: $FONT_COLOR_03;
31
+ font-weight: 500;
32
+ }
33
+
34
+ .rcs_text_area_wrapper .rcs-edit-template-message-input .ant-input,
35
+ .rcs_text_area_wrapper .rcs-edit-template-message-input textarea.ant-input {
36
+ width: 100%;
37
+ box-sizing: border-box;
38
+ min-height: 2.5rem;
39
+ padding-top: $CAP_SPACE_08;
40
+ padding-bottom: $CAP_SPACE_08;
41
+ border-color: $CAP_G07;
42
+ box-shadow: none;
43
+ overflow: hidden;
44
+ }
45
+
46
+ .rcs_text_area_wrapper .rcs-edit-template-message-input .ant-input:focus,
47
+ .rcs_text_area_wrapper .rcs-edit-template-message-input .ant-input:active,
48
+ .rcs_text_area_wrapper .rcs-edit-template-message-input textarea.ant-input:focus,
49
+ .rcs_text_area_wrapper .rcs-edit-template-message-input textarea.ant-input:active {
50
+ border-color: $CAP_G07;
51
+ box-shadow: none;
52
+ outline: none;
53
+ }
54
+
55
+ /*
56
+ * DLT per-slot hint: long selector (under CapSpin + message row) for specificity without !important.
57
+ */
58
+ .rcs_text_area_wrapper .rcs-edit-template-message-input .var-segment-message-editor__var-slot {
59
+ display: flex;
60
+ flex-direction: column;
61
+ align-items: stretch;
62
+ }
63
+
64
+ .rcs_text_area_wrapper
65
+ .rcs-edit-template-message-input
66
+ .var-segment-message-editor__var-slot
67
+ span.sms-trai-rcs-fallback-var-hint {
68
+ display: block;
69
+ box-sizing: border-box;
70
+ flex-shrink: 0;
71
+ margin-top: $CAP_SPACE_04;
72
+ margin-left: auto;
73
+ margin-right: 0;
74
+ width: fit-content;
75
+ max-width: 100%;
76
+ text-align: right;
77
+ color: $FONT_COLOR_02;
78
+ font-weight: 400;
79
+ font-size: 0.75rem;
80
+ line-height: 1rem;
81
+ opacity: 0.92;
82
+ }
83
+
84
+ /* Footer “1 SMS (n characters)” — match RCS message typography, not muted gray */
85
+ .rcs-character-count,
86
+ .rcs-character-count--compact {
87
+ color: $FONT_COLOR_03;
88
+ font-weight: 500;
89
+ }
90
+ }
91
+
92
+ .rcs-character-count {
93
+ display: block;
94
+ margin-top: $CAP_SPACE_16;
95
+ margin-bottom: $CAP_SPACE_04;
96
+ text-align: right;
97
+ color: $FONT_COLOR_02;
98
+ width: 100%;
99
+ }
100
+
101
+ .rcs-character-count--compact {
102
+ font-size: 0.75rem;
103
+ line-height: 1rem;
104
+ font-weight: 400;
105
+ }
106
+
107
+ /* Non–RCS fallback: segmented editor shell + character count row (was inline styles on CapRow) */
108
+ .sms-trai-editor-segment-row {
109
+ background-color: $CAP_G10;
110
+ padding: $CAP_SPACE_16;
111
+ }
112
+
113
+ .sms-trai-length-row {
114
+ display: flex;
115
+ justify-content: flex-end;
116
+ margin-top: $CAP_SPACE_04;
117
+ }
118
+
119
+ .sms-trai-edit-bottom-spacer {
120
+ margin-bottom: 6.25rem;
121
+ }
@@ -11,10 +11,6 @@ export default defineMessages({
11
11
  id: `${prefix}.saveButtonLabel`,
12
12
  defaultMessage: 'Save',
13
13
  },
14
- cancelButtonLabel: {
15
- id: `${prefix}.cancelButtonLabel`,
16
- defaultMessage: 'Cancel',
17
- },
18
14
  traiEditTitle: {
19
15
  id: `${prefix}.traiEditTitle`,
20
16
  defaultMessage: 'Message',
@@ -35,6 +31,11 @@ export default defineMessages({
35
31
  id: `${prefix}.totalCharacters`,
36
32
  defaultMessage: '{smsCount} SMS ({number} characters)',
37
33
  },
34
+ /** Primary counter in edit UI (aligned with RCS / standard Edit SMS reference). */
35
+ charactersCountLabel: {
36
+ id: `${prefix}.charactersCountLabel`,
37
+ defaultMessage: 'Characters count {current}/{max}',
38
+ },
38
39
  smsEditNotification: {
39
40
  id: `${prefix}.smsEditNotification`,
40
41
  defaultMessage: 'Sms template updated successfully',
@@ -72,4 +73,8 @@ export default defineMessages({
72
73
  id: `${prefix}.testAndPreviewButtonLabel`,
73
74
  defaultMessage: 'Preview and Test',
74
75
  },
76
+ incompleteOrInvalidTagsError: {
77
+ id: `${prefix}.incompleteOrInvalidTagsError`,
78
+ defaultMessage: 'Incomplete or invalid tags. Please provide values for all variables (e.g. {{optout}}, {{fullname}}).',
79
+ },
75
80
  });