index.vue
3.61 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
<script lang="ts" setup>
  import { ComponentPropsConfigType } from '/@/views/visual/packages/index.type';
  import { option } from './config';
  import { useComponentScale } from '/@/views/visual/packages/hook/useComponentScale';
  import { ref, unref } from 'vue';
  import { UpdateTime } from '/@/views/visual/commonComponents/UpdateTime';
  import { SvgIcon } from '/@/components/Icon';
  import { computed } from 'vue';
  import { DeviceName } from '/@/views/visual/commonComponents/DeviceName';
  import { useDataFetch } from '../../../hook/socket/useSocket';
  import { DataFetchUpdateFn } from '../../../hook/socket/useSocket.type';
  import { useThingsModelValueTransform } from '/@/views/visual/palette/hooks/useThingsModelValueTransform';
  import { useDeviceProfileQueryContext } from '/@/views/visual/palette/hooks/useDeviceProfileQueryContext';
  const props = defineProps<{
    config: ComponentPropsConfigType<typeof option>;
  }>();
  const currentValue = ref<string | number>(123);
  const time = ref<Nullable<number>>(null);
  const { getDeviceProfileTslByIdWithIdentifier } = useDeviceProfileQueryContext();
  const getThingModelTsl = computed(() => {
    const { option } = props.config;
    const { deviceProfileId, attribute } = option;
    return getDeviceProfileTslByIdWithIdentifier?.(deviceProfileId, attribute);
  });
  const getDesign = computed(() => {
    const { persetOption = {}, option } = props.config;
    const {
      iconColor: persetIconColor,
      unit: perseUnit,
      icon: persetIcon,
      fontColor: persetFontColor,
      valueSize: persetValueSize,
      fontSize: persetFontSize,
    } = persetOption;
    const { componentInfo, attributeRename } = option;
    const { functionName } = unref(getThingModelTsl) || {};
    const { icon, iconColor, fontColor, unit, valueSize, fontSize } = componentInfo || {};
    return {
      iconColor: iconColor || persetIconColor,
      unit: unit ?? perseUnit,
      icon: icon || persetIcon,
      fontColor: fontColor || persetFontColor,
      attribute: attributeRename || functionName,
      valueSize: valueSize || persetValueSize || 20,
      fontSize: fontSize || persetFontSize || 14,
    };
  });
  const updateFn: DataFetchUpdateFn = (message, attribute) => {
    const { data = {} } = message;
    const [latest] = data[attribute] || [];
    if (!latest.length) return;
    const [timespan, value] = latest;
    currentValue.value = useThingsModelValueTransform(
      value,
      unref(getThingModelTsl)?.specs?.dataType
    );
    time.value = timespan;
  };
  useDataFetch(props, updateFn);
  const { getScale, getRatio } = useComponentScale(props);
</script>
<template>
  <main :style="getScale" class="w-full h-full flex flex-col justify-center items-center">
    <DeviceName :config="config" />
    <div class="flex-1 flex justify-center items-center flex-col w-full">
      <SvgIcon
        :name="getDesign.icon!"
        prefix="iconfont"
        :size="getRatio ? getRatio * 70 : 70"
        :style="{ color: getDesign.iconColor }"
      />
      <h1
        class="font-bold m-2 truncate w-full text-center"
        :style="{
          color: getDesign.fontColor,
          fontSize: (getRatio ? getRatio * getDesign.valueSize : getDesign.valueSize) + 'px',
        }"
      >
        <span> {{ currentValue || 0 }}</span>
        <span>{{ getDesign.unit }} </span>
      </h1>
      <div
        class="text-gray-500 truncate"
        :style="{
          fontSize: (getRatio ? getRatio * getDesign.fontSize : getDesign.fontSize) + 'px',
        }"
        >{{ getDesign.attribute || '温度' }}</div
      >
    </div>
    <UpdateTime :time="time" />
  </main>
</template>