| /*  | 
 |  * QR Code generator demo (JavaScript) | 
 |  *  | 
 |  * Copyright (c) Project Nayuki. (MIT License) | 
 |  * https://www.nayuki.io/page/qr-code-generator-library | 
 |  *  | 
 |  * Permission is hereby granted, free of charge, to any person obtaining a copy of | 
 |  * this software and associated documentation files (the "Software"), to deal in | 
 |  * the Software without restriction, including without limitation the rights to | 
 |  * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of | 
 |  * the Software, and to permit persons to whom the Software is furnished to do so, | 
 |  * subject to the following conditions: | 
 |  * - The above copyright notice and this permission notice shall be included in | 
 |  *   all copies or substantial portions of the Software. | 
 |  * - The Software is provided "as is", without warranty of any kind, express or | 
 |  *   implied, including but not limited to the warranties of merchantability, | 
 |  *   fitness for a particular purpose and noninfringement. In no event shall the | 
 |  *   authors or copyright holders be liable for any claim, damages or other | 
 |  *   liability, whether in an action of contract, tort or otherwise, arising from, | 
 |  *   out of or in connection with the Software or the use or other dealings in the | 
 |  *   Software. | 
 |  */ | 
 |  | 
 | "use strict"; | 
 |  | 
 |  | 
 | function redrawQrCode() { | 
 | 	// Show/hide rows based on bitmap/vector image output | 
 | 	var bitmapOutput = document.getElementById("output-format-bitmap").checked; | 
 | 	var scaleRow = document.getElementById("scale-row"); | 
 | 	var svgXmlRow = document.getElementById("svg-xml-row"); | 
 | 	if (bitmapOutput) { | 
 | 		scaleRow.style.removeProperty("display"); | 
 | 		svgXmlRow.style.display = "none"; | 
 | 	} else { | 
 | 		scaleRow.style.display = "none"; | 
 | 		svgXmlRow.style.removeProperty("display"); | 
 | 	} | 
 | 	var svgXml = document.getElementById("svg-xml-output"); | 
 | 	svgXml.value = ""; | 
 | 	 | 
 | 	// Reset output images in case of early termination | 
 | 	var canvas = document.getElementById("qrcode-canvas"); | 
 | 	var svg = document.getElementById("qrcode-svg"); | 
 | 	canvas.style.display = "none"; | 
 | 	svg.style.display = "none"; | 
 | 	 | 
 | 	// Returns a QrCode.Ecc object based on the radio buttons in the HTML form. | 
 | 	function getInputErrorCorrectionLevel() { | 
 | 		if (document.getElementById("errcorlvl-medium").checked) | 
 | 			return qrcodegen.QrCode.Ecc.MEDIUM; | 
 | 		else if (document.getElementById("errcorlvl-quartile").checked) | 
 | 			return qrcodegen.QrCode.Ecc.QUARTILE; | 
 | 		else if (document.getElementById("errcorlvl-high").checked) | 
 | 			return qrcodegen.QrCode.Ecc.HIGH; | 
 | 		else  // In case no radio button is depressed | 
 | 			return qrcodegen.QrCode.Ecc.LOW; | 
 | 	} | 
 | 	 | 
 | 	// Get form inputs and compute QR Code | 
 | 	var ecl = getInputErrorCorrectionLevel(); | 
 | 	var text = document.getElementById("text-input").value; | 
 | 	var segs = qrcodegen.QrSegment.makeSegments(text); | 
 | 	var minVer = parseInt(document.getElementById("version-min-input").value, 10); | 
 | 	var maxVer = parseInt(document.getElementById("version-max-input").value, 10); | 
 | 	var mask = parseInt(document.getElementById("mask-input").value, 10); | 
 | 	var boostEcc = document.getElementById("boost-ecc-input").checked; | 
 | 	var qr = qrcodegen.QrCode.encodeSegments(segs, ecl, minVer, maxVer, mask, boostEcc); | 
 | 	 | 
 | 	// Draw image output | 
 | 	var border = parseInt(document.getElementById("border-input").value, 10); | 
 | 	if (border < 0 || border > 100) | 
 | 		return; | 
 | 	if (bitmapOutput) { | 
 | 		var scale = parseInt(document.getElementById("scale-input").value, 10); | 
 | 		if (scale <= 0 || scale > 30) | 
 | 			return; | 
 | 		qr.drawCanvas(scale, border, canvas); | 
 | 		canvas.style.removeProperty("display"); | 
 | 	} else { | 
 | 		var code = qr.toSvgString(border); | 
 | 		svg.setAttribute("viewBox", / viewBox="([^"]*)"/.exec(code)[1]); | 
 | 		svg.querySelector("path").setAttribute("d", / d="([^"]*)"/.exec(code)[1]); | 
 | 		svg.style.removeProperty("display"); | 
 | 		svgXml.value = qr.toSvgString(border); | 
 | 	} | 
 | 	 | 
 | 	 | 
 | 	// Returns a string to describe the given list of segments. | 
 | 	function describeSegments(segs) { | 
 | 		if (segs.length == 0) | 
 | 			return "none"; | 
 | 		else if (segs.length == 1) { | 
 | 			var mode = segs[0].mode; | 
 | 			var Mode = qrcodegen.QrSegment.Mode; | 
 | 			if (mode == Mode.NUMERIC     )  return "numeric"; | 
 | 			if (mode == Mode.ALPHANUMERIC)  return "alphanumeric"; | 
 | 			if (mode == Mode.BYTE        )  return "byte"; | 
 | 			if (mode == Mode.KANJI       )  return "kanji"; | 
 | 			return "unknown"; | 
 | 		} else | 
 | 			return "multiple"; | 
 | 	} | 
 | 	 | 
 | 	// Returns the number of Unicode code points in the given UTF-16 string. | 
 | 	function countUnicodeChars(str) { | 
 | 		var result = 0; | 
 | 		for (var i = 0; i < str.length; i++, result++) { | 
 | 			var c = str.charCodeAt(i); | 
 | 			if (c < 0xD800 || c >= 0xE000) | 
 | 				continue; | 
 | 			else if (0xD800 <= c && c < 0xDC00) {  // High surrogate | 
 | 				i++; | 
 | 				var d = str.charCodeAt(i); | 
 | 				if (0xDC00 <= d && d < 0xE000)  // Low surrogate | 
 | 					continue; | 
 | 			} | 
 | 			throw "Invalid UTF-16 string"; | 
 | 		} | 
 | 		return result; | 
 | 	} | 
 | 	 | 
 | 	// Show the QR Code symbol's statistics as a string | 
 | 	var stats = "QR Code version = " + qr.version + ", "; | 
 | 	stats += "mask pattern = " + qr.mask + ", "; | 
 | 	stats += "character count = " + countUnicodeChars(text) + ",\n"; | 
 | 	stats += "encoding mode = " + describeSegments(segs) + ", "; | 
 | 	stats += "error correction = level " + "LMQH".charAt(qr.errorCorrectionLevel.ordinal) + ", "; | 
 | 	stats += "data bits = " + qrcodegen.QrSegment.getTotalBits(segs, qr.version) + "."; | 
 | 	var elem = document.getElementById("statistics-output"); | 
 | 	while (elem.firstChild != null) | 
 | 		elem.removeChild(elem.firstChild); | 
 | 	elem.appendChild(document.createTextNode(stats)); | 
 | } | 
 |  | 
 |  | 
 | function handleVersionMinMax(which) { | 
 | 	var minElem = document.getElementById("version-min-input"); | 
 | 	var maxElem = document.getElementById("version-max-input"); | 
 | 	var minVal = parseInt(minElem.value, 10); | 
 | 	var maxVal = parseInt(maxElem.value, 10); | 
 | 	minVal = Math.max(Math.min(minVal, qrcodegen.QrCode.MAX_VERSION), qrcodegen.QrCode.MIN_VERSION); | 
 | 	maxVal = Math.max(Math.min(maxVal, qrcodegen.QrCode.MAX_VERSION), qrcodegen.QrCode.MIN_VERSION); | 
 | 	if (which == "min" && minVal > maxVal) | 
 | 		maxVal = minVal; | 
 | 	else if (which == "max" && maxVal < minVal) | 
 | 		minVal = maxVal; | 
 | 	minElem.value = minVal.toString(); | 
 | 	maxElem.value = maxVal.toString(); | 
 | 	redrawQrCode(); | 
 | } | 
 |  | 
 |  | 
 | redrawQrCode(); |