- updated base for endpoints

- added loading states
- need to add new form for ftp type
This commit is contained in:
2025-11-27 09:43:09 +00:00
parent 97ff9a981d
commit 3c10ff82cb
8 changed files with 217 additions and 196 deletions

View File

@@ -13,6 +13,8 @@ type SystemHealthProps = {
const SystemHealth = ({ startTime, uptime, statuses, isLoading, isError, dateUpdatedAt }: SystemHealthProps) => { const SystemHealth = ({ startTime, uptime, statuses, isLoading, isError, dateUpdatedAt }: SystemHealthProps) => {
const updatedDate = dateUpdatedAt ? new Date(dateUpdatedAt).toLocaleString() : null; const updatedDate = dateUpdatedAt ? new Date(dateUpdatedAt).toLocaleString() : null;
// console.log(statuses);
if (isError) { if (isError) {
return <span className="text-red-500">Error loading system health.</span>; return <span className="text-red-500">Error loading system health.</span>;
} }
@@ -31,7 +33,7 @@ const SystemHealth = ({ startTime, uptime, statuses, isLoading, isError, dateUpd
</div> </div>
<div className="h-50 overflow-auto"> <div className="h-50 overflow-auto">
{statuses?.map((status: SystemHealthStatus) => ( {statuses?.map((status: SystemHealthStatus) => (
<div className="border border-gray-700 p-4 rounded-md m-2 flex justify-between"> <div className="border border-gray-700 p-4 rounded-md m-2 flex justify-between" key={status.id}>
<span>{status.id}</span> <Badge text={status.tags[0]} /> <span>{status.id}</span> <Badge text={status.tags[0]} />
</div> </div>
))} ))}

View File

@@ -1,7 +1,8 @@
import { useQuery } from "@tanstack/react-query"; import { useQuery } from "@tanstack/react-query";
import { CAMBASE } from "../../../utils/config";
const fetchData = async () => { const fetchData = async () => {
const response = await fetch(`http://100.115.148.59/api/system-health`); const response = await fetch(`${CAMBASE}/api/system-health`);
if (!response.ok) throw new Error("Cannot get System overview"); if (!response.ok) throw new Error("Cannot get System overview");
return response.json(); return response.json();
}; };

View File

@@ -46,8 +46,11 @@ const ChannelFields = ({ errors, touched, values, outputData, onSetFieldValue }:
onSetFieldValue(key, value); onSetFieldValue(key, value);
} }
}, [channelFieldsObject, onSetFieldValue, outputData]); }, [channelFieldsObject, onSetFieldValue, outputData]);
return ( return (
<div className="flex flex-col gap-4 p-4"> <div className="flex flex-col gap-4 p-4">
{values.format.toLowerCase() !== "ftp" ? (
<>
<div className="flex flex-row justify-between"> <div className="flex flex-row justify-between">
<label htmlFor="backoffice" className="block mb-2 font-medium"> <label htmlFor="backoffice" className="block mb-2 font-medium">
Back Office URL Back Office URL
@@ -258,6 +261,10 @@ const ChannelFields = ({ errors, touched, values, outputData, onSetFieldValue }:
</div> </div>
</> </>
)} )}
</>
) : (
<></>
)}
</div> </div>
); );
}; };

View File

@@ -10,6 +10,7 @@ const OutputForms = () => {
const { bearerMutation } = usePostBearerConfig(); const { bearerMutation } = usePostBearerConfig();
const { dispatcherQuery, dispatcherMutation } = useDispatcherConfig(); const { dispatcherQuery, dispatcherMutation } = useDispatcherConfig();
const isLoading = dispatcherQuery?.isLoading;
const format = dispatcherQuery?.data?.propFormat?.value; const format = dispatcherQuery?.data?.propFormat?.value;
const { optionalConstantsQuery, optionalConstantsMutation } = useOptionalConstants(format?.toLowerCase()); const { optionalConstantsQuery, optionalConstantsMutation } = useOptionalConstants(format?.toLowerCase());
const FFID = optionalConstantsQuery?.data?.propFeedIdentifier?.value; const FFID = optionalConstantsQuery?.data?.propFeedIdentifier?.value;
@@ -38,6 +39,8 @@ const OutputForms = () => {
laneId: "", laneId: "",
LID1: "", LID1: "",
LID2: "", LID2: "",
// ftp - fields
}; };
const handleSubmit = async (values: FormTypes) => { const handleSubmit = async (values: FormTypes) => {
@@ -85,6 +88,10 @@ const OutputForms = () => {
} }
}; };
if (isLoading) {
return <div>Loading...</div>;
}
return ( return (
<Formik initialValues={inititalValues} onSubmit={handleSubmit} enableReinitialize> <Formik initialValues={inititalValues} onSubmit={handleSubmit} enableReinitialize>
<Form className="grid grid-cols-1 md:grid-cols-2"> <Form className="grid grid-cols-1 md:grid-cols-2">

View File

@@ -1,8 +1,9 @@
import { useMutation, useQuery } from "@tanstack/react-query"; import { useMutation, useQuery } from "@tanstack/react-query";
import type { BearerTypeFields } from "../../../types/types"; import type { BearerTypeFields } from "../../../types/types";
import { CAMBASE } from "../../../utils/config";
const fetchBearerConfig = async (bearerConfig: string) => { const fetchBearerConfig = async (bearerConfig: string) => {
const response = await fetch(`http://100.115.148.59/api/fetch-config?id=Dispatcher0-${bearerConfig}`, { const response = await fetch(`${CAMBASE}/api/fetch-config?id=Dispatcher0-${bearerConfig}`, {
method: "GET", method: "GET",
}); });
if (!response.ok) { if (!response.ok) {
@@ -37,7 +38,7 @@ const postBearerConfig = async (config: BearerTypeFields) => {
}, },
], ],
}; };
const response = await fetch("http://192.168.202.121/api/update-config", { const response = await fetch(`${CAMBASE}/api/update-config`, {
method: "POST", method: "POST",
body: JSON.stringify(channelConfigPayload), body: JSON.stringify(channelConfigPayload),
}); });

View File

@@ -1,8 +1,9 @@
import { useQuery, useMutation } from "@tanstack/react-query"; import { useQuery, useMutation } from "@tanstack/react-query";
import type { DispatcherConfig } from "../../../types/types"; import type { DispatcherConfig } from "../../../types/types";
import { CAMBASE } from "../../../utils/config";
const getDispatcherConfig = async () => { const getDispatcherConfig = async () => {
const response = await fetch(`http://192.168.202.121/api/fetch-config?id=Dispatcher0`); const response = await fetch(`${CAMBASE}/api/fetch-config?id=Dispatcher0`);
if (!response.ok) { if (!response.ok) {
throw new Error("Network response was not ok"); throw new Error("Network response was not ok");
} }
@@ -23,7 +24,7 @@ const postDispatcherConfig = async (config: DispatcherConfig) => {
}, },
], ],
}; };
const response = await fetch(`http://192.168.202.121/api/update-config`, { const response = await fetch(`${CAMBASE}/api/update-config`, {
method: "POST", method: "POST",
body: JSON.stringify(updateConfigPayload), body: JSON.stringify(updateConfigPayload),
}); });

View File

@@ -1,9 +1,10 @@
import { useQuery, useMutation } from "@tanstack/react-query"; import { useQuery, useMutation } from "@tanstack/react-query";
import type { OptionalBOF2Constants } from "../../../types/types"; import type { OptionalBOF2Constants } from "../../../types/types";
import { CAMBASE } from "../../../utils/config";
const fetchOptionalConstants = async (format: string) => { const fetchOptionalConstants = async (format: string) => {
if (!format || format === "json") return null; if (!format || format === "json") return null;
const response = await fetch(`http://100.115.148.59/api/fetch-config?id=Dispatcher0-${format}-constants`); const response = await fetch(`${CAMBASE}/api/fetch-config?id=Dispatcher0-${format}-constants`);
if (!response.ok) { if (!response.ok) {
throw new Error("Network response was not ok"); throw new Error("Network response was not ok");
} }
@@ -37,7 +38,7 @@ const postOptionalConstants = async (config: OptionalBOF2Constants) => {
fields: fields, fields: fields,
}; };
const response = await fetch(`http://100.115.148.59/api/update-config`, { const response = await fetch(`${CAMBASE}/api/update-config`, {
method: "POST", method: "POST",
body: JSON.stringify(updateConfigPayload), body: JSON.stringify(updateConfigPayload),
}); });

1
src/utils/config.ts Normal file
View File

@@ -0,0 +1 @@
export const CAMBASE = import.meta.env.VITE_BASEURL;