mirror of
				https://github.com/donaldzou/WGDashboard.git
				synced 2025-10-25 03:46:24 +00:00 
			
		
		
		
	Finished adding data usage on configuration list
This commit is contained in:
		| @@ -212,9 +212,10 @@ export default { | ||||
| 										{ | ||||
| 											label: 'Data Sent', | ||||
| 											data: [...this.historySentData.datasets[0].data, | ||||
| 												((sent - this.historyDataSentDifference[this.historyDataSentDifference.length - 1])*1000).toFixed(4)], | ||||
| 												((sent - this.historyDataSentDifference[this.historyDataSentDifference.length - 1])*1000) | ||||
| 													.toFixed(4)], | ||||
| 											fill: false, | ||||
| 											borderColor: ' #198754', | ||||
| 											borderColor: '#198754', | ||||
| 											tension: 0 | ||||
| 										} | ||||
| 									], | ||||
| @@ -237,6 +238,15 @@ export default { | ||||
| 											fill: false, | ||||
| 											borderColor: '#0d6efd', | ||||
| 											tension: 0 | ||||
| 										}, | ||||
| 										{ | ||||
| 											label: 'Data Sent', | ||||
| 											data: [...this.historySentData.datasets[0].data, | ||||
| 												((sent - this.historyDataSentDifference[this.historyDataSentDifference.length - 1])*1000) | ||||
| 													.toFixed(4)], | ||||
| 											fill: false, | ||||
| 											borderColor: '#198754', | ||||
| 											tension: 0 | ||||
| 										} | ||||
| 									], | ||||
| 								} | ||||
|   | ||||
| @@ -8,7 +8,6 @@ export default { | ||||
| 	components: {ConfigurationCard}, | ||||
| 	async setup(){ | ||||
| 		const wireguardConfigurationsStore = WireguardConfigurationsStore(); | ||||
| 		 | ||||
| 		return {wireguardConfigurationsStore} | ||||
| 	}, | ||||
| 	data(){ | ||||
| @@ -19,6 +18,13 @@ export default { | ||||
| 	async mounted() { | ||||
| 		await this.wireguardConfigurationsStore.getConfigurations(); | ||||
| 		this.configurationLoaded = true; | ||||
| 		 | ||||
| 		this.wireguardConfigurationsStore.ConfigurationListInterval = setInterval(() => { | ||||
| 			this.wireguardConfigurationsStore.getConfigurations() | ||||
| 		}, 10000) | ||||
| 	}, | ||||
| 	beforeUnmount() { | ||||
| 		clearInterval(this.wireguardConfigurationsStore.ConfigurationListInterval) | ||||
| 	} | ||||
| } | ||||
| </script> | ||||
| @@ -40,8 +46,8 @@ export default { | ||||
| 					<p class="text-muted" v-if="this.wireguardConfigurationsStore.Configurations.length === 0"> | ||||
| 						You don't have any WireGuard configurations yet. Please check the configuration folder or change it in "Settings". By default the folder is "/etc/wireguard". | ||||
| 					</p> | ||||
| 					<div class="d-flex gap-3 flex-column" v-else> | ||||
| 						<ConfigurationCard  v-for="c in this.wireguardConfigurationsStore.Configurations" :key="c.Name" :c="c"></ConfigurationCard> | ||||
| 					<div class="d-flex gap-3 flex-column mb-3" v-else> | ||||
| 						<ConfigurationCard v-for="c in this.wireguardConfigurationsStore.Configurations" :key="c.Name" :c="c"></ConfigurationCard> | ||||
| 					</div> | ||||
| 				</div> | ||||
| 			</Transition> | ||||
|   | ||||
| @@ -10,7 +10,6 @@ export default { | ||||
| 			Status: Boolean, | ||||
| 			PublicKey: String, | ||||
| 			PrivateKey: String | ||||
| 			 | ||||
| 		} | ||||
| 	}, | ||||
| 	data(){ | ||||
| @@ -52,27 +51,43 @@ export default { | ||||
| 				<i class="bi bi-chevron-right"></i> | ||||
| 			</h6> | ||||
| 		</RouterLink> | ||||
| 		<div class="card-footer d-flex align-items-center"> | ||||
| 			<small class="me-2 text-muted"> | ||||
| 				<strong>PUBLIC KEY</strong> | ||||
| 			</small> | ||||
| 			<small class="mb-0 d-block d-lg-inline-block "> | ||||
| 				<samp style="line-break: anywhere">{{c.PublicKey}}</samp> | ||||
| 			</small> | ||||
| 			<div class="form-check form-switch ms-auto"> | ||||
| 				<label class="form-check-label" style="cursor: pointer" :for="'switch' + c.PrivateKey"> | ||||
| 					{{this.configurationToggling ? 'Turning ':''}} | ||||
| 					{{c.Status ? "On":"Off"}} | ||||
| 					<span v-if="this.configurationToggling"  | ||||
| 					      class="spinner-border spinner-border-sm" aria-hidden="true"></span> | ||||
| 				</label> | ||||
| 				<input class="form-check-input" | ||||
| 				       style="cursor: pointer" | ||||
| 				       :disabled="this.configurationToggling" | ||||
| 				       type="checkbox" role="switch" :id="'switch' + c.PrivateKey" | ||||
| 				       @change="this.toggle()" | ||||
| 				       v-model="c.Status" | ||||
| 				> | ||||
| 		<div class="card-footer d-flex gap-2 flex-column"> | ||||
| 			<div class="d-flex gap-4"> | ||||
| 				<small > | ||||
| 					<i class="bi bi-arrow-down-up me-2"></i>{{c.DataUsage.Total > 0 ? c.DataUsage.Total.toFixed(4) : 0}} GB | ||||
| 				</small> | ||||
| 				<small class="text-primary-emphasis"> | ||||
| 					<i class="bi bi-arrow-down me-2"></i>{{c.DataUsage.Receive > 0 ? c.DataUsage.Receive.toFixed(4) : 0}} GB | ||||
| 				</small> | ||||
| 				<small class="text-success-emphasis"> | ||||
| 					<i class="bi bi-arrow-up me-2"></i>{{c.DataUsage.Sent > 0 ? c.DataUsage.Sent.toFixed(4) : 0}} GB | ||||
| 				</small> | ||||
| 				<small class="ms-auto"> | ||||
| 					<span class="dot me-2" :class="{active: c.ConnectedPeers > 0}"></span>{{c.ConnectedPeers}} Peers | ||||
| 				</small> | ||||
| 			</div> | ||||
| 			<div class="d-flex align-items-center"> | ||||
| 				<small class="me-2 text-muted"> | ||||
| 					<strong>Public Key</strong> | ||||
| 				</small> | ||||
| 				<small class="mb-0 d-block d-lg-inline-block "> | ||||
| 					<samp style="line-break: anywhere">{{c.PublicKey}}</samp> | ||||
| 				</small> | ||||
| 				<div class="form-check form-switch ms-auto"> | ||||
| 					<label class="form-check-label" style="cursor: pointer" :for="'switch' + c.PrivateKey"> | ||||
| 						{{this.configurationToggling ? 'Turning ':''}} | ||||
| 						{{c.Status ? "On":"Off"}} | ||||
| 						<span v-if="this.configurationToggling" | ||||
| 						      class="spinner-border spinner-border-sm" aria-hidden="true"></span> | ||||
| 					</label> | ||||
| 					<input class="form-check-input" | ||||
| 					       style="cursor: pointer" | ||||
| 					       :disabled="this.configurationToggling" | ||||
| 					       type="checkbox" role="switch" :id="'switch' + c.PrivateKey" | ||||
| 					       @change="this.toggle()" | ||||
| 					       v-model="c.Status" | ||||
| 					> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 		</div> | ||||
| 	</div> | ||||
|   | ||||
| @@ -6,6 +6,7 @@ export const WireguardConfigurationsStore = defineStore('WireguardConfigurations | ||||
| 	state: () => ({ | ||||
| 		Configurations: undefined, | ||||
| 		searchString: "", | ||||
| 		ConfigurationListInterval: undefined, | ||||
| 		PeerScheduleJobs: { | ||||
| 			dropdowns: { | ||||
| 				Field: [ | ||||
|   | ||||
		Reference in New Issue
	
	Block a user