2016-06-25 21:12:17 +02:00
|
|
|
<div class="container-fluid container-fluid-custom" element-height ng-controller="SignUpController as vm">
|
2016-07-01 12:37:17 +02:00
|
|
|
<modal-dialog modal-title="// vm.modalTitle //" modal-message="// vm.modalMessage //" confirm-only="vm.confirmOnly" action="vm.action()"></modal-dialog>
|
|
|
|
<div class="container container-custom" ng-init="vm.targetType = {{.AddNew}}">
|
2016-05-06 14:37:44 +02:00
|
|
|
<div class="row extend-height">
|
2016-05-09 12:53:40 +02:00
|
|
|
<div class="section">
|
2016-06-22 09:15:25 +02:00
|
|
|
<h1 class="col-md-12 col-md-offset-2 main-title title-color">
|
|
|
|
{{ if eq .AddNew true }}
|
|
|
|
// 'add_new_title' | tr //
|
|
|
|
{{ else }}
|
|
|
|
// 'sign_up' | tr //
|
|
|
|
{{ end }}
|
|
|
|
</h1>
|
2016-05-09 12:53:40 +02:00
|
|
|
<div class="row">
|
|
|
|
<div class="col-md-12 col-md-offset-2 main-content">
|
2016-07-07 13:59:18 +02:00
|
|
|
<form name="form" class="form-horizontal css-form" novalidate>
|
2016-05-09 12:53:40 +02:00
|
|
|
<div class="form-group">
|
2016-05-13 12:48:06 +02:00
|
|
|
<label for="username" class="col-sm-3 control-label">// 'username' | tr //:</label>
|
2016-05-09 12:53:40 +02:00
|
|
|
<div class="col-sm-7">
|
2016-05-16 07:44:35 +02:00
|
|
|
<input type="text" class="form-control" id="username" ng-model="user.username" name="uUsername" ng-model-options="{ updateOn: 'blur' }" required maxlength="20" invalid-chars user-exists data-target="username">
|
2016-07-07 13:59:18 +02:00
|
|
|
<div class="error-message" ng-messages="(form.$submitted || form.uUsername.$touched) && form.uUsername.$error" >
|
2016-05-13 12:48:06 +02:00
|
|
|
<span ng-message="required">// 'username_is_required' | tr //</span>
|
|
|
|
<span ng-message="maxlength">// 'username_is_too_long' | tr //</span>
|
|
|
|
<span ng-message="invalidChars">// 'username_contains_illegal_chars' | tr //</span>
|
|
|
|
<span ng-message="userExists">// 'username_has_been_taken' | tr //</span>
|
2016-05-06 14:37:44 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
2016-05-09 12:53:40 +02:00
|
|
|
<div class="col-sm-2">
|
|
|
|
<span class="asterisk">*</span>
|
2016-05-06 14:37:44 +02:00
|
|
|
</div>
|
2016-05-09 12:53:40 +02:00
|
|
|
</div>
|
|
|
|
<div class="form-group">
|
2016-05-13 12:48:06 +02:00
|
|
|
<label for="email" class="col-sm-3 control-label">// 'email' | tr //:</label>
|
2016-05-09 12:53:40 +02:00
|
|
|
<div class="col-sm-7">
|
2016-05-16 07:44:35 +02:00
|
|
|
<input type="email" class="form-control" id="email" ng-model="user.email" name="uEmail" ng-model-options="{ updateOn: 'blur' }" required user-exists data-target="email" maxlength="50">
|
2016-07-07 13:59:18 +02:00
|
|
|
<div class="error-message" ng-messages="(form.$submitted || form.uEmail.$touched) &&form.uEmail.$error">
|
2016-05-13 12:48:06 +02:00
|
|
|
<span ng-message="required">// 'email_is_required' | tr //</span>
|
|
|
|
<span ng-message="email">// 'email_content_illegal' | tr //</span>
|
|
|
|
<span ng-message="userExists">// 'email_has_been_taken' | tr //</span>
|
2016-05-16 07:44:35 +02:00
|
|
|
<span ng-message="maxlength">// 'email_is_too_long' | tr //</span>
|
2016-05-06 14:37:44 +02:00
|
|
|
</div>
|
2016-05-13 12:48:06 +02:00
|
|
|
<p class="help-block small-size-fonts">// 'email_desc' | tr //</p>
|
2016-05-06 14:37:44 +02:00
|
|
|
</div>
|
2016-05-09 12:53:40 +02:00
|
|
|
<div class="col-sm-2">
|
|
|
|
<span class="asterisk">*</span>
|
2016-05-06 14:37:44 +02:00
|
|
|
</div>
|
2016-05-09 12:53:40 +02:00
|
|
|
</div>
|
|
|
|
<div class="form-group">
|
2016-05-13 12:48:06 +02:00
|
|
|
<label for="fullName" class="col-sm-3 control-label">// 'full_name' | tr //:</label>
|
2016-05-09 12:53:40 +02:00
|
|
|
<div class="col-sm-7">
|
2016-05-16 07:44:35 +02:00
|
|
|
<input type="text" class="form-control" id="fullName" ng-model="user.fullName" name="uFullName" ng-model-options="{ updateOn: 'blur' }" required maxlength="20" invalid-chars>
|
2016-07-07 13:59:18 +02:00
|
|
|
<div class="error-message" ng-messages="(form.$submitted || form.uFullName.$touched) && form.uFullName.$error">
|
2016-05-13 12:48:06 +02:00
|
|
|
<span ng-message="required">// 'full_name_is_required' | tr //</span>
|
|
|
|
<span ng-message="invalidChars">// 'full_name_contains_illegal_chars' | tr //</span>
|
|
|
|
<span ng-message="maxlength">// 'full_name_is_too_long' | tr //</span>
|
2016-05-06 14:37:44 +02:00
|
|
|
</div>
|
2016-05-13 12:48:06 +02:00
|
|
|
<p class="help-block small-size-fonts">// 'full_name_desc' | tr //</p>
|
2016-05-09 12:53:40 +02:00
|
|
|
</div>
|
|
|
|
<div class="col-sm-2">
|
|
|
|
<span class="asterisk">*</span>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="form-group">
|
2016-05-13 12:48:06 +02:00
|
|
|
<label for="password" class="col-sm-3 control-label">// 'password' | tr //:</label>
|
2016-05-09 12:53:40 +02:00
|
|
|
<div class="col-sm-7">
|
2016-05-16 07:44:35 +02:00
|
|
|
<input type="password" class="form-control" id="password" ng-model="user.password" name="uPassword" ng-model-options="{ updateOn: 'blur' }" required password>
|
2016-07-07 13:59:18 +02:00
|
|
|
<div class="error-message" ng-messages="(form.$submitted || form.uPassword.$touched) && form.uPassword.$error">
|
2016-05-13 12:48:06 +02:00
|
|
|
<span ng-message="required">// 'password_is_required' | tr //</span>
|
|
|
|
<span ng-message="password">// 'password_is_invalid' | tr //</span>
|
2016-05-06 14:37:44 +02:00
|
|
|
</div>
|
2016-05-13 12:48:06 +02:00
|
|
|
<p class="help-block small-size-fonts">// 'password_desc' | tr //</p>
|
2016-05-09 12:53:40 +02:00
|
|
|
</div>
|
|
|
|
<div class="col-sm-2">
|
|
|
|
<span class="asterisk">*</span>
|
2016-05-06 14:37:44 +02:00
|
|
|
</div>
|
2016-05-09 12:53:40 +02:00
|
|
|
</div>
|
|
|
|
<div class="form-group">
|
2016-05-13 12:48:06 +02:00
|
|
|
<label for="confirmPassword" class="col-sm-3 control-label">// 'confirm_password' | tr //:</label>
|
2016-05-09 12:53:40 +02:00
|
|
|
<div class="col-sm-7">
|
2016-05-16 07:44:35 +02:00
|
|
|
<input type="password" class="form-control" id="confirmPassword" ng-model="user.confirmPassword" name="uConfirmPassword" ng-model-options="{ updateOn: 'blur' }" compare-to="user.password">
|
2016-07-07 13:59:18 +02:00
|
|
|
<div class="error-message" ng-messages="(form.$submitted || form.uConfirmPassword.$touched) && form.uConfirmPassword.$error">
|
2016-05-13 12:48:06 +02:00
|
|
|
<span ng-message="compareTo">// 'password_does_not_match' | tr //</span>
|
2016-05-06 14:37:44 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
2016-05-09 12:53:40 +02:00
|
|
|
<div class="col-sm-2">
|
|
|
|
<span class="asterisk">*</span>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="form-group">
|
2016-05-13 12:48:06 +02:00
|
|
|
<label for="comments" class="col-sm-3 control-label">// 'comments' | tr //:</label>
|
2016-05-09 12:53:40 +02:00
|
|
|
<div class="col-sm-7">
|
2016-05-16 07:44:35 +02:00
|
|
|
<input type="text" class="form-control" id="comments" ng-model="user.comment" name="uComments" ng-model-options="{ updateOn: 'blur' }" maxlength="20">
|
2016-07-07 13:59:18 +02:00
|
|
|
<div class="error-message" ng-messages="(form.$submitted || form.uComments.$touched) && form.uComments.$error">
|
2016-05-13 12:48:06 +02:00
|
|
|
<span ng-show="maxlength">// 'comment_is_too_long' | tr //</span>
|
2016-05-06 14:37:44 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
2016-05-09 12:53:40 +02:00
|
|
|
</div>
|
|
|
|
<div class="form-group">
|
|
|
|
<div class="col-md-offset-8 col-md-10">
|
2016-06-22 09:15:25 +02:00
|
|
|
{{ if eq .AddNew true }}
|
2016-07-07 13:59:18 +02:00
|
|
|
<button type="submit" class="btn btn-success" ng-click="form.$valid && vm.signUp(user)">// 'add_new' | tr //</button>
|
2016-06-22 09:15:25 +02:00
|
|
|
{{ else }}
|
2016-07-07 13:59:18 +02:00
|
|
|
<button type="submit" class="btn btn-success" ng-click="form.$valid && vm.signUp(user)">// 'sign_up' | tr //</button>
|
2016-06-22 09:15:25 +02:00
|
|
|
{{ end }}
|
2016-05-09 12:53:40 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2016-05-06 14:37:44 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|