aboutsummaryrefslogtreecommitdiff
path: root/source/library/components/ResultViewer.svelte
blob: 083828df44dd3c1e48013bd2782a77cd9537455a (plain) (blame)
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
42
43
44
45
46
47
<script lang="ts">
  import Editor from "./Editor.svelte";
  import type { Extension } from "@codemirror/state";
  import type { Snippet } from "svelte";

  type Props = {
    footer?: Snippet<[{ result: string }]>;
    theme?: Extension;
    value: string;
  };

  let { footer, theme, value }: Props = $props();

  function noop(_v: string) {}
</script>

<style lang="scss">
  .result {
    display: grid;
    grid-template-rows: auto 1fr auto;
    height: 100%;
    min-height: 0;
  }

  .label {
    background: var(--graphiql-panel, #252526);
    font-size: 0.75rem;
    letter-spacing: 0.05em;
    padding: 0.25rem 0.75rem;
    text-transform: uppercase;
  }

  .footer {
    background: var(--graphiql-panel, #252526);
    border-top: 1px solid var(--graphiql-border, #333);
    font-size: 0.75rem;
    padding: 0.25rem 0.75rem;
  }
</style>

<div class="result">
  <div class="label">Response</div>
  <Editor language="json" onChange={noop} readOnly {theme} {value}/>
  {#if footer}
    <div class="footer">{@render footer({ result: value })}</div>
  {/if}
</div>