// Copyright (C) The Arvados Authors. All rights reserved. // // SPDX-License-Identifier: AGPL-3.0 import React from "react"; import { Field, FieldArray } from 'redux-form'; import { TextField, DateTextField } from "components/text-field/text-field"; import { CheckboxField } from 'components/checkbox-field/checkbox-field'; import { NativeSelectField } from 'components/select-field/select-field'; import { ResourceKind } from 'models/resource'; import { SearchBarAdvancedPropertiesView } from 'views-components/search-bar/search-bar-advanced-properties-view'; import { PropertyKeyField, } from 'views-components/resource-properties-form/property-key-field'; import { PropertyValueField } from 'views-components/resource-properties-form/property-value-field'; import { connect } from "react-redux"; import { RootState } from "store/store"; import { ProjectInput, ProjectCommandInputParameter } from 'views/run-process-panel/inputs/project-input'; export const SearchBarTypeField = () => <Field name='type' component={NativeSelectField as any} items={[ { key: '', value: 'Any' }, { key: ResourceKind.COLLECTION, value: 'Collection' }, { key: ResourceKind.PROJECT, value: 'Project' }, { key: ResourceKind.PROCESS, value: 'Process' } ]} />; interface SearchBarClusterFieldProps { clusters: { key: string, value: string }[]; } export const SearchBarClusterField = connect( (state: RootState) => ({ clusters: [{ key: '', value: 'Any' }].concat( state.auth.sessions .filter(s => s.loggedIn) .map(s => ({ key: s.clusterId, value: s.clusterId }))) }))((props: SearchBarClusterFieldProps) => <Field name='cluster' component={NativeSelectField as any} items={props.clusters} /> ); export const SearchBarProjectField = () => <ProjectInput required={false} input={{ id: "projectObject", label: "Limit search to Project" } as ProjectCommandInputParameter} options={{ showOnlyOwned: false, showOnlyWritable: false }} /> export const SearchBarTrashField = () => <Field name='inTrash' component={CheckboxField} label="In trash" />; export const SearchBarPastVersionsField = () => <Field name='pastVersions' component={CheckboxField} label="Past versions" />; export const SearchBarDateFromField = () => <Field name='dateFrom' component={DateTextField as any} />; export const SearchBarDateToField = () => <Field name='dateTo' component={DateTextField as any} />; export const SearchBarPropertiesField = () => <FieldArray name="properties" component={SearchBarAdvancedPropertiesView as any} />; export const SearchBarKeyField = () => <PropertyKeyField skipValidation={true} />; export const SearchBarValueField = () => <PropertyValueField skipValidation={true} />; export const SearchBarSaveSearchField = () => <Field name='saveQuery' component={CheckboxField} label="Save query" />; export const SearchBarQuerySearchField = () => <Field name='queryName' component={TextField as any} label="Query name" />;