diff options
author | Filipa Lacerda <filipa@gitlab.com> | 2016-10-25 21:00:56 +0100 |
---|---|---|
committer | Filipa Lacerda <filipa@gitlab.com> | 2016-11-16 11:58:05 +0000 |
commit | a2dbdb88be6fdd363d42f925c2792adb2e4756ab (patch) | |
tree | 1bed260111b26da8e5f2bfc301f4f7afa959a7ff /app | |
parent | 9a7fa3b6d38f6ac9dbdfef793d66cb6d21c6431e (diff) | |
download | gitlab-ce-a2dbdb88be6fdd363d42f925c2792adb2e4756ab.tar.gz |
Fix tab filtering and counting
Diffstat (limited to 'app')
3 files changed, 41 insertions, 17 deletions
diff --git a/app/assets/javascripts/environments/environments_bundle.js.es6 b/app/assets/javascripts/environments/environments_bundle.js.es6 index 3382e7a4b29..59c0dcfe1c2 100644 --- a/app/assets/javascripts/environments/environments_bundle.js.es6 +++ b/app/assets/javascripts/environments/environments_bundle.js.es6 @@ -16,14 +16,21 @@ $(() => { gl.EnvironmentsListApp.$destroy(true); } - const filterEnvironments = (environments = [], filter = "") => { - return environments.filter((env) => { - if (env.children) { - return env.children.filter((child) => child.state === filter).length; - } else { - return env.state === filter; - }; - }); + + const filterState = (state) => (environment) => environment.state === state && environment; + + // recursiveMap :: (Function, Array) -> Array + const recursiveMap = (fn, arr) => { + return arr.map((item) => { + if (!item.children) { return fn(item); } + + const filteredChildren = recursiveMap(fn, item.children).filter(Boolean); + if (filteredChildren.length) { + item.children = filteredChildren; + return item; + } + + }).filter(Boolean); }; gl.EnvironmentsListApp = new Vue({ @@ -43,15 +50,15 @@ $(() => { computed: { filteredEnvironments () { - return filterEnvironments(this.state.environments, this.visibility); + return recursiveMap(filterState(this.visibility), this.state.environments); }, countStopped () { - return filterEnvironments(this.state.environments, 'stopped').length; + }, countAvailable () { - return filterEnvironments(this.state.environments, 'available').length; + // return recursiveMap(filterState('available'), this.state.environments).length; } }, diff --git a/app/assets/javascripts/environments/stores/environmnets_store.js.es6 b/app/assets/javascripts/environments/stores/environmnets_store.js.es6 index 9416b944b4d..de51d94d2b5 100644 --- a/app/assets/javascripts/environments/stores/environmnets_store.js.es6 +++ b/app/assets/javascripts/environments/stores/environmnets_store.js.es6 @@ -7,6 +7,8 @@ create () { this.state.environments = []; + this.state.stoppedCounter = 0; + this.state.availableCounter = 0; }, /** @@ -42,6 +44,10 @@ * @returns {Array} Tree structured array with the received environments. */ storeEnvironments(environments = []) { + + this.state.stoppedCounter = this.countByState(environments, 'stopped'); + this.state.availableCounter = this.countByState(environments, 'available'); + const environmentsTree = environments.reduce((acc, environment) => { if (environment.last_deployment) { @@ -59,15 +65,14 @@ if (environment.environment_type !== null) { const occurs = acc.find((element, index, array) => { - return element.environment_type === environment.environment_type; + return element.children && element.name === environment.environment_type; }); - - + environment["vue-isChildren"] = true; if (occurs !== undefined) { acc[acc.indexOf(occurs)].children.push(environment); - acc[acc.indexOf(occurs)].children.push(environment).sort(this.sortByName) + acc[acc.indexOf(occurs)].children.sort(this.sortByName) } else { acc.push({ name: environment.environment_type, @@ -89,6 +94,18 @@ }, /** + * Given an array of environments, returns the number of environments + * that have the given state. + * + * @param {Array} environments + * @param {String} state + * @returns {Number} + */ + countByState(environments, state) { + return environments.filter((env) => env.state === state).length; + }, + + /** * Sorts the two objects provided by their name. * * @param {Object} a diff --git a/app/views/projects/environments/index.html.haml b/app/views/projects/environments/index.html.haml index 3538777d11c..81c8fd9d9db 100644 --- a/app/views/projects/environments/index.html.haml +++ b/app/views/projects/environments/index.html.haml @@ -12,13 +12,13 @@ = link_to project_environments_path(@project) do Available %span.badge.js-available-environments-count - {{countAvailable}} + {{state.availableCounter}} %li{class: ('active' if @scope == 'stopped')} = link_to project_environments_path(@project, scope: :stopped) do Stopped %span.badge.js-stopped-environments-count - {{countStopped}} + {{state.stoppedCounter}} - if can?(current_user, :create_environment, @project) && !@all_environments.blank? .nav-controls |