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
b1f408cd
Commit
b1f408cd
authored
Apr 21, 2017
by
Phil Hughes
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'environments-vue-3-ee' into 'master'
Port of environments-vue-3 to EE See merge request !1693
parents
0997a5ae
34b4b9a2
Changes
8
Show whitespace changes
Inline
Side-by-side
Showing
8 changed files
with
398 additions
and
132 deletions
+398
-132
app/assets/javascripts/environments/components/environment.js
...assets/javascripts/environments/components/environment.js
+1
-1
app/assets/javascripts/environments/components/environment_actions.vue
...vascripts/environments/components/environment_actions.vue
+103
-0
app/assets/javascripts/environments/components/environment_item.vue
.../javascripts/environments/components/environment_item.vue
+145
-127
app/assets/javascripts/environments/components/environments_table.vue
...avascripts/environments/components/environments_table.vue
+145
-0
app/assets/javascripts/environments/folder/environments_folder_view.js
...vascripts/environments/folder/environments_folder_view.js
+1
-1
spec/javascripts/environments/environment_actions_spec.js
spec/javascripts/environments/environment_actions_spec.js
+1
-1
spec/javascripts/environments/environment_item_spec.js
spec/javascripts/environments/environment_item_spec.js
+1
-1
spec/javascripts/environments/environment_table_spec.js
spec/javascripts/environments/environment_table_spec.js
+1
-1
No files found.
app/assets/javascripts/environments/components/environment.js
View file @
b1f408cd
...
...
@@ -2,7 +2,7 @@
/* global Flash */
import
Vue
from
'
vue
'
;
import
EnvironmentsService
from
'
../services/environments_service
'
;
import
EnvironmentTable
from
'
./environments_table
'
;
import
EnvironmentTable
from
'
./environments_table
.vue
'
;
import
EnvironmentsStore
from
'
../stores/environments_store
'
;
import
TablePaginationComponent
from
'
../../vue_shared/components/table_pagination
'
;
import
'
../../lib/utils/common_utils
'
;
...
...
app/assets/javascripts/environments/components/environment_actions.
js
→
app/assets/javascripts/environments/components/environment_actions.
vue
View file @
b1f408cd
<
script
>
/* global Flash */
/* eslint-disable no-new */
...
...
@@ -15,7 +16,6 @@ export default {
service
:
{
type
:
Object
,
required
:
true
,
default
:
()
=>
({}),
},
},
...
...
@@ -57,9 +57,12 @@ export default {
return
!
action
.
playable
;
},
},
template
:
`
<div class="btn-group" role="group">
};
</
script
>
<
template
>
<div
class=
"btn-group"
role=
"group"
>
<button
type=
"button"
class=
"dropdown btn btn-default dropdown-new js-dropdown-play-icon-container has-tooltip"
...
...
@@ -87,9 +90,9 @@ export default {
type=
"button"
class=
"js-manual-action-link no-btn btn"
@
click=
"onClickAction(action.play_path)"
:class="{ 'disabled'
: isActionDisabled(action) }"
:class=
"
{ disabled
: isActionDisabled(action) }"
:disabled="isActionDisabled(action)">
${
playIconSvg
}
<span
v-html=
"playIconSvg"
></span>
<span>
{{
action
.
name
}}
</span>
...
...
@@ -97,5 +100,4 @@ export default {
</li>
</ul>
</div>
`
,
};
</
template
>
app/assets/javascripts/environments/components/environment_item.
js
→
app/assets/javascripts/environments/components/environment_item.
vue
View file @
b1f408cd
/**
* Environment Item Component
*
* Renders a table row for each environment.
*/
<
script
>
import
Timeago
from
'
timeago.js
'
;
import
'
../../lib/utils/text_utility
'
;
import
ActionsComponent
from
'
./environment_actions
'
;
import
ActionsComponent
from
'
./environment_actions
.vue
'
;
import
ExternalUrlComponent
from
'
./environment_external_url.vue
'
;
import
StopComponent
from
'
./environment_stop.vue
'
;
import
RollbackComponent
from
'
./environment_rollback
'
;
...
...
@@ -441,33 +436,36 @@ export default {
eventHub
.
$emit
(
'
toggleFolder
'
,
this
.
model
,
this
.
folderUrl
);
},
},
template
:
`
};
</
script
>
<
template
>
<tr
:class=
"
{ 'js-child-row': model.isChildren }">
<td>
<span class="deploy-board-icon"
<span
class=
"deploy-board-icon"
v-if=
"model.hasDeployBoard"
@
click=
"toggleDeployBoard(model)"
>
<i v-show="!model.isDeployBoardVisible"
<i
v-show=
"!model.isDeployBoardVisible"
class=
"fa fa-caret-right"
aria-hidden=
"true"
/>
<i
v-show="model.isDeployBoardVisible"
<i
v-show=
"model.isDeployBoardVisible"
class=
"fa fa-caret-down"
aria-hidden=
"true"
/>
</span>
<a v-if="!model.isFolder"
<a
v-if=
"!model.isFolder"
class=
"environment-name"
:class=
"
{ 'prepend-left-default': model.isChildren }"
:href="environmentPath">
{{
model
.
name
}}
</a>
<span v-if="model.isFolder"
<span
v-else
class=
"folder-name"
@
click=
"onClickFolder"
role=
"button"
>
...
...
@@ -484,7 +482,9 @@ export default {
</span>
<span
class=
"folder-icon"
>
<i class="fa fa-folder" aria-hidden="true"></i>
<i
class=
"fa fa-folder"
aria-hidden=
"true"
/>
</span>
<span>
...
...
@@ -504,8 +504,11 @@ export default {
<span
v-if=
"!model.isFolder && deploymentHasUser"
>
by
<a :href="deploymentUser.web_url" class="js-deploy-user-container">
<img class="avatar has-tooltip s20"
<a
:href=
"deploymentUser.web_url"
class=
"js-deploy-user-container"
>
<img
class=
"avatar has-tooltip s20"
:src=
"deploymentUser.avatar_url"
:alt=
"userImageAltDescription"
:title=
"deploymentUser.username"
/>
...
...
@@ -514,7 +517,8 @@ export default {
</td>
<td
class=
"environments-build-cell"
>
<a v-if="shouldRenderBuildName"
<a
v-if=
"shouldRenderBuildName"
class=
"build-link"
:href=
"buildPath"
>
{{
buildName
}}
...
...
@@ -522,7 +526,9 @@ export default {
</td>
<td>
<div v-if="!model.isFolder && hasLastDeploymentKey" class="js-commit-component">
<div
v-if=
"!model.isFolder && hasLastDeploymentKey"
class=
"js-commit-component"
>
<commit-component
:tag=
"commitTag"
:commit-ref=
"commitRef"
...
...
@@ -531,43 +537,55 @@ export default {
:title=
"commitTitle"
:author=
"commitAuthor"
/>
</div>
<p v-if="!model.isFolder && !hasLastDeploymentKey" class="commit-title">
<p
v-if=
"!model.isFolder && !hasLastDeploymentKey"
class=
"commit-title"
>
No deployments yet
</p>
</td>
<td>
<span v-if="!model.isFolder && canShowDate"
<span
v-if=
"!model.isFolder && canShowDate"
class=
"environment-created-date-timeago"
>
{{
createdDate
}}
</span>
</td>
<td
class=
"environments-actions"
>
<div v-if="!model.isFolder" class="btn-group pull-right" role="group">
<actions-component v-if="hasManualActions && canCreateDeployment"
<div
v-if=
"!model.isFolder"
class=
"btn-group pull-right"
role=
"group"
>
<actions-component
v-if=
"hasManualActions && canCreateDeployment"
:service=
"service"
:actions=
"manualActions"
/>
<external-url-component v-if="externalURL && canReadEnvironment"
<external-url-component
v-if=
"externalURL && canReadEnvironment"
:external-url=
"externalURL"
/>
<monitoring-button-component v-if="monitoringUrl && canReadEnvironment"
<monitoring-button-component
v-if=
"monitoringUrl && canReadEnvironment"
:monitoring-url=
"monitoringUrl"
/>
<terminal-button-component v-if="model && model.terminal_path"
<terminal-button-component
v-if=
"model && model.terminal_path"
:terminal-path=
"model.terminal_path"
/>
<stop-component v-if="hasStopAction && canCreateDeployment"
<stop-component
v-if=
"hasStopAction && canCreateDeployment"
:stop-url=
"model.stop_path"
:service=
"service"
/>
<rollback-component v-if="canRetry && canCreateDeployment"
<rollback-component
v-if=
"canRetry && canCreateDeployment"
:is-last-deployment=
"isLastDeployment"
:retry-url=
"retryUrl"
:service=
"service"
/>
</div>
</td>
</tr>
`
,
};
</
template
>
app/assets/javascripts/environments/components/environments_table.
js
→
app/assets/javascripts/environments/components/environments_table.
vue
View file @
b1f408cd
<
script
>
/**
* Render environments table.
*
* Dumb component used to render top level environments and
* the folder view.
*/
import
EnvironmentTableRowComponent
from
'
./environment_item
'
;
import
EnvironmentTableRowComponent
from
'
./environment_item
.vue
'
;
import
DeployBoard
from
'
./deploy_board_component
'
;
export
default
{
...
...
@@ -32,6 +30,17 @@ export default {
default
:
false
,
},
service
:
{
type
:
Object
,
required
:
true
,
},
isLoadingFolderContent
:
{
type
:
Boolean
,
required
:
false
,
default
:
false
,
},
toggleDeployBoard
:
{
type
:
Function
,
required
:
false
,
...
...
@@ -43,18 +52,6 @@ export default {
required
:
false
,
default
:
()
=>
({}),
},
service
:
{
type
:
Object
,
required
:
true
,
default
:
()
=>
({}),
},
isLoadingFolderContent
:
{
type
:
Boolean
,
required
:
false
,
default
:
false
,
},
},
methods
:
{
...
...
@@ -62,29 +59,42 @@ export default {
return
`
${
window
.
location
.
pathname
}
/folders/
${
model
.
folderName
}
`
;
},
},
template
:
`
};
</
script
>
<
template
>
<table
class=
"table ci-table"
>
<thead>
<tr>
<th class="environments-name">Environment</th>
<th class="environments-deploy">Last deployment</th>
<th class="environments-build">Job</th>
<th class="environments-commit">Commit</th>
<th class="environments-date">Updated</th>
<th
class=
"environments-name"
>
Environment
</th>
<th
class=
"environments-deploy"
>
Last deployment
</th>
<th
class=
"environments-build"
>
Job
</th>
<th
class=
"environments-commit"
>
Commit
</th>
<th
class=
"environments-date"
>
Updated
</th>
<th
class=
"environments-actions"
></th>
</tr>
</thead>
<tbody>
<template v-for="model in environments"
<template
v-for=
"model in environments"
v-bind:model=
"model"
>
<tr
is="environment-item"
<tr
is=
"environment-item"
:model=
"model"
:can-create-deployment=
"canCreateDeployment"
:can-read-environment=
"canReadEnvironment"
:service=
"service"
:toggleDeployBoard=
"toggleDeployBoard"
:service="service"></tr
>
/
>
<tr
v-if=
"model.hasDeployBoard && model.isDeployBoardVisible"
class=
"js-deploy-board-row"
>
<td
colspan=
"6"
class=
"deploy-board-container"
>
...
...
@@ -93,29 +103,36 @@ export default {
:service=
"service"
:environmentID=
"model.id"
:deployBoardData=
"model.deployBoardData"
:endpoint="model.rollout_status_path">
</deploy-board
>
:endpoint=
"model.rollout_status_path"
/
>
</td>
</tr>
<template
v-if=
"model.isFolder && model.isOpen && model.children && model.children.length > 0"
>
<tr
v-if=
"isLoadingFolderContent"
>
<td
colspan=
"6"
class=
"text-center"
>
<i class="fa fa-spin fa-spinner fa-2x" aria-hidden="true"/>
<i
class=
"fa fa-spin fa-spinner fa-2x"
aria-hidden=
"true"
/>
</td>
</tr>
<template
v-else
>
<tr is="environment-item"
<tr
is=
"environment-item"
v-for=
"children in model.children"
:model=
"children"
:can-create-deployment=
"canCreateDeployment"
:can-read-environment=
"canReadEnvironment"
:service="service"></tr
>
:service=
"service"
/
>
<tr>
<td colspan="6" class="text-center">
<a :href="folderUrl(model)" class="btn btn-default">
<td
colspan=
"6"
class=
"text-center"
>
<a
:href=
"folderUrl(model)"
class=
"btn btn-default"
>
Show all
</a>
</td>
...
...
@@ -125,5 +142,4 @@ export default {
</template>
</tbody>
</table>
`
,
};
</template>
app/assets/javascripts/environments/folder/environments_folder_view.js
View file @
b1f408cd
...
...
@@ -2,7 +2,7 @@
/* global Flash */
import
Vue
from
'
vue
'
;
import
EnvironmentsService
from
'
../services/environments_service
'
;
import
EnvironmentTable
from
'
../components/environments_table
'
;
import
EnvironmentTable
from
'
../components/environments_table
.vue
'
;
import
EnvironmentsStore
from
'
../stores/environments_store
'
;
import
TablePaginationComponent
from
'
../../vue_shared/components/table_pagination
'
;
import
'
../../lib/utils/common_utils
'
;
...
...
spec/javascripts/environments/environment_actions_spec.js
View file @
b1f408cd
import
Vue
from
'
vue
'
;
import
actionsComp
from
'
~/environments/components/environment_actions
'
;
import
actionsComp
from
'
~/environments/components/environment_actions
.vue
'
;
describe
(
'
Actions Component
'
,
()
=>
{
let
ActionsComponent
;
...
...
spec/javascripts/environments/environment_item_spec.js
View file @
b1f408cd
import
'
timeago.js
'
;
import
Vue
from
'
vue
'
;
import
environmentItemComp
from
'
~/environments/components/environment_item
'
;
import
environmentItemComp
from
'
~/environments/components/environment_item
.vue
'
;
describe
(
'
Environment item
'
,
()
=>
{
let
EnvironmentItem
;
...
...
spec/javascripts/environments/environment_table_spec.js
View file @
b1f408cd
import
Vue
from
'
vue
'
;
import
environmentTableComp
from
'
~/environments/components/environments_table
'
;
import
environmentTableComp
from
'
~/environments/components/environments_table
.vue
'
;
describe
(
'
Environment item
'
,
()
=>
{
let
EnvironmentTable
;
...
...
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