Monorepo for Tangled tangled.org
8

Configure Feed

Select the types of activity you want to include in your feed.

1{{ define "title" }}Login &middot; Tangled{{ end }} 2 3{{ define "content" }} 4 {{ if .AddAccount }} 5 <div class="flex gap-2 my-4 bg-blue-50 dark:bg-blue-900/30 border border-blue-300 dark:border-sky-800 rounded px-3 py-2 text-blue-600 dark:text-blue-300"> 6 <span class="py-1">{{ i "user-plus" "w-4 h-4" }}</span> 7 <div> 8 <h5 class="font-medium">Add another account</h5> 9 <p class="text-sm">Sign in with a different account to add it to your account list.</p> 10 </div> 11 </div> 12 {{ end }} 13 14 {{ if .Accounts }} 15 <div class="my-4 border border-gray-200 dark:border-gray-700 rounded overflow-hidden"> 16 <div class="px-3 py-2 bg-gray-50 dark:bg-gray-800 border-b border-gray-200 dark:border-gray-700"> 17 <span class="text-xs text-gray-500 dark:text-gray-400 tracking-wide font-medium">Saved accounts</span> 18 </div> 19 <div class="divide-y divide-gray-200 dark:divide-gray-700"> 20 {{ range .Accounts }} 21 <div class="flex items-center justify-between px-3 py-2 hover:bg-gray-100 dark:hover:bg-gray-700"> 22 <button 23 type="button" 24 hx-post="/account/switch" 25 hx-include="this" 26 hx-swap="none" 27 class="flex items-center gap-2 flex-1 text-left min-w-0" 28 > 29 {{ $returnUrl := (or $.ReturnUrl "/") }} 30 <input type="hidden" name="did" value="{{ .Did }}"> 31 <input type="hidden" name="return_url" value="{{ $returnUrl }}"> 32 {{ template "user/fragments/pic" (list .Did "size-8") }} 33 <div class="flex flex-col min-w-0"> 34 <span class="text-sm font-medium dark:text-white truncate">{{ .Did | resolve | truncateAt30 }}</span> 35 <span class="text-xs text-gray-500 dark:text-gray-400">Click to switch</span> 36 </div> 37 </button> 38 <button 39 type="button" 40 hx-delete="/account/{{ .Did }}" 41 hx-swap="none" 42 class="p-1 text-gray-400 hover:text-red-500 dark:hover:text-red-400 flex-shrink-0" 43 title="Remove account" 44 > 45 {{ i "x" "w-4 h-4" }} 46 </button> 47 </div> 48 {{ end }} 49 </div> 50 </div> 51 {{ end }} 52 53 <form 54 class="mt-4 group" 55 hx-post="/login" 56 hx-swap="none" 57 hx-disabled-elt="#login-button" 58 > 59 <div class="flex flex-col"> 60 <label for="handle">Handle</label> 61 <input 62 autocapitalize="none" 63 autocorrect="off" 64 autocomplete="username" 65 type="text" 66 id="handle" 67 inputmode="url" 68 name="handle" 69 tabindex="1" 70 required 71 placeholder="akshay.tngl.sh" 72 class="text-lg md:text-base" 73 /> 74 <span class="text-sm text-gray-500 mt-1"> 75 Use your <a href="https://atproto.com">AT Protocol</a> 76 handle to log in. If you're unsure, this is likely 77 your Tangled (<code>.tngl.sh</code>) or <a href="https://bsky.app">Bluesky</a> (<code>.bsky.social</code>) account. 78 </span> 79 </div> 80 <input type="hidden" name="return_url" value="{{ .ReturnUrl }}"> 81 82 <button 83 class="btn w-full my-2 mt-6 text-base" 84 type="submit" 85 id="login-button" 86 tabindex="3" 87 > 88 {{ i "loader-circle" "size-4 animate-spin hidden group-[.htmx-request]:inline" }} 89 <span class="inline group-[.htmx-request]:hidden">Login</span> 90 </button> 91 </form> 92 {{ if .ErrorCode }} 93 <div class="flex gap-2 my-2 bg-red-50 dark:bg-red-900 border border-red-500 rounded drop-shadow-sm px-3 py-2 text-red-500 dark:text-red-300"> 94 <span class="py-1">{{ i "circle-alert" "w-4 h-4" }}</span> 95 <div> 96 <h5 class="font-medium">Login error</h5> 97 <p class="text-sm"> 98 {{ if eq .ErrorCode "access_denied" }} 99 You have not authorized the app. 100 {{ else if eq .ErrorCode "session" }} 101 Server failed to create user session. 102 {{ else if eq .ErrorCode "max_accounts" }} 103 You have reached the maximum of 20 linked accounts. Please remove an account before adding a new one. 104 {{ else }} 105 Internal Server error. 106 {{ end }} 107 Please try again. 108 </p> 109 </div> 110 </div> 111 {{ end }} 112 <p class="text-sm text-gray-500"> 113 Don't have an account? <a href="/signup" class="underline">Create an account</a> on Tangled now! 114 </p> 115 116 <p id="login-msg" class="error w-full"></p> 117{{ end }}