Commit 91bc422c authored by Jose Ivan Vargas's avatar Jose Ivan Vargas

Merge branch...

Merge branch 'Replace-GlDeprecatedDropdown-with-GlDropdown-in-app/assets/javascripts/boards' into 'master'

GlDeprecatedDropdown to GlDropdown in app/assets/javascripts/boards

See merge request gitlab-org/gitlab!41410
parents e706ff7c be1c077c
...@@ -3,10 +3,10 @@ import { throttle } from 'lodash'; ...@@ -3,10 +3,10 @@ import { throttle } from 'lodash';
import { import {
GlLoadingIcon, GlLoadingIcon,
GlSearchBoxByType, GlSearchBoxByType,
GlDeprecatedDropdown, GlDropdown,
GlDeprecatedDropdownDivider, GlDropdownDivider,
GlDeprecatedDropdownHeader, GlDropdownSectionHeader,
GlDeprecatedDropdownItem, GlDropdownItem,
} from '@gitlab/ui'; } from '@gitlab/ui';
import httpStatusCodes from '~/lib/utils/http_status'; import httpStatusCodes from '~/lib/utils/http_status';
...@@ -26,10 +26,10 @@ export default { ...@@ -26,10 +26,10 @@ export default {
BoardForm, BoardForm,
GlLoadingIcon, GlLoadingIcon,
GlSearchBoxByType, GlSearchBoxByType,
GlDeprecatedDropdown, GlDropdown,
GlDeprecatedDropdownDivider, GlDropdownDivider,
GlDeprecatedDropdownHeader, GlDropdownSectionHeader,
GlDeprecatedDropdownItem, GlDropdownItem,
}, },
props: { props: {
currentBoard: { currentBoard: {
...@@ -235,22 +235,17 @@ export default { ...@@ -235,22 +235,17 @@ export default {
<template> <template>
<div class="boards-switcher js-boards-selector gl-mr-3"> <div class="boards-switcher js-boards-selector gl-mr-3">
<span class="boards-selector-wrapper js-boards-selector-wrapper"> <span class="boards-selector-wrapper js-boards-selector-wrapper">
<gl-deprecated-dropdown <gl-dropdown
data-qa-selector="boards_dropdown" data-qa-selector="boards_dropdown"
toggle-class="dropdown-menu-toggle js-dropdown-toggle" toggle-class="dropdown-menu-toggle js-dropdown-toggle"
menu-class="flex-column dropdown-extended-height" menu-class="flex-column dropdown-extended-height"
:text="board.name" :text="board.name"
@show="loadBoards" @show="loadBoards"
> >
<div> <p class="gl-new-dropdown-header-top" @mousedown.prevent>
<div class="dropdown-title mb-0" @mousedown.prevent> {{ s__('IssueBoards|Switch board') }}
{{ s__('IssueBoards|Switch board') }} </p>
</div> <gl-search-box-by-type ref="searchBox" v-model="filterTerm" class="m-2" />
</div>
<gl-deprecated-dropdown-header class="mt-0">
<gl-search-box-by-type ref="searchBox" v-model="filterTerm" />
</gl-deprecated-dropdown-header>
<div <div
v-if="!loading" v-if="!loading"
...@@ -259,49 +254,50 @@ export default { ...@@ -259,49 +254,50 @@ export default {
class="dropdown-content flex-fill" class="dropdown-content flex-fill"
@scroll.passive="throttledSetScrollFade" @scroll.passive="throttledSetScrollFade"
> >
<gl-deprecated-dropdown-item <gl-dropdown-item
v-show="filteredBoards.length === 0" v-show="filteredBoards.length === 0"
class="gl-pointer-events-none text-secondary" class="gl-pointer-events-none text-secondary"
> >
{{ s__('IssueBoards|No matching boards found') }} {{ s__('IssueBoards|No matching boards found') }}
</gl-deprecated-dropdown-item> </gl-dropdown-item>
<h6 v-if="showRecentSection" class="dropdown-bold-header my-0"> <gl-dropdown-section-header v-if="showRecentSection">
{{ __('Recent') }} {{ __('Recent') }}
</h6> </gl-dropdown-section-header>
<template v-if="showRecentSection"> <template v-if="showRecentSection">
<gl-deprecated-dropdown-item <gl-dropdown-item
v-for="recentBoard in recentBoards" v-for="recentBoard in recentBoards"
:key="`recent-${recentBoard.id}`" :key="`recent-${recentBoard.id}`"
class="js-dropdown-item" class="js-dropdown-item"
:href="`${boardBaseUrl}/${recentBoard.id}`" :href="`${boardBaseUrl}/${recentBoard.id}`"
> >
{{ recentBoard.name }} {{ recentBoard.name }}
</gl-deprecated-dropdown-item> </gl-dropdown-item>
</template> </template>
<hr v-if="showRecentSection" class="my-1" /> <gl-dropdown-divider v-if="showRecentSection" />
<h6 v-if="showRecentSection" class="dropdown-bold-header my-0"> <gl-dropdown-section-header v-if="showRecentSection">
{{ __('All') }} {{ __('All') }}
</h6> </gl-dropdown-section-header>
<gl-deprecated-dropdown-item <gl-dropdown-item
v-for="otherBoard in filteredBoards" v-for="otherBoard in filteredBoards"
:key="otherBoard.id" :key="otherBoard.id"
class="js-dropdown-item" class="js-dropdown-item"
:href="`${boardBaseUrl}/${otherBoard.id}`" :href="`${boardBaseUrl}/${otherBoard.id}`"
> >
{{ otherBoard.name }} {{ otherBoard.name }}
</gl-deprecated-dropdown-item> </gl-dropdown-item>
<gl-deprecated-dropdown-item v-if="hasMissingBoards" class="small unclickable">
<gl-dropdown-item v-if="hasMissingBoards" class="no-pointer-events">
{{ {{
s__( s__(
'IssueBoards|Some of your boards are hidden, activate a license to see them again.', 'IssueBoards|Some of your boards are hidden, activate a license to see them again.',
) )
}} }}
</gl-deprecated-dropdown-item> </gl-dropdown-item>
</div> </div>
<div <div
...@@ -313,25 +309,25 @@ export default { ...@@ -313,25 +309,25 @@ export default {
<gl-loading-icon v-if="loading" /> <gl-loading-icon v-if="loading" />
<div v-if="canAdminBoard"> <div v-if="canAdminBoard">
<gl-deprecated-dropdown-divider /> <gl-dropdown-divider />
<gl-deprecated-dropdown-item <gl-dropdown-item
v-if="multipleIssueBoardsAvailable" v-if="multipleIssueBoardsAvailable"
data-qa-selector="create_new_board_button" data-qa-selector="create_new_board_button"
@click.prevent="showPage('new')" @click.prevent="showPage('new')"
> >
{{ s__('IssueBoards|Create new board') }} {{ s__('IssueBoards|Create new board') }}
</gl-deprecated-dropdown-item> </gl-dropdown-item>
<gl-deprecated-dropdown-item <gl-dropdown-item
v-if="showDelete" v-if="showDelete"
class="text-danger js-delete-board" class="text-danger js-delete-board"
@click.prevent="showPage('delete')" @click.prevent="showPage('delete')"
> >
{{ s__('IssueBoards|Delete board') }} {{ s__('IssueBoards|Delete board') }}
</gl-deprecated-dropdown-item> </gl-dropdown-item>
</div> </div>
</gl-deprecated-dropdown> </gl-dropdown>
<board-form <board-form
v-if="currentPage" v-if="currentPage"
......
---
title: Replace-GlDeprecatedDropdown-with-GlDropdown-in-app/assets/javascripts/boards
merge_request: 41410
author: nuwe1
type: other
<script> <script>
import { GlButton, GlDeprecatedDropdown, GlDeprecatedDropdownItem } from '@gitlab/ui'; import { GlButton, GlDropdown, GlDropdownItem } from '@gitlab/ui';
const ANY_WEIGHT = 'Any weight'; const ANY_WEIGHT = 'Any weight';
const NO_WEIGHT = 'None'; const NO_WEIGHT = 'None';
...@@ -7,8 +7,8 @@ const NO_WEIGHT = 'None'; ...@@ -7,8 +7,8 @@ const NO_WEIGHT = 'None';
export default { export default {
components: { components: {
GlButton, GlButton,
GlDeprecatedDropdown, GlDropdown,
GlDeprecatedDropdownItem, GlDropdownItem,
}, },
props: { props: {
board: { board: {
...@@ -49,17 +49,15 @@ export default { ...@@ -49,17 +49,15 @@ export default {
this.dropdownHidden = false; this.dropdownHidden = false;
this.$refs.dropdown.$children[0].show(); this.$refs.dropdown.$children[0].show();
}, },
selectWeight({ target: { value: weight } }) { selectWeight(weight) {
this.board.weight = this.weightInt(weight); this.board.weight = this.weightInt(weight);
this.dropdownHidden = true; this.dropdownHidden = true;
}, },
weightInt(weight) { weightInt(weight) {
if (weight > 0) { if (weight >= 0) {
return parseInt(weight, 10); return weight;
} else if (weight === NO_WEIGHT) { } else if (weight === NO_WEIGHT) {
return -2; return -2;
} else if (weight === '0') {
return 0;
} }
return -1; return -1;
}, },
...@@ -77,19 +75,21 @@ export default { ...@@ -77,19 +75,21 @@ export default {
</div> </div>
<div :class="valueClass" :hidden="!dropdownHidden" class="value">{{ valueText }}</div> <div :class="valueClass" :hidden="!dropdownHidden" class="value">{{ valueText }}</div>
<gl-deprecated-dropdown <gl-dropdown
ref="dropdown" ref="dropdown"
:hidden="dropdownHidden" :hidden="dropdownHidden"
:text="valueText" :text="valueText"
class="w-100" block
menu-class="w-100"
toggle-class="d-flex justify-content-between" toggle-class="d-flex justify-content-between"
> >
<div ref="weight-select" @click="selectWeight"> <gl-dropdown-item
<gl-deprecated-dropdown-item v-for="weight in weights" :key="weight" :value="weight"> v-for="weight in weights"
{{ weight }} :key="weight"
</gl-deprecated-dropdown-item> :value="weight"
</div> @click="selectWeight(weight)"
</gl-deprecated-dropdown> >
{{ weight }}
</gl-dropdown-item>
</gl-dropdown>
</div> </div>
</template> </template>
import { GlButton, GlDeprecatedDropdown } from '@gitlab/ui';
import { mount } from '@vue/test-utils'; import { mount } from '@vue/test-utils';
import WeightSelect from 'ee/boards/components/weight_select.vue'; import WeightSelect from 'ee/boards/components/weight_select.vue';
import { GlButton, GlDropdown, GlDropdownItem } from '@gitlab/ui';
describe('WeightSelect', () => { describe('WeightSelect', () => {
let wrapper; let wrapper;
const editButton = () => wrapper.find(GlButton); const editButton = () => wrapper.find(GlButton);
const valueContainer = () => wrapper.find('.value'); const valueContainer = () => wrapper.find('.value');
const weightDropdown = () => wrapper.find(GlDeprecatedDropdown); const weightDropdown = () => wrapper.find(GlDropdown);
const weightSelect = () => wrapper.find({ ref: 'weight-select' }); const getWeightItemAtIndex = index =>
weightDropdown()
.findAll(GlDropdownItem)
.at(index);
const defaultProps = { const defaultProps = {
weights: ['Any', 'None', 0, 1, 2, 3], weights: ['Any', 'None', 0, 1, 2, 3],
board: { board: {
...@@ -81,15 +83,16 @@ describe('WeightSelect', () => { ...@@ -81,15 +83,16 @@ describe('WeightSelect', () => {
describe('and a weight has been selected', () => { describe('and a weight has been selected', () => {
beforeEach(() => { beforeEach(() => {
weightSelect().trigger('click'); editButton().trigger('click');
getWeightItemAtIndex(0).vm.$emit('click');
}); });
it('shows the value text', () => { it('shows the value text', () => {
expect(valueContainer().isVisible()).toBeTruthy(); expect(valueContainer().isVisible()).toBe(true);
}); });
it('hides the weight dropdown', () => { it('hides the weight dropdown', () => {
expect(weightDropdown().isVisible()).toBeFalsy(); expect(weightDropdown().isVisible()).toBe(false);
}); });
}); });
}); });
......
import { nextTick } from 'vue'; import { nextTick } from 'vue';
import { mount } from '@vue/test-utils'; import { mount } from '@vue/test-utils';
import { GlDeprecatedDropdown, GlLoadingIcon } from '@gitlab/ui'; import { GlDropdown, GlLoadingIcon, GlDropdownSectionHeader } from '@gitlab/ui';
import { TEST_HOST } from 'spec/test_constants'; import { TEST_HOST } from 'spec/test_constants';
import BoardsSelector from '~/boards/components/boards_selector.vue'; import BoardsSelector from '~/boards/components/boards_selector.vue';
import boardsStore from '~/boards/stores/boards_store'; import boardsStore from '~/boards/stores/boards_store';
...@@ -34,8 +34,9 @@ describe('BoardsSelector', () => { ...@@ -34,8 +34,9 @@ describe('BoardsSelector', () => {
}; };
const getDropdownItems = () => wrapper.findAll('.js-dropdown-item'); const getDropdownItems = () => wrapper.findAll('.js-dropdown-item');
const getDropdownHeaders = () => wrapper.findAll('.dropdown-bold-header'); const getDropdownHeaders = () => wrapper.findAll(GlDropdownSectionHeader);
const getLoadingIcon = () => wrapper.find(GlLoadingIcon); const getLoadingIcon = () => wrapper.find(GlLoadingIcon);
const findDropdown = () => wrapper.find(GlDropdown);
beforeEach(() => { beforeEach(() => {
const $apollo = { const $apollo = {
...@@ -103,7 +104,7 @@ describe('BoardsSelector', () => { ...@@ -103,7 +104,7 @@ describe('BoardsSelector', () => {
}); });
// Emits gl-dropdown show event to simulate the dropdown is opened at initialization time // Emits gl-dropdown show event to simulate the dropdown is opened at initialization time
wrapper.find(GlDeprecatedDropdown).vm.$emit('show'); findDropdown().vm.$emit('show');
}); });
afterEach(() => { afterEach(() => {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment