<template>
  <view v-show="!isLoading" class="container">
    <!-- 卡券信息 -->
    <view v-if="!isLoading" class="coupon-info m-top20">
      <!-- 标题、分享 -->
      <view class="info-item info-item__name dis-flex flex-y-center">
        <view class="coupon-name flex-box">
          <text class="twolist-hidden">{{ couponInfo.name }}</text>
        </view>
        <!-- #ifdef MP-WEIXIN -->
        <view class="coupon-share__line"></view>
        <view class="coupon-share">
          <button class="share-btn dis-flex flex-dir-column" open-type="share">
            <text class="share__icon iconfont icon-fenxiang"></text>
            <text class="f-24">分享</text>
          </button>
        </view>
        <!-- #endif -->
      </view>
      <!-- 卡券预存规则 -->
      <view class="store-rule">
          <view class="title">预存规则:</view>
          <view v-for="(item, index) in storeRule" :key="index" class="item">
            <text>预存¥{{ item.store }} 到账 ¥{{ item.upStore }}</text>
          </view>
      </view>
      <view class="info-item">
          <text>已有<text class="number">{{ couponInfo.gotNum }}</text>人预存,剩余<text class="number">{{ couponInfo.limitNum }}</text>名额</text>
      </view>
      <view class="info-item">
          <text>有效期:{{ couponInfo.effectiveDate }}</text>
      </view>
    </view>

    <!-- 选择卡券规格 -->
    <view class="coupon-choice m-top20 b-f" @click="onShowPopup()">
      <view class="spec-list">
        <view class="flex-box">
          <text class="col-8">选择:</text>
          <text class="spec-name" key="index">预存金额、数量</text>
        </view>
        <view class="f-26 col-9 t-r">
          <text class="iconfont icon-xiangyoujiantou"></text>
        </view>
      </view>
    </view>

    <!-- 预存选项弹窗 -->
    <Popup v-if="!isLoading" v-model="showPopup" :couponInfo="couponInfo" :storeRule="storeRule"/>

    <!-- 卡券描述 -->
    <view v-if="!isLoading" class="coupon-content m-top20">
      <view class="item-title b-f">
        <text>卡券描述</text>
      </view>
      <block v-if="couponInfo.description != ''">
        <view class="coupon-content-detail b-f">
          <jyf-parser :html="couponInfo.description"></jyf-parser>
        </view>
      </block>
      <empty v-else tips="亲,暂无卡券描述" />
    </view>

    <!-- 底部选项卡 -->
    <view class="footer-fixed">
      <view class="footer-container">
        <!-- 导航图标 -->
        <view class="foo-item-fast">
          <!-- 客服 (仅微信小程序端显示) -->
          <!-- #ifdef MP-WEIXIN -->
          <button class="btn-normal" open-type="contact">
            <view class="fast-item">
              <view class="fast-icon">
                <text class="iconfont icon-kefu1"></text>
              </view>
              <view class="fast-text">
                <text>客服</text>
              </view>
            </view>
          </button>
          <!-- #endif -->
        </view>
        <!-- 操作按钮 -->
        <view class="foo-item-btn">
          <view class="btn-wrapper">
            <view class="btn-item btn-item-main" @click="onShowPopup()">
              <text>立即预存</text>
            </view>
          </view>
        </view>
      </view>
    </view>
  </view>
</template>

<script>
  import * as CouponApi from '@/api/coupon'
  import jyfParser from '@/components/jyf-parser/jyf-parser'
  import Shortcut from '@/components/shortcut'
  import Popup from './components/Popup'

  export default {
    components: {
      jyfParser,
      Shortcut,
      Popup
    },
    data() {
      return {
        // 正在加载
        isLoading: true,
        // 当前卡券ID
        couponId: null,
        // 卡券详情
        couponInfo: null,
        // 预存规则
        storeRule: [],
        // 显示/隐藏弹窗
        showPopup: false
      }
    },

    /**
     * 生命周期函数--监听页面加载
     */
    onLoad(options) {
      // 卡券ID
      this.couponId = parseInt(options.couponId)
      // 加载页面数据
      this.onRefreshPage()
    },

    methods: {

      // 刷新页面数据
      onRefreshPage() {
        const app = this
        app.isLoading = true
        Promise.all([app.getCouponDetail()])
          .finally(() => app.isLoading = false)
      },

      // 获取卡券信息
      getCouponDetail() {
        const app = this
        return new Promise((resolve, reject) => {
          CouponApi.detail(app.couponId)
            .then(result => {
              app.couponInfo = result.data
              let ruleItem = app.couponInfo.inRule.split(",");
              ruleItem.forEach(function(item) {
                  let rule = item.split("_")
                  app.storeRule.push({"store": rule[0], "upStore": rule[1]})
              })
              resolve(result)
            })
            .catch(err => reject(err))
        })
      },

      /**
       * 显示/隐藏预存弹窗
       */
      onShowPopup() {
        this.showPopup = !this.showPopup
      },

      // 跳转到首页
      onTargetHome(e) {
        this.$navTo('pages/index/index')
      }
      
    },

    /**
     * 分享当前页面
     */
    onShareAppMessage() {
      const app = this
      // 构建页面参数
      const params = app.$getShareUrlParams({
        couponId: app.couponId
      })
      return {
        title: app.couponInfo.name,
        path: `/pages/prestore/buy?${params}`
      }
    },

    /**
     * 分享到朋友圈
     * 本接口为 Beta 版本,暂只在 Android 平台支持,详见分享到朋友圈 (Beta)
     * https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/share-timeline.html
     */
    onShareTimeline() {
      const app = this
      // 构建页面参数
      const params = app.$getShareUrlParams({
        couponId: app.couponId,
      })
      return {
        title: app.couponInfo.name,
        path: `/pages/prestore/buy?${params}`
      }
    }
  }
</script>

<style>
  page {
    background: #fafafa;
  }
</style>
<style lang="scss" scoped>
  @import "./buy.scss";
</style>