From ce7d7b6022f6752d33290695733ded9cf36455c1 Mon Sep 17 00:00:00 2001 From: Antoine Dewez <44063631+Zewed@users.noreply.github.com> Date: Fri, 26 Jan 2024 22:20:23 -0800 Subject: [PATCH] fix(frontend): remove dark theme (#2100) # Description Please include a summary of the changes and the related issue. Please also include relevant motivation and context. ## Checklist before requesting a review Please delete options that are not relevant. - [ ] My code follows the style guidelines of this project - [ ] I have performed a self-review of my code - [ ] I have commented hard-to-understand areas - [ ] I have ideally added tests that prove my fix is effective or that my feature works - [ ] New and existing unit tests pass locally with my changes - [ ] Any dependent changes have been merged ## Screenshots (if appropriate): --- .../components/ThemeSelect/DarkModeToggle.tsx | 21 --------- .../components/ThemeSelect/ThemeSelect.tsx | 46 ------------------- .../__tests__/ThemeSelect.test.tsx | 45 ------------------ .../components/ThemeSelect/hooks/useTheme.ts | 44 ------------------ frontend/app/user/page.tsx | 3 -- 5 files changed, 159 deletions(-) delete mode 100644 frontend/app/user/components/ThemeSelect/DarkModeToggle.tsx delete mode 100644 frontend/app/user/components/ThemeSelect/ThemeSelect.tsx delete mode 100644 frontend/app/user/components/ThemeSelect/__tests__/ThemeSelect.test.tsx delete mode 100644 frontend/app/user/components/ThemeSelect/hooks/useTheme.ts diff --git a/frontend/app/user/components/ThemeSelect/DarkModeToggle.tsx b/frontend/app/user/components/ThemeSelect/DarkModeToggle.tsx deleted file mode 100644 index d3ed68664b14..000000000000 --- a/frontend/app/user/components/ThemeSelect/DarkModeToggle.tsx +++ /dev/null @@ -1,21 +0,0 @@ -/* eslint-disable */ -"use client"; -import { MdDarkMode, MdLightMode } from "react-icons/md"; - -import Button from "@/lib/components/ui/Button"; -import { useTheme } from "./hooks/useTheme"; - -export const DarkModeToggle = (): JSX.Element => { - const { isDark, setTheme } = useTheme(); - - return ( - - ); -}; diff --git a/frontend/app/user/components/ThemeSelect/ThemeSelect.tsx b/frontend/app/user/components/ThemeSelect/ThemeSelect.tsx deleted file mode 100644 index 706d484dd0b9..000000000000 --- a/frontend/app/user/components/ThemeSelect/ThemeSelect.tsx +++ /dev/null @@ -1,46 +0,0 @@ -"use client"; - -import { FormEvent } from "react"; -import { useTranslation } from "react-i18next"; - -/* eslint-disable-next-line sort-imports */ -import { useTheme, type Theme } from "./hooks/useTheme"; - -const ThemeSelect = (): JSX.Element => { - const { theme, setTheme } = useTheme(); - const { t } = useTranslation(["translation"]); - const handleChange = (e: FormEvent) => { - setTheme(e.currentTarget.value as Theme); - }; - - return ( -
- - - -
- ); -}; - -ThemeSelect.displayName = "ThemeSelect"; - -export default ThemeSelect; diff --git a/frontend/app/user/components/ThemeSelect/__tests__/ThemeSelect.test.tsx b/frontend/app/user/components/ThemeSelect/__tests__/ThemeSelect.test.tsx deleted file mode 100644 index b2df4f4f2304..000000000000 --- a/frontend/app/user/components/ThemeSelect/__tests__/ThemeSelect.test.tsx +++ /dev/null @@ -1,45 +0,0 @@ -import { fireEvent, render } from "@testing-library/react"; -import { afterEach, describe, expect, it, vi } from "vitest"; - -import ThemeSelect from "../ThemeSelect"; - -const useTranslationMock = vi.fn(() => ({ - t: (str: string): string => str, -})); - -vi.mock("react-i18next", () => ({ - useTranslation: () => useTranslationMock(), -})); - -describe("ThemeSelect", () => { - afterEach(() => { - vi.restoreAllMocks(); - }); - - it("should render ThemeSelect component", () => { - const { getByTestId } = render(); - const select = getByTestId("theme-select"); - expect(select).toBeDefined(); - expect(getByTestId("theme-dark")).toBeDefined(); - - // defaults to light - const lightOption = getByTestId("theme-light") as HTMLOptionElement; - expect(lightOption).toBeDefined(); - expect(lightOption.selected).toBeTruthy(); - }); - - it.each([ - { input: "dark", expected: { dark: true, light: false } }, - { input: "light", expected: { dark: false, light: true } }, - ])("should select $input theme option", ({ input, expected }) => { - const { getByTestId } = render(); - const select = getByTestId("theme-select"); - const darkOption = getByTestId("theme-dark") as HTMLOptionElement; - const lightOption = getByTestId("theme-light") as HTMLOptionElement; - - fireEvent.change(select, { target: { value: input } }); - - expect(darkOption.selected).toBe(expected.dark); - expect(lightOption.selected).toBe(expected.light); - }); -}); diff --git a/frontend/app/user/components/ThemeSelect/hooks/useTheme.ts b/frontend/app/user/components/ThemeSelect/hooks/useTheme.ts deleted file mode 100644 index b3020eb51102..000000000000 --- a/frontend/app/user/components/ThemeSelect/hooks/useTheme.ts +++ /dev/null @@ -1,44 +0,0 @@ -import { useEffect, useLayoutEffect, useState } from "react"; - -export type Theme = "dark" | "light" | "system"; - -/** - * @todo implement "system" theme - */ -export const useTheme = (): { - isDark: boolean; - isLight: boolean; - theme: Theme; - setTheme: (t: Theme) => void; -} => { - const [theme, setTheme] = useState("light"); - const isDark = theme === "dark"; - const isLight = theme === "light"; - - useLayoutEffect(() => { - const savedTheme = localStorage.getItem("theme"); - - if (savedTheme === "dark") { - document.body.parentElement?.classList.add("dark"); - - setTheme(savedTheme); - } - }, []); - - useEffect(() => { - if (isDark) { - document.body.parentElement?.classList.add("dark"); - } else { - document.body.parentElement?.classList.remove("dark"); - } - - localStorage.setItem("theme", theme); - }, [theme, isDark]); - - return { - isDark, - isLight, - theme, - setTheme, - }; -}; diff --git a/frontend/app/user/page.tsx b/frontend/app/user/page.tsx index cd667713d923..ae59da822dbf 100644 --- a/frontend/app/user/page.tsx +++ b/frontend/app/user/page.tsx @@ -11,7 +11,6 @@ import { StripePricingOrManageButton, UserStatistics } from "./components"; import { ApiKeyConfig } from "./components/ApiKeyConfig"; import LanguageSelect from "./components/LanguageSelect/LanguageSelect"; import { LogoutModal } from "./components/LogoutCard/LogoutModal"; -import ThemeSelect from "./components/ThemeSelect/ThemeSelect"; const UserPage = (): JSX.Element => { const { session } = useSupabase(); @@ -58,8 +57,6 @@ const UserPage = (): JSX.Element => { - -