index.vue 42 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214
  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. let url = `shuibei://`;
  240. let errUrl = "https://a.app.qq.com/o/simple.jsp?pkgname=uni.app.UNI9DE338F";
  241. window.location.href = url;
  242. setTimeout(() => {
  243. window.location.href = errUrl;
  244. }, 3000);
  245. };
  246. // const appStore = useAppStore();
  247. // const isLogin = computed(() => appStore.isLogin);
  248. // const uid = computed(() => appStore.uid);
  249. const attrTxt = ref("请选择");
  250. const attrValue = ref("");
  251. const id = ref("");
  252. const productInfo = ref({});
  253. const productValue = ref([]);
  254. const productAttr = ref([]);
  255. const specExtraList = ref([]);
  256. const combinationId = ref("");
  257. const attr = ref({
  258. cartAttr: false,
  259. productAttr: [],
  260. productSelect: {},
  261. });
  262. const description = ref("");
  263. const opacity = ref(0);
  264. const height = ref(0);
  265. const scrollTop = ref(0);
  266. const sliderImage = ref([]);
  267. const userJoinPink = ref(false);
  268. const type = ref("");
  269. const showProductPopup = ref(false); // 商品规格弹窗
  270. const handleBtnTpe = ref(""); // "buy" or "cart"
  271. // 定义 onChange 方法
  272. const onChange = (e) => {
  273. const isEnded = msTime.value <= Date.now();
  274. if (isEnded) {
  275. timeData.value = { hours: 0, minutes: 0, seconds: 0 };
  276. } else {
  277. timeData.value = e;
  278. }
  279. };
  280. // 计算秒杀是否结束
  281. const isSeckillEnded = computed(() => {
  282. return msTime.value <= Date.now();
  283. });
  284. onLoad((options) => {
  285. uni.getSystemInfo({
  286. success(res) {
  287. height.value = res.windowHeight;
  288. },
  289. });
  290. if (options.combinationId || options.scene) {
  291. combinationId.value = options.combinationId;
  292. }
  293. getGoodsDetails(combinationId.value);
  294. });
  295. onShow(() => {});
  296. onReady(() => {
  297. initwxlaunch();
  298. });
  299. const iptCartNum = (e) => {
  300. attr.value.productSelect.cart_num = e || 1;
  301. };
  302. const handleScroll = (e) => {
  303. const scrollYVal = e.detail.scrollTop;
  304. const opacityVal = scrollYVal / 350 > 1 ? 1 : scrollYVal / 350;
  305. opacity.value = opacityVal;
  306. };
  307. const ChangeAttr = (res) => {
  308. const productSelect = productValue.value[res];
  309. console.log("productSelect", productSelect);
  310. if (productSelect) {
  311. attr.value.productSelect = {
  312. ...attr.value.productSelect,
  313. image: productSelect.image,
  314. sales: productSelect.sales,
  315. weight: productSelect.weight,
  316. price: productSelect.price,
  317. storePrice: productSelect.storePrice,
  318. stock: productSelect.stock,
  319. unique: productSelect.id,
  320. cart_num: 1,
  321. additionalAmount: productSelect.additionalAmount,
  322. };
  323. attrValue.value = res;
  324. attrTxt.value = "已选择";
  325. } else {
  326. attr.value.productSelect = {
  327. ...attr.value.productSelect,
  328. image: productInfo.value.image,
  329. weight: productSelect.weight,
  330. price: productInfo.value.price,
  331. storePrice: productSelect.storePrice,
  332. stock: 0,
  333. unique: productInfo.value.id,
  334. cart_num: 1,
  335. additionalAmount: productSelect.additionalAmount,
  336. };
  337. attrValue.value = "";
  338. attrTxt.value = "请选择";
  339. }
  340. };
  341. const getGoodsDetails = async (productId) => {
  342. try {
  343. const res = await getGroupBuyingProductDetail(productId);
  344. const product = res.data.storeCombination;
  345. msTime.value = res.data.stopTime;
  346. specExtraList.value = res.data.specExtraList || [];
  347. sliderImage.value = JSON.parse(product.sliderImage);
  348. productInfo.value = product;
  349. description.value = product.content;
  350. userJoinPink.value = res.data.userJoinPink;
  351. attr.value.productAttr = res.data.productAttr;
  352. productValue.value = res.data.productValue;
  353. console.log("API Response:", res.data);
  354. console.log("specExtraList:", specExtraList.value);
  355. console.log("productInfo:", productInfo.value);
  356. uni.setNavigationBarTitle({
  357. title: product.storeName.substring(0, 7) + "...",
  358. });
  359. attr.value.productAttr = attr.value.productAttr.map((item) => ({
  360. attrName: item.attrName,
  361. attrValues: item.attrValues.split(","),
  362. id: item.id,
  363. isDel: item.isDel,
  364. productId: item.productId,
  365. type: item.type,
  366. }));
  367. downloadFilestoreImage();
  368. // DefaultSelect();
  369. } catch (err) {
  370. Toast({ title: err.toString(), icon: "none" });
  371. console.error("getGoodsDetails error:", err);
  372. }
  373. };
  374. const DefaultSelect = () => {
  375. let value = [];
  376. console.log("productValue.value", toRaw(productValue.value));
  377. const keys = Object.keys(productValue.value);
  378. for (let i = 0; i < keys.length; i++) {
  379. const key = keys[i];
  380. value = attr.value.productAttr.length ? key.split(",") : [];
  381. }
  382. attr.value.productAttr.forEach((item, i) => {
  383. item.index = value[i];
  384. });
  385. const productSelect = productValue.value[value.join(",")];
  386. if (productSelect && attr.value.productAttr.length) {
  387. attr.value.productSelect = {
  388. ...attr.value.productSelect,
  389. storeName: productInfo.value.storeName,
  390. image: productSelect.image,
  391. sales: productSelect.sales,
  392. weight: productSelect.weight,
  393. price: productSelect.price,
  394. storePrice: productSelect.storePrice,
  395. stock: productSelect.stock,
  396. unique: productSelect.id,
  397. cart_num: 1,
  398. additionalAmount: productSelect.additionalAmount,
  399. };
  400. attrValue.value = value.join(",");
  401. attrTxt.value = "已选择";
  402. } else if (!productSelect && attr.value.productAttr.length) {
  403. attr.value.productSelect = {
  404. ...attr.value.productSelect,
  405. storeName: productInfo.value.storeName,
  406. image: productInfo.value.image,
  407. sales: productSelect.sales,
  408. weight: productSelect.weight,
  409. price: productInfo.value.price,
  410. storePrice: productSelect.storePrice,
  411. stock: 0,
  412. unique: productInfo.value.id,
  413. cart_num: 1,
  414. additionalAmount: productSelect.additionalAmount,
  415. };
  416. attrValue.value = "";
  417. attrTxt.value = "请选择";
  418. } else if (!productSelect && !attr.value.productAttr.length) {
  419. attr.value.productSelect = {
  420. ...attr.value.productSelect,
  421. storeName: productInfo.value.storeName,
  422. image: productInfo.value.image,
  423. sales: productSelect.sales,
  424. weight: productSelect.weight,
  425. price: productInfo.value.price,
  426. storePrice: productSelect.storePrice,
  427. stock: productInfo.value.stock,
  428. unique: productInfo.value.id || "",
  429. cart_num: 1,
  430. additionalAmount: productSelect.additionalAmount,
  431. };
  432. attrValue.value = "";
  433. attrTxt.value = "请选择";
  434. }
  435. };
  436. const selecAttr = () => {
  437. showProductPopup.value = true;
  438. handleBtnTpe.value = "buy";
  439. };
  440. const onMyEvent = () => {
  441. attr.value.cartAttr = false;
  442. };
  443. // 关闭规格弹窗
  444. const closeProductPopup = () => {
  445. showProductPopup.value = false;
  446. attr.value.cartAttr = false;
  447. };
  448. const setDomain = (url) => {
  449. url = url ? url.toString() : "";
  450. return url.includes("https://") ? url : url.replace("http://", "https://");
  451. };
  452. const downloadFilestoreImage = async () => {
  453. try {
  454. const res = await uni.downloadFile({
  455. url: setDomain(productInfo.value.image),
  456. });
  457. } catch {}
  458. };
  459. const goBack = () => {
  460. const pages = getCurrentPages();
  461. if (pages.length > 1) {
  462. uni.navigateBack();
  463. } else {
  464. uni.switchTab({ url: "/pages/mall/index" });
  465. }
  466. };
  467. function toMessagePage() {
  468. uni.navigateTo({ url: "/pages/users/customer_service_message/index" });
  469. }
  470. </script>
  471. <style scoped lang="scss">
  472. .wrapper {
  473. .label-item {
  474. color: #f94200;
  475. }
  476. .introduce {
  477. display: flex;
  478. .tag {
  479. width: 83rpx;
  480. height: 40rpx;
  481. background-color: #f94200;
  482. border-radius: 5rpx;
  483. display: flex;
  484. justify-content: center;
  485. align-items: center;
  486. color: #fff;
  487. font-size: 24rpx;
  488. border-radius: 5rpx;
  489. }
  490. .tag-text {
  491. margin-left: 10rpx;
  492. }
  493. }
  494. }
  495. .product-con {
  496. height: 100%;
  497. .mask {
  498. z-index: 88;
  499. }
  500. .goods-nav-bar {
  501. background-color: rgba(255, 255, 255, 0.3);
  502. .nav-slot {
  503. padding: 5rpx 10rpx;
  504. border-radius: 40rpx;
  505. border: 1px solid #ccc;
  506. display: flex;
  507. justify-content: space-between;
  508. align-items: center;
  509. background-color: rgba(255, 255, 255, 0.8);
  510. }
  511. }
  512. .ms-time {
  513. width: 100%;
  514. position: relative;
  515. image {
  516. width: 100%;
  517. height: 90rpx;
  518. }
  519. .ms-time-text {
  520. position: absolute;
  521. left: 17%;
  522. top: 50%;
  523. transform: translateY(-50%);
  524. color: #fc5072;
  525. }
  526. .ms-time-box {
  527. position: absolute;
  528. right: 2%;
  529. top: 50%;
  530. transform: translateY(-50%);
  531. display: flex;
  532. flex-direction: column;
  533. align-items: center;
  534. justify-content: center;
  535. height: 100%;
  536. color: #fff;
  537. .time {
  538. @include flex;
  539. align-items: center;
  540. &__custom {
  541. margin-top: 4px;
  542. width: 22px;
  543. height: 22px;
  544. border-radius: 4px;
  545. /* #ifndef APP-NVUE */
  546. display: flex;
  547. /* #endif */
  548. justify-content: center;
  549. align-items: center;
  550. &__item {
  551. color: #fff;
  552. font-size: 12px;
  553. text-align: center;
  554. }
  555. }
  556. &__doc {
  557. color: #fff;
  558. padding: 0px 4px;
  559. }
  560. &__item {
  561. color: #606266;
  562. font-size: 15px;
  563. margin-right: 4px;
  564. }
  565. }
  566. }
  567. }
  568. .store-info {
  569. margin-top: 20rpx;
  570. background-color: #fff;
  571. .title {
  572. padding: 0 30rpx;
  573. font-size: 28rpx;
  574. color: #282828;
  575. height: 80rpx;
  576. line-height: 80rpx;
  577. border-bottom: 1px solid #f5f5f5;
  578. }
  579. .info {
  580. padding: 0 30rpx;
  581. height: 126rpx;
  582. .picTxt {
  583. width: 615rpx;
  584. .pictrue {
  585. width: 76rpx;
  586. height: 76rpx;
  587. image {
  588. width: 100%;
  589. height: 100%;
  590. border-radius: 6rpx;
  591. }
  592. }
  593. .text {
  594. width: 522rpx;
  595. .name {
  596. font-size: 30rpx;
  597. color: #282828;
  598. }
  599. .address {
  600. font-size: 24rpx;
  601. color: #666;
  602. margin-top: 3rpx;
  603. .iconfont {
  604. color: #707070;
  605. font-size: 18rpx;
  606. margin-left: 10rpx;
  607. }
  608. .addressTxt {
  609. max-width: 480rpx;
  610. }
  611. }
  612. }
  613. }
  614. .iconfont {
  615. font-size: 40rpx;
  616. }
  617. }
  618. }
  619. .superior {
  620. background-color: #fff;
  621. margin-top: 30rpx;
  622. padding: 0 24rpx 30rpx 24rpx;
  623. .title {
  624. height: 98rpx;
  625. image {
  626. width: 20rpx;
  627. height: 20rpx;
  628. }
  629. .titleTxt {
  630. margin: 0 10rpx;
  631. font-size: 30rpx;
  632. color: #333333;
  633. // background-image: linear-gradient(to right, #f57a37 0%, #f21b07 100%);
  634. // -webkit-background-clip: text;
  635. // -webkit-text-fill-color: transparent;
  636. }
  637. }
  638. .slider-banner {
  639. width: 100%;
  640. margin: 0 auto;
  641. position: relative;
  642. swiper,
  643. swiper-item {
  644. height: 100%;
  645. width: 100%;
  646. }
  647. .list {
  648. width: 100%;
  649. .item {
  650. width: 198rpx;
  651. margin: 0 22rpx 30rpx 0;
  652. font-size: 26rpx;
  653. &:nth-of-type(3n) {
  654. margin-right: 0;
  655. }
  656. .pictrue {
  657. position: relative;
  658. width: 100%;
  659. height: 198rpx;
  660. image {
  661. width: 100%;
  662. height: 100%;
  663. border-radius: 6rpx;
  664. }
  665. }
  666. .name {
  667. color: #282828;
  668. margin-top: 12rpx;
  669. }
  670. }
  671. }
  672. .swiper-pagination-bullet {
  673. background-color: #999;
  674. }
  675. .swiper-pagination-bullet-active {
  676. background-color: $theme-color;
  677. }
  678. }
  679. }
  680. }
  681. .activityName {
  682. line-height: 44rpx;
  683. }
  684. .bntVideo {
  685. width: auto !important;
  686. .buy {
  687. border-radius: 50rpx !important;
  688. }
  689. }
  690. .row-block {
  691. background-color: #fff;
  692. padding: 20rpx;
  693. font-size: 0.8125rem;
  694. color: #000;
  695. .row-express {
  696. // width: 100%;
  697. display: flex;
  698. justify-content: space-between;
  699. // margin: 20rpx 10rpx 10rpx;
  700. .left-box {
  701. .icon {
  702. vertical-align: middle;
  703. }
  704. .text {
  705. margin: 0 0 0 14rpx;
  706. font-size: 28rpx;
  707. vertical-align: middle;
  708. }
  709. }
  710. .express-price {
  711. display: flex;
  712. align-items: center;
  713. }
  714. }
  715. .tip-text {
  716. display: flex;
  717. align-items: center;
  718. .text {
  719. display: flex;
  720. flex-direction: column;
  721. margin: 0 0 0 20rpx;
  722. .t2 {
  723. font-size: 24rpx;
  724. color: #666;
  725. }
  726. }
  727. }
  728. }
  729. .attribute {
  730. .line1 {
  731. width: 600rpx;
  732. color: #000;
  733. .atterTxt {
  734. display: inline-block;
  735. padding: 0 15rpx;
  736. font-size: 26rpx;
  737. // color: #000;
  738. background-color: #ffe4cb;
  739. border-radius: 10rpx;
  740. border: solid 1rpx #ffa666;
  741. }
  742. }
  743. }
  744. .chat-btn {
  745. background-color: antiquewhite !important;
  746. }
  747. .activity_pin,
  748. .activity_miao,
  749. .activity_kan {
  750. width: auto;
  751. height: 44rpx;
  752. line-height: 44rpx;
  753. padding: 0 15rpx;
  754. opacity: 1;
  755. border-radius: 22rpx;
  756. }
  757. .activity_pin {
  758. background: linear-gradient(
  759. 90deg,
  760. rgba(233, 51, 35, 1) 0%,
  761. rgba(250, 101, 20, 1) 100%
  762. );
  763. }
  764. .activity_miao {
  765. background: linear-gradient(
  766. 90deg,
  767. rgba(250, 102, 24, 1) 0%,
  768. rgba(254, 161, 15, 1) 100%
  769. );
  770. margin-left: 19rpx;
  771. }
  772. .activity_kan {
  773. background: linear-gradient(
  774. 90deg,
  775. rgba(254, 159, 15, 1) 0%,
  776. rgba(254, 178, 15, 1) 100%
  777. );
  778. margin-left: 19rpx;
  779. }
  780. .iconfonts {
  781. color: #fff !important;
  782. font-size: 28rpx;
  783. }
  784. .activity_title {
  785. font-size: 24rpx;
  786. color: #fff;
  787. }
  788. .mask {
  789. position: fixed;
  790. top: 0;
  791. left: 0;
  792. right: 0;
  793. bottom: 0;
  794. background-color: rgba(0, 0, 0, 0.6);
  795. z-index: 9;
  796. &.mask {
  797. z-index: 300 !important;
  798. }
  799. }
  800. .head-bar {
  801. background: #fff;
  802. }
  803. .generate-posters {
  804. width: 100%;
  805. height: 170rpx;
  806. background-color: #fff;
  807. position: fixed;
  808. left: 0;
  809. bottom: 0;
  810. z-index: 388;
  811. transform: translate3d(0, 100%, 0);
  812. transition: all 0.3s cubic-bezier(0.25, 0.5, 0.5, 0.9);
  813. border-top: 1rpx solid #eee;
  814. &.on {
  815. transform: translate3d(0, 0, 0);
  816. }
  817. .item {
  818. flex: 50%;
  819. text-align: center;
  820. font-size: 30rpx;
  821. .iconfont {
  822. font-size: 80rpx;
  823. color: #5eae72;
  824. &.icon-haibao {
  825. color: #5391f1;
  826. }
  827. }
  828. }
  829. }
  830. .pictrue_log {
  831. width: 80upx;
  832. height: 40upx;
  833. border-radius: 10upx 0 12upx 0;
  834. line-height: 40upx;
  835. font-size: 24upx;
  836. }
  837. .pictrue_log_class {
  838. z-index: 3;
  839. background: linear-gradient(
  840. 90deg,
  841. rgba(246, 122, 56, 1) 0%,
  842. rgba(241, 27, 9, 1) 100%
  843. );
  844. opacity: 1;
  845. position: absolute;
  846. top: 0;
  847. left: 0;
  848. color: #fff;
  849. text-align: center;
  850. }
  851. .navbar {
  852. position: fixed;
  853. background-color: #fff;
  854. top: 0;
  855. left: 0;
  856. z-index: 99;
  857. width: 100%;
  858. .navbarH {
  859. position: relative;
  860. .navbarCon {
  861. position: absolute;
  862. bottom: 0;
  863. height: 100rpx;
  864. width: 100%;
  865. }
  866. }
  867. .header {
  868. height: 96rpx;
  869. font-size: 30rpx;
  870. color: #050505;
  871. background-color: #fff;
  872. /* #ifdef MP */
  873. padding-right: 95rpx;
  874. /* #endif */
  875. .item {
  876. position: relative;
  877. margin: 0 25rpx;
  878. &.on:before {
  879. position: absolute;
  880. width: 60rpx;
  881. height: 5rpx;
  882. background-repeat: no-repeat;
  883. content: "";
  884. background-image: linear-gradient(to right, #ff3366 0%, #ff6533 100%);
  885. bottom: -10rpx;
  886. left: 50%;
  887. margin-left: -28rpx;
  888. }
  889. }
  890. }
  891. }
  892. .icon-xiangzuo {
  893. margin-top: var(--status-bar-height);
  894. /* #ifdef H5 */
  895. top: 20rpx !important;
  896. /* #endif */
  897. color: #000;
  898. position: fixed;
  899. font-size: 36rpx;
  900. width: 100rpx;
  901. height: 56rpx;
  902. line-height: 54rpx;
  903. z-index: 1000;
  904. left: -5rpx;
  905. }
  906. .share-box {
  907. z-index: 1000;
  908. position: fixed;
  909. left: 0;
  910. top: 0;
  911. width: 100%;
  912. height: 100%;
  913. image {
  914. width: 100%;
  915. height: 100%;
  916. }
  917. }
  918. .pro-wrapper {
  919. .iconn {
  920. background-image: url("data:image/png;base64,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");
  921. width: 100rpx;
  922. height: 100rpx;
  923. background-repeat: no-repeat;
  924. background-size: 100% 100%;
  925. margin: 0 auto;
  926. &.iconn1 {
  927. background-image: url("data:image/png;base64,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");
  928. }
  929. }
  930. }
  931. .canvas {
  932. position: fixed;
  933. z-index: -5;
  934. opacity: 0;
  935. }
  936. .poster-pop {
  937. position: fixed;
  938. width: 450rpx;
  939. height: 714rpx;
  940. top: 50%;
  941. left: 50%;
  942. transform: translateX(-50%);
  943. margin-top: -432rpx;
  944. z-index: 399;
  945. image {
  946. width: 100%;
  947. height: 100%;
  948. display: block;
  949. }
  950. .close {
  951. width: 46rpx;
  952. height: 75rpx;
  953. position: fixed;
  954. right: 0;
  955. top: -73rpx;
  956. display: block;
  957. }
  958. .save-poster {
  959. background-color: #df2d0a;
  960. font-size: 22rpx;
  961. color: #fff;
  962. text-align: center;
  963. height: 76rpx;
  964. line-height: 76rpx;
  965. width: 100%;
  966. }
  967. .keep {
  968. color: #fff;
  969. text-align: center;
  970. font-size: 25rpx;
  971. margin-top: 10rpx;
  972. }
  973. }
  974. button {
  975. padding: 0;
  976. margin: 0;
  977. line-height: normal;
  978. background-color: #fff;
  979. &::after {
  980. border: 0;
  981. }
  982. }
  983. action-sheet-item {
  984. padding: 0;
  985. height: 240rpx;
  986. align-items: center;
  987. display: flex;
  988. }
  989. .contact {
  990. font-size: 16px;
  991. width: 50%;
  992. background-color: #fff;
  993. padding: 8rpx 0;
  994. border-radius: 0;
  995. margin: 0;
  996. line-height: 2;
  997. &::after {
  998. border: none;
  999. }
  1000. }
  1001. .action-sheet {
  1002. font-size: 17px;
  1003. line-height: 1.8;
  1004. width: 50%;
  1005. position: absolute;
  1006. top: 0;
  1007. right: 0;
  1008. padding: 25rpx 0;
  1009. }
  1010. .share-top {
  1011. background-color: rgba(255, 255, 255, 0.8);
  1012. padding: 5rpx 10rpx;
  1013. border-radius: 40rpx;
  1014. }
  1015. .footer {
  1016. padding: 0 20rpx 0 30rpx;
  1017. position: fixed;
  1018. bottom: 0;
  1019. width: 100%;
  1020. box-sizing: border-box;
  1021. height: 100rpx;
  1022. background-color: #fff;
  1023. z-index: 277;
  1024. border-top: 1rpx solid #f0f0f0;
  1025. text-align: center;
  1026. .toAPP {
  1027. min-width: 30%;
  1028. position: absolute;
  1029. top: -85rpx;
  1030. left: 35%;
  1031. .storeAPP {
  1032. background-color: #e9c279;
  1033. color: #fff;
  1034. border-radius: 50rpx;
  1035. line-height: 50rpx;
  1036. padding: 20rpx 20rpx;
  1037. z-index: 999;
  1038. .logoimg {
  1039. display: inline-block;
  1040. width: 50rpx;
  1041. height: 50rpx;
  1042. border-radius: 5rpx;
  1043. vertical-align: middle;
  1044. }
  1045. }
  1046. }
  1047. .item {
  1048. font-size: 18rpx;
  1049. color: #666;
  1050. .iconfont {
  1051. text-align: center;
  1052. font-size: 40rpx;
  1053. &.icon-shoucang1 {
  1054. color: #f00;
  1055. }
  1056. }
  1057. .icon-item {
  1058. font-size: 40rpx;
  1059. position: relative;
  1060. .num {
  1061. color: #fff;
  1062. position: absolute;
  1063. font-size: 18rpx;
  1064. padding: 2rpx 8rpx 3rpx;
  1065. border-radius: 200rpx;
  1066. top: -10rpx;
  1067. right: -10rpx;
  1068. }
  1069. }
  1070. }
  1071. .bnt {
  1072. width: 444rpx;
  1073. height: 76rpx;
  1074. .bnts {
  1075. width: 222rpx;
  1076. text-align: center;
  1077. line-height: 76rpx;
  1078. color: #fff;
  1079. font-size: 28rpx;
  1080. }
  1081. .joinCart {
  1082. border-radius: 50rpx 0 0 50rpx;
  1083. background-image: linear-gradient(to right, #fea10f 0%, #fa8013 100%);
  1084. }
  1085. .buy {
  1086. border-radius: 0 50rpx 50rpx 0;
  1087. background-image: linear-gradient(to right, #fa6514 0%, #e93323 100%);
  1088. }
  1089. }
  1090. }
  1091. </style>