Skip to content

Commit

Permalink
feat: Rework design
Browse files Browse the repository at this point in the history
  • Loading branch information
kiosion committed Sep 16, 2023
1 parent 5f1319a commit f4a0d00
Show file tree
Hide file tree
Showing 37 changed files with 517 additions and 1,038 deletions.
4 changes: 2 additions & 2 deletions svelte-app/src/app.scss
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ body {
@media (min-width: 0px) {
background-color: $dark;
}
@media (min-width: 1024px) {
@media (min-width: 768px) {
background-color: $black;
}

Expand All @@ -43,7 +43,7 @@ body {
@media (min-width: 0px) {
background-color: $white;
}
@media (min-width: 1024px) {
@media (min-width: 768px) {
background-color: $light;
}

Expand Down
198 changes: 78 additions & 120 deletions svelte-app/src/components/about/timeline.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
import { currentLang, t } from '$i18n';
import Settings from '$stores/settings';
import EmptyContent from '$components/empty-content.svelte';
import BulletPoint from '$components/bullet-point.svelte';
import Hoverable from '$components/hoverable.svelte';
import Icon from '$components/icon.svelte';
import PortableText from '$components/portable-text/portable-text.svelte';
Expand All @@ -17,7 +17,7 @@
let selected: number | null = null;
export let data: AuthorTimelineItem[] | undefined;
export let data: AuthorTimelineItem[];
const dateDisplay = (start: string, end: string | undefined) => {
try {
Expand All @@ -26,33 +26,16 @@
if (!endDate) {
return `${new Intl.DateTimeFormat($currentLang, {
month: 'long',
month: 'short',
year: 'numeric'
}).format(startDate)} ${$t('to')} ${$t('now')}`;
}
if (startDate.getFullYear() === endDate.getFullYear()) {
if (startDate.getMonth() === endDate.getMonth()) {
return `${new Intl.DateTimeFormat($currentLang, {
month: 'long',
day: 'numeric'
}).format(startDate)} ${$t('to')} ${new Intl.DateTimeFormat($currentLang, {
day: 'numeric',
year: 'numeric'
}).format(endDate)}`;
}
return `${new Intl.DateTimeFormat($currentLang, {
month: 'long'
}).format(startDate)} ${$t('to')} ${new Intl.DateTimeFormat($currentLang, {
month: 'long'
}).format(endDate)} ${endDate.getFullYear()}`;
}).format(startDate)} - ${$t('present')}`;
}
return `${new Intl.DateTimeFormat($currentLang, {
month: 'long',
month: 'short',
year: 'numeric'
}).format(startDate)} ${$t('to')} ${new Intl.DateTimeFormat($currentLang, {
month: 'long',
}).format(startDate)} - ${new Intl.DateTimeFormat($currentLang, {
month: 'short',
year: 'numeric'
}).format(endDate)}`;
} catch (_) {
Expand All @@ -63,104 +46,79 @@
const { reduce_motion } = Settings;
</script>

<div class="relative ml-0 mr-2 mt-4 h-fit">
{#if data}
<div
class="absolute left-0 top-[14px] h-[calc(100%_-_14px)] w-[1px] rounded-full bg-dark/40 dark:bg-light/40"
/>
<div class="-ml-[4px] flex flex-col items-start justify-start gap-4">
{#each data as item, i}
<div class="flex w-full flex-row items-start justify-start gap-2">
<Icon
width={24}
height={24}
icon="ArrowRight"
class="translate-x-[1px] translate-y-[2.5px] text-dark/40 dark:text-light/40"
/>
<div class="mr-6 flex w-full flex-col items-start justify-start">
<h1 class="select-none font-code text-base text-dark/90 dark:text-light/90">
<div class="flex flex-col items-start justify-start gap-4">
{#each data as item, i}
<Hoverable bind:hovered={data[i].hovered}>
<Tooltip
text={selected === i ? $t('Click to hide details') : $t('Click to show details')}
position="bottom"
disable={!item.body}
>
<div
class="flex w-full flex-col items-start justify-start"
on:click={() => {
if (item.body) {
selected = selected === i ? null : i;
}
}}
on:keydown={(e) => {
if (item.body && (e.code === 'Enter' || e.code === 'Space')) {
selected = selected === i ? null : i;
}
}}
aria-expanded={selected === i}
tabindex={0}
role="button"
>
<div class="flex flex-row items-center justify-start gap-4">
<Icon
icon="ChevronDown"
class="{selected === i ? 'rotate-0' : '-rotate-90'} transition-all"
/>
<p
class="min-w-[10rem] select-none font-code text-base text-dark/90 dark:text-light/90"
>
{dateDisplay(item.range.start, item.range.end)}
</h1>
<Hoverable bind:hovered={data[i].hovered}>
<Tooltip
text={selected === i
? $t('Click to hide details')
: $t('Click to show details')}
position="bottom"
disable={!item.body}
</p>
<div class="flex flex-row items-center justify-start">
<h1
class="text-lg font-bold decoration-accent-light decoration-[3px] underline-offset-4 dark:decoration-accent-dark"
class:underline={data[i].hovered}
>
<div
class="relative ml-2 mt-2 w-full rounded-lg {data[i].hovered
? 'border-dark/60 bg-dark/10 dark:border-light/60 dark:bg-dark/40'
: 'border-dark/40 bg-dark/5 dark:border-light/40 dark:bg-dark/20'} focusOutline overflow-hidden border px-4 py-3 transition-[background-color,border-color]"
on:click={() => {
if (item.body) {
selected = selected === i ? null : i;
}
}}
on:keydown={(e) => {
if (item.body && (e.code === 'Enter' || e.code === 'Space')) {
selected = selected === i ? null : i;
}
}}
aria-expanded={selected === i}
tabindex={0}
role="button"
>
<div class="line-clamp-1 select-none font-sans text-base font-bold">
{item.title}
</div>
{#if item.subtitle}
<div
class="text-gray-700 dark:text-gray-200 mt-1 line-clamp-1 select-none font-sans text-base italic"
>
{item.subtitle}
</div>
{/if}
{#if selected === i && item.body}
<div
class="pb-2 font-sans text-base"
in:maybe={{
fn: $reduce_motion ? 'fade' : 'slide',
enable: true,
duration: 200,
easing: circInOut
}}
out:maybe={{
fn: $reduce_motion ? 'fade' : 'slide',
enable: true,
duration: 150,
easing: circInOut
}}
>
{#if item.skills}
<Tags
model="project"
data={item.skills}
classes="my-2 select-none"
/>
{/if}
<div class="-mb-5 mt-4">
<PortableText text={item.body} />
</div>
</div>
{/if}
{#if item.body}
<Icon
icon="ChevronDown"
class="{selected === i
? 'rotate-0'
: 'rotate-90'} absolute right-4 top-4 transition-all"
/>
{/if}
</div>
</Tooltip>
</Hoverable>
{item.title}
</h1>
{#if item.subtitle}
<BulletPoint />
<p class="text-base">{item.subtitle}</p>
{/if}
</div>
</div>
{#if selected === i && item.body}
<div
class="mx-10 pb-2 font-sans text-base"
in:maybe={{
fn: $reduce_motion ? 'fade' : 'slide',
enable: true,
duration: 200,
easing: circInOut
}}
out:maybe={{
fn: $reduce_motion ? 'fade' : 'slide',
enable: true,
duration: 150,
easing: circInOut
}}
>
{#if item.skills}
<Tags model="project" data={item.skills} classes="my-2 select-none" />
{/if}
<div class="-mb-5 mt-4">
<PortableText text={item.body} />
</div>
</div>
{/if}
</div>
{/each}
</div>
{:else}
<EmptyContent />
{/if}
</Tooltip>
</Hoverable>
{/each}
</div>
3 changes: 2 additions & 1 deletion svelte-app/src/components/bullet-point.svelte
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
<div
class="mx-2 h-1 w-1 rounded-full bg-dark/80 transition-all duration-150 dark:bg-light/90"
class="mx-2 h-1 w-1 rounded-full bg-dark/80 transition-all duration-150 dark:bg-light/90 {$$props.class ||
''}"
/>
Original file line number Diff line number Diff line change
@@ -1,18 +1,19 @@
<script lang="ts">
import { goto } from '$app/navigation';
import { page } from '$app/stores';
import { linkTo, t } from '$i18n';
import { currentLang, linkTo, t } from '$i18n';
import { APP_LANGS } from '$lib/consts';
import { navOpen } from '$stores/navigation';
import Dialog from '$components/dialog.svelte';
import Hoverable from '$components/hoverable.svelte';
import Icon from '$components/icon.svelte';
import Tooltip from '$components/tooltip.svelte';
export let langs = [
{ lang: 'en', name: 'English' },
{ lang: 'fr', name: 'Français' }
],
forNav = false;
{ lang: 'en', name: 'English' },
{ lang: 'fr', name: 'Français' }
];
let modalOpen = false;
Expand Down Expand Up @@ -54,7 +55,31 @@
on:confirm={modalConfirm}
/>

<div class={$$props.class || ''}>
<Hoverable>
<Tooltip
text={$t(
$currentLang === 'en' ? 'Switch language to French' : 'Switch language to English'
)}
delay={150}
fixed
>
<button
class="focusOutline h-[20px] w-[20px] rounded-sm hover:text-accent-light dark:hover:text-accent-dark {$$props.class ||
''}"
aria-label={$t(
$currentLang === 'en' ? 'Switch language to French' : 'Switch language to English'
)}
tabindex="0"
on:click={(e) => {
handleClick(e, $currentLang === 'en' ? 'fr' : 'en');
}}
>
<Icon icon="script" />
</button>
</Tooltip>
</Hoverable>

<!-- <div class={$$props.class || ''}>
<span class="cursor-default select-none">{$t('Language')} (</span>
{#each _langs as lang, i}
<Hoverable bind:hovered={lang.active}>
Expand Down Expand Up @@ -86,8 +111,7 @@
{/if}
{/each}
<span class="cursor-default select-none">)</span>
</div>

</div> -->
<style lang="scss">
a {
&.forNav {
Expand Down
Loading

0 comments on commit f4a0d00

Please sign in to comment.