Add header bar
This commit is contained in:
parent
586c7b959d
commit
e08a3ec6b5
@ -0,0 +1,3 @@
|
||||
div.header-bar {
|
||||
display: flex;
|
||||
}
|
@ -1,45 +1,38 @@
|
||||
import { Component, ReactNode } from "react";
|
||||
import { useSetting, IMixinSettingProps, Themes } from "@Context/Setting";
|
||||
import { useStatus, IMixinStatusProps } from "@Context/Status";
|
||||
import { Theme, BackgroundLevel, FontLevel } from "@Component/Theme/Theme";
|
||||
|
||||
interface IHeaderBarProps {}
|
||||
interface IHeaderBarProps {
|
||||
height: number;
|
||||
}
|
||||
|
||||
/**
|
||||
* 头部信息栏
|
||||
*/
|
||||
@useSetting
|
||||
class HeaderBar extends Component<IHeaderBarProps & IMixinSettingProps> {
|
||||
|
||||
private handelClick = () => {
|
||||
if (this.props.setting) {
|
||||
this.props.setting.setProps("themes",
|
||||
this.props.setting.themes === Themes.dark ? Themes.light : Themes.dark
|
||||
);
|
||||
this.props.setting.setProps("language",
|
||||
this.props.setting.language === "EN_US" ?'ZH_CN' : "EN_US"
|
||||
);
|
||||
}
|
||||
}
|
||||
@useStatus
|
||||
class HeaderBar extends Component<IHeaderBarProps & IMixinStatusProps> {
|
||||
|
||||
private changeListener = () => {
|
||||
this.forceUpdate();
|
||||
}
|
||||
|
||||
public componentDidMount() {
|
||||
console.log("mount");
|
||||
if (this.props.setting) {
|
||||
this.props.setting.on("change", this.changeListener);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public componentWillUnmount() {
|
||||
console.log("die");
|
||||
if (this.props.setting) {
|
||||
this.props.setting.off("change", this.changeListener);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
public render(): ReactNode {
|
||||
return <div onClick={this.handelClick}>{this.props.setting?.themes}</div>
|
||||
return <Theme
|
||||
className="header-bar"
|
||||
backgroundLevel={BackgroundLevel.Level1}
|
||||
fontLevel={FontLevel.Level3}
|
||||
style={{ height: this.props.height }}
|
||||
>
|
||||
Living Together | Web
|
||||
</Theme>
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1,9 +1,9 @@
|
||||
@import "@fluentui/react/dist/sass/References";
|
||||
|
||||
$lt-font-size-normal: $ms-font-size-14;
|
||||
$lt-font-size-lvl3: $ms-font-size-18;
|
||||
$lt-font-size-lvl2: $ms-font-size-24;
|
||||
$lt-font-size-lvl1: $ms-font-size-32;
|
||||
$lt-font-size-lvl3: $ms-font-size-16;
|
||||
$lt-font-size-lvl2: $ms-font-size-18;
|
||||
$lt-font-size-lvl1: $ms-font-size-24;
|
||||
|
||||
$lt-font-weight-normal: $ms-font-weight-regular;
|
||||
$lt-font-weight-lvl3: $ms-font-weight-semibold;
|
||||
|
@ -0,0 +1,6 @@
|
||||
div.app-root {
|
||||
width: 100%;
|
||||
height: 100%;
|
||||
position: absolute;
|
||||
overflow: hidden;
|
||||
}
|
@ -46,6 +46,8 @@ class SimulatorWeb extends Component {
|
||||
})
|
||||
this.status.model.update(0);
|
||||
}
|
||||
|
||||
(window as any).s = this;
|
||||
}
|
||||
|
||||
public render(): ReactNode {
|
||||
@ -57,17 +59,12 @@ class SimulatorWeb extends Component {
|
||||
}
|
||||
|
||||
private renderContent(): ReactNode {
|
||||
return <div className="app-root">
|
||||
<HeaderBar/>
|
||||
<Theme
|
||||
className="test"
|
||||
fontLevel={FontLevel.Level2}
|
||||
backgroundLevel={BackgroundLevel.Level1}
|
||||
>
|
||||
Theme
|
||||
</Theme>
|
||||
<Localization i18nKey="EN_US"/>
|
||||
</div>
|
||||
return <Theme
|
||||
className="app-root"
|
||||
backgroundLevel={BackgroundLevel.Level5}
|
||||
>
|
||||
<HeaderBar height={45}/>
|
||||
</Theme>
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user