domsPlace/public/objects/window/_window95.scss

240 lines
5.3 KiB
SCSS

/*
* Window 95
* Windows 95 esque objects
*
* Dependencies:
*
* Version:
* 1.0.0 - 2018/06/24
*/
@import '~@styles/global';
$o-window--color-background: #C0C0C0;
$o-window--color-highlight: #0000BF;
$o-window--color-disabled: #808080;
$o-window--color-title-bar: #000080;
$o-window--font: 'MS PGothic', Verdana, Arial, Helvetica, sans-serif;
$o-window--scale: 1;
$o-window--font-size: 12px * $o-window--scale;
$o-window--one-third: #{"33.333333333%"};//I needed greater accuracy than SCSS provided
@mixin o-window-border($thickness) {
border: (3px * $thickness) solid black;
border-image-source: url('~@assets/images/window/window.svg');
border-image-slice: $o-window--one-third;
}
@mixin o-window-button($thickness) {
border: (2px * $thickness) solid black;
border-image-source: url('~@assets/images/window/button.svg');
border-image-slice: $o-window--one-third;
display: inline-block;
background: $o-window--color-background;
&:not(.is-disabled):active {
border-image-source: url('~@assets/images/window/button-inverted.svg');
}
}
@mixin o-window-frame($thickness) {
border: (2px * $thickness) solid black;
border-image: url('~@assets/images/window/frame.svg') $o-window--one-third repeat;
}
//Classes
.o-window {
@extend %t-dp--shadow;
@include o-window-border($o-window--scale);
background: $o-window--color-background;
font-size: $o-window--font-size;
font-family: $o-window--font;
&__button {
@include o-window-button($o-window--scale);
padding: (1px * $o-window--scale) (5px * $o-window--scale);
border: 1px * $o-window--scale solid transparent;
display: inline-block;
position: relative;
&::first-letter {
text-decoration: underline;
}
}
&__title-bar {
width: 100%;
background: $o-window--color-title-bar;
padding: 2px * $o-window--scale;
&-title {
color: white;
font-weight: bold;
font-family: $o-window--font;
font-size: $o-window--font-size;
cursor: default;
}
&-buttons {
height: 100%;
float: right;
font-size: 0;
}
&-button {
@include o-window-button($o-window--scale);
width: 16px * $o-window--scale;
height: 14px * $o-window--scale;
font-size: $o-window--font-size;
background-image: url('~@assets/images/window/icons.png');
background-position: 0px 0px;
background-size: 48px*$o-window--scale 20px*$o-window--scale;
&.is-disabled {
background-position-y: 10px*$o-window--scale;
}
&--close {
margin-left: 2px * $o-window--scale;
}
&--minimize {
background-position-x: 24px * $o-window--scale;
}
}
}
&__menu-bar {
width: 100%;
overflow: visible;
&-option {
display: inline-block;
position: relative;
}
&-button {
padding: (1px * $o-window--scale) (5px * $o-window--scale);
border: 1px * $o-window--scale solid transparent;
font-family: $o-window--font;
font-size: $o-window--font-size;
cursor: default;
color: black;
&::first-letter {
text-decoration: underline;
}
&:hover {
color: black;
text-decoration: none;
border-bottom-color: #868686;
border-right-color: #868686;
border-top-color: #FFFFFF;
border-left-color: #FFFFFF;
}
&:active,
&.is-active,
.o-window__menu-bar-option.is-active &
{
border-right-color: #FFFFFF;
border-bottom-color: #FFFFFF;
border-top-color: #868686;
border-left-color: #868686;
}
.o-window__menu-bar-option.is-disabled & {
color: $o-window--color-disabled;
&:hover,&:active,&.is-active,.o-window__menu-bar.is-active & {
border-right-color: transparent;
border-bottom-color: transparent;
border-top-color: transparent;
border-left-color: transparent;
}
}
}
}
&__context-menu {
@include o-window-border($o-window--scale);
border-top-width: 2px*$o-window--scale;
background: $o-window--color-background;
width: auto;
.o-window__menu-bar-option > & {
position: absolute;
display: none;
}
.o-window__menu-bar-option.is-active > & {
display: block;
}
&-option {
padding-left: 22px*$o-window--scale;
padding-right: 22px*$o-window--scale;
padding-bottom: 3px*$o-window--scale;
padding-top: 1px*$o-window--scale;
white-space: nowrap;
&-title {
font-family: $o-window--font;
font-size: $o-window--font-size;
cursor: default;
&::first-letter {
text-decoration: underline;
}
}
&:hover {
background: $o-window--color-highlight;
color: white;
}
&:first-child > .o-window__context-menu-option-title {
font-weight: bold;
}
&.is-disabled {
color: $o-window--color-disabled;
&:hover {
background: inherit;
color: $o-window--color-disabled;
}
}
}
}
&__frame {
@include o-window-frame($o-window--scale);
}
&__address-bar {
display: flex;
align-items: center;
&-title {
display: block;
padding-right: 2px;
}
&-frame {
flex-basis: 100%;
}
}
&__input {
display: block;
width: 100%;
background: white;
}
}