Move page list to header for easier navigation.
rodzic
3090d9fd89
commit
a917f40da9
18
index.html
18
index.html
|
@ -30,6 +30,24 @@ select {
|
|||
margin-top: 10px;
|
||||
margin-bottom: 10px;
|
||||
}
|
||||
|
||||
ul.navbar {
|
||||
display: flex;
|
||||
list-style-type: none;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
justify-content: flex-end;
|
||||
}
|
||||
|
||||
ul.navbar li {
|
||||
border-right: 1px solid gray;
|
||||
margin-right: 8px;
|
||||
padding-right: 8px;
|
||||
}
|
||||
|
||||
ul.navbar li:last-child {
|
||||
border-right: none;
|
||||
}
|
||||
</style>
|
||||
<noscript>
|
||||
<p>Alas, you need JavaScript to peruse this page.</p>
|
||||
|
|
|
@ -26,6 +26,20 @@ if (!appEl) {
|
|||
throw new Error(`Unable to find #${APP_ID}!`);
|
||||
}
|
||||
|
||||
const Navbar: React.FC<{ currPageName: string }> = (props) => (
|
||||
<ul className="navbar">
|
||||
{pageNames.map((pageName) => (
|
||||
<li key={pageName}>
|
||||
{props.currPageName === pageName ? (
|
||||
pageName
|
||||
) : (
|
||||
<a href={`?p=${encodeURIComponent(pageName)}`}>{pageName}</a>
|
||||
)}
|
||||
</li>
|
||||
))}
|
||||
</ul>
|
||||
);
|
||||
|
||||
const App: React.FC<{}> = (props) => {
|
||||
const page = new URLSearchParams(window.location.search);
|
||||
const currPageName = toPageName(page.get("p") || "", "vocabulary");
|
||||
|
@ -33,22 +47,13 @@ const App: React.FC<{}> = (props) => {
|
|||
|
||||
return (
|
||||
<>
|
||||
<header>
|
||||
<Navbar currPageName={currPageName} />
|
||||
</header>
|
||||
<main>
|
||||
<PageComponent />
|
||||
</main>
|
||||
<footer>
|
||||
<p>Other pages</p>
|
||||
<ul>
|
||||
{pageNames.map((pageName) => (
|
||||
<li key={pageName}>
|
||||
{currPageName === pageName ? (
|
||||
pageName
|
||||
) : (
|
||||
<a href={`?p=${encodeURIComponent(pageName)}`}>{pageName}</a>
|
||||
)}
|
||||
</li>
|
||||
))}
|
||||
</ul>
|
||||
<p>
|
||||
For more details about this project, see its{" "}
|
||||
<a href="https://github.com/toolness/mystic-symbolic" target="_blank">
|
||||
|
|
Ładowanie…
Reference in New Issue