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