storybook/docs/snippets/vue/button-implementation.vue.mdx
2021-01-13 16:28:43 +00:00

53 lines
857 B
Plaintext

```html
<!-- Button.vue -->
<template>
<!--- the component markup implementation -->
</template>
<script>
export default {
name: "button",
props: {
/**
* Button contents
*/
label: {
type: String,
required: true
},
/**
* Is this the principal call to action on the page?
*/
primary: {
type: Boolean,
default: false
},
/**
* How large should the button be?
*/
size: {
type: String,
default: "medium",
validator: function(value) {
return ["small", "medium", "large"].indexOf(value) !== -1;
}
},
/**
* What background color to use
*/
backgroundColor: {
type: String
}
},
methods: {
/**
* Optional click handler
*/
onClick() {
this.$emit("onClick");
}
}
};
</script>
```