# frozen_string_literal: true module Phlex module Rails module SGML module Overrides def helpers if defined?(ViewComponent::Base) && @_view_context.is_a?(ViewComponent::Base) @_view_context.helpers else @_view_context end end def render(*args, **kwargs, &block) renderable = args[0] case renderable when Phlex::SGML, Proc return super when Class return super if renderable < Phlex::SGML when Enumerable return super unless renderable.is_a?(ActiveRecord::Relation) else @_context.target << @_view_context.render(*args, **kwargs, &block) end nil end def render_in(view_context, &block) if block_given? call(view_context: view_context) do |*args| original_length = @_context.target.length if args.length == 1 && Phlex::SGML === args[0] && !block.source_location&.[](0)&.end_with?(".rb") output = view_context.capture( args[0].unbuffered, &block ) else output = view_context.capture(*args, &block) end unchanged = (original_length == @_context.target.length) if unchanged case output when ActiveSupport::SafeBuffer @_context.target << output end end end.html_safe else call(view_context: view_context).html_safe end end def capture super&.html_safe end def __text__(content) case content when ActiveSupport::SafeBuffer @_context.target << content else super end end # @api experimental def await(task) if task.is_a?(ActiveRecord::Relation) flush unless task.loaded? task else super end end # Trick ViewComponent into thinking we're a ViewComponent to fix rendering output def set_original_view_context(view_context) end end end end end