Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
hunterlong committed Sep 18, 2020
1 parent 1eb0b85 commit b7008f8
Show file tree
Hide file tree
Showing 4 changed files with 33 additions and 36 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
# 0.90.69 (09-18-2020)
- Fixed issue with service view not loading. #808 #811 #800

# 0.90.68 (09-17-2020)
- Added DB_DSN env for mysql, postgres or sqlite DSN database connection string
- Added READ_ONLY env for a read only connection to the database
Expand Down
60 changes: 27 additions & 33 deletions frontend/src/pages/Service.vue
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
<template>
<div class="container col-md-7 col-sm-12 mt-md-5">

<div v-if="!ready" class="row mt-5">
<div class="col-12 text-center">
<font-awesome-icon icon="circle-notch" size="3x" spin/>
Expand All @@ -10,7 +9,7 @@
</div>
</div>

<div v-if="ready" class="col-12 mb-4">
<div v-if="ready && service" class="col-12 mb-4">
<span class="mt-3 mb-3 text-white d-md-none btn d-block d-md-none text-uppercase" :class="{'bg-success': service.online, 'bg-danger': !service.online}">
{{service.online ? $t('online') : $t('offline')}}
</span>
Expand All @@ -31,11 +30,11 @@
<div class="card-body pb-4">
<div class="row">
<div class="col">
<flatPickr :disabled="!loaded" @on-change="reload" v-model="start_time" :config="{ wrap: true, allowInput: true, enableTime: true, dateFormat: 'Z', altInput: true, altFormat: 'Y-m-d h:i K', maxDate: new Date() }" type="text" class="form-control text-left" required />
<flatPickr :disabled="!loaded" @on-change="reload" v-model="start_time" :config="{ wrap: true, allowInput: true, enableTime: true, dateFormat: 'Z', altInput: true, altFormat: 'Y-m-d h:i K', maxDate: this.endOf('today') }" type="text" class="form-control text-left" required />
<small class="d-block">From {{this.format(new Date(start_time))}}</small>
</div>
<div class="col">
<flatPickr :disabled="!loaded" @on-change="reload" v-model="end_time" :config="{ wrap: true, allowInput: true, enableTime: true, dateFormat: 'Z', altInput: true, altFormat: 'Y-m-d h:i K', maxDate: new Date() }" type="text" class="form-control text-left" required />
<flatPickr :disabled="!loaded" @on-change="reload" v-model="end_time" :config="{ wrap: true, allowInput: true, enableTime: true, dateFormat: 'Z', altInput: true, altFormat: 'Y-m-d h:i K', maxDate: this.endOf('today') }" type="text" class="form-control text-left" required />
<small class="d-block">To {{this.format(new Date(end_time))}}</small>
</div>
<div class="col">
Expand All @@ -55,6 +54,7 @@
<small class="d-block d-md-none d-block">Increment Timeframe</small>
</div>
</div>

</div>
</div>

Expand Down Expand Up @@ -99,10 +99,11 @@
const ServiceHeatmap = () => import(/* webpackChunkName: "service" */ '@/components/Service/ServiceHeatmap')
const ServiceTopStats = () => import(/* webpackChunkName: "service" */ '@/components/Service/ServiceTopStats')
const AdvancedChart = () => import(/* webpackChunkName: "service" */ '@/components/Service/AdvancedChart')
const FailuresBarChart = () => import(/* webpackChunkName: "service" */ '@/components/Service/FailuresBarChart')
import flatPickr from 'vue-flatpickr-component';
import 'flatpickr/dist/flatpickr.css';
import FailuresBarChart from "@/components/Service/FailuresBarChart";
const timeoptions = { weekday: 'long', year: 'numeric', month: 'long', day: 'numeric', hour: 'numeric', minute: 'numeric' };
const axisOptions = {
Expand Down Expand Up @@ -149,13 +150,12 @@ export default {
ready: false,
group: "15m",
data: null,
service: null,
uptime_data: null,
loaded: false,
messages: [],
failures: [],
start_time: this.nowSubtract(84600 * 30),
end_time: this.nowSubtract(0),
start_time: this.beginningOf('day', this.nowSubtract(259200 * 3)),
end_time: this.endOf('today'),
timedata: null,
load_timedata: false,
dailyRangeOpts: {
Expand Down Expand Up @@ -232,7 +232,7 @@ export default {
window.console.log(event)
},
updated: (chartContext, config) => {
window.console.log('updated')
window.console.log('updated chart')
},
beforeZoom: (chartContext, { xaxis }) => {
const start = (xaxis.min / 1000).toFixed(0)
Expand Down Expand Up @@ -368,6 +368,9 @@ export default {
core () {
return this.$store.getters.core
},
service() {
return this.$store.getters.serviceByAll(this.$route.params.id)
},
params () {
return {start: this.toUnix(new Date(this.start_time)), end: this.toUnix(new Date(this.end_time))}
},
Expand All @@ -388,41 +391,40 @@ export default {
this.fetchData()
},
mounted() {
this.fetchData()
},
methods: {
async fetchData () {
fetchData () {
if (!this.$route.params.id) {
this.ready = false
return
}
this.services = await Api.services()
await this.$store.commit("setServices", this.services)
this.service = await Api.service(this.$route.params.id)
await this.reload()
this.reload()
this.ready = true
},
async updated_chart(start, end) {
this.loaded = false
this.start_time = start
this.end_time = end
this.loaded = true
},
async reload() {
if (!this.ready || !this.service) {
return
}
await this.chartHits()
await this.chartFailures()
await this.fetchUptime()
},
async updated_chart(start, end) {
this.loaded = false
this.start_time = start
this.end_time = end
this.loaded = true
},
async fetchUptime(service) {
if (service) {
return
}
async fetchUptime() {
const uptime = await Api.service_uptime(this.service.id, this.params.start, this.params.end)
this.uptime_data = this.parse_uptime(uptime)
},
parse_uptime(timedata) {
if (!timedata.series) {
return []
}
const data = timedata.series.filter((g) => g.online) || []
const offData = timedata.series.filter((g) => !g.online) || []
let arr = [];
Expand Down Expand Up @@ -456,18 +458,10 @@ export default {
return this.isBetween(this.now(), message.start_on, message.start_on === message.end_on ? this.maxDate().toISOString() : message.end_on)
},
async chartHits(start=0, end=99999999999) {
if (!this.service) {
return
}
this.data = await Api.service_hits(this.service.id, this.params.start, this.params.end, this.group, false)
this.ready = true
},
async chartFailures(start=0, end=99999999999) {
if (!this.service) {
return
}
this.failures_data = await Api.service_failures_data(this.service.id, this.params.start, this.params.end, this.group, true)
this.ready = true
}
}
}
Expand Down
4 changes: 2 additions & 2 deletions frontend/src/store.js
Original file line number Diff line number Diff line change
Expand Up @@ -72,8 +72,8 @@ export default new Vuex.Store({
return state.checkins.filter(c => c.service_id === id)
},
serviceByAll: (state) => (element) => {
if (element % 1 === 0) {
return state.services.find(s => s.id === element)
if (!isNaN(parseFloat(element)) && isFinite(element)) {
return state.services.find(s => s.id === parseInt(element))
} else {
return state.services.find(s => s.permalink === element)
}
Expand Down
2 changes: 1 addition & 1 deletion version.txt
Original file line number Diff line number Diff line change
@@ -1 +1 @@
0.90.68
0.90.69

0 comments on commit b7008f8

Please sign in to comment.