'use strict';
const router = require('../router.js');
const misc = require('../util/misc.js');
const topNavigation = require('../models/top_navigation.js');
const Post = require('../models/post.js');
const PostUploadView = require('../views/post_upload_view.js');
class PostUploadController {
constructor() {
topNavigation.activate('upload');
topNavigation.setTitle('Upload');
this._view = new PostUploadView();
this._view.addEventListener('change', e => this._evtChange(e));
this._view.addEventListener('submit', e => this._evtSubmit(e));
}
_evtChange(e) {
if (e.detail.uploadables.length) {
misc.enableExitConfirmation();
} else {
misc.disableExitConfirmation();
this._view.clearMessages();
_evtSubmit(e) {
this._view.disableForm();
e.detail.uploadables.reduce((promise, uploadable) => {
return promise.then(
() => {
let post = new Post();
post.safety = uploadable.safety;
if (uploadable.url) {
post.newContentUrl = uploadable.url;
post.newContent = uploadable.file;
return post.save(uploadable.anonymous)
.then(() => {
this._view.removeUploadable(uploadable);
return Promise.resolve();
});
}, Promise.resolve()).then(
const ctx = router.show('/posts');
ctx.controller.showSuccess('Posts uploaded.');
}, errorMessage => {
this._view.showError(errorMessage);
this._view.enableForm();
return Promise.reject();
module.exports = router => {
router.enter('/upload', (ctx, next) => {
ctx.controller = new PostUploadController();
};