117 lines
3.1 KiB
Vue
117 lines
3.1 KiB
Vue
<script>
|
|
import Flash from '../../flash';
|
|
import { s__ } from '../../locale';
|
|
import emptyState from './empty_state.vue';
|
|
import eventHub from '../event_hub';
|
|
import environmentsMixin from '../mixins/environments_mixin';
|
|
import CIPaginationMixin from '../../vue_shared/mixins/ci_pagination_api_mixin';
|
|
import StopEnvironmentModal from './stop_environment_modal.vue';
|
|
|
|
export default {
|
|
components: {
|
|
emptyState,
|
|
StopEnvironmentModal,
|
|
},
|
|
|
|
mixins: [CIPaginationMixin, environmentsMixin],
|
|
|
|
props: {
|
|
endpoint: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
canCreateEnvironment: {
|
|
type: Boolean,
|
|
required: true,
|
|
},
|
|
canReadEnvironment: {
|
|
type: Boolean,
|
|
required: true,
|
|
},
|
|
cssContainerClass: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
newEnvironmentPath: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
helpPagePath: {
|
|
type: String,
|
|
required: true,
|
|
},
|
|
},
|
|
|
|
created() {
|
|
eventHub.$on('toggleFolder', this.toggleFolder);
|
|
},
|
|
|
|
beforeDestroy() {
|
|
eventHub.$off('toggleFolder');
|
|
},
|
|
|
|
methods: {
|
|
toggleFolder(folder) {
|
|
this.store.toggleFolder(folder);
|
|
|
|
if (!folder.isOpen) {
|
|
this.fetchChildEnvironments(folder, true);
|
|
}
|
|
},
|
|
|
|
fetchChildEnvironments(folder, showLoader = false) {
|
|
this.store.updateEnvironmentProp(folder, 'isLoadingFolderContent', showLoader);
|
|
|
|
this.service
|
|
.getFolderContent(folder.folder_path)
|
|
.then(response => this.store.setfolderContent(folder, response.data.environments))
|
|
.then(() => this.store.updateEnvironmentProp(folder, 'isLoadingFolderContent', false))
|
|
.catch(() => {
|
|
Flash(s__('Environments|An error occurred while fetching the environments.'));
|
|
this.store.updateEnvironmentProp(folder, 'isLoadingFolderContent', false);
|
|
});
|
|
},
|
|
|
|
successCallback(resp) {
|
|
this.saveData(resp);
|
|
|
|
// We need to verify if any folder is open to also update it
|
|
const openFolders = this.store.getOpenFolders();
|
|
if (openFolders.length) {
|
|
openFolders.forEach(folder => this.fetchChildEnvironments(folder));
|
|
}
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
<template>
|
|
<div :class="cssContainerClass">
|
|
<stop-environment-modal :environment="environmentInStopModal" />
|
|
|
|
<div class="top-area">
|
|
<tabs :tabs="tabs" scope="environments" @onChangeTab="onChangeTab" />
|
|
|
|
<div v-if="canCreateEnvironment && !isLoading" class="nav-controls">
|
|
<a :href="newEnvironmentPath" class="btn btn-success">{{
|
|
s__('Environments|New environment')
|
|
}}</a>
|
|
</div>
|
|
</div>
|
|
|
|
<container
|
|
:is-loading="isLoading"
|
|
:environments="state.environments"
|
|
:pagination="state.paginationInformation"
|
|
:can-read-environment="canReadEnvironment"
|
|
@onChangePage="onChangePage"
|
|
>
|
|
<empty-state
|
|
v-if="!isLoading && state.environments.length === 0"
|
|
slot="emptyState"
|
|
:new-path="newEnvironmentPath"
|
|
:help-path="helpPagePath"
|
|
:can-create-environment="canCreateEnvironment"
|
|
/>
|
|
</container>
|
|
</div>
|
|
</template>
|