2013-05-19 17:01:01 +00:00
_ = require ' lodash '
items = module.exports.items =
weapon: [
{ index: 0 , text: " Training Sword " , classes: " weapon_0 " , notes : ' Training weapon. ' , strength: 0 , value : 0 }
{ index: 1 , text: " Sword " , classes : ' weapon_1 ' , notes : ' Increases experience gain by 3%. ' , strength: 3 , value : 20 }
{ index: 2 , text: " Axe " , classes : ' weapon_2 ' , notes : ' Increases experience gain by 6%. ' , strength: 6 , value : 30 }
{ index: 3 , text: " Morningstar " , classes : ' weapon_3 ' , notes : ' Increases experience gain by 9%. ' , strength: 9 , value : 45 }
{ index: 4 , text: " Blue Sword " , classes : ' weapon_4 ' , notes : ' Increases experience gain by 12%. ' , strength: 12 , value : 65 }
{ index: 5 , text: " Red Sword " , classes : ' weapon_5 ' , notes : ' Increases experience gain by 15%. ' , strength: 15 , value : 90 }
{ index: 6 , text: " Golden Sword " , classes : ' weapon_6 ' , notes : ' Increases experience gain by 18%. ' , strength: 18 , value : 120 }
2013-11-07 21:11:35 +00:00
{ index: 7 , text: " Dark Souls Blade " , classes : ' weapon_7 ' , notes : ' Increases experience gain by 21%. ' , strength: 21 , value : 150 , canOwn: ( (u)-> + u . backer ? . tier >= 70 ) }
{ index: 8 , text: " Crystal Blade " , classes : ' weapon_8 ' , notes : ' Increases experience gain by 24%. ' , strength: 24 , value : 170 , canOwn: ( (u)-> + u . contributor ? . level >= 4 ) }
2013-05-19 17:01:01 +00:00
]
armor: [
{ index: 0 , text: " Cloth Armor " , classes: ' armor_0 ' , notes : ' Training armor. ' , defense: 0 , value : 0 }
{ index: 1 , text: " Leather Armor " , classes: ' armor_1 ' , notes : ' Decreases HP loss by 4%. ' , defense: 4 , value : 30 }
{ index: 2 , text: " Chain Mail " , classes: ' armor_2 ' , notes : ' Decreases HP loss by 6%. ' , defense: 6 , value : 45 }
{ index: 3 , text: " Plate Mail " , classes: ' armor_3 ' , notes : ' Decreases HP loss by 7%. ' , defense: 7 , value : 65 }
{ index: 4 , text: " Red Armor " , classes: ' armor_4 ' , notes : ' Decreases HP loss by 8%. ' , defense: 8 , value : 90 }
{ index: 5 , text: " Golden Armor " , classes: ' armor_5 ' , notes : ' Decreases HP loss by 10%. ' , defense: 10 , value : 120 }
2013-11-07 21:11:35 +00:00
{ index: 6 , text: " Shade Armor " , classes: ' armor_6 ' , notes : ' Decreases HP loss by 12%. ' , defense: 12 , value : 150 , canOwn: ( (u)-> + u . backer ? . tier >= 45 ) }
{ index: 7 , text: " Crystal Armor " , classes: ' armor_7 ' , notes : ' Decreases HP loss by 14%. ' , defense: 14 , value : 170 , canOwn: ( (u)-> + u . contributor ? . level >= 2 ) }
2013-05-19 17:01:01 +00:00
]
head: [
{ index: 0 , text: " No Helm " , classes: ' head_0 ' , notes : ' Training helm. ' , defense: 0 , value : 0 }
{ index: 1 , text: " Leather Helm " , classes: ' head_1 ' , notes : ' Decreases HP loss by 2%. ' , defense: 2 , value : 15 }
{ index: 2 , text: " Chain Coif " , classes: ' head_2 ' , notes : ' Decreases HP loss by 3%. ' , defense: 3 , value : 25 }
{ index: 3 , text: " Plate Helm " , classes: ' head_3 ' , notes : ' Decreases HP loss by 4%. ' , defense: 4 , value : 45 }
{ index: 4 , text: " Red Helm " , classes: ' head_4 ' , notes : ' Decreases HP loss by 5%. ' , defense: 5 , value : 60 }
{ index: 5 , text: " Golden Helm " , classes: ' head_5 ' , notes : ' Decreases HP loss by 6%. ' , defense: 6 , value : 80 }
2013-11-07 21:11:35 +00:00
{ index: 6 , text: " Shade Helm " , classes: ' head_6 ' , notes : ' Decreases HP loss by 7%. ' , defense: 7 , value : 100 , canOwn: ( (u)-> + u . backer ? . tier >= 45 ) }
{ index: 7 , text: " Crystal Helm " , classes: ' head_7 ' , notes : ' Decreases HP loss by 8%. ' , defense: 8 , value : 120 , canOwn: ( (u)-> + u . contributor ? . level >= 3 ) }
2013-05-19 17:01:01 +00:00
]
shield: [
{ index: 0 , text: " No Shield " , classes: ' shield_0 ' , notes : ' No Shield. ' , defense: 0 , value : 0 }
{ index: 1 , text: " Wooden Shield " , classes: ' shield_1 ' , notes : ' Decreases HP loss by 3% ' , defense: 3 , value : 20 }
{ index: 2 , text: " Buckler " , classes: ' shield_2 ' , notes : ' Decreases HP loss by 4%. ' , defense: 4 , value : 35 }
2013-05-26 06:29:31 +00:00
{ index: 3 , text: " Reinforced Shield " , classes: ' shield_3 ' , notes : ' Decreases HP loss by 5%. ' , defense: 5 , value : 55 }
2013-05-19 17:01:01 +00:00
{ index: 4 , text: " Red Shield " , classes: ' shield_4 ' , notes : ' Decreases HP loss by 7%. ' , defense: 7 , value : 70 }
{ index: 5 , text: " Golden Shield " , classes: ' shield_5 ' , notes : ' Decreases HP loss by 8%. ' , defense: 8 , value : 90 }
2013-11-07 21:11:35 +00:00
{ index: 6 , text: " Tormented Skull " , classes: ' shield_6 ' , notes : ' Decreases HP loss by 9%. ' , defense: 9 , value : 120 , canOwn: ( (u)-> + u . backer ? . tier >= 45 ) }
{ index: 7 , text: " Crystal Shield " , classes: ' shield_7 ' , notes : ' Decreases HP loss by 10%. ' , defense: 10 , value : 150 , canOwn: ( (u)-> + u . contributor ? . level >= 5 ) }
2013-05-19 17:01:01 +00:00
]
2013-05-22 10:14:59 +00:00
potion: { type: ' potion ' , text: " Potion " , notes: " Recover 15 HP (Instant Use) " , value: 25 , classes: ' potion ' }
2013-05-19 17:01:01 +00:00
reroll: { type: ' reroll ' , text: " Re-Roll " , classes: ' reroll ' , notes: " Resets your task values back to 0 (yellow). Useful when everything ' s red and it ' s hard to stay alive. " , value : 0 }
2013-11-10 21:25:13 +00:00
eggs:
2013-11-14 00:45:08 +00:00
# value & other defaults set below
Wolf: text: ' Wolf '
TigerCub: text: ' Tiger Cub ' , mountText: ' Tiger '
PandaCub: text: ' Panda Cub ' , mountText: ' Panda '
LionCub: text: ' Lion Cub ' , mountText: ' Lion '
2013-11-11 03:38:06 +00:00
Fox: text: ' Fox '
FlyingPig: text: ' Flying Pig '
Dragon: text: ' Dragon '
Cactus: text: ' Cactus '
2013-11-14 00:45:08 +00:00
BearCub: text: ' Bear Cub ' , mountText: ' Bear '
2013-11-11 03:38:06 +00:00
#{text: 'Polar Bear Cub', name: 'PolarBearCub', value: 3}
2013-05-19 17:01:01 +00:00
2013-11-10 21:25:13 +00:00
hatchingPotions:
2013-11-14 20:34:11 +00:00
Base: value: 2 , text: ' Base '
2013-11-14 20:12:49 +00:00
White: value: 2 , text: ' White '
Desert: value: 2 , text: ' Desert '
Red: value: 3 , text: ' Red '
Shade: value: 3 , text: ' Shade '
Skeleton: value: 3 , text: ' Skeleton '
Zombie: value: 4 , text: ' Zombie '
CottonCandyPink: value: 4 , text: ' Cotton Candy Pink '
CottonCandyBlue: value: 4 , text: ' Cotton Candy Blue '
Golden: value: 5 , text: ' Golden '
2013-11-10 21:25:13 +00:00
food:
2013-11-11 03:38:06 +00:00
Meat: text: ' Meat ' , target: ' Base '
Milk: text: ' Milk ' , target: ' White '
Potatoe: text: ' Potatoe ' , target: ' Desert '
Strawberry: text: ' Strawberry ' , target: ' Red '
Chocolate: text: ' Chocolate ' , target: ' Shade '
Fish: text: ' Fish ' , target: ' Skeleton '
RottenMeat: text: ' Rotten Meat ' , target: ' Zombie '
CottonCandyPink: text: ' Pink Cotton Candy ' , target: ' CottonCandyPink '
CottonCandyBlue: text: ' Blue Cotton Candy ' , target: ' CottonCandyBlue '
Honey: text: ' Honey ' , target: ' Golden '
# FIXME what to do with these extra items? Should we add "targets" (plural) for food instead of singular, so we don't have awkward extras?
#Cheese: text: 'Cheese', target: 'Golden'
#Watermelon: text: 'Watermelon', target: 'Golden'
#SeaWeed: text: 'SeaWeed', target: 'Golden'
Saddle: text: ' Saddle ' , value: 5 , notes: ' Instantly raises your pet into a mount. '
2013-05-19 17:01:01 +00:00
2013-11-07 21:11:35 +00:00
# we somtimes want item arrays above in reverse order, for backward lookups (you'll see later in the code)
reversed = { }
_ . each [ ' weapon ' , ' armor ' , ' head ' , ' shield ' ] , (type) ->
reversed [ type ] = items [ type ] . slice ( ) . reverse ( )
# add "type" to each item, so we can reference that as "weapon" or "armor" in the html
# Also add canOwn(), which we use when comparing if user is a backer or contributor - but defaulted to `return true`
_ . each items [ type ] , (item) -> _ . defaults ( item , { type , canOwn: -> true } )
2013-05-19 17:01:01 +00:00
2013-11-11 03:38:06 +00:00
_ . each items . eggs , (egg,k) ->
2013-11-14 00:45:08 +00:00
_ . defaults egg ,
value: 3
name: k
notes: ' Find a hatching potion to pour on this egg, and it will hatch into a loyal pet. '
mountText: egg . text
2013-11-11 03:38:06 +00:00
_ . each items . hatchingPotions , (pot,k) ->
2013-11-14 20:12:49 +00:00
_ . defaults pot , { name: k , value: 2 , notes: " Pour this on an egg, and it will hatch as a #{ pot . text } pet. " }
2013-11-11 03:38:06 +00:00
_ . each items . food , (food,k) ->
_ . defaults food , { value: 1 , name: k , notes: " Feed this to a pet and it may grown into a sturdy steed. " }
2013-05-19 17:01:01 +00:00
2013-11-07 21:11:35 +00:00
module.exports.buyItem = (user, type) ->
2013-08-13 03:26:36 +00:00
nextItem =
2013-11-07 21:11:35 +00:00
if type is ' potion ' then items . potion
else _ . find items [ type ] . slice ( ~ ~ user . items [ type ] + 1 ) , ( (i) -> i . canOwn user )
2013-08-13 03:26:36 +00:00
2013-08-19 00:12:24 +00:00
return false if + user . stats . gp < + nextItem . value
2013-08-13 03:26:36 +00:00
if nextItem . type is ' potion '
user . stats . hp += 15 ;
user.stats.hp = 50 if user . stats . hp > 50
else
2013-08-15 04:12:45 +00:00
user . items [ type ] = ~ ~ nextItem . index
2013-11-07 21:11:35 +00:00
if + user . items . weapon >= 6 and + user . items . armor >= 5 and + user . items . head >= 5 and + user . items . shield >= 5
2013-10-27 11:13:06 +00:00
user.achievements.ultimateGear = true ;
2013-08-15 04:12:45 +00:00
user . stats . gp -= + nextItem . value
2013-08-13 03:26:36 +00:00
true
2013-05-19 17:01:01 +00:00
# ##
update store
# ##
module.exports.updateStore = (user) ->
changes = { }
_ . each [ ' weapon ' , ' armor ' , ' shield ' , ' head ' ] , (type) ->
2013-11-07 21:11:35 +00:00
# Find the first item that fits the "next" bill, from between current item and end of the list
curr = user . items ? [ type ] or 0
changes [ type ] = _ . find ( items [ type ] . slice ( curr + 1 ) , ( (item) -> item . canOwn user ) ) or { hide : true }
2013-08-25 18:53:45 +00:00
changes.potion = items . potion
changes.reroll = items . reroll
changes
2013-07-24 20:45:48 +00:00
# ##
2013-11-07 21:11:35 +00:00
Gets an item , and caps max to the last item in its array
2013-07-24 20:45:48 +00:00
# ##
module.exports.getItem = (type, index=0) ->
2013-11-07 21:11:35 +00:00
# if they set their gear manually to something over what they can own, just set to 0 to avoid errors
i = if ( ~ ~ index > items [ type ] . length - 1 ) then 0 else ~ ~ index
2013-08-05 02:32:41 +00:00
items [ type ] [ i ]
2013-11-07 21:11:35 +00:00
# ##
User ' s currently equiped item
TODO this function is ugly , find a more elegant solution
# ##
module.exports.equipped = (type, item=0, pref={gender:'m', armorSet:'v1'}, backer={}, contributor={}) ->
lastStandardItem = items [ type ] . length - 3 # -1 for 0-based index, -2 for backer + contrib
if ( item > lastStandardItem ) and ! items [ type ] [ item ] ? . canOwn ( { backer , contributor } )
# They entered a # above what's legal in the restore dialog, find first legit item. (we should do checking on the restore-save instead)
item = _ . find ( reversed [ type ] , ( (i) -> i . canOwn ( { backer , contributor } ) ) ) . index
# backer / contrib (they don't have gender)
return " #{ type } _ #{ item } " if ( item > lastStandardItem )
# Females have some special thing going on for their armor / helms
if ( type in [ ' armor ' , ' head ' ] and pref . gender is ' f ' )
return " f_armor_ #{ item } _ #{ pref . armorSet } " if ( item is 0 and type is ' armor ' )
return " f_head_ #{ item } _ #{ pref . armorSet } " if ( item > 1 and type is ' head ' )
return " #{ pref . gender } _ #{ type } _ #{ item } "