CocoView = require 'views/core/CocoView' template = require 'templates/play/level/tome/spell_palette_entry' {me} = require 'core/auth' filters = require 'lib/image_filter' DocFormatter = require './DocFormatter' utils = require 'core/utils' module.exports = class SpellPaletteEntryView extends CocoView tagName: 'div' # Could also try instead of
, but would need to adjust colors className: 'spell-palette-entry-view' template: template popoverPinned: false overridePopoverTemplate: '' subscriptions: 'surface:frame-changed': 'onFrameChanged' 'tome:palette-hovered': 'onPaletteHovered' 'tome:palette-pin-toggled': 'onPalettePinToggled' 'tome:spell-debug-property-hovered': 'onSpellDebugPropertyHovered' events: 'mouseenter': 'onMouseEnter' 'mouseleave': 'onMouseLeave' 'click': 'onClick' constructor: (options) -> super options @thang = options.thang @docFormatter = new DocFormatter options @doc = @docFormatter.doc @doc.initialHTML = @docFormatter.formatPopover() @aceEditors = [] afterRender: -> super() @$el.addClass(@doc.type) placement = -> if $('body').hasClass('dialogue-view-active') then 'top' else 'left' @$el.popover( animation: false html: true placement: placement trigger: 'manual' # Hover, until they click, which will then pin it until unclick. content: @docFormatter.formatPopover() container: 'body' template: @overridePopoverTemplate ).on 'shown.bs.popover', => Backbone.Mediator.publish 'tome:palette-hovered', thang: @thang, prop: @doc.name, entry: @ soundIndex = Math.floor(Math.random() * 4) @playSound "spell-palette-entry-open-#{soundIndex}", 0.75 popover = @$el.data('bs.popover') popover?.$tip?.i18n() codeLanguage = @options.language oldEditor.destroy() for oldEditor in @aceEditors @aceEditors = [] aceEditors = @aceEditors popover?.$tip?.find('.docs-ace').each -> aceEditor = utils.initializeACE @, codeLanguage aceEditors.push aceEditor onMouseEnter: (e) -> # Make sure the doc has the updated Thang so it can regenerate its prop value @$el.data('bs.popover').options.content = @docFormatter.formatPopover() @$el.popover('setContent') @$el.popover 'show' unless @popoverPinned or @otherPopoverPinned onMouseLeave: (e) -> @$el.popover 'hide' unless @popoverPinned or @otherPopoverPinned togglePinned: -> if @popoverPinned @popoverPinned = false @$el.add('.spell-palette-popover.popover').removeClass 'pinned' $('.spell-palette-popover.popover .close').remove() @$el.popover 'hide' @playSound 'spell-palette-entry-unpin' else @popoverPinned = true @$el.popover 'show' @$el.add('.spell-palette-popover.popover').addClass 'pinned' x = $('') $('.spell-palette-popover.popover').append x x.on 'click', @onClick @playSound 'spell-palette-entry-pin' Backbone.Mediator.publish 'tome:palette-pin-toggled', entry: @, pinned: @popoverPinned onClick: (e) => if true or @options.level.get('type', true) in ['hero', 'hero-ladder', 'hero-coop', 'course', 'course-ladder', 'game-dev', 'hero-practice'] # Jiggle instead of pin for hero levels # Actually, do it all the time, because we recently busted the pin CSS. TODO: restore pinning jigglyPopover = $('.spell-palette-popover.popover') jigglyPopover.addClass 'jiggling' pauseJiggle = => jigglyPopover.removeClass 'jiggling' _.delay pauseJiggle, 1000 return if key.shift Backbone.Mediator.publish 'tome:insert-snippet', doc: @options.doc, language: @options.language, formatted: @doc return @togglePinned() Backbone.Mediator.publish 'tome:palette-clicked', thang: @thang, prop: @doc.name, entry: @ 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 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 destroy: -> $('.popover.pinned').remove() if @popoverPinned # @$el.popover('destroy') doesn't work @togglePinned() if @popoverPinned @$el.popover 'destroy' @$el.off() oldEditor.destroy() for oldEditor in @aceEditors super()