mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-15 05:37:22 +01:00
* common: import lodash modules separately * remove test/content from .eslintignore, fix with eslint --fix content/index * lint test/content * lint content/index except for lodash methods * upgrade server/models * upgrade server/middlewares and server/libs * port server/controllers/top-level * port server/controllers/api-v3 * port views and tests * client old port lodash and _(, missing _. * upgrade client-old * port common/script (root level files only) * port common/script/fns * port common/libs * port common/script/ops * port common/script/content and common/script/libs/shops.js * misc fixes * misc fixes * misc fixes * more tests fixes * fix payments test stubbing, down to 2 failing tests * remove more instances of lodash wrapping * fix bug where toObject does not clone object * fix tests * upgrade migration or add lodash 4 note * update shrinkwrap * fix linting * upgrade eslint-config-habitrpg * update shrinkwrap * recompile shrinkwrap
79 lines
2.3 KiB
JavaScript
79 lines
2.3 KiB
JavaScript
import i18n from '../i18n';
|
|
import get from 'lodash/get';
|
|
import each from 'lodash/each';
|
|
import findLast from 'lodash/findLast';
|
|
import pick from 'lodash/pick';
|
|
import splitWhitespace from '../libs/splitWhitespace';
|
|
import { capByLevel } from '../statHelpers';
|
|
import {
|
|
NotAuthorized,
|
|
} from '../libs/errors';
|
|
|
|
module.exports = function changeClass (user, req = {}, analytics) {
|
|
let klass = get(req, 'query.class');
|
|
|
|
// user.flags.classSelected is set to false after the user paid the 3 gems
|
|
if (user.stats.lvl < 10) {
|
|
throw new NotAuthorized(i18n.t('lvl10ChangeClass', req.language));
|
|
} else if (!user.flags.classSelected && (klass === 'warrior' || klass === 'rogue' || klass === 'wizard' || klass === 'healer')) {
|
|
user.stats.class = klass;
|
|
user.flags.classSelected = true;
|
|
|
|
each(['weapon', 'armor', 'shield', 'head'], (type) => {
|
|
let foundKey = false;
|
|
findLast(user.items.gear.owned, (val, key) => {
|
|
if (key.indexOf(`${type}_${klass}`) !== -1 && val === true) {
|
|
foundKey = key;
|
|
return true;
|
|
}
|
|
});
|
|
|
|
if (!foundKey) {
|
|
if (type === 'weapon') {
|
|
foundKey = `weapon_${klass}_0`;
|
|
} else if (type === 'shield' && klass === 'rogue') {
|
|
foundKey = 'shield_rogue_0';
|
|
} else {
|
|
foundKey = `${type}_base_0`;
|
|
}
|
|
}
|
|
|
|
user.items.gear.equipped[type] = foundKey;
|
|
|
|
if (type === 'weapon' || (type === 'shield' && klass === 'rogue')) { // eslint-disable-line no-extra-parens
|
|
user.items.gear.owned[`${type}_${klass}_0`] = true;
|
|
}
|
|
});
|
|
|
|
if (analytics) {
|
|
analytics.track('change class', {
|
|
uuid: user._id,
|
|
class: klass,
|
|
acquireMethod: 'Gems',
|
|
gemCost: 3,
|
|
category: 'behavior',
|
|
headers: req.headers,
|
|
});
|
|
}
|
|
} else {
|
|
if (user.preferences.disableClasses) {
|
|
user.preferences.disableClasses = false;
|
|
user.preferences.autoAllocate = false;
|
|
} else {
|
|
if (user.balance < 0.75) throw new NotAuthorized(i18n.t('notEnoughGems', req.language));
|
|
user.balance -= 0.75;
|
|
}
|
|
|
|
user.stats.str = 0;
|
|
user.stats.con = 0;
|
|
user.stats.per = 0;
|
|
user.stats.int = 0;
|
|
user.stats.points = capByLevel(user.stats.lvl);
|
|
user.flags.classSelected = false;
|
|
}
|
|
|
|
return [
|
|
pick(user, splitWhitespace('stats flags items preferences')),
|
|
];
|
|
};
|