|
|
@ -25,8 +25,10 @@ class NewsletterController extends SiteController { |
|
|
|
|
|
|
|
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('/', 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) { |
|
|
|
res.render('admin/newsletter/editor'); |
|
|
|
} |
|
|
@ -53,7 +77,7 @@ class NewsletterController extends SiteController { |
|
|
|
const { newsletter: newsletterService } = this.dtp.services; |
|
|
|
try { |
|
|
|
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'); |
|
|
|
} catch (error) { |
|
|
|
return next(error); |
|
|
|