|
@@ -1,6 +1,5 @@
|
|
|
<template>
|
|
|
- <el-form ref="form" label-width="106px" class="camera-from">
|
|
|
- <div class="def-select-map" ref="mapEl"></div>
|
|
|
+ <el-form ref="form" label-width="84px" class="camera-from">
|
|
|
<div class="el-form-item">
|
|
|
<el-col :span="12">
|
|
|
<el-form-item label="项目编号" class="mandatory">
|
|
@@ -21,25 +20,26 @@
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
</div>
|
|
|
- <el-form-item label="详细地址" class="mandatory asdasd">
|
|
|
- <!-- <el-input
|
|
|
- v-model="bindFire.projectAddress"
|
|
|
- maxlength="50"
|
|
|
- placeholder="请输入详细地址"
|
|
|
- /> -->
|
|
|
+ <el-form-item label="详细地址" class="mandatory">
|
|
|
<el-input
|
|
|
- v-model="bindFire.projectAddress"
|
|
|
+ v-model="bindFire.mapUrl"
|
|
|
placeholder="输入名称搜索"
|
|
|
clearable
|
|
|
disabled
|
|
|
+ class="mandatory"
|
|
|
>
|
|
|
<template #append>
|
|
|
<el-button :icon="Search" @click="searchAMapAddress" />
|
|
|
</template>
|
|
|
</el-input>
|
|
|
</el-form-item>
|
|
|
- <el-form-item label="勘验地址">
|
|
|
- <el-input v-model="bindFire.field1" maxlength="50" placeholder="请输入勘验地址" />
|
|
|
+
|
|
|
+ <el-form-item label="起火地址" class="mandatory">
|
|
|
+ <el-input
|
|
|
+ v-model="bindFire.projectAddress"
|
|
|
+ maxlength="50"
|
|
|
+ placeholder="请输入起火地址"
|
|
|
+ />
|
|
|
</el-form-item>
|
|
|
<el-form-item label="起火场所" class="mandatory">
|
|
|
<el-cascader
|
|
@@ -50,42 +50,26 @@
|
|
|
:props="{ expandTrigger: 'hover' }"
|
|
|
/>
|
|
|
</el-form-item>
|
|
|
- <!-- <el-form-item label="全宗名称">
|
|
|
- <el-input v-model="bindFire.field2" maxlength="50" placeholder="请输入全宗名称" />
|
|
|
- </el-form-item> -->
|
|
|
-
|
|
|
<div class="el-form-item">
|
|
|
<el-col :span="12">
|
|
|
- <el-form-item label="勘验单位" class="mandatory">
|
|
|
+ <el-form-item label="承办单位" class="mandatory">
|
|
|
<companySelect v-model="bindFire.deptId" hideAll :notUpdate="true" disabled />
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
<el-col :span="12">
|
|
|
- <el-form-item label="勘验人员" class="mandatory">
|
|
|
- <el-input
|
|
|
- v-model="bindFire.organizerUsers"
|
|
|
- maxlength="50"
|
|
|
- placeholder="请输入勘验人员"
|
|
|
- />
|
|
|
+ <el-form-item label="承办人员" class="mandatory" placeholder="请输入承办人员">
|
|
|
+ <el-input v-model="bindFire.organizerUsers" maxlength="50" />
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
</div>
|
|
|
<div class="el-form-item">
|
|
|
- <!-- <el-col :span="12">
|
|
|
- <el-form-item label="勘验人姓名">
|
|
|
- <el-input
|
|
|
- v-model="bindFire.field3"
|
|
|
- maxlength="18"
|
|
|
- placeholder="请输入勘验人姓名"
|
|
|
- />
|
|
|
- </el-form-item>
|
|
|
- </el-col> -->
|
|
|
<el-col :span="12">
|
|
|
- <el-form-item label="勘验人职务">
|
|
|
- <el-input
|
|
|
- v-model="bindFire.field4"
|
|
|
- maxlength="50"
|
|
|
- placeholder="请输入勘验人职务"
|
|
|
+ <el-form-item label="事故日期" class="mandatory" placeholder="请选择事故日期">
|
|
|
+ <el-date-picker
|
|
|
+ type="date"
|
|
|
+ v-model="accidentDate"
|
|
|
+ style="width: 100%"
|
|
|
+ :disabled-date="(date) => date.getTime() > new Date().getTime()"
|
|
|
/>
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
@@ -100,78 +84,12 @@
|
|
|
/>
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
+
|
|
|
</div>
|
|
|
-
|
|
|
<div class="el-form-item">
|
|
|
<el-col :span="12">
|
|
|
- <el-form-item label="事故日期" class="mandatory" placeholder="请选择事故日期">
|
|
|
- <el-date-picker
|
|
|
- type="date"
|
|
|
- v-model="accidentDate"
|
|
|
- style="width: 100%"
|
|
|
- :disabled-date="(date) => date.getTime() > new Date().getTime()"
|
|
|
- />
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="大屏显示" class="mandatory">
|
|
|
- <el-switch v-model="bindFire.mapShow" :disabled="!bindFire.latlng" />
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- </div>
|
|
|
-
|
|
|
- <div class="el-form-item">
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="事件分类">
|
|
|
- <el-input
|
|
|
- v-model="bindFire.field5"
|
|
|
- maxlength="18"
|
|
|
- placeholder="请输入事件分类"
|
|
|
- />
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="分类登记">
|
|
|
- <el-input
|
|
|
- v-model="bindFire.field6"
|
|
|
- maxlength="50"
|
|
|
- placeholder="请输入分类登记"
|
|
|
- />
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- </div>
|
|
|
-
|
|
|
- <div class="el-form-item">
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item label="天气情况">
|
|
|
- <el-input
|
|
|
- v-model="bindFire.field7"
|
|
|
- placeholder="请输入天气情况"
|
|
|
- show-word-limit
|
|
|
- maxlength="100"
|
|
|
- />
|
|
|
- </el-form-item>
|
|
|
- </el-col>
|
|
|
- <el-col :span="12">
|
|
|
- <el-form-item
|
|
|
- label="勘验起止时间"
|
|
|
- class="mandatory"
|
|
|
- placeholder="请选择勘验起止时间"
|
|
|
- >
|
|
|
- <el-date-picker
|
|
|
- v-model="f8"
|
|
|
- type="daterange"
|
|
|
- range-separator="-"
|
|
|
- start-placeholder="开始时间"
|
|
|
- end-placeholder="结束时间"
|
|
|
- :disabled-date="(date) => date.getTime() > new Date().getTime()"
|
|
|
- />
|
|
|
- <!-- <el-date-picker
|
|
|
- type="date"
|
|
|
- v-model="f8"
|
|
|
- style="width: 100%"
|
|
|
- :disabled-date="(date) => date.getTime() > new Date().getTime()"
|
|
|
- /> -->
|
|
|
+ <el-form-item label="首页显示" class="mandatory">
|
|
|
+ <el-switch v-model="bindFire.mapShow" :disabled="!bindFire.latAndLong" />
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
</div>
|
|
@@ -180,14 +98,13 @@
|
|
|
|
|
|
<script setup lang="ts">
|
|
|
import companySelect from "@/components/company-select/index.vue";
|
|
|
-import { ref, watchEffect } from "vue";
|
|
|
+import { ref } from "vue";
|
|
|
import { Fire, setFire, addFire } from "@/app/fire/store/fire";
|
|
|
import { reason, place } from "@/app/fire/constant/fire";
|
|
|
import { ElMessage } from "element-plus";
|
|
|
-import { dateFormat, debounce } from "@/util";
|
|
|
+import { dateFormat } from "@/util";
|
|
|
import { genCascaderValue, getCode } from "@/helper/cascader";
|
|
|
import { QuiskExpose } from "@/helper/mount";
|
|
|
-import AMapLoader from "@amap/amap-jsapi-loader";
|
|
|
import { user } from "@/store/user";
|
|
|
import { Search } from "@element-plus/icons-vue";
|
|
|
import { selectMapImage } from "@/view/case/quisk";
|
|
@@ -208,31 +125,14 @@ const accidentDate = ref(
|
|
|
bindFire.value.accidentDate ? new Date(bindFire.value.accidentDate) : new Date()
|
|
|
);
|
|
|
|
|
|
-const f8s = [new Date(), new Date()];
|
|
|
-if (bindFire.value.field8) {
|
|
|
- const s = bindFire.value.field8.split("至");
|
|
|
- console.log(s);
|
|
|
- if (s.length > 1) {
|
|
|
- f8s[0] = new Date(s[0]);
|
|
|
- f8s[1] = new Date(s[1]);
|
|
|
- } else {
|
|
|
- f8s[0] = new Date(s[0]);
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-const f8 = ref(f8s);
|
|
|
-const searchAMapAddress = async () => {
|
|
|
- const data = await selectMapImage({});
|
|
|
- if (!data?.search) return;
|
|
|
- bindFire.value.projectAddress = data.search.text;
|
|
|
- bindFire.value.latlng = bindFire.value.latAndLong = `${data.search.lat},${data.search.lng}`;
|
|
|
-};
|
|
|
-
|
|
|
defineExpose<QuiskExpose>({
|
|
|
async submit() {
|
|
|
- if (!bindFire.value.projectAddress || !bindFire.value.projectAddress.trim()) {
|
|
|
- ElMessage.error("详细地址不能为空!");
|
|
|
+ if (!bindFire.value.latAndLong || !bindFire.value.latAndLong.trim()) {
|
|
|
+ ElMessage.error("详细地址不能为空");
|
|
|
throw "详细地址不能为空!";
|
|
|
+ } else if (!bindFire.value.projectAddress || !bindFire.value.projectAddress.trim()) {
|
|
|
+ ElMessage.error("起火地址不能为空!");
|
|
|
+ throw "起火地址不能为空!";
|
|
|
} else if (!bindFire.value.projectSn || !bindFire.value.projectSn.trim()) {
|
|
|
ElMessage.error("项目编号不能为空!");
|
|
|
throw "项目编号不能为空!";
|
|
@@ -243,11 +143,11 @@ defineExpose<QuiskExpose>({
|
|
|
ElMessage.error("起火场所不能为空!");
|
|
|
throw "起火场所不能为空!";
|
|
|
} else if (!bindFire.value.deptId || !bindFire.value.deptId.trim()) {
|
|
|
- ElMessage.error("勘验单位不能为空!");
|
|
|
- throw "勘验单位不能为空!";
|
|
|
+ ElMessage.error("承办单位不能为空!");
|
|
|
+ throw "承办单位不能为空!";
|
|
|
} else if (!bindFire.value.organizerUsers || !bindFire.value.organizerUsers.trim()) {
|
|
|
- ElMessage.error("勘验人员不能为空!");
|
|
|
- throw "勘验人员不能为空!";
|
|
|
+ ElMessage.error("承办人员不能为空!");
|
|
|
+ throw "承办人员不能为空!";
|
|
|
} else if (!accidentDate) {
|
|
|
ElMessage.error("事故日期不能为空!");
|
|
|
throw "事故日期不能为空!";
|
|
@@ -257,65 +157,17 @@ defineExpose<QuiskExpose>({
|
|
|
}
|
|
|
|
|
|
bindFire.value.accidentDate = dateFormat(accidentDate.value, "yyyy-MM-dd");
|
|
|
- bindFire.value.field8 =
|
|
|
- dateFormat(f8.value[0], "yyyy-MM-dd") +
|
|
|
- "至" +
|
|
|
- dateFormat(f8.value[1], "yyyy-MM-dd");
|
|
|
bindFire.value.projectSiteCode = getCode(place, bindFire.value.projectSite);
|
|
|
bindFire.value.id
|
|
|
? await setFire(bindFire.value)
|
|
|
: await addFire(bindFire.value as any);
|
|
|
},
|
|
|
});
|
|
|
-</script>
|
|
|
-
|
|
|
-<style scoped>
|
|
|
-.search-result {
|
|
|
- position: absolute;
|
|
|
- left: 0;
|
|
|
- right: 0;
|
|
|
- z-index: 1;
|
|
|
- overflow: hidden;
|
|
|
- top: 100%;
|
|
|
|
|
|
- &.show {
|
|
|
- max-height: 450px;
|
|
|
- overflow-y: auto;
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-.def-map-info {
|
|
|
- margin-top: 10px;
|
|
|
- p {
|
|
|
- font-size: 14px;
|
|
|
- color: rgba(0, 0, 0, 0.85);
|
|
|
- display: inline;
|
|
|
- &:not(:last-child)::after {
|
|
|
- content: ",";
|
|
|
- margin-right: 6px;
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- span::after {
|
|
|
- content: ":";
|
|
|
- }
|
|
|
-}
|
|
|
-
|
|
|
-.def-select-map {
|
|
|
- position: absolute;
|
|
|
- opacity: 0;
|
|
|
- z-index: -1;
|
|
|
- width: 540px;
|
|
|
- height: 390px;
|
|
|
- z-index: 1;
|
|
|
- left: -100vw;
|
|
|
- top: -100vh;
|
|
|
- display: none;
|
|
|
-}
|
|
|
-
|
|
|
-.asdasd {
|
|
|
- position: relative;
|
|
|
- margin-bottom: 15px;
|
|
|
- z-index: 2;
|
|
|
-}
|
|
|
-</style>
|
|
|
+const searchAMapAddress = async () => {
|
|
|
+ const data = await selectMapImage({});
|
|
|
+ if (!data?.search) return;
|
|
|
+ bindFire.value.mapUrl = data.search.text;
|
|
|
+ bindFire.value.latAndLong = `${data.search.lat},${data.search.lng}`;
|
|
|
+};
|
|
|
+</script>
|