mirror of
https://github.com/flarum/framework.git
synced 2025-06-07 17:24:33 +08:00

Also fixes a couple of miscellaneous bugs: - Minimise the Composer when clicking the preview button in full-screen mode on desktop. - Minimise the Composer when clicking the link to the discussion/post in the header on mobile/full-screen mode.
87 lines
2.2 KiB
JavaScript
87 lines
2.2 KiB
JavaScript
import ComposerBody from 'flarum/components/ComposerBody';
|
|
import icon from 'flarum/helpers/icon';
|
|
|
|
function minimizeComposerIfFullScreen(e) {
|
|
if (app.composer.isFullScreen()) {
|
|
app.composer.minimize();
|
|
e.stopPropagation();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* The `EditPostComposer` component displays the composer content for editing a
|
|
* post. It sets the initial content to the content of the post that is being
|
|
* edited, and adds a header control to indicate which post is being edited.
|
|
*
|
|
* ### Props
|
|
*
|
|
* - All of the props for ComposerBody
|
|
* - `post`
|
|
*/
|
|
export default class EditPostComposer extends ComposerBody {
|
|
init() {
|
|
super.init();
|
|
|
|
this.editor.props.preview = e => {
|
|
minimizeComposerIfFullScreen(e);
|
|
|
|
m.route(app.route.post(this.props.post));
|
|
};
|
|
}
|
|
|
|
static initProps(props) {
|
|
super.initProps(props);
|
|
|
|
props.submitLabel = props.submitLabel || app.translator.trans('core.forum.composer_edit.submit_button');
|
|
props.confirmExit = props.confirmExit || app.translator.trans('core.forum.composer_edit.discard_confirmation');
|
|
props.originalContent = props.originalContent || props.post.content();
|
|
props.user = props.user || props.post.user();
|
|
|
|
props.post.editedContent = props.originalContent;
|
|
}
|
|
|
|
headerItems() {
|
|
const items = super.headerItems();
|
|
const post = this.props.post;
|
|
|
|
const routeAndMinimize = function(element, isInitialized) {
|
|
if (isInitialized) return;
|
|
$(element).on('click', minimizeComposerIfFullScreen);
|
|
m.route.apply(this, arguments);
|
|
};
|
|
|
|
items.add('title', (
|
|
<h3>
|
|
{icon('pencil')} {' '}
|
|
<a href={app.route.discussion(post.discussion(), post.number())} config={routeAndMinimize}>
|
|
{app.translator.trans('core.forum.composer_edit.post_link', {number: post.number(), discussion: post.discussion().title()})}
|
|
</a>
|
|
</h3>
|
|
));
|
|
|
|
return items;
|
|
}
|
|
|
|
/**
|
|
* Get the data to submit to the server when the post is saved.
|
|
*
|
|
* @return {Object}
|
|
*/
|
|
data() {
|
|
return {
|
|
content: this.content()
|
|
};
|
|
}
|
|
|
|
onsubmit() {
|
|
this.loading = true;
|
|
|
|
const data = this.data();
|
|
|
|
this.props.post.save(data).then(
|
|
() => app.composer.hide(),
|
|
this.loaded.bind(this)
|
|
);
|
|
}
|
|
}
|