bs5 0.0.24 → 0.0.29

Sign up to get free protection for your applications and to get access to all the features.
Files changed (129) hide show
  1. checksums.yaml +4 -4
  2. data/app/components/bs5/alert_component.html.erb +1 -1
  3. data/app/components/bs5/alert_component.rb +1 -0
  4. data/app/components/bs5/button_tag_component.rb +10 -1
  5. data/app/components/bs5/carousel/caption_component.html.erb +3 -0
  6. data/app/components/bs5/carousel/caption_component.rb +8 -0
  7. data/app/components/bs5/carousel/item_component.html.erb +4 -0
  8. data/app/components/bs5/carousel/item_component.rb +74 -0
  9. data/app/components/bs5/carousel_component.html.erb +30 -0
  10. data/app/components/bs5/carousel_component.rb +60 -0
  11. data/app/components/bs5/close_button_component.rb +14 -6
  12. data/app/components/bs5/dropdown/item_component.html.erb +1 -0
  13. data/app/components/bs5/dropdown/item_component.rb +39 -0
  14. data/app/components/bs5/dropdown_component.html.erb +22 -0
  15. data/app/components/bs5/dropdown_component.rb +154 -0
  16. data/app/components/bs5/modal/body_component.html.erb +3 -0
  17. data/app/components/bs5/modal/body_component.rb +8 -0
  18. data/app/components/bs5/modal/controller_component.html.erb +1 -0
  19. data/app/components/bs5/modal/controller_component.rb +40 -0
  20. data/app/components/bs5/modal/footer_component.html.erb +4 -0
  21. data/app/components/bs5/modal/footer_component.rb +8 -0
  22. data/app/components/bs5/modal/header_component.html.erb +4 -0
  23. data/app/components/bs5/modal/header_component.rb +18 -0
  24. data/app/components/bs5/modal_component.html.erb +11 -0
  25. data/app/components/bs5/modal_component.rb +80 -0
  26. data/app/components/bs5/progress/bar_component.html.erb +1 -0
  27. data/app/components/bs5/progress/bar_component.rb +60 -0
  28. data/app/components/bs5/progress_component.html.erb +9 -0
  29. data/app/components/bs5/progress_component.rb +15 -0
  30. data/app/components/bs5/toast/body_component.html.erb +3 -0
  31. data/app/components/bs5/toast/body_component.rb +8 -0
  32. data/app/components/bs5/toast/header_component.html.erb +4 -0
  33. data/app/components/bs5/toast/header_component.rb +9 -0
  34. data/app/components/bs5/toast_component.html.erb +8 -0
  35. data/app/components/bs5/toast_component.rb +72 -0
  36. data/app/components/bs5/toast_container_component.html.erb +3 -0
  37. data/app/components/bs5/toast_container_component.rb +19 -0
  38. data/app/helpers/bs5/components_helper.rb +5 -2
  39. data/app/views/bs5/examples/alert/color/snippet.html.erb +8 -24
  40. data/app/views/bs5/examples/alert/default/snippet.html.erb +1 -3
  41. data/app/views/bs5/examples/carousel/_dark_variant.html.erb +2 -0
  42. data/app/views/bs5/examples/carousel/_examples.html.erb +13 -0
  43. data/app/views/bs5/examples/carousel/dark_variant/snippet1.html.erb +25 -0
  44. data/app/views/bs5/examples/carousel/examples/snippet1.html.erb +13 -0
  45. data/app/views/bs5/examples/carousel/examples/snippet2.html.erb +13 -0
  46. data/app/views/bs5/examples/carousel/examples/snippet3.html.erb +13 -0
  47. data/app/views/bs5/examples/carousel/examples/snippet4.html.erb +25 -0
  48. data/app/views/bs5/examples/carousel/examples/snippet5.html.erb +13 -0
  49. data/app/views/bs5/examples/carousel/examples/snippet6.html.erb +13 -0
  50. data/app/views/bs5/examples/dropdowns/dark/_example.html.erb +2 -0
  51. data/app/views/bs5/examples/dropdowns/dark/snippet.html.erb +7 -0
  52. data/app/views/bs5/examples/dropdowns/directions/_example.html.erb +7 -0
  53. data/app/views/bs5/examples/dropdowns/directions/snippet1.html.erb +17 -0
  54. data/app/views/bs5/examples/dropdowns/directions/snippet2.html.erb +17 -0
  55. data/app/views/bs5/examples/dropdowns/directions/snippet3.html.erb +17 -0
  56. data/app/views/bs5/examples/dropdowns/menu_alignment/_example.html.erb +5 -0
  57. data/app/views/bs5/examples/dropdowns/menu_alignment/snippet1.html.erb +5 -0
  58. data/app/views/bs5/examples/dropdowns/menu_alignment/snippet2.html.erb +7 -0
  59. data/app/views/bs5/examples/dropdowns/menu_alignment/snippet3.html.erb +7 -0
  60. data/app/views/bs5/examples/dropdowns/menu_content/_example.html.erb +9 -0
  61. data/app/views/bs5/examples/dropdowns/menu_content/snippet1.html.erb +5 -0
  62. data/app/views/bs5/examples/dropdowns/menu_content/snippet2.html.erb +7 -0
  63. data/app/views/bs5/examples/dropdowns/menu_content/snippet3.html.erb +10 -0
  64. data/app/views/bs5/examples/dropdowns/menu_content/snippet4.html.erb +24 -0
  65. data/app/views/bs5/examples/dropdowns/menu_items/_example.html.erb +7 -0
  66. data/app/views/bs5/examples/dropdowns/menu_items/snippet1.html.erb +5 -0
  67. data/app/views/bs5/examples/dropdowns/menu_items/snippet2.html.erb +6 -0
  68. data/app/views/bs5/examples/dropdowns/menu_items/snippet3.html.erb +5 -0
  69. data/app/views/bs5/examples/dropdowns/menu_items/snippet4.html.erb +5 -0
  70. data/app/views/bs5/examples/dropdowns/single/_example.html.erb +4 -0
  71. data/app/views/bs5/examples/dropdowns/single/snippet1.html.erb +5 -0
  72. data/app/views/bs5/examples/dropdowns/single/snippet2.html.erb +47 -0
  73. data/app/views/bs5/examples/dropdowns/single/snippet3.html.erb +47 -0
  74. data/app/views/bs5/examples/dropdowns/sizing/_example.html.erb +3 -0
  75. data/app/views/bs5/examples/dropdowns/sizing/snippet1.html.erb +17 -0
  76. data/app/views/bs5/examples/dropdowns/sizing/snippet2.html.erb +17 -0
  77. data/app/views/bs5/examples/dropdowns/split/_example.html.erb +3 -0
  78. data/app/views/bs5/examples/dropdowns/split/snippet1.html.erb +35 -0
  79. data/app/views/bs5/examples/dropdowns/split/snippet2.html.erb +47 -0
  80. data/app/views/bs5/examples/list_group/active/snippet.html.erb +5 -5
  81. data/app/views/bs5/examples/list_group/default/snippet.html.erb +5 -5
  82. data/app/views/bs5/examples/list_group/disabled/snippet.html.erb +5 -5
  83. data/app/views/bs5/examples/list_group/flush/snippet.html.erb +5 -5
  84. data/app/views/bs5/examples/list_group/horizontal/snippet.html.erb +18 -18
  85. data/app/views/bs5/examples/list_group/style/default.html.erb +8 -8
  86. data/app/views/bs5/examples/modal/_examples.html.erb +9 -0
  87. data/app/views/bs5/examples/modal/_fullscreen.html.erb +2 -0
  88. data/app/views/bs5/examples/modal/_optional_sizes.html.erb +2 -0
  89. data/app/views/bs5/examples/modal/examples/snippet1.html.erb +12 -0
  90. data/app/views/bs5/examples/modal/examples/snippet2.html.erb +12 -0
  91. data/app/views/bs5/examples/modal/examples/snippet3.html.erb +14 -0
  92. data/app/views/bs5/examples/modal/examples/snippet4.html.erb +12 -0
  93. data/app/views/bs5/examples/modal/fullscreen/snippet1.html.erb +55 -0
  94. data/app/views/bs5/examples/modal/optional_sizes/snippet1.html.erb +23 -0
  95. data/app/views/bs5/examples/progress/_animated.html.erb +2 -0
  96. data/app/views/bs5/examples/progress/_backgrounds.html.erb +2 -0
  97. data/app/views/bs5/examples/progress/_examples.html.erb +2 -0
  98. data/app/views/bs5/examples/progress/_labels.html.erb +2 -0
  99. data/app/views/bs5/examples/progress/_multiple_bars.html.erb +2 -0
  100. data/app/views/bs5/examples/progress/_striped.html.erb +2 -0
  101. data/app/views/bs5/examples/progress/animated/snippet1.html.erb +13 -0
  102. data/app/views/bs5/examples/progress/backgrounds/snippet1.html.erb +13 -0
  103. data/app/views/bs5/examples/progress/examples/snippet1.html.erb +17 -0
  104. data/app/views/bs5/examples/progress/labels/snippet1.html.erb +5 -0
  105. data/app/views/bs5/examples/progress/multiple_bars/snippet1.html.erb +5 -0
  106. data/app/views/bs5/examples/progress/striped/snippet1.html.erb +13 -0
  107. data/app/views/bs5/examples/toasts/color_schemes/_example.html.erb +2 -0
  108. data/app/views/bs5/examples/toasts/color_schemes/snippet.html.erb +33 -0
  109. data/app/views/bs5/examples/toasts/custom_content/_example.html.erb +3 -0
  110. data/app/views/bs5/examples/toasts/custom_content/snippet1.html.erb +3 -0
  111. data/app/views/bs5/examples/toasts/custom_content/snippet2.html.erb +9 -0
  112. data/app/views/bs5/examples/toasts/default/_example.html.erb +2 -0
  113. data/app/views/bs5/examples/toasts/default/snippet.html.erb +17 -0
  114. data/app/views/bs5/examples/toasts/js_options/_example.html.erb +2 -0
  115. data/app/views/bs5/examples/toasts/js_options/snippet.html.erb +23 -0
  116. data/app/views/bs5/examples/toasts/placement/_example.html.erb +3 -0
  117. data/app/views/bs5/examples/toasts/placement/snippet1.html.erb +44 -0
  118. data/app/views/bs5/examples/toasts/placement/snippet2.html.erb +24 -0
  119. data/app/views/bs5/examples/toasts/stacking/_example.html.erb +2 -0
  120. data/app/views/bs5/examples/toasts/stacking/snippet.html.erb +37 -0
  121. data/app/views/bs5/pages/carousel.html.erb +3 -0
  122. data/app/views/bs5/pages/dropdowns.html.erb +10 -0
  123. data/app/views/bs5/pages/modal.html.erb +4 -0
  124. data/app/views/bs5/pages/progress.html.erb +7 -0
  125. data/app/views/bs5/pages/toasts.html.erb +7 -0
  126. data/app/views/layouts/bs5/pages.html.erb +5 -0
  127. data/lib/bs5/version.rb +1 -1
  128. data/lib/generators/bs5/install/templates/bs5.js +24 -13
  129. metadata +113 -2
@@ -0,0 +1,13 @@
1
+ <div class="mb-3">
2
+ <%= bs5_progress(25, color: :success) %>
3
+ </div>
4
+
5
+ <div class="mb-3">
6
+ <%= bs5_progress(50, color: :info) %>
7
+ </div>
8
+
9
+ <div class="mb-3">
10
+ <%= bs5_progress(75, color: :warning) %>
11
+ </div>
12
+
13
+ <%= bs5_progress(100, color: :danger) %>
@@ -0,0 +1,17 @@
1
+ <div class="mb-3">
2
+ <%= bs5_progress(0) %>
3
+ </div>
4
+
5
+ <div class="mb-3">
6
+ <%= bs5_progress(25) %>
7
+ </div>
8
+
9
+ <div class="mb-3">
10
+ <%= bs5_progress(50) %>
11
+ </div>
12
+
13
+ <div class="mb-3">
14
+ <%= bs5_progress(75) %>
15
+ </div>
16
+
17
+ <%= bs5_progress(100) %>
@@ -0,0 +1,5 @@
1
+ <div class="mb-3">
2
+ <%= bs5_progress(25, label: true) %>
3
+ </div>
4
+
5
+ <%= bs5_progress(50, label: "Woah, we're half way there.") %>
@@ -0,0 +1,5 @@
1
+ <%= bs5_progress do |p| %>
2
+ <%= p.bar(15) %>
3
+ <%= p.bar(30, color: :success) %>
4
+ <%= p.bar(20, color: :info) %>
5
+ <% end %>
@@ -0,0 +1,13 @@
1
+ <div class="mb-3">
2
+ <%= bs5_progress(25, striped: true, color: :success) %>
3
+ </div>
4
+
5
+ <div class="mb-3">
6
+ <%= bs5_progress(50, striped: true, color: :info) %>
7
+ </div>
8
+
9
+ <div class="mb-3">
10
+ <%= bs5_progress(75, striped: true, color: :warning) %>
11
+ </div>
12
+
13
+ <%= bs5_progress(100, striped: true, color: :danger) %>
@@ -0,0 +1,2 @@
1
+ <h2>Color schemes</h2>
2
+ <%= bs5_example(snippet: 'toasts/color_schemes/snippet') %>
@@ -0,0 +1,33 @@
1
+ <%= bs5_toast_container do %>
2
+ <%= bs5_toast(color: :primary, class: 'd-flex align-items-center') do |t| %>
3
+ <%= t.body do %>Hello, world! This is a toast message.<% end %>
4
+ <% end %>
5
+
6
+ <%= bs5_toast(color: :secondary, class: 'd-flex align-items-center') do |t| %>
7
+ <%= t.body do %>Hello, world! This is a toast message.<% end %>
8
+ <% end %>
9
+
10
+ <%= bs5_toast(color: :success, class: 'd-flex align-items-center') do |t| %>
11
+ <%= t.body do %>Hello, world! This is a toast message.<% end %>
12
+ <% end %>
13
+
14
+ <%= bs5_toast(color: :danger, class: 'd-flex align-items-center') do |t| %>
15
+ <%= t.body do %>Hello, world! This is a toast message.<% end %>
16
+ <% end %>
17
+
18
+ <%= bs5_toast(color: :warning, class: 'd-flex align-items-center') do |t| %>
19
+ <%= t.body do %>Hello, world! This is a toast message.<% end %>
20
+ <% end %>
21
+
22
+ <%= bs5_toast(color: :info, class: 'd-flex align-items-center') do |t| %>
23
+ <%= t.body do %>Hello, world! This is a toast message.<% end %>
24
+ <% end %>
25
+
26
+ <%= bs5_toast(color: :light, class: 'd-flex align-items-center') do |t| %>
27
+ <%= t.body do %>Hello, world! This is a toast message.<% end %>
28
+ <% end %>
29
+
30
+ <%= bs5_toast(color: :dark, class: 'd-flex align-items-center') do |t| %>
31
+ <%= t.body do %>Hello, world! This is a toast message.<% end %>
32
+ <% end %>
33
+ <% end %>
@@ -0,0 +1,3 @@
1
+ <h2>Custom content</h2>
2
+ <%= bs5_example(snippet: 'toasts/custom_content/snippet1') %>
3
+ <%= bs5_example(snippet: 'toasts/custom_content/snippet2') %>
@@ -0,0 +1,3 @@
1
+ <%= bs5_toast(class: 'd-flex align-items-center') do |t| %>
2
+ <%= t.body do %>Hello, world! This is a toast message.<% end %>
3
+ <% end %>
@@ -0,0 +1,9 @@
1
+ <%= bs5_toast(close_button: false) do |t| %>
2
+ <%= t.body do %>
3
+ Hello, world! This is a toast message.
4
+ <div class="mt-2 pt-2 border-top">
5
+ <%= bs5_button_tag('Take action', color: :primary, size: :small) %>
6
+ <%= bs5_button_tag('Close', color: :secondary, size: :small, dismiss: :toast) %>
7
+ </div>
8
+ <% end %>
9
+ <% end %>
@@ -0,0 +1,2 @@
1
+ <h2>Default</h2>
2
+ <%= bs5_example(snippet: 'toasts/default/snippet') %>
@@ -0,0 +1,17 @@
1
+ <%= bs5_toast do |t| %>
2
+ <%= t.header do %>
3
+ <svg
4
+ class="bd-placeholder-img rounded me-2"
5
+ width="20"
6
+ height="20"
7
+ xmlns="http://www.w3.org/2000/svg"
8
+ aria-hidden="true"
9
+ focusable="false"
10
+ >
11
+ <rect width="100%" height="100%" fill="#007aff"></rect>
12
+ </svg>
13
+ <strong class="me-auto">Bootstrap</strong>
14
+ <small>11 mins ago</small>
15
+ <% end %>
16
+ <%= t.body { "Hello, world! This is a toast message." } %>
17
+ <% end %>
@@ -0,0 +1,2 @@
1
+ <h2>Options</h2>
2
+ <%= bs5_example(snippet: 'toasts/js_options/snippet') %>
@@ -0,0 +1,23 @@
1
+ <%= bs5_toast_container do %>
2
+ <%= bs5_toast(autohide: true, delay: 10_000, animation: false) do |t| %>
3
+ <%= t.header do %>
4
+ <svg
5
+ class="bd-placeholder-img rounded me-2"
6
+ width="20"
7
+ height="20"
8
+ xmlns="http://www.w3.org/2000/svg"
9
+ aria-hidden="true"
10
+ focusable="false"
11
+ >
12
+ <rect width="100%" height="100%" fill="#007aff"></rect>
13
+ </svg>
14
+ <strong class="me-auto">Bootstrap</strong>
15
+ <small>11 mins ago</small>
16
+ <% end %>
17
+ <%= t.body do %>Hello, world! This is a toast message.<% end %>
18
+ <% end %>
19
+
20
+ <%= bs5_toast(close_button: false, autohide: true, delay: 11_000) do |t| %>
21
+ <%= t.body do %>Hello, world! This is a toast message.<% end %>
22
+ <% end %>
23
+ <% end %>
@@ -0,0 +1,3 @@
1
+ <h2>Placement</h2>
2
+ <%= bs5_example(snippet: 'toasts/placement/snippet1') %>
3
+ <%= bs5_example(snippet: 'toasts/placement/snippet2') %>
@@ -0,0 +1,44 @@
1
+ <div
2
+ aria-live="polite"
3
+ aria-atomic="true"
4
+ class="position-relative"
5
+ style="min-height: 240px"
6
+ >
7
+ <%= bs5_toast_container(class: 'position-absolute top-0 end-0') do %>
8
+ <%= bs5_toast do |t| %>
9
+ <%= t.header do %>
10
+ <svg
11
+ class="bd-placeholder-img rounded me-2"
12
+ width="20"
13
+ height="20"
14
+ xmlns="http://www.w3.org/2000/svg"
15
+ aria-hidden="true"
16
+ focusable="false"
17
+ >
18
+ <rect width="100%" height="100%" fill="#007aff"></rect>
19
+ </svg>
20
+ <strong class="me-auto">Bootstrap</strong>
21
+ <small>just now</small>
22
+ <% end %>
23
+ <%= t.body do %>See? Just like this.<% end %>
24
+ <% end %>
25
+
26
+ <%= bs5_toast do |t| %>
27
+ <%= t.header do %>
28
+ <svg
29
+ class="bd-placeholder-img rounded me-2"
30
+ width="20"
31
+ height="20"
32
+ xmlns="http://www.w3.org/2000/svg"
33
+ aria-hidden="true"
34
+ focusable="false"
35
+ >
36
+ <rect width="100%" height="100%" fill="#007aff"></rect>
37
+ </svg>
38
+ <strong class="me-auto">Bootstrap</strong>
39
+ <small>2 seconds ago</small>
40
+ <% end %>
41
+ <%= t.body do %>Heads up, toasts will stack automatically<% end %>
42
+ <% end %>
43
+ <% end %>
44
+ </div>
@@ -0,0 +1,24 @@
1
+ <div
2
+ aria-live="polite"
3
+ aria-atomic="true"
4
+ class="d-flex justify-content-center align-items-center w-100"
5
+ style="min-height: 240px"
6
+ >
7
+ <%= bs5_toast do |t| %>
8
+ <%= t.header do %>
9
+ <svg
10
+ class="bd-placeholder-img rounded me-2"
11
+ width="20"
12
+ height="20"
13
+ xmlns="http://www.w3.org/2000/svg"
14
+ aria-hidden="true"
15
+ focusable="false"
16
+ >
17
+ <rect width="100%" height="100%" fill="#007aff"></rect>
18
+ </svg>
19
+ <strong class="me-auto">Bootstrap</strong>
20
+ <small>11 mins ago</small>
21
+ <% end %>
22
+ <%= t.body do %>Hello, world! This is a toast message.<% end %>
23
+ <% end %>
24
+ </div>
@@ -0,0 +1,2 @@
1
+ <h2>Stacking</h2>
2
+ <%= bs5_example(snippet: 'toasts/stacking/snippet') %>
@@ -0,0 +1,37 @@
1
+ <%= bs5_toast_container do %>
2
+ <%= bs5_toast do |t| %>
3
+ <%= t.header do %>
4
+ <svg
5
+ class="bd-placeholder-img rounded me-2"
6
+ width="20"
7
+ height="20"
8
+ xmlns="http://www.w3.org/2000/svg"
9
+ aria-hidden="true"
10
+ focusable="false"
11
+ >
12
+ <rect width="100%" height="100%" fill="#007aff"></rect>
13
+ </svg>
14
+ <strong class="me-auto">Bootstrap</strong>
15
+ <small>just now</small>
16
+ <% end %>
17
+ <%= t.body do %>See? Just like this.<% end %>
18
+ <% end %>
19
+
20
+ <%= bs5_toast do |t| %>
21
+ <%= t.header do %>
22
+ <svg
23
+ class="bd-placeholder-img rounded me-2"
24
+ width="20"
25
+ height="20"
26
+ xmlns="http://www.w3.org/2000/svg"
27
+ aria-hidden="true"
28
+ focusable="false"
29
+ >
30
+ <rect width="100%" height="100%" fill="#007aff"></rect>
31
+ </svg>
32
+ <strong class="me-auto">Bootstrap</strong>
33
+ <small>2 seconds ago</small>
34
+ <% end %>
35
+ <%= t.body do %>Heads up, toasts will stack automatically<% end %>
36
+ <% end %>
37
+ <% end %>
@@ -0,0 +1,3 @@
1
+ <h1>Carousel</h1>
2
+ <%= render 'bs5/examples/carousel/examples' %>
3
+ <%= render 'bs5/examples/carousel/dark_variant' %>
@@ -0,0 +1,10 @@
1
+ <h1>Dropdowns</h1>
2
+ <h2>Examples</h2>
3
+ <%= render 'bs5/examples/dropdowns/single/example' %>
4
+ <%= render 'bs5/examples/dropdowns/split/example' %>
5
+ <%= render 'bs5/examples/dropdowns/sizing/example' %>
6
+ <%= render 'bs5/examples/dropdowns/dark/example' %>
7
+ <%= render 'bs5/examples/dropdowns/directions/example' %>
8
+ <%= render 'bs5/examples/dropdowns/menu_items/example' %>
9
+ <%= render 'bs5/examples/dropdowns/menu_alignment/example' %>
10
+ <%= render 'bs5/examples/dropdowns/menu_content/example' %>
@@ -0,0 +1,4 @@
1
+ <h1>Modal</h1>
2
+ <%= render 'bs5/examples/modal/examples' %>
3
+ <%= render 'bs5/examples/modal/optional_sizes' %>
4
+ <%= render 'bs5/examples/modal/fullscreen' %>
@@ -0,0 +1,7 @@
1
+ <h1>Progress</h1>
2
+ <%= render 'bs5/examples/progress/examples' %>
3
+ <%= render 'bs5/examples/progress/labels' %>
4
+ <%= render 'bs5/examples/progress/backgrounds' %>
5
+ <%= render 'bs5/examples/progress/multiple_bars' %>
6
+ <%= render 'bs5/examples/progress/striped' %>
7
+ <%= render 'bs5/examples/progress/animated' %>
@@ -0,0 +1,7 @@
1
+ <h1>Toasts</h1>
2
+ <%= render 'bs5/examples/toasts/default/example' %>
3
+ <%= render 'bs5/examples/toasts/stacking/example' %>
4
+ <%= render 'bs5/examples/toasts/custom_content/example' %>
5
+ <%= render 'bs5/examples/toasts/color_schemes/example' %>
6
+ <%= render 'bs5/examples/toasts/placement/example' %>
7
+ <%= render 'bs5/examples/toasts/js_options/example' %>
@@ -21,10 +21,15 @@
21
21
  <% lg.item(active: current_page?(pages_path('buttons'))) do %><%= link_to 'Buttons', pages_path('buttons') %><% end %>
22
22
  <% lg.item(active: current_page?(pages_path('button_group'))) do %><%= link_to 'Button group', pages_path('button_group') %><% end %>
23
23
  <% lg.item(active: current_page?(pages_path('close_button'))) do %><%= link_to 'Close button', pages_path('close_button') %><% end %>
24
+ <% lg.item(active: current_page?(pages_path('carousel'))) do %><%= link_to 'Carousel', pages_path('carousel') %><% end %>
24
25
  <% lg.item(active: current_page?(pages_path('collapse'))) do %><%= link_to 'Collapse', pages_path('collapse') %><% end %>
26
+ <% lg.item(active: current_page?(pages_path('dropdowns'))) do %><%= link_to 'Dropdowns', pages_path('dropdowns') %><% end %>
25
27
  <% lg.item(active: current_page?(pages_path('list_group'))) do %><%= link_to 'List group', pages_path('list_group') %><% end %>
28
+ <% lg.item(active: current_page?(pages_path('modal'))) do %><%= link_to 'Modal', pages_path('modal') %><% end %>
26
29
  <% lg.item(active: current_page?(pages_path('popovers'))) do %><%= link_to 'Popovers', pages_path('popovers') %><% end %>
30
+ <% lg.item(active: current_page?(pages_path('progress'))) do %><%= link_to 'Progress', pages_path('progress') %><% end %>
27
31
  <% lg.item(active: current_page?(pages_path('spinners'))) do %><%= link_to 'Spinners', pages_path('spinners') %><% end %>
32
+ <% lg.item(active: current_page?(pages_path('toasts'))) do %><%= link_to 'Toasts', pages_path('toasts') %><% end %>
28
33
  <% lg.item(active: current_page?(pages_path('tooltips'))) do %><%= link_to 'Tooltips', pages_path('tooltips') %><% end %>
29
34
  <%- end %>
30
35
  </div>
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Bs5
4
- VERSION = '0.0.24'
4
+ VERSION = '0.0.29'
5
5
  end
@@ -1,24 +1,35 @@
1
1
  import * as bootstrap from "bootstrap";
2
2
 
3
- function tooltipify() {
4
- const tooltipTriggerList = [].slice.call(
5
- document.querySelectorAll('[data-bs-toggle="tooltip"]')
6
- );
7
- tooltipTriggerList.map(function (tooltipTriggerEl) {
8
- return new bootstrap.Tooltip(tooltipTriggerEl);
9
- });
3
+ function popoverify() {
4
+ document
5
+ .querySelectorAll('[data-bs-toggle="popover"]')
6
+ .forEach(function (popoverTriggerEl) {
7
+ new bootstrap.Popover(popoverTriggerEl);
8
+ });
10
9
  }
11
10
 
12
- function popoverify() {
13
- const popoverTriggerList = [].slice.call(
14
- document.querySelectorAll('[data-bs-toggle="popover"]')
15
- );
16
- popoverTriggerList.map(function (popoverTriggerEl) {
17
- return new bootstrap.Popover(popoverTriggerEl);
11
+ function toastify() {
12
+ document.querySelectorAll(".toast").forEach(function (toastNode) {
13
+ let autohide = new RegExp("true", "i").test(
14
+ toastNode.dataset["bsAutohide"] || "false"
15
+ );
16
+ let toast = new bootstrap.Toast(toastNode, {
17
+ autohide,
18
+ });
19
+ toast.show();
18
20
  });
19
21
  }
20
22
 
23
+ function tooltipify() {
24
+ document
25
+ .querySelectorAll('[data-bs-toggle="tooltip"]')
26
+ .forEach(function (tooltipTriggerEl) {
27
+ new bootstrap.Tooltip(tooltipTriggerEl);
28
+ });
29
+ }
30
+
21
31
  export function start() {
22
32
  popoverify();
33
+ toastify();
23
34
  tooltipify();
24
35
  }
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: bs5
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.24
4
+ version: 0.0.29
5
5
  platform: ruby
6
6
  authors:
7
7
  - Patrick Baselier
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2020-12-16 00:00:00.000000000 Z
11
+ date: 2020-12-29 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: nokogiri
@@ -141,14 +141,46 @@ files:
141
141
  - app/components/bs5/button_to_component.rb
142
142
  - app/components/bs5/button_toolbar_component.html.erb
143
143
  - app/components/bs5/button_toolbar_component.rb
144
+ - app/components/bs5/carousel/caption_component.html.erb
145
+ - app/components/bs5/carousel/caption_component.rb
146
+ - app/components/bs5/carousel/item_component.html.erb
147
+ - app/components/bs5/carousel/item_component.rb
148
+ - app/components/bs5/carousel_component.html.erb
149
+ - app/components/bs5/carousel_component.rb
144
150
  - app/components/bs5/close_button_component.html.erb
145
151
  - app/components/bs5/close_button_component.rb
152
+ - app/components/bs5/dropdown/item_component.html.erb
153
+ - app/components/bs5/dropdown/item_component.rb
154
+ - app/components/bs5/dropdown_component.html.erb
155
+ - app/components/bs5/dropdown_component.rb
146
156
  - app/components/bs5/example_component.html.erb
147
157
  - app/components/bs5/example_component.rb
148
158
  - app/components/bs5/list_group_component.html.erb
149
159
  - app/components/bs5/list_group_component.rb
160
+ - app/components/bs5/modal/body_component.html.erb
161
+ - app/components/bs5/modal/body_component.rb
162
+ - app/components/bs5/modal/controller_component.html.erb
163
+ - app/components/bs5/modal/controller_component.rb
164
+ - app/components/bs5/modal/footer_component.html.erb
165
+ - app/components/bs5/modal/footer_component.rb
166
+ - app/components/bs5/modal/header_component.html.erb
167
+ - app/components/bs5/modal/header_component.rb
168
+ - app/components/bs5/modal_component.html.erb
169
+ - app/components/bs5/modal_component.rb
170
+ - app/components/bs5/progress/bar_component.html.erb
171
+ - app/components/bs5/progress/bar_component.rb
172
+ - app/components/bs5/progress_component.html.erb
173
+ - app/components/bs5/progress_component.rb
150
174
  - app/components/bs5/spinner_component.html.erb
151
175
  - app/components/bs5/spinner_component.rb
176
+ - app/components/bs5/toast/body_component.html.erb
177
+ - app/components/bs5/toast/body_component.rb
178
+ - app/components/bs5/toast/header_component.html.erb
179
+ - app/components/bs5/toast/header_component.rb
180
+ - app/components/bs5/toast_component.html.erb
181
+ - app/components/bs5/toast_component.rb
182
+ - app/components/bs5/toast_container_component.html.erb
183
+ - app/components/bs5/toast_container_component.rb
152
184
  - app/controllers/bs5/application_controller.rb
153
185
  - app/controllers/bs5/pages_controller.rb
154
186
  - app/helpers/bs5/application_helper.rb
@@ -207,6 +239,15 @@ files:
207
239
  - app/views/bs5/examples/buttons/button_tag/toggle_states/snippet.html.erb
208
240
  - app/views/bs5/examples/buttons/button_to/default/_example.html.erb
209
241
  - app/views/bs5/examples/buttons/button_to/default/snippet.html.erb
242
+ - app/views/bs5/examples/carousel/_dark_variant.html.erb
243
+ - app/views/bs5/examples/carousel/_examples.html.erb
244
+ - app/views/bs5/examples/carousel/dark_variant/snippet1.html.erb
245
+ - app/views/bs5/examples/carousel/examples/snippet1.html.erb
246
+ - app/views/bs5/examples/carousel/examples/snippet2.html.erb
247
+ - app/views/bs5/examples/carousel/examples/snippet3.html.erb
248
+ - app/views/bs5/examples/carousel/examples/snippet4.html.erb
249
+ - app/views/bs5/examples/carousel/examples/snippet5.html.erb
250
+ - app/views/bs5/examples/carousel/examples/snippet6.html.erb
210
251
  - app/views/bs5/examples/close_button/default/_example.html.erb
211
252
  - app/views/bs5/examples/close_button/default/snippet.html.erb
212
253
  - app/views/bs5/examples/close_button/disabled/_example.html.erb
@@ -216,6 +257,36 @@ files:
216
257
  - app/views/bs5/examples/collapse/default/_example.html.erb
217
258
  - app/views/bs5/examples/collapse/default/multiple_targets.html.erb
218
259
  - app/views/bs5/examples/collapse/default/snippet.html.erb
260
+ - app/views/bs5/examples/dropdowns/dark/_example.html.erb
261
+ - app/views/bs5/examples/dropdowns/dark/snippet.html.erb
262
+ - app/views/bs5/examples/dropdowns/directions/_example.html.erb
263
+ - app/views/bs5/examples/dropdowns/directions/snippet1.html.erb
264
+ - app/views/bs5/examples/dropdowns/directions/snippet2.html.erb
265
+ - app/views/bs5/examples/dropdowns/directions/snippet3.html.erb
266
+ - app/views/bs5/examples/dropdowns/menu_alignment/_example.html.erb
267
+ - app/views/bs5/examples/dropdowns/menu_alignment/snippet1.html.erb
268
+ - app/views/bs5/examples/dropdowns/menu_alignment/snippet2.html.erb
269
+ - app/views/bs5/examples/dropdowns/menu_alignment/snippet3.html.erb
270
+ - app/views/bs5/examples/dropdowns/menu_content/_example.html.erb
271
+ - app/views/bs5/examples/dropdowns/menu_content/snippet1.html.erb
272
+ - app/views/bs5/examples/dropdowns/menu_content/snippet2.html.erb
273
+ - app/views/bs5/examples/dropdowns/menu_content/snippet3.html.erb
274
+ - app/views/bs5/examples/dropdowns/menu_content/snippet4.html.erb
275
+ - app/views/bs5/examples/dropdowns/menu_items/_example.html.erb
276
+ - app/views/bs5/examples/dropdowns/menu_items/snippet1.html.erb
277
+ - app/views/bs5/examples/dropdowns/menu_items/snippet2.html.erb
278
+ - app/views/bs5/examples/dropdowns/menu_items/snippet3.html.erb
279
+ - app/views/bs5/examples/dropdowns/menu_items/snippet4.html.erb
280
+ - app/views/bs5/examples/dropdowns/single/_example.html.erb
281
+ - app/views/bs5/examples/dropdowns/single/snippet1.html.erb
282
+ - app/views/bs5/examples/dropdowns/single/snippet2.html.erb
283
+ - app/views/bs5/examples/dropdowns/single/snippet3.html.erb
284
+ - app/views/bs5/examples/dropdowns/sizing/_example.html.erb
285
+ - app/views/bs5/examples/dropdowns/sizing/snippet1.html.erb
286
+ - app/views/bs5/examples/dropdowns/sizing/snippet2.html.erb
287
+ - app/views/bs5/examples/dropdowns/split/_example.html.erb
288
+ - app/views/bs5/examples/dropdowns/split/snippet1.html.erb
289
+ - app/views/bs5/examples/dropdowns/split/snippet2.html.erb
219
290
  - app/views/bs5/examples/list_group/actionable/_example.html.erb
220
291
  - app/views/bs5/examples/list_group/actionable/button.html.erb
221
292
  - app/views/bs5/examples/list_group/actionable/snippet.html.erb
@@ -239,6 +310,15 @@ files:
239
310
  - app/views/bs5/examples/list_group/style/default.html.erb
240
311
  - app/views/bs5/examples/list_group/with_badges/_example.html.erb
241
312
  - app/views/bs5/examples/list_group/with_badges/default.html.erb
313
+ - app/views/bs5/examples/modal/_examples.html.erb
314
+ - app/views/bs5/examples/modal/_fullscreen.html.erb
315
+ - app/views/bs5/examples/modal/_optional_sizes.html.erb
316
+ - app/views/bs5/examples/modal/examples/snippet1.html.erb
317
+ - app/views/bs5/examples/modal/examples/snippet2.html.erb
318
+ - app/views/bs5/examples/modal/examples/snippet3.html.erb
319
+ - app/views/bs5/examples/modal/examples/snippet4.html.erb
320
+ - app/views/bs5/examples/modal/fullscreen/snippet1.html.erb
321
+ - app/views/bs5/examples/modal/optional_sizes/snippet1.html.erb
242
322
  - app/views/bs5/examples/popovers/default/_example.html.erb
243
323
  - app/views/bs5/examples/popovers/default/snippet.html.erb
244
324
  - app/views/bs5/examples/popovers/disabled_elements/_example.html.erb
@@ -247,6 +327,18 @@ files:
247
327
  - app/views/bs5/examples/popovers/dismissable_on_next_click/snippet.html.erb
248
328
  - app/views/bs5/examples/popovers/four_directions/_example.html.erb
249
329
  - app/views/bs5/examples/popovers/four_directions/snippet.html.erb
330
+ - app/views/bs5/examples/progress/_animated.html.erb
331
+ - app/views/bs5/examples/progress/_backgrounds.html.erb
332
+ - app/views/bs5/examples/progress/_examples.html.erb
333
+ - app/views/bs5/examples/progress/_labels.html.erb
334
+ - app/views/bs5/examples/progress/_multiple_bars.html.erb
335
+ - app/views/bs5/examples/progress/_striped.html.erb
336
+ - app/views/bs5/examples/progress/animated/snippet1.html.erb
337
+ - app/views/bs5/examples/progress/backgrounds/snippet1.html.erb
338
+ - app/views/bs5/examples/progress/examples/snippet1.html.erb
339
+ - app/views/bs5/examples/progress/labels/snippet1.html.erb
340
+ - app/views/bs5/examples/progress/multiple_bars/snippet1.html.erb
341
+ - app/views/bs5/examples/progress/striped/snippet1.html.erb
250
342
  - app/views/bs5/examples/spinners/border/_example.html.erb
251
343
  - app/views/bs5/examples/spinners/border/snippet.html.erb
252
344
  - app/views/bs5/examples/spinners/buttons/_example.html.erb
@@ -265,6 +357,20 @@ files:
265
357
  - app/views/bs5/examples/spinners/size/_example.html.erb
266
358
  - app/views/bs5/examples/spinners/size/size1.html.erb
267
359
  - app/views/bs5/examples/spinners/size/size2.html.erb
360
+ - app/views/bs5/examples/toasts/color_schemes/_example.html.erb
361
+ - app/views/bs5/examples/toasts/color_schemes/snippet.html.erb
362
+ - app/views/bs5/examples/toasts/custom_content/_example.html.erb
363
+ - app/views/bs5/examples/toasts/custom_content/snippet1.html.erb
364
+ - app/views/bs5/examples/toasts/custom_content/snippet2.html.erb
365
+ - app/views/bs5/examples/toasts/default/_example.html.erb
366
+ - app/views/bs5/examples/toasts/default/snippet.html.erb
367
+ - app/views/bs5/examples/toasts/js_options/_example.html.erb
368
+ - app/views/bs5/examples/toasts/js_options/snippet.html.erb
369
+ - app/views/bs5/examples/toasts/placement/_example.html.erb
370
+ - app/views/bs5/examples/toasts/placement/snippet1.html.erb
371
+ - app/views/bs5/examples/toasts/placement/snippet2.html.erb
372
+ - app/views/bs5/examples/toasts/stacking/_example.html.erb
373
+ - app/views/bs5/examples/toasts/stacking/snippet.html.erb
268
374
  - app/views/bs5/examples/tooltips/default/_example.html.erb
269
375
  - app/views/bs5/examples/tooltips/default/buttons.html.erb
270
376
  - app/views/bs5/examples/tooltips/default/disabled_elements.html.erb
@@ -275,11 +381,16 @@ files:
275
381
  - app/views/bs5/pages/breadcrumb.html.erb
276
382
  - app/views/bs5/pages/button_group.html.erb
277
383
  - app/views/bs5/pages/buttons.html.erb
384
+ - app/views/bs5/pages/carousel.html.erb
278
385
  - app/views/bs5/pages/close_button.html.erb
279
386
  - app/views/bs5/pages/collapse.html.erb
387
+ - app/views/bs5/pages/dropdowns.html.erb
280
388
  - app/views/bs5/pages/list_group.html.erb
389
+ - app/views/bs5/pages/modal.html.erb
281
390
  - app/views/bs5/pages/popovers.html.erb
391
+ - app/views/bs5/pages/progress.html.erb
282
392
  - app/views/bs5/pages/spinners.html.erb
393
+ - app/views/bs5/pages/toasts.html.erb
283
394
  - app/views/bs5/pages/tooltips.html.erb
284
395
  - app/views/layouts/bs5/application.html.erb
285
396
  - app/views/layouts/bs5/pages.html.erb