Created
November 20, 2018 13:41
-
-
Save rudmanmrrod/118c62f9ec831de3e4614d436e3cd069 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
{% extends "base.html" %} | |
{% load staticfiles %} | |
{% block 'content %} | |
<h1 class="text-center">Create User</h1><hr> | |
<form id="app" v-on:submit.prevent="onSubmit"> | |
{% csrf_token %} | |
<div class="container"> | |
<div class="row"> | |
<div class="col-md-4 col-sm-4 col-xs-4"> | |
<label>{{form.username.label}}</label> | |
{{form.username}} | |
<div class="text-danger" v-if="errors['username'].lenght != 0"> | |
<ul v-for="error in errors['username']"> | |
<li>[[error]]</li> | |
</ul> | |
</div> | |
</div> | |
<div class="col-md-4 col-sm-4 col-xs-4"> | |
<label>{{form.password1.label}}</label> | |
{{form.password1}} | |
<div class="text-danger" v-if="errors['password1'].lenght != 0"> | |
<ul v-for="error in errors['password1']"> | |
<li>[[error]]</li> | |
</ul> | |
</div> | |
</div> | |
<div class="col-md-4 col-sm-4 col-xs-4"> | |
<label>{{form.password2.label}}</label> | |
{{form.password2}} | |
<div class="text-danger" v-if="errors['password2'].lenght != 0"> | |
<ul v-for="error in errors['password2']"> | |
<li>[[error]]</li> | |
</ul> | |
</div> | |
</div> | |
</div> | |
<div class="row"> | |
<div class="col-md-4 col-sm-4 col-xs-4"> | |
<label>{{form.first_name.label}}</label> | |
{{form.first_name}} | |
<div class="text-danger" v-if="errors['first_name'].lenght != 0"> | |
<ul v-for="error in errors['first_name']"> | |
<li>[[error]]</li> | |
</ul> | |
</div> | |
</div> | |
<div class="col-md-4 col-sm-4 col-xs-4"> | |
<label>{{form.last_name.label}}</label> | |
{{form.last_name}} | |
<div class="text-danger" v-if="errors['last_name'].lenght != 0"> | |
<ul v-for="error in errors['last_name']"> | |
<li>[[error]]</li> | |
</ul> | |
</div> | |
</div> | |
<div class="col-md-4 col-sm-4 col-xs-4"> | |
<label>{{form.email.label}}</label> | |
{{form.email}} | |
<div class="text-danger" v-if="errors['email'].lenght != 0"> | |
<ul v-for="error in errors['email']"> | |
<li>[[error]]</li> | |
</ul> | |
</div> | |
</div> | |
</div> | |
<div class="row"> | |
<div class="col-md-3 col-sm-3 col-xs-3"> | |
<label>{{form.dni_number.label}}</label> | |
{{form.dni_number}} | |
<div class="text-danger" v-if="errors['dni_number'].lenght != 0"> | |
<ul v-for="error in errors['dni_number']"> | |
<li>[[error]]</li> | |
</ul> | |
</div> | |
</div> | |
<div class="col-md-3 col-sm-3 col-xs-3"> | |
<label>{{form.address.label}}</label> | |
{{form.address}} | |
<div class="text-danger" v-if="errors['address'].lenght != 0"> | |
<ul v-for="error in errors['address']"> | |
<li>[[error]]</li> | |
</ul> | |
</div> | |
</div> | |
<div class="col-md-3 col-sm-3 col-xs-3"> | |
<label>{{form.zip_code.label}}</label> | |
{{form.zip_code}} | |
<div class="text-danger" v-if="errors['zip_code'].lenght != 0"> | |
<ul v-for="error in errors['zip_code']"> | |
<li>[[error]]</li> | |
</ul> | |
</div> | |
</div> | |
<div class="col-md-3 col-sm-3 col-xs-3"> | |
<label>{{form.gender.label}}</label> | |
{{form.gender}} | |
<div class="text-danger" v-if="errors['gender'].lenght != 0"> | |
<ul v-for="error in errors['gender']"> | |
<li>[[error]]</li> | |
</ul> | |
</div> | |
</div> | |
</div> | |
<br> | |
<div class="text-center"> | |
<button class="btn btn-success">Submit</button> | |
</div> | |
</div> | |
</form> | |
{% endblock %} | |
{% block 'extraJs %} | |
<script> | |
var app = new Vue({ | |
delimiters: ['[[', ']]'], | |
el: '#app', | |
data: { | |
csrfmiddlewaretoken: '', | |
username: 'rudmanmrrod', | |
email: '[email protected]', | |
password1: '123', | |
password2: '123', | |
first_name: 'rodrigo', | |
last_name: 'boet', | |
dni_number: '123', | |
address: 'Algun lugar', | |
zip_code: '5101', | |
gender: 'M', | |
errors: { | |
'username':[], | |
'email':[], | |
'password1':[], | |
'password2':[], | |
'first_name':[], | |
'last_name':[], | |
'dni_number':[], | |
'address':[], | |
'zip_code':[], | |
'gender':[], | |
} | |
}, | |
methods: { | |
onSubmit: function() { | |
var form = new FormData(); | |
form.append('username',this.username) | |
form.append('email',this.email) | |
form.append('password1',this.password1) | |
form.append('password2',this.password2) | |
form.append('first_name',this.first_name) | |
form.append('last_name',this.last_name) | |
form.append('dni_number',this.dni_number) | |
form.append('address',this.address) | |
form.append('zip_code',this.zip_code) | |
form.append('gender',this.gender) | |
axios.post('http://localhost:8000/create',form, {'headers':{ | |
'X-CSRFToken': this.csrfmiddlewaretoken, | |
'Content-Type': 'multipart/form-data' | |
}}) | |
.then(response => { | |
if(response.data['valid']){ | |
console.log(response.data['message']) | |
window.location = '/' | |
} | |
else{ | |
this.clear() | |
for(field in response.data['error']){ | |
this.errors[field] = response.data['error'][field] | |
} | |
} | |
}) | |
.catch( err => { | |
console.log(err.response); | |
console.log("err") | |
}) | |
}, | |
clear: function(){ | |
this.errors = { | |
'username':[], | |
'email':[], | |
'password1':[], | |
'password2':[], | |
'first_name':[], | |
'last_name':[], | |
'dni_number':[], | |
'address':[], | |
'zip_code':[], | |
'gender':[], | |
} | |
} | |
}, | |
mounted: function(){ | |
this.csrfmiddlewaretoken = document.getElementsByName('csrfmiddlewaretoken')[0].value | |
} | |
}) | |
</script> | |
{% endblock %} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment