Commit 3def42f5 authored by Ezekiel Kigbo's avatar Ezekiel Kigbo

Added currentGroupPath getter for groupLabels request

The group path is needed to fetch group
labels, previously this was passed from the
backend, but with the new vuex store, we can
retrieve this from state.
parent 3e99ee37
...@@ -55,7 +55,7 @@ export default { ...@@ -55,7 +55,7 @@ export default {
'summary', 'summary',
'dataTimeframe', 'dataTimeframe',
]), ]),
...mapGetters(['currentStage', 'defaultStage', 'hasNoAccessError']), ...mapGetters(['currentStage', 'defaultStage', 'hasNoAccessError', 'currentGroupPath']),
shouldRenderEmptyState() { shouldRenderEmptyState() {
return !this.selectedGroup; return !this.selectedGroup;
}, },
...@@ -161,24 +161,22 @@ export default { ...@@ -161,24 +161,22 @@ export default {
) )
" "
/> />
<div v-else class="cycle-analytics mt-0"> <summary-table class="js-summary-table" :items="summary" />
<summary-table class="js-summary-table" :items="summary" /> <stage-table
<stage-table v-if="currentStage"
v-if="currentStage" class="js-stage-table"
class="js-stage-table" :current-stage="currentStage"
:current-stage="currentStage" :stages="stages"
:stages="stages" :is-loading-stage="isLoadingStage"
:is-loading-stage="isLoadingStage" :is-empty-stage="isEmptyStage"
:is-empty-stage="isEmptyStage" :is-adding-custom-stage="isAddingCustomStage"
:is-adding-custom-stage="isAddingCustomStage" :events="events"
:events="events" :no-data-svg-path="noDataSvgPath"
:no-data-svg-path="noDataSvgPath" :no-access-svg-path="noAccessSvgPath"
:no-access-svg-path="noAccessSvgPath" :can-edit-stages="hasCustomizableCycleAnalytics"
:can-edit-stages="hasCustomizableCycleAnalytics" @selectStage="onStageSelect"
@selectStage="onStageSelect" @showAddStageForm="onShowAddStageForm"
@showAddStageForm="onShowAddStageForm" />
/>
</div>
</div> </div>
</div> </div>
</template> </template>
<script> <script>
// NOTE: this is a temporary component while cycle-analytics is being refactored // NOTE: this is a temporary component while cycle-analytics is being refactored
// post refactor we will have a vuex store and functionality to fetch data // post refactor we will have a vuex store and functionality to fetch data
// https://gitlab.com/gitlab-org/gitlab-ee/merge_requests/15039 // https://gitlab.com/gitlab-org/gitlab/issues/32019
import { GlLoadingIcon } from '@gitlab/ui'; import { GlLoadingIcon } from '@gitlab/ui';
import { __ } from '~/locale'; import { __ } from '~/locale';
import createFlash from '~/flash'; import createFlash from '~/flash';
......
...@@ -6,7 +6,7 @@ import StageNavItem from './stage_nav_item.vue'; ...@@ -6,7 +6,7 @@ import StageNavItem from './stage_nav_item.vue';
import StageEventList from './stage_event_list.vue'; import StageEventList from './stage_event_list.vue';
import StageTableHeader from './stage_table_header.vue'; import StageTableHeader from './stage_table_header.vue';
import AddStageButton from './add_stage_button.vue'; import AddStageButton from './add_stage_button.vue';
import CustomStageForm from './custom_stage_form.vue'; import CustomStageFormContainer from './custom_stage_form_container.vue';
export default { export default {
name: 'StageTable', name: 'StageTable',
...@@ -18,7 +18,7 @@ export default { ...@@ -18,7 +18,7 @@ export default {
StageNavItem, StageNavItem,
StageTableHeader, StageTableHeader,
AddStageButton, AddStageButton,
CustomStageForm, CustomStageFormContainer,
}, },
directives: { directives: {
GlTooltip: GlTooltipDirective, GlTooltip: GlTooltipDirective,
...@@ -60,6 +60,11 @@ export default { ...@@ -60,6 +60,11 @@ export default {
type: Boolean, type: Boolean,
required: true, required: true,
}, },
groupPath: {
type: String,
required: false,
default: null,
},
}, },
computed: { computed: {
stageName() { stageName() {
...@@ -149,7 +154,11 @@ export default { ...@@ -149,7 +154,11 @@ export default {
:description="__('Want to see the data? Please ask an administrator for access.')" :description="__('Want to see the data? Please ask an administrator for access.')"
:svg-path="noAccessSvgPath" :svg-path="noAccessSvgPath"
/> />
<custom-stage-form v-else-if="isAddingCustomStage" /> <custom-stage-form-container
v-else-if="isAddingCustomStage"
:events="events"
:namespace="groupPath"
/>
<template v-else> <template v-else>
<stage-event-list v-if="shouldDisplayStage" :stage="currentStage" :events="events" /> <stage-event-list v-if="shouldDisplayStage" :stage="currentStage" :events="events" />
<gl-empty-state <gl-empty-state
......
...@@ -7,3 +7,6 @@ export const currentStage = ({ stages, selectedStageName }) => ...@@ -7,3 +7,6 @@ export const currentStage = ({ stages, selectedStageName }) =>
export const defaultStage = state => (state.stages.length ? state.stages[0] : null); export const defaultStage = state => (state.stages.length ? state.stages[0] : null);
export const hasNoAccessError = state => state.errorCode === httpStatus.FORBIDDEN; export const hasNoAccessError = state => state.errorCode === httpStatus.FORBIDDEN;
export const currentGroupPath = state =>
state.selectedGroup ? state.selectedGroup.full_path : null;
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment