// Copyright 2025 Zentrum für Digitale Souveränität der Öffentlichen Verwaltung (ZenDiS) GmbH.
// SPDX-License-Identifier: MIT

import React from 'react'
import { DocsThemeConfig, useConfig } from 'nextra-theme-docs'
import Image from 'next/image'
import { useRouter } from 'next/router'
import Footer from './src/components/Footer'

const config: DocsThemeConfig = {
    head() {
        // eslint-disable-next-line react-hooks/rules-of-hooks
        const { asPath, defaultLocale, locale } = useRouter()
        // eslint-disable-next-line react-hooks/rules-of-hooks
        const { frontMatter, ...rest } = useConfig()
        const url =
            'http://localhost:3000' +
            (defaultLocale === locale ? asPath : `/${locale}${asPath}`)

        return (
            <>
                <meta property="og:url" content={url} />
                <meta
                    property="og:title"
                    content={
                        (frontMatter.title ?? rest.title) +
                            ' | Badge API Documentation' ||
                        'Badge API Documentation'
                    }
                />
                <title>
                    {(frontMatter.title ?? rest.title) +
                        ' | Badge API Documentation' ||
                        'Badge API Documentation'}
                </title>
            </>
        )
    },
    banner: {
        key: 'development',
        content: '🚧 Diese Dokumentation befindet sich aktuell im Aufbau.',
        dismissible: false,
    },
    i18n: [
        { locale: 'en', name: 'English' },
        { locale: 'de', name: 'Deutsch' },
    ],
    logo: (
        <span className="flex items-center space-x-2">
            <Image
                src="/assets/badge-programm-logo.svg"
                alt="Badge API Icon"
                width={220}
                height={80}
                className="h-12 w-auto md:inline-block"
            />

            <span className="font-space-grotesk text-xl font-bold text-black md:hidden lg:inline-block">
                Badge Programm
            </span>
        </span>
    ),
    sidebar: {
        defaultMenuCollapseLevel: 2,
    },
    project: {
        link: 'https://gitlab.opencode.de/open-code/badgebackend/badge-api',
        icon: (
            <Image
                src="/opencode-icon.svg"
                alt="OpenCode Icon"
                width={32}
                height={32}
            />
        ),
    },
    docsRepositoryBase:
        'https://gitlab.opencode.de/open-code/badgebackend/gitlab-profile/-/tree/main',
    backgroundColor: {
        dark: '12,17,23',
        light: '255,255,255',
    },
    color: {
        hue: {
            dark: 173,
            light: 228,
        },
        saturation: {
            dark: 100,
            light: 100,
        },
        lightness: {
            dark: 45,
            light: 46,
        },
    },
    darkMode: false,
    nextThemes: {
        defaultTheme: 'light',
        forcedTheme: 'light',
    },
    footer: {
        content: <Footer />,
    },
    navbar: {
        extraContent: (
            <div className="flex items-center space-x-4">
                <a
                    href="/de/leichte-sprache"
                    className="text-base font-medium hover:opacity-60"
                >
                    <img
                        src="/assets/leichte-sprache.svg"
                        alt="Leichte Sprache Icon"
                        width={24}
                        height={24}
                        className="h-6 w-auto"
                    />
                </a>
            </div>
        ),
    },
}

export default config