Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

EuiCard updates #1032

Merged
merged 6 commits into from
Jul 20, 2018
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,10 @@
## [`master`](https://github.com/elastic/eui/tree/master)

No public interface changes since `3.1.0`.
- Allow `titleElement` to be passed to `EuiCard` ([#1032](https://github.com/elastic/eui/pull/1032))

**Bug fixes**

- `BetaBadge` now shows outside of `EuiPanel` bounds in IE ([#1032](https://github.com/elastic/eui/pull/1032))

## [`3.1.0`](https://github.com/elastic/eui/tree/v3.1.0)

Expand Down
5 changes: 5 additions & 0 deletions src-docs/src/views/card/card_example.js
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,11 @@ export const CardExample = {
<EuiCode>description</EuiCode>, and an <EuiCode>icon</EuiCode>. You can make the whole card
clickable by giving it an <EuiCode>onClick</EuiCode> handler.
</p>
<p>
By default a card&apos;s title element is a <EuiCode>span</EuiCode>. This can be changed via
the <EuiCode>titleElement</EuiCode> prop. However, if an <EuiCode>onClick</EuiCode> function is
also passed, the title element will be forced back to a span.
</p>
<p>
By default a card&apos;s content is center aligned. To change the alignment
set <EuiCode>textAlign</EuiCode> to <EuiCode>left</EuiCode> or <EuiCode>right</EuiCode>.
Expand Down
2 changes: 2 additions & 0 deletions src/components/badge/beta_badge/_mixins.scss
Original file line number Diff line number Diff line change
@@ -1,11 +1,13 @@

/**
* 1. Extend beta badges to at least 40% of the container's width
* 2. Fix for IE to ensure badges are visible outside of a <button> tag
*/

@mixin hasBetaBadge($selector, $spacing: $euiSize) {
&.#{$selector}--hasBetaBadge {
position: relative;
overflow: visible; /* 2 */

.#{$selector}__betaBadgeWrapper {
position: absolute;
Expand Down
15 changes: 6 additions & 9 deletions src/components/card/_card.scss
Original file line number Diff line number Diff line change
Expand Up @@ -10,20 +10,17 @@ $euiCardTitleSize: 18px; // Hardcoded pixel value for theme parity.

/**
* 1. Footer is always at the bottom.
* 2. Fix for IE to ensure badges are visible outside of a <button> tag
* 3. Fix for IE where the image correctly resizes in width but doesn't collapse it's height
* 2. Fix for IE where the image correctly resizes in width but doesn't collapse it's height
(https://github.com/philipwalton/flexbugs/issues/75#issuecomment-134702421)
* 4. Horizontal layouts should always top left align no matter the textAlign prop
* 3. Horizontal layouts should always top left align no matter the textAlign prop
*/

// EuiCard specific
.euiCard {
display: flex;
flex-direction: column;
padding: $euiCardSpacing;
overflow: visible; /* 2 */
min-height: 1px; /* 3 */

min-height: 1px; /* 2 */

@include hasBetaBadge($selector: 'euiCard', $spacing: $euiCardSpacing);

Expand Down Expand Up @@ -67,7 +64,7 @@ $euiCardTitleSize: 18px; // Hardcoded pixel value for theme parity.
.euiCard__top {
flex-grow: 0; /* 1 */
position: relative;
min-height: 1px; /* 3 */
min-height: 1px; /* 2 */

.euiCard__icon {
margin-top: $euiCardSpacing/2;
Expand Down Expand Up @@ -123,15 +120,15 @@ $euiCardTitleSize: 18px; // Hardcoded pixel value for theme parity.
.euiCard.euiCard--horizontal {
.euiCard__content {
padding-top: $euiSizeS; // Aligns title and text a bit better and adds spacing in case of beta badge
text-align: left; /* 4 */
text-align: left; /* 3 */
}
}

// Only change the flex direction if the card has an icon
// otherwise the button tag won't properly align contents to top
.euiCard.euiCard--horizontal.euiCard--hasIcon {
flex-direction: row;
align-items: flex-start !important; /* 4 */
align-items: flex-start !important; /* 3 */

.euiCard__top,
.euiCard__content {
Expand Down
14 changes: 13 additions & 1 deletion src/components/card/card.js
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ export const EuiCard = ({
className,
description,
title,
titleElement,
icon,
image,
footer,
Expand Down Expand Up @@ -94,6 +95,11 @@ export const EuiCard = ({
OuterElement = 'button';
}

let TitleElement = titleElement;
if (OuterElement === 'button') {
TitleElement = 'span';
}

let optionalCardTop;
if (imageNode || iconNode) {
optionalCardTop = (
Expand Down Expand Up @@ -133,7 +139,7 @@ export const EuiCard = ({

<span className="euiCard__content">
<EuiTitle className="euiCard__title">
<span>{title}</span>
<TitleElement>{title}</TitleElement>
</EuiTitle>

<EuiText size="s" className="euiCard__description">
Expand All @@ -153,6 +159,11 @@ export const EuiCard = ({
EuiCard.propTypes = {
className: PropTypes.string,
title: PropTypes.node.isRequired,
/**
* Determines the title's heading element. Will force to 'span' if
* the card is a button.
*/
titleElement: PropTypes.oneOf(['h2', 'h3', 'h4', 'h5', 'h6', 'span']),
description: PropTypes.node.isRequired,

/**
Expand Down Expand Up @@ -203,4 +214,5 @@ EuiCard.propTypes = {
EuiCard.defaultProps = {
textAlign: 'center',
layout: 'vertical',
titleElement: 'span',
};