form.hbs 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. <form id="login-signup" hx-post="/api/auth/login" hx-swap="outerHTML">
  2. <label class="{{#if errors.email}}error{{/if}}">
  3. Email address:
  4. <input
  5. name="email"
  6. id="email"
  7. type="email"
  8. autofocus="true"
  9. placeholder="Email address..."
  10. hx-preserve="true"
  11. />
  12. {{#if errors.email}}<p class="error">{{errors.email}}</p>{{/if}}
  13. </label>
  14. <label class="{{#if errors.password}}error{{/if}}">
  15. Password:
  16. <input
  17. name="password"
  18. id="password"
  19. type="password"
  20. placeholder="Password..."
  21. hx-preserve="true"
  22. />
  23. {{#if errors.password}}<p class="error">{{errors.password}}</p>{{/if}}
  24. </label>
  25. <div class="buttons-wrapper">
  26. <button type="submit" class="primary login">
  27. <span>{{> icons/login}}</span>
  28. <span>{{> icons/spinner}}</span>
  29. Log in
  30. </button>
  31. {{#unless disallow_registration}}
  32. <button
  33. type="button"
  34. class="secondary signup"
  35. hx-post="/api/auth/signup"
  36. hx-target="#login-signup"
  37. hx-trigger="click"
  38. hx-indicator="#login-signup"
  39. hx-swap="outerHTML"
  40. hx-sync="closest form"
  41. hx-on:htmx:before-request="htmx.addClass('#login-signup', 'signup')"
  42. hx-on:htmx:after-request="htmx.removeClass('#login-signup', 'signup')"
  43. >
  44. <span>{{> icons/new_user}}</span>
  45. <span>{{> icons/spinner}}</span>
  46. Sign up
  47. </button>
  48. {{/unless}}
  49. </div>
  50. <a class="forgot-password" href="/reset-password" title="Reset password">Forgot your password?</a>
  51. {{#unless errors}}
  52. {{#if error}}
  53. <p class="error">{{error}}</p>
  54. {{/if}}
  55. {{/unless}}
  56. </form>