@ekyc_qoobiss/qbs-ect-cmp 3.2.0 → 3.2.2
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/README.md +19 -0
- package/dist/cjs/agreement-check_18.cjs.entry.js +393 -277
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/cjs/qbs-ect-cmp.cjs.js +1 -1
- package/dist/collection/components/base-component.js +48 -0
- package/dist/collection/components/common/camera-error/camera-error.js +9 -36
- package/dist/collection/components/common/id-back-capture/id-back-capture.js +2 -27
- package/dist/collection/components/common/id-capture/id-capture.js +2 -27
- package/dist/collection/components/common/selfie-capture/selfie-capture.js +4 -28
- package/dist/collection/components/controls/camera/camera.js +3 -23
- package/dist/collection/components/flow/agreement-info/agreement-info.js +6 -9
- package/dist/collection/components/flow/end-redirect/end-redirect.js +4 -9
- package/dist/collection/components/flow/id-double-side/id-double-side.js +31 -51
- package/dist/collection/components/flow/id-single-side/id-single-side.js +14 -42
- package/dist/collection/components/flow/landing-validation/landing-validation.js +19 -40
- package/dist/collection/components/flow/mobile-redirect/mobile-redirect.js +7 -10
- package/dist/collection/components/flow/sms-code-validation/sms-code-validation.js +12 -15
- package/dist/collection/components/flow/user-liveness/user-liveness.js +29 -49
- package/dist/collection/components/identification-component/identification-component.js +28 -25
- package/dist/collection/helpers/ApiCall.js +3 -3
- package/dist/collection/helpers/Cameras.js +3 -2
- package/dist/collection/helpers/DeviceDetection.js +83 -0
- package/dist/collection/helpers/Events.js +9 -0
- package/dist/collection/helpers/Stream.js +9 -8
- package/dist/collection/helpers/index.js +0 -33
- package/dist/collection/helpers/store.js +2 -0
- package/dist/collection/models/FlowSteps.js +19 -13
- package/dist/collection/models/IDevice.js +22 -1
- package/dist/collection/models/IEctStore.js +1 -0
- package/dist/esm/agreement-check_18.entry.js +393 -277
- package/dist/esm/loader.js +1 -1
- package/dist/esm/qbs-ect-cmp.js +1 -1
- package/dist/qbs-ect-cmp/{p-acda46c1.entry.js → p-29f81591.entry.js} +2 -2
- package/dist/qbs-ect-cmp/qbs-ect-cmp.esm.js +1 -1
- package/dist/types/components/base-component.d.ts +14 -0
- package/dist/types/components/common/camera-error/camera-error.d.ts +1 -3
- package/dist/types/components/common/id-back-capture/id-back-capture.d.ts +0 -2
- package/dist/types/components/common/id-capture/id-capture.d.ts +0 -2
- package/dist/types/components/common/selfie-capture/selfie-capture.d.ts +0 -2
- package/dist/types/components/controls/camera/camera.d.ts +0 -2
- package/dist/types/components/flow/agreement-info/agreement-info.d.ts +3 -3
- package/dist/types/components/flow/end-redirect/end-redirect.d.ts +1 -1
- package/dist/types/components/flow/id-double-side/id-double-side.d.ts +4 -5
- package/dist/types/components/flow/id-single-side/id-single-side.d.ts +3 -5
- package/dist/types/components/flow/landing-validation/landing-validation.d.ts +2 -3
- package/dist/types/components/flow/mobile-redirect/mobile-redirect.d.ts +1 -1
- package/dist/types/components/flow/sms-code-validation/sms-code-validation.d.ts +2 -2
- package/dist/types/components/flow/user-liveness/user-liveness.d.ts +3 -4
- package/dist/types/components/identification-component/identification-component.d.ts +1 -2
- package/dist/types/components.d.ts +0 -19
- package/dist/types/helpers/ApiCall.d.ts +4 -4
- package/dist/types/helpers/Cameras.d.ts +4 -4
- package/dist/types/helpers/DeviceDetection.d.ts +18 -0
- package/dist/types/helpers/Events.d.ts +2 -0
- package/dist/types/helpers/Stream.d.ts +1 -3
- package/dist/types/helpers/index.d.ts +0 -2
- package/dist/types/helpers/store.d.ts +2 -17
- package/dist/types/models/FlowSteps.d.ts +18 -13
- package/dist/types/models/IDevice.d.ts +32 -9
- package/dist/types/models/IEctStore.d.ts +20 -0
- package/package.json +1 -1
|
@@ -378,6 +378,8 @@ const { state, onChange } = createStore({
|
|
|
378
378
|
phoneValidation: true,
|
|
379
379
|
phoneNumber: '',
|
|
380
380
|
apiBaseUrl: 'https://apiro.id-kyc.com',
|
|
381
|
+
device: null,
|
|
382
|
+
recordingRetryCount: 0,
|
|
381
383
|
});
|
|
382
384
|
onChange('environment', value => {
|
|
383
385
|
state.debug = value == 'QA';
|
|
@@ -406,20 +408,26 @@ onChange('phoneValidation', value => {
|
|
|
406
408
|
|
|
407
409
|
var FlowSteps;
|
|
408
410
|
(function (FlowSteps) {
|
|
409
|
-
FlowSteps[
|
|
410
|
-
FlowSteps[
|
|
411
|
-
FlowSteps[
|
|
412
|
-
FlowSteps[
|
|
413
|
-
FlowSteps[
|
|
414
|
-
FlowSteps[
|
|
415
|
-
FlowSteps[
|
|
416
|
-
FlowSteps[
|
|
417
|
-
FlowSteps[
|
|
418
|
-
FlowSteps[
|
|
419
|
-
FlowSteps[
|
|
420
|
-
FlowSteps[
|
|
421
|
-
FlowSteps[
|
|
422
|
-
})(FlowSteps || (FlowSteps = {}));
|
|
411
|
+
FlowSteps["MobileRedirect"] = "mobile-redirect";
|
|
412
|
+
FlowSteps["Landing"] = "landing";
|
|
413
|
+
FlowSteps["Agreements"] = "agreements";
|
|
414
|
+
FlowSteps["OtpSend"] = "otp-send";
|
|
415
|
+
FlowSteps["OtpCheck"] = "otp-check";
|
|
416
|
+
FlowSteps["CiFrontHowTo"] = "ci-front-how-to";
|
|
417
|
+
FlowSteps["CiFront"] = "ci-front";
|
|
418
|
+
FlowSteps["CiBackHowTo"] = "ci-back-how-to";
|
|
419
|
+
FlowSteps["CiBack"] = "ci-back";
|
|
420
|
+
FlowSteps["SelfieHowTo"] = "selfie-how-to";
|
|
421
|
+
FlowSteps["Selfie"] = "selfie";
|
|
422
|
+
FlowSteps["End"] = "end";
|
|
423
|
+
FlowSteps["CameraError"] = "camera-error";
|
|
424
|
+
})(FlowSteps || (FlowSteps = {}));
|
|
425
|
+
var FlowMoments;
|
|
426
|
+
(function (FlowMoments) {
|
|
427
|
+
FlowMoments["Initialized"] = "initialized";
|
|
428
|
+
FlowMoments["Finalized"] = "finalized";
|
|
429
|
+
FlowMoments["None"] = "none";
|
|
430
|
+
})(FlowMoments || (FlowMoments = {}));
|
|
423
431
|
|
|
424
432
|
class ApiCall {
|
|
425
433
|
constructor() {
|
|
@@ -541,8 +549,8 @@ class ApiCall {
|
|
|
541
549
|
}
|
|
542
550
|
catch (_a) { }
|
|
543
551
|
}
|
|
544
|
-
async AddStep(step) {
|
|
545
|
-
let data = { requestId: state.requestId, redirectId: state.redirectId, step: FlowSteps[step] };
|
|
552
|
+
async AddStep(step, moment) {
|
|
553
|
+
let data = { requestId: state.requestId, redirectId: state.redirectId, step: FlowSteps[step], moment: FlowMoments[moment] };
|
|
546
554
|
let result = await this.post(this.urls.AddStep, JSON.stringify(data));
|
|
547
555
|
return result.saved;
|
|
548
556
|
}
|
|
@@ -584,6 +592,215 @@ const AgreementCheck = class {
|
|
|
584
592
|
};
|
|
585
593
|
AgreementCheck.style = agreementCheckCss;
|
|
586
594
|
|
|
595
|
+
var MobileOS;
|
|
596
|
+
(function (MobileOS) {
|
|
597
|
+
MobileOS["Android"] = "android";
|
|
598
|
+
MobileOS["iOS"] = "ios";
|
|
599
|
+
MobileOS["Unknown"] = "unknown";
|
|
600
|
+
MobileOS["WindowsPhone"] = "Windows Phone";
|
|
601
|
+
})(MobileOS || (MobileOS = {}));
|
|
602
|
+
var DesktopOS;
|
|
603
|
+
(function (DesktopOS) {
|
|
604
|
+
DesktopOS["Linux"] = "linux";
|
|
605
|
+
DesktopOS["MacOS"] = "mac_os";
|
|
606
|
+
DesktopOS["Unix"] = "unix";
|
|
607
|
+
DesktopOS["Unknown"] = "unknown";
|
|
608
|
+
DesktopOS["Windows"] = "windows";
|
|
609
|
+
})(DesktopOS || (DesktopOS = {}));
|
|
610
|
+
var Browser;
|
|
611
|
+
(function (Browser) {
|
|
612
|
+
Browser["Chrome"] = "chrome";
|
|
613
|
+
Browser["Firefox"] = "firefox";
|
|
614
|
+
Browser["Safari"] = "safari";
|
|
615
|
+
Browser["Unknown"] = "unknown";
|
|
616
|
+
})(Browser || (Browser = {}));
|
|
617
|
+
|
|
618
|
+
class DeviceDetection {
|
|
619
|
+
constructor() {
|
|
620
|
+
var _a, _b, _c, _d;
|
|
621
|
+
this.supportedScreenOrientation = (_b = (_a = ((screen === null || screen === void 0 ? void 0 : screen.orientation) || {}).type) !== null && _a !== void 0 ? _a : screen.mozOrientation) !== null && _b !== void 0 ? _b : screen.msOrientation;
|
|
622
|
+
this.safariScreenOrientation = !(screen === null || screen === void 0 ? void 0 : screen.orientation) && matchMedia('(orientation: portrait)').matches ? 'portrait-primary' : 'landscape-primary';
|
|
623
|
+
this.initialScreenOrientation = (_d = (_c = this.supportedScreenOrientation) !== null && _c !== void 0 ? _c : this.safariScreenOrientation) !== null && _d !== void 0 ? _d : 'portrait-primary';
|
|
624
|
+
this.userAgent = navigator.userAgent || navigator.vendor || window.opera || undefined;
|
|
625
|
+
this.isMobile = this.isMobileDevice();
|
|
626
|
+
this.isTablet = this.isTabletDevice();
|
|
627
|
+
this.isDesktop = !this.isMobile && !this.isTablet;
|
|
628
|
+
}
|
|
629
|
+
// Device typology
|
|
630
|
+
isMobileDevice() {
|
|
631
|
+
const regexs = [/(Android)(.+)(Mobile)/i, /BlackBerry/i, /iPhone|iPod/i, /Opera Mini/i, /IEMobile/i];
|
|
632
|
+
return regexs.some(b => this.userAgent.match(b));
|
|
633
|
+
}
|
|
634
|
+
isTabletDevice() {
|
|
635
|
+
const regex = /(ipad|tablet|(android(?!.*mobile))|(windows(?!.*phone)(.*touch))|kindle|playbook|silk|(puffin(?!.*(IP|AP|WP))))/;
|
|
636
|
+
return regex.test(this.userAgent.toLowerCase());
|
|
637
|
+
}
|
|
638
|
+
// Device Operating System
|
|
639
|
+
getMobileOS() {
|
|
640
|
+
if (this.isMobileDevice()) {
|
|
641
|
+
if (/windows phone/i.test(this.userAgent))
|
|
642
|
+
return MobileOS.WindowsPhone;
|
|
643
|
+
else if (/android/i.test(this.userAgent))
|
|
644
|
+
return MobileOS.Android;
|
|
645
|
+
else if (/iPad|iPhone|iPod/.test(this.userAgent) && !window.MSStream)
|
|
646
|
+
return MobileOS.iOS;
|
|
647
|
+
return MobileOS.Unknown;
|
|
648
|
+
}
|
|
649
|
+
else
|
|
650
|
+
return undefined;
|
|
651
|
+
}
|
|
652
|
+
getDesktopOS() {
|
|
653
|
+
if (this.isDesktop) {
|
|
654
|
+
if (this.userAgent.indexOf('Win') !== -1)
|
|
655
|
+
return DesktopOS.Windows;
|
|
656
|
+
else if (this.userAgent.indexOf('Mac') !== -1)
|
|
657
|
+
return DesktopOS.MacOS;
|
|
658
|
+
else if (this.userAgent.indexOf('X11') !== -1)
|
|
659
|
+
return DesktopOS.Unix;
|
|
660
|
+
else if (this.userAgent.indexOf('Linux') !== -1)
|
|
661
|
+
return DesktopOS.Linux;
|
|
662
|
+
return DesktopOS.Unknown;
|
|
663
|
+
}
|
|
664
|
+
else
|
|
665
|
+
return undefined;
|
|
666
|
+
}
|
|
667
|
+
getDeviceOS() {
|
|
668
|
+
var _a;
|
|
669
|
+
return (_a = this.getMobileOS()) !== null && _a !== void 0 ? _a : this.getDesktopOS();
|
|
670
|
+
}
|
|
671
|
+
getBrowser() {
|
|
672
|
+
var isChrome = /chrome/i.test(this.userAgent);
|
|
673
|
+
if (isChrome)
|
|
674
|
+
return Browser.Chrome;
|
|
675
|
+
if (/firefox/i.test(navigator.userAgent))
|
|
676
|
+
return Browser.Firefox;
|
|
677
|
+
else if (!isChrome && /safari/i.test(navigator.userAgent))
|
|
678
|
+
return Browser.Safari;
|
|
679
|
+
else
|
|
680
|
+
return Browser.Unknown;
|
|
681
|
+
}
|
|
682
|
+
getDevice() {
|
|
683
|
+
var device = {
|
|
684
|
+
isDesktop: this.isDesktop,
|
|
685
|
+
desktopOS: this.getDesktopOS(),
|
|
686
|
+
isWindowsDesktop: this.getDeviceOS() === DesktopOS.Windows,
|
|
687
|
+
isLinuxOrUnixDesktop: this.getDeviceOS() === DesktopOS.Linux || this.getDeviceOS() === DesktopOS.Unix,
|
|
688
|
+
isMobile: this.isMobile,
|
|
689
|
+
mobileOS: this.getMobileOS(),
|
|
690
|
+
isAndroidDevice: this.getDeviceOS() === MobileOS.Android,
|
|
691
|
+
isAppleDevice: this.getDeviceOS() === MobileOS.iOS || this.getDeviceOS() === DesktopOS.MacOS,
|
|
692
|
+
isUnknownMobileDevice: this.getDeviceOS() === MobileOS.Unknown,
|
|
693
|
+
browser: this.getBrowser(),
|
|
694
|
+
isTablet: this.isTablet,
|
|
695
|
+
initialScreenOrientation: this.initialScreenOrientation,
|
|
696
|
+
};
|
|
697
|
+
return device;
|
|
698
|
+
}
|
|
699
|
+
}
|
|
700
|
+
|
|
701
|
+
class Events {
|
|
702
|
+
static init(element) {
|
|
703
|
+
this.callingModule = element;
|
|
704
|
+
}
|
|
705
|
+
static flowEvent(step, moment) {
|
|
706
|
+
const eventName = `ect-${step.toString()}-${moment.toString()}-event`;
|
|
707
|
+
this.callingModule.dispatchEvent(new CustomEvent(eventName, {
|
|
708
|
+
detail: {},
|
|
709
|
+
bubbles: true,
|
|
710
|
+
cancelable: true,
|
|
711
|
+
composed: true,
|
|
712
|
+
}));
|
|
713
|
+
}
|
|
714
|
+
static flowStarted() {
|
|
715
|
+
this.callingModule.dispatchEvent(new CustomEvent('ect-started', {
|
|
716
|
+
detail: {},
|
|
717
|
+
bubbles: true,
|
|
718
|
+
cancelable: true,
|
|
719
|
+
composed: true,
|
|
720
|
+
}));
|
|
721
|
+
}
|
|
722
|
+
static flowAborted() {
|
|
723
|
+
sessionStorage.clear();
|
|
724
|
+
this.callingModule.dispatchEvent(new CustomEvent('ect-aborted', {
|
|
725
|
+
detail: {},
|
|
726
|
+
bubbles: true,
|
|
727
|
+
cancelable: true,
|
|
728
|
+
composed: true,
|
|
729
|
+
}));
|
|
730
|
+
}
|
|
731
|
+
static flowCompleted() {
|
|
732
|
+
sessionStorage.clear();
|
|
733
|
+
this.callingModule.dispatchEvent(new CustomEvent('ect-completed', {
|
|
734
|
+
detail: {},
|
|
735
|
+
bubbles: true,
|
|
736
|
+
cancelable: true,
|
|
737
|
+
composed: true,
|
|
738
|
+
}));
|
|
739
|
+
}
|
|
740
|
+
static flowError(error) {
|
|
741
|
+
sessionStorage.clear();
|
|
742
|
+
this.callingModule.dispatchEvent(new CustomEvent('ect-error', {
|
|
743
|
+
detail: { error },
|
|
744
|
+
bubbles: true,
|
|
745
|
+
cancelable: true,
|
|
746
|
+
composed: true,
|
|
747
|
+
}));
|
|
748
|
+
}
|
|
749
|
+
static tokenExpired() {
|
|
750
|
+
sessionStorage.clear();
|
|
751
|
+
this.callingModule.dispatchEvent(new CustomEvent('ect-session-expired', {
|
|
752
|
+
detail: {},
|
|
753
|
+
bubbles: true,
|
|
754
|
+
cancelable: true,
|
|
755
|
+
composed: true,
|
|
756
|
+
}));
|
|
757
|
+
}
|
|
758
|
+
}
|
|
759
|
+
|
|
760
|
+
class BaseComponent {
|
|
761
|
+
constructor(step) {
|
|
762
|
+
this.apiErrorEvent = null;
|
|
763
|
+
this.processError = null;
|
|
764
|
+
this.apiCall = new ApiCall();
|
|
765
|
+
if (step)
|
|
766
|
+
this.flowStep = step;
|
|
767
|
+
if (!state.device) {
|
|
768
|
+
state.device = new DeviceDetection().getDevice();
|
|
769
|
+
}
|
|
770
|
+
Events.init(window);
|
|
771
|
+
}
|
|
772
|
+
setEventEmitter(event) {
|
|
773
|
+
this.apiErrorEvent = event;
|
|
774
|
+
}
|
|
775
|
+
setErrorCallback(callback) {
|
|
776
|
+
this.processError = callback;
|
|
777
|
+
}
|
|
778
|
+
async initialize() {
|
|
779
|
+
Events.flowEvent(this.flowStep, FlowMoments.Initialized);
|
|
780
|
+
try {
|
|
781
|
+
await this.apiCall.AddStep(this.flowStep, FlowMoments.Initialized);
|
|
782
|
+
}
|
|
783
|
+
catch (e) {
|
|
784
|
+
if (this.apiErrorEvent)
|
|
785
|
+
this.apiErrorEvent.emit(e);
|
|
786
|
+
else
|
|
787
|
+
this.processError(e, FlowMoments.Initialized);
|
|
788
|
+
}
|
|
789
|
+
}
|
|
790
|
+
async finalize() {
|
|
791
|
+
Events.flowEvent(this.flowStep, FlowMoments.Finalized);
|
|
792
|
+
try {
|
|
793
|
+
await this.apiCall.AddStep(this.flowStep, FlowMoments.Finalized);
|
|
794
|
+
}
|
|
795
|
+
catch (e) {
|
|
796
|
+
if (this.apiErrorEvent)
|
|
797
|
+
this.apiErrorEvent.emit(e);
|
|
798
|
+
else
|
|
799
|
+
this.processError(e, FlowMoments.Initialized);
|
|
800
|
+
}
|
|
801
|
+
}
|
|
802
|
+
}
|
|
803
|
+
|
|
587
804
|
const agreementInfoCss = "";
|
|
588
805
|
|
|
589
806
|
const AgreementInfo = class {
|
|
@@ -594,24 +811,21 @@ const AgreementInfo = class {
|
|
|
594
811
|
this.termsChecked = undefined;
|
|
595
812
|
this.openAgreements = undefined;
|
|
596
813
|
this.openTerms = undefined;
|
|
814
|
+
this.baseComponent = new BaseComponent(FlowSteps.Agreements);
|
|
815
|
+
this.baseComponent.setEventEmitter(this.apiErrorEvent);
|
|
597
816
|
this.agreementsChecked = false;
|
|
598
817
|
this.termsChecked = false;
|
|
599
|
-
this.apiCall = new ApiCall();
|
|
600
818
|
}
|
|
601
819
|
async componentDidLoad() {
|
|
602
|
-
|
|
603
|
-
await this.apiCall.AddStep(FlowSteps.Agreements);
|
|
604
|
-
}
|
|
605
|
-
catch (e) {
|
|
606
|
-
this.apiErrorEvent.emit(e);
|
|
607
|
-
}
|
|
820
|
+
await this.baseComponent.initialize();
|
|
608
821
|
}
|
|
609
822
|
componentWillLoad() {
|
|
610
823
|
this.openAgreements = false;
|
|
611
824
|
this.openTerms = false;
|
|
612
825
|
}
|
|
613
|
-
buttonClick() {
|
|
826
|
+
async buttonClick() {
|
|
614
827
|
if (this.agreementsChecked && this.termsChecked) {
|
|
828
|
+
await this.baseComponent.finalize();
|
|
615
829
|
state.flowStatus = FlowStatus.PHONE;
|
|
616
830
|
}
|
|
617
831
|
}
|
|
@@ -4909,7 +5123,7 @@ class Stream {
|
|
|
4909
5123
|
setVerificationFinished(fun) {
|
|
4910
5124
|
this.verificationFinished = fun;
|
|
4911
5125
|
}
|
|
4912
|
-
constructor(
|
|
5126
|
+
constructor(_modelPath) {
|
|
4913
5127
|
this.streamPaused = false;
|
|
4914
5128
|
this.recordedChunks = [];
|
|
4915
5129
|
this.videoSize = { width: 0, height: 0 };
|
|
@@ -4920,13 +5134,12 @@ class Stream {
|
|
|
4920
5134
|
// this.dropMask();
|
|
4921
5135
|
// if (this.faceDetection) Detector.getInstance().stopDetector();
|
|
4922
5136
|
};
|
|
4923
|
-
this.
|
|
4924
|
-
this.
|
|
4925
|
-
this.faceML5Detector = FaceML5Detector.getInstance(this, device.isMobile);
|
|
5137
|
+
this.idML5Detector = IDML5Detector.getInstance(this, state.device.isMobile);
|
|
5138
|
+
this.faceML5Detector = FaceML5Detector.getInstance(this, state.device.isMobile);
|
|
4926
5139
|
}
|
|
4927
|
-
static getInstance(
|
|
5140
|
+
static getInstance(modelPath) {
|
|
4928
5141
|
if (!Stream.instance) {
|
|
4929
|
-
Stream.instance = new Stream(
|
|
5142
|
+
Stream.instance = new Stream(modelPath);
|
|
4930
5143
|
}
|
|
4931
5144
|
return Stream.instance;
|
|
4932
5145
|
}
|
|
@@ -4987,7 +5200,7 @@ class Stream {
|
|
|
4987
5200
|
recordStream() {
|
|
4988
5201
|
var options = { mimeType: Stream.webmMimeType.mime, videoBitsPerSecond: 1500000 };
|
|
4989
5202
|
if (!MediaRecorder.isTypeSupported(options.mimeType)) {
|
|
4990
|
-
if (
|
|
5203
|
+
if (state.device.mobileOS == MobileOS.iOS || state.device.browser == Browser.Safari)
|
|
4991
5204
|
options.mimeType = Stream.mp4MimeType.mime;
|
|
4992
5205
|
}
|
|
4993
5206
|
this.recordedChunks = [];
|
|
@@ -5042,7 +5255,7 @@ class Stream {
|
|
|
5042
5255
|
const context = canvas.getContext('2d');
|
|
5043
5256
|
context.drawImage(this.videoElement, 0, 0, canvas.width, canvas.height);
|
|
5044
5257
|
canvas.toBlob((frame) => {
|
|
5045
|
-
if (frame.type === ImageFormat.JPEG && !
|
|
5258
|
+
if (frame.type === ImageFormat.JPEG && !state.device.isAppleDevice) {
|
|
5046
5259
|
try {
|
|
5047
5260
|
addExifInImg(frame, this.stream.getTracks()[0], this.videoSize).then(updatedFrame => resolve(updatedFrame));
|
|
5048
5261
|
}
|
|
@@ -5135,7 +5348,6 @@ const Camera = class {
|
|
|
5135
5348
|
this.verificationFinished.emit();
|
|
5136
5349
|
};
|
|
5137
5350
|
this.modelPath = undefined;
|
|
5138
|
-
this.device = undefined;
|
|
5139
5351
|
this.probabilityThreshold = undefined;
|
|
5140
5352
|
this.captureMode = undefined;
|
|
5141
5353
|
}
|
|
@@ -5145,7 +5357,7 @@ const Camera = class {
|
|
|
5145
5357
|
render() {
|
|
5146
5358
|
let cameraVideoClass = 'cameraVideo';
|
|
5147
5359
|
let cameraCanvasClass = 'cameraCanvas';
|
|
5148
|
-
if (
|
|
5360
|
+
if (state.device.isDesktop) {
|
|
5149
5361
|
cameraVideoClass = 'cameraVideoSelfieDesk';
|
|
5150
5362
|
cameraCanvasClass = 'cameraCanvasSelfieDesk';
|
|
5151
5363
|
}
|
|
@@ -5157,7 +5369,7 @@ const Camera = class {
|
|
|
5157
5369
|
}
|
|
5158
5370
|
startStream() {
|
|
5159
5371
|
if (!Stream.instance)
|
|
5160
|
-
Stream.getInstance(this.
|
|
5372
|
+
Stream.getInstance(this.modelPath);
|
|
5161
5373
|
const stream = Stream.getInstance();
|
|
5162
5374
|
stream.updateHtmlElements(this.cameraVideo, this.cameraCanvas, this.component);
|
|
5163
5375
|
if (this.captureMode == 'selfie') {
|
|
@@ -5189,12 +5401,12 @@ const CameraError = class {
|
|
|
5189
5401
|
constructor(hostRef) {
|
|
5190
5402
|
index.registerInstance(this, hostRef);
|
|
5191
5403
|
this.apiErrorEvent = index.createEvent(this, "apiError", 7);
|
|
5192
|
-
this.device = undefined;
|
|
5193
5404
|
this.title = undefined;
|
|
5194
5405
|
this.description = undefined;
|
|
5195
5406
|
this.buttonDisabled = undefined;
|
|
5196
5407
|
this.demoVideo = undefined;
|
|
5197
|
-
this.
|
|
5408
|
+
this.baseComponent = new BaseComponent(FlowSteps.CameraError);
|
|
5409
|
+
this.baseComponent.setEventEmitter(this.apiErrorEvent);
|
|
5198
5410
|
}
|
|
5199
5411
|
async componentWillLoad() {
|
|
5200
5412
|
this.buttonDisabled = false;
|
|
@@ -5203,7 +5415,8 @@ const CameraError = class {
|
|
|
5203
5415
|
this.buttonText = CameraErrorValues.Button;
|
|
5204
5416
|
}
|
|
5205
5417
|
async componentDidLoad() {
|
|
5206
|
-
|
|
5418
|
+
await this.baseComponent.initialize();
|
|
5419
|
+
if (state.device.mobileOS != MobileOS.iOS) {
|
|
5207
5420
|
this.demoVideo.src = CameraErrorValues.HowToLink;
|
|
5208
5421
|
this.demoVideo.loop = true;
|
|
5209
5422
|
this.demoVideo.play();
|
|
@@ -5215,16 +5428,11 @@ const CameraError = class {
|
|
|
5215
5428
|
state.flowStatus = FlowStatus.LANDING;
|
|
5216
5429
|
}
|
|
5217
5430
|
}
|
|
5218
|
-
try {
|
|
5219
|
-
await this.apiCall.AddStep(FlowSteps.CameraError);
|
|
5220
|
-
}
|
|
5221
|
-
catch (e) {
|
|
5222
|
-
this.apiErrorEvent.emit(e);
|
|
5223
|
-
}
|
|
5224
5431
|
}
|
|
5225
5432
|
async buttonClick() {
|
|
5226
5433
|
this.buttonDisabled = true;
|
|
5227
|
-
|
|
5434
|
+
await this.baseComponent.finalize();
|
|
5435
|
+
if (state.device.mobileOS == MobileOS.iOS) {
|
|
5228
5436
|
sessionStorage.setItem(SessionKeys.RefreshDoneKey, 'true');
|
|
5229
5437
|
window.location.reload();
|
|
5230
5438
|
}
|
|
@@ -5233,7 +5441,7 @@ const CameraError = class {
|
|
|
5233
5441
|
}
|
|
5234
5442
|
}
|
|
5235
5443
|
render() {
|
|
5236
|
-
return (index.h("div", { class: "container" }, index.h("div", { class: "row" }, index.h("h1", { class: "color-red" }, this.title), index.h("div", null, index.h("p", { class: "color-red font-weight-bold font-size-25 mt-5" }, this.description)), index.h("div", { hidden:
|
|
5444
|
+
return (index.h("div", { class: "container" }, index.h("div", { class: "row" }, index.h("h1", { class: "color-red" }, this.title), index.h("div", null, index.h("p", { class: "color-red font-weight-bold font-size-25 mt-5" }, this.description)), index.h("div", { hidden: state.device.mobileOS == MobileOS.iOS }, index.h("video", { id: "howtoPermissions", class: "video-demo", playsinline: true, ref: el => (this.demoVideo = el) }, index.h("source", { type: "video/mp4" }))), index.h("div", { class: "pos-relative show-bottom" }, index.h("div", { class: "btn-buletin" }, index.h("button", { class: "main-button", type: "button", disabled: this.buttonDisabled, onClick: () => this.buttonClick() }, this.buttonText), index.h("p", { class: "main-text font-size-18 text-right mb-0" }, CameraErrorValues.FooterText))))));
|
|
5237
5445
|
}
|
|
5238
5446
|
};
|
|
5239
5447
|
CameraError.style = cameraErrorCss;
|
|
@@ -5283,74 +5491,19 @@ CaptureError.style = captureErrorCss;
|
|
|
5283
5491
|
|
|
5284
5492
|
const completeSvg = '';
|
|
5285
5493
|
|
|
5286
|
-
class Events {
|
|
5287
|
-
static init(element) {
|
|
5288
|
-
this.callingModule = element;
|
|
5289
|
-
}
|
|
5290
|
-
static flowStarted() {
|
|
5291
|
-
this.callingModule.dispatchEvent(new CustomEvent('ect-started', {
|
|
5292
|
-
detail: {},
|
|
5293
|
-
bubbles: true,
|
|
5294
|
-
cancelable: true,
|
|
5295
|
-
composed: true,
|
|
5296
|
-
}));
|
|
5297
|
-
}
|
|
5298
|
-
static flowAborted() {
|
|
5299
|
-
sessionStorage.clear();
|
|
5300
|
-
this.callingModule.dispatchEvent(new CustomEvent('ect-aborted', {
|
|
5301
|
-
detail: {},
|
|
5302
|
-
bubbles: true,
|
|
5303
|
-
cancelable: true,
|
|
5304
|
-
composed: true,
|
|
5305
|
-
}));
|
|
5306
|
-
}
|
|
5307
|
-
static flowCompleted() {
|
|
5308
|
-
sessionStorage.clear();
|
|
5309
|
-
this.callingModule.dispatchEvent(new CustomEvent('ect-completed', {
|
|
5310
|
-
detail: {},
|
|
5311
|
-
bubbles: true,
|
|
5312
|
-
cancelable: true,
|
|
5313
|
-
composed: true,
|
|
5314
|
-
}));
|
|
5315
|
-
}
|
|
5316
|
-
static flowError(error) {
|
|
5317
|
-
sessionStorage.clear();
|
|
5318
|
-
this.callingModule.dispatchEvent(new CustomEvent('ect-error', {
|
|
5319
|
-
detail: { error },
|
|
5320
|
-
bubbles: true,
|
|
5321
|
-
cancelable: true,
|
|
5322
|
-
composed: true,
|
|
5323
|
-
}));
|
|
5324
|
-
}
|
|
5325
|
-
static tokenExpired() {
|
|
5326
|
-
sessionStorage.clear();
|
|
5327
|
-
this.callingModule.dispatchEvent(new CustomEvent('ect-session-expired', {
|
|
5328
|
-
detail: {},
|
|
5329
|
-
bubbles: true,
|
|
5330
|
-
cancelable: true,
|
|
5331
|
-
composed: true,
|
|
5332
|
-
}));
|
|
5333
|
-
}
|
|
5334
|
-
}
|
|
5335
|
-
|
|
5336
5494
|
const endRedirectCss = "h1{font-family:'Inter', sans-serif;font-style:normal;font-weight:900;font-size:4vh;line-height:4vh;letter-spacing:0.01em;color:#1f2024}p{font-family:'Inter', sans-serif;font-style:normal;font-weight:400;font-size:2vh;line-height:3vh;color:#1f2024;text-align:justify}.container{gap:10rem;text-align:center}.greet{color:rgb(73, 78, 79);visibility:hidden;animation-name:rise;animation-delay:1s;animation-fill-mode:forwards}@keyframes rise{0%{visibility:hidden}50%{visibility:visible}100%{visibility:visible}}.container-coin{background-color:transparent;perspective:1000px;rotate:120deg 0deg}.coin-flip{animation:flip 0.4s ease-in;animation-delay:0.5s;transform-style:preserve-3d;animation-fill-mode:forwards;visibility:hidden}.coin-scale{animation:show 0.4s ease-in;animation-delay:0.5s;transform-style:preserve-3d;animation-fill-mode:forwards}.coin{margin-top:10rem}@keyframes flip{0%{transform:rotateX(140deg);visibility:visible}25%{transform:rotateX(120deg);visibility:visible}50%{transform:rotateX(90deg);visibility:visible}75%{transform:rotateX(75deg);visibility:visible}100%{transform:rotateX(0deg);visibility:visible}}@keyframes show{0%{transform:scale(0)}25%{transform:scale(0.2)}40%{transform:scale(0.4)}50%{transform:scale(0.5)}60%{transform:scale(0.6)}70%{transform:scale(0.7)}100%{transform:scale(1)}}";
|
|
5337
5495
|
|
|
5338
5496
|
const EndRedirect = class {
|
|
5339
5497
|
constructor(hostRef) {
|
|
5340
5498
|
index.registerInstance(this, hostRef);
|
|
5341
5499
|
this.apiErrorEvent = index.createEvent(this, "apiError", 7);
|
|
5342
|
-
this.
|
|
5500
|
+
this.baseComponent = new BaseComponent(FlowSteps.End);
|
|
5501
|
+
this.baseComponent.setEventEmitter(this.apiErrorEvent);
|
|
5343
5502
|
}
|
|
5344
5503
|
async componentDidLoad() {
|
|
5345
|
-
Events.init(window);
|
|
5346
5504
|
Events.flowCompleted();
|
|
5347
5505
|
if (state.environment !== 'DEMO') {
|
|
5348
|
-
|
|
5349
|
-
await this.apiCall.AddStep(FlowSteps.End);
|
|
5350
|
-
}
|
|
5351
|
-
catch (e) {
|
|
5352
|
-
this.apiErrorEvent.emit(e);
|
|
5353
|
-
}
|
|
5506
|
+
await this.baseComponent.initialize();
|
|
5354
5507
|
}
|
|
5355
5508
|
}
|
|
5356
5509
|
render() {
|
|
@@ -5432,7 +5585,7 @@ class Cameras {
|
|
|
5432
5585
|
const stream = await navigator.mediaDevices.getUserMedia(updatedConstraints);
|
|
5433
5586
|
stream.getVideoTracks().forEach(track => {
|
|
5434
5587
|
var _a, _b;
|
|
5435
|
-
if (deviceInfo.
|
|
5588
|
+
if (deviceInfo.browser === Browser.Firefox) {
|
|
5436
5589
|
const settings = track.getSettings();
|
|
5437
5590
|
let facingMode = settings.facingMode && settings.facingMode.length > 0 ? settings.facingMode[0] : '';
|
|
5438
5591
|
facingMode = facingMode === 'e' ? 'environment' : facingMode;
|
|
@@ -5498,7 +5651,7 @@ class Cameras {
|
|
|
5498
5651
|
exact: selectedDeviceId,
|
|
5499
5652
|
};
|
|
5500
5653
|
}
|
|
5501
|
-
if (device.
|
|
5654
|
+
if (device.isDesktop) {
|
|
5502
5655
|
constraints.video.width = { ideal: 1280 };
|
|
5503
5656
|
}
|
|
5504
5657
|
else {
|
|
@@ -5554,7 +5707,6 @@ const IdBackCapture = class {
|
|
|
5554
5707
|
//this.closeCamera();
|
|
5555
5708
|
this.eventPhotoCapture.emit(photos);
|
|
5556
5709
|
};
|
|
5557
|
-
this.device = undefined;
|
|
5558
5710
|
this.videoStarted = undefined;
|
|
5559
5711
|
this.cameraSize = undefined;
|
|
5560
5712
|
this.captureTaken = undefined;
|
|
@@ -5599,7 +5751,7 @@ const IdBackCapture = class {
|
|
|
5599
5751
|
this.openCamera();
|
|
5600
5752
|
}
|
|
5601
5753
|
async openCamera() {
|
|
5602
|
-
var constraints = this.cameras.GetConstraints(state.cameraId,
|
|
5754
|
+
var constraints = this.cameras.GetConstraints(state.cameraId, state.device);
|
|
5603
5755
|
setTimeout(() => {
|
|
5604
5756
|
navigator.mediaDevices
|
|
5605
5757
|
.getUserMedia(constraints)
|
|
@@ -5652,7 +5804,7 @@ const IdBackCapture = class {
|
|
|
5652
5804
|
let titleClass = this.verified ? 'color-black-2 text-center' : 'color-white text-center';
|
|
5653
5805
|
//let videoClass = this.device.isMobile ? '' : 'video-demo';
|
|
5654
5806
|
let bgDemo = this.verified ? 'container' : 'container bg-black';
|
|
5655
|
-
return (index.h("div", { class: bgDemo }, index.h("div", { class: "container-video" }, index.h("div", { hidden: this.showDemo == false }, index.h("video", { id: "howtoBack", class: "video-demo", playsinline: true, ref: el => (this.demoVideo = el) }, index.h("source", { type: "video/mp4" }))), index.h("div", { hidden: this.showDemo }, index.h("div", { hidden: this.verified }, index.h("div", { class: "video-capture" }, index.h("div", { style: cameraStyle }, index.h("div", { style: cameraStyleInner }, index.h("camera-comp", {
|
|
5807
|
+
return (index.h("div", { class: bgDemo }, index.h("div", { class: "container-video" }, index.h("div", { hidden: this.showDemo == false }, index.h("video", { id: "howtoBack", class: "video-demo", playsinline: true, ref: el => (this.demoVideo = el) }, index.h("source", { type: "video/mp4" }))), index.h("div", { hidden: this.showDemo }, index.h("div", { hidden: this.verified }, index.h("div", { class: "video-capture" }, index.h("div", { style: cameraStyle }, index.h("div", { style: cameraStyleInner }, index.h("camera-comp", { "capture-mode": "id" })))))), index.h("div", { class: "capture-title" }, index.h("h1", { class: titleClass }, this.titleMesage), index.h("p", { class: "main-text font-size-18 text-right mb-0" }, IdCaptureValues.FooterText)))));
|
|
5656
5808
|
}
|
|
5657
5809
|
get component() { return index.getElement(this); }
|
|
5658
5810
|
};
|
|
@@ -5669,7 +5821,6 @@ const IdCapture = class {
|
|
|
5669
5821
|
//this.closeCamera();
|
|
5670
5822
|
this.eventPhotoCapture.emit(photos);
|
|
5671
5823
|
};
|
|
5672
|
-
this.device = undefined;
|
|
5673
5824
|
this.videoStarted = undefined;
|
|
5674
5825
|
this.cameraSize = undefined;
|
|
5675
5826
|
this.captureTaken = undefined;
|
|
@@ -5710,7 +5861,7 @@ const IdCapture = class {
|
|
|
5710
5861
|
this.openCamera();
|
|
5711
5862
|
}
|
|
5712
5863
|
async openCamera() {
|
|
5713
|
-
var constraints = this.cameras.GetConstraints(state.cameraId,
|
|
5864
|
+
var constraints = this.cameras.GetConstraints(state.cameraId, state.device);
|
|
5714
5865
|
setTimeout(() => {
|
|
5715
5866
|
navigator.mediaDevices
|
|
5716
5867
|
.getUserMedia(constraints)
|
|
@@ -5768,7 +5919,7 @@ const IdCapture = class {
|
|
|
5768
5919
|
let titleClass = this.verified ? 'color-black-2 text-center' : 'color-white text-center';
|
|
5769
5920
|
//let videoClass = this.device.isMobile ? '' : 'video-demo';
|
|
5770
5921
|
let bgDemo = this.verified ? 'container' : 'container bg-black';
|
|
5771
|
-
return (index.h("div", { class: bgDemo }, index.h("div", { class: "container-video" }, index.h("div", { hidden: this.showDemo == false }, index.h("video", { id: "howtoFront", class: "video-demo", playsinline: true, ref: el => (this.demoVideo = el) }, index.h("source", { type: "video/mp4" }))), index.h("div", { hidden: this.showDemo }, index.h("div", { hidden: this.verified }, index.h("div", { class: "video-capture" }, index.h("div", { style: cameraStyle }, index.h("div", { style: cameraStyleInner }, index.h("camera-comp", {
|
|
5922
|
+
return (index.h("div", { class: bgDemo }, index.h("div", { class: "container-video" }, index.h("div", { hidden: this.showDemo == false }, index.h("video", { id: "howtoFront", class: "video-demo", playsinline: true, ref: el => (this.demoVideo = el) }, index.h("source", { type: "video/mp4" }))), index.h("div", { hidden: this.showDemo }, index.h("div", { hidden: this.verified }, index.h("div", { class: "video-capture" }, index.h("div", { style: cameraStyle }, index.h("div", { style: cameraStyleInner }, index.h("camera-comp", { "capture-mode": "id" })))))), index.h("div", { class: "capture-title" }, index.h("h1", { class: titleClass }, this.titleMesage), index.h("p", { class: "main-text font-size-18 text-right mb-0" }, IdCaptureValues.FooterText)))));
|
|
5772
5923
|
}
|
|
5773
5924
|
get component() { return index.getElement(this); }
|
|
5774
5925
|
};
|
|
@@ -5780,7 +5931,6 @@ const IdDoubleSide = class {
|
|
|
5780
5931
|
constructor(hostRef) {
|
|
5781
5932
|
index.registerInstance(this, hostRef);
|
|
5782
5933
|
this.apiErrorEvent = index.createEvent(this, "apiError", 7);
|
|
5783
|
-
this.device = undefined;
|
|
5784
5934
|
this.showTimeout = undefined;
|
|
5785
5935
|
this.showInvalid = undefined;
|
|
5786
5936
|
this.showHowTo = undefined;
|
|
@@ -5796,7 +5946,8 @@ const IdDoubleSide = class {
|
|
|
5796
5946
|
recordingFileName: '',
|
|
5797
5947
|
recordingUploadType: '',
|
|
5798
5948
|
};
|
|
5799
|
-
this.
|
|
5949
|
+
this.baseComponent = new BaseComponent(FlowSteps.CiBack);
|
|
5950
|
+
this.baseComponent.setEventEmitter(this.apiErrorEvent);
|
|
5800
5951
|
}
|
|
5801
5952
|
componentWillLoad() {
|
|
5802
5953
|
this.captureRetryCount = 0;
|
|
@@ -5833,7 +5984,7 @@ const IdDoubleSide = class {
|
|
|
5833
5984
|
async captureIdImage(event) {
|
|
5834
5985
|
let idPhoto = event.detail;
|
|
5835
5986
|
if (idPhoto.length == 0 || idPhoto.size == 0) {
|
|
5836
|
-
await this.apiCall.AddLog({ message: 'Empty id photo', blobData: idPhoto }, getLogMessage());
|
|
5987
|
+
await this.baseComponent.apiCall.AddLog({ message: 'Empty id photo', blobData: idPhoto }, getLogMessage());
|
|
5837
5988
|
return;
|
|
5838
5989
|
}
|
|
5839
5990
|
try {
|
|
@@ -5847,7 +5998,7 @@ const IdDoubleSide = class {
|
|
|
5847
5998
|
async captureIdBackImage(event) {
|
|
5848
5999
|
let idPhoto = event.detail;
|
|
5849
6000
|
if (idPhoto.length == 0 || idPhoto.size == 0) {
|
|
5850
|
-
await this.apiCall.AddLog({ message: 'Empty id photo', blobData: idPhoto }, getLogMessage());
|
|
6001
|
+
await this.baseComponent.apiCall.AddLog({ message: 'Empty id photo', blobData: idPhoto }, getLogMessage());
|
|
5851
6002
|
return;
|
|
5852
6003
|
}
|
|
5853
6004
|
try {
|
|
@@ -5861,7 +6012,7 @@ const IdDoubleSide = class {
|
|
|
5861
6012
|
async capturedIdRecording(event) {
|
|
5862
6013
|
let idRecording = event.detail;
|
|
5863
6014
|
if (idRecording.length == 0 || idRecording.size == 0) {
|
|
5864
|
-
await this.apiCall.AddLog({ message: 'Empty recording', blobData: idRecording }, getLogMessage());
|
|
6015
|
+
await this.baseComponent.apiCall.AddLog({ message: 'Empty recording', blobData: idRecording }, getLogMessage());
|
|
5865
6016
|
return;
|
|
5866
6017
|
}
|
|
5867
6018
|
let mimeType = idRecording.type == Stream.mp4MimeType.type ? Stream.mp4MimeType : Stream.webmMimeType;
|
|
@@ -5870,51 +6021,53 @@ const IdDoubleSide = class {
|
|
|
5870
6021
|
this.uploadRecording();
|
|
5871
6022
|
}
|
|
5872
6023
|
catch (e) {
|
|
5873
|
-
|
|
6024
|
+
if (state.recordingRetryCount < 3) {
|
|
6025
|
+
state.recordingRetryCount++;
|
|
6026
|
+
this.triggerErrorFlow();
|
|
6027
|
+
}
|
|
6028
|
+
else {
|
|
6029
|
+
this.apiErrorEvent.emit(e);
|
|
6030
|
+
}
|
|
5874
6031
|
}
|
|
5875
6032
|
}
|
|
5876
6033
|
async verificationFinished(_event) {
|
|
5877
6034
|
this.flow.verificationFinished = true;
|
|
5878
|
-
this.endFlow();
|
|
6035
|
+
await this.endFlow();
|
|
5879
6036
|
}
|
|
5880
6037
|
async componentDidLoad() {
|
|
5881
|
-
|
|
5882
|
-
await this.apiCall.AddStep(FlowSteps.CiBack);
|
|
5883
|
-
}
|
|
5884
|
-
catch (e) {
|
|
5885
|
-
this.apiErrorEvent.emit(e);
|
|
5886
|
-
}
|
|
6038
|
+
await this.baseComponent.initialize();
|
|
5887
6039
|
}
|
|
5888
6040
|
async uploadPhoto() {
|
|
5889
6041
|
if (this.flow.photoFile == null || this.flow.photoDone) {
|
|
5890
6042
|
return;
|
|
5891
6043
|
}
|
|
5892
|
-
this.flow.photoDone = await this.apiCall.UploadFileForRequestB64(state.requestId, this.flow.photoUploadType, this.flow.photoFile);
|
|
6044
|
+
this.flow.photoDone = await this.baseComponent.apiCall.UploadFileForRequestB64(state.requestId, this.flow.photoUploadType, this.flow.photoFile);
|
|
5893
6045
|
if (this.flow.photoDone) {
|
|
5894
|
-
this.endFlow();
|
|
6046
|
+
await this.endFlow();
|
|
5895
6047
|
}
|
|
5896
6048
|
else {
|
|
5897
|
-
this.flow.photoFile = null;
|
|
5898
|
-
this.flow.recordingFile = null;
|
|
5899
6049
|
this.switchCamera();
|
|
5900
|
-
this.
|
|
6050
|
+
this.triggerErrorFlow();
|
|
5901
6051
|
}
|
|
5902
6052
|
}
|
|
5903
6053
|
async uploadRecording() {
|
|
5904
6054
|
if (this.flow.recordingFile == null || this.flow.recordingDone) {
|
|
5905
6055
|
return;
|
|
5906
6056
|
}
|
|
5907
|
-
this.flow.recordingDone = await this.apiCall.UploadFileForRequestB64(state.requestId, this.flow.recordingUploadType, this.flow.recordingFile);
|
|
6057
|
+
this.flow.recordingDone = await this.baseComponent.apiCall.UploadFileForRequestB64(state.requestId, this.flow.recordingUploadType, this.flow.recordingFile);
|
|
5908
6058
|
if (this.flow.recordingDone) {
|
|
5909
|
-
this.endFlow();
|
|
6059
|
+
await this.endFlow();
|
|
5910
6060
|
}
|
|
5911
6061
|
else {
|
|
5912
|
-
this.
|
|
5913
|
-
this.flow.recordingFile = null;
|
|
5914
|
-
this.showInvalid = true;
|
|
6062
|
+
this.triggerErrorFlow();
|
|
5915
6063
|
}
|
|
5916
6064
|
}
|
|
5917
|
-
|
|
6065
|
+
triggerErrorFlow() {
|
|
6066
|
+
this.flow.photoFile = null;
|
|
6067
|
+
this.flow.recordingFile = null;
|
|
6068
|
+
this.showInvalid = true;
|
|
6069
|
+
}
|
|
6070
|
+
async endFlow() {
|
|
5918
6071
|
if (!this.flow.photoDone) {
|
|
5919
6072
|
return;
|
|
5920
6073
|
}
|
|
@@ -5937,6 +6090,8 @@ const IdDoubleSide = class {
|
|
|
5937
6090
|
if (!this.flow.verificationFinished) {
|
|
5938
6091
|
return;
|
|
5939
6092
|
}
|
|
6093
|
+
state.recordingRetryCount = 0;
|
|
6094
|
+
await this.baseComponent.finalize();
|
|
5940
6095
|
state.flowStatus = FlowStatus.LIVENESS;
|
|
5941
6096
|
}
|
|
5942
6097
|
switchCamera() {
|
|
@@ -5951,8 +6106,8 @@ const IdDoubleSide = class {
|
|
|
5951
6106
|
}
|
|
5952
6107
|
render() {
|
|
5953
6108
|
let error = index.h("capture-error", { type: "ID" });
|
|
5954
|
-
let frontCapture = index.h("id-capture", { id: "idFront"
|
|
5955
|
-
let secondCapture = index.h("id-back-capture", { id: "idBack"
|
|
6109
|
+
let frontCapture = index.h("id-capture", { id: "idFront" });
|
|
6110
|
+
let secondCapture = index.h("id-back-capture", { id: "idBack" });
|
|
5956
6111
|
let howToInfo = index.h("how-to-info", { idSide: this.front ? 'front' : 'back' });
|
|
5957
6112
|
return this.showHowTo ? howToInfo : this.showInvalid || this.showTimeout ? error : this.front ? frontCapture : secondCapture;
|
|
5958
6113
|
}
|
|
@@ -5965,7 +6120,6 @@ const IdSingleSide = class {
|
|
|
5965
6120
|
constructor(hostRef) {
|
|
5966
6121
|
index.registerInstance(this, hostRef);
|
|
5967
6122
|
this.apiErrorEvent = index.createEvent(this, "apiError", 7);
|
|
5968
|
-
this.device = undefined;
|
|
5969
6123
|
this.showTimeout = undefined;
|
|
5970
6124
|
this.showHowTo = undefined;
|
|
5971
6125
|
this.idFlow = {
|
|
@@ -5975,7 +6129,8 @@ const IdSingleSide = class {
|
|
|
5975
6129
|
photoFile: null,
|
|
5976
6130
|
recordingFile: null,
|
|
5977
6131
|
};
|
|
5978
|
-
this.
|
|
6132
|
+
this.baseComponent = new BaseComponent(FlowSteps.CiFront);
|
|
6133
|
+
this.baseComponent.setEventEmitter(this.apiErrorEvent);
|
|
5979
6134
|
this.captureRetryCount = 0;
|
|
5980
6135
|
this.showHowTo = true;
|
|
5981
6136
|
}
|
|
@@ -5993,7 +6148,7 @@ const IdSingleSide = class {
|
|
|
5993
6148
|
async captureIdImage(event) {
|
|
5994
6149
|
let idPhoto = event.detail;
|
|
5995
6150
|
if (idPhoto.length == 0 || idPhoto.size == 0) {
|
|
5996
|
-
await this.apiCall.AddLog({ message: 'Empty id photo', blobData: idPhoto }, getLogMessage());
|
|
6151
|
+
await this.baseComponent.apiCall.AddLog({ message: 'Empty id photo', blobData: idPhoto }, getLogMessage());
|
|
5997
6152
|
return;
|
|
5998
6153
|
}
|
|
5999
6154
|
try {
|
|
@@ -6006,12 +6161,12 @@ const IdSingleSide = class {
|
|
|
6006
6161
|
}
|
|
6007
6162
|
async verificationFinished(_event) {
|
|
6008
6163
|
this.idFlow.verificationFinished = true;
|
|
6009
|
-
this.endFlow();
|
|
6164
|
+
await this.endFlow();
|
|
6010
6165
|
}
|
|
6011
6166
|
async capturedIdRecording(event) {
|
|
6012
6167
|
let idRecording = event.detail;
|
|
6013
6168
|
if (idRecording.length == 0 || idRecording.size == 0) {
|
|
6014
|
-
await this.apiCall.AddLog({ message: 'Empty recording', blobData: idRecording }, getLogMessage());
|
|
6169
|
+
await this.baseComponent.apiCall.AddLog({ message: 'Empty recording', blobData: idRecording }, getLogMessage());
|
|
6015
6170
|
return;
|
|
6016
6171
|
}
|
|
6017
6172
|
let mimeType = idRecording.type == Stream.mp4MimeType.type ? Stream.mp4MimeType : Stream.webmMimeType;
|
|
@@ -6026,20 +6181,15 @@ const IdSingleSide = class {
|
|
|
6026
6181
|
}
|
|
6027
6182
|
}
|
|
6028
6183
|
async componentDidLoad() {
|
|
6029
|
-
|
|
6030
|
-
await this.apiCall.AddStep(FlowSteps.CiFront);
|
|
6031
|
-
}
|
|
6032
|
-
catch (e) {
|
|
6033
|
-
this.apiErrorEvent.emit(e);
|
|
6034
|
-
}
|
|
6184
|
+
await this.baseComponent.initialize();
|
|
6035
6185
|
}
|
|
6036
6186
|
async uploadPhoto() {
|
|
6037
6187
|
if (this.idFlow.photoFile == null || this.idFlow.photoDone) {
|
|
6038
6188
|
return;
|
|
6039
6189
|
}
|
|
6040
|
-
this.idFlow.photoDone = await this.apiCall.UploadFileForRequestB64(state.requestId, 'IdFront', this.idFlow.photoFile);
|
|
6190
|
+
this.idFlow.photoDone = await this.baseComponent.apiCall.UploadFileForRequestB64(state.requestId, 'IdFront', this.idFlow.photoFile);
|
|
6041
6191
|
if (this.idFlow.photoDone) {
|
|
6042
|
-
this.endFlow();
|
|
6192
|
+
await this.endFlow();
|
|
6043
6193
|
}
|
|
6044
6194
|
else {
|
|
6045
6195
|
this.idFlow.photoFile = null;
|
|
@@ -6052,9 +6202,9 @@ const IdSingleSide = class {
|
|
|
6052
6202
|
if (this.idFlow.recordingFile == null || this.idFlow.recordingDone) {
|
|
6053
6203
|
return;
|
|
6054
6204
|
}
|
|
6055
|
-
this.idFlow.recordingDone = await this.apiCall.UploadFileForRequestB64(state.requestId, 'IdFrontVideo', this.idFlow.recordingFile);
|
|
6205
|
+
this.idFlow.recordingDone = await this.baseComponent.apiCall.UploadFileForRequestB64(state.requestId, 'IdFrontVideo', this.idFlow.recordingFile);
|
|
6056
6206
|
if (this.idFlow.recordingDone) {
|
|
6057
|
-
this.endFlow();
|
|
6207
|
+
await this.endFlow();
|
|
6058
6208
|
}
|
|
6059
6209
|
else {
|
|
6060
6210
|
this.idFlow.photoFile = null;
|
|
@@ -6062,7 +6212,7 @@ const IdSingleSide = class {
|
|
|
6062
6212
|
this.showTimeout = true;
|
|
6063
6213
|
}
|
|
6064
6214
|
}
|
|
6065
|
-
endFlow() {
|
|
6215
|
+
async endFlow() {
|
|
6066
6216
|
if (!this.idFlow.photoDone) {
|
|
6067
6217
|
return;
|
|
6068
6218
|
}
|
|
@@ -6072,6 +6222,7 @@ const IdSingleSide = class {
|
|
|
6072
6222
|
if (!this.idFlow.verificationFinished) {
|
|
6073
6223
|
return;
|
|
6074
6224
|
}
|
|
6225
|
+
await this.baseComponent.finalize();
|
|
6075
6226
|
state.flowStatus = FlowStatus.LIVENESS;
|
|
6076
6227
|
}
|
|
6077
6228
|
switchCamera() {
|
|
@@ -6086,47 +6237,13 @@ const IdSingleSide = class {
|
|
|
6086
6237
|
}
|
|
6087
6238
|
render() {
|
|
6088
6239
|
let error = index.h("capture-error", { type: "ID" });
|
|
6089
|
-
let capture = index.h("id-capture", { id: "idFront"
|
|
6240
|
+
let capture = index.h("id-capture", { id: "idFront" });
|
|
6090
6241
|
let howToInfo = index.h("how-to-info", { idSide: "front" });
|
|
6091
6242
|
return this.showHowTo ? howToInfo : this.showTimeout ? error : capture;
|
|
6092
6243
|
}
|
|
6093
6244
|
};
|
|
6094
6245
|
IdSingleSide.style = idSingleSideCss;
|
|
6095
6246
|
|
|
6096
|
-
const initDevice = () => {
|
|
6097
|
-
let device = {
|
|
6098
|
-
isMobile: false,
|
|
6099
|
-
isAndroid: false,
|
|
6100
|
-
isLinux: false,
|
|
6101
|
-
isMac: false,
|
|
6102
|
-
isWin: false,
|
|
6103
|
-
isChrome: false,
|
|
6104
|
-
isFirefox: false,
|
|
6105
|
-
isSafari: false,
|
|
6106
|
-
isIos: false,
|
|
6107
|
-
};
|
|
6108
|
-
device.isMobile = /Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent);
|
|
6109
|
-
device.isAndroid = /Android/i.test(navigator.userAgent);
|
|
6110
|
-
device.isIos = /iPhone|iPad|iPod/i.test(navigator.userAgent);
|
|
6111
|
-
device.isLinux = /linux/i.test(navigator.platform);
|
|
6112
|
-
device.isMac = /mac/i.test(navigator.platform);
|
|
6113
|
-
device.isWin = /win/i.test(navigator.platform);
|
|
6114
|
-
device.isChrome = /chrome/i.test(navigator.userAgent);
|
|
6115
|
-
device.isFirefox = /firefox/i.test(navigator.userAgent);
|
|
6116
|
-
device.isSafari = !device.isChrome ? /safari/i.test(navigator.userAgent) : false;
|
|
6117
|
-
device.isMobile = /Android|webOS|iPhone|iPad|iPod|BlackBerry/i.test(navigator.userAgent);
|
|
6118
|
-
device.isAndroid = /Android/i.test(navigator.userAgent);
|
|
6119
|
-
device.isIos = /iPhone|iPad|iPod/i.test(navigator.userAgent);
|
|
6120
|
-
if (!device.isIos) {
|
|
6121
|
-
const isIPad = navigator.userAgent.match(/Mac/) && navigator.maxTouchPoints && navigator.maxTouchPoints > 2;
|
|
6122
|
-
if (isIPad) {
|
|
6123
|
-
device.isIos = true;
|
|
6124
|
-
device.isMobile = true;
|
|
6125
|
-
}
|
|
6126
|
-
}
|
|
6127
|
-
return device;
|
|
6128
|
-
};
|
|
6129
|
-
|
|
6130
6247
|
// Unique ID creation requires a high quality random # generator. In the browser we therefore
|
|
6131
6248
|
// require the crypto API and do not support built-in fallback to lower quality random number
|
|
6132
6249
|
// generators (like Math.random()).
|
|
@@ -6193,7 +6310,7 @@ function v4(options, buf, offset) {
|
|
|
6193
6310
|
}
|
|
6194
6311
|
|
|
6195
6312
|
const name = "@ekyc_qoobiss/qbs-ect-cmp";
|
|
6196
|
-
const version$1 = "3.2.
|
|
6313
|
+
const version$1 = "3.2.2";
|
|
6197
6314
|
const description = "Person Identification Component";
|
|
6198
6315
|
const main = "./dist/index.cjs.js";
|
|
6199
6316
|
const module$1 = "./dist/index.js";
|
|
@@ -6282,10 +6399,10 @@ const IdentificationComponent = class {
|
|
|
6282
6399
|
if (state.requestId !== newValue && newValue != '') {
|
|
6283
6400
|
state.requestId = newValue;
|
|
6284
6401
|
state.initialised = false;
|
|
6402
|
+
await this.initializeRequest();
|
|
6285
6403
|
if (state.flowStatus != FlowStatus.LANDING) {
|
|
6286
6404
|
state.flowStatus = FlowStatus.LANDING;
|
|
6287
6405
|
}
|
|
6288
|
-
await this.initializeRequest();
|
|
6289
6406
|
}
|
|
6290
6407
|
}
|
|
6291
6408
|
onApiUrlChange(newValue, _oldValue) {
|
|
@@ -6329,7 +6446,7 @@ const IdentificationComponent = class {
|
|
|
6329
6446
|
}
|
|
6330
6447
|
agreementAcceptanceEmitted(data) {
|
|
6331
6448
|
try {
|
|
6332
|
-
this.apiCall.GenerateAgreement(data.detail.agreementType);
|
|
6449
|
+
this.baseComponent.apiCall.GenerateAgreement(data.detail.agreementType);
|
|
6333
6450
|
}
|
|
6334
6451
|
catch (e) {
|
|
6335
6452
|
this.apiErrorEmitter(e, 'Agreement Acceptance');
|
|
@@ -6351,7 +6468,7 @@ const IdentificationComponent = class {
|
|
|
6351
6468
|
else {
|
|
6352
6469
|
this.errorTitle = data;
|
|
6353
6470
|
}
|
|
6354
|
-
await this.apiCall.AddLog(apiLogData, getLogMessage(this.order_id, this.redirect_id, this.token));
|
|
6471
|
+
await this.baseComponent.apiCall.AddLog(apiLogData, getLogMessage(this.order_id, this.redirect_id, this.token));
|
|
6355
6472
|
Events.flowError(data);
|
|
6356
6473
|
state.flowStatus = FlowStatus.ERROREND;
|
|
6357
6474
|
}
|
|
@@ -6367,7 +6484,8 @@ const IdentificationComponent = class {
|
|
|
6367
6484
|
this.idSide = '';
|
|
6368
6485
|
this.errorMessage = undefined;
|
|
6369
6486
|
this.errorTitle = undefined;
|
|
6370
|
-
this.
|
|
6487
|
+
this.baseComponent = new BaseComponent(null);
|
|
6488
|
+
this.baseComponent.setErrorCallback(this.apiErrorEmitter);
|
|
6371
6489
|
}
|
|
6372
6490
|
async componentWillLoad() {
|
|
6373
6491
|
Events.init(window);
|
|
@@ -6394,13 +6512,6 @@ const IdentificationComponent = class {
|
|
|
6394
6512
|
if (this.phone_number && this.phone_number != '') {
|
|
6395
6513
|
state.phoneNumber = this.phone_number;
|
|
6396
6514
|
}
|
|
6397
|
-
var flowSt = sessionStorage.getItem(SessionKeys.FlowStatusKey);
|
|
6398
|
-
if (flowSt) {
|
|
6399
|
-
state.flowStatus = FlowStatus[flowSt];
|
|
6400
|
-
}
|
|
6401
|
-
else {
|
|
6402
|
-
state.flowStatus = FlowStatus.LANDING;
|
|
6403
|
-
}
|
|
6404
6515
|
var ini = sessionStorage.getItem(SessionKeys.InitialisedKey);
|
|
6405
6516
|
if (ini && ini.toLowerCase() == 'true') {
|
|
6406
6517
|
state.initialised = true;
|
|
@@ -6417,17 +6528,18 @@ const IdentificationComponent = class {
|
|
|
6417
6528
|
if (phoneVal && phoneVal.toLowerCase() == 'true') {
|
|
6418
6529
|
state.phoneValidation = true;
|
|
6419
6530
|
}
|
|
6531
|
+
var flowStatusToSet = null;
|
|
6420
6532
|
const savedRequest = sessionStorage.getItem(SessionKeys.RequestIdKey);
|
|
6421
6533
|
if (this.order_id && this.order_id != '') {
|
|
6534
|
+
state.requestId = this.order_id;
|
|
6422
6535
|
if (state.debug)
|
|
6423
6536
|
console.log('Current RequestId has value: ' + this.order_id);
|
|
6424
6537
|
if (savedRequest && savedRequest != '' && savedRequest != this.order_id) {
|
|
6425
6538
|
if (state.debug)
|
|
6426
6539
|
console.log('Session RequestId: ' + savedRequest + ' has different value than property one: ' + this.order_id);
|
|
6427
|
-
|
|
6540
|
+
flowStatusToSet = FlowStatus.LANDING;
|
|
6428
6541
|
state.initialised = false;
|
|
6429
6542
|
}
|
|
6430
|
-
state.requestId = this.order_id;
|
|
6431
6543
|
}
|
|
6432
6544
|
else if (savedRequest) {
|
|
6433
6545
|
if (state.debug)
|
|
@@ -6435,8 +6547,17 @@ const IdentificationComponent = class {
|
|
|
6435
6547
|
state.requestId = savedRequest;
|
|
6436
6548
|
this.order_id = savedRequest;
|
|
6437
6549
|
}
|
|
6438
|
-
|
|
6550
|
+
if (flowStatusToSet == null) {
|
|
6551
|
+
var flowSt = sessionStorage.getItem(SessionKeys.FlowStatusKey);
|
|
6552
|
+
if (flowSt) {
|
|
6553
|
+
flowStatusToSet = FlowStatus[flowSt];
|
|
6554
|
+
}
|
|
6555
|
+
else {
|
|
6556
|
+
flowStatusToSet = FlowStatus.LANDING;
|
|
6557
|
+
}
|
|
6558
|
+
}
|
|
6439
6559
|
await this.initializeRequest();
|
|
6560
|
+
state.flowStatus = flowStatusToSet;
|
|
6440
6561
|
}
|
|
6441
6562
|
componentWillRender() {
|
|
6442
6563
|
if (this.idSide == '') {
|
|
@@ -6453,16 +6574,16 @@ const IdentificationComponent = class {
|
|
|
6453
6574
|
}
|
|
6454
6575
|
try {
|
|
6455
6576
|
if (state.debug)
|
|
6456
|
-
this.apiCall.AddLog('init log', this.logInit);
|
|
6577
|
+
this.baseComponent.apiCall.AddLog('init log', this.logInit);
|
|
6457
6578
|
}
|
|
6458
6579
|
catch (_a) { }
|
|
6459
6580
|
try {
|
|
6460
|
-
if (!
|
|
6581
|
+
if (!state.device.isMobile && state.redirectId == '') {
|
|
6461
6582
|
state.redirectId = v4();
|
|
6462
6583
|
this.redirect_id = state.redirectId;
|
|
6463
6584
|
}
|
|
6464
6585
|
if (state.token != '' && (state.requestId != '' || state.redirectId != '')) {
|
|
6465
|
-
state.initialised = await this.apiCall.AddIdentificationRequest(
|
|
6586
|
+
state.initialised = await this.baseComponent.apiCall.AddIdentificationRequest(state.device, packageJson.version);
|
|
6466
6587
|
if (!this.order_id || this.order_id == '') {
|
|
6467
6588
|
this.order_id = state.requestId;
|
|
6468
6589
|
}
|
|
@@ -6475,9 +6596,9 @@ const IdentificationComponent = class {
|
|
|
6475
6596
|
}
|
|
6476
6597
|
render() {
|
|
6477
6598
|
let currentBlock = index.h("div", null);
|
|
6478
|
-
if (
|
|
6599
|
+
if (state.device.isMobile || state.environment == 'DEMO') {
|
|
6479
6600
|
if (state.flowStatus == FlowStatus.LANDING) {
|
|
6480
|
-
currentBlock = index.h("landing-validation",
|
|
6601
|
+
currentBlock = index.h("landing-validation", null);
|
|
6481
6602
|
}
|
|
6482
6603
|
}
|
|
6483
6604
|
else {
|
|
@@ -6496,13 +6617,13 @@ const IdentificationComponent = class {
|
|
|
6496
6617
|
currentBlock = index.h("sms-code-validation", null);
|
|
6497
6618
|
}
|
|
6498
6619
|
if (state.flowStatus == FlowStatus.ID && !state.hasIdBack) {
|
|
6499
|
-
currentBlock = index.h("id-single-side", { id: "idFront"
|
|
6620
|
+
currentBlock = index.h("id-single-side", { id: "idFront" });
|
|
6500
6621
|
}
|
|
6501
6622
|
if (state.flowStatus == FlowStatus.ID && state.hasIdBack) {
|
|
6502
|
-
currentBlock = index.h("id-double-side", { id: "idFront"
|
|
6623
|
+
currentBlock = index.h("id-double-side", { id: "idFront" });
|
|
6503
6624
|
}
|
|
6504
6625
|
if (state.flowStatus == FlowStatus.LIVENESS) {
|
|
6505
|
-
currentBlock = index.h("user-liveness", {
|
|
6626
|
+
currentBlock = index.h("user-liveness", { id: "camera" });
|
|
6506
6627
|
}
|
|
6507
6628
|
if (state.flowStatus == FlowStatus.COMPLETE) {
|
|
6508
6629
|
currentBlock = index.h("end-redirect", null);
|
|
@@ -6511,7 +6632,7 @@ const IdentificationComponent = class {
|
|
|
6511
6632
|
currentBlock = index.h("error-end", { errorTitle: this.errorTitle, message: this.errorMessage });
|
|
6512
6633
|
}
|
|
6513
6634
|
if (state.flowStatus == FlowStatus.CAMERAERROR) {
|
|
6514
|
-
currentBlock = index.h("camera-error",
|
|
6635
|
+
currentBlock = index.h("camera-error", null);
|
|
6515
6636
|
}
|
|
6516
6637
|
return index.h("div", null, currentBlock);
|
|
6517
6638
|
}
|
|
@@ -6530,22 +6651,23 @@ const infoSvg = '
|
|
|
6530
6651
|
|
|
6531
6652
|
const idSvg = '';
|
|
6532
6653
|
|
|
6533
|
-
const deviceSvg = '';
|
|
6534
|
-
|
|
6535
6654
|
const validationSvg = '';
|
|
6536
6655
|
|
|
6656
|
+
const deviceSvg = '';
|
|
6657
|
+
|
|
6537
6658
|
const landingValidationCss = "";
|
|
6538
6659
|
|
|
6539
6660
|
const LandingValidation = class {
|
|
6540
6661
|
constructor(hostRef) {
|
|
6541
6662
|
index.registerInstance(this, hostRef);
|
|
6542
6663
|
this.apiErrorEvent = index.createEvent(this, "apiError", 7);
|
|
6543
|
-
this.device = undefined;
|
|
6544
6664
|
this.warningText = undefined;
|
|
6545
6665
|
this.buttonDisabled = undefined;
|
|
6666
|
+
this.baseComponent = new BaseComponent(FlowSteps.Landing);
|
|
6667
|
+
this.baseComponent.setEventEmitter(this.apiErrorEvent);
|
|
6546
6668
|
}
|
|
6547
6669
|
async componentWillLoad() {
|
|
6548
|
-
this.apiCall = new ApiCall();
|
|
6670
|
+
this.baseComponent.apiCall = new ApiCall();
|
|
6549
6671
|
this.buttonDisabled = false;
|
|
6550
6672
|
await this.initRequest();
|
|
6551
6673
|
}
|
|
@@ -6553,12 +6675,7 @@ const LandingValidation = class {
|
|
|
6553
6675
|
Events.init(window);
|
|
6554
6676
|
Events.flowStarted();
|
|
6555
6677
|
if (state.environment !== 'DEMO') {
|
|
6556
|
-
|
|
6557
|
-
await this.apiCall.AddStep(FlowSteps.Landing);
|
|
6558
|
-
}
|
|
6559
|
-
catch (e) {
|
|
6560
|
-
this.apiErrorEvent.emit(e);
|
|
6561
|
-
}
|
|
6678
|
+
await this.baseComponent.initialize();
|
|
6562
6679
|
}
|
|
6563
6680
|
}
|
|
6564
6681
|
async initRequest() {
|
|
@@ -6576,8 +6693,9 @@ const LandingValidation = class {
|
|
|
6576
6693
|
state.flowStatus = FlowStatus.COMPLETE;
|
|
6577
6694
|
return;
|
|
6578
6695
|
}
|
|
6579
|
-
|
|
6580
|
-
|
|
6696
|
+
await this.baseComponent.finalize();
|
|
6697
|
+
if (!(await Cameras.InitCameras(state.device))) {
|
|
6698
|
+
if (state.device.mobileOS == MobileOS.iOS)
|
|
6581
6699
|
sessionStorage.setItem(SessionKeys.RefreshDoneKey, 'false');
|
|
6582
6700
|
state.flowStatus = FlowStatus.CAMERAERROR;
|
|
6583
6701
|
}
|
|
@@ -6597,7 +6715,8 @@ const LandingValidation = class {
|
|
|
6597
6715
|
return;
|
|
6598
6716
|
state.initialised = false;
|
|
6599
6717
|
try {
|
|
6600
|
-
await this.apiCall.AbortRequest();
|
|
6718
|
+
await this.baseComponent.apiCall.AbortRequest();
|
|
6719
|
+
await this.baseComponent.finalize();
|
|
6601
6720
|
Events.flowAborted();
|
|
6602
6721
|
}
|
|
6603
6722
|
catch (e) {
|
|
@@ -9499,7 +9618,8 @@ const MobileRedirect = class {
|
|
|
9499
9618
|
this.redirectLink = undefined;
|
|
9500
9619
|
this.qrCode = undefined;
|
|
9501
9620
|
this.prefilledPhone = false;
|
|
9502
|
-
this.
|
|
9621
|
+
this.baseComponent = new BaseComponent(FlowSteps.MobileRedirect);
|
|
9622
|
+
this.baseComponent.setEventEmitter(this.apiErrorEvent);
|
|
9503
9623
|
this.invalidValue = false;
|
|
9504
9624
|
this.waitingMobile = false;
|
|
9505
9625
|
}
|
|
@@ -9523,12 +9643,7 @@ const MobileRedirect = class {
|
|
|
9523
9643
|
async componentDidLoad() {
|
|
9524
9644
|
Events.init(window);
|
|
9525
9645
|
Events.flowStarted();
|
|
9526
|
-
|
|
9527
|
-
await this.apiCall.AddStep(FlowSteps.MobileRedirect);
|
|
9528
|
-
}
|
|
9529
|
-
catch (e) {
|
|
9530
|
-
this.apiErrorEvent.emit(e);
|
|
9531
|
-
}
|
|
9646
|
+
await this.baseComponent.initialize();
|
|
9532
9647
|
await delay(5000);
|
|
9533
9648
|
await this.checkStatus();
|
|
9534
9649
|
while (this.orderStatus == OrderStatuses.Capturing || this.orderStatus == OrderStatuses.Waiting) {
|
|
@@ -9537,9 +9652,10 @@ const MobileRedirect = class {
|
|
|
9537
9652
|
}
|
|
9538
9653
|
}
|
|
9539
9654
|
async checkStatus() {
|
|
9540
|
-
this.orderStatus = await this.apiCall.GetStatus(state.requestId);
|
|
9655
|
+
this.orderStatus = await this.baseComponent.apiCall.GetStatus(state.requestId);
|
|
9541
9656
|
if (this.orderStatus == OrderStatuses.FinishedCapturing) {
|
|
9542
9657
|
this.waitingMobile = false;
|
|
9658
|
+
await this.baseComponent.finalize();
|
|
9543
9659
|
state.flowStatus = FlowStatus.COMPLETE;
|
|
9544
9660
|
}
|
|
9545
9661
|
if (this.orderStatus == OrderStatuses.NotFound) {
|
|
@@ -9562,7 +9678,7 @@ const MobileRedirect = class {
|
|
|
9562
9678
|
this.waitingMobile = true;
|
|
9563
9679
|
this.infoTextTop = MobileRedirectValues.InfoWaiting;
|
|
9564
9680
|
try {
|
|
9565
|
-
await this.apiCall.SendLink(this.redirectLink, this.contact);
|
|
9681
|
+
await this.baseComponent.apiCall.SendLink(this.redirectLink, this.contact);
|
|
9566
9682
|
}
|
|
9567
9683
|
catch (e) {
|
|
9568
9684
|
this.apiErrorEvent.emit(e);
|
|
@@ -9594,7 +9710,6 @@ const SelfieCapture = class {
|
|
|
9594
9710
|
//this.closeCamera();
|
|
9595
9711
|
this.eventPhotoCapture.emit(photos);
|
|
9596
9712
|
};
|
|
9597
|
-
this.device = undefined;
|
|
9598
9713
|
this.videoStarted = undefined;
|
|
9599
9714
|
this.captureTaken = undefined;
|
|
9600
9715
|
this.verified = undefined;
|
|
@@ -9647,7 +9762,7 @@ const SelfieCapture = class {
|
|
|
9647
9762
|
this.openCamera();
|
|
9648
9763
|
}
|
|
9649
9764
|
async openCamera() {
|
|
9650
|
-
const constraints = this.cameras.GetConstraints('',
|
|
9765
|
+
const constraints = this.cameras.GetConstraints('', state.device, true);
|
|
9651
9766
|
setTimeout(() => {
|
|
9652
9767
|
navigator.mediaDevices
|
|
9653
9768
|
.getUserMedia(constraints)
|
|
@@ -9691,7 +9806,7 @@ const SelfieCapture = class {
|
|
|
9691
9806
|
}
|
|
9692
9807
|
render() {
|
|
9693
9808
|
let cameraStyle;
|
|
9694
|
-
if (
|
|
9809
|
+
if (state.device.isMobile && this.videoStarted) {
|
|
9695
9810
|
cameraStyle = {
|
|
9696
9811
|
'width': this.captureWidth + 'px',
|
|
9697
9812
|
'height': this.captureHeight + 'px',
|
|
@@ -9704,7 +9819,7 @@ const SelfieCapture = class {
|
|
|
9704
9819
|
let titleClass = this.verified ? 'color-black-2 text-center' : 'color-white text-center';
|
|
9705
9820
|
//let videoClass = this.device.isMobile ? '' : 'video-demo';
|
|
9706
9821
|
let bgDemo = this.verified ? 'container' : 'container bg-black';
|
|
9707
|
-
return (index.h("div", { class: bgDemo }, index.h("div", { class: "container-video" }, index.h("div", { hidden: this.demoEnded }, index.h("video", { id: "howtoSelfie", class: "video-demo", playsinline: true, ref: el => (this.demoVideo = el) }, index.h("source", { type: "video/mp4" }))), index.h("div", { hidden: this.demoEnded == false }, index.h("div", { hidden: this.verified }, index.h("div", { class: "video-capture" }, index.h("div", { style: cameraStyle }, index.h("camera-comp", {
|
|
9822
|
+
return (index.h("div", { class: bgDemo }, index.h("div", { class: "container-video" }, index.h("div", { hidden: this.demoEnded }, index.h("video", { id: "howtoSelfie", class: "video-demo", playsinline: true, ref: el => (this.demoVideo = el) }, index.h("source", { type: "video/mp4" }))), index.h("div", { hidden: this.demoEnded == false }, index.h("div", { hidden: this.verified }, index.h("div", { class: "video-capture" }, index.h("div", { style: cameraStyle }, index.h("camera-comp", { "capture-mode": "selfie" }))))), index.h("div", { class: "capture-title" }, index.h("h1", { class: titleClass }, this.titleMesage), index.h("p", { class: "main-text font-size-18 text-right mb-0" }, SelfieCaptureValues.FooterText)))));
|
|
9708
9823
|
}
|
|
9709
9824
|
get component() { return index.getElement(this); }
|
|
9710
9825
|
};
|
|
@@ -9723,13 +9838,20 @@ const SmsCodeValidation = class {
|
|
|
9723
9838
|
this.code = undefined;
|
|
9724
9839
|
this.prefilledPhone = false;
|
|
9725
9840
|
this.canSend = false;
|
|
9726
|
-
|
|
9841
|
+
if (state.flowStatus == FlowStatus.PHONE) {
|
|
9842
|
+
this.baseComponent = new BaseComponent(FlowSteps.OtpSend);
|
|
9843
|
+
}
|
|
9844
|
+
if (state.flowStatus == FlowStatus.CODE) {
|
|
9845
|
+
this.baseComponent = new BaseComponent(FlowSteps.OtpCheck);
|
|
9846
|
+
}
|
|
9847
|
+
this.baseComponent.setEventEmitter(this.apiErrorEvent);
|
|
9727
9848
|
}
|
|
9728
9849
|
async doAction() {
|
|
9729
9850
|
try {
|
|
9730
9851
|
this.canSend = false;
|
|
9852
|
+
await this.baseComponent.finalize();
|
|
9731
9853
|
if (state.flowStatus == FlowStatus.CODE || state.flowStatus == FlowStatus.CODEERROR) {
|
|
9732
|
-
var codeChecked = await this.apiCall.CheckOTPCode(state.requestId, this.code);
|
|
9854
|
+
var codeChecked = await this.baseComponent.apiCall.CheckOTPCode(state.requestId, this.code);
|
|
9733
9855
|
if (codeChecked === true) {
|
|
9734
9856
|
state.flowStatus = FlowStatus.ID;
|
|
9735
9857
|
}
|
|
@@ -9738,7 +9860,7 @@ const SmsCodeValidation = class {
|
|
|
9738
9860
|
}
|
|
9739
9861
|
}
|
|
9740
9862
|
if (state.flowStatus == FlowStatus.PHONE) {
|
|
9741
|
-
var codeSent = await this.apiCall.SendOTPCode(state.requestId, this.phoneNumber);
|
|
9863
|
+
var codeSent = await this.baseComponent.apiCall.SendOTPCode(state.requestId, this.phoneNumber);
|
|
9742
9864
|
if (codeSent === true) {
|
|
9743
9865
|
state.flowStatus = FlowStatus.CODE;
|
|
9744
9866
|
}
|
|
@@ -9766,17 +9888,7 @@ const SmsCodeValidation = class {
|
|
|
9766
9888
|
}
|
|
9767
9889
|
}
|
|
9768
9890
|
async componentDidLoad() {
|
|
9769
|
-
|
|
9770
|
-
if (state.flowStatus == FlowStatus.PHONE) {
|
|
9771
|
-
await this.apiCall.AddStep(FlowSteps.OtpSend);
|
|
9772
|
-
}
|
|
9773
|
-
if (state.flowStatus == FlowStatus.CODE) {
|
|
9774
|
-
await this.apiCall.AddStep(FlowSteps.OtpCheck);
|
|
9775
|
-
}
|
|
9776
|
-
}
|
|
9777
|
-
catch (e) {
|
|
9778
|
-
this.apiErrorEvent.emit(e);
|
|
9779
|
-
}
|
|
9891
|
+
await this.baseComponent.initialize();
|
|
9780
9892
|
}
|
|
9781
9893
|
handleChangePhone(ev) {
|
|
9782
9894
|
let value = ev.target ? ev.target.value : '';
|
|
@@ -9817,7 +9929,6 @@ const UserLiveness = class {
|
|
|
9817
9929
|
constructor(hostRef) {
|
|
9818
9930
|
index.registerInstance(this, hostRef);
|
|
9819
9931
|
this.apiErrorEvent = index.createEvent(this, "apiError", 7);
|
|
9820
|
-
this.device = undefined;
|
|
9821
9932
|
this.showError = undefined;
|
|
9822
9933
|
this.showHowTo = undefined;
|
|
9823
9934
|
this.selfieFlow = {
|
|
@@ -9827,15 +9938,11 @@ const UserLiveness = class {
|
|
|
9827
9938
|
photoFile: null,
|
|
9828
9939
|
recordingFile: null,
|
|
9829
9940
|
};
|
|
9830
|
-
this.
|
|
9941
|
+
this.baseComponent = new BaseComponent(FlowSteps.Selfie);
|
|
9942
|
+
this.baseComponent.setEventEmitter(this.apiErrorEvent);
|
|
9831
9943
|
}
|
|
9832
9944
|
async componentDidLoad() {
|
|
9833
|
-
|
|
9834
|
-
await this.apiCall.AddStep(FlowSteps.Selfie);
|
|
9835
|
-
}
|
|
9836
|
-
catch (e) {
|
|
9837
|
-
this.apiErrorEvent.emit(e);
|
|
9838
|
-
}
|
|
9945
|
+
await this.baseComponent.initialize();
|
|
9839
9946
|
}
|
|
9840
9947
|
componentWillLoad() {
|
|
9841
9948
|
this.showHowTo = true;
|
|
@@ -9856,7 +9963,7 @@ const UserLiveness = class {
|
|
|
9856
9963
|
async captureSelfieImage(event) {
|
|
9857
9964
|
let selfiePhoto = event.detail;
|
|
9858
9965
|
if (selfiePhoto.length == 0 || selfiePhoto.size == 0) {
|
|
9859
|
-
await this.apiCall.AddLog({ message: 'Empty selfie', blobData: selfiePhoto }, getLogMessage());
|
|
9966
|
+
await this.baseComponent.apiCall.AddLog({ message: 'Empty selfie', blobData: selfiePhoto }, getLogMessage());
|
|
9860
9967
|
return;
|
|
9861
9968
|
}
|
|
9862
9969
|
try {
|
|
@@ -9870,7 +9977,7 @@ const UserLiveness = class {
|
|
|
9870
9977
|
async capturedSelfieRecording(event) {
|
|
9871
9978
|
let selfieRecording = event.detail;
|
|
9872
9979
|
if (selfieRecording.length == 0 || selfieRecording.size == 0) {
|
|
9873
|
-
await this.apiCall.AddLog({ message: 'Empty recording', blobData: selfieRecording }, getLogMessage());
|
|
9980
|
+
await this.baseComponent.apiCall.AddLog({ message: 'Empty recording', blobData: selfieRecording }, getLogMessage());
|
|
9874
9981
|
return;
|
|
9875
9982
|
}
|
|
9876
9983
|
let mimeType = selfieRecording.type == Stream.mp4MimeType.type ? Stream.mp4MimeType : Stream.webmMimeType;
|
|
@@ -9879,42 +9986,49 @@ const UserLiveness = class {
|
|
|
9879
9986
|
await this.uploadRecording();
|
|
9880
9987
|
}
|
|
9881
9988
|
catch (e) {
|
|
9882
|
-
|
|
9989
|
+
if (state.recordingRetryCount < 3) {
|
|
9990
|
+
state.recordingRetryCount++;
|
|
9991
|
+
this.triggerErrorFlow();
|
|
9992
|
+
}
|
|
9993
|
+
else {
|
|
9994
|
+
this.apiErrorEvent.emit(e);
|
|
9995
|
+
}
|
|
9883
9996
|
}
|
|
9884
9997
|
}
|
|
9885
9998
|
async verificationFinished(_event) {
|
|
9886
9999
|
this.selfieFlow.verificationFinished = true;
|
|
9887
|
-
this.endFlow();
|
|
10000
|
+
await this.endFlow();
|
|
9888
10001
|
}
|
|
9889
10002
|
async uploadPhoto() {
|
|
9890
10003
|
if (this.selfieFlow.photoFile == null || this.selfieFlow.photoDone) {
|
|
9891
10004
|
return;
|
|
9892
10005
|
}
|
|
9893
|
-
this.selfieFlow.photoDone = await this.apiCall.UploadFileForRequestB64(state.requestId, 'Selfie', this.selfieFlow.photoFile);
|
|
10006
|
+
this.selfieFlow.photoDone = await this.baseComponent.apiCall.UploadFileForRequestB64(state.requestId, 'Selfie', this.selfieFlow.photoFile);
|
|
9894
10007
|
if (this.selfieFlow.photoDone) {
|
|
9895
|
-
this.endFlow();
|
|
10008
|
+
await this.endFlow();
|
|
9896
10009
|
}
|
|
9897
10010
|
else {
|
|
9898
|
-
this.
|
|
9899
|
-
this.selfieFlow.recordingFile = null;
|
|
9900
|
-
this.showError = true;
|
|
10011
|
+
this.triggerErrorFlow();
|
|
9901
10012
|
}
|
|
9902
10013
|
}
|
|
9903
10014
|
async uploadRecording() {
|
|
9904
10015
|
if (this.selfieFlow.recordingFile == null || this.selfieFlow.recordingDone) {
|
|
9905
10016
|
return;
|
|
9906
10017
|
}
|
|
9907
|
-
this.selfieFlow.recordingDone = await this.apiCall.UploadFileForRequestB64(state.requestId, 'SelfieVideo', this.selfieFlow.recordingFile);
|
|
10018
|
+
this.selfieFlow.recordingDone = await this.baseComponent.apiCall.UploadFileForRequestB64(state.requestId, 'SelfieVideo', this.selfieFlow.recordingFile);
|
|
9908
10019
|
if (this.selfieFlow.recordingDone) {
|
|
9909
|
-
this.endFlow();
|
|
10020
|
+
await this.endFlow();
|
|
9910
10021
|
}
|
|
9911
10022
|
else {
|
|
9912
|
-
this.
|
|
9913
|
-
this.selfieFlow.recordingFile = null;
|
|
9914
|
-
this.showError = true;
|
|
10023
|
+
this.triggerErrorFlow();
|
|
9915
10024
|
}
|
|
9916
10025
|
}
|
|
9917
|
-
|
|
10026
|
+
triggerErrorFlow() {
|
|
10027
|
+
this.selfieFlow.photoFile = null;
|
|
10028
|
+
this.selfieFlow.recordingFile = null;
|
|
10029
|
+
this.showError = true;
|
|
10030
|
+
}
|
|
10031
|
+
async endFlow() {
|
|
9918
10032
|
if (!this.selfieFlow.photoDone) {
|
|
9919
10033
|
return;
|
|
9920
10034
|
}
|
|
@@ -9924,11 +10038,13 @@ const UserLiveness = class {
|
|
|
9924
10038
|
if (!this.selfieFlow.verificationFinished) {
|
|
9925
10039
|
return;
|
|
9926
10040
|
}
|
|
10041
|
+
state.recordingRetryCount = 0;
|
|
10042
|
+
await this.baseComponent.finalize();
|
|
9927
10043
|
state.flowStatus = FlowStatus.COMPLETE;
|
|
9928
10044
|
}
|
|
9929
10045
|
render() {
|
|
9930
10046
|
let howTo = index.h("how-to-info", { idSide: "" });
|
|
9931
|
-
let capture = index.h("selfie-capture", {
|
|
10047
|
+
let capture = index.h("selfie-capture", { id: "camera" });
|
|
9932
10048
|
let error = index.h("capture-error", { type: "LIVENESS" });
|
|
9933
10049
|
return this.showHowTo ? howTo : this.showError ? error : capture;
|
|
9934
10050
|
}
|