2016-03-19 21:37:04 +01:00
|
|
|
'use strict';
|
|
|
|
|
2016-07-07 22:13:58 +02:00
|
|
|
const router = require('../router.js');
|
2016-06-02 00:07:51 +02:00
|
|
|
const api = require('../api.js');
|
2017-01-20 21:51:04 +01:00
|
|
|
const uri = require('../util/uri.js');
|
2016-06-17 20:25:44 +02:00
|
|
|
const misc = require('../util/misc.js');
|
2016-06-14 10:31:48 +02:00
|
|
|
const settings = require('../models/settings.js');
|
2016-06-17 20:25:44 +02:00
|
|
|
const Comment = require('../models/comment.js');
|
2016-06-13 23:28:55 +02:00
|
|
|
const Post = require('../models/post.js');
|
2016-06-19 19:16:40 +02:00
|
|
|
const PostList = require('../models/post_list.js');
|
2016-10-22 10:03:38 +02:00
|
|
|
const PostMainView = require('../views/post_main_view.js');
|
|
|
|
const BasePostController = require('./base_post_controller.js');
|
2016-05-29 12:21:25 +02:00
|
|
|
const EmptyView = require('../views/empty_view.js');
|
2016-03-19 21:37:04 +01:00
|
|
|
|
2016-10-22 10:03:38 +02:00
|
|
|
class PostMainController extends BasePostController {
|
|
|
|
constructor(ctx, editMode) {
|
|
|
|
super(ctx);
|
2016-03-19 21:37:04 +01:00
|
|
|
|
2016-07-07 22:13:58 +02:00
|
|
|
let parameters = ctx.parameters;
|
2016-06-06 20:57:22 +02:00
|
|
|
Promise.all([
|
2016-10-22 10:03:38 +02:00
|
|
|
Post.get(ctx.parameters.id),
|
2016-06-19 19:16:40 +02:00
|
|
|
PostList.getAround(
|
2017-03-30 20:50:12 +02:00
|
|
|
ctx.parameters.id,
|
|
|
|
parameters ? parameters.query : null),
|
2016-06-06 20:57:22 +02:00
|
|
|
]).then(responses => {
|
2016-06-13 23:28:55 +02:00
|
|
|
const [post, aroundResponse] = responses;
|
2016-07-07 22:13:58 +02:00
|
|
|
|
|
|
|
// remove junk from query, but save it into history so that it can
|
|
|
|
// be still accessed after history navigation / page refresh
|
|
|
|
if (parameters.query) {
|
|
|
|
ctx.state.parameters = parameters;
|
2016-07-26 23:13:07 +02:00
|
|
|
const url = editMode ?
|
2017-01-20 21:51:04 +01:00
|
|
|
uri.formatClientLink('post', ctx.parameters.id, 'edit') :
|
|
|
|
uri.formatClientLink('post', ctx.parameters.id);
|
2016-07-26 23:13:07 +02:00
|
|
|
router.replace(url, ctx.state, false);
|
2016-07-07 22:13:58 +02:00
|
|
|
}
|
|
|
|
|
2016-06-17 20:25:44 +02:00
|
|
|
this._post = post;
|
2016-10-22 10:03:38 +02:00
|
|
|
this._view = new PostMainView({
|
2016-06-13 23:28:55 +02:00
|
|
|
post: post,
|
2016-06-06 20:57:22 +02:00
|
|
|
editMode: editMode,
|
|
|
|
prevPostId: aroundResponse.prev ? aroundResponse.prev.id : null,
|
2016-10-02 17:04:56 +02:00
|
|
|
nextPostId: aroundResponse.next ? aroundResponse.next.id : null,
|
2016-06-11 09:59:29 +02:00
|
|
|
canEditPosts: api.hasPrivilege('posts:edit'),
|
2016-08-23 22:23:59 +02:00
|
|
|
canDeletePosts: api.hasPrivilege('posts:delete'),
|
|
|
|
canFeaturePosts: api.hasPrivilege('posts:feature'),
|
2016-06-12 18:08:50 +02:00
|
|
|
canListComments: api.hasPrivilege('comments:list'),
|
|
|
|
canCreateComments: api.hasPrivilege('comments:create'),
|
2016-07-07 21:18:35 +02:00
|
|
|
parameters: parameters,
|
2016-06-06 20:57:22 +02:00
|
|
|
});
|
2016-08-22 20:45:58 +02:00
|
|
|
|
2016-06-17 20:25:44 +02:00
|
|
|
if (this._view.sidebarControl) {
|
|
|
|
this._view.sidebarControl.addEventListener(
|
|
|
|
'favorite', e => this._evtFavoritePost(e));
|
|
|
|
this._view.sidebarControl.addEventListener(
|
|
|
|
'unfavorite', e => this._evtUnfavoritePost(e));
|
|
|
|
this._view.sidebarControl.addEventListener(
|
|
|
|
'score', e => this._evtScorePost(e));
|
2016-06-29 18:54:49 +02:00
|
|
|
this._view.sidebarControl.addEventListener(
|
|
|
|
'fitModeChange', e => this._evtFitModeChange(e));
|
2016-07-03 13:46:49 +02:00
|
|
|
this._view.sidebarControl.addEventListener(
|
|
|
|
'change', e => this._evtPostChange(e));
|
|
|
|
this._view.sidebarControl.addEventListener(
|
2016-08-22 20:45:58 +02:00
|
|
|
'submit', e => this._evtUpdatePost(e));
|
2016-08-02 10:37:56 +02:00
|
|
|
this._view.sidebarControl.addEventListener(
|
2016-08-22 20:45:58 +02:00
|
|
|
'feature', e => this._evtFeaturePost(e));
|
2016-08-02 11:05:40 +02:00
|
|
|
this._view.sidebarControl.addEventListener(
|
2016-08-22 20:45:58 +02:00
|
|
|
'delete', e => this._evtDeletePost(e));
|
2016-10-22 10:03:38 +02:00
|
|
|
this._view.sidebarControl.addEventListener(
|
|
|
|
'merge', e => this._evtMergePost(e));
|
2016-06-17 20:25:44 +02:00
|
|
|
}
|
2016-08-22 20:45:58 +02:00
|
|
|
|
2016-12-24 21:49:39 +01:00
|
|
|
if (this._view.commentControl) {
|
|
|
|
this._view.commentControl.addEventListener(
|
2016-06-17 20:25:44 +02:00
|
|
|
'change', e => this._evtCommentChange(e));
|
2016-12-24 21:49:39 +01:00
|
|
|
this._view.commentControl.addEventListener(
|
2016-06-17 20:25:44 +02:00
|
|
|
'submit', e => this._evtCreateComment(e));
|
|
|
|
}
|
2016-08-22 20:45:58 +02:00
|
|
|
|
2016-06-17 20:25:44 +02:00
|
|
|
if (this._view.commentListControl) {
|
|
|
|
this._view.commentListControl.addEventListener(
|
2016-08-22 20:45:58 +02:00
|
|
|
'submit', e => this._evtUpdateComment(e));
|
2016-06-17 20:25:44 +02:00
|
|
|
this._view.commentListControl.addEventListener(
|
|
|
|
'score', e => this._evtScoreComment(e));
|
|
|
|
this._view.commentListControl.addEventListener(
|
|
|
|
'delete', e => this._evtDeleteComment(e));
|
|
|
|
}
|
2017-01-08 02:12:38 +01:00
|
|
|
}, error => {
|
2016-06-14 10:31:48 +02:00
|
|
|
this._view = new EmptyView();
|
2017-01-08 02:12:38 +01:00
|
|
|
this._view.showError(error.message);
|
2016-06-06 20:57:22 +02:00
|
|
|
});
|
2016-03-19 21:37:04 +01:00
|
|
|
}
|
|
|
|
|
2016-06-29 18:54:49 +02:00
|
|
|
_evtFitModeChange(e) {
|
|
|
|
const browsingSettings = settings.get();
|
|
|
|
browsingSettings.fitMode = e.detail.mode;
|
|
|
|
settings.save(browsingSettings);
|
|
|
|
}
|
|
|
|
|
2016-08-22 20:45:58 +02:00
|
|
|
_evtFeaturePost(e) {
|
2016-08-02 10:37:56 +02:00
|
|
|
this._view.sidebarControl.disableForm();
|
|
|
|
this._view.sidebarControl.clearMessages();
|
|
|
|
e.detail.post.feature()
|
|
|
|
.then(() => {
|
|
|
|
this._view.sidebarControl.showSuccess('Post featured.');
|
|
|
|
this._view.sidebarControl.enableForm();
|
2017-01-08 02:12:38 +01:00
|
|
|
}, error => {
|
|
|
|
this._view.sidebarControl.showError(error.message);
|
2016-08-02 10:37:56 +02:00
|
|
|
this._view.sidebarControl.enableForm();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2016-10-22 10:03:38 +02:00
|
|
|
_evtMergePost(e) {
|
2017-01-20 21:51:04 +01:00
|
|
|
router.show(uri.formatClientLink('post', e.detail.post.id, 'merge'));
|
2016-10-22 10:03:38 +02:00
|
|
|
}
|
|
|
|
|
2016-08-22 20:45:58 +02:00
|
|
|
_evtDeletePost(e) {
|
2016-08-02 11:05:40 +02:00
|
|
|
this._view.sidebarControl.disableForm();
|
|
|
|
this._view.sidebarControl.clearMessages();
|
|
|
|
e.detail.post.delete()
|
|
|
|
.then(() => {
|
|
|
|
misc.disableExitConfirmation();
|
2017-01-20 21:51:04 +01:00
|
|
|
const ctx = router.show(uri.formatClientLink('posts'));
|
2016-08-02 11:05:40 +02:00
|
|
|
ctx.controller.showSuccess('Post deleted.');
|
2017-01-08 02:12:38 +01:00
|
|
|
}, error => {
|
|
|
|
this._view.sidebarControl.showError(error.message);
|
2016-08-02 11:05:40 +02:00
|
|
|
this._view.sidebarControl.enableForm();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2016-08-22 20:45:58 +02:00
|
|
|
_evtUpdatePost(e) {
|
2016-07-30 16:13:07 +02:00
|
|
|
this._view.sidebarControl.disableForm();
|
2016-07-31 23:55:22 +02:00
|
|
|
this._view.sidebarControl.clearMessages();
|
2016-07-03 13:46:49 +02:00
|
|
|
const post = e.detail.post;
|
2016-07-26 19:58:26 +02:00
|
|
|
if (e.detail.safety !== undefined) {
|
|
|
|
post.safety = e.detail.safety;
|
|
|
|
}
|
2016-07-26 20:37:55 +02:00
|
|
|
if (e.detail.flags !== undefined) {
|
|
|
|
post.flags = e.detail.flags;
|
|
|
|
}
|
2016-07-26 19:58:26 +02:00
|
|
|
if (e.detail.relations !== undefined) {
|
|
|
|
post.relations = e.detail.relations;
|
|
|
|
}
|
2016-07-27 22:27:33 +02:00
|
|
|
if (e.detail.content !== undefined) {
|
2016-08-20 22:40:25 +02:00
|
|
|
post.newContent = e.detail.content;
|
2016-07-27 22:27:33 +02:00
|
|
|
}
|
2016-07-28 19:28:48 +02:00
|
|
|
if (e.detail.thumbnail !== undefined) {
|
2016-08-20 22:40:25 +02:00
|
|
|
post.newThumbnail = e.detail.thumbnail;
|
2016-07-28 19:28:48 +02:00
|
|
|
}
|
2018-12-27 10:22:36 +01:00
|
|
|
if (e.detail.source !== undefined) {
|
|
|
|
post.source = e.detail.source;
|
|
|
|
}
|
2016-07-03 13:46:49 +02:00
|
|
|
post.save()
|
|
|
|
.then(() => {
|
2016-07-30 16:13:07 +02:00
|
|
|
this._view.sidebarControl.showSuccess('Post saved.');
|
|
|
|
this._view.sidebarControl.enableForm();
|
2016-07-03 13:46:49 +02:00
|
|
|
misc.disableExitConfirmation();
|
2017-01-08 02:12:38 +01:00
|
|
|
}, error => {
|
|
|
|
this._view.sidebarControl.showError(error.message);
|
2016-07-30 16:13:07 +02:00
|
|
|
this._view.sidebarControl.enableForm();
|
2016-07-03 13:46:49 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
_evtPostChange(e) {
|
|
|
|
misc.enableExitConfirmation();
|
|
|
|
}
|
|
|
|
|
2016-06-17 20:25:44 +02:00
|
|
|
_evtCommentChange(e) {
|
|
|
|
misc.enableExitConfirmation();
|
|
|
|
}
|
|
|
|
|
|
|
|
_evtCreateComment(e) {
|
2016-12-24 21:49:39 +01:00
|
|
|
this._view.commentControl.disableForm();
|
2016-06-17 20:25:44 +02:00
|
|
|
const comment = Comment.create(this._post.id);
|
|
|
|
comment.text = e.detail.text;
|
|
|
|
comment.save()
|
|
|
|
.then(() => {
|
|
|
|
this._post.comments.add(comment);
|
2016-12-24 21:49:39 +01:00
|
|
|
this._view.commentControl.exitEditMode();
|
|
|
|
this._view.commentControl.enableForm();
|
2016-06-17 20:25:44 +02:00
|
|
|
misc.disableExitConfirmation();
|
2017-01-08 02:12:38 +01:00
|
|
|
}, error => {
|
|
|
|
this._view.commentControl.showError(error.message);
|
2016-12-24 21:49:39 +01:00
|
|
|
this._view.commentControl.enableForm();
|
2016-06-17 20:25:44 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
_evtUpdateComment(e) {
|
|
|
|
// TODO: disable form
|
|
|
|
e.detail.comment.text = e.detail.text;
|
|
|
|
e.detail.comment.save()
|
2017-01-08 02:12:38 +01:00
|
|
|
.catch(error => {
|
|
|
|
e.detail.target.showError(error.message);
|
2016-06-17 20:25:44 +02:00
|
|
|
// TODO: enable form
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
_evtScoreComment(e) {
|
|
|
|
e.detail.comment.setScore(e.detail.score)
|
2017-01-08 02:12:38 +01:00
|
|
|
.catch(error => window.alert(error.message));
|
2016-06-17 20:25:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
_evtDeleteComment(e) {
|
|
|
|
e.detail.comment.delete()
|
2017-01-08 02:12:38 +01:00
|
|
|
.catch(error => window.alert(error.message));
|
2016-06-17 20:25:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
_evtScorePost(e) {
|
2016-08-23 21:30:53 +02:00
|
|
|
if (!api.hasPrivilege('posts:score')) {
|
|
|
|
return;
|
|
|
|
}
|
2016-06-17 20:25:44 +02:00
|
|
|
e.detail.post.setScore(e.detail.score)
|
2017-01-08 02:12:38 +01:00
|
|
|
.catch(error => window.alert(error.message));
|
2016-06-17 20:25:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
_evtFavoritePost(e) {
|
2016-08-23 21:30:53 +02:00
|
|
|
if (!api.hasPrivilege('posts:favorite')) {
|
|
|
|
return;
|
|
|
|
}
|
2016-06-17 20:25:44 +02:00
|
|
|
e.detail.post.addToFavorites()
|
2017-01-08 02:12:38 +01:00
|
|
|
.catch(error => window.alert(error.message));
|
2016-06-17 20:25:44 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
_evtUnfavoritePost(e) {
|
2016-08-23 21:30:53 +02:00
|
|
|
if (!api.hasPrivilege('posts:favorite')) {
|
|
|
|
return;
|
|
|
|
}
|
2016-06-17 20:25:44 +02:00
|
|
|
e.detail.post.removeFromFavorites()
|
2017-01-08 02:12:38 +01:00
|
|
|
.catch(error => window.alert(error.message));
|
2016-06-17 20:25:44 +02:00
|
|
|
}
|
2016-03-19 21:37:04 +01:00
|
|
|
}
|
|
|
|
|
2016-06-14 10:31:48 +02:00
|
|
|
module.exports = router => {
|
2017-01-20 21:51:04 +01:00
|
|
|
router.enter(['post', ':id', 'edit'],
|
2016-06-18 11:39:54 +02:00
|
|
|
(ctx, next) => {
|
2016-07-17 19:00:30 +02:00
|
|
|
// restore parameters from history state
|
|
|
|
if (ctx.state.parameters) {
|
|
|
|
Object.assign(ctx.parameters, ctx.state.parameters);
|
|
|
|
}
|
2016-10-22 10:03:38 +02:00
|
|
|
ctx.controller = new PostMainController(ctx, true);
|
2016-06-18 11:39:54 +02:00
|
|
|
});
|
|
|
|
router.enter(
|
2017-01-20 21:51:04 +01:00
|
|
|
['post', ':id'],
|
2016-06-18 11:39:54 +02:00
|
|
|
(ctx, next) => {
|
2016-07-07 22:13:58 +02:00
|
|
|
// restore parameters from history state
|
|
|
|
if (ctx.state.parameters) {
|
|
|
|
Object.assign(ctx.parameters, ctx.state.parameters);
|
|
|
|
}
|
2016-10-22 10:03:38 +02:00
|
|
|
ctx.controller = new PostMainController(ctx, false);
|
2016-06-18 11:39:54 +02:00
|
|
|
});
|
2016-06-14 10:31:48 +02:00
|
|
|
};
|