2017-08-22 21:49:50 +03:00
|
|
|
import React from 'react';
|
2019-12-07 21:43:08 +02:00
|
|
|
import clsx from 'clsx';
|
2019-12-07 21:02:00 +02:00
|
|
|
import { CaptchaID } from 'app/services/captcha';
|
|
|
|
import { Skin } from 'app/components/ui';
|
|
|
|
import captcha from 'app/services/captcha';
|
|
|
|
import logger from 'app/services/logger';
|
|
|
|
import { ComponentLoader } from 'app/components/ui/loader';
|
2016-07-31 16:53:16 +03:00
|
|
|
|
|
|
|
import styles from './form.scss';
|
|
|
|
import FormInputComponent from './FormInputComponent';
|
|
|
|
|
2019-11-27 11:03:32 +02:00
|
|
|
export default class Captcha extends FormInputComponent<
|
2020-05-24 02:08:24 +03:00
|
|
|
{
|
|
|
|
delay: number;
|
|
|
|
skin: Skin;
|
|
|
|
},
|
|
|
|
{
|
|
|
|
code: string;
|
|
|
|
}
|
2019-11-27 11:03:32 +02:00
|
|
|
> {
|
2020-05-24 02:08:24 +03:00
|
|
|
elRef = React.createRef<HTMLDivElement>();
|
|
|
|
captchaId: CaptchaID;
|
2016-07-31 16:53:16 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
static defaultProps = {
|
|
|
|
skin: 'dark',
|
|
|
|
delay: 0,
|
|
|
|
};
|
2016-07-31 16:53:16 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
componentDidMount() {
|
|
|
|
setTimeout(() => {
|
|
|
|
const { current: el } = this.elRef;
|
2019-06-30 16:32:50 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
el &&
|
|
|
|
captcha
|
|
|
|
.render(el, {
|
|
|
|
skin: this.props.skin,
|
|
|
|
onSetCode: this.setCode,
|
|
|
|
})
|
|
|
|
.then((captchaId) => {
|
|
|
|
this.captchaId = captchaId;
|
|
|
|
})
|
|
|
|
.catch((error) => {
|
|
|
|
logger.error('Failed rendering captcha', {
|
|
|
|
error,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}, this.props.delay);
|
|
|
|
}
|
2016-07-31 16:53:16 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
render() {
|
|
|
|
const { skin } = this.props;
|
2016-08-05 08:58:24 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
return (
|
|
|
|
<div className={styles.captchaContainer}>
|
|
|
|
<div className={styles.captchaLoader}>
|
|
|
|
<ComponentLoader />
|
|
|
|
</div>
|
2016-08-14 13:10:59 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
<div ref={this.elRef} className={clsx(styles.captcha, styles[`${skin}Captcha`])} />
|
2016-08-14 13:10:59 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
{this.renderError()}
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
2016-07-31 16:53:16 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
reset() {
|
|
|
|
captcha.reset(this.captchaId);
|
|
|
|
}
|
2016-08-14 13:10:59 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
getValue() {
|
|
|
|
return this.state && this.state.code;
|
|
|
|
}
|
2016-08-14 13:10:59 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
onFormInvalid() {
|
|
|
|
this.reset();
|
|
|
|
}
|
2016-08-14 13:10:59 +03:00
|
|
|
|
2020-05-24 02:08:24 +03:00
|
|
|
setCode = (code: string) => this.setState({ code });
|
2016-07-31 16:53:16 +03:00
|
|
|
}
|