mebjas / html5-qrcode

A cross platform HTML5 QR code reader. See end to end implementation at: https://scanapp.org
https://qrcode.minhazav.dev
Apache License 2.0
5.04k stars 975 forks source link

TypeError: window._ is undefined #248

Closed connorpwilliams closed 3 years ago

connorpwilliams commented 3 years ago

Describe the bug Following the example here #113 I was unable to get this to work as a stand alone react component.

import React from "react";

import Html5QrcodeScanner from 'html5-qrcode'

class BarcodeScanner extends React.Component {
    componentDidMount() {
        // Creates the configuration object for Html5QrcodeScanner.
        function createConfig(props) {
            var config = {};
            if (props.fps) {
                config.fps = props.fps;
            }
            if (props.qrBox) {
                config.qrBox = props.qrBox;
            }
            if (props.aspectRatio) {
                config.aspectRatio = props.aspectRatio;
            }
            if (props.disableFlip !== undefined) {
                config.disableFlip = props.disableFlip;
            }
            return config;
        }

        var config = createConfig(this.props);
        var verbose = this.props.verbose === true;

        // Suceess callback is required.
        if (!(this.props.qrCodeSuccessCallback)) {
            throw 'qrCodeSuccessCallback is required callback.';
        }

        this.html5QrcodeScanner = new Html5QrcodeScanner('qr-code-full-region', config, verbose);
        this.html5QrcodeScanner.render(
            this.props.qrCodeSuccessCallback, this.props.qrCodeErrorCallback);
    }

    componentWillUnmount() {
        // TODO(mebjas): See if there is a better way to handle
        //  promise in `componentWillUnmount`.
        this.html5QrcodeScanner.clear().catch(error => {
            console.error('Failed to clear html5QrcodeScanner. ', error);
        });
    }

    render() {
        return <div id='qr-code-full-region' />
    }
}

export default BarcodeScanner

I am getting an error saying TypeError: window._ is undefined in the browser. I have fiddled around with different attempts but have not been able to find a solution. I have also tried importing this library into my top level index.html file but to no avail. I'd be happy to contribute with a React component but have not been able to find something standalone that works.

Does anyone have any suggestions or solutions for a React Component?

Thank you in advance

connorpwilliams commented 3 years ago
Didn't want to have the huge error long output above so here it is in a spoiler for reference ```javascript TypeError: window._ is undefined ./node_modules/html5-qrcode/dist/html5-qrcode.min.js/< node_modules/html5-qrcode/dist/html5-qrcode.min.js:6 3 | /** Html5Qrcode **/ 4 | var _;(()=>{"use strict";var A,e={d:(A,t)=>{for(var g in t)e.o(t,g)&&!e.o(A,g)&&Object.defineProperty(A,g,{enumerable:!0,get:t[g]})},o:(A,e)=>Object.prototype.hasOwnProperty.call(A,e),r:A=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(A,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(A,"__esModule",{value:!0})}},t={};e.r(t),e.d(t,{Html5Qrcode:()=>G,Html5QrcodeScanner:()=>Y,Html5QrcodeSupportedFormats:()=>A}),function(A){A[A.QR_CODE=0]="QR_CODE",A[A.AZTEC=1]="AZTEC",A[A.CODABAR=2]="CODABAR",A[A.CODE_39=3]="CODE_39",A[A.CODE_93=4]="CODE_93",A[A.CODE_128=5]="CODE_128",A[A.DATA_MATRIX=6]="DATA_MATRIX",A[A.MAXICODE=7]="MAXICODE",A[A.ITF=8]="ITF",A[A.EAN_13=9]="EAN_13",A[A.EAN_8=10]="EAN_8",A[A.PDF_417=11]="PDF_417",A[A.RSS_14=12]="RSS_14",A[A.RSS_EXPANDED=13]="RSS_EXPANDED",A[A.UPC_A=14]="UPC_A",A[A.UPC_E=15]="UPC_E",A[A.UPC_EAN_EXTENSION=16]="UPC_EAN_EXTENSION"}(A||(A={}));var g,i,n=new Map([[A.QR_CODE,"QR_CODE"],[A.AZTEC,"AZTEC"],[A.CODABAR,"CODABAR"],[A.CODE_39,"CODE_39"],[A.CODE_93,"CODE_93"],[A.CODE_128,"CODE_128"],[A.DATA_MATRIX,"DATA_MATRIX"],[A.MAXICODE,"MAXICODE"],[A.ITF,"ITF"],[A.EAN_13,"EAN_13"],[A.EAN_8,"EAN_8"],[A.PDF_417,"PDF_417"],[A.RSS_14,"RSS_14"],[A.RSS_EXPANDED,"RSS_EXPANDED"],[A.UPC_A,"UPC_A"],[A.UPC_E,"UPC_E"],[A.UPC_EAN_EXTENSION,"UPC_EAN_EXTENSION"]]);function o(e){return Object.values(A).includes(e)}!function(A){A[A.UNKNOWN=0]="UNKNOWN",A[A.URL=1]="URL"}(g||(g={})),function(A){A[A.SCAN_TYPE_CAMERA=0]="SCAN_TYPE_CAMERA",A[A.SCAN_TYPE_FILE=1]="SCAN_TYPE_FILE"}(i||(i={}));var I,C=function(){function A(){}return A.GITHUB_PROJECT_URL="https://github.com/mebjas/html5-qrcode",A.SCAN_DEFAULT_FPS=2,A.DEFAULT_DISABLE_FLIP=!1,A}(),a=function(){function A(A,e){this.format=A,this.formatName=e}return A.prototype.toString=function(){return this.formatName},A.create=function(e){if(!n.has(e))throw e+" not in html5QrcodeSupportedFormatsTextMap";return new A(e,n.get(e))},A}(),r=function(){function A(){}return A.createFromText=function(A){return{decodedText:A,result:{text:A}}},A.createFromQrcodeResult=function(A){return{decodedText:A.text,result:A}},A}();!function(A){A[A.UNKWOWN_ERROR=0]="UNKWOWN_ERROR",A[A.IMPLEMENTATION_ERROR=1]="IMPLEMENTATION_ERROR",A[A.NO_CODE_FOUND_ERROR=2]="NO_CODE_FOUND_ERROR"}(I||(I={}));var c=function(){function A(){}return A.createFrom=function(A){return{errorMessage:A,type:I.UNKWOWN_ERROR}},A}(),l=function(){function A(A){this.verbose=A}return A.prototype.log=function(A){this.verbose&&console.log(A)},A.prototype.warn=function(A){this.verbose&&console.warn(A)},A.prototype.logError=function(A,e){(this.verbose||!0===e)&&console.error(A)},A.prototype.logErrors=function(A){if(0===A.length)throw"Logger#logError called without arguments";this.verbose&&console.error(A)},A}();function s(A){return null==A}var d,B,E=function(){function A(){}return A.codeParseError=function(A){return"QR code parse error, error = "+A},A.errorGettingUserMedia=function(A){return"Error getting userMedia, error = "+A},A.onlyDeviceSupportedError=function(){return"The device doesn't support navigator.mediaDevices , only supported cameraIdOrConfig in this case is deviceId parameter (string)."},A.cameraStreamingNotSupported=function(){return"Camera streaming not supported by the browser."},A.unableToQuerySupportedDevices=function(){return"Unable to query supported devices, unknown error."},A.insecureContextCameraQueryError=function(){return"Camera access is only supported in secure context like https or localhost."},A}(),h=function(){function A(){}return A.scanningStatus=function(){return"Scanning"},A.idleStatus=function(){return"Idle"},A.errorStatus=function(){return"Error"},A.permissionStatus=function(){return"Permission"},A.noCameraFoundErrorStatus=function(){return"No Cameras"},A.lastMatch=function(A){return"Last Match: "+A},A.codeScannerTitle=function(){return"Code Scanner"},A.cameraPermissionTitle=function(){return"Request Camera Permissions"},A.cameraPermissionRequesting=function(){return"Requesting camera permissions..."},A.scanButtonStopScanningText=function(){return"Stop Scanning"},A.scanButtonStartScanningText=function(){return"Start Scanning"},A.textIfCameraScanSelected=function(){return"Scan an Image File"},A.textIfFileScanSelected=function(){return"Scan using camera directly"},A}(),m=function(){function A(){}return A.isMediaStreamConstraintsValid=function(A,e){if("object"!=typeof A){var t=typeof A;return e.logError("videoConstraints should be of type object, the object passed is of type "+t+".",!0),!1}for(var g=new Set(["autoGainControl","channelCount","echoCancellation","latency","noiseSuppression","sampleRate","sampleSize","volume"]),i=0,n=Object.keys(A);i0&&i[i.length-1])||6!==n[0]&&2!==n[0])){o=0;continue}if(3===n[0]&&(!i||n[1]>i[0]&&n[1]t&&(t=o,e=n)}if(!e)throw"No largest barcode found";return e},e.prototype.createBarcodeDetectorFormats=function(A){for(var e=[],t=0,g=A;ta)throw"'config.qrbox' should not be greater than the width of the HTML element."}var c=this;return new Promise((function(e,n){var I=o?i.videoConstraints:c.createVideoConstraints(A);if(I)if(navigator.mediaDevices&&navigator.mediaDevices.getUserMedia)navigator.mediaDevices.getUserMedia({audio:!1,video:I}).then((function(A){c.onMediaStreamReceived(A,i,o,a,t,g).then((function(A){c.isScanning=!0,e(null)})).catch(n)})).catch((function(A){n(E.errorGettingUserMedia(A))}));else if(navigator.getUserMedia){if("string"!=typeof A)throw E.onlyDeviceSupportedError();var C={video:I};navigator.getUserMedia(C,(function(A){c.onMediaStreamReceived(A,i,o,a,t,g).then((function(A){c.isScanning=!0,e(null)})).catch((function(A){n(E.errorGettingUserMedia(A))}))}),(function(A){n(E.errorGettingUserMedia(A))}))}else n(E.cameraStreamingNotSupported());else n("videoConstraints should be defined")}))},e.prototype.stop=function(){var A=this;return this.shouldScan=!1,this.foreverScanTimeout&&clearTimeout(this.foreverScanTimeout),new Promise((function(e,t){var g=function(){A.localMediaStream=null,A.element&&(A.element.removeChild(A.videoElement),A.element.removeChild(A.canvasElement)),function(){if(A.element)for(;A.element.getElementsByClassName(Z.SHADED_REGION_CLASSNAME).length;){var e=A.element.getElementsByClassName(Z.SHADED_REGION_CLASSNAME)[0];A.element.removeChild(e)}}(),A.isScanning=!1,A.qrRegion&&(A.qrRegion=null),A.context&&(A.context=null),e()};A.localMediaStream||g();var i=A.localMediaStream.getVideoTracks().length,n=0;A.localMediaStream.getVideoTracks().forEach((function(e){A.localMediaStream.removeTrack(e),e.stop(),++n>=i&&g()}))}))},e.prototype.scanFile=function(A,e){return this.scanFileV2(A,e).then((function(A){return A.decodedText}))},e.prototype.scanFileV2=function(A,e){var t=this;if(!(A&&A instanceof File))throw"imageFile argument is mandatory and should be instance of File. Use 'event.target.files[0]'.";if(s(e)&&(e=!0),this.isScanning)throw"Close ongoing scan before scanning a file.";return new Promise((function(g,i){t.possiblyCloseLastScanImageFile(),t.clearElement(),t.lastScanImageFile=URL.createObjectURL(A);var n=new Image;n.onload=function(){var A=n.width,o=n.height,I=document.getElementById(t.elementId),C=I.clientWidth?I.clientWidth:Z.DEFAULT_WIDTH,a=Math.max(I.clientHeight?I.clientHeight:o,Z.FILE_SCAN_MIN_HEIGHT),c=t.computeCanvasDrawConfig(A,o,C,a);if(e){var l=t.createCanvasElement(C,a,"qr-canvas-visible");l.style.display="inline-block",I.appendChild(l);var s=l.getContext("2d");if(!s)throw"Unable to get 2d context from canvas";s.canvas.width=C,s.canvas.height=a,s.drawImage(n,0,0,A,o,c.x,c.y,c.width,c.height)}var d=t.createCanvasElement(c.width,c.height);I.appendChild(d);var B=d.getContext("2d");if(!B)throw"Unable to get 2d context from canvas";B.canvas.width=c.width,B.canvas.height=c.height,B.drawImage(n,0,0,A,o,0,0,c.width,c.height);try{t.qrcode.decodeAsync(d).then((function(A){g(r.createFromQrcodeResult(A))})).catch(i)}catch(A){i("QR code parse error, error = "+A)}},n.onerror=i,n.onabort=i,n.onstalled=i,n.onsuspend=i,n.src=URL.createObjectURL(A)}))},e.prototype.clear=function(){this.clearElement()},e.getCameras=function(){if(navigator.mediaDevices)return e.getCamerasFromMediaDevices();var A=MediaStreamTrack;if(MediaStreamTrack&&A.getSources)return e.getCamerasFrmoMediaStreamTrack();var t=E.unableToQuerySupportedDevices();return function(){if("https:"===location.protocol)return!0;var A=location.host.split(":")[0];return"127.0.0.1"===A||"localhost"===A}()||(t=E.insecureContextCameraQueryError()),Promise.reject(t)},e.prototype.getRunningTrackCapabilities=function(){if(null==this.localMediaStream)throw"Scanning is not in running state, call this API only when QR code scanning using camera is in running state.";if(0===this.localMediaStream.getVideoTracks().length)throw"No video tracks found";return this.localMediaStream.getVideoTracks()[0].getCapabilities()},e.prototype.applyVideoConstraints=function(A){var e=this;if(!A)throw"videoConstaints is required argument.";if(!m.isMediaStreamConstraintsValid(A,this.logger))throw"invalid videoConstaints passed, check logs for more details";if(null===this.localMediaStream)throw"Scanning is not in running state, call this API only when QR code scanning using camera is in running state.";if(0===this.localMediaStream.getVideoTracks().length)throw"No video tracks found";return new Promise((function(t,g){"aspectRatio"in A?g("Chaning 'aspectRatio' in run-time is not yet supported."):e.localMediaStream.getVideoTracks()[0].applyConstraints(A).then((function(A){t(A)})).catch((function(A){g(A)}))}))},e.getCamerasFromMediaDevices=function(){return new Promise((function(A,e){navigator.mediaDevices.getUserMedia({audio:!1,video:!0}).then((function(t){navigator.mediaDevices.enumerateDevices().then((function(e){for(var g=[],i=0,n=e;ie&&this.logger.warn("[Html5Qrcode] config.qrboxsize is greater than video height. Shading will be ignored");var i=t.isShadedBoxEnabled()&&g<=e,n={x:0,y:0,width:A,height:e},o=i?this.getShadedRegionBounds(A,e,g):n,I=this.createCanvasElement(o.width,o.height),C=I.getContext("2d");C.canvas.width=o.width,C.canvas.height=o.height,this.element.append(I),i&&this.possiblyInsertShadingElement(this.element,A,e,g),this.qrRegion=o,this.context=C,this.canvasElement=I},e.prototype.scanContext=function(A,e){var t=this;return this.qrcode.decodeAsync(this.canvasElement).then((function(e){return A(e.text,r.createFromQrcodeResult(e)),t.possiblyUpdateShaders(!0),!0})).catch((function(A){t.possiblyUpdateShaders(!1);var g=E.codeParseError(A);return e(g,c.createFrom(g)),!1}))},e.prototype.foreverScan=function(A,e,t){var g=this;if(this.shouldScan&&this.localMediaStream){var i=this.videoElement,n=i.videoWidth/i.clientWidth,o=i.videoHeight/i.clientHeight;if(!this.qrRegion)throw"qrRegion undefined when localMediaStream is ready.";var I=this.qrRegion.width*n,C=this.qrRegion.height*o,a=this.qrRegion.x*n,r=this.qrRegion.y*o;this.context.drawImage(i,a,r,I,C,0,0,this.qrRegion.width,this.qrRegion.height);var c=function(){g.foreverScanTimeout=setTimeout((function(){g.foreverScan(A,e,t)}),g.getTimeoutFps(A.fps))};this.scanContext(e,t).then((function(i){i||!0===A.disableFlip?c():(g.context.translate(g.context.canvas.width,0),g.context.scale(-1,1),g.scanContext(e,t).finally((function(){c()})))})).catch((function(A){g.logger.logError("Error happend while scanning context",A),c()}))}},e.prototype.onMediaStreamReceived=function(A,e,t,g,i,n){var o=this,I=this;return new Promise((function(C,a){var r=function(){var t=o.createVideoElement(g);I.element.append(t),t.onabort=a,t.onerror=a,t.onplaying=function(){var A=t.clientWidth,g=t.clientHeight;I.setupUi(A,g,e),I.foreverScan(e,i,n),C(null)},t.srcObject=A,t.play(),I.videoElement=t};if(I.localMediaStream=A,t||!e.aspectRatio)r();else{var c={aspectRatio:e.aspectRatio};A.getVideoTracks()[0].applyConstraints(c).then((function(A){return r()})).catch((function(A){I.logger.logErrors(["[Html5Qrcode] Constriants could not be satisfied, ignoring constraints",A]),r()}))}}))},e.prototype.createVideoConstraints=function(A){if("string"==typeof A)return{deviceId:{exact:A}};if("object"==typeof A){var e="facingMode",t={user:!0,environment:!0},g="exact",i=function(A){if(A in t)return!0;throw"config has invalid 'facingMode' value = '"+A+"'"},n=Object.keys(A);if(1!==n.length)throw"'cameraIdOrConfig' object should have exactly 1 key, if passed as an object, found "+n.length+" keys";var o=Object.keys(A)[0];if(o!==e&&"deviceId"!==o)throw"Only 'facingMode' and 'deviceId' are supported for 'cameraIdOrConfig'";if(o!==e){var I=A.deviceId;if("string"==typeof I)return{deviceId:I};if("object"==typeof I){if(g in I)return{deviceId:{exact:I.exact}};throw"'deviceId' should be string or object with exact as key."}throw"Invalid type of 'deviceId' = "+typeof I}var C=A.facingMode;if("string"==typeof C){if(i(C))return{facingMode:C}}else{if("object"!=typeof C)throw"Invalid type of 'facingMode' = "+typeof C;if(!(g in C))throw"'facingMode' should be string or object with exact as key.";if(i(C.exact))return{facingMode:{exact:C.exact}}}}throw"Invalid type of 'cameraIdOrConfig' = "+typeof A},e.prototype.computeCanvasDrawConfig=function(A,e,t,g){if(A<=t&&e<=g)return{x:(t-A)/2,y:(g-e)/2,width:A,height:e};var i=A,n=e;return A>t&&(e*=t/A,A=t),e>g&&(A*=g/e,e=g),this.logger.log("Image downsampled from "+i+"X"+n+" to "+A+"X"+e+"."),this.computeCanvasDrawConfig(A,e,t,g)},e.prototype.clearElement=function(){if(this.isScanning)throw"Cannot clear while scan is ongoing, close it first.";var A=document.getElementById(this.elementId);A&&(A.innerHTML="")},e.prototype.createVideoElement=function(A){var e=document.createElement("video");return e.style.width=A+"px",e.muted=!0,e.setAttribute("muted","true"),e.playsInline=!0,e},e.prototype.possiblyUpdateShaders=function(A){this.qrMatch!==A&&(this.hasBorderShaders&&this.borderShaders&&this.borderShaders.length&&this.borderShaders.forEach((function(e){e.style.backgroundColor=A?Z.BORDER_SHADER_MATCH_COLOR:Z.BORDER_SHADER_DEFAULT_COLOR})),this.qrMatch=A)},e.prototype.possiblyCloseLastScanImageFile=function(){this.lastScanImageFile&&(URL.revokeObjectURL(this.lastScanImageFile),this.lastScanImageFile=null)},e.prototype.createCanvasElement=function(A,e,t){var g=A,i=e,n=document.createElement("canvas");return n.style.width=g+"px",n.style.height=i+"px",n.style.display="none",n.id=s(t)?"qr-canvas":t,n},e.prototype.getShadedRegionBounds=function(A,e,t){if(t>A||t>e)throw"'config.qrbox' should not be greater than the width and height of the HTML element.";return{x:(A-t)/2,y:(e-t)/2,width:t,height:t}},e.prototype.possiblyInsertShadingElement=function(A,e,t,g){if(!(e-g<1||t-g<1)){var i=document.createElement("div");if(i.style.position="absolute",i.style.borderLeft=(e-g)/2+"px solid #0000007a",i.style.borderRight=(e-g)/2+"px solid #0000007a",i.style.borderTop=(t-g)/2+"px solid #0000007a",i.style.borderBottom=(t-g)/2+"px solid #0000007a",i.style.boxSizing="border-box",i.style.top="0px",i.style.bottom="0px",i.style.left="0px",i.style.right="0px",i.id=""+Z.SHADED_REGION_CLASSNAME,e-g<11||t-g<11)this.hasBorderShaders=!1;else{var n=40;this.insertShaderBorders(i,n,5,-5,0,!0),this.insertShaderBorders(i,n,5,-5,0,!1),this.insertShaderBorders(i,n,5,g+5,0,!0),this.insertShaderBorders(i,n,5,g+5,0,!1),this.insertShaderBorders(i,5,45,-5,-5,!0),this.insertShaderBorders(i,5,45,g+5-n,-5,!0),this.insertShaderBorders(i,5,45,-5,-5,!1),this.insertShaderBorders(i,5,45,g+5-n,-5,!1),this.hasBorderShaders=!0}A.append(i)}},e.prototype.insertShaderBorders=function(A,e,t,g,i,n){var o=document.createElement("div");o.style.position="absolute",o.style.backgroundColor=Z.BORDER_SHADER_DEFAULT_COLOR,o.style.width=e+"px",o.style.height=t+"px",o.style.top=g+"px",n?o.style.left=i+"px":o.style.right=i+"px",this.borderShaders||(this.borderShaders=[]),this.borderShaders.push(o),A.appendChild(o)},e.prototype.getTimeoutFps=function(A){return 1e3/A},e}();!function(A){A[A.STATUS_DEFAULT=0]="STATUS_DEFAULT",A[A.STATUS_SUCCESS=1]="STATUS_SUCCESS",A[A.STATUS_WARNING=2]="STATUS_WARNING"}(B||(B={}));var Y=function(){function A(A,e,t){if(this.lastMatchFound=null,this.cameraScanImage=null,this.fileScanImage=null,this.elementId=A,this.config=this.createConfig(e),this.verbose=!0===t,!document.getElementById(A))throw"HTML Element with id="+A+" not found";this.currentScanType=i.SCAN_TYPE_CAMERA,this.sectionSwapAllowed=!0,this.logger=new l(this.verbose)}return A.prototype.render=function(A,e){var t=this;this.lastMatchFound=null,this.qrCodeSuccessCallback=function(e,g){if(A)A(e,g);else{if(t.lastMatchFound===e)return;t.lastMatchFound=e,t.setHeaderMessage(h.lastMatch(e),B.STATUS_SUCCESS)}},this.qrCodeErrorCallback=function(A,g){t.setStatus(h.scanningStatus()),e&&e(A,g)};var g,i,n=document.getElementById(this.elementId);if(!n)throw"HTML Element with id="+this.elementId+" not found";n.innerHTML="",this.createBasicLayout(n),this.html5Qrcode=new G(this.getScanRegionId(),(g=this.config,i=this.verbose,{formatsToSupport:g.formatsToSupport,experimentalFeatures:g.experimentalFeatures,verbose:i}))},A.prototype.clear=function(){var A=this;return this.html5Qrcode?new Promise((function(e,t){A.html5Qrcode?A.html5Qrcode.isScanning&&A.html5Qrcode.stop().then((function(t){var g;A.html5Qrcode?(A.html5Qrcode.clear(),(g=document.getElementById(A.elementId))&&(g.innerHTML="",A.resetBasicLayout(g)),e()):e()})).catch((function(e){A.verbose&&A.logger.logError("Unable to stop qrcode scanner",e),t(e)})):e()})):Promise.resolve()},A.prototype.createConfig=function(A){return A?(A.fps||(A.fps=C.SCAN_DEFAULT_FPS),A):{fps:C.SCAN_DEFAULT_FPS}},A.prototype.createBasicLayout=function(A){A.style.position="relative",A.style.padding="0px",A.style.border="1px solid silver",this.createHeader(A);var e=document.createElement("div"),t=this.getScanRegionId();e.id=t,e.style.width="100%",e.style.minHeight="100px",e.style.textAlign="center",A.appendChild(e),this.insertCameraScanImageToScanRegion();var g=document.createElement("div"),i=this.getDashboardId();g.id=i,g.style.width="100%",A.appendChild(g),this.setupInitialDashboard(g)},A.prototype.resetBasicLayout=function(A){A.style.border="none"},A.prototype.setupInitialDashboard=function(A){this.createSection(A),this.createSectionControlPanel(),this.createSectionSwap()},A.prototype.createHeader=function(A){var e=document.createElement("div");e.style.textAlign="left",e.style.margin="0px",e.style.padding="5px",e.style.fontSize="20px",e.style.borderBottom="1px solid rgba(192, 192, 192, 0.18)",A.appendChild(e);var t=document.createElement("span"),g=document.createElement("a");g.innerText=h.codeScannerTitle(),g.href=C.GITHUB_PROJECT_URL,t.appendChild(g),e.appendChild(t);var i=document.createElement("span");i.id=this.getStatusSpanId(),i.style.float="right",i.style.padding="5px 7px",i.style.fontSize="14px",i.style.background="#dedede6b",i.style.border="1px solid #00000000",i.style.color="rgb(17, 17, 17)",e.appendChild(i),this.setStatus(h.idleStatus());var n=document.createElement("div");n.id=this.getHeaderMessageContainerId(),n.style.display="none",n.style.fontSize="14px",n.style.padding="2px 10px",n.style.marginTop="4px",n.style.borderTop="1px solid #f6f6f6",e.appendChild(n)},A.prototype.createSection=function(A){var e=document.createElement("div");e.id=this.getDashboardSectionId(),e.style.width="100%",e.style.padding="10px",e.style.textAlign="left",A.appendChild(e)},A.prototype.createSectionControlPanel=function(){var A=document.getElementById(this.getDashboardSectionId()),e=document.createElement("div");A.appendChild(e);var t=document.createElement("div");t.id=this.getDashboardSectionCameraScanRegionId(),t.style.display=this.currentScanType===i.SCAN_TYPE_CAMERA?"block":"none",e.appendChild(t);var g=document.createElement("div");g.style.textAlign="center";var n=document.createElement("button");n.innerText=h.cameraPermissionTitle();var o=this;n.addEventListener("click",(function(){n.disabled=!0,o.setStatus(h.permissionStatus()),o.setHeaderMessage(h.cameraPermissionRequesting()),G.getCameras().then((function(A){o.setStatus(h.idleStatus()),o.resetHeaderMessage(),A&&0!==A.length?(t.removeChild(g),o.renderCameraSelection(A)):o.setStatus(h.noCameraFoundErrorStatus(),B.STATUS_WARNING)})).catch((function(A){n.disabled=!1,o.setStatus(h.idleStatus()),o.setHeaderMessage(A,B.STATUS_WARNING)}))})),g.appendChild(n),t.appendChild(g);var I=document.createElement("div");I.id=this.getDashboardSectionFileScanRegionId(),I.style.textAlign="center",I.style.display=this.currentScanType===i.SCAN_TYPE_CAMERA?"none":"block",e.appendChild(I);var C=document.createElement("input");C.id=this.getFileScanInputId(),C.accept="image/*",C.type="file",C.style.width="200px",C.disabled=this.currentScanType===i.SCAN_TYPE_CAMERA;var a=document.createElement("span");a.innerText=" Select Image",I.appendChild(C),I.appendChild(a),C.addEventListener("change",(function(A){if(!o.html5Qrcode)throw"html5Qrcode not defined";if(null!=A&&null!=A.target&&o.currentScanType===i.SCAN_TYPE_FILE&&0!==A.target.files.length){var e=A.target.files[0];o.html5Qrcode.scanFileV2(e,!0).then((function(A){o.resetHeaderMessage(),o.qrCodeSuccessCallback(A.decodedText,A)})).catch((function(A){o.setStatus(h.errorStatus(),B.STATUS_WARNING),o.setHeaderMessage(A,B.STATUS_WARNING),o.qrCodeErrorCallback(A,c.createFrom(A))}))}}))},A.prototype.renderCameraSelection=function(A){var e=this,t=document.getElementById(this.getDashboardSectionCameraScanRegionId());t.style.textAlign="center";var g=document.createElement("span");g.innerText="Select Camera ("+A.length+") ",g.style.marginRight="10px";var i=document.createElement("select");i.id=this.getCameraSelectionId();for(var n=0,o=A;n",e.appendChild(A.cameraScanImage)},this.cameraScanImage.width=64,this.cameraScanImage.style.opacity="0.3",this.cameraScanImage.src=""},A.prototype.insertFileScanImageToScanRegion=function(){var A=this,e=document.getElementById(this.getScanRegionId());if(this.fileScanImage)return e.innerHTML="
",void e.appendChild(this.fileScanImage);this.fileScanImage=new Image,this.fileScanImage.onload=function(t){e.innerHTML="
",e.appendChild(A.fileScanImage)},this.fileScanImage.width=64,this.fileScanImage.style.opacity="0.3",this.fileScanImage.src=""},A.prototype.clearScanRegion=function(){document.getElementById(this.getScanRegionId()).innerHTML=""},A.prototype.getDashboardSectionId=function(){return this.elementId+"__dashboard_section"},A.prototype.getDashboardSectionCameraScanRegionId=function(){return this.elementId+"__dashboard_section_csr"},A.prototype.getDashboardSectionFileScanRegionId=function(){return this.elementId+"__dashboard_section_fsr"},A.prototype.getDashboardSectionSwapLinkId=function(){return this.elementId+"__dashboard_section_swaplink"},A.prototype.getScanRegionId=function(){return this.elementId+"__scan_region"},A.prototype.getDashboardId=function(){return this.elementId+"__dashboard"},A.prototype.getFileScanInputId=function(){return this.elementId+"__filescan_input"},A.prototype.getStatusSpanId=function(){return this.elementId+"__status_span"},A.prototype.getHeaderMessageContainerId=function(){return this.elementId+"__header_message"},A.prototype.getCameraSelectionId=function(){return this.elementId+"__camera_selection"},A.prototype.getCameraScanRegion=function(){return document.getElementById(this.getDashboardSectionCameraScanRegionId())},A.prototype.getFileScanRegion=function(){return document.getElementById(this.getDashboardSectionFileScanRegionId())},A.prototype.getFileScanInput=function(){return document.getElementById(this.getFileScanInputId())},A.prototype.getDashboardSectionSwapLink=function(){return document.getElementById(this.getDashboardSectionSwapLinkId())},A.prototype.getStatusSpan=function(){return document.getElementById(this.getStatusSpanId())},A.prototype.getHeaderMessageDiv=function(){return document.getElementById(this.getHeaderMessageContainerId())},A}();_=t})(); 5 | /**ref**/ > 6 | ;var Html5Qrcode = window._.Html5Qrcode; 7 | ;var Html5QrcodeScanner = window._.Html5QrcodeScanner; 8 | ;var Html5QrcodeSupportedFormats = window._.Html5QrcodeSupportedFormats; 9 | ./node_modules/html5-qrcode/dist/html5-qrcode.min.js http://localhost:3000/static/js/0.chunk.js:19413:30 __webpack_require__ /webpack/bootstrap:851 848 | 849 | __webpack_require__.$Refresh$.init(); 850 | try { > 851 | modules[moduleId].call(module.exports, module, module.exports, hotCreateRequire(moduleId)); | ^ 852 | } finally { 853 | __webpack_require__.$Refresh$.cleanup(moduleId); 854 | } fn /webpack/bootstrap:150 147 | ); 148 | hotCurrentParents = []; 149 | } > 150 | return __webpack_require__(request); | ^ 151 | }; 152 | var ObjectFactory = function ObjectFactory(name) { 153 | return { __webpack_require__ /webpack/bootstrap:851 848 | 849 | __webpack_require__.$Refresh$.init(); 850 | try { > 851 | modules[moduleId].call(module.exports, module, module.exports, hotCreateRequire(moduleId)); | ^ 852 | } finally { 853 | __webpack_require__.$Refresh$.cleanup(moduleId); 854 | } fn /webpack/bootstrap:150 147 | ); 148 | hotCurrentParents = []; 149 | } > 150 | return __webpack_require__(request); | ^ 151 | }; 152 | var ObjectFactory = function ObjectFactory(name) { 153 | return { __webpack_require__ /webpack/bootstrap:851 848 | 849 | __webpack_require__.$Refresh$.init(); 850 | try { > 851 | modules[moduleId].call(module.exports, module, module.exports, hotCreateRequire(moduleId)); | ^ 852 | } finally { 853 | __webpack_require__.$Refresh$.cleanup(moduleId); 854 | } fn /webpack/bootstrap:150 147 | ); 148 | hotCurrentParents = []; 149 | } > 150 | return __webpack_require__(request); | ^ 151 | }; 152 | var ObjectFactory = function ObjectFactory(name) { 153 | return { __webpack_require__ /webpack/bootstrap:851 848 | 849 | __webpack_require__.$Refresh$.init(); 850 | try { > 851 | modules[moduleId].call(module.exports, module, module.exports, hotCreateRequire(moduleId)); | ^ 852 | } finally { 853 | __webpack_require__.$Refresh$.cleanup(moduleId); 854 | } fn /webpack/bootstrap:150 147 | ); 148 | hotCurrentParents = []; 149 | } > 150 | return __webpack_require__(request); | ^ 151 | }; 152 | var ObjectFactory = function ObjectFactory(name) { 153 | return { 1 http://localhost:3000/static/js/main.chunk.js:8417:18 __webpack_require__ /webpack/bootstrap:851 848 | 849 | __webpack_require__.$Refresh$.init(); 850 | try { > 851 | modules[moduleId].call(module.exports, module, module.exports, hotCreateRequire(moduleId)); | ^ 852 | } finally { 853 | __webpack_require__.$Refresh$.cleanup(moduleId); 854 | } checkDeferredModules /webpack/bootstrap:45 42 | } 43 | if(fulfilled) { 44 | deferredModules.splice(i--, 1); > 45 | result = __webpack_require__(__webpack_require__.s = deferredModule[0]); | ^ 46 | } 47 | } 48 | webpackJsonpCallback /webpack/bootstrap:32 29 | deferredModules.push.apply(deferredModules, executeModules || []); 30 | 31 | // run deferred modules when all chunks ready > 32 | return checkDeferredModules(); | ^ 33 | }; 34 | function checkDeferredModules() { 35 | var result; (anonymous function) http://localhost:3000/static/js/main.chunk.js:1:67 This screen is visible only in development. It will not appear if the app crashes in production. Open your browser’s developer console to further inspect this error. Click the 'X' or hit ESC to dismiss this message. ```
strongishllama commented 3 years ago

Same issue for me when using Vue. I've tried a couple of different versions with no luck.

sep2 commented 3 years ago

Use it this way:

const importHtml5Qrcode = async () => {
    const backup = window._
    // @ts-ignore
    window._ = {}
    const m = await import('html5-qrcode')
    window._ = backup
    return m
}

importHtml5Qrcode().then((x) => console.log('x', x))
strongishllama commented 3 years ago

@sep2 Are you talking about using your example in React? That snippet didn't compile for me using Vue and Typescript.

sep2 commented 3 years ago

The problem is the last three lines in the minified file, I ended up loading the js file from url using dynamically created script tag.

ROBERT-MCDOWELL commented 3 years ago

is this issue can be closed?

connorpwilliams commented 3 years ago

Use it this way:

const importHtml5Qrcode = async () => {
    const backup = window._
    // @ts-ignore
    window._ = {}
    const m = await import('html5-qrcode')
    window._ = backup
    return m
}

importHtml5Qrcode().then((x) => console.log('x', x))

I will try this later today. Haven't had time to work on personal projects. If it is resolved, I'll close this issue.

HamzaAlvi719 commented 3 years ago

It didn't worked for me. I have been implementing it in rails.

stefann01 commented 3 years ago

It didn't work for me also. Please provide a better react example. The one specified doesn't even have a constructor. Or try an example with functional component.

arduino-man commented 3 years ago

I can confirm the issue persists on Firefox running on Ubuntu 20.04

damienlethiec commented 3 years ago

Same problem with rails here

Nighthree commented 3 years ago

I solved it in my Vue webpack project. In the html5-qrcode.min.js bottom, I modified the ref part. And then import it in the vue file,I successfully used object orientation to call the Html5QrcodeScanner object. Sorry, I'm not good at English. Hope you can understand. And hope this can help you. vue-html5-qrcode-reslove

eskan commented 3 years ago

The npm package contains a minified version only as it should also contains source.

Nighthree commented 3 years ago

您好,您这个怎么调用后置摄像头

只能使用 Javascript 操纵节点调用后置摄像头,除了 render(callback),官方没有提供其他接口

Dengyu-1129 commented 3 years ago

I solved it in my Vue webpack project. In the html5-qrcode.min.js bottom, I modified the ref part. And then import it in the vue file,I successfully used object orientation to call the Html5QrcodeScanner object. Sorry, I'm not good at English. Hope you can understand. And hope this can help you. vue-html5-qrcode-reslove

您好,您这个怎么调用后置摄像头

只能使用 Javascript 操纵节点调用后置摄像头,除了 render(callback),官方没有提供其他接口

再请问一下,我本地调试没问题,但发布线上后调不了摄像头怎么回事呢?你有没有遇到过

Dengyu-1129 commented 3 years ago

I solved it in my Vue webpack project. In the html5-qrcode.min.js bottom, I modified the ref part. And then import it in the vue file,I successfully used object orientation to call the Html5QrcodeScanner object. Sorry, I'm not good at English. Hope you can understand. And hope this can help you. vue-html5-qrcode-reslove

我这样把代码引到src下面怎么用不了了呢?求解答

Nighthree commented 3 years ago

再请问一下,我本地调试没问题,但发布线上后调不了摄像头怎么回事呢?你有没有遇到过

镜头调用属于 WebRTC 协议,仅限于 localhost 以及 https 环境,请检查您的环境是否符合,以及浏览器是否支持该协议。

Dengyu-1129 commented 3 years ago

I solved it in my Vue webpack project. In the html5-qrcode.min.js bottom, I modified the ref part. And then import it in the vue file,I successfully used object orientation to call the Html5QrcodeScanner object. Sorry, I'm not good at English. Hope you can understand. And hope this can help you. vue-html5-qrcode-reslove

您好,您这个怎么调用后置摄像头

只能使用 Javascript 操纵节点调用后置摄像头,除了 render(callback),官方没有提供其他接口

再请问一下,我本地调试没问题,但发布线上后调不了摄像头怎么回事呢?你有没有遇到过

镜头调用属于 WebRTC 协议,仅限于 localhost 以及 https 环境,请检查您的环境是否符合,以及浏览器是否支持该协议。 zxing is not defined是怎么回事儿呢

ROBERT-MCDOWELL commented 3 years ago

@Dengyu-1129 please send comments in plain English, use google or other translator to help you thanks

connorpwilliams commented 3 years ago

I solved it in my Vue webpack project. In the html5-qrcode.min.js bottom, I modified the ref part. And then import it in the vue file,I successfully used object orientation to call the Html5QrcodeScanner object. Sorry, I'm not good at English. Hope you can understand. And hope this can help you. vue-html5-qrcode-reslove

I understand just fine :)

Modifying the npm package source code should not be the solution to this problem if several others are experiencing this.

@mebjas Seems this has been going on since July. Do you have any updates? I'm happy to go through and try to fix things but don't fully know the project and don't want to duplicate effort if you have already started on this.

Thank you

Nighthree commented 3 years ago

@thecpdubguy Yes, this is a temporary solution before the author fixes it.

mebjas commented 3 years ago

Can you verify with latest version of code with npm update?

(I'll add more documentation later)

mebjas commented 3 years ago

With latest update of the library (2.1.0)

I tested following template code and it worked fine

import './App.css';

import {Html5QrcodeScanner} from "html5-qrcode"
import React from 'react';

class QrcodeDiv extends React.Component {
  render() {
    return (<div id="qrcode">qr code container</div>);
  }

  componentDidMount() {
    let scanner = new Html5QrcodeScanner("qrcode", {qrbox: {width: 250, height: 250}});
    scanner.render();
  }
}

function App() {
  return (
    <div className="App">
      <section>
        <QrcodeDiv />
      </section>
    </div>
  );
}

export default App;
Nighthree commented 3 years ago

I updated the plugin (2.1.0) in my vue webpack project and it worked fine. codesandbox

<template>
  <div id="app">
    <div id="qr-code-full-region"></div>
    <div>
      <button type="button" @click="message = []">clear</button>
    </div>
    <div
      v-for="(msg, index) in message"
      :key="index"
      style="white-space: pre-line"
    >
      <pre>decodedResult => {{ msg.decodedResult }}</pre>
    </div>
  </div>
</template>

<script>
import { Html5QrcodeScanner } from "html5-qrcode";
export default {
  data() {
    return {
      message: [],
    };
  },
  methods: {
    creatScan() {
      const config = { fps: 10, qrbox: 250 };
      const html5QrcodeScanner = new Html5QrcodeScanner(
        "qr-code-full-region",
        config
      );
      html5QrcodeScanner.render(this.onScanSuccess);
    },
    onScanSuccess(decodedText, decodedResult) {
      const obj = { decodedResult: decodedResult };
      this.message.push(obj);
    },
  },
  async mounted() {
    this.creatScan();
  },
};
</script>
mebjas commented 3 years ago

Thanks for confirming, closing this!

@Nighthree thanks for the example, if you are interested please send a PR with updated example (or a modified example) at https://github.com/mebjas/html5-qrcode/tree/master/examples/vuejs on how to use VueJs + webpack with this library.