- implement certifications section

This commit is contained in:
Amruth Pillai
2020-07-08 20:20:44 +05:30
parent c38788aa3b
commit 70866420e5
16 changed files with 129 additions and 139 deletions

View File

@ -2,6 +2,7 @@ import React, { Fragment } from "react";
import AuthModal from "./AuthModal";
import ResumeModal from "./ResumeModal";
import AwardModal from "./sections/AwardModal";
import CertificateModal from "./sections/CertificateModal";
import EducationModal from "./sections/EducationModal";
import SocialModal from "./sections/SocialModal";
import WorkModal from "./sections/WorkModal";
@ -15,6 +16,7 @@ const ModalRegistrar = () => {
<WorkModal />
<EducationModal />
<AwardModal />
<CertificateModal />
</Fragment>
);
};

View File

@ -36,8 +36,8 @@ const AwardModal = () => {
>
{(formik) => (
<DataModal
name="Award"
path="awards.items"
name="Awards"
event={ModalEvents.AWARD_MODAL}
>
<div className="grid grid-cols-2 gap-8">

View File

@ -0,0 +1,76 @@
import { Formik } from "formik";
import { get } from "lodash";
import React from "react";
import * as Yup from "yup";
import Input from "../../components/shared/Input";
import ModalEvents from "../../constants/ModalEvents";
import DataModal from "../DataModal";
const initialValues = {
title: "",
issuer: "",
date: "",
summary: "",
};
const validationSchema = Yup.object().shape({
title: Yup.string().required("This is a required field."),
issuer: Yup.string().required("This is a required field."),
date: Yup.date().max(new Date()),
summary: Yup.string(),
});
const CertificateModal = () => {
const getFieldProps = (formik, name) => ({
touched: get(formik, `touched.${name}`, false),
error: get(formik, `errors.${name}`, ""),
isRequired: get(validationSchema, `fields.${name}._exclusive.required`),
...formik.getFieldProps(name),
});
return (
<Formik
validateOnBlur
initialValues={initialValues}
validationSchema={validationSchema}
>
{(formik) => (
<DataModal
name="Certificate"
path="certifications.items"
event={ModalEvents.CERTIFICATION_MODAL}
>
<div className="grid grid-cols-2 gap-8">
<Input
label="Title"
className="col-span-2"
placeholder="CCNP"
{...getFieldProps(formik, "title")}
/>
<Input
label="Issuer"
placeholder="Cisco Systems"
{...getFieldProps(formik, "issuer")}
/>
<Input
type="date"
label="Date"
{...getFieldProps(formik, "date")}
/>
<Input
type="textarea"
label="Summary"
className="col-span-2"
{...getFieldProps(formik, "summary")}
/>
</div>
</DataModal>
)}
</Formik>
);
};
export default CertificateModal;

View File

@ -51,8 +51,8 @@ const EducationModal = () => {
>
{(formik) => (
<DataModal
path="education.items"
name="Education"
path="education.items"
event={ModalEvents.EDUCATION_MODAL}
>
<div className="grid grid-cols-2 gap-8">