Class: React::RenderingContext
Class Attribute Summary collapse
-
.waiting_on_resources ⇒ Object
Returns the value of attribute waiting_on_resources.
Class Method Summary collapse
- .as_node(element) ⇒ Object (also: delete)
- .build ⇒ Object
- .build_only(name, *args, &block) ⇒ Object
- .improper_render(message, solution) ⇒ Object
-
.raise_render_error(result) ⇒ Object
heurestically raise a meaningful error based on the situation.
- .remove_nodes_from_args(args) ⇒ Object
- .render(name, *args, &block) ⇒ Object
- .replace(e1, e2) ⇒ Object
-
.run_child_block(is_outer_scope) ⇒ Object
run_child_block gathers the element(s) generated by a child block.
Class Attribute Details
.waiting_on_resources ⇒ Object
Returns the value of attribute waiting_on_resources.
4 5 6 |
# File 'lib/react/rendering_context.rb', line 4 def waiting_on_resources @waiting_on_resources end |
Class Method Details
.as_node(element) ⇒ Object Also known as: delete
52 53 54 55 |
# File 'lib/react/rendering_context.rb', line 52 def self.as_node(element) @buffer.delete(element) element end |
.build ⇒ Object
44 45 46 47 48 49 50 |
# File 'lib/react/rendering_context.rb', line 44 def self.build current = @buffer @buffer = [] return_val = yield @buffer @buffer = current return_val end |
.build_only(name, *args, &block) ⇒ Object
7 8 9 10 11 12 |
# File 'lib/react/rendering_context.rb', line 7 def self.build_only(name, *args, &block) React::Component.deprecation_warning( '..._as_node is deprecated. Render component and then use the .node method instead' ) React::RenderingContext.build { React::RenderingContext.render(name, *args, &block) }.to_n end |
.improper_render(message, solution) ⇒ Object
109 110 111 112 |
# File 'lib/react/rendering_context.rb', line 109 def self.improper_render(, solution) raise "a component's render method must generate and return exactly 1 element or a string.\n"\ " #{} #{solution}" end |
.raise_render_error(result) ⇒ Object
heurestically raise a meaningful error based on the situation
98 99 100 101 102 103 104 105 106 107 |
# File 'lib/react/rendering_context.rb', line 98 def self.raise_render_error(result) improper_render 'A different element was returned than was generated within the DSL.', 'Possibly improper use of Element#delete.' if @buffer.count == 1 improper_render "Instead #{@buffer.count} elements were generated.", 'Do you want to wrap your elements in a div?' if @buffer.count > 1 improper_render "Instead the component #{result} was returned.", "Did you mean #{result}()?" if result.try :reactrb_component? improper_render "Instead the #{result.class} #{result} was returned.", 'You may need to convert this to a string.' end |
.remove_nodes_from_args(args) ⇒ Object
63 64 65 66 67 |
# File 'lib/react/rendering_context.rb', line 63 def self.remove_nodes_from_args(args) args[0].each do |key, value| value.as_node if value.is_a?(Element) rescue nil end if args[0] && args[0].is_a?(Hash) end |
.render(name, *args, &block) ⇒ Object
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 |
# File 'lib/react/rendering_context.rb', line 14 def self.render(name, *args, &block) remove_nodes_from_args(args) @buffer ||= [] unless @buffer if block element = build do saved_waiting_on_resources = waiting_on_resources self.waiting_on_resources = nil run_child_block(name.nil?, &block) if name buffer = @buffer.dup React.create_element(name, *args) { buffer }.tap do |element| element.waiting_on_resources = saved_waiting_on_resources || !!buffer.detect { |e| e.waiting_on_resources if e.respond_to?(:waiting_on_resources) } end elsif @buffer.last.is_a? React::Element @buffer.last.tap { |element| element.waiting_on_resources ||= saved_waiting_on_resources } else @buffer.last.to_s.span.tap { |element| element.waiting_on_resources = saved_waiting_on_resources } end end elsif name.is_a? React::Element element = name else element = React.create_element(name, *args) element.waiting_on_resources = waiting_on_resources end @buffer << element self.waiting_on_resources = nil element end |
.replace(e1, e2) ⇒ Object
59 60 61 |
# File 'lib/react/rendering_context.rb', line 59 def self.replace(e1, e2) @buffer[@buffer.index(e1)] = e2 end |
.run_child_block(is_outer_scope) ⇒ Object
run_child_block gathers the element(s) generated by a child block. for example when rendering this div: div { “hello”.span; “goodby”.span } two child Elements will be generated.
the final value of the block should either be
1 an object that responds to :acts_as_string?
2 a string,
3 an element that is NOT yet pushed on the rendering buffer
4 or the last element pushed on the buffer
in case 1 we change the object to a string, and then it becomes case 2 in case 2 we automatically push the string onto the buffer in case 3 we also push the Element onto the buffer IF the buffer is empty case 4 requires no special processing
Once we have taken care of these special cases we do a check IF we are in an outer rendering scope. In this case react only allows us to generate 1 Element so we insure that is the case, and also check to make sure that element in the buffer is the element returned
89 90 91 92 93 94 |
# File 'lib/react/rendering_context.rb', line 89 def self.run_child_block(is_outer_scope) result = yield result = result.to_s if result.try :acts_as_string? @buffer << result if result.is_a?(String) || (result.is_a?(Element) && @buffer.empty?) raise_render_error(result) if is_outer_scope && @buffer != [result] end |