@gitlab/ui 131.2.0 → 131.3.1

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 (402) hide show
  1. package/package.json +11 -11
  2. package/src/components/base/form/form_checkbox/form_checkbox.vue +1 -2
  3. package/src/components/base/form/form_checkbox/form_checkbox_group.vue +1 -1
  4. package/src/components/base/form/form_radio/form_radio.vue +1 -1
  5. package/src/components/base/form/form_radio_group/form_radio_group.vue +1 -1
  6. package/src/components/base/table/table.scss +8 -0
  7. package/src/components/utilities/truncate/truncate.scss +3 -1
  8. package/src/scss/mixins.scss +3 -1
  9. package/src/utils/equality_utils.js +82 -0
  10. package/src/vendor/bootstrap-vue/src/components/button/button-close.js +20 -5
  11. package/src/vendor/bootstrap-vue/src/components/button/button.js +36 -8
  12. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.js +12 -4
  13. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.js +16 -5
  14. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown.js +99 -24
  15. package/src/vendor/bootstrap-vue/src/components/form/form-text.js +20 -5
  16. package/src/vendor/bootstrap-vue/src/components/form/form.js +20 -5
  17. package/src/vendor/bootstrap-vue/src/components/layout/form-row.js +5 -2
  18. package/src/vendor/bootstrap-vue/src/components/table/tbody.js +10 -3
  19. package/src/vendor/bootstrap-vue/src/components/table/td.js +28 -7
  20. package/src/vendor/bootstrap-vue/src/components/table/tfoot.js +5 -2
  21. package/src/vendor/bootstrap-vue/src/components/table/thead.js +5 -2
  22. package/src/vendor/bootstrap-vue/src/components/table/tr.js +5 -2
  23. package/src/vendor/bootstrap-vue/src/components/tabs/tab.js +51 -12
  24. package/tailwind.defaults.js +10 -1
  25. package/dist/charts.js +0 -13
  26. package/dist/components/base/accordion/accordion.js +0 -69
  27. package/dist/components/base/accordion/accordion_item.js +0 -160
  28. package/dist/components/base/accordion/constants.js +0 -3
  29. package/dist/components/base/alert/alert.js +0 -263
  30. package/dist/components/base/animated_icon/animated_chevron_down_up_icon.js +0 -45
  31. package/dist/components/base/animated_icon/animated_chevron_lg_down_up_icon.js +0 -45
  32. package/dist/components/base/animated_icon/animated_chevron_lg_right_down_icon.js +0 -45
  33. package/dist/components/base/animated_icon/animated_chevron_right_down_icon.js +0 -45
  34. package/dist/components/base/animated_icon/animated_duo_chat_icon.js +0 -45
  35. package/dist/components/base/animated_icon/animated_loader_icon.js +0 -45
  36. package/dist/components/base/animated_icon/animated_notifications_icon.js +0 -45
  37. package/dist/components/base/animated_icon/animated_sidebar_icon.js +0 -45
  38. package/dist/components/base/animated_icon/animated_smile_icon.js +0 -45
  39. package/dist/components/base/animated_icon/animated_sort_icon.js +0 -45
  40. package/dist/components/base/animated_icon/animated_star_icon.js +0 -45
  41. package/dist/components/base/animated_icon/animated_todo_icon.js +0 -45
  42. package/dist/components/base/animated_icon/animated_upload_icon.js +0 -45
  43. package/dist/components/base/animated_icon/base_animated_icon.js +0 -77
  44. package/dist/components/base/attribute_list/attribute_list.js +0 -100
  45. package/dist/components/base/avatar/avatar.js +0 -175
  46. package/dist/components/base/avatar/utils.js +0 -17
  47. package/dist/components/base/avatar_labeled/avatar_labeled.js +0 -198
  48. package/dist/components/base/avatar_link/avatar_link.js +0 -47
  49. package/dist/components/base/avatars_inline/avatars_inline.js +0 -139
  50. package/dist/components/base/badge/badge.js +0 -197
  51. package/dist/components/base/banner/banner.js +0 -149
  52. package/dist/components/base/breadcrumb/breadcrumb.js +0 -282
  53. package/dist/components/base/breadcrumb/breadcrumb_item.js +0 -96
  54. package/dist/components/base/broadcast_message/broadcast_message.js +0 -113
  55. package/dist/components/base/broadcast_message/constants.js +0 -5
  56. package/dist/components/base/button/button.js +0 -419
  57. package/dist/components/base/button_group/button_group.js +0 -53
  58. package/dist/components/base/card/card.js +0 -69
  59. package/dist/components/base/collapse/collapse.js +0 -163
  60. package/dist/components/base/color_mode_toggle/color_mode_toggle.js +0 -92
  61. package/dist/components/base/datepicker/datepicker.js +0 -475
  62. package/dist/components/base/daterange_picker/daterange_picker.js +0 -394
  63. package/dist/components/base/drawer/drawer.js +0 -156
  64. package/dist/components/base/dropdown/dropdown.js +0 -330
  65. package/dist/components/base/dropdown/dropdown_divider.js +0 -48
  66. package/dist/components/base/dropdown/dropdown_form.js +0 -48
  67. package/dist/components/base/dropdown/dropdown_item.js +0 -175
  68. package/dist/components/base/dropdown/dropdown_section_header.js +0 -48
  69. package/dist/components/base/dropdown/dropdown_text.js +0 -48
  70. package/dist/components/base/filtered_search/common_story_options.js +0 -14
  71. package/dist/components/base/filtered_search/filtered_search.js +0 -428
  72. package/dist/components/base/filtered_search/filtered_search_suggestion.js +0 -95
  73. package/dist/components/base/filtered_search/filtered_search_suggestion_list.js +0 -139
  74. package/dist/components/base/filtered_search/filtered_search_term.js +0 -217
  75. package/dist/components/base/filtered_search/filtered_search_token.js +0 -383
  76. package/dist/components/base/filtered_search/filtered_search_token_segment.js +0 -444
  77. package/dist/components/base/filtered_search/filtered_search_utils.js +0 -241
  78. package/dist/components/base/form/form.js +0 -43
  79. package/dist/components/base/form/form_character_count/form_character_count.js +0 -107
  80. package/dist/components/base/form/form_checkbox/form_checkbox.js +0 -343
  81. package/dist/components/base/form/form_checkbox/form_checkbox_group.js +0 -186
  82. package/dist/components/base/form/form_combobox/constants.js +0 -55
  83. package/dist/components/base/form/form_combobox/form_combobox.js +0 -239
  84. package/dist/components/base/form/form_date/form_date.js +0 -143
  85. package/dist/components/base/form/form_fields/form_field_validator.js +0 -93
  86. package/dist/components/base/form/form_fields/form_fields.js +0 -289
  87. package/dist/components/base/form/form_fields/form_fields_loop.js +0 -75
  88. package/dist/components/base/form/form_fields/mappers.js +0 -13
  89. package/dist/components/base/form/form_fields/validators.js +0 -48
  90. package/dist/components/base/form/form_group/form_group.js +0 -119
  91. package/dist/components/base/form/form_input/form_input.js +0 -695
  92. package/dist/components/base/form/form_input_group/form_input_group.js +0 -120
  93. package/dist/components/base/form/form_input_group/form_input_group_mixin.js +0 -41
  94. package/dist/components/base/form/form_radio/form_radio.js +0 -259
  95. package/dist/components/base/form/form_radio_group/form_radio_group.js +0 -187
  96. package/dist/components/base/form/form_select/constants.js +0 -12
  97. package/dist/components/base/form/form_select/form_select.js +0 -96
  98. package/dist/components/base/form/form_textarea/form_textarea.js +0 -166
  99. package/dist/components/base/form/input_group_text/input_group_text.js +0 -43
  100. package/dist/components/base/icon/icon.js +0 -113
  101. package/dist/components/base/illustration/illustration.js +0 -80
  102. package/dist/components/base/infinite_scroll/infinite_scroll.js +0 -196
  103. package/dist/components/base/keyset_pagination/keyset_pagination.js +0 -152
  104. package/dist/components/base/label/label.js +0 -174
  105. package/dist/components/base/link/link.js +0 -332
  106. package/dist/components/base/loading_icon/loading_icon.js +0 -120
  107. package/dist/components/base/markdown/markdown.js +0 -50
  108. package/dist/components/base/modal/modal.js +0 -259
  109. package/dist/components/base/new_dropdowns/base_dropdown/base_dropdown.js +0 -716
  110. package/dist/components/base/new_dropdowns/base_dropdown/constants.js +0 -5
  111. package/dist/components/base/new_dropdowns/base_dropdown/dropdown_container.js +0 -32
  112. package/dist/components/base/new_dropdowns/constants.js +0 -24
  113. package/dist/components/base/new_dropdowns/disclosure/constants.js +0 -8
  114. package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown.js +0 -400
  115. package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown_group.js +0 -112
  116. package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown_item.js +0 -196
  117. package/dist/components/base/new_dropdowns/disclosure/mock_data.js +0 -168
  118. package/dist/components/base/new_dropdowns/disclosure/utils.js +0 -84
  119. package/dist/components/base/new_dropdowns/listbox/listbox.js +0 -997
  120. package/dist/components/base/new_dropdowns/listbox/listbox_group.js +0 -58
  121. package/dist/components/base/new_dropdowns/listbox/listbox_item.js +0 -112
  122. package/dist/components/base/new_dropdowns/listbox/listbox_search_input.js +0 -94
  123. package/dist/components/base/new_dropdowns/listbox/mock_data.js +0 -131
  124. package/dist/components/base/new_dropdowns/listbox/utils.js +0 -33
  125. package/dist/components/base/pagination/pagination.js +0 -397
  126. package/dist/components/base/path/data.js +0 -34
  127. package/dist/components/base/path/path.js +0 -177
  128. package/dist/components/base/popover/popover.js +0 -142
  129. package/dist/components/base/progress_bar/progress_bar.js +0 -117
  130. package/dist/components/base/search_box_by_click/search_box_by_click.js +0 -245
  131. package/dist/components/base/search_box_by_type/search_box_by_type.js +0 -187
  132. package/dist/components/base/segmented_control/segmented_control.js +0 -73
  133. package/dist/components/base/skeleton_loader/skeleton_loader.js +0 -232
  134. package/dist/components/base/sorting/sorting.js +0 -180
  135. package/dist/components/base/table/constants.js +0 -5
  136. package/dist/components/base/table/table.js +0 -187
  137. package/dist/components/base/table_lite/table_lite.js +0 -80
  138. package/dist/components/base/tabs/constants.js +0 -3
  139. package/dist/components/base/tabs/tab/tab.js +0 -113
  140. package/dist/components/base/tabs/tabs/scrollable_tabs.js +0 -162
  141. package/dist/components/base/tabs/tabs/tabs.js +0 -223
  142. package/dist/components/base/toast/index.js +0 -66
  143. package/dist/components/base/toast/toast.js +0 -125
  144. package/dist/components/base/toast/toaster.js +0 -87
  145. package/dist/components/base/toggle/toggle.js +0 -178
  146. package/dist/components/base/token/token.js +0 -97
  147. package/dist/components/base/token_selector/helpers.js +0 -5
  148. package/dist/components/base/token_selector/token_container.js +0 -160
  149. package/dist/components/base/token_selector/token_selector.js +0 -454
  150. package/dist/components/base/token_selector/token_selector_dropdown.js +0 -223
  151. package/dist/components/base/tooltip/tooltip.js +0 -54
  152. package/dist/components/charts/area/area.js +0 -329
  153. package/dist/components/charts/bar/bar.js +0 -207
  154. package/dist/components/charts/chart/chart.js +0 -215
  155. package/dist/components/charts/column/column.js +0 -221
  156. package/dist/components/charts/discrete_scatter/discrete_scatter.js +0 -199
  157. package/dist/components/charts/gauge/gauge.js +0 -205
  158. package/dist/components/charts/heatmap/heatmap.js +0 -299
  159. package/dist/components/charts/heatmap/index.js +0 -2
  160. package/dist/components/charts/legend/legend.js +0 -245
  161. package/dist/components/charts/line/line.js +0 -340
  162. package/dist/components/charts/series_label/series_label.js +0 -101
  163. package/dist/components/charts/shared/tooltip/tooltip.js +0 -369
  164. package/dist/components/charts/shared/tooltip/tooltip_default_format/tooltip_default_format.js +0 -53
  165. package/dist/components/charts/single_stat/single_stat.js +0 -164
  166. package/dist/components/charts/sparkline/sparkline.js +0 -299
  167. package/dist/components/charts/stacked_column/stacked_column.js +0 -380
  168. package/dist/components/dashboards/dashboard_layout/dashboard_layout.js +0 -125
  169. package/dist/components/dashboards/dashboard_layout/grid_layout/grid_layout.js +0 -326
  170. package/dist/components/dashboards/dashboard_layout/validators.js +0 -14
  171. package/dist/components/dashboards/dashboard_panel/dashboard_panel.js +0 -236
  172. package/dist/components/dashboards/mock_data.js +0 -49
  173. package/dist/components/experimental/experiment_badge/constants.js +0 -4
  174. package/dist/components/experimental/experiment_badge/experiment_badge.js +0 -102
  175. package/dist/components/extended/multi_step_form_template/multi_step_form_template.js +0 -87
  176. package/dist/components/index.js +0 -107
  177. package/dist/components/mixins/button_mixin.js +0 -11
  178. package/dist/components/mixins/safe_link_mixin.js +0 -30
  179. package/dist/components/mixins/tooltip_mixin.js +0 -21
  180. package/dist/components/regions/dashboard_skeleton/dashboard_skeleton.js +0 -53
  181. package/dist/components/regions/empty_state/empty_state.js +0 -181
  182. package/dist/components/shared_components/clear_icon_button/clear_icon_button.js +0 -64
  183. package/dist/components/shared_components/clipboard_button/clipboard_button.js +0 -100
  184. package/dist/components/shared_components/close_button/close_button.js +0 -55
  185. package/dist/components/utilities/animated_number/animated_number.js +0 -131
  186. package/dist/components/utilities/friendly_wrap/friendly_wrap.js +0 -75
  187. package/dist/components/utilities/intersection_observer/intersection_observer.js +0 -88
  188. package/dist/components/utilities/intersperse/intersperse.js +0 -104
  189. package/dist/components/utilities/sprintf/sprintf.js +0 -171
  190. package/dist/components/utilities/truncate/constants.js +0 -8
  191. package/dist/components/utilities/truncate/truncate.js +0 -154
  192. package/dist/components/utilities/truncate_text/constants.js +0 -7
  193. package/dist/components/utilities/truncate_text/truncate_text.js +0 -146
  194. package/dist/config.js +0 -53
  195. package/dist/directives/hover_load/hover_load.js +0 -45
  196. package/dist/directives/index.js +0 -8
  197. package/dist/directives/modal.js +0 -1
  198. package/dist/directives/outside/outside.js +0 -149
  199. package/dist/directives/resize_observer/resize_observer.js +0 -58
  200. package/dist/directives/safe_html/constants.js +0 -6
  201. package/dist/directives/safe_html/safe_html.js +0 -39
  202. package/dist/directives/safe_link/mock_data.js +0 -10
  203. package/dist/directives/safe_link/safe_link.js +0 -67
  204. package/dist/directives/tooltip/container.js +0 -7
  205. package/dist/directives/tooltip/tooltip.js +0 -18
  206. package/dist/index.css +0 -7
  207. package/dist/index.css.map +0 -1
  208. package/dist/index.js +0 -2
  209. package/dist/tailwind.css +0 -2
  210. package/dist/tailwind.css.map +0 -1
  211. package/dist/tokens/build/js/tokens.dark.js +0 -1410
  212. package/dist/tokens/build/js/tokens.js +0 -1410
  213. package/dist/tokens/common_story_options.js +0 -29
  214. package/dist/tokens/tokens_story.js +0 -76
  215. package/dist/utils/breakpoints.js +0 -20
  216. package/dist/utils/charts/config.js +0 -616
  217. package/dist/utils/charts/constants.js +0 -69
  218. package/dist/utils/charts/mock_data.js +0 -191
  219. package/dist/utils/charts/story_config.js +0 -24
  220. package/dist/utils/charts/theme.js +0 -200
  221. package/dist/utils/charts/utils.js +0 -54
  222. package/dist/utils/constants.js +0 -333
  223. package/dist/utils/data_utils.js +0 -19
  224. package/dist/utils/datetime_utility.js +0 -61
  225. package/dist/utils/i18n.js +0 -65
  226. package/dist/utils/is_slot_empty.js +0 -34
  227. package/dist/utils/number_utils.js +0 -132
  228. package/dist/utils/play_utils.js +0 -11
  229. package/dist/utils/set_utils.js +0 -25
  230. package/dist/utils/stories_constants.js +0 -29
  231. package/dist/utils/stories_utils.js +0 -62
  232. package/dist/utils/story_decorators/container.js +0 -19
  233. package/dist/utils/string_utils.js +0 -69
  234. package/dist/utils/svgs/svg_paths.js +0 -7
  235. package/dist/utils/test_utils.js +0 -33
  236. package/dist/utils/use_fake_date.js +0 -29
  237. package/dist/utils/use_mock_intersection_observer.js +0 -105
  238. package/dist/utils/utils.js +0 -205
  239. package/dist/utils.js +0 -5
  240. package/dist/vendor/bootstrap-vue/src/bv-config.js +0 -8
  241. package/dist/vendor/bootstrap-vue/src/components/button/button-close.js +0 -66
  242. package/dist/vendor/bootstrap-vue/src/components/button/button.js +0 -176
  243. package/dist/vendor/bootstrap-vue/src/components/button/index.js +0 -2
  244. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-divider.js +0 -41
  245. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-form.js +0 -52
  246. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-group.js +0 -75
  247. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-header.js +0 -52
  248. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-item-button.js +0 -85
  249. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.js +0 -89
  250. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.js +0 -49
  251. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown.js +0 -195
  252. package/dist/vendor/bootstrap-vue/src/components/dropdown/index.js +0 -8
  253. package/dist/vendor/bootstrap-vue/src/components/form/form-invalid-feedback.js +0 -53
  254. package/dist/vendor/bootstrap-vue/src/components/form/form-text.js +0 -40
  255. package/dist/vendor/bootstrap-vue/src/components/form/form-valid-feedback.js +0 -53
  256. package/dist/vendor/bootstrap-vue/src/components/form/form.js +0 -41
  257. package/dist/vendor/bootstrap-vue/src/components/form/index.js +0 -4
  258. package/dist/vendor/bootstrap-vue/src/components/form-group/form-group.js +0 -348
  259. package/dist/vendor/bootstrap-vue/src/components/form-group/index.js +0 -1
  260. package/dist/vendor/bootstrap-vue/src/components/form-select/form-select-option-group.js +0 -54
  261. package/dist/vendor/bootstrap-vue/src/components/form-select/form-select-option.js +0 -41
  262. package/dist/vendor/bootstrap-vue/src/components/form-select/form-select.js +0 -143
  263. package/dist/vendor/bootstrap-vue/src/components/form-select/helpers/mixin-options.js +0 -56
  264. package/dist/vendor/bootstrap-vue/src/components/form-select/index.js +0 -3
  265. package/dist/vendor/bootstrap-vue/src/components/form-textarea/form-textarea.js +0 -217
  266. package/dist/vendor/bootstrap-vue/src/components/form-textarea/index.js +0 -1
  267. package/dist/vendor/bootstrap-vue/src/components/layout/col.js +0 -156
  268. package/dist/vendor/bootstrap-vue/src/components/layout/form-row.js +0 -31
  269. package/dist/vendor/bootstrap-vue/src/components/layout/index.js +0 -2
  270. package/dist/vendor/bootstrap-vue/src/components/link/index.js +0 -1
  271. package/dist/vendor/bootstrap-vue/src/components/link/link.js +0 -283
  272. package/dist/vendor/bootstrap-vue/src/components/modal/helpers/bv-modal-event.class.js +0 -21
  273. package/dist/vendor/bootstrap-vue/src/components/modal/helpers/modal-manager.js +0 -212
  274. package/dist/vendor/bootstrap-vue/src/components/modal/index.js +0 -1
  275. package/dist/vendor/bootstrap-vue/src/components/modal/modal.js +0 -887
  276. package/dist/vendor/bootstrap-vue/src/components/popover/helpers/bv-popover-template.js +0 -55
  277. package/dist/vendor/bootstrap-vue/src/components/popover/helpers/bv-popover.js +0 -31
  278. package/dist/vendor/bootstrap-vue/src/components/popover/index.js +0 -1
  279. package/dist/vendor/bootstrap-vue/src/components/popover/popover.js +0 -49
  280. package/dist/vendor/bootstrap-vue/src/components/table/helpers/constants.js +0 -22
  281. package/dist/vendor/bootstrap-vue/src/components/table/helpers/default-sort-compare.js +0 -64
  282. package/dist/vendor/bootstrap-vue/src/components/table/helpers/filter-event.js +0 -40
  283. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-bottom-row.js +0 -43
  284. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-busy.js +0 -83
  285. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-caption.js +0 -50
  286. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-colgroup.js +0 -32
  287. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-empty.js +0 -82
  288. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-filtering.js +0 -274
  289. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-items.js +0 -154
  290. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-pagination.js +0 -44
  291. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-provider.js +0 -191
  292. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-selectable.js +0 -213
  293. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-sorting.js +0 -275
  294. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-stacked.js +0 -39
  295. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-table-renderer.js +0 -186
  296. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tbody-row.js +0 -338
  297. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tbody.js +0 -243
  298. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tfoot.js +0 -50
  299. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-thead.js +0 -218
  300. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-top-row.js +0 -42
  301. package/dist/vendor/bootstrap-vue/src/components/table/helpers/normalize-fields.js +0 -86
  302. package/dist/vendor/bootstrap-vue/src/components/table/helpers/sanitize-row.js +0 -32
  303. package/dist/vendor/bootstrap-vue/src/components/table/helpers/stringify-record-values.js +0 -11
  304. package/dist/vendor/bootstrap-vue/src/components/table/helpers/text-selection-active.js +0 -14
  305. package/dist/vendor/bootstrap-vue/src/components/table/index.js +0 -9
  306. package/dist/vendor/bootstrap-vue/src/components/table/table-lite.js +0 -51
  307. package/dist/vendor/bootstrap-vue/src/components/table/table-simple.js +0 -44
  308. package/dist/vendor/bootstrap-vue/src/components/table/table.js +0 -67
  309. package/dist/vendor/bootstrap-vue/src/components/table/tbody.js +0 -109
  310. package/dist/vendor/bootstrap-vue/src/components/table/td.js +0 -183
  311. package/dist/vendor/bootstrap-vue/src/components/table/tfoot.js +0 -93
  312. package/dist/vendor/bootstrap-vue/src/components/table/th.js +0 -26
  313. package/dist/vendor/bootstrap-vue/src/components/table/thead.js +0 -96
  314. package/dist/vendor/bootstrap-vue/src/components/table/tr.js +0 -118
  315. package/dist/vendor/bootstrap-vue/src/components/tabs/index.js +0 -2
  316. package/dist/vendor/bootstrap-vue/src/components/tabs/tab.js +0 -199
  317. package/dist/vendor/bootstrap-vue/src/components/tabs/tabs.js +0 -601
  318. package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-popper.js +0 -251
  319. package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip-template.js +0 -118
  320. package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip.js +0 -932
  321. package/dist/vendor/bootstrap-vue/src/components/tooltip/index.js +0 -1
  322. package/dist/vendor/bootstrap-vue/src/components/tooltip/tooltip.js +0 -269
  323. package/dist/vendor/bootstrap-vue/src/components/transition/bv-transition.js +0 -103
  324. package/dist/vendor/bootstrap-vue/src/components/transporter/transporter.js +0 -205
  325. package/dist/vendor/bootstrap-vue/src/constants/components.js +0 -55
  326. package/dist/vendor/bootstrap-vue/src/constants/config.js +0 -11
  327. package/dist/vendor/bootstrap-vue/src/constants/env.js +0 -36
  328. package/dist/vendor/bootstrap-vue/src/constants/events.js +0 -56
  329. package/dist/vendor/bootstrap-vue/src/constants/key-codes.js +0 -11
  330. package/dist/vendor/bootstrap-vue/src/constants/popper.js +0 -10
  331. package/dist/vendor/bootstrap-vue/src/constants/props.js +0 -24
  332. package/dist/vendor/bootstrap-vue/src/constants/regex.js +0 -35
  333. package/dist/vendor/bootstrap-vue/src/constants/safe-types.js +0 -15
  334. package/dist/vendor/bootstrap-vue/src/constants/slots.js +0 -36
  335. package/dist/vendor/bootstrap-vue/src/directives/modal/index.js +0 -1
  336. package/dist/vendor/bootstrap-vue/src/directives/modal/modal.js +0 -112
  337. package/dist/vendor/bootstrap-vue/src/directives/tooltip/index.js +0 -1
  338. package/dist/vendor/bootstrap-vue/src/directives/tooltip/tooltip.js +0 -265
  339. package/dist/vendor/bootstrap-vue/src/directives/visible/index.js +0 -1
  340. package/dist/vendor/bootstrap-vue/src/directives/visible/visible.js +0 -187
  341. package/dist/vendor/bootstrap-vue/src/mixins/attrs.js +0 -5
  342. package/dist/vendor/bootstrap-vue/src/mixins/click-out.js +0 -54
  343. package/dist/vendor/bootstrap-vue/src/mixins/dropdown.js +0 -470
  344. package/dist/vendor/bootstrap-vue/src/mixins/focus-in.js +0 -46
  345. package/dist/vendor/bootstrap-vue/src/mixins/form-control.js +0 -73
  346. package/dist/vendor/bootstrap-vue/src/mixins/form-custom.js +0 -26
  347. package/dist/vendor/bootstrap-vue/src/mixins/form-options.js +0 -91
  348. package/dist/vendor/bootstrap-vue/src/mixins/form-selection.js +0 -62
  349. package/dist/vendor/bootstrap-vue/src/mixins/form-size.js +0 -26
  350. package/dist/vendor/bootstrap-vue/src/mixins/form-state.js +0 -50
  351. package/dist/vendor/bootstrap-vue/src/mixins/form-text.js +0 -293
  352. package/dist/vendor/bootstrap-vue/src/mixins/form-validity.js +0 -50
  353. package/dist/vendor/bootstrap-vue/src/mixins/has-listener.js +0 -29
  354. package/dist/vendor/bootstrap-vue/src/mixins/id.js +0 -57
  355. package/dist/vendor/bootstrap-vue/src/mixins/listen-on-document.js +0 -63
  356. package/dist/vendor/bootstrap-vue/src/mixins/listen-on-root.js +0 -121
  357. package/dist/vendor/bootstrap-vue/src/mixins/listen-on-window.js +0 -63
  358. package/dist/vendor/bootstrap-vue/src/mixins/listeners.js +0 -25
  359. package/dist/vendor/bootstrap-vue/src/mixins/model.js +0 -10
  360. package/dist/vendor/bootstrap-vue/src/mixins/normalize-slot.js +0 -30
  361. package/dist/vendor/bootstrap-vue/src/mixins/scoped-style.js +0 -18
  362. package/dist/vendor/bootstrap-vue/src/mixins/use-parent.js +0 -14
  363. package/dist/vendor/bootstrap-vue/src/utils/array.js +0 -28
  364. package/dist/vendor/bootstrap-vue/src/utils/bv-event.class.js +0 -60
  365. package/dist/vendor/bootstrap-vue/src/utils/cache.js +0 -60
  366. package/dist/vendor/bootstrap-vue/src/utils/clone-deep.js +0 -18
  367. package/dist/vendor/bootstrap-vue/src/utils/config-set.js +0 -86
  368. package/dist/vendor/bootstrap-vue/src/utils/config.js +0 -71
  369. package/dist/vendor/bootstrap-vue/src/utils/create-new-child-component.js +0 -133
  370. package/dist/vendor/bootstrap-vue/src/utils/css-escape.js +0 -70
  371. package/dist/vendor/bootstrap-vue/src/utils/dom.js +0 -298
  372. package/dist/vendor/bootstrap-vue/src/utils/element-to-vue-instance-registry.js +0 -28
  373. package/dist/vendor/bootstrap-vue/src/utils/env.js +0 -16
  374. package/dist/vendor/bootstrap-vue/src/utils/events.js +0 -78
  375. package/dist/vendor/bootstrap-vue/src/utils/get-event-root.js +0 -5
  376. package/dist/vendor/bootstrap-vue/src/utils/get-instance-from-directive.js +0 -3
  377. package/dist/vendor/bootstrap-vue/src/utils/get-scope-id.js +0 -9
  378. package/dist/vendor/bootstrap-vue/src/utils/get.js +0 -63
  379. package/dist/vendor/bootstrap-vue/src/utils/html.js +0 -16
  380. package/dist/vendor/bootstrap-vue/src/utils/identity.js +0 -3
  381. package/dist/vendor/bootstrap-vue/src/utils/inspect.js +0 -35
  382. package/dist/vendor/bootstrap-vue/src/utils/locale.js +0 -19
  383. package/dist/vendor/bootstrap-vue/src/utils/loose-equal.js +0 -59
  384. package/dist/vendor/bootstrap-vue/src/utils/loose-index-of.js +0 -13
  385. package/dist/vendor/bootstrap-vue/src/utils/math.js +0 -9
  386. package/dist/vendor/bootstrap-vue/src/utils/memoize.js +0 -14
  387. package/dist/vendor/bootstrap-vue/src/utils/model.js +0 -33
  388. package/dist/vendor/bootstrap-vue/src/utils/noop.js +0 -3
  389. package/dist/vendor/bootstrap-vue/src/utils/normalize-slot.js +0 -51
  390. package/dist/vendor/bootstrap-vue/src/utils/number.js +0 -23
  391. package/dist/vendor/bootstrap-vue/src/utils/object.js +0 -72
  392. package/dist/vendor/bootstrap-vue/src/utils/observe-dom.js +0 -76
  393. package/dist/vendor/bootstrap-vue/src/utils/on-instance-destroy.js +0 -22
  394. package/dist/vendor/bootstrap-vue/src/utils/plugins.js +0 -124
  395. package/dist/vendor/bootstrap-vue/src/utils/props.js +0 -67
  396. package/dist/vendor/bootstrap-vue/src/utils/router.js +0 -150
  397. package/dist/vendor/bootstrap-vue/src/utils/safe-vue-instance.js +0 -14
  398. package/dist/vendor/bootstrap-vue/src/utils/stable-sort.js +0 -28
  399. package/dist/vendor/bootstrap-vue/src/utils/string.js +0 -47
  400. package/dist/vendor/bootstrap-vue/src/utils/stringify-object-values.js +0 -31
  401. package/dist/vendor/bootstrap-vue/src/utils/warn.js +0 -45
  402. package/dist/vendor/bootstrap-vue/src/vue.js +0 -55
@@ -1,454 +0,0 @@
1
- import { uniqueId } from 'lodash-es';
2
- import { logWarning } from '../../../utils/utils';
3
- import { tokensValidator } from './helpers';
4
- import GlTokenContainer from './token_container';
5
- import GlTokenSelectorDropdown from './token_selector_dropdown';
6
- import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js';
7
-
8
- var script = {
9
- name: 'GlTokenSelector',
10
- components: {
11
- GlTokenContainer,
12
- GlTokenSelectorDropdown
13
- },
14
- model: {
15
- prop: 'selectedTokens',
16
- event: 'input'
17
- },
18
- props: {
19
- /**
20
- * Items to display in dropdown
21
- */
22
- dropdownItems: {
23
- type: Array,
24
- // All items need to have an `id` key
25
- validator: tokensValidator,
26
- required: false,
27
- default: () => []
28
- },
29
- /**
30
- * Should users be allowed to add tokens that are not in `dropdown-items`
31
- */
32
- allowUserDefinedTokens: {
33
- type: Boolean,
34
- required: false,
35
- default: false
36
- },
37
- /**
38
- * Shows "Add new token option" in dropdown even if results are present. Requires `allowUserDefinedTokens` to be `true`.
39
- */
40
- showAddNewAlways: {
41
- type: Boolean,
42
- required: false,
43
- default: false
44
- },
45
- /**
46
- * Dropdown items are loading, can be used when requesting new dropdown items
47
- */
48
- loading: {
49
- type: Boolean,
50
- required: false,
51
- default: false
52
- },
53
- /**
54
- * Hide the dropdown if `dropdown-items` is empty. Will show `no-results-content` slot if this is `false`
55
- */
56
- hideDropdownWithNoItems: {
57
- type: Boolean,
58
- required: false,
59
- default: false
60
- },
61
- /**
62
- * CSS classes to add to the main token selector container (`.gl-token-selector`)
63
- */
64
- containerClass: {
65
- type: String,
66
- required: false,
67
- default: ''
68
- },
69
- /**
70
- * CSS classes to add to dropdown menu `ul` element
71
- */
72
- menuClass: {
73
- type: [String, Array, Object],
74
- required: false,
75
- default: ''
76
- },
77
- /**
78
- * The HTML5 autocomplete attribute value for the underlying `input` element.
79
- */
80
- autocomplete: {
81
- type: String,
82
- required: false,
83
- default: 'off'
84
- },
85
- /**
86
- * The `aria-label` attribute value for the underlying `input` element.
87
- * Input must have an `aria-label` or `aria-labelledby` prop or it will be inaccessible.
88
- *
89
- * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Reference/Attributes/aria-label
90
- */
91
- ariaLabel: {
92
- type: String,
93
- required: false,
94
- default: null
95
- },
96
- /**
97
- * The `aria-labelledby` attribute value for the underlying `input` element.
98
- * String must match the unique ID on a text element to create an accessible label.
99
- *
100
- * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Reference/Attributes/aria-labelledby
101
- */
102
- ariaLabelledby: {
103
- type: String,
104
- required: false,
105
- default: null
106
- },
107
- /**
108
- * The `placeholder` attribute value for the underlying `input` element
109
- */
110
- placeholder: {
111
- type: String,
112
- required: false,
113
- default: null
114
- },
115
- /**
116
- * HTML attributes to add to the text input. Helpful for adding `data-testid` and similar attributes.
117
- * Do not pass `aria-label` or `aria-labelledby` into this object. Use `ariaLabel` or `ariaLabelledby` prop instead.
118
- */
119
- textInputAttrs: {
120
- type: Object,
121
- required: false,
122
- default: null
123
- },
124
- /**
125
- * Controls the validation state appearance of the component. `true` for valid, `false` for invalid, or `null` for no validation state
126
- */
127
- state: {
128
- type: Boolean,
129
- required: false,
130
- default: null
131
- },
132
- /**
133
- * Tokens that are selected. This prop will automatically be added when using `v-model`
134
- */
135
- selectedTokens: {
136
- type: Array,
137
- // All tokens need to have an `id` key
138
- validator: tokensValidator,
139
- required: true
140
- },
141
- /**
142
- * Controls the `view-only` mode for the tokens
143
- */
144
- viewOnly: {
145
- type: Boolean,
146
- required: false,
147
- default: false
148
- },
149
- /**
150
- * Allows user to bulk delete tokens when enabled
151
- */
152
- allowClearAll: {
153
- type: Boolean,
154
- required: false,
155
- default: false
156
- }
157
- },
158
- data() {
159
- return {
160
- inputText: '',
161
- inputFocused: false,
162
- dropdownIsOpen: false,
163
- focusedDropdownItem: null,
164
- triggerTokenFocusNextBackspace: true,
165
- rootElClasses: '',
166
- dropdownEventHandlers: {
167
- handleUpArrow: () => {},
168
- handleDownArrow: () => {},
169
- handleHomeKey: () => {},
170
- handleEndKey: () => {}
171
- },
172
- resetFocusedDropdownItem: () => {},
173
- focusOnToken: () => {}
174
- };
175
- },
176
- computed: {
177
- filteredDropdownItems() {
178
- return this.dropdownItems.filter(dropdownItem => this.selectedTokens.findIndex(token => token.id === dropdownItem.id) === -1);
179
- },
180
- dropdownHasNoItems() {
181
- return !this.filteredDropdownItems.length;
182
- },
183
- userDefinedTokenCanBeAdded() {
184
- if (!this.allowUserDefinedTokens || !this.inputText) {
185
- return false;
186
- }
187
- return this.showAddNewAlways || this.dropdownHasNoItems;
188
- },
189
- hideDropdown() {
190
- if (this.userDefinedTokenCanBeAdded) {
191
- return false;
192
- }
193
- if (this.hideDropdownWithNoItems && this.dropdownHasNoItems) {
194
- return true;
195
- }
196
- return false;
197
- },
198
- stateClass() {
199
- switch (this.state) {
200
- case true:
201
- return 'is-valid';
202
- case false:
203
- return 'is-invalid';
204
- default:
205
- return '';
206
- }
207
- },
208
- hasSelectedTokens() {
209
- return this.selectedTokens.length > 0;
210
- },
211
- showEmptyPlaceholder() {
212
- return !this.hasSelectedTokens && !this.inputFocused;
213
- },
214
- showClearAllButton() {
215
- return this.hasSelectedTokens && this.allowClearAll;
216
- }
217
- },
218
- watch: {
219
- inputText(newValue, oldValue) {
220
- if (newValue !== oldValue) {
221
- /**
222
- * Fired when user types in the token selector
223
- *
224
- * @property {string} inputText
225
- */
226
- this.$emit('text-input', newValue);
227
- this.resetFocusedDropdownItem();
228
- if (newValue !== '') {
229
- this.triggerTokenFocusNextBackspace = false;
230
- } else {
231
- this.triggerTokenFocusNextBackspace = true;
232
- }
233
-
234
- // Wait a tick so `text-input` event can be used to validate
235
- // the value and change the `allowUserDefinedTokens` and/or
236
- // `hideDropdownWithNoItems` props
237
- this.$nextTick(() => {
238
- if (this.hideDropdown) {
239
- this.closeDropdown();
240
- } else if (newValue !== '') {
241
- this.openDropdown();
242
- }
243
- });
244
- }
245
- }
246
- },
247
- created() {
248
- // Each instance must have a unique ID for proper ARIA relationships
249
- this.uniqueId = uniqueId('token-selector-');
250
- },
251
- mounted() {
252
- var _this$textInputAttrs;
253
- const hasLabel = this.ariaLabel || ((_this$textInputAttrs = this.textInputAttrs) === null || _this$textInputAttrs === void 0 ? void 0 : _this$textInputAttrs['aria-label']) || this.ariaLabelledby;
254
- if (!hasLabel) {
255
- logWarning('The text input needs an accessible label. ' + 'Provide an `id` and a sibling `<label>` with a `for` attribute. Or add an `aria-labelledby` or `aria-label` prop to ensure the component is accessible. ' + 'See https://design.gitlab.com/components/token/#accessibility', {
256
- name: 'GlTokenSelector'
257
- });
258
- }
259
- },
260
- methods: {
261
- handleFocus(event) {
262
- /**
263
- * Fired when the token selector is focused
264
- *
265
- * @property {FocusEvent} event
266
- */
267
- this.$emit('focus', event);
268
- this.openDropdown();
269
- this.inputFocused = true;
270
- this.focusOnToken();
271
- if (this.inputText === '') {
272
- this.triggerTokenFocusNextBackspace = true;
273
- }
274
- },
275
- handleBlur(event) {
276
- /**
277
- * Fired when the token selector is blurred
278
- *
279
- * @property {FocusEvent} event
280
- */
281
- this.$emit('blur', event);
282
- this.inputFocused = false;
283
-
284
- // `event.relatedTarget` returns `null` on Safari because buttons are not focused on click (https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button#Clicking_and_focus)
285
- // Workaround is to:
286
- // 1. Explicitly focus the dropdown menu item button on `mousedown` event. (see './token_selector_dropdown.vue')
287
- // 2. Use `nextTick` so `blur` event is fired after the `mousedown` event
288
- this.$nextTick(() => {
289
- var _event$relatedTarget, _event$relatedTarget$;
290
- if (!((_event$relatedTarget = event.relatedTarget) !== null && _event$relatedTarget !== void 0 && (_event$relatedTarget$ = _event$relatedTarget.closest) !== null && _event$relatedTarget$ !== void 0 && _event$relatedTarget$.call(_event$relatedTarget, '.dropdown-item'))) {
291
- this.closeDropdown();
292
- }
293
- });
294
- },
295
- handleEnter() {
296
- if (this.focusedDropdownItem && this.dropdownIsOpen) {
297
- this.addToken(this.focusedDropdownItem);
298
- }
299
- },
300
- handleEscape() {
301
- this.inputText = '';
302
- this.closeDropdown();
303
- },
304
- handleBackspace(event) {
305
- if (this.inputText !== '' || !this.selectedTokens.length) {
306
- return;
307
- }
308
-
309
- // Prevent triggering the browser back button
310
- event.preventDefault();
311
- if (this.triggerTokenFocusNextBackspace) {
312
- this.$refs.textInput.blur();
313
- this.focusOnToken(this.selectedTokens.length - 1);
314
- } else {
315
- this.triggerTokenFocusNextBackspace = true;
316
- }
317
- },
318
- handleInputClick() {
319
- // Open the dropdown if the user clicks an already focused input
320
- if (this.inputFocused && this.inputText === '' && !this.dropdownIsOpen) {
321
- this.openDropdown();
322
- }
323
- },
324
- handleContainerClick(event) {
325
- // Bail if token is clicked
326
- const {
327
- target
328
- } = event;
329
- if ((target === null || target === void 0 ? void 0 : target.closest('.gl-token')) !== null || this.inputFocused) {
330
- return;
331
- }
332
- this.focusTextInput();
333
- },
334
- addToken(dropdownItem) {
335
- /**
336
- * Fired when a token is added or removed
337
- *
338
- * @property {array} selectedTokens
339
- */
340
- this.$emit('input', [...this.selectedTokens, dropdownItem]);
341
- this.inputText = '';
342
- this.closeDropdown();
343
-
344
- /**
345
- * Fired when a token is added
346
- *
347
- * @property {object} token
348
- */
349
- this.$emit('token-add', dropdownItem);
350
- this.focusTextInput();
351
- },
352
- removeToken(token) {
353
- /**
354
- * Fired when a token is added or removed
355
- *
356
- * @property {array} selectedTokens
357
- */
358
- this.$emit('input', this.selectedTokens.filter(selectedToken => selectedToken.id !== token.id));
359
- /**
360
- * Fired when a token is removed
361
- *
362
- * @property {object} token
363
- */
364
- this.$emit('token-remove', token);
365
- },
366
- cancelTokenFocus() {
367
- this.focusTextInput();
368
- },
369
- closeDropdown() {
370
- this.dropdownIsOpen = false;
371
- this.resetFocusedDropdownItem();
372
- },
373
- openDropdown() {
374
- if (this.hideDropdown) {
375
- return;
376
- }
377
- this.dropdownIsOpen = true;
378
- },
379
- focusTextInput() {
380
- this.$refs.textInput.focus();
381
- },
382
- // Register methods passed as props from child components
383
- registerDropdownEventHandlers(dropdownEventHandlers) {
384
- this.dropdownEventHandlers = dropdownEventHandlers;
385
- },
386
- registerResetFocusedDropdownItem(resetFocusedDropdownItem) {
387
- this.resetFocusedDropdownItem = resetFocusedDropdownItem;
388
- },
389
- registerFocusOnToken(focusOnToken) {
390
- this.focusOnToken = focusOnToken;
391
- },
392
- clearAll() {
393
- this.$emit('input', []);
394
- this.focusTextInput();
395
- },
396
- handleAriaInvalid() {
397
- const {
398
- state
399
- } = this;
400
- return state === false ? 'true' : null;
401
- },
402
- handleAriaActiveDescendent(value) {
403
- return value ? `${this.uniqueId}-dropdown-item-${value.id}` : null;
404
- }
405
- }
406
- };
407
-
408
- /* script */
409
- const __vue_script__ = script;
410
-
411
- /* template */
412
- var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',[_c('div',{ref:"container",staticClass:"gl-token-selector gl-form-input gl-form-input-not-readonly form-control gl-flex !gl-cursor-text gl-items-center !gl-px-3 !gl-py-2",class:[
413
- {
414
- 'gl-token-selector-focus-glow': _vm.inputFocused,
415
- 'gl-token-selector-view-only': _vm.viewOnly,
416
- },
417
- _vm.containerClass,
418
- _vm.stateClass ],on:{"click":_vm.handleContainerClick}},[(_vm.showEmptyPlaceholder)?_vm._t("empty-placeholder"):_vm._e(),_vm._v(" "),_c('gl-token-container',{attrs:{"tokens":_vm.selectedTokens,"state":_vm.state,"register-focus-on-token":_vm.registerFocusOnToken,"view-only":_vm.viewOnly,"show-clear-all-button":_vm.showClearAllButton},on:{"token-remove":_vm.removeToken,"cancel-focus":_vm.cancelTokenFocus,"clear-all":_vm.clearAll},scopedSlots:_vm._u([{key:"token-content",fn:function(ref){
419
- var token = ref.token;
420
- return [_vm._t("token-content",null,{"token":token})]}},{key:"text-input",fn:function(){return [_c('input',_vm._b({ref:"textInput",staticClass:"gl-token-selector-input gl-h-auto gl-w-4/10 gl-grow gl-border-none gl-bg-transparent gl-px-1 gl-font-regular gl-text-base gl-leading-normal gl-text-default gl-outline-none",attrs:{"type":"text","aria-activedescendant":_vm.handleAriaActiveDescendent(_vm.focusedDropdownItem),"autocomplete":_vm.autocomplete,"aria-controls":_vm.uniqueId,"aria-expanded":_vm.dropdownIsOpen.toString(),"aria-invalid":_vm.handleAriaInvalid(),"aria-label":_vm.ariaLabelledby ? null : _vm.ariaLabel,"aria-labelledby":_vm.ariaLabelledby,"placeholder":_vm.placeholder,"disabled":_vm.viewOnly,"aria-autocomplete":"list","role":"combobox"},domProps:{"value":_vm.inputText},on:{"input":function($event){_vm.inputText = $event.target.value;},"focus":_vm.handleFocus,"blur":_vm.handleBlur,"keydown":[function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"enter",13,$event.key,"Enter")){ return null; }return _vm.handleEnter.apply(null, arguments)},function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"esc",27,$event.key,["Esc","Escape"])){ return null; }return _vm.handleEscape.apply(null, arguments)},function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"delete",[8,46],$event.key,["Backspace","Delete","Del"])){ return null; }return _vm.handleBackspace.apply(null, arguments)},function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"up",38,$event.key,["Up","ArrowUp"])){ return null; }$event.preventDefault();return _vm.dropdownEventHandlers.handleUpArrow.apply(null, arguments)},function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"down",40,$event.key,["Down","ArrowDown"])){ return null; }$event.preventDefault();return _vm.dropdownEventHandlers.handleDownArrow.apply(null, arguments)},function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"home",undefined,$event.key,undefined)){ return null; }return _vm.dropdownEventHandlers.handleHomeKey.apply(null, arguments)},function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"end",undefined,$event.key,undefined)){ return null; }return _vm.dropdownEventHandlers.handleEndKey.apply(null, arguments)},function($event){$event.stopPropagation();return _vm.$emit('keydown', $event)}],"click":_vm.handleInputClick}},'input',_vm.textInputAttrs,false))]},proxy:true}],null,true)})],2),_vm._v(" "),_c('gl-token-selector-dropdown',{attrs:{"menu-class":_vm.menuClass,"show":_vm.dropdownIsOpen,"loading":_vm.loading,"dropdown-items":_vm.filteredDropdownItems,"input-text":_vm.inputText,"user-defined-token-can-be-added":_vm.userDefinedTokenCanBeAdded,"component-id":_vm.uniqueId,"register-dropdown-event-handlers":_vm.registerDropdownEventHandlers,"register-reset-focused-dropdown-item":_vm.registerResetFocusedDropdownItem},on:{"dropdown-item-click":_vm.addToken,"input":function($event){_vm.focusedDropdownItem = $event;},"aria-active-descendant":_vm.handleAriaActiveDescendent,"show":_vm.openDropdown},scopedSlots:_vm._u([{key:"loading-content",fn:function(){return [_vm._t("loading-content")]},proxy:true},{key:"user-defined-token-content",fn:function(){return [_vm._t("user-defined-token-content",null,{"inputText":_vm.inputText})]},proxy:true},{key:"no-results-content",fn:function(){return [_vm._t("no-results-content")]},proxy:true},{key:"dropdown-item-content",fn:function(ref){
421
- var dropdownItem = ref.dropdownItem;
422
- return [_vm._t("dropdown-item-content",null,{"dropdownItem":dropdownItem})]}},{key:"dropdown-footer",fn:function(){return [_vm._t("dropdown-footer")]},proxy:true}],null,true)})],1)};
423
- var __vue_staticRenderFns__ = [];
424
-
425
- /* style */
426
- const __vue_inject_styles__ = undefined;
427
- /* scoped */
428
- const __vue_scope_id__ = undefined;
429
- /* module identifier */
430
- const __vue_module_identifier__ = undefined;
431
- /* functional template */
432
- const __vue_is_functional_template__ = false;
433
- /* style inject */
434
-
435
- /* style inject SSR */
436
-
437
- /* style inject shadow dom */
438
-
439
-
440
-
441
- const __vue_component__ = /*#__PURE__*/__vue_normalize__(
442
- { render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ },
443
- __vue_inject_styles__,
444
- __vue_script__,
445
- __vue_scope_id__,
446
- __vue_is_functional_template__,
447
- __vue_module_identifier__,
448
- false,
449
- undefined,
450
- undefined,
451
- undefined
452
- );
453
-
454
- export { __vue_component__ as default };
@@ -1,223 +0,0 @@
1
- import { uniqueId } from 'lodash-es';
2
- import GlDropdownItem from '../dropdown/dropdown_item';
3
- import { tokensValidator } from './helpers';
4
- import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js';
5
-
6
- var script = {
7
- name: 'GlTokenSelectorDropdown',
8
- components: {
9
- GlDropdownItem
10
- },
11
- props: {
12
- show: {
13
- type: Boolean,
14
- required: true
15
- },
16
- menuClass: {
17
- type: [String, Array, Object],
18
- required: false,
19
- default: ''
20
- },
21
- loading: {
22
- type: Boolean,
23
- required: false,
24
- default: false
25
- },
26
- dropdownItems: {
27
- type: Array,
28
- // All items need to have an `id` key
29
- validator: tokensValidator,
30
- required: true
31
- },
32
- inputText: {
33
- type: String,
34
- required: true
35
- },
36
- userDefinedTokenCanBeAdded: {
37
- type: Boolean,
38
- required: true
39
- },
40
- componentId: {
41
- type: String,
42
- required: true
43
- },
44
- registerDropdownEventHandlers: {
45
- type: Function,
46
- required: true
47
- },
48
- registerResetFocusedDropdownItem: {
49
- type: Function,
50
- required: true
51
- }
52
- },
53
- data() {
54
- return {
55
- focusedDropdownItemIndex: 0
56
- };
57
- },
58
- computed: {
59
- userDefinedToken() {
60
- return {
61
- id: uniqueId('user-defined-token'),
62
- name: this.inputText
63
- };
64
- },
65
- dropdownLength() {
66
- // Adds an additional dropdown item for the 'Add ... dropdown' item
67
- return this.userDefinedTokenCanBeAdded ? this.dropdownItems.length : this.dropdownItems.length - 1;
68
- },
69
- focusedLastDropdownItem() {
70
- return this.focusedDropdownItemIndex === this.dropdownLength;
71
- },
72
- focusedUserDefinedToken() {
73
- // User defined tokens are always the last in the list
74
- return this.userDefinedTokenCanBeAdded && this.focusedLastDropdownItem;
75
- },
76
- focusedDropdownItem() {
77
- if (this.focusedUserDefinedToken) {
78
- return this.userDefinedToken;
79
- }
80
- return this.dropdownItems[this.focusedDropdownItemIndex];
81
- }
82
- },
83
- watch: {
84
- focusedDropdownItem(newValue, oldValue) {
85
- if ((newValue === null || newValue === void 0 ? void 0 : newValue.id) !== (oldValue === null || oldValue === void 0 ? void 0 : oldValue.id)) {
86
- this.$emit('input', newValue);
87
- if (!newValue) {
88
- return;
89
- }
90
- const dropdownItemRef = this.getDropdownItemRef(newValue);
91
- if (dropdownItemRef !== null && dropdownItemRef !== void 0 && dropdownItemRef.$el) {
92
- dropdownItemRef.$el.scrollIntoView({
93
- block: 'nearest',
94
- inline: 'end'
95
- });
96
- }
97
- }
98
- }
99
- },
100
- created() {
101
- this.registerDropdownEventHandlers({
102
- handleUpArrow: this.handleUpArrow,
103
- handleDownArrow: this.handleDownArrow,
104
- handleHomeKey: this.handleHomeKey,
105
- handleEndKey: this.handleEndKey
106
- });
107
- this.registerResetFocusedDropdownItem(this.resetFocusedDropdownItem);
108
- this.$emit('input', this.focusedDropdownItem);
109
- },
110
- methods: {
111
- handleDropdownItemClick(dropdownItem) {
112
- this.$emit('dropdown-item-click', dropdownItem);
113
- },
114
- handleMousedown(dropdownItem) {
115
- // `event.relatedTarget` returns `null` on Safari because buttons are not focused on click (https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button#Clicking_and_focus)
116
- // Because of this we need to manually focus on the button. We do this in `mousedown` because it is fired before the `blur` event
117
- const dropdownItemRef = this.getDropdownItemRef(dropdownItem);
118
- if (dropdownItemRef !== null && dropdownItemRef !== void 0 && dropdownItemRef.$el) {
119
- dropdownItemRef.$el.querySelector('button').focus();
120
- }
121
- },
122
- handleUpArrow() {
123
- if (!this.show) {
124
- return;
125
- }
126
-
127
- // First dropdown item has been reached
128
- if (this.focusedDropdownItemIndex === 0) {
129
- return;
130
- }
131
- this.focusPrevDropdownItem();
132
- },
133
- handleDownArrow() {
134
- if (!this.show) {
135
- this.$emit('show');
136
- return;
137
- }
138
-
139
- // Last dropdown item has been reached
140
- if (this.focusedLastDropdownItem) {
141
- return;
142
- }
143
- this.focusNextDropdownItem();
144
- },
145
- handleHomeKey(event) {
146
- event.preventDefault();
147
- this.focusFirstDropdownItem();
148
- },
149
- handleEndKey(event) {
150
- event.preventDefault();
151
- this.focusLastDropdownItem();
152
- },
153
- focusLastDropdownItem() {
154
- this.focusedDropdownItemIndex = this.dropdownLength;
155
- },
156
- focusFirstDropdownItem() {
157
- this.focusedDropdownItemIndex = 0;
158
- },
159
- focusNextDropdownItem() {
160
- this.focusedDropdownItemIndex += 1;
161
- },
162
- focusPrevDropdownItem() {
163
- this.focusedDropdownItemIndex -= 1;
164
- },
165
- resetFocusedDropdownItem() {
166
- this.focusedDropdownItemIndex = 0;
167
- },
168
- dropdownItemIsFocused(dropdownItem) {
169
- if (!this.focusedDropdownItem) {
170
- return false;
171
- }
172
- return dropdownItem.id === this.focusedDropdownItem.id;
173
- },
174
- getDropdownItemRef(dropdownItem) {
175
- var _this$$refs$dropdownI;
176
- if (this.focusedUserDefinedToken) {
177
- return this.$refs[this.userDefinedToken.id];
178
- }
179
- return (_this$$refs$dropdownI = this.$refs.dropdownItems) === null || _this$$refs$dropdownI === void 0 ? void 0 : _this$$refs$dropdownI.find(ref => ref.$attrs['data-dropdown-item-id'] === dropdownItem.id);
180
- },
181
- dropdownItemIdAttribute(dropdownItem) {
182
- return dropdownItem ? `${this.componentId}-dropdown-item-${dropdownItem.id}` : null;
183
- }
184
- }
185
- };
186
-
187
- /* script */
188
- const __vue_script__ = script;
189
-
190
- /* template */
191
- var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{staticClass:"dropdown b-dropdown gl-dropdown gl-relative",class:{ show: _vm.show }},[_c('ul',{ref:"dropdownMenu",staticClass:"dropdown-menu gl-absolute",class:[{ show: _vm.show }, _vm.menuClass],attrs:{"id":_vm.componentId,"role":"listbox"}},[(_vm.loading)?_c('gl-dropdown-item',{attrs:{"role":"option","disabled":""}},[_vm._t("loading-content",function(){return [_vm._v("Searching...")]})],2):_vm._e(),_vm._v(" "),_vm._l((_vm.dropdownItems),function(dropdownItem){return _c('gl-dropdown-item',{key:dropdownItem.id,ref:"dropdownItems",refInFor:true,attrs:{"id":_vm.dropdownItemIdAttribute(dropdownItem),"data-dropdown-item-id":dropdownItem.id,"active":_vm.dropdownItemIsFocused(dropdownItem),"aria-selected":_vm.dropdownItemIsFocused(dropdownItem).toString(),"active-class":"is-focused","role":"option","tabindex":"-1"},on:{"click":function($event){return _vm.handleDropdownItemClick(dropdownItem)}}},[_c('div',{staticClass:"-gl-mx-4 -gl-my-3 gl-px-4 gl-py-3",on:{"mousedown":function($event){return _vm.handleMousedown(dropdownItem)}}},[_vm._t("dropdown-item-content",function(){return [_vm._v("\n "+_vm._s(dropdownItem.name)+"\n ")]},{"dropdownItem":dropdownItem})],2)])}),_vm._v(" "),(_vm.userDefinedTokenCanBeAdded)?_c('gl-dropdown-item',{ref:_vm.userDefinedToken.id,attrs:{"id":_vm.dropdownItemIdAttribute(_vm.userDefinedToken),"data-dropdown-item-id":_vm.userDefinedToken.id,"active":_vm.dropdownItemIsFocused(_vm.userDefinedToken),"active-class":"is-focused","role":"option","tabindex":"-1"},on:{"click":function($event){return _vm.handleDropdownItemClick(_vm.userDefinedToken)}}},[_c('div',{staticClass:"-gl-mx-4 -gl-my-3 gl-px-4 gl-py-3",on:{"mousedown":function($event){return _vm.handleMousedown(_vm.userDefinedToken)}}},[_vm._t("user-defined-token-content",function(){return [_vm._v("\n Add \""+_vm._s(_vm.inputText)+"\"\n ")]},{"inputText":_vm.inputText})],2)]):(!_vm.dropdownItems.length)?_c('gl-dropdown-item',{attrs:{"role":"option","disabled":""}},[_vm._t("no-results-content",function(){return [_vm._v("No matches found")]})],2):_vm._e(),_vm._v(" "),_vm._t("dropdown-footer")],2)])};
192
- var __vue_staticRenderFns__ = [];
193
-
194
- /* style */
195
- const __vue_inject_styles__ = undefined;
196
- /* scoped */
197
- const __vue_scope_id__ = undefined;
198
- /* module identifier */
199
- const __vue_module_identifier__ = undefined;
200
- /* functional template */
201
- const __vue_is_functional_template__ = false;
202
- /* style inject */
203
-
204
- /* style inject SSR */
205
-
206
- /* style inject shadow dom */
207
-
208
-
209
-
210
- const __vue_component__ = /*#__PURE__*/__vue_normalize__(
211
- { render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ },
212
- __vue_inject_styles__,
213
- __vue_script__,
214
- __vue_scope_id__,
215
- __vue_is_functional_template__,
216
- __vue_module_identifier__,
217
- false,
218
- undefined,
219
- undefined,
220
- undefined
221
- );
222
-
223
- export { __vue_component__ as default };