sba-icon-button.vue 1.58 KB
Newer Older
Johannes Edmeier committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
<!--
  - Copyright 2014-2018 the original author or authors.
  -
  - Licensed under the Apache License, Version 2.0 (the "License");
  - you may not use this file except in compliance with the License.
  - You may obtain a copy of the License at
  -
  -     http://www.apache.org/licenses/LICENSE-2.0
  -
  - Unless required by applicable law or agreed to in writing, software
  - distributed under the License is distributed on an "AS IS" BASIS,
  - WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  - See the License for the specific language governing permissions and
  - limitations under the License.
  -->

<template>
18 19 20
  <button type="button" class="icon-button" :disabled="disabled">
    <font-awesome-icon :icon="icon" :size="size" :class="iconClass"/>
  </button>
Johannes Edmeier committed
21 22 23 24
</template>

<script>
  export default {
25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42
    props: {
      disabled: {
        type: Boolean,
        default: false,
      },
      icon: {
        type: [String, Array],
        required: true,
      },
      size: {
        type: String,
        default: null
      },
      iconClass: {
        type: String,
        default: null
      }
    }
Johannes Edmeier committed
43 44 45 46
  }
</script>

<style lang="scss">
47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65
  @import "~@/assets/css/utilities";

  .icon-button {
    background: none;
    border: none;
    padding: 0;
    font-size: 1em;
    color: inherit;

    &:not([disabled]) {
      cursor: pointer;

      &:hover {
        color: $black;
      }

      & svg {
        fill: currentcolor;
      }
Johannes Edmeier committed
66
    }
67 68 69 70 71 72 73 74 75 76 77

    &:disabled {
      opacity: 0.5;
      pointer-events: none;
    }

    &:active {
      outline: none;
    }
  }
</style>