mirror of
https://github.com/XRPLF/xrpl-dev-portal.git
synced 2026-04-29 15:37:48 +00:00
- Introduced LanguageDropdown for improved language selection in Navbar and MobileMenu. - Updated LanguagePill to display the current language dynamically and manage dropdown state. - Enhanced styles for language-related components to support open/close states and transitions. - Added mobile-specific dropdown positioning and styles for better user experience.
47 lines
1.6 KiB
TypeScript
47 lines
1.6 KiB
TypeScript
import * as React from "react";
|
|
import { SearchButton } from "./SearchButton";
|
|
import { ModeToggleButton } from "./ModeToggleButton";
|
|
import { LanguagePill } from "./LanguagePill";
|
|
import { LanguageDropdown } from "./LanguageDropdown";
|
|
|
|
interface NavControlsProps {
|
|
onSearch?: () => void;
|
|
}
|
|
|
|
/**
|
|
* Nav Controls Component.
|
|
* Right side of the navbar containing search, mode toggle, and language selector.
|
|
*/
|
|
export function NavControls({ onSearch }: NavControlsProps) {
|
|
const [isLanguageDropdownOpen, setIsLanguageDropdownOpen] = React.useState(false);
|
|
|
|
const handleModeToggle = () => {
|
|
// Toggle between light and dark theme
|
|
const newTheme = document.documentElement.classList.contains("dark") ? "light" : "dark";
|
|
window.localStorage.setItem("user-prefers-color", newTheme);
|
|
document.body.style.transition = "background-color .2s ease";
|
|
document.documentElement.classList.remove("dark", "light");
|
|
document.documentElement.classList.add(newTheme);
|
|
};
|
|
|
|
const handleLanguageClick = () => {
|
|
setIsLanguageDropdownOpen(!isLanguageDropdownOpen);
|
|
};
|
|
|
|
const handleLanguageDropdownClose = () => {
|
|
setIsLanguageDropdownOpen(false);
|
|
};
|
|
|
|
return (
|
|
<div className="bds-navbar__controls">
|
|
<SearchButton onClick={onSearch} />
|
|
<ModeToggleButton onClick={handleModeToggle} />
|
|
<div className="bds-navbar__lang-wrapper">
|
|
<LanguagePill onClick={handleLanguageClick} isOpen={isLanguageDropdownOpen} />
|
|
<LanguageDropdown isOpen={isLanguageDropdownOpen} onClose={handleLanguageDropdownClose} />
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|