pages-goods-index.f17bfe87.js 16 KB

1
  1. import{y as s,c as e,X as t,Y as o,l,m as a,e as d,f as n,w as c,j as i,t as u,u as r,v as f,C as p,k as m,F as g,r as y,B as _,s as k,x as b,i as h,G as I,S as v,E as x,Z as w,D as S,g as C,d as j,o as A,p as V,a0 as M,q as $,a1 as P,a2 as O,a3 as L}from"./index-17c0fdfd.js";import{_ as U}from"./s-empty.f4ef2949.js";import{_ as E}from"./su-swiper.15fca05d.js";import{_ as T}from"./su-number-box.d63d2664.js";import{d as B}from"./form.3c11c8bd.js";import{c as G,f as F,a as D,b as q,d as R}from"./useGoods.fdff7cb3.js";import{_ as z}from"./_plugin-vue_export-helper.1b428a4d.js";import{_ as H}from"./s-coupon-list.eb5a89cf.js";import{R as J}from"./rewardActivity.ad289370.js";import{a as N,S as X,_ as Y}from"./s-layout.7bb6bf02.js";import{F as Z}from"./favorite.6bdb01ba.js";import{d as K,a as Q,_ as W,b as ss,c as es,e as ts}from"./detail-content-card.cb72dfa8.js";import{S as os}from"./spu.2a38165d.js";/* empty css */import"./comment-item.4586829c.js";import"./uni-rate.acdfec84.js";import"./su-image.44cfb09b.js";import"./mp-html.6da0311c.js";const ls=z({__name:"s-select-sku",props:{goodsInfo:{type:Object,default(){}},show:{type:Boolean,default:!1}},emits:["change","addCart","buy","close"],setup(x,{emit:w}){const S=w,C=x,j=s({selectedSku:{},currentPropertyArray:[]}),A=G(C.goodsInfo.skus),V=e((()=>{let s=C.goodsInfo.skus;for(let e of s)e.value_id_array=e.properties.map((s=>s.valueId));return s}));function M(){j.selectedSku.id<=0?k.$helper.toast("请选择规格"):j.selectedSku.stock<=0?k.$helper.toast("库存不足"):S("addCart",j.selectedSku)}function $(){j.selectedSku.id<=0?k.$helper.toast("请选择规格"):j.selectedSku.stock<=0?k.$helper.toast("库存不足"):S("buy",j.selectedSku)}function P(s=!1,e=0,t=0){let o=[];if(s)for(let d of V.value)d.stock<=0||d.value_id_array.indexOf(t)>=0&&o.push(d);else o=O();let l=[];for(let d of o)l=l.concat(d.value_id_array);if(l=Array.from(new Set(l)),s){let s=l.indexOf(t);l.splice(s,1)}else j.currentPropertyArray.forEach((s=>{if(""!==s.toString())return;let e=l.indexOf(s);e>=0&&l.splice(e,1)}));let a=[];s?a=[e]:j.currentPropertyArray.forEach(((s,e)=>{""!==s&&a.push(e)}));for(let d in A)if(!(a.indexOf(A[d].id)>=0))for(let s in A[d].values)A[d].values[s].disabled=l.indexOf(A[d].values[s].id)<0}function O(){let s=[];for(let e of V.value){if(e.stock<=0)continue;let t=!0;j.currentPropertyArray.forEach((s=>{""!==s.toString()&&e.value_id_array.indexOf(s)<0&&(t=!1)})),t&&s.push(e)}return s}function L(s,e){let t=!0;void 0!==j.currentPropertyArray[s]&&j.currentPropertyArray[s]===e?(t=!1,j.currentPropertyArray.splice(s,1,"")):j.currentPropertyArray[s]=e;let o=[];j.currentPropertyArray.forEach((s=>{""!==s&&o.push(s)}));let l=O();o.length===A.length&&l.length?(l[0].goods_num=j.selectedSku.goods_num||1,j.selectedSku=l[0]):j.selectedSku={},P(t,s,e)}return t((()=>j.selectedSku),(s=>{S("change",s)}),{immediate:!0,deep:!0}),P(!1),o((()=>{1==A.length&&1==A[0].values.length&&L(0,0)})),(s,e)=>{const t=b,o=h,k=I,w=l(a("su-number-box"),T),C=v,V=l(a("su-popup"),B);return d(),n(V,{show:x.show,round:"10",onClose:e[3]||(e[3]=s=>S("close"))},{default:c((()=>[i(o,{class:"ss-modal-box bg-white ss-flex-col"},{default:c((()=>[i(o,{class:"modal-header ss-flex ss-col-center"},{default:c((()=>[i(o,{class:"header-left ss-m-r-30"},{default:c((()=>[i(t,{class:"sku-image",src:j.selectedSku.picUrl||x.goodsInfo.picUrl,mode:"aspectFill"},null,8,["src"])])),_:1}),i(o,{class:"header-right ss-flex-col ss-row-between ss-flex-1"},{default:c((()=>[i(o,{class:"goods-title ss-line-2"},{default:c((()=>[u(r(x.goodsInfo.name),1)])),_:1}),i(o,{class:"header-right-bottom ss-flex ss-col-center ss-row-between"},{default:c((()=>[i(o,{class:"ss-flex"},{default:c((()=>[i(o,{class:"price-text"},{default:c((()=>[u(r(f(F)(j.selectedSku.price||x.goodsInfo.price)),1)])),_:1})])),_:1}),i(o,{class:"stock-text ss-m-l-20"},{default:c((()=>[u(r(f(D)("exact",j.selectedSku.stock||x.goodsInfo.stock)),1)])),_:1})])),_:1})])),_:1})])),_:1}),i(o,{class:"modal-content ss-flex-1"},{default:c((()=>[i(C,{"scroll-y":"true",class:"modal-content-scroll",onTouchmove:e[2]||(e[2]=p((()=>{}),["stop"]))},{default:c((()=>[(d(!0),m(g,null,y(f(A),(s=>(d(),n(o,{class:"sku-item ss-m-b-20",key:s.id},{default:c((()=>[i(o,{class:"label-text ss-m-b-20"},{default:c((()=>[u(r(s.name),1)])),_:2},1024),i(o,{class:"ss-flex ss-col-center ss-flex-wrap"},{default:c((()=>[(d(!0),m(g,null,y(s.values,(e=>(d(),n(k,{class:_(["ss-reset-button spec-btn",[{"ui-BG-Main-Gradient":j.currentPropertyArray[s.id]===e.id},{"disabled-btn":!0===e.disabled}]]),key:e.id,disabled:!0===e.disabled,onClick:t=>L(s.id,e.id)},{default:c((()=>[u(r(e.name),1)])),_:2},1032,["class","disabled","onClick"])))),128))])),_:2},1024)])),_:2},1024)))),128)),i(o,{class:"buy-num-box ss-flex ss-col-center ss-row-between ss-m-b-40"},{default:c((()=>[i(o,{class:"label-text"},{default:c((()=>[u("购买数量")])),_:1}),i(w,{min:1,max:j.selectedSku.stock,step:1,modelValue:j.selectedSku.goods_num,"onUpdate:modelValue":e[0]||(e[0]=s=>j.selectedSku.goods_num=s),onChange:e[1]||(e[1]=s=>{var e;0!==(e=s)&&j.selectedSku.goods_num!==e&&(j.selectedSku.goods_num=e)})},null,8,["max","modelValue"])])),_:1})])),_:1})])),_:1}),i(o,{class:"modal-footer border-top"},{default:c((()=>[i(o,{class:"buy-box ss-flex ss-col-center ss-flex ss-col-center ss-row-center"},{default:c((()=>[i(k,{class:"ss-reset-button add-btn ui-Shadow-Main",onClick:M},{default:c((()=>[u("加入购物车")])),_:1}),i(k,{class:"ss-reset-button buy-btn ui-Shadow-Main",onClick:$},{default:c((()=>[u("立即购买")])),_:1})])),_:1})])),_:1})])),_:1})])),_:1},8,["show"])}}},[["__scopeId","data-v-0b7e4c36"]]),as=z({__name:"s-coupon-get",props:{modelValue:{type:Object,default(){}},show:{type:Boolean,default:!1}},emits:["get","close"],setup(t,{emit:o}){const f=t,k=o,b=s({couponInfo:e((()=>f.modelValue))});return(s,e)=>{const o=h,f=I,x=l(a("s-coupon-list"),H),w=v,S=l(a("su-popup"),B);return d(),n(S,{show:t.show,type:"bottom",round:"20",onClose:e[0]||(e[0]=s=>k("close")),showClose:"",backgroundColor:"#f2f2f2"},{default:c((()=>[i(o,{class:"model-box"},{default:c((()=>[i(o,{class:"title ss-m-t-16 ss-m-l-20 ss-flex"},{default:c((()=>[u("优惠券")])),_:1}),i(w,{class:"model-content","scroll-y":"","scroll-with-animation":!1,"enable-back-to-top":!0},{default:c((()=>[i(o,{class:"subtitle ss-m-l-20"},{default:c((()=>[u("可使用优惠券")])),_:1}),(d(!0),m(g,null,y(b.couponInfo,(s=>(d(),n(o,{key:s.id},{default:c((()=>[i(x,{data:s},{default:c((()=>[i(f,{class:_(["ss-reset-button card-btn ss-flex ss-row-center ss-col-center",s.canTake?"":"boder-btn"]),onClick:p((e=>{return t=s.id,void k("get",t);var t}),["stop"]),disabled:!s.canTake},{default:c((()=>[u(r(s.canTake?"立即领取":"已领取"),1)])),_:2},1032,["class","onClick","disabled"])])),_:2},1032,["data"])])),_:2},1024)))),128))])),_:1})])),_:1})])),_:1},8,["show"])}}},[["__scopeId","data-v-3a9aaf40"]]),ds=z({__name:"s-activity-pop",props:{modelValue:{type:Object,default(){}},show:{type:Boolean,default:!1}},emits:["close"],setup(o,{emit:p}){const _=o,b=p,I=s({activityInfo:e((()=>_.modelValue)),activityMap:{}});return t((()=>_.show),(()=>{var s;_.show&&(null==(s=I.activityInfo)||s.forEach((s=>{J.getRewardActivity(s.id).then((e=>{0===e.code&&(I.activityMap[s.id]=e.data)}))})))})),(s,e)=>{const t=h,p=x,_=v,w=l(a("su-popup"),B);return d(),n(w,{show:o.show,type:"bottom",round:"20",onClose:e[0]||(e[0]=s=>b("close")),showClose:""},{default:c((()=>[i(t,{class:"model-box"},{default:c((()=>[i(t,{class:"title ss-m-t-16 ss-m-l-20 ss-flex"},{default:c((()=>[u("营销活动")])),_:1}),i(_,{class:"model-content ss-m-t-50","scroll-y":"","scroll-with-animation":!1,"enable-back-to-top":!0},{default:c((()=>[(d(!0),m(g,null,y(I.activityInfo,(s=>(d(),n(t,{key:s.id},{default:c((()=>[i(t,{class:"ss-flex ss-col-top ss-m-b-40",onClick:e=>{return t=s,void k.$router.go("/pages/activity/index",{activityId:t.id});var t}},{default:c((()=>[i(t,{class:"model-content-tag ss-flex ss-row-center"},{default:c((()=>[u("满减")])),_:1}),i(t,{class:"ss-m-l-20 model-content-title ss-flex-1"},{default:c((()=>{var e;return[(d(!0),m(g,null,y(null==(e=I.activityMap[s.id])?void 0:e.rules,(e=>(d(),n(t,{class:"ss-m-b-24",key:e},{default:c((()=>[u(r(f(q)(I.activityMap[s.id],e)),1)])),_:2},1024)))),128))]})),_:2},1024),i(p,{class:"cicon-forward"})])),_:2},1032,["onClick"])])),_:2},1024)))),128))])),_:1})])),_:1})])),_:1},8,["show"])}}},[["__scopeId","data-v-fdb00d48"]]),ns=s=>w({url:"/promotion/activity/list-by-spu-id",method:"GET",params:{spuId:s}}),cs=z({__name:"detail-activity-tip",props:{activityList:{type:Array,default:()=>[]}},setup(s){S((s=>({52218784:f(e),"932ed426":f(t)})));const e=k.$url.css("/static/images/seckill-tip-bg.png"),t=k.$url.css("/static/images/groupon-tip-bg.png"),o=s;return(s,e)=>{const t=b,p=h,v=I,x=l(a("su-fixed"),N);return d(),n(x,{bottom:"",placeholder:"",val:44},{default:c((()=>[i(p,null,{default:c((()=>[(d(!0),m(g,null,y(o.activityList,(s=>(d(),n(p,{key:s.id},{default:c((()=>[i(p,{class:_(["activity-box ss-p-x-38 ss-flex ss-row-between ss-col-center",1===s.type?"seckill-box":"groupon-box"])},{default:c((()=>[i(p,{class:"activity-title ss-flex"},{default:c((()=>[i(p,{class:"ss-m-r-16"},{default:c((()=>[1===s.type?(d(),n(t,{key:0,src:f(k).$url.static("/static/images/seckill-icon.png"),class:"activity-icon"},null,8,["src"])):3===s.type?(d(),n(t,{key:1,src:f(k).$url.static("/static/images/groupon-icon.png"),class:"activity-icon"},null,8,["src"])):C("",!0)])),_:2},1024),i(p,null,{default:c((()=>[u("该商品正在参与"+r(s.name)+"活动",1)])),_:2},1024)])),_:2},1024),i(v,{class:"ss-reset-button activity-go",onClick:e=>function(s){const e=s.type,t=1===e?"seckill":2===e?"TODO 拼团":"groupon";k.$router.go(`/pages/goods/${t}`,{id:s.id})}(s)},{default:c((()=>[u(" GO ")])),_:2},1032,["onClick"])])),_:2},1032,["class"])])),_:2},1024)))),128))])),_:1})])),_:1})}}},[["__scopeId","data-v-fb4b78d9"]]),is=z({__name:"index",setup(o){j((()=>{}));const p=s({goodsId:0,skeletonLoading:!0,goodsInfo:{},showSelectSku:!1,selectedSku:{},showModel:!1,couponInfo:[],showActivityModel:!1,activityInfo:[],activityList:[],linkId:0});function _(s){p.selectedSku=s}function b(s){s.id?G.value?k.$store("cart").add(s):$():k.$helper.toast("请选择商品规格")}function v(s){p.selectedSku.id?k.$router.go("/pages/order/confirm",{data:JSON.stringify({items:[{skuId:s.id,count:s.goods_num}],deliveryType:1,pointStatus:!1})}):k.$helper.toast("请选择商品规格")}function w(){p.showActivityModel=!0}async function S(s){const{code:e}=await P.takeCoupon(s);0===e&&(O({title:"领取成功"}),setTimeout((()=>{!async function(){const{code:s,data:e}=await P.getCouponTemplateList(p.goodsId,2,10);0===s&&(p.couponInfo=e)}()}),1e3))}const T=e((()=>L.isEmpty(p.goodsInfo)?{}:k.$platform.share.getShareInfo({title:p.goodsInfo.name,image:k.$url.cdn(p.goodsInfo.image),desc:p.goodsInfo.subtitle,params:{page:"2"}},{type:"goods",title:p.goodsInfo.name,introduction:p.goodsInfo.introduction,image:k.$url.cdn(p.goodsInfo.picUrl),price:F(p.goodsInfo.price),original_price:F(p.goodsInfo.maretPrice)})));async function B(s){os.getSpuDetail(s).then((s=>{0===s.code&&s.data?(p.skeletonLoading=!1,p.goodsInfo=s.data,G.value&&Z.isFavoriteExists(p.goodsId,"goods").then((s=>{0===s.code&&(p.goodsInfo.favorite=s.data)}))):p.goodsInfo=null}))}const G=e((()=>k.$store("user").isLogin));return t((()=>G.value),(s=>{s&&B(p.goodsId)})),A((s=>{if(console.log("options.id",s.id,"options.linkId",s.linkId),s.id||s.linkId){if(p.goodsId=s.id||0,!s.id&&s.linkId){console.log("如果只是没有spuId有linkId的话 要去linkId对应的spuId");const e=s.linkId.toString();X.getObjectIdByLinkId(e).then((s=>{0===s.code&&(p.goodsId=s.data,B(p.goodsId),async function(){X.getLinkId(3,p.goodsId).then((s=>{0===s.code&&(p.linkId=s.data.linkId)}))}())})),V("linkId",s.linkId)}else B(p.goodsId);ns(p.goodsId).then((s=>{0===s.code&&s.data.forEach((s=>{[1,2,3].includes(s.type)?p.activityList.push(s):5===s.type?p.activityInfo.push(s):console.log("待实现!优先级不高")}))}))}else p.goodsInfo=null})),(s,e)=>{const t=l(a("s-empty"),U),o=l(a("su-swiper"),E),k=h,j=x,A=l(a("s-select-sku"),ls),V=I,$=l(a("s-coupon-get"),as),P=l(a("s-activity-pop"),ds),O=l(a("s-layout"),Y);return d(),n(k,null,{default:c((()=>[i(O,{onShareAppMessage:T.value,navbar:"goods"},{default:c((()=>[i(K,{modelValue:p.goodsInfo,"onUpdate:modelValue":e[0]||(e[0]=s=>p.goodsInfo=s)},null,8,["modelValue"]),p.skeletonLoading?(d(),n(Q,{key:0})):null===p.goodsInfo?(d(),n(t,{key:1,text:"商品不存在或已下架",icon:"/static/soldout-empty.png",showAction:"",actionText:"再逛逛",actionUrl:"/pages/goods/list"})):(d(),m(g,{key:2},[i(k,{class:"detail-swiper-selector"},{default:c((()=>[i(o,{class:"ss-m-b-14",isPreview:"",list:f(R)(p.goodsInfo.sliderPicUrls),otStyle:"tag",imageMode:"widthFix",dotCur:"bg-mask-40",seizeHeight:750},null,8,["list"]),i(k,{class:"title-card detail-card ss-p-y-40 ss-p-x-20"},{default:c((()=>[i(k,{class:"ss-flex ss-row-between ss-col-center ss-m-b-26"},{default:c((()=>[i(k,{class:"price-box ss-flex ss-col-bottom"},{default:c((()=>[i(k,{class:"price-text ss-m-r-16"},{default:c((()=>[u(r(f(F)(p.selectedSku.price||p.goodsInfo.price)),1)])),_:1}),p.goodsInfo.marketPrice>0?(d(),n(k,{key:0,class:"origin-price-text"},{default:c((()=>[u(r(f(F)(p.selectedSku.marketPrice||p.goodsInfo.marketPrice)),1)])),_:1})):C("",!0)])),_:1}),i(k,{class:"sales-text"})])),_:1}),i(k,{class:"discounts-box ss-flex ss-row-between ss-m-b-28"},{default:c((()=>[M("div",{class:"tag-content"},[i(k,{class:"tag-box ss-flex"},{default:c((()=>[(d(!0),m(g,null,y(p.activityInfo,(s=>(d(),n(k,{class:"tag ss-m-r-10",key:s.id,onClick:w},{default:c((()=>[u(r(s.name),1)])),_:2},1024)))),128))])),_:1})]),p.couponInfo.length?(d(),n(k,{key:0,class:"get-coupon-box ss-flex ss-col-center ss-m-l-20",onClick:e[1]||(e[1]=s=>p.showModel=!0)},{default:c((()=>[i(k,{class:"discounts-title ss-m-r-8"},{default:c((()=>[u("领券")])),_:1}),i(j,{class:"cicon-forward"})])),_:1})):C("",!0)])),_:1}),i(k,{class:"title-text ss-line-2 ss-m-b-6"},{default:c((()=>[u(r(p.goodsInfo.name),1)])),_:1}),i(k,{class:"subtitle-text ss-line-1"},{default:c((()=>[u(r(p.goodsInfo.introduction),1)])),_:1})])),_:1}),i(k,{class:"detail-cell-card detail-card ss-flex-col"},{default:c((()=>[i(W,{modelValue:p.selectedSku.goods_sku_text,"onUpdate:modelValue":e[2]||(e[2]=s=>p.selectedSku.goods_sku_text=s),sku:p.selectedSku,onClick:e[3]||(e[3]=s=>p.showSelectSku=!0)},null,8,["modelValue","sku"])])),_:1}),i(A,{goodsInfo:p.goodsInfo,show:p.showSelectSku,onAddCart:b,onBuy:v,onChange:_,onClose:e[4]||(e[4]=s=>p.showSelectSku=!1)},null,8,["goodsInfo","show"])])),_:1}),i(ss,{class:"detail-comment-selector",goodsId:p.goodsId},null,8,["goodsId"]),i(es,{class:"detail-content-selector",content:p.goodsInfo.description},null,8,["content"]),p.activityList.length>0?(d(),n(cs,{key:0,"activity-list":p.activityList},null,8,["activity-list"])):C("",!0),i(ts,{modelValue:p.goodsInfo,"onUpdate:modelValue":e[7]||(e[7]=s=>p.goodsInfo=s)},{default:c((()=>[p.goodsInfo.stock>0?(d(),n(k,{key:0,class:"buy-box ss-flex ss-col-center ss-p-r-20"},{default:c((()=>[i(V,{class:"ss-reset-button add-btn ui-Shadow-Main",onClick:e[5]||(e[5]=s=>p.showSelectSku=!0)},{default:c((()=>[u(" 加入购物车 ")])),_:1}),i(V,{class:"ss-reset-button buy-btn ui-Shadow-Main",onClick:e[6]||(e[6]=s=>p.showSelectSku=!0)},{default:c((()=>[u(" 立即购买 ")])),_:1})])),_:1})):(d(),n(k,{key:1,class:"buy-box ss-flex ss-col-center ss-p-r-20"},{default:c((()=>[i(V,{class:"ss-reset-button disabled-btn",disabled:""},{default:c((()=>[u(" 已售罄 ")])),_:1})])),_:1}))])),_:1},8,["modelValue"]),i($,{modelValue:p.couponInfo,"onUpdate:modelValue":e[8]||(e[8]=s=>p.couponInfo=s),show:p.showModel,onClose:e[9]||(e[9]=s=>p.showModel=!1),onGet:S},null,8,["modelValue","show"]),i(P,{modelValue:p.activityInfo,"onUpdate:modelValue":e[10]||(e[10]=s=>p.activityInfo=s),show:p.showActivityModel,onClose:e[11]||(e[11]=s=>p.showActivityModel=!1)},null,8,["modelValue","show"])],64))])),_:1},8,["onShareAppMessage"])])),_:1})}}},[["__scopeId","data-v-58d0567d"]]);export{is as default};