added employer column in ready table

This commit was merged in pull request #31.
This commit is contained in:
victorAnumudu
2024-06-13 17:33:47 +01:00
parent c970467f16
commit ea90bd6fc5
15 changed files with 38 additions and 13 deletions
@@ -0,0 +1,44 @@
import {useEffect} from 'react'
import {UserEditModalHeader} from './UserEditModalHeader'
import {UserEditModalFormWrapper} from './UserEditModalFormWrapper'
const EditLoanModal = () => {
useEffect(() => {
document.body.classList.add('modal-open')
return () => {
document.body.classList.remove('modal-open')
}
}, [])
return (
<>
<div
className='modal fade show d-block'
id='kt_modal_add_user'
role='dialog'
tabIndex={-1}
aria-modal='true'
>
{/* begin::Modal dialog */}
<div className='modal-dialog modal-dialog-centered mw-650px'>
{/* begin::Modal content */}
<div className='modal-content'>
<UserEditModalHeader />
{/* begin::Modal body */}
<div className='modal-body scroll-y mx-5 mx-xl-15 my-7'>
<UserEditModalFormWrapper />
</div>
{/* end::Modal body */}
</div>
{/* end::Modal content */}
</div>
{/* end::Modal dialog */}
</div>
{/* begin::Modal Backdrop */}
<div className='modal-backdrop fade show'></div>
{/* end::Modal Backdrop */}
</>
)
}
export {EditLoanModal}
@@ -0,0 +1,433 @@
import { FC, useState } from "react";
import * as Yup from "yup";
import { useFormik } from "formik";
import { isNotEmpty, toAbsoluteUrl } from "../../../../../_digifi/helpers";
import { initialUser, User } from "../../core/_models";
import clsx from "clsx";
import { useListView } from "../core/ListViewProvider";
import { UsersListLoading } from "../components/loading/UsersListLoading";
import { createUser, updateUser } from "../../core/_requests";
import { useQueryResponse } from "../core/QueryResponseProvider";
type Props = {
isUserLoading: boolean;
user: User;
};
const editUserSchema = Yup.object().shape({
email: Yup.string()
.email("Wrong email format")
.min(3, "Minimum 3 symbols")
.max(50, "Maximum 50 symbols")
.required("Email is required"),
name: Yup.string()
.min(3, "Minimum 3 symbols")
.max(50, "Maximum 50 symbols")
.required("Name is required"),
});
const UserEditModalForm: FC<Props> = ({ user, isUserLoading }) => {
const { setItemIdForUpdate } = useListView();
const { refetch } = useQueryResponse();
const [userForEdit] = useState<User>({
...user,
avatar: user.avatar || initialUser.avatar,
role: user.role || initialUser.role,
position: user.position || initialUser.position,
name: user.name || initialUser.name,
email: user.email || initialUser.email,
});
const cancel = (withRefresh?: boolean) => {
if (withRefresh) {
refetch();
}
setItemIdForUpdate(undefined);
};
const blankImg = toAbsoluteUrl("media/svg/avatars/blank.svg");
const userAvatarImg = toAbsoluteUrl(`media/${userForEdit.avatar}`);
const formik = useFormik({
initialValues: userForEdit,
validationSchema: editUserSchema,
onSubmit: async (values, { setSubmitting }) => {
setSubmitting(true);
try {
if (isNotEmpty(values.id)) {
await updateUser(values);
} else {
await createUser(values);
}
} catch (ex) {
console.error(ex);
} finally {
setSubmitting(true);
cancel(true);
}
},
});
return (
<>
<form
id="kt_modal_add_user_form"
className="form"
onSubmit={formik.handleSubmit}
noValidate
>
{/* begin::Scroll */}
<div
className="d-flex flex-column scroll-y me-n7 pe-7"
id="kt_modal_add_user_scroll"
data-kt-scroll="true"
data-kt-scroll-activate="{default: false, lg: true}"
data-kt-scroll-max-height="auto"
data-kt-scroll-dependencies="#kt_modal_add_user_header"
data-kt-scroll-wrappers="#kt_modal_add_user_scroll"
data-kt-scroll-offset="300px"
>
{/* begin::Input group */}
<div className="fv-row mb-7">
{/* begin::Label */}
<label className="d-block fw-bold fs-6 mb-5">Avatar</label>
{/* end::Label */}
{/* begin::Image input */}
<div
className="image-input image-input-outline"
data-kt-image-input="true"
style={{ backgroundImage: `url('${blankImg}')` }}
>
{/* begin::Preview existing avatar */}
<div
className="image-input-wrapper w-125px h-125px"
style={{ backgroundImage: `url('${userAvatarImg}')` }}
></div>
{/* end::Preview existing avatar */}
{/* begin::Label */}
{/* <label
className='btn btn-icon btn-circle btn-active-color-primary w-25px h-25px bg-body shadow'
data-kt-image-input-action='change'
data-bs-toggle='tooltip'
title='Change avatar'
>
<i className='bi bi-pencil-fill fs-7'></i>
<input type='file' name='avatar' accept='.png, .jpg, .jpeg' />
<input type='hidden' name='avatar_remove' />
</label> */}
{/* end::Label */}
{/* begin::Cancel */}
{/* <span
className='btn btn-icon btn-circle btn-active-color-primary w-25px h-25px bg-body shadow'
data-kt-image-input-action='cancel'
data-bs-toggle='tooltip'
title='Cancel avatar'
>
<i className='bi bi-x fs-2'></i>
</span> */}
{/* end::Cancel */}
{/* begin::Remove */}
{/* <span
className='btn btn-icon btn-circle btn-active-color-primary w-25px h-25px bg-body shadow'
data-kt-image-input-action='remove'
data-bs-toggle='tooltip'
title='Remove avatar'
>
<i className='bi bi-x fs-2'></i>
</span> */}
{/* end::Remove */}
</div>
{/* end::Image input */}
{/* begin::Hint */}
{/* <div className='form-text'>Allowed file types: png, jpg, jpeg.</div> */}
{/* end::Hint */}
</div>
{/* end::Input group */}
{/* begin::Input group */}
<div className="fv-row mb-7">
{/* begin::Label */}
<label className="required fw-bold fs-6 mb-2">Full Name</label>
{/* end::Label */}
{/* begin::Input */}
<input
placeholder="Full name"
{...formik.getFieldProps("name")}
type="text"
name="name"
className={clsx(
"form-control form-control-solid mb-3 mb-lg-0",
{ "is-invalid": formik.touched.name && formik.errors.name },
{
"is-valid": formik.touched.name && !formik.errors.name,
}
)}
autoComplete="off"
disabled={formik.isSubmitting || isUserLoading}
/>
{formik.touched.name && formik.errors.name && (
<div className="fv-plugins-message-container">
<div className="fv-help-block">
<span role="alert">{formik.errors.name}</span>
</div>
</div>
)}
{/* end::Input */}
</div>
{/* end::Input group */}
{/* begin::Input group */}
<div className="fv-row mb-7">
{/* begin::Label */}
<label className="required fw-bold fs-6 mb-2">Email</label>
{/* end::Label */}
{/* begin::Input */}
<input
placeholder="Email"
{...formik.getFieldProps("email")}
className={clsx(
"form-control form-control-solid mb-3 mb-lg-0",
{ "is-invalid": formik.touched.email && formik.errors.email },
{
"is-valid": formik.touched.email && !formik.errors.email,
}
)}
type="email"
name="email"
autoComplete="off"
disabled={formik.isSubmitting || isUserLoading}
/>
{/* end::Input */}
{formik.touched.email && formik.errors.email && (
<div className="fv-plugins-message-container">
<span role="alert">{formik.errors.email}</span>
</div>
)}
</div>
{/* end::Input group */}
{/* begin::Input group */}
<div className="mb-7">
{/* begin::Label */}
<label className="required fw-bold fs-6 mb-5">Role</label>
{/* end::Label */}
{/* begin::Roles */}
{/* begin::Input row */}
<div className="d-flex fv-row">
{/* begin::Radio */}
<div className="form-check form-check-custom form-check-solid">
{/* begin::Input */}
<input
className="form-check-input me-3"
{...formik.getFieldProps("role")}
name="role"
type="radio"
value="Administrator"
id="kt_modal_update_role_option_0"
checked={formik.values.role === "Administrator"}
disabled={formik.isSubmitting || isUserLoading}
/>
{/* end::Input */}
{/* begin::Label */}
<label
className="form-check-label"
htmlFor="kt_modal_update_role_option_0"
>
<div className="fw-bolder text-gray-800">Administrator</div>
<div className="text-gray-600">
Best for business owners and company administrators
</div>
</label>
{/* end::Label */}
</div>
{/* end::Radio */}
</div>
{/* end::Input row */}
<div className="separator separator-dashed my-5"></div>
{/* begin::Input row */}
<div className="d-flex fv-row">
{/* begin::Radio */}
<div className="form-check form-check-custom form-check-solid">
{/* begin::Input */}
<input
className="form-check-input me-3"
{...formik.getFieldProps("role")}
name="role"
type="radio"
value="Developer"
id="kt_modal_update_role_option_1"
checked={formik.values.role === "Developer"}
disabled={formik.isSubmitting || isUserLoading}
/>
{/* end::Input */}
{/* begin::Label */}
<label
className="form-check-label"
htmlFor="kt_modal_update_role_option_1"
>
<div className="fw-bolder text-gray-800">Developer</div>
<div className="text-gray-600">
Best for developers or people primarily using the API
</div>
</label>
{/* end::Label */}
</div>
{/* end::Radio */}
</div>
{/* end::Input row */}
<div className="separator separator-dashed my-5"></div>
{/* begin::Input row */}
<div className="d-flex fv-row">
{/* begin::Radio */}
<div className="form-check form-check-custom form-check-solid">
{/* begin::Input */}
<input
className="form-check-input me-3"
{...formik.getFieldProps("role")}
name="role"
type="radio"
value="Analyst"
id="kt_modal_update_role_option_2"
checked={formik.values.role === "Analyst"}
disabled={formik.isSubmitting || isUserLoading}
/>
{/* end::Input */}
{/* begin::Label */}
<label
className="form-check-label"
htmlFor="kt_modal_update_role_option_2"
>
<div className="fw-bolder text-gray-800">Analyst</div>
<div className="text-gray-600">
Best for people who need full access to analytics data, but
don't need to update business settings
</div>
</label>
{/* end::Label */}
</div>
{/* end::Radio */}
</div>
{/* end::Input row */}
<div className="separator separator-dashed my-5"></div>
{/* begin::Input row */}
<div className="d-flex fv-row">
{/* begin::Radio */}
<div className="form-check form-check-custom form-check-solid">
{/* begin::Input */}
<input
className="form-check-input me-3"
{...formik.getFieldProps("role")}
name="role"
type="radio"
value="Support"
id="kt_modal_update_role_option_3"
checked={formik.values.role === "Support"}
disabled={formik.isSubmitting || isUserLoading}
/>
{/* end::Input */}
{/* begin::Label */}
<label
className="form-check-label"
htmlFor="kt_modal_update_role_option_3"
>
<div className="fw-bolder text-gray-800">Support</div>
<div className="text-gray-600">
Best for employees who regularly refund payments and respond
to disputes
</div>
</label>
{/* end::Label */}
</div>
{/* end::Radio */}
</div>
{/* end::Input row */}
<div className="separator separator-dashed my-5"></div>
{/* begin::Input row */}
<div className="d-flex fv-row">
{/* begin::Radio */}
<div className="form-check form-check-custom form-check-solid">
{/* begin::Input */}
<input
className="form-check-input me-3"
{...formik.getFieldProps("role")}
name="role"
type="radio"
id="kt_modal_update_role_option_4"
value="Trial"
checked={formik.values.role === "Trial"}
disabled={formik.isSubmitting || isUserLoading}
/>
{/* end::Input */}
{/* begin::Label */}
<label
className="form-check-label"
htmlFor="kt_modal_update_role_option_4"
>
<div className="fw-bolder text-gray-800">Trial</div>
<div className="text-gray-600">
Best for people who need to preview content data, but don't
need to make any updates
</div>
</label>
{/* end::Label */}
</div>
{/* end::Radio */}
</div>
{/* end::Input row */}
{/* end::Roles */}
</div>
{/* end::Input group */}
</div>
{/* end::Scroll */}
{/* begin::Actions */}
<div className="text-center pt-15">
<button
type="reset"
onClick={() => cancel()}
className="btn btn-light me-3"
data-kt-users-modal-action="cancel"
disabled={formik.isSubmitting || isUserLoading}
>
Discard
</button>
<button
type="submit"
className="btn btn-primary"
data-kt-users-modal-action="submit"
disabled={
isUserLoading ||
formik.isSubmitting ||
!formik.isValid ||
!formik.touched
}
>
<span className="indicator-label">Submit</span>
{(formik.isSubmitting || isUserLoading) && (
<span className="indicator-progress">
Please wait...{" "}
<span className="spinner-border spinner-border-sm align-middle ms-2"></span>
</span>
)}
</button>
</div>
{/* end::Actions */}
</form>
{(formik.isSubmitting || isUserLoading) && <UsersListLoading />}
</>
);
};
export { UserEditModalForm };
@@ -0,0 +1,42 @@
import { useQuery } from "react-query";
import { UserEditModalForm } from "./UserEditModalForm";
import { isNotEmpty, QUERIES } from "../../../../../_digifi/helpers";
import { useListView } from "../core/ListViewProvider";
import { getUserById } from "../../core/_requests";
const UserEditModalFormWrapper = () => {
const { itemIdForUpdate, setItemIdForUpdate } = useListView();
const enabledQuery: boolean = isNotEmpty(itemIdForUpdate);
const {
isLoading,
data: user,
error,
} = useQuery(
`${QUERIES.READY_LIST}-user-${itemIdForUpdate}`,
() => {
return getUserById(itemIdForUpdate);
},
{
cacheTime: 0,
enabled: enabledQuery,
onError: (err) => {
setItemIdForUpdate(undefined);
console.error(err);
},
}
);
if (!itemIdForUpdate) {
return (
<UserEditModalForm isUserLoading={isLoading} user={{ id: undefined }} />
);
}
if (!isLoading && !error && user) {
return <UserEditModalForm isUserLoading={isLoading} user={user} />;
}
return null;
};
export { UserEditModalFormWrapper };
@@ -0,0 +1,27 @@
import { KTIcon } from "../../../../../_digifi/helpers";
import { useListView } from "../core/ListViewProvider";
const UserEditModalHeader = () => {
const { setItemIdForUpdate } = useListView();
return (
<div className="modal-header">
{/* begin::Modal title */}
<h2 className="fw-bolder">Edit Loan</h2>
{/* end::Modal title */}
{/* begin::Close */}
<div
className="btn btn-icon btn-sm btn-active-icon-primary"
data-kt-users-modal-action="close"
onClick={() => setItemIdForUpdate(undefined)}
style={{ cursor: "pointer" }}
>
<KTIcon iconName="cross" className="fs-1" />
</div>
{/* end::Close */}
</div>
);
};
export { UserEditModalHeader };