codecombat/app/views/play/level/tome/spell_palette_entry_view.coffee

105 lines
3.4 KiB
CoffeeScript
Raw Normal View History

2014-01-03 13:32:13 -05:00
View = require 'views/kinds/CocoView'
template = require 'templates/play/level/tome/spell_palette_entry'
{me} = require 'lib/auth'
filters = require 'lib/image_filter'
DocFormatter = require './doc_formatter'
2014-01-03 13:32:13 -05:00
module.exports = class SpellPaletteEntryView extends View
tagName: 'div' # Could also try <code> instead of <div>, but would need to adjust colors
className: 'spell-palette-entry-view'
template: template
popoverPinned: false
2014-01-03 13:32:13 -05:00
subscriptions:
'surface:frame-changed': "onFrameChanged"
2014-02-20 13:39:16 -05:00
'tome:palette-hovered': "onPaletteHovered"
'tome:palette-pin-toggled': "onPalettePinToggled"
'tome:spell-debug-property-hovered': 'onSpellDebugPropertyHovered'
2014-01-03 13:32:13 -05:00
events:
'mouseenter': 'onMouseEnter'
'mouseleave': 'onMouseLeave'
2014-01-03 13:32:13 -05:00
'click': 'onClick'
constructor: (options) ->
super options
@thang = options.thang
@docFormatter = new DocFormatter options
@doc = @docFormatter.doc
getRenderData: ->
c = super()
c.doc = @doc
c
2014-01-03 13:32:13 -05:00
afterRender: ->
super()
@$el.addClass(@doc.type)
@$el.popover(
animation: false
2014-01-03 13:32:13 -05:00
html: true
2014-02-20 13:39:16 -05:00
placement: 'top'
trigger: 'manual' # Hover, until they click, which will then pin it until unclick.
content: @docFormatter.formatPopover()
container: '#tome-view'
2014-01-03 13:32:13 -05:00
)
2014-01-30 19:36:36 -05:00
@$el.on 'show.bs.popover', =>
2014-02-20 13:39:16 -05:00
Backbone.Mediator.publish 'tome:palette-hovered', thang: @thang, prop: @doc.name, entry: @
onMouseEnter: (e) ->
2014-01-03 13:32:13 -05:00
# Make sure the doc has the updated Thang so it can regenerate its prop value
@$el.data('bs.popover').options.content = @docFormatter.formatPopover()
2014-01-03 13:32:13 -05:00
@$el.popover('setContent')
2014-02-20 13:39:16 -05:00
@$el.popover 'show' unless @popoverPinned or @otherPopoverPinned
onMouseLeave: (e) ->
2014-02-20 13:39:16 -05:00
@$el.popover 'hide' unless @popoverPinned or @otherPopoverPinned
togglePinned: ->
if @popoverPinned
@popoverPinned = false
@$el.add('#tome-view .popover').removeClass 'pinned'
2014-02-20 13:39:16 -05:00
$('#tome-view .popover .close').remove()
@$el.popover 'hide'
else
@popoverPinned = true
2014-02-20 13:39:16 -05:00
@$el.popover 'show'
@$el.add('#tome-view .popover').addClass 'pinned'
2014-02-20 13:39:16 -05:00
x = $('<button type="button" data-dismiss="modal" aria-hidden="true" class="close">×</button>')
$('#tome-view .popover').append x
x.on 'click', @onClick
Backbone.Mediator.publish 'tome:palette-pin-toggled', entry: @, pinned: @popoverPinned
2014-01-03 13:32:13 -05:00
2014-02-20 13:39:16 -05:00
onClick: (e) =>
@togglePinned()
2014-02-20 13:39:16 -05:00
Backbone.Mediator.publish 'tome:palette-clicked', thang: @thang, prop: @doc.name, entry: @
2014-01-03 13:32:13 -05:00
onFrameChanged: (e) ->
return unless e.selectedThang?.id is @thang.id
@options.thang = @thang = @docFormatter.options.thang = e.selectedThang # Update our thang to the current version
2014-02-11 14:31:02 -05:00
2014-02-20 13:39:16 -05:00
onPaletteHovered: (e) ->
return if e.entry is @
@togglePinned() if @popoverPinned
onPalettePinToggled: (e) ->
return if e.entry is @
@otherPopoverPinned = e.pinned
onSpellDebugPropertyHovered: (e) ->
matched = e.property is @doc.name and e.owner is @doc.owner
if matched and not @debugHovered
@debugHovered = true
@togglePinned() unless @popoverPinned
else if @debugHovered and not matched
@debugHovered = false
@togglePinned() if @popoverPinned
null
2014-02-11 14:31:02 -05:00
destroy: ->
$('.popover.pinned').remove() if @popoverPinned # @$el.popover('destroy') doesn't work
@togglePinned() if @popoverPinned
@$el.popover 'destroy'
2014-02-11 14:31:02 -05:00
@$el.off()
super()