Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Vertical stepper implemenetation #1441

Merged
merged 22 commits into from
Oct 7, 2024
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
fe9341f
Inmpelemented modularised vertical stepper for upload screen
ashish-egov Sep 30, 2024
70aab30
Merge remote-tracking branch 'origin/console' into console
ashish-egov Sep 30, 2024
d9525f3
Update health/micro-ui/web/micro-ui-internals/packages/modules/microp…
ashish-egov Sep 30, 2024
d631f37
Update health/micro-ui/web/micro-ui-internals/packages/modules/microp…
ashish-egov Sep 30, 2024
c12d9eb
Enchancement in vetical Stepper
ashish-egov Oct 7, 2024
8e22724
Merge remote-tracking branch 'origin/console' into vertical-stepper-i…
ashish-egov Oct 7, 2024
6c05bf1
Vertical stepper enhancement
ashish-egov Oct 7, 2024
bcce31b
Merge branch 'vertical-stepper-implemenetation' of https://github.com…
ashish-egov Oct 7, 2024
b720036
Vertical Stepper Integration
ashish-egov Oct 7, 2024
ef7e850
Update SetupMicroplan.js
ashish-egov Oct 7, 2024
d1d493e
Update health/micro-ui/web/micro-ui-internals/packages/modules/microp…
ashish-egov Oct 7, 2024
a8787a5
Delete micro-ui/web/workbench/package-lock.json
ashish-egov Oct 7, 2024
e1c207f
Verycal Stepper Enhancement
ashish-egov Oct 7, 2024
b30cc19
Merge branch 'vertical-stepper-implemenetation' of https://github.com…
ashish-egov Oct 7, 2024
0ad275f
Update package.json
ashish-egov Oct 7, 2024
f580d17
Update package.json
ashish-egov Oct 7, 2024
12d71e6
Vertical stepper enhancement
ashish-egov Oct 7, 2024
a1c5dc2
Merge branch 'vertical-stepper-implemenetation' of https://github.com…
ashish-egov Oct 7, 2024
253e2cb
Merge branch 'console' into vertical-stepper-implemenetation
nipunarora-eGov Oct 7, 2024
f372b96
Revert
ashish-egov Oct 7, 2024
22e3bc4
Merge branch 'vertical-stepper-implemenetation' of https://github.com…
ashish-egov Oct 7, 2024
941ea96
Vertical stepper
ashish-egov Oct 7, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ import UpdateDatesWithBoundaries from "./pages/employee/UpdateDatesWithBoundarie
import DateWithBoundary from "./components/DateWithBoundary";
import BoundaryWithDate from "./components/BoundaryWithDate";
import DateAndCycleUpdate from "./pages/employee/DateAndCycleUpdate";
import { CreateChecklist} from "./pages/employee/CreateChecklist";
import { CreateChecklist } from "./pages/employee/CreateChecklist";
import CreateQuestionContext from "./components/CreateQuestionContext";
import SearchChecklist from "./pages/employee/SearchChecklist";
import DeliveryDetailsSummary from "./components/DeliveryDetailsSummary";
Expand All @@ -45,6 +45,7 @@ import UpdateBoundaryWrapper from "./components/UpdateBoundaryWrapper";
// import SelectingBoundaryComponent from "./components/SelectingBoundaryComponent";
import { Wrapper } from "./components/SelectingBoundaryComponent";
import SelectingBoundariesDuplicate from "./components/SelectingBoundariesDuplicate";
import XlsPreview from "./components/XlsPreview";

/**
* The CampaignModule function fetches store data based on state code, module code, and language, and
Expand All @@ -60,7 +61,7 @@ const CampaignModule = ({ stateCode, userType, tenants }) => {
},
});

const hierarchyData = Digit.Hooks.campaign.useBoundaryRelationshipSearch({BOUNDARY_HIERARCHY_TYPE,tenantId});
const hierarchyData = Digit.Hooks.campaign.useBoundaryRelationshipSearch({ BOUNDARY_HIERARCHY_TYPE, tenantId });

const moduleCode = ["hr", "campaignmanager", "workbench", "mdms", "schema", "hcm-admin-schemas", `boundary-${BOUNDARY_HIERARCHY_TYPE}`];
const { path, url } = useRouteMatch();
Expand Down Expand Up @@ -115,7 +116,7 @@ const componentsToRegister = {
DateAndCycleUpdate,
TimelineComponent,
CreateChecklist,
CreateQuestion : CreateQuestionContext,
CreateQuestion: CreateQuestionContext,
SearchChecklist,
DeliveryDetailsSummary,
DataUploadSummary,
Expand All @@ -125,6 +126,7 @@ const componentsToRegister = {
UpdateBoundary,
UpdateBoundaryWrapper,
SelectingBoundariesDuplicate,
XlsPreview
// SelectingBoundaryComponent
};

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ import { UploadIcon, FileIcon, DeleteIconv2, Button, DownloadIcon, PopUp, SVG }
import { FileUploader } from "react-drag-drop-files";
import { useTranslation } from "react-i18next";
import XLSX from "xlsx";
import XlsPreview from "./XlsPreview";
import { PRIMARY_COLOR } from "../utils";
import { Toast } from "@egovernments/digit-ui-components";

Expand All @@ -25,6 +24,7 @@ const BulkUpload = ({ multiple = true, onSubmit, fileData, onFileDelete, onFileD
const [fileUrl, setFileUrl] = useState(fileData?.[0]);
const [fileName, setFileName] = useState(null);
const [showToast, setShowToast] = useState(false);
const XlsPreview = Digit?.ComponentRegistryService?.getComponent("XlsPreview");

useEffect(() => {
const fetch = async () => {
Expand Down Expand Up @@ -136,9 +136,9 @@ const BulkUpload = ({ multiple = true, onSubmit, fileData, onFileDelete, onFileD
<div
className="uploaded-file-container-sub"
style={{ cursor: "pointer" }}
// onClick={() => {
// setShowPreview(true);
// }}
// onClick={() => {
// setShowPreview(true);
// }}
ashish-egov marked this conversation as resolved.
Show resolved Hide resolved
>
<FileIcon className="icon" />
<div style={{ marginLeft: "0.5rem", color: "#505A5F", fontWeight: "700" }}>{file.filename}</div>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -68,8 +68,8 @@ const UploadData = ({ formData, onSelect, ...props }) => {
const totalData = Digit.SessionStorage.get("HCM_CAMPAIGN_MANAGER_FORM_DATA");
const [convertedSchema, setConvertedSchema] = useState({});
const [loader, setLoader] = useState(false);
const [currentStep , setCurrentStep] = useState(1);
const baseKey = 9;
const [currentStep, setCurrentStep] = useState(1);
const baseKey = 9;
ashish-egov marked this conversation as resolved.
Show resolved Hide resolved

function updateUrlParams(params) {
const url = new URL(window.location.href);
Expand All @@ -79,7 +79,7 @@ const UploadData = ({ formData, onSelect, ...props }) => {
window.history.replaceState({}, "", url);
}

useEffect(() =>{
useEffect(() => {
setKey(currentKey);
setCurrentStep(currentKey - baseKey + 1);
}, [currentKey])
Expand Down Expand Up @@ -237,7 +237,7 @@ const UploadData = ({ formData, onSelect, ...props }) => {

const filterByUpdateFlag = (schemaProperties) => {
return Object.keys(schemaProperties).filter(
(key) => schemaProperties[key].isUpdate !== true
(key) => schemaProperties[key].isUpdate !== true
);
};

Expand Down Expand Up @@ -873,10 +873,10 @@ const UploadData = ({ formData, onSelect, ...props }) => {
type === "facilityWithBoundary"
? "facility"
: type === "userWithBoundary"
? "user"
: type === "boundary"
? "boundaryWithTarget"
: type;
? "user"
: type === "boundary"
? "boundaryWithTarget"
: type;
ashish-egov marked this conversation as resolved.
Show resolved Hide resolved
return {
...i,
filestoreId: id,
Expand Down Expand Up @@ -912,10 +912,10 @@ const UploadData = ({ formData, onSelect, ...props }) => {
type === "facilityWithBoundary"
? "facility"
: type === "userWithBoundary"
? "user"
: type === "boundary"
? "boundaryWithTarget"
: type;
? "user"
: type === "boundary"
? "boundaryWithTarget"
: type;
return {
...i,
filestoreId: id,
Expand All @@ -930,7 +930,7 @@ const UploadData = ({ formData, onSelect, ...props }) => {
setIsError(true);
}
}
} catch (error) {}
} catch (error) { }
ashish-egov marked this conversation as resolved.
Show resolved Hide resolved
}
};

Expand Down Expand Up @@ -1024,14 +1024,14 @@ const UploadData = ({ formData, onSelect, ...props }) => {
}, [key]);

const onStepClick = (currentStep) => {
setCurrentStep(currentStep+1);
if(currentStep === 0){
setCurrentStep(currentStep + 1);
if (currentStep === 0) {
setKey(9);
}
else if(currentStep === 1){
else if (currentStep === 1) {
setKey(10);
}
else if(currentStep === 3){
else if (currentStep === 3) {
setKey(12);
}
else setKey(11);
nipunarora-eGov marked this conversation as resolved.
Show resolved Hide resolved
Expand All @@ -1040,93 +1040,93 @@ const UploadData = ({ formData, onSelect, ...props }) => {
return (
<>
<div className="container-full">
<div className="card-container">
nipunarora-eGov marked this conversation as resolved.
Show resolved Hide resolved
<Card className="card-header-timeline">
<TextBlock
subHeader={t("HCM_UPLOAD_DATA")}
subHeaderClasName={"stepper-subheader"}
wrapperClassName={"stepper-wrapper"}
/>
</Card>
<Card className="stepper-card">
<Stepper
customSteps={["HCM_UPLOAD_FACILITY", "HCM_UPLOAD_USER" , "HCM_UPLOAD_TARGET" , "HCM_SUMMARY"]}
currentStep={currentStep}
onStepClick={onStepClick}
direction={"vertical"}
/>
</Card>
</div>
{loader && <LoaderWithGap text={"CAMPAIGN_VALIDATION_INPROGRESS"} />}
<div className="card-container">
<Card>
<div className="campaign-bulk-upload">
<Header className="digit-form-composer-sub-header">
{type === "boundary" ? t("WBH_UPLOAD_TARGET") : type === "facilityWithBoundary" ? t("WBH_UPLOAD_FACILITY") : t("WBH_UPLOAD_USER")}
</Header>
<Button
label={t("WBH_DOWNLOAD_TEMPLATE")}
variation="secondary"
icon={"FileDownload"}
type="button"
className="campaign-download-template-btn"
onClick={downloadTemplate}
<Card className="card-header-timeline">
<TextBlock
subHeader={t("HCM_UPLOAD_DATA")}
subHeaderClasName={"stepper-subheader"}
wrapperClassName={"stepper-wrapper"}
/>
</div>
{uploadedFile.length === 0 && (
<div className="info-text">
{type === "boundary" ? t("HCM_BOUNDARY_MESSAGE") : type === "facilityWithBoundary" ? t("HCM_FACILITY_MESSAGE") : t("HCM_USER_MESSAGE")}
</div>
)}
<BulkUpload onSubmit={onBulkUploadSubmit} fileData={uploadedFile} onFileDelete={onFileDelete} onFileDownload={onFileDownload} />
{showInfoCard && (
<InfoCard
populators={{
name: "infocard",
}}
variant="error"
style={{ marginLeft: "0rem", maxWidth: "100%" }}
label={t("HCM_ERROR")}
additionalElements={[
<React.Fragment key={type}>
{errorsType[type] && (
<React.Fragment>
{errorsType[type]
.split(",")
.slice(0, 50)
.map((error, index) => (
<React.Fragment key={index}>
{index > 0 && <br />}
{error.trim()}
</React.Fragment>
))}
</React.Fragment>
)}
</React.Fragment>,
]}
</Card>
<Card className="stepper-card">
<Stepper
customSteps={["HCM_UPLOAD_FACILITY", "HCM_UPLOAD_USER", "HCM_UPLOAD_TARGET", "HCM_SUMMARY"]}
currentStep={currentStep}
onStepClick={onStepClick}
direction={"vertical"}
/>
)}
</Card>
<InfoCard
populators={{
name: "infocard",
}}
variant="default"
style={{ margin: "0rem", maxWidth: "100%" }}
additionalElements={readMeInfo[type]?.map((info, index) => (
<div key={index} style={{ display: "flex", flexDirection: "column" }}>
<h2>{info?.header}</h2>
<ul style={{ paddingLeft: 0 }}>
{info?.descriptions.map((desc, i) => (
<li key={i} className="info-points">
{desc.isBold ? <h2>{desc.text}</h2> : <p>{desc.text}</p>}
</li>
))}
</ul>
</Card>
</div>
{loader && <LoaderWithGap text={"CAMPAIGN_VALIDATION_INPROGRESS"} />}
<div className="card-container">
<Card>
<div className="campaign-bulk-upload">
<Header className="digit-form-composer-sub-header">
{type === "boundary" ? t("WBH_UPLOAD_TARGET") : type === "facilityWithBoundary" ? t("WBH_UPLOAD_FACILITY") : t("WBH_UPLOAD_USER")}
</Header>
<Button
label={t("WBH_DOWNLOAD_TEMPLATE")}
variation="secondary"
icon={"FileDownload"}
type="button"
className="campaign-download-template-btn"
onClick={downloadTemplate}
/>
</div>
))}
label={"Info"}
/>
{uploadedFile.length === 0 && (
<div className="info-text">
{type === "boundary" ? t("HCM_BOUNDARY_MESSAGE") : type === "facilityWithBoundary" ? t("HCM_FACILITY_MESSAGE") : t("HCM_USER_MESSAGE")}
</div>
)}
<BulkUpload onSubmit={onBulkUploadSubmit} fileData={uploadedFile} onFileDelete={onFileDelete} onFileDownload={onFileDownload} />
{showInfoCard && (
<InfoCard
populators={{
name: "infocard",
}}
variant="error"
style={{ marginLeft: "0rem", maxWidth: "100%" }}
label={t("HCM_ERROR")}
additionalElements={[
<React.Fragment key={type}>
{errorsType[type] && (
<React.Fragment>
{errorsType[type]
.split(",")
.slice(0, 50)
.map((error, index) => (
<React.Fragment key={index}>
{index > 0 && <br />}
{error.trim()}
</React.Fragment>
))}
</React.Fragment>
)}
</React.Fragment>,
]}
/>
)}
</Card>
<InfoCard
populators={{
name: "infocard",
}}
variant="default"
style={{ margin: "0rem", maxWidth: "100%" }}
additionalElements={readMeInfo[type]?.map((info, index) => (
<div key={index} style={{ display: "flex", flexDirection: "column" }}>
<h2>{info?.header}</h2>
<ul style={{ paddingLeft: 0 }}>
{info?.descriptions.map((desc, i) => (
<li key={i} className="info-points">
{desc.isBold ? <h2>{desc.text}</h2> : <p>{desc.text}</p>}
</li>
))}
</ul>
</div>
))}
label={"Info"}
/>
ashish-egov marked this conversation as resolved.
Show resolved Hide resolved
</div>
{showPopUp && (
<PopUp
Expand All @@ -1137,16 +1137,16 @@ const UploadData = ({ formData, onSelect, ...props }) => {
type === "boundary"
? t("ES_CAMPAIGN_UPLOAD_BOUNDARY_DATA_MODAL_HEADER")
: type === "facilityWithBoundary"
? t("ES_CAMPAIGN_UPLOAD_FACILITY_DATA_MODAL_HEADER")
: t("ES_CAMPAIGN_UPLOAD_USER_DATA_MODAL_HEADER")
? t("ES_CAMPAIGN_UPLOAD_FACILITY_DATA_MODAL_HEADER")
: t("ES_CAMPAIGN_UPLOAD_USER_DATA_MODAL_HEADER")
}
children={[
<div>
{type === "boundary"
? t("ES_CAMPAIGN_UPLOAD_BOUNDARY_DATA_MODAL_TEXT")
: type === "facilityWithBoundary"
? t("ES_CAMPAIGN_UPLOAD_FACILITY_DATA_MODAL_TEXT")
: t("ES_CAMPAIGN_UPLOAD_USER_DATA_MODAL_TEXT ")}
? t("ES_CAMPAIGN_UPLOAD_FACILITY_DATA_MODAL_TEXT")
: t("ES_CAMPAIGN_UPLOAD_USER_DATA_MODAL_TEXT ")}
</div>,
]}
onOverlayClick={() => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -46,11 +46,14 @@ const Hooks = {

const Utils = {
browser: {
sample: () => {},
sample: () => { },
},
workbench: {
...utils,
},
campaign: {
...utils
}
};

export const CustomisedHooks = {
Expand Down
Loading