/**
* @Author Sean
* @Date 2019/10/22
*/
<template>
  <h-view id="my-collect" class="public-style" style="height: 100%">
    <h-header :proportion="[5,1,1]" class="bar-custom">
      <div slot="left" class="h-header-btn">
        <img src="@/assets/userBind/arrow.png" @click="$routeGo()">
        <span>我的收藏</span>
      </div>
    </h-header>

      <!-- 搜索 -->
    <div class="search has-header">
      <input v-model="searchInput" type="text" placeholder="请输入经销商/产品名称/参数项">
    </div>
      <scroll
        ref="scroll"
        :updateData="[productList]"
        :pullUp="true"
        @pullingUp="loadMore"
      >
<div class="division-box">

      <list-item v-for="(item,index) in productList" :key="index">
        <item :proportion="[1,4]" @click.native="goDetailed(item)">
          <div slot="name" class="item-pic">
              <img :src="item.url" alt="">
            </div>
          <div slot="content" class="item-content">
            <div class="pro-name">
              <p>{{ item.product_name }}</p>
              <img class="arrow" src="@/assets/productQuery/collmark.png" alt="" >
            </div>
            <div class="centers">
              <p class="firsts1">{{ item.bp_type_n }}</p>
              <p class="seconds1">{{ item.bp_name }}</p>
            </div>
            <div class="centers">
              <p class="firsts1">参数项</p>
              <p class="seconds1">{{ item.product_code }}</p>
            </div>
          </div>
        </item>
      </list-item>
</div>
      </scroll>

  </h-view>
</template>

<script>
export default {
  data () {
    return {
      pagenum: 1,
      searchInput: '',
      productList: [],
    }
  },
  created: function () {
  },
  watch: {
    searchInput () {
      let vm = this
      if (vm.timeout) {
        clearTimeout(vm.timeout)
      }
      vm.timeout = setTimeout(() => {
        vm.search()
      }, 1000)
    },
  },
  mounted: function () {

  },
  updated: function () {
  },
  destroyed: function () {
  },
  beforeRouteEnter (to, from, next) {
    next(vm => {
      if (from.name === 'MyInfo') {
        vm.pagenum = 1
        vm.searchInput = ''
      vm.getList()
      } else if (from.name === 'ProDetailed') {
        vm.getList()
      }
    })
  },
  methods: {
    getList () {
      let vm = this
      let url = $config.basePath + 'my_collection_query'
      let param = {
        pagesize: 10,
        pagenum: vm.pagenum,
        searchInput: vm.searchInput,
        user_phone: window.localStorage.getItem('user_phone'),
      }
      hlsPopup.showLoading('数据加载中')
      vm.$post(url, param).then(function (res) {
        hlsPopup.hideLoading()
        if (res.result === 'S') {
          vm.productList = res.lists

          if (vm.productList.length === 0) {
           vm.$refs.scroll.update(true)
         } else if (vm.productList.length > 0 && vm.productList.length < 10) {
           vm.productList.forEach(item => {
             item['url'] = process.env.filePath + 'attachment_id=' + item.product_attachment_id + '&access_token=' + window.localStorage.access_token
           })
           vm.$refs.scroll.update(true)
         } else if (vm.productList.length === 10) {
           vm.productList.forEach(item => {
             item['url'] = process.env.filePath + 'attachment_id=' + item.product_attachment_id + '&access_token=' + window.localStorage.access_token
           })
           vm.$refs.scroll.update(false)
         }
        } else {
          hlsPopup.showLongCenter(res.message)
        }
      })
    },
    loadMore () {
     let vm = this
     vm.pagenum = vm.pagenum + 1
     let url = $config.basePath + 'my_collection_query'
     let param = {
       pagesize: 10,
        pagenum: vm.pagenum,
        searchInput: vm.searchInput,
        user_phone: window.localStorage.getItem('user_phone'),
     }
     vm.hlsPopup.showLoading('数据加载中')
     vm.$post(url, param).then(function (res) {
       vm.hlsPopup.hideLoading()
       let returnData = []
       if (res.result === 'S') {
         returnData = res.lists
         if (returnData.length === 0) {
           vm.$refs.scroll.update(true)
         } else if (returnData.length > 0 && returnData.length < 10) {
           returnData.forEach(item => {
             item['url'] = process.env.filePath + 'attachment_id=' + item.product_attachment_id + '&access_token=' + window.localStorage.access_token
           })
           returnData.forEach((data, index, array) => {
             vm.productList.push(array[index])
           })
           vm.$refs.scroll.update(true)
         } else if (returnData.length === 10) {
           returnData.forEach(item => {
             item['url'] = process.env.filePath + 'attachment_id=' + item.product_attachment_id + '&access_token=' + window.localStorage.access_token
           })
           returnData.forEach((data, index, array) => {
             vm.productList.push(array[index])
           })
           vm.$refs.scroll.update(false)
         }
       } else {
         hlsPopup.showLongCenter(res.message)
       }
     })
   },
   search () {
     let vm = this
     vm.pagenum = 1
     // vm.bpList = []
     let url = $config.basePath + 'my_collection_query'
     let param = {
       pagesize: 10,
       pagenum: 1,
       searchInput: vm.searchInput,
       user_phone: window.localStorage.getItem('user_phone'),
     }
     vm.hlsPopup.showLoading('数据加载中')
     vm.hlsHttp.post(url, param).then(function (res) {
       vm.hlsPopup.hideLoading()
       vm.productList = res.lists
       vm.productList.forEach(item => {
         item['url'] = process.env.filePath + 'attachment_id=' + item.product_attachment_id + '&access_token=' + window.localStorage.access_token
       })
       if (vm.productList.length >= 0 && vm.productList.length < 10) {
         vm.$refs.scroll.update(true)
       } else if (vm.productList.length === 10) {
         vm.$refs.scroll.update(false)
       }
     })
   },
    // val:产品id, status: 收藏状态
    goDetailed (item) { // 进入产品查询功能明细页面
      window.localStorage.setItem('collect_status', item.collect_status)
      this.$router.push({
        name: 'ProDetailed',
        params: {
          product_id: item.product_id,
          bp_id: item.bp_id,
          //  collect_status: status,
        },
      })
    },
  },
}
</script>

<style lang="less" rel="stylesheet">
#my-collect {
  .search {
      background-color: #fff;
      padding: 8px 12px;
      position: absolute;
      width: 100%;
      z-index: 100;
      margin-bottom: 8px;
      input {
        background: url("../../assets/contractStart/search1.png") 320px no-repeat;
        background-size: 16px 16px;
        background-color: rgba(239, 239, 239, 0.55);
        padding-left: 12px;
        border-radius: 4px;
        height: 36px;
        width: 100%;
        font-family: PingFangSC-Regular;
        font-size: 14px;
        color: #888C8F;
        //line-height: 36px;
      }

      input::placeholder {
        font-family: PingFangSC-Regular;
        font-size: 14px;
        color: #888C8F;
        letter-spacing: 0;
      }
      input:focus {
      background: url("../../assets/contractStart/search2.png") 320px no-repeat;
      background-size: 16px 16px;
      background-color: rgba(239, 239, 239, 0.55);
      border: 2px solid #bcc6ff;
    }
      
    }
.division-box {
      padding: 8px;
    }
    .hls-list-item {
      border-radius: 4px;
    }
    .item-pic {
          width: 100px;
          //height: 110px;
          img {
              width: 100%;
              height: 100%;
          }
    }
    .item-content {
          width: 100%;
          margin-left: 20px;
          .pro-name {
            height: 42px;
            width: 100%;
            position: relative;
            border-bottom: 1px solid #F3F3F7;
            .arrow {
              position: absolute;
              width: 10px;
              height: 15px;
              right: 0;
              top: 0px;
            }
            p {
              height: 42px;
              line-height: 42px;
            font-family: PingFangSC-Semibold;
            font-size: 15px;
            color: #4B4A4B;
            letter-spacing: 0;
            font-weight: 600;
            }
          }

          .centers {
              font-family: PingFangSC-Semibold;
              font-size: 13px;
              color: rgba(56,63,69,0.60);
              letter-spacing: 0.5px;
              display: flex;
              flex-direction: row;
              margin-top: 8px;
              .firsts1 {
                  width: 60px;
                  height: 17px;
                  font-family: PingFangSC-Regular;
                  font-size: 13px;
                  color: rgba(56,63,69,0.60);
              }
              .seconds1 {
                  width: 70%;
                  margin-left: 16px;
                  height: auto;
                  font-family: PingFangSC-Regular;
                  font-size: 13px;
                  color: #4B4A4B;
              }
          }
    }
   .content{
    position: absolute;
      top:0;
  } 
  .scrollContent{
     padding-top: 1.9rem;
      padding-bottom: 20px;
    }
}
.platform-ios {
    #my-collect {
      .scrollContent {
        padding-top: 2.3rem;
      }
    }
  }
  // iPhoneX适配
  @media (device-width: 375px) and (device-height: 812px) and (-webkit-min-device-pixel-ratio: 3) {
    .platform-ios {
      #my-collect {
        .scrollContent {
          padding-top: 2.7rem;
        }
      }
    }
  }
  // iPhoneXR适配
  @media (device-width: 414px) and (device-height: 896px) {
    .platform-ios {
      #my-collect {
        .scrollContent {
          padding-top: 3.1rem;
        }
      }
    }
  }
 

</style>