Commit 393ff05a authored by samdbeckham's avatar samdbeckham

Adds changes from @fatihacet review

- Splits `activeFilters` getter into multiple parts
- Adds actions for filters and commits them from the components
- Renames `help` to `report-type-popover`
- Adds constants for the state
- Makes some code-style tweaks
- Adds a changelog
parent 1deccea4
<script> <script>
import { mapGetters, mapMutations } from 'vuex'; import { mapGetters, mapActions } from 'vuex';
import { GlDropdown, GlDropdownItem } from '@gitlab/ui'; import { GlDropdown, GlDropdownItem } from '@gitlab/ui';
import Icon from '~/vue_shared/components/icon.vue'; import Icon from '~/vue_shared/components/icon.vue';
import Help from './help.vue'; import ReportTypePopover from './report_type_popover.vue';
export default { export default {
components: { components: {
GlDropdown, GlDropdown,
GlDropdownItem, GlDropdownItem,
Help, ReportTypePopover,
Icon, Icon,
}, },
props: { props: {
...@@ -27,16 +27,17 @@ export default { ...@@ -27,16 +27,17 @@ export default {
return this.getFilter(this.filterId); return this.getFilter(this.filterId);
}, },
selectedOptionText() { selectedOptionText() {
const selectedOption = this.getSelectedOptions(this.filterId)[0]; const [selectedOption] = this.getSelectedOptions(this.filterId);
return (selectedOption && selectedOption.name) || '-'; return (selectedOption && selectedOption.name) || '-';
}, },
}, },
methods: { methods: {
...mapMutations('filters', ['SET_FILTER']), ...mapActions('filters', ['setFilter']),
clickFilter(option) { clickFilter(option) {
const { filterId } = this; this.setFilter({
const optionId = option.id; filterId: this.filterId,
this.SET_FILTER({ filterId, optionId }); optionId: option.id,
});
this.$emit('change'); this.$emit('change');
}, },
}, },
...@@ -46,7 +47,10 @@ export default { ...@@ -46,7 +47,10 @@ export default {
<template> <template>
<div class="dashboard-filter"> <div class="dashboard-filter">
<strong class="js-name">{{ filter.name }}</strong> <strong class="js-name">{{ filter.name }}</strong>
<help v-if="filterId === 'type'" :dashboard-documentation="dashboardDocumentation" /> <report-type-popover
v-if="filterId === 'type'"
:dashboard-documentation="dashboardDocumentation"
/>
<gl-dropdown :text="selectedOptionText" class="d-block mt-1"> <gl-dropdown :text="selectedOptionText" class="d-block mt-1">
<gl-dropdown-item <gl-dropdown-item
v-for="option in filter.options" v-for="option in filter.options"
......
import * as types from './mutation_types';
export const setFilter = ({ commit }, payload) => {
commit(types.SET_FILTER, payload);
};
// prevent babel-plugin-rewire from generating an invalid default during karma tests
// This is no longer needed after gitlab-ce#52179 is merged
export default () => {};
export const SEVERITIES = {
critical: 'Critical',
high: 'High',
medium: 'Medium',
low: 'Low',
unknown: 'Unknown',
experimental: 'Experimental',
ignore: 'Ignore',
undefined: 'Undefined',
};
export const REPORT_TYPES = {
sast: 'SAST',
};
...@@ -3,25 +3,25 @@ export const getFilter = state => filterId => state.filters.find(filter => filte ...@@ -3,25 +3,25 @@ export const getFilter = state => filterId => state.filters.find(filter => filte
export const getSelectedOptions = (state, getters) => filterId => export const getSelectedOptions = (state, getters) => filterId =>
getters.getFilter(filterId).options.filter(option => option.selected); getters.getFilter(filterId).options.filter(option => option.selected);
export const getSelectedOptionIds = (state, getters) => filterId =>
getters.getSelectedOptions(filterId).map(option => option.id);
export const getFilterIds = state => state.filters.map(filter => filter.id);
/** /**
* Loops through all the filters and returns all the selected/active ones * Loops through all the filters and returns all the active ones
* stripping out any that are set to 'all' * stripping out any that are set to 'all'
* @returns Object * @returns Object
* e.g. { type: ['sast'], severity: ['high', 'medium'] } * e.g. { type: ['sast'], severity: ['high', 'medium'] }
*/ */
export const activeFilters = (state, getters) => export const activeFilters = (state, getters) =>
state.filters getters.getFilterIds.reduce(
.map(filter => filter.id) (result, filterId) => ({
.reduce( ...result,
(result, filterId) => ({ [filterId]: getters.getSelectedOptionIds(filterId).filter(option => option !== 'all'),
...result, }),
[filterId]: getters {},
.getSelectedOptions(filterId) );
.map(option => option.id)
.filter(option => option !== 'all'),
}),
{},
);
// prevent babel-plugin-rewire from generating an invalid default during karma tests // prevent babel-plugin-rewire from generating an invalid default during karma tests
// This is no longer needed after gitlab-ce#52179 is merged // This is no longer needed after gitlab-ce#52179 is merged
......
import state from './state'; import * as actions from './actions';
import mutations from './mutations';
import * as getters from './getters'; import * as getters from './getters';
import mutations from './mutations';
import state from './state';
export default { export default {
namespaced: true, namespaced: true,
state, actions,
mutations,
getters, getters,
mutations,
state,
}; };
...@@ -4,7 +4,9 @@ export default { ...@@ -4,7 +4,9 @@ export default {
[types.SET_FILTER](state, payload) { [types.SET_FILTER](state, payload) {
const { filterId, optionId } = payload; const { filterId, optionId } = payload;
const activeFilter = state.filters.find(filter => filter.id === filterId); const activeFilter = state.filters.find(filter => filter.id === filterId);
activeFilter.options.find(option => option.selected).selected = false; if (activeFilter) {
activeFilter.options.find(option => option.id === optionId).selected = true; activeFilter.options.find(option => option.selected).selected = false;
activeFilter.options.find(option => option.id === optionId).selected = true;
}
}, },
}; };
import { SEVERITIES, REPORT_TYPES } from './constants';
export default () => ({ export default () => ({
filters: [ filters: [
{ {
...@@ -9,46 +11,10 @@ export default () => ({ ...@@ -9,46 +11,10 @@ export default () => ({
id: 'all', id: 'all',
selected: true, selected: true,
}, },
{ ...Object.entries(SEVERITIES).map(severity => {
name: 'Critical', const [id, name] = severity;
id: 'critical', return { id, name };
selected: false, }),
},
{
name: 'High',
id: 'high',
selected: false,
},
{
name: 'Medium',
id: 'medium',
selected: false,
},
{
name: 'Low',
id: 'low',
selected: false,
},
{
name: 'Unknown',
id: 'unknown',
selected: false,
},
{
name: 'Experimental',
id: 'experimental',
selected: false,
},
{
name: 'Ignore',
id: 'ignore',
selected: false,
},
{
name: 'Undefined',
id: 'undefined',
selected: false,
},
], ],
}, },
{ {
...@@ -56,7 +22,7 @@ export default () => ({ ...@@ -56,7 +22,7 @@ export default () => ({
id: 'type', id: 'type',
options: [ options: [
{ {
name: 'SAST', name: REPORT_TYPES.sast,
id: 'sast', id: 'sast',
selected: true, selected: true,
}, },
......
---
title: Adds basic filtering to the Group Security Dashboard frontend
merge_request: 8886
author:
type: added
import testAction from 'spec/helpers/vuex_action_helper';
import createState from 'ee/security_dashboard/store/modules/filters/state';
import * as types from 'ee/security_dashboard/store/modules/filters/mutation_types';
import * as actions from 'ee/security_dashboard/store/modules/filters/actions';
describe('filters actions', () => {
describe('setFilter', () => {
it('should commit the SET_FILTER mutuation', done => {
const state = createState();
const payload = { filterId: 'type', optionId: 'sast' };
testAction(
actions.setFilter,
payload,
state,
[
{
type: types.SET_FILTER,
payload,
},
],
[],
done,
);
});
});
});
...@@ -6,10 +6,15 @@ describe('filters module getters', () => { ...@@ -6,10 +6,15 @@ describe('filters module getters', () => {
const getFilter = filterId => getters.getFilter(state)(filterId); const getFilter = filterId => getters.getFilter(state)(filterId);
const getSelectedOptions = filterId => const getSelectedOptions = filterId =>
getters.getSelectedOptions(state, { getFilter })(filterId); getters.getSelectedOptions(state, { getFilter })(filterId);
const getSelectedOptionIds = filterId =>
getters.getSelectedOptionIds(state, { getSelectedOptions })(filterId);
const getFilterIds = getters.getFilterIds(state);
return { return {
getFilter, getFilter,
getSelectedOptions, getSelectedOptions,
getSelectedOptionIds,
getFilterIds,
}; };
}; };
...@@ -32,6 +37,16 @@ describe('filters module getters', () => { ...@@ -32,6 +37,16 @@ describe('filters module getters', () => {
}); });
}); });
describe('getSelectedOptionIds', () => {
it('should return "sast" as the selcted option ID', () => {
const state = createState();
const selectedOptionIds = getters.getSelectedOptionIds(state, mockedGetters(state))('type');
expect(selectedOptionIds).toHaveLength(1);
expect(selectedOptionIds[0]).toEqual('sast');
});
});
describe('activeFilters', () => { describe('activeFilters', () => {
it('should return no severity filters', () => { it('should return no severity filters', () => {
const state = createState(); const state = createState();
......
...@@ -14,10 +14,10 @@ describe('filters module mutations', () => { ...@@ -14,10 +14,10 @@ describe('filters module mutations', () => {
[typeFilter] = state.filters; [typeFilter] = state.filters;
[allOption, sastOption] = typeFilter.options; [allOption, sastOption] = typeFilter.options;
const filterId = typeFilter.id; mutations[types.SET_FILTER](state, {
const optionId = sastOption.id; filterId: typeFilter.id,
optionId: sastOption.id,
mutations[types.SET_FILTER](state, { filterId, optionId }); });
}); });
it('should make SAST the selected option', () => { it('should make SAST the selected option', () => {
......
...@@ -7534,9 +7534,6 @@ msgstr "" ...@@ -7534,9 +7534,6 @@ msgstr ""
msgid "SAML for %{group_name}" msgid "SAML for %{group_name}"
msgstr "" msgstr ""
msgid "SAST"
msgstr ""
msgid "SHA1 fingerprint of the SAML token signing certificate. Get this from your identity provider, where it can also be called \"Thumbprint\"." msgid "SHA1 fingerprint of the SAML token signing certificate. Get this from your identity provider, where it can also be called \"Thumbprint\"."
msgstr "" msgstr ""
......
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