import { Component, Input, Output, EventEmitter } from '@angular/core'; @Component({ // Needs to be a different name to the CLI template button selector: 'storybook-framework-button', template: ` `, styleUrls: ['./button.css'], }) export default class FrameworkButtonComponent { /** * Is this the principal call to action on the page? */ @Input() primary = false; /** * What background color to use */ @Input() backgroundColor?: string; /** * How large should the button be? */ @Input() size: 'small' | 'medium' | 'large' = 'medium'; /** * Button contents * * @required */ @Input() label = 'Button'; /** * Optional click handler */ @Output() onClick = new EventEmitter(); public get classes(): string[] { const mode = this.primary ? 'storybook-button--primary' : 'storybook-button--secondary'; return ['storybook-button', `storybook-button--${this.size}`, mode]; } }