/* * SonarQube * Copyright (C) 2009-2018 SonarSource SA * mailto:info 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. */ // @flow import React from 'react'; import { sortBy, without } from 'lodash'; import FacetBox from '../../../components/facet/FacetBox'; import FacetHeader from '../../../components/facet/FacetHeader'; import FacetItem from '../../../components/facet/FacetItem'; import FacetItemsList from '../../../components/facet/FacetItemsList'; import QualifierIcon from '../../../components/shared/QualifierIcon'; import { translate } from '../../../helpers/l10n'; import { collapsePath } from '../../../helpers/path'; import { formatFacetStat } from '../utils'; /*:: import type { ReferencedComponent } from '../utils'; */ /*:: type Props = {| facetMode: string, onChange: (changes: { [string]: Array }) => void, onToggle: (property: string) => void, open: boolean, stats?: { [string]: number }, referencedComponents: { [string]: ReferencedComponent }, directories: Array |}; */ export default class DirectoryFacet extends React.PureComponent { /*:: props: Props; */ static defaultProps = { open: true }; property = 'directories'; handleItemClick = (itemValue /*: string */) => { const { directories } = this.props; const newValue = sortBy( directories.includes(itemValue) ? without(directories, itemValue) : [...directories, itemValue] ); this.props.onChange({ [this.property]: newValue }); }; handleHeaderClick = () => { this.props.onToggle(this.property); }; handleClear = () => { this.props.onChange({ [this.property]: [] }); }; getStat(directory /*: string */) /*: ?number */ { const { stats } = this.props; return stats ? stats[directory] : null; } renderName(directory /*: string */) /*: React.Element<*> | string */ { return ( {directory} ); } renderList() { const { stats } = this.props; if (!stats) { return null; } const directories = sortBy(Object.keys(stats), key => -stats[key]); return ( {directories.map(directory => ( ))} ); } render() { const values = this.props.directories.map(dir => collapsePath(dir)); return ( {this.props.open && this.renderList()} ); } }