Merge password and 2fa page on user settings (#2695)
* merge password and 2fa page on user settingstokarchuk/v1.17
parent
c1b0c9e7c4
commit
9e865cee67
@ -1,41 +0,0 @@ |
|||||||
{{template "base/head" .}} |
|
||||||
<div class="user settings password"> |
|
||||||
{{template "user/settings/navbar" .}} |
|
||||||
<div class="ui container"> |
|
||||||
{{template "base/alert" .}} |
|
||||||
<h4 class="ui top attached header"> |
|
||||||
{{.i18n.Tr "settings.change_password"}} |
|
||||||
</h4> |
|
||||||
<div class="ui attached segment"> |
|
||||||
{{if or (.SignedUser.IsLocal) (.SignedUser.IsOAuth2)}} |
|
||||||
<form class="ui form" action="{{.Link}}" method="post"> |
|
||||||
{{.CsrfTokenHtml}} |
|
||||||
{{if .SignedUser.IsPasswordSet}} |
|
||||||
<div class="required field {{if .Err_OldPassword}}error{{end}}"> |
|
||||||
<label for="old_password">{{.i18n.Tr "settings.old_password"}}</label> |
|
||||||
<input id="old_password" name="old_password" type="password" autocomplete="off" autofocus required> |
|
||||||
</div> |
|
||||||
{{end}} |
|
||||||
<div class="required field {{if .Err_Password}}error{{end}}"> |
|
||||||
<label for="password">{{.i18n.Tr "settings.new_password"}}</label> |
|
||||||
<input id="password" name="password" type="password" autocomplete="off" required> |
|
||||||
</div> |
|
||||||
<div class="required field {{if .Err_Password}}error{{end}}"> |
|
||||||
<label for="retype">{{.i18n.Tr "settings.retype_new_password"}}</label> |
|
||||||
<input id="retype" name="retype" type="password" autocomplete="off" required> |
|
||||||
</div> |
|
||||||
|
|
||||||
<div class="field"> |
|
||||||
<button class="ui green button">{{$.i18n.Tr "settings.change_password"}}</button> |
|
||||||
<a href="{{AppSubUrl}}/user/forgot_password?email={{.Email}}">{{.i18n.Tr "auth.forgot_password"}}</a> |
|
||||||
</div> |
|
||||||
</form> |
|
||||||
{{else}} |
|
||||||
<div class="ui info message"> |
|
||||||
<p class="text left">{{$.i18n.Tr "settings.password_change_disabled"}}</p> |
|
||||||
</div> |
|
||||||
{{end}} |
|
||||||
</div> |
|
||||||
</div> |
|
||||||
</div> |
|
||||||
{{template "base/footer" .}} |
|
@ -0,0 +1,79 @@ |
|||||||
|
{{template "base/head" .}} |
||||||
|
<div class="user settings password"> |
||||||
|
{{template "user/settings/navbar" .}} |
||||||
|
<div class="ui container"> |
||||||
|
{{template "base/alert" .}} |
||||||
|
<h4 class="ui top attached header"> |
||||||
|
{{.i18n.Tr "settings.password"}} |
||||||
|
</h4> |
||||||
|
<div class="ui attached segment"> |
||||||
|
{{if or (.SignedUser.IsLocal) (.SignedUser.IsOAuth2)}} |
||||||
|
<form class="ui form" action="{{.Link}}?tp=password" method="post"> |
||||||
|
{{.CsrfTokenHtml}} |
||||||
|
{{if .SignedUser.IsPasswordSet}} |
||||||
|
<div class="required field {{if .Err_OldPassword}}error{{end}}"> |
||||||
|
<label for="old_password">{{.i18n.Tr "settings.old_password"}}</label> |
||||||
|
<input id="old_password" name="old_password" type="password" autocomplete="off" autofocus required> |
||||||
|
</div> |
||||||
|
{{end}} |
||||||
|
<div class="required field {{if .Err_Password}}error{{end}}"> |
||||||
|
<label for="password">{{.i18n.Tr "settings.new_password"}}</label> |
||||||
|
<input id="password" name="password" type="password" autocomplete="off" required> |
||||||
|
</div> |
||||||
|
<div class="required field {{if .Err_Password}}error{{end}}"> |
||||||
|
<label for="retype">{{.i18n.Tr "settings.retype_new_password"}}</label> |
||||||
|
<input id="retype" name="retype" type="password" autocomplete="off" required> |
||||||
|
</div> |
||||||
|
|
||||||
|
<div class="field"> |
||||||
|
<button class="ui green button">{{$.i18n.Tr "settings.change_password"}}</button> |
||||||
|
<a href="{{AppSubUrl}}/user/forgot_password?email={{.Email}}">{{.i18n.Tr "auth.forgot_password"}}</a> |
||||||
|
</div> |
||||||
|
</form> |
||||||
|
{{else}} |
||||||
|
<div class="ui info message"> |
||||||
|
<p class="text left">{{$.i18n.Tr "settings.password_change_disabled"}}</p> |
||||||
|
</div> |
||||||
|
{{end}} |
||||||
|
</div> |
||||||
|
<br/> |
||||||
|
|
||||||
|
<h4 class="ui top attached header"> |
||||||
|
{{.i18n.Tr "settings.twofa"}} |
||||||
|
</h4> |
||||||
|
<div class="ui attached segment"> |
||||||
|
<p>{{.i18n.Tr "settings.twofa_desc"}}</p> |
||||||
|
{{if .TwofaEnrolled}} |
||||||
|
<p>{{$.i18n.Tr "settings.twofa_is_enrolled" | Str2html }}</p> |
||||||
|
<form class="ui form" action="{{.Link}}/two_factor/regenerate_scratch" method="post" enctype="multipart/form-data"> |
||||||
|
{{.CsrfTokenHtml}} |
||||||
|
<p>{{.i18n.Tr "settings.regenerate_scratch_token_desc"}}</p> |
||||||
|
<button class="ui blue button">{{$.i18n.Tr "settings.twofa_scratch_token_regenerate"}}</button> |
||||||
|
</form> |
||||||
|
<form class="ui form" action="{{.Link}}/two_factor/disable" method="post" enctype="multipart/form-data" id="disable-form"> |
||||||
|
{{.CsrfTokenHtml}} |
||||||
|
<p>{{.i18n.Tr "settings.twofa_disable_note"}}</p> |
||||||
|
<div class="ui red button delete-button" data-type="form" data-form="#disable-form">{{$.i18n.Tr "settings.twofa_disable"}}</div> |
||||||
|
</form> |
||||||
|
{{else}} |
||||||
|
<p>{{.i18n.Tr "settings.twofa_not_enrolled"}}</p> |
||||||
|
<div class="inline field"> |
||||||
|
<a class="ui green button" href="{{.Link}}/two_factor/enroll">{{$.i18n.Tr "settings.twofa_enroll"}}</a> |
||||||
|
</div> |
||||||
|
{{end}} |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
</div> |
||||||
|
|
||||||
|
<div class="ui small basic delete modal"> |
||||||
|
<div class="ui icon header"> |
||||||
|
<i class="trash icon"></i> |
||||||
|
{{.i18n.Tr "settings.twofa_disable"}} |
||||||
|
</div> |
||||||
|
<div class="content"> |
||||||
|
<p>{{.i18n.Tr "settings.twofa_disable_desc"}}</p> |
||||||
|
</div> |
||||||
|
{{template "base/delete_modal_actions" .}} |
||||||
|
</div> |
||||||
|
|
||||||
|
{{template "base/footer" .}} |
Loading…
Reference in new issue