<!--
  - Copyright 2014-2018 the original author or authors.
  -
  - Licensed under the Apache License, Version 2.0 (the "License");
  - you may not use this file except in compliance with the License.
  - You may obtain a copy of the License at
  -
  -     http://www.apache.org/licenses/LICENSE-2.0
  -
  - Unless required by applicable law or agreed to in writing, software
  - distributed under the License is distributed on an "AS IS" BASIS,
  - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  - See the License for the specific language governing permissions and
  - limitations under the License.
  -->

<template>
  <div>
    <sba-instance-header :instance="instance" :application="application" :class="headerClass"/>
    <sba-instance-tabs :views="instanceViews" :instance="instance" :application="application" :class="headerClass"/>
    <router-view v-if="instance" :instance="instance"/>
  </div>
</template>

<script>
  import sbaInstanceHeader from './header';
  import sbaInstanceTabs from './tabs';

  export default {
    components: {sbaInstanceHeader, sbaInstanceTabs},
    props: {
      instanceId: {
        type: String,
        required: true
      },
      applications: {
        type: Array,
        default: () => [],
      },
      error: {
        type: null,
        default: null
      }
    },
    computed: {
      instance() {
        return this.applications.findInstance(this.instanceId);
      },
      application() {
        return this.applications.findApplicationForInstance(this.instanceId);
      },
      instanceViews() {
        return this.$root.views.filter(view => view.name.lastIndexOf('instance/') === 0);
      },
      headerClass() {
        if (!this.instance) {
          return '';
        }
        if (this.instance.statusInfo.status === 'UP') {
          return 'is-primary';
        }
        if (this.instance.statusInfo.status === 'RESTRICTED') {
          return 'is-warning';
        }
        if (this.instance.statusInfo.status === 'DOWN') {
          return 'is-danger';
        }
        if (this.instance.statusInfo.status === 'OUT_OF_SERVICE') {
          return 'is-danger';
        }
        if (this.instance.statusInfo.status === 'OFFLINE') {
          return 'is-light';
        }
        return 'is-light';
      }
    }
  }
</script>