2023-12-06 18:12:31 +01:00
|
|
|
{% extends 'base.html' %}
|
|
|
|
{%load static%}
|
|
|
|
{%block extracss%}
|
|
|
|
<link rel="stylesheet" href="{%static 'DetectionApp/css/upload.css' %}">
|
2024-03-14 23:20:12 +01:00
|
|
|
<script src="https://code.jquery.com/jquery-3.6.4.min.js"></script>
|
2023-12-06 18:12:31 +01:00
|
|
|
{%endblock extracss%}
|
|
|
|
{%block content%}
|
2023-12-23 17:01:39 +01:00
|
|
|
<form method="POST" enctype="multipart/form-data" id="upload_form">
|
2023-11-20 15:53:42 +01:00
|
|
|
{% csrf_token %}
|
|
|
|
<div class="side_menu">
|
2024-03-14 23:20:12 +01:00
|
|
|
</div>
|
|
|
|
<div class="upload_field">
|
|
|
|
<div id="carouselExampleControls" class="carousel slide" data-ride="carousel">
|
2023-12-13 02:11:29 +01:00
|
|
|
{% if not user.is_authenticated %}
|
|
|
|
<p id="description">Please login to submit image</p>
|
2023-12-19 17:33:46 +01:00
|
|
|
{% else %}
|
2023-11-20 15:53:42 +01:00
|
|
|
<p id="description">Choose image for analysis</p>
|
|
|
|
{%endif%}
|
2024-03-14 23:20:12 +01:00
|
|
|
<div class="carousel-inner" id="car-div">
|
|
|
|
<div class="carousel-item active">
|
|
|
|
<label for="id_image", class="upload_button" id="image-preview-container">
|
2023-11-20 15:53:42 +01:00
|
|
|
{{form.as_p}}
|
2024-03-14 23:20:12 +01:00
|
|
|
<img id="image-preview" src="{% static 'DetectionApp/images/upload_img.png' %}" alt="Image Preview" class="rounded"/>
|
2023-11-20 15:53:42 +01:00
|
|
|
</label>
|
2024-03-14 23:20:12 +01:00
|
|
|
</div>
|
|
|
|
<a class="carousel-control-prev" href="#carouselExampleControls" role="button" data-slide="prev" id="prev">
|
|
|
|
<span class="carousel-control-prev-icon" aria-hidden="true"></span>
|
|
|
|
<span class="sr-only">Previous</span>
|
|
|
|
</a>
|
|
|
|
<a class="carousel-control-next" href="#carouselExampleControls" role="button" data-slide="next" id="next">
|
|
|
|
<span class="carousel-control-next-icon" aria-hidden="true"></span>
|
|
|
|
<span class="sr-only">Next</span>
|
|
|
|
</a>
|
|
|
|
</div>
|
|
|
|
{% if not user.is_authenticated%}
|
|
|
|
<a href="{% url 'login' %}?next={{request.path}}" id="submit" class="btn btn-primary">Login</a>
|
|
|
|
{%else%}
|
|
|
|
<div class="spinner-border text-primary" role="status" style="display: none" id="spinner"></div>
|
|
|
|
<input type="submit" id="submit" value="Submit" class="btn btn-primary">
|
|
|
|
{%endif%}
|
|
|
|
|
2023-12-19 17:33:46 +01:00
|
|
|
</div>
|
2023-11-20 15:53:42 +01:00
|
|
|
</form>
|
2024-03-14 23:20:12 +01:00
|
|
|
</form>
|
|
|
|
{%endblock content%}
|
|
|
|
{%block extrascript%}
|
2023-11-27 16:52:09 +01:00
|
|
|
<script>
|
2023-12-19 17:33:46 +01:00
|
|
|
document.getElementById('id_image').addEventListener('change', function () {
|
|
|
|
var input = this;
|
2024-03-14 23:20:12 +01:00
|
|
|
var previewContainer = document.getElementById('car-div');
|
2023-11-27 16:52:09 +01:00
|
|
|
|
2023-12-19 17:33:46 +01:00
|
|
|
|
|
|
|
if (input.files && input.files.length > 1) {
|
2024-03-14 23:20:12 +01:00
|
|
|
var prev_cont = document.getElementById('image-preview-container')
|
|
|
|
prev_cont.parentElement.classList.remove("carousel-item")
|
|
|
|
prev_cont.parentElement.classList.remove("active")
|
|
|
|
prev_cont.style.display='none'
|
|
|
|
document.getElementById("prev").style.cssText = 'display:flex !important';
|
|
|
|
document.getElementById("next").style.cssText = 'display:flex !important';
|
2023-12-19 17:33:46 +01:00
|
|
|
for (var i = 0; i < input.files.length; i++) {
|
|
|
|
(function (index) {
|
2023-11-27 16:52:09 +01:00
|
|
|
var reader = new FileReader();
|
|
|
|
|
2023-12-19 17:33:46 +01:00
|
|
|
reader.onload = function (e) {
|
|
|
|
// Create a new image element for each preview
|
2024-03-14 23:20:12 +01:00
|
|
|
var div = document.createElement('div');
|
|
|
|
div.classList.add("carousel-item")
|
|
|
|
if (index < 1 ){
|
|
|
|
div.classList.add("active")
|
|
|
|
}
|
|
|
|
var img = document.createElement('img')
|
|
|
|
div.appendChild(img)
|
2023-12-19 17:33:46 +01:00
|
|
|
img.src = e.target.result;
|
|
|
|
img.id = 'image-preview'
|
|
|
|
img.style.display = 'block';
|
|
|
|
img.style.marginRight="5px"
|
2024-03-14 23:20:12 +01:00
|
|
|
img.style.opacity="100%"
|
2023-12-19 17:33:46 +01:00
|
|
|
|
|
|
|
// Append the image element to the container
|
2024-03-14 23:20:12 +01:00
|
|
|
{# previewContainer.style.overflowY='hidden' #}
|
|
|
|
{# previewContainer.style.overflowX='scroll' #}
|
|
|
|
{% comment %} previewContainer.style.width='640px' {% endcomment %}
|
|
|
|
{% comment %} previewContainer.style.height='460px' {% endcomment %}
|
|
|
|
previewContainer.appendChild(div);
|
2023-12-19 17:33:46 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
reader.readAsDataURL(input.files[index]);
|
|
|
|
})(i);
|
|
|
|
}
|
|
|
|
}else{
|
|
|
|
var reader = new FileReader();
|
|
|
|
|
2023-11-27 16:52:09 +01:00
|
|
|
reader.onload = function(e) {
|
|
|
|
document.getElementById('image-preview').src = e.target.result;
|
|
|
|
document.getElementById('image-preview').style.display = 'block';
|
2024-03-14 23:20:12 +01:00
|
|
|
document.getElementById("image-preview").style.opacity='100%';
|
2023-11-27 16:52:09 +01:00
|
|
|
}
|
2023-12-19 17:33:46 +01:00
|
|
|
reader.readAsDataURL(input.files[0]);
|
2023-11-27 16:52:09 +01:00
|
|
|
|
2023-12-19 17:33:46 +01:00
|
|
|
}
|
|
|
|
});
|
2024-01-04 21:33:13 +01:00
|
|
|
|
2024-03-14 23:20:12 +01:00
|
|
|
|
2024-01-04 21:33:13 +01:00
|
|
|
var user = `{{user.is_authenticated}}`
|
|
|
|
var upload = document.getElementById("id_image")
|
|
|
|
if (user.toLowerCase()=="false"){
|
|
|
|
upload.disabled=true;
|
|
|
|
}else if (user.toLowerCase()=="true"){
|
|
|
|
upload.disabled=false;
|
|
|
|
}
|
2024-03-14 23:20:12 +01:00
|
|
|
|
|
|
|
document.getElementById('id_image').addEventListener('change', function () {
|
|
|
|
$("#submit").click(function(event){
|
|
|
|
document.getElementById('image-preview-container').disabled=true;
|
|
|
|
$("#submit").hide();
|
|
|
|
$("#spinner").show();
|
|
|
|
$("#description").text("Please wait ...")
|
|
|
|
});});
|
|
|
|
$(document).ready(function() {
|
|
|
|
// Initial width adjustment
|
|
|
|
adjustCarouselWidth();
|
|
|
|
|
|
|
|
// Listen for window resize events
|
|
|
|
$(window).resize(function() {
|
|
|
|
adjustCarouselWidth();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
function adjustCarouselWidth() {
|
|
|
|
// Check if the window width is below 700 pixels and there are more than 1 images
|
|
|
|
if ($(window).width() < 700) {
|
|
|
|
// Set the desired width for the carousel-inner
|
|
|
|
$('#carouselExampleControls').css('width', '330px');
|
|
|
|
} else {
|
|
|
|
// Reset to the default width when window width is 700 pixels or more, or only 1 image
|
|
|
|
$('#carouselExampleControls').css('width', '640px');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
</script>
|
|
|
|
{%endblock extrascript%}
|