diff --git a/package.json b/package.json index 446eac4613b5b1723bfdc6e4e45ee6b0a342d86e..005a5adb7fe23366b37c619e40c3f8824f2e6840 100644 --- a/package.json +++ b/package.json @@ -34,6 +34,7 @@ "@eslint/eslintrc": "^3.1.0", "@eslint/js": "^9.14.0", "@hey-api/openapi-ts": "^0.54.2", + "@types/react-dom": "^19.0.2", "@typescript-eslint/eslint-plugin": "^8.13.0", "@typescript-eslint/parser": "^8.13.0", "eslint": "^9.14.0", diff --git a/src/main.tsx b/src/main.tsx index 599a14c3728932afd5ef5823daec4cf5f666a274..3aa4cf3a75ca080799466b5c91ad01c8869b4465 100644 --- a/src/main.tsx +++ b/src/main.tsx @@ -1,21 +1,16 @@ -// main.tsx import React from "react"; -import client from "./apiClientConfig"; import ReactDOM from "react-dom/client"; import { createBrowserRouter, RouterProvider } from "react-router-dom"; + +import { AuthProvider } from "./useAuth"; // Import AuthProvider import Root from "./pages/root"; import ErrorBoundary from "./ErrorBoundary"; import Index from "./pages/index"; import ThemeWrapper from "./ThemeWrapper"; - import Callback from "./Callback"; -import CreditList, { - addLoader as addCreditListLoader, -} from "./pages/CreditList"; +import CreditList, { addLoader as addCreditListLoader } from "./pages/CreditList"; import CombinedPaymentsPage from "./pages/CombinedList"; -import Belegformular, { - addLoader as addCreditPaymentLoader, -} from "./pages/Belegformular"; +import Belegformular, { addLoader as addCreditPaymentLoader } from "./pages/Belegformular"; import EditCreditPayment from "./pages/EditCreditPayment"; import GenerateItem from "./pages/GenerateItem"; import GenerateLedger from "./pages/GenerateLedger"; @@ -26,6 +21,7 @@ import EditInternalTransfer from "./pages/EditInternalTransfer"; import EditReimbursement from "./pages/EditReimbursement"; import UncheckedPayments from "./pages/UncheckedPayments"; import KstEval from "./pages/KstEval"; +import OnboardingCourse from "./pages/OnboardingQuiz"; const router = createBrowserRouter([ { @@ -98,14 +94,18 @@ const router = createBrowserRouter([ element: <KstEval />, loader: addCreditListLoader, }, + { path: "OnboardingCourse", element: <OnboardingCourse /> }, ], }, { path: "callback", element: <Callback /> }, ]); + ReactDOM.createRoot(document.getElementById("root")!).render( <React.StrictMode> - <ThemeWrapper> - <RouterProvider router={router} /> - </ThemeWrapper> - </React.StrictMode>, + <AuthProvider> {/* Wrap your app with AuthProvider */} + <ThemeWrapper> + <RouterProvider router={router} /> + </ThemeWrapper> + </AuthProvider> + </React.StrictMode> ); diff --git a/src/pages/Onboarding.tsx b/src/pages/Onboarding.tsx index b50e6ba16da1fada9fe280dd26df3327dfea5303..66aedfd9f9f5ddcc0e5f7e9c43904bd8361e7e2a 100644 --- a/src/pages/Onboarding.tsx +++ b/src/pages/Onboarding.tsx @@ -88,7 +88,7 @@ export default function OnboardingPage() { return ( <Container> - here goes some text + Please enter your bank details. Any reimbursements will be sent to this account. Once you have entered your bank details, you will be able to submit your first reimbursement. <ObjectEditor fieldConfigs={fieldConfig} header="Onboarding" diff --git a/src/pages/OnboardingQuiz.tsx b/src/pages/OnboardingQuiz.tsx new file mode 100644 index 0000000000000000000000000000000000000000..8200190917dce22ea2d77f9a923aef68468db9ac --- /dev/null +++ b/src/pages/OnboardingQuiz.tsx @@ -0,0 +1,255 @@ +import React, { useState } from "react"; +import { + Container, + Box, + Typography, + Button, + FormControl, + FormLabel, + RadioGroup, + FormControlLabel, + Radio, + Checkbox +} from "@mui/material"; + +export default function OnboardingCourse() { + interface PageContent { + id: number; + title: string; + description: string; + question?: string; + options?: string[]; // Multiple-choice options + correctAnswer?: string; // The correct option + isFinalPage?: boolean; // Whether this is the last page + } + + // Sample content with multiple-choice questions + const data: PageContent[] = [ + { + id: 1, + title: "Welcome to QTool! ", + description: "In the next few minutes, you will learn how to use the tool correctly. At the end of this onboarding, you will need to enter your IBAN and address, so please have them ready. You will also need to answer a small quiz on each page of this onboarding. Let's begin!", + question: "I will pay attention.", + options: ["Yes", "No", "Maybe"], + correctAnswer: "Yes", + }, + { + id: 2, + title: "What is Qtool?", + description: "QTool is used by AMIV to manage most financial processes. For you, it provides the ability to request reimbursements, enter any purchases made with an AMIV credit card, submit large bills that need to be paid by AMIV, and check the current status of the AMIV budget. If you are part of the board or a commission co-president, you will have detailed access to any transactions concerning the cost centers you are responsible for.", + question: "What is not a feature of QTool?", + options: ["Reimbursement Requests", "Rights management of AMIV IT services.", "AMIV Invoice Management", "Budget Overview"], + correctAnswer: "Rights management of AMIV IT services.", + }, + { + id: 3, + title: "Receipts are important!", + description: "The most common scenario for using QTool is when you spend money for AMIV (e.g., buying snacks for the biweekly EESTEC meeting). When spending money for AMIV, you ALWAYS need to ask for a receipt. If you don’t have the receipt, we cannot guarantee reimbursement. The receipt is always necessary, whether you use your own money or an AMIV credit card.", + question: "Do I need a receipt when spending money for AMIV?", + options: ["Only if I need a reimbursement", "Only if I use an AMIV Credit card", "I always need a receipt when spending money for AMIV", "Never, receipts are optional"], + correctAnswer: "I always need a receipt when spending money for AMIV", + }, + { + id: 4, + title: "Reimbursement Requests", + description: "When you want to get a reimbursement, choose the appropriate icon in the sidebar of QTool. Enter a short, unique, but precise description of what the money was spent on and what it is. Choose the correct cost center. If you are part of a commission, select the commission; if you spent the money for an AMIV event, select the event; if you are part of the board, you should know which option to choose. If in doubt, please contact the responsible person. Select the most appropriate ledger. Enter the exact amount stated on the receipt. Upload the receipt, making sure it is clear and that the whole receipt is visible. If you are happy with your choice, submit the form.", + question: "Which of the following is the best description of a reimbursement request?", + options: ["Gimme Money, was for snacks", "Snacks", "Beer for EESTEC meeting on 20.02.2014.", "Beer for EESTEC meeting"], + correctAnswer: "Beer for EESTEC meeting on 20.02.2014.", + }, + { + id: 5, + title: "AMIV Credit Card", + description: "If you use an AMIV credit card, the receipt also needs to be entered into QTool. The procedure is very similar to the reimbursement process, but you should choose the credit card form. Please be aware that you are responsible for the credit card when you have it with you, and AMIV could charge you for any usage of the card where you cannot provide the receipt.", + question: "How many expenses does AMIV have approximately in one year?", + options: ["30'000,-", "100'000,-", "650'000,-", "1'030'000,-"], + correctAnswer: "650'000,-", + }, + { + id: 6, + title: "Submitting Requests", + description: "Once you submit a request, the AMIV treasury will check it for correctness and either accept or decline it. You will be notified by email, and in the summary of QTool, you can see the status of all your requests.", + question: "When can I discard the original receipt?", + options: ["After I submitted the request", "After I received the money", "Never", "After the request was accepted"], + correctAnswer: "After the request was accepted", + }, + { + id: 7, + title: "Warning!", + description: "Use QTool responsibly and try your best to do everything correctly. The AMIV treasury will be very grateful. In the end, we all do this work voluntarily. Finally, every request will be thoroughly checked by the AMIV treasury; any fraudulent behavior will have consequences.", + isFinalPage: true, + } + ]; + + // State + const [currentPage, setCurrentPage] = useState(1); + const [selectedOption, setSelectedOption] = useState(""); + const [answeredPages, setAnsweredPages] = useState<number[]>([]); + const [termsAccepted, setTermsAccepted] = useState(false); + + // Derived values + const totalPages = data.length; + const currentItem = data[currentPage - 1]; + + // Handle multiple-choice selection + const handleOptionChange = (event: React.ChangeEvent<HTMLInputElement>) => { + setSelectedOption(event.target.value); + }; + + // Validate the selected answer + const checkAnswer = () => { + if ( + selectedOption.trim().toLowerCase() === + (currentItem.correctAnswer?.toLowerCase() ?? "") + ) { + // Mark page as answered correctly if not already + if (!answeredPages.includes(currentItem.id)) { + setAnsweredPages((prev) => [...prev, currentItem.id]); + } + setSelectedOption(""); // Clear the selection + // Auto-advance if not on the last page + if (currentPage < totalPages) { + setCurrentPage((prev) => prev + 1); + } + } else { + alert("Incorrect answer. Please try again!"); + } + }; + + // Navigate to previous page + const goToPreviousPage = () => { + if (currentPage > 1) { + setCurrentPage((prev) => prev - 1); + setSelectedOption(""); + } + }; + + // Navigate to next page (only if page is answered or is the final page) + const goToNextPage = () => { + // If it's a quiz page, must be answered before allowing next + if (currentItem?.correctAnswer) { + // If current page is answered, or we are on the final page + if (answeredPages.includes(currentItem.id) && currentPage < totalPages) { + setCurrentPage((prev) => prev + 1); + setSelectedOption(""); + } + } else if (currentItem.isFinalPage && currentPage < totalPages) { + // Jump directly to T&C page if user hasn't gone there yet + setCurrentPage((prev) => prev + 1); + } + }; + + // Handle T&C acceptance on the final page + const handleAcceptTerms = () => { + // Usually you'd call an API or do something else before redirecting + // Then redirect once accepted: + window.location.href = "/Onboarding"; + }; + + return ( + <Container + sx={{ + display: "flex", + flexDirection: "column", + justifyContent: "center", + alignItems: "center", + padding: 2, + height: "100vh", + }} + > + {/* Title & Description */} + <Box sx={{ textAlign: "center", marginBottom: 2 }}> + <Typography variant="h4">{currentItem.title}</Typography> + <Typography variant="body1">{currentItem.description}</Typography> + </Box> + + {/* If it's the final page, show Terms & Conditions instead of quiz */} + {currentItem.isFinalPage ? ( + <Box> + {/* Example: Simple checkbox for T&C acceptance */} + <Box sx={{ display: "flex", alignItems: "center", marginBottom: 2 }}> + <Checkbox + checked={termsAccepted} + onChange={() => setTermsAccepted(!termsAccepted)} + /> + <Typography variant="body2"> + I am aware of my responsibilities and will use QTool responsibly. + </Typography> + </Box> + + <Button + variant="contained" + disabled={!termsAccepted} + onClick={handleAcceptTerms} + > + Submit & Continue to enter IBAN and address + </Button> + </Box> + ) : ( + <> + {/* Multiple Choice Question */} + {currentItem.options && currentItem.question && ( + <Box sx={{ marginBottom: 2 }}> + <FormControl component="fieldset"> + <FormLabel component="legend" sx={{ marginBottom: 1 }}> + {currentItem.question} + </FormLabel> + <RadioGroup + value={selectedOption} + onChange={handleOptionChange} + sx={{ marginLeft: 2 }} + > + {currentItem.options.map((option) => ( + <FormControlLabel + key={option} + value={option} + control={<Radio />} + label={option} + /> + ))} + </RadioGroup> + </FormControl> + </Box> + )} + + {/* Submit Button for Quiz Pages */} + {currentItem.correctAnswer && ( + <Box sx={{ textAlign: "center", marginBottom: 2 }}> + <Button + variant="contained" + color="primary" + onClick={checkAnswer} + sx={{ marginRight: 2 }} + > + Submit Answer + </Button> + </Box> + )} + + {/* Navigation Buttons */} + <Box sx={{ display: "flex", justifyContent: "center", gap: 1 }}> + <Button + variant="contained" + onClick={goToPreviousPage} + disabled={currentPage === 1} + > + Previous + </Button> + <Button + variant="contained" + onClick={goToNextPage} + disabled={ + // If it's a quiz page, disable Next if it's not answered yet + (currentItem.correctAnswer && + !answeredPages.includes(currentItem.id)) || + currentPage === totalPages + } + > + Next + </Button> + </Box> + </> + )} + </Container> + ); +} \ No newline at end of file diff --git a/src/pages/index.tsx b/src/pages/index.tsx index e45248976bc610b3307f2685cc0bac26002e5409..5e8660d58a09a176816c7f2d42ce20ea4e2ff176 100644 --- a/src/pages/index.tsx +++ b/src/pages/index.tsx @@ -1,25 +1,25 @@ import React from "react"; -import { Container, CircularProgress, Typography, Box } from "@mui/material"; +import { useAuth } from "../useAuth"; + +const Index: React.FC = () => { + const { user, isAuthenticated, login, logout } = useAuth(); -export default function Index() { return ( - <Container - sx={{ - display: "flex", - flexDirection: "column", // Stack children vertically - justifyContent: "center", - alignItems: "center", // Center horizontally - padding: 2, - height: "100vh", // Ensure full viewport height - }} - > - <Box sx={{ textAlign: "center", marginBottom: 2 }}> - <Typography variant="h6"> - This page is still work in Progress, but check out the pages in the - side bar, you are up for a treat. - </Typography> - </Box> - <CircularProgress /> - </Container> + <div> + <h1>Welcome to the App</h1> + {isAuthenticated ? ( + <> + <p>Logged in as: {user?.firstname} {user?.lastname}</p> + <button onClick={logout}>Logout</button> + </> + ) : ( + <> + <p>You are not logged in.</p> + <button onClick={login}>Login</button> + </> + )} + </div> ); -} +}; + +export default Index; diff --git a/src/pages/root.tsx b/src/pages/root.tsx index 639fb2548adb478f1e4e1b69ccf696266bb052b6..82f05fa54d7448d22f6932bd8b131914b46d01e7 100644 --- a/src/pages/root.tsx +++ b/src/pages/root.tsx @@ -39,6 +39,11 @@ import AmivWheelSVG from "../assets/amiv-wheel.svg"; import Callback from "../Callback"; const navContent = [ + { + path: "/", + name: "Home", + icon: <Home />, + }, { path: "/creditlist", name: "Credit List", @@ -75,16 +80,16 @@ const navContent = [ name: "Internal Transfer", icon: <ShoppingCart />, }, - { - path: "/Onboarding", - name: "Onboarding", - icon: <Groups />, - }, { path: "/KstEval", name: "Kst Evaluation", icon: <Groups />, }, + { + path: "/onboardingCourse", + name: "Onboarding", + icon: <Groups />, + } ] as { path: string; name: string; icon: React.ReactNode }[]; function NavigationList() { diff --git a/src/useAuth.tsx b/src/useAuth.tsx new file mode 100644 index 0000000000000000000000000000000000000000..f5d036a9f6927cf73cf4705aae27eab6e968e5c9 --- /dev/null +++ b/src/useAuth.tsx @@ -0,0 +1,104 @@ +import { createContext, ReactNode, useState, useEffect, useContext } from "react"; +import { useLocation, useNavigate } from "react-router-dom"; +import { authGetBasicUserInfo } from "./client/services.gen"; // Import your generated service function + +// User type definition +interface User { + id: string; + firstname: string; + lastname: string; + email: string; + role: string | null; +} + +// AuthContext type definition +interface AuthContextType { + user?: User; // If undefined, user is not signed in + authError?: string; // If there was an error fetching user data + login: () => void; // Function to trigger login + logout: () => void; // Function to trigger logout + isAuthenticated: boolean; // Boolean indicating login state +} + +// Create AuthContext +const AuthContext = createContext<AuthContextType | undefined>(undefined); + +export function AuthProvider({ children }: { children: ReactNode }): JSX.Element { + const [user, setUser] = useState<User | undefined>(); + const [authError, setAuthError] = useState<string | undefined>(); + const [isAuthenticated, setIsAuthenticated] = useState(false); + + const location = useLocation(); + const navigate = useNavigate(); + + // Clear errors on route change + useEffect(() => { + setAuthError(undefined); + }, [location]); + + // Fetch user info on initial load + useEffect(() => { + const fetchUser = async () => { + try { + const response = await authGetBasicUserInfo(); + console.log("Fetched user:", response.data); // Debug log + + const basicUser = response.data; + const transformedUser: User = { + id: basicUser.id, + firstname: basicUser.firstname, + lastname: basicUser.lastname, + email: basicUser.email, + role: basicUser.role ?? null, + }; + + setUser(transformedUser); + setIsAuthenticated(true); + } catch (error: any) { + console.error("Error fetching user:", error.message || error); // Debug log + setAuthError(error.message || "Failed to fetch user data"); + setIsAuthenticated(false); + } + }; + + fetchUser(); + }, []); + + // Login function + const login = () => { + console.log("Redirecting to login..."); + window.location.href = "/api/login"; // Redirect to your backend login endpoint + }; + + // Logout function + const logout = () => { + console.log("Logging out..."); + setUser(undefined); + setIsAuthenticated(false); + localStorage.removeItem("token"); // Clear session token if stored + navigate("/"); // Redirect to the homepage + }; + + const contextValue = { + user, + authError, + isAuthenticated, + login, + logout, + }; + + return ( + <AuthContext.Provider value={contextValue}> + {children} + </AuthContext.Provider> + ); +} + +// Custom hook to use AuthContext +export const useAuth = () => { + const context = useContext(AuthContext); + if (!context) { + throw new Error("useAuth must be used within an AuthProvider"); + } + return context; +}; diff --git a/yarn.lock b/yarn.lock index f2951034945159656e49de3462620c39e0a25b6f..bc33bf1958370d91140bd6c22e8353ba228b90bd 100644 --- a/yarn.lock +++ b/yarn.lock @@ -144,7 +144,7 @@ "@babel/runtime-corejs3@^7.12.1": version "7.26.0" - resolved "https://registry.yarnpkg.com/@babel/runtime-corejs3/-/runtime-corejs3-7.26.0.tgz#5af6bed16073eb4a0191233d61e158a5c768c430" + resolved "https://registry.npmjs.org/@babel/runtime-corejs3/-/runtime-corejs3-7.26.0.tgz" integrity sha512-YXHu5lN8kJCb1LOb9PgV6pvak43X2h4HvRApcN5SdWeaItQOzfn1hgP6jasD6KWQyJDBxrVmA9o9OivlnNJK/w== dependencies: core-js-pure "^3.30.2" @@ -204,9 +204,9 @@ source-map "^0.5.7" stylis "4.2.0" -"@emotion/cache@*", "@emotion/cache@^11.7.1": +"@emotion/cache@*": version "11.14.0" - resolved "https://registry.yarnpkg.com/@emotion/cache/-/cache-11.14.0.tgz#ee44b26986eeb93c8be82bb92f1f7a9b21b2ed76" + resolved "https://registry.npmjs.org/@emotion/cache/-/cache-11.14.0.tgz" integrity sha512-L/B1lc/TViYk4DcpGxtAVbx0ZyiKM5ktoIyafGkH6zg/tj+mA+NE//aPYKG0k8kCHSHVJrpLpcAlOBEXQ3SavA== dependencies: "@emotion/memoize" "^0.9.0" @@ -226,6 +226,17 @@ "@emotion/weak-memoize" "^0.4.0" stylis "4.2.0" +"@emotion/cache@^11.7.1": + version "11.14.0" + resolved "https://registry.npmjs.org/@emotion/cache/-/cache-11.14.0.tgz" + integrity sha512-L/B1lc/TViYk4DcpGxtAVbx0ZyiKM5ktoIyafGkH6zg/tj+mA+NE//aPYKG0k8kCHSHVJrpLpcAlOBEXQ3SavA== + dependencies: + "@emotion/memoize" "^0.9.0" + "@emotion/sheet" "^1.4.0" + "@emotion/utils" "^1.4.2" + "@emotion/weak-memoize" "^0.4.0" + stylis "4.2.0" + "@emotion/hash@^0.9.2": version "0.9.2" resolved "https://registry.npmjs.org/@emotion/hash/-/hash-0.9.2.tgz" @@ -259,7 +270,7 @@ "@emotion/serialize@*": version "1.3.3" - resolved "https://registry.yarnpkg.com/@emotion/serialize/-/serialize-1.3.3.tgz#d291531005f17d704d0463a032fe679f376509e8" + resolved "https://registry.npmjs.org/@emotion/serialize/-/serialize-1.3.3.tgz" integrity sha512-EISGqt7sSNWHGI76hC7x1CksiXPahbxEOrC5RjmFRJTqLyEK9/9hZvBbiYn70dw4wuwMKiEMCUlR6ZXTSWQqxA== dependencies: "@emotion/hash" "^0.9.2" @@ -308,7 +319,7 @@ "@emotion/utils@*", "@emotion/utils@^1.4.2": version "1.4.2" - resolved "https://registry.yarnpkg.com/@emotion/utils/-/utils-1.4.2.tgz#6df6c45881fcb1c412d6688a311a98b7f59c1b52" + resolved "https://registry.npmjs.org/@emotion/utils/-/utils-1.4.2.tgz" integrity sha512-3vLclRofFziIa3J2wDh9jjbkUz9qk5Vi3IZ/FSTKViB0k+ef0fPV7dYrUIugbgupYDx7v9ud/SjrtEP8Y4xLoA== "@emotion/utils@^1.4.0", "@emotion/utils@^1.4.1": @@ -321,121 +332,11 @@ resolved "https://registry.npmjs.org/@emotion/weak-memoize/-/weak-memoize-0.4.0.tgz" integrity sha512-snKqtPW01tN0ui7yu9rGv69aJXr/a/Ywvl11sUjNtEcRc+ng/mQriFL0wLXMef74iHa/EkftbDzU9F8iFbH+zg== -"@esbuild/aix-ppc64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz#c7184a326533fcdf1b8ee0733e21c713b975575f" - integrity sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ== - -"@esbuild/android-arm64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/android-arm64/-/android-arm64-0.21.5.tgz#09d9b4357780da9ea3a7dfb833a1f1ff439b4052" - integrity sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A== - -"@esbuild/android-arm@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/android-arm/-/android-arm-0.21.5.tgz#9b04384fb771926dfa6d7ad04324ecb2ab9b2e28" - integrity sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg== - -"@esbuild/android-x64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/android-x64/-/android-x64-0.21.5.tgz#29918ec2db754cedcb6c1b04de8cd6547af6461e" - integrity sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA== - -"@esbuild/darwin-arm64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/darwin-arm64/-/darwin-arm64-0.21.5.tgz#e495b539660e51690f3928af50a76fb0a6ccff2a" - integrity sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ== - -"@esbuild/darwin-x64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/darwin-x64/-/darwin-x64-0.21.5.tgz#c13838fa57372839abdddc91d71542ceea2e1e22" - integrity sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw== - -"@esbuild/freebsd-arm64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/freebsd-arm64/-/freebsd-arm64-0.21.5.tgz#646b989aa20bf89fd071dd5dbfad69a3542e550e" - integrity sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g== - -"@esbuild/freebsd-x64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/freebsd-x64/-/freebsd-x64-0.21.5.tgz#aa615cfc80af954d3458906e38ca22c18cf5c261" - integrity sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ== - -"@esbuild/linux-arm64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/linux-arm64/-/linux-arm64-0.21.5.tgz#70ac6fa14f5cb7e1f7f887bcffb680ad09922b5b" - integrity sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q== - -"@esbuild/linux-arm@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/linux-arm/-/linux-arm-0.21.5.tgz#fc6fd11a8aca56c1f6f3894f2bea0479f8f626b9" - integrity sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA== - -"@esbuild/linux-ia32@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/linux-ia32/-/linux-ia32-0.21.5.tgz#3271f53b3f93e3d093d518d1649d6d68d346ede2" - integrity sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg== - -"@esbuild/linux-loong64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/linux-loong64/-/linux-loong64-0.21.5.tgz#ed62e04238c57026aea831c5a130b73c0f9f26df" - integrity sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg== - -"@esbuild/linux-mips64el@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/linux-mips64el/-/linux-mips64el-0.21.5.tgz#e79b8eb48bf3b106fadec1ac8240fb97b4e64cbe" - integrity sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg== - -"@esbuild/linux-ppc64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/linux-ppc64/-/linux-ppc64-0.21.5.tgz#5f2203860a143b9919d383ef7573521fb154c3e4" - integrity sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w== - -"@esbuild/linux-riscv64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/linux-riscv64/-/linux-riscv64-0.21.5.tgz#07bcafd99322d5af62f618cb9e6a9b7f4bb825dc" - integrity sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA== - -"@esbuild/linux-s390x@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/linux-s390x/-/linux-s390x-0.21.5.tgz#b7ccf686751d6a3e44b8627ababc8be3ef62d8de" - integrity sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A== - "@esbuild/linux-x64@0.21.5": version "0.21.5" resolved "https://registry.npmjs.org/@esbuild/linux-x64/-/linux-x64-0.21.5.tgz" integrity sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ== -"@esbuild/netbsd-x64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/netbsd-x64/-/netbsd-x64-0.21.5.tgz#bbe430f60d378ecb88decb219c602667387a6047" - integrity sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg== - -"@esbuild/openbsd-x64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/openbsd-x64/-/openbsd-x64-0.21.5.tgz#99d1cf2937279560d2104821f5ccce220cb2af70" - integrity sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow== - -"@esbuild/sunos-x64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/sunos-x64/-/sunos-x64-0.21.5.tgz#08741512c10d529566baba837b4fe052c8f3487b" - integrity sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg== - -"@esbuild/win32-arm64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/win32-arm64/-/win32-arm64-0.21.5.tgz#675b7385398411240735016144ab2e99a60fc75d" - integrity sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A== - -"@esbuild/win32-ia32@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/win32-ia32/-/win32-ia32-0.21.5.tgz#1bfc3ce98aa6ca9a0969e4d2af72144c59c1193b" - integrity sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA== - -"@esbuild/win32-x64@0.21.5": - version "0.21.5" - resolved "https://registry.yarnpkg.com/@esbuild/win32-x64/-/win32-x64-0.21.5.tgz#acad351d582d157bb145535db2a6ff53dd514b5c" - integrity sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw== - "@eslint-community/eslint-utils@^4.2.0", "@eslint-community/eslint-utils@^4.4.0": version "4.4.1" resolved "https://registry.npmjs.org/@eslint-community/eslint-utils/-/eslint-utils-4.4.1.tgz" @@ -482,7 +383,7 @@ minimatch "^3.1.2" strip-json-comments "^3.1.1" -"@eslint/js@9.14.0", "@eslint/js@^9.14.0": +"@eslint/js@^9.14.0", "@eslint/js@9.14.0": version "9.14.0" resolved "https://registry.npmjs.org/@eslint/js/-/js-9.14.0.tgz" integrity sha512-pFoEtFWCPyDOl+C6Ift+wC7Ro89otjigCf5vcuWqWgqNSQbRrpjSvdeE6ofLz4dHmyxD5f7gIdGT4+p36L6Twg== @@ -730,7 +631,7 @@ "@nodelib/fs.stat" "2.0.5" run-parallel "^1.1.9" -"@nodelib/fs.stat@2.0.5", "@nodelib/fs.stat@^2.0.2": +"@nodelib/fs.stat@^2.0.2", "@nodelib/fs.stat@2.0.5": version "2.0.5" resolved "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz" integrity sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A== @@ -750,17 +651,17 @@ "@react-dnd/asap@^4.0.0": version "4.0.1" - resolved "https://registry.yarnpkg.com/@react-dnd/asap/-/asap-4.0.1.tgz#5291850a6b58ce6f2da25352a64f1b0674871aab" + resolved "https://registry.npmjs.org/@react-dnd/asap/-/asap-4.0.1.tgz" integrity sha512-kLy0PJDDwvwwTXxqTFNAAllPHD73AycE9ypWeln/IguoGBEbvFcPDbCV03G52bEcC5E+YgupBE0VzHGdC8SIXg== "@react-dnd/invariant@^2.0.0": version "2.0.0" - resolved "https://registry.yarnpkg.com/@react-dnd/invariant/-/invariant-2.0.0.tgz#09d2e81cd39e0e767d7da62df9325860f24e517e" + resolved "https://registry.npmjs.org/@react-dnd/invariant/-/invariant-2.0.0.tgz" integrity sha512-xL4RCQBCBDJ+GRwKTFhGUW8GXa4yoDfJrPbLblc3U09ciS+9ZJXJ3Qrcs/x2IODOdIE5kQxvMmE2UKyqUictUw== "@react-dnd/shallowequal@^2.0.0": version "2.0.0" - resolved "https://registry.yarnpkg.com/@react-dnd/shallowequal/-/shallowequal-2.0.0.tgz#a3031eb54129f2c66b2753f8404266ec7bf67f0a" + resolved "https://registry.npmjs.org/@react-dnd/shallowequal/-/shallowequal-2.0.0.tgz" integrity sha512-Pc/AFTdwZwEKJxFJvlxrSmGe/di+aAOBn60sremrpLo6VI/6cmiUYNNwlI5KNYttg7uypzA3ILPMPgxB2GYZEg== "@remix-run/router@1.20.0": @@ -768,71 +669,6 @@ resolved "https://registry.npmjs.org/@remix-run/router/-/router-1.20.0.tgz" integrity sha512-mUnk8rPJBI9loFDZ+YzPGdeniYK+FTmRD1TMCz7ev2SNIozyKKpnGgsxO34u6Z4z/t0ITuu7voi/AshfsGsgFg== -"@rollup/rollup-android-arm-eabi@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.24.4.tgz#c460b54c50d42f27f8254c435a4f3b3e01910bc8" - integrity sha512-jfUJrFct/hTA0XDM5p/htWKoNNTbDLY0KRwEt6pyOA6k2fmk0WVwl65PdUdJZgzGEHWx+49LilkcSaumQRyNQw== - -"@rollup/rollup-android-arm64@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.24.4.tgz#96e01f3a04675d8d5973ab8d3fd6bc3be21fa5e1" - integrity sha512-j4nrEO6nHU1nZUuCfRKoCcvh7PIywQPUCBa2UsootTHvTHIoIu2BzueInGJhhvQO/2FTRdNYpf63xsgEqH9IhA== - -"@rollup/rollup-darwin-arm64@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.24.4.tgz#9b2ec23b17b47cbb2f771b81f86ede3ac6730bce" - integrity sha512-GmU/QgGtBTeraKyldC7cDVVvAJEOr3dFLKneez/n7BvX57UdhOqDsVwzU7UOnYA7AAOt+Xb26lk79PldDHgMIQ== - -"@rollup/rollup-darwin-x64@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.24.4.tgz#f30e4ee6929e048190cf10e0daa8e8ae035b6e46" - integrity sha512-N6oDBiZCBKlwYcsEPXGDE4g9RoxZLK6vT98M8111cW7VsVJFpNEqvJeIPfsCzbf0XEakPslh72X0gnlMi4Ddgg== - -"@rollup/rollup-freebsd-arm64@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-freebsd-arm64/-/rollup-freebsd-arm64-4.24.4.tgz#c54b2373ec5bcf71f08c4519c7ae80a0b6c8e03b" - integrity sha512-py5oNShCCjCyjWXCZNrRGRpjWsF0ic8f4ieBNra5buQz0O/U6mMXCpC1LvrHuhJsNPgRt36tSYMidGzZiJF6mw== - -"@rollup/rollup-freebsd-x64@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-freebsd-x64/-/rollup-freebsd-x64-4.24.4.tgz#3bc53aa29d5a34c28ba8e00def76aa612368458e" - integrity sha512-L7VVVW9FCnTTp4i7KrmHeDsDvjB4++KOBENYtNYAiYl96jeBThFfhP6HVxL74v4SiZEVDH/1ILscR5U9S4ms4g== - -"@rollup/rollup-linux-arm-gnueabihf@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.24.4.tgz#c85aedd1710c9e267ee86b6d1ce355ecf7d9e8d9" - integrity sha512-10ICosOwYChROdQoQo589N5idQIisxjaFE/PAnX2i0Zr84mY0k9zul1ArH0rnJ/fpgiqfu13TFZR5A5YJLOYZA== - -"@rollup/rollup-linux-arm-musleabihf@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.24.4.tgz#e77313408bf13995aecde281aec0cceb08747e42" - integrity sha512-ySAfWs69LYC7QhRDZNKqNhz2UKN8LDfbKSMAEtoEI0jitwfAG2iZwVqGACJT+kfYvvz3/JgsLlcBP+WWoKCLcw== - -"@rollup/rollup-linux-arm64-gnu@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.24.4.tgz#633f632397b3662108cfaa1abca2a80b85f51102" - integrity sha512-uHYJ0HNOI6pGEeZ/5mgm5arNVTI0nLlmrbdph+pGXpC9tFHFDQmDMOEqkmUObRfosJqpU8RliYoGz06qSdtcjg== - -"@rollup/rollup-linux-arm64-musl@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.24.4.tgz#63edd72b29c4cced93e16113a68e1be9fef88907" - integrity sha512-38yiWLemQf7aLHDgTg85fh3hW9stJ0Muk7+s6tIkSUOMmi4Xbv5pH/5Bofnsb6spIwD5FJiR+jg71f0CH5OzoA== - -"@rollup/rollup-linux-powerpc64le-gnu@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.24.4.tgz#a9418a4173df80848c0d47df0426a0bf183c4e75" - integrity sha512-q73XUPnkwt9ZNF2xRS4fvneSuaHw2BXuV5rI4cw0fWYVIWIBeDZX7c7FWhFQPNTnE24172K30I+dViWRVD9TwA== - -"@rollup/rollup-linux-riscv64-gnu@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.24.4.tgz#bc9c195db036a27e5e3339b02f51526b4ce1e988" - integrity sha512-Aie/TbmQi6UXokJqDZdmTJuZBCU3QBDA8oTKRGtd4ABi/nHgXICulfg1KI6n9/koDsiDbvHAiQO3YAUNa/7BCw== - -"@rollup/rollup-linux-s390x-gnu@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.24.4.tgz#1651fdf8144ae89326c01da5d52c60be63e71a82" - integrity sha512-P8MPErVO/y8ohWSP9JY7lLQ8+YMHfTI4bAdtCi3pC2hTeqFJco2jYspzOzTUB8hwUWIIu1xwOrJE11nP+0JFAQ== - "@rollup/rollup-linux-x64-gnu@4.24.4": version "4.24.4" resolved "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.24.4.tgz" @@ -843,33 +679,6 @@ resolved "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.24.4.tgz" integrity sha512-VJYl4xSl/wqG2D5xTYncVWW+26ICV4wubwN9Gs5NrqhJtayikwCXzPL8GDsLnaLU3WwhQ8W02IinYSFJfyo34Q== -"@rollup/rollup-win32-arm64-msvc@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.24.4.tgz#e48e78cdd45313b977c1390f4bfde7ab79be8871" - integrity sha512-ku2GvtPwQfCqoPFIJCqZ8o7bJcj+Y54cZSr43hHca6jLwAiCbZdBUOrqE6y29QFajNAzzpIOwsckaTFmN6/8TA== - -"@rollup/rollup-win32-ia32-msvc@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.24.4.tgz#a3fc8536d243fe161c796acb93eba43c250f311c" - integrity sha512-V3nCe+eTt/W6UYNr/wGvO1fLpHUrnlirlypZfKCT1fG6hWfqhPgQV/K/mRBXBpxc0eKLIF18pIOFVPh0mqHjlg== - -"@rollup/rollup-win32-x64-msvc@4.24.4": - version "4.24.4" - resolved "https://registry.yarnpkg.com/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.24.4.tgz#e2a9d1fd56524103a6cc8a54404d9d3ebc73c454" - integrity sha512-LTw1Dfd0mBIEqUVCxbvTE/LLo+9ZxVC9k99v1v4ahg9Aak6FpqOfNu5kRkeTAn0wphoC4JU7No1/rL+bBCEwhg== - -"@types/babel-traverse@^6.7.17": - version "6.25.10" - resolved "https://registry.npmjs.org/@types/babel-traverse/-/babel-traverse-6.25.10.tgz" - integrity sha512-B3XitTFG8YeXb5lr7Nj62t1DikCDuAJ/4BDeK6GCuWREEmdunI9DWnv+81oHl2yQBQPWY/C1PmV3vaRZB4LQmw== - dependencies: - "@types/babel-types" "*" - -"@types/babel-types@*": - version "7.0.16" - resolved "https://registry.npmjs.org/@types/babel-types/-/babel-types-7.0.16.tgz" - integrity sha512-5QXs9GBFTNTmilLlWBhnsprqpjfrotyrnzUdwDrywEL/DA4LuCWQT300BTOXA3Y9ngT9F2uvmCoIxI6z8DlJEA== - "@types/babel__core@^7.20.5": version "7.20.5" resolved "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.20.5.tgz" @@ -903,14 +712,26 @@ dependencies: "@babel/types" "^7.20.7" -"@types/estree@1.0.6", "@types/estree@^1.0.6": +"@types/babel-traverse@^6.7.17": + version "6.25.10" + resolved "https://registry.npmjs.org/@types/babel-traverse/-/babel-traverse-6.25.10.tgz" + integrity sha512-B3XitTFG8YeXb5lr7Nj62t1DikCDuAJ/4BDeK6GCuWREEmdunI9DWnv+81oHl2yQBQPWY/C1PmV3vaRZB4LQmw== + dependencies: + "@types/babel-types" "*" + +"@types/babel-types@*": + version "7.0.16" + resolved "https://registry.npmjs.org/@types/babel-types/-/babel-types-7.0.16.tgz" + integrity sha512-5QXs9GBFTNTmilLlWBhnsprqpjfrotyrnzUdwDrywEL/DA4LuCWQT300BTOXA3Y9ngT9F2uvmCoIxI6z8DlJEA== + +"@types/estree@^1.0.6", "@types/estree@1.0.6": version "1.0.6" resolved "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz" integrity sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw== "@types/hoist-non-react-statics@^3.3.1": version "3.3.6" - resolved "https://registry.yarnpkg.com/@types/hoist-non-react-statics/-/hoist-non-react-statics-3.3.6.tgz#6bba74383cdab98e8db4e20ce5b4a6b98caed010" + resolved "https://registry.npmjs.org/@types/hoist-non-react-statics/-/hoist-non-react-statics-3.3.6.tgz" integrity sha512-lPByRJUer/iN/xa4qpyL0qmL11DqNW81iU/IG1S3uvRUq4oKagz8VCxZjiWkumgt66YT3vOdDgZ0o32sGKtCEw== dependencies: "@types/react" "*" @@ -931,6 +752,11 @@ resolved "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.13.tgz" integrity sha512-hCZTSvwbzWGvhqxp/RqVqwU999pBf2vp7hzIjiYOsl8wqOmUxkQ6ddw1cV3l8811+kdUFus/q4d1Y3E3SyEifA== +"@types/react-dom@^19.0.2": + version "19.0.2" + resolved "https://registry.npmjs.org/@types/react-dom/-/react-dom-19.0.2.tgz" + integrity sha512-c1s+7TKFaDRRxr1TxccIX2u7sfCnc3RxkVyBIUA2lCpyqCF+QoAwQ/CBg7bsMdVwP120HEH143VQezKtef5nCg== + "@types/react-transition-group@^4.4.11": version "4.4.11" resolved "https://registry.npmjs.org/@types/react-transition-group/-/react-transition-group-4.4.11.tgz" @@ -1070,6 +896,20 @@ argparse@^2.0.1: resolved "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz" integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== +asynckit@^0.4.0: + version "0.4.0" + resolved "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz" + integrity sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q== + +axios@^1.7.9: + version "1.7.9" + resolved "https://registry.npmjs.org/axios/-/axios-1.7.9.tgz" + integrity sha512-LhLcE7Hbiryz8oMDdDptSrWowmB4Bl6RCt6sIJKpRB4XtVf0iEgewX3au/pJqm+Py1kCASkb/FFKjxQaLtxJvw== + dependencies: + follow-redirects "^1.15.6" + form-data "^4.0.0" + proxy-from-env "^1.1.0" + babel-plugin-macros@^3.1.0: version "3.1.0" resolved "https://registry.npmjs.org/babel-plugin-macros/-/babel-plugin-macros-3.1.0.tgz" @@ -1176,9 +1016,14 @@ citty@^0.1.6: dependencies: consola "^3.2.3" -clsx@^1.0.4, clsx@^1.1.1: +clsx@^1.0.4: + version "1.2.1" + resolved "https://registry.npmjs.org/clsx/-/clsx-1.2.1.tgz" + integrity sha512-EcR6r5a8bj6pu3ycsa/E/cKVGuTgZJZdsyUYHOksG/UHIiKfjxzRxYJpyVBwYaQeOvghal9fcc4PidlgzugAQg== + +clsx@^1.1.1: version "1.2.1" - resolved "https://registry.yarnpkg.com/clsx/-/clsx-1.2.1.tgz#0ddc4a20a549b59c93a4116bb26f5294ca17dc12" + resolved "https://registry.npmjs.org/clsx/-/clsx-1.2.1.tgz" integrity sha512-EcR6r5a8bj6pu3ycsa/E/cKVGuTgZJZdsyUYHOksG/UHIiKfjxzRxYJpyVBwYaQeOvghal9fcc4PidlgzugAQg== clsx@^2.1.1: @@ -1198,6 +1043,13 @@ color-name@~1.1.4: resolved "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz" integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== +combined-stream@^1.0.8: + version "1.0.8" + resolved "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz" + integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg== + dependencies: + delayed-stream "~1.0.0" + commander@12.1.0: version "12.1.0" resolved "https://registry.npmjs.org/commander/-/commander-12.1.0.tgz" @@ -1230,7 +1082,7 @@ convert-source-map@^2.0.0: core-js-pure@^3.30.2: version "3.39.0" - resolved "https://registry.yarnpkg.com/core-js-pure/-/core-js-pure-3.39.0.tgz#aa0d54d70a15bdc13e7c853db87c10abc30d68f3" + resolved "https://registry.npmjs.org/core-js-pure/-/core-js-pure-3.39.0.tgz" integrity sha512-7fEcWwKI4rJinnK+wLTezeg2smbFFdSBP6E2kQZNbnzM2s1rpKQ6aaRteZSSg7FLU3P0HGGVo/gbpfanU36urg== cosmiconfig@^7.0.0: @@ -1280,6 +1132,11 @@ defu@^6.1.4: resolved "https://registry.npmjs.org/defu/-/defu-6.1.4.tgz" integrity sha512-mEQCMmwJu317oSz8CwdIOdwf3xMif1ttiM8LTufzc3g6kR+9Pe236twL8j3IYT1F7GfRgGcW6MWxzZjLIkuHIg== +delayed-stream@~1.0.0: + version "1.0.0" + resolved "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz" + integrity sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ== + destr@^2.0.3: version "2.0.3" resolved "https://registry.npmjs.org/destr/-/destr-2.0.3.tgz" @@ -1287,7 +1144,7 @@ destr@^2.0.3: dnd-core@^11.1.3: version "11.1.3" - resolved "https://registry.yarnpkg.com/dnd-core/-/dnd-core-11.1.3.tgz#f92099ba7245e49729d2433157031a6267afcc98" + resolved "https://registry.npmjs.org/dnd-core/-/dnd-core-11.1.3.tgz" integrity sha512-QugF55dNW+h+vzxVJ/LSJeTeUw9MCJ2cllhmVThVPEtF16ooBkxj0WBE5RB+AceFxMFo1rO6bJKXtqKl+JNnyA== dependencies: "@react-dnd/asap" "^4.0.0" @@ -1562,6 +1419,20 @@ flatted@^3.2.9: resolved "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz" integrity sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw== +follow-redirects@^1.15.6: + version "1.15.9" + resolved "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.9.tgz" + integrity sha512-gew4GsXizNgdoRyqmyfMHyAmXsZDk6mHkSxZFCzW9gwlbtOW44CDtYavM+y+72qD/Vq2l550kMF52DT8fOLJqQ== + +form-data@^4.0.0: + version "4.0.1" + resolved "https://registry.npmjs.org/form-data/-/form-data-4.0.1.tgz" + integrity sha512-tzN8e4TX8+kkxGPK8D5u0FNmjPUjw3lwC9lSLxxoB/+GtsJG91CO8bSWy73APlgAZzZbXEYZJuxjkHH2w+Ezhw== + dependencies: + asynckit "^0.4.0" + combined-stream "^1.0.8" + mime-types "^2.1.12" + fs-minipass@^2.0.0: version "2.1.0" resolved "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz" @@ -1569,11 +1440,6 @@ fs-minipass@^2.0.0: dependencies: minipass "^3.0.0" -fsevents@~2.3.2, fsevents@~2.3.3: - version "2.3.3" - resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.3.tgz#cac6407785d03675a2a5e1a5305c697b347d90d6" - integrity sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw== - function-bind@^1.1.2: version "1.1.2" resolved "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz" @@ -1801,42 +1667,42 @@ locate-path@^6.0.0: lodash.assignwith@^4.2.0: version "4.2.0" - resolved "https://registry.yarnpkg.com/lodash.assignwith/-/lodash.assignwith-4.2.0.tgz#127a97f02adc41751a954d24b0de17e100e038eb" + resolved "https://registry.npmjs.org/lodash.assignwith/-/lodash.assignwith-4.2.0.tgz" integrity sha512-ZznplvbvtjK2gMvnQ1BR/zqPFZmS6jbK4p+6Up4xcRYA7yMIwxHCfbTcrYxXKzzqLsQ05eJPVznEW3tuwV7k1g== lodash.clonedeep@^4.5.0: version "4.5.0" - resolved "https://registry.yarnpkg.com/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz#e23f3f9c4f8fbdde872529c1071857a086e5ccef" + resolved "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz" integrity sha512-H5ZhCF25riFd9uB5UCkVKo61m3S/xZk1x4wA6yp/L3RFP6Z/eHH1ymQcGLo7J3GMPfm0V/7m1tryHuGVxpqEBQ== lodash.debounce@^4.0.8: version "4.0.8" - resolved "https://registry.yarnpkg.com/lodash.debounce/-/lodash.debounce-4.0.8.tgz#82d79bff30a67c4005ffd5e2515300ad9ca4d7af" + resolved "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz" integrity sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow== lodash.find@^4.6.0: version "4.6.0" - resolved "https://registry.yarnpkg.com/lodash.find/-/lodash.find-4.6.0.tgz#cb0704d47ab71789ffa0de8b97dd926fb88b13b1" + resolved "https://registry.npmjs.org/lodash.find/-/lodash.find-4.6.0.tgz" integrity sha512-yaRZoAV3Xq28F1iafWN1+a0rflOej93l1DQUejs3SZ41h2O9UJBoS9aueGjPDgAl4B6tPC0NuuchLKaDQQ3Isg== lodash.get@^4.4.2: version "4.4.2" - resolved "https://registry.yarnpkg.com/lodash.get/-/lodash.get-4.4.2.tgz#2d177f652fa31e939b4438d5341499dfa3825e99" + resolved "https://registry.npmjs.org/lodash.get/-/lodash.get-4.4.2.tgz" integrity sha512-z+Uw/vLuy6gQe8cfaFWD7p0wVv8fJl3mbzXh33RS+0oW2wvUqiRXiQ69gLWSLpgB5/6sU+r6BlQR0MBILadqTQ== lodash.isequal@^4.5.0: version "4.5.0" - resolved "https://registry.yarnpkg.com/lodash.isequal/-/lodash.isequal-4.5.0.tgz#415c4478f2bcc30120c22ce10ed3226f7d3e18e0" + resolved "https://registry.npmjs.org/lodash.isequal/-/lodash.isequal-4.5.0.tgz" integrity sha512-pDo3lu8Jhfjqls6GkMgpahsF9kCyayhgykjyLMNFTKWrpVdAQtYyB4muAMWozBB4ig/dtWAmsMxLEI8wuz+DYQ== lodash.isundefined@^3.0.1: version "3.0.1" - resolved "https://registry.yarnpkg.com/lodash.isundefined/-/lodash.isundefined-3.0.1.tgz#23ef3d9535565203a66cefd5b830f848911afb48" + resolved "https://registry.npmjs.org/lodash.isundefined/-/lodash.isundefined-3.0.1.tgz" integrity sha512-MXB1is3s899/cD8jheYYE2V9qTHwKvt+npCwpD+1Sxm3Q3cECXCiYHjeHWXNwr6Q0SOBPrYUDxendrO6goVTEA== lodash.memoize@^4.1.2: version "4.1.2" - resolved "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-4.1.2.tgz#bcc6c49a42a2840ed997f323eada5ecd182e0bfe" + resolved "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz" integrity sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag== lodash.merge@^4.6.2: @@ -1846,7 +1712,7 @@ lodash.merge@^4.6.2: lodash.throttle@^4.0.1: version "4.1.1" - resolved "https://registry.yarnpkg.com/lodash.throttle/-/lodash.throttle-4.1.1.tgz#c23e91b710242ac70c37f1e1cda9274cc39bf2f4" + resolved "https://registry.npmjs.org/lodash.throttle/-/lodash.throttle-4.1.1.tgz" integrity sha512-wIkUCfVKpVsWo3JSZlc+8MB5it+2AN5W8J7YVMST30UrvcQNZ1Okbj+rbVniijTWE6FGYy4XJq/rHkas8qJMLQ== loose-envify@^1.1.0, loose-envify@^1.4.0: @@ -1888,6 +1754,18 @@ micromatch@^4.0.4: braces "^3.0.3" picomatch "^2.3.1" +mime-db@1.52.0: + version "1.52.0" + resolved "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz" + integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== + +mime-types@^2.1.12: + version "2.1.35" + resolved "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz" + integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== + dependencies: + mime-db "1.52.0" + mimic-fn@^4.0.0: version "4.0.0" resolved "https://registry.npmjs.org/mimic-fn/-/mimic-fn-4.0.0.tgz" @@ -1961,7 +1839,7 @@ ms@^2.1.3: mui-datatables@^4.3.0: version "4.3.0" - resolved "https://registry.yarnpkg.com/mui-datatables/-/mui-datatables-4.3.0.tgz#445d6da0960005e242d4f69693702a33daba05ae" + resolved "https://registry.npmjs.org/mui-datatables/-/mui-datatables-4.3.0.tgz" integrity sha512-LFliQwNnnxW03IO+V3q/ORxZsOHkzl53iGogLbjUJzme47hNEN106dM0ie8oMSc0heYJY0J07oZmKm7Xn3X7IQ== dependencies: "@babel/runtime-corejs3" "^7.12.1" @@ -2141,7 +2019,7 @@ perfect-debounce@^1.0.0: performance-now@^2.1.0: version "2.1.0" - resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-2.1.0.tgz#6309f4e0e5fa913ec1c69307ae364b4b377c9e7b" + resolved "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz" integrity sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow== picocolors@^1.0.0, picocolors@^1.1.0: @@ -2191,6 +2069,11 @@ prop-types@^15.5.9, prop-types@^15.6.1, prop-types@^15.6.2, prop-types@^15.7.2, object-assign "^4.1.1" react-is "^16.13.1" +proxy-from-env@^1.1.0: + version "1.1.0" + resolved "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz" + integrity sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg== + punycode@^2.1.0: version "2.3.1" resolved "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz" @@ -2203,7 +2086,7 @@ queue-microtask@^1.2.2: raf@^3.2.0: version "3.4.1" - resolved "https://registry.yarnpkg.com/raf/-/raf-3.4.1.tgz#0742e99a4a6552f445d73e3ee0328af0ff1ede39" + resolved "https://registry.npmjs.org/raf/-/raf-3.4.1.tgz" integrity sha512-Sq4CW4QhwOHE8ucn6J34MqtZCeWFP2aQSmrlroYgqAV1PjStIhJXxYuTgUIfkEk7zTLjmIjLmU5q+fbD1NnOJA== dependencies: performance-now "^2.1.0" @@ -2218,19 +2101,19 @@ rc9@^2.1.2: react-display-name@^0.2.0: version "0.2.5" - resolved "https://registry.yarnpkg.com/react-display-name/-/react-display-name-0.2.5.tgz#304c7cbfb59ee40389d436e1a822c17fe27936c6" + resolved "https://registry.npmjs.org/react-display-name/-/react-display-name-0.2.5.tgz" integrity sha512-I+vcaK9t4+kypiSgaiVWAipqHRXYmZIuAiS8vzFvXHHXVigg/sMKwlRgLy6LH2i3rmP+0Vzfl5lFsFRwF1r3pg== react-dnd-html5-backend@^11.1.3: version "11.1.3" - resolved "https://registry.yarnpkg.com/react-dnd-html5-backend/-/react-dnd-html5-backend-11.1.3.tgz#2749f04f416ec230ea193f5c1fbea2de7dffb8f7" + resolved "https://registry.npmjs.org/react-dnd-html5-backend/-/react-dnd-html5-backend-11.1.3.tgz" integrity sha512-/1FjNlJbW/ivkUxlxQd7o3trA5DE33QiRZgxent3zKme8DwF4Nbw3OFVhTRFGaYhHFNL1rZt6Rdj1D78BjnNLw== dependencies: dnd-core "^11.1.3" react-dnd-scrollzone-patch-react-17@^1.0.2: version "1.0.2" - resolved "https://registry.yarnpkg.com/react-dnd-scrollzone-patch-react-17/-/react-dnd-scrollzone-patch-react-17-1.0.2.tgz#aa7e4c54268fe109246e790f1412427481b63067" + resolved "https://registry.npmjs.org/react-dnd-scrollzone-patch-react-17/-/react-dnd-scrollzone-patch-react-17-1.0.2.tgz" integrity sha512-Wfhyc/Y/Veim29REBYm8nMmtDB5IwSmPPhXIuabBgsEa1MrVsuOwK9+7LmuP+mGbDOEP/S6G8+5XvDqPlRFK2g== dependencies: hoist-non-react-statics "^3.1.0" @@ -2241,7 +2124,7 @@ react-dnd-scrollzone-patch-react-17@^1.0.2: react-dnd@^11.1.3: version "11.1.3" - resolved "https://registry.yarnpkg.com/react-dnd/-/react-dnd-11.1.3.tgz#f9844f5699ccc55dfc81462c2c19f726e670c1af" + resolved "https://registry.npmjs.org/react-dnd/-/react-dnd-11.1.3.tgz" integrity sha512-8rtzzT8iwHgdSC89VktwhqdKKtfXaAyC4wiqp0SywpHG12TTLvfOoL6xNEIUWXwIEWu+CFfDn4GZJyynCEuHIQ== dependencies: "@react-dnd/shallowequal" "^2.0.0" @@ -2251,7 +2134,7 @@ react-dnd@^11.1.3: react-dom@^17.0.0: version "17.0.2" - resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-17.0.2.tgz#ecffb6845e3ad8dbfcdc498f0d0a939736502c23" + resolved "https://registry.npmjs.org/react-dom/-/react-dom-17.0.2.tgz" integrity sha512-s4h96KtLDUQlsENhMn1ar8t2bEa+q/YAtj8pPPdIjPDGBDIVNsrD9aXNWqspUe6AzKCIG0C1HZZLqLV7qpOBGA== dependencies: loose-envify "^1.1.0" @@ -2278,7 +2161,7 @@ react-is@^18.3.1: react-lifecycles-compat@^3.0.4: version "3.0.4" - resolved "https://registry.yarnpkg.com/react-lifecycles-compat/-/react-lifecycles-compat-3.0.4.tgz#4f1a273afdfc8f3488a8c516bfda78f872352362" + resolved "https://registry.npmjs.org/react-lifecycles-compat/-/react-lifecycles-compat-3.0.4.tgz" integrity sha512-fBASbA6LnOU9dOU2eW7aQ8xmYBSXUIWr+UmF9b1efZBazGNO+rcXT/icdKnYm2pTwcRylVUYwW7H1PHfLekVzA== react-refresh@^0.14.2: @@ -2303,7 +2186,7 @@ react-router@6.27.0: react-sortable-tree-patch-react-17@^2.9.0: version "2.9.0" - resolved "https://registry.yarnpkg.com/react-sortable-tree-patch-react-17/-/react-sortable-tree-patch-react-17-2.9.0.tgz#d80ef61a5b941a8cc52570f6aa2c3059076d9f21" + resolved "https://registry.npmjs.org/react-sortable-tree-patch-react-17/-/react-sortable-tree-patch-react-17-2.9.0.tgz" integrity sha512-Ngtdbf78OfjqCxLj7+N+K4zM9d1mQ/tfnUsOfICFDzNa5JHg6AjixAj69ijvz0ykEiA9lYop+0Fm4KCOqCdlKA== dependencies: lodash.isequal "^4.5.0" @@ -2318,7 +2201,7 @@ react-sortable-tree-patch-react-17@^2.9.0: react-to-print@^2.8.0: version "2.15.1" - resolved "https://registry.yarnpkg.com/react-to-print/-/react-to-print-2.15.1.tgz#c9a6732cadf1118fc90d886b54a9388c419561b9" + resolved "https://registry.npmjs.org/react-to-print/-/react-to-print-2.15.1.tgz" integrity sha512-1foogIFbCpzAVxydkhBiDfMiFYhIMphiagDOfcG4X/EcQ+fBPqJ0rby9Wv/emzY1YLkIQy/rEgOrWQT+rBKhjw== react-transition-group@^4.4.5: @@ -2333,7 +2216,7 @@ react-transition-group@^4.4.5: react-virtualized@^9.21.2: version "9.22.5" - resolved "https://registry.yarnpkg.com/react-virtualized/-/react-virtualized-9.22.5.tgz#bfb96fed519de378b50d8c0064b92994b3b91620" + resolved "https://registry.npmjs.org/react-virtualized/-/react-virtualized-9.22.5.tgz" integrity sha512-YqQMRzlVANBv1L/7r63OHa2b0ZsAaDp1UhVNEdUaXI8A5u6hTpA5NYtUueLH2rFuY/27mTGIBl7ZhqFKzw18YQ== dependencies: "@babel/runtime" "^7.7.2" @@ -2345,7 +2228,7 @@ react-virtualized@^9.21.2: react@^17.0.0: version "17.0.2" - resolved "https://registry.yarnpkg.com/react/-/react-17.0.2.tgz#d0b5cc516d29eb3eee383f75b62864cfb6800037" + resolved "https://registry.npmjs.org/react/-/react-17.0.2.tgz" integrity sha512-gnhPt75i/dq/z3/6q/0asP78D0u592D5L1pd7M8P+dck6Fu/jJeL6iVVK23fptSUZj8Vjf++7wXA8UNclGQcbA== dependencies: loose-envify "^1.1.0" @@ -2365,7 +2248,7 @@ readdirp@^4.0.1: redux@^4.0.4: version "4.2.1" - resolved "https://registry.yarnpkg.com/redux/-/redux-4.2.1.tgz#c08f4306826c49b5e9dc901dee0452ea8fce6197" + resolved "https://registry.npmjs.org/redux/-/redux-4.2.1.tgz" integrity sha512-LAUYz4lc+Do8/g7aeRa8JkyDErK6ekstQaqWQrNRW//MY1TvCEpMtpTWvlQ+FPbWCx+Xixu/6SHt5N0HR+SB4w== dependencies: "@babel/runtime" "^7.9.2" @@ -2430,7 +2313,7 @@ run-parallel@^1.1.9: scheduler@^0.20.2: version "0.20.2" - resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.20.2.tgz#4baee39436e34aa93b4874bddcbf0fe8b8b50e91" + resolved "https://registry.npmjs.org/scheduler/-/scheduler-0.20.2.tgz" integrity sha512-2eWfGgAqqWFGqtdMmcL5zCMK1U8KlXv8SQFGglL3CEtd0aDVDWgeF/YoCmvln55m5zSk3J/20hTaSBeSObsQDQ== dependencies: loose-envify "^1.1.0" @@ -2553,7 +2436,7 @@ ts-api-utils@^1.3.0: tss-react@^3.6.0: version "3.7.1" - resolved "https://registry.yarnpkg.com/tss-react/-/tss-react-3.7.1.tgz#119647731490f9e7e62c7f6a38a78df981929a4b" + resolved "https://registry.npmjs.org/tss-react/-/tss-react-3.7.1.tgz" integrity sha512-dfWUoxBlKZfIG9UC1A2h02OmcE/Ni0itCmmZu94E9g+KyBhKMHKcsKvUm0bNlRqTmYjXiCgPJDmj5fyc8CSrLg== dependencies: "@emotion/cache" "*"