Files
fnx_web/svelte/src/filesystem/Menu.svelte

129 lines
3.6 KiB
Svelte
Raw Normal View History

<script lang="ts">
import PixeldrainLogo from "util/PixeldrainLogo.svelte";
import Button from "layout/Button.svelte";
import Euro from "util/Euro.svelte";
import { formatDataVolume } from "util/Formatting";
import { user } from "lib/UserStore";
2025-06-05 21:29:07 +02:00
import Dialog from "layout/Dialog.svelte";
2024-03-12 17:53:53 +01:00
let button: HTMLButtonElement
2025-06-05 21:29:07 +02:00
let dialog: Dialog
2024-03-12 17:53:53 +01:00
2024-06-26 23:28:17 +02:00
export let no_login_label = "Pixeldrain"
// Hide the label if the screen is smaller than 800px
2024-06-26 23:28:17 +02:00
export let hide_name = true
export let hide_logo = false
2024-07-23 16:45:04 +02:00
export let style = ""
export let embedded = false
$: target = embedded ? "_blank" : "_self"
2024-06-26 23:28:17 +02:00
2025-06-05 21:29:07 +02:00
const open = () => dialog.open(button.getBoundingClientRect())
2024-03-12 17:53:53 +01:00
</script>
<div class="wrapper">
<button bind:this={button} on:click={open} class="button round" title="Menu" style={style}>
2024-06-26 23:28:17 +02:00
{#if !hide_logo}
<PixeldrainLogo style="height: 1.6em; width: 1.6em;"/>
2024-06-26 23:28:17 +02:00
{/if}
<span class="button_username" class:hide_name>
{$user.username === "" ? no_login_label : $user.username}
2024-03-12 17:53:53 +01:00
</span>
</button>
</div>
2025-06-05 21:29:07 +02:00
<Dialog bind:this={dialog}>
2024-03-12 17:53:53 +01:00
<div class="menu">
{#if $user.username !== undefined && $user.username !== ""}
2024-06-26 23:28:17 +02:00
<Button link_href="/user" link_target={target} icon="dashboard" label="Dashboard" />
<div class="separator"></div>
2024-06-26 23:28:17 +02:00
2024-03-12 17:53:53 +01:00
<div class="stats_table">
<div>Subscription</div>
<div>{$user.subscription.name}</div>
2024-03-12 17:53:53 +01:00
{#if $user.subscription.type === "prepaid"}
2024-03-12 17:53:53 +01:00
<div>Credit</div>
<div><Euro amount={$user.balance_micro_eur}/></div>
2024-03-12 17:53:53 +01:00
{/if}
<div>Storage used</div>
<div>{formatDataVolume($user.filesystem_storage_used, 3)}</div>
2024-03-12 17:53:53 +01:00
<div>Transfer used</div>
<div>{formatDataVolume($user.monthly_transfer_used, 3)}</div>
2024-03-12 17:53:53 +01:00
</div>
<div class="separator"></div>
2024-06-26 23:28:17 +02:00
{#if $user.subscription.filesystem_access}
<Button link_href="/d/me" link_target={target} icon="folder" label="My Filesystem"/>
2024-06-26 23:28:17 +02:00
{:else}
<Button link_href="/#pro" link_target={target} icon="star" label="Get Premium"/>
2024-06-26 23:28:17 +02:00
{/if}
<Button link_href="/filesystem" link_target={target} icon="description" label="Filesystem Guide"/>
2024-06-26 23:28:17 +02:00
<div class="separator"></div>
2024-06-26 23:28:17 +02:00
<Button link_href="/user/filemanager#files" link_target={target} icon="image" label="My Files"/>
<Button link_href="/user/filemanager#lists" link_target={target} icon="photo_library" label="My Albums"/>
2024-06-26 23:28:17 +02:00
<div class="separator"></div>
2024-06-26 23:28:17 +02:00
<Button link_href="/user/settings" link_target={target} icon="settings" label="Account Settings"/>
<Button link_href="/user/subscription" link_target={target} icon="shopping_cart" label="Subscription"/>
<Button link_href="/user/prepaid/transactions" link_target={target} icon="receipt" label="Transactions"/>
2024-03-15 13:58:27 +01:00
{#if $user.is_admin}
<div class="separator"></div>
<Button link_href="/admin" link_target={target} icon="admin_panel_settings" label="Admin Panel"/>
2024-03-15 13:58:27 +01:00
{/if}
2024-03-12 17:53:53 +01:00
{:else}
<Button link_href="/" link_target={target} icon="home" label="Home"/>
<Button link_href="/#pro" link_target={target} icon="star" label="Get Premium"/>
<Button link_href="/login" link_target={target} icon="person" label="Log in"/>
<Button link_href="/register" link_target={target} icon="person" label="Register"/>
2024-03-12 17:53:53 +01:00
{/if}
</div>
2025-06-05 21:29:07 +02:00
</Dialog>
2024-03-12 17:53:53 +01:00
<style>
.wrapper {
flex-grow: 0;
flex-shrink: 0;
display: inline-flex;
2024-03-12 17:53:53 +01:00
align-self: center;
}
.button {
flex: 0 0 content;
}
.button_username {
margin: 0 4px;
}
2024-03-12 17:53:53 +01:00
.menu {
display: flex;
flex-direction: column;
max-width: 15em;
2024-03-12 17:53:53 +01:00
}
.separator {
height: 1px;
margin: 2px 0;
width: 100%;
background-color: var(--separator);
}
2024-03-12 17:53:53 +01:00
.stats_table {
display: grid;
grid-template-columns: auto auto;
gap: 0.2em 1em;
margin: 3px;
}
2024-03-15 13:58:27 +01:00
/* Hide username on small screen */
@media(max-width: 800px) {
2024-06-26 23:28:17 +02:00
.hide_name {
2024-03-15 13:58:27 +01:00
display: none;
}
}
2024-03-12 17:53:53 +01:00
</style>