mirror of
https://github.com/TwiN/gatus.git
synced 2024-11-21 23:43:27 +01:00
feat(ui): Show number of failing checks per group (#493)
* feat: added number of failing checks * updated design --------- Co-authored-by: TwiN <twin@linux.com>
This commit is contained in:
parent
5eebe6d9cc
commit
36207490b2
@ -7,12 +7,10 @@
|
|||||||
{{ collapsed ? '▼' : '▲' }}
|
{{ collapsed ? '▼' : '▲' }}
|
||||||
</span>
|
</span>
|
||||||
{{ name }}
|
{{ name }}
|
||||||
<span v-if="healthy" class="float-right text-green-600 w-7 hover:scale-110" title="Operational">
|
<span v-if="unhealthyCount" class="rounded-xl bg-red-600 text-white px-2 font-bold leading-6 float-right h-6 text-center hover:scale-110 text-sm" title="Partial Outage">{{unhealthyCount}}</span>
|
||||||
|
<span v-if="unhealthyCount === 0" class="float-right text-green-600 w-7 hover:scale-110" title="Operational">
|
||||||
<CheckCircleIcon />
|
<CheckCircleIcon />
|
||||||
</span>
|
</span>
|
||||||
<span v-else class="float-right text-yellow-500 text-sm w-7 hover:scale-110" title="Partial Outage">
|
|
||||||
<ExclamationCircleIcon />
|
|
||||||
</span>
|
|
||||||
</h5>
|
</h5>
|
||||||
</div>
|
</div>
|
||||||
</slot>
|
</slot>
|
||||||
@ -32,14 +30,13 @@
|
|||||||
|
|
||||||
<script>
|
<script>
|
||||||
import Endpoint from './Endpoint.vue';
|
import Endpoint from './Endpoint.vue';
|
||||||
import { CheckCircleIcon, ExclamationCircleIcon } from '@heroicons/vue/20/solid'
|
import { CheckCircleIcon } from '@heroicons/vue/20/solid'
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'EndpointGroup',
|
name: 'EndpointGroup',
|
||||||
components: {
|
components: {
|
||||||
Endpoint,
|
Endpoint,
|
||||||
CheckCircleIcon,
|
CheckCircleIcon
|
||||||
ExclamationCircleIcon
|
|
||||||
},
|
},
|
||||||
props: {
|
props: {
|
||||||
name: String,
|
name: String,
|
||||||
@ -49,22 +46,17 @@ export default {
|
|||||||
emits: ['showTooltip', 'toggleShowAverageResponseTime'],
|
emits: ['showTooltip', 'toggleShowAverageResponseTime'],
|
||||||
methods: {
|
methods: {
|
||||||
healthCheck() {
|
healthCheck() {
|
||||||
|
let unhealthyCount = 0
|
||||||
if (this.endpoints) {
|
if (this.endpoints) {
|
||||||
for (let i in this.endpoints) {
|
for (let i in this.endpoints) {
|
||||||
if (this.endpoints[i].results && this.endpoints[i].results.length > 0) {
|
if (this.endpoints[i].results && this.endpoints[i].results.length > 0) {
|
||||||
if (!this.endpoints[i].results[this.endpoints[i].results.length-1].success) {
|
if (!this.endpoints[i].results[this.endpoints[i].results.length-1].success) {
|
||||||
if (this.healthy) {
|
unhealthyCount++
|
||||||
this.healthy = false;
|
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Set the endpoint group to healthy (only if it's currently unhealthy)
|
this.unhealthyCount = unhealthyCount;
|
||||||
if (!this.healthy) {
|
|
||||||
this.healthy = true;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
toggleGroup() {
|
toggleGroup() {
|
||||||
this.collapsed = !this.collapsed;
|
this.collapsed = !this.collapsed;
|
||||||
@ -87,7 +79,7 @@ export default {
|
|||||||
},
|
},
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
healthy: true,
|
unhealthyCount: 0,
|
||||||
collapsed: sessionStorage.getItem(`gatus:endpoint-group:${this.name}:collapsed`) === "true"
|
collapsed: sessionStorage.getItem(`gatus:endpoint-group:${this.name}:collapsed`) === "true"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user