@sparrowengg/integrations-templates-frontend 2.1.0-notion-release.33 → 2.1.0-notion-release.35

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 (238) hide show
  1. package/dist/cjs/_virtual/index5.js +2 -2
  2. package/dist/cjs/_virtual/index8.js +2 -2
  3. package/dist/cjs/_virtual/index9.js +2 -2
  4. package/dist/cjs/commons/constants/index.js +0 -2
  5. package/dist/cjs/commons/constants/index.js.map +1 -1
  6. package/dist/cjs/contact-import/components/ContactImportHeader.js +27 -37
  7. package/dist/cjs/contact-import/components/ContactImportHeader.js.map +1 -1
  8. package/dist/cjs/contact-import/components/ContactImportModal.js +53 -54
  9. package/dist/cjs/contact-import/components/ContactImportModal.js.map +1 -1
  10. package/dist/cjs/contact-import/constants/ui-strings.js +18 -0
  11. package/dist/cjs/contact-import/constants/ui-strings.js.map +1 -0
  12. package/dist/cjs/contact-import/index.js +13 -230
  13. package/dist/cjs/contact-import/index.js.map +1 -1
  14. package/dist/cjs/contact-import/utils/validation.utils.js +18 -0
  15. package/dist/cjs/contact-import/utils/validation.utils.js.map +1 -0
  16. package/dist/cjs/dynamic-mapping/constants/ui-strings.js +52 -0
  17. package/dist/cjs/dynamic-mapping/constants/ui-strings.js.map +1 -0
  18. package/dist/cjs/dynamic-mapping/index.js +4 -3
  19. package/dist/cjs/dynamic-mapping/index.js.map +1 -1
  20. package/dist/cjs/index.js +10 -12
  21. package/dist/cjs/index.js.map +1 -1
  22. package/dist/cjs/integration-template/components/ConfigureTemplate.js +43 -31
  23. package/dist/cjs/integration-template/components/ConfigureTemplate.js.map +1 -1
  24. package/dist/cjs/integration-template/components/TemplateCard.js +2 -3
  25. package/dist/cjs/integration-template/components/TemplateCard.js.map +1 -1
  26. package/dist/cjs/integration-template/components/dashboard/DashboardItem.js +273 -0
  27. package/dist/cjs/integration-template/components/dashboard/DashboardItem.js.map +1 -0
  28. package/dist/cjs/integration-template/components/dashboard/DropdownItem.js +1 -2
  29. package/dist/cjs/integration-template/components/dashboard/DropdownItem.js.map +1 -1
  30. package/dist/cjs/integration-template/components/dashboard/EventComponent.js +1 -1
  31. package/dist/cjs/integration-template/components/dashboard/EventComponent.js.map +1 -1
  32. package/dist/cjs/integration-template/components/dashboard/MultiAccountFallback.js +4 -4
  33. package/dist/cjs/integration-template/components/dashboard/MultiAccountFallback.js.map +1 -1
  34. package/dist/cjs/integration-template/components/dashboard/SingleMappingChipWrapper.js +75 -0
  35. package/dist/cjs/integration-template/components/dashboard/SingleMappingChipWrapper.js.map +1 -0
  36. package/dist/cjs/integration-template/components/dashboard/SingleMappingDashboardItem.js +346 -0
  37. package/dist/cjs/integration-template/components/dashboard/SingleMappingDashboardItem.js.map +1 -0
  38. package/dist/cjs/integration-template/components/dashboard/SingleMappingEventWrapper.js +79 -0
  39. package/dist/cjs/integration-template/components/dashboard/SingleMappingEventWrapper.js.map +1 -0
  40. package/dist/cjs/integration-template/components/dashboard/TriggerDashboardItem.js +214 -0
  41. package/dist/cjs/integration-template/components/dashboard/TriggerDashboardItem.js.map +1 -0
  42. package/dist/cjs/integration-template/components/dashboard-constants.js +92 -0
  43. package/dist/cjs/integration-template/components/dashboard-constants.js.map +1 -0
  44. package/dist/cjs/integration-template/components/dashboard-utils.js +39 -0
  45. package/dist/cjs/integration-template/components/dashboard-utils.js.map +1 -0
  46. package/dist/cjs/integration-template/components/dashboard.js +55 -1195
  47. package/dist/cjs/integration-template/components/dashboard.js.map +1 -1
  48. package/dist/cjs/integration-template/constants/index.js +1 -41
  49. package/dist/cjs/integration-template/constants/index.js.map +1 -1
  50. package/dist/cjs/integration-template/constants/ui-strings.js +15 -0
  51. package/dist/cjs/integration-template/constants/ui-strings.js.map +1 -0
  52. package/dist/cjs/integration-template/index.js +155 -217
  53. package/dist/cjs/integration-template/index.js.map +1 -1
  54. package/dist/cjs/integration-template/utils/component.utils.js +22 -0
  55. package/dist/cjs/integration-template/utils/component.utils.js.map +1 -0
  56. package/dist/cjs/integration-template/utils/url.utils.js +16 -0
  57. package/dist/cjs/integration-template/utils/url.utils.js.map +1 -0
  58. package/dist/cjs/mapping/components/ConfigurationField.js +178 -0
  59. package/dist/cjs/mapping/components/ConfigurationField.js.map +1 -0
  60. package/dist/cjs/mapping/components/ConfigurationSetup.js +19 -16
  61. package/dist/cjs/mapping/components/ConfigurationSetup.js.map +1 -1
  62. package/dist/cjs/mapping/components/CustomAddNewSelect.js +64 -61
  63. package/dist/cjs/mapping/components/CustomAddNewSelect.js.map +1 -1
  64. package/dist/cjs/mapping/components/EventSetup.js +25 -22
  65. package/dist/cjs/mapping/components/EventSetup.js.map +1 -1
  66. package/dist/cjs/mapping/components/MappingHeader.js +24 -24
  67. package/dist/cjs/mapping/components/MappingHeader.js.map +1 -1
  68. package/dist/cjs/mapping/constants/index.js.map +1 -1
  69. package/dist/cjs/mapping/constants/ui-strings.js +39 -0
  70. package/dist/cjs/mapping/constants/ui-strings.js.map +1 -0
  71. package/dist/cjs/mapping/index.js +7 -612
  72. package/dist/cjs/mapping/index.js.map +1 -1
  73. package/dist/cjs/mapping/utils/validation.utils.js +32 -0
  74. package/dist/cjs/mapping/utils/validation.utils.js.map +1 -0
  75. package/dist/cjs/node_modules/domelementtype/lib/index.js +1 -1
  76. package/dist/cjs/node_modules/hoist-non-react-statics/node_modules/react-is/index.js +1 -1
  77. package/dist/cjs/node_modules/html-dom-parser/lib/server/html-to-dom.js +2 -2
  78. package/dist/cjs/node_modules/html-dom-parser/node_modules/dom-serializer/lib/index.js +1 -1
  79. package/dist/cjs/node_modules/html-dom-parser/node_modules/domhandler/lib/index.js +2 -2
  80. package/dist/cjs/node_modules/html-dom-parser/node_modules/domhandler/lib/node.js +1 -1
  81. package/dist/cjs/node_modules/html-dom-parser/node_modules/domutils/lib/helpers.js +1 -1
  82. package/dist/cjs/node_modules/html-dom-parser/node_modules/domutils/lib/index.js +1 -1
  83. package/dist/cjs/node_modules/html-dom-parser/node_modules/domutils/lib/legacy.js +1 -1
  84. package/dist/cjs/node_modules/html-dom-parser/node_modules/domutils/lib/querying.js +1 -1
  85. package/dist/cjs/node_modules/html-dom-parser/node_modules/domutils/lib/stringify.js +2 -2
  86. package/dist/cjs/node_modules/html-dom-parser/node_modules/domutils/lib/traversal.js +1 -1
  87. package/dist/cjs/node_modules/html-dom-parser/node_modules/htmlparser2/lib/index.js +3 -3
  88. package/dist/cjs/node_modules/html-react-parser/node_modules/domhandler/lib/index.js +1 -1
  89. package/dist/cjs/node_modules/html-react-parser/node_modules/domhandler/lib/node.js +1 -1
  90. package/dist/cjs/node_modules/style-to-js/cjs/index.js +1 -1
  91. package/dist/cjs/node_modules/style-to-object/cjs/index.js +1 -1
  92. package/dist/cjs/single-mapping/components/ConfigurationField.js +243 -0
  93. package/dist/cjs/single-mapping/components/ConfigurationField.js.map +1 -0
  94. package/dist/cjs/single-mapping/components/ConfigurationSetup.js +14 -13
  95. package/dist/cjs/single-mapping/components/ConfigurationSetup.js.map +1 -1
  96. package/dist/cjs/single-mapping/components/CustomDropdown.js +157 -228
  97. package/dist/cjs/single-mapping/components/CustomDropdown.js.map +1 -1
  98. package/dist/cjs/single-mapping/components/MappingHeader.js +67 -48
  99. package/dist/cjs/single-mapping/components/MappingHeader.js.map +1 -1
  100. package/dist/cjs/single-mapping/hooks/useEditState.js +58 -0
  101. package/dist/cjs/single-mapping/hooks/useEditState.js.map +1 -0
  102. package/dist/cjs/single-mapping/index.js +32 -940
  103. package/dist/cjs/single-mapping/index.js.map +1 -1
  104. package/dist/cjs/single-mapping/utils/validation.utils.js +36 -30
  105. package/dist/cjs/single-mapping/utils/validation.utils.js.map +1 -1
  106. package/dist/cjs/triggers/components/EventSetup.js +64 -58
  107. package/dist/cjs/triggers/components/EventSetup.js.map +1 -1
  108. package/dist/cjs/triggers/components/TriggerHeader.js +26 -30
  109. package/dist/cjs/triggers/components/TriggerHeader.js.map +1 -1
  110. package/dist/cjs/triggers/components/subcomponents.js +3 -3
  111. package/dist/cjs/triggers/components/subcomponents.js.map +1 -1
  112. package/dist/cjs/triggers/constants/index.js.map +1 -1
  113. package/dist/cjs/triggers/constants/ui-strings.js +28 -0
  114. package/dist/cjs/triggers/constants/ui-strings.js.map +1 -0
  115. package/dist/cjs/triggers/index.js +6 -252
  116. package/dist/cjs/triggers/index.js.map +1 -1
  117. package/dist/cjs/triggers/utils/validation.utils.js +36 -0
  118. package/dist/cjs/triggers/utils/validation.utils.js.map +1 -0
  119. package/dist/es/_virtual/index5.js +2 -2
  120. package/dist/es/_virtual/index8.js +2 -2
  121. package/dist/es/_virtual/index9.js +2 -2
  122. package/dist/es/commons/constants/index.js +1 -2
  123. package/dist/es/commons/constants/index.js.map +1 -1
  124. package/dist/es/contact-import/components/ContactImportHeader.js +30 -38
  125. package/dist/es/contact-import/components/ContactImportHeader.js.map +1 -1
  126. package/dist/es/contact-import/components/ContactImportModal.js +51 -50
  127. package/dist/es/contact-import/components/ContactImportModal.js.map +1 -1
  128. package/dist/es/contact-import/constants/ui-strings.js +16 -0
  129. package/dist/es/contact-import/constants/ui-strings.js.map +1 -0
  130. package/dist/es/contact-import/index.js +12 -229
  131. package/dist/es/contact-import/index.js.map +1 -1
  132. package/dist/es/contact-import/utils/validation.utils.js +15 -0
  133. package/dist/es/contact-import/utils/validation.utils.js.map +1 -0
  134. package/dist/es/dynamic-mapping/constants/ui-strings.js +50 -0
  135. package/dist/es/dynamic-mapping/constants/ui-strings.js.map +1 -0
  136. package/dist/es/dynamic-mapping/index.js +4 -3
  137. package/dist/es/dynamic-mapping/index.js.map +1 -1
  138. package/dist/es/index.js +0 -1
  139. package/dist/es/index.js.map +1 -1
  140. package/dist/es/integration-template/components/ConfigureTemplate.js +43 -31
  141. package/dist/es/integration-template/components/ConfigureTemplate.js.map +1 -1
  142. package/dist/es/integration-template/components/TemplateCard.js +2 -3
  143. package/dist/es/integration-template/components/TemplateCard.js.map +1 -1
  144. package/dist/es/integration-template/components/dashboard/DashboardItem.js +271 -0
  145. package/dist/es/integration-template/components/dashboard/DashboardItem.js.map +1 -0
  146. package/dist/es/integration-template/components/dashboard/DropdownItem.js +1 -2
  147. package/dist/es/integration-template/components/dashboard/DropdownItem.js.map +1 -1
  148. package/dist/es/integration-template/components/dashboard/EventComponent.js +1 -1
  149. package/dist/es/integration-template/components/dashboard/EventComponent.js.map +1 -1
  150. package/dist/es/integration-template/components/dashboard/MultiAccountFallback.js +4 -4
  151. package/dist/es/integration-template/components/dashboard/MultiAccountFallback.js.map +1 -1
  152. package/dist/es/integration-template/components/dashboard/SingleMappingChipWrapper.js +73 -0
  153. package/dist/es/integration-template/components/dashboard/SingleMappingChipWrapper.js.map +1 -0
  154. package/dist/es/integration-template/components/dashboard/SingleMappingDashboardItem.js +344 -0
  155. package/dist/es/integration-template/components/dashboard/SingleMappingDashboardItem.js.map +1 -0
  156. package/dist/es/integration-template/components/dashboard/SingleMappingEventWrapper.js +77 -0
  157. package/dist/es/integration-template/components/dashboard/SingleMappingEventWrapper.js.map +1 -0
  158. package/dist/es/integration-template/components/dashboard/TriggerDashboardItem.js +212 -0
  159. package/dist/es/integration-template/components/dashboard/TriggerDashboardItem.js.map +1 -0
  160. package/dist/es/integration-template/components/dashboard-constants.js +88 -0
  161. package/dist/es/integration-template/components/dashboard-constants.js.map +1 -0
  162. package/dist/es/integration-template/components/dashboard-utils.js +36 -0
  163. package/dist/es/integration-template/components/dashboard-utils.js.map +1 -0
  164. package/dist/es/integration-template/components/dashboard.js +43 -1183
  165. package/dist/es/integration-template/components/dashboard.js.map +1 -1
  166. package/dist/es/integration-template/constants/index.js +2 -36
  167. package/dist/es/integration-template/constants/index.js.map +1 -1
  168. package/dist/es/integration-template/constants/ui-strings.js +13 -0
  169. package/dist/es/integration-template/constants/ui-strings.js.map +1 -0
  170. package/dist/es/integration-template/index.js +154 -216
  171. package/dist/es/integration-template/index.js.map +1 -1
  172. package/dist/es/integration-template/utils/component.utils.js +18 -0
  173. package/dist/es/integration-template/utils/component.utils.js.map +1 -0
  174. package/dist/es/integration-template/utils/url.utils.js +13 -0
  175. package/dist/es/integration-template/utils/url.utils.js.map +1 -0
  176. package/dist/es/mapping/components/ConfigurationField.js +174 -0
  177. package/dist/es/mapping/components/ConfigurationField.js.map +1 -0
  178. package/dist/es/mapping/components/ConfigurationSetup.js +17 -16
  179. package/dist/es/mapping/components/ConfigurationSetup.js.map +1 -1
  180. package/dist/es/mapping/components/CustomAddNewSelect.js +62 -61
  181. package/dist/es/mapping/components/CustomAddNewSelect.js.map +1 -1
  182. package/dist/es/mapping/components/EventSetup.js +23 -22
  183. package/dist/es/mapping/components/EventSetup.js.map +1 -1
  184. package/dist/es/mapping/components/MappingHeader.js +23 -25
  185. package/dist/es/mapping/components/MappingHeader.js.map +1 -1
  186. package/dist/es/mapping/constants/index.js.map +1 -1
  187. package/dist/es/mapping/constants/ui-strings.js +37 -0
  188. package/dist/es/mapping/constants/ui-strings.js.map +1 -0
  189. package/dist/es/mapping/index.js +5 -610
  190. package/dist/es/mapping/index.js.map +1 -1
  191. package/dist/es/mapping/utils/validation.utils.js +28 -0
  192. package/dist/es/mapping/utils/validation.utils.js.map +1 -0
  193. package/dist/es/node_modules/domelementtype/lib/index.js +1 -1
  194. package/dist/es/node_modules/hoist-non-react-statics/node_modules/react-is/index.js +1 -1
  195. package/dist/es/node_modules/html-dom-parser/lib/server/html-to-dom.js +2 -2
  196. package/dist/es/node_modules/html-dom-parser/node_modules/dom-serializer/lib/index.js +1 -1
  197. package/dist/es/node_modules/html-dom-parser/node_modules/domhandler/lib/index.js +2 -2
  198. package/dist/es/node_modules/html-dom-parser/node_modules/domhandler/lib/node.js +1 -1
  199. package/dist/es/node_modules/html-dom-parser/node_modules/domutils/lib/helpers.js +1 -1
  200. package/dist/es/node_modules/html-dom-parser/node_modules/domutils/lib/index.js +1 -1
  201. package/dist/es/node_modules/html-dom-parser/node_modules/domutils/lib/legacy.js +1 -1
  202. package/dist/es/node_modules/html-dom-parser/node_modules/domutils/lib/querying.js +1 -1
  203. package/dist/es/node_modules/html-dom-parser/node_modules/domutils/lib/stringify.js +2 -2
  204. package/dist/es/node_modules/html-dom-parser/node_modules/domutils/lib/traversal.js +1 -1
  205. package/dist/es/node_modules/html-dom-parser/node_modules/htmlparser2/lib/index.js +3 -3
  206. package/dist/es/node_modules/html-react-parser/node_modules/domhandler/lib/index.js +1 -1
  207. package/dist/es/node_modules/html-react-parser/node_modules/domhandler/lib/node.js +1 -1
  208. package/dist/es/node_modules/style-to-js/cjs/index.js +1 -1
  209. package/dist/es/node_modules/style-to-object/cjs/index.js +1 -1
  210. package/dist/es/single-mapping/components/ConfigurationField.js +241 -0
  211. package/dist/es/single-mapping/components/ConfigurationField.js.map +1 -0
  212. package/dist/es/single-mapping/components/ConfigurationSetup.js +14 -13
  213. package/dist/es/single-mapping/components/ConfigurationSetup.js.map +1 -1
  214. package/dist/es/single-mapping/components/CustomDropdown.js +156 -227
  215. package/dist/es/single-mapping/components/CustomDropdown.js.map +1 -1
  216. package/dist/es/single-mapping/components/MappingHeader.js +68 -49
  217. package/dist/es/single-mapping/components/MappingHeader.js.map +1 -1
  218. package/dist/es/single-mapping/hooks/useEditState.js +56 -0
  219. package/dist/es/single-mapping/hooks/useEditState.js.map +1 -0
  220. package/dist/es/single-mapping/index.js +30 -941
  221. package/dist/es/single-mapping/index.js.map +1 -1
  222. package/dist/es/single-mapping/utils/validation.utils.js +31 -27
  223. package/dist/es/single-mapping/utils/validation.utils.js.map +1 -1
  224. package/dist/es/triggers/components/EventSetup.js +62 -58
  225. package/dist/es/triggers/components/EventSetup.js.map +1 -1
  226. package/dist/es/triggers/components/TriggerHeader.js +26 -32
  227. package/dist/es/triggers/components/TriggerHeader.js.map +1 -1
  228. package/dist/es/triggers/components/subcomponents.js +3 -3
  229. package/dist/es/triggers/components/subcomponents.js.map +1 -1
  230. package/dist/es/triggers/constants/index.js.map +1 -1
  231. package/dist/es/triggers/constants/ui-strings.js +26 -0
  232. package/dist/es/triggers/constants/ui-strings.js.map +1 -0
  233. package/dist/es/triggers/index.js +5 -251
  234. package/dist/es/triggers/index.js.map +1 -1
  235. package/dist/es/triggers/utils/validation.utils.js +30 -0
  236. package/dist/es/triggers/utils/validation.utils.js.map +1 -0
  237. package/dist/index.d.ts +216 -143
  238. package/package.json +1 -1
@@ -1,10 +1,9 @@
1
1
  'use strict';
2
2
 
3
3
  var React = require('react');
4
- var editConfirmation = require('../../commons/components/edit-confirmation.js');
5
4
  var arrow = require('../../commons/icons/arrow.js');
6
- var useMappingHeaderLogic = require('../hooks/useMappingHeaderLogic.js');
7
- var index = require('../constants/index.js');
5
+ var editConfirmation = require('../../commons/components/edit-confirmation.js');
6
+ var validation_utils = require('../utils/validation.utils.js');
8
7
  var flex = require('../../node_modules/@sparrowengg/twigs-react/dist/es/flex/flex.js');
9
8
  var iconButton = require('../../node_modules/@sparrowengg/twigs-react/dist/es/button/icon-button.js');
10
9
  var arrowLeft = require('../../node_modules/@sparrowengg/twigs-react-icons/dist/es/icons/arrow-left.js');
@@ -26,24 +25,68 @@ const MappingHeader = ({
26
25
  saveConfiguration,
27
26
  setIsEditConfirmationOpen
28
27
  }) => {
29
- const { isButtonDisabled, isMappingPageDisabled } = useMappingHeaderLogic.useMappingHeaderLogic({
30
- ssMappingData,
31
- configuration,
32
- hasFieldsChanged,
33
- editField,
34
- importResponse,
35
- isMappingPage
36
- });
28
+ const isButtonDisabled = () => {
29
+ if (isMappingPage) {
30
+ return isMappingPageButtonDisabled();
31
+ }
32
+ return isConfigurationPageButtonDisabled();
33
+ };
34
+ const isMappingPageButtonDisabled = () => {
35
+ var _a;
36
+ if (editField == null ? void 0 : editField.id) {
37
+ return !hasFieldsChanged;
38
+ }
39
+ if (((_a = importResponse == null ? void 0 : importResponse.value) == null ? void 0 : _a.importMethod) === "SEND_ALL_DATA") {
40
+ return !validation_utils.hasMappingDataLength(ssMappingData);
41
+ }
42
+ return !validation_utils.hasMappingDataEnabled(ssMappingData);
43
+ };
44
+ const isConfigurationPageButtonDisabled = () => {
45
+ const allFieldsFilled = validation_utils.areAllConfigFieldsFilled(configuration.configurationFields);
46
+ const importSettingsValid = validation_utils.isResponseImportSettingsValid(
47
+ configuration.configurationFields,
48
+ configuration.configuredFields
49
+ );
50
+ return !allFieldsFilled || !importSettingsValid;
51
+ };
52
+ const isMappingNavigationDisabled = () => {
53
+ const allFieldsFilled = validation_utils.areAllConfigFieldsFilled(configuration.configurationFields);
54
+ const importSettingsValid = validation_utils.isResponseImportSettingsValid(
55
+ configuration.configurationFields,
56
+ configuration.configuredFields
57
+ );
58
+ return !allFieldsFilled || !importSettingsValid;
59
+ };
60
+ const handleSaveClick = () => {
61
+ if (isMappingPage) {
62
+ if (editField == null ? void 0 : editField.id) {
63
+ setIsEditConfirmationOpen(true);
64
+ } else {
65
+ onSaveHandler({});
66
+ }
67
+ } else {
68
+ saveConfiguration();
69
+ }
70
+ };
71
+ const handleMappingNavigation = () => {
72
+ if (isMappingPage) {
73
+ onSaveHandler({});
74
+ } else {
75
+ saveConfiguration();
76
+ }
77
+ };
78
+ const getButtonText = () => {
79
+ if (isMappingPage) {
80
+ return (editField == null ? void 0 : editField.id) ? "Update Mapping" : "Save Mapping";
81
+ }
82
+ return "Continue, Mapping";
83
+ };
37
84
  return /* @__PURE__ */ React.createElement(
38
85
  flex.Flex,
39
86
  {
40
87
  alignItems: "center",
41
88
  justifyContent: "space-between",
42
89
  css: {
43
- position: "sticky",
44
- top: 0,
45
- zIndex: 100,
46
- background: "#ffff",
47
90
  borderBottom: "$borderWidths$xs solid $neutral200",
48
91
  padding: "$8 $12"
49
92
  }
@@ -64,7 +107,7 @@ const MappingHeader = ({
64
107
  size: "lg"
65
108
  }
66
109
  ),
67
- /* @__PURE__ */ React.createElement(heading.Heading, { size: "h6" }, (editField == null ? void 0 : editField.id) ? index.UI_LABELS.EDIT_MAPPING : index.UI_LABELS.NEW_MAPPING)
110
+ /* @__PURE__ */ React.createElement(heading.Heading, { size: "h6" }, (editField == null ? void 0 : editField.id) ? "Edit Mapping" : "New Mapping")
68
111
  ),
69
112
  /* @__PURE__ */ React.createElement(
70
113
  flex.Flex,
@@ -84,55 +127,31 @@ const MappingHeader = ({
84
127
  size: "md",
85
128
  onClick: () => isMappingPage && navigateConfigPage()
86
129
  },
87
- index.UI_LABELS.CONFIGURATION
130
+ "Configuration"
88
131
  ),
89
132
  /* @__PURE__ */ React.createElement(arrow.default, null),
90
133
  /* @__PURE__ */ React.createElement(
91
134
  button.Button,
92
135
  {
93
- disabled: isMappingPageDisabled(),
136
+ disabled: isMappingNavigationDisabled(),
94
137
  css: {
95
138
  color: isMappingPage ? "$neutral900" : "$neutral800",
96
- cursor: isMappingPageDisabled() ? "not-allowed" : "pointer"
139
+ cursor: isMappingNavigationDisabled() ? "not-allowed" : "pointer"
97
140
  },
98
141
  color: "default",
99
142
  variant: "ghost",
100
- onClick: () => {
101
- if (isMappingPage) {
102
- onSaveHandler({});
103
- } else {
104
- saveConfiguration();
105
- }
106
- },
143
+ onClick: handleMappingNavigation,
107
144
  size: "md"
108
145
  },
109
- index.UI_LABELS.MAPPING
146
+ "Mapping"
110
147
  )
111
148
  ),
112
- /* @__PURE__ */ React.createElement(flex.Flex, { justifyContent: "end", css: { width: "180px" } }, /* @__PURE__ */ React.createElement(
113
- button.Button,
114
- {
115
- size: "lg",
116
- disabled: isButtonDisabled(),
117
- onClick: () => {
118
- if (isMappingPage) {
119
- if (editField == null ? void 0 : editField.id) {
120
- setIsEditConfirmationOpen(true);
121
- } else {
122
- onSaveHandler({});
123
- }
124
- } else {
125
- saveConfiguration();
126
- }
127
- }
128
- },
129
- isMappingPage ? (editField == null ? void 0 : editField.id) ? index.UI_LABELS.UPDATE_MAPPING : index.UI_LABELS.SAVE_MAPPING : index.UI_LABELS.CONTINUE_MAPPING
130
- )),
149
+ /* @__PURE__ */ React.createElement(flex.Flex, { justifyContent: "end", css: { width: "180px" } }, /* @__PURE__ */ React.createElement(button.Button, { size: "lg", disabled: isButtonDisabled(), onClick: handleSaveClick }, getButtonText())),
131
150
  isEditConfirmationOpen && /* @__PURE__ */ React.createElement(
132
151
  editConfirmation.default,
133
152
  {
134
- name: index.UI_MESSAGES.EDIT_CONFIRMATION_TITLE,
135
- description: index.UI_MESSAGES.EDIT_CONFIRMATION_DESCRIPTION,
153
+ name: "Are you sure?",
154
+ description: "Saving this updated mapping properties will generate new sheet with the revised mapping.",
136
155
  onConfirm: async () => {
137
156
  await onSaveHandler({});
138
157
  setIsEditConfirmationOpen(false);
@@ -1 +1 @@
1
- {"version":3,"file":"MappingHeader.js","sources":["../../../../src/single-mapping/components/MappingHeader.tsx"],"sourcesContent":["import React from \"react\";\nimport {\n Flex,\n IconButton,\n Heading,\n Button,\n} from \"@sparrowengg/twigs-react\";\nimport { ArrowLeftIcon } from \"@sparrowengg/twigs-react-icons\";\nimport { MappingHeaderProps } from \"../types/mapping.types\";\nimport EditConfirmation from \"../../commons/components/edit-confirmation\";\nimport Arrow from \"../../commons/icons/arrow\";\nimport { useMappingHeaderLogic } from \"../hooks/useMappingHeaderLogic\";\nimport { UI_LABELS, UI_MESSAGES } from \"../constants\";\n\nexport const MappingHeader: React.FC<MappingHeaderProps> = ({\n ssMappingData,\n configuration,\n hasFieldsChanged,\n isEditConfirmationOpen,\n editField,\n importResponse,\n hasExistingMapping,\n isMappingPage,\n navigateConfigPage,\n onSaveHandler,\n previousMappingHandler,\n saveConfiguration,\n setIsEditConfirmationOpen,\n}) => {\n const { isButtonDisabled, isMappingPageDisabled } = useMappingHeaderLogic({\n ssMappingData,\n configuration,\n hasFieldsChanged,\n editField,\n importResponse,\n isMappingPage,\n });\n\n return (\n <Flex\n alignItems=\"center\"\n justifyContent=\"space-between\"\n css={{\n position: \"sticky\",\n top: 0,\n zIndex: 100,\n background: \"#ffff\",\n borderBottom: \"$borderWidths$xs solid $neutral200\",\n padding: \"$8 $12\",\n }}\n >\n <Flex\n gap=\"$6\"\n alignItems=\"center\"\n css={{ visibility: hasExistingMapping ? \"visible\" : \"hidden\" }}\n >\n <IconButton\n onClick={() => previousMappingHandler?.()}\n color=\"default\"\n icon={<ArrowLeftIcon />}\n size=\"lg\"\n />\n <Heading size=\"h6\">\n {editField?.id ? UI_LABELS.EDIT_MAPPING : UI_LABELS.NEW_MAPPING}\n </Heading>\n </Flex>\n\n <Flex\n alignItems=\"center\"\n gap=\"$4\"\n css={{\n \"& button\": { background: \"transparent !important\", fontSize: \"$md\" },\n }}\n >\n <Button\n css={{ color: !isMappingPage ? \"$neutral900\" : \"$neutral800\" }}\n color=\"default\"\n variant=\"ghost\"\n size=\"md\"\n onClick={() => isMappingPage && navigateConfigPage()}\n >\n {UI_LABELS.CONFIGURATION}\n </Button>\n <Arrow />\n <Button\n disabled={isMappingPageDisabled()}\n css={{\n color: isMappingPage ? \"$neutral900\" : \"$neutral800\",\n cursor: isMappingPageDisabled() ? \"not-allowed\" : \"pointer\",\n }}\n color=\"default\"\n variant=\"ghost\"\n onClick={() => {\n if (isMappingPage) {\n onSaveHandler({});\n } else {\n saveConfiguration();\n }\n }}\n size=\"md\"\n >\n {UI_LABELS.MAPPING}\n </Button>\n </Flex>\n\n <Flex justifyContent=\"end\" css={{ width: \"180px\" }}>\n <Button\n size=\"lg\"\n disabled={isButtonDisabled()}\n onClick={() => {\n if (isMappingPage) {\n if (editField?.id) {\n setIsEditConfirmationOpen(true);\n } else {\n onSaveHandler({});\n }\n } else {\n saveConfiguration();\n }\n }}\n >\n {isMappingPage\n ? editField?.id\n ? UI_LABELS.UPDATE_MAPPING\n : UI_LABELS.SAVE_MAPPING\n : UI_LABELS.CONTINUE_MAPPING}\n </Button>\n </Flex>\n\n {isEditConfirmationOpen && (\n <EditConfirmation\n name={UI_MESSAGES.EDIT_CONFIRMATION_TITLE}\n description={UI_MESSAGES.EDIT_CONFIRMATION_DESCRIPTION}\n onConfirm={async () => {\n await onSaveHandler({});\n setIsEditConfirmationOpen(false);\n }}\n onCancel={() => {\n setIsEditConfirmationOpen(false);\n }}\n />\n )}\n </Flex>\n );\n};\n\n"],"names":["useMappingHeaderLogic","Flex","IconButton","ArrowLeftIcon","Heading","UI_LABELS","Button","Arrow","EditConfirmation","UI_MESSAGES"],"mappings":"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"}
1
+ {"version":3,"file":"MappingHeader.js","sources":["../../../../src/single-mapping/components/MappingHeader.tsx"],"sourcesContent":["import React, { useState } from \"react\";\nimport { Box, Button, Flex, Heading, IconButton } from \"@sparrowengg/twigs-react\";\nimport { ArrowLeftIcon, ChevronRightIcon } from \"@sparrowengg/twigs-react-icons\";\nimport Arrow from \"../../commons/icons/arrow\";\nimport EditConfirmation from \"../../commons/components/edit-confirmation\";\nimport { MappingData } from \"../../commons/types/enhanced\";\nimport { ConfigurationType } from \"../types/configuration.types\";\nimport {\n hasMappingDataEnabled,\n hasMappingDataLength,\n areAllConfigFieldsFilled,\n isResponseImportSettingsValid,\n} from \"../utils/validation.utils\";\n\ntype MappingHeaderProps = {\n ssMappingData: MappingData;\n configuration: ConfigurationType;\n hasFieldsChanged: boolean;\n isEditConfirmationOpen: boolean;\n editField?: any;\n importResponse: any;\n hasExistingMapping: boolean;\n isMappingPage: boolean;\n navigateConfigPage: (value?: boolean) => void;\n onSaveHandler: (fields: any) => void;\n previousMappingHandler?: (value?: boolean) => void;\n saveConfiguration: () => void;\n setIsEditConfirmationOpen: (value: boolean) => void;\n};\n\n/**\n * Header component for the single mapping interface\n * Handles navigation between configuration and mapping pages\n */\nexport const MappingHeader: React.FC<MappingHeaderProps> = ({\n ssMappingData,\n configuration,\n hasFieldsChanged,\n isEditConfirmationOpen,\n editField,\n importResponse,\n hasExistingMapping,\n isMappingPage,\n navigateConfigPage,\n onSaveHandler,\n previousMappingHandler,\n saveConfiguration,\n setIsEditConfirmationOpen,\n}) => {\n const isButtonDisabled = (): boolean => {\n if (isMappingPage) {\n return isMappingPageButtonDisabled();\n }\n return isConfigurationPageButtonDisabled();\n };\n\n const isMappingPageButtonDisabled = (): boolean => {\n // In edit mode, check if any fields have changed\n if (editField?.id) {\n return !hasFieldsChanged;\n }\n\n // Check import method\n if ((importResponse?.value as any)?.importMethod === \"SEND_ALL_DATA\") {\n return !hasMappingDataLength(ssMappingData);\n }\n\n return !hasMappingDataEnabled(ssMappingData);\n };\n\n const isConfigurationPageButtonDisabled = (): boolean => {\n const allFieldsFilled = areAllConfigFieldsFilled(configuration.configurationFields);\n const importSettingsValid = isResponseImportSettingsValid(\n configuration.configurationFields,\n configuration.configuredFields\n );\n\n return !allFieldsFilled || !importSettingsValid;\n };\n\n const isMappingNavigationDisabled = (): boolean => {\n const allFieldsFilled = areAllConfigFieldsFilled(configuration.configurationFields);\n const importSettingsValid = isResponseImportSettingsValid(\n configuration.configurationFields,\n configuration.configuredFields\n );\n\n return !allFieldsFilled || !importSettingsValid;\n };\n\n const handleSaveClick = () => {\n if (isMappingPage) {\n if (editField?.id) {\n setIsEditConfirmationOpen(true);\n } else {\n onSaveHandler({});\n }\n } else {\n saveConfiguration();\n }\n };\n\n const handleMappingNavigation = () => {\n if (isMappingPage) {\n onSaveHandler({});\n } else {\n saveConfiguration();\n }\n };\n\n const getButtonText = (): string => {\n if (isMappingPage) {\n return editField?.id ? \"Update Mapping\" : \"Save Mapping\";\n }\n return \"Continue, Mapping\";\n };\n\n return (\n <Flex\n alignItems=\"center\"\n justifyContent=\"space-between\"\n css={{\n borderBottom: \"$borderWidths$xs solid $neutral200\",\n padding: \"$8 $12\",\n }}\n >\n {/* Back Button and Title */}\n <Flex\n gap=\"$6\"\n alignItems=\"center\"\n css={{ visibility: hasExistingMapping ? \"visible\" : \"hidden\" }}\n >\n <IconButton\n onClick={() => previousMappingHandler?.()}\n color=\"default\"\n icon={<ArrowLeftIcon />}\n size=\"lg\"\n />\n <Heading size=\"h6\">\n {editField?.id ? \"Edit Mapping\" : \"New Mapping\"}\n </Heading>\n </Flex>\n\n {/* Navigation Buttons */}\n <Flex\n alignItems=\"center\"\n gap=\"$4\"\n css={{\n \"& button\": { background: \"transparent !important\", fontSize: \"$md\" },\n }}\n >\n <Button\n css={{ color: !isMappingPage ? \"$neutral900\" : \"$neutral800\" }}\n color=\"default\"\n variant=\"ghost\"\n size=\"md\"\n onClick={() => isMappingPage && navigateConfigPage()}\n >\n Configuration\n </Button>\n <Arrow />\n <Button\n disabled={isMappingNavigationDisabled()}\n css={{\n color: isMappingPage ? \"$neutral900\" : \"$neutral800\",\n cursor: isMappingNavigationDisabled() ? \"not-allowed\" : \"pointer\",\n }}\n color=\"default\"\n variant=\"ghost\"\n onClick={handleMappingNavigation}\n size=\"md\"\n >\n Mapping\n </Button>\n </Flex>\n\n {/* Save Button */}\n <Flex justifyContent=\"end\" css={{ width: \"180px\" }}>\n <Button size=\"lg\" disabled={isButtonDisabled()} onClick={handleSaveClick}>\n {getButtonText()}\n </Button>\n </Flex>\n\n {/* Edit Confirmation Modal */}\n {isEditConfirmationOpen && (\n <EditConfirmation\n name=\"Are you sure?\"\n description=\"Saving this updated mapping properties will generate new sheet with the revised mapping.\"\n onConfirm={async () => {\n await onSaveHandler({});\n setIsEditConfirmationOpen(false);\n }}\n onCancel={() => {\n setIsEditConfirmationOpen(false);\n }}\n />\n )}\n </Flex>\n );\n};\n\n"],"names":["hasMappingDataLength","hasMappingDataEnabled","areAllConfigFieldsFilled","isResponseImportSettingsValid","Flex","IconButton","ArrowLeftIcon","Heading","Button","Arrow","EditConfirmation"],"mappings":"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"}
@@ -0,0 +1,58 @@
1
+ 'use strict';
2
+
3
+ var React = require('react');
4
+ var validation_utils = require('../utils/validation.utils.js');
5
+
6
+ const useEditState = ({
7
+ editField,
8
+ configuration,
9
+ importResponse,
10
+ navigateMappingPage
11
+ }) => {
12
+ const [originalMappingData, setOriginalMappingData] = React.useState(null);
13
+ const [originalConfigurationFields, setOriginalConfigurationFields] = React.useState(null);
14
+ const [originalConfiguredFields, setOriginalConfiguredFields] = React.useState(null);
15
+ const [originalImportResponse, setOriginalImportResponse] = React.useState(null);
16
+ const [isInitialLoad, setIsInitialLoad] = React.useState(true);
17
+ React.useEffect(() => {
18
+ if (editField == null ? void 0 : editField.id) {
19
+ navigateMappingPage(true);
20
+ setOriginalConfigurationFields(validation_utils.deepClone(configuration.configurationFields));
21
+ setOriginalConfiguredFields(validation_utils.deepClone(configuration.configuredFields));
22
+ setOriginalImportResponse(validation_utils.deepClone(importResponse));
23
+ }
24
+ }, []);
25
+ const hasFieldsChanged = () => {
26
+ if (!(editField == null ? void 0 : editField.id) || !originalMappingData) {
27
+ return true;
28
+ }
29
+ const mappingDataChanged = !validation_utils.areObjectsEqual(
30
+ originalMappingData,
31
+ originalMappingData
32
+ // This will be compared with current state in the component
33
+ );
34
+ const importResponseChanged = !validation_utils.areObjectsEqual(
35
+ validation_utils.deepClone(importResponse),
36
+ originalImportResponse
37
+ );
38
+ const configFieldsChanged = !validation_utils.areObjectsEqual(
39
+ configuration.configurationFields,
40
+ originalConfigurationFields
41
+ );
42
+ const configuredFieldsChanged = !validation_utils.areObjectsEqual(
43
+ configuration.configuredFields,
44
+ originalConfiguredFields
45
+ );
46
+ return configFieldsChanged || configuredFieldsChanged || !isInitialLoad && mappingDataChanged || importResponseChanged;
47
+ };
48
+ return {
49
+ originalMappingData,
50
+ setOriginalMappingData,
51
+ isInitialLoad,
52
+ setIsInitialLoad,
53
+ hasFieldsChanged
54
+ };
55
+ };
56
+
57
+ exports.useEditState = useEditState;
58
+ //# sourceMappingURL=useEditState.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useEditState.js","sources":["../../../../src/single-mapping/hooks/useEditState.ts"],"sourcesContent":["import { useState, useEffect } from \"react\";\nimport { MappingData } from \"../../commons/types/enhanced\";\nimport { ConfigurationFieldType } from \"../types/configuration.types\";\nimport { deepClone, areObjectsEqual } from \"../utils/validation.utils\";\n\ntype UseEditStateProps = {\n editField: any;\n configuration: {\n configurationFields: Array<ConfigurationFieldType>;\n configuredFields: Record<string, any>;\n };\n importResponse: any;\n navigateMappingPage: (value?: boolean) => void;\n};\n\ntype UseEditStateReturn = {\n originalMappingData: MappingData | null;\n setOriginalMappingData: (data: MappingData | null) => void;\n isInitialLoad: boolean;\n setIsInitialLoad: (value: boolean) => void;\n hasFieldsChanged: () => boolean;\n};\n\n/**\n * Custom hook to manage edit state and track changes\n */\nexport const useEditState = ({\n editField,\n configuration,\n importResponse,\n navigateMappingPage,\n}: UseEditStateProps): UseEditStateReturn => {\n const [originalMappingData, setOriginalMappingData] = useState<MappingData | null>(null);\n const [originalConfigurationFields, setOriginalConfigurationFields] = useState<any>(null);\n const [originalConfiguredFields, setOriginalConfiguredFields] = useState<any>(null);\n const [originalImportResponse, setOriginalImportResponse] = useState<any>(null);\n const [isInitialLoad, setIsInitialLoad] = useState(true);\n\n useEffect(() => {\n if (editField?.id) {\n navigateMappingPage(true);\n // Store original state when entering edit mode\n setOriginalConfigurationFields(deepClone(configuration.configurationFields));\n setOriginalConfiguredFields(deepClone(configuration.configuredFields));\n setOriginalImportResponse(deepClone(importResponse));\n }\n }, []);\n\n const hasFieldsChanged = (): boolean => {\n // Not in edit mode or no original data\n if (!editField?.id || !originalMappingData) {\n return true;\n }\n\n // Check if mapping data has changed\n const mappingDataChanged = !areObjectsEqual(\n originalMappingData,\n originalMappingData // This will be compared with current state in the component\n );\n\n const importResponseChanged = !areObjectsEqual(\n deepClone(importResponse),\n originalImportResponse\n );\n\n // Check if configuration fields have changed\n const configFieldsChanged = !areObjectsEqual(\n configuration.configurationFields,\n originalConfigurationFields\n );\n\n // Check if configured fields have changed\n const configuredFieldsChanged = !areObjectsEqual(\n configuration.configuredFields,\n originalConfiguredFields\n );\n\n return (\n configFieldsChanged ||\n configuredFieldsChanged ||\n (!isInitialLoad && mappingDataChanged) ||\n importResponseChanged\n );\n };\n\n return {\n originalMappingData,\n setOriginalMappingData,\n isInitialLoad,\n setIsInitialLoad,\n hasFieldsChanged,\n };\n};\n\n"],"names":["useState","useEffect","deepClone","areObjectsEqual"],"mappings":";;;;;AA0BO,MAAM,eAAe,CAAC;AAAA,EAC3B,SAAA;AAAA,EACA,aAAA;AAAA,EACA,cAAA;AAAA,EACA,mBAAA;AACF,CAA6C,KAAA;AAC3C,EAAA,MAAM,CAAC,mBAAA,EAAqB,sBAAsB,CAAA,GAAIA,eAA6B,IAAI,CAAA,CAAA;AACvF,EAAA,MAAM,CAAC,2BAAA,EAA6B,8BAA8B,CAAA,GAAIA,eAAc,IAAI,CAAA,CAAA;AACxF,EAAA,MAAM,CAAC,wBAAA,EAA0B,2BAA2B,CAAA,GAAIA,eAAc,IAAI,CAAA,CAAA;AAClF,EAAA,MAAM,CAAC,sBAAA,EAAwB,yBAAyB,CAAA,GAAIA,eAAc,IAAI,CAAA,CAAA;AAC9E,EAAA,MAAM,CAAC,aAAA,EAAe,gBAAgB,CAAA,GAAIA,eAAS,IAAI,CAAA,CAAA;AAEvD,EAAAC,eAAA,CAAU,MAAM;AACd,IAAA,IAAI,uCAAW,EAAI,EAAA;AACjB,MAAA,mBAAA,CAAoB,IAAI,CAAA,CAAA;AAExB,MAA+B,8BAAA,CAAAC,0BAAA,CAAU,aAAc,CAAA,mBAAmB,CAAC,CAAA,CAAA;AAC3E,MAA4B,2BAAA,CAAAA,0BAAA,CAAU,aAAc,CAAA,gBAAgB,CAAC,CAAA,CAAA;AACrE,MAA0B,yBAAA,CAAAA,0BAAA,CAAU,cAAc,CAAC,CAAA,CAAA;AAAA,KACrD;AAAA,GACF,EAAG,EAAE,CAAA,CAAA;AAEL,EAAA,MAAM,mBAAmB,MAAe;AAEtC,IAAA,IAAI,EAAC,SAAA,IAAA,IAAA,GAAA,KAAA,CAAA,GAAA,SAAA,CAAW,EAAM,CAAA,IAAA,CAAC,mBAAqB,EAAA;AAC1C,MAAO,OAAA,IAAA,CAAA;AAAA,KACT;AAGA,IAAA,MAAM,qBAAqB,CAACC,gCAAA;AAAA,MAC1B,mBAAA;AAAA,MACA,mBAAA;AAAA;AAAA,KACF,CAAA;AAEA,IAAA,MAAM,wBAAwB,CAACA,gCAAA;AAAA,MAC7BD,2BAAU,cAAc,CAAA;AAAA,MACxB,sBAAA;AAAA,KACF,CAAA;AAGA,IAAA,MAAM,sBAAsB,CAACC,gCAAA;AAAA,MAC3B,aAAc,CAAA,mBAAA;AAAA,MACd,2BAAA;AAAA,KACF,CAAA;AAGA,IAAA,MAAM,0BAA0B,CAACA,gCAAA;AAAA,MAC/B,aAAc,CAAA,gBAAA;AAAA,MACd,wBAAA;AAAA,KACF,CAAA;AAEA,IAAA,OACE,mBACA,IAAA,uBAAA,IACC,CAAC,aAAA,IAAiB,kBACnB,IAAA,qBAAA,CAAA;AAAA,GAEJ,CAAA;AAEA,EAAO,OAAA;AAAA,IACL,mBAAA;AAAA,IACA,sBAAA;AAAA,IACA,aAAA;AAAA,IACA,gBAAA;AAAA,IACA,gBAAA;AAAA,GACF,CAAA;AACF;;;;"}