bootstrap_builders 0.0.7 → 0.0.8

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 5667a14a34a64f4e0d6dc77a4132aab7e960d3c6
4
- data.tar.gz: a145dbbb99683102010efc65bf84ad8925450f8d
3
+ metadata.gz: 2f43a631bcbdf0f1260acd838942e89370548386
4
+ data.tar.gz: 5e31aab0381b04f8d53d6f637eeef0b8745c7077
5
5
  SHA512:
6
- metadata.gz: a9a1c90e3d3cd6fd3ea8767fe90d29799285a0aef122b71d4e944ddef353d65baf72e05f617265222c308535bc0cd84043bfedc1a183ecdec44c31a74aa98bc1
7
- data.tar.gz: f8d789fbbeaf73c1cb0a33d9cfb6d121ad1085e7cf339045de2ccfd73cda8743b41dbb41b147621c90af575dc5f0b9b010f4c8fa81b59b113a9725490403717a
6
+ metadata.gz: 81ab0ea91a7288126daf96766d93efcf31483c9c4f6a00186c52749c01f0366ec3c59b6ea89568d4116a57a675b63254460ac3051e16310f7290d0b840975d42
7
+ data.tar.gz: f06b0c4e58863482c73967a16925f02a14a1f73b1c51f0b01e5d6b52b9c9b45349678db6515f8c79f88d49cdcd0c1997d68d6aecf6a0f79ddd13f47e44786358
data/README.md CHANGED
@@ -83,6 +83,20 @@ The classes "bb-table" and "table" are always added.
83
83
  = bb_btn "/url", "My label", :block, :lg, confirm: true
84
84
  ```
85
85
 
86
+ ### Tabs
87
+
88
+ ```haml
89
+ = bb_tabs do |tabs|
90
+ = tabs.tab "Title" do
91
+ Content of tab
92
+ ```
93
+
94
+ ```haml
95
+ = bb_tabs :pills, :stacked do |tabs|
96
+ = tabs.tab "Title", "id-of-content-container" do
97
+ Content of tab
98
+ ```
99
+
86
100
  ## Contributing to bootstrap_builders
87
101
 
88
102
  * Check out the latest master to make sure the feature hasn't been implemented or the bug hasn't been fixed yet.
@@ -49,6 +49,7 @@ module BootstrapBuilders::ApplicationHelper
49
49
  args[:data][:confirm] ||= t("are_you_sure")
50
50
 
51
51
  button = BootstrapBuilders::Button.new(args.merge(icon: "remove", context: self, can_type: :destroy, method: :delete))
52
+ button.classes.remove(["btn-default"])
52
53
  button.classes.add(["btn-danger", "bb-btn", "bb-btn-destroy"])
53
54
  button.classes.add("bb-btn-destroy-#{button.can_model_class.name.tableize.singularize}") if button.can_model_class
54
55
  button.classes.add("bb-btn-destroy-#{button.can_model_class.name.tableize.singularize}-#{button.can_model.id}") if button.can_model
@@ -107,8 +108,14 @@ module BootstrapBuilders::ApplicationHelper
107
108
  table.html
108
109
  end
109
110
 
110
- def bb_tabs(args = {})
111
- tabs = BootstrapBuilders::Tabs.new(args.merge(context: self))
111
+ def bb_tabs(*args)
112
+ args = BootstrapBuilders::ArgumentsParser.new(
113
+ arguments: args,
114
+ argument_hash_default: {context: self},
115
+ short_true_arguments: [:justified, :pills, :stacked]
116
+ ).arguments
117
+
118
+ tabs = BootstrapBuilders::Tabs.new(*args)
112
119
  yield tabs
113
120
  tabs.to_html
114
121
  end
@@ -5,6 +5,7 @@ module BootstrapBuilders
5
5
  extend ActiveSupport::Autoload
6
6
 
7
7
  autoload :AttributeRows
8
+ autoload :ArgumentsParser
8
9
  autoload :Button
9
10
  autoload :ClassAttributeHandler
10
11
  autoload :Configuration
@@ -0,0 +1,35 @@
1
+ class BootstrapBuilders::ArgumentsParser
2
+ attr_reader :arguments
3
+
4
+ def initialize(args)
5
+ @arguments = args.fetch(:arguments)
6
+
7
+ if args[:argument_hash_default]
8
+ @argument_hash = args.fetch(:argument_hash_default)
9
+ else
10
+ @argument_hash = {}
11
+ end
12
+
13
+ if @arguments.last.is_a?(Hash)
14
+ @argument_hash = @argument_hash.merge(@arguments.pop)
15
+ end
16
+
17
+ @arguments << @argument_hash
18
+
19
+ @short_true_arguments = args[:short_true_arguments]
20
+ parse_short_true_arguments if @short_true_arguments
21
+ end
22
+
23
+ private
24
+
25
+ def parse_short_true_arguments
26
+ @arguments.delete_if do |argument|
27
+ if @short_true_arguments.include?(argument)
28
+ @argument_hash[argument] = true
29
+ true
30
+ else
31
+ false
32
+ end
33
+ end
34
+ end
35
+ end
@@ -17,7 +17,7 @@ class BootstrapBuilders::Button
17
17
 
18
18
  real_args[:label] ||= args.shift if args.first.is_a?(String)
19
19
 
20
- pass_args = [:block, :lg, :md, :sm, :xs]
20
+ pass_args = [:block, :confirm, :lg, :md, :mini, :sm, :xs]
21
21
  args.each do |arg|
22
22
  real_args[arg] = true if pass_args.include?(arg)
23
23
  end
@@ -9,6 +9,14 @@ class BootstrapBuilders::ClassAttributeHandler
9
9
  @classes += convert_to_array(class_argument)
10
10
  end
11
11
 
12
+ def remove(class_argument)
13
+ if class_argument.is_a?(Array)
14
+ @classes -= class_argument
15
+ else
16
+ @classes.delete(class_argument)
17
+ end
18
+ end
19
+
12
20
  def include?(attr_class)
13
21
  @classes.include?(attr_class)
14
22
  end
@@ -1,5 +1,6 @@
1
1
  class BootstrapBuilders::Tabs
2
2
  def initialize(args)
3
+ @args = args
3
4
  @context = args.fetch(:context)
4
5
  @tabs = []
5
6
  end
@@ -19,7 +20,8 @@ class BootstrapBuilders::Tabs
19
20
 
20
21
  def to_html
21
22
  container = HtmlGen::Element.new(:div, inden: " ", classes: ["bb-tabs-container"])
22
- ul = container.add_ele(:ul, classes: ["nav", "nav-tabs"])
23
+ ul = container.add_ele(:ul, classes: nav_classes)
24
+ container.add_ele(:div, classes: ["clearfix"])
23
25
 
24
26
  @tabs.each do |tab|
25
27
  li = ul.add_ele(:li)
@@ -38,4 +40,20 @@ class BootstrapBuilders::Tabs
38
40
 
39
41
  container.html
40
42
  end
43
+
44
+ private
45
+
46
+ def nav_classes
47
+ classes = ["nav"]
48
+ classes << "nav-stacked" if @args[:stacked]
49
+ classes << "nav-justified" if @args[:justified]
50
+
51
+ if @args[:pills]
52
+ classes << "nav-pills"
53
+ else
54
+ classes << "nav-tabs"
55
+ end
56
+
57
+ classes
58
+ end
41
59
  end
@@ -1,3 +1,3 @@
1
1
  module BootstrapBuilders
2
- VERSION = "0.0.7".freeze
2
+ VERSION = "0.0.8".freeze
3
3
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: bootstrap_builders
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.7
4
+ version: 0.0.8
5
5
  platform: ruby
6
6
  authors:
7
7
  - kaspernj
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2016-06-07 00:00:00.000000000 Z
11
+ date: 2016-06-10 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: rails
@@ -238,6 +238,7 @@ files:
238
238
  - config/routes.rb
239
239
  - config/spring.rb
240
240
  - lib/bootstrap_builders.rb
241
+ - lib/bootstrap_builders/arguments_parser.rb
241
242
  - lib/bootstrap_builders/attribute_rows.rb
242
243
  - lib/bootstrap_builders/button.rb
243
244
  - lib/bootstrap_builders/class_attribute_handler.rb
@@ -271,7 +272,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
271
272
  version: '0'
272
273
  requirements: []
273
274
  rubyforge_project:
274
- rubygems_version: 2.2.2
275
+ rubygems_version: 2.4.0
275
276
  signing_key:
276
277
  specification_version: 4
277
278
  summary: A library to generate Bootstrap HTML for Rails.