index.vue 42 KB

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