mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-19 04:19:28 +01:00
8e42d4d274
- Fix egw not loading in time - Fix manually hiding side content meant auto-opening did not work - Some accessibility adjustments
184 lines
3.3 KiB
TypeScript
184 lines
3.3 KiB
TypeScript
import {css} from 'lit';
|
|
|
|
export default css`
|
|
|
|
/* Layout */
|
|
|
|
:host {
|
|
position: relative;
|
|
width: 100%;
|
|
height: 100%;
|
|
|
|
display: flex;
|
|
flex-direction: column;
|
|
}
|
|
|
|
:host > * {
|
|
position: relative;
|
|
display: flex;
|
|
}
|
|
|
|
.egw_fw_app__name {
|
|
max-width: 20vw;
|
|
flex: 1 1 20vw;
|
|
}
|
|
|
|
.egw_fw_app__name h2 {
|
|
margin-inline-start: var(--sl-spacing-medium);
|
|
}
|
|
|
|
.egw_fw_app__header {
|
|
justify-content: flex-start;
|
|
align-items: center;
|
|
justify-items: stretch;
|
|
flex: 1 0 2em;
|
|
max-height: 3em;
|
|
}
|
|
|
|
.egw_fw_app__outerSplit {
|
|
grid-column: start / end;
|
|
grid-row: start / end;
|
|
grid-template-rows: subgrid;
|
|
--min: var(--left-min, 0px);
|
|
--max: var(--left-max, 20%);
|
|
}
|
|
|
|
.egw_fw_app__innerSplit {
|
|
grid-template-rows: subgrid;
|
|
grid-column-end: -1;
|
|
grid-row: start / end;
|
|
--max: calc(100% - var(--right-min, 0px));
|
|
--min: calc(100% - var(--right-max, 50%));
|
|
}
|
|
|
|
.egw_fw_app__innerSplit.no-content {
|
|
--min: 100%;
|
|
}
|
|
|
|
sl-split-panel::part(divider) {
|
|
grid-row: start / end;
|
|
font-size: var(--sl-font-size-medium);
|
|
}
|
|
|
|
sl-split-panel > sl-icon {
|
|
position: absolute;
|
|
border-radius: var(--sl-border-radius-small);
|
|
background-color: var(--primary-background-color);
|
|
color: var(--sl-color-neutral-0);
|
|
padding: 0.5rem 0.125rem;
|
|
z-index: var(--sl-z-index-drawer);
|
|
}
|
|
|
|
sl-split-panel.no-content {
|
|
--divider-width: 0px;
|
|
}
|
|
|
|
sl-split-panel.no-content::part(divider) {
|
|
display: none;
|
|
}
|
|
|
|
.egw_fw_app__aside {
|
|
overflow-x: hidden;
|
|
overflow-y: auto;
|
|
display: grid;
|
|
grid-template-rows: subgrid;
|
|
grid-row: start / end;
|
|
}
|
|
|
|
|
|
.egw_fw_app__aside_header {
|
|
grid-row: sub-header / main;
|
|
}
|
|
|
|
.egw_fw_app__aside_content {
|
|
height: 100%;
|
|
grid-row: main / footer;
|
|
}
|
|
|
|
.egw_fw_app__aside_footer {
|
|
grid-row: footer / end;
|
|
}
|
|
|
|
.egw_fw_app__main {
|
|
flex: 1 1 100%;
|
|
display: grid;
|
|
align-items: stretch;
|
|
justify-content: stretch;
|
|
overflow: hidden;
|
|
}
|
|
.egw_fw_app__header {
|
|
grid-row: sub-header / main;
|
|
}
|
|
|
|
.egw_fw_app__main_content {
|
|
grid-row: main / footer;
|
|
}
|
|
|
|
.egw_fw_app__footer {
|
|
grid-row: footer / end;
|
|
}
|
|
|
|
.header, .footer {
|
|
overflow: hidden;
|
|
}
|
|
|
|
@media (min-width: 600px) {
|
|
.egw_fw_app__main {
|
|
grid-template-columns: [start left] min-content [ main] 1fr [right] min-content [end];
|
|
grid-template-rows: [start sub-header] fit-content(2em) [main] auto [footer] fit-content(2em) [end];
|
|
}
|
|
|
|
::slotted(*) {
|
|
height: 100%;
|
|
}
|
|
}
|
|
@media (max-width: 599px) {
|
|
.egw_fw_app__main {
|
|
grid-template-columns: [start left main-start] fit-content(50%) [right] auto [main-end end];
|
|
grid-template-rows:
|
|
[start sub-header] fit-content(2em)
|
|
[main] auto
|
|
[aside-header] fit-content(2em)
|
|
[aside] min-content
|
|
[aside-footer] fit-content(4em)
|
|
[footer] fit-content(4em)
|
|
[end];
|
|
}
|
|
|
|
sl-split-panel {
|
|
display: contents
|
|
}
|
|
|
|
sl-split-panel::part(divider) {
|
|
display: none;
|
|
}
|
|
|
|
.egw_fw_app__header {
|
|
grid-column: start / end;
|
|
}
|
|
.egw_fw_app__main_content {
|
|
grid-row: main / aside-header;
|
|
grid-column: start / end;
|
|
}
|
|
|
|
.egw_fw_app__aside {
|
|
grid-row: aside-header / footer;
|
|
}
|
|
|
|
.egw_fw_app__aside_header {
|
|
grid-row: aside-header / aside;
|
|
}
|
|
|
|
.egw_fw_app__aside_content {
|
|
grid-row: aside / aside-footer;
|
|
}
|
|
|
|
.egw_fw_app__aside_footer {
|
|
grid-row: aside-footer / footer;
|
|
}
|
|
|
|
.egw_fw_app__footer {
|
|
grid-column: start / end;
|
|
}
|
|
}
|
|
` |