Files
Reactive-Resume/src/templates/Pikachu.js
Amruth Pillai df71b86028 - bumped version to 2.3.3
- fixed text alignment issues
- updated dependencies
- added ukranian language
2020-12-09 10:40:27 +05:30

120 lines
3.7 KiB
JavaScript

import React from 'react';
import ReactMarkdown from 'react-markdown';
import PageContext from '../contexts/PageContext';
import ContactA from './blocks/Contact/ContactA';
import HeadingB from './blocks/Heading/HeadingB';
import AwardsA from './blocks/Awards/AwardsA';
import CertificationsA from './blocks/Certifications/CertificationsA';
import EducationA from './blocks/Education/EducationA';
import HobbiesA from './blocks/Hobbies/HobbiesA';
import LanguagesA from './blocks/Languages/LanguagesA';
import ProjectsA from './blocks/Projects/ProjectsA';
import ReferencesA from './blocks/References/ReferencesA';
import SkillsA from './blocks/Skills/SkillsA';
import WorkA from './blocks/Work/WorkA';
import BirthDateB from './blocks/BirthDate/BirthDateB';
const Blocks = {
work: WorkA,
education: EducationA,
projects: ProjectsA,
awards: AwardsA,
certifications: CertificationsA,
skills: SkillsA,
hobbies: HobbiesA,
languages: LanguagesA,
references: ReferencesA,
};
const Pikachu = ({ data }) => {
const layout = data.metadata.layout.pikachu;
return (
<PageContext.Provider value={{ data, heading: HeadingB }}>
<div
id="page"
className="p-8 rounded"
style={{
fontFamily: data.metadata.font,
color: data.metadata.colors.text,
backgroundColor: data.metadata.colors.background,
}}
>
<div className="grid grid-cols-12 gap-8">
{data.profile.photograph && (
<div className="self-center col-span-4">
<img
className="w-48 h-48 rounded-full mx-auto object-cover"
src={data.profile.photograph}
alt={data.profile.firstName}
/>
</div>
)}
<div
className={`${
data.profile.photograph !== '' ? 'col-span-8' : 'col-span-12'
}`}
>
<div
className="h-48 rounded flex flex-col justify-center"
style={{
backgroundColor: data.metadata.colors.primary,
color: data.metadata.colors.background,
}}
>
<div className="flex flex-col justify-center mx-8 my-6">
<h1 className="text-3xl font-bold leading-tight">
{data.profile.firstName} {data.profile.lastName}
</h1>
<div className="text-sm font-medium tracking-wide">
{data.profile.subtitle}
</div>
{data.objective.body && (
<div>
<hr
className="my-5 opacity-25"
style={{ borderColor: data.metadata.colors.background }}
/>
<ReactMarkdown
className="text-sm"
source={data.objective.body}
/>
</div>
)}
</div>
</div>
</div>
<div className="col-span-4">
<div className="grid gap-4">
<BirthDateB />
<ContactA />
{layout[0] &&
layout[0].map((x) => {
const Component = Blocks[x];
return Component && <Component key={x} />;
})}
</div>
</div>
<div className="col-span-8">
<div className="grid gap-4">
{layout[1] &&
layout[1].map((x) => {
const Component = Blocks[x];
return Component && <Component key={x} />;
})}
</div>
</div>
</div>
</div>
</PageContext.Provider>
);
};
export default Pikachu;