mirror of
https://github.com/mountain-loop/yaak.git
synced 2026-01-15 13:43:39 +01:00
41 lines
1.3 KiB
TypeScript
41 lines
1.3 KiB
TypeScript
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 <WebPageViewer response={response} />;
|
|
}
|
|
if (rawTextBody.data == null) {
|
|
return <EmptyStateText>Empty response</EmptyStateText>;
|
|
}
|
|
return (
|
|
<TextViewer
|
|
language={language}
|
|
text={rawTextBody.data}
|
|
pretty={pretty}
|
|
className={textViewerClassName}
|
|
response={response}
|
|
requestId={response.requestId}
|
|
/>
|
|
);
|
|
}
|