<template>
  <view class="evaluate-list" ref="container">
    <view class="header">
      <view class="generalComment acea-row row-between-wrapper">
        <view class="acea-row row-middle font-color-red">
          <text class="evaluate">评分</text>
          <view class="start" :class="'star' + replyData.replyStar"></view>
        </view>
        <view>
          <text class="font-color-red">{{ replyData.replyChance || 0 }}%</text>
		  <text>好评率</text>
        </view>
      </view>
      <view class="nav acea-row row-middle">
        <view
          class="acea-row row-center-wrapper"
          v-for="(item, navListIndex) in navList"
          :key="navListIndex"
          @click="changeType(navListIndex)"
        >
          <view
            class="item"
            :class="currentActive === navListIndex ? 'bg-color-red' : ''"
            v-if="item.num"
          >
		  <text>{{ item.evaluate }}({{ item.num }})</text>
          </view>
        </view>
      </view>
    </view>
    <UserEvaluation :reply="reply"></UserEvaluation>
    <Loading :loaded="loadend" :loading="loading"></Loading>
  </view>
</template>
<script>
import UserEvaluation from "@/components/UserEvaluation";
import { getReplyConfig, getReplyList } from "@/api/store";
import Loading from "@/components/Loading";

export default {
  name: "EvaluateList",
  components: {
    UserEvaluation,
    Loading
  },
  props: {},
  data: function() {
    return {
      product_id: 0,
      replyData: {},
      navList: [
        { evaluate: "全部", num: 0 },
        { evaluate: "好评", num: 0 },
        { evaluate: "中评", num: 0 },
        { evaluate: "差评", num: 0 }
      ],
      currentActive: 0,
      page: 1,
      limit: 8,
      reply: [],
      loadTitle: "",
      loading: false,
      loadend: false
    };
  },
  mounted: function() {
    this.product_id = this.$yroute.query.id;
    this.getProductReplyCount();
    this.getProductReplyList();
  },
  onReachBottom() {
    !this.loading && this.getProductReplyList();
  },
  methods: {
    getProductReplyCount () {
      getReplyConfig(this.product_id).then(res => {
        this.$set(that, "replyData", res.data);
        this.navList[0].num = res.data.sumCount;
        this.navList[1].num = res.data.goodCount;
        this.navList[2].num = res.data.inCount;
        this.navList[3].num = res.data.poorCount;
      });
    },
    getProductReplyList () {
      if (this.loading) return; //阻止下次请求(false可以进行请求);
      if (this.loadend) return; //阻止结束当前请求(false可以进行请求);
      this.loading = true;
      let q = { page: this.page, limit: this.limit, type: this.currentActive };
      getReplyList(this.product_id, q).then(res => {
        this.loading = false;
        //apply();js将一个数组插入另一个数组;
        this.reply.push.apply(this.reply, res.data);
        this.loadend = res.data.length < this.limit; //判断所有数据是否加载完成;
        this.page = this.page + 1;
      });
    },
    changeType (index) {
      this.currentActive = index;
      this.page = 1;
      this.loadend = false;
      this.$set(this, "reply", []);
      this.getProductReplyList();
    }
  }
};
</script>
<style scoped lang="less">
.noCommodity {
  height: 8*100rpx;
  background-color: #fff;
}
</style>