119 lines
3.4 KiB
Vue
119 lines
3.4 KiB
Vue
<script>
|
|
import $ from 'jquery';
|
|
import { escape } from 'lodash';
|
|
import { GlLoadingIcon, GlIcon } from '@gitlab/ui';
|
|
import { __ } from '~/locale';
|
|
import eventHub from '../eventhub';
|
|
import Api from '../../api';
|
|
import { featureAccessLevel } from '~/pages/projects/shared/permissions/constants';
|
|
import initDeprecatedJQueryDropdown from '~/deprecated_jquery_dropdown';
|
|
|
|
export default {
|
|
name: 'BoardProjectSelect',
|
|
components: {
|
|
GlIcon,
|
|
GlLoadingIcon,
|
|
},
|
|
props: {
|
|
list: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
},
|
|
inject: ['groupId'],
|
|
data() {
|
|
return {
|
|
loading: true,
|
|
selectedProject: {},
|
|
};
|
|
},
|
|
computed: {
|
|
selectedProjectName() {
|
|
return this.selectedProject.name || __('Select a project');
|
|
},
|
|
},
|
|
mounted() {
|
|
initDeprecatedJQueryDropdown($(this.$refs.projectsDropdown), {
|
|
filterable: true,
|
|
filterRemote: true,
|
|
search: {
|
|
fields: ['name_with_namespace'],
|
|
},
|
|
clicked: ({ $el, e }) => {
|
|
e.preventDefault();
|
|
this.selectedProject = {
|
|
id: $el.data('project-id'),
|
|
name: $el.data('project-name'),
|
|
path: $el.data('project-path'),
|
|
};
|
|
eventHub.$emit('setSelectedProject', this.selectedProject);
|
|
},
|
|
selectable: true,
|
|
data: (term, callback) => {
|
|
this.loading = true;
|
|
const additionalAttrs = {};
|
|
|
|
if (this.list.type && this.list.type !== 'backlog') {
|
|
additionalAttrs.min_access_level = featureAccessLevel.EVERYONE;
|
|
}
|
|
|
|
return Api.groupProjects(
|
|
this.groupId,
|
|
term,
|
|
{
|
|
with_issues_enabled: true,
|
|
with_shared: false,
|
|
include_subgroups: true,
|
|
order_by: 'similarity',
|
|
...additionalAttrs,
|
|
},
|
|
projects => {
|
|
this.loading = false;
|
|
callback(projects);
|
|
},
|
|
);
|
|
},
|
|
renderRow(project) {
|
|
return `
|
|
<li>
|
|
<a href='#' class='dropdown-menu-link'
|
|
data-project-id="${project.id}"
|
|
data-project-name="${project.name}"
|
|
data-project-name-with-namespace="${project.name_with_namespace}"
|
|
data-project-path="${project.path_with_namespace}"
|
|
>
|
|
${escape(project.name_with_namespace)}
|
|
</a>
|
|
</li>
|
|
`;
|
|
},
|
|
text: project => project.name_with_namespace,
|
|
});
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<div>
|
|
<label class="label-bold gl-mt-3">{{ __('Project') }}</label>
|
|
<div ref="projectsDropdown" class="dropdown dropdown-projects">
|
|
<button
|
|
class="dropdown-menu-toggle wide"
|
|
type="button"
|
|
data-toggle="dropdown"
|
|
aria-expanded="false"
|
|
>
|
|
{{ selectedProjectName }} <gl-icon name="chevron-down" class="dropdown-menu-toggle-icon" />
|
|
</button>
|
|
<div class="dropdown-menu dropdown-menu-selectable dropdown-menu-full-width">
|
|
<div class="dropdown-title">{{ __('Projects') }}</div>
|
|
<div class="dropdown-input">
|
|
<input class="dropdown-input-field" type="search" :placeholder="__('Search projects')" />
|
|
<gl-icon name="search" class="dropdown-input-search" data-hidden="true" />
|
|
</div>
|
|
<div class="dropdown-content"></div>
|
|
<div class="dropdown-loading"><gl-loading-icon /></div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|