Files
habitica/website/server/controllers/api-v3/news.js
Sabe Jones 048b60f79d chore(news): Bailey
and some seasonal string tweaks
2020-06-18 13:25:56 -05:00

106 lines
3.7 KiB
JavaScript

import { authWithHeaders } from '../../middlewares/auth';
const api = {};
// @TODO export this const, cannot export it from here because only routes are exported from
// controllers
const LAST_ANNOUNCEMENT_TITLE = 'SUMMER SPLASH BEGINS!';
const worldDmg = { // @TODO
bailey: false,
};
/**
* @api {get} /api/v3/news Get latest Bailey announcement
* @apiName GetNews
* @apiGroup News
*
*
* @apiSuccess {Object} html Latest Bailey html
*
*/
api.getNews = {
method: 'GET',
url: '/news',
async handler (req, res) {
const baileyClass = worldDmg.bailey ? 'npc_bailey_broken' : 'npc_bailey';
res.status(200).send({
html: `
<div class="bailey">
<div class="media align-items-center">
<div class="mr-3 ${baileyClass}"></div>
<div class="media-body">
<h1 class="align-self-center">${res.t('newStuff')}</h1>
<h2>6/18/2020 - ${LAST_ANNOUNCEMENT_TITLE}</h2>
</div>
</div>
<hr/>
<p>
To escape the summer heat in Habit City, everyone's moved down to the undersea city of
Dilatory. The Summer Splash event has begun!
</p>
<div class="promo_summer_splash_2020 center-block"></div>
<h3>Summer Class Outfits</h3>
<p>
From now until July 31st, limited edition outfits are available in the Rewards column.
Depending on your class, you can be a Rainbow Trout Warrior, Crocodile Rogue, Oarfish
Mage, or Sea Glass Healer! You'd better get productive to earn enough Gold before they
disappear. Good luck!
</p>
<div class="small mb-3">by Vikte, QuartzFox, jjgame83, and Vyllan</div>
<div class="promo_summer_splash_2019 center-block"></div>
<h3>Seasonal Shop is Open!</h3>
<p>
The <a href='/shops/seasonal'>Seasonal Shop</a> has opened! The Seasonal Sorceress is
stocking the seasonal edition versions of previous summer outfits, now available for Gems
instead of Gold. Plus, there will be more fun things in the shop as the event progresses.
The Seasonal Shop will only be open until July 31st, so don't wait!
</p>
<div class="small mb-3">
by SabreCat, Lemoness, AnnDeLune, Vikte, gawrone, TheDudeAbides, Lalaitha, Beffymaroo,
Vampitch, nonight, tricksy.fox, Giu09, JaizakArpaik, TetoForever, and Kai
</div>
<div class="npc_matt center-block"></div>
<h3>NPC Costumes</h3>
<p>
Looks like the NPCs are really getting in to the cheery summer mood around the site. Who
wouldn't? After all, there's plenty more celebration to come....
</p>
<div class="small mb-3">by Lemoness</div>
</div>
`,
});
},
};
/**
* @api {post} /api/v3/news/tell-me-later Allow latest Bailey announcement to be read later
* @apiName TellMeLaterNews
* @apiDescription Add a notification to allow viewing of the latest "New Stuff by Bailey" message.
* Prevent this specific Bailey message from appearing automatically.
* @apiGroup News
*
*
* @apiSuccess {Object} data An empty Object
*
*/
api.tellMeLaterNews = {
method: 'POST',
middlewares: [authWithHeaders()],
url: '/news/tell-me-later',
async handler (req, res) {
const { user } = res.locals;
user.flags.newStuff = false;
const existingNotificationIndex = user.notifications.findIndex(n => n && n.type === 'NEW_STUFF');
if (existingNotificationIndex !== -1) user.notifications.splice(existingNotificationIndex, 1);
user.addNotification('NEW_STUFF', { title: LAST_ANNOUNCEMENT_TITLE }, true); // seen by default
await user.save();
res.respond(200, {});
},
};
export default api;