ExCeipt / templates /extractor.html
Scezui's picture
added files
0d6ddfa
raw
history blame
16.7 kB
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<!--Favicon-->
<link rel="shortcut icon" href="/static/images/favicon.ico" title="Favicon" />
<!-- Main CSS Files -->
<link rel="stylesheet" href="/static/css/style.css">
<!-- Color CSS -->
<link rel="stylesheet" href="/static/css/color.css">
<!--Icon Fonts - Font Awesome Icons-->
<link rel="stylesheet" href="/static/css/font-awesome.min.css">
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.2.0/css/all.min.css">
<!-- Animate CSS-->
<link href="css/animate.css" rel="stylesheet" type="text/css">
<!--Google Webfonts-->
<link href='https://fonts.googleapis.com/css?family=Open+Sans:400,300,600,700,800' rel='stylesheet' type='text/css'>
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link href="https://fonts.googleapis.com/css2?family=Poppins:wght@100;200;300;400;500;600&display=swap" rel="stylesheet">
<title>ExCeipt | Extractor</title>
<style>
.containerz {
display: flex;
width: 100vw;
height: 100vh;
}
.left-column {
padding-top: 100px;
flex: 2;
background-color: #ddd;
padding: 20px;
overflow-y: hidden;
max-height: 100vh;
width: 100%;
box-shadow: inset 0 15px 30px rgba(0, 0, 0, 0.1);
}
.right-column {
flex: 2;
background-color: #ffffff;
padding: 20px;
overflow: auto; /* or 'visible' or 'scroll' */
}
.backbutton {
box-sizing: border-box;
border-radius: 10px;
color: var(--secondary-color);
padding: 1em 1.8em;
display: flex;
transition: 0.2s background;
align-items: center;
gap: 0.6em;
font-weight: bold;
background: rgba(255, 255, 255, 0.6);
backdrop-filter: blur(10px);
border: none;
cursor: pointer;
position: fixed;
z-index: 999;
}
.backbutton span {
text-decoration: none;
color: black;
font-family: 'Poppins', sans-serif, Arial, Helvetica;
font-size: 14px;
font-weight: 300;
}
.backbutton:hover {
background: linear-gradient(45deg, #FF6347, #FFA07A);
transition: all .3s ease-in-out;
}
.backbutton:hover span {
color: white;
transition: all .3s ease-in-out;
}
.backbutton:hover i {
color: white;
transition: all .3s ease-in-out;
}
.left-column h1 {
padding-top: 45px;
}
#canvas-container {
position: relative;
overflow: hidden;
width: 100%;
height: 100%;
}
#canvas {
cursor: grab;
user-select: none;
}
#upload-input {
margin-top: 10px;
object-position: center;
}
.bordered-table {
justify-content: center;
display: flex;
padding: 0px 30px;
}
.bordered-table tbody td.full-width {
display: flex;
flex-wrap: wrap;
align-items: center;
}
.bordered-table tbody td.full-width .label {
width: 100px;
text-align: right;
margin-right: 5px;
}
.bordered-table tbody td.full-width input {
flex-grow: 1;
}
.bordered-table tbody td.full-width {
display: grid;
grid-template-columns: 100px 1fr;
}
.bordered-table tbody td.full-width .label {
justify-self: end;
}
#logox {
display: flex;
justify-content: center;
}
#logox img {
position: relative;
object-position: center;
width: 25%;
height: 25%;
padding: 10px 10px 10px 10px;
}
.receipt {
margin: 20px 20px;
border: 1px solid #ccc;
border-radius: 10px;
font:14px;
}
.receipt1 {
margin: 20px 20px;
font:14px;
}
.receipt1 table {
border-radius:10px;
}
.filenm{
padding: 1em 1.8em;
box-sizing: border-box;
border-radius: 10px;
display: flex;
transition: 0.2s background;
align-items: center;
gap: 0.6em;
background: rgba(255, 255, 255, 0.6);
backdrop-filter: blur(10px);
margin-right: 10px;
font-size: 14px;
font-weight: 300;
}
.receipt h1 {
text-align: center;
}
.receipt .details {
margin: 0px 0px 0px 15px;
}
.receipt table {
width: 100%;
border-collapse: collapse;
margin-bottom: 20px;
}
.receipt table th,
.receipt table td {
border: 1px solid #ccc;
padding: 5px;
}
.receipt table th {
background-color: #f0f0f0;
text-align: left;
}
.receipt tfoot td {
text-align: right;
font-weight: bold;
}
#dataTable {
border-radius:10px;
border-collapse: collapse;
width: 100%;
width: 100%;
border-collapse: collapse;
table-layout: fixed;
overflow-x: auto;
}
#receiptdiv{
display: none;
}
#dataTable th, #dataTable td {
font-size: 12px;
text-align: center;
padding: 3px;
}
#downloadbutton {
display: none;
}
#loadingSpinner {
position: relative;
top: 20%;
left: 50%;
transform: translate(-50%, -50%);
border: 4px solid rgba(0, 0, 0, 0.1);
border-left: 4px solid #FF8B4A;
border-radius: 50%;
width: 30px;
height: 30px;
animation: spin 1s linear infinite;
display: none; /* Hide initially */
}
@keyframes spin {
0% { transform: rotate(0deg); }
100% { transform: rotate(360deg); }
}
#uploadbutton:disabled {
cursor: not-allowed;
background-color: #dddddd;
}
.labels {
margin: 0 0 0 20px;
font-weight: 500;
}
.labels p{
font-size: 14px;
padding-top: 8px;
line-height: 15px;
color:ccc;
}
#filenm{
position: relative;
z-index:999;
}
.valid{
padding-left:8px;
font-weight:300;
font-size:14px;
}
.details1{
border-radius:10px;
z-index:-1;
}
</style>
<script src="https://cdn.lordicon.com/lordicon.js"></script>
</head>
<body>
<!-- Preloader -->
<div id="preloader">
<div class="ocrloader" id="status">
<em></em>
<div>
<i></i><i></i><i></i><i></i><i></i><i></i><i></i>
<i></i><i></i><i></i><i></i><i></i><i></i><i></i>
<i></i><i></i><i></i>
</div>
<span></span>
</div>
</div>
<!--End of Preloader-->
<div id="flash-container" class="alert alert-danger" role="alert">
<!-- Flash message will be displayed here -->
</div>
<div class="containerz">
<div class="left-column">
<button class="backbutton" id="submitButton" onclick="window.location.href='{{ url_for('index') }}'">
<i class="fa-solid fa-arrow-left"></i>
<span>Back</span>
</button>
<div id="filenm">
<div style="display: flex; align-items: center; position: absolute; top: 10px; right: 0;">
<span class="filenm">
<lord-icon
src="https://cdn.lordicon.com/xpgofwru.json"
trigger="in"
delay ="500"
state="hover-file-2"
colors="primary:#ff8b4a"
style="width:20px;height:20px">
</lord-icon>
{{ old_name }}</span>
</button>
</div>
</div>
<div id="canvas-container">
<canvas id="c3"></canvas>
{% if uploaded_file %}
<img src="{{ url_for('static', filename='uploads/' + uploaded_file) }}" id="my-image" hidden>
{% else %}
<p>No file uploaded.</p>
{% endif %}
</div>
</div>
<div class="right-column">
<div id="logox">
<img src="/static/images/logo.png" id="banner-logo" alt="Landing Page" />
</div>
<div style="display: flex; align-items: center;">
</div>
<hr style="color: #ccc; width:95%; opacity:0.35;">
<div class="labels" style="margin: 0 0 0 20px;"><p>Receipt Verification</p></div>
<div class="receipt">
<div class="details">
<div style="display: flex; align-items: center;">
{% if prediction_result.lower() == 'receipt' %}
<lord-icon
src="https://cdn.lordicon.com/lomfljuq.json"
trigger="in"
delay="1500"
colors="primary:#16c72e"
state="morph-check-in-1"
style="width:25px;height:25px">
</lord-icon>
<p class="valid">The image uploaded is a Valid Receipt.</p>
{% else %}
<lord-icon
src="https://cdn.lordicon.com/zxvuvcnc.json"
trigger="in"
delay="1500"
state="morph-cross-in"
colors="primary:#e83a30"
style="width:25px;height:25px">
</lord-icon>
<p class="valid">The image uploaded is NOT a Receipt Please return and upload again.</p>
{% endif %}
</div>
</div>
</div>
<hr style="color: #ccc; width:95%; opacity:0.35;">
<div class="labels"><p>Text Extraction</p></div>
<div style="text-align: center;">
<a href="{{ url_for('run_inference') }}">
<button id="uploadbutton" class="uploadbutton" type="submit">Extract</button>
</a>
</div>
<div class="loader" id="loader">
<em></em>
<div>
<i></i><i></i><i></i><i></i><i></i><i></i><i></i>
<i></i><i></i><i></i><i></i><i></i><i></i><i></i>
<i></i><i></i><i></i>
</div>
<span></span>
</div>
<div class="receipt1" id="receiptdiv">
<div class="details1">
<table id="dataTable" border="1">
<thead>
<tr>
<th>Receipt No.</th>
<th>Merchant</th>
<th>Address</th>
<th>Date</th>
<th>Time</th>
<th>Items</th>
<th>Price</th>
<th>Total</th>
<th>Vat Tax</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</div>
<hr style="color: #ccc; width:95%; opacity:0.35;">
<div class="labels" style="margin: 0 0 0 20px;"><p>Export</p></div>
<div style="text-align: center;">
<a href="{{ url_for('download_csv') }}">
<button id="downloadbutton" class="uploadbutton" type="submit">Export CSV</button>
</a>
</div>
</div>
<a href="https://lordicon.com/" hidden >Icons by Lordicon.com</a>
<script>
document.addEventListener('DOMContentLoaded', function() {
const dataTable = document.getElementById('receiptdiv');
const loadingSpinner = document.getElementById('loader');
const runInferenceButton = document.getElementById('uploadbutton');
const exportCSVButton = document.getElementById('downloadbutton');
document.getElementById('uploadbutton').addEventListener('click', function() {
loadingSpinner.style.display = 'inline-block'; // Show loading spinner
runInferenceButton.disabled = true;
runInference();
});
async function runInference() {
await fetch('/run_inference');
setTimeout(function() {
loadingSpinner.style.display = 'none';
runInferenceButton.style.display = 'none';
exportCSVButton.style.display = 'inline-block';
getData();
}, 500);
}
async function getData() {
const response = await fetch('/get_data');
const data = await response.text();
updateTable(data);
// Show the table when data is updated
dataTable.style.display = 'table';
}
function updateTable(data) {
const table = data.split('\n').map(row => row.trim()).filter(Boolean).slice(1);
const tbody = document.querySelector('#dataTable tbody');
tbody.innerHTML = ''; // Clear existing rows
table.forEach(row => {
const column = row.split('|');
const RECEIPTNUMBER = column[0] || ''; // Set to an empty string if undefined
const MERCHANTNAME = column[1] || '';
const MERCHANTADDRESS = column[2] || '';
const TRANSACTIONDATE = column[3] || '';
const TRANSACTIONTIME = column[4] || '';
const ITEMS = column[5] || '';
const PRICE = column[6] || '';
const TOTAL = column[7] || '';
const VATTAX = column[8] || '';
const tr = document.createElement('tr');
tr.innerHTML = `
<td contenteditable="true">${RECEIPTNUMBER}</td>
<td contenteditable="true">${MERCHANTNAME}</td>
<td contenteditable="true">${MERCHANTADDRESS}</td>
<td contenteditable="true">${TRANSACTIONDATE}</td>
<td contenteditable="true">${TRANSACTIONTIME}</td>
<td contenteditable="true">${ITEMS}</td>
<td contenteditable="true">${PRICE}</td>
<td contenteditable="true">${TOTAL}</td>
<td contenteditable="true">${VATTAX}</td>
`;
tbody.appendChild(tr);
});
}
});
</script>
<!-- Include JavaScript resources -->
<script src="/static/js/jquery.1.8.3.min.js"></script>
<script src="/static/js/wow.min.js"></script>
<script src="/static/js/featherlight.min.js"></script>
<script src="/static/js/featherlight.gallery.min.js"></script>
<script src="/static/js/jquery.enllax.min.js"></script>
<script src="/static/js/jquery.scrollUp.min.js"></script>
<script src="/static/js/jquery.easing.min.js"></script>
<script src="/static/js/jquery.stickyNavbar.min.js"></script>
<script src="/static/js/jquery.waypoints.min.js"></script>
<script src="/static/js/images-loaded.min.js"></script>
<script src="/static/js/lightbox.min.js"></script>
<script src="/static/js/site.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/4.5.0/fabric.min.js"></script>
</body>
</html>