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("");
  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("");
  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>