73 lines
1.9 KiB
Vue
73 lines
1.9 KiB
Vue
<script>
|
|
import DeploymentActions from './deployment_actions.vue';
|
|
import DeploymentInfo from './deployment_info.vue';
|
|
import { MANUAL_DEPLOY, WILL_DEPLOY, CREATED } from './constants';
|
|
|
|
export default {
|
|
// name: 'Deployment' is a false positive: https://gitlab.com/gitlab-org/frontend/eslint-plugin-i18n/issues/26#possible-false-positives
|
|
// eslint-disable-next-line @gitlab/require-i18n-strings
|
|
name: 'Deployment',
|
|
components: {
|
|
DeploymentActions,
|
|
DeploymentInfo,
|
|
},
|
|
props: {
|
|
deployment: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
showMetrics: {
|
|
type: Boolean,
|
|
required: true,
|
|
},
|
|
showVisualReviewApp: {
|
|
type: Boolean,
|
|
required: false,
|
|
default: false,
|
|
},
|
|
visualReviewAppMeta: {
|
|
type: Object,
|
|
required: false,
|
|
default: () => ({
|
|
sourceProjectId: '',
|
|
sourceProjectPath: '',
|
|
mergeRequestId: '',
|
|
appUrl: '',
|
|
}),
|
|
},
|
|
},
|
|
computed: {
|
|
computedDeploymentStatus() {
|
|
if (this.deployment.status === CREATED) {
|
|
return this.isManual ? MANUAL_DEPLOY : WILL_DEPLOY;
|
|
}
|
|
return this.deployment.status;
|
|
},
|
|
isManual() {
|
|
return Boolean(this.deployment.details?.playable_build?.play_path);
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
|
|
<template>
|
|
<div class="deploy-heading">
|
|
<div class="ci-widget media">
|
|
<div class="media-body">
|
|
<div class="deploy-body">
|
|
<deployment-info
|
|
:computed-deployment-status="computedDeploymentStatus"
|
|
:deployment="deployment"
|
|
:show-metrics="showMetrics"
|
|
/>
|
|
<deployment-actions
|
|
:deployment="deployment"
|
|
:computed-deployment-status="computedDeploymentStatus"
|
|
:show-visual-review-app="showVisualReviewApp"
|
|
:visual-review-app-meta="visualReviewAppMeta"
|
|
/>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|