@gitlab/ui 122.4.0 → 122.6.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.
Files changed (44) hide show
  1. package/dist/components/charts/bar/bar.js +3 -58
  2. package/dist/components/charts/shared/tooltip/tooltip.js +26 -7
  3. package/dist/components/dashboards/dashboard_panel/dashboard_panel.js +12 -3
  4. package/dist/index.css +2 -2
  5. package/dist/index.css.map +1 -1
  6. package/dist/tailwind.css +1 -1
  7. package/dist/tailwind.css.map +1 -1
  8. package/dist/tokens/build/js/tokens.dark.js +33 -1
  9. package/dist/tokens/build/js/tokens.js +33 -1
  10. package/dist/tokens/css/tokens.css +32 -0
  11. package/dist/tokens/css/tokens.dark.css +32 -0
  12. package/dist/tokens/docs/tokens-tailwind-docs.dark.json +802 -0
  13. package/dist/tokens/docs/tokens-tailwind-docs.json +802 -0
  14. package/dist/tokens/figma/constants.tokens.json +226 -0
  15. package/dist/tokens/js/tokens.dark.js +32 -0
  16. package/dist/tokens/js/tokens.js +32 -0
  17. package/dist/tokens/json/tokens.dark.json +770 -0
  18. package/dist/tokens/json/tokens.json +770 -0
  19. package/dist/tokens/scss/_tokens.dark.scss +32 -0
  20. package/dist/tokens/scss/_tokens.scss +32 -0
  21. package/dist/tokens/scss/_tokens_custom_properties.scss +32 -0
  22. package/dist/tokens/tailwind/tokens.cjs +2 -0
  23. package/dist/utils/charts/config.js +26 -7
  24. package/package.json +1 -1
  25. package/src/components/charts/bar/bar.vue +14 -55
  26. package/src/components/charts/shared/tooltip/tooltip.vue +29 -6
  27. package/src/components/dashboards/dashboard_panel/dashboard_panel.vue +33 -10
  28. package/src/scss/variables.scss +0 -29
  29. package/src/tokens/build/css/tokens.css +32 -0
  30. package/src/tokens/build/css/tokens.dark.css +32 -0
  31. package/src/tokens/build/docs/tokens-tailwind-docs.dark.json +802 -0
  32. package/src/tokens/build/docs/tokens-tailwind-docs.json +802 -0
  33. package/src/tokens/build/figma/constants.tokens.json +226 -0
  34. package/src/tokens/build/js/tokens.dark.js +32 -0
  35. package/src/tokens/build/js/tokens.js +32 -0
  36. package/src/tokens/build/json/tokens.dark.json +770 -0
  37. package/src/tokens/build/json/tokens.json +770 -0
  38. package/src/tokens/build/scss/_tokens.dark.scss +32 -0
  39. package/src/tokens/build/scss/_tokens.scss +32 -0
  40. package/src/tokens/build/scss/_tokens_custom_properties.scss +32 -0
  41. package/src/tokens/build/tailwind/tokens.cjs +35 -0
  42. package/src/tokens/constant/spacing_scale.tokens.json +228 -0
  43. package/src/utils/charts/config.js +22 -11
  44. package/tailwind.defaults.js +1 -38
@@ -237,6 +237,38 @@ $gl-line-height-36: 2.25rem;
237
237
  $gl-line-height-42: 2.625rem;
238
238
  $gl-line-height-44: 2.75rem;
239
239
  $gl-line-height-52: 3.25rem;
240
+ $gl-spacing-scale-0: 0;
241
+ $gl-spacing-scale-1: 0.125rem;
242
+ $gl-spacing-scale-2: 0.25rem;
243
+ $gl-spacing-scale-3: 0.5rem;
244
+ $gl-spacing-scale-4: 0.75rem;
245
+ $gl-spacing-scale-5: 1rem;
246
+ $gl-spacing-scale-6: 1.5rem;
247
+ $gl-spacing-scale-7: 2rem;
248
+ $gl-spacing-scale-8: 2.5rem;
249
+ $gl-spacing-scale-9: 3rem;
250
+ $gl-spacing-scale-10: 3.5rem;
251
+ $gl-spacing-scale-11: 4rem;
252
+ $gl-spacing-scale-12: 5rem;
253
+ $gl-spacing-scale-13: 6rem;
254
+ $gl-spacing-scale-15: 7.5rem;
255
+ $gl-spacing-scale-18: 9rem;
256
+ $gl-spacing-scale-20: 10rem;
257
+ $gl-spacing-scale-26: 13rem;
258
+ $gl-spacing-scale-28: 14rem;
259
+ $gl-spacing-scale-30: 15rem;
260
+ $gl-spacing-scale-31: 15.5rem;
261
+ $gl-spacing-scale-33: 16.5rem;
262
+ $gl-spacing-scale-34: 17rem;
263
+ $gl-spacing-scale-37: 18.5rem;
264
+ $gl-spacing-scale-48: 24rem;
265
+ $gl-spacing-scale-62: 31rem;
266
+ $gl-spacing-scale-75: 37.5rem;
267
+ $gl-spacing-scale-80: 40rem;
268
+ $gl-spacing-scale-88: 44rem;
269
+ $gl-spacing-scale-px: 1px;
270
+ $gl-spacing-scale-2-5: 0.375rem;
271
+ $gl-spacing-scale-11-5: 4.5rem;
240
272
  $gl-avatar-fallback-background-color-red: #fcb5aa3d; // Red background for avatar fallback with no particular meaning.
241
273
  $gl-avatar-fallback-background-color-purple: #cbbbf23d; // Purple background for avatar fallback with no particular meaning.
242
274
  $gl-avatar-fallback-background-color-blue: #9dc7f13d; // Blue background for avatar fallback with no particular meaning.
@@ -237,6 +237,38 @@ $gl-line-height-36: 2.25rem;
237
237
  $gl-line-height-42: 2.625rem;
238
238
  $gl-line-height-44: 2.75rem;
239
239
  $gl-line-height-52: 3.25rem;
240
+ $gl-spacing-scale-0: 0;
241
+ $gl-spacing-scale-1: 0.125rem;
242
+ $gl-spacing-scale-2: 0.25rem;
243
+ $gl-spacing-scale-3: 0.5rem;
244
+ $gl-spacing-scale-4: 0.75rem;
245
+ $gl-spacing-scale-5: 1rem;
246
+ $gl-spacing-scale-6: 1.5rem;
247
+ $gl-spacing-scale-7: 2rem;
248
+ $gl-spacing-scale-8: 2.5rem;
249
+ $gl-spacing-scale-9: 3rem;
250
+ $gl-spacing-scale-10: 3.5rem;
251
+ $gl-spacing-scale-11: 4rem;
252
+ $gl-spacing-scale-12: 5rem;
253
+ $gl-spacing-scale-13: 6rem;
254
+ $gl-spacing-scale-15: 7.5rem;
255
+ $gl-spacing-scale-18: 9rem;
256
+ $gl-spacing-scale-20: 10rem;
257
+ $gl-spacing-scale-26: 13rem;
258
+ $gl-spacing-scale-28: 14rem;
259
+ $gl-spacing-scale-30: 15rem;
260
+ $gl-spacing-scale-31: 15.5rem;
261
+ $gl-spacing-scale-33: 16.5rem;
262
+ $gl-spacing-scale-34: 17rem;
263
+ $gl-spacing-scale-37: 18.5rem;
264
+ $gl-spacing-scale-48: 24rem;
265
+ $gl-spacing-scale-62: 31rem;
266
+ $gl-spacing-scale-75: 37.5rem;
267
+ $gl-spacing-scale-80: 40rem;
268
+ $gl-spacing-scale-88: 44rem;
269
+ $gl-spacing-scale-px: 1px;
270
+ $gl-spacing-scale-2-5: 0.375rem;
271
+ $gl-spacing-scale-11-5: 4.5rem;
240
272
  $gl-avatar-fallback-background-color-red: #fcb5aa3d; // Red background for avatar fallback with no particular meaning.
241
273
  $gl-avatar-fallback-background-color-purple: #cbbbf23d; // Purple background for avatar fallback with no particular meaning.
242
274
  $gl-avatar-fallback-background-color-blue: #9dc7f13d; // Blue background for avatar fallback with no particular meaning.
@@ -238,6 +238,38 @@ $gl-line-height-36: var(--gl-line-height-36);
238
238
  $gl-line-height-42: var(--gl-line-height-42);
239
239
  $gl-line-height-44: var(--gl-line-height-44);
240
240
  $gl-line-height-52: var(--gl-line-height-52);
241
+ $gl-spacing-scale-0: var(--gl-spacing-scale-0);
242
+ $gl-spacing-scale-1: var(--gl-spacing-scale-1);
243
+ $gl-spacing-scale-2: var(--gl-spacing-scale-2);
244
+ $gl-spacing-scale-3: var(--gl-spacing-scale-3);
245
+ $gl-spacing-scale-4: var(--gl-spacing-scale-4);
246
+ $gl-spacing-scale-5: var(--gl-spacing-scale-5);
247
+ $gl-spacing-scale-6: var(--gl-spacing-scale-6);
248
+ $gl-spacing-scale-7: var(--gl-spacing-scale-7);
249
+ $gl-spacing-scale-8: var(--gl-spacing-scale-8);
250
+ $gl-spacing-scale-9: var(--gl-spacing-scale-9);
251
+ $gl-spacing-scale-10: var(--gl-spacing-scale-10);
252
+ $gl-spacing-scale-11: var(--gl-spacing-scale-11);
253
+ $gl-spacing-scale-12: var(--gl-spacing-scale-12);
254
+ $gl-spacing-scale-13: var(--gl-spacing-scale-13);
255
+ $gl-spacing-scale-15: var(--gl-spacing-scale-15);
256
+ $gl-spacing-scale-18: var(--gl-spacing-scale-18);
257
+ $gl-spacing-scale-20: var(--gl-spacing-scale-20);
258
+ $gl-spacing-scale-26: var(--gl-spacing-scale-26);
259
+ $gl-spacing-scale-28: var(--gl-spacing-scale-28);
260
+ $gl-spacing-scale-30: var(--gl-spacing-scale-30);
261
+ $gl-spacing-scale-31: var(--gl-spacing-scale-31);
262
+ $gl-spacing-scale-33: var(--gl-spacing-scale-33);
263
+ $gl-spacing-scale-34: var(--gl-spacing-scale-34);
264
+ $gl-spacing-scale-37: var(--gl-spacing-scale-37);
265
+ $gl-spacing-scale-48: var(--gl-spacing-scale-48);
266
+ $gl-spacing-scale-62: var(--gl-spacing-scale-62);
267
+ $gl-spacing-scale-75: var(--gl-spacing-scale-75);
268
+ $gl-spacing-scale-80: var(--gl-spacing-scale-80);
269
+ $gl-spacing-scale-88: var(--gl-spacing-scale-88);
270
+ $gl-spacing-scale-px: var(--gl-spacing-scale-px);
271
+ $gl-spacing-scale-2-5: var(--gl-spacing-scale-2-5);
272
+ $gl-spacing-scale-11-5: var(--gl-spacing-scale-11-5);
241
273
  $gl-alert-neutral-title-color: var(--gl-alert-neutral-title-color);
242
274
  $gl-alert-neutral-background-color: var(--gl-alert-neutral-background-color);
243
275
  $gl-alert-neutral-border-top-color: var(--gl-alert-neutral-border-top-color);
@@ -352,6 +352,40 @@ const feedbackIconColors = {
352
352
  'feedback-warning': 'var(--gl-feedback-warning-icon-color, var(--gl-color-orange-600, #995715))',
353
353
  'feedback-danger': 'var(--gl-feedback-danger-icon-color, var(--gl-color-red-600, #c02f12))',
354
354
  };
355
+ const spacingScale = {
356
+ 0: 'var(--gl-spacing-scale-0, 0)',
357
+ 1: 'var(--gl-spacing-scale-1, 0.125rem)',
358
+ 2: 'var(--gl-spacing-scale-2, 0.25rem)',
359
+ 3: 'var(--gl-spacing-scale-3, 0.5rem)',
360
+ 4: 'var(--gl-spacing-scale-4, 0.75rem)',
361
+ 5: 'var(--gl-spacing-scale-5, 1rem)',
362
+ 6: 'var(--gl-spacing-scale-6, 1.5rem)',
363
+ 7: 'var(--gl-spacing-scale-7, 2rem)',
364
+ 8: 'var(--gl-spacing-scale-8, 2.5rem)',
365
+ 9: 'var(--gl-spacing-scale-9, 3rem)',
366
+ 10: 'var(--gl-spacing-scale-10, 3.5rem)',
367
+ 11: 'var(--gl-spacing-scale-11, 4rem)',
368
+ 12: 'var(--gl-spacing-scale-12, 5rem)',
369
+ 13: 'var(--gl-spacing-scale-13, 6rem)',
370
+ 15: 'var(--gl-spacing-scale-15, 7.5rem)',
371
+ 18: 'var(--gl-spacing-scale-18, 9rem)',
372
+ 20: 'var(--gl-spacing-scale-20, 10rem)',
373
+ 26: 'var(--gl-spacing-scale-26, 13rem)',
374
+ 28: 'var(--gl-spacing-scale-28, 14rem)',
375
+ 30: 'var(--gl-spacing-scale-30, 15rem)',
376
+ 31: 'var(--gl-spacing-scale-31, 15.5rem)',
377
+ 33: 'var(--gl-spacing-scale-33, 16.5rem)',
378
+ 34: 'var(--gl-spacing-scale-34, 17rem)',
379
+ 37: 'var(--gl-spacing-scale-37, 18.5rem)',
380
+ 48: 'var(--gl-spacing-scale-48, 24rem)',
381
+ 62: 'var(--gl-spacing-scale-62, 31rem)',
382
+ 75: 'var(--gl-spacing-scale-75, 37.5rem)',
383
+ 80: 'var(--gl-spacing-scale-80, 40rem)',
384
+ 88: 'var(--gl-spacing-scale-88, 44rem)',
385
+ px: 'var(--gl-spacing-scale-px, 1px)',
386
+ '2-5': 'var(--gl-spacing-scale-2-5, 0.375rem)',
387
+ '11-5': 'var(--gl-spacing-scale-11-5, 4.5rem)',
388
+ };
355
389
 
356
390
  const colors = {
357
391
  inherit: 'inherit',
@@ -433,4 +467,5 @@ module.exports = {
433
467
  outlineColor,
434
468
  textColor,
435
469
  fill,
470
+ spacing: spacingScale,
436
471
  };
@@ -0,0 +1,228 @@
1
+ {
2
+ "spacing-scale": {
3
+ "0": {
4
+ "$value": "0",
5
+ "$type": "dimension",
6
+ "$extensions": {
7
+ "com.figma.scope": []
8
+ }
9
+ },
10
+ "px": {
11
+ "$value": "1px",
12
+ "$type": "dimension",
13
+ "$extensions": {
14
+ "com.figma.scope": []
15
+ }
16
+ },
17
+ "1": {
18
+ "$value": "0.125rem",
19
+ "$type": "dimension",
20
+ "$extensions": {
21
+ "com.figma.scope": []
22
+ }
23
+ },
24
+ "2": {
25
+ "$value": "0.25rem",
26
+ "$type": "dimension",
27
+ "$extensions": {
28
+ "com.figma.scope": []
29
+ }
30
+ },
31
+ "2-5": {
32
+ "$value": "0.375rem",
33
+ "$type": "dimension",
34
+ "$extensions": {
35
+ "com.figma.scope": []
36
+ }
37
+ },
38
+ "3": {
39
+ "$value": "0.5rem",
40
+ "$type": "dimension",
41
+ "$extensions": {
42
+ "com.figma.scope": []
43
+ }
44
+ },
45
+ "4": {
46
+ "$value": "0.75rem",
47
+ "$type": "dimension",
48
+ "$extensions": {
49
+ "com.figma.scope": []
50
+ }
51
+ },
52
+ "5": {
53
+ "$value": "1rem",
54
+ "$type": "dimension",
55
+ "$extensions": {
56
+ "com.figma.scope": []
57
+ }
58
+ },
59
+ "6": {
60
+ "$value": "1.5rem",
61
+ "$type": "dimension",
62
+ "$extensions": {
63
+ "com.figma.scope": []
64
+ }
65
+ },
66
+ "7": {
67
+ "$value": "2rem",
68
+ "$type": "dimension",
69
+ "$extensions": {
70
+ "com.figma.scope": []
71
+ }
72
+ },
73
+ "8": {
74
+ "$value": "2.5rem",
75
+ "$type": "dimension",
76
+ "$extensions": {
77
+ "com.figma.scope": []
78
+ }
79
+ },
80
+ "9": {
81
+ "$value": "3rem",
82
+ "$type": "dimension",
83
+ "$extensions": {
84
+ "com.figma.scope": []
85
+ }
86
+ },
87
+ "10": {
88
+ "$value": "3.5rem",
89
+ "$type": "dimension",
90
+ "$extensions": {
91
+ "com.figma.scope": []
92
+ }
93
+ },
94
+ "11": {
95
+ "$value": "4rem",
96
+ "$type": "dimension",
97
+ "$extensions": {
98
+ "com.figma.scope": []
99
+ }
100
+ },
101
+ "11-5": {
102
+ "$value": "4.5rem",
103
+ "$type": "dimension",
104
+ "$extensions": {
105
+ "com.figma.scope": []
106
+ }
107
+ },
108
+ "12": {
109
+ "$value": "5rem",
110
+ "$type": "dimension",
111
+ "$extensions": {
112
+ "com.figma.scope": []
113
+ }
114
+ },
115
+ "13": {
116
+ "$value": "6rem",
117
+ "$type": "dimension",
118
+ "$extensions": {
119
+ "com.figma.scope": []
120
+ }
121
+ },
122
+ "15": {
123
+ "$value": "7.5rem",
124
+ "$type": "dimension",
125
+ "$extensions": {
126
+ "com.figma.scope": []
127
+ }
128
+ },
129
+ "18": {
130
+ "$value": "9rem",
131
+ "$type": "dimension",
132
+ "$extensions": {
133
+ "com.figma.scope": []
134
+ }
135
+ },
136
+ "20": {
137
+ "$value": "10rem",
138
+ "$type": "dimension",
139
+ "$extensions": {
140
+ "com.figma.scope": []
141
+ }
142
+ },
143
+ "26": {
144
+ "$value": "13rem",
145
+ "$type": "dimension",
146
+ "$extensions": {
147
+ "com.figma.scope": []
148
+ }
149
+ },
150
+ "28": {
151
+ "$value": "14rem",
152
+ "$type": "dimension",
153
+ "$extensions": {
154
+ "com.figma.scope": []
155
+ }
156
+ },
157
+ "30": {
158
+ "$value": "15rem",
159
+ "$type": "dimension",
160
+ "$extensions": {
161
+ "com.figma.scope": []
162
+ }
163
+ },
164
+ "31": {
165
+ "$value": "15.5rem",
166
+ "$type": "dimension",
167
+ "$extensions": {
168
+ "com.figma.scope": []
169
+ }
170
+ },
171
+ "33": {
172
+ "$value": "16.5rem",
173
+ "$type": "dimension",
174
+ "$extensions": {
175
+ "com.figma.scope": []
176
+ }
177
+ },
178
+ "34": {
179
+ "$value": "17rem",
180
+ "$type": "dimension",
181
+ "$extensions": {
182
+ "com.figma.scope": []
183
+ }
184
+ },
185
+ "37": {
186
+ "$value": "18.5rem",
187
+ "$type": "dimension",
188
+ "$extensions": {
189
+ "com.figma.scope": []
190
+ }
191
+ },
192
+ "48": {
193
+ "$value": "24rem",
194
+ "$type": "dimension",
195
+ "$extensions": {
196
+ "com.figma.scope": []
197
+ }
198
+ },
199
+ "62": {
200
+ "$value": "31rem",
201
+ "$type": "dimension",
202
+ "$extensions": {
203
+ "com.figma.scope": []
204
+ }
205
+ },
206
+ "75": {
207
+ "$value": "37.5rem",
208
+ "$type": "dimension",
209
+ "$extensions": {
210
+ "com.figma.scope": []
211
+ }
212
+ },
213
+ "80": {
214
+ "$value": "40rem",
215
+ "$type": "dimension",
216
+ "$extensions": {
217
+ "com.figma.scope": []
218
+ }
219
+ },
220
+ "88": {
221
+ "$value": "44rem",
222
+ "$type": "dimension",
223
+ "$extensions": {
224
+ "com.figma.scope": []
225
+ }
226
+ }
227
+ }
228
+ }
@@ -432,22 +432,36 @@ export const generateLineSeries = ({ name, color, data = [], yAxisIndex = 0 }) =
432
432
  itemStyle: { color },
433
433
  });
434
434
 
435
- export const getTooltipTitle = (params = null, titleAxisName = null) => {
435
+ export const getTooltipAxisConfig = (dimensionAxis) => {
436
+ if (!['xAxis', 'yAxis'].includes(dimensionAxis)) {
437
+ throw new Error(`\`dimensionAxis\` must be "xAxis" or "yAxis", received ${dimensionAxis}`);
438
+ }
439
+
440
+ if (dimensionAxis === 'xAxis') {
441
+ return { dimensionIndex: 0, metricIndex: 1, valueAxis: 'yAxis' };
442
+ }
443
+
444
+ return { dimensionIndex: 1, metricIndex: 0, valueAxis: 'xAxis' };
445
+ };
446
+
447
+ export const getTooltipTitle = (params = null, titleAxisName = null, dimensionIndex = 0) => {
436
448
  if (!params) return '';
437
449
 
438
450
  const title = params.seriesData
439
451
  .reduce((acc, { value }) => {
440
- if (acc.includes(value[0])) {
452
+ const dimension = value[dimensionIndex];
453
+
454
+ if (acc.includes(dimension)) {
441
455
  return acc;
442
456
  }
443
- return [...acc, value[0]];
457
+ return [...acc, dimension];
444
458
  }, [])
445
459
  .join(', ');
446
460
 
447
461
  return titleAxisName ? `${title} (${titleAxisName})` : title;
448
462
  };
449
463
 
450
- export const getTooltipContent = (params = null, valueAxisName = null) => {
464
+ export const getTooltipContent = (params = null, valueAxisName = null, metricIndex = 1) => {
451
465
  if (!params) {
452
466
  return {};
453
467
  }
@@ -455,22 +469,19 @@ export const getTooltipContent = (params = null, valueAxisName = null) => {
455
469
  const { seriesData } = params;
456
470
 
457
471
  if (seriesData.length === 1) {
458
- const {
459
- value: [, yValue],
460
- seriesName,
461
- } = seriesData[0];
472
+ const { value, seriesName } = seriesData[0];
462
473
 
463
474
  return {
464
475
  [valueAxisName || seriesName]: {
465
- value: yValue,
476
+ value: value[metricIndex],
466
477
  color: '', // ignore color when showing a single series
467
478
  },
468
479
  };
469
480
  }
470
481
 
471
482
  return seriesData.reduce((acc, { value, seriesName, color }) => {
472
- const yValue = value[1];
473
- acc[seriesName] = { value: yValue, color };
483
+ acc[seriesName] = { value: value[metricIndex], color };
484
+
474
485
  return acc;
475
486
  }, {});
476
487
  };
@@ -8,48 +8,11 @@ const {
8
8
  outlineColor,
9
9
  fill,
10
10
  textColor,
11
+ spacing,
11
12
  } = require('./src/tokens/build/tailwind/tokens.cjs');
12
13
 
13
14
  const buildCQs = Boolean(process.env.USE_TAILWIND_CONTAINER_QUERIES);
14
15
 
15
- const gridSize = 0.5; // rem
16
- const spacing = {
17
- 0: '0',
18
- px: '1px',
19
- ...Object.fromEntries(
20
- Object.entries({
21
- 1: 0.25,
22
- 2: 0.5,
23
- 3: 1,
24
- 4: 1.5,
25
- 5: 2,
26
- 6: 3,
27
- 7: 4,
28
- 8: 5,
29
- 9: 6,
30
- 10: 7,
31
- 11: 8,
32
- '11-5': 9,
33
- 12: 10,
34
- 13: 12,
35
- 15: 15,
36
- 20: 20,
37
- 26: 26,
38
- 28: 28,
39
- 30: 30,
40
- 31: 31,
41
- 34: 34,
42
- 48: 48,
43
- 62: 62,
44
- 75: 75,
45
- 80: 80,
46
- 88: 88,
47
- }).map(([scale, factor]) => {
48
- return [scale, `${factor * gridSize}rem`];
49
- }),
50
- ),
51
- };
52
-
53
16
  function addCustomDefinitions({ addComponents, addUtilities }) {
54
17
  addComponents({
55
18
  '.action-neutral-colors': {