diff --git a/frontend/app/App.jsx b/frontend/app/App.jsx
index 4683b99..8d4a3da 100644
--- a/frontend/app/App.jsx
+++ b/frontend/app/App.jsx
@@ -1,21 +1,47 @@
"use client";
+import "beercss";
+import "material-dynamic-colors";
import { NavigationRail } from "@/app/components/NavigationRail/NavigationRail";
-import { useThemeStore } from "./store/theme-store";
-import { useEffect } from "react";
-// import { useStore } from "./store/app-store";
+import { setTheme, getTheme, setMode, getMode } from "./store/theme-store";
+import { useEffect, useState } from "react";
+import { ColorPicker } from "@/app/components/ColorPicker/ColorPicker";
export const App = (props) => {
- const themeStore = useThemeStore();
+ const [colorPicker, setColorPicker] = useState(false);
+
+ const theme = async (from) => {
+ setTheme(from);
+ await ui("theme", from);
+ };
+
+ const mode = () => {
+ let newMode = ui("mode") == "dark" ? "light" : "dark";
+ setMode(newMode);
+ ui("mode", getMode());
+ };
useEffect(() => {
- themeStore.checkTheme();
+ const mode = getMode();
+ const theme = getTheme();
+ if (mode != ui("mode")) {
+ ui("mode", getMode());
+ }
+ if (theme != ui("theme")) {
+ ui("theme", theme);
+ }
}, []);
return (
-
-
- {props.children}
+
+
+
+ {colorPicker && }
+ {props.children}
+
);
};
diff --git a/frontend/app/components/ColorPicker/ColorPicker.jsx b/frontend/app/components/ColorPicker/ColorPicker.jsx
new file mode 100644
index 0000000..d8827d8
--- /dev/null
+++ b/frontend/app/components/ColorPicker/ColorPicker.jsx
@@ -0,0 +1,48 @@
+"use client";
+
+import { useState } from "react";
+import Styles from "./ColorPicker.module.css"
+
+export const ColorPicker = (props) => {
+ const colors = [
+ { hex: "#ffffff", color: "white" },
+ { hex: "#e91e63", color: "pink" },
+ { hex: "#ff9800", color: "orange" },
+ { hex: "#4caf50", color: "green" },
+ { hex: "#009688", color: "teal" },
+ { hex: "#9c27b0", color: "purple" },
+ { hex: "#673ab7", color: "deep-purple" },
+ { hex: "#ffeb3b", color: "yellow" },
+ { hex: "#ffc8ff", color: Styles["radiquum-pink"]},
+ { hex: "#0087c7", color: Styles["fuxigen-blue"]},
+ { hex: "#e54040", color: Styles["anixart-red"]},
+ ];
+ const [mode, setMode] = useState(ui("mode"));
+
+ return (
+
+ );
+};
diff --git a/frontend/app/components/ColorPicker/ColorPicker.module.css b/frontend/app/components/ColorPicker/ColorPicker.module.css
new file mode 100644
index 0000000..f1afadf
--- /dev/null
+++ b/frontend/app/components/ColorPicker/ColorPicker.module.css
@@ -0,0 +1,9 @@
+.radiquum-pink{
+ background-color: #ffc8ff !important;
+}
+.fuxigen-blue{
+ background-color: #0087c7 !important;
+}
+.anixart-red{
+ background-color: #e54040 !important;
+}
\ No newline at end of file
diff --git a/frontend/app/components/NavigationRail/NavigationRail.jsx b/frontend/app/components/NavigationRail/NavigationRail.jsx
index 269f66d..1cdd9e4 100644
--- a/frontend/app/components/NavigationRail/NavigationRail.jsx
+++ b/frontend/app/components/NavigationRail/NavigationRail.jsx
@@ -1,12 +1,38 @@
"use client";
import { usePathname } from "next/navigation";
-import { useThemeStore } from "@/app/store/theme-store";
import Link from "next/link";
-export const NavigationRail = () => {
+export const NavigationRail = (props) => {
const pathname = usePathname();
- const themeStore = useThemeStore();
+
+ const items = [
+ {
+ title: "Домашняя",
+ icon: "home",
+ path: "/",
+ },
+ {
+ title: "Поиск",
+ icon: "search",
+ path: "/search",
+ },
+ {
+ title: "Закладки",
+ icon: "bookmark",
+ path: "/bookmarks",
+ },
+ {
+ title: "Избранное",
+ icon: "favorite",
+ path: "/favorites",
+ },
+ {
+ title: "История",
+ icon: "history",
+ path: "/history",
+ },
+ ];
return (
);
};
diff --git a/frontend/app/globals.css b/frontend/app/globals.css
index deea98c..f55e9e5 100644
--- a/frontend/app/globals.css
+++ b/frontend/app/globals.css
@@ -21,81 +21,3 @@ body, nav.left{
transition: background .2s;
transform-origin: left;
}
-
-body.light.light {
- --primary: #bc004b;
- --on-primary: #ffffff;
- --primary-container: #ffd9de;
- --on-primary-container: #400014;
- --secondary: #75565b;
- --on-secondary: #ffffff;
- --secondary-container: #ffd9de;
- --on-secondary-container: #2c1519;
- --tertiary: #795831;
- --on-tertiary: #ffffff;
- --tertiary-container: #ffddba;
- --on-tertiary-container: #2b1700;
- --error: #ba1a1a;
- --on-error: #ffffff;
- --error-container: #ffdad6;
- --on-error-container: #410002;
- --background: #fffbff;
- --on-background: #201a1b;
- --surface: #fff8f7;
- --on-surface: #201a1b;
- --surface-variant: #f3dddf;
- --on-surface-variant: #524345;
- --outline: #847375;
- --outline-variant: #d6c2c3;
- --shadow: #000000;
- --scrim: #000000;
- --inverse-surface: #362f2f;
- --inverse-on-surface: #fbeeee;
- --inverse-primary: #ffb2be;
- --surface-dim: #e3d7d8;
- --surface-bright: #fff8f7;
- --surface-container-lowest: #ffffff;
- --surface-container-low: #fdf1f1;
- --surface-container: #f8ebeb;
- --surface-container-high: #f2e5e6;
- --surface-container-highest: #ece0e0;
-}
-
-body.dark.dark {
- --primary: #ffb2be;
- --on-primary: #660025;
- --primary-container: #900038;
- --on-primary-container: #ffd9de;
- --secondary: #e5bdc2;
- --on-secondary: #43292d;
- --secondary-container: #5c3f43;
- --on-secondary-container: #ffd9de;
- --tertiary: #ebbf90;
- --on-tertiary: #452b08;
- --tertiary-container: #5f411c;
- --on-tertiary-container: #ffddba;
- --error: #ffb4ab;
- --on-error: #690005;
- --error-container: #93000a;
- --on-error-container: #ffb4ab;
- --background: #201a1b;
- --on-background: #ece0e0;
- --surface: #181213;
- --on-surface: #ece0e0;
- --surface-variant: #524345;
- --on-surface-variant: #d6c2c3;
- --outline: #9f8c8e;
- --outline-variant: #524345;
- --shadow: #000000;
- --scrim: #000000;
- --inverse-surface: #ece0e0;
- --inverse-on-surface: #362f2f;
- --inverse-primary: #bc004b;
- --surface-dim: #181213;
- --surface-bright: #3f3738;
- --surface-container-lowest: #120d0d;
- --surface-container-low: #201a1b;
- --surface-container: #241e1f;
- --surface-container-high: #2f2829;
- --surface-container-highest: #3a3334;
-}
\ No newline at end of file
diff --git a/frontend/app/layout.js b/frontend/app/layout.js
index bf915f1..e615634 100644
--- a/frontend/app/layout.js
+++ b/frontend/app/layout.js
@@ -1,5 +1,4 @@
import "./globals.css";
-import "beercss";
import {App} from "@/app/App"
export const metadata = {
diff --git a/frontend/app/page.js b/frontend/app/page.js
index dccd559..de48d18 100644
--- a/frontend/app/page.js
+++ b/frontend/app/page.js
@@ -28,7 +28,12 @@ export default function Home() {
// set list on initial page load
useEffect(() => {
- setList(searchParams.get("list") || "last");
+ const query = searchParams.get("list");
+ if (query) {
+ setList(query);
+ } else {
+ setList("last");
+ }
}, []);
async function fetchData(list, page = 0) {
@@ -44,10 +49,12 @@ export default function Home() {
}
useEffect(() => {
- router.push(pathname + "?" + createQueryString("list", list));
- setReleases(null);
- setPage(0);
- fetchData(list); // Call fetchData here
+ if (list) {
+ router.push(pathname + "?" + createQueryString("list", list));
+ setReleases(null);
+ setPage(0);
+ fetchData(list); // Call fetchData here
+ }
}, [list]);
useEffect(() => {
@@ -81,6 +88,7 @@ export default function Home() {
{chips.map((item) => {
return (
{
setList(item.list);
diff --git a/frontend/app/store/theme-store.js b/frontend/app/store/theme-store.js
index 3903029..dfc5185 100644
--- a/frontend/app/store/theme-store.js
+++ b/frontend/app/store/theme-store.js
@@ -1,5 +1,10 @@
"use client";
-import { create } from "zustand";
+export function setMode(mode) {
+ localStorage.setItem("mode", mode);
+}
+export function getMode() {
+ return localStorage.getItem("mode");
+}
export function setTheme(theme) {
localStorage.setItem("theme", theme);
@@ -8,13 +13,3 @@ export function getTheme() {
return localStorage.getItem("theme");
}
-export const useThemeStore = create((set) => ({
- theme: "light",
- changeTheme: (theme) => {
- set({ theme: theme });
- setTheme(theme);
- },
- checkTheme: () => {
- set({ theme: getTheme() || "light" });
- }
-}));