|
@@ -1,17 +1,22 @@
|
|
|
<template>
|
|
|
<div class="container">
|
|
|
- <div v-if="!hideMap" id="aMap" class="event_map"></div>
|
|
|
+ <div v-if="!hideMap" id="aMap" class="event_map" />
|
|
|
<div class="box">
|
|
|
- <div class="event_title">{{ eventInfo.event_title || "暂无事件标题" }}</div>
|
|
|
+ <div class="event_title">
|
|
|
+ {{ eventInfo.event_title || "暂无事件标题" }}
|
|
|
+ </div>
|
|
|
<div class="event_prop">
|
|
|
<div class="event_type">
|
|
|
- <dict-tag :options="mm_event_type" :value="eventInfo.event_type"></dict-tag>
|
|
|
+ <dict-tag :options="mm_event_type" :value="eventInfo.event_type" />
|
|
|
</div>
|
|
|
<div class="event_level">
|
|
|
- <dict-tag :options="mm_event_level" :value="eventInfo.event_level||'0'"></dict-tag>
|
|
|
+ <dict-tag
|
|
|
+ :options="mm_event_level"
|
|
|
+ :value="eventInfo.event_level || '0'"
|
|
|
+ />
|
|
|
</div>
|
|
|
<div class="event_status">
|
|
|
- <dict-tag :options="mm_event_state" :value="eventInfo.event_status"></dict-tag>
|
|
|
+ <dict-tag :options="mm_event_state" :value="eventInfo.event_status" />
|
|
|
</div>
|
|
|
</div>
|
|
|
<van-tabs v-model:active="active">
|
|
@@ -19,93 +24,117 @@
|
|
|
<div class="event_tab">
|
|
|
<div class="event-data-item">
|
|
|
<div class="item-left">
|
|
|
- <i class="icon6"/>
|
|
|
+ <i class="icon6" />
|
|
|
<div class="event-data-item-title">事件编号:</div>
|
|
|
</div>
|
|
|
<div class="event-data-item-value">{{ eventInfo.event_id }}</div>
|
|
|
</div>
|
|
|
<div class="event-data-item">
|
|
|
<div class="item-left">
|
|
|
- <i class="icon1"/>
|
|
|
+ <i class="icon1" />
|
|
|
<div class="event-data-item-title">事件类型:</div>
|
|
|
</div>
|
|
|
<div class="event-data-item-value">
|
|
|
- <dict-tag :options="mm_event_type" :value="eventInfo.event_type"></dict-tag>
|
|
|
+ <dict-tag
|
|
|
+ :options="mm_event_type"
|
|
|
+ :value="eventInfo.event_type"
|
|
|
+ />
|
|
|
</div>
|
|
|
</div>
|
|
|
<div class="event-data-item">
|
|
|
<div class="item-left">
|
|
|
- <i class="icon2"/>
|
|
|
+ <i class="icon2" />
|
|
|
<div class="event-data-item-title">事件等级:</div>
|
|
|
</div>
|
|
|
<div class="event-data-item-value">
|
|
|
- <dict-tag :options="mm_event_level" :value="eventInfo.event_level||'0'"></dict-tag>
|
|
|
+ <dict-tag
|
|
|
+ :options="mm_event_level"
|
|
|
+ :value="eventInfo.event_level || '0'"
|
|
|
+ />
|
|
|
</div>
|
|
|
</div>
|
|
|
<div class="event-data-item">
|
|
|
<div class="item-left">
|
|
|
- <i class="icon3"/>
|
|
|
+ <i class="icon3" />
|
|
|
<div class="event-data-item-title">事件状态:</div>
|
|
|
</div>
|
|
|
<div class="event-data-item-value">
|
|
|
- <dict-tag :options="mm_event_state" :value="eventInfo.event_status"></dict-tag>
|
|
|
+ <dict-tag
|
|
|
+ :options="mm_event_state"
|
|
|
+ :value="eventInfo.event_status"
|
|
|
+ />
|
|
|
</div>
|
|
|
</div>
|
|
|
<div class="event-data-item">
|
|
|
<div class="item-left">
|
|
|
- <i class="icon5"/>
|
|
|
+ <i class="icon5" />
|
|
|
<div class="event-data-item-title">事发地点:</div>
|
|
|
</div>
|
|
|
<div class="event-data-item-value">{{ eventInfo.address }}</div>
|
|
|
</div>
|
|
|
<div class="event-data-item">
|
|
|
<div class="item-left">
|
|
|
- <i class="icon4"/>
|
|
|
+ <i class="icon4" />
|
|
|
<div class="event-data-item-title">事发时间:</div>
|
|
|
</div>
|
|
|
- <div class="event-data-item-value">{{ eventInfo.event_time }}</div>
|
|
|
+ <div class="event-data-item-value">
|
|
|
+ {{ eventInfo.event_time }}
|
|
|
+ </div>
|
|
|
</div>
|
|
|
<div class="event-data-item">
|
|
|
<div class="item-left">
|
|
|
- <i class="icon4"/>
|
|
|
+ <i class="icon4" />
|
|
|
<div class="event-data-item-title">上报时间:</div>
|
|
|
</div>
|
|
|
- <div class="event-data-item-value">{{ eventInfo.report_time }}</div>
|
|
|
+ <div class="event-data-item-value">
|
|
|
+ {{ eventInfo.report_time }}
|
|
|
+ </div>
|
|
|
</div>
|
|
|
<div class="event-data-item">
|
|
|
<div class="item-left">
|
|
|
- <i class="icon7"/>
|
|
|
+ <i class="icon7" />
|
|
|
<div class="event-data-item-title">伤亡情况:</div>
|
|
|
</div>
|
|
|
- <div class="event-data-item-value blue" @click="handleUploadCasualties">去上报</div>
|
|
|
+ <div
|
|
|
+ class="event-data-item-value blue"
|
|
|
+ @click="handleUploadCasualties"
|
|
|
+ >
|
|
|
+ 去上报
|
|
|
+ </div>
|
|
|
</div>
|
|
|
<div class="event-data-item">
|
|
|
<div class="item-left">
|
|
|
- <i class="icon8"/>
|
|
|
+ <i class="icon8" />
|
|
|
<div class="event-data-item-title">登记人:</div>
|
|
|
</div>
|
|
|
- <div class="event-data-item-value">{{ eventInfo.reported_by }}</div>
|
|
|
+ <div class="event-data-item-value">
|
|
|
+ {{ eventInfo.reported_by }}
|
|
|
+ </div>
|
|
|
</div>
|
|
|
<div class="event-data-item">
|
|
|
<div class="item-left">
|
|
|
- <i class="icon4"/>
|
|
|
+ <i class="icon4" />
|
|
|
<div class="event-data-item-title">登记时间:</div>
|
|
|
</div>
|
|
|
- <div class="event-data-item-value">{{ eventInfo.reported_time }}</div>
|
|
|
+ <div class="event-data-item-value">
|
|
|
+ {{ eventInfo.reported_time }}
|
|
|
+ </div>
|
|
|
</div>
|
|
|
<div class="event-data-item">
|
|
|
<div class="item-left">
|
|
|
- <i class="icon9"/>
|
|
|
+ <i class="icon9" />
|
|
|
<div class="event-data-item-title">联系方式:</div>
|
|
|
</div>
|
|
|
<div class="event-data-item-value">{{ eventInfo.contact }}</div>
|
|
|
</div>
|
|
|
<div class="event-data-item">
|
|
|
<div class="item-left">
|
|
|
- <i class="icon10"/>
|
|
|
+ <i class="icon10" />
|
|
|
<div class="event-data-item-title">事件来源:</div>
|
|
|
</div>
|
|
|
- <div class="event-data-item-value">{{ eventInfo.event_source }}</div>
|
|
|
+ <div class="event-data-item-value">
|
|
|
+ {{ eventInfo.event_source }}
|
|
|
+ </div>
|
|
|
</div>
|
|
|
</div>
|
|
|
</van-tab>
|
|
@@ -115,7 +144,10 @@
|
|
|
<van-tab title="事件跟踪">
|
|
|
<div class="event_tab">
|
|
|
<van-steps direction="vertical" :active="0">
|
|
|
- <van-step v-for="(item,index) in eventTrackState.items" :key="item.id">
|
|
|
+ <van-step
|
|
|
+ v-for="(item, index) in eventTrackState.items"
|
|
|
+ :key="item.id"
|
|
|
+ >
|
|
|
<h3>{{ item.title }}</h3>
|
|
|
<p>{{ item.description }}</p>
|
|
|
</van-step>
|
|
@@ -124,39 +156,70 @@
|
|
|
</van-tab>
|
|
|
<van-tab title="匹配预案">
|
|
|
<div class="event_tab2">
|
|
|
- <template v-if="!!eventInfo.plan_id && !!eventInfo.plan_files && eventInfo.plan_files.length > 0">
|
|
|
+ <template
|
|
|
+ v-if="
|
|
|
+ !!eventInfo.plan_id &&
|
|
|
+ !!eventInfo.plan_files &&
|
|
|
+ eventInfo.plan_files.length > 0
|
|
|
+ "
|
|
|
+ >
|
|
|
<div class="plan-content">
|
|
|
<div class="content-header">
|
|
|
- <div class="plan-content-title">{{ eventInfo.plan_files[0]?.name }}</div>
|
|
|
- <i class="download-icon" @click="handleDownload(eventInfo.plan_files[0])"/>
|
|
|
+ <div class="plan-content-title">
|
|
|
+ {{ eventInfo.plan_files[0]?.name }}
|
|
|
+ </div>
|
|
|
+ <i
|
|
|
+ class="download-icon"
|
|
|
+ @click="handleDownload(eventInfo.plan_files[0])"
|
|
|
+ />
|
|
|
</div>
|
|
|
<div class="content-text">
|
|
|
<div v-for="(item, index) in planFiles" :key="index">
|
|
|
<div>{{ item.title }}</div>
|
|
|
<div v-for="(item2, index2) in item.items" :key="index2">
|
|
|
<div>{{ item2.title }}</div>
|
|
|
- <div v-html="item2.value"></div>
|
|
|
+ <div v-html="item2.value" />
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
</template>
|
|
|
<template v-else>
|
|
|
- <div class="emptyIcon"/>
|
|
|
+ <div class="emptyIcon" />
|
|
|
<div class="emptyText">未关联到对应预案</div>
|
|
|
- <van-button type="primary" size="small" @click="associationShow = true">手工关联</van-button>
|
|
|
+ <van-button
|
|
|
+ type="primary"
|
|
|
+ size="small"
|
|
|
+ @click="associationShow = true"
|
|
|
+ >手工关联</van-button
|
|
|
+ >
|
|
|
</template>
|
|
|
</div>
|
|
|
</van-tab>
|
|
|
<van-tab title="总结报告">
|
|
|
<div class="event_tab2">
|
|
|
- <div v-if="eventInfo.summary_file && eventInfo.summary_file.length > 0" class="file-list">
|
|
|
- <div v-for="(item, index) in eventInfo.summary_file" :key="index" class="item" @click="handleDownload2(item)">{{item.file_name}}</div>
|
|
|
+ <div
|
|
|
+ v-if="eventInfo.summary_file && eventInfo.summary_file.length > 0"
|
|
|
+ class="file-list"
|
|
|
+ >
|
|
|
+ <div
|
|
|
+ v-for="(item, index) in eventInfo.summary_file"
|
|
|
+ :key="index"
|
|
|
+ class="item"
|
|
|
+ @click="handleDownload2(item)"
|
|
|
+ >
|
|
|
+ {{ item.file_name }}
|
|
|
+ </div>
|
|
|
</div>
|
|
|
<template v-else>
|
|
|
- <div class="emptyIcon2"/>
|
|
|
+ <div class="emptyIcon2" />
|
|
|
<div class="emptyText">暂未上传总结报告</div>
|
|
|
- <van-button type="primary" size="small" @click="handleUploadCasualties">去上传</van-button>
|
|
|
+ <van-button
|
|
|
+ type="primary"
|
|
|
+ size="small"
|
|
|
+ @click="handleUploadCasualties"
|
|
|
+ >去上传</van-button
|
|
|
+ >
|
|
|
</template>
|
|
|
</div>
|
|
|
</van-tab>
|
|
@@ -164,93 +227,119 @@
|
|
|
</div>
|
|
|
|
|
|
<div class="footer">
|
|
|
- <div style="display: flex; flex-direction: row; justify-content: space-between;">
|
|
|
- <van-button v-if="eventInfo.event_status == '0'" type="primary" @click="handleStartEvent">开始指挥</van-button>
|
|
|
- <van-button v-if="eventInfo.event_status == '1'" type="primary" @click="handleEnterEvent">进入指挥</van-button>
|
|
|
- <van-button v-if="eventInfo.event_status == '0' || eventInfo.event_status == '2'" type="danger"
|
|
|
- @click="handleCloseEvent">关闭事件
|
|
|
+ <div
|
|
|
+ style="
|
|
|
+ display: flex;
|
|
|
+ flex-direction: row;
|
|
|
+ justify-content: space-between;
|
|
|
+ "
|
|
|
+ >
|
|
|
+ <van-button
|
|
|
+ v-if="eventInfo.event_status == '0'"
|
|
|
+ type="primary"
|
|
|
+ @click="handleStartEvent"
|
|
|
+ >开始指挥</van-button
|
|
|
+ >
|
|
|
+ <van-button
|
|
|
+ v-if="eventInfo.event_status == '1'"
|
|
|
+ type="primary"
|
|
|
+ @click="handleEnterEvent"
|
|
|
+ >进入指挥</van-button
|
|
|
+ >
|
|
|
+ <van-button
|
|
|
+ v-if="eventInfo.event_status == '0' || eventInfo.event_status == '2'"
|
|
|
+ type="danger"
|
|
|
+ @click="handleCloseEvent"
|
|
|
+ >关闭事件
|
|
|
</van-button>
|
|
|
</div>
|
|
|
</div>
|
|
|
- <AssociationPlan v-model="associationShow" :eventId="eventId" @confirm="associationPlanConfirm" />
|
|
|
+ <AssociationPlan
|
|
|
+ v-model="associationShow"
|
|
|
+ :eventId="eventId"
|
|
|
+ @confirm="associationPlanConfirm"
|
|
|
+ />
|
|
|
<UploadEventCasualtiesDialog
|
|
|
- v-model="uploadCasualtiesState.show"
|
|
|
- :data="uploadCasualtiesState.form"
|
|
|
- @update:model-value="onUploadCasualtiesDialogClose"
|
|
|
- @confirm="onUploadCasualtiesDialogClose"
|
|
|
+ v-model="uploadCasualtiesState.show"
|
|
|
+ :data="uploadCasualtiesState.form"
|
|
|
+ @update:model-value="onUploadCasualtiesDialogClose"
|
|
|
+ @confirm="onUploadCasualtiesDialogClose"
|
|
|
+ />
|
|
|
+ <StartEventDialog
|
|
|
+ v-model="startEventState.show"
|
|
|
+ :data="startEventState.form"
|
|
|
+ @update:model-value="onStartEventDialogClose"
|
|
|
/>
|
|
|
- <StartEventDialog v-model="startEventState.show" :data="startEventState.form"
|
|
|
- @update:model-value="onStartEventDialogClose"></StartEventDialog>
|
|
|
</div>
|
|
|
</template>
|
|
|
|
|
|
<script lang="ts" setup>
|
|
|
-import {getCurrentInstance, reactive, ref, toRefs, onMounted} from 'vue';
|
|
|
-import {useRouter, useRoute} from 'vue-router'
|
|
|
-import {getEventDetail, closeEvent} from "@/api/event";
|
|
|
+import { getCurrentInstance, reactive, ref, toRefs, onMounted } from "vue";
|
|
|
+import { useRouter, useRoute } from "vue-router";
|
|
|
+import { getEventDetail, closeEvent } from "@/api/event";
|
|
|
import UploadEventCasualtiesDialog from "./UploadEventCasualtiesDialog.vue";
|
|
|
-import {showDialog, showConfirmDialog} from 'vant';
|
|
|
-import {useAMap} from "@/hooks/AMap/useAMap";
|
|
|
+import { showDialog, showConfirmDialog } from "vant";
|
|
|
+import { useAMap } from "@/hooks/AMap/useAMap";
|
|
|
import StartEventDialog from "@/views/event/StartEventDialog.vue";
|
|
|
-import {download2} from "@/utils/request";
|
|
|
-import {getPlanDoc, listPlan} from "@/api/duty/eventing";
|
|
|
+import { download2 } from "@/utils/request";
|
|
|
+import { getPlanDoc, listPlan } from "@/api/duty/eventing";
|
|
|
import AssociationPlan from "@/views/event/AssociationPlan.vue";
|
|
|
|
|
|
-const router = useRouter()
|
|
|
-const route = useRoute()
|
|
|
+const router = useRouter();
|
|
|
+const route = useRoute();
|
|
|
const proxy = getCurrentInstance()?.proxy;
|
|
|
-const {
|
|
|
- mm_event_type,
|
|
|
- mm_event_level,
|
|
|
- mm_event_state
|
|
|
-} = toRefs<any>(proxy?.useDict('mm_event_type', 'mm_event_level', 'mm_event_state'));
|
|
|
+const { mm_event_type, mm_event_level, mm_event_state } = toRefs<any>(
|
|
|
+ proxy?.useDict("mm_event_type", "mm_event_level", "mm_event_state")
|
|
|
+);
|
|
|
|
|
|
const active = ref(0);
|
|
|
-const eventId = ref('');
|
|
|
+const eventId = ref("");
|
|
|
const data = reactive({
|
|
|
eventInfo: {
|
|
|
- event_id: '',
|
|
|
- event_title: '',
|
|
|
- event_code: '',
|
|
|
- event_type: '',
|
|
|
- event_level: '',
|
|
|
- event_status: '',
|
|
|
- address: '',
|
|
|
- event_time: '',
|
|
|
- report_time: '',
|
|
|
- contact: '',
|
|
|
- event_source: '',
|
|
|
- event_description: '',
|
|
|
- reported_by: '',
|
|
|
- reported_time: '',
|
|
|
- longitude: '',
|
|
|
- latitude: '',
|
|
|
- plan_id: '',
|
|
|
- plan_name: '',
|
|
|
+ event_id: "",
|
|
|
+ event_title: "",
|
|
|
+ event_code: "",
|
|
|
+ event_type: "",
|
|
|
+ event_level: "",
|
|
|
+ event_status: "",
|
|
|
+ address: "",
|
|
|
+ event_time: "",
|
|
|
+ report_time: "",
|
|
|
+ contact: "",
|
|
|
+ event_source: "",
|
|
|
+ event_description: "",
|
|
|
+ reported_by: "",
|
|
|
+ reported_time: "",
|
|
|
+ longitude: "",
|
|
|
+ latitude: "",
|
|
|
+ plan_id: "",
|
|
|
+ plan_name: "",
|
|
|
summary_file: [],
|
|
|
plan_files: [],
|
|
|
// 伤亡情况
|
|
|
- deaths: '',
|
|
|
- injuries: '',
|
|
|
- missing: '',
|
|
|
+ deaths: "",
|
|
|
+ injuries: "",
|
|
|
+ missing: ""
|
|
|
},
|
|
|
eventTrackState: {
|
|
|
active: 0,
|
|
|
- items: [{
|
|
|
- id: 0,
|
|
|
- title: '事件登记',
|
|
|
- description: ''
|
|
|
- }]
|
|
|
+ items: [
|
|
|
+ {
|
|
|
+ id: 0,
|
|
|
+ title: "事件登记",
|
|
|
+ description: ""
|
|
|
+ }
|
|
|
+ ]
|
|
|
}
|
|
|
});
|
|
|
-const {eventInfo, eventTrackState} = toRefs(data);
|
|
|
+const { eventInfo, eventTrackState } = toRefs(data);
|
|
|
const startEventState = reactive({
|
|
|
show: false,
|
|
|
form: {
|
|
|
- event_id: '',
|
|
|
- event_title: '',
|
|
|
- event_level: '',
|
|
|
- event_level_text: '',
|
|
|
+ event_id: "",
|
|
|
+ event_title: "",
|
|
|
+ event_level: "",
|
|
|
+ event_level_text: ""
|
|
|
}
|
|
|
});
|
|
|
const handleStartEvent = () => {
|
|
@@ -259,10 +348,10 @@ const handleStartEvent = () => {
|
|
|
startEventState.form.event_level = eventInfo.value.event_level;
|
|
|
startEventState.show = true;
|
|
|
return false;
|
|
|
-}
|
|
|
+};
|
|
|
const handleEnterEvent = () => {
|
|
|
router.push({
|
|
|
- path: '/leader/mobile_control',
|
|
|
+ path: "/leader/mobile_control",
|
|
|
query: {
|
|
|
event_id: eventId.value
|
|
|
}
|
|
@@ -271,22 +360,22 @@ const handleEnterEvent = () => {
|
|
|
|
|
|
// 关闭事件
|
|
|
const handleCloseEvent = () => {
|
|
|
- if (eventInfo.value.plan_id === '') {
|
|
|
- showDialog({message: '关闭事件前请先匹配预案'});
|
|
|
+ if (eventInfo.value.plan_id === "") {
|
|
|
+ showDialog({ message: "关闭事件前请先匹配预案" });
|
|
|
return false;
|
|
|
}
|
|
|
if (eventInfo.value.summary_file.length === 0) {
|
|
|
- showDialog({message: '关闭事件前请先上传总结报告'});
|
|
|
+ showDialog({ message: "关闭事件前请先上传总结报告" });
|
|
|
return false;
|
|
|
}
|
|
|
showConfirmDialog({
|
|
|
- title: '提示',
|
|
|
- message: '关闭事件所有事项相关数据将不能再修改,是否继续?'
|
|
|
+ title: "提示",
|
|
|
+ message: "关闭事件所有事项相关数据将不能再修改,是否继续?"
|
|
|
}).then(() => {
|
|
|
- closeEvent({eventId: eventId.value}).then((res) => {
|
|
|
- refreshData()
|
|
|
- })
|
|
|
- })
|
|
|
+ closeEvent({ eventId: eventId.value }).then(res => {
|
|
|
+ refreshData();
|
|
|
+ });
|
|
|
+ });
|
|
|
};
|
|
|
|
|
|
let associationShow = ref(false);
|
|
@@ -295,16 +384,15 @@ let associationShow = ref(false);
|
|
|
const uploadCasualtiesState = reactive({
|
|
|
show: false,
|
|
|
form: {
|
|
|
- event_id: '',
|
|
|
- deaths: '',
|
|
|
- injuries: '',
|
|
|
- missing: ''
|
|
|
+ event_id: "",
|
|
|
+ deaths: "",
|
|
|
+ injuries: "",
|
|
|
+ missing: ""
|
|
|
}
|
|
|
-})
|
|
|
-
|
|
|
+});
|
|
|
|
|
|
const handleUploadCasualties = () => {
|
|
|
- console.log('handleUploadCasualties');
|
|
|
+ console.log("handleUploadCasualties");
|
|
|
uploadCasualtiesState.form.event_id = eventId.value;
|
|
|
uploadCasualtiesState.form.deaths = eventInfo.value.deaths;
|
|
|
uploadCasualtiesState.form.injuries = eventInfo.value.injuries;
|
|
@@ -312,88 +400,88 @@ const handleUploadCasualties = () => {
|
|
|
uploadCasualtiesState.show = true;
|
|
|
};
|
|
|
|
|
|
-const onUploadCasualtiesDialogClose = (t) => {
|
|
|
- console.log('onUploadCasualtiesDialogClose', t)
|
|
|
+const onUploadCasualtiesDialogClose = t => {
|
|
|
+ console.log("onUploadCasualtiesDialogClose", t);
|
|
|
uploadCasualtiesState.show = false;
|
|
|
if (t) {
|
|
|
refreshData();
|
|
|
}
|
|
|
-}
|
|
|
+};
|
|
|
|
|
|
-const onStartEventDialogClose = (t) => {
|
|
|
+const onStartEventDialogClose = t => {
|
|
|
startEventState.show = false;
|
|
|
console.log(startEventState.form);
|
|
|
if (t) {
|
|
|
- getEventDetail({event_id: eventId.value}).then((res) => {
|
|
|
- eventInfo.value = res.data
|
|
|
+ getEventDetail({ event_id: eventId.value }).then(res => {
|
|
|
+ eventInfo.value = res.data;
|
|
|
eventTrackState.value = res.data.event_status_tracks;
|
|
|
- })
|
|
|
+ });
|
|
|
}
|
|
|
};
|
|
|
let planFiles = ref([]);
|
|
|
const getPlan = () => {
|
|
|
- getPlanDoc({plan_id: eventInfo.value.plan_id}).then((res)=> {
|
|
|
+ getPlanDoc({ plan_id: eventInfo.value.plan_id }).then(res => {
|
|
|
planFiles.value = res.data;
|
|
|
});
|
|
|
-}
|
|
|
-const associationPlanConfirm = (plan_id) => {
|
|
|
+};
|
|
|
+const associationPlanConfirm = plan_id => {
|
|
|
associationShow.value = false;
|
|
|
eventInfo.value.plan_id = plan_id;
|
|
|
getPlan();
|
|
|
-}
|
|
|
+};
|
|
|
const baseUrl = import.meta.env.VITE_BASE_API;
|
|
|
// 下载方法
|
|
|
const handleDownload = (file: any) => {
|
|
|
- download2(baseUrl + '/file/download/' + file.url, file.name);
|
|
|
+ download2(baseUrl + "/file/download/" + file.url, file.name);
|
|
|
};
|
|
|
const handleDownload2 = (file: any) => {
|
|
|
- download2(baseUrl + '/file/download/' + file.url, file.file_name);
|
|
|
+ download2(baseUrl + "/file/download/" + file.url, file.file_name);
|
|
|
};
|
|
|
onMounted(() => {
|
|
|
refreshData();
|
|
|
-
|
|
|
-})
|
|
|
+});
|
|
|
let hideMap = ref(false);
|
|
|
let map;
|
|
|
const refreshData = () => {
|
|
|
eventId.value = route.query.event_id as string;
|
|
|
- getEventDetail({event_id: eventId.value}).then((res) => {
|
|
|
- eventInfo.value = res.data
|
|
|
+ getEventDetail({ event_id: eventId.value }).then(res => {
|
|
|
+ eventInfo.value = res.data;
|
|
|
eventTrackState.value = res.data.event_status_tracks;
|
|
|
if (!!eventInfo.value.plan_id) {
|
|
|
getPlan(eventInfo.value.plan_id);
|
|
|
}
|
|
|
if (!eventInfo.value.longitude || !eventInfo.value.latitude) {
|
|
|
- hideMap.vlaue = true
|
|
|
+ hideMap.value.vlaue = true;
|
|
|
} else {
|
|
|
// 初始化地图
|
|
|
const lnglat = [eventInfo.value.longitude, eventInfo.value.latitude];
|
|
|
- const {getMap} = useAMap({
|
|
|
- key: '30d3d8448efd68cb0b284549fd41adcf',
|
|
|
- version: '2.0',
|
|
|
+ const { getMap } = useAMap({
|
|
|
+ key: "30d3d8448efd68cb0b284549fd41adcf",
|
|
|
+ version: "2.0",
|
|
|
zoom: 16,
|
|
|
center: lnglat,
|
|
|
dragEnable: true,
|
|
|
scrollWheel: true,
|
|
|
// 加载完成事件
|
|
|
- onLoadCompleted: (AMap) => {
|
|
|
+ onLoadCompleted: AMap => {
|
|
|
map = getMap();
|
|
|
let marker = new AMap.Marker({
|
|
|
position: lnglat,
|
|
|
icon: new AMap.Icon({
|
|
|
- size: new AMap.Size(22, 28), //图标所处区域大小
|
|
|
+ size: new AMap.Size(22, 28), //图标所处区域大小
|
|
|
imageSize: new AMap.Size(22, 28), //图标大小
|
|
|
- image: "//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png",
|
|
|
+ image:
|
|
|
+ "//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png"
|
|
|
}),
|
|
|
- anchor: 'bottom-center',
|
|
|
+ anchor: "bottom-center",
|
|
|
offset: new AMap.Pixel(0, 0)
|
|
|
});
|
|
|
marker.setMap(map);
|
|
|
}
|
|
|
});
|
|
|
}
|
|
|
- })
|
|
|
-}
|
|
|
+ });
|
|
|
+};
|
|
|
</script>
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
@@ -412,7 +500,7 @@ const refreshData = () => {
|
|
|
.event_title {
|
|
|
font-weight: 600;
|
|
|
min-height: 46px;
|
|
|
- background-image: linear-gradient(180deg, #F3F7FD 0%, #FFFFFF 100%);
|
|
|
+ background-image: linear-gradient(180deg, #f3f7fd 0%, #ffffff 100%);
|
|
|
padding: 12px;
|
|
|
}
|
|
|
|
|
@@ -427,35 +515,35 @@ const refreshData = () => {
|
|
|
|
|
|
.event_type {
|
|
|
padding: 3px 10px;
|
|
|
- border: 0.8px solid #2C81FF;
|
|
|
+ border: 0.8px solid #2c81ff;
|
|
|
border-radius: 2px;
|
|
|
- color: #2C81FF;
|
|
|
+ color: #2c81ff;
|
|
|
margin-right: 7px;
|
|
|
}
|
|
|
|
|
|
.event_level {
|
|
|
padding: 3px 10px;
|
|
|
- border: 0.8px solid #2C81FF;
|
|
|
+ border: 0.8px solid #2c81ff;
|
|
|
border-radius: 2px;
|
|
|
margin-right: 7px;
|
|
|
- color: #2C81FF;
|
|
|
+ color: #2c81ff;
|
|
|
}
|
|
|
|
|
|
.event_status {
|
|
|
padding: 3px 10px;
|
|
|
- border: 0.8px solid #2C81FF;
|
|
|
+ border: 0.8px solid #2c81ff;
|
|
|
border-radius: 2px;
|
|
|
- color: #2C81FF;
|
|
|
+ color: #2c81ff;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
.event_tab {
|
|
|
padding: 16px;
|
|
|
- color: #A6000000;
|
|
|
+ color: #a6000000;
|
|
|
|
|
|
.event-data-item {
|
|
|
font-size: 14px;
|
|
|
- line-height: 8.0vmin;
|
|
|
+ line-height: 8vmin;
|
|
|
display: flex;
|
|
|
flex-direction: row;
|
|
|
align-items: flex-start;
|
|
@@ -470,7 +558,7 @@ const refreshData = () => {
|
|
|
.icon1 {
|
|
|
width: 17px;
|
|
|
height: 16px;
|
|
|
- background: url('@/assets/images/event/icon1.png') no-repeat;
|
|
|
+ background: url("@/assets/images/event/icon1.png") no-repeat;
|
|
|
background-size: 100% 100%;
|
|
|
margin-right: 7px;
|
|
|
}
|
|
@@ -478,7 +566,7 @@ const refreshData = () => {
|
|
|
.icon2 {
|
|
|
width: 17px;
|
|
|
height: 16px;
|
|
|
- background: url('@/assets/images/event/icon2.png') no-repeat;
|
|
|
+ background: url("@/assets/images/event/icon2.png") no-repeat;
|
|
|
background-size: 100% 100%;
|
|
|
margin-right: 7px;
|
|
|
}
|
|
@@ -486,7 +574,7 @@ const refreshData = () => {
|
|
|
.icon3 {
|
|
|
width: 17px;
|
|
|
height: 16px;
|
|
|
- background: url('@/assets/images/event/icon3.png') no-repeat;
|
|
|
+ background: url("@/assets/images/event/icon3.png") no-repeat;
|
|
|
background-size: 100% 100%;
|
|
|
margin-right: 7px;
|
|
|
}
|
|
@@ -494,7 +582,7 @@ const refreshData = () => {
|
|
|
.icon4 {
|
|
|
width: 17px;
|
|
|
height: 16px;
|
|
|
- background: url('@/assets/images/event/icon4.png') no-repeat;
|
|
|
+ background: url("@/assets/images/event/icon4.png") no-repeat;
|
|
|
background-size: 100% 100%;
|
|
|
margin-right: 7px;
|
|
|
}
|
|
@@ -502,7 +590,7 @@ const refreshData = () => {
|
|
|
.icon5 {
|
|
|
width: 16px;
|
|
|
height: 16px;
|
|
|
- background: url('@/assets/images/event/icon5.png') no-repeat;
|
|
|
+ background: url("@/assets/images/event/icon5.png") no-repeat;
|
|
|
background-size: 100% 100%;
|
|
|
margin-right: 7px;
|
|
|
}
|
|
@@ -564,7 +652,7 @@ const refreshData = () => {
|
|
|
|
|
|
h3 {
|
|
|
font-size: 4.2vmin;
|
|
|
- line-height: 8.0vmin;
|
|
|
+ line-height: 8vmin;
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -598,14 +686,14 @@ const refreshData = () => {
|
|
|
.emptyIcon {
|
|
|
width: 110px;
|
|
|
height: 108px;
|
|
|
- background: url('@/assets/images/unrelatedPlan.png') no-repeat;
|
|
|
+ background: url("@/assets/images/unrelatedPlan.png") no-repeat;
|
|
|
background-size: 100% 100%;
|
|
|
}
|
|
|
|
|
|
.emptyIcon2 {
|
|
|
width: 111px;
|
|
|
height: 110px;
|
|
|
- background: url('@/assets/images/noReport.png') no-repeat;
|
|
|
+ background: url("@/assets/images/noReport.png") no-repeat;
|
|
|
background-size: 100% 100%;
|
|
|
}
|
|
|
|
|
@@ -621,7 +709,7 @@ const refreshData = () => {
|
|
|
justify-content: center;
|
|
|
align-items: center;
|
|
|
font-size: 14px;
|
|
|
- color: #2C81FF;
|
|
|
+ color: #2c81ff;
|
|
|
font-weight: bold;
|
|
|
padding: 5px 0;
|
|
|
.plan-content-title {
|
|
@@ -632,7 +720,7 @@ const refreshData = () => {
|
|
|
display: inline-block;
|
|
|
width: 15px;
|
|
|
height: 14px;
|
|
|
- background: url('@/assets/images/download.png') no-repeat;
|
|
|
+ background: url("@/assets/images/download.png") no-repeat;
|
|
|
background-size: 100% 100%;
|
|
|
margin-left: 20px;
|
|
|
}
|
|
@@ -646,7 +734,7 @@ const refreshData = () => {
|
|
|
}
|
|
|
}
|
|
|
:deep(.van-tabs__wrap) {
|
|
|
- border-bottom: 1px solid #F6F6F6;
|
|
|
+ border-bottom: 1px solid #f6f6f6;
|
|
|
}
|
|
|
.file-list {
|
|
|
width: 100%;
|