diff options
Diffstat (limited to 'resources/js/components/call-sign-description.vue')
| -rw-r--r-- | resources/js/components/call-sign-description.vue | 56 | 
1 files changed, 56 insertions, 0 deletions
| diff --git a/resources/js/components/call-sign-description.vue b/resources/js/components/call-sign-description.vue new file mode 100644 index 0000000..7ab8b64 --- /dev/null +++ b/resources/js/components/call-sign-description.vue @@ -0,0 +1,56 @@ +<template> +  <div> +    <div class="form-group"> +        <label for="special-call">Special Callsign:</label> +        <select class="form-control" :class="{ 'is-invalid': isInvalid }" id="special-call" v-model="selected" :name="name" required> +          <option v-for="option in options" :key="option.id" :value="option.sign" v-text="option.sign"></option> +        </select>  +    </div> + +    <div class="card mb-3"> +      <div class="card-body pb-1"> +        <div class="card-text" v-html="description"></div> +      </div> +    </div> +  </div> +</template> + +<script> +export default { +  props: [ 'name', 'old', 'isInvalid' ], +  mounted() { +    this.$store.dispatch('pullSigns').then(() => { +      try { +        if (this.old) { +          this.$store.dispatch('setSelectedSign', this.old); +        } +        else { +          this.$store.dispatch('setSelectedSign', this.$store.getters.getSigns[0].sign); +        } +      } +      catch { +        console.log('No call signs!'); +      } +    }); +  }, +  computed: { +    options() { +      return this.$store.getters.getSigns; +    }, +    selected: { +      get() { +        return this.$store.getters.getSelectedSign; +      }, +      set(value) { +        this.$store.dispatch('setSelectedSign', value); +      } +    }, +    description() { +      for (let i = 0; i < this.options.length; i++) +        if (this.options[i].sign === this.selected) +          return this.options[i].description; +      return ''; +    } +  } +} +</script> | 
