import { useContext } from 'react'; import { useMessages, useFormat, useFilters, useFields } from 'components/hooks'; import Icons from 'components/icons'; import { Button, FormRow, Icon, Popup, PopupTrigger } from 'react-basics'; import FilterSelectForm from '../[reportId]/FilterSelectForm'; import ParameterList from '../[reportId]/ParameterList'; import PopupForm from '../[reportId]/PopupForm'; import { ReportContext } from './Report'; import { OPERATORS } from 'lib/constants'; import FieldFilterEditForm from '../[reportId]/FieldFilterEditForm'; import styles from './FilterParameters.module.css'; export function FilterParameters() { const { report, updateReport } = useContext(ReportContext); const { formatMessage, labels } = useMessages(); const { formatValue } = useFormat(); const { parameters } = report || {}; const { websiteId, filters, dateRange } = parameters || {}; const { fields } = useFields(); const handleAdd = (value: { name: any }) => { if (!filters.find(({ name }) => name === value.name)) { updateReport({ parameters: { filters: filters.concat(value) } }); } }; const handleRemove = (name: string) => { updateReport({ parameters: { filters: filters.filter(f => f.name !== name) } }); }; const handleChange = (close: () => void, filter: { name: any }) => { updateReport({ parameters: { filters: filters.map(f => { if (filter.name === f.name) { return filter; } return f; }), }, }); close(); }; const AddButton = () => { return ( !filters.find(f => f.name === name))} onChange={handleAdd} /> ); }; return ( }> {filters.map( ({ name, operator, value }: { name: string; operator: string; value: string }) => { const label = fields.find(f => f.name === name)?.label; const isEquals = [OPERATORS.equals, OPERATORS.notEquals].includes(operator as any); return ( handleRemove(name)}> ); }, )} ); } const FilterParameter = ({ websiteId, name, label, operator, value, type = 'string', startDate, endDate, onChange, }) => { const { filterLabels } = useFilters(); return (
{label}
{filterLabels[operator]}
{value}
{(close: any) => ( )}
); }; export default FilterParameters;