mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-10 02:55:41 +00:00
9ef1920fe0
* Align footer to bottom * Fix request payment offset padding * Update request payment padding * Add new Input and Dropdown components * Fix offset margins in equiv vals * Update all send tx inputs & dropdowns * Update generate wallet dropdowns * Update inputs & dropdowns for contracts tab * Add inputs & dropdowns for all but swap tab * amend * Fix imports * inputs are invalid when not disabled or readonly * Fix offset refresh button * Add togglable password back to wallet generation * Update swap inputs, textareas, and dropdowns * Update any outstanding inputs * Make UnitDropDown searchable * unitdropdown searchanble if options > 10 * Fix css issues * Reset before setting currentTo
64 lines
1.6 KiB
TypeScript
64 lines
1.6 KiB
TypeScript
import React from 'react';
|
|
import Select, { ReactSelectProps } from 'react-select';
|
|
|
|
interface Props extends ReactSelectProps {
|
|
className?: string;
|
|
options: any;
|
|
onChange: any;
|
|
}
|
|
|
|
export default class Dropdown extends React.Component<Props> {
|
|
public state = {
|
|
selectedOption: { value: '', label: '' },
|
|
hasBlurred: false
|
|
};
|
|
|
|
public handleChange = selectedOption => {
|
|
this.setState({ selectedOption });
|
|
};
|
|
|
|
public formatOptions = options => {
|
|
if (typeof options[0] === 'object') {
|
|
return options;
|
|
}
|
|
const formatted = options.map(opt => {
|
|
return { value: opt, label: opt };
|
|
});
|
|
return formatted;
|
|
};
|
|
|
|
public render() {
|
|
const { onChange } = this.props;
|
|
const { selectedOption } = this.state;
|
|
const value = selectedOption && selectedOption.value;
|
|
const options = this.formatOptions(this.props.options);
|
|
|
|
return (
|
|
<Select
|
|
// use ref to prevent <label /> from stealing focus when used inline with an input
|
|
ref={el => {
|
|
if (!!el && !!(el as any).control) {
|
|
(el as any).control.addEventListener('click', e => {
|
|
e.preventDefault();
|
|
});
|
|
}
|
|
}}
|
|
className={`${this.props.className} ${this.state.hasBlurred ? 'has-blurred' : ''}`}
|
|
value={value}
|
|
onChange={obj => {
|
|
this.handleChange(obj);
|
|
onChange();
|
|
}}
|
|
{...this.props}
|
|
onBlur={e => {
|
|
this.setState({ hasBlurred: true });
|
|
if (this.props && this.props.onBlur) {
|
|
this.props.onBlur(e);
|
|
}
|
|
}}
|
|
options={options}
|
|
/>
|
|
);
|
|
}
|
|
}
|