index.vue 4.36 KB
<script lang="ts" setup>
  import { ref } from 'vue';
  import { Image as AntImage } from 'ant-design-vue';
  import { UpdateTime } from '/@/views/visual/commonComponents/UpdateTime';
  import { ComponentPropsConfigType } from '../../../index.type';
  import { useDataFetch } from '../../../hook/socket/useSocket';
  import { DataFetchUpdateFn } from '../../../hook/socket/useSocket.type';

  const props = defineProps<{
    config: ComponentPropsConfigType;
  }>();

  const fallback =
    '';

  const time = ref<Nullable<number>>(null);

  const url = ref<string>(fallback);

  const updateFn: DataFetchUpdateFn = (message, attribute) => {
    const { data = {} } = message;
    const [latest] = data[attribute] || [];
    const [timespan, value] = latest;
    time.value = timespan;
    url.value = `${value}?timespan=${timespan}`;
  };

  useDataFetch(props, updateFn);
</script>

<template>
  <main class="w-full h-full flex flex-col items-center">
    <AntImage :src="url" :fallback="fallback" />
    <UpdateTime :time="time" />
  </main>
</template>

<style scoped lang="less">
  :deep(.ant-image) {
    @apply flex justify-center w-auto;

    height: calc(100% - 56px);

    img {
      @apply w-auto h-full;
    }
  }
</style>