40 lines
1.1 KiB
TypeScript
Raw Normal View History

2019-12-07 13:28:52 +02:00
import React from 'react';
import { MessageDescriptor } from 'react-intl';
import i18n from 'app/services/i18n';
2019-12-07 13:28:52 +02:00
export default class FormComponent<P, S = {}> extends React.Component<P, S> {
2020-05-24 02:08:24 +03:00
/**
* Formats message resolving intl translations
*
* @param {string|object} message - message string, or intl message descriptor with an `id` field
*
* @returns {string}
*/
formatMessage(message: string | MessageDescriptor): string {
if (!message) {
throw new Error('A message is required');
}
2019-12-07 13:28:52 +02:00
2020-05-24 02:08:24 +03:00
if (typeof message === 'string') {
return message;
}
2019-12-07 13:28:52 +02:00
2020-05-24 02:08:24 +03:00
if (!message.id) {
throw new Error(`Invalid message format: ${JSON.stringify(message)}`);
}
2019-12-07 13:28:52 +02:00
2020-05-24 02:08:24 +03:00
return i18n.getIntl().formatMessage(message);
}
2019-12-07 13:28:52 +02:00
2020-05-24 02:08:24 +03:00
/**
* Focuses this field
*/
focus() {}
2019-12-07 13:28:52 +02:00
2020-05-24 02:08:24 +03:00
/**
* A hook, that called, when the form was submitted with invalid data
* This is useful for the cases, when some field needs to be refreshed e.g. captcha
*/
onFormInvalid() {}
2019-12-07 13:28:52 +02:00
}