@gitlab/ui 92.1.1 → 92.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (449) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/bin/migrate_custom_utils_to_tw.bundled.mjs +11 -3
  3. package/dist/components/experimental/duo/chat/components/duo_chat_context/duo_chat_context_item_popover/duo_chat_context_item_popover.js +29 -1
  4. package/dist/components/experimental/duo/chat/components/duo_chat_context/duo_chat_context_item_selections/duo_chat_context_item_selections.js +18 -1
  5. package/dist/components/experimental/duo/chat/components/duo_chat_message/duo_chat_message.js +4 -6
  6. package/dist/components/experimental/duo/chat/constants.js +2 -1
  7. package/dist/index.css +4 -2
  8. package/dist/index.css.map +1 -1
  9. package/dist/tailwind.css +1 -1
  10. package/dist/tailwind.css.map +1 -1
  11. package/dist/vendor/bootstrap-vue/src/components/form/index.js +0 -4
  12. package/dist/vendor/bootstrap-vue/src/components/index.js +0 -48
  13. package/dist/vendor/bootstrap-vue/src/components/layout/index.js +0 -6
  14. package/dist/vendor/bootstrap-vue/src/components/nav/index.js +0 -6
  15. package/dist/vendor/bootstrap-vue/src/components/navbar/index.js +1 -8
  16. package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip.js +2 -6
  17. package/dist/vendor/bootstrap-vue/src/constants/classes.js +1 -2
  18. package/dist/vendor/bootstrap-vue/src/constants/components.js +1 -51
  19. package/dist/vendor/bootstrap-vue/src/constants/events.js +1 -12
  20. package/dist/vendor/bootstrap-vue/src/constants/key-codes.js +1 -5
  21. package/dist/vendor/bootstrap-vue/src/constants/props.js +1 -4
  22. package/dist/vendor/bootstrap-vue/src/constants/regex.js +1 -20
  23. package/dist/vendor/bootstrap-vue/src/constants/slots.js +1 -33
  24. package/dist/vendor/bootstrap-vue/src/directives/toggle/toggle.js +1 -1
  25. package/dist/vendor/bootstrap-vue/src/index.js +0 -74
  26. package/dist/vendor/bootstrap-vue/src/utils/array.js +1 -3
  27. package/dist/vendor/bootstrap-vue/src/utils/inspect.js +1 -3
  28. package/dist/vendor/bootstrap-vue/src/utils/math.js +1 -3
  29. package/dist/vendor/bootstrap-vue/src/utils/object.js +1 -6
  30. package/dist/vendor/bootstrap-vue/src/utils/props.js +2 -8
  31. package/dist/vendor/bootstrap-vue/src/utils/string.js +1 -10
  32. package/package.json +1 -1
  33. package/src/components/base/accordion/accordion_item.scss +3 -3
  34. package/src/components/base/alert/alert.scss +3 -3
  35. package/src/components/base/avatar_labeled/avatar_labeled.scss +2 -2
  36. package/src/components/base/avatars_inline/avatars_inline.scss +1 -1
  37. package/src/components/base/badge/badge.scss +2 -2
  38. package/src/components/base/banner/banner.scss +2 -2
  39. package/src/components/base/breadcrumb/breadcrumb.scss +3 -3
  40. package/src/components/base/broadcast_message/broadcast_message.scss +3 -3
  41. package/src/components/base/button/button.scss +26 -16
  42. package/src/components/base/card/card.scss +1 -1
  43. package/src/components/base/datepicker/datepicker.scss +10 -10
  44. package/src/components/base/drawer/drawer.scss +5 -5
  45. package/src/components/base/dropdown/dropdown.scss +28 -28
  46. package/src/components/base/dropdown/dropdown_divider.scss +3 -3
  47. package/src/components/base/dropdown/dropdown_item.scss +9 -9
  48. package/src/components/base/dropdown/dropdown_section_header.scss +2 -2
  49. package/src/components/base/dropdown/dropdown_text.scss +1 -1
  50. package/src/components/base/filtered_search/filtered_search.scss +7 -7
  51. package/src/components/base/filtered_search/filtered_search_suggestion.scss +1 -1
  52. package/src/components/base/filtered_search/filtered_search_suggestion_list.scss +3 -3
  53. package/src/components/base/filtered_search/filtered_search_term.scss +2 -2
  54. package/src/components/base/filtered_search/filtered_search_token.scss +4 -4
  55. package/src/components/base/filtered_search/filtered_search_token_segment.scss +2 -2
  56. package/src/components/base/form/form_checkbox/form_checkbox.scss +10 -10
  57. package/src/components/base/form/form_group/form_group.scss +5 -5
  58. package/src/components/base/form/form_input/form_input.scss +2 -2
  59. package/src/components/base/form/form_select/form_select.scss +2 -2
  60. package/src/components/base/keyset_pagination/keyset_pagination.scss +1 -1
  61. package/src/components/base/label/label.scss +1 -1
  62. package/src/components/base/loading_icon/loading_icon.scss +1 -1
  63. package/src/components/base/markdown/markdown.scss +33 -33
  64. package/src/components/base/modal/modal.scss +11 -11
  65. package/src/components/base/new_dropdowns/dropdown.scss +14 -14
  66. package/src/components/base/new_dropdowns/dropdown_item.scss +9 -9
  67. package/src/components/base/new_dropdowns/listbox/listbox.scss +1 -1
  68. package/src/components/base/pagination/pagination.scss +3 -3
  69. package/src/components/base/path/path.scss +5 -5
  70. package/src/components/base/popover/popover.scss +5 -5
  71. package/src/components/base/search_box_by_click/search_box_by_click.scss +2 -2
  72. package/src/components/base/search_box_by_type/search_box_by_type.scss +4 -4
  73. package/src/components/base/table/table.scss +4 -4
  74. package/src/components/base/tabs/tabs/tabs.scss +10 -10
  75. package/src/components/base/toast/toast.scss +7 -7
  76. package/src/components/base/toggle/toggle.scss +6 -6
  77. package/src/components/base/token/token.scss +5 -5
  78. package/src/components/base/tooltip/tooltip.scss +3 -3
  79. package/src/components/charts/legend/legend.scss +4 -4
  80. package/src/components/charts/series_label/series_label.scss +1 -1
  81. package/src/components/experimental/duo/chat/components/duo_chat_context/duo_chat_context_item_popover/duo_chat_context_item_popover.vue +62 -30
  82. package/src/components/experimental/duo/chat/components/duo_chat_context/duo_chat_context_item_selections/duo_chat_context_item_selections.vue +29 -10
  83. package/src/components/experimental/duo/chat/components/duo_chat_message/duo_chat_message.scss +1 -1
  84. package/src/components/experimental/duo/chat/components/duo_chat_message/duo_chat_message.vue +11 -6
  85. package/src/components/experimental/duo/chat/constants.js +2 -0
  86. package/src/components/experimental/duo/chat/duo_chat.scss +4 -4
  87. package/src/components/shared_components/charts/tooltip_default_format.scss +1 -1
  88. package/src/scss/bootstrap_vue.scss +0 -18
  89. package/src/scss/typescale/_index.scss +9 -9
  90. package/src/vendor/bootstrap-vue/nuxt/index.js +0 -8
  91. package/src/vendor/bootstrap-vue/src/_utilities.scss +0 -9
  92. package/src/vendor/bootstrap-vue/src/_variables.scss +0 -52
  93. package/src/vendor/bootstrap-vue/src/components/form/index.d.ts +0 -3
  94. package/src/vendor/bootstrap-vue/src/components/form/index.js +1 -4
  95. package/src/vendor/bootstrap-vue/src/components/form/package.json +0 -12
  96. package/src/vendor/bootstrap-vue/src/components/index.d.ts +0 -24
  97. package/src/vendor/bootstrap-vue/src/components/index.js +0 -48
  98. package/src/vendor/bootstrap-vue/src/components/index.scss +0 -15
  99. package/src/vendor/bootstrap-vue/src/components/layout/index.d.ts +0 -6
  100. package/src/vendor/bootstrap-vue/src/components/layout/index.js +1 -5
  101. package/src/vendor/bootstrap-vue/src/components/layout/package.json +0 -67
  102. package/src/vendor/bootstrap-vue/src/components/modal/README.md +0 -1
  103. package/src/vendor/bootstrap-vue/src/components/nav/index.d.ts +0 -6
  104. package/src/vendor/bootstrap-vue/src/components/nav/index.js +1 -5
  105. package/src/vendor/bootstrap-vue/src/components/nav/package.json +0 -45
  106. package/src/vendor/bootstrap-vue/src/components/navbar/README.md +0 -5
  107. package/src/vendor/bootstrap-vue/src/components/navbar/index.d.ts +1 -7
  108. package/src/vendor/bootstrap-vue/src/components/navbar/index.js +2 -7
  109. package/src/vendor/bootstrap-vue/src/components/navbar/package.json +0 -75
  110. package/src/vendor/bootstrap-vue/src/components/table/README.md +1 -2
  111. package/src/vendor/bootstrap-vue/src/components/tabs/README.md +2 -2
  112. package/src/vendor/bootstrap-vue/src/components/toast/README.md +1 -3
  113. package/src/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip.js +2 -6
  114. package/src/vendor/bootstrap-vue/src/constants/classes.js +0 -1
  115. package/src/vendor/bootstrap-vue/src/constants/components.js +0 -50
  116. package/src/vendor/bootstrap-vue/src/constants/events.js +0 -11
  117. package/src/vendor/bootstrap-vue/src/constants/key-codes.js +0 -4
  118. package/src/vendor/bootstrap-vue/src/constants/props.js +0 -3
  119. package/src/vendor/bootstrap-vue/src/constants/regex.js +0 -19
  120. package/src/vendor/bootstrap-vue/src/constants/slots.js +0 -32
  121. package/src/vendor/bootstrap-vue/src/directives/toggle/README.md +5 -23
  122. package/src/vendor/bootstrap-vue/src/directives/toggle/package.json +1 -1
  123. package/src/vendor/bootstrap-vue/src/directives/toggle/toggle.js +1 -1
  124. package/src/vendor/bootstrap-vue/src/index.js +0 -122
  125. package/src/vendor/bootstrap-vue/src/index.scss +0 -3
  126. package/src/vendor/bootstrap-vue/src/utils/array.js +0 -5
  127. package/src/vendor/bootstrap-vue/src/utils/config.spec.js +15 -15
  128. package/src/vendor/bootstrap-vue/src/utils/inspect.js +0 -4
  129. package/src/vendor/bootstrap-vue/src/utils/math.js +0 -4
  130. package/src/vendor/bootstrap-vue/src/utils/object.js +0 -5
  131. package/src/vendor/bootstrap-vue/src/utils/props.js +1 -7
  132. package/src/vendor/bootstrap-vue/src/utils/string.js +0 -9
  133. package/src/vendor/bootstrap-vue/src/utils/string.spec.js +1 -20
  134. package/translations.js +3 -0
  135. package/dist/vendor/bootstrap-vue/src/components/alert/alert.js +0 -179
  136. package/dist/vendor/bootstrap-vue/src/components/alert/index.js +0 -11
  137. package/dist/vendor/bootstrap-vue/src/components/aspect/aspect.js +0 -67
  138. package/dist/vendor/bootstrap-vue/src/components/aspect/index.js +0 -11
  139. package/dist/vendor/bootstrap-vue/src/components/avatar/avatar-group.js +0 -67
  140. package/dist/vendor/bootstrap-vue/src/components/avatar/avatar.js +0 -266
  141. package/dist/vendor/bootstrap-vue/src/components/avatar/index.js +0 -14
  142. package/dist/vendor/bootstrap-vue/src/components/button-toolbar/button-toolbar.js +0 -112
  143. package/dist/vendor/bootstrap-vue/src/components/button-toolbar/index.js +0 -12
  144. package/dist/vendor/bootstrap-vue/src/components/calendar/calendar.js +0 -1010
  145. package/dist/vendor/bootstrap-vue/src/components/calendar/index.js +0 -11
  146. package/dist/vendor/bootstrap-vue/src/components/card/card-body.js +0 -63
  147. package/dist/vendor/bootstrap-vue/src/components/card/card-footer.js +0 -48
  148. package/dist/vendor/bootstrap-vue/src/components/card/card-group.js +0 -33
  149. package/dist/vendor/bootstrap-vue/src/components/card/card-header.js +0 -48
  150. package/dist/vendor/bootstrap-vue/src/components/card/card-img-lazy.js +0 -46
  151. package/dist/vendor/bootstrap-vue/src/components/card/card-img.js +0 -58
  152. package/dist/vendor/bootstrap-vue/src/components/card/card-sub-title.js +0 -35
  153. package/dist/vendor/bootstrap-vue/src/components/card/card-text.js +0 -31
  154. package/dist/vendor/bootstrap-vue/src/components/card/card-title.js +0 -33
  155. package/dist/vendor/bootstrap-vue/src/components/card/card.js +0 -123
  156. package/dist/vendor/bootstrap-vue/src/components/card/index.js +0 -38
  157. package/dist/vendor/bootstrap-vue/src/components/embed/embed.js +0 -50
  158. package/dist/vendor/bootstrap-vue/src/components/embed/index.js +0 -11
  159. package/dist/vendor/bootstrap-vue/src/components/form/form-datalist.js +0 -52
  160. package/dist/vendor/bootstrap-vue/src/components/form-btn-label-control/bv-form-btn-label-control.js +0 -261
  161. package/dist/vendor/bootstrap-vue/src/components/form-datepicker/form-datepicker.js +0 -310
  162. package/dist/vendor/bootstrap-vue/src/components/form-datepicker/index.js +0 -12
  163. package/dist/vendor/bootstrap-vue/src/components/form-file/form-file.js +0 -561
  164. package/dist/vendor/bootstrap-vue/src/components/form-file/index.js +0 -12
  165. package/dist/vendor/bootstrap-vue/src/components/form-rating/form-rating.js +0 -402
  166. package/dist/vendor/bootstrap-vue/src/components/form-rating/index.js +0 -12
  167. package/dist/vendor/bootstrap-vue/src/components/form-spinbutton/form-spinbutton.js +0 -555
  168. package/dist/vendor/bootstrap-vue/src/components/form-spinbutton/index.js +0 -12
  169. package/dist/vendor/bootstrap-vue/src/components/form-tags/form-tag.js +0 -97
  170. package/dist/vendor/bootstrap-vue/src/components/form-tags/form-tags.js +0 -806
  171. package/dist/vendor/bootstrap-vue/src/components/form-tags/index.js +0 -16
  172. package/dist/vendor/bootstrap-vue/src/components/form-timepicker/form-timepicker.js +0 -281
  173. package/dist/vendor/bootstrap-vue/src/components/form-timepicker/index.js +0 -12
  174. package/dist/vendor/bootstrap-vue/src/components/image/img-lazy.js +0 -157
  175. package/dist/vendor/bootstrap-vue/src/components/image/img.js +0 -124
  176. package/dist/vendor/bootstrap-vue/src/components/image/index.js +0 -14
  177. package/dist/vendor/bootstrap-vue/src/components/jumbotron/index.js +0 -11
  178. package/dist/vendor/bootstrap-vue/src/components/jumbotron/jumbotron.js +0 -98
  179. package/dist/vendor/bootstrap-vue/src/components/layout/container.js +0 -41
  180. package/dist/vendor/bootstrap-vue/src/components/layout/row.js +0 -113
  181. package/dist/vendor/bootstrap-vue/src/components/list-group/index.js +0 -14
  182. package/dist/vendor/bootstrap-vue/src/components/list-group/list-group-item.js +0 -78
  183. package/dist/vendor/bootstrap-vue/src/components/list-group/list-group.js +0 -42
  184. package/dist/vendor/bootstrap-vue/src/components/media/index.js +0 -17
  185. package/dist/vendor/bootstrap-vue/src/components/media/media-aside.js +0 -41
  186. package/dist/vendor/bootstrap-vue/src/components/media/media-body.js +0 -31
  187. package/dist/vendor/bootstrap-vue/src/components/media/media.js +0 -61
  188. package/dist/vendor/bootstrap-vue/src/components/nav/nav-form.js +0 -45
  189. package/dist/vendor/bootstrap-vue/src/components/nav/nav-text.js +0 -26
  190. package/dist/vendor/bootstrap-vue/src/components/navbar/navbar-nav.js +0 -46
  191. package/dist/vendor/bootstrap-vue/src/components/navbar/navbar-toggle.js +0 -89
  192. package/dist/vendor/bootstrap-vue/src/components/overlay/index.js +0 -11
  193. package/dist/vendor/bootstrap-vue/src/components/overlay/overlay.js +0 -163
  194. package/dist/vendor/bootstrap-vue/src/components/pagination/index.js +0 -11
  195. package/dist/vendor/bootstrap-vue/src/components/pagination/pagination.js +0 -135
  196. package/dist/vendor/bootstrap-vue/src/components/pagination-nav/index.js +0 -11
  197. package/dist/vendor/bootstrap-vue/src/components/pagination-nav/pagination-nav.js +0 -299
  198. package/dist/vendor/bootstrap-vue/src/components/sidebar/index.js +0 -15
  199. package/dist/vendor/bootstrap-vue/src/components/sidebar/sidebar.js +0 -432
  200. package/dist/vendor/bootstrap-vue/src/components/skeleton/index.js +0 -23
  201. package/dist/vendor/bootstrap-vue/src/components/skeleton/skeleton-icon.js +0 -47
  202. package/dist/vendor/bootstrap-vue/src/components/skeleton/skeleton-img.js +0 -60
  203. package/dist/vendor/bootstrap-vue/src/components/skeleton/skeleton-table.js +0 -64
  204. package/dist/vendor/bootstrap-vue/src/components/skeleton/skeleton-wrapper.js +0 -46
  205. package/dist/vendor/bootstrap-vue/src/components/skeleton/skeleton.js +0 -49
  206. package/dist/vendor/bootstrap-vue/src/components/spinner/index.js +0 -11
  207. package/dist/vendor/bootstrap-vue/src/components/spinner/spinner.js +0 -55
  208. package/dist/vendor/bootstrap-vue/src/components/time/index.js +0 -11
  209. package/dist/vendor/bootstrap-vue/src/components/time/time.js +0 -600
  210. package/dist/vendor/bootstrap-vue/src/constants/date.js +0 -8
  211. package/dist/vendor/bootstrap-vue/src/mixins/card.js +0 -22
  212. package/dist/vendor/bootstrap-vue/src/mixins/pagination.js +0 -598
  213. package/dist/vendor/bootstrap-vue/src/utils/date.js +0 -135
  214. package/src/vendor/bootstrap-vue/src/_custom-controls.scss +0 -30
  215. package/src/vendor/bootstrap-vue/src/components/alert/README.md +0 -280
  216. package/src/vendor/bootstrap-vue/src/components/alert/alert.js +0 -185
  217. package/src/vendor/bootstrap-vue/src/components/alert/alert.spec.js +0 -442
  218. package/src/vendor/bootstrap-vue/src/components/alert/index.d.ts +0 -13
  219. package/src/vendor/bootstrap-vue/src/components/alert/index.js +0 -8
  220. package/src/vendor/bootstrap-vue/src/components/alert/package.json +0 -72
  221. package/src/vendor/bootstrap-vue/src/components/aspect/README.md +0 -65
  222. package/src/vendor/bootstrap-vue/src/components/aspect/aspect.js +0 -65
  223. package/src/vendor/bootstrap-vue/src/components/aspect/aspect.spec.js +0 -121
  224. package/src/vendor/bootstrap-vue/src/components/aspect/index.d.ts +0 -11
  225. package/src/vendor/bootstrap-vue/src/components/aspect/index.js +0 -8
  226. package/src/vendor/bootstrap-vue/src/components/aspect/package.json +0 -26
  227. package/src/vendor/bootstrap-vue/src/components/avatar/README.md +0 -567
  228. package/src/vendor/bootstrap-vue/src/components/avatar/_avatar.scss +0 -148
  229. package/src/vendor/bootstrap-vue/src/components/avatar/avatar-group.js +0 -75
  230. package/src/vendor/bootstrap-vue/src/components/avatar/avatar-group.spec.js +0 -74
  231. package/src/vendor/bootstrap-vue/src/components/avatar/avatar.js +0 -228
  232. package/src/vendor/bootstrap-vue/src/components/avatar/avatar.spec.js +0 -355
  233. package/src/vendor/bootstrap-vue/src/components/avatar/index.d.ts +0 -14
  234. package/src/vendor/bootstrap-vue/src/components/avatar/index.js +0 -9
  235. package/src/vendor/bootstrap-vue/src/components/avatar/index.scss +0 -1
  236. package/src/vendor/bootstrap-vue/src/components/avatar/package.json +0 -149
  237. package/src/vendor/bootstrap-vue/src/components/button-toolbar/README.md +0 -109
  238. package/src/vendor/bootstrap-vue/src/components/button-toolbar/button-toolbar.js +0 -117
  239. package/src/vendor/bootstrap-vue/src/components/button-toolbar/button-toolbar.spec.js +0 -185
  240. package/src/vendor/bootstrap-vue/src/components/button-toolbar/index.d.ts +0 -11
  241. package/src/vendor/bootstrap-vue/src/components/button-toolbar/index.js +0 -11
  242. package/src/vendor/bootstrap-vue/src/components/button-toolbar/package.json +0 -32
  243. package/src/vendor/bootstrap-vue/src/components/calendar/README.md +0 -735
  244. package/src/vendor/bootstrap-vue/src/components/calendar/_calendar.scss +0 -78
  245. package/src/vendor/bootstrap-vue/src/components/calendar/calendar.js +0 -1146
  246. package/src/vendor/bootstrap-vue/src/components/calendar/calendar.spec.js +0 -466
  247. package/src/vendor/bootstrap-vue/src/components/calendar/index.d.ts +0 -28
  248. package/src/vendor/bootstrap-vue/src/components/calendar/index.js +0 -8
  249. package/src/vendor/bootstrap-vue/src/components/calendar/index.scss +0 -1
  250. package/src/vendor/bootstrap-vue/src/components/calendar/package.json +0 -317
  251. package/src/vendor/bootstrap-vue/src/components/card/README.md +0 -729
  252. package/src/vendor/bootstrap-vue/src/components/card/_card-img.scss +0 -7
  253. package/src/vendor/bootstrap-vue/src/components/card/card-body.js +0 -69
  254. package/src/vendor/bootstrap-vue/src/components/card/card-body.spec.js +0 -142
  255. package/src/vendor/bootstrap-vue/src/components/card/card-footer.js +0 -48
  256. package/src/vendor/bootstrap-vue/src/components/card/card-footer.spec.js +0 -98
  257. package/src/vendor/bootstrap-vue/src/components/card/card-group.js +0 -33
  258. package/src/vendor/bootstrap-vue/src/components/card/card-group.spec.js +0 -75
  259. package/src/vendor/bootstrap-vue/src/components/card/card-header.js +0 -48
  260. package/src/vendor/bootstrap-vue/src/components/card/card-header.spec.js +0 -98
  261. package/src/vendor/bootstrap-vue/src/components/card/card-img-lazy.js +0 -47
  262. package/src/vendor/bootstrap-vue/src/components/card/card-img-lazy.spec.js +0 -204
  263. package/src/vendor/bootstrap-vue/src/components/card/card-img.js +0 -50
  264. package/src/vendor/bootstrap-vue/src/components/card/card-img.spec.js +0 -208
  265. package/src/vendor/bootstrap-vue/src/components/card/card-sub-title.js +0 -35
  266. package/src/vendor/bootstrap-vue/src/components/card/card-sub-title.spec.js +0 -60
  267. package/src/vendor/bootstrap-vue/src/components/card/card-text.js +0 -25
  268. package/src/vendor/bootstrap-vue/src/components/card/card-text.spec.js +0 -48
  269. package/src/vendor/bootstrap-vue/src/components/card/card-title.js +0 -33
  270. package/src/vendor/bootstrap-vue/src/components/card/card-title.spec.js +0 -45
  271. package/src/vendor/bootstrap-vue/src/components/card/card.js +0 -140
  272. package/src/vendor/bootstrap-vue/src/components/card/card.spec.js +0 -296
  273. package/src/vendor/bootstrap-vue/src/components/card/index.d.ts +0 -38
  274. package/src/vendor/bootstrap-vue/src/components/card/index.js +0 -40
  275. package/src/vendor/bootstrap-vue/src/components/card/index.scss +0 -1
  276. package/src/vendor/bootstrap-vue/src/components/card/package.json +0 -262
  277. package/src/vendor/bootstrap-vue/src/components/embed/README.md +0 -63
  278. package/src/vendor/bootstrap-vue/src/components/embed/embed.js +0 -51
  279. package/src/vendor/bootstrap-vue/src/components/embed/embed.spec.js +0 -110
  280. package/src/vendor/bootstrap-vue/src/components/embed/index.d.ts +0 -11
  281. package/src/vendor/bootstrap-vue/src/components/embed/index.js +0 -8
  282. package/src/vendor/bootstrap-vue/src/components/embed/package.json +0 -29
  283. package/src/vendor/bootstrap-vue/src/components/form/form-datalist.js +0 -42
  284. package/src/vendor/bootstrap-vue/src/components/form/form-datalist.spec.js +0 -57
  285. package/src/vendor/bootstrap-vue/src/components/form-btn-label-control/_form-btn-label-control.scss +0 -125
  286. package/src/vendor/bootstrap-vue/src/components/form-btn-label-control/bv-form-btn-label-control.js +0 -278
  287. package/src/vendor/bootstrap-vue/src/components/form-btn-label-control/index.scss +0 -1
  288. package/src/vendor/bootstrap-vue/src/components/form-btn-label-control/package.json +0 -5
  289. package/src/vendor/bootstrap-vue/src/components/form-datepicker/README.md +0 -694
  290. package/src/vendor/bootstrap-vue/src/components/form-datepicker/_form-datepicker.scss +0 -1
  291. package/src/vendor/bootstrap-vue/src/components/form-datepicker/form-datepicker.js +0 -342
  292. package/src/vendor/bootstrap-vue/src/components/form-datepicker/form-datepicker.spec.js +0 -562
  293. package/src/vendor/bootstrap-vue/src/components/form-datepicker/index.d.ts +0 -12
  294. package/src/vendor/bootstrap-vue/src/components/form-datepicker/index.js +0 -11
  295. package/src/vendor/bootstrap-vue/src/components/form-datepicker/index.scss +0 -1
  296. package/src/vendor/bootstrap-vue/src/components/form-datepicker/package.json +0 -420
  297. package/src/vendor/bootstrap-vue/src/components/form-file/README.md +0 -357
  298. package/src/vendor/bootstrap-vue/src/components/form-file/_form-file.scss +0 -61
  299. package/src/vendor/bootstrap-vue/src/components/form-file/form-file.js +0 -575
  300. package/src/vendor/bootstrap-vue/src/components/form-file/form-file.spec.js +0 -885
  301. package/src/vendor/bootstrap-vue/src/components/form-file/index.d.ts +0 -13
  302. package/src/vendor/bootstrap-vue/src/components/form-file/index.js +0 -11
  303. package/src/vendor/bootstrap-vue/src/components/form-file/index.scss +0 -1
  304. package/src/vendor/bootstrap-vue/src/components/form-file/package.json +0 -131
  305. package/src/vendor/bootstrap-vue/src/components/form-rating/README.md +0 -526
  306. package/src/vendor/bootstrap-vue/src/components/form-rating/_form-rating.scss +0 -57
  307. package/src/vendor/bootstrap-vue/src/components/form-rating/form-rating.js +0 -411
  308. package/src/vendor/bootstrap-vue/src/components/form-rating/form-rating.spec.js +0 -544
  309. package/src/vendor/bootstrap-vue/src/components/form-rating/index.d.ts +0 -14
  310. package/src/vendor/bootstrap-vue/src/components/form-rating/index.js +0 -8
  311. package/src/vendor/bootstrap-vue/src/components/form-rating/index.scss +0 -1
  312. package/src/vendor/bootstrap-vue/src/components/form-rating/package.json +0 -166
  313. package/src/vendor/bootstrap-vue/src/components/form-spinbutton/README.md +0 -411
  314. package/src/vendor/bootstrap-vue/src/components/form-spinbutton/_spinbutton.scss +0 -76
  315. package/src/vendor/bootstrap-vue/src/components/form-spinbutton/form-spinbutton.js +0 -572
  316. package/src/vendor/bootstrap-vue/src/components/form-spinbutton/form-spinbutton.spec.js +0 -731
  317. package/src/vendor/bootstrap-vue/src/components/form-spinbutton/index.d.ts +0 -12
  318. package/src/vendor/bootstrap-vue/src/components/form-spinbutton/index.js +0 -11
  319. package/src/vendor/bootstrap-vue/src/components/form-spinbutton/index.scss +0 -1
  320. package/src/vendor/bootstrap-vue/src/components/form-spinbutton/package.json +0 -150
  321. package/src/vendor/bootstrap-vue/src/components/form-tags/README.md +0 -880
  322. package/src/vendor/bootstrap-vue/src/components/form-tags/_form-tags.scss +0 -70
  323. package/src/vendor/bootstrap-vue/src/components/form-tags/form-tag.js +0 -94
  324. package/src/vendor/bootstrap-vue/src/components/form-tags/form-tag.spec.js +0 -166
  325. package/src/vendor/bootstrap-vue/src/components/form-tags/form-tags.js +0 -891
  326. package/src/vendor/bootstrap-vue/src/components/form-tags/form-tags.spec.js +0 -920
  327. package/src/vendor/bootstrap-vue/src/components/form-tags/index.d.ts +0 -16
  328. package/src/vendor/bootstrap-vue/src/components/form-tags/index.js +0 -14
  329. package/src/vendor/bootstrap-vue/src/components/form-tags/index.scss +0 -1
  330. package/src/vendor/bootstrap-vue/src/components/form-tags/package.json +0 -440
  331. package/src/vendor/bootstrap-vue/src/components/form-timepicker/README.md +0 -450
  332. package/src/vendor/bootstrap-vue/src/components/form-timepicker/_form-timepicker.scss +0 -1
  333. package/src/vendor/bootstrap-vue/src/components/form-timepicker/form-timepicker.js +0 -308
  334. package/src/vendor/bootstrap-vue/src/components/form-timepicker/form-timepicker.spec.js +0 -440
  335. package/src/vendor/bootstrap-vue/src/components/form-timepicker/index.d.ts +0 -12
  336. package/src/vendor/bootstrap-vue/src/components/form-timepicker/index.js +0 -11
  337. package/src/vendor/bootstrap-vue/src/components/form-timepicker/index.scss +0 -1
  338. package/src/vendor/bootstrap-vue/src/components/form-timepicker/package.json +0 -255
  339. package/src/vendor/bootstrap-vue/src/components/image/README.md +0 -322
  340. package/src/vendor/bootstrap-vue/src/components/image/img-lazy.js +0 -161
  341. package/src/vendor/bootstrap-vue/src/components/image/img-lazy.spec.js +0 -96
  342. package/src/vendor/bootstrap-vue/src/components/image/img.js +0 -139
  343. package/src/vendor/bootstrap-vue/src/components/image/img.spec.js +0 -255
  344. package/src/vendor/bootstrap-vue/src/components/image/index.d.ts +0 -14
  345. package/src/vendor/bootstrap-vue/src/components/image/index.js +0 -12
  346. package/src/vendor/bootstrap-vue/src/components/image/package.json +0 -152
  347. package/src/vendor/bootstrap-vue/src/components/jumbotron/README.md +0 -109
  348. package/src/vendor/bootstrap-vue/src/components/jumbotron/index.d.ts +0 -11
  349. package/src/vendor/bootstrap-vue/src/components/jumbotron/index.js +0 -8
  350. package/src/vendor/bootstrap-vue/src/components/jumbotron/jumbotron.js +0 -103
  351. package/src/vendor/bootstrap-vue/src/components/jumbotron/jumbotron.spec.js +0 -254
  352. package/src/vendor/bootstrap-vue/src/components/jumbotron/package.json +0 -66
  353. package/src/vendor/bootstrap-vue/src/components/layout/container.js +0 -40
  354. package/src/vendor/bootstrap-vue/src/components/layout/container.spec.js +0 -75
  355. package/src/vendor/bootstrap-vue/src/components/layout/row.js +0 -111
  356. package/src/vendor/bootstrap-vue/src/components/layout/row.spec.js +0 -138
  357. package/src/vendor/bootstrap-vue/src/components/list-group/README.md +0 -291
  358. package/src/vendor/bootstrap-vue/src/components/list-group/index.d.ts +0 -14
  359. package/src/vendor/bootstrap-vue/src/components/list-group/index.js +0 -12
  360. package/src/vendor/bootstrap-vue/src/components/list-group/list-group-item.js +0 -76
  361. package/src/vendor/bootstrap-vue/src/components/list-group/list-group-item.spec.js +0 -286
  362. package/src/vendor/bootstrap-vue/src/components/list-group/list-group.js +0 -42
  363. package/src/vendor/bootstrap-vue/src/components/list-group/list-group.spec.js +0 -132
  364. package/src/vendor/bootstrap-vue/src/components/list-group/package.json +0 -52
  365. package/src/vendor/bootstrap-vue/src/components/media/README.md +0 -183
  366. package/src/vendor/bootstrap-vue/src/components/media/_media.scss +0 -9
  367. package/src/vendor/bootstrap-vue/src/components/media/index.d.ts +0 -17
  368. package/src/vendor/bootstrap-vue/src/components/media/index.js +0 -14
  369. package/src/vendor/bootstrap-vue/src/components/media/index.scss +0 -1
  370. package/src/vendor/bootstrap-vue/src/components/media/media-aside.js +0 -45
  371. package/src/vendor/bootstrap-vue/src/components/media/media-aside.spec.js +0 -79
  372. package/src/vendor/bootstrap-vue/src/components/media/media-body.js +0 -25
  373. package/src/vendor/bootstrap-vue/src/components/media/media-body.spec.js +0 -47
  374. package/src/vendor/bootstrap-vue/src/components/media/media.js +0 -52
  375. package/src/vendor/bootstrap-vue/src/components/media/media.spec.js +0 -149
  376. package/src/vendor/bootstrap-vue/src/components/media/package.json +0 -65
  377. package/src/vendor/bootstrap-vue/src/components/nav/nav-form.js +0 -50
  378. package/src/vendor/bootstrap-vue/src/components/nav/nav-form.spec.js +0 -93
  379. package/src/vendor/bootstrap-vue/src/components/nav/nav-text.js +0 -18
  380. package/src/vendor/bootstrap-vue/src/components/nav/nav-text.spec.js +0 -30
  381. package/src/vendor/bootstrap-vue/src/components/navbar/navbar-nav.js +0 -45
  382. package/src/vendor/bootstrap-vue/src/components/navbar/navbar-nav.spec.js +0 -105
  383. package/src/vendor/bootstrap-vue/src/components/navbar/navbar-toggle.js +0 -84
  384. package/src/vendor/bootstrap-vue/src/components/navbar/navbar-toggle.spec.js +0 -189
  385. package/src/vendor/bootstrap-vue/src/components/overlay/README.md +0 -815
  386. package/src/vendor/bootstrap-vue/src/components/overlay/index.d.ts +0 -11
  387. package/src/vendor/bootstrap-vue/src/components/overlay/index.js +0 -8
  388. package/src/vendor/bootstrap-vue/src/components/overlay/overlay.js +0 -162
  389. package/src/vendor/bootstrap-vue/src/components/overlay/overlay.spec.js +0 -257
  390. package/src/vendor/bootstrap-vue/src/components/overlay/package.json +0 -130
  391. package/src/vendor/bootstrap-vue/src/components/pagination/README.md +0 -430
  392. package/src/vendor/bootstrap-vue/src/components/pagination/_pagination.scss +0 -26
  393. package/src/vendor/bootstrap-vue/src/components/pagination/index.d.ts +0 -11
  394. package/src/vendor/bootstrap-vue/src/components/pagination/index.js +0 -8
  395. package/src/vendor/bootstrap-vue/src/components/pagination/index.scss +0 -1
  396. package/src/vendor/bootstrap-vue/src/components/pagination/package.json +0 -295
  397. package/src/vendor/bootstrap-vue/src/components/pagination/pagination.js +0 -138
  398. package/src/vendor/bootstrap-vue/src/components/pagination/pagination.spec.js +0 -1198
  399. package/src/vendor/bootstrap-vue/src/components/pagination-nav/README.md +0 -544
  400. package/src/vendor/bootstrap-vue/src/components/pagination-nav/_pagination-nav.scss +0 -2
  401. package/src/vendor/bootstrap-vue/src/components/pagination-nav/index.d.ts +0 -11
  402. package/src/vendor/bootstrap-vue/src/components/pagination-nav/index.js +0 -8
  403. package/src/vendor/bootstrap-vue/src/components/pagination-nav/index.scss +0 -1
  404. package/src/vendor/bootstrap-vue/src/components/pagination-nav/package.json +0 -315
  405. package/src/vendor/bootstrap-vue/src/components/pagination-nav/pagination-nav.js +0 -281
  406. package/src/vendor/bootstrap-vue/src/components/pagination-nav/pagination-nav.spec.js +0 -671
  407. package/src/vendor/bootstrap-vue/src/components/sidebar/README.md +0 -406
  408. package/src/vendor/bootstrap-vue/src/components/sidebar/_sidebar.scss +0 -97
  409. package/src/vendor/bootstrap-vue/src/components/sidebar/index.d.ts +0 -11
  410. package/src/vendor/bootstrap-vue/src/components/sidebar/index.js +0 -10
  411. package/src/vendor/bootstrap-vue/src/components/sidebar/index.scss +0 -1
  412. package/src/vendor/bootstrap-vue/src/components/sidebar/package.json +0 -239
  413. package/src/vendor/bootstrap-vue/src/components/sidebar/sidebar.js +0 -438
  414. package/src/vendor/bootstrap-vue/src/components/sidebar/sidebar.spec.js +0 -404
  415. package/src/vendor/bootstrap-vue/src/components/skeleton/README.md +0 -275
  416. package/src/vendor/bootstrap-vue/src/components/skeleton/_skeleton.scss +0 -141
  417. package/src/vendor/bootstrap-vue/src/components/skeleton/index.d.ts +0 -23
  418. package/src/vendor/bootstrap-vue/src/components/skeleton/index.js +0 -18
  419. package/src/vendor/bootstrap-vue/src/components/skeleton/index.scss +0 -1
  420. package/src/vendor/bootstrap-vue/src/components/skeleton/package.json +0 -136
  421. package/src/vendor/bootstrap-vue/src/components/skeleton/skeleton-icon.js +0 -45
  422. package/src/vendor/bootstrap-vue/src/components/skeleton/skeleton-icon.spec.js +0 -86
  423. package/src/vendor/bootstrap-vue/src/components/skeleton/skeleton-img.js +0 -49
  424. package/src/vendor/bootstrap-vue/src/components/skeleton/skeleton-img.spec.js +0 -139
  425. package/src/vendor/bootstrap-vue/src/components/skeleton/skeleton-table.js +0 -58
  426. package/src/vendor/bootstrap-vue/src/components/skeleton/skeleton-table.spec.js +0 -119
  427. package/src/vendor/bootstrap-vue/src/components/skeleton/skeleton-wrapper.js +0 -47
  428. package/src/vendor/bootstrap-vue/src/components/skeleton/skeleton-wrapper.spec.js +0 -48
  429. package/src/vendor/bootstrap-vue/src/components/skeleton/skeleton.js +0 -46
  430. package/src/vendor/bootstrap-vue/src/components/skeleton/skeleton.spec.js +0 -126
  431. package/src/vendor/bootstrap-vue/src/components/spinner/README.md +0 -229
  432. package/src/vendor/bootstrap-vue/src/components/spinner/index.d.ts +0 -11
  433. package/src/vendor/bootstrap-vue/src/components/spinner/index.js +0 -8
  434. package/src/vendor/bootstrap-vue/src/components/spinner/package.json +0 -38
  435. package/src/vendor/bootstrap-vue/src/components/spinner/spinner.js +0 -54
  436. package/src/vendor/bootstrap-vue/src/components/spinner/spinner.spec.js +0 -305
  437. package/src/vendor/bootstrap-vue/src/components/time/README.md +0 -431
  438. package/src/vendor/bootstrap-vue/src/components/time/_time.scss +0 -41
  439. package/src/vendor/bootstrap-vue/src/components/time/index.d.ts +0 -27
  440. package/src/vendor/bootstrap-vue/src/components/time/index.js +0 -8
  441. package/src/vendor/bootstrap-vue/src/components/time/index.scss +0 -1
  442. package/src/vendor/bootstrap-vue/src/components/time/package.json +0 -123
  443. package/src/vendor/bootstrap-vue/src/components/time/time.js +0 -601
  444. package/src/vendor/bootstrap-vue/src/components/time/time.spec.js +0 -330
  445. package/src/vendor/bootstrap-vue/src/constants/date.js +0 -7
  446. package/src/vendor/bootstrap-vue/src/mixins/card.js +0 -23
  447. package/src/vendor/bootstrap-vue/src/mixins/pagination.js +0 -670
  448. package/src/vendor/bootstrap-vue/src/utils/date.js +0 -130
  449. package/src/vendor/bootstrap-vue/src/utils/date.spec.js +0 -159
@@ -1,815 +0,0 @@
1
- # Overlay
2
-
3
- > BootstrapVue's custom `b-overlay` component is used to _visually obscure_ a particular element or
4
- > component and its content. It signals to the user of a state change within the element or
5
- > component and can be used for creating loaders, warnings/alerts, prompts, and more.
6
-
7
- ## Overview
8
-
9
- `<b-overlay>` can be used to obscure almost anything. [Example use cases](#use-case-examples) would
10
- be forms, tables, delete confirmation dialogs, or anywhere you need to signal that the application
11
- is busy performing a background task, to signal that a certain component is unavailable, or to
12
- provide additional context to the end user.
13
-
14
- `<b-overlay>` can be used to overlay (wrap) an element or component (the default behaviour), or can
15
- be placed as a descendant of a `position: relative` element
16
- ([non-wrapping mode](#non-wrapping-mode)).
17
-
18
- The overlay visibility is controlled via the `show` prop. By default the overlay is _not_ shown.
19
-
20
- <div class="alert alert-info">
21
- <p class="mb-0">
22
- Note that this component only <em>visually obscures</em> its content (or the page). Refer to the
23
- <a href="#accessibility" class="alert-link">Accessibility section</a> below for additional
24
- accessibility details and concerns.
25
- </p>
26
- </div>
27
-
28
- **Default wrapping mode example:**
29
-
30
- ```html
31
- <template>
32
- <div>
33
- <b-overlay :show="show" rounded="sm">
34
- <b-card title="Card with overlay" :aria-hidden="show ? 'true' : null">
35
- <b-card-text>Laborum consequat non elit enim exercitation cillum.</b-card-text>
36
- <b-card-text>Click the button to toggle the overlay:</b-card-text>
37
- <b-button :disabled="show" variant="primary" @click="show = true">
38
- Show overlay
39
- </b-button>
40
- </b-card>
41
- </b-overlay>
42
- <b-button class="mt-3" @click="show = !show">Toggle overlay</b-button>
43
- </div>
44
- </template>
45
-
46
- <script>
47
- export default {
48
- data() {
49
- return {
50
- show: false
51
- }
52
- }
53
- }
54
- </script>
55
-
56
- <!-- b-overlay.vue -->
57
- ```
58
-
59
- ## Options
60
-
61
- There are many options available for styling the overlay, and for providing custom content within
62
- the overlay.
63
-
64
- ### Overlay backdrop color
65
-
66
- You can control the backdrop background color via the `variant` prop. The variant is translated into
67
- one of Bootstrap's
68
- [background variant utility classes](/docs/reference/color-variants#background-and-border-variants).
69
- Control the opacity of the backdrop via the `opacity` prop (opacity values can range from `0` to
70
- `1`). And background blurring can be controlled via the `blur` prop.
71
-
72
- ```html
73
- <template>
74
- <div>
75
- <b-row>
76
- <b-col lg="6" aria-controls="overlay-background">
77
- <b-form-group label="Variant" label-for="bg-variant" label-cols-sm="4" label-cols-lg="12">
78
- <b-form-select id="bg-variant" v-model="variant" :options="variants"></b-form-select>
79
- </b-form-group>
80
-
81
- <b-form-group label="Opacity" label-for="bg-opacity" label-cols-sm="4" label-cols-lg="12">
82
- <b-input-group>
83
- <b-form-input
84
- id="bg-opacity"
85
- v-model="opacity"
86
- type="range"
87
- number
88
- min="0"
89
- max="1"
90
- step="0.01"
91
- ></b-form-input>
92
- <b-input-group-append is-text class="text-monospace">
93
- {{ opacity.toFixed(2) }}
94
- </b-input-group-append>
95
- </b-input-group>
96
- </b-form-group>
97
-
98
- <b-form-group label="Blur" label-for="bg-blur" label-cols-sm="4" label-cols-lg="12">
99
- <b-form-select id="bg-blur" v-model="blur" :options="blurs"></b-form-select>
100
- </b-form-group>
101
- </b-col>
102
-
103
- <b-col lg="6">
104
- <b-overlay
105
- id="overlay-background"
106
- show
107
- :variant="variant"
108
- :opacity="opacity"
109
- :blur="blur"
110
- rounded="sm"
111
- >
112
- <b-card title="Card with overlay" aria-hidden="true">
113
- <b-card-text>
114
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
115
- incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud
116
- exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
117
- </b-card-text>
118
-
119
- <b-button disabled variant="primary">Button</b-button>
120
- </b-card>
121
- </b-overlay>
122
- </b-col>
123
- </b-row>
124
- </div>
125
- </template>
126
-
127
- <script>
128
- export default {
129
- data() {
130
- return {
131
- variant: 'light',
132
- opacity: 0.85,
133
- blur: '2px',
134
- variants: [
135
- 'transparent',
136
- 'white',
137
- 'light',
138
- 'dark',
139
- 'primary',
140
- 'secondary',
141
- 'success',
142
- 'danger',
143
- 'warning',
144
- 'info',
145
- ],
146
- blurs: [
147
- { text: 'None', value: '' },
148
- '1px',
149
- '2px',
150
- '5px',
151
- '0.5em',
152
- '1rem'
153
- ]
154
- }
155
- }
156
- }
157
- </script>
158
-
159
- <!-- b-overlay-background.vue -->
160
- ```
161
-
162
- As an alternative to the `variant` prop, you can specify a CSS color string value via the `bg-color`
163
- prop. When a value is provided for `bg-color`, the `variant` prop value is ignored.
164
-
165
- **Notes:**
166
-
167
- - Background blurring is not available on some browsers (e.g. IE 11).
168
- - Blurring requires that the opacity level be relatively high for the effect to be visible.
169
-
170
- ### Fade transition
171
-
172
- By default, the overlay uses Bootstrap's fade transition when showing or hiding. You can disable the
173
- fade transition via adding the `no-fade` prop to `<b-overlay>`.
174
-
175
- ### Default spinner styling
176
-
177
- The default overlay content is a [`<b-spinner>`](/docs/components/spinner) of type `'border'`. You
178
- can control the appearance of the spinner via the following props:
179
-
180
- - `spinner-type`: Currently supported values are `'border'` (the default) or `'grow'`.
181
- - `spinner-variant`: Variant theme color for the spinner. Default is `null` which inherits the
182
- current font color.
183
- - `spinner-small`: Set to `true` to render a small size spinner.
184
-
185
- ```html
186
- <template>
187
- <div>
188
- <b-overlay
189
- show
190
- spinner-variant="primary"
191
- spinner-type="grow"
192
- spinner-small
193
- rounded="sm"
194
- style="max-width: 320px;"
195
- >
196
- <b-card title="Card with spinner style" aria-hidden="true">
197
- <b-card-text>
198
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
199
- incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud
200
- exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
201
- </b-card-text>
202
- <b-button disabled variant="primary">Button</b-button>
203
- </b-card>
204
- </b-overlay>
205
- </div>
206
- </template>
207
-
208
- <!-- b-overlay-spinner-style.vue -->
209
- ```
210
-
211
- ### Overlay corner rounding
212
-
213
- By default, the overlay backdrop has square corners. If the content you are wrapping has rounded
214
- corners, you can use the `rounded` prop to apply rounding to the overlay's corners to match the
215
- obscured content's rounded corners.
216
-
217
- Possible values are:
218
-
219
- - `true` (or the empty string `''`) to apply default (medium) rounding
220
- - `false` (the default) applies no rounding to the backdrop overlay
221
- - `'sm'` for small rounded corners
222
- - `'lg'` for large rounded corners
223
- - `'pill'` for pill style rounded corners
224
- - `'circle'` for circular (or oval) rounding
225
- - `'top'` for rounding only the top two corners
226
- - `'bottom'` for rounding only the bottom two corners
227
- - `'left'` for rounding only the two left corners
228
- - `'right'` for rounding only the two right corners
229
-
230
- ```html
231
- <template>
232
- <div>
233
- <b-button @click="show = !show">Toggle overlay</b-button>
234
- <b-row class="text-center mt-3">
235
- <b-col md="6">
236
- <p>With rounding</p>
237
- <b-overlay :show="show" class="d-inline-block" rounded="circle">
238
- <b-img thumbnail rounded="circle" fluid src="https://picsum.photos/200/200/?image=54" alt="Image 1"></b-img>
239
- </b-overlay>
240
- </b-col>
241
- <b-col md="6">
242
- <p>Without rounding</p>
243
- <b-overlay :show="show" class="d-inline-block">
244
- <b-img thumbnail rounded="circle" fluid src="https://picsum.photos/200/200/?image=54" alt="Image 1"></b-img>
245
- </b-overlay>
246
- </b-col>
247
- </b-row>
248
- </div>
249
- </template>
250
-
251
- <script>
252
- export default {
253
- data() {
254
- return {
255
- show: true
256
- }
257
- }
258
- }
259
- </script>
260
-
261
- <!-- b-overlay-rounded.vue -->
262
- ```
263
-
264
- ### Custom overlay content
265
-
266
- Place custom content in the overlay (replacing the default spinner) via the optionally scoped slot
267
- `overlay`.
268
-
269
- ```html
270
- <template>
271
- <div>
272
- <b-overlay :show="show" rounded="sm" @shown="onShown" @hidden="onHidden">
273
- <b-card title="Card with custom overlay content" :aria-hidden="show ? 'true' : null">
274
- <b-card-text>Lorem ipsum dolor sit amet, consectetur adipiscing elit.</b-card-text>
275
- <b-card-text>Click the button to toggle the overlay:</b-card-text>
276
- <b-button ref="show" :disabled="show" variant="primary" @click="show = true">
277
- Show overlay
278
- </b-button>
279
- </b-card>
280
- <template #overlay>
281
- <div class="text-center">
282
- <b-icon icon="stopwatch" font-scale="3" animation="cylon"></b-icon>
283
- <p id="cancel-label">Please wait...</p>
284
- <b-button
285
- ref="cancel"
286
- variant="outline-danger"
287
- size="sm"
288
- aria-describedby="cancel-label"
289
- @click="show = false"
290
- >
291
- Cancel
292
- </b-button>
293
- </div>
294
- </template>
295
- </b-overlay>
296
- </div>
297
- </template>
298
-
299
- <script>
300
- export default {
301
- data() {
302
- return {
303
- show: false
304
- }
305
- },
306
- methods: {
307
- onShown() {
308
- // Focus the cancel button when the overlay is showing
309
- this.$refs.cancel.focus()
310
- },
311
- onHidden() {
312
- // Focus the show button when the overlay is removed
313
- this.$refs.show.focus()
314
- }
315
- }
316
- }
317
- </script>
318
-
319
- <!-- b-overlay-overlay-slot.vue -->
320
- ```
321
-
322
- The following scope properties are available to the `overlay` slot:
323
-
324
- | Property | Description |
325
- | ---------------- | ----------------------------------- |
326
- | `spinnerVariant` | Value of the `spinner-variant` prop |
327
- | `spinnerType` | Value of the `spinner-type` prop |
328
- | `spinnerSmall` | Value of the `spinner-small` prop |
329
-
330
- When placing interactive content in the overlay, you should focus the container of the custom
331
- content or one of the focusable controls in the overlay content for accessibility reasons. You can
332
- listen for the `<b-overlay>` `'shown'` event to know when the overlay content is available in the
333
- document.
334
-
335
- ### Overlay content centering
336
-
337
- By default the overlay content will be horizontally and vertically centered within the overlay
338
- region. To disable centering, set the `no-center` prop to `true`.
339
-
340
- In the following example, we have set the `no-center` prop, and absolutely positioned the custom
341
- overlay slot content at the top right.
342
-
343
- ```html
344
- <template>
345
- <div>
346
- <b-overlay no-center show rounded="sm">
347
- <template #overlay>
348
- <b-icon
349
- icon="stopwatch"
350
- variant="info"
351
- scale="2"
352
- shift-v="8"
353
- shift-h="8"
354
- class="position-absolute"
355
- style="top: 0; right: 0"
356
- ></b-icon>
357
- </template>
358
- <b-card title="Card with no-center overlay" aria-hidden="true">
359
- <b-card-text>
360
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
361
- incididunt ut labore et dolore magna aliqua.
362
- </b-card-text>
363
- <b-button disabled variant="primary">Button</b-button>
364
- </b-card>
365
- </b-overlay>
366
- </div>
367
- </template>
368
-
369
- <!-- b-overlay-no-center.vue -->
370
- ```
371
-
372
- ### Width
373
-
374
- `<b-overlay>` defaults to a width of `100%`. When wrapping an inline or inline-block element, you
375
- will need to add the class `d-inline-block` (e.g. `<b-overlay class="d-inline-block">`).
376
-
377
- You can also use the width [utility classes](/docs/reference/utility-classes) or CSS styles to
378
- control the width of the overlay's wrapping container element.
379
-
380
- ### Non-wrapping mode
381
-
382
- By default, `<b-overlay>` wraps the content of the default slot. In some cases you may want to
383
- obscure a parent container. Use the `no-wrap` prop to disable rendering of the wrapping (and ignore
384
- the default slot). Note that this requires that the ancestor element that is to be obscured to have
385
- relative positioning (either via the utility class `'position-relative'`, or CSS style
386
- `'position: relative;'`).
387
-
388
- ```html
389
- <template>
390
- <div>
391
- <div class="position-relative p-4 bg-info">
392
- <p class="text-light font-weight-bold">
393
- Lorem ipsum dolor sit amet, consectetur adipiscing elit.
394
- </p>
395
- <b-card title="Card with parent overlay">
396
- <b-card-text>Laborum consequat non elit enim exercitation cillum.</b-card-text>
397
- <b-card-text>Click the button to toggle the overlay:</b-card-text>
398
- <b-button :disabled="show" variant="primary" @click="show = true">
399
- Show overlay
400
- </b-button>
401
- </b-card>
402
- <p class="text-light font-weight-bold mb-0">
403
- Lorem ipsum dolor sit amet, consectetur adipiscing elit.
404
- </p>
405
- <b-overlay :show="show" no-wrap>
406
- </b-overlay>
407
- </div>
408
- <b-button class="mt-3" @click="show = !show">Toggle overlay</b-button>
409
- </div>
410
- </template>
411
-
412
- <script>
413
- export default {
414
- data() {
415
- return {
416
- show: false
417
- }
418
- }
419
- }
420
- </script>
421
-
422
- <!-- b-overlay-nowrap.vue -->
423
- ```
424
-
425
- Note that some of Bootstrap v4's component styles have relative positioning defined (e.g. cards,
426
- cols, etc.). You may need to adjust the placement of `<b-overlay>` in your markup.
427
-
428
- For example, `<b-card>` has relative positioning, so you can place the `<b-overlay no-wrap>` as a
429
- descendant of `<b-card>`:
430
-
431
- ```html
432
- <template>
433
- <div>
434
- <b-card header="Card header" footer="Card footer">
435
- <b-media>
436
- <template #aside>
437
- <b-img
438
- thumbnail
439
- rounded="circle"
440
- src="https://picsum.photos/72/72/?image=58"
441
- alt="Image"
442
- ></b-img>
443
- </template>
444
- <p class="mb-0">
445
- Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor
446
- incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud
447
- exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.
448
- </p>
449
- </b-media>
450
- <b-overlay :show="show" no-wrap></b-overlay>
451
- </b-card>
452
- <b-button @click="show = !show" class="mt-3">Toggle overlay</b-button>
453
- </div>
454
- </template>
455
-
456
- <script>
457
- export default {
458
- data() {
459
- return {
460
- show: true
461
- }
462
- }
463
- }
464
- </script>
465
-
466
- <!-- b-overlay-card-relative.vue -->
467
- ```
468
-
469
- When in `no-wrap` mode, `<b-overlay>` will not set the `aria-busy` attribute on the obscured
470
- element. You may also want to use an `aria-live` region in your app that announces to screen reader
471
- users that the page is busy.
472
-
473
- Refer to the [Accessibility section](#accessibility) below for additional details and concerns.
474
-
475
- #### Absolute vs fixed positioning for `no-wrap`
476
-
477
- In cases where you want to obscure the entire app or page, when using the `no-wrap` prop, you can
478
- switch to viewport fixed positioning via setting the prop `fixed` on `<b-overlay>`. Note that this
479
- does not disable scrolling of the page, and note that any interactive elements on the page will
480
- still be in the document tab sequence.
481
-
482
- You may also need to adjust the [z-index of the overlay](#overlay-z-index) to ensure that the
483
- backdrop appears above all other page elements. Use the `z-index` property to override the default
484
- `z-index` value.
485
-
486
- Refer to the [Accessibility section](#accessibility) below for additional details and concerns.
487
-
488
- ### Overlay z-index
489
-
490
- In some circumstances, you may need to adjust the `z-index` used by the overlay (depending on
491
- positioning in the DOM or the content being obscured). Simply set the `z-index` prop with a value
492
- suitable for your application or use case. The default `z-index` is `10`.
493
-
494
- ## Accessibility
495
-
496
- Note that the overlay is visual only. You **must** disable any interactive elements (buttons, links,
497
- etc.) when the overlay is showing, otherwise the obscured elements will still be reachable via
498
- keyboard navigation (i.e. still in the document tab sequence).
499
-
500
- If you have any links in the obscured content, we recommend using the
501
- [`<b-link>` component](/docs/components/link), as it supports the `disabled` state, as native links
502
- (`<a href="...">`) and `<router-link>` components do not support the disabled state.
503
-
504
- It is also recommended to add either the `aria-hidden="true"` or `aria-busy="true"` attribute to
505
- your obscured content when the overlay is visible. Just be careful not to add `aria-hidden="true"`
506
- to the wrapper that contains the `<b-overlay>` component (when using `no-wrap`), as that would hide
507
- any interactive content in the `overlay` slot for screen reader users.
508
-
509
- If you are placing interactive content in the `overlay` slot, you should focus the content once the
510
- `'shown'` event has been emitted. You can use the `hidden` event to trigger returning focus to an
511
- element as needed when the overlay is no longer visible.
512
-
513
- When using the wrapping mode (prop `no-wrap` is not set), the wrapper will have the attribute
514
- `aria-busy="true"` set, to allow screen reader users to know that the wrapped content is in a busy
515
- or loading state. When prop `no-wrap` is set, the attribute will _not_ be applied.
516
-
517
- When using the `no-wrap` prop, and potentially the `fixed` prop, to obscure the entire application
518
- or page, you must ensure that all internative page elements (other than the content of the overlay)
519
- have been disabled and are _not_ in the document tab sequence.
520
-
521
- ## Use case examples
522
-
523
- Here are just a few examples of common use cases of `<b-overlay>`. In all cases, we disable any
524
- interactive elements in the obscured area to prevent reachability via keyboard navigation (i.e.
525
- <kbd>Tab</kbd> key) or screen reader access.
526
-
527
- Please refer to the [Accessibility section](#accessibility) for additional details and concerns.
528
-
529
- ### Loading button
530
-
531
- Easily create a loading button:
532
-
533
- ```html
534
- <template>
535
- <div>
536
- <b-overlay
537
- :show="busy"
538
- rounded
539
- opacity="0.6"
540
- spinner-small
541
- spinner-variant="primary"
542
- class="d-inline-block"
543
- @hidden="onHidden"
544
- >
545
- <b-button
546
- ref="button"
547
- :disabled="busy"
548
- variant="primary"
549
- @click="onClick"
550
- >
551
- Do something
552
- </b-button>
553
- </b-overlay>
554
- </div>
555
- </template>
556
-
557
- <script>
558
- export default {
559
- data() {
560
- return {
561
- busy: false,
562
- timeout: null
563
- }
564
- },
565
- beforeDestroy() {
566
- this.clearTimeout()
567
- },
568
- methods: {
569
- clearTimeout() {
570
- if (this.timeout) {
571
- clearTimeout(this.timeout)
572
- this.timeout = null
573
- }
574
- },
575
- setTimeout(callback) {
576
- this.clearTimeout()
577
- this.timeout = setTimeout(() => {
578
- this.clearTimeout()
579
- callback()
580
- }, 5000)
581
- },
582
- onHidden() {
583
- // Return focus to the button once hidden
584
- this.$refs.button.focus()
585
- },
586
- onClick() {
587
- this.busy = true
588
- // Simulate an async request
589
- this.setTimeout(() => {
590
- this.busy = false
591
- })
592
- }
593
- }
594
- }
595
- </script>
596
-
597
- <!-- b-overlay-example-loading-button.vue -->
598
- ```
599
-
600
- ### Busy state input group
601
-
602
- In this example, we obscure the input and button:
603
-
604
- ```html
605
- <template>
606
- <div>
607
- <b-overlay :show="busy" rounded="lg" opacity="0.6" @hidden="onHidden">
608
- <template #overlay>
609
- <div class="d-flex align-items-center">
610
- <b-spinner small type="grow" variant="secondary"></b-spinner>
611
- <b-spinner type="grow" variant="dark"></b-spinner>
612
- <b-spinner small type="grow" variant="secondary"></b-spinner>
613
- <!-- We add an SR only text for screen readers -->
614
- <span class="sr-only">Please wait...</span>
615
- </div>
616
- </template>
617
- <b-input-group size="lg" :aria-hidden="busy ? 'true' : null">
618
- <b-form-input v-model="value" :disabled="busy"></b-form-input>
619
- <b-input-group-append>
620
- <b-button ref="button" :disabled="busy" variant="primary" @click="onClick">
621
- Do something
622
- </b-button>
623
- </b-input-group-append>
624
- </b-input-group>
625
- </b-overlay>
626
- </div>
627
- </template>
628
-
629
- <script>
630
- export default {
631
- data() {
632
- return {
633
- value: 'Some value',
634
- busy: false,
635
- timeout: null
636
- }
637
- },
638
- beforeDestroy() {
639
- this.clearTimeout()
640
- },
641
- methods: {
642
- clearTimeout() {
643
- if (this.timeout) {
644
- clearTimeout(this.timeout)
645
- this.timeout = null
646
- }
647
- },
648
- setTimeout(callback) {
649
- this.clearTimeout()
650
- this.timeout = setTimeout(() => {
651
- this.clearTimeout()
652
- callback()
653
- }, 5000)
654
- },
655
- onHidden() {
656
- // Return focus to the button
657
- this.$refs.button.focus()
658
- },
659
- onClick() {
660
- this.busy = true
661
- // Simulate an async request
662
- this.setTimeout(() => {
663
- this.busy = false
664
- })
665
- }
666
- }
667
- }
668
- </script>
669
-
670
- <!-- b-overlay-example-input-group.vue -->
671
- ```
672
-
673
- ### Form confirmation prompt and upload status
674
-
675
- This example is a bit more complex, but shows the use of `no-wrap`, and using the `overlay` slot to
676
- present the user with a prompt dialog, and once confirmed it shows a uploading status indicator.
677
- This example also demonstrates additional accessibility markup.
678
-
679
- ```html
680
- <template>
681
- <div>
682
- <b-form class="position-relative p-3" @submit.prevent="onSubmit">
683
- <b-form-group label="Name" label-for="form-name" label-cols-lg="2">
684
- <b-input-group>
685
- <b-input-group-prepend is-text>
686
- <b-icon icon="person-fill"></b-icon>
687
- </b-input-group-prepend>
688
- <b-form-input id="form-name" :disabled="busy"></b-form-input>
689
- </b-input-group>
690
- </b-form-group>
691
-
692
- <b-form-group label="Email" label-for="form-mail" label-cols-lg="2">
693
- <b-input-group>
694
- <b-input-group-prepend is-text>
695
- <b-icon icon="envelope-fill"></b-icon>
696
- </b-input-group-prepend>
697
- <b-form-input id="form-email" type="email" :disabled="busy"></b-form-input>
698
- </b-input-group>
699
- </b-form-group>
700
-
701
- <b-form-group label="Image" label-for="form-image" label-cols-lg="2">
702
- <b-input-group>
703
- <b-input-group-prepend is-text>
704
- <b-icon icon="image-fill"></b-icon>
705
- </b-input-group-prepend>
706
- <b-form-file id="form-image" :disabled="busy" accept="image/*"></b-form-file>
707
- </b-input-group>
708
- </b-form-group>
709
-
710
- <div class="d-flex justify-content-center">
711
- <b-button ref="submit" type="submit" :disabled="busy">Submit</b-button>
712
- </div>
713
-
714
- <b-overlay :show="busy" no-wrap @shown="onShown" @hidden="onHidden">
715
- <template #overlay>
716
- <div v-if="processing" class="text-center p-4 bg-primary text-light rounded">
717
- <b-icon icon="cloud-upload" font-scale="4"></b-icon>
718
- <div class="mb-3">Processing...</div>
719
- <b-progress
720
- min="1"
721
- max="20"
722
- :value="counter"
723
- variant="success"
724
- height="3px"
725
- class="mx-n4 rounded-0"
726
- ></b-progress>
727
- </div>
728
- <div
729
- v-else
730
- ref="dialog"
731
- tabindex="-1"
732
- role="dialog"
733
- aria-modal="false"
734
- aria-labelledby="form-confirm-label"
735
- class="text-center p-3"
736
- >
737
- <p><strong id="form-confirm-label">Are you sure?</strong></p>
738
- <div class="d-flex">
739
- <b-button variant="outline-danger" class="mr-3" @click="onCancel">
740
- Cancel
741
- </b-button>
742
- <b-button variant="outline-success" @click="onOK">OK</b-button>
743
- </div>
744
- </div>
745
- </template>
746
- </b-overlay>
747
- </b-form>
748
- </div>
749
- </template>
750
-
751
- <script>
752
- export default {
753
- data() {
754
- return {
755
- busy: false,
756
- processing: false,
757
- counter: 1,
758
- interval: null
759
- }
760
- },
761
- beforeDestroy() {
762
- this.clearInterval()
763
- },
764
- methods: {
765
- clearInterval() {
766
- if (this.interval) {
767
- clearInterval(this.interval)
768
- this.interval = null
769
- }
770
- },
771
- onShown() {
772
- // Focus the dialog prompt
773
- this.$refs.dialog.focus()
774
- },
775
- onHidden() {
776
- // In this case, we return focus to the submit button
777
- // You may need to alter this based on your application requirements
778
- this.$refs.submit.focus()
779
- },
780
- onSubmit() {
781
- this.processing = false
782
- this.busy = true
783
- },
784
- onCancel() {
785
- this.busy = false
786
- },
787
- onOK() {
788
- this.counter = 1
789
- this.processing = true
790
- // Simulate an async request
791
- this.clearInterval()
792
- this.interval = setInterval(() => {
793
- if (this.counter < 20) {
794
- this.counter = this.counter + 1
795
- } else {
796
- this.clearInterval()
797
- this.$nextTick(() => {
798
- this.busy = this.processing = false
799
- })
800
- }
801
- }, 350)
802
- }
803
- }
804
- }
805
- </script>
806
-
807
- <!-- b-overlay-example-form.vue -->
808
- ```
809
-
810
- ### Using in `<b-modal>`
811
-
812
- The modal body has `position: relative;` set, so when using `<b-overlay no-wrap ...>` in the modal
813
- body only the modal body will be obscured. If you wish to obscure the entire modal (including the
814
- header and footer), you will need to set the `<b-modal>` prop `body-class` to `position-static`, and
815
- also set the `rounded` prop on `<b-overlay>`.