@gitlab/ui 132.0.1 → 132.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/charts.js +13 -0
- package/dist/components/base/accordion/accordion.js +69 -0
- package/dist/components/base/accordion/accordion_item.js +160 -0
- package/dist/components/base/accordion/constants.js +3 -0
- package/dist/components/base/alert/alert.js +263 -0
- package/dist/components/base/animated_icon/animated_chevron_down_up_icon.js +45 -0
- package/dist/components/base/animated_icon/animated_chevron_lg_down_up_icon.js +45 -0
- package/dist/components/base/animated_icon/animated_chevron_lg_right_down_icon.js +45 -0
- package/dist/components/base/animated_icon/animated_chevron_right_down_icon.js +45 -0
- package/dist/components/base/animated_icon/animated_duo_chat_icon.js +45 -0
- package/dist/components/base/animated_icon/animated_loader_icon.js +45 -0
- package/dist/components/base/animated_icon/animated_notifications_icon.js +45 -0
- package/dist/components/base/animated_icon/animated_sidebar_icon.js +45 -0
- package/dist/components/base/animated_icon/animated_smile_icon.js +45 -0
- package/dist/components/base/animated_icon/animated_sort_icon.js +45 -0
- package/dist/components/base/animated_icon/animated_star_icon.js +45 -0
- package/dist/components/base/animated_icon/animated_todo_icon.js +45 -0
- package/dist/components/base/animated_icon/animated_upload_icon.js +45 -0
- package/dist/components/base/animated_icon/base_animated_icon.js +77 -0
- package/dist/components/base/attribute_list/attribute_list.js +100 -0
- package/dist/components/base/avatar/avatar.js +175 -0
- package/dist/components/base/avatar/utils.js +17 -0
- package/dist/components/base/avatar_labeled/avatar_labeled.js +198 -0
- package/dist/components/base/avatar_link/avatar_link.js +47 -0
- package/dist/components/base/avatars_inline/avatars_inline.js +139 -0
- package/dist/components/base/badge/badge.js +197 -0
- package/dist/components/base/banner/banner.js +149 -0
- package/dist/components/base/breadcrumb/breadcrumb.js +282 -0
- package/dist/components/base/breadcrumb/breadcrumb_item.js +96 -0
- package/dist/components/base/broadcast_message/broadcast_message.js +113 -0
- package/dist/components/base/broadcast_message/constants.js +5 -0
- package/dist/components/base/button/button.js +419 -0
- package/dist/components/base/button_group/button_group.js +53 -0
- package/dist/components/base/card/card.js +69 -0
- package/dist/components/base/collapse/collapse.js +163 -0
- package/dist/components/base/color_mode_toggle/color_mode_toggle.js +92 -0
- package/dist/components/base/datepicker/datepicker.js +475 -0
- package/dist/components/base/daterange_picker/daterange_picker.js +394 -0
- package/dist/components/base/drawer/drawer.js +156 -0
- package/dist/components/base/dropdown/dropdown.js +330 -0
- package/dist/components/base/dropdown/dropdown_divider.js +48 -0
- package/dist/components/base/dropdown/dropdown_form.js +48 -0
- package/dist/components/base/dropdown/dropdown_item.js +175 -0
- package/dist/components/base/dropdown/dropdown_section_header.js +48 -0
- package/dist/components/base/dropdown/dropdown_text.js +48 -0
- package/dist/components/base/filtered_search/common_story_options.js +14 -0
- package/dist/components/base/filtered_search/filtered_search.js +428 -0
- package/dist/components/base/filtered_search/filtered_search_suggestion.js +95 -0
- package/dist/components/base/filtered_search/filtered_search_suggestion_list.js +139 -0
- package/dist/components/base/filtered_search/filtered_search_term.js +217 -0
- package/dist/components/base/filtered_search/filtered_search_token.js +383 -0
- package/dist/components/base/filtered_search/filtered_search_token_segment.js +444 -0
- package/dist/components/base/filtered_search/filtered_search_utils.js +241 -0
- package/dist/components/base/form/form.js +43 -0
- package/dist/components/base/form/form_character_count/form_character_count.js +107 -0
- package/dist/components/base/form/form_checkbox/form_checkbox.js +342 -0
- package/dist/components/base/form/form_checkbox/form_checkbox_group.js +188 -0
- package/dist/components/base/form/form_combobox/constants.js +55 -0
- package/dist/components/base/form/form_combobox/form_combobox.js +239 -0
- package/dist/components/base/form/form_date/form_date.js +143 -0
- package/dist/components/base/form/form_fields/form_field_validator.js +93 -0
- package/dist/components/base/form/form_fields/form_fields.js +289 -0
- package/dist/components/base/form/form_fields/form_fields_loop.js +75 -0
- package/dist/components/base/form/form_fields/mappers.js +13 -0
- package/dist/components/base/form/form_fields/validators.js +48 -0
- package/dist/components/base/form/form_group/form_group.js +119 -0
- package/dist/components/base/form/form_input/form_input.js +695 -0
- package/dist/components/base/form/form_input_group/form_input_group.js +120 -0
- package/dist/components/base/form/form_input_group/form_input_group_mixin.js +41 -0
- package/dist/components/base/form/form_radio/form_radio.js +259 -0
- package/dist/components/base/form/form_radio_group/form_radio_group.js +189 -0
- package/dist/components/base/form/form_select/constants.js +12 -0
- package/dist/components/base/form/form_select/form_select.js +96 -0
- package/dist/components/base/form/form_textarea/form_textarea.js +166 -0
- package/dist/components/base/form/input_group_text/input_group_text.js +43 -0
- package/dist/components/base/icon/icon.js +113 -0
- package/dist/components/base/illustration/illustration.js +80 -0
- package/dist/components/base/infinite_scroll/infinite_scroll.js +196 -0
- package/dist/components/base/keyset_pagination/keyset_pagination.js +152 -0
- package/dist/components/base/label/label.js +174 -0
- package/dist/components/base/link/link.js +330 -0
- package/dist/components/base/loading_icon/loading_icon.js +120 -0
- package/dist/components/base/markdown/markdown.js +50 -0
- package/dist/components/base/modal/modal.js +259 -0
- package/dist/components/base/new_dropdowns/base_dropdown/base_dropdown.js +716 -0
- package/dist/components/base/new_dropdowns/base_dropdown/constants.js +5 -0
- package/dist/components/base/new_dropdowns/base_dropdown/dropdown_container.js +32 -0
- package/dist/components/base/new_dropdowns/constants.js +24 -0
- package/dist/components/base/new_dropdowns/disclosure/constants.js +8 -0
- package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown.js +400 -0
- package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown_group.js +112 -0
- package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown_item.js +196 -0
- package/dist/components/base/new_dropdowns/disclosure/mock_data.js +168 -0
- package/dist/components/base/new_dropdowns/disclosure/utils.js +84 -0
- package/dist/components/base/new_dropdowns/listbox/listbox.js +997 -0
- package/dist/components/base/new_dropdowns/listbox/listbox_group.js +58 -0
- package/dist/components/base/new_dropdowns/listbox/listbox_item.js +112 -0
- package/dist/components/base/new_dropdowns/listbox/listbox_search_input.js +94 -0
- package/dist/components/base/new_dropdowns/listbox/mock_data.js +131 -0
- package/dist/components/base/new_dropdowns/listbox/utils.js +33 -0
- package/dist/components/base/pagination/pagination.js +397 -0
- package/dist/components/base/path/data.js +34 -0
- package/dist/components/base/path/path.js +177 -0
- package/dist/components/base/popover/popover.js +142 -0
- package/dist/components/base/progress_bar/progress_bar.js +117 -0
- package/dist/components/base/search_box_by_click/search_box_by_click.js +245 -0
- package/dist/components/base/search_box_by_type/search_box_by_type.js +187 -0
- package/dist/components/base/segmented_control/segmented_control.js +73 -0
- package/dist/components/base/skeleton_loader/skeleton_loader.js +232 -0
- package/dist/components/base/sorting/sorting.js +180 -0
- package/dist/components/base/table/constants.js +5 -0
- package/dist/components/base/table/table.js +187 -0
- package/dist/components/base/table_lite/table_lite.js +80 -0
- package/dist/components/base/tabs/constants.js +3 -0
- package/dist/components/base/tabs/tab/tab.js +113 -0
- package/dist/components/base/tabs/tabs/scrollable_tabs.js +162 -0
- package/dist/components/base/tabs/tabs/tabs.js +223 -0
- package/dist/components/base/toast/index.js +66 -0
- package/dist/components/base/toast/toast.js +125 -0
- package/dist/components/base/toast/toaster.js +87 -0
- package/dist/components/base/toggle/toggle.js +178 -0
- package/dist/components/base/token/token.js +97 -0
- package/dist/components/base/token_selector/helpers.js +5 -0
- package/dist/components/base/token_selector/token_container.js +160 -0
- package/dist/components/base/token_selector/token_selector.js +454 -0
- package/dist/components/base/token_selector/token_selector_dropdown.js +223 -0
- package/dist/components/base/tooltip/tooltip.js +54 -0
- package/dist/components/charts/area/area.js +329 -0
- package/dist/components/charts/bar/bar.js +207 -0
- package/dist/components/charts/chart/chart.js +215 -0
- package/dist/components/charts/column/column.js +221 -0
- package/dist/components/charts/discrete_scatter/discrete_scatter.js +199 -0
- package/dist/components/charts/gauge/gauge.js +205 -0
- package/dist/components/charts/heatmap/heatmap.js +299 -0
- package/dist/components/charts/heatmap/index.js +2 -0
- package/dist/components/charts/legend/legend.js +245 -0
- package/dist/components/charts/line/line.js +340 -0
- package/dist/components/charts/series_label/series_label.js +101 -0
- package/dist/components/charts/shared/tooltip/tooltip.js +369 -0
- package/dist/components/charts/shared/tooltip/tooltip_default_format/tooltip_default_format.js +53 -0
- package/dist/components/charts/single_stat/single_stat.js +164 -0
- package/dist/components/charts/sparkline/sparkline.js +299 -0
- package/dist/components/charts/stacked_column/stacked_column.js +380 -0
- package/dist/components/dashboards/dashboard_layout/dashboard_layout.js +125 -0
- package/dist/components/dashboards/dashboard_layout/grid_layout/grid_layout.js +326 -0
- package/dist/components/dashboards/dashboard_layout/validators.js +14 -0
- package/dist/components/dashboards/dashboard_panel/dashboard_panel.js +236 -0
- package/dist/components/dashboards/mock_data.js +49 -0
- package/dist/components/experimental/experiment_badge/constants.js +4 -0
- package/dist/components/experimental/experiment_badge/experiment_badge.js +102 -0
- package/dist/components/extended/multi_step_form_template/multi_step_form_template.js +87 -0
- package/dist/components/index.js +107 -0
- package/dist/components/mixins/button_mixin.js +11 -0
- package/dist/components/mixins/safe_link_mixin.js +30 -0
- package/dist/components/mixins/tooltip_mixin.js +21 -0
- package/dist/components/regions/dashboard_skeleton/dashboard_skeleton.js +53 -0
- package/dist/components/regions/empty_state/empty_state.js +181 -0
- package/dist/components/shared_components/clear_icon_button/clear_icon_button.js +64 -0
- package/dist/components/shared_components/clipboard_button/clipboard_button.js +100 -0
- package/dist/components/shared_components/close_button/close_button.js +55 -0
- package/dist/components/utilities/animated_number/animated_number.js +131 -0
- package/dist/components/utilities/friendly_wrap/friendly_wrap.js +75 -0
- package/dist/components/utilities/intersection_observer/intersection_observer.js +88 -0
- package/dist/components/utilities/intersperse/intersperse.js +104 -0
- package/dist/components/utilities/sprintf/sprintf.js +171 -0
- package/dist/components/utilities/truncate/constants.js +8 -0
- package/dist/components/utilities/truncate/truncate.js +154 -0
- package/dist/components/utilities/truncate_text/constants.js +7 -0
- package/dist/components/utilities/truncate_text/truncate_text.js +146 -0
- package/dist/config.js +53 -0
- package/dist/directives/hover_load/hover_load.js +45 -0
- package/dist/directives/index.js +8 -0
- package/dist/directives/modal.js +1 -0
- package/dist/directives/outside/outside.js +149 -0
- package/dist/directives/resize_observer/resize_observer.js +58 -0
- package/dist/directives/safe_html/constants.js +6 -0
- package/dist/directives/safe_html/safe_html.js +39 -0
- package/dist/directives/safe_link/mock_data.js +10 -0
- package/dist/directives/safe_link/safe_link.js +67 -0
- package/dist/directives/tooltip/container.js +7 -0
- package/dist/directives/tooltip/tooltip.js +18 -0
- package/dist/index.css +7 -0
- package/dist/index.css.map +1 -0
- package/dist/index.js +2 -0
- package/dist/tailwind.css +2 -0
- package/dist/tailwind.css.map +1 -0
- package/dist/tokens/build/js/tokens.dark.js +1410 -0
- package/dist/tokens/build/js/tokens.js +1410 -0
- package/dist/tokens/common_story_options.js +29 -0
- package/dist/tokens/tokens_story.js +76 -0
- package/dist/utils/breakpoints.js +20 -0
- package/dist/utils/charts/config.js +616 -0
- package/dist/utils/charts/constants.js +69 -0
- package/dist/utils/charts/mock_data.js +191 -0
- package/dist/utils/charts/story_config.js +24 -0
- package/dist/utils/charts/theme.js +200 -0
- package/dist/utils/charts/utils.js +54 -0
- package/dist/utils/constants.js +331 -0
- package/dist/utils/data_utils.js +19 -0
- package/dist/utils/datetime_utility.js +61 -0
- package/dist/utils/equality_utils.js +84 -0
- package/dist/utils/form_options_utils.js +46 -0
- package/dist/utils/i18n.js +65 -0
- package/dist/utils/is_slot_empty.js +34 -0
- package/dist/utils/number_utils.js +132 -0
- package/dist/utils/play_utils.js +11 -0
- package/dist/utils/set_utils.js +25 -0
- package/dist/utils/stories_constants.js +29 -0
- package/dist/utils/stories_utils.js +62 -0
- package/dist/utils/story_decorators/container.js +19 -0
- package/dist/utils/string_utils.js +69 -0
- package/dist/utils/svgs/svg_paths.js +7 -0
- package/dist/utils/test_utils.js +33 -0
- package/dist/utils/use_fake_date.js +29 -0
- package/dist/utils/use_mock_intersection_observer.js +105 -0
- package/dist/utils/utils.js +205 -0
- package/dist/utils/vue_utils.js +57 -0
- package/dist/utils.js +5 -0
- package/dist/vendor/bootstrap-vue/src/bv-config.js +8 -0
- package/dist/vendor/bootstrap-vue/src/components/button/button-close.js +81 -0
- package/dist/vendor/bootstrap-vue/src/components/button/button.js +204 -0
- package/dist/vendor/bootstrap-vue/src/components/button/index.js +2 -0
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-divider.js +41 -0
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-form.js +52 -0
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-group.js +75 -0
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-header.js +52 -0
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-item-button.js +85 -0
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.js +97 -0
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.js +60 -0
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown.js +270 -0
- package/dist/vendor/bootstrap-vue/src/components/dropdown/index.js +8 -0
- package/dist/vendor/bootstrap-vue/src/components/form/form-invalid-feedback.js +53 -0
- package/dist/vendor/bootstrap-vue/src/components/form/form-text.js +55 -0
- package/dist/vendor/bootstrap-vue/src/components/form/form-valid-feedback.js +53 -0
- package/dist/vendor/bootstrap-vue/src/components/form/form.js +56 -0
- package/dist/vendor/bootstrap-vue/src/components/form/index.js +4 -0
- package/dist/vendor/bootstrap-vue/src/components/form-group/form-group.js +347 -0
- package/dist/vendor/bootstrap-vue/src/components/form-group/index.js +1 -0
- package/dist/vendor/bootstrap-vue/src/components/form-select/form-select-option-group.js +54 -0
- package/dist/vendor/bootstrap-vue/src/components/form-select/form-select-option.js +41 -0
- package/dist/vendor/bootstrap-vue/src/components/form-select/form-select.js +143 -0
- package/dist/vendor/bootstrap-vue/src/components/form-select/helpers/mixin-options.js +56 -0
- package/dist/vendor/bootstrap-vue/src/components/form-select/index.js +3 -0
- package/dist/vendor/bootstrap-vue/src/components/form-textarea/form-textarea.js +217 -0
- package/dist/vendor/bootstrap-vue/src/components/form-textarea/index.js +1 -0
- package/dist/vendor/bootstrap-vue/src/components/layout/col.js +155 -0
- package/dist/vendor/bootstrap-vue/src/components/layout/form-row.js +34 -0
- package/dist/vendor/bootstrap-vue/src/components/layout/index.js +2 -0
- package/dist/vendor/bootstrap-vue/src/components/link/index.js +1 -0
- package/dist/vendor/bootstrap-vue/src/components/link/link.js +283 -0
- package/dist/vendor/bootstrap-vue/src/components/modal/helpers/bv-modal-event.class.js +21 -0
- package/dist/vendor/bootstrap-vue/src/components/modal/helpers/modal-manager.js +212 -0
- package/dist/vendor/bootstrap-vue/src/components/modal/index.js +1 -0
- package/dist/vendor/bootstrap-vue/src/components/modal/modal.js +1059 -0
- package/dist/vendor/bootstrap-vue/src/components/popover/helpers/bv-popover-template.js +55 -0
- package/dist/vendor/bootstrap-vue/src/components/popover/helpers/bv-popover.js +31 -0
- package/dist/vendor/bootstrap-vue/src/components/popover/index.js +1 -0
- package/dist/vendor/bootstrap-vue/src/components/popover/popover.js +49 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/constants.js +22 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/default-sort-compare.js +64 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/filter-event.js +40 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-bottom-row.js +43 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-busy.js +83 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-caption.js +50 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-colgroup.js +32 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-empty.js +82 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-filtering.js +292 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-items.js +154 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-pagination.js +44 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-provider.js +191 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-selectable.js +213 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-sorting.js +274 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-stacked.js +39 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-table-renderer.js +186 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tbody-row.js +338 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tbody.js +243 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tfoot.js +50 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-thead.js +218 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-top-row.js +42 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/normalize-fields.js +86 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/sanitize-row.js +31 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/stringify-record-values.js +11 -0
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/text-selection-active.js +14 -0
- package/dist/vendor/bootstrap-vue/src/components/table/index.js +9 -0
- package/dist/vendor/bootstrap-vue/src/components/table/table-lite.js +51 -0
- package/dist/vendor/bootstrap-vue/src/components/table/table-simple.js +44 -0
- package/dist/vendor/bootstrap-vue/src/components/table/table.js +67 -0
- package/dist/vendor/bootstrap-vue/src/components/table/tbody.js +116 -0
- package/dist/vendor/bootstrap-vue/src/components/table/td.js +204 -0
- package/dist/vendor/bootstrap-vue/src/components/table/tfoot.js +96 -0
- package/dist/vendor/bootstrap-vue/src/components/table/th.js +26 -0
- package/dist/vendor/bootstrap-vue/src/components/table/thead.js +99 -0
- package/dist/vendor/bootstrap-vue/src/components/table/tr.js +121 -0
- package/dist/vendor/bootstrap-vue/src/components/tabs/index.js +2 -0
- package/dist/vendor/bootstrap-vue/src/components/tabs/tab.js +238 -0
- package/dist/vendor/bootstrap-vue/src/components/tabs/tabs.js +690 -0
- package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-popper.js +251 -0
- package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip-template.js +118 -0
- package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip.js +932 -0
- package/dist/vendor/bootstrap-vue/src/components/tooltip/index.js +1 -0
- package/dist/vendor/bootstrap-vue/src/components/tooltip/tooltip.js +337 -0
- package/dist/vendor/bootstrap-vue/src/components/transition/bv-transition.js +103 -0
- package/dist/vendor/bootstrap-vue/src/components/transporter/transporter.js +205 -0
- package/dist/vendor/bootstrap-vue/src/constants/components.js +55 -0
- package/dist/vendor/bootstrap-vue/src/constants/config.js +11 -0
- package/dist/vendor/bootstrap-vue/src/constants/env.js +36 -0
- package/dist/vendor/bootstrap-vue/src/constants/events.js +56 -0
- package/dist/vendor/bootstrap-vue/src/constants/key-codes.js +11 -0
- package/dist/vendor/bootstrap-vue/src/constants/popper.js +10 -0
- package/dist/vendor/bootstrap-vue/src/constants/props.js +24 -0
- package/dist/vendor/bootstrap-vue/src/constants/regex.js +35 -0
- package/dist/vendor/bootstrap-vue/src/constants/safe-types.js +15 -0
- package/dist/vendor/bootstrap-vue/src/constants/slots.js +36 -0
- package/dist/vendor/bootstrap-vue/src/directives/modal/index.js +1 -0
- package/dist/vendor/bootstrap-vue/src/directives/modal/modal.js +112 -0
- package/dist/vendor/bootstrap-vue/src/directives/tooltip/index.js +1 -0
- package/dist/vendor/bootstrap-vue/src/directives/tooltip/tooltip.js +267 -0
- package/dist/vendor/bootstrap-vue/src/directives/visible/index.js +1 -0
- package/dist/vendor/bootstrap-vue/src/directives/visible/visible.js +187 -0
- package/dist/vendor/bootstrap-vue/src/mixins/attrs.js +5 -0
- package/dist/vendor/bootstrap-vue/src/mixins/click-out.js +54 -0
- package/dist/vendor/bootstrap-vue/src/mixins/dropdown.js +470 -0
- package/dist/vendor/bootstrap-vue/src/mixins/focus-in.js +46 -0
- package/dist/vendor/bootstrap-vue/src/mixins/form-control.js +73 -0
- package/dist/vendor/bootstrap-vue/src/mixins/form-custom.js +26 -0
- package/dist/vendor/bootstrap-vue/src/mixins/form-options.js +91 -0
- package/dist/vendor/bootstrap-vue/src/mixins/form-selection.js +62 -0
- package/dist/vendor/bootstrap-vue/src/mixins/form-size.js +26 -0
- package/dist/vendor/bootstrap-vue/src/mixins/form-state.js +50 -0
- package/dist/vendor/bootstrap-vue/src/mixins/form-text.js +293 -0
- package/dist/vendor/bootstrap-vue/src/mixins/form-validity.js +50 -0
- package/dist/vendor/bootstrap-vue/src/mixins/has-listener.js +29 -0
- package/dist/vendor/bootstrap-vue/src/mixins/id.js +57 -0
- package/dist/vendor/bootstrap-vue/src/mixins/listen-on-document.js +62 -0
- package/dist/vendor/bootstrap-vue/src/mixins/listen-on-root.js +120 -0
- package/dist/vendor/bootstrap-vue/src/mixins/listen-on-window.js +62 -0
- package/dist/vendor/bootstrap-vue/src/mixins/listeners.js +25 -0
- package/dist/vendor/bootstrap-vue/src/mixins/model.js +10 -0
- package/dist/vendor/bootstrap-vue/src/mixins/normalize-slot.js +30 -0
- package/dist/vendor/bootstrap-vue/src/mixins/scoped-style.js +18 -0
- package/dist/vendor/bootstrap-vue/src/mixins/use-parent.js +14 -0
- package/dist/vendor/bootstrap-vue/src/utils/array.js +27 -0
- package/dist/vendor/bootstrap-vue/src/utils/bv-event.class.js +60 -0
- package/dist/vendor/bootstrap-vue/src/utils/cache.js +60 -0
- package/dist/vendor/bootstrap-vue/src/utils/clone-deep.js +18 -0
- package/dist/vendor/bootstrap-vue/src/utils/config-set.js +86 -0
- package/dist/vendor/bootstrap-vue/src/utils/config.js +71 -0
- package/dist/vendor/bootstrap-vue/src/utils/create-new-child-component.js +133 -0
- package/dist/vendor/bootstrap-vue/src/utils/css-escape.js +70 -0
- package/dist/vendor/bootstrap-vue/src/utils/dom.js +298 -0
- package/dist/vendor/bootstrap-vue/src/utils/element-to-vue-instance-registry.js +28 -0
- package/dist/vendor/bootstrap-vue/src/utils/env.js +16 -0
- package/dist/vendor/bootstrap-vue/src/utils/events.js +78 -0
- package/dist/vendor/bootstrap-vue/src/utils/get-event-root.js +5 -0
- package/dist/vendor/bootstrap-vue/src/utils/get-instance-from-directive.js +3 -0
- package/dist/vendor/bootstrap-vue/src/utils/get-scope-id.js +9 -0
- package/dist/vendor/bootstrap-vue/src/utils/get.js +63 -0
- package/dist/vendor/bootstrap-vue/src/utils/html.js +16 -0
- package/dist/vendor/bootstrap-vue/src/utils/identity.js +3 -0
- package/dist/vendor/bootstrap-vue/src/utils/inspect.js +35 -0
- package/dist/vendor/bootstrap-vue/src/utils/locale.js +18 -0
- package/dist/vendor/bootstrap-vue/src/utils/loose-equal.js +59 -0
- package/dist/vendor/bootstrap-vue/src/utils/loose-index-of.js +13 -0
- package/dist/vendor/bootstrap-vue/src/utils/math.js +9 -0
- package/dist/vendor/bootstrap-vue/src/utils/memoize.js +14 -0
- package/dist/vendor/bootstrap-vue/src/utils/model.js +33 -0
- package/dist/vendor/bootstrap-vue/src/utils/noop.js +3 -0
- package/dist/vendor/bootstrap-vue/src/utils/normalize-slot.js +51 -0
- package/dist/vendor/bootstrap-vue/src/utils/number.js +23 -0
- package/dist/vendor/bootstrap-vue/src/utils/object.js +72 -0
- package/dist/vendor/bootstrap-vue/src/utils/observe-dom.js +76 -0
- package/dist/vendor/bootstrap-vue/src/utils/on-instance-destroy.js +22 -0
- package/dist/vendor/bootstrap-vue/src/utils/plugins.js +124 -0
- package/dist/vendor/bootstrap-vue/src/utils/props.js +67 -0
- package/dist/vendor/bootstrap-vue/src/utils/router.js +150 -0
- package/dist/vendor/bootstrap-vue/src/utils/safe-vue-instance.js +14 -0
- package/dist/vendor/bootstrap-vue/src/utils/stable-sort.js +28 -0
- package/dist/vendor/bootstrap-vue/src/utils/string.js +47 -0
- package/dist/vendor/bootstrap-vue/src/utils/stringify-object-values.js +31 -0
- package/dist/vendor/bootstrap-vue/src/utils/warn.js +45 -0
- package/dist/vendor/bootstrap-vue/src/vue.js +55 -0
- package/package.json +4 -3
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown.js +2 -2
- package/src/vendor/bootstrap-vue/src/components/form-group/form-group.js +2 -2
- package/src/vendor/bootstrap-vue/src/components/layout/col.js +2 -2
- package/src/vendor/bootstrap-vue/src/components/modal/modal.js +2 -2
- package/src/vendor/bootstrap-vue/src/components/tabs/tabs.js +2 -2
- package/src/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip.js +8 -9
- package/src/vendor/bootstrap-vue/src/mixins/listen-on-document.js +1 -2
- package/src/vendor/bootstrap-vue/src/mixins/listen-on-root.js +1 -2
- package/src/vendor/bootstrap-vue/src/mixins/listen-on-window.js +1 -2
- package/src/vendor/bootstrap-vue/src/utils/array.js +0 -1
- package/src/vendor/bootstrap-vue/src/utils/locale.js +1 -2
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import GlButton from '../button/button';
|
|
2
|
+
import GlButtonGroup from '../button_group/button_group';
|
|
3
|
+
import GlIcon from '../icon/icon';
|
|
4
|
+
import { translate } from '../../../utils/i18n';
|
|
5
|
+
import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js';
|
|
6
|
+
|
|
7
|
+
var script = {
|
|
8
|
+
name: 'GlKeysetPagination',
|
|
9
|
+
components: {
|
|
10
|
+
GlButtonGroup,
|
|
11
|
+
GlButton,
|
|
12
|
+
GlIcon
|
|
13
|
+
},
|
|
14
|
+
inheritAttrs: false,
|
|
15
|
+
props: {
|
|
16
|
+
// The following 4 properties match the default names of the
|
|
17
|
+
// [PageInfo](https://docs.gitlab.com/ee/api/graphql/reference/index.html#pageinfo)
|
|
18
|
+
// GraphQL type, allowing the returned `pageInfo` object to
|
|
19
|
+
// be bound directly to this component:
|
|
20
|
+
// `<gl-keyset-pagination v-bind="pageInfo">`
|
|
21
|
+
/**
|
|
22
|
+
* Whether or not the "Prev" button should be enabled
|
|
23
|
+
*/
|
|
24
|
+
hasPreviousPage: {
|
|
25
|
+
type: Boolean,
|
|
26
|
+
required: false,
|
|
27
|
+
default: false
|
|
28
|
+
},
|
|
29
|
+
/**
|
|
30
|
+
* Whether or not the "Next" button should be enabled
|
|
31
|
+
*/
|
|
32
|
+
hasNextPage: {
|
|
33
|
+
type: Boolean,
|
|
34
|
+
required: false,
|
|
35
|
+
default: false
|
|
36
|
+
},
|
|
37
|
+
/**
|
|
38
|
+
* A cursor that points to the first item in the current page.
|
|
39
|
+
* Will be passed as an event parameter when the "prev" event is fired.
|
|
40
|
+
*/
|
|
41
|
+
startCursor: {
|
|
42
|
+
type: String,
|
|
43
|
+
required: false,
|
|
44
|
+
default: null
|
|
45
|
+
},
|
|
46
|
+
/**
|
|
47
|
+
* A cursor that points to the last item in the current page.
|
|
48
|
+
* Will be passed as an event parameter when the "next" event is fired.
|
|
49
|
+
*/
|
|
50
|
+
endCursor: {
|
|
51
|
+
type: String,
|
|
52
|
+
required: false,
|
|
53
|
+
default: null
|
|
54
|
+
},
|
|
55
|
+
/**
|
|
56
|
+
* The text that will be rendered inside the "Previous" button.
|
|
57
|
+
* It's important to provide this parameter since the default text is not translatable.
|
|
58
|
+
*/
|
|
59
|
+
prevText: {
|
|
60
|
+
type: String,
|
|
61
|
+
required: false,
|
|
62
|
+
default: () => translate('GlKeysetPagination.prevText', 'Previous')
|
|
63
|
+
},
|
|
64
|
+
/**
|
|
65
|
+
* A link that will be used as the "Prev" button\'s "href" attribute.
|
|
66
|
+
* If provided, the "Prev" button renders as a link button; otherwise, it is rendered as a regular button.
|
|
67
|
+
*/
|
|
68
|
+
prevButtonLink: {
|
|
69
|
+
type: String,
|
|
70
|
+
required: false,
|
|
71
|
+
default: null
|
|
72
|
+
},
|
|
73
|
+
/**
|
|
74
|
+
* The aria-label that needs to be set for the
|
|
75
|
+
* pagination landmark region.
|
|
76
|
+
*/
|
|
77
|
+
navigationLabel: {
|
|
78
|
+
type: String,
|
|
79
|
+
required: false,
|
|
80
|
+
default: () => translate('GlKeysetPagination.navigationLabel', 'Pagination')
|
|
81
|
+
},
|
|
82
|
+
/**
|
|
83
|
+
* The text that will be rendered inside the "Next" button.
|
|
84
|
+
* It's important to provide this parameter since the default text is not translatable.
|
|
85
|
+
*/
|
|
86
|
+
nextText: {
|
|
87
|
+
type: String,
|
|
88
|
+
required: false,
|
|
89
|
+
default: () => translate('GlKeysetPagination.nextText', 'Next')
|
|
90
|
+
},
|
|
91
|
+
/**
|
|
92
|
+
* A link that will be used as the "Next" button\'s "href" attribute.
|
|
93
|
+
* If provided, the "Next" button renders as a link button; otherwise, it is rendered as a regular button.
|
|
94
|
+
*/
|
|
95
|
+
nextButtonLink: {
|
|
96
|
+
type: String,
|
|
97
|
+
required: false,
|
|
98
|
+
default: null
|
|
99
|
+
},
|
|
100
|
+
/**
|
|
101
|
+
* Whether or not both buttons should be disabled (regardless of the "hasPreviousPage" and "hasNextPage" values).
|
|
102
|
+
*/
|
|
103
|
+
disabled: {
|
|
104
|
+
type: Boolean,
|
|
105
|
+
required: false,
|
|
106
|
+
default: false
|
|
107
|
+
}
|
|
108
|
+
},
|
|
109
|
+
computed: {
|
|
110
|
+
isVisible() {
|
|
111
|
+
return this.hasPreviousPage || this.hasNextPage;
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
};
|
|
115
|
+
|
|
116
|
+
/* script */
|
|
117
|
+
const __vue_script__ = script;
|
|
118
|
+
|
|
119
|
+
/* template */
|
|
120
|
+
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.navigationLabel}},[_c('gl-button-group',_vm._g(_vm._b({staticClass:"gl-keyset-pagination gl-gap-3"},'gl-button-group',_vm.$attrs,false),_vm.$listeners),[_c('gl-button',{attrs:{"href":_vm.prevButtonLink,"disabled":_vm.disabled || !_vm.hasPreviousPage,"data-testid":"prevButton","category":"tertiary"},on:{"click":function($event){return _vm.$emit('prev', _vm.startCursor)}}},[_vm._t("previous-button-content",function(){return [_c('div',{staticClass:"gl-align-center gl-flex"},[_c('gl-icon',{staticClass:"gl-mr-2",attrs:{"name":"chevron-lg-left"}}),_vm._v("\n "+_vm._s(_vm.prevText)+"\n ")],1)]})],2),_vm._v(" "),_c('gl-button',{attrs:{"href":_vm.nextButtonLink,"disabled":_vm.disabled || !_vm.hasNextPage,"data-testid":"nextButton","category":"tertiary"},on:{"click":function($event){return _vm.$emit('next', _vm.endCursor)}}},[_vm._t("next-button-content",function(){return [_c('div',{staticClass:"gl-align-center gl-flex"},[_vm._v("\n "+_vm._s(_vm.nextText)+"\n "),_c('gl-icon',{staticClass:"gl-ml-2",attrs:{"name":"chevron-lg-right"}})],1)]})],2)],1)],1):_vm._e()};
|
|
121
|
+
var __vue_staticRenderFns__ = [];
|
|
122
|
+
|
|
123
|
+
/* style */
|
|
124
|
+
const __vue_inject_styles__ = undefined;
|
|
125
|
+
/* scoped */
|
|
126
|
+
const __vue_scope_id__ = undefined;
|
|
127
|
+
/* module identifier */
|
|
128
|
+
const __vue_module_identifier__ = undefined;
|
|
129
|
+
/* functional template */
|
|
130
|
+
const __vue_is_functional_template__ = false;
|
|
131
|
+
/* style inject */
|
|
132
|
+
|
|
133
|
+
/* style inject SSR */
|
|
134
|
+
|
|
135
|
+
/* style inject shadow dom */
|
|
136
|
+
|
|
137
|
+
|
|
138
|
+
|
|
139
|
+
const __vue_component__ = /*#__PURE__*/__vue_normalize__(
|
|
140
|
+
{ render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ },
|
|
141
|
+
__vue_inject_styles__,
|
|
142
|
+
__vue_script__,
|
|
143
|
+
__vue_scope_id__,
|
|
144
|
+
__vue_is_functional_template__,
|
|
145
|
+
__vue_module_identifier__,
|
|
146
|
+
false,
|
|
147
|
+
undefined,
|
|
148
|
+
undefined,
|
|
149
|
+
undefined
|
|
150
|
+
);
|
|
151
|
+
|
|
152
|
+
export { __vue_component__ as default };
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
import { labelColorOptions } from '../../../utils/constants';
|
|
2
|
+
import { colorFromBackground } from '../../../utils/utils';
|
|
3
|
+
import { translate } from '../../../utils/i18n';
|
|
4
|
+
import GlButton from '../button/button';
|
|
5
|
+
import GlIcon from '../icon/icon';
|
|
6
|
+
import GlLink from '../link/link';
|
|
7
|
+
import GlTooltip from '../tooltip/tooltip';
|
|
8
|
+
import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js';
|
|
9
|
+
|
|
10
|
+
var script = {
|
|
11
|
+
name: 'GlLabel',
|
|
12
|
+
components: {
|
|
13
|
+
GlButton,
|
|
14
|
+
GlIcon,
|
|
15
|
+
GlLink,
|
|
16
|
+
GlTooltip
|
|
17
|
+
},
|
|
18
|
+
props: {
|
|
19
|
+
/**
|
|
20
|
+
* Background color of the label in hex, rgb, or rgba format
|
|
21
|
+
*/
|
|
22
|
+
backgroundColor: {
|
|
23
|
+
type: String,
|
|
24
|
+
required: true,
|
|
25
|
+
validator: value => /^(#|rgb|rgba)/.test(value)
|
|
26
|
+
},
|
|
27
|
+
/**
|
|
28
|
+
* Title text of the label
|
|
29
|
+
*/
|
|
30
|
+
title: {
|
|
31
|
+
type: String,
|
|
32
|
+
required: true,
|
|
33
|
+
default: ''
|
|
34
|
+
},
|
|
35
|
+
/**
|
|
36
|
+
* Description text shown in tooltip
|
|
37
|
+
*/
|
|
38
|
+
description: {
|
|
39
|
+
type: String,
|
|
40
|
+
required: false,
|
|
41
|
+
default: ''
|
|
42
|
+
},
|
|
43
|
+
/**
|
|
44
|
+
* Placement of the tooltip
|
|
45
|
+
*/
|
|
46
|
+
tooltipPlacement: {
|
|
47
|
+
type: String,
|
|
48
|
+
required: false,
|
|
49
|
+
default: 'top'
|
|
50
|
+
},
|
|
51
|
+
/**
|
|
52
|
+
* Target URL for the label link
|
|
53
|
+
*/
|
|
54
|
+
target: {
|
|
55
|
+
type: String,
|
|
56
|
+
required: false,
|
|
57
|
+
default: ''
|
|
58
|
+
},
|
|
59
|
+
/**
|
|
60
|
+
* Whether the label is scoped (uses :: separator)
|
|
61
|
+
*/
|
|
62
|
+
scoped: {
|
|
63
|
+
type: Boolean,
|
|
64
|
+
required: false,
|
|
65
|
+
default: false
|
|
66
|
+
},
|
|
67
|
+
/**
|
|
68
|
+
* Whether to show the close button
|
|
69
|
+
*/
|
|
70
|
+
showCloseButton: {
|
|
71
|
+
type: Boolean,
|
|
72
|
+
required: false,
|
|
73
|
+
default: false
|
|
74
|
+
},
|
|
75
|
+
/**
|
|
76
|
+
* Whether the label is disabled
|
|
77
|
+
*/
|
|
78
|
+
disabled: {
|
|
79
|
+
type: Boolean,
|
|
80
|
+
required: false,
|
|
81
|
+
default: false
|
|
82
|
+
}
|
|
83
|
+
},
|
|
84
|
+
computed: {
|
|
85
|
+
removeButtonAriaLabel() {
|
|
86
|
+
return translate('GlLabel.removeButtonAriaLabel', 'Remove label - %{label}', {
|
|
87
|
+
label: this.title
|
|
88
|
+
});
|
|
89
|
+
},
|
|
90
|
+
cssClasses() {
|
|
91
|
+
const textColorVariant = colorFromBackground(this.backgroundColor);
|
|
92
|
+
return {
|
|
93
|
+
'gl-label-scoped': this.scoped,
|
|
94
|
+
'gl-label-text-dark': textColorVariant === labelColorOptions.dark,
|
|
95
|
+
'gl-label-text-light': textColorVariant === labelColorOptions.light
|
|
96
|
+
};
|
|
97
|
+
},
|
|
98
|
+
cssVariables() {
|
|
99
|
+
return {
|
|
100
|
+
'--label-background-color': this.backgroundColor,
|
|
101
|
+
'--label-inset-border': `inset 0 0 0 2px ${this.backgroundColor}`
|
|
102
|
+
};
|
|
103
|
+
},
|
|
104
|
+
splitScopedLabelIndex() {
|
|
105
|
+
return this.title.lastIndexOf('::');
|
|
106
|
+
},
|
|
107
|
+
scopedKey() {
|
|
108
|
+
return this.scoped ? this.title.slice(0, this.splitScopedLabelIndex) : this.title;
|
|
109
|
+
},
|
|
110
|
+
scopedValue() {
|
|
111
|
+
return this.title.slice(this.splitScopedLabelIndex + 2);
|
|
112
|
+
},
|
|
113
|
+
labelComponent() {
|
|
114
|
+
return this.target ? GlLink : 'span';
|
|
115
|
+
},
|
|
116
|
+
tooltipTarget() {
|
|
117
|
+
return this.target ? this.$refs.labelTitle.$el : this.$refs.labelTitle;
|
|
118
|
+
}
|
|
119
|
+
},
|
|
120
|
+
methods: {
|
|
121
|
+
onClick(e) {
|
|
122
|
+
/**
|
|
123
|
+
* Emitted when the label is clicked.
|
|
124
|
+
* @event click
|
|
125
|
+
*/
|
|
126
|
+
this.$emit('click', e);
|
|
127
|
+
},
|
|
128
|
+
onClose(e) {
|
|
129
|
+
/**
|
|
130
|
+
* Emitted when the close button is clicked.
|
|
131
|
+
* @event close
|
|
132
|
+
*/
|
|
133
|
+
this.$emit('close', e);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
|
|
138
|
+
/* script */
|
|
139
|
+
const __vue_script__ = script;
|
|
140
|
+
|
|
141
|
+
/* template */
|
|
142
|
+
var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('span',_vm._b({staticClass:"gl-label",class:_vm.cssClasses,style:(_vm.cssVariables),on:{"click":_vm.onClick}},'span',_vm.$attrs,false),[_c(_vm.labelComponent,{ref:"labelTitle",tag:"component",staticClass:"gl-label-link",class:{ 'gl-label-link-underline': _vm.target },attrs:{"href":_vm.target ? _vm.target : false,"tabindex":"0"}},[_c('span',{staticClass:"gl-label-text"},[_vm._v("\n "+_vm._s(_vm.scopedKey)+"\n ")]),_vm._v(" "),(_vm.scoped && _vm.scopedValue)?_c('span',{staticClass:"gl-label-text-scoped"},[_vm._v("\n "+_vm._s(_vm.scopedValue)+"\n ")]):_vm._e()]),_vm._v(" "),(_vm.showCloseButton)?_c('gl-button',{staticClass:"gl-label-close !gl-p-0",attrs:{"category":"tertiary","size":"small","variant":"reset","aria-label":_vm.removeButtonAriaLabel,"disabled":_vm.disabled},on:{"click":_vm.onClose}},[_c('gl-icon',{attrs:{"name":"close-xs","size":12}})],1):_vm._e(),_vm._v(" "),(_vm.description)?_c('gl-tooltip',{attrs:{"target":function () { return _vm.tooltipTarget; },"placement":_vm.tooltipPlacement,"boundary":"viewport"}},[(_vm.scoped)?_c('span',{staticClass:"gl-label-tooltip-title"},[_vm._v("Scoped label")]):_vm._e(),_vm._v("\n "+_vm._s(_vm.description)+"\n ")]):_vm._e()],1)};
|
|
143
|
+
var __vue_staticRenderFns__ = [];
|
|
144
|
+
|
|
145
|
+
/* style */
|
|
146
|
+
const __vue_inject_styles__ = undefined;
|
|
147
|
+
/* scoped */
|
|
148
|
+
const __vue_scope_id__ = undefined;
|
|
149
|
+
/* module identifier */
|
|
150
|
+
const __vue_module_identifier__ = undefined;
|
|
151
|
+
/* functional template */
|
|
152
|
+
const __vue_is_functional_template__ = false;
|
|
153
|
+
/* style inject */
|
|
154
|
+
|
|
155
|
+
/* style inject SSR */
|
|
156
|
+
|
|
157
|
+
/* style inject shadow dom */
|
|
158
|
+
|
|
159
|
+
|
|
160
|
+
|
|
161
|
+
const __vue_component__ = /*#__PURE__*/__vue_normalize__(
|
|
162
|
+
{ render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ },
|
|
163
|
+
__vue_inject_styles__,
|
|
164
|
+
__vue_script__,
|
|
165
|
+
__vue_scope_id__,
|
|
166
|
+
__vue_is_functional_template__,
|
|
167
|
+
__vue_module_identifier__,
|
|
168
|
+
false,
|
|
169
|
+
undefined,
|
|
170
|
+
undefined,
|
|
171
|
+
undefined
|
|
172
|
+
);
|
|
173
|
+
|
|
174
|
+
export { __vue_component__ as default };
|
|
@@ -0,0 +1,330 @@
|
|
|
1
|
+
import { isString, isObject, toString, isBoolean, concat, isFunction } from 'lodash-es';
|
|
2
|
+
import { SafeLinkDirective, isExternalURL } from '../../../directives/safe_link/safe_link';
|
|
3
|
+
import { stopEvent } from '../../../utils/utils';
|
|
4
|
+
import { safeVueInstance, isVue3 } from '../../../utils/vue_utils';
|
|
5
|
+
import { stringifyQueryObj } from '../../../vendor/bootstrap-vue/src/utils/router';
|
|
6
|
+
import { linkVariantOptions, linkVariantUnstyled, linkVariantInline, linkVariantMeta } from '../../../utils/constants';
|
|
7
|
+
import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js';
|
|
8
|
+
|
|
9
|
+
const ANCHOR_TAG = 'a';
|
|
10
|
+
const NUXT_LINK_TAG = 'nuxt-link';
|
|
11
|
+
const VUE_ROUTER_LINK_TAG = 'router-link';
|
|
12
|
+
var script = {
|
|
13
|
+
name: 'GlLink',
|
|
14
|
+
directives: {
|
|
15
|
+
SafeLink: SafeLinkDirective
|
|
16
|
+
},
|
|
17
|
+
inheritAttrs: false,
|
|
18
|
+
props: {
|
|
19
|
+
/**
|
|
20
|
+
* Denotes the target URL of the link for standard links.
|
|
21
|
+
*/
|
|
22
|
+
href: {
|
|
23
|
+
type: String,
|
|
24
|
+
required: false,
|
|
25
|
+
default: undefined
|
|
26
|
+
},
|
|
27
|
+
/**
|
|
28
|
+
* When set to `true`, disables the component's functionality and places it in a disabled state.
|
|
29
|
+
*/
|
|
30
|
+
disabled: {
|
|
31
|
+
type: Boolean,
|
|
32
|
+
required: false,
|
|
33
|
+
default: false
|
|
34
|
+
},
|
|
35
|
+
/**
|
|
36
|
+
* Skips sanitization of href if true. This should be used sparingly.
|
|
37
|
+
* Consult security team before setting to true.
|
|
38
|
+
*/
|
|
39
|
+
isUnsafeLink: {
|
|
40
|
+
type: Boolean,
|
|
41
|
+
required: false,
|
|
42
|
+
default: false
|
|
43
|
+
},
|
|
44
|
+
/**
|
|
45
|
+
* Sets the 'rel' attribute on the rendered link.
|
|
46
|
+
*/
|
|
47
|
+
rel: {
|
|
48
|
+
type: String,
|
|
49
|
+
required: false,
|
|
50
|
+
default: null
|
|
51
|
+
},
|
|
52
|
+
/**
|
|
53
|
+
* Sets the 'target' attribute on the rendered link.
|
|
54
|
+
*/
|
|
55
|
+
target: {
|
|
56
|
+
type: String,
|
|
57
|
+
required: false,
|
|
58
|
+
default: null
|
|
59
|
+
},
|
|
60
|
+
/**
|
|
61
|
+
* When set to `true`, places the component in the active state with active styling
|
|
62
|
+
*/
|
|
63
|
+
active: {
|
|
64
|
+
type: Boolean,
|
|
65
|
+
required: false,
|
|
66
|
+
default: false
|
|
67
|
+
},
|
|
68
|
+
/**
|
|
69
|
+
* <router-link> prop: Denotes the target route of the link.
|
|
70
|
+
* When clicked, the value of the to prop will be passed to `router.push()` internally,
|
|
71
|
+
* so the value can be either a string or a Location descriptor object.
|
|
72
|
+
*/
|
|
73
|
+
to: {
|
|
74
|
+
type: [Object, String],
|
|
75
|
+
required: false,
|
|
76
|
+
default: undefined
|
|
77
|
+
},
|
|
78
|
+
/**
|
|
79
|
+
* <router-link> prop: Configure the active CSS class applied when the link is active.
|
|
80
|
+
*/
|
|
81
|
+
activeClass: {
|
|
82
|
+
type: String,
|
|
83
|
+
required: false,
|
|
84
|
+
default: undefined
|
|
85
|
+
},
|
|
86
|
+
/**
|
|
87
|
+
* <router-link> prop: Configure the active CSS class applied when the link is active with exact match.
|
|
88
|
+
*/
|
|
89
|
+
exactActiveClass: {
|
|
90
|
+
type: String,
|
|
91
|
+
required: false,
|
|
92
|
+
default: undefined
|
|
93
|
+
},
|
|
94
|
+
/**
|
|
95
|
+
* <router-link> prop: Setting the replace prop will call `router.replace()` instead of `router.push()`
|
|
96
|
+
* when clicked, so the navigation will not leave a history record.
|
|
97
|
+
*/
|
|
98
|
+
replace: {
|
|
99
|
+
type: Boolean,
|
|
100
|
+
required: false,
|
|
101
|
+
default: false
|
|
102
|
+
},
|
|
103
|
+
/**
|
|
104
|
+
* <nuxt-link> prop: To improve the responsiveness of your Nuxt.js applications, when the link will be displayed within the viewport,
|
|
105
|
+
* Nuxt.js will automatically prefetch the code splitted page. Setting `prefetch` to `true` or `false` will overwrite the default value of `router.prefetchLinks`
|
|
106
|
+
*/
|
|
107
|
+
prefetch: {
|
|
108
|
+
type: Boolean,
|
|
109
|
+
required: false,
|
|
110
|
+
// Must be `null` to fall back to the value defined in the
|
|
111
|
+
// `nuxt.config.js` configuration file for `router.prefetchLinks`
|
|
112
|
+
// We convert `null` to `undefined`, so that Nuxt.js will use the
|
|
113
|
+
// compiled default
|
|
114
|
+
// Vue treats `undefined` as default of `false` for Boolean props,
|
|
115
|
+
// so we must set it as `null` here to be a true tri-state prop
|
|
116
|
+
default: null
|
|
117
|
+
},
|
|
118
|
+
/**
|
|
119
|
+
* Controls ↗ character visibility for external links
|
|
120
|
+
*/
|
|
121
|
+
showExternalIcon: {
|
|
122
|
+
type: Boolean,
|
|
123
|
+
required: false,
|
|
124
|
+
default: false
|
|
125
|
+
},
|
|
126
|
+
/**
|
|
127
|
+
* Link variant
|
|
128
|
+
*/
|
|
129
|
+
variant: {
|
|
130
|
+
type: String,
|
|
131
|
+
required: false,
|
|
132
|
+
default: null,
|
|
133
|
+
validator: value => value && Object.hasOwn(linkVariantOptions, value)
|
|
134
|
+
}
|
|
135
|
+
},
|
|
136
|
+
computed: {
|
|
137
|
+
safeLinkConfig() {
|
|
138
|
+
return {
|
|
139
|
+
skipSanitization: this.isUnsafeLink
|
|
140
|
+
};
|
|
141
|
+
},
|
|
142
|
+
tag() {
|
|
143
|
+
const hasRouter = Boolean(safeVueInstance(this).$router);
|
|
144
|
+
const hasNuxt = Boolean(safeVueInstance(this).$nuxt);
|
|
145
|
+
if (!hasRouter || this.disabled || !this.to) {
|
|
146
|
+
return ANCHOR_TAG;
|
|
147
|
+
}
|
|
148
|
+
return hasNuxt ? NUXT_LINK_TAG : VUE_ROUTER_LINK_TAG;
|
|
149
|
+
},
|
|
150
|
+
isRouterLink() {
|
|
151
|
+
return this.tag !== ANCHOR_TAG;
|
|
152
|
+
},
|
|
153
|
+
isVue3RouterLink() {
|
|
154
|
+
return this.tag === VUE_ROUTER_LINK_TAG && isVue3(this);
|
|
155
|
+
},
|
|
156
|
+
shouldShowExternalIcon() {
|
|
157
|
+
const allowedVariants = [linkVariantInline, linkVariantMeta, null]; // null represents default/UI variant
|
|
158
|
+
return this.showExternalIcon && allowedVariants.includes(this.variant) && this.href && isExternalURL(this.target, this.href);
|
|
159
|
+
},
|
|
160
|
+
computedHref() {
|
|
161
|
+
const fallback = '#';
|
|
162
|
+
const toFallback = '/';
|
|
163
|
+
const {
|
|
164
|
+
to
|
|
165
|
+
} = this;
|
|
166
|
+
|
|
167
|
+
// Return `href` when explicitly provided
|
|
168
|
+
if (this.href) {
|
|
169
|
+
return this.href;
|
|
170
|
+
}
|
|
171
|
+
if (isString(to)) {
|
|
172
|
+
return to || toFallback;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
// Fallback to `to.path' + `to.query` + `to.hash` prop (if `to` is an object)
|
|
176
|
+
if (isObject(to) && (to.path || to.query || to.hash)) {
|
|
177
|
+
const path = toString(to.path);
|
|
178
|
+
const query = stringifyQueryObj(to.query);
|
|
179
|
+
let hash = toString(to.hash);
|
|
180
|
+
hash = !hash || hash.charAt(0) === '#' ? hash : `#${hash}`;
|
|
181
|
+
return `${path}${query}${hash}` || fallback;
|
|
182
|
+
}
|
|
183
|
+
return fallback;
|
|
184
|
+
},
|
|
185
|
+
computedProps() {
|
|
186
|
+
const baseRouterLinkProps = {
|
|
187
|
+
to: this.to,
|
|
188
|
+
activeClass: this.activeClass,
|
|
189
|
+
exactActiveClass: this.exactActiveClass,
|
|
190
|
+
replace: this.replace,
|
|
191
|
+
...(isBoolean(this.prefetch) ? {
|
|
192
|
+
prefetch: this.prefetch
|
|
193
|
+
} : {})
|
|
194
|
+
};
|
|
195
|
+
if (this.isRouterLink) {
|
|
196
|
+
if (this.isVue3RouterLink) {
|
|
197
|
+
return baseRouterLinkProps;
|
|
198
|
+
}
|
|
199
|
+
return {
|
|
200
|
+
...baseRouterLinkProps,
|
|
201
|
+
...this.$attrs
|
|
202
|
+
};
|
|
203
|
+
}
|
|
204
|
+
return {
|
|
205
|
+
disabled: this.disabled,
|
|
206
|
+
...(this.disabled ? {
|
|
207
|
+
'aria-disabled': 'true',
|
|
208
|
+
tabindex: '-1'
|
|
209
|
+
} : {}),
|
|
210
|
+
rel: this.rel,
|
|
211
|
+
target: this.target,
|
|
212
|
+
href: this.computedHref,
|
|
213
|
+
...this.$attrs
|
|
214
|
+
};
|
|
215
|
+
},
|
|
216
|
+
computedListeners() {
|
|
217
|
+
const {
|
|
218
|
+
click,
|
|
219
|
+
...listenersWithoutClick
|
|
220
|
+
} = this.$listeners;
|
|
221
|
+
return listenersWithoutClick;
|
|
222
|
+
},
|
|
223
|
+
computedClass() {
|
|
224
|
+
if (this.variant === linkVariantUnstyled) {
|
|
225
|
+
return [];
|
|
226
|
+
}
|
|
227
|
+
return ['gl-link', linkVariantOptions[this.variant], {
|
|
228
|
+
disabled: this.disabled,
|
|
229
|
+
active: this.active,
|
|
230
|
+
'gl-link-external': this.shouldShowExternalIcon
|
|
231
|
+
}];
|
|
232
|
+
}
|
|
233
|
+
},
|
|
234
|
+
methods: {
|
|
235
|
+
onClick(event, navigate) {
|
|
236
|
+
const eventIsEvent = event instanceof Event;
|
|
237
|
+
const suppliedHandler = this.$listeners.click;
|
|
238
|
+
if (eventIsEvent && this.disabled) {
|
|
239
|
+
// Stop event from bubbling up
|
|
240
|
+
// Kill the event loop attached to this specific `EventTarget`
|
|
241
|
+
// Needed to prevent `vue-router` from navigating
|
|
242
|
+
stopEvent(event, {
|
|
243
|
+
immediatePropagation: true
|
|
244
|
+
});
|
|
245
|
+
} else {
|
|
246
|
+
// Router links do not emit instance `click` events, so we
|
|
247
|
+
// add in an `$emit('click', event)` on its Vue instance
|
|
248
|
+
//
|
|
249
|
+
// seems not to be required for Vue3 compat build
|
|
250
|
+
if (this.isRouterLink) {
|
|
251
|
+
var _event$currentTarget$;
|
|
252
|
+
// eslint-disable-next-line no-underscore-dangle
|
|
253
|
+
(_event$currentTarget$ = event.currentTarget.__vue__) === null || _event$currentTarget$ === void 0 ? void 0 : _event$currentTarget$.$emit('click', event);
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
// Call the suppliedHandler(s), if any provided
|
|
257
|
+
concat([], suppliedHandler).filter(h => isFunction(h)).forEach(handler => {
|
|
258
|
+
// eslint-disable-next-line prefer-rest-params
|
|
259
|
+
handler(...arguments);
|
|
260
|
+
});
|
|
261
|
+
|
|
262
|
+
// this navigate function comes from Vue 3 router
|
|
263
|
+
// See https://router.vuejs.org/guide/advanced/extending-router-link.html#Extending-RouterLink
|
|
264
|
+
if (isFunction(navigate)) {
|
|
265
|
+
navigate(event);
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
// TODO: Remove deprecated 'clicked::link' event
|
|
269
|
+
this.$root.$emit('clicked::link', event);
|
|
270
|
+
}
|
|
271
|
+
// Stop scroll-to-top behavior or navigation on
|
|
272
|
+
// regular links when href is just '#'
|
|
273
|
+
if (eventIsEvent && !this.isRouterLink && this.computedHref === '#') {
|
|
274
|
+
stopEvent(event, {
|
|
275
|
+
stopPropagation: false
|
|
276
|
+
});
|
|
277
|
+
}
|
|
278
|
+
},
|
|
279
|
+
focus() {
|
|
280
|
+
this.$el.focus();
|
|
281
|
+
},
|
|
282
|
+
blur() {
|
|
283
|
+
this.$el.blur();
|
|
284
|
+
}
|
|
285
|
+
}
|
|
286
|
+
};
|
|
287
|
+
|
|
288
|
+
/* script */
|
|
289
|
+
const __vue_script__ = script;
|
|
290
|
+
|
|
291
|
+
/* template */
|
|
292
|
+
var __vue_render__ = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return (_vm.isVue3RouterLink)?_c(_vm.tag,_vm._b({tag:"component",attrs:{"custom":""},scopedSlots:_vm._u([{key:"default",fn:function(ref){
|
|
293
|
+
var _obj;
|
|
294
|
+
|
|
295
|
+
var routerLinkHref = ref.href;
|
|
296
|
+
var isActive = ref.isActive;
|
|
297
|
+
var isExactActive = ref.isExactActive;
|
|
298
|
+
var navigate = ref.navigate;return [_c('a',_vm._g(_vm._b({directives:[{name:"safe-link",rawName:"v-safe-link:[safeLinkConfig]",arg:_vm.safeLinkConfig}],class:[_vm.computedClass, ( _obj = {}, _obj[_vm.activeClass] = isActive, _obj[_vm.exactActiveClass] = isExactActive, _obj )],attrs:{"href":routerLinkHref},on:{"click":function($event){return _vm.onClick($event, navigate)}}},'a',_vm.$attrs,false),_vm.computedListeners),[_vm._t("default")],2)]}}],null,true)},'component',_vm.computedProps,false)):(_vm.isRouterLink)?_c(_vm.tag,_vm._g(_vm._b({directives:[{name:"safe-link",rawName:"v-safe-link:[safeLinkConfig]",arg:_vm.safeLinkConfig}],tag:"component",class:_vm.computedClass,nativeOn:{"click":function($event){return _vm.onClick.apply(null, arguments)}}},'component',_vm.computedProps,false),_vm.computedListeners),[_vm._t("default")],2):_c(_vm.tag,_vm._g(_vm._b({directives:[{name:"safe-link",rawName:"v-safe-link:[safeLinkConfig]",arg:_vm.safeLinkConfig}],tag:"component",class:_vm.computedClass,on:{"click":_vm.onClick}},'component',_vm.computedProps,false),_vm.computedListeners),[_vm._t("default")],2)};
|
|
299
|
+
var __vue_staticRenderFns__ = [];
|
|
300
|
+
|
|
301
|
+
/* style */
|
|
302
|
+
const __vue_inject_styles__ = undefined;
|
|
303
|
+
/* scoped */
|
|
304
|
+
const __vue_scope_id__ = undefined;
|
|
305
|
+
/* module identifier */
|
|
306
|
+
const __vue_module_identifier__ = undefined;
|
|
307
|
+
/* functional template */
|
|
308
|
+
const __vue_is_functional_template__ = false;
|
|
309
|
+
/* style inject */
|
|
310
|
+
|
|
311
|
+
/* style inject SSR */
|
|
312
|
+
|
|
313
|
+
/* style inject shadow dom */
|
|
314
|
+
|
|
315
|
+
|
|
316
|
+
|
|
317
|
+
const __vue_component__ = /*#__PURE__*/__vue_normalize__(
|
|
318
|
+
{ render: __vue_render__, staticRenderFns: __vue_staticRenderFns__ },
|
|
319
|
+
__vue_inject_styles__,
|
|
320
|
+
__vue_script__,
|
|
321
|
+
__vue_scope_id__,
|
|
322
|
+
__vue_is_functional_template__,
|
|
323
|
+
__vue_module_identifier__,
|
|
324
|
+
false,
|
|
325
|
+
undefined,
|
|
326
|
+
undefined,
|
|
327
|
+
undefined
|
|
328
|
+
);
|
|
329
|
+
|
|
330
|
+
export { __vue_component__ as default };
|