@tap-payments/auth-jsconnect 2.13.9-beta → 2.14.0-beta

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 (148) hide show
  1. package/build/@types/app.d.ts +2 -1
  2. package/build/@types/app.js +1 -0
  3. package/build/@types/index.d.ts +1 -0
  4. package/build/@types/index.js +1 -0
  5. package/build/@types/terminal.d.ts +104 -0
  6. package/build/@types/terminal.js +1 -0
  7. package/build/api/auth.d.ts +15 -1
  8. package/build/api/index.d.ts +7 -1
  9. package/build/api/index.js +3 -1
  10. package/build/api/terminal.d.ts +25 -0
  11. package/build/api/terminal.js +55 -0
  12. package/build/app/rootReducer.d.ts +1 -0
  13. package/build/app/rootReducer.js +3 -1
  14. package/build/app/store.d.ts +2 -0
  15. package/build/assets/locales/en.json +0 -1
  16. package/build/components/DeviceCard/DeviceCard.d.ts +19 -0
  17. package/build/components/DeviceCard/DeviceCard.js +102 -0
  18. package/build/components/DeviceCard/index.d.ts +3 -0
  19. package/build/components/DeviceCard/index.js +2 -0
  20. package/build/components/OTPTimer/OTPTimer.d.ts +2 -1
  21. package/build/components/OTPTimer/OTPTimer.js +4 -4
  22. package/build/components/TruncatedTooltipText/TruncatedTooltipText.d.ts +7 -0
  23. package/build/components/TruncatedTooltipText/TruncatedTooltipText.js +33 -0
  24. package/build/components/TruncatedTooltipText/index.d.ts +2 -0
  25. package/build/components/TruncatedTooltipText/index.js +2 -0
  26. package/build/constants/app.d.ts +12 -1
  27. package/build/constants/app.js +133 -0
  28. package/build/constants/flows.d.ts +16 -0
  29. package/build/constants/flows.js +16 -0
  30. package/build/constants/validation.d.ts +1 -0
  31. package/build/constants/validation.js +1 -0
  32. package/build/features/app/terminal/terminalStore.d.ts +110 -0
  33. package/build/features/app/terminal/terminalStore.js +703 -0
  34. package/build/features/auth/screens/AuthenticationList/AuthenticationList.js +10 -7
  35. package/build/features/auth/screens/AuthenticationList/EntityLicenseType.d.ts +4 -1
  36. package/build/features/auth/screens/AuthenticationList/EntityLicenseType.js +6 -4
  37. package/build/features/auth/screens/AuthenticationList/EntityList.js +9 -1
  38. package/build/features/business/screens/BusinessType/BusinessType.js +2 -3
  39. package/build/features/business/screens/BusinessType/LicenseList.js +5 -5
  40. package/build/features/connectExpress/screens/AuthenticationList/AuthenticationList.js +10 -10
  41. package/build/features/connectExpress/screens/AuthenticationList/EntityLicenseType.d.ts +4 -1
  42. package/build/features/connectExpress/screens/AuthenticationList/EntityLicenseType.js +6 -4
  43. package/build/features/connectExpress/screens/AuthenticationList/EntityList.js +9 -1
  44. package/build/features/connectExpress/screens/CollectBusinessInfo/LicenseList.js +6 -11
  45. package/build/features/connectExpress/screens/Mobile/Mobile.js +7 -6
  46. package/build/features/featuresScreens.d.ts +1 -0
  47. package/build/features/featuresScreens.js +72 -0
  48. package/build/features/shared/Button/Button.js +1 -1
  49. package/build/features/shared/Button/FlowsButtons.d.ts +1 -0
  50. package/build/features/shared/Button/FlowsButtons.js +2 -2
  51. package/build/features/shared/PushNotification/PushNotification.d.ts +11 -0
  52. package/build/features/shared/PushNotification/PushNotification.js +34 -0
  53. package/build/features/shared/PushNotification/index.d.ts +2 -0
  54. package/build/features/shared/PushNotification/index.js +2 -0
  55. package/build/features/shared/SuccessFlowButtons/SuccessFlowButtons.d.ts +2 -1
  56. package/build/features/shared/SuccessFlowButtons/SuccessFlowButtons.js +5 -4
  57. package/build/features/shared/SuccessScreen/SuccessScreen.d.ts +3 -1
  58. package/build/features/shared/SuccessScreen/SuccessScreen.js +2 -2
  59. package/build/features/terminal/Terminal.d.ts +14 -0
  60. package/build/features/terminal/Terminal.js +95 -0
  61. package/build/features/terminal/index.d.ts +1 -0
  62. package/build/features/terminal/index.js +1 -0
  63. package/build/features/terminal/screens/LinkNewTerminal/LinkNewTerminal.d.ts +3 -0
  64. package/build/features/terminal/screens/LinkNewTerminal/LinkNewTerminal.js +68 -0
  65. package/build/features/terminal/screens/LinkNewTerminal/index.d.ts +2 -0
  66. package/build/features/terminal/screens/LinkNewTerminal/index.js +2 -0
  67. package/build/features/terminal/screens/LinkNewTerminal/styles.d.ts +10 -0
  68. package/build/features/terminal/screens/LinkNewTerminal/styles.js +28 -0
  69. package/build/features/terminal/screens/LinkedSuccess/LinkedSuccess.d.ts +3 -0
  70. package/build/features/terminal/screens/LinkedSuccess/LinkedSuccess.js +50 -0
  71. package/build/features/terminal/screens/LinkedSuccess/index.d.ts +2 -0
  72. package/build/features/terminal/screens/LinkedSuccess/index.js +2 -0
  73. package/build/features/terminal/screens/LinkedTerminalInfo/LinkedTerminalInfo.d.ts +3 -0
  74. package/build/features/terminal/screens/LinkedTerminalInfo/LinkedTerminalInfo.js +55 -0
  75. package/build/features/terminal/screens/LinkedTerminalInfo/index.d.ts +2 -0
  76. package/build/features/terminal/screens/LinkedTerminalInfo/index.js +2 -0
  77. package/build/features/terminal/screens/Loading/Loading.d.ts +4 -0
  78. package/build/features/terminal/screens/Loading/Loading.js +10 -0
  79. package/build/features/terminal/screens/Loading/index.d.ts +2 -0
  80. package/build/features/terminal/screens/Loading/index.js +2 -0
  81. package/build/features/terminal/screens/NoTerminalDeviceLinked/NoTerminalDeviceLinked.d.ts +3 -0
  82. package/build/features/terminal/screens/NoTerminalDeviceLinked/NoTerminalDeviceLinked.js +103 -0
  83. package/build/features/terminal/screens/NoTerminalDeviceLinked/index.d.ts +2 -0
  84. package/build/features/terminal/screens/NoTerminalDeviceLinked/index.js +2 -0
  85. package/build/features/terminal/screens/NoTerminalDeviceLinked/styles.d.ts +36 -0
  86. package/build/features/terminal/screens/NoTerminalDeviceLinked/styles.js +34 -0
  87. package/build/features/terminal/screens/OperatorError/OperatorError.d.ts +5 -0
  88. package/build/features/terminal/screens/OperatorError/OperatorError.js +9 -0
  89. package/build/features/terminal/screens/OperatorError/index.d.ts +2 -0
  90. package/build/features/terminal/screens/OperatorError/index.js +2 -0
  91. package/build/features/terminal/screens/POSDeviceListPage/POSDeviceListPage.d.ts +3 -0
  92. package/build/features/terminal/screens/POSDeviceListPage/POSDeviceListPage.js +50 -0
  93. package/build/features/terminal/screens/POSDeviceListPage/index.d.ts +2 -0
  94. package/build/features/terminal/screens/POSDeviceListPage/index.js +2 -0
  95. package/build/features/terminal/screens/ResetPasswordSuccess/ResetPasswordSuccess.d.ts +3 -0
  96. package/build/features/terminal/screens/ResetPasswordSuccess/ResetPasswordSuccess.js +21 -0
  97. package/build/features/terminal/screens/ResetPasswordSuccess/index.d.ts +2 -0
  98. package/build/features/terminal/screens/ResetPasswordSuccess/index.js +2 -0
  99. package/build/features/terminal/screens/SuccessWithFlowButtons/SuccessWithFlowButtons.d.ts +3 -0
  100. package/build/features/terminal/screens/SuccessWithFlowButtons/SuccessWithFlowButtons.js +32 -0
  101. package/build/features/terminal/screens/SuccessWithFlowButtons/index.d.ts +2 -0
  102. package/build/features/terminal/screens/SuccessWithFlowButtons/index.js +2 -0
  103. package/build/features/terminal/screens/TerminalDeviceList/DeviceList.d.ts +9 -0
  104. package/build/features/terminal/screens/TerminalDeviceList/DeviceList.js +20 -0
  105. package/build/features/terminal/screens/TerminalDeviceList/TerminalDeviceList.d.ts +3 -0
  106. package/build/features/terminal/screens/TerminalDeviceList/TerminalDeviceList.js +153 -0
  107. package/build/features/terminal/screens/TerminalDeviceList/index.d.ts +2 -0
  108. package/build/features/terminal/screens/TerminalDeviceList/index.js +2 -0
  109. package/build/features/terminal/screens/TerminalDeviceList/styles.d.ts +9 -0
  110. package/build/features/terminal/screens/TerminalDeviceList/styles.js +13 -0
  111. package/build/features/terminal/screens/UnlinkedSuccess/UnlinkedSuccess.d.ts +3 -0
  112. package/build/features/terminal/screens/UnlinkedSuccess/UnlinkedSuccess.js +51 -0
  113. package/build/features/terminal/screens/UnlinkedSuccess/index.d.ts +2 -0
  114. package/build/features/terminal/screens/UnlinkedSuccess/index.js +2 -0
  115. package/build/features/terminal/screens/UnlinkedTerminalInfo/UnlinkedTerminalInfo.d.ts +3 -0
  116. package/build/features/terminal/screens/UnlinkedTerminalInfo/UnlinkedTerminalInfo.js +99 -0
  117. package/build/features/terminal/screens/UnlinkedTerminalInfo/index.d.ts +2 -0
  118. package/build/features/terminal/screens/UnlinkedTerminalInfo/index.js +2 -0
  119. package/build/features/terminal/screens/UnlinkedTerminalInfo/styles.d.ts +26 -0
  120. package/build/features/terminal/screens/UnlinkedTerminalInfo/styles.js +30 -0
  121. package/build/features/terminal/screens/Verify/OTPInput.d.ts +7 -0
  122. package/build/features/terminal/screens/Verify/OTPInput.js +51 -0
  123. package/build/features/terminal/screens/Verify/Verify.d.ts +5 -0
  124. package/build/features/terminal/screens/Verify/Verify.js +89 -0
  125. package/build/features/terminal/screens/Verify/index.d.ts +2 -0
  126. package/build/features/terminal/screens/Verify/index.js +2 -0
  127. package/build/features/terminal/screens/Verify/validation.d.ts +8 -0
  128. package/build/features/terminal/screens/Verify/validation.js +4 -0
  129. package/build/features/terminal/screens/shared/Header.d.ts +10 -0
  130. package/build/features/terminal/screens/shared/Header.js +30 -0
  131. package/build/features/terminal/screens/shared/POSDeviceList.d.ts +11 -0
  132. package/build/features/terminal/screens/shared/POSDeviceList.js +30 -0
  133. package/build/features/terminal/screens/shared/index.d.ts +5 -0
  134. package/build/features/terminal/screens/shared/index.js +5 -0
  135. package/build/features/terminal/screens/shared/styles.d.ts +196 -0
  136. package/build/features/terminal/screens/shared/styles.js +155 -0
  137. package/build/features/terminal/screens/shared/utils.d.ts +7 -0
  138. package/build/features/terminal/screens/shared/utils.js +24 -0
  139. package/build/hooks/useAppDispatch.d.ts +1 -0
  140. package/build/index.d.ts +3 -2
  141. package/build/index.js +4 -2
  142. package/build/theme/palette.js +12 -0
  143. package/build/theme/typography.js +4 -0
  144. package/build/utils/error.d.ts +1 -0
  145. package/build/utils/error.js +3 -0
  146. package/build/utils/string.d.ts +2 -1
  147. package/build/utils/string.js +11 -2
  148. package/package.json +1 -1
@@ -0,0 +1,51 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import * as React from 'react';
14
+ import { useTranslation } from 'react-i18next';
15
+ import Box from '@mui/material/Box';
16
+ import { useAppDispatch, useAppSelector, useLanguage } from '../../../../hooks';
17
+ import { CONNECT_FLOWS } from '../../../../constants';
18
+ import { handleNextScreenStep, handlePrevScreenStep } from '../../../../app/settings';
19
+ import { retrieveBoardDetails, retrieveBoardStatus, retrieveTerminalList, terminalSelector } from '../../../app/terminal/terminalStore';
20
+ import SuccessScreen from '../../../shared/SuccessScreen';
21
+ import Button from '../../../shared/Button';
22
+ import { SuccessContainerStyled } from '../shared';
23
+ var UnlinkedSuccess = function () {
24
+ var t = useTranslation().t;
25
+ var isAr = useLanguage().isAr;
26
+ var dispatch = useAppDispatch();
27
+ var _a = useAppSelector(terminalSelector), error = _a.error, loading = _a.loading, _b = _a.data, device = _b.terminalInfo.selectedTerminal.device, responseData = _b.responseData;
28
+ var _c = responseData || {}, boardData = _c.boardData, authData = _c.authData;
29
+ var deviceName = device === null || device === void 0 ? void 0 : device.display_name;
30
+ var handleGoToBoard = function () {
31
+ var board_id = (boardData || {}).id;
32
+ var _a = (authData === null || authData === void 0 ? void 0 : authData.recipient) || {}, id = _a.id, type = _a.type;
33
+ dispatch(retrieveTerminalList());
34
+ dispatch(retrieveBoardStatus({ boardId: board_id }))
35
+ .unwrap()
36
+ .then(function () {
37
+ dispatch(retrieveBoardDetails({ boardId: board_id, individualId: id, individualType: type }))
38
+ .unwrap()
39
+ .then(function () {
40
+ dispatch(handleNextScreenStep(CONNECT_FLOWS.terminal.board));
41
+ })
42
+ .catch(function () { });
43
+ })
44
+ .catch(function () { });
45
+ };
46
+ var handleOnBack = function () {
47
+ dispatch(handlePrevScreenStep());
48
+ };
49
+ return (_jsxs(SuccessContainerStyled, { children: [_jsx(SuccessScreen, { sx: { minHeight: 'unset', ml: 2.5, mr: 2.5 }, title: t('terminal_unlinked_success', { device: deviceName }), successTitle: t('terminal_go_to_board'), loading: loading, error: error || '' }), _jsx(Box, __assign({ sx: { width: '100%' } }, { children: _jsx(Button, __assign({ loading: loading, disableBack: true, onBackClicked: handleOnBack, onClick: handleGoToBoard, isAr: isAr }, { children: t('terminal_go_to_board') })) }))] }));
50
+ };
51
+ export default React.memo(UnlinkedSuccess);
@@ -0,0 +1,2 @@
1
+ import UnlinkedSuccess from './UnlinkedSuccess';
2
+ export default UnlinkedSuccess;
@@ -0,0 +1,2 @@
1
+ import UnlinkedSuccess from './UnlinkedSuccess';
2
+ export default UnlinkedSuccess;
@@ -0,0 +1,3 @@
1
+ import * as React from 'react';
2
+ declare const _default: React.MemoExoticComponent<() => JSX.Element>;
3
+ export default _default;
@@ -0,0 +1,99 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import * as React from 'react';
14
+ import { useTranslation } from 'react-i18next';
15
+ import { useTheme } from '@mui/material/styles';
16
+ import Box from '@mui/material/Box';
17
+ import { CONNECT_FLOWS, DEFAULT_TIMER_VALUE, ICONS_NAMES, TERMINAL_PUSH_NOTIFICATION_DURATION } from '../../../../constants';
18
+ import { useAppDispatch, useAppSelector, useLanguage } from '../../../../hooks';
19
+ import { handleNextScreenStep, handlePrevScreenStep } from '../../../../app/settings';
20
+ import { ScreenContainer } from '../../../shared/Containers';
21
+ import DeviceCard from '../../../../components/DeviceCard';
22
+ import OTPTimer from '../../../../components/OTPTimer';
23
+ import Collapse from '../../../../components/Collapse';
24
+ import { clearError, linkTerminalDevice, pushNotificationLinkNewTerminal, storeSelectedPOS, terminalSelector } from '../../../app/terminal/terminalStore';
25
+ import PushNotification from '../../../shared/PushNotification';
26
+ import Button from '../../../shared/Button';
27
+ import { Container, getId, getIdLabel, LinkWithText } from '../shared';
28
+ import { SendRequestContainer } from './styles';
29
+ import { POSDeviceList } from '../shared';
30
+ var UnlinkedTerminalInfo = function () {
31
+ var t = useTranslation().t;
32
+ var typography = useTheme().typography;
33
+ var dispatch = useAppDispatch();
34
+ var isAr = useLanguage().isAr;
35
+ var _a = React.useState(false), isRequestSent = _a[0], setIsRequestSent = _a[1];
36
+ var _b = React.useState(false), isReady = _b[0], setIsReady = _b[1];
37
+ var _c = React.useState(false), success = _c[0], setSuccess = _c[1];
38
+ var _d = React.useState(false), failed = _d[0], setFailed = _d[1];
39
+ var _e = useAppSelector(terminalSelector), data = _e.data, error = _e.error;
40
+ var _f = data.terminalInfo, selectedTerminal = _f.selectedTerminal, selectedPOS = _f.selectedPOS, responseData = data.responseData;
41
+ var _g = responseData || {}, linkTerminalDeviceData = _g.linkTerminalDeviceData, posDevices = _g.posDevices;
42
+ var terminal_device = selectedTerminal.terminal_device, linked = selectedTerminal.linked;
43
+ var _h = ((terminal_device === null || terminal_device === void 0 ? void 0 : terminal_device.model) || {}).image_url, image_url = _h === void 0 ? ICONS_NAMES.device_image : _h;
44
+ var displayName = (terminal_device === null || terminal_device === void 0 ? void 0 : terminal_device.display_name) || '';
45
+ var expiry = TERMINAL_PUSH_NOTIFICATION_DURATION;
46
+ var newTerminal = false;
47
+ React.useEffect(function () {
48
+ if (linkTerminalDeviceData && !isReady) {
49
+ setIsReady(true);
50
+ }
51
+ }, [linkTerminalDeviceData]);
52
+ React.useEffect(function () {
53
+ if (!isReady)
54
+ return;
55
+ var promise = dispatch(pushNotificationLinkNewTerminal({ newTerminal: newTerminal, onSuccess: function () { return setSuccess(true); }, onFailure: function () { return setFailed(true); } }));
56
+ promise
57
+ .unwrap()
58
+ .then(function (_a) {
59
+ var nextScreen = _a.nextScreen;
60
+ if (nextScreen)
61
+ dispatch(handleNextScreenStep(nextScreen));
62
+ })
63
+ .catch(function () { });
64
+ return function () {
65
+ promise === null || promise === void 0 ? void 0 : promise.abort();
66
+ };
67
+ }, [isReady]);
68
+ var getRequestSendDescription = function () {
69
+ if (error)
70
+ return t('terminal_request_denied', { device: displayName });
71
+ if (isRequestSent)
72
+ return t('terminal_new_request_will_send');
73
+ return t('terminal_request_will_send');
74
+ };
75
+ var handleOnSendRequest = function () {
76
+ setIsRequestSent(true);
77
+ handleOnResendClick();
78
+ };
79
+ var handleOnBack = function () {
80
+ if (error)
81
+ dispatch(clearError());
82
+ dispatch(handlePrevScreenStep(CONNECT_FLOWS.terminal.terminalDeviceList));
83
+ };
84
+ var handleOnSelectPOS = function (pos) {
85
+ if (error)
86
+ dispatch(clearError());
87
+ dispatch(storeSelectedPOS(pos));
88
+ };
89
+ var handleOnResendClick = function () {
90
+ if (isReady)
91
+ setIsReady(false);
92
+ if (failed)
93
+ setFailed(false);
94
+ dispatch(linkTerminalDevice());
95
+ };
96
+ var disabled = !(selectedPOS === null || selectedPOS === void 0 ? void 0 : selectedPOS.id) || isRequestSent;
97
+ return (_jsxs(ScreenContainer, __assign({ minHeight: 224, justifyContent: 'space-between' }, { children: [_jsx(PushNotification, __assign({ error: t('terminal_request_denied', { device: displayName }), failed: failed, success: success, expiryInSeconds: expiry }, { children: _jsxs(Container, { children: [_jsxs(Box, __assign({ sx: { ml: 2.5, mr: 2.5 } }, { children: [_jsx(LinkWithText, { children: "".concat(t('terminal_link'), " ").concat(displayName) }), _jsx(DeviceCard, { image: image_url, name: displayName, deviceId: getId(selectedTerminal), deviceIdLabel: getIdLabel(selectedTerminal), isLinked: linked }), _jsx(LinkWithText, { children: t('terminal_with') }), _jsx(POSDeviceList, { selectedPOS: selectedPOS, posDevices: posDevices, onClick: handleOnSelectPOS })] })), _jsxs(SendRequestContainer, __assign({ hasError: !!error, sx: __assign(__assign({}, typography.button_small), { fontWeight: typography.fontWeightRegular, mt: 2 }) }, { children: [getRequestSendDescription(), _jsx(Collapse, __assign({ in: isRequestSent && !error }, { children: _jsx(OTPTimer, { timeEndLabel: t('terminal_resend_request'), failed: failed, timeInSeconds: DEFAULT_TIMER_VALUE, onResetClick: handleOnResendClick }) }))] }))] }) })), _jsx(Button, __assign({ sx: { ml: 2.5, mr: 2.5, mt: 2 }, disabled: disabled, onBackClicked: handleOnBack, onClick: handleOnSendRequest, isAr: isAr }, { children: t('terminal_send_link_request') }))] })));
98
+ };
99
+ export default React.memo(UnlinkedTerminalInfo);
@@ -0,0 +1,2 @@
1
+ import UnlinkedTerminalInfo from './UnlinkedTerminalInfo';
2
+ export default UnlinkedTerminalInfo;
@@ -0,0 +1,2 @@
1
+ import UnlinkedTerminalInfo from './UnlinkedTerminalInfo';
2
+ export default UnlinkedTerminalInfo;
@@ -0,0 +1,26 @@
1
+ /// <reference types="react" />
2
+ export declare const ResendText: import("@emotion/styled").StyledComponent<import("@mui/system").SystemProps<import("@mui/material/styles").Theme> & {
3
+ align?: "left" | "right" | "inherit" | "center" | "justify" | undefined;
4
+ children?: import("react").ReactNode;
5
+ classes?: Partial<import("@mui/material/Typography").TypographyClasses> | undefined;
6
+ gutterBottom?: boolean | undefined;
7
+ noWrap?: boolean | undefined;
8
+ paragraph?: boolean | undefined;
9
+ sx?: import("@mui/material/styles").SxProps<import("@mui/material/styles").Theme> | undefined;
10
+ variant?: "button" | "caption" | "h1" | "h2" | "h3" | "h4" | "h5" | "h6" | "inherit" | "subtitle1" | "subtitle2" | "body1" | "body2" | "overline" | undefined;
11
+ variantMapping?: Partial<Record<"button" | "caption" | "h1" | "h2" | "h3" | "h4" | "h5" | "h6" | "inherit" | "subtitle1" | "subtitle2" | "body1" | "body2" | "overline", string>> | undefined;
12
+ } & import("@mui/material/OverridableComponent").CommonProps & Omit<Pick<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, "key" | keyof import("react").HTMLAttributes<HTMLSpanElement>> & {
13
+ ref?: ((instance: HTMLSpanElement | null) => void) | import("react").RefObject<HTMLSpanElement> | null | undefined;
14
+ }, keyof import("@mui/material/OverridableComponent").CommonProps | ("left" | "right" | "border" | "borderTop" | "borderRight" | "borderBottom" | "borderLeft" | "borderColor" | "borderRadius" | "display" | "displayPrint" | "overflow" | "textOverflow" | "visibility" | "whiteSpace" | "flexBasis" | "flexDirection" | "flexWrap" | "justifyContent" | "alignItems" | "alignContent" | "order" | "flex" | "flexGrow" | "flexShrink" | "alignSelf" | "justifyItems" | "justifySelf" | "gap" | "columnGap" | "rowGap" | "gridColumn" | "gridRow" | "gridAutoFlow" | "gridAutoColumns" | "gridAutoRows" | "gridTemplateColumns" | "gridTemplateRows" | "gridTemplateAreas" | "gridArea" | "bgcolor" | "color" | "zIndex" | "position" | "top" | "bottom" | "boxShadow" | "width" | "maxWidth" | "minWidth" | "height" | "maxHeight" | "minHeight" | "boxSizing" | "m" | "mt" | "mr" | "mb" | "ml" | "mx" | "my" | "p" | "pt" | "pr" | "pb" | "pl" | "px" | "py" | "margin" | "marginTop" | "marginRight" | "marginBottom" | "marginLeft" | "marginX" | "marginY" | "padding" | "paddingTop" | "paddingRight" | "paddingBottom" | "paddingLeft" | "paddingX" | "paddingY" | "typography" | "fontFamily" | "fontSize" | "fontStyle" | "fontWeight" | "letterSpacing" | "lineHeight" | "textAlign" | "textTransform") | "children" | "sx" | "variant" | "align" | "gutterBottom" | "noWrap" | "paragraph" | "variantMapping"> & import("@mui/system").MUIStyledCommonProps<import("@mui/material/styles").Theme>, {}, {}>;
15
+ interface SendRequestContainerProps {
16
+ hasError?: boolean;
17
+ }
18
+ export declare const SendRequestContainer: import("@emotion/styled").StyledComponent<import("@mui/system").SystemProps<import("@mui/material/styles").Theme> & {
19
+ children?: import("react").ReactNode;
20
+ component?: import("react").ElementType<any> | undefined;
21
+ ref?: import("react").Ref<unknown> | undefined;
22
+ sx?: import("@mui/material/styles").SxProps<import("@mui/material/styles").Theme> | undefined;
23
+ } & import("@mui/material/OverridableComponent").CommonProps & Omit<Pick<import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, "key" | keyof import("react").HTMLAttributes<HTMLDivElement>> & {
24
+ ref?: ((instance: HTMLDivElement | null) => void) | import("react").RefObject<HTMLDivElement> | null | undefined;
25
+ }, keyof import("@mui/material/OverridableComponent").CommonProps | ("left" | "right" | "border" | "borderTop" | "borderRight" | "borderBottom" | "borderLeft" | "borderColor" | "borderRadius" | "display" | "displayPrint" | "overflow" | "textOverflow" | "visibility" | "whiteSpace" | "flexBasis" | "flexDirection" | "flexWrap" | "justifyContent" | "alignItems" | "alignContent" | "order" | "flex" | "flexGrow" | "flexShrink" | "alignSelf" | "justifyItems" | "justifySelf" | "gap" | "columnGap" | "rowGap" | "gridColumn" | "gridRow" | "gridAutoFlow" | "gridAutoColumns" | "gridAutoRows" | "gridTemplateColumns" | "gridTemplateRows" | "gridTemplateAreas" | "gridArea" | "bgcolor" | "color" | "zIndex" | "position" | "top" | "bottom" | "boxShadow" | "width" | "maxWidth" | "minWidth" | "height" | "maxHeight" | "minHeight" | "boxSizing" | "m" | "mt" | "mr" | "mb" | "ml" | "mx" | "my" | "p" | "pt" | "pr" | "pb" | "pl" | "px" | "py" | "margin" | "marginTop" | "marginRight" | "marginBottom" | "marginLeft" | "marginX" | "marginY" | "padding" | "paddingTop" | "paddingRight" | "paddingBottom" | "paddingLeft" | "paddingX" | "paddingY" | "typography" | "fontFamily" | "fontSize" | "fontStyle" | "fontWeight" | "letterSpacing" | "lineHeight" | "textAlign" | "textTransform") | "children" | "component" | "ref" | "sx"> & import("@mui/system").MUIStyledCommonProps<import("@mui/material/styles").Theme> & SendRequestContainerProps, {}, {}>;
26
+ export {};
@@ -0,0 +1,30 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { alpha, styled } from '@mui/material/styles';
13
+ import Typography from '@mui/material/Typography';
14
+ import Box from '@mui/material/Box';
15
+ export var ResendText = styled(Typography)(function (_a) {
16
+ var _b = _a.theme, palette = _b.palette, typography = _b.typography, spacing = _b.spacing;
17
+ return (__assign(__assign({ cursor: 'pointer', color: palette.primary.main }, typography.caption), { fontWeight: typography.fontWeightRegular, textAlign: 'end', marginTop: spacing(0.75) }));
18
+ });
19
+ export var SendRequestContainer = styled(Box, {
20
+ shouldForwardProp: function (prop) { return !['hasError'].includes(prop.toString()); }
21
+ })(function (_a) {
22
+ var _b = _a.theme, typography = _b.typography, palette = _b.palette, spacing = _b.spacing, hasError = _a.hasError;
23
+ return (__assign(__assign(__assign(__assign({}, typography.button_small), { fontWeight: typography.fontWeightRegular, mt: 2, backgroundColor: palette.common.white, borderWidth: spacing(0.125, 0, 0.125, 0), borderStyle: 'solid', borderColor: palette.divider, padding: spacing(1.5, 2.5, 1.5, 2.5), marginTop: spacing(1), color: palette.text.primary }), typography.body1), (hasError && {
24
+ background: alpha(palette.error.dark, 0.3),
25
+ borderWidth: '1px, 0px, 1px, 0px',
26
+ borderStyle: 'solid',
27
+ borderColor: alpha(palette.error.dark, 0.7),
28
+ color: alpha(palette.error.main, 0.7)
29
+ })));
30
+ });
@@ -0,0 +1,7 @@
1
+ import * as React from 'react';
2
+ export interface OTPProps {
3
+ loading: boolean;
4
+ setLoading: (flag: boolean) => void;
5
+ }
6
+ declare const _default: React.MemoExoticComponent<({ loading }: OTPProps) => JSX.Element>;
7
+ export default _default;
@@ -0,0 +1,51 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx } from "react/jsx-runtime";
13
+ import * as React from 'react';
14
+ import Box from '@mui/material/Box/Box';
15
+ import { styled } from '@mui/material/styles';
16
+ import OTPField from '../../../shared/OTP';
17
+ import { useController, useFormContext } from 'react-hook-form';
18
+ import { useTranslation } from 'react-i18next';
19
+ import { DEFAULT_TIMER_VALUE } from '../../../../constants';
20
+ import { useAppDispatch, useAppSelector } from '../../../../hooks';
21
+ import { isTokenExpired } from '../../../../utils';
22
+ import { clearError, terminalSelector, resendOTP } from '../../../app/terminal/terminalStore';
23
+ var BoxStyled = styled(Box)(function (_a) {
24
+ var theme = _a.theme;
25
+ return ({
26
+ display: 'flex',
27
+ flexDirection: 'column',
28
+ fontFamily: theme.typography.fontFamily
29
+ });
30
+ });
31
+ var OTPInput = function (_a) {
32
+ var loading = _a.loading;
33
+ var _b = useFormContext(), control = _b.control, setValue = _b.setValue;
34
+ var t = useTranslation().t;
35
+ var otpControl = useController({ name: 'otp', control: control });
36
+ var dispatch = useAppDispatch();
37
+ var error = useAppSelector(terminalSelector).error;
38
+ var handleOnOTPChange = function (otp) {
39
+ if (error)
40
+ dispatch(clearError());
41
+ otpControl.field.onChange(otp);
42
+ };
43
+ var handleOnResendOTP = function () {
44
+ if (otpControl.field.value)
45
+ setValue('otp', '', { shouldValidate: true });
46
+ dispatch(resendOTP());
47
+ };
48
+ var otpValue = otpControl.field.value;
49
+ return (_jsx(BoxStyled, __assign({ dir: 'ltr' }, { children: _jsx(OTPField, { loading: loading, timeEndLabel: t('ide_otp_resend_label'), timerInSeconds: DEFAULT_TIMER_VALUE, onResetClick: handleOnResendOTP, value: otpValue, hasError: isTokenExpired(error), onChange: function (number) { return handleOnOTPChange(number.toString()); } }) })));
50
+ };
51
+ export default React.memo(OTPInput);
@@ -0,0 +1,5 @@
1
+ import * as React from 'react';
2
+ export interface OTPProps {
3
+ }
4
+ declare const _default: React.MemoExoticComponent<({}: OTPProps) => JSX.Element>;
5
+ export default _default;
@@ -0,0 +1,89 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import * as React from 'react';
14
+ import { useAppDispatch, useSetFromDefaultValues, useSanitizedTranslation, useLanguage, useAppSelector } from '../../../../hooks';
15
+ import { useTranslation } from 'react-i18next';
16
+ import { useForm, FormProvider } from 'react-hook-form';
17
+ import { yupResolver } from '@hookform/resolvers/yup';
18
+ import Box from '@mui/material/Box/Box';
19
+ import { styled } from '@mui/material/styles';
20
+ import { handleNextScreenStep } from '../../../../app/settings';
21
+ import { deepCopy, isAuthenticationVerificationFailed, maskPhone } from '../../../../utils';
22
+ import Form from '../../../../components/Form';
23
+ import Text from '../../../../components/Text';
24
+ import { ScreenContainer } from '../../../shared/Containers';
25
+ import { terminalSelector, clearError, resetOTPScreen, verifyTokenOTP } from '../../../app/terminal/terminalStore';
26
+ import Button from '../../../shared/Button';
27
+ import { OTPValidation } from './validation';
28
+ import OTPInput from './OTPInput';
29
+ import { CONNECT_FLOWS } from '../../../../constants';
30
+ var OTPTitleContainerStyled = styled(Box)(function (_a) {
31
+ var theme = _a.theme;
32
+ return ({
33
+ background: theme.palette.common.white,
34
+ border: '1px solid',
35
+ borderColor: theme.palette.divider,
36
+ direction: theme.direction,
37
+ borderRadius: theme.spacing(0, 0, 1.25, 1.25),
38
+ marginBottom: theme.spacing(5.75)
39
+ });
40
+ });
41
+ var OTPTitleStyled = styled(Text)(function (_a) {
42
+ var theme = _a.theme;
43
+ return (__assign(__assign({}, theme.typography.body1), { color: theme.palette.text.primary, fontWeight: theme.typography.fontWeightLight, marginBlock: theme.spacing(1.75), marginInlineStart: theme.spacing(2.5), lineHeight: 1.75 }));
44
+ });
45
+ var FormStyled = styled(Form)(function () { return ({
46
+ display: 'flex',
47
+ flexDirection: 'column'
48
+ }); });
49
+ var VerifyNumber = function (_a) {
50
+ var _b, _c, _d;
51
+ var dispatch = useAppDispatch();
52
+ var _e = useAppSelector(terminalSelector), data = _e.data, loading = _e.loading, error = _e.error;
53
+ var otp = data.otpData.otp;
54
+ var methods = useForm({
55
+ resolver: yupResolver(OTPValidation),
56
+ defaultValues: {
57
+ otp: otp
58
+ },
59
+ mode: 'onChange'
60
+ });
61
+ useSetFromDefaultValues(methods, data.otpData);
62
+ var t = useTranslation().t;
63
+ var st = useSanitizedTranslation();
64
+ var isAr = useLanguage().isAr;
65
+ var _f = React.useState(false), resendLoading = _f[0], setResendLoading = _f[1];
66
+ var phone = (_d = (_c = (_b = data.responseData) === null || _b === void 0 ? void 0 : _b.authData) === null || _c === void 0 ? void 0 : _c.verification_by) === null || _d === void 0 ? void 0 : _d.sent_to;
67
+ React.useEffect(function () {
68
+ if (error && methods.formState.isValid && phone)
69
+ dispatch(clearError());
70
+ return function () {
71
+ dispatch(resetOTPScreen());
72
+ };
73
+ }, [methods.formState.isValid]);
74
+ var onSubmit = function (formData) {
75
+ dispatch(verifyTokenOTP(deepCopy(formData)))
76
+ .unwrap()
77
+ .then(function (_a) {
78
+ var nextScreen = _a.nextScreen;
79
+ dispatch(handleNextScreenStep(nextScreen));
80
+ })
81
+ .catch(function (err) {
82
+ if (isAuthenticationVerificationFailed(err === null || err === void 0 ? void 0 : err.message))
83
+ dispatch(handleNextScreenStep(CONNECT_FLOWS.terminal.otpVerifySecurityError));
84
+ });
85
+ };
86
+ var disabled = !methods.formState.isValid || !phone || resendLoading;
87
+ return (_jsx(ScreenContainer, { children: _jsx(FormProvider, __assign({}, methods, { children: _jsxs(FormStyled, __assign({ onSubmit: methods.handleSubmit(onSubmit) }, { children: [_jsx(OTPTitleContainerStyled, { children: _jsxs(OTPTitleStyled, { children: [loading ? st('ide_otp_waiting_title') : st('ide_opt_sent_title'), !loading && phone && _jsx("span", __assign({ dir: 'ltr' }, { children: "".concat(maskPhone(phone || '')) }))] }) }), _jsx(OTPInput, { loading: resendLoading, setLoading: setResendLoading }), _jsx(Button, __assign({ disableBack: true, disabled: disabled, isAr: isAr, loading: loading, error: st(error || '') }, { children: t('next') }))] })) })) }));
88
+ };
89
+ export default React.memo(VerifyNumber);
@@ -0,0 +1,2 @@
1
+ import OTP from './Verify';
2
+ export default OTP;
@@ -0,0 +1,2 @@
1
+ import OTP from './Verify';
2
+ export default OTP;
@@ -0,0 +1,8 @@
1
+ import * as yup from 'yup';
2
+ export declare const OTPValidation: yup.ObjectSchema<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
3
+ otp: import("yup/lib/string").RequiredStringSchema<string | undefined, import("yup/lib/types").AnyObject>;
4
+ }>, import("yup/lib/object").AnyObject, import("yup/lib/object").TypeOfShape<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
5
+ otp: import("yup/lib/string").RequiredStringSchema<string | undefined, import("yup/lib/types").AnyObject>;
6
+ }>>, import("yup/lib/object").AssertsShape<import("yup/lib/object").Assign<import("yup/lib/object").ObjectShape, {
7
+ otp: import("yup/lib/string").RequiredStringSchema<string | undefined, import("yup/lib/types").AnyObject>;
8
+ }>>>;
@@ -0,0 +1,4 @@
1
+ import * as yup from 'yup';
2
+ export var OTPValidation = yup.object().shape({
3
+ otp: yup.string().min(6, 'otp_min_length').required('otp_required')
4
+ });
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ import { SxProps, Theme } from '@mui/material';
3
+ interface HeaderProps {
4
+ onLinkClick?: () => void;
5
+ loading?: boolean;
6
+ title?: string;
7
+ sx?: SxProps<Theme>;
8
+ }
9
+ declare const _default: React.MemoExoticComponent<({ onLinkClick, loading, title, sx }: HeaderProps) => JSX.Element>;
10
+ export default _default;
@@ -0,0 +1,30 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
13
+ import { memo } from 'react';
14
+ import { useTranslation } from 'react-i18next';
15
+ import AddIcon from '@mui/icons-material/Add';
16
+ import Loader from '../../../../components/Loader';
17
+ import { AddIconContainer, HeadContainer, LinkButton, LinkText, TextTypography } from './styles';
18
+ var Header = function (_a) {
19
+ var onLinkClick = _a.onLinkClick, loading = _a.loading, title = _a.title, sx = _a.sx;
20
+ var t = useTranslation().t;
21
+ var getLink = function () {
22
+ if (!onLinkClick)
23
+ return;
24
+ if (loading)
25
+ return _jsx(Loader, { innerColor: 'black', outerColor: 'black', size: 14, style: { height: 28, width: 28, margin: 0 }, toggleAnimation: !!loading });
26
+ return (_jsxs(LinkButton, __assign({ onClick: onLinkClick }, { children: [_jsx(AddIconContainer, { children: _jsx(AddIcon, { fontSize: 'small' }) }), _jsx(LinkText, { children: t('terminal_link_terminal') })] })));
27
+ };
28
+ return (_jsxs(HeadContainer, __assign({ sx: sx }, { children: [_jsx(TextTypography, { children: t(title !== null && title !== void 0 ? title : 'terminal_manage_terminals') }), getLink()] })));
29
+ };
30
+ export default memo(Header);
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ import { POSInfo } from '../../../../@types';
3
+ interface POSDeviceListProps {
4
+ selectedPOS: POSInfo;
5
+ posDevices: POSInfo[];
6
+ select?: boolean;
7
+ loading?: boolean;
8
+ onClick: (pos: POSInfo) => void;
9
+ }
10
+ declare const _default: React.MemoExoticComponent<({ posDevices, onClick, selectedPOS, select, loading }: POSDeviceListProps) => JSX.Element>;
11
+ export default _default;
@@ -0,0 +1,30 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { memo } from 'react';
3
+ import { useTranslation } from 'react-i18next';
4
+ import { ICONS_NAMES } from '../../../../constants';
5
+ import Icon from '../../../../components/Icon';
6
+ import Loader from '../../../../components/Loader';
7
+ import { ListContainer, POSListContainer, TitleContainer, Image, Title, ScrollContainer, ListItem, StyledRadio, ArrowIcon } from './styles';
8
+ import { useAppSelector } from '../../../../hooks';
9
+ import { terminalSelector } from '../../../../features/app/terminal/terminalStore';
10
+ import { useTheme } from '@mui/material/styles';
11
+ var POSDeviceList = function (_a) {
12
+ var _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
13
+ var posDevices = _a.posDevices, onClick = _a.onClick, selectedPOS = _a.selectedPOS, _m = _a.select, select = _m === void 0 ? true : _m, loading = _a.loading;
14
+ var t = useTranslation().t;
15
+ var typography = useTheme().typography;
16
+ var responseData = useAppSelector(terminalSelector).data.responseData;
17
+ var terminalData = (responseData || {}).terminalData;
18
+ var platformImage = ((_e = (_d = (_c = (_b = terminalData === null || terminalData === void 0 ? void 0 : terminalData.list) === null || _b === void 0 ? void 0 : _b[0]) === null || _c === void 0 ? void 0 : _c.platform) === null || _d === void 0 ? void 0 : _d.brand) === null || _e === void 0 ? void 0 : _e.logo) || ICONS_NAMES.platform_image;
19
+ var platformName = (_l = (_k = (_j = (_h = (_g = (_f = terminalData === null || terminalData === void 0 ? void 0 : terminalData.list) === null || _f === void 0 ? void 0 : _f[0]) === null || _g === void 0 ? void 0 : _g.platform) === null || _h === void 0 ? void 0 : _h.brand) === null || _j === void 0 ? void 0 : _j.name) === null || _k === void 0 ? void 0 : _k[0]) === null || _l === void 0 ? void 0 : _l.text;
20
+ var getEndComponent = function (pos) {
21
+ if (loading && (selectedPOS === null || selectedPOS === void 0 ? void 0 : selectedPOS.id) === (pos === null || pos === void 0 ? void 0 : pos.id))
22
+ return _jsx(Loader, { innerColor: 'black', outerColor: 'black', size: 10, style: { height: 24, width: 24 }, toggleAnimation: !!loading });
23
+ if (select)
24
+ return (_jsx(StyledRadio, { sx: { paddingInlineEnd: 0 }, disableFocusRipple: true, disableRipple: true, disableTouchRipple: true, onChange: function () { return onClick(pos); }, checkedIcon: _jsx(Icon, { src: ICONS_NAMES.radio_checked }), checked: (selectedPOS === null || selectedPOS === void 0 ? void 0 : selectedPOS.id) === pos.id }));
25
+ if (!select)
26
+ return _jsx(ArrowIcon, {});
27
+ };
28
+ return (_jsxs(ListContainer, { children: [_jsxs(TitleContainer, { children: [_jsx(Image, { src: platformImage, alt: 'Device' }), _jsx(Title, { children: t('terminal_devices', { name: platformName }) })] }), _jsx(ScrollContainer, { children: _jsx(POSListContainer, { children: (posDevices || []).map(function (device, index) { return (_jsx(ListItem, { sx: { minHeight: 'unset' }, titleSx: { fontSize: typography.subtitle2.fontSize }, onClick: function () { return onClick(device); }, name: device.display_name, deviceId: device.reference, deviceIdLabel: 'terminal_device_id', endAdornment: getEndComponent(device) }, index)); }) }) })] }));
29
+ };
30
+ export default memo(POSDeviceList);
@@ -0,0 +1,5 @@
1
+ import Header from './Header';
2
+ import POSDeviceList from './POSDeviceList';
3
+ export * from './styles';
4
+ export * from './utils';
5
+ export { Header, POSDeviceList };
@@ -0,0 +1,5 @@
1
+ import Header from './Header';
2
+ import POSDeviceList from './POSDeviceList';
3
+ export * from './styles';
4
+ export * from './utils';
5
+ export { Header, POSDeviceList };