修复数据不更新的问题、分组显示改为折叠菜单

This commit is contained in:
我若为王 2021-01-12 16:34:11 +08:00 committed by GitHub
parent be3fc41755
commit b4c8010715
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -7,13 +7,10 @@
<div class="nb-container"> <div class="nb-container">
<div class="ui container"> <div class="ui container">
<div id="app"> <div id="app">
<div class="ui" v-for="group in groups" >
<br>
<div class="ui horizontal divider">
@#group.Tag#@
</div>
<div class="ui four stackable status cards"> <div v-for='server in group.data' :id="server.ID" class="card"> <div class="ui styled fluid accordion" v-for="group in groups">
<div class="active title"><i class="dropdown icon"></i>@#(group.Tag!==''?group.Tag:'默认')#@</div>
<div class="active content"><div class="ui four stackable status cards"> <div v-for='server in group.data' :id="server.ID" class="card">
<div class="content" v-if='server.Host'> <div class="content" v-if='server.Host'>
<div class="header"><i :class="server.Host.CountryCode + ' flag'"></i><i <div class="header"><i :class="server.Host.CountryCode + ' flag'"></i><i
v-if='server.Host.Platform == "darwin"' class="apple icon"></i><i v-if='server.Host.Platform == "darwin"' class="apple icon"></i><i
@ -95,8 +92,7 @@
<p>@#server.Name#@</p> <p>@#server.Name#@</p>
<p>节点已离线</p> <p>节点已离线</p>
</div> </div>
</div></div> </div></div></div>
</div> </div>
</div> </div>
</div> </div>
@ -104,7 +100,6 @@
{{template "common/footer" .}} {{template "common/footer" .}}
<script> <script>
const initData = {{.Servers}}; const initData = {{.Servers}};
var statusCards = new Vue({ var statusCards = new Vue({
el: '#app', el: '#app',
delimiters: ['@#', '#@'], delimiters: ['@#', '#@'],
@ -124,41 +119,9 @@
}, },
methods: { methods: {
group() { group() {
this.groups = this.groupingData(this.data, "Tag") this.groups = groupingData(this.data, "Tag")
console.log(this.groups) console.log(this.groups)
}, },
groupingData(data, filed) {
let map = {};
let dest = [];
data.forEach(item => {
if (!map[item[filed]]) {
dest.push({
[filed]: item[filed],
data: [item]
});
map[item[filed]] = item;
} else {
dest.forEach(dItem => {
if (dItem[filed] == item[filed]) {
dItem.data.push(item);
}
});
}
})
return dest;
},
formatPercent(live, used, total) { formatPercent(live, used, total) {
const percent = live ? (parseInt(used / total * 100) || 0) : -1 const percent = live ? (parseInt(used / total * 100) || 0) : -1
if (!this.cache[percent]) { if (!this.cache[percent]) {
@ -209,6 +172,38 @@
} }
} }
}) })
function groupingData(data, filed){
let map = {};
let dest = [];
data.forEach(item => {
if (!map[item[filed]]) {
dest.push({
[filed]: item[filed],
data: [item]
});
map[item[filed]] = item;
} else {
dest.forEach(dItem => {
if (dItem[filed] == item[filed]) {
dItem.data.push(item);
}
});
}
})
return dest;
}
const wsProtocol = window.location.protocol == "https:" ? "wss" : "ws" const wsProtocol = window.location.protocol == "https:" ? "wss" : "ws"
const ws = new WebSocket(wsProtocol + '://' + window.location.host + '/ws'); const ws = new WebSocket(wsProtocol + '://' + window.location.host + '/ws');
ws.onopen = function (evt) { ws.onopen = function (evt) {
@ -235,6 +230,7 @@
} }
} }
} }
statusCards.groups=groupingData(statusCards.servers,"Tag")
} }
ws.onclose = function () { ws.onclose = function () {
$.suiAlert({ $.suiAlert({
@ -245,5 +241,8 @@
position: 'top-center', position: 'top-center',
}); });
} }
$('.ui.accordion')
.accordion({"exclusive":false})
;
</script> </script>
{{end}} {{end}}