index.vue 5.13 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';
  import { isNullOrUnDef } from '/@/utils/is';

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

  const fallback =
    '';

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

  const url = ref<string>(fallback);

  // const getImagBase64 = ref(fallback);

  // const getBase64Image = (url: string) => {
  //   let canvas: Nullable<HTMLCanvasElement> = document.createElement('canvas');
  //   const ctx = canvas.getContext('2d');
  //   let image: Nullable<HTMLImageElement> = new Image();

  //   image.onload = function () {
  //     canvas!.height = image!.height;
  //     canvas!.width = image!.width;
  //     ctx?.drawImage(image!, 0, 0);
  //     const dataUrl = canvas!.toDataURL('image/png');
  //     getImagBase64.value = dataUrl;
  //     console.log(dataUrl);
  //     image = null;
  //     canvas = null;
  //   };
  //   image.setAttribute('crossOrigin', 'Anonymous');
  //   image.src = url;
  // };

  const updateFn: DataFetchUpdateFn = (message, attribute) => {
    const { data = {} } = message;
    const [latest] = data[attribute] || [];
    const [timespan, value] = latest;
    if (isNullOrUnDef(value)) return;
    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>