download bar working

This commit is contained in:
Cuptain 2024-06-24 11:24:04 +10:00
parent 144f098661
commit f53a34a7cc
4 changed files with 32 additions and 1 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 757 KiB

After

Width:  |  Height:  |  Size: 367 KiB

View File

@ -17,6 +17,9 @@
<div class="Logo"> <div class="Logo">
<img src="assets/Title.png" alt="Title" id="Title"> <img src="assets/Title.png" alt="Title" id="Title">
</div> </div>
<div class="progress">
<div class="progressFinished"></div>
</div>
<div class="container" data-bs-theme="dark"> <div class="container" data-bs-theme="dark">

View File

@ -1,11 +1,16 @@
const { invoke } = window.__TAURI__.tauri; const { invoke } = window.__TAURI__.tauri;
const { listen } = window.__TAURI__.event; const { listen } = window.__TAURI__.event;
const { ask } = window.__TAURI__.dialog; const { ask } = window.__TAURI__.dialog;
const downBar = document.querySelector(".progressFinished");
//import { listen } from '@tauri-apps/api'; //import { listen } from '@tauri-apps/api';
let greetInputEl; let greetInputEl;
let greetMsgEl; let greetMsgEl;
function progressBar() {
}
const download_progress = listen("download_progress", (progress) => { const download_progress = listen("download_progress", (progress) => {
console.log("Downloading"); console.log("Downloading");
@ -15,6 +20,8 @@ const download_progress = listen("download_progress", (progress) => {
document.getElementById("download_name").textContent = "Downloading "+progress.payload.download_name; document.getElementById("download_name").textContent = "Downloading "+progress.payload.download_name;
document.getElementById("download_progress").textContent = downProgress + "MB / "+downTotal+"MB"; document.getElementById("download_progress").textContent = downProgress + "MB / "+downTotal+"MB";
document.getElementById("launchGame").disabled = true; document.getElementById("launchGame").disabled = true;
downBar.style.width = `${(progress.payload.downloaded / progress.payload.total) * 100}%`;
document.querySelector(".progress").style.visibility = "visible";
}); });
const download_finished = listen("download_finished", (event) => { const download_finished = listen("download_finished", (event) => {
@ -22,6 +29,8 @@ const download_finished = listen("download_finished", (event) => {
document.getElementById("download_progress").textContent = ""; document.getElementById("download_progress").textContent = "";
document.getElementById("launchGame").disabled = false; document.getElementById("launchGame").disabled = false;
document.getElementById("launchGame").textContent ="Launch Minecraft"; document.getElementById("launchGame").textContent ="Launch Minecraft";
downBar.style.width = 0;
document.querySelector(".progress").style.visibility = "hidden";
}); });
const update_dialog = listen("update_dialog", (event) => { const update_dialog = listen("update_dialog", (event) => {
@ -50,7 +59,7 @@ function load() {
window.onload = async function() { window.onload = async function() {
invoke("install_prism"); invoke("install_prism");
invoke("get_modpacks").then(addModpacks); invoke("get_modpacks").then(addModpacks);
console.log(downBar.style.width)
} }
function addModpacks(modpacks) { function addModpacks(modpacks) {

View File

@ -163,6 +163,24 @@ button {
.show {display:block;} .show {display:block;}
} }
.progress {
background-color: grey;
border-radius: 20px;
height: 15px;
width: 100%;
visibility: hidden;
}
.progressFinished{
display: flex;
align-items: center;
justify-content: center;
background-color: #3498DB;
border-radius: 20px;
height: 100%;
width: 0;
/*transition: 1s ease 0.3s;*/
}
#Modpacks{ #Modpacks{
width:300px ; width:300px ;
align-content: center; align-content: center;
@ -180,6 +198,7 @@ button {
height: auto; height: auto;
background-repeat: no-repeat; background-repeat: no-repeat;
flex-direction: column; flex-direction: column;
background-size: contain;
} }
#launchGame { #launchGame {
margin-top: 20px; margin-top: 20px;