mirror of
https://github.com/flarum/framework.git
synced 2025-05-23 23:29:57 +08:00

Improved consistency for existing core translation key names. See flarum/core#265 - Completely overhauled core en.yml - Replaced existing key names in all core JS files to match - Extracted a hardcoded string in IndexPage.js - Combined two app.trans calls in DiscussionControls.js - Removed hardcoded spaces from LogInModal.js and SignUpModal.js - Added two new keys from DiscussionControls.js (soft delete) - Created two new “reused keys” to YML to accommodate same
119 lines
3.1 KiB
JavaScript
119 lines
3.1 KiB
JavaScript
import ComposerBody from 'flarum/components/ComposerBody';
|
|
|
|
/**
|
|
* The `DiscussionComposer` component displays the composer content for starting
|
|
* a new discussion. It adds a text field as a header control so the user can
|
|
* enter the title of their discussion. It also overrides the `submit` and
|
|
* `willExit` actions to account for the title.
|
|
*
|
|
* ### Props
|
|
*
|
|
* - All of the props for ComposerBody
|
|
* - `titlePlaceholder`
|
|
*/
|
|
export default class DiscussionComposer extends ComposerBody {
|
|
constructor(...args) {
|
|
super(...args);
|
|
|
|
/**
|
|
* The value of the title input.
|
|
*
|
|
* @type {Function}
|
|
*/
|
|
this.title = m.prop('');
|
|
}
|
|
|
|
static initProps(props) {
|
|
super.initProps(props);
|
|
|
|
props.placeholder = props.placeholder || app.trans('core.composer_discussion_body_placeholder');
|
|
props.submitLabel = props.submitLabel || app.trans('core.composer_discussion_submit_button');
|
|
props.confirmExit = props.confirmExit || app.trans('core.composer_discussion_discard_confirmation');
|
|
props.titlePlaceholder = props.titlePlaceholder || app.trans('core.composer_discussion_title_placeholder');
|
|
}
|
|
|
|
headerItems() {
|
|
const items = super.headerItems();
|
|
|
|
items.add('title', (
|
|
<h3>
|
|
<input className="FormControl"
|
|
value={this.title()}
|
|
oninput={m.withAttr('value', this.title)}
|
|
placeholder={this.props.titlePlaceholder}
|
|
disabled={!!this.props.disabled}
|
|
onkeydown={this.onkeydown.bind(this)}/>
|
|
</h3>
|
|
));
|
|
|
|
return items;
|
|
}
|
|
|
|
/**
|
|
* Handle the title input's keydown event. When the return key is pressed,
|
|
* move the focus to the start of the text editor.
|
|
*
|
|
* @param {Event} e
|
|
*/
|
|
onkeydown(e) {
|
|
if (e.which === 13) { // Return
|
|
e.preventDefault();
|
|
this.editor.setSelectionRange(0, 0);
|
|
}
|
|
|
|
m.redraw.strategy('none');
|
|
}
|
|
|
|
config(isInitialized, context) {
|
|
super.config(isInitialized, context);
|
|
|
|
// If the user presses the backspace key in the text editor, and the cursor
|
|
// is already at the start, then we'll move the focus back into the title
|
|
// input.
|
|
this.editor.$('textarea').keydown((e) => {
|
|
if (e.which === 8 && e.target.selectionStart === 0 && e.target.selectionEnd === 0) {
|
|
e.preventDefault();
|
|
|
|
const $title = this.$(':input:enabled:visible:first')[0];
|
|
$title.focus();
|
|
$title.selectionStart = $title.selectionEnd = $title.value.length;
|
|
}
|
|
});
|
|
}
|
|
|
|
preventExit() {
|
|
return (this.title() || this.content()) && this.props.confirmExit;
|
|
}
|
|
|
|
/**
|
|
* Get the data to submit to the server when the discussion is saved.
|
|
*
|
|
* @return {Object}
|
|
*/
|
|
data() {
|
|
return {
|
|
title: this.title(),
|
|
content: this.content()
|
|
};
|
|
}
|
|
|
|
onsubmit() {
|
|
this.loading = true;
|
|
|
|
const data = this.data();
|
|
|
|
app.store.createRecord('discussions').save(data).then(
|
|
discussion => {
|
|
app.composer.hide();
|
|
app.cache.discussionList.addDiscussion(discussion);
|
|
m.route(app.route.discussion(discussion));
|
|
},
|
|
response => {
|
|
this.loading = false;
|
|
m.redraw();
|
|
app.alertErrors(response.errors);
|
|
}
|
|
);
|
|
}
|
|
}
|