diff --git a/app/Http/Controllers/ApiController.php b/app/Http/Controllers/ApiController.php index e29bdda..85a50c9 100644 --- a/app/Http/Controllers/ApiController.php +++ b/app/Http/Controllers/ApiController.php @@ -70,105 +70,74 @@ class ApiController extends Controller return response()->json($tasks); } - - public function getTaskGraph(Request $request, $id) { - $days = ($request->input('days', 15) - 1); - - // First, we get the first date of the stats - // In this case, one month ago - $date = $last_days = Carbon::now()->subDays($days); - - // Then we get all history for the past month - $results = TaskHistory::orderBy('created_at', 'asc') - ->where('created_at', '>', $last_days->toDateString()) - ->where('task_id', '=', $id) - ->selectRaw('date(created_at) as date, status') - ->get() - ; - - // Then we start building an array for the entire month - $stats = []; - do { - $stats[$date->toDateString()] = [ - 'up' => 0, - 'down' => 0 - ]; - $date = $date->addDay(); - } - while ($date->lt(Carbon::now())); - - // Finally we populate the data - if (! is_null($results)) { - foreach ($results as $r) { - if (empty($stats[$r->date])) { - $stats[$r->date] = [ - 'up' => 0, - 'down' => 0 - ]; - } - - if ($r->status == 1) { - ++$stats[$r->date]['up']; - } - else { - ++$stats[$r->date]['down']; - } - } - } - return response()->json($stats); - } - - public function getTaskDetails(Request $request, $id) { $days = ($request->input('days', 15) - 1); - $task = Task::with(['group', 'history']) + $task = Task::with(['group']) ->find($id) ; if (! is_null($task)) { - - $results = $task + // First, we get the first date of the stats + // In this case, one month ago + $date = $last_days = Carbon::now()->subDays($days); + // Then we get all history for the past month + $history = $task ->history() - ->orderBy('created_at', 'desc') - ->where('created_at', '>', \Carbon\Carbon::now()->subDay($days)->toDateString()) - ->selectRaw('date(created_at) as `date`, created_at, status, output') + ->orderBy('created_at', 'asc') + ->where('created_at', '>', $last_days->toDateString()) + ->selectRaw('date(created_at) as date, status') ->get() ; - if (! is_null($results)) { - $prev = null; - $history = $averages = []; + // Then we start building an array for the entire month + $stats = []; + do { + $stats[$date->toDateString()] = [ + 'up' => 0, + 'down' => 0 + ]; + $date = $date->addDay(); + } + while ($date->lt(Carbon::now())); - foreach ($results as $h) { - if ($h->status != $prev) { - array_push($history, $h); - } - $prev = $h->status; - - if (empty($averages[$h->date])) { - $averages[$h->date] = [ - 'sum' => 0, - 'count' => 0 + // Then we populate the stats data + if (! is_null($history)) { + foreach ($history as $r) { + if (empty($stats[$r->date])) { + $stats[$r->date] = [ + 'up' => 0, + 'down' => 0 ]; } - if ($h->status == 1) { - $averages[$h->date]['sum'] ++; + + if ($r->status == 1) { + ++$stats[$r->date]['up']; + } + else { + ++$stats[$r->date]['down']; } - $averages[$h->date]['count'] ++; } } - return response()->json(array_merge($task->toArray(), [ - $task, - 'id' => $task->id, - 'host' => $task->host, - 'status' => $task->status, - 'type' => $task->type, - 'history' => $history, - 'averages' => $averages, - 'group' => $task->group - ])); + // Then we populate the history data + if (! is_null($history)) { + $prev = null; + + foreach ($history as $k => $h) { + // We only take tasks when status has changed between them + if ($h->status == $prev) { + unset($history[$k]); + } + $prev = $h->status; + } + } + + return response()->json([ + 'task' => $task, + 'stats' => $stats, + 'history' => $history + ]); } } diff --git a/public/js/app.js b/public/js/app.js index f5e0184..74e069e 100644 --- a/public/js/app.js +++ b/public/js/app.js @@ -343,7 +343,7 @@ eval("\n\nvar bind = __webpack_require__(/*! ./helpers/bind */ \"./node_modules/ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; -eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _components_tasklist_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./components/tasklist.vue */ \"./resources/views/components/tasklist.vue\");\n/* harmony import */ var _components_quickview_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./components/quickview.vue */ \"./resources/views/components/quickview.vue\");\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({\n components: {\n QuickView: _components_quickview_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n TaskList: _components_tasklist_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n data: function data() {\n return {\n refreshed_time: null\n };\n },\n computed: {\n refreshedTime: function refreshedTime() {\n return this.refreshed_time != null ? this.moment(this.refreshed_time).format('HH:mm:ss') : 'never';\n }\n },\n methods: {\n getTasks: function getTasks() {\n var _this = this;\n\n this.$http.get('/api/getTasks').then(function (response) {\n return _this.$store.commit('setTasks', response.data);\n }).then(function () {\n _this.refreshed_time = _this.moment();\n })[\"catch\"](function (error) {\n return window.alert('Cannot get tasks');\n });\n this.refreshed_time = this.moment();\n }\n },\n beforeRouteLeave: function beforeRouteLeave(to, from, next) {\n clearTimeout(this.refresh);\n next();\n },\n mounted: function mounted() {\n var _this2 = this;\n\n this.getTasks();\n this.refresh = window.setInterval(function () {\n _this2.getTasks();\n }, 10000);\n }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvYmFiZWwtbG9hZGVyL2xpYi9pbmRleC5qcz8/Y2xvbmVkUnVsZVNldC01WzBdLnJ1bGVzWzBdLnVzZVswXSEuL25vZGVfbW9kdWxlcy92dWUtbG9hZGVyL2xpYi9pbmRleC5qcz8/dnVlLWxvYWRlci1vcHRpb25zIS4vcmVzb3VyY2VzL3ZpZXdzL2FwcC52dWU/dnVlJnR5cGU9c2NyaXB0Jmxhbmc9anMmLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7OztBQVdBO0FBQ0E7QUFFQTtBQUNBO0FBQ0EsZ0ZBREE7QUFFQTtBQUZBLEdBREE7QUFLQTtBQUNBO0FBQ0E7QUFEQTtBQUdBLEdBVEE7QUFVQTtBQUNBO0FBQ0E7QUFDQTtBQUhBLEdBVkE7QUFlQTtBQUNBO0FBQUE7O0FBQ0Esc0NBQ0EsSUFEQSxDQUNBO0FBQUE7QUFBQSxPQURBLEVBRUEsSUFGQSxDQUVBO0FBQ0E7QUFDQSxPQUpBLFdBS0E7QUFBQTtBQUFBLE9BTEE7QUFNQTtBQUNBO0FBVEEsR0FmQTtBQTBCQSxrQkExQkEsNEJBMEJBLEVBMUJBLEVBMEJBLElBMUJBLEVBMEJBLElBMUJBLEVBMEJBO0FBQ0E7QUFDQTtBQUNBLEdBN0JBO0FBOEJBO0FBQUE7O0FBQ0E7QUFDQTtBQUNBO0FBQ0EsS0FGQSxFQUVBLEtBRkE7QUFHQTtBQW5DQSIsInNvdXJjZXMiOlsid2VicGFjazovLy9yZXNvdXJjZXMvdmlld3MvYXBwLnZ1ZT9kNzRiIl0sInNvdXJjZXNDb250ZW50IjpbIjx0ZW1wbGF0ZT5cbiAgICA8ZGl2IGNsYXNzPVwiY29udGFpbmVyXCI+XG4gICAgICAgIDxoMT5Nb25pdG9MaXRlIERhc2hib2FyZDwvaDE+XG4gICAgICAgIDxwIGNsYXNzPVwicmVmcmVzaGVkLXRpbWVcIj5MYXN0IHJlZnJlc2g6IDxiciAvPjxzcGFuIGNsYXNzPVwiY2xvY2tcIj57eyByZWZyZXNoZWRUaW1lIH19PC9zcGFuPjwvcD5cbiAgICAgICAgPHF1aWNrLXZpZXc+PC9xdWljay12aWV3PlxuICAgICAgICA8dGFzay1saXN0PjwvdGFzay1saXN0PlxuICAgIDwvZGl2PlxuPC90ZW1wbGF0ZT5cblxuPHNjcmlwdD5cblxuICAgIGltcG9ydCBUYXNrTGlzdCBmcm9tICcuL2NvbXBvbmVudHMvdGFza2xpc3QudnVlJ1xuICAgIGltcG9ydCBRdWlja1ZpZXcgZnJvbSAnLi9jb21wb25lbnRzL3F1aWNrdmlldy52dWUnXG5cbiAgICBleHBvcnQgZGVmYXVsdHtcbiAgICAgICAgY29tcG9uZW50czoge1xuICAgICAgICAgICAgUXVpY2tWaWV3LFxuICAgICAgICAgICAgVGFza0xpc3RcbiAgICAgICAgfSxcbiAgICAgICAgZGF0YTogZnVuY3Rpb24oKSB7XG4gICAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgICAgIHJlZnJlc2hlZF90aW1lOiBudWxsXG4gICAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICAgIGNvbXB1dGVkOiB7XG4gICAgICAgICAgICByZWZyZXNoZWRUaW1lOiBmdW5jdGlvbigpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gdGhpcy5yZWZyZXNoZWRfdGltZSAhPSBudWxsID8gdGhpcy5tb21lbnQodGhpcy5yZWZyZXNoZWRfdGltZSkuZm9ybWF0KCdISDptbTpzcycpIDogJ25ldmVyJ1xuICAgICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICBtZXRob2RzOiB7XG4gICAgICAgICAgICBnZXRUYXNrczogZnVuY3Rpb24oKSB7XG4gICAgICAgICAgICAgICAgdGhpcy4kaHR0cC5nZXQoJy9hcGkvZ2V0VGFza3MnKVxuICAgICAgICAgICAgICAgIC50aGVuKHJlc3BvbnNlID0+IHRoaXMuJHN0b3JlLmNvbW1pdCgnc2V0VGFza3MnLCByZXNwb25zZS5kYXRhKSlcbiAgICAgICAgICAgICAgICAudGhlbigoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHRoaXMucmVmcmVzaGVkX3RpbWUgPSB0aGlzLm1vbWVudCgpO1xuICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgLmNhdGNoKGVycm9yID0+IHdpbmRvdy5hbGVydCgnQ2Fubm90IGdldCB0YXNrcycpKVxuICAgICAgICAgICAgICAgIHRoaXMucmVmcmVzaGVkX3RpbWUgPSB0aGlzLm1vbWVudCgpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICBiZWZvcmVSb3V0ZUxlYXZlKHRvLCBmcm9tLCBuZXh0KSB7XG4gICAgICAgICAgICBjbGVhclRpbWVvdXQodGhpcy5yZWZyZXNoKTtcbiAgICAgICAgICAgIG5leHQoKTtcbiAgICAgICAgfSxcbiAgICAgICAgbW91bnRlZDogZnVuY3Rpb24oKSB7XG4gICAgICAgICAgICB0aGlzLmdldFRhc2tzKClcbiAgICAgICAgICAgIHRoaXMucmVmcmVzaCA9IHdpbmRvdy5zZXRJbnRlcnZhbCgoKSA9PiB7XG4gICAgICAgICAgICAgICAgdGhpcy5nZXRUYXNrcygpO1xuICAgICAgICAgICAgfSwgMTAwMDApXG4gICAgICAgIH1cbiAgICB9XG48L3NjcmlwdD5cblxuPHN0eWxlIHNjb3BlZD5cblxuPC9zdHlsZT4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./node_modules/babel-loader/lib/index.js??clonedRuleSet-5[0].rules[0].use[0]!./node_modules/vue-loader/lib/index.js??vue-loader-options!./resources/views/app.vue?vue&type=script&lang=js&\n"); +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var _components_tasklist_vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./components/tasklist.vue */ \"./resources/views/components/tasklist.vue\");\n/* harmony import */ var _components_quickview_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./components/quickview.vue */ \"./resources/views/components/quickview.vue\");\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({\n components: {\n QuickView: _components_quickview_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"],\n TaskList: _components_tasklist_vue__WEBPACK_IMPORTED_MODULE_0__[\"default\"]\n },\n data: function data() {\n return {\n refreshed_time: null,\n refresh: null\n };\n },\n computed: {\n refreshedTime: function refreshedTime() {\n return this.refreshed_time != null ? this.moment(this.refreshed_time).format('HH:mm:ss') : 'never';\n }\n },\n methods: {\n getTasks: function getTasks() {\n var _this = this;\n\n this.$http.get('/api/getTasks').then(function (response) {\n return _this.$store.commit('setTasks', response.data);\n }).then(function () {\n _this.refreshed_time = _this.moment();\n })[\"catch\"](function (error) {\n return window.alert('Cannot get tasks');\n });\n this.refreshed_time = this.moment();\n }\n },\n beforeRouteLeave: function beforeRouteLeave(to, from, next) {\n clearTimeout(this.refresh);\n next();\n },\n mounted: function mounted() {\n var _this2 = this;\n\n this.getTasks();\n this.refresh = window.setInterval(function () {\n _this2.getTasks();\n }, 10000);\n }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9ub2RlX21vZHVsZXMvYmFiZWwtbG9hZGVyL2xpYi9pbmRleC5qcz8/Y2xvbmVkUnVsZVNldC01WzBdLnJ1bGVzWzBdLnVzZVswXSEuL25vZGVfbW9kdWxlcy92dWUtbG9hZGVyL2xpYi9pbmRleC5qcz8/dnVlLWxvYWRlci1vcHRpb25zIS4vcmVzb3VyY2VzL3ZpZXdzL2FwcC52dWU/dnVlJnR5cGU9c2NyaXB0Jmxhbmc9anMmLmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7OztBQVdBO0FBQ0E7QUFFQTtBQUNBO0FBQ0EsZ0ZBREE7QUFFQTtBQUZBLEdBREE7QUFLQTtBQUNBO0FBQ0EsMEJBREE7QUFFQTtBQUZBO0FBSUEsR0FWQTtBQVdBO0FBQ0E7QUFDQTtBQUNBO0FBSEEsR0FYQTtBQWdCQTtBQUNBO0FBQUE7O0FBQ0Esc0NBQ0EsSUFEQSxDQUNBO0FBQUE7QUFBQSxPQURBLEVBRUEsSUFGQSxDQUVBO0FBQ0E7QUFDQSxPQUpBLFdBS0E7QUFBQTtBQUFBLE9BTEE7QUFNQTtBQUNBO0FBVEEsR0FoQkE7QUEyQkEsa0JBM0JBLDRCQTJCQSxFQTNCQSxFQTJCQSxJQTNCQSxFQTJCQSxJQTNCQSxFQTJCQTtBQUNBO0FBQ0E7QUFDQSxHQTlCQTtBQStCQTtBQUFBOztBQUNBO0FBQ0E7QUFDQTtBQUNBLEtBRkEsRUFFQSxLQUZBO0FBR0E7QUFwQ0EiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly8vcmVzb3VyY2VzL3ZpZXdzL2FwcC52dWU/ZDc0YiJdLCJzb3VyY2VzQ29udGVudCI6WyI8dGVtcGxhdGU+XG4gICAgPGRpdiBjbGFzcz1cImNvbnRhaW5lclwiPlxuICAgICAgICA8aDE+TW9uaXRvTGl0ZSBEYXNoYm9hcmQ8L2gxPlxuICAgICAgICA8cCBjbGFzcz1cInJlZnJlc2hlZC10aW1lXCI+TGFzdCByZWZyZXNoOiA8YnIgLz48c3BhbiBjbGFzcz1cImNsb2NrXCI+e3sgcmVmcmVzaGVkVGltZSB9fTwvc3Bhbj48L3A+XG4gICAgICAgIDxxdWljay12aWV3PjwvcXVpY2stdmlldz5cbiAgICAgICAgPHRhc2stbGlzdD48L3Rhc2stbGlzdD5cbiAgICA8L2Rpdj5cbjwvdGVtcGxhdGU+XG5cbjxzY3JpcHQ+XG5cbiAgICBpbXBvcnQgVGFza0xpc3QgZnJvbSAnLi9jb21wb25lbnRzL3Rhc2tsaXN0LnZ1ZSdcbiAgICBpbXBvcnQgUXVpY2tWaWV3IGZyb20gJy4vY29tcG9uZW50cy9xdWlja3ZpZXcudnVlJ1xuXG4gICAgZXhwb3J0IGRlZmF1bHR7XG4gICAgICAgIGNvbXBvbmVudHM6IHtcbiAgICAgICAgICAgIFF1aWNrVmlldyxcbiAgICAgICAgICAgIFRhc2tMaXN0XG4gICAgICAgIH0sXG4gICAgICAgIGRhdGE6IGZ1bmN0aW9uKCkge1xuICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICByZWZyZXNoZWRfdGltZTogbnVsbCxcbiAgICAgICAgICAgICAgICByZWZyZXNoOiBudWxsXG4gICAgICAgICAgICB9XG4gICAgICAgIH0sXG4gICAgICAgIGNvbXB1dGVkOiB7XG4gICAgICAgICAgICByZWZyZXNoZWRUaW1lOiBmdW5jdGlvbigpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gdGhpcy5yZWZyZXNoZWRfdGltZSAhPSBudWxsID8gdGhpcy5tb21lbnQodGhpcy5yZWZyZXNoZWRfdGltZSkuZm9ybWF0KCdISDptbTpzcycpIDogJ25ldmVyJ1xuICAgICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICBtZXRob2RzOiB7XG4gICAgICAgICAgICBnZXRUYXNrczogZnVuY3Rpb24oKSB7XG4gICAgICAgICAgICAgICAgdGhpcy4kaHR0cC5nZXQoJy9hcGkvZ2V0VGFza3MnKVxuICAgICAgICAgICAgICAgIC50aGVuKHJlc3BvbnNlID0+IHRoaXMuJHN0b3JlLmNvbW1pdCgnc2V0VGFza3MnLCByZXNwb25zZS5kYXRhKSlcbiAgICAgICAgICAgICAgICAudGhlbigoKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgIHRoaXMucmVmcmVzaGVkX3RpbWUgPSB0aGlzLm1vbWVudCgpO1xuICAgICAgICAgICAgICAgIH0pXG4gICAgICAgICAgICAgICAgLmNhdGNoKGVycm9yID0+IHdpbmRvdy5hbGVydCgnQ2Fubm90IGdldCB0YXNrcycpKVxuICAgICAgICAgICAgICAgIHRoaXMucmVmcmVzaGVkX3RpbWUgPSB0aGlzLm1vbWVudCgpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICBiZWZvcmVSb3V0ZUxlYXZlKHRvLCBmcm9tLCBuZXh0KSB7XG4gICAgICAgICAgICBjbGVhclRpbWVvdXQodGhpcy5yZWZyZXNoKTtcbiAgICAgICAgICAgIG5leHQoKTtcbiAgICAgICAgfSxcbiAgICAgICAgbW91bnRlZDogZnVuY3Rpb24oKSB7XG4gICAgICAgICAgICB0aGlzLmdldFRhc2tzKClcbiAgICAgICAgICAgIHRoaXMucmVmcmVzaCA9IHdpbmRvdy5zZXRJbnRlcnZhbCgoKSA9PiB7XG4gICAgICAgICAgICAgICAgdGhpcy5nZXRUYXNrcygpO1xuICAgICAgICAgICAgfSwgMTAwMDApXG4gICAgICAgIH1cbiAgICB9XG48L3NjcmlwdD5cblxuPHN0eWxlIHNjb3BlZD5cblxuPC9zdHlsZT4iXSwibmFtZXMiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./node_modules/babel-loader/lib/index.js??clonedRuleSet-5[0].rules[0].use[0]!./node_modules/vue-loader/lib/index.js??vue-loader-options!./resources/views/app.vue?vue&type=script&lang=js&\n"); /***/ }), @@ -376,7 +376,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; -eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({\n data: function data() {\n return {\n task: null,\n chart: {\n render: false,\n days: 15\n },\n series: [{\n data: []\n }],\n noData: {\n text: 'Loading...'\n },\n chartOptions: {\n responsive: [{\n breakpoint: 480,\n options: {\n legend: {\n position: 'bottom',\n offsetX: -10,\n offsetY: 0\n }\n }\n }],\n xaxis: {\n categories: []\n },\n fill: {\n opacity: .9\n },\n legend: {\n position: 'right',\n offsetX: 0,\n offsetY: 50\n }\n }\n };\n },\n methods: {\n statusText: function statusText(status) {\n switch (status) {\n case 1:\n return 'up';\n break;\n\n case 0:\n return 'down';\n break;\n\n default:\n return 'unknown';\n }\n },\n refreshGraph: function refreshGraph() {\n var _this = this;\n\n this.$http.post('/api/getTaskGraph/' + this.task.id, {\n days: this.chart.days\n }).then(function (response) {\n var xaxis = [];\n var new_data_a = [];\n var new_data_b = [];\n console.log(response.data);\n\n for (var date in response.data) {\n xaxis.push(date);\n new_data_a.push(response.data[date]['up']);\n new_data_b.push(response.data[date]['down']);\n }\n\n _this.chartOptions = {\n xaxis: {\n categories: xaxis,\n labels: {\n show: true,\n rotate: -45,\n rotateAlways: true\n }\n },\n chart: {\n type: 'bar',\n height: 300,\n stacked: true,\n stackType: '100%'\n }\n };\n _this.series = [{\n name: 'UP',\n data: new_data_a,\n color: '#00955c'\n }, {\n name: 'DOWN',\n data: new_data_b,\n color: '#ef3232'\n }];\n _this.chart.render = true;\n });\n }\n },\n mounted: function mounted() {\n var _this$$route$params$i,\n _this2 = this;\n\n var task_id = (_this$$route$params$i = this.$route.params.id) !== null && _this$$route$params$i !== void 0 ? _this$$route$params$i : null;\n\n if (task_id != null) {\n this.$http.post('/api/getTask/' + task_id, {\n days: this.chart.days\n }).then(function (response) {\n return _this2.task = response.data;\n }).then(function () {\n _this2.refreshGraph();\n });\n }\n }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/babel-loader/lib/index.js??clonedRuleSet-5[0].rules[0].use[0]!./node_modules/vue-loader/lib/index.js??vue-loader-options!./resources/views/taskdetails.vue?vue&type=script&lang=js&.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqEA;AACA;AACA;AACA,gBADA;AAGA;AACA,qBADA;AAEA;AAFA,OAHA;AAQA;AACA;AADA,QARA;AAWA;AACA;AADA,OAXA;AAcA;AACA;AACA,yBADA;AAEA;AACA;AACA,gCADA;AAEA,0BAFA;AAGA;AAHA;AADA;AAFA,UADA;AAWA;AACA;AADA,SAXA;AAcA;AACA;AADA,SAdA;AAiBA;AACA,2BADA;AAEA,oBAFA;AAGA;AAHA;AAjBA;AAdA;AAsCA,GAxCA;AAyCA;AACA;AACA;AACA;AACA;AACA;;AACA;AACA;AACA;;AACA;AACA;AARA;AAUA,KAZA;AAaA;AAAA;;AACA;AACA;AADA,SAGA,IAHA,CAGA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,6BADA;AAEA;AACA,wBADA;AAEA,yBAFA;AAGA;AAHA;AAFA,WADA;AASA;AACA,uBADA;AAEA,uBAFA;AAGA,yBAHA;AAIA;AAJA;AATA;AAgBA;AACA,oBADA;AAEA,0BAFA;AAGA;AAHA,WAKA;AACA,sBADA;AAEA,0BAFA;AAGA;AAHA,SALA;AAWA;AACA,OA3CA;AA4CA;AA1DA,GAzCA;AAqGA;AAAA;AAAA;;AACA;;AAEA;AACA;AACA;AADA,SAGA,IAHA,CAGA;AAAA;AAAA,OAHA,EAIA,IAJA,CAIA;AACA;AACA,OANA;AAOA;AACA;AAjHA","sources":["webpack:///resources/views/taskdetails.vue?73a4"],"sourcesContent":["<template>\n\t<div>\n\t\t<div class=\"container\"\n\t\t\tv-if=\"task\"\n\t\t>\n\t\t\t<h1>\n\t\t\t\tTask #{{ task.id }}\n\t\t\t\t<!-- <p class=\"context-menu\"><img src=\"/img/menu.svg\" width=\"40\" /></p> -->\n\t\t\t</h1>\n\n\t\t\tShow:\n\t\t\t<select\n\t\t\t\tv-model=\"chart.days\"\n\t\t\t\t@change=\"refreshGraph\"\n\t\t\t>\n\t\t\t\t<option value=\"7\">7 days</option>\n\t\t\t\t<option value=\"15\">15 days</option>\n\t\t\t\t<option value=\"30\">30 days</option>\n\t\t\t</select>\n\t\t\t<div id=\"chart\" class=\"round\">\n\t\t\t\t<h3>Uptime: past {{ chart.days }} days</h3>\n\t\t\t\t<div class=\"block-content\">\n\t\t\t\t\t<apexchart class=\"graph\" v-if=\"chart.render\" type=\"bar\" height=\"350\" :options=\"chartOptions\" :series=\"series\"></apexchart>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t\t<div v-if=\"task.history.length > 0\" class=\"round\">\n\t\t\t\t<h3>Last {{ chart.days }} days history log</h3>\n\t\t\t\t<div class=\"block-content\">\n\t\t\t\t\t<p><i>Showing only records where status has changed</i></p>\n\t\t\t\t\t<table id=\"tasks_tbl\">\n\t\t\t\t\t\t<thead>\n\t\t\t\t\t\t\t<tr>\n\t\t\t\t\t\t\t\t<th width=\"20%\">Date</th>\n\t\t\t\t\t\t\t\t<th width=\"20%\">Time</th>\n\t\t\t\t\t\t\t\t<th width=\"*\">Output</th>\n\t\t\t\t\t\t\t\t<th width=\"10%\">Status</th>\n\t\t\t\t\t\t\t</tr>\n\t\t\t\t\t\t</thead>\n\t\t\t\t\t\t<tbody>\n\t\t\t\t\t\t\t<tr\n\t\t\t\t\t\t\t\tv-for=\"history in task.history\"\n\t\t\t\t\t\t\t\tv-bind:key=\"history.id\"\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<td>{{ moment(history.date).format('YYYY-MM-DD') }}</td>\n\t\t\t\t\t\t\t\t<td>{{ moment(history.created_at).format('HH:mm:ss') }}</td>\n\t\t\t\t\t\t\t\t<td>\n\t\t\t\t\t\t\t\t\t<span v-if=\"history.output\">\n\t\t\t\t\t\t\t\t\t\t{{ history.output }}\n\t\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t\t<span v-else>\n\t\t\t\t\t\t\t\t\t\t<i>No output</i>\n\t\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t\t<td :class=\"statusText(history.status)\">\n\t\t\t\t\t\t\t\t\t<img :src=\"'/img/'+statusText(history.status)+'.svg'\" width=\"16\" alt=\"Status\" />\n\t\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t</tr>\n\t\t\t\t\t\t</tbody>\n\t\t\t\t\t</table>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t\t<p v-else>No history to display here</p>\n\t\t</div>\n\t</div>\n</template>\n\n<script>\n\n    export default{\n\t\tdata: function() {\n\t\t\treturn {\n\t\t\t\ttask: null,\n\n\t\t\t\tchart: {\n\t\t\t\t\trender: false,\n\t\t\t\t\tdays: 15\n\t\t\t\t},\n\n\t\t\t\tseries: [{\n\t\t\t\t\tdata: []\n\t\t\t\t}],\n\t\t\t\tnoData: {\n\t\t\t\t\ttext: 'Loading...'\n\t\t\t\t},\n\t\t\t\tchartOptions: {\n\t\t\t\t\tresponsive: [{\n\t\t\t\t\t\tbreakpoint: 480,\n\t\t\t\t\t\toptions: {\n\t\t\t\t\t\t\tlegend: {\n\t\t\t\t\t\t\t\tposition: 'bottom',\n\t\t\t\t\t\t\t\toffsetX: -10,\n\t\t\t\t\t\t\t\toffsetY: 0\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}],\n\t\t\t\t\txaxis: {\n\t\t\t\t\t\tcategories: [],\n\t\t\t\t\t},\n\t\t\t\t\tfill: {\n\t\t\t\t\t\topacity: .9\n\t\t\t\t\t},\n\t\t\t\t\tlegend: {\n\t\t\t\t\t\tposition: 'right',\n\t\t\t\t\t\toffsetX: 0,\n\t\t\t\t\t\toffsetY: 50\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t}\n\t\t},\n\t\tmethods: {\n\t\t\tstatusText: function (status) {\n\t\t\t\tswitch (status) {\n\t\t\t\t\tcase 1:\n\t\t\t\t\t\treturn 'up';\n\t\t\t\t\tbreak;\n\t\t\t\t\tcase 0:\n\t\t\t\t\t\treturn 'down';\n\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\treturn 'unknown';\n\t\t\t\t}\n\t\t\t},\n\t\t\trefreshGraph: function() {\n\t\t\t\tthis.$http.post('/api/getTaskGraph/'+this.task.id, {\n\t\t\t\t\tdays: this.chart.days\n\t\t\t\t})\n\t\t\t\t.then(response => {\n\t\t\t\t\tlet xaxis = [];\n\t\t\t\t\tlet new_data_a = [];\n\t\t\t\t\tlet new_data_b = [];\n\t\t\t\t\tconsole.log(response.data)\n\n\t\t\t\t\tfor (let date in response.data) {\n\t\t\t\t\t\txaxis.push(date)\n\t\t\t\t\t\tnew_data_a.push(response.data[date]['up'])\n\t\t\t\t\t\tnew_data_b.push(response.data[date]['down'])\n\t\t\t\t\t}\n\n\t\t\t\t\tthis.chartOptions = {\n\t\t\t\t\t\txaxis: {\n\t\t\t\t\t\t\tcategories: xaxis,\n\t\t\t\t\t\t\tlabels: {\n\t\t\t\t\t\t\t\tshow: true,\n\t\t\t\t\t\t\t\trotate: -45,\n\t\t\t\t\t\t\t\trotateAlways: true,\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t},\n\t\t\t\t\t\tchart: {\n\t\t\t\t\t\t\ttype: 'bar',\n\t\t\t\t\t\t\theight: 300,\n\t\t\t\t\t\t\tstacked: true,\n\t\t\t\t\t\t\tstackType: '100%'\n\t\t\t\t\t\t},\n\t\t\t\t\t}\n\t\t\t\t\tthis.series = [{\n\t\t\t\t\t\tname: 'UP',\n\t\t\t\t\t\tdata: new_data_a,\n\t\t\t\t\t\tcolor: '#00955c'\n\t\t\t\t\t},\n\t\t\t\t\t{\n\t\t\t\t\t\tname: 'DOWN',\n\t\t\t\t\t\tdata: new_data_b,\n\t\t\t\t\t\tcolor: '#ef3232'\n\t\t\t\t\t}]\n\n\t\t\t\t\tthis.chart.render = true\n\t\t\t\t})\n\t\t\t}\n\t\t},\n\t\tmounted: function() {\n\t\t\tlet task_id = this.$route.params.id ?? null\n\n\t\t\tif (task_id != null) {\n\t\t\t\tthis.$http.post('/api/getTask/'+task_id, {\n\t\t\t\t\tdays: this.chart.days\n\t\t\t\t})\n\t\t\t\t.then(response => this.task = response.data)\n\t\t\t\t.then(() => {\n\t\t\t\t\tthis.refreshGraph()\n\t\t\t\t})\n\t\t\t}\n\t\t}\n    }\n</script>\n\n<style scoped>\n\n</style>\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/babel-loader/lib/index.js??clonedRuleSet-5[0].rules[0].use[0]!./node_modules/vue-loader/lib/index.js??vue-loader-options!./resources/views/taskdetails.vue?vue&type=script&lang=js&\n"); +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ({\n data: function data() {\n return {\n task: {\n id: null\n },\n history: null,\n refresh: null,\n chart: {\n render: false,\n days: 15\n },\n series: [{\n data: []\n }],\n noData: {\n text: 'Loading...'\n },\n chartOptions: {\n responsive: [{\n breakpoint: 480,\n options: {\n legend: {\n position: 'bottom',\n offsetX: -10,\n offsetY: 0\n }\n }\n }],\n xaxis: {\n categories: []\n },\n fill: {\n opacity: .9\n },\n legend: {\n position: 'right',\n offsetX: 0,\n offsetY: 50\n }\n }\n };\n },\n methods: {\n statusText: function statusText(status) {\n switch (status) {\n case 1:\n return 'up';\n break;\n\n case 0:\n return 'down';\n break;\n\n default:\n return 'unknown';\n }\n },\n refreshTask: function refreshTask() {\n var _this = this;\n\n this.$http.post('/api/getTask/' + this.task.id, {\n days: this.chart.days\n }).then(function (response) {\n _this.task = response.data.task;\n _this.history = response.data.history;\n\n _this.refreshGraph(response.data.stats);\n });\n },\n refreshGraph: function refreshGraph(stats) {\n var xaxis = [];\n var new_data_a = [];\n var new_data_b = [];\n\n for (var date in stats) {\n xaxis.push(date);\n new_data_a.push(stats[date]['up']);\n new_data_b.push(stats[date]['down']);\n }\n\n this.chartOptions = {\n xaxis: {\n categories: xaxis,\n labels: {\n show: true,\n rotate: -45,\n rotateAlways: true\n }\n },\n chart: {\n type: 'bar',\n height: 300,\n stacked: true,\n stackType: '100%'\n }\n };\n this.series = [{\n name: 'UP',\n data: new_data_a,\n color: '#00955c'\n }, {\n name: 'DOWN',\n data: new_data_b,\n color: '#ef3232'\n }];\n this.chart.render = true;\n }\n },\n mounted: function mounted() {\n var _this$$route$params$i;\n\n this.task.id = (_this$$route$params$i = this.$route.params.id) !== null && _this$$route$params$i !== void 0 ? _this$$route$params$i : null;\n\n if (this.task.id != null) {\n this.refreshTask();\n }\n },\n beforeRouteLeave: function beforeRouteLeave(to, from, next) {\n clearTimeout(this.refresh);\n next();\n }\n});//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/babel-loader/lib/index.js??clonedRuleSet-5[0].rules[0].use[0]!./node_modules/vue-loader/lib/index.js??vue-loader-options!./resources/views/taskdetails.vue?vue&type=script&lang=js&.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqEA;AACA;AACA;AACA;AACA;AADA,OADA;AAIA,mBAJA;AAKA,mBALA;AAOA;AACA,qBADA;AAEA;AAFA,OAPA;AAYA;AACA;AADA,QAZA;AAeA;AACA;AADA,OAfA;AAkBA;AACA;AACA,yBADA;AAEA;AACA;AACA,gCADA;AAEA,0BAFA;AAGA;AAHA;AADA;AAFA,UADA;AAWA;AACA;AADA,SAXA;AAcA;AACA;AADA,SAdA;AAiBA;AACA,2BADA;AAEA,oBAFA;AAGA;AAHA;AAjBA;AAlBA;AA0CA,GA5CA;AA6CA;AACA;AACA;AACA;AACA;AACA;;AACA;AACA;AACA;;AACA;AACA;AARA;AAUA,KAZA;AAaA;AAAA;;AACA;AACA;AADA,SAGA,IAHA,CAGA;AACA;AACA;;AACA;AACA,OAPA;AAQA,KAtBA;AAuBA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,2BADA;AAEA;AACA,sBADA;AAEA,uBAFA;AAGA;AAHA;AAFA,SADA;AASA;AACA,qBADA;AAEA,qBAFA;AAGA,uBAHA;AAIA;AAJA;AATA;AAgBA;AACA,kBADA;AAEA,wBAFA;AAGA;AAHA,SAKA;AACA,oBADA;AAEA,wBAFA;AAGA;AAHA,OALA;AAWA;AACA;AA9DA,GA7CA;AA6GA;AAAA;;AACA;;AAEA;AACA;AACA;AACA,GAnHA;AAoHA,kBApHA,4BAoHA,EApHA,EAoHA,IApHA,EAoHA,IApHA,EAoHA;AACA;AACA;AACA;AAvHA","sources":["webpack:///resources/views/taskdetails.vue?73a4"],"sourcesContent":["<template>\n\t<div>\n\t\t<div class=\"container\"\n\t\t\tv-if=\"task.id != null\"\n\t\t>\n\t\t\t<h1>\n\t\t\t\tTask #{{ task.id }}\n\t\t\t\t<!-- <p class=\"context-menu\"><img src=\"/img/menu.svg\" width=\"40\" /></p> -->\n\t\t\t</h1>\n\n\t\t\tShow:\n\t\t\t<select\n\t\t\t\tv-model=\"chart.days\"\n\t\t\t\t@change=\"refreshTask\"\n\t\t\t>\n\t\t\t\t<option value=\"7\">7 days</option>\n\t\t\t\t<option value=\"15\">15 days</option>\n\t\t\t\t<option value=\"30\">30 days</option>\n\t\t\t</select>\n\t\t\t<div id=\"chart\" class=\"round\">\n\t\t\t\t<h3>Uptime: past {{ chart.days }} days</h3>\n\t\t\t\t<div class=\"block-content\">\n\t\t\t\t\t<apexchart class=\"graph\" v-if=\"chart.render\" type=\"bar\" height=\"350\" :options=\"chartOptions\" :series=\"series\"></apexchart>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t\t<div class=\"round\">\n\t\t\t\t<h3>Last {{ chart.days }} days history log</h3>\n\t\t\t\t<div class=\"block-content\" v-if=\"history\">\n\t\t\t\t\t<p><i>Showing only records where status has changed</i></p>\n\t\t\t\t\t<table id=\"tasks_tbl\">\n\t\t\t\t\t\t<thead>\n\t\t\t\t\t\t\t<tr>\n\t\t\t\t\t\t\t\t<th width=\"20%\">Date</th>\n\t\t\t\t\t\t\t\t<th width=\"20%\">Time</th>\n\t\t\t\t\t\t\t\t<th width=\"*\">Output</th>\n\t\t\t\t\t\t\t\t<th width=\"10%\">Status</th>\n\t\t\t\t\t\t\t</tr>\n\t\t\t\t\t\t</thead>\n\t\t\t\t\t\t<tbody>\n\t\t\t\t\t\t\t<tr\n\t\t\t\t\t\t\t\tv-for=\"h in history\"\n\t\t\t\t\t\t\t\tv-bind:key=\"history.id\"\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<td>{{ moment(h.created_at).format('YYYY-MM-DD') }}</td>\n\t\t\t\t\t\t\t\t<td>{{ moment(h.created_at).format('HH:mm:ss') }}</td>\n\t\t\t\t\t\t\t\t<td>\n\t\t\t\t\t\t\t\t\t<span v-if=\"h.output\">\n\t\t\t\t\t\t\t\t\t\t{{ h.output }}\n\t\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t\t<span v-else>\n\t\t\t\t\t\t\t\t\t\t<i>No output</i>\n\t\t\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t\t<td :class=\"statusText(h.status)\">\n\t\t\t\t\t\t\t\t\t<img :src=\"'/img/'+statusText(h.status)+'.svg'\" width=\"16\" alt=\"Status\" />\n\t\t\t\t\t\t\t\t</td>\n\t\t\t\t\t\t\t</tr>\n\t\t\t\t\t\t</tbody>\n\t\t\t\t\t</table>\n\t\t\t\t</div>\n\t\t\t\t<p v-else><center>No history to display here</center></p>\n\t\t\t</div>\n\t\t</div>\n\t</div>\n</template>\n\n<script>\n\n    export default{\n\t\tdata: function() {\n\t\t\treturn {\n\t\t\t\ttask: {\n\t\t\t\t\tid: null\n\t\t\t\t},\n\t\t\t\thistory: null,\n\t\t\t\trefresh: null,\n\n\t\t\t\tchart: {\n\t\t\t\t\trender: false,\n\t\t\t\t\tdays: 15\n\t\t\t\t},\n\n\t\t\t\tseries: [{\n\t\t\t\t\tdata: []\n\t\t\t\t}],\n\t\t\t\tnoData: {\n\t\t\t\t\ttext: 'Loading...'\n\t\t\t\t},\n\t\t\t\tchartOptions: {\n\t\t\t\t\tresponsive: [{\n\t\t\t\t\t\tbreakpoint: 480,\n\t\t\t\t\t\toptions: {\n\t\t\t\t\t\t\tlegend: {\n\t\t\t\t\t\t\t\tposition: 'bottom',\n\t\t\t\t\t\t\t\toffsetX: -10,\n\t\t\t\t\t\t\t\toffsetY: 0\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}],\n\t\t\t\t\txaxis: {\n\t\t\t\t\t\tcategories: [],\n\t\t\t\t\t},\n\t\t\t\t\tfill: {\n\t\t\t\t\t\topacity: .9\n\t\t\t\t\t},\n\t\t\t\t\tlegend: {\n\t\t\t\t\t\tposition: 'right',\n\t\t\t\t\t\toffsetX: 0,\n\t\t\t\t\t\toffsetY: 50\n\t\t\t\t\t},\n\t\t\t\t},\n\t\t\t}\n\t\t},\n\t\tmethods: {\n\t\t\tstatusText: function (status) {\n\t\t\t\tswitch (status) {\n\t\t\t\t\tcase 1:\n\t\t\t\t\t\treturn 'up';\n\t\t\t\t\tbreak;\n\t\t\t\t\tcase 0:\n\t\t\t\t\t\treturn 'down';\n\t\t\t\t\tbreak;\n\t\t\t\t\tdefault:\n\t\t\t\t\t\treturn 'unknown';\n\t\t\t\t}\n\t\t\t},\n\t\t\trefreshTask: function() {\n\t\t\t\tthis.$http.post('/api/getTask/'+this.task.id, {\n\t\t\t\t\tdays: this.chart.days\n\t\t\t\t})\n\t\t\t\t.then(response => {\n\t\t\t\t\tthis.task = response.data.task\n\t\t\t\t\tthis.history = response.data.history\n\t\t\t\t\tthis.refreshGraph(response.data.stats)\n\t\t\t\t})\n\t\t\t},\n\t\t\trefreshGraph: function(stats) {\n\t\t\t\tlet xaxis = [];\n\t\t\t\tlet new_data_a = [];\n\t\t\t\tlet new_data_b = [];\n\n\t\t\t\tfor (let date in stats) {\n\t\t\t\t\txaxis.push(date)\n\t\t\t\t\tnew_data_a.push(stats[date]['up'])\n\t\t\t\t\tnew_data_b.push(stats[date]['down'])\n\t\t\t\t}\n\n\t\t\t\tthis.chartOptions = {\n\t\t\t\t\txaxis: {\n\t\t\t\t\t\tcategories: xaxis,\n\t\t\t\t\t\tlabels: {\n\t\t\t\t\t\t\tshow: true,\n\t\t\t\t\t\t\trotate: -45,\n\t\t\t\t\t\t\trotateAlways: true,\n\t\t\t\t\t\t}\n\t\t\t\t\t},\n\t\t\t\t\tchart: {\n\t\t\t\t\t\ttype: 'bar',\n\t\t\t\t\t\theight: 300,\n\t\t\t\t\t\tstacked: true,\n\t\t\t\t\t\tstackType: '100%'\n\t\t\t\t\t},\n\t\t\t\t}\n\t\t\t\tthis.series = [{\n\t\t\t\t\tname: 'UP',\n\t\t\t\t\tdata: new_data_a,\n\t\t\t\t\tcolor: '#00955c'\n\t\t\t\t},\n\t\t\t\t{\n\t\t\t\t\tname: 'DOWN',\n\t\t\t\t\tdata: new_data_b,\n\t\t\t\t\tcolor: '#ef3232'\n\t\t\t\t}]\n\n\t\t\t\tthis.chart.render = true\n\t\t\t},\n\t\t},\n\t\tmounted: function() {\n\t\t\tthis.task.id = this.$route.params.id ?? null\n\n\t\t\tif (this.task.id != null) {\n\t\t\t\tthis.refreshTask()\n\t\t\t}\n\t\t},\n\t\tbeforeRouteLeave(to, from, next) {\n\t\t\tclearTimeout(this.refresh);\n\t\t\tnext();\n\t\t},\n    }\n</script>\n\n<style scoped>\n\n</style>\n"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/babel-loader/lib/index.js??clonedRuleSet-5[0].rules[0].use[0]!./node_modules/vue-loader/lib/index.js??vue-loader-options!./resources/views/taskdetails.vue?vue&type=script&lang=js&\n"); /***/ }), @@ -2279,7 +2279,7 @@ eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpac /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { "use strict"; -eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"render\": () => (/* binding */ render),\n/* harmony export */ \"staticRenderFns\": () => (/* binding */ staticRenderFns)\n/* harmony export */ });\nvar render = function () {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"div\", [\n _vm.task\n ? _c(\"div\", { staticClass: \"container\" }, [\n _c(\"h1\", [\n _vm._v(\"\\n\\t\\t\\tTask #\" + _vm._s(_vm.task.id) + \"\\n\\t\\t\\t\"),\n ]),\n _vm._v(\"\\n\\n\\t\\tShow:\\n\\t\\t\"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.chart.days,\n expression: \"chart.days\",\n },\n ],\n on: {\n change: [\n function ($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function (o) {\n return o.selected\n })\n .map(function (o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.$set(\n _vm.chart,\n \"days\",\n $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n )\n },\n _vm.refreshGraph,\n ],\n },\n },\n [\n _c(\"option\", { attrs: { value: \"7\" } }, [_vm._v(\"7 days\")]),\n _vm._v(\" \"),\n _c(\"option\", { attrs: { value: \"15\" } }, [_vm._v(\"15 days\")]),\n _vm._v(\" \"),\n _c(\"option\", { attrs: { value: \"30\" } }, [_vm._v(\"30 days\")]),\n ]\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"round\", attrs: { id: \"chart\" } }, [\n _c(\"h3\", [\n _vm._v(\"Uptime: past \" + _vm._s(_vm.chart.days) + \" days\"),\n ]),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"block-content\" },\n [\n _vm.chart.render\n ? _c(\"apexchart\", {\n staticClass: \"graph\",\n attrs: {\n type: \"bar\",\n height: \"350\",\n options: _vm.chartOptions,\n series: _vm.series,\n },\n })\n : _vm._e(),\n ],\n 1\n ),\n ]),\n _vm._v(\" \"),\n _vm.task.history.length > 0\n ? _c(\"div\", { staticClass: \"round\" }, [\n _c(\"h3\", [\n _vm._v(\n \"Last \" + _vm._s(_vm.chart.days) + \" days history log\"\n ),\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"block-content\" }, [\n _vm._m(0),\n _vm._v(\" \"),\n _c(\"table\", { attrs: { id: \"tasks_tbl\" } }, [\n _vm._m(1),\n _vm._v(\" \"),\n _c(\n \"tbody\",\n _vm._l(_vm.task.history, function (history) {\n return _c(\"tr\", { key: history.id }, [\n _c(\"td\", [\n _vm._v(\n _vm._s(\n _vm.moment(history.date).format(\"YYYY-MM-DD\")\n )\n ),\n ]),\n _vm._v(\" \"),\n _c(\"td\", [\n _vm._v(\n _vm._s(\n _vm\n .moment(history.created_at)\n .format(\"HH:mm:ss\")\n )\n ),\n ]),\n _vm._v(\" \"),\n _c(\"td\", [\n history.output\n ? _c(\"span\", [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\\t\" +\n _vm._s(history.output) +\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\"\n ),\n ])\n : _c(\"span\", [_c(\"i\", [_vm._v(\"No output\")])]),\n ]),\n _vm._v(\" \"),\n _c(\"td\", { class: _vm.statusText(history.status) }, [\n _c(\"img\", {\n attrs: {\n src:\n \"/img/\" +\n _vm.statusText(history.status) +\n \".svg\",\n width: \"16\",\n alt: \"Status\",\n },\n }),\n ]),\n ])\n }),\n 0\n ),\n ]),\n ]),\n ])\n : _c(\"p\", [_vm._v(\"No history to display here\")]),\n ])\n : _vm._e(),\n ])\n}\nvar staticRenderFns = [\n function () {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"p\", [\n _c(\"i\", [_vm._v(\"Showing only records where status has changed\")]),\n ])\n },\n function () {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"thead\", [\n _c(\"tr\", [\n _c(\"th\", { attrs: { width: \"20%\" } }, [_vm._v(\"Date\")]),\n _vm._v(\" \"),\n _c(\"th\", { attrs: { width: \"20%\" } }, [_vm._v(\"Time\")]),\n _vm._v(\" \"),\n _c(\"th\", { attrs: { width: \"*\" } }, [_vm._v(\"Output\")]),\n _vm._v(\" \"),\n _c(\"th\", { attrs: { width: \"10%\" } }, [_vm._v(\"Status\")]),\n ]),\n ])\n },\n]\nrender._withStripped = true\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib/index.js??vue-loader-options!./resources/views/taskdetails.vue?vue&type=template&id=a378bf18&scoped=true&.js","mappings":";;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,0BAA0B;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA;AACA;AACA,mBAAmB;AACnB;AACA;AACA,eAAe;AACf,aAAa;AACb;AACA,6BAA6B,SAAS,cAAc;AACpD;AACA,6BAA6B,SAAS,eAAe;AACrD;AACA,6BAA6B,SAAS,eAAe;AACrD;AACA;AACA;AACA,sBAAsB,+BAA+B,eAAe;AACpE;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,8BAA8B;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,sBAAsB;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,8BAA8B;AAC1D;AACA;AACA,gCAAgC,SAAS,mBAAmB;AAC5D;AACA;AACA;AACA;AACA;AACA,0CAA0C,iBAAiB;AAC3D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC,uCAAuC;AAC5E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B;AAC/B,6BAA6B;AAC7B;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,SAAS,gBAAgB;AAC5C;AACA,mBAAmB,SAAS,gBAAgB;AAC5C;AACA,mBAAmB,SAAS,cAAc;AAC1C;AACA,mBAAmB,SAAS,gBAAgB;AAC5C;AACA;AACA,GAAG;AACH;AACA","sources":["webpack:///./resources/views/taskdetails.vue?6569"],"sourcesContent":["var render = function () {\n  var _vm = this\n  var _h = _vm.$createElement\n  var _c = _vm._self._c || _h\n  return _c(\"div\", [\n    _vm.task\n      ? _c(\"div\", { staticClass: \"container\" }, [\n          _c(\"h1\", [\n            _vm._v(\"\\n\\t\\t\\tTask #\" + _vm._s(_vm.task.id) + \"\\n\\t\\t\\t\"),\n          ]),\n          _vm._v(\"\\n\\n\\t\\tShow:\\n\\t\\t\"),\n          _c(\n            \"select\",\n            {\n              directives: [\n                {\n                  name: \"model\",\n                  rawName: \"v-model\",\n                  value: _vm.chart.days,\n                  expression: \"chart.days\",\n                },\n              ],\n              on: {\n                change: [\n                  function ($event) {\n                    var $$selectedVal = Array.prototype.filter\n                      .call($event.target.options, function (o) {\n                        return o.selected\n                      })\n                      .map(function (o) {\n                        var val = \"_value\" in o ? o._value : o.value\n                        return val\n                      })\n                    _vm.$set(\n                      _vm.chart,\n                      \"days\",\n                      $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n                    )\n                  },\n                  _vm.refreshGraph,\n                ],\n              },\n            },\n            [\n              _c(\"option\", { attrs: { value: \"7\" } }, [_vm._v(\"7 days\")]),\n              _vm._v(\" \"),\n              _c(\"option\", { attrs: { value: \"15\" } }, [_vm._v(\"15 days\")]),\n              _vm._v(\" \"),\n              _c(\"option\", { attrs: { value: \"30\" } }, [_vm._v(\"30 days\")]),\n            ]\n          ),\n          _vm._v(\" \"),\n          _c(\"div\", { staticClass: \"round\", attrs: { id: \"chart\" } }, [\n            _c(\"h3\", [\n              _vm._v(\"Uptime: past \" + _vm._s(_vm.chart.days) + \" days\"),\n            ]),\n            _vm._v(\" \"),\n            _c(\n              \"div\",\n              { staticClass: \"block-content\" },\n              [\n                _vm.chart.render\n                  ? _c(\"apexchart\", {\n                      staticClass: \"graph\",\n                      attrs: {\n                        type: \"bar\",\n                        height: \"350\",\n                        options: _vm.chartOptions,\n                        series: _vm.series,\n                      },\n                    })\n                  : _vm._e(),\n              ],\n              1\n            ),\n          ]),\n          _vm._v(\" \"),\n          _vm.task.history.length > 0\n            ? _c(\"div\", { staticClass: \"round\" }, [\n                _c(\"h3\", [\n                  _vm._v(\n                    \"Last \" + _vm._s(_vm.chart.days) + \" days history log\"\n                  ),\n                ]),\n                _vm._v(\" \"),\n                _c(\"div\", { staticClass: \"block-content\" }, [\n                  _vm._m(0),\n                  _vm._v(\" \"),\n                  _c(\"table\", { attrs: { id: \"tasks_tbl\" } }, [\n                    _vm._m(1),\n                    _vm._v(\" \"),\n                    _c(\n                      \"tbody\",\n                      _vm._l(_vm.task.history, function (history) {\n                        return _c(\"tr\", { key: history.id }, [\n                          _c(\"td\", [\n                            _vm._v(\n                              _vm._s(\n                                _vm.moment(history.date).format(\"YYYY-MM-DD\")\n                              )\n                            ),\n                          ]),\n                          _vm._v(\" \"),\n                          _c(\"td\", [\n                            _vm._v(\n                              _vm._s(\n                                _vm\n                                  .moment(history.created_at)\n                                  .format(\"HH:mm:ss\")\n                              )\n                            ),\n                          ]),\n                          _vm._v(\" \"),\n                          _c(\"td\", [\n                            history.output\n                              ? _c(\"span\", [\n                                  _vm._v(\n                                    \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\\t\" +\n                                      _vm._s(history.output) +\n                                      \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\"\n                                  ),\n                                ])\n                              : _c(\"span\", [_c(\"i\", [_vm._v(\"No output\")])]),\n                          ]),\n                          _vm._v(\" \"),\n                          _c(\"td\", { class: _vm.statusText(history.status) }, [\n                            _c(\"img\", {\n                              attrs: {\n                                src:\n                                  \"/img/\" +\n                                  _vm.statusText(history.status) +\n                                  \".svg\",\n                                width: \"16\",\n                                alt: \"Status\",\n                              },\n                            }),\n                          ]),\n                        ])\n                      }),\n                      0\n                    ),\n                  ]),\n                ]),\n              ])\n            : _c(\"p\", [_vm._v(\"No history to display here\")]),\n        ])\n      : _vm._e(),\n  ])\n}\nvar staticRenderFns = [\n  function () {\n    var _vm = this\n    var _h = _vm.$createElement\n    var _c = _vm._self._c || _h\n    return _c(\"p\", [\n      _c(\"i\", [_vm._v(\"Showing only records where status has changed\")]),\n    ])\n  },\n  function () {\n    var _vm = this\n    var _h = _vm.$createElement\n    var _c = _vm._self._c || _h\n    return _c(\"thead\", [\n      _c(\"tr\", [\n        _c(\"th\", { attrs: { width: \"20%\" } }, [_vm._v(\"Date\")]),\n        _vm._v(\" \"),\n        _c(\"th\", { attrs: { width: \"20%\" } }, [_vm._v(\"Time\")]),\n        _vm._v(\" \"),\n        _c(\"th\", { attrs: { width: \"*\" } }, [_vm._v(\"Output\")]),\n        _vm._v(\" \"),\n        _c(\"th\", { attrs: { width: \"10%\" } }, [_vm._v(\"Status\")]),\n      ]),\n    ])\n  },\n]\nrender._withStripped = true\n\nexport { render, staticRenderFns }"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib/index.js??vue-loader-options!./resources/views/taskdetails.vue?vue&type=template&id=a378bf18&scoped=true&\n"); +eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"render\": () => (/* binding */ render),\n/* harmony export */ \"staticRenderFns\": () => (/* binding */ staticRenderFns)\n/* harmony export */ });\nvar render = function () {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"div\", [\n _vm.task.id != null\n ? _c(\"div\", { staticClass: \"container\" }, [\n _c(\"h1\", [\n _vm._v(\"\\n\\t\\t\\tTask #\" + _vm._s(_vm.task.id) + \"\\n\\t\\t\\t\"),\n ]),\n _vm._v(\"\\n\\n\\t\\tShow:\\n\\t\\t\"),\n _c(\n \"select\",\n {\n directives: [\n {\n name: \"model\",\n rawName: \"v-model\",\n value: _vm.chart.days,\n expression: \"chart.days\",\n },\n ],\n on: {\n change: [\n function ($event) {\n var $$selectedVal = Array.prototype.filter\n .call($event.target.options, function (o) {\n return o.selected\n })\n .map(function (o) {\n var val = \"_value\" in o ? o._value : o.value\n return val\n })\n _vm.$set(\n _vm.chart,\n \"days\",\n $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n )\n },\n _vm.refreshTask,\n ],\n },\n },\n [\n _c(\"option\", { attrs: { value: \"7\" } }, [_vm._v(\"7 days\")]),\n _vm._v(\" \"),\n _c(\"option\", { attrs: { value: \"15\" } }, [_vm._v(\"15 days\")]),\n _vm._v(\" \"),\n _c(\"option\", { attrs: { value: \"30\" } }, [_vm._v(\"30 days\")]),\n ]\n ),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"round\", attrs: { id: \"chart\" } }, [\n _c(\"h3\", [\n _vm._v(\"Uptime: past \" + _vm._s(_vm.chart.days) + \" days\"),\n ]),\n _vm._v(\" \"),\n _c(\n \"div\",\n { staticClass: \"block-content\" },\n [\n _vm.chart.render\n ? _c(\"apexchart\", {\n staticClass: \"graph\",\n attrs: {\n type: \"bar\",\n height: \"350\",\n options: _vm.chartOptions,\n series: _vm.series,\n },\n })\n : _vm._e(),\n ],\n 1\n ),\n ]),\n _vm._v(\" \"),\n _c(\"div\", { staticClass: \"round\" }, [\n _c(\"h3\", [\n _vm._v(\"Last \" + _vm._s(_vm.chart.days) + \" days history log\"),\n ]),\n _vm._v(\" \"),\n _vm.history\n ? _c(\"div\", { staticClass: \"block-content\" }, [\n _vm._m(0),\n _vm._v(\" \"),\n _c(\"table\", { attrs: { id: \"tasks_tbl\" } }, [\n _vm._m(1),\n _vm._v(\" \"),\n _c(\n \"tbody\",\n _vm._l(_vm.history, function (h) {\n return _c(\"tr\", { key: _vm.history.id }, [\n _c(\"td\", [\n _vm._v(\n _vm._s(\n _vm.moment(h.created_at).format(\"YYYY-MM-DD\")\n )\n ),\n ]),\n _vm._v(\" \"),\n _c(\"td\", [\n _vm._v(\n _vm._s(\n _vm.moment(h.created_at).format(\"HH:mm:ss\")\n )\n ),\n ]),\n _vm._v(\" \"),\n _c(\"td\", [\n h.output\n ? _c(\"span\", [\n _vm._v(\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\\t\" +\n _vm._s(h.output) +\n \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\"\n ),\n ])\n : _c(\"span\", [_c(\"i\", [_vm._v(\"No output\")])]),\n ]),\n _vm._v(\" \"),\n _c(\"td\", { class: _vm.statusText(h.status) }, [\n _c(\"img\", {\n attrs: {\n src:\n \"/img/\" + _vm.statusText(h.status) + \".svg\",\n width: \"16\",\n alt: \"Status\",\n },\n }),\n ]),\n ])\n }),\n 0\n ),\n ]),\n ])\n : _c(\n \"p\",\n [_c(\"center\", [_vm._v(\"No history to display here\")])],\n 1\n ),\n ]),\n ])\n : _vm._e(),\n ])\n}\nvar staticRenderFns = [\n function () {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"p\", [\n _c(\"i\", [_vm._v(\"Showing only records where status has changed\")]),\n ])\n },\n function () {\n var _vm = this\n var _h = _vm.$createElement\n var _c = _vm._self._c || _h\n return _c(\"thead\", [\n _c(\"tr\", [\n _c(\"th\", { attrs: { width: \"20%\" } }, [_vm._v(\"Date\")]),\n _vm._v(\" \"),\n _c(\"th\", { attrs: { width: \"20%\" } }, [_vm._v(\"Time\")]),\n _vm._v(\" \"),\n _c(\"th\", { attrs: { width: \"*\" } }, [_vm._v(\"Output\")]),\n _vm._v(\" \"),\n _c(\"th\", { attrs: { width: \"10%\" } }, [_vm._v(\"Status\")]),\n ]),\n ])\n },\n]\nrender._withStripped = true\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib/index.js??vue-loader-options!./resources/views/taskdetails.vue?vue&type=template&id=a378bf18&scoped=true&.js","mappings":";;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,0BAA0B;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA;AACA;AACA,mBAAmB;AACnB;AACA;AACA,eAAe;AACf,aAAa;AACb;AACA,6BAA6B,SAAS,cAAc;AACpD;AACA,6BAA6B,SAAS,eAAe;AACrD;AACA,6BAA6B,SAAS,eAAe;AACrD;AACA;AACA;AACA,sBAAsB,+BAA+B,eAAe;AACpE;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,8BAA8B;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB;AACvB,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,sBAAsB;AAC5C;AACA;AACA;AACA;AACA;AACA,4BAA4B,8BAA8B;AAC1D;AACA;AACA,gCAAgC,SAAS,mBAAmB;AAC5D;AACA;AACA;AACA;AACA;AACA,0CAA0C,qBAAqB;AAC/D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC,iCAAiC;AACtE;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B;AAC/B,6BAA6B;AAC7B;AACA;AACA,uBAAuB;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,SAAS,gBAAgB;AAC5C;AACA,mBAAmB,SAAS,gBAAgB;AAC5C;AACA,mBAAmB,SAAS,cAAc;AAC1C;AACA,mBAAmB,SAAS,gBAAgB;AAC5C;AACA;AACA,GAAG;AACH;AACA","sources":["webpack:///./resources/views/taskdetails.vue?6569"],"sourcesContent":["var render = function () {\n  var _vm = this\n  var _h = _vm.$createElement\n  var _c = _vm._self._c || _h\n  return _c(\"div\", [\n    _vm.task.id != null\n      ? _c(\"div\", { staticClass: \"container\" }, [\n          _c(\"h1\", [\n            _vm._v(\"\\n\\t\\t\\tTask #\" + _vm._s(_vm.task.id) + \"\\n\\t\\t\\t\"),\n          ]),\n          _vm._v(\"\\n\\n\\t\\tShow:\\n\\t\\t\"),\n          _c(\n            \"select\",\n            {\n              directives: [\n                {\n                  name: \"model\",\n                  rawName: \"v-model\",\n                  value: _vm.chart.days,\n                  expression: \"chart.days\",\n                },\n              ],\n              on: {\n                change: [\n                  function ($event) {\n                    var $$selectedVal = Array.prototype.filter\n                      .call($event.target.options, function (o) {\n                        return o.selected\n                      })\n                      .map(function (o) {\n                        var val = \"_value\" in o ? o._value : o.value\n                        return val\n                      })\n                    _vm.$set(\n                      _vm.chart,\n                      \"days\",\n                      $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n                    )\n                  },\n                  _vm.refreshTask,\n                ],\n              },\n            },\n            [\n              _c(\"option\", { attrs: { value: \"7\" } }, [_vm._v(\"7 days\")]),\n              _vm._v(\" \"),\n              _c(\"option\", { attrs: { value: \"15\" } }, [_vm._v(\"15 days\")]),\n              _vm._v(\" \"),\n              _c(\"option\", { attrs: { value: \"30\" } }, [_vm._v(\"30 days\")]),\n            ]\n          ),\n          _vm._v(\" \"),\n          _c(\"div\", { staticClass: \"round\", attrs: { id: \"chart\" } }, [\n            _c(\"h3\", [\n              _vm._v(\"Uptime: past \" + _vm._s(_vm.chart.days) + \" days\"),\n            ]),\n            _vm._v(\" \"),\n            _c(\n              \"div\",\n              { staticClass: \"block-content\" },\n              [\n                _vm.chart.render\n                  ? _c(\"apexchart\", {\n                      staticClass: \"graph\",\n                      attrs: {\n                        type: \"bar\",\n                        height: \"350\",\n                        options: _vm.chartOptions,\n                        series: _vm.series,\n                      },\n                    })\n                  : _vm._e(),\n              ],\n              1\n            ),\n          ]),\n          _vm._v(\" \"),\n          _c(\"div\", { staticClass: \"round\" }, [\n            _c(\"h3\", [\n              _vm._v(\"Last \" + _vm._s(_vm.chart.days) + \" days history log\"),\n            ]),\n            _vm._v(\" \"),\n            _vm.history\n              ? _c(\"div\", { staticClass: \"block-content\" }, [\n                  _vm._m(0),\n                  _vm._v(\" \"),\n                  _c(\"table\", { attrs: { id: \"tasks_tbl\" } }, [\n                    _vm._m(1),\n                    _vm._v(\" \"),\n                    _c(\n                      \"tbody\",\n                      _vm._l(_vm.history, function (h) {\n                        return _c(\"tr\", { key: _vm.history.id }, [\n                          _c(\"td\", [\n                            _vm._v(\n                              _vm._s(\n                                _vm.moment(h.created_at).format(\"YYYY-MM-DD\")\n                              )\n                            ),\n                          ]),\n                          _vm._v(\" \"),\n                          _c(\"td\", [\n                            _vm._v(\n                              _vm._s(\n                                _vm.moment(h.created_at).format(\"HH:mm:ss\")\n                              )\n                            ),\n                          ]),\n                          _vm._v(\" \"),\n                          _c(\"td\", [\n                            h.output\n                              ? _c(\"span\", [\n                                  _vm._v(\n                                    \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\\t\" +\n                                      _vm._s(h.output) +\n                                      \"\\n\\t\\t\\t\\t\\t\\t\\t\\t\"\n                                  ),\n                                ])\n                              : _c(\"span\", [_c(\"i\", [_vm._v(\"No output\")])]),\n                          ]),\n                          _vm._v(\" \"),\n                          _c(\"td\", { class: _vm.statusText(h.status) }, [\n                            _c(\"img\", {\n                              attrs: {\n                                src:\n                                  \"/img/\" + _vm.statusText(h.status) + \".svg\",\n                                width: \"16\",\n                                alt: \"Status\",\n                              },\n                            }),\n                          ]),\n                        ])\n                      }),\n                      0\n                    ),\n                  ]),\n                ])\n              : _c(\n                  \"p\",\n                  [_c(\"center\", [_vm._v(\"No history to display here\")])],\n                  1\n                ),\n          ]),\n        ])\n      : _vm._e(),\n  ])\n}\nvar staticRenderFns = [\n  function () {\n    var _vm = this\n    var _h = _vm.$createElement\n    var _c = _vm._self._c || _h\n    return _c(\"p\", [\n      _c(\"i\", [_vm._v(\"Showing only records where status has changed\")]),\n    ])\n  },\n  function () {\n    var _vm = this\n    var _h = _vm.$createElement\n    var _c = _vm._self._c || _h\n    return _c(\"thead\", [\n      _c(\"tr\", [\n        _c(\"th\", { attrs: { width: \"20%\" } }, [_vm._v(\"Date\")]),\n        _vm._v(\" \"),\n        _c(\"th\", { attrs: { width: \"20%\" } }, [_vm._v(\"Time\")]),\n        _vm._v(\" \"),\n        _c(\"th\", { attrs: { width: \"*\" } }, [_vm._v(\"Output\")]),\n        _vm._v(\" \"),\n        _c(\"th\", { attrs: { width: \"10%\" } }, [_vm._v(\"Status\")]),\n      ]),\n    ])\n  },\n]\nrender._withStripped = true\n\nexport { render, staticRenderFns }"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib/index.js??vue-loader-options!./resources/views/taskdetails.vue?vue&type=template&id=a378bf18&scoped=true&\n"); /***/ }), diff --git a/resources/views/app.vue b/resources/views/app.vue index f7e8ba5..86b0e18 100644 --- a/resources/views/app.vue +++ b/resources/views/app.vue @@ -19,7 +19,8 @@ }, data: function() { return { - refreshed_time: null + refreshed_time: null, + refresh: null } }, computed: { diff --git a/resources/views/taskdetails.vue b/resources/views/taskdetails.vue index 5fe6fdb..d36b0c3 100644 --- a/resources/views/taskdetails.vue +++ b/resources/views/taskdetails.vue @@ -1,7 +1,7 @@ @@ -70,7 +70,11 @@ export default{ data: function() { return { - task: null, + task: { + id: null + }, + history: null, + refresh: null, chart: { render: false, @@ -121,66 +125,68 @@ return 'unknown'; } }, - refreshGraph: function() { - this.$http.post('/api/getTaskGraph/'+this.task.id, { + refreshTask: function() { + this.$http.post('/api/getTask/'+this.task.id, { days: this.chart.days }) .then(response => { - let xaxis = []; - let new_data_a = []; - let new_data_b = []; - console.log(response.data) - - for (let date in response.data) { - xaxis.push(date) - new_data_a.push(response.data[date]['up']) - new_data_b.push(response.data[date]['down']) - } - - this.chartOptions = { - xaxis: { - categories: xaxis, - labels: { - show: true, - rotate: -45, - rotateAlways: true, - } - }, - chart: { - type: 'bar', - height: 300, - stacked: true, - stackType: '100%' - }, - } - this.series = [{ - name: 'UP', - data: new_data_a, - color: '#00955c' - }, - { - name: 'DOWN', - data: new_data_b, - color: '#ef3232' - }] - - this.chart.render = true + this.task = response.data.task + this.history = response.data.history + this.refreshGraph(response.data.stats) }) - } + }, + refreshGraph: function(stats) { + let xaxis = []; + let new_data_a = []; + let new_data_b = []; + + for (let date in stats) { + xaxis.push(date) + new_data_a.push(stats[date]['up']) + new_data_b.push(stats[date]['down']) + } + + this.chartOptions = { + xaxis: { + categories: xaxis, + labels: { + show: true, + rotate: -45, + rotateAlways: true, + } + }, + chart: { + type: 'bar', + height: 300, + stacked: true, + stackType: '100%' + }, + } + this.series = [{ + name: 'UP', + data: new_data_a, + color: '#00955c' + }, + { + name: 'DOWN', + data: new_data_b, + color: '#ef3232' + }] + + this.chart.render = true + }, }, mounted: function() { - let task_id = this.$route.params.id ?? null + this.task.id = this.$route.params.id ?? null - if (task_id != null) { - this.$http.post('/api/getTask/'+task_id, { - days: this.chart.days - }) - .then(response => this.task = response.data) - .then(() => { - this.refreshGraph() - }) + if (this.task.id != null) { + this.refreshTask() } - } + }, + beforeRouteLeave(to, from, next) { + clearTimeout(this.refresh); + next(); + }, } diff --git a/routes/web.php b/routes/web.php index c3f8bdf..48f8296 100644 --- a/routes/web.php +++ b/routes/web.php @@ -16,7 +16,6 @@ $router->group(['prefix' => 'api/'], function () use ($router) { $router->get('getTasks/', ['uses' => 'ApiController@getTasks']); $router->post('getTask/{id}', ['uses' => 'ApiController@getTaskDetails']); - $router->post('getTaskGraph/{id}', ['uses' => 'ApiController@getTaskGraph']); $router->patch('toggleTaskStatus/{id}', ['uses' => 'ApiController@toggleTaskStatus']); });