class EditableChamp::SectionComponent < ApplicationComponent include ApplicationHelper include TreeableConcern def initialize(nodes: nil, champs: nil) if (nodes.nil?) nodes = to_tree(champs:) end @nodes = to_fieldset(nodes:) end def render_within_fieldset? first_champ_is_an_header_section? && any_champ_fillable? end def header_section return @nodes.first if @nodes.first.is_a?(Champs::HeaderSectionChamp) end def splitted_tail tail.map { split_section_champ(_1) } end def tail return @nodes if !first_champ_is_an_header_section? _, *rest_of_champ = @nodes rest_of_champ end def tag_for_depth "h#{header_section.level + 1}" end # if two headers follows each others [h1, [h2, c]] # the first one must not be contained in fieldset # so we make the tree not fillable def fillable? false end def split_section_champ(node) case node when EditableChamp::SectionComponent [node, nil] else [nil, node] end end private def to_fieldset(nodes:) nodes.map { _1.is_a?(Array) ? EditableChamp::SectionComponent.new(nodes: _1) : _1 } end def first_champ_is_an_header_section? header_section.present? end def any_champ_fillable? tail.any? { _1&.fillable? } end end