MenuButton.vue 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <template>
  2. <menu-tooltip
  3. v-model='menuOpen'
  4. top='0'
  5. width='10rem'
  6. touch-disabled='true'
  7. >
  8. <div class='menu_button__icon' @click='menuOpen = true' slot='button'>
  9. <slot></slot>
  10. </div>
  11. <template slot='menu'>
  12. <div
  13. class='menu_button__option'
  14. v-for='(option, $index) in options'
  15. @click='emit(option.event)'
  16. :style="{ 'border-bottom' : $index === options.length-1 ? 'none' : 'solid thin rgb(245, 245, 245)' }"
  17. >
  18. {{option.value}}
  19. </div>
  20. </template>
  21. </menu-tooltip>
  22. </template>
  23. <script>
  24. import MenuTooltip from './MenuTooltip';
  25. export default {
  26. name: 'MenuButton',
  27. props: ['options'],
  28. components: {
  29. MenuTooltip
  30. },
  31. data () {
  32. return {
  33. menuOpen: false
  34. }
  35. },
  36. methods: {
  37. emit (option) {
  38. this.$emit(option)
  39. this.menuOpen = false;
  40. }
  41. }
  42. }
  43. </script>
  44. <style lang='scss' scoped>
  45. @import '../assets/scss/variables.scss';
  46. .menu_button {
  47. @at-root #{&}__option {
  48. border-radius: 0.25rem;
  49. cursor: default;
  50. font-size: 0.9rem;
  51. padding: 0.5rem;
  52. transition: all 0.2s;
  53. &:hover { background-color: $color__lightgray--primary; }
  54. &:active { background-color: $color__lightgray--darker; }
  55. }
  56. }
  57. @media (max-width: 420px) {
  58. .menu_button {
  59. @at-root #{&}__option {
  60. padding: 0.75rem;
  61. font-size: 1.125rem;
  62. }
  63. }
  64. }
  65. </style>