shopList.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672
  1. <template>
  2. <view class="box">
  3. <view class="allShop">
  4. <view class="topView">
  5. <view class="search">
  6. <!-- 120rpx -->
  7. <view class="searchVIew">
  8. <image src="../../static/img/icon_search.png" mode="" class="searchIMg"></image>
  9. <input type="text" value="" placeholder-style="color:#999999" placeholder="请输入门店名称"
  10. class="searchInput" v-model="shopName" @confirm="searchList" />
  11. <image src="../../static/img/icon_search_del.png" v-show="shopName" mode="" class="ssScImg"
  12. @click="searchSc"></image>
  13. </view>
  14. </view>
  15. <view class="screen">
  16. <view class="screenLine">
  17. <view class="screenLineTxt" @click="showCity(),comprehensiveShow=false,levelShow=false">
  18. {{cityName}}
  19. </view>
  20. <image src="../../static/img/icon_arrow_gray.png" mode="" v-show="!showCity" class="screenJt">
  21. </image>
  22. </view>
  23. <view class="screenLine" @click="juli" :class="{colorCS:comprehensiveShow}">
  24. <!-- <view class="screenLineTxt" v-if="comprehensive==0">综合排序</view> -->
  25. <view class="screenLineTxt" v-if="comprehensive==1">距离最近</view>
  26. <view class="screenLineTxt" v-if="comprehensive==2">评分最高</view>
  27. <image src="../../static/img/icon_arrow_gray.png" mode="" class="screenJt"></image>
  28. </view>
  29. <!-- 综合排序 -->
  30. <view class="shoplevelBox " v-show="comprehensiveShow" @click="comprehensiveShow=false">
  31. <view class="shoplevelCont ">
  32. <view class="comprehensivebox">
  33. <!-- <view class="comprehensiveLine" :class="{comprehensiveACtive:comprehensive==0}"
  34. @click.stop="comprehensiveClick(0)">综合排序</view> -->
  35. <view class="comprehensiveLine" :class="{comprehensiveACtive:comprehensive==1}"
  36. @click.stop="comprehensiveClick(1)">距离最近</view>
  37. <view class="comprehensiveLine" :class="{comprehensiveACtive:comprehensive==2}"
  38. @click.stop="comprehensiveClick(2)">评分最高</view>
  39. </view>
  40. </view>
  41. </view>
  42. <!-- 综合排序 -->
  43. </view>
  44. </view>
  45. <view class="shopLineBox">
  46. <view class="shopline" v-for="(item,index) in queryShopList" @click="goDetail(item)">
  47. <view class="shoplineLeft">
  48. <image :src="item.photoPath" mode="" class="shopImg" v-if="item.photoPath"></image>
  49. <image src="../../static/img/noimg.png" mode="" class="shopImg" v-else></image>
  50. </view>
  51. <view class="shopright">
  52. <view class="shopTop">
  53. <view class="shopName">{{item.shopName}}</view>
  54. <!-- <image src="../../static/img/shopcall.png" mode="" class="shopCallImg"></image> -->
  55. </view>
  56. <view class="brandsBg">
  57. <span class="shopScore1" v-if="item.shopScore">{{item.shopScore}}</span>
  58. <span class="shopScore11" v-if="item.shopScore">分</span>
  59. <span class="shopScore2" v-if="!item.shopScore">暂无评分</span>
  60. <view class="brands" v-if="item.brands" v-for="(barnd,index2) in item.brands.split(',')">
  61. {{barnd}}
  62. </view>
  63. </view>
  64. <view class="timeBg">
  65. <view class="shopTime"><span v-if="item.startTime">{{item.startTime}}</span> - <span
  66. v-if="item.endTime">{{item.endTime}}</span> </view>
  67. <span class="shopScore3">服务次数 {{item.sheetSum}}</span>
  68. </view>
  69. <view class="shopBottom">
  70. <view class="shopBottomLeft">
  71. <span v-if="item.distance&&item.distance!= '0.00'">{{item.distance}}km</span>
  72. <span class="shopaddress">{{item.address}}</span>
  73. </view>
  74. <!-- <view class="Btn" @click="ckshop(item)">确定</view> -->
  75. </view>
  76. </view>
  77. </view>
  78. <view v-if="queryShopList==''" class="nodataBox">
  79. <image src="../../static/img/nodata.png" mode="widthFix" class="nodataImg"></image>
  80. <view class="noTxt">暂无数据</view>
  81. </view>
  82. </view>
  83. </view>
  84. </view>
  85. </template>
  86. <script>
  87. export default {
  88. data() {
  89. return {
  90. location: {
  91. lng: '',
  92. lat: '',
  93. },
  94. cityName: '选择城市',
  95. cityCode: '',
  96. queryShopList: '',
  97. shopName: '',
  98. level: '',
  99. comprehensive: 1,
  100. shopLevel: [{
  101. name: '洗剪点',
  102. ckeck: false
  103. }, {
  104. name: 'VIIIP',
  105. ckeck: false
  106. }],
  107. levelShow: false,
  108. comprehensiveShow: false,
  109. uid: '',
  110. share: {
  111. title: '车蓝图4S店养车服务',
  112. path: '/pages/shop/shopList',
  113. imageUrl: '',
  114. desc: '',
  115. content: ''
  116. }
  117. }
  118. },
  119. onShow() {
  120. this.levelShow = false;
  121. this.comprehensiveShow = false;
  122. // this.$common.isUserId();
  123. var selectCity = uni.getStorageSync("selectCity");
  124. this.location = uni.getStorageSync("locationCity");
  125. if (selectCity) {
  126. //有选择的城市
  127. this.cityName = selectCity.city
  128. this.cityCode = selectCity.code
  129. } else {
  130. this.cityName = this.location.cityName
  131. this.cityCode = this.location.cityCode
  132. }
  133. this.getqueryShopList() //获取全部门店列表
  134. },
  135. onLoad() {
  136. },
  137. methods: {
  138. showCity() {
  139. console.log('城市');
  140. uni.navigateTo({
  141. url: '../chooseCity/chooseCity'
  142. })
  143. },
  144. mdlx() {
  145. this.levelShow = !this.levelShow;
  146. this.comprehensiveShow = false;
  147. },
  148. juli() {
  149. this.comprehensiveShow = !this.comprehensiveShow;
  150. this.levelShow = false;
  151. },
  152. searchList() {
  153. this.getqueryShopList() //获取全部门店列表
  154. },
  155. searchSc() {
  156. this.shopName = '';
  157. this.getqueryShopList() //获取全部门店列表
  158. },
  159. getqueryShopList() {
  160. uni.showLoading({
  161. title: '加载中'
  162. })
  163. this.$http('worldKeepCar/worldHome/getWorldShopInfoList', {
  164. name: this.shopName,
  165. lat: this.location.lat ? this.location.lat : '',
  166. lng: this.location.lng ? this.location.lng : '',
  167. cityCode: this.cityCode ? this.cityCode : '',
  168. comprehensive: this.comprehensive,
  169. }, 'GET').then(res => {
  170. uni.hideLoading();
  171. this.queryShopList = res.data
  172. // 处理 undefined和null转为空白字符串
  173. this.queryShopList.forEach((item, index) => {
  174. for (const key in item) {
  175. item[key] = this.$praseStrEmpty(item[key])
  176. }
  177. })
  178. })
  179. },
  180. getqueryBShopLevel() {
  181. this.$http('miniAppShopInfoController/queryBShopLevel', {
  182. }, 'GET').then(res => {
  183. res.data.forEach(item => {
  184. item.ckeck = false;
  185. })
  186. this.shopLevel = res.data
  187. })
  188. },
  189. levelClick(item) {
  190. item.ckeck = !item.ckeck
  191. },
  192. shoplevelReset() {
  193. this.shopLevel.forEach(item => {
  194. item.ckeck = false;
  195. })
  196. // this.getqueryShopList()
  197. //this.levelShow=false;
  198. },
  199. shoplevelsbu() {
  200. var arr = []
  201. this.shopLevel.forEach(item => {
  202. if (item.ckeck) {
  203. arr.push(item.id)
  204. }
  205. })
  206. this.level = arr.join(',')
  207. console.log(this.level)
  208. this.levelShow = false;
  209. this.getqueryShopList()
  210. },
  211. comprehensiveClick(num) {
  212. this.comprehensive = num;
  213. this.comprehensiveShow = false;
  214. this.getqueryShopList()
  215. },
  216. goDetail(item) {
  217. uni.navigateTo({
  218. url: '../shop/shopDetail?id=' + item.shopId
  219. })
  220. }
  221. }
  222. }
  223. </script>
  224. <style scoped>
  225. .box {
  226. min-height: 100vh;
  227. background: #F4F5F7;
  228. }
  229. .allShop {
  230. /* background: #FFFFFF; */
  231. }
  232. .topView {
  233. position: fixed;
  234. width: 100%;
  235. height: 170rpx;
  236. background-color: #FFFFFF;
  237. z-index: 11;
  238. }
  239. .searchIMg {
  240. width: 40rpx;
  241. height: 40rpx;
  242. margin-top: 16rpx;
  243. margin-left: 20rpx;
  244. }
  245. .ssScImg {
  246. width: 40rpx;
  247. height: 40rpx;
  248. margin-top: 16rpx;
  249. }
  250. .search {
  251. padding: 24rpx;
  252. background: #FFFFFF;
  253. }
  254. .searchVIew {
  255. display: flex;
  256. background: #F4F5F7;
  257. border-radius: 36rpx;
  258. height: 72rpx;
  259. }
  260. .searchInput {
  261. color: #333333;
  262. font-size: 28rpx;
  263. padding-left: 16rpx;
  264. height: 72rpx;
  265. line-height: 72rpx;
  266. width: 570rpx;
  267. }
  268. .screenJt {
  269. width: 24rpx;
  270. height: 24rpx;
  271. margin-top: 7rpx;
  272. margin-left: 5rpx;
  273. }
  274. .screen {
  275. display: flex;
  276. justify-content: space-around;
  277. padding: 0 24rpx 24rpx;
  278. align-items: center;
  279. border-bottom: 2rpx solid #EEEEEE;
  280. position: relative;
  281. background: #FFFFFF;
  282. }
  283. .screenLine {
  284. display: flex;
  285. color: #333333;
  286. font-size: 28rpx;
  287. }
  288. .shopLineBox {
  289. padding: 190rpx 0rpx 25rpx;
  290. }
  291. .shopBox2 {
  292. margin-top: 20rpx;
  293. padding-bottom: 30rpx;
  294. background: #FFFFFF;
  295. border-radius: 10rpx;
  296. padding-left: 20rpx;
  297. padding-right: 20rpx;
  298. }
  299. .shoplevelBox {
  300. position: fixed;
  301. left: 0;
  302. width: 750rpx;
  303. top: 196rpx;
  304. background: rgba(0, 0, 0, 0.4);
  305. z-index: 11;
  306. border-top: 1px solid #EEEEEE;
  307. border-bottom: 1px solid #EEEEEE;
  308. height: calc(100vh - 196rpx);
  309. }
  310. /* #ifdef H5 */
  311. .shoplevelBox {
  312. top: calc(196rpx + 44px);
  313. }
  314. /* #endif */
  315. .shoplevelCont {
  316. display: flex;
  317. flex-wrap: wrap;
  318. background: #FFFFFF;
  319. padding: 24rpx;
  320. }
  321. .shoplevelLine {
  322. color: #333333;
  323. line-height: 64rpx;
  324. padding: 0 40rpx;
  325. height: 64rpx;
  326. background: #F4F5F7;
  327. border-radius: 32rpx;
  328. margin-right: 20rpx;
  329. margin-bottom: 30rpx;
  330. }
  331. .shoplevelBottom {
  332. display: flex;
  333. justify-content: space-between;
  334. padding-top: 60rpx;
  335. padding-right: 24rpx;
  336. background: #FFFFFF;
  337. padding: 24rpx;
  338. }
  339. .shoplevelReset {
  340. width: 320rpx;
  341. height: 74rpx;
  342. border-radius: 37rpx;
  343. border: 2rpx solid #FF4F00;
  344. text-align: center;
  345. line-height: 74rpx;
  346. font-size: 30rpx;
  347. font-family: PingFangSC-Medium, PingFang SC;
  348. font-weight: 500;
  349. color: #FF4F00;
  350. }
  351. .shoplevelsbu {
  352. width: 320rpx;
  353. height: 74rpx;
  354. background: #FF4F00;
  355. border-radius: 37rpx;
  356. font-size: 30rpx;
  357. font-family: PingFangSC-Medium, PingFang SC;
  358. font-weight: 500;
  359. color: #FFFFFF;
  360. text-align: center;
  361. line-height: 74rpx;
  362. border: 2rpx solid #FF4F00;
  363. }
  364. .shoplevalActive {
  365. color: #FF4F00;
  366. background: rgba(255, 79, 0, 0.08);
  367. }
  368. .comprehensiveLine {
  369. /* width: 200rpx;
  370. height: 60rpx;
  371. line-height: 60rpx;
  372. text-align: center;
  373. border: 1px solid rgb(228, 228, 228);
  374. border-radius: 10rpx; */
  375. font-size: 26rpx;
  376. font-family: PingFangSC-Regular, PingFang SC;
  377. font-weight: 400;
  378. color: #333333;
  379. padding: 25rpx 0;
  380. }
  381. .comprehensivebox {
  382. /* display: flex;justify-content: space-around; */
  383. }
  384. .comprehensiveACtive {
  385. color: #FF4F00;
  386. }
  387. .nodataImg {
  388. width: 400rpx;
  389. padding-top: 100rpx;
  390. }
  391. .noTxt {
  392. font-size: 36rpx;
  393. color: #999999;
  394. padding-top: 50rpx;
  395. }
  396. .nodataBox {
  397. text-align: center;
  398. }
  399. .shopImg {
  400. width: 146rpx;
  401. height: 146rpx;
  402. border-radius: 6rpx;
  403. }
  404. .shopBox {
  405. padding-top: 30rpx;
  406. display: flex;
  407. }
  408. .flex {
  409. display: flex;
  410. justify-content: space-between;
  411. }
  412. .shopCont {
  413. padding-left: 22rpx;
  414. width: 520rpx;
  415. }
  416. .shopName {
  417. color: #333333;
  418. font-size: 26rpx;
  419. font-weight: 600;
  420. }
  421. .span1 {
  422. color: #FF4F00;
  423. font-size: 36rpx;
  424. }
  425. .span2 {
  426. color: #FF4F00;
  427. font-size: 22rpx;
  428. }
  429. .span3 {
  430. color: #333333;
  431. font-size: 22rpx;
  432. padding-left: 22rpx;
  433. }
  434. .shopBq {
  435. color: #FF4F00;
  436. font-size: 22rpx;
  437. border-radius: 4rpx;
  438. border: 1px solid #FF4F00;
  439. line-height: 30rpx;
  440. height: 30rpx;
  441. padding: 0rpx 5rpx;
  442. margin-top: 10rpx;
  443. }
  444. .brandsBg {
  445. display: flex;
  446. flex-wrap: wrap;
  447. align-items: center;
  448. overflow: hidden;
  449. height: 50rpx;
  450. }
  451. .brands {
  452. border-radius: 4rpx;
  453. padding: 0 5rpx;
  454. color: #F19D01;
  455. height: 28rpx;
  456. border: 1px solid #F19D01;
  457. margin-right: 5rpx;
  458. font-size: 20rpx;
  459. line-height: 28rpx;
  460. }
  461. .timeBg {
  462. display: flex;
  463. align-items: center;
  464. }
  465. .shopTime {
  466. color: #666666;
  467. font-size: 22rpx;
  468. }
  469. .addressBox {
  470. color: #666666;
  471. font-size: 22rpx;
  472. }
  473. .shopNameSearchInput {
  474. width: 500rpx;
  475. }
  476. .colorCS {
  477. color: #FF4F00;
  478. }
  479. .shopbox {
  480. padding: 0 16rpx;
  481. }
  482. .shopline {
  483. padding: 20rpx;
  484. background: #FFFFFF;
  485. border-radius: 10rpx;
  486. margin-top: 20rpx;
  487. display: flex;
  488. }
  489. .shopImg {
  490. width: 146rpx;
  491. height: 146rpx;
  492. border-radius: 10rpx;
  493. }
  494. .shopCallImg {
  495. width: 38rpx;
  496. height: 46rpx;
  497. }
  498. .shopTop {
  499. display: flex;
  500. justify-content: space-between;
  501. width: 510rpx;
  502. }
  503. .shopright {
  504. padding-left: 20rpx;
  505. }
  506. .shopName {
  507. font-size: 26rpx;
  508. color: #333333;
  509. line-height: 37rpx;
  510. width: 450rpx;
  511. white-space: nowrap;
  512. overflow: hidden;
  513. text-overflow: ellipsis;
  514. }
  515. .shopScore1 {
  516. font-size: 36rpx;
  517. font-weight: bold;
  518. color: #FF4F00;
  519. height: 50rpx;
  520. line-height: 50rpx;
  521. }
  522. .shopScore11 {
  523. font-size: 22rpx;
  524. color: #FF4F00;
  525. margin-right: 14rpx;
  526. }
  527. .shopScore2 {
  528. font-size: 22rpx;
  529. color: #666666;
  530. margin-right: 14rpx;
  531. padding: 8rpx 0;
  532. }
  533. .shopScore3 {
  534. font-size: 22rpx;
  535. color: #333333;
  536. padding-left: 20rpx;
  537. }
  538. .Btn {
  539. width: 104rpx;
  540. height: 56rpx;
  541. background: #FF2400 linear-gradient(135deg, #FD5300 0%, #FF270A 100%);
  542. border-radius: 6rpx;
  543. font-size: 26rpx;
  544. text-align: center;
  545. color: #FFFFFF;
  546. line-height: 56rpx;
  547. }
  548. .shopBottom {
  549. display: flex;
  550. }
  551. .shopBottomLeft {
  552. width: 500rpx;
  553. font-size: 22rpx;
  554. color: #666666;
  555. line-height: 30rpx;
  556. padding-top: 10rpx;
  557. }
  558. .shopaddress {
  559. padding-left: 10rpx;
  560. }
  561. </style>