All files / components BaseButton.vue

0% Statements 0/4
0% Branches 0/4
0% Functions 0/2
0% Lines 0/4

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77                                                                                                                                                         
<template>
  <tag
    :is="tagName"
    @click="handleClick"
    :class="{ '--base-button': true, dangerous, small, clicked }"
  >
    <slot></slot>
  </tag>
</template>
 
<script>
import { isURL } from '~/utils/validators'
 
export default {
  props: {
    dangerous: {
      type: Boolean,
      default: false,
    },
    small: {
      type: Boolean,
      default: false,
    },
    href: {
      type: String,
      default: null,
      validator: isURL,
    },
  },
  computed: {
    tagName() {
      return this.href ? 'a' : 'button'
    },
  },
  methods: {
    handleClick() {
      if (!this.href) {
        this.$emit('click')
      }
    },
  },
}
</script>
 
<style lang="stylus" scoped>
//
//Definitions
//
 
//
//Positioning
//
 
//
//Sizing
//
 
//
//Spacing
//
 
//
//Decoration
//
.--base-button::-moz-focus-inner
  border 0
 
.--base-button
  outline 0
 
//
//States
//
[disabled]
  cursor not-allowed
</style>