ui_bibz 3.0.0.beta5 → 3.0.0.beta10
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile.lock +4 -4
- data/lib/ui_bibz.rb +2 -0
- data/lib/ui_bibz/infos.rb +2 -2
- data/lib/ui_bibz/ui/core/forms/dropdowns/split_dropdown.rb +4 -4
- data/lib/ui_bibz/ui/core/forms/files/file_field.rb +8 -14
- data/lib/ui_bibz/ui/core/notifications/popover.rb +89 -0
- data/lib/ui_bibz/ui/core/notifications/toast.rb +4 -4
- data/lib/ui_bibz/ui/core/notifications/tooltip.rb +89 -0
- data/lib/ui_bibz/ui/extensions/core/component/popover_extension.rb +55 -19
- data/lib/ui_bibz/ui/ux/tables/extensions/actionable.rb +1 -1
- data/lib/ui_bibz/ui/ux/tables/table.rb +5 -8
- data/lib/ui_bibz/ui/ux/tables/table_card.rb +2 -1
- data/test/simple_form_test.rb +1 -1
- data/test/ui/core/boxes/card_test.rb +1 -1
- data/test/ui/core/forms/buttons/button_test.rb +4 -4
- data/test/ui/core/forms/files/file_field_test.rb +1 -1
- data/test/ui/core/navigations/navbar_test.rb +4 -4
- data/test/ui/core/notifications/popover_test.rb +59 -0
- data/test/ui/core/notifications/tooltip_test.rb +58 -0
- data/test/ui/ux/tables/table_card_test.rb +37 -0
- data/test/ui/ux/tables/table_test.rb +8 -5
- metadata +10 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: b0b4963785be829c23f3f560fdc03346b3ee8beba96998a95b7ecf15ba20d7bf
|
4
|
+
data.tar.gz: 0e37bab962b5fb777493fbe861cf21efd0acb2c6072cda35c8c0c24686ecee77
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: d5a557c7bd724918100d60570f86fdd9a49b0862bc2735f11a450a524dc97569929fbc1753cbc69a71c864df51aeb5eaae67f02daff2a712cadb088d10e5961d
|
7
|
+
data.tar.gz: a892279deea5157f18bb6f37fb6eed213ab979890e652d35058da21696e0d000c9ce8305bd48433fcb56f8fcb571840ee4a850e78b240c935dc5a5a98b952bb7
|
data/Gemfile.lock
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
PATH
|
2
2
|
remote: .
|
3
3
|
specs:
|
4
|
-
ui_bibz (3.0.0.
|
4
|
+
ui_bibz (3.0.0.beta10)
|
5
5
|
will-paginate-i18n
|
6
6
|
will_paginate (~> 3.3.0)
|
7
7
|
will_paginate-bootstrap4
|
@@ -95,7 +95,7 @@ GEM
|
|
95
95
|
haml (>= 4.0, < 6)
|
96
96
|
nokogiri (>= 1.6.0)
|
97
97
|
ruby_parser (~> 3.5)
|
98
|
-
i18n (1.8.
|
98
|
+
i18n (1.8.8)
|
99
99
|
concurrent-ruby (~> 1.0)
|
100
100
|
iniparse (1.5.0)
|
101
101
|
jquery-rails (4.4.0)
|
@@ -114,7 +114,7 @@ GEM
|
|
114
114
|
mini_mime (1.0.2)
|
115
115
|
mini_portile2 (2.5.0)
|
116
116
|
minitest (5.14.3)
|
117
|
-
nio4r (2.5.
|
117
|
+
nio4r (2.5.5)
|
118
118
|
nokogiri (1.11.1)
|
119
119
|
mini_portile2 (~> 2.5.0)
|
120
120
|
racc (~> 1.4)
|
@@ -158,7 +158,7 @@ GEM
|
|
158
158
|
rake (13.0.3)
|
159
159
|
regexp_parser (2.0.3)
|
160
160
|
rexml (3.2.4)
|
161
|
-
rubocop (1.
|
161
|
+
rubocop (1.9.1)
|
162
162
|
parallel (~> 1.10)
|
163
163
|
parser (>= 3.0.0.0)
|
164
164
|
rainbow (>= 2.2.2, < 4.0)
|
data/lib/ui_bibz.rb
CHANGED
@@ -180,9 +180,11 @@ module UiBibz
|
|
180
180
|
module Notifications
|
181
181
|
autoload :Alert, 'ui_bibz/ui/core/notifications/alert'
|
182
182
|
autoload :Badge, 'ui_bibz/ui/core/notifications/badge'
|
183
|
+
autoload :Popover, 'ui_bibz/ui/core/notifications/popover'
|
183
184
|
autoload :ProgressBar, 'ui_bibz/ui/core/notifications/progress_bar'
|
184
185
|
autoload :Spinner, 'ui_bibz/ui/core/notifications/spinner'
|
185
186
|
autoload :Toast, 'ui_bibz/ui/core/notifications/toast'
|
187
|
+
autoload :Tooltip, 'ui_bibz/ui/core/notifications/tooltip'
|
186
188
|
end
|
187
189
|
|
188
190
|
module Windows
|
data/lib/ui_bibz/infos.rb
CHANGED
@@ -7,11 +7,11 @@ module UiBibz
|
|
7
7
|
DESCRIPTION = "A Rails Interface Framework using Bootstrap #{BOOTSTRAP_VERSION}."
|
8
8
|
SUMMARY = "Ui Bibz is an Ui Framework that allows you to build an interface very quickly and simply using Bootstrap #{BOOTSTRAP_VERSION}."
|
9
9
|
LICENSE = 'MIT'
|
10
|
-
FONTAWESOME_VERSION = '5.15.
|
10
|
+
FONTAWESOME_VERSION = '5.15.2'
|
11
11
|
HOMEPAGE = 'https://hummel.link/ui-bibz/'
|
12
12
|
REPO = 'git+https://github.com/thooams/ui_bibz.git'
|
13
13
|
EMAIL = 'thomas@hummel.link'
|
14
14
|
AUTHOR = 'Thooams [Thomas HUMMEL]'
|
15
|
-
VERSION = '3.0.0.
|
15
|
+
VERSION = '3.0.0.beta10'
|
16
16
|
AUTHORS = ['Thooams'].freeze
|
17
17
|
end
|
@@ -73,12 +73,12 @@ module UiBibz::Ui::Core::Forms::Dropdowns
|
|
73
73
|
end
|
74
74
|
|
75
75
|
def button_html
|
76
|
-
content_tag :button, button_content, class: join_classes('btn', button_status, size)
|
76
|
+
content_tag :button, button_content, (options[:html_button] || {}).merge(class: join_classes('btn', button_status, size, options[:html_button].try(:[], :class)))
|
77
77
|
end
|
78
78
|
|
79
79
|
def split_html
|
80
|
-
content_tag :button, split_content, class: split_classes, type: 'button',
|
81
|
-
|
80
|
+
content_tag :button, split_content, (options[:html_split] || {}).merge(class: split_classes, type: 'button',
|
81
|
+
'data-bs-toggle' => 'dropdown', 'aria-haspopup' => true, 'aria-expanded' => false)
|
82
82
|
end
|
83
83
|
|
84
84
|
def split_content
|
@@ -86,7 +86,7 @@ module UiBibz::Ui::Core::Forms::Dropdowns
|
|
86
86
|
end
|
87
87
|
|
88
88
|
def split_classes
|
89
|
-
join_classes('btn', button_status, size, 'dropdown-toggle', 'dropdown-toggle-split')
|
89
|
+
join_classes('btn', button_status, size, 'dropdown-toggle', 'dropdown-toggle-split', options[:split_html].try(:[], :class))
|
90
90
|
end
|
91
91
|
|
92
92
|
def src_only
|
@@ -45,19 +45,17 @@ module UiBibz::Ui::Core::Forms::Files
|
|
45
45
|
|
46
46
|
# Render html tag
|
47
47
|
def pre_render
|
48
|
-
|
49
|
-
concat file_field_tag content, class: 'form-file-input', multiple: options[:multiple], disabled: disabled?
|
50
|
-
concat label_text_and_button
|
51
|
-
end
|
48
|
+
file_field_tag content, html_options
|
52
49
|
end
|
53
50
|
|
54
51
|
private
|
55
52
|
|
56
|
-
def
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
53
|
+
def component_html_options
|
54
|
+
super.merge({
|
55
|
+
multiple: options[:multiple],
|
56
|
+
disabled: disabled?,
|
57
|
+
value: format_value(options[:input_text] || options[:value])
|
58
|
+
})
|
61
59
|
end
|
62
60
|
|
63
61
|
def format_value(value)
|
@@ -70,12 +68,8 @@ module UiBibz::Ui::Core::Forms::Files
|
|
70
68
|
value.to_s
|
71
69
|
end
|
72
70
|
|
73
|
-
def label_name
|
74
|
-
html_options[:id] || content
|
75
|
-
end
|
76
|
-
|
77
71
|
def component_html_classes
|
78
|
-
super << 'form-
|
72
|
+
super << 'form-control'
|
79
73
|
end
|
80
74
|
end
|
81
75
|
end
|
@@ -0,0 +1,89 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module UiBibz::Ui::Core::Notifications
|
4
|
+
# Create a popover
|
5
|
+
#
|
6
|
+
# This element is an extend of UiBibz::Ui::Core::Component.
|
7
|
+
#
|
8
|
+
# ==== Attributes
|
9
|
+
#
|
10
|
+
# * +content+ - Content of element
|
11
|
+
# * +options+ - Options of element
|
12
|
+
# * +html_options+ - Html Options of element
|
13
|
+
#
|
14
|
+
# ==== Options
|
15
|
+
#
|
16
|
+
# You can add HTML attributes using the +html_options+.
|
17
|
+
# You can pass arguments in options attribute:
|
18
|
+
#
|
19
|
+
# ==== Signatures
|
20
|
+
#
|
21
|
+
# UiBibz::Ui::Core::Notifications::Popover.new(content, options = nil, html_options = nil)
|
22
|
+
#
|
23
|
+
# UiBibz::Ui::Core::Notifications::Popover.new(options = nil, html_options = nil) do
|
24
|
+
# content
|
25
|
+
# end
|
26
|
+
#
|
27
|
+
# ==== Examples
|
28
|
+
#
|
29
|
+
# UiBibz::Ui::Core::Notifications::Popover.new(class: 'my-toast').tap |t|
|
30
|
+
# t.header "My header toast", glyph: 'eye', time: 'now'
|
31
|
+
# t.body "My body toast"
|
32
|
+
# end
|
33
|
+
#
|
34
|
+
# ==== Helper
|
35
|
+
#
|
36
|
+
# popover = UiBibz::Ui::Core::Notifications::Popover.new(position: :left) do
|
37
|
+
# My content
|
38
|
+
# end
|
39
|
+
# ui_glyph("diamond", popover: popover)
|
40
|
+
#
|
41
|
+
# # or
|
42
|
+
#
|
43
|
+
# ui_glyph("diamond", {popover: true}, { title: "My content" })
|
44
|
+
#
|
45
|
+
# # or
|
46
|
+
#
|
47
|
+
# ui_glyph("diamond", popover: { title: "My content", position: :right})
|
48
|
+
#
|
49
|
+
class Popover < UiBibz::Ui::Core::Component
|
50
|
+
# Note that for security reasons the sanitize, sanitizeFn, and allowList
|
51
|
+
# options cannot be supplied using data attributes.
|
52
|
+
# https://getbootstrap.com/docs/5.0/components/popovers/#options
|
53
|
+
DATA_ATTRIBUTES = %i[animation container delay html selector
|
54
|
+
template title trigger offset fallbackPlacement
|
55
|
+
boundary customClass popperConfig].freeze
|
56
|
+
|
57
|
+
# See UiBibz::Ui::Core::Component.initialize
|
58
|
+
def initialize(content = nil, options = nil, html_options = nil, &block)
|
59
|
+
super
|
60
|
+
@content = @options[:content] if content.is_a?(Hash) && block.nil?
|
61
|
+
end
|
62
|
+
|
63
|
+
# Render html tag
|
64
|
+
def render
|
65
|
+
base_attributes.merge(data_attributes)
|
66
|
+
end
|
67
|
+
|
68
|
+
private
|
69
|
+
|
70
|
+
def base_attributes
|
71
|
+
{
|
72
|
+
'data-bs-toggle' => 'popover',
|
73
|
+
'data-bs-content' => @content.html_safe
|
74
|
+
}.tap do |h|
|
75
|
+
h['data-bs-placement'] = options[:position] || options[:placement] if (options[:position] || options[:placement]).present?
|
76
|
+
end
|
77
|
+
end
|
78
|
+
|
79
|
+
def data_attributes
|
80
|
+
DATA_ATTRIBUTES.map do |data_attribute|
|
81
|
+
options[data_attribute].to_s.blank? ? nil : { "data-bs-#{data_attribute}" => data_attribute_value(data_attribute) }
|
82
|
+
end.compact.reduce(&:merge) || {}
|
83
|
+
end
|
84
|
+
|
85
|
+
def data_attribute_value(data_attribute)
|
86
|
+
options[data_attribute].is_a?(String) ? options[data_attribute].html_safe : options[data_attribute]
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
@@ -25,20 +25,20 @@ module UiBibz::Ui::Core::Notifications
|
|
25
25
|
#
|
26
26
|
# ==== Signatures
|
27
27
|
#
|
28
|
-
# UiBibz::Ui::Core::Toast.new(content, options = nil, html_options = nil)
|
28
|
+
# UiBibz::Ui::Core::Notifications::Toast.new(content, options = nil, html_options = nil)
|
29
29
|
#
|
30
|
-
# UiBibz::Ui::Core::Toast.new(options = nil, html_options = nil) do
|
30
|
+
# UiBibz::Ui::Core::Notifications::Toast.new(options = nil, html_options = nil) do
|
31
31
|
# content
|
32
32
|
# end
|
33
33
|
#
|
34
34
|
# ==== Examples
|
35
35
|
#
|
36
|
-
# UiBibz::Ui::Core::Toast.new(class: 'my-toast').tap |t|
|
36
|
+
# UiBibz::Ui::Core::Notifications::Toast.new(class: 'my-toast').tap |t|
|
37
37
|
# t.header "My header toast", glyph: 'eye', time: 'now'
|
38
38
|
# t.body "My body toast"
|
39
39
|
# end
|
40
40
|
#
|
41
|
-
# UiBibz::Ui::Core::Toast.new(class: 'my-toast').tap |t|
|
41
|
+
# UiBibz::Ui::Core::Notifications::Toast.new(class: 'my-toast').tap |t|
|
42
42
|
# t.header glyph: 'eye', time: 'now' do
|
43
43
|
# My header toast
|
44
44
|
# end
|
@@ -0,0 +1,89 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
module UiBibz::Ui::Core::Notifications
|
4
|
+
# Create a tooltip
|
5
|
+
#
|
6
|
+
# This element is an extend of UiBibz::Ui::Core::Component.
|
7
|
+
#
|
8
|
+
# ==== Attributes
|
9
|
+
#
|
10
|
+
# * +content+ - Content of element
|
11
|
+
# * +options+ - Options of element
|
12
|
+
# * +html_options+ - Html Options of element
|
13
|
+
#
|
14
|
+
# ==== Options
|
15
|
+
#
|
16
|
+
# You can add HTML attributes using the +html_options+.
|
17
|
+
# You can pass arguments in options attribute:
|
18
|
+
#
|
19
|
+
# ==== Signatures
|
20
|
+
#
|
21
|
+
# UiBibz::Ui::Core::Notifications::Tooltip.new(content, options = nil, html_options = nil)
|
22
|
+
#
|
23
|
+
# UiBibz::Ui::Core::Notifications::Tooltip.new(options = nil, html_options = nil) do
|
24
|
+
# content
|
25
|
+
# end
|
26
|
+
#
|
27
|
+
# ==== Examples
|
28
|
+
#
|
29
|
+
# UiBibz::Ui::Core::Notifications::Tooltip.new("My content")
|
30
|
+
#
|
31
|
+
# # or
|
32
|
+
#
|
33
|
+
# UiBibz::Ui::Core::Notifications::Tooltip.new(position: :right) do
|
34
|
+
# content
|
35
|
+
# end
|
36
|
+
#
|
37
|
+
# ==== Helper
|
38
|
+
#
|
39
|
+
# tooltip = UiBibz::Ui::Core::Notifications::Tooltip.new("My content", position: :left)
|
40
|
+
# ui_glyph("diamond", tooltip: tooltip)
|
41
|
+
#
|
42
|
+
# # or
|
43
|
+
#
|
44
|
+
# ui_glyph("diamond", {tooltip: true}, { title: "My content" })
|
45
|
+
#
|
46
|
+
# # or
|
47
|
+
#
|
48
|
+
# ui_glyph("diamond", tooltip: { title: "My content", position: :right})
|
49
|
+
#
|
50
|
+
class Tooltip < UiBibz::Ui::Core::Component
|
51
|
+
# Note that for security reasons the sanitize, sanitizeFn, and allowList
|
52
|
+
# options cannot be supplied using data attributes.
|
53
|
+
# https://getbootstrap.com/docs/5.0/components/tooltips/#options
|
54
|
+
DATA_ATTRIBUTES = %i[animation container delay html selector template trigger
|
55
|
+
fallbackPlacement boundary].freeze
|
56
|
+
|
57
|
+
# See UiBibz::Ui::Core::Component.initialize
|
58
|
+
def initialize(content = nil, options = nil, html_options = nil, &block)
|
59
|
+
super
|
60
|
+
@content = @options[:title] if content.is_a?(Hash) && block.nil?
|
61
|
+
end
|
62
|
+
|
63
|
+
# Render html tag
|
64
|
+
def render
|
65
|
+
base_attributes.merge(data_attributes)
|
66
|
+
end
|
67
|
+
|
68
|
+
private
|
69
|
+
|
70
|
+
def base_attributes
|
71
|
+
{
|
72
|
+
'data-bs-toggle' => 'tooltip',
|
73
|
+
'data-bs-title' => @content.html_safe
|
74
|
+
}.tap do |h|
|
75
|
+
h['data-bs-placement'] = options[:position] || options[:placement] if (options[:position] || options[:placement]).present?
|
76
|
+
end
|
77
|
+
end
|
78
|
+
|
79
|
+
def data_attributes
|
80
|
+
DATA_ATTRIBUTES.map do |data_attribute|
|
81
|
+
options[data_attribute].to_s.blank? ? nil : { "data-bs-#{data_attribute}" => data_attribute_value(data_attribute) }
|
82
|
+
end.compact.reduce(&:merge) || {}
|
83
|
+
end
|
84
|
+
|
85
|
+
def data_attribute_value(data_attribute)
|
86
|
+
options[data_attribute].is_a?(String) ? options[data_attribute].html_safe : options[data_attribute]
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
@@ -1,34 +1,70 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
|
3
3
|
module PopoverExtension
|
4
|
-
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
9
|
-
|
4
|
+
# Add popover to a component
|
5
|
+
#
|
6
|
+
# By tooltip object
|
7
|
+
#
|
8
|
+
# popover = UiBibz::Ui::Core::Notifications::Popover.new("My Popover")
|
9
|
+
# UiBibz::Ui::Core::Component.new("My content", popover: popover)
|
10
|
+
#
|
11
|
+
# By Hash
|
12
|
+
#
|
13
|
+
# UiBibz::Ui::Core::Component.new("My content", popover: { content: "My Popover" })
|
14
|
+
#
|
15
|
+
# By String
|
16
|
+
#
|
17
|
+
# UiBibz::Ui::Core::Component.new("My content", popover: "My Popover")
|
18
|
+
#
|
10
19
|
def popover_data_html
|
11
|
-
if options[:popover].
|
12
|
-
add_html_data 'bs-toggle', value: 'popover'
|
13
|
-
add_html_data 'bs-content', value: (options[:popover].is_a?(String) ? options[:popover] : options[:popover][:content])
|
14
|
-
end
|
20
|
+
return if options[:popover].nil?
|
15
21
|
|
16
|
-
|
17
|
-
|
18
|
-
POPOVER_METHODS.each { |mth| add_html_data(mth, value: options[:popover].try(:[], mth)) unless options[:popover].try(:[], mth).nil? }
|
19
|
-
add_html_data 'bs-placement', value: options[:popover].try(:[], :position) unless options[:popover].try(:[], :position).nil?
|
22
|
+
html_options.update(generate_popover.render)
|
20
23
|
end
|
21
24
|
|
25
|
+
# Add tooltip to a component
|
26
|
+
#
|
27
|
+
# By tooltip object
|
28
|
+
#
|
29
|
+
# tooltip = UiBibz::Ui::Core::Notifications::Tooltip.new("My tooltip")
|
30
|
+
# UiBibz::Ui::Core::Component.new("My content", tooltip: tooltip)
|
31
|
+
#
|
32
|
+
# By Boolean
|
33
|
+
#
|
34
|
+
# UiBibz::Ui::Core::Component.new("My content", tooltip: true)
|
35
|
+
# # or
|
36
|
+
# UiBibz::Ui::Core::Component.new("My content", {tooltip: true}, { title: 'My tooltip' })
|
37
|
+
#
|
38
|
+
# By Hash
|
39
|
+
#
|
40
|
+
# UiBibz::Ui::Core::Component.new("My content", tooltip: { title: 'My tooltip' })
|
41
|
+
#
|
22
42
|
def tooltip_data_html
|
23
43
|
return if options[:tooltip].nil?
|
24
44
|
|
25
|
-
|
45
|
+
html_options.update(generate_tooltip.render)
|
46
|
+
end
|
47
|
+
|
48
|
+
private
|
49
|
+
|
50
|
+
def generate_tooltip
|
51
|
+
case options[:tooltip].class.name
|
52
|
+
when 'UiBibz::Ui::Core::Notifications::Tooltip'
|
53
|
+
options[:tooltip]
|
54
|
+
when 'TrueClass'
|
55
|
+
tooltip_content = html_options.delete(:title) || (sanitize_text(content) if options[:text] == false)
|
56
|
+
UiBibz::Ui::Core::Notifications::Tooltip.new(tooltip_content)
|
57
|
+
else
|
58
|
+
UiBibz::Ui::Core::Notifications::Tooltip.new(options[:tooltip])
|
59
|
+
end
|
60
|
+
end
|
26
61
|
|
27
|
-
|
28
|
-
|
29
|
-
|
62
|
+
def generate_popover
|
63
|
+
case options[:popover].class.name
|
64
|
+
when 'UiBibz::Ui::Core::Notifications::Popover'
|
65
|
+
options[:popover]
|
30
66
|
else
|
31
|
-
|
67
|
+
UiBibz::Ui::Core::Notifications::Popover.new(options[:popover])
|
32
68
|
end
|
33
69
|
end
|
34
70
|
end
|
@@ -35,7 +35,7 @@ module UiBibz::Ui::Ux::Tables
|
|
35
35
|
|
36
36
|
return if default_actions? != true && @actions.raw_list.empty?
|
37
37
|
|
38
|
-
UiBibz::Ui::Core::Forms::Dropdowns::Dropdown.new(dropdown_action_name, {
|
38
|
+
UiBibz::Ui::Core::Forms::Dropdowns::Dropdown.new(dropdown_action_name, { size: :sm, glyph: actions_glyph }, { class: 'dropdown-action' }).tap do |d|
|
39
39
|
actions_links(record).each do |l|
|
40
40
|
d.html l.to_s.html_safe
|
41
41
|
end
|
@@ -42,7 +42,8 @@ module UiBibz::Ui::Ux::Tables
|
|
42
42
|
# * +size+
|
43
43
|
# (+:sm+)
|
44
44
|
# * +responsive+ - Boolean
|
45
|
-
# * +
|
45
|
+
# * +breakpoint+
|
46
|
+
# (+:sm+, +:md+, +:lg+, +:xl+, +:xxl+)
|
46
47
|
#
|
47
48
|
# ==== Signatures
|
48
49
|
#
|
@@ -118,7 +119,7 @@ module UiBibz::Ui::Ux::Tables
|
|
118
119
|
|
119
120
|
# Render html tag
|
120
121
|
def pre_render
|
121
|
-
table_html
|
122
|
+
options[:responsive] ? content_tag(:div, table_html, class: responsive) : table_html
|
122
123
|
end
|
123
124
|
|
124
125
|
# Store must be generated by *table_search_pagination* method
|
@@ -184,7 +185,7 @@ module UiBibz::Ui::Ux::Tables
|
|
184
185
|
private
|
185
186
|
|
186
187
|
def component_html_classes
|
187
|
-
['table', striped, bordered, hoverable, size
|
188
|
+
['table', striped, bordered, hoverable, size]
|
188
189
|
end
|
189
190
|
|
190
191
|
def status
|
@@ -208,11 +209,7 @@ module UiBibz::Ui::Ux::Tables
|
|
208
209
|
end
|
209
210
|
|
210
211
|
def responsive
|
211
|
-
'table-responsive' unless @options[:responsive].nil?
|
212
|
-
end
|
213
|
-
|
214
|
-
def reflow
|
215
|
-
'table-reflow' unless @options[:reflow].nil?
|
212
|
+
['table-responsive', @options[:breakpoint]].compact.join('-') unless @options[:responsive].nil?
|
216
213
|
end
|
217
214
|
end
|
218
215
|
end
|
data/test/simple_form_test.rb
CHANGED
@@ -202,7 +202,7 @@ test1</textarea></div></form>"
|
|
202
202
|
f.input :name_fr, as: :ui_file_field
|
203
203
|
end
|
204
204
|
|
205
|
-
expected = "<form class=\"simple_form edit_user\" id=\"edit_user_1\" action=\"/users/1\" accept-charset=\"UTF-8\" method=\"post\"><input type=\"hidden\" name=\"_method\" value=\"patch\" /><div class=\"form-group ui_file_field optional user_name_fr\"><label class=\"control-label ui_file_field optional\" for=\"user_name_fr\">Name fr</label><
|
205
|
+
expected = "<form class=\"simple_form edit_user\" id=\"edit_user_1\" action=\"/users/1\" accept-charset=\"UTF-8\" method=\"post\"><input type=\"hidden\" name=\"_method\" value=\"patch\" /><div class=\"form-group ui_file_field optional user_name_fr\"><label class=\"control-label ui_file_field optional\" for=\"user_name_fr\">Name fr</label><input type=\"file\" name=\"user[name_fr]\" id=\"user_name_fr\" value=\"test1\" class=\"ui_file_field optional form-control\" /></div></form>"
|
206
206
|
|
207
207
|
assert_equal expected, actual
|
208
208
|
end
|
@@ -69,7 +69,7 @@ class CardTest < ActionView::TestCase
|
|
69
69
|
p.body do |b|
|
70
70
|
b.title 'Special title treatment'
|
71
71
|
b.subtitle 'The subtitle'
|
72
|
-
b.text
|
72
|
+
b.text 'With supporting text below as a natural lead-in to additional content.'
|
73
73
|
b.link 'Go somewhere', url: '#go-somewhere', class: 'btn btn-primary'
|
74
74
|
end
|
75
75
|
end
|
@@ -90,22 +90,22 @@ class ButtonTest < ActionView::TestCase
|
|
90
90
|
end
|
91
91
|
|
92
92
|
test 'button with complex popover' do
|
93
|
-
actual = ui_button('My Button', popover: { content: 'My popover', position: :left })
|
94
|
-
expected =
|
93
|
+
actual = ui_button('My Button', popover: { content: 'My popover', position: :left, html: true })
|
94
|
+
expected = "<button data-bs-toggle=\"popover\" data-bs-content=\"My popover\" data-bs-placement=\"left\" data-bs-html=\"true\" class=\"btn-secondary btn\">My Button</button>"
|
95
95
|
|
96
96
|
assert_equal expected, actual
|
97
97
|
end
|
98
98
|
|
99
99
|
test 'button with simple tooltip' do
|
100
100
|
actual = ui_button('My Button', { tooltip: 'My Button' }, { title: 'My tooltip' })
|
101
|
-
expected = '<button title="My tooltip" data-bs-toggle="tooltip" data-title="My Button" class="btn-secondary btn">My Button</button>'
|
101
|
+
expected = '<button title="My tooltip" data-bs-toggle="tooltip" data-bs-title="My Button" class="btn-secondary btn">My Button</button>'
|
102
102
|
|
103
103
|
assert_equal expected, actual
|
104
104
|
end
|
105
105
|
|
106
106
|
test 'button with complex tooltip' do
|
107
107
|
actual = ui_button('My Button', tooltip: { title: 'My tooltip', position: :left })
|
108
|
-
expected = '<button data-bs-toggle="tooltip" data-title="My tooltip" data-bs-placement="left" class="btn-secondary btn">My Button</button>'
|
108
|
+
expected = '<button data-bs-toggle="tooltip" data-bs-title="My tooltip" data-bs-placement="left" class="btn-secondary btn">My Button</button>'
|
109
109
|
|
110
110
|
assert_equal expected, actual
|
111
111
|
end
|
@@ -5,7 +5,7 @@ require 'test_helper'
|
|
5
5
|
class FileFieldTest < ActionView::TestCase
|
6
6
|
test 'file_field' do
|
7
7
|
actual = UiBibz::Ui::Core::Forms::Files::FileField.new('test').render
|
8
|
-
expected = "<
|
8
|
+
expected = "<input type=\"file\" name=\"test\" id=\"test\" value=\"\" class=\"form-control\" />"
|
9
9
|
|
10
10
|
assert_equal expected, actual
|
11
11
|
end
|
@@ -4,14 +4,14 @@ require 'test_helper'
|
|
4
4
|
class NavbarTest < ActionView::TestCase
|
5
5
|
test 'Navbar' do
|
6
6
|
actual = UiBibz::Ui::Core::Navigations::Navbar.new
|
7
|
-
expected = "<nav class=\"navbar navbar-light navbar-expand-lg\"><div class=\"container\"><button class=\"navbar-toggler hidden-sm-up\" type=\"button\" data-bs-toggle=\"collapse\" data-target=\"##{actual.id}\">☰</button><div class=\"navbar-collapse collapse\" id=\"#{actual.id}\"></div></div></nav>"
|
7
|
+
expected = "<nav class=\"navbar navbar-light navbar-expand-lg\"><div class=\"container\"><button class=\"navbar-toggler hidden-sm-up\" type=\"button\" data-bs-toggle=\"collapse\" data-bs-target=\"##{actual.id}\">☰</button><div class=\"navbar-collapse collapse\" id=\"#{actual.id}\"></div></div></nav>"
|
8
8
|
|
9
9
|
assert_equal expected, actual.render
|
10
10
|
end
|
11
11
|
|
12
12
|
test 'Navbar with options' do
|
13
13
|
actual = UiBibz::Ui::Core::Navigations::Navbar.new(title: 'Brand', expand_size: :xs, status: :primary, position: :top, brand_position: :right)
|
14
|
-
expected = "<nav class=\"bg-primary navbar navbar-light fixed-top navbar-expand-xs\"><div class=\"container\"><button class=\"navbar-toggler hidden-sm-up\" type=\"button\" data-bs-toggle=\"collapse\" data-target=\"##{actual.id}\">☰</button><span class=\"navbar-brand\">Brand</span><div class=\"navbar-collapse collapse\" id=\"#{actual.id}\"></div></div></nav>"
|
14
|
+
expected = "<nav class=\"bg-primary navbar navbar-light fixed-top navbar-expand-xs\"><div class=\"container\"><button class=\"navbar-toggler hidden-sm-up\" type=\"button\" data-bs-toggle=\"collapse\" data-bs-target=\"##{actual.id}\">☰</button><span class=\"navbar-brand\">Brand</span><div class=\"navbar-collapse collapse\" id=\"#{actual.id}\"></div></div></nav>"
|
15
15
|
|
16
16
|
assert_equal expected, actual.render
|
17
17
|
end
|
@@ -30,7 +30,7 @@ class NavbarTest < ActionView::TestCase
|
|
30
30
|
end
|
31
31
|
nb.text 'test'
|
32
32
|
end
|
33
|
-
expected = "<nav class=\"navbar navbar-light navbar-expand-lg\"><div class=\"container\"><span class=\"navbar-brand\">Brand</span><button class=\"navbar-toggler hidden-sm-up\" type=\"button\" data-bs-toggle=\"collapse\" data-target=\"##{actual.id}\">☰</button><div class=\"navbar-collapse collapse\" id=\"#{actual.id}\"><ul class=\"navbar-nav\"><li class=\"nav-item\"><a href=\"#Home\" class=\"active nav-link\">Home</a></li><li class=\"nav-item\"><a href=\"#profile\" class=\"nav-link\">Profile</a></li><li class=\"nav-item\"><a href=\"#messages\" class=\"nav-link\">Messages</a></li></ul><form type=\"form_tag\" position=\"right\" class=\"d-flex\" action=\"#\" accept-charset=\"UTF-8\" method=\"post\"><button class=\"btn-secondary btn\">Search</button></form><span class=\"navbar-text\">test</span></div></div></nav>"
|
33
|
+
expected = "<nav class=\"navbar navbar-light navbar-expand-lg\"><div class=\"container\"><span class=\"navbar-brand\">Brand</span><button class=\"navbar-toggler hidden-sm-up\" type=\"button\" data-bs-toggle=\"collapse\" data-bs-target=\"##{actual.id}\">☰</button><div class=\"navbar-collapse collapse\" id=\"#{actual.id}\"><ul class=\"navbar-nav\"><li class=\"nav-item\"><a href=\"#Home\" class=\"active nav-link\">Home</a></li><li class=\"nav-item\"><a href=\"#profile\" class=\"nav-link\">Profile</a></li><li class=\"nav-item\"><a href=\"#messages\" class=\"nav-link\">Messages</a></li></ul><form type=\"form_tag\" position=\"right\" class=\"d-flex\" action=\"#\" accept-charset=\"UTF-8\" method=\"post\"><button class=\"btn-secondary btn\">Search</button></form><span class=\"navbar-text\">test</span></div></div></nav>"
|
34
34
|
|
35
35
|
assert_equal expected, actual.render
|
36
36
|
end
|
@@ -43,7 +43,7 @@ class NavbarTest < ActionView::TestCase
|
|
43
43
|
end
|
44
44
|
end
|
45
45
|
expected =
|
46
|
-
"<nav class=\"bg-dark navbar navbar-dark navbar-expand-lg\"><div class=\"container\"><span class=\"navbar-brand\"><img src=\"/images/ruby-white\" /></span><button class=\"navbar-toggler hidden-sm-up\" type=\"button\" data-bs-toggle=\"collapse\" data-target=\"##{actual.id}\">☰</button><div class=\"navbar-collapse collapse\" id=\"#{actual.id}\"><ul class=\"navbar-nav\"><li class=\"nav-item\"><a href=\"#link\" class=\"nav-link\">Link</a></li></ul></div></div></nav>"
|
46
|
+
"<nav class=\"bg-dark navbar navbar-dark navbar-expand-lg\"><div class=\"container\"><span class=\"navbar-brand\"><img src=\"/images/ruby-white\" /></span><button class=\"navbar-toggler hidden-sm-up\" type=\"button\" data-bs-toggle=\"collapse\" data-bs-target=\"##{actual.id}\">☰</button><div class=\"navbar-collapse collapse\" id=\"#{actual.id}\"><ul class=\"navbar-nav\"><li class=\"nav-item\"><a href=\"#link\" class=\"nav-link\">Link</a></li></ul></div></div></nav>"
|
47
47
|
|
48
48
|
assert_equal expected, actual.render
|
49
49
|
end
|
@@ -0,0 +1,59 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'test_helper'
|
4
|
+
class PopoverTest < ActionView::TestCase
|
5
|
+
setup do
|
6
|
+
@parameters = { animation: true, container: "body", position: :left,
|
7
|
+
delay: 10, html: true, selector: false, template: "<b>",
|
8
|
+
trigger: "hover focus", fallbackPlacement: %w[top right],
|
9
|
+
boundary: 'clippingParents', title: "My title", offset: 2,
|
10
|
+
customClass: "test", popperConfig: "Mystring" }
|
11
|
+
end
|
12
|
+
|
13
|
+
test 'popover by hash' do
|
14
|
+
actual = UiBibz::Ui::Core::Notifications::Popover.new(@parameters.merge(content: "My Content")).render
|
15
|
+
expected = { "data-bs-toggle" => "popover", "data-bs-content" => "My Content", "data-bs-placement" => :left, "data-bs-animation" => true, "data-bs-container" => "body", "data-bs-delay" => 10, "data-bs-html" => true, "data-bs-selector" => false, "data-bs-template" => "<b>", "data-bs-title" => "My title", "data-bs-trigger" => "hover focus", "data-bs-offset" => 2, "data-bs-fallbackPlacement" => %w[top right], "data-bs-boundary" => "clippingParents", "data-bs-customClass" => "test", "data-bs-popperConfig" => "Mystring" }
|
16
|
+
|
17
|
+
assert_equal expected, actual
|
18
|
+
end
|
19
|
+
|
20
|
+
test 'popover with content and options' do
|
21
|
+
actual = UiBibz::Ui::Core::Notifications::Popover.new("My Content", @parameters).render
|
22
|
+
|
23
|
+
expected = { "data-bs-toggle" => "popover", "data-bs-content" => "My Content", "data-bs-placement" => :left, "data-bs-animation" => true, "data-bs-container" => "body", "data-bs-delay" => 10, "data-bs-html" => true, "data-bs-selector" => false, "data-bs-template" => "<b>", "data-bs-title" => "My title", "data-bs-trigger" => "hover focus", "data-bs-offset" => 2, "data-bs-fallbackPlacement" => %w[top right], "data-bs-boundary" => "clippingParents", "data-bs-customClass" => "test", "data-bs-popperConfig" => "Mystring" }
|
24
|
+
|
25
|
+
assert_equal expected, actual
|
26
|
+
end
|
27
|
+
|
28
|
+
test 'popover with block and options' do
|
29
|
+
actual = UiBibz::Ui::Core::Notifications::Popover.new(@parameters) do
|
30
|
+
"My Content"
|
31
|
+
end.render
|
32
|
+
|
33
|
+
expected = { "data-bs-toggle" => "popover", "data-bs-content" => "My Content", "data-bs-placement" => :left, "data-bs-animation" => true, "data-bs-container" => "body", "data-bs-delay" => 10, "data-bs-html" => true, "data-bs-selector" => false, "data-bs-template" => "<b>", "data-bs-title" => "My title", "data-bs-trigger" => "hover focus", "data-bs-offset" => 2, "data-bs-fallbackPlacement" => %w[top right], "data-bs-boundary" => "clippingParents", "data-bs-customClass" => "test", "data-bs-popperConfig" => "Mystring" }
|
34
|
+
|
35
|
+
assert_equal expected, actual
|
36
|
+
end
|
37
|
+
|
38
|
+
test 'glyph with popover object' do
|
39
|
+
popover = UiBibz::Ui::Core::Notifications::Popover.new(@parameters.merge(content: "My Content"))
|
40
|
+
actual = UiBibz::Ui::Core::Icons::Glyph.new("diamond", popover: popover).render
|
41
|
+
expected = "<i data-bs-toggle=\"popover\" data-bs-content=\"My Content\" data-bs-placement=\"left\" data-bs-animation=\"true\" data-bs-container=\"body\" data-bs-delay=\"10\" data-bs-html=\"true\" data-bs-selector=\"false\" data-bs-template=\"<b>\" data-bs-title=\"My title\" data-bs-trigger=\"hover focus\" data-bs-offset=\"2\" data-bs-fallbackPlacement=\"top right\" data-bs-boundary=\"clippingParents\" data-bs-customClass=\"test\" data-bs-popperConfig=\"Mystring\" class=\"glyph fas fa-diamond\"></i>"
|
42
|
+
|
43
|
+
assert_equal expected, actual
|
44
|
+
end
|
45
|
+
|
46
|
+
test 'glyph with popover hash' do
|
47
|
+
actual = UiBibz::Ui::Core::Icons::Glyph.new("diamond", popover: @parameters.merge(content: "My Content")).render
|
48
|
+
expected = "<i data-bs-toggle=\"popover\" data-bs-content=\"My Content\" data-bs-placement=\"left\" data-bs-animation=\"true\" data-bs-container=\"body\" data-bs-delay=\"10\" data-bs-html=\"true\" data-bs-selector=\"false\" data-bs-template=\"<b>\" data-bs-title=\"My title\" data-bs-trigger=\"hover focus\" data-bs-offset=\"2\" data-bs-fallbackPlacement=\"top right\" data-bs-boundary=\"clippingParents\" data-bs-customClass=\"test\" data-bs-popperConfig=\"Mystring\" class=\"glyph fas fa-diamond\"></i>"
|
49
|
+
|
50
|
+
assert_equal expected, actual
|
51
|
+
end
|
52
|
+
|
53
|
+
test 'glyph with popover String' do
|
54
|
+
actual = UiBibz::Ui::Core::Icons::Glyph.new("diamond", popover: "My Content").render
|
55
|
+
expected = "<i data-bs-toggle=\"popover\" data-bs-content=\"My Content\" class=\"glyph fas fa-diamond\"></i>"
|
56
|
+
|
57
|
+
assert_equal expected, actual
|
58
|
+
end
|
59
|
+
end
|
@@ -0,0 +1,58 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'test_helper'
|
4
|
+
class TooltipTest < ActionView::TestCase
|
5
|
+
setup do
|
6
|
+
@parameters = { animation: true, container: "body", position: :left,
|
7
|
+
delay: 10, html: true, selector: false, template: "<b>",
|
8
|
+
trigger: "hover focus", fallbackPlacement: %w[top right],
|
9
|
+
boundary: 'clippingParents' }
|
10
|
+
end
|
11
|
+
|
12
|
+
test 'tooltip by hash' do
|
13
|
+
actual = UiBibz::Ui::Core::Notifications::Tooltip.new(@parameters.merge(title: "My Title")).render
|
14
|
+
expected = { "data-bs-toggle" => "tooltip", "data-bs-title" => "My Title", "data-bs-placement" => :left, "data-bs-animation" => true, "data-bs-container" => "body", "data-bs-delay" => 10, "data-bs-html" => true, "data-bs-selector" => false, "data-bs-template" => "<b>", "data-bs-trigger" => "hover focus", "data-bs-fallbackPlacement" => %w[top right], "data-bs-boundary" => "clippingParents" }
|
15
|
+
|
16
|
+
assert_equal expected, actual
|
17
|
+
end
|
18
|
+
|
19
|
+
test 'tooltip with content and options' do
|
20
|
+
actual = UiBibz::Ui::Core::Notifications::Tooltip.new("My Title", @parameters).render
|
21
|
+
|
22
|
+
expected = { "data-bs-toggle" => "tooltip", "data-bs-title" => "My Title", "data-bs-placement" => :left, "data-bs-animation" => true, "data-bs-container" => "body", "data-bs-delay" => 10, "data-bs-html" => true, "data-bs-selector" => false, "data-bs-template" => "<b>", "data-bs-trigger" => "hover focus", "data-bs-fallbackPlacement" => %w[top right], "data-bs-boundary" => "clippingParents" }
|
23
|
+
|
24
|
+
assert_equal expected, actual
|
25
|
+
end
|
26
|
+
|
27
|
+
test 'tooltip with block and options' do
|
28
|
+
actual = UiBibz::Ui::Core::Notifications::Tooltip.new(@parameters) do
|
29
|
+
"My Title"
|
30
|
+
end.render
|
31
|
+
|
32
|
+
expected = { "data-bs-toggle" => "tooltip", "data-bs-title" => "My Title", "data-bs-placement" => :left, "data-bs-animation" => true, "data-bs-container" => "body", "data-bs-delay" => 10, "data-bs-html" => true, "data-bs-selector" => false, "data-bs-template" => "<b>", "data-bs-trigger" => "hover focus", "data-bs-fallbackPlacement" => %w[top right], "data-bs-boundary" => "clippingParents" }
|
33
|
+
|
34
|
+
assert_equal expected, actual
|
35
|
+
end
|
36
|
+
|
37
|
+
test 'glyph with tooltip object' do
|
38
|
+
tooltip = UiBibz::Ui::Core::Notifications::Tooltip.new(@parameters.merge(title: "My Title"))
|
39
|
+
actual = UiBibz::Ui::Core::Icons::Glyph.new("diamond", tooltip: tooltip).render
|
40
|
+
expected = "<i data-bs-toggle=\"tooltip\" data-bs-title=\"My Title\" data-bs-placement=\"left\" data-bs-animation=\"true\" data-bs-container=\"body\" data-bs-delay=\"10\" data-bs-html=\"true\" data-bs-selector=\"false\" data-bs-template=\"<b>\" data-bs-trigger=\"hover focus\" data-bs-fallbackPlacement=\"top right\" data-bs-boundary=\"clippingParents\" class=\"glyph fas fa-diamond\"></i>"
|
41
|
+
|
42
|
+
assert_equal expected, actual
|
43
|
+
end
|
44
|
+
|
45
|
+
test 'glyph with tooltip hash' do
|
46
|
+
actual = UiBibz::Ui::Core::Icons::Glyph.new("diamond", tooltip: @parameters.merge(title: "My Title")).render
|
47
|
+
expected = "<i data-bs-toggle=\"tooltip\" data-bs-title=\"My Title\" data-bs-placement=\"left\" data-bs-animation=\"true\" data-bs-container=\"body\" data-bs-delay=\"10\" data-bs-html=\"true\" data-bs-selector=\"false\" data-bs-template=\"<b>\" data-bs-trigger=\"hover focus\" data-bs-fallbackPlacement=\"top right\" data-bs-boundary=\"clippingParents\" class=\"glyph fas fa-diamond\"></i>"
|
48
|
+
|
49
|
+
assert_equal expected, actual
|
50
|
+
end
|
51
|
+
|
52
|
+
test 'glyph with tooltip boolean' do
|
53
|
+
actual = UiBibz::Ui::Core::Icons::Glyph.new("diamond", { tooltip: true }, { title: "My Title" }).render
|
54
|
+
expected = "<i data-bs-toggle=\"tooltip\" data-bs-title=\"My Title\" class=\"glyph fas fa-diamond\"></i>"
|
55
|
+
|
56
|
+
assert_equal expected, actual
|
57
|
+
end
|
58
|
+
end
|
@@ -0,0 +1,37 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require 'test_helper'
|
4
|
+
require 'ui_bibz/ui/ux/tables/components/store'
|
5
|
+
require 'ui_bibz/ui/ux/tables/extensions/paginable'
|
6
|
+
require 'ui_bibz/ui/ux/tables/extensions/searchable'
|
7
|
+
require 'ui_bibz/ui/ux/tables/extensions/sortable'
|
8
|
+
require 'ui_bibz/ui/ux/tables/extensions/actionable'
|
9
|
+
|
10
|
+
class TableCardTest < ActionView::TestCase
|
11
|
+
setup do
|
12
|
+
create_list(:user, 25)
|
13
|
+
params = ActionController::Parameters.new({
|
14
|
+
controller: 'users',
|
15
|
+
action: 'index',
|
16
|
+
sort: 'users.name_fr',
|
17
|
+
direction: 'asc',
|
18
|
+
search: 'Name fr',
|
19
|
+
per_page: 2,
|
20
|
+
page: 1,
|
21
|
+
only_path: true
|
22
|
+
})
|
23
|
+
@users = User.table_search_pagination(params, session)
|
24
|
+
@store = UiBibz::Ui::Ux::Tables::Store.new @users
|
25
|
+
end
|
26
|
+
|
27
|
+
test 'table card visual options' do
|
28
|
+
table_card = UiBibz::Ui::Ux::Tables::TableCard.new(store: @users, table_options: { striped: true, status: :inverse, responsive: true, bordered: true, size: :sm, hoverable: true, breakpoint: :sm }).render
|
29
|
+
actual_table_classes = Nokogiri::HTML(table_card).xpath('//table')[0].attributes['class'].value
|
30
|
+
div_classes = Nokogiri::HTML(table_card).xpath('//div').css('.table-responsive-sm')[0].attributes['class'].value
|
31
|
+
table_classes = 'table-inverse table table-striped table-bordered table-hoverable table-sm'
|
32
|
+
actual_div_classes = 'table-responsive-sm'
|
33
|
+
|
34
|
+
assert_equal table_classes, actual_table_classes
|
35
|
+
assert_equal div_classes, actual_div_classes
|
36
|
+
end
|
37
|
+
end
|
@@ -195,11 +195,14 @@ class TableTest < ActionView::TestCase
|
|
195
195
|
end
|
196
196
|
|
197
197
|
test 'table visual options' do
|
198
|
-
table
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
198
|
+
table = UiBibz::Ui::Ux::Tables::Table.new(store: @users, striped: true, status: :inverse, responsive: true, bordered: true, size: :sm, hoverable: true, breakpoint: :sm).render
|
199
|
+
div_classes = Nokogiri::HTML(table).xpath('//div')[0].attributes['class'].value
|
200
|
+
actual_table_classes = Nokogiri::HTML(table).xpath('//table')[0].attributes['class'].value
|
201
|
+
table_classes = 'table-inverse table table-striped table-bordered table-hoverable table-sm'
|
202
|
+
actual_div_classes = 'table-responsive-sm'
|
203
|
+
|
204
|
+
assert_equal table_classes, actual_table_classes
|
205
|
+
assert_equal div_classes, actual_div_classes
|
203
206
|
end
|
204
207
|
|
205
208
|
test 'table thead visual options' do
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: ui_bibz
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 3.0.0.
|
4
|
+
version: 3.0.0.beta10
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Thooams [Thomas HUMMEL]
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-
|
11
|
+
date: 2021-02-08 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rails
|
@@ -411,9 +411,11 @@ files:
|
|
411
411
|
- lib/ui_bibz/ui/core/notifications/components/bar.rb
|
412
412
|
- lib/ui_bibz/ui/core/notifications/components/toast_body.rb
|
413
413
|
- lib/ui_bibz/ui/core/notifications/components/toast_header.rb
|
414
|
+
- lib/ui_bibz/ui/core/notifications/popover.rb
|
414
415
|
- lib/ui_bibz/ui/core/notifications/progress_bar.rb
|
415
416
|
- lib/ui_bibz/ui/core/notifications/spinner.rb
|
416
417
|
- lib/ui_bibz/ui/core/notifications/toast.rb
|
418
|
+
- lib/ui_bibz/ui/core/notifications/tooltip.rb
|
417
419
|
- lib/ui_bibz/ui/core/windows/components/modal_body.rb
|
418
420
|
- lib/ui_bibz/ui/core/windows/components/modal_footer.rb
|
419
421
|
- lib/ui_bibz/ui/core/windows/components/modal_header.rb
|
@@ -564,12 +566,15 @@ files:
|
|
564
566
|
- test/ui/core/navigations/toolbar_test.rb
|
565
567
|
- test/ui/core/notifications/alert_test.rb
|
566
568
|
- test/ui/core/notifications/badge_test.rb
|
569
|
+
- test/ui/core/notifications/popover_test.rb
|
567
570
|
- test/ui/core/notifications/progress_bar_test.rb
|
568
571
|
- test/ui/core/notifications/spinner_test.rb
|
569
572
|
- test/ui/core/notifications/toast_test.rb
|
573
|
+
- test/ui/core/notifications/tooltip_test.rb
|
570
574
|
- test/ui/core/windows/modal_test.rb
|
571
575
|
- test/ui/utils/breakdown_class_name_generator_test.rb
|
572
576
|
- test/ui/ux/containers/panel_test.rb
|
577
|
+
- test/ui/ux/tables/table_card_test.rb
|
573
578
|
- test/ui/ux/tables/table_test.rb
|
574
579
|
- test/ui_bibz_test.rb
|
575
580
|
- ui_bibz.gemspec
|
@@ -774,11 +779,14 @@ test_files:
|
|
774
779
|
- test/ui/core/navigations/toolbar_test.rb
|
775
780
|
- test/ui/core/notifications/alert_test.rb
|
776
781
|
- test/ui/core/notifications/badge_test.rb
|
782
|
+
- test/ui/core/notifications/popover_test.rb
|
777
783
|
- test/ui/core/notifications/progress_bar_test.rb
|
778
784
|
- test/ui/core/notifications/spinner_test.rb
|
779
785
|
- test/ui/core/notifications/toast_test.rb
|
786
|
+
- test/ui/core/notifications/tooltip_test.rb
|
780
787
|
- test/ui/core/windows/modal_test.rb
|
781
788
|
- test/ui/utils/breakdown_class_name_generator_test.rb
|
782
789
|
- test/ui/ux/containers/panel_test.rb
|
790
|
+
- test/ui/ux/tables/table_card_test.rb
|
783
791
|
- test/ui/ux/tables/table_test.rb
|
784
792
|
- test/ui_bibz_test.rb
|