Files
nebula/layouts/app.templ

114 lines
2.8 KiB
Plaintext

package layouts
type WalletUser struct {
Name string
Address string
}
templ AppLayout(title string, user WalletUser) {
@Base(title) {
@appStyles()
<wa-page>
<div class="app-layout">
@AppHeader(user)
<main class="main-content">
<div class="content-container">
{ children... }
</div>
</main>
</div>
</wa-page>
}
}
templ AppHeader(user WalletUser) {
<div class="header-wrapper">
<header class="app-header">
<div class="header-left">
<wa-icon name="cube" style="font-size: 24px; color: var(--wa-color-primary);"></wa-icon>
<span class="logo-text">Sonr Wallet</span>
</div>
<div class="header-right">
<wa-dropdown>
<wa-avatar slot="trigger" initials="S" style="--size: 36px; background: var(--wa-color-primary); cursor: pointer;"></wa-avatar>
<div style="padding: var(--wa-space-m); border-bottom: 1px solid var(--wa-color-neutral-200);">
<div class="wa-stack wa-gap-0">
<span class="wa-heading-s">{ user.Name }</span>
<span class="wa-caption-xs" style="color: var(--wa-color-neutral-500);">{ user.Address }</span>
</div>
</div>
<wa-dropdown-item href="/connections">
<wa-icon slot="icon" name="plug"></wa-icon>
Connections
</wa-dropdown-item>
<wa-dropdown-item href="/devices">
<wa-icon slot="icon" name="mobile"></wa-icon>
Devices
</wa-dropdown-item>
<wa-dropdown-item href="/services">
<wa-icon slot="icon" name="server"></wa-icon>
Services
</wa-dropdown-item>
<wa-dropdown-item href="/settings">
<wa-icon slot="icon" name="gear"></wa-icon>
Settings
</wa-dropdown-item>
<wa-divider></wa-divider>
<wa-dropdown-item variant="danger" href="/logout">
<wa-icon slot="icon" name="arrow-right-from-bracket"></wa-icon>
Sign Out
</wa-dropdown-item>
</wa-dropdown>
</div>
</header>
</div>
}
templ appStyles() {
<style>
.app-layout {
display: flex;
flex-direction: column;
min-height: 100vh;
background: var(--wa-color-surface-alt);
}
.header-wrapper {
background: var(--wa-color-surface);
border-bottom: 1px solid var(--wa-color-neutral-200);
}
.app-header {
display: flex;
align-items: center;
justify-content: space-between;
max-width: 1200px;
margin: 0 auto;
padding: var(--wa-space-s) var(--wa-space-l);
background: var(--wa-color-surface);
}
.header-left {
display: flex;
align-items: center;
gap: var(--wa-space-m);
}
.header-right {
display: flex;
align-items: center;
gap: var(--wa-space-m);
}
.logo-text {
font-weight: 600;
font-size: var(--wa-font-size-l);
color: var(--wa-color-neutral-900);
}
.main-content {
flex: 1;
overflow-y: auto;
}
.content-container {
max-width: 1200px;
margin: 0 auto;
padding: 0 var(--wa-space-l);
}
</style>
}