diff options
| author | shpuld <shp@cock.li> | 2018-12-18 22:09:27 +0200 |
|---|---|---|
| committer | shpuld <shp@cock.li> | 2018-12-18 22:09:27 +0200 |
| commit | 640a28789222035f8d500b8dd4bfc4c9f0cdd1af (patch) | |
| tree | de6e7a72f0a90b8196b1bf99ac0fe4cd5bfe39a2 /src/components/registration | |
| parent | bd2ed617a740ef3b37dedf3bed608e433dc0ec09 (diff) | |
| parent | 2f28bf95fdce6a215961fe264c236c111e4a1e66 (diff) | |
Merge branch 'develop' into feature/replace-panel-switcher
Diffstat (limited to 'src/components/registration')
| -rw-r--r-- | src/components/registration/registration.js | 16 | ||||
| -rw-r--r-- | src/components/registration/registration.vue | 13 |
2 files changed, 25 insertions, 4 deletions
diff --git a/src/components/registration/registration.js b/src/components/registration/registration.js index e5ead8bc..65b2fb9b 100644 --- a/src/components/registration/registration.js +++ b/src/components/registration/registration.js @@ -11,7 +11,8 @@ const registration = { username: '', password: '', confirm: '' - } + }, + captcha: {} }), validations: { user: { @@ -27,8 +28,10 @@ const registration = { }, created () { if ((!this.registrationOpen && !this.token) || this.signedIn) { - this.$router.push('/main/all') + this.$router.push('/~/main/all') } + + this.setCaptcha() }, computed: { token () { return this.$route.params.token }, @@ -41,21 +44,26 @@ const registration = { }) }, methods: { - ...mapActions(['signUp']), + ...mapActions(['signUp', 'getCaptcha']), async submit () { this.user.nickname = this.user.username this.user.token = this.token + this.user.captcha_solution = this.captcha.solution + this.user.captcha_token = this.captcha.token this.$v.$touch() if (!this.$v.$invalid) { try { await this.signUp(this.user) - this.$router.push('/main/friends') + this.$router.push('/~/main/friends') } catch (error) { console.warn('Registration failed: ' + error) } } + }, + setCaptcha () { + this.getCaptcha().then(cpt => { this.captcha = cpt }) } } } diff --git a/src/components/registration/registration.vue b/src/components/registration/registration.vue index 8cb1392b..f187e215 100644 --- a/src/components/registration/registration.vue +++ b/src/components/registration/registration.vue @@ -75,6 +75,19 @@ </ul> </div> + <div class="form-group" id="captcha-group" v-if="captcha.type != 'none'"> + <template v-if="captcha.type == 'kocaptcha'"> + <img v-bind:src="captcha.url" v-on:click="setCaptcha"> + + <sub>Click the image to get a new captcha</sub> + <label class='form--label' for='captcha-label'>CAPTCHA</label> + + <input :disabled="isPending" + v-model='captcha.solution' + class='form-control' id='captcha-answer' type='text'> + </template> + </div> + <div class='form-group' v-if='token' > <label for='token'>{{$t('registration.token')}}</label> <input disabled='true' v-model='token' class='form-control' id='token' type='text'> |
