167 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			167 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
<template>
 | 
						||
  <div v-if="wines.length > 0" class="wines-main-container">
 | 
						||
    <div class="info-and-link">
 | 
						||
      <h3>
 | 
						||
        Topp 5 viner
 | 
						||
      </h3>
 | 
						||
      <router-link to="viner">
 | 
						||
        <span class="vin-link">Se alle viner </span>
 | 
						||
      </router-link>
 | 
						||
    </div>
 | 
						||
    <div class="wine-container">
 | 
						||
      <Wine v-for="wine in wines" :key="wine" :wine="wine">
 | 
						||
        <template v-slot:top>
 | 
						||
          <div class="flex justify-end">
 | 
						||
            <div class="requested-count cursor-pointer">
 | 
						||
              <span> {{ wine.occurences }} </span>
 | 
						||
              <i class="icon icon--heart" />
 | 
						||
            </div>
 | 
						||
          </div>
 | 
						||
        </template>
 | 
						||
      </Wine>
 | 
						||
    </div>
 | 
						||
  </div>
 | 
						||
</template>
 | 
						||
 | 
						||
<script>
 | 
						||
import Wine from "@/ui/Wine";
 | 
						||
import { overallWineStatistics } from "@/api";
 | 
						||
 | 
						||
export default {
 | 
						||
  components: {
 | 
						||
    Wine
 | 
						||
  },
 | 
						||
  data() {
 | 
						||
    return { 
 | 
						||
      wines: [], 
 | 
						||
      clickedWine: null, 
 | 
						||
    };
 | 
						||
  },
 | 
						||
  async mounted() {
 | 
						||
    let response = await overallWineStatistics();
 | 
						||
 | 
						||
    response.sort();
 | 
						||
    response = response
 | 
						||
      .filter(wine => wine.name != null && wine.name != "")
 | 
						||
      .sort(
 | 
						||
        this.predicate(
 | 
						||
          {
 | 
						||
            name: "occurences",
 | 
						||
            reverse: true
 | 
						||
          },
 | 
						||
          {
 | 
						||
            name: "rating",
 | 
						||
            reverse: true
 | 
						||
          }
 | 
						||
        )
 | 
						||
      );
 | 
						||
    this.wines = response.slice(0, 5);
 | 
						||
  },
 | 
						||
  methods: {
 | 
						||
    predicate: function() {
 | 
						||
      var fields = [],
 | 
						||
        n_fields = arguments.length,
 | 
						||
        field,
 | 
						||
        name,
 | 
						||
        cmp;
 | 
						||
 | 
						||
      var default_cmp = function(a, b) {
 | 
						||
          if (a == undefined) a = 0;
 | 
						||
          if (b == undefined) b = 0;
 | 
						||
          if (a === b) return 0;
 | 
						||
          return a < b ? -1 : 1;
 | 
						||
        },
 | 
						||
        getCmpFunc = function(primer, reverse) {
 | 
						||
          var dfc = default_cmp,
 | 
						||
            // closer in scope
 | 
						||
            cmp = default_cmp;
 | 
						||
          if (primer) {
 | 
						||
            cmp = function(a, b) {
 | 
						||
              return dfc(primer(a), primer(b));
 | 
						||
            };
 | 
						||
          }
 | 
						||
          if (reverse) {
 | 
						||
            return function(a, b) {
 | 
						||
              return -1 * cmp(a, b);
 | 
						||
            };
 | 
						||
          }
 | 
						||
          return cmp;
 | 
						||
        };
 | 
						||
 | 
						||
      // preprocess sorting options
 | 
						||
      for (var i = 0; i < n_fields; i++) {
 | 
						||
        field = arguments[i];
 | 
						||
        if (typeof field === "string") {
 | 
						||
          name = field;
 | 
						||
          cmp = default_cmp;
 | 
						||
        } else {
 | 
						||
          name = field.name;
 | 
						||
          cmp = getCmpFunc(field.primer, field.reverse);
 | 
						||
        }
 | 
						||
        fields.push({
 | 
						||
          name: name,
 | 
						||
          cmp: cmp
 | 
						||
        });
 | 
						||
      }
 | 
						||
 | 
						||
      // final comparison function
 | 
						||
      return function(A, B) {
 | 
						||
        var name, result;
 | 
						||
        for (var i = 0; i < n_fields; i++) {
 | 
						||
          result = 0;
 | 
						||
          field = fields[i];
 | 
						||
          name = field.name;
 | 
						||
 | 
						||
          result = field.cmp(A[name], B[name]);
 | 
						||
          if (result !== 0) break;
 | 
						||
        }
 | 
						||
        return result;
 | 
						||
      };
 | 
						||
    }
 | 
						||
  }
 | 
						||
};
 | 
						||
</script>
 | 
						||
 | 
						||
<style lang="scss" scoped>
 | 
						||
@import "@/styles/variables.scss";
 | 
						||
@import "@/styles/global.scss";
 | 
						||
@import "../styles/media-queries.scss";
 | 
						||
 | 
						||
.wines-main-container {
 | 
						||
  margin-bottom: 10em;
 | 
						||
}
 | 
						||
 | 
						||
.info-and-link{
 | 
						||
  display: flex;
 | 
						||
  justify-content: space-between;
 | 
						||
}
 | 
						||
 | 
						||
.wine-container {
 | 
						||
  display: grid;
 | 
						||
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
 | 
						||
  grid-gap: 2rem;
 | 
						||
 | 
						||
  .requested-count {
 | 
						||
    display: flex;
 | 
						||
    align-items: center;
 | 
						||
    margin-top: -0.5rem;
 | 
						||
    background-color: rgb(244,244,244);
 | 
						||
    border-radius: 1.1rem;
 | 
						||
    padding: 0.25rem 1rem;
 | 
						||
    font-size: 1.25em;
 | 
						||
 | 
						||
    span {
 | 
						||
      padding-right: 0.5rem;
 | 
						||
      line-height: 1.25em;
 | 
						||
    }
 | 
						||
    .icon--heart{
 | 
						||
      font-size: 1.5rem;
 | 
						||
      color: $link-color;
 | 
						||
    }
 | 
						||
  }
 | 
						||
}
 | 
						||
 | 
						||
 | 
						||
 | 
						||
</style>
 |