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 => {
-
-