Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
gitlab-ce
Commits
3069a2c9
Commit
3069a2c9
authored
Apr 03, 2017
by
Jose Ivan Vargas
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Removed formatRelevantDigits from text_utils.js and added it to a new file number_utils.js
Also improved code formatting
parent
d745876e
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
169 additions
and
142 deletions
+169
-142
app/assets/javascripts/lib/utils/number_utils.js
app/assets/javascripts/lib/utils/number_utils.js
+34
-0
app/assets/javascripts/lib/utils/text_utility.js
app/assets/javascripts/lib/utils/text_utility.js
+0
-24
app/assets/javascripts/monitoring/prometheus_graph.js
app/assets/javascripts/monitoring/prometheus_graph.js
+94
-92
spec/javascripts/lib/utils/number_utility_spec.js
spec/javascripts/lib/utils/number_utility_spec.js
+41
-0
spec/javascripts/lib/utils/text_utility_spec.js
spec/javascripts/lib/utils/text_utility_spec.js
+0
-26
No files found.
app/assets/javascripts/lib/utils/number_utils.js
0 → 100644
View file @
3069a2c9
/* eslint-disable import/prefer-default-export */
/**
* Function that allows a number with an X amount of decimals
* to be formatted in the following fashion:
* * For 1 digit to the left of the decimal point and X digits to the right of it
* * * Show 3 digits to the right
* * For 2 digits to the left of the decimal point and X digits to the right of it
* * * Show 2 digits to the right
*/
export
function
formatRelevantDigits
(
number
)
{
let
digitsLeft
=
''
;
let
relevantDigits
=
0
;
let
formattedNumber
=
''
;
if
(
!
isNaN
(
Number
(
number
)))
{
digitsLeft
=
number
.
split
(
'
.
'
)[
0
];
switch
(
digitsLeft
.
length
)
{
case
1
:
relevantDigits
=
3
;
break
;
case
2
:
relevantDigits
=
2
;
break
;
case
3
:
relevantDigits
=
1
;
break
;
default
:
relevantDigits
=
4
;
break
;
}
formattedNumber
=
Number
(
number
).
toFixed
(
relevantDigits
);
}
return
formattedNumber
;
}
app/assets/javascripts/lib/utils/text_utility.js
View file @
3069a2c9
...
...
@@ -188,29 +188,5 @@ require('vendor/latinise');
gl
.
text
.
slugify
=
function
(
str
)
{
return
str
.
trim
().
toLowerCase
().
latinise
();
};
gl
.
text
.
formatRelevantDigits
=
function
(
number
)
{
var
digitsLeft
=
''
;
var
relevantDigits
=
0
;
if
(
isNaN
(
Number
(
number
)))
{
return
0
;
}
else
{
digitsLeft
=
number
.
split
(
'
.
'
)[
0
];
switch
(
digitsLeft
.
length
)
{
case
1
:
relevantDigits
=
3
;
break
;
case
2
:
relevantDigits
=
2
;
break
;
case
3
:
relevantDigits
=
1
;
break
;
default
:
relevantDigits
=
4
;
break
;
}
return
Number
(
number
).
toFixed
(
relevantDigits
);
}
};
})(
window
);
}).
call
(
window
);
app/assets/javascripts/monitoring/prometheus_graph.js
View file @
3069a2c9
...
...
@@ -3,7 +3,7 @@
import
d3
from
'
d3
'
;
import
statusCodes
from
'
~/lib/utils/http_status
'
;
import
'
../lib/utils/common
_utils
'
;
import
{
formatRelevantDigits
}
from
'
~/lib/utils/number
_utils
'
;
import
'
../flash
'
;
const
prometheusGraphsContainer
=
'
.prometheus-graph
'
;
...
...
@@ -64,10 +64,10 @@ class PrometheusGraph {
const
prometheusGraphContainer
=
`
${
prometheusGraphsContainer
}
[graph-type=
${
key
}
]`
;
const
chart
=
d3
.
select
(
prometheusGraphContainer
)
.
attr
(
'
width
'
,
this
.
width
+
this
.
margin
.
left
+
this
.
margin
.
right
)
.
attr
(
'
height
'
,
this
.
height
+
this
.
margin
.
bottom
+
this
.
margin
.
top
)
.
append
(
'
g
'
)
.
attr
(
'
transform
'
,
`translate(
${
this
.
margin
.
left
}
,
${
this
.
margin
.
top
}
)`
);
.
attr
(
'
width
'
,
this
.
width
+
this
.
margin
.
left
+
this
.
margin
.
right
)
.
attr
(
'
height
'
,
this
.
height
+
this
.
margin
.
bottom
+
this
.
margin
.
top
)
.
append
(
'
g
'
)
.
attr
(
'
transform
'
,
`translate(
${
this
.
margin
.
left
}
,
${
this
.
margin
.
top
}
)`
);
const
axisLabelContainer
=
d3
.
select
(
prometheusGraphContainer
)
.
attr
(
'
width
'
,
this
.
originalWidth
)
...
...
@@ -79,26 +79,26 @@ class PrometheusGraph {
y
.
domain
([
0
,
d3
.
max
(
graphSpecifics
.
data
.
map
(
metricValue
=>
metricValue
.
value
))]);
const
xAxis
=
d3
.
svg
.
axis
()
.
scale
(
x
)
.
ticks
(
this
.
commonGraphProperties
.
axis_no_ticks
)
.
orient
(
'
bottom
'
);
.
scale
(
x
)
.
ticks
(
this
.
commonGraphProperties
.
axis_no_ticks
)
.
orient
(
'
bottom
'
);
const
yAxis
=
d3
.
svg
.
axis
()
.
scale
(
y
)
.
ticks
(
this
.
commonGraphProperties
.
axis_no_ticks
)
.
tickSize
(
-
this
.
width
)
.
orient
(
'
left
'
);
.
scale
(
y
)
.
ticks
(
this
.
commonGraphProperties
.
axis_no_ticks
)
.
tickSize
(
-
this
.
width
)
.
orient
(
'
left
'
);
this
.
createAxisLabelContainers
(
axisLabelContainer
,
key
);
chart
.
append
(
'
g
'
)
.
attr
(
'
class
'
,
'
x-axis
'
)
.
attr
(
'
transform
'
,
`translate(0,
${
this
.
height
}
)`
)
.
call
(
xAxis
);
.
attr
(
'
class
'
,
'
x-axis
'
)
.
attr
(
'
transform
'
,
`translate(0,
${
this
.
height
}
)`
)
.
call
(
xAxis
);
chart
.
append
(
'
g
'
)
.
attr
(
'
class
'
,
'
y-axis
'
)
.
call
(
yAxis
);
.
attr
(
'
class
'
,
'
y-axis
'
)
.
call
(
yAxis
);
const
area
=
d3
.
svg
.
area
()
.
x
(
d
=>
x
(
d
.
time
))
...
...
@@ -111,10 +111,10 @@ class PrometheusGraph {
.
y
(
d
=>
y
(
d
.
value
));
chart
.
append
(
'
path
'
)
.
datum
(
graphSpecifics
.
data
)
.
attr
(
'
d
'
,
area
)
.
attr
(
'
class
'
,
'
metric-area
'
)
.
attr
(
'
fill
'
,
graphSpecifics
.
area_fill_color
);
.
datum
(
graphSpecifics
.
data
)
.
attr
(
'
d
'
,
area
)
.
attr
(
'
class
'
,
'
metric-area
'
)
.
attr
(
'
fill
'
,
graphSpecifics
.
area_fill_color
);
chart
.
append
(
'
path
'
)
.
datum
(
graphSpecifics
.
data
)
...
...
@@ -137,73 +137,74 @@ class PrometheusGraph {
const
graphSpecifics
=
this
.
graphSpecificProperties
[
key
];
axisLabelContainer
.
append
(
'
line
'
)
.
attr
(
'
class
'
,
'
label-x-axis-line
'
)
.
attr
(
'
stroke
'
,
'
#000000
'
)
.
attr
(
'
stroke-width
'
,
'
1
'
)
.
attr
({
x1
:
10
,
y1
:
this
.
originalHeight
-
this
.
margin
.
top
,
x2
:
(
this
.
originalWidth
-
this
.
margin
.
right
)
+
10
,
y2
:
this
.
originalHeight
-
this
.
margin
.
top
,
});
.
attr
(
'
class
'
,
'
label-x-axis-line
'
)
.
attr
(
'
stroke
'
,
'
#000000
'
)
.
attr
(
'
stroke-width
'
,
'
1
'
)
.
attr
({
x1
:
10
,
y1
:
this
.
originalHeight
-
this
.
margin
.
top
,
x2
:
(
this
.
originalWidth
-
this
.
margin
.
right
)
+
10
,
y2
:
this
.
originalHeight
-
this
.
margin
.
top
,
});
axisLabelContainer
.
append
(
'
line
'
)
.
attr
(
'
class
'
,
'
label-y-axis-line
'
)
.
attr
(
'
stroke
'
,
'
#000000
'
)
.
attr
(
'
stroke-width
'
,
'
1
'
)
.
attr
({
x1
:
10
,
y1
:
0
,
x2
:
10
,
y2
:
this
.
originalHeight
-
this
.
margin
.
top
,
});
.
attr
(
'
class
'
,
'
label-y-axis-line
'
)
.
attr
(
'
stroke
'
,
'
#000000
'
)
.
attr
(
'
stroke-width
'
,
'
1
'
)
.
attr
({
x1
:
10
,
y1
:
0
,
x2
:
10
,
y2
:
this
.
originalHeight
-
this
.
margin
.
top
,
});
axisLabelContainer
.
append
(
'
rect
'
)
.
attr
(
'
class
'
,
'
rect-axis-text
'
)
.
attr
(
'
x
'
,
0
)
.
attr
(
'
y
'
,
50
)
.
attr
(
'
width
'
,
30
)
.
attr
(
'
height
'
,
150
);
.
attr
(
'
class
'
,
'
rect-axis-text
'
)
.
attr
(
'
x
'
,
0
)
.
attr
(
'
y
'
,
50
)
.
attr
(
'
width
'
,
30
)
.
attr
(
'
height
'
,
150
);
axisLabelContainer
.
append
(
'
text
'
)
.
attr
(
'
class
'
,
'
label-axis-text
'
)
.
attr
(
'
text-anchor
'
,
'
middle
'
)
.
attr
(
'
transform
'
,
`translate(15,
${(
this
.
originalHeight
-
this
.
margin
.
top
)
/
2
}
) rotate(-90)`
)
.
text
(
graphSpecifics
.
graph_legend_title
);
.
attr
(
'
class
'
,
'
label-axis-text
'
)
.
attr
(
'
text-anchor
'
,
'
middle
'
)
.
attr
(
'
transform
'
,
`translate(15,
${(
this
.
originalHeight
-
this
.
margin
.
top
)
/
2
}
) rotate(-90)`
)
.
text
(
graphSpecifics
.
graph_legend_title
);
axisLabelContainer
.
append
(
'
rect
'
)
.
attr
(
'
class
'
,
'
rect-axis-text
'
)
.
attr
(
'
x
'
,
(
this
.
originalWidth
/
2
)
-
this
.
margin
.
right
)
.
attr
(
'
y
'
,
this
.
originalHeight
-
100
)
.
attr
(
'
width
'
,
30
)
.
attr
(
'
height
'
,
80
);
.
attr
(
'
class
'
,
'
rect-axis-text
'
)
.
attr
(
'
x
'
,
(
this
.
originalWidth
/
2
)
-
this
.
margin
.
right
)
.
attr
(
'
y
'
,
this
.
originalHeight
-
100
)
.
attr
(
'
width
'
,
30
)
.
attr
(
'
height
'
,
80
);
axisLabelContainer
.
append
(
'
text
'
)
.
attr
(
'
class
'
,
'
label-axis-text
'
)
.
attr
(
'
x
'
,
(
this
.
originalWidth
/
2
)
-
this
.
margin
.
right
)
.
attr
(
'
y
'
,
this
.
originalHeight
-
this
.
margin
.
top
)
.
attr
(
'
dy
'
,
'
.35em
'
)
.
text
(
'
Time
'
);
.
attr
(
'
class
'
,
'
label-axis-text
'
)
.
attr
(
'
x
'
,
(
this
.
originalWidth
/
2
)
-
this
.
margin
.
right
)
.
attr
(
'
y
'
,
this
.
originalHeight
-
this
.
margin
.
top
)
.
attr
(
'
dy
'
,
'
.35em
'
)
.
text
(
'
Time
'
);
// Legends
// Metric Usage
axisLabelContainer
.
append
(
'
rect
'
)
.
attr
(
'
x
'
,
this
.
originalWidth
-
170
)
.
attr
(
'
y
'
,
(
this
.
originalHeight
/
2
)
-
60
)
.
style
(
'
fill
'
,
graphSpecifics
.
area_fill_color
)
.
attr
(
'
width
'
,
20
)
.
attr
(
'
height
'
,
35
);
.
attr
(
'
x
'
,
this
.
originalWidth
-
170
)
.
attr
(
'
y
'
,
(
this
.
originalHeight
/
2
)
-
60
)
.
style
(
'
fill
'
,
graphSpecifics
.
area_fill_color
)
.
attr
(
'
width
'
,
20
)
.
attr
(
'
height
'
,
35
);
axisLabelContainer
.
append
(
'
text
'
)
.
attr
(
'
class
'
,
'
text-metric-title
'
)
.
attr
(
'
x
'
,
this
.
originalWidth
-
140
)
.
attr
(
'
y
'
,
(
this
.
originalHeight
/
2
)
-
50
)
.
text
(
'
Average
'
);
.
attr
(
'
class
'
,
'
text-metric-title
'
)
.
attr
(
'
x
'
,
this
.
originalWidth
-
140
)
.
attr
(
'
y
'
,
(
this
.
originalHeight
/
2
)
-
50
)
.
text
(
'
Average
'
);
axisLabelContainer
.
append
(
'
text
'
)
.
attr
(
'
class
'
,
'
text-metric-usage
'
)
.
attr
(
'
x
'
,
this
.
originalWidth
-
140
)
.
attr
(
'
y
'
,
(
this
.
originalHeight
/
2
)
-
25
);
.
attr
(
'
class
'
,
'
text-metric-usage
'
)
.
attr
(
'
x
'
,
this
.
originalWidth
-
140
)
.
attr
(
'
y
'
,
(
this
.
originalHeight
/
2
)
-
25
);
}
handleMouseOverGraph
(
prometheusGraphContainer
)
{
...
...
@@ -240,44 +241,45 @@ class PrometheusGraph {
});
currentChart
.
append
(
'
circle
'
)
.
attr
(
'
class
'
,
'
circle-metric
'
)
.
attr
(
'
fill
'
,
currentGraphProps
.
line_color
)
.
attr
(
'
cx
'
,
currentTimeCoordinate
)
.
attr
(
'
cy
'
,
currentGraphProps
.
yScale
(
currentData
.
value
))
.
attr
(
'
r
'
,
this
.
commonGraphProperties
.
circle_radius_metric
);
.
attr
(
'
class
'
,
'
circle-metric
'
)
.
attr
(
'
fill
'
,
currentGraphProps
.
line_color
)
.
attr
(
'
cx
'
,
currentTimeCoordinate
)
.
attr
(
'
cy
'
,
currentGraphProps
.
yScale
(
currentData
.
value
))
.
attr
(
'
r
'
,
this
.
commonGraphProperties
.
circle_radius_metric
);
// The little box with text
const
rectTextMetric
=
currentChart
.
append
(
'
g
'
)
.
attr
(
'
class
'
,
'
rect-text-metric
'
)
.
attr
(
'
translate
'
,
`(
${
currentTimeCoordinate
}
,
${
currentGraphProps
.
yScale
(
currentData
.
value
)}
)`
);
.
attr
(
'
class
'
,
'
rect-text-metric
'
)
.
attr
(
'
translate
'
,
`(
${
currentTimeCoordinate
}
,
${
currentGraphProps
.
yScale
(
currentData
.
value
)}
)`
);
rectTextMetric
.
append
(
'
rect
'
)
.
attr
(
'
class
'
,
'
rect-metric
'
)
.
attr
(
'
x
'
,
currentTimeCoordinate
+
10
)
.
attr
(
'
y
'
,
maxMetricValue
)
.
attr
(
'
width
'
,
this
.
commonGraphProperties
.
rect_text_width
)
.
attr
(
'
height
'
,
this
.
commonGraphProperties
.
rect_text_height
);
.
attr
(
'
class
'
,
'
rect-metric
'
)
.
attr
(
'
x
'
,
currentTimeCoordinate
+
10
)
.
attr
(
'
y
'
,
maxMetricValue
)
.
attr
(
'
width
'
,
this
.
commonGraphProperties
.
rect_text_width
)
.
attr
(
'
height
'
,
this
.
commonGraphProperties
.
rect_text_height
);
rectTextMetric
.
append
(
'
text
'
)
.
attr
(
'
class
'
,
'
text-metric
'
)
.
attr
(
'
x
'
,
currentTimeCoordinate
+
35
)
.
attr
(
'
y
'
,
maxMetricValue
+
35
)
.
text
(
timeFormat
(
currentData
.
time
));
.
attr
(
'
class
'
,
'
text-metric
'
)
.
attr
(
'
x
'
,
currentTimeCoordinate
+
35
)
.
attr
(
'
y
'
,
maxMetricValue
+
35
)
.
text
(
timeFormat
(
currentData
.
time
));
rectTextMetric
.
append
(
'
text
'
)
.
attr
(
'
class
'
,
'
text-metric-date
'
)
.
attr
(
'
x
'
,
currentTimeCoordinate
+
15
)
.
attr
(
'
y
'
,
maxMetricValue
+
15
)
.
text
(
dayFormat
(
currentData
.
time
));
.
attr
(
'
class
'
,
'
text-metric-date
'
)
.
attr
(
'
x
'
,
currentTimeCoordinate
+
15
)
.
attr
(
'
y
'
,
maxMetricValue
+
15
)
.
text
(
dayFormat
(
currentData
.
time
));
let
currentMetricValue
=
gl
.
text
.
formatRelevantDigits
(
currentData
.
value
);
let
currentMetricValue
=
formatRelevantDigits
(
currentData
.
value
);
if
(
key
===
'
cpu_values
'
)
{
currentMetricValue
=
`
${
currentMetricValue
}
%`
;
}
else
{
currentMetricValue
=
`
${
currentMetricValue
}
MB`
;
}
d3
.
select
(
`
${
currentPrometheusGraphContainer
}
.text-metric-usage`
)
.
text
(
currentMetricValue
);
.
text
(
currentMetricValue
);
});
}
...
...
spec/javascripts/lib/utils/number_utility_spec.js
0 → 100644
View file @
3069a2c9
import
{
formatRelevantDigits
}
from
'
~/lib/utils/number_utils
'
;
describe
(
'
Number Utils
'
,
()
=>
{
describe
(
'
formatRelevantDigits
'
,
()
=>
{
it
(
'
returns an empty string when the number is NaN
'
,
()
=>
{
expect
(
formatRelevantDigits
(
'
fail
'
)).
toBe
(
''
);
});
it
(
'
returns 4 decimals when there is 4 plus digits to the left
'
,
()
=>
{
const
formattedNumber
=
formatRelevantDigits
(
'
1000.1234567
'
);
const
rightFromDecimal
=
formattedNumber
.
split
(
'
.
'
)[
1
];
const
leftFromDecimal
=
formattedNumber
.
split
(
'
.
'
)[
0
];
expect
(
rightFromDecimal
.
length
).
toBe
(
4
);
expect
(
leftFromDecimal
.
length
).
toBe
(
4
);
});
it
(
'
returns 3 decimals when there is 1 digit to the left
'
,
()
=>
{
const
formattedNumber
=
formatRelevantDigits
(
'
0.1234567
'
);
const
rightFromDecimal
=
formattedNumber
.
split
(
'
.
'
)[
1
];
const
leftFromDecimal
=
formattedNumber
.
split
(
'
.
'
)[
0
];
expect
(
rightFromDecimal
.
length
).
toBe
(
3
);
expect
(
leftFromDecimal
.
length
).
toBe
(
1
);
});
it
(
'
returns 2 decimals when there is 2 digits to the left
'
,
()
=>
{
const
formattedNumber
=
formatRelevantDigits
(
'
10.1234567
'
);
const
rightFromDecimal
=
formattedNumber
.
split
(
'
.
'
)[
1
];
const
leftFromDecimal
=
formattedNumber
.
split
(
'
.
'
)[
0
];
expect
(
rightFromDecimal
.
length
).
toBe
(
2
);
expect
(
leftFromDecimal
.
length
).
toBe
(
2
);
});
it
(
'
returns 1 decimal when there is 3 digits to the left
'
,
()
=>
{
const
formattedNumber
=
formatRelevantDigits
(
'
100.1234567
'
);
const
rightFromDecimal
=
formattedNumber
.
split
(
'
.
'
)[
1
];
const
leftFromDecimal
=
formattedNumber
.
split
(
'
.
'
)[
0
];
expect
(
rightFromDecimal
.
length
).
toBe
(
1
);
expect
(
leftFromDecimal
.
length
).
toBe
(
3
);
});
});
});
spec/javascripts/lib/utils/text_utility_spec.js
View file @
3069a2c9
...
...
@@ -105,32 +105,6 @@ require('~/lib/utils/text_utility');
expect
(
textArea
.
value
).
toEqual
(
`
${
initialValue
}
* `
);
});
});
describe
(
'
gl.text.formatRelevantDigits
'
,
()
=>
{
it
(
'
returns 0 when the number is NaN
'
,
()
=>
{
expect
(
gl
.
text
.
formatRelevantDigits
(
'
fail
'
)).
toBe
(
0
);
});
it
(
'
returns 4 decimals when there is 4 plus digits to the left
'
,
()
=>
{
const
formattedNumber
=
gl
.
text
.
formatRelevantDigits
(
'
1000.1234567
'
).
split
(
'
.
'
)[
1
];
expect
(
formattedNumber
.
length
).
toBe
(
4
);
});
it
(
'
returns 3 decimals when there is 1 digit to the left
'
,
()
=>
{
const
formattedNumber
=
gl
.
text
.
formatRelevantDigits
(
'
0.1234567
'
).
split
(
'
.
'
)[
1
];
expect
(
formattedNumber
.
length
).
toBe
(
3
);
});
it
(
'
returns 2 decimals when there is 2 digits to the left
'
,
()
=>
{
const
formattedNumber
=
gl
.
text
.
formatRelevantDigits
(
'
10.1234567
'
).
split
(
'
.
'
)[
1
];
expect
(
formattedNumber
.
length
).
toBe
(
2
);
});
it
(
'
returns 1 decimal when there is 3 digits to the left
'
,
()
=>
{
const
formattedNumber
=
gl
.
text
.
formatRelevantDigits
(
'
100.1234567
'
).
split
(
'
.
'
)[
1
];
expect
(
formattedNumber
.
length
).
toBe
(
1
);
});
});
});
});
})();
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment