@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,997 +0,0 @@
1
- import { uniqueId, isEqual, clamp } from 'lodash-es';
2
- import { logWarning, stopEvent } from '../../../../utils/utils';
3
- import { GL_DROPDOWN_SHOWN, GL_DROPDOWN_HIDDEN, GL_DROPDOWN_FOCUS_CONTENT, POSITION_ABSOLUTE, POSITION_FIXED, GL_DROPDOWN_CONTENTS_CLASS, ENTER, ARROW_DOWN, ARROW_UP, END, HOME } from '../constants';
4
- import { buttonCategoryOptions, dropdownVariantOptions, buttonSizeOptions, dropdownPlacements } from '../../../../utils/constants';
5
- import GlButton from '../../button/button';
6
- import GlLoadingIcon from '../../loading_icon/loading_icon';
7
- import GlIntersectionObserver from '../../../utilities/intersection_observer/intersection_observer';
8
- import GlSearchBoxByType from '../../search_box_by_type/search_box_by_type';
9
- import GlBaseDropdown from '../base_dropdown/base_dropdown';
10
- import { translatePlural, translate } from '../../../../utils/i18n';
11
- import GlListboxItem from './listbox_item';
12
- import GlListboxSearchInput from './listbox_search_input';
13
- import GlListboxGroup from './listbox_group';
14
- import { itemsValidator, isOption, flattenedOptions } from './utils';
15
- import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js';
16
-
17
- const ITEM_SELECTOR = '[role="option"]';
18
- const ITEM_NULL_KEY = Symbol('null-key');
19
- const HEADER_ITEMS_BORDER_CLASSES = ['gl-border-b-1', 'gl-border-b-solid', 'gl-border-b-dropdown-divider'];
20
- const GROUP_TOP_BORDER_CLASSES = ['gl-border-t-1', 'gl-border-t-solid', 'gl-border-t-dropdown-divider', 'gl-pt-1', 'gl-mt-2'];
21
- const SEARCH_INPUT_SELECTOR = '.gl-listbox-search-input';
22
- var script = {
23
- name: 'GlCollapsibleListbox',
24
- HEADER_ITEMS_BORDER_CLASSES,
25
- events: {
26
- GL_DROPDOWN_SHOWN,
27
- GL_DROPDOWN_HIDDEN,
28
- GL_DROPDOWN_FOCUS_CONTENT
29
- },
30
- components: {
31
- GlBaseDropdown,
32
- GlListboxItem,
33
- GlListboxGroup,
34
- GlButton,
35
- GlSearchBoxByType,
36
- GlListboxSearchInput,
37
- GlLoadingIcon,
38
- GlIntersectionObserver
39
- },
40
- inject: {
41
- getFormGroupInstance: {
42
- default: () => () => {}
43
- }
44
- },
45
- model: {
46
- prop: 'selected',
47
- event: 'select'
48
- },
49
- props: {
50
- /**
51
- * Items to display in the dropdown
52
- */
53
- items: {
54
- type: Array,
55
- required: false,
56
- default: () => [],
57
- validator: itemsValidator
58
- },
59
- /**
60
- * Array of selected items values for multi-select and selected item value for single-select
61
- */
62
- selected: {
63
- type: [Array, String, Number, null],
64
- required: false,
65
- default: () => []
66
- },
67
- /**
68
- * Allow multi-selection
69
- */
70
- multiple: {
71
- type: Boolean,
72
- required: false,
73
- default: false
74
- },
75
- /**
76
- * Toggle button text
77
- */
78
- toggleText: {
79
- type: String,
80
- required: false,
81
- default: ''
82
- },
83
- /**
84
- * Toggle text to be read by screen readers only
85
- */
86
- textSrOnly: {
87
- type: Boolean,
88
- required: false,
89
- default: false
90
- },
91
- /** The header text */
92
- headerText: {
93
- type: String,
94
- required: false,
95
- default: ''
96
- },
97
- /**
98
- * Styling option - dropdown's toggle category
99
- */
100
- category: {
101
- type: String,
102
- required: false,
103
- default: buttonCategoryOptions.primary,
104
- validator: value => value in buttonCategoryOptions
105
- },
106
- /**
107
- * Styling option - dropdown's toggle variant
108
- */
109
- variant: {
110
- type: String,
111
- required: false,
112
- default: dropdownVariantOptions.default,
113
- validator: value => value in dropdownVariantOptions
114
- },
115
- /**
116
- * The size of the dropdown toggle
117
- */
118
- size: {
119
- type: String,
120
- required: false,
121
- default: 'medium',
122
- validator: value => value in buttonSizeOptions
123
- },
124
- /**
125
- * Icon name that will be rendered in the toggle button
126
- */
127
- icon: {
128
- type: String,
129
- required: false,
130
- default: ''
131
- },
132
- /**
133
- * Set to "true" to disable the dropdown
134
- */
135
- disabled: {
136
- type: Boolean,
137
- required: false,
138
- default: false
139
- },
140
- /**
141
- * Controls the validation state appearance of the component. `true` for valid, `false` for invalid, or `null` for no validation state
142
- */
143
- state: {
144
- type: Boolean,
145
- required: false,
146
- default: null
147
- },
148
- /**
149
- * Set to "true" when dropdown content (items) is loading
150
- * It will render a small loader in the dropdown toggle and make it disabled
151
- */
152
- loading: {
153
- type: Boolean,
154
- required: false,
155
- default: false
156
- },
157
- /**
158
- * Additional CSS classes to customize toggle appearance
159
- */
160
- toggleClass: {
161
- type: [String, Array, Object],
162
- required: false,
163
- default: null
164
- },
165
- /**
166
- * Set to "true" to hide the caret
167
- */
168
- noCaret: {
169
- type: Boolean,
170
- required: false,
171
- default: false
172
- },
173
- /**
174
- * Align listbox menu with respect to the toggle button
175
- */
176
- placement: {
177
- type: String,
178
- required: false,
179
- default: 'bottom-start',
180
- validator: value => Object.keys(dropdownPlacements).includes(value)
181
- },
182
- /**
183
- * Center selected item checkmark
184
- */
185
- isCheckCentered: {
186
- type: Boolean,
187
- required: false,
188
- default: false
189
- },
190
- /**
191
- * The `id` attribute value for the toggle button
192
- */
193
- toggleId: {
194
- type: String,
195
- required: false,
196
- default: null
197
- },
198
- /**
199
- * The `aria-labelledby` attribute value for the toggle button
200
- * Provide the string of IDs seperated by space
201
- */
202
- toggleAriaLabelledBy: {
203
- type: String,
204
- required: false,
205
- default: null
206
- },
207
- /**
208
- * The `aria-labelledby` attribute value for the list of options
209
- * Provide the string of IDs seperated by space
210
- */
211
- listAriaLabelledBy: {
212
- type: String,
213
- required: false,
214
- default: null
215
- },
216
- /**
217
- * Enable search
218
- */
219
- searchable: {
220
- type: Boolean,
221
- required: false,
222
- default: false
223
- },
224
- /**
225
- * Set to "true" when items search is in progress.
226
- * It will display loading icon below the search input
227
- */
228
- searching: {
229
- type: Boolean,
230
- required: false,
231
- default: false
232
- },
233
- /**
234
- * Enables infinite scroll.
235
- * When set to `true`, the `@bottom-reached` event will be fired when
236
- * the bottom of the listbox is scrolled to.
237
- * Does not support groups.
238
- */
239
- infiniteScroll: {
240
- type: Boolean,
241
- required: false,
242
- default: false
243
- },
244
- /**
245
- * This prop is used for infinite scroll.
246
- * It represents the total number of items that exist,
247
- * even if they have not yet been loaded.
248
- * Do not set this prop if the total number of items is unknown.
249
- */
250
- totalItems: {
251
- type: Number,
252
- required: false,
253
- default: null
254
- },
255
- /**
256
- * This prop is used for infinite scroll.
257
- * Set to `true` when more items are being loaded.
258
- */
259
- infiniteScrollLoading: {
260
- type: Boolean,
261
- required: false,
262
- default: false
263
- },
264
- /**
265
- * Message to be displayed when filtering produced no results
266
- */
267
- noResultsText: {
268
- type: String,
269
- required: false,
270
- default: 'No results found'
271
- },
272
- /**
273
- * Search input placeholder text and aria-label
274
- */
275
- searchPlaceholder: {
276
- type: String,
277
- required: false,
278
- default: 'Search'
279
- },
280
- /**
281
- * The reset button's label, to be rendered in the header. If this is omitted, the button is not
282
- * rendered.
283
- * The reset button requires a header to be set, so this prop should be used in conjunction with
284
- * headerText.
285
- */
286
- resetButtonLabel: {
287
- type: String,
288
- required: false,
289
- default: ''
290
- },
291
- /**
292
- * The select all button's label, to be rendered in the header. If this is omitted, the button is not
293
- * rendered.
294
- * The select all button requires a header to be set, so this prop should be used in conjunction with
295
- * headerText.
296
- */
297
- showSelectAllButtonLabel: {
298
- type: String,
299
- required: false,
300
- default: ''
301
- },
302
- /**
303
- * Render the toggle button as a block element
304
- */
305
- block: {
306
- type: Boolean,
307
- required: false,
308
- default: false
309
- },
310
- /**
311
- * Custom offset to be applied to Floating UI's offset middleware.
312
- * https://floating-ui.com/docs/offset
313
- */
314
- dropdownOffset: {
315
- type: [Number, Object],
316
- required: false,
317
- default: undefined
318
- },
319
- /**
320
- * Lets the dropdown extend to match its content's width, up to a maximum width
321
- * defined by the `$gl-new-dropdown-max-width` variable.
322
- */
323
- fluidWidth: {
324
- type: Boolean,
325
- required: false,
326
- default: false
327
- },
328
- /**
329
- * Allows the dropdown panel to match the width of the trigger element
330
- */
331
- panelMatchTriggerWidth: {
332
- type: Boolean,
333
- required: false,
334
- default: false
335
- },
336
- /**
337
- * Strategy to be applied by computePosition. If the dropdown's container is too short for it to
338
- * fit in, setting this to fixed will let it position itself above its container.
339
- * https://floating-ui.com/docs/computePosition#strategy
340
- */
341
- positioningStrategy: {
342
- type: String,
343
- required: false,
344
- default: POSITION_ABSOLUTE,
345
- validator: strategy => [POSITION_ABSOLUTE, POSITION_FIXED].includes(strategy)
346
- },
347
- /**
348
- * Opens dropdown on render
349
- */
350
- startOpened: {
351
- type: Boolean,
352
- required: false,
353
- default: false
354
- },
355
- srOnlyResultsLabel: {
356
- type: Function,
357
- required: false,
358
- default: translatePlural('GlCollapsibleListbox.srOnlyResultsLabel', '%d result', '%d results')
359
- }
360
- },
361
- data() {
362
- return {
363
- selectedValues: [],
364
- listboxId: uniqueId('listbox-'),
365
- searchInputId: uniqueId('listbox-search-input-'),
366
- nextFocusedItemIndex: null,
367
- searchStr: '',
368
- topBoundaryVisible: true,
369
- bottomBoundaryVisible: true,
370
- activeItemId: null,
371
- itemIds: new Map()
372
- };
373
- },
374
- computed: {
375
- /**
376
- * Determines the `aria-labelledby` attribute value for the listbox by
377
- * evaluating a series of conditions in priority order. The returned ID
378
- * references the element that best describes the listbox content, with
379
- * preference given to headers in searchable lists, followed by search
380
- * input, form labels, and finally fallback options.
381
- */
382
- listboxAriaLabelledByID() {
383
- // Listbox is labelled by closest heading, creating a meaningful relationship
384
- if (this.headerId && this.searchable) return `${this.headerId}`;
385
-
386
- // Listbox is labelled by the search input with role="combobox"
387
- if (this.searchable) return this.searchInputId;
388
-
389
- // Listbox is labelledy by the text inside an externally labelled button
390
- if (this.isInFormGroup) return this.listboxIdComputed;
391
-
392
- // Fallback. Return a header ID or the toggle button ID.
393
- return this.listAriaLabelledBy || this.headerId || this.toggleIdComputed;
394
- },
395
- isInFormGroup() {
396
- return Boolean(this.getFormGroupInstance());
397
- },
398
- toggleIdComputed() {
399
- return this.toggleId || uniqueId('dropdown-toggle-btn-');
400
- },
401
- // Generate a custom listbox ID when inside GlFormGroup
402
- listboxIdComputed() {
403
- if (this.isInFormGroup) {
404
- if (this.listAriaLabelledBy) {
405
- return this.listAriaLabelledBy;
406
- }
407
- if (this.toggleId) {
408
- return `${this.toggleId}-span`;
409
- }
410
- return uniqueId('dropdown-toggle-span-');
411
- }
412
- return undefined;
413
- },
414
- listboxTag() {
415
- if (!this.hasItems || isOption(this.items[0])) return 'ul';
416
- return 'div';
417
- },
418
- listboxClasses() {
419
- return {
420
- 'top-scrim-visible': !this.topBoundaryVisible,
421
- 'bottom-scrim-visible': !this.bottomBoundaryVisible,
422
- [GL_DROPDOWN_CONTENTS_CLASS]: true
423
- };
424
- },
425
- itemTag() {
426
- return this.listboxTag === 'ul' ? 'li' : 'div';
427
- },
428
- flattenedOptions() {
429
- return flattenedOptions(this.items);
430
- },
431
- searchHasOptions() {
432
- return this.flattenedOptions.length > 0 && this.searchStr;
433
- },
434
- hasItems() {
435
- return this.items.length > 0;
436
- },
437
- listboxToggleText() {
438
- if (!this.toggleText) {
439
- if (!this.multiple && this.selectedValues.length) {
440
- var _this$flattenedOption;
441
- return (_this$flattenedOption = this.flattenedOptions.find(_ref => {
442
- let {
443
- value
444
- } = _ref;
445
- return value === this.selectedValues[0];
446
- })) === null || _this$flattenedOption === void 0 ? void 0 : _this$flattenedOption.text;
447
- }
448
- return '';
449
- }
450
- return this.toggleText;
451
- },
452
- selectedIndices() {
453
- return this.selectedValues.map(selected => this.flattenedOptions.findIndex(_ref2 => {
454
- let {
455
- value
456
- } = _ref2;
457
- return value === selected;
458
- })).filter(index => index !== -1).sort();
459
- },
460
- showList() {
461
- return this.flattenedOptions.length && !this.searching;
462
- },
463
- showNoResultsText() {
464
- return !this.flattenedOptions.length && !this.searching;
465
- },
466
- announceSRSearchResults() {
467
- return this.searchable && !this.showNoResultsText;
468
- },
469
- headerId() {
470
- return this.headerText && uniqueId('listbox-header-');
471
- },
472
- showResetButton() {
473
- if (!this.resetButtonLabel) {
474
- return false;
475
- }
476
-
477
- /**
478
- * if dropdown has no items
479
- * reset all should be hidden
480
- */
481
- if (!this.hasItems) {
482
- return false;
483
- }
484
-
485
- // hide if no selection
486
- if (!this.selected || this.selected.length === 0) {
487
- return false;
488
- }
489
-
490
- // only show reset button if show all button is not there
491
- return !this.showSelectAllButton;
492
- },
493
- showSelectAllButton() {
494
- if (!this.showSelectAllButtonLabel) {
495
- return false;
496
- }
497
- if (!this.multiple) {
498
- return false;
499
- }
500
-
501
- /**
502
- * if dropdown has no items
503
- * select all should be hidden
504
- */
505
- if (!this.hasItems) {
506
- return false;
507
- }
508
- return this.selected.length !== this.flattenedOptions.length;
509
- },
510
- showIntersectionObserver() {
511
- return this.infiniteScroll && !this.infiniteScrollLoading && !this.loading && !this.searching;
512
- },
513
- isBusy() {
514
- return this.infiniteScrollLoading || this.loading || this.searching;
515
- },
516
- hasCustomToggle() {
517
- return Boolean(this.$scopedSlots.toggle);
518
- },
519
- hasSelection() {
520
- return Boolean(this.selectedValues.length);
521
- },
522
- toggleButtonClasses() {
523
- const toggleClasses = [this.toggleClass];
524
- if (!this.hasSelection) {
525
- toggleClasses.push('!gl-text-subtle');
526
- }
527
- return toggleClasses;
528
- },
529
- hasHeader() {
530
- return this.headerText || this.searchable;
531
- },
532
- hasFooter() {
533
- return Boolean(this.$scopedSlots.footer);
534
- },
535
- loadingAnnouncementText() {
536
- if (this.infiniteScrollLoading) {
537
- return translate('GlCollapsibleListbox.loadingAnnouncementText.loadingMoreItems', 'Loading more items');
538
- }
539
- if (this.searching) {
540
- return translate('GlCollapsibleListbox.loadingAnnouncementText.searching', 'Searching');
541
- }
542
- if (this.loading) {
543
- return translate('GlCollapsibleListbox.loadingAnnouncementText.loadingItems', 'Loading items');
544
- }
545
- return '';
546
- }
547
- },
548
- watch: {
549
- selected: {
550
- immediate: true,
551
- handler(newSelected, oldSelected) {
552
- if (Array.isArray(newSelected)) {
553
- if (process.env.NODE_ENV !== 'production' && !this.multiple && newSelected.length) {
554
- throw new Error('To allow multi-selection, please, set "multiple" property to "true"');
555
- }
556
- this.selectedValues = [...newSelected];
557
- } else {
558
- this.selectedValues = [newSelected];
559
- }
560
- if (
561
- // Do not emit change event immediately on watcher creation.
562
- oldSelected !== undefined && !isEqual(newSelected, oldSelected)) {
563
- /**
564
- * Emitted when the selected prop value changes
565
- *
566
- * @event change
567
- */
568
- this.$emit('change');
569
- }
570
- }
571
- },
572
- items: {
573
- handler() {
574
- this.$nextTick(() => {
575
- /* Every time the list of items changes (on search),
576
- * the observed elements are recreated, thus we need to start obesrving them again */
577
- this.observeScroll();
578
-
579
- /**
580
- * Every time the list of items changes, and there is a search string,
581
- * we want to visually highlight the first enabled item
582
- */
583
- if (this.searchHasOptions) {
584
- this.nextFocusedItemIndex = this.getFirstEnabledIndex();
585
- } else {
586
- this.nextFocusedItemIndex = null;
587
- }
588
- });
589
- }
590
- },
591
- ...(process.env.NODE_ENV !== 'production' ? {
592
- resetButtonLabel: {
593
- immediate: true,
594
- handler(newResetButtonLabel) {
595
- if (newResetButtonLabel && !this.headerText) {
596
- throw new Error('The reset button cannot be rendered without a header. Either provide a header via the headerText prop, or do not provide the resetButtonLabel prop.');
597
- }
598
- }
599
- },
600
- showSelectAllButtonLabel: {
601
- immediate: true,
602
- handler(showSelectAllButtonLabel) {
603
- if (showSelectAllButtonLabel && !this.headerText) {
604
- throw new Error('The select all button cannot be rendered without a header. Either provide a header via the headerText prop, or do not provide the showSelectAllButtonLabel prop.');
605
- }
606
- }
607
- },
608
- infiniteScroll: {
609
- immediate: true,
610
- handler(newValue) {
611
- if (newValue && this.items.some(item => !isOption(item))) {
612
- logWarning('When using grouped options infinite scroll can only be used on the last group.', {
613
- name: 'GlCollapsibleListbox'
614
- });
615
- }
616
- }
617
- }
618
- } : {})
619
- },
620
- mounted() {
621
- if (this.startOpened) {
622
- this.open();
623
- }
624
- this.observeScroll();
625
- },
626
- beforeDestroy() {
627
- var _this$scrollObserver;
628
- (_this$scrollObserver = this.scrollObserver) === null || _this$scrollObserver === void 0 ? void 0 : _this$scrollObserver.disconnect();
629
- },
630
- methods: {
631
- onFocusContent(event) {
632
- event.preventDefault();
633
- this.open();
634
- },
635
- open() {
636
- this.$refs.baseDropdown.open();
637
- },
638
- close() {
639
- this.$refs.baseDropdown.close();
640
- },
641
- groupClasses(index) {
642
- return index === 0 ? null : GROUP_TOP_BORDER_CLASSES;
643
- },
644
- onShow() {
645
- if (this.searchable) {
646
- this.focusSearchInput();
647
-
648
- /**
649
- * If the search string is not empty, highlight the first enabled item
650
- */
651
- if (this.searchHasOptions) {
652
- const firstEnabledIndex = this.getFirstEnabledIndex();
653
- this.nextFocusedItemIndex = firstEnabledIndex;
654
- // Set activeItemId for the first enabled item
655
- const firstItem = this.flattenedOptions[firstEnabledIndex];
656
- this.activeItemId = this.generateItemId(firstItem);
657
- }
658
- } else {
659
- var _this$flattenedOption2;
660
- const selectedIndex = this.selectedIndices[0];
661
- const initialIndex = selectedIndex !== undefined && !((_this$flattenedOption2 = this.flattenedOptions[selectedIndex]) !== null && _this$flattenedOption2 !== void 0 && _this$flattenedOption2.disabled) ? selectedIndex : this.getFirstEnabledIndex();
662
- this.focusItem(initialIndex, this.getFocusableListItemElements());
663
- }
664
- /**
665
- * Emitted when dropdown is shown
666
- *
667
- * @event shown
668
- */
669
- this.$emit(GL_DROPDOWN_SHOWN);
670
- },
671
- onHide(event) {
672
- /**
673
- * Emitted when dropdown is hidden
674
- *
675
- * @event hidden
676
- */
677
- this.$emit(GL_DROPDOWN_HIDDEN);
678
- this.nextFocusedItemIndex = null;
679
- // Emit native blur event for form validation in FormGroup
680
- this.$emit('blur', event);
681
- },
682
- getNextIndex(currentIndex, keyCode, totalLength) {
683
- const direction = keyCode === ARROW_UP ? -1 : 1;
684
- let nextIndex = currentIndex;
685
- for (let i = 0; i < totalLength; i += 1) {
686
- var _this$flattenedOption3;
687
- nextIndex += direction;
688
- if (nextIndex < 0) nextIndex = totalLength - 1;
689
- if (nextIndex >= totalLength) nextIndex = 0;
690
- if (!((_this$flattenedOption3 = this.flattenedOptions[nextIndex]) !== null && _this$flattenedOption3 !== void 0 && _this$flattenedOption3.disabled)) {
691
- return nextIndex;
692
- }
693
- }
694
- return currentIndex;
695
- },
696
- getFirstEnabledIndex() {
697
- return this.flattenedOptions.findIndex(item => !item.disabled);
698
- },
699
- getLastEnabledIndex() {
700
- return this.flattenedOptions.findLastIndex(item => !item.disabled);
701
- },
702
- handleListNavigation(keyCode, elements) {
703
- var _this$nextFocusedItem;
704
- const currentIndex = (_this$nextFocusedItem = this.nextFocusedItemIndex) !== null && _this$nextFocusedItem !== void 0 ? _this$nextFocusedItem : -1;
705
- const nextIndex = this.getNextIndex(currentIndex, keyCode, elements.length);
706
- this.focusItem(nextIndex, elements, this.searchable);
707
- },
708
- onKeydown(event) {
709
- const {
710
- code,
711
- target
712
- } = event;
713
- const elements = this.getFocusableListItemElements();
714
- if (elements.length < 1) return;
715
- const isSearchInput = target.matches(SEARCH_INPUT_SELECTOR);
716
- let stop = true;
717
- switch (code) {
718
- case HOME:
719
- // Jump to first enabled item if searchable or not in search input
720
- if (this.searchable || !isSearchInput) {
721
- this.focusItem(this.getFirstEnabledIndex(), elements, this.searchable);
722
- }
723
- break;
724
- case END:
725
- // Jump to last enabled item if searchable or not in search input
726
- if (this.searchable || !isSearchInput) {
727
- this.focusItem(this.getLastEnabledIndex(), elements, this.searchable);
728
- }
729
- break;
730
- case ARROW_UP:
731
- // Let default behavior work for non-searchable input
732
- if (isSearchInput && !this.searchable) {
733
- return;
734
- }
735
- this.handleListNavigation(ARROW_UP, elements);
736
- break;
737
- case ARROW_DOWN:
738
- // Focus first enabled item from search input, otherwise navigate down
739
- if (isSearchInput && !this.searchable) {
740
- this.focusItem(this.getFirstEnabledIndex(), elements);
741
- } else {
742
- this.handleListNavigation(ARROW_DOWN, elements);
743
- }
744
- break;
745
- case ENTER:
746
- if (isSearchInput) {
747
- // Toggle selection of highlighted item if one exists and is not disabled
748
- if (elements.length > 0 && this.nextFocusedItemIndex !== null) {
749
- const highlightedItem = this.flattenedOptions[this.nextFocusedItemIndex];
750
- if (!(highlightedItem !== null && highlightedItem !== void 0 && highlightedItem.disabled)) {
751
- this.onSelect(highlightedItem, !this.isSelected(highlightedItem));
752
- }
753
- }
754
- } else {
755
- stop = false;
756
- }
757
- break;
758
- default:
759
- // Allow default behavior for unhandled keys
760
- stop = false;
761
- break;
762
- }
763
-
764
- // Prevent default behavior for handled keys
765
- if (stop) {
766
- stopEvent(event);
767
- }
768
- },
769
- getFocusableListItemElements() {
770
- var _this$$refs$list;
771
- const items = (_this$$refs$list = this.$refs.list) === null || _this$$refs$list === void 0 ? void 0 : _this$$refs$list.querySelectorAll(ITEM_SELECTOR);
772
- return Array.from(items || []);
773
- },
774
- focusNextItem(event, elements, offset) {
775
- const {
776
- target
777
- } = event;
778
- const currentIndex = elements.indexOf(target);
779
- const nextIndex = clamp(currentIndex + offset, 0, elements.length - 1);
780
- this.focusItem(nextIndex, elements);
781
- },
782
- focusItem(index, elements) {
783
- let keepSearchFocused = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
784
- this.nextFocusedItemIndex = index;
785
-
786
- // Always update the activeItemId when focus changes
787
- const item = this.flattenedOptions[index];
788
- if (item) {
789
- this.activeItemId = this.generateItemId(item);
790
- } else {
791
- this.activeItemId = null;
792
- }
793
-
794
- // If we're not keeping the search focused, focus the item
795
- if (!keepSearchFocused) {
796
- var _elements$index;
797
- (_elements$index = elements[index]) === null || _elements$index === void 0 ? void 0 : _elements$index.focus();
798
- }
799
- this.$nextTick(() => {
800
- this.scrollActiveItemIntoView();
801
- });
802
- },
803
- focusSearchInput() {
804
- this.$refs.searchBox.focusInput();
805
- },
806
- onSelect(item, isSelected) {
807
- if (this.multiple) {
808
- this.onMultiSelect(item.value, isSelected);
809
- } else {
810
- this.onSingleSelect(item.value, isSelected);
811
- }
812
- },
813
- isHighlighted(item) {
814
- return this.nextFocusedItemIndex === this.flattenedOptions.indexOf(item);
815
- },
816
- isSelected(item) {
817
- return this.selectedValues.some(value => value === item.value);
818
- },
819
- isFocused(item) {
820
- return this.nextFocusedItemIndex === this.flattenedOptions.indexOf(item);
821
- },
822
- isDisabled(item) {
823
- return item.disabled;
824
- },
825
- onSingleSelect(value, isSelected) {
826
- if (isSelected) {
827
- /**
828
- * Emitted when selection is changed
829
- *
830
- * @event select
831
- */
832
- this.$emit('select', value);
833
- }
834
- this.closeAndFocus();
835
- },
836
- onMultiSelect(value, isSelected) {
837
- if (isSelected) {
838
- this.$emit('select', [...this.selectedValues, value]);
839
- } else {
840
- this.$emit('select', this.selectedValues.filter(selectedValue => selectedValue !== value));
841
- }
842
- },
843
- search(searchTerm) {
844
- /**
845
- * Emitted when the search query string is changed
846
- *
847
- * @event search
848
- * @type {string}
849
- */
850
- this.$emit('search', searchTerm);
851
- },
852
- onResetButtonClicked() {
853
- /**
854
- * Emitted when the reset button is clicked
855
- *
856
- * @event reset
857
- */
858
- this.$emit('reset');
859
- },
860
- onSelectAllButtonClicked() {
861
- /**
862
- * Emitted when the select all button is clicked
863
- *
864
- * @event select-all
865
- */
866
- this.$emit('select-all');
867
- },
868
- closeAndFocus() {
869
- this.$refs.baseDropdown.closeAndFocus();
870
- },
871
- onIntersectionObserverAppear() {
872
- /**
873
- * Emitted when bottom of listbox has been scrolled to.
874
- * Used for infinite scroll.
875
- *
876
- * @event bottom-reached
877
- */
878
- this.$emit('bottom-reached');
879
- },
880
- listboxItemKey(item) {
881
- if (item.value === null) {
882
- return ITEM_NULL_KEY;
883
- }
884
- return item.value;
885
- },
886
- listboxItemMoreItemsAriaAttributes(index) {
887
- if (this.totalItems === null) {
888
- return {};
889
- }
890
- return {
891
- 'aria-setsize': this.totalItems,
892
- 'aria-posinset': index + 1
893
- };
894
- },
895
- observeScroll() {
896
- var _this$scrollObserver2;
897
- const root = this.$refs.list;
898
- const options = {
899
- rootMargin: '8px',
900
- root,
901
- threshold: 1.0
902
- };
903
- (_this$scrollObserver2 = this.scrollObserver) === null || _this$scrollObserver2 === void 0 ? void 0 : _this$scrollObserver2.disconnect();
904
- const observer = new IntersectionObserver(entries => {
905
- entries.forEach(entry => {
906
- var _entry$target;
907
- this[(_entry$target = entry.target) === null || _entry$target === void 0 ? void 0 : _entry$target.$__visibilityProp] = entry.isIntersecting;
908
- });
909
- }, options);
910
- const topBoundary = this.$refs['top-boundary'];
911
- const bottomBoundary = this.$refs['bottom-boundary'];
912
- if (topBoundary) {
913
- topBoundary.$__visibilityProp = 'topBoundaryVisible';
914
- observer.observe(topBoundary);
915
- }
916
- if (bottomBoundary) {
917
- bottomBoundary.$__visibilityProp = 'bottomBoundaryVisible';
918
- observer.observe(bottomBoundary);
919
- }
920
- this.scrollObserver = observer;
921
- },
922
- isOption,
923
- generateItemId(item) {
924
- const key = item.value === null ? ITEM_NULL_KEY : item.value;
925
- if (!this.itemIds.has(key)) {
926
- this.itemIds.set(key, uniqueId('listbox-item-'));
927
- }
928
- return this.itemIds.get(key);
929
- },
930
- scrollActiveItemIntoView() {
931
- const listContainer = this.$refs.list;
932
- if (!this.activeItemId || !this.searchable || !listContainer) return;
933
- const activeElement = document.getElementById(this.activeItemId);
934
- if (!activeElement) return;
935
- const containerRect = listContainer.getBoundingClientRect();
936
- const itemRect = activeElement.getBoundingClientRect();
937
- const itemTop = activeElement.offsetTop;
938
- const padding = 30;
939
-
940
- // If item is above the visible area
941
- if (itemRect.top < containerRect.top) {
942
- listContainer.scrollTo({
943
- top: itemTop - padding,
944
- behavior: 'smooth'
945
- });
946
- }
947
-
948
- // If item is below the visible area
949
- else if (itemRect.bottom > containerRect.bottom) {
950
- listContainer.scrollTo({
951
- top: itemTop - containerRect.height + activeElement.offsetHeight + padding,
952
- behavior: 'smooth'
953
- });
954
- }
955
- }
956
- }
957
- };
958
-
959
- /* script */
960
- const __vue_script__ = script;
961
-
962
- /* template */
963
- var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('gl-base-dropdown',{ref:"baseDropdown",attrs:{"aria-haspopup":"listbox","active-item-id":_vm.activeItemId,"aria-labelledby":_vm.toggleAriaLabelledBy,"block":_vm.block,"has-searchable-listbox":_vm.searchable,"has-external-label":_vm.isInFormGroup,"listbox-id":_vm.listboxIdComputed,"state":_vm.state,"toggle-id":_vm.toggleIdComputed,"toggle-text":_vm.listboxToggleText,"toggle-class":_vm.toggleButtonClasses,"text-sr-only":_vm.textSrOnly,"category":_vm.category,"variant":_vm.variant,"size":_vm.size,"icon":_vm.icon,"disabled":_vm.disabled,"loading":_vm.loading,"no-caret":_vm.noCaret,"placement":_vm.placement,"offset":_vm.dropdownOffset,"fluid-width":_vm.fluidWidth,"panel-match-trigger-width":_vm.panelMatchTriggerWidth,"positioning-strategy":_vm.positioningStrategy},on:_vm._d({},[_vm.$options.events.GL_DROPDOWN_FOCUS_CONTENT,_vm.onFocusContent,_vm.$options.events.GL_DROPDOWN_SHOWN,_vm.onShow,_vm.$options.events.GL_DROPDOWN_HIDDEN,_vm.onHide]),scopedSlots:_vm._u([(_vm.hasCustomToggle)?{key:"toggle",fn:function(slotProps){return [_vm._t("toggle",null,null,slotProps)]}}:null,{key:"default",fn:function(ref){
964
- var visible = ref.visible;
965
- return [(_vm.headerText)?_c('div',{staticClass:"gl-flex gl-min-h-8 gl-items-center !gl-p-4",class:_vm.$options.HEADER_ITEMS_BORDER_CLASSES},[_c('div',{staticClass:"gl-grow gl-pr-2 gl-text-sm gl-font-bold gl-text-strong",attrs:{"id":_vm.headerId,"data-testid":"listbox-header-text"}},[_vm._v("\n "+_vm._s(_vm.headerText)+"\n ")]),_vm._v(" "),(_vm.showResetButton)?_c('gl-button',{staticClass:"!gl-m-0 !gl-w-auto gl-max-w-1/2 gl-flex-shrink-0 gl-text-ellipsis !gl-px-2 !gl-text-sm focus:!gl-focus-inset",attrs:{"category":"tertiary","size":"small","data-testid":"listbox-reset-button"},on:{"click":_vm.onResetButtonClicked}},[_vm._v("\n "+_vm._s(_vm.resetButtonLabel)+"\n ")]):_vm._e(),_vm._v(" "),(_vm.showSelectAllButton)?_c('gl-button',{staticClass:"!gl-m-0 !gl-w-auto gl-max-w-1/2 gl-flex-shrink-0 gl-text-ellipsis !gl-px-2 !gl-text-sm focus:!gl-focus-inset",attrs:{"category":"tertiary","size":"small","data-testid":"listbox-select-all-button"},on:{"click":_vm.onSelectAllButtonClicked}},[_vm._v("\n "+_vm._s(_vm.showSelectAllButtonLabel)+"\n ")]):_vm._e()],1):_vm._e(),_vm._v(" "),(_vm.searchable)?_c('div',{class:_vm.$options.HEADER_ITEMS_BORDER_CLASSES},[_c('gl-listbox-search-input',{ref:"searchBox",class:{ 'gl-listbox-topmost': !_vm.headerText },attrs:{"id":_vm.searchInputId,"data-testid":"listbox-search-input","role":"combobox","aria-expanded":String(visible),"aria-controls":_vm.listboxId,"aria-activedescendant":_vm.activeItemId,"aria-haspopup":"listbox","placeholder":_vm.searchPlaceholder},on:{"input":_vm.search,"keydown":[function($event){if(!$event.type.indexOf('key')&&_vm._k($event.keyCode,"enter",13,$event.key,"Enter")){ return null; }$event.preventDefault();},_vm.onKeydown]},model:{value:(_vm.searchStr),callback:function ($$v) {_vm.searchStr=$$v;},expression:"searchStr"}}),_vm._v(" "),(_vm.searching)?_c('gl-loading-icon',{staticClass:"gl-my-3",attrs:{"data-testid":"listbox-search-loader","size":"md"}}):_vm._e()],1):_vm._e(),_vm._v(" "),(_vm.showList)?_c(_vm.listboxTag,{ref:"list",tag:"component",staticClass:"gl-new-dropdown-contents gl-new-dropdown-contents-with-scrim-overlay",class:_vm.listboxClasses,attrs:{"id":_vm.listboxId,"aria-busy":_vm.isBusy,"aria-labelledby":_vm.listboxAriaLabelledByID,"aria-multiselectable":_vm.multiple ? 'true' : undefined,"role":"listbox","tabindex":"0"},on:{"keydown":_vm.onKeydown}},[_c(_vm.itemTag,{tag:"component",staticClass:"top-scrim-wrapper",attrs:{"aria-hidden":"true","data-testid":"top-scrim"}},[_c('div',{staticClass:"top-scrim",class:{ 'top-scrim-light': !_vm.hasHeader, 'top-scrim-dark': _vm.hasHeader }})]),_vm._v(" "),_c(_vm.itemTag,{ref:"top-boundary",tag:"component",attrs:{"aria-hidden":"true"}}),_vm._v(" "),_vm._l((_vm.items),function(item,index){return [(_vm.isOption(item))?[_c('gl-listbox-item',_vm._b({key:_vm.listboxItemKey(item),attrs:{"id":_vm.generateItemId(item),"data-testid":("listbox-item-" + (item.value)),"is-highlighted":_vm.isHighlighted(item),"is-selected":_vm.isSelected(item),"is-focused":_vm.isFocused(item),"is-check-centered":_vm.isCheckCentered,"is-disabled":_vm.isDisabled(item)},on:{"select":function($event){return _vm.onSelect(item, $event)}}},'gl-listbox-item',_vm.listboxItemMoreItemsAriaAttributes(index),false),[_vm._t("list-item",function(){return [_vm._v("\n "+_vm._s(item.text)+"\n ")]},{"item":item})],2)]:[_c('gl-listbox-group',{key:item.text,class:_vm.groupClasses(index),attrs:{"name":item.text,"text-sr-only":item.textSrOnly},scopedSlots:_vm._u([(_vm.$scopedSlots['group-label'])?{key:"group-label",fn:function(){return [_vm._t("group-label",null,{"group":item})]},proxy:true}:null],null,true)},[_vm._v(" "),_vm._l((item.options),function(option){return _c('gl-listbox-item',{key:_vm.listboxItemKey(option),attrs:{"id":_vm.generateItemId(option),"data-testid":("listbox-item-" + (option.value)),"is-highlighted":_vm.isHighlighted(option),"is-selected":_vm.isSelected(option),"is-focused":_vm.isFocused(option),"is-check-centered":_vm.isCheckCentered,"is-disabled":_vm.isDisabled(option)},on:{"select":function($event){return _vm.onSelect(option, $event)}}},[_vm._t("list-item",function(){return [_vm._v("\n "+_vm._s(option.text)+"\n ")]},{"item":option})],2)})],2)]]}),_vm._v(" "),(_vm.infiniteScrollLoading)?_c(_vm.itemTag,{tag:"component"},[_c('gl-loading-icon',{staticClass:"gl-my-3",attrs:{"data-testid":"listbox-infinite-scroll-loader","size":"md"}})],1):_vm._e(),_vm._v(" "),(_vm.showIntersectionObserver)?_c('gl-intersection-observer',{on:{"appear":_vm.onIntersectionObserverAppear}}):_vm._e(),_vm._v(" "),_c(_vm.itemTag,{ref:"bottom-boundary",tag:"component",attrs:{"aria-hidden":"true"}}),_vm._v(" "),_c(_vm.itemTag,{tag:"component",staticClass:"bottom-scrim-wrapper",attrs:{"aria-hidden":"true","data-testid":"bottom-scrim"}},[_c('div',{staticClass:"bottom-scrim",class:{ '!gl-rounded-none': _vm.hasFooter }})])],2):_vm._e(),_vm._v(" "),(_vm.announceSRSearchResults)?_c('span',{staticClass:"gl-sr-only",attrs:{"data-testid":"listbox-number-of-results","aria-live":"assertive"}},[_vm._t("search-summary-sr-only",function(){return [_vm._v("\n "+_vm._s(_vm.srOnlyResultsLabel(_vm.flattenedOptions.length))+"\n ")]})],2):_vm._e(),_vm._v(" "),(_vm.isBusy)?_c('span',{staticClass:"gl-sr-only",attrs:{"aria-live":"polite","data-testid":"listbox-loading-announcement"}},[_vm._v("\n "+_vm._s(_vm.loadingAnnouncementText)+"\n ")]):(_vm.showNoResultsText)?_c('div',{staticClass:"gl-py-3 gl-pl-7 gl-pr-5 gl-text-base gl-text-subtle",attrs:{"aria-live":"assertive","data-testid":"listbox-no-results-text"}},[_vm._v("\n "+_vm._s(_vm.noResultsText)+"\n ")]):_vm._e(),_vm._v(" "),_vm._t("footer")]}}],null,true)})};
966
- var __vue_staticRenderFns__ = [];
967
-
968
- /* style */
969
- const __vue_inject_styles__ = undefined;
970
- /* scoped */
971
- const __vue_scope_id__ = undefined;
972
- /* module identifier */
973
- const __vue_module_identifier__ = undefined;
974
- /* functional template */
975
- const __vue_is_functional_template__ = false;
976
- /* style inject */
977
-
978
- /* style inject SSR */
979
-
980
- /* style inject shadow dom */
981
-
982
-
983
-
984
- const __vue_component__ = /*#__PURE__*/__vue_normalize__(
985
- { render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ },
986
- __vue_inject_styles__,
987
- __vue_script__,
988
- __vue_scope_id__,
989
- __vue_is_functional_template__,
990
- __vue_module_identifier__,
991
- false,
992
- undefined,
993
- undefined,
994
- undefined
995
- );
996
-
997
- export { ITEM_NULL_KEY, ITEM_SELECTOR, SEARCH_INPUT_SELECTOR, __vue_component__ as default };