Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Boxiang Sun
gitlab-ce
Commits
929cb400
Commit
929cb400
authored
Nov 17, 2016
by
Filipa Lacerda
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Adds documentation to filter function
parent
c20a1cf2
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
6 deletions
+27
-6
app/assets/javascripts/environments/components/environment.js.es6
...ts/javascripts/environments/components/environment.js.es6
+27
-6
No files found.
app/assets/javascripts/environments/components/environment.js.es6
View file @
929cb400
...
@@ -6,15 +6,36 @@
...
@@ -6,15 +6,36 @@
/* globals Vue, EnvironmentsService */
/* globals Vue, EnvironmentsService */
/* eslint-disable no-param-reassign */
/* eslint-disable no-param-reassign */
$(() => {
(() => { // eslint-disable-line
window.gl = window.gl || {};
window.gl = window.gl || {};
const filterState = state => environment => environment.state === state && environment;
/**
* Given the visibility prop provided by the url query parameter and which
* changes according to the active tab we need to filter which environments
* should be visible.
*
* The environments array is a recursive tree structure and we need to filter
* both root level environments and children environments.
*
* In order to acomplish that, both `filterState` and `filterEnvironmnetsByState`
* functions work together.
* The first one works as the filter that verifies if the given environment matches
* the given state.
* The second guarantees both root level and children elements are filtered as well.
*/
// recursiveMap :: (Function, Array) -> Array
const filterState = state => environment => environment.state === state && environment;
const recursiveMap = (fn, arr) => arr.map((item) => {
/**
* Given the filter function and the array of environments will return only
* the environments that match the state provided to the filter function.
*
* @param {Function} fn
* @param {Array} array
* @return {Array}
*/
const filterEnvironmnetsByState = (fn, arr) => arr.map((item) => {
if (item.children) {
if (item.children) {
const filteredChildren =
recursiveMap
(fn, item.children).filter(Boolean);
const filteredChildren =
filterEnvironmnetsByState
(fn, item.children).filter(Boolean);
if (filteredChildren.length) {
if (filteredChildren.length) {
item.children = filteredChildren;
item.children = filteredChildren;
return item;
return item;
...
@@ -56,7 +77,7 @@ $(() => {
...
@@ -56,7 +77,7 @@ $(() => {
computed: {
computed: {
filteredEnvironments() {
filteredEnvironments() {
return
recursiveMap
(filterState(this.visibility), this.state.environments);
return
filterEnvironmnetsByState
(filterState(this.visibility), this.state.environments);
},
},
scope() {
scope() {
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment