Commit 3660169a authored by Martin Wortschack's avatar Martin Wortschack

Merge branch 'jivanvl-frontend-metrics-visibility-toggle' into 'master'

Add metric visibility toggle in project

See merge request gitlab-org/gitlab!29442
parents 16a91de1 d0226559
...@@ -3,6 +3,7 @@ import { GlSprintf, GlLink } from '@gitlab/ui'; ...@@ -3,6 +3,7 @@ import { GlSprintf, GlLink } from '@gitlab/ui';
import settingsMixin from 'ee_else_ce/pages/projects/shared/permissions/mixins/settings_pannel_mixin'; import settingsMixin from 'ee_else_ce/pages/projects/shared/permissions/mixins/settings_pannel_mixin';
import { s__ } from '~/locale'; import { s__ } from '~/locale';
import glFeatureFlagsMixin from '~/vue_shared/mixins/gl_feature_flags_mixin';
import projectFeatureSetting from './project_feature_setting.vue'; import projectFeatureSetting from './project_feature_setting.vue';
import projectFeatureToggle from '~/vue_shared/components/toggle_button.vue'; import projectFeatureToggle from '~/vue_shared/components/toggle_button.vue';
import projectSettingRow from './project_setting_row.vue'; import projectSettingRow from './project_setting_row.vue';
...@@ -24,7 +25,7 @@ export default { ...@@ -24,7 +25,7 @@ export default {
GlSprintf, GlSprintf,
GlLink, GlLink,
}, },
mixins: [settingsMixin], mixins: [settingsMixin, glFeatureFlagsMixin()],
props: { props: {
currentSettings: { currentSettings: {
...@@ -116,6 +117,8 @@ export default { ...@@ -116,6 +117,8 @@ export default {
const defaults = { const defaults = {
visibilityOptions, visibilityOptions,
visibilityLevel: visibilityOptions.PUBLIC, visibilityLevel: visibilityOptions.PUBLIC,
// TODO: Change all of these to use the visibilityOptions constants
// https://gitlab.com/gitlab-org/gitlab/-/issues/214667
issuesAccessLevel: 20, issuesAccessLevel: 20,
repositoryAccessLevel: 20, repositoryAccessLevel: 20,
forkingAccessLevel: 20, forkingAccessLevel: 20,
...@@ -124,11 +127,14 @@ export default { ...@@ -124,11 +127,14 @@ export default {
wikiAccessLevel: 20, wikiAccessLevel: 20,
snippetsAccessLevel: 20, snippetsAccessLevel: 20,
pagesAccessLevel: 20, pagesAccessLevel: 20,
metricsAccessLevel: visibilityOptions.PRIVATE,
containerRegistryEnabled: true, containerRegistryEnabled: true,
lfsEnabled: true, lfsEnabled: true,
requestAccessEnabled: true, requestAccessEnabled: true,
highlightChangesClass: false, highlightChangesClass: false,
emailsDisabled: false, emailsDisabled: false,
featureAccessLevelEveryone,
featureAccessLevelMembers,
}; };
return { ...defaults, ...this.currentSettings }; return { ...defaults, ...this.currentSettings };
...@@ -189,6 +195,10 @@ export default { ...@@ -189,6 +195,10 @@ export default {
'ProjectSettings|View and edit files in this project. Non-project members will only have read access', 'ProjectSettings|View and edit files in this project. Non-project members will only have read access',
); );
}, },
metricsDashboardVisibilitySwitchingAvailable() {
return this.glFeatures.metricsDashboardVisibilitySwitchingAvailable;
},
}, },
watch: { watch: {
...@@ -462,6 +472,38 @@ export default { ...@@ -462,6 +472,38 @@ export default {
name="project[project_feature_attributes][pages_access_level]" name="project[project_feature_attributes][pages_access_level]"
/> />
</project-setting-row> </project-setting-row>
<project-setting-row
v-if="metricsDashboardVisibilitySwitchingAvailable"
ref="metrics-visibility-settings"
:label="__('Metrics Dashboard')"
:help-text="
s__(
'ProjectSettings|With Metrics Dashboard you can visualize this project performance metrics',
)
"
>
<div class="project-feature-controls">
<div class="select-wrapper">
<select
v-model="metricsAccessLevel"
name="project[project_feature_attributes][metrics_dashboard_access_level]"
class="form-control select-control"
>
<option
:value="visibilityOptions.PRIVATE"
:disabled="!visibilityAllowed(visibilityOptions.PRIVATE)"
>{{ featureAccessLevelMembers[1] }}</option
>
<option
:value="visibilityOptions.PUBLIC"
:disabled="!visibilityAllowed(visibilityOptions.PUBLIC)"
>{{ featureAccessLevelEveryone[1] }}</option
>
</select>
<i aria-hidden="true" data-hidden="true" class="fa fa-chevron-down"></i>
</div>
</div>
</project-setting-row>
</div> </div>
<project-setting-row v-if="canDisableEmails" ref="email-settings" class="mb-3"> <project-setting-row v-if="canDisableEmails" ref="email-settings" class="mb-3">
<label class="js-emails-disabled"> <label class="js-emails-disabled">
......
...@@ -36,6 +36,10 @@ class ProjectsController < Projects::ApplicationController ...@@ -36,6 +36,10 @@ class ProjectsController < Projects::ApplicationController
layout :determine_layout layout :determine_layout
before_action do
push_frontend_feature_flag(:metrics_dashboard_visibility_switching_available)
end
def index def index
redirect_to(current_user ? root_path : explore_root_path) redirect_to(current_user ? root_path : explore_root_path)
end end
......
...@@ -16075,6 +16075,9 @@ msgstr "" ...@@ -16075,6 +16075,9 @@ msgstr ""
msgid "ProjectSettings|With GitLab Pages you can host your static websites on GitLab" msgid "ProjectSettings|With GitLab Pages you can host your static websites on GitLab"
msgstr "" msgstr ""
msgid "ProjectSettings|With Metrics Dashboard you can visualize this project performance metrics"
msgstr ""
msgid "ProjectTemplates|.NET Core" msgid "ProjectTemplates|.NET Core"
msgstr "" msgstr ""
......
...@@ -55,7 +55,12 @@ describe('Settings Panel', () => { ...@@ -55,7 +55,12 @@ describe('Settings Panel', () => {
currentSettings: { ...defaultProps.currentSettings, ...currentSettings }, currentSettings: { ...defaultProps.currentSettings, ...currentSettings },
}; };
return mountFn(settingsPanel, { propsData }); return mountFn(settingsPanel, {
propsData,
provide: {
glFeatures: { metricsDashboardVisibilitySwitchingAvailable: true },
},
});
}; };
const overrideCurrentSettings = (currentSettingsProps, extraProps = {}) => { const overrideCurrentSettings = (currentSettingsProps, extraProps = {}) => {
...@@ -471,4 +476,28 @@ describe('Settings Panel', () => { ...@@ -471,4 +476,28 @@ describe('Settings Panel', () => {
}); });
}); });
}); });
describe('Metrics dashboard', () => {
it('should show the metrics dashboard access toggle', () => {
return wrapper.vm.$nextTick(() => {
expect(wrapper.find({ ref: 'metrics-visibility-settings' }).exists()).toBe(true);
});
});
it('should set the visibility level description based upon the selected visibility level', () => {
wrapper
.find('[name="project[project_feature_attributes][metrics_dashboard_access_level]"]')
.setValue(visibilityOptions.PUBLIC);
expect(wrapper.vm.metricsAccessLevel).toBe(visibilityOptions.PUBLIC);
});
it('should contain help text', () => {
wrapper = overrideCurrentSettings({ visibilityLevel: visibilityOptions.PRIVATE });
expect(wrapper.find({ ref: 'metrics-visibility-settings' }).props().helpText).toEqual(
'With Metrics Dashboard you can visualize this project performance metrics',
);
});
});
}); });
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