2024-02-25 10:16:57 -05:00
|
|
|
{{define "theme-server-status/home-group-false"}}
|
|
|
|
<table class="table table-striped table-condensed table-hover">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th class="node-cell status center">{{tr "Status"}}</th>
|
|
|
|
<th class="node-cell name center">{{tr "Name"}}</th>
|
|
|
|
<th class="node-cell os center">{{tr "Platform"}}</th>
|
|
|
|
<th class="node-cell location center">{{tr "Location"}}</th>
|
2024-10-04 11:35:44 -04:00
|
|
|
<th v-if="nodesNoTag.some(item => item.additional && item.additional.price && Object.keys(item.additional.price).length > 0)" class="node-cell price center">{{tr "Price"}}</th>
|
2024-02-25 10:16:57 -05:00
|
|
|
<th class="node-cell uptime center">{{tr "Uptime"}}</th>
|
|
|
|
<th class="node-cell load center">{{tr "Load"}}</th>
|
|
|
|
<th class="node-cell network center">{{tr "NetSpeed"}}↓|↑</th>
|
|
|
|
<th class="node-cell traffic center">{{tr "NetTransfer"}}↓|↑</th>
|
|
|
|
<th class="node-cell cpu center">{{tr "CpuUsed"}}</th>
|
|
|
|
<th class="node-cell memory center">{{tr "MemUsed"}}</th>
|
|
|
|
<th class="node-cell hdd center">{{tr "DiskUsed"}}</th>
|
2024-10-04 11:35:44 -04:00
|
|
|
<th v-if="nodesNoTag.some(item => item.additional && item.additional.remaining && Object.keys(item.additional.remaining).length > 0)" class="node-cell remaining center">{{tr "Remaining"}}</th>
|
2024-02-25 10:16:57 -05:00
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
<tbody id="servers">
|
|
|
|
<template v-for="(node,index) in nodesNoTag">
|
|
|
|
<tr :id="'r'+node.ID" data-toggle="collapse" :data-target="'#rt'+node.ID" class="accordion-toggle" :class="index % 2 === 0 ? 'odd': 'even'"
|
2024-09-11 09:50:40 -04:00
|
|
|
aria-expanded="false" @click="showCharts(node.ID)">
|
2024-02-25 10:16:57 -05:00
|
|
|
<td class="node-cell status center">
|
|
|
|
<div class="status-container">
|
|
|
|
<div v-if="node.online" class="status-icon online"></div>
|
|
|
|
<div v-else class="status-icon offline"></div>
|
|
|
|
</div>
|
|
|
|
</td>
|
|
|
|
<td class="node-cell name center">@#node.name#@</td>
|
|
|
|
<td class="node-cell os center">
|
2024-06-14 21:43:30 -04:00
|
|
|
<i v-if='isWindowsPlatform(node.host.Platform)' class="windows icon"></i>
|
|
|
|
<i v-else-if='getFontLogoClass(node.host.Platform) == "" && node.stateuptime > 0' class="fl-tux"></i>
|
2024-02-25 10:16:57 -05:00
|
|
|
<i v-else :class="'fl-' + getFontLogoClass(node.host.Platform)"></i>
|
2024-10-07 23:39:44 -04:00
|
|
|
<span class="node-cell-os-text">@#getPlatformName(node.os) === '' && node.stateuptime > 0 ? 'linux' : getPlatformName(node.os)#@</span>
|
2024-02-25 10:16:57 -05:00
|
|
|
</td>
|
2024-10-07 23:39:44 -04:00
|
|
|
<td class="node-cell location center">
|
2024-11-01 09:28:14 -04:00
|
|
|
<i :class="'fi fi-' + (node.stateuptime > 0 ? (node.location || 'un') : '')"></i>
|
|
|
|
<span class="node-cell-location-text text-uppercase">@#node.stateuptime > 0 ? (node.location || 'UN') : ''#@</span>
|
2024-02-25 10:16:57 -05:00
|
|
|
</td>
|
2024-10-04 11:35:44 -04:00
|
|
|
<td v-if="nodesNoTag.some(item => item.additional && item.additional.price && Object.keys(item.additional.price).length > 0)" class="node-cell price center">
|
|
|
|
<template v-if="node.additional && node.additional.price">
|
2024-10-07 23:39:44 -04:00
|
|
|
<span v-if="node.additional.price.amount == 0" class="node-cell-price-text">FREE</span>
|
|
|
|
<span v-else-if="node.additional.price.amount == -1" class="node-cell-price-text">PAYG</span>
|
2024-10-04 11:35:44 -04:00
|
|
|
<span v-else class="node-cell-price-text">@#node.additional.price.amount#@@#(node.additional.price.cycle ? '/' + node.additional.price.cycle : '')#@</span>
|
2024-10-01 22:05:53 -04:00
|
|
|
</template>
|
|
|
|
</td>
|
2024-02-25 10:16:57 -05:00
|
|
|
<td style="text-align: center;" class="node-cell uptime">@#node.uptime#@</td>
|
|
|
|
<td style="text-align: center;" class="node-cell load">@#node.load#@</td>
|
|
|
|
<td style="text-align: center;" class="node-cell network">@#node.network#@</td>
|
|
|
|
<td style="text-align: center;" class="node-cell traffic">@#node.traffic#@</td>
|
|
|
|
<td class="node-cell cpu">
|
|
|
|
<div :class="['progress', node.online ? 'progress-online' : 'progress-offline']">
|
|
|
|
<div :style="node.cpu.style" :class="node.cpu.class"><small>@#node.cpu.percent#@%</small>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</td>
|
|
|
|
<td class="node-cell memory">
|
|
|
|
<div :class="['progress', node.online ? 'progress-online' : 'progress-offline']">
|
|
|
|
<div :style="node.memory.style" :class="node.memory.class">
|
|
|
|
<small>@#node.memory.percent#@%</small>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</td>
|
|
|
|
<td class="node-cell hdd">
|
|
|
|
<div :class="['progress', node.online ? 'progress-online' : 'progress-offline']">
|
|
|
|
<div :style="node.hdd.style" :class="node.hdd.class"><small>@#node.hdd.percent#@%</small>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</td>
|
2024-10-04 11:35:44 -04:00
|
|
|
<td v-if="nodesNoTag.some(item => item.additional && item.additional.remaining && Object.keys(item.additional.remaining).length > 0)" class="node-cell remaining">
|
2024-10-01 22:05:53 -04:00
|
|
|
<div :class="['progress', node.online ? 'progress-online' : 'progress-offline']">
|
2024-10-04 11:35:44 -04:00
|
|
|
<template v-if="node.additional && node.additional.remaining.format">
|
|
|
|
<div :style="node.additional.remaining.format.style" :class="node.additional.remaining.days == 'lifetime' ? '' : node.additional.remaining.format.class"></div>
|
2024-10-01 22:05:53 -04:00
|
|
|
<div class="additional">
|
2024-10-04 11:35:44 -04:00
|
|
|
<small v-if="node.additional.remaining.days == 'lifetime'">{{tr "Lifetime"}}</small>
|
|
|
|
<small v-else-if="node.additional.remaining.days < 0">{{tr "Expired"}}</small>
|
2024-10-01 22:05:53 -04:00
|
|
|
<small v-else>
|
2024-10-04 11:35:44 -04:00
|
|
|
<span class="node-cell-remaining-days">@#node.additional.remaining.days#@{{tr "Days"}}</span>
|
|
|
|
<span class="node-cell-remaining-percent">@#node.additional.remaining.percent#@%</span>
|
2024-10-01 22:05:53 -04:00
|
|
|
</small>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
</div>
|
|
|
|
</td>
|
2024-02-25 10:16:57 -05:00
|
|
|
</tr>
|
|
|
|
<tr class="expandRow" :class="index % 2 === 0 ? 'odd': 'even'">
|
|
|
|
<td colspan="16">
|
|
|
|
<div class="accordian-body collapse" :id="'rt'+node.ID">
|
|
|
|
<div style="display: flex;left-items: center;justify-content: center;flex-direction: column; max-width: 89vw">
|
2024-11-01 09:28:14 -04:00
|
|
|
<span v-if="node.additional && Object.keys(node.additional.plan).length > 0" class="node-cell-expand">
|
|
|
|
<span class="node-cell-expand-label">{{tr "Plan"}}:</span>
|
|
|
|
<span v-if="node.additional && Object.keys(node.additional.price).length > 0" class="plan price">
|
|
|
|
<span v-if="node.additional.price.amount == 0">FREE</span>
|
|
|
|
<span v-else-if="node.additional.price.amount == -1">PAYG</span>
|
|
|
|
<span v-else><i class="bi bi-cash-stack"></i> @#node.additional.price.amount#@@#(node.additional.price.cycle ? '/' + node.additional.price.cycle : '')#@</span>
|
|
|
|
</span>
|
|
|
|
<span v-if="node.additional && node.additional.remaining.endDate" class="plan enddate">
|
|
|
|
<span v-if="node.additional.remaining.days == 'lifetime'">{{tr "Lifetime"}}</span>
|
|
|
|
<span v-else-if="node.additional.remaining.days < 0">{{tr "Expired"}}</span>
|
2024-11-04 10:11:24 -05:00
|
|
|
<span v-else><i class="bi bi-clock-history"></i> @#node.additional.remaining.endDate.toISOString().split('T')[0]#@</span>
|
2024-11-01 09:28:14 -04:00
|
|
|
</span>
|
|
|
|
<span v-if="node.additional && node.additional.plan.bandwidth" class="plan bandwidth">
|
|
|
|
<i class="bi bi-speedometer2"></i>
|
|
|
|
<span>@#node.additional.plan.bandwidth#@</span>
|
|
|
|
</span>
|
2024-11-04 10:11:24 -05:00
|
|
|
<span v-if="node.additional && node.additional.plan.trafficVol" class="plan traffics">
|
2024-11-01 09:28:14 -04:00
|
|
|
<i v-if="node.additional && node.additional.plan.trafficType == 1" class="bi bi-arrow-up"></i>
|
2024-11-04 10:11:24 -05:00
|
|
|
<i v-else-if="node.additional && node.additional.plan.trafficType == 3" class="bi bi-arrows-collapse"></i>
|
2024-11-01 09:28:14 -04:00
|
|
|
<i v-else class="bi bi-arrow-down-up"></i>
|
|
|
|
<span>@#node.additional.plan.trafficVol#@</span>
|
|
|
|
</span>
|
|
|
|
<span v-if="node.additional && node.additional.plan.ipv4" class="plan ipv4">
|
|
|
|
<span>IPv4</span>
|
|
|
|
</span>
|
|
|
|
<span v-if="node.additional && node.additional.plan.ipv6" class="plan ipv6">
|
|
|
|
<span>IPv6</span>
|
|
|
|
</span>
|
|
|
|
<template v-if="node.additional && node.additional.plan.networkRoute.length>0" v-for="(item, index) in node.additional.plan.networkRoute" :key="index">
|
|
|
|
<span class="plan network-route" :class="{ last: index === node.additional.plan.networkRoute.length - 1 }">
|
|
|
|
<span>@#item#@</span>
|
|
|
|
</span>
|
|
|
|
</template>
|
|
|
|
<template v-if="node.additional && node.additional.plan.extra.length>0" v-for="(item, index) in node.additional.plan.extra" :key="index">
|
|
|
|
<span class="plan extra" :class="{ last: index === node.additional.plan.extra.length - 1 }">
|
|
|
|
<span>@#item#@</span>
|
|
|
|
</span>
|
|
|
|
</template>
|
|
|
|
</span>
|
2024-02-25 10:16:57 -05:00
|
|
|
<span class="node-cell-expand">
|
|
|
|
<span class="node-cell-expand-label">{{tr "Platform"}}:</span>
|
2024-10-07 23:39:44 -04:00
|
|
|
<span v-if="node.host.Platform">@#node.host.Platform#@@#node.host.PlatformVersion ? '-' + node.host.PlatformVersion : ''#@</span>
|
|
|
|
<span v-if="node.host.Arch">[@#node.host.Virtualization ? node.host.Virtualization + ':' : ''#@@#node.host.Arch#@]</span>
|
2024-02-25 10:16:57 -05:00
|
|
|
</span>
|
|
|
|
<span class="node-cell-expand" v-if="node.host.CPU">
|
|
|
|
<span class="node-cell-expand-label">CPU:</span>
|
2024-06-14 06:02:55 -04:00
|
|
|
@#node.host.CPU.join(",")#@ (@#node.cpu.percent#@%)
|
2024-02-25 10:16:57 -05:00
|
|
|
</span>
|
2024-06-22 22:27:33 -04:00
|
|
|
<span class="node-cell-expand" v-if="node.host.GPU">
|
|
|
|
<span class="node-cell-expand-label">GPU:</span>
|
2024-06-23 10:20:04 -04:00
|
|
|
@#node.host.GPU.join(",")#@
|
|
|
|
(@#parseInt(node.state.GPU >=0 ? node.state.GPU : 0)#@%)
|
2024-06-22 22:27:33 -04:00
|
|
|
</span>
|
2024-02-25 10:16:57 -05:00
|
|
|
<span class="node-cell-expand">
|
|
|
|
<span class="node-cell-expand-label">{{tr "DiskUsed"}}:</span>
|
2024-06-14 06:02:55 -04:00
|
|
|
@#formatByteSize(node.state.DiskUsed)#@ / @#formatByteSize(node.host.DiskTotal)#@ (@#node.hdd.percent#@%)
|
2024-02-25 10:16:57 -05:00
|
|
|
</span>
|
|
|
|
<span class="node-cell-expand">
|
|
|
|
<span class="node-cell-expand-label">{{tr "MemUsed"}}:</span>
|
2024-06-22 10:51:42 -04:00
|
|
|
@#formatByteSize(node.state.MemUsed)#@ / @#formatByteSize(node.host.MemTotal)#@ (@#node.memory.percent#@%)
|
2024-02-25 10:16:57 -05:00
|
|
|
</span>
|
2024-06-14 06:02:55 -04:00
|
|
|
<span v-if="node.host.SwapTotal > 0" class="node-cell-expand">
|
2024-02-25 10:16:57 -05:00
|
|
|
<span class="node-cell-expand-label">{{tr "SwapUsed"}}:</span>
|
|
|
|
@#formatByteSize(node.state.SwapUsed)#@ / @#formatByteSize(node.host.SwapTotal)#@
|
2024-06-14 06:02:55 -04:00
|
|
|
<span>(@#toFixed2(node.state.SwapUsed / node.host.SwapTotal * 100)#@%)</span>
|
|
|
|
</span>
|
|
|
|
<span v-else class="node-cell-expand">
|
|
|
|
<span class="node-cell-expand-label">{{tr "SwapUsed"}}: OFF</span>
|
2024-02-25 10:16:57 -05:00
|
|
|
</span>
|
|
|
|
<span class="node-cell-expand">
|
|
|
|
<span class="node-cell-expand-label">{{tr "NetTransfer"}}:</span>
|
2024-11-04 10:11:24 -05:00
|
|
|
IN @#formatByteSize(node.state.NetInTransfer)#@ / OUT @#formatByteSize(node.state.NetOutTransfer)#@
|
2024-02-25 10:16:57 -05:00
|
|
|
</span>
|
|
|
|
<span class="node-cell-expand load">
|
|
|
|
<span class="node-cell-expand-label">{{tr "Load"}}:</span>
|
|
|
|
@#toFixed2(node.state.Load1)#@ / @#toFixed2(node.state.Load5)#@ / @#toFixed2(node.state.Load15)#@
|
|
|
|
</span>
|
|
|
|
<span class="node-cell-expand">
|
|
|
|
<span class="node-cell-expand-label">{{tr "ProcessCount"}}:</span>
|
|
|
|
@#node.state.ProcessCount#@
|
|
|
|
</span>
|
|
|
|
<span class="node-cell-expand">
|
|
|
|
<span class="node-cell-expand-label">{{tr "ConnCount"}}:</span>
|
|
|
|
TCP @#node.state.TcpConnCount#@ / UDP @#node.state.UdpConnCount#@
|
|
|
|
</span>
|
|
|
|
<span class="node-cell-expand">
|
|
|
|
<span class="node-cell-expand-label">{{tr "BootTime"}}:</span>
|
|
|
|
@#formatTimestamp(node.host.BootTime)#@
|
|
|
|
</span>
|
|
|
|
<span class="node-cell-expand">
|
|
|
|
<span class="node-cell-expand-label">{{tr "LastActive"}}:</span>
|
|
|
|
@#new Date(node.lastActive).toLocaleString()#@
|
|
|
|
</span>
|
|
|
|
<span class="node-cell-expand">
|
|
|
|
<span class="node-cell-expand-label">{{tr "Uptime"}}:</span>
|
|
|
|
@#node.uptime#@
|
|
|
|
</span>
|
2024-06-22 10:51:42 -04:00
|
|
|
<span v-if="node.state.Temperatures && getTemperature(node.state.Temperatures, sensorList) > 0" @click="toggleDetailedTemp(node.ID)" class="node-cell-expand temp-detail" :id="`temp-${node.ID}`" temp-detail-show="0">
|
|
|
|
<span class="node-cell-expand-label">{{tr "Temperature"}}:</span>
|
|
|
|
<span :id="`temp-main-${node.ID}`" class="node-cell-expand-label">
|
|
|
|
@#getTemperature(node.state.Temperatures, sensorList)#@°C
|
|
|
|
<i class="bi bi-chevron-double-down"></i>
|
|
|
|
</span>
|
|
|
|
<span :id="`temp-detail-${node.ID}`" class="node-cell-expand-label" style="display:none">
|
|
|
|
<span v-for="temp in node.state.Temperatures" :key="temp.Name" v-if="temp.Temperature !== 0">
|
|
|
|
[ @#temp.Name#@ : @#temp.Temperature#@°C ]
|
|
|
|
</span>
|
|
|
|
<i class="bi bi-chevron-double-up"></i>
|
|
|
|
</span>
|
|
|
|
</span>
|
2024-02-25 10:16:57 -05:00
|
|
|
<span class="node-cell-expand">
|
|
|
|
<span class="node-cell-expand-label">{{tr "Version"}}:</span>
|
|
|
|
@#node.host.Version#@
|
|
|
|
</span>
|
|
|
|
<span class="node-echarts-expand">
|
2024-09-11 09:50:40 -04:00
|
|
|
<div class="chartbox" :id="`chart-${node.ID}`" chartbox-show="0" :key="node.ID" style="width: 100%; height: auto;"></div>
|
2024-02-25 10:16:57 -05:00
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</td>
|
|
|
|
</tr>
|
|
|
|
</template>
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
{{end}}
|