@gitlab/ui 132.0.3 → 132.2.0
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/components/base/accordion/accordion_item.js +1 -3
- package/dist/components/base/avatar/avatar.js +76 -5
- package/dist/components/base/badge/badge.js +5 -7
- package/dist/components/base/button/button.js +1 -3
- package/dist/components/base/collapse/collapse.js +2 -6
- package/dist/components/base/datepicker/datepicker.js +4 -5
- package/dist/components/base/daterange_picker/daterange_picker.js +2 -4
- package/dist/components/base/dropdown/dropdown_item.js +3 -4
- package/dist/components/base/filtered_search/filtered_search.js +55 -7
- package/dist/components/base/filtered_search/filtered_search_token.js +6 -14
- package/dist/components/base/filtered_search/filtered_search_token_segment.js +39 -19
- package/dist/components/base/filtered_search/filtered_search_utils.js +57 -7
- package/dist/components/base/form/form_checkbox/form_checkbox.js +13 -26
- package/dist/components/base/form/form_checkbox/form_checkbox_group.js +1 -3
- package/dist/components/base/form/form_fields/form_fields_loop.js +57 -6
- package/dist/components/base/form/form_group/form_group.js +1 -3
- package/dist/components/base/form/form_input/form_input.js +95 -41
- package/dist/components/base/form/form_input_group/form_input_group.js +2 -4
- package/dist/components/base/form/form_radio/form_radio.js +5 -9
- package/dist/components/base/form/form_radio_group/form_radio_group.js +1 -3
- package/dist/components/base/form/form_select/form_select.js +76 -5
- package/dist/components/base/infinite_scroll/infinite_scroll.js +7 -14
- package/dist/components/base/link/link.js +26 -7
- package/dist/components/base/new_dropdowns/base_dropdown/base_dropdown.js +93 -32
- package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown.js +2 -6
- package/dist/components/base/new_dropdowns/disclosure/disclosure_dropdown_item.js +2 -6
- package/dist/components/base/new_dropdowns/listbox/listbox.js +5 -13
- package/dist/components/base/new_dropdowns/listbox/listbox_item.js +1 -3
- package/dist/components/base/new_dropdowns/listbox/mock_data.js +2 -6
- package/dist/components/base/new_dropdowns/listbox/utils.js +6 -11
- package/dist/components/base/path/path.js +1 -5
- package/dist/components/base/search_box_by_type/search_box_by_type.js +2 -6
- package/dist/components/base/skeleton_loader/skeleton_loader.js +3 -5
- package/dist/components/base/table/table.js +32 -21
- package/dist/components/base/table_lite/table_lite.js +1 -3
- package/dist/components/base/tabs/tab/tab.js +1 -3
- package/dist/components/base/tabs/tabs/scrollable_tabs.js +1 -5
- package/dist/components/base/token_selector/token_selector.js +2 -6
- package/dist/components/charts/area/area.js +6 -7
- package/dist/components/charts/column/column.js +11 -15
- package/dist/components/charts/discrete_scatter/discrete_scatter.js +57 -5
- package/dist/components/charts/gauge/gauge.js +13 -21
- package/dist/components/charts/heatmap/heatmap.js +66 -18
- package/dist/components/charts/legend/legend.js +59 -13
- package/dist/components/charts/line/line.js +6 -7
- package/dist/components/charts/shared/tooltip/tooltip.js +11 -18
- package/dist/components/charts/sparkline/sparkline.js +72 -19
- package/dist/components/charts/stacked_column/stacked_column.js +18 -31
- package/dist/components/dashboards/dashboard_layout/grid_layout/grid_layout.js +40 -24
- package/dist/components/utilities/friendly_wrap/friendly_wrap.js +3 -7
- package/dist/components/utilities/intersperse/intersperse.js +6 -11
- package/dist/components/utilities/sprintf/sprintf.js +58 -7
- package/dist/components/utilities/truncate/truncate.js +2 -4
- package/dist/components/utilities/truncate_text/truncate_text.js +1 -3
- package/dist/config.js +3 -4
- package/dist/directives/hover_load/hover_load.js +1 -3
- package/dist/directives/outside/outside.js +9 -16
- package/dist/directives/resize_observer/resize_observer.js +6 -8
- package/dist/directives/safe_html/safe_html.js +1 -3
- package/dist/directives/safe_link/safe_link.js +11 -14
- package/dist/index.css +2 -2
- package/dist/index.css.map +1 -1
- package/dist/tokens/build/js/tokens.dark.js +95 -95
- package/dist/tokens/build/js/tokens.js +74 -74
- package/dist/tokens/common_story_options.js +7 -8
- package/dist/utils/charts/config.js +122 -90
- package/dist/utils/constants.js +26 -1
- package/dist/utils/data_utils.js +28 -1
- package/dist/utils/form_options_utils.js +4 -6
- package/dist/utils/is_slot_empty.js +3 -5
- package/dist/utils/stories_utils.js +8 -8
- package/dist/utils/use_mock_intersection_observer.js +63 -12
- package/dist/utils/utils.js +76 -19
- package/dist/vendor/bootstrap-vue/src/components/button/button-close.js +8 -11
- package/dist/vendor/bootstrap-vue/src/components/button/button.js +12 -17
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-divider.js +3 -6
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-form.js +6 -9
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-group.js +14 -19
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-header.js +8 -13
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-item-button.js +9 -12
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.js +8 -11
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.js +9 -14
- package/dist/vendor/bootstrap-vue/src/components/dropdown/dropdown.js +34 -43
- package/dist/vendor/bootstrap-vue/src/components/form/form-invalid-feedback.js +5 -9
- package/dist/vendor/bootstrap-vue/src/components/form/form-text.js +7 -10
- package/dist/vendor/bootstrap-vue/src/components/form/form-valid-feedback.js +5 -9
- package/dist/vendor/bootstrap-vue/src/components/form/form.js +7 -10
- package/dist/vendor/bootstrap-vue/src/components/form-group/form-group.js +77 -33
- package/dist/vendor/bootstrap-vue/src/components/form-select/form-select-option-group.js +6 -11
- package/dist/vendor/bootstrap-vue/src/components/form-select/form-select-option.js +6 -12
- package/dist/vendor/bootstrap-vue/src/components/form-select/form-select.js +28 -29
- package/dist/vendor/bootstrap-vue/src/components/form-textarea/form-textarea.js +7 -10
- package/dist/vendor/bootstrap-vue/src/components/layout/col.js +7 -11
- package/dist/vendor/bootstrap-vue/src/components/layout/form-row.js +3 -5
- package/dist/vendor/bootstrap-vue/src/components/link/link.js +19 -31
- package/dist/vendor/bootstrap-vue/src/components/modal/helpers/modal-manager.js +3 -4
- package/dist/vendor/bootstrap-vue/src/components/modal/modal.js +59 -68
- package/dist/vendor/bootstrap-vue/src/components/popover/helpers/bv-popover-template.js +2 -4
- package/dist/vendor/bootstrap-vue/src/components/popover/popover.js +4 -5
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/default-sort-compare.js +11 -7
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-bottom-row.js +4 -6
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-busy.js +3 -6
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-caption.js +4 -7
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-colgroup.js +1 -3
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-empty.js +16 -20
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-filtering.js +14 -25
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-items.js +23 -35
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-pagination.js +6 -8
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-provider.js +8 -10
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-selectable.js +8 -15
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-sorting.js +33 -41
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-stacked.js +3 -8
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-table-renderer.js +38 -50
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tbody-row.js +19 -31
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tbody.js +13 -23
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-tfoot.js +5 -6
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-thead.js +17 -21
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/mixin-top-row.js +4 -6
- package/dist/vendor/bootstrap-vue/src/components/table/helpers/sanitize-row.js +1 -3
- package/dist/vendor/bootstrap-vue/src/components/table/tbody.js +3 -6
- package/dist/vendor/bootstrap-vue/src/components/table/td.js +9 -14
- package/dist/vendor/bootstrap-vue/src/components/table/tfoot.js +1 -2
- package/dist/vendor/bootstrap-vue/src/components/table/thead.js +1 -2
- package/dist/vendor/bootstrap-vue/src/components/table/tr.js +2 -5
- package/dist/vendor/bootstrap-vue/src/components/tabs/tab.js +19 -36
- package/dist/vendor/bootstrap-vue/src/components/tabs/tabs.js +66 -81
- package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-popper.js +2 -6
- package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip-template.js +5 -11
- package/dist/vendor/bootstrap-vue/src/components/tooltip/helpers/bv-tooltip.js +8 -14
- package/dist/vendor/bootstrap-vue/src/components/tooltip/tooltip.js +19 -22
- package/dist/vendor/bootstrap-vue/src/components/transition/bv-transition.js +7 -10
- package/dist/vendor/bootstrap-vue/src/components/transporter/transporter.js +7 -14
- package/dist/vendor/bootstrap-vue/src/directives/modal/modal.js +4 -5
- package/dist/vendor/bootstrap-vue/src/directives/visible/visible.js +5 -9
- package/dist/vendor/bootstrap-vue/src/mixins/dropdown.js +17 -29
- package/dist/vendor/bootstrap-vue/src/mixins/form-control.js +6 -7
- package/dist/vendor/bootstrap-vue/src/mixins/form-custom.js +1 -2
- package/dist/vendor/bootstrap-vue/src/mixins/form-options.js +5 -6
- package/dist/vendor/bootstrap-vue/src/mixins/form-size.js +1 -2
- package/dist/vendor/bootstrap-vue/src/mixins/form-state.js +1 -2
- package/dist/vendor/bootstrap-vue/src/mixins/form-text.js +29 -43
- package/dist/vendor/bootstrap-vue/src/mixins/id.js +1 -2
- package/dist/vendor/bootstrap-vue/src/utils/create-new-child-component.js +62 -15
- package/dist/vendor/bootstrap-vue/src/utils/dom.js +3 -9
- package/dist/vendor/bootstrap-vue/src/utils/events.js +7 -5
- package/dist/vendor/bootstrap-vue/src/utils/plugins.js +4 -5
- package/dist/vendor/bootstrap-vue/src/utils/router.js +9 -13
- package/package.json +10 -8
- package/src/components/dashboards/dashboard_layout/grid_layout/grid_layout.vue +21 -19
- package/src/scss/gitlab_ui.scss +3 -0
- package/src/scss/storybook.scss +3 -0
- package/src/scss/themes.scss +84 -0
- package/src/tokens/build/css/tokens.css +142 -142
- package/src/tokens/build/css/tokens.dark.css +138 -138
- package/src/tokens/build/docs/tokens-tailwind-docs.dark.json +580 -580
- package/src/tokens/build/docs/tokens-tailwind-docs.json +495 -495
- package/src/tokens/build/figma/constants.dark.json +799 -799
- package/src/tokens/build/figma/constants.json +799 -799
- package/src/tokens/build/js/tokens.dark.js +95 -95
- package/src/tokens/build/js/tokens.js +74 -74
- package/src/tokens/build/json/tokens.dark.json +1668 -1668
- package/src/tokens/build/json/tokens.json +1647 -1647
- package/src/tokens/build/scss/_tokens.dark.scss +138 -138
- package/src/tokens/build/scss/_tokens.scss +142 -142
- package/src/tokens/build/scss/_tokens_custom_properties.scss +73 -73
- package/src/tokens/constant/color.blue.tokens.json +182 -0
- package/src/tokens/constant/color.brand.tokens.json +252 -0
- package/src/tokens/constant/color.data.tokens.json +894 -0
- package/src/tokens/constant/color.green.tokens.json +182 -0
- package/src/tokens/constant/color.neutral.tokens.json +230 -0
- package/src/tokens/constant/color.orange.tokens.json +182 -0
- package/src/tokens/constant/color.purple.tokens.json +182 -0
- package/src/tokens/constant/color.red.tokens.json +182 -0
- package/src/tokens/constant/color.theme.tokens.json +1168 -0
- package/src/tokens/deprecated/deprecated.color.tokens.json +134 -1340
- package/src/utils/constants.js +9 -0
- package/src/vendor/bootstrap-vue/src/components/button/button-close.js +4 -5
- package/src/vendor/bootstrap-vue/src/components/button/button.js +7 -8
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-divider.js +1 -2
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-form.js +2 -8
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-group.js +6 -7
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-header.js +3 -4
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item-button.js +6 -12
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-item.js +2 -3
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown-text.js +3 -4
- package/src/vendor/bootstrap-vue/src/components/dropdown/dropdown.js +19 -26
- package/src/vendor/bootstrap-vue/src/components/form/form-text.js +4 -6
- package/src/vendor/bootstrap-vue/src/components/form/form.js +4 -6
- package/src/vendor/bootstrap-vue/src/components/form-group/form-group.js +66 -19
- package/src/vendor/bootstrap-vue/src/components/form-select/form-select-option-group.js +1 -2
- package/src/vendor/bootstrap-vue/src/components/form-select/form-select-option.js +1 -4
- package/src/vendor/bootstrap-vue/src/components/form-select/form-select.js +13 -14
- package/src/vendor/bootstrap-vue/src/components/form-textarea/form-textarea.js +5 -6
- package/src/vendor/bootstrap-vue/src/components/modal/modal.js +53 -62
- package/src/vendor/bootstrap-vue/src/components/popover/popover.js +4 -10
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-busy.js +1 -2
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-caption.js +2 -3
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-empty.js +5 -6
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-filtering.js +5 -13
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-items.js +12 -21
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-pagination.js +2 -3
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-provider.js +5 -11
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-selectable.js +4 -5
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-sorting.js +14 -21
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-stacked.js +1 -2
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-table-renderer.js +14 -20
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-tbody-row.js +3 -9
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-tbody.js +1 -2
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-tfoot.js +5 -11
- package/src/vendor/bootstrap-vue/src/components/table/helpers/mixin-thead.js +4 -5
- package/src/vendor/bootstrap-vue/src/components/table/tbody.js +2 -3
- package/src/vendor/bootstrap-vue/src/components/table/td.js +5 -6
- package/src/vendor/bootstrap-vue/src/components/table/tfoot.js +1 -2
- package/src/vendor/bootstrap-vue/src/components/table/thead.js +1 -2
- package/src/vendor/bootstrap-vue/src/components/table/tr.js +1 -2
- package/src/vendor/bootstrap-vue/src/components/tabs/tab.js +10 -16
- package/src/vendor/bootstrap-vue/src/components/tabs/tabs.js +33 -39
- package/src/vendor/bootstrap-vue/src/components/tooltip/tooltip.js +17 -25
- package/src/vendor/bootstrap-vue/src/components/transition/bv-transition.js +4 -5
- package/src/vendor/bootstrap-vue/src/components/transporter/transporter.js +4 -10
- package/src/vendor/bootstrap-vue/src/mixins/dropdown.js +9 -15
- package/src/vendor/bootstrap-vue/src/mixins/form-control.js +6 -7
- package/src/vendor/bootstrap-vue/src/mixins/form-custom.js +1 -2
- package/src/vendor/bootstrap-vue/src/mixins/form-options.js +5 -6
- package/src/vendor/bootstrap-vue/src/mixins/form-size.js +1 -2
- package/src/vendor/bootstrap-vue/src/mixins/form-state.js +1 -2
- package/src/vendor/bootstrap-vue/src/mixins/form-text.js +21 -33
- package/src/vendor/bootstrap-vue/src/mixins/id.js +1 -2
- package/dist/vendor/bootstrap-vue/src/mixins/model.js +0 -10
- package/dist/vendor/bootstrap-vue/src/utils/model.js +0 -33
- package/src/tokens/constant/color.tokens.json +0 -3422
- package/src/vendor/bootstrap-vue/src/mixins/model.js +0 -5
- package/src/vendor/bootstrap-vue/src/utils/model.js +0 -29
|
@@ -1,8 +1,32 @@
|
|
|
1
|
+
import { markRaw } from 'vue';
|
|
1
2
|
import { GridStack } from 'gridstack';
|
|
2
3
|
import { pickBy } from 'lodash-es';
|
|
3
4
|
import { breakpoints } from '../../../../utils/breakpoints';
|
|
4
5
|
import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js';
|
|
5
6
|
|
|
7
|
+
function _objectWithoutProperties(e, t) {
|
|
8
|
+
if (null == e) return {};
|
|
9
|
+
var o,
|
|
10
|
+
r,
|
|
11
|
+
i = _objectWithoutPropertiesLoose(e, t);
|
|
12
|
+
if (Object.getOwnPropertySymbols) {
|
|
13
|
+
var n = Object.getOwnPropertySymbols(e);
|
|
14
|
+
for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]);
|
|
15
|
+
}
|
|
16
|
+
return i;
|
|
17
|
+
}
|
|
18
|
+
function _objectWithoutPropertiesLoose(r, e) {
|
|
19
|
+
if (null == r) return {};
|
|
20
|
+
var t = {};
|
|
21
|
+
for (var n in r) if ({}.hasOwnProperty.call(r, n)) {
|
|
22
|
+
if (-1 !== e.indexOf(n)) continue;
|
|
23
|
+
t[n] = r[n];
|
|
24
|
+
}
|
|
25
|
+
return t;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
const _excluded = ["gridAttributes"],
|
|
29
|
+
_excluded2 = ["grid"];
|
|
6
30
|
const CURSOR_GRABBING_CLASS = '!gl-cursor-grabbing';
|
|
7
31
|
var script = {
|
|
8
32
|
name: 'GlGridLayout',
|
|
@@ -63,17 +87,14 @@ var script = {
|
|
|
63
87
|
},
|
|
64
88
|
data() {
|
|
65
89
|
return {
|
|
66
|
-
grid: undefined,
|
|
67
90
|
gridPanels: []
|
|
68
91
|
};
|
|
69
92
|
},
|
|
70
93
|
computed: {
|
|
71
94
|
gridConfig() {
|
|
72
95
|
return this.value.panels.map(panel => {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
...otherProps
|
|
76
|
-
} = panel;
|
|
96
|
+
panel.gridAttributes;
|
|
97
|
+
const otherProps = _objectWithoutProperties(panel, _excluded);
|
|
77
98
|
return {
|
|
78
99
|
...this.getPanelGridItemConfig(panel),
|
|
79
100
|
props: otherProps
|
|
@@ -165,7 +186,7 @@ var script = {
|
|
|
165
186
|
},
|
|
166
187
|
initGridStack() {
|
|
167
188
|
// See https://github.com/gridstack/gridstack.js/tree/master/doc#grid-options
|
|
168
|
-
this.grid = GridStack.init({
|
|
189
|
+
this.grid = markRaw(GridStack.init({
|
|
169
190
|
// Uniform gap between panels
|
|
170
191
|
margin: '8px',
|
|
171
192
|
// CSS Selector for finding the drag handle element
|
|
@@ -185,7 +206,7 @@ var script = {
|
|
|
185
206
|
float: true,
|
|
186
207
|
// Toggles user-customization of grid layout
|
|
187
208
|
staticGrid: this.isStaticGrid
|
|
188
|
-
}, this.$refs.grid).load(this.gridConfig);
|
|
209
|
+
}, this.$refs.grid)).load(this.gridConfig);
|
|
189
210
|
|
|
190
211
|
// Sync Vue components array with gridstack items
|
|
191
212
|
this.initGridPanelSlots(this.grid.getGridItems());
|
|
@@ -207,19 +228,16 @@ var script = {
|
|
|
207
228
|
});
|
|
208
229
|
},
|
|
209
230
|
getPanelGridItemConfig(_ref) {
|
|
210
|
-
let
|
|
211
|
-
gridAttributes
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
},
|
|
221
|
-
id
|
|
222
|
-
} = _ref;
|
|
231
|
+
let _ref$gridAttributes = _ref.gridAttributes,
|
|
232
|
+
xPos = _ref$gridAttributes.xPos,
|
|
233
|
+
yPos = _ref$gridAttributes.yPos,
|
|
234
|
+
width = _ref$gridAttributes.width,
|
|
235
|
+
height = _ref$gridAttributes.height,
|
|
236
|
+
minHeight = _ref$gridAttributes.minHeight,
|
|
237
|
+
minWidth = _ref$gridAttributes.minWidth,
|
|
238
|
+
maxHeight = _ref$gridAttributes.maxHeight,
|
|
239
|
+
maxWidth = _ref$gridAttributes.maxWidth,
|
|
240
|
+
id = _ref.id;
|
|
223
241
|
const filterUndefinedValues = obj => pickBy(obj, value => value !== undefined);
|
|
224
242
|
|
|
225
243
|
// GridStack renders undefined layout values so we need to filter them out.
|
|
@@ -253,10 +271,8 @@ var script = {
|
|
|
253
271
|
},
|
|
254
272
|
addGridPanels(items) {
|
|
255
273
|
const newPanels = items.map(_ref2 => {
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
...rest
|
|
259
|
-
} = _ref2;
|
|
274
|
+
_ref2.grid;
|
|
275
|
+
let rest = _objectWithoutProperties(_ref2, _excluded2);
|
|
260
276
|
return {
|
|
261
277
|
...rest
|
|
262
278
|
};
|
|
@@ -23,13 +23,9 @@ var script = {
|
|
|
23
23
|
}
|
|
24
24
|
},
|
|
25
25
|
render(createElement, _ref) {
|
|
26
|
-
let
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
const {
|
|
30
|
-
symbols,
|
|
31
|
-
text
|
|
32
|
-
} = props;
|
|
26
|
+
let props = _ref.props;
|
|
27
|
+
const symbols = props.symbols,
|
|
28
|
+
text = props.text;
|
|
33
29
|
const textParts = splitAfterSymbols(symbols, text !== null && text !== void 0 ? text : '');
|
|
34
30
|
const content = intersperse(() => createElement('wbr'), textParts);
|
|
35
31
|
return createElement('span', {
|
|
@@ -4,9 +4,7 @@ import { isVnodeEmpty } from '../../../utils/is_slot_empty';
|
|
|
4
4
|
import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js';
|
|
5
5
|
|
|
6
6
|
const filterEmptyNodesVue2 = vNodes => vNodes.filter(vNode => typeof vNode.tag === 'string' || vNode.text.trim() !== '');
|
|
7
|
-
const
|
|
8
|
-
Fragment
|
|
9
|
-
} = Vue;
|
|
7
|
+
const Fragment = Vue.Fragment;
|
|
10
8
|
const filterEmptyNodesVue3 = vNode => {
|
|
11
9
|
return vNode.reduce((acc, node) => {
|
|
12
10
|
if (Fragment && node.type === Fragment && Array.isArray(node.children)) {
|
|
@@ -51,14 +49,11 @@ var script = {
|
|
|
51
49
|
}
|
|
52
50
|
},
|
|
53
51
|
render(createElement, context) {
|
|
54
|
-
const
|
|
55
|
-
props
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
slots,
|
|
60
|
-
data
|
|
61
|
-
} = context;
|
|
52
|
+
const _context$props = context.props,
|
|
53
|
+
separator = _context$props.separator,
|
|
54
|
+
lastSeparator = _context$props.lastSeparator,
|
|
55
|
+
slots = context.slots,
|
|
56
|
+
data = context.data;
|
|
62
57
|
const slotContent = slots().default || [];
|
|
63
58
|
const filtered = filterEmptyNodes(slotContent);
|
|
64
59
|
const separated = intersperse(separator, filtered);
|
|
@@ -1,7 +1,55 @@
|
|
|
1
1
|
import { isString, has } from 'lodash-es';
|
|
2
2
|
import __vue_normalize__ from 'vue-runtime-helpers/dist/normalize-component.js';
|
|
3
3
|
|
|
4
|
-
|
|
4
|
+
function _arrayLikeToArray(r, a) {
|
|
5
|
+
(null == a || a > r.length) && (a = r.length);
|
|
6
|
+
for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e];
|
|
7
|
+
return n;
|
|
8
|
+
}
|
|
9
|
+
function _arrayWithHoles(r) {
|
|
10
|
+
if (Array.isArray(r)) return r;
|
|
11
|
+
}
|
|
12
|
+
function _iterableToArrayLimit(r, l) {
|
|
13
|
+
var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"];
|
|
14
|
+
if (null != t) {
|
|
15
|
+
var e,
|
|
16
|
+
n,
|
|
17
|
+
i,
|
|
18
|
+
u,
|
|
19
|
+
a = [],
|
|
20
|
+
f = !0,
|
|
21
|
+
o = !1;
|
|
22
|
+
try {
|
|
23
|
+
if (i = (t = t.call(r)).next, 0 === l) {
|
|
24
|
+
if (Object(t) !== t) return;
|
|
25
|
+
f = !1;
|
|
26
|
+
} else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0);
|
|
27
|
+
} catch (r) {
|
|
28
|
+
o = !0, n = r;
|
|
29
|
+
} finally {
|
|
30
|
+
try {
|
|
31
|
+
if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return;
|
|
32
|
+
} finally {
|
|
33
|
+
if (o) throw n;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return a;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
function _nonIterableRest() {
|
|
40
|
+
throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
|
|
41
|
+
}
|
|
42
|
+
function _slicedToArray(r, e) {
|
|
43
|
+
return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest();
|
|
44
|
+
}
|
|
45
|
+
function _unsupportedIterableToArray(r, a) {
|
|
46
|
+
if (r) {
|
|
47
|
+
if ("string" == typeof r) return _arrayLikeToArray(r, a);
|
|
48
|
+
var t = {}.toString.call(r).slice(8, -1);
|
|
49
|
+
return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
|
|
5
53
|
const PREFIX = '%{';
|
|
6
54
|
const SUFFIX = '}';
|
|
7
55
|
const START_SUFFIX = 'Start';
|
|
@@ -10,7 +58,11 @@ const PLACE_HOLDER_REGEX = new RegExp(`(${PREFIX}[a-z]+[\\w-]*[a-z0-9]+${SUFFIX}
|
|
|
10
58
|
function groupPlaceholdersByStartTag() {
|
|
11
59
|
let placeholders = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
12
60
|
return Object.entries(placeholders).reduce((acc, _ref) => {
|
|
13
|
-
let
|
|
61
|
+
let _ref2 = _slicedToArray(_ref, 2),
|
|
62
|
+
slotName = _ref2[0],
|
|
63
|
+
_ref2$ = _slicedToArray(_ref2[1], 2),
|
|
64
|
+
startTag = _ref2$[0],
|
|
65
|
+
endTag = _ref2$[1];
|
|
14
66
|
acc[startTag] = {
|
|
15
67
|
slotName,
|
|
16
68
|
endTag
|
|
@@ -99,11 +151,10 @@ var script = {
|
|
|
99
151
|
vnodes.push(chunk);
|
|
100
152
|
continue;
|
|
101
153
|
}
|
|
102
|
-
const
|
|
103
|
-
slotName,
|
|
104
|
-
endTag,
|
|
105
|
-
tagName
|
|
106
|
-
} = getPlaceholderDefinition(chunk, placeholdersByStartTag);
|
|
154
|
+
const _getPlaceholderDefini = getPlaceholderDefinition(chunk, placeholdersByStartTag),
|
|
155
|
+
slotName = _getPlaceholderDefini.slotName,
|
|
156
|
+
endTag = _getPlaceholderDefini.endTag,
|
|
157
|
+
tagName = _getPlaceholderDefini.tagName;
|
|
107
158
|
if (endTag) {
|
|
108
159
|
// Peek ahead to find end placeholder, if any
|
|
109
160
|
const indexOfEnd = chunks.indexOf(`${PREFIX}${endTag}${SUFFIX}`, i);
|
|
@@ -51,10 +51,8 @@ var script = {
|
|
|
51
51
|
// See https://infra.spec.whatwg.org/#strip-and-collapse-ascii-whitespace
|
|
52
52
|
// and https://infra.spec.whatwg.org/#ascii-whitespace.
|
|
53
53
|
const collapsibleWhitespaceChar = /^[ \n\t\r\f]$/;
|
|
54
|
-
const
|
|
55
|
-
|
|
56
|
-
middleIndex
|
|
57
|
-
} = this;
|
|
54
|
+
const text = this.text,
|
|
55
|
+
middleIndex = this.middleIndex;
|
|
58
56
|
const lastCharOfFirstIsCollapsibleWhitespace = collapsibleWhitespaceChar.test(text.charAt(middleIndex - 1));
|
|
59
57
|
const firstCharOfLastIsCollapsibleWhitespace = collapsibleWhitespaceChar.test(text.charAt(middleIndex));
|
|
60
58
|
return lastCharOfFirstIsCollapsibleWhitespace && !firstCharOfLastIsCollapsibleWhitespace;
|
package/dist/config.js
CHANGED
|
@@ -17,10 +17,9 @@ let configured = false;
|
|
|
17
17
|
*
|
|
18
18
|
*/
|
|
19
19
|
const setConfigs = function () {
|
|
20
|
-
let {
|
|
21
|
-
translations,
|
|
22
|
-
firstDayOfWeek
|
|
23
|
-
} = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
20
|
+
let _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
|
|
21
|
+
translations = _ref.translations,
|
|
22
|
+
firstDayOfWeek = _ref.firstDayOfWeek;
|
|
24
23
|
if (configured) {
|
|
25
24
|
if (process.env.NODE_ENV === 'development') {
|
|
26
25
|
throw new Error('GitLab UI can only be configured once!');
|
|
@@ -4,9 +4,7 @@ const DELAY_ON_HOVER = 100;
|
|
|
4
4
|
let mouseOverTimer;
|
|
5
5
|
let mouseOverHandler;
|
|
6
6
|
const bind = (el, _ref) => {
|
|
7
|
-
let
|
|
8
|
-
value: loadHandler
|
|
9
|
-
} = _ref;
|
|
7
|
+
let loadHandler = _ref.value;
|
|
10
8
|
if (!isFunction(loadHandler)) {
|
|
11
9
|
throw TypeError('Directive value must be a function');
|
|
12
10
|
}
|
|
@@ -17,10 +17,8 @@ const activeEventTypes = new Set();
|
|
|
17
17
|
let lastMousedown = null;
|
|
18
18
|
const globalListener = event => {
|
|
19
19
|
callbacks.forEach((_ref, element) => {
|
|
20
|
-
let
|
|
21
|
-
|
|
22
|
-
eventTypes
|
|
23
|
-
} = _ref;
|
|
20
|
+
let callback = _ref.callback,
|
|
21
|
+
eventTypes = _ref.eventTypes;
|
|
24
22
|
const originalEvent = event.type === click ? lastMousedown || event : event;
|
|
25
23
|
if (
|
|
26
24
|
// Ignore events that aren't targeted outside the element
|
|
@@ -73,9 +71,7 @@ const stopListening = eventTypesToUnbind => {
|
|
|
73
71
|
eventTypesToUnbind.forEach(eventType => {
|
|
74
72
|
if (activeEventTypes.has(eventType)) {
|
|
75
73
|
if ([...callbacks.values()].every(_ref2 => {
|
|
76
|
-
let
|
|
77
|
-
eventTypes
|
|
78
|
-
} = _ref2;
|
|
74
|
+
let eventTypes = _ref2.eventTypes;
|
|
79
75
|
return !eventTypes.includes(eventType);
|
|
80
76
|
})) {
|
|
81
77
|
document.removeEventListener(eventType, globalListener);
|
|
@@ -88,11 +84,9 @@ const stopListening = eventTypesToUnbind => {
|
|
|
88
84
|
}
|
|
89
85
|
};
|
|
90
86
|
function parseBinding(_ref3) {
|
|
91
|
-
let
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
modifiers
|
|
95
|
-
} = _ref3;
|
|
87
|
+
let arg = _ref3.arg,
|
|
88
|
+
value = _ref3.value,
|
|
89
|
+
modifiers = _ref3.modifiers;
|
|
96
90
|
const modifiersList = Object.keys(modifiers);
|
|
97
91
|
if (process.env.NODE_ENV !== 'production') {
|
|
98
92
|
if (typeof value !== 'function') {
|
|
@@ -112,10 +106,9 @@ function parseBinding(_ref3) {
|
|
|
112
106
|
};
|
|
113
107
|
}
|
|
114
108
|
const bind = (el, bindings) => {
|
|
115
|
-
const
|
|
116
|
-
callback,
|
|
117
|
-
eventTypes
|
|
118
|
-
} = parseBinding(bindings);
|
|
109
|
+
const _parseBinding = parseBinding(bindings),
|
|
110
|
+
callback = _parseBinding.callback,
|
|
111
|
+
eventTypes = _parseBinding.eventTypes;
|
|
119
112
|
if (callbacks.has(el)) {
|
|
120
113
|
// This element is already bound. This is possible if two components, which
|
|
121
114
|
// share the same root node, (i.e., one is a higher-order component
|
|
@@ -33,19 +33,17 @@ const detachObserver = el => {
|
|
|
33
33
|
};
|
|
34
34
|
const GlResizeObserverDirective = {
|
|
35
35
|
bind(el, _ref) {
|
|
36
|
-
let
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
} = _ref;
|
|
36
|
+
let resizeHandler = _ref.value,
|
|
37
|
+
_ref$arg = _ref.arg,
|
|
38
|
+
enabled = _ref$arg === void 0 ? true : _ref$arg;
|
|
40
39
|
if (enabled) {
|
|
41
40
|
attachObserver(el, resizeHandler);
|
|
42
41
|
}
|
|
43
42
|
},
|
|
44
43
|
update(el, _ref2) {
|
|
45
|
-
let
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
} = _ref2;
|
|
44
|
+
let resizeHandler = _ref2.value,
|
|
45
|
+
_ref2$arg = _ref2.arg,
|
|
46
|
+
enabled = _ref2$arg === void 0 ? true : _ref2$arg;
|
|
49
47
|
if (enabled) {
|
|
50
48
|
attachObserver(el, resizeHandler);
|
|
51
49
|
} else {
|
|
@@ -1,9 +1,7 @@
|
|
|
1
1
|
import DOMPurify from 'dompurify';
|
|
2
2
|
import { forbiddenDataAttrs, forbiddenTags } from './constants';
|
|
3
3
|
|
|
4
|
-
const
|
|
5
|
-
sanitize
|
|
6
|
-
} = DOMPurify;
|
|
4
|
+
const sanitize = DOMPurify.sanitize;
|
|
7
5
|
|
|
8
6
|
// Mitigate against future dompurify mXSS bypasses by
|
|
9
7
|
// avoiding additional serialize/parse round trip.
|
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
import Vue from 'vue';
|
|
2
2
|
|
|
3
3
|
const getBaseURL = () => {
|
|
4
|
-
const
|
|
5
|
-
protocol,
|
|
6
|
-
host
|
|
7
|
-
} = window.location;
|
|
4
|
+
const _window$location = window.location,
|
|
5
|
+
protocol = _window$location.protocol,
|
|
6
|
+
host = _window$location.host;
|
|
8
7
|
return `${protocol}//${host}`;
|
|
9
8
|
};
|
|
10
9
|
const isTargetBlank = target => {
|
|
@@ -32,19 +31,17 @@ const isSafeURL = url => {
|
|
|
32
31
|
}
|
|
33
32
|
};
|
|
34
33
|
const transform = function (el) {
|
|
35
|
-
let {
|
|
36
|
-
arg
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
34
|
+
let _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
|
|
35
|
+
_ref$arg = _ref.arg,
|
|
36
|
+
_ref$arg2 = _ref$arg === void 0 ? {} : _ref$arg,
|
|
37
|
+
_ref$arg2$skipSanitiz = _ref$arg2.skipSanitization,
|
|
38
|
+
skipSanitization = _ref$arg2$skipSanitiz === void 0 ? false : _ref$arg2$skipSanitiz;
|
|
40
39
|
if (skipSanitization) {
|
|
41
40
|
return;
|
|
42
41
|
}
|
|
43
|
-
const
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
rel
|
|
47
|
-
} = el;
|
|
42
|
+
const href = el.href,
|
|
43
|
+
target = el.target,
|
|
44
|
+
rel = el.rel;
|
|
48
45
|
if (!isSafeURL(href)) {
|
|
49
46
|
el.href = 'about:blank';
|
|
50
47
|
}
|