computer-scienceangular-roadmapbackend-roadmapblockchain-roadmapdba-roadmapdeveloper-roadmapdevops-roadmapfrontend-roadmapgo-roadmaphactoberfestjava-roadmapjavascript-roadmapnodejs-roadmappython-roadmapqa-roadmapreact-roadmaproadmapstudy-planvue-roadmapweb3-roadmap
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
93 lines
2.8 KiB
93 lines
2.8 KiB
import Link from 'next/link'; |
|
import classNames from 'classnames'; |
|
import { |
|
SummaryContainer, |
|
Title, |
|
Description, |
|
Image, |
|
Header, |
|
Summary, |
|
VersionLink, |
|
VersionList, |
|
} from './style'; |
|
import SharePage from 'components/share-page'; |
|
import { BadgeLink, BadgesList, PrimaryBadge, SecondaryBadge, DarkBadge } from 'components/badges'; |
|
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; |
|
import { faEnvelope, faClock, faHandshake, faArrowLeft } from '@fortawesome/free-solid-svg-icons'; |
|
import GuideBody from 'components/guide-body'; |
|
import siteConfig from "data/site"; |
|
|
|
const isActiveRoadmap = (loadedVersion, roadmapVersion) => ( |
|
(loadedVersion === roadmapVersion) || |
|
(loadedVersion === 'latest' && parseInt(roadmapVersion, 10) === (new Date()).getFullYear()) |
|
); |
|
|
|
const UpcomingGuide = require(`../../data/roadmaps/upcoming.md`).default; |
|
|
|
const RoadmapSummary = ({ roadmap }) => ( |
|
<SummaryContainer> |
|
<Header> |
|
<Title>{ roadmap.title }</Title> |
|
<Description>{ roadmap.description }</Description> |
|
|
|
<BadgesList className="mt-4"> |
|
<BadgeLink href="/roadmaps"> |
|
<DarkBadge> |
|
<FontAwesomeIcon icon={faArrowLeft}/> |
|
Other Roadmaps |
|
</DarkBadge> |
|
</BadgeLink> |
|
{ roadmap.upcoming && ( |
|
<SecondaryBadge> |
|
<FontAwesomeIcon icon={faClock}/> |
|
Upcoming Roadmap |
|
</SecondaryBadge> |
|
) } |
|
{ !roadmap.upcoming && ( |
|
<BadgeLink href={`${siteConfig.url.issue}?title=[${roadmap.title}] - Title Here`} target="_blank"> |
|
<SecondaryBadge> |
|
<FontAwesomeIcon icon={faHandshake}/> |
|
Suggest Changes |
|
</SecondaryBadge> |
|
</BadgeLink> |
|
) } |
|
|
|
<BadgeLink href="/signup"> |
|
<PrimaryBadge> |
|
<FontAwesomeIcon icon={faEnvelope}/> |
|
Send me Updates |
|
</PrimaryBadge> |
|
</BadgeLink> |
|
</BadgesList> |
|
|
|
<VersionList className="border-bottom"> |
|
{ (roadmap.versions || []).map(versionItem => ( |
|
<Link href={ `${roadmap.url}/${versionItem}` } passHref key={ versionItem }> |
|
<VersionLink className={ classNames({ |
|
active: isActiveRoadmap(versionItem, roadmap.version), |
|
}) }>{ versionItem } Version</VersionLink> |
|
</Link> |
|
)) } |
|
</VersionList> |
|
</Header> |
|
<Summary> |
|
{ |
|
roadmap.upcoming && ( |
|
<GuideBody> |
|
<UpcomingGuide /> |
|
</GuideBody> |
|
) |
|
} |
|
{ |
|
!roadmap.upcoming && ( |
|
<div className="container"> |
|
<Image src={ roadmap.picture } /> |
|
<SharePage title={ roadmap.description } url={ roadmap.url } /> |
|
</div> |
|
) |
|
} |
|
</Summary> |
|
</SummaryContainer> |
|
); |
|
|
|
export default RoadmapSummary;
|
|
|