File size: 1,075 Bytes
8a37e0a
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
import { IAINoContentFallback } from 'common/components/IAIImageFallback';
import { memo, useMemo } from 'react';
import { useTranslation } from 'react-i18next';
import { useDebouncedImageWorkflow } from 'services/api/hooks/useDebouncedImageWorkflow';
import type { ImageDTO } from 'services/api/types';

import DataViewer from './DataViewer';

type Props = {
  image: ImageDTO;
};

const ImageMetadataWorkflowTabContent = ({ image }: Props) => {
  const { t } = useTranslation();
  const { currentData } = useDebouncedImageWorkflow(image);
  const workflow = useMemo(() => {
    if (currentData?.workflow) {
      try {
        return JSON.parse(currentData.workflow);
      } catch {
        return null;
      }
    }
    return null;
  }, [currentData]);

  if (!workflow) {
    return <IAINoContentFallback label={t('nodes.noWorkflow')} />;
  }

  return (
    <DataViewer
      fileName={`${image.image_name.replace('.png', '')}_workflow`}
      data={workflow}
      label={t('metadata.workflow')}
    />
  );
};

export default memo(ImageMetadataWorkflowTabContent);