Skip to content
This repository has been archived by the owner on Aug 13, 2023. It is now read-only.

Commit

Permalink
Merge branch 'latest' into ghstorybook
Browse files Browse the repository at this point in the history
  • Loading branch information
Drew McMillan authored Dec 11, 2018
2 parents 2c64b36 + 993a52b commit 208b76e
Show file tree
Hide file tree
Showing 8 changed files with 599 additions and 0 deletions.
5 changes: 5 additions & 0 deletions packages/components/psammead-inline-link/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
# Psammead Inline Link Changelog

| Version | Description |
|---------|-------------|
| 0.1.0 | [PR#106](https://github.com/BBC-News/psammead/pull/106) Create initial package with Inline Link component pulled in from [Simorgh](https://github.com/BBC-News/simorgh). |
92 changes: 92 additions & 0 deletions packages/components/psammead-inline-link/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
# psammead-inline-link · [![GitHub license](https://img.shields.io/badge/license-Apache%202.0-blue.svg)](https://github.com/BBC-News/psammead/blob/latest/LICENSE) [![npm version](https://img.shields.io/npm/v/@bbc/psammead-inline-link.svg)](https://www.npmjs.com/package/@bbc/psammead-inline-link) [![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg)](https://reactjs.org/docs/how-to-contribute.html#your-first-pull-request)

## Description

The `@bbc/psammead-inline-link` package exports a single Inline Link component. It uses an `a` HTML element and colours from `@bbc/psammead-styles`.

## Installation

```
npm install @bbc/psammead-inline-link --save
```

## Usage

```jsx
import InlineLink from '@bbc/psammead-inline-link';

const WrappingComponent = () => (
<InlineLink href="https://www.bbc.com/news">Text here</InlineLink>
);
```

## When to use this component

This component can be used at any point on a page.

We have not included any typography styles inside this component. This is so it is reusable in multiple contexts. For example, you can use `InlineLink` inside our existing `psammead-paragraph` for body copy and `psammead-headings` for headlines and subheadings (`h1`s and `h2`s).

Example inline link in a paragraph:

```jsx
import InlineLink from '@bbc/psammead-inline-link';
import Paragraph from '@bbc/psammead-paragraph';

const WrapperComponent = () => (
<Paragraph>I am a paragraph that has a link to <InlineLink href="https://www.bbc.com/news">the BBC News front page</InlineLink>.<Paragraph>
);
```

Example inline link in a Headline or SubHeading:

```jsx
import InlineLink from '@bbc/psammead-inline-link';
import { Headline, SubHeading } from '@bbc/psammead-headings';

const HeadlineWithALink = () => (
<InlineLink href="https://www.bbc.com/news"><Headline>Headline</Headline></InlineLink>


const SubHeadingWithALink = () => (
<InlineLink href="https://www.bbc.com/news"><SubHeading>SubHeading</SubHeading></InlineLink>
);
```
Alternatively, if you want to just extend existing styles with other GEL Typography groups, you can do the following:
```jsx
import InlineLink from '@bbc/psammead-inline-link';
import { GEL_PARAGON } from '@bbc/gel-foundations-styled-components';

const GelParagonLink = styled(InlineLink)`
${GEL_PARAGON};
`;

const WrapperComponent = () => (
<GelParagonLink href="https://www.bbc.com/news">
Link with GEL Paragon typography
</GelParagonLink>
);
```
## Accessibility notes
Since this is just a `<a>` tag with associated styles, when you use this component, it has the same semantic meaning as a regular anchor element.
The font and background-color choices for each hover/focused/visited/default states meet WCAG AA colour contrast guidelines.
## Roadmap
Our UX team are considering updating the colours for the hover and focus states of this component. When we implement this change, we will ensure it is a major version increase, since for downstream teams this will be a breaking change.
## Contributing
Psammead is completely open source. We are grateful for any contributions, whether they be new components, bug fixes or general improvements. Please see our primary contributing guide which can be found at [the root of the Psammead respository](https://github.com/BBC-News/psammead/blob/latest/CONTRIBUTING.md).
### [Code of Conduct](https://github.com/BBC-News/psammead/blob/latest/CODE_OF_CONDUCT.md)
We welcome feedback and help on this work. By participating in this project, you agree to abide by the [code of conduct](https://github.com/BBC-News/psammead/blob/latest/CODE_OF_CONDUCT.md). Please take a moment to read it.
### License
Psammead is [Apache 2.0 licensed](https://github.com/BBC-News/psammead/blob/latest/LICENSE).
Loading

0 comments on commit 208b76e

Please sign in to comment.