mirror of
https://github.com/status-im/consul.git
synced 2025-01-09 21:35:52 +00:00
f26201a7a4
* Create Topology Tab with foundational layout and styling * Create Toplogy Metrics component with dynamic SVG * Add ember-render-modifiers addon * Implement Topology Metrics comp and fix up styling * Create topology endpoint with tests * Move arrow drawing to index.js file * Add topology to show controller * Fix up conditional wrapper, tabs positioning, links, and styling * Group upstreams by dc and fix up styling * Create service/health-percentage helper * Add health check percentages to upstreams and downstreams * Basic Layout * Upgrade @hashicorp/consul-api-double to v5.2.3 * Renamed endpoint to be service-topology * Refactor styling * Update to only show Topology tab when Connect is enabled * Fix bug and changes from review notes * Remove unused functions that are replaced with SVG markers * Refactor to resuse svg-curve helper * Use the render-template helper for the metrics link * Add topology default null to services show route * Removed unused ID * Fix up tests broken by redirect to /topology
88 lines
2.6 KiB
Handlebars
88 lines
2.6 KiB
Handlebars
{{#if (gt items.length 0)}}
|
|
<ListCollection @items={{items}} @linkable={{action "isLinkable"}} class="consul-service-list" as |item index|>
|
|
<BlockSlot @name="header">
|
|
<dl class={{item.MeshStatus}}>
|
|
<dt>
|
|
Health
|
|
</dt>
|
|
<dd>
|
|
<Tooltip @position="top-start">
|
|
{{#if (eq 'critical' item.MeshStatus)}}
|
|
At least one health check on one instance is failing.
|
|
{{else if (eq 'warning' item.MeshStatus)}}
|
|
At least one health check on one instance has a warning.
|
|
{{else if (eq 'passing' item.MeshStatus)}}
|
|
All health checks are passing.
|
|
{{else}}
|
|
There are no health checks.
|
|
{{/if}}
|
|
</Tooltip>
|
|
</dd>
|
|
</dl>
|
|
{{#if (gt item.InstanceCount 0)}}
|
|
<a data-test-service-name href={{href-to "dc.services.show.index" item.Name}}>
|
|
{{item.Name}}
|
|
</a>
|
|
{{else}}
|
|
<p data-test-service-name>
|
|
{{item.Name}}
|
|
</p>
|
|
{{/if}}
|
|
</BlockSlot>
|
|
<BlockSlot @name="details">
|
|
{{#if (and nspace (env 'CONSUL_NSPACES_ENABLED'))}}
|
|
{{#if (not-eq item.Namespace nspace)}}
|
|
<dl class="nspace">
|
|
<dt>
|
|
<Tooltip>
|
|
Namespace
|
|
</Tooltip>
|
|
</dt>
|
|
<dd>
|
|
{{item.Namespace}}
|
|
</dd>
|
|
</dl>
|
|
{{/if}}
|
|
{{/if}}
|
|
<ConsulKind @item={{item}} />
|
|
<ConsulExternalSource @item={{item}} />
|
|
{{#if (not-eq item.InstanceCount 0)}}
|
|
<span>
|
|
{{format-number item.InstanceCount}} {{pluralize item.InstanceCount 'Instance' without-count=true}}
|
|
</span>
|
|
{{/if}}
|
|
{{#if (eq item.Kind 'terminating-gateway')}}
|
|
<span data-test-associated-service-count>
|
|
{{format-number item.GatewayConfig.AssociatedServiceCount}} linked services
|
|
</span>
|
|
{{else if (eq item.Kind 'ingress-gateway')}}
|
|
<span data-test-associated-service-count>
|
|
{{format-number item.GatewayConfig.AssociatedServiceCount}} upstreams
|
|
</span>
|
|
{{/if}}
|
|
{{#if (or item.ConnectedWithGateway item.ConnectedWithProxy)}}
|
|
<dl class="mesh">
|
|
<dt>
|
|
<Tooltip>
|
|
This service uses a proxy for the Consul service mesh
|
|
</Tooltip>
|
|
</dt>
|
|
{{#if (and item.ConnectedWithGateway item.ConnectedWithProxy )}}
|
|
<dd data-test-mesh>
|
|
in service mesh with proxy and gateway
|
|
</dd>
|
|
{{else if item.ConnectedWithProxy}}
|
|
<dd data-test-mesh>
|
|
in service mesh with proxy
|
|
</dd>
|
|
{{else if item.ConnectedWithGateway}}
|
|
<dd data-test-mesh>
|
|
in service mesh with gateway
|
|
</dd>
|
|
{{/if}}
|
|
</dl>
|
|
{{/if}}
|
|
<TagList @item={{item}} />
|
|
</BlockSlot>
|
|
</ListCollection>
|
|
{{/if}} |