Fix ProseH remains, rollback layout rendering and add proper scrolling to the character sheet tabs
This commit is contained in:
parent
df9ae95890
commit
5c1f41b0b7
12
app.vue
12
app.vue
|
|
@ -1,13 +1,11 @@
|
||||||
<template>
|
<template>
|
||||||
<div class="text-light-100 dark:text-dark-100 flex bg-light-0 dark:bg-dark-0 h-screen overflow-hidden">
|
<div class="text-light-100 dark:text-dark-100 flex bg-light-0 dark:bg-dark-0 h-screen overflow-hidden">
|
||||||
<NuxtRouteAnnouncer/>
|
<NuxtRouteAnnouncer/>
|
||||||
<TooltipProvider>
|
<NuxtLayout>
|
||||||
<NuxtLayout>
|
<div class="xl:px-12 xl:py-8 lg:px-8 lg:py-6 px-6 py-3 flex flex-1 justify-center overflow-auto max-h-full max-w-full relative" id="mainContainer">
|
||||||
<div class="xl:px-12 xl:py-8 lg:px-8 lg:py-6 px-6 py-3 flex flex-1 justify-center overflow-auto max-h-full max-w-full relative" id="mainContainer">
|
<NuxtPage />
|
||||||
<NuxtPage />
|
</div>
|
||||||
</div>
|
</NuxtLayout>
|
||||||
</NuxtLayout>
|
|
||||||
</TooltipProvider>
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,68 +1,56 @@
|
||||||
<template>
|
<template>
|
||||||
<CollapsibleRoot class="flex flex-1 flex-col" v-model:open="open">
|
<div class="flex flex-row w-full max-w-full h-full max-h-full" style="--sidebar-width: 300px">
|
||||||
<div class="z-30 flex w-full items-center justify-between border-b border-light-35 dark:border-dark-35 px-2">
|
<div class="bg-light-0 dark:bg-dark-0 w-[var(--sidebar-width)] border-r border-light-30 dark:border-dark-30 flex flex-col gap-2">
|
||||||
<div class="flex items-center px-2 gap-4">
|
<NuxtLink class="flex flex-row items-center justify-center group gap-2 my-2" aria-label="Accueil" :to="{ name: 'index', force: true }">
|
||||||
<CollapsibleTrigger asChild>
|
<Avatar src="/logo.dark.svg" class="dark:block hidden" />
|
||||||
<Button icon class="!bg-transparent group md:hidden">
|
<Avatar src="/logo.light.svg" class="block dark:hidden" />
|
||||||
<Icon class="group-data-[state=open]:hidden" icon="radix-icons:hamburger-menu" />
|
<span class="text-xl font-semibold group-hover:text-light-70 dark:group-hover:text-dark-70">d[any]</span>
|
||||||
<Icon class="group-data-[state=closed]:hidden" icon="radix-icons:cross-1" />
|
</NuxtLink>
|
||||||
</Button>
|
<div class="flex-1 px-2 max-w-full max-h-full overflow-y-auto overflow-x-hidden" ref="treeParent"></div>
|
||||||
</CollapsibleTrigger>
|
<div class="flex flex-col my-4 items-center justify-center gap-1 text-xs text-light-60 dark:text-dark-60">
|
||||||
<NuxtLink class="text-light-100 dark:text-dark-100 hover:text-opacity-70 m-2 flex items-center gap-4" aria-label="Accueil" :to="{ path: '/', force: true }">
|
<NuxtLink class="hover:underline" :to="{ name: 'legal' }">Mentions légales</NuxtLink>
|
||||||
<Avatar src="/logo.dark.svg" class="dark:block hidden" />
|
<NuxtLink class="hover:underline" :to="{ name: 'usage' }">Conditions d'utilisations</NuxtLink>
|
||||||
<Avatar src="/logo.light.svg" class="block dark:hidden" />
|
Copyright Peaceultime - 2025
|
||||||
<span class="text-xl max-md:hidden">d[any]</span>
|
|
||||||
</NuxtLink>
|
|
||||||
</div>
|
</div>
|
||||||
<NavigationMenuRoot class="relative">
|
</div>
|
||||||
<NavigationMenuList class="flex items-center gap-8 max-md:hidden">
|
<div class="flex flex-col flex-1 h-full w-[calc(100vw-var(--sidebar-width))]">
|
||||||
<NavigationMenuItem>
|
<div class="flex flex-row border-b border-light-30 dark:border-dark-30 justify-between px-8">
|
||||||
<NavigationMenuTrigger>
|
<div class="flex flex-row gap-16 items-center">
|
||||||
<NuxtLink :href="{ name: 'character' }" class="text-light-70 dark:text-dark-70 border-b-[2px] border-transparent hover:border-accent-blue py-2 hover:!text-opacity-70 flex items-center" active-class="!text-accent-blue"><span class="px-3 flex-1 truncate">Personnages</span><Icon icon="radix-icons:caret-down" /></NuxtLink>
|
<NavigationMenuRoot class="relative">
|
||||||
</NavigationMenuTrigger>
|
<NavigationMenuList class="flex items-center gap-8 max-md:hidden">
|
||||||
<NavigationMenuContent class="absolute top-0 w-full sm:w-auto bg-light-0 dark:bg-dark-0 border border-light-30 dark:border-dark-30 py-2 z-20 flex flex-col">
|
<NavigationMenuItem>
|
||||||
<NuxtLink :href="{ name: 'character-list' }" class="text-light-70 dark:text-dark-70 hover:bg-light-10 dark:hover:bg-dark-10 hover:text-light-100 dark:hover:text-dark-100 py-2 px-4" active-class="!text-accent-blue"><span class="flex-1 truncate">Personnages publics</span></NuxtLink>
|
<NavigationMenuTrigger>
|
||||||
<NuxtLink :href="{ name: 'character-id-edit', params: { id: 'new' } }" class="text-light-70 dark:text-dark-70 hover:bg-light-10 dark:hover:bg-dark-10 hover:text-light-100 dark:hover:text-dark-100 py-2 px-4" active-class="!text-accent-blue"><span class="flex-1 truncate">Nouveau personnage</span></NuxtLink>
|
<NuxtLink :href="{ name: 'character' }" class="flex flex-row gap-2 items-center border-b-2 border-transparent hover:border-accent-blue py-4 select-none" active-class="!text-accent-blue"><span class="px-3 flex-1 truncate">Personnages</span><Icon icon="radix-icons:caret-down" /></NuxtLink>
|
||||||
</NavigationMenuContent>
|
</NavigationMenuTrigger>
|
||||||
</NavigationMenuItem>
|
<NavigationMenuContent class="absolute top-0 w-full sm:w-auto bg-light-0 dark:bg-dark-0 border border-light-30 dark:border-dark-30 py-2 z-20 flex flex-col">
|
||||||
</NavigationMenuList>
|
<NuxtLink :href="{ name: 'character-list' }" class="hover:bg-light-30 dark:hover:bg-dark-30 px-4 py-2 select-none" active-class="!text-accent-blue"><span class="flex-1 truncate">Personnages publics</span></NuxtLink>
|
||||||
<div class="absolute top-full left-0 flex w-full justify-center">
|
<NuxtLink :href="{ name: 'character-id-edit', params: { id: 'new' } }" class="hover:bg-light-30 dark:hover:bg-dark-30 px-4 py-2 select-none" active-class="!text-accent-blue"><span class="flex-1 truncate">Nouveau personnage</span></NuxtLink>
|
||||||
<NavigationMenuViewport class="h-[var(--radix-navigation-menu-viewport-height)] w-full origin-[top_center] flex justify-center overflow-hidden sm:w-[var(--radix-navigation-menu-viewport-width)]" />
|
</NavigationMenuContent>
|
||||||
</div>
|
</NavigationMenuItem>
|
||||||
</NavigationMenuRoot>
|
</NavigationMenuList>
|
||||||
<div class="flex items-center px-2 gap-4">
|
<div class="absolute top-full left-0 flex w-full justify-center">
|
||||||
<template v-if="!loggedIn">
|
<NavigationMenuViewport class="h-[var(--radix-navigation-menu-viewport-height)] w-full origin-[top_center] flex justify-center overflow-hidden sm:w-[var(--radix-navigation-menu-viewport-width)]" />
|
||||||
<NuxtLink class="text-light-100 dark:text-dark-100 hover:text-light-70 dark:hover:text-dark-70" :to="{ name: 'user-login' }">Se connecter</NuxtLink>
|
|
||||||
<NuxtLink class="text-light-100 dark:text-dark-100 hover:text-light-70 dark:hover:text-dark-70 max-md:hidden" :to="{ name: 'user-register' }">Créer un compte</NuxtLink>
|
|
||||||
</template>
|
|
||||||
<template v-else>
|
|
||||||
<NuxtLink class="text-light-100 dark:text-dark-100 hover:text-light-70 dark:hover:text-dark-70" :to="{ name: 'user-login' }">{{ user!.username }}</NuxtLink>
|
|
||||||
</template>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="flex flex-1 flex-row relative h-screen w-screen overflow-hidden">
|
|
||||||
<!-- <CollapsibleContent asChild forceMount> -->
|
|
||||||
<div class="bg-light-0 dark:bg-dark-0 z-40 w-screen md:w-[18rem] border-r border-light-30 dark:border-dark-30 flex flex-col justify-between my-2 max-md:data-[state=closed]:hidden">
|
|
||||||
<div class="flex-1 px-2 max-w-full max-h-full overflow-y-auto overflow-x-hidden" ref="treeParent">
|
|
||||||
<div v-if="user" class="flex flex-1 py-4 px-2 flex-row flex-1 justify-between items-center">
|
|
||||||
<NuxtLink v-if="hasPermissions(user.permissions, ['admin', 'editor'])" :to="{ name: 'explore-edit' }"><Button icon><Icon icon="radix-icons:pencil-2" /></Button></NuxtLink>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</NavigationMenuRoot>
|
||||||
<div class="xl:px-12 px-6 pt-4 pb-2 text-center text-xs text-light-60 dark:text-dark-60">
|
<NuxtLink :href="{ name: 'character' }" class="flex flex-row gap-2 items-center border-b-2 border-transparent hover:border-accent-blue py-4 select-none" active-class="!text-accent-blue"><span class="px-3 flex-1 truncate">Campagnes</span></NuxtLink>
|
||||||
<NuxtLink class="hover:underline italic" :to="{ name: 'legal' }">Mentions légales</NuxtLink> - <NuxtLink class="hover:underline italic" :to="{ name: 'usage' }">Conditions d'utilisations</NuxtLink>
|
|
||||||
<p>Copyright Peaceultime - 2025</p>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<!-- </CollapsibleContent> -->
|
<div class="flex flex-row gap-16 items-center">
|
||||||
|
<template v-if="!loggedIn">
|
||||||
|
<NuxtLink class="text-light-100 dark:text-dark-100 hover:text-light-70 dark:hover:text-dark-70" :to="{ name: 'user-login' }">Se connecter</NuxtLink>
|
||||||
|
<NuxtLink class="text-light-100 dark:text-dark-100 hover:text-light-70 dark:hover:text-dark-70 max-md:hidden" :to="{ name: 'user-register' }">Créer un compte</NuxtLink>
|
||||||
|
</template>
|
||||||
|
<template v-else>
|
||||||
|
<NuxtLink class="text-light-100 dark:text-dark-100 hover:text-light-70 dark:hover:text-dark-70" :to="{ name: 'user-login' }">{{ user!.username }}</NuxtLink>
|
||||||
|
</template>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<slot></slot>
|
<slot></slot>
|
||||||
</div>
|
</div>
|
||||||
</CollapsibleRoot>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { Icon } from '@iconify/vue/dist/iconify.js';
|
import { Icon } from '@iconify/vue/dist/iconify.js';
|
||||||
import type { DropdownOption } from '~/components/base/DropdownMenu.vue';
|
|
||||||
import { hasPermissions } from '#shared/auth.util';
|
|
||||||
import { TreeDOM } from '#shared/tree';
|
import { TreeDOM } from '#shared/tree';
|
||||||
import { Content, iconByType } from '#shared/content.util';
|
import { Content, iconByType } from '#shared/content.util';
|
||||||
import { dom, icon } from '#shared/dom.util';
|
import { dom, icon } from '#shared/dom.util';
|
||||||
|
|
@ -70,18 +58,8 @@ import { unifySlug } from '#shared/general.util';
|
||||||
import { tooltip } from '#shared/floating.util';
|
import { tooltip } from '#shared/floating.util';
|
||||||
import { link } from '#shared/components.util';
|
import { link } from '#shared/components.util';
|
||||||
|
|
||||||
const options = ref<DropdownOption[]>([{
|
|
||||||
type: 'item',
|
|
||||||
label: 'Mon profil',
|
|
||||||
select: () => useRouter().push({ name: 'user-profile' }),
|
|
||||||
}, {
|
|
||||||
type: 'item',
|
|
||||||
label: 'Deconnexion',
|
|
||||||
select: () => clear(),
|
|
||||||
}]);
|
|
||||||
|
|
||||||
const open = ref(false);
|
const open = ref(false);
|
||||||
const { loggedIn, user, clear } = useUserSession();
|
const { loggedIn, user } = useUserSession();
|
||||||
const { fetch } = useContent();
|
const { fetch } = useContent();
|
||||||
|
|
||||||
await fetch(false);
|
await fetch(false);
|
||||||
|
|
@ -119,9 +97,7 @@ watch(route, () => {
|
||||||
|
|
||||||
onMounted(() => {
|
onMounted(() => {
|
||||||
if(treeParent.value)
|
if(treeParent.value)
|
||||||
{
|
|
||||||
treeParent.value.appendChild(tree.container);
|
treeParent.value.appendChild(tree.container);
|
||||||
}
|
|
||||||
})
|
})
|
||||||
onUnmounted(() => {
|
onUnmounted(() => {
|
||||||
unmount();
|
unmount();
|
||||||
|
|
|
||||||
|
|
@ -164,8 +164,8 @@ async function logout(user: User)
|
||||||
</Head>
|
</Head>
|
||||||
<div class="flex flex-1 flex-col p-4">
|
<div class="flex flex-1 flex-col p-4">
|
||||||
<div class="flex flex-row justify-between items-center">
|
<div class="flex flex-row justify-between items-center">
|
||||||
<ProseH2 class="text-center flex-1">Administration</ProseH2>
|
<h2 class="text-center flex-1 text-2xl font-bold">Administration</h2>
|
||||||
<Button><NuxtLink :to="{ name: 'admin-jobs' }">Jobs</NuxtLink></Button>
|
<NuxtLink :to="{ name: 'admin-jobs' }"><Button>Jobs</Button></NuxtLink>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex flex-1 w-full justify-center items-stretch flex-row gap-4">
|
<div class="flex flex-1 w-full justify-center items-stretch flex-row gap-4">
|
||||||
<div class="flex-1">
|
<div class="flex-1">
|
||||||
|
|
|
||||||
|
|
@ -71,7 +71,7 @@ async function fetch()
|
||||||
<div class="flex flex-col justify-start items-center p-4">
|
<div class="flex flex-col justify-start items-center p-4">
|
||||||
<div class="flex flex-row justify-between items-center gap-8">
|
<div class="flex flex-row justify-between items-center gap-8">
|
||||||
<span class="border border-transparent hover:border-light-35 dark:hover:border-dark-35 p-1 cursor-pointer" @click="() => $router.go(-1)"><Icon icon="radix-icons:arrow-left" class="text-light-50 dark:text-dark-50 w-6 h-6"/></span>
|
<span class="border border-transparent hover:border-light-35 dark:hover:border-dark-35 p-1 cursor-pointer" @click="() => $router.go(-1)"><Icon icon="radix-icons:arrow-left" class="text-light-50 dark:text-dark-50 w-6 h-6"/></span>
|
||||||
<ProseH2 class="text-center flex-1">Administration</ProseH2>
|
<h2 class="text-center flex-1 text-2xl font-bold">Administration</h2>
|
||||||
</div>
|
</div>
|
||||||
<div class="flex flex-row w-full gap-8">
|
<div class="flex flex-row w-full gap-8">
|
||||||
<Select label="Job" v-model="job">
|
<Select label="Job" v-model="job">
|
||||||
|
|
|
||||||
|
|
@ -33,5 +33,5 @@ onMounted(() => {
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div ref="container"></div>
|
<div class="flex flex-1 w-full h-full items-start justify-center" ref="container"></div>
|
||||||
</template>
|
</template>
|
||||||
|
|
@ -3,7 +3,7 @@
|
||||||
<Title>d[any] - Validation de votre adresse mail</Title>
|
<Title>d[any] - Validation de votre adresse mail</Title>
|
||||||
</Head>
|
</Head>
|
||||||
<div class="flex flex-col justify-center items-center">
|
<div class="flex flex-col justify-center items-center">
|
||||||
<ProseH2>Votre compte a été validé ! 🎉</ProseH2>
|
<h2 class="text-2xl font-bold">Votre compte a été validé ! 🎉</h2>
|
||||||
<div class="flex flex-row gap-8">
|
<div class="flex flex-row gap-8">
|
||||||
<Button class="bg-light-25 dark:bg-dark-25"><NuxtLink :to="{ name: 'user-login', replace: true }">Se connecter</NuxtLink></Button>
|
<Button class="bg-light-25 dark:bg-dark-25"><NuxtLink :to="{ name: 'user-login', replace: true }">Se connecter</NuxtLink></Button>
|
||||||
<Button class="bg-light-25 dark:bg-dark-25"><NuxtLink :to="{ name: 'index', replace: true }">Retourner à l'accueil</NuxtLink></Button>
|
<Button class="bg-light-25 dark:bg-dark-25"><NuxtLink :to="{ name: 'index', replace: true }">Retourner à l'accueil</NuxtLink></Button>
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@
|
||||||
<div class="flex flex-1 flex-col justify-center items-center">
|
<div class="flex flex-1 flex-col justify-center items-center">
|
||||||
<div class="flex gap-8 items-center">
|
<div class="flex gap-8 items-center">
|
||||||
<span class="border border-transparent hover:border-light-35 dark:hover:border-dark-35 p-1 cursor-pointer" @click="() => $router.go(-1)"><Icon icon="radix-icons:arrow-left" class="text-light-50 dark:text-dark-50 w-6 h-6"/></span>
|
<span class="border border-transparent hover:border-light-35 dark:hover:border-dark-35 p-1 cursor-pointer" @click="() => $router.go(-1)"><Icon icon="radix-icons:arrow-left" class="text-light-50 dark:text-dark-50 w-6 h-6"/></span>
|
||||||
<ProseH4>Reinitialisation de mon mot de passe</ProseH4>
|
<h4 class="text-xl font-bold">Reinitialisation de mon mot de passe</h4>
|
||||||
</div>
|
</div>
|
||||||
<form @submit.prevent="() => submit()" class="flex flex-1 flex-col justify-center items-stretch">
|
<form @submit.prevent="() => submit()" class="flex flex-1 flex-col justify-center items-stretch">
|
||||||
<TextInput type="text" label="Utilisateur ou email" autocomplete="username" v-model="email"/>
|
<TextInput type="text" label="Utilisateur ou email" autocomplete="username" v-model="email"/>
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@
|
||||||
<div class="flex flex-1 flex-col justify-center items-center">
|
<div class="flex flex-1 flex-col justify-center items-center">
|
||||||
<div class="flex gap-8 items-center">
|
<div class="flex gap-8 items-center">
|
||||||
<span class="border border-transparent hover:border-light-35 dark:hover:border-dark-35 p-1 cursor-pointer" @click="() => $router.go(-1)"><Icon icon="radix-icons:arrow-left" class="text-light-50 dark:text-dark-50 w-6 h-6"/></span>
|
<span class="border border-transparent hover:border-light-35 dark:hover:border-dark-35 p-1 cursor-pointer" @click="() => $router.go(-1)"><Icon icon="radix-icons:arrow-left" class="text-light-50 dark:text-dark-50 w-6 h-6"/></span>
|
||||||
<ProseH4>Reinitialisation de mon mot de passe</ProseH4>
|
<h4 class="text-center flex-1 text-xl font-bold">Reinitialisation de mon mot de passe</h4>
|
||||||
</div>
|
</div>
|
||||||
<form @submit.prevent="submit" class="flex flex-1 flex-col justify-center items-stretch">
|
<form @submit.prevent="submit" class="flex flex-1 flex-col justify-center items-stretch">
|
||||||
<TextInput type="password" label="Nouveau mot de passe" autocomplete="newPassword" v-model="newPasswd" :class="{ '!border-light-red !dark:border-dark-red': error }"/>
|
<TextInput type="password" label="Nouveau mot de passe" autocomplete="newPassword" v-model="newPasswd" :class="{ '!border-light-red !dark:border-dark-red': error }"/>
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@
|
||||||
<div class="flex flex-1 flex-col justify-center items-center">
|
<div class="flex flex-1 flex-col justify-center items-center">
|
||||||
<div class="flex gap-8 items-center">
|
<div class="flex gap-8 items-center">
|
||||||
<span class="border border-transparent hover:border-light-35 dark:hover:border-dark-35 p-1 cursor-pointer" @click="() => $router.go(-1)"><Icon icon="radix-icons:arrow-left" class="text-light-50 dark:text-dark-50 w-6 h-6"/></span>
|
<span class="border border-transparent hover:border-light-35 dark:hover:border-dark-35 p-1 cursor-pointer" @click="() => $router.go(-1)"><Icon icon="radix-icons:arrow-left" class="text-light-50 dark:text-dark-50 w-6 h-6"/></span>
|
||||||
<ProseH4>Modification de mon mot de passe</ProseH4>
|
<h4 class="text-center flex-1 text-xl font-bold">Modification de mon mot de passe</h4>
|
||||||
</div>
|
</div>
|
||||||
<form @submit.prevent="submit" class="flex flex-1 flex-col justify-center items-stretch">
|
<form @submit.prevent="submit" class="flex flex-1 flex-col justify-center items-stretch">
|
||||||
<TextInput type="password" label="Ancien mot de passe" name="old-password" autocomplete="current-password" v-model="oldPasswd"/>
|
<TextInput type="password" label="Ancien mot de passe" name="old-password" autocomplete="current-password" v-model="oldPasswd"/>
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@
|
||||||
<div class="flex flex-1 flex-col justify-center items-center">
|
<div class="flex flex-1 flex-col justify-center items-center">
|
||||||
<div class="flex gap-8 items-center">
|
<div class="flex gap-8 items-center">
|
||||||
<span class="border border-transparent hover:border-light-35 dark:hover:border-dark-35 p-1 cursor-pointer" @click="() => $router.go(-1)"><Icon icon="radix-icons:arrow-left" class="text-light-50 dark:text-dark-50 w-6 h-6"/></span>
|
<span class="border border-transparent hover:border-light-35 dark:hover:border-dark-35 p-1 cursor-pointer" @click="() => $router.go(-1)"><Icon icon="radix-icons:arrow-left" class="text-light-50 dark:text-dark-50 w-6 h-6"/></span>
|
||||||
<ProseH4>Connexion</ProseH4>
|
<h4 class="text-xl font-bold">Connexion</h4>
|
||||||
</div>
|
</div>
|
||||||
<form @submit.prevent="() => submit()" class="flex flex-1 flex-col justify-center items-stretch">
|
<form @submit.prevent="() => submit()" class="flex flex-1 flex-col justify-center items-stretch">
|
||||||
<TextInput type="text" label="Utilisateur ou email" name="username" autocomplete="username email" v-model="state.usernameOrEmail"/>
|
<TextInput type="text" label="Utilisateur ou email" name="username" autocomplete="username email" v-model="state.usernameOrEmail"/>
|
||||||
|
|
|
||||||
|
|
@ -38,8 +38,8 @@ async function deleteUser()
|
||||||
<div class="flex gap-4">
|
<div class="flex gap-4">
|
||||||
<Avatar icon="radix-icons:person" :src="`/users/${user?.id}.medium.jpg`" class="w-32 h-32" />
|
<Avatar icon="radix-icons:person" :src="`/users/${user?.id}.medium.jpg`" class="w-32 h-32" />
|
||||||
<div class="flex flex-col items-start">
|
<div class="flex flex-col items-start">
|
||||||
<ProseH5>{{ user.username }}</ProseH5>
|
<h4 class="text-xl font-bold">{{ user.username }}</h4>
|
||||||
<ProseH5>{{ user.email }}</ProseH5>
|
<h4 class="text-xl font-bold">{{ user.email }}</h4>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="border-light-red dark:border-dark-red bg-light-redBack dark:bg-dark-redBack text-light-red dark:text-dark-red py-1 px-3 flex items-center justify-between flex-col md:flex-row"
|
<div class="border-light-red dark:border-dark-red bg-light-redBack dark:bg-dark-redBack text-light-red dark:text-dark-red py-1 px-3 flex items-center justify-between flex-col md:flex-row"
|
||||||
|
|
|
||||||
|
|
@ -5,7 +5,7 @@
|
||||||
<div class="flex flex-1 flex-col justify-center items-center">
|
<div class="flex flex-1 flex-col justify-center items-center">
|
||||||
<div class="flex gap-8 items-center">
|
<div class="flex gap-8 items-center">
|
||||||
<span class="border border-transparent hover:border-light-35 dark:hover:border-dark-35 p-1 cursor-pointer" @click="() => $router.go(-1)"><Icon icon="radix-icons:arrow-left" class="text-light-50 dark:text-dark-50 w-6 h-6"/></span>
|
<span class="border border-transparent hover:border-light-35 dark:hover:border-dark-35 p-1 cursor-pointer" @click="() => $router.go(-1)"><Icon icon="radix-icons:arrow-left" class="text-light-50 dark:text-dark-50 w-6 h-6"/></span>
|
||||||
<ProseH4>Inscription</ProseH4>
|
<h4 class="text-xl font-bold">Inscription</h4>
|
||||||
</div>
|
</div>
|
||||||
<form @submit.prevent="() => submit()" class="grid flex-1 p-4 grid-cols-2 md:grid-cols-1 gap-4 md:gap-0">
|
<form @submit.prevent="() => submit()" class="grid flex-1 p-4 grid-cols-2 md:grid-cols-1 gap-4 md:gap-0">
|
||||||
<TextInput type="text" label="Nom d'utilisateur" name="username" autocomplete="username" v-model="state.username" class="w-full md:w-auto"/>
|
<TextInput type="text" label="Nom d'utilisateur" name="username" autocomplete="username" v-model="state.username" class="w-full md:w-auto"/>
|
||||||
|
|
|
||||||
|
|
@ -8,6 +8,71 @@ import { preview } from "#shared/proses";
|
||||||
import { SpatialGrid } from "#shared/physics.util";
|
import { SpatialGrid } from "#shared/physics.util";
|
||||||
import type { CanvasPreferences } from "~/types/general";
|
import type { CanvasPreferences } from "~/types/general";
|
||||||
|
|
||||||
|
/*
|
||||||
|
|
||||||
|
stroke-light-red
|
||||||
|
stroke-light-orange
|
||||||
|
stroke-light-yellow
|
||||||
|
stroke-light-green
|
||||||
|
stroke-light-cyan
|
||||||
|
stroke-light-purple
|
||||||
|
dark:stroke-dark-red
|
||||||
|
dark:stroke-dark-orange
|
||||||
|
dark:stroke-dark-yellow
|
||||||
|
dark:stroke-dark-green
|
||||||
|
dark:stroke-dark-cyan
|
||||||
|
dark:stroke-dark-purple
|
||||||
|
fill-light-red
|
||||||
|
fill-light-orange
|
||||||
|
fill-light-yellow
|
||||||
|
fill-light-green
|
||||||
|
fill-light-cyan
|
||||||
|
fill-light-purple
|
||||||
|
dark:fill-dark-red
|
||||||
|
dark:fill-dark-orange
|
||||||
|
dark:fill-dark-yellow
|
||||||
|
dark:fill-dark-green
|
||||||
|
dark:fill-dark-cyan
|
||||||
|
dark:fill-dark-purple
|
||||||
|
bg-light-red
|
||||||
|
bg-light-orange
|
||||||
|
bg-light-yellow
|
||||||
|
bg-light-green
|
||||||
|
bg-light-cyan
|
||||||
|
bg-light-purple
|
||||||
|
dark:bg-dark-red
|
||||||
|
dark:bg-dark-orange
|
||||||
|
dark:bg-dark-yellow
|
||||||
|
dark:bg-dark-green
|
||||||
|
dark:bg-dark-cyan
|
||||||
|
dark:bg-dark-purple
|
||||||
|
border-light-red
|
||||||
|
border-light-orange
|
||||||
|
border-light-yellow
|
||||||
|
border-light-green
|
||||||
|
border-light-cyan
|
||||||
|
border-light-purple
|
||||||
|
dark:border-dark-red
|
||||||
|
dark:border-dark-orange
|
||||||
|
dark:border-dark-yellow
|
||||||
|
dark:border-dark-green
|
||||||
|
dark:border-dark-cyan
|
||||||
|
dark:border-dark-purple
|
||||||
|
outline-light-red
|
||||||
|
outline-light-orange
|
||||||
|
outline-light-yellow
|
||||||
|
outline-light-green
|
||||||
|
outline-light-cyan
|
||||||
|
outline-light-purple
|
||||||
|
dark:outline-dark-red
|
||||||
|
dark:outline-dark-orange
|
||||||
|
dark:outline-dark-yellow
|
||||||
|
dark:outline-dark-green
|
||||||
|
dark:outline-dark-cyan
|
||||||
|
dark:outline-dark-purple
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
export type Direction = 'bottom' | 'top' | 'left' | 'right';
|
export type Direction = 'bottom' | 'top' | 'left' | 'right';
|
||||||
export type Position = { x: number, y: number };
|
export type Position = { x: number, y: number };
|
||||||
export type Box = Position & { width: number, height: number };
|
export type Box = Position & { width: number, height: number };
|
||||||
|
|
@ -417,6 +482,8 @@ export class Canvas
|
||||||
]),
|
]),
|
||||||
]), this.transform,
|
]), this.transform,
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
console.log(this.nodes.length, this.edges.length);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected computeLimits()
|
protected computeLimits()
|
||||||
|
|
@ -467,11 +534,11 @@ export class Canvas
|
||||||
this.firstX = pos.x;
|
this.firstX = pos.x;
|
||||||
this.firstY = pos.y;
|
this.firstY = pos.y;
|
||||||
|
|
||||||
window.addEventListener('mouseup', dragEnd, { passive: true });
|
window.addEventListener('mouseup', dragEnd);
|
||||||
window.addEventListener('mousemove', dragMove, { passive: true });
|
window.addEventListener('mousemove', dragMove);
|
||||||
|
|
||||||
this.dragStart(e);
|
this.dragStart(e);
|
||||||
}, { passive: true });
|
});
|
||||||
this.container.addEventListener('wheel', (e) => {
|
this.container.addEventListener('wheel', (e) => {
|
||||||
if((this._zoom >= Canvas.maxZoom && e.deltaY < 0) || (this._zoom <= this.containZoom && e.deltaY > 0))
|
if((this._zoom >= Canvas.maxZoom && e.deltaY < 0) || (this._zoom <= this.containZoom && e.deltaY > 0))
|
||||||
return;
|
return;
|
||||||
|
|
@ -490,10 +557,10 @@ export class Canvas
|
||||||
this.lastDistance = distance(e.touches);
|
this.lastDistance = distance(e.touches);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.container.addEventListener('touchend', touchend, { passive: true });
|
this.container.addEventListener('touchend', touchend);
|
||||||
this.container.addEventListener('touchcancel', touchcancel, { passive: true });
|
this.container.addEventListener('touchcancel', touchcancel);
|
||||||
this.container.addEventListener('touchmove', touchmove, { passive: true });
|
this.container.addEventListener('touchmove', touchmove);
|
||||||
}, { passive: true });
|
});
|
||||||
const touchend = (e: TouchEvent) => {
|
const touchend = (e: TouchEvent) => {
|
||||||
if(e.touches.length > 1)
|
if(e.touches.length > 1)
|
||||||
{
|
{
|
||||||
|
|
|
||||||
|
|
@ -406,7 +406,7 @@ export class CharacterCompiler
|
||||||
if(feature.action === 'add' && !this._result.lists[feature.list]!.includes(feature.item))
|
if(feature.action === 'add' && !this._result.lists[feature.list]!.includes(feature.item))
|
||||||
this._result.lists[feature.list]!.push(feature.item);
|
this._result.lists[feature.list]!.push(feature.item);
|
||||||
else if(feature.action === 'remove')
|
else if(feature.action === 'remove')
|
||||||
this._result.lists[feature.list] = this._result.lists[feature.list]!.splice(this._result.lists[feature.list]!.findIndex((e: string) => e !== feature.item), 1);
|
this._result.lists[feature.list]!.splice(this._result.lists[feature.list]!.findIndex((e: string) => e === feature.item), 1);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
case "value":
|
case "value":
|
||||||
|
|
@ -443,7 +443,7 @@ export class CharacterCompiler
|
||||||
if(feature.action === 'remove' && !this._result.lists[feature.list]!.includes(feature.item))
|
if(feature.action === 'remove' && !this._result.lists[feature.list]!.includes(feature.item))
|
||||||
this._result.lists[feature.list]!.push(feature.item);
|
this._result.lists[feature.list]!.push(feature.item);
|
||||||
else if(feature.action === 'add')
|
else if(feature.action === 'add')
|
||||||
this._result.lists[feature.list] = this._result.lists[feature.list]!.splice(this._result.lists[feature.list]!.findIndex((e: string) => e !== feature.item), 1)
|
this._result.lists[feature.list]!.splice(this._result.lists[feature.list]!.findIndex((e: string) => e === feature.item), 1)
|
||||||
|
|
||||||
return;
|
return;
|
||||||
case "value":
|
case "value":
|
||||||
|
|
@ -1233,7 +1233,7 @@ export class CharacterSheet
|
||||||
{
|
{
|
||||||
user: ComputedRef<User | null>;
|
user: ComputedRef<User | null>;
|
||||||
character?: CharacterCompiler;
|
character?: CharacterCompiler;
|
||||||
container: HTMLElement = div();
|
container: HTMLElement = div('flex flex-1 h-full w-full items-start justify-center');
|
||||||
tabs?: HTMLDivElement & { refresh: () => void };
|
tabs?: HTMLDivElement & { refresh: () => void };
|
||||||
constructor(id: string, user: ComputedRef<User | null>)
|
constructor(id: string, user: ComputedRef<User | null>)
|
||||||
{
|
{
|
||||||
|
|
@ -1296,8 +1296,8 @@ export class CharacterSheet
|
||||||
div('flex flex-col gap-2', [ span('text-lg font-bold', 'Notes privés'), div('border border-light-35 dark:border-dark-35 p-1', [ privateNotes.dom ]) ]),
|
div('flex flex-col gap-2', [ span('text-lg font-bold', 'Notes privés'), div('border border-light-35 dark:border-dark-35 p-1', [ privateNotes.dom ]) ]),
|
||||||
])
|
])
|
||||||
] },
|
] },
|
||||||
], { focused: 'abilities', class: { container: 'flex-1 gap-4 px-4 w-[960px]' } });
|
], { focused: 'abilities', class: { container: 'flex-1 gap-4 px-4 w-[960px] h-full', content: 'overflow-auto' } });
|
||||||
this.container.replaceChildren(div('flex flex-col justify-center gap-1', [
|
this.container.replaceChildren(div('flex flex-col justify-start gap-1 h-full', [
|
||||||
div("flex flex-row gap-4 justify-between", [
|
div("flex flex-row gap-4 justify-between", [
|
||||||
div(),
|
div(),
|
||||||
|
|
||||||
|
|
@ -1420,7 +1420,7 @@ export class CharacterSheet
|
||||||
]),
|
]),
|
||||||
]),
|
]),
|
||||||
|
|
||||||
div("flex flex-1 flex-row items-stretch justify-center py-2 gap-4", [
|
div("flex flex-1 flex-row items-stretch justify-center py-2 gap-4 h-0", [
|
||||||
div("flex flex-col gap-4 py-1 w-60", [
|
div("flex flex-col gap-4 py-1 w-60", [
|
||||||
div("flex flex-col py-1 gap-4", [
|
div("flex flex-col py-1 gap-4", [
|
||||||
div("flex flex-row items-center justify-center gap-4", [
|
div("flex flex-row items-center justify-center gap-4", [
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue