@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
@@ -1,243 +0,0 @@
1
- ## Overview
2
-
3
- The `GlSprintf` component lets you do `sprintf`-style string interpolation with
4
- child components. Each placeholder in the translated string, provided via the
5
- `message` prop, becomes a slot that you can use to insert any components or
6
- markup in the rendered output.
7
-
8
- > NOTE: `gl-sprintf` does not translate the message for you; you must provide
9
- > it already translated. In the following examples, it is assumed that
10
- > a `gettext`-style `__` translation function is available in your Vue
11
- > templates.
12
-
13
- ## Displaying messages with text between placeholders (e.g., links, buttons)
14
-
15
- Sentences should not be split up into different messages, otherwise they may
16
- not be translatable into certain languages. To help with this, `GlSprintf`
17
- interprets placeholders suffixed with `Start` and `End` to indicate the
18
- boundaries of a component to display within the message. Any text between
19
- them is passed, via the `content` scoped slot property, to the slot name common
20
- to the placeholders.
21
-
22
- For example, using `linkStart` and `linkEnd` placeholders in a message defines
23
- a `link` scoped slot:
24
-
25
- ```html
26
- <div>
27
- <gl-sprintf :message="__('Learn more about %{linkStart}zones%{linkEnd}')">
28
- <template #link="{ content }">
29
- <gl-link
30
- href="https://cloud.google.com/compute/docs/regions-zones/regions-zones"
31
- target="_blank"
32
- >{{ content }}</gl-link>
33
- </template>
34
- </gl-sprintf>
35
- </div>
36
- ```
37
-
38
- will render as:
39
-
40
- ```html
41
- <div>
42
- Learn more about
43
- <a
44
- href="https://cloud.google.com/compute/docs/regions-zones/regions-zones"
45
- target="_blank"
46
- rel="noopener noreferrer"
47
- >zones</a>
48
- </div>
49
- ```
50
-
51
- Note that _any_ arbitrary HTML tags or Vue component(s) can be used within
52
- a scoped slot, and that the content passed to it can be used in any way at all;
53
- for instance, as regular text, or in component attributes or slots.
54
-
55
- Here's a more complex example, which `<gl-sprintf>` lets you do in a breeze:
56
-
57
- ```html
58
- <div>
59
- <gl-sprintf :message="__('Written by %{authorStart}someone%{authorEnd}')">
60
- <template #author="{ content }">
61
- <my-vue-component v-gl-tooltip="content" @event="handleEvent(content)">
62
- {{ content }}
63
- </my-vue-component>
64
- <p>
65
- {{ content }}
66
- <div>{{ content }}</div>
67
- </p>
68
- </template>
69
- </gl-sprintf>
70
- </div>
71
- ```
72
-
73
- This is not feasible in a JS-only solution, since arbitrary Vue components
74
- cannot easily be used. In addition, a JS-only solution is more likely to be
75
- prone to XSS attacks, as the Vue compiler isn't available to help protect
76
- against them.
77
-
78
- ### Customizing start/end placeholders
79
-
80
- You can customize the start and end placeholders that `GlSprintf` looks for
81
- using the `placeholders` prop. For instance:
82
-
83
- ```html
84
- <div>
85
- <gl-sprintf
86
- :message="__('Learn more about %{my_custom_start}zones%{my_custom_end}')"
87
- :placeholders="{ link: ['my_custom_start', 'my_custom_end'] }"
88
- >
89
- <template #link="{ content }">
90
- <gl-link
91
- href="https://cloud.google.com/compute/docs/regions-zones/regions-zones"
92
- target="_blank"
93
- >{{ content }}</gl-link>
94
- </template>
95
- </gl-sprintf>
96
- </div>
97
- ```
98
-
99
- This can be useful if you are migrating an existing string to `GlSprintf` that
100
- uses different placeholder naming conventions, and don't want invalidate
101
- existing translations.
102
-
103
- ## Displaying components within a message
104
-
105
- Use slots to replace placeholders in the message with the slots' contents.
106
- There is a slot for every placeholder in the message. For example, the `author`
107
- slot name can be used when there is an `%{author}` placeholder in the message:
108
-
109
- ```html
110
- <script>
111
- export default {
112
- data() {
113
- return {
114
- authorName: 'Some author',
115
- };
116
- },
117
- };
118
- </script>
119
-
120
- <template>
121
- <div>
122
- <gl-sprintf :message="__('Written by %{author}')">
123
- <template #author>
124
- <span>{{ authorName }}</span>
125
- </template>
126
- </gl-sprintf>
127
- </div>
128
- </template>
129
- ```
130
-
131
- The example above renders to this HTML:
132
-
133
- ```html
134
- <div>Written by <span>Some author</span></div>
135
- ```
136
-
137
- ## Usage caveats
138
-
139
- ### White space
140
-
141
- `GlSprintf` does not handle white space in scoped slots specially; it is passed
142
- through and rendered just like regular text. This means that white space in the
143
- scoped slot templates *themselves*, including newlines and indentation, are
144
- passed through untouched (assuming the template compiler you're using doesn't
145
- trim text nodes at compile time; `vue-template-compiler` preserves white space
146
- by default, for instance).
147
-
148
- Most of the time you don't need to worry about this, since
149
- [browsers normalize white space][1] automatically, but here's an example, using
150
- punctuation, where you might want to be conscious of the white space in the
151
- template:
152
-
153
- ```html
154
- <div>
155
- <gl-sprintf :message="__('Foo %{boldStart}bar%{boldEnd}!')">
156
- <template #bold="{ content }">
157
- <b>
158
- {{ content }}
159
- </b>
160
- </template>
161
- </gl-sprintf>
162
- </div>
163
- ```
164
-
165
- As written, the literal markup rendered would be:
166
-
167
- ```html
168
- <div> Foo <b>
169
- bar
170
- </b>!
171
- </div>
172
- ```
173
-
174
- where the white space (including newlines) before and after `bar` is exactly
175
- the newlines and indentation in the source template. The browser will render
176
- this as:
177
-
178
- <div> Foo <b>
179
- bar
180
- </b>!
181
- </div>
182
-
183
- Note the single space between `bar` and `!`. To avoid that, remove the
184
- white space in the template, or use `v-text`:
185
-
186
- ```html
187
- <div>
188
- <gl-sprintf :message="__('Foo %{boldStart}bar%{boldEnd}!')">
189
- <template #bold="{ content }">
190
- <b>{{ content }}</b>
191
- <!-- OR -->
192
- <b v-text="content" />
193
- </template>
194
- </gl-sprintf>
195
- </div>
196
- ```
197
-
198
- ### Miscellaneous
199
-
200
- While there are a lot of caveats here, you don't need to worry about reading
201
- them _unless_ you find `GlSprintf` isn't rendering what you'd expect.
202
-
203
- - Since `GlSprintf` typically renders multiple elements, it can't be used as
204
- a component's root, it must be wrapped with at least one other root element,
205
- otherwise Vue will throw a `Multiple root nodes returned from render
206
- function` error.
207
- - If a slot for a given placeholder _isn't_ provided, the placeholder
208
- will be rendered as-is, e.g., literally `Written by %{author}` if the
209
- `author` slot _isn't_ provided, or literally `%{linkStart}foo%{linkEnd}` if
210
- the `link` slot isn't provided.
211
- - Content between `Start` and `End` placeholders is effectively thrown away if
212
- the scoped slot of the correct name doesn't consume the `content` property in
213
- some way, though the slot's components should still be rendered.
214
- - If there's no placeholder in the message for a provided named slot, the
215
- content of that slot is silently thrown away.
216
- - If only one of the `Start` or `End` placeholders is in the message, or they
217
- are in the wrong order, they are treated as plain slots, i.e., it is assumed
218
- there is no text to extract and pass to the scoped slot. This allows you to
219
- use plain slots whose names end in `Start` or `End`, e.g., `backEnd`, or
220
- `fromStart` in isolation, without their `Start`/`End` counterparts.
221
- - Text extraction between `Start` and `End` placeholders is only done one level
222
- deep. This is intentional, so as to avoid building complex sprintf messages
223
- that would better be implemented in components. As an example,
224
- `${linkStart}test%{icon}%{linkEnd}`, if provided both the `link` and `icon`
225
- slots, would pass `test%{icon}` as a literal string as content to the `link`
226
- scoped slot.
227
- - For more examples and edge cases, please see the test suite for `GlSprintf`.
228
- - To be successfully used in `GlSprintf`, slot names should:
229
- - start with a letter (`[A-Za-z]`)
230
- - only contain alpha-numeric characters (`[A-Za-z0-9]`), underscore (`_`) and
231
- dash (`-`),
232
- - should not end with underscore (`_`) or dash (`-`) So for example:
233
- `%{author}`, `%{author_name}`, `%{authorName}` or `%{author-name-100}` are
234
- all valid placeholders.
235
-
236
- ## Internet Explorer 11
237
-
238
- This component uses [`String.prototype.startsWith()`] and [`String.prototype.endsWith()`] under the
239
- hood. Make sure those methods are polyfilled if you plan on using the component on IE11.
240
-
241
- [1]: https://www.w3.org/TR/css-text-3/#white-space-phase-1
242
- [`String.prototype.startsWith()`]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith
243
- [`String.prototype.endsWith()`]: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/endsWith
@@ -1,142 +0,0 @@
1
- <!-- eslint-disable vue/multi-word-component-names -->
2
- <script>
3
- /* eslint-disable no-continue */
4
- import has from 'lodash/has';
5
- import isString from 'lodash/isString';
6
-
7
- const PREFIX = '%{';
8
- const SUFFIX = '}';
9
- const START_SUFFIX = 'Start';
10
- const END_SUFFIX = 'End';
11
- const PLACE_HOLDER_REGEX = new RegExp(`(${PREFIX}[a-z]+[\\w-]*[a-z0-9]+${SUFFIX})`, 'gi');
12
-
13
- function groupPlaceholdersByStartTag(placeholders = {}) {
14
- return Object.entries(placeholders).reduce((acc, [slotName, [startTag, endTag]]) => {
15
- acc[startTag] = { slotName, endTag };
16
- return acc;
17
- }, {});
18
- }
19
-
20
- function getPlaceholderDefinition(chunk, placeholdersByStartTag) {
21
- const tagName = chunk.slice(PREFIX.length, -SUFFIX.length);
22
-
23
- if (has(placeholdersByStartTag, tagName)) {
24
- // Use provided custom placeholder definition
25
- return {
26
- ...placeholdersByStartTag[tagName],
27
- tagName,
28
- };
29
- }
30
-
31
- if (tagName.endsWith(START_SUFFIX)) {
32
- // Tag conforms to default start/end tag naming convention
33
- const slotName = tagName.slice(0, -START_SUFFIX.length);
34
-
35
- return {
36
- slotName,
37
- endTag: `${slotName}${END_SUFFIX}`,
38
- tagName,
39
- };
40
- }
41
-
42
- return {
43
- slotName: tagName,
44
- endTag: undefined,
45
- tagName,
46
- };
47
- }
48
-
49
- export default {
50
- name: 'GlSprintf',
51
- functional: true,
52
- props: {
53
- /**
54
- * A translated string with named placeholders, e.g., "Written by %{author}".
55
- */
56
- message: {
57
- type: String,
58
- required: true,
59
- },
60
- /**
61
- * An object mapping slot names to custom start/end placeholders. Use this
62
- * to avoid changing an existing message, and in turn invalidating existing
63
- * translations, in the case it uses non-default placeholders.
64
- */
65
- placeholders: {
66
- type: Object,
67
- required: false,
68
- default: undefined,
69
- validator: (value) =>
70
- Object.values(value).every(
71
- // eslint-disable-next-line unicorn/no-array-callback-reference
72
- (tagPair) => Array.isArray(tagPair) && tagPair.length === 2 && tagPair.every(isString)
73
- ),
74
- },
75
- },
76
- /**
77
- * Available slots are determined by the placeholders in the provided
78
- * message prop. For example, a message of "Written by %{author}" has
79
- * a slot called "author", and its content is used to replace "%{author}"
80
- * in the rendered output. When two placeholders indicate a start and an
81
- * end region in the message, e.g., "%{linkStart}foo%{linkEnd}", the common
82
- * base name can be used as a scoped slot, where the content between the
83
- * placeholders is passed via the `content` scoped slot prop.
84
- * @slot * (arbitrary)
85
- * @binding {string} content The content to place between start and end placeholders.
86
- */
87
- render(createElement, context) {
88
- // While a functional style is generally preferred, an imperative style is
89
- // used here, as it lends itself better to the message parsing algorithm.
90
- // This approach is also more performant, as it minimizes (relatively) object
91
- // creation/garbage collection, which is important given how frequently this
92
- // code may run on a given page.
93
-
94
- let i = 0;
95
- const vnodes = [];
96
- const slots = context.scopedSlots;
97
- const chunks = context.props.message.split(PLACE_HOLDER_REGEX);
98
- const placeholdersByStartTag = groupPlaceholdersByStartTag(context.props.placeholders);
99
-
100
- while (i < chunks.length) {
101
- const chunk = chunks[i];
102
- // Skip past this chunk now we have it
103
- i += 1;
104
-
105
- if (!PLACE_HOLDER_REGEX.test(chunk)) {
106
- // Not a placeholder, so pass through as-is
107
- vnodes.push(chunk);
108
- continue;
109
- }
110
-
111
- const { slotName, endTag, tagName } = getPlaceholderDefinition(chunk, placeholdersByStartTag);
112
-
113
- if (endTag) {
114
- // Peek ahead to find end placeholder, if any
115
- const indexOfEnd = chunks.indexOf(`${PREFIX}${endTag}${SUFFIX}`, i);
116
- if (indexOfEnd > -1) {
117
- // We have a valid start/end placeholder pair! Extract the content
118
- // between them and skip past the end placeholder
119
- const content = chunks.slice(i, indexOfEnd);
120
- i = indexOfEnd + 1;
121
-
122
- if (!has(slots, slotName)) {
123
- // Slot hasn't been provided; return placeholders and content as-is
124
- vnodes.push(chunk, ...content, chunks[indexOfEnd]);
125
- continue;
126
- }
127
-
128
- // Provide content to provided scoped slot
129
- vnodes.push(slots[slotName]({ content: content.join('') }));
130
- continue;
131
- }
132
- }
133
-
134
- // By process of elimination, chunk must be a plain placeholder
135
- vnodes.push(has(slots, tagName) ? slots[tagName]() : chunk);
136
- continue;
137
- }
138
-
139
- return vnodes;
140
- },
141
- };
142
- </script>
@@ -1,5 +0,0 @@
1
- export const POSITION = {
2
- START: 'start',
3
- MIDDLE: 'middle',
4
- END: 'end',
5
- };
@@ -1,14 +0,0 @@
1
- The `GlTruncate` component lets you truncate the long texts with ellipsis.
2
-
3
- > **Tip:** Try resizing the side panel for truncation.
4
-
5
- ## Usage
6
-
7
- ```html
8
- <gl-truncate :text="text" :position="position" />
9
- ```
10
-
11
- By default, the ellipsis position is at the `end`.
12
-
13
- Pro Tip: Truncating long filepaths from the `middle` / `start` can help preventing the important
14
- information in the end, i.e. filenames.
@@ -1,21 +0,0 @@
1
- .gl-truncate-component {
2
- display: inline-flex;
3
- max-width: 100%;
4
- }
5
-
6
- .gl-truncate-start,
7
- .gl-truncate-end {
8
- flex: 0 1 auto;
9
- white-space: nowrap;
10
- overflow: hidden;
11
- }
12
-
13
- .gl-truncate-start {
14
- direction: rtl;
15
- text-align: left;
16
- text-overflow: '';
17
- }
18
-
19
- .gl-truncate-end {
20
- text-overflow: ellipsis;
21
- }
@@ -1,109 +0,0 @@
1
- <!-- eslint-disable vue/multi-word-component-names -->
2
- <script>
3
- import { GlTooltipDirective } from '../../../directives/tooltip';
4
- import { GlResizeObserverDirective } from '../../../directives/resize_observer/resize_observer';
5
- import { POSITION } from './constants';
6
-
7
- export default {
8
- name: 'GlTruncate',
9
- POSITION,
10
- directives: {
11
- GlTooltip: GlTooltipDirective,
12
- GlResizeObserver: GlResizeObserverDirective,
13
- },
14
- props: {
15
- /**
16
- * Text to be ellipsized
17
- */
18
- text: {
19
- type: String,
20
- required: true,
21
- },
22
- /**
23
- * Ellipsis position
24
- */
25
- position: {
26
- type: String,
27
- required: false,
28
- default: POSITION.END,
29
- validator: (value) => Object.values(POSITION).includes(value),
30
- },
31
- /**
32
- * Display the full text in a tooltip only if it is being truncated
33
- */
34
- withTooltip: {
35
- type: Boolean,
36
- required: false,
37
- default: false,
38
- },
39
- },
40
- data() {
41
- return {
42
- isTruncated: false,
43
- };
44
- },
45
- computed: {
46
- middleIndex() {
47
- return Math.floor(this.text.length / 2);
48
- },
49
-
50
- first() {
51
- return this.text.slice(0, this.middleIndex);
52
- },
53
- last() {
54
- return this.text.slice(this.middleIndex);
55
- },
56
- isTooltipDisabled() {
57
- return !this.withTooltip || !this.isTruncated;
58
- },
59
- },
60
- watch: {
61
- withTooltip(withTooltip) {
62
- if (withTooltip) {
63
- this.checkTruncationState();
64
- }
65
- },
66
- },
67
- methods: {
68
- checkTruncationState() {
69
- if (this.withTooltip) {
70
- this.isTruncated = this.$refs.text.scrollWidth > this.$refs.text.offsetWidth;
71
- }
72
- },
73
- },
74
- };
75
- </script>
76
-
77
- <template>
78
- <span
79
- v-if="position === $options.POSITION.START"
80
- v-gl-tooltip="{ disabled: isTooltipDisabled }"
81
- v-gl-resize-observer:[withTooltip]="checkTruncationState"
82
- class="gl-truncate-component"
83
- :title="text"
84
- >
85
- <span ref="text" class="gl-truncate-start !gl-text-ellipsis">&lrm;{{ text }}&lrm;</span>
86
- </span>
87
-
88
- <span
89
- v-else-if="position === $options.POSITION.MIDDLE"
90
- v-gl-tooltip="{ disabled: isTooltipDisabled }"
91
- v-gl-resize-observer:[withTooltip]="checkTruncationState"
92
- class="gl-truncate-component"
93
- :title="text"
94
- >
95
- <span ref="text" class="gl-truncate-end">{{ first }}</span
96
- ><span class="gl-truncate-start">&lrm;{{ last }}&lrm;</span>
97
- </span>
98
-
99
- <span
100
- v-else
101
- v-gl-tooltip="{ disabled: isTooltipDisabled }"
102
- v-gl-resize-observer:[withTooltip]="checkTruncationState"
103
- class="gl-truncate-component"
104
- data-testid="truncate-end-container"
105
- :title="text"
106
- >
107
- <span ref="text" class="gl-truncate-end">{{ text }}</span>
108
- </span>
109
- </template>
@@ -1,5 +0,0 @@
1
- export const STATES = {
2
- INITIAL: 'initial',
3
- TRUNCATED: 'truncated',
4
- EXTENDED: 'extended',
5
- };
@@ -1,26 +0,0 @@
1
- The `GlTruncateText` component lets you truncate a large text by number of lines.
2
- The last line ends with an ellipsis if the text is truncated.
3
- Truncation can be toggled by a 'Show more' / 'Show less' button.
4
- The button will not be shown when no truncation is necessary.
5
- There is a separate property to set the number of lines initially shown on small screens.
6
- Use the `showMoreText` and `showLessText` properties to provide translated strings.
7
-
8
- > **Tip:** Try resizing the side panel to see the truncated number of lines change.
9
-
10
- ## Usage
11
-
12
- ```html
13
- <gl-truncate-text :show-more-text="__('Show more')" :show-less-text="__('Show less')" :lines="3" :mobile-lines="10">
14
- {{ largeText }}
15
- </gl-truncate-text>
16
- ```
17
-
18
- ## Usage caveats
19
-
20
- When the size of the window is large,
21
- and the text is displayed on a number of lines greater than the value of the `lines` property,
22
- but smaller than the value of the `mobileLines` property,
23
- and the `Show more` button has been clicked to show the entire content of the text,
24
- and the window is resized to a small size,
25
- then instead of disappearing,
26
- the `Show less` button will remain visible and will do nothing when clicked.
@@ -1,14 +0,0 @@
1
- /**
2
- Note: although vendor-prefixes are used here, these properties are supported by all browsers.
3
- See https://caniuse.com/css-line-clamp
4
- **/
5
- .gl-truncate-text {
6
- // stylelint-disable-next-line value-no-vendor-prefix
7
- display: -webkit-box;
8
- -webkit-line-clamp: var(--mobile-lines);
9
- -webkit-box-orient: vertical;
10
-
11
- @include gl-media-breakpoint-up(sm) {
12
- -webkit-line-clamp: var(--lines);
13
- }
14
- }