<SettingsLayout page='settings/instances/add' label="Add instance">
  <h1 id="add-an-instance-h1">Add instance</h1>

  <form class="add-new-instance" on:submit='onSubmit(event)' aria-labelledby="add-an-instance-h1">

    {{#if $logInToInstanceError && $logInToInstanceErrorForText === $instanceNameInSearch}}
    <div class="form-error form-error-user-error" role="alert">
      Error: {{$logInToInstanceError}}
    </div>
    {{/if}}

    <noscript>
      <div class="form-error" role="alert">
        You must enable JavaScript to log in.
      </div>
    </noscript>

    <label for="instanceInput">Instance:</label>
    <input class="new-instance-input" type="text" id="instanceInput"
           bind:value='$instanceNameInSearch' placeholder='' required
    >
    <button class="primary" type="submit" id="submitButton"
            disabled={{!$instanceNameInSearch || $logInToInstanceLoading}}>
      Add instance
    </button>
  </form>

  {{#if !$isUserLoggedIn}}
  <p>Don't have an instance? <ExternalLink href="https://joinmastodon.org">Join Mastodon!</ExternalLink></p>
  {{/if}}
</SettingsLayout>
<style>
  .form-error {
    border: 2px solid red;
    border-radius: 2px;
    padding: 10px;
    font-size: 1.3em;
    margin: 5px;
    background-color: var(--main-bg);
  }
  input.new-instance-input {
    min-width: 60%;
    max-width: 100%;
  }

  form.add-new-instance {
    background: var(--form-bg);
    padding: 5px 10px 15px;
    margin: 20px auto;
    border: 1px solid var(--form-border);
    border-radius: 4px;
  }

  form.add-new-instance label, form.add-new-instance input, form.add-new-instance button {
    display: block;
    margin: 20px 5px;
  }
</style>
<script>
  import SettingsLayout from '../../../_components/settings/SettingsLayout.html'
  import { store } from '../../../_store/store'
  import { logInToInstance, handleOauthCode } from '../../../_actions/addInstance'
  import ExternalLink from '../../../_components/ExternalLink.html'

  export default {
    async oncreate () {
      let codeMatch = location.search.match(/code=([^&]+)/)
      if (codeMatch) {
        handleOauthCode(codeMatch[1])
      }
    },
    components: {
      SettingsLayout,
      ExternalLink
    },
    store: () => store,
    methods: {
      onSubmit (event) {
        event.preventDefault()
        logInToInstance()
      }
    }
  }
</script>