Use ItemList for signup and login modals (#1420)

* Remove unused imports

* Use body and footer methods

* Use ItemList for signup and login inputs
This commit is contained in:
Clark Winkelmann 2018-05-11 11:29:58 +02:00 committed by Toby Zerner
parent f6398fc245
commit 5f8ca30f45
2 changed files with 103 additions and 75 deletions

View File

@ -1,10 +1,10 @@
import Modal from 'flarum/components/Modal'; import Modal from 'flarum/components/Modal';
import ForgotPasswordModal from 'flarum/components/ForgotPasswordModal'; import ForgotPasswordModal from 'flarum/components/ForgotPasswordModal';
import SignUpModal from 'flarum/components/SignUpModal'; import SignUpModal from 'flarum/components/SignUpModal';
import Alert from 'flarum/components/Alert';
import Button from 'flarum/components/Button'; import Button from 'flarum/components/Button';
import LogInButtons from 'flarum/components/LogInButtons'; import LogInButtons from 'flarum/components/LogInButtons';
import extractText from 'flarum/utils/extractText'; import extractText from 'flarum/utils/extractText';
import ItemList from 'flarum/utils/ItemList';
/** /**
* The `LogInModal` component displays a modal dialog with a login form. * The `LogInModal` component displays a modal dialog with a login form.
@ -51,51 +51,71 @@ export default class LogInModal extends Modal {
content() { content() {
return [ return [
<div className="Modal-body"> <div className="Modal-body">
<LogInButtons/> {this.body()}
</div>,
<div className="Modal-footer">
{this.footer()}
</div>
];
}
body() {
return [
<LogInButtons/>,
<div className="Form Form--centered"> <div className="Form Form--centered">
<div className="Form-group"> {this.fields().toArray()}
</div>
];
}
fields() {
const items = new ItemList();
items.add('identification', <div className="Form-group">
<input className="FormControl" name="identification" type="text" placeholder={extractText(app.translator.trans('core.forum.log_in.username_or_email_placeholder'))} <input className="FormControl" name="identification" type="text" placeholder={extractText(app.translator.trans('core.forum.log_in.username_or_email_placeholder'))}
bidi={this.identification} bidi={this.identification}
disabled={this.loading} /> disabled={this.loading} />
</div> </div>, 30);
<div className="Form-group"> items.add('password', <div className="Form-group">
<input className="FormControl" name="password" type="password" placeholder={extractText(app.translator.trans('core.forum.log_in.password_placeholder'))} <input className="FormControl" name="password" type="password" placeholder={extractText(app.translator.trans('core.forum.log_in.password_placeholder'))}
bidi={this.password} bidi={this.password}
disabled={this.loading} /> disabled={this.loading} />
</div> </div>, 20);
<div className="Form-group"> items.add('remember', <div className="Form-group">
<div> <div>
<label className="checkbox"> <label className="checkbox">
<input type="checkbox" bidi={this.remember} disabled={this.loading} /> <input type="checkbox" bidi={this.remember} disabled={this.loading} />
{app.translator.trans('core.forum.log_in.remember_me_label')} {app.translator.trans('core.forum.log_in.remember_me_label')}
</label> </label>
</div> </div>
</div> </div>, 10);
<div className="Form-group"> items.add('submit', <div className="Form-group">
{Button.component({ {Button.component({
className: 'Button Button--primary Button--block', className: 'Button Button--primary Button--block',
type: 'submit', type: 'submit',
loading: this.loading, loading: this.loading,
children: app.translator.trans('core.forum.log_in.submit_button') children: app.translator.trans('core.forum.log_in.submit_button')
})} })}
</div> </div>, -10);
</div>
</div>, return items;
<div className="Modal-footer"> }
footer() {
return [
<p className="LogInModal-forgotPassword"> <p className="LogInModal-forgotPassword">
<a onclick={this.forgotPassword.bind(this)}>{app.translator.trans('core.forum.log_in.forgot_password_link')}</a> <a onclick={this.forgotPassword.bind(this)}>{app.translator.trans('core.forum.log_in.forgot_password_link')}</a>
</p> </p>,
{app.forum.attribute('allowSignUp') ? ( app.forum.attribute('allowSignUp') ? (
<p className="LogInModal-signUp"> <p className="LogInModal-signUp">
{app.translator.trans('core.forum.log_in.sign_up_text', {a: <a onclick={this.signUp.bind(this)}/>})} {app.translator.trans('core.forum.log_in.sign_up_text', {a: <a onclick={this.signUp.bind(this)}/>})}
</p> </p>
) : ''} ) : ''
</div>
]; ];
} }

View File

@ -1,9 +1,9 @@
import Modal from 'flarum/components/Modal'; import Modal from 'flarum/components/Modal';
import LogInModal from 'flarum/components/LogInModal'; import LogInModal from 'flarum/components/LogInModal';
import avatar from 'flarum/helpers/avatar';
import Button from 'flarum/components/Button'; import Button from 'flarum/components/Button';
import LogInButtons from 'flarum/components/LogInButtons'; import LogInButtons from 'flarum/components/LogInButtons';
import extractText from 'flarum/utils/extractText'; import extractText from 'flarum/utils/extractText';
import ItemList from 'flarum/utils/ItemList';
/** /**
* The `SignUpModal` component displays a modal dialog with a singup form. * The `SignUpModal` component displays a modal dialog with a singup form.
@ -69,39 +69,47 @@ export default class SignUpModal extends Modal {
this.props.token ? '' : <LogInButtons/>, this.props.token ? '' : <LogInButtons/>,
<div className="Form Form--centered"> <div className="Form Form--centered">
<div className="Form-group"> {this.fields().toArray()}
</div>
];
}
fields() {
const items = new ItemList();
items.add('username', <div className="Form-group">
<input className="FormControl" name="username" type="text" placeholder={extractText(app.translator.trans('core.forum.sign_up.username_placeholder'))} <input className="FormControl" name="username" type="text" placeholder={extractText(app.translator.trans('core.forum.sign_up.username_placeholder'))}
value={this.username()} value={this.username()}
onchange={m.withAttr('value', this.username)} onchange={m.withAttr('value', this.username)}
disabled={this.loading || this.isProvided('username')} /> disabled={this.loading || this.isProvided('username')} />
</div> </div>, 30);
<div className="Form-group"> items.add('email', <div className="Form-group">
<input className="FormControl" name="email" type="email" placeholder={extractText(app.translator.trans('core.forum.sign_up.email_placeholder'))} <input className="FormControl" name="email" type="email" placeholder={extractText(app.translator.trans('core.forum.sign_up.email_placeholder'))}
value={this.email()} value={this.email()}
onchange={m.withAttr('value', this.email)} onchange={m.withAttr('value', this.email)}
disabled={this.loading || this.isProvided('email')} /> disabled={this.loading || this.isProvided('email')} />
</div> </div>, 20);
{this.props.token ? '' : ( if (!this.props.token) {
<div className="Form-group"> items.add('password', <div className="Form-group">
<input className="FormControl" name="password" type="password" placeholder={extractText(app.translator.trans('core.forum.sign_up.password_placeholder'))} <input className="FormControl" name="password" type="password" placeholder={extractText(app.translator.trans('core.forum.sign_up.password_placeholder'))}
value={this.password()} value={this.password()}
onchange={m.withAttr('value', this.password)} onchange={m.withAttr('value', this.password)}
disabled={this.loading} /> disabled={this.loading} />
</div> </div>, 10);
)} }
<div className="Form-group"> items.add('submit', <div className="Form-group">
<Button <Button
className="Button Button--primary Button--block" className="Button Button--primary Button--block"
type="submit" type="submit"
loading={this.loading}> loading={this.loading}>
{app.translator.trans('core.forum.sign_up.submit_button')} {app.translator.trans('core.forum.sign_up.submit_button')}
</Button> </Button>
</div> </div>, -10);
</div>
]; return items;
} }
footer() { footer() {