<!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>