MenuButton.vue 1.3 KB

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