Pfad-Link-Vergleich deckt nun mehr Möglichkeiten ab.
Raumstatusbild angefangen. Prefix von Überschriften entfernt. Links sind jetzt nur noch durch hovern unterstrichen. Signed-off-by: xoy <felix@erstfeld.net>
This commit is contained in:
parent
de06d2718d
commit
c111c4b9d5
8 changed files with 53 additions and 10 deletions
|
@ -13,6 +13,24 @@ let pages = [
|
|||
['supporte uns', '/support/', ''],
|
||||
]
|
||||
|
||||
function PathCheck(path, link) {
|
||||
if(path === link) {
|
||||
return ' ' + navStyles.navItemActive
|
||||
}
|
||||
|
||||
if(link !== '/' && path !== '/') {
|
||||
if(path.includes(link)){
|
||||
return ' ' + navStyles.navItemActive
|
||||
}
|
||||
|
||||
if(link.includes(path)){
|
||||
return ' ' + navStyles.navItemActive
|
||||
}
|
||||
}
|
||||
|
||||
return ''
|
||||
}
|
||||
|
||||
export default function Nav({ path }) {
|
||||
// nav items should always be active in the staticly generated html
|
||||
const isSSR = typeof window === 'undefined'
|
||||
|
@ -44,7 +62,7 @@ export default function Nav({ path }) {
|
|||
{pages.map(([title, link, device]) => (
|
||||
<Link
|
||||
key={title}
|
||||
className={navStyles.navItem + activeClasses(link) + ' ' + device}
|
||||
className={navStyles.navItem + PathCheck(path, link) + ' ' + device}
|
||||
activeClassName={navStyles.navItemActive}
|
||||
to={`${link}`}
|
||||
>
|
||||
|
|
|
@ -1,4 +1,5 @@
|
|||
import React, { useEffect, useState } from 'react'
|
||||
import { StaticImage } from 'gatsby-plugin-image'
|
||||
|
||||
const roomStateData = {
|
||||
loading: { text: '...', color: 'white' },
|
||||
|
@ -7,6 +8,24 @@ const roomStateData = {
|
|||
error: { text: 'laut API kaputt', color: '#ee3333' },
|
||||
}
|
||||
|
||||
function GetRightImage(openState) {
|
||||
if(openState === 'loading') {
|
||||
return <StaticImage src='../images/warning.png' width='250' height='250' alt='...' />
|
||||
}
|
||||
|
||||
if(openState === 'open'){
|
||||
return <StaticImage src='../images/tuer_offen.png' width='250' height='250' alt='offen' />
|
||||
}
|
||||
|
||||
if(openState === 'closed'){
|
||||
return <StaticImage src='../images/tuer_zu.png' width='250' height='250' alt='geschlossen' />
|
||||
}
|
||||
|
||||
if(openState === 'error'){
|
||||
return <StaticImage src='../images/warning.png' width='250' height='250' alt='laut API kaputt' />
|
||||
}
|
||||
}
|
||||
|
||||
export default function RoomState() {
|
||||
const [openState, setOpenState] = useState('loading')
|
||||
|
||||
|
@ -25,12 +44,13 @@ export default function RoomState() {
|
|||
}, [])
|
||||
|
||||
const isSSR = typeof window === 'undefined'
|
||||
const useIMG = false
|
||||
return (
|
||||
<a
|
||||
href="https://status.ctdo.de/"
|
||||
style={{ color: roomStateData[openState].color }}
|
||||
>
|
||||
{isSSR ? '<Benötigt JavaScript>' : roomStateData[openState].text}
|
||||
{isSSR ? '<Benötigt JavaScript>' : useIMG ? GetRightImage(openState) : roomStateData[openState].text}
|
||||
</a>
|
||||
)
|
||||
}
|
||||
|
|
BIN
src/images/tuer_offen.png
Normal file
BIN
src/images/tuer_offen.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.6 KiB |
BIN
src/images/tuer_zu.png
Normal file
BIN
src/images/tuer_zu.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.2 KiB |
BIN
src/images/warning.png
Normal file
BIN
src/images/warning.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 30 KiB |
|
@ -22,6 +22,11 @@ body {
|
|||
|
||||
a {
|
||||
color: #22bb22;
|
||||
text-decoration: none;
|
||||
}
|
||||
|
||||
a:hover {
|
||||
text-decoration: underline;
|
||||
}
|
||||
|
||||
a:visited {
|
||||
|
|
|
@ -5,10 +5,10 @@ import { MDXRenderer } from 'gatsby-plugin-mdx'
|
|||
import { MDXProvider } from '@mdx-js/react'
|
||||
import { Helmet } from 'react-helmet'
|
||||
|
||||
const MdLeakH1 = (props) => <h2 {...props}># {props.children}</h2>
|
||||
const MdLeakH2 = (props) => <h3 {...props}>## {props.children}</h3>
|
||||
const MdLeakH3 = (props) => <h4 {...props}>### {props.children}</h4>
|
||||
const MdLeakH4 = (props) => <h5 {...props}>#### {props.children}</h5>
|
||||
const MdLeakH1 = (props) => <h2 {...props}>{props.children}</h2>
|
||||
const MdLeakH2 = (props) => <h3 {...props}>{props.children}</h3>
|
||||
const MdLeakH3 = (props) => <h4 {...props}>{props.children}</h4>
|
||||
const MdLeakH4 = (props) => <h5 {...props}>{props.children}</h5>
|
||||
|
||||
const components = {
|
||||
h1: MdLeakH1,
|
||||
|
|
|
@ -8,10 +8,10 @@ import { Helmet } from 'react-helmet'
|
|||
const ide =
|
||||
'https://repos.ctdo.de/neri/ctdo-homepage/_edit/master/src/webpages/'
|
||||
|
||||
const MdLeakH1 = (props) => <h2 {...props}># {props.children}</h2>
|
||||
const MdLeakH2 = (props) => <h3 {...props}>## {props.children}</h3>
|
||||
const MdLeakH3 = (props) => <h4 {...props}>### {props.children}</h4>
|
||||
const MdLeakH4 = (props) => <h5 {...props}>#### {props.children}</h5>
|
||||
const MdLeakH1 = (props) => <h2 {...props}>{props.children}</h2>
|
||||
const MdLeakH2 = (props) => <h3 {...props}>{props.children}</h3>
|
||||
const MdLeakH3 = (props) => <h4 {...props}>{props.children}</h4>
|
||||
const MdLeakH4 = (props) => <h5 {...props}>{props.children}</h5>
|
||||
|
||||
const components = {
|
||||
h1: MdLeakH1,
|
||||
|
|
Loading…
Reference in a new issue