<!DOCTYPE html> <html> <head> <title>Nina Configuration</title> <!-- <link href="https://fonts.googleapis.com/css?family=Roboto:100,300,400,500,700,900" rel="stylesheet"> --> <link href="css/materialdesignicons.min.css" rel="stylesheet"> <link href="css/vuetify.min.css" rel="stylesheet"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no, minimal-ui"> </head> <body> <div id="app"> <v-app> <v-app-bar app> <v-toolbar-title>MOWAS/BBK Configuration</v-toolbar-title> <v-spacer></v-spacer> <v-btn color="success" @click="storeConfig()">Store & Restart</v-btn> <v-checkbox label="Expert Mode" v-model="EXPERTMODE"></v-checkbox> </v-app-bar> <v-content> <v-form> <v-tabs v-model="configTab" next-icon="mdi-arrow-right-bold-box-outline" prev-icon="mdi-arrow-left-bold-box-outline" show-arrows> <v-tabs-slider></v-tabs-slider> <v-tab key="regions">Regions</v-tab> <v-tab v-show="EXPERTMODE" key="notificationConfig">Notification Configuration</v-tab> </v-tabs> <v-tabs-items v-model="configTab"> <v-tab-item key="regions"> <v-container> <v-row> <v-checkbox label="use German POCSAG" v-model="configData.germanUmlautSupport"></v-checkbox> </v-row> <v-row> <h3>Regions:</h3> </v-row> <v-row> <v-btn color="primary" fab dark small icon @click="addAlarm()"> <v-icon>mdi-plus</v-icon> </v-btn> </v-row> <v-row v-for="(subConfig, index) in configData.regions" :key="subConfig._id"> <v-col cols="4"> <v-checkbox label="Active" v-model="subConfig.active"></v-checkbox> <v-text-field v-model="subConfig.name" label="Name"></v-text-field> <v-autocomplete v-model="subConfig.preset" :items="presetSearchItems" :loading="!presetSearchItems.length > 0" color="white" hide-no-data dense label="Profile" placeholder="Start typing to Search" prepend-icon="mdi-database-search" ></v-autocomplete> </v-col> <v-col cols="6"> <v-autocomplete v-model="subConfig.regionsID" :items="regionsSearchItems" :loading="!regionsSearchItems.length > 0" color="white" hide-no-data dense label="Amtlicher Regionalschlüssel" placeholder="Start typing to Search" prepend-icon="mdi-database-search" ></v-autocomplete> <v-checkbox v-model="subConfig.mowas" label="MOWAS"></v-checkbox> </v-col> <v-col cols="2"> <v-btn color="error" @click="configData.regions.splice(index, 1)" fab icon><v-icon>mdi-delete</v-icon></v-btn> </v-col> <v-col cols="12"> <hr/> </v-col> </v-row> </v-container> </v-tab-item> <v-tab-item key="notificationConfig"> <v-container> <b>Routing Paramters:</b> <v-row> <v-col cols="12" sm="12" md="6"> <v-text-field label="Daemon Endpoint URL" v-model="configData.pager.url"> </v-text-field> </v-col> </v-row> </v-container> </v-tab-item> </v-tabs-items> </v-form> </v-content> </v-app> </div> <script src="js/vue/vue.js"></script> <script src="js/vue/vuetify.js"></script> <script src="js/vue/vue-resource_1.5.1.js"></script> <script> new Vue({ el: '#app', vuetify: new Vuetify(), http: { root: '/' }, data() { return { EXPERTMODE: false, configTab: null, configData: { "bottoken": "", "pager": { "url": "", }, "germanUmlautSupport": false, "regions": [] }, regionsSearchItems: [], presetSearchItems: [], } }, created() { this.loadPresets() this.loadConfig() }, methods: { loadPresets() { this.$http.get('/api/deliveryPresets') .then(response => { this.presetSearchItems = response.body.map(x => { return { text: x.name, value: x.key, }}) }, response => { }) }, loadConfig() { this.$http.get('/config').then(response => { const newConfig = response.body newConfig.regions = newConfig.regions.map((x) => { x._id = btoa(JSON.stringify(x)) return x }) this.configData = newConfig }, response => { }) this.$http.get('/Regionalschl_ssel_2022-09-30.json').then(response => { console.log(response.body.daten) this.regionsSearchItems = response.body.daten.map(x => { return { text: (!!x[2] ? x.slice(1).join(' - ') : x[1]) + ' (' + x[0] + ')', value: x[0], //Description }}) }, response => { }) }, storeConfig() { const storeConfig = JSON.parse(JSON.stringify(this.configData)) storeConfig.regions = storeConfig.regions.map(a=> { delete a._id return a }) this.$http.post('/config', storeConfig).then(response => { }) .then(this.$http.post('/restart')) .then(() => { document.body.style = 'display:none' setTimeout(() => window.location.reload(), 1e3) }) }, addDeliveryTarget(index) { this.configData.regions[index].params.routing.connectors.push(["connectorName", "connectorParam"]) }, addAlarm() { this.configData.regions.push({ name: "Testalarm", params: { "type": "simple", "routing": { "device": "generic", "connectors": [] }, }, "alarmSchedulingMode": "weekly", }) }, } }) </script> </body> </html>