All files / app/assets/javascripts/boards/components board_add_new_column_trigger.vue

100% Statements 9/9
100% Branches 4/4
100% Functions 4/4
100% Lines 9/9

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  1x 1x 1x 1x                     4x   4x           1x 1x           15x                        
<script>
import { GlButton, GlTooltipDirective } from '@gitlab/ui';
import { mapActions, mapState } from 'vuex';
import { __ } from '~/locale';
import Tracking from '~/tracking';
 
export default {
  components: {
    GlButton,
  },
  directives: {
    GlTooltip: GlTooltipDirective,
  },
  mixins: [Tracking.mixin()],
  computed: {
    ...mapState({ isNewListShowing: ({ addColumnForm }) => addColumnForm.visible }),
    tooltip() {
      return this.isNewListShowing ? __('The list creation wizard is already open') : '';
    },
  },
  methods: {
    ...mapActions(['setAddColumnFormVisibility']),
    handleClick() {
      this.setAddColumnFormVisibility(true);
      this.track('click_button', { label: 'create_list' });
    },
  },
};
</script>
 
<template>
  <div
    v-gl-tooltip="tooltip"
    :tabindex="isNewListShowing ? '0' : undefined"
    class="gl-ml-3 gl-display-flex gl-align-items-center"
    data-testid="boards-create-list"
  >
    <gl-button :disabled="isNewListShowing" variant="confirm" @click="handleClick"
      >{{ __('Create list') }}
    </gl-button>
  </div>
</template>