-
Notifications
You must be signed in to change notification settings - Fork 355
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Added OTP Verification Form & Drag and Drop Form (#573)
- Loading branch information
1 parent
0684082
commit c942ca3
Showing
11 changed files
with
471 additions
and
0 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,38 @@ | ||
<!DOCTYPE html> | ||
<html lang="en"> | ||
<head> | ||
<meta charset="UTF-8"> | ||
<meta http-equiv="X-UA-Compatible" content="IE=edge"> | ||
<meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||
<title>Drag and Drop File Upload</title> | ||
<link rel="stylesheet" href="style.css"> | ||
</head> | ||
<body> | ||
<div class="container"> | ||
<div class="header-section"> | ||
<h1>Upload Files</h1> | ||
<p>Upload files you want to share with your team members.</p> | ||
<p>PDF, Images & Videos are allowed.</p> | ||
</div> | ||
<div class="drop-section"> | ||
<div class="col"> | ||
<div class="cloud-icon"> | ||
<img src="icons/cloud.png" alt="cloud"> | ||
</div> | ||
<span>Drag & Drop your files here</span> | ||
<span>OR</span> | ||
<button class="file-selector">Browse Files</button> | ||
<input type="file" class="file-selector-input" multiple> | ||
</div> | ||
<div class="col"> | ||
<div class="drop-here">Drop Here</div> | ||
</div> | ||
</div> | ||
<div class="list-section"> | ||
<div class="list-title">Uploaded Files</div> | ||
<div class="list"></div> | ||
</div> | ||
</div> | ||
<script src="script.js"></script> | ||
</body> | ||
</html> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,107 @@ | ||
const dropArea = document.querySelector('.drop-section') | ||
const listSection = document.querySelector('.list-section') | ||
const listContainer = document.querySelector('.list') | ||
const fileSelector = document.querySelector('.file-selector') | ||
const fileSelectorInput = document.querySelector('.file-selector-input') | ||
|
||
// upload files with browse button | ||
fileSelector.onclick = () => fileSelectorInput.click() | ||
fileSelectorInput.onchange = () => { | ||
[...fileSelectorInput.files].forEach((file) => { | ||
if(typeValidation(file.type)){ | ||
uploadFile(file) | ||
} | ||
}) | ||
} | ||
|
||
// when file is over the drag area | ||
dropArea.ondragover = (e) => { | ||
e.preventDefault(); | ||
[...e.dataTransfer.items].forEach((item) => { | ||
if(typeValidation(item.type)){ | ||
dropArea.classList.add('drag-over-effect') | ||
} | ||
}) | ||
} | ||
// when file leave the drag area | ||
dropArea.ondragleave = () => { | ||
dropArea.classList.remove('drag-over-effect') | ||
} | ||
// when file drop on the drag area | ||
dropArea.ondrop = (e) => { | ||
e.preventDefault(); | ||
dropArea.classList.remove('drag-over-effect') | ||
if(e.dataTransfer.items){ | ||
[...e.dataTransfer.items].forEach((item) => { | ||
if(item.kind === 'file'){ | ||
const file = item.getAsFile(); | ||
if(typeValidation(file.type)){ | ||
uploadFile(file) | ||
} | ||
} | ||
}) | ||
}else{ | ||
[...e.dataTransfer.files].forEach((file) => { | ||
if(typeValidation(file.type)){ | ||
uploadFile(file) | ||
} | ||
}) | ||
} | ||
} | ||
|
||
|
||
// check the file type | ||
function typeValidation(type){ | ||
var splitType = type.split('/')[0] | ||
if(type == 'application/pdf' || splitType == 'image' || splitType == 'video'){ | ||
return true | ||
} | ||
} | ||
|
||
// upload file function | ||
function uploadFile(file){ | ||
listSection.style.display = 'block' | ||
var li = document.createElement('li') | ||
li.classList.add('in-prog') | ||
li.innerHTML = ` | ||
<div class="col"> | ||
<img src="icons/${iconSelector(file.type)}" alt=""> | ||
</div> | ||
<div class="col"> | ||
<div class="file-name"> | ||
<div class="name">${file.name}</div> | ||
<span>0%</span> | ||
</div> | ||
<div class="file-progress"> | ||
<span></span> | ||
</div> | ||
<div class="file-size">${(file.size/(1024*1024)).toFixed(2)} MB</div> | ||
</div> | ||
<div class="col"> | ||
<svg xmlns="http://www.w3.org/2000/svg" class="cross" height="20" width="20"><path d="m5.979 14.917-.854-.896 4-4.021-4-4.062.854-.896 4.042 4.062 4-4.062.854.896-4 4.062 4 4.021-.854.896-4-4.063Z"/></svg> | ||
<svg xmlns="http://www.w3.org/2000/svg" class="tick" height="20" width="20"><path d="m8.229 14.438-3.896-3.917 1.438-1.438 2.458 2.459 6-6L15.667 7Z"/></svg> | ||
</div> | ||
` | ||
listContainer.prepend(li) | ||
var http = new XMLHttpRequest() | ||
var data = new FormData() | ||
data.append('file', file) | ||
http.onload = () => { | ||
li.classList.add('complete') | ||
li.classList.remove('in-prog') | ||
} | ||
http.upload.onprogress = (e) => { | ||
var percent_complete = (e.loaded / e.total)*100 | ||
li.querySelectorAll('span')[0].innerHTML = Math.round(percent_complete) + '%' | ||
li.querySelectorAll('span')[1].style.width = percent_complete + '%' | ||
} | ||
http.open('POST', 'sender.php', true) | ||
http.send(data) | ||
li.querySelector('.cross').onclick = () => http.abort() | ||
http.onabort = () => li.remove() | ||
} | ||
// find icon for file | ||
function iconSelector(type){ | ||
var splitType = (type.split('/')[0] == 'application') ? type.split('/')[1] : type.split('/')[0]; | ||
return splitType + '.png' | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,199 @@ | ||
/* optional google fonts */ | ||
@import url('https://fonts.googleapis.com/css2?family=Ubuntu:wght@400;500;700&display=swap'); | ||
body{ | ||
background-color: #7494EC; | ||
padding: 30px; | ||
margin: 0px; | ||
} | ||
*{ | ||
font-family: 'Ubuntu', sans-serif; | ||
} | ||
.container{ | ||
text-align: center; | ||
width: 100%; | ||
max-width: 500px; | ||
min-height: 435px; | ||
margin: auto; | ||
background-color: white; | ||
border-radius: 16px; | ||
box-shadow: rgba(255, 255, 255, 0.1) 0px 1px 1px 0px inset, rgba(50, 50, 93, 0.25) 0px 50px 100px -20px, rgba(0, 0, 0, 0.3) 0px 30px 60px -30px; | ||
} | ||
|
||
.header-section{ | ||
padding: 25px 0px; | ||
} | ||
.header-section h1{ | ||
font-weight: 500; | ||
font-size: 1.7rem; | ||
text-transform: uppercase; | ||
color: #707EA0; | ||
margin: 0px; | ||
margin-bottom: 8px; | ||
} | ||
.header-section p{ | ||
margin: 5px; | ||
font-size: 0.95rem; | ||
color: #707EA0; | ||
} | ||
|
||
.drop-section{ | ||
min-height: 250px; | ||
border: 1px dashed #A8B3E3; | ||
background-image: linear-gradient(180deg, white, #F1F6FF); | ||
margin: 5px 35px 35px 35px; | ||
border-radius: 12px; | ||
position: relative; | ||
} | ||
.drop-section div.col:first-child{ | ||
opacity: 1; | ||
visibility: visible; | ||
transition-duration: 0.2s; | ||
transform: scale(1); | ||
width: 200px; | ||
margin: auto; | ||
} | ||
.drop-section div.col:last-child{ | ||
font-size: 40px; | ||
font-weight: 700; | ||
color: #c0cae1; | ||
position: absolute; | ||
top: 0px; | ||
bottom: 0px; | ||
left: 0px; | ||
right: 0px; | ||
margin: auto; | ||
width: 200px; | ||
height: 55px; | ||
pointer-events: none; | ||
opacity: 0; | ||
visibility: hidden; | ||
transform: scale(0.6); | ||
transition-duration: 0.2s; | ||
} | ||
|
||
.drag-over-effect div.col:first-child{ | ||
opacity: 0; | ||
visibility: hidden; | ||
pointer-events: none; | ||
transform: scale(1.1); | ||
} | ||
.drag-over-effect div.col:last-child{ | ||
opacity: 1; | ||
visibility: visible; | ||
transform: scale(1); | ||
} | ||
.drop-section .cloud-icon{ | ||
margin-top: 25px; | ||
margin-bottom: 20px; | ||
} | ||
.drop-section span, | ||
.drop-section button{ | ||
display: block; | ||
margin: auto; | ||
color: #707EA0; | ||
margin-bottom: 10px; | ||
} | ||
.drop-section button{ | ||
color: white; | ||
background-color: #5874C6; | ||
border: none; | ||
outline: none; | ||
padding: 7px 20px; | ||
border-radius: 8px; | ||
margin-top: 20px; | ||
cursor: pointer; | ||
box-shadow: rgba(50, 50, 93, 0.25) 0px 13px 27px -5px, rgba(0, 0, 0, 0.3) 0px 8px 16px -8px; | ||
} | ||
.drop-section input{ | ||
display: none; | ||
} | ||
|
||
.list-section{ | ||
display: none; | ||
text-align: left; | ||
margin: 0px 35px; | ||
padding-bottom: 20px; | ||
} | ||
.list-section .list-title{ | ||
font-size: 0.95rem; | ||
color: #707EA0; | ||
} | ||
.list-section li{ | ||
display: flex; | ||
margin: 15px 0px; | ||
padding-top: 4px; | ||
padding-bottom: 2px; | ||
border-radius: 8px; | ||
transition-duration: 0.2s; | ||
} | ||
.list-section li:hover{ | ||
box-shadow: #E3EAF9 0px 0px 4px 0px, #E3EAF9 0px 12px 16px 0px; | ||
} | ||
.list-section li .col{ | ||
flex: .1; | ||
} | ||
.list-section li .col:nth-child(1){ | ||
flex: .15; | ||
text-align: center; | ||
} | ||
.list-section li .col:nth-child(2){ | ||
flex: .75; | ||
text-align: left; | ||
font-size: 0.9rem; | ||
color: #3e4046; | ||
padding: 8px 10px; | ||
} | ||
.list-section li .col:nth-child(2) div.name{ | ||
overflow: hidden; | ||
white-space: nowrap; | ||
text-overflow: ellipsis; | ||
max-width: 250px; | ||
display: inline-block; | ||
} | ||
.list-section li .col .file-name span{ | ||
color: #707EA0; | ||
float: right; | ||
} | ||
.list-section li .file-progress{ | ||
width: 100%; | ||
height: 5px; | ||
margin-top: 8px; | ||
border-radius: 8px; | ||
background-color: #dee6fd; | ||
} | ||
.list-section li .file-progress span{ | ||
display: block; | ||
width: 0%; | ||
height: 100%; | ||
border-radius: 8px; | ||
background-image: linear-gradient(120deg, #6b99fd, #9385ff); | ||
transition-duration: 0.4s; | ||
} | ||
.list-section li .col .file-size{ | ||
font-size: 0.75rem; | ||
margin-top: 3px; | ||
color: #707EA0; | ||
} | ||
.list-section li .col svg.cross, | ||
.list-section li .col svg.tick{ | ||
fill: #8694d2; | ||
background-color: #dee6fd; | ||
position: relative; | ||
left: 50%; | ||
top: 50%; | ||
transform: translate(-50%, -50%); | ||
border-radius: 50%; | ||
} | ||
.list-section li .col svg.tick{ | ||
fill: #50a156; | ||
background-color: transparent; | ||
} | ||
.list-section li.complete span, | ||
.list-section li.complete .file-progress, | ||
.list-section li.complete svg.cross{ | ||
display: none; | ||
} | ||
.list-section li.in-prog .file-size, | ||
.list-section li.in-prog svg.tick{ | ||
display: none; | ||
} |
Oops, something went wrong.