flinfo/dc-App/pages/index/search.vue
2025-03-01 10:26:49 +08:00

315 lines
6.6 KiB
Vue

<template>
<view class="content">
<view class="top_s">
<view class="search_">
<u-icon name="arrow-left" size="24" @click="goback()"></u-icon>
<view class="newsearch">
<view @click="toQf()" style="margin-left: 10px;" ><u-icon name="camera" color="#32714F" size="28"></u-icon></view>
<view class="newsearch_g">|</view>
<input type="text" v-model="keyword" placeholder="Please enter" />
<view class="anniu" @click="getSound">search</view>
</view>
</view>
</view>
<view class="box_" v-if="cityList.length>1">
<view class="h_top">
<view class="icon_">
<image src="../../static/imgs/huohuo.png" style="width: 16px; height: 16px; "></image>
</view>
<view class="sm_">City</view>
<view class="size_"></view>
</view>
<view class="h_" v-for="(item,index) in cityList" :key="index" @click="goclick(item)">
<view class="icon_"><u-icon name="map" size="14"></u-icon></view>
<view class="title_">{{item.cnName}}-{{item.name}}</view>
<view class="size_">→</view>
</view>
</view>
<view class="box_" >
<view class="h_top">
<view class="icon_"><u-icon name="clock" size="14"></u-icon></view>
<view class="sm_">History</view>
<view class="size_" @click="removeRecord()" >Clear</view>
</view>
<view class="h_" v-for="(item,index) in hisList" :key="index" @click="newclick(item)">
<view class="icon_"><u-icon name="map" size="14"></u-icon></view>
<view class="title_">{{item.cnName}}-{{item.searchName}}</view>
<view class="size_">→</view>
</view>
<view class="h_" v-if="hisList.length<1" >
<view style="font-size: 14px;color: #939393;">You have no search history yet~</view>
</view>
</view>
</view>
</template>
<script>
import request from '../../utils/request'
export default {
data() {
return {
keyword: '',
type:'',
hisList: [],
cityList: [],
startPoint: [],
endPoint: [],
city:"",
lon: '116.897442',
lat: '36.67937',
actionStyle:{
width: '50px'
}
}
},
onLoad(option) {
if(option.type){
this.type = option.type
console.log(this.type);
}
this.watchData()
},
onShow() {
this.getmyhis();
},
methods: {
watchData() {
let that = this
uni.$once('updateOcrText', function(res) {
that.keyword = res
that.getSound()
})
},
toQf(){
uni.chooseImage({
count: 1, //默认9
sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有
success: function (res) {
uni.navigateTo({
url: '/components/bt-cropper/index?image='+res.tempFilePaths[0]
})
}
});
},
removeRecord(){
request({
url: 'system/records/removeRecord',
method: 'delete',
}).then(res=>{
console.log(res);
uni.showToast({
title:"cleared!",
icon:'none'
})
this.getmyhis()
})
},
goback() {
uni.navigateBack()
},
newclick(item){
let tempData = {
lal:item.location,
location:item.location,
searchName:item.name,
name:item.name,
cnName:item.cnName
}
request({
url: 'system/records/addRecordsInfo',
method: 'post',
data:tempData
})
let res ={type:this.type,data:item}
uni.$emit('updatePosition',res)
uni.navigateBack()
},
goclick(item) {
let tempData = {
lal:item.location,
location:item.location,
searchName:item.name,
name:item.name,
cnName:item.cnName
}
let res ={type:this.type,data:tempData}
request({
url: 'system/records/addRecordsInfo',
method: 'post',
data:tempData
})
uni.$emit('updatePosition',res)
uni.navigateBack()
},
getSound() {
let that = this
uni.getLocation({
// 谷歌使用wgs84 其他使用gcj02
type: 'gcj02', // 使用国测局坐标系
geocode: true,
success: function(res) {
uni.showLoading({
title: 'Loading...'
});
request({
url: 'system/records/roundSearch?searchName=' + that.keyword +
"&longitude=" + res.longitude + "&latitude=" + res.latitude,
method: 'get',
}).then(res => {
console.log('1119', res);
const data = res.data
if (data&&data.length > 1) {
that.cityList = data
} else {
uni.showToast({
title: "Sorry, we couldn't find anything related to it in the search!",
icon: 'none'
})
}
}).finally(()=>{
uni.hideLoading();
})
},
fail: function(err) {
uni.showToast({
title: 'Failed to get location',
icon: 'none'
})
}
});
},
async getmyhis() {
this.hisList = []
let res = await request({
url: 'system/records/listByOne?orderBy=desc?pageNum=1?pagesize=10',
method: 'get',
})
if (res.code == 200) {
console.log("res", res)
for (var i = 0; i < res.rows.length; i++) {
this.hisList.push(res.rows[i])
}
}
}
}
}
</script>
<style scoped lang="scss">
.search_ {
box-sizing: border-box;
width: 100%;
padding: 0px 10px;
display: flex;
align-items: center;
}
.newsearch_g{
color: #939393; line-height: 22px; margin-bottom: 4px;margin-right: 5px;
margin-left: 5px;
}
.newsearch{
width: 100%;
border: 2px solid #32714F;
border-radius: 8px;
display: flex;
align-items: center;
justify-content: space-between;
box-sizing: border-box;
padding: 5px 2px;
input{
width: 100%;
}
}
.anniu{
background: #32714F;
color: #fff;
box-sizing: border-box;
padding: 8rpx 10rpx;
border-radius: 4px;
}
.content {
background: #F8F8F8;
height: 100vh;
}
.h_top {
background: #F7F8FA;
border-radius: 6px 6px 0px 0px;
box-sizing: border-box;
padding: 15px;
display: flex;
align-items: center;
}
.sm_ {
font-weight: 500;
font-size: 10px;
color: #333333;
width: 80%;
}
.top_s {
width: 100%;
height: 114px;
background: #FFFFFF;
box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.05);
border-radius: 0px 0px 0px 0px;
box-sizing: border-box;
padding-top: 44px;
}
.box_ {
width: 95%;
overflow: hidden;
background: #fff;
box-shadow: 0px 0px 8px 0px rgba(0, 0, 0, 0.05);
margin: 15px auto;
border-radius: 6px 6px 6px 6px;
}
.h_ {
width: 100%;
border-bottom: 1px solid #F2F2F2;
box-sizing: border-box;
padding: 15px;
display: flex;
align-items: center;
}
.icon_ {
width: 8%;
display: flex;
align-items: center;
justify-content: center;
}
.title_ {
width: 80%;
font-weight: bold;
font-size: 12px;
color: #333333;
}
.size_ {
width: 10%;
font-weight: 400;
font-size: 10px;
color: #999999;
text-align: right;
}
</style>