@plone/volto
Version:
Volto
130 lines (123 loc) • 4 kB
JSX
/**
* EndField component.
* @module components/manage/Widgets/RecurrenceWidget/EndField
*/
import React from 'react';
import PropTypes from 'prop-types';
import { defineMessages, injectIntl } from 'react-intl';
import { Form, Grid, Input, Radio } from 'semantic-ui-react';
import DatetimeWidget from '../DatetimeWidget';
const messages = defineMessages({
recurrenceEnds: { id: 'Recurrence ends', defaultMessage: 'Ends' },
recurrenceEndsCount: { id: 'Recurrence ends after', defaultMessage: 'after' },
recurrenceEndsUntil: { id: 'Recurrence ends on', defaultMessage: 'on' },
occurrences: { id: 'Occurences', defaultMessage: 'occurrence(s)' },
});
/**
* EndField component class.
* @function EndField
* @returns {string} Markup of the component.
*/
const EndField = ({ value, count, until, onChange, intl }) => {
return (
<Form.Field inline className="text">
<Grid>
<Grid.Row stretched>
<Grid.Column width="4">
<div className="wrapper">
<label htmlFor="recurrenceEnds">
{intl.formatMessage(messages.recurrenceEnds)}
</label>
</div>
</Grid.Column>
<Grid.Column width="8">
<Form.Group inline>
<Form.Field>
<Radio
label=""
name="recurrenceEnds"
id="recurrenceEndsCount"
value="count"
checked={value === 'count'}
onChange={(e, { value }) => onChange('recurrenceEnds', value)}
/>
</Form.Field>
<Form.Field disabled={value !== 'count'}>
{intl.formatMessage(messages.recurrenceEndsCount)}
</Form.Field>
<Form.Field disabled={value !== 'count'}>
<Input
id="count"
name="count"
value={count || ''}
onChange={({ target }) => {
onChange(
target.id,
target.value === '' ? undefined : target.value,
);
}}
/>
</Form.Field>
<Form.Field disabled={value !== 'count'}>
{intl.formatMessage(messages.occurrences)}
</Form.Field>
</Form.Group>
<Form.Group inline>
<Form.Field>
<Radio
id="recurrenceEndsUntil"
label=""
name="recurrenceEnds"
value="until"
checked={value === 'until'}
onChange={(e, { value }) => onChange('recurrenceEnds', value)}
/>
</Form.Field>
<Form.Field disabled={value !== 'until'}>
<DatetimeWidget
id="until"
title={intl.formatMessage(messages.recurrenceEndsUntil)}
dateOnly={true}
value={
until
? typeof until === 'string'
? until
: until?.toISOString()
: ''
}
resettable={false}
onChange={(id, value) => {
onChange(id, value === '' ? undefined : value);
}}
/>
</Form.Field>
</Form.Group>
</Grid.Column>
</Grid.Row>
</Grid>
</Form.Field>
);
};
/**
* Property types.
* @property {Object} propTypes Property types.
* @static
*/
EndField.propTypes = {
value: PropTypes.string,
count: PropTypes.any,
until: PropTypes.any,
onChange: PropTypes.func,
};
/**
* Default properties.
* @property {Object} defaultProps Default properties.
* @static
*/
EndField.defaultProps = {
value: null,
count: null,
until: null,
onChange: null,
};
export default injectIntl(EndField);