detail.html 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. {extend name="public/container"}{block name="head_top"}
  2. <link rel="stylesheet" href="{__PLUG_PATH}swiper/swiper-3.4.1.min.css">
  3. <script type="text/javascript" src="{__PLUG_PATH}swiper/swiper-3.4.1.jquery.min.js"></script>
  4. <script type="text/javascript"
  5. src="{__WAP_PATH}crmeb/js/car-model.js"></script>{/block}{block name="title"}{$storeInfo.store_name}{/block}{block name="content"}
  6. <div id="store_detail" class="wrapper product-con">
  7. <section>
  8. <div class="banner">
  9. <ul class="swiper-wrapper"> {volist name="storeInfo.slider_image" id="vo"}
  10. <li class="swiper-slide"><img src="{$vo}"/></li>
  11. {/volist}
  12. </ul>
  13. </div>
  14. <div class="product-info">
  15. <div class="title">{$storeInfo.store_name}</div>
  16. <div class="price">¥{$minprice|floatval}</div>
  17. <div class="oldprice">原价:¥{$storeInfo.ot_price|floatval}</div>
  18. <div class="info-amount flex"><span class="current">商品编号:{$storeInfo.id}</span> <span class="">库存:{$storeInfo.stock}{$storeInfo.unit_name}</span>
  19. <span class="fr">销量:{$storeInfo.sales}{$storeInfo.unit_name}</span></div>
  20. {gt name="storeInfo['give_integral']" value="0"}
  21. <div class="integral">积分:{$storeInfo.give_integral|floatval} <span>赠送</span></div>
  22. {/gt}
  23. </div>
  24. <div class="like-it" v-cloak=""><i class="zan-btn iconfont icon-thumbsup"
  25. :class="{'icon-thumbsup110':product.userLike == true}" @click="like"></i> 点赞
  26. <span v-text="product.like_num"></span>次
  27. </div>
  28. <div class="pro-attributes" @click="cardUp" v-show="productAttr && productAttr.length > 0" v-cloak="">选择
  29. {{productAttrCate}}
  30. </div>
  31. {notempty name="reply"}
  32. <div class="item-box">
  33. <div class="item-tit"><i class="line"></i><i class="iconfont icon-pinglun1"></i><span>评价</span><i
  34. class="line"></i></div>
  35. <div class="assess-hot"><p class="title">宝贝评价({$replyCount})</p>
  36. <div class="assess-hot-con">
  37. <div class="user-info flex">
  38. <div class="avatar"><img src="{$reply.avatar}"/></div>
  39. <div class="name">{$reply.nickname}</div>
  40. <div class="star{$reply.star} all"><span class="num"></span></div>
  41. </div>
  42. <div class="txt-info">{$reply.comment}</div>
  43. <div class="pro-parameter"><span>{$reply.add_time}</span> <span>{$reply.suk}</span></div>
  44. {gt name="replyCount" value="1"} <a class="more"
  45. href="{:url('reply_list',['productId'=>$storeInfo['id']])}">查看全部评价</a>
  46. {/gt}
  47. </div>
  48. </div>
  49. </div>
  50. {/notempty}
  51. <div class="item-box">
  52. <div class="item-tit"><i class="line"></i><i class="iconfont icon-icon-tupian"></i><span>详情</span><i
  53. class="line"></i></div>
  54. <div class="con-box" ref="store_desc"></div>
  55. </div>
  56. <div class="footer-bar flex"><a href="{:Url('Service/service_list',array('mer_id'=>$mer_id))}"> <span
  57. class="iconfont icon-kefu"></span>
  58. <p>客服</p></a> <a class="collect-btn iconfont icon-xing1"
  59. :class="{'icon-xing2':product.userCollect == true}" @click="collect"
  60. href="javascript:void(0)"><p>收藏</p></a> <a href="{:Url('store/cart')}"> <span
  61. class="iconfont icon-icon-shoppingcart-02"></span>
  62. <p>购物车</p> <span class="cart_num" v-show="cartNum > 0" v-cloak=""
  63. v-text="cartNum"></span> </a>
  64. <div class="big-btn buy-car" @click="cardUp">加入购物车</div>
  65. <div class="big-btn confirm" @click="cardUp">立即购买</div>
  66. </div>
  67. </section>
  68. {notempty name="similarity"}
  69. <section class="template-piclist">
  70. <div class="template-prolist">
  71. <div class="title-like flex"><span class="title-line left"></span> <span class="icon"></span> <span>新品推荐</span> <span class="title-line right"></span></div>
  72. </div>
  73. <ul class="flex"> {volist name="similarity" id="store"}
  74. <li><a href="{:url('store/detail',array('id'=>$store['id']))}">
  75. <div class="picture"><img src="{$store.image}"/></div>
  76. <div class="pro-info"><p class="title">{$store.store_name}</p>
  77. <p class="conut">已售{$store.sales}</p>
  78. <p class="price">¥{$store.price|floatval}</p></div>
  79. <div class="buy-car-btn"><i class="iconfont icon-gouwuche"></i></div>
  80. </a></li>
  81. {/volist}
  82. </ul>
  83. </section>
  84. {/notempty}
  85. <shop-card ref="shopCard" :show="cardShow" :product="productCardInfo" :attr-list="productAttr"
  86. :on-change="changeAttr" :on-close="cardClose" :on-cart="goCart" :on-buy="goBuy"></shop-card>
  87. <script ref="store_desc_temp" type="text/template">{$storeInfo.description}</script>
  88. <div style="height:1rem;"></div>
  89. </div>
  90. <script> window.$product = <?php unset($storeInfo['description']); echo json_encode($storeInfo);?>;
  91. window.$productAttr = <?php echo json_encode($productAttr) ?: '[]'; ?>;
  92. window.$productValue = <?php echo json_encode($productValue) ?: '{}'; ?>;</script>
  93. <script
  94. type="text/javascript"> requirejs(['vue', 'axios', 'helper', 'store', 'wap/crmeb/module/store/shop-card'], function (Vue, axios, $h, storeApi, shopCard) {
  95. new Vue({
  96. el: "#store_detail",
  97. components: {'shop-card': shopCard},
  98. data: {
  99. cardShow: false,
  100. product: $product,
  101. productAttr: $productAttr || [],
  102. productValue: $productValue || {},
  103. productCardInfo: {},
  104. status: {like: false, collect: false},
  105. cartNum: 0
  106. },
  107. computed: {
  108. productAttrCate: function () {
  109. return this.productAttr.map(function (attr) {
  110. return attr.attr_name;
  111. }).join(',');
  112. }
  113. },
  114. methods: {
  115. cardClose: function () {
  116. this.cardShow = false;
  117. }, cardUp: function () {
  118. this.cardShow = true;
  119. }, goCart: function (values, cartNum) {
  120. var checkedAttr = this.productValue[values.sort().join(',')], that = this;
  121. storeApi.setCart({
  122. cartNum: cartNum,
  123. uniqueId: checkedAttr === undefined ? 0 : checkedAttr.unique,
  124. productId: this.product.id
  125. }, function () {
  126. that.getCartNum();
  127. $h.pushMsg('加入购物车成功!');
  128. });
  129. that.cardClose();
  130. }, goBuy: function (values, cartNum) {
  131. var checkedAttr = this.productValue[values.sort().join(',')];
  132. storeApi.goBuy({
  133. cartNum: cartNum,
  134. uniqueId: checkedAttr === undefined ? 0 : checkedAttr.unique,
  135. productId: this.product.id
  136. }, function (cartId) {
  137. location.href = $h.U({c: 'store', a: 'confirm_order', p: {cartId: cartId}});
  138. });
  139. this.cardClose();
  140. }, changeAttr: function (values) {
  141. var checkedAttr = this.productValue[values.sort().join(',')];
  142. if (!checkedAttr) {
  143. this.setProductCardInfo({stock: 0});
  144. } else {
  145. this.setProductCardInfo({
  146. stock: checkedAttr.stock,
  147. price: checkedAttr.price,
  148. image: checkedAttr.image
  149. });
  150. }
  151. }, setProductCardInfo: function (info) {
  152. info || (info = {});
  153. this.$set(this, 'productCardInfo', {
  154. image: info.image !== undefined ? info.image : this.product.image,
  155. price: info.price !== undefined ? info.price : this.product.price,
  156. stock: info.stock !== undefined ? info.stock : this.product.stock
  157. });
  158. }, like: function () {
  159. var that = this;
  160. if (that.status.like) return false;
  161. that.status.like = true;
  162. if (this.product.userLike) {
  163. storeApi.unlikeProduct(this.product.id, 'product', function () {
  164. setTimeout(function () {
  165. that.product.like_num -= 1;
  166. that.product.userLike = false;
  167. that.status.like = false;
  168. }, 300);
  169. }, function (err) {
  170. that.status.like = false;
  171. });
  172. } else {
  173. storeApi.likeProduct(this.product.id, 'product', function () {
  174. setTimeout(function () {
  175. that.product.like_num += 1;
  176. that.product.userLike = true;
  177. that.status.like = false;
  178. }, 300);
  179. }, function (err) {
  180. that.status.like = false;
  181. });
  182. }
  183. }, collect: function () {
  184. var that = this;
  185. if (that.status.collect) return false;
  186. that.status.collect = true;
  187. if (this.product.userCollect) {
  188. storeApi.unCollectProduct(this.product.id, 'product', function () {
  189. setTimeout(function () {
  190. that.product.userCollect = false;
  191. that.status.collect = false;
  192. }, 300);
  193. }, function (err) {
  194. that.status.collect = false;
  195. });
  196. } else {
  197. storeApi.collectProduct(this.product.id, 'product', function () {
  198. setTimeout(function () {
  199. that.product.userCollect = true;
  200. that.status.collect = false;
  201. }, 300);
  202. }, function (err) {
  203. that.status.collect = false;
  204. });
  205. }
  206. }, pushMsg: function (msg, fn) {
  207. $h.pushMsg(msg, fn)
  208. }, init: function () {
  209. new Swiper('.banner', {
  210. paginationClickable: false,
  211. autoplay: 3000,
  212. loop: false,
  213. speed: 1000,
  214. autoplayDisableOnInteraction: false,
  215. pagination: '.swiper-pagination',
  216. });
  217. }, getCartNum: function () {
  218. var that = this;
  219. storeApi.getCartNum(function (cartNum) {
  220. that.cartNum = cartNum;
  221. });
  222. }
  223. },
  224. mounted: function () {
  225. var wxApi = mapleWx($jssdk(), function () {
  226. this.onMenuShareAll({
  227. title: $product.store_name,
  228. desc: $product.store_info || $product.store_name,
  229. imgUrl: location.origin + $product.image,
  230. link: location.href
  231. });
  232. });
  233. this.$nextTick(function () {
  234. this.$refs.store_desc.innerHTML = this.$refs.store_desc_temp.innerHTML;
  235. });
  236. this.getCartNum();
  237. this.init();
  238. this.setProductCardInfo();
  239. }
  240. });
  241. });</script>{/block}