feat: implémentation complète du système Célestopol 1922 pour FoundryVTT v13
- DataModels (character, npc, anomaly, aspect, attribute, equipment) - ApplicationV2 sheets (character 5 tabs, npc 3 tabs, 4 item sheets) - DialogV2 pour les jets de dés avec phase de lune - Templates Handlebars complets (fiches PJ/PNJ, items, jet, chat) - Styles LESS → CSS compilé (thème vert foncé / orange CopaseticNF) - i18n fr.json complet (clés CELESTOPOL.*) - Point d'entrée fvtt-celestopol.mjs avec hooks init/ready - Assets : polices CopaseticNF, images UI, icônes items - Mise à jour copilot-instructions.md avec l'architecture réelle Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
This commit is contained in:
241
styles/character.less
Normal file
241
styles/character.less
Normal file
@@ -0,0 +1,241 @@
|
||||
@import "mixins";
|
||||
|
||||
// ─── Character sheet specifics ───────────────────────────────────────────────
|
||||
|
||||
.celestopol.character-sheet {
|
||||
|
||||
// Attributs perso (Entregent, Fortune, Rêve, Vision)
|
||||
.perso-attributs {
|
||||
display: flex;
|
||||
gap: 8px;
|
||||
flex-wrap: wrap;
|
||||
margin-top: 4px;
|
||||
|
||||
.perso-attr {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
align-items: center;
|
||||
background: rgba(0,0,0,0.25);
|
||||
border: 1px solid var(--cel-orange);
|
||||
border-radius: 4px;
|
||||
padding: 4px 8px;
|
||||
min-width: 60px;
|
||||
|
||||
label {
|
||||
font-size: 0.6em;
|
||||
text-transform: uppercase;
|
||||
color: var(--cel-orange-light);
|
||||
}
|
||||
|
||||
.attr-display, .attr-val, .attr-max {
|
||||
color: var(--cel-orange);
|
||||
font-family: var(--cel-font-title);
|
||||
font-size: 1em;
|
||||
font-weight: bold;
|
||||
}
|
||||
|
||||
input.attr-val, input.attr-max {
|
||||
width: 28px;
|
||||
text-align: center;
|
||||
background: transparent;
|
||||
border: none;
|
||||
border-bottom: 1px solid var(--cel-orange-light);
|
||||
color: var(--cel-orange);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Stats × Compétences grid
|
||||
.stats-grid {
|
||||
display: grid;
|
||||
grid-template-columns: 1fr 1fr;
|
||||
gap: 12px;
|
||||
padding: 8px 0;
|
||||
|
||||
.stat-block {
|
||||
border: 1px solid var(--cel-border);
|
||||
border-radius: 4px;
|
||||
overflow: hidden;
|
||||
|
||||
.stat-header {
|
||||
background: var(--cel-green);
|
||||
color: var(--cel-orange);
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
padding: 4px 8px;
|
||||
|
||||
.stat-name {
|
||||
font-family: var(--cel-font-title);
|
||||
font-weight: bold;
|
||||
font-size: 1em;
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 0.05em;
|
||||
}
|
||||
|
||||
.stat-res {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 4px;
|
||||
font-size: 0.8em;
|
||||
|
||||
label { color: var(--cel-orange-light); }
|
||||
input[type="number"] { width: 30px; .cel-input-std(); }
|
||||
.stat-res-value {
|
||||
font-size: 1.3em;
|
||||
font-weight: bold;
|
||||
min-width: 24px;
|
||||
text-align: center;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.skills-list {
|
||||
background: var(--cel-cream);
|
||||
|
||||
.skill-row {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: space-between;
|
||||
padding: 3px 8px;
|
||||
border-bottom: 1px solid rgba(139,115,85,0.2);
|
||||
font-size: 0.85em;
|
||||
|
||||
&.rollable { .cel-rollable(); }
|
||||
|
||||
.skill-name { flex: 1; }
|
||||
.skill-value {
|
||||
font-weight: bold;
|
||||
min-width: 24px;
|
||||
text-align: center;
|
||||
color: var(--cel-green);
|
||||
}
|
||||
.skill-value-input {
|
||||
width: 36px;
|
||||
.cel-input-std();
|
||||
text-align: center;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Items (anomalies, aspects, attributs)
|
||||
.items-section {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
gap: 8px;
|
||||
padding: 8px 0;
|
||||
|
||||
.items-group {
|
||||
.items-header {
|
||||
.cel-section-header();
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
a { color: var(--cel-orange); cursor: pointer; }
|
||||
}
|
||||
|
||||
.item-row { .cel-item-row(); }
|
||||
}
|
||||
}
|
||||
|
||||
// Tracks (Blessures, Destin, Spleen)
|
||||
.track-section {
|
||||
border: 1px solid var(--cel-border);
|
||||
border-radius: 4px;
|
||||
margin-bottom: 12px;
|
||||
overflow: hidden;
|
||||
|
||||
.track-header {
|
||||
background: var(--cel-green);
|
||||
color: var(--cel-orange);
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
padding: 4px 8px;
|
||||
|
||||
.track-title {
|
||||
font-family: var(--cel-font-title);
|
||||
font-weight: bold;
|
||||
text-transform: uppercase;
|
||||
font-size: 0.9em;
|
||||
}
|
||||
}
|
||||
|
||||
.track-boxes {
|
||||
display: flex;
|
||||
padding: 8px;
|
||||
gap: 8px;
|
||||
flex-wrap: wrap;
|
||||
background: var(--cel-cream);
|
||||
|
||||
.track-box {
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
align-items: center;
|
||||
gap: 2px;
|
||||
|
||||
input[type="checkbox"] { .cel-box(); }
|
||||
.box-label {
|
||||
font-size: 0.65em;
|
||||
color: var(--cel-border);
|
||||
}
|
||||
|
||||
&.checked input[type="checkbox"] {
|
||||
accent-color: var(--cel-orange);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
.track-level {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
gap: 6px;
|
||||
padding: 4px 8px;
|
||||
background: rgba(139,115,85,0.1);
|
||||
font-size: 0.85em;
|
||||
label { color: var(--cel-border); }
|
||||
input[type="number"] { width: 40px; .cel-input-std(); }
|
||||
}
|
||||
}
|
||||
|
||||
// Factions table
|
||||
.factions-table {
|
||||
width: 100%;
|
||||
border-collapse: collapse;
|
||||
font-size: 0.9em;
|
||||
|
||||
thead tr {
|
||||
background: var(--cel-green);
|
||||
color: var(--cel-orange);
|
||||
th { padding: 4px 8px; font-family: var(--cel-font-title); }
|
||||
}
|
||||
|
||||
.faction-row {
|
||||
&:nth-child(odd) td { background: rgba(139,115,85,0.08); }
|
||||
td { padding: 4px 8px; border-bottom: 1px solid rgba(139,115,85,0.2); }
|
||||
&.custom td { font-style: italic; color: #666; }
|
||||
|
||||
.faction-value input[type="number"] {
|
||||
width: 50px;
|
||||
.cel-input-std();
|
||||
text-align: center;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Biography / Equipment
|
||||
.equipments-section {
|
||||
margin-bottom: 12px;
|
||||
.section-header { .cel-section-header(); display: flex; justify-content: space-between; }
|
||||
.item-row { .cel-item-row(); }
|
||||
.item-qty { font-size: 0.8em; color: var(--cel-border); }
|
||||
}
|
||||
|
||||
.biography-section, .notes-section {
|
||||
margin-bottom: 12px;
|
||||
.section-header { .cel-section-header(); }
|
||||
.enriched-html { font-size: 0.9em; line-height: 1.6; }
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user