shopDetail.vue 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371
  1. <template>
  2. <view class="cont">
  3. <view v-if="shopdata">
  4. <view class="top">
  5. <swiper class="swiper" :circular="true" :indicator-dots="true" indicator-active-color="#FF4F00"
  6. v-if="shopImg.length>0">
  7. <swiper-item v-for="(item,index) in shopImg">
  8. <view class="swiper-item">
  9. <image :src="item" mode="widthFix" class="swpImg"></image>
  10. </view>
  11. </swiper-item>
  12. </swiper>
  13. <image src="../../static/img/750500.png" mode="" class="swpImg" v-else></image>
  14. <!-- <view class="Member" @click="deleteMember" v-if="shopdata.isAttention">取消关注</view>
  15. <view class="Member" @click="Member" v-if="!shopdata.isAttention">关注</view> -->
  16. </view>
  17. <!-- 店铺主体 -->
  18. <view class="shopMain">
  19. <view class="shopName">{{shopdata.shopName}}</view>
  20. <view class="pingfenBox" @click="goAppraise(shopdata.shopId)">
  21. <view class="fenshuBox" v-if="shopdata.shopScore"><span
  22. class="fenshuNum">{{shopdata.shopScore}}</span> <span class="fenshuTxt">分</span></view>
  23. <view class="fenshuBox" v-if="!shopdata.shopScore"> <span class="fenshuTxt2">暂无评分</span></view>
  24. <view class="shuxian"></view>
  25. <span class="cishu">服务次数 {{shopdata.sheetSum}}</span>
  26. <view class="shuxian"></view>
  27. <span class="cishu">评价数 {{shopdata.evaluateSum}}</span>
  28. <image src="../../static/img/jt.png" mode="" class="pingfenImg"></image>
  29. </view>
  30. <!-- 是否营业 -->
  31. <view class="business">
  32. <view class="businessTitle">营业时间:</view>
  33. <view class="businessTitme"> <span v-if="shopdata.startTime">{{shopdata.startTime}}</span>-<span
  34. v-if="shopdata.endTime">{{shopdata.endTime}}</span> </view>
  35. </view>
  36. <!-- 品牌 -->
  37. <view class="brandsBox">
  38. <view class="brandsLine" v-if="shopdata.levelName">{{shopdata.levelName}}</view>
  39. <view v-for="(item,index) in brandsList" class="brandsLine2">{{item}}</view>
  40. </view>
  41. </view>
  42. <!-- 地图 -->
  43. <view class="mapBox">
  44. <view class="mapLeft">
  45. <view class="dingwBox">
  46. <image src="../../static/img/icon_coordinate.png" mode="" class="mapdwImg"></image>
  47. <view class="distance" v-if="shopdata.distance&&shopdata.distance!= '0.00'">距离
  48. {{shopdata.distance}}km
  49. </view>
  50. <view class="distance" v-else>距离 --km</view>
  51. </view>
  52. <view class="mapaddress">{{shopdata.provinceName}}{{shopdata.cityName}}{{shopdata.areaName}}
  53. <span v-if="shopdata.address">{{shopdata.address}}</span>
  54. </view>
  55. </view>
  56. <view class="shopsx"></view>
  57. <view class="shopRightBox" @click="map">
  58. <view>
  59. <image src="../../static/img/icon_map.png" mode="" class="shopRightImg"></image>
  60. </view>
  61. <view class="shopRihgtTxt">地图</view>
  62. </view>
  63. <view class="shopsx"></view>
  64. <view class="shopRightBox" @click="call">
  65. <view>
  66. <image src="../../static/img/icon_phone2.png" mode="" class="shopRightImg"></image>
  67. </view>
  68. <view class="shopRihgtTxt">电话</view>
  69. </view>
  70. </view>
  71. <!-- 去保养 -->
  72. <view class="bottom">
  73. <view class="care" @click="goCare">去保养</view>
  74. </view>
  75. <!-- 车型里程 -->
  76. <!-- <view class="Cartop">
  77. <view class="CartopLeft">
  78. <image :src="maintainCarData.brandLogo" mode="" class="CarbrandLogo" @click="carEdit"></image>
  79. <view class="carName" @click="carEdit">
  80. <span v-if="maintainCarData.brand"> {{maintainCarData.brand}}</span>
  81. <span v-if="maintainCarData.series">-{{maintainCarData.series}}</span>
  82. <span v-if="!maintainCarData.brand">添加我的爱车</span>
  83. </view>
  84. <image src="../../static/img/icon_edit.png" mode="" class="CartopEdit" @click="carEdit"></image>
  85. </view>
  86. <view class="CartopRight">
  87. <input type="text" v-model="maintainCarData.milage" @confirm="getData" value="" placeholder="请输入当前里程" class="CartopInput" placeholder-style="color:#999999;"/>
  88. <view>
  89. <image src="../../static/img/icon_edit.png" mode="" class="CartopEdit" @click="milageEdit"></image>
  90. </view>
  91. </view>
  92. </view> -->
  93. <!-- 车型里程 -->
  94. <!-- 保养 -->
  95. <!-- <view class="main" style="margin-top: 20rpx;">
  96. <view class="mainLeft">
  97. <scroll-view scroll-y="true" class="mainscrollView">
  98. <view class="mainLeftLine" v-for="(item,index) in mealData" :class="{lineLeftActive:leftIndex==index}"
  99. @click="leftClick(item,index)">
  100. <span>{{item.name}}</span>
  101. <view class="lineNum" v-show="item.num!=0">{{item.num}}</view>
  102. </view>
  103. </scroll-view>
  104. </view>
  105. <view class="mainRight">
  106. <scroll-view scroll-y="true" class="mainscrollView">
  107. <view v-show="!mealData[leftIndex].listPackage||mealData[leftIndex].listPackage.length==0">
  108. <view class="nodataBox">
  109. <image src="../../static/img/nodata.png" mode="widthFix" class="nodataImg"></image>
  110. <view class="noTxt">暂无数据</view>
  111. </view>
  112. </view>
  113. <view class="mainRightLine" v-for="(item,index) in mealData[leftIndex].listPackage">
  114. <view class="contTop">
  115. <view class="contTopLeft">
  116. <view class="listPackgeName"> {{item.name}} </view>
  117. <view class="listPackgeMs">10000公里(或6个月)/次 | 机油参考用量4L</view>
  118. </view>
  119. <view class="contTopRight" @click="listcheck(item)">
  120. <image src="../../static/img/login_icon_checked.png" mode="" class="imgPrivacy" v-show="item.planItem"></image>
  121. <image src="../../static/img/login_icon_uncheck.png" mode="" class="imgPrivacy" v-show="!item.planItem"></image>
  122. </view>
  123. </view>
  124. <view class="contZk">
  125. <view class="contZkMain" v-show="item.planItem">
  126. <view v-for="(vf,findex) in item.listGoodsAll">
  127. <view class="goodsItemLIne" v-for="(v,i) in vf" v-if="i==0" @click="goGoods(v)">
  128. <image :src="v.picUrl" mode="" class="goodsImg" v-if="v.picUrl"></image>
  129. <image src="../../static/img/noimg.png" mode="" class="goodsImg sm" v-else></image>
  130. <view class="goodsCont">
  131. <view class="goodsContTop">
  132. <view class="goodsItemName">{{v.showName}}</view>
  133. <view class="replace" @click.stop="replace(vf,index,findex,i)" v-if="vf.length>1">更换</view>
  134. </view>
  135. <view class="goodsCOntBOttom">
  136. <view class="salePrice">¥{{v.salePrice}}</view>
  137. <view class="as">
  138. <view class="asa" @click.stop="reduce(v)">-</view>
  139. <view class="asNum">{{v.qty}}</view>
  140. <view class="asa" @click.stop="plus(v)">+</view>
  141. </view>
  142. </view>
  143. </view>
  144. </view>
  145. </view>
  146. <view class="goodsItemLIne" v-for="(v,i) in item.listItem">
  147. <image :src="v.picUrl" mode="" class="goodsImg" v-if="v.picUrl"></image>
  148. <image src="../../static/img/noimg.png" mode="" class="goodsImg sm" v-else></image>
  149. <view class="goodsCont">
  150. <view class="goodsContTop">
  151. <view class="goodsItemName">{{v.showName}}</view>
  152. </view>
  153. <view class="goodsCOntBOttom">
  154. <view class="salePrice">¥{{v.salePrice}}</view>
  155. <view class="itemNum">x1</view>
  156. </view>
  157. </view>
  158. </view>
  159. </view>
  160. </view>
  161. </view>
  162. </scroll-view>
  163. </view>
  164. </view> -->
  165. <!-- 保养 -->
  166. <!-- 底部 -->
  167. <!-- <view class="bottom">
  168. <view class="bottomLeft">
  169. <view class="caidan" @click="caidanClick">
  170. <image src="../../static/img/caidan.png" mode="" class="caidanImg"></image>
  171. <view class="total" v-show="total>0">{{total}}</view>
  172. </view>
  173. <view>
  174. <view class="heji"> <span class="heji1">合计</span> <span class="hejiNum">¥{{totalhj}}</span> </view>
  175. <view class="hejiMs">商品¥{{goodsTotal}}+工时费¥{{salePriceTotal}}</view>
  176. </view>
  177. </view>
  178. <view class="settlement" @click="settlement">去结算</view>
  179. </view> -->
  180. <!-- <view class="caidanTk" v-show="qingdanShow" @click="qingdanShow=false">
  181. <view class="tkCont" @click.stop="">
  182. <view class="caidanTkTop" >
  183. <view class="tkTopTitle">清单</view>
  184. <view class="topTopright">
  185. <view class="empty" @click.stop="empty">清空</view>
  186. <view class="close" @click="qingdanShow=false">X</view>
  187. </view>
  188. </view>
  189. <view class="tkMain">
  190. <scroll-view scroll-y="true" class="tkMainSv">
  191. <view class="qingdanLine" v-for="(item,index) in orderData">
  192. <view class="mainTitle">{{item.name}}</view>
  193. <view class="goodsItem" v-for="(v,i) in item.listGoodsAll">
  194. <view>
  195. <image :src="v.picUrl" mode="" class="goodsImg" v-if="v.picUrl"></image>
  196. <image src="../../static/img/noimg.png" mode="" class="goodsImg " v-else></image>
  197. </view>
  198. <view class="goodsItemRight" >
  199. <view class="goodsItemName">{{v.goodsName}}</view>
  200. <view class="goodsItemBottom">
  201. <view class="goodssalePrice">¥{{v.salePrice}}</view>
  202. <view class="goodsNum">x{{v.qty}}</view>
  203. </view>
  204. </view>
  205. </view>
  206. <view class="goodsItem" v-for="(v,i) in item.listItem">
  207. <view>
  208. <image :src="v.picUrl" mode="" class="goodsImg" v-if="v.picUrl"></image>
  209. <image src="../../static/img/noimg.png" mode="" class="goodsImg " v-else></image>
  210. </view>
  211. <view class="goodsItemRight" >
  212. <view class="goodsItemName">{{v.itemName}}</view>
  213. <view class="goodsItemBottom">
  214. <view class="goodssalePrice">¥{{v.salePrice}}</view>
  215. <view class="goodsNum">x{{v.qty}}</view>
  216. </view>
  217. </view>
  218. </view>
  219. </view>
  220. </scroll-view>
  221. </view>
  222. </view>
  223. </view> -->
  224. </view>
  225. </view>
  226. </template>
  227. <script>
  228. export default {
  229. data() {
  230. return {
  231. shopId: '',
  232. location: '',
  233. shopdata: '',
  234. shopImg: [],
  235. indicatorcolor: 'rgba(255, 79, 0)',
  236. brandsList: [],
  237. maintainCarData: '',
  238. mealData: '',
  239. leftIndex: 0,
  240. total: 0,
  241. qingdanShow: false,
  242. totalhj: 0,
  243. goodsTotal: 0,
  244. salePriceTotal: 0,
  245. orderData: [],
  246. replaceIndex1: '',
  247. replaceIndex2: '',
  248. brand: '',
  249. }
  250. },
  251. onShow() {
  252. /* var maintainCarData2=uni.getStorageSync("maintainCarData");
  253. if(this.maintainCarData.id!=maintainCarData2.id){
  254. this.maintainCarData=maintainCarData2;
  255. if(this.maintainCarData.milage==0){
  256. this.maintainCarData.milage='';
  257. }
  258. this.getData();
  259. }
  260. var replaceData=uni.getStorageSync("replaceData");
  261. if(replaceData){
  262. replaceData.qty=1;
  263. console.log(replaceData)
  264. this.mealData[this.leftIndex].listPackage[this.replaceIndex1].listGoodsAll[this.replaceIndex2].unshift(replaceData)
  265. console.log(this.mealData[this.leftIndex].listPackage[this.replaceIndex1].listGoodsAll[this.replaceIndex2])
  266. this.mealData[this.leftIndex].listPackage[this.replaceIndex1].listGoodsAll[this.replaceIndex2]=this.unique(this.mealData[this.leftIndex].listPackage[this.replaceIndex1].listGoodsAll[this.replaceIndex2])
  267. this.$forceUpdate()
  268. } */
  269. var cardata = uni.getStorageSync("maintainCarData")
  270. if (cardata) {
  271. this.brand = cardata.brand
  272. }
  273. },
  274. onLoad(opt) {
  275. // this.$common.isUserId()
  276. this.shopId = opt.id;
  277. this.location = uni.getStorageSync("locationCity");
  278. this.maintainCarData = uni.getStorageSync("maintainCarData");
  279. this.getData();
  280. /* this.addBMemberShopFootprint();
  281. this.getmainData() */
  282. },
  283. methods: {
  284. goCare() {
  285. this.$common.isUserId()
  286. uni.navigateTo({
  287. url: '../module/maintain?brand=' + this.brand
  288. })
  289. },
  290. goGoods(item) {
  291. uni.navigateTo({
  292. url: '../goods/goodsDetail?goodsId=' + item.mGoodsID + '&type=1' + '&typeIndex=2&maintain=1'
  293. })
  294. },
  295. unique(arr1) {
  296. const res = new Map();
  297. return arr1.filter((a) => !res.has(a.goodsID) && res.set(a.goodsID, 1))
  298. },
  299. goAppraise(shopId) {
  300. console.log(shopId);
  301. uni.navigateTo({
  302. url: 'shopAppraise?shopId=' + shopId
  303. })
  304. },
  305. getmainData() {
  306. uni.showLoading({
  307. title: '加载中'
  308. })
  309. this.$http('miniApp/packageMiniAppController/queryPackageList', {
  310. mileage: this.maintainCarData.milage,
  311. liyangId: this.maintainCarData.nLevelID,
  312. shopId: this.shopId
  313. }, 'GET').then(res => {
  314. uni.hideLoading();
  315. this.mealData = res.data;
  316. this.calculation();
  317. })
  318. },
  319. carEdit() {
  320. uni.navigateTo({
  321. url: '../car/cailist?type=2'
  322. })
  323. },
  324. milageEdit() {
  325. this.maintainCarData.milage = ''
  326. },
  327. map() {
  328. console.log("打开地图")
  329. var that = this;
  330. if (!that.shopdata.lat || !that.shopdata.lng) {
  331. uni.showToast({
  332. title: '该店铺未设置定位',
  333. icon: 'none',
  334. duration: 3000
  335. });
  336. } else {
  337. uni.openLocation({
  338. latitude: Number(that.shopdata.lat),
  339. longitude: Number(that.shopdata.lng),
  340. name: that.shopdata.shopName,
  341. address: that.shopdata.address,
  342. success: function() {
  343. console.log('success');
  344. },
  345. fail(err) {
  346. console.log(err)
  347. }
  348. });
  349. }
  350. },
  351. call() {
  352. uni.makePhoneCall({
  353. phoneNumber: this.shopdata.mobilePhone
  354. });
  355. },
  356. getData() {
  357. uni.showLoading({
  358. title: '加载中'
  359. })
  360. this.shopImg = [];
  361. this.$http('worldKeepCar/worldHome/queryKeepCarShopDetail', {
  362. id: this.shopId,
  363. lat: this.location.lat ? this.location.lat : '',
  364. lng: this.location.lng ? this.location.lng : '',
  365. }, 'GET').then(res => {
  366. uni.hideLoading();
  367. this.shopdata = res.data;
  368. if (this.shopdata.photoPath) {
  369. this.shopImg.push(this.shopdata.photoPath)
  370. }
  371. this.shopImg = this.shopImg.concat(this.shopdata.imgList)
  372. console.log(this.shopImg)
  373. if (this.shopdata.brands) {
  374. this.brandsList = this.shopdata.brands.split(',');
  375. }
  376. uni.setNavigationBarTitle({
  377. title: res.data.shopName
  378. })
  379. })
  380. },
  381. addBMemberShopFootprint() {
  382. this.$http('miniAppShopInfoController/addBMemberShopFootprint', {
  383. shopId: this.shopId
  384. }, 'POST').then(res => {
  385. })
  386. },
  387. Member() {
  388. uni.showLoading({
  389. title: '处理中'
  390. })
  391. this.$http('miniAppShopInfoController/addBMemberShop', {
  392. shopID: this.shopId,
  393. }, 'POST').then(res => {
  394. uni.hideLoading();
  395. if (res.code == 0) {
  396. uni.showToast({
  397. title: '关注成功',
  398. icon: 'none',
  399. duration: 3000
  400. });
  401. this.shopdata.isAttention = 1
  402. } else {
  403. uni.showToast({
  404. title: res.msg,
  405. icon: 'none',
  406. duration: 3000
  407. });
  408. }
  409. })
  410. },
  411. deleteMember() {
  412. uni.showLoading({
  413. title: '处理中'
  414. })
  415. this.$http('miniAppMyBMemberCar/deleteBMemberShop', {
  416. shopId: this.shopId,
  417. }, 'POST').then(res => {
  418. uni.hideLoading();
  419. if (res.code == 0) {
  420. uni.showToast({
  421. title: '取消成功',
  422. icon: 'none',
  423. duration: 3000
  424. });
  425. this.shopdata.isAttention = 0
  426. } else {
  427. uni.showToast({
  428. title: res.msg,
  429. icon: 'none',
  430. duration: 3000
  431. });
  432. }
  433. })
  434. },
  435. settlement() {
  436. console.log(this.orderData)
  437. var that = this;
  438. if (this.orderData.length > 0) {
  439. uni.setStorage({
  440. key: 'cfshopInfo',
  441. data: that.shopdata,
  442. success: function() {
  443. uni.removeStorageSync('couponData');
  444. uni.navigateTo({
  445. url: '../module/confirmOrder?orderData=' + JSON.stringify(that
  446. .orderData) + '&currentMileage=' + that.maintainCarData
  447. .milage + '&type=2'
  448. })
  449. }
  450. });
  451. }
  452. },
  453. replace(v, index, i, replaceIndex) {
  454. console.log(v)
  455. v.forEach((item, vindex) => {
  456. if (replaceIndex == vindex) {
  457. item.showr = false
  458. } else {
  459. item.showr = true
  460. }
  461. })
  462. uni.removeStorageSync('replaceData');
  463. this.replaceIndex1 = index;
  464. this.replaceIndex2 = i;
  465. uni.setStorage({
  466. key: 'replaceDataList',
  467. data: v,
  468. success: function() {
  469. uni.navigateTo({
  470. url: '../module/replaceGoods'
  471. })
  472. }
  473. });
  474. },
  475. caidanClick() {
  476. this.qingdanShow = !this.qingdanShow
  477. },
  478. leftClick(item, index) {
  479. this.leftIndex = index
  480. },
  481. listcheck(item) {
  482. item.planItem = !item.planItem;
  483. //var
  484. this.calculation();
  485. if (item.planItem) {
  486. /* this.orderData.push(item) */
  487. }
  488. },
  489. empty() {
  490. var that = this;
  491. uni.showModal({
  492. title: '提示',
  493. content: '确定要清空清单吗',
  494. success: function(res) {
  495. if (res.confirm) {
  496. that.orderData = [];
  497. that.mealData.forEach(item => {
  498. item.num = 0;
  499. if (item.listPackage) {
  500. item.listPackage.forEach(v => {
  501. v.planItem = false
  502. })
  503. }
  504. })
  505. that.calculation();
  506. that.qingdanShow = false;
  507. }
  508. }
  509. });
  510. },
  511. calculation() {
  512. this.total = 0;
  513. this.totalhj = 0;
  514. this.goodsTotal = 0;
  515. this.salePriceTotal = 0;
  516. this.orderData = []
  517. this.mealData.forEach(v => {
  518. v.num = 0;
  519. if (v.listPackage) {
  520. v.listPackage.forEach(i => {
  521. if (i.planItem) {
  522. var obj = {
  523. listGoodsAll: [],
  524. listItem: '',
  525. }
  526. if (i.listGoodsAll.length > 0) {
  527. i.listGoodsAll.forEach((goods, goodsIndex) => {
  528. /* goods.forEach(sp=>{
  529. this.goodsTotal=Number(this.goodsTotal)
  530. this.goodsTotal+=sp.salePrice*sp.qty
  531. this.goodsTotal=this.goodsTotal.toFixed(2)
  532. })
  533. */
  534. this.goodsTotal = Number(this.goodsTotal)
  535. this.goodsTotal += goods[0].salePrice * goods[0].qty
  536. this.goodsTotal = this.goodsTotal.toFixed(2)
  537. obj.listGoodsAll.push(goods[0])
  538. })
  539. }
  540. if (i.listItem.length > 0) {
  541. obj.listItem = i.listItem
  542. }
  543. this.orderData.push(obj)
  544. v.num++;
  545. this.total++;
  546. i.listItem.forEach(xm => {
  547. xm.qty = 1;
  548. this.salePriceTotal = Number(this.salePriceTotal)
  549. this.salePriceTotal += xm.salePrice
  550. this.salePriceTotal = this.salePriceTotal.toFixed(2)
  551. })
  552. //this.totalhj
  553. }
  554. })
  555. }
  556. //if(v.listPackage)
  557. })
  558. this.totalhj = Number(this.goodsTotal) + Number(this.salePriceTotal)
  559. this.totalhj = this.totalhj.toFixed(2)
  560. console.log(this.orderData)
  561. },
  562. reduce(v) {
  563. if (v.qty > 1) {
  564. v.qty--;
  565. this.calculation()
  566. }
  567. },
  568. plus(v) {
  569. v.qty++;
  570. this.calculation()
  571. },
  572. }
  573. }
  574. </script>
  575. <style scoped>
  576. .cont {
  577. min-height: 100vh;
  578. background: #F4F5F7;
  579. }
  580. /deep/.uni-swiper-wrapper .uni-swiper-dots {
  581. bottom: 60rpx;
  582. }
  583. .swiper-item {
  584. width: 100vw;
  585. height: 500rpx;
  586. }
  587. .swiper {
  588. width: 100vw;
  589. height: 500rpx;
  590. }
  591. .swpImg {
  592. width: 100vw;
  593. height: 500rpx;
  594. }
  595. .top {
  596. position: relative;
  597. }
  598. .Member {
  599. width: 140rpx;
  600. height: 42rpx;
  601. line-height: 42rpx;
  602. text-align: center;
  603. color: #FFFFFF;
  604. font-size: 24rpx;
  605. background: rgba(0, 0, 0, 0.4);
  606. border-radius: 21rpx;
  607. position: absolute;
  608. bottom: 60rpx;
  609. right: 32rpx;
  610. }
  611. .shopMain {
  612. width: 702rpx;
  613. /* height: 368rpx; */
  614. background: #FFFFFF;
  615. border-radius: 10rpx;
  616. margin-left: 24rpx;
  617. margin-top: -50rpx;
  618. z-index: 111;
  619. position: relative;
  620. }
  621. .shopName {
  622. padding-top: 30rpx;
  623. padding-left: 20rpx;
  624. color: #333333;
  625. font-size: 32rpx;
  626. font-weight: 600;
  627. }
  628. .pingfenBox {
  629. width: 559rpx;
  630. height: 62rpx;
  631. background: rgba(255, 79, 0, 0.08);
  632. border-radius: 0rpx 15rpx 14rpx 0rpx;
  633. margin-top: 10rpx;
  634. }
  635. .pingfenImg {
  636. width: 14rpx;
  637. height: 26rpx;
  638. margin-right: 30rpx;
  639. margin-top: 20rpx;
  640. }
  641. .fenshuNum {
  642. font-size: 38rpx;
  643. font-weight: 600;
  644. color: #FF4F00;
  645. }
  646. .pingfenBox {
  647. display: flex;
  648. line-height: 62rpx;
  649. justify-content: space-between;
  650. }
  651. .fenshuTxt {
  652. font-size: 26rpx;
  653. font-weight: 600;
  654. color: #FF4F00;
  655. padding-left: 5rpx;
  656. padding-top: 2rpx;
  657. }
  658. .fenshuTxt2 {
  659. font-size: 26rpx;
  660. color: #FF4F00;
  661. padding-left: 5rpx;
  662. }
  663. .cishu {
  664. font-size: 24rpx;
  665. color: #666666;
  666. }
  667. .shuxian {
  668. width: 2px;
  669. height: 30rpx;
  670. background: #E9E8E8;
  671. margin-top: 16rpx;
  672. }
  673. .fenshuBox {
  674. padding-left: 20rpx;
  675. }
  676. .business {
  677. display: flex;
  678. font-size: 26rpx;
  679. padding-left: 20rpx;
  680. padding-top: 20rpx;
  681. color: #999999;
  682. }
  683. .businessTitme {
  684. color: #666666;
  685. }
  686. .brandsBox {
  687. display: flex;
  688. padding: 20rpx;
  689. font-size: 24rpx;
  690. flex-wrap: wrap;
  691. }
  692. .brandsLine {
  693. height: 34rpx;
  694. background: linear-gradient(138deg, #FF630F 0%, #FF450F 100%);
  695. border-radius: 4rpx;
  696. line-height: 34rpx;
  697. padding: 0 8rpx;
  698. color: #FFFFFF;
  699. margin-right: 14rpx;
  700. margin-bottom: 15rpx;
  701. }
  702. .brandsLine2 {
  703. border-radius: 4rpx;
  704. line-height: 30rpx;
  705. padding: 0 8rpx;
  706. color: #F19D01;
  707. height: 30rpx;
  708. border: 1px solid #F19D01;
  709. margin-right: 14rpx;
  710. margin-bottom: 15rpx;
  711. }
  712. .mapBox {
  713. width: 702rpx;
  714. height: 150rpx;
  715. background: url('http://phone.66km.cn:8088/thFiles/184C909A-0A58-4E60-92F1-4AF80BF071F1.png') no-repeat;
  716. background-size: 100% 100;
  717. display: flex;
  718. margin-left: 24rpx;
  719. margin-top: 20rpx;
  720. }
  721. .mapdwImg {
  722. width: 22rpx;
  723. height: 30rpx;
  724. }
  725. .dingwBox {
  726. display: flex;
  727. }
  728. .mapLeft {
  729. padding-top: 30rpx;
  730. padding-left: 20rpx;
  731. font-size: 24rpx;
  732. width: 450rpx;
  733. }
  734. .distance {
  735. padding-left: 16rpx;
  736. color: #3C3C3C;
  737. font-weight: 600;
  738. }
  739. .mapaddress {
  740. color: #999999;
  741. padding-top: 15rpx;
  742. }
  743. .shopsx {
  744. width: 1px;
  745. height: 61rpx;
  746. background: #EEEEEE;
  747. margin-top: 30rpx;
  748. margin-left: 28rpx;
  749. }
  750. .shopRihgtTxt {
  751. color: #999999;
  752. font-size: 22rpx;
  753. }
  754. .shopRightBox {
  755. padding-top: 30rpx;
  756. padding-left: 28rpx;
  757. }
  758. .shopRightImg {
  759. width: 44rpx;
  760. height: 48rpx;
  761. }
  762. .Cartop {
  763. background: #FFFFFF;
  764. display: flex;
  765. justify-content: space-between;
  766. padding: 30rpx 25rpx;
  767. font-size: 28rpx;
  768. width: 654rpx;
  769. margin-top: 20rpx;
  770. margin-left: 24rpx;
  771. }
  772. .CarbrandLogo {
  773. width: 42rpx;
  774. height: 42rpx;
  775. }
  776. .CartopLeft {
  777. display: flex;
  778. width: 500rpx;
  779. }
  780. .carName {
  781. padding-left: 10rpx;
  782. color: #3C3C3C;
  783. padding-top: 2rpx;
  784. }
  785. .CartopEdit {
  786. width: 30rpx;
  787. height: 30rpx;
  788. padding-top: 3px;
  789. padding-left: 12rpx;
  790. padding-right: 5px;
  791. padding-bottom: 5px;
  792. }
  793. .CartopRight {
  794. display: flex;
  795. }
  796. .CartopInput {
  797. font-size: 28rpx;
  798. text-align: right;
  799. padding-top: 3rpx;
  800. }
  801. .caidanTk {
  802. height: calc(100vh - 120rpx);
  803. width: 100vw;
  804. background: rgba(0, 0, 0, 0.6);
  805. position: fixed;
  806. left: 0;
  807. top: 0;
  808. z-index: 111;
  809. }
  810. .tkCont {
  811. height: 60vh;
  812. margin-top: calc(40vh - 120rpx);
  813. }
  814. .caidanTkTop {
  815. width: 750rpx;
  816. height: 90rpx;
  817. background: #FFFFFF;
  818. border-radius: 24rpx 24rpx 0px 0px;
  819. }
  820. .caidanTkTop {
  821. display: flex;
  822. justify-content: space-between;
  823. }
  824. .topTopright {
  825. display: flex;
  826. padding-top: 29rpx;
  827. }
  828. .tkTopTitle {
  829. line-height: 90rpx;
  830. font-size: 30rpx;
  831. font-weight: 600;
  832. color: #3C3C3C;
  833. padding-left: 24rpx;
  834. }
  835. .empty {
  836. width: 86rpx;
  837. height: 42rpx;
  838. background: #EEEEEE;
  839. border-radius: 21rpx;
  840. text-align: center;
  841. color: #666666;
  842. font-size: 24rpx;
  843. line-height: 42rpx;
  844. }
  845. .close {
  846. color: #999999;
  847. font-size: 30rpx;
  848. padding-right: 30rpx;
  849. padding-left: 24rpx;
  850. }
  851. .tkMain {
  852. background: #F0F0F0;
  853. height: calc(60vh - 90rpx);
  854. }
  855. .tkMainSv {
  856. padding: 0 24rpx;
  857. width: 702rpx;
  858. height: calc(60vh - 90rpx);
  859. }
  860. .goodsItemRight {
  861. width: 520rpx;
  862. padding-left: 20rpx;
  863. display: flex;
  864. flex-direction: column;
  865. justify-content: space-between;
  866. }
  867. .goodsItemBottom {
  868. display: flex;
  869. justify-content: space-between;
  870. }
  871. .goodssalePrice {
  872. font-size: 32rpx;
  873. font-weight: 500;
  874. color: #FF4F00;
  875. }
  876. .goodsNum {
  877. font-size: 24rpx;
  878. font-weight: 400;
  879. color: #999999;
  880. }
  881. .top {
  882. /* background: #FF4F00; */
  883. display: flex;
  884. justify-content: space-between;
  885. /* padding: 30rpx 25rpx; */
  886. font-size: 28rpx;
  887. color: #FFFFFF;
  888. }
  889. .goodsItem {
  890. display: flex;
  891. padding: 15rpx 0;
  892. }
  893. .qingdanLine {
  894. background: #FFFFFF;
  895. margin-top: 20rpx;
  896. padding: 24rpx 20rpx;
  897. border-radius: 10rpx;
  898. }
  899. .brandLogo {
  900. width: 42rpx;
  901. height: 42rpx;
  902. }
  903. .topLeft {
  904. display: flex;
  905. }
  906. .carName {
  907. padding-left: 10rpx;
  908. width: 280rpx;
  909. }
  910. .topEdit {
  911. width: 22rpx;
  912. height: 22rpx;
  913. padding-top: 5px;
  914. padding-left: 10rpx;
  915. }
  916. .topRight {
  917. display: flex;
  918. }
  919. .topInput {
  920. font-size: 28rpx;
  921. color: #FFFFFF;
  922. text-align: right;
  923. padding-top: 3rpx;
  924. }
  925. .maintainrecommend {
  926. padding: 30rpx 24rpx;
  927. display: flex;
  928. justify-content: space-between;
  929. border-bottom: 2rpx solid #EEEEEE;
  930. }
  931. .recommendTxt {
  932. color: #3C3C3C;
  933. font-size: 30rpx;
  934. font-weight: 600;
  935. }
  936. .manual {
  937. width: 119rpx;
  938. height: 40rpx;
  939. border-radius: 20rpx;
  940. border: 2rpx solid #F19D01;
  941. text-align: center;
  942. line-height: 40rpx;
  943. font-size: 22rpx;
  944. color: #F19D01;
  945. }
  946. .bottom {
  947. position: fixed;
  948. left: 0;
  949. bottom: 0;
  950. width: 100vw;
  951. height: 120rpx;
  952. background: #FFFFFF;
  953. box-shadow: 0px -2px 20px 0px rgba(153, 153, 153, 0.2);
  954. }
  955. .care {
  956. width: 690rpx;
  957. margin: 23rpx 30rpx;
  958. text-align: center;
  959. height: 74rpx;
  960. background: linear-gradient(135deg, #FD5300 0%, #FF270A 100%);
  961. border-radius: 37rpx;
  962. color: #FFFFFF;
  963. font-size: 30rpx;
  964. line-height: 74rpx;
  965. }
  966. .main {
  967. display: flex;
  968. height: calc(100vh - 410rpx);
  969. }
  970. .mainscrollView {
  971. height: calc(100vh - 410rpx);
  972. }
  973. /* #ifdef MP-WEIXIN */
  974. .main {
  975. display: flex;
  976. height: calc(100vh - 310rpx);
  977. }
  978. .mainscrollView {
  979. height: calc(100vh - 310rpx);
  980. }
  981. /* #endif */
  982. .mainLeft {
  983. width: 146rpx;
  984. background: #F5F5F5;
  985. }
  986. .mainRight {
  987. width: 604rpx;
  988. background: #FFFFFF;
  989. }
  990. .mainLeftLine {
  991. color: #3C3C3C;
  992. padding: 30rpx 20rpx;
  993. font-size: 24rpx;
  994. text-align: center;
  995. position: relative;
  996. }
  997. .lineNum {
  998. position: absolute;
  999. background: #FF270A;
  1000. width: 40rpx;
  1001. height: 26rpx;
  1002. text-align: center;
  1003. line-height: 26rpx;
  1004. font-size: 20rpx;
  1005. color: #FFFFFF;
  1006. border-radius: 13rpx;
  1007. top: 10rpx;
  1008. right: 10rpx;
  1009. }
  1010. .lineLeftActive {
  1011. background: #FFFFFF;
  1012. }
  1013. .nock {
  1014. width: 22rpx;
  1015. height: 22rpx;
  1016. border-radius: 50%;
  1017. border: 2px solid #AEAEAE;
  1018. margin-top: 2rpx;
  1019. margin-right: 10rpx;
  1020. }
  1021. .imgPrivacy {
  1022. width: 28rpx;
  1023. height: 28rpx;
  1024. margin-top: 2rpx;
  1025. margin-right: 10rpx;
  1026. }
  1027. .mainRightLine {
  1028. padding: 20rpx 20rpx 0 20rpx;
  1029. background: #FFFFFF;
  1030. }
  1031. .contTop {
  1032. display: flex;
  1033. justify-content: space-between;
  1034. }
  1035. .listPackgeName {
  1036. font-size: 26rpx;
  1037. font-family: PingFangSC-Regular, PingFang SC;
  1038. font-weight: 600;
  1039. color: #3C3C3C;
  1040. }
  1041. .listPackgeMs {
  1042. font-size: 22rpx;
  1043. font-family: PingFangSC-Regular, PingFang SC;
  1044. font-weight: 400;
  1045. color: #999999;
  1046. padding-top: 5rpx;
  1047. }
  1048. .contZk {
  1049. border-bottom: 1px solid #EEEEEE;
  1050. padding-bottom: 20rpx;
  1051. }
  1052. .goodsImg {
  1053. width: 120rpx;
  1054. height: 120rpx;
  1055. border-radius: 11rpx;
  1056. }
  1057. .goodsItemLIne {
  1058. display: flex;
  1059. padding-top: 20rpx;
  1060. padding-bottom: 20rpx;
  1061. }
  1062. .goodsCont {
  1063. display: flex;
  1064. flex-direction: column;
  1065. justify-content: space-between;
  1066. padding-left: 20rpx;
  1067. }
  1068. .goodsContTop {
  1069. display: flex;
  1070. justify-content: space-between;
  1071. width: 400rpx;
  1072. }
  1073. .goodsItemName {
  1074. font-size: 26rpx;
  1075. font-weight: 400;
  1076. color: #3C3C3C;
  1077. width: 300rpx;
  1078. }
  1079. .salePrice {
  1080. font-size: 32rpx;
  1081. font-weight: 500;
  1082. color: #FF4F00;
  1083. }
  1084. .replace {
  1085. width: 75rpx;
  1086. height: 37rpx;
  1087. border-radius: 19rpx;
  1088. border: 2rpx solid #B9B9B9;
  1089. text-align: center;
  1090. line-height: 35rpx;
  1091. color: #707070;
  1092. font-size: 22rpx;
  1093. }
  1094. .contZkMain {
  1095. padding-top: 20rpx;
  1096. }
  1097. .asa {
  1098. width: 44rpx;
  1099. height: 44rpx;
  1100. line-height: 44rpx;
  1101. text-align: center;
  1102. background: #F4F5F7;
  1103. font-size: 30rpx;
  1104. }
  1105. .goodsCOntBOttom {
  1106. display: flex;
  1107. justify-content: space-between;
  1108. }
  1109. .as {
  1110. display: flex;
  1111. }
  1112. .goodsPrice {
  1113. display: flex;
  1114. justify-content: space-between;
  1115. padding-top: 10rpx;
  1116. }
  1117. .goodsPriceNum {
  1118. color: #F8F8F8;
  1119. font-size: 28rpx;
  1120. }
  1121. .asNum {
  1122. font-size: 24rpx;
  1123. color: #333333;
  1124. padding: 0 18rpx;
  1125. line-height: 44rpx;
  1126. background: #F4F5F7;
  1127. margin-left: 1px;
  1128. margin-right: 1px;
  1129. }
  1130. .itemNum {
  1131. font-size: 24rpx;
  1132. font-weight: 400;
  1133. color: #999999;
  1134. }
  1135. .bottom {
  1136. display: flex;
  1137. justify-content: space-between;
  1138. }
  1139. .caidanImg {
  1140. width: 50rpx;
  1141. height: 50rpx;
  1142. }
  1143. .bottomLeft {
  1144. display: flex;
  1145. }
  1146. .caidan {
  1147. padding-left: 33rpx;
  1148. padding-top: 35rpx;
  1149. padding-right: 33rpx;
  1150. position: relative;
  1151. }
  1152. .total {
  1153. position: absolute;
  1154. width: 40rpx;
  1155. height: 26rpx;
  1156. background: #FF270A;
  1157. line-height: 26rpx;
  1158. text-align: center;
  1159. color: #FFFFFF;
  1160. font-size: 20rpx;
  1161. top: 25rpx;
  1162. right: 15rpx;
  1163. border-radius: 13rpx;
  1164. }
  1165. .heji1 {
  1166. font-size: 24rpx;
  1167. font-weight: 500;
  1168. color: #666666;
  1169. }
  1170. .hejiNum {
  1171. font-size: 32rpx;
  1172. font-family: PingFangSC-Medium, PingFang SC;
  1173. font-weight: 500;
  1174. color: #FF4F00;
  1175. }
  1176. .hejiMs {
  1177. font-size: 24rpx;
  1178. padding-top: 5rpx;
  1179. color: #999999;
  1180. }
  1181. .heji {
  1182. padding-top: 23rpx;
  1183. }
  1184. .settlement {
  1185. width: 203rpx;
  1186. height: 74rpx;
  1187. background: #FF4F00;
  1188. border-radius: 37rpx;
  1189. text-align: center;
  1190. line-height: 74rpx;
  1191. font-size: 30rpx;
  1192. font-family: PingFangSC-Medium, PingFang SC;
  1193. font-weight: 500;
  1194. color: #FEFFFE;
  1195. margin-top: 23rpx;
  1196. margin-right: 32rpx;
  1197. }
  1198. .nodataImg {
  1199. width: 400rpx;
  1200. padding-top: 100rpx;
  1201. }
  1202. .noTxt {
  1203. font-size: 36rpx;
  1204. color: #999999;
  1205. padding-top: 50rpx;
  1206. }
  1207. .nodataBox {
  1208. text-align: center;
  1209. }
  1210. </style>