| <script lang="ts"> |
| import ModalBase from './ModalBase.svelte'; |
| import type { CloseModalFn } from '$lib/types/utilTypes'; |
| import { type Message, type HeaderField } from '$lib/domain/Message'; |
| import MessageDecoder from '$lib/components/MessageDecoder/MessageDecoder.svelte'; |
| import { decodeBase64 } from '$lib/utils/base64Utils'; |
| |
| interface Props { |
| closeModal: CloseModalFn; |
| message: Message; |
| } |
| |
| let { closeModal, message }: Props = $props(); |
| |
| const formatHeaders = (headers: Record<string, HeaderField> | null | undefined) => { |
| if (!headers || Object.keys(headers).length === 0) { |
| return 'No headers'; |
| } |
| try { |
| return JSON.stringify(headers, null, 2); |
| } catch { |
| return 'Invalid headers format'; |
| } |
| }; |
| |
| // TODO: whether all header values should be decoded? |
| let codec = $derived(message?.user_headers?.['codec']?.value |
| ? decodeBase64(message.user_headers['codec'].value) |
| : undefined); |
| </script> |
| |
| <ModalBase {closeModal} title="Message details" class="w-full max-w-[90vw] lg:max-w-[80vw]"> |
| <div class="grid grid-cols-1 lg:grid-cols-2 gap-6 p-4 lg:p-6 h-full w-full overflow-auto"> |
| <div class="flex flex-col gap-4"> |
| <div class="bg-shadeL200 dark:bg-shadeD400 p-3 lg:p-4 rounded-md"> |
| <span class="text-xs text-shadeL900 dark:text-shadeL700 block mb-1">ID</span> |
| <div class="text-sm text-color font-medium">{message?.id ?? 'N/A'}</div> |
| </div> |
| |
| <div class="bg-shadeL200 dark:bg-shadeD400 p-3 lg:p-4 rounded-md"> |
| <span class="text-xs text-shadeL900 dark:text-shadeL700 block mb-1">Offset</span> |
| <div class="text-sm text-color font-medium">{message?.offset ?? 'N/A'}</div> |
| </div> |
| |
| <div class="bg-shadeL200 dark:bg-shadeD400 p-3 lg:p-4 rounded-md"> |
| <span class="text-xs text-shadeL900 dark:text-shadeL700 block mb-1">Checksum</span> |
| <div class="text-sm text-color font-medium">{message?.checksum ?? 'N/A'}</div> |
| </div> |
| |
| <div class="bg-shadeL200 dark:bg-shadeD400 p-3 lg:p-4 rounded-md"> |
| <span class="text-xs text-shadeL900 dark:text-shadeL700 block mb-1">Timestamp</span> |
| <div class="text-sm text-color font-medium"> |
| {message?.formattedTimestamp ?? 'N/A'} |
| <span class="text-xs text-shadeL900 dark:text-shadeL700 ml-2"> |
| ({message?.timestamp ?? 'N/A'}) |
| </span> |
| </div> |
| </div> |
| |
| <div class="bg-shadeL200 dark:bg-shadeD400 p-3 lg:p-4 rounded-md"> |
| <span class="text-xs text-shadeL900 dark:text-shadeL700 block mb-1">Headers</span> |
| <div class="text-sm text-color font-medium font-mono whitespace-pre-wrap"> |
| {formatHeaders(message?.user_headers)} |
| </div> |
| </div> |
| </div> |
| |
| <div class="bg-shadeL200 dark:bg-shadeD400 p-3 lg:p-4 rounded-md"> |
| <span class="text-xs text-shadeL900 dark:text-shadeL700 block mb-1">Payload</span> |
| <div class="text-sm text-color font-medium"> |
| <MessageDecoder payload={message?.payload} {codec} /> |
| </div> |
| </div> |
| </div> |
| </ModalBase> |