kopia lustrzana https://github.com/shoelace-style/shoelace
168 wiersze
2.9 KiB
SCSS
168 wiersze
2.9 KiB
SCSS
@import 'component';
|
|
|
|
/**
|
|
* @prop --size: The preferred size of the drawer. This will be applied to the drawer's width or height depending on its
|
|
* `placement`. Note that the drawer will shrink to accommodate smaller screens.
|
|
*/
|
|
:host {
|
|
--size: 25rem;
|
|
|
|
display: contents;
|
|
}
|
|
|
|
.drawer {
|
|
top: 0;
|
|
left: 0;
|
|
width: 100%;
|
|
height: 100%;
|
|
pointer-events: none;
|
|
overflow: hidden;
|
|
|
|
&[hidden] {
|
|
display: none;
|
|
}
|
|
}
|
|
|
|
.drawer--contained {
|
|
position: absolute;
|
|
z-index: initial;
|
|
}
|
|
|
|
.drawer--fixed {
|
|
position: fixed;
|
|
z-index: var(--sl-z-index-drawer);
|
|
}
|
|
|
|
.drawer__panel {
|
|
position: absolute;
|
|
display: flex;
|
|
flex-direction: column;
|
|
z-index: 2;
|
|
max-width: 100%;
|
|
max-height: 100%;
|
|
background-color: var(--sl-color-white);
|
|
box-shadow: var(--sl-shadow-x-large);
|
|
transition: var(--sl-transition-medium) transform;
|
|
overflow: auto;
|
|
pointer-events: all;
|
|
|
|
&:focus {
|
|
outline: none;
|
|
}
|
|
}
|
|
|
|
.drawer--top .drawer__panel {
|
|
top: 0;
|
|
left: 0;
|
|
width: 100%;
|
|
height: var(--size);
|
|
transform: translate(0, -100%);
|
|
}
|
|
|
|
.drawer--right .drawer__panel {
|
|
top: 0;
|
|
right: 0;
|
|
width: var(--size);
|
|
height: 100%;
|
|
transform: translate(100%, 0);
|
|
}
|
|
|
|
.drawer--bottom .drawer__panel {
|
|
bottom: 0;
|
|
left: 0;
|
|
width: 100%;
|
|
height: var(--size);
|
|
transform: translate(0, 100%);
|
|
}
|
|
|
|
.drawer--left .drawer__panel {
|
|
top: 0;
|
|
left: 0;
|
|
width: var(--size);
|
|
height: 100%;
|
|
transform: translate(-100%, 0);
|
|
}
|
|
|
|
.drawer--open .drawer__panel {
|
|
transform: translate(0, 0);
|
|
}
|
|
|
|
.drawer__header {
|
|
display: flex;
|
|
}
|
|
|
|
.drawer__title {
|
|
flex: 1 1 auto;
|
|
font-size: var(--sl-font-size-large);
|
|
line-height: var(--sl-line-height-dense);
|
|
padding: var(--sl-spacing-large);
|
|
}
|
|
|
|
.drawer__close {
|
|
flex: 0 0 auto;
|
|
display: flex;
|
|
align-items: center;
|
|
background: none;
|
|
border: none;
|
|
border-radius: var(--sl-border-radius-small);
|
|
font-family: inherit;
|
|
font-size: var(--sl-font-size-x-large);
|
|
font-weight: inherit;
|
|
color: var(--sl-color-gray-50);
|
|
padding: 0 var(--sl-spacing-large);
|
|
cursor: pointer;
|
|
transition: var(--sl-transition-fast) color;
|
|
-webkit-appearance: none;
|
|
|
|
&:hover,
|
|
&:focus,
|
|
&:active {
|
|
color: var(--sl-color-primary-50);
|
|
}
|
|
|
|
&:focus {
|
|
outline: none;
|
|
}
|
|
}
|
|
|
|
.focus-visible .drawer__close:focus {
|
|
box-shadow: var(--sl-focus-ring-box-shadow);
|
|
}
|
|
|
|
.drawer__body {
|
|
flex: 1 1 auto;
|
|
padding: var(--sl-spacing-large);
|
|
overflow: auto;
|
|
-webkit-overflow-scrolling: touch;
|
|
}
|
|
|
|
.drawer__footer {
|
|
text-align: right;
|
|
padding: var(--sl-spacing-large);
|
|
|
|
::slotted(sl-button:not(:last-of-type)) {
|
|
margin-right: var(--sl-spacing-x-small);
|
|
}
|
|
}
|
|
|
|
.drawer__overlay {
|
|
display: block;
|
|
position: fixed;
|
|
top: 0;
|
|
right: 0;
|
|
bottom: 0;
|
|
left: 0;
|
|
background-color: var(--sl-overlay-background-color);
|
|
opacity: 0;
|
|
transition: var(--sl-transition-medium) opacity;
|
|
pointer-events: all;
|
|
}
|
|
|
|
.drawer--contained .drawer__overlay {
|
|
position: absolute;
|
|
}
|
|
|
|
.drawer--open .drawer__overlay {
|
|
opacity: 1;
|
|
}
|