mirror of https://github.com/hashicorp/consul
UI: CC-4032 - Update sidebar width (#16204)
* Update chrome-width var to be 280px * Formatting & Changelogpull/15878/head^2
parent
8979e64a94
commit
3f22879106
|
@ -0,0 +1,3 @@
|
||||||
|
```release-note:improvement
|
||||||
|
ui: Update sidebar width to 280px
|
||||||
|
```
|
|
@ -123,11 +123,11 @@ main {
|
||||||
}
|
}
|
||||||
%main-nav-horizontal-toggle:checked ~ footer,
|
%main-nav-horizontal-toggle:checked ~ footer,
|
||||||
%main-nav-horizontal-toggle:checked + header > div > nav:first-of-type {
|
%main-nav-horizontal-toggle:checked + header > div > nav:first-of-type {
|
||||||
left: calc(var(--chrome-width, 300px) * -1);
|
left: calc(var(--chrome-width, 280px) * -1);
|
||||||
}
|
}
|
||||||
%main-nav-horizontal-toggle ~ main .notifications,
|
%main-nav-horizontal-toggle ~ main .notifications,
|
||||||
%main-nav-horizontal-toggle ~ main {
|
%main-nav-horizontal-toggle ~ main {
|
||||||
margin-left: var(--chrome-width, 300px);
|
margin-left: var(--chrome-width, 280px);
|
||||||
}
|
}
|
||||||
%main-nav-horizontal-toggle:checked ~ main .notifications,
|
%main-nav-horizontal-toggle:checked ~ main .notifications,
|
||||||
%main-nav-horizontal-toggle:checked ~ main {
|
%main-nav-horizontal-toggle:checked ~ main {
|
||||||
|
@ -144,7 +144,7 @@ main {
|
||||||
}
|
}
|
||||||
%main-nav-horizontal-toggle ~ footer,
|
%main-nav-horizontal-toggle ~ footer,
|
||||||
%main-nav-horizontal-toggle + header > div > nav:first-of-type {
|
%main-nav-horizontal-toggle + header > div > nav:first-of-type {
|
||||||
left: calc(var(--chrome-width, 300px) * -1);
|
left: calc(var(--chrome-width, 280px) * -1);
|
||||||
}
|
}
|
||||||
%main-nav-horizontal-toggle ~ main .notifications,
|
%main-nav-horizontal-toggle ~ main .notifications,
|
||||||
%main-nav-horizontal-toggle ~ main {
|
%main-nav-horizontal-toggle ~ main {
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
position: absolute;
|
position: absolute;
|
||||||
left: 0;
|
left: 0;
|
||||||
top: var(--chrome-height, 47px);
|
top: var(--chrome-height, 47px);
|
||||||
width: var(--chrome-width, 300px);
|
width: var(--chrome-width, 280px);
|
||||||
height: calc(100vh - var(--chrome-height, 47px) - 35px);
|
height: calc(100vh - var(--chrome-height, 47px) - 35px);
|
||||||
padding-top: 35px;
|
padding-top: 35px;
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
:root {
|
:root {
|
||||||
--chrome-width: 300px;
|
--chrome-width: 280px;
|
||||||
--chrome-height: 64px;
|
--chrome-height: 64px;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,133 +1,138 @@
|
||||||
<Route @name={{routeName}} as |route|>
|
<Route @name={{routeName}} as |route|>
|
||||||
|
|
||||||
{{! Add the a11y route announcer }}
|
{{! Add the a11y route announcer }}
|
||||||
<route.Announcer @title="Consul" />
|
<route.Announcer @title='Consul' />
|
||||||
{{! Tell CSS what we have enabled }}
|
{{! Tell CSS what we have enabled }}
|
||||||
{{#if (can "use acls")}}
|
{{#if (can 'use acls')}}
|
||||||
{{document-attrs class="has-acls"}}
|
{{document-attrs class='has-acls'}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
{{#if (can "use nspaces")}}
|
{{#if (can 'use nspaces')}}
|
||||||
{{document-attrs class="has-nspaces"}}
|
{{document-attrs class='has-nspaces'}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
{{#if (can "use partitions")}}
|
{{#if (can 'use partitions')}}
|
||||||
{{document-attrs class="has-partitions"}}
|
{{document-attrs class='has-partitions'}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
|
|
||||||
{{! Listen out for blocking query/client setting changes }}
|
{{! Listen out for blocking query/client setting changes }}
|
||||||
<DataSource @src={{uri 'settings://consul:client' }} @onchange={{route-action "onClientChanged" }} />
|
<DataSource
|
||||||
|
@src={{uri 'settings://consul:client'}}
|
||||||
|
@onchange={{route-action 'onClientChanged'}}
|
||||||
|
/>
|
||||||
|
|
||||||
{{! Tell CSS about our theme }}
|
{{! Tell CSS about our theme }}
|
||||||
<DataSource @src={{uri 'settings://consul:theme' }} as |source|>
|
<DataSource @src={{uri 'settings://consul:theme'}} as |source|>
|
||||||
{{#each-in source.data as |key value|}}
|
{{#each-in source.data as |key value|}}
|
||||||
{{#if (and value (includes key (array "color-scheme" "contrast")))}}
|
{{#if (and value (includes key (array 'color-scheme' 'contrast')))}}
|
||||||
{{document-attrs class=(concat 'prefers-' key '-' value)}}
|
{{document-attrs class=(concat 'prefers-' key '-' value)}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
{{/each-in}}
|
{{/each-in}}
|
||||||
</DataSource>
|
</DataSource>
|
||||||
|
|
||||||
{{! If ACLs are enabled try get a token }}
|
{{! If ACLs are enabled try get a token }}
|
||||||
{{#if (can "use acls")}}
|
{{#if (can 'use acls')}}
|
||||||
<DataSource @src={{uri 'settings://consul:token' }} @onchange={{action (mut token) value="data" }} />
|
<DataSource
|
||||||
|
@src={{uri 'settings://consul:token'}}
|
||||||
|
@onchange={{action (mut token) value='data'}}
|
||||||
|
/>
|
||||||
{{/if}}
|
{{/if}}
|
||||||
|
|
||||||
|
|
||||||
{{#if (not-eq route.currentName 'oauth-provider-debug')}}
|
{{#if (not-eq route.currentName 'oauth-provider-debug')}}
|
||||||
|
|
||||||
{{! redirect if we aren't on a URL with dc information }}
|
{{! redirect if we aren't on a URL with dc information }}
|
||||||
{{#if (eq route.currentName 'index')}}
|
{{#if (eq route.currentName 'index')}}
|
||||||
{{! until we get to the dc route we don't know any permissions }}
|
{{! until we get to the dc route we don't know any permissions }}
|
||||||
{{! as we don't know the dc, any inital permission based }}
|
{{! as we don't know the dc, any inital permission based }}
|
||||||
{{! redirects are in the dc.show route}}
|
{{! redirects are in the dc.show route}}
|
||||||
|
|
||||||
{{! 2022-04-15: Temporarily reverting the services page to the default }}
|
{{! 2022-04-15: Temporarily reverting the services page to the default }}
|
||||||
{{did-insert (route-action 'replaceWith' 'dc.services.index'
|
{{did-insert
|
||||||
(hash
|
(route-action 'replaceWith' 'dc.services.index' (hash dc=(env 'CONSUL_DATACENTER_LOCAL')))
|
||||||
dc=(env 'CONSUL_DATACENTER_LOCAL')
|
}}
|
||||||
)
|
{{else}}
|
||||||
)}}
|
{{! If we are notfound, guess the params we need }}
|
||||||
{{else}}
|
{{#if (eq route.currentName 'notfound')}}
|
||||||
{{! If we are notfound, guess the params we need }}
|
<DataSource
|
||||||
{{#if (eq route.currentName 'notfound')}}
|
@src={{uri '/*/*/*/notfound/${path}' (hash path=route.params.notfound)}}
|
||||||
<DataSource @src={{uri '/*/*/*/notfound/${path}' (hash path=route.params.notfound ) }} @onchange={{action (mut
|
@onchange={{action (mut notfound) value='data'}}
|
||||||
notfound) value="data" }} />
|
/>
|
||||||
{{/if}}
|
|
||||||
|
|
||||||
{{! Make sure we guess and default to the right params when not found }}
|
|
||||||
{{#let
|
|
||||||
(if (can "use partitions") (or route.params.partition notfound.partition token.Partition '') '')
|
|
||||||
(if (can "use nspaces") (or route.params.nspace notfound.nspace token.Namespace '') '')
|
|
||||||
as |partition nspace|}}
|
|
||||||
|
|
||||||
{{! Make sure we have enough to show the app chrome}}
|
|
||||||
{{! Don't show anything until we have a list of DCs }}
|
|
||||||
<DataSource @src={{uri '/*/*/*/datacenters' }} as |dcs|>
|
|
||||||
{{! Once we have a list of DCs make sure the DC we are asking for exists }}
|
|
||||||
{{! If not use the DC that the UI is running in }}
|
|
||||||
{{#let
|
|
||||||
|
|
||||||
(or
|
|
||||||
|
|
||||||
(if nofound.dc
|
|
||||||
(object-at 0 (cached-model
|
|
||||||
'dc'
|
|
||||||
(hash
|
|
||||||
Name=notfound.dc
|
|
||||||
)
|
|
||||||
)
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
(object-at 0 (cached-model
|
|
||||||
'dc'
|
|
||||||
(hash
|
|
||||||
Name=route.params.dc
|
|
||||||
)
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
(hash
|
|
||||||
Name=(env "CONSUL_DATACENTER_LOCAL")
|
|
||||||
)
|
|
||||||
|
|
||||||
)
|
|
||||||
|
|
||||||
dcs.data
|
|
||||||
|
|
||||||
as |dc dcs|}}
|
|
||||||
{{#if (and (gt dc.Name.length 0) dcs)}}
|
|
||||||
|
|
||||||
{{! figure out our current DC and convert it to a model }}
|
|
||||||
<DataSource @src={{uri '/${partition}/*/${dc}/datacenter-cache/${name}' (hash dc=dc.Name partition=partition
|
|
||||||
name=dc.Name ) }} as |dc|>
|
|
||||||
{{#if dc.data}}
|
|
||||||
<HashicorpConsul id="wrapper" @dcs={{dcs}} @dc={{dc.data}} @partition={{partition}} @nspace={{nspace}}
|
|
||||||
@user={{hash token=token }} @onchange={{action "reauthorize" }} as |consul|>
|
|
||||||
|
|
||||||
{{#if error}}
|
|
||||||
{{! If we got an error from anything, show an error page }}
|
|
||||||
<AppError @error={{error}} @login={{consul.login.open}} />
|
|
||||||
{{else}}
|
|
||||||
{{! Otherwise show the rest of the app}}
|
|
||||||
<Outlet @name="application" @model={{hash app=consul user=(hash token=token ) dc=dc.data dcs=dcs }} as |o|>
|
|
||||||
{{outlet}}
|
|
||||||
</Outlet>
|
|
||||||
|
|
||||||
{{! loading component for when we need it}}
|
|
||||||
<Consul::Loader class="view-loader" />
|
|
||||||
{{/if}}
|
|
||||||
|
|
||||||
</HashicorpConsul>
|
|
||||||
{{/if}}
|
{{/if}}
|
||||||
</DataSource>
|
|
||||||
|
{{! Make sure we guess and default to the right params when not found }}
|
||||||
|
{{#let
|
||||||
|
(if
|
||||||
|
(can 'use partitions')
|
||||||
|
(or route.params.partition notfound.partition token.Partition '')
|
||||||
|
''
|
||||||
|
)
|
||||||
|
(if (can 'use nspaces') (or route.params.nspace notfound.nspace token.Namespace '') '')
|
||||||
|
as |partition nspace|
|
||||||
|
}}
|
||||||
|
|
||||||
|
{{! Make sure we have enough to show the app chrome}}
|
||||||
|
{{! Don't show anything until we have a list of DCs }}
|
||||||
|
<DataSource @src={{uri '/*/*/*/datacenters'}} as |dcs|>
|
||||||
|
{{! Once we have a list of DCs make sure the DC we are asking for exists }}
|
||||||
|
{{! If not use the DC that the UI is running in }}
|
||||||
|
{{#let
|
||||||
|
(or
|
||||||
|
(if nofound.dc (object-at 0 (cached-model 'dc' (hash Name=notfound.dc))))
|
||||||
|
(object-at 0 (cached-model 'dc' (hash Name=route.params.dc)))
|
||||||
|
(hash Name=(env 'CONSUL_DATACENTER_LOCAL'))
|
||||||
|
)
|
||||||
|
dcs.data
|
||||||
|
as |dc dcs|
|
||||||
|
}}
|
||||||
|
{{#if (and (gt dc.Name.length 0) dcs)}}
|
||||||
|
|
||||||
|
{{! figure out our current DC and convert it to a model }}
|
||||||
|
<DataSource
|
||||||
|
@src={{uri
|
||||||
|
'/${partition}/*/${dc}/datacenter-cache/${name}'
|
||||||
|
(hash dc=dc.Name partition=partition name=dc.Name)
|
||||||
|
}}
|
||||||
|
as |dc|
|
||||||
|
>
|
||||||
|
{{#if dc.data}}
|
||||||
|
<HashicorpConsul
|
||||||
|
id='wrapper'
|
||||||
|
@dcs={{dcs}}
|
||||||
|
@dc={{dc.data}}
|
||||||
|
@partition={{partition}}
|
||||||
|
@nspace={{nspace}}
|
||||||
|
@user={{hash token=token}}
|
||||||
|
@onchange={{action 'reauthorize'}}
|
||||||
|
as |consul|
|
||||||
|
>
|
||||||
|
|
||||||
|
{{#if error}}
|
||||||
|
{{! If we got an error from anything, show an error page }}
|
||||||
|
<AppError @error={{error}} @login={{consul.login.open}} />
|
||||||
|
{{else}}
|
||||||
|
{{! Otherwise show the rest of the app}}
|
||||||
|
<Outlet
|
||||||
|
@name='application'
|
||||||
|
@model={{hash app=consul user=(hash token=token) dc=dc.data dcs=dcs}}
|
||||||
|
as |o|
|
||||||
|
>
|
||||||
|
{{outlet}}
|
||||||
|
</Outlet>
|
||||||
|
|
||||||
|
{{! loading component for when we need it}}
|
||||||
|
<Consul::Loader class='view-loader' />
|
||||||
|
{{/if}}
|
||||||
|
|
||||||
|
</HashicorpConsul>
|
||||||
|
{{/if}}
|
||||||
|
</DataSource>
|
||||||
|
{{/if}}
|
||||||
|
{{/let}}
|
||||||
|
</DataSource>
|
||||||
|
{{/let}}
|
||||||
{{/if}}
|
{{/if}}
|
||||||
{{/let}}
|
|
||||||
</DataSource>
|
|
||||||
{{/let}}
|
|
||||||
{{/if}}
|
|
||||||
{{else}}
|
{{else}}
|
||||||
{{! Routes with no main navigation }}
|
{{! Routes with no main navigation }}
|
||||||
<Outlet @name="application" @model={{hash user=(hash token=token ) }} as |o|>
|
<Outlet @name='application' @model={{hash user=(hash token=token)}} as |o|>
|
||||||
{{outlet}}
|
{{outlet}}
|
||||||
</Outlet>
|
</Outlet>
|
||||||
{{/if}}
|
{{/if}}
|
||||||
</Route>
|
</Route>
|
||||||
|
|
Loading…
Reference in New Issue