@gitlab/duo-ui 0.1.0 → 0.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 (761) hide show
  1. package/CHANGELOG.md +8 -0
  2. package/dist/components/chat/components/duo_chat_context/constants.js +11 -0
  3. package/dist/components/chat/components/duo_chat_context/duo_chat_context_item_details_modal/duo_chat_context_item_details_modal.js +118 -0
  4. package/dist/components/chat/components/duo_chat_context/duo_chat_context_item_menu/duo_chat_context_item_menu.js +265 -0
  5. package/dist/components/chat/components/duo_chat_context/duo_chat_context_item_menu/duo_chat_context_item_menu_category_items.js +68 -0
  6. package/dist/components/chat/components/duo_chat_context/duo_chat_context_item_menu/duo_chat_context_item_menu_search_item.js +87 -0
  7. package/dist/components/chat/components/duo_chat_context/duo_chat_context_item_menu/duo_chat_context_item_menu_search_items.js +137 -0
  8. package/dist/components/chat/components/duo_chat_context/duo_chat_context_item_menu/duo_chat_context_item_menu_search_items_loading.js +53 -0
  9. package/dist/components/chat/components/duo_chat_context/duo_chat_context_item_popover/duo_chat_context_item_popover.js +121 -0
  10. package/dist/components/chat/components/duo_chat_context/duo_chat_context_item_selections/duo_chat_context_item_selections.js +153 -0
  11. package/dist/components/chat/components/duo_chat_context/mock_context_data.js +191 -0
  12. package/dist/components/chat/components/duo_chat_context/utils.js +106 -0
  13. package/dist/components/chat/components/duo_chat_conversation/duo_chat_conversation.js +101 -0
  14. package/dist/components/chat/components/duo_chat_loader/duo_chat_loader.js +101 -0
  15. package/dist/components/chat/components/duo_chat_message/buttons_utils.js +25 -0
  16. package/dist/components/chat/components/duo_chat_message/constants.js +5 -0
  17. package/dist/components/chat/components/duo_chat_message/copy_code_element.js +16 -0
  18. package/dist/components/chat/components/duo_chat_message/duo_chat_message.js +287 -0
  19. package/dist/components/chat/components/duo_chat_message/insert_code_snippet_element.js +56 -0
  20. package/dist/components/chat/components/duo_chat_message/utils.js +8 -0
  21. package/dist/components/chat/components/duo_chat_message_sources/duo_chat_message_sources.js +106 -0
  22. package/dist/components/chat/components/duo_chat_predefined_prompts/duo_chat_predefined_prompts.js +64 -0
  23. package/dist/components/chat/constants.js +30 -0
  24. package/dist/components/chat/duo_chat.js +524 -0
  25. package/dist/components/chat/markdown_renderer.js +18 -0
  26. package/dist/components/chat/mock_data.js +162 -0
  27. package/dist/components/user_feedback/user_feedback.js +97 -0
  28. package/dist/components/user_feedback/user_feedback_modal.js +149 -0
  29. package/dist/components/workflow/components/duo_workflow_panel/duo_workflow_panel.js +95 -0
  30. package/dist/components/workflow/components/duo_workflow_prompt/duo_workflow_prompt.js +235 -0
  31. package/dist/components.css +2 -0
  32. package/dist/components.css.map +1 -0
  33. package/dist/tailwind.css +2 -0
  34. package/dist/tailwind.css.map +1 -0
  35. package/package.json +8 -16
  36. package/src/components/{experimental/duo/chat → chat}/components/duo_chat_context/duo_chat_context_item_details_modal/duo_chat_context_item_details_modal.vue +1 -1
  37. package/src/components/{experimental/duo/chat → chat}/components/duo_chat_context/duo_chat_context_item_menu/duo_chat_context_item_menu_search_items_loading.vue +1 -1
  38. package/src/components/chat/components/duo_chat_message/constants.js +3 -0
  39. package/src/components/{experimental/duo/chat → chat}/components/duo_chat_message/duo_chat_message.scss +31 -2
  40. package/src/components/{experimental/duo/chat → chat}/components/duo_chat_message/duo_chat_message.vue +33 -2
  41. package/src/components/chat/duo_chat.scss +393 -0
  42. package/src/components/{experimental/duo/chat → chat}/mock_data.js +2 -2
  43. package/src/config.js +3 -43
  44. package/src/index.js +3 -130
  45. package/src/scss/components.scss +6 -83
  46. package/src/tokens/build/json/tokens.json +13548 -13548
  47. package/src/vendor/bootstrap/LICENSE +22 -0
  48. package/src/vendor/bootstrap-vue/LICENSE +21 -0
  49. package/src/vendor/bootstrap-vue/nuxt/index.js +164 -0
  50. package/src/vendor/bootstrap-vue/nuxt/plugin.template.js +29 -0
  51. package/src/vendor/bootstrap-vue/package.json +201 -0
  52. package/src/vendor/bootstrap-vue/src/bv-config.d.ts +4 -0
  53. package/src/vendor/bootstrap-vue/src/components/badge/README.md +126 -0
  54. package/src/vendor/bootstrap-vue/src/components/badge/badge.spec.js +141 -0
  55. package/src/vendor/bootstrap-vue/src/components/badge/index.d.ts +7 -0
  56. package/src/vendor/bootstrap-vue/src/components/badge/package.json +29 -0
  57. package/src/vendor/bootstrap-vue/src/components/breadcrumb/README.md +93 -0
  58. package/src/vendor/bootstrap-vue/src/components/breadcrumb/breadcrumb-item.spec.js +123 -0
  59. package/src/vendor/bootstrap-vue/src/components/breadcrumb/breadcrumb-link.spec.js +117 -0
  60. package/src/vendor/bootstrap-vue/src/components/breadcrumb/breadcrumb.spec.js +183 -0
  61. package/src/vendor/bootstrap-vue/src/components/breadcrumb/index.d.ts +13 -0
  62. package/src/vendor/bootstrap-vue/src/components/breadcrumb/package.json +62 -0
  63. package/src/vendor/bootstrap-vue/src/components/button/README.md +281 -0
  64. package/src/vendor/bootstrap-vue/src/components/button/button-close.spec.js +210 -0
  65. package/src/vendor/bootstrap-vue/src/components/button/button.spec.js +385 -0
  66. package/src/vendor/bootstrap-vue/src/components/button/index.d.ts +10 -0
  67. package/src/vendor/bootstrap-vue/src/components/button/package.json +105 -0
  68. package/src/vendor/bootstrap-vue/src/components/button-group/README.md +112 -0
  69. package/src/vendor/bootstrap-vue/src/components/button-group/button-group.spec.js +98 -0
  70. package/src/vendor/bootstrap-vue/src/components/button-group/index.d.ts +7 -0
  71. package/src/vendor/bootstrap-vue/src/components/button-group/package.json +29 -0
  72. package/src/vendor/bootstrap-vue/src/components/collapse/README.md +321 -0
  73. package/src/vendor/bootstrap-vue/src/components/collapse/collapse.spec.js +558 -0
  74. package/src/vendor/bootstrap-vue/src/components/collapse/index.d.ts +9 -0
  75. package/src/vendor/bootstrap-vue/src/components/collapse/package.json +111 -0
  76. package/src/vendor/bootstrap-vue/src/components/dropdown/README.md +730 -0
  77. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-divider.spec.js +58 -0
  78. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-form.spec.js +110 -0
  79. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-group.spec.js +94 -0
  80. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-header.spec.js +73 -0
  81. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item-button.spec.js +117 -0
  82. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.spec.js +147 -0
  83. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.spec.js +59 -0
  84. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown.spec.js +1121 -0
  85. package/src/vendor/bootstrap-vue/src/components/dropdown/index.d.ts +32 -0
  86. package/src/vendor/bootstrap-vue/src/components/dropdown/package.json +368 -0
  87. package/src/vendor/bootstrap-vue/src/components/form/README.md +370 -0
  88. package/src/vendor/bootstrap-vue/src/components/form/form-invalid-feedback.spec.js +170 -0
  89. package/src/vendor/bootstrap-vue/src/components/form/form-text.spec.js +93 -0
  90. package/src/vendor/bootstrap-vue/src/components/form/form-valid-feedback.spec.js +157 -0
  91. package/src/vendor/bootstrap-vue/src/components/form/form.spec.js +97 -0
  92. package/src/vendor/bootstrap-vue/src/components/form/index.d.ts +16 -0
  93. package/src/vendor/bootstrap-vue/src/components/form/package.json +112 -0
  94. package/src/vendor/bootstrap-vue/src/components/form-checkbox/README.md +862 -0
  95. package/src/vendor/bootstrap-vue/src/components/form-checkbox/form-checkbox-group.spec.js +642 -0
  96. package/src/vendor/bootstrap-vue/src/components/form-checkbox/form-checkbox.spec.js +1331 -0
  97. package/src/vendor/bootstrap-vue/src/components/form-checkbox/index.d.ts +10 -0
  98. package/src/vendor/bootstrap-vue/src/components/form-checkbox/package.json +172 -0
  99. package/src/vendor/bootstrap-vue/src/components/form-group/README.md +337 -0
  100. package/src/vendor/bootstrap-vue/src/components/form-group/form-group.spec.js +477 -0
  101. package/src/vendor/bootstrap-vue/src/components/form-group/index.d.ts +7 -0
  102. package/src/vendor/bootstrap-vue/src/components/form-group/package.json +183 -0
  103. package/src/vendor/bootstrap-vue/src/components/form-input/README.md +612 -0
  104. package/src/vendor/bootstrap-vue/src/components/form-input/form-input.spec.js +986 -0
  105. package/src/vendor/bootstrap-vue/src/components/form-input/index.d.ts +9 -0
  106. package/src/vendor/bootstrap-vue/src/components/form-input/package.json +135 -0
  107. package/src/vendor/bootstrap-vue/src/components/form-radio/README.md +566 -0
  108. package/src/vendor/bootstrap-vue/src/components/form-radio/form-radio-group.spec.js +469 -0
  109. package/src/vendor/bootstrap-vue/src/components/form-radio/form-radio.spec.js +952 -0
  110. package/src/vendor/bootstrap-vue/src/components/form-radio/index.d.ts +10 -0
  111. package/src/vendor/bootstrap-vue/src/components/form-radio/package.json +162 -0
  112. package/src/vendor/bootstrap-vue/src/components/form-select/README.md +504 -0
  113. package/src/vendor/bootstrap-vue/src/components/form-select/form-select-option-group.spec.js +138 -0
  114. package/src/vendor/bootstrap-vue/src/components/form-select/form-select-option.spec.js +75 -0
  115. package/src/vendor/bootstrap-vue/src/components/form-select/form-select.spec.js +723 -0
  116. package/src/vendor/bootstrap-vue/src/components/form-select/index.d.ts +13 -0
  117. package/src/vendor/bootstrap-vue/src/components/form-select/package.json +132 -0
  118. package/src/vendor/bootstrap-vue/src/components/form-textarea/README.md +453 -0
  119. package/src/vendor/bootstrap-vue/src/components/form-textarea/form-textarea.spec.js +1000 -0
  120. package/src/vendor/bootstrap-vue/src/components/form-textarea/index.d.ts +9 -0
  121. package/src/vendor/bootstrap-vue/src/components/form-textarea/package.json +122 -0
  122. package/src/vendor/bootstrap-vue/src/components/index.d.ts +31 -0
  123. package/src/vendor/bootstrap-vue/src/components/input-group/README.md +334 -0
  124. package/src/vendor/bootstrap-vue/src/components/input-group/index.d.ts +19 -0
  125. package/src/vendor/bootstrap-vue/src/components/input-group/input-group-append.spec.js +84 -0
  126. package/src/vendor/bootstrap-vue/src/components/input-group/input-group-prepend.spec.js +84 -0
  127. package/src/vendor/bootstrap-vue/src/components/input-group/input-group-text.spec.js +45 -0
  128. package/src/vendor/bootstrap-vue/src/components/input-group/input-group.spec.js +153 -0
  129. package/src/vendor/bootstrap-vue/src/components/input-group/package.json +109 -0
  130. package/src/vendor/bootstrap-vue/src/components/layout/README.md +791 -0
  131. package/src/vendor/bootstrap-vue/src/components/layout/col.spec.js +192 -0
  132. package/src/vendor/bootstrap-vue/src/components/layout/form-row.spec.js +45 -0
  133. package/src/vendor/bootstrap-vue/src/components/layout/index.d.ts +10 -0
  134. package/src/vendor/bootstrap-vue/src/components/layout/package.json +99 -0
  135. package/src/vendor/bootstrap-vue/src/components/link/README.md +76 -0
  136. package/src/vendor/bootstrap-vue/src/components/link/index.d.ts +10 -0
  137. package/src/vendor/bootstrap-vue/src/components/link/link.spec.js +434 -0
  138. package/src/vendor/bootstrap-vue/src/components/link/package.json +57 -0
  139. package/src/vendor/bootstrap-vue/src/components/modal/MODIFICATIONS.md +27 -0
  140. package/src/vendor/bootstrap-vue/src/components/modal/README.md +1068 -0
  141. package/src/vendor/bootstrap-vue/src/components/modal/helpers/bv-modal-event.class.spec.js +82 -0
  142. package/src/vendor/bootstrap-vue/src/components/modal/index.d.ts +82 -0
  143. package/src/vendor/bootstrap-vue/src/components/modal/modal.spec.js +1418 -0
  144. package/src/vendor/bootstrap-vue/src/components/modal/package.json +548 -0
  145. package/src/vendor/bootstrap-vue/src/components/nav/README.md +480 -0
  146. package/src/vendor/bootstrap-vue/src/components/nav/index.d.ts +17 -0
  147. package/src/vendor/bootstrap-vue/src/components/nav/nav-item-dropdown.spec.js +268 -0
  148. package/src/vendor/bootstrap-vue/src/components/nav/nav-item.spec.js +127 -0
  149. package/src/vendor/bootstrap-vue/src/components/nav/nav.spec.js +244 -0
  150. package/src/vendor/bootstrap-vue/src/components/nav/package.json +190 -0
  151. package/src/vendor/bootstrap-vue/src/components/navbar/README.md +333 -0
  152. package/src/vendor/bootstrap-vue/src/components/navbar/index.d.ts +10 -0
  153. package/src/vendor/bootstrap-vue/src/components/navbar/navbar-brand.spec.js +50 -0
  154. package/src/vendor/bootstrap-vue/src/components/navbar/navbar.spec.js +130 -0
  155. package/src/vendor/bootstrap-vue/src/components/navbar/package.json +54 -0
  156. package/src/vendor/bootstrap-vue/src/components/popover/README.md +919 -0
  157. package/src/vendor/bootstrap-vue/src/components/popover/index.d.ts +7 -0
  158. package/src/vendor/bootstrap-vue/src/components/popover/package.json +261 -0
  159. package/src/vendor/bootstrap-vue/src/components/popover/popover.spec.js +199 -0
  160. package/src/vendor/bootstrap-vue/src/components/progress/MODIFICATIONS.md +23 -0
  161. package/src/vendor/bootstrap-vue/src/components/progress/README.md +363 -0
  162. package/src/vendor/bootstrap-vue/src/components/progress/index.d.ts +10 -0
  163. package/src/vendor/bootstrap-vue/src/components/progress/package.json +109 -0
  164. package/src/vendor/bootstrap-vue/src/components/progress/progress-bar.spec.js +270 -0
  165. package/src/vendor/bootstrap-vue/src/components/progress/progress.spec.js +71 -0
  166. package/src/vendor/bootstrap-vue/src/components/table/README.md +3157 -0
  167. package/src/vendor/bootstrap-vue/src/components/table/helpers/default-sort-compare.spec.js +112 -0
  168. package/src/vendor/bootstrap-vue/src/components/table/helpers/normalize-fields.spec.js +93 -0
  169. package/src/vendor/bootstrap-vue/src/components/table/index.d.ts +237 -0
  170. package/src/vendor/bootstrap-vue/src/components/table/package.json +1763 -0
  171. package/src/vendor/bootstrap-vue/src/components/table/table-busy.spec.js +150 -0
  172. package/src/vendor/bootstrap-vue/src/components/table/table-caption.spec.js +176 -0
  173. package/src/vendor/bootstrap-vue/src/components/table/table-colgroup.spec.js +81 -0
  174. package/src/vendor/bootstrap-vue/src/components/table/table-filtering.spec.js +409 -0
  175. package/src/vendor/bootstrap-vue/src/components/table/table-item-formatter.spec.js +56 -0
  176. package/src/vendor/bootstrap-vue/src/components/table/table-lite.spec.js +682 -0
  177. package/src/vendor/bootstrap-vue/src/components/table/table-pagination.spec.js +133 -0
  178. package/src/vendor/bootstrap-vue/src/components/table/table-primarykey.spec.js +83 -0
  179. package/src/vendor/bootstrap-vue/src/components/table/table-provider.spec.js +411 -0
  180. package/src/vendor/bootstrap-vue/src/components/table/table-row-details.spec.js +459 -0
  181. package/src/vendor/bootstrap-vue/src/components/table/table-selectable.spec.js +1182 -0
  182. package/src/vendor/bootstrap-vue/src/components/table/table-simple.spec.js +206 -0
  183. package/src/vendor/bootstrap-vue/src/components/table/table-sorting.spec.js +858 -0
  184. package/src/vendor/bootstrap-vue/src/components/table/table-sticky-column.spec.js +377 -0
  185. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-bottom-row.spec.js +94 -0
  186. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-row-events.spec.js +529 -0
  187. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-top-row.spec.js +88 -0
  188. package/src/vendor/bootstrap-vue/src/components/table/table-tbody-transition.spec.js +83 -0
  189. package/src/vendor/bootstrap-vue/src/components/table/table-tfoot-custom.spec.js +91 -0
  190. package/src/vendor/bootstrap-vue/src/components/table/table-tfoot-events.spec.js +137 -0
  191. package/src/vendor/bootstrap-vue/src/components/table/table-thead-events.spec.js +155 -0
  192. package/src/vendor/bootstrap-vue/src/components/table/table-thead-top.spec.js +96 -0
  193. package/src/vendor/bootstrap-vue/src/components/table/table.spec.js +692 -0
  194. package/src/vendor/bootstrap-vue/src/components/tabs/README.md +575 -0
  195. package/src/vendor/bootstrap-vue/src/components/tabs/index.d.ts +13 -0
  196. package/src/vendor/bootstrap-vue/src/components/tabs/package.json +205 -0
  197. package/src/vendor/bootstrap-vue/src/components/tabs/tab.spec.js +330 -0
  198. package/src/vendor/bootstrap-vue/src/components/tabs/tabs.spec.js +836 -0
  199. package/src/vendor/bootstrap-vue/src/components/toast/README.md +656 -0
  200. package/src/vendor/bootstrap-vue/src/components/toast/helpers/bv-toast.spec.js +131 -0
  201. package/src/vendor/bootstrap-vue/src/components/toast/index.d.ts +70 -0
  202. package/src/vendor/bootstrap-vue/src/components/toast/package.json +188 -0
  203. package/src/vendor/bootstrap-vue/src/components/toast/toast.spec.js +346 -0
  204. package/src/vendor/bootstrap-vue/src/components/toast/toaster.spec.js +77 -0
  205. package/src/vendor/bootstrap-vue/src/components/tooltip/README.md +559 -0
  206. package/src/vendor/bootstrap-vue/src/components/tooltip/index.d.ts +7 -0
  207. package/src/vendor/bootstrap-vue/src/components/tooltip/package.json +258 -0
  208. package/src/vendor/bootstrap-vue/src/components/tooltip/tooltip.spec.js +1529 -0
  209. package/src/vendor/bootstrap-vue/src/components/transition/package.json +5 -0
  210. package/src/vendor/bootstrap-vue/src/components/transporter/package.json +5 -0
  211. package/src/vendor/bootstrap-vue/src/components/transporter/transporter.spec.js +85 -0
  212. package/src/vendor/bootstrap-vue/src/directives/modal/index.d.ts +8 -0
  213. package/src/vendor/bootstrap-vue/src/directives/modal/modal.spec.js +191 -0
  214. package/src/vendor/bootstrap-vue/src/directives/toggle/README.md +146 -0
  215. package/src/vendor/bootstrap-vue/src/directives/toggle/index.d.ts +7 -0
  216. package/src/vendor/bootstrap-vue/src/directives/toggle/package.json +26 -0
  217. package/src/vendor/bootstrap-vue/src/directives/toggle/toggle.spec.js +452 -0
  218. package/src/vendor/bootstrap-vue/src/directives/tooltip/README.md +521 -0
  219. package/src/vendor/bootstrap-vue/src/directives/tooltip/index.d.ts +7 -0
  220. package/src/vendor/bootstrap-vue/src/directives/tooltip/package.json +131 -0
  221. package/src/vendor/bootstrap-vue/src/directives/tooltip/tooltip.spec.js +223 -0
  222. package/src/vendor/bootstrap-vue/src/directives/visible/README.md +244 -0
  223. package/src/vendor/bootstrap-vue/src/directives/visible/index.d.ts +7 -0
  224. package/src/vendor/bootstrap-vue/src/directives/visible/package.json +24 -0
  225. package/src/vendor/bootstrap-vue/src/index.d.ts +61 -0
  226. package/src/vendor/bootstrap-vue/src/mixins/attrs.spec.js +194 -0
  227. package/src/vendor/bootstrap-vue/src/mixins/click-out.spec.js +52 -0
  228. package/src/vendor/bootstrap-vue/src/mixins/focus-in.spec.js +53 -0
  229. package/src/vendor/bootstrap-vue/src/mixins/listen-on-document.spec.js +117 -0
  230. package/src/vendor/bootstrap-vue/src/mixins/listen-on-root.spec.js +77 -0
  231. package/src/vendor/bootstrap-vue/src/mixins/listen-on-window.spec.js +115 -0
  232. package/src/vendor/bootstrap-vue/src/mixins/listeners.spec.js +245 -0
  233. package/src/vendor/bootstrap-vue/src/utils/bv-event.class.spec.js +66 -0
  234. package/src/vendor/bootstrap-vue/src/utils/clone-deep.spec.js +70 -0
  235. package/src/vendor/bootstrap-vue/src/utils/config.spec.js +169 -0
  236. package/src/vendor/bootstrap-vue/src/utils/css-escape.spec.js +82 -0
  237. package/src/vendor/bootstrap-vue/src/utils/dom.spec.js +291 -0
  238. package/src/vendor/bootstrap-vue/src/utils/events.spec.js +41 -0
  239. package/src/vendor/bootstrap-vue/src/utils/get.spec.js +109 -0
  240. package/src/vendor/bootstrap-vue/src/utils/inspect.spec.js +251 -0
  241. package/src/vendor/bootstrap-vue/src/utils/loose-equal.spec.js +203 -0
  242. package/src/vendor/bootstrap-vue/src/utils/normalize-slot.spec.js +63 -0
  243. package/src/vendor/bootstrap-vue/src/utils/number.spec.js +72 -0
  244. package/src/vendor/bootstrap-vue/src/utils/object.spec.js +61 -0
  245. package/src/vendor/bootstrap-vue/src/utils/props.spec.js +112 -0
  246. package/src/vendor/bootstrap-vue/src/utils/router.spec.js +248 -0
  247. package/src/vendor/bootstrap-vue/src/utils/string.spec.js +65 -0
  248. package/src/vendor/bootstrap-vue/src/utils/stringify-object-values.spec.js +47 -0
  249. package/src/vendor/bootstrap-vue/src/utils/warn.spec.js +54 -0
  250. package/src/vendor/bootstrap-vue/src/vue-injections.d.ts +13 -0
  251. package/translations.js +0 -26
  252. package/dist/tokens/css/tokens.css +0 -953
  253. package/dist/tokens/css/tokens.dark.css +0 -953
  254. package/dist/tokens/js/tokens.dark.js +0 -951
  255. package/dist/tokens/js/tokens.js +0 -951
  256. package/dist/tokens/json/tokens.dark.json +0 -21803
  257. package/dist/tokens/json/tokens.json +0 -21803
  258. package/dist/tokens/scss/_tokens.dark.scss +0 -950
  259. package/dist/tokens/scss/_tokens.scss +0 -950
  260. package/dist/tokens/scss/_tokens_custom_properties.scss +0 -951
  261. package/dist/tokens/tailwind/tokens.cjs +0 -336
  262. package/src/charts.js +0 -14
  263. package/src/components/base/accordion/accordion.md +0 -3
  264. package/src/components/base/accordion/accordion.vue +0 -43
  265. package/src/components/base/accordion/accordion_item.md +0 -3
  266. package/src/components/base/accordion/accordion_item.scss +0 -16
  267. package/src/components/base/accordion/accordion_item.vue +0 -122
  268. package/src/components/base/alert/alert.md +0 -35
  269. package/src/components/base/alert/alert.scss +0 -179
  270. package/src/components/base/alert/alert.vue +0 -241
  271. package/src/components/base/animated_icon/animated_chevron_right_down_icon.vue +0 -28
  272. package/src/components/base/animated_icon/animated_duo_chat_icon.vue +0 -39
  273. package/src/components/base/animated_icon/animated_icon.md +0 -4
  274. package/src/components/base/animated_icon/animated_icon.scss +0 -456
  275. package/src/components/base/animated_icon/animated_notifications_icon.vue +0 -49
  276. package/src/components/base/animated_icon/animated_sidebar_icon.vue +0 -35
  277. package/src/components/base/animated_icon/animated_smile_icon.vue +0 -37
  278. package/src/components/base/animated_icon/animated_sort_icon.vue +0 -84
  279. package/src/components/base/animated_icon/animated_star_icon.vue +0 -27
  280. package/src/components/base/animated_icon/animated_todo_icon.vue +0 -49
  281. package/src/components/base/animated_icon/animated_upload_icon.vue +0 -41
  282. package/src/components/base/animated_icon/base_animated_icon.vue +0 -39
  283. package/src/components/base/avatar/avatar.md +0 -1
  284. package/src/components/base/avatar/avatar.scss +0 -228
  285. package/src/components/base/avatar/avatar.vue +0 -151
  286. package/src/components/base/avatar_labeled/avatar_labeled.md +0 -20
  287. package/src/components/base/avatar_labeled/avatar_labeled.scss +0 -30
  288. package/src/components/base/avatar_labeled/avatar_labeled.vue +0 -92
  289. package/src/components/base/avatar_link/avatar_link.md +0 -33
  290. package/src/components/base/avatar_link/avatar_link.scss +0 -41
  291. package/src/components/base/avatar_link/avatar_link.vue +0 -15
  292. package/src/components/base/avatars_inline/avatars_inline.md +0 -38
  293. package/src/components/base/avatars_inline/avatars_inline.scss +0 -64
  294. package/src/components/base/avatars_inline/avatars_inline.vue +0 -110
  295. package/src/components/base/badge/badge.md +0 -38
  296. package/src/components/base/badge/badge.scss +0 -251
  297. package/src/components/base/badge/badge.vue +0 -91
  298. package/src/components/base/banner/banner.md +0 -35
  299. package/src/components/base/banner/banner.scss +0 -35
  300. package/src/components/base/banner/banner.vue +0 -131
  301. package/src/components/base/breadcrumb/breadcrumb.md +0 -23
  302. package/src/components/base/breadcrumb/breadcrumb.scss +0 -62
  303. package/src/components/base/breadcrumb/breadcrumb.vue +0 -229
  304. package/src/components/base/breadcrumb/breadcrumb_item.vue +0 -44
  305. package/src/components/base/broadcast_message/broadcast_message.md +0 -25
  306. package/src/components/base/broadcast_message/broadcast_message.scss +0 -135
  307. package/src/components/base/broadcast_message/broadcast_message.vue +0 -98
  308. package/src/components/base/broadcast_message/constants.js +0 -3
  309. package/src/components/base/button/button.md +0 -61
  310. package/src/components/base/button/button.scss +0 -699
  311. package/src/components/base/button/button.vue +0 -143
  312. package/src/components/base/button_group/button_group.md +0 -28
  313. package/src/components/base/button_group/button_group.vue +0 -16
  314. package/src/components/base/card/card.md +0 -4
  315. package/src/components/base/card/card.scss +0 -46
  316. package/src/components/base/card/card.vue +0 -49
  317. package/src/components/base/collapse/collapse.md +0 -26
  318. package/src/components/base/collapse/collapse.vue +0 -29
  319. package/src/components/base/datepicker/datepicker.md +0 -8
  320. package/src/components/base/datepicker/datepicker.scss +0 -228
  321. package/src/components/base/datepicker/datepicker.vue +0 -454
  322. package/src/components/base/daterange_picker/daterange_picker.md +0 -32
  323. package/src/components/base/daterange_picker/daterange_picker.scss +0 -20
  324. package/src/components/base/daterange_picker/daterange_picker.vue +0 -345
  325. package/src/components/base/drawer/drawer.md +0 -17
  326. package/src/components/base/drawer/drawer.scss +0 -153
  327. package/src/components/base/drawer/drawer.vue +0 -136
  328. package/src/components/base/dropdown/dropdown.md +0 -72
  329. package/src/components/base/dropdown/dropdown.scss +0 -210
  330. package/src/components/base/dropdown/dropdown.vue +0 -323
  331. package/src/components/base/dropdown/dropdown_divider.scss +0 -20
  332. package/src/components/base/dropdown/dropdown_divider.vue +0 -15
  333. package/src/components/base/dropdown/dropdown_form.vue +0 -17
  334. package/src/components/base/dropdown/dropdown_item.md +0 -2
  335. package/src/components/base/dropdown/dropdown_item.scss +0 -102
  336. package/src/components/base/dropdown/dropdown_item.vue +0 -114
  337. package/src/components/base/dropdown/dropdown_section_header.md +0 -7
  338. package/src/components/base/dropdown/dropdown_section_header.scss +0 -22
  339. package/src/components/base/dropdown/dropdown_section_header.vue +0 -17
  340. package/src/components/base/dropdown/dropdown_text.md +0 -7
  341. package/src/components/base/dropdown/dropdown_text.scss +0 -6
  342. package/src/components/base/dropdown/dropdown_text.vue +0 -17
  343. package/src/components/base/filtered_search/common_story_options.js +0 -12
  344. package/src/components/base/filtered_search/filtered_search.md +0 -76
  345. package/src/components/base/filtered_search/filtered_search.scss +0 -51
  346. package/src/components/base/filtered_search/filtered_search.vue +0 -475
  347. package/src/components/base/filtered_search/filtered_search_suggestion.md +0 -15
  348. package/src/components/base/filtered_search/filtered_search_suggestion.scss +0 -11
  349. package/src/components/base/filtered_search/filtered_search_suggestion.vue +0 -64
  350. package/src/components/base/filtered_search/filtered_search_suggestion_list.md +0 -13
  351. package/src/components/base/filtered_search/filtered_search_suggestion_list.scss +0 -36
  352. package/src/components/base/filtered_search/filtered_search_suggestion_list.vue +0 -122
  353. package/src/components/base/filtered_search/filtered_search_term.md +0 -7
  354. package/src/components/base/filtered_search/filtered_search_term.scss +0 -19
  355. package/src/components/base/filtered_search/filtered_search_term.vue +0 -243
  356. package/src/components/base/filtered_search/filtered_search_token.md +0 -23
  357. package/src/components/base/filtered_search/filtered_search_token.scss +0 -63
  358. package/src/components/base/filtered_search/filtered_search_token.vue +0 -484
  359. package/src/components/base/filtered_search/filtered_search_token_segment.md +0 -14
  360. package/src/components/base/filtered_search/filtered_search_token_segment.scss +0 -25
  361. package/src/components/base/filtered_search/filtered_search_token_segment.vue +0 -468
  362. package/src/components/base/filtered_search/filtered_search_utils.js +0 -251
  363. package/src/components/base/form/form.md +0 -2
  364. package/src/components/base/form/form.vue +0 -17
  365. package/src/components/base/form/form_character_count/form_character_count.md +0 -53
  366. package/src/components/base/form/form_character_count/form_character_count.vue +0 -97
  367. package/src/components/base/form/form_checkbox/form_checkbox.md +0 -6
  368. package/src/components/base/form/form_checkbox/form_checkbox.scss +0 -221
  369. package/src/components/base/form/form_checkbox/form_checkbox.vue +0 -58
  370. package/src/components/base/form/form_checkbox/form_checkbox_group.vue +0 -44
  371. package/src/components/base/form/form_checkbox_tree/checkbox_tree_node.vue +0 -58
  372. package/src/components/base/form/form_checkbox_tree/form_checkbox_tree.md +0 -73
  373. package/src/components/base/form/form_checkbox_tree/form_checkbox_tree.vue +0 -116
  374. package/src/components/base/form/form_checkbox_tree/models/constants.js +0 -12
  375. package/src/components/base/form/form_checkbox_tree/models/node.js +0 -48
  376. package/src/components/base/form/form_checkbox_tree/models/tree.js +0 -186
  377. package/src/components/base/form/form_combobox/constants.js +0 -50
  378. package/src/components/base/form/form_combobox/form_combobox.md +0 -52
  379. package/src/components/base/form/form_combobox/form_combobox.scss +0 -5
  380. package/src/components/base/form/form_combobox/form_combobox.vue +0 -280
  381. package/src/components/base/form/form_date/form_date.md +0 -26
  382. package/src/components/base/form/form_date/form_date.scss +0 -7
  383. package/src/components/base/form/form_date/form_date.vue +0 -135
  384. package/src/components/base/form/form_fields/form_field_validator.vue +0 -59
  385. package/src/components/base/form/form_fields/form_fields.md +0 -41
  386. package/src/components/base/form/form_fields/form_fields.vue +0 -258
  387. package/src/components/base/form/form_fields/mappers.js +0 -11
  388. package/src/components/base/form/form_fields/validators.js +0 -49
  389. package/src/components/base/form/form_group/form_group.md +0 -1
  390. package/src/components/base/form/form_group/form_group.scss +0 -59
  391. package/src/components/base/form/form_group/form_group.vue +0 -76
  392. package/src/components/base/form/form_input/form_input.md +0 -1
  393. package/src/components/base/form/form_input/form_input.scss +0 -74
  394. package/src/components/base/form/form_input/form_input.vue +0 -98
  395. package/src/components/base/form/form_input_group/form_input_group.md +0 -67
  396. package/src/components/base/form/form_input_group/form_input_group.vue +0 -103
  397. package/src/components/base/form/form_input_group/form_input_group_mixin.js +0 -39
  398. package/src/components/base/form/form_radio/form_radio.md +0 -23
  399. package/src/components/base/form/form_radio/form_radio.scss +0 -1
  400. package/src/components/base/form/form_radio/form_radio.vue +0 -51
  401. package/src/components/base/form/form_radio_group/form_radio_group.md +0 -63
  402. package/src/components/base/form/form_radio_group/form_radio_group.scss +0 -4
  403. package/src/components/base/form/form_radio_group/form_radio_group.vue +0 -64
  404. package/src/components/base/form/form_select/constants.js +0 -5
  405. package/src/components/base/form/form_select/form_select.md +0 -1
  406. package/src/components/base/form/form_select/form_select.scss +0 -117
  407. package/src/components/base/form/form_select/form_select.vue +0 -61
  408. package/src/components/base/form/form_textarea/form_textarea.md +0 -3
  409. package/src/components/base/form/form_textarea/form_textarea.vue +0 -141
  410. package/src/components/base/form/input_group_text/input_group_text.md +0 -4
  411. package/src/components/base/form/input_group_text/input_group_text.vue +0 -17
  412. package/src/components/base/icon/icon.md +0 -27
  413. package/src/components/base/icon/icon.scss +0 -8
  414. package/src/components/base/icon/icon.vue +0 -98
  415. package/src/components/base/infinite_scroll/infinite_scroll.md +0 -104
  416. package/src/components/base/infinite_scroll/infinite_scroll.scss +0 -11
  417. package/src/components/base/infinite_scroll/infinite_scroll.vue +0 -169
  418. package/src/components/base/keyset_pagination/keyset_pagination.md +0 -49
  419. package/src/components/base/keyset_pagination/keyset_pagination.scss +0 -9
  420. package/src/components/base/keyset_pagination/keyset_pagination.vue +0 -152
  421. package/src/components/base/label/label.md +0 -15
  422. package/src/components/base/label/label.scss +0 -156
  423. package/src/components/base/label/label.vue +0 -160
  424. package/src/components/base/link/link.md +0 -22
  425. package/src/components/base/link/link.scss +0 -13
  426. package/src/components/base/link/link.vue +0 -25
  427. package/src/components/base/loading_icon/loading_icon.md +0 -3
  428. package/src/components/base/loading_icon/loading_icon.scss +0 -139
  429. package/src/components/base/loading_icon/loading_icon.vue +0 -96
  430. package/src/components/base/markdown/markdown.md +0 -73
  431. package/src/components/base/markdown/markdown.scss +0 -223
  432. package/src/components/base/markdown/markdown.vue +0 -18
  433. package/src/components/base/markdown/markdown_typescale_demo.html +0 -155
  434. package/src/components/base/modal/modal.md +0 -30
  435. package/src/components/base/modal/modal.scss +0 -130
  436. package/src/components/base/modal/modal.vue +0 -269
  437. package/src/components/base/nav/nav.md +0 -11
  438. package/src/components/base/nav/nav.scss +0 -7
  439. package/src/components/base/nav/nav.vue +0 -17
  440. package/src/components/base/nav/nav_item.vue +0 -17
  441. package/src/components/base/nav/nav_item_dropdown.vue +0 -40
  442. package/src/components/base/navbar/navbar.md +0 -4
  443. package/src/components/base/navbar/navbar.scss +0 -0
  444. package/src/components/base/navbar/navbar.vue +0 -17
  445. package/src/components/base/new_dropdowns/base_dropdown/base_dropdown.vue +0 -507
  446. package/src/components/base/new_dropdowns/base_dropdown/constants.js +0 -2
  447. package/src/components/base/new_dropdowns/constants.js +0 -20
  448. package/src/components/base/new_dropdowns/disclosure/constants.js +0 -6
  449. package/src/components/base/new_dropdowns/disclosure/disclosure_dropdown.md +0 -168
  450. package/src/components/base/new_dropdowns/disclosure/disclosure_dropdown.scss +0 -17
  451. package/src/components/base/new_dropdowns/disclosure/disclosure_dropdown.vue +0 -458
  452. package/src/components/base/new_dropdowns/disclosure/disclosure_dropdown_group.vue +0 -104
  453. package/src/components/base/new_dropdowns/disclosure/disclosure_dropdown_item.vue +0 -131
  454. package/src/components/base/new_dropdowns/disclosure/mock_data.js +0 -201
  455. package/src/components/base/new_dropdowns/disclosure/utils.js +0 -70
  456. package/src/components/base/new_dropdowns/dropdown.scss +0 -243
  457. package/src/components/base/new_dropdowns/dropdown_item.scss +0 -134
  458. package/src/components/base/new_dropdowns/listbox/listbox.md +0 -159
  459. package/src/components/base/new_dropdowns/listbox/listbox.scss +0 -53
  460. package/src/components/base/new_dropdowns/listbox/listbox.vue +0 -940
  461. package/src/components/base/new_dropdowns/listbox/listbox_group.vue +0 -35
  462. package/src/components/base/new_dropdowns/listbox/listbox_item.vue +0 -77
  463. package/src/components/base/new_dropdowns/listbox/listbox_search_input.vue +0 -76
  464. package/src/components/base/new_dropdowns/listbox/mock_data.js +0 -139
  465. package/src/components/base/new_dropdowns/listbox/utils.js +0 -25
  466. package/src/components/base/paginated_list/paginated_list.md +0 -1
  467. package/src/components/base/paginated_list/paginated_list.vue +0 -179
  468. package/src/components/base/pagination/pagination.md +0 -45
  469. package/src/components/base/pagination/pagination.scss +0 -57
  470. package/src/components/base/pagination/pagination.vue +0 -498
  471. package/src/components/base/path/data.js +0 -43
  472. package/src/components/base/path/path.md +0 -41
  473. package/src/components/base/path/path.scss +0 -163
  474. package/src/components/base/path/path.vue +0 -191
  475. package/src/components/base/popover/popover.scss +0 -102
  476. package/src/components/base/popover/popover.vue +0 -111
  477. package/src/components/base/progress_bar/progress_bar.scss +0 -19
  478. package/src/components/base/progress_bar/progress_bar.vue +0 -15
  479. package/src/components/base/search_box_by_click/search_box_by_click.md +0 -1
  480. package/src/components/base/search_box_by_click/search_box_by_click.scss +0 -49
  481. package/src/components/base/search_box_by_click/search_box_by_click.vue +0 -296
  482. package/src/components/base/search_box_by_type/search_box_by_type.md +0 -1
  483. package/src/components/base/search_box_by_type/search_box_by_type.scss +0 -70
  484. package/src/components/base/search_box_by_type/search_box_by_type.vue +0 -159
  485. package/src/components/base/segmented_control/segmented_control.md +0 -1
  486. package/src/components/base/segmented_control/segmented_control.scss +0 -179
  487. package/src/components/base/segmented_control/segmented_control.vue +0 -77
  488. package/src/components/base/skeleton_loader/skeleton_loader.md +0 -46
  489. package/src/components/base/skeleton_loader/skeleton_loader.scss +0 -17
  490. package/src/components/base/skeleton_loader/skeleton_loader.vue +0 -249
  491. package/src/components/base/sorting/sorting.md +0 -80
  492. package/src/components/base/sorting/sorting.vue +0 -160
  493. package/src/components/base/table/constants.js +0 -48
  494. package/src/components/base/table/table.md +0 -72
  495. package/src/components/base/table/table.scss +0 -145
  496. package/src/components/base/table/table.vue +0 -144
  497. package/src/components/base/table_lite/table_lite.md +0 -68
  498. package/src/components/base/table_lite/table_lite.vue +0 -43
  499. package/src/components/base/tabs/constants.js +0 -1
  500. package/src/components/base/tabs/tab/tab.vue +0 -57
  501. package/src/components/base/tabs/tabs/scrollable_tabs.vue +0 -140
  502. package/src/components/base/tabs/tabs/tabs.md +0 -76
  503. package/src/components/base/tabs/tabs/tabs.scss +0 -164
  504. package/src/components/base/tabs/tabs/tabs.vue +0 -282
  505. package/src/components/base/toast/toast.js +0 -93
  506. package/src/components/base/toast/toast.md +0 -48
  507. package/src/components/base/toast/toast.scss +0 -62
  508. package/src/components/base/toggle/toggle.md +0 -4
  509. package/src/components/base/toggle/toggle.scss +0 -177
  510. package/src/components/base/toggle/toggle.vue +0 -194
  511. package/src/components/base/token/token.md +0 -12
  512. package/src/components/base/token/token.scss +0 -44
  513. package/src/components/base/token/token.vue +0 -67
  514. package/src/components/base/token_selector/helpers.js +0 -3
  515. package/src/components/base/token_selector/token_container.vue +0 -184
  516. package/src/components/base/token_selector/token_selector.md +0 -78
  517. package/src/components/base/token_selector/token_selector.scss +0 -19
  518. package/src/components/base/token_selector/token_selector.vue +0 -489
  519. package/src/components/base/token_selector/token_selector_dropdown.vue +0 -257
  520. package/src/components/base/tooltip/tooltip.md +0 -52
  521. package/src/components/base/tooltip/tooltip.scss +0 -52
  522. package/src/components/base/tooltip/tooltip.vue +0 -31
  523. package/src/components/charts/area/area.vue +0 -372
  524. package/src/components/charts/bar/bar.md +0 -3
  525. package/src/components/charts/bar/bar.vue +0 -237
  526. package/src/components/charts/chart/chart.md +0 -19
  527. package/src/components/charts/chart/chart.vue +0 -188
  528. package/src/components/charts/column/column.vue +0 -204
  529. package/src/components/charts/discrete_scatter/discrete_scatter.vue +0 -207
  530. package/src/components/charts/gauge/gauge.md +0 -8
  531. package/src/components/charts/gauge/gauge.scss +0 -0
  532. package/src/components/charts/gauge/gauge.vue +0 -178
  533. package/src/components/charts/heatmap/heatmap.md +0 -7
  534. package/src/components/charts/heatmap/heatmap.scss +0 -7
  535. package/src/components/charts/heatmap/heatmap.vue +0 -290
  536. package/src/components/charts/heatmap/index.js +0 -3
  537. package/src/components/charts/legend/legend.md +0 -16
  538. package/src/components/charts/legend/legend.scss +0 -97
  539. package/src/components/charts/legend/legend.vue +0 -284
  540. package/src/components/charts/line/line.md +0 -7
  541. package/src/components/charts/line/line.vue +0 -368
  542. package/src/components/charts/series_label/series_label.md +0 -1
  543. package/src/components/charts/series_label/series_label.scss +0 -23
  544. package/src/components/charts/series_label/series_label.vue +0 -85
  545. package/src/components/charts/single_stat/single_stat.md +0 -8
  546. package/src/components/charts/single_stat/single_stat.scss +0 -17
  547. package/src/components/charts/single_stat/single_stat.vue +0 -158
  548. package/src/components/charts/sparkline/sparkline.md +0 -8
  549. package/src/components/charts/sparkline/sparkline.vue +0 -308
  550. package/src/components/charts/stacked_column/stacked_column.md +0 -10
  551. package/src/components/charts/stacked_column/stacked_column.vue +0 -330
  552. package/src/components/charts/tooltip/tooltip.md +0 -3
  553. package/src/components/charts/tooltip/tooltip.scss +0 -9
  554. package/src/components/charts/tooltip/tooltip.vue +0 -253
  555. package/src/components/experimental/duo/chat/duo_chat.scss +0 -168
  556. package/src/components/experimental/experiment_badge/constants.js +0 -2
  557. package/src/components/experimental/experiment_badge/experiment_badge.md +0 -9
  558. package/src/components/experimental/experiment_badge/experiment_badge.vue +0 -113
  559. package/src/components/mixins/button_mixin.js +0 -9
  560. package/src/components/mixins/safe_link_mixin.js +0 -28
  561. package/src/components/mixins/tooltip_mixin.js +0 -21
  562. package/src/components/regions/dashboard_skeleton/dashboard_skeleton.md +0 -4
  563. package/src/components/regions/dashboard_skeleton/dashboard_skeleton.vue +0 -40
  564. package/src/components/regions/empty_state/empty_state.md +0 -4
  565. package/src/components/regions/empty_state/empty_state.scss +0 -3
  566. package/src/components/regions/empty_state/empty_state.vue +0 -187
  567. package/src/components/shared_components/charts/tooltip_default_format.scss +0 -18
  568. package/src/components/shared_components/charts/tooltip_default_format.vue +0 -32
  569. package/src/components/shared_components/clear_icon_button/clear_icon_button.scss +0 -10
  570. package/src/components/shared_components/clear_icon_button/clear_icon_button.vue +0 -43
  571. package/src/components/shared_components/close_button/close_button.vue +0 -29
  572. package/src/components/utilities/animated_number/animated_number.md +0 -6
  573. package/src/components/utilities/animated_number/animated_number.vue +0 -99
  574. package/src/components/utilities/friendly_wrap/friendly_wrap.md +0 -66
  575. package/src/components/utilities/friendly_wrap/friendly_wrap.vue +0 -33
  576. package/src/components/utilities/intersection_observer/intersection_observer.md +0 -16
  577. package/src/components/utilities/intersection_observer/intersection_observer.vue +0 -67
  578. package/src/components/utilities/intersperse/intersperse.md +0 -90
  579. package/src/components/utilities/intersperse/intersperse.vue +0 -60
  580. package/src/components/utilities/sprintf/sprintf.md +0 -243
  581. package/src/components/utilities/sprintf/sprintf.vue +0 -142
  582. package/src/components/utilities/truncate/constants.js +0 -5
  583. package/src/components/utilities/truncate/truncate.md +0 -14
  584. package/src/components/utilities/truncate/truncate.scss +0 -21
  585. package/src/components/utilities/truncate/truncate.vue +0 -109
  586. package/src/components/utilities/truncate_text/constants.js +0 -5
  587. package/src/components/utilities/truncate_text/truncate_text.md +0 -26
  588. package/src/components/utilities/truncate_text/truncate_text.scss +0 -14
  589. package/src/components/utilities/truncate_text/truncate_text.vue +0 -124
  590. package/src/directives/collapse_toggle.js +0 -1
  591. package/src/directives/hover_load/hover_load.js +0 -46
  592. package/src/directives/hover_load/hover_load.md +0 -22
  593. package/src/directives/modal.js +0 -1
  594. package/src/directives/outside/outside.js +0 -151
  595. package/src/directives/outside/outside.md +0 -140
  596. package/src/directives/resize_observer/resize_observer.js +0 -45
  597. package/src/directives/resize_observer/resize_observer.md +0 -54
  598. package/src/directives/safe_html/constants.js +0 -14
  599. package/src/directives/safe_html/safe_html.js +0 -35
  600. package/src/directives/safe_html/safe_html.md +0 -58
  601. package/src/directives/safe_link/mock_data.js +0 -33
  602. package/src/directives/safe_link/safe_link.js +0 -56
  603. package/src/directives/safe_link/safe_link.md +0 -37
  604. package/src/directives/tooltip.js +0 -1
  605. package/src/internal/color_contrast/color_contrast.md +0 -8
  606. package/src/internal/color_contrast/color_contrast.vue +0 -52
  607. package/src/scss/README.md +0 -1
  608. package/src/scss/body.scss +0 -4
  609. package/src/scss/bootstrap.scss +0 -34
  610. package/src/scss/bootstrap_vue.scss +0 -25
  611. package/src/scss/fonts.scss +0 -67
  612. package/src/scss/functions.scss +0 -63
  613. package/src/scss/gitlab_ui.scss +0 -19
  614. package/src/scss/mixins.scss +0 -262
  615. package/src/scss/storybook.scss +0 -43
  616. package/src/scss/storybook_dark_mode.scss +0 -21
  617. package/src/scss/tokens.scss +0 -2
  618. package/src/scss/typescale/_index.scss +0 -103
  619. package/src/scss/typescale/typeface_demo.html +0 -70
  620. package/src/scss/typescale/typescale.md +0 -82
  621. package/src/scss/typescale/typescale_demo.html +0 -78
  622. package/src/scss/typescale/typescale_demo.scss +0 -8
  623. package/src/scss/utilities.scss +0 -9196
  624. package/src/scss/utility-mixins/accessibility.scss +0 -19
  625. package/src/scss/utility-mixins/animation.scss +0 -90
  626. package/src/scss/utility-mixins/background.scss +0 -421
  627. package/src/scss/utility-mixins/border.scss +0 -498
  628. package/src/scss/utility-mixins/box-shadow.scss +0 -220
  629. package/src/scss/utility-mixins/clearfix.scss +0 -9
  630. package/src/scss/utility-mixins/color.scss +0 -228
  631. package/src/scss/utility-mixins/composite.scss +0 -24
  632. package/src/scss/utility-mixins/cursor.scss +0 -36
  633. package/src/scss/utility-mixins/deprecated.scss +0 -20
  634. package/src/scss/utility-mixins/display.scss +0 -192
  635. package/src/scss/utility-mixins/flex.scss +0 -360
  636. package/src/scss/utility-mixins/grid.scss +0 -50
  637. package/src/scss/utility-mixins/image.scss +0 -8
  638. package/src/scss/utility-mixins/index.scss +0 -47
  639. package/src/scss/utility-mixins/list-style.scss +0 -12
  640. package/src/scss/utility-mixins/opacity.scss +0 -32
  641. package/src/scss/utility-mixins/outline.scss +0 -12
  642. package/src/scss/utility-mixins/overflow.scss +0 -45
  643. package/src/scss/utility-mixins/pointer-events.scss +0 -12
  644. package/src/scss/utility-mixins/sizing.scss +0 -582
  645. package/src/scss/utility-mixins/spacing.scss +0 -1564
  646. package/src/scss/utility-mixins/svg.scss +0 -79
  647. package/src/scss/utility-mixins/text.scss +0 -183
  648. package/src/scss/utility-mixins/transform.scss +0 -58
  649. package/src/scss/utility-mixins/transition.scss +0 -44
  650. package/src/scss/utility-mixins/typography.scss +0 -381
  651. package/src/scss/utility-mixins/vertical-align.scss +0 -22
  652. package/src/scss/utility-mixins/visibility.scss +0 -12
  653. package/src/scss/utility-mixins/z-index.scss +0 -37
  654. package/src/scss/variables.scss +0 -337
  655. package/src/tokens/action.tokens.json +0 -566
  656. package/src/tokens/background.tokens.json +0 -62
  657. package/src/tokens/border.tokens.json +0 -43
  658. package/src/tokens/build/css/tokens.css +0 -953
  659. package/src/tokens/build/css/tokens.dark.css +0 -953
  660. package/src/tokens/build/js/tokens.dark.js +0 -951
  661. package/src/tokens/build/js/tokens.js +0 -951
  662. package/src/tokens/build/json/tokens.dark.json +0 -21803
  663. package/src/tokens/build/scss/_tokens.dark.scss +0 -950
  664. package/src/tokens/build/scss/_tokens.scss +0 -950
  665. package/src/tokens/build/scss/_tokens_custom_properties.scss +0 -951
  666. package/src/tokens/build/tailwind/tokens.cjs +0 -336
  667. package/src/tokens/color.alpha.tokens.json +0 -70
  668. package/src/tokens/color.constant.tokens.json +0 -660
  669. package/src/tokens/color.data_viz.tokens.json +0 -509
  670. package/src/tokens/common_story_options.js +0 -25
  671. package/src/tokens/contextual/alert.tokens.json +0 -209
  672. package/src/tokens/contextual/avatar.tokens.json +0 -112
  673. package/src/tokens/contextual/badge.tokens.json +0 -879
  674. package/src/tokens/contextual/banner.tokens.json +0 -38
  675. package/src/tokens/contextual/breadcrumb.tokens.json +0 -11
  676. package/src/tokens/contextual/broadcast.tokens.json +0 -222
  677. package/src/tokens/contextual/button.tokens.json +0 -874
  678. package/src/tokens/contextual/datepicker.tokens.json +0 -25
  679. package/src/tokens/contextual/dropdown.tokens.json +0 -148
  680. package/src/tokens/contextual/filtered-search.tokens.json +0 -72
  681. package/src/tokens/contextual/label.tokens.json +0 -118
  682. package/src/tokens/contextual/link.tokens.json +0 -46
  683. package/src/tokens/contextual/progress-bar.tokens.json +0 -38
  684. package/src/tokens/contextual/skeleton-loader.tokens.json +0 -24
  685. package/src/tokens/contextual/spinner.tokens.json +0 -38
  686. package/src/tokens/contextual/table.tokens.json +0 -24
  687. package/src/tokens/contextual/tabs.tokens.json +0 -18
  688. package/src/tokens/contextual/toggle.tokens.json +0 -59
  689. package/src/tokens/contextual/token.tokens.json +0 -21
  690. package/src/tokens/control.tokens.json +0 -177
  691. package/src/tokens/deprecated.color.theme.tokens.json +0 -736
  692. package/src/tokens/deprecated.color.tokens.json +0 -800
  693. package/src/tokens/deprecated.color.transparency.tokens.json +0 -110
  694. package/src/tokens/feedback.tokens.json +0 -200
  695. package/src/tokens/focus-ring.tokens.json +0 -21
  696. package/src/tokens/icon.tokens.json +0 -78
  697. package/src/tokens/line_height.tokens.json +0 -74
  698. package/src/tokens/shadow.tokens.json +0 -14
  699. package/src/tokens/status.tokens.json +0 -196
  700. package/src/tokens/text.tokens.json +0 -105
  701. package/src/tokens/tokens_story.vue +0 -84
  702. package/src/tokens/tokens_table.vue +0 -248
  703. package/src/utils/breakpoints.js +0 -21
  704. package/src/utils/charts/config.js +0 -514
  705. package/src/utils/charts/constants.js +0 -61
  706. package/src/utils/charts/mock_data.js +0 -259
  707. package/src/utils/charts/story_config.js +0 -21
  708. package/src/utils/charts/theme.js +0 -344
  709. package/src/utils/charts/utils.js +0 -49
  710. package/src/utils/constants.js +0 -347
  711. package/src/utils/data_utils.js +0 -28
  712. package/src/utils/datetime_utility.js +0 -63
  713. package/src/utils/i18n.js +0 -62
  714. package/src/utils/is_slot_empty.js +0 -40
  715. package/src/utils/number_utils.js +0 -120
  716. package/src/utils/play_utils.js +0 -9
  717. package/src/utils/set_utils.js +0 -24
  718. package/src/utils/stories_constants.js +0 -30
  719. package/src/utils/stories_utils.js +0 -5
  720. package/src/utils/story_decorators/container.js +0 -14
  721. package/src/utils/string_utils.js +0 -79
  722. package/src/utils/svgs/svg_paths.js +0 -10
  723. package/src/utils/use_fake_date.js +0 -27
  724. package/src/utils/use_mock_intersection_observer.js +0 -96
  725. package/src/utils/utils.js +0 -206
  726. package/src/utils.js +0 -4
  727. package/tailwind.defaults.js +0 -543
  728. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_context/constants.js +0 -0
  729. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_context/duo_chat_context_item_menu/duo_chat_context_item_menu.vue +0 -0
  730. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_context/duo_chat_context_item_menu/duo_chat_context_item_menu_category_items.vue +0 -0
  731. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_context/duo_chat_context_item_menu/duo_chat_context_item_menu_search_item.vue +0 -0
  732. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_context/duo_chat_context_item_menu/duo_chat_context_item_menu_search_items.vue +0 -0
  733. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_context/duo_chat_context_item_popover/duo_chat_context_item_popover.vue +0 -0
  734. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_context/duo_chat_context_item_selections/duo_chat_context_item_selections.vue +0 -0
  735. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_context/mock_context_data.js +0 -0
  736. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_context/utils.js +0 -0
  737. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_conversation/duo_chat_conversation.md +0 -0
  738. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_conversation/duo_chat_conversation.vue +0 -0
  739. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_loader/duo_chat_loader.md +0 -0
  740. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_loader/duo_chat_loader.scss +0 -0
  741. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_loader/duo_chat_loader.vue +0 -0
  742. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_message/buttons_utils.js +0 -0
  743. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_message/copy_code_element.js +0 -0
  744. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_message/duo_chat_message.md +0 -0
  745. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_message/insert_code_snippet_element.js +0 -0
  746. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_message/utils.js +0 -0
  747. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_message_sources/duo_chat_message_sources.md +0 -0
  748. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_message_sources/duo_chat_message_sources.vue +0 -0
  749. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_predefined_prompts/duo_chat_predefined_prompts.md +0 -0
  750. /package/src/components/{experimental/duo/chat → chat}/components/duo_chat_predefined_prompts/duo_chat_predefined_prompts.vue +0 -0
  751. /package/src/components/{experimental/duo/chat → chat}/constants.js +0 -0
  752. /package/src/components/{experimental/duo/chat → chat}/duo_chat.md +0 -0
  753. /package/src/components/{experimental/duo/chat → chat}/duo_chat.vue +0 -0
  754. /package/src/components/{experimental/duo/chat → chat}/markdown_renderer.js +0 -0
  755. /package/src/components/{experimental/duo/user_feedback → user_feedback}/user_feedback.md +0 -0
  756. /package/src/components/{experimental/duo/user_feedback → user_feedback}/user_feedback.vue +0 -0
  757. /package/src/components/{experimental/duo/user_feedback → user_feedback}/user_feedback_modal.vue +0 -0
  758. /package/src/components/{experimental/duo/workflow → workflow}/components/duo_workflow_panel/duo_workflow_panel.md +0 -0
  759. /package/src/components/{experimental/duo/workflow → workflow}/components/duo_workflow_panel/duo_workflow_panel.vue +0 -0
  760. /package/src/components/{experimental/duo/workflow → workflow}/components/duo_workflow_prompt/duo_workflow_prompt.md +0 -0
  761. /package/src/components/{experimental/duo/workflow → workflow}/components/duo_workflow_prompt/duo_workflow_prompt.vue +0 -0
@@ -0,0 +1,223 @@
1
+ import { mount } from '@vue/test-utils'
2
+ import { waitNT, waitRAF } from '../../../tests/utils'
3
+ import { VBTooltip } from './tooltip'
4
+
5
+ // Key which we use to store tooltip object on element
6
+ const BV_TOOLTIP = '__BV_Tooltip__'
7
+
8
+ describe('v-b-tooltip directive', () => {
9
+ const originalCreateRange = document.createRange
10
+ const origGetBCR = Element.prototype.getBoundingClientRect
11
+
12
+ beforeEach(() => {
13
+ // Hack to make Popper not bork out during tests
14
+ // Note: Popper still does not do any positioning calculation in JSDOM though
15
+ // So we cannot test actual positioning - just detect when it is open
16
+ // https://github.com/FezVrasta/popper.js/issues/478#issuecomment-407422016
17
+ document.createRange = () => ({
18
+ setStart: () => {},
19
+ setEnd: () => {},
20
+ commonAncestorContainer: {
21
+ nodeName: 'BODY',
22
+ ownerDocument: document
23
+ }
24
+ })
25
+ // Mock `getBoundingClientRect()` so that the `isVisible(el)` test returns `true`
26
+ // Needed for visibility checks of trigger element, etc.
27
+ Element.prototype.getBoundingClientRect = jest.fn(() => ({
28
+ width: 24,
29
+ height: 24,
30
+ top: 0,
31
+ left: 0,
32
+ bottom: 0,
33
+ right: 0
34
+ }))
35
+ })
36
+
37
+ afterEach(() => {
38
+ // Reset overrides
39
+ document.createRange = originalCreateRange
40
+ Element.prototype.getBoundingClientRect = origGetBCR
41
+ })
42
+
43
+ it('should have BVTooltip Vue class instance', async () => {
44
+ jest.useFakeTimers()
45
+
46
+ const App = {
47
+ directives: {
48
+ bTooltip: VBTooltip
49
+ },
50
+ template: '<button v-b-tooltip title="foobar">button</button>'
51
+ }
52
+
53
+ const wrapper = mount(App, {
54
+ attachTo: document.body
55
+ })
56
+
57
+ expect(wrapper.vm).toBeDefined()
58
+ await waitNT(wrapper.vm)
59
+ await waitRAF()
60
+ await waitNT(wrapper.vm)
61
+ await waitRAF()
62
+ await waitNT(wrapper.vm)
63
+ await waitRAF()
64
+ jest.runOnlyPendingTimers()
65
+ await waitNT(wrapper.vm)
66
+ await waitRAF()
67
+
68
+ expect(wrapper.element.tagName).toBe('BUTTON')
69
+ const $button = wrapper.find('button')
70
+
71
+ // Should have instance of popover class on it
72
+ expect($button.element[BV_TOOLTIP]).toBeDefined()
73
+ expect($button.element[BV_TOOLTIP].$options.name).toBe('BVTooltip')
74
+
75
+ wrapper.destroy()
76
+ })
77
+
78
+ it('should work', async () => {
79
+ jest.useFakeTimers()
80
+
81
+ const App = {
82
+ directives: {
83
+ bTooltip: VBTooltip
84
+ },
85
+ template: '<button v-b-tooltip.click.html title="<b>foobar</b>">button</button>'
86
+ }
87
+
88
+ const wrapper = mount(App, {
89
+ attachTo: document.body
90
+ })
91
+
92
+ expect(wrapper.vm).toBeDefined()
93
+ await waitNT(wrapper.vm)
94
+ await waitRAF()
95
+ await waitNT(wrapper.vm)
96
+ await waitRAF()
97
+ await waitNT(wrapper.vm)
98
+ await waitRAF()
99
+ jest.runOnlyPendingTimers()
100
+ await waitNT(wrapper.vm)
101
+ await waitRAF()
102
+
103
+ expect(wrapper.element.tagName).toBe('BUTTON')
104
+ const $button = wrapper.find('button')
105
+
106
+ // Should have instance of popover class on it
107
+ expect($button.element[BV_TOOLTIP]).toBeDefined()
108
+ expect($button.element[BV_TOOLTIP].$options.name).toBe('BVTooltip')
109
+
110
+ expect($button.attributes('aria-describedby')).toBeUndefined()
111
+
112
+ // Trigger click
113
+ await $button.trigger('click')
114
+ await waitRAF()
115
+ await waitRAF()
116
+ jest.runOnlyPendingTimers()
117
+ await waitNT(wrapper.vm)
118
+ await waitRAF()
119
+
120
+ expect($button.attributes('aria-describedby')).toBeDefined()
121
+ const adb = $button.attributes('aria-describedby')
122
+
123
+ const tip = document.querySelector(`#${adb}`)
124
+ expect(tip).not.toBe(null)
125
+ expect(tip.classList.contains('tooltip')).toBe(true)
126
+
127
+ wrapper.destroy()
128
+ })
129
+
130
+ it('should not show tooltip when title is empty', async () => {
131
+ jest.useFakeTimers()
132
+
133
+ const App = {
134
+ directives: {
135
+ bTooltip: VBTooltip
136
+ },
137
+ template: '<button v-b-tooltip.click title="">button</button>'
138
+ }
139
+
140
+ const wrapper = mount(App, {
141
+ attachTo: document.body
142
+ })
143
+
144
+ expect(wrapper.vm).toBeDefined()
145
+ await waitNT(wrapper.vm)
146
+ await waitRAF()
147
+ await waitNT(wrapper.vm)
148
+ await waitRAF()
149
+ await waitNT(wrapper.vm)
150
+ await waitRAF()
151
+ jest.runOnlyPendingTimers()
152
+ await waitNT(wrapper.vm)
153
+ await waitRAF()
154
+
155
+ expect(wrapper.element.tagName).toBe('BUTTON')
156
+ const $button = wrapper.find('button')
157
+
158
+ // Should have instance of popover class on it
159
+ expect($button.element[BV_TOOLTIP]).toBeDefined()
160
+ expect($button.element[BV_TOOLTIP].$options.name).toBe('BVTooltip')
161
+
162
+ expect($button.attributes('aria-describedby')).toBeUndefined()
163
+
164
+ // Trigger click
165
+ await $button.trigger('click')
166
+ await waitRAF()
167
+ await waitRAF()
168
+ jest.runOnlyPendingTimers()
169
+ await waitNT(wrapper.vm)
170
+ await waitRAF()
171
+
172
+ expect($button.attributes('aria-describedby')).toBeUndefined()
173
+
174
+ wrapper.destroy()
175
+ })
176
+
177
+ it('variant and customClass should work', async () => {
178
+ jest.useFakeTimers()
179
+
180
+ const App = {
181
+ directives: {
182
+ bTooltip: VBTooltip
183
+ },
184
+ template: `<button v-b-tooltip.click.html.v-info="{ customClass: 'foobar'}" title="<b>foobar</b>">button</button>`
185
+ }
186
+
187
+ const wrapper = mount(App, {
188
+ attachTo: document.body
189
+ })
190
+
191
+ expect(wrapper.vm).toBeDefined()
192
+ expect(wrapper.element.tagName).toBe('BUTTON')
193
+ const $button = wrapper.find('button')
194
+ await waitNT(wrapper.vm)
195
+ await waitRAF()
196
+ await waitNT(wrapper.vm)
197
+ await waitRAF()
198
+ await waitNT(wrapper.vm)
199
+ await waitRAF()
200
+ jest.runOnlyPendingTimers()
201
+ await waitNT(wrapper.vm)
202
+ await waitRAF()
203
+
204
+ // Trigger click
205
+ await $button.trigger('click')
206
+ await waitRAF()
207
+ await waitRAF()
208
+ jest.runOnlyPendingTimers()
209
+ await waitNT(wrapper.vm)
210
+ await waitRAF()
211
+
212
+ expect($button.attributes('aria-describedby')).toBeDefined()
213
+ const adb = $button.attributes('aria-describedby')
214
+
215
+ const tip = document.querySelector(`#${adb}`)
216
+ expect(tip).not.toBe(null)
217
+ expect(tip.classList.contains('tooltip')).toBe(true)
218
+ expect(tip.classList.contains('b-tooltip-info')).toBe(true)
219
+ expect(tip.classList.contains('foobar')).toBe(true)
220
+
221
+ wrapper.destroy()
222
+ })
223
+ })
@@ -0,0 +1,244 @@
1
+ # Visible
2
+
3
+ > `v-b-visible` is a lightweight directive that allows you to react when an element becomes visible
4
+ > in the viewport and/or when it moves out of the viewport (or is no longer visible).
5
+
6
+ ## Overview
7
+
8
+ - `v-b-visible` will call your callback method with a boolean value indicating if the element is
9
+ visible (intersecting with the viewport) or not.
10
+ - The directive can be placed on almost any element or component.
11
+ - Changes in visibility can also be detected (such as `display: none`), as long as the element is
12
+ within (or partially within) the viewport, or within the optional offset. Note: transitioning to a
13
+ non-visible state due to `v-if="false"` _cannot_ be detected.
14
+ - Internally, BootstrapVue uses this directive in several components, such as `<b-img-lazy>`.
15
+ - The `v-b-visible` directive requires browser support of
16
+ [`IntersectionObserver`](https://developer.mozilla.org/en-US/docs/Web/API/Intersection_Observer_API).
17
+ For older browsers that do not support `IntersectionObserver`, you will need to use a
18
+ [polyfill](/docs/#js).
19
+ - If `IntersectionObserver` support is not detected, then `v-b-visible` will assume the element is
20
+ _always visible_, and will call the callback once with the argument set to `true`.
21
+
22
+ ## Directive syntax and usage
23
+
24
+ ```html
25
+ <div v-b-visible.[mod1].[mod2]="callback">content</div>
26
+ ```
27
+
28
+ Where `callback` is required:
29
+
30
+ - A function reference that will be called whenever visibility changes. The callback is passed a
31
+ single boolean argument. `true` indicates that the element is intersecting (partially or entirely
32
+ visible) in the viewport, or `false` if the element is not visible/intersecting with the viewport.
33
+ The callback will be called each time the element's visibility changes (except when the `once`
34
+ modifier is used. See below for details)
35
+
36
+ Where `[mod1]` or `[mod2]` can be (all optional):
37
+
38
+ - A positive integer number representing the offset (margin) in pixels _away_ from the edge of the
39
+ _viewport_ to determine when the element is considered in (or just about to be in) the viewport.
40
+ The value adds a margin around the viewport. The default value is `0`.
41
+ - The keyword `once`. When this modifier is present, the callback will be called only once the first
42
+ time the element is visible (with the argument of `true` indicating the element is
43
+ intersecting/visible). Note the callback _may be_ called prior to this with an argument of `false`
44
+ signifying the element is not intersecting/visible.
45
+
46
+ The order of the modifiers is not important.
47
+
48
+ ### Usage syntax examples
49
+
50
+ In all use cases, the callback function is required.
51
+
52
+ #### Basic (no modifiers)
53
+
54
+ ```html
55
+ <template>
56
+ <div v-b-visible="visibleHandler"> ... </div>
57
+ </template>
58
+ <script>
59
+ export default {
60
+ methods: {
61
+ visibleHandler(isVisible) {
62
+ if (isVisible) {
63
+ // Do something
64
+ } else {
65
+ // Do something else
66
+ }
67
+ }
68
+ }
69
+ }
70
+ </script>
71
+ ```
72
+
73
+ #### With viewport offset modifier
74
+
75
+ In this example, the modifier value represents 350px (if the element is outside of the physical
76
+ viewport by at least 350px, then it will be considered "visible"):
77
+
78
+ ```html
79
+ <template>
80
+ <div v-b-visible.350="visibleHandler"> ... </div>
81
+ </template>
82
+ <script>
83
+ export default {
84
+ methods: {
85
+ visibleHandler(isVisible) {
86
+ if (isVisible) {
87
+ // Do something
88
+ } else {
89
+ // Do something else
90
+ }
91
+ }
92
+ }
93
+ }
94
+ </script>
95
+ ```
96
+
97
+ #### With the `once` modifier
98
+
99
+ ```html
100
+ <template>
101
+ <div v-b-visible.once="visibleHandler"> ... </div>
102
+ </template>
103
+ <script>
104
+ export default {
105
+ methods: {
106
+ visibleHandler(isVisible) {
107
+ if (isVisible) {
108
+ // This will only ever happen once, when the
109
+ // element has become visible for the first time
110
+ } else {
111
+ // This may happen zero or more times before
112
+ // the element becomes visible, but will never
113
+ // happen after the element has become visible
114
+ }
115
+ }
116
+ }
117
+ }
118
+ </script>
119
+ ```
120
+
121
+ #### With both `once` and offset modifiers
122
+
123
+ ```html
124
+ <template>
125
+ <div v-b-visible.once.350="visibleHandler"> ... </div>
126
+ </template>
127
+ <script>
128
+ export default {
129
+ methods: {
130
+ visibleHandler(isVisible) {
131
+ if (isVisible) {
132
+ // This will only ever happen once, when the
133
+ // element is outside of the physical viewport
134
+ // by at least 350px for the first time
135
+ } else {
136
+ // This may happen zero or more times before
137
+ // the element becomes visible, but will never
138
+ // happen after the element has become visible
139
+ }
140
+ }
141
+ }
142
+ }
143
+ </script>
144
+ ```
145
+
146
+ ## Live examples
147
+
148
+ Here are two live examples showing two common use cases.
149
+
150
+ ### Visibility of scrolled content
151
+
152
+ Scroll the container to see the reaction when the `<b-badge>` scrolls into view. Note that
153
+ visibility state will also change if the element is scrolled out of the viewport.
154
+
155
+ ```html
156
+ <template>
157
+ <div>
158
+ <div
159
+ :class="[isVisible ? 'bg-info' : 'bg-light', 'border', 'p-2', 'text-center']"
160
+ style="height: 85px; overflow-y: scroll;"
161
+ >
162
+ <p>{{ text }}</p>
163
+ <b-badge v-b-visible="handleVisibility">Element with v-b-visible directive</b-badge>
164
+ <p>{{ text }}</p>
165
+ </div>
166
+ <p class="mt-2">
167
+ Visible: {{ isVisible }}
168
+ </p>
169
+ </div>
170
+ </template>
171
+
172
+ <script>
173
+ export default {
174
+ data() {
175
+ return {
176
+ isVisible: false,
177
+ text: `
178
+ Quis magna Lorem anim amet ipsum do mollit sit cillum voluptate ex nulla
179
+ tempor. Laborum consequat non elit enim exercitation cillum aliqua
180
+ consequat id aliqua. Esse ex consectetur mollit voluptate est in duis
181
+ laboris ad sit ipsum anim Lorem. Incididunt veniam velit elit elit veniam
182
+ Lorem aliqua quis ullamco deserunt sit enim elit aliqua esse irure. Laborum
183
+ nisi sit est tempor laborum mollit labore officia laborum excepteur commodo
184
+ non commodo dolor excepteur commodo. Ipsum fugiat ex est consectetur ipsum
185
+ commodo tempor sunt in proident. Non elixir food exorcism nacho tequila tasty.
186
+ `
187
+ }
188
+ },
189
+ methods: {
190
+ handleVisibility(isVisible) {
191
+ this.isVisible = isVisible
192
+ }
193
+ }
194
+ }
195
+ </script>
196
+
197
+ <!-- v-b-visible-scroll.vue -->
198
+ ```
199
+
200
+ One use case for this, when combined with the `once` modifier, is to see if a user has scrolled to
201
+ the bottom of a page or scrollable div (i.e. has "read" the entire terms of service).
202
+
203
+ ### CSS display visibility detection
204
+
205
+ Click the button to change the `<div>` visibility state. Note that visibility state will also change
206
+ if the element is scrolled out of the viewport.
207
+
208
+ ```html
209
+ <template>
210
+ <div>
211
+ <b-button @click="show = !show" class="mb-2">Toggle display</b-button>
212
+ <p>Visible: {{ isVisible }}</p>
213
+ <div class="border p-3" style="height: 6em;">
214
+ <!-- We use Vue's `v-show` directive to control the CSS `display` of the div -->
215
+ <div v-show="show" class="bg-info p-3">
216
+ <b-badge v-b-visible="handleVisibility">Element with v-b-visible directive</b-badge>
217
+ </div>
218
+ </div>
219
+ </div>
220
+ </template>
221
+
222
+ <script>
223
+ export default {
224
+ data() {
225
+ return {
226
+ show: true,
227
+ isVisible: false
228
+ }
229
+ },
230
+ methods: {
231
+ handleVisibility(isVisible) {
232
+ this.isVisible = isVisible
233
+ }
234
+ }
235
+ }
236
+ </script>
237
+
238
+ <!-- v-b-visible-display.vue -->
239
+ ```
240
+
241
+ ## See also
242
+
243
+ For more details on `IntersectionObserver`, refer to the
244
+ [MDN documentation](https://developer.mozilla.org/en-US/docs/Web/API/Intersection_Observer_API)
@@ -0,0 +1,7 @@
1
+ //
2
+ // VBVisible
3
+ //
4
+ import { DirectiveOptions } from 'vue'
5
+
6
+ // Directive: v-b-visible
7
+ export declare const VBVisible: DirectiveOptions
@@ -0,0 +1,24 @@
1
+ {
2
+ "name": "@bootstrap-vue/v-b-visible",
3
+ "version": "0.0.0",
4
+ "meta": {
5
+ "title": "Visible",
6
+ "description": "The `v-b-visible` directive allows you to react when an element becomes visible in the viewport.",
7
+ "directive": "VBVisible",
8
+ "version": "2.1.0",
9
+ "expression": [
10
+ "Function"
11
+ ],
12
+ "modifiers": [
13
+ {
14
+ "name": "once",
15
+ "description": "Only calls the callback once when the element becomes visible in the viewport"
16
+ },
17
+ {
18
+ "name": "{###}",
19
+ "pattern": "[0-9]+",
20
+ "description": "An offset value in pixels (where `{###}` is the number of pixels) relative to the viewport, defaults to 0. Negative values allowed"
21
+ }
22
+ ]
23
+ }
24
+ }
@@ -0,0 +1,61 @@
1
+ import Vue, { Component, PluginFunction, PluginObject } from 'vue'
2
+
3
+ // Plugin Config Options
4
+ export type BvConfigComponentOptionValue =
5
+ | string
6
+ | string[]
7
+ | number
8
+ | number[]
9
+ | boolean
10
+ | object
11
+ | null
12
+ export type BvConfigBreakpointsValue = string[]
13
+ export interface BvConfigComponentOptions {
14
+ [key: string]: BvConfigComponentOptionValue | any
15
+ }
16
+ export interface BvConfigOptions {
17
+ breakpoints?: BvConfigBreakpointsValue
18
+ [key: string]: BvConfigComponentOptions | any
19
+ }
20
+
21
+ // Plugin definition
22
+ export interface BvPlugin extends PluginObject<BvConfigOptions> {
23
+ install: PluginFunction<BvConfigOptions>
24
+ }
25
+
26
+ // Component base definition
27
+ export class BvComponent extends Vue {
28
+ // Simple catch-all to allow any prop/type
29
+ [key: string]: any
30
+ }
31
+
32
+ // Generic BvEvent Object
33
+ export interface BvEvent {
34
+ readonly type: string
35
+ readonly cancelable: boolean
36
+ readonly nativeEvent: any
37
+ readonly target: any
38
+ readonly relatedTarget: any
39
+ readonly defaultPrevented: boolean
40
+ readonly vueTarget: Vue | Component | null
41
+ readonly componentId: string | null
42
+ preventDefault: () => void
43
+ // Catch all
44
+ [key: string]: any
45
+ }
46
+
47
+ // Vue prototype augments
48
+ import './vue-injections'
49
+
50
+ // BvConfig Plugin
51
+ export * from './bv-config'
52
+
53
+ // Components & Plugins
54
+ export * from './components'
55
+
56
+ // BootstrapVue plugin
57
+ export interface BootstrapVuePlugin extends BvPlugin {
58
+ setConfig: (config: BvConfigOptions) => void
59
+ }
60
+ export declare const BootstrapVue: BootstrapVuePlugin
61
+ export default BootstrapVue