Markup / scss refactor WIP

- Significant reorg of splitter CSS to reduce specificity;
- Splitter enhancements for collapsed state;
This commit is contained in:
charlesh88 2018-08-17 09:39:33 -07:00
parent 233c17e75b
commit e6b22cbcbe
2 changed files with 126 additions and 97 deletions

View File

@ -236,11 +236,13 @@ $scrollbarThumbColorMenuHov: pullForward($scrollbarThumbColorMenu, 2%);
// Splitter // Splitter
$splitterD: 10px; $splitterD: 10px;
$splitterCollapseBtnD: ($splitterD, 30px);
$splitterDSm: 8px; // Smaller splitter, used inside elements like a Timeline view $splitterDSm: 8px; // Smaller splitter, used inside elements like a Timeline view
$splitterHandleD: 4px; $splitterHandleD: 3px;
$colorSplitterBaseBg: $colorBodyBg; $colorSplitterBaseBg: $colorBodyBg;
$colorSplitterBg: pullForward($colorSplitterBaseBg, 15%); $colorSplitterBg: pullForward($colorSplitterBaseBg, 15%);
$colorSplitterFg: $colorBodyBg; $colorSplitterFg: $colorBodyBg;
$colorSplitterButtonBg: pullForward($colorSplitterBaseBg, 20%);
$splitterShdw: none; $splitterShdw: none;
$splitterEndCr: none; $splitterEndCr: none;
$colorSplitterHover: pullForward($colorSplitterBg, $hoverRatioPercent * 2); $colorSplitterHover: pullForward($colorSplitterBg, $hoverRatioPercent * 2);

View File

@ -12,13 +12,8 @@
'l-pane__resize-handle--before': handle === 'before', 'l-pane__resize-handle--before': handle === 'before',
'l-pane__resize-handle--after': handle === 'after' 'l-pane__resize-handle--after': handle === 'after'
}" }"
@mousedown="start" @mousedown="start">
>
<a class="l-pane__collapse-button" <a class="l-pane__collapse-button"
:class="{
'l-pane__collapse-button--before': handle === 'before',
'l-pane__collapse-button--after': handle === 'after'
}"
@click="toggleCollapse" @click="toggleCollapse"
v-if="collapsable"></a> v-if="collapsable"></a>
</div> </div>
@ -35,17 +30,126 @@
// TODO: get handles visible when pane is collapsed // TODO: get handles visible when pane is collapsed
/**************************** BASE STYLES */
.l-pane { .l-pane {
&__contents { /************************ PANES */
display: contents; &--horizontal {
// Pane adjusts size horizontally, handles run vertically
// Selectors here
> .l-pane__resize-handle {
//background: red;
cursor: col-resize;
width: $splitterHandleD;
top: 0;
bottom: 0;
&:before {
// Extended hit area
top: 0;
right: $hitMargin * -1;
bottom: 0;
left: $hitMargin * -1;
}
&--before {
// Handle at left edge of containing pane
left: 0;
[class*="collapse-button"] {
left: 0;
transform: scaleX(-1);
}
}
&--after {
// Handle at right edge of containing pane
right: 0;
[class*="collapse-button"] {
right: 0;
}
}
}
[class*="collapse-button"] {
border-bottom-left-radius: $controlCr;
height: nth($splitterCollapseBtnD, 2);
width: nth($splitterCollapseBtnD, 1);
&:before {
content: $glyph-icon-arrow-left;
}
}
&.l-pane--collapsed {
padding-left: 0 !important;
padding-right: 0 !important;
width: 0px;
min-width: 0px;
> .l-pane__resize-handle {
&--before {
transform: translateX($splitterHandleD * -1) scaleX(-1);
}
&--after {
transform: translateX($splitterHandleD) scaleX(-1);
}
}
}
} }
& > .l-pane__resize-handle { &--vertical {
// Pane adjusts size vertically, handles run horizontally
// Selectors here
> .l-pane__resize-handle {
//background: green;
cursor: row-resize;
height: $splitterHandleD;
left: 0;
right: 0;
&:before {
top: $hitMargin * -1;
right: 0;
bottom: $hitMargin * -1;
left: 0;
}
&--before {
// Handle at top edge of containing pane
top: 0;
}
&--after {
// Handle at bottom edge of containing pane
bottom: 0;
}
}
[class*="collapse-button"] {
height: nth($splitterCollapseBtnD, 1);
width: nth($splitterCollapseBtnD, 2);
}
&.l-pane--collapsed {
padding-top: 0 !important;
padding-bottom: 0 !important;
height: 0px;
min-height: 0px;
}
}
/************************ HANDLES */
&__resize-handle {
// Selectors for handle in any context
z-index: 1; z-index: 1;
display: block; display: block;
background: $colorSplitterBg; background: $colorSplitterBg;
position: absolute; position: absolute;
transition: $transOut; transition: $transOut;
&:before { &:before {
@ -61,7 +165,7 @@
} }
&:active { &:active {
background: $colorSplitterActive; background: $colorSplitterActive; // Not really working with drag
} }
&:hover { &:hover {
@ -69,62 +173,14 @@
} }
} }
&--horizontal { /************************ COLLAPSE BUTTONS */
& > .l-pane__resize-handle { &__collapse-button {
cursor: col-resize;
width: $splitterHandleD;
top: 0;
bottom: 0;
&--before {
left: 0;
}
&--after {
right: 0;
}
&:before {
top: 0;
right: $hitMargin * -1;
bottom: 0;
left: $hitMargin * -1;
}
}
}
&--vertical {
> .l-pane__resize-handle {
cursor: row-resize;
height: $splitterHandleD;
left: 0;
right: 0;
&--before {
top: 0
}
&--after {
bottom: 0;
}
&:before {
top: $hitMargin * -1;
right: 0;
bottom: $hitMargin * -1;
left: 0;
}
}
}
& > .l-pane__resize-handle > .l-pane__collapse-button {
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
position: absolute; position: absolute;
z-index: 3; z-index: 3;
background: $colorSplitterBg; background: $colorSplitterButtonBg;
transition: $transOut; transition: $transOut;
&:active, &:hover { &:active, &:hover {
@ -142,52 +198,23 @@
&:before { &:before {
color: $colorSplitterFg; color: $colorSplitterFg;
display: block; display: block;
font-size: 0.8em; font-size: 0.7em;
font-family: symbolsfont; font-family: symbolsfont;
} }
} }
&--horizontal > .l-pane__resize-handle > .l-pane__collapse-button { /************************ CONTENTS */
width: $splitterD; &__contents {
height: 40px; display: contents;
&--before {
border-bottom-right-radius: $controlCr;
left: 0;
&:before {
content: $glyph-icon-arrow-right;
}
}
&--after {
border-bottom-left-radius: $controlCr;
right: 0;
&:before {
content: $glyph-icon-arrow-left;
}
}
}
&--vertical > .l-pane__resize-handle > .l-pane__collapse-button {
/* TODO: style buttons for vertical collapse. */
} }
/************************ COLLAPSED STATE */
&--collapsed { &--collapsed {
padding: 0 !important;
.l-pane__contents { .l-pane__contents {
display: none; display: none;
} }
} }
} }
.l-pane--horizontal.l-pane--collapsed {
width: 0px;
min-width: 0px;
}
.l-pane--vertical.l-pane--collapsed {
height: 0px;
min-height: 0px;
}
</style> </style>