| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100 |
- <template>
- <view class="product-con">
- <up-navbar
- class="goods-nav-bar"
- :bgColor="`rgba(255, 255, 255, ${opacity})`"
- >
- <template #left>
- <view class="nav-slot">
- <uni-icons
- @click="goBack"
- type="left"
- size="22"
- color="#606266"
- ></uni-icons>
- <up-line
- direction="column"
- :hairline="false"
- length="16"
- margin="0 8px"
- ></up-line>
- <uni-icons
- @click="goHome"
- type="home"
- id="home"
- size="22"
- color="#606266"
- ></uni-icons>
- </view>
- </template>
- <template #center> </template>
- <template #right>
- <!-- 分享 -->
- <!-- <view @click="handleShare" class="share share-top">-->
- <!-- <uni-icons size="24" type="redo"></uni-icons>-->
- <!-- </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
- :imgUrls="sliderImage"
- :videoline="productInfo.videoLink"
- @click="previewImage(sliderImage)"
- >
- </product-con-swiper>
- <view class="pad30 container">
- <view class="wrapper mb30 borRadius14" style="margin-top: 0;">
- <view class="product-info">
- <view style="width:100%;">
- <view class="share acea-row row-between row-bottom">
- <view class="money font-color">
- <text class="num">¥{{ attr.productSelect.storePrice }}</text>
- </view>
- <view @click="listenerActionSheet" class="share share-top">
- <uni-icons size="24" type="redo"></uni-icons>
- </view>
- </view>
- <view class="label acea-row row-between-wrapper">
- <view>工费:{{ attr.productSelect.price || 0 }}元/g</view>
- <view>重量:{{ attr.productSelect.weight }}g</view>
- <view>
- 附加费:{{ attr.productSelect.additionalAmount || "" }}
- </view>
- <view >
- 销量:{{
- Number(productInfo?.sales || 0) + productInfo.ficti || "0"
- }}件
- </view>
- </view>
- </view>
- <!-- <view class="sales-container">-->
- <!-- <text class="sales-text">-->
- <!-- 销量:{{-->
- <!-- Number(productInfo?.sales || 0) + productInfo.ficti || "0"-->
- <!-- }}件-->
- <!-- </text>-->
- <!-- </view>-->
- </view>
- <view class="introduce" style="margin-bottom: 0;">{{ productInfo.storeName }}</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="type == 'normal'"-->
- <!-- class="coupon acea-row row-between-wrapper"-->
- <!-- @click="handleCoupon"-->
- <!-- >-->
- <!-- <view class="hide line1 acea-row">-->
- <!-- 优惠券:-->
- <!-- <view class="activity">-->
- <!-- 满{{ coupon.list[0]?.minPrice || "0.00" }}减{{-->
- <!-- coupon.list[0]?.money || "0.00"-->
- <!-- }}-->
- <!-- </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="product-card" @click="selecAttr">
- <!-- 材质和克重行 -->
- <view class="material-row">
- <view class="material-item" style="width: 60rpx;">
- <image style="width: 40rpx;" src="@/static/images/order.png" mode="widthFix"></image>
- </view>
- <view class="material-item">
- <text class="material-value">{{ metalTypeFormatter(productInfo.metalType) }}</text>
- <text class="material-label">材质</text>
- </view>
- <view class="material-item" style="width: 2rpx;">
- <view class="line"></view>
- </view>
- <view class="material-item">
- <text class="material-value">{{ selectValue().val }}</text>
- <text class="material-label">{{ selectValue().name }}</text>
- </view>
- <view class="material-item" style="width: 2rpx;">
- <view class="line"></view>
- </view>
- <view class="material-item">
- <text class="material-value">{{ attr.productSelect.price || 0 }}元/g</text>
- <text class="material-label">工费</text>
- </view>
- <view class="material-item" style="width: 2rpx;">
- <view class="line"></view>
- </view>
- <view class="material-item">
- <text class="material-value">{{ attr.productSelect.additionalAmount || "" }}</text>
- <text class="material-label">附加费</text>
- </view>
- </view>
- <!-- 分割线 -->
- <view class="divider"></view>
- <!-- 规格选择区域 -->
- <view class="spec-section" @click="handleSpecSelect">
- <view style="width: 60rpx;text-align: center;">
- <image style="width: 40rpx;" src="@/static/images/2-001.png" mode="widthFix"></image>
- </view>
- <view class="spec-info">
- <view class="spec-label">请选择规格</view>
- </view>
- <uni-icons type="right" size="16" color="#999999"></uni-icons>
- </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 class="store-card" @click="toStore">
- <view class="left">
- <image class="storeImg" :src="sbMerchantInfo.merchantLogo" mode="aspectFit"></image>
- </view>
- <view class="center">
- <view class="name line1">{{sbMerchantInfo.merchantName}}</view>
- <view class="desc line1">{{sbMerchantInfo.merchantDescribe}}</view>
- </view>
- <view class="right">
- <uni-icons type="right" size="16" color="#999999"></uni-icons>
- </view>
- </view>
- <view class="product-intro" id="past3">
- <view class="title" style="text-align: left;height:80rpx;line-height: 80rpx;font-size: 32rpx;color: #333;">
- <!-- <image src="/static/images/xzuo.png"></image>-->
- <span class="sp">商品详情</span>
- <!-- <image src="/static/images/xyou.png"></image>-->
- </view>
- <view class="conter" style="border-radius: 16rpx;overflow: hidden;">
- <up-parse :content="description"></up-parse>
- </view>
- </view>
- </view>
- </view>
- <view style="height: 120rpx"></view>
- </scroll-view>
- </view>
- <view class="footer acea-row row-between-wrapper">
- <!-- <navigator-->
- <!-- open-type="switchTab"-->
- <!-- class="animated item"-->
- <!-- :class="animated == true ? 'bounceIn' : ''"-->
- <!-- url="/pages/mall/index"-->
- <!-- 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>
- <button
- @click="setCollect"
- hover-class="none"
- class="item"
- >
- <uni-icons
- size="22"
- color="#F8C008"
- customPrefix="iconfont"
- type="icon-shoucangxuanzhong"
- v-if="userCollect"
- ></uni-icons>
- <uni-icons
- size="22"
- color="#666"
- customPrefix="iconfont"
- type="icon-shoucang"
- v-else
- ></uni-icons>
- <view>收藏</view>
- </button>
- <block v-if="type === 'normal'">
- <view
- class="animated item"
- :class="animated == true ? 'bounceIn' : ''"
- url="/pages/order_addcart/order_addcart"
- hover-class="none"
- @click="toShopCart"
- >
- <uni-icons
- size="22"
- color="#666"
- customPrefix="iconfont"
- type="icon-gouwuche"
- class="icon-item"
- >
- <text v-if="Math.floor(CartCount) > 0" class="num bg-color">{{
- CartCount
- }}</text>
- </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" v-if="attr.productSelect.stock <= 0">
- <form @submit="joinCart" report-submit="true">
- <button class="joinCart bnts" form-type="submit">加入购物车</button>
- </form>
- <form report-submit="true">
- <button class="buy bnts bg-color-hui" form-type="submit">
- 已售罄
- </button>
- </form>
- </view>
- <view class="bnt acea-row" v-else>
- <form @submit="joinCart" report-submit="true">
- <button class="joinCart bnts" form-type="submit">加入购物车</button>
- </form>
- <form @submit="goBuy" report-submit="true">
- <button class="buy bnts" form-type="submit">立即购买</button>
- </form>
- </view>
- </block>
- <!-- <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"
- @closePopup="closeProductPopup"
- @myevent="onMyEvent"
- @ChangeAttr="ChangeAttr"
- @ChangeCartNum="ChangeCartNum"
- @attrVal="attrVal"
- @iptCartNum="iptCartNum"
- @updatePrice="handlePriceUpdate"
- @submit="handleSubmit"
- id="product-window"
- >
- </productWindow>
- <couponListWindow
- :coupon="coupon"
- :showPopup="showCouponPopup"
- @close="closeCouponPopup"
- @ChangCoupons="ChangCoupons"
- @ChangCouponsUseState="ChangCouponsUseState"
- @tabCouponType="tabCouponType"
- >
- </couponListWindow>
- <!-- 分享按钮 -->
- <view class="generate-posters acea-row row-middle" :class="posters ? 'on' : ''">
- <!-- #ifndef MP -->
- <view class="item" hover-class='none' v-if="weixinStatus === true" @click="H5ShareBox = true">
- <view>
- <image class="shareImg" src="@/static/images/wexin.png" mode="widthFix"></image>
- </view>
- <view class="">发送给朋友</view>
- </view>
- <!-- #endif -->
- <!-- #ifdef MP -->
- <view class="item" open-type="share" hover-class='none' @click="goFriend">
- <view class="">
- <image class="shareImg" src="@/static/images/wexin.png" mode="widthFix"></image>
- </view>
- <view class="">发送给朋友</view>
- </view>
- <!-- #endif -->
- <view class="item" hover-class='none' @click="goPoster">
- <view style="display: flex;justify-content: center;align-items: center;">
- <view class="shareImg1">
- <image class="img" src="@/static/images/picture.png" mode="widthFix"></image>
- </view>
- </view>
- <view class="">生成海报</view>
- </view>
- </view>
- <view class="mask" v-if="posters" @click="closePosters"></view>
- </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 { useAppStore } from "@/stores/app.js";
- // import uQRCode from '@/js_sdk/Sansnn-uQRCode/uqrcode.js';
- import UQRCode from "uqrcodejs";
- import { getProductDetail, postCartAdd,collectDel,collectAdd } 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 { isTabBarPage } from "@/utils/util.js";
- import $util from "@/utils/util.js";
- import { HTTP_REQUEST_URL_SHARE } from "@/config/app.js";
- import UniIcons from "../../uni_modules/uni-icons/components/uni-icons/uni-icons.vue";
- const { Toast } = useToast();
- const app = getApp();
- const instance = getCurrentInstance();
- const appStore = useAppStore();
- const isLogin = computed(() => appStore.isLogin);
- const uid = computed(() => appStore.uid);
- 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 sbMerchantInfo = ref({});
- watch(
- isLogin,
- (newV) => {
- if (newV) {
- getCouponList();
- getCartCount();
- }
- },
- {
- deep: true,
- }
- );
- 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.id || 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,
- });
- }
- getGoodsDetails();
- getCouponList();
- });
- onShow(() => {
- getCartCount();
- });
- onReady(() => {
- // #ifdef MP
- const menuButton = uni.getMenuButtonBoundingClientRect();
- const query = uni.createSelectorQuery().in(instance.proxy);
- query
- .select("#home")
- .boundingClientRect((data) => {
- console.log(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) => {
- 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,
- additionalAmount: productSelect.additionalAmount,
- };
- console.log(res);
- 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 () => {
- try {
- const res = await getProductDetail(id.value, type.value);
- const product = res.data.productInfo;
- sliderImage.value = JSON.parse(product.sliderImage);
- productInfo.value = product;
- description.value = product.content;
- userCollect.value = res.data.userCollect;
- attr.value.productAttr = res.data.productAttr;
- 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 || [];
- sbMerchantInfo.value = res.data?.sbMerchant || {};
- 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 DefaultSelect = () => {
- let value = [];
- const keys = Object.keys(productValue.value);
- for (let i = 0; i < keys.length; i++) {
- const key = keys[i];
- if (productValue.value[key].stock > 0) {
- value = attr.value.productAttr.length ? key.split(",") : [];
- break;
- }
- }
- attr.value.productAttr.forEach((item, i) => {
- item.index = value[i];
- });
- const productSelect = productValue.value[value.join(",")];
- if (productSelect && attr.value.productAttr.length) {
- attr.value.productSelect = {
- ...attr.value.productSelect,
- storeName: productInfo.value.storeName,
- image: productSelect.image,
- additionalAmount: productSelect.additionalAmount,
- 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,
- additionalAmount: productSelect.additionalAmount,
- 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,
- additionalAmount: productSelect.additionalAmount,
- 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" });
- }
- }
- };
- function handlePriceUpdate(price) {
- attr.value.productSelect.storePrice = price;
- }
- // 点击优惠券事件
- 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.switchTab({
- 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 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 =
- "data:image/png;base64,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";
- // 调用制作二维码方法
- 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;
- console.log('PromotionCode.value',PromotionCode.value)
- console.log('imgTop.value',imgTop.value)
- 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 handleShare = () => {
- console.log("uni.getSystemInfoSync()", uni.getSystemInfoSync());
- if (uni.getSystemInfoSync().romName !== "HarmonyOS") {
- uni.shareWithSystem({
- href: `${HTTP_REQUEST_URL_SHARE}/share/#/pages/goods_details/index?articleId=${id.value}`,
- title: productInfo.value.storeName,
- success() {
- // 分享完成,请注意此时不一定是成功分享
- },
- fail() {
- // 分享失败
- },
- });
- } else {
- uni.share({
- provider: "weixin",
- scene: "WXSceneSession",
- type: 0,
- href: `${HTTP_REQUEST_URL_SHARE}/share/#/pages/goods_details/index?articleId=${id.value}`,
- title: productInfo.value.storeName,
- imageUrl:
- "https://sb-admin.oss-cn-shenzhen.aliyuncs.com/crmebimage/public/maintain/2025/08/28/eb3953f78a0f468fa2e4c7721c2a6ca2b9pirw5y37.png",
- // imageUrl:"",
- success: function (res) {
- console.log("success:" + JSON.stringify(res));
- },
- fail: function (err) {
- console.log("fail:" + JSON.stringify(err));
- },
- });
- }
- };
- /**
- * 分享打开
- *
- */
- function listenerActionSheet () {
- if (isLogin === false) {
- toLogin();
- } else {
- // #ifdef H5
- if (wechat.isWeixin() === true) {
- weixinStatus = true;
- }
- // #endif
- posters.value = true;
- }
- }
- function closePosters() {
- posters.value = false;
- }
- const goBack = () => {
- if (isTabBarPage()) {
- uni.switchTab({
- url: "/pages/index/index",
- });
- } else {
- uni.navigateBack();
- }
- };
- const goHome = () => {
- uni.switchTab({
- url: "/pages/index/index",
- });
- };
- function toMessagePage() {
- uni.navigateTo({ url: "/pages/users/customer_service_message/index" });
- }
- const previewImage = (item) => {
- // 预览图片,支持多张图片传数组
- uni.previewImage({
- urls: item,
- current: item[0],
- });
- };
- const calcNumPrice = (productSelect) => {
- const { price, cart_num, additionalAmount, weight } = productSelect;
- ``;
- // 计算总价并保留两位小数
- const total =
- Number(price) * Number(weight) * Number(cart_num) + additionalAmount;
- return total.toFixed(2);
- };
- const selectValue = () => {
- let val = '',name='';
- const arr = attrValue.value.split(',');
- // 优先查找 '克重' 或 '重量'
- const weightItem = attr.value.productAttr.find((item, index) => {
- if (item.attrName == '克重' || item.attrName == '重量') {
- val = arr == '' ? item.attrValues : arr[index];
- name = item.attrName;
- return true;
- }
- return false;
- });
- // 如果没有找到 '克重' 或 '重量',取第一个对象
- if (!weightItem && attr.value.productAttr.length > 0) {
- val = arr == '' ? attr.value.productAttr[0].attrValues : arr[0];
- name = attr.value.productAttr[0].attrName;
- }
- return {
- val,
- name
- };
- }
- const metalTypeFormatter = (val)=> {
- let str = '';
- if(val == 1){
- str = '黄金'
- }else if(val == 3){
- str = '铂金'
- }else{
- str = '白银'
- }
- return str;
- }
- const toStore = () => {
- uni.navigateTo({ url: "/pages/merchant/index?merchantId="+sbMerchantInfo.value.id });
- }
- /**
- *
- *
- * 收藏商品
- */
- function setCollect () {
- if (isLogin.value === false) {
- toLogin();
- } else {
- if (userCollect.value) {
- collectDel(productInfo.value.id).then(res => {
- userCollect.value = !userCollect.value;
- })
- } else {
- collectAdd(productInfo.value.id).then(res => {
- userCollect.value = !userCollect.value;
- })
- }
- }
- }
- </script>
- <style scoped lang="scss">
- .product-con {
- height: 100%;
- .mask {
- z-index: 88;
- }
- .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;
- .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("data:image/png;base64,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");
- width: 100rpx;
- height: 100rpx;
- background-repeat: no-repeat;
- background-size: 100% 100%;
- margin: 0 auto;
- &.iconn1 {
- background-image: url("data:image/png;base64,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");
- }
- }
- }
- .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;
- }
- .share-top {
- background-color: rgba(255, 255, 255, 0.8);
- padding: 5rpx 10rpx;
- border-radius: 40rpx;
- }
- .container{
- margin-top: -40rpx;
- position: relative;
- z-index: 2;
- background-color: #F9F7F0;
- border-radius: 14rpx 14rpx 0 0;
- padding-top: 30rpx; /* 顶部内边距 */
- }
- .product-info {
- display: flex;
- justify-content: space-between;
- align-items: center;
- width: 100%;
- }
- .sales-container {
- width: 20%;
- display: flex;
- justify-content: flex-end;
- align-items: center;
- text-align: right;
- }
- .sales-text {
- font-size: 24rpx;
- color: #666;
- text-align: right;
- white-space: nowrap;
- }
- .product-card {
- background: #ffffff;
- border-radius: 16rpx;
- padding: 20rpx;
- }
- .material-row {
- display: flex;
- justify-content: flex-start;
- align-items: center;
- padding: 24rpx 0;
- }
- .material-item {
- width: 22%;
- display: flex;
- flex-direction: column;
- align-items: center;
- }
- .material-item .line{
- height: 72rpx;
- width: 2rpx;
- background-color: #F1F3F8;
- }
- .material-label {
- font-size: 26rpx;
- color: #999;
- margin-bottom: 8rpx;
- }
- .material-value {
- font-size: 28rpx;
- color: #333;
- font-weight: 500;
- }
- .divider {
- height: 1rpx;
- background-color: #F1F3F8;
- }
- .craft-fee-section {
- padding: 24rpx 0;
- }
- .craft-fee-header {
- display: flex;
- justify-content: space-between;
- align-items: center;
- margin-bottom: 16rpx;
- }
- .craft-fee-label {
- font-size: 28rpx;
- color: #333;
- font-weight: 500;
- }
- .unit-price {
- background: #f8f8f8;
- padding: 8rpx 16rpx;
- border-radius: 20rpx;
- }
- .unit-price-text {
- font-size: 24rpx;
- color: #666;
- }
- .total-fee {
- text-align: right;
- }
- .total-fee-text {
- font-size: 32rpx;
- color: #e4393c;
- font-weight: 600;
- }
- .spec-section {
- display: flex;
- justify-content: space-between;
- align-items: center;
- padding-top: 24rpx;
- min-height: 120rpx;
- }
- .spec-info {
- width: 100%;
- display: flex;
- justify-items: space-between;
- }
- .spec-label {
- font-size: 28rpx;
- color: #333;
- font-weight: 500;
- margin-bottom: 8rpx;
- }
- .spec-hint {
- font-size: 24rpx;
- color: #999;
- float: right;
- }
- .store-card{
- background: #ffffff;
- border-radius: 16rpx;
- padding: 20rpx;
- display: flex;
- justify-content: center;
- align-items: center;
- margin-top: 30rpx;
- .left{
- width: 140rpx;
- .storeImg{
- width: 100rpx;
- height: 100rpx;
- }
- }
- .center{
- width: 70%;
- .name{
- font-size: 32rpx;
- color: #333;line-height: 60rpx;
- }
- .desc{
- font-size: 28rpx;
- color: #666;
- }
- }
- }
- .product-intro{
- background: #ffffff;
- border-radius: 16rpx;
- padding: 20rpx;
- margin-top: 30rpx;
- }
- .shareImg{
- width: 70rpx;
- height: 70rpx;
- border-radius: 50%;
- }
- .shareImg1{
- width: 70rpx;
- height: 70rpx;
- border-radius: 50%;
- display: flex;
- justify-content: center;
- align-items: center;
- background-color: #5590EB;
- .img{
- width: 40rpx;
- }
- }
- </style>
- <style>
- .goods-nav-bar {
- background-color: rgba(255, 255, 255, 0.3) !important;
- }
- .nav-slot {
- padding: 5rpx 10rpx !important;
- border-radius: 40rpx;
- border: 1px solid #ccc;
- display: flex;
- justify-content: space-between;
- align-items: center;
- background-color: rgba(255, 255, 255, 0.8);
- }
- </style>
|