main
Last change
on this file since 5d6f37a was 5d6f37a, checked in by Naum Shapkarovski <naumshapkarovski@…>, 7 weeks ago |
add customer
|
-
Property mode
set to
100644
|
File size:
1.5 KB
|
Rev | Line | |
---|
[5d6f37a] | 1 | import { m } from 'framer-motion';
|
---|
| 2 | // @mui
|
---|
| 3 | import { Theme, SxProps } from '@mui/material/styles';
|
---|
| 4 | import Box from '@mui/material/Box';
|
---|
| 5 | import IconButton from '@mui/material/IconButton';
|
---|
| 6 | import Badge, { badgeClasses } from '@mui/material/Badge';
|
---|
| 7 | // components
|
---|
| 8 | import Iconify from 'src/components/iconify';
|
---|
| 9 | import { varHover } from 'src/components/animate';
|
---|
| 10 | import { useSettingsContext } from 'src/components/settings';
|
---|
| 11 |
|
---|
| 12 | // ----------------------------------------------------------------------
|
---|
| 13 |
|
---|
| 14 | type Props = {
|
---|
| 15 | sx?: SxProps<Theme>;
|
---|
| 16 | };
|
---|
| 17 |
|
---|
| 18 | export default function SettingsButton({ sx }: Props) {
|
---|
| 19 | const settings = useSettingsContext();
|
---|
| 20 |
|
---|
| 21 | return (
|
---|
| 22 | <Badge
|
---|
| 23 | color="error"
|
---|
| 24 | variant="dot"
|
---|
| 25 | invisible={!settings.canReset}
|
---|
| 26 | sx={{
|
---|
| 27 | [`& .${badgeClasses.badge}`]: {
|
---|
| 28 | top: 8,
|
---|
| 29 | right: 8,
|
---|
| 30 | },
|
---|
| 31 | ...sx,
|
---|
| 32 | }}
|
---|
| 33 | >
|
---|
| 34 | <Box
|
---|
| 35 | component={m.div}
|
---|
| 36 | animate={{
|
---|
| 37 | rotate: [0, settings.open ? 0 : 360],
|
---|
| 38 | }}
|
---|
| 39 | transition={{
|
---|
| 40 | duration: 12,
|
---|
| 41 | ease: 'linear',
|
---|
| 42 | repeat: Infinity,
|
---|
| 43 | }}
|
---|
| 44 | >
|
---|
| 45 | <IconButton
|
---|
| 46 | component={m.button}
|
---|
| 47 | whileTap="tap"
|
---|
| 48 | whileHover="hover"
|
---|
| 49 | variants={varHover(1.05)}
|
---|
| 50 | aria-label="settings"
|
---|
| 51 | onClick={settings.onToggle}
|
---|
| 52 | sx={{
|
---|
| 53 | width: 40,
|
---|
| 54 | height: 40,
|
---|
| 55 | }}
|
---|
| 56 | >
|
---|
| 57 | <Iconify icon="solar:settings-bold-duotone" width={24} />
|
---|
| 58 | </IconButton>
|
---|
| 59 | </Box>
|
---|
| 60 | </Badge>
|
---|
| 61 | );
|
---|
| 62 | }
|
---|
Note:
See
TracBrowser
for help on using the repository browser.