@gitlab/ui 131.3.0 → 131.3.1

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