diff --git a/src/servers/helpers/HighlightCard.scss b/src/servers/helpers/HighlightCard.scss index ddb11b6b..beb6fe5b 100644 --- a/src/servers/helpers/HighlightCard.scss +++ b/src/servers/helpers/HighlightCard.scss @@ -7,6 +7,13 @@ text-decoration: none; } +.highlight-card__link-icon { + position: absolute; + right: 5px; + bottom: 5px; + opacity: 0.1; +} + .highlight-card__title { text-transform: uppercase; color: $textPlaceholder; diff --git a/src/servers/helpers/HighlightCard.tsx b/src/servers/helpers/HighlightCard.tsx index 85988a7f..e46782a7 100644 --- a/src/servers/helpers/HighlightCard.tsx +++ b/src/servers/helpers/HighlightCard.tsx @@ -1,6 +1,8 @@ import { FC } from 'react'; import { Card, CardText, CardTitle } from 'reactstrap'; import { Link } from 'react-router-dom'; +import { faLink as linkIcon } from '@fortawesome/free-solid-svg-icons'; +import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; import './HighlightCard.scss'; export interface HighlightCardProps { @@ -8,8 +10,11 @@ export interface HighlightCardProps { link?: string; } +const buildExtraProps = (link?: string) => !link ? {} : { tag: Link, to: link }; + export const HighlightCard: FC = ({ children, title, link }) => ( - + + {link && } {title} {children} diff --git a/test/servers/helpers/HighlightCard.test.tsx b/test/servers/helpers/HighlightCard.test.tsx index b166c1de..94426bb2 100644 --- a/test/servers/helpers/HighlightCard.test.tsx +++ b/test/servers/helpers/HighlightCard.test.tsx @@ -2,6 +2,7 @@ import { shallow, ShallowWrapper } from 'enzyme'; import { ReactNode } from 'react'; import { Card, CardText, CardTitle } from 'reactstrap'; import { Link } from 'react-router-dom'; +import { FontAwesomeIcon } from '@fortawesome/react-fontawesome'; import { HighlightCard, HighlightCardProps } from '../../../src/servers/helpers/HighlightCard'; describe('', () => { @@ -20,6 +21,7 @@ describe('', () => { expect(wrapper.find(Card)).toHaveLength(1); expect(wrapper.find(CardTitle)).toHaveLength(1); expect(wrapper.find(CardText)).toHaveLength(1); + expect(wrapper.find(FontAwesomeIcon)).toHaveLength(0); expect(wrapper.prop('tag')).not.toEqual(Link); expect(wrapper.prop('to')).not.toBeDefined(); }); @@ -53,6 +55,7 @@ describe('', () => { ])('adds extra props when a link is provided', (link) => { const wrapper = createWrapper({ title: 'foo', link }); + expect(wrapper.find(FontAwesomeIcon)).toHaveLength(1); expect(wrapper.prop('tag')).toEqual(Link); expect(wrapper.prop('to')).toEqual(link); });