Performance improvements when rendering pages

pull/417/merge
Thibaut Courouble 9 years ago
parent 4becd25605
commit af8998453a

@ -40,11 +40,13 @@ class app.views.EntryPage extends app.View
@trigger 'loaded' @trigger 'loaded'
return return
CLIPBOARD_LINK = '<a class="_pre-clip" title="Copy to clipboard" tabindex="-1"></a>'
PRE_TAGS = /<pre[^>]*>/g
addClipboardLinks: -> addClipboardLinks: ->
@el.innerHTML = @el.innerHTML.replace(PRE_TAGS, "$&#{CLIPBOARD_LINK}") unless @clipBoardLink
@clipBoardLink = document.createElement('a')
@clipBoardLink.className = '_pre-clip'
@clipBoardLink.title = 'Copy to clipboard'
@clipBoardLink.tabIndex = -1
el.appendChild(@clipBoardLink.cloneNode()) for el in @el.querySelectorAll('pre')
return return
LINKS = LINKS =

@ -1,19 +1,42 @@
class app.views.BasePage extends app.View class app.views.BasePage extends app.View
constructor: (@el, @entry) -> super constructor: (@el, @entry) -> super
deactivate: ->
if super
@highlightNodes = []
render: (content, fromCache = false) -> render: (content, fromCache = false) ->
@highlightNodes = []
@previousTiming = null
@addClass "_#{@entry.doc.type}" unless @constructor.className @addClass "_#{@entry.doc.type}" unless @constructor.className
@html content @html content
@prepare?() unless fromCache @prepare?() unless fromCache
@activate() @activate()
@delay @afterRender if @afterRender @delay @afterRender if @afterRender
$.requestAnimationFrame(@paintCode) if @highlightNodes.length > 0
return return
highlightCode: (el, language) -> highlightCode: (el, language) ->
return unless language return unless language
language = "language-#{language}"
if $.isCollection(el) if $.isCollection(el)
@highlightCode e, language for e in el for e in el
e.classList.add(language)
@highlightNodes.push(e)
else if el else if el
el.classList.add "language-#{language}" el.classList.add(language)
Prism.highlightElement(el) @highlightNodes.push(el)
return
paintCode: (timing) =>
if @previousTiming
if Math.round(1000 / (timing - @previousTiming)) > 50 # fps
@nodesPerFrame = Math.round(Math.min(@nodesPerFrame * 1.25, 50))
else
@nodesPerFrame = Math.round(Math.max(@nodesPerFrame * .8, 10))
else
@nodesPerFrame = 10
Prism.highlightElement(el) for el in @highlightNodes.splice(0, @nodesPerFrame)
$.requestAnimationFrame(@paintCode) if @highlightNodes.length > 0
@previousTiming = timing
return return

Loading…
Cancel
Save