<Route
  @name={{routeName}}
as |route|>
  <DataLoader @src={{
    uri '/${partition}/${nspace}/${dc}/token/${id}'
      (hash
        partition=route.params.partition
        nspace=route.params.nspace
        dc=route.params.dc
        id=(or route.params.id '')
      )
    }}
  as |loader|>

    <BlockSlot @name="error">
      {{#if (eq loader.error.status '401')}}
        <Consul::Acl::Disabled />
      {{else}}
        <AppError
          @error={{loader.error}}
          @login={{route.model.app.login.open}}
        />
      {{/if}}
    </BlockSlot>

    <BlockSlot @name="loaded">
{{#let

  route.params.dc
  route.params.partition
  route.params.nspace

  loader.data
  loader.data.isNew
as |dc partition nspace item create|}}
  <AppView
    @login={{route.model.app.login.open}}
  >
      <BlockSlot @name="breadcrumbs">
          <ol>
              <li><a data-test-back href={{href-to 'dc.acls.tokens'}}>All Tokens</a></li>
          </ol>
      </BlockSlot>
      <BlockSlot @name="header">
          <h1>
    {{#if create}}
              <route.Title @title="New Token" />
    {{else}}
              <route.Title @title="Edit Token" />
    {{/if}}
          </h1>
      </BlockSlot>
      <BlockSlot @name="actions">
  {{#if (not create)}}
    {{#if (not-eq item.AccessorID token.AccessorID)}}
        <ConfirmationDialog @message="Are you sure you want to use this ACL token?">
          <BlockSlot @name="action" as |confirm|>
              <button data-test-use type="button" {{ action confirm 'use' item }}>Use</button>
          </BlockSlot>
          <BlockSlot @name="dialog" as |execute cancel message|>
            <p>
                {{message}}
            </p>
            <button type="button" class="type-delete" {{action execute}}>Confirm Use</button>
            <button type="button" class="type-cancel" {{action cancel}}>Cancel</button>
          </BlockSlot>
        </ConfirmationDialog>
    {{/if}}
    {{#if (can "duplicate token" item=item)}}
        <button data-test-clone type="button" {{ action "clone" item }}>Duplicate</button>
    {{/if}}
  {{/if}}
      </BlockSlot>
      <BlockSlot @name="content">
          {{#if (token/is-legacy item)}}
            <Notice
              @type="info"
            as |notice|>
              <notice.Header>
                <h2>Update</h2>
              </notice.Header>
              <notice.Body>
                <p>
                  We have upgraded our ACL system by allowing you to create reusable policies which you can then apply to tokens. Don't worry, even though this token was written in the old style, it is still valid. However, we do recommend upgrading your old tokens to the new style. Learn how in our <a href="{{env 'CONSUL_DOCS_URL'}}/guides/acl-migrate-tokens.html" target="_blank" rel="noopener noreferrer">documentation</a>.
                </p>
              </notice.Body>
            </Notice>
          {{/if}}
  {{#if (not create) }}
        <div class="definition-table">
            <dl>
              <dt>AccessorID</dt>
              <dd>
                <CopyButton @value={{item.AccessorID}} @name="AccessorID" @position="top-start" /> {{item.AccessorID}}
              </dd>
              <dt>Token</dt>
              <dd>
                <CopyButton @value={{item.SecretID}} @name="Token" @position="top-start" /> <SecretButton>{{item.SecretID}}</SecretButton>
              </dd>
  {{#if (and (not (token/is-legacy item)) (not create))}}
              <dt>Scope</dt>
              <dd>
                {{if item.Local 'local' 'global' }}
              </dd>
  {{/if}}
            </dl>
        </div>
  {{/if}}
          {{ partial 'dc/acls/tokens/form'}}
      </BlockSlot>
  </AppView>
{{/let}}
    </BlockSlot>
  </DataLoader>
</Route>