1 import { Response, Router } from "express";
2 import { getService } from "../map";
3 import { authEndpoint, AuthRequest } from '../auth';
4 import { logger } from "../lib/logger";
5 import * as Alert from "../views/alert";
6 import { changeProfession } from "../player";
7 import { renderPlayerBar } from "../views/player-bar";
8 import { BackToTown } from "../views/components/button";
10 function p(str: string) {
11 return `<p>${str}</p>`;
14 export const router = Router();
18 router.get('/city/services/profession_recruitor/:location_id', authEndpoint, async(req: AuthRequest, res: Response) => {
19 const service = await getService(parseInt(req.params.location_id));
21 if(!service || service.city_id !== req.player.city_id) {
22 logger.log(`Invalid location: [${req.params.location_id}]`);
26 let html: string[] = [];
27 if(req.player.profession === 'Wanderer') {
28 html.push(`<p>Our duty is to help Wanderers such as yourself become more than they are. By helping you achieve new levels in service of the King, we can ensure that the Kingdom of Khatis continues to grow!</p>`);
29 html.push(`<p>You have 3 choices laid before you.</p>`);
30 html.push(`<p>You could become a great and mighty <b>Warrior</b>! Wielding powerful swords and maces.</p>`);
31 html.push(`<p>You could become a powerful <b>Mage</b>! Casting spells to rain fire upon our enemies.</p>`);
32 html.push(`<p>You could become a lithe <b>Rogue</b>! Attacking our enemies swiftly when they least expect!</p>`);
34 if(req.player.level < MIN_LEVEL) {
35 html.push(p(`Unfortunately you have to be at least level ${MIN_LEVEL} to take part in our training...`));
38 html.push(p(`<b>Be Careful!</b> Once you change your profession, you'll never be a Wanderer again...`));
41 <form hx-post="/city/services/profession_change/${service.id}">
42 <button type="submit" value="warrior" name="profession">Become a Warrior</button>
43 <button type="submit" value="mage" name="profession">Become a Mage</button>
44 <button type="submit" value="rogue" name="profession">Become a Rogue</button>
52 let place = 'UNSETPLACE';
53 switch(req.player.profession) {
56 place = 'Highbreaker Inn'
60 place = 'Mages Tower';
64 place = 'Keepers Tavern';
68 html.push(p(`Welcome <b>${req.player.profession}</b>!`));
69 html.push(`<p>Unfortunately I won't be of much help to you now that you are no longer a wanderer...</p>`);
70 html.push(`<p>However, you should visit the ${place} in ${town} that can probably provide some guidance!</p>`);
73 html.push(BackToTown());
75 <div class="city-title-wrapper"><div class="city-title">${service.city_name}</div></div>
76 <div class="city-details">
77 <h3 class="location-name"><span>${service.name}</span></h3>
78 <div class="service-in-town" id="recruiter-target">${html.join("\n")}</div>
83 router.post('/city/services/profession_change/:location_id', authEndpoint, async(req: AuthRequest, res: Response) => {
84 const service = await getService(parseInt(req.params.location_id));
86 if(!service || service.city_id !== req.player.city_id) {
87 logger.log(`Invalid location: [${req.params.location_id}]`);
91 let update: {level: number, exp: number};
93 switch(req.body.profession.toLowerCase()) {
95 update = await changeProfession(req.player.id, 'Warrior');
96 req.player.profession = 'Warrior';
99 update = await changeProfession(req.player.id, 'Mage');
100 req.player.profession = 'Mage';
103 update = await changeProfession(req.player.id, 'Rogue');
104 req.player.profession = 'Rogue';
107 res.send(Alert.ErrorAlert(`Invalid profession`));
112 req.player.level = update.level;
113 req.player.exp = update.exp;
114 res.send(renderPlayerBar(req.player) + `<div id="recruiter-target" class="service-in-town" hx-swap-oob="true">Congrats! You are now a ${req.player.profession}</div>`);