index.vue 58 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735
  1. <template>
  2. <view class="product-con">
  3. <!-- <up-navbar
  4. class="goods-nav-bar"
  5. :bgColor="`rgba(255, 255, 255, ${opacity})`"
  6. >
  7. <template #left>
  8. <view class="nav-slot">
  9. <up-icon @click="goBack" name="arrow-left" size="19"></up-icon>
  10. <up-line
  11. direction="column"
  12. :hairline="false"
  13. length="16"
  14. margin="0 8px"
  15. ></up-line>
  16. <up-icon @click="goHome" name="home" size="20"></up-icon>
  17. </view>
  18. </template>
  19. </up-navbar> -->
  20. <!-- <view class='iconfont icon-xiangzuo' :style="'top:'+navH/2+'rpx'" @tap='returns'></view> -->
  21. <view>
  22. <scroll-view
  23. :scroll-top="scrollTop"
  24. scroll-y="true"
  25. scroll-with-animation="true"
  26. :style="'height:' + height + 'px;'"
  27. @scroll="handleScroll"
  28. >
  29. <view id="past0">
  30. <product-con-swiper :indicator-dots="false" :imgUrls="sliderImage">
  31. </product-con-swiper>
  32. <!-- <image :src="sliderImage" class="goodImg"></image> -->
  33. <view class="pad30">
  34. <view class="wrapper mb30 borRadius14">
  35. <view class="introduce">{{ productInfo.storeName }}</view>
  36. <view class="label acea-row row-between-wrapper">
  37. <view>工费: {{ attr.productSelect.price || 0 }}元/克</view>
  38. <view>重量: {{ attr.productSelect.weight }}克</view>
  39. <view>
  40. 销量:{{ Number(attr.productSelect?.sales || 0)
  41. }}{{ productInfo.unitName || "" }}
  42. </view>
  43. </view>
  44. <view class="share acea-row row-between row-bottom">
  45. <view class="money font-color">
  46. <text class="num">{{ attr.productSelect.storePrice }}</text>
  47. <!-- <text
  48. class="vip-money"
  49. v-if="productInfo.vipPrice && productInfo.vipPrice > 0"
  50. >¥{{ productInfo.vipPrice }}</text
  51. > -->
  52. <!-- <image
  53. v-if="productInfo.vipPrice && productInfo.vipPrice > 0"
  54. src="/static/images/vip.png"
  55. ></image> -->
  56. </view>
  57. </view>
  58. <!-- <view class='coupon acea-row row-between-wrapper' v-if="productInfo.give_integral > 0">
  59. <view class='hide line1 acea-row'>
  60. 赠积分:
  61. <view class='activity'>赠送 {{productInfo.give_integral}} 积分</view>
  62. </view>
  63. </view> -->
  64. <view
  65. v-if="coupon.list.length > 0"
  66. class="coupon acea-row row-between-wrapper"
  67. @click="handleCoupon"
  68. >
  69. <view class="hide line1 acea-row">
  70. 优惠券:
  71. <view class="activity">
  72. 满{{ coupon.list[0].minPrice }}减{{
  73. coupon.list[0].money
  74. }}</view
  75. >
  76. </view>
  77. <view class="iconfont icon-jiantou"></view>
  78. </view>
  79. </view>
  80. <view
  81. class="attribute acea-row row-between-wrapper mb30 borRadius14"
  82. @click="selecAttr"
  83. >
  84. <view class="line1"
  85. >{{ attrTxt }}:
  86. <text class="atterTxt">{{ attrValue }}</text>
  87. </view>
  88. <view class="iconfont icon-jiantou"></view>
  89. </view>
  90. <view class="row-block mb30 borRadius14">
  91. <view class="row-express">
  92. <view class="left-box">
  93. <uni-icons class="icon" type="cart" size="24"></uni-icons>
  94. <text class="text">48小时送达</text>
  95. </view>
  96. <view class="express-price">
  97. <text class="express-place">广东深圳</text>
  98. <!-- <up-line
  99. color="#ccc"
  100. direction="column"
  101. :hairline="false"
  102. length="14px"
  103. margin="0 8px"
  104. ></up-line> -->
  105. <!-- <text class="express-place">快递费:8元</text> -->
  106. </view>
  107. </view>
  108. <up-line color="#ccc" length="100%" margin="10px 0"></up-line>
  109. <view class="tip-text">
  110. <uni-icons size="24" type="hand-up"></uni-icons>
  111. <view class="text">
  112. <text class="t1">买的放心,用的称心</text>
  113. <text class="t2">平台有保障</text>
  114. </view>
  115. </view>
  116. </view>
  117. </view>
  118. </view>
  119. </scroll-view>
  120. </view>
  121. <view class="footer acea-row row-between-wrapper">
  122. <view class="toAPP">
  123. <wx-open-launch-app
  124. id="launch-btn"
  125. appid="wx5f33a4ace799b661"
  126. :extinfo="'/pages/goods_details/index?articleId=' + articleId"
  127. @error="goShuiBei"
  128. >
  129. <component :is="'script'" v-bind="{ type: 'text/wxtag-template' }">
  130. <button
  131. class="storeAPP"
  132. style="
  133. background-color: #e9c279;
  134. color: #fff;
  135. border-radius: 50rpx;
  136. line-height: 100rpx;
  137. padding: 20rpx 20rpx;
  138. z-index: 999;
  139. box-sizing: border-box;
  140. "
  141. >
  142. 打开水贝商城
  143. </button>
  144. </component>
  145. </wx-open-launch-app>
  146. <!-- <button type="default" class="storeAPP" @click="goShuiBei">
  147. <image src="/static/images/logo_person.png" mode="" class="logoimg"></image>
  148. 打开水贝商城
  149. </button> -->
  150. </view>
  151. <navigator
  152. open-type="switchTab"
  153. class="animated item bounceIn"
  154. hover-class="none"
  155. >
  156. <uni-icons
  157. size="22"
  158. color="#666"
  159. customPrefix="iconfont"
  160. type="icon-shouye"
  161. ></uni-icons>
  162. <view>首页</view>
  163. </navigator>
  164. <button
  165. @click="toMessagePage"
  166. open-type="contact"
  167. hover-class="none"
  168. class="item"
  169. >
  170. <uni-icons
  171. size="22"
  172. color="#666"
  173. customPrefix="iconfont"
  174. type="icon-kefu1"
  175. ></uni-icons>
  176. <view>客服</view>
  177. </button>
  178. <view
  179. class="animated item bounceIn"
  180. hover-class="none"
  181. @click="toShopCart"
  182. >
  183. <uni-icons
  184. size="22"
  185. color="#666"
  186. customPrefix="iconfont"
  187. type="icon-gouwuche"
  188. class="icon-item"
  189. >
  190. </uni-icons>
  191. <!-- <view class="iconfont icon-gouwuche1">
  192. <text v-if="Math.floor(CartCount) > 0" class="num bg-color">{{
  193. CartCount
  194. }}</text>
  195. </view> -->
  196. <view>购物车</view>
  197. </view>
  198. <view class="bnt acea-row">
  199. <form report-submit="true">
  200. <button class="joinCart bnts" form-type="submit">加入购物车</button>
  201. </form>
  202. <form report-submit="true">
  203. <button class="buy bnts" form-type="submit">立即购买</button>
  204. </form>
  205. </view>
  206. <!-- <view
  207. class="bnt bntVideo acea-row"
  208. v-if="attr.productSelect.stock <= 0 && type === 'video'"
  209. >
  210. <form report-submit="true">
  211. <button class="buy bnts bg-color-hui" form-type="submit">
  212. 已售罄
  213. </button>
  214. </form>
  215. </view>
  216. <view
  217. class="bnt bntVideo acea-row"
  218. v-if="attr.productSelect.stock > 0 && type === 'video'"
  219. >
  220. <form @submit="goBuy" report-submit="true">
  221. <button class="buy bnts" form-type="submit">立即购买</button>
  222. </form>
  223. </view> -->
  224. </view>
  225. <!-- 组件 -->
  226. <productWindow
  227. :attr="attr"
  228. :isShow="1"
  229. :iSplus="1"
  230. :showPopup="showProductPopup"
  231. id="product-window"
  232. >
  233. </productWindow>
  234. <couponListWindow
  235. :coupon="coupon"
  236. :showPopup="showCouponPopup"
  237. ></couponListWindow>
  238. </view>
  239. </template>
  240. <script setup>
  241. import { onReady, onLoad, onShow } from "@dcloudio/uni-app";
  242. import { ref, computed, watch, getCurrentInstance, toRaw } from "vue";
  243. import { useToast } from "@/hooks/useToast";
  244. import wx from "weixin-js-sdk";
  245. // import { useAppStore } from "@/stores/app.js";
  246. // import uQRCode from '@/js_sdk/Sansnn-uQRCode/uqrcode.js';
  247. // import UQRCode from "uqrcodejs";
  248. // import { getProductDetail, postCartAdd } from "@/api/store.js";
  249. // import { spread } from "@/api/user";
  250. // import { getCoupons, getQrcode } from "@/api/api.js";
  251. // import { getCartCounts } from "@/api/order.js";
  252. // import { toLogin } from "@/libs/login.js";
  253. // import { imageBase64 } from "@/api/public";
  254. import wechat from "@/libs/wechat.js";
  255. // import { getPreOrder } from "@/libs/order";
  256. import productConSwiper from "@/components/productConSwiper";
  257. import couponListWindow from "@/components/couponListWindow";
  258. import productWindow from "@/components/productWindow";
  259. import {
  260. getArticleDetailId,
  261. getGoodDetailId,
  262. getWechatConfig,
  263. } from "@/api/index.js";
  264. const { Toast } = useToast();
  265. // const app = getApp();
  266. const instance = getCurrentInstance();
  267. // const appStore = useAppStore();
  268. // const isLogin = computed(() => appStore.isLogin);
  269. // const uid = computed(() => appStore.uid);
  270. const initwxlaunch = () => {
  271. getWechatConfig(encodeURIComponent(location.href.split("#")[0])).then(
  272. (res) => {
  273. wx.config({
  274. debug: res.data.debug, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
  275. appId: res.data.appId, // 必填,公众号的唯一标识
  276. timestamp: res.data.timestamp, // 必填,生成签名的时间戳
  277. nonceStr: res.data.nonceStr, // 必填,生成签名的随机串
  278. signature: res.data.signature, // 必填,签名,// 必填,签名
  279. jsApiList: ["wx-open-subscribe", "wx-open-launch-app"], // 必填,需要使用的JS接口列表,这个地方必须至少写一个,即使你一个都不想用'updateTimelineShareData',
  280. openTagList: ["wx-open-subscribe", "wx-open-launch-app"],
  281. // 可选,需要使用的开放标签列表
  282. });
  283. wx.checkJsApi({
  284. jsApiList: ["wx-open-launch-app"], // 校验跳转APP的标签是否可用
  285. success: function (res) {
  286. console.log("可用");
  287. },
  288. fail: (err) => {
  289. console.log(err, "不可用");
  290. },
  291. });
  292. }
  293. );
  294. };
  295. initwxlaunch();
  296. const coupon = ref({
  297. coupon: false,
  298. type: 1,
  299. list: [],
  300. count: [],
  301. });
  302. const attrTxt = ref("请选择");
  303. const attrValue = ref("");
  304. const animated = ref(false);
  305. const id = ref(0);
  306. const productInfo = ref({});
  307. const productValue = ref([]);
  308. const couponList = ref([]);
  309. const cart_num = ref(1);
  310. const isOpen = ref(false);
  311. const storeImage = ref("");
  312. const PromotionCode = ref("");
  313. const posterbackgd = ref("/static/images/posterbackgd.png");
  314. const sharePacket = ref({
  315. isState: true,
  316. });
  317. const clientHeight = ref("");
  318. const good_list = ref([]);
  319. const CartCount = ref(0);
  320. const posters = ref(false);
  321. const attr = ref({
  322. cartAttr: false,
  323. productAttr: [],
  324. productSelect: {},
  325. });
  326. const description = ref("");
  327. const navActive = ref(0);
  328. const activityH5 = ref([]);
  329. const retunTop = ref(true);
  330. const navH = ref("");
  331. const opacity = ref(0);
  332. const scrollY = ref(0);
  333. const topArr = ref([]);
  334. const height = ref(0);
  335. const heightArr = ref([]);
  336. const lock = ref(false);
  337. const scrollTop = ref(0);
  338. const sliderImage = ref([]);
  339. const canvasStatus = ref(false);
  340. const imagePath = ref("");
  341. const imgTop = ref("");
  342. const errT = ref("");
  343. const homeTop = ref(20);
  344. const userCollect = ref(false);
  345. const returnShow = ref(true);
  346. const type = ref("");
  347. const showProductPopup = ref(false); // 商品规格弹窗
  348. const showCouponPopup = ref(false); // 优惠券弹窗
  349. const handleBtnTpe = ref(""); // "buy" or "cart"
  350. const goShuiBei = () => {
  351. const path = articleId.value
  352. ? `/pages/goods_details/index?articleId=${articleId.value}`
  353. : "";
  354. const url = `shuibei://${path}`;
  355. const errUrl = "https://a.app.qq.com/o/simple.jsp?pkgname=uni.app.UNI9DE338F";
  356. window.location.href = url;
  357. setTimeout(() => {
  358. window.location.href = errUrl;
  359. }, 3000);
  360. };
  361. const onListenLaunchError = () => {
  362. let errUrl = "https://a.app.qq.com/o/simple.jsp?pkgname=uni.app.UNI9DE338F";
  363. };
  364. // watch(
  365. // isLogin,
  366. // (newV) => {
  367. // if (newV) {
  368. // getCouponList();
  369. // getCartCount();
  370. // }
  371. // },
  372. // { deep: true }
  373. // );
  374. const articleId = ref();
  375. onLoad((options) => {
  376. const pages = getCurrentPages();
  377. returnShow.value = pages.length > 1;
  378. retunTop.value = pages.length > 1;
  379. // navH.value = app.globalData.navHeight;
  380. // #ifdef MP || APP-PLUS
  381. setTimeout(() => {
  382. if (options.spread) {
  383. // app.globalData.spread = options.spread;
  384. spread(options.spread).catch(() => {});
  385. }
  386. }, 2000);
  387. // #endif
  388. uni.getSystemInfo({
  389. success(res) {
  390. height.value = res.windowHeight;
  391. },
  392. });
  393. // if (!options.scene && !options.id) {
  394. // Toast({ title: "缺少参数无法查看商品", icon: "none" });
  395. // uni.navigateTo({ url: "/pages/mall/index" });
  396. // return;
  397. // }
  398. if (options.articleId || options.scene) {
  399. if (options.scene) {
  400. const qrCodeValue = $util.getUrlParams(decodeURIComponent(options.scene));
  401. const mapeMpQrCodeValue = $util.formatMpQrCodeData(qrCodeValue);
  402. // app.globalData.spread = mapeMpQrCodeValue.spread;
  403. id.value = mapeMpQrCodeValue.id;
  404. setTimeout(() => {
  405. spread(mapeMpQrCodeValue.spread).catch(() => {});
  406. }, 2000);
  407. } else {
  408. id.value = options.id;
  409. }
  410. type.value = options.type ?? "normal";
  411. // appStore.$patch({ productType: type.value });
  412. }
  413. articleId.value = options.articleId;
  414. getGoodsDetails(options.articleId);
  415. // getCouponList();
  416. });
  417. onShow(() => {
  418. getCartCount();
  419. });
  420. onReady(() => {
  421. // #ifdef MP
  422. const menuButton = uni.getMenuButtonBoundingClientRect();
  423. const query = uni.createSelectorQuery().in(this);
  424. query
  425. .select("#home")
  426. .boundingClientRect((data) => {
  427. homeTop.value = menuButton.top * 2 + menuButton.height - data.height;
  428. })
  429. .exec();
  430. // #endif
  431. });
  432. const iptCartNum = (e) => {
  433. attr.value.productSelect.cart_num = e || 1;
  434. };
  435. const handleScroll = (e) => {
  436. const scrollYVal = e.detail.scrollTop;
  437. const opacityVal = scrollYVal / 350 > 1 ? 1 : scrollYVal / 350;
  438. opacity.value = opacityVal;
  439. scrollY.value = scrollYVal;
  440. if (lock.value) {
  441. lock.value = false;
  442. return;
  443. }
  444. // for (let i = 0; i < topArr.value.length; i++) {
  445. // if (
  446. // scrollYVal <
  447. // topArr.value[i] - app.globalData.navHeight / 2 + heightArr.value[i]
  448. // ) {
  449. // navActive.value = i;
  450. // break;
  451. // }
  452. // }
  453. };
  454. const closeCouponPopup = () => {
  455. showCouponPopup.value = false;
  456. // coupon.value.coupon = false;
  457. };
  458. const ChangeCartNum = (changeValue) => {
  459. console.log("changeValue", changeValue);
  460. let productSelect =
  461. productValue.value[attrValue.value] ||
  462. (attr.value.productAttr.length ? undefined : attr.value.productSelect);
  463. if (!productSelect) return;
  464. const stock = productSelect.stock || 0;
  465. let num = attr.value.productSelect;
  466. num.cart_num = changeValue
  467. ? Math.min(num.cart_num + 1, stock)
  468. : Math.max(num.cart_num - 1, 1);
  469. attr.value.productSelect.cart_num = num.cart_num;
  470. cart_num.value = num.cart_num;
  471. };
  472. const attrVal = (val) => {
  473. attr.value.productAttr[val.indexw].index =
  474. attr.value.productAttr[val.indexw].attrValues[val.indexn];
  475. };
  476. const ChangeAttr = (res) => {
  477. const productSelect = productValue.value[res];
  478. if (productSelect) {
  479. attr.value.productSelect = {
  480. ...attr.value.productSelect,
  481. image: productSelect.image,
  482. sales: productSelect.sales,
  483. weight: productSelect.weight,
  484. price: productSelect.price,
  485. storePrice: productSelect.storePrice,
  486. stock: productSelect.stock,
  487. unique: productSelect.id,
  488. cart_num: 1,
  489. };
  490. attrValue.value = res;
  491. attrTxt.value = "已选择";
  492. } else {
  493. attr.value.productSelect = {
  494. ...attr.value.productSelect,
  495. image: productInfo.value.image,
  496. weight: productSelect.weight,
  497. price: productInfo.value.price,
  498. storePrice: productSelect.storePrice,
  499. stock: 0,
  500. unique: productInfo.value.id,
  501. cart_num: 1,
  502. };
  503. attrValue.value = "";
  504. attrTxt.value = "请选择";
  505. }
  506. };
  507. const ChangCoupons = (coupon) => {
  508. couponList.value = couponList.value.filter((item) => item.id !== coupon.id);
  509. getCouponList();
  510. };
  511. const setClientHeight = () => {
  512. if (!good_list.value.length) return;
  513. const query = uni.createSelectorQuery().in(instance.proxy);
  514. query
  515. .select("#list0")
  516. .fields(
  517. {
  518. size: true,
  519. },
  520. (data) => {
  521. clientHeight.value = data.height + 20;
  522. }
  523. )
  524. .exec();
  525. };
  526. const getGoodsDetails = async (id) => {
  527. try {
  528. const res = await getArticleDetailId(id);
  529. const product = res.data.productInfo;
  530. sliderImage.value = [product.image];
  531. console.log("sliderImage.value", sliderImage.value);
  532. productInfo.value = product;
  533. console.log("productInfo.value", productInfo.value);
  534. description.value = product.content;
  535. console.log("description.value", description.value);
  536. userCollect.value = res.data.userCollect;
  537. attr.value.productAttr = res.data.productAttr;
  538. console.log("res.data.productValue", res.data);
  539. productValue.value = res.data.productValue;
  540. sharePacket.value.priceName = res.data.priceName;
  541. sharePacket.value.isState = Math.floor(res.data.priceName) !== 0;
  542. activityH5.value = res.data.activityAllH5 || [];
  543. uni.setNavigationBarTitle({
  544. title: product.storeName.substring(0, 7) + "...",
  545. });
  546. attr.value.productAttr = attr.value.productAttr.map((item) => ({
  547. attrName: item.attrName,
  548. attrValues: item.attrValues.split(","),
  549. id: item.id,
  550. isDel: item.isDel,
  551. productId: item.productId,
  552. type: item.type,
  553. }));
  554. // if (isLogin.value) {
  555. // // #ifdef H5
  556. // // make(uid.value);
  557. // ShareInfo();
  558. // getImageBase64(productInfo.value.image);
  559. // // #endif
  560. // // #ifdef MP
  561. // getQrcodeFn();
  562. // // #endif
  563. // }
  564. // nextTick(() => {
  565. // infoScroll();
  566. // });
  567. // #ifdef MP
  568. imgTop.value = productInfo.value.image;
  569. // #endif
  570. // #ifndef H5
  571. downloadFilestoreImage();
  572. // #endif
  573. DefaultSelect();
  574. } catch (err) {
  575. Toast({
  576. title: err.toString(),
  577. icon: "none",
  578. });
  579. // uni.navigateBack();
  580. }
  581. };
  582. // const infoScroll = () => {
  583. // for (let i = 0; i < navList.value.length; i++) {
  584. // const query = uni.createSelectorQuery().in(this);
  585. // const idView = `#past${i}`;
  586. // query
  587. // .select(idView)
  588. // .boundingClientRect()
  589. // .exec((res) => {
  590. // const top = res[0].top;
  591. // const height = res[0].height;
  592. // topArr.value = [...topArr.value, top];
  593. // heightArr.value = [...heightArr.value, height];
  594. // });
  595. // }
  596. // };
  597. const DefaultSelect = () => {
  598. let value = [];
  599. console.log("productValue.value", toRaw(productValue.value));
  600. const keys = Object.keys(productValue.value);
  601. console.log("keys", keys);
  602. for (let i = 0; i < keys.length; i++) {
  603. const key = keys[i];
  604. console.log("key", key);
  605. // if (productValue.value[key].stock > 0) {
  606. value = attr.value.productAttr.length ? key.split(",") : [];
  607. // break;
  608. // }
  609. }
  610. console.log("value", value);
  611. attr.value.productAttr.forEach((item, i) => {
  612. item.index = value[i];
  613. });
  614. const productSelect = productValue.value[value.join(",")];
  615. console.log({
  616. productSelect,
  617. });
  618. console.log({
  619. attr,
  620. });
  621. if (productSelect && attr.value.productAttr.length) {
  622. attr.value.productSelect = {
  623. ...attr.value.productSelect,
  624. storeName: productInfo.value.storeName,
  625. image: productSelect.image,
  626. sales: productSelect.sales,
  627. weight: productSelect.weight,
  628. price: productSelect.price,
  629. storePrice: productSelect.storePrice,
  630. stock: productSelect.stock,
  631. unique: productSelect.id,
  632. cart_num: 1,
  633. };
  634. attrValue.value = value.join(",");
  635. attrTxt.value = "已选择";
  636. } else if (!productSelect && attr.value.productAttr.length) {
  637. attr.value.productSelect = {
  638. ...attr.value.productSelect,
  639. storeName: productInfo.value.storeName,
  640. image: productInfo.value.image,
  641. sales: productSelect.sales,
  642. weight: productSelect.weight,
  643. price: productInfo.value.price,
  644. storePrice: productSelect.storePrice,
  645. stock: 0,
  646. unique: productInfo.value.id,
  647. cart_num: 1,
  648. };
  649. attrValue.value = "";
  650. attrTxt.value = "请选择";
  651. } else if (!productSelect && !attr.value.productAttr.length) {
  652. attr.value.productSelect = {
  653. ...attr.value.productSelect,
  654. storeName: productInfo.value.storeName,
  655. image: productInfo.value.image,
  656. sales: productSelect.sales,
  657. weight: productSelect.weight,
  658. price: productInfo.value.price,
  659. storePrice: productSelect.storePrice,
  660. stock: productInfo.value.stock,
  661. unique: productInfo.value.id || "",
  662. cart_num: 1,
  663. };
  664. attrValue.value = "";
  665. attrTxt.value = "请选择";
  666. }
  667. };
  668. const getCouponList = async (type = "") => {
  669. try {
  670. const obj = {
  671. page: 1,
  672. limit: 20,
  673. productId: id.value,
  674. type,
  675. };
  676. const { data } = await getCoupons(obj);
  677. coupon.value.list = data;
  678. } catch (err) {
  679. console.error("getCouponList", err);
  680. }
  681. };
  682. const tabCouponType = (type) => {
  683. coupon.value.type = type;
  684. getCouponList(type);
  685. };
  686. const ChangCouponsUseState = (index) => {
  687. coupon.value.list[index].isUse = true;
  688. coupon.value.coupon = false;
  689. };
  690. const selecAttr = () => {
  691. // attr.value.cartAttr = true;
  692. // isOpen.value = true;
  693. showProductPopup.value = true;
  694. handleBtnTpe.value = "buy";
  695. };
  696. // 购买/加入购物车 提交事件
  697. const handleSubmit = async () => {
  698. // if (!isLogin.value) {
  699. // return toLogin();
  700. // }
  701. const productSelect = productValue.value[attrValue.value];
  702. // if (attrValue.value) {
  703. // attr.value.cartAttr = isOpen.value ? attr.value.cartAttr : true;
  704. // } else {
  705. // attr.value.cartAttr = isOpen.value ? true : !attr.value.cartAttr;
  706. // }
  707. // if (attr.value.cartAttr && !isOpen.value) {
  708. // isOpen.value = true;
  709. // return;
  710. // }
  711. if (
  712. attr.value.productAttr.length &&
  713. productSelect?.stock === 0 &&
  714. isOpen.value
  715. ) {
  716. return Toast({
  717. title: "产品库存不足,请选择其它",
  718. icon: "none",
  719. });
  720. }
  721. if (handleBtnTpe.value === "buy") {
  722. showProductPopup.value = false;
  723. getPreOrderFn();
  724. } else if (handleBtnTpe.value === "cart") {
  725. try {
  726. const params = {
  727. productId: parseFloat(id.value),
  728. cartNum: parseFloat(attr.value.productSelect.cart_num),
  729. isNew: false,
  730. productAttrUnique:
  731. attr.value.productSelect?.unique ?? productInfo.value.id,
  732. };
  733. // await postCartAdd(params);
  734. Toast({
  735. title: "添加购物车成功",
  736. icon: "success",
  737. success: () => getCartCount(true),
  738. });
  739. showProductPopup.value = false;
  740. } catch (res) {
  741. showProductPopup.value = false;
  742. Toast({
  743. title: res.message,
  744. icon: "none",
  745. });
  746. }
  747. }
  748. };
  749. // 点击优惠券事件
  750. const handleCoupon = () => {
  751. // if (!isLogin.value) {
  752. // toLogin();
  753. // } else {
  754. // getCouponList(1);
  755. // showCouponPopup.value = true;
  756. // }
  757. };
  758. const onMyEvent = () => {
  759. attr.value.cartAttr = false;
  760. isOpen.value = false;
  761. };
  762. // 关闭规格弹窗
  763. const closeProductPopup = () => {
  764. showProductPopup.value = false;
  765. attr.value.cartAttr = false;
  766. isOpen.value = false;
  767. };
  768. // 立即购买
  769. const goBuy = () => {
  770. // if (!isLogin.value) {
  771. // toLogin();
  772. // } else {
  773. // handleBtnTpe.value = "buy"
  774. // showProductPopup.value = true;
  775. // }
  776. };
  777. // 加入购物车
  778. const joinCart = (e) => {
  779. // if (!isLogin.value) {
  780. // toLogin();
  781. // } else {
  782. // handleBtnTpe.value = "cart"
  783. // showProductPopup.value = true;
  784. // }
  785. };
  786. // 跳到购物车页
  787. const toShopCart = () => {
  788. // if (!isLogin.value) {
  789. // toLogin();
  790. // } else {
  791. // uni.navigateTo({ url: "/pages/order_addcart/order_addcart" });
  792. // }
  793. };
  794. // 获取购物车数量统计
  795. const getCartCount = async (isAnima = false) => {
  796. // if (!isLogin.value) return;
  797. // try {
  798. // const res = await getCartCounts(true, "total");
  799. // CartCount.value = res.data.count;
  800. // if (isAnima) {
  801. // animated.value = true;
  802. // setTimeout(() => {
  803. // animated.value = false;
  804. // }, 1000);
  805. // }
  806. // } catch (err) {
  807. // console.error(err);
  808. // }
  809. };
  810. // 立即购买 加载预订单
  811. const getPreOrderFn = () => {
  812. const params = {
  813. mallType: 0,
  814. preOrderType: type.value === "normal" ? "buyNow" : "video",
  815. orderDetails: [
  816. {
  817. attrValueId: parseFloat(attr.value.productSelect.unique),
  818. productId: parseFloat(id.value),
  819. productNum: parseFloat(attr.value.productSelect.cart_num),
  820. },
  821. ],
  822. };
  823. // getPreOrder(params);
  824. };
  825. const closePosters = () => {
  826. posters.value = false;
  827. };
  828. const posterImageClose = () => {
  829. canvasStatus.value = false;
  830. };
  831. const setDomain = (url) => {
  832. url = url ? url.toString() : "";
  833. return url.includes("https://") ? url : url.replace("http://", "https://");
  834. };
  835. const downloadFilestoreImage = async () => {
  836. try {
  837. const res = await uni.downloadFile({
  838. url: setDomain(productInfo.value.image),
  839. });
  840. storeImage.value = res.tempFilePath;
  841. } catch {
  842. storeImage.value = "";
  843. }
  844. };
  845. const goFriend = () => {
  846. posters.value = false;
  847. };
  848. const getQrcodeFn = async () => {
  849. // try {
  850. // const data = {
  851. // pid: uid.value,
  852. // id: id.value,
  853. // path: "pages/goods_details/index",
  854. // };
  855. // const res = await getQrcode(data);
  856. // base64src(res.data.code, (res) => {
  857. // PromotionCode.value = res;
  858. // });
  859. // } catch (err) {
  860. // errT.value = err;
  861. // }
  862. };
  863. // const make = (uid) => {
  864. // const href = `${location.href.split("?")[0]}?id=${id.value}&spread=${uid}`;
  865. // var qr = new UQRCode();
  866. // // 设置二维码内容
  867. // qr.data = "https://uqrcode.cn/doc";
  868. // // 设置二维码大小,必须与canvas设置的宽高一致
  869. // qr.size = 200;
  870. // // 设置二维码前景图,可以是路径
  871. // qr.foregroundImageSrc =
  872. // "data:image/png;base64,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";
  873. // // 调用制作二维码方法
  874. // qr.make();
  875. // // qr.make({
  876. // // canvasId: 'qrcode',
  877. // // text: href,
  878. // // size: qrcodeSize.value,
  879. // // margin: 10,
  880. // // success: (res) => {
  881. // // PromotionCode.value = res;
  882. // // },
  883. // // fail: () => {
  884. // // Toast({ title: '海报二维码生成失败!', icon: 'none' });
  885. // // },
  886. // // });
  887. // };
  888. const getImageBase64 = async (images) => {
  889. try {
  890. const res = await imageBase64({
  891. url: images,
  892. });
  893. imgTop.value = res.data.code;
  894. } catch (err) {
  895. console.error(err);
  896. }
  897. };
  898. const goPoster = async () => {
  899. uni.showLoading({
  900. title: "海报生成中",
  901. mask: true,
  902. });
  903. posters.value = false;
  904. if (!PromotionCode.value) {
  905. uni.hideLoading();
  906. Toast({
  907. title: errT.value,
  908. icon: "none",
  909. });
  910. return;
  911. }
  912. setTimeout(() => {
  913. if (!imgTop.value) {
  914. uni.hideLoading();
  915. Toast({
  916. title: "无法生成商品海报!",
  917. icon: "none",
  918. });
  919. return;
  920. }
  921. }, 1000);
  922. try {
  923. const res = await uni.downloadFile({
  924. url: imgTop.value,
  925. });
  926. const arrImages = [
  927. posterbackgd.value,
  928. res.tempFilePath,
  929. PromotionCode.value,
  930. ];
  931. const storeName = productInfo.value.storeName;
  932. const price = productInfo.value.storePrice;
  933. setTimeout(() => {
  934. $util.PosterCanvas(
  935. arrImages,
  936. storeName,
  937. price,
  938. productInfo.value.otPrice,
  939. (tempFilePath) => {
  940. imagePath.value = tempFilePath;
  941. canvasStatus.value = true;
  942. uni.hideLoading();
  943. }
  944. );
  945. }, 500);
  946. } catch {
  947. uni.hideLoading();
  948. }
  949. };
  950. // #ifdef MP
  951. const savePosterPath = () => {
  952. uni.getSetting({
  953. success(res) {
  954. if (!res.authSetting["scope.writePhotosAlbum"]) {
  955. uni.authorize({
  956. scope: "scope.writePhotosAlbum",
  957. success() {
  958. uni.saveImageToPhotosAlbum({
  959. filePath: imagePath.value,
  960. success() {
  961. posterImageClose();
  962. Toast({
  963. title: "保存成功",
  964. icon: "success",
  965. });
  966. },
  967. fail() {
  968. Toast({
  969. title: "保存失败",
  970. icon: "none",
  971. });
  972. },
  973. });
  974. },
  975. });
  976. } else {
  977. uni.saveImageToPhotosAlbum({
  978. filePath: imagePath.value,
  979. success() {
  980. posterImageClose();
  981. Toast({
  982. title: "保存成功",
  983. icon: "success",
  984. });
  985. },
  986. fail() {
  987. Toast({
  988. title: "保存失败",
  989. icon: "none",
  990. });
  991. },
  992. });
  993. }
  994. },
  995. });
  996. };
  997. // #endif
  998. const ShareInfo = async () => {
  999. // const data = productInfo.value;
  1000. // let href = location.href;
  1001. // if (wechat.isWeixin()) {
  1002. // href = href.includes("?")
  1003. // ? `${href}&spread=${uid.value}`
  1004. // : `${href}?spread=${uid.value}`;
  1005. // const configAppMessage = {
  1006. // desc: data.storeInfo,
  1007. // title: data.storeName,
  1008. // link: href,
  1009. // imgUrl: data.image,
  1010. // };
  1011. // try {
  1012. // await wechat.wechatEvevt(
  1013. // [
  1014. // "updateAppMessageShareData",
  1015. // "updateTimelineShareData",
  1016. // "onMenuShareAppMessage",
  1017. // "onMenuShareTimeline",
  1018. // ],
  1019. // configAppMessage
  1020. // );
  1021. // } catch (err) {
  1022. // console.error(err);
  1023. // }
  1024. // }
  1025. };
  1026. const goBack = () => {
  1027. const pages = getCurrentPages();
  1028. if (pages.length > 1) {
  1029. uni.navigateBack();
  1030. } else {
  1031. uni.switchTab({
  1032. url: "/pages/mall/index",
  1033. });
  1034. }
  1035. };
  1036. const goHome = () => {
  1037. uni.switchTab({
  1038. url: "/pages/index/index",
  1039. });
  1040. };
  1041. function toMessagePage() {
  1042. uni.navigateTo({
  1043. url: "/pages/message_create/message_create",
  1044. });
  1045. }
  1046. </script>
  1047. <style scoped lang="scss">
  1048. .goodImg {
  1049. width: 100%;
  1050. }
  1051. .uni-swiper-dots-horizontal {
  1052. display: none;
  1053. }
  1054. .product-con {
  1055. height: 100%;
  1056. .mask {
  1057. z-index: 88;
  1058. }
  1059. .goods-nav-bar {
  1060. background-color: rgba(255, 255, 255, 0.3);
  1061. .nav-slot {
  1062. padding: 5rpx 10rpx;
  1063. border-radius: 40rpx;
  1064. border: 1px solid #ccc;
  1065. display: flex;
  1066. justify-content: space-between;
  1067. align-items: center;
  1068. background-color: rgba(255, 255, 255, 0.8);
  1069. }
  1070. }
  1071. .footer {
  1072. padding: 0 20rpx 0 30rpx;
  1073. position: fixed;
  1074. bottom: 0;
  1075. width: 100%;
  1076. box-sizing: border-box;
  1077. height: 100rpx;
  1078. background-color: #fff;
  1079. z-index: 277;
  1080. border-top: 1rpx solid #f0f0f0;
  1081. text-align: center;
  1082. .toAPP {
  1083. min-width: 30%;
  1084. position: absolute;
  1085. top: -85rpx;
  1086. left: 35%;
  1087. .storeAPP {
  1088. background-color: #e9c279;
  1089. color: #fff;
  1090. border-radius: 50rpx;
  1091. line-height: 50rpx;
  1092. padding: 20rpx 20rpx;
  1093. z-index: 999;
  1094. .logoimg {
  1095. display: inline-block;
  1096. width: 50rpx;
  1097. height: 50rpx;
  1098. border-radius: 5rpx;
  1099. vertical-align: middle;
  1100. }
  1101. }
  1102. }
  1103. .item {
  1104. font-size: 18rpx;
  1105. color: #666;
  1106. .iconfont {
  1107. text-align: center;
  1108. font-size: 40rpx;
  1109. &.icon-shoucang1 {
  1110. color: #f00;
  1111. }
  1112. }
  1113. .icon-item {
  1114. font-size: 40rpx;
  1115. position: relative;
  1116. .num {
  1117. color: #fff;
  1118. position: absolute;
  1119. font-size: 18rpx;
  1120. padding: 2rpx 8rpx 3rpx;
  1121. border-radius: 200rpx;
  1122. top: -10rpx;
  1123. right: -10rpx;
  1124. }
  1125. }
  1126. }
  1127. .bnt {
  1128. width: 444rpx;
  1129. height: 76rpx;
  1130. .bnts {
  1131. width: 222rpx;
  1132. text-align: center;
  1133. line-height: 76rpx;
  1134. color: #fff;
  1135. font-size: 28rpx;
  1136. }
  1137. .joinCart {
  1138. border-radius: 50rpx 0 0 50rpx;
  1139. background-image: linear-gradient(to right, #fea10f 0%, #fa8013 100%);
  1140. }
  1141. .buy {
  1142. border-radius: 0 50rpx 50rpx 0;
  1143. background-image: linear-gradient(to right, #fa6514 0%, #e93323 100%);
  1144. }
  1145. }
  1146. }
  1147. .store-info {
  1148. margin-top: 20rpx;
  1149. background-color: #fff;
  1150. .title {
  1151. padding: 0 30rpx;
  1152. font-size: 28rpx;
  1153. color: #282828;
  1154. height: 80rpx;
  1155. line-height: 80rpx;
  1156. border-bottom: 1px solid #f5f5f5;
  1157. }
  1158. .info {
  1159. padding: 0 30rpx;
  1160. height: 126rpx;
  1161. .picTxt {
  1162. width: 615rpx;
  1163. .pictrue {
  1164. width: 76rpx;
  1165. height: 76rpx;
  1166. image {
  1167. width: 100%;
  1168. height: 100%;
  1169. border-radius: 6rpx;
  1170. }
  1171. }
  1172. .text {
  1173. width: 522rpx;
  1174. .name {
  1175. font-size: 30rpx;
  1176. color: #282828;
  1177. }
  1178. .address {
  1179. font-size: 24rpx;
  1180. color: #666;
  1181. margin-top: 3rpx;
  1182. .iconfont {
  1183. color: #707070;
  1184. font-size: 18rpx;
  1185. margin-left: 10rpx;
  1186. }
  1187. .addressTxt {
  1188. max-width: 480rpx;
  1189. }
  1190. }
  1191. }
  1192. }
  1193. .iconfont {
  1194. font-size: 40rpx;
  1195. }
  1196. }
  1197. }
  1198. .superior {
  1199. background-color: #fff;
  1200. margin-top: 30rpx;
  1201. padding: 0 24rpx 30rpx 24rpx;
  1202. .title {
  1203. height: 98rpx;
  1204. image {
  1205. width: 20rpx;
  1206. height: 20rpx;
  1207. }
  1208. .titleTxt {
  1209. margin: 0 10rpx;
  1210. font-size: 30rpx;
  1211. color: #333333;
  1212. // background-image: linear-gradient(to right, #f57a37 0%, #f21b07 100%);
  1213. // -webkit-background-clip: text;
  1214. // -webkit-text-fill-color: transparent;
  1215. }
  1216. }
  1217. .slider-banner {
  1218. width: 100%;
  1219. margin: 0 auto;
  1220. position: relative;
  1221. swiper,
  1222. swiper-item {
  1223. height: 100%;
  1224. width: 100%;
  1225. }
  1226. .list {
  1227. width: 100%;
  1228. .item {
  1229. width: 198rpx;
  1230. margin: 0 22rpx 30rpx 0;
  1231. font-size: 26rpx;
  1232. &:nth-of-type(3n) {
  1233. margin-right: 0;
  1234. }
  1235. .pictrue {
  1236. position: relative;
  1237. width: 100%;
  1238. height: 198rpx;
  1239. image {
  1240. width: 100%;
  1241. height: 100%;
  1242. border-radius: 6rpx;
  1243. }
  1244. }
  1245. .name {
  1246. color: #282828;
  1247. margin-top: 12rpx;
  1248. }
  1249. }
  1250. }
  1251. .swiper-pagination-bullet {
  1252. background-color: #999;
  1253. }
  1254. .swiper-pagination-bullet-active {
  1255. background-color: $theme-color;
  1256. }
  1257. }
  1258. }
  1259. }
  1260. .activityName {
  1261. line-height: 44rpx;
  1262. }
  1263. .bntVideo {
  1264. width: auto !important;
  1265. .buy {
  1266. border-radius: 50rpx !important;
  1267. }
  1268. }
  1269. .row-block {
  1270. background-color: #fff;
  1271. padding: 20rpx;
  1272. font-size: 0.8125rem;
  1273. color: #000;
  1274. .row-express {
  1275. // width: 100%;
  1276. display: flex;
  1277. justify-content: space-between;
  1278. // margin: 20rpx 10rpx 10rpx;
  1279. .left-box {
  1280. .icon {
  1281. vertical-align: middle;
  1282. }
  1283. .text {
  1284. margin: 0 0 0 14rpx;
  1285. font-size: 28rpx;
  1286. vertical-align: middle;
  1287. }
  1288. }
  1289. .express-price {
  1290. display: flex;
  1291. align-items: center;
  1292. }
  1293. }
  1294. .tip-text {
  1295. display: flex;
  1296. align-items: center;
  1297. .text {
  1298. display: flex;
  1299. flex-direction: column;
  1300. margin: 0 0 0 20rpx;
  1301. .t2 {
  1302. font-size: 24rpx;
  1303. color: #666;
  1304. }
  1305. }
  1306. }
  1307. }
  1308. .attribute {
  1309. .line1 {
  1310. width: 600rpx;
  1311. }
  1312. }
  1313. .chat-btn {
  1314. background-color: antiquewhite !important;
  1315. }
  1316. .activity_pin,
  1317. .activity_miao,
  1318. .activity_kan {
  1319. width: auto;
  1320. height: 44rpx;
  1321. line-height: 44rpx;
  1322. padding: 0 15rpx;
  1323. opacity: 1;
  1324. border-radius: 22rpx;
  1325. }
  1326. .activity_pin {
  1327. background: linear-gradient(
  1328. 90deg,
  1329. rgba(233, 51, 35, 1) 0%,
  1330. rgba(250, 101, 20, 1) 100%
  1331. );
  1332. }
  1333. .activity_miao {
  1334. background: linear-gradient(
  1335. 90deg,
  1336. rgba(250, 102, 24, 1) 0%,
  1337. rgba(254, 161, 15, 1) 100%
  1338. );
  1339. margin-left: 19rpx;
  1340. }
  1341. .activity_kan {
  1342. background: linear-gradient(
  1343. 90deg,
  1344. rgba(254, 159, 15, 1) 0%,
  1345. rgba(254, 178, 15, 1) 100%
  1346. );
  1347. margin-left: 19rpx;
  1348. }
  1349. .iconfonts {
  1350. color: #fff !important;
  1351. font-size: 28rpx;
  1352. }
  1353. .activity_title {
  1354. font-size: 24rpx;
  1355. color: #fff;
  1356. }
  1357. .mask {
  1358. position: fixed;
  1359. top: 0;
  1360. left: 0;
  1361. right: 0;
  1362. bottom: 0;
  1363. background-color: rgba(0, 0, 0, 0.6);
  1364. z-index: 9;
  1365. &.mask {
  1366. z-index: 300 !important;
  1367. }
  1368. }
  1369. .head-bar {
  1370. background: #fff;
  1371. }
  1372. .generate-posters {
  1373. width: 100%;
  1374. height: 170rpx;
  1375. background-color: #fff;
  1376. position: fixed;
  1377. left: 0;
  1378. bottom: 0;
  1379. z-index: 388;
  1380. transform: translate3d(0, 100%, 0);
  1381. transition: all 0.3s cubic-bezier(0.25, 0.5, 0.5, 0.9);
  1382. border-top: 1rpx solid #eee;
  1383. &.on {
  1384. transform: translate3d(0, 0, 0);
  1385. }
  1386. .item {
  1387. flex: 50%;
  1388. text-align: center;
  1389. font-size: 30rpx;
  1390. .iconfont {
  1391. font-size: 80rpx;
  1392. color: #5eae72;
  1393. &.icon-haibao {
  1394. color: #5391f1;
  1395. }
  1396. }
  1397. }
  1398. }
  1399. .pictrue_log {
  1400. width: 80upx;
  1401. height: 40upx;
  1402. border-radius: 10upx 0 12upx 0;
  1403. line-height: 40upx;
  1404. font-size: 24upx;
  1405. }
  1406. .pictrue_log_class {
  1407. z-index: 3;
  1408. background: linear-gradient(
  1409. 90deg,
  1410. rgba(246, 122, 56, 1) 0%,
  1411. rgba(241, 27, 9, 1) 100%
  1412. );
  1413. opacity: 1;
  1414. position: absolute;
  1415. top: 0;
  1416. left: 0;
  1417. color: #fff;
  1418. text-align: center;
  1419. }
  1420. .navbar {
  1421. position: fixed;
  1422. background-color: #fff;
  1423. top: 0;
  1424. left: 0;
  1425. z-index: 99;
  1426. width: 100%;
  1427. .navbarH {
  1428. position: relative;
  1429. .navbarCon {
  1430. position: absolute;
  1431. bottom: 0;
  1432. height: 100rpx;
  1433. width: 100%;
  1434. }
  1435. }
  1436. .header {
  1437. height: 96rpx;
  1438. font-size: 30rpx;
  1439. color: #050505;
  1440. background-color: #fff;
  1441. /* #ifdef MP */
  1442. padding-right: 95rpx;
  1443. /* #endif */
  1444. .item {
  1445. position: relative;
  1446. margin: 0 25rpx;
  1447. &.on:before {
  1448. position: absolute;
  1449. width: 60rpx;
  1450. height: 5rpx;
  1451. background-repeat: no-repeat;
  1452. content: "";
  1453. background-image: linear-gradient(to right, #ff3366 0%, #ff6533 100%);
  1454. bottom: -10rpx;
  1455. left: 50%;
  1456. margin-left: -28rpx;
  1457. }
  1458. }
  1459. }
  1460. }
  1461. .icon-xiangzuo {
  1462. margin-top: var(--status-bar-height);
  1463. /* #ifdef H5 */
  1464. top: 20rpx !important;
  1465. /* #endif */
  1466. color: #000;
  1467. position: fixed;
  1468. font-size: 36rpx;
  1469. width: 100rpx;
  1470. height: 56rpx;
  1471. line-height: 54rpx;
  1472. z-index: 1000;
  1473. left: -5rpx;
  1474. }
  1475. .share-box {
  1476. z-index: 1000;
  1477. position: fixed;
  1478. left: 0;
  1479. top: 0;
  1480. width: 100%;
  1481. height: 100%;
  1482. image {
  1483. width: 100%;
  1484. height: 100%;
  1485. }
  1486. }
  1487. .pro-wrapper {
  1488. .iconn {
  1489. background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHgAAAB4CAYAAAA5ZDbSAAAYKElEQVR4nO2deXhTVfrHP0nTlpautHSjZSkt+x42UTYVF5C4gsKIOqOjIxJHZdTfyG+eEZ1xxgVHjeLo6KiIKKsYcAUEBQooASxQKC1QulPolm50S+aPJPXmZm2a3BTo53n6QM49956T+8259yzv+x7ZmC8WcbGjU2migBFAGpAK9AGSgBjzX3dAAYSbT6kBWoA6oNz8VwycAU4BuUCmUquuku5beIZOpXF6XCFRPbyGTqUJAsYCVwCTgTFASjsvYxE6Gkh2UlYBcADYCewB9iu16qb21tmfXBQC61SaeGA2cANwHb8K5GtSzH83mz/X6lSarcCXwCalVn1Wonp4TKcVWKfSRAJzgLuAaUCAXytkIgy4xfzXqlNpfgA+A9Yotepqv9bMAbLO9g7WqTTjgYcxidvdnXNaDK3k1Z4lt6aEorrzFDdUUFpfQXljDfrmehpaGmkxtlLf0ghAqCIYhSyAEEUw4YEhxAZHkBDag6SQHvTqHktaeCJ9w+JRyN3+TdUBa4F3lFr13vZ/a89x9Q7uFALrVBo5plaxGJjkKn9lUy37zmVzqPwkmZWnOVlTQouh1at1UsgD6B+eyIjofozqkcqEuEFEB4W5c2oGsAzYqNSqDV6tlB06tcA6lUYG3Ao8Cwx3lveEvojvS34h42wWx6rzMRiNUlSxDblMxuDI3kyKH8LViSMZENHL1SmHMX2vz5Vatc8q22kF1qk004BXAKWjPGUXqtDm7+Xrwv3k1Xau/kzfsHhuTB6LqvdE4rpFOcuqA/6k1Kp3+KIenU5gnUqTDLwEzHOUZ9+5bD47vYNdZ7MwGH3+lOsQcpmcq+KHcFe/aUzoOdBZ1s+Ap5RadYE3y+80ApvfswuBF7AzzDEYjWwpPsBHuVvJri6UpE7eZmBkMvemXcuMpDHIZTJ7WWqAZ4Dl3no/dwqBdSpNX2AlcKW94ztKM3n7+Jfk6ot9XhcpSItI4uFBs5iWMMJRlt3AAqVWfbqjZfldYJ1KczfwFhAhPpZdXciyoxvQnc/xaR38hTI2ncVDb2NgpN3JMj3wiFKrXtmRMvwmsE6lCQbeBB4QH6tvaWT58c2sPv2D5L1hqZHLZMztN4VHBs0mVBFsL8t7wCKlVt3oyfVdCSz35KJuFJqMaf7WRty9544zd/sLfHpqxyUvLpj6Fp+d+oG5219g77nj9rI8AOw03zOv43WBdSrNKGAfME6Y3mRo4dWjG1i0ZzklDRXeLrbTU9JQwaI9y1l2ZANNhhbx4XHAPvO98ypeFVin0lyPqeUmCdOL6su5b+cyPjm5HSOXfqt1hBEjq05t576dyyiqLxcfTsLUkq/3ZpleE1in0twKaDFNyLeRUZbFgh9fvmiHPr4gu7qQBT++zJ6yY+JDYYBWp9Lc5q2yvCKwTqWZj2myPUiYvjZvJ3/c9w7VTXXeKOaSorqpjkf3/Zt1eTvFh4KANeZ72mE6LLD517YCwXKeESOvZ23kn5lrOv1MlD8xGA38I3MNrx3dKH51BQArdCrN7R0to0MC61SaG4FPEYhrMBp4/tAqVuRu62jdLhs+PrmN5w6tEjeGAGCV+R57jMcC61Sa4cBqBI9lg9HA0kOf8EW+pEuilwTa/L0sPfSJWGTL49rpSpszPBLYPGb7CsGcshEjL2SuZnPBT57W5bJnc8FPvJC5Wvy4DgO+8nSc3G6BzUZvGxAZq715bBOfn8nwpA5dCPj8TAZvHtskTk4GNphnB9uFJy14OaJJjHV5O/kwZ4sHl+rCHh/mbLHXux6HaU6/XbRLYPPCwf3CtIyyLF48vK695XbhghcPryOjLEucfL9ZA7dxW2Dzkp/VL6iovpwlBz7qGgr5AIPRwJIDH9mb8XpLp9L0c/c6bglsXqxfiWDJr8nQwpM/v4e+qd7dsrpoJ/qmep78+T3x3HUE8LFZE5e424IXIlqsf/OYtmv6UQKyqwvRZGnFyVdi0sQlLgXWqTQpmMxs2th37jirTu5ws4pddJRPT+1gn+1S4wtmbZziTgtehmC8W9/SyPOHPr2sV4WkxoiR5w6tajPcNxOOSRunOBVYp9JMBu4Qpr11bNNluZ7rb0obKnnLdnw8B5MDnkMcCmw2Sv8X0GYemF1dyBrb8VkXErEmb6e9fo+VRmKcteBbERmlLzu6oWtI5EcMRgPLjqwXJysxaWUXuwKbu+DPCtO2l/xyyVo/XkzoynPZUZopTl6KAy0dteDZCHyFDEYjy49v9koFu+g4bx//UmywOAyTZjY4EvhJ4Yfvig9wqqbUO7XrosPk6ovZUnxAnPykvbw2DuA6lWYiokmNFblbvVY5byGXyUkLTyQ1IpHk0BiigsIIVXQjQCajtvkC+uZ6ShsqOFVTygl9EY2tzf6uslf5KHcr1/ey6iJdCUwErBbj7Xn4Pyj88NP57E4zYxUWGMK1SaOZnjACZWw6IQFBrk8CWo0GMitOs6vsKN8W6i6JYV52dSH7zmWLHd4eRCSwlWeDOWxCEQLP+sf2vcPOs0d8W1sX9AqN5XfpM7gheSzd3BTVGRllWaw8+T37zmV7oXb+Y3L8MF6b8JAwqQ7oBbSFkxC34DsRiHu2ocrekpVkhCqCWTjoJub0ndyecAoumRQ3hElxQ9h/PodXjqwnR1/ktWtLye6yLM42VBEf0uaf3B2Thu9aEsSdrDuFHzYV7KPVT+Pe0TH9WTf9/5mXOs2r4goZG5vOJ1Of4g8DZyKX+cSLx6cYjAY2FewTJ1tp2PatdCpNAjBVePDrwp99Vjln3NF3Mu9MelT4y/QZATI5vx94I8uveITwwBCfl+dtviq0sYGbCiRYPgh/trMRmL/m6Iv8EjbhvvQZ/HnEXAIkblHjYgfw/lWP0yNYqhBc3uFMbRknrF8xAcBNlg/CuzhTmGtr8SHf1swOt/SZhHqwSvJyLfQPT+TtKxYRdpG15G22Ws2y/EcOoFNpAoGrhTmk7jkPjerDMyPudJ3Rx6RFJPHc6AXIHM/fdzp2nT0qTroaCIRfe9FjEZjjlDfqOVEtXc8yUB7A35T3unwsH6nM4+OT31NYd570iCQeH3orkUGuY6Wdu1DN+ye+Jas6n6jA7jwyeLYjr3sApiYM5/a+V9mzbOyUZFcXUtFYI3y9RGCywsywCGw1c7X/fI6kC/rzUqfRu3tPp3mOVRXwwO7XaDYHPDteXUBNcwPLxv/e6XkXWpv43a5XKa7/dXLjWHUBX85YSpA80OF5fxxyM1uLD1LVVOv+F/ETRoz8fP6EeGZrEpAhF3xo45eKU1LVjSB5IPemXesy35biA23iWjhQkevyvMzK01biAlQ01nBS73xuPVQRzIK0q53m6UwcstVsEvzaybKS/peKDgd/cZvreo0myo0QganhCTZpLgKQAZDSvafNo18uk9GzW6TLc2/vc5XTVt6ZyLTVTAkg16k00UBvS6rBaJR05Wh64ki38s1KGc+81GltYnVXdOOJoa79pBNDerB09AIiAkMBk7gPDZxFbDeboD82hAeGcGX8ELfq529ya4rF8Tp7A9EKRDEiSxoqaDJIs/IiQ8b4WKfR4azy/mnY7Tw48EZKGypJDo11FLXGhhuTx3JN0ijya8uIDg4jJti+uAajgZIGU5TaZkMrClmAy75BZ8EScTctwip6xnAFkC5MkXJyIyk0xm2RLEQEhra1xvYQJFeIvzxg6rxtKT7A/vIcsqsLaTG0Eh0URs9ukYQogjAYjfQPT+TshSpqmxvaXa6U5NaUiL/jIAXQV5iSX1smWYUSQ6MlK0uIESPfFOr4KHcrOfoiBkT0YnriSB4dfDNDono7/NGVN+rJrDjN3nPH2VGayfkLeolr7pxiWzeXVAWmTSzayJNQ4DCF9DNGx6sLeP7Qp+Toi7gxeRxLR9/tdEwsJCY4gumJI5meOJKnh8/hh9LDfJS7lcOVeb6ttJsU1Z0XJ/VWAPFWmeptMvmMZqN3g3i74pOT23nj2BeM7tGftdOX0CcszuNryWXyNrG3lRzilcPrKbvg301aShoqxUlxCqCHMEXKgb1ewug7Lx1ey7q8XTw29Bbmp0736rWvSRzFFT0H8+zBlWwrkX4O34K+2eZ+xsgBq5+xlCGP8uvOSVLOy4fX8UX+XjQTF3pdXAuhimBeGnc/DwzwahyzdlHVaKNdnBxR4DK9hD3F6qY6Cm3fG17li/y9rD+zi1fHP+gqYLdXeHjQTTw0cKbrjD6gpsVGu+5yRFYdUnsu+HLVqri+gpcOr2XxsNslEdfCgwNv5IbksZKVZ8GOdgFyRNHXRR5sPucrH1qNLDuynjExaczp69Q/yycsGXEXSaE9XGf0Ina0C/O7IVJWVb4939cOc7y6gF1lR/nTMOfB4hpam/iz7gOu/ub/ePynd1z2hJcf38yMb5/h3p3LyKrKd5gvVBHMY0MdugxJhhzTPgJttHdmyRu8eWyT12NHr83bxdT44S6HQitzt/Fd0QGqm+r4sfQI/8xc4zDvnrJjvH/iWyoaazhSmccTP73rMC+Yetf9wxM9qr8n2NGuVg5YPbj9YV2YVZXvVe8Jg9HItuKD3NznCpd5G1qt95p09oqyl9eV1eltfe1uU+ET7GjXKsdkLN1GuB9mlwDezv6Sg+UnvXKtrKozNBlaGBc7wGXee9KuYXh0X8BkrvPk8Dsc5p2WMIJZyeORy2TEdYviH8r7XFqhTE3wOAphu7GjXZ0CKEMQwDsquLtfXDtaDK088dO7fDD5CfqGxbs+wQnZ1UX0D08kSO56782ooDA+nLyYC61NLr0m5DIZz41ZwJKRdxEc4N46cWJID3oEh1PRWOM6cweJCrYxXyqTY9ocuY3IQLf2g/QJ+uZ6Htj1Wod9oQrrz9ErNLZd57THJcZdcS2kSLTkGGGrXbkcsFofTJC4ay+msqmWBzPeYHcHXGbqWi7QrZ0i+JIwRTdJykkMsVmdOysHrGw9eoXGSFIZZ9Q2N/DHvf/mw1zP4l8qZAG0SLyQ4YzalguSlJNkq12ejcB2MvkFI0YqGz1b+IgKCqP8gu/fee5y/oI0e0f36m7zWjotB6wCb6RJOG5zxYyk0R6dl9K9J7k1nWObvPMX9PbiTfoEO9qdUABWk8GWna+9veFye0kIiWaYefhioaG1idWnf+BsQxWDI1MYEtWb1PAEm/Hf0Og+VDTWkKMvIt31Pr8+ZUfpL5KUo5AH2Bt9HFEoteoKnUpTAKRYMqaFJ3G82qu7oLabawWtt8nQzPq83XyQs4XyRmszmUB5AEmhMfTsFtlmIXLBPCHxXdEBvwu8Lm+3JOX0D08Uu9nmAxWWgeJ+zAIDjOzRz+8Cz0ga3Sbsh7lbHNo/NRtaOVNbxhk7pkYb8/dw/4DrvRIVwBO+KdJJ5lw+skeqOEkHvy4VZrjILCkRgaFkVp5m9tZneeXIeo+N2yoaa/y2+4u+uZ43sjZKVt4oW80y4FeBrZ4jyph0v3rX6ZvrWXZkg1esFj/I+c4vIRqeP7SKsw3S2GjJkDE2Nl2cbCXwfkz72QIQ2y2CdDs2xBcjTYYWnt7/X0lNkd7I+oLvS6TpXIFp53GRMX8N8DOYBVZq1c3A98IcUyScJPc1Z2rLeHTfv9E3+z46/bvZX/ORxHHFroofKk7aBjSDtbnOV8Ic1yR5fadTv3KkMo/7d/2LAh8Z+hmMBl46vJZ3sr9yndnL2NHqS8t/hAJvAtoGvwMienXIbrgzcqqmlLt/fJmN+Xu8fu3nDq1i9ekfvX5dV/QJi2OA9VCwFWgLLNomsFKrLgV+EOacmTze1/WTnNrmBp4/tIr7di7zqqmQO+6ovmBm8jhx0g9Am3uoeLV6tfDD7JQJkke7kYrDlXks3PMWc7b/nRW52+yOo+2hb65n99mjNkuakxOG+aKaTpHL5MxOmShOttJQvCK+GlME8VCA+JAoJsUN8XsoQ19yqqaU17M28nrWRmKCIxgS1ZuU7j2J7RZBcEAgRqORqqY6iuvLya4u5FRNKUaMyGUyZiaPY+Gg2cSHRDE8ui9RQWGSeoZcGTdEHEusHmcCK7Xqap1Ksxr4rSVtXuq0S1pgIeWNere/q8FoZHPBT2wpPsj81On8Nn0GV8UPZbNt5DmfMS91qjhpNYI4lWA/XrSVqeCEngPd9r67HGlsbeaDnO9QbV1KpQRmORYGRiYzoecgcbKNmaeNwEqtei9g1c28p/81Xq3cpUhVU22HrFDayz22gWv2IAolDI4jvr8o/HBdL6XdIChd+If+4YlclzRGnPyivbyOBN6EYJ1YLpOxcNBNDrJ2ITUPD5qFXGa1VnAEk2Y22BVYqVUbgL8K06YnjkQZk+atOnbhIWNi0uxFJvorIgcGC84GuZ9jXlO0sHjY7RdlXOVLBblMZs/X6gAmreyf4+iAUqs2Ao8L0wZGJjPXD556XZiY23eKvRHN4+A47qTT5qjUqncCa4VpjwyeTYKt/W0XPiYhJJpHBttsjbQWcDoB7s7zdjECD8RQRTB/GTX/ogq3e7EjQ8ZfRs0Xew/WYtLGKS4FVmrVBcAzwrSJPQcxL3Va+2rZhcfclTqVibaTGs+YtXGKuz2m5YjMetRDVF0zXBIwMDKZR4fcLE7OAN5y53y3BDYPmxYgMOsJkit4edz9HoUV7MI9IgJDeXnc/WIvST2wwKyJS9we8yi16tPAImFar9BY/q68t2vo5APkMjl/U95rz0tykVKrdjugd7uUUWrVHwPvC9MmxQ3haSdO0114xtPD7+DKOJtQxv81a+A2njS9RzBZYbZxR9/J3Jc+w4NLdWGP+9JncIftfMN+YGF7r9VugZVadSOmHaetTBoWDZ7NLX0m2T+pC7e5pc8kFtmOdwuBW833vl149PJUatWFmPZZajNfkCFjyYg7mXUJ2nFJxazk8SwZcad4jqEOmGm+5+3G496RUqs+DMwF2kLPyGVynh39G2anTPD0spctN6VM4NnRvxF3WJuAOeZ77REd6v4qteqvgXkIzG3lMjl/Hf0bFnQZCbjN3f2vtiduKzDffI89psPjG6VWvQG4B4HIMmQ8NvQWnh4+p2sI5QS5TM7Tw+fw+NBbxY/lVuAepVa9vsNldPQCAEqtehWixzXA3H5TeH3CQ0QEdU2GiIkICuX1CQ8xt98U8aEm4E7zPe0wXmte5pZ8M4KOF5jGySunPNU1rSlgYGQyK6c8xSTbcW4tcLM3Wq4Frz4/lVr1N8AUwCpARq/QGD6c/ATzU6df1qtQMmTc2W8KH05+wl40o2Jgivkeeg2vvyCVWvVBYAKiyZAgeSCLh92GZuLDl+V6ckJING9M/ANPDZ9jbze1/cAE873zKj7pAZnHbJOB98THrogbzNrpS7ir31Sx4dgliVwm465+U1k7fYm9RzKYpn4nezrOdYVszBeLXOfqADqV5m5MS1s2241lVxey7OgGdOdzbE+8BFDGprN46G2O+h96QK3Uqld0pAydSuP0uM8FNlciFViBaBtbCztKM1l+bDMna0p8Xhcp6B+eyMLBNzEtYYSjLBmYlvw6vM1rpxDYXBE5poWKvyPaRgBMvj7fFR9gRe7WDgcj9RcDI5O5J+1arksa4+j1UwMsAd5ydz3XFZ1GYAs6lSYFeBVwuMa471w2q05tJ6PsmOSbhLQXuUzOpLjBzE+d7mrjj/XA4+6Y2bSHTiewBZ1KMw1YBtj4YFg421DFpoK9fFX4s9v+u1LRJyyOmcnjmJ0yUezCKeYAsFipVe/wRT06rcAAOpVGhmnpcSng1IM6u7qQrcUH2V2WxYnqIkm3oAfTGHZAZC+uih/KNYmj3Jm4OQI8C2ww25j7hE4tsAXz+/kWTGagLheVyxv1/HzuBAcrTnG48jQna0q8HltTIQ+gf3giw6P7MapHKuN7DnC477CIDExPpo3ees8646IQWIhOpZkIPIRpbtutSewWQyuna0s5WVNKUd15iuvLKWmopLxRT01zAw0tjTQbWto21QgJCCJQriBEEUx4YAgxwREkhESRFBpLcvdY+ocn0C8sQRz70Rn1wBrgHbP7rWRcdAJb0Kk0kZhEnodp+tPtuy0RrZi8Cj4F1ii1ammCQotwJbDrXSv8hPmG/Qf4j06liQdmAzcA12FnmCURtcBWTHGoNim1aum2S/eQTiuwEPONfA94T6fSBAFjgSswTYeOQRAp18sUYOoF78TkQb9fqVU3OT+lc9FpH9HtQafSRAMjgHRMW9b3xbRVUIz5LxQIAizbktQDjeZ/y81/xUCe+S8HyFRq1TY7Lnc2XD2i/wckBEniScYuwQAAAABJRU5ErkJggg==");
  1490. width: 100rpx;
  1491. height: 100rpx;
  1492. background-repeat: no-repeat;
  1493. background-size: 100% 100%;
  1494. margin: 0 auto;
  1495. &.iconn1 {
  1496. background-image: url("data:image/png;base64,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");
  1497. }
  1498. }
  1499. }
  1500. .canvas {
  1501. position: fixed;
  1502. z-index: -5;
  1503. opacity: 0;
  1504. }
  1505. .poster-pop {
  1506. position: fixed;
  1507. width: 450rpx;
  1508. height: 714rpx;
  1509. top: 50%;
  1510. left: 50%;
  1511. transform: translateX(-50%);
  1512. margin-top: -432rpx;
  1513. z-index: 399;
  1514. image {
  1515. width: 100%;
  1516. height: 100%;
  1517. display: block;
  1518. }
  1519. .close {
  1520. width: 46rpx;
  1521. height: 75rpx;
  1522. position: fixed;
  1523. right: 0;
  1524. top: -73rpx;
  1525. display: block;
  1526. }
  1527. .save-poster {
  1528. background-color: #df2d0a;
  1529. font-size: 22rpx;
  1530. color: #fff;
  1531. text-align: center;
  1532. height: 76rpx;
  1533. line-height: 76rpx;
  1534. width: 100%;
  1535. }
  1536. .keep {
  1537. color: #fff;
  1538. text-align: center;
  1539. font-size: 25rpx;
  1540. margin-top: 10rpx;
  1541. }
  1542. }
  1543. button {
  1544. padding: 0;
  1545. margin: 0;
  1546. line-height: normal;
  1547. background-color: #fff;
  1548. &::after {
  1549. border: 0;
  1550. }
  1551. }
  1552. action-sheet-item {
  1553. padding: 0;
  1554. height: 240rpx;
  1555. align-items: center;
  1556. display: flex;
  1557. }
  1558. .contact {
  1559. font-size: 16px;
  1560. width: 50%;
  1561. background-color: #fff;
  1562. padding: 8rpx 0;
  1563. border-radius: 0;
  1564. margin: 0;
  1565. line-height: 2;
  1566. &::after {
  1567. border: none;
  1568. }
  1569. }
  1570. .action-sheet {
  1571. font-size: 17px;
  1572. line-height: 1.8;
  1573. width: 50%;
  1574. position: absolute;
  1575. top: 0;
  1576. right: 0;
  1577. padding: 25rpx 0;
  1578. }
  1579. </style>