Skip to content
Merged
Original file line number Diff line number Diff line change
Expand Up @@ -9,28 +9,33 @@ const handleFinish = async () => {
};
</script>


<main class="h-[max-content] pt-[5.2svh] px-[5vw] pb-[4.5svh] flex flex-col justify-between">
<main
class="h-[max-content] pt-[5.2svh] px-[5vw] pb-[4.5svh] flex flex-col justify-between"
>
<section>
<Hero
title="Your ePassport and eVault are ready"
subtitle="Log into any W3DS platform without passwords. It’s tied to this phone; if lost, you’ll need to revoke and reissue it on a new device."
class="mb-2"
title="Your ePassport and eVault are ready"
subtitle="Log into any W3DS platform without passwords. It’s tied to this phone; if lost, you’ll need to revoke and reissue it on a new device."
class="mb-2"
/>
<IdentityCard
variant="ePassport"
userData={{
Name: "Ananya",
Dob: "29 Nov 2003",
Nationality: "Indian",
Passport: "234dfvgsdfg",
}}
/>
<IdentityCard variant= "ePassport"
userData= {{
Name: "Ananya",
Dob: "29 Nov 2003",
Nationality: "Indian",
Passport: "234dfvgsdfg",
}}/>
</section>
<section class="mt-[4svh] mb-[9svh]">
<h4>Your eVault</h4>
<p class="text-black-700 mb-[1svh]">We’ve also created your eVault—secure cloud storage for your personal data. W3DS platforms access it directly, keeping you in control.</p>
<IdentityCard variant= "eVault"
usedStorage= {15}
totalStorage= {80}/>
<p class="text-black-700 mb-[1svh]">
We’ve also created your eVault—secure cloud storage for your
personal data. W3DS platforms access it directly, keeping you in
control.
</p>
<IdentityCard variant="eVault" usedStorage={15} totalStorage={80} />
</section>
<ButtonAction class="w-full" callback={handleFinish}>Finish</ButtonAction>
</main>
</main>
18 changes: 8 additions & 10 deletions platforms/metagram/src/lib/fragments/BottomNav/BottomNav.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -14,20 +14,18 @@
profileSrc = 'https://picsum.photos/200'
}: IBottomNavProps = $props();

const tabs = ['home', 'discover', 'post', 'messages', 'profile'];
const tabs = ['home', 'discover', 'post', 'messages', 'profile', 'settings'];
let previousTab = $state('home');
let _activeTab = $derived(page.url.pathname);
let fullPath = $derived(page.url.pathname);

const handleNavClick = (newTab: string) => {
// activeTab = newTab;
isNavigatingThroughNav.value = true;

const fromIndex = tabs.indexOf(previousTab);
const toIndex = tabs.indexOf(newTab);

const direction = toIndex > fromIndex ? 'right' : 'left';
document.documentElement.setAttribute('data-transition', direction);

previousTab = newTab;
goto(`/${newTab}`);
};
Expand All @@ -40,7 +38,7 @@
<!-- svelte-ignore a11y_no_noninteractive_element_to_interactive_role -->
<nav
aria-label="Main navigation"
class="fixed start-0 bottom-0 flex w-full items-center justify-between bg-white px-7 py-2 md:hidden"
class="border-grey fixed start-0 bottom-0 flex w-full items-center justify-between border-t-[1px] bg-white px-7 py-2 md:hidden"
role="tablist"
>
<button
Expand All @@ -54,7 +52,7 @@
color={activeTab === 'home'
? 'var(--color-brand-burnt-orange)'
: 'var(--color-black-400)'}
fill={activeTab === 'home' ? 'var(--color-brand-burnt-orange)' : 'white'}
fill={activeTab === 'home' ? 'var(--color-brand-burnt-orange-300)' : 'white'}
/>
</button>

Expand All @@ -69,7 +67,7 @@
color={activeTab === 'discover'
? 'var(--color-brand-burnt-orange)'
: 'var(--color-black-400)'}
fill={activeTab === 'discover' ? 'var(--color-brand-burnt-orange)' : 'white'}
fill={activeTab === 'discover' ? 'var(--color-brand-burnt-orange-300)' : 'white'}
/>
</button>

Expand All @@ -84,7 +82,7 @@
color={activeTab === 'post'
? 'var(--color-brand-burnt-orange)'
: 'var(--color-black-400)'}
fill={activeTab === 'post' ? 'var(--color-brand-burnt-orange)' : 'white'}
fill={activeTab === 'post' ? 'var(--color-brand-burnt-orange-300)' : 'white'}
/>
</button>

Expand All @@ -99,7 +97,7 @@
color={activeTab === 'messages'
? 'var(--color-brand-burnt-orange)'
: 'var(--color-black-400)'}
fill={activeTab === 'messages' ? 'var(--color-brand-burnt-orange)' : 'white'}
fill={activeTab === 'messages' ? 'var(--color-brand-burnt-orange-300)' : 'white'}
/>
</button>

Expand All @@ -110,7 +108,7 @@
onclick={() => handleNavClick('profile')}
>
<span
class={`inline-block w-full rounded-full border p-1 ${activeTab === 'profile' ? 'border-brand-burnt-orange' : 'border-transparent'}`}
class={`inline-block w-full rounded-full border p-1 ${activeTab === 'profile' || fullPath.includes('settings') ? 'border-brand-burnt-orange' : 'border-transparent'}`}
>
<img
width="24px"
Expand Down
6 changes: 4 additions & 2 deletions platforms/metagram/src/lib/fragments/Header/Header.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@

const variantClasses = {
primary: {
text: 'text-transparent bg-clip-text bg-[image:var(--color-brand-gradient)]',
text: 'text-transparent bg-clip-text bg-[image:var(--color-brand-gradient)] py-2',
background: ''
},
secondary: {
Expand All @@ -44,7 +44,9 @@
};

const classes = $derived({
common: cn('flex items-center justify-between py-4 px-0'),
common: cn(
'flex items-center justify-between my-4 pb-6 border-b-[1px] md:border-0 border-grey'
),
text: variantClasses[variant].text,
background: variantClasses[variant].background
});
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
<script lang="ts">
import type { Snippet } from 'svelte';
import type { HTMLAttributes } from 'svelte/elements';
import { Header } from '..';

interface IRightAsideProps extends HTMLAttributes<HTMLElement> {
header: Snippet;
asideContent: Snippet;
}
let { header, asideContent, ...restProps }: IRightAsideProps = $props();
</script>

<aside {...restProps} class="hidden border border-y-0 border-s-gray-200 md:block md:pt-13">
<div class="mx-5">
<h2 class="mb-10 text-lg font-semibold">
{@render header?.()}
</h2>
<div>
{@render asideContent?.()}
</div>
</div>
</aside>
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
<script lang="ts">
import { cn } from '$lib/utils';
import { Delete02Icon } from '@hugeicons/core-free-icons';
import { HugeiconsIcon } from '@hugeicons/svelte';
import type { Snippet } from 'svelte';
import type { HTMLAttributes } from 'svelte/elements';
interface ISettingsDeleteButtonProps extends HTMLAttributes<HTMLElement> {
children: Snippet;
onclick: () => void;
}
let { children, onclick, ...restProps }: ISettingsDeleteButtonProps = $props();
const cBase = 'flex w-full items-center justify-between';
</script>

<div {...restProps} class={cn([cBase, restProps.class].join(' '))}>
<div class="flex items-center gap-2">
<h3 class="text-black-800 text-base">
{@render children?.()}
</h3>
</div>
<button class="cursor-pointer" {onclick}>
<HugeiconsIcon icon={Delete02Icon} color="var(--color-black-400)" />
</button>
</div>
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,14 @@ export const Primary = {
hasTrailingIcon: true
}
};
export const ProfileSrc = {
args: {
children: ButtonText,
profileSrc: 'https://picsum.photos/200/300',
onclick: () => alert('clicked'),
hasTrailingIcon: true
}
};

export const Secondary = {
args: {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,13 +7,15 @@

interface ISettingsNaviationButtonProps extends HTMLButtonAttributes {
leadingIcon?: Snippet;
profileSrc?: string;
children: Snippet;
onclick: () => void;
hasTrailingIcon: boolean;
onclick?: () => void;
hasTrailingIcon?: boolean;
}

let {
leadingIcon,
profileSrc,
children,
onclick,
hasTrailingIcon = true,
Expand All @@ -27,12 +29,21 @@
<div class="flex items-center gap-2">
{#if leadingIcon}
<div
class="bg-brand-burnt-orange-100 flex h-10 w-10 items-center justify-center rounded-full"
class="bg-brand-burnt-orange-100 flex size-8 items-center justify-center rounded-full md:size-10"
>
{@render leadingIcon?.()}
</div>
{/if}
<h3 class="text-black-800 font-semibold">
{#if profileSrc}
<img
width="24px"
height="24px"
class="flex aspect-square size-10 items-center justify-center rounded-full md:size-12"
src={profileSrc}
alt=""
/>
{/if}
<h3 class="text-black-800 text-start text-base">
{@render children?.()}
</h3>
</div>
Expand Down
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is obsolete now :)

Original file line number Diff line number Diff line change
@@ -0,0 +1,84 @@
<script lang="ts">
import { goto } from '$app/navigation';
import { page } from '$app/state';
import SettingsNavigationButton from '$lib/fragments/SettingsNavigationButton/SettingsNavigationButton.svelte';
import {
DatabaseIcon,
Logout01Icon,
Notification02FreeIcons
} from '@hugeicons/core-free-icons';
import { HugeiconsIcon } from '@hugeicons/svelte';
import type { HTMLAttributes } from 'svelte/elements';
let route = $derived(page.url.pathname);
interface ISettingsPageProps extends HTMLAttributes<HTMLElement> {
username: string;
userEmail: string;
}
let { username, userEmail }: ISettingsPageProps = $props();
</script>

<div class="bg-grey rounded-xl p-3 md:p-5">
<SettingsNavigationButton
onclick={() => goto(`/settings/account`)}
profileSrc="https://picsum.photos/200/300"
>
{#snippet children()}
<div class="flex flex-col items-start">
<h2 class="text-lg">{username}</h2>
<p class="text-sm">{userEmail}</p>
</div>
{/snippet}
</SettingsNavigationButton>
</div>
<hr class="text-grey" />
<div class="flex flex-col gap-3">
<h3 class="text-brand-burnt-orange text-base font-semibold">Personalisation</h3>
<div class="{route === `/settings/notifications` ? 'bg-grey' : ''} rounded-xl p-2">
<SettingsNavigationButton onclick={() => goto(`/settings/notifications`)}>
{#snippet leadingIcon()}
<HugeiconsIcon
size="24px"
icon={Notification02FreeIcons}
color="var(--color-brand-burnt-orange)"
/>
{/snippet}
{#snippet children()}
Notifications
{/snippet}
</SettingsNavigationButton>
</div>
</div>
<hr class="text-grey" />
<div class="flex flex-col gap-3">
<h3 class="text-brand-burnt-orange text-base font-semibold">System</h3>
<div class="{route === `/settings/data-and-storage` ? 'bg-grey' : ''} rounded-xl p-2">
<SettingsNavigationButton onclick={() => goto(`/settings/data-and-storage`)}>
{#snippet leadingIcon()}
<HugeiconsIcon
size="24px"
icon={DatabaseIcon}
color="var(--color-brand-burnt-orange)"
/>
{/snippet}
{#snippet children()}
Data & Storage
{/snippet}
</SettingsNavigationButton>
</div>
<div class="{route === `/settings/logout` ? 'bg-grey' : ''} rounded-xl p-2">
<SettingsNavigationButton onclick={() => goto(`/settings/logout`)}>
{#snippet leadingIcon()}
<HugeiconsIcon
size="24px"
icon={Logout01Icon}
color="var(--color-brand-burnt-orange)"
/>
{/snippet}
{#snippet children()}
Logout
{/snippet}
</SettingsNavigationButton>
</div>
</div>
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
<script lang="ts">
import { Toggle } from '$lib/ui';
import { cn } from '$lib/utils';
import type { Snippet } from 'svelte';
import type { HTMLButtonAttributes } from 'svelte/elements';

interface ISettingsToggleButtonProps extends HTMLButtonAttributes {
children: Snippet;
checked: boolean;
}

let { children, onclick, checked, ...restProps }: ISettingsToggleButtonProps = $props();

const cBase = 'flex w-full items-center justify-between';
</script>

<button {...restProps} class={cn([cBase, restProps.class].join(' '))} {onclick}>
<div class="flex items-center gap-2">
<h3 class="text-black-800 text-base">
{@render children?.()}
</h3>
</div>
<Toggle {checked}></Toggle>
</button>
Loading
Loading