summaryrefslogtreecommitdiffstats
path: root/templates
diff options
context:
space:
mode:
authorOtto <otto@codeberg.org>2024-12-30 21:28:36 +0100
committerOtto <otto@codeberg.org>2024-12-30 21:28:36 +0100
commit7bb043ce9b841ff7af28f3f1f3eff73da822034b (patch)
tree2a62412571a1aa41907ce9893d88578e7db955c8 /templates
parentMerge pull request 'Update code.forgejo.org/oci/alpine Docker tag to v3.21 (f... (diff)
parentRework user profile settings (diff)
downloadforgejo-7bb043ce9b841ff7af28f3f1f3eff73da822034b.tar.xz
forgejo-7bb043ce9b841ff7af28f3f1f3eff73da822034b.zip
Merge pull request 'Rework user profile settings' (#6407) from fnetx/profile-a11y into forgejo
Reviewed-on: https://codeberg.org/forgejo/forgejo/pulls/6407 Reviewed-by: Gusted <gusted@noreply.codeberg.org>
Diffstat (limited to 'templates')
-rw-r--r--templates/user/settings/account.tmpl2
-rw-r--r--templates/user/settings/profile.tmpl207
2 files changed, 102 insertions, 107 deletions
diff --git a/templates/user/settings/account.tmpl b/templates/user/settings/account.tmpl
index a97136f407..55431392c7 100644
--- a/templates/user/settings/account.tmpl
+++ b/templates/user/settings/account.tmpl
@@ -40,9 +40,9 @@
</h4>
<div class="ui attached segment">
<div class="ui list">
+ <div class="tw-mb-2">{{ctx.Locale.Tr "settings.email_desc"}}</div>
{{if $.EnableNotifyMail}}
<div class="item">
- <div class="tw-mb-2">{{ctx.Locale.Tr "settings.email_desc"}}</div>
<form action="{{AppSubUrl}}/user/settings/account/email" class="ui form" method="post">
{{$.CsrfTokenHtml}}
<input name="_method" type="hidden" value="NOTIFICATION">
diff --git a/templates/user/settings/profile.tmpl b/templates/user/settings/profile.tmpl
index a007380387..5ecaada4e2 100644
--- a/templates/user/settings/profile.tmpl
+++ b/templates/user/settings/profile.tmpl
@@ -4,126 +4,121 @@
{{ctx.Locale.Tr "settings.public_profile"}}
</h4>
<div class="ui attached segment">
- <p>{{ctx.Locale.Tr "settings.profile_desc"}}</p>
<form class="ui form" action="{{.Link}}" method="post">
{{.CsrfTokenHtml}}
- <div class="required field {{if .Err_Name}}error{{end}}">
- <label for="username">{{ctx.Locale.Tr "username"}}
- <span class="text red tw-hidden" id="name-change-prompt"> {{ctx.Locale.Tr "settings.change_username_prompt"}}</span>
- <span class="text red tw-hidden" id="name-change-redirect-prompt"> {{ctx.Locale.Tr "settings.change_username_redirect_prompt"}}</span>
+ <fieldset>
+ <legend>{{ctx.Locale.Tr "settings.profile_desc"}}</legend>
+ <label {{if .Err_Name}}class="field error"{{end}}>
+ {{ctx.Locale.Tr "username"}}
+ <input name="name" value="{{.SignedUser.Name}}" data-name="{{.SignedUser.Name}}" autofocus required {{if or (not .SignedUser.IsLocal) .IsReverseProxy}}disabled{{end}} maxlength="40">
+ {{if or (not .SignedUser.IsLocal) .IsReverseProxy}}
+ <span class="help">{{ctx.Locale.Tr "settings.password_username_disabled"}}</span>
+ {{else}}
+ <span class="help">
+ {{ctx.Locale.Tr "settings.change_username_prompt"}}
+ {{ctx.Locale.Tr "settings.change_username_redirect_prompt"}}
+ </span>
+ {{end}}
</label>
- <input id="username" name="name" value="{{.SignedUser.Name}}" data-name="{{.SignedUser.Name}}" autofocus required {{if or (not .SignedUser.IsLocal) .IsReverseProxy}}disabled{{end}} maxlength="40">
- {{if or (not .SignedUser.IsLocal) .IsReverseProxy}}
- <p class="help text blue">{{ctx.Locale.Tr "settings.password_username_disabled"}}</p>
- {{end}}
- </div>
- <div class="field {{if .Err_FullName}}error{{end}}">
- <label for="full_name">{{ctx.Locale.Tr "settings.full_name"}}</label>
- <input id="full_name" name="full_name" value="{{.SignedUser.FullName}}" maxlength="100">
- </div>
- <div class="inline field">
- <span class="inline field"><label for="pronouns">{{ctx.Locale.Tr "settings.pronouns"}}</label></span>
- <div id="pronouns-dropdown" style="display: none" class="ui selection dropdown">
- <input type="hidden" value="{{.SignedUser.Pronouns}}">
- <div class="text">
- {{if .PronounsAreCustom}}
- {{ctx.Locale.Tr "settings.pronouns_custom"}}
- {{else if eq "" .SignedUser.Pronouns}}
- {{ctx.Locale.Tr "settings.pronouns_unspecified"}}
- {{else}}
- {{.SignedUser.Pronouns}}
- {{end}}
- </div>
- {{svg "octicon-triangle-down" 14 "dropdown icon"}}
- <div class="menu">
- <div class="item{{if eq "" .SignedUser.Pronouns}} active selected{{end}}" data-value=""><p>{{ctx.Locale.Tr "settings.pronouns_unspecified"}}</p></div>
- <div class="item{{if eq "he/him" .SignedUser.Pronouns}} active selected{{end}}" data-value="he/him">he/him</div>
- <div class="item{{if eq "she/her" .SignedUser.Pronouns}} active selected{{end}}" data-value="she/her">she/her</div>
- <div class="item{{if eq "they/them" .SignedUser.Pronouns}} active selected{{end}}" data-value="they/them">they/them</div>
- <div class="item{{if eq "it/its" .SignedUser.Pronouns}} active selected{{end}}" data-value="it/its">it/its</div>
- <div class="item{{if eq "any pronouns" .SignedUser.Pronouns}} active selected{{end}}" data-value="any pronouns">any pronouns</div>
- {{if .PronounsAreCustom}}
- <div class="item active selected" data-value="{{.SignedUser.Pronouns}}"><p>{{ctx.Locale.Tr "settings.pronouns_custom"}}</p></div>
- {{else}}
- <div class="item" data-value="!"><i>{{ctx.Locale.Tr "settings.pronouns_custom"}}</i></div>
- {{end}}
+
+ <label {{if .Err_FullName}}class="field error"{{end}}>
+ {{ctx.Locale.Tr "settings.full_name"}}
+ <input name="full_name" value="{{.SignedUser.FullName}}" maxlength="100">
+ </label>
+
+ <label id="label-pronouns" class="tw-hidden">
+ {{ctx.Locale.Tr "settings.pronouns"}}
+ <div id="pronouns-dropdown" class="ui selection dropdown" aria-labelledby="label-pronouns">
+ <input type="hidden" value="{{.SignedUser.Pronouns}}">
+ <div class="text">
+ {{if .PronounsAreCustom}}
+ {{ctx.Locale.Tr "settings.pronouns_custom"}}
+ {{else if eq "" .SignedUser.Pronouns}}
+ {{ctx.Locale.Tr "settings.pronouns_unspecified"}}
+ {{else}}
+ {{.SignedUser.Pronouns}}
+ {{end}}
+ </div>
+ {{svg "octicon-triangle-down" 14 "dropdown icon"}}
+ <div class="menu">
+ <div class="item{{if eq "" .SignedUser.Pronouns}} active selected{{end}}" data-value=""><p>{{ctx.Locale.Tr "settings.pronouns_unspecified"}}</p></div>
+ <div class="item{{if eq "he/him" .SignedUser.Pronouns}} active selected{{end}}" data-value="he/him">he/him</div>
+ <div class="item{{if eq "she/her" .SignedUser.Pronouns}} active selected{{end}}" data-value="she/her">she/her</div>
+ <div class="item{{if eq "they/them" .SignedUser.Pronouns}} active selected{{end}}" data-value="they/them">they/them</div>
+ <div class="item{{if eq "it/its" .SignedUser.Pronouns}} active selected{{end}}" data-value="it/its">it/its</div>
+ <div class="item{{if eq "any pronouns" .SignedUser.Pronouns}} active selected{{end}}" data-value="any pronouns">any pronouns</div>
+ {{if .PronounsAreCustom}}
+ <div class="item active selected" data-value="{{.SignedUser.Pronouns}}">{{ctx.Locale.Tr "settings.pronouns_custom"}}</div>
+ {{else}}
+ <div class="item" data-value="!"><i>{{ctx.Locale.Tr "settings.pronouns_custom"}}</i></div>
+ {{end}}
+ </div>
</div>
- </div>
- <input id="pronouns-custom" name="pronouns" value="{{.SignedUser.Pronouns}}" maxlength="50">
- </div>
- {{if not .SignedUser.KeepEmailPrivate}}
- <div class="field">
- <label>{{ctx.Locale.Tr "email"}}</label>
- <p id="signed-user-email">{{.SignedUser.Email}}</p>
- </div>
- {{end}}
- <div class="field {{if .Err_Biography}}error{{end}}">
- <label for="biography">{{ctx.Locale.Tr "user.user_bio"}}</label>
- <textarea id="biography" name="biography" rows="2" placeholder="{{ctx.Locale.Tr "settings.biography_placeholder"}}" maxlength="255">{{.SignedUser.Description}}</textarea>
- </div>
- <div class="field {{if .Err_Website}}error{{end}}">
- <label for="website">{{ctx.Locale.Tr "settings.website"}}</label>
- <input id="website" name="website" type="url" value="{{.SignedUser.Website}}" maxlength="255">
- </div>
- <div class="field">
- <label for="location">{{ctx.Locale.Tr "settings.location"}}</label>
- <input id="location" name="location" placeholder="{{ctx.Locale.Tr "settings.location_placeholder"}}" value="{{.SignedUser.Location}}" maxlength="50">
- </div>
+ </label>
+ <label id="label-pronouns-custom">
+ {{ctx.Locale.Tr "settings.pronouns_custom_label"}}
+ <input name="pronouns" value="{{.SignedUser.Pronouns}}" maxlength="50">
+ </label>
+
+ <label {{if .Err_Biography}}class="field error"{{end}}>
+ {{ctx.Locale.Tr "user.user_bio"}}
+ <textarea name="biography" rows="2" placeholder="{{ctx.Locale.Tr "settings.biography_placeholder"}}" maxlength="255">{{.SignedUser.Description}}</textarea>
+ </label>
- <div class="divider"></div>
- <!-- private block -->
+ <label {{if .Err_Website}}class="field error"{{end}}>
+ {{ctx.Locale.Tr "settings.website"}}
+ <input name="website" type="url" value="{{.SignedUser.Website}}" maxlength="255">
+ </label>
- <div class="field" id="privacy-user-settings">
- <label><strong>{{ctx.Locale.Tr "settings.privacy"}}</strong></label>
- </div>
+ <label>
+ {{ctx.Locale.Tr "settings.location"}}
+ <input name="location" placeholder="{{ctx.Locale.Tr "settings.location_placeholder"}}" value="{{.SignedUser.Location}}" maxlength="50">
+ </label>
+ </fieldset>
- <div class="inline field {{if .Err_Visibility}}error{{end}}">
- <span class="inline required field" id="visibility-setting"><label>{{ctx.Locale.Tr "settings.visibility"}}</label></span>
- <div class="ui selection type dropdown">
- {{if .SignedUser.Visibility.IsPublic}}<input type="hidden" id="visibility" name="visibility" value="0">{{end}}
- {{if .SignedUser.Visibility.IsLimited}}<input type="hidden" id="visibility" name="visibility" value="1">{{end}}
- {{if .SignedUser.Visibility.IsPrivate}}<input type="hidden" id="visibility" name="visibility" value="2">{{end}}
- <div class="text">
- {{if .SignedUser.Visibility.IsPublic}}{{ctx.Locale.Tr "settings.visibility.public"}}{{end}}
- {{if .SignedUser.Visibility.IsLimited}}{{ctx.Locale.Tr "settings.visibility.limited"}}{{end}}
- {{if .SignedUser.Visibility.IsPrivate}}{{ctx.Locale.Tr "settings.visibility.private"}}{{end}}
- </div>
- {{svg "octicon-triangle-down" 14 "dropdown icon"}}
- <div class="menu">
- {{range $mode := .AllowedUserVisibilityModes}}
- {{if $mode.IsPublic}}
- <div class="item" data-tooltip-content="{{ctx.Locale.Tr "settings.visibility.public_tooltip"}}" data-value="0">{{ctx.Locale.Tr "settings.visibility.public"}}</div>
- {{else if $mode.IsLimited}}
- <div class="item" data-tooltip-content="{{ctx.Locale.Tr "settings.visibility.limited_tooltip"}}" data-value="1">{{ctx.Locale.Tr "settings.visibility.limited"}}</div>
- {{else if $mode.IsPrivate}}
- <div class="item" data-tooltip-content="{{ctx.Locale.Tr "settings.visibility.private_tooltip"}}" data-value="2">{{ctx.Locale.Tr "settings.visibility.private"}}</div>
+ <fieldset>
+ <legend id="privacy-user-settings">{{ctx.Locale.Tr "settings.privacy"}}</legend>
+
+ <label id="visibility-setting" {{if .Err_Visibility}}class="field error"{{end}}>
+ {{ctx.Locale.Tr "settings.visibility"}}
+ <div class="ui selection type dropdown" aria-labelledby="visibility-setting">
+ {{if .SignedUser.Visibility.IsPublic}}<input type="hidden" id="visibility" name="visibility" value="0">{{end}}
+ {{if .SignedUser.Visibility.IsLimited}}<input type="hidden" id="visibility" name="visibility" value="1">{{end}}
+ {{if .SignedUser.Visibility.IsPrivate}}<input type="hidden" id="visibility" name="visibility" value="2">{{end}}
+ <div class="text">
+ {{if .SignedUser.Visibility.IsPublic}}{{ctx.Locale.Tr "settings.visibility.public"}}{{end}}
+ {{if .SignedUser.Visibility.IsLimited}}{{ctx.Locale.Tr "settings.visibility.limited"}}{{end}}
+ {{if .SignedUser.Visibility.IsPrivate}}{{ctx.Locale.Tr "settings.visibility.private"}}{{end}}
+ </div>
+ {{svg "octicon-triangle-down" 14 "dropdown icon"}}
+ <div class="menu">
+ {{range $mode := .AllowedUserVisibilityModes}}
+ {{if $mode.IsPublic}}
+ <div class="item" data-tooltip-content="{{ctx.Locale.Tr "settings.visibility.public_tooltip"}}" data-value="0">{{ctx.Locale.Tr "settings.visibility.public"}}</div>
+ {{else if $mode.IsLimited}}
+ <div class="item" data-tooltip-content="{{ctx.Locale.Tr "settings.visibility.limited_tooltip"}}" data-value="1">{{ctx.Locale.Tr "settings.visibility.limited"}}</div>
+ {{else if $mode.IsPrivate}}
+ <div class="item" data-tooltip-content="{{ctx.Locale.Tr "settings.visibility.private_tooltip"}}" data-value="2">{{ctx.Locale.Tr "settings.visibility.private"}}</div>
+ {{end}}
{{end}}
- {{end}}
+ </div>
</div>
- </div>
- </div>
+ </label>
- <div class="field">
- <div class="ui checkbox">
- <label>{{ctx.Locale.Tr "settings.keep_email_private"}}</label>
+ <label>
<input name="keep_email_private" type="checkbox" {{if .SignedUser.KeepEmailPrivate}}checked{{end}}>
- </div>
- <span class="help tw-block">{{ctx.Locale.Tr "settings.keep_email_private_popup" .SignedUser.GetPlaceholderEmail}}</span>
- </div>
+ {{ctx.Locale.Tr "settings.keep_email_private"}}
+ <span class="help">{{ctx.Locale.Tr "settings.keep_email_private_popup" .SignedUser.GetPlaceholderEmail}}</span>
+ </label>
- <div class="field">
- <div class="ui checkbox" id="keep-activity-private">
- <label>{{ctx.Locale.Tr "settings.keep_activity_private"}}</label>
+ <label id="keep-activity-private">
<input name="keep_activity_private" type="checkbox" {{if .SignedUser.KeepActivityPrivate}}checked{{end}}>
- </div>
- <span class="help tw-block">{{ctx.Locale.Tr "settings.keep_activity_private.description" (printf "/%s?tab=activity" .SignedUser.Name)}}</span>
- </div>
-
- <div class="divider"></div>
+ {{ctx.Locale.Tr "settings.keep_activity_private"}}
+ <span class="help">{{ctx.Locale.Tr "settings.keep_activity_private.description" (printf "/%s?tab=activity" .SignedUser.Name)}}</span>
+ </label>
+ </fieldset>
- <div class="field">
- <button class="ui primary button">{{ctx.Locale.Tr "settings.update_profile"}}</button>
- </div>
+ <button class="ui primary button">{{ctx.Locale.Tr "settings.update_profile"}}</button>
</form>
</div>