aboutsummaryrefslogtreecommitdiffstats
path: root/packages/renderer/src/components/locationBar/LocationBar.tsx
diff options
context:
space:
mode:
authorLibravatar Kristóf Marussy <kristof@marussy.com>2022-02-16 01:09:27 +0100
committerLibravatar Kristóf Marussy <kristof@marussy.com>2022-02-24 00:53:06 +0100
commit39231032ef9abfc3a90af7bf0460037aa220ce11 (patch)
tree0159913431d04689c5a988eb4d69e001486d9bac /packages/renderer/src/components/locationBar/LocationBar.tsx
parentchore(deps): Bump dependencies (diff)
downloadsophie-39231032ef9abfc3a90af7bf0460037aa220ce11.tar.gz
sophie-39231032ef9abfc3a90af7bf0460037aa220ce11.tar.zst
sophie-39231032ef9abfc3a90af7bf0460037aa220ce11.zip
feat: Basic location bar
Still needs adding event handlers to actually navigate the browser. Signed-off-by: Kristóf Marussy <kristof@marussy.com>
Diffstat (limited to 'packages/renderer/src/components/locationBar/LocationBar.tsx')
-rw-r--r--packages/renderer/src/components/locationBar/LocationBar.tsx54
1 files changed, 54 insertions, 0 deletions
diff --git a/packages/renderer/src/components/locationBar/LocationBar.tsx b/packages/renderer/src/components/locationBar/LocationBar.tsx
new file mode 100644
index 0000000..e1f470d
--- /dev/null
+++ b/packages/renderer/src/components/locationBar/LocationBar.tsx
@@ -0,0 +1,54 @@
1/*
2 * Copyright (C) 2022 Kristóf Marussy <kristof@marussy.com>
3 *
4 * This file is part of Sophie.
5 *
6 * Sophie is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU Affero General Public License as
8 * published by the Free Software Foundation, version 3.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU Affero General Public License for more details.
14 *
15 * You should have received a copy of the GNU Affero General Public License
16 * along with this program. If not, see <https://www.gnu.org/licenses/>.
17 *
18 * SPDX-License-Identifier: AGPL-3.0-only
19 */
20
21import { styled } from '@mui/material/styles';
22import { observer } from 'mobx-react-lite';
23import React from 'react';
24
25import { useStore } from '../StoreProvider';
26
27import LocationTextField from './LocationTextField';
28import NavigationButtons from './NavigationButtons';
29
30const LocationBarRoot = styled('header', {
31 name: 'LocationBar',
32 slot: 'Root',
33})(({ theme, hidden }) => ({
34 display: hidden ? 'none' : 'flex',
35 flexDirection: 'row',
36 padding: theme.spacing(1),
37 gap: theme.spacing(1),
38 borderBottom: `1px solid ${theme.palette.divider}`,
39}));
40
41function LocationBar(): JSX.Element {
42 const {
43 settings: { selectedService, showLocationBar },
44 } = useStore();
45
46 return (
47 <LocationBarRoot id="locationBar" hidden={!showLocationBar}>
48 <NavigationButtons service={selectedService} />
49 <LocationTextField service={selectedService} />
50 </LocationBarRoot>
51 );
52}
53
54export default observer(LocationBar);