aboutsummaryrefslogtreecommitdiff
path: root/src/lib/Loading/Message.svelte
blob: 53c993d32bc48e9913545acba423cad3702ebacf (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>