profile.tmpl 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. {{template "base/head" .}}
  2. <div class="user settings profile">
  3. <div class="ui container">
  4. <div class="ui grid">
  5. {{template "user/settings/navbar" .}}
  6. <div class="twelve wide column content">
  7. {{template "base/alert" .}}
  8. <h4 class="ui top attached header">
  9. {{.i18n.Tr "settings.public_profile"}}
  10. </h4>
  11. <div class="ui attached segment">
  12. <p>{{.i18n.Tr "settings.profile_desc"}}</p>
  13. <form class="ui form" action="{{.Link}}" method="post">
  14. {{.CsrfTokenHtml}}
  15. <div class="required field {{if .Err_Name}}error{{end}}">
  16. <label for="username">{{.i18n.Tr "username"}}<span class="text red hide" id="name-change-prompt"> {{.i18n.Tr "settings.change_username_prompt"}}</span></label>
  17. <input id="username" name="name" value="{{.SignedUser.Name}}" data-name="{{.SignedUser.Name}}" autofocus required {{if not .SignedUser.IsLocal}}disabled{{end}}>
  18. {{if not .SignedUser.IsLocal}}
  19. <p class="help text blue">{{$.i18n.Tr "settings.password_username_disabled"}}</p>
  20. {{end}}
  21. </div>
  22. <div class="field {{if .Err_FullName}}error{{end}}">
  23. <label for="full_name">{{.i18n.Tr "settings.full_name"}}</label>
  24. <input id="full_name" name="full_name" value="{{.SignedUser.FullName}}">
  25. </div>
  26. <div class="required field {{if .Err_Email}}error{{end}}">
  27. <label for="email">{{.i18n.Tr "email"}}</label>
  28. <input id="email" name="email" value="{{.SignedUser.Email}}">
  29. </div>
  30. <div class="field {{if .Err_Website}}error{{end}}">
  31. <label for="website">{{.i18n.Tr "settings.website"}}</label>
  32. <input id="website" name="website" type="url" value="{{.SignedUser.Website}}">
  33. </div>
  34. <div class="field">
  35. <label for="location">{{.i18n.Tr "settings.location"}}</label>
  36. <input id="location" name="location" value="{{.SignedUser.Location}}">
  37. </div>
  38. {{if not DisableGravatar}}
  39. <div class="field {{if .Err_Gravatar}}error{{end}}">
  40. <label for="gravatar">Gravatar {{.i18n.Tr "email"}}</label>
  41. <input id="gravatar" name="gravatar" value="{{.SignedUser.AvatarEmail}}" />
  42. </div>
  43. {{end}}
  44. <div class="field">
  45. <button class="ui green button">{{$.i18n.Tr "settings.update_profile"}}</button>
  46. </div>
  47. </form>
  48. <div class="ui divider"></div>
  49. <form class="ui form" action="{{.Link}}/avatar" method="post" enctype="multipart/form-data">
  50. {{.CsrfTokenHtml}}
  51. <div class="inline field">
  52. <div class="ui checkbox">
  53. <input name="enable" type="checkbox" {{if .SignedUser.UseCustomAvatar}}checked{{end}}>
  54. <label>{{.i18n.Tr "settings.enable_custom_avatar"}}</label>
  55. </div>
  56. </div>
  57. <div class="inline field">
  58. <label for="avatar">{{.i18n.Tr "settings.choose_new_avatar"}}</label>
  59. <input name="avatar" type="file" >
  60. </div>
  61. <div class="field">
  62. <button class="ui green button">{{$.i18n.Tr "settings.update_avatar"}}</button>
  63. <a class="ui red button delete-post" data-request-url="{{.Link}}/avatar/delete" data-done-url="{{.Link}}">{{$.i18n.Tr "settings.delete_current_avatar"}}</a>
  64. </div>
  65. </form>
  66. </div>
  67. </div>
  68. </div>
  69. </div>
  70. </div>
  71. {{template "base/footer" .}}