🏗️ Refactored AirDCPP context using react-query

This commit is contained in:
2023-11-05 01:26:56 -04:00
parent 1f8dded15e
commit a0f7280fbb
6 changed files with 66 additions and 61 deletions

View File

@@ -12,10 +12,7 @@ import Downloads from "./Downloads/Downloads";
import { Routes, Route } from "react-router-dom";
import Navbar from "./shared/Navbar";
import "../assets/scss/App.scss";
import {
AirDCPPSocketContextProvider,
AirDCPPSocketContext,
} from "../context/AirDCPPSocket";
import { SocketIOProvider } from "../context/SocketIOContext";
import socketIOConnectionInstance from "../shared/socket.io/instance";
import { isEmpty, isNil, isUndefined } from "lodash";

View File

@@ -1,5 +1,4 @@
import React, { ReactElement, useCallback, useContext } from "react";
import { useDispatch } from "react-redux";
import {
saveSettings,
deleteSettings,
@@ -10,31 +9,31 @@ import { isUndefined, isEmpty } from "lodash";
import { ConnectionForm } from "../../shared/ConnectionForm/ConnectionForm";
export const AirDCPPSettingsForm = (): ReactElement => {
const dispatch = useDispatch();
const airDCPPSettings = useContext(AirDCPPSocketContext);
console.log(airDCPPSettings);
const onSubmit = useCallback(async (values) => {
try {
airDCPPSettings.setSettings(values);
dispatch(saveSettings(values, "directConnect"));
} catch (error) {
console.log(error);
}
}, []);
const removeSettings = useCallback(async () => {
airDCPPSettings.setSettings({});
dispatch(deleteSettings());
}, []);
const initFormData = !isUndefined(
airDCPPSettings.airDCPPState.settings.directConnect,
)
? airDCPPSettings.airDCPPState.settings.directConnect.client.host
: {};
// const onSubmit = useCallback(async (values) => {
// try {
// airDCPPSettings.setSettings(values);
// // dispatch(saveSettings(values, "directConnect"));
// } catch (error) {
// console.log(error);
// }
// }, []);
// const removeSettings = useCallback(async () => {
// airDCPPSettings.setSettings({});
// // dispatch(deleteSettings());
// }, []);
//
// const initFormData = !isUndefined(
// airDCPPSettings.airDCPPState.settings.directConnect,
// )
// ? airDCPPSettings.airDCPPState.settings.directConnect.client.host
// : {};
return (
<>
<ConnectionForm
{/* <ConnectionForm
initialData={initFormData}
submitHandler={onSubmit}
formHeading={"Configure AirDC++"}
@@ -52,7 +51,7 @@ export const AirDCPPSettingsForm = (): ReactElement => {
Delete
</button>
</p>
) : null}
) : null} */}
</>
);
};

View File

@@ -4,7 +4,6 @@ import { useQuery, useMutation } from "@tanstack/react-query";
import axios from "axios";
export const QbittorrentConnectionForm = (): ReactElement => {
// axios interceptors to destructure response
// fetch settings
const { data, isLoading, isError } = useQuery({
queryKey: ["settings"],

View File

@@ -18,7 +18,11 @@ export const Settings = (props: ISettingsProps): ReactElement => {
},
{
id: "adc-connection",
content: <div key="adc-connection">{/* <AirDCPPSettingsForm /> */}</div>,
content: (
<div key="adc-connection">
<AirDCPPSettingsForm />
</div>
),
},
{
id: "qbt-connection",