material-web/labs/card/demo/stories.ts
Elizabeth Mitchell 1e47fd7383 fix(typography): rename md-typescale.js to md-typescale-styles.js
Fixes #5524

This fixes the new md-typescale file not being published. Our build assumes CSS-to-JS files end in "-styles".

This isn't a breaking change since the typescale classes haven't been published yet.

PiperOrigin-RevId: 617613456
2024-03-20 13:43:26 -07:00

115 lines
6.1 KiB
TypeScript

/**
* @license
* Copyright 2023 Google LLC
* SPDX-License-Identifier: Apache-2.0
*/
import '@material/web/button/filled-button.js';
import '@material/web/labs/card/elevated-card.js';
import '@material/web/labs/card/filled-card.js';
import '@material/web/labs/card/outlined-card.js';
import {MaterialStoryInit} from './material-collection.js';
import {styles as typescaleStyles} from '@material/web/typography/md-typescale-styles.js';
import {css, html} from 'lit';
/** Knob types for card stories. */
export interface StoryKnobs {}
const MEDIA_IMAGE =
'';
const styles = [
typescaleStyles,
css`
.container {
display: flex;
flex-wrap: wrap;
gap: 8px;
color: var(--md-sys-color-on-surface);
}
.card {
width: 192px;
}
img {
border-radius: inherit;
background: #dadce0;
object-fit: contain;
height: 128px;
}
.content {
display: flex;
flex-direction: column;
flex: 1;
justify-content: space-between;
padding: 16px;
gap: 16px;
}
`,
];
const cards: MaterialStoryInit<StoryKnobs> = {
name: 'Cards',
styles,
render() {
return html`
<div class="container md-typescale-body-medium">
<md-elevated-card class="card">
<img src=${MEDIA_IMAGE} alt="Placeholder image" />
<div class="content">A static elevated card</div>
</md-elevated-card>
<md-filled-card class="card">
<img src=${MEDIA_IMAGE} alt="Placeholder image" />
<div class="content">A static filled card</div>
</md-filled-card>
<md-outlined-card class="card">
<img src=${MEDIA_IMAGE} alt="Placeholder image" />
<div class="content">A static outlined card</div>
</md-outlined-card>
</div>
`;
},
};
const withActions: MaterialStoryInit<StoryKnobs> = {
name: 'Cards with actions',
styles,
render() {
return html`
<div class="container md-typescale-body-medium">
<md-elevated-card class="card">
<img src=${MEDIA_IMAGE} alt="Placeholder image" />
<div class="content">
An elevated card with actions
<md-filled-button>Card action</md-filled-button>
</div>
</md-elevated-card>
<md-filled-card class="card">
<img src=${MEDIA_IMAGE} alt="Placeholder image" />
<div class="content">
A filled card with actions
<md-filled-button>Card action</md-filled-button>
</div>
</md-filled-card>
<md-outlined-card class="card">
<img src=${MEDIA_IMAGE} alt="Placeholder image" />
<div class="content">
An outlined card with actions
<md-filled-button>Card action</md-filled-button>
</div>
</md-outlined-card>
</div>
`;
},
};
/** Card stories. */
export const stories = [cards, withActions];