# frozen_string_literal: true module PlaybookWebsite module PbDocHelper def pb_kit_title(title) title.remove("pb_").titleize.tr("_", " ") end def pb_kit(kit: "", type: "rails", show_code: true, limit_examples: false, dark_mode: false) examples = pb_doc_kit_examples(kit, type) examples = examples.first(1) if limit_examples examples.map do |example| pb_rails "docs/kit_example", props: { kit: kit, example_title: example.values.first, example_key: example.keys.first, show_code: show_code, type: type, dark: dark_mode, } end.join.yield_self(&method(:raw)) end def nav_hash_array(link) link.first.last end # Deal with lists of kits, used in Playbook doc and Externally def pb_kits(type: "rails", limit_examples: false, dark_mode: false) kits = get_kits(type) # Iterate through the filtered kits and render them kits.map do |kit| render_pb_doc_kit(kit["name"], type, limit_examples, true, dark_mode) end.join.html_safe end def get_kits(type = "rails") kits = YAML.load_file(Playbook::Engine.root.join("dist/menu.yml")) || [] # Filter kits that have at least one component compatible with the type kits.select do |kit| kit["components"].any? { |component| component["platforms"].include?(type) } end end def aggregate_kits all_kits = [] YAML.load_file(Playbook::Engine.root.join("dist/menu.yml")).each do |kit| kit_name = kit["name"] components = kit["components"].map { |c| c["name"] } all_kits << if components.size == 1 components.first else { kit_name => components } end end all_kits end # rubocop:disable Style/OptionalBooleanParameter def render_pb_doc_kit(kit_name, type, limit_examples, code = true, dark_mode = false) parent_kit = YAML.load_file(Playbook::Engine.root.join("dist/menu.yml")).find { |kit| kit["name"] == kit_name } # Initialize component_content as an empty string component_content = "" title = "" # Check if parent_kit is nil if parent_kit.nil? title = pb_doc_render_clickable_title(kit_name, type) component_content = raw("