ui_bibz 2.0.0.beta2.6 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +0 -7
- data/Gemfile.lock +63 -63
- data/app/assets/javascripts/interface.coffee +6 -1
- data/app/assets/javascripts/ui_bibz.coffee +1 -0
- data/app/assets/stylesheets/_custom_variables.sass +20 -0
- data/app/assets/stylesheets/_panel.scss +314 -0
- data/app/assets/stylesheets/boxes.sass +5 -0
- data/app/assets/stylesheets/containers.sass +2 -0
- data/app/assets/stylesheets/fix-bootstrap-4.sass +4 -0
- data/app/assets/stylesheets/fix-dropdown-select.sass +1 -0
- data/app/assets/stylesheets/fix_addon.sass +187 -0
- data/app/assets/stylesheets/forms.sass +60 -0
- data/app/assets/stylesheets/navigations.sass +11 -0
- data/app/assets/stylesheets/notifications.sass +10 -0
- data/app/assets/stylesheets/{table.sass → tables.sass} +0 -0
- data/app/assets/stylesheets/ui_bibz.sass +11 -91
- data/config/initializers/ui_bibz.rb +6 -4
- data/lib/ui_bibz.rb +5 -0
- data/lib/ui_bibz/helpers/ui/ux_helper.rb +4 -0
- data/lib/ui_bibz/inputs/ui_bibz_form/ui_bibz_form_builder.rb +38 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/auto_complete_field_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/base_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/collection_input.rb +15 -11
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/string_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/ui_auto_complete_field_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/ui_choice_group_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/ui_date_picker_field_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/ui_dropdown_select_field_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/ui_formula_field_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/ui_markdown_editor_field_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/ui_multi_column_field_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/ui_multi_select_field_input.rb +0 -0
- data/lib/ui_bibz/inputs/ui_bibz_inputs/ui_number_field_input.rb +10 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/ui_radio_field_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/ui_select_field_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/ui_switch_field_input.rb +0 -0
- data/{app → lib/ui_bibz}/inputs/ui_bibz_inputs/ui_text_field_input.rb +0 -0
- data/lib/ui_bibz/rails/engine.rb +3 -9
- data/lib/ui_bibz/ui/core/boxes/card.rb +1 -1
- data/lib/ui_bibz/ui/core/boxes/card_column.rb +1 -1
- data/lib/ui_bibz/ui/core/boxes/card_deck.rb +1 -1
- data/lib/ui_bibz/ui/core/boxes/card_group.rb +1 -1
- data/lib/ui_bibz/ui/core/boxes/components/body/card_body_link.rb +1 -1
- data/lib/ui_bibz/ui/core/boxes/components/body/card_body_text.rb +1 -1
- data/lib/ui_bibz/ui/core/boxes/components/body/card_body_title.rb +1 -1
- data/lib/ui_bibz/ui/core/boxes/components/card_body.rb +1 -1
- data/lib/ui_bibz/ui/core/boxes/components/card_footer.rb +1 -1
- data/lib/ui_bibz/ui/core/boxes/components/card_header.rb +1 -1
- data/lib/ui_bibz/ui/core/boxes/components/card_image.rb +1 -1
- data/lib/ui_bibz/ui/core/boxes/jumbotron.rb +1 -1
- data/lib/ui_bibz/ui/core/component.rb +34 -3
- data/lib/ui_bibz/ui/core/forms/buttons/button.rb +11 -7
- data/lib/ui_bibz/ui/core/forms/buttons/button_group.rb +5 -1
- data/lib/ui_bibz/ui/core/forms/buttons/button_link.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/buttons/button_refresh.rb +2 -2
- data/lib/ui_bibz/ui/core/forms/choices/checkbox_field.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/choices/components/choice.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/choices/radio_field.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/choices/switch_field.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/dates/date_picker_field.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/dropdowns/components/dropdown_header.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/dropdowns/components/dropdown_link.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/dropdowns/dropdown.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/dropdowns/split_dropdown.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/numbers/formula_field.rb +7 -2
- data/lib/ui_bibz/ui/core/forms/numbers/number_field.rb +63 -0
- data/lib/ui_bibz/ui/core/forms/selects/abstract_select.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/selects/select_field.rb +5 -1
- data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_addon.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_button.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_button_link.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/surrounds/components/surround_button_refresh.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/surrounds/surround_field.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/textareas/markdown_editor_field.rb +1 -1
- data/lib/ui_bibz/ui/core/forms/texts/text_field.rb +7 -3
- data/lib/ui_bibz/ui/core/icons/glyph.rb +10 -2
- data/lib/ui_bibz/ui/core/icons/star.rb +1 -1
- data/lib/ui_bibz/ui/core/layouts/col.rb +1 -1
- data/lib/ui_bibz/ui/core/layouts/container.rb +1 -1
- data/lib/ui_bibz/ui/core/layouts/row.rb +1 -1
- data/lib/ui_bibz/ui/core/lists/components/list.rb +1 -1
- data/lib/ui_bibz/ui/core/lists/components/list/list_body.rb +1 -1
- data/lib/ui_bibz/ui/core/lists/components/list/list_header.rb +1 -1
- data/lib/ui_bibz/ui/core/lists/list_group.rb +1 -1
- data/lib/ui_bibz/ui/core/navigations/breadcrumb.rb +1 -1
- data/lib/ui_bibz/ui/core/navigations/components/breadcrumb_link.rb +3 -3
- data/lib/ui_bibz/ui/core/navigations/components/nav_dropdown.rb +1 -1
- data/lib/ui_bibz/ui/core/navigations/components/nav_link.rb +1 -1
- data/lib/ui_bibz/ui/core/navigations/components/nav_link_link.rb +1 -1
- data/lib/ui_bibz/ui/core/navigations/components/nav_link_list.rb +1 -1
- data/lib/ui_bibz/ui/core/navigations/components/nav_text.rb +1 -1
- data/lib/ui_bibz/ui/core/navigations/components/navbar_brand.rb +1 -1
- data/lib/ui_bibz/ui/core/navigations/components/navbar_form.rb +19 -17
- data/lib/ui_bibz/ui/core/navigations/components/navbar_text.rb +1 -1
- data/lib/ui_bibz/ui/core/navigations/components/pagination_link.rb +1 -1
- data/lib/ui_bibz/ui/core/navigations/link.rb +8 -2
- data/lib/ui_bibz/ui/core/navigations/nav.rb +1 -1
- data/lib/ui_bibz/ui/core/navigations/navbar.rb +10 -5
- data/lib/ui_bibz/ui/core/navigations/pagination.rb +1 -1
- data/lib/ui_bibz/ui/core/navigations/toolbar.rb +5 -8
- data/lib/ui_bibz/ui/core/notifications/alert.rb +1 -1
- data/lib/ui_bibz/ui/core/notifications/badge.rb +1 -1
- data/lib/ui_bibz/ui/core/notifications/components/alert_body.rb +1 -1
- data/lib/ui_bibz/ui/core/notifications/components/alert_header.rb +1 -1
- data/lib/ui_bibz/ui/core/notifications/components/bar.rb +1 -1
- data/lib/ui_bibz/ui/core/notifications/progress_bar.rb +1 -1
- data/lib/ui_bibz/ui/core/windows/components/modal_body.rb +1 -1
- data/lib/ui_bibz/ui/core/windows/components/modal_footer.rb +1 -1
- data/lib/ui_bibz/ui/core/windows/components/modal_header.rb +1 -1
- data/lib/ui_bibz/ui/core/windows/modal.rb +1 -1
- data/lib/ui_bibz/ui/extensions/core/component/glyph_extension.rb +22 -4
- data/lib/ui_bibz/ui/ux/containers/components/panel_body.rb +51 -0
- data/lib/ui_bibz/ui/ux/containers/components/panel_column.rb +48 -0
- data/lib/ui_bibz/ui/ux/containers/components/panel_deck.rb +50 -0
- data/lib/ui_bibz/ui/ux/containers/components/panel_footer.rb +52 -0
- data/lib/ui_bibz/ui/ux/containers/components/panel_group.rb +46 -0
- data/lib/ui_bibz/ui/ux/containers/components/panel_header.rb +61 -0
- data/lib/ui_bibz/ui/ux/containers/components/panel_toolbar.rb +38 -0
- data/lib/ui_bibz/ui/ux/containers/panel.rb +104 -0
- data/lib/ui_bibz/ui/ux/tables/components/thead.rb +1 -1
- data/lib/ui_bibz/ui/ux/tables/table.rb +1 -1
- data/lib/ui_bibz/ui/ux/tables/table_card.rb +1 -1
- data/lib/ui_bibz/ui/ux/tables/table_search_field.rb +1 -1
- data/lib/ui_bibz/utils/internationalization.rb +3 -0
- data/lib/ui_bibz/version.rb +1 -1
- data/test/factories/user.rb +1 -1
- data/test/simple_form_test.rb +2 -2
- data/test/support/factory_bot.rb +9 -0
- data/test/test_helper.rb +0 -1
- data/test/ui/core/boxes/card_test.rb +1 -1
- data/test/ui/core/component_test.rb +8 -1
- data/test/ui/core/forms/buttons/button_group_test.rb +1 -1
- data/test/ui/core/forms/buttons/button_link_test.rb +1 -1
- data/test/ui/core/forms/buttons/button_refresh_test.rb +1 -1
- data/test/ui/core/forms/buttons/button_test.rb +2 -2
- data/test/ui/core/forms/choices/choice_group_test.rb +1 -1
- data/test/ui/core/forms/dropdowns/dropdown_test.rb +1 -1
- data/test/ui/core/forms/numbers/formula_field_test.rb +1 -1
- data/test/ui/core/forms/selects/dropdown_select_field_test.rb +1 -1
- data/test/ui/core/forms/selects/multi_select_field_test.rb +1 -1
- data/test/ui/core/forms/selects/select_field_test.rb +1 -1
- data/test/ui/core/forms/surrounds/surround_field_test.rb +3 -3
- data/test/ui/core/forms/texts/auto_complete_field_test.rb +2 -2
- data/test/ui/core/forms/texts/text_field_test.rb +1 -1
- data/test/ui/core/icons/glyph_test.rb +6 -4
- data/test/ui/core/icons/star_test.rb +6 -6
- data/test/ui/core/navigations/breadcrumb_test.rb +1 -1
- data/test/ui/core/navigations/navbar_test.rb +1 -1
- data/test/ui/core/notifications/alert_test.rb +1 -1
- data/test/ui/core/notifications/badge_test.rb +2 -2
- data/test/ui/ux/containers/panel_test.rb +143 -0
- data/test/ui/ux/tables/table_test.rb +3 -3
- data/ui_bibz.gemspec +3 -12
- data/vendor/assets/javascripts/bootstrap-markdown.js +12 -12
- data/vendor/assets/javascripts/jquery-ui.min.js +6 -0
- data/vendor/assets/stylesheets/jquery-ui.min.css +6 -0
- metadata +63 -27
- data/app/inputs/ui_bibz_form/ui_bibz_form_builder.rb +0 -36
- data/test/support/factory_girl.rb +0 -6
data/lib/ui_bibz/version.rb
CHANGED
data/test/factories/user.rb
CHANGED
data/test/simple_form_test.rb
CHANGED
@@ -73,7 +73,7 @@ class SimpleFormTest < ActionView::TestCase
|
|
73
73
|
f.input :price, as: :ui_formula_field
|
74
74
|
end
|
75
75
|
|
76
|
-
expected = "<form class=\"simple_form edit_user\" id=\"edit_user_1\" action=\"/users/1\" accept-charset=\"UTF-8\" method=\"post\"><input name=\"utf8\" type=\"hidden\" value=\"✓\" /><input type=\"hidden\" name=\"_method\" value=\"patch\" /><div class=\"form-group ui_formula_field optional user_price\"><label class=\"control-label ui_formula_field optional\" for=\"user_price\">Price</label><div class=\"formula_field input-group ui_surround_field\"><input type=\"text\" name=\"user[price_formula]\" id=\"user_price_formula\" value=\"1+2\" class=\"ui_formula_field optional formula-field form-control\" formula_field_value=\"1+2\" /><span class=\"formula-field-sign input-group-addon\">=</span><input type=\"text\" name=\"user[price]\" id=\"user_price\" value=\"3.0\" class=\"formula-field-result form-control\" readonly=\"readonly\" /><span data-toggle=\"tooltip\" class=\"formula-field-alert input-group-addon\"><i class=\"glyph-danger glyph
|
76
|
+
expected = "<form class=\"simple_form edit_user\" id=\"edit_user_1\" action=\"/users/1\" accept-charset=\"UTF-8\" method=\"post\"><input name=\"utf8\" type=\"hidden\" value=\"✓\" /><input type=\"hidden\" name=\"_method\" value=\"patch\" /><div class=\"form-group ui_formula_field optional user_price\"><label class=\"control-label ui_formula_field optional\" for=\"user_price\">Price</label><div class=\"formula_field input-group ui_surround_field\"><input type=\"text\" name=\"user[price_formula]\" id=\"user_price_formula\" value=\"1+2\" class=\"ui_formula_field optional formula-field form-control\" formula_field_value=\"1+2\" /><span class=\"formula-field-sign input-group-addon\">=</span><input type=\"text\" name=\"user[price]\" id=\"user_price\" value=\"3.0\" class=\"formula-field-result form-control\" readonly=\"readonly\" /><span data-toggle=\"tooltip\" class=\"formula-field-alert input-group-addon\"><i class=\"glyph-danger glyph fas fa-exclamation-triangle\"></i></span></div></div></form>"
|
77
77
|
|
78
78
|
assert_equal expected, actual
|
79
79
|
end
|
@@ -171,7 +171,7 @@ class SimpleFormTest < ActionView::TestCase
|
|
171
171
|
end
|
172
172
|
|
173
173
|
expected = "<form class=\"simple_form edit_user\" id=\"edit_user_1\" action=\"/users/1\" accept-charset=\"UTF-8\" method=\"post\"><input name=\"utf8\" type=\"hidden\" value=\"✓\" /><input type=\"hidden\" name=\"_method\" value=\"patch\" /><div class=\"form-group ui_select_field optional user_name_fr\"><label class=\"control-label ui_select_field optional\" for=\"user_name_fr\">Name fr</label><div class=\"field-refresh input-group ui_surround_field\"><select name=\"user[name_fr]\" id=\"user_name_fr\" class=\"select-field form-control\"><option value=\"1\">test1</option>
|
174
|
-
<option value=\"2\">test2</option></select><div class=\"input-group-btn\"><span data-connect=\"{"events":"click","mode":"remote","target":{"selector":"#user_name_fr","url":"","data":[]}}\" class=\"btn-secondary ui-bibz-connect btn input-refresh-button\"><i class=\"glyph
|
174
|
+
<option value=\"2\">test2</option></select><div class=\"input-group-btn\"><span data-connect=\"{"events":"click","mode":"remote","target":{"selector":"#user_name_fr","url":"","data":[]}}\" class=\"btn-secondary ui-bibz-connect btn input-refresh-button\"><i class=\"glyph fas fa-sync-alt\"></i> </span></div></div></div></form>"
|
175
175
|
|
176
176
|
assert_equal expected, actual
|
177
177
|
end
|
data/test/test_helper.rb
CHANGED
@@ -57,7 +57,7 @@ class CardTest < ActionView::TestCase
|
|
57
57
|
p.body 'state'
|
58
58
|
p.footer 'state'
|
59
59
|
end
|
60
|
-
expected = "<div class=\"state card\"><div class=\"card-header\"><i class=\"glyph
|
60
|
+
expected = "<div class=\"state card\"><div class=\"card-header\"><i class=\"glyph fas fa-eye\"></i> state</div><div class=\"card-body\">state</div><div class=\"card-footer\">state</div></div>"
|
61
61
|
|
62
62
|
assert_equal expected, actual
|
63
63
|
end
|
@@ -4,7 +4,7 @@ class ComponentTest < ActionView::TestCase
|
|
4
4
|
|
5
5
|
test 'create complex component' do
|
6
6
|
actual = UiBibz::Ui::Core::Component.new('New component', { state: :active, glyph: 'add' }, { class: 'new-class' }).render
|
7
|
-
expected = '<i class="glyph
|
7
|
+
expected = '<i class="glyph fas fa-add"></i> New component'
|
8
8
|
|
9
9
|
assert_equal expected, actual
|
10
10
|
end
|
@@ -17,4 +17,11 @@ class ComponentTest < ActionView::TestCase
|
|
17
17
|
|
18
18
|
assert_equal expected, actual
|
19
19
|
end
|
20
|
+
|
21
|
+
test 'create component without text and glyph' do
|
22
|
+
actual = UiBibz::Ui::Core::Component.new('My text', { glyph: 'diamond', text: false }).render
|
23
|
+
expected = "<i title=\"My text\" class=\"glyph fas fa-diamond\"></i>"
|
24
|
+
|
25
|
+
assert_equal expected, actual
|
26
|
+
end
|
20
27
|
end
|
@@ -45,7 +45,7 @@ class ButtonGroupTest < ActionView::TestCase
|
|
45
45
|
d.link 'Link 1', url: '#link1', glyph: 'eye'
|
46
46
|
end
|
47
47
|
end
|
48
|
-
expected = "<div class=\"btn-group\" role=\"group\"><div id=\"dropdown-test\" class=\"dropup btn-group\"><button class=\"btn btn-success dropdown-toggle\" type=\"button\" data-toggle=\"dropdown\" aria-haspopup=\"true\" aria-expanded=\"false\" id=\"dropdown-test\">Dropdown <span class=\"caret\"></span></button><div class=\"dropdown-menu\" arial-labelledby=\"dropdown-test\"><a class=\"dropdown-item\" href=\"#link1\"><i class=\"glyph
|
48
|
+
expected = "<div class=\"btn-group\" role=\"group\"><div id=\"dropdown-test\" class=\"dropup btn-group\"><button class=\"btn btn-success dropdown-toggle\" type=\"button\" data-toggle=\"dropdown\" aria-haspopup=\"true\" aria-expanded=\"false\" id=\"dropdown-test\">Dropdown <span class=\"caret\"></span></button><div class=\"dropdown-menu\" arial-labelledby=\"dropdown-test\"><a class=\"dropdown-item\" href=\"#link1\"><i class=\"glyph fas fa-eye\"></i> Link 1</a></div></div></div>"
|
49
49
|
|
50
50
|
assert_equal expected, actual
|
51
51
|
end
|
@@ -75,7 +75,7 @@ class ButtonLinkTest < ActionView::TestCase
|
|
75
75
|
|
76
76
|
test 'button_link glyph' do
|
77
77
|
actual = ui_button_link('state', glyph: 'diamond')
|
78
|
-
expected = "<a class=\"btn-secondary btn\" role=\"button\" href=\"#\"><i class=\"glyph
|
78
|
+
expected = "<a class=\"btn-secondary btn\" role=\"button\" href=\"#\"><i class=\"glyph fas fa-diamond\"></i> state</a>"
|
79
79
|
|
80
80
|
assert_equal expected, actual
|
81
81
|
end
|
@@ -4,7 +4,7 @@ class ButtonRefreshTest < ActionView::TestCase
|
|
4
4
|
|
5
5
|
test "button" do
|
6
6
|
actual = UiBibz::Ui::Core::Forms::Buttons::ButtonRefresh.new('state', status: :success, connect: { target: { url: '/'}}).render
|
7
|
-
expected = "<span data-connect=\"{"events":"click","mode":"remote","target":{"selector":"","url":"/","data":[]}}\" class=\"btn-success ui-bibz-connect btn input-refresh-button\"><i class=\"glyph
|
7
|
+
expected = "<span data-connect=\"{"events":"click","mode":"remote","target":{"selector":"","url":"/","data":[]}}\" class=\"btn-success ui-bibz-connect btn input-refresh-button\"><i class=\"glyph fas fa-sync-alt\"></i> state</span>"
|
8
8
|
|
9
9
|
assert_equal expected, actual
|
10
10
|
end
|
@@ -68,14 +68,14 @@ class ButtonTest < ActionView::TestCase
|
|
68
68
|
|
69
69
|
test 'button glyph' do
|
70
70
|
actual = ui_button('state', glyph: 'diamond')
|
71
|
-
expected = "<button class=\"btn\"><i class=\"glyph
|
71
|
+
expected = "<button class=\"btn\"><i class=\"glyph fas fa-diamond\"></i> state</button>"
|
72
72
|
|
73
73
|
assert_equal expected, actual
|
74
74
|
end
|
75
75
|
|
76
76
|
test 'button glyph without text' do
|
77
77
|
actual = ui_button('state', glyph: 'diamond', text: false)
|
78
|
-
expected = "<button class=\"btn without-text\" title=\"state\"
|
78
|
+
expected = "<button class=\"btn without-text\"><i title=\"state\" class=\"glyph fas fa-diamond\"></i></button>"
|
79
79
|
|
80
80
|
assert_equal expected, actual
|
81
81
|
end
|
@@ -28,7 +28,7 @@ class ChoiceGroupTest < ActionView::TestCase
|
|
28
28
|
bc.choice 'Radio 1', glyph: 'diamond', status: :primary
|
29
29
|
bc.choice 'Radio 2', state: :active
|
30
30
|
end
|
31
|
-
expected = "<div data-toggle=\"buttons\" class=\"btn-group btn-group-lg button-choice\"><label class=\"btn-outline-primary btn btn-lg radio\"><input type=\"radio\" autocomplete=\"off\" /><i class=\"glyph
|
31
|
+
expected = "<div data-toggle=\"buttons\" class=\"btn-group btn-group-lg button-choice\"><label class=\"btn-outline-primary btn btn-lg radio\"><input type=\"radio\" autocomplete=\"off\" /><i class=\"glyph fas fa-diamond\"></i> Radio 1</label><label class=\"active btn-outline-secondary btn btn-lg radio\" aria-pressed=\"true\"><input type=\"radio\" autocomplete=\"off\" checked=\"checked\" />Radio 2</label></div>"
|
32
32
|
|
33
33
|
assert_equal expected, actual
|
34
34
|
end
|
@@ -37,7 +37,7 @@ class DropdownTest < ActionView::TestCase
|
|
37
37
|
d.divider
|
38
38
|
d.link 'Link3', url: '#link3'
|
39
39
|
end
|
40
|
-
expected = "<div class=\"dropup\"><button class=\"btn btn-success dropdown-toggle\" type=\"button\" data-toggle=\"dropdown\" aria-haspopup=\"true\" aria-expanded=\"false\" id=\"#{ actual.id }\"><i class=\"glyph
|
40
|
+
expected = "<div class=\"dropup\"><button class=\"btn btn-success dropdown-toggle\" type=\"button\" data-toggle=\"dropdown\" aria-haspopup=\"true\" aria-expanded=\"false\" id=\"#{ actual.id }\"><i class=\"glyph fas fa-diamond\"></i> Dropdown <span class=\"caret\"></span></button><div class=\"dropdown-menu\" arial-labelledby=\"#{ actual.id }\"><a class=\"dropdown-item\" href=\"#link1\"><i class=\"glyph fas fa-eye\"></i> Link 1</a><h6 class=\"dropdown-header\" role=\"presentation\">header</h6><a class=\"dropdown-item\" href=\"#link2\">Link 2</a><div class=\"dropdown-divider\"></div><a class=\"dropdown-item\" href=\"#link3\">Link3</a></div></div>"
|
41
41
|
|
42
42
|
assert_equal expected, actual.render
|
43
43
|
end
|
@@ -4,7 +4,7 @@ class FormulaFieldTest < ActionView::TestCase
|
|
4
4
|
|
5
5
|
test 'formula_field' do
|
6
6
|
actual = UiBibz::Ui::Core::Forms::Numbers::FormulaField.new('value').render
|
7
|
-
expected = "<div class=\"formula_field input-group ui_surround_field\"><input type=\"text\" name=\"value_formula\" id=\"value_formula\" class=\"formula-field form-control\" /><span class=\"formula-field-sign input-group-addon\">=</span><input type=\"text\" name=\"value\" id=\"value\" class=\"formula-field-result form-control\" readonly=\"readonly\" /><span data-toggle=\"tooltip\" class=\"formula-field-alert input-group-addon\"><i class=\"glyph-danger glyph
|
7
|
+
expected = "<div class=\"formula_field input-group ui_surround_field\"><input type=\"text\" name=\"value_formula\" id=\"value_formula\" class=\"formula-field form-control\" /><span class=\"formula-field-sign input-group-addon\">=</span><input type=\"text\" name=\"value\" id=\"value\" class=\"formula-field-result form-control\" readonly=\"readonly\" /><span data-toggle=\"tooltip\" class=\"formula-field-alert input-group-addon\"><i class=\"glyph-danger glyph fas fa-exclamation-triangle\"></i></span></div>"
|
8
8
|
|
9
9
|
assert_equal expected, actual
|
10
10
|
end
|
@@ -76,7 +76,7 @@ class DropdownSelectFieldTest < ActionView::TestCase
|
|
76
76
|
|
77
77
|
test 'dropdown_select_field refresh' do
|
78
78
|
actual = UiBibz::Ui::Core::Forms::Selects::DropdownSelectField.new('test', { refresh: { mode: 'local', target: { data: [] }}}).render
|
79
|
-
expected = "<div class=\"field-refresh input-group ui_surround_field\"><select name=\"test\" id=\"test\" class=\"dropdown-select-field\"></select><div class=\"input-group-btn\"><span data-connect=\"{"events":"click","mode":"local","target":{"selector":"#test","url":"","data":[]}}\" class=\"btn-secondary ui-bibz-connect btn input-refresh-button\"><i class=\"glyph
|
79
|
+
expected = "<div class=\"field-refresh input-group ui_surround_field\"><select name=\"test\" id=\"test\" class=\"dropdown-select-field\"></select><div class=\"input-group-btn\"><span data-connect=\"{"events":"click","mode":"local","target":{"selector":"#test","url":"","data":[]}}\" class=\"btn-secondary ui-bibz-connect btn input-refresh-button\"><i class=\"glyph fas fa-sync-alt\"></i> </span></div></div>"
|
80
80
|
|
81
81
|
assert_equal expected, actual
|
82
82
|
end
|
@@ -24,7 +24,7 @@ class MultiSelectFieldTest < ActionView::TestCase
|
|
24
24
|
|
25
25
|
test 'Multi select Field refresh option' do
|
26
26
|
actual = UiBibz::Ui::Core::Forms::Selects::MultiSelectField.new('test', { refresh: { target: { url: '/'}}}).render
|
27
|
-
expected = "<div class=\"field-refresh input-group ui_surround_field\"><select name=\"test[]\" id=\"test\" class=\"btn-secondary multi-select-field\" multiple=\"multiple\"></select><div class=\"input-group-btn\"><span data-connect=\"{"events":"click","mode":"remote","target":{"selector":"#test","url":"/","data":[]}}\" class=\"btn-secondary ui-bibz-connect btn input-refresh-button\"><i class=\"glyph
|
27
|
+
expected = "<div class=\"field-refresh input-group ui_surround_field\"><select name=\"test[]\" id=\"test\" class=\"btn-secondary multi-select-field\" multiple=\"multiple\"></select><div class=\"input-group-btn\"><span data-connect=\"{"events":"click","mode":"remote","target":{"selector":"#test","url":"/","data":[]}}\" class=\"btn-secondary ui-bibz-connect btn input-refresh-button\"><i class=\"glyph fas fa-sync-alt\"></i> </span></div></div>"
|
28
28
|
|
29
29
|
assert_equal expected, actual
|
30
30
|
end
|
@@ -13,7 +13,7 @@ class SelectFieldTest < ActionView::TestCase
|
|
13
13
|
|
14
14
|
test "Select Field refresh" do
|
15
15
|
actual = UiBibz::Ui::Core::Forms::Selects::SelectField.new('example', refresh: { target: { url: '/' }}).render
|
16
|
-
expected = "<div class=\"field-refresh input-group ui_surround_field\"><select name=\"example\" id=\"example\" class=\"select-field form-control\"></select><div class=\"input-group-btn\"><span data-connect=\"{"events":"click","mode":"remote","target":{"selector":"#example","url":"/","data":[]}}\" class=\"btn-secondary ui-bibz-connect btn input-refresh-button\"><i class=\"glyph
|
16
|
+
expected = "<div class=\"field-refresh input-group ui_surround_field\"><select name=\"example\" id=\"example\" class=\"select-field form-control\"></select><div class=\"input-group-btn\"><span data-connect=\"{"events":"click","mode":"remote","target":{"selector":"#example","url":"/","data":[]}}\" class=\"btn-secondary ui-bibz-connect btn input-refresh-button\"><i class=\"glyph fas fa-sync-alt\"></i> </span></div></div>"
|
17
17
|
|
18
18
|
assert_equal expected, actual
|
19
19
|
end
|
@@ -6,7 +6,7 @@ class SurroundFieldTest < ActionView::TestCase
|
|
6
6
|
actual = UiBibz::Ui::Core::Forms::Surrounds::SurroundField.new.tap do |sf|
|
7
7
|
sf.glyph 'pencil'
|
8
8
|
end.render
|
9
|
-
expected = "<div class=\"input-group ui_surround_field\"><span class=\"input-group-addon\"><i class=\"glyph
|
9
|
+
expected = "<div class=\"input-group ui_surround_field\"><span class=\"input-group-addon\"><i class=\"glyph fas fa-pencil\"></i></span></div>"
|
10
10
|
|
11
11
|
assert_equal expected, actual
|
12
12
|
end
|
@@ -30,7 +30,7 @@ class SurroundFieldTest < ActionView::TestCase
|
|
30
30
|
d.link 'Link3', url: '#link3'
|
31
31
|
end
|
32
32
|
end.render
|
33
|
-
expected = "<div class=\"input-group ui_surround_field\"><div id=\"dropdown-test\" class=\"dropdown input-group-btn\"><button class=\"btn btn-secondary dropdown-toggle\" type=\"button\" data-toggle=\"dropdown\" aria-haspopup=\"true\" aria-expanded=\"false\" id=\"dropdown-test\">Dropdown <span class=\"caret\"></span></button><div class=\"dropdown-menu\" arial-labelledby=\"dropdown-test\"><a class=\"dropdown-item\" href=\"#link1\"><i class=\"glyph
|
33
|
+
expected = "<div class=\"input-group ui_surround_field\"><div id=\"dropdown-test\" class=\"dropdown input-group-btn\"><button class=\"btn btn-secondary dropdown-toggle\" type=\"button\" data-toggle=\"dropdown\" aria-haspopup=\"true\" aria-expanded=\"false\" id=\"dropdown-test\">Dropdown <span class=\"caret\"></span></button><div class=\"dropdown-menu\" arial-labelledby=\"dropdown-test\"><a class=\"dropdown-item\" href=\"#link1\"><i class=\"glyph fas fa-eye\"></i> Link 1</a><h6 class=\"dropdown-header\" role=\"presentation\">header</h6><a class=\"dropdown-item\" href=\"#link2\">Link 2</a><div class=\"dropdown-divider\"></div><a class=\"dropdown-item\" href=\"#link3\">Link3</a></div></div></div>"
|
34
34
|
|
35
35
|
assert_equal expected, actual
|
36
36
|
end
|
@@ -50,7 +50,7 @@ class SurroundFieldTest < ActionView::TestCase
|
|
50
50
|
sf.addon '€'
|
51
51
|
sf.glyph 'pencil'
|
52
52
|
end.render
|
53
|
-
expected = "<div class=\"input-group ui_surround_field\"><div class=\"input-group-btn\"><button class=\"btn\">Submit</button></div><span class=\"input-group-addon\">€</span><span class=\"input-group-addon\"><i class=\"glyph
|
53
|
+
expected = "<div class=\"input-group ui_surround_field\"><div class=\"input-group-btn\"><button class=\"btn\">Submit</button></div><span class=\"input-group-addon\">€</span><span class=\"input-group-addon\"><i class=\"glyph fas fa-pencil\"></i></span></div>"
|
54
54
|
|
55
55
|
assert_equal expected, actual
|
56
56
|
end
|
@@ -15,7 +15,7 @@ class AutoCompleteFieldTest < ActionView::TestCase
|
|
15
15
|
options = options_for_select(2.times.map{ |i| "option #{i}" })
|
16
16
|
actual = UiBibz::Ui::Core::Forms::Texts::AutoCompleteField.new('test', { option_tags: options, refresh: { target: { url: '/'}} }, { id: 'test' }).render
|
17
17
|
expected = "<div class=\"field-refresh input-group ui_surround_field\"><input type=\"text\" name=\"test\" id=\"test\" class=\"form-control auto-complete-field\" autocomplete=\"true\" list=\"test-datalist\" /><datalist id=\"test-datalist\"><option value=\"option 0\">option 0</option>
|
18
|
-
<option value=\"option 1\">option 1</option></datalist><div class=\"input-group-btn\"><span data-connect=\"{"events":"click","mode":"remote","target":{"selector":"#test-datalist","url":"/","data":[]}}\" class=\"btn-secondary ui-bibz-connect btn input-refresh-button\"><i class=\"glyph
|
18
|
+
<option value=\"option 1\">option 1</option></datalist><div class=\"input-group-btn\"><span data-connect=\"{"events":"click","mode":"remote","target":{"selector":"#test-datalist","url":"/","data":[]}}\" class=\"btn-secondary ui-bibz-connect btn input-refresh-button\"><i class=\"glyph fas fa-sync-alt\"></i> </span></div></div>"
|
19
19
|
|
20
20
|
assert_equal expected, actual
|
21
21
|
end
|
@@ -24,7 +24,7 @@ class AutoCompleteFieldTest < ActionView::TestCase
|
|
24
24
|
options = options_for_select(2.times.map{ |i| "option #{i}" })
|
25
25
|
actual = UiBibz::Ui::Core::Forms::Texts::AutoCompleteField.new('test', { option_tags: options, append: 'Append content', refresh: { target: { url: '/'}} }, { id: 'test' }).render
|
26
26
|
expected = "<div class=\"field-refresh input-group ui_surround_field\"><span class=\"input-group-addon\">Append content</span><input type=\"text\" name=\"test\" id=\"test\" class=\"form-control auto-complete-field\" autocomplete=\"true\" list=\"test-datalist\" /><datalist id=\"test-datalist\"><option value=\"option 0\">option 0</option>
|
27
|
-
<option value=\"option 1\">option 1</option></datalist><div class=\"input-group-btn\"><span data-connect=\"{"events":"click","mode":"remote","target":{"selector":"#test-datalist","url":"/","data":[]}}\" class=\"btn-secondary ui-bibz-connect btn input-refresh-button\"><i class=\"glyph
|
27
|
+
<option value=\"option 1\">option 1</option></datalist><div class=\"input-group-btn\"><span data-connect=\"{"events":"click","mode":"remote","target":{"selector":"#test-datalist","url":"/","data":[]}}\" class=\"btn-secondary ui-bibz-connect btn input-refresh-button\"><i class=\"glyph fas fa-sync-alt\"></i> </span></div></div>"
|
28
28
|
|
29
29
|
assert_equal expected, actual
|
30
30
|
end
|
@@ -18,7 +18,7 @@ class TextFieldTest < ActionView::TestCase
|
|
18
18
|
|
19
19
|
test 'text_field size' do
|
20
20
|
actual = UiBibz::Ui::Core::Forms::Texts::TextField.new('test', size: :xs, append: '1', prepend: '2').render
|
21
|
-
expected = "<div class=\"input-group-xs input-group ui_surround_field\"><span class=\"input-group-addon\">1</span><input type=\"text\" name=\"test\" id=\"test\" class=\"form-control\" /><span class=\"input-group-addon\">2</span></div>"
|
21
|
+
expected = "<div class=\"input-group-xs input-group ui_surround_field\"><span class=\"input-group-addon\">1</span><input type=\"text\" name=\"test\" id=\"test\" class=\"form-control form-control-xs\" /><span class=\"input-group-addon\">2</span></div>"
|
22
22
|
|
23
23
|
assert_equal expected, actual
|
24
24
|
end
|
@@ -1,29 +1,31 @@
|
|
1
1
|
require 'test_helper'
|
2
2
|
|
3
|
+
|
3
4
|
class GlyphTest < ActionView::TestCase
|
4
5
|
include UiBibz::Helpers::Ui::CoreHelper
|
5
6
|
|
6
7
|
test 'create glyph with a name' do
|
7
8
|
actual = ui_glyph('add')
|
8
|
-
expected = '<i class="glyph
|
9
|
+
expected = '<i class="glyph fas fa-add"></i>'
|
9
10
|
assert_equal expected, actual
|
10
11
|
end
|
11
12
|
|
12
13
|
test 'create glyph with hash' do
|
13
14
|
actual = ui_glyph({ name: 'add', size: 3, type: 'li'})
|
14
|
-
expected = '<i class="glyph
|
15
|
+
expected = '<i class="glyph fas fa-add fa-3x fa-li"></i>'
|
15
16
|
assert_equal expected, actual
|
16
17
|
end
|
17
18
|
|
18
19
|
test 'create glyph with name and hash' do
|
19
20
|
actual = ui_glyph('add', { size: 3, type: 'li' })
|
20
|
-
expected = '<i class="glyph
|
21
|
+
expected = '<i class="glyph fas fa-add fa-3x fa-li"></i>'
|
21
22
|
assert_equal expected, actual
|
22
23
|
end
|
23
24
|
|
24
25
|
test 'create glyph with label' do
|
25
26
|
actual = ui_glyph('add', { label: 'Example' })
|
26
|
-
expected = "<i class=\"glyph
|
27
|
+
expected = "<i class=\"glyph fas fa-add\"></i> Example"
|
27
28
|
assert_equal expected, actual
|
28
29
|
end
|
30
|
+
|
29
31
|
end
|
@@ -5,37 +5,37 @@ class StarTest < ActionView::TestCase
|
|
5
5
|
|
6
6
|
test "stars with 1" do
|
7
7
|
actual = ui_star(1)
|
8
|
-
expected = "<span class=\"stars-notation\"><i class=\"glyph
|
8
|
+
expected = "<span class=\"stars-notation\"><i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star-o\"></i> <i class=\"glyph fas fa-star-o\"></i> <i class=\"glyph fas fa-star-o\"></i> <i class=\"glyph fas fa-star-o\"></i></span>"
|
9
9
|
assert_equal expected, actual
|
10
10
|
end
|
11
11
|
|
12
12
|
test "stars with 2.1" do
|
13
13
|
actual = ui_star(2.1)
|
14
|
-
expected = "<span class=\"stars-notation\"><i class=\"glyph
|
14
|
+
expected = "<span class=\"stars-notation\"><i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star-half-o\"></i> <i class=\"glyph fas fa-star-o\"></i> <i class=\"glyph fas fa-star-o\"></i></span>"
|
15
15
|
assert_equal expected, actual
|
16
16
|
end
|
17
17
|
|
18
18
|
test "stars with 3.6 with status danger" do
|
19
19
|
actual = ui_star(3.6, { status: :danger })
|
20
|
-
expected = "<span class=\"stars-notation\"><i class=\"glyph-danger glyph
|
20
|
+
expected = "<span class=\"stars-notation\"><i class=\"glyph-danger glyph fas fa-star\"></i> <i class=\"glyph-danger glyph fas fa-star\"></i> <i class=\"glyph-danger glyph fas fa-star\"></i> <i class=\"glyph-danger glyph fas fa-star-half-o\"></i> <i class=\"glyph-danger glyph fas fa-star-o\"></i></span>"
|
21
21
|
assert_equal expected, actual
|
22
22
|
end
|
23
23
|
|
24
24
|
test "stars with 4.9" do
|
25
25
|
actual = ui_star(4.9)
|
26
|
-
expected = "<span class=\"stars-notation\"><i class=\"glyph
|
26
|
+
expected = "<span class=\"stars-notation\"><i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star-half-o\"></i></span>"
|
27
27
|
assert_equal expected, actual
|
28
28
|
end
|
29
29
|
|
30
30
|
test "stars with 5" do
|
31
31
|
actual = ui_star(5)
|
32
|
-
expected = "<span class=\"stars-notation\"><i class=\"glyph
|
32
|
+
expected = "<span class=\"stars-notation\"><i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star\"></i></span>"
|
33
33
|
assert_equal expected, actual
|
34
34
|
end
|
35
35
|
|
36
36
|
test "stars with number options 11.2" do
|
37
37
|
actual = ui_star(2.5, { num: 11.2 })
|
38
|
-
expected = "<span class=\"stars-notation\"><i class=\"glyph
|
38
|
+
expected = "<span class=\"stars-notation\"><i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star\"></i> <i class=\"glyph fas fa-star-half-o\"></i> <i class=\"glyph fas fa-star-o\"></i> <i class=\"glyph fas fa-star-o\"></i> <i class=\"glyph fas fa-star-o\"></i> <i class=\"glyph fas fa-star-o\"></i> <i class=\"glyph fas fa-star-o\"></i> <i class=\"glyph fas fa-star-o\"></i> <i class=\"glyph fas fa-star-o\"></i> <i class=\"glyph fas fa-star-o\"></i></span>"
|
39
39
|
assert_equal expected, actual
|
40
40
|
end
|
41
41
|
|
@@ -8,7 +8,7 @@ class BreadcrumbTest < ActionView::TestCase
|
|
8
8
|
b.link 'Home', url: '#home', glyph: 'home'
|
9
9
|
b.link 'state', { url: '#state', state: :active }
|
10
10
|
end
|
11
|
-
expected = "<ol class=\"breadcrumb\"><li class=\"breadcrumb-item\"><a href=\"#home\"><i class=\"glyph
|
11
|
+
expected = "<ol class=\"breadcrumb\"><li class=\"breadcrumb-item\"><a href=\"#home\"><i class=\"glyph fas fa-home\"></i> Home</a></li><li class=\"active breadcrumb-item\"><a href=\"#state\">state</a></li></ol>"
|
12
12
|
|
13
13
|
assert_equal expected, actual
|
14
14
|
end
|
@@ -31,7 +31,7 @@ class NavbarTest < ActionView::TestCase
|
|
31
31
|
end
|
32
32
|
nb.text 'test'
|
33
33
|
end
|
34
|
-
expected = "<nav class=\"navbar navbar-light navbar-expand-lg\"><a class=\"navbar-brand\" href=\"/\">Brand</a><button class=\"navbar-toggler hidden-sm-up\" type=\"button\" data-toggle=\"collapse\" data-target=\"##{ actual.id }\">☰</button><div class=\"collapse navbar-collapse\" id=\"#{ actual.id }\"><ul class=\"navbar-nav\"><li class=\"nav-item\"><a class=\"active nav-link\" href=\"#Home\">Home</a></li><li class=\"nav-item\"><a class=\"nav-link\" href=\"#profile\">Profile</a></li><li class=\"nav-item\"><a class=\"nav-link\" href=\"#messages\">Messages</a></li></ul><form type=\"form_tag\" position=\"right\" class=\"navbar-form form-inline
|
34
|
+
expected = "<nav class=\"navbar navbar-light navbar-expand-lg\"><a class=\"navbar-brand\" href=\"/\">Brand</a><button class=\"navbar-toggler hidden-sm-up\" type=\"button\" data-toggle=\"collapse\" data-target=\"##{ actual.id }\">☰</button><div class=\"collapse navbar-collapse\" id=\"#{ actual.id }\"><ul class=\"navbar-nav\"><li class=\"nav-item\"><a class=\"active nav-link\" href=\"#Home\">Home</a></li><li class=\"nav-item\"><a class=\"nav-link\" href=\"#profile\">Profile</a></li><li class=\"nav-item\"><a class=\"nav-link\" href=\"#messages\">Messages</a></li></ul><form type=\"form_tag\" position=\"right\" class=\"navbar-form form-inline my-lg-0 my-2\" action=\"#\" accept-charset=\"UTF-8\" method=\"post\"><input name=\"utf8\" type=\"hidden\" value=\"✓\" /><button class=\"btn\">Search</button></form><span class=\"navbar-text\">test</span></div></nav>"
|
35
35
|
|
36
36
|
assert_equal expected, actual.render
|
37
37
|
end
|
@@ -14,7 +14,7 @@ class AlertTest < ActionView::TestCase
|
|
14
14
|
a.header 'Information'
|
15
15
|
a.body 'Body text'
|
16
16
|
end
|
17
|
-
expected = "<div class=\"alert-success alert alert-dismissible\" role=\"alert\"><h4 class=\"alert-header\"><i class=\"glyph
|
17
|
+
expected = "<div class=\"alert-success alert alert-dismissible\" role=\"alert\"><h4 class=\"alert-header\"><i class=\"glyph fas fa-thumbs-o-up\"></i> Information<button type=\"button\" class=\"close\" data-dismiss=\"alert\" aria-label=\"Close\"><span aria-hidden=\"true\">×</span><span class=\"sr-only\">Close</span></button></h4><hr /><p class=\"alert-body mb-0\">Body text</p></div>"
|
18
18
|
|
19
19
|
assert_equal expected, actual
|
20
20
|
end
|
@@ -4,14 +4,14 @@ class BadgeTest < ActionView::TestCase
|
|
4
4
|
|
5
5
|
test 'badge' do
|
6
6
|
actual = ui_badge 'state', status: :success, glyph: 'pencil'
|
7
|
-
expected = "<span class=\"badge-success badge\"><i class=\"glyph
|
7
|
+
expected = "<span class=\"badge-success badge\"><i class=\"glyph fas fa-pencil\"></i> state</span>"
|
8
8
|
|
9
9
|
assert_equal expected, actual
|
10
10
|
end
|
11
11
|
|
12
12
|
test 'badge pill' do
|
13
13
|
actual = ui_badge 'state', status: :success, type: :pill, glyph: 'pencil'
|
14
|
-
expected = "<span class=\"badge-success badge badge-pill\"><i class=\"glyph
|
14
|
+
expected = "<span class=\"badge-success badge badge-pill\"><i class=\"glyph fas fa-pencil\"></i> state</span>"
|
15
15
|
|
16
16
|
assert_equal expected, actual
|
17
17
|
end
|
@@ -0,0 +1,143 @@
|
|
1
|
+
require 'test_helper'
|
2
|
+
|
3
|
+
class CardTest < ActionView::TestCase
|
4
|
+
include UiBibz::Helpers::Ui::UxHelper
|
5
|
+
|
6
|
+
test 'create panel' do
|
7
|
+
actual = ui_panel do |p|
|
8
|
+
p.header tap: true do |h|
|
9
|
+
h.title 'My header'
|
10
|
+
h.actions size: :sm, outline: true, status: :secondary do |a|
|
11
|
+
a.button 'Minimize', glyph: 'caret-up', text: false
|
12
|
+
a.button 'Options', glyph: 'cog', text: false
|
13
|
+
a.button 'Close', glyph: 'Close', text: false
|
14
|
+
end
|
15
|
+
end
|
16
|
+
p.toolbar justify: true, size: :sm do |t|
|
17
|
+
t.button_group do |bg|
|
18
|
+
bg.button 'Copy'
|
19
|
+
bg.button 'Cut'
|
20
|
+
bg.button 'Paste'
|
21
|
+
end
|
22
|
+
t.spacer 2
|
23
|
+
t.button_group do |bg|
|
24
|
+
bg.button 'Delete'
|
25
|
+
end
|
26
|
+
end
|
27
|
+
p.body 'Body'
|
28
|
+
p.toolbar size: :sm do |t|
|
29
|
+
t.button_group size: :sm do |bg|
|
30
|
+
bg.button 'Add', glyph: 'plus-circle', status: :success, text: false
|
31
|
+
bg.button 'Remove', glyph: 'minus-circle', status: :danger, text: false
|
32
|
+
end
|
33
|
+
end
|
34
|
+
p.footer 'Footer'
|
35
|
+
end
|
36
|
+
expected = "<div class=\"panel\"><div class=\"panel-header justify-content-between\"><div class=\"panel-title\">My header</div><div class=\"btn-group btn-group-sm\" role=\"group\"><button class=\"btn-outline-secondary btn btn-sm without-text\"><i title=\"Minimize\" class=\"glyph fas fa-caret-up\"></i></button><button class=\"btn-outline-secondary btn btn-sm without-text\"><i title=\"Options\" class=\"glyph fas fa-cog\"></i></button><button class=\"btn-outline-secondary btn btn-sm without-text\"><i title=\"Close\" class=\"glyph fas fa-Close\"></i></button></div></div><div class=\"btn-toolbar justify-content-between panel-toolbar\" role=\"toolbar\"><div class=\"btn-group btn-group-sm mr-2\" role=\"group\"><button class=\"btn btn-sm\">Copy</button><button class=\"btn btn-sm\">Cut</button><button class=\"btn btn-sm\">Paste</button></div><div class=\"btn-group btn-group-sm\" role=\"group\"><button class=\"btn btn-sm\">Delete</button></div></div><div class=\"panel-body\">Body</div><div class=\"btn-toolbar panel-toolbar\" role=\"toolbar\"><div class=\"btn-group btn-group-sm\" role=\"group\"><button class=\"btn-success btn btn-sm without-text\"><i title=\"Add\" class=\"glyph fas fa-plus-circle\"></i></button><button class=\"btn-danger btn btn-sm without-text\"><i title=\"Remove\" class=\"glyph fas fa-minus-circle\"></i></button></div></div><div class=\"panel-footer\">Footer</div></div>"
|
37
|
+
|
38
|
+
assert_equal expected, actual
|
39
|
+
end
|
40
|
+
|
41
|
+
test 'panel with group' do
|
42
|
+
actual = ui_panel do |p|
|
43
|
+
p.header tap: true do |h|
|
44
|
+
h.title 'Main panel header'
|
45
|
+
end
|
46
|
+
p.toolbar justify: true, size: :sm do |t|
|
47
|
+
t.button_group do |bg|
|
48
|
+
bg.button 'Copy'
|
49
|
+
bg.button 'Cut'
|
50
|
+
bg.button 'Paste'
|
51
|
+
end
|
52
|
+
t.spacer 2
|
53
|
+
t.button_group do |bg|
|
54
|
+
bg.button 'Delete'
|
55
|
+
end
|
56
|
+
end
|
57
|
+
p.group do |d|
|
58
|
+
d.panel do |b|
|
59
|
+
b.header 'Left Panel Header'
|
60
|
+
b.body 'Left Panel Body'
|
61
|
+
b.footer 'Left Panel Footer'
|
62
|
+
end
|
63
|
+
d.panel do |b|
|
64
|
+
b.header 'Right Panel Header'
|
65
|
+
b.body 'Right Panel Body'
|
66
|
+
end
|
67
|
+
end
|
68
|
+
p.footer 'Main Panel Footer'
|
69
|
+
end
|
70
|
+
expected = "<div class=\"panel\"><div class=\"panel-header justify-content-between\"><div class=\"panel-title\">Main panel header</div></div><div class=\"btn-toolbar justify-content-between panel-toolbar\" role=\"toolbar\"><div class=\"btn-group btn-group-sm mr-2\" role=\"group\"><button class=\"btn btn-sm\">Copy</button><button class=\"btn btn-sm\">Cut</button><button class=\"btn btn-sm\">Paste</button></div><div class=\"btn-group btn-group-sm\" role=\"group\"><button class=\"btn btn-sm\">Delete</button></div></div><div class=\"panel-group\"><div class=\"panel\"><div class=\"panel-header justify-content-between\">Left Panel Header</div><div class=\"panel-body\">Left Panel Body</div><div class=\"panel-footer\">Left Panel Footer</div></div><div class=\"panel\"><div class=\"panel-header justify-content-between\">Right Panel Header</div><div class=\"panel-body\">Right Panel Body</div></div></div><div class=\"panel-footer\">Main Panel Footer</div></div>"
|
71
|
+
|
72
|
+
assert_equal expected, actual
|
73
|
+
end
|
74
|
+
|
75
|
+
test 'panel with deck' do
|
76
|
+
actual = ui_panel do |p|
|
77
|
+
p.header tap: true do |h|
|
78
|
+
h.title 'Main panel header'
|
79
|
+
end
|
80
|
+
p.toolbar justify: true, size: :sm do |t|
|
81
|
+
t.button_group do |bg|
|
82
|
+
bg.button 'Copy'
|
83
|
+
bg.button 'Cut'
|
84
|
+
bg.button 'Paste'
|
85
|
+
end
|
86
|
+
t.spacer 2
|
87
|
+
t.button_group do |bg|
|
88
|
+
bg.button 'Delete'
|
89
|
+
end
|
90
|
+
end
|
91
|
+
p.deck do |d|
|
92
|
+
d.panel do |b|
|
93
|
+
b.header 'Left Panel Header'
|
94
|
+
b.body 'Left Panel Body'
|
95
|
+
b.footer 'Left Panel Footer'
|
96
|
+
end
|
97
|
+
d.panel do |b|
|
98
|
+
b.header 'Right Panel Header'
|
99
|
+
b.body 'Right Panel Body'
|
100
|
+
end
|
101
|
+
end
|
102
|
+
p.footer 'Main Panel Footer'
|
103
|
+
end
|
104
|
+
expected = "<div class=\"panel\"><div class=\"panel-header justify-content-between\"><div class=\"panel-title\">Main panel header</div></div><div class=\"btn-toolbar justify-content-between panel-toolbar\" role=\"toolbar\"><div class=\"btn-group btn-group-sm mr-2\" role=\"group\"><button class=\"btn btn-sm\">Copy</button><button class=\"btn btn-sm\">Cut</button><button class=\"btn btn-sm\">Paste</button></div><div class=\"btn-group btn-group-sm\" role=\"group\"><button class=\"btn btn-sm\">Delete</button></div></div><div class=\"panel-deck-wrapper\"><div class=\"panel-deck\"><div class=\"panel\"><div class=\"panel-header justify-content-between\">Left Panel Header</div><div class=\"panel-body\">Left Panel Body</div><div class=\"panel-footer\">Left Panel Footer</div></div><div class=\"panel\"><div class=\"panel-header justify-content-between\">Right Panel Header</div><div class=\"panel-body\">Right Panel Body</div></div></div></div><div class=\"panel-footer\">Main Panel Footer</div></div>"
|
105
|
+
|
106
|
+
assert_equal expected, actual
|
107
|
+
end
|
108
|
+
|
109
|
+
test 'panel with column' do
|
110
|
+
actual = ui_panel do |p|
|
111
|
+
p.header tap: true do |h|
|
112
|
+
h.title 'Main panel header'
|
113
|
+
end
|
114
|
+
p.toolbar justify: true, size: :sm do |t|
|
115
|
+
t.button_group do |bg|
|
116
|
+
bg.button 'Copy'
|
117
|
+
bg.button 'Cut'
|
118
|
+
bg.button 'Paste'
|
119
|
+
end
|
120
|
+
t.spacer 2
|
121
|
+
t.button_group do |bg|
|
122
|
+
bg.button 'Delete'
|
123
|
+
end
|
124
|
+
end
|
125
|
+
p.column do |d|
|
126
|
+
d.panel do |b|
|
127
|
+
b.header 'Left Panel Header'
|
128
|
+
b.body 'Left Panel Body'
|
129
|
+
b.footer 'Left Panel Footer'
|
130
|
+
end
|
131
|
+
d.panel do |b|
|
132
|
+
b.header 'Right Panel Header'
|
133
|
+
b.body 'Right Panel Body'
|
134
|
+
end
|
135
|
+
end
|
136
|
+
p.footer 'Main Panel Footer'
|
137
|
+
end
|
138
|
+
expected = "<div class=\"panel\"><div class=\"panel-header justify-content-between\"><div class=\"panel-title\">Main panel header</div></div><div class=\"btn-toolbar justify-content-between panel-toolbar\" role=\"toolbar\"><div class=\"btn-group btn-group-sm mr-2\" role=\"group\"><button class=\"btn btn-sm\">Copy</button><button class=\"btn btn-sm\">Cut</button><button class=\"btn btn-sm\">Paste</button></div><div class=\"btn-group btn-group-sm\" role=\"group\"><button class=\"btn btn-sm\">Delete</button></div></div><div class=\"panel-columns\"><div class=\"panel\"><div class=\"panel-header justify-content-between\">Left Panel Header</div><div class=\"panel-body\">Left Panel Body</div><div class=\"panel-footer\">Left Panel Footer</div></div><div class=\"panel\"><div class=\"panel-header justify-content-between\">Right Panel Header</div><div class=\"panel-body\">Right Panel Body</div></div></div><div class=\"panel-footer\">Main Panel Footer</div></div>"
|
139
|
+
|
140
|
+
assert_equal expected, actual
|
141
|
+
end
|
142
|
+
|
143
|
+
end
|