@gitlab/ui 131.3.0 → 131.3.2

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 (384) hide show
  1. package/package.json +4 -4
  2. package/src/components/utilities/truncate/truncate.scss +3 -1
  3. package/src/scss/mixins.scss +3 -1
  4. package/src/vendor/bootstrap-vue/src/components/tooltip/tooltip.js +86 -25
  5. package/tailwind.defaults.js +10 -1
  6. package/dist/charts.js +0 -13
  7. package/dist/components/base/accordion/accordion.js +0 -69
  8. package/dist/components/base/accordion/accordion_item.js +0 -160
  9. package/dist/components/base/accordion/constants.js +0 -3
  10. package/dist/components/base/alert/alert.js +0 -263
  11. package/dist/components/base/animated_icon/animated_chevron_down_up_icon.js +0 -45
  12. package/dist/components/base/animated_icon/animated_chevron_lg_down_up_icon.js +0 -45
  13. package/dist/components/base/animated_icon/animated_chevron_lg_right_down_icon.js +0 -45
  14. package/dist/components/base/animated_icon/animated_chevron_right_down_icon.js +0 -45
  15. package/dist/components/base/animated_icon/animated_duo_chat_icon.js +0 -45
  16. package/dist/components/base/animated_icon/animated_loader_icon.js +0 -45
  17. package/dist/components/base/animated_icon/animated_notifications_icon.js +0 -45
  18. package/dist/components/base/animated_icon/animated_sidebar_icon.js +0 -45
  19. package/dist/components/base/animated_icon/animated_smile_icon.js +0 -45
  20. package/dist/components/base/animated_icon/animated_sort_icon.js +0 -45
  21. package/dist/components/base/animated_icon/animated_star_icon.js +0 -45
  22. package/dist/components/base/animated_icon/animated_todo_icon.js +0 -45
  23. package/dist/components/base/animated_icon/animated_upload_icon.js +0 -45
  24. package/dist/components/base/animated_icon/base_animated_icon.js +0 -77
  25. package/dist/components/base/attribute_list/attribute_list.js +0 -100
  26. package/dist/components/base/avatar/avatar.js +0 -175
  27. package/dist/components/base/avatar/utils.js +0 -17
  28. package/dist/components/base/avatar_labeled/avatar_labeled.js +0 -198
  29. package/dist/components/base/avatar_link/avatar_link.js +0 -47
  30. package/dist/components/base/avatars_inline/avatars_inline.js +0 -139
  31. package/dist/components/base/badge/badge.js +0 -197
  32. package/dist/components/base/banner/banner.js +0 -149
  33. package/dist/components/base/breadcrumb/breadcrumb.js +0 -282
  34. package/dist/components/base/breadcrumb/breadcrumb_item.js +0 -96
  35. package/dist/components/base/broadcast_message/broadcast_message.js +0 -113
  36. package/dist/components/base/broadcast_message/constants.js +0 -5
  37. package/dist/components/base/button/button.js +0 -419
  38. package/dist/components/base/button_group/button_group.js +0 -53
  39. package/dist/components/base/card/card.js +0 -69
  40. package/dist/components/base/collapse/collapse.js +0 -163
  41. package/dist/components/base/color_mode_toggle/color_mode_toggle.js +0 -92
  42. package/dist/components/base/datepicker/datepicker.js +0 -475
  43. package/dist/components/base/daterange_picker/daterange_picker.js +0 -394
  44. package/dist/components/base/drawer/drawer.js +0 -156
  45. package/dist/components/base/dropdown/dropdown.js +0 -330
  46. package/dist/components/base/dropdown/dropdown_divider.js +0 -48
  47. package/dist/components/base/dropdown/dropdown_form.js +0 -48
  48. package/dist/components/base/dropdown/dropdown_item.js +0 -175
  49. package/dist/components/base/dropdown/dropdown_section_header.js +0 -48
  50. package/dist/components/base/dropdown/dropdown_text.js +0 -48
  51. package/dist/components/base/filtered_search/common_story_options.js +0 -14
  52. package/dist/components/base/filtered_search/filtered_search.js +0 -428
  53. package/dist/components/base/filtered_search/filtered_search_suggestion.js +0 -95
  54. package/dist/components/base/filtered_search/filtered_search_suggestion_list.js +0 -139
  55. package/dist/components/base/filtered_search/filtered_search_term.js +0 -217
  56. package/dist/components/base/filtered_search/filtered_search_token.js +0 -383
  57. package/dist/components/base/filtered_search/filtered_search_token_segment.js +0 -444
  58. package/dist/components/base/filtered_search/filtered_search_utils.js +0 -241
  59. package/dist/components/base/form/form.js +0 -43
  60. package/dist/components/base/form/form_character_count/form_character_count.js +0 -107
  61. package/dist/components/base/form/form_checkbox/form_checkbox.js +0 -342
  62. package/dist/components/base/form/form_checkbox/form_checkbox_group.js +0 -186
  63. package/dist/components/base/form/form_combobox/constants.js +0 -55
  64. package/dist/components/base/form/form_combobox/form_combobox.js +0 -239
  65. package/dist/components/base/form/form_date/form_date.js +0 -143
  66. package/dist/components/base/form/form_fields/form_field_validator.js +0 -93
  67. package/dist/components/base/form/form_fields/form_fields.js +0 -289
  68. package/dist/components/base/form/form_fields/form_fields_loop.js +0 -75
  69. package/dist/components/base/form/form_fields/mappers.js +0 -13
  70. package/dist/components/base/form/form_fields/validators.js +0 -48
  71. package/dist/components/base/form/form_group/form_group.js +0 -119
  72. package/dist/components/base/form/form_input/form_input.js +0 -695
  73. package/dist/components/base/form/form_input_group/form_input_group.js +0 -120
  74. package/dist/components/base/form/form_input_group/form_input_group_mixin.js +0 -41
  75. package/dist/components/base/form/form_radio/form_radio.js +0 -259
  76. package/dist/components/base/form/form_radio_group/form_radio_group.js +0 -187
  77. package/dist/components/base/form/form_select/constants.js +0 -12
  78. package/dist/components/base/form/form_select/form_select.js +0 -96
  79. package/dist/components/base/form/form_textarea/form_textarea.js +0 -166
  80. package/dist/components/base/form/input_group_text/input_group_text.js +0 -43
  81. package/dist/components/base/icon/icon.js +0 -113
  82. package/dist/components/base/illustration/illustration.js +0 -80
  83. package/dist/components/base/infinite_scroll/infinite_scroll.js +0 -196
  84. package/dist/components/base/keyset_pagination/keyset_pagination.js +0 -152
  85. package/dist/components/base/label/label.js +0 -174
  86. package/dist/components/base/link/link.js +0 -332
  87. package/dist/components/base/loading_icon/loading_icon.js +0 -120
  88. package/dist/components/base/markdown/markdown.js +0 -50
  89. package/dist/components/base/modal/modal.js +0 -259
  90. package/dist/components/base/new_dropdowns/base_dropdown/base_dropdown.js +0 -716
  91. package/dist/components/base/new_dropdowns/base_dropdown/constants.js +0 -5
  92. package/dist/components/base/new_dropdowns/base_dropdown/dropdown_container.js +0 -32
  93. package/dist/components/base/new_dropdowns/constants.js +0 -24
  94. package/dist/components/base/new_dropdowns/disclosure/constants.js +0 -8
  95. package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown.js +0 -400
  96. package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown_group.js +0 -112
  97. package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown_item.js +0 -196
  98. package/dist/components/base/new_dropdowns/disclosure/mock_data.js +0 -168
  99. package/dist/components/base/new_dropdowns/disclosure/utils.js +0 -84
  100. package/dist/components/base/new_dropdowns/listbox/listbox.js +0 -997
  101. package/dist/components/base/new_dropdowns/listbox/listbox_group.js +0 -58
  102. package/dist/components/base/new_dropdowns/listbox/listbox_item.js +0 -112
  103. package/dist/components/base/new_dropdowns/listbox/listbox_search_input.js +0 -94
  104. package/dist/components/base/new_dropdowns/listbox/mock_data.js +0 -131
  105. package/dist/components/base/new_dropdowns/listbox/utils.js +0 -33
  106. package/dist/components/base/pagination/pagination.js +0 -397
  107. package/dist/components/base/path/data.js +0 -34
  108. package/dist/components/base/path/path.js +0 -177
  109. package/dist/components/base/popover/popover.js +0 -142
  110. package/dist/components/base/progress_bar/progress_bar.js +0 -117
  111. package/dist/components/base/search_box_by_click/search_box_by_click.js +0 -245
  112. package/dist/components/base/search_box_by_type/search_box_by_type.js +0 -187
  113. package/dist/components/base/segmented_control/segmented_control.js +0 -73
  114. package/dist/components/base/skeleton_loader/skeleton_loader.js +0 -232
  115. package/dist/components/base/sorting/sorting.js +0 -180
  116. package/dist/components/base/table/constants.js +0 -5
  117. package/dist/components/base/table/table.js +0 -187
  118. package/dist/components/base/table_lite/table_lite.js +0 -80
  119. package/dist/components/base/tabs/constants.js +0 -3
  120. package/dist/components/base/tabs/tab/tab.js +0 -113
  121. package/dist/components/base/tabs/tabs/scrollable_tabs.js +0 -162
  122. package/dist/components/base/tabs/tabs/tabs.js +0 -223
  123. package/dist/components/base/toast/index.js +0 -66
  124. package/dist/components/base/toast/toast.js +0 -125
  125. package/dist/components/base/toast/toaster.js +0 -87
  126. package/dist/components/base/toggle/toggle.js +0 -178
  127. package/dist/components/base/token/token.js +0 -97
  128. package/dist/components/base/token_selector/helpers.js +0 -5
  129. package/dist/components/base/token_selector/token_container.js +0 -160
  130. package/dist/components/base/token_selector/token_selector.js +0 -454
  131. package/dist/components/base/token_selector/token_selector_dropdown.js +0 -223
  132. package/dist/components/base/tooltip/tooltip.js +0 -54
  133. package/dist/components/charts/area/area.js +0 -329
  134. package/dist/components/charts/bar/bar.js +0 -207
  135. package/dist/components/charts/chart/chart.js +0 -215
  136. package/dist/components/charts/column/column.js +0 -221
  137. package/dist/components/charts/discrete_scatter/discrete_scatter.js +0 -199
  138. package/dist/components/charts/gauge/gauge.js +0 -205
  139. package/dist/components/charts/heatmap/heatmap.js +0 -299
  140. package/dist/components/charts/heatmap/index.js +0 -2
  141. package/dist/components/charts/legend/legend.js +0 -245
  142. package/dist/components/charts/line/line.js +0 -340
  143. package/dist/components/charts/series_label/series_label.js +0 -101
  144. package/dist/components/charts/shared/tooltip/tooltip.js +0 -369
  145. package/dist/components/charts/shared/tooltip/tooltip_default_format/tooltip_default_format.js +0 -53
  146. package/dist/components/charts/single_stat/single_stat.js +0 -164
  147. package/dist/components/charts/sparkline/sparkline.js +0 -299
  148. package/dist/components/charts/stacked_column/stacked_column.js +0 -380
  149. package/dist/components/dashboards/dashboard_layout/dashboard_layout.js +0 -125
  150. package/dist/components/dashboards/dashboard_layout/grid_layout/grid_layout.js +0 -326
  151. package/dist/components/dashboards/dashboard_layout/validators.js +0 -14
  152. package/dist/components/dashboards/dashboard_panel/dashboard_panel.js +0 -236
  153. package/dist/components/dashboards/mock_data.js +0 -49
  154. package/dist/components/experimental/experiment_badge/constants.js +0 -4
  155. package/dist/components/experimental/experiment_badge/experiment_badge.js +0 -102
  156. package/dist/components/extended/multi_step_form_template/multi_step_form_template.js +0 -87
  157. package/dist/components/index.js +0 -107
  158. package/dist/components/mixins/button_mixin.js +0 -11
  159. package/dist/components/mixins/safe_link_mixin.js +0 -30
  160. package/dist/components/mixins/tooltip_mixin.js +0 -21
  161. package/dist/components/regions/dashboard_skeleton/dashboard_skeleton.js +0 -53
  162. package/dist/components/regions/empty_state/empty_state.js +0 -181
  163. package/dist/components/shared_components/clear_icon_button/clear_icon_button.js +0 -64
  164. package/dist/components/shared_components/clipboard_button/clipboard_button.js +0 -100
  165. package/dist/components/shared_components/close_button/close_button.js +0 -55
  166. package/dist/components/utilities/animated_number/animated_number.js +0 -131
  167. package/dist/components/utilities/friendly_wrap/friendly_wrap.js +0 -75
  168. package/dist/components/utilities/intersection_observer/intersection_observer.js +0 -88
  169. package/dist/components/utilities/intersperse/intersperse.js +0 -104
  170. package/dist/components/utilities/sprintf/sprintf.js +0 -171
  171. package/dist/components/utilities/truncate/constants.js +0 -8
  172. package/dist/components/utilities/truncate/truncate.js +0 -154
  173. package/dist/components/utilities/truncate_text/constants.js +0 -7
  174. package/dist/components/utilities/truncate_text/truncate_text.js +0 -146
  175. package/dist/config.js +0 -53
  176. package/dist/directives/hover_load/hover_load.js +0 -45
  177. package/dist/directives/index.js +0 -8
  178. package/dist/directives/modal.js +0 -1
  179. package/dist/directives/outside/outside.js +0 -149
  180. package/dist/directives/resize_observer/resize_observer.js +0 -58
  181. package/dist/directives/safe_html/constants.js +0 -6
  182. package/dist/directives/safe_html/safe_html.js +0 -39
  183. package/dist/directives/safe_link/mock_data.js +0 -10
  184. package/dist/directives/safe_link/safe_link.js +0 -67
  185. package/dist/directives/tooltip/container.js +0 -7
  186. package/dist/directives/tooltip/tooltip.js +0 -18
  187. package/dist/index.css +0 -7
  188. package/dist/index.css.map +0 -1
  189. package/dist/index.js +0 -2
  190. package/dist/tailwind.css +0 -2
  191. package/dist/tailwind.css.map +0 -1
  192. package/dist/tokens/build/js/tokens.dark.js +0 -1410
  193. package/dist/tokens/build/js/tokens.js +0 -1410
  194. package/dist/tokens/common_story_options.js +0 -29
  195. package/dist/tokens/tokens_story.js +0 -76
  196. package/dist/utils/breakpoints.js +0 -20
  197. package/dist/utils/charts/config.js +0 -616
  198. package/dist/utils/charts/constants.js +0 -69
  199. package/dist/utils/charts/mock_data.js +0 -191
  200. package/dist/utils/charts/story_config.js +0 -24
  201. package/dist/utils/charts/theme.js +0 -200
  202. package/dist/utils/charts/utils.js +0 -54
  203. package/dist/utils/constants.js +0 -333
  204. package/dist/utils/data_utils.js +0 -19
  205. package/dist/utils/datetime_utility.js +0 -61
  206. package/dist/utils/equality_utils.js +0 -84
  207. package/dist/utils/i18n.js +0 -65
  208. package/dist/utils/is_slot_empty.js +0 -34
  209. package/dist/utils/number_utils.js +0 -132
  210. package/dist/utils/play_utils.js +0 -11
  211. package/dist/utils/set_utils.js +0 -25
  212. package/dist/utils/stories_constants.js +0 -29
  213. package/dist/utils/stories_utils.js +0 -62
  214. package/dist/utils/story_decorators/container.js +0 -19
  215. package/dist/utils/string_utils.js +0 -69
  216. package/dist/utils/svgs/svg_paths.js +0 -7
  217. package/dist/utils/test_utils.js +0 -33
  218. package/dist/utils/use_fake_date.js +0 -29
  219. package/dist/utils/use_mock_intersection_observer.js +0 -105
  220. package/dist/utils/utils.js +0 -205
  221. package/dist/utils.js +0 -5
  222. package/dist/vendor/bootstrap-vue/src/bv-config.js +0 -8
  223. package/dist/vendor/bootstrap-vue/src/components/button/button-close.js +0 -81
  224. package/dist/vendor/bootstrap-vue/src/components/button/button.js +0 -204
  225. package/dist/vendor/bootstrap-vue/src/components/button/index.js +0 -2
  226. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-divider.js +0 -41
  227. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-form.js +0 -52
  228. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-group.js +0 -75
  229. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-header.js +0 -52
  230. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-item-button.js +0 -85
  231. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.js +0 -97
  232. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.js +0 -60
  233. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown.js +0 -271
  234. package/dist/vendor/bootstrap-vue/src/components/dropdown/index.js +0 -8
  235. package/dist/vendor/bootstrap-vue/src/components/form/form-invalid-feedback.js +0 -53
  236. package/dist/vendor/bootstrap-vue/src/components/form/form-text.js +0 -55
  237. package/dist/vendor/bootstrap-vue/src/components/form/form-valid-feedback.js +0 -53
  238. package/dist/vendor/bootstrap-vue/src/components/form/form.js +0 -56
  239. package/dist/vendor/bootstrap-vue/src/components/form/index.js +0 -4
  240. package/dist/vendor/bootstrap-vue/src/components/form-group/form-group.js +0 -348
  241. package/dist/vendor/bootstrap-vue/src/components/form-group/index.js +0 -1
  242. package/dist/vendor/bootstrap-vue/src/components/form-select/form-select-option-group.js +0 -54
  243. package/dist/vendor/bootstrap-vue/src/components/form-select/form-select-option.js +0 -41
  244. package/dist/vendor/bootstrap-vue/src/components/form-select/form-select.js +0 -143
  245. package/dist/vendor/bootstrap-vue/src/components/form-select/helpers/mixin-options.js +0 -56
  246. package/dist/vendor/bootstrap-vue/src/components/form-select/index.js +0 -3
  247. package/dist/vendor/bootstrap-vue/src/components/form-textarea/form-textarea.js +0 -217
  248. package/dist/vendor/bootstrap-vue/src/components/form-textarea/index.js +0 -1
  249. package/dist/vendor/bootstrap-vue/src/components/layout/col.js +0 -156
  250. package/dist/vendor/bootstrap-vue/src/components/layout/form-row.js +0 -34
  251. package/dist/vendor/bootstrap-vue/src/components/layout/index.js +0 -2
  252. package/dist/vendor/bootstrap-vue/src/components/link/index.js +0 -1
  253. package/dist/vendor/bootstrap-vue/src/components/link/link.js +0 -283
  254. package/dist/vendor/bootstrap-vue/src/components/modal/helpers/bv-modal-event.class.js +0 -21
  255. package/dist/vendor/bootstrap-vue/src/components/modal/helpers/modal-manager.js +0 -212
  256. package/dist/vendor/bootstrap-vue/src/components/modal/index.js +0 -1
  257. package/dist/vendor/bootstrap-vue/src/components/modal/modal.js +0 -887
  258. package/dist/vendor/bootstrap-vue/src/components/popover/helpers/bv-popover-template.js +0 -55
  259. package/dist/vendor/bootstrap-vue/src/components/popover/helpers/bv-popover.js +0 -31
  260. package/dist/vendor/bootstrap-vue/src/components/popover/index.js +0 -1
  261. package/dist/vendor/bootstrap-vue/src/components/popover/popover.js +0 -49
  262. package/dist/vendor/bootstrap-vue/src/components/table/helpers/constants.js +0 -22
  263. package/dist/vendor/bootstrap-vue/src/components/table/helpers/default-sort-compare.js +0 -64
  264. package/dist/vendor/bootstrap-vue/src/components/table/helpers/filter-event.js +0 -40
  265. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-bottom-row.js +0 -43
  266. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-busy.js +0 -83
  267. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-caption.js +0 -50
  268. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-colgroup.js +0 -32
  269. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-empty.js +0 -82
  270. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-filtering.js +0 -274
  271. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-items.js +0 -154
  272. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-pagination.js +0 -44
  273. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-provider.js +0 -191
  274. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-selectable.js +0 -213
  275. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-sorting.js +0 -275
  276. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-stacked.js +0 -39
  277. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-table-renderer.js +0 -186
  278. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tbody-row.js +0 -338
  279. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tbody.js +0 -243
  280. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tfoot.js +0 -50
  281. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-thead.js +0 -218
  282. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-top-row.js +0 -42
  283. package/dist/vendor/bootstrap-vue/src/components/table/helpers/normalize-fields.js +0 -86
  284. package/dist/vendor/bootstrap-vue/src/components/table/helpers/sanitize-row.js +0 -32
  285. package/dist/vendor/bootstrap-vue/src/components/table/helpers/stringify-record-values.js +0 -11
  286. package/dist/vendor/bootstrap-vue/src/components/table/helpers/text-selection-active.js +0 -14
  287. package/dist/vendor/bootstrap-vue/src/components/table/index.js +0 -9
  288. package/dist/vendor/bootstrap-vue/src/components/table/table-lite.js +0 -51
  289. package/dist/vendor/bootstrap-vue/src/components/table/table-simple.js +0 -44
  290. package/dist/vendor/bootstrap-vue/src/components/table/table.js +0 -67
  291. package/dist/vendor/bootstrap-vue/src/components/table/tbody.js +0 -116
  292. package/dist/vendor/bootstrap-vue/src/components/table/td.js +0 -204
  293. package/dist/vendor/bootstrap-vue/src/components/table/tfoot.js +0 -96
  294. package/dist/vendor/bootstrap-vue/src/components/table/th.js +0 -26
  295. package/dist/vendor/bootstrap-vue/src/components/table/thead.js +0 -99
  296. package/dist/vendor/bootstrap-vue/src/components/table/tr.js +0 -121
  297. package/dist/vendor/bootstrap-vue/src/components/tabs/index.js +0 -2
  298. package/dist/vendor/bootstrap-vue/src/components/tabs/tab.js +0 -238
  299. package/dist/vendor/bootstrap-vue/src/components/tabs/tabs.js +0 -601
  300. package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-popper.js +0 -251
  301. package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip-template.js +0 -118
  302. package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip.js +0 -932
  303. package/dist/vendor/bootstrap-vue/src/components/tooltip/index.js +0 -1
  304. package/dist/vendor/bootstrap-vue/src/components/tooltip/tooltip.js +0 -269
  305. package/dist/vendor/bootstrap-vue/src/components/transition/bv-transition.js +0 -103
  306. package/dist/vendor/bootstrap-vue/src/components/transporter/transporter.js +0 -205
  307. package/dist/vendor/bootstrap-vue/src/constants/components.js +0 -55
  308. package/dist/vendor/bootstrap-vue/src/constants/config.js +0 -11
  309. package/dist/vendor/bootstrap-vue/src/constants/env.js +0 -36
  310. package/dist/vendor/bootstrap-vue/src/constants/events.js +0 -56
  311. package/dist/vendor/bootstrap-vue/src/constants/key-codes.js +0 -11
  312. package/dist/vendor/bootstrap-vue/src/constants/popper.js +0 -10
  313. package/dist/vendor/bootstrap-vue/src/constants/props.js +0 -24
  314. package/dist/vendor/bootstrap-vue/src/constants/regex.js +0 -35
  315. package/dist/vendor/bootstrap-vue/src/constants/safe-types.js +0 -15
  316. package/dist/vendor/bootstrap-vue/src/constants/slots.js +0 -36
  317. package/dist/vendor/bootstrap-vue/src/directives/modal/index.js +0 -1
  318. package/dist/vendor/bootstrap-vue/src/directives/modal/modal.js +0 -112
  319. package/dist/vendor/bootstrap-vue/src/directives/tooltip/index.js +0 -1
  320. package/dist/vendor/bootstrap-vue/src/directives/tooltip/tooltip.js +0 -265
  321. package/dist/vendor/bootstrap-vue/src/directives/visible/index.js +0 -1
  322. package/dist/vendor/bootstrap-vue/src/directives/visible/visible.js +0 -187
  323. package/dist/vendor/bootstrap-vue/src/mixins/attrs.js +0 -5
  324. package/dist/vendor/bootstrap-vue/src/mixins/click-out.js +0 -54
  325. package/dist/vendor/bootstrap-vue/src/mixins/dropdown.js +0 -470
  326. package/dist/vendor/bootstrap-vue/src/mixins/focus-in.js +0 -46
  327. package/dist/vendor/bootstrap-vue/src/mixins/form-control.js +0 -73
  328. package/dist/vendor/bootstrap-vue/src/mixins/form-custom.js +0 -26
  329. package/dist/vendor/bootstrap-vue/src/mixins/form-options.js +0 -91
  330. package/dist/vendor/bootstrap-vue/src/mixins/form-selection.js +0 -62
  331. package/dist/vendor/bootstrap-vue/src/mixins/form-size.js +0 -26
  332. package/dist/vendor/bootstrap-vue/src/mixins/form-state.js +0 -50
  333. package/dist/vendor/bootstrap-vue/src/mixins/form-text.js +0 -293
  334. package/dist/vendor/bootstrap-vue/src/mixins/form-validity.js +0 -50
  335. package/dist/vendor/bootstrap-vue/src/mixins/has-listener.js +0 -29
  336. package/dist/vendor/bootstrap-vue/src/mixins/id.js +0 -57
  337. package/dist/vendor/bootstrap-vue/src/mixins/listen-on-document.js +0 -63
  338. package/dist/vendor/bootstrap-vue/src/mixins/listen-on-root.js +0 -121
  339. package/dist/vendor/bootstrap-vue/src/mixins/listen-on-window.js +0 -63
  340. package/dist/vendor/bootstrap-vue/src/mixins/listeners.js +0 -25
  341. package/dist/vendor/bootstrap-vue/src/mixins/model.js +0 -10
  342. package/dist/vendor/bootstrap-vue/src/mixins/normalize-slot.js +0 -30
  343. package/dist/vendor/bootstrap-vue/src/mixins/scoped-style.js +0 -18
  344. package/dist/vendor/bootstrap-vue/src/mixins/use-parent.js +0 -14
  345. package/dist/vendor/bootstrap-vue/src/utils/array.js +0 -28
  346. package/dist/vendor/bootstrap-vue/src/utils/bv-event.class.js +0 -60
  347. package/dist/vendor/bootstrap-vue/src/utils/cache.js +0 -60
  348. package/dist/vendor/bootstrap-vue/src/utils/clone-deep.js +0 -18
  349. package/dist/vendor/bootstrap-vue/src/utils/config-set.js +0 -86
  350. package/dist/vendor/bootstrap-vue/src/utils/config.js +0 -71
  351. package/dist/vendor/bootstrap-vue/src/utils/create-new-child-component.js +0 -133
  352. package/dist/vendor/bootstrap-vue/src/utils/css-escape.js +0 -70
  353. package/dist/vendor/bootstrap-vue/src/utils/dom.js +0 -298
  354. package/dist/vendor/bootstrap-vue/src/utils/element-to-vue-instance-registry.js +0 -28
  355. package/dist/vendor/bootstrap-vue/src/utils/env.js +0 -16
  356. package/dist/vendor/bootstrap-vue/src/utils/events.js +0 -78
  357. package/dist/vendor/bootstrap-vue/src/utils/get-event-root.js +0 -5
  358. package/dist/vendor/bootstrap-vue/src/utils/get-instance-from-directive.js +0 -3
  359. package/dist/vendor/bootstrap-vue/src/utils/get-scope-id.js +0 -9
  360. package/dist/vendor/bootstrap-vue/src/utils/get.js +0 -63
  361. package/dist/vendor/bootstrap-vue/src/utils/html.js +0 -16
  362. package/dist/vendor/bootstrap-vue/src/utils/identity.js +0 -3
  363. package/dist/vendor/bootstrap-vue/src/utils/inspect.js +0 -35
  364. package/dist/vendor/bootstrap-vue/src/utils/locale.js +0 -19
  365. package/dist/vendor/bootstrap-vue/src/utils/loose-equal.js +0 -59
  366. package/dist/vendor/bootstrap-vue/src/utils/loose-index-of.js +0 -13
  367. package/dist/vendor/bootstrap-vue/src/utils/math.js +0 -9
  368. package/dist/vendor/bootstrap-vue/src/utils/memoize.js +0 -14
  369. package/dist/vendor/bootstrap-vue/src/utils/model.js +0 -33
  370. package/dist/vendor/bootstrap-vue/src/utils/noop.js +0 -3
  371. package/dist/vendor/bootstrap-vue/src/utils/normalize-slot.js +0 -51
  372. package/dist/vendor/bootstrap-vue/src/utils/number.js +0 -23
  373. package/dist/vendor/bootstrap-vue/src/utils/object.js +0 -72
  374. package/dist/vendor/bootstrap-vue/src/utils/observe-dom.js +0 -76
  375. package/dist/vendor/bootstrap-vue/src/utils/on-instance-destroy.js +0 -22
  376. package/dist/vendor/bootstrap-vue/src/utils/plugins.js +0 -124
  377. package/dist/vendor/bootstrap-vue/src/utils/props.js +0 -67
  378. package/dist/vendor/bootstrap-vue/src/utils/router.js +0 -150
  379. package/dist/vendor/bootstrap-vue/src/utils/safe-vue-instance.js +0 -14
  380. package/dist/vendor/bootstrap-vue/src/utils/stable-sort.js +0 -28
  381. package/dist/vendor/bootstrap-vue/src/utils/string.js +0 -47
  382. package/dist/vendor/bootstrap-vue/src/utils/stringify-object-values.js +0 -31
  383. package/dist/vendor/bootstrap-vue/src/utils/warn.js +0 -45
  384. 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 };