Skip to content

Commit

Permalink
fix(TestManagementConfigMenu-page): reusable component + PanelRenameP…
Browse files Browse the repository at this point in the history
…age done
  • Loading branch information
adityadeshlahre committed Aug 14, 2024
1 parent 544496e commit 22f2855
Show file tree
Hide file tree
Showing 3 changed files with 530 additions and 50 deletions.
Original file line number Diff line number Diff line change
@@ -1,35 +1,7 @@
import React, { useContext, useState, useEffect, useRef } from "react";
import {
Form,
Heading,
Button,
Loading,
Grid,
Column,
Section,
DataTable,
Table,
TableHead,
TableRow,
TableBody,
TableHeader,
TableCell,
TableSelectRow,
TableSelectAll,
TableContainer,
Pagination,
Search,
Select,
SelectItem,
Stack,
UnorderedList,
ListItem,
} from "@carbon/react";
import { Heading, Button, Grid, Column, Section } from "@carbon/react";
import {
getFromOpenElisServer,
postToOpenElisServer,
postToOpenElisServerFormData,
postToOpenElisServerFullResponse,
postToOpenElisServerJsonResponse,
} from "../../utils/Utils.js";
import { NotificationContext } from "../../layout/Layout.js";
Expand All @@ -39,8 +11,7 @@ import {
} from "../../common/CustomNotification.js";
import { FormattedMessage, injectIntl, useIntl } from "react-intl";
import PageBreadCrumb from "../../common/PageBreadCrumb.js";
import CustomCheckBox from "../../common/CustomCheckBox.js";
import ActionPaginationButtonType from "../../common/ActionPaginationButtonType.js";
import RenameModelBox from "./renameModel/RenameModelBox.js";

let breadcrumbs = [
{ label: "home.label", link: "/" },
Expand All @@ -60,33 +31,197 @@ function PanelRenameEntry() {
useContext(NotificationContext);

const intl = useIntl();
const modalHeading = intl.formatMessage({ id: "field.panel" });

const componentMounted = useRef(false);
const [isLoading, setIsLoading] = useState(false);
const [finished, setFinished] = useState(true);
const [isAddModalOpen, setIsAddModalOpen] = useState(false);
const [confirmationStep, setConfirmationStep] = useState(false);
const [inputError, setInputError] = useState(false);
const [panel, setPanel] = useState({});
const [panelListShow, setPanelListShow] = useState([]);
const [panelPost, setPanelPost] = useState({});
const [entityNamesProvider, setEntityNamesProvider] = useState({});
const [entityNamesProviderPost, setEntityNamesProviderPost] = useState({});
const [entityId, setEntityId] = useState();
const [entityName, setEntityName] = useState("panel");
const [selectedItem, setSelectedItem] = useState({});

useEffect(() => {
componentMounted.current = true;
getFromOpenElisServer("/rest/PanelRenameEntry", handelPanelRename);
return () => {
componentMounted.current = false;
};
}, []);

const handelPanelRename = (res) => {
if (!res) {
setIsLoading(true);
} else {
setPanel(res);
setPanelPost(res);
setPanelListShow(res.panelList);
}
};

useEffect(() => {
getFromOpenElisServer(
`/rest/EntityNamesProvider?entityId=${entityId}&entityName=${entityName}`,
handelEntityNamesProvider,
);
}, [entityId]);

const handelEntityNamesProvider = (res) => {
if (!res) {
setIsLoading(true);
} else {
setEntityNamesProvider(res);
setEntityNamesProviderPost(res);
}
};

function panelUpdatePost() {
setIsLoading(true);
if (confirmationStep) {
postToOpenElisServerJsonResponse(
`/rest/PanelRenameEntry`,
JSON.stringify(panelPost),
(res) => {
panelUpdatePostCallback(res);
},
);
} else {
setConfirmationStep(true);
}
}

function panelUpdatePostCallback(res) {
if (res) {
setIsLoading(false);
setFinished(false);
addNotification({
title: intl.formatMessage({
id: "notification.title",
}),
message: intl.formatMessage({
id: "notification.user.post.save.success",
}),
kind: NotificationKinds.success,
});
setNotificationVisible(true);
setIsAddModalOpen(false);
} else {
addNotification({
kind: NotificationKinds.error,
title: intl.formatMessage({ id: "notification.title" }),
message: intl.formatMessage({ id: "server.error.msg" }),
});
setNotificationVisible(true);
setTimeout(() => {
window.location.reload();
}, 200);
}
}

const openAppModle = (item) => {
setConfirmationStep(false);
setIsAddModalOpen(true);
setEntityId(item.id);
// setEntityName(test.value);
setSelectedItem(item);
};

const onInputChangeEn = (e) => {
const englishName = e.target.value;
setEntityNamesProviderPost((prev) => ({
name: {
...prev.name,
english: englishName,
},
}));
setInputError(false);
};

const onInputChangeFr = (e) => {
const frenchName = e.target.value;
setEntityNamesProviderPost((prev) => ({
name: {
...prev.name,
french: frenchName,
},
}));
setInputError(false);
};

useEffect(() => {
if (entityId && entityNamesProviderPost && entityNamesProviderPost.name) {
setPanelPost((prev) => ({
...prev,
panelId: entityId,
nameEnglish: entityNamesProviderPost.name.english,
nameFrench: entityNamesProviderPost.name.french,
}));
}
}, [entityNamesProviderPost, entityId]);

const closeAddModal = () => {
setIsAddModalOpen(false);
};

return (
<>
{notificationVisible === true ? <AlertDialog /> : ""}
<div className="adminPageContent">
<PageBreadCrumb breadcrumbs={breadcrumbs} />
<Grid fullWidth={true}>
<Column lg={16} md={8} sm={4}>
<Section>
<Heading>
<FormattedMessage id="panel.panelName" />
</Heading>
</Section>
</Column>
</Grid>
<br />
<hr />
<br />
<Grid fullWidth={true}>
<Column lg={16} md={8} sm={4}>
<Button type="tertiary">
<FormattedMessage id="label.button.finished" />
</Button>
</Column>
</Grid>
<div className="orderLegendBody">
<Grid fullWidth={true}>
<Column lg={16} md={8} sm={4}>
<Section>
<Heading>
<FormattedMessage id="panel.panelName" />
</Heading>
</Section>
</Column>
</Grid>
<br />
<hr />
<br />
<Grid fullWidth={true}>
<Column lg={16} md={8} sm={4}>
<Button
disabled={finished}
id="finishdButton"
type="button"
onClick={() => {
window.location.reload();
}}
>
<FormattedMessage id="label.button.finished" />
</Button>
</Column>
</Grid>
<br />
<RenameModelBox
data={panelListShow}
isModalOpen={isAddModalOpen}
openModel={openAppModle}
closeModel={closeAddModal}
onSubmit={panelUpdatePost}
onInputChangeEn={onInputChangeEn}
onInputChangeFr={onInputChangeFr}
isLoading={isLoading}
modalHeading={modalHeading}
heading="banner.menu.patientEdit"
mainLabel="panel.panelName"
confirmationStep={confirmationStep}
inputError={inputError}
lang={entityNamesProvider}
langPost={entityNamesProviderPost}
selectedItem={selectedItem}
/>
</div>
</div>
</>
);
Expand Down
Loading

0 comments on commit 22f2855

Please sign in to comment.