|
|
@ -25,8 +25,10 @@ class NewsletterController extends SiteController {
|
|
|
|
|
|
|
|
|
|
|
|
router.param('newsletterId', this.populateNewsletterId.bind(this));
|
|
|
|
router.param('newsletterId', this.populateNewsletterId.bind(this));
|
|
|
|
|
|
|
|
|
|
|
|
router.get('/compose', this.getComposer.bind(this));
|
|
|
|
router.post('/:newsletterId', this.postUpdateNewsletter.bind(this));
|
|
|
|
|
|
|
|
router.post('/', this.postCreateNewsletter.bind(this));
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
router.get('/compose', this.getComposer.bind(this));
|
|
|
|
router.get('/:newsletterId', this.getComposer.bind(this));
|
|
|
|
router.get('/:newsletterId', this.getComposer.bind(this));
|
|
|
|
|
|
|
|
|
|
|
|
router.get('/', this.getIndex.bind(this));
|
|
|
|
router.get('/', this.getIndex.bind(this));
|
|
|
@ -45,6 +47,28 @@ class NewsletterController extends SiteController {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async postUpdateNewsletter (req, res, next) {
|
|
|
|
|
|
|
|
const { newsletter: newsletterService } = this.dtp.services;
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
await newsletterService.update(res.locals.newsletter, req.body);
|
|
|
|
|
|
|
|
res.redirect('/admin/newsletter');
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
|
|
|
this.log.error('failed to update newsletter', { newletterId: res.locals.newsletter._id, error });
|
|
|
|
|
|
|
|
return next(error);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async postCreateNewsletter (req, res, next) {
|
|
|
|
|
|
|
|
const { newsletter: newsletterService } = this.dtp.services;
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
const newsletter = await newsletterService.create(req.user, req.body);
|
|
|
|
|
|
|
|
res.redirect(`/admin/newsletter/${newsletter._id}`);
|
|
|
|
|
|
|
|
} catch (error) {
|
|
|
|
|
|
|
|
this.log.error('failed to update newsletter', { error });
|
|
|
|
|
|
|
|
return next(error);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
async getComposer (req, res) {
|
|
|
|
async getComposer (req, res) {
|
|
|
|
res.render('admin/newsletter/editor');
|
|
|
|
res.render('admin/newsletter/editor');
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -53,7 +77,7 @@ class NewsletterController extends SiteController {
|
|
|
|
const { newsletter: newsletterService } = this.dtp.services;
|
|
|
|
const { newsletter: newsletterService } = this.dtp.services;
|
|
|
|
try {
|
|
|
|
try {
|
|
|
|
res.locals.pagination = this.getPaginationParameters(req, 20);
|
|
|
|
res.locals.pagination = this.getPaginationParameters(req, 20);
|
|
|
|
res.locals.newsletters = await newsletterService.getNewsletters(res.locals.pagination);
|
|
|
|
res.locals.newsletters = await newsletterService.getNewsletters(res.locals.pagination, ['draft', 'published']);
|
|
|
|
res.render('admin/newsletter/index');
|
|
|
|
res.render('admin/newsletter/index');
|
|
|
|
} catch (error) {
|
|
|
|
} catch (error) {
|
|
|
|
return next(error);
|
|
|
|
return next(error);
|
|
|
|