Add LCARS2 display

This commit is contained in:
Tanner Collin 2023-04-05 04:54:49 +00:00
parent bc41a71219
commit d7aa8c824e
3 changed files with 48 additions and 1 deletions

View File

@ -29,7 +29,7 @@ import { NotFound, PleaseLogin } from './Misc.js';
import { Debug } from './Debug.js'; import { Debug } from './Debug.js';
import { Garden } from './Garden.js'; import { Garden } from './Garden.js';
import { Footer } from './Footer.js'; import { Footer } from './Footer.js';
import { LCARS1Display } from './Display.js'; import { LCARS1Display, LCARS2Display } from './Display.js';
const APP_VERSION = 5; // TODO: automate this const APP_VERSION = 5; // TODO: automate this
@ -130,6 +130,10 @@ function App() {
<LCARS1Display token={token} /> <LCARS1Display token={token} />
</Route> </Route>
<Route exact path='/display/lcars2'>
<LCARS2Display token={token} />
</Route>
<Route path='/'> <Route path='/'>
<Container> <Container>
<div className='hero'> <div className='hero'>

View File

@ -28,6 +28,8 @@ export function Debug(props) {
<p><Link to='/display/lcars1'>LCARS1 Display</Link></p> <p><Link to='/display/lcars1'>LCARS1 Display</Link></p>
<p><Link to='/display/lcars2'>LCARS2 Display</Link></p>
</Container> </Container>
); );

View File

@ -50,6 +50,47 @@ export function LCARS1Display(props) {
); );
}; };
export function LCARS2Display(props) {
const { token } = props;
const [fullElement, setFullElement] = useState(false);
const ref = useRef(null);
const goFullScreen = () => {
if ('wakeLock' in navigator) {
navigator.wakeLock.request('screen');
}
ref.current.requestFullscreen({ navigationUI: 'hide' }).then(() => {
setFullElement(true);
});
};
return (
<Container>
<div className='display' ref={ref}>
{!fullElement &&
<p>
<Button onClick={goFullScreen}>Fullscreen</Button>
</p>
}
<div className='display-scores'>
<DisplayScores />
</div>
<div className='display-scores'>
<DisplayHosting />
</div>
<div className='display-usage'>
<DisplayUsage token={token} name={'trotec'} />
</div>
</div>
</Container>
);
};
export function DisplayUsage(props) { export function DisplayUsage(props) {
const { token, name } = props; const { token, name } = props;
const title = deviceNames[name].title; const title = deviceNames[name].title;