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
1
Merge Requests
1
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
nexedi
gitlab-ce
Commits
1525b005
Commit
1525b005
authored
Jan 05, 2018
by
Filipa Lacerda
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[ci skip] Fix more eslint rules
parent
cdc49388
Changes
10
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
415 additions
and
272 deletions
+415
-272
app/assets/javascripts/clusters/components/application_row.vue
...ssets/javascripts/clusters/components/application_row.vue
+107
-102
app/assets/javascripts/clusters/components/applications.vue
app/assets/javascripts/clusters/components/applications.vue
+98
-94
app/assets/javascripts/commit/pipelines/pipelines_table.vue
app/assets/javascripts/commit/pipelines/pipelines_table.vue
+10
-8
app/assets/javascripts/cycle_analytics/components/banner.vue
app/assets/javascripts/cycle_analytics/components/banner.vue
+10
-5
app/assets/javascripts/cycle_analytics/components/limit_warning_component.vue
...ts/cycle_analytics/components/limit_warning_component.vue
+15
-6
app/assets/javascripts/cycle_analytics/components/stage_code_component.vue
...ripts/cycle_analytics/components/stage_code_component.vue
+32
-10
app/assets/javascripts/cycle_analytics/components/stage_component.vue
...avascripts/cycle_analytics/components/stage_component.vue
+29
-10
app/assets/javascripts/cycle_analytics/components/stage_plan_component.vue
...ripts/cycle_analytics/components/stage_plan_component.vue
+26
-9
app/assets/javascripts/cycle_analytics/components/stage_review_component.vue
...pts/cycle_analytics/components/stage_review_component.vue
+40
-14
app/assets/javascripts/cycle_analytics/components/stage_staging_component.vue
...ts/cycle_analytics/components/stage_staging_component.vue
+48
-14
No files found.
app/assets/javascripts/clusters/components/application_row.vue
View file @
1525b005
<
script
>
<
script
>
import
{
s__
,
sprintf
}
from
'
../../locale
'
;
import
{
s__
,
sprintf
}
from
'
../../locale
'
;
import
eventHub
from
'
../event_hub
'
;
import
eventHub
from
'
../event_hub
'
;
import
loadingButton
from
'
../../vue_shared/components/loading_button.vue
'
;
import
loadingButton
from
'
../../vue_shared/components/loading_button.vue
'
;
import
{
import
{
APPLICATION_NOT_INSTALLABLE
,
APPLICATION_NOT_INSTALLABLE
,
APPLICATION_SCHEDULED
,
APPLICATION_SCHEDULED
,
APPLICATION_INSTALLABLE
,
APPLICATION_INSTALLABLE
,
APPLICATION_INSTALLING
,
APPLICATION_INSTALLING
,
APPLICATION_INSTALLED
,
APPLICATION_INSTALLED
,
APPLICATION_ERROR
,
APPLICATION_ERROR
,
REQUEST_LOADING
,
REQUEST_LOADING
,
REQUEST_SUCCESS
,
REQUEST_SUCCESS
,
REQUEST_FAILURE
,
REQUEST_FAILURE
,
}
from
'
../constants
'
;
}
from
'
../constants
'
;
export
default
{
export
default
{
props
:
{
components
:
{
id
:
{
loadingButton
,
type
:
String
,
required
:
true
,
},
},
title
:
{
props
:
{
type
:
String
,
id
:
{
required
:
true
,
type
:
String
,
required
:
true
,
},
title
:
{
type
:
String
,
required
:
true
,
},
titleLink
:
{
type
:
String
,
required
:
false
,
default
:
''
,
},
description
:
{
type
:
String
,
required
:
true
,
},
status
:
{
type
:
String
,
required
:
false
,
default
:
''
,
},
statusReason
:
{
type
:
String
,
required
:
false
,
default
:
''
,
},
requestStatus
:
{
type
:
String
,
required
:
false
,
default
:
''
,
},
requestReason
:
{
type
:
String
,
required
:
false
,
default
:
''
,
},
},
},
titleLink
:
{
computed
:
{
type
:
String
,
rowJsClass
()
{
required
:
false
,
return
`js-cluster-application-row-
${
this
.
id
}
`
;
},
},
description
:
{
installButtonLoading
()
{
type
:
String
,
return
this
.
status
!==
''
||
required
:
true
,
this
.
status
===
APPLICATION_SCHEDULED
||
},
this
.
status
===
APPLICATION_INSTALLING
||
status
:
{
this
.
requestStatus
===
REQUEST_LOADING
;
type
:
String
,
},
required
:
false
,
installButtonDisabled
()
{
},
// Avoid the potential for the real-time data to say APPLICATION_INSTALLABLE but
statusReason
:
{
// we already made a request to install and are just waiting for the real-time
type
:
String
,
// to sync up.
required
:
false
,
return
(
this
.
status
!==
APPLICATION_INSTALLABLE
&&
this
.
status
!==
APPLICATION_ERROR
)
||
},
this
.
requestStatus
===
REQUEST_LOADING
||
requestStatus
:
{
this
.
requestStatus
===
REQUEST_SUCCESS
;
type
:
String
,
},
required
:
false
,
installButtonLabel
()
{
},
let
label
;
requestReason
:
{
if
(
type
:
String
,
this
.
status
===
APPLICATION_NOT_INSTALLABLE
||
required
:
false
,
this
.
status
===
APPLICATION_INSTALLABLE
||
},
this
.
status
===
APPLICATION_ERROR
},
)
{
components
:
{
label
=
s__
(
'
ClusterIntegration|Install
'
);
loadingButton
,
}
else
if
(
this
.
status
===
APPLICATION_SCHEDULED
||
this
.
status
===
APPLICATION_INSTALLING
)
{
},
label
=
s__
(
'
ClusterIntegration|Installing
'
);
computed
:
{
}
else
if
(
this
.
status
===
APPLICATION_INSTALLED
)
{
rowJsClass
()
{
label
=
s__
(
'
ClusterIntegration|Installed
'
);
return
`js-cluster-application-row-
${
this
.
id
}
`
;
}
},
installButtonLoading
()
{
return
!
this
.
status
||
this
.
status
===
APPLICATION_SCHEDULED
||
this
.
status
===
APPLICATION_INSTALLING
||
this
.
requestStatus
===
REQUEST_LOADING
;
},
installButtonDisabled
()
{
// Avoid the potential for the real-time data to say APPLICATION_INSTALLABLE but
// we already made a request to install and are just waiting for the real-time
// to sync up.
return
(
this
.
status
!==
APPLICATION_INSTALLABLE
&&
this
.
status
!==
APPLICATION_ERROR
)
||
this
.
requestStatus
===
REQUEST_LOADING
||
this
.
requestStatus
===
REQUEST_SUCCESS
;
},
installButtonLabel
()
{
let
label
;
if
(
this
.
status
===
APPLICATION_NOT_INSTALLABLE
||
this
.
status
===
APPLICATION_INSTALLABLE
||
this
.
status
===
APPLICATION_ERROR
)
{
label
=
s__
(
'
ClusterIntegration|Install
'
);
}
else
if
(
this
.
status
===
APPLICATION_SCHEDULED
||
this
.
status
===
APPLICATION_INSTALLING
)
{
label
=
s__
(
'
ClusterIntegration|Installing
'
);
}
else
if
(
this
.
status
===
APPLICATION_INSTALLED
)
{
label
=
s__
(
'
ClusterIntegration|Installed
'
);
}
return
label
;
return
label
;
},
},
hasError
()
{
hasError
()
{
return
this
.
status
===
APPLICATION_ERROR
||
this
.
requestStatus
===
REQUEST_FAILURE
;
return
this
.
status
===
APPLICATION_ERROR
||
this
.
requestStatus
===
REQUEST_FAILURE
;
},
},
generalErrorDescription
()
{
generalErrorDescription
()
{
return
sprintf
(
return
sprintf
(
s__
(
'
ClusterIntegration|Something went wrong while installing %{title}
'
),
{
s__
(
'
ClusterIntegration|Something went wrong while installing %{title}
'
),
{
title
:
this
.
title
,
title
:
this
.
title
,
},
},
);
);
},
},
},
},
methods
:
{
methods
:
{
installClicked
()
{
installClicked
()
{
eventHub
.
$emit
(
'
installApplication
'
,
this
.
id
);
eventHub
.
$emit
(
'
installApplication
'
,
this
.
id
);
},
},
},
},
};
};
</
script
>
</
script
>
<
template
>
<
template
>
...
@@ -115,7 +120,7 @@ export default {
...
@@ -115,7 +120,7 @@ export default {
role=
"row"
role=
"row"
>
>
<a
<a
v-if=
"titleLink"
v-if=
"titleLink
!== ''
"
:href=
"titleLink"
:href=
"titleLink"
target=
"blank"
target=
"blank"
rel=
"noopener noreferrer"
rel=
"noopener noreferrer"
...
@@ -164,15 +169,15 @@ export default {
...
@@ -164,15 +169,15 @@ export default {
<p
class=
"js-cluster-application-general-error-message"
>
<p
class=
"js-cluster-application-general-error-message"
>
{{
generalErrorDescription
}}
{{
generalErrorDescription
}}
</p>
</p>
<ul
v-if=
"statusReason
|| requestReason
"
>
<ul
v-if=
"statusReason
!== '' || requestReason !== ''
"
>
<li
<li
v-if=
"statusReason"
v-if=
"statusReason
!== ''
"
class=
"js-cluster-application-status-error-message"
class=
"js-cluster-application-status-error-message"
>
>
{{
statusReason
}}
{{
statusReason
}}
</li>
</li>
<li
<li
v-if=
"requestReason"
v-if=
"requestReason
!== ''
"
class=
"js-cluster-application-request-error-message"
class=
"js-cluster-application-request-error-message"
>
>
{{
requestReason
}}
{{
requestReason
}}
...
...
app/assets/javascripts/clusters/components/applications.vue
View file @
1525b005
<
script
>
<
script
>
import
_
from
'
underscore
'
;
import
_
from
'
underscore
'
;
import
{
s__
,
sprintf
}
from
'
../../locale
'
;
import
{
s__
,
sprintf
}
from
'
../../locale
'
;
import
applicationRow
from
'
./application_row.vue
'
;
import
applicationRow
from
'
./application_row.vue
'
;
export
default
{
export
default
{
props
:
{
components
:
{
applications
:
{
applicationRow
,
type
:
Object
,
required
:
false
,
default
:
()
=>
({}),
},
},
helpPath
:
{
props
:
{
type
:
String
,
applications
:
{
required
:
false
,
type
:
Object
,
required
:
false
,
default
:
()
=>
({}),
},
helpPath
:
{
type
:
String
,
required
:
false
,
default
:
''
,
},
},
},
},
computed
:
{
components
:
{
generalApplicationDescription
()
{
applicationRow
,
return
sprintf
(
},
_
.
escape
(
s__
(
`ClusterIntegration|Install applications on your cluster.
computed
:
{
Read more about %{helpLink}`
)),
generalApplicationDescription
()
{
{
return
sprintf
(
helpLink
:
`<a href="
${
this
.
helpPath
}
">
_
.
escape
(
s__
(
`ClusterIntegration|Install applications on your cluster.
${
_
.
escape
(
s__
(
'
ClusterIntegration|installing applications
'
))}
Read more about %{helpLink}`
)),
</a>`
,
{
},
helpLink
:
`<a href="
${
this
.
helpPath
}
">
false
,
${
_
.
escape
(
s__
(
'
ClusterIntegration|installing applications
'
))}
);
</a>`
,
},
},
helmTillerDescription
()
{
false
,
return
_
.
escape
(
s__
(
);
`ClusterIntegration|Helm streamlines installing and managing Kubernets applications.
},
Tiller runs inside of your Kubernetes Cluster, and manages
helmTillerDescription
()
{
releases of your charts.`
,
return
_
.
escape
(
s__
(
));
`ClusterIntegration|Helm streamlines installing and managing Kubernets applications.
},
Tiller runs inside of your Kubernetes Cluster, and manages
ingressDescription
()
{
releases of your charts.`
,
const
descriptionParagraph
=
_
.
escape
(
s__
(
));
`ClusterIntegration|Ingress gives you a way to route requests to services based on the
},
request host or path, centralizing a number of services into a single entrypoint.`
,
ingressDescription
()
{
));
const
descriptionParagraph
=
_
.
escape
(
s__
(
`ClusterIntegration|Ingress gives you a way to route requests to services based on the
request host or path, centralizing a number of services into a single entrypoint.`
,
));
const
extraCostParagraph
=
sprintf
(
const
extraCostParagraph
=
sprintf
(
_
.
escape
(
s__
(
`ClusterIntegration|%{boldNotice} This will add some
_
.
escape
(
s__
(
`ClusterIntegration|%{boldNotice} This will add some
extra resources like a load balancer,
extra resources like a load balancer,
which incur additional costs. See %{pricingLink}`
)),
which incur additional costs. See %{pricingLink}`
)),
{
{
...
@@ -54,39 +55,39 @@ which incur additional costs. See %{pricingLink}`)),
...
@@ -54,39 +55,39 @@ which incur additional costs. See %{pricingLink}`)),
${
_
.
escape
(
s__
(
'
ClusterIntegration|GKE pricing
'
))}
${
_
.
escape
(
s__
(
'
ClusterIntegration|GKE pricing
'
))}
</a>`
,
</a>`
,
},
},
false
,
false
,
);
);
return
`
return
`
<p>
<p>
${
descriptionParagraph
}
${
descriptionParagraph
}
</p>
</p>
<p class="append-bottom-0">
<p class="append-bottom-0">
${
extraCostParagraph
}
${
extraCostParagraph
}
</p>
</p>
`
;
`
;
},
},
gitlabRunnerDescription
()
{
gitlabRunnerDescription
()
{
return
_
.
escape
(
s__
(
return
_
.
escape
(
s__
(
`ClusterIntegration|GitLab Runner is the open source project that is used to run your jobs
`ClusterIntegration|GitLab Runner is the open source project that is used to run your jobs
and send the results back to GitLab.`
,
and send the results back to GitLab.`
,
));
));
},
prometheusDescription
()
{
return
sprintf
(
_
.
escape
(
s__
(
`ClusterIntegration|Prometheus is an open-source monitoring system
with %{gitlabIntegrationLink} to monitor deployed applications.`
)),
{
gitlabIntegrationLink
:
`<a href="https://docs.gitlab.com/ce/user/project/integrations/prometheus.html"
target="_blank" rel="noopener noreferrer">
${
_
.
escape
(
s__
(
'
ClusterIntegration|Gitlab Integration
'
))}
</a>`
,
},
false
,
);
},
},
},
prometheusDescription
()
{
};
return
sprintf
(
_
.
escape
(
s__
(
`ClusterIntegration|Prometheus is an open-source monitoring system
with %{gitlabIntegrationLink} to monitor deployed applications.`
)),
{
gitlabIntegrationLink
:
`<a href="https://docs.gitlab.com/ce/user/project/integrations/prometheus.html"
target="_blank" rel="noopener noreferrer">
${
_
.
escape
(
s__
(
'
ClusterIntegration|Gitlab Integration
'
))}
</a>`
,
},
false
,
);
},
},
};
</
script
>
</
script
>
<
template
>
<
template
>
...
@@ -115,26 +116,29 @@ target="_blank" rel="noopener noreferrer">
...
@@ -115,26 +116,29 @@ target="_blank" rel="noopener noreferrer">
:request-reason=
"applications.helm.requestReason"
:request-reason=
"applications.helm.requestReason"
/>
/>
<application-row
<application-row
id=
"ingress"
id=
"ingress"
:title=
"applications.ingress.title"
:title=
"applications.ingress.title"
title-link=
"https://kubernetes.io/docs/concepts/services-networking/ingress/"
title-link=
"https://kubernetes.io/docs/concepts/services-networking/ingress/"
:description=
"ingressDescription"
:description=
"ingressDescription"
:status=
"applications.ingress.status"
:status=
"applications.ingress.status"
:status-reason=
"applications.ingress.statusReason"
:status-reason=
"applications.ingress.statusReason"
:request-status=
"applications.ingress.requestStatus"
:request-status=
"applications.ingress.requestStatus"
:request-reason=
"applications.ingress.requestReason"
:request-reason=
"applications.ingress.requestReason"
/>
/>
<application-row
<application-row
id=
"prometheus"
id=
"prometheus"
:title=
"applications.prometheus.title"
:title=
"applications.prometheus.title"
title-link=
"https://prometheus.io/docs/introduction/overview/"
title-link=
"https://prometheus.io/docs/introduction/overview/"
:description=
"prometheusDescription"
:description=
"prometheusDescription"
:status=
"applications.prometheus.status"
:status=
"applications.prometheus.status"
:status-reason=
"applications.prometheus.statusReason"
:status-reason=
"applications.prometheus.statusReason"
:request-status=
"applications.prometheus.requestStatus"
:request-status=
"applications.prometheus.requestStatus"
:request-reason=
"applications.prometheus.requestReason"
:request-reason=
"applications.prometheus.requestReason"
/>
/>
<!-- NOTE: Don't forget to update `clusters.scss` min-height for this block and uncomment `application_spec` tests -->
<!--
NOTE: Don't forget to update `clusters.scss`
min-height for this block and uncomment `application_spec` tests
-->
<!-- Add GitLab Runner row, all other plumbing is complete -->
<!-- Add GitLab Runner row, all other plumbing is complete -->
</div>
</div>
</div>
</div>
...
...
app/assets/javascripts/commit/pipelines/pipelines_table.vue
View file @
1525b005
...
@@ -4,6 +4,10 @@
...
@@ -4,6 +4,10 @@
import
pipelinesMixin
from
'
../../pipelines/mixins/pipelines
'
;
import
pipelinesMixin
from
'
../../pipelines/mixins/pipelines
'
;
export
default
{
export
default
{
mixins
:
[
pipelinesMixin
,
],
props
:
{
props
:
{
endpoint
:
{
endpoint
:
{
type
:
String
,
type
:
String
,
...
@@ -31,9 +35,6 @@
...
@@ -31,9 +35,6 @@
default
:
'
child
'
,
default
:
'
child
'
,
},
},
},
},
mixins
:
[
pipelinesMixin
,
],
data
()
{
data
()
{
const
store
=
new
PipelineStore
();
const
store
=
new
PipelineStore
();
...
@@ -95,28 +96,29 @@
...
@@ -95,28 +96,29 @@
label=
"Loading pipelines"
label=
"Loading pipelines"
size=
"3"
size=
"3"
v-if=
"isLoading"
v-if=
"isLoading"
/>
/>
<empty-state
<empty-state
v-if=
"shouldRenderEmptyState"
v-if=
"shouldRenderEmptyState"
:help-page-path=
"helpPagePath"
:help-page-path=
"helpPagePath"
:empty-state-svg-path=
"emptyStateSvgPath"
:empty-state-svg-path=
"emptyStateSvgPath"
/>
/>
<error-state
<error-state
v-if=
"shouldRenderErrorState"
v-if=
"shouldRenderErrorState"
:error-state-svg-path=
"errorStateSvgPath"
:error-state-svg-path=
"errorStateSvgPath"
/>
/>
<div
<div
class=
"table-holder"
class=
"table-holder"
v-if=
"shouldRenderTable"
>
v-if=
"shouldRenderTable"
>
<pipelines-table-component
<pipelines-table-component
:pipelines=
"state.pipelines"
:pipelines=
"state.pipelines"
:update-graph-dropdown=
"updateGraphDropdown"
:update-graph-dropdown=
"updateGraphDropdown"
:auto-devops-help-path=
"autoDevopsHelpPath"
:auto-devops-help-path=
"autoDevopsHelpPath"
:view-type=
"viewType"
:view-type=
"viewType"
/>
/>
</div>
</div>
</div>
</div>
</
template
>
</
template
>
app/assets/javascripts/cycle_analytics/components/banner.vue
View file @
1525b005
...
@@ -26,17 +26,21 @@
...
@@ -26,17 +26,21 @@
class=
"js-ca-dismiss-button dismiss-button"
class=
"js-ca-dismiss-button dismiss-button"
type=
"button"
type=
"button"
:aria-label=
"__('Dismiss Cycle Analytics introduction box')"
:aria-label=
"__('Dismiss Cycle Analytics introduction box')"
@
click=
"dismissOverviewDialog"
>
@
click=
"dismissOverviewDialog"
>
<i
<i
class=
"fa fa-times"
class=
"fa fa-times"
aria-hidden=
"true"
>
aria-hidden=
"true"
>
</i>
</i>
</button>
</button>
<div
class=
"svg-container"
v-html=
"iconCycleAnalyticsSplash"
>
<div
class=
"svg-container"
v-html=
"iconCycleAnalyticsSplash"
>
</div>
</div>
<div
class=
"inner-content"
>
<div
class=
"inner-content"
>
<h4>
<h4>
{{
__
(
'
Introducing Cycle Analytics
'
)
}}
{{
__
(
'
Introducing Cycle Analytics
'
)
}}
</h4>
</h4>
<p>
<p>
{{
__
(
'
Cycle Analytics gives an overview of how much time it takes to go from idea to production in your project.
'
)
}}
{{
__
(
'
Cycle Analytics gives an overview of how much time it takes to go from idea to production in your project.
'
)
}}
...
@@ -46,8 +50,9 @@
...
@@ -46,8 +50,9 @@
:href=
"documentationLink"
:href=
"documentationLink"
target=
"_blank"
target=
"_blank"
rel=
"nofollow"
rel=
"nofollow"
class=
"btn"
>
class=
"btn"
{{
__
(
'
Read more
'
)
}}
>
{{
__
(
'
Read more
'
)
}}
</a>
</a>
</p>
</p>
</div>
</div>
...
...
app/assets/javascripts/cycle_analytics/components/limit_warning_component.vue
View file @
1525b005
...
@@ -2,25 +2,34 @@
...
@@ -2,25 +2,34 @@
import
tooltip
from
'
../../vue_shared/directives/tooltip
'
;
import
tooltip
from
'
../../vue_shared/directives/tooltip
'
;
export
default
{
export
default
{
directives
:
{
tooltip
,
},
props
:
{
props
:
{
count
:
{
count
:
{
type
:
Number
,
type
:
Number
,
required
:
true
,
required
:
true
,
},
},
},
},
directives
:
{
tooltip
,
},
};
};
</
script
>
</
script
>
<
template
>
<
template
>
<span
v-if=
"count === 50"
class=
"events-info pull-right"
>
<span
v-if=
"count === 50"
class=
"events-info pull-right"
>
<i
<i
class=
"fa fa-warning"
class=
"fa fa-warning"
v-tooltip
v-tooltip
aria-hidden=
"true"
aria-hidden=
"true"
:title=
"n__('Limited to showing %d event at most', 'Limited to showing %d events at most', 50)"
:title=
"n__(
data-placement=
"top"
></i>
'Limited to showing %d event at most',
'Limited to showing %d events at most',
50
)"
data-placement=
"top"
>
</i>
{{
n__
(
'
Showing %d event
'
,
'
Showing %d events
'
,
50
)
}}
{{
n__
(
'
Showing %d event
'
,
'
Showing %d events
'
,
50
)
}}
</span>
</span>
</
template
>
</
template
>
app/assets/javascripts/cycle_analytics/components/stage_code_component.vue
View file @
1525b005
...
@@ -4,15 +4,21 @@
...
@@ -4,15 +4,21 @@
import
totalTime
from
'
./total_time_component.vue
'
;
import
totalTime
from
'
./total_time_component.vue
'
;
export
default
{
export
default
{
props
:
{
items
:
Array
,
stage
:
Object
,
},
components
:
{
components
:
{
userAvatarImage
,
userAvatarImage
,
limitWarning
,
limitWarning
,
totalTime
,
totalTime
,
},
},
props
:
{
items
:
{
type
:
Array
,
default
:
[]
},
stage
:
{
type
:
Object
,
default
:
()
=>
({}),
},
},
};
};
</
script
>
</
script
>
<
template
>
<
template
>
...
@@ -22,28 +28,44 @@
...
@@ -22,28 +28,44 @@
<limit-warning
:count=
"items.length"
/>
<limit-warning
:count=
"items.length"
/>
</div>
</div>
<ul
class=
"stage-event-list"
>
<ul
class=
"stage-event-list"
>
<li
v-for=
"mergeRequest in items"
class=
"stage-event-item"
>
<li
v-for=
"(mergeRequest, i) in items"
:key=
"i"
class=
"stage-event-item"
>
<div
class=
"item-details"
>
<div
class=
"item-details"
>
<!-- FIXME: Pass an alt attribute here for accessibility -->
<!-- FIXME: Pass an alt attribute here for accessibility -->
<user-avatar-image
:img-src=
"mergeRequest.author.avatarUrl"
/>
<user-avatar-image
:img-src=
"mergeRequest.author.avatarUrl"
/>
<h5
class=
"item-title merge-merquest-title"
>
<h5
class=
"item-title merge-merquest-title"
>
<a
:href=
"mergeRequest.url"
>
<a
:href=
"mergeRequest.url"
>
{{
mergeRequest
.
title
}}
{{
mergeRequest
.
title
}}
</a>
</a>
</h5>
</h5>
<a
:href=
"mergeRequest.url"
class=
"issue-link"
>
!
{{
mergeRequest
.
iid
}}
</a>
<a
:href=
"mergeRequest.url"
class=
"issue-link"
>
!
{{
mergeRequest
.
iid
}}
</a>
·
·
<span>
<span>
{{
s__
(
'
OpenedNDaysAgo|Opened
'
)
}}
{{
s__
(
'
OpenedNDaysAgo|Opened
'
)
}}
<a
:href=
"mergeRequest.url"
class=
"issue-date"
>
{{
mergeRequest
.
createdAt
}}
</a>
<a
:href=
"mergeRequest.url"
class=
"issue-date"
>
{{
mergeRequest
.
createdAt
}}
</a>
</span>
</span>
<span>
<span>
{{
s__
(
'
ByAuthor|by
'
)
}}
{{
s__
(
'
ByAuthor|by
'
)
}}
<a
:href=
"mergeRequest.author.webUrl"
class=
"issue-author-link"
>
{{
mergeRequest
.
author
.
name
}}
</a>
<a
:href=
"mergeRequest.author.webUrl"
class=
"issue-author-link"
>
{{
mergeRequest
.
author
.
name
}}
</a>
</span>
</span>
</div>
</div>
<div
class=
"item-time"
>
<div
class=
"item-time"
>
<total-time
:time=
"mergeRequest.totalTime"
></total-time
>
<total-time
:time=
"mergeRequest.totalTime"
/
>
</div>
</div>
</li>
</li>
</ul>
</ul>
...
...
app/assets/javascripts/cycle_analytics/components/stage_component.vue
View file @
1525b005
...
@@ -4,15 +4,21 @@
...
@@ -4,15 +4,21 @@
import
totalTime
from
'
./total_time_component.vue
'
;
import
totalTime
from
'
./total_time_component.vue
'
;
export
default
{
export
default
{
props
:
{
items
:
Array
,
stage
:
Object
,
},
components
:
{
components
:
{
userAvatarImage
,
userAvatarImage
,
limitWarning
,
limitWarning
,
totalTime
,
totalTime
,
},
},
props
:
{
items
:
{
type
:
Array
,
default
:
[]
},
stage
:
{
type
:
Object
,
default
:
()
=>
({}),
},
},
};
};
</
script
>
</
script
>
<
template
>
<
template
>
...
@@ -25,30 +31,43 @@
...
@@ -25,30 +31,43 @@
<li
<li
v-for=
"(issue, i) in items"
v-for=
"(issue, i) in items"
:key=
"i"
:key=
"i"
class=
"stage-event-item"
>
class=
"stage-event-item"
>
<div
class=
"item-details"
>
<div
class=
"item-details"
>
<!-- FIXME: Pass an alt attribute here for accessibility -->
<!-- FIXME: Pass an alt attribute here for accessibility -->
<user-avatar-image
:img-src=
"issue.author.avatarUrl"
/>
<user-avatar-image
:img-src=
"issue.author.avatarUrl"
/>
<h5
class=
"item-title issue-title"
>
<h5
class=
"item-title issue-title"
>
<a
class=
"issue-title"
:href=
"issue.url"
>
<a
class=
"issue-title"
:href=
"issue.url"
>
{{
issue
.
title
}}
{{
issue
.
title
}}
</a>
</a>
</h5>
</h5>
<a
:href=
"issue.url"
class=
"issue-link"
>
#
{{
issue
.
iid
}}
</a>
<a
:href=
"issue.url"
class=
"issue-link"
>
#
{{
issue
.
iid
}}
</a>
·
·
<span>
<span>
{{
s__
(
'
OpenedNDaysAgo|Opened
'
)
}}
{{
s__
(
'
OpenedNDaysAgo|Opened
'
)
}}
<a
:href=
"issue.url"
class=
"issue-date"
>
{{
issue
.
createdAt
}}
</a>
<a
:href=
"issue.url"
class=
"issue-date"
>
{{
issue
.
createdAt
}}
</a>
</span>
</span>
<span>
<span>
{{
s__
(
'
ByAuthor|by
'
)
}}
{{
s__
(
'
ByAuthor|by
'
)
}}
<a
:href=
"issue.author.webUrl"
class=
"issue-author-link"
>
<a
:href=
"issue.author.webUrl"
class=
"issue-author-link"
>
{{
issue
.
author
.
name
}}
{{
issue
.
author
.
name
}}
</a>
</a>
</span>
</span>
</div>
</div>
<div
class=
"item-time"
>
<div
class=
"item-time"
>
<total-time
:time=
"issue.totalTime"
/>
<total-time
:time=
"issue.totalTime"
/>
</div>
</div>
</li>
</li>
</ul>
</ul>
...
...
app/assets/javascripts/cycle_analytics/components/stage_plan_component.vue
View file @
1525b005
...
@@ -5,15 +5,21 @@
...
@@ -5,15 +5,21 @@
import
totalTime
from
'
./total_time_component.vue
'
;
import
totalTime
from
'
./total_time_component.vue
'
;
export
default
{
export
default
{
props
:
{
items
:
Array
,
stage
:
Object
,
},
components
:
{
components
:
{
userAvatarImage
,
userAvatarImage
,
totalTime
,
totalTime
,
limitWarning
,
limitWarning
,
},
},
props
:
{
items
:
{
type
:
Array
,
default
:
[]
},
stage
:
{
type
:
Object
,
default
:
()
=>
({}),
},
},
computed
:
{
computed
:
{
iconCommit
()
{
iconCommit
()
{
return
iconCommit
;
return
iconCommit
;
...
@@ -31,10 +37,11 @@
...
@@ -31,10 +37,11 @@
<li
<li
v-for=
"(commit, i) in items"
v-for=
"(commit, i) in items"
:key=
"i"
:key=
"i"
class=
"stage-event-item"
>
class=
"stage-event-item"
>
<div
class=
"item-details item-conmmit-component"
>
<div
class=
"item-details item-conmmit-component"
>
<!-- FIXME: Pass an alt attribute here for accessibility -->
<!-- FIXME: Pass an alt attribute here for accessibility -->
<user-avatar-image
:img-src=
"commit.author.avatarUrl"
/>
<user-avatar-image
:img-src=
"commit.author.avatarUrl"
/>
<h5
class=
"item-title commit-title"
>
<h5
class=
"item-title commit-title"
>
<a
:href=
"commit.commitUrl"
>
<a
:href=
"commit.commitUrl"
>
{{
commit
.
title
}}
{{
commit
.
title
}}
...
@@ -42,10 +49,20 @@
...
@@ -42,10 +49,20 @@
</h5>
</h5>
<span>
<span>
{{
s__
(
'
FirstPushedBy|First
'
)
}}
{{
s__
(
'
FirstPushedBy|First
'
)
}}
<span
class=
"commit-icon"
v-html=
"iconCommit"
></span>
<span
<a
:href=
"commit.commitUrl"
class=
"commit-hash-link commit-sha"
>
{{
commit
.
shortSha
}}
</a>
class=
"commit-icon"
v-html=
"iconCommit"
>
</span>
<a
:href=
"commit.commitUrl"
class=
"commit-hash-link commit-sha"
>
{{
commit
.
shortSha
}}
</a>
{{
s__
(
'
FirstPushedBy|pushed by
'
)
}}
{{
s__
(
'
FirstPushedBy|pushed by
'
)
}}
<a
:href=
"commit.author.webUrl"
class=
"commit-author-link"
>
<a
:href=
"commit.author.webUrl"
class=
"commit-author-link"
>
{{
commit
.
author
.
name
}}
{{
commit
.
author
.
name
}}
</a>
</a>
</span>
</span>
...
...
app/assets/javascripts/cycle_analytics/components/stage_review_component.vue
View file @
1525b005
...
@@ -5,16 +5,22 @@
...
@@ -5,16 +5,22 @@
import
icon
from
'
../../vue_shared/components/icon.vue
'
;
import
icon
from
'
../../vue_shared/components/icon.vue
'
;
export
default
{
export
default
{
props
:
{
items
:
Array
,
stage
:
Object
,
},
components
:
{
components
:
{
userAvatarImage
,
userAvatarImage
,
totalTime
,
totalTime
,
limitWarning
,
limitWarning
,
icon
,
icon
,
},
},
props
:
{
items
:
{
type
:
Array
,
default
:
[]
},
stage
:
{
type
:
Object
,
default
:
()
=>
({}),
},
},
};
};
</
script
>
</
script
>
<
template
>
<
template
>
...
@@ -27,7 +33,8 @@
...
@@ -27,7 +33,8 @@
<li
<li
v-for=
"(mergeRequest, i) in items"
v-for=
"(mergeRequest, i) in items"
:key=
"i"
:key=
"i"
class=
"stage-event-item"
>
class=
"stage-event-item"
>
<div
class=
"item-details"
>
<div
class=
"item-details"
>
<!-- FIXME: Pass an alt attribute here for accessibility -->
<!-- FIXME: Pass an alt attribute here for accessibility -->
<user-avatar-image
:img-src=
"mergeRequest.author.avatarUrl"
/>
<user-avatar-image
:img-src=
"mergeRequest.author.avatarUrl"
/>
...
@@ -36,34 +43,53 @@
...
@@ -36,34 +43,53 @@
{{
mergeRequest
.
title
}}
{{
mergeRequest
.
title
}}
</a>
</a>
</h5>
</h5>
<a
:href=
"mergeRequest.url"
class=
"issue-link"
>
!
{{
mergeRequest
.
iid
}}
</a>
<a
:href=
"mergeRequest.url"
class=
"issue-link"
>
!
{{
mergeRequest
.
iid
}}
</a>
·
·
<span>
<span>
{{
s__
(
'
OpenedNDaysAgo|Opened
'
)
}}
{{
s__
(
'
OpenedNDaysAgo|Opened
'
)
}}
<a
:href=
"mergeRequest.url"
class=
"issue-date"
>
{{
mergeRequest
.
createdAt
}}
</a>
<a
:href=
"mergeRequest.url"
class=
"issue-date"
>
{{
mergeRequest
.
createdAt
}}
</a>
</span>
</span>
<span>
<span>
{{
s__
(
'
ByAuthor|by
'
)
}}
{{
s__
(
'
ByAuthor|by
'
)
}}
<a
:href=
"mergeRequest.author.webUrl"
class=
"issue-author-link"
>
{{
mergeRequest
.
author
.
name
}}
</a>
<a
:href=
"mergeRequest.author.webUrl"
class=
"issue-author-link"
>
{{
mergeRequest
.
author
.
name
}}
</a>
</span>
</span>
<template
v-if=
"mergeRequest.state === 'closed'"
>
<template
v-if=
"mergeRequest.state === 'closed'"
>
<span
class=
"merge-request-state"
>
<span
class=
"merge-request-state"
>
<i
class=
"fa fa-ban"
></i>
<i
class=
"fa fa-ban"
aria-hidden=
"true"
>
</i>
{{
mergeRequest
.
state
.
toUpperCase
()
}}
{{
mergeRequest
.
state
.
toUpperCase
()
}}
</span>
</span>
</
template
>
</
template
>
<
template
v-else
>
<
template
v-else
>
<span
class=
"merge-request-branch"
v-if=
"mergeRequest.branch"
>
<span
class=
"merge-request-branch"
v-if=
"mergeRequest.branch"
>
<icon
<icon
name=
"fork"
name=
"fork"
:size=
"16"
>
:size=
"16"
</icon>
/>
<a
:href=
"mergeRequest.branch.url"
>
{{
mergeRequest
.
branch
.
name
}}
</a>
<a
:href=
"mergeRequest.branch.url"
>
{{
mergeRequest
.
branch
.
name
}}
</a>
</span>
</span>
</
template
>
</
template
>
</div>
</div>
<div
class=
"item-time"
>
<div
class=
"item-time"
>
<total-time
:time=
"mergeRequest.totalTime"
/>
<total-time
:time=
"mergeRequest.totalTime"
/>
</div>
</div>
</li>
</li>
</ul>
</ul>
...
...
app/assets/javascripts/cycle_analytics/components/stage_staging_component.vue
View file @
1525b005
...
@@ -6,16 +6,22 @@
...
@@ -6,16 +6,22 @@
import
icon
from
'
../../vue_shared/components/icon.vue
'
;
import
icon
from
'
../../vue_shared/components/icon.vue
'
;
export
default
{
export
default
{
props
:
{
items
:
Array
,
stage
:
Object
,
},
components
:
{
components
:
{
userAvatarImage
,
userAvatarImage
,
totalTime
,
totalTime
,
limitWarning
,
limitWarning
,
icon
,
icon
,
},
},
props
:
{
items
:
{
type
:
Array
,
default
:
[]
},
stage
:
{
type
:
Object
,
default
:
()
=>
({}),
},
},
computed
:
{
computed
:
{
iconBranch
()
{
iconBranch
()
{
return
iconBranch
;
return
iconBranch
;
...
@@ -33,30 +39,58 @@
...
@@ -33,30 +39,58 @@
<li
<li
v-for=
"(build, i) in items"
v-for=
"(build, i) in items"
class=
"stage-event-item item-build-component"
class=
"stage-event-item item-build-component"
:key=
"i"
>
:key=
"i"
>
<div
class=
"item-details"
>
<div
class=
"item-details"
>
<!-- FIXME: Pass an alt attribute here for accessibility -->
<!-- FIXME: Pass an alt attribute here for accessibility -->
<user-avatar-image
:img-src=
"build.author.avatarUrl"
/>
<user-avatar-image
:img-src=
"build.author.avatarUrl"
/>
<h5
class=
"item-title"
>
<h5
class=
"item-title"
>
<a
:href=
"build.url"
class=
"pipeline-id"
>
#
{{
build
.
id
}}
</a>
<a
:href=
"build.url"
class=
"pipeline-id"
>
#
{{
build
.
id
}}
</a>
<icon
<icon
name=
"fork"
name=
"fork"
:size=
"16"
>
:size=
"16"
</icon>
/>
<a
:href=
"build.branch.url"
class=
"ref-name"
>
{{
build
.
branch
.
name
}}
</a>
<a
<span
class=
"icon-branch"
v-html=
"iconBranch"
></span>
:href=
"build.branch.url"
<a
:href=
"build.commitUrl"
class=
"commit-sha"
>
{{
build
.
shortSha
}}
</a>
class=
"ref-name"
>
{{
build
.
branch
.
name
}}
</a>
<span
class=
"icon-branch"
v-html=
"iconBranch"
>
</span>
<a
:href=
"build.commitUrl"
class=
"commit-sha"
>
{{
build
.
shortSha
}}
</a>
</h5>
</h5>
<span>
<span>
<a
:href=
"build.url"
class=
"build-date"
>
{{
build
.
date
}}
</a>
<a
:href=
"build.url"
class=
"build-date"
>
{{
build
.
date
}}
</a>
{{
s__
(
'
ByAuthor|by
'
)
}}
{{
s__
(
'
ByAuthor|by
'
)
}}
<a
:href=
"build.author.webUrl"
class=
"issue-author-link"
>
<a
:href=
"build.author.webUrl"
class=
"issue-author-link"
>
{{
build
.
author
.
name
}}
{{
build
.
author
.
name
}}
</a>
</a>
</span>
</span>
</div>
</div>
<div
class=
"item-time"
>
<div
class=
"item-time"
>
<total-time
:time=
"build.totalTime"
/>
<total-time
:time=
"build.totalTime"
/>
</div>
</div>
</li>
</li>
</ul>
</ul>
...
...
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