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
da2a7823
Commit
da2a7823
authored
Apr 18, 2017
by
Phil Hughes
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Shows deployment box on hover
parent
69c450c0
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
64 additions
and
22 deletions
+64
-22
app/assets/javascripts/monitoring/deployments.js
app/assets/javascripts/monitoring/deployments.js
+45
-7
app/assets/javascripts/monitoring/prometheus_graph.js
app/assets/javascripts/monitoring/prometheus_graph.js
+19
-15
No files found.
app/assets/javascripts/monitoring/deployments.js
View file @
da2a7823
...
@@ -4,7 +4,8 @@ export default class Deployments {
...
@@ -4,7 +4,8 @@ export default class Deployments {
constructor
(
width
,
height
)
{
constructor
(
width
,
height
)
{
this
.
width
=
width
;
this
.
width
=
width
;
this
.
height
=
height
;
this
.
height
=
height
;
this
.
timeFormat
=
d3
.
time
.
format
(
'
%b %d, %Y, %H:%M%p
'
);
this
.
dateFormat
=
d3
.
time
.
format
(
'
%b %d, %Y
'
);
this
.
timeFormat
=
d3
.
time
.
format
(
'
%H:%M%p
'
);
this
.
endpoint
=
document
.
getElementById
(
'
js-metrics
'
).
dataset
.
deploymentEndpoint
;
this
.
endpoint
=
document
.
getElementById
(
'
js-metrics
'
).
dataset
.
deploymentEndpoint
;
}
}
...
@@ -29,15 +30,20 @@ export default class Deployments {
...
@@ -29,15 +30,20 @@ export default class Deployments {
this
.
data
=
[];
this
.
data
=
[];
data
.
deployments
.
forEach
((
deployment
)
=>
{
data
.
deployments
.
forEach
((
deployment
)
=>
{
const
date
=
new
Date
(
deployment
.
created_at
);
const
coeff
=
1000
*
60
;
let
time
=
new
Date
(
deployment
.
created_at
);
time
=
new
Date
(
Math
.
round
(
time
.
getTime
()
/
coeff
)
*
coeff
);
time
.
setSeconds
(
this
.
chartData
[
0
].
time
.
getSeconds
());
const
xPos
=
Math
.
floor
(
this
.
x
(
time
));
if
(
this
.
x
(
date
)
>=
0
)
{
if
(
xPos
>=
0
)
{
this
.
data
.
push
({
this
.
data
.
push
({
id
:
deployment
.
id
,
id
:
deployment
.
id
,
time
:
new
Date
(
deployment
.
created_at
)
,
time
,
sha
:
deployment
.
sha
,
sha
:
deployment
.
sha
,
tag
:
deployment
.
tag
,
tag
:
deployment
.
tag
,
ref
:
deployment
.
ref
.
name
,
ref
:
deployment
.
ref
.
name
,
xPos
,
});
});
}
}
});
});
...
@@ -66,7 +72,7 @@ export default class Deployments {
...
@@ -66,7 +72,7 @@ export default class Deployments {
.
append
(
'
g
'
)
.
append
(
'
g
'
)
.
attr
({
.
attr
({
class
:
d
=>
`deploy-info-
${
d
.
id
}
`
,
class
:
d
=>
`deploy-info-
${
d
.
id
}
`
,
transform
:
d
=>
`translate(
${
Math
.
floor
(
this
.
x
(
d
.
time
)
)
+
1
}
, 0)`
,
transform
:
d
=>
`translate(
${
Math
.
floor
(
d
.
xPos
)
+
1
}
, 0)`
,
})
})
.
append
(
'
line
'
)
.
append
(
'
line
'
)
.
attr
({
.
attr
({
...
@@ -85,7 +91,7 @@ export default class Deployments {
...
@@ -85,7 +91,7 @@ export default class Deployments {
.
attr
({
.
attr
({
x
:
3
,
x
:
3
,
y
:
0
,
y
:
0
,
height
:
41
,
height
:
58
,
});
});
const
rect
=
group
.
append
(
'
rect
'
)
const
rect
=
group
.
append
(
'
rect
'
)
...
@@ -115,14 +121,46 @@ export default class Deployments {
...
@@ -115,14 +121,46 @@ export default class Deployments {
textGroup
.
append
(
'
text
'
)
textGroup
.
append
(
'
text
'
)
.
attr
({
.
attr
({
style
:
'
dominant-baseline: text-before-edge;
font-weight: 600;
'
,
style
:
'
dominant-baseline: text-before-edge;
'
,
y
:
18
,
y
:
18
,
})
})
.
text
(()
=>
this
.
dateFormat
(
d
.
time
));
textGroup
.
append
(
'
text
'
)
.
attr
({
style
:
'
dominant-baseline: text-before-edge;
'
,
y
:
36
,
})
.
text
(()
=>
this
.
timeFormat
(
d
.
time
));
.
text
(()
=>
this
.
timeFormat
(
d
.
time
));
group
.
attr
(
'
width
'
,
Math
.
floor
(
textGroup
.
node
().
getBoundingClientRect
().
width
)
+
14
);
group
.
attr
(
'
width
'
,
Math
.
floor
(
textGroup
.
node
().
getBoundingClientRect
().
width
)
+
14
);
rect
.
attr
(
'
width
'
,
Math
.
floor
(
textGroup
.
node
().
getBoundingClientRect
().
width
)
+
10
);
rect
.
attr
(
'
width
'
,
Math
.
floor
(
textGroup
.
node
().
getBoundingClientRect
().
width
)
+
10
);
group
.
attr
(
'
class
'
,
'
js-deploy-info-box hidden
'
);
});
}
static
toggleDeployTextbox
(
deploy
,
showInfoBox
)
{
d3
.
selectAll
(
`.deploy-info-
${
deploy
.
id
}
.js-deploy-info-box`
)
.
classed
(
'
hidden
'
,
!
showInfoBox
);
}
mouseOverDeployInfo
(
mouseXPos
)
{
if
(
!
this
.
data
)
return
false
;
let
dataFound
=
false
;
this
.
data
.
forEach
((
d
)
=>
{
if
(
d
.
xPos
>=
mouseXPos
-
10
&&
d
.
xPos
<=
mouseXPos
+
10
&&
!
dataFound
)
{
dataFound
=
true
;
Deployments
.
toggleDeployTextbox
(
d
,
true
);
}
else
{
Deployments
.
toggleDeployTextbox
(
d
,
false
);
}
});
});
return
dataFound
;
}
}
}
}
app/assets/javascripts/monitoring/prometheus_graph.js
View file @
da2a7823
...
@@ -9,8 +9,8 @@ import '../flash';
...
@@ -9,8 +9,8 @@ import '../flash';
const
prometheusGraphsContainer
=
'
.prometheus-graph
'
;
const
prometheusGraphsContainer
=
'
.prometheus-graph
'
;
const
metricsEndpoint
=
'
metrics.json
'
;
const
metricsEndpoint
=
'
metrics.json
'
;
const
timeFormat
=
d3
.
time
.
format
(
'
%H:%M
'
);
const
timeFormat
=
d3
.
time
.
format
(
'
%H:%M
%p
'
);
const
dayFormat
=
d3
.
time
.
format
(
'
%b %
e, %a
'
);
const
dayFormat
=
d3
.
time
.
format
(
'
%b %
d, %Y
'
);
const
bisectDate
=
d3
.
bisector
(
d
=>
d
.
time
).
left
;
const
bisectDate
=
d3
.
bisector
(
d
=>
d
.
time
).
left
;
const
extraAddedWidthParent
=
100
;
const
extraAddedWidthParent
=
100
;
...
@@ -205,7 +205,8 @@ class PrometheusGraph {
...
@@ -205,7 +205,8 @@ class PrometheusGraph {
handleMouseOverGraph
(
x
,
y
,
valuesToPlot
,
chart
,
prometheusGraphContainer
,
key
)
{
handleMouseOverGraph
(
x
,
y
,
valuesToPlot
,
chart
,
prometheusGraphContainer
,
key
)
{
const
rectOverlay
=
document
.
querySelector
(
`
${
prometheusGraphContainer
}
.prometheus-graph-overlay`
);
const
rectOverlay
=
document
.
querySelector
(
`
${
prometheusGraphContainer
}
.prometheus-graph-overlay`
);
const
timeValueFromOverlay
=
x
.
invert
(
d3
.
mouse
(
rectOverlay
)[
0
]);
const
mouse
=
d3
.
mouse
(
rectOverlay
)[
0
];
const
timeValueFromOverlay
=
x
.
invert
(
mouse
);
const
timeValueIndex
=
bisectDate
(
valuesToPlot
,
timeValueFromOverlay
,
1
);
const
timeValueIndex
=
bisectDate
(
valuesToPlot
,
timeValueFromOverlay
,
1
);
const
d0
=
valuesToPlot
[
timeValueIndex
-
1
];
const
d0
=
valuesToPlot
[
timeValueIndex
-
1
];
const
d1
=
valuesToPlot
[
timeValueIndex
];
const
d1
=
valuesToPlot
[
timeValueIndex
];
...
@@ -215,11 +216,21 @@ class PrometheusGraph {
...
@@ -215,11 +216,21 @@ class PrometheusGraph {
);
);
const
currentTimeCoordinate
=
Math
.
floor
(
x
(
currentData
.
time
));
const
currentTimeCoordinate
=
Math
.
floor
(
x
(
currentData
.
time
));
const
graphSpecifics
=
this
.
graphSpecificProperties
[
key
];
const
graphSpecifics
=
this
.
graphSpecificProperties
[
key
];
const
shouldHideTextMetric
=
this
.
deployments
.
mouseOverDeployInfo
(
mouse
);
// Remove the current selectors
// Remove the current selectors
d3
.
selectAll
(
`
${
prometheusGraphContainer
}
.selected-metric-line`
).
remove
();
d3
.
selectAll
(
`
${
prometheusGraphContainer
}
.selected-metric-line`
).
remove
();
d3
.
selectAll
(
`
${
prometheusGraphContainer
}
.circle-metric`
).
remove
();
d3
.
selectAll
(
`
${
prometheusGraphContainer
}
.circle-metric`
).
remove
();
d3
.
selectAll
(
`
${
prometheusGraphContainer
}
.rect-text-metric:not(.deploy-info-rect)`
).
remove
();
d3
.
selectAll
(
`
${
prometheusGraphContainer
}
.rect-text-metric:not(.deploy-info-rect)`
).
remove
();
chart
.
append
(
'
circle
'
)
.
attr
(
'
class
'
,
'
circle-metric
'
)
.
attr
(
'
fill
'
,
graphSpecifics
.
line_color
)
.
attr
(
'
cx
'
,
currentTimeCoordinate
)
.
attr
(
'
cy
'
,
y
(
currentData
.
value
))
.
attr
(
'
r
'
,
this
.
commonGraphProperties
.
circle_radius_metric
);
if
(
shouldHideTextMetric
)
return
;
chart
.
append
(
'
line
'
)
chart
.
append
(
'
line
'
)
.
attr
(
'
class
'
,
'
selected-metric-line
'
)
.
attr
(
'
class
'
,
'
selected-metric-line
'
)
.
attr
({
.
attr
({
...
@@ -229,13 +240,6 @@ class PrometheusGraph {
...
@@ -229,13 +240,6 @@ class PrometheusGraph {
y2
:
maxValueMetric
,
y2
:
maxValueMetric
,
});
});
chart
.
append
(
'
circle
'
)
.
attr
(
'
class
'
,
'
circle-metric
'
)
.
attr
(
'
fill
'
,
graphSpecifics
.
line_color
)
.
attr
(
'
cx
'
,
currentTimeCoordinate
)
.
attr
(
'
cy
'
,
y
(
currentData
.
value
))
.
attr
(
'
r
'
,
this
.
commonGraphProperties
.
circle_radius_metric
);
// The little box with text
// The little box with text
const
rectTextMetric
=
chart
.
append
(
'
svg
'
)
const
rectTextMetric
=
chart
.
append
(
'
svg
'
)
.
attr
(
'
class
'
,
'
rect-text-metric
'
)
.
attr
(
'
class
'
,
'
rect-text-metric
'
)
...
@@ -244,20 +248,20 @@ class PrometheusGraph {
...
@@ -244,20 +248,20 @@ class PrometheusGraph {
rectTextMetric
.
append
(
'
rect
'
)
rectTextMetric
.
append
(
'
rect
'
)
.
attr
(
'
class
'
,
'
rect-metric
'
)
.
attr
(
'
class
'
,
'
rect-metric
'
)
.
attr
(
'
x
'
,
10
)
.
attr
(
'
x
'
,
4
)
.
attr
(
'
y
'
,
0
)
.
attr
(
'
y
'
,
1
)
.
attr
(
'
rx
'
,
2
)
.
attr
(
'
width
'
,
this
.
commonGraphProperties
.
rect_text_width
)
.
attr
(
'
width
'
,
this
.
commonGraphProperties
.
rect_text_width
)
.
attr
(
'
height
'
,
this
.
commonGraphProperties
.
rect_text_height
);
.
attr
(
'
height
'
,
this
.
commonGraphProperties
.
rect_text_height
);
rectTextMetric
.
append
(
'
text
'
)
rectTextMetric
.
append
(
'
text
'
)
.
attr
(
'
class
'
,
'
text-metric
'
)
.
attr
(
'
x
'
,
8
)
.
attr
(
'
x
'
,
35
)
.
attr
(
'
y
'
,
35
)
.
attr
(
'
y
'
,
35
)
.
text
(
timeFormat
(
currentData
.
time
));
.
text
(
timeFormat
(
currentData
.
time
));
rectTextMetric
.
append
(
'
text
'
)
rectTextMetric
.
append
(
'
text
'
)
.
attr
(
'
class
'
,
'
text-metric-date
'
)
.
attr
(
'
class
'
,
'
text-metric-date
'
)
.
attr
(
'
x
'
,
15
)
.
attr
(
'
x
'
,
8
)
.
attr
(
'
y
'
,
15
)
.
attr
(
'
y
'
,
15
)
.
text
(
dayFormat
(
currentData
.
time
));
.
text
(
dayFormat
(
currentData
.
time
));
...
...
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