mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2025-04-02 16:21:01 -04:00
Spell palette cool with multiple items offering same skills.
This commit is contained in:
parent
025780a575
commit
ba6565395e
2 changed files with 8 additions and 2 deletions
app/views/play/level
|
@ -427,6 +427,7 @@ module.exports = class PlayLevelView extends RootView
|
|||
application.tracker?.trackTiming victoryTime, 'Level Victory Time', @levelID, @levelID, 100
|
||||
|
||||
showVictory: ->
|
||||
@endHighlight()
|
||||
options = {level: @level, supermodel: @supermodel, session: @session}
|
||||
ModalClass = if @level.get('type', true) in ['hero', 'hero-ladder', 'hero-coop'] then HeroVictoryModal else VictoryModal
|
||||
victoryModal = new ModalClass(options)
|
||||
|
|
|
@ -129,6 +129,7 @@ module.exports = class SpellPaletteView extends CocoView
|
|||
storages = [storages] if _.isString storages
|
||||
for storage in storages
|
||||
props = _.reject @thang[storage] ? [], (prop) -> prop[0] is '_' # no private properties
|
||||
props = _.uniq props
|
||||
added = _.sortBy(props).slice()
|
||||
propGroups[owner] = (propGroups[owner] ? []).concat added
|
||||
count += added.length
|
||||
|
@ -181,14 +182,18 @@ module.exports = class SpellPaletteView extends CocoView
|
|||
propsByItem = {}
|
||||
propCount = 0
|
||||
itemsByProp = {}
|
||||
for slot, thangTypeName of @thang.inventoryThangTypeNames ? {}
|
||||
# Make sure that we get the spellbook first, then the primary hand, then anything else.
|
||||
slots = _.sortBy _.keys(@thang.inventoryThangTypeNames ? {}), (slot) ->
|
||||
if slot is 'left-hand' then 0 else if slot is 'right-hand' then 1 else 2
|
||||
for slot in slots
|
||||
thangTypeName = @thang.inventoryThangTypeNames[slot]
|
||||
if item = itemThangTypes[thangTypeName]
|
||||
unless item.get('components')
|
||||
console.error 'Item', item, 'did not have any components when we went to assemble docs.'
|
||||
for component in item.get('components') ? [] when component.config
|
||||
for owner, storages of propStorage
|
||||
if props = component.config[storages]
|
||||
for prop in _.sortBy(props) when prop[0] isnt '_' # no private properties
|
||||
for prop in _.sortBy(props) when prop[0] isnt '_' and not itemsByProp[prop] # no private properties
|
||||
propsByItem[item.get('name')] ?= []
|
||||
propsByItem[item.get('name')].push owner: owner, prop: prop, item: item
|
||||
itemsByProp[prop] = item
|
||||
|
|
Loading…
Add table
Reference in a new issue