aboutsummaryrefslogtreecommitdiff
path: root/src/lib/Loading/Message.svelte
blob: 36f889d200582fb1118f002c8d84803862ed8f39 (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
<script lang="ts">
import Ellipsis from "./Ellipsis.svelte";
import Ripple from "./Ripple.svelte";
import Grid from "./Grid.svelte";
import Popup from "$lib/Layout/Popup.svelte";

export let message: string | undefined = undefined;
export let loader: "ellipsis" | "ripple" | "grid" = "ellipsis";
export let colour = "var(--fg)";
export let slot = false;
export let withReload = false;
export let fullscreen = true;
</script>

<Popup {fullscreen} locked>
  <div class="message">
    {#if loader === 'ellipsis'}
      <Ellipsis {colour} />
    {:else if loader === 'ripple'}
      <Ripple {colour} />
    {:else if loader === 'grid'}
      <Grid {colour} />
    {/if}

    {#if message}
      <br />

      {message}
    {:else if slot}
      <br />

      <slot />

      {#if withReload}
        Please <a href={'#'} onclick={() => location.reload()}>try again</a> later.
      {/if}
    {/if}
  </div>
</Popup>

<style>
  .message {
    text-align: center;
  }
</style>