@gitlab/ui 131.2.0 → 131.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (402) hide show
  1. package/package.json +11 -11
  2. package/src/components/base/form/form_checkbox/form_checkbox.vue +1 -2
  3. package/src/components/base/form/form_checkbox/form_checkbox_group.vue +1 -1
  4. package/src/components/base/form/form_radio/form_radio.vue +1 -1
  5. package/src/components/base/form/form_radio_group/form_radio_group.vue +1 -1
  6. package/src/components/base/table/table.scss +8 -0
  7. package/src/components/utilities/truncate/truncate.scss +3 -1
  8. package/src/scss/mixins.scss +3 -1
  9. package/src/utils/equality_utils.js +82 -0
  10. package/src/vendor/bootstrap-vue/src/components/button/button-close.js +20 -5
  11. package/src/vendor/bootstrap-vue/src/components/button/button.js +36 -8
  12. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.js +12 -4
  13. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.js +16 -5
  14. package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown.js +99 -24
  15. package/src/vendor/bootstrap-vue/src/components/form/form-text.js +20 -5
  16. package/src/vendor/bootstrap-vue/src/components/form/form.js +20 -5
  17. package/src/vendor/bootstrap-vue/src/components/layout/form-row.js +5 -2
  18. package/src/vendor/bootstrap-vue/src/components/table/tbody.js +10 -3
  19. package/src/vendor/bootstrap-vue/src/components/table/td.js +28 -7
  20. package/src/vendor/bootstrap-vue/src/components/table/tfoot.js +5 -2
  21. package/src/vendor/bootstrap-vue/src/components/table/thead.js +5 -2
  22. package/src/vendor/bootstrap-vue/src/components/table/tr.js +5 -2
  23. package/src/vendor/bootstrap-vue/src/components/tabs/tab.js +51 -12
  24. package/tailwind.defaults.js +10 -1
  25. package/dist/charts.js +0 -13
  26. package/dist/components/base/accordion/accordion.js +0 -69
  27. package/dist/components/base/accordion/accordion_item.js +0 -160
  28. package/dist/components/base/accordion/constants.js +0 -3
  29. package/dist/components/base/alert/alert.js +0 -263
  30. package/dist/components/base/animated_icon/animated_chevron_down_up_icon.js +0 -45
  31. package/dist/components/base/animated_icon/animated_chevron_lg_down_up_icon.js +0 -45
  32. package/dist/components/base/animated_icon/animated_chevron_lg_right_down_icon.js +0 -45
  33. package/dist/components/base/animated_icon/animated_chevron_right_down_icon.js +0 -45
  34. package/dist/components/base/animated_icon/animated_duo_chat_icon.js +0 -45
  35. package/dist/components/base/animated_icon/animated_loader_icon.js +0 -45
  36. package/dist/components/base/animated_icon/animated_notifications_icon.js +0 -45
  37. package/dist/components/base/animated_icon/animated_sidebar_icon.js +0 -45
  38. package/dist/components/base/animated_icon/animated_smile_icon.js +0 -45
  39. package/dist/components/base/animated_icon/animated_sort_icon.js +0 -45
  40. package/dist/components/base/animated_icon/animated_star_icon.js +0 -45
  41. package/dist/components/base/animated_icon/animated_todo_icon.js +0 -45
  42. package/dist/components/base/animated_icon/animated_upload_icon.js +0 -45
  43. package/dist/components/base/animated_icon/base_animated_icon.js +0 -77
  44. package/dist/components/base/attribute_list/attribute_list.js +0 -100
  45. package/dist/components/base/avatar/avatar.js +0 -175
  46. package/dist/components/base/avatar/utils.js +0 -17
  47. package/dist/components/base/avatar_labeled/avatar_labeled.js +0 -198
  48. package/dist/components/base/avatar_link/avatar_link.js +0 -47
  49. package/dist/components/base/avatars_inline/avatars_inline.js +0 -139
  50. package/dist/components/base/badge/badge.js +0 -197
  51. package/dist/components/base/banner/banner.js +0 -149
  52. package/dist/components/base/breadcrumb/breadcrumb.js +0 -282
  53. package/dist/components/base/breadcrumb/breadcrumb_item.js +0 -96
  54. package/dist/components/base/broadcast_message/broadcast_message.js +0 -113
  55. package/dist/components/base/broadcast_message/constants.js +0 -5
  56. package/dist/components/base/button/button.js +0 -419
  57. package/dist/components/base/button_group/button_group.js +0 -53
  58. package/dist/components/base/card/card.js +0 -69
  59. package/dist/components/base/collapse/collapse.js +0 -163
  60. package/dist/components/base/color_mode_toggle/color_mode_toggle.js +0 -92
  61. package/dist/components/base/datepicker/datepicker.js +0 -475
  62. package/dist/components/base/daterange_picker/daterange_picker.js +0 -394
  63. package/dist/components/base/drawer/drawer.js +0 -156
  64. package/dist/components/base/dropdown/dropdown.js +0 -330
  65. package/dist/components/base/dropdown/dropdown_divider.js +0 -48
  66. package/dist/components/base/dropdown/dropdown_form.js +0 -48
  67. package/dist/components/base/dropdown/dropdown_item.js +0 -175
  68. package/dist/components/base/dropdown/dropdown_section_header.js +0 -48
  69. package/dist/components/base/dropdown/dropdown_text.js +0 -48
  70. package/dist/components/base/filtered_search/common_story_options.js +0 -14
  71. package/dist/components/base/filtered_search/filtered_search.js +0 -428
  72. package/dist/components/base/filtered_search/filtered_search_suggestion.js +0 -95
  73. package/dist/components/base/filtered_search/filtered_search_suggestion_list.js +0 -139
  74. package/dist/components/base/filtered_search/filtered_search_term.js +0 -217
  75. package/dist/components/base/filtered_search/filtered_search_token.js +0 -383
  76. package/dist/components/base/filtered_search/filtered_search_token_segment.js +0 -444
  77. package/dist/components/base/filtered_search/filtered_search_utils.js +0 -241
  78. package/dist/components/base/form/form.js +0 -43
  79. package/dist/components/base/form/form_character_count/form_character_count.js +0 -107
  80. package/dist/components/base/form/form_checkbox/form_checkbox.js +0 -343
  81. package/dist/components/base/form/form_checkbox/form_checkbox_group.js +0 -186
  82. package/dist/components/base/form/form_combobox/constants.js +0 -55
  83. package/dist/components/base/form/form_combobox/form_combobox.js +0 -239
  84. package/dist/components/base/form/form_date/form_date.js +0 -143
  85. package/dist/components/base/form/form_fields/form_field_validator.js +0 -93
  86. package/dist/components/base/form/form_fields/form_fields.js +0 -289
  87. package/dist/components/base/form/form_fields/form_fields_loop.js +0 -75
  88. package/dist/components/base/form/form_fields/mappers.js +0 -13
  89. package/dist/components/base/form/form_fields/validators.js +0 -48
  90. package/dist/components/base/form/form_group/form_group.js +0 -119
  91. package/dist/components/base/form/form_input/form_input.js +0 -695
  92. package/dist/components/base/form/form_input_group/form_input_group.js +0 -120
  93. package/dist/components/base/form/form_input_group/form_input_group_mixin.js +0 -41
  94. package/dist/components/base/form/form_radio/form_radio.js +0 -259
  95. package/dist/components/base/form/form_radio_group/form_radio_group.js +0 -187
  96. package/dist/components/base/form/form_select/constants.js +0 -12
  97. package/dist/components/base/form/form_select/form_select.js +0 -96
  98. package/dist/components/base/form/form_textarea/form_textarea.js +0 -166
  99. package/dist/components/base/form/input_group_text/input_group_text.js +0 -43
  100. package/dist/components/base/icon/icon.js +0 -113
  101. package/dist/components/base/illustration/illustration.js +0 -80
  102. package/dist/components/base/infinite_scroll/infinite_scroll.js +0 -196
  103. package/dist/components/base/keyset_pagination/keyset_pagination.js +0 -152
  104. package/dist/components/base/label/label.js +0 -174
  105. package/dist/components/base/link/link.js +0 -332
  106. package/dist/components/base/loading_icon/loading_icon.js +0 -120
  107. package/dist/components/base/markdown/markdown.js +0 -50
  108. package/dist/components/base/modal/modal.js +0 -259
  109. package/dist/components/base/new_dropdowns/base_dropdown/base_dropdown.js +0 -716
  110. package/dist/components/base/new_dropdowns/base_dropdown/constants.js +0 -5
  111. package/dist/components/base/new_dropdowns/base_dropdown/dropdown_container.js +0 -32
  112. package/dist/components/base/new_dropdowns/constants.js +0 -24
  113. package/dist/components/base/new_dropdowns/disclosure/constants.js +0 -8
  114. package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown.js +0 -400
  115. package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown_group.js +0 -112
  116. package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown_item.js +0 -196
  117. package/dist/components/base/new_dropdowns/disclosure/mock_data.js +0 -168
  118. package/dist/components/base/new_dropdowns/disclosure/utils.js +0 -84
  119. package/dist/components/base/new_dropdowns/listbox/listbox.js +0 -997
  120. package/dist/components/base/new_dropdowns/listbox/listbox_group.js +0 -58
  121. package/dist/components/base/new_dropdowns/listbox/listbox_item.js +0 -112
  122. package/dist/components/base/new_dropdowns/listbox/listbox_search_input.js +0 -94
  123. package/dist/components/base/new_dropdowns/listbox/mock_data.js +0 -131
  124. package/dist/components/base/new_dropdowns/listbox/utils.js +0 -33
  125. package/dist/components/base/pagination/pagination.js +0 -397
  126. package/dist/components/base/path/data.js +0 -34
  127. package/dist/components/base/path/path.js +0 -177
  128. package/dist/components/base/popover/popover.js +0 -142
  129. package/dist/components/base/progress_bar/progress_bar.js +0 -117
  130. package/dist/components/base/search_box_by_click/search_box_by_click.js +0 -245
  131. package/dist/components/base/search_box_by_type/search_box_by_type.js +0 -187
  132. package/dist/components/base/segmented_control/segmented_control.js +0 -73
  133. package/dist/components/base/skeleton_loader/skeleton_loader.js +0 -232
  134. package/dist/components/base/sorting/sorting.js +0 -180
  135. package/dist/components/base/table/constants.js +0 -5
  136. package/dist/components/base/table/table.js +0 -187
  137. package/dist/components/base/table_lite/table_lite.js +0 -80
  138. package/dist/components/base/tabs/constants.js +0 -3
  139. package/dist/components/base/tabs/tab/tab.js +0 -113
  140. package/dist/components/base/tabs/tabs/scrollable_tabs.js +0 -162
  141. package/dist/components/base/tabs/tabs/tabs.js +0 -223
  142. package/dist/components/base/toast/index.js +0 -66
  143. package/dist/components/base/toast/toast.js +0 -125
  144. package/dist/components/base/toast/toaster.js +0 -87
  145. package/dist/components/base/toggle/toggle.js +0 -178
  146. package/dist/components/base/token/token.js +0 -97
  147. package/dist/components/base/token_selector/helpers.js +0 -5
  148. package/dist/components/base/token_selector/token_container.js +0 -160
  149. package/dist/components/base/token_selector/token_selector.js +0 -454
  150. package/dist/components/base/token_selector/token_selector_dropdown.js +0 -223
  151. package/dist/components/base/tooltip/tooltip.js +0 -54
  152. package/dist/components/charts/area/area.js +0 -329
  153. package/dist/components/charts/bar/bar.js +0 -207
  154. package/dist/components/charts/chart/chart.js +0 -215
  155. package/dist/components/charts/column/column.js +0 -221
  156. package/dist/components/charts/discrete_scatter/discrete_scatter.js +0 -199
  157. package/dist/components/charts/gauge/gauge.js +0 -205
  158. package/dist/components/charts/heatmap/heatmap.js +0 -299
  159. package/dist/components/charts/heatmap/index.js +0 -2
  160. package/dist/components/charts/legend/legend.js +0 -245
  161. package/dist/components/charts/line/line.js +0 -340
  162. package/dist/components/charts/series_label/series_label.js +0 -101
  163. package/dist/components/charts/shared/tooltip/tooltip.js +0 -369
  164. package/dist/components/charts/shared/tooltip/tooltip_default_format/tooltip_default_format.js +0 -53
  165. package/dist/components/charts/single_stat/single_stat.js +0 -164
  166. package/dist/components/charts/sparkline/sparkline.js +0 -299
  167. package/dist/components/charts/stacked_column/stacked_column.js +0 -380
  168. package/dist/components/dashboards/dashboard_layout/dashboard_layout.js +0 -125
  169. package/dist/components/dashboards/dashboard_layout/grid_layout/grid_layout.js +0 -326
  170. package/dist/components/dashboards/dashboard_layout/validators.js +0 -14
  171. package/dist/components/dashboards/dashboard_panel/dashboard_panel.js +0 -236
  172. package/dist/components/dashboards/mock_data.js +0 -49
  173. package/dist/components/experimental/experiment_badge/constants.js +0 -4
  174. package/dist/components/experimental/experiment_badge/experiment_badge.js +0 -102
  175. package/dist/components/extended/multi_step_form_template/multi_step_form_template.js +0 -87
  176. package/dist/components/index.js +0 -107
  177. package/dist/components/mixins/button_mixin.js +0 -11
  178. package/dist/components/mixins/safe_link_mixin.js +0 -30
  179. package/dist/components/mixins/tooltip_mixin.js +0 -21
  180. package/dist/components/regions/dashboard_skeleton/dashboard_skeleton.js +0 -53
  181. package/dist/components/regions/empty_state/empty_state.js +0 -181
  182. package/dist/components/shared_components/clear_icon_button/clear_icon_button.js +0 -64
  183. package/dist/components/shared_components/clipboard_button/clipboard_button.js +0 -100
  184. package/dist/components/shared_components/close_button/close_button.js +0 -55
  185. package/dist/components/utilities/animated_number/animated_number.js +0 -131
  186. package/dist/components/utilities/friendly_wrap/friendly_wrap.js +0 -75
  187. package/dist/components/utilities/intersection_observer/intersection_observer.js +0 -88
  188. package/dist/components/utilities/intersperse/intersperse.js +0 -104
  189. package/dist/components/utilities/sprintf/sprintf.js +0 -171
  190. package/dist/components/utilities/truncate/constants.js +0 -8
  191. package/dist/components/utilities/truncate/truncate.js +0 -154
  192. package/dist/components/utilities/truncate_text/constants.js +0 -7
  193. package/dist/components/utilities/truncate_text/truncate_text.js +0 -146
  194. package/dist/config.js +0 -53
  195. package/dist/directives/hover_load/hover_load.js +0 -45
  196. package/dist/directives/index.js +0 -8
  197. package/dist/directives/modal.js +0 -1
  198. package/dist/directives/outside/outside.js +0 -149
  199. package/dist/directives/resize_observer/resize_observer.js +0 -58
  200. package/dist/directives/safe_html/constants.js +0 -6
  201. package/dist/directives/safe_html/safe_html.js +0 -39
  202. package/dist/directives/safe_link/mock_data.js +0 -10
  203. package/dist/directives/safe_link/safe_link.js +0 -67
  204. package/dist/directives/tooltip/container.js +0 -7
  205. package/dist/directives/tooltip/tooltip.js +0 -18
  206. package/dist/index.css +0 -7
  207. package/dist/index.css.map +0 -1
  208. package/dist/index.js +0 -2
  209. package/dist/tailwind.css +0 -2
  210. package/dist/tailwind.css.map +0 -1
  211. package/dist/tokens/build/js/tokens.dark.js +0 -1410
  212. package/dist/tokens/build/js/tokens.js +0 -1410
  213. package/dist/tokens/common_story_options.js +0 -29
  214. package/dist/tokens/tokens_story.js +0 -76
  215. package/dist/utils/breakpoints.js +0 -20
  216. package/dist/utils/charts/config.js +0 -616
  217. package/dist/utils/charts/constants.js +0 -69
  218. package/dist/utils/charts/mock_data.js +0 -191
  219. package/dist/utils/charts/story_config.js +0 -24
  220. package/dist/utils/charts/theme.js +0 -200
  221. package/dist/utils/charts/utils.js +0 -54
  222. package/dist/utils/constants.js +0 -333
  223. package/dist/utils/data_utils.js +0 -19
  224. package/dist/utils/datetime_utility.js +0 -61
  225. package/dist/utils/i18n.js +0 -65
  226. package/dist/utils/is_slot_empty.js +0 -34
  227. package/dist/utils/number_utils.js +0 -132
  228. package/dist/utils/play_utils.js +0 -11
  229. package/dist/utils/set_utils.js +0 -25
  230. package/dist/utils/stories_constants.js +0 -29
  231. package/dist/utils/stories_utils.js +0 -62
  232. package/dist/utils/story_decorators/container.js +0 -19
  233. package/dist/utils/string_utils.js +0 -69
  234. package/dist/utils/svgs/svg_paths.js +0 -7
  235. package/dist/utils/test_utils.js +0 -33
  236. package/dist/utils/use_fake_date.js +0 -29
  237. package/dist/utils/use_mock_intersection_observer.js +0 -105
  238. package/dist/utils/utils.js +0 -205
  239. package/dist/utils.js +0 -5
  240. package/dist/vendor/bootstrap-vue/src/bv-config.js +0 -8
  241. package/dist/vendor/bootstrap-vue/src/components/button/button-close.js +0 -66
  242. package/dist/vendor/bootstrap-vue/src/components/button/button.js +0 -176
  243. package/dist/vendor/bootstrap-vue/src/components/button/index.js +0 -2
  244. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-divider.js +0 -41
  245. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-form.js +0 -52
  246. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-group.js +0 -75
  247. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-header.js +0 -52
  248. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-item-button.js +0 -85
  249. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.js +0 -89
  250. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.js +0 -49
  251. package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown.js +0 -195
  252. package/dist/vendor/bootstrap-vue/src/components/dropdown/index.js +0 -8
  253. package/dist/vendor/bootstrap-vue/src/components/form/form-invalid-feedback.js +0 -53
  254. package/dist/vendor/bootstrap-vue/src/components/form/form-text.js +0 -40
  255. package/dist/vendor/bootstrap-vue/src/components/form/form-valid-feedback.js +0 -53
  256. package/dist/vendor/bootstrap-vue/src/components/form/form.js +0 -41
  257. package/dist/vendor/bootstrap-vue/src/components/form/index.js +0 -4
  258. package/dist/vendor/bootstrap-vue/src/components/form-group/form-group.js +0 -348
  259. package/dist/vendor/bootstrap-vue/src/components/form-group/index.js +0 -1
  260. package/dist/vendor/bootstrap-vue/src/components/form-select/form-select-option-group.js +0 -54
  261. package/dist/vendor/bootstrap-vue/src/components/form-select/form-select-option.js +0 -41
  262. package/dist/vendor/bootstrap-vue/src/components/form-select/form-select.js +0 -143
  263. package/dist/vendor/bootstrap-vue/src/components/form-select/helpers/mixin-options.js +0 -56
  264. package/dist/vendor/bootstrap-vue/src/components/form-select/index.js +0 -3
  265. package/dist/vendor/bootstrap-vue/src/components/form-textarea/form-textarea.js +0 -217
  266. package/dist/vendor/bootstrap-vue/src/components/form-textarea/index.js +0 -1
  267. package/dist/vendor/bootstrap-vue/src/components/layout/col.js +0 -156
  268. package/dist/vendor/bootstrap-vue/src/components/layout/form-row.js +0 -31
  269. package/dist/vendor/bootstrap-vue/src/components/layout/index.js +0 -2
  270. package/dist/vendor/bootstrap-vue/src/components/link/index.js +0 -1
  271. package/dist/vendor/bootstrap-vue/src/components/link/link.js +0 -283
  272. package/dist/vendor/bootstrap-vue/src/components/modal/helpers/bv-modal-event.class.js +0 -21
  273. package/dist/vendor/bootstrap-vue/src/components/modal/helpers/modal-manager.js +0 -212
  274. package/dist/vendor/bootstrap-vue/src/components/modal/index.js +0 -1
  275. package/dist/vendor/bootstrap-vue/src/components/modal/modal.js +0 -887
  276. package/dist/vendor/bootstrap-vue/src/components/popover/helpers/bv-popover-template.js +0 -55
  277. package/dist/vendor/bootstrap-vue/src/components/popover/helpers/bv-popover.js +0 -31
  278. package/dist/vendor/bootstrap-vue/src/components/popover/index.js +0 -1
  279. package/dist/vendor/bootstrap-vue/src/components/popover/popover.js +0 -49
  280. package/dist/vendor/bootstrap-vue/src/components/table/helpers/constants.js +0 -22
  281. package/dist/vendor/bootstrap-vue/src/components/table/helpers/default-sort-compare.js +0 -64
  282. package/dist/vendor/bootstrap-vue/src/components/table/helpers/filter-event.js +0 -40
  283. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-bottom-row.js +0 -43
  284. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-busy.js +0 -83
  285. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-caption.js +0 -50
  286. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-colgroup.js +0 -32
  287. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-empty.js +0 -82
  288. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-filtering.js +0 -274
  289. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-items.js +0 -154
  290. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-pagination.js +0 -44
  291. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-provider.js +0 -191
  292. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-selectable.js +0 -213
  293. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-sorting.js +0 -275
  294. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-stacked.js +0 -39
  295. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-table-renderer.js +0 -186
  296. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tbody-row.js +0 -338
  297. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tbody.js +0 -243
  298. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tfoot.js +0 -50
  299. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-thead.js +0 -218
  300. package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-top-row.js +0 -42
  301. package/dist/vendor/bootstrap-vue/src/components/table/helpers/normalize-fields.js +0 -86
  302. package/dist/vendor/bootstrap-vue/src/components/table/helpers/sanitize-row.js +0 -32
  303. package/dist/vendor/bootstrap-vue/src/components/table/helpers/stringify-record-values.js +0 -11
  304. package/dist/vendor/bootstrap-vue/src/components/table/helpers/text-selection-active.js +0 -14
  305. package/dist/vendor/bootstrap-vue/src/components/table/index.js +0 -9
  306. package/dist/vendor/bootstrap-vue/src/components/table/table-lite.js +0 -51
  307. package/dist/vendor/bootstrap-vue/src/components/table/table-simple.js +0 -44
  308. package/dist/vendor/bootstrap-vue/src/components/table/table.js +0 -67
  309. package/dist/vendor/bootstrap-vue/src/components/table/tbody.js +0 -109
  310. package/dist/vendor/bootstrap-vue/src/components/table/td.js +0 -183
  311. package/dist/vendor/bootstrap-vue/src/components/table/tfoot.js +0 -93
  312. package/dist/vendor/bootstrap-vue/src/components/table/th.js +0 -26
  313. package/dist/vendor/bootstrap-vue/src/components/table/thead.js +0 -96
  314. package/dist/vendor/bootstrap-vue/src/components/table/tr.js +0 -118
  315. package/dist/vendor/bootstrap-vue/src/components/tabs/index.js +0 -2
  316. package/dist/vendor/bootstrap-vue/src/components/tabs/tab.js +0 -199
  317. package/dist/vendor/bootstrap-vue/src/components/tabs/tabs.js +0 -601
  318. package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-popper.js +0 -251
  319. package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip-template.js +0 -118
  320. package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip.js +0 -932
  321. package/dist/vendor/bootstrap-vue/src/components/tooltip/index.js +0 -1
  322. package/dist/vendor/bootstrap-vue/src/components/tooltip/tooltip.js +0 -269
  323. package/dist/vendor/bootstrap-vue/src/components/transition/bv-transition.js +0 -103
  324. package/dist/vendor/bootstrap-vue/src/components/transporter/transporter.js +0 -205
  325. package/dist/vendor/bootstrap-vue/src/constants/components.js +0 -55
  326. package/dist/vendor/bootstrap-vue/src/constants/config.js +0 -11
  327. package/dist/vendor/bootstrap-vue/src/constants/env.js +0 -36
  328. package/dist/vendor/bootstrap-vue/src/constants/events.js +0 -56
  329. package/dist/vendor/bootstrap-vue/src/constants/key-codes.js +0 -11
  330. package/dist/vendor/bootstrap-vue/src/constants/popper.js +0 -10
  331. package/dist/vendor/bootstrap-vue/src/constants/props.js +0 -24
  332. package/dist/vendor/bootstrap-vue/src/constants/regex.js +0 -35
  333. package/dist/vendor/bootstrap-vue/src/constants/safe-types.js +0 -15
  334. package/dist/vendor/bootstrap-vue/src/constants/slots.js +0 -36
  335. package/dist/vendor/bootstrap-vue/src/directives/modal/index.js +0 -1
  336. package/dist/vendor/bootstrap-vue/src/directives/modal/modal.js +0 -112
  337. package/dist/vendor/bootstrap-vue/src/directives/tooltip/index.js +0 -1
  338. package/dist/vendor/bootstrap-vue/src/directives/tooltip/tooltip.js +0 -265
  339. package/dist/vendor/bootstrap-vue/src/directives/visible/index.js +0 -1
  340. package/dist/vendor/bootstrap-vue/src/directives/visible/visible.js +0 -187
  341. package/dist/vendor/bootstrap-vue/src/mixins/attrs.js +0 -5
  342. package/dist/vendor/bootstrap-vue/src/mixins/click-out.js +0 -54
  343. package/dist/vendor/bootstrap-vue/src/mixins/dropdown.js +0 -470
  344. package/dist/vendor/bootstrap-vue/src/mixins/focus-in.js +0 -46
  345. package/dist/vendor/bootstrap-vue/src/mixins/form-control.js +0 -73
  346. package/dist/vendor/bootstrap-vue/src/mixins/form-custom.js +0 -26
  347. package/dist/vendor/bootstrap-vue/src/mixins/form-options.js +0 -91
  348. package/dist/vendor/bootstrap-vue/src/mixins/form-selection.js +0 -62
  349. package/dist/vendor/bootstrap-vue/src/mixins/form-size.js +0 -26
  350. package/dist/vendor/bootstrap-vue/src/mixins/form-state.js +0 -50
  351. package/dist/vendor/bootstrap-vue/src/mixins/form-text.js +0 -293
  352. package/dist/vendor/bootstrap-vue/src/mixins/form-validity.js +0 -50
  353. package/dist/vendor/bootstrap-vue/src/mixins/has-listener.js +0 -29
  354. package/dist/vendor/bootstrap-vue/src/mixins/id.js +0 -57
  355. package/dist/vendor/bootstrap-vue/src/mixins/listen-on-document.js +0 -63
  356. package/dist/vendor/bootstrap-vue/src/mixins/listen-on-root.js +0 -121
  357. package/dist/vendor/bootstrap-vue/src/mixins/listen-on-window.js +0 -63
  358. package/dist/vendor/bootstrap-vue/src/mixins/listeners.js +0 -25
  359. package/dist/vendor/bootstrap-vue/src/mixins/model.js +0 -10
  360. package/dist/vendor/bootstrap-vue/src/mixins/normalize-slot.js +0 -30
  361. package/dist/vendor/bootstrap-vue/src/mixins/scoped-style.js +0 -18
  362. package/dist/vendor/bootstrap-vue/src/mixins/use-parent.js +0 -14
  363. package/dist/vendor/bootstrap-vue/src/utils/array.js +0 -28
  364. package/dist/vendor/bootstrap-vue/src/utils/bv-event.class.js +0 -60
  365. package/dist/vendor/bootstrap-vue/src/utils/cache.js +0 -60
  366. package/dist/vendor/bootstrap-vue/src/utils/clone-deep.js +0 -18
  367. package/dist/vendor/bootstrap-vue/src/utils/config-set.js +0 -86
  368. package/dist/vendor/bootstrap-vue/src/utils/config.js +0 -71
  369. package/dist/vendor/bootstrap-vue/src/utils/create-new-child-component.js +0 -133
  370. package/dist/vendor/bootstrap-vue/src/utils/css-escape.js +0 -70
  371. package/dist/vendor/bootstrap-vue/src/utils/dom.js +0 -298
  372. package/dist/vendor/bootstrap-vue/src/utils/element-to-vue-instance-registry.js +0 -28
  373. package/dist/vendor/bootstrap-vue/src/utils/env.js +0 -16
  374. package/dist/vendor/bootstrap-vue/src/utils/events.js +0 -78
  375. package/dist/vendor/bootstrap-vue/src/utils/get-event-root.js +0 -5
  376. package/dist/vendor/bootstrap-vue/src/utils/get-instance-from-directive.js +0 -3
  377. package/dist/vendor/bootstrap-vue/src/utils/get-scope-id.js +0 -9
  378. package/dist/vendor/bootstrap-vue/src/utils/get.js +0 -63
  379. package/dist/vendor/bootstrap-vue/src/utils/html.js +0 -16
  380. package/dist/vendor/bootstrap-vue/src/utils/identity.js +0 -3
  381. package/dist/vendor/bootstrap-vue/src/utils/inspect.js +0 -35
  382. package/dist/vendor/bootstrap-vue/src/utils/locale.js +0 -19
  383. package/dist/vendor/bootstrap-vue/src/utils/loose-equal.js +0 -59
  384. package/dist/vendor/bootstrap-vue/src/utils/loose-index-of.js +0 -13
  385. package/dist/vendor/bootstrap-vue/src/utils/math.js +0 -9
  386. package/dist/vendor/bootstrap-vue/src/utils/memoize.js +0 -14
  387. package/dist/vendor/bootstrap-vue/src/utils/model.js +0 -33
  388. package/dist/vendor/bootstrap-vue/src/utils/noop.js +0 -3
  389. package/dist/vendor/bootstrap-vue/src/utils/normalize-slot.js +0 -51
  390. package/dist/vendor/bootstrap-vue/src/utils/number.js +0 -23
  391. package/dist/vendor/bootstrap-vue/src/utils/object.js +0 -72
  392. package/dist/vendor/bootstrap-vue/src/utils/observe-dom.js +0 -76
  393. package/dist/vendor/bootstrap-vue/src/utils/on-instance-destroy.js +0 -22
  394. package/dist/vendor/bootstrap-vue/src/utils/plugins.js +0 -124
  395. package/dist/vendor/bootstrap-vue/src/utils/props.js +0 -67
  396. package/dist/vendor/bootstrap-vue/src/utils/router.js +0 -150
  397. package/dist/vendor/bootstrap-vue/src/utils/safe-vue-instance.js +0 -14
  398. package/dist/vendor/bootstrap-vue/src/utils/stable-sort.js +0 -28
  399. package/dist/vendor/bootstrap-vue/src/utils/string.js +0 -47
  400. package/dist/vendor/bootstrap-vue/src/utils/stringify-object-values.js +0 -31
  401. package/dist/vendor/bootstrap-vue/src/utils/warn.js +0 -45
  402. package/dist/vendor/bootstrap-vue/src/vue.js +0 -55
@@ -1,397 +0,0 @@
1
- import { isFunction, debounce, range } from 'lodash-es';
2
- import { breakpoints, GlBreakpointInstance } from '../../../utils/breakpoints';
3
- import { alignOptions, resizeDebounceTime } from '../../../utils/constants';
4
- import { translate, sprintf } from '../../../utils/i18n';
5
- import GlIcon from '../icon/icon';
6
- import GlLink from '../link/link';
7
- import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js';
8
-
9
- const pageRange = (from, to) => range(from, to + 1, 1);
10
- var script = {
11
- name: 'GlPagination',
12
- components: {
13
- GlLink,
14
- GlIcon
15
- },
16
- model: {
17
- prop: 'value',
18
- event: 'input'
19
- },
20
- props: {
21
- /**
22
- * The current page number. Must be greater than 0.
23
- */
24
- value: {
25
- type: Number,
26
- required: false,
27
- default: 1,
28
- validator: x => x > 0
29
- },
30
- /**
31
- * Number of items per page
32
- */
33
- perPage: {
34
- type: Number,
35
- required: false,
36
- default: 20,
37
- validator: x => x > 0
38
- },
39
- /**
40
- * Total number of items
41
- */
42
- totalItems: {
43
- type: Number,
44
- required: false,
45
- default: 0
46
- },
47
- /**
48
- * The object must contain the xs, sm, md and default keys
49
- */
50
- limits: {
51
- type: Object,
52
- required: false,
53
- default: () => ({
54
- xs: 0,
55
- sm: 3,
56
- md: 9,
57
- default: 9
58
- }),
59
- validator: value => {
60
- const missingSizes = Object.keys(breakpoints).filter(size => !value[size]).length;
61
- return missingSizes === 0 ? true : value.default;
62
- }
63
- },
64
- /**
65
- * A function that receives the page number and that returns a string representing the page URL
66
- */
67
- linkGen: {
68
- type: Function,
69
- required: false,
70
- default: null
71
- },
72
- /**
73
- * When using the compact pagination, use this prop to pass the previous page number
74
- */
75
- prevPage: {
76
- type: Number,
77
- required: false,
78
- default: null
79
- },
80
- /**
81
- * When using the compact pagination, use this prop to pass the next page number
82
- */
83
- nextPage: {
84
- type: Number,
85
- required: false,
86
- default: null
87
- },
88
- /**
89
- * Text for the ellipsis (overridden by "ellipsis-left" and "ellipsis-right" slots)
90
- */
91
- ellipsisText: {
92
- type: String,
93
- required: false,
94
- default: '…'
95
- },
96
- /**
97
- * aria-label for the nav
98
- */
99
- labelNav: {
100
- type: String,
101
- required: false,
102
- default: translate('GlPagination.nav', 'Pagination')
103
- },
104
- /**
105
- * aria-label for the first page item
106
- */
107
- labelFirstPage: {
108
- type: String,
109
- required: false,
110
- default: translate('GlPagination.labelFirstPage', 'Go to first page')
111
- },
112
- /**
113
- * aria-label for the previous page item
114
- */
115
- labelPrevPage: {
116
- type: String,
117
- required: false,
118
- default: translate('GlPagination.labelPrevPage', 'Go to previous page')
119
- },
120
- /**
121
- * aria-label for the next page item
122
- */
123
- labelNextPage: {
124
- type: String,
125
- required: false,
126
- default: translate('GlPagination.labelNextPage', 'Go to next page')
127
- },
128
- /**
129
- * aria-label for the last page item
130
- */
131
- labelLastPage: {
132
- type: String,
133
- required: false,
134
- default: translate('GlPagination.labelLastPage', 'Go to last page')
135
- },
136
- /**
137
- * aria-label getter for numbered page items, defaults to "Go to page <page_number>"
138
- */
139
- labelPage: {
140
- // note: `Function` support is for legacy reasons
141
- type: [Function, String],
142
- required: false,
143
- default: translate('GlPagination.labelPage', 'Go to page %{page}')
144
- },
145
- /**
146
- * Controls the component\'s horizontal alignment, value should be one of "left", "center", "right" or "fill"
147
- */
148
- align: {
149
- type: String,
150
- required: false,
151
- default: alignOptions.left,
152
- validator: value => Object.keys(alignOptions).includes(value)
153
- }
154
- },
155
- data() {
156
- return {
157
- breakpoint: GlBreakpointInstance.getBreakpointSize(),
158
- // If total pages count is below or equal to minTotalPagesToCollapse, collapsing is disabled
159
- minTotalPagesToCollapse: 4
160
- };
161
- },
162
- computed: {
163
- isVisible() {
164
- return this.totalPages > 1 || this.isCompactPagination;
165
- },
166
- isLinkBased() {
167
- return isFunction(this.linkGen);
168
- },
169
- paginationLimit() {
170
- return typeof this.limits[this.breakpoint] !== 'undefined' ? this.limits[this.breakpoint] : this.limits.default;
171
- },
172
- maxAdjacentPages() {
173
- return Math.max(Math.ceil((this.paginationLimit - 1) / 2), 0);
174
- },
175
- totalPages() {
176
- return Math.ceil(this.totalItems / this.perPage);
177
- },
178
- isFillAlign() {
179
- return this.align === alignOptions.fill;
180
- },
181
- wrapperClasses() {
182
- const classes = [];
183
- if (this.align === alignOptions.center) {
184
- classes.push('gl-justify-center');
185
- }
186
- if (this.align === alignOptions.right) {
187
- classes.push('gl-justify-end');
188
- }
189
- if (this.isFillAlign) {
190
- classes.push('gl-text-center');
191
- }
192
- return classes;
193
- },
194
- shouldCollapseLeftSide() {
195
- const diff = this.value - this.maxAdjacentPages;
196
-
197
- // Magic 3: prevents collapsing a single page on the left side
198
- return diff >= this.maxAdjacentPages && diff > 3 && this.totalPages > this.minTotalPagesToCollapse;
199
- },
200
- shouldCollapseRightSide() {
201
- // Magic 2: prevents collapsing a single page on the right side
202
- const diff = this.totalPages - 2 - this.value;
203
- return diff > this.maxAdjacentPages && this.totalPages > this.minTotalPagesToCollapse;
204
- },
205
- visibleItems() {
206
- let items = [];
207
- if (!this.isCompactPagination) {
208
- let firstPage = this.shouldCollapseLeftSide ? this.value - this.maxAdjacentPages : 1;
209
- // If we're on last page, show at least one page to the left
210
- firstPage = Math.min(firstPage, this.totalPages - 1);
211
- let lastPage = this.shouldCollapseRightSide ? this.value + this.maxAdjacentPages : this.totalPages;
212
- // If we're on first page, show at least one page to the right
213
- lastPage = Math.max(lastPage, 2);
214
-
215
- // Default numbered items
216
- items = pageRange(firstPage, lastPage).map(page => this.getPageItem(page));
217
- if (this.shouldCollapseLeftSide) {
218
- items.splice(0, 0, this.getPageItem(1, this.labelFirstPage), this.getEllipsisItem('left'));
219
- }
220
- if (this.shouldCollapseRightSide) {
221
- items.push(this.getEllipsisItem('right'), this.getPageItem(this.totalPages, this.labelLastPage));
222
- }
223
- }
224
- return items;
225
- },
226
- isCompactPagination() {
227
- return Boolean(!this.totalItems && (this.prevPage || this.nextPage));
228
- },
229
- prevPageIsDisabled() {
230
- return this.pageIsDisabled(this.value - 1);
231
- },
232
- nextPageIsDisabled() {
233
- return this.pageIsDisabled(this.value + 1);
234
- },
235
- prevPageAriaLabel() {
236
- return this.prevPageIsDisabled ? false : this.labelPrevPage || this.labelForPage(this.value - 1);
237
- },
238
- nextPageAriaLabel() {
239
- return this.nextPageIsDisabled ? false : this.labelNextPage || this.labelForPage(this.value + 1);
240
- },
241
- prevPageHref() {
242
- if (this.prevPageIsDisabled) return false;
243
- if (this.isLinkBased) return this.linkGen(this.value - 1);
244
- return '#';
245
- },
246
- nextPageHref() {
247
- if (this.nextPageIsDisabled) return false;
248
- if (this.isLinkBased) return this.linkGen(this.value + 1);
249
- return '#';
250
- }
251
- },
252
- created() {
253
- this.resizeDebounced = debounce(this.setBreakpoint, resizeDebounceTime);
254
- window.addEventListener('resize', this.resizeDebounced);
255
- },
256
- beforeDestroy() {
257
- window.removeEventListener('resize', this.resizeDebounced);
258
- },
259
- methods: {
260
- labelForPage(page) {
261
- if (isFunction(this.labelPage)) {
262
- return this.labelPage(page);
263
- }
264
- return sprintf(this.labelPage, {
265
- page
266
- });
267
- },
268
- setBreakpoint() {
269
- this.breakpoint = GlBreakpointInstance.getBreakpointSize();
270
- },
271
- pageIsDisabled(page) {
272
- return page < 1 || this.isCompactPagination && page > this.value && !this.nextPage || !this.isCompactPagination && page > this.totalPages;
273
- },
274
- getPageItem(page) {
275
- let label = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
276
- const commonAttrs = {
277
- 'aria-label': label || this.labelForPage(page),
278
- href: '#',
279
- class: []
280
- };
281
- const isActivePage = page === this.value;
282
- const isDisabled = this.pageIsDisabled(page);
283
- const attrs = {
284
- ...commonAttrs
285
- };
286
- const listeners = {};
287
- if (isActivePage) {
288
- attrs.class.push('active');
289
- attrs['aria-current'] = 'page';
290
- }
291
- // Disable previous and/or next buttons if needed
292
- if (this.isLinkBased) {
293
- attrs.href = this.linkGen(page);
294
- }
295
- listeners.click = e => this.handleClick(e, page);
296
- return {
297
- content: page,
298
- component: isDisabled ? 'span' : GlLink,
299
- disabled: isDisabled,
300
- key: `page_${page}`,
301
- slot: 'page-number',
302
- slotData: {
303
- page,
304
- active: isActivePage,
305
- disabled: isDisabled
306
- },
307
- attrs,
308
- listeners
309
- };
310
- },
311
- getEllipsisItem(side) {
312
- return {
313
- content: this.ellipsisText,
314
- key: `ellipsis_${side}`,
315
- slot: `ellipsis-${side}`,
316
- component: 'span',
317
- disabled: true,
318
- slotData: {},
319
- listeners: {}
320
- };
321
- },
322
- handleClick(event, value) {
323
- if (!this.isLinkBased) {
324
- event.preventDefault();
325
- /**
326
- * Emitted when the page changes
327
- * @event input
328
- * @arg {number} value The page that just got loaded
329
- */
330
- this.$emit('input', value);
331
- }
332
- },
333
- handlePrevious(event, value) {
334
- this.handleClick(event, value);
335
- /**
336
- * Emitted when the "previous" button is clicked
337
- * @event previous
338
- */
339
- this.$emit('previous');
340
- },
341
- handleNext(event, value) {
342
- this.handleClick(event, value);
343
- /**
344
- * Emitted when the "next" button is clicked
345
- * @event next
346
- */
347
- this.$emit('next');
348
- }
349
- }
350
- };
351
-
352
- /* script */
353
- const __vue_script__ = script;
354
-
355
- /* template */
356
- var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return (_vm.isVisible)?_c('nav',{staticClass:"gl-pagination",attrs:{"aria-label":_vm.labelNav}},[_c('ul',{class:_vm.wrapperClasses},[_c('li',{class:{
357
- disabled: _vm.prevPageIsDisabled,
358
- 'gl-flex-auto': _vm.isFillAlign,
359
- },attrs:{"aria-hidden":_vm.prevPageIsDisabled,"data-testid":"gl-pagination-li"}},[_c(_vm.prevPageIsDisabled ? 'span' : 'a',{tag:"component",staticClass:"gl-pagination-item",attrs:{"data-testid":"gl-pagination-prev","aria-label":_vm.prevPageAriaLabel,"href":_vm.prevPageHref},on:{"click":function($event){!_vm.prevPageIsDisabled ? _vm.handlePrevious($event, _vm.value - 1) : null;}}},[_vm._t("previous",function(){return [_c('gl-icon',{attrs:{"name":"chevron-lg-left"}})]},null,{ page: _vm.value - 1, disabled: _vm.prevPageIsDisabled })],2)],1),_vm._v(" "),_vm._l((_vm.visibleItems),function(item){return _c('li',{key:item.key,class:{
360
- disabled: item.disabled,
361
- 'gl-flex-auto': _vm.isFillAlign,
362
- },attrs:{"data-testid":"gl-pagination-li"}},[_c(item.component,_vm._g(_vm._b({tag:"component",staticClass:"gl-pagination-item",attrs:{"data-testid":"gl-pagination-item","size":"md","aria-disabled":item.disabled}},'component',item.attrs,false),item.listeners),[_vm._t(item.slot,function(){return [_vm._v(_vm._s(item.content))]},null,item.slotData)],2)],1)}),_vm._v(" "),_c('li',{class:{
363
- disabled: _vm.nextPageIsDisabled,
364
- 'gl-flex-auto': _vm.isFillAlign,
365
- },attrs:{"aria-hidden":_vm.nextPageIsDisabled,"data-testid":"gl-pagination-li"}},[_c(_vm.nextPageIsDisabled ? 'span' : 'a',{tag:"component",staticClass:"gl-pagination-item",attrs:{"data-testid":"gl-pagination-next","aria-label":_vm.nextPageAriaLabel,"href":_vm.nextPageHref},on:{"click":function($event){!_vm.nextPageIsDisabled ? _vm.handleNext($event, _vm.value + 1) : null;}}},[_vm._t("next",function(){return [_c('gl-icon',{attrs:{"name":"chevron-lg-right"}})]},null,{ page: _vm.value + 1, disabled: _vm.nextPageIsDisabled })],2)],1)],2)]):_vm._e()};
366
- var __vue_staticRenderFns__ = [];
367
-
368
- /* style */
369
- const __vue_inject_styles__ = undefined;
370
- /* scoped */
371
- const __vue_scope_id__ = undefined;
372
- /* module identifier */
373
- const __vue_module_identifier__ = undefined;
374
- /* functional template */
375
- const __vue_is_functional_template__ = false;
376
- /* style inject */
377
-
378
- /* style inject SSR */
379
-
380
- /* style inject shadow dom */
381
-
382
-
383
-
384
- const __vue_component__ = /*#__PURE__*/__vue_normalize__(
385
- { render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ },
386
- __vue_inject_styles__,
387
- __vue_script__,
388
- __vue_scope_id__,
389
- __vue_is_functional_template__,
390
- __vue_module_identifier__,
391
- false,
392
- undefined,
393
- undefined,
394
- undefined
395
- );
396
-
397
- export { __vue_component__ as default };
@@ -1,34 +0,0 @@
1
- const mockPathItems = () => [{
2
- title: 'First',
3
- metric: '1d'
4
- }, {
5
- title: 'Second',
6
- metric: '2d'
7
- }, {
8
- title: 'Third',
9
- metric: '3d'
10
- }, {
11
- title: 'Fourth',
12
- metric: '4d'
13
- }, {
14
- title: 'Fifth',
15
- metric: '5d'
16
- }, {
17
- title: 'Sixth',
18
- metric: '6d'
19
- }, {
20
- title: 'Seventh',
21
- metric: '7d'
22
- }, {
23
- title: 'Eighth',
24
- metric: '8d',
25
- disabled: true
26
- }, {
27
- title: 'Ninth',
28
- metric: '9d'
29
- }, {
30
- title: 'Tenth',
31
- metric: '10d'
32
- }];
33
-
34
- export { mockPathItems };
@@ -1,177 +0,0 @@
1
- import iconSpriteInfo from '@gitlab/svgs/dist/icons.json';
2
- import { uniqueId, findLast } from 'lodash-es';
3
- import { GlResizeObserverDirective } from '../../../directives/resize_observer/resize_observer';
4
- import GlIcon from '../icon/icon';
5
- import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js';
6
-
7
- const BOUNDARY_WIDTH = 40;
8
- const PATH_ITEM_CLASS = 'gl-path-button';
9
- const PATH_ACTIVE_ITEM_CLASS = 'gl-path-active-item';
10
- var script = {
11
- name: 'GlPath',
12
- components: {
13
- GlIcon
14
- },
15
- directives: {
16
- GlResizeObserverDirective
17
- },
18
- props: {
19
- /**
20
- * A list of path items in the form:
21
- * ```
22
- * {
23
- * title: String, required
24
- * metric: Any, optional
25
- * icon: String, optional
26
- * disabled: Boolean, optional
27
- * }
28
- * ```
29
- */
30
- items: {
31
- type: Array,
32
- required: false,
33
- default: () => []
34
- },
35
- /**
36
- * The items' background color.
37
- */
38
- backgroundColor: {
39
- type: String,
40
- required: false,
41
- default: 'rgba(0,0,0,0)'
42
- }
43
- },
44
- data() {
45
- return {
46
- selectedIndex: 0,
47
- width: 0,
48
- scrollLeft: 0
49
- };
50
- },
51
- computed: {
52
- entireListVisible() {
53
- return this.width >= this.getScrollWidth();
54
- },
55
- displayScrollLeft() {
56
- return !this.entireListVisible && this.scrollLeft;
57
- },
58
- displayScrollRight() {
59
- const scrollOffset = this.getScrollWidth() - this.width;
60
- return !this.entireListVisible && scrollOffset !== this.scrollLeft;
61
- },
62
- rightHandBoundary() {
63
- return this.width - BOUNDARY_WIDTH + this.scrollLeft;
64
- },
65
- leftHandBoundary() {
66
- return this.scrollLeft + BOUNDARY_WIDTH;
67
- }
68
- },
69
- watch: {
70
- items: {
71
- immediate: true,
72
- handler(items) {
73
- const selectedIndex = items.findIndex(item => item.selected);
74
- this.selectedIndex = selectedIndex > 0 ? selectedIndex : 0;
75
- }
76
- }
77
- },
78
- beforeCreate() {
79
- this.pathUuid = uniqueId('path-');
80
- },
81
- methods: {
82
- pathItemClass(index) {
83
- return index === this.selectedIndex ? `${PATH_ITEM_CLASS} ${PATH_ACTIVE_ITEM_CLASS}` : PATH_ITEM_CLASS;
84
- },
85
- onItemClicked(selectedIndex) {
86
- this.selectedIndex = selectedIndex;
87
- /**
88
- * Emitted when an item is selected.
89
- */
90
- this.$emit('selected', this.items[this.selectedIndex]);
91
- },
92
- handleResize(_ref) {
93
- let {
94
- contentRect: {
95
- width
96
- }
97
- } = _ref;
98
- this.width = width;
99
- },
100
- scrollPathLeft() {
101
- const previousItemToScollTo = findLast(this.$refs.pathListItems, listItem => {
102
- return listItem.offsetLeft < this.leftHandBoundary;
103
- });
104
- const availableWidth = this.width - previousItemToScollTo.offsetWidth - BOUNDARY_WIDTH - BOUNDARY_WIDTH;
105
- let scrollTo = previousItemToScollTo.offsetLeft - BOUNDARY_WIDTH - availableWidth;
106
- if (scrollTo < 0) {
107
- scrollTo = 0;
108
- }
109
- this.scrollPath(scrollTo);
110
- },
111
- scrollPathRight() {
112
- const nextItemToScollTo = this.$refs.pathListItems.find(listItem => listItem.offsetLeft + listItem.offsetWidth > this.rightHandBoundary);
113
- let scrollTo = nextItemToScollTo.offsetLeft - BOUNDARY_WIDTH;
114
- if (scrollTo > this.getScrollWidth() - this.width) {
115
- scrollTo = this.getScrollWidth() - this.width;
116
- }
117
- this.scrollPath(scrollTo);
118
- },
119
- scrollPath(scrollTo) {
120
- this.$refs.pathNavList.scrollTo({
121
- left: scrollTo,
122
- behavior: 'smooth'
123
- });
124
- this.scrollLeft = scrollTo;
125
- },
126
- getScrollWidth() {
127
- return this.$refs.pathNavList ? this.$refs.pathNavList.scrollWidth : 0;
128
- },
129
- shouldDisplayIcon(icon) {
130
- return icon && iconSpriteInfo.icons.includes(icon);
131
- },
132
- pathId(index) {
133
- return `${this.pathUuid}-item-${index}`;
134
- },
135
- getAriaCurrentAttr(index) {
136
- return index === this.selectedIndex;
137
- }
138
- }
139
- };
140
-
141
- /* script */
142
- const __vue_script__ = script;
143
-
144
- /* template */
145
- var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('div',{directives:[{name:"gl-resize-observer-directive",rawName:"v-gl-resize-observer-directive",value:(_vm.handleResize),expression:"handleResize"}],staticClass:"gl-path-nav",style:({ '--path-bg-color': _vm.backgroundColor }),attrs:{"data-testid":"gl-path-nav"}},[_c('span',{directives:[{name:"show",rawName:"v-show",value:(_vm.displayScrollLeft),expression:"displayScrollLeft"}],staticClass:"gl-path-fade gl-path-fade-left"},[_c('button',{staticClass:"gl-clear-icon-button",attrs:{"aria-label":"Scroll left"},on:{"click":_vm.scrollPathLeft}},[_c('gl-icon',{attrs:{"size":32,"name":"chevron-left"}})],1)]),_vm._v(" "),_c('ul',{ref:"pathNavList",staticClass:"gl-path-nav-list"},_vm._l((_vm.items),function(item,index){return _c('li',{key:index,ref:"pathListItems",refInFor:true,staticClass:"gl-path-nav-list-item"},[_c('button',{class:_vm.pathItemClass(index),attrs:{"id":_vm.pathId(index),"aria-current":_vm.getAriaCurrentAttr(index),"category":item.disabled ? 'tertiary' : undefined,"disabled":item.disabled},on:{"click":function($event){return _vm.onItemClicked(index)}}},[(_vm.shouldDisplayIcon(item.icon))?_c('gl-icon',{staticClass:"gl-mr-2",attrs:{"name":item.icon,"data-testid":"gl-path-item-icon"}}):_vm._e(),_vm._v(_vm._s(item.title)),(item.metric)?_c('span',{staticClass:"gl-pl-2 gl-font-normal"},[_vm._v(_vm._s(item.metric))]):_vm._e()],1),_vm._v(" "),_vm._t("default",null,{"pathItem":item,"pathId":_vm.pathId(index)})],2)}),0),_vm._v(" "),_c('span',{directives:[{name:"show",rawName:"v-show",value:(_vm.displayScrollRight),expression:"displayScrollRight"}],staticClass:"gl-path-fade gl-path-fade-right"},[_c('button',{staticClass:"gl-clear-icon-button",attrs:{"aria-label":"Scroll right"},on:{"click":_vm.scrollPathRight}},[_c('gl-icon',{attrs:{"size":32,"name":"chevron-right"}})],1)])])};
146
- var __vue_staticRenderFns__ = [];
147
-
148
- /* style */
149
- const __vue_inject_styles__ = undefined;
150
- /* scoped */
151
- const __vue_scope_id__ = undefined;
152
- /* module identifier */
153
- const __vue_module_identifier__ = undefined;
154
- /* functional template */
155
- const __vue_is_functional_template__ = false;
156
- /* style inject */
157
-
158
- /* style inject SSR */
159
-
160
- /* style inject shadow dom */
161
-
162
-
163
-
164
- const __vue_component__ = /*#__PURE__*/__vue_normalize__(
165
- { render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ },
166
- __vue_inject_styles__,
167
- __vue_script__,
168
- __vue_scope_id__,
169
- __vue_is_functional_template__,
170
- __vue_module_identifier__,
171
- false,
172
- undefined,
173
- undefined,
174
- undefined
175
- );
176
-
177
- export { __vue_component__ as default };