index.vue 41 KB

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