lanan-repair-app/pages-internal/carManagement/informationAdd.vue
2025-08-11 17:42:50 +08:00

596 lines
13 KiB
Vue

<!-- 发起订单 -->
<template>
<view class="content">
<!-- <view class="c-top">-->
<!-- <view class="" @click="getback()">-->
<!-- <uni-icons type="left" size="18"></uni-icons>-->
<!-- </view>-->
<!-- <view class="c-title" v-if="type == 'add'">新增设备</view>-->
<!-- <view class="c-title" v-if="type == 'edit'">编辑设备</view>-->
<!-- <view class=""></view>-->
<!-- </view>-->
<!-- <headersVue :titles="pageName" style="position: static !important;">
<u-icon name="arrow-left" color="#fff" size="18"></u-icon>
</headersVue> -->
<view class="page-top" :style='{ justifyContent: "center" }'>
<!-- 返回上一级页面信息 -->
<view class='go-back-page' @click='pageBack'>返回</view>
<!-- 人员/车辆/我的组件显示的表头信息 -->
<view class="other-title-class">
{{pageName}}
</view>
</view>
<view class="dil">
<view class="tinput">
<view class="text1">
<text class="hong1">*</text>
设备名称
</view>
<view class="you">
<input type="text" placeholder="请输入设备名称" v-model="box.equName">
</view>
</view>
<view class="tinput">
<view class="text1">
<text class="hong1">*</text>
设备型号
</view>
<view class="you">
<input type="text" placeholder="请输入设备型号" v-model="box.equModel">
</view>
</view>
<view class="tinput">
<view class="text1">
<text class="hong1">*</text>
设备编号
</view>
<view class="you">
<input type="text" placeholder="请输入设备编号" v-model="box.equNumber">
</view>
</view>
<view class="tinput" @click="typeShow = true">
<view class="text1">
设备类别
</view>
<view class="you">
<input type="text" disabled placeholder="请选择设备类别" v-model="typeName">
</view>
</view>
<view class="tinput">
<view class="text1">
<text class="hong1">*</text>
设备检定周期
</view>
<view class="you">
<input type="text" placeholder="请输入设备检定周期" v-model="box.equZq">
</view>
</view>
<view class="tinput">
<view class="text1">
<text class="hong1">*</text>
上次检定单位
</view>
<view class="you">
<input type="text" placeholder="请输入上次检定单位" v-model="box.lastUnit">
</view>
</view>
<view class="tinput">
<view class="text1">
<text class="hong1">*</text>
有效期
</view>
<!-- validTime -->
<view class="you" @click="show = true ">
<text>{{ time || '' }}</text>
</view>
</view>
<view class="tinput">
<view class="text1">
<text class="hong1">*</text>
下次检定时间
</view>
<!-- nextCheckTime -->
<view class="you" @click="show1 = true ">
<text>{{ time1 || '' }}</text>
</view>
</view>
<view class="tinput">
<view class="text1">
<text class="hong1">*</text>
设备附件
</view>
<view class="lan_" @click="goFile">查看附件
<image src="/static/imgs/add.png" mode=""></image>
</view>
</view>
<u-datetime-picker :show="show" v-model="box.validTime" @cancel="cancels" @confirm="confirms" mode="date"
return-type='string'></u-datetime-picker>
<u-datetime-picker :show="show1" v-model="box.nextCheckTime" @cancel="cancels1" @confirm="confirms1"
mode="date" return-type='string'></u-datetime-picker>
<u-picker :show="typeShow" :columns="columns" @confirm="confirmsType" @cancel="typeShow = false"
keyName="label"></u-picker>
<view class="anniu" @click="getnewsadd()">
<text>保存</text>
</view>
<view style="width: 100%; height: 60px;"></view>
</view>
</view>
</template>
<script>
import request from '@/utils/request'
import config from '@/config'
import {
getToken
} from '@/utils/auth'
import upload from '@/utils/upload.js'
// import {getDictDataByType} from "@/utils/utils";
// import headersVue from "@/components/header/headers.vue";
var wvCurrent;
export default {
// components: {headersVue},
data() {
return {
time: '请选择有效期',
time1: '请选择下次检定时间',
value1: '2023-10-10',
baseUrl: this.$baseUrl,
show: false,
show1: false,
fileId: null,
id: '',
type: 'add',
box: {},
typeShow: false,
columns: [],
typeName: null,
//附件列表
fileList3: [],
pageName: '新增设备',
baseImageUrl: config.baseImageUrl,
}
},
onLoad(option) {
this.type = option.type
if (option.type == 'edit') {
this.box.id = option.id
this.pageName = '编辑设备'
}
this.getInsType()
},
onShow() {
if (this.type == 'edit') this.getDetail();
},
methods: {
confirmsType(e) {
console.log(e)
this.box.type = e.value[0].value
this.typeName = e.value[0].label
this.typeShow = false
},
async getInsType() {
if (!this.columns || this.columns.length === 0) {
this.columns = [await getDictDataByType("ins_equ_type")]
}
console.log(this.columns)
},
async getDetail() {
let res = await request({
url: '/admin-api/system/equInfo/' + this.box.id,
method: 'get'
})
if (res.code == 200) {
this.box = res.data
if (this.box.fileList) {
this.fileList3 = this.box.fileList
// 在回显时给 URL 加上域名
this.fileList3 = this.fileList3.map(file => {
// 如果是相对路径,添加域名
file.url = this.baseImageUrl + '/' + file.url;
return file;
});
}
// this.maneizhi = this.box.type
this.time = this.box.validTime
this.time1 = this.box.nextCheckTime
}
if (this.box.type) {
const data = this.columns[0]
const index = data.findIndex(item => item.value === this.box.type)
if (index !== -1) {
this.typeName = data[index].label
}
}
},
cancels() {
this.show = false
},
cancels1() {
this.show1 = false
},
confirms(e) {
var timestamp = e.value;
var date = new Date(timestamp);
var year = date.getFullYear();
var month = ("0" + (date.getMonth() + 1)).slice(-2);
var day = ("0" + date.getDate()).slice(-2);
var formattedDate = year + "-" + month + "-" + day;
this.box.validTime = formattedDate
this.time = formattedDate
this.show = false
},
confirms1(e) {
var timestamp = e.value;
var date = new Date(timestamp);
var year = date.getFullYear();
var month = ("0" + (date.getMonth() + 1)).slice(-2);
var day = ("0" + date.getDate()).slice(-2);
var formattedDate = year + "-" + month + "-" + day;
this.box.nextCheckTime = formattedDate
this.time1 = formattedDate
this.show1 = false
},
//发布按钮
async getnewsadd() {
// if(this.box.filePath==''||this.box.fileName==''||this.box.warnTime==''){
// uni.showToast({
// title:'必填项不能有空!',
// icon:'none'
// })
this.box.fileList = this.fileList3.map(file => {
// 去掉域名,返回相对路径
if (file.url && file.url.startsWith(this.baseImageUrl)) {
file.url = file.url.replace(this.baseImageUrl, '');
}
return file;
});
if (this.type == 'add') {
let res = await request({
url: '/admin-api/system/equInfo/add',
method: 'post',
data: this.box
})
if (res.code == 200) {
uni.showToast({
title: '发布成功'
})
setTimeout(() => {
uni.navigateBack({
delta: 1
});
}, 1000);
}
}
if (this.type == 'edit') {
let res = await request({
url: '/admin-api/system/equInfo/edit',
method: 'post',
data: this.box
})
if (res.code == 200) {
uni.showToast({
title: '发布成功'
})
setTimeout(() => {
uni.navigateBack({
delta: 1
});
}, 1000);
}
}
},
getback() {
uni.navigateBack({
delta: 1,
})
},
// 删除图片
deletePic(event) {
this[`fileList${event.name}`].splice(event.index, 1);
},
// 新增图片
async afterRead(event) {
// 当设置 multiple 为 true 时, file 为数组格式,否则为对象格式
let lists = [].concat(event.file);
let fileListLen = this[`fileList${event.name}`].length;
lists.map((item) => {
this[`fileList${event.name}`].push({
...item,
status: "uploading",
message: "上传中",
});
});
for (let i = 0; i < lists.length; i++) {
const result = await this.uploadFilePromise(lists[i].url);
let item = this[`fileList${event.name}`][fileListLen];
this[`fileList${event.name}`].splice(
fileListLen,
1,
Object.assign(item, {
status: "success",
message: "",
url: result,
})
);
fileListLen++;
}
console.log('现在文件集合', this[`fileList${event.name}`])
},
uploadFilePromise(url) {
return new Promise((resolve, reject) => {
upload({
url: '/admin-api/common/upload',
filePath: url,
}).then((res) => {
resolve(res.data.url);
})
});
},
pageBack() {
uni.navigateBack({
delta: 1 // delta值为1时表示返回的页面层数
});
},
goFile() {
if (!this.box.id) {
uni.showToast({
title: '请先新建设备',
icon: 'none'
})
return
}
if (!this.box.folderId) {
console.log('当前员工没有文件加')
//给当前员工创建一个文件夹
request({
url: '/admin-api/system/equInfo/addFolder',
method: 'post',
data: JSON.stringify(this.box.id), // 手动转换为 JSON
}).then(res => {
this.box.folderId = res.data
uni.navigateTo({
url: '/pages/internalManagement/dataManagement/deviceManage?type=staff&folderId=' +
this.box.folderId
})
})
} else {
uni.navigateTo({
url: '/pages/internalManagement/dataManagement/deviceManage?type=staff&folderId=' + this
.box.folderId
})
}
},
}
}
</script>
<style scoped lang="scss">
.content {
width: 100%;
height: calc(100vh);
background-color: #F6F6F6;
box-sizing: border-box;
// padding-top: 45px;
}
.dil {
box-sizing: border-box;
background-color: #F6F6F6;
padding: 0px 12px;
}
.lan_ {
font-size: 28rpx;
color: #327DFB;
display: flex;
align-items: center;
image {
width: 36rpx;
height: 36rpx;
margin-left: 15rpx;
}
}
.top-icon {
margin-bottom: 45px;
}
.c-top {
width: 100%;
box-sizing: border-box;
padding: 15px;
display: flex;
justify-content: space-between;
align-items: center;
background-color: white;
padding-top: 40px;
}
.c-title {
font-size: 18px;
font-weight: bold
}
.top {
box-sizing: border-box;
padding: 0px 15px;
width: 100%;
background-color: white;
}
.top-box {
display: flex;
justify-content: space-between;
align-items: center;
box-sizing: border-box;
padding: 20px 0px;
}
.tb-left {
height: 100%;
width: 80%;
display: flex;
align-items: center;
}
.uicon {
width: 18px;
height: 18px;
border-radius: 4px;
color: white;
background: orangered;
display: flex;
justify-content: center;
align-items: center;
font-size: 12px;
font-weight: bold;
margin-right: 6px;
}
.tb-right {
width: 20px;
height: 26px;
image {
width: 100%;
height: 100%;
}
}
.text1 {
font-size: 16px;
font-weight: bold;
color: #363636;
}
.hong1 {
margin-top: 5px;
font-size: 12px;
font-weight: 400;
color: #FF5453;
}
.hong2 {
margin-top: 5px;
font-size: 12px;
font-weight: 400;
}
.tinput {
width: 100%;
display: flex;
background: white;
align-items: center;
justify-content: space-between;
box-sizing: border-box;
padding: 16px;
margin-top: 14px;
margin-bottom: 14px;
}
.xinput {
width: 100%;
background: white;
box-sizing: border-box;
padding: 16px;
margin-top: 14px;
}
.you {
text-align: right;
}
.xz {
margin-top: 10px;
display: flex;
align-items: center;
}
.kuang {
width: 80px;
height: 23px;
background: #ECECEC;
border-radius: 5px;
display: flex;
justify-content: center;
align-items: center;
color: #666666;
font-size: 14px;
margin-right: 15px;
}
.xlan {
background: #CDE7FF !important;
color: #1D62FF !important;
border: 1px solid #2A96FE;
}
.anniu {
width: 100%;
//background: linear-gradient(180deg, #3F61C0 0%, #0D2E8D 100%);
background: #327dfb;
border-radius: 50px;
height: 40px;
display: flex;
justify-content: center;
align-items: center;
//color: #542F0E;
margin-top: 20px;
color: white;
}
button::after {
border: none;
}
.page-top {
flex-shrink: 0;
width: 100%;
height: 160rpx;
display: flex;
align-items: center;
color: white;
flex-shrink: 0;
background: linear-gradient(180deg, #054DF3 0%, #55A3FF 100%);
.go-back-page {
position: absolute;
left: 20rpx;
}
}
</style>