1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
/*
* Copyright (C) 2021-2022 Kristóf Marussy <kristof@marussy.com>
*
* 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 <https://www.gnu.org/licenses/>.
*
* SPDX-License-Identifier: AGPL-3.0-only
*/
import Box from '@mui/material/Box';
import { alpha } from '@mui/material/styles';
import React from 'react';
import ServiceSwitcher from './ServiceSwitcher';
import ToggleDarkModeButton from './ToggleDarkModeButton';
import ToggleLocationBarButton from './ToggleLocationBarButton';
export default function Sidebar(): JSX.Element {
return (
<Box
component="aside"
sx={(theme) => ({
flex: 0,
display: 'flex',
flexDirection: 'column',
alignItems: 'center',
paddingY: 1,
gap: 1,
background: alpha(theme.palette.text.primary, 0.09),
backgroundClip: 'padding-box',
borderInlineEnd: `1px solid ${theme.palette.divider}`,
minWidth: 69,
})}
>
<ToggleLocationBarButton />
<ServiceSwitcher />
<Box
sx={{
flex: 1,
WebkitAppRegion: 'drag',
}}
/>
<ToggleDarkModeButton />
</Box>
);
}
|