{intl.formatMessage(messages.betawarning)}
import { MenuAlt2Icon } from '@heroicons/react/outline'; import { InformationCircleIcon } from '@heroicons/react/solid'; import { useRouter } from 'next/router'; import React, { useEffect, useState } from 'react'; import { defineMessages, useIntl } from 'react-intl'; import { Permission, useUser } from '../../hooks/useUser'; import LanguagePicker from './LanguagePicker'; import SearchInput from './SearchInput'; import Sidebar from './Sidebar'; import UserDropdown from './UserDropdown'; const messages = defineMessages({ betawarning: 'This is BETA software. Features may be broken and/or unstable. Please report any issues on GitHub!', }); const Layout: React.FC = ({ children }) => { const [isSidebarOpen, setSidebarOpen] = useState(false); const [isScrolled, setIsScrolled] = useState(false); const { hasPermission } = useUser(); const router = useRouter(); const intl = useIntl(); useEffect(() => { const updateScrolled = () => { if (window.pageYOffset > 60) { setIsScrolled(true); } else { setIsScrolled(false); } }; window.addEventListener('scroll', updateScrolled, { passive: true }); return () => { window.removeEventListener('scroll', updateScrolled); }; }, []); return (
{intl.formatMessage(messages.betawarning)}