Commit 31e1fde616494ed7918530bae007514507904245
Merge branch 'perf/main_dev' of http://git.yunteng.com/yunteng/thingskit-scada into fix/zfl
Showing
3 changed files
with
16 additions
and
7 deletions
| ... | ... | @@ -9,6 +9,7 @@ import type { NodeDataDataSourceJsonType } from '@/api/node/model' |
| 9 | 9 | import { SocketSubscriberEnum } from '@/enums/datasource' |
| 10 | 10 | import type { SubscriptionData } from '@/core/websocket/type/message' |
| 11 | 11 | import { formatToDateTime } from '@/utils/dateUtil' |
| 12 | +import type { CommandSource } from '@/core/websocket/processor' | |
| 12 | 13 | |
| 13 | 14 | const props = defineProps<{ |
| 14 | 15 | config: CreateComponentType |
| ... | ... | @@ -25,18 +26,25 @@ function initChartInstance() { |
| 25 | 26 | chartInstance.value.setOption(defaultOption) |
| 26 | 27 | } |
| 27 | 28 | |
| 28 | -const handleHistoryData = (message: SubscriptionData, attr: string) => { | |
| 29 | - const data = message[attr] | |
| 29 | +const handleHistoryData = (commandSource: CommandSource, message: SubscriptionData) => { | |
| 30 | + const { data } = commandSource | |
| 31 | + const { attrInfo, deviceInfo, attr } = data as NodeDataDataSourceJsonType | |
| 32 | + const { deviceName } = deviceInfo || {} | |
| 33 | + | |
| 34 | + const historyData = message[attr] | |
| 30 | 35 | const xAxisData: string[] = [] |
| 31 | 36 | const seriesData: number[] = [] |
| 32 | 37 | |
| 33 | - for (const item of data) { | |
| 38 | + for (const item of historyData) { | |
| 34 | 39 | const [ts, value] = item |
| 35 | 40 | xAxisData.push(formatToDateTime(ts)) |
| 36 | 41 | seriesData.push(value) |
| 37 | 42 | } |
| 38 | 43 | |
| 39 | 44 | unref(chartInstance)?.setOption({ |
| 45 | + title: { | |
| 46 | + text: `${deviceName || ''}-${attrInfo.name || ''}`, | |
| 47 | + }, | |
| 40 | 48 | xAxis: { data: xAxisData }, |
| 41 | 49 | series: { data: seriesData }, |
| 42 | 50 | } as EChartsOption) |
| ... | ... | @@ -45,11 +53,11 @@ const handleHistoryData = (message: SubscriptionData, attr: string) => { |
| 45 | 53 | const { onMessage } = useOnMessage({ |
| 46 | 54 | onReceiveDataSourceMessage(commandSource, message) { |
| 47 | 55 | const { data } = commandSource |
| 48 | - const { chartOption, attr } = data as NodeDataDataSourceJsonType | |
| 56 | + const { chartOption } = data as NodeDataDataSourceJsonType | |
| 49 | 57 | const { queryType } = chartOption || {} |
| 50 | 58 | |
| 51 | 59 | if (queryType === SocketSubscriberEnum.HISTORY_CMDS) |
| 52 | - handleHistoryData(message.data, attr) | |
| 60 | + handleHistoryData(commandSource, message.data) | |
| 53 | 61 | }, |
| 54 | 62 | }) |
| 55 | 63 | ... | ... |
| ... | ... | @@ -64,7 +64,7 @@ const handlerTimeSeriesData = (commandSource: CommandSource, message: Subscripti |
| 64 | 64 | |
| 65 | 65 | unref(chartInstance)?.setOption({ |
| 66 | 66 | title: { |
| 67 | - text: `${deviceName}-${attrInfo.name}`, | |
| 67 | + text: `${deviceName || ''}-${attrInfo.name || ''}`, | |
| 68 | 68 | }, |
| 69 | 69 | dataset: { |
| 70 | 70 | dimensions: ['ts', attr], | ... | ... |