mirror of
https://github.com/HabitRPG/habitica.git
synced 2025-12-17 14:47:53 +01:00
244 lines
6.9 KiB
JavaScript
244 lines
6.9 KiB
JavaScript
import _ from 'lodash';
|
|
import content from '../content/index';
|
|
import i18n from '../i18n';
|
|
|
|
let shops = {};
|
|
|
|
function lockQuest (quest, user) {
|
|
if (quest.lvl && user.stats.lvl < quest.lvl) return true;
|
|
if (user.achievements.quests) return quest.previous && !user.achievements.quests[quest.previous];
|
|
return quest.previous;
|
|
}
|
|
|
|
shops.getMarketCategories = function getMarket (user, language) {
|
|
let categories = [];
|
|
let eggsCategory = {
|
|
identifier: 'eggs',
|
|
text: i18n.t('eggs', language),
|
|
notes: i18n.t('dropsExplanation', language),
|
|
};
|
|
|
|
eggsCategory.items = _(content.questEggs)
|
|
.values()
|
|
.filter(egg => egg.canBuy(user))
|
|
.concat(_.values(content.dropEggs))
|
|
.map(egg => {
|
|
return {
|
|
key: egg.key,
|
|
text: i18n.t('egg', {eggType: egg.text()}, language),
|
|
notes: egg.notes(language),
|
|
value: egg.value,
|
|
class: `Pet_Egg_${egg.key}`,
|
|
locked: false,
|
|
currency: 'gems',
|
|
purchaseType: 'eggs',
|
|
};
|
|
}).sortBy('key').value();
|
|
categories.push(eggsCategory);
|
|
|
|
let hatchingPotionsCategory = {
|
|
identifier: 'hatchingPotions',
|
|
text: i18n.t('hatchingPotions', language),
|
|
notes: i18n.t('dropsExplanation', language),
|
|
};
|
|
hatchingPotionsCategory.items = _(content.hatchingPotions)
|
|
.values()
|
|
.filter(hp => !hp.limited)
|
|
.map(hatchingPotion => {
|
|
return {
|
|
key: hatchingPotion.key,
|
|
text: hatchingPotion.text(language),
|
|
notes: hatchingPotion.notes(language),
|
|
class: `Pet_HatchingPotion_${hatchingPotion.key}`,
|
|
value: hatchingPotion.value,
|
|
locked: false,
|
|
currency: 'gems',
|
|
purchaseType: 'hatchingpotions',
|
|
};
|
|
}).sortBy('key').value();
|
|
categories.push(hatchingPotionsCategory);
|
|
|
|
let foodCategory = {
|
|
identifier: 'food',
|
|
text: i18n.t('food', language),
|
|
notes: i18n.t('dropsExplanation', language),
|
|
};
|
|
foodCategory.items = _(content.food)
|
|
.values()
|
|
.filter(food => food.canDrop || food.key === 'Saddle')
|
|
.map(foodItem => {
|
|
return {
|
|
key: foodItem.key,
|
|
text: foodItem.text(language),
|
|
notes: foodItem.notes(language),
|
|
class: `Pet_Food_${foodItem.key}`,
|
|
value: foodItem.value,
|
|
locked: false,
|
|
currency: 'gems',
|
|
purchaseType: 'food',
|
|
};
|
|
}).sortBy('key').value();
|
|
categories.push(foodCategory);
|
|
|
|
return categories;
|
|
};
|
|
|
|
shops.getQuestShopCategories = function getQuestShopCategories (user, language) {
|
|
let categories = [];
|
|
|
|
_.each(content.userCanOwnQuestCategories, type => {
|
|
let category = {
|
|
identifier: type,
|
|
text: i18n.t(`${type}Quests`, language),
|
|
};
|
|
|
|
category.items = _(content.questsByLevel)
|
|
.filter(quest => quest.canBuy(user) && quest.category === type)
|
|
.map(quest => {
|
|
let locked = lockQuest(quest, user);
|
|
return {
|
|
key: quest.key,
|
|
text: quest.text(language),
|
|
notes: quest.notes(language),
|
|
value: quest.goldValue ? quest.goldValue : quest.value,
|
|
currency: quest.goldValue ? 'gold' : 'gems',
|
|
locked,
|
|
unlockCondition: quest.unlockCondition,
|
|
drop: quest.drop,
|
|
boss: quest.boss,
|
|
collect: quest.collect,
|
|
lvl: quest.lvl,
|
|
class: locked ? `inventory_quest_scroll_${quest.key}_locked` : `inventory_quest_scroll_${quest.key}`,
|
|
purchaseType: 'quests',
|
|
};
|
|
}).value();
|
|
|
|
categories.push(category);
|
|
});
|
|
|
|
return categories;
|
|
};
|
|
|
|
shops.getTimeTravelersCategories = function getTimeTravelersCategories (user, language) {
|
|
let categories = [];
|
|
let stable = {pets: 'Pet-', mounts: 'Mount_Head_'};
|
|
for (let type in stable) {
|
|
if (stable.hasOwnProperty(type)) {
|
|
let category = {
|
|
identifier: type,
|
|
text: i18n.t(type, language),
|
|
items: [],
|
|
};
|
|
|
|
for (let key in content.timeTravelStable[type]) {
|
|
if (content.timeTravelStable[type].hasOwnProperty(key)) {
|
|
if (!user.items[type][key]) {
|
|
let item = {
|
|
key,
|
|
text: content.timeTravelStable[type][key](language),
|
|
class: stable[type] + key,
|
|
type,
|
|
purchaseType: type,
|
|
value: 1,
|
|
notes: '',
|
|
locked: false,
|
|
currency: 'hourglasses',
|
|
};
|
|
category.items.push(item);
|
|
}
|
|
}
|
|
}
|
|
if (category.items.length > 0) {
|
|
categories.push(category);
|
|
}
|
|
}
|
|
}
|
|
|
|
let sets = content.timeTravelerStore(user.items.gear.owned);
|
|
for (let setKey in sets) {
|
|
if (sets.hasOwnProperty(setKey)) {
|
|
let set = sets[setKey];
|
|
let category = {
|
|
identifier: set.key,
|
|
text: set.text(language),
|
|
purchaseAll: true,
|
|
};
|
|
|
|
category.items = _.map(set.items, item => {
|
|
return {
|
|
key: item.key,
|
|
text: item.text(language),
|
|
notes: item.notes(language),
|
|
type: item.type,
|
|
purchaseType: 'gear',
|
|
value: 1,
|
|
locked: false,
|
|
currency: 'hourglasses',
|
|
class: `shop_${item.key}`,
|
|
};
|
|
});
|
|
if (category.items.length > 0) {
|
|
categories.push(category);
|
|
}
|
|
}
|
|
}
|
|
|
|
return categories;
|
|
};
|
|
|
|
// To switch seasons/available inventory, edit the availableSets object to whatever should be sold.
|
|
// let availableSets = {
|
|
// setKey: i18n.t('setTranslationString', language),
|
|
// };
|
|
shops.getSeasonalShopCategories = function getSeasonalShopCategories (user, language) {
|
|
let availableSets = {
|
|
summerWarrior: i18n.t('daringSwashbucklerSet', language),
|
|
summerMage: i18n.t('emeraldMermageSet', language),
|
|
summerHealer: i18n.t('reefSeahealerSet', language),
|
|
summerRogue: i18n.t('roguishPirateSet', language),
|
|
summer2015Warrior: i18n.t('sunfishWarriorSet', language),
|
|
summer2015Mage: i18n.t('shipSoothsayerSet', language),
|
|
summer2015Healer: i18n.t('strappingSailorSet', language),
|
|
summer2015Rogue: i18n.t('reefRenegadeSet', language),
|
|
};
|
|
|
|
let categories = [];
|
|
|
|
let flatGearArray = _.toArray(content.gear.flat);
|
|
|
|
for (let key in availableSets) {
|
|
if (availableSets.hasOwnProperty(key)) {
|
|
let category = {
|
|
identifier: key,
|
|
text: availableSets[key],
|
|
};
|
|
|
|
category.items = _(flatGearArray).filter((gear) => {
|
|
if (gear.index !== key) {
|
|
return false;
|
|
}
|
|
return user.items.gear.owned[gear.key] !== true;
|
|
}).where({index: key}).map(gear => {
|
|
return {
|
|
key: gear.key,
|
|
text: gear.text(language),
|
|
notes: gear.notes(language),
|
|
value: 1,
|
|
type: gear.type,
|
|
specialClass: gear.specialClass,
|
|
locked: false,
|
|
currency: 'gems',
|
|
purchaseType: 'gear',
|
|
};
|
|
}).value();
|
|
if (category.items.length > 0) {
|
|
categories.push(category);
|
|
}
|
|
}
|
|
}
|
|
|
|
return categories;
|
|
};
|
|
|
|
module.exports = shops;
|