0
Fork 0
mirror of https://github.com/stonith404/pingvin-share.git synced 2025-01-15 01:14:27 -05:00

Add dark mode toggle

This commit is contained in:
Elias Schneider 2022-05-11 15:32:28 +02:00
parent c15cb062a8
commit a5f450d80f
No known key found for this signature in database
GPG key ID: D5EC1C72D93244FD
4 changed files with 18 additions and 21 deletions

View file

@ -5,7 +5,7 @@ export default [
$write: [],
name: "Shares",
enabled: true,
permission: "collection",
permission: "document",
attributes: [
{
key: "securityID",

View file

@ -1,7 +1,8 @@
import { ActionIcon, Avatar, Menu } from "@mantine/core";
import { ActionIcon, Avatar, Menu, Switch } from "@mantine/core";
import { NextLink } from "@mantine/next";
import { DoorExit, Link } from "tabler-icons-react";
import { DoorExit, Link, Moon } from "tabler-icons-react";
import aw from "../../utils/appwrite.util";
import ToggleThemeButton from "./ToggleThemeButton";
const ActionAvatar = () => {
return (
@ -36,6 +37,10 @@ const ActionAvatar = () => {
>
Sign out
</Menu.Item>
<Menu.Label>Settings</Menu.Label>
<Menu.Item icon={<Moon size={14} />}>
<ToggleThemeButton />
</Menu.Item>
</Menu>
);
};

View file

@ -1,25 +1,18 @@
import { ActionIcon, useMantineColorScheme } from "@mantine/core";
import { Sun, MoonStars } from "tabler-icons-react";
import { Switch, useMantineColorScheme } from "@mantine/core";
const ToggleThemeButton = () => {
const { colorScheme, toggleColorScheme } = useMantineColorScheme();
return (
<ActionIcon
onClick={() => toggleColorScheme()}
sx={(theme) => ({
backgroundColor:
theme.colorScheme === "dark"
? theme.colors.dark[6]
: theme.colors.gray[0],
color:
theme.colorScheme === "dark"
? theme.colors.yellow[4]
: theme.colors.violet,
})}
>
{colorScheme === "dark" ? <Sun size={18} /> : <MoonStars size={18} />}
</ActionIcon>
<Switch
size="sm"
checked={colorScheme == "dark"}
onClick={(v) =>
toggleColorScheme(v.currentTarget.checked ? "dark" : "light")
}
onLabel="ON"
offLabel="OFF"
/>
);
};

View file

@ -1,7 +1,6 @@
import {
ColorScheme,
Container,
Group,
LoadingOverlay,
MantineProvider,
Stack,