fix() : 添加车俩管理

dev.saas
Li HD 2024-09-20 19:15:44 +08:00
parent 982d1fa9d0
commit e1a0a2dad5
4 changed files with 736 additions and 0 deletions

44
src/api/car/car.js 100644
View File

@ -0,0 +1,44 @@
import request from '@/utils/request'
// 查询车辆基础信息列表
export function listCar(query) {
return request({
url: '/car/car/list',
method: 'get',
params: query
})
}
// 查询车辆基础信息详细
export function getCar(id) {
return request({
url: '/car/car/' + id,
method: 'get'
})
}
// 新增车辆基础信息
export function addCar(data) {
return request({
url: '/car/car',
method: 'post',
data: data
})
}
// 修改车辆基础信息
export function updateCar(data) {
return request({
url: '/car/car',
method: 'put',
data: data
})
}
// 删除车辆基础信息
export function delCar(id) {
return request({
url: '/car/car/' + id,
method: 'delete'
})
}

View File

@ -0,0 +1,36 @@
import request from '@/utils/request'
// 报文模版列表
export function templateList() {
return request({
url: 'car/messageTemplate/list',
method: 'POST',
})
}
//添加报文模版
export function addTemplate(data) {
return request({
url: 'car/messageTemplate/',
method: 'POST',
data: data
})
}
// 报文数据列表
export function valueList(data) {
return request({
url: 'car/messageValue/list',
method: 'POST',
data: data
})
}
// 添加报文数据
export function addValue(data) {
return request({
url: 'car/messageValue/',
method: 'POST',
data: data
})
}

View File

@ -0,0 +1,343 @@
<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
<el-form-item label="车辆VIN码" prop="carVin">
<el-input
v-model="queryParams.carVin"
placeholder="请输入车辆VIN码"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="车辆车牌号" prop="carPlate">
<el-input
v-model="queryParams.carPlate"
placeholder="请输入车辆车牌号"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item label="启用状态" prop="state">
<el-input
v-model="queryParams.state"
placeholder="请输入启用状态"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery"></el-button>
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery"></el-button>
</el-form-item>
</el-form>
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button
type="primary"
plain
icon="el-icon-plus"
size="mini"
@click="handleAdd"
v-hasPermi="['car:car:add']"
>新增</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="success"
plain
icon="el-icon-edit"
size="mini"
:disabled="single"
@click="handleUpdate"
v-hasPermi="['car:car:edit']"
>修改</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="danger"
plain
icon="el-icon-delete"
size="mini"
:disabled="multiple"
@click="handleDelete"
v-hasPermi="['car:car:remove']"
>删除</el-button>
</el-col>
<el-col :span="1.5">
<el-button
type="warning"
plain
icon="el-icon-download"
size="mini"
@click="handleExport"
v-hasPermi="['car:car:export']"
>导出</el-button>
</el-col>
<right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
</el-row>
<el-table v-loading="loading" :data="carList" @selection-change="handleSelectionChange">
<el-table-column type="selection" width="55" align="center" />
<el-table-column label="自增主键" align="center" prop="id" />
<el-table-column label="车辆VIN码" align="center" prop="carVin" />
<el-table-column label="车辆车牌号" align="center" prop="carPlate" />
<el-table-column label="车辆品牌;" align="center" prop="carBrand" />
<el-table-column label="车辆型号" align="center" prop="carModel" />
<el-table-column label="车辆车型" align="center" prop="carType" />
<el-table-column label="最后一次连线时间" align="center" prop="carLastJoinTime" width="180">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.carLastJoinTime, '{y}-{m}-{d}') }}</span>
</template>
</el-table-column>
<el-table-column label="最后一次离线时间" align="center" prop="carLastOfflineTime" width="180">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.carLastOfflineTime, '{y}-{m}-{d}') }}</span>
</template>
</el-table-column>
<el-table-column label="车辆电机厂商" align="center" prop="carMotorManufacturer" />
<el-table-column label="电机型号" align="center" prop="carMotorModel" />
<el-table-column label="车辆电池厂商" align="center" prop="carBatteryManufacturer" />
<el-table-column label="电池型号" align="center" prop="carBatteryModel" />
<el-table-column label="围栏组编码" align="center" prop="groupCode" />
<el-table-column label="启用状态" align="center" prop="state" />
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
icon="el-icon-edit"
@click="handleUpdate(scope.row)"
v-hasPermi="['car:car:edit']"
>修改</el-button>
<el-button
size="mini"
type="text"
icon="el-icon-delete"
@click="handleDelete(scope.row)"
v-hasPermi="['car:car:remove']"
>删除</el-button>
</template>
</el-table-column>
</el-table>
<pagination
v-show="total>0"
:total="total"
:page.sync="queryParams.pageNum"
:limit.sync="queryParams.pageSize"
@pagination="getList"
/>
<!-- 添加或修改车辆基础信息对话框 -->
<el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
<el-form-item label="车辆VIN码" prop="carVin">
<el-input v-model="form.carVin" placeholder="请输入车辆VIN码" />
</el-form-item>
<el-form-item label="车辆车牌号" prop="carPlate">
<el-input v-model="form.carPlate" placeholder="请输入车辆车牌号" />
</el-form-item>
<el-form-item label="最后一次连线时间" prop="carLastJoinTime">
<el-date-picker clearable
v-model="form.carLastJoinTime"
type="date"
value-format="yyyy-MM-dd"
placeholder="请选择最后一次连线时间">
</el-date-picker>
</el-form-item>
<el-form-item label="最后一次离线时间" prop="carLastOfflineTime">
<el-date-picker clearable
v-model="form.carLastOfflineTime"
type="date"
value-format="yyyy-MM-dd"
placeholder="请选择最后一次离线时间">
</el-date-picker>
</el-form-item>
<el-form-item label="车辆电机厂商" prop="carMotorManufacturer">
<el-input v-model="form.carMotorManufacturer" placeholder="请输入车辆电机厂商" />
</el-form-item>
<el-form-item label="电机型号" prop="carMotorModel">
<el-input v-model="form.carMotorModel" placeholder="请输入电机型号" />
</el-form-item>
<el-form-item label="车辆电池厂商" prop="carBatteryManufacturer">
<el-input v-model="form.carBatteryManufacturer" placeholder="请输入车辆电池厂商" />
</el-form-item>
<el-form-item label="电池型号" prop="carBatteryModel">
<el-input v-model="form.carBatteryModel" placeholder="请输入电池型号" />
</el-form-item>
<el-form-item label="围栏组编码" prop="groupCode">
<el-input v-model="form.groupCode" placeholder="请输入围栏组编码" />
</el-form-item>
<el-form-item label="启用状态" prop="state">
<el-input v-model="form.state" placeholder="请输入启用状态" />
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-input v-model="form.remark" type="textarea" placeholder="请输入内容" />
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
</div>
</template>
<script>
import { listCar, getCar, delCar, addCar, updateCar } from "/src/api/car/car";
export default {
name: "Car",
data() {
return {
//
loading: true,
//
ids: [],
//
single: true,
//
multiple: true,
//
showSearch: true,
//
total: 0,
//
carList: [],
//
title: "",
//
open: false,
//
queryParams: {
pageNum: 1,
pageSize: 10,
carVin: null,
carPlate: null,
carBrand: null,
carModel: null,
carType: null,
state: null,
},
//
form: {},
//
rules: {
}
};
},
created() {
this.getList();
},
methods: {
/** 查询车辆基础信息列表 */
getList() {
this.loading = true;
listCar(this.queryParams).then(response => {
this.carList = response.data.rows;
this.total = response.data.total;
this.loading = false;
});
},
//
cancel() {
this.open = false;
this.reset();
},
//
reset() {
this.form = {
id: null,
carVin: null,
carPlate: null,
carBrand: null,
carModel: null,
carType: null,
carLastJoinTime: null,
carLastOfflineTime: null,
carMotorManufacturer: null,
carMotorModel: null,
carBatteryManufacturer: null,
carBatteryModel: null,
groupCode: null,
state: null,
createBy: null,
createTime: null,
updateBy: null,
updateTime: null,
remark: null
};
this.resetForm("form");
},
/** 搜索按钮操作 */
handleQuery() {
this.queryParams.pageNum = 1;
this.getList();
},
/** 重置按钮操作 */
resetQuery() {
this.resetForm("queryForm");
this.handleQuery();
},
//
handleSelectionChange(selection) {
this.ids = selection.map(item => item.id)
this.single = selection.length!==1
this.multiple = !selection.length
},
/** 新增按钮操作 */
handleAdd() {
this.reset();
this.open = true;
this.title = "添加车辆基础信息";
},
/** 修改按钮操作 */
handleUpdate(row) {
this.reset();
const id = row.id || this.ids
getCar(id).then(response => {
this.form = response.data;
this.open = true;
this.title = "修改车辆基础信息";
});
},
/** 提交按钮 */
submitForm() {
this.$refs["form"].validate(valid => {
if (valid) {
if (this.form.id != null) {
updateCar(this.form).then(response => {
this.$modal.msgSuccess("修改成功");
this.open = false;
this.getList();
});
} else {
addCar(this.form).then(response => {
this.$modal.msgSuccess("新增成功");
this.open = false;
this.getList();
});
}
}
});
},
/** 删除按钮操作 */
handleDelete(row) {
const ids = row.id || this.ids;
this.$modal.confirm('是否确认删除车辆基础信息编号为"' + ids + '"的数据项?').then(function() {
return delCar(ids);
}).then(() => {
this.getList();
this.$modal.msgSuccess("删除成功");
}).catch(() => {});
},
/** 导出按钮操作 */
handleExport() {
this.download('car/car/export', {
...this.queryParams
}, `car_${new Date().getTime()}.xlsx`)
}
}
};
</script>

View File

@ -0,0 +1,313 @@
<template>
<div class="app-container">
<el-container>
<el-aside width="400px">
<el-button @click="handleAddTemplate"></el-button>
<el-empty description="暂无报文模版" v-if="templateList.length == 0"></el-empty>
<el-col :span="24" v-for="template in templateList" v-if="templateList.length != 0">
<el-card class="box-card" style="margin-top: 20px">
<div slot="header" class="text">
<span>{{ template.messageTemplateName }}</span>
<el-button style="float: right" type="text" @click="handleArrange(template.messageTemplateId)">
</el-button>
</div>
<div class="text">
<span>{{ template.messageTemplateDescribe }}</span>
</div>
</el-card>
</el-col>
</el-aside>
<el-container v-if="this.queryParam.messageTemplateId != 0">
<el-header>
<el-form :inline="true" ref="queryParams" :model="addParams" class="demo-form-inline">
<el-form-item label="报文类别" size="mini">
<el-select
v-model="addParams.messageType"
clearable
placeholder="报文类别"
>
<el-option
v-for="dict in dict.type.car_message_type"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="编码" size="mini">
<el-input v-model="addParams.messageCode" placeholder="编码"></el-input>
</el-form-item>
<el-form-item label="标签" size="mini">
<el-input v-model="addParams.messageLabel" placeholder="标签"></el-input>
</el-form-item>
<el-form-item label="起始位" size="mini">
<el-input v-model="addParams.messageStartIndex" placeholder="起始位"></el-input>
</el-form-item>
<el-form-item label="终止位" size="mini">
<el-input v-model="addParams.messageEndIndex" placeholder="终止位"></el-input>
</el-form-item>
<el-form-item label="数据类型" size="mini">
<el-select
v-model="addParams.messageDataType"
clearable
placeholder="数据类型"
>
<el-option
v-for="dict in dict.type.car_message_data_type"
:key="dict.value"
:label="dict.label"
:value="dict.value"
/>
</el-select>
</el-form-item>
<el-form-item label="固定值" size="mini" v-if="this.addParams.messageDataType == 'fixed'">
<el-input v-model="addParams.fixedValue" placeholder="固定值"></el-input>
</el-form-item>
<el-form-item label="最小值" size="mini" v-if="this.addParams.messageDataType == 'range'">
<el-input v-model="addParams.minimumValue" placeholder="最小值"></el-input>
</el-form-item>
<el-form-item label="最大值" size="mini" v-if="this.addParams.messageDataType == 'range'">
<el-input v-model="addParams.maximumValue" placeholder="最大值"></el-input>
</el-form-item>
<el-form-item size="mini">
<el-button type="primary" @click="handleAddValue"></el-button>
<el-button icon="el-icon-refresh" @click="resetQuery"></el-button>
</el-form-item>
</el-form>
</el-header>
<el-main style="margin-top: 35px">
<el-tabs v-model="queryParam.messageType" @tab-click="handleClick">
<el-tab-pane label="基础" name="basics">
<el-table :data="valueList">
<el-table-column label="编码" prop="messageCode" align="center"/>
<el-table-column label="标签" prop="messageLabel" align="center"/>
<el-table-column label="起始位" prop="messageStartIndex" align="center"/>
<el-table-column label="终止位" prop="messageEndIndex" align="center"/>
<el-table-column align="center" label="数据类型" prop="messageDataType">
<template slot-scope="scope">
<dict-tag :options="dict.type.car_message_data_type" :value="scope.row.messageDataType"/>
</template>
</el-table-column>
<el-table-column label="固定值" prop="fixedValue" align="center">
<template slot-scope="scope">
{{scope.row.fixedValue?scope.row.fixedValue:'-'}}
</template>
</el-table-column>
<el-table-column label="最小值" align="center">
<template slot-scope="scope">
{{scope.row.minimumValue?scope.row.minimumValue:'-'}}
</template>
</el-table-column>
<el-table-column label="最大值" align="center">
<template slot-scope="scope">
{{scope.row.maximumValue?scope.row.maximumValue:'-'}}
</template>
</el-table-column>
</el-table>
</el-tab-pane>
<el-tab-pane label="数据" name="info">
<el-table :data="valueList">
<el-table-column label="编码" prop="messageCode" align="center"/>
<el-table-column label="标签" prop="messageLabel" align="center"/>
<el-table-column label="起始位" prop="messageStartIndex" align="center"/>
<el-table-column label="终止位" prop="messageEndIndex" align="center"/>
<el-table-column align="center" label="数据类型" prop="messageDataType">
<template slot-scope="scope">
<dict-tag :options="dict.type.car_message_data_type" :value="scope.row.messageDataType"/>
</template>
</el-table-column>
<el-table-column label="固定值" prop="fixedValue" align="center">
<template slot-scope="scope">
{{scope.row.fixedValue?scope.row.fixedValue:'-'}}
</template>
</el-table-column>
<el-table-column label="最小值" align="center">
<template slot-scope="scope">
{{scope.row.minimumValue?scope.row.minimumValue:'-'}}
</template>
</el-table-column>
<el-table-column label="最大值" align="center">
<template slot-scope="scope">
{{scope.row.maximumValue?scope.row.maximumValue:'-'}}
</template>
</el-table-column>
</el-table>
</el-tab-pane>
<el-tab-pane label="状态" name="status">
<el-table :data="valueList">
<el-table-column label="编码" prop="messageCode" align="center"/>
<el-table-column label="标签" prop="messageLabel" align="center"/>
<el-table-column label="起始位" prop="messageStartIndex" align="center"/>
<el-table-column label="终止位" prop="messageEndIndex" align="center"/>
<el-table-column label="数据类型" prop="messageDataType" align="center"/>
<el-table-column label="固定值" prop="fixedValue" align="center">
<template slot-scope="scope">
{{scope.row.fixedValue?scope.row.fixedValue:'-'}}
</template>
</el-table-column>
<el-table-column label="最小值" align="center">
<template slot-scope="scope">
{{scope.row.minimumValue?scope.row.minimumValue:'-'}}
</template>
</el-table-column>
<el-table-column label="最大值" align="center">
<template slot-scope="scope">
{{scope.row.maximumValue?scope.row.maximumValue:'-'}}
</template>
</el-table-column>
</el-table>
</el-tab-pane>
</el-tabs>
</el-main>
</el-container>
</el-container>
<el-dialog title="添加报文模版" :visible.sync="open" append-to-body>
<el-form :model="form">
<el-form-item label="模版名称">
<el-input v-model="form.messageTemplateName" placeholder="模版名称"></el-input>
</el-form-item>
<el-form-item label="模版描述">
<el-input v-model="form.messageTemplateDescribe" placeholder="模版描述"></el-input>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm"> </el-button>
<el-button @click="cancel"> </el-button>
</div>
</el-dialog>
</div>
</template>
<script>
import {
templateList,
addTemplate,
valueList,
addValue
} from "/src/api/car/message/template";
export default {
name: "MessageTemplateValue",
dicts: ['car_message_type', 'car_message_data_type'],
data() {
return {
//
templateList: [],
//
open: false,
//
form: {},
//
queryParam: {
//
messageTemplateId: 0,
//
messageType: '',
},
//
valueList: [],
//
addParams: {
templateId: 0,
},
};
},
created() {
//
this.getTemplateList();
},
methods: {
/** 获取报文模版列表 */
getTemplateList() {
templateList().then(response => {
this.templateList = response.data;
})
},
/** 添加报文模版 */
handleAddTemplate() {
this.open = true
},
/** 提交按钮 */
submitForm() {
addTemplate(this.form).then(response => {
this.$modal.msgSuccess("修改成功");
this.open = false;
this.getTemplateList();
})
},
/** 取消按钮 */
cancel() {
this.open = false;
this.reset();
},
/** 模版配置 */
handleArrange(messageTemplateId) {
this.queryParam.messageTemplateId = messageTemplateId;
this.addParams.templateId = messageTemplateId;
},
/** 切换选项卡 */
handleClick() {
valueList(this.queryParam).then(response => {
this.valueList = response.data
})
},
/** 添加报文数据 */
handleAddValue(){
if (this.addParams.messageType == null){
this.$modal.msgError("请选择报文类别");
}else {
addValue(this.addParams).then(response => {
this.$modal.msgSuccess("添加成功");
valueList(this.queryParam).then(response => {
this.valueList = response.data
})
})
}
},
/** 重置按钮操作 */
resetQuery() {
this.addParams = {
messageType: '',
messageCode: '',
messageLabel: '',
messageStartIndex: '',
messageEndIndex: '',
messageDataType: '',
fixedValue: '',
minimumValue: '',
maximumValue: ''
}
},
}
};
</script>
<style>
.el-header {
//background-color: #B3C0D1;
//color: #333;
text-align: center;
}
.el-aside {
//background-color: #D3DCE6;
//color: #333;
}
.el-main {
//background-color: #E9EEF3;
//color: #333;
text-align: center;
}
.text {
line-height: 30px;
}
.box-card {
width: 350px;
margin-top: 15px;
}
</style>