In this POC we can see how to develop QR code scan in Pega using Javascript
Demo video:
Create a case:
data:image/s3,"s3://crabby-images/2da76/2da762b3c1e4f877023c8516a0fb4d694364857d" alt=""
Process Flow
data:image/s3,"s3://crabby-images/f8d4a/f8d4a8dd08ab49523878e0f36719f3c7cc7c6721" alt=""
Flow Action
data:image/s3,"s3://crabby-images/00b0c/00b0c8be82a4ecb5339ee6c39cb043e90d98f90b" alt=""
Section – MainQRCodeScan
Create a Text Area – Property – QRCodeData
Create a embedded section and call the custom HTML section ()
data:image/s3,"s3://crabby-images/a755d/a755db586fe688c5fe04fbe8cd5b618bd396fb4c" alt=""
Embedded section
data:image/s3,"s3://crabby-images/e36c9/e36c96f3ad85c7060664954dcfb0b5564795489b" alt=""
data:image/s3,"s3://crabby-images/66ace/66ace719d78f5435a8e74c6a7bf10cf17dc16028" alt=""
Click Submit
Then the MainQRCodeScan will look like as below
data:image/s3,"s3://crabby-images/1427d/1427dc361a61a2345fe4909f263f1be3c0e1f65f" alt=""
QRCodeScan section – custom HTML section – Calling the javascript through iframe to get the scan result
data:image/s3,"s3://crabby-images/e6fcb/e6fcbb10a9d87fd724dc53dcf9718456af830eb8" alt=""
You can get the QRcode scan javascript from the internet. Create a folder MyQRCode
Place the folder MyQRCode folder containing
- index.html
- html5-qrcode-min.js
in the path — D:\PEGA8.5.1\Install_PRPC\PRPCPersonalEdition\tomcat\webapps
Now, type in the browser:
http://localhost:8080/MyQRCode/index.html
Check that the javascript is working fine. Then use the below code in Pega section
******************************************************************************************************
<html>
<body>
//keep the index.html in the below path
<iframe id=”myiframe” src=”http://localhost:8080/MyQRCode/index.html” style=”width:1000px; height:300px;”></iframe>
<button onclick=”myFunction()”>Get Scan Result</button>
<script>
function myFunction() {
var iframe3 = document.getElementById(“myiframe”).contentWindow.document.getElementById(“result”).firstChild.innerHTML;
//set the value from javascript to pyWorkPage
pega.api.ui.actions.setValue(“pyWorkPage.QRCodeData”, iframe3, false);
}
</script>
</body>
</html>
********************************************************************************************
Test Scenario:
data:image/s3,"s3://crabby-images/20eeb/20eeb06b07094cfabeec1a73df65a863fbac53ff" alt=""
Click New – QRCodeScan
data:image/s3,"s3://crabby-images/5aef2/5aef2350a7eeb0bd7848b22cfe25f95839b3a054" alt=""
data:image/s3,"s3://crabby-images/d173e/d173e7501bab4b177036ea9b0caf255a693b6054" alt=""
You can upload a file and scan the QR code which will be placed in the Pega property QR Code Data.
You can scan a code using the camera and place the data in the Pega property by clicking Get Scan Result.
data:image/s3,"s3://crabby-images/f053e/f053e039ce076692cd9c3e7cd0f877b1fe0d28e0" alt=""
data:image/s3,"s3://crabby-images/24393/24393c8340af3b423ada949d9a38cd60651ff42c" alt=""
Now click Get Scan Result
data:image/s3,"s3://crabby-images/b085a/b085ac3dfb39637eb35ca27231a16bd82ae22f9e" alt=""
Data moved to the text area – QR Code Data
Click submit to create the case–then the Scanned data will be posted in the pyWorkPage
data:image/s3,"s3://crabby-images/3b3d9/3b3d950ab80cf820015127ede25847a3ffc364bd" alt=""
Case number:1007
data:image/s3,"s3://crabby-images/24d57/24d57587de9a1d2412f2963e7c28c60637e58b64" alt=""
QRCodeData is populated with the QRcode that has been scanned.