@integry/sdk 4.7.39 → 4.7.40

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 (267) hide show
  1. package/dist/esm/index.csm.js +1 -1
  2. package/dist/umd/index.umd.js +1 -1
  3. package/package.json +6 -1
  4. package/.eslintignore +0 -1
  5. package/.vscode/launch.json +0 -17
  6. package/CHANGELOG_INTERNAL.md +0 -134
  7. package/README_INTERNAL.md +0 -176
  8. package/THIRD_PARTY_LICENSES +0 -525
  9. package/generateTests.js +0 -80
  10. package/jest.config.cjs +0 -10
  11. package/src/components/AddTagButton/index.ts +0 -23
  12. package/src/components/BasicSelect/index.ts +0 -123
  13. package/src/components/BasicSelect/styles.module.scss +0 -44
  14. package/src/components/Button/index.ts +0 -97
  15. package/src/components/Button/styles.module.scss +0 -152
  16. package/src/components/CheckboxGroup/Checkbox.ts +0 -104
  17. package/src/components/CheckboxGroup/index.ts +0 -190
  18. package/src/components/CheckboxGroup/styles.module.scss +0 -63
  19. package/src/components/CollapsedMenu/index.ts +0 -104
  20. package/src/components/CollapsedMenu/styles.module.scss +0 -46
  21. package/src/components/ConfigureFieldWrapper/index.ts +0 -85
  22. package/src/components/ConfigureFieldWrapper/styles.module.scss +0 -57
  23. package/src/components/EditableText/index.ts +0 -121
  24. package/src/components/EditableText/styles.module.scss +0 -38
  25. package/src/components/EditableTextArea/index.ts +0 -143
  26. package/src/components/EditableTextArea/styles.module.scss +0 -91
  27. package/src/components/ErrorMessage/index.ts +0 -16
  28. package/src/components/ErrorMessage/styles.module.scss +0 -19
  29. package/src/components/ErrorPage/index.ts +0 -42
  30. package/src/components/ErrorPage/styles.module.scss +0 -26
  31. package/src/components/Footer/index.ts +0 -41
  32. package/src/components/Footer/styles.module.scss +0 -40
  33. package/src/components/HTMLContent/index.tsx +0 -205
  34. package/src/components/HTMLContent/styles.module.scss +0 -3
  35. package/src/components/InfoBox/index.ts +0 -48
  36. package/src/components/InfoBox/styles.module.scss +0 -21
  37. package/src/components/Input/BaseInput/index.ts +0 -170
  38. package/src/components/Input/BaseInput/styles.module.scss +0 -95
  39. package/src/components/Input/DateInput/index.ts +0 -103
  40. package/src/components/Input/DateInput/styles.module.scss +0 -50
  41. package/src/components/Input/Input/index.ts +0 -225
  42. package/src/components/Input/Input/styles.module.scss +0 -16
  43. package/src/components/Input/PasswordInput/index.ts +0 -164
  44. package/src/components/Input/PasswordInput/styles.module.scss +0 -37
  45. package/src/components/Input/index.ts +0 -7
  46. package/src/components/Label/index.ts +0 -61
  47. package/src/components/Label/styles.module.scss +0 -41
  48. package/src/components/LargeLoader/index.ts +0 -25
  49. package/src/components/LargeLoader/styles.module.scss +0 -16
  50. package/src/components/Listbox/ListBoxItem.ts +0 -57
  51. package/src/components/Listbox/index.ts +0 -488
  52. package/src/components/Listbox/styles.module.scss +0 -197
  53. package/src/components/Loader/index.ts +0 -25
  54. package/src/components/Loader/styles.module.scss +0 -16
  55. package/src/components/MediaGallery/MediaGalleryModal.ts +0 -82
  56. package/src/components/MediaGallery/MediaSlider.ts +0 -76
  57. package/src/components/MediaGallery/index.ts +0 -92
  58. package/src/components/MediaGallery/styles.module.scss +0 -156
  59. package/src/components/MediaUpload/index.ts +0 -233
  60. package/src/components/MediaUpload/styles.module.scss +0 -118
  61. package/src/components/Modal/index.ts +0 -87
  62. package/src/components/Modal/styles.module.scss +0 -441
  63. package/src/components/MultipurposeField/Dropdown/ListBoxItem.tsx +0 -59
  64. package/src/components/MultipurposeField/Dropdown/index.tsx +0 -1202
  65. package/src/components/MultipurposeField/Dropdown/styles.module.scss +0 -215
  66. package/src/components/MultipurposeField/TagMenu/index.ts +0 -536
  67. package/src/components/MultipurposeField/TagMenu/styles.module.scss +0 -175
  68. package/src/components/MultipurposeField/TagOptions/index.tsx +0 -83
  69. package/src/components/MultipurposeField/TagOptions/styles.module.scss +0 -95
  70. package/src/components/MultipurposeField/index.tsx +0 -944
  71. package/src/components/MultipurposeField/styles.module.scss +0 -77
  72. package/src/components/NewModal/index.ts +0 -69
  73. package/src/components/NewModal/styles.module.scss +0 -70
  74. package/src/components/OverflowTooltip/index.tsx +0 -59
  75. package/src/components/PopUp/ConfirmationPopUp/index.ts +0 -58
  76. package/src/components/PopUp/ConfirmationPopUp/styles.module.scss +0 -49
  77. package/src/components/PopUp/SuccessPopUp/index.ts +0 -62
  78. package/src/components/PopUp/SuccessPopUp/styles.module.scss +0 -38
  79. package/src/components/RadioGroup/Radio.ts +0 -128
  80. package/src/components/RadioGroup/index.ts +0 -169
  81. package/src/components/RadioGroup/styles.module.scss +0 -81
  82. package/src/components/Search/index.ts +0 -69
  83. package/src/components/Search/styles.module.scss +0 -149
  84. package/src/components/TabBar/Tab.ts +0 -33
  85. package/src/components/TabBar/index.ts +0 -64
  86. package/src/components/TabBar/styles.module.scss +0 -43
  87. package/src/components/Tag/index.ts +0 -29
  88. package/src/components/Tag/styles.module.scss +0 -57
  89. package/src/components/TagsMenu/index.ts +0 -1697
  90. package/src/components/TagsMenu/styles.module.scss +0 -350
  91. package/src/components/TestComponent/index.ts +0 -71
  92. package/src/components/TestComponent/styles.module.scss +0 -152
  93. package/src/components/TextArea/index.ts +0 -172
  94. package/src/components/TextArea/styles.module.scss +0 -72
  95. package/src/components/TextContent/index.tsx +0 -128
  96. package/src/components/TextContent/styles.module.scss +0 -6
  97. package/src/components/ThreeDotLoader/index.ts +0 -39
  98. package/src/components/ThreeDotLoader/styles.module.scss +0 -41
  99. package/src/components/TimeInput/index.ts +0 -129
  100. package/src/components/TimeInput/styles.module.scss +0 -16
  101. package/src/components/Toggle/index.ts +0 -34
  102. package/src/components/Toggle/styles.module.scss +0 -56
  103. package/src/components/Toggle-v2/index.ts +0 -40
  104. package/src/components/Toggle-v2/styles.module.scss +0 -86
  105. package/src/components/Tooltip/index.ts +0 -271
  106. package/src/components/Tooltip/styles.module.scss +0 -105
  107. package/src/components/form/FunctionField/index.ts +0 -816
  108. package/src/components/form/FunctionField/styles.module.scss +0 -478
  109. package/src/components/form/ObjectField/__snapshots__/index.ts.test.tsx.snap +0 -3
  110. package/src/components/form/ObjectField/index.ts +0 -593
  111. package/src/components/form/ObjectField/index.ts.test.tsx +0 -213
  112. package/src/components/form/ObjectField/styles.module.scss +0 -103
  113. package/src/components/form/index.ts +0 -4
  114. package/src/contexts/AppContext.ts +0 -12
  115. package/src/declaration.d.ts +0 -7
  116. package/src/extensions/HMAC.ts +0 -25
  117. package/src/extensions/IntegryAPIError.ts +0 -19
  118. package/src/features/common/AccountDropdown/index.ts +0 -291
  119. package/src/features/common/AccountDropdown/styles.module.scss +0 -19
  120. package/src/features/common/ActionForm/index.ts +0 -2602
  121. package/src/features/common/ActionForm/styles.module.scss +0 -35
  122. package/src/features/common/AppCard/index.ts +0 -207
  123. package/src/features/common/AppCard/styles.module.scss +0 -117
  124. package/src/features/common/AppCardCompact/index.ts +0 -189
  125. package/src/features/common/AppCardCompact/styles.module.scss +0 -141
  126. package/src/features/common/AuthSelector/index.ts +0 -537
  127. package/src/features/common/AuthSelector/styles.module.scss +0 -161
  128. package/src/features/common/AuthSelectorCompact/index.ts +0 -706
  129. package/src/features/common/AuthSelectorCompact/styles.module.scss +0 -219
  130. package/src/features/common/AuthSelectorDropdown/index.ts +0 -704
  131. package/src/features/common/AuthSelectorDropdown/styles.module.scss +0 -361
  132. package/src/features/common/AuthSelectorV2/index.ts +0 -336
  133. package/src/features/common/AuthSelectorV2/styles.module.scss +0 -235
  134. package/src/features/common/DynamicField/index.ts +0 -402
  135. package/src/features/common/DynamicField/styles.module.scss +0 -266
  136. package/src/features/common/DynamicTypedField/index.ts +0 -504
  137. package/src/features/common/DynamicTypedField/styles.module.scss +0 -135
  138. package/src/features/common/FunctionForm/index.ts +0 -1095
  139. package/src/features/common/FunctionForm/styles.module.scss +0 -225
  140. package/src/features/common/MappingUI/index.ts +0 -649
  141. package/src/features/common/MappingUI/styles.module.scss +0 -121
  142. package/src/features/common/MarketplaceAppCard/index.ts +0 -279
  143. package/src/features/common/MarketplaceAppCard/styles.module.scss +0 -231
  144. package/src/features/common/MarketplaceAppCardCompact/index.ts +0 -283
  145. package/src/features/common/MarketplaceAppCardCompact/styles.module.scss +0 -255
  146. package/src/features/common/NewMappingUI/index.ts +0 -515
  147. package/src/features/common/NewMappingUI/styles.module.scss +0 -113
  148. package/src/features/common/RequestAppWidget/RequestAppModal/index.ts +0 -67
  149. package/src/features/common/RequestAppWidget/RequestAppModal/styles.module.scss +0 -23
  150. package/src/features/common/RequestAppWidget/index.ts +0 -48
  151. package/src/features/common/RequestAppWidget/request-app-form.ts +0 -89
  152. package/src/features/common/RequestAppWidget/styles.module.scss +0 -43
  153. package/src/features/common/SectionField/index.ts +0 -272
  154. package/src/features/common/SectionField/styles.module.scss +0 -67
  155. package/src/features/common/Step/index.ts +0 -827
  156. package/src/features/common/Step/styles.module.scss +0 -12
  157. package/src/features/common/StepNavigation/CollapsedSteps.ts +0 -131
  158. package/src/features/common/StepNavigation/NavItem.ts +0 -111
  159. package/src/features/common/StepNavigation/index.ts +0 -261
  160. package/src/features/common/StepNavigation/styles.module.scss +0 -117
  161. package/src/features/common/Steps/index.ts +0 -1140
  162. package/src/features/common/Steps/styles.module.scss +0 -314
  163. package/src/features/containers/AppFlowContainer/AppFlowListing/compactStyles.module.scss +0 -404
  164. package/src/features/containers/AppFlowContainer/AppFlowListing/flow-instance.tsx +0 -367
  165. package/src/features/containers/AppFlowContainer/AppFlowListing/flowCard.test.tsx +0 -58
  166. package/src/features/containers/AppFlowContainer/AppFlowListing/flowCard.tsx +0 -208
  167. package/src/features/containers/AppFlowContainer/AppFlowListing/flowCardCompact.test.tsx +0 -49
  168. package/src/features/containers/AppFlowContainer/AppFlowListing/flowCardCompact.tsx +0 -421
  169. package/src/features/containers/AppFlowContainer/AppFlowListing/flowInstanceCompact.tsx +0 -577
  170. package/src/features/containers/AppFlowContainer/AppFlowListing/index.tsx +0 -83
  171. package/src/features/containers/AppFlowContainer/AppFlowListing/styles.module.scss +0 -233
  172. package/src/features/containers/AppFlowContainer/AppFlowWrap/app-page-loader.tsx +0 -45
  173. package/src/features/containers/AppFlowContainer/AppFlowWrap/index.tsx +0 -1085
  174. package/src/features/containers/AppFlowContainer/AppFlowWrap/styles.module.scss +0 -465
  175. package/src/features/containers/AppFlowContainer/Authentication/index.ts +0 -610
  176. package/src/features/containers/AppFlowContainer/Authentication/styles.module.scss +0 -468
  177. package/src/features/containers/AppFlowContainer/index.ts +0 -114
  178. package/src/features/containers/AppPageContainer/AppPage/index.tsx +0 -262
  179. package/src/features/containers/AppPageContainer/AppPage/styles.module.scss +0 -120
  180. package/src/features/containers/AppPageContainer/IntegrationCard/index.ts +0 -165
  181. package/src/features/containers/AppPageContainer/IntegrationCard/styles.module.scss +0 -81
  182. package/src/features/containers/AppPageContainer/index.tsx +0 -93
  183. package/src/features/containers/AppPageContainer/styles.module.scss +0 -0
  184. package/src/features/containers/AppsForFlows/index.ts +0 -161
  185. package/src/features/containers/AppsForFlows/styles.module.scss +0 -280
  186. package/src/features/containers/AppsForFlowsCompact/index.ts +0 -161
  187. package/src/features/containers/AppsForFlowsCompact/styles.module.scss +0 -279
  188. package/src/features/containers/AuthSetupContainer/AppSelection.ts +0 -73
  189. package/src/features/containers/AuthSetupContainer/AuthTypeSelection.ts +0 -67
  190. package/src/features/containers/AuthSetupContainer/Footer.ts +0 -32
  191. package/src/features/containers/AuthSetupContainer/Header.ts +0 -39
  192. package/src/features/containers/AuthSetupContainer/PostAdditionPopup.ts +0 -27
  193. package/src/features/containers/AuthSetupContainer/index.ts +0 -349
  194. package/src/features/containers/AuthSetupContainer/styles.module.scss +0 -229
  195. package/src/features/containers/FlowSetupContainer/index.ts +0 -391
  196. package/src/features/containers/FlowSetupContainer/styles.module.scss +0 -18
  197. package/src/features/containers/MarkeplaceApps/index.ts +0 -583
  198. package/src/features/containers/MarkeplaceApps/styles.module.scss +0 -558
  199. package/src/features/containers/MarketplaceAppsCompact/index.ts +0 -585
  200. package/src/features/containers/MarketplaceAppsCompact/styles.module.scss +0 -563
  201. package/src/features/containers/MarketplaceAppsContainer/index.ts +0 -91
  202. package/src/features/containers/MarketplaceContainer/AppCard/index.ts +0 -91
  203. package/src/features/containers/MarketplaceContainer/AppCard/styles.module.scss +0 -66
  204. package/src/features/containers/MarketplaceContainer/AppListing/index.ts +0 -34
  205. package/src/features/containers/MarketplaceContainer/AppListing/styles.module.scss +0 -10
  206. package/src/features/containers/MarketplaceContainer/MarketplaceContentWrap/index.ts +0 -132
  207. package/src/features/containers/MarketplaceContainer/MarketplaceContentWrap/styles.module.scss +0 -117
  208. package/src/features/containers/MarketplaceContainer/index.ts +0 -242
  209. package/src/features/containers/MarketplaceContainer/styles.module.scss +0 -84
  210. package/src/features/containers/SDKContainer/index.ts +0 -817
  211. package/src/features/containers/SDKContainer/styles.module.scss +0 -266
  212. package/src/features/containers/SDKDebugContainer/index.ts +0 -137
  213. package/src/features/containers/SDKDebugContainer/styles.module.scss +0 -37
  214. package/src/features/containers/SDKFailedContainer/index.ts +0 -117
  215. package/src/features/containers/SDKFailedContainer/styles.module.scss +0 -57
  216. package/src/features/integrations/IntegrationRow/Icons.ts +0 -77
  217. package/src/features/integrations/IntegrationRow/index.ts +0 -129
  218. package/src/features/integrations/IntegrationRow/styles.module.scss +0 -62
  219. package/src/features/integrations/IntegrationsHeader/index.ts +0 -34
  220. package/src/features/integrations/IntegrationsHeader/styles.module.scss +0 -47
  221. package/src/features/integrations/IntegrationsList/index.ts +0 -252
  222. package/src/features/integrations/IntegrationsList/styles.module.scss +0 -67
  223. package/src/features/templates/Template/index.ts +0 -295
  224. package/src/features/templates/Template/styles.module.scss +0 -226
  225. package/src/features/templates/TemplatesView/index.ts +0 -368
  226. package/src/features/templates/TemplatesView/styles.module.scss +0 -71
  227. package/src/features/templates/TemplatesViewCompact/index.ts +0 -364
  228. package/src/features/templates/TemplatesViewCompact/styles.module.scss +0 -141
  229. package/src/hooks/useAutosizeTextArea.ts +0 -22
  230. package/src/hooks/useCustomRef.ts +0 -13
  231. package/src/hooks/useDebounce.ts +0 -17
  232. package/src/hooks/useElementResize.ts +0 -40
  233. package/src/hooks/useEventListener.ts +0 -42
  234. package/src/hooks/useHover.ts +0 -40
  235. package/src/hooks/useOnClickOutside.ts +0 -32
  236. package/src/index.ts +0 -2244
  237. package/src/index.umd.ts +0 -13
  238. package/src/interfaces/index.ts +0 -938
  239. package/src/modules/api/index.ts +0 -1325
  240. package/src/modules/api/responseHandler.ts +0 -38
  241. package/src/modules/event-emitter/index.ts +0 -72
  242. package/src/modules/event-emitter/runners/abstract.ts +0 -21
  243. package/src/modules/event-emitter/runners/default.ts +0 -11
  244. package/src/modules/event-emitter/runners/ntimes.ts +0 -28
  245. package/src/modules/event-emitter/types.ts +0 -34
  246. package/src/store/actionFunctions.ts +0 -1578
  247. package/src/store/index.ts +0 -17
  248. package/src/store/initialState.ts +0 -58
  249. package/src/types/index.ts +0 -320
  250. package/src/types/preact-compat.d.ts +0 -4
  251. package/src/types/store.ts +0 -366
  252. package/src/types/utils.ts +0 -19
  253. package/src/utils/ActivityOutputUtils.ts +0 -176
  254. package/src/utils/common.ts +0 -20
  255. package/src/utils/copyToClipboard.ts +0 -24
  256. package/src/utils/datetime.ts +0 -101
  257. package/src/utils/getUrlParam.ts +0 -11
  258. package/src/utils/isAuthMessage.ts +0 -16
  259. package/src/utils/isBrowser.ts +0 -1
  260. package/src/utils/jsonEncodeDecode.ts +0 -15
  261. package/src/utils/objectUtils.ts +0 -117
  262. package/src/utils/popup.ts +0 -30
  263. package/src/utils/searchJson.ts +0 -51
  264. package/src/utils/stepUtils.ts +0 -45
  265. package/src/utils/truncate.ts +0 -6
  266. package/test/setup.ts +0 -1
  267. package/vitest.config.ts +0 -16
@@ -1,610 +0,0 @@
1
- import { html } from 'htm/preact';
2
- import { actionFunctions } from '@/store';
3
- import { useEffect, useContext, useState, useRef } from 'preact/hooks';
4
- import { connect } from 'unistore/preact';
5
- import AppContext from '@/contexts/AppContext';
6
- import { Hint } from '@/components/Tooltip';
7
- import { Modal } from '@/components/Modal';
8
- import { Loader } from '@/components/Loader';
9
- import { openPopupWindow } from '@/utils/popup';
10
- import isBrowser from '@/utils/isBrowser';
11
- import { AuthData, isAuthMessage } from '@/utils/isAuthMessage';
12
- import { StoreType } from '@/types/store';
13
- import { BrandingApp } from '@/interfaces';
14
- import AuthSelectorDropdown from '@/features/common/AuthSelectorDropdown';
15
- import { createRef } from 'preact';
16
- import { ViewStyles } from '@/types';
17
- import styles from './styles.module.scss';
18
-
19
- export type StepsPropsType = {
20
- onUpdate?(): void;
21
- isActionSetup?: boolean;
22
- goBack?(): void;
23
- brandingApp: any;
24
- } & StoreType;
25
-
26
- const Authentication = (props: any) => {
27
- const {
28
- embedConfig,
29
- authorizations,
30
- onAuthDelete,
31
- onAuthenticationRecieved,
32
- hideAuthActions = false,
33
- onAuthVerify,
34
- stepId,
35
- onAuthSelected,
36
- initialAuthVerification = true,
37
- } = props;
38
-
39
- const context = useContext(AppContext);
40
-
41
- const [selectedAuth, setSelectedAuth] = useState<any>(null);
42
- const [authVerification, setAuthVerification] = useState<any>({});
43
- const [isVerifying, setIsVerifying] = useState<boolean>(true);
44
- const [isSelectedAuthVerified, setIsSelectedAuthVerified] = useState<boolean>(
45
- false,
46
- );
47
- const [showAuthPopup, setShowAuthPopup] = useState<boolean>(false);
48
- const [allowMultipleAccounts, setAllowMultipleAccounts] = useState<boolean>(
49
- true,
50
- );
51
- const [showDeleteConfirmation, setShowDeleteConfirmation] = useState<boolean>(
52
- false,
53
- );
54
- const [isDeleting, setIsDeleting] = useState<boolean>(false);
55
- const [isFirstTimeLoad, setIsFirstTimeLoad] = useState<boolean>(true);
56
- const [authError, setAuthError] = useState<string | null>(null);
57
-
58
- const onAuthResponseReceived = (messageEvent: MessageEvent<AuthData>) => {
59
- if (isAuthMessage(messageEvent) && messageEvent.data.activity_name) {
60
- if (onAuthenticationRecieved) onAuthenticationRecieved(messageEvent);
61
- setAuthError(null);
62
- }
63
- };
64
-
65
- const authPopoverRef = createRef();
66
-
67
- const authPopoverCtaRef = createRef();
68
-
69
- const openAuthWindow = () => {
70
- const { appData } = props;
71
- const { authorization_type } = appData || {};
72
- if (context) {
73
- const url = context.apiHandler.getAuthUrl(authorization_type.id);
74
- openPopupWindow(url, 'Auth Window', window, 800, 600);
75
- }
76
- };
77
- useEffect(() => {
78
- const { userConfig, selectedAuthByAppId, appData } = props;
79
- const { id: appId } = appData || {};
80
- let tempAuthVerification = {};
81
- let hasSetDefaultAuth = false;
82
-
83
- let currentAuthObj = selectedAuthByAppId[appId]
84
- ? authorizations.find(
85
- (auth: any) => auth.id === selectedAuthByAppId[appId],
86
- ) || authorizations[authorizations.length - 1]
87
- : authorizations[authorizations.length - 1];
88
-
89
- if (authorizations.length > 0) {
90
- const tempAuth = authorizations.filter(
91
- (auth: any) => auth.id === props.stepMapping[stepId]?.selectedAuthId,
92
- );
93
- if (
94
- stepId &&
95
- tempAuth.length > 0 &&
96
- (selectedAuth === null ||
97
- props.stepMapping[stepId].authorizations.filter(
98
- (auth: any) => auth.authorizationId === selectedAuth?.id,
99
- ).length === 0)
100
- ) {
101
- setSelectedAuth(tempAuth[0]);
102
- [currentAuthObj] = tempAuth;
103
- hasSetDefaultAuth = true;
104
- } else if (
105
- props.stepMapping[stepId]?.selectedAuthId === null ||
106
- !stepId
107
- ) {
108
- setSelectedAuth(currentAuthObj);
109
- hasSetDefaultAuth = true;
110
- }
111
-
112
- authorizations.forEach((auth: any) => {
113
- tempAuthVerification = {
114
- ...tempAuthVerification,
115
- [auth.id]: 'verifying',
116
- };
117
- });
118
- // NOTE: ENABLE IT WHEN HANDLING MULTIPLE AUTHS
119
- // authorizations.forEach((auth: any) => {
120
- // context?.apiHandler
121
- // .verifyOAuth(auth.id)
122
- // .then((isVerified) => {
123
- // setAuthVerification({
124
- // ...tempAuthVerification,
125
- // [auth.id]: isVerified ? 'success' : 'fail',
126
- // });
127
- // setAuthError(isVerified ? null : 'Could not authorize');
128
- // onAuthVerify(auth.id, isVerified);
129
- // })
130
- // .catch((err) => {
131
- // console.error(err);
132
- // })
133
- // .finally(() => {
134
- // setIsVerifying(false);
135
- // });
136
- // });
137
- if (selectedAuth === null && !hasSetDefaultAuth) {
138
- setSelectedAuth(currentAuthObj);
139
- hasSetDefaultAuth = true;
140
- }
141
- if (hasSetDefaultAuth && initialAuthVerification) {
142
- context?.apiHandler
143
- .verifyOAuth(currentAuthObj.id)
144
- .then((isVerified) => {
145
- setAuthVerification({
146
- ...tempAuthVerification,
147
- [currentAuthObj.id]: isVerified ? 'success' : 'fail',
148
- });
149
- setAuthError(isVerified ? null : 'Could not authorize');
150
- onAuthVerify(currentAuthObj.id, isVerified);
151
- setIsSelectedAuthVerified(isVerified || false);
152
- onAuthSelected(currentAuthObj.id, isVerified);
153
-
154
- if (stepId) {
155
- const dependentSteps = props.stepMapping[
156
- stepId
157
- ].step.template_fields
158
- .filter(
159
- (el: any) =>
160
- el.activity_field && el.activity_field.is_dynamic,
161
- )
162
- .map((el: any) => el.id);
163
- props.setStepAuthorization(
164
- stepId,
165
- currentAuthObj.id,
166
- isVerified,
167
- [],
168
- false,
169
- );
170
- }
171
- })
172
- .catch((err) => {
173
- console.error(err);
174
- })
175
- .finally(() => {
176
- setIsVerifying(false);
177
- });
178
- setIsFirstTimeLoad(false);
179
- } else if (hasSetDefaultAuth && !initialAuthVerification) {
180
- setIsVerifying(false);
181
- setAuthVerification({
182
- ...tempAuthVerification,
183
- [currentAuthObj.id]: 'success',
184
- });
185
- setAuthError(null);
186
- onAuthVerify(currentAuthObj.id, true);
187
- setIsSelectedAuthVerified(true);
188
- setIsFirstTimeLoad(false);
189
- onAuthSelected(currentAuthObj.id, false);
190
- }
191
- } else {
192
- setIsVerifying(false);
193
- setSelectedAuth(null);
194
- if (
195
- props.appData &&
196
- isFirstTimeLoad &&
197
- !userConfig.skipAutoConnect &&
198
- !props.genericData.skipAccountConnectionOnLoad
199
- ) {
200
- setIsFirstTimeLoad(false);
201
- openAuthWindow();
202
- }
203
- if (props.appData && isFirstTimeLoad) {
204
- setIsFirstTimeLoad(false);
205
- props.setGenericData({
206
- ...props.genericData,
207
- skipAccountConnectionOnLoad: false, // NOTE: This is to make sure that the auth window is Skipped only once
208
- });
209
- }
210
- }
211
- if (isBrowser()) window.addEventListener('message', onAuthResponseReceived);
212
- return () => {
213
- if (isBrowser())
214
- window.removeEventListener('message', onAuthResponseReceived);
215
- };
216
- }, [authorizations]);
217
-
218
- const handleAuthSelected = (
219
- authId: number,
220
- authStepId: number,
221
- isVerified: boolean,
222
- override: boolean,
223
- ) => {
224
- const tempAuth = authorizations.filter((auth: any) => auth.id === authId);
225
- if (tempAuth.length > 0) {
226
- setSelectedAuth(tempAuth[0]);
227
- if (onAuthSelected) {
228
- onAuthSelected(tempAuth[0].id, isVerified);
229
- }
230
- } else {
231
- setSelectedAuth(null);
232
- if (onAuthSelected) {
233
- onAuthSelected(0, isVerified); // NOTE: 0 is for no auth
234
- }
235
- }
236
-
237
- setShowAuthPopup(false);
238
- };
239
-
240
- const handleNewAccountAdded = (authId: any) => {
241
- const tempAuth = authorizations.filter((auth: any) => auth.id === authId);
242
- setSelectedAuth(tempAuth[0]);
243
- setShowAuthPopup(false);
244
- };
245
-
246
- const deleteAuth = (authId: number) => {
247
- const { appData } = props;
248
- const { id: appId } = appData as BrandingApp;
249
- if (context) {
250
- setIsDeleting(true);
251
- context.apiHandler
252
- .deleteAuth(authId, true)
253
- .then((res: any) => {
254
- const { data, status = 500 } = res;
255
- if (status === 200) {
256
- if (onAuthDelete) onAuthDelete(authId, appId);
257
- if (authorizations.length > 1) {
258
- const tempAuths = authorizations.filter(
259
- (auth: any) => auth.id !== authId,
260
- );
261
- setSelectedAuth(tempAuths[0]);
262
- } else {
263
- setSelectedAuth(null);
264
- }
265
- setAuthError(null);
266
- } else if (typeof data === 'string') {
267
- setAuthError(data || 'Could not authorize');
268
- } else {
269
- setAuthError('Could not authorize');
270
- }
271
- })
272
- .catch((err) => {
273
- console.error(err);
274
- })
275
- .finally(() => {
276
- setIsDeleting(false);
277
- });
278
- }
279
- };
280
-
281
- // if (authorizations.length === 0 && !isVerifying) {
282
- // return html`
283
- // <div class="${styles.authenticationContainer}">
284
- // <div class="${styles.authSelectorInlineWrap}">
285
- // <div class="${styles.authSelectorUsername}">
286
- // <span class="${styles.authSelectorLabel}" style="color: #999999;"
287
- // >Account:</span
288
- // >
289
- // <span
290
- // onclick=${(e: any) => {
291
- // e.stopPropagation();
292
- // openAuthWindow();
293
- // }}
294
- // class="${styles.authCTA}"
295
- // >Connect an account...</span
296
- // >
297
- // </div>
298
- // </div>
299
- // </div>
300
- // `;
301
- // }
302
-
303
- return html`
304
- <div
305
- class=${styles.accountField}
306
- style="color: #999999;"
307
- onClick=${() => {
308
- setShowAuthPopup(true);
309
- }}
310
- >
311
- ${props.genericData.viewStyle === ViewStyles.COMFORTABLE
312
- ? `${props?.appData?.name} Account:`
313
- : ''}
314
- ${allowMultipleAccounts &&
315
- html` <${Hint} dismissOnClick=${true} position=${'bottom-right'}>
316
- <div
317
- ref=${authPopoverCtaRef}
318
- class=${styles.accountFieldDropdown}
319
- style="${showAuthPopup ? 'border: 1px solid #4250F0;' : ''}"
320
- data-hint="${props.genericData.viewStyle === ViewStyles.COMPACT
321
- ? `${props?.appData?.name} Account`
322
- : ''}"
323
- >
324
- <p style="margin-left: 0;">
325
- ${selectedAuth?.user_identity
326
- ? html` <div
327
- style="max-width: ${isSelectedAuthVerified || false
328
- ? '220px'
329
- : '156px'}; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;"
330
- >
331
- ${selectedAuth?.user_identity}
332
- </div>`
333
- : html` <div
334
- style="max-width: 220px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;color: #999999;"
335
- >
336
- No account connected
337
- </div>`}
338
- ${selectedAuth?.user_identity &&
339
- html` <div class=${styles.accountStatus}>
340
- ${false
341
- ? html`<${Loader} />`
342
- : html`
343
- ${isSelectedAuthVerified &&
344
- html`<svg
345
- data-hint="Connected"
346
- width="12"
347
- height="12"
348
- viewBox="0 0 12 12"
349
- fill="none"
350
- xmlns="http://www.w3.org/2000/svg"
351
- >
352
- <path
353
- d="M5.07595 8.71074C4.99537 8.71124 4.91558 8.69526 4.8414 8.66377C4.76723 8.63229 4.70025 8.58597 4.64465 8.52767L2.70076 6.55521C2.64173 6.49997 2.59474 6.43321 2.56257 6.35906C2.5304 6.28491 2.51367 6.20495 2.51367 6.12412C2.51367 6.0433 2.5304 5.96334 2.56257 5.88919C2.59474 5.81503 2.64173 5.74827 2.70076 5.69303C2.75596 5.63496 2.82243 5.58871 2.89607 5.55711C2.96971 5.52551 3.04904 5.50921 3.12918 5.50921C3.20932 5.50921 3.2885 5.52551 3.36214 5.55711C3.43578 5.58871 3.50225 5.63496 3.55745 5.69303L5.02272 7.1812L8.04198 3.50208C8.09133 3.43834 8.15314 3.38537 8.22373 3.34644C8.29433 3.3075 8.37226 3.28343 8.45251 3.27568C8.53277 3.26794 8.61363 3.2767 8.69038 3.30142C8.76712 3.32613 8.83804 3.36627 8.89867 3.41939C8.96243 3.46871 9.0155 3.53057 9.05446 3.60113C9.09341 3.67169 9.11739 3.74947 9.12514 3.82968C9.13289 3.9099 9.12419 3.99084 9.09946 4.06754C9.07474 4.14425 9.03461 4.21509 8.98147 4.2757L5.53682 8.4745C5.48369 8.54182 5.41645 8.59676 5.33992 8.63552C5.2634 8.67427 5.17943 8.69591 5.09369 8.69892L5.07595 8.71074Z"
354
- fill="#7ED321"
355
- />
356
- <path
357
- d="M6.00303 12C4.41143 11.9984 2.8854 11.3658 1.75997 10.2409C0.634541 9.11601 0.00156423 7.5908 0 5.99998C0.00156423 4.40916 0.634541 2.88395 1.75997 1.75907C2.8854 0.634194 4.41143 0.00156346 6.00303 0C7.5936 0.00312568 9.11804 0.636454 10.2422 1.76116C11.3663 2.88587 11.9984 4.41018 12 5.99998C11.9984 7.58978 11.3663 9.11413 10.2422 10.2388C9.11804 11.3635 7.5936 11.9969 6.00303 12ZM6.00303 0.885826C4.64648 0.887389 3.34595 1.4267 2.38673 2.38545C1.4275 3.34421 0.887824 4.6441 0.88626 5.99998C0.88626 7.35634 1.42544 8.65715 2.385 9.61624C3.34456 10.5753 4.646 11.1142 6.00303 11.1142C7.35903 11.1126 8.65888 10.5731 9.61717 9.61415C10.5755 8.65523 11.1137 7.35532 11.1137 5.99998C11.1122 4.64512 10.5734 3.34613 9.61543 2.38754C8.65749 1.42896 7.35855 0.888951 6.00303 0.885826Z"
358
- fill="#7ED321"
359
- />
360
- </svg>`}
361
- ${selectedAuth &&
362
- !isSelectedAuthVerified &&
363
- html`<svg
364
- data-hint="Could not authorize"
365
- width="12"
366
- height="12"
367
- viewBox="0 0 12 12"
368
- fill="none"
369
- xmlns="http://www.w3.org/2000/svg"
370
- >
371
- <path
372
- d="M5.99833 0.891429C6.08866 0.891429 6.31281 0.918857 6.43659 1.16571L11.0702 10.3749C11.1839 10.6011 11.0969 10.7966 11.0535 10.8686C11.01 10.9406 10.8828 11.112 10.6319 11.112H1.36474C1.11382 11.112 0.986692 10.944 0.9432 10.8686C0.899708 10.7966 0.812723 10.6011 0.926472 10.3749L5.56006 1.16571C5.68385 0.918857 5.908 0.891429 5.99833 0.891429ZM5.99833 0C5.51991 0 5.0415 0.250286 4.78724 0.754286L0.15365 9.96343C-0.314727 10.8926 0.344346 12 1.36474 12H10.6353C11.6557 12 12.3147 10.8926 11.8464 9.96343L7.20942 0.754286C6.95515 0.250286 6.47674 0 5.99833 0Z"
373
- fill="#F05C42"
374
- />
375
- <path
376
- d="M5.99494 8.71924C5.83435 8.71924 5.70053 8.77752 5.59013 8.89067C5.47973 9.00381 5.42285 9.14095 5.42285 9.3021C5.42285 9.48724 5.47973 9.63124 5.59682 9.7341C5.71391 9.83695 5.84774 9.88838 6.00163 9.88838C6.15553 9.88838 6.286 9.83695 6.4031 9.73067C6.51685 9.62781 6.57372 9.48381 6.57372 9.3021C6.57372 9.14095 6.51685 9.00381 6.4031 8.89067C6.29269 8.7741 6.15553 8.71924 5.99494 8.71924Z"
377
- fill="#F05C42"
378
- />
379
- <path
380
- d="M5.99923 3.9668C5.68474 3.9668 5.43048 4.23423 5.44386 4.55651L5.54423 7.57708C5.55092 7.8308 5.755 8.03308 6.00257 8.03308C6.25014 8.03308 6.45422 7.8308 6.46091 7.57708L6.55793 4.55651C6.56797 4.23423 6.31371 3.9668 5.99923 3.9668Z"
381
- fill="#F05C42"
382
- />
383
- </svg>`}
384
- `}
385
- </div>`}
386
- </p>
387
- ${selectedAuth &&
388
- !isSelectedAuthVerified &&
389
- !false &&
390
- html` <span
391
- style="margin-left: 0px;margin-right: 4px;display: flex;
392
- flex-direction: row;
393
- align-items: center;
394
- justify-content: center;
395
- visibility: hidden;"
396
- >Reconnect</span
397
- >`}
398
- <svg
399
- class=${styles.accountFieldDropdownIcon}
400
- style="${showAuthPopup ? 'transform: rotate(180deg);' : ''}"
401
- width="20"
402
- height="20"
403
- viewBox="0 0 20 20"
404
- fill="none"
405
- xmlns="http://www.w3.org/2000/svg"
406
- >
407
- <path
408
- d="M15 8L10 13L5 8"
409
- stroke="#999999"
410
- stroke-width="2"
411
- stroke-linecap="round"
412
- />
413
- </svg>
414
- </div>
415
- <div
416
- style=${showAuthPopup && allowMultipleAccounts
417
- ? 'display:block;'
418
- : 'display:none;'}
419
- class=${styles.authWrapDropdown}
420
- ref=${authPopoverRef}
421
- >
422
- ${true &&
423
- html`<${AuthSelectorDropdown}
424
- appId=${props?.appData?.id}
425
- appData=${props?.appData}
426
- apiHandler=${context ? context?.apiHandler : null}
427
- showErrors=${false}
428
- closePopup=${() => {
429
- setShowAuthPopup(false);
430
- }}
431
- onAuthSelected=${(
432
- authId: number,
433
- isVerified: boolean,
434
- override: boolean,
435
- ) => handleAuthSelected(authId, 0, isVerified, override)}
436
- }
437
- onAuthDeleted=${(authId: number, appId: number) =>
438
- onAuthDelete(authId, appId)}
439
- }
440
- showPopup=${showAuthPopup}
441
- onNextButtonClick=${() => {
442
- setShowAuthPopup(false);
443
- }}
444
- authWindowSwitch="false"
445
- autoSelectAuth=${true}
446
- onNewAccountAdded=${handleNewAccountAdded}
447
- selectedAuth=${selectedAuth}
448
- authorizations=${authorizations}
449
- authPopoverRef=${authPopoverRef}
450
- authPopoverCtaRef=${authPopoverCtaRef}
451
- setShowAuthPopup=${(state: boolean) => {
452
- setShowAuthPopup(state);
453
- }}
454
- >
455
- <//>`}
456
- </div>
457
- <//>`}
458
- ${allowMultipleAccounts
459
- ? html``
460
- : html` ${!false &&
461
- html`
462
- <div
463
- style="
464
- display: flex;
465
- flex-direction: row;
466
- align-items: center;
467
- justify-content: ${
468
- selectedAuth && !isSelectedAuthVerified
469
- ? 'flex-end'
470
- : 'flex-start'
471
- };
472
- margin-left: ${
473
- selectedAuth && !isSelectedAuthVerified ? 'auto' : '5px'
474
- };"
475
- >
476
- ${
477
- selectedAuth &&
478
- !isSelectedAuthVerified &&
479
- html` <span
480
- style="margin-left: 0px;margin-right: 4px;display: flex;
481
- flex-direction: row;
482
- align-items: center;
483
- justify-content: center;
484
- margin-top: -2px;
485
- visibility: hidden;"
486
- >Reconnect</span
487
- >`
488
- }
489
- <span
490
- style="${
491
- false
492
- ? 'opacity:0.5;cursor:not-allowed;border-bottom:none; margin-top: -1.5px;'
493
- : 'border-bottom:none; margin-top: -1.5px;'
494
- }"
495
-
496
- class=${
497
- false ? 'deleteAuthIconError' : 'deleteAuthIcon'
498
- }
499
- >
500
- ${
501
- selectedAuth &&
502
- html` <${Hint}
503
- dismissOnClick=${true}
504
- position=${'bottom-right'}
505
- className=${styles.deleteIconTooltip}
506
- >
507
- <svg
508
- style=${selectedAuth && !isSelectedAuthVerified
509
- ? 'visibility: visible;'
510
- : ''}
511
- data-hint="Disconnect"
512
- width="13"
513
- height="13"
514
- viewBox="0 0 13 13"
515
- fill="none"
516
- xmlns="http://www.w3.org/2000/svg"
517
- >
518
- <path
519
- d="M0.866211 3.46654H12.1329"
520
- stroke="#F05C42"
521
- stroke-width="1.4"
522
- />
523
- <path
524
- d="M9.95091 4.7666V5.34438L9.37313 11.6999H3.59536L3.01758 5.34438V4.7666"
525
- stroke="#F05C42"
526
- stroke-width="1.4"
527
- stroke-linejoin="round"
528
- />
529
- <path
530
- d="M4.75098 3.03314V1.87758C4.75098 1.55848 5.00966 1.2998 5.32875 1.2998H7.63987C7.95896 1.2998 8.21764 1.55848 8.21764 1.87758V3.03314"
531
- stroke="#F05C42"
532
- stroke-width="1.4"
533
- />
534
- </svg>
535
- <//>`
536
- }
537
- </span>
538
- </div>
539
- </div>`}`}
540
- </div>
541
-
542
- ${showDeleteConfirmation &&
543
- html` <${Modal} isOpen=${true} className=${'authConfirmation'}>
544
- <div class=${styles.confirmation}>
545
- <div class=${styles.confirmationHeading}>
546
- <svg
547
- width="22"
548
- height="22"
549
- viewBox="0 0 22 22"
550
- fill="none"
551
- xmlns="http://www.w3.org/2000/svg"
552
- >
553
- <path
554
- d="M10.9969 1.63429C11.1625 1.63429 11.5735 1.68457 11.8004 2.13714L20.2953 19.0206C20.5039 19.4354 20.3444 19.7937 20.2647 19.9257C20.1849 20.0577 19.9519 20.372 19.4918 20.372H2.50202C2.04201 20.372 1.80894 20.064 1.7292 19.9257C1.64946 19.7937 1.48999 19.4354 1.69853 19.0206L10.1934 2.13714C10.4204 1.68457 10.8313 1.63429 10.9969 1.63429ZM10.9969 0C10.1198 0 9.24275 0.458857 8.7766 1.38286L0.281691 18.2663C-0.577 19.9697 0.631301 22 2.50202 22H19.498C21.3687 22 22.577 19.9697 21.7183 18.2663L13.2173 1.38286C12.7511 0.458857 11.874 0 10.9969 0Z"
555
- fill="#F05C42"
556
- />
557
- <path
558
- d="M10.9941 15.6943C10.6997 15.6943 10.4544 15.8012 10.252 16.0086C10.0496 16.2161 9.94531 16.4675 9.94531 16.7629C9.94531 17.1023 10.0496 17.3663 10.2643 17.5549C10.4789 17.7435 10.7243 17.8378 11.0064 17.8378C11.2886 17.8378 11.5278 17.7435 11.7424 17.5486C11.951 17.36 12.0552 17.096 12.0552 16.7629C12.0552 16.4675 11.951 16.2161 11.7424 16.0086C11.54 15.7949 11.2886 15.6943 10.9941 15.6943Z"
559
- fill="#F05C42"
560
- />
561
- <path
562
- d="M11.0074 7.65039C10.4308 7.65039 9.96467 8.14068 9.98921 8.73153L10.167 13.6023C10.1793 14.0675 10.5534 14.4383 11.0073 14.4383C11.4612 14.4383 11.8353 14.0675 11.8476 13.6023L12.0317 8.73153C12.0501 8.14068 11.5839 7.65039 11.0074 7.65039Z"
563
- fill="#F05C42"
564
- />
565
- </svg>
566
- Disconnect account
567
- </div>
568
- <div class=${styles.confirmationDescription}>
569
- <p>
570
- Disconnecting your account will delete all integration instances.
571
- This action cannot be undone.
572
- </p>
573
- <p>Are you sure?</p>
574
- </div>
575
- <div class=${styles.confirmationActions}>
576
- <button
577
- class=${styles.secondaryCTA}
578
- onclick=${(e: any) => {
579
- e.stopPropagation();
580
- setShowDeleteConfirmation(false);
581
- }}
582
- >
583
- Cancel
584
- </button>
585
- <button
586
- class=${styles.primaryCTA}
587
- onclick=${(e: any) => {
588
- e.stopPropagation();
589
- deleteAuth(selectedAuth?.id);
590
- setShowDeleteConfirmation(false);
591
- }}
592
- >
593
- Disconnect
594
- </button>
595
- </div>
596
- </div>
597
- <//>`}
598
- `;
599
- };
600
-
601
- export default connect<unknown, unknown, StoreType, unknown>(
602
- [
603
- 'userConfig',
604
- 'genericData',
605
- 'embedConfig',
606
- 'stepMapping',
607
- 'selectedAuthByAppId',
608
- ],
609
- actionFunctions,
610
- )(Authentication);