first commit

This commit is contained in:
2026-04-18 16:58:50 +03:00
commit 8fc3243687
28 changed files with 7777 additions and 0 deletions

View File

@@ -0,0 +1,140 @@
---
import config from 'virtual:starlight/user-config';
import LanguageSelect from 'virtual:starlight/components/LanguageSelect';
import Search from 'virtual:starlight/components/Search';
import SiteTitle from 'virtual:starlight/components/SiteTitle';
import SocialIcons from 'virtual:starlight/components/SocialIcons';
import ThemeSelect from 'virtual:starlight/components/ThemeSelect';
const shouldRenderSearch =
config.pagefind || config.components.Search !== '@astrojs/starlight/components/Search.astro';
const topLinks = [
{ label: 'Старт', href: '/getting-started/' },
{ label: 'Гайды', href: '/guides/' },
{ label: 'Механики', href: '/mechanics/' },
{ label: 'FAQ', href: '/faq/' },
{ label: 'Правила', href: '/rules/' }
];
---
<div class="header wiki-header">
<div class="title-wrapper sl-flex">
<SiteTitle />
<nav class="wiki-top-nav" aria-label="Быстрая навигация">
{
topLinks.map((link) => (
<a href={link.href} class="wiki-top-nav__link">
{link.label}
</a>
))
}
</nav>
</div>
<div class="sl-flex print:hidden">
{shouldRenderSearch && <Search />}
</div>
<div class="sl-hidden md:sl-flex print:hidden right-group">
<div class="sl-flex social-icons">
<SocialIcons />
</div>
<ThemeSelect />
<LanguageSelect />
</div>
</div>
<style>
@layer starlight.core {
.wiki-header {
display: flex;
gap: var(--sl-nav-gap);
justify-content: space-between;
align-items: center;
height: 100%;
}
.title-wrapper {
overflow: clip;
padding: 0.25rem;
margin: -0.25rem;
min-width: 0;
gap: 1rem;
align-items: center;
}
.wiki-top-nav {
display: none;
gap: 0.45rem;
align-items: center;
}
.wiki-top-nav__link {
border: 1px solid transparent;
border-radius: 0.18rem;
padding: 0.36rem 0.74rem;
text-decoration: none;
color: var(--sl-color-gray-2);
font-size: 0.82rem;
font-family: 'Sora', sans-serif;
font-weight: 600;
letter-spacing: 0.01em;
transition: border-color 150ms ease, background 150ms ease, color 150ms ease;
}
.wiki-top-nav__link:hover {
border-color: color-mix(in srgb, var(--sl-color-accent) 28%, transparent);
background: color-mix(in srgb, var(--sl-color-accent-low) 65%, transparent);
color: var(--sl-color-white);
}
.right-group,
.social-icons {
gap: 1rem;
align-items: center;
}
.social-icons::after {
content: '';
height: 2rem;
border-inline-end: 1px solid var(--sl-color-gray-5);
}
@media (min-width: 64rem) {
.wiki-top-nav {
display: inline-flex;
}
}
@media (min-width: 50rem) {
:global(:root[data-has-sidebar]) {
--__sidebar-pad: calc(2 * var(--sl-nav-pad-x));
}
:global(:root:not([data-has-toc])) {
--__toc-width: 0rem;
}
.wiki-header {
--__sidebar-width: max(0rem, var(--sl-content-inline-start, 0rem) - var(--sl-nav-pad-x));
--__main-column-fr: calc(
(
100% + var(--__sidebar-pad, 0rem) - var(--__toc-width, var(--sl-sidebar-width)) -
(2 * var(--__toc-width, var(--sl-nav-pad-x))) - var(--sl-content-inline-start, 0rem) -
var(--sl-content-width)
) / 2
);
display: grid;
grid-template-columns: minmax(
calc(var(--__sidebar-width) + max(0rem, var(--__main-column-fr) - var(--sl-nav-gap))),
auto
)
1fr auto;
align-content: center;
}
}
}
</style>