Finish new reset password, etc.
This commit is contained in:
parent
5605af973b
commit
7af7584d25
16 changed files with 625 additions and 602 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -38,3 +38,4 @@ __pycache__
|
||||||
*.pem
|
*.pem
|
||||||
output*
|
output*
|
||||||
config.codekit
|
config.codekit
|
||||||
|
.brackets.json
|
||||||
|
|
|
@ -52,9 +52,23 @@ create_new_account = Create New Account
|
||||||
register_hepler_msg = Already have an account? Sign in now!
|
register_hepler_msg = Already have an account? Sign in now!
|
||||||
social_register_hepler_msg = Already have an account? Bind now!
|
social_register_hepler_msg = Already have an account? Bind now!
|
||||||
disable_register_prompt = Sorry, registration has been disabled. Please contact the site administrator.
|
disable_register_prompt = Sorry, registration has been disabled. Please contact the site administrator.
|
||||||
|
disable_register_mail = Sorry, Register Mail Confirmation has been disabled.
|
||||||
remember_me = Remember Me
|
remember_me = Remember Me
|
||||||
|
forgot_password= Fotgot Password
|
||||||
forget_password = Fotget password?
|
forget_password = Fotget password?
|
||||||
sign_up_now = Need an account? Sign up now.
|
sign_up_now = Need an account? Sign up now.
|
||||||
|
confirmation_mail_sent_prompt = A new confirmation e-mail has been sent to <b>%s</b>, please check your inbox within the next %d hours to complete your registration.
|
||||||
|
sign_in_email = Sign in to your e-mail
|
||||||
|
active_your_account = Activate Your Account
|
||||||
|
resent_limit_prompt = Sorry, you are sending an activation e-mail too frequently. Please wait 3 minutes.
|
||||||
|
has_unconfirmed_mail = Hi %s, you have an unconfirmed email address(<b>%s</b>). If you haven't received a confirmation e-mail or need to resend a new one, please click on the button below.
|
||||||
|
resend_mail = Click here to resend your activation e-mail
|
||||||
|
email_not_associate = This e-mail address does not associate to any account.
|
||||||
|
send_reset_mail = Click here to (re)send your passowrd reset e-mail
|
||||||
|
reset_password = Reset Your Password
|
||||||
|
invalid_code = Sorry, your confirmation code has exipired or not valid.
|
||||||
|
reset_password_helper = Click here to reset your password
|
||||||
|
password_too_short = Password length cannot be less then 6.
|
||||||
|
|
||||||
[form]
|
[form]
|
||||||
UserName = Username
|
UserName = Username
|
||||||
|
|
|
@ -52,9 +52,23 @@ create_new_account = 创建帐户
|
||||||
register_hepler_msg = 已经注册?立即登录!
|
register_hepler_msg = 已经注册?立即登录!
|
||||||
social_register_hepler_msg = 已经注册?立即绑定!
|
social_register_hepler_msg = 已经注册?立即绑定!
|
||||||
disable_register_prompt = 对不起,注册功能已被关闭。请联系网站管理员。
|
disable_register_prompt = 对不起,注册功能已被关闭。请联系网站管理员。
|
||||||
|
disable_register_mail = 对不起,注册邮箱确认功能已被关闭。
|
||||||
remember_me = 记住登录
|
remember_me = 记住登录
|
||||||
|
forgot_password = 忘记密码
|
||||||
forget_password = 忘记密码?
|
forget_password = 忘记密码?
|
||||||
sign_up_now = 还没帐户?马上注册。
|
sign_up_now = 还没帐户?马上注册。
|
||||||
|
confirmation_mail_sent_prompt = 一封新的确认邮件已经被发送至 <b>%s</b>,请检查您的收件箱并在 %d 小时内完成确认注册操作。
|
||||||
|
sign_in_email = 登录到您的邮箱
|
||||||
|
active_your_account = 激活您的帐户
|
||||||
|
resent_limit_prompt = 对不起,您请求发送激活邮件过于频繁,请等待 3 分钟后再试!
|
||||||
|
has_unconfirmed_mail = %s 您好,系统检测到您有一封发送至 <b>%s</b> 但未被确认的邮件。如果您未收到激活邮件,或需要重新发送,请单击下方的按钮。
|
||||||
|
resend_mail = 单击此处重新发送确认邮件
|
||||||
|
email_not_associate = 您输入的邮箱地址未被关联到任何帐号!
|
||||||
|
send_reset_mail = 单击此处(重新)发送您的密码重置邮件
|
||||||
|
reset_password = 重置密码
|
||||||
|
invalid_code = 对不起,您的确认代码已过期或已失效。
|
||||||
|
reset_password_helper = 单击此处重置密码
|
||||||
|
password_too_short = 密码长度不能少于 6 位!
|
||||||
|
|
||||||
[form]
|
[form]
|
||||||
UserName = 用户名
|
UserName = 用户名
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
package middleware
|
package middleware
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"fmt"
|
||||||
"net/url"
|
"net/url"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
@ -43,6 +44,7 @@ func Toggle(options *ToggleOptions) macaron.Handler {
|
||||||
}
|
}
|
||||||
|
|
||||||
if options.SignInRequire {
|
if options.SignInRequire {
|
||||||
|
fmt.Println(ctx.User.IsActive, setting.Service.RegisterEmailConfirm)
|
||||||
if !ctx.IsSigned {
|
if !ctx.IsSigned {
|
||||||
// Ignore watch repository operation.
|
// Ignore watch repository operation.
|
||||||
if strings.HasSuffix(ctx.Req.RequestURI, "watch") {
|
if strings.HasSuffix(ctx.Req.RequestURI, "watch") {
|
||||||
|
@ -52,7 +54,7 @@ func Toggle(options *ToggleOptions) macaron.Handler {
|
||||||
ctx.Redirect("/user/login")
|
ctx.Redirect("/user/login")
|
||||||
return
|
return
|
||||||
} else if !ctx.User.IsActive && setting.Service.RegisterEmailConfirm {
|
} else if !ctx.User.IsActive && setting.Service.RegisterEmailConfirm {
|
||||||
// ctx.Data["Title"] = "Activate Your Account"
|
ctx.Data["Title"] = ctx.Tr("auth.active_your_account")
|
||||||
ctx.HTML(200, "user/activate")
|
ctx.HTML(200, "user/activate")
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
|
@ -435,6 +435,7 @@ dt {
|
||||||
}
|
}
|
||||||
.btn-link {
|
.btn-link {
|
||||||
overflow: visible;
|
overflow: visible;
|
||||||
|
color: white;
|
||||||
padding: .6em 1.2em;
|
padding: .6em 1.2em;
|
||||||
}
|
}
|
||||||
.btn-radius {
|
.btn-radius {
|
||||||
|
|
|
@ -1,476 +1,458 @@
|
||||||
@import "../ui/var";
|
@import "../ui/var";
|
||||||
|
|
||||||
@repoHeaderBorderColor: #D6D6D6;
|
@repoHeaderBorderColor: #D6D6D6;
|
||||||
@repoHeaderBgColor: #FFF;
|
@repoHeaderBgColor: #FFF;
|
||||||
@repoHeaderNameColor: #888;
|
@repoHeaderNameColor: #888;
|
||||||
|
|
||||||
/* repository main */
|
/* repository main */
|
||||||
|
|
||||||
#repo-wrapper {
|
#repo-wrapper {
|
||||||
padding-bottom: 100px;
|
padding-bottom: 100px;
|
||||||
}
|
}
|
||||||
#repo-header {
|
#repo-header {
|
||||||
height: 69px;
|
height: 69px;
|
||||||
border-bottom: 1px solid @repoHeaderBorderColor;
|
border-bottom: 1px solid@repoHeaderBorderColor;
|
||||||
background-color: @repoHeaderBgColor;
|
|
||||||
|
background-color: @repoHeaderBgColor;
|
||||||
|
|
||||||
}
|
}
|
||||||
#repo-header-name {
|
#repo-header-name {
|
||||||
line-height: 66px;
|
line-height: 66px;
|
||||||
color: @repoHeaderNameColor;
|
color: @repoHeaderNameColor;
|
||||||
font-size: 1.6em;
|
|
||||||
font-weight: normal;
|
|
||||||
margin-bottom: 0;
|
|
||||||
i {
|
|
||||||
margin-right: 12px;
|
|
||||||
vertical-align: middle;
|
|
||||||
}
|
|
||||||
.divider {
|
|
||||||
margin: 0 4px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
font-size: 1.6em;
|
||||||
|
font-weight: normal;
|
||||||
|
margin-bottom: 0;
|
||||||
|
i {
|
||||||
|
margin-right: 12px;
|
||||||
|
vertical-align: middle;
|
||||||
|
}
|
||||||
|
.divider {
|
||||||
|
margin: 0 4px;
|
||||||
|
}
|
||||||
|
}
|
||||||
#repo-header-meta {
|
#repo-header-meta {
|
||||||
line-height: 66px;
|
line-height: 66px;
|
||||||
li {
|
li {
|
||||||
> a {
|
> a {
|
||||||
padding: 0;
|
padding: 0;
|
||||||
&:hover {
|
&:hover {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
a > .btn {
|
a > .btn {
|
||||||
font-size: 1.05em;
|
font-size: 1.05em;
|
||||||
margin-left: 16px;
|
margin-left: 16px;
|
||||||
i {
|
i {
|
||||||
margin-right: 6px;
|
margin-right: 6px;
|
||||||
}
|
}
|
||||||
line-height: 16px;
|
line-height:16px;
|
||||||
.num {
|
.num {
|
||||||
margin-left: 6px;
|
margin-left: 6px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-header-download-btn {
|
#repo-header-download-btn {
|
||||||
> .btn > i {
|
> .btn > i {
|
||||||
margin-right: 0 !important;
|
margin-right: 0 !important;
|
||||||
}
|
}
|
||||||
&:hover {
|
&:hover {
|
||||||
&:after,
|
&:after, .btn {
|
||||||
.btn {
|
background-color: @btnHoverBlackColor;
|
||||||
background-color: @btnHoverBlackColor;
|
|
||||||
color: #FFF;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
&:after {
|
|
||||||
background-color: @btnBlackColor;
|
|
||||||
padding: 9px 16px 8px 0;
|
|
||||||
margin-left: -8px !important;
|
|
||||||
color: #FFF;
|
|
||||||
border-top: 1px solid @btnBlackColor;
|
|
||||||
border-bottom: 1px solid @btnBlackColor;
|
|
||||||
border-top-right-radius: .25em;
|
|
||||||
border-bottom-right-radius: .25em;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
color: #FFF;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
&:after {
|
||||||
|
background-color: @btnBlackColor;
|
||||||
|
|
||||||
|
padding: 9px 16px 8px 0;
|
||||||
|
margin-left: -8px !important;
|
||||||
|
color: #FFF;
|
||||||
|
border-top: 1px solid@btnBlackColor;
|
||||||
|
|
||||||
|
border-bottom: 1px solid@btnBlackColor;
|
||||||
|
|
||||||
|
border-top-right-radius: .25em;
|
||||||
|
border-bottom-right-radius: .25em;
|
||||||
|
}
|
||||||
|
}
|
||||||
#repo-header-download-drop {
|
#repo-header-download-drop {
|
||||||
line-height: 24px;
|
line-height: 24px;
|
||||||
width: 440px;
|
width: 440px;
|
||||||
top: 50px;
|
top: 50px;
|
||||||
left: -354px;
|
left: -354px;
|
||||||
padding: 20px;
|
padding: 20px;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
.btn > i {
|
.btn > i {
|
||||||
margin-right: 6px;
|
margin-right: 6px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-content {
|
#repo-content {
|
||||||
padding: 18px 0;
|
padding: 18px 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-clone-url {
|
#repo-clone-url {
|
||||||
border-right: none;
|
border-right: none;
|
||||||
width: 196px;
|
width: 196px;
|
||||||
border-left: none;
|
border-left: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-clone-help {
|
#repo-clone-help {
|
||||||
line-height: 48px;
|
line-height: 48px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-clone-zip {
|
#repo-clone-zip {
|
||||||
line-height: 48px;
|
line-height: 48px;
|
||||||
a {
|
a {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
color: white;
|
color: white;
|
||||||
overflow: visible;
|
overflow: visible;
|
||||||
padding: .6em 1.2em;
|
padding: .6em 1.2em;
|
||||||
}
|
}
|
||||||
.btn {
|
.btn {
|
||||||
margin: 0 6px;
|
margin: 0 6px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-desc {
|
#repo-desc {
|
||||||
font-size: 1.2em;
|
font-size: 1.2em;
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-sidebar-nav {
|
#repo-sidebar-nav {
|
||||||
.label {
|
.label {
|
||||||
font-size: 12px;
|
font-size: 12px;
|
||||||
line-height: 1.4em;
|
line-height: 1.4em;
|
||||||
margin-top: 2px;
|
margin-top: 2px;
|
||||||
}
|
}
|
||||||
i {
|
i {
|
||||||
margin-right: 6px;
|
margin-right: 6px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-file-nav {
|
#repo-file-nav {
|
||||||
padding: .6em 0 1em 0;
|
padding: .6em 0 1em 0;
|
||||||
> li > a {
|
> li > a {
|
||||||
padding-left: 0;
|
padding-left: 0;
|
||||||
&:hover {
|
&:hover {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
li.repo-jump > a {
|
li.repo-jump > a {
|
||||||
padding-right: 0;
|
padding-right: 0;
|
||||||
.btn {
|
.btn {
|
||||||
margin-left: -1px;
|
margin-left: -1px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-branch-switch {
|
#repo-branch-switch {
|
||||||
> a {
|
> a {
|
||||||
.btn {
|
.btn {
|
||||||
padding-right: 30px;
|
padding-right: 30px;
|
||||||
}
|
}
|
||||||
&:after {
|
&:after {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
top: 12px;
|
top: 12px;
|
||||||
right: 30px;
|
right: 30px;
|
||||||
margin-left: 0;
|
margin-left: 0;
|
||||||
color: @baseFontColor;
|
color: @baseFontColor;
|
||||||
}
|
|
||||||
}
|
|
||||||
> .drop-down {
|
|
||||||
top: 40px;
|
|
||||||
left: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
> .drop-down {
|
||||||
|
top: 40px;
|
||||||
|
left: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
#repo-branch-filter-ipt {
|
#repo-branch-filter-ipt {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
border-left: none;
|
border-left: none;
|
||||||
border-right: none;
|
border-right: none;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-branch-tag {
|
#repo-branch-tag {
|
||||||
.tab-nav {
|
.tab-nav {
|
||||||
border-bottom: 1px solid #EAEAEA;
|
border-bottom: 1px solid #EAEAEA;
|
||||||
a {
|
a {
|
||||||
padding: .3em .8em;
|
padding: .3em .8em;
|
||||||
}
|
}
|
||||||
.js-tab-nav-show {
|
.js-tab-nav-show {
|
||||||
background-color: #EEE;
|
background-color: #EEE;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-branch-list,
|
#repo-branch-list,
|
||||||
#repo-tag-list {
|
#repo-tag-list {
|
||||||
li {
|
li {
|
||||||
i {
|
i {
|
||||||
margin-right: 12px;
|
margin-right: 12px;
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
li.checked {
|
li.checked {
|
||||||
i {
|
i {
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-tag-list {
|
#repo-tag-list {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-bread {
|
#repo-bread {
|
||||||
.bread {
|
.bread {
|
||||||
padding-right: 0;
|
padding-right: 0;
|
||||||
font-size: 16px;
|
font-size: 16px;
|
||||||
font-weight: bold;
|
font-weight: bold;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-main {
|
#repo-main {
|
||||||
padding-right: 40px;
|
padding-right: 40px;
|
||||||
box-sizing: border-box;
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-files-table {
|
#repo-files-table {
|
||||||
margin-bottom: 20px;
|
margin-bottom: 20px;
|
||||||
th,
|
th, td {
|
||||||
td {
|
text-align: left;
|
||||||
text-align: left;
|
line-height: 32px;
|
||||||
line-height: 32px;
|
}
|
||||||
}
|
td.icon {
|
||||||
td.icon {
|
width: 16px;
|
||||||
width: 16px;
|
padding-right: .1em;
|
||||||
padding-right: .1em;
|
padding-left: 1em;
|
||||||
padding-left: 1em;
|
}
|
||||||
}
|
td.name {
|
||||||
td.name {
|
max-width: 120px;
|
||||||
max-width: 120px;
|
.text-truncate {
|
||||||
.text-truncate {
|
max-width: 100%;
|
||||||
max-width: 100%;
|
}
|
||||||
}
|
}
|
||||||
}
|
td.age {
|
||||||
td.age {
|
max-width: 120px;
|
||||||
max-width: 120px;
|
text-align: right;
|
||||||
text-align: right;
|
}
|
||||||
}
|
td.msg {
|
||||||
td.msg {
|
max-width: 440px;
|
||||||
max-width: 440px;
|
.text-truncate {
|
||||||
.text-truncate {
|
max-width: 100%;
|
||||||
max-width: 100%;
|
}
|
||||||
}
|
}
|
||||||
}
|
td.age,
|
||||||
td.age,
|
td.size,
|
||||||
td.size,
|
td.msg a {
|
||||||
td.msg a {
|
color: #888;
|
||||||
color: #888;
|
}
|
||||||
}
|
td.msg a:hover {
|
||||||
td.msg a:hover {
|
color: #428BCA;
|
||||||
color: #428BCA;
|
text-decoration: underline;
|
||||||
text-decoration: underline;
|
}
|
||||||
}
|
tbody {
|
||||||
tbody {
|
background-color: #FFF;
|
||||||
background-color: #FFF;
|
tr:hover {
|
||||||
tr:hover {
|
background-color: #ffffEE;
|
||||||
background-color: #ffffEE;
|
}
|
||||||
}
|
}
|
||||||
}
|
thead {
|
||||||
thead {
|
background-color: #F0F0F0;
|
||||||
background-color: #F0F0F0;
|
.author {
|
||||||
.author {
|
a {
|
||||||
a {
|
margin: 0 .4em;
|
||||||
margin: 0 .4em;
|
}
|
||||||
}
|
}
|
||||||
}
|
.last-commit {
|
||||||
.last-commit {
|
strong {
|
||||||
strong {
|
color: #444;
|
||||||
color: #444;
|
}
|
||||||
}
|
.text-truncate {
|
||||||
.text-truncate {
|
margin-left: .4em;
|
||||||
margin-left: .4em;
|
}
|
||||||
}
|
}
|
||||||
}
|
.last-commit .text-truncate,
|
||||||
.last-commit .text-truncate,
|
.age {
|
||||||
.age {
|
font-weight: normal;
|
||||||
font-weight: normal;
|
color: #888;
|
||||||
color: #888;
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-readme {
|
#repo-readme {
|
||||||
margin-bottom: 80px;
|
margin-bottom: 80px;
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-bare-start {
|
#repo-bare-start {
|
||||||
margin-bottom: 100px;
|
margin-bottom: 100px;
|
||||||
.panel-content {
|
.panel-content {
|
||||||
background-color: #FFF;
|
background-color: #FFF;
|
||||||
}
|
}
|
||||||
pre {
|
pre {
|
||||||
margin: 0 40px;
|
margin: 0 40px;
|
||||||
padding: 6px 10px;
|
padding: 6px 10px;
|
||||||
border: 1px solid #ddd;
|
border: 1px solid #ddd;
|
||||||
background: #f8f8f8;
|
background: #f8f8f8;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.repo-bare {
|
.repo-bare {
|
||||||
#repo-bare-start {
|
#repo-bare-start {
|
||||||
h2 {
|
h2 {
|
||||||
margin-top: 30px;
|
margin-top: 30px;
|
||||||
margin-bottom: 24px;
|
margin-bottom: 24px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#repo-header-meta {
|
#repo-header-meta {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
#repo-clone-ssh {
|
#repo-clone-ssh {
|
||||||
margin-left: 200px;
|
margin-left: 200px;
|
||||||
}
|
}
|
||||||
#repo-clone-copy {
|
#repo-clone-copy {
|
||||||
margin-right: 200px;
|
margin-right: 200px;
|
||||||
}
|
}
|
||||||
#repo-clone-help {
|
#repo-clone-help {
|
||||||
clear: both;
|
clear: both;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
}
|
}
|
||||||
#repo-clone-url {
|
#repo-clone-url {
|
||||||
width: 520px;
|
width: 520px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* repository create */
|
/* repository create */
|
||||||
|
|
||||||
#repo-migrate-form,
|
#repo-migrate-form,
|
||||||
#repo-create-form {
|
#repo-create-form {
|
||||||
width: 800px;
|
width: 800px;
|
||||||
margin: 60px auto auto auto;
|
margin: 60px auto auto auto;
|
||||||
background: white;
|
background: white;
|
||||||
h2 {
|
h2 {
|
||||||
margin: .5em 1em;
|
margin: .5em 1em;
|
||||||
}
|
}
|
||||||
.field {
|
.field {
|
||||||
margin: 1.2em 0 2em 0;
|
margin: 1.2em 0 2em 0;
|
||||||
}
|
}
|
||||||
.ipt {
|
.ipt {
|
||||||
width: 540px;
|
width: 540px;
|
||||||
}
|
}
|
||||||
textarea {
|
textarea {
|
||||||
height: 120px;
|
height: 120px;
|
||||||
}
|
}
|
||||||
.avatar {
|
.avatar {
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
margin-right: .6em;
|
margin-right: .6em;
|
||||||
width: 28px;
|
width: 28px;
|
||||||
height: 28px;
|
height: 28px;
|
||||||
}
|
}
|
||||||
&:hover {
|
&:hover {
|
||||||
box-shadow: 0px 0px 6px #CCC;
|
box-shadow: 0px 0px 6px #CCC;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-create-cancel {
|
#repo-create-cancel {
|
||||||
margin-left: 4em;
|
margin-left: 4em;
|
||||||
}
|
}
|
||||||
|
|
||||||
#repo-create-owner-list {
|
#repo-create-owner-list {
|
||||||
top: 30px;
|
top: 30px;
|
||||||
left: 0;
|
left: 0;
|
||||||
width: auto;
|
width: auto;
|
||||||
max-width: 300px;
|
max-width: 300px;
|
||||||
.octicon {
|
.octicon {
|
||||||
margin-right: 12px;
|
margin-right: 12px;
|
||||||
opacity: 0;
|
opacity: 0;
|
||||||
}
|
}
|
||||||
.avatar {
|
.avatar {
|
||||||
width: 20px;
|
width: 20px;
|
||||||
height: 20px;
|
height: 20px;
|
||||||
}
|
}
|
||||||
li {
|
li {
|
||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
&.checked {
|
&.checked {
|
||||||
.octicon {
|
.octicon {
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
a {
|
a {
|
||||||
text-overflow: ellipsis;
|
text-overflow: ellipsis;
|
||||||
-o-text-overflow: ellipsis;
|
-o-text-overflow: ellipsis;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.file-name {
|
.file-name {
|
||||||
margin-left: 1em;
|
margin-left: 1em;
|
||||||
}
|
}
|
||||||
.file-size {
|
.file-size {
|
||||||
font-size: 13px;
|
font-size: 13px;
|
||||||
color: #888;
|
color: #888;
|
||||||
margin-left: 1em;
|
margin-left: 1em;
|
||||||
}
|
}
|
||||||
.code-view {
|
.code-view {
|
||||||
overflow: auto;
|
overflow: auto;
|
||||||
overflow-x: auto;
|
overflow-x: auto;
|
||||||
overflow-y: hidden;
|
overflow-y: hidden;
|
||||||
background: white;
|
background: white;
|
||||||
.view-raw {
|
.view-raw {
|
||||||
min-height: 40px;
|
min-height: 40px;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
padding-top: 20px;
|
padding-top: 20px;
|
||||||
.btn {
|
.btn {
|
||||||
font-size: 1.05em;
|
font-size: 1.05em;
|
||||||
line-height: 16px;
|
line-height: 16px;
|
||||||
padding: 6px 8px;
|
padding: 6px 8px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
table {
|
table {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
td {
|
td {
|
||||||
padding: 0;
|
padding: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.lines-num {
|
.lines-num {
|
||||||
text-align: right;
|
text-align: right;
|
||||||
color: #999;
|
color: #999;
|
||||||
background: #f5f5f5;
|
background: #f5f5f5;
|
||||||
width: 1%;
|
width: 1%;
|
||||||
span {
|
span {
|
||||||
font-family: Monaco, Menlo, Consolas, "Courier New", monospace;
|
font-family: Monaco, Menlo, Consolas, "Courier New", monospace;
|
||||||
line-height: 18px;
|
line-height: 18px;
|
||||||
padding: 0 8px 0 10px;
|
padding: 0 8px 0 10px;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
display: block;
|
display: block;
|
||||||
margin-top: 2px;
|
margin-top: 2px;
|
||||||
font-size: 12px;
|
font-size: 12px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.lines-code > pre {
|
.lines-code > pre {
|
||||||
border: none;
|
border: none;
|
||||||
border-left: 1px solid #ddd;
|
border-left: 1px solid #ddd;
|
||||||
> ol.linenums > li {
|
> ol.linenums > li {
|
||||||
padding: 0 10px;
|
padding: 0 10px;
|
||||||
&.active {
|
&.active {
|
||||||
background: #ffffdd;
|
background: #ffffdd;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.repo-setting-zone {
|
.repo-setting-zone {
|
||||||
padding: 30px;
|
padding: 30px;
|
||||||
}
|
}
|
||||||
#repo-collab-list {
|
#repo-collab-list {
|
||||||
list-style: none;
|
list-style: none;
|
||||||
padding: 10px 0 5px 0;
|
padding: 10px 0 5px 0;
|
||||||
li.collab {
|
li.collab {
|
||||||
clear: both;
|
clear: both;
|
||||||
height: 50px;
|
height: 50px;
|
||||||
padding: 0 15px 0 15px;
|
padding: 0 15px 0 15px;
|
||||||
}
|
}
|
||||||
a.member {
|
a.member {
|
||||||
color: #444;
|
color: #444;
|
||||||
height: 50px;
|
height: 50px;
|
||||||
line-height: 50px;
|
line-height: 50px;
|
||||||
&:hover {
|
&:hover {
|
||||||
color: #4183C4;
|
color: #4183C4;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.avatar {
|
.avatar {
|
||||||
margin-right: 1em;
|
margin-right: 1em;
|
||||||
width: 40px;
|
width: 40px;
|
||||||
}
|
}
|
||||||
.remove-collab {
|
.remove-collab {
|
||||||
color: #DD4B39;
|
color: #DD4B39;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.repo-user-list-block {
|
.repo-user-list-block {
|
||||||
position: relative;
|
position: relative;
|
||||||
top: 5px;
|
top: 5px;
|
||||||
}
|
}
|
||||||
.setting-list {
|
.setting-list {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
list-style: none;
|
list-style: none;
|
||||||
}
|
}
|
|
@ -81,6 +81,7 @@
|
||||||
}
|
}
|
||||||
.btn-link {
|
.btn-link {
|
||||||
overflow: visible;
|
overflow: visible;
|
||||||
|
color: white;
|
||||||
padding: .6em 1.2em;
|
padding: .6em 1.2em;
|
||||||
}
|
}
|
||||||
.btn-radius {
|
.btn-radius {
|
||||||
|
|
|
@ -17,7 +17,12 @@ const (
|
||||||
|
|
||||||
func Home(ctx *middleware.Context) {
|
func Home(ctx *middleware.Context) {
|
||||||
if ctx.IsSigned {
|
if ctx.IsSigned {
|
||||||
user.Dashboard(ctx)
|
if !ctx.User.IsActive && setting.Service.RegisterEmailConfirm {
|
||||||
|
ctx.Data["Title"] = ctx.Tr("auth.active_your_account")
|
||||||
|
ctx.HTML(200, user.ACTIVATE)
|
||||||
|
} else {
|
||||||
|
user.Dashboard(ctx)
|
||||||
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -106,10 +106,9 @@ func SignInPost(ctx *middleware.Context, form auth.SignInForm) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if err == models.ErrUserNotExist {
|
if err == models.ErrUserNotExist {
|
||||||
ctx.RenderWithErr(ctx.Tr("form.username_password_incorrect"), SIGNIN, &form)
|
ctx.RenderWithErr(ctx.Tr("form.username_password_incorrect"), SIGNIN, &form)
|
||||||
return
|
} else {
|
||||||
|
ctx.Handle(500, "UserSignIn", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx.Handle(500, "UserSignIn", err)
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -294,55 +293,59 @@ func SignUpPost(ctx *middleware.Context, cpt *captcha.Captcha, form auth.Registe
|
||||||
}
|
}
|
||||||
|
|
||||||
func Activate(ctx *middleware.Context) {
|
func Activate(ctx *middleware.Context) {
|
||||||
// code := ctx.Query("code")
|
code := ctx.Query("code")
|
||||||
// if len(code) == 0 {
|
if len(code) == 0 {
|
||||||
// ctx.Data["IsActivatePage"] = true
|
ctx.Data["IsActivatePage"] = true
|
||||||
// if ctx.User.IsActive {
|
if ctx.User.IsActive {
|
||||||
// ctx.Handle(404, "user.Activate", nil)
|
ctx.Error(404)
|
||||||
// return
|
return
|
||||||
// }
|
}
|
||||||
// // Resend confirmation e-mail.
|
// Resend confirmation e-mail.
|
||||||
// if setting.Service.RegisterEmailConfirm {
|
if setting.Service.RegisterEmailConfirm {
|
||||||
// if ctx.Cache.IsExist("MailResendLimit_" + ctx.User.LowerName) {
|
if ctx.Cache.IsExist("MailResendLimit_" + ctx.User.LowerName) {
|
||||||
// ctx.Data["ResendLimited"] = true
|
ctx.Data["ResendLimited"] = true
|
||||||
// } else {
|
} else {
|
||||||
// ctx.Data["Hours"] = setting.Service.ActiveCodeLives / 60
|
ctx.Data["Hours"] = setting.Service.ActiveCodeLives / 60
|
||||||
// mailer.SendActiveMail(ctx.Render, ctx.User)
|
mailer.SendActiveMail(ctx.Render, ctx.User)
|
||||||
|
|
||||||
// if err := ctx.Cache.Put("MailResendLimit_"+ctx.User.LowerName, ctx.User.LowerName, 180); err != nil {
|
if err := ctx.Cache.Put("MailResendLimit_"+ctx.User.LowerName, ctx.User.LowerName, 180); err != nil {
|
||||||
// log.Error("Set cache(MailResendLimit) fail: %v", err)
|
log.Error(4, "Set cache(MailResendLimit) fail: %v", err)
|
||||||
// }
|
}
|
||||||
// }
|
}
|
||||||
// } else {
|
} else {
|
||||||
// ctx.Data["ServiceNotEnabled"] = true
|
ctx.Data["ServiceNotEnabled"] = true
|
||||||
// }
|
}
|
||||||
// ctx.HTML(200, ACTIVATE)
|
ctx.HTML(200, ACTIVATE)
|
||||||
// return
|
return
|
||||||
// }
|
}
|
||||||
|
|
||||||
// // Verify code.
|
// Verify code.
|
||||||
// if user := models.VerifyUserActiveCode(code); user != nil {
|
if user := models.VerifyUserActiveCode(code); user != nil {
|
||||||
// user.IsActive = true
|
user.IsActive = true
|
||||||
// user.Rands = models.GetUserSalt()
|
user.Rands = models.GetUserSalt()
|
||||||
// if err := models.UpdateUser(user); err != nil {
|
if err := models.UpdateUser(user); err != nil {
|
||||||
// ctx.Handle(404, "user.Activate", err)
|
if err == models.ErrUserNotExist {
|
||||||
// return
|
ctx.Error(404)
|
||||||
// }
|
} else {
|
||||||
|
ctx.Handle(500, "UpdateUser", err)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
// log.Trace("%s User activated: %s", ctx.Req.RequestURI, user.Name)
|
log.Trace("User activated: %s", user.Name)
|
||||||
|
|
||||||
// ctx.Session.Set("userId", user.Id)
|
ctx.Session.Set("uid", user.Id)
|
||||||
// ctx.Session.Set("userName", user.Name)
|
ctx.Session.Set("uname", user.Name)
|
||||||
// ctx.Redirect("/")
|
ctx.Redirect("/")
|
||||||
// return
|
return
|
||||||
// }
|
}
|
||||||
|
|
||||||
// ctx.Data["IsActivateFailed"] = true
|
ctx.Data["IsActivateFailed"] = true
|
||||||
// ctx.HTML(200, ACTIVATE)
|
ctx.HTML(200, ACTIVATE)
|
||||||
}
|
}
|
||||||
|
|
||||||
func ForgotPasswd(ctx *middleware.Context) {
|
func ForgotPasswd(ctx *middleware.Context) {
|
||||||
ctx.Data["Title"] = "Forgot Password"
|
ctx.Data["Title"] = ctx.Tr("auth.forgot_password")
|
||||||
|
|
||||||
if setting.MailService == nil {
|
if setting.MailService == nil {
|
||||||
ctx.Data["IsResetDisable"] = true
|
ctx.Data["IsResetDisable"] = true
|
||||||
|
@ -355,44 +358,45 @@ func ForgotPasswd(ctx *middleware.Context) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func ForgotPasswdPost(ctx *middleware.Context) {
|
func ForgotPasswdPost(ctx *middleware.Context) {
|
||||||
// ctx.Data["Title"] = "Forgot Password"
|
ctx.Data["Title"] = ctx.Tr("auth.forgot_password")
|
||||||
|
|
||||||
// if setting.MailService == nil {
|
if setting.MailService == nil {
|
||||||
// ctx.Handle(403, "user.ForgotPasswdPost", nil)
|
ctx.Handle(403, "user.ForgotPasswdPost", nil)
|
||||||
// return
|
return
|
||||||
// }
|
}
|
||||||
// ctx.Data["IsResetRequest"] = true
|
ctx.Data["IsResetRequest"] = true
|
||||||
|
|
||||||
// email := ctx.Query("email")
|
email := ctx.Query("email")
|
||||||
// u, err := models.GetUserByEmail(email)
|
u, err := models.GetUserByEmail(email)
|
||||||
// if err != nil {
|
if err != nil {
|
||||||
// if err == models.ErrUserNotExist {
|
if err == models.ErrUserNotExist {
|
||||||
// ctx.RenderWithErr("This e-mail address does not associate to any account.", "user/forgot_passwd", nil)
|
ctx.Data["Err_Email"] = true
|
||||||
// } else {
|
ctx.RenderWithErr(ctx.Tr("auth.email_not_associate"), FORGOT_PASSWORD, nil)
|
||||||
// ctx.Handle(500, "user.ResetPasswd(check existence)", err)
|
} else {
|
||||||
// }
|
ctx.Handle(500, "user.ResetPasswd(check existence)", err)
|
||||||
// return
|
}
|
||||||
// }
|
return
|
||||||
|
}
|
||||||
|
|
||||||
// if ctx.Cache.IsExist("MailResendLimit_" + u.LowerName) {
|
if ctx.Cache.IsExist("MailResendLimit_" + u.LowerName) {
|
||||||
// ctx.Data["ResendLimited"] = true
|
ctx.Data["ResendLimited"] = true
|
||||||
// ctx.HTML(200, FORGOT_PASSWORD)
|
ctx.HTML(200, FORGOT_PASSWORD)
|
||||||
// return
|
return
|
||||||
// }
|
}
|
||||||
|
|
||||||
// mailer.SendResetPasswdMail(ctx.Render, u)
|
mailer.SendResetPasswdMail(ctx.Render, u)
|
||||||
// if err = ctx.Cache.Put("MailResendLimit_"+u.LowerName, u.LowerName, 180); err != nil {
|
if err = ctx.Cache.Put("MailResendLimit_"+u.LowerName, u.LowerName, 180); err != nil {
|
||||||
// log.Error("Set cache(MailResendLimit) fail: %v", err)
|
log.Error(4, "Set cache(MailResendLimit) fail: %v", err)
|
||||||
// }
|
}
|
||||||
|
|
||||||
// ctx.Data["Email"] = email
|
ctx.Data["Email"] = email
|
||||||
// ctx.Data["Hours"] = setting.Service.ActiveCodeLives / 60
|
ctx.Data["Hours"] = setting.Service.ActiveCodeLives / 60
|
||||||
// ctx.Data["IsResetSent"] = true
|
ctx.Data["IsResetSent"] = true
|
||||||
// ctx.HTML(200, FORGOT_PASSWORD)
|
ctx.HTML(200, FORGOT_PASSWORD)
|
||||||
}
|
}
|
||||||
|
|
||||||
func ResetPasswd(ctx *middleware.Context) {
|
func ResetPasswd(ctx *middleware.Context) {
|
||||||
ctx.Data["Title"] = "Reset Password"
|
ctx.Data["Title"] = ctx.Tr("auth.reset_password")
|
||||||
|
|
||||||
code := ctx.Query("code")
|
code := ctx.Query("code")
|
||||||
if len(code) == 0 {
|
if len(code) == 0 {
|
||||||
|
@ -405,38 +409,39 @@ func ResetPasswd(ctx *middleware.Context) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func ResetPasswdPost(ctx *middleware.Context) {
|
func ResetPasswdPost(ctx *middleware.Context) {
|
||||||
// ctx.Data["Title"] = "Reset Password"
|
ctx.Data["Title"] = ctx.Tr("auth.reset_password")
|
||||||
|
|
||||||
// code := ctx.Query("code")
|
code := ctx.Query("code")
|
||||||
// if len(code) == 0 {
|
if len(code) == 0 {
|
||||||
// ctx.Error(404)
|
ctx.Error(404)
|
||||||
// return
|
return
|
||||||
// }
|
}
|
||||||
// ctx.Data["Code"] = code
|
ctx.Data["Code"] = code
|
||||||
|
|
||||||
// if u := models.VerifyUserActiveCode(code); u != nil {
|
if u := models.VerifyUserActiveCode(code); u != nil {
|
||||||
// // Validate password length.
|
// Validate password length.
|
||||||
// passwd := ctx.Query("passwd")
|
passwd := ctx.Query("password")
|
||||||
// if len(passwd) < 6 || len(passwd) > 30 {
|
if len(passwd) < 6 {
|
||||||
// ctx.Data["IsResetForm"] = true
|
ctx.Data["IsResetForm"] = true
|
||||||
// ctx.RenderWithErr("Password length should be in 6 and 30.", "user/reset_passwd", nil)
|
ctx.Data["Err_Password"] = true
|
||||||
// return
|
ctx.RenderWithErr(ctx.Tr("auth.password_too_short"), RESET_PASSWORD, nil)
|
||||||
// }
|
return
|
||||||
|
}
|
||||||
|
|
||||||
// u.Passwd = passwd
|
u.Passwd = passwd
|
||||||
// u.Rands = models.GetUserSalt()
|
u.Rands = models.GetUserSalt()
|
||||||
// u.Salt = models.GetUserSalt()
|
u.Salt = models.GetUserSalt()
|
||||||
// u.EncodePasswd()
|
u.EncodePasswd()
|
||||||
// if err := models.UpdateUser(u); err != nil {
|
if err := models.UpdateUser(u); err != nil {
|
||||||
// ctx.Handle(500, "user.ResetPasswd(UpdateUser)", err)
|
ctx.Handle(500, "UpdateUser", err)
|
||||||
// return
|
return
|
||||||
// }
|
}
|
||||||
|
|
||||||
// log.Trace("%s User password reset: %s", ctx.Req.RequestURI, u.Name)
|
log.Trace("User password reset: %s", u.Name)
|
||||||
// ctx.Redirect("/user/login")
|
ctx.Redirect("/user/login")
|
||||||
// return
|
return
|
||||||
// }
|
}
|
||||||
|
|
||||||
// ctx.Data["IsResetFailed"] = true
|
ctx.Data["IsResetFailed"] = true
|
||||||
// ctx.HTML(200, RESET_PASSWORD)
|
ctx.HTML(200, RESET_PASSWORD)
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,5 +0,0 @@
|
||||||
{
|
|
||||||
"language.fileExtensions": {
|
|
||||||
"tmpl": "html"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -1,4 +1,5 @@
|
||||||
{{template "ng/base/head" .}} {{template "ng/base/header" .}}
|
{{template "ng/base/head" .}}
|
||||||
|
{{template "ng/base/header" .}}
|
||||||
<div id="promo-wrapper">
|
<div id="promo-wrapper">
|
||||||
<div class="container clear">
|
<div class="container clear">
|
||||||
<div id="promo-logo" class="left">
|
<div id="promo-logo" class="left">
|
||||||
|
|
|
@ -1,36 +1,39 @@
|
||||||
{{template "base/head" .}}
|
{{template "ng/base/head" .}}
|
||||||
{{template "base/navbar" .}}
|
{{template "ng/base/header" .}}
|
||||||
<div id="body" class="container">
|
<div id="sign-wrapper">
|
||||||
<form action="/user/activate" method="post" class="form-horizontal card" id="login-card">
|
<form class="form-align form panel sign-panel sign-form container panel-radius" id="sign-up-form" action="/user/activate" method="post">
|
||||||
{{.CsrfTokenHtml}}
|
{{.CsrfTokenHtml}}
|
||||||
<h3>Activate Your Account</h3>
|
<div class="panel-header">
|
||||||
|
<h2>{{.i18n.Tr "auth.active_your_account"}}</h2>
|
||||||
|
</div>
|
||||||
|
<div class="panel-content">
|
||||||
{{if .IsActivatePage}}
|
{{if .IsActivatePage}}
|
||||||
{{if .ServiceNotEnabled}}
|
{{if .ServiceNotEnabled}}
|
||||||
<p>Sorry, Register Mail Confirmation has been disabled.</p>
|
<p>{{.i18n.Tr "auth.disable_register_mail"}}</p>
|
||||||
{{else if .ResendLimited}}
|
{{else if .ResendLimited}}
|
||||||
<p>Sorry, you are sending an activation e-mail too frequently. Please wait 3 minutes.</p>
|
<p>{{.i18n.Tr "auth.resent_limit_prompt"}}</p>
|
||||||
{{else}}
|
{{else}}
|
||||||
<p>A new confirmation e-mail has been sent to <b>{{.SignedUser.Email}}</b>, please check your inbox within the next {{.Hours}} hours to complete your registration.</p>
|
<p>{{.i18n.Tr "auth.confirmation_mail_sent_prompt" .SignedUser.Email .Hours | Str2html}}</p>
|
||||||
<hr/>
|
<hr/>
|
||||||
<a href="http://{{Mail2Domain .SignedUser.Email}}" class="btn btn-lg btn-success">Sign in to your e-mail</a>
|
<label></label>
|
||||||
|
<a class="btn btn-green btn-large btn-link btn-radius" href="http://{{Mail2Domain .SignedUser.Email}}">{{.i18n.Tr "auth.sign_in_email"}}</a>
|
||||||
{{end}}
|
{{end}}
|
||||||
{{else}}
|
{{else}}
|
||||||
{{if .IsSendRegisterMail}}
|
{{if .IsSendRegisterMail}}
|
||||||
<p>A confirmation e-mail has been sent to <b>{{.Email}}</b>, please check your inbox within the next {{.Hours}} hours to complete your registration.</p>
|
<p>{{.i18n.Tr "auth.confirmation_mail_sent_prompt" .Email .Hours | Str2html}}</p>
|
||||||
<hr/>
|
<hr/>
|
||||||
<a href="http://{{Mail2Domain .Email}}" class="btn btn-lg btn-success">Sign in to your e-mail</a>
|
<label></label>
|
||||||
|
<a class="btn btn-green btn-large btn-link btn-radius" href="http://{{Mail2Domain .Email}}">{{.i18n.Tr "auth.sign_in_email"}}</a>
|
||||||
{{else if .IsActivateFailed}}
|
{{else if .IsActivateFailed}}
|
||||||
<p>Sorry, your confirmation code has exipired or not valid.</p>
|
<p>{{.i18n.Tr "auth.invalid_code"}}</p>
|
||||||
{{else}}
|
{{else}}
|
||||||
<p>Hi, {{.SignedUser.Name}}, you have an unconfirmed email address(<b>{{.SignedUser.Email}}</b>). If you haven't received a confirmation e-mail or need to resend a new one, please click on the button below.</p>
|
<p>{{.i18n.Tr "auth.has_unconfirmed_mail" .SignedUser.Name .SignedUser.Email | Str2html}}</p>
|
||||||
<hr/>
|
<hr/>
|
||||||
<div class="form-group">
|
<label></label>
|
||||||
<div class="col-md-offset-4 col-md-6">
|
<button class="btn btn-blue btn-large btn-radius">{{.i18n.Tr "auth.resend_mail"}}</button>
|
||||||
<button type="submit" class="btn btn-lg btn-primary">Click here to resend your activation e-mail</button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
{{end}}
|
{{end}}
|
||||||
{{end}}
|
{{end}}
|
||||||
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
{{template "base/footer" .}}
|
{{template "ng/base/footer" .}}
|
||||||
|
|
|
@ -1,32 +1,32 @@
|
||||||
{{template "base/head" .}}
|
{{template "ng/base/head" .}}
|
||||||
{{template "base/navbar" .}}
|
{{template "ng/base/header" .}}
|
||||||
<div id="body" class="container">
|
<div id="sign-wrapper">
|
||||||
<form action="/user/forget_password" method="post" class="form-horizontal card" id="login-card">
|
<form class="form-align form panel sign-panel sign-form container panel-radius" id="sign-up-form" action="/user/forget_password" method="post">
|
||||||
{{.CsrfTokenHtml}}
|
{{.CsrfTokenHtml}}
|
||||||
<h3>Reset Your Password</h3>
|
<div class="panel-header">
|
||||||
{{template "base/alert" .}}
|
<h2>{{.i18n.Tr "auth.forgot_password"}}</h2>
|
||||||
{{if .IsResetSent}}
|
|
||||||
<p>A confirmation e-mail has been sent to <b>{{.Email}}</b>, please check your inbox within {{.Hours}} hours.</p>
|
|
||||||
<hr/>
|
|
||||||
<a href="http://{{Mail2Domain .Email}}" class="btn btn-lg btn-success">Sign in to your e-mail</a>
|
|
||||||
{{else if .IsResetRequest}}
|
|
||||||
<div class="form-group {{if .Err_Email}}has-error has-feedback{{end}}">
|
|
||||||
<label class="col-md-3 control-label">Email: </label>
|
|
||||||
<div class="col-md-7">
|
|
||||||
<input name="email" class="form-control" placeholder="Type your e-mail address" required="required">
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<hr/>
|
<div class="panel-content">
|
||||||
<div class="form-group">
|
{{template "ng/base/alert" .}}
|
||||||
<div class="col-md-offset-4 col-md-6">
|
{{if .IsResetSent}}
|
||||||
<button type="submit" class="btn btn-lg btn-primary">Click here to send resend confirmation e-mail</button>
|
<p>{{.i18n.Tr "auth.confirmation_mail_sent_prompt" .Email .Hours | Str2html}}</p>
|
||||||
|
<hr/>
|
||||||
|
<label></label>
|
||||||
|
<a class="btn btn-green btn-large btn-link btn-radius" href="http://{{Mail2Domain .Email}}">{{.i18n.Tr "auth.sign_in_email"}}</a>
|
||||||
|
{{else if .IsResetRequest}}
|
||||||
|
<div class="field">
|
||||||
|
<label class="req" for="email">{{.i18n.Tr "email"}}</label>
|
||||||
|
<input class="ipt ipt-large ipt-radius {{if .Err_Email}}ipt-error{{end}}" id="email" name="email" type="email" value="{{.email}}"required/>
|
||||||
</div>
|
</div>
|
||||||
|
<hr/>
|
||||||
|
<label></label>
|
||||||
|
<button class="btn btn-blue btn-large btn-radius">{{.i18n.Tr "auth.send_reset_mail"}}</button>
|
||||||
|
{{else if .IsResetDisable}}
|
||||||
|
<p>{{.i18n.Tr "auth.disable_register_mail"}}</p>
|
||||||
|
{{else if .ResendLimited}}
|
||||||
|
<p>{{.i18n.Tr "auth.resent_limit_prompt"}}</p>
|
||||||
|
{{end}}
|
||||||
</div>
|
</div>
|
||||||
{{else if .IsResetDisable}}
|
|
||||||
<p>Sorry, mail service is not enabled.</p>
|
|
||||||
{{else if .ResendLimited}}
|
|
||||||
<p>Sorry, you are sending an e-mail too frequently, please wait another 3 minutes and try again.</p>
|
|
||||||
{{end}}
|
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
{{template "base/footer" .}}
|
{{template "ng/base/footer" .}}
|
||||||
|
|
|
@ -1,26 +1,25 @@
|
||||||
{{template "base/head" .}}
|
{{template "ng/base/head" .}}
|
||||||
{{template "base/navbar" .}}
|
{{template "ng/base/header" .}}
|
||||||
<div id="body" class="container">
|
<div id="sign-wrapper">
|
||||||
<form action="/user/reset_password?code={{.Code}}" method="post" class="form-horizontal card" id="login-card">
|
<form class="form-align form panel sign-panel sign-form container panel-radius" id="sign-up-form" action="/user/reset_password?code={{.Code}}" method="post">
|
||||||
{{.CsrfTokenHtml}}
|
{{.CsrfTokenHtml}}
|
||||||
<h3>Reset Your Pasword</h3>
|
<div class="panel-header">
|
||||||
{{template "base/alert" .}}
|
<h2>{{.i18n.Tr "auth.reset_password"}}</h2>
|
||||||
{{if .IsResetForm}}
|
|
||||||
<div class="form-group">
|
|
||||||
<label class="col-md-4 control-label">Password: </label>
|
|
||||||
<div class="col-md-6">
|
|
||||||
<input name="passwd" type="password" class="form-control" placeholder="Type your password" required="required">
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<hr/>
|
<div class="panel-content">
|
||||||
<div class="form-group">
|
{{template "ng/base/alert" .}}
|
||||||
<div class="col-md-offset-4 col-md-6">
|
{{if .IsResetForm}}
|
||||||
<button type="submit" class="btn btn-lg btn-primary">Click here to reset your password</button>
|
<div class="field">
|
||||||
|
<label class="req" for="password">{{.i18n.Tr "password"}}</label>
|
||||||
|
<input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="password" name="password" type="password" value="{{.password}}" required/>
|
||||||
</div>
|
</div>
|
||||||
|
<hr/>
|
||||||
|
<label></label>
|
||||||
|
<button class="btn btn-blue btn-large btn-radius">{{.i18n.Tr "auth.reset_password_helper"}}</button>
|
||||||
|
{{else}}
|
||||||
|
<p>{{.i18n.Tr "auth.invalid_code"}}</p>
|
||||||
|
{{end}}
|
||||||
</div>
|
</div>
|
||||||
{{else}}
|
|
||||||
<p>Sorry, your confirmation code has expired or is not valid.</p>
|
|
||||||
{{end}}
|
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
{{template "base/footer" .}}
|
{{template "ng/base/footer" .}}
|
||||||
|
|
|
@ -7,30 +7,30 @@
|
||||||
</div>
|
</div>
|
||||||
<div class="panel-content">
|
<div class="panel-content">
|
||||||
{{template "ng/base/alert" .}}
|
{{template "ng/base/alert" .}}
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<label class="req" for="username">{{.i18n.Tr "home.uname_holder"}}</label>
|
<label class="req" for="username">{{.i18n.Tr "home.uname_holder"}}</label>
|
||||||
<input class="ipt ipt-large ipt-radius {{if .Err_UserName}}ipt-error{{end}}" id="username" name="uname" type="text" value="{{.uname}}" required/>
|
<input class="ipt ipt-large ipt-radius {{if .Err_UserName}}ipt-error{{end}}" id="username" name="uname" type="text" value="{{.uname}}" required/>
|
||||||
</p>
|
</div>
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<label class="req" for="password">{{.i18n.Tr "password"}}</label>
|
<label class="req" for="password">{{.i18n.Tr "password"}}</label>
|
||||||
<input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="password" name="password" type="password" required/>
|
<input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="password" name="password" type="password" required/>
|
||||||
</p>
|
</div>
|
||||||
{{if not .IsSocialLogin}}
|
{{if not .IsSocialLogin}}
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<span class="form-label"></span>
|
<span class="form-label"></span>
|
||||||
<input class="ipt-chk" id="remember" name="remember" type="checkbox"/> <strong>{{.i18n.Tr "auth.remember_me"}}</strong>
|
<input class="ipt-chk" id="remember" name="remember" type="checkbox"/> <strong>{{.i18n.Tr "auth.remember_me"}}</strong>
|
||||||
</p>
|
</div>
|
||||||
{{end}}
|
{{end}}
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<span class="form-label"></span>
|
<span class="form-label"></span>
|
||||||
<button class="btn btn-green btn-large btn-radius">{{.i18n.Tr "sign_in"}}</button>
|
<button class="btn btn-green btn-large btn-radius">{{.i18n.Tr "sign_in"}}</button>
|
||||||
{{if not .IsSocialLogin}}<a href="/user/forget_password">{{.i18n.Tr "auth.forget_password"}}</a>{{end}}
|
{{if not .IsSocialLogin}}<a href="/user/forget_password">{{.i18n.Tr "auth.forget_password"}}</a>{{end}}
|
||||||
</p>
|
</div>
|
||||||
{{if not .IsSocialLogin}}
|
{{if not .IsSocialLogin}}
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<span class="form-label"></span>
|
<label></label>
|
||||||
<a href="/user/sign_up">{{.i18n.Tr "auth.sign_up_now" | Str2html}}</a>
|
<a href="/user/sign_up">{{.i18n.Tr "auth.sign_up_now" | Str2html}}</a>
|
||||||
</p>
|
</div>
|
||||||
{{if .OauthEnabled}}
|
{{if .OauthEnabled}}
|
||||||
<hr/>
|
<hr/>
|
||||||
<div id="sign-social" class="text-center social-buttons">
|
<div id="sign-social" class="text-center social-buttons">
|
||||||
|
|
|
@ -10,38 +10,38 @@
|
||||||
{{if .DisableRegistration}}
|
{{if .DisableRegistration}}
|
||||||
<p>{{.i18n.Tr "auth.disable_register_prompt"}}</p>
|
<p>{{.i18n.Tr "auth.disable_register_prompt"}}</p>
|
||||||
{{else}}
|
{{else}}
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<label class="req" for="username">{{.i18n.Tr "username"}}</label>
|
<label class="req" for="username">{{.i18n.Tr "username"}}</label>
|
||||||
<input class="ipt ipt-large ipt-radius {{if .Err_UserName}}ipt-error{{end}}" id="username" name="uname" type="text" value="{{.uname}}" required/>
|
<input class="ipt ipt-large ipt-radius {{if .Err_UserName}}ipt-error{{end}}" id="username" name="uname" type="text" value="{{.uname}}" required/>
|
||||||
</p>
|
</div>
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<label class="req" for="email">{{.i18n.Tr "email"}}</label>
|
<label class="req" for="email">{{.i18n.Tr "email"}}</label>
|
||||||
<input class="ipt ipt-large ipt-radius {{if .Err_Email}}ipt-error{{end}}" id="email" name="email" type="email" value="{{.email}}"required/>
|
<input class="ipt ipt-large ipt-radius {{if .Err_Email}}ipt-error{{end}}" id="email" name="email" type="email" value="{{.email}}"required/>
|
||||||
</p>
|
</div>
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<label class="req" for="password">{{.i18n.Tr "password"}}</label>
|
<label class="req" for="password">{{.i18n.Tr "password"}}</label>
|
||||||
<input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="password" name="password" type="password" value="{{.password}}" required/>
|
<input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="password" name="password" type="password" value="{{.password}}" required/>
|
||||||
</p>
|
</div>
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<label class="req" for="re-type">{{.i18n.Tr "re_type"}}</label>
|
<label class="req" for="re-type">{{.i18n.Tr "re_type"}}</label>
|
||||||
<input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="re-type" name="retype" type="password" required/>
|
<input class="ipt ipt-large ipt-radius {{if .Err_Password}}ipt-error{{end}}" id="re-type" name="retype" type="password" required/>
|
||||||
</p>
|
</div>
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<label></label>
|
<label></label>
|
||||||
{{.Captcha.CreateHtml}}
|
{{.Captcha.CreateHtml}}
|
||||||
</p>
|
</div>
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<label class="req" for="captcha">{{.i18n.Tr "captcha"}}</label>
|
<label class="req" for="captcha">{{.i18n.Tr "captcha"}}</label>
|
||||||
<input class="ipt ipt-large ipt-radius {{if .Err_Captcha}}ipt-error{{end}}" id="captcha" name="captcha" type="text" required/>
|
<input class="ipt ipt-large ipt-radius {{if .Err_Captcha}}ipt-error{{end}}" id="captcha" name="captcha" type="text" required/>
|
||||||
</p>
|
</div>
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<span class="form-label"></span>
|
<span class="form-label"></span>
|
||||||
<button class="btn btn-blue btn-large btn-radius">{{.i18n.Tr "auth.create_new_account"}}</button>
|
<button class="btn btn-blue btn-large btn-radius">{{.i18n.Tr "auth.create_new_account"}}</button>
|
||||||
</p>
|
</div>
|
||||||
<p class="field">
|
<div class="field">
|
||||||
<span class="form-label"></span>
|
<span class="form-label"></span>
|
||||||
<a href="/user/login">{{if .IsSocialLogin}}{{.i18n.Tr "auth.social_register_hepler_msg"}}{{else}}{{.i18n.Tr "auth.register_hepler_msg"}}{{end}}</a>
|
<a href="/user/login">{{if .IsSocialLogin}}{{.i18n.Tr "auth.social_register_hepler_msg"}}{{else}}{{.i18n.Tr "auth.register_hepler_msg"}}{{end}}</a>
|
||||||
</p>
|
</div>
|
||||||
{{end}}
|
{{end}}
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
|
Reference in a new issue