From 7b03fa16c50f2250bcc16284016cb05f501ec51a Mon Sep 17 00:00:00 2001 From: haraldox Date: Fri, 19 Jan 2018 16:36:26 +0100 Subject: [PATCH 1/5] fix invite screen [object Object] value mobx-react-form expects nested `fields` property in array --- src/components/auth/Invite.js | 22 +++++++++++----------- src/helpers/validation-helpers.js | 2 +- src/lib/Form.js | 5 +++-- 3 files changed, 15 insertions(+), 14 deletions(-) diff --git a/src/components/auth/Invite.js b/src/components/auth/Invite.js index c1d815dcd..dface4fe1 100644 --- a/src/components/auth/Invite.js +++ b/src/components/auth/Invite.js @@ -45,17 +45,17 @@ export default class Invite extends Component { form = new Form({ fields: { invite: [...Array(3).fill({ - name: { - label: this.context.intl.formatMessage(messages.nameLabel), - // value: '', - placeholder: this.context.intl.formatMessage(messages.nameLabel), - }, - email: { - label: this.context.intl.formatMessage(messages.emailLabel), - // value: '', - validate: [email], - placeholder: this.context.intl.formatMessage(messages.emailLabel), - }, + fields: { + name: { + label: this.context.intl.formatMessage(messages.nameLabel), + placeholder: this.context.intl.formatMessage(messages.nameLabel), + }, + email: { + label: this.context.intl.formatMessage(messages.emailLabel), + placeholder: this.context.intl.formatMessage(messages.emailLabel), + validators: [email], + } + } })], }, }, this.context.intl); diff --git a/src/helpers/validation-helpers.js b/src/helpers/validation-helpers.js index eeb12cab7..a8a242d54 100644 --- a/src/helpers/validation-helpers.js +++ b/src/helpers/validation-helpers.js @@ -13,7 +13,7 @@ export function email({ field }) { isValid = true; } - return [isValid, `${field.label} is not a valid email address`]; + return [isValid, `${field.label} not valid`]; } export function url({ field }) { diff --git a/src/lib/Form.js b/src/lib/Form.js index a22699b45..9b8321948 100644 --- a/src/lib/Form.js +++ b/src/lib/Form.js @@ -21,8 +21,9 @@ export default class DefaultForm extends Form { options() { return { - validateOnInit: false, - // validateOnBlur: true, + validateOnInit: false, // default: true + // validateOnBlur: true, // default: true + // validateOnChange: true // default: false // // validationDebounceWait: { // // trailing: true, // // }, From 3692bd81a71d4caf094dc01b175df95519e796e8 Mon Sep 17 00:00:00 2001 From: haraldox Date: Fri, 19 Jan 2018 17:14:44 +0100 Subject: [PATCH 2/5] implemented check for at least one email address realized by leveraging `disabled` attribute of submit button --- src/components/auth/Invite.js | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/components/auth/Invite.js b/src/components/auth/Invite.js index dface4fe1..3eb1f2765 100644 --- a/src/components/auth/Invite.js +++ b/src/components/auth/Invite.js @@ -74,6 +74,10 @@ export default class Invite extends Component { const { form } = this; const { intl } = this.context; + const atLeastOneEmailAddress = form.$('invite') + .map(invite => {return invite.$('email').value}) + .some(email => email.trim() !== '') + return (
this.submit(e)}> @@ -96,6 +100,7 @@ export default class Invite extends Component {
))} + {form.error === 'no-email-addresses' && ( +

+ {intl.formatMessage(messages.noEmailAddresses)} +

+ )}