index.vue 42 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217
  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. <uni-icons
  10. customPrefix="iconfont"
  11. size="19"
  12. @click="goBack"
  13. type="icon-fanhui"
  14. />
  15. </view>
  16. </template>
  17. <template #right> </template>
  18. </up-navbar> -->
  19. <view>
  20. <scroll-view
  21. :scroll-top="scrollTop"
  22. scroll-y="true"
  23. scroll-with-animation="true"
  24. :style="'height:' + height + 'px;'"
  25. @scroll="handleScroll"
  26. >
  27. <view id="past0">
  28. <product-con-swiper
  29. @click="previewImage(sliderImage)"
  30. :imgUrls="sliderImage"
  31. :videoline="productInfo.videoLink"
  32. >
  33. </product-con-swiper>
  34. <view class="ms-time">
  35. <image src="/static/images/tg_detail.png"></image>
  36. <text class="ms-time-text"
  37. >团购价:¥{{
  38. (
  39. Number(specExtraList[0].laborCost) *
  40. Number(specExtraList[0].weight) +
  41. Number(specExtraList[0].additionalFee)
  42. ).toFixed(2)
  43. }}</text
  44. >
  45. <view class="ms-time-box">
  46. <view class="ms-time-tips">{{
  47. productInfo.seckillStatusName
  48. }}</view>
  49. <up-count-down
  50. :time="Math.max(msTime - Date.now(), 0)"
  51. format="HH:mm:ss"
  52. autoStart
  53. millisecond
  54. @change="onChange"
  55. >
  56. <view class="time">
  57. <view class="time__custom">
  58. <text class="time__custom__item">
  59. {{ timeData.days.toString().padStart(2, "0") }}
  60. </text>
  61. </view>
  62. <text class="time__doc">:</text>
  63. <view class="time__custom">
  64. <text class="time__custom__item">
  65. {{ timeData.hours.toString().padStart(2, "0") }}
  66. </text>
  67. </view>
  68. <text class="time__doc">:</text>
  69. <view class="time__custom">
  70. <text class="time__custom__item">
  71. {{ timeData.minutes.toString().padStart(2, "0") }}
  72. </text>
  73. </view>
  74. <text class="time__doc">:</text>
  75. <view class="time__custom">
  76. <text class="time__custom__item">
  77. {{ timeData.seconds.toString().padStart(2, "0") }}
  78. </text>
  79. </view>
  80. </view>
  81. </up-count-down>
  82. </view>
  83. </view>
  84. <view class="pad30">
  85. <view class="wrapper mb30 borRadius14">
  86. <view class="introduce">
  87. <view class="tag">现货</view>
  88. <view class="tag-text"> {{ productInfo.storeName }} </view>
  89. </view>
  90. <view class="label acea-row row-between-wrapper">
  91. <view class="label-item"
  92. >工费:
  93. {{ specExtraList[0].laborCost.toFixed(2) || 0 }}元/克</view
  94. >
  95. <view class="label-item"
  96. >重量: {{ specExtraList[0].weight }}克</view
  97. >
  98. <view class="label-item">
  99. 附加费{{ specExtraList[0].additionalFee || 0 }}元</view
  100. >
  101. </view>
  102. <view
  103. class="share acea-row row-between row-bottom"
  104. style="margin-top: 10px"
  105. >
  106. <view class="money font-color">
  107. <text class="num">{{
  108. (
  109. Number(specExtraList[0].laborCost) *
  110. Number(specExtraList[0].weight) +
  111. Number(specExtraList[0].additionalFee)
  112. ).toFixed(2)
  113. }}</text>
  114. </view>
  115. </view>
  116. </view>
  117. <view
  118. class="attribute acea-row row-between-wrapper mb30 borRadius14"
  119. >
  120. <view class="line1">
  121. 已选择 :
  122. <text class="atterTxt" v-for="item in productAttr" :key="item"
  123. >{{ item.attrName }}:{{ item.attrValues }}</text
  124. >
  125. </view>
  126. <view class="iconfont icon-jiantou"></view>
  127. </view>
  128. <view class="row-block mb30 borRadius14">
  129. <view class="row-express">
  130. <view class="left-box">
  131. <uni-icons class="icon" type="cart" size="24"></uni-icons>
  132. <text class="text">48小时送达</text>
  133. </view>
  134. <view class="express-price">
  135. <text class="express-place">广东深圳</text>
  136. </view>
  137. </view>
  138. <up-line color="#ccc" length="100%" margin="10px 0"></up-line>
  139. <view class="tip-text">
  140. <uni-icons size="24" type="hand-up"></uni-icons>
  141. <view class="text">
  142. <text class="t1">买的放心,用的称心</text>
  143. <text class="t2">平台有保障</text>
  144. </view>
  145. </view>
  146. </view>
  147. </view>
  148. </view>
  149. <view class="product-intro" id="past3">
  150. <view class="title">
  151. <image src="/static/images/xzuo.png"></image>
  152. <span class="sp">产品详情</span>
  153. <image src="/static/images/xyou.png"></image>
  154. </view>
  155. <view class="conter">
  156. <up-parse :content="description"></up-parse>
  157. </view>
  158. </view>
  159. <view style="height: 120rpx"></view>
  160. </scroll-view>
  161. </view>
  162. <view class="footer acea-row row-between-wrapper">
  163. <view class="toAPP">
  164. <wx-open-launch-app
  165. id="launch-btn"
  166. appid="wx5f33a4ace799b661"
  167. :extinfo="
  168. '/pages/group_buying/proDetail?combinationId=' + combinationId
  169. "
  170. @error="goShuiBei"
  171. >
  172. <component :is="'script'" v-bind="{ type: 'text/wxtag-template' }">
  173. <button
  174. class="storeAPP"
  175. style="
  176. background-color: #e9c279;
  177. color: #fff;
  178. border-radius: 50rpx;
  179. line-height: 100rpx;
  180. padding: 20rpx 20rpx;
  181. z-index: 999;
  182. box-sizing: border-box;
  183. "
  184. >
  185. 打开水贝商城
  186. </button>
  187. </component>
  188. </wx-open-launch-app>
  189. </view>
  190. </view>
  191. </view>
  192. </template>
  193. <script setup>
  194. import { onReady, onLoad, onShow } from "@dcloudio/uni-app";
  195. import { ref, computed, getCurrentInstance, toRaw } from "vue";
  196. import { useToast } from "@/hooks/useToast";
  197. import wx from "weixin-js-sdk";
  198. // import { useAppStore } from "@/stores/app.js";
  199. import { getGroupBuyingProductDetail, getWechatConfig } from "@/api/index.js";
  200. import productConSwiper from "@/components/productConSwiper";
  201. const { Toast } = useToast();
  202. const msTime = ref(0);
  203. const timeData = ref({});
  204. const app = getApp();
  205. const instance = getCurrentInstance();
  206. const initwxlaunch = () => {
  207. getWechatConfig(encodeURIComponent(location.href.split("#")[0])).then(
  208. (res) => {
  209. wx.config({
  210. debug: res.data.debug, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
  211. appId: res.data.appId, // 必填,公众号的唯一标识
  212. timestamp: res.data.timestamp, // 必填,生成签名的时间戳
  213. nonceStr: res.data.nonceStr, // 必填,生成签名的随机串
  214. signature: res.data.signature, // 必填,签名,// 必填,签名
  215. jsapi_ticket: res.data.jsapi_ticket, // 必填,签名,// 必填,签名
  216. jsApiList: ["wx-open-subscribe", "wx-open-launch-app"], // 必填,需要使用的JS接口列表,这个地方必须至少写一个,即使你一个都不想用'updateTimelineShareData',
  217. openTagList: ["wx-open-subscribe", "wx-open-launch-app"],
  218. // 可选,需要使用的开放标签列表
  219. success: function () {
  220. console.log("wx.config success");
  221. },
  222. error: function (err) {
  223. console.log("wx.config error:", err);
  224. },
  225. });
  226. wx.checkJsApi({
  227. jsApiList: ["wx-open-launch-app"], // 校验跳转APP的标签是否可用
  228. success: function (res) {
  229. console.log("可用");
  230. },
  231. fail: (err) => {
  232. console.log(err, "不可用");
  233. },
  234. });
  235. }
  236. );
  237. };
  238. const goShuiBei = () => {
  239. const path = combinationId.value
  240. ? `/pages/group_buying/proDetail?combinationId=${combinationId.value}`
  241. : "";
  242. const url = `shuibei://${path}`;
  243. const errUrl = "https://a.app.qq.com/o/simple.jsp?pkgname=uni.app.UNI9DE338F";
  244. window.location.href = url;
  245. setTimeout(() => {
  246. window.location.href = errUrl;
  247. }, 3000);
  248. };
  249. // const appStore = useAppStore();
  250. // const isLogin = computed(() => appStore.isLogin);
  251. // const uid = computed(() => appStore.uid);
  252. const attrTxt = ref("请选择");
  253. const attrValue = ref("");
  254. const id = ref("");
  255. const productInfo = ref({});
  256. const productValue = ref([]);
  257. const productAttr = ref([]);
  258. const specExtraList = ref([]);
  259. const combinationId = ref("");
  260. const attr = ref({
  261. cartAttr: false,
  262. productAttr: [],
  263. productSelect: {},
  264. });
  265. const description = ref("");
  266. const opacity = ref(0);
  267. const height = ref(0);
  268. const scrollTop = ref(0);
  269. const sliderImage = ref([]);
  270. const userJoinPink = ref(false);
  271. const type = ref("");
  272. const showProductPopup = ref(false); // 商品规格弹窗
  273. const handleBtnTpe = ref(""); // "buy" or "cart"
  274. // 定义 onChange 方法
  275. const onChange = (e) => {
  276. const isEnded = msTime.value <= Date.now();
  277. if (isEnded) {
  278. timeData.value = { hours: 0, minutes: 0, seconds: 0 };
  279. } else {
  280. timeData.value = e;
  281. }
  282. };
  283. // 计算秒杀是否结束
  284. const isSeckillEnded = computed(() => {
  285. return msTime.value <= Date.now();
  286. });
  287. onLoad((options) => {
  288. uni.getSystemInfo({
  289. success(res) {
  290. height.value = res.windowHeight;
  291. },
  292. });
  293. if (options.combinationId || options.scene) {
  294. combinationId.value = options.combinationId;
  295. }
  296. getGoodsDetails(combinationId.value);
  297. });
  298. onShow(() => {});
  299. onReady(() => {
  300. initwxlaunch();
  301. });
  302. const iptCartNum = (e) => {
  303. attr.value.productSelect.cart_num = e || 1;
  304. };
  305. const handleScroll = (e) => {
  306. const scrollYVal = e.detail.scrollTop;
  307. const opacityVal = scrollYVal / 350 > 1 ? 1 : scrollYVal / 350;
  308. opacity.value = opacityVal;
  309. };
  310. const ChangeAttr = (res) => {
  311. const productSelect = productValue.value[res];
  312. console.log("productSelect", productSelect);
  313. if (productSelect) {
  314. attr.value.productSelect = {
  315. ...attr.value.productSelect,
  316. image: productSelect.image,
  317. sales: productSelect.sales,
  318. weight: productSelect.weight,
  319. price: productSelect.price,
  320. storePrice: productSelect.storePrice,
  321. stock: productSelect.stock,
  322. unique: productSelect.id,
  323. cart_num: 1,
  324. additionalAmount: productSelect.additionalAmount,
  325. };
  326. attrValue.value = res;
  327. attrTxt.value = "已选择";
  328. } else {
  329. attr.value.productSelect = {
  330. ...attr.value.productSelect,
  331. image: productInfo.value.image,
  332. weight: productSelect.weight,
  333. price: productInfo.value.price,
  334. storePrice: productSelect.storePrice,
  335. stock: 0,
  336. unique: productInfo.value.id,
  337. cart_num: 1,
  338. additionalAmount: productSelect.additionalAmount,
  339. };
  340. attrValue.value = "";
  341. attrTxt.value = "请选择";
  342. }
  343. };
  344. const getGoodsDetails = async (productId) => {
  345. try {
  346. const res = await getGroupBuyingProductDetail(productId);
  347. const product = res.data.storeCombination;
  348. msTime.value = res.data.stopTime;
  349. specExtraList.value = res.data.specExtraList || [];
  350. sliderImage.value = JSON.parse(product.sliderImage);
  351. productInfo.value = product;
  352. description.value = product.content;
  353. userJoinPink.value = res.data.userJoinPink;
  354. attr.value.productAttr = res.data.productAttr;
  355. productValue.value = res.data.productValue;
  356. console.log("API Response:", res.data);
  357. console.log("specExtraList:", specExtraList.value);
  358. console.log("productInfo:", productInfo.value);
  359. uni.setNavigationBarTitle({
  360. title: product.storeName.substring(0, 7) + "...",
  361. });
  362. attr.value.productAttr = attr.value.productAttr.map((item) => ({
  363. attrName: item.attrName,
  364. attrValues: item.attrValues.split(","),
  365. id: item.id,
  366. isDel: item.isDel,
  367. productId: item.productId,
  368. type: item.type,
  369. }));
  370. downloadFilestoreImage();
  371. // DefaultSelect();
  372. } catch (err) {
  373. Toast({ title: err.toString(), icon: "none" });
  374. console.error("getGoodsDetails error:", err);
  375. }
  376. };
  377. const DefaultSelect = () => {
  378. let value = [];
  379. console.log("productValue.value", toRaw(productValue.value));
  380. const keys = Object.keys(productValue.value);
  381. for (let i = 0; i < keys.length; i++) {
  382. const key = keys[i];
  383. value = attr.value.productAttr.length ? key.split(",") : [];
  384. }
  385. attr.value.productAttr.forEach((item, i) => {
  386. item.index = value[i];
  387. });
  388. const productSelect = productValue.value[value.join(",")];
  389. if (productSelect && attr.value.productAttr.length) {
  390. attr.value.productSelect = {
  391. ...attr.value.productSelect,
  392. storeName: productInfo.value.storeName,
  393. image: productSelect.image,
  394. sales: productSelect.sales,
  395. weight: productSelect.weight,
  396. price: productSelect.price,
  397. storePrice: productSelect.storePrice,
  398. stock: productSelect.stock,
  399. unique: productSelect.id,
  400. cart_num: 1,
  401. additionalAmount: productSelect.additionalAmount,
  402. };
  403. attrValue.value = value.join(",");
  404. attrTxt.value = "已选择";
  405. } else if (!productSelect && attr.value.productAttr.length) {
  406. attr.value.productSelect = {
  407. ...attr.value.productSelect,
  408. storeName: productInfo.value.storeName,
  409. image: productInfo.value.image,
  410. sales: productSelect.sales,
  411. weight: productSelect.weight,
  412. price: productInfo.value.price,
  413. storePrice: productSelect.storePrice,
  414. stock: 0,
  415. unique: productInfo.value.id,
  416. cart_num: 1,
  417. additionalAmount: productSelect.additionalAmount,
  418. };
  419. attrValue.value = "";
  420. attrTxt.value = "请选择";
  421. } else if (!productSelect && !attr.value.productAttr.length) {
  422. attr.value.productSelect = {
  423. ...attr.value.productSelect,
  424. storeName: productInfo.value.storeName,
  425. image: productInfo.value.image,
  426. sales: productSelect.sales,
  427. weight: productSelect.weight,
  428. price: productInfo.value.price,
  429. storePrice: productSelect.storePrice,
  430. stock: productInfo.value.stock,
  431. unique: productInfo.value.id || "",
  432. cart_num: 1,
  433. additionalAmount: productSelect.additionalAmount,
  434. };
  435. attrValue.value = "";
  436. attrTxt.value = "请选择";
  437. }
  438. };
  439. const selecAttr = () => {
  440. showProductPopup.value = true;
  441. handleBtnTpe.value = "buy";
  442. };
  443. const onMyEvent = () => {
  444. attr.value.cartAttr = false;
  445. };
  446. // 关闭规格弹窗
  447. const closeProductPopup = () => {
  448. showProductPopup.value = false;
  449. attr.value.cartAttr = false;
  450. };
  451. const setDomain = (url) => {
  452. url = url ? url.toString() : "";
  453. return url.includes("https://") ? url : url.replace("http://", "https://");
  454. };
  455. const downloadFilestoreImage = async () => {
  456. try {
  457. const res = await uni.downloadFile({
  458. url: setDomain(productInfo.value.image),
  459. });
  460. } catch {}
  461. };
  462. const goBack = () => {
  463. const pages = getCurrentPages();
  464. if (pages.length > 1) {
  465. uni.navigateBack();
  466. } else {
  467. uni.switchTab({ url: "/pages/mall/index" });
  468. }
  469. };
  470. function toMessagePage() {
  471. uni.navigateTo({ url: "/pages/users/customer_service_message/index" });
  472. }
  473. </script>
  474. <style scoped lang="scss">
  475. .wrapper {
  476. .label-item {
  477. color: #f94200;
  478. }
  479. .introduce {
  480. display: flex;
  481. .tag {
  482. width: 83rpx;
  483. height: 40rpx;
  484. background-color: #f94200;
  485. border-radius: 5rpx;
  486. display: flex;
  487. justify-content: center;
  488. align-items: center;
  489. color: #fff;
  490. font-size: 24rpx;
  491. border-radius: 5rpx;
  492. }
  493. .tag-text {
  494. margin-left: 10rpx;
  495. }
  496. }
  497. }
  498. .product-con {
  499. height: 100%;
  500. .mask {
  501. z-index: 88;
  502. }
  503. .goods-nav-bar {
  504. background-color: rgba(255, 255, 255, 0.3);
  505. .nav-slot {
  506. padding: 5rpx 10rpx;
  507. border-radius: 40rpx;
  508. border: 1px solid #ccc;
  509. display: flex;
  510. justify-content: space-between;
  511. align-items: center;
  512. background-color: rgba(255, 255, 255, 0.8);
  513. }
  514. }
  515. .ms-time {
  516. width: 100%;
  517. position: relative;
  518. image {
  519. width: 100%;
  520. height: 90rpx;
  521. }
  522. .ms-time-text {
  523. position: absolute;
  524. left: 17%;
  525. top: 50%;
  526. transform: translateY(-50%);
  527. color: #fc5072;
  528. }
  529. .ms-time-box {
  530. position: absolute;
  531. right: 2%;
  532. top: 50%;
  533. transform: translateY(-50%);
  534. display: flex;
  535. flex-direction: column;
  536. align-items: center;
  537. justify-content: center;
  538. height: 100%;
  539. color: #fff;
  540. .time {
  541. @include flex;
  542. align-items: center;
  543. &__custom {
  544. margin-top: 4px;
  545. width: 22px;
  546. height: 22px;
  547. border-radius: 4px;
  548. /* #ifndef APP-NVUE */
  549. display: flex;
  550. /* #endif */
  551. justify-content: center;
  552. align-items: center;
  553. &__item {
  554. color: #fff;
  555. font-size: 12px;
  556. text-align: center;
  557. }
  558. }
  559. &__doc {
  560. color: #fff;
  561. padding: 0px 4px;
  562. }
  563. &__item {
  564. color: #606266;
  565. font-size: 15px;
  566. margin-right: 4px;
  567. }
  568. }
  569. }
  570. }
  571. .store-info {
  572. margin-top: 20rpx;
  573. background-color: #fff;
  574. .title {
  575. padding: 0 30rpx;
  576. font-size: 28rpx;
  577. color: #282828;
  578. height: 80rpx;
  579. line-height: 80rpx;
  580. border-bottom: 1px solid #f5f5f5;
  581. }
  582. .info {
  583. padding: 0 30rpx;
  584. height: 126rpx;
  585. .picTxt {
  586. width: 615rpx;
  587. .pictrue {
  588. width: 76rpx;
  589. height: 76rpx;
  590. image {
  591. width: 100%;
  592. height: 100%;
  593. border-radius: 6rpx;
  594. }
  595. }
  596. .text {
  597. width: 522rpx;
  598. .name {
  599. font-size: 30rpx;
  600. color: #282828;
  601. }
  602. .address {
  603. font-size: 24rpx;
  604. color: #666;
  605. margin-top: 3rpx;
  606. .iconfont {
  607. color: #707070;
  608. font-size: 18rpx;
  609. margin-left: 10rpx;
  610. }
  611. .addressTxt {
  612. max-width: 480rpx;
  613. }
  614. }
  615. }
  616. }
  617. .iconfont {
  618. font-size: 40rpx;
  619. }
  620. }
  621. }
  622. .superior {
  623. background-color: #fff;
  624. margin-top: 30rpx;
  625. padding: 0 24rpx 30rpx 24rpx;
  626. .title {
  627. height: 98rpx;
  628. image {
  629. width: 20rpx;
  630. height: 20rpx;
  631. }
  632. .titleTxt {
  633. margin: 0 10rpx;
  634. font-size: 30rpx;
  635. color: #333333;
  636. // background-image: linear-gradient(to right, #f57a37 0%, #f21b07 100%);
  637. // -webkit-background-clip: text;
  638. // -webkit-text-fill-color: transparent;
  639. }
  640. }
  641. .slider-banner {
  642. width: 100%;
  643. margin: 0 auto;
  644. position: relative;
  645. swiper,
  646. swiper-item {
  647. height: 100%;
  648. width: 100%;
  649. }
  650. .list {
  651. width: 100%;
  652. .item {
  653. width: 198rpx;
  654. margin: 0 22rpx 30rpx 0;
  655. font-size: 26rpx;
  656. &:nth-of-type(3n) {
  657. margin-right: 0;
  658. }
  659. .pictrue {
  660. position: relative;
  661. width: 100%;
  662. height: 198rpx;
  663. image {
  664. width: 100%;
  665. height: 100%;
  666. border-radius: 6rpx;
  667. }
  668. }
  669. .name {
  670. color: #282828;
  671. margin-top: 12rpx;
  672. }
  673. }
  674. }
  675. .swiper-pagination-bullet {
  676. background-color: #999;
  677. }
  678. .swiper-pagination-bullet-active {
  679. background-color: $theme-color;
  680. }
  681. }
  682. }
  683. }
  684. .activityName {
  685. line-height: 44rpx;
  686. }
  687. .bntVideo {
  688. width: auto !important;
  689. .buy {
  690. border-radius: 50rpx !important;
  691. }
  692. }
  693. .row-block {
  694. background-color: #fff;
  695. padding: 20rpx;
  696. font-size: 0.8125rem;
  697. color: #000;
  698. .row-express {
  699. // width: 100%;
  700. display: flex;
  701. justify-content: space-between;
  702. // margin: 20rpx 10rpx 10rpx;
  703. .left-box {
  704. .icon {
  705. vertical-align: middle;
  706. }
  707. .text {
  708. margin: 0 0 0 14rpx;
  709. font-size: 28rpx;
  710. vertical-align: middle;
  711. }
  712. }
  713. .express-price {
  714. display: flex;
  715. align-items: center;
  716. }
  717. }
  718. .tip-text {
  719. display: flex;
  720. align-items: center;
  721. .text {
  722. display: flex;
  723. flex-direction: column;
  724. margin: 0 0 0 20rpx;
  725. .t2 {
  726. font-size: 24rpx;
  727. color: #666;
  728. }
  729. }
  730. }
  731. }
  732. .attribute {
  733. .line1 {
  734. width: 600rpx;
  735. color: #000;
  736. .atterTxt {
  737. display: inline-block;
  738. padding: 0 15rpx;
  739. font-size: 26rpx;
  740. // color: #000;
  741. background-color: #ffe4cb;
  742. border-radius: 10rpx;
  743. border: solid 1rpx #ffa666;
  744. }
  745. }
  746. }
  747. .chat-btn {
  748. background-color: antiquewhite !important;
  749. }
  750. .activity_pin,
  751. .activity_miao,
  752. .activity_kan {
  753. width: auto;
  754. height: 44rpx;
  755. line-height: 44rpx;
  756. padding: 0 15rpx;
  757. opacity: 1;
  758. border-radius: 22rpx;
  759. }
  760. .activity_pin {
  761. background: linear-gradient(
  762. 90deg,
  763. rgba(233, 51, 35, 1) 0%,
  764. rgba(250, 101, 20, 1) 100%
  765. );
  766. }
  767. .activity_miao {
  768. background: linear-gradient(
  769. 90deg,
  770. rgba(250, 102, 24, 1) 0%,
  771. rgba(254, 161, 15, 1) 100%
  772. );
  773. margin-left: 19rpx;
  774. }
  775. .activity_kan {
  776. background: linear-gradient(
  777. 90deg,
  778. rgba(254, 159, 15, 1) 0%,
  779. rgba(254, 178, 15, 1) 100%
  780. );
  781. margin-left: 19rpx;
  782. }
  783. .iconfonts {
  784. color: #fff !important;
  785. font-size: 28rpx;
  786. }
  787. .activity_title {
  788. font-size: 24rpx;
  789. color: #fff;
  790. }
  791. .mask {
  792. position: fixed;
  793. top: 0;
  794. left: 0;
  795. right: 0;
  796. bottom: 0;
  797. background-color: rgba(0, 0, 0, 0.6);
  798. z-index: 9;
  799. &.mask {
  800. z-index: 300 !important;
  801. }
  802. }
  803. .head-bar {
  804. background: #fff;
  805. }
  806. .generate-posters {
  807. width: 100%;
  808. height: 170rpx;
  809. background-color: #fff;
  810. position: fixed;
  811. left: 0;
  812. bottom: 0;
  813. z-index: 388;
  814. transform: translate3d(0, 100%, 0);
  815. transition: all 0.3s cubic-bezier(0.25, 0.5, 0.5, 0.9);
  816. border-top: 1rpx solid #eee;
  817. &.on {
  818. transform: translate3d(0, 0, 0);
  819. }
  820. .item {
  821. flex: 50%;
  822. text-align: center;
  823. font-size: 30rpx;
  824. .iconfont {
  825. font-size: 80rpx;
  826. color: #5eae72;
  827. &.icon-haibao {
  828. color: #5391f1;
  829. }
  830. }
  831. }
  832. }
  833. .pictrue_log {
  834. width: 80upx;
  835. height: 40upx;
  836. border-radius: 10upx 0 12upx 0;
  837. line-height: 40upx;
  838. font-size: 24upx;
  839. }
  840. .pictrue_log_class {
  841. z-index: 3;
  842. background: linear-gradient(
  843. 90deg,
  844. rgba(246, 122, 56, 1) 0%,
  845. rgba(241, 27, 9, 1) 100%
  846. );
  847. opacity: 1;
  848. position: absolute;
  849. top: 0;
  850. left: 0;
  851. color: #fff;
  852. text-align: center;
  853. }
  854. .navbar {
  855. position: fixed;
  856. background-color: #fff;
  857. top: 0;
  858. left: 0;
  859. z-index: 99;
  860. width: 100%;
  861. .navbarH {
  862. position: relative;
  863. .navbarCon {
  864. position: absolute;
  865. bottom: 0;
  866. height: 100rpx;
  867. width: 100%;
  868. }
  869. }
  870. .header {
  871. height: 96rpx;
  872. font-size: 30rpx;
  873. color: #050505;
  874. background-color: #fff;
  875. /* #ifdef MP */
  876. padding-right: 95rpx;
  877. /* #endif */
  878. .item {
  879. position: relative;
  880. margin: 0 25rpx;
  881. &.on:before {
  882. position: absolute;
  883. width: 60rpx;
  884. height: 5rpx;
  885. background-repeat: no-repeat;
  886. content: "";
  887. background-image: linear-gradient(to right, #ff3366 0%, #ff6533 100%);
  888. bottom: -10rpx;
  889. left: 50%;
  890. margin-left: -28rpx;
  891. }
  892. }
  893. }
  894. }
  895. .icon-xiangzuo {
  896. margin-top: var(--status-bar-height);
  897. /* #ifdef H5 */
  898. top: 20rpx !important;
  899. /* #endif */
  900. color: #000;
  901. position: fixed;
  902. font-size: 36rpx;
  903. width: 100rpx;
  904. height: 56rpx;
  905. line-height: 54rpx;
  906. z-index: 1000;
  907. left: -5rpx;
  908. }
  909. .share-box {
  910. z-index: 1000;
  911. position: fixed;
  912. left: 0;
  913. top: 0;
  914. width: 100%;
  915. height: 100%;
  916. image {
  917. width: 100%;
  918. height: 100%;
  919. }
  920. }
  921. .pro-wrapper {
  922. .iconn {
  923. background-image: url("data:image/png;base64,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");
  924. width: 100rpx;
  925. height: 100rpx;
  926. background-repeat: no-repeat;
  927. background-size: 100% 100%;
  928. margin: 0 auto;
  929. &.iconn1 {
  930. background-image: url("data:image/png;base64,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");
  931. }
  932. }
  933. }
  934. .canvas {
  935. position: fixed;
  936. z-index: -5;
  937. opacity: 0;
  938. }
  939. .poster-pop {
  940. position: fixed;
  941. width: 450rpx;
  942. height: 714rpx;
  943. top: 50%;
  944. left: 50%;
  945. transform: translateX(-50%);
  946. margin-top: -432rpx;
  947. z-index: 399;
  948. image {
  949. width: 100%;
  950. height: 100%;
  951. display: block;
  952. }
  953. .close {
  954. width: 46rpx;
  955. height: 75rpx;
  956. position: fixed;
  957. right: 0;
  958. top: -73rpx;
  959. display: block;
  960. }
  961. .save-poster {
  962. background-color: #df2d0a;
  963. font-size: 22rpx;
  964. color: #fff;
  965. text-align: center;
  966. height: 76rpx;
  967. line-height: 76rpx;
  968. width: 100%;
  969. }
  970. .keep {
  971. color: #fff;
  972. text-align: center;
  973. font-size: 25rpx;
  974. margin-top: 10rpx;
  975. }
  976. }
  977. button {
  978. padding: 0;
  979. margin: 0;
  980. line-height: normal;
  981. background-color: #fff;
  982. &::after {
  983. border: 0;
  984. }
  985. }
  986. action-sheet-item {
  987. padding: 0;
  988. height: 240rpx;
  989. align-items: center;
  990. display: flex;
  991. }
  992. .contact {
  993. font-size: 16px;
  994. width: 50%;
  995. background-color: #fff;
  996. padding: 8rpx 0;
  997. border-radius: 0;
  998. margin: 0;
  999. line-height: 2;
  1000. &::after {
  1001. border: none;
  1002. }
  1003. }
  1004. .action-sheet {
  1005. font-size: 17px;
  1006. line-height: 1.8;
  1007. width: 50%;
  1008. position: absolute;
  1009. top: 0;
  1010. right: 0;
  1011. padding: 25rpx 0;
  1012. }
  1013. .share-top {
  1014. background-color: rgba(255, 255, 255, 0.8);
  1015. padding: 5rpx 10rpx;
  1016. border-radius: 40rpx;
  1017. }
  1018. .footer {
  1019. padding: 0 20rpx 0 30rpx;
  1020. position: fixed;
  1021. bottom: 0;
  1022. width: 100%;
  1023. box-sizing: border-box;
  1024. height: 100rpx;
  1025. background-color: #fff;
  1026. z-index: 277;
  1027. border-top: 1rpx solid #f0f0f0;
  1028. text-align: center;
  1029. .toAPP {
  1030. min-width: 30%;
  1031. position: absolute;
  1032. top: -85rpx;
  1033. left: 35%;
  1034. .storeAPP {
  1035. background-color: #e9c279;
  1036. color: #fff;
  1037. border-radius: 50rpx;
  1038. line-height: 50rpx;
  1039. padding: 20rpx 20rpx;
  1040. z-index: 999;
  1041. .logoimg {
  1042. display: inline-block;
  1043. width: 50rpx;
  1044. height: 50rpx;
  1045. border-radius: 5rpx;
  1046. vertical-align: middle;
  1047. }
  1048. }
  1049. }
  1050. .item {
  1051. font-size: 18rpx;
  1052. color: #666;
  1053. .iconfont {
  1054. text-align: center;
  1055. font-size: 40rpx;
  1056. &.icon-shoucang1 {
  1057. color: #f00;
  1058. }
  1059. }
  1060. .icon-item {
  1061. font-size: 40rpx;
  1062. position: relative;
  1063. .num {
  1064. color: #fff;
  1065. position: absolute;
  1066. font-size: 18rpx;
  1067. padding: 2rpx 8rpx 3rpx;
  1068. border-radius: 200rpx;
  1069. top: -10rpx;
  1070. right: -10rpx;
  1071. }
  1072. }
  1073. }
  1074. .bnt {
  1075. width: 444rpx;
  1076. height: 76rpx;
  1077. .bnts {
  1078. width: 222rpx;
  1079. text-align: center;
  1080. line-height: 76rpx;
  1081. color: #fff;
  1082. font-size: 28rpx;
  1083. }
  1084. .joinCart {
  1085. border-radius: 50rpx 0 0 50rpx;
  1086. background-image: linear-gradient(to right, #fea10f 0%, #fa8013 100%);
  1087. }
  1088. .buy {
  1089. border-radius: 0 50rpx 50rpx 0;
  1090. background-image: linear-gradient(to right, #fa6514 0%, #e93323 100%);
  1091. }
  1092. }
  1093. }
  1094. </style>