2017-04-15 09:12:23 -07:00
|
|
|
<template>
|
2018-03-31 11:14:36 -07:00
|
|
|
<div class="settings panel panel-default">
|
|
|
|
<div class="panel-heading">
|
2019-07-05 00:17:44 -07:00
|
|
|
{{ $t('registration.registration') }}
|
2017-04-15 09:12:23 -07:00
|
|
|
</div>
|
|
|
|
<div class="panel-body">
|
2019-07-05 00:17:44 -07:00
|
|
|
<form
|
|
|
|
class="registration-form"
|
|
|
|
@submit.prevent="submit(user)"
|
|
|
|
>
|
|
|
|
<div class="container">
|
|
|
|
<div class="text-fields">
|
|
|
|
<div
|
|
|
|
class="form-group"
|
|
|
|
:class="{ 'form-group--error': $v.user.username.$error }"
|
|
|
|
>
|
|
|
|
<label
|
|
|
|
class="form--label"
|
|
|
|
for="sign-up-username"
|
|
|
|
>{{ $t('login.username') }}</label>
|
|
|
|
<input
|
|
|
|
id="sign-up-username"
|
|
|
|
v-model.trim="$v.user.username.$model"
|
|
|
|
:disabled="isPending"
|
|
|
|
class="form-control"
|
|
|
|
:placeholder="$t('registration.username_placeholder')"
|
|
|
|
>
|
2017-04-17 03:57:02 -07:00
|
|
|
</div>
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
v-if="$v.user.username.$dirty"
|
|
|
|
class="form-error"
|
|
|
|
>
|
2018-12-05 07:17:29 -08:00
|
|
|
<ul>
|
|
|
|
<li v-if="!$v.user.username.required">
|
2019-07-05 00:17:44 -07:00
|
|
|
<span>{{ $t('registration.validations.username_required') }}</span>
|
2018-12-05 07:17:29 -08:00
|
|
|
</li>
|
|
|
|
</ul>
|
2017-04-17 03:57:02 -07:00
|
|
|
</div>
|
2018-12-05 01:43:01 -08:00
|
|
|
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
class="form-group"
|
|
|
|
:class="{ 'form-group--error': $v.user.fullname.$error }"
|
|
|
|
>
|
|
|
|
<label
|
|
|
|
class="form--label"
|
|
|
|
for="sign-up-fullname"
|
|
|
|
>{{ $t('registration.fullname') }}</label>
|
|
|
|
<input
|
|
|
|
id="sign-up-fullname"
|
|
|
|
v-model.trim="$v.user.fullname.$model"
|
|
|
|
:disabled="isPending"
|
|
|
|
class="form-control"
|
|
|
|
:placeholder="$t('registration.fullname_placeholder')"
|
|
|
|
>
|
2018-12-05 07:42:33 -08:00
|
|
|
</div>
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
v-if="$v.user.fullname.$dirty"
|
|
|
|
class="form-error"
|
|
|
|
>
|
2018-12-05 07:42:33 -08:00
|
|
|
<ul>
|
|
|
|
<li v-if="!$v.user.fullname.required">
|
2019-07-05 00:17:44 -07:00
|
|
|
<span>{{ $t('registration.validations.fullname_required') }}</span>
|
2018-12-05 07:42:33 -08:00
|
|
|
</li>
|
|
|
|
</ul>
|
2017-04-17 03:57:02 -07:00
|
|
|
</div>
|
2018-12-05 01:43:01 -08:00
|
|
|
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
class="form-group"
|
|
|
|
:class="{ 'form-group--error': $v.user.email.$error }"
|
|
|
|
>
|
|
|
|
<label
|
|
|
|
class="form--label"
|
|
|
|
for="email"
|
|
|
|
>{{ $t('registration.email') }}</label>
|
|
|
|
<input
|
|
|
|
id="email"
|
|
|
|
v-model="$v.user.email.$model"
|
|
|
|
:disabled="isPending"
|
|
|
|
class="form-control"
|
|
|
|
type="email"
|
|
|
|
>
|
2017-04-17 03:57:02 -07:00
|
|
|
</div>
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
v-if="$v.user.email.$dirty"
|
|
|
|
class="form-error"
|
|
|
|
>
|
2018-12-05 07:17:29 -08:00
|
|
|
<ul>
|
|
|
|
<li v-if="!$v.user.email.required">
|
2019-07-05 00:17:44 -07:00
|
|
|
<span>{{ $t('registration.validations.email_required') }}</span>
|
2018-12-05 07:17:29 -08:00
|
|
|
</li>
|
|
|
|
</ul>
|
2017-04-17 03:57:02 -07:00
|
|
|
</div>
|
2018-12-05 01:43:01 -08:00
|
|
|
|
2019-07-05 00:17:44 -07:00
|
|
|
<div class="form-group">
|
|
|
|
<label
|
|
|
|
class="form--label"
|
|
|
|
for="bio"
|
|
|
|
>{{ $t('registration.bio') }} ({{ $t('general.optional') }})</label>
|
|
|
|
<textarea
|
|
|
|
id="bio"
|
|
|
|
v-model="user.bio"
|
|
|
|
:disabled="isPending"
|
|
|
|
class="form-control"
|
|
|
|
:placeholder="bioPlaceholder"
|
|
|
|
/>
|
2018-12-05 01:43:01 -08:00
|
|
|
</div>
|
|
|
|
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
class="form-group"
|
|
|
|
:class="{ 'form-group--error': $v.user.password.$error }"
|
|
|
|
>
|
|
|
|
<label
|
|
|
|
class="form--label"
|
|
|
|
for="sign-up-password"
|
|
|
|
>{{ $t('login.password') }}</label>
|
|
|
|
<input
|
|
|
|
id="sign-up-password"
|
|
|
|
v-model="user.password"
|
|
|
|
:disabled="isPending"
|
|
|
|
class="form-control"
|
|
|
|
type="password"
|
|
|
|
>
|
2018-12-05 01:43:01 -08:00
|
|
|
</div>
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
v-if="$v.user.password.$dirty"
|
|
|
|
class="form-error"
|
|
|
|
>
|
2018-12-05 07:17:29 -08:00
|
|
|
<ul>
|
|
|
|
<li v-if="!$v.user.password.required">
|
2019-07-05 00:17:44 -07:00
|
|
|
<span>{{ $t('registration.validations.password_required') }}</span>
|
2018-12-05 07:17:29 -08:00
|
|
|
</li>
|
|
|
|
</ul>
|
2018-12-05 01:43:01 -08:00
|
|
|
</div>
|
|
|
|
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
class="form-group"
|
|
|
|
:class="{ 'form-group--error': $v.user.confirm.$error }"
|
|
|
|
>
|
|
|
|
<label
|
|
|
|
class="form--label"
|
|
|
|
for="sign-up-password-confirmation"
|
|
|
|
>{{ $t('registration.password_confirm') }}</label>
|
|
|
|
<input
|
|
|
|
id="sign-up-password-confirmation"
|
|
|
|
v-model="user.confirm"
|
|
|
|
:disabled="isPending"
|
|
|
|
class="form-control"
|
|
|
|
type="password"
|
|
|
|
>
|
2018-12-05 01:43:01 -08:00
|
|
|
</div>
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
v-if="$v.user.confirm.$dirty"
|
|
|
|
class="form-error"
|
|
|
|
>
|
2018-12-05 07:17:29 -08:00
|
|
|
<ul>
|
|
|
|
<li v-if="!$v.user.confirm.required">
|
2019-07-05 00:17:44 -07:00
|
|
|
<span>{{ $t('registration.validations.password_confirmation_required') }}</span>
|
2018-12-05 07:17:29 -08:00
|
|
|
</li>
|
|
|
|
<li v-if="!$v.user.confirm.sameAsPassword">
|
2019-07-05 00:17:44 -07:00
|
|
|
<span>{{ $t('registration.validations.password_confirmation_match') }}</span>
|
2018-12-05 07:17:29 -08:00
|
|
|
</li>
|
|
|
|
</ul>
|
2017-04-17 03:57:02 -07:00
|
|
|
</div>
|
2018-12-05 08:19:39 -08:00
|
|
|
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
v-if="captcha.type != 'none'"
|
|
|
|
id="captcha-group"
|
|
|
|
class="form-group"
|
|
|
|
>
|
|
|
|
<label
|
|
|
|
class="form--label"
|
|
|
|
for="captcha-label"
|
|
|
|
>{{ $t('captcha') }}</label>
|
2018-12-20 13:25:36 -08:00
|
|
|
|
2018-12-14 16:05:47 -08:00
|
|
|
<template v-if="captcha.type == 'kocaptcha'">
|
2019-07-05 00:17:44 -07:00
|
|
|
<img
|
|
|
|
:src="captcha.url"
|
|
|
|
@click="setCaptcha"
|
|
|
|
>
|
2018-12-14 16:05:47 -08:00
|
|
|
|
2019-07-05 00:17:44 -07:00
|
|
|
<sub>{{ $t('registration.new_captcha') }}</sub>
|
2018-12-14 16:05:47 -08:00
|
|
|
|
2019-07-05 00:17:44 -07:00
|
|
|
<input
|
|
|
|
id="captcha-answer"
|
|
|
|
v-model="captcha.solution"
|
|
|
|
:disabled="isPending"
|
|
|
|
class="form-control"
|
|
|
|
type="text"
|
|
|
|
autocomplete="off"
|
|
|
|
>
|
2018-12-14 16:05:47 -08:00
|
|
|
</template>
|
|
|
|
</div>
|
|
|
|
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
v-if="token"
|
|
|
|
class="form-group"
|
|
|
|
>
|
|
|
|
<label for="token">{{ $t('registration.token') }}</label>
|
|
|
|
<input
|
|
|
|
id="token"
|
|
|
|
v-model="token"
|
|
|
|
disabled="true"
|
|
|
|
class="form-control"
|
|
|
|
type="text"
|
|
|
|
>
|
2018-08-05 00:01:38 -07:00
|
|
|
</div>
|
2019-07-05 00:17:44 -07:00
|
|
|
<div class="form-group">
|
|
|
|
<button
|
|
|
|
:disabled="isPending"
|
|
|
|
type="submit"
|
|
|
|
class="btn btn-default"
|
|
|
|
>
|
|
|
|
{{ $t('general.submit') }}
|
|
|
|
</button>
|
2017-04-17 03:57:02 -07:00
|
|
|
</div>
|
|
|
|
</div>
|
2018-12-05 08:19:39 -08:00
|
|
|
|
2019-07-06 14:54:17 -07:00
|
|
|
<!-- eslint-disable vue/no-v-html -->
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
class="terms-of-service"
|
|
|
|
v-html="termsOfService"
|
|
|
|
/>
|
2019-07-06 14:54:17 -07:00
|
|
|
<!-- eslint-enable vue/no-v-html -->
|
2017-04-15 09:12:23 -07:00
|
|
|
</div>
|
2019-07-05 00:17:44 -07:00
|
|
|
<div
|
|
|
|
v-if="serverValidationErrors.length"
|
|
|
|
class="form-group"
|
|
|
|
>
|
|
|
|
<div class="alert error">
|
2019-07-06 14:54:17 -07:00
|
|
|
<span
|
|
|
|
v-for="error in serverValidationErrors"
|
|
|
|
:key="error"
|
|
|
|
>{{ error }}</span>
|
2018-12-03 10:43:58 -08:00
|
|
|
</div>
|
2017-04-15 09:12:23 -07:00
|
|
|
</div>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script src="./registration.js"></script>
|
|
|
|
<style lang="scss">
|
2018-03-31 19:28:20 -07:00
|
|
|
@import '../../_variables.scss';
|
2018-12-05 11:05:43 -08:00
|
|
|
$validations-cRed: #f04124;
|
2017-04-15 09:12:23 -07:00
|
|
|
|
|
|
|
.registration-form {
|
2018-04-07 09:30:27 -07:00
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
margin: 0.6em;
|
2017-04-17 03:57:02 -07:00
|
|
|
|
2018-04-07 09:30:27 -07:00
|
|
|
.container {
|
|
|
|
display: flex;
|
|
|
|
flex-direction: row;
|
|
|
|
//margin-bottom: 1em;
|
|
|
|
}
|
2017-04-17 03:57:02 -07:00
|
|
|
|
2018-04-07 09:30:27 -07:00
|
|
|
.terms-of-service {
|
|
|
|
flex: 0 1 50%;
|
|
|
|
margin: 0.8em;
|
|
|
|
}
|
2017-04-15 09:12:23 -07:00
|
|
|
|
2018-04-07 09:30:27 -07:00
|
|
|
.text-fields {
|
|
|
|
margin-top: 0.6em;
|
|
|
|
flex: 1 0;
|
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
}
|
2017-04-17 03:57:02 -07:00
|
|
|
|
2019-02-24 11:30:29 -08:00
|
|
|
textarea {
|
|
|
|
min-height: 100px;
|
|
|
|
}
|
|
|
|
|
2018-04-07 09:30:27 -07:00
|
|
|
.form-group {
|
|
|
|
display: flex;
|
|
|
|
flex-direction: column;
|
|
|
|
padding: 0.3em 0.0em 0.3em;
|
|
|
|
line-height:24px;
|
2018-12-05 01:43:01 -08:00
|
|
|
margin-bottom: 1em;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-group--error {
|
|
|
|
animation-name: shakeError;
|
|
|
|
animation-duration: .6s;
|
|
|
|
animation-timing-function: ease-in-out;
|
|
|
|
}
|
|
|
|
|
|
|
|
.form-group--error .form--label {
|
2018-12-05 11:05:43 -08:00
|
|
|
color: $validations-cRed;
|
2018-12-05 11:35:15 -08:00
|
|
|
color: var(--cRed, $validations-cRed);
|
2018-12-05 01:43:01 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
.form-error {
|
|
|
|
margin-top: -0.7em;
|
|
|
|
text-align: left;
|
2018-12-05 07:42:33 -08:00
|
|
|
|
2018-12-05 01:43:01 -08:00
|
|
|
span {
|
|
|
|
font-size: 12px;
|
|
|
|
}
|
2018-12-05 07:17:29 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
.form-error ul {
|
|
|
|
list-style: none;
|
|
|
|
padding: 0 0 0 5px;
|
|
|
|
margin-top: 0;
|
|
|
|
|
|
|
|
li::before {
|
|
|
|
content: "• ";
|
|
|
|
}
|
2018-04-07 09:30:27 -07:00
|
|
|
}
|
2017-04-15 09:12:23 -07:00
|
|
|
|
2018-04-07 09:30:27 -07:00
|
|
|
form textarea {
|
|
|
|
line-height:16px;
|
|
|
|
resize: vertical;
|
|
|
|
}
|
2017-04-15 09:12:23 -07:00
|
|
|
|
2018-04-07 09:30:27 -07:00
|
|
|
.captcha {
|
|
|
|
max-width: 350px;
|
|
|
|
margin-bottom: 0.4em;
|
|
|
|
}
|
2017-04-21 08:52:42 -07:00
|
|
|
|
2018-04-07 09:30:27 -07:00
|
|
|
.btn {
|
|
|
|
margin-top: 0.6em;
|
|
|
|
height: 28px;
|
|
|
|
}
|
2017-04-15 09:12:23 -07:00
|
|
|
|
2018-04-07 09:30:27 -07:00
|
|
|
.error {
|
|
|
|
text-align: center;
|
|
|
|
}
|
2017-04-15 09:12:23 -07:00
|
|
|
}
|
2017-04-17 03:57:02 -07:00
|
|
|
|
2019-01-26 07:45:03 -08:00
|
|
|
@media all and (max-width: 800px) {
|
2018-04-07 09:30:27 -07:00
|
|
|
.registration-form .container {
|
2017-04-17 03:57:02 -07:00
|
|
|
flex-direction: column-reverse;
|
|
|
|
}
|
|
|
|
}
|
2017-04-15 09:12:23 -07:00
|
|
|
</style>
|