🏗️ Refactored AirDCPP context using react-query
This commit is contained in:
@@ -12,10 +12,7 @@ import Downloads from "./Downloads/Downloads";
|
|||||||
import { Routes, Route } from "react-router-dom";
|
import { Routes, Route } from "react-router-dom";
|
||||||
import Navbar from "./shared/Navbar";
|
import Navbar from "./shared/Navbar";
|
||||||
import "../assets/scss/App.scss";
|
import "../assets/scss/App.scss";
|
||||||
import {
|
|
||||||
AirDCPPSocketContextProvider,
|
|
||||||
AirDCPPSocketContext,
|
|
||||||
} from "../context/AirDCPPSocket";
|
|
||||||
import { SocketIOProvider } from "../context/SocketIOContext";
|
import { SocketIOProvider } from "../context/SocketIOContext";
|
||||||
import socketIOConnectionInstance from "../shared/socket.io/instance";
|
import socketIOConnectionInstance from "../shared/socket.io/instance";
|
||||||
import { isEmpty, isNil, isUndefined } from "lodash";
|
import { isEmpty, isNil, isUndefined } from "lodash";
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
import React, { ReactElement, useCallback, useContext } from "react";
|
import React, { ReactElement, useCallback, useContext } from "react";
|
||||||
import { useDispatch } from "react-redux";
|
|
||||||
import {
|
import {
|
||||||
saveSettings,
|
saveSettings,
|
||||||
deleteSettings,
|
deleteSettings,
|
||||||
@@ -10,31 +9,31 @@ import { isUndefined, isEmpty } from "lodash";
|
|||||||
import { ConnectionForm } from "../../shared/ConnectionForm/ConnectionForm";
|
import { ConnectionForm } from "../../shared/ConnectionForm/ConnectionForm";
|
||||||
|
|
||||||
export const AirDCPPSettingsForm = (): ReactElement => {
|
export const AirDCPPSettingsForm = (): ReactElement => {
|
||||||
const dispatch = useDispatch();
|
|
||||||
const airDCPPSettings = useContext(AirDCPPSocketContext);
|
const airDCPPSettings = useContext(AirDCPPSocketContext);
|
||||||
|
console.log(airDCPPSettings);
|
||||||
|
|
||||||
const onSubmit = useCallback(async (values) => {
|
// const onSubmit = useCallback(async (values) => {
|
||||||
try {
|
// try {
|
||||||
airDCPPSettings.setSettings(values);
|
// airDCPPSettings.setSettings(values);
|
||||||
dispatch(saveSettings(values, "directConnect"));
|
// // dispatch(saveSettings(values, "directConnect"));
|
||||||
} catch (error) {
|
// } catch (error) {
|
||||||
console.log(error);
|
// console.log(error);
|
||||||
}
|
// }
|
||||||
}, []);
|
// }, []);
|
||||||
const removeSettings = useCallback(async () => {
|
// const removeSettings = useCallback(async () => {
|
||||||
airDCPPSettings.setSettings({});
|
// airDCPPSettings.setSettings({});
|
||||||
dispatch(deleteSettings());
|
// // dispatch(deleteSettings());
|
||||||
}, []);
|
// }, []);
|
||||||
|
//
|
||||||
const initFormData = !isUndefined(
|
// const initFormData = !isUndefined(
|
||||||
airDCPPSettings.airDCPPState.settings.directConnect,
|
// airDCPPSettings.airDCPPState.settings.directConnect,
|
||||||
)
|
// )
|
||||||
? airDCPPSettings.airDCPPState.settings.directConnect.client.host
|
// ? airDCPPSettings.airDCPPState.settings.directConnect.client.host
|
||||||
: {};
|
// : {};
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ConnectionForm
|
{/* <ConnectionForm
|
||||||
initialData={initFormData}
|
initialData={initFormData}
|
||||||
submitHandler={onSubmit}
|
submitHandler={onSubmit}
|
||||||
formHeading={"Configure AirDC++"}
|
formHeading={"Configure AirDC++"}
|
||||||
@@ -52,7 +51,7 @@ export const AirDCPPSettingsForm = (): ReactElement => {
|
|||||||
Delete
|
Delete
|
||||||
</button>
|
</button>
|
||||||
</p>
|
</p>
|
||||||
) : null}
|
) : null} */}
|
||||||
</>
|
</>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -4,7 +4,6 @@ import { useQuery, useMutation } from "@tanstack/react-query";
|
|||||||
import axios from "axios";
|
import axios from "axios";
|
||||||
|
|
||||||
export const QbittorrentConnectionForm = (): ReactElement => {
|
export const QbittorrentConnectionForm = (): ReactElement => {
|
||||||
// axios interceptors to destructure response
|
|
||||||
// fetch settings
|
// fetch settings
|
||||||
const { data, isLoading, isError } = useQuery({
|
const { data, isLoading, isError } = useQuery({
|
||||||
queryKey: ["settings"],
|
queryKey: ["settings"],
|
||||||
|
|||||||
@@ -18,7 +18,11 @@ export const Settings = (props: ISettingsProps): ReactElement => {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: "adc-connection",
|
id: "adc-connection",
|
||||||
content: <div key="adc-connection">{/* <AirDCPPSettingsForm /> */}</div>,
|
content: (
|
||||||
|
<div key="adc-connection">
|
||||||
|
<AirDCPPSettingsForm />
|
||||||
|
</div>
|
||||||
|
),
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
id: "qbt-connection",
|
id: "qbt-connection",
|
||||||
|
|||||||
@@ -1,10 +1,11 @@
|
|||||||
import { isEmpty, isUndefined } from "lodash";
|
import { isEmpty, isUndefined } from "lodash";
|
||||||
import React, { createContext, useEffect, useState } from "react";
|
import React, { createContext, useEffect, useState } from "react";
|
||||||
import { useDispatch, useSelector } from "react-redux";
|
|
||||||
import { toggleAirDCPPSocketConnectionStatus } from "../actions/airdcpp.actions";
|
import { toggleAirDCPPSocketConnectionStatus } from "../actions/airdcpp.actions";
|
||||||
import { getSettings } from "../actions/settings.actions";
|
import { getSettings } from "../actions/settings.actions";
|
||||||
|
import { useQuery, useMutation } from "@tanstack/react-query";
|
||||||
|
|
||||||
import AirDCPPSocket from "../services/DcppSearchService";
|
import AirDCPPSocket from "../services/DcppSearchService";
|
||||||
|
import axios from "axios";
|
||||||
|
|
||||||
const AirDCPPSocketContextProvider = ({ children }) => {
|
const AirDCPPSocketContextProvider = ({ children }) => {
|
||||||
// setter for settings for use in the context consumer
|
// setter for settings for use in the context consumer
|
||||||
@@ -14,7 +15,7 @@ const AirDCPPSocketContextProvider = ({ children }) => {
|
|||||||
airDCPPState: {
|
airDCPPState: {
|
||||||
settings: settingsObject,
|
settings: settingsObject,
|
||||||
socket: {},
|
socket: {},
|
||||||
socketConectionInformation: {},
|
socketConnectionInformation: {},
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
@@ -27,59 +28,58 @@ const AirDCPPSocketContextProvider = ({ children }) => {
|
|||||||
},
|
},
|
||||||
setSettings: setSettings,
|
setSettings: setSettings,
|
||||||
};
|
};
|
||||||
const dispatch = useDispatch();
|
|
||||||
const [airDCPPState, persistSettings] = useState(initState);
|
const [airDCPPState, persistSettings] = useState(initState);
|
||||||
const airDCPPSettings = useSelector(
|
|
||||||
(state: RootState) => state.settings.data,
|
|
||||||
);
|
|
||||||
|
|
||||||
// 1. get settings from mongo
|
// 1. get settings from mongo
|
||||||
useEffect(() => {
|
const { data, isLoading, isError } = useQuery({
|
||||||
dispatch(getSettings());
|
queryKey: ["settings"],
|
||||||
}, []);
|
queryFn: async () =>
|
||||||
|
await axios({
|
||||||
|
url: "http://localhost:3000/api/settings/getAllSettings",
|
||||||
|
method: "GET",
|
||||||
|
}),
|
||||||
|
});
|
||||||
|
|
||||||
|
const directConnectConfiguration = data?.data.directConnect.client.host;
|
||||||
|
|
||||||
// 2. If available, init AirDC++ Socket with those settings
|
// 2. If available, init AirDC++ Socket with those settings
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!isEmpty(airDCPPSettings)) {
|
if (!isEmpty(directConnectConfiguration)) {
|
||||||
initializeAirDCPPSocket(airDCPPSettings);
|
initializeAirDCPPSocket(directConnectConfiguration);
|
||||||
}
|
}
|
||||||
}, [airDCPPSettings]);
|
}, [directConnectConfiguration]);
|
||||||
|
|
||||||
// Method to init AirDC++ Socket with supplied settings
|
// Method to init AirDC++ Socket with supplied settings
|
||||||
const initializeAirDCPPSocket = async (configuration) => {
|
const initializeAirDCPPSocket = async (configuration) => {
|
||||||
console.log("[AirDCPP]: Initializing socket...");
|
console.log("[AirDCPP]: Initializing socket...");
|
||||||
const {
|
|
||||||
directConnect: {
|
|
||||||
client: { host },
|
|
||||||
},
|
|
||||||
} = configuration;
|
|
||||||
|
|
||||||
const initializedAirDCPPSocket = new AirDCPPSocket({
|
const initializedAirDCPPSocket = new AirDCPPSocket({
|
||||||
protocol: `${host.protocol}`,
|
protocol: `${configuration.protocol}`,
|
||||||
hostname: `${host.hostname}:${host.port}`,
|
hostname: `${configuration.hostname}:${configuration.port}`,
|
||||||
username: `${host.username}`,
|
username: `${configuration.username}`,
|
||||||
password: `${host.password}`,
|
password: `${configuration.password}`,
|
||||||
});
|
});
|
||||||
|
|
||||||
// connect and disconnect handlers
|
// connect and disconnect handlers
|
||||||
initializedAirDCPPSocket.onConnected = (sessionInfo) => {
|
initializedAirDCPPSocket.onConnected = (sessionInfo) => {
|
||||||
dispatch(toggleAirDCPPSocketConnectionStatus("connected", sessionInfo));
|
// dispatch(toggleAirDCPPSocketConnectionStatus("connected", sessionInfo));
|
||||||
};
|
};
|
||||||
initializedAirDCPPSocket.onDisconnected = async (
|
initializedAirDCPPSocket.onDisconnected = async (
|
||||||
reason,
|
reason,
|
||||||
code,
|
code,
|
||||||
wasClean,
|
wasClean,
|
||||||
) => {
|
) => {
|
||||||
dispatch(
|
// dispatch(
|
||||||
toggleAirDCPPSocketConnectionStatus("disconnected", {
|
// toggleAirDCPPSocketConnectionStatus("disconnected", {
|
||||||
reason,
|
// reason,
|
||||||
code,
|
// code,
|
||||||
wasClean,
|
// wasClean,
|
||||||
}),
|
// }),
|
||||||
);
|
// );
|
||||||
};
|
};
|
||||||
|
|
||||||
const socketConnectionInformation = await initializedAirDCPPSocket.connect();
|
const socketConnectionInformation =
|
||||||
|
await initializedAirDCPPSocket.connect();
|
||||||
|
|
||||||
// update the state with the new socket connection information
|
// update the state with the new socket connection information
|
||||||
persistSettings({
|
persistSettings({
|
||||||
@@ -101,7 +101,7 @@ const AirDCPPSocketContextProvider = ({ children }) => {
|
|||||||
};
|
};
|
||||||
const AirDCPPSocketContext = createContext({
|
const AirDCPPSocketContext = createContext({
|
||||||
airDCPPState: {},
|
airDCPPState: {},
|
||||||
saveSettings: () => { },
|
saveSettings: () => {},
|
||||||
});
|
});
|
||||||
|
|
||||||
export { AirDCPPSocketContext, AirDCPPSocketContextProvider };
|
export { AirDCPPSocketContext, AirDCPPSocketContextProvider };
|
||||||
|
|||||||
@@ -8,6 +8,10 @@ const rootEl = document.getElementById("root");
|
|||||||
const root = createRoot(rootEl);
|
const root = createRoot(rootEl);
|
||||||
import { QueryClient, QueryClientProvider } from "@tanstack/react-query";
|
import { QueryClient, QueryClientProvider } from "@tanstack/react-query";
|
||||||
import { ReactQueryDevtools } from "@tanstack/react-query-devtools";
|
import { ReactQueryDevtools } from "@tanstack/react-query-devtools";
|
||||||
|
import {
|
||||||
|
AirDCPPSocketContextProvider,
|
||||||
|
AirDCPPSocketContext,
|
||||||
|
} from "./context/AirDCPPSocket";
|
||||||
|
|
||||||
const queryClient = new QueryClient();
|
const queryClient = new QueryClient();
|
||||||
|
|
||||||
@@ -25,8 +29,10 @@ const router = createBrowserRouter([
|
|||||||
root.render(
|
root.render(
|
||||||
<React.StrictMode>
|
<React.StrictMode>
|
||||||
<QueryClientProvider client={queryClient}>
|
<QueryClientProvider client={queryClient}>
|
||||||
<RouterProvider router={router} />
|
<AirDCPPSocketContextProvider>
|
||||||
<ReactQueryDevtools initialIsOpen={true} />
|
<RouterProvider router={router} />
|
||||||
|
<ReactQueryDevtools initialIsOpen={true} />
|
||||||
|
</AirDCPPSocketContextProvider>
|
||||||
</QueryClientProvider>
|
</QueryClientProvider>
|
||||||
</React.StrictMode>,
|
</React.StrictMode>,
|
||||||
);
|
);
|
||||||
|
|||||||
Reference in New Issue
Block a user