@wise/dynamic-flow-client 3.3.2 → 3.4.0-experimental-9862ccf
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.
- package/build/common/httpClientContext/HttpClientContext.js +35 -0
- package/build/common/httpClientContext/index.js +1 -0
- package/build/common/makeHttpClient/index.js +1 -0
- package/build/common/makeHttpClient/makeHttpClient.js +34 -0
- package/build/common/messages/generic-error.messages.js +18 -0
- package/build/common/messages/help.messages.js +8 -0
- package/build/common/messages/multi-file-upload.messages.js +18 -0
- package/build/common/messages/paragraph.messages.js +13 -0
- package/build/common/messages/repeatable.messages.js +23 -0
- package/build/common/messages/validation.array.messages.js +13 -0
- package/build/common/messages/validation.messages.js +53 -0
- package/build/common/utils/api-utils.js +4 -0
- package/build/legacy/common/constants/DateMode.js +4 -0
- package/build/legacy/common/constants/FeatureName.js +4 -0
- package/build/legacy/common/constants/FormControlType.js +21 -0
- package/build/legacy/common/constants/MonthFormat.js +4 -0
- package/build/legacy/common/constants/Size.js +7 -0
- package/build/legacy/common/constants/index.js +4 -0
- package/build/legacy/common/contexts/dynamicFlowContexts/DynamicFlowContexts.js +36 -0
- package/build/legacy/common/contexts/dynamicFlowContexts/usePendingPromiseCounter.js +13 -0
- package/build/legacy/common/contexts/eventsContext/EventsContext.js +38 -0
- package/build/legacy/common/contexts/featureContext/FeatureContext.js +22 -0
- package/build/legacy/common/contexts/index.js +3 -0
- package/build/legacy/common/contexts/logContext/LogContext.js +44 -0
- package/build/legacy/common/hooks/index.js +7 -0
- package/build/legacy/common/hooks/useDebouncedFunction/useDebouncedFunction.js +9 -0
- package/build/legacy/common/hooks/useExternal/useExternal.js +15 -0
- package/build/legacy/common/hooks/useExternalStepPolling/useExternalStepPolling.js +70 -0
- package/build/legacy/common/hooks/usePersistAsync/usePersistAsync.js +172 -0
- package/build/legacy/common/hooks/usePolling/usePolling.js +51 -0
- package/build/legacy/common/hooks/usePrevious/usePrevious.js +8 -0
- package/build/legacy/common/hooks/useStepPolling/useStepPolling.js +43 -0
- package/build/legacy/common/messages.js +8 -0
- package/build/legacy/common/utils/api-utils.js +6 -0
- package/build/legacy/common/utils/date-utils.js +22 -0
- package/build/legacy/common/utils/debounce.js +38 -0
- package/build/legacy/common/utils/file-utils.js +45 -0
- package/build/legacy/common/utils/id-utils.js +5 -0
- package/build/legacy/common/utils/index.js +11 -0
- package/build/legacy/common/utils/is-equal.js +21 -0
- package/build/legacy/common/utils/misc-utils.js +4 -0
- package/build/legacy/common/utils/mobile-utils.js +23 -0
- package/build/legacy/common/utils/model-utils.js +33 -0
- package/build/legacy/common/utils/schema-utils.js +97 -0
- package/build/legacy/common/utils/step-utils.js +32 -0
- package/build/legacy/common/validators/index.js +5 -0
- package/build/legacy/common/validators/models/model-utils.js +119 -0
- package/build/legacy/common/validators/models/model-validators.js +62 -0
- package/build/legacy/common/validators/schemas/schema-validators.js +101 -0
- package/build/legacy/common/validators/types/type-validators.js +14 -0
- package/build/legacy/common/validators/validationFailures/validation-failures.js +139 -0
- package/build/legacy/common/validators/validationFailures/validation-failures.utils.js +40 -0
- package/build/legacy/common/validators/values/value-validators.js +6 -0
- package/build/legacy/dynamic-flow-types.js +1 -0
- package/build/legacy/dynamicFlow/BackButton.js +22 -0
- package/build/legacy/dynamicFlow/DynamicFlowStep.js +37 -0
- package/build/legacy/formControl/FormControl.js +266 -0
- package/build/legacy/formControl/index.js +1 -0
- package/build/legacy/formControl/utils/getAutocompleteString.js +80 -0
- package/build/legacy/formControl/utils/index.js +2 -0
- package/build/legacy/formControl/utils/value-utils.js +108 -0
- package/build/legacy/jsonSchemaForm/allOfSchema/AllOfSchema.js +50 -0
- package/build/legacy/jsonSchemaForm/allOfSchema/index.js +1 -0
- package/build/legacy/jsonSchemaForm/arrayTypeSchema/ArraySchema.js +25 -0
- package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/ArrayListSchema.js +30 -0
- package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/multipleFileUploadSchema/MultipleFileUploadSchema.js +141 -0
- package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/multipleFileUploadSchema/index.js +1 -0
- package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/multipleFileUploadSchema/utils/index.js +2 -0
- package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/multipleFileUploadSchema/utils/upload-utils.js +79 -0
- package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/multipleFileUploadSchema/utils/useFormattedDefaultErrorMessages.js +14 -0
- package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/repeatableSchema/ItemSummary.js +7 -0
- package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/repeatableSchema/RepeatableSchema.js +134 -0
- package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/repeatableSchema/RepeatableSchemaStep.js +85 -0
- package/build/legacy/jsonSchemaForm/arrayTypeSchema/arrayListSchema/repeatableSchema/utils/summary-utils.js +135 -0
- package/build/legacy/jsonSchemaForm/arrayTypeSchema/index.js +1 -0
- package/build/legacy/jsonSchemaForm/basicTypeSchema/BasicTypeSchema.js +111 -0
- package/build/legacy/jsonSchemaForm/basicTypeSchema/index.js +1 -0
- package/build/legacy/jsonSchemaForm/controlFeedback/ControlFeedback.js +86 -0
- package/build/legacy/jsonSchemaForm/controlFeedback/index.js +1 -0
- package/build/legacy/jsonSchemaForm/help/Help.js +20 -0
- package/build/legacy/jsonSchemaForm/help/index.js +1 -0
- package/build/legacy/jsonSchemaForm/objectSchema/ObjectSchema.js +77 -0
- package/build/legacy/jsonSchemaForm/objectSchema/index.js +1 -0
- package/build/legacy/jsonSchemaForm/oneOfSchema/OneOfSchema.js +155 -0
- package/build/legacy/jsonSchemaForm/oneOfSchema/index.js +1 -0
- package/build/legacy/jsonSchemaForm/oneOfSchema/utils.js +68 -0
- package/build/legacy/jsonSchemaForm/persistAsyncSchema/PersistAsyncSchema.js +26 -0
- package/build/legacy/jsonSchemaForm/persistAsyncSchema/index.js +1 -0
- package/build/legacy/jsonSchemaForm/persistAsyncSchema/persistAsyncBasicSchema/PersistAsyncBasicSchema.js +165 -0
- package/build/legacy/jsonSchemaForm/persistAsyncSchema/persistAsyncBasicSchema/index.js +1 -0
- package/build/legacy/jsonSchemaForm/persistAsyncSchema/persistAsyncBlobSchema/PersistAsyncBlobSchema.js +131 -0
- package/build/legacy/jsonSchemaForm/persistAsyncSchema/persistAsyncBlobSchema/UploadInputAdapter.js +31 -0
- package/build/legacy/jsonSchemaForm/persistAsyncSchema/persistAsyncBlobSchema/index.js +1 -0
- package/build/legacy/jsonSchemaForm/promotedOneOfSchema/PromotedOneOfSchema.js +72 -0
- package/build/legacy/jsonSchemaForm/promotedOneOfSchema/index.js +1 -0
- package/build/legacy/jsonSchemaForm/promotedOneOfSchema/promoted-one-of-utils.js +8 -0
- package/build/legacy/jsonSchemaForm/promotedOneOfSchema/promotedOneOfControl/PromotedOneOfCheckboxControl.js +27 -0
- package/build/legacy/jsonSchemaForm/promotedOneOfSchema/promotedOneOfControl/PromotedOneOfControl.js +31 -0
- package/build/legacy/jsonSchemaForm/promotedOneOfSchema/promotedOneOfControl/PromotedOneOfRadioControl.js +32 -0
- package/build/legacy/jsonSchemaForm/readOnlySchema/ReadOnlySchema.js +54 -0
- package/build/legacy/jsonSchemaForm/readOnlySchema/ReadOnlySchema.messages.js +13 -0
- package/build/legacy/jsonSchemaForm/readOnlySchema/index.js +1 -0
- package/build/legacy/jsonSchemaForm/schemaFormControl/SchemaFormControl.js +133 -0
- package/build/legacy/jsonSchemaForm/schemaFormControl/index.js +1 -0
- package/build/legacy/jsonSchemaForm/schemaFormControl/utils/index.js +1 -0
- package/build/legacy/jsonSchemaForm/schemaFormControl/utils/mapping-utils.js +107 -0
- package/build/legacy/layout/DynamicLayout.js +68 -0
- package/build/legacy/layout/alert/DynamicAlert.js +29 -0
- package/build/legacy/layout/box/DynamicBox.js +41 -0
- package/build/legacy/layout/button/DynamicButton.js +27 -0
- package/build/legacy/layout/button/utils.js +45 -0
- package/build/legacy/layout/columns/DynamicColumns.js +38 -0
- package/build/legacy/layout/decision/DynamicDecision.js +21 -0
- package/build/legacy/layout/divider/DynamicDivider.js +9 -0
- package/build/legacy/layout/external/DynamicExternal.js +32 -0
- package/build/legacy/layout/external/DynamicExternal.messages.js +8 -0
- package/build/legacy/layout/form/DynamicForm.js +22 -0
- package/build/legacy/layout/heading/DynamicHeading.js +51 -0
- package/build/legacy/layout/icon/DynamicIcon.js +17 -0
- package/build/legacy/layout/icon/FlagIcon.js +198 -0
- package/build/legacy/layout/icon/NamedIcon.js +19 -0
- package/build/legacy/layout/image/DynamicImage.js +111 -0
- package/build/legacy/layout/index.js +20 -0
- package/build/legacy/layout/instructions/DynamicInstructions.js +30 -0
- package/build/legacy/layout/list/DynamicStatusList.js +37 -0
- package/build/legacy/layout/loadingIndicator/DynamicLoadingIndicator.js +11 -0
- package/build/legacy/layout/markdown/DynamicMarkdown.js +23 -0
- package/build/legacy/layout/modal/DynamicModal.js +26 -0
- package/build/legacy/layout/paragraph/DynamicParagraph.js +46 -0
- package/build/legacy/layout/paragraph/useSnackBarIfAvailable.js +9 -0
- package/build/legacy/layout/review/DynamicReview.js +58 -0
- package/build/legacy/layout/search/DynamicSearch.js +58 -0
- package/build/legacy/layout/search/SearchInput.js +17 -0
- package/build/legacy/layout/search/SearchResults.js +31 -0
- package/build/legacy/layout/search/useSearch.js +137 -0
- package/build/legacy/layout/utils/getNavigationOptionMedia.js +28 -0
- package/build/legacy/layout/utils/index.js +32 -0
- package/build/legacy/step/cameraStep/CameraStep.js +124 -0
- package/build/legacy/step/cameraStep/cameraCapture/CameraCapture.js +161 -0
- package/build/legacy/step/cameraStep/cameraCapture/CameraCapture.messages.js +58 -0
- package/build/legacy/step/cameraStep/cameraCapture/components/bottomBar/BottomBar.js +28 -0
- package/build/legacy/step/cameraStep/cameraCapture/components/index.js +3 -0
- package/build/legacy/step/cameraStep/cameraCapture/components/orientationLockOverlay/OrientationLockOverlay.js +19 -0
- package/build/legacy/step/cameraStep/cameraCapture/components/orientationLockOverlay/OrientationLockOverlay.messages.js +8 -0
- package/build/legacy/step/cameraStep/cameraCapture/hooks/useFullScreenOrientationLock.js +60 -0
- package/build/legacy/step/cameraStep/cameraCapture/hooks/useVideoConstraints.js +80 -0
- package/build/legacy/step/cameraStep/cameraCapture/index.js +1 -0
- package/build/legacy/step/cameraStep/cameraCapture/overlay/Overlay.js +77 -0
- package/build/legacy/step/cameraStep/cameraCapture/screens/cameraErrorScreen/CameraErrorScreen.js +18 -0
- package/build/legacy/step/cameraStep/cameraCapture/screens/index.js +1 -0
- package/build/legacy/step/cameraStep/cameraCapture/tracking/index.js +109 -0
- package/build/legacy/step/cameraStep/cameraCapture/types/index.js +7 -0
- package/build/legacy/step/cameraStep/cameraCapture/utils/index.js +107 -0
- package/build/legacy/step/cameraStep/index.js +1 -0
- package/build/legacy/step/externalConfirmationStep/ExternalConfirmationStep.js +64 -0
- package/build/legacy/step/externalConfirmationStep/ExternalConfirmationStep.messages.js +23 -0
- package/build/legacy/step/externalConfirmationStep/index.js +1 -0
- package/build/legacy/step/index.js +3 -0
- package/build/legacy/step/layoutStep/LayoutStep.js +33 -0
- package/build/legacy/step/layoutStep/index.js +1 -0
- package/build/legacy/step/layoutStep/utils/index.js +2 -0
- package/build/legacy/step/layoutStep/utils/inline-reference-utils.js +105 -0
- package/build/legacy/step/layoutStep/utils/layout-utils.js +212 -0
- package/build/main.js +13 -28
- package/build/main.min.js +1 -1
- package/build/main.mjs +13 -28
- package/build/types/revamp/domain/features/events.d.ts +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,28 @@
|
|
|
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 { Button, ControlType, Priority, Size } from '@transferwise/components';
|
|
14
|
+
import { useIntl } from 'react-intl';
|
|
15
|
+
import messages from '../../CameraCapture.messages';
|
|
16
|
+
export var CaptureBottomBar = function (_a) {
|
|
17
|
+
var onCapture = _a.onCapture;
|
|
18
|
+
return (_jsx("div", __assign({ className: "bottom-bar" }, { children: _jsx(CaptureButton, { onClick: onCapture }) })));
|
|
19
|
+
};
|
|
20
|
+
export var ReviewBottomBar = function (_a) {
|
|
21
|
+
var onSubmit = _a.onSubmit, onRetry = _a.onRetry;
|
|
22
|
+
var intl = useIntl();
|
|
23
|
+
return (_jsx("div", __assign({ className: "bottom-bar p-x-2" }, { children: _jsx("div", __assign({ className: "row" }, { children: _jsxs("div", __assign({ className: "col-xs-12 col-md-6 col-md-offset-3" }, { children: [_jsx(Button, __assign({ className: "m-b-1", block: true, size: Size.MEDIUM, type: ControlType.ACCENT, onClick: onSubmit }, { children: intl.formatMessage(messages.reviewSubmit) })), _jsx(Button, __assign({ className: "m-b-2", block: true, size: Size.MEDIUM, type: ControlType.ACCENT, priority: Priority.SECONDARY, onClick: onRetry }, { children: intl.formatMessage(messages.reviewRetry) }))] })) })) })));
|
|
24
|
+
};
|
|
25
|
+
var CaptureButton = function (_a) {
|
|
26
|
+
var onClick = _a.onClick;
|
|
27
|
+
return (_jsx("button", __assign({ type: "button", className: "camera-capture-btn m-b-2", "data-testid": "camera-capture-button", onClick: onClick }, { children: _jsx("span", { className: "camera-capture-btn-inner" }) })));
|
|
28
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
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 { useIntl } from 'react-intl';
|
|
14
|
+
import messages from './OrientationLockOverlay.messages';
|
|
15
|
+
function OrientationLockOverlay() {
|
|
16
|
+
var intl = useIntl();
|
|
17
|
+
return (_jsxs("div", __assign({ className: "orientation-lock-overlay" }, { children: [_jsx("img", { className: "m-b-3", src: "https://wise.com/public-resources/assets/camera-guidelines/icon-rotate-phone.svg", width: "96", height: "96", alt: "" }), _jsx("p", __assign({ className: "text-center m-b-0" }, { children: intl.formatMessage(messages.text) }))] })));
|
|
18
|
+
}
|
|
19
|
+
export default OrientationLockOverlay;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { defineMessages } from 'react-intl';
|
|
2
|
+
export default defineMessages({
|
|
3
|
+
text: {
|
|
4
|
+
id: 'dynamicFlows.CameraCapture.rotatePhone.text',
|
|
5
|
+
defaultMessage: 'Rotate your phone to portrait view to take a photo',
|
|
6
|
+
description: 'Prompt the user to rotate their phone from landscape to portrait mode when attempting to take a photo'
|
|
7
|
+
}
|
|
8
|
+
});
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { useCallback, useEffect } from 'react';
|
|
2
|
+
import screenfull from 'screenfull';
|
|
3
|
+
import { trackCameraOrientationLandscape, trackCameraOrientationLocked } from '../tracking';
|
|
4
|
+
export var useFullScreenOrientationLock = function (shouldLockOrientation, onEvent) {
|
|
5
|
+
var lockOrientation = useCallback(function () {
|
|
6
|
+
if (window.screen.orientation &&
|
|
7
|
+
'lock' in window.screen.orientation &&
|
|
8
|
+
typeof window.screen.orientation.lock === 'function') {
|
|
9
|
+
window.screen.orientation
|
|
10
|
+
.lock('portrait')
|
|
11
|
+
.then(function () { return trackCameraOrientationLocked(onEvent); })["catch"](noop);
|
|
12
|
+
}
|
|
13
|
+
}, [onEvent]);
|
|
14
|
+
var unlockOrientation = useCallback(function () { var _a, _b, _c; return (_c = (_b = (_a = window === null || window === void 0 ? void 0 : window.screen) === null || _a === void 0 ? void 0 : _a.orientation) === null || _b === void 0 ? void 0 : _b.unlock) === null || _c === void 0 ? void 0 : _c.call(_b); }, []);
|
|
15
|
+
var enterFullScreen = useCallback(function () {
|
|
16
|
+
setTimeout(function () {
|
|
17
|
+
if (shouldLockOrientation && !screenfull.isFullscreen && screenfull.isEnabled) {
|
|
18
|
+
screenfull
|
|
19
|
+
.request(document.documentElement, { navigationUI: 'show' })
|
|
20
|
+
.then(function () {
|
|
21
|
+
lockOrientation();
|
|
22
|
+
})["catch"](noop);
|
|
23
|
+
}
|
|
24
|
+
}, 100);
|
|
25
|
+
}, [shouldLockOrientation, lockOrientation]);
|
|
26
|
+
var exitFullScreen = useCallback(function () {
|
|
27
|
+
if (screenfull.isFullscreen) {
|
|
28
|
+
screenfull.exit()["catch"](noop);
|
|
29
|
+
}
|
|
30
|
+
unlockOrientation();
|
|
31
|
+
}, [unlockOrientation]);
|
|
32
|
+
var handleOrientationChange = useCallback(function (event) {
|
|
33
|
+
var _a, _b;
|
|
34
|
+
if ((_a = event === null || event === void 0 ? void 0 : event.target) === null || _a === void 0 ? void 0 : _a.type.includes('landscape')) {
|
|
35
|
+
if ((_b = window.screen) === null || _b === void 0 ? void 0 : _b.orientation) {
|
|
36
|
+
trackCameraOrientationLandscape(onEvent);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}, [onEvent]);
|
|
40
|
+
useEffect(function () {
|
|
41
|
+
var _a, _b;
|
|
42
|
+
if (shouldLockOrientation) {
|
|
43
|
+
(_b = (_a = window.screen) === null || _a === void 0 ? void 0 : _a.orientation) === null || _b === void 0 ? void 0 : _b.addEventListener('change', function (event) {
|
|
44
|
+
return handleOrientationChange(event);
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
return function () {
|
|
48
|
+
var _a, _b;
|
|
49
|
+
(_b = (_a = window.screen) === null || _a === void 0 ? void 0 : _a.orientation) === null || _b === void 0 ? void 0 : _b.removeEventListener('change', handleOrientationChange);
|
|
50
|
+
exitFullScreen();
|
|
51
|
+
};
|
|
52
|
+
}, [exitFullScreen, handleOrientationChange, shouldLockOrientation]);
|
|
53
|
+
return {
|
|
54
|
+
enterFullScreen: enterFullScreen,
|
|
55
|
+
exitFullScreen: exitFullScreen
|
|
56
|
+
};
|
|
57
|
+
};
|
|
58
|
+
var noop = function () {
|
|
59
|
+
// no-op
|
|
60
|
+
};
|
|
@@ -0,0 +1,80 @@
|
|
|
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
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
13
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
14
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
15
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
16
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
17
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
18
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
19
|
+
});
|
|
20
|
+
};
|
|
21
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
22
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
23
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
24
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
25
|
+
function step(op) {
|
|
26
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
27
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
28
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
29
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
30
|
+
switch (op[0]) {
|
|
31
|
+
case 0: case 1: t = op; break;
|
|
32
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
33
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
34
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
35
|
+
default:
|
|
36
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
37
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
38
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
39
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
40
|
+
if (t[2]) _.ops.pop();
|
|
41
|
+
_.trys.pop(); continue;
|
|
42
|
+
}
|
|
43
|
+
op = body.call(thisArg, _);
|
|
44
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
45
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
import { useEffect, useState } from 'react';
|
|
49
|
+
import { getAvailableVideoDevices, isMainBackCamera } from '../utils';
|
|
50
|
+
export var useVideoConstraints = function (direction) {
|
|
51
|
+
var _a = useState(), videoConstraints = _a[0], setVideoConstraints = _a[1];
|
|
52
|
+
var defaultVideoConstraints = {
|
|
53
|
+
facingMode: direction === 'front' ? 'user' : 'environment',
|
|
54
|
+
height: { min: 480, max: 1080, ideal: 720 },
|
|
55
|
+
width: { min: 640, max: 1920, ideal: 1280 },
|
|
56
|
+
frameRate: 30,
|
|
57
|
+
aspectRatio: 16 / 9
|
|
58
|
+
};
|
|
59
|
+
useEffect(function () {
|
|
60
|
+
void getVideoConstraints(direction).then(setVideoConstraints);
|
|
61
|
+
}, [direction]);
|
|
62
|
+
var getVideoConstraints = function (direction) { return __awaiter(void 0, void 0, void 0, function () {
|
|
63
|
+
var mainCamera;
|
|
64
|
+
return __generator(this, function (_a) {
|
|
65
|
+
switch (_a.label) {
|
|
66
|
+
case 0:
|
|
67
|
+
if (!(direction === 'back')) return [3 /*break*/, 2];
|
|
68
|
+
return [4 /*yield*/, getAvailableVideoDevices()];
|
|
69
|
+
case 1:
|
|
70
|
+
mainCamera = (_a.sent()).find(isMainBackCamera);
|
|
71
|
+
if (mainCamera === null || mainCamera === void 0 ? void 0 : mainCamera.deviceId) {
|
|
72
|
+
return [2 /*return*/, __assign(__assign({}, defaultVideoConstraints), { deviceId: { exact: mainCamera.deviceId } })];
|
|
73
|
+
}
|
|
74
|
+
_a.label = 2;
|
|
75
|
+
case 2: return [2 /*return*/, defaultVideoConstraints];
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
}); };
|
|
79
|
+
return { videoConstraints: videoConstraints };
|
|
80
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from './CameraCapture';
|
|
@@ -0,0 +1,77 @@
|
|
|
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, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
13
|
+
import { useEffect, useRef } from 'react';
|
|
14
|
+
import { debounce } from '../../../../common/utils/debounce';
|
|
15
|
+
var captureButtonHeight = 92;
|
|
16
|
+
var reviewButtonsHeight = 120;
|
|
17
|
+
var imageHeight = 40;
|
|
18
|
+
var titleHeight = 32;
|
|
19
|
+
var instructionsHeight = 48;
|
|
20
|
+
var reviewInstructionsHeight = 40;
|
|
21
|
+
var overlayMaxWidth = 800;
|
|
22
|
+
function Overlay(_a) {
|
|
23
|
+
var overlay = _a.overlay, outline = _a.outline, imageUrl = _a.imageUrl, title = _a.title, instructions = _a.instructions, reviewInstructions = _a.reviewInstructions;
|
|
24
|
+
var svgReference = useRef(null);
|
|
25
|
+
/*
|
|
26
|
+
SVG doesn't always rerender when screen orientation changes,
|
|
27
|
+
so need to force rerender
|
|
28
|
+
*/
|
|
29
|
+
useEffect(function () {
|
|
30
|
+
var listener = debounce(function () {
|
|
31
|
+
var _a;
|
|
32
|
+
if ((_a = svgReference.current) === null || _a === void 0 ? void 0 : _a.innerHTML) {
|
|
33
|
+
var reference = svgReference.current;
|
|
34
|
+
reference.innerHTML = String(reference.innerHTML);
|
|
35
|
+
}
|
|
36
|
+
}, 100);
|
|
37
|
+
window.addEventListener('resize', listener);
|
|
38
|
+
return function () { return window.removeEventListener('resize', listener); };
|
|
39
|
+
});
|
|
40
|
+
var helperBoxHeight = (imageUrl ? imageHeight : 0) +
|
|
41
|
+
(title ? titleHeight : 0) +
|
|
42
|
+
(instructions ? instructionsHeight : 0);
|
|
43
|
+
var helperBox = (_jsxs(_Fragment, { children: [imageUrl && _jsx("img", { className: "camera-capture-img", src: imageUrl, alt: "" }), title && _jsx("h4", __assign({ className: "camera-capture-title" }, { children: title })), instructions && _jsx("small", __assign({ className: "camera-capture-instructions" }, { children: instructions }))] }));
|
|
44
|
+
var frameBottomMargin = captureButtonHeight + helperBoxHeight;
|
|
45
|
+
/*
|
|
46
|
+
frameBottomMargin needs to stay the same for the review page so that
|
|
47
|
+
the overlay position does not change! Basically if it is the review step
|
|
48
|
+
and there is a 'reviewInstructions' specified, the overlay position stays
|
|
49
|
+
the same, but the helperBox height and content changes to adjust for the
|
|
50
|
+
large review buttons and smaller height required by 'reviewInstructionsHeight'
|
|
51
|
+
*/
|
|
52
|
+
if (reviewInstructions) {
|
|
53
|
+
helperBoxHeight = frameBottomMargin - reviewButtonsHeight;
|
|
54
|
+
helperBox = _jsx("small", __assign({ className: "camera-capture-instructions" }, { children: reviewInstructions }));
|
|
55
|
+
var frameWithReviewInstructionsMinBottomMargin = reviewButtonsHeight + reviewInstructionsHeight;
|
|
56
|
+
if (frameBottomMargin < frameWithReviewInstructionsMinBottomMargin) {
|
|
57
|
+
helperBox = _jsx(_Fragment, {});
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
var framePosition = {
|
|
61
|
+
x: '50%',
|
|
62
|
+
y: '5%',
|
|
63
|
+
width: "min(90%, ".concat(overlayMaxWidth, "px)"),
|
|
64
|
+
height: "calc(90% - ".concat(frameBottomMargin, "px)"),
|
|
65
|
+
style: { transform: "translateX(max(-45%, -".concat(overlayMaxWidth / 2, "px))") }
|
|
66
|
+
};
|
|
67
|
+
var helperBoxPosition = {
|
|
68
|
+
style: {
|
|
69
|
+
left: '5%',
|
|
70
|
+
top: "calc(100% - ".concat(frameBottomMargin, "px - 5%)"),
|
|
71
|
+
height: "calc(".concat(helperBoxHeight, "px + 5%)"),
|
|
72
|
+
width: '90%'
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
return (_jsxs("svg", __assign({ ref: svgReference, xmlns: "http://www.w3.org/2000/svg" }, { children: [_jsx("defs", { children: _jsxs("mask", __assign({ id: "mask" }, { children: [_jsx("rect", { width: "100%", height: "100%", fill: "#fff" }), _jsx("image", __assign({ href: overlay }, framePosition))] })) }), overlay && _jsx("rect", { width: "100%", height: "100%", mask: "url(#mask)", fillOpacity: "0.72" }), outline && _jsx("image", __assign({ href: outline }, framePosition)), _jsx("foreignObject", __assign({ width: "100%", height: "100%" }, { children: _jsx("div", __assign({ className: "camera-capture-text-and-image-container" }, helperBoxPosition, { children: helperBox })) }))] })));
|
|
76
|
+
}
|
|
77
|
+
export default Overlay;
|
package/build/legacy/step/cameraStep/cameraCapture/screens/cameraErrorScreen/CameraErrorScreen.js
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
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 { Button } from '@transferwise/components';
|
|
14
|
+
function CameraErrorScreen(_a) {
|
|
15
|
+
var title = _a.title, description = _a.description, actionButton = _a.actionButton, onAction = _a.onAction;
|
|
16
|
+
return (_jsx("div", __assign({ className: "container p-t-5" }, { children: _jsx("div", __assign({ className: "row" }, { children: _jsxs("div", __assign({ className: "col-md-6 col-md-offset-3" }, { children: [_jsx("h2", __assign({ className: "text-xs-center m-b-3" }, { children: title })), _jsx("p", __assign({ className: "text-xs-center m-b-5" }, { children: description })), onAction && actionButton && (_jsx(Button, __assign({ block: true, onClick: onAction }, { children: actionButton })))] })) })) })));
|
|
17
|
+
}
|
|
18
|
+
export default CameraErrorScreen;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default as CameraErrorScreen } from "./cameraErrorScreen/CameraErrorScreen";
|
|
@@ -0,0 +1,109 @@
|
|
|
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
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
13
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
14
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
15
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
16
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
17
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
18
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
19
|
+
});
|
|
20
|
+
};
|
|
21
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
22
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
23
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
24
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
25
|
+
function step(op) {
|
|
26
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
27
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
28
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
29
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
30
|
+
switch (op[0]) {
|
|
31
|
+
case 0: case 1: t = op; break;
|
|
32
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
33
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
34
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
35
|
+
default:
|
|
36
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
37
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
38
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
39
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
40
|
+
if (t[2]) _.ops.pop();
|
|
41
|
+
_.trys.pop(); continue;
|
|
42
|
+
}
|
|
43
|
+
op = body.call(thisArg, _);
|
|
44
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
45
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
import { getActiveVideoDeviceLabel, getAvailableVideoDeviceLabels, getVideoCapabilities, getVideoTrack, } from '../utils';
|
|
49
|
+
export var trackCameraError = function (message, onEvent, error) { return onEvent === null || onEvent === void 0 ? void 0 : onEvent(message, { Error: getSerializedError(error) }); };
|
|
50
|
+
var getSerializedError = function (error) {
|
|
51
|
+
return error instanceof DOMException
|
|
52
|
+
? JSON.stringify({
|
|
53
|
+
name: error === null || error === void 0 ? void 0 : error.name,
|
|
54
|
+
message: error === null || error === void 0 ? void 0 : error.message
|
|
55
|
+
})
|
|
56
|
+
: error;
|
|
57
|
+
};
|
|
58
|
+
export var trackCameraFeedStarted = function (onEvent, props, stream) { return __awaiter(void 0, void 0, void 0, function () { var _a, _b, _c; return __generator(this, function (_d) {
|
|
59
|
+
switch (_d.label) {
|
|
60
|
+
case 0:
|
|
61
|
+
if (!(onEvent === null || onEvent === void 0)) return [3 /*break*/, 1];
|
|
62
|
+
_a = void 0;
|
|
63
|
+
return [3 /*break*/, 3];
|
|
64
|
+
case 1:
|
|
65
|
+
_b = onEvent;
|
|
66
|
+
_c = ['Dynamic Flow - Camera Feed Started'];
|
|
67
|
+
return [4 /*yield*/, getCameraStartedProperties(props, stream)];
|
|
68
|
+
case 2:
|
|
69
|
+
_a = _b.apply(void 0, _c.concat([_d.sent()]));
|
|
70
|
+
_d.label = 3;
|
|
71
|
+
case 3: return [2 /*return*/, _a];
|
|
72
|
+
}
|
|
73
|
+
}); }); };
|
|
74
|
+
var getCameraStartedProperties = function (props, videoStream) { return __awaiter(void 0, void 0, void 0, function () {
|
|
75
|
+
var videoTrack, capabilities, settings, _a, _b, _c, _d;
|
|
76
|
+
var _e;
|
|
77
|
+
var _f;
|
|
78
|
+
return __generator(this, function (_g) {
|
|
79
|
+
switch (_g.label) {
|
|
80
|
+
case 0:
|
|
81
|
+
videoTrack = getVideoTrack(videoStream);
|
|
82
|
+
capabilities = getVideoCapabilities(videoStream);
|
|
83
|
+
settings = (_f = videoTrack === null || videoTrack === void 0 ? void 0 : videoTrack.getSettings) === null || _f === void 0 ? void 0 : _f.call(videoTrack);
|
|
84
|
+
_a = [{}];
|
|
85
|
+
_b = videoTrack;
|
|
86
|
+
if (!_b) return [3 /*break*/, 3];
|
|
87
|
+
_e = {};
|
|
88
|
+
_c = 'Available Video Devices (by label)';
|
|
89
|
+
return [4 /*yield*/, getAvailableVideoDeviceLabels()];
|
|
90
|
+
case 1:
|
|
91
|
+
_e[_c] = _g.sent();
|
|
92
|
+
_d = 'Active Video Device (by label)';
|
|
93
|
+
return [4 /*yield*/, getActiveVideoDeviceLabel(videoStream)];
|
|
94
|
+
case 2:
|
|
95
|
+
_b = (_e[_d] = _g.sent(),
|
|
96
|
+
_e['Camera Capabilities'] = capabilities,
|
|
97
|
+
_e['Camera Settings'] = settings,
|
|
98
|
+
_e);
|
|
99
|
+
_g.label = 3;
|
|
100
|
+
case 3: return [2 /*return*/, __assign.apply(void 0, [__assign.apply(void 0, _a.concat([(_b)])), { 'Camera Direction (Asked)': props === null || props === void 0 ? void 0 : props.direction }])];
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
}); };
|
|
104
|
+
export var trackCameraOrientationLandscape = function (onEvent) {
|
|
105
|
+
onEvent === null || onEvent === void 0 ? void 0 : onEvent('Dynamic Flow - Camera Orientation Lock Overlay Shown', {});
|
|
106
|
+
};
|
|
107
|
+
export var trackCameraOrientationLocked = function (onEvent) {
|
|
108
|
+
onEvent === null || onEvent === void 0 ? void 0 : onEvent('Dynamic Flow - Camera Orientation Locked', {});
|
|
109
|
+
};
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
2
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
3
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
4
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
5
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
6
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
7
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
11
|
+
var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
|
|
12
|
+
return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
|
|
13
|
+
function verb(n) { return function (v) { return step([n, v]); }; }
|
|
14
|
+
function step(op) {
|
|
15
|
+
if (f) throw new TypeError("Generator is already executing.");
|
|
16
|
+
while (g && (g = 0, op[0] && (_ = 0)), _) try {
|
|
17
|
+
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
|
|
18
|
+
if (y = 0, t) op = [op[0] & 2, t.value];
|
|
19
|
+
switch (op[0]) {
|
|
20
|
+
case 0: case 1: t = op; break;
|
|
21
|
+
case 4: _.label++; return { value: op[1], done: false };
|
|
22
|
+
case 5: _.label++; y = op[1]; op = [0]; continue;
|
|
23
|
+
case 7: op = _.ops.pop(); _.trys.pop(); continue;
|
|
24
|
+
default:
|
|
25
|
+
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
|
|
26
|
+
if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
|
|
27
|
+
if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
|
|
28
|
+
if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
|
|
29
|
+
if (t[2]) _.ops.pop();
|
|
30
|
+
_.trys.pop(); continue;
|
|
31
|
+
}
|
|
32
|
+
op = body.call(thisArg, _);
|
|
33
|
+
} catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
|
|
34
|
+
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
/* eslint-disable no-implicit-coercion */
|
|
38
|
+
/* eslint-disable @typescript-eslint/no-unnecessary-condition */
|
|
39
|
+
export var isSelfieCamera = function (stream) {
|
|
40
|
+
var _a;
|
|
41
|
+
var facingMode = (((_a = getVideoTrack(stream)) === null || _a === void 0 ? void 0 : _a.getSettings()) || {}).facingMode;
|
|
42
|
+
// facingMode === undefined for desktop users
|
|
43
|
+
return facingMode === 'user' || facingMode === undefined;
|
|
44
|
+
};
|
|
45
|
+
export var isMainBackCamera = function (deviceInfo) {
|
|
46
|
+
return !!((deviceInfo === null || deviceInfo === void 0 ? void 0 : deviceInfo.label) || '').match(/camera2? 0/g);
|
|
47
|
+
};
|
|
48
|
+
export var generateCanvasFromVideo = function (video) { return __awaiter(void 0, void 0, void 0, function () {
|
|
49
|
+
var canvas, context;
|
|
50
|
+
return __generator(this, function (_a) {
|
|
51
|
+
switch (_a.label) {
|
|
52
|
+
case 0:
|
|
53
|
+
canvas = document.createElement('canvas');
|
|
54
|
+
if (!video) return [3 /*break*/, 2];
|
|
55
|
+
canvas.setAttribute('height', "".concat(video.videoHeight));
|
|
56
|
+
canvas.setAttribute('width', "".concat(video.videoWidth));
|
|
57
|
+
context = canvas === null || canvas === void 0 ? void 0 : canvas.getContext('2d');
|
|
58
|
+
if (!context) return [3 /*break*/, 2];
|
|
59
|
+
// Timeout is needed for intermittent iOS issue
|
|
60
|
+
return [4 /*yield*/, new Promise(function (resolve) {
|
|
61
|
+
setTimeout(resolve, 100);
|
|
62
|
+
})];
|
|
63
|
+
case 1:
|
|
64
|
+
// Timeout is needed for intermittent iOS issue
|
|
65
|
+
_a.sent();
|
|
66
|
+
context.drawImage(video, 0, 0, canvas.width, canvas.height);
|
|
67
|
+
_a.label = 2;
|
|
68
|
+
case 2: return [2 /*return*/, canvas];
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
}); };
|
|
72
|
+
export var getAvailableVideoDevices = function () { return __awaiter(void 0, void 0, void 0, function () {
|
|
73
|
+
var _a, _b;
|
|
74
|
+
return __generator(this, function (_c) {
|
|
75
|
+
switch (_c.label) {
|
|
76
|
+
case 0: return [4 /*yield*/, ((_b = (_a = navigator === null || navigator === void 0 ? void 0 : navigator.mediaDevices) === null || _a === void 0 ? void 0 : _a.enumerateDevices) === null || _b === void 0 ? void 0 : _b.call(_a))];
|
|
77
|
+
case 1: return [2 /*return*/, ((_c.sent()) || []).filter(function (deviceInfo) { return deviceInfo.kind === 'videoinput'; })];
|
|
78
|
+
}
|
|
79
|
+
});
|
|
80
|
+
}); };
|
|
81
|
+
export var getAvailableVideoDeviceLabels = function () { return __awaiter(void 0, void 0, void 0, function () {
|
|
82
|
+
var _a, _b;
|
|
83
|
+
return __generator(this, function (_c) {
|
|
84
|
+
switch (_c.label) {
|
|
85
|
+
case 0: return [4 /*yield*/, ((_b = (_a = navigator === null || navigator === void 0 ? void 0 : navigator.mediaDevices) === null || _a === void 0 ? void 0 : _a.enumerateDevices) === null || _b === void 0 ? void 0 : _b.call(_a))];
|
|
86
|
+
case 1: return [2 /*return*/, ((_c.sent()) || [])
|
|
87
|
+
.filter(function (deviceInfo) { return deviceInfo.kind === 'videoinput'; })
|
|
88
|
+
.map(function (deviceInfo) { return deviceInfo.label; })];
|
|
89
|
+
}
|
|
90
|
+
});
|
|
91
|
+
}); };
|
|
92
|
+
export var getActiveVideoDeviceLabel = function (videoStream) { return __awaiter(void 0, void 0, void 0, function () {
|
|
93
|
+
var capabilities;
|
|
94
|
+
var _a, _b, _c;
|
|
95
|
+
return __generator(this, function (_d) {
|
|
96
|
+
switch (_d.label) {
|
|
97
|
+
case 0:
|
|
98
|
+
capabilities = getVideoCapabilities(videoStream);
|
|
99
|
+
return [4 /*yield*/, ((_b = (_a = navigator === null || navigator === void 0 ? void 0 : navigator.mediaDevices) === null || _a === void 0 ? void 0 : _a.enumerateDevices) === null || _b === void 0 ? void 0 : _b.call(_a))];
|
|
100
|
+
case 1: return [2 /*return*/, (_c = ((_d.sent()) || [])
|
|
101
|
+
.filter(function (deviceInfo) { return deviceInfo.kind === 'videoinput'; })
|
|
102
|
+
.find(function (deviceInfo) { return deviceInfo.deviceId === (capabilities === null || capabilities === void 0 ? void 0 : capabilities.deviceId); })) === null || _c === void 0 ? void 0 : _c.label];
|
|
103
|
+
}
|
|
104
|
+
});
|
|
105
|
+
}); };
|
|
106
|
+
export var getVideoTrack = function (videoStream) { var _a; return (((_a = videoStream === null || videoStream === void 0 ? void 0 : videoStream.getVideoTracks) === null || _a === void 0 ? void 0 : _a.call(videoStream)) || [])[0]; };
|
|
107
|
+
export var getVideoCapabilities = function (videoStream) { var _a, _b; return (_b = (_a = getVideoTrack(videoStream)) === null || _a === void 0 ? void 0 : _a.getCapabilities) === null || _b === void 0 ? void 0 : _b.call(_a); };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from './CameraStep';
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useIntl } from 'react-intl';
|
|
3
|
+
import { DynamicLayout } from '../../layout';
|
|
4
|
+
import messages from './ExternalConfirmationStep.messages';
|
|
5
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
6
|
+
var noop = function () { };
|
|
7
|
+
var ExternalConfirmationStep = function (_a) {
|
|
8
|
+
var url = _a.url, onClose = _a.onClose;
|
|
9
|
+
var formatMessage = useIntl().formatMessage;
|
|
10
|
+
return (_jsx(DynamicLayout, { components: [
|
|
11
|
+
{
|
|
12
|
+
type: 'box',
|
|
13
|
+
width: 'lg',
|
|
14
|
+
components: [
|
|
15
|
+
{
|
|
16
|
+
type: 'heading',
|
|
17
|
+
text: formatMessage(messages.title),
|
|
18
|
+
size: 'lg',
|
|
19
|
+
align: 'center',
|
|
20
|
+
margin: 'xl'
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
type: 'info',
|
|
24
|
+
markdown: formatMessage(messages.description, { origin: getOrigin(url) }),
|
|
25
|
+
align: 'center',
|
|
26
|
+
margin: 'xl'
|
|
27
|
+
},
|
|
28
|
+
{
|
|
29
|
+
type: 'box',
|
|
30
|
+
width: 'md',
|
|
31
|
+
components: [
|
|
32
|
+
{
|
|
33
|
+
type: 'button',
|
|
34
|
+
action: { title: formatMessage(messages.open), type: 'primary', url: url, exit: true }
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
type: 'button',
|
|
38
|
+
action: {
|
|
39
|
+
title: formatMessage(messages.cancel),
|
|
40
|
+
type: 'link',
|
|
41
|
+
url: '',
|
|
42
|
+
exit: true
|
|
43
|
+
}
|
|
44
|
+
},
|
|
45
|
+
]
|
|
46
|
+
},
|
|
47
|
+
]
|
|
48
|
+
},
|
|
49
|
+
], submitted: false, onAction: function (action) {
|
|
50
|
+
if (action.url) {
|
|
51
|
+
window.open(action.url, '_blank');
|
|
52
|
+
}
|
|
53
|
+
onClose();
|
|
54
|
+
}, onModelChange: noop, onPersistAsync: noop }));
|
|
55
|
+
};
|
|
56
|
+
export default ExternalConfirmationStep;
|
|
57
|
+
function getOrigin(url) {
|
|
58
|
+
try {
|
|
59
|
+
return new URL(url).origin;
|
|
60
|
+
}
|
|
61
|
+
catch (_a) {
|
|
62
|
+
return url;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { defineMessages } from 'react-intl';
|
|
2
|
+
export default defineMessages({
|
|
3
|
+
title: {
|
|
4
|
+
id: 'dynamicFlows.ExternalConfirmation.title',
|
|
5
|
+
defaultMessage: 'Please confirm',
|
|
6
|
+
description: 'Heading for the confirmation screen.'
|
|
7
|
+
},
|
|
8
|
+
description: {
|
|
9
|
+
id: 'dynamicFlows.ExternalConfirmation.description',
|
|
10
|
+
defaultMessage: 'Please confirm you want to open **{origin}** in a new browser tab.',
|
|
11
|
+
description: 'Description for the confirmation screen.'
|
|
12
|
+
},
|
|
13
|
+
open: {
|
|
14
|
+
id: 'dynamicFlows.ExternalConfirmation.open',
|
|
15
|
+
defaultMessage: 'Open in new tab',
|
|
16
|
+
description: 'Button text confirming opening a new browser tab.'
|
|
17
|
+
},
|
|
18
|
+
cancel: {
|
|
19
|
+
id: 'dynamicFlows.ExternalConfirmation.cancel',
|
|
20
|
+
defaultMessage: 'Cancel',
|
|
21
|
+
description: 'Button text rejecting opening a new browser tab.'
|
|
22
|
+
}
|
|
23
|
+
});
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from './ExternalConfirmationStep';
|