View = require 'views/kinds/CocoView' template = require 'templates/play/level/tome/spell_palette_entry' popoverTemplate = require 'templates/play/level/tome/spell_palette_entry_popover' {me} = require 'lib/auth' filters = require 'lib/image_filter' {downTheChain} = require 'lib/world/world_utils' # If we use marked somewhere else, we'll have to make sure to preserve options marked.setOptions {gfm: true, sanitize: false, smartLists: true, breaks: true} module.exports = class SpellPaletteEntryView extends View tagName: 'div' # Could also try instead of
, but would need to adjust colors className: 'spell-palette-entry-view' template: template subscriptions: 'surface:frame-changed': "onFrameChanged" events: 'mouseover': 'onMouseOver' 'click': 'onClick' constructor: (options) -> super options @thang = options.thang @doc = options.doc if _.isString @doc @doc = name: @doc, type: typeof @thang[@doc] @doc.owner ?= 'this' if options.isSnippet @doc.type = 'snippet' @doc.shortName = @doc.shorterName = @doc.title = @doc.name else suffix = if @doc.type is 'function' then '()' else '' @doc.shortName = "#{@doc.owner}.#{@doc.name}#{suffix};" if @doc.owner is 'this' @doc.shorterName = "#{@doc.name}#{suffix}" else @doc.shorterName = @doc.shortName.replace ';', '' @doc.title = if options.shortenize then @doc.shorterName else @doc.shortName getRenderData: -> c = super() c.doc = @doc c afterRender: -> super() @$el.addClass(@doc.type) @$el.popover( animation: true html: true placement: 'top' trigger: 'hover' content: @formatPopover() container: @$el.parent().parent().parent() ) @$el.on 'show.bs.popover', => Backbone.Mediator.publish 'tome:palette-hovered', thang: @thang, prop: @doc.name formatPopover: -> content = popoverTemplate doc: @doc, value: @formatValue(), marked: marked, argumentExamples: (arg.example or arg.default or arg.name for arg in @doc.args ? []) owner = if @doc.owner is 'this' then @thang else window[@doc.owner] content.replace /\#\{(.*?)\}/g, (s, properties) => @formatValue downTheChain(owner, properties.split('.')) formatValue: (v) -> return '' if @doc.type is 'function' unless v? if @doc.owner is 'this' v = @thang[@doc.name] else v = window[@doc.owner][@doc.name] if @type is 'number' and not isNaN v if v == Math.round v return v return v.toFixed 2 if _.isString v return "\"#{v}\"" if v?.id return v.id if v?.name return v.name if _.isArray v return '[' + (@formatValue v2 for v2 in v).join(', ') + ']' v onMouseOver: (e) -> # Make sure the doc has the updated Thang so it can regenerate its prop value @$el.data('bs.popover').options.content = @formatPopover() @$el.popover('setContent') onClick: (e) -> Backbone.Mediator.publish 'tome:palette-clicked', thang: @thang, prop: @doc.name onFrameChanged: (e) -> return unless e.selectedThang?.id is @thang.id @options.thang = @thang = e.selectedThang # Update our thang to the current version @$el.find("code.current-value").text(@formatValue()) destroy: -> @$el.off() super()