All files / views Fruits.vue

0% Statements 0/4
100% Branches 0/0
0% Functions 0/3
0% Lines 0/4

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64                                                                                                                               
<template>
  <div class="fruits">
    <h2>Directory</h2>
    <Grid v-if="!error" :data="this.fruits" />
    <div class="alert" v-else>
      {{ error }}
      <pre><span>$</span> yarn run api</pre>
    </div>
  </div>
</template>
 
<script>
import { mapState } from "vuex";
import Grid from "@/components/Grid/Grid";
 
export default {
  name: "Fruits",
  components: { Grid },
  computed: {
    ...mapState(["fruits"])
  },
  data() {
    return {
      error: null
    };
  },
  async created() {
    await this.$store.dispatch("getFruits").catch(err => (this.error = err));
  }
};
</script>
 
<style scoped lang="less">
.fruits {
  margin: 0 auto;
  max-width: 1200px;
}
 
.alert {
  box-sizing: border-box;
  margin: 0 auto;
  width: 80%;
  background-color: @text-error;
  color: @color-2;
  padding: 1rem 1.5rem;
  border-radius: 4px;
 
  @media screen and (min-width: @sm) {
    width: 50%;
    max-width: 535px;
  }
 
  pre {
    padding: 1rem;
    border-radius: 4px;
    background-color: rgb(45, 48, 55);
 
    span {
      color: @color-3;
    }
  }
}
</style>