From 4e419b9b37d1da538b70fb20d54a58e36c4cb326 Mon Sep 17 00:00:00 2001 From: John Cowen Date: Mon, 14 Dec 2020 14:25:33 +0000 Subject: [PATCH] ui: Add External Sources Filter to Node > Service Instances (#9368) * Add service collections to get all ExternalServices * Add a basic collection helper * Use the collections to get all ExternalSources * Remove old Controllers --- .../app/controllers/dc/services/index.js | 20 -- .../controllers/dc/services/show/instances.js | 13 -- .../consul-ui/app/helpers/collection.js | 23 +++ .../consul-ui/app/models/service-instance.js | 17 ++ ui/packages/consul-ui/app/models/service.js | 17 ++ .../app/templates/dc/nodes/show/services.hbs | 4 +- .../app/templates/dc/services/index.hbs | 188 +++++++++--------- .../templates/dc/services/show/instances.hbs | 2 +- 8 files changed, 158 insertions(+), 126 deletions(-) delete mode 100644 ui/packages/consul-ui/app/controllers/dc/services/index.js delete mode 100644 ui/packages/consul-ui/app/controllers/dc/services/show/instances.js create mode 100644 ui/packages/consul-ui/app/helpers/collection.js diff --git a/ui/packages/consul-ui/app/controllers/dc/services/index.js b/ui/packages/consul-ui/app/controllers/dc/services/index.js deleted file mode 100644 index a615646734..0000000000 --- a/ui/packages/consul-ui/app/controllers/dc/services/index.js +++ /dev/null @@ -1,20 +0,0 @@ -import { computed } from '@ember/object'; -import Controller from '@ember/controller'; - -export default class IndexController extends Controller { - @computed('items.[]') - get services() { - return this.items.filter(function(item) { - return item.Kind !== 'connect-proxy'; - }); - } - - @computed('services') - get externalSources() { - const sources = this.services.reduce(function(prev, item) { - return prev.concat(item.ExternalSources || []); - }, []); - // unique, non-empty values, alpha sort - return [...new Set(sources)].filter(Boolean).sort(); - } -} diff --git a/ui/packages/consul-ui/app/controllers/dc/services/show/instances.js b/ui/packages/consul-ui/app/controllers/dc/services/show/instances.js deleted file mode 100644 index 9618d59b3b..0000000000 --- a/ui/packages/consul-ui/app/controllers/dc/services/show/instances.js +++ /dev/null @@ -1,13 +0,0 @@ -import { computed } from '@ember/object'; -import Controller from '@ember/controller'; - -export default class InstancesController extends Controller { - @computed('items') - get externalSources() { - const sources = this.items.reduce(function(prev, item) { - return prev.concat(item.ExternalSources || []); - }, []); - // unique, non-empty values, alpha sort - return [...new Set(sources)].filter(Boolean).sort(); - } -} diff --git a/ui/packages/consul-ui/app/helpers/collection.js b/ui/packages/consul-ui/app/helpers/collection.js new file mode 100644 index 0000000000..5cef73b93a --- /dev/null +++ b/ui/packages/consul-ui/app/helpers/collection.js @@ -0,0 +1,23 @@ +import Helper from '@ember/component/helper'; +import { get } from '@ember/object'; + +import { Collection as Service } from 'consul-ui/models/service'; +import { Collection as ServiceInstance } from 'consul-ui/models/service-instance'; + +const collections = { + service: Service, + 'service-instance': ServiceInstance, +}; +class EmptyCollection {} +export default class CollectionHelper extends Helper { + compute([collection, str], hash) { + if (collection.length > 0) { + // TODO: Looksee if theres ever going to be a public way to get this + const modelName = get(collection, 'firstObject')._internalModel.modelName; + const Collection = collections[modelName]; + return new Collection(collection); + } else { + return new EmptyCollection(); + } + } +} diff --git a/ui/packages/consul-ui/app/models/service-instance.js b/ui/packages/consul-ui/app/models/service-instance.js index dd86310682..09a386a02f 100644 --- a/ui/packages/consul-ui/app/models/service-instance.js +++ b/ui/packages/consul-ui/app/models/service-instance.js @@ -2,10 +2,27 @@ import Model, { attr, belongsTo } from '@ember-data/model'; import { fragmentArray } from 'ember-data-model-fragments/attributes'; import { computed, get, set } from '@ember/object'; import { or, filter, alias } from '@ember/object/computed'; +import { tracked } from '@glimmer/tracking'; export const PRIMARY_KEY = 'uid'; export const SLUG_KEY = 'Node.Node,Service.ID'; +export const Collection = class Collection { + @tracked items; + + constructor(items) { + this.items = items; + } + + get ExternalSources() { + const sources = this.items.reduce(function(prev, item) { + return prev.concat(item.ExternalSources || []); + }, []); + // unique, non-empty values, alpha sort + return [...new Set(sources)].filter(Boolean).sort(); + } +}; + export default class ServiceInstance extends Model { @attr('string') uid; diff --git a/ui/packages/consul-ui/app/models/service.js b/ui/packages/consul-ui/app/models/service.js index a04d2e599e..f55691015c 100644 --- a/ui/packages/consul-ui/app/models/service.js +++ b/ui/packages/consul-ui/app/models/service.js @@ -1,9 +1,26 @@ import Model, { attr } from '@ember-data/model'; import { computed, get } from '@ember/object'; +import { tracked } from '@glimmer/tracking'; export const PRIMARY_KEY = 'uid'; export const SLUG_KEY = 'Name'; +export const Collection = class Collection { + @tracked items; + + constructor(items) { + this.items = items; + } + + get ExternalSources() { + const sources = this.items.reduce(function(prev, item) { + return prev.concat(item.ExternalSources || []); + }, []); + // unique, non-empty values, alpha sort + return [...new Set(sources)].filter(Boolean).sort(); + } +}; + export default class Service extends Model { @attr('string') uid; @attr('string') Name; diff --git a/ui/packages/consul-ui/app/templates/dc/nodes/show/services.hbs b/ui/packages/consul-ui/app/templates/dc/nodes/show/services.hbs index 462308ec7e..52a8f3933a 100644 --- a/ui/packages/consul-ui/app/templates/dc/nodes/show/services.hbs +++ b/ui/packages/consul-ui/app/templates/dc/nodes/show/services.hbs @@ -7,13 +7,13 @@ ) ) as |filters|}} {{#let (or sortBy "Status:asc") as |sort|}} - {{#let item.Services as |items|}} + {{#let (reject-by 'Service.Kind' 'connect-proxy' item.Services) as |items|}}
{{#if (gt items.length 0) }} -{{#let (hash - statuses=(if status (split status ',') undefined) - kinds=(if kind (split kind ',') undefined) - sources=(if source (split source ',') undefined) - searchproperties=(if (not-eq searchproperty undefined) - (split searchproperty ',') - (array 'Name' 'Tags') + +{{#let + + (or sortBy "Status:asc") + + (hash + statuses=(if status (split status ',') undefined) + kinds=(if kind (split kind ',') undefined) + sources=(if source (split source ',') undefined) + searchproperties=(if (not-eq searchproperty undefined) + (split searchproperty ',') + (array 'Name' 'Tags') + ) ) -) as |filters|}} - {{#let (or sortBy "Status:asc") as |sort|}} - - - - - -

- Services {{format-number services.length}} total -

- -
- - {{#if (gt services.length 0) }} - + + + + +

+ Services {{format-number items.length}} total +

+ +
+ + {{#if (gt items.length 0) }} + - {{/if}} - - - - - - - - - - -

- {{#if (gt services.length 0)}} - No services found - {{else}} - Welcome to Services - {{/if}} -

-
- -

- {{#if (gt services.length 0)}} - No services where found matching that search, or you may not have access to view the services you are searching for. - {{else}} - There don't seem to be any registered services, or you may not have access to view services yet. - {{/if}} -

-
- - - - -
-
-
-
-
- {{/let}} + @onsearch={{action (mut search) value="target.value"}} + + @sort={{sort}} + @onsort={{action (mut sortBy) value="target.selected"}} + + @filter={{filters}} + @onfilter={{hash + searchproperty=(action (mut searchproperty) value="target.selectedItems") + status=(action (mut status) value="target.selectedItems") + kind=(action (mut kind) value="target.selectedItems") + source=(action (mut source) value="target.selectedItems") + }} + /> + {{/if}} + + + + + + + + + + +

+ {{#if (gt services.length 0)}} + No services found + {{else}} + Welcome to Services + {{/if}} +

+
+ +

+ {{#if (gt services.length 0)}} + No services where found matching that search, or you may not have access to view the services you are searching for. + {{else}} + There don't seem to be any registered services, or you may not have access to view services yet. + {{/if}} +

+
+ + + + +
+
+
+
+ + + {{/let}} diff --git a/ui/packages/consul-ui/app/templates/dc/services/show/instances.hbs b/ui/packages/consul-ui/app/templates/dc/services/show/instances.hbs index e66d998a38..a0251307e8 100644 --- a/ui/packages/consul-ui/app/templates/dc/services/show/instances.hbs +++ b/ui/packages/consul-ui/app/templates/dc/services/show/instances.hbs @@ -12,7 +12,7 @@ {{#if (gt items.length 0) }}