import * as React from "react"; import * as Constants from "~/common/constants"; import * as SVG from "~/common/svg"; import * as Styles from "~/common/styles"; import { css } from "@emotion/react"; import { GlobalTooltip } from "~/components/system/components/fragments/GlobalTooltip"; import { Boundary } from "~/components/system/components/fragments/Boundary"; import { Alert } from "~/components/core/Alert"; const STYLES_NO_VISIBLE_SCROLL = css` overflow-y: scroll; scrollbar-width: none; -webkit-overflow-scrolling: touch; -ms-overflow-style: -ms-autohiding-scrollbar; ::-webkit-scrollbar { width: 0px; display: none; } ::-webkit-scrollbar-track { background: ${Constants.semantic.bgLight}; } ::-webkit-scrollbar-thumb { background: ${Constants.system.grayLight2}; } `; const STYLES_CONTENT = css` background: ${Constants.system.white}; width: 100%; min-width: 10%; min-height: 100vh; position: relative; @media (max-width: ${Constants.sizes.mobile}px) { padding-left: 0px; padding: 0 0 88px 0; } `; const STYLES_SIDEBAR_ELEMENTS = css` height: 100vh; width: ${Constants.sizes.sidebar}px; padding: 0; flex-shrink: 0; background-color: ${Constants.semantic.bgGrayLight}; top: 0; right: 0; ${STYLES_NO_VISIBLE_SCROLL} @media (max-width: ${Constants.sizes.mobile}px) { width: 100%; } /* @supports ((-webkit-backdrop-filter: blur(25px)) or (backdrop-filter: blur(25px))) { -webkit-backdrop-filter: blur(25px); backdrop-filter: blur(25px); background-color: rgba(195, 195, 196, 0.6); } */ `; const STYLES_SIDEBAR = css` position: fixed; top: 0; right: 0; margin: auto; z-index: ${Constants.zindex.sidebar}; `; const STYLES_MODAL = css` z-index: ${Constants.zindex.modal}; top: ${Constants.sizes.header}px; right: 0; bottom: 0; position: fixed; left: 0; padding: 24px 24px 32px; height: calc(100vh - ${Constants.sizes.header}px); background-color: ${Constants.semantic.bgBlurWhiteOP}; @supports ((-webkit-backdrop-filter: blur(75px)) or (backdrop-filter: blur(75px))) { -webkit-backdrop-filter: blur(75px); backdrop-filter: blur(75px); } `; const STYLES_MODAL_ELEMENTS = css` width: 100%; height: 100%; `; const STYLES_SIDEBAR_HEADER = css` display: flex; justify-content: flex-end; margin-bottom: 8px; `; const STYLES_SIDEBAR_CONTENT = css` padding: 56px 24px 24px 24px; padding-top: calc(32px + ${Constants.sizes.topOffset}px); @media (max-width: ${Constants.sizes.mobile}px) { padding-top: 8px; margin-bottom: 48px; } `; const STYLES_BLOCK = css` margin-top: 8px; height: 56px; width: 56px; display: inline-flex; align-items: center; justify-content: center; transition: 200ms ease all; cursor: pointer; color: ${Constants.semantic.textGray}; `; const STYLES_DISMISS = css` ${Styles.ICON_CONTAINER} color: ${Constants.semantic.textGray}; :focus { outline: none; } :hover { color: ${Constants.system.blue}; } `; export default class ApplicationLayout extends React.Component { _sidebar; _navigation; _body; state = { headerTop: 0, }; componentDidMount = () => { this.prevScrollPos = window.pageYOffset; if (this.props.isMobile) { window.addEventListener("scroll", this._handleScroll); } }; componentWillUnmount = () => { if (this.props.isMobile) { window.removeEventListener("scroll", this._handleScroll); } }; _handleScroll = () => { let currentScrollPos = window.pageYOffset; if (this.prevScrollPos > currentScrollPos) { this.setState({ headerTop: 0 }); } else { if (currentScrollPos > 56) { this.setState({ headerTop: -56 }); } } this.prevScrollPos = currentScrollPos; }; _handleDismiss = (e) => { e.stopPropagation(); e.preventDefault(); this.props.onDismissSidebar(); }; render() { let sidebarElements = null; if (this.props.sidebar) { sidebarElements = (
{ this._sidebar = c; }} >
{this.props.sidebar}
); } return (
{this.props.header && ( <>
{this.props.header}
)} {this.props.children}
{sidebarElements ? sidebarElements : null} ); } }