github.com/minio/console@v1.4.1/web-app/src/screens/Console/Common/DarkModeActivator/DarkModeActivator.tsx (about) 1 // This file is part of MinIO Console Server 2 // Copyright (c) 2023 MinIO, Inc. 3 // 4 // This program is free software: you can redistribute it and/or modify 5 // it under the terms of the GNU Affero General Public License as published by 6 // the Free Software Foundation, either version 3 of the License, or 7 // (at your option) any later version. 8 // 9 // This program is distributed in the hope that it will be useful, 10 // but WITHOUT ANY WARRANTY; without even the implied warranty of 11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 // GNU Affero General Public License for more details. 13 // 14 // You should have received a copy of the GNU Affero General Public License 15 // along with this program. If not, see <http://www.gnu.org/licenses/>. 16 17 import React from "react"; 18 import { Button, DarkModeIcon, LightModeIcon } from "mds"; 19 import TooltipWrapper from "../TooltipWrapper/TooltipWrapper"; 20 import { useSelector } from "react-redux"; 21 import { AppState, useAppDispatch } from "../../../../store"; 22 import { setDarkMode } from "../../../../systemSlice"; 23 import { storeDarkMode } from "../../../../utils/stylesUtils"; 24 25 const DarkModeActivator = () => { 26 const dispatch = useAppDispatch(); 27 28 const darkMode = useSelector((state: AppState) => state.system.darkMode); 29 30 const darkModeActivator = () => { 31 const currentStatus = !!darkMode; 32 33 dispatch(setDarkMode(!currentStatus)); 34 storeDarkMode(!currentStatus ? "on" : "off"); 35 }; 36 37 return ( 38 <TooltipWrapper tooltip={`${darkMode ? "Light" : "Dark"} Mode`}> 39 <Button 40 id={"dark-mode-activator"} 41 icon={darkMode ? <LightModeIcon /> : <DarkModeIcon />} 42 onClick={darkModeActivator} 43 /> 44 </TooltipWrapper> 45 ); 46 }; 47 48 export default DarkModeActivator;