/* * SonarQube * Copyright (C) 2009-2023 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. */ import { sortBy } from 'lodash'; import * as React from 'react'; import { components, OptionProps, SingleValueProps } from 'react-select'; import { Project } from '../../api/project-management'; import withAppStateContext from '../../app/components/app-state/withAppStateContext'; import { Button } from '../../components/controls/buttons'; import Checkbox from '../../components/controls/Checkbox'; import DateInput from '../../components/controls/DateInput'; import HelpTooltip from '../../components/controls/HelpTooltip'; import SearchBox from '../../components/controls/SearchBox'; import Select, { LabelValueSelectOption } from '../../components/controls/Select'; import QualifierIcon from '../../components/icons/QualifierIcon'; import { translate } from '../../helpers/l10n'; import { AppState } from '../../types/appstate'; import { Visibility } from '../../types/component'; import BulkApplyTemplateModal from './BulkApplyTemplateModal'; import DeleteModal from './DeleteModal'; export interface Props { analyzedBefore: Date | undefined; onAllDeselected: () => void; onAllSelected: () => void; onDateChanged: (analyzedBefore: Date | undefined) => void; onDeleteProjects: () => void; onProvisionedChanged: (provisioned: boolean) => void; onQualifierChanged: (qualifier: string) => void; onVisibilityChanged: (qualifier: string) => void; onSearch: (query: string) => void; projects: Project[]; provisioned: boolean; qualifiers: string; query: string; ready: boolean; selection: any[]; appState: AppState; total: number; visibility?: Visibility; } interface State { bulkApplyTemplateModal: boolean; deleteModal: boolean; } const QUALIFIERS_ORDER = ['TRK', 'VW', 'APP']; class Search extends React.PureComponent { state: State = { bulkApplyTemplateModal: false, deleteModal: false }; getQualifierOptions = () => { const options = this.props.appState.qualifiers.map((q) => ({ label: translate('qualifiers', q), value: q, })); return sortBy(options, (option) => QUALIFIERS_ORDER.indexOf(option.value)); }; onCheck = (checked: boolean) => { if (checked) { this.props.onAllSelected(); } else { this.props.onAllDeselected(); } }; handleDeleteClick = () => { this.setState({ deleteModal: true }); }; closeDeleteModal = () => { this.setState({ deleteModal: false }); }; handleDeleteConfirm = () => { this.closeDeleteModal(); this.props.onDeleteProjects(); }; handleBulkApplyTemplateClick = () => { this.setState({ bulkApplyTemplateModal: true }); }; closeBulkApplyTemplateModal = () => { this.setState({ bulkApplyTemplateModal: false }); }; handleQualifierChange = ({ value }: LabelValueSelectOption) => this.props.onQualifierChanged(value); handleVisibilityChange = ({ value }: LabelValueSelectOption) => this.props.onVisibilityChanged(value); optionRenderer = (props: OptionProps) => ( {this.renderQualifierOption(props.data)} ); singleValueRenderer = (props: SingleValueProps) => ( {this.renderQualifierOption(props.data)} ); renderCheckbox = () => { const isAllChecked = this.props.projects.length > 0 && this.props.selection.length === this.props.projects.length; const thirdState = this.props.projects.length > 0 && this.props.selection.length > 0 && this.props.selection.length < this.props.projects.length; const checked = isAllChecked || thirdState; return ( ); }; renderQualifierOption = (option: LabelValueSelectOption) => (
{option.label}
); renderQualifierFilter = () => { const options = this.getQualifierOptions(); if (options.length < 2) { return null; } return ( option.value === (this.props.visibility || 'all'))} /> ); }; renderTypeFilter = () => this.props.qualifiers === 'TRK' ? (
{translate('provisioning.only_provisioned')}
) : null; renderDateFilter = () => { return ( ); }; render() { return (
{this.props.ready ? this.renderCheckbox() : }
{this.renderQualifierFilter()} {this.renderDateFilter()} {this.renderVisibilityFilter()} {this.renderTypeFilter()}
{this.props.qualifiers === 'TRK' && ( )}
{this.state.bulkApplyTemplateModal && ( )} {this.state.deleteModal && ( )}
); } } export default withAppStateContext(Search);