From 9e765ee8e2852409a1a98a6fb548b2d9d4111713 Mon Sep 17 00:00:00 2001
From: husq <931347610@qq.com>
Date: Thu, 19 Oct 2023 17:25:34 +0800
Subject: [PATCH] 添加航线任务待提醒
---
src/components/GMap.vue | 82 ++++++++++++++++++++++++++++++-----------
1 files changed, 60 insertions(+), 22 deletions(-)
diff --git a/src/components/GMap.vue b/src/components/GMap.vue
index 813c026..595dc27 100644
--- a/src/components/GMap.vue
+++ b/src/components/GMap.vue
@@ -113,13 +113,15 @@
<a-col span="6">
<a-tooltip title="海拔高度">
<span>ASL</span>
- <span class="ml5">{{ deviceInfo.device.height === str ? str : deviceInfo.device.height.toFixed(2) + 'm'}}</span>
+ <span class="ml5">{{ deviceInfo.device.height === str ? str : deviceInfo.device.height.toFixed(2) +
+ 'm' }}</span>
</a-tooltip>
</a-col>
<a-col span="6">
<a-tooltip title="高于起飞高度">
<span>ALT</span>
- <span class="ml5">{{ deviceInfo.device.elevation === str ? str : deviceInfo.device.elevation.toFixed(2) + 'm' }}</span>
+ <span class="ml5">{{ deviceInfo.device.elevation === str ? str : deviceInfo.device.elevation.toFixed(2) +
+ 'm' }}</span>
</a-tooltip>
</a-col>
<a-col span="6">
@@ -148,8 +150,7 @@
<a-col span="6">
<a-tooltip title="风速">
<span>W.S</span>
- <span class="ml5">{{ deviceInfo.device.wind_speed === str ? str : (deviceInfo.device.wind_speed /
- 10).toFixed(2) + ' m/s' }}</span>
+ <span class="ml5">{{ deviceInfo.device.wind_speed === str ? str : (deviceInfo.device.wind_speed / 10).toFixed(2) + ' m/s' }}</span>
</a-tooltip>
</a-col>
</a-row>
@@ -171,17 +172,33 @@
<!-- 机场OSD -->
<!-- && osdVisible.is_dock -->
<div class="osd-panel fz12" v-if="osdVisible.visible">
- <div class="fz16 pl5 pr5 flex-align-center flex-row flex-justify-between"
+ <div class="fz16 pr5 flex-align-center flex-row flex-justify-between"
style="border-bottom: 1px solid #515151; height: 10%;">
- <span>{{ osdVisible.gateway_callsign }}</span>
- <span><a style="color: white;" @click="closeOsdWindow">
+ <div class="flex-align-center flex-justify-center" style="display: flex;">
+ <div v-if="osdVisible.latest_wayline_job" class="flex-column flex-align-center flex-justify-center">
+ <div class="task_wrapper">
+ <div class="task_content">
+ <div class="task_status">
+ <ContainerOutlined />
+ <span>待执行</span>
+ </div>
+ <div class="task_info">{{convertTimestampToDate(osdVisible.latest_wayline_job.begin_time)}}</div>
+ </div>
+ <div class="task_title">{{osdVisible.latest_wayline_job.name}}</div>
+ </div>
+ </div>
+ <span :style="[osdVisible.latest_wayline_job?'margin-left:20px':'']">{{ osdVisible.gateway_callsign }}</span>
+ </div>
+ <div>
+ <a style="color: white;" @click="closeOsdWindow">
<CloseOutlined />
- </a></span>
+ </a>
+ </div>
</div>
<!-- 机场 -->
<div class="flex-display" style="border-bottom: 1px solid #515151;">
<div class="flex-column flex-align-stretch flex-justify-center" style="width: 60px; background: #2d2d2d;">
- <a-tooltip :title="osdVisible.model">
+ <a-tooltip :title="osdVisible.gateway_callsign">
<div class="flex-column flex-align-center flex-justify-center" style="width: 90%;">
<span>
<RobotFilled style="font-size: 48px;" />
@@ -301,7 +318,7 @@
<a-col span="2"></a-col>
<a-col span="8">
<a-button :class="[airPortOption ? 'active-color' : 'unactive-color']" class="width-100" type="primary"
- size="small" @click="openFlySetting">
+ size="small" @click="openFlySetting">
操作
</a-button>
</a-col>
@@ -436,19 +453,22 @@
<a-tooltip :title="osdVisible.model">
<div style="width: 90%;" class="flex-column flex-align-center flex-justify-center">
<span><a-image :src="M30" :preview="false" /></span>
- <span>{{ DEVICE_NAME[`${osdVisible.device_domain}-${osdVisible.device_type}-${osdVisible.device_sub_type}`] }}</span>
+ <span>{{ DEVICE_NAME[`${osdVisible.device_domain}-${osdVisible.device_type}-${osdVisible.device_sub_type}`]
+ }}</span>
</div>
</a-tooltip>
</div>
<div class="osd flex-1">
<a-row class="mr-20" align="middle">
<a-col span="9"
- :style="deviceInfo.device && deviceInfo.device?.mode_code !== EModeCode.Disconnected ? 'color: rgb(25,190,107)' : deviceInfo.dock.basic_osd?.drone_in_dock === 1? 'color: rgb(25,190,107)' : 'color: red; font-weight: 700;' ">
+ :style="deviceInfo.device && deviceInfo.device?.mode_code !== EModeCode.Disconnected ? 'color: rgb(25,190,107)' : deviceInfo.dock.basic_osd?.drone_in_dock === 1 ? 'color: rgb(25,190,107)' : 'color: red; font-weight: 700;'">
<!-- DroneInDockEnum[deviceInfo.dock.basic_osd?.drone_in_dock] -->
- {{ deviceInfo.device ? EModeText[deviceInfo.device?.mode_code] : (deviceInfo.dock.basic_osd?.drone_in_dock === 1) ? '舱内关机' : EModeText[EModeCode.Disconnected]
+ {{ deviceInfo.device ? EModeText[deviceInfo.device?.mode_code] : (deviceInfo.dock.basic_osd?.drone_in_dock
+ === 1) ? '舱内关机' : EModeText[EModeCode.Disconnected]
}}</a-col>
<a-col span="15">
- <div style="width:100%;padding:0 5px;background-color: #5d5f61;color: #fff;font-size: 10px;">{{deviceInfo.device?.mode_code == 14 || !deviceInfo.device ? 'N/A' : '当前正常'}}</div>
+ <div style="width:100%;padding:0 5px;background-color: #5d5f61;color: #fff;font-size: 10px;">
+ {{ deviceInfo.device?.mode_code == 14 || !deviceInfo.device ? 'N/A' : '当前正常' }}</div>
</a-col>
</a-row>
<a-row align="middle" justify="center">
@@ -457,10 +477,11 @@
class="flex-display flex-justify-center mt5 mb5">当前设备已关机,无法进行直播</div>
</a-col>
</a-row>
- <a-row class="p5" v-if="deviceInfo.device?.mode_code != 14 && deviceInfo.device" align="middle" justify="space-between">
+ <a-row class="p5" v-if="deviceInfo.device?.mode_code != 14 && deviceInfo.device" align="middle"
+ justify="space-between">
<a-col span="11">
- <a-button :class="[aircrafIndex === 0 ? 'active-color' : 'unactive-color']" class="width-100" type="primary" size="small"
- @click="openAircra(0)">
+ <a-button :class="[aircrafIndex === 0 ? 'active-color' : 'unactive-color']" class="width-100" type="primary"
+ size="small" @click="openAircra(0)">
飞行相机
</a-button>
</a-col>
@@ -740,10 +761,10 @@
import pin from '/@/assets/icons/pin-2d8cf0.svg'
import M30 from '/@/assets/icons/m30.png'
import {
- BorderOutlined, LineOutlined, CloseOutlined, ControlOutlined, TrademarkOutlined, ArrowDownOutlined,
+ BorderOutlined, LineOutlined, ControlOutlined, TrademarkOutlined, ArrowDownOutlined,
ThunderboltOutlined, SignalFilled, GlobalOutlined, HistoryOutlined, CloudUploadOutlined, RocketOutlined,
FieldTimeOutlined, CloudOutlined, CloudFilled, FolderOpenOutlined, RobotFilled, ArrowUpOutlined, CarryOutOutlined,
- DesktopOutlined
+ DesktopOutlined, CloseOutlined
} from '@ant-design/icons-vue'
import { EDeviceTypeName } from '../types'
import DockControlPanel from './g-map/DockControlPanel.vue'
@@ -751,6 +772,7 @@
import DroneControlPanel from './g-map/DroneControlPanel.vue'
import { useConnectMqtt } from './g-map/use-connect-mqtt'
import Cesium from './cesiumMap/cesium.vue'
+import { convertTimestampToDate } from '/@/utils/time'
export default defineComponent({
components: {
BorderOutlined,
@@ -774,7 +796,7 @@
DroneControlPanel,
CarryOutOutlined,
RocketOutlined,
- DesktopOutlined
+ DesktopOutlined,
},
name: 'GMap',
props: {},
@@ -1431,7 +1453,8 @@
flyTimeout,
aircrafIndex,
airPortOption,
- controlStatus
+ controlStatus,
+ convertTimestampToDate
}
}
})
@@ -1475,6 +1498,7 @@
display: none;
}
}
+
&:deep(.ant-btn > .anticon + span, .ant-btn > span + .anticon, .ant-btn > .anticon + span, .ant-btn > span + .anticon) {
margin-left: 5px !important;
}
@@ -1568,4 +1592,18 @@
position: absolute;
min-height: 2px;
border-radius: 2px;
-}</style>
+}
+.task_wrapper {
+ display: flex;
+ align-items: center;
+ font-size: 12px;
+ .task_content {
+ background-color: #19be6b;
+ padding: 2px 4px;
+ }
+ .task_title {
+ margin-left: 5px;
+ font-size: 14px;
+ }
+}
+</style>
--
Gitblit v1.9.3