mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-14 21:27:23 +01:00
Add Transaction log for gem and hourglass changes (#13589)
* Log all gem transactions to database * Also store hourglass transactions * Fix tests * Display transaction history in hall of heroes for admins * add tests to new API call * hide transaction settings tab for non admins * fix(lint): remove console * fix(lint): various automatic corrections * fix(transactions): use enum expected pluralizations * fix api unit tests * fix lint * fix failing test * Fix minor inconsistencies * Log all gem transactions to database * Also store hourglass transactions * Fix tests * Display transaction history in hall of heroes for admins * add tests to new API call * hide transaction settings tab for non admins * fix(lint): remove console * fix(lint): various automatic corrections * fix(transactions): use enum expected pluralizations * fix api unit tests * fix lint * Fix minor inconsistencies Co-authored-by: Sabe Jones <sabrecat@gmail.com>
This commit is contained in:
@@ -8,8 +8,9 @@ import {
|
||||
BadRequest,
|
||||
} from '../libs/errors';
|
||||
import { removePinnedGearByClass, removePinnedItemsByOwnedGear, addPinnedGearByClass } from './pinnedGearUtils';
|
||||
import updateUserBalance from './updateUserBalance';
|
||||
|
||||
function resetClass (user, req = {}) {
|
||||
async function resetClass (user, req = {}) {
|
||||
removePinnedGearByClass(user);
|
||||
|
||||
let balanceRemoved = 0;
|
||||
@@ -19,7 +20,7 @@ function resetClass (user, req = {}) {
|
||||
user.preferences.autoAllocate = false;
|
||||
} else {
|
||||
if (user.balance < 0.75) throw new NotAuthorized(i18n.t('notEnoughGems', req.language));
|
||||
user.balance -= 0.75;
|
||||
await updateUserBalance(user, -0.75, 'change_class');
|
||||
balanceRemoved = 0.75;
|
||||
}
|
||||
|
||||
@@ -33,7 +34,7 @@ function resetClass (user, req = {}) {
|
||||
return balanceRemoved;
|
||||
}
|
||||
|
||||
export default function changeClass (user, req = {}, analytics) {
|
||||
export default async function changeClass (user, req = {}, analytics) {
|
||||
const klass = get(req, 'query.class');
|
||||
let balanceRemoved = 0;
|
||||
// user.flags.classSelected is set to false after the user paid the 3 gems
|
||||
@@ -42,10 +43,10 @@ export default function changeClass (user, req = {}, analytics) {
|
||||
} else if (!klass) {
|
||||
// if no class is specified, reset points and set user.flags.classSelected to false.
|
||||
// User will have paid 3 gems and will be prompted to select class.
|
||||
balanceRemoved = resetClass(user, req);
|
||||
balanceRemoved = await resetClass(user, req);
|
||||
} else if (klass === 'warrior' || klass === 'rogue' || klass === 'wizard' || klass === 'healer') {
|
||||
if (user.flags.classSelected) {
|
||||
balanceRemoved = resetClass(user, req);
|
||||
balanceRemoved = await resetClass(user, req);
|
||||
}
|
||||
|
||||
user.stats.class = klass;
|
||||
|
||||
Reference in New Issue
Block a user