| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680 |
- <template>
- <view class="product-con">
- <!-- <up-navbar
- class="goods-nav-bar"
- :bgColor="`rgba(255, 255, 255, ${opacity})`"
- >
- <template #left>
- <view class="nav-slot">
- <up-icon @click="goBack" name="arrow-left" size="19"></up-icon>
- <up-line
- direction="column"
- :hairline="false"
- length="16"
- margin="0 8px"
- ></up-line>
- <up-icon @click="goHome" name="home" size="20"></up-icon>
- </view>
- </template>
- </up-navbar> -->
- <!-- <view class='iconfont icon-xiangzuo' :style="'top:'+navH/2+'rpx'" @tap='returns'></view> -->
- <view>
- <scroll-view :scroll-top="scrollTop" scroll-y="true" scroll-with-animation="true"
- :style="'height:' + height + 'px;'" @scroll="handleScroll">
- <view id="past0">
- <product-con-swiper :indicator-dots="false" :imgUrls="sliderImage">
- </product-con-swiper>
- <!-- <image :src="sliderImage" class="goodImg"></image> -->
- <view class="pad30">
- <view class="wrapper mb30 borRadius14">
- <view class="introduce">{{ productInfo.storeName }}</view>
- <view class="label acea-row row-between-wrapper">
- <view>工费: {{ attr.productSelect.price || 0 }}元/克</view>
- <view>重量: {{ attr.productSelect.weight }}克</view>
- <view>
- 销量:{{ Number(attr.productSelect?.sales || 0)
- }}{{ productInfo.unitName || "" }}
- </view>
- </view>
- <view class="share acea-row row-between row-bottom">
- <view class="money font-color">
- ¥
- <text class="num">{{ attr.productSelect.storePrice }}</text>
- <!-- <text
- class="vip-money"
- v-if="productInfo.vipPrice && productInfo.vipPrice > 0"
- >¥{{ productInfo.vipPrice }}</text
- > -->
- <!-- <image
- v-if="productInfo.vipPrice && productInfo.vipPrice > 0"
- src="/static/images/vip.png"
- ></image> -->
- </view>
- </view>
- <!-- <view class='coupon acea-row row-between-wrapper' v-if="productInfo.give_integral > 0">
- <view class='hide line1 acea-row'>
- 赠积分:
- <view class='activity'>赠送 {{productInfo.give_integral}} 积分</view>
- </view>
- </view> -->
- <view v-if="coupon.list.length > 0 " class="coupon acea-row row-between-wrapper"
- @click="handleCoupon">
- <view class="hide line1 acea-row">
- 优惠券:
- <view class="activity">
- 满{{ coupon.list[0].minPrice }}减{{
- coupon.list[0].money
- }}</view>
- </view>
- <view class="iconfont icon-jiantou"></view>
- </view>
- </view>
- <view class="attribute acea-row row-between-wrapper mb30 borRadius14" @click="selecAttr">
- <view class="line1">{{ attrTxt }}:
- <text class="atterTxt">{{ attrValue }}</text>
- </view>
- <view class="iconfont icon-jiantou"></view>
- </view>
- <view class="row-block mb30 borRadius14">
- <view class="row-express">
- <view class="left-box">
- <uni-icons class="icon" type="cart" size="24"></uni-icons>
- <text class="text">48小时送达</text>
- </view>
- <view class="express-price">
- <text class="express-place">广东深圳</text>
- <!-- <up-line
- color="#ccc"
- direction="column"
- :hairline="false"
- length="14px"
- margin="0 8px"
- ></up-line> -->
- <!-- <text class="express-place">快递费:8元</text> -->
- </view>
- </view>
- <up-line color="#ccc" length="100%" margin="10px 0"></up-line>
- <view class="tip-text">
- <uni-icons size="24" type="hand-up"></uni-icons>
- <view class="text">
- <text class="t1">买的放心,用的称心</text>
- <text class="t2">平台有保障</text>
- </view>
- </view>
- </view>
- </view>
- </view>
- </scroll-view>
- </view>
- <view class="footer acea-row row-between-wrapper">
- <view class="toAPP">
- <wx-open-launch-app id="launch-btn" appid="wx5f33a4ace799b661"
- :extinfo="'pages/goods_details/index?articleId='+articleId" @error="goShuiBei">
- <component :is="'script'" v-bind="{type:'text/wxtag-template'}">
- <button class="storeAPP" style="background-color: #e9c279;
- color: #fff;
- border-radius: 50rpx;
- line-height:100rpx;
- padding: 20rpx 20rpx;
- z-index: 999;box-sizing: border-box;">
- 打开水贝商城
- </button>
- </component>
- </wx-open-launch-app>
- <!-- <button type="default" class="storeAPP" @click="goShuiBei">
- <image src="/static/images/logo_person.png" mode="" class="logoimg"></image>
- 打开水贝商城
- </button> -->
- </view>
- <navigator open-type="switchTab" class="animated item bounceIn" hover-class="none">
- <uni-icons size="22" color="#666" customPrefix="iconfont" type="icon-shouye"></uni-icons>
- <view>首页</view>
- </navigator>
- <button @click="toMessagePage" open-type="contact" hover-class="none" class="item">
- <uni-icons size="22" color="#666" customPrefix="iconfont" type="icon-kefu1"></uni-icons>
- <view>客服</view>
- </button>
- <view class="animated item bounceIn" hover-class="none" @click="toShopCart">
- <uni-icons size="22" color="#666" customPrefix="iconfont" type="icon-gouwuche" class="icon-item">
- </uni-icons>
- <!-- <view class="iconfont icon-gouwuche1">
- <text v-if="Math.floor(CartCount) > 0" class="num bg-color">{{
- CartCount
- }}</text>
- </view> -->
- <view>购物车</view>
- </view>
- <view class="bnt acea-row">
- <form report-submit="true">
- <button class="joinCart bnts" form-type="submit">加入购物车</button>
- </form>
- <form report-submit="true">
- <button class="buy bnts" form-type="submit">立即购买</button>
- </form>
- </view>
- <!-- <view
- class="bnt bntVideo acea-row"
- v-if="attr.productSelect.stock <= 0 && type === 'video'"
- >
- <form report-submit="true">
- <button class="buy bnts bg-color-hui" form-type="submit">
- 已售罄
- </button>
- </form>
- </view>
- <view
- class="bnt bntVideo acea-row"
- v-if="attr.productSelect.stock > 0 && type === 'video'"
- >
- <form @submit="goBuy" report-submit="true">
- <button class="buy bnts" form-type="submit">立即购买</button>
- </form>
- </view> -->
- </view>
- <!-- 组件 -->
- <productWindow :attr="attr" :isShow="1" :iSplus="1" :showPopup="showProductPopup" id="product-window">
- </productWindow>
- <couponListWindow :coupon="coupon" :showPopup="showCouponPopup"></couponListWindow>
- </view>
- </template>
- <script setup>
- import {
- onReady,
- onLoad,
- onShow
- } from "@dcloudio/uni-app";
- import {
- ref,
- computed,
- watch,
- getCurrentInstance,
- toRaw
- } from "vue";
- import {
- useToast
- } from "@/hooks/useToast";
- import wx from 'weixin-js-sdk'
- // import { useAppStore } from "@/stores/app.js";
- // import uQRCode from '@/js_sdk/Sansnn-uQRCode/uqrcode.js';
- // import UQRCode from "uqrcodejs";
- // import { getProductDetail, postCartAdd } from "@/api/store.js";
- // import { spread } from "@/api/user";
- // import { getCoupons, getQrcode } from "@/api/api.js";
- // import { getCartCounts } from "@/api/order.js";
- // import { toLogin } from "@/libs/login.js";
- // import { imageBase64 } from "@/api/public";
- import wechat from "@/libs/wechat.js";
- // import { getPreOrder } from "@/libs/order";
- import productConSwiper from "@/components/productConSwiper";
- import couponListWindow from "@/components/couponListWindow";
- import productWindow from "@/components/productWindow";
- import {
- getArticleDetailId,
- getGoodDetailId,
- getWechatConfig
- } from "@/api/index.js"
- const {
- Toast
- } = useToast();
- // const app = getApp();
- const instance = getCurrentInstance();
- // const appStore = useAppStore();
- // const isLogin = computed(() => appStore.isLogin);
- // const uid = computed(() => appStore.uid);
- const initwxlaunch = () => {
- getWechatConfig(encodeURIComponent(location.href.split('#')[0])).then(res => {
- wx.config({
- debug: res.data
- .debug, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
- appId: res.data.appId, // 必填,公众号的唯一标识
- timestamp: res.data.timestamp, // 必填,生成签名的时间戳
- nonceStr: res.data.nonceStr, // 必填,生成签名的随机串
- signature: res.data.signature, // 必填,签名,// 必填,签名
- jsApiList: ['wx-open-subscribe',
- 'wx-open-launch-app'
- ], // 必填,需要使用的JS接口列表,这个地方必须至少写一个,即使你一个都不想用'updateTimelineShareData',
- openTagList: ['wx-open-subscribe', 'wx-open-launch-app']
- // 可选,需要使用的开放标签列表
- });
- wx.checkJsApi({
- jsApiList: ['wx-open-launch-app'], // 校验跳转APP的标签是否可用
- success: function(res) {
- console.log('可用')
- },
- fail: (err) => {
- console.log(err, '不可用')
- }
- })
- })
- }
- initwxlaunch()
- const coupon = ref({
- coupon: false,
- type: 1,
- list: [],
- count: [],
- });
- const attrTxt = ref("请选择");
- const attrValue = ref("");
- const animated = ref(false);
- const id = ref(0);
- const productInfo = ref({});
- const productValue = ref([]);
- const couponList = ref([]);
- const cart_num = ref(1);
- const isOpen = ref(false);
- const storeImage = ref("");
- const PromotionCode = ref("");
- const posterbackgd = ref("/static/images/posterbackgd.png");
- const sharePacket = ref({
- isState: true
- });
- const clientHeight = ref("");
- const good_list = ref([]);
- const CartCount = ref(0);
- const posters = ref(false);
- const attr = ref({
- cartAttr: false,
- productAttr: [],
- productSelect: {},
- });
- const description = ref("");
- const navActive = ref(0);
- const activityH5 = ref([]);
- const retunTop = ref(true);
- const navH = ref("");
- const opacity = ref(0);
- const scrollY = ref(0);
- const topArr = ref([]);
- const height = ref(0);
- const heightArr = ref([]);
- const lock = ref(false);
- const scrollTop = ref(0);
- const sliderImage = ref([]);
- const canvasStatus = ref(false);
- const imagePath = ref("");
- const imgTop = ref("");
- const errT = ref("");
- const homeTop = ref(20);
- const userCollect = ref(false);
- const returnShow = ref(true);
- const type = ref("");
- const showProductPopup = ref(false); // 商品规格弹窗
- const showCouponPopup = ref(false); // 优惠券弹窗
- const handleBtnTpe = ref(""); // "buy" or "cart"
- const goShuiBei = () => {
- let url = `shuibei://`
- let errUrl = "https://a.app.qq.com/o/simple.jsp?pkgname=uni.app.UNI9DE338F"
- window.location.href = url;
- setTimeout(() => {
- window.location.href = errUrl;
- }, 3000);
- }
- const onListenLaunchError = () => {
- let errUrl = "https://a.app.qq.com/o/simple.jsp?pkgname=uni.app.UNI9DE338F"
- }
- // watch(
- // isLogin,
- // (newV) => {
- // if (newV) {
- // getCouponList();
- // getCartCount();
- // }
- // },
- // { deep: true }
- // );
- const articleId = ref()
- onLoad((options) => {
- const pages = getCurrentPages();
- returnShow.value = pages.length > 1;
- retunTop.value = pages.length > 1;
- // navH.value = app.globalData.navHeight;
- // #ifdef MP || APP-PLUS
- setTimeout(() => {
- if (options.spread) {
- // app.globalData.spread = options.spread;
- spread(options.spread).catch(() => {});
- }
- }, 2000);
- // #endif
- uni.getSystemInfo({
- success(res) {
- height.value = res.windowHeight;
- },
- });
- // if (!options.scene && !options.id) {
- // Toast({ title: "缺少参数无法查看商品", icon: "none" });
- // uni.navigateTo({ url: "/pages/mall/index" });
- // return;
- // }
- if (options.articleId || options.scene) {
- if (options.scene) {
- const qrCodeValue = $util.getUrlParams(decodeURIComponent(options.scene));
- const mapeMpQrCodeValue = $util.formatMpQrCodeData(qrCodeValue);
- // app.globalData.spread = mapeMpQrCodeValue.spread;
- id.value = mapeMpQrCodeValue.id;
- setTimeout(() => {
- spread(mapeMpQrCodeValue.spread).catch(() => {});
- }, 2000);
- } else {
- id.value = options.id;
- }
- type.value = options.type ?? "normal";
- // appStore.$patch({ productType: type.value });
- }
- articleId.value = options.articleId
- getGoodsDetails(options.articleId);
- // getCouponList();
- });
- onShow(() => {
- getCartCount();
- })
- onReady(() => {
- // #ifdef MP
- const menuButton = uni.getMenuButtonBoundingClientRect();
- const query = uni.createSelectorQuery().in(this);
- query
- .select("#home")
- .boundingClientRect((data) => {
- homeTop.value = menuButton.top * 2 + menuButton.height - data.height;
- })
- .exec();
- // #endif
- });
- const iptCartNum = (e) => {
- attr.value.productSelect.cart_num = e || 1;
- };
- const handleScroll = (e) => {
- const scrollYVal = e.detail.scrollTop;
- const opacityVal = scrollYVal / 350 > 1 ? 1 : scrollYVal / 350;
- opacity.value = opacityVal;
- scrollY.value = scrollYVal;
- if (lock.value) {
- lock.value = false;
- return;
- }
- // for (let i = 0; i < topArr.value.length; i++) {
- // if (
- // scrollYVal <
- // topArr.value[i] - app.globalData.navHeight / 2 + heightArr.value[i]
- // ) {
- // navActive.value = i;
- // break;
- // }
- // }
- };
- const closeCouponPopup = () => {
- showCouponPopup.value = false;
- // coupon.value.coupon = false;
- };
- const ChangeCartNum = (changeValue) => {
- console.log("changeValue", changeValue);
- let productSelect =
- productValue.value[attrValue.value] ||
- (attr.value.productAttr.length ? undefined : attr.value.productSelect);
- if (!productSelect) return;
- const stock = productSelect.stock || 0;
- let num = attr.value.productSelect;
- num.cart_num = changeValue ?
- Math.min(num.cart_num + 1, stock) :
- Math.max(num.cart_num - 1, 1);
- attr.value.productSelect.cart_num = num.cart_num;
- cart_num.value = num.cart_num;
- };
- const attrVal = (val) => {
- attr.value.productAttr[val.indexw].index =
- attr.value.productAttr[val.indexw].attrValues[val.indexn];
- };
- const ChangeAttr = (res) => {
- const productSelect = productValue.value[res];
- if (productSelect) {
- attr.value.productSelect = {
- ...attr.value.productSelect,
- image: productSelect.image,
- sales: productSelect.sales,
- weight: productSelect.weight,
- price: productSelect.price,
- storePrice: productSelect.storePrice,
- stock: productSelect.stock,
- unique: productSelect.id,
- cart_num: 1,
- };
- attrValue.value = res;
- attrTxt.value = "已选择";
- } else {
- attr.value.productSelect = {
- ...attr.value.productSelect,
- image: productInfo.value.image,
- weight: productSelect.weight,
- price: productInfo.value.price,
- storePrice: productSelect.storePrice,
- stock: 0,
- unique: productInfo.value.id,
- cart_num: 1,
- };
- attrValue.value = "";
- attrTxt.value = "请选择";
- }
- };
- const ChangCoupons = (coupon) => {
- couponList.value = couponList.value.filter((item) => item.id !== coupon.id);
- getCouponList();
- };
- const setClientHeight = () => {
- if (!good_list.value.length) return;
- const query = uni.createSelectorQuery().in(instance.proxy);
- query
- .select("#list0")
- .fields({
- size: true
- }, (data) => {
- clientHeight.value = data.height + 20;
- })
- .exec();
- };
- const getGoodsDetails = async (id) => {
- try {
- const res = await getArticleDetailId(id);
- const product = res.data.productInfo;
- sliderImage.value = [product.image];
- console.log("sliderImage.value", sliderImage.value);
- productInfo.value = product;
- console.log("productInfo.value", productInfo.value);
- description.value = product.content;
- console.log("description.value", description.value);
- userCollect.value = res.data.userCollect;
- attr.value.productAttr = res.data.productAttr;
- console.log('res.data.productValue', res.data)
- productValue.value = res.data.productValue;
- sharePacket.value.priceName = res.data.priceName;
- sharePacket.value.isState = Math.floor(res.data.priceName) !== 0;
- activityH5.value = res.data.activityAllH5 || [];
- uni.setNavigationBarTitle({
- title: product.storeName.substring(0, 7) + "...",
- });
- attr.value.productAttr = attr.value.productAttr.map((item) => ({
- attrName: item.attrName,
- attrValues: item.attrValues.split(","),
- id: item.id,
- isDel: item.isDel,
- productId: item.productId,
- type: item.type,
- }));
- // if (isLogin.value) {
- // // #ifdef H5
- // // make(uid.value);
- // ShareInfo();
- // getImageBase64(productInfo.value.image);
- // // #endif
- // // #ifdef MP
- // getQrcodeFn();
- // // #endif
- // }
- // nextTick(() => {
- // infoScroll();
- // });
- // #ifdef MP
- imgTop.value = productInfo.value.image;
- // #endif
- // #ifndef H5
- downloadFilestoreImage();
- // #endif
- DefaultSelect();
- } catch (err) {
- Toast({
- title: err.toString(),
- icon: "none"
- });
- // uni.navigateBack();
- }
- };
- // const infoScroll = () => {
- // for (let i = 0; i < navList.value.length; i++) {
- // const query = uni.createSelectorQuery().in(this);
- // const idView = `#past${i}`;
- // query
- // .select(idView)
- // .boundingClientRect()
- // .exec((res) => {
- // const top = res[0].top;
- // const height = res[0].height;
- // topArr.value = [...topArr.value, top];
- // heightArr.value = [...heightArr.value, height];
- // });
- // }
- // };
- const DefaultSelect = () => {
- let value = [];
- console.log('productValue.value', toRaw(productValue.value))
- const keys = Object.keys(productValue.value);
- console.log('keys', keys)
- for (let i = 0; i < keys.length; i++) {
- const key = keys[i];
- console.log('key', key)
- // if (productValue.value[key].stock > 0) {
- value = attr.value.productAttr.length ? key.split(",") : [];
- // break;
- // }
- }
- console.log('value', value)
- attr.value.productAttr.forEach((item, i) => {
- item.index = value[i];
- });
- const productSelect = productValue.value[value.join(",")];
- console.log({
- productSelect
- });
- console.log({
- attr
- });
- if (productSelect && attr.value.productAttr.length) {
- attr.value.productSelect = {
- ...attr.value.productSelect,
- storeName: productInfo.value.storeName,
- image: productSelect.image,
- sales: productSelect.sales,
- weight: productSelect.weight,
- price: productSelect.price,
- storePrice: productSelect.storePrice,
- stock: productSelect.stock,
- unique: productSelect.id,
- cart_num: 1,
- };
- attrValue.value = value.join(",");
- attrTxt.value = "已选择";
- } else if (!productSelect && attr.value.productAttr.length) {
- attr.value.productSelect = {
- ...attr.value.productSelect,
- storeName: productInfo.value.storeName,
- image: productInfo.value.image,
- sales: productSelect.sales,
- weight: productSelect.weight,
- price: productInfo.value.price,
- storePrice: productSelect.storePrice,
- stock: 0,
- unique: productInfo.value.id,
- cart_num: 1,
- };
- attrValue.value = "";
- attrTxt.value = "请选择";
- } else if (!productSelect && !attr.value.productAttr.length) {
- attr.value.productSelect = {
- ...attr.value.productSelect,
- storeName: productInfo.value.storeName,
- image: productInfo.value.image,
- sales: productSelect.sales,
- weight: productSelect.weight,
- price: productInfo.value.price,
- storePrice: productSelect.storePrice,
- stock: productInfo.value.stock,
- unique: productInfo.value.id || "",
- cart_num: 1,
- };
- attrValue.value = "";
- attrTxt.value = "请选择";
- }
- };
- const getCouponList = async (type = "") => {
- try {
- const obj = {
- page: 1,
- limit: 20,
- productId: id.value,
- type
- };
- const {
- data
- } = await getCoupons(obj);
- coupon.value.list = data;
- } catch (err) {
- console.error('getCouponList', err);
- }
- };
- const tabCouponType = (type) => {
- coupon.value.type = type;
- getCouponList(type);
- };
- const ChangCouponsUseState = (index) => {
- coupon.value.list[index].isUse = true;
- coupon.value.coupon = false;
- };
- const selecAttr = () => {
- // attr.value.cartAttr = true;
- // isOpen.value = true;
- showProductPopup.value = true;
- handleBtnTpe.value = "buy";
- };
- // 购买/加入购物车 提交事件
- const handleSubmit = async () => {
- // if (!isLogin.value) {
- // return toLogin();
- // }
- const productSelect = productValue.value[attrValue.value];
- // if (attrValue.value) {
- // attr.value.cartAttr = isOpen.value ? attr.value.cartAttr : true;
- // } else {
- // attr.value.cartAttr = isOpen.value ? true : !attr.value.cartAttr;
- // }
- // if (attr.value.cartAttr && !isOpen.value) {
- // isOpen.value = true;
- // return;
- // }
- if (
- attr.value.productAttr.length &&
- productSelect?.stock === 0 &&
- isOpen.value
- ) {
- return Toast({
- title: "产品库存不足,请选择其它",
- icon: "none"
- });
- }
- if (handleBtnTpe.value === 'buy') {
- showProductPopup.value = false;
- getPreOrderFn();
- } else if (handleBtnTpe.value === 'cart') {
- try {
- const params = {
- productId: parseFloat(id.value),
- cartNum: parseFloat(attr.value.productSelect.cart_num),
- isNew: false,
- productAttrUnique: attr.value.productSelect?.unique ?? productInfo.value.id,
- };
- // await postCartAdd(params);
- Toast({
- title: "添加购物车成功",
- icon: "success",
- success: () => getCartCount(true),
- });
- showProductPopup.value = false;
- } catch (res) {
- showProductPopup.value = false;
- Toast({
- title: res.message,
- icon: "none"
- });
- }
- }
- };
- // 点击优惠券事件
- const handleCoupon = () => {
- // if (!isLogin.value) {
- // toLogin();
- // } else {
- // getCouponList(1);
- // showCouponPopup.value = true;
- // }
- };
- const onMyEvent = () => {
- attr.value.cartAttr = false;
- isOpen.value = false;
- };
- // 关闭规格弹窗
- const closeProductPopup = () => {
- showProductPopup.value = false;
- attr.value.cartAttr = false;
- isOpen.value = false;
- };
- // 立即购买
- const goBuy = () => {
- // if (!isLogin.value) {
- // toLogin();
- // } else {
- // handleBtnTpe.value = "buy"
- // showProductPopup.value = true;
- // }
- };
- // 加入购物车
- const joinCart = (e) => {
- // if (!isLogin.value) {
- // toLogin();
- // } else {
- // handleBtnTpe.value = "cart"
- // showProductPopup.value = true;
- // }
- };
- // 跳到购物车页
- const toShopCart = () => {
- // if (!isLogin.value) {
- // toLogin();
- // } else {
- // uni.navigateTo({ url: "/pages/order_addcart/order_addcart" });
- // }
- };
- // 获取购物车数量统计
- const getCartCount = async (isAnima = false) => {
- // if (!isLogin.value) return;
- // try {
- // const res = await getCartCounts(true, "total");
- // CartCount.value = res.data.count;
- // if (isAnima) {
- // animated.value = true;
- // setTimeout(() => {
- // animated.value = false;
- // }, 1000);
- // }
- // } catch (err) {
- // console.error(err);
- // }
- };
- // 立即购买 加载预订单
- const getPreOrderFn = () => {
- const params = {
- mallType: 0,
- preOrderType: type.value === "normal" ? "buyNow" : "video",
- orderDetails: [{
- attrValueId: parseFloat(attr.value.productSelect.unique),
- productId: parseFloat(id.value),
- productNum: parseFloat(attr.value.productSelect.cart_num),
- }, ],
- };
- // getPreOrder(params);
- };
- const closePosters = () => {
- posters.value = false;
- };
- const posterImageClose = () => {
- canvasStatus.value = false;
- };
- const setDomain = (url) => {
- url = url ? url.toString() : "";
- return url.includes("https://") ? url : url.replace("http://", "https://");
- };
- const downloadFilestoreImage = async () => {
- try {
- const res = await uni.downloadFile({
- url: setDomain(productInfo.value.image),
- });
- storeImage.value = res.tempFilePath;
- } catch {
- storeImage.value = "";
- }
- };
- const goFriend = () => {
- posters.value = false;
- };
- const getQrcodeFn = async () => {
- // try {
- // const data = {
- // pid: uid.value,
- // id: id.value,
- // path: "pages/goods_details/index",
- // };
- // const res = await getQrcode(data);
- // base64src(res.data.code, (res) => {
- // PromotionCode.value = res;
- // });
- // } catch (err) {
- // errT.value = err;
- // }
- };
- // const make = (uid) => {
- // const href = `${location.href.split("?")[0]}?id=${id.value}&spread=${uid}`;
- // var qr = new UQRCode();
- // // 设置二维码内容
- // qr.data = "https://uqrcode.cn/doc";
- // // 设置二维码大小,必须与canvas设置的宽高一致
- // qr.size = 200;
- // // 设置二维码前景图,可以是路径
- // qr.foregroundImageSrc =
- // "";
- // // 调用制作二维码方法
- // qr.make();
- // // qr.make({
- // // canvasId: 'qrcode',
- // // text: href,
- // // size: qrcodeSize.value,
- // // margin: 10,
- // // success: (res) => {
- // // PromotionCode.value = res;
- // // },
- // // fail: () => {
- // // Toast({ title: '海报二维码生成失败!', icon: 'none' });
- // // },
- // // });
- // };
- const getImageBase64 = async (images) => {
- try {
- const res = await imageBase64({
- url: images
- });
- imgTop.value = res.data.code;
- } catch (err) {
- console.error(err);
- }
- };
- const goPoster = async () => {
- uni.showLoading({
- title: "海报生成中",
- mask: true
- });
- posters.value = false;
- if (!PromotionCode.value) {
- uni.hideLoading();
- Toast({
- title: errT.value,
- icon: "none"
- });
- return;
- }
- setTimeout(() => {
- if (!imgTop.value) {
- uni.hideLoading();
- Toast({
- title: "无法生成商品海报!",
- icon: "none"
- });
- return;
- }
- }, 1000);
- try {
- const res = await uni.downloadFile({
- url: imgTop.value
- });
- const arrImages = [
- posterbackgd.value,
- res.tempFilePath,
- PromotionCode.value,
- ];
- const storeName = productInfo.value.storeName;
- const price = productInfo.value.storePrice;
- setTimeout(() => {
- $util.PosterCanvas(
- arrImages,
- storeName,
- price,
- productInfo.value.otPrice,
- (tempFilePath) => {
- imagePath.value = tempFilePath;
- canvasStatus.value = true;
- uni.hideLoading();
- }
- );
- }, 500);
- } catch {
- uni.hideLoading();
- }
- };
- // #ifdef MP
- const savePosterPath = () => {
- uni.getSetting({
- success(res) {
- if (!res.authSetting["scope.writePhotosAlbum"]) {
- uni.authorize({
- scope: "scope.writePhotosAlbum",
- success() {
- uni.saveImageToPhotosAlbum({
- filePath: imagePath.value,
- success() {
- posterImageClose();
- Toast({
- title: "保存成功",
- icon: "success"
- });
- },
- fail() {
- Toast({
- title: "保存失败",
- icon: "none"
- });
- },
- });
- },
- });
- } else {
- uni.saveImageToPhotosAlbum({
- filePath: imagePath.value,
- success() {
- posterImageClose();
- Toast({
- title: "保存成功",
- icon: "success"
- });
- },
- fail() {
- Toast({
- title: "保存失败",
- icon: "none"
- });
- },
- });
- }
- },
- });
- };
- // #endif
- const ShareInfo = async () => {
- // const data = productInfo.value;
- // let href = location.href;
- // if (wechat.isWeixin()) {
- // href = href.includes("?")
- // ? `${href}&spread=${uid.value}`
- // : `${href}?spread=${uid.value}`;
- // const configAppMessage = {
- // desc: data.storeInfo,
- // title: data.storeName,
- // link: href,
- // imgUrl: data.image,
- // };
- // try {
- // await wechat.wechatEvevt(
- // [
- // "updateAppMessageShareData",
- // "updateTimelineShareData",
- // "onMenuShareAppMessage",
- // "onMenuShareTimeline",
- // ],
- // configAppMessage
- // );
- // } catch (err) {
- // console.error(err);
- // }
- // }
- };
- const goBack = () => {
- const pages = getCurrentPages();
- if (pages.length > 1) {
- uni.navigateBack();
- } else {
- uni.switchTab({
- url: "/pages/mall/index"
- });
- }
- };
- const goHome = () => {
- uni.switchTab({
- url: "/pages/index/index"
- });
- };
- function toMessagePage() {
- uni.navigateTo({
- url: '/pages/message_create/message_create'
- })
- }
- </script>
- <style scoped lang="scss">
- .goodImg {
- width: 100%;
- }
- .uni-swiper-dots-horizontal {
- display: none;
- }
- .product-con {
- height: 100%;
- .mask {
- z-index: 88;
- }
- .goods-nav-bar {
- background-color: rgba(255, 255, 255, 0.3);
- .nav-slot {
- padding: 5rpx 10rpx;
- border-radius: 40rpx;
- border: 1px solid #ccc;
- display: flex;
- justify-content: space-between;
- align-items: center;
- background-color: rgba(255, 255, 255, 0.8);
- }
- }
- .footer {
- padding: 0 20rpx 0 30rpx;
- position: fixed;
- bottom: 0;
- width: 100%;
- box-sizing: border-box;
- height: 100rpx;
- background-color: #fff;
- z-index: 277;
- border-top: 1rpx solid #f0f0f0;
- text-align: center;
- .toAPP {
- min-width: 30%;
- position: absolute;
- top: -85rpx;
- left: 35%;
- .storeAPP {
- background-color: #e9c279;
- color: #fff;
- border-radius: 50rpx;
- line-height: 50rpx;
- padding: 20rpx 20rpx;
- z-index: 999;
- .logoimg {
- display: inline-block;
- width: 50rpx;
- height: 50rpx;
- border-radius: 5rpx;
- vertical-align: middle;
- }
- }
- }
- .item {
- font-size: 18rpx;
- color: #666;
- .iconfont {
- text-align: center;
- font-size: 40rpx;
- &.icon-shoucang1 {
- color: #f00;
- }
- }
- .icon-item {
- font-size: 40rpx;
- position: relative;
- .num {
- color: #fff;
- position: absolute;
- font-size: 18rpx;
- padding: 2rpx 8rpx 3rpx;
- border-radius: 200rpx;
- top: -10rpx;
- right: -10rpx;
- }
- }
- }
- .bnt {
- width: 444rpx;
- height: 76rpx;
- .bnts {
- width: 222rpx;
- text-align: center;
- line-height: 76rpx;
- color: #fff;
- font-size: 28rpx;
- }
- .joinCart {
- border-radius: 50rpx 0 0 50rpx;
- background-image: linear-gradient(to right, #fea10f 0%, #fa8013 100%);
- }
- .buy {
- border-radius: 0 50rpx 50rpx 0;
- background-image: linear-gradient(to right, #fa6514 0%, #e93323 100%);
- }
- }
- }
- .store-info {
- margin-top: 20rpx;
- background-color: #fff;
- .title {
- padding: 0 30rpx;
- font-size: 28rpx;
- color: #282828;
- height: 80rpx;
- line-height: 80rpx;
- border-bottom: 1px solid #f5f5f5;
- }
- .info {
- padding: 0 30rpx;
- height: 126rpx;
- .picTxt {
- width: 615rpx;
- .pictrue {
- width: 76rpx;
- height: 76rpx;
- image {
- width: 100%;
- height: 100%;
- border-radius: 6rpx;
- }
- }
- .text {
- width: 522rpx;
- .name {
- font-size: 30rpx;
- color: #282828;
- }
- .address {
- font-size: 24rpx;
- color: #666;
- margin-top: 3rpx;
- .iconfont {
- color: #707070;
- font-size: 18rpx;
- margin-left: 10rpx;
- }
- .addressTxt {
- max-width: 480rpx;
- }
- }
- }
- }
- .iconfont {
- font-size: 40rpx;
- }
- }
- }
- .superior {
- background-color: #fff;
- margin-top: 30rpx;
- padding: 0 24rpx 30rpx 24rpx;
- .title {
- height: 98rpx;
- image {
- width: 20rpx;
- height: 20rpx;
- }
- .titleTxt {
- margin: 0 10rpx;
- font-size: 30rpx;
- color: #333333;
- // background-image: linear-gradient(to right, #f57a37 0%, #f21b07 100%);
- // -webkit-background-clip: text;
- // -webkit-text-fill-color: transparent;
- }
- }
- .slider-banner {
- width: 100%;
- margin: 0 auto;
- position: relative;
- swiper,
- swiper-item {
- height: 100%;
- width: 100%;
- }
- .list {
- width: 100%;
- .item {
- width: 198rpx;
- margin: 0 22rpx 30rpx 0;
- font-size: 26rpx;
- &:nth-of-type(3n) {
- margin-right: 0;
- }
- .pictrue {
- position: relative;
- width: 100%;
- height: 198rpx;
- image {
- width: 100%;
- height: 100%;
- border-radius: 6rpx;
- }
- }
- .name {
- color: #282828;
- margin-top: 12rpx;
- }
- }
- }
- .swiper-pagination-bullet {
- background-color: #999;
- }
- .swiper-pagination-bullet-active {
- background-color: $theme-color;
- }
- }
- }
- }
- .activityName {
- line-height: 44rpx;
- }
- .bntVideo {
- width: auto !important;
- .buy {
- border-radius: 50rpx !important;
- }
- }
- .row-block {
- background-color: #fff;
- padding: 20rpx;
- font-size: 0.8125rem;
- color: #000;
- .row-express {
- // width: 100%;
- display: flex;
- justify-content: space-between;
- // margin: 20rpx 10rpx 10rpx;
- .left-box {
- .icon {
- vertical-align: middle;
- }
- .text {
- margin: 0 0 0 14rpx;
- font-size: 28rpx;
- vertical-align: middle;
- }
- }
- .express-price {
- display: flex;
- align-items: center;
- }
- }
- .tip-text {
- display: flex;
- align-items: center;
- .text {
- display: flex;
- flex-direction: column;
- margin: 0 0 0 20rpx;
- .t2 {
- font-size: 24rpx;
- color: #666;
- }
- }
- }
- }
- .attribute {
- .line1 {
- width: 600rpx;
- }
- }
- .chat-btn {
- background-color: antiquewhite !important;
- }
- .activity_pin,
- .activity_miao,
- .activity_kan {
- width: auto;
- height: 44rpx;
- line-height: 44rpx;
- padding: 0 15rpx;
- opacity: 1;
- border-radius: 22rpx;
- }
- .activity_pin {
- background: linear-gradient(90deg,
- rgba(233, 51, 35, 1) 0%,
- rgba(250, 101, 20, 1) 100%);
- }
- .activity_miao {
- background: linear-gradient(90deg,
- rgba(250, 102, 24, 1) 0%,
- rgba(254, 161, 15, 1) 100%);
- margin-left: 19rpx;
- }
- .activity_kan {
- background: linear-gradient(90deg,
- rgba(254, 159, 15, 1) 0%,
- rgba(254, 178, 15, 1) 100%);
- margin-left: 19rpx;
- }
- .iconfonts {
- color: #fff !important;
- font-size: 28rpx;
- }
- .activity_title {
- font-size: 24rpx;
- color: #fff;
- }
- .mask {
- position: fixed;
- top: 0;
- left: 0;
- right: 0;
- bottom: 0;
- background-color: rgba(0, 0, 0, 0.6);
- z-index: 9;
- &.mask {
- z-index: 300 !important;
- }
- }
- .head-bar {
- background: #fff;
- }
- .generate-posters {
- width: 100%;
- height: 170rpx;
- background-color: #fff;
- position: fixed;
- left: 0;
- bottom: 0;
- z-index: 388;
- transform: translate3d(0, 100%, 0);
- transition: all 0.3s cubic-bezier(0.25, 0.5, 0.5, 0.9);
- border-top: 1rpx solid #eee;
- &.on {
- transform: translate3d(0, 0, 0);
- }
- .item {
- flex: 50%;
- text-align: center;
- font-size: 30rpx;
- .iconfont {
- font-size: 80rpx;
- color: #5eae72;
- &.icon-haibao {
- color: #5391f1;
- }
- }
- }
- }
- .pictrue_log {
- width: 80upx;
- height: 40upx;
- border-radius: 10upx 0 12upx 0;
- line-height: 40upx;
- font-size: 24upx;
- }
- .pictrue_log_class {
- z-index: 3;
- background: linear-gradient(90deg,
- rgba(246, 122, 56, 1) 0%,
- rgba(241, 27, 9, 1) 100%);
- opacity: 1;
- position: absolute;
- top: 0;
- left: 0;
- color: #fff;
- text-align: center;
- }
- .navbar {
- position: fixed;
- background-color: #fff;
- top: 0;
- left: 0;
- z-index: 99;
- width: 100%;
- .navbarH {
- position: relative;
- .navbarCon {
- position: absolute;
- bottom: 0;
- height: 100rpx;
- width: 100%;
- }
- }
- .header {
- height: 96rpx;
- font-size: 30rpx;
- color: #050505;
- background-color: #fff;
- /* #ifdef MP */
- padding-right: 95rpx;
- /* #endif */
- .item {
- position: relative;
- margin: 0 25rpx;
- &.on:before {
- position: absolute;
- width: 60rpx;
- height: 5rpx;
- background-repeat: no-repeat;
- content: "";
- background-image: linear-gradient(to right, #ff3366 0%, #ff6533 100%);
- bottom: -10rpx;
- left: 50%;
- margin-left: -28rpx;
- }
- }
- }
- }
- .icon-xiangzuo {
- margin-top: var(--status-bar-height);
- /* #ifdef H5 */
- top: 20rpx !important;
- /* #endif */
- color: #000;
- position: fixed;
- font-size: 36rpx;
- width: 100rpx;
- height: 56rpx;
- line-height: 54rpx;
- z-index: 1000;
- left: -5rpx;
- }
- .share-box {
- z-index: 1000;
- position: fixed;
- left: 0;
- top: 0;
- width: 100%;
- height: 100%;
- image {
- width: 100%;
- height: 100%;
- }
- }
- .pro-wrapper {
- .iconn {
- background-image: url("");
- width: 100rpx;
- height: 100rpx;
- background-repeat: no-repeat;
- background-size: 100% 100%;
- margin: 0 auto;
- &.iconn1 {
- background-image: url("");
- }
- }
- }
- .canvas {
- position: fixed;
- z-index: -5;
- opacity: 0;
- }
- .poster-pop {
- position: fixed;
- width: 450rpx;
- height: 714rpx;
- top: 50%;
- left: 50%;
- transform: translateX(-50%);
- margin-top: -432rpx;
- z-index: 399;
- image {
- width: 100%;
- height: 100%;
- display: block;
- }
- .close {
- width: 46rpx;
- height: 75rpx;
- position: fixed;
- right: 0;
- top: -73rpx;
- display: block;
- }
- .save-poster {
- background-color: #df2d0a;
- font-size: 22rpx;
- color: #fff;
- text-align: center;
- height: 76rpx;
- line-height: 76rpx;
- width: 100%;
- }
- .keep {
- color: #fff;
- text-align: center;
- font-size: 25rpx;
- margin-top: 10rpx;
- }
- }
- button {
- padding: 0;
- margin: 0;
- line-height: normal;
- background-color: #fff;
- &::after {
- border: 0;
- }
- }
- action-sheet-item {
- padding: 0;
- height: 240rpx;
- align-items: center;
- display: flex;
- }
- .contact {
- font-size: 16px;
- width: 50%;
- background-color: #fff;
- padding: 8rpx 0;
- border-radius: 0;
- margin: 0;
- line-height: 2;
- &::after {
- border: none;
- }
- }
- .action-sheet {
- font-size: 17px;
- line-height: 1.8;
- width: 50%;
- position: absolute;
- top: 0;
- right: 0;
- padding: 25rpx 0;
- }
- </style>
|