register.mako
150 lines
| 5.7 KiB
| application/x-mako
|
MakoHtmlLexer
r1535 | ## -*- coding: utf-8 -*- | |||
r1282 | <%inherit file="base/root.mako"/> | |||
<%def name="title()"> | ||||
${_('Create an Account')} | ||||
%if c.rhodecode_name: | ||||
· ${h.branding(c.rhodecode_name)} | ||||
%endif | ||||
</%def> | ||||
<style>body{background-color:#eeeeee;}</style> | ||||
<div class="loginbox"> | ||||
r4544 | <div class="header-account"> | |||
r1282 | <div id="header-inner" class="title"> | |||
<div id="logo"> | ||||
<div class="logo-wrapper"> | ||||
r3541 | <a href="${h.route_path('home')}"><img src="${h.asset('images/rhodecode-logo-white-60x60.png')}" alt="RhodeCode"/></a> | |||
r1282 | </div> | |||
r3543 | % if c.rhodecode_name: | |||
<div class="branding"> | ||||
<a href="${h.route_path('home')}">${h.branding(c.rhodecode_name)}</a> | ||||
</div> | ||||
% endif | ||||
r1282 | </div> | |||
</div> | ||||
</div> | ||||
<div class="loginwrapper"> | ||||
r1485 | <rhodecode-toast id="notifications"></rhodecode-toast> | |||
r4546 | ||||
<div class="auth-image-wrapper"> | ||||
r1282 | <img class="sign-in-image" src="${h.asset('images/sign-in.png')}" alt="RhodeCode"/> | |||
</div> | ||||
r4546 | ||||
<div id="register"> | ||||
<%block name="above_register_button" /> | ||||
r1282 | <!-- login --> | |||
<div class="sign-in-title"> | ||||
r3257 | % if external_auth_provider: | |||
<h1>${_('Create an account linked with {}').format(external_auth_provider)}</h1> | ||||
r2905 | % else: | |||
<h1>${_('Create an account')}</h1> | ||||
% endif | ||||
r1282 | <h4>${h.link_to(_("Go to the login page to sign in with an existing account."), request.route_path('login'))}</h4> | |||
</div> | ||||
<div class="inner form"> | ||||
${h.form(request.route_path('register'), needs_csrf_token=False)} | ||||
<label for="username">${_('Username')}:</label> | ||||
${h.text('username', defaults.get('username'))} | ||||
%if 'username' in errors: | ||||
<span class="error-message">${errors.get('username')}</span> | ||||
<br /> | ||||
%endif | ||||
r3257 | % if external_auth_provider: | |||
## store internal marker about external identity | ||||
${h.hidden('external_identity', external_auth_provider)} | ||||
r2905 | ## hide password prompts for social auth | |||
<div style="display: none"> | ||||
% endif | ||||
r1282 | <label for="password">${_('Password')}:</label> | |||
${h.password('password', defaults.get('password'))} | ||||
%if 'password' in errors: | ||||
<span class="error-message">${errors.get('password')}</span> | ||||
<br /> | ||||
%endif | ||||
<label for="password_confirmation">${_('Re-enter password')}:</label> | ||||
${h.password('password_confirmation', defaults.get('password_confirmation'))} | ||||
%if 'password_confirmation' in errors: | ||||
<span class="error-message">${errors.get('password_confirmation')}</span> | ||||
<br /> | ||||
%endif | ||||
r3257 | % if external_auth_provider: | |||
r2905 | ## hide password prompts for social auth | |||
</div> | ||||
% endif | ||||
r1282 | <label for="firstname">${_('First Name')}:</label> | |||
${h.text('firstname', defaults.get('firstname'))} | ||||
%if 'firstname' in errors: | ||||
<span class="error-message">${errors.get('firstname')}</span> | ||||
<br /> | ||||
%endif | ||||
<label for="lastname">${_('Last Name')}:</label> | ||||
${h.text('lastname', defaults.get('lastname'))} | ||||
%if 'lastname' in errors: | ||||
<span class="error-message">${errors.get('lastname')}</span> | ||||
<br /> | ||||
%endif | ||||
<label for="email">${_('Email')}:</label> | ||||
${h.text('email', defaults.get('email'))} | ||||
%if 'email' in errors: | ||||
<span class="error-message">${errors.get('email')}</span> | ||||
<br /> | ||||
%endif | ||||
%if captcha_active: | ||||
<div> | ||||
<label for="recaptcha">${_('Captcha')}:</label> | ||||
${h.hidden('recaptcha_field')} | ||||
<div id="recaptcha"></div> | ||||
%if 'recaptcha_field' in errors: | ||||
<span class="error-message">${errors.get('recaptcha_field')}</span> | ||||
<br /> | ||||
%endif | ||||
</div> | ||||
%endif | ||||
%if not auto_active: | ||||
<p class="activation_msg"> | ||||
${_('Account activation requires admin approval.')} | ||||
</p> | ||||
%endif | ||||
<p class="register_message"> | ||||
${register_message|n} | ||||
</p> | ||||
r3386 | ${h.submit('sign_up',_('Create Account'), class_="btn sign-in", title=_('Create Account in {}').format(c.rhodecode_edition))} | |||
r1282 | ${h.end_form()} | |||
</div> | ||||
<%block name="below_register_button" /> | ||||
</div> | ||||
</div> | ||||
</div> | ||||
r2731 | ||||
r1282 | <script type="text/javascript"> | |||
r2731 | $(document).ready(function(){ | |||
r1282 | $('#username').focus(); | |||
r2731 | }); | |||
r1282 | </script> | |||
r2731 | ||||
% if captcha_active: | ||||
<script type="text/javascript"> | ||||
var onloadCallback = function() { | ||||
grecaptcha.render('recaptcha', { | ||||
'sitekey' : "${captcha_public_key}" | ||||
}); | ||||
}; | ||||
</script> | ||||
<script src="https://www.google.com/recaptcha/api.js?onload=onloadCallback&render=explicit" async defer></script> | ||||
% endif | ||||