91 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
{{define "page-content"}}
 | 
						|
<h2>{{.Title}}</h2>
 | 
						|
 | 
						|
<form class="flex flex-col gap-4" hx-encoding="multipart/form-data">
 | 
						|
    <div class="grid grid-cols-1 md:grid-cols-2 gap-4">
 | 
						|
        {{template "profile-pic-template" .}}
 | 
						|
 | 
						|
        <div>
 | 
						|
            <label for="username">Benutzername</label>
 | 
						|
            <input class="w-full" required name="username" type="text" {{if lt .Role 4}}value="{{.UserName}}" {{end}} />
 | 
						|
        </div>
 | 
						|
 | 
						|
        <div>
 | 
						|
            <label for="password">Passwort</label>
 | 
						|
            <input class="w-full" required name="password" placeholder="***" type="password" />
 | 
						|
        </div>
 | 
						|
 | 
						|
        <div>
 | 
						|
            <label for="password2">Passwort wiederholen</label>
 | 
						|
            <input class="w-full" required name="password2" placeholder="***" type="password" />
 | 
						|
        </div>
 | 
						|
 | 
						|
        <div>
 | 
						|
            <label for="first-name">Vorname</label>
 | 
						|
            <input class="w-full" required name="first-name" type="text" {{if lt .Role 4}}value="{{.FirstName}}"
 | 
						|
                {{end}} />
 | 
						|
        </div>
 | 
						|
 | 
						|
        <div>
 | 
						|
            <label for="last-name">Nachname</label>
 | 
						|
            <input class="w-full" required name="last-name" type="text" {{if lt .Role 4}}value="{{.LastName}}"
 | 
						|
                {{end}} />
 | 
						|
        </div>
 | 
						|
 | 
						|
        <div>
 | 
						|
            <label for="email">Emailadresse</label>
 | 
						|
            <input class="w-full" required name="email" type="text" {{if lt .Role 4}}value="{{.Email}}" {{end}} />
 | 
						|
        </div>
 | 
						|
 | 
						|
        <div>
 | 
						|
            <label for="email2">Emailadresse wiederholen</label>
 | 
						|
            <input class="w-full" required name="email2" type="text" {{if lt .Role 4}}value="{{.Email}}" {{end}} />
 | 
						|
        </div>
 | 
						|
    </div>
 | 
						|
 | 
						|
    {{if lt .Role 4}}
 | 
						|
    <div class="flex flex-wrap gap-4">
 | 
						|
        <div>
 | 
						|
            <input required id="author" name="role" type="radio" value="3" {{if eq .Role 3}}checked{{end}} />
 | 
						|
            <label for="author">Autor</label>
 | 
						|
        </div>
 | 
						|
        <div>
 | 
						|
            <input required id="editor" name="role" type="radio" value="2" {{if eq .Role 2}}checked{{end}} />
 | 
						|
            <label for="editor">Redakteur</label>
 | 
						|
        </div>
 | 
						|
        <div>
 | 
						|
            <input required id="publisher" name="role" type="radio" value="1" {{if eq .Role 1}}checked{{end}} />
 | 
						|
            <label for="publisher">Herausgeber</label>
 | 
						|
        </div>
 | 
						|
        <div>
 | 
						|
            <input required id="admin" name="role" type="radio" value="0" {{if eq .Role 0}}checked{{end}} />
 | 
						|
            <label for="admin">Administrator</label>
 | 
						|
        </div>
 | 
						|
    </div>
 | 
						|
    {{end}}
 | 
						|
 | 
						|
    <div class="btn-area">
 | 
						|
        <input class="action-btn" type="submit" value="{{.ButtonText}}" hx-post="{{.URL}}" hx-target="#page-content" />
 | 
						|
        <button class="btn" hx-get="/hub" hx-target="#page-content">Abbrechen</button>
 | 
						|
    </div>
 | 
						|
</form>
 | 
						|
{{end}}
 | 
						|
 | 
						|
{{define "profile-pic-template"}}
 | 
						|
<div class="flex items-center justify-center row-span-3 self-center" id="profile-pic-container">
 | 
						|
    <label
 | 
						|
        class="bg-slate-200 dark:bg-slate-800 hover:bg-slate-100 dark:hover:bg-slate-900 border border-slate-200 dark:border-slate-800 cursor-pointer flex flex-col h-48 items-center justify-center overflow-hidden rounded-full w-48"
 | 
						|
        for="upload-profile-pic">
 | 
						|
        {{if gt (len .Image) 0}}
 | 
						|
        <img src="/image/serve/{{.Image}}" alt="" />
 | 
						|
        {{else}}
 | 
						|
        <span class="text-2xl">+</span>
 | 
						|
        <span>Profilbild</span>
 | 
						|
        {{end}}
 | 
						|
    </label>
 | 
						|
    <input class="hidden" id="upload-profile-pic" name="upload-profile-pic" type="file"
 | 
						|
        hx-post="/user/upload-profile-pic" hx-swap="outerHTML" hx-target="#profile-pic-container" />
 | 
						|
    <input id="profile-pic-url" name="profile-pic-url" type="hidden" value="{{.Image}}" />
 | 
						|
</div>
 | 
						|
{{end}}
 |