From f48e6b1a3e728d8c628040c2f9420337048da1a5 Mon Sep 17 00:00:00 2001 From: Timothy Carambat Date: Thu, 7 Dec 2023 09:09:01 -0800 Subject: [PATCH] chore: add @ as alias for frontend root (#414) * chore: add @ as alias for frontend root * fix: remove bad tag --- frontend/jsconfig.json | 7 +++- frontend/src/App.jsx | 40 +++++++++---------- frontend/src/AuthContext.jsx | 2 +- frontend/src/components/ChatBubble/index.jsx | 7 +--- frontend/src/components/DefaultChat/index.jsx | 12 ++---- .../LocalAiOptions/index.jsx | 2 +- .../LLMSelection/AnthropicAiOptions/index.jsx | 2 +- .../LLMSelection/LMStudioOptions/index.jsx | 2 +- .../LLMSelection/LocalAiOptions/index.jsx | 4 +- .../LLMSelection/OpenAiOptions/index.jsx | 2 +- .../src/components/Modals/NewWorkspace.jsx | 4 +- .../src/components/PrivateRoute/index.jsx | 10 ++--- .../src/components/SettingsSidebar/index.jsx | 8 ++-- .../Sidebar/ActiveWorkspaces/index.jsx | 6 +-- .../src/components/Sidebar/IndexCount.jsx | 4 +- frontend/src/components/Sidebar/LLMStatus.jsx | 2 +- frontend/src/components/Sidebar/index.jsx | 8 ++-- frontend/src/components/UserMenu/index.jsx | 6 +-- .../ChatHistory/HistoricalMessage/index.jsx | 9 ++--- .../ChatHistory/PromptReply/index.jsx | 2 +- .../ChatContainer/PromptInput/index.jsx | 2 +- .../WorkspaceChat/ChatContainer/index.jsx | 4 +- .../src/components/WorkspaceChat/index.jsx | 4 +- frontend/src/hooks/useLogo.js | 4 +- frontend/src/hooks/useUser.js | 2 +- frontend/src/main.jsx | 4 +- frontend/src/models/admin.js | 4 +- frontend/src/models/invite.js | 2 +- frontend/src/models/system.js | 4 +- frontend/src/models/workspace.js | 4 +- .../Admin/Invitations/InviteRow/index.jsx | 2 +- .../Invitations/NewInviteModal/index.jsx | 2 +- .../src/pages/Admin/Invitations/index.jsx | 8 ++-- frontend/src/pages/Admin/System/index.jsx | 8 ++-- .../pages/Admin/Users/NewUserModal/index.jsx | 4 +- .../Users/UserRow/EditUserModal/index.jsx | 2 +- .../src/pages/Admin/Users/UserRow/index.jsx | 2 +- frontend/src/pages/Admin/Users/index.jsx | 8 ++-- .../Workspaces/NewWorkspaceModal/index.jsx | 2 +- .../EditWorkspaceUsersModal/index.jsx | 2 +- .../Admin/Workspaces/WorkspaceRow/index.jsx | 4 +- frontend/src/pages/Admin/Workspaces/index.jsx | 8 ++-- .../ApiKeys/ApiKeyRow/index.jsx | 8 ++-- .../ApiKeys/NewApiKeyModal/index.jsx | 8 ++-- .../pages/GeneralSettings/ApiKeys/index.jsx | 12 +++--- .../GeneralSettings/Appearance/index.jsx | 16 ++++---- .../GeneralSettings/Chats/ChatRow/index.jsx | 2 +- .../src/pages/GeneralSettings/Chats/index.jsx | 10 ++--- .../EmbeddingPreference/index.jsx | 30 +++++++------- .../GeneralSettings/ExportImport/index.jsx | 15 +++---- .../GeneralSettings/LLMPreference/index.jsx | 32 +++++++-------- .../pages/GeneralSettings/Security/index.jsx | 18 +++------ .../GeneralSettings/VectorDatabase/index.jsx | 24 +++++------ .../src/pages/Invite/NewUserModal/index.jsx | 8 ++-- frontend/src/pages/Invite/index.jsx | 4 +- frontend/src/pages/Login/index.jsx | 6 +-- frontend/src/pages/Main/index.jsx | 12 +++--- .../Steps/AppearanceSetup/index.jsx | 8 ++-- .../Steps/CreateFirstWorkspace/index.jsx | 4 +- .../Steps/DataHandling/index.jsx | 26 ++++++------ .../Steps/EmbeddingSelection/index.jsx | 22 +++++----- .../Steps/LLMSelection/index.jsx | 26 ++++++------ .../Steps/MultiUserSetup/index.jsx | 8 +--- .../Steps/PasswordProtection/index.jsx | 8 +--- .../Steps/VectorDatabaseConnection/index.jsx | 16 ++++---- frontend/src/pages/OnboardingFlow/index.jsx | 2 +- frontend/src/pages/WorkspaceChat/index.jsx | 12 +++--- frontend/src/utils/toast.js | 2 +- frontend/vite.config.js | 2 + 69 files changed, 259 insertions(+), 307 deletions(-) diff --git a/frontend/jsconfig.json b/frontend/jsconfig.json index cffec62896..c8cc81fdbe 100644 --- a/frontend/jsconfig.json +++ b/frontend/jsconfig.json @@ -2,6 +2,11 @@ "compilerOptions": { "module": "commonjs", "target": "esnext", - "jsx": "react" + "jsx": "react", + "paths": { + "@/*": [ + "./src/*" + ], + } } } \ No newline at end of file diff --git a/frontend/src/App.jsx b/frontend/src/App.jsx index 2b8a645b3a..558e8ae3f7 100644 --- a/frontend/src/App.jsx +++ b/frontend/src/App.jsx @@ -1,42 +1,40 @@ import React, { lazy, Suspense } from "react"; import { Routes, Route } from "react-router-dom"; -import { ContextWrapper } from "./AuthContext"; +import { ContextWrapper } from "@/AuthContext"; import PrivateRoute, { AdminRoute, ManagerRoute, -} from "./components/PrivateRoute"; +} from "@/components/PrivateRoute"; import { ToastContainer } from "react-toastify"; import "react-toastify/dist/ReactToastify.css"; -import Login from "./pages/Login"; +import Login from "@/pages/Login"; -const Main = lazy(() => import("./pages/Main")); -const InvitePage = lazy(() => import("./pages/Invite")); -const WorkspaceChat = lazy(() => import("./pages/WorkspaceChat")); -const AdminUsers = lazy(() => import("./pages/Admin/Users")); -const AdminInvites = lazy(() => import("./pages/Admin/Invitations")); -const AdminWorkspaces = lazy(() => import("./pages/Admin/Workspaces")); -const AdminSystem = lazy(() => import("./pages/Admin/System")); -const GeneralChats = lazy(() => import("./pages/GeneralSettings/Chats")); +const Main = lazy(() => import("@/pages/Main")); +const InvitePage = lazy(() => import("@/pages/Invite")); +const WorkspaceChat = lazy(() => import("@/pages/WorkspaceChat")); +const AdminUsers = lazy(() => import("@/pages/Admin/Users")); +const AdminInvites = lazy(() => import("@/pages/Admin/Invitations")); +const AdminWorkspaces = lazy(() => import("@/pages/Admin/Workspaces")); +const AdminSystem = lazy(() => import("@/pages/Admin/System")); +const GeneralChats = lazy(() => import("@/pages/GeneralSettings/Chats")); const GeneralAppearance = lazy(() => - import("./pages/GeneralSettings/Appearance") + import("@/pages/GeneralSettings/Appearance") ); -const GeneralApiKeys = lazy(() => import("./pages/GeneralSettings/ApiKeys")); - +const GeneralApiKeys = lazy(() => import("@/pages/GeneralSettings/ApiKeys")); const GeneralLLMPreference = lazy(() => - import("./pages/GeneralSettings/LLMPreference") + import("@/pages/GeneralSettings/LLMPreference") ); const GeneralEmbeddingPreference = lazy(() => - import("./pages/GeneralSettings/EmbeddingPreference") + import("@/pages/GeneralSettings/EmbeddingPreference") ); const GeneralVectorDatabase = lazy(() => - import("./pages/GeneralSettings/VectorDatabase") + import("@/pages/GeneralSettings/VectorDatabase") ); const GeneralExportImport = lazy(() => - import("./pages/GeneralSettings/ExportImport") + import("@/pages/GeneralSettings/ExportImport") ); -const GeneralSecurity = lazy(() => import("./pages/GeneralSettings/Security")); - -const OnboardingFlow = lazy(() => import("./pages/OnboardingFlow")); +const GeneralSecurity = lazy(() => import("@/pages/GeneralSettings/Security")); +const OnboardingFlow = lazy(() => import("@/pages/OnboardingFlow")); export default function App() { return ( diff --git a/frontend/src/AuthContext.jsx b/frontend/src/AuthContext.jsx index 23e25a358e..34ec0cff7e 100644 --- a/frontend/src/AuthContext.jsx +++ b/frontend/src/AuthContext.jsx @@ -1,5 +1,5 @@ import React, { useState, createContext } from "react"; -import { AUTH_TIMESTAMP, AUTH_TOKEN, AUTH_USER } from "./utils/constants"; +import { AUTH_TIMESTAMP, AUTH_TOKEN, AUTH_USER } from "@/utils/constants"; export const AuthContext = createContext(null); export function ContextWrapper(props) { diff --git a/frontend/src/components/ChatBubble/index.jsx b/frontend/src/components/ChatBubble/index.jsx index f5e9475e96..72002ab292 100644 --- a/frontend/src/components/ChatBubble/index.jsx +++ b/frontend/src/components/ChatBubble/index.jsx @@ -1,10 +1,7 @@ import React from "react"; import Jazzicon from "../UserIcon"; -import { userFromStorage } from "../../utils/request"; -import { - AI_BACKGROUND_COLOR, - USER_BACKGROUND_COLOR, -} from "../../utils/constants"; +import { userFromStorage } from "@/utils/request"; +import { AI_BACKGROUND_COLOR, USER_BACKGROUND_COLOR } from "@/utils/constants"; export default function ChatBubble({ message, type, popMsg }) { const isUser = type === "user"; diff --git a/frontend/src/components/DefaultChat/index.jsx b/frontend/src/components/DefaultChat/index.jsx index 081ce17267..ca29b4700e 100644 --- a/frontend/src/components/DefaultChat/index.jsx +++ b/frontend/src/components/DefaultChat/index.jsx @@ -5,21 +5,17 @@ import { EnvelopeSimple, Plus, } from "@phosphor-icons/react"; - import NewWorkspaceModal, { useNewWorkspaceModal, } from "../Modals/NewWorkspace"; -import paths from "../../utils/paths"; +import paths from "@/utils/paths"; import { isMobile } from "react-device-detect"; import { SidebarMobileHeader } from "../Sidebar"; import ChatBubble from "../ChatBubble"; -import System from "../../models/system"; +import System from "@/models/system"; import Jazzicon from "../UserIcon"; -import { userFromStorage } from "../../utils/request"; -import { - AI_BACKGROUND_COLOR, - USER_BACKGROUND_COLOR, -} from "../../utils/constants"; +import { userFromStorage } from "@/utils/request"; +import { AI_BACKGROUND_COLOR, USER_BACKGROUND_COLOR } from "@/utils/constants"; export default function DefaultChatContainer() { const [mockMsgs, setMockMessages] = useState([]); diff --git a/frontend/src/components/EmbeddingSelection/LocalAiOptions/index.jsx b/frontend/src/components/EmbeddingSelection/LocalAiOptions/index.jsx index 109da0e4f9..73b8a5df89 100644 --- a/frontend/src/components/EmbeddingSelection/LocalAiOptions/index.jsx +++ b/frontend/src/components/EmbeddingSelection/LocalAiOptions/index.jsx @@ -1,5 +1,5 @@ import { useEffect, useState } from "react"; -import System from "../../../models/system"; +import System from "@/models/system"; export default function LocalAiOptions({ settings }) { const [basePathValue, setBasePathValue] = useState( diff --git a/frontend/src/components/LLMSelection/AnthropicAiOptions/index.jsx b/frontend/src/components/LLMSelection/AnthropicAiOptions/index.jsx index 454ab5f985..52bbbfd897 100644 --- a/frontend/src/components/LLMSelection/AnthropicAiOptions/index.jsx +++ b/frontend/src/components/LLMSelection/AnthropicAiOptions/index.jsx @@ -1,5 +1,5 @@ import { Info } from "@phosphor-icons/react"; -import paths from "../../../utils/paths"; +import paths from "@/utils/paths"; export default function AnthropicAiOptions({ settings, showAlert = false }) { return ( diff --git a/frontend/src/components/LLMSelection/LMStudioOptions/index.jsx b/frontend/src/components/LLMSelection/LMStudioOptions/index.jsx index 883b6e8ef9..7e9e8a8b6d 100644 --- a/frontend/src/components/LLMSelection/LMStudioOptions/index.jsx +++ b/frontend/src/components/LLMSelection/LMStudioOptions/index.jsx @@ -1,5 +1,5 @@ import { Info } from "@phosphor-icons/react"; -import paths from "../../../utils/paths"; +import paths from "@/utils/paths"; export default function LMStudioOptions({ settings, showAlert = false }) { return ( diff --git a/frontend/src/components/LLMSelection/LocalAiOptions/index.jsx b/frontend/src/components/LLMSelection/LocalAiOptions/index.jsx index 8adad7e50e..846c378374 100644 --- a/frontend/src/components/LLMSelection/LocalAiOptions/index.jsx +++ b/frontend/src/components/LLMSelection/LocalAiOptions/index.jsx @@ -1,7 +1,7 @@ import { useEffect, useState } from "react"; import { Info } from "@phosphor-icons/react"; -import paths from "../../../utils/paths"; -import System from "../../../models/system"; +import paths from "@/utils/paths"; +import System from "@/models/system"; export default function LocalAiOptions({ settings, showAlert = false }) { const [basePathValue, setBasePathValue] = useState(settings?.LocalAiBasePath); diff --git a/frontend/src/components/LLMSelection/OpenAiOptions/index.jsx b/frontend/src/components/LLMSelection/OpenAiOptions/index.jsx index 0e6a890ade..d9ca3f2970 100644 --- a/frontend/src/components/LLMSelection/OpenAiOptions/index.jsx +++ b/frontend/src/components/LLMSelection/OpenAiOptions/index.jsx @@ -1,5 +1,5 @@ import { useState, useEffect } from "react"; -import System from "../../../models/system"; +import System from "@/models/system"; export default function OpenAiOptions({ settings }) { const [inputValue, setInputValue] = useState(settings?.OpenAiKey); diff --git a/frontend/src/components/Modals/NewWorkspace.jsx b/frontend/src/components/Modals/NewWorkspace.jsx index fb48504045..4afd0faeeb 100644 --- a/frontend/src/components/Modals/NewWorkspace.jsx +++ b/frontend/src/components/Modals/NewWorkspace.jsx @@ -1,7 +1,7 @@ import React, { useRef, useState } from "react"; import { X } from "@phosphor-icons/react"; -import Workspace from "../../models/workspace"; -import paths from "../../utils/paths"; +import Workspace from "@/models/workspace"; +import paths from "@/utils/paths"; const noop = () => false; export default function NewWorkspaceModal({ hideModal = noop }) { diff --git a/frontend/src/components/PrivateRoute/index.jsx b/frontend/src/components/PrivateRoute/index.jsx index 7ca949b26a..ed2b833045 100644 --- a/frontend/src/components/PrivateRoute/index.jsx +++ b/frontend/src/components/PrivateRoute/index.jsx @@ -1,11 +1,11 @@ import { useEffect, useState } from "react"; import { Navigate } from "react-router-dom"; import { FullScreenLoader } from "../Preloader"; -import validateSessionTokenForUser from "../../utils/session"; -import paths from "../../utils/paths"; -import { AUTH_TIMESTAMP, AUTH_TOKEN, AUTH_USER } from "../../utils/constants"; -import { userFromStorage } from "../../utils/request"; -import System from "../../models/system"; +import validateSessionTokenForUser from "@/utils/session"; +import paths from "@/utils/paths"; +import { AUTH_TIMESTAMP, AUTH_TOKEN, AUTH_USER } from "@/utils/constants"; +import { userFromStorage } from "@/utils/request"; +import System from "@/models/system"; import UserMenu from "../UserMenu"; // Used only for Multi-user mode only as we permission specific pages based on auth role. diff --git a/frontend/src/components/SettingsSidebar/index.jsx b/frontend/src/components/SettingsSidebar/index.jsx index 89c71df30a..e599ee2b20 100644 --- a/frontend/src/components/SettingsSidebar/index.jsx +++ b/frontend/src/components/SettingsSidebar/index.jsx @@ -1,8 +1,8 @@ import React, { useEffect, useRef, useState } from "react"; // import IndexCount from "../Sidebar/IndexCount"; // import LLMStatus from "../Sidebar/LLMStatus"; -import paths from "../../utils/paths"; -import useLogo from "../../hooks/useLogo"; +import paths from "@/utils/paths"; +import useLogo from "@/hooks/useLogo"; import { DiscordLogo, EnvelopeSimple, @@ -23,8 +23,8 @@ import { List, FileCode, } from "@phosphor-icons/react"; -import useUser from "../../hooks/useUser"; -import { USER_BACKGROUND_COLOR } from "../../utils/constants"; +import useUser from "@/hooks/useUser"; +import { USER_BACKGROUND_COLOR } from "@/utils/constants"; export default function SettingsSidebar() { const { logo } = useLogo(); diff --git a/frontend/src/components/Sidebar/ActiveWorkspaces/index.jsx b/frontend/src/components/Sidebar/ActiveWorkspaces/index.jsx index fe14bf9f2c..cefd6b9777 100644 --- a/frontend/src/components/Sidebar/ActiveWorkspaces/index.jsx +++ b/frontend/src/components/Sidebar/ActiveWorkspaces/index.jsx @@ -1,15 +1,15 @@ import React, { useState, useEffect, useCallback } from "react"; import * as Skeleton from "react-loading-skeleton"; import "react-loading-skeleton/dist/skeleton.css"; -import Workspace from "../../../models/workspace"; +import Workspace from "@/models/workspace"; import ManageWorkspace, { useManageWorkspaceModal, } from "../../Modals/MangeWorkspace"; -import paths from "../../../utils/paths"; +import paths from "@/utils/paths"; import { useParams } from "react-router-dom"; import { GearSix, SquaresFour } from "@phosphor-icons/react"; import truncate from "truncate"; -import useUser from "../../../hooks/useUser"; +import useUser from "@/hooks/useUser"; export default function ActiveWorkspaces() { const { slug } = useParams(); diff --git a/frontend/src/components/Sidebar/IndexCount.jsx b/frontend/src/components/Sidebar/IndexCount.jsx index a31a1b72b6..9e0e126c60 100644 --- a/frontend/src/components/Sidebar/IndexCount.jsx +++ b/frontend/src/components/Sidebar/IndexCount.jsx @@ -1,7 +1,7 @@ import pluralize from "pluralize"; import React, { useEffect, useState } from "react"; -import System from "../../models/system"; -import { numberWithCommas } from "../../utils/numbers"; +import System from "@/models/system"; +import { numberWithCommas } from "@/utils/numbers"; export default function IndexCount() { const [indexes, setIndexes] = useState(null); diff --git a/frontend/src/components/Sidebar/LLMStatus.jsx b/frontend/src/components/Sidebar/LLMStatus.jsx index 553b7d4e02..733dcb1e77 100644 --- a/frontend/src/components/Sidebar/LLMStatus.jsx +++ b/frontend/src/components/Sidebar/LLMStatus.jsx @@ -1,6 +1,6 @@ import React, { useEffect, useState } from "react"; import { WarningCircle, Circle } from "@phosphor-icons/react"; -import System from "../../models/system"; +import System from "@/models/system"; export default function LLMStatus() { const [status, setStatus] = useState(null); diff --git a/frontend/src/components/Sidebar/index.jsx b/frontend/src/components/Sidebar/index.jsx index cbee14ae60..ac92f4830f 100644 --- a/frontend/src/components/Sidebar/index.jsx +++ b/frontend/src/components/Sidebar/index.jsx @@ -12,10 +12,10 @@ import NewWorkspaceModal, { useNewWorkspaceModal, } from "../Modals/NewWorkspace"; import ActiveWorkspaces from "./ActiveWorkspaces"; -import paths from "../../utils/paths"; -import { USER_BACKGROUND_COLOR } from "../../utils/constants"; -import useLogo from "../../hooks/useLogo"; -import useUser from "../../hooks/useUser"; +import paths from "@/utils/paths"; +import { USER_BACKGROUND_COLOR } from "@/utils/constants"; +import useLogo from "@/hooks/useLogo"; +import useUser from "@/hooks/useUser"; export default function Sidebar() { const { user } = useUser(); diff --git a/frontend/src/components/UserMenu/index.jsx b/frontend/src/components/UserMenu/index.jsx index 6a549f8202..8bfc1b9346 100644 --- a/frontend/src/components/UserMenu/index.jsx +++ b/frontend/src/components/UserMenu/index.jsx @@ -1,9 +1,9 @@ import React, { useState, useEffect, useRef } from "react"; import { isMobile } from "react-device-detect"; -import paths from "../../utils/paths"; -import { AUTH_TIMESTAMP, AUTH_TOKEN, AUTH_USER } from "../../utils/constants"; +import paths from "@/utils/paths"; +import { AUTH_TIMESTAMP, AUTH_TOKEN, AUTH_USER } from "@/utils/constants"; import { Person, SignOut } from "@phosphor-icons/react"; -import { userFromStorage } from "../../utils/request"; +import { userFromStorage } from "@/utils/request"; export default function UserMenu({ children }) { if (isMobile) return <>{children}; diff --git a/frontend/src/components/WorkspaceChat/ChatContainer/ChatHistory/HistoricalMessage/index.jsx b/frontend/src/components/WorkspaceChat/ChatContainer/ChatHistory/HistoricalMessage/index.jsx index 6155e76272..f0605a3721 100644 --- a/frontend/src/components/WorkspaceChat/ChatContainer/ChatHistory/HistoricalMessage/index.jsx +++ b/frontend/src/components/WorkspaceChat/ChatContainer/ChatHistory/HistoricalMessage/index.jsx @@ -1,13 +1,10 @@ import { memo, forwardRef } from "react"; import { Warning } from "@phosphor-icons/react"; import Jazzicon from "../../../../UserIcon"; -import renderMarkdown from "../../../../../utils/chat/markdown"; -import { userFromStorage } from "../../../../../utils/request"; +import renderMarkdown from "@/utils/chat/markdown"; +import { userFromStorage } from "@/utils/request"; import Citations from "../Citation"; -import { - AI_BACKGROUND_COLOR, - USER_BACKGROUND_COLOR, -} from "../../../../../utils/constants"; +import { AI_BACKGROUND_COLOR, USER_BACKGROUND_COLOR } from "@/utils/constants"; import { v4 } from "uuid"; const HistoricalMessage = forwardRef( diff --git a/frontend/src/components/WorkspaceChat/ChatContainer/ChatHistory/PromptReply/index.jsx b/frontend/src/components/WorkspaceChat/ChatContainer/ChatHistory/PromptReply/index.jsx index a65eebd5fb..a219f1202c 100644 --- a/frontend/src/components/WorkspaceChat/ChatContainer/ChatHistory/PromptReply/index.jsx +++ b/frontend/src/components/WorkspaceChat/ChatContainer/ChatHistory/PromptReply/index.jsx @@ -1,7 +1,7 @@ import { forwardRef, memo } from "react"; import { Warning } from "@phosphor-icons/react"; import Jazzicon from "../../../../UserIcon"; -import renderMarkdown from "../../../../../utils/chat/markdown"; +import renderMarkdown from "@/utils/chat/markdown"; import Citations from "../Citation"; const PromptReply = forwardRef( diff --git a/frontend/src/components/WorkspaceChat/ChatContainer/PromptInput/index.jsx b/frontend/src/components/WorkspaceChat/ChatContainer/PromptInput/index.jsx index 22dbdf3205..14daff8095 100644 --- a/frontend/src/components/WorkspaceChat/ChatContainer/PromptInput/index.jsx +++ b/frontend/src/components/WorkspaceChat/ChatContainer/PromptInput/index.jsx @@ -10,7 +10,7 @@ import { isMobile } from "react-device-detect"; import ManageWorkspace, { useManageWorkspaceModal, } from "../../../Modals/MangeWorkspace"; -import useUser from "../../../../hooks/useUser"; +import useUser from "@/hooks/useUser"; export default function PromptInput({ workspace, diff --git a/frontend/src/components/WorkspaceChat/ChatContainer/index.jsx b/frontend/src/components/WorkspaceChat/ChatContainer/index.jsx index 0096aadfe9..34ae8de9af 100644 --- a/frontend/src/components/WorkspaceChat/ChatContainer/index.jsx +++ b/frontend/src/components/WorkspaceChat/ChatContainer/index.jsx @@ -1,8 +1,8 @@ import { useState, useEffect } from "react"; import ChatHistory from "./ChatHistory"; import PromptInput from "./PromptInput"; -import Workspace from "../../../models/workspace"; -import handleChat from "../../../utils/chat"; +import Workspace from "@/models/workspace"; +import handleChat from "@/utils/chat"; import { isMobile } from "react-device-detect"; import { SidebarMobileHeader } from "../../Sidebar"; diff --git a/frontend/src/components/WorkspaceChat/index.jsx b/frontend/src/components/WorkspaceChat/index.jsx index 98a77a4255..3e129c2a6a 100644 --- a/frontend/src/components/WorkspaceChat/index.jsx +++ b/frontend/src/components/WorkspaceChat/index.jsx @@ -1,8 +1,8 @@ import React, { useEffect, useState } from "react"; -import Workspace from "../../models/workspace"; +import Workspace from "@/models/workspace"; import LoadingChat from "./LoadingChat"; import ChatContainer from "./ChatContainer"; -import paths from "../../utils/paths"; +import paths from "@/utils/paths"; export default function WorkspaceChat({ loading, workspace }) { const [history, setHistory] = useState([]); diff --git a/frontend/src/hooks/useLogo.js b/frontend/src/hooks/useLogo.js index e4ecd5e877..f03d20981c 100644 --- a/frontend/src/hooks/useLogo.js +++ b/frontend/src/hooks/useLogo.js @@ -1,6 +1,6 @@ import { useEffect, useState } from "react"; -import System from "../models/system"; -import AnythingLLM from "../media/logo/anything-llm.png"; +import System from "@/models/system"; +import AnythingLLM from "@/media/logo/anything-llm.png"; export default function useLogo() { const [logo, setLogo] = useState(""); diff --git a/frontend/src/hooks/useUser.js b/frontend/src/hooks/useUser.js index c3feb04bb8..2a753dce93 100644 --- a/frontend/src/hooks/useUser.js +++ b/frontend/src/hooks/useUser.js @@ -1,5 +1,5 @@ import { useContext } from "react"; -import { AuthContext } from "../AuthContext"; +import { AuthContext } from "@/AuthContext"; // interface IStore { // store: { diff --git a/frontend/src/main.jsx b/frontend/src/main.jsx index 76206a4056..bb415f3a7a 100644 --- a/frontend/src/main.jsx +++ b/frontend/src/main.jsx @@ -1,8 +1,8 @@ import React from "react"; import ReactDOM from "react-dom/client"; import { BrowserRouter as Router } from "react-router-dom"; -import App from "./App.jsx"; -import "./index.css"; +import App from "@/App.jsx"; +import "@/index.css"; const isDev = process.env.NODE_ENV !== "production"; const REACTWRAP = isDev ? React.Fragment : React.StrictMode; diff --git a/frontend/src/models/admin.js b/frontend/src/models/admin.js index ade884d58f..0798a3e73c 100644 --- a/frontend/src/models/admin.js +++ b/frontend/src/models/admin.js @@ -1,5 +1,5 @@ -import { API_BASE } from "../utils/constants"; -import { baseHeaders } from "../utils/request"; +import { API_BASE } from "@/utils/constants"; +import { baseHeaders } from "@/utils/request"; const Admin = { // User Management diff --git a/frontend/src/models/invite.js b/frontend/src/models/invite.js index c5f3e3c4ba..d36fb8592a 100644 --- a/frontend/src/models/invite.js +++ b/frontend/src/models/invite.js @@ -1,4 +1,4 @@ -import { API_BASE } from "../utils/constants"; +import { API_BASE } from "@/utils/constants"; const Invite = { checkInvite: async (inviteCode) => { diff --git a/frontend/src/models/system.js b/frontend/src/models/system.js index f69636a428..2ef4eebbfb 100644 --- a/frontend/src/models/system.js +++ b/frontend/src/models/system.js @@ -1,5 +1,5 @@ -import { API_BASE, AUTH_TIMESTAMP } from "../utils/constants"; -import { baseHeaders } from "../utils/request"; +import { API_BASE, AUTH_TIMESTAMP } from "@/utils/constants"; +import { baseHeaders } from "@/utils/request"; const System = { ping: async function () { diff --git a/frontend/src/models/workspace.js b/frontend/src/models/workspace.js index 2990e55410..aa0b9f7444 100644 --- a/frontend/src/models/workspace.js +++ b/frontend/src/models/workspace.js @@ -1,5 +1,5 @@ -import { API_BASE } from "../utils/constants"; -import { baseHeaders } from "../utils/request"; +import { API_BASE } from "@/utils/constants"; +import { baseHeaders } from "@/utils/request"; import { fetchEventSource } from "@microsoft/fetch-event-source"; import { v4 } from "uuid"; diff --git a/frontend/src/pages/Admin/Invitations/InviteRow/index.jsx b/frontend/src/pages/Admin/Invitations/InviteRow/index.jsx index 68408d7e75..56ebf7dc90 100644 --- a/frontend/src/pages/Admin/Invitations/InviteRow/index.jsx +++ b/frontend/src/pages/Admin/Invitations/InviteRow/index.jsx @@ -1,6 +1,6 @@ import { useEffect, useRef, useState } from "react"; import { titleCase } from "text-case"; -import Admin from "../../../../models/admin"; +import Admin from "@/models/admin"; import { Trash } from "@phosphor-icons/react"; export default function InviteRow({ invite }) { diff --git a/frontend/src/pages/Admin/Invitations/NewInviteModal/index.jsx b/frontend/src/pages/Admin/Invitations/NewInviteModal/index.jsx index 81205f20d4..54ae7e076c 100644 --- a/frontend/src/pages/Admin/Invitations/NewInviteModal/index.jsx +++ b/frontend/src/pages/Admin/Invitations/NewInviteModal/index.jsx @@ -1,6 +1,6 @@ import React, { useEffect, useState } from "react"; import { X } from "@phosphor-icons/react"; -import Admin from "../../../../models/admin"; +import Admin from "@/models/admin"; const DIALOG_ID = `new-invite-modal`; diff --git a/frontend/src/pages/Admin/Invitations/index.jsx b/frontend/src/pages/Admin/Invitations/index.jsx index 699fa76e4f..cf5b38d376 100644 --- a/frontend/src/pages/Admin/Invitations/index.jsx +++ b/frontend/src/pages/Admin/Invitations/index.jsx @@ -1,13 +1,11 @@ import { useEffect, useState } from "react"; -import Sidebar, { - SidebarMobileHeader, -} from "../../../components/SettingsSidebar"; +import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar"; import { isMobile } from "react-device-detect"; import * as Skeleton from "react-loading-skeleton"; import "react-loading-skeleton/dist/skeleton.css"; import { EnvelopeSimple } from "@phosphor-icons/react"; -import usePrefersDarkMode from "../../../hooks/usePrefersDarkMode"; -import Admin from "../../../models/admin"; +import usePrefersDarkMode from "@/hooks/usePrefersDarkMode"; +import Admin from "@/models/admin"; import InviteRow from "./InviteRow"; import NewInviteModal, { NewInviteModalId } from "./NewInviteModal"; diff --git a/frontend/src/pages/Admin/System/index.jsx b/frontend/src/pages/Admin/System/index.jsx index 4f77ba24ae..c4c1b9ebdd 100644 --- a/frontend/src/pages/Admin/System/index.jsx +++ b/frontend/src/pages/Admin/System/index.jsx @@ -1,10 +1,8 @@ import { useEffect, useState } from "react"; -import Sidebar, { - SidebarMobileHeader, -} from "../../../components/SettingsSidebar"; +import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar"; import { isMobile } from "react-device-detect"; -import Admin from "../../../models/admin"; -import showToast from "../../../utils/toast"; +import Admin from "@/models/admin"; +import showToast from "@/utils/toast"; export default function AdminSystem() { const [saving, setSaving] = useState(false); diff --git a/frontend/src/pages/Admin/Users/NewUserModal/index.jsx b/frontend/src/pages/Admin/Users/NewUserModal/index.jsx index 8282070eb6..d8c26d1e31 100644 --- a/frontend/src/pages/Admin/Users/NewUserModal/index.jsx +++ b/frontend/src/pages/Admin/Users/NewUserModal/index.jsx @@ -1,7 +1,7 @@ import React, { useState } from "react"; import { X } from "@phosphor-icons/react"; -import Admin from "../../../../models/admin"; -import { userFromStorage } from "../../../../utils/request"; +import Admin from "@/models/admin"; +import { userFromStorage } from "@/utils/request"; import { RoleHintDisplay } from ".."; const DIALOG_ID = `new-user-modal`; diff --git a/frontend/src/pages/Admin/Users/UserRow/EditUserModal/index.jsx b/frontend/src/pages/Admin/Users/UserRow/EditUserModal/index.jsx index 6b25f42ac6..4c3c2686ae 100644 --- a/frontend/src/pages/Admin/Users/UserRow/EditUserModal/index.jsx +++ b/frontend/src/pages/Admin/Users/UserRow/EditUserModal/index.jsx @@ -1,6 +1,6 @@ import React, { useState } from "react"; import { X } from "@phosphor-icons/react"; -import Admin from "../../../../../models/admin"; +import Admin from "@/models/admin"; import { RoleHintDisplay } from "../.."; export const EditUserModalId = (user) => `edit-user-${user.id}-modal`; diff --git a/frontend/src/pages/Admin/Users/UserRow/index.jsx b/frontend/src/pages/Admin/Users/UserRow/index.jsx index 5964b6bdf4..d734759fc6 100644 --- a/frontend/src/pages/Admin/Users/UserRow/index.jsx +++ b/frontend/src/pages/Admin/Users/UserRow/index.jsx @@ -1,6 +1,6 @@ import { useRef, useState } from "react"; import { titleCase } from "text-case"; -import Admin from "../../../../models/admin"; +import Admin from "@/models/admin"; import EditUserModal, { EditUserModalId } from "./EditUserModal"; import { DotsThreeOutline } from "@phosphor-icons/react"; diff --git a/frontend/src/pages/Admin/Users/index.jsx b/frontend/src/pages/Admin/Users/index.jsx index c1facda617..b59bbe5761 100644 --- a/frontend/src/pages/Admin/Users/index.jsx +++ b/frontend/src/pages/Admin/Users/index.jsx @@ -1,14 +1,12 @@ import { useEffect, useState } from "react"; -import Sidebar, { - SidebarMobileHeader, -} from "../../../components/SettingsSidebar"; +import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar"; import { isMobile } from "react-device-detect"; import * as Skeleton from "react-loading-skeleton"; import "react-loading-skeleton/dist/skeleton.css"; import { UserPlus } from "@phosphor-icons/react"; -import Admin from "../../../models/admin"; +import Admin from "@/models/admin"; import UserRow from "./UserRow"; -import useUser from "../../../hooks/useUser"; +import useUser from "@/hooks/useUser"; import NewUserModal, { NewUserModalId } from "./NewUserModal"; export default function AdminUsers() { diff --git a/frontend/src/pages/Admin/Workspaces/NewWorkspaceModal/index.jsx b/frontend/src/pages/Admin/Workspaces/NewWorkspaceModal/index.jsx index de33e4db25..21d9faed46 100644 --- a/frontend/src/pages/Admin/Workspaces/NewWorkspaceModal/index.jsx +++ b/frontend/src/pages/Admin/Workspaces/NewWorkspaceModal/index.jsx @@ -1,6 +1,6 @@ import React, { useState } from "react"; import { X } from "@phosphor-icons/react"; -import Admin from "../../../../models/admin"; +import Admin from "@/models/admin"; const DIALOG_ID = `new-workspace-modal`; function hideModal() { diff --git a/frontend/src/pages/Admin/Workspaces/WorkspaceRow/EditWorkspaceUsersModal/index.jsx b/frontend/src/pages/Admin/Workspaces/WorkspaceRow/EditWorkspaceUsersModal/index.jsx index 108b9bbfe5..052f845b40 100644 --- a/frontend/src/pages/Admin/Workspaces/WorkspaceRow/EditWorkspaceUsersModal/index.jsx +++ b/frontend/src/pages/Admin/Workspaces/WorkspaceRow/EditWorkspaceUsersModal/index.jsx @@ -1,6 +1,6 @@ import React, { useState } from "react"; import { X } from "@phosphor-icons/react"; -import Admin from "../../../../../models/admin"; +import Admin from "@/models/admin"; import { titleCase } from "text-case"; export const EditWorkspaceUsersModalId = (workspace) => diff --git a/frontend/src/pages/Admin/Workspaces/WorkspaceRow/index.jsx b/frontend/src/pages/Admin/Workspaces/WorkspaceRow/index.jsx index 6b181d4cd6..8c8969622a 100644 --- a/frontend/src/pages/Admin/Workspaces/WorkspaceRow/index.jsx +++ b/frontend/src/pages/Admin/Workspaces/WorkspaceRow/index.jsx @@ -1,6 +1,6 @@ import { useRef } from "react"; -import Admin from "../../../../models/admin"; -import paths from "../../../../utils/paths"; +import Admin from "@/models/admin"; +import paths from "@/utils/paths"; import EditWorkspaceUsersModal, { EditWorkspaceUsersModalId, } from "./EditWorkspaceUsersModal"; diff --git a/frontend/src/pages/Admin/Workspaces/index.jsx b/frontend/src/pages/Admin/Workspaces/index.jsx index e2217e4b69..c29c92ac29 100644 --- a/frontend/src/pages/Admin/Workspaces/index.jsx +++ b/frontend/src/pages/Admin/Workspaces/index.jsx @@ -1,13 +1,11 @@ import { useEffect, useState } from "react"; -import Sidebar, { - SidebarMobileHeader, -} from "../../../components/SettingsSidebar"; +import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar"; import { isMobile } from "react-device-detect"; import * as Skeleton from "react-loading-skeleton"; import "react-loading-skeleton/dist/skeleton.css"; import { BookOpen } from "@phosphor-icons/react"; -import usePrefersDarkMode from "../../../hooks/usePrefersDarkMode"; -import Admin from "../../../models/admin"; +import usePrefersDarkMode from "@/hooks/usePrefersDarkMode"; +import Admin from "@/models/admin"; import WorkspaceRow from "./WorkspaceRow"; import NewWorkspaceModal, { NewWorkspaceModalId } from "./NewWorkspaceModal"; diff --git a/frontend/src/pages/GeneralSettings/ApiKeys/ApiKeyRow/index.jsx b/frontend/src/pages/GeneralSettings/ApiKeys/ApiKeyRow/index.jsx index 29657f3f34..6b970bf3ef 100644 --- a/frontend/src/pages/GeneralSettings/ApiKeys/ApiKeyRow/index.jsx +++ b/frontend/src/pages/GeneralSettings/ApiKeys/ApiKeyRow/index.jsx @@ -1,9 +1,9 @@ import { useEffect, useRef, useState } from "react"; -import Admin from "../../../../models/admin"; -import showToast from "../../../../utils/toast"; +import Admin from "@/models/admin"; +import showToast from "@/utils/toast"; import { Trash } from "@phosphor-icons/react"; -import { userFromStorage } from "../../../../utils/request"; -import System from "../../../../models/system"; +import { userFromStorage } from "@/utils/request"; +import System from "@/models/system"; export default function ApiKeyRow({ apiKey }) { const rowRef = useRef(null); diff --git a/frontend/src/pages/GeneralSettings/ApiKeys/NewApiKeyModal/index.jsx b/frontend/src/pages/GeneralSettings/ApiKeys/NewApiKeyModal/index.jsx index 665e78f412..a4095ae9c7 100644 --- a/frontend/src/pages/GeneralSettings/ApiKeys/NewApiKeyModal/index.jsx +++ b/frontend/src/pages/GeneralSettings/ApiKeys/NewApiKeyModal/index.jsx @@ -1,9 +1,9 @@ import React, { useEffect, useState } from "react"; import { X } from "@phosphor-icons/react"; -import Admin from "../../../../models/admin"; -import paths from "../../../../utils/paths"; -import { userFromStorage } from "../../../../utils/request"; -import System from "../../../../models/system"; +import Admin from "@/models/admin"; +import paths from "@/utils/paths"; +import { userFromStorage } from "@/utils/request"; +import System from "@/models/system"; const DIALOG_ID = `new-api-key-modal`; diff --git a/frontend/src/pages/GeneralSettings/ApiKeys/index.jsx b/frontend/src/pages/GeneralSettings/ApiKeys/index.jsx index 66026ed5b2..5ee5fd0a39 100644 --- a/frontend/src/pages/GeneralSettings/ApiKeys/index.jsx +++ b/frontend/src/pages/GeneralSettings/ApiKeys/index.jsx @@ -1,17 +1,15 @@ import { useEffect, useState } from "react"; -import Sidebar, { - SidebarMobileHeader, -} from "../../../components/SettingsSidebar"; +import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar"; import { isMobile } from "react-device-detect"; import * as Skeleton from "react-loading-skeleton"; import "react-loading-skeleton/dist/skeleton.css"; import { PlusCircle } from "@phosphor-icons/react"; -import Admin from "../../../models/admin"; +import Admin from "@/models/admin"; import ApiKeyRow from "./ApiKeyRow"; import NewApiKeyModal, { NewApiKeyModalId } from "./NewApiKeyModal"; -import paths from "../../../utils/paths"; -import { userFromStorage } from "../../../utils/request"; -import System from "../../../models/system"; +import paths from "@/utils/paths"; +import { userFromStorage } from "@/utils/request"; +import System from "@/models/system"; export default function AdminApiKeys() { return ( diff --git a/frontend/src/pages/GeneralSettings/Appearance/index.jsx b/frontend/src/pages/GeneralSettings/Appearance/index.jsx index 107e57caea..e823dd0b71 100644 --- a/frontend/src/pages/GeneralSettings/Appearance/index.jsx +++ b/frontend/src/pages/GeneralSettings/Appearance/index.jsx @@ -1,14 +1,12 @@ import React, { useState, useEffect } from "react"; -import Sidebar, { - SidebarMobileHeader, -} from "../../../components/SettingsSidebar"; +import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar"; import { isMobile } from "react-device-detect"; -import Admin from "../../../models/admin"; -import AnythingLLM from "../../../media/logo/anything-llm.png"; -import useLogo from "../../../hooks/useLogo"; -import System from "../../../models/system"; -import EditingChatBubble from "../../../components/EditingChatBubble"; -import showToast from "../../../utils/toast"; +import Admin from "@/models/admin"; +import AnythingLLM from "@/media/logo/anything-llm.png"; +import useLogo from "@/hooks/useLogo"; +import System from "@/models/system"; +import EditingChatBubble from "@/components/EditingChatBubble"; +import showToast from "@/utils/toast"; import { Plus } from "@phosphor-icons/react"; export default function Appearance() { diff --git a/frontend/src/pages/GeneralSettings/Chats/ChatRow/index.jsx b/frontend/src/pages/GeneralSettings/Chats/ChatRow/index.jsx index 96c3970d5a..23fc39d9ae 100644 --- a/frontend/src/pages/GeneralSettings/Chats/ChatRow/index.jsx +++ b/frontend/src/pages/GeneralSettings/Chats/ChatRow/index.jsx @@ -1,7 +1,7 @@ import { useRef } from "react"; import truncate from "truncate"; import { X, Trash } from "@phosphor-icons/react"; -import System from "../../../../models/system"; +import System from "@/models/system"; export default function ChatRow({ chat }) { const rowRef = useRef(null); diff --git a/frontend/src/pages/GeneralSettings/Chats/index.jsx b/frontend/src/pages/GeneralSettings/Chats/index.jsx index fbf041a06f..d925232c3d 100644 --- a/frontend/src/pages/GeneralSettings/Chats/index.jsx +++ b/frontend/src/pages/GeneralSettings/Chats/index.jsx @@ -1,14 +1,12 @@ import { useEffect, useState } from "react"; -import Sidebar, { - SidebarMobileHeader, -} from "../../../components/SettingsSidebar"; +import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar"; import { isMobile } from "react-device-detect"; import * as Skeleton from "react-loading-skeleton"; import "react-loading-skeleton/dist/skeleton.css"; -import useQuery from "../../../hooks/useQuery"; +import useQuery from "@/hooks/useQuery"; import ChatRow from "./ChatRow"; -import showToast from "../../../utils/toast"; -import System from "../../../models/system"; +import showToast from "@/utils/toast"; +import System from "@/models/system"; const PAGE_SIZE = 20; export default function WorkspaceChats() { diff --git a/frontend/src/pages/GeneralSettings/EmbeddingPreference/index.jsx b/frontend/src/pages/GeneralSettings/EmbeddingPreference/index.jsx index 32efaa986a..0edcb1816f 100644 --- a/frontend/src/pages/GeneralSettings/EmbeddingPreference/index.jsx +++ b/frontend/src/pages/GeneralSettings/EmbeddingPreference/index.jsx @@ -1,21 +1,19 @@ import React, { useEffect, useState } from "react"; -import Sidebar, { - SidebarMobileHeader, -} from "../../../components/SettingsSidebar"; +import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar"; import { isMobile } from "react-device-detect"; -import System from "../../../models/system"; -import showToast from "../../../utils/toast"; -import AnythingLLMIcon from "../../../media/logo/anything-llm-icon.png"; -import OpenAiLogo from "../../../media/llmprovider/openai.png"; -import AzureOpenAiLogo from "../../../media/llmprovider/azure.png"; -import LocalAiLogo from "../../../media/llmprovider/localai.png"; -import PreLoader from "../../../components/Preloader"; -import LLMProviderOption from "../../../components/LLMSelection/LLMProviderOption"; -import ChangeWarningModal from "../../../components/ChangeWarning"; -import OpenAiOptions from "../../../components/EmbeddingSelection/OpenAiOptions"; -import AzureAiOptions from "../../../components/EmbeddingSelection/AzureAiOptions"; -import LocalAiOptions from "../../../components/EmbeddingSelection/LocalAiOptions"; -import NativeEmbeddingOptions from "../../../components/EmbeddingSelection/NativeEmbeddingOptions"; +import System from "@/models/system"; +import showToast from "@/utils/toast"; +import AnythingLLMIcon from "@/media/logo/anything-llm-icon.png"; +import OpenAiLogo from "@/media/llmprovider/openai.png"; +import AzureOpenAiLogo from "@/media/llmprovider/azure.png"; +import LocalAiLogo from "@/media/llmprovider/localai.png"; +import PreLoader from "@/components/Preloader"; +import LLMProviderOption from "@/components/LLMSelection/LLMProviderOption"; +import ChangeWarningModal from "@/components/ChangeWarning"; +import OpenAiOptions from "@/components/EmbeddingSelection/OpenAiOptions"; +import AzureAiOptions from "@/components/EmbeddingSelection/AzureAiOptions"; +import LocalAiOptions from "@/components/EmbeddingSelection/LocalAiOptions"; +import NativeEmbeddingOptions from "@/components/EmbeddingSelection/NativeEmbeddingOptions"; export default function GeneralEmbeddingPreference() { const [saving, setSaving] = useState(false); diff --git a/frontend/src/pages/GeneralSettings/ExportImport/index.jsx b/frontend/src/pages/GeneralSettings/ExportImport/index.jsx index bd4c254e7b..b6a9a608c6 100644 --- a/frontend/src/pages/GeneralSettings/ExportImport/index.jsx +++ b/frontend/src/pages/GeneralSettings/ExportImport/index.jsx @@ -1,14 +1,11 @@ -import { useEffect, useRef, useState } from "react"; -import Sidebar, { - SidebarMobileHeader, -} from "../../../components/SettingsSidebar"; +import { useRef, useState } from "react"; +import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar"; import { isMobile } from "react-device-detect"; -import Admin from "../../../models/admin"; -import showToast from "../../../utils/toast"; +import showToast from "@/utils/toast"; import { CloudArrowUp, DownloadSimple } from "@phosphor-icons/react"; -import System from "../../../models/system"; -import { API_BASE } from "../../../utils/constants"; -import paths from "../../../utils/paths"; +import System from "@/models/system"; +import { API_BASE } from "@/utils/constants"; +import paths from "@/utils/paths"; export default function GeneralExportImport() { const hostname = window?.location?.hostname; diff --git a/frontend/src/pages/GeneralSettings/LLMPreference/index.jsx b/frontend/src/pages/GeneralSettings/LLMPreference/index.jsx index b3b1bdf4c7..80fe1c575e 100644 --- a/frontend/src/pages/GeneralSettings/LLMPreference/index.jsx +++ b/frontend/src/pages/GeneralSettings/LLMPreference/index.jsx @@ -1,22 +1,20 @@ import React, { useEffect, useState } from "react"; -import Sidebar, { - SidebarMobileHeader, -} from "../../../components/SettingsSidebar"; +import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar"; import { isMobile } from "react-device-detect"; -import System from "../../../models/system"; -import showToast from "../../../utils/toast"; -import OpenAiLogo from "../../../media/llmprovider/openai.png"; -import AzureOpenAiLogo from "../../../media/llmprovider/azure.png"; -import AnthropicLogo from "../../../media/llmprovider/anthropic.png"; -import LMStudioLogo from "../../../media/llmprovider/lmstudio.png"; -import LocalAiLogo from "../../../media/llmprovider/localai.png"; -import PreLoader from "../../../components/Preloader"; -import LLMProviderOption from "../../../components/LLMSelection/LLMProviderOption"; -import OpenAiOptions from "../../../components/LLMSelection/OpenAiOptions"; -import AzureAiOptions from "../../../components/LLMSelection/AzureAiOptions"; -import AnthropicAiOptions from "../../../components/LLMSelection/AnthropicAiOptions"; -import LMStudioOptions from "../../../components/LLMSelection/LMStudioOptions"; -import LocalAiOptions from "../../../components/LLMSelection/LocalAiOptions"; +import System from "@/models/system"; +import showToast from "@/utils/toast"; +import OpenAiLogo from "@/media/llmprovider/openai.png"; +import AzureOpenAiLogo from "@/media/llmprovider/azure.png"; +import AnthropicLogo from "@/media/llmprovider/anthropic.png"; +import LMStudioLogo from "@/media/llmprovider/lmstudio.png"; +import LocalAiLogo from "@/media/llmprovider/localai.png"; +import PreLoader from "@/components/Preloader"; +import LLMProviderOption from "@/components/LLMSelection/LLMProviderOption"; +import OpenAiOptions from "@/components/LLMSelection/OpenAiOptions"; +import AzureAiOptions from "@/components/LLMSelection/AzureAiOptions"; +import AnthropicAiOptions from "@/components/LLMSelection/AnthropicAiOptions"; +import LMStudioOptions from "@/components/LLMSelection/LMStudioOptions"; +import LocalAiOptions from "@/components/LLMSelection/LocalAiOptions"; export default function GeneralLLMPreference() { const [saving, setSaving] = useState(false); diff --git a/frontend/src/pages/GeneralSettings/Security/index.jsx b/frontend/src/pages/GeneralSettings/Security/index.jsx index 3183dabfc6..4c4cfc0a7d 100644 --- a/frontend/src/pages/GeneralSettings/Security/index.jsx +++ b/frontend/src/pages/GeneralSettings/Security/index.jsx @@ -1,17 +1,11 @@ import { useEffect, useState } from "react"; -import Sidebar, { - SidebarMobileHeader, -} from "../../../components/SettingsSidebar"; +import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar"; import { isMobile } from "react-device-detect"; -import showToast from "../../../utils/toast"; -import System from "../../../models/system"; -import paths from "../../../utils/paths"; -import { - AUTH_TIMESTAMP, - AUTH_TOKEN, - AUTH_USER, -} from "../../../utils/constants"; -import PreLoader from "../../../components/Preloader"; +import showToast from "@/utils/toast"; +import System from "@/models/system"; +import paths from "@/utils/paths"; +import { AUTH_TIMESTAMP, AUTH_TOKEN, AUTH_USER } from "@/utils/constants"; +import PreLoader from "@/components/Preloader"; export default function GeneralSecurity() { return ( diff --git a/frontend/src/pages/GeneralSettings/VectorDatabase/index.jsx b/frontend/src/pages/GeneralSettings/VectorDatabase/index.jsx index f8b4374399..1635fef8b8 100644 --- a/frontend/src/pages/GeneralSettings/VectorDatabase/index.jsx +++ b/frontend/src/pages/GeneralSettings/VectorDatabase/index.jsx @@ -1,18 +1,16 @@ import React, { useState, useEffect } from "react"; -import Sidebar, { - SidebarMobileHeader, -} from "../../../components/SettingsSidebar"; +import Sidebar, { SidebarMobileHeader } from "@/components/SettingsSidebar"; import { isMobile } from "react-device-detect"; -import System from "../../../models/system"; -import showToast from "../../../utils/toast"; -import ChromaLogo from "../../../media/vectordbs/chroma.png"; -import PineconeLogo from "../../../media/vectordbs/pinecone.png"; -import LanceDbLogo from "../../../media/vectordbs/lancedb.png"; -import WeaviateLogo from "../../../media/vectordbs/weaviate.png"; -import QDrantLogo from "../../../media/vectordbs/qdrant.png"; -import PreLoader from "../../../components/Preloader"; -import VectorDBOption from "../../../components/VectorDBOption"; -import ChangeWarningModal from "../../../components/ChangeWarning"; +import System from "@/models/system"; +import showToast from "@/utils/toast"; +import ChromaLogo from "@/media/vectordbs/chroma.png"; +import PineconeLogo from "@/media/vectordbs/pinecone.png"; +import LanceDbLogo from "@/media/vectordbs/lancedb.png"; +import WeaviateLogo from "@/media/vectordbs/weaviate.png"; +import QDrantLogo from "@/media/vectordbs/qdrant.png"; +import PreLoader from "@/components/Preloader"; +import VectorDBOption from "@/components/VectorDBOption"; +import ChangeWarningModal from "@/components/ChangeWarning"; export default function GeneralVectorDatabase() { const [saving, setSaving] = useState(false); diff --git a/frontend/src/pages/Invite/NewUserModal/index.jsx b/frontend/src/pages/Invite/NewUserModal/index.jsx index 3984119095..0733a36021 100644 --- a/frontend/src/pages/Invite/NewUserModal/index.jsx +++ b/frontend/src/pages/Invite/NewUserModal/index.jsx @@ -1,9 +1,9 @@ import React, { useState } from "react"; -import Invite from "../../../models/invite"; -import paths from "../../../utils/paths"; +import Invite from "@/models/invite"; +import paths from "@/utils/paths"; import { useParams } from "react-router-dom"; -import { AUTH_TOKEN, AUTH_USER } from "../../../utils/constants"; -import System from "../../../models/system"; +import { AUTH_TOKEN, AUTH_USER } from "@/utils/constants"; +import System from "@/models/system"; export default function NewUserModal() { const { code } = useParams(); diff --git a/frontend/src/pages/Invite/index.jsx b/frontend/src/pages/Invite/index.jsx index 1ed25e7999..e44ff23599 100644 --- a/frontend/src/pages/Invite/index.jsx +++ b/frontend/src/pages/Invite/index.jsx @@ -1,7 +1,7 @@ import React, { useEffect, useState } from "react"; import { useParams } from "react-router-dom"; -import { FullScreenLoader } from "../../components/Preloader"; -import Invite from "../../models/invite"; +import { FullScreenLoader } from "@/components/Preloader"; +import Invite from "@/models/invite"; import NewUserModal from "./NewUserModal"; export default function InvitePage() { diff --git a/frontend/src/pages/Login/index.jsx b/frontend/src/pages/Login/index.jsx index d7d80926b2..ec5950cbe8 100644 --- a/frontend/src/pages/Login/index.jsx +++ b/frontend/src/pages/Login/index.jsx @@ -1,8 +1,6 @@ import React from "react"; -import PasswordModal, { - usePasswordModal, -} from "../../components/Modals/Password"; -import { FullScreenLoader } from "../../components/Preloader"; +import PasswordModal, { usePasswordModal } from "@/components/Modals/Password"; +import { FullScreenLoader } from "@/components/Preloader"; export default function Login() { const { loading, mode } = usePasswordModal(); diff --git a/frontend/src/pages/Main/index.jsx b/frontend/src/pages/Main/index.jsx index 5d79c5cab7..d0b3cbf8ce 100644 --- a/frontend/src/pages/Main/index.jsx +++ b/frontend/src/pages/Main/index.jsx @@ -1,12 +1,10 @@ import React from "react"; -import DefaultChatContainer from "../../components/DefaultChat"; -import Sidebar from "../../components/Sidebar"; -import PasswordModal, { - usePasswordModal, -} from "../../components/Modals/Password"; +import DefaultChatContainer from "@/components/DefaultChat"; +import Sidebar from "@/components/Sidebar"; +import PasswordModal, { usePasswordModal } from "@/components/Modals/Password"; import { isMobile } from "react-device-detect"; -import { FullScreenLoader } from "../../components/Preloader"; -import UserMenu from "../../components/UserMenu"; +import { FullScreenLoader } from "@/components/Preloader"; +import UserMenu from "@/components/UserMenu"; export default function Main() { const { loading, requiresAuth, mode } = usePasswordModal(); diff --git a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/AppearanceSetup/index.jsx b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/AppearanceSetup/index.jsx index ed5c557990..496a4ff4fe 100644 --- a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/AppearanceSetup/index.jsx +++ b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/AppearanceSetup/index.jsx @@ -1,9 +1,9 @@ import React, { memo, useEffect, useState } from "react"; -import System from "../../../../../models/system"; -import AnythingLLM from "../../../../../media/logo/anything-llm.png"; -import useLogo from "../../../../../hooks/useLogo"; +import System from "@/models/system"; +import AnythingLLM from "@/media/logo/anything-llm.png"; +import useLogo from "@/hooks/useLogo"; import { Plus } from "@phosphor-icons/react"; -import showToast from "../../../../../utils/toast"; +import showToast from "@/utils/toast"; function AppearanceSetup({ prevStep, nextStep }) { const { logo: _initLogo } = useLogo(); diff --git a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/CreateFirstWorkspace/index.jsx b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/CreateFirstWorkspace/index.jsx index c9fb442e99..3c9949f89b 100644 --- a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/CreateFirstWorkspace/index.jsx +++ b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/CreateFirstWorkspace/index.jsx @@ -1,7 +1,7 @@ import React, { memo } from "react"; import { useNavigate } from "react-router-dom"; -import paths from "../../../../../utils/paths"; -import Workspace from "../../../../../models/workspace"; +import paths from "@/utils/paths"; +import Workspace from "@/models/workspace"; function CreateFirstWorkspace() { const navigate = useNavigate(); diff --git a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/DataHandling/index.jsx b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/DataHandling/index.jsx index ebb9ae1ecf..2a29e5670a 100644 --- a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/DataHandling/index.jsx +++ b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/DataHandling/index.jsx @@ -1,17 +1,17 @@ import React, { memo, useEffect, useState } from "react"; -import System from "../../../../../models/system"; -import AnythingLLMIcon from "../../../../../media/logo/anything-llm-icon.png"; -import OpenAiLogo from "../../../../../media/llmprovider/openai.png"; -import AzureOpenAiLogo from "../../../../../media/llmprovider/azure.png"; -import AnthropicLogo from "../../../../../media/llmprovider/anthropic.png"; -import LMStudioLogo from "../../../../../media/llmprovider/lmstudio.png"; -import LocalAiLogo from "../../../../../media/llmprovider/localai.png"; -import ChromaLogo from "../../../../../media/vectordbs/chroma.png"; -import PineconeLogo from "../../../../../media/vectordbs/pinecone.png"; -import LanceDbLogo from "../../../../../media/vectordbs/lancedb.png"; -import WeaviateLogo from "../../../../../media/vectordbs/weaviate.png"; -import QDrantLogo from "../../../../../media/vectordbs/qdrant.png"; -import PreLoader from "../../../../../components/Preloader"; +import System from "@/models/system"; +import AnythingLLMIcon from "@/media/logo/anything-llm-icon.png"; +import OpenAiLogo from "@/media/llmprovider/openai.png"; +import AzureOpenAiLogo from "@/media/llmprovider/azure.png"; +import AnthropicLogo from "@/media/llmprovider/anthropic.png"; +import LMStudioLogo from "@/media/llmprovider/lmstudio.png"; +import LocalAiLogo from "@/media/llmprovider/localai.png"; +import ChromaLogo from "@/media/vectordbs/chroma.png"; +import PineconeLogo from "@/media/vectordbs/pinecone.png"; +import LanceDbLogo from "@/media/vectordbs/lancedb.png"; +import WeaviateLogo from "@/media/vectordbs/weaviate.png"; +import QDrantLogo from "@/media/vectordbs/qdrant.png"; +import PreLoader from "@/components/Preloader"; const LLM_SELECTION_PRIVACY = { openai: { diff --git a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/EmbeddingSelection/index.jsx b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/EmbeddingSelection/index.jsx index 501c88ef02..1f44c463bd 100644 --- a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/EmbeddingSelection/index.jsx +++ b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/EmbeddingSelection/index.jsx @@ -1,15 +1,15 @@ import React, { memo, useEffect, useState } from "react"; -import AnythingLLMIcon from "../../../../../media/logo/anything-llm-icon.png"; -import OpenAiLogo from "../../../../../media/llmprovider/openai.png"; -import AzureOpenAiLogo from "../../../../../media/llmprovider/azure.png"; -import LocalAiLogo from "../../../../../media/llmprovider/localai.png"; -import System from "../../../../../models/system"; -import PreLoader from "../../../../../components/Preloader"; -import LLMProviderOption from "../../../../../components/LLMSelection/LLMProviderOption"; -import OpenAiOptions from "../../../../../components/EmbeddingSelection/OpenAiOptions"; -import AzureAiOptions from "../../../../../components/EmbeddingSelection/AzureAiOptions"; -import LocalAiOptions from "../../../../../components/EmbeddingSelection/LocalAiOptions"; -import NativeEmbeddingOptions from "../../../../../components/EmbeddingSelection/NativeEmbeddingOptions"; +import AnythingLLMIcon from "@/media/logo/anything-llm-icon.png"; +import OpenAiLogo from "@/media/llmprovider/openai.png"; +import AzureOpenAiLogo from "@/media/llmprovider/azure.png"; +import LocalAiLogo from "@/media/llmprovider/localai.png"; +import System from "@/models/system"; +import PreLoader from "@/components/Preloader"; +import LLMProviderOption from "@/components/LLMSelection/LLMProviderOption"; +import OpenAiOptions from "@/components/EmbeddingSelection/OpenAiOptions"; +import AzureAiOptions from "@/components/EmbeddingSelection/AzureAiOptions"; +import LocalAiOptions from "@/components/EmbeddingSelection/LocalAiOptions"; +import NativeEmbeddingOptions from "@/components/EmbeddingSelection/NativeEmbeddingOptions"; function EmbeddingSelection({ nextStep, prevStep, currentStep }) { const [embeddingChoice, setEmbeddingChoice] = useState("native"); diff --git a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/LLMSelection/index.jsx b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/LLMSelection/index.jsx index eec16bc8fe..84b232d741 100644 --- a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/LLMSelection/index.jsx +++ b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/LLMSelection/index.jsx @@ -1,17 +1,17 @@ import React, { memo, useEffect, useState } from "react"; -import OpenAiLogo from "../../../../../media/llmprovider/openai.png"; -import AzureOpenAiLogo from "../../../../../media/llmprovider/azure.png"; -import AnthropicLogo from "../../../../../media/llmprovider/anthropic.png"; -import LMStudioLogo from "../../../../../media/llmprovider/lmstudio.png"; -import LocalAiLogo from "../../../../../media/llmprovider/localai.png"; -import System from "../../../../../models/system"; -import PreLoader from "../../../../../components/Preloader"; -import LLMProviderOption from "../../../../../components/LLMSelection/LLMProviderOption"; -import OpenAiOptions from "../../../../../components/LLMSelection/OpenAiOptions"; -import AzureAiOptions from "../../../../../components/LLMSelection/AzureAiOptions"; -import AnthropicAiOptions from "../../../../../components/LLMSelection/AnthropicAiOptions"; -import LMStudioOptions from "../../../../../components/LLMSelection/LMStudioOptions"; -import LocalAiOptions from "../../../../../components/LLMSelection/LocalAiOptions"; +import OpenAiLogo from "@/media/llmprovider/openai.png"; +import AzureOpenAiLogo from "@/media/llmprovider/azure.png"; +import AnthropicLogo from "@/media/llmprovider/anthropic.png"; +import LMStudioLogo from "@/media/llmprovider/lmstudio.png"; +import LocalAiLogo from "@/media/llmprovider/localai.png"; +import System from "@/models/system"; +import PreLoader from "@/components/Preloader"; +import LLMProviderOption from "@/components/LLMSelection/LLMProviderOption"; +import OpenAiOptions from "@/components/LLMSelection/OpenAiOptions"; +import AzureAiOptions from "@/components/LLMSelection/AzureAiOptions"; +import AnthropicAiOptions from "@/components/LLMSelection/AnthropicAiOptions"; +import LMStudioOptions from "@/components/LLMSelection/LMStudioOptions"; +import LocalAiOptions from "@/components/LLMSelection/LocalAiOptions"; function LLMSelection({ nextStep, prevStep, currentStep }) { const [llmChoice, setLLMChoice] = useState("openai"); diff --git a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/MultiUserSetup/index.jsx b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/MultiUserSetup/index.jsx index 675e885919..71310abfca 100644 --- a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/MultiUserSetup/index.jsx +++ b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/MultiUserSetup/index.jsx @@ -1,10 +1,6 @@ import React, { useState, memo } from "react"; -import System from "../../../../../models/system"; -import { - AUTH_TIMESTAMP, - AUTH_TOKEN, - AUTH_USER, -} from "../../../../../utils/constants"; +import System from "@/models/system"; +import { AUTH_TIMESTAMP, AUTH_TOKEN, AUTH_USER } from "@/utils/constants"; import debounce from "lodash.debounce"; // Multi-user mode step diff --git a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/PasswordProtection/index.jsx b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/PasswordProtection/index.jsx index c1f8b73023..4504288e6a 100644 --- a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/PasswordProtection/index.jsx +++ b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/PasswordProtection/index.jsx @@ -1,10 +1,6 @@ import React, { memo, useState } from "react"; -import System from "../../../../../models/system"; -import { - AUTH_TIMESTAMP, - AUTH_TOKEN, - AUTH_USER, -} from "../../../../../utils/constants"; +import System from "@/models/system"; +import { AUTH_TIMESTAMP, AUTH_TOKEN, AUTH_USER } from "@/utils/constants"; import debounce from "lodash.debounce"; function PasswordProtection({ nextStep, prevStep }) { diff --git a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/VectorDatabaseConnection/index.jsx b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/VectorDatabaseConnection/index.jsx index 99c42f1b2f..16ee9aa53b 100644 --- a/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/VectorDatabaseConnection/index.jsx +++ b/frontend/src/pages/OnboardingFlow/OnboardingModal/Steps/VectorDatabaseConnection/index.jsx @@ -1,13 +1,13 @@ import React, { memo, useEffect, useState } from "react"; -import VectorDBOption from "../../../../../components/VectorDBOption"; -import ChromaLogo from "../../../../../media/vectordbs/chroma.png"; -import PineconeLogo from "../../../../../media/vectordbs/pinecone.png"; -import LanceDbLogo from "../../../../../media/vectordbs/lancedb.png"; -import WeaviateLogo from "../../../../../media/vectordbs/weaviate.png"; -import QDrantLogo from "../../../../../media/vectordbs/qdrant.png"; -import System from "../../../../../models/system"; -import PreLoader from "../../../../../components/Preloader"; +import VectorDBOption from "@/components/VectorDBOption"; +import ChromaLogo from "@/media/vectordbs/chroma.png"; +import PineconeLogo from "@/media/vectordbs/pinecone.png"; +import LanceDbLogo from "@/media/vectordbs/lancedb.png"; +import WeaviateLogo from "@/media/vectordbs/weaviate.png"; +import QDrantLogo from "@/media/vectordbs/qdrant.png"; +import System from "@/models/system"; +import PreLoader from "@/components/Preloader"; function VectorDatabaseConnection({ nextStep, prevStep, currentStep }) { const [vectorDB, setVectorDB] = useState("lancedb"); diff --git a/frontend/src/pages/OnboardingFlow/index.jsx b/frontend/src/pages/OnboardingFlow/index.jsx index 0839635c25..106f7cbae1 100644 --- a/frontend/src/pages/OnboardingFlow/index.jsx +++ b/frontend/src/pages/OnboardingFlow/index.jsx @@ -1,6 +1,6 @@ import React, { useEffect, useState } from "react"; import OnboardingModal, { OnboardingModalId } from "./OnboardingModal"; -import useLogo from "../../hooks/useLogo"; +import useLogo from "@/hooks/useLogo"; import { isMobile } from "react-device-detect"; export default function OnboardingFlow() { diff --git a/frontend/src/pages/WorkspaceChat/index.jsx b/frontend/src/pages/WorkspaceChat/index.jsx index 5f8985f49c..7db652a921 100644 --- a/frontend/src/pages/WorkspaceChat/index.jsx +++ b/frontend/src/pages/WorkspaceChat/index.jsx @@ -1,13 +1,11 @@ import React, { useEffect, useState } from "react"; -import { default as WorkspaceChatContainer } from "../../components/WorkspaceChat"; -import Sidebar from "../../components/Sidebar"; +import { default as WorkspaceChatContainer } from "@/components/WorkspaceChat"; +import Sidebar from "@/components/Sidebar"; import { useParams } from "react-router-dom"; -import Workspace from "../../models/workspace"; -import PasswordModal, { - usePasswordModal, -} from "../../components/Modals/Password"; +import Workspace from "@/models/workspace"; +import PasswordModal, { usePasswordModal } from "@/components/Modals/Password"; import { isMobile } from "react-device-detect"; -import { FullScreenLoader } from "../../components/Preloader"; +import { FullScreenLoader } from "@/components/Preloader"; export default function WorkspaceChat() { const { loading, requiresAuth, mode } = usePasswordModal(); diff --git a/frontend/src/utils/toast.js b/frontend/src/utils/toast.js index 7c12c5ea81..5ce17d5aea 100644 --- a/frontend/src/utils/toast.js +++ b/frontend/src/utils/toast.js @@ -1,5 +1,5 @@ import { toast } from "react-toastify"; -import usePrefersDarkMode from "../hooks/usePrefersDarkMode"; +import usePrefersDarkMode from "@/hooks/usePrefersDarkMode"; // Additional Configs (opts) // You can also pass valid ReactToast params to override the defaults. diff --git a/frontend/vite.config.js b/frontend/vite.config.js index 7166d50a92..a7e6ac01d1 100644 --- a/frontend/vite.config.js +++ b/frontend/vite.config.js @@ -1,4 +1,5 @@ import { defineConfig } from 'vite' +import { fileURLToPath, URL } from "url"; import postcss from './postcss.config.js' import react from '@vitejs/plugin-react' import dns from 'dns' @@ -30,6 +31,7 @@ export default defineConfig({ ], resolve: { alias: [ + { find: '@', replacement: fileURLToPath(new URL('./src', import.meta.url)) }, { process: "process/browser", stream: "stream-browserify",