{{title 'Key/Value'}} {{#let (or sortBy "isFolder:asc") as |sort|}} <AppView> <BlockSlot @name="breadcrumbs"> <ol> {{#if (not-eq parent.Key '/') }} <li><a href={{href-to 'dc.kv'}}>Key / Values</a></li> {{/if}} {{#each (slice 0 -2 (split parent.Key '/')) as |breadcrumb index|}} <li><a href={{href-to 'dc.kv.folder' (join '/' (append (slice 0 (add index 1) (split parent.Key '/')) ''))}}>{{breadcrumb}}</a></li> {{/each}} </ol> </BlockSlot> <BlockSlot @name="header"> <h1> {{#if (eq parent.Key '/')}} Key / Value {{else}} {{take 1 (drop 1 (reverse (split parent.Key '/')))}} {{/if}} </h1> <label for="toolbar-toggle"></label> </BlockSlot> <BlockSlot @name="toolbar"> {{#if (gt items.length 0) }} <form class="filter-bar with-sort"> <FreetextFilter @onsearch={{action (mut search) value="target.value"}} @value={{search}} @placeholder="Search" /> <div class="sort"> <PopoverSelect class="type-sort" @position="right" @onchange={{action (mut sortBy) value='target.selected'}} @multiple={{false}} as |components|> <BlockSlot @name="selected"> <span> {{#let (from-entries (array (array "Key:asc" "A to Z") (array "Key:desc" "Z to A") (array "isFolder:desc" "Folders to Keys") (array "isFolder:asc" "Keys to Folders") )) as |selectable| }} {{get selectable sort}} {{/let}} </span> </BlockSlot> <BlockSlot @name="options"> {{#let components.Optgroup components.Option as |Optgroup Option|}} <Optgroup @label="Name"> <Option @value="Key:asc" @selected={{eq "Key:asc" sort}}>A to Z</Option> <Option @value="Key:desc" @selected={{eq "Key:desc" sort}}>Z to A</Option> </Optgroup> <Optgroup @label="Type"> <Option @value="isFolder:desc" @selected={{eq "isFolder:desc" sort}}>Folders to Keys</Option> <Option @value="isFolder:asc" @selected={{eq "isFolder:asc" sort}}>Keys to Folders</Option> </Optgroup> {{/let}} </BlockSlot> </PopoverSelect> </div> </form> {{/if}} </BlockSlot> <BlockSlot @name="actions"> {{#if (not-eq parent.Key '/') }} <a data-test-create href="{{href-to 'dc.kv.create' parent.Key}}" class="type-create">Create</a> {{else}} <a data-test-create href="{{href-to 'dc.kv.root-create'}}" class="type-create">Create</a> {{/if}} </BlockSlot> <BlockSlot @name="content"> {{#let (sort-by (comparator 'kv' sort) items) as |sorted|}} <ChangeableSet @dispatcher={{searchable 'kv' sorted}} @terms={{search}}> <BlockSlot @name="content" as |filtered|> <ConsulKvList @items={{filtered}} @parent={{parent}} @ondelete={{refresh-route}} > <EmptyState @allowLogin={{true}}> <BlockSlot @name="header"> <h2> {{#if (gt items.length 0)}} No K/V pairs found {{else}} Welcome to Key/Value {{/if}} </h2> </BlockSlot> <BlockSlot @name="body"> <p> {{#if (gt items.length 0)}} No K/V pairs where found matching that search, or you may not have access to view the K/V pairs you are searching for. {{else}} You don't have any K/V pairs, or you may not have access to view K/V pairs yet. {{/if}} </p> </BlockSlot> <BlockSlot @name="actions"> <li class="docs-link"> <a href="{{env 'CONSUL_DOCS_URL'}}/agent/kv" rel="noopener noreferrer" target="_blank">Documentation on K/V</a> </li> <li class="learn-link"> <a href="{{env 'CONSUL_DOCS_LEARN_URL'}}/consul/getting-started/kv" rel="noopener noreferrer" target="_blank">Read the guide</a> </li> </BlockSlot> </EmptyState> </ConsulKvList> </BlockSlot> </ChangeableSet> {{/let}} </BlockSlot> </AppView> {{/let}}