uptime-kuma/src/pages/EditMonitor.vue

302 lines
12 KiB
Vue
Raw Normal View History

2021-06-25 06:55:49 -07:00
<template>
2021-08-19 11:37:59 -07:00
<transition name="slide-fade" appear>
<div>
<h1 class="mb-3">{{ pageName }}</h1>
<form @submit.prevent="submit">
<div class="shadow-box">
<div class="row">
<div class="col-md-6">
<h2 class="mb-2">{{ $t("General") }}</h2>
2021-08-19 11:37:59 -07:00
<div class="my-3">
<label for="type" class="form-label">{{ $t("Monitor Type") }}</label>
2021-08-19 11:37:59 -07:00
<select id="type" v-model="monitor.type" class="form-select" aria-label="Default select example">
<option value="http">
HTTP(s)
</option>
<option value="port">
TCP Port
</option>
<option value="ping">
Ping
</option>
<option value="keyword">
HTTP(s) - {{ $t("Keyword") }}
2021-08-19 11:37:59 -07:00
</option>
</select>
</div>
<div class="my-3">
<label for="name" class="form-label">{{ $t("Friendly Name") }}</label>
2021-08-19 11:37:59 -07:00
<input id="name" v-model="monitor.name" type="text" class="form-control" required>
</div>
<div v-if="monitor.type === 'http' || monitor.type === 'keyword' " class="my-3">
<label for="url" class="form-label">{{ $t("URL") }}</label>
2021-08-19 11:37:59 -07:00
<input id="url" v-model="monitor.url" type="url" class="form-control" pattern="https?://.+" required>
</div>
<div v-if="monitor.type === 'keyword' " class="my-3">
<label for="keyword" class="form-label">{{ $t("Keyword") }}</label>
2021-08-19 11:37:59 -07:00
<input id="keyword" v-model="monitor.keyword" type="text" class="form-control" required>
<div class="form-text">
Search keyword in plain html or JSON response and it is case-sensitive
</div>
</div>
<div v-if="monitor.type === 'port' || monitor.type === 'ping' " class="my-3">
<label for="hostname" class="form-label">{{ $t("Hostname") }}</label>
2021-08-19 11:37:59 -07:00
<input id="hostname" v-model="monitor.hostname" type="text" class="form-control" required>
</div>
<div v-if="monitor.type === 'port' " class="my-3">
<label for="port" class="form-label">{{ $t("Port") }}</label>
2021-08-19 11:37:59 -07:00
<input id="port" v-model="monitor.port" type="number" class="form-control" required min="0" max="65535" step="1">
</div>
<div class="my-3">
<label for="interval" class="form-label">{{ $t("Heartbeat Interval") }} ({{ $t("checkEverySecond", [ monitor.interval ]) }})</label>
2021-08-19 11:37:59 -07:00
<input id="interval" v-model="monitor.interval" type="number" class="form-control" required min="20" step="1">
</div>
<div class="my-3">
<label for="maxRetries" class="form-label">{{ $t("Retries") }}</label>
2021-08-19 11:37:59 -07:00
<input id="maxRetries" v-model="monitor.maxretries" type="number" class="form-control" required min="0" step="1">
<div class="form-text">
{{ $t("retriesDescription") }}
2021-08-19 11:37:59 -07:00
</div>
</div>
<h2 class="mt-5 mb-2">{{ $t("Advanced") }}</h2>
2021-08-19 11:37:59 -07:00
<div v-if="monitor.type === 'http' || monitor.type === 'keyword' " class="my-3 form-check">
<input id="ignore-tls" v-model="monitor.ignoreTls" class="form-check-input" type="checkbox" value="">
<label class="form-check-label" for="ignore-tls">
{{ $t("ignoreTLSError") }}
2021-08-19 11:37:59 -07:00
</label>
</div>
<div class="my-3 form-check">
<input id="upside-down" v-model="monitor.upsideDown" class="form-check-input" type="checkbox">
<label class="form-check-label" for="upside-down">
{{ $t("Upside Down Mode") }}
2021-08-19 11:37:59 -07:00
</label>
<div class="form-text">
{{ $t("upsideDownModeDescription") }}
2021-08-19 11:37:59 -07:00
</div>
</div>
<div v-if="monitor.type === 'http' || monitor.type === 'keyword' " class="my-3">
<label for="maxRedirects" class="form-label">{{ $t("Max. Redirects") }}</label>
2021-08-19 11:37:59 -07:00
<input id="maxRedirects" v-model="monitor.maxredirects" type="number" class="form-control" required min="0" step="1">
<div class="form-text">
{{ $t("maxRedirectDescription") }}
2021-08-19 11:37:59 -07:00
</div>
</div>
<div v-if="monitor.type === 'http' || monitor.type === 'keyword' " class="my-3">
<label for="acceptedStatusCodes" class="form-label">{{ $t("Accepted Status Codes") }}</label>
2021-08-19 11:37:59 -07:00
<VueMultiselect
id="acceptedStatusCodes"
v-model="monitor.accepted_statuscodes"
:options="acceptedStatusCodeOptions"
:multiple="true"
:close-on-select="false"
:clear-on-select="false"
:preserve-search="true"
placeholder="Pick Accepted Status Codes..."
:preselect-first="false"
:max-height="600"
:taggable="true"
></VueMultiselect>
<div class="form-text">
{{ $t("acceptedStatusCodesDescription") }}
2021-08-19 11:37:59 -07:00
</div>
</div>
<div class="mt-5 mb-1">
<button class="btn btn-primary" type="submit" :disabled="processing">{{ $t("Save") }}</button>
2021-08-19 11:37:59 -07:00
</div>
2021-07-27 10:47:13 -07:00
</div>
2021-08-19 11:37:59 -07:00
<div class="col-md-6">
<div v-if="$root.isMobile" class="mt-3" />
2021-07-29 10:09:14 -07:00
<h2 class="mb-2">{{ $t("Notifications") }}</h2>
2021-08-19 11:37:59 -07:00
<p v-if="$root.notificationList.length === 0">
{{ $t("Not available, please setup.") }}
2021-08-19 11:37:59 -07:00
</p>
2021-07-29 10:09:14 -07:00
2021-08-19 11:37:59 -07:00
<div v-for="notification in $root.notificationList" :key="notification.id" class="form-check form-switch my-3">
<input :id=" 'notification' + notification.id" v-model="monitor.notificationIDList[notification.id]" class="form-check-input" type="checkbox">
2021-07-29 10:09:14 -07:00
2021-08-19 11:37:59 -07:00
<label class="form-check-label" :for=" 'notification' + notification.id">
{{ notification.name }}
<a href="#" @click="$refs.notificationDialog.show(notification.id)">{{ $t("Edit") }}</a>
2021-08-19 11:37:59 -07:00
</label>
</div>
2021-08-19 11:37:59 -07:00
<button class="btn btn-primary me-2" type="button" @click="$refs.notificationDialog.show()">
{{ $t("Setup Notification") }}
2021-08-19 11:37:59 -07:00
</button>
</div>
</div>
2021-07-27 10:47:13 -07:00
</div>
2021-08-19 11:37:59 -07:00
</form>
2021-06-25 06:55:49 -07:00
2021-08-19 11:37:59 -07:00
<NotificationDialog ref="notificationDialog" />
2021-06-25 06:55:49 -07:00
</div>
2021-08-19 11:37:59 -07:00
</transition>
2021-06-25 06:55:49 -07:00
</template>
<script>
2021-06-29 01:06:20 -07:00
import NotificationDialog from "../components/NotificationDialog.vue";
2021-07-27 10:47:13 -07:00
import { useToast } from "vue-toastification"
import VueMultiselect from "vue-multiselect"
2021-06-25 06:55:49 -07:00
const toast = useToast()
export default {
components: {
2021-07-27 10:47:13 -07:00
NotificationDialog,
VueMultiselect,
2021-06-25 06:55:49 -07:00
},
2021-08-08 06:14:29 -07:00
2021-06-25 06:55:49 -07:00
data() {
return {
processing: false,
monitor: {
notificationIDList: {},
},
2021-08-08 06:14:29 -07:00
acceptedStatusCodeOptions: [],
2021-06-25 06:55:49 -07:00
}
},
2021-08-08 06:14:29 -07:00
2021-06-25 06:55:49 -07:00
computed: {
pageName() {
return this.$t((this.isAdd) ? "Add New Monitor" : "Edit");
2021-06-25 06:55:49 -07:00
},
isAdd() {
return this.$route.path === "/add";
2021-06-27 01:10:55 -07:00
},
isEdit() {
return this.$route.path.startsWith("/edit");
2021-07-27 10:47:13 -07:00
},
},
watch: {
2021-08-19 11:37:59 -07:00
"$route.fullPath"() {
2021-07-27 10:47:13 -07:00
this.init();
},
},
mounted() {
this.init();
2021-08-08 06:14:29 -07:00
let acceptedStatusCodeOptions = [
"100-199",
"200-299",
"300-399",
"400-499",
"500-599",
];
for (let i = 100; i <= 999; i++) {
acceptedStatusCodeOptions.push(i.toString());
}
this.acceptedStatusCodeOptions = acceptedStatusCodeOptions;
2021-06-25 06:55:49 -07:00
},
methods: {
2021-06-27 01:10:55 -07:00
init() {
if (this.isAdd) {
console.log("??????")
this.monitor = {
type: "http",
name: "",
url: "https://",
interval: 60,
maxretries: 0,
notificationIDList: {},
2021-07-30 04:18:26 -07:00
ignoreTls: false,
2021-07-29 10:09:14 -07:00
upsideDown: false,
maxredirects: 10,
accepted_statuscodes: ["200-299"],
2021-06-27 01:10:55 -07:00
}
} else if (this.isEdit) {
this.$root.getSocket().emit("getMonitor", this.$route.params.id, (res) => {
if (res.ok) {
this.monitor = res.monitor;
} else {
toast.error(res.msg)
}
})
}
},
2021-06-25 06:55:49 -07:00
submit() {
this.processing = true;
if (this.isAdd) {
this.$root.add(this.monitor, (res) => {
this.processing = false;
if (res.ok) {
toast.success(res.msg);
this.$router.push("/dashboard/" + res.monitorID)
} else {
toast.error(res.msg);
}
})
} else {
2021-06-27 01:10:55 -07:00
this.$root.getSocket().emit("editMonitor", this.monitor, (res) => {
this.processing = false;
this.$root.toastRes(res)
})
2021-06-25 06:55:49 -07:00
}
2021-07-27 10:47:13 -07:00
},
2021-06-27 01:10:55 -07:00
},
2021-06-25 06:55:49 -07:00
}
</script>
<style src="vue-multiselect/dist/vue-multiselect.css"></style>
2021-08-06 04:48:51 -07:00
<style lang="scss">
@import "../assets/vars.scss";
.multiselect__tags {
2021-08-08 06:03:10 -07:00
border-radius: 1.5rem;
border: 1px solid #ced4da;
}
2021-08-06 04:48:51 -07:00
.multiselect--active .multiselect__tags {
border-radius: 1rem;
}
2021-08-06 04:48:51 -07:00
.multiselect__option--highlight {
background: $primary !important;
}
.multiselect__option--highlight::after {
background: $primary !important;
}
.multiselect__tag {
2021-08-08 06:03:10 -07:00
border-radius: 50rem;
2021-08-06 04:48:51 -07:00
background: $primary !important;
}
2021-08-08 06:03:10 -07:00
.dark {
.multiselect__tag {
color: $dark-font-color2;
}
}
</style>
2021-06-25 06:55:49 -07:00
<style scoped>
.shadow-box {
padding: 20px;
}
</style>