/* * SonarQube :: Web * Copyright (C) 2009-2016 SonarSource SA * mailto:contact AT sonarsource DOT com * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 3 of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this program; if not, write to the Free Software Foundation, * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ import _ from 'underscore'; import React from 'react'; import Header from './header'; import Search from './search'; import Projects from './projects'; import { PAGE_SIZE, TYPE } from './constants'; import { getComponents, getProvisioned, getGhosts, deleteComponents } from '../../api/components'; import ListFooter from '../../components/shared/list-footer'; export default React.createClass({ propTypes: { hasProvisionPermission: React.PropTypes.bool.isRequired, topLevelQualifiers: React.PropTypes.array.isRequired }, getInitialState() { return { ready: false, projects: [], total: 0, page: 1, query: '', qualifiers: 'TRK', type: TYPE.ALL, selection: [] }; }, componentWillMount: function () { this.requestProjects = _.debounce(this.requestProjects, 250); }, componentDidMount() { this.requestProjects(); }, getFilters() { let filters = { ps: PAGE_SIZE }; if (this.state.page !== 1) { filters.p = this.state.page; } if (this.state.query) { filters.q = this.state.query; } return filters; }, requestProjects() { switch (this.state.type) { case TYPE.ALL: this.requestAllProjects(); break; case TYPE.PROVISIONED: this.requestProvisioned(); break; case TYPE.GHOSTS: this.requestGhosts(); break; default: // should never happen } }, requestGhosts() { let data = this.getFilters(); getGhosts(data).then(r => { let projects = r.projects.map(project => { return _.extend(project, { id: project.uuid, qualifier: 'TRK' }); }); if (this.state.page > 1) { projects = [].concat(this.state.projects, projects); } this.setState({ ready: true, projects: projects, total: r.total }); }); }, requestProvisioned() { let data = this.getFilters(); getProvisioned(data).then(r => { let projects = r.projects.map(project => { return _.extend(project, { id: project.uuid, qualifier: 'TRK' }); }); if (this.state.page > 1) { projects = [].concat(this.state.projects, projects); } this.setState({ ready: true, projects: projects, total: r.total }); }); }, requestAllProjects() { let data = this.getFilters(); data.qualifiers = this.state.qualifiers; getComponents(data).then(r => { let projects = r.components; if (this.state.page > 1) { projects = [].concat(this.state.projects, projects); } this.setState({ ready: true, projects: projects, total: r.paging.total }); }); }, loadMore() { this.setState({ ready: false, page: this.state.page + 1 }, this.requestProjects); }, onSearch(query) { this.setState({ ready: false, page: 1, query, selection: [] }, this.requestProjects); }, onTypeChanged(newType) { this.setState({ ready: false, page: 1, query: '', type: newType, qualifiers: 'TRK', selection: [] }, this.requestProjects); }, onQualifierChanged(newQualifier) { this.setState({ ready: false, page: 1, query: '', type: TYPE.ALL, qualifiers: newQualifier, selection: [] }, this.requestProjects); }, onProjectSelected(project) { let newSelection = _.uniq([].concat(this.state.selection, project.id)); this.setState({ selection: newSelection }); }, onProjectDeselected(project) { let newSelection = _.without(this.state.selection, project.id); this.setState({ selection: newSelection }); }, onAllSelected() { let newSelection = this.state.projects.map(project => { return project.id; }); this.setState({ selection: newSelection }); }, onAllDeselected() { this.setState({ selection: [] }); }, deleteProjects() { let ids = this.state.selection.join(','); deleteComponents({ ids }).then(() => { this.setState({ page: 1, selection: [] }, this.requestProjects); }); }, render() { return (