- DataModel : renommage value→level (1-4), ajout usesRemaining (0-4), suppression scores/notes - Config : ajout ANOMALY_DEFINITIONS avec compétences applicables par type (8 anomalies) - Fiche item anomalie : header avec level/uses visuels (dots), barre de compétences applicables, 2 onglets Description + Technique/Narratif (suppression onglet Scores) - Fiche PJ onglet Domaines : bloc anomalie proéminent unique avec: - Nom + sous-type + icône - Dots niveau (●●○○) - Dots usages + bouton Utiliser + bouton Réinitialiser - Chips des domaines applicables - Actions : useAnomaly (décrémente usesRemaining), resetAnomalyUses (reset au niveau) - Contrainte : max 1 anomalie par personnage (drop + createAnomaly) - Helpers HBS : lte, gte, lt ajoutés - i18n : nouvelles clés Anomaly.* (level, usesRemaining, use, resetUses, etc.) - CSS : .anomaly-block sur fiche PJ, dots animés, .anomaly-uses-row sur fiche item Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>
179 lines
8.1 KiB
Handlebars
179 lines
8.1 KiB
Handlebars
<div class="tab competences {{tab.cssClass}}" data-group="sheet" data-tab="competences">
|
||
{{!-- Grille des 4 stats × 4 domaines --}}
|
||
<div class="stats-grid">
|
||
{{#each stats as |stat statId|}}
|
||
<div class="stat-block">
|
||
<div class="stat-header">
|
||
<span class="stat-name">{{localize stat.label}}</span>
|
||
<div class="stat-res">
|
||
<label>{{localize "CELESTOPOL.Stat.res"}}</label>
|
||
{{#if ../isEditMode}}
|
||
<input type="number" name="system.stats.{{statId}}.res" value="{{lookup (lookup ../system.stats statId) 'res'}}" min="0" max="8" class="stat-res-input">
|
||
{{else}}
|
||
<span class="stat-res-value">{{lookup (lookup ../system.stats statId) 'res'}}</span>
|
||
{{/if}}
|
||
</div>
|
||
</div>
|
||
<div class="skills-list">
|
||
{{#each (lookup ../skills statId) as |skill skillId|}}
|
||
{{#if @root.isEditMode}}
|
||
<div class="skill-row edit-mode" data-stat-id="{{statId}}" data-skill-id="{{skillId}}">
|
||
<span class="skill-name">{{localize skill.label}}</span>
|
||
<div class="skill-checkboxes-container">
|
||
<div class="skill-checkboxes">
|
||
{{#each (array 1 2 3 4 5 6 7 8) as |level|}}
|
||
<label class="skill-checkbox-wrapper">
|
||
<input type="checkbox" name="system.stats.{{statId}}.{{skillId}}.level{{level}}"
|
||
{{#if (lookup (lookup (lookup @root.system.stats statId) skillId) (concat 'level' level))}}checked{{/if}}
|
||
class="skill-level-checkbox">
|
||
</label>
|
||
{{/each}}
|
||
</div>
|
||
</div>
|
||
<input type="number" name="system.stats.{{statId}}.{{skillId}}.value"
|
||
value="{{lookup (lookup @root.system.stats statId) skillId 'value'}}"
|
||
min="0" max="8" class="skill-value-input">
|
||
</div>
|
||
{{else}}
|
||
<div class="skill-row rollable" data-stat-id="{{statId}}" data-skill-id="{{skillId}}"
|
||
title="{{localize 'CELESTOPOL.Roll.clickToRoll'}}">
|
||
<span class="skill-name">{{localize skill.label}}</span>
|
||
<div class="skill-checkboxes-container">
|
||
<div class="skill-checkboxes">
|
||
{{#each (array 1 2 3 4 5 6 7 8) as |level|}}
|
||
<label class="skill-checkbox-wrapper">
|
||
<input type="checkbox"
|
||
{{#if (lookup (lookup (lookup @root.system.stats statId) skillId) (concat 'level' level))}}checked{{/if}}
|
||
disabled class="skill-level-checkbox">
|
||
</label>
|
||
{{/each}}
|
||
</div>
|
||
</div>
|
||
<span class="skill-value">{{lookup (lookup @root.system.stats statId) skillId 'value'}}</span>
|
||
</div>
|
||
{{/if}}
|
||
{{/each}}
|
||
</div>
|
||
</div>
|
||
{{/each}}
|
||
</div>
|
||
|
||
{{!-- Items : Anomalie (unique), Aspects, Attributs --}}
|
||
<div class="items-section">
|
||
{{!-- Anomalie : bloc proéminent unique --}}
|
||
<div class="anomaly-block">
|
||
<div class="anomaly-block-header">
|
||
<span class="anomaly-block-title">{{localize "CELESTOPOL.Item.anomaly"}}</span>
|
||
{{#if isEditMode}}
|
||
{{#unless anomaly}}
|
||
<a data-action="createAnomaly" title="{{localize 'CELESTOPOL.Item.newAnomaly'}}"><i class="fas fa-plus"></i></a>
|
||
{{/unless}}
|
||
{{/if}}
|
||
</div>
|
||
{{#if anomaly}}
|
||
<div class="anomaly-content" data-item-id="{{anomaly.id}}" data-item-uuid="{{anomaly.uuid}}" data-drag="true">
|
||
<div class="anomaly-info-row">
|
||
<img src="{{anomaly.img}}" class="anomaly-icon" alt="{{anomaly.name}}">
|
||
<div class="anomaly-details">
|
||
<div class="anomaly-name">{{anomaly.name}}</div>
|
||
<div class="anomaly-subtype">{{localize (lookup (lookup anomalyTypes anomaly.system.subtype) 'label')}}</div>
|
||
</div>
|
||
<div class="anomaly-controls">
|
||
<a data-action="edit" data-item-uuid="{{anomaly.uuid}}"><i class="fas fa-edit"></i></a>
|
||
{{#if isEditMode}}<a data-action="delete" data-item-uuid="{{anomaly.uuid}}"><i class="fas fa-trash"></i></a>{{/if}}
|
||
</div>
|
||
</div>
|
||
<div class="anomaly-level-row">
|
||
<span class="anomaly-level-label">{{localize "CELESTOPOL.Anomaly.level"}} :</span>
|
||
<div class="anomaly-level-dots">
|
||
{{#each (array 1 2 3 4) as |n|}}
|
||
<span class="anomaly-level-dot {{#if (lte n ../anomaly.system.level)}}active{{else}}inactive{{/if}}"></span>
|
||
{{/each}}
|
||
</div>
|
||
</div>
|
||
<div class="anomaly-uses-row">
|
||
<span class="anomaly-uses-label">{{localize "CELESTOPOL.Anomaly.usesRemaining"}} :</span>
|
||
<div class="anomaly-uses-dots">
|
||
{{#each (array 1 2 3 4) as |n|}}
|
||
{{#if (lte n ../anomaly.system.usesRemaining)}}
|
||
<span class="anomaly-dot available"></span>
|
||
{{else}}
|
||
{{#if (lte n ../anomaly.system.level)}}
|
||
<span class="anomaly-dot spent"></span>
|
||
{{else}}
|
||
<span class="anomaly-dot inactive"></span>
|
||
{{/if}}
|
||
{{/if}}
|
||
{{/each}}
|
||
</div>
|
||
<button class="anomaly-use-btn" data-action="useAnomaly" data-item-id="{{anomaly.id}}"
|
||
title="{{localize 'CELESTOPOL.Anomaly.use'}}"
|
||
{{#unless (gt anomaly.system.usesRemaining 0)}}disabled{{/unless}}>
|
||
<i class="fas fa-bolt"></i> {{localize "CELESTOPOL.Anomaly.use"}}
|
||
</button>
|
||
<a class="anomaly-reset-btn" data-action="resetAnomalyUses" data-item-id="{{anomaly.id}}"
|
||
title="{{localize 'CELESTOPOL.Anomaly.resetUses'}}">
|
||
<i class="fas fa-rotate-right"></i>
|
||
</a>
|
||
</div>
|
||
{{#if anomalySkillLabels.length}}
|
||
<div class="anomaly-skills">
|
||
<span class="anomaly-skills-label">{{localize "CELESTOPOL.Anomaly.applicableSkills"}} :</span>
|
||
{{#each anomalySkillLabels as |label|}}
|
||
<span class="anomaly-skill-chip">{{label}}</span>
|
||
{{/each}}
|
||
</div>
|
||
{{/if}}
|
||
</div>
|
||
{{else}}
|
||
<div class="anomaly-empty">
|
||
<i class="fas fa-ghost"></i>
|
||
<span>{{localize "CELESTOPOL.Anomaly.noAnomaly"}}</span>
|
||
</div>
|
||
{{/if}}
|
||
</div>
|
||
|
||
{{!-- Aspects --}}
|
||
<div class="items-group">
|
||
<div class="items-header">
|
||
<span>{{localize "CELESTOPOL.Item.aspects"}}</span>
|
||
{{#if isEditMode}}
|
||
<a data-action="createAspect" title="{{localize 'CELESTOPOL.Item.newAspect'}}"><i class="fas fa-plus"></i></a>
|
||
{{/if}}
|
||
</div>
|
||
{{#each aspects as |item|}}
|
||
<div class="item-row" data-item-id="{{item.id}}" data-item-uuid="{{item.uuid}}" data-drag="true">
|
||
<img src="{{item.img}}" class="item-icon" alt="{{item.name}}">
|
||
<span class="item-name">{{item.name}}</span>
|
||
<span class="item-value">{{item.system.value}}</span>
|
||
<div class="item-controls">
|
||
<a data-action="edit" data-item-uuid="{{item.uuid}}"><i class="fas fa-edit"></i></a>
|
||
{{#if ../isEditMode}}<a data-action="delete" data-item-uuid="{{item.uuid}}"><i class="fas fa-trash"></i></a>{{/if}}
|
||
</div>
|
||
</div>
|
||
{{/each}}
|
||
</div>
|
||
|
||
{{!-- Attributs --}}
|
||
<div class="items-group">
|
||
<div class="items-header">
|
||
<span>{{localize "CELESTOPOL.Item.attributes"}}</span>
|
||
{{#if isEditMode}}
|
||
<a data-action="createAttribute" title="{{localize 'CELESTOPOL.Item.newAttribute'}}"><i class="fas fa-plus"></i></a>
|
||
{{/if}}
|
||
</div>
|
||
{{#each attributes as |item|}}
|
||
<div class="item-row" data-item-id="{{item.id}}" data-item-uuid="{{item.uuid}}" data-drag="true">
|
||
<img src="{{item.img}}" class="item-icon" alt="{{item.name}}">
|
||
<span class="item-name">{{item.name}}</span>
|
||
<span class="item-value">{{item.system.value}}</span>
|
||
<div class="item-controls">
|
||
<a data-action="edit" data-item-uuid="{{item.uuid}}"><i class="fas fa-edit"></i></a>
|
||
{{#if ../isEditMode}}<a data-action="delete" data-item-uuid="{{item.uuid}}"><i class="fas fa-trash"></i></a>{{/if}}
|
||
</div>
|
||
</div>
|
||
{{/each}}
|
||
</div>
|
||
</div>
|
||
</div>
|