/* * SonarQube * Copyright (C) 2009-2024 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 { Button } from '@sonarsource/echoes-react'; import { InputSearch } from 'design-system'; import * as React from 'react'; import { translate } from '../../../helpers/l10n'; import { DEFAULT_FILTERS } from '../constants'; import { Query } from '../utils'; import CurrentsFilter from './CurrentsFilter'; import DateFilter from './DateFilter'; import StatusFilter from './StatusFilter'; import TypesFilter from './TypesFilter'; interface Props { component?: unknown; currents: string; loading: boolean; maxExecutedAt: Date | undefined; minSubmittedAt: Date | undefined; onFilterUpdate: (changes: Partial) => void; onReload: () => void; query: string; status: string; taskType: string; types: string[]; } export default class Search extends React.PureComponent { handleStatusChange = (status: string) => { this.props.onFilterUpdate({ status }); }; handleTypeChange = (taskType: string) => { this.props.onFilterUpdate({ taskType }); }; handleCurrentsChange = (currents: string) => { this.props.onFilterUpdate({ currents }); }; handleDateChange = (date: { maxExecutedAt?: Date; minSubmittedAt?: Date }) => { this.props.onFilterUpdate(date); }; handleQueryChange = (query: string) => { this.props.onFilterUpdate({ query }); }; handleReload = () => { this.props.onReload(); }; handleReset = () => { this.props.onFilterUpdate(DEFAULT_FILTERS); }; render() { const { loading, component, query, types, status, taskType, currents, minSubmittedAt, maxExecutedAt, } = this.props; return (
  • {types.length > 1 && (
  • )} {!component && (
  • )}
  • {!component && (
  • )}
); } }