2018-03-26 14:32:43 -07:00
|
|
|
// @flow
|
|
|
|
import * as React from 'react';
|
|
|
|
import { FormField } from './form-field';
|
|
|
|
|
2019-04-24 10:02:08 -04:00
|
|
|
type FormPrice = {
|
|
|
|
amount: ?number,
|
|
|
|
currency: string,
|
|
|
|
};
|
|
|
|
|
2018-03-26 14:32:43 -07:00
|
|
|
type Props = {
|
2019-04-24 10:02:08 -04:00
|
|
|
price: FormPrice,
|
|
|
|
onChange: FormPrice => void,
|
2018-03-26 14:32:43 -07:00
|
|
|
placeholder: number,
|
|
|
|
min: number,
|
|
|
|
disabled: boolean,
|
|
|
|
name: string,
|
|
|
|
step: ?number,
|
|
|
|
};
|
|
|
|
|
|
|
|
export class FormFieldPrice extends React.PureComponent<Props> {
|
|
|
|
constructor(props: Props) {
|
|
|
|
super(props);
|
|
|
|
|
|
|
|
(this: any).handleAmountChange = this.handleAmountChange.bind(this);
|
|
|
|
(this: any).handleCurrencyChange = this.handleCurrencyChange.bind(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
handleAmountChange(event: SyntheticInputEvent<*>) {
|
|
|
|
const { price, onChange } = this.props;
|
2019-04-24 10:02:08 -04:00
|
|
|
const amount = event.target.value ? parseFloat(event.target.value) : undefined;
|
2018-03-26 14:32:43 -07:00
|
|
|
onChange({
|
|
|
|
currency: price.currency,
|
2018-04-04 12:32:02 -04:00
|
|
|
amount,
|
2018-03-26 14:32:43 -07:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
handleCurrencyChange(event: SyntheticInputEvent<*>) {
|
|
|
|
const { price, onChange } = this.props;
|
|
|
|
onChange({
|
|
|
|
currency: event.target.value,
|
|
|
|
amount: price.amount,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
2019-02-13 12:27:20 -04:00
|
|
|
const { price, placeholder, min, disabled, name, step } = this.props;
|
2018-03-26 14:32:43 -07:00
|
|
|
|
|
|
|
return (
|
2019-02-13 12:27:20 -04:00
|
|
|
<fieldset-group class="fieldset-group--smushed">
|
2019-08-19 12:10:48 -04:00
|
|
|
<FormField
|
|
|
|
name={`${name}_amount`}
|
|
|
|
label={__('Price')}
|
|
|
|
type="number"
|
|
|
|
className="form-field--price-amount"
|
|
|
|
min={min}
|
|
|
|
value={price.amount}
|
2019-10-14 09:18:43 -07:00
|
|
|
onWheel={e => e.preventDefault()}
|
2019-08-19 12:10:48 -04:00
|
|
|
onChange={this.handleAmountChange}
|
|
|
|
placeholder={placeholder || 5}
|
|
|
|
disabled={disabled}
|
|
|
|
step={step || 'any'}
|
|
|
|
/>
|
|
|
|
<FormField
|
|
|
|
label={__('Currency')}
|
|
|
|
name={`${name}_currency`}
|
|
|
|
type="select"
|
|
|
|
id={`${name}_currency`}
|
|
|
|
className="input--currency-select"
|
|
|
|
disabled={disabled}
|
|
|
|
onChange={this.handleCurrencyChange}
|
|
|
|
value={price.currency}
|
|
|
|
>
|
|
|
|
<option value="LBC">{__('LBRY Credits (LBC)')}</option>
|
|
|
|
<option value="USD">{__('US Dollars')}</option>
|
|
|
|
</FormField>
|
2019-02-13 12:27:20 -04:00
|
|
|
</fieldset-group>
|
2018-03-26 14:32:43 -07:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default FormFieldPrice;
|