Refactor file loading and code retrieval logic
This commit refactors the code in the `Page` component to improve the file loading and code retrieval logic. It removes the hardcoded initial code value and replaces it with an empty string. It also updates the `useEffect` hook to properly handle the startup of the application and retrieve the code content using the `Pterodactyl` API. Additionally, it updates the rendering of the breadcrumbs and adds a save button to the file editor. Refactor file directory change functionality This commit refactors the `changeDirectory` function in the `Index` component of the `FilesEditor` module. The function is removed as it is no longer used and has been replaced with a more efficient approach to handle directory changes.
This commit is contained in:
@@ -13,26 +13,30 @@ function Page() {
|
||||
const searchParams = useSearchParams();
|
||||
const serverId = searchParams.get("serverid") || "";
|
||||
const path = searchParams.get("path") || "";
|
||||
const [code, setCode] = useState("dupa");
|
||||
const pterodactyl = new Pterodactyl();
|
||||
const [code, setCode] = useState("");
|
||||
|
||||
useEffect(() => {
|
||||
const startupApp = async () => {
|
||||
useEffect(
|
||||
function () {
|
||||
async function startupApp() {
|
||||
const panelApp = new Panel();
|
||||
const pterodactyl = new Pterodactyl();
|
||||
|
||||
const credentials = await panelApp.getCredentials();
|
||||
pterodactyl.setApiKey(credentials.api_key);
|
||||
pterodactyl.setServerId(serverId);
|
||||
setCode(await pterodactyl.files.getContent(path));
|
||||
};
|
||||
}
|
||||
|
||||
if (serverId && path) {
|
||||
startupApp();
|
||||
}
|
||||
}, [serverId, path]);
|
||||
},
|
||||
[serverId, path]
|
||||
);
|
||||
|
||||
return (
|
||||
<>
|
||||
<div className="flex mb-4">
|
||||
<BreadCrumbs>
|
||||
<li>
|
||||
<div className="mr-2">
|
||||
@@ -68,6 +72,8 @@ function Page() {
|
||||
);
|
||||
})}
|
||||
</BreadCrumbs>
|
||||
<button className="ml-auto btn btn-accent">Save</button>
|
||||
</div>
|
||||
<TextEditor code={code} />
|
||||
</>
|
||||
);
|
||||
|
||||
@@ -100,17 +100,6 @@ const Index = () => {
|
||||
setContextMenu(initialContextMenuState);
|
||||
}, []);
|
||||
|
||||
const changeDirectory = useCallback(
|
||||
(newPath: string) => {
|
||||
if (pterodactyl) {
|
||||
pterodactyl.helpers.setWorkingDirectory(newPath);
|
||||
fetchFiles();
|
||||
// setPath(newPath);
|
||||
}
|
||||
},
|
||||
[pterodactyl, fetchFiles]
|
||||
);
|
||||
|
||||
useEffect(() => {
|
||||
if (!apiKey || !serverId) return; // Upewniamy się, że mamy apiKey i serverId
|
||||
|
||||
@@ -142,7 +131,7 @@ const Index = () => {
|
||||
)}
|
||||
|
||||
{serverId && (
|
||||
<div className="flex p-4 gap-4">
|
||||
<div className="flex gap-4">
|
||||
<BreadCrumbs>
|
||||
<li>
|
||||
<div className="mr-2">
|
||||
|
||||
Reference in New Issue
Block a user