Skip to content

Commit

Permalink
feat(EntryCard): add size=auto to EntryCard (#576)
Browse files Browse the repository at this point in the history
  • Loading branch information
anho committed Sep 30, 2020
1 parent 76074dd commit a1f8557
Show file tree
Hide file tree
Showing 3 changed files with 67 additions and 14 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,10 @@
height: calc(1rem * (84 / var(--font-base-default)));
}

.EntryCard--size-auto {
min-height: calc(1rem * (84 / var(--font-base-default)));
}

.EntryCard__wrapper {
padding: calc(1rem * (14 / var(--font-base-default)));
flex: 1 1 0;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -181,4 +181,43 @@ storiesOf('Components/Card/EntryCard', module)
className={text('className', '')}
/>
</div>
))
.add('with auto-sizing', () => (
<div>
<EntryCard
size={select('size', { Auto: 'auto', Default: 'default', Small: 'small' }, 'auto')}
title={text('title', 'Play around with description and thumbnail to see auto-sizing in action')}
description={text('description', '')}
status={select(
'status',
{
Draft: 'draft',
Changed: 'changed',
Published: 'published',
Archived: 'archived',
},
'published',
)}
contentType={text('contentType', 'Album')}
thumbnailElement={
boolean('withThumbnail', false) ? <img
src=""
alt="Joy Division - Closer album cover"
/> : undefined
}
dropdownListElements={
<DropdownList>
<DropdownListItem onClick={action('Edit onClick')}>
Edit
</DropdownListItem>
<DropdownListItem onClick={action('Download onClick')}>
Download
</DropdownListItem>
<DropdownListItem onClick={action('Remove onClick')}>
Remove
</DropdownListItem>
</DropdownList>
}
/>
</div>
));
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,8 @@ import styles from './EntryCard.css';

export type EntryCardStatus = 'archived' | 'changed' | 'draft' | 'published';

export type EntryCardSize = 'default' | 'small' | 'auto';

export type EntryCardPropTypes = BaseCardProps & {
/**
* The title of the entry
Expand Down Expand Up @@ -68,7 +70,7 @@ export type EntryCardPropTypes = BaseCardProps & {
/**
* Changes the height of the component. When small will also ensure thumbnail and description aren't rendered
*/
size: 'default' | 'small';
size: EntryCardSize;
} & typeof defaultProps;

const defaultProps = {
Expand All @@ -84,7 +86,11 @@ export class EntryCard extends Component<EntryCardPropTypes> {
isDropdownOpen: false,
};

renderTitle = (title: string) => {
renderTitle = (size: EntryCardSize, title?: string) => {
if (!title) {
return;
}

const truncatedTitle = truncate(title, 255, {});

return (
Expand All @@ -98,17 +104,25 @@ export class EntryCard extends Component<EntryCardPropTypes> {
);
};

renderDescription = (description: string) => {
renderDescription = (size: EntryCardSize, description?: string) => {
if (!description || size === 'small') {
return;
}

const truncatedDescription = truncate(description, 95, {});

return (
<p className={styles.EntryCard__description}>{truncatedDescription}</p>
);
};

renderThumbnail = (thumbnailElement: React.ReactNode) => (
<figure className={styles.EntryCard__thumbnail}>{thumbnailElement}</figure>
);
renderThumbnail = (size: EntryCardSize, thumbnailElement?: React.ReactNode) => {
if (!thumbnailElement || size === 'small') {
return;
}

return <figure className={styles.EntryCard__thumbnail}>{thumbnailElement}</figure>
};

renderStatus = (status: EntryCardStatus) => {
let label: string;
Expand Down Expand Up @@ -179,9 +193,9 @@ export class EntryCard extends Component<EntryCardPropTypes> {

const classNames = cn(
styles.EntryCard,
styles[`EntryCard--size-${size}`],
{
[styles['EntryCard--drag-active']]: isDragActive,
[styles[`EntryCard--size-${size}`]]: size,
},
className,
);
Expand Down Expand Up @@ -232,14 +246,10 @@ export class EntryCard extends Component<EntryCardPropTypes> {
</div>
<div className={styles.EntryCard__content}>
<div className={styles.EntryCard__body}>
{title && this.renderTitle(title)}
{description &&
size === 'default' &&
this.renderDescription(description)}
{this.renderTitle(size, title)}
{this.renderDescription(size, description)}
</div>
{thumbnailElement &&
size === 'default' &&
this.renderThumbnail(thumbnailElement)}
{this.renderThumbnail(size, thumbnailElement)}
</div>
</React.Fragment>
</article>
Expand Down

0 comments on commit a1f8557

Please sign in to comment.