import type { HttpResponse } from '@yaakapp-internal/models'; import { useResponseBodyText } from '../../hooks/useResponseBodyText'; import { languageFromContentType } from '../../lib/contentType'; import { getContentTypeFromHeaders } from '../../lib/model_util'; import { EmptyStateText } from '../EmptyStateText'; import { TextViewer } from './TextViewer'; import { WebPageViewer } from './WebPageViewer'; interface Props { response: HttpResponse; pretty: boolean; textViewerClassName?: string; } export function HTMLOrTextViewer({ response, pretty, textViewerClassName }: Props) { const rawTextBody = useResponseBodyText({ response, filter: null }); const contentType = getContentTypeFromHeaders(response.headers); const language = languageFromContentType(contentType, rawTextBody.data ?? ''); if (rawTextBody.isLoading || response.state === 'initialized') { return null; } if (language === 'html' && pretty) { return ; } if (rawTextBody.data == null) { return Empty response; } return ( ); }