114 lines
2.8 KiB
Plaintext
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>
|
|
}
|