Styling pass for scrollbars, fieldsets, and scroll shadows

This commit is contained in:
Carlos Fernandez 2026-05-29 05:41:22 -04:00
parent 3eb33a71af
commit 7dec188167
30 changed files with 177 additions and 88 deletions

View file

@ -7,7 +7,7 @@ export default class AdversarySheet extends DHBaseActorSheet {
/** @inheritDoc */ /** @inheritDoc */
static DEFAULT_OPTIONS = { static DEFAULT_OPTIONS = {
classes: ['adversary'], classes: ['adversary'],
position: { width: 660, height: 766 }, position: { width: 670, height: 766 },
window: { resizable: true }, window: { resizable: true },
actions: { actions: {
toggleHitPoints: AdversarySheet.#toggleHitPoints, toggleHitPoints: AdversarySheet.#toggleHitPoints,

View file

@ -54,7 +54,7 @@ body.game:is(.performance-low, .noblur) {
position: relative; position: relative;
min-height: -webkit-fill-available; min-height: -webkit-fill-available;
transition: opacity 0.3s ease; transition: opacity 0.3s ease;
padding-bottom: 20px; padding-bottom: 16px;
.tab { .tab {
padding: 0 10px; padding: 0 10px;

View file

@ -42,7 +42,7 @@
display: grid; display: grid;
grid-template-columns: 1fr 1fr 1fr 1fr; grid-template-columns: 1fr 1fr 1fr 1fr;
gap: 10px; gap: 10px;
padding: 10px 10px 0; padding: 12px 12px 0 10px;
.input { .input {
color: light-dark(@dark, @beige); color: light-dark(@dark, @beige);

View file

@ -8,7 +8,8 @@
flex-direction: column; flex-direction: column;
gap: 10px; gap: 10px;
overflow-y: auto; overflow-y: auto;
padding-bottom: 20px; padding-bottom: 4px;
scrollbar-gutter: stable;
.with-scroll-shadows(); .with-scroll-shadows();
} }
} }

View file

@ -3,14 +3,27 @@
@import '../../../utils/mixin.less'; @import '../../../utils/mixin.less';
.application.sheet.daggerheart.actor.dh-style.adversary { .application.sheet.daggerheart.actor.dh-style.adversary {
.tab.features { .tab.features.active {
position: relative;
padding-left: 15px;
.feature-section { .feature-section {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 10px; gap: 10px;
padding: 6px 2px 4px 0;
overflow-y: auto; overflow-y: auto;
padding-bottom: 20px; scrollbar-gutter: stable;
.with-scroll-shadows(); .with-scroll-shadows();
} }
> button {
--button-size: 1.75rem;
width: 1.75rem;
position: absolute;
inset: auto 16px 0 auto;
box-shadow: 0 0 5px @light-black;
}
&:has(> button) .feature-section {
padding-bottom: calc(1px + 1.75rem);
}
} }
} }

View file

@ -1,7 +1,6 @@
@import './features.less';
@import './header.less';
@import './sheet.less'; @import './sheet.less';
@import './header.less';
@import './features.less';
@import './sidebar.less'; @import './sidebar.less';
@import './effects.less'; @import './effects.less';
@import './notes.less'; @import './notes.less';

View file

@ -1,3 +1,7 @@
.application.sheet.daggerheart.actor.dh-style.adversary .tab.notes.active { .application.sheet.daggerheart.actor.dh-style.adversary .tab.notes.active {
padding-bottom: 20px; padding: 6px 0 4px 15px;
.editor-content {
scrollbar-gutter: stable;
.with-scroll-shadows();
}
} }

View file

@ -9,6 +9,7 @@
height: 100%; height: 100%;
width: 100%; width: 100%;
padding-bottom: 0; padding-bottom: 0;
}
.adversary-sidebar-sheet { .adversary-sidebar-sheet {
grid-row: 1 / span 2; grid-row: 1 / span 2;
@ -30,7 +31,9 @@
overflow: hidden; overflow: hidden;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
} padding-right: 0;
margin-right: 2px;
margin-bottom: 16px;
} }
} }
} }

View file

@ -11,8 +11,9 @@
height: 100%; height: 100%;
overflow-y: auto; overflow-y: auto;
padding-top: 8px; padding-top: 8px;
padding-bottom: 20px; padding-bottom: 4px;
height: 100%; height: 100%;
scrollbar-gutter: stable;
.with-scroll-shadows(); .with-scroll-shadows();
} }

View file

@ -10,6 +10,7 @@
gap: 10px; gap: 10px;
overflow-y: auto; overflow-y: auto;
padding-bottom: 20px; padding-bottom: 20px;
scrollbar-gutter: stable;
.with-scroll-shadows(); .with-scroll-shadows();
} }
} }

View file

@ -1,8 +1,8 @@
@import './sheet.less';
@import './biography.less'; @import './biography.less';
@import './effects.less'; @import './effects.less';
@import './features.less'; @import './features.less';
@import './header.less'; @import './header.less';
@import './inventory.less'; @import './inventory.less';
@import './loadout.less'; @import './loadout.less';
@import './sheet.less';
@import './sidebar.less'; @import './sidebar.less';

View file

@ -4,13 +4,18 @@
.application.sheet.daggerheart.actor.dh-style.character { .application.sheet.daggerheart.actor.dh-style.character {
.tab.inventory { .tab.inventory {
padding-right: 0;
.search-section {
padding-right: 14px;
}
.items-section { .items-section {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 10px; gap: 10px;
overflow-y: auto; overflow-y: auto;
scrollbar-gutter: stable;
margin-top: 20px; margin-top: 20px;
padding-bottom: 20px; padding-bottom: 4px;
.with-scroll-shadows(); .with-scroll-shadows();
} }
} }

View file

@ -5,6 +5,7 @@
.application.sheet.daggerheart.actor.dh-style.character { .application.sheet.daggerheart.actor.dh-style.character {
.tab.loadout { .tab.loadout {
.search-section { .search-section {
padding-right: 14px;
.btn-toggle-view { .btn-toggle-view {
background: light-dark(@dark-blue-10, @dark-blue); background: light-dark(@dark-blue-10, @dark-blue);
border: 1px solid @color-border; border: 1px solid @color-border;
@ -52,8 +53,9 @@
gap: 10px; gap: 10px;
height: 100%; height: 100%;
overflow-y: auto; overflow-y: auto;
scrollbar-gutter: stable;
margin-top: 20px; margin-top: 20px;
padding-bottom: 20px; padding-bottom: 4px;
.with-scroll-shadows(); .with-scroll-shadows();
} }
} }

View file

@ -10,6 +10,7 @@
width: 100%; width: 100%;
padding-bottom: 0; padding-bottom: 0;
overflow-x: auto; overflow-x: auto;
}
.character-sidebar-sheet { .character-sidebar-sheet {
grid-row: 1 / span 2; grid-row: 1 / span 2;
@ -27,6 +28,9 @@
.tab { .tab {
grid-row: 2; grid-row: 2;
grid-column: 2; grid-column: 2;
padding-right: 0;
margin-right: 2px;
margin-bottom: 12px;
&.active { &.active {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
@ -34,4 +38,3 @@
} }
} }
} }
}

View file

@ -1,13 +1,17 @@
@import '../../../utils/colors.less'; @import '../../../utils/colors.less';
@import '../../../utils/mixin.less';
.application.sheet.daggerheart.actor.dh-style.companion { .application.sheet.daggerheart.actor.dh-style.companion {
.tab.effects { .tab.effects {
margin-right: 2px;
padding-right: 0;
.effects-sections { .effects-sections {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 10px; gap: 10px;
overflow-y: auto; overflow-y: auto;
padding-bottom: 20px; padding-bottom: 4px;
scrollbar-gutter: stable;
.with-scroll-shadows(); .with-scroll-shadows();
} }
} }

View file

@ -4,13 +4,25 @@
.application.sheet.daggerheart.actor.dh-style.environment { .application.sheet.daggerheart.actor.dh-style.environment {
.tab.features { .tab.features {
position: relative;
.feature-section { .feature-section {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 10px; gap: 10px;
overflow-y: auto; overflow-y: auto;
padding-bottom: 4px; padding: 4px 8px;
scrollbar-gutter: stable;
.with-scroll-shadows(); .with-scroll-shadows();
} }
> button {
--button-size: 1.75rem;
width: 1.75rem;
position: absolute;
inset: auto 16px 0 auto;
box-shadow: 0 0 5px @light-black;
}
&:has(> button) .feature-section {
padding-bottom: calc(1px + 1.75rem);
}
} }
} }

View file

@ -1,4 +1,5 @@
@import './sheet.less';
@import './features.less'; @import './features.less';
@import './header.less'; @import './header.less';
@import './potentialAdversaries.less'; @import './potentialAdversaries.less';
@import './sheet.less'; @import './notes.less';

View file

@ -0,0 +1,11 @@
@import '../../../utils/mixin.less';
.application.sheet.daggerheart.actor.dh-style.environment {
.tab.notes {
padding: 6px 0 4px 15px;
.editor-content {
scrollbar-gutter: stable;
.with-scroll-shadows();
}
}
}

View file

@ -1,4 +1,5 @@
@import '../../../utils/colors.less'; @import '../../../utils/colors.less';
@import '../../../utils/mixin.less';
.application.sheet.daggerheart.actor.dh-style.environment { .application.sheet.daggerheart.actor.dh-style.environment {
.tab.potentialAdversaries { .tab.potentialAdversaries {
@ -7,7 +8,8 @@
flex-direction: column; flex-direction: column;
gap: 10px; gap: 10px;
overflow-y: auto; overflow-y: auto;
padding-bottom: 4px; padding: 0 4px 4px 4px;
scrollbar-gutter: stable;
.with-scroll-shadows(); .with-scroll-shadows();
} }
} }

View file

@ -16,6 +16,8 @@
.tab { .tab {
flex: 1; flex: 1;
overflow-y: auto; overflow-y: auto;
padding-right: 0;
margin-right: 2px;
&.active { &.active {
overflow: hidden; overflow: hidden;

View file

@ -1,4 +1,5 @@
@import './sheet.less';
@import './header.less'; @import './header.less';
@import './party-members.less'; @import './party-members.less';
@import './sheet.less';
@import './inventory.less'; @import './inventory.less';
@import './notes.less';

View file

@ -4,11 +4,17 @@
.application.sheet.daggerheart.actor.dh-style.party { .application.sheet.daggerheart.actor.dh-style.party {
.tab.inventory { .tab.inventory {
padding-right: 0;
.search-section {
padding-right: 14px;
}
.items-section { .items-section {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: 10px; gap: 10px;
overflow-y: auto; overflow-y: auto;
scrollbar-gutter: stable;
margin-top: 20px; margin-top: 20px;
padding-bottom: 4px; padding-bottom: 4px;
.with-scroll-shadows(); .with-scroll-shadows();

View file

@ -0,0 +1,12 @@
@import '../../../utils/mixin.less';
.application.sheet.daggerheart.actor.dh-style.party {
.tab.notes {
padding: 16px 0 4px 15px;
.editor-content {
scrollbar-gutter: stable;
padding-left: 8px;
.with-scroll-shadows();
}
}
}

View file

@ -4,6 +4,7 @@
.application.sheet.daggerheart.actor.dh-style.party .tab.partyMembers { .application.sheet.daggerheart.actor.dh-style.party .tab.partyMembers {
overflow: auto; overflow: auto;
.with-scroll-shadows();
.actors-list { .actors-list {
display: flex; display: flex;

View file

@ -21,6 +21,8 @@
flex: 1; flex: 1;
overflow-y: auto; overflow-y: auto;
scrollbar-gutter: stable; scrollbar-gutter: stable;
margin-right: 2px;
padding-right: 8px;
&.active { &.active {
overflow: auto; overflow: auto;

View file

@ -1,14 +1,20 @@
<section class='tab {{tabs.features.cssClass}} {{tabs.features.id}}' data-tab='{{tabs.features.id}}' <section class='tab {{tabs.features.cssClass}} {{tabs.features.id}}' data-tab='{{tabs.features.id}}'
data-group='{{tabs.features.group}}'> data-group='{{tabs.features.group}}'>
<div class="feature-section"> <div class="feature-section">
{{> 'daggerheart.inventory-items' {{#each @root.features as |item|}}
title=tabs.features.label {{> 'daggerheart.inventory-item'
item=item
type='feature' type='feature'
collection=@root.features actorType=@root.document.type
hideContextMenu=true hideContextMenu=true
hideModifyControls=true hideModifyControls=true
canCreate=@root.editable
showActions=@root.editable showActions=@root.editable
}} }}
{{/each}}
</div> </div>
{{#if @root.editable}}
<button data-action="createDoc" data-document-class="Item" data-type="feature" data-tooltip="{{localize 'DOCUMENT.Create' type=(localize 'TYPES.Item.feature')}}">
<i class="fa-solid fa-plus icon-button"></i>
</button>
{{/if}}
</section> </section>

View file

@ -3,10 +3,7 @@
data-tab='{{tabs.notes.id}}' data-tab='{{tabs.notes.id}}'
data-group='{{tabs.notes.group}}' data-group='{{tabs.notes.group}}'
> >
<fieldset class="fit-height"> {{formInput notes.field value=notes.value enriched=notes.enriched class="aaa" toggled=true}}
<legend>{{localize tabs.notes.label}}</legend>
{{formInput notes.field value=notes.value enriched=notes.enriched toggled=true}}
</fieldset>
{{#if (and showAttribution document.system.attribution.artist)}} {{#if (and showAttribution document.system.attribution.artist)}}
<label class="artist-attribution">{{localize "DAGGERHEART.GENERAL.artistAttribution" artist=document.system.attribution.artist}}</label> <label class="artist-attribution">{{localize "DAGGERHEART.GENERAL.artistAttribution" artist=document.system.attribution.artist}}</label>

View file

@ -4,14 +4,20 @@
data-group='{{tabs.features.group}}' data-group='{{tabs.features.group}}'
> >
<div class="feature-section"> <div class="feature-section">
{{> 'daggerheart.inventory-items' {{#each @root.features as |item|}}
title=tabs.features.label {{> 'daggerheart.inventory-item'
item=item
type='feature' type='feature'
collection=@root.features actorType=@root.document.type
hideContextMenu=true hideContextMenu=true
hideModifyControls=true hideModifyControls=true
canCreate=@root.editable
showActions=@root.editable showActions=@root.editable
}} }}
{{/each}}
</div> </div>
{{#if @root.editable}}
<button data-action="createDoc" data-document-class="Item" data-type="feature" data-tooltip="{{localize 'DOCUMENT.Create' type=(localize 'TYPES.Item.feature')}}">
<i class="fa-solid fa-plus icon-button"></i>
</button>
{{/if}}
</section> </section>

View file

@ -3,10 +3,7 @@
data-tab='{{tabs.notes.id}}' data-tab='{{tabs.notes.id}}'
data-group='{{tabs.notes.group}}' data-group='{{tabs.notes.group}}'
> >
<fieldset class="fit-height">
<legend>{{localize tabs.notes.label}}</legend>
{{formInput notes.field value=notes.value enriched=notes.value toggled=true}} {{formInput notes.field value=notes.value enriched=notes.value toggled=true}}
</fieldset>
{{#if (and showAttribution document.system.attribution.artist)}} {{#if (and showAttribution document.system.attribution.artist)}}
<label class="artist-attribution">{{localize "DAGGERHEART.GENERAL.artistAttribution" artist=document.system.attribution.artist}}</label> <label class="artist-attribution">{{localize "DAGGERHEART.GENERAL.artistAttribution" artist=document.system.attribution.artist}}</label>

View file

@ -3,8 +3,5 @@
data-tab='{{tabs.notes.id}}' data-tab='{{tabs.notes.id}}'
data-group='{{tabs.notes.group}}' data-group='{{tabs.notes.group}}'
> >
<fieldset class="fit-height">
<legend>{{localize tabs.notes.label}}</legend>
{{formInput notes.field value=notes.value enriched=notes.value toggled=true}} {{formInput notes.field value=notes.value enriched=notes.value toggled=true}}
</fieldset>
</section> </section>