index.vue 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800
  1. <template>
  2. <view class="content">
  3. <view class="topBox"></view>
  4. <view class="yuanhu"></view>
  5. <view class="shoptopbox2" v-if="!carInfo">
  6. <view class="carinfoBox2">
  7. <view class="carinfoBoxNocar" @click="addCar">
  8. <img src="../../static/timg/addcar.png" alt="" class="carinfonocarIcon">
  9. <view class="carinfoBoxNocarRight">
  10. <view class="carinfoBoxNocarRightTitle">添加我的爱车</view>
  11. <view class="carinfoBoxNocarRightMS">按照车型推荐合适的商品</view>
  12. </view>
  13. </view>
  14. </view>
  15. </view>
  16. <view class="shoptopbox" v-if="carInfo">
  17. <view class="carinfoBox" >
  18. <view class="carinfoBoxTop">
  19. <img :src="carInfo.brandLogo" alt="" class="carLogo" v-if="carInfo.brandLogo">
  20. <img src="../../static/timg/nocar.png" alt="" class="carLogo" v-else>
  21. <view class="carinfoBoxTopCont">
  22. <view class="carinfoBoxTopContTop">
  23. <view class="carInfoplateNumber">{{carInfo.plateNumber}}</view>
  24. <view class="carTnfomilage" v-if="carInfo.milage">{{carInfo.milage}}km</view>
  25. </view>
  26. <view class="carInfocarModel" v-if="carInfo.carModel">{{carInfo.carModel}}</view>
  27. <view class="carInfocarModel" v-else>暂无</view>
  28. </view>
  29. <view class="carinfoBoxTopRight" @click="changeCar">
  30. <img src="../../static/timg/icon_change@2x.png" alt="" class="carinfoBoxTopRightIcon">
  31. <view class="huancheBtn">换车</view>
  32. </view>
  33. </view>
  34. <view class="carInfoBottom">
  35. <view class="carInfoBottomLine">
  36. <view class="carInfoBottomLineTitle">下次保养里程</view>
  37. <view class="carInfoBottomLineTxt" v-if="carInfo.nextCareMilage">{{carInfo.nextCareMilage}}</view>
  38. <view class="carInfoBottomLineTxt" v-else>暂无</view>
  39. </view>
  40. <view class="carInfoBottomLine">
  41. <view class="carInfoBottomLineTitle">下次保养日期</view>
  42. <view class="carInfoBottomLineTxt" v-if="carInfo.nextCareDate">{{carInfo.nextCareDate.slice(0,10)}}</view>
  43. <view class="carInfoBottomLineTxt" v-else>暂无</view>
  44. </view>
  45. <view class="carInfoBottomLine">
  46. <view class="carInfoBottomLineTitle">保养手册</view>
  47. <view class="carInfoBottomLineTxt" @click="information">点击查看</view>
  48. </view>
  49. </view>
  50. </view>
  51. </view>
  52. <!-- 服务顾问 -->
  53. <view class="adviser" v-if="homeCardList.openMUsers" @click="goRoter">
  54. <view class="adviserLeft">
  55. <img src="../../static/timg/pic_def_ava@2x.png" alt="" class="advisertx">
  56. <view class="adviserNema">{{homeCardList.openMUsers.operatorName}}</view>
  57. <view class="adviserms">服务顾问</view>
  58. </view>
  59. <img src="../../static/timg/icon_arrow_right.png" alt="" class="adviserJt">
  60. </view>
  61. <!-- 中间功能应用模块 -->
  62. <view class="modular" v-if="homeCardList.application.length>0">
  63. <view class="swiper-item">
  64. <view class="itemLine" @click="goRoter('onlineBooking')" v-for="(item,index) in homeCardList.application">
  65. <view><img :src="item.icon" alt="" class="itemImg"></view>
  66. <view class="Menusline">{{item.name}}</view>
  67. </view>
  68. </view>
  69. </view>
  70. <view class="advertisement" v-if="homeCardList.ad1.length>0">
  71. <swiper class="swiper2" circular :autoplay="false" :interval="interval"
  72. :duration="duration" :indicator-dots="true" indicator-color="#CCCCCC" indicator-active-color="#D53533">
  73. <swiper-item v-for="(item,index) in homeCardList.ad1">
  74. <view class="swiper-item2" @click="goRoter('onlineBooking')">
  75. <image class="swiper-item2Img" :src="item.icon" mode=""></image>
  76. </view>
  77. </swiper-item>
  78. </swiper>
  79. </view>
  80. <!-- 热门活动 -->
  81. <view class="Hot">
  82. <view class="hotTop">
  83. <view class="hotLeft">
  84. <view class="hotSx"></view>
  85. <view class="hottitle">热门活动</view>
  86. </view>
  87. <view class="hotRight">
  88. <view class="hotMore">更多</view>
  89. <img src="../../static/timg/icon_arrow_right.png" alt="" class="hotMoreJt">
  90. </view>
  91. </view>
  92. <view class="hotLine">
  93. <view class="hotLineTop">
  94. <image class="hotLineTopImg" src="http://phone.66km.cn:8088/thFiles/C678448A-C874-4B42-9EAE-4F8F21D71D27.jpg" mode=""></image>
  95. <view class="hotlineTimebox">
  96. <view class="hotlinestate1">进行中</view>
  97. <view class="hotTime">2022.01.21-2022.02.14</view>
  98. </view>
  99. </view>
  100. <view class="hotName">博世 7月促【CX-200715003】</view>
  101. </view>
  102. <view class="hotLine">
  103. <view class="hotLineTop">
  104. <image class="hotLineTopImg" src="http://phone.66km.cn:8088/thFiles/C678448A-C874-4B42-9EAE-4F8F21D71D27.jpg" mode=""></image>
  105. <view class="hotlineTimebox">
  106. <view class="hotlinestate2">未开始</view>
  107. <view class="hotTime">2022.01.21-2022.02.14</view>
  108. </view>
  109. </view>
  110. <view class="hotName">博世 7月促【CX-200715003】</view>
  111. </view>
  112. </view>
  113. <!-- 热门商品 -->
  114. <view class="Hot">
  115. <view class="hotTop">
  116. <view class="hotLeft">
  117. <view class="hotSx"></view>
  118. <view class="hottitle">热门商品</view>
  119. </view>
  120. <view class="hotRight">
  121. <view class="hotMore">更多</view>
  122. <img src="../../static/timg/icon_arrow_right.png" alt="" class="hotMoreJt">
  123. </view>
  124. </view>
  125. <view class="hotGoodsLine" v-for="(item,index) in 5">
  126. <view>
  127. <image src="../../static/timg/nocar.png" mode="" class="hotGoodsLineImg"></image>
  128. </view>
  129. <view class="hotGoodsLineRIght">
  130. <view class="goodsName">德国马牌 Continental 全新升级6代 TechContct德国马牌 Continental 全新升级6代 TechContct</view>
  131. <view class="Sold">已售 999</view>
  132. <view class="goodsPrice">
  133. <view class="goodsPrice1">店庆价</view>
  134. <view class="goodsPrice2">¥</view>
  135. <view class="goodsPrice3">999</view>
  136. <view class="goodsPrice3">¥893</view>
  137. </view>
  138. </view>
  139. </view>
  140. </view>
  141. <view style="height: 60rpx;"></view>
  142. <!-- 手机号授权 -->
  143. <view class="authorizBox" v-if="authorizShow" @click="authorizShow=false">
  144. <view class="authorizCont" @click.stop="">
  145. <view class="authorizName">{{wxOpenData.miniAppName}}</view>
  146. <view class="authorizMs">您好,欢迎访问本店,授权手机号登录能获取我们最新的促销活动哦~</view>
  147. <button class="authorizContbutton" type="default" open-type="getPhoneNumber" @getphonenumber="decryptPhoneNumber">授权</button>
  148. </view>
  149. <view style="text-align: center;padding-top: 56rpx;">
  150. <image src="../../static/timg/icon_guanbi@2x.png" mode="" class="authorizCloseImg"></image>
  151. </view>
  152. </view>
  153. <!-- <view @getphonenumber="decryptPhoneNumber" >shopId:{{shopId}}</view>
  154. -->
  155. </view>
  156. </template>
  157. <script>
  158. export default {
  159. data() {
  160. return {
  161. shopId: '',
  162. url:'',
  163. wxOpenData:'',
  164. code:'',
  165. carInfo:'',
  166. homeCardList:'',
  167. authorizShow:false,
  168. miniAppName:'',
  169. }
  170. },
  171. onLoad() {
  172. var that=this;
  173. this.$common.getExtStoreId()
  174. var ext=this.$common.getExtStoreId();
  175. //console.log( String(Date.now()))
  176. this.shopId=ext.shopId;
  177. this.url=ext.url;
  178. // uni.setStorage({
  179. // key: 'extdata',
  180. // data: {
  181. // shopId:'E37BB296-5A08-4534-859D-B351BA611AF9',
  182. // },
  183. // success: function () {
  184. // that.uniLogin()
  185. // }
  186. // });
  187. //this.userInfo = uni.getStorageSync("userInfo");
  188. this.userInfo=this.$store.state.userInfo
  189. if(this.userInfo){
  190. //this.wxOpenData = uni.getStorageSync("wxOpenData");
  191. this.getCarList();
  192. this.queryHomeCardList()
  193. }else{
  194. this.uniLogin()
  195. }
  196. },
  197. onShow() {
  198. this.carInfo=this.$store.state.carInfo
  199. },
  200. methods: {
  201. addCar(){
  202. if(!this.userInfo){
  203. this.authorizShow=true;
  204. }else{
  205. uni.navigateTo({
  206. url:'../user/addCar/addCar'
  207. })
  208. }
  209. },
  210. information(){
  211. },
  212. changeCar(){
  213. uni.navigateTo({
  214. url:'../user/addCar/cailist'
  215. })
  216. },
  217. goRoter(url){
  218. if(!this.userInfo){
  219. this.authorizShow=true;
  220. }else{
  221. uni.navigateTo({
  222. url:url
  223. })
  224. }
  225. },
  226. decryptPhoneNumber: function(e) {
  227. console.log(e);
  228. this.code=e.detail.code
  229. this.wxPhoneLogin()
  230. this.authorizShow=false;
  231. },
  232. wxgologin(){
  233. var that=this;
  234. uni.getUserProfile({
  235. lang:'zh_CN',
  236. desc:'登录',
  237. success:(res)=>{
  238. console.log(res);
  239. that.wxdata=res;
  240. uni.setStorage({
  241. key: 'wxdata',
  242. data: res,
  243. success: function () {
  244. that.uniLogin()
  245. }
  246. });
  247. },
  248. fail:(res)=>{
  249. console.log(res)
  250. }
  251. });
  252. },
  253. uniLogin(){
  254. var that=this;
  255. uni.login({
  256. provider: 'weixin',
  257. success: function (loginRes) {
  258. console.log(loginRes);
  259. that.getWxOpenID(loginRes)
  260. }
  261. });
  262. },
  263. getWxOpenID(e){
  264. var that=this;
  265. uni.showLoading({
  266. title: '加载中'
  267. })
  268. this.$http('miniApp2/sys/getWxOpenID', {
  269. code:e.code,
  270. unionId:'EEADACCD-8A19-499D-8AD7-6975D2C93243'
  271. },'GET').then(res => {
  272. this.wxOpenData=res.data;
  273. that.queryHomeCardList()
  274. //that.wxPhoneLogin()
  275. this.$store.commit('mutationswxOpenData', that.wxOpenData)
  276. uni.setStorage({
  277. key: 'wxOpenData',
  278. data: that.wxOpenData,
  279. success: function () {
  280. // that.uniLogin()
  281. }
  282. });
  283. if(this.wxOpenData.loginInfo){
  284. this.$store.commit('mutationsuserInfo', that.wxOpenData.loginInfo.openUser)
  285. this.userInfo=that.wxOpenData.loginInfo.openUser
  286. uni.setStorage({
  287. key: 'userInfo',
  288. data: that.wxOpenData.loginInfo.openUser,
  289. success: function () {
  290. that.getCarList()
  291. }
  292. });
  293. }else{
  294. this.authorizShow=true;
  295. }
  296. })
  297. },
  298. wxPhoneLogin(){
  299. var that=this;
  300. this.$http('miniApp2/sys/wxPhoneLogin', {
  301. appId:'wx33053a645546ec31',
  302. unionId:'EEADACCD-8A19-499D-8AD7-6975D2C93243',
  303. code:this.code,
  304. openId:this.wxOpenData.openid
  305. },'POST').then(res => {
  306. var data = res.data;
  307. if(data.loginInfo){
  308. this.userInfo=data.loginInfo.openUser;
  309. this.$store.commit('mutationsuserInfo', this.userInfo);
  310. this.$store.commit('mutationswxOpenData', data.loginInfo)
  311. uni.setStorage({
  312. key: 'userInfo',
  313. data: data.loginInfo.openUser,
  314. success: function () {
  315. that.getCarList()
  316. that.queryHomeCardList()
  317. }
  318. });
  319. }
  320. })
  321. },
  322. getCarList(){
  323. this.$http('opencarOwnerHome/queryCarInfoList', {
  324. },'GET').then(res => {
  325. if(res.code==401){
  326. this.uniLogin()
  327. }else{
  328. this.carInfo=res.data[0]
  329. this.$store.commit('mutationscarInfo', this.carInfo)
  330. }
  331. })
  332. },
  333. queryHomeCardList(){
  334. //console.log(this.wxOpenData)
  335. this.$http('openHome/queryHomeCardList', {
  336. unionId:'EEADACCD-8A19-499D-8AD7-6975D2C93243'
  337. },'GET').then(res => {
  338. uni.hideLoading();
  339. this.homeCardList=res.data
  340. })
  341. }
  342. }
  343. }
  344. </script>
  345. <style scoped>
  346. .authorizBox{
  347. width: 100vw;
  348. height: 100vh;
  349. background: rgba(0, 0, 0, 0.5);
  350. position: fixed;
  351. top: 0;
  352. left: 0;
  353. }
  354. .authorizCont{
  355. margin-top: 30vh;
  356. width: 564rpx;
  357. height: 408rpx;
  358. background: #FFFFFF;
  359. border-radius: 24rpx;
  360. margin-left: 93rpx;
  361. position: relative;
  362. }
  363. .authorizCloseImg{
  364. width: 62rpx;
  365. height: 62rpx;
  366. }
  367. .sqLogoBox{
  368. width: 180rpx;
  369. height: 180rpx;
  370. background: #FFFFFF;
  371. border-radius: 90rpx;
  372. text-align: center;
  373. position: absolute;
  374. top: -50rpx;
  375. left: 192rpx;
  376. }
  377. .authorizName{
  378. color: #333333;
  379. line-height: 42rpx;
  380. font-size: 30rpx;
  381. text-align: center;
  382. padding-top: 58rpx;
  383. }
  384. .authorizMs{
  385. color: #999999;
  386. line-height: 36rpx;
  387. font-size: 26rpx;
  388. width: 452rpx;
  389. padding-top: 24rpx;
  390. text-align: center;
  391. margin-left: 56rpx;
  392. }
  393. .authorizContbutton{
  394. width: 422rpx;
  395. height: 88rpx;
  396. background: #D53533;
  397. border-radius: 44rpx;
  398. line-height: 88rpx;
  399. text-align: center;
  400. font-size:30rpx;
  401. color: #FFFFFF;
  402. margin-top: 62rpx;
  403. margin-left:71rpx;
  404. }
  405. .content{
  406. min-height: 100vh;
  407. background: #F4F5F7;
  408. }
  409. .topBox{
  410. width: 750rpx;
  411. height: 200rpx;
  412. background: #D53533;
  413. }
  414. .yuanhu{
  415. width: 750rpx;
  416. height: 50rpx;
  417. background: #D53533;
  418. border-radius: 0 0 100% 100%;
  419. }
  420. .carinfoBox{
  421. width: 702rpx;
  422. height: 250rpx;
  423. background: #FFFFFF;
  424. border-radius: 10rpx;
  425. margin-left: 24rpx;
  426. overflow: hidden;
  427. }
  428. .carinfoBox2{
  429. width: 702rpx;
  430. height: 180rpx;
  431. background: #FFFFFF;
  432. border-radius: 10rpx;
  433. margin-left: 24rpx;
  434. overflow: hidden;
  435. }
  436. .carinfoBox2{
  437. }
  438. .carinfoBox .carLogo{
  439. width: 72rpx;height: 72rpx;
  440. }
  441. .carinfoBoxTop{
  442. display: flex;
  443. justify-content: space-between;
  444. padding-top: 29rpx;
  445. padding-left: 24rpx;
  446. padding-right: 20rpx;
  447. padding-bottom: 24rpx;
  448. border: 1px solid #EEEEEE;
  449. }
  450. .carinfoBoxTopCont{
  451. width: 454rpx;
  452. }
  453. .carinfoBoxTopContTop{
  454. display: flex;
  455. }
  456. .carInfoplateNumber{
  457. font-weight: 500;
  458. color: #3C3C3C;
  459. font-size: 30rpx;
  460. line-height: 42rpx;
  461. padding-right: 16rpx;
  462. }
  463. .carTnfomilage{
  464. color: #F19D01;
  465. font-size: 22rpx;
  466. padding: 0rpx 10rpx;
  467. border-radius: 4rpx;
  468. border: 1px solid #F19D01;
  469. height: 32rpx;
  470. line-height: 34rpx;
  471. margin-top: 2rpx;
  472. margin-left: 2rpx;
  473. }
  474. .carInfocarModel{
  475. width: 454rpx;
  476. color: #666666;
  477. font-size: 26rpx;
  478. white-space: nowrap;
  479. overflow: hidden;
  480. text-overflow: ellipsis;
  481. }
  482. .carinfoBoxTopRight{
  483. display: flex;padding-top: 25rpx;
  484. }
  485. .carinfoBoxTopRightIcon{
  486. width: 29rpx;
  487. height: 31rpx;
  488. }
  489. .huancheBtn{
  490. color: #666666; font-size: 26rpx;line-height: 31rpx;
  491. padding-left: 10rpx;
  492. }
  493. .carInfoBottom{
  494. display: flex;
  495. justify-content: space-around;
  496. }
  497. .carInfoBottomLineTitle{
  498. color: #999999;font-size: 24rpx;
  499. text-align: center;
  500. padding-top: 24rpx;
  501. }
  502. .carInfoBottomLineTxt{
  503. color: #3C3C3C;
  504. font-size: 26rpx;
  505. padding-top: 5rpx;
  506. text-align: center;
  507. }
  508. .carinfonocarIcon{
  509. width: 72rpx;
  510. height: 72rpx;
  511. }
  512. .carinfoBoxNocar{
  513. display: flex;
  514. padding-top: 50rpx;
  515. padding-left: 20rpx;
  516. }
  517. .carinfoBoxNocarRightTitle{
  518. font-weight: 500;
  519. color: #3C3C3C;
  520. font-size: 30rpx;
  521. }
  522. .carinfoBoxNocarRightMS{
  523. color: #666666;
  524. font-size: 26rpx;
  525. }
  526. .carinfoBoxNocarRight{
  527. padding-left: 24rpx;
  528. }
  529. .shoptopbox{
  530. margin-top: -200rpx;
  531. }
  532. .shoptopbox2{
  533. margin-top: -170rpx;
  534. }
  535. .adviser{
  536. width: 662rpx;
  537. margin-left: 24rpx;
  538. background: #FFFFFF;
  539. border-radius: 10px;
  540. display: flex;
  541. justify-content: space-between;
  542. padding: 18rpx 20rpx;
  543. margin-top: 20rpx;
  544. }
  545. .adviserLeft{
  546. display: flex;
  547. }
  548. .advisertx{
  549. width: 62rpx;height: 62rpx;
  550. }
  551. .adviserNema{
  552. color: #333333;font-size: 30rpx;
  553. line-height: 62rpx;padding-left: 24rpx;
  554. }
  555. .adviserms{
  556. width: 118rpx;
  557. height: 36rpx;
  558. border-radius: 4rpx;
  559. border: 1px solid #D53533;
  560. line-height: 36rpx;
  561. text-align: center;
  562. margin-top: 12rpx;
  563. margin-left: 20rpx;
  564. color: #D53533;
  565. font-size: 24rpx;
  566. }
  567. .adviserJt{
  568. width: 12rpx;
  569. height: 20rpx;
  570. margin-top: 16rpx;
  571. }
  572. .modular{
  573. width: 702rpx;
  574. /* height: 313rpx; */
  575. background: #FFFFFF;
  576. border-radius: 10px;
  577. margin-top: 20rpx;
  578. margin-left: 24rpx;
  579. padding-bottom: 40rpx;
  580. }
  581. .swiper-item{
  582. display: flex;
  583. flex-wrap: wrap;
  584. }
  585. .itemImg{
  586. width: 46rpx;
  587. height: 46rpx;
  588. }
  589. .Menusline{
  590. font-size: 24rpx;
  591. color: #333333;
  592. }
  593. .itemLine{
  594. width: 20%;
  595. text-align: center;
  596. padding-top: 40rpx;
  597. }
  598. .advertisement{
  599. width: 702rpx;
  600. height: 280rpx;
  601. margin-top: 20rpx;
  602. margin-left: 24rpx;
  603. border-radius: 20rpx;
  604. }
  605. .swiper-item2{
  606. width: 702rpx;
  607. height: 280px;
  608. }
  609. .swiper-item2Img{
  610. width: 702rpx;
  611. height: 280rpx;
  612. }
  613. .hotMoreJt{
  614. width: 12rpx;
  615. height: 20rpx;
  616. margin-top: 6rpx;
  617. }
  618. .Hot{
  619. width: 702rpx;
  620. margin-top: 20rpx;
  621. margin-left: 24rpx;
  622. }
  623. .hotTop{
  624. display: flex;
  625. justify-content: space-between;
  626. padding: 6rpx 0;
  627. }
  628. .hotSx{
  629. width: 8rpx;
  630. height: 30rpx;
  631. background: #FF0000;
  632. border-radius: 5rpx;
  633. }
  634. .hotLeft{
  635. display: flex;
  636. }
  637. .hottitle{
  638. font-weight: 500;
  639. color: #333333;
  640. font-size: 30rpx;
  641. line-height: 30rpx;
  642. margin-left: 16rpx;
  643. }
  644. .hotRight{
  645. display: flex;
  646. }
  647. .hotMore{
  648. line-height: 30rpx;color: #666666;font-size: 24rpx;
  649. margin-right: 16rpx;
  650. }
  651. .hotLineTopImg{
  652. width: 702rpx;
  653. height: 280rpx;
  654. }
  655. .hotLineTop{
  656. position: relative;
  657. height: 280rpx;
  658. }
  659. .hotLine{
  660. margin-top: 20rpx;
  661. border-radius: 10rpx;
  662. background: #FFFFFF;
  663. overflow: hidden;
  664. }
  665. .hotlinestate1{
  666. width: 102rpx;
  667. height: 44rpx;
  668. background:#FBBF00 ;
  669. line-height: 44rpx;
  670. font-weight: 500;
  671. color: #333333;
  672. font-size: 24rpx;
  673. text-align: center;
  674. }
  675. .hotlinestate2{
  676. width: 102rpx;
  677. height: 44rpx;
  678. background:#FF0000 ;
  679. line-height: 44rpx;
  680. font-weight: 500;
  681. color: #FFFFFF;
  682. font-size: 24rpx;
  683. text-align: center;
  684. }
  685. .hotlineTimebox{
  686. position: absolute;
  687. left: 0;
  688. bottom: 0;
  689. background: rgba(0, 0, 0, 0.5);
  690. display: flex;
  691. }
  692. .hotTime{
  693. font-weight: 400;
  694. color: #FFFFFF;
  695. font-size: 24rpx;
  696. line-height: 44rpx;
  697. padding: 0 20rpx;
  698. }
  699. .hotName{
  700. padding: 24rpx 20rpx;
  701. color: #333333;
  702. line-height: 40rpx;
  703. font-size: 28rpx;
  704. }
  705. .hotGoodsLine{
  706. margin-top: 20rpx;
  707. padding: 20rpx;
  708. background: #FFFFFF;
  709. border-radius: 16rpx;
  710. display: flex;
  711. }
  712. .hotGoodsLineImg{
  713. width: 208rpx;
  714. height: 194rpx;
  715. border-radius: 16rpx;
  716. border: 1px solid #EEEEEE;
  717. }
  718. .goodsName{
  719. font-size: 28rpx;
  720. font-family: PingFangSC-Regular, PingFang SC;
  721. font-weight: 400;
  722. color: #333333;
  723. line-height: 40rpx;
  724. text-overflow: -o-ellipsis-lastline;
  725. overflow: hidden;
  726. text-overflow: ellipsis;
  727. display: -webkit-box;
  728. -webkit-line-clamp: 2;
  729. line-clamp: 2;
  730. -webkit-box-orient: vertical;
  731. }
  732. .hotGoodsLineRIght{
  733. padding-left: 24rpx;
  734. }
  735. .goodsPrice{
  736. display: flex;
  737. padding-top: 10rpx;
  738. }
  739. .goodsPrice1{
  740. font-size: 24rpx;
  741. font-weight: 400;
  742. color: #FF0000;
  743. }
  744. .goodsPrice2{
  745. font-size: 22rpx;
  746. font-weight: 400;
  747. color: #FF0000;
  748. }
  749. .goodsPrice3{
  750. font-size: 32rpx;
  751. font-weight: 400;
  752. color: #FF0000;
  753. }
  754. .goodsPrice3{
  755. font-size: 24rpx;
  756. font-weight: 400;
  757. color: #999999;
  758. }
  759. .Sold{
  760. font-weight: 400;
  761. color: #999999;
  762. font-size: 24rpx;
  763. padding-top: 8rpx;
  764. }
  765. </style>