Refonte design : 4 humeurs, onboarding, sections avec boite a outils

- Systeme de themes adaptatifs : Peps (light chaud), Zen (light calme),
  Chagrine (dark violet), Grave (dark ambre) avec CSS custom properties
- Dashboard d'accueil orienté onboarding avec cartes-portes et teaser
  boite a outils
- SectionLayout reutilisable : liste + sidebar toolbox + status pills
  cliquables (En prepa / En vote / En vigueur / Clos)
- ToolboxVignette : vignettes Contexte / Tutos / Choisir / Demarrer
- Seed : Acte engagement certification + forgeron, Runtime Upgrade
  (decision on-chain), 3 modalites de vote (majoritaire, quadratique,
  permanent)
- Backend adapte SQLite (Uuid portable, 204 fix, pool conditionnel)
- Correction noms composants (pathPrefix: false), pinia/nuxt ^0.11

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
Yvv
2026-02-28 17:44:48 +01:00
parent 403b94fa2c
commit 77dceb49c3
49 changed files with 20628 additions and 1180 deletions

View File

@@ -105,7 +105,7 @@ async function archiveToSanctuary() {
<UBadge variant="subtle" color="primary">
{{ typeLabel(documents.current.doc_type) }}
</UBadge>
<CommonStatusBadge :status="documents.current.status" type="document" />
<StatusBadge :status="documents.current.status" type="document" />
<span class="text-sm text-gray-500 font-mono">
v{{ documents.current.version }}
</span>
@@ -155,7 +155,7 @@ async function archiveToSanctuary() {
<div>
<p class="text-gray-500">Ancrage IPFS</p>
<div class="mt-1">
<SanctuaryIPFSLink :cid="documents.current.ipfs_cid" />
<IPFSLink :cid="documents.current.ipfs_cid" />
</div>
</div>
</div>
@@ -164,7 +164,7 @@ async function archiveToSanctuary() {
<div v-if="documents.current.chain_anchor" class="mt-4 pt-4 border-t border-gray-100 dark:border-gray-800">
<div class="flex items-center gap-2">
<p class="text-sm text-gray-500">Ancrage on-chain :</p>
<SanctuaryChainAnchor :tx-hash="documents.current.chain_anchor" :block="null" />
<ChainAnchor :tx-hash="documents.current.chain_anchor" :block="null" />
</div>
</div>
</UCard>
@@ -181,7 +181,7 @@ async function archiveToSanctuary() {
</div>
<div v-else class="space-y-4">
<DocumentsItemCard
<ItemCard
v-for="item in documents.items"
:key="item.id"
:item="item"