Commit 0a022266 authored by honghuiliu's avatar honghuiliu 💬

Merge remote-tracking branch 'origin/master'

parents 46eb31dc 4a311364
......@@ -69,11 +69,11 @@ function checkCode(res,url) {
}
export default {
post(url,data, config = { 'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8' }){
post(url,data, config = { 'Content-Type': 'application/json; charset=UTF-8' }){
let record = id;
if(list.indexOf(url)==-1){
let token = myPublic.getStorage('token');
config['token'] = token;
let token = myPublic.getStorage('qsh-wc-token');
url = url+'?access_token='+token;
}
console.log(`request`,record,url+' ',data);
console.time(`request ${record}`);
......@@ -82,7 +82,7 @@ export default {
method: 'post',
baseURL: API_HOST,
url,
data: qs.stringify(data),
data: JSON.stringify(data),
headers: config
}).then(response =>{
return checkStatus(response,url,record);
......
......@@ -14,6 +14,10 @@ export default {
},
//工单列表
getPatrolList(params) {
return http.post('web/toilet/getPatrolList', params)
return http.post('web/patrol/getPatrolList', params)
},
//工单详情
getPatrolDetail(params) {
return http.post('web/patrol/getPatrolDetail', params)
}
}
......@@ -47,41 +47,41 @@
site_id:'',
time:myPublic.dateFormat.format(Date.now(), 'HH:mm:ss YYYY年MM月DD日'),
list:[
{
longitude:119.779647,
latitude:30.24369,
name:'青山湖国家森林公园',
address:'浙江省杭州市临安区老圣园路北',
type:1
},
{
longitude:119.821796,
latitude:30.254114,
name:'青山湖街道',
address:'浙江省杭州市临安区',
type:1
},
{
longitude:119.790127,
latitude:30.255317,
name:'灵山',
address:'浙江省杭州市临安区',
type:2
},
{
longitude:119.852565,
latitude:30.2528,
name:'青山湖互通',
address:'浙江省杭州市临安区',
type:1
},
{
longitude:119.823904,
latitude:30.24808,
name:'青山中学',
address:'浙江省杭州市临安区',
type:1
},
// {
// longitude:119.779647,
// latitude:30.24369,
// name:'青山湖国家森林公园',
// address:'浙江省杭州市临安区老圣园路北',
// type:1
// },
// {
// longitude:119.821796,
// latitude:30.254114,
// name:'青山湖街道',
// address:'浙江省杭州市临安区',
// type:1
// },
// {
// longitude:119.790127,
// latitude:30.255317,
// name:'灵山',
// address:'浙江省杭州市临安区',
// type:2
// },
// {
// longitude:119.852565,
// latitude:30.2528,
// name:'青山湖互通',
// address:'浙江省杭州市临安区',
// type:1
// },
// {
// longitude:119.823904,
// latitude:30.24808,
// name:'青山中学',
// address:'浙江省杭州市临安区',
// type:1
// },
]
});
const user = computed(()=>{
......@@ -98,12 +98,23 @@
getList();
}
function getList() {
for (let item of state.list) {
const marker = new BMapGL.Point(item.longitude, item.latitude);
mapShow(marker, item, function (i) {
let p = {
page:1,
page_size:99
};
api.toiletList(p).then((res)=>{
if(res.code==0){
if(Array.isArray(res.data.list)){
state.list = [...res.data.list];
for (let item of state.list) {
const marker = new BMapGL.Point(item.lng, item.lat);
mapShow(marker, item, function (i) {
});
}
});
}
}
}
});
}
function mapShow(coordinate, item, callBack) {
const now = Date.now();
......@@ -172,8 +183,8 @@
}
}
function seeDetail(item){
state.site_id = item.ID;
state.show = true;
state.site_id = item.site_id||'12';
}
onMounted(()=>{
nextTick(()=>{
......
......@@ -11,7 +11,7 @@
</div>
<div class="row">
<span class="icon icon-17"></span>
<input class="input" type="password" v-model="password" placeholder="请输入密码" />
<input class="input" type="password" v-model="password" placeholder="请输入密码" @keyup.enter="submit"/>
</div>
<div class="opt">
<span class="btn" @click="submit">登录</span>
......@@ -57,7 +57,6 @@
if(res.data){
myPublic.setStorage("qsh-wc-token",res.data);
await router.replace({path:"/home"});
window.reload();
}
}
})
......
......@@ -11,7 +11,7 @@
</div>
<div class="row-one">
<span class="row-name">巡检公厕单位</span>
<span class="row-content">{{detail.name}}</span>
<span class="row-content">{{detail.toiletId}}</span>
</div>
<div class="row-one">
<span class="row-name">巡检类型</span>
......@@ -19,7 +19,7 @@
</div>
<div class="row-one baseline">
<span class="row-name">巡检内容</span>
<div class="row-content">
<div class="row-content" v-if="detail.content">
<template v-for="item in detail.content">
<div class="check-one">
<el-checkbox v-model="item.check" :label="item.title" size="large" :disabled="true"/>
......@@ -28,7 +28,7 @@
</div>
</div>
<div class="row-one">
<span class="row-name">附件</span>
<span class="row-name">巡检图片</span>
<div class="row-content">
<photo-provider>
<photo-consumer v-for="(url,index) in fileList" :key="url" :src="url">
......@@ -44,11 +44,11 @@
</div>
<div class="row-one">
<span class="row-name">站点巡检人</span>
<span class="row-content">{{detail.staff}}</span>
<span class="row-content">{{detail.partolName}}</span>
</div>
<div class="row-one">
<span class="row-name">提交时间</span>
<span class="row-content">{{detail.create_time}}</span>
<span class="row-content">{{detail.CreatedAt}}</span>
</div>
</div>
</div>
......@@ -60,6 +60,7 @@
import {ElMessage} from "element-plus"
import {Close} from "@element-plus/icons-vue"
import api from "@/api/methods/index"
import myPublic from "@/utils/public"
export default {
name: 'order-detail',
emits: ['update:modelValue'],
......@@ -76,10 +77,10 @@
setup(props, {emit}) {
const state = reactive({
detail: {
title:'2022年6月22日公厕巡检工作',
title:'',
type:1,
name:'三号路公共厕所【GC-004】',
staff:'罗小飞',
name:'',
partolName:'',
content:[
{
title:'检查格栅井',
......@@ -148,7 +149,7 @@
],
description:'泵站清淤很多、泵站清淤很多、泵站清淤很多、泵站清淤很多、泵站清淤很多、泵站清淤很多、\n' +
'泵站清淤很多。',
create_time:'2022-06-22 10:00'
CreatedAt:'2022-06-22 10:00'
},
typeList:[
{
......@@ -233,7 +234,12 @@
}
}
function getDetail(){
api.getPatrolDetail({id:props.order_id}).then((res)=>{
if(res.code==0){
res.data.CreatedAt = myPublic.dateFormat.format(res.data.CreatedAt)
Object.assign(state.detail,{...res.data});
}
});
}
function closeBox(){
emit('update:modelValue',false)
......
......@@ -31,7 +31,7 @@
点位名称
</div>
<div class="table-content-cell cell">
{{detail.name}}
</div>
</div>
<div class="table-row">
......@@ -39,7 +39,7 @@
公厕类型
</div>
<div class="table-content-cell cell">
{{wcTypeChange(detail.type).text}}
</div>
</div>
<div class="table-row">
......@@ -47,7 +47,7 @@
管理人员
</div>
<div class="table-content-cell cell">
{{detail.manager}}
</div>
</div>
<div class="table-row">
......@@ -55,7 +55,7 @@
联系电话
</div>
<div class="table-content-cell cell">
{{detail.managerPhone}}
</div>
</div>
<div class="table-row">
......@@ -63,7 +63,7 @@
地址
</div>
<div class="table-content-cell cell">
{{detail.address}}
</div>
</div>
</div>
......@@ -179,12 +179,12 @@
<div class="filter-one">
<p class="filter-name">类型筛选</p>
<div class="filter-content">
<el-select v-model="filter.type" class="m-2" placeholder="请选择类型" @change="()=>getList()">
<el-select v-model="filter.order_type" class="m-2" placeholder="请选择类型" @change="()=>getOrderList()">
<el-option
v-for="item in [{name:'全部类型',value:'',prop:''},...typeList]"
:key="item.prop"
v-for="item in typeList_order"
:key="item.value"
:label="item.name"
:value="item.prop"
:value="item.value"
/>
</el-select>
</div>
......@@ -193,7 +193,7 @@
<p class="filter-name">时间筛选</p>
<div class="filter-content">
<el-date-picker
v-model="filter.time"
v-model="filter.time_order"
type="datetimerange"
format="YYYY-MM-DD HH:mm"
value-format="YYYY-MM-DD HH:mm"
......@@ -202,7 +202,7 @@
end-placeholder="结束时间"
:teleported="false"
:editable="true"
@change="()=>getList()"
@change="()=>getOrderList()"
/>
</div>
</div>
......@@ -225,8 +225,8 @@
<div class="cell flex_2">
<span class="type" :style="{backgroundColor:typeChange(item.type).color}">{{typeChange(item.type).text}}</span>
</div>
<div class="cell flex_2">{{item.staff}}</div>
<div class="cell flex_2">{{item.create_time}}</div>
<div class="cell flex_2">{{item.partolName}}</div>
<div class="cell flex_2">{{item.CreatedAt}}</div>
<div class="cell">
<span class="opt" @click="seeDetail(item)">查看</span>
</div>
......@@ -242,7 +242,7 @@
:background="background"
layout="sizes, prev, pager, next"
:total="list.total"
@size-change="()=>getOrderList(list.page)"
@size-change="()=>getOrderList()"
@current-change="()=>getOrderList()"
/>
</div>
......@@ -260,6 +260,7 @@
import {ref,reactive, toRefs, onMounted,nextTick,defineAsyncComponent} from "vue"
import {ElMessage} from "element-plus"
import api from "@/api/methods/index"
import myPublic from "@/utils/public"
export default {
name: 'site-detail',
emits: ['update:modelValue'],
......@@ -269,7 +270,7 @@
default: false
},
site_id: {
type: String,
type: Number,
default: ''
},
},
......@@ -278,7 +279,6 @@
show:false,
order_id:'',
detail: {
name: '三号路公共厕所GC-004',
poster: [
require("@/assets/img/banner-1.png"),
require("@/assets/img/banner-1.png"),
......@@ -322,7 +322,9 @@
myChart:null,
filter:{
type:'',
time:['','']
order_type:'',
time:['',''],
time_order:['','']
},
typeList:[
{
......@@ -390,82 +392,39 @@
create_time:'2022-09-01 10:00'
}
],
typeList_order:[
{
name:'全部类型',
value:'',
},
{
name:'一体化设备',
value:1,
},
{
name:'玻璃钢',
value:2,
}
],
list:{
page:1,
pageSize:15,
total:20,
data:[
{
title:'2022年6月22日公厕巡检工作',
type:1,
name:'三号路公共厕所【GC-004】',
staff:'罗小飞',
create_time:'2022-06-22 10:00'
},
{
title:'2022年6月21日公厕巡检工作',
type:1,
name:'三号路公共厕所【GC-004】',
staff:'罗小飞',
create_time:'2022-06-21 10:00'
},
{
title:'2022年6月20日公厕巡检工作',
type:1,
name:'三号路公共厕所【GC-004】',
staff:'罗小飞',
create_time:'2022-06-20 10:00'
},
{
title:'2022年6月19日公厕巡检工作',
type:2,
name:'三号路公共厕所【GC-004】',
staff:'罗小飞',
create_time:'2022-06-19 10:00'
},
{
title:'2022年6月18日公厕巡检工作',
type:1,
name:'三号路公共厕所【GC-004】',
staff:'罗小飞',
create_time:'2022-06-18 10:00'
},
{
title:'2022年6月17日公厕巡检工作',
type:1,
name:'三号路公共厕所【GC-004】',
staff:'罗小飞',
create_time:'2022-06-17 10:00'
},
{
title:'2022年6月16日公厕巡检工作',
type:2,
name:'三号路公共厕所【GC-004】',
staff:'罗小飞',
create_time:'2022-06-16 10:00'
},
{
title:'2022年6月14日公厕巡检工作',
type:1,
name:'三号路公共厕所【GC-004】',
staff:'罗小飞',
create_time:'2022-06-14 10:00'
},
{
title:'2022年6月13日公厕巡检工作',
type:1,
name:'三号路公共厕所【GC-004】',
staff:'罗小飞',
create_time:'2022-06-13 10:00'
},
]
}
});
const chart = ref(null);
function getDetail() {
if(state.detail.type==1){
state.tabs.find(one=>one.value=='process').show = true;
}
api.getToiletDetail({id:props.site_id}).then((res)=>{
if(res.code==0){
Object.assign(state.detail,{...res.data});
if(state.detail.type==1){
state.tabs.find(one=>one.value=='process').show = true;
}
}
});
}
function typeChange(type=1) {
switch (type) {
......@@ -484,6 +443,9 @@
function tabActive(item) {
if (state.tab != item.value) {
state.tab = item.value;
if(item.value=='base'){
initGauge();
}
if(item.value=='history'){
getList();
}
......@@ -493,96 +455,100 @@
}
}
function initGauge(){
state.myChart = echarts.init(chart.value);
let option = {
series: [
{
type: 'gauge',
progress: {
show: true,
width: 18,
nextTick(()=>{
state.myChart = echarts.init(chart.value);
let option = {
series: [
{
type: 'gauge',
progress: {
show: true,
width: 18,
itemStyle:{
color:'#3396fb',
}
},
pointer: {
icon: 'path://M2.9,0.7L2.9,0.7c1.4,0,2.6,1.2,2.6,2.6v115c0,1.4-1.2,2.6-2.6,2.6l0,0c-1.4,0-2.6-1.2-2.6-2.6V3.3C0.3,1.9,1.4,0.7,2.9,0.7z',
width: 4,
length: '60%',
offsetCenter: [0, '8%']
},
itemStyle:{
color:'#3396fb',
}
},
pointer: {
icon: 'path://M2.9,0.7L2.9,0.7c1.4,0,2.6,1.2,2.6,2.6v115c0,1.4-1.2,2.6-2.6,2.6l0,0c-1.4,0-2.6-1.2-2.6-2.6V3.3C0.3,1.9,1.4,0.7,2.9,0.7z',
width: 4,
length: '60%',
offsetCenter: [0, '8%']
},
itemStyle:{
color:'#3396fb'
},
axisLine: {
lineStyle: {
width: 18
}
},
axisTick: {
show: true,
distance: 0,
},
splitLine: {
distance: 5,
length: 8,
lineStyle: {
width: 1,
color: '#999'
}
},
axisLabel: {
distance: 22,
color: '#999',
fontSize: 12
},
anchor: {
show: true,
showAbove: true,
size: 20,
itemStyle: {
borderWidth: 4,
borderColor: '#3396fb',
color:'#fff',
}
},
title: {
show: false
},
detail: {
valueAnimation: true,
fontSize: 24,
offsetCenter: [0, '70%'],
formatter(p){
return `{a|${p}m}\n{b|液位}`
color:'#3396fb'
},
rich: {
a: {
color: '#333',
lineHeight: 20,
fontSize:18
axisLine: {
lineStyle: {
width: 18
}
},
axisTick: {
show: true,
distance: 0,
},
splitLine: {
distance: 5,
length: 8,
lineStyle: {
width: 1,
color: '#999'
}
},
axisLabel: {
distance: 22,
color: '#999',
fontSize: 12
},
anchor: {
show: true,
showAbove: true,
size: 20,
itemStyle: {
borderWidth: 4,
borderColor: '#3396fb',
color:'#fff',
}
},
title: {
show: false
},
detail: {
valueAnimation: true,
fontSize: 24,
offsetCenter: [0, '70%'],
formatter(p){
return `{a|${p}m}\n{b|液位}`
},
b: {
color: '#666',
lineHeight: 20,
fontSize:14
rich: {
a: {
color: '#333',
lineHeight: 20,
fontSize:18
},
b: {
color: '#666',
lineHeight: 20,
fontSize:14
}
}
}
},
data: [
{
value: state.detail.yewei
}
],
radius:"95%",
startAngle:210,
endAngle:-30,
max:1
}
]
};
state.myChart.setOption(option);
},
data: [
{
value: state.detail.yewei
}
],
radius:"95%",
startAngle:210,
endAngle:-30,
max:1
}
]
};
state.myChart.clear();
state.myChart.setOption(option);
state.myChart.resize();
})
}
function getList(){
......@@ -590,19 +556,45 @@
function getOrderList(page=1){
let p = {
page:page,
pageSize:state.list.pageSize
page_size:state.list.pageSize,
};
if(state.filter.time_order[0]&&state.filter.time_order[1]){
p.start_time = state.filter.time_order[0];
p.end_time = state.filter.time_order[1];
}
if(state.filter.order_type){
p.type = state.filter.order_type;
}
state.list.page = page;
api.getPatrolList(p).then((res)=>{
if(res.code==0){
if(Array.isArray(res.data.list)){
res.data.list.forEach((item)=>{
item.CreatedAt = myPublic.dateFormat.format(item.CreatedAt);
})
state.list.data = res.data.list;
state.list.total = res.data.total;
}
}
})
}
function seeDetail(item){
state.order_id = item.order_id;
state.order_id = item.ID;
state.show = true;
}
onMounted(async () => {
function wcTypeChange(type=1) {
switch (type) {
case 1:
return {text:'有动力',color:'#3396fb'};
case 2:
return {text:'无动力',color:'#f78131'};
default:
return {text:'...',color:'#f78131'};
}
}
onMounted(() => {
getDetail();
await nextTick(()=>{
initGauge();
})
initGauge();
});
return {
...toRefs(state),
......@@ -612,7 +604,8 @@
typeChange,
getList,
getOrderList,
seeDetail
seeDetail,
wcTypeChange
}
},
components: {
......
......@@ -62,7 +62,7 @@ module.exports = {
port:80,
proxy: {
'/api': {
target: 'http://qsh-wc-test.linanquan.com/api',
target: 'http://127.0.0.1:9801',
changeOrigin: true,
pathRewrite: {
// '^/apis': ''表示把/apis替换为‘’(空字符串),这样既能使用代理,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment