Sha256: 3ecf243ffc796d70d80352890354caaa8c411cca1deec8cf4536a68c2f2598ba

Contents?: true

Size: 1.27 KB

Versions: 1

Compression:

Stored size: 1.27 KB

Contents

require 'native'
require 'beryl/frontend_runtime'

class Renderer
  def render(runtime, element, parentDom, replace = true)
    document = Native(`window.document`)
    dom = element[:type] == 'text' ? document.createTextNode('') : document.createElement(element[:type])

    add_event_listeners(element, dom, runtime)
    set_attributes(element, dom)

    childElements = element[:children] || [];
    childElements.each { |child| render(runtime, child, dom, false) }

    update_dom(parentDom, dom, replace)
  end

  private

  def add_event_listeners(element, dom, runtime)
    listeners = element[:props].select { |key, _value| listener?(key) }
    listeners.each do |key, value|
      event_type = key.downcase[2..-1]
      dom.addEventListener(event_type, lambda { runtime.push(value); runtime.process })
    end
  end

  def listener?(key)
    key.start_with?('on')
  end

  def set_attributes(element, dom)
    attributes = element[:props].reject { |key, _value| listener?(key) }
    attributes.each { |key, value| key != :class ? dom[key] = value : dom.className = value }
  end

  def update_dom(parent_dom, dom, replace)
    if replace
      while (parent_dom.firstChild) do
        parent_dom.removeChild(parent_dom.firstChild)
      end
    end
    parent_dom.appendChild(dom)
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
beryl-0.3.1 lib/renderer.rb