class Element
	
	
	Represents a single dynamic content area on the page.
Definitions
def self.root(id = self.unique_id, **data)
Create a new root element with a convenient syntax for specifying the id and data.
Signature
	- 
					parameter idString
- The unique identifier within the page. 
- 
					parameter dataHash
- The data associated with the element, typically stored as - data-attributes.
Implementation
						def self.root(id = self.unique_id, **data)
	self.new(id, data)
enddef self.child(parent, id = self.unique_id, **data)
Mount an element within a parent element.
Implementation
						def self.child(parent, id = self.unique_id, **data)
	full_id = parent.id + ":" + id
	
	self.new(full_id, data)
enddef initialize(id = self.class.unique_id, data = {})
Initialize the element with the specified id and data.
Signature
	- 
					parameter idString
- The unique identifier within the page. 
- 
					parameter dataHash
- The data associated with the element, typically stored as - data-attributes.
Implementation
						def initialize(id = self.class.unique_id, data = {})
	data[:class] ||= self.class.name
	
	@id = id
	@data = data
	@page = nil
endattr :id
The unique id within the bound page.
attr :data
The data associated with the element.
attr :page
Signature
	- 
					attribute Page | Nil
- The page this elemenet is bound to. 
def forward_event(detail = nil)
Generate a JavaScript string which forwards the specified event to the server.
Signature
	- 
					parameter detailHash
- The detail associated with the forwarded event. 
Implementation
						def forward_event(detail = nil)
	if detail
		"live.forwardEvent(#{JSON.dump(@id)}, event, #{JSON.dump(detail)})"
	else
		"live.forwardEvent(#{JSON.dump(@id)}, event)"
	end
enddef bind(page)
Bind this tag to a dynamically updating page.
Signature
	- 
					parameter pageLive::Page
Implementation
						def bind(page)
	@page = page
enddef handle(event)
Handle a client event, typically as triggered by #forward.
Signature
	- 
					parameter eventString
- The type of the event. 
Implementation
						def handle(event)
enddef rpc(*arguments)
Enqueue a remote procedure call to the currently bound page.
Signature
	- 
					parameter methodSymbol
- The name of the remote functio to invoke. 
- 
					parameter argumentsArray
Implementation
						def rpc(*arguments)
	if @page
		# This update might not be sent right away. Therefore, mutable arguments may be serialized to JSON at a later time (or never). This could be a race condition:
		@page.enqueue(arguments)
	else
		# This is a programming error, as it probably means the element is still part of the logic of the server side (e.g. async loop), but it is not bound to a page, so there is nothing to update/access/rpc.
		raise PageError, "Element is not bound to a page, make sure to implement #close!"
	end
enddef update!(**options)
Update the content of the client-side element by rendering this view.
Implementation
						def update!(**options)
	rpc(:update, @id, self.to_html, options)
enddef replace(selector, fragment = nil, **options, &block)
Replace the content of the client-side element by rendering this view.
Signature
	- 
					parameter selectorString
- The CSS selector to replace. 
- 
					parameter nodeString
- The HTML to replace. 
Implementation
						def replace(selector, fragment = nil, **options, &block)
	fragment ||= XRB::Builder.fragment(&block)
	
	rpc(:replace, selector, fragment.to_s, options)
enddef prepend(selector, fragment = nil, **options, &block)
Prepend to the content of the client-side element by appending the specified element.
Signature
	- 
					parameter selectorString
- The CSS selector to prepend to. 
- 
					parameter nodeString
- The HTML to prepend. 
Implementation
						def prepend(selector, fragment = nil, **options, &block)
	fragment ||= XRB::Builder.fragment(&block)
	
	rpc(:prepend, selector, fragment.to_s, options)
enddef append(selector, fragment = nil, **options, &block)
Append to the content of the client-side element by appending the specified element.
Signature
	- 
					parameter selectorString
- The CSS selector to append to. 
- 
					parameter nodeString
- The HTML to prepend. 
Implementation
						def append(selector, fragment = nil, **options, &block)
	fragment ||= XRB::Builder.fragment(&block)
	
	rpc(:append, selector, fragment.to_s, options)
enddef remove(selector, **options)
Remove the specified element from the client-side element.
Signature
	- 
					parameter selectorString
- The CSS selector to remove. 
Implementation
						def remove(selector, **options)
	rpc(:remove, selector, options)
enddef render(builder)
Render the element.
Signature
	- 
					parameter builderXRB::Builder
- The HTML builder. 
Implementation
						def render(builder)
	builder.text(self.class.name)
enddef to_html
Signature
	- 
					returns Object
- The generated HTML. 
Implementation
						def to_html
	XRB::Builder.fragment(&self.method(:build_markup))
enddef to_s
Convenience method for rendering the view as a string.
Signature
	- 
					returns String
- The generated HTML. 
Implementation
						def to_s
	to_html.to_s
end