106 lines
2.4 KiB
TypeScript
Raw Normal View History

import React from 'react';
2019-12-07 13:28:52 +02:00
import { MessageDescriptor } from 'react-intl';
import TextareaAutosize from 'react-textarea-autosize';
2019-12-07 21:43:08 +02:00
import clsx from 'clsx';
import { uniqueId, omit } from 'app/functions';
import { SKIN_DARK, COLOR_GREEN, Skin, Color } from 'app/components/ui';
2016-05-22 20:25:38 +03:00
import styles from './form.scss';
import FormInputComponent from './FormInputComponent';
type TextareaAutosizeProps = {
2019-12-07 13:28:52 +02:00
onHeightChange?: (number, TextareaAutosizeProps) => void;
useCacheForDOMMeasurements?: boolean;
minRows?: number;
maxRows?: number;
inputRef?: (el?: HTMLTextAreaElement) => void;
};
export default class TextArea extends FormInputComponent<
{
2019-12-07 13:28:52 +02:00
placeholder?: string | MessageDescriptor;
label?: string | MessageDescriptor;
skin: Skin;
color: Color;
} & TextareaAutosizeProps &
React.TextareaHTMLAttributes<HTMLTextAreaElement>
> {
static defaultProps = {
color: COLOR_GREEN,
skin: SKIN_DARK,
};
elRef = React.createRef<HTMLTextAreaElement>();
render() {
2019-12-07 13:28:52 +02:00
const {
color,
skin,
label: labelText,
placeholder: placeholderText,
} = this.props;
let label: React.ReactElement | undefined;
let placeholder: string | undefined;
const props = omit(
{
type: 'text',
...this.props,
},
2019-12-07 13:28:52 +02:00
['label', 'placeholder', 'error', 'skin', 'color'],
);
2019-12-07 13:28:52 +02:00
if (labelText) {
if (!props.id) {
props.id = uniqueId('textarea');
}
label = (
<label className={styles.textFieldLabel} htmlFor={props.id}>
2019-12-07 13:28:52 +02:00
{this.formatMessage(labelText)}
</label>
);
2016-05-22 20:25:38 +03:00
}
2019-12-07 13:28:52 +02:00
if (placeholderText) {
placeholder = this.formatMessage(placeholderText);
}
return (
<div className={styles.formRow}>
{label}
<div className={styles.textAreaContainer}>
<TextareaAutosize
inputRef={this.elRef}
2019-12-07 21:43:08 +02:00
className={clsx(
styles.textArea,
styles[`${skin}TextField`],
styles[`${color}TextField`],
)}
2019-12-07 13:28:52 +02:00
placeholder={placeholder}
{...props}
/>
</div>
{this.renderError()}
</div>
);
}
getValue() {
const { current: el } = this.elRef;
return el && el.value;
}
focus() {
const { current: el } = this.elRef;
if (!el) {
return;
2016-05-22 20:25:38 +03:00
}
el.focus();
setTimeout(el.focus.bind(el), 10);
}
2016-05-22 20:25:38 +03:00
}