/* * Copyright (C) 2022 Kristóf Marussy * * This file is part of Sophie. * * Sophie is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, version 3. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see . * * SPDX-License-Identifier: AGPL-3.0-only */ import { styled } from '@mui/material/styles'; import { observer } from 'mobx-react-lite'; import React from 'react'; import type Service from '../../stores/Service'; import { useStore } from '../StoreProvider'; import ExtraButtons from './ExtraButtons'; import LocationTextField from './LocationTextField'; import NavigationButtons from './NavigationButtons'; export function getLocaltionBarID(service: Service): string { return `Sophie-${service.id}-LocationBar`; } const LocationBarRoot = styled('header', { name: 'LocationBar', slot: 'Root', })(({ theme, hidden }) => ({ display: hidden ? 'none' : 'flex', flexDirection: 'row', padding: theme.spacing(1), gap: theme.spacing(1), borderBottom: `1px solid ${theme.palette.divider}`, })); function LocationBar({ service }: { service: Service }): JSX.Element { const { settings: { showLocationBar }, } = useStore(); const { alwaysShowLocationBar } = service; const locationBarVisible = showLocationBar || alwaysShowLocationBar; return ( ); } export default observer(LocationBar);