From c71cf7b2f51001e69b98aefdc7a3e583c64f225d Mon Sep 17 00:00:00 2001 From: Javier Julio Date: Tue, 24 Oct 2023 18:39:49 -0400 Subject: [PATCH] Remove component CSS class name default --- docs/index.md | 6 +++--- lib/arbre/component.rb | 14 -------------- spec/arbre/unit/component_spec.rb | 14 ++++++-------- 3 files changed, 9 insertions(+), 25 deletions(-) diff --git a/docs/index.md b/docs/index.md index b0f67dca..b29145c7 100644 --- a/docs/index.md +++ b/docs/index.md @@ -49,7 +49,7 @@ This provides a simpler alternative to nesting partials. The recommended approach is to subclass Arbre::Component and implement a new builder method. The builder_method defines the method that will be called to build this component -when using the DSL. The arguments passed into the builder_method will be passed +when using the DSL. The arguments passed into the builder_method will be passed into the #build method for you. For example: @@ -66,7 +66,7 @@ class Panel < Arbre::Component end ``` -By default components are `div` tags with an HTML class corresponding to the component class name. This can be overridden by redefining the `tag_name` method. +By default, components are `div` tags. This can be overridden by redefining the `tag_name` method. Several examples of Arbre components are [included in Active Admin](https://activeadmin.info/12-arbre-components.html) @@ -76,7 +76,7 @@ An [Arbre::Context](http://www.rubydoc.info/gems/arbre/Arbre/Context) is an obje ```ruby html = Arbre::Context.new do - panel "Hello World", id: "my-panel" do + panel "Hello World", class: "panel", id: "my-panel" do span "Inside the panel" text_node "Plain text" end diff --git a/lib/arbre/component.rb b/lib/arbre/component.rb index 77e03880..00276246 100644 --- a/lib/arbre/component.rb +++ b/lib/arbre/component.rb @@ -1,23 +1,9 @@ # frozen_string_literal: true module Arbre class Component < Arbre::HTML::Div - # By default components render a div def tag_name 'div' end - - def initialize(*) - super - add_class default_class_name - end - - protected - - # By default, add a css class named after the ruby class - def default_class_name - self.class.name.demodulize.underscore - end - end end diff --git a/spec/arbre/unit/component_spec.rb b/spec/arbre/unit/component_spec.rb index 2b01ce02..31dc3480 100644 --- a/spec/arbre/unit/component_spec.rb +++ b/spec/arbre/unit/component_spec.rb @@ -13,12 +13,10 @@ def build end describe Arbre::Component do - let(:assigns) { {} } let(:helpers) { nil } - - let(:component_class){ MockComponent } - let(:component){ component_class.new } + let(:component_class) { MockComponent } + let(:component) { component_class.new } it "should be a subclass of an html div" do expect(Arbre::Component.ancestors).to include(Arbre::HTML::Div) @@ -28,18 +26,18 @@ def build expect(component.tag_name).to eq('div') end - it "should add a class by default" do - expect(component.class_list).to include("mock_component") + it "should not have a class list" do + expect(component.class_list.to_s).to eq("") + expect(component.class_list.empty?).to eq(true) end it "should render the object using the builder method name" do comp = expect(arbre { mock_component }.to_s).to eq <<~HTML -
+

Hello World

HTML end - end