2019-08-14 16:54:31 -04:00
|
|
|
import React, { Fragment } from 'react';
|
|
|
|
import { NavLink } from 'react-router-dom';
|
|
|
|
|
2021-09-24 13:31:03 -04:00
|
|
|
import { AggregationDescriptionConfig, buildingUserFields, dataFields } from '../../config/data-fields-config';
|
2021-08-22 21:26:58 -04:00
|
|
|
import { CopyProps } from '../data-containers/category-view-props';
|
|
|
|
import { DataTitleCopyable } from './data-title';
|
2019-08-14 16:54:31 -04:00
|
|
|
|
2019-10-18 10:06:50 -04:00
|
|
|
|
2021-09-24 13:31:03 -04:00
|
|
|
interface UserOpinionEntryProps {
|
|
|
|
slug: string;
|
|
|
|
title: string;
|
2019-10-18 10:06:50 -04:00
|
|
|
mode: 'view' | 'edit' | 'multi-edit';
|
2021-08-22 21:26:58 -04:00
|
|
|
userValue: boolean;
|
|
|
|
aggregateValue: number;
|
2021-09-24 13:31:03 -04:00
|
|
|
aggregationDescriptions: AggregationDescriptionConfig;
|
2021-08-22 21:26:58 -04:00
|
|
|
copy: CopyProps;
|
|
|
|
onChange: (key: string, value: boolean) => void;
|
2019-10-18 10:06:50 -04:00
|
|
|
}
|
|
|
|
|
2021-09-24 13:31:03 -04:00
|
|
|
const UserOpinionEntry: React.FunctionComponent<UserOpinionEntryProps> = (props) => {
|
2021-08-22 21:26:58 -04:00
|
|
|
|
2019-08-14 16:54:31 -04:00
|
|
|
return (
|
2021-08-12 16:11:00 -04:00
|
|
|
<>
|
2021-08-22 21:26:58 -04:00
|
|
|
<DataTitleCopyable
|
2021-09-24 13:31:03 -04:00
|
|
|
slug={props.slug}
|
|
|
|
title={props.title}
|
2021-08-22 21:26:58 -04:00
|
|
|
copy={props.copy}
|
|
|
|
/>
|
2021-08-12 16:11:00 -04:00
|
|
|
<label className="form-check-label">
|
|
|
|
<input className="form-check-input" type="checkbox"
|
2021-09-24 13:31:03 -04:00
|
|
|
name={props.slug}
|
2021-08-22 21:26:58 -04:00
|
|
|
checked={!!props.userValue}
|
2021-08-12 16:11:00 -04:00
|
|
|
disabled={props.mode === 'view'}
|
2021-09-24 13:31:03 -04:00
|
|
|
onChange={e => props.onChange(props.slug, e.target.checked)}
|
2021-08-22 21:26:58 -04:00
|
|
|
/> Yes
|
2021-08-12 16:11:00 -04:00
|
|
|
</label>
|
2019-08-23 12:35:17 -04:00
|
|
|
<p>
|
2019-08-14 16:54:31 -04:00
|
|
|
{
|
2021-09-24 13:31:03 -04:00
|
|
|
(props.aggregateValue)?
|
2021-08-22 21:26:58 -04:00
|
|
|
(props.aggregateValue === 1)?
|
2021-09-24 13:31:03 -04:00
|
|
|
`1 person ${props.aggregationDescriptions.one}`
|
|
|
|
: `${props.aggregateValue} people ${props.aggregationDescriptions.many}`
|
|
|
|
: `0 people ${props.aggregationDescriptions.zero}`
|
2019-08-14 16:54:31 -04:00
|
|
|
}
|
2019-08-23 12:35:17 -04:00
|
|
|
</p>
|
2021-08-12 16:11:00 -04:00
|
|
|
</>
|
2019-08-14 16:54:31 -04:00
|
|
|
);
|
2019-11-07 03:13:30 -05:00
|
|
|
};
|
2019-08-14 16:54:31 -04:00
|
|
|
|
2021-09-24 13:31:03 -04:00
|
|
|
export default UserOpinionEntry;
|