中小
xiaozhiyong 9 months ago
parent d1af8b7ecb
commit 9f13a13cc8
  1. 2
      BagStation/pages/routePlain/routePlain.vue
  2. 404
      BagStation/pages/stationMap/stationMap.vue
  3. 286
      components/three-sites.vue

@ -170,7 +170,7 @@
latitude :that.origin.latitude latitude :that.origin.latitude
} }
} }
oilSiteApi.getSiteList(data1).then(res => { oilSiteApi.findKASiteInfoByPage(data1).then(res => {
//console.log(res) //console.log(res)
if (res.code == 20000) { if (res.code == 20000) {
that.nearSite = res.data.list that.nearSite = res.data.list

@ -1,79 +1,109 @@
<template> <template>
<view>
<cu-custom class="main-totextbar bg-main-oil" :isBack="true" bgColor="bg-main-oil">
<block slot="backText">返回</block>
<block slot="content">油站地图</block>
</cu-custom>
<view> <view>
<view class="cu-bar search bg-white"> <cu-custom
<view class="search-form round"> class="main-totextbar bg-main-oil"
<text class="cuIcon-search"></text> :isBack="true"
<input confirm-type="search" @input="onInput" @confirm="onSearch" v-model="siteName" :adjust-position="false" type="text" placeholder="加油站名称" /> bgColor="bg-main-oil"
>
</view> <block slot="backText">返回</block>
<view class="action" @tap="loadMore"> <block slot="content">油站地图</block>
更多 </cu-custom>
<view>
<view class="cu-bar search bg-white">
<view class="search-form round">
<text class="cuIcon-search"></text>
<input
confirm-type="search"
@input="onInput"
@confirm="onSearch"
v-model="siteName"
:adjust-position="false"
type="text"
placeholder="加油站名称"
/>
</view>
<view class="action" @tap="loadMore"> 更多 </view>
</view> </view>
</view> <view class="page-body">
<view class="page-body"> <view class="page-section page-section-gap">
<view class="page-section page-section-gap"> <map
<map style="width: 100%; height:100vh;" :controls="controls" :polyline='polyline' :scale="scale" :latitude="latitude" @labeltap='makerTap' @markertap="makerTap" :longitude="longitude" :markers="covers"> style="width: 100%; height: 100vh"
</map> :controls="controls"
:polyline="polyline"
:scale="scale"
:latitude="latitude"
@labeltap="makerTap"
@markertap="makerTap"
:longitude="longitude"
:markers="covers"
>
</map>
</view>
</view> </view>
</view> </view>
<view class="cu-modal bottom-modal" :class="showSite">
</view> <view class="cu-dialog" @tap.stop="">
<view class="cu-modal bottom-modal" :class="showSite"> <view class="cu-bar bg-white justify-end">
<view class="cu-dialog" @tap.stop=""> <view class="content">
<view class="cu-bar bg-white justify-end"> {{ siteInfo.siteName ? siteInfo.siteName : "油站名称" }}</view
<view class="content"> {{siteInfo.siteName?siteInfo.siteName:'油站名称'}}</view> >
<view class="action" @tap="showSite=''"> <view class="action" @tap="showSite = ''">
<text class="cuIcon-close text-red"></text> <text class="cuIcon-close text-red"></text>
</view>
</view> </view>
</view> <view class="flex-sub">
<view class="flex-sub"> <view
<view class="cu-list menu padding-sm radius my-shadow bg-white yu-card-xuan"> class="cu-list menu padding-sm radius my-shadow bg-white yu-card-xuan"
<view class="cu-item "> >
<view class="content" @tap="toDetail(siteInfo)"> <view class="cu-item">
<view class="strong padding-bottom-xs"> <view class="content" @tap="toDetail(siteInfo)">
{{siteInfo.siteName?siteInfo.siteName:'油站名称'}} <view class="strong padding-bottom-xs">
</view> {{ siteInfo.siteName ? siteInfo.siteName : "油站名称" }}
<view class="text-gray flex">
<view class="text-bold yellow-oil; text-xl padding-right-xs">
{{siteInfo.oilProductCode}}
</view> </view>
<view class="oil-main-color text-xl text-bold padding-right-xs"> <view class="text-gray flex">
<view class="text-bold yellow-oil; text-xl padding-right-xs">
{{ siteInfo.oilProductCode }}
</view>
<view
class="oil-main-color text-xl text-bold padding-right-xs"
>
{{ siteInfo.sitePrice | moneyFormat }}
</view>
<view class="">
<text
class="cu-tag oil-tag radius text-xs"
v-if="siteInfo.oilSitePrice - siteInfo.sitePrice > 0"
>{{
(siteInfo.oilSitePrice - siteInfo.sitePrice)
| moneyFormat
}}</text
>
</view>
{{siteInfo.sitePrice|moneyFormat}} <view class="text-cut padding-left-sm text-lg">
<text
class="text-delete color-333 text-sm padding-right-xs"
>
{{ siteInfo.oilSitePrice | moneyFormat }}/L
</text>
</view> <!-- <my-icon iconName="¥.png" class="padding-right-xs icon-rectangle"></my-icon>
<view class="">
<text class="cu-tag oil-tag radius text-xs" v-if="siteInfo.oilSitePrice - siteInfo.sitePrice>0">{{(siteInfo.oilSitePrice - siteInfo.sitePrice)|moneyFormat}}</text>
</view>
<view class="text-cut padding-left-sm text-lg">
<text class="text-delete color-333 text-sm padding-right-xs">
{{siteInfo.oilSitePrice|moneyFormat}}/L
</text>
<!-- <my-icon iconName="¥.png" class="padding-right-xs icon-rectangle"></my-icon>
<my-icon iconName="f.png" class="padding-right-xs "></my-icon> --> <my-icon iconName="f.png" class="padding-right-xs "></my-icon> -->
</view>
</view>
<view class="font-12 text-left color-999 site-label text-cut">
{{ siteInfo.address ? siteInfo.siteName : "油站地址" }}
</view> </view>
</view>
<view class="font-12 text-left color-999 site-label text-cut">
{{siteInfo.address?siteInfo.siteName:'油站地址'}}
</view> </view>
</view> <view class="action" @tap="openMap">
<view class="action " @tap="openMap"> <view class="oil-main-color">
<view class="oil-main-color"> <my-icon
<my-icon iconName="sy-der-icon.png" class="padding-right-xs text-sm"></my-icon> iconName="sy-der-icon.png"
{{siteInfo.juli|distanceFilter}} class="padding-right-xs text-sm"
></my-icon>
{{ siteInfo.juli | distanceFilter }}
</view>
</view> </view>
</view> </view>
</view> </view>
@ -81,17 +111,16 @@
</view> </view>
</view> </view>
</view> </view>
</view>
</template> </template>
<script> <script>
import oilSiteApi from '@/api/oil-site.js' import oilSiteApi from "@/api/oil-site.js";
export default { export default {
data() { data() {
return { return {
siteInfo: {}, siteInfo: {},
showSite: '', showSite: "",
imgUrl: this.global.imgURL, imgUrl: this.global.imgURL,
siteList: [], siteList: [],
InputBottom: 0, InputBottom: 0,
@ -99,67 +128,73 @@ export default {
siteCount: 1, siteCount: 1,
currentPage: 1, currentPage: 1,
isLoadMore: false, // isLoadMore: false, //
baseDriver: uni.getStorageSync('baseDriver'), baseDriver: uni.getStorageSync("baseDriver"),
selLocation: {}, selLocation: {},
title: 'map', title: "map",
location: uni.getStorageSync('location'), location: uni.getStorageSync("location"),
latitude: 39.909, latitude: 39.909,
longitude: 116.39742, longitude: 116.39742,
covers: [], covers: [],
fillColor: '#ffd75e', fillColor: "#ffd75e",
borderColor: '#12A1DD', borderColor: "#12A1DD",
scale: 12, // scale: 12, //
controls: [{ // controls: [
id: 1, //id {
position: { // //
left: 0, id: 1, //id
top: 15, position: {
width: 50, //
height: 50 left: 0,
top: 15,
width: 50,
height: 50,
},
}, },
}], ],
polyline: [{ //线 polyline: [
points: [], {
color: "#0000AA", //线 //线
width: 2, //线 points: [],
dottedLine: true, //线 color: "#0000AA", //线
arrowLine: true, //线 width: 2, //线
}], dottedLine: true, //线
arrowLine: true, //线
},
],
}; };
}, },
onLoad() { onLoad() {
let that = this let that = this;
this.getSiteList() this.getSiteList();
}, },
filters: { filters: {
distanceFilter(value) { distanceFilter(value) {
if (value) { if (value) {
return value > 1000 ? ((value / 1000).toFixed(2) + 'km') : (value + 'm') return value > 1000 ? (value / 1000).toFixed(2) + "km" : value + "m";
} }
}, },
moneyFormat(value) { moneyFormat(value) {
if (value) { if (value) {
return value.toFixed(2) return value.toFixed(2);
} else { } else {
return '0.00' return "0.00";
} }
} },
}, },
methods: { methods: {
getSiteInfo(id) { getSiteInfo(id) {
let data2 = { let data2 = {
...uni.getStorageSync('location'), ...uni.getStorageSync("location"),
siteId: id siteId: id,
} };
oilSiteApi.getSiteDetailsByKA(data2).then(res => { oilSiteApi.getSiteDetailsByKA(data2).then((res) => {
if (res.code == 20000) { if (res.code == 20000) {
this.siteInfo = res.data this.siteInfo = res.data;
} }
}) });
}, },
openMap() { openMap() {
let that = this let that = this;
uni.openLocation({ uni.openLocation({
latitude: this.siteInfo.latitude, latitude: this.siteInfo.latitude,
longitude: this.siteInfo.longitude, longitude: this.siteInfo.longitude,
@ -176,21 +211,22 @@ export default {
complete: () => { complete: () => {
// // console.log('made') // // console.log('made')
}, },
});
}) var map = uni.createMapContext("map");
map.moveToLocation();
var map = uni.createMapContext('map')
map.moveToLocation()
}, },
makerTap(e) { makerTap(e) {
// // console.log(e) // // console.log(e)
// // console.log(e.detail) // // console.log(e.detail)
this.showSite = '' this.showSite = "";
if (e.detail.markerId !== 0) { if (e.detail.markerId !== 0) {
const index = this.siteList.findIndex(s => s.markerId === e.detail.markerId) const index = this.siteList.findIndex(
(s) => s.markerId === e.detail.markerId
);
// // console.log(index) // // console.log(index)
this.showSite = 'show' this.showSite = "show";
this.siteInfo = this.siteList[index] this.siteInfo = this.siteList[index];
} }
}, },
refreshLocation() { refreshLocation() {
@ -200,7 +236,6 @@ export default {
// uni.setStorageSync('location', res) // uni.setStorageSync('location', res)
// this.location = res // this.location = res
// this.addLocationCurrent() // this.addLocationCurrent()
// } // }
// }); // });
}, },
@ -209,104 +244,105 @@ export default {
id: 0, id: 0,
latitude: this.location.latitude, // latitude: this.location.latitude, //
longitude: this.location.longitude, // longitude: this.location.longitude, //
label: { // label: {
//
content: "我的位置", // content: "我的位置", //
color: '#12A1DD', // color: "#12A1DD", //
anchorX: 5, //label marker anchorX: 5, //label marker
anchorY: -10, //label marker anchorY: -10, //label marker
bgColor: '#fff', // bgColor: "#fff", //
padding: 5, // padding: 5, //
borderWidth: 1, // borderWidth: 1, //
borderRadius: 10, borderRadius: 10,
borderColor: '#12A1DD', // textAlign: 'right' // borderColor: "#12A1DD", // textAlign: 'right' //
} },
}) });
}, },
loadMore() { loadMore() {
this.getSiteList() this.getSiteList();
}, },
getSiteList() { getSiteList() {
this.refreshLocation() this.refreshLocation();
let data1 = { let data1 = {
currentPage: this.currentPage, currentPage: this.currentPage,
pageSize: 20, pageSize: 20,
params: { //Object // params: {
//Object //
sort: "juli", //String // ( price juli ) sort: "juli", //String // ( price juli )
siteName: this.siteName, siteName: this.siteName,
...uni.getStorageSync('location'), ...uni.getStorageSync("location"),
...this.filterData ...this.filterData,
// siteBrand: "", // // ( 1- 2- 3- 4- 5- 6- 7- 8- ) // siteBrand: "", // // ( 1- 2- 3- 4- 5- 6- 7- 8- )
// channelCode: "", // // ( OIL WJY LV TY YDJY) // channelCode: "", // // ( OIL WJY LV TY YDJY)
// oilProductCode: "" // // ( 0# 92# 92#) // oilProductCode: "" // // ( 0# 92# 92#)
} },
};
} oilSiteApi.findKASiteInfoByPage(data1).then((res) => {
oilSiteApi.getSiteList(data1).then(res => {
if (res.code == 20000) { if (res.code == 20000) {
const tmp = res.data.list const tmp = res.data.list;
tmp.forEach(e => { tmp.forEach((e) => {
e.markerId = this.siteCount++ e.markerId = this.siteCount++;
}) });
this.siteList = this.siteList.concat(tmp) this.siteList = this.siteList.concat(tmp);
if (this.siteList.length != 0) { if (this.siteList.length != 0) {
this.latitude = this.siteList[0].latitude this.latitude = this.siteList[0].latitude;
this.longitude = this.siteList[0].longitude this.longitude = this.siteList[0].longitude;
} else { } else {
uni.showToast({ uni.showToast({
title: '没有查到相关油站', title: "没有查到相关油站",
icon: 'none' icon: "none",
}) });
this.latitude = this.location.latitude this.latitude = this.location.latitude;
this.longitude = this.location.longitude this.longitude = this.location.longitude;
} }
tmp.forEach(item => { tmp.forEach((item) => {
this.addCover(item) this.addCover(item);
}) });
if (tmp.length == 0) { // if (tmp.length == 0) {
//
// this.$emit('changeLoad', 'nomore', true) // this.$emit('changeLoad', 'nomore', true)
uni.showToast({ uni.showToast({
title: '没有更多油站了', title: "没有更多油站了",
icon: 'none' icon: "none",
}) });
} else { } else {
this.currentPage++ this.currentPage++;
// this.$emit('changeLoad', 'load', false) // this.$emit('changeLoad', 'load', false)
} }
} }
}) });
}, },
onInput() { onInput() {
setTimeout(() => { setTimeout(() => {
this.currentPage = 1 this.currentPage = 1;
this.siteList = [] this.siteList = [];
this.covers = [] this.covers = [];
this.getSiteList() this.getSiteList();
}, 100) }, 100);
}, },
onSearch() { onSearch() {
this.currentPage = 1 this.currentPage = 1;
this.siteList = [] this.siteList = [];
this.covers = [] this.covers = [];
this.getSiteList() this.getSiteList();
}, },
toDetail(item) { toDetail(item) {
let itemS = JSON.stringify(item) let itemS = JSON.stringify(item);
console.log('++++++') console.log("++++++");
console.log(itemS) console.log(itemS);
if (uni.getStorageSync('user')) { if (uni.getStorageSync("user")) {
uni.navigateTo({ uni.navigateTo({
url: `/BagStation/pages/stationDetail/stationDetail?item=${itemS}`, url: `/BagStation/pages/stationDetail/stationDetail?item=${itemS}`,
fail: (err) => { fail: (err) => {
// console.log(err) // console.log(err)
}, },
success: () => { success: () => {
// console.log('err') // console.log('err')
} },
}) });
} }
}, },
addCover(site) { addCover(site) {
// ( XOIL WJY LV TY YDJY) // ( XOIL WJY LV TY YDJY)
@ -315,28 +351,30 @@ export default {
latitude: site.latitude, // latitude: site.latitude, //
longitude: site.longitude, // longitude: site.longitude, //
// iconPath: this.imgUrl + 'map-' + site.channelCode + '.png', // iconPath: this.imgUrl + 'map-' + site.channelCode + '.png',
iconPath: this.imgUrl + 'map-' +'XOIL' + '.png', iconPath: this.imgUrl + "map-" + "XOIL" + ".png",
width: 100, width: 100,
height: 50, height: 50,
title: site.siteName, // title: site.siteName, //
label: { // label: {
content: '¥' + site.sitePrice, // //
content: "¥" + site.sitePrice, //
// color: '#F76350', // // color: '#F76350', //
color: '#fff', // color: "#fff", //
fontSize: '16', fontSize: "16",
textAlign:'center', textAlign: "center",
anchorX: -5, //label marker anchorX: -5, //label marker
anchorY: -45, //label marker anchorY: -45, //label marker
// x:39.909,//1.2.0 // x:39.909,//1.2.0
// y:116.39742, // y:116.39742,
bgColor: '#FF0000', // bgColor: "#FF0000", //
borderRadius: 10, borderRadius: 10,
// borderWidth: 1, // // borderWidth: 1, //
// borderColor: '#D84C29', // textAlign: 'center' // // borderColor: '#D84C29', // textAlign: 'center' //
}, },
callout: { // callout: {
//
content: site.siteName, content: site.siteName,
color: '#F76350', color: "#F76350",
fontSize: 12, fontSize: 12,
borderRadius: 5, borderRadius: 5,
}, },
@ -344,10 +382,10 @@ export default {
// x:5, // x:5,
// y:1, // y:1,
// } // }
}) });
} },
} },
} };
</script> </script>
<style scoped> <style scoped>

@ -1,149 +1,159 @@
<template> <template>
<!-- 三个最近的油站弹窗 --> <!-- 三个最近的油站弹窗 -->
<view> <view>
<view class="cu-modal" :class="showThreeSites?'show':''"> <view class="cu-modal" :class="showThreeSites ? 'show' : ''">
<view class="cu-dialog"> <view class="cu-dialog">
<view class="cu-bar bg-white justify-end"> <view class="cu-bar bg-white justify-end">
<view class="content">选择油站</view> <view class="content">选择油站</view>
<view class="action" @tap="hideModal('sites')"> <view class="action" @tap="hideModal('sites')">
<text class="cuIcon-close text-red"></text> <text class="cuIcon-close text-red"></text>
</view> </view>
</view> </view>
<view class="padding-xl bg-white"> <view class="padding-xl bg-white">
<view class="" v-if="siteList.length>0"> <view class="" v-if="siteList.length > 0">
<three-item v-for="(item,index) in siteList" :key="item.id" :site-item="item" :first="index==0" <three-item
class="cu-list menu-avatar cu-item " @tap="toDetail(item)"> v-for="(item, index) in siteList"
</three-item> :key="item.id"
</view> :site-item="item"
<view class="" v-else> :first="index == 0"
<my-empty></my-empty> class="cu-list menu-avatar cu-item"
</view> @tap="toDetail(item)"
<view class="btn-box padding-top"> >
<button @tap="toSitePage" class="cu-tn bg-red round margin-bottom lg" color="#3982F6" </three-item>
size="large">前往油站列表查找 </view>
</button> <view class="" v-else>
</view> <my-empty></my-empty>
</view> </view>
</view> <view class="btn-box padding-top">
</view> <button
@tap="toSitePage"
</view> class="cu-tn bg-red round margin-bottom lg"
color="#3982F6"
size="large"
>
前往油站列表查找
</button>
</view>
</view>
</view>
</view>
</view>
</template> </template>
<script> <script>
import oilSiteApi from '@/api/oil-site.js' import oilSiteApi from "@/api/oil-site.js";
import threeItem from './three-item.vue' import threeItem from "./three-item.vue";
export default { export default {
components: { components: {
threeItem threeItem,
}, },
props: { props: {
showThreeSites: { showThreeSites: {
type: Boolean, type: Boolean,
default: false default: false,
} },
}, },
data() { data() {
return { return {
siteList: [], siteList: [],
imgURL: this.global.baseURL, imgURL: this.global.baseURL,
} };
}, },
created() { created() {
this.getSiteList() this.getSiteList();
}, },
methods: { methods: {
toSitePage(){ toSitePage() {
// uni.setStorageSync('activeCur','station') // uni.setStorageSync('activeCur','station')
uni.switchTab({ uni.switchTab({
url: '/pages/tabbar/station/stationList' url: "/pages/tabbar/station/stationList",
}); });
}, },
refreshLocation(){ refreshLocation() {
uni.getLocation({ uni.getLocation({
type: 'wgs84', type: "wgs84",
success: function (res) { success: function (res) {
uni.setStorageSync('location',res) uni.setStorageSync("location", res);
} },
}); });
}, },
getSiteList() { getSiteList() {
this.refreshLocation() this.refreshLocation();
let data1 = { let data1 = {
currentPage: 1, currentPage: 1,
pageSize: 3, pageSize: 3,
params: { //Object // params: {
sort: "juli", //String // ( price juli ) //Object //
...uni.getStorageSync('location'), sort: "juli", //String // ( price juli )
...this.filterData, ...uni.getStorageSync("location"),
clientBelong:'BAICHUAN', ...this.filterData,
bcDisable:'ENABLE', clientBelong: "BAICHUAN",
// siteBrand: "", // // ( 1- 2- 3- 4- 5- 6- 7- 8- ) bcDisable: "ENABLE",
// channelCode: "", // // ( OIL WJY LV TY YDJY) // siteBrand: "", // // ( 1- 2- 3- 4- 5- 6- 7- 8- )
// oilProductCode: "" // // ( 0# 92# 92#) // channelCode: "", // // ( OIL WJY LV TY YDJY)
} // oilProductCode: "" // // ( 0# 92# 92#)
},
} };
oilSiteApi.getSiteList(data1).then(res => { oilSiteApi.findKASiteInfoByPage(data1).then((res) => {
if (res.code == 20000) { if (res.code == 20000) {
this.siteList = res.data.list this.siteList = res.data.list;
} }
}) });
}, },
toDetail(item) { toDetail(item) {
let itemS = JSON.stringify(item) let itemS = JSON.stringify(item);
console.log(itemS) console.log(itemS);
uni.navigateTo({ uni.navigateTo({
url: `/BagStation/pages/stationDetail/stationDetail?item=${itemS}`, url: `/BagStation/pages/stationDetail/stationDetail?item=${itemS}`,
fail: (err) => { fail: (err) => {
// console.log(err) // console.log(err)
}, },
success: () => { success: () => {
// console.log('err') // console.log('err')
} },
}) });
}, },
callShipper() { callShipper() {
uni.makePhoneCall({ uni.makePhoneCall({
phoneNumber: this.waybillData.shippePhone phoneNumber: this.waybillData.shippePhone,
}) });
}, },
hideModal(name) { hideModal(name) {
this.$emit('hideOneModal', name) this.$emit("hideOneModal", name);
}, },
registerContracts() { registerContracts() {
this.$emit('registerContracts') this.$emit("registerContracts");
}, },
toSetLocation() { toSetLocation() {
this.$emit('toSetLocation') this.$emit("toSetLocation");
}, },
toAuth() { toAuth() {
uni.navigateTo({ uni.navigateTo({
url: '认证路径' url: "认证路径",
}) });
} },
} },
} };
</script> </script>
<style scoped> <style scoped>
.cu-list.menu-avatar>.cu-item .action { .cu-list.menu-avatar > .cu-item .action {
width: 130rpx; width: 130rpx;
} }
.ro-right { .ro-right {
max-width: 100upx; max-width: 100upx;
/* position: absolute; */ /* position: absolute; */
} }
.position-re { .position-re {
position: relative; position: relative;
} }
.postion-ab { .postion-ab {
position: absolute; position: absolute;
top: -0.8rem; top: -0.8rem;
left: 0.2rem; left: 0.2rem;
min-width: 100%; min-width: 100%;
} }
</style> </style>

Loading…
Cancel
Save