form-backend-validation
Advanced tools
Comparing version 0.0.4 to 1.0.0
# Changelog | ||
All Notable changes to `vue-form-backend-validation` will be documented in this file | ||
All notable changes to `form-backend-validation` will be documented in this file | ||
## 1.0.0 - 201X-XX-XX | ||
## 1.0.0 - 2017-01-16 | ||
- Initial release |
@@ -5,3 +5,3 @@ # Contributing | ||
We accept contributions via Pull Requests on [Github](https://github.com/spatie/vue-form-backend-validation). | ||
We accept contributions via Pull Requests on [Github](https://github.com/spatie/form-backend-validation). | ||
@@ -8,0 +8,0 @@ ## Pull Requests |
@@ -22,5 +22,5 @@ "use strict"; | ||
/** | ||
* Determine if an errors exists for the given field. | ||
* Get all the errors. | ||
* | ||
* @param {string} field | ||
* @param {object} errors | ||
*/ | ||
@@ -30,2 +30,14 @@ | ||
_createClass(Errors, [{ | ||
key: "all", | ||
value: function all() { | ||
return this.errors; | ||
} | ||
/** | ||
* Determine if an errors exists for the given field. | ||
* | ||
* @param {string} field | ||
*/ | ||
}, { | ||
key: "has", | ||
@@ -32,0 +44,0 @@ value: function has(field) { |
@@ -30,3 +30,11 @@ 'use strict'; | ||
if (Array.isArray(data)) { | ||
data = data.reduce(function (carry, element) { | ||
carry[element] = ''; | ||
return carry; | ||
}, {}); | ||
} | ||
this.originalData = data; | ||
this.errors = new _Errors2.default(); | ||
@@ -36,4 +44,2 @@ for (var field in data) { | ||
} | ||
this.errors = new _Errors2.default(); | ||
} | ||
@@ -74,3 +80,3 @@ | ||
* Send a POST request to the given URL. | ||
* . | ||
* | ||
* @param {string} url | ||
@@ -87,3 +93,3 @@ */ | ||
* Send a PUT request to the given URL. | ||
* . | ||
* | ||
* @param {string} url | ||
@@ -100,3 +106,3 @@ */ | ||
* Send a PATCH request to the given URL. | ||
* . | ||
* | ||
* @param {string} url | ||
@@ -113,3 +119,3 @@ */ | ||
* Send a DELETE request to the given URL. | ||
* . | ||
* | ||
* @param {string} url | ||
@@ -136,2 +142,4 @@ */ | ||
this.validateRequestType(requestType); | ||
return new Promise(function (resolve, reject) { | ||
@@ -145,3 +153,3 @@ _axios2.default[requestType](url, _this.data()).then(function (response) { | ||
reject(error.response.data); | ||
reject(error.response); | ||
}); | ||
@@ -152,2 +160,18 @@ }); | ||
/** | ||
* Validate a request type. | ||
* | ||
* @param {string} requestType | ||
*/ | ||
}, { | ||
key: 'validateRequestType', | ||
value: function validateRequestType(requestType) { | ||
var requestTypes = ['get', 'delete', 'head', 'post', 'put', 'patch']; | ||
if (requestTypes.indexOf(requestType) === -1) { | ||
throw new Error('`' + requestType + '` is not a valid request type, ' + ('must be one of: `' + requestTypes.join('\`, \`') + '`.')); | ||
} | ||
} | ||
/** | ||
* Handle a successful form submission. | ||
@@ -154,0 +178,0 @@ * |
{ | ||
"name": "form-backend-validation", | ||
"version": "0.0.4", | ||
"version": "1.0.0", | ||
"description": "An easy way to validate forms using back end logic", | ||
@@ -20,6 +20,6 @@ "main": "dist/index.js", | ||
"vue", | ||
"laravel", | ||
"form", | ||
"validation", | ||
"server", | ||
"laravel" | ||
"server" | ||
], | ||
@@ -26,0 +26,0 @@ "author": "Freek Van der Herten", |
@@ -1,11 +0,9 @@ | ||
**THIS PACKAGE IS STILL IN DEVELOPMENT, DO NOT USE (YET)** | ||
# An easy way to validate forms using back end logic | ||
[data:image/s3,"s3://crabby-images/5fa3b/5fa3bf8c6aeb7b9d2a19a0c56120af3a37c2487e" alt="Latest Version on NPM"](https://npmjs.com/package/vue-form-backend-validation) | ||
[data:image/s3,"s3://crabby-images/0fbe0/0fbe0d846f7eb69f9acca033daf3322b5d1812e7" alt="Latest Version on NPM"](https://npmjs.com/package/form-backend-validation) | ||
[data:image/s3,"s3://crabby-images/eb25f/eb25fe57a9e201e58f4a28ab70e7ca26fb2bc967" alt="Software License"](LICENSE.md) | ||
[data:image/s3,"s3://crabby-images/cc96b/cc96bc0c6fc72f62edd97de15d1e026686659006" alt="Build Status"](https://travis-ci.org/spatie/vue-form-backend-validation) | ||
[data:image/s3,"s3://crabby-images/8bd51/8bd51d66f0965f592a7d777192d1468c7c317162" alt="Build Status"](https://travis-ci.org/spatie/form-backend-validation) | ||
[data:image/s3,"s3://crabby-images/ad7c4/ad7c47dcae6ebb9e6d0b3555103d821feb46f877" alt="npm"]() | ||
Wouldn't it be great if you could just use your back end to validate forms on the front end? This package provides a `Form` class does exactly that. It can post itself to a configured endpoint and manage errors. The class meant to be used in a `Vue` component and works out of the box with a Laravel back end. | ||
Wouldn't it be great if you could just use your back end to validate forms on the front end? This package provides a `Form` class does exactly that. It can post itself to a configured endpoint and manage errors. The class meant to be used with a Laravel back end. | ||
@@ -34,43 +32,36 @@ Take a look at the [usage section](#usage) to view a detailed example on how to use it. | ||
This is an example of a fully configured form that could be built up in a `Blade` view. | ||
You find an example implementation with Laravel and Vue in the [spatie/form-backend-validation-example-app repo](https://github.com/spatie/form-backend-validation-example-app). | ||
```html | ||
<form @submit.prevent="onSubmit" @keydown="form.errors.clear($event.target.name)"> | ||
<div> | ||
<label for="name">Name:</label> | ||
<input type="text" name="name" v-model="form.name"> | ||
<span v-if="form.errors.has('name')" v-text="form.errors.get('name')"></span> | ||
</div> | ||
data:image/s3,"s3://crabby-images/f71ea/f71ea4fb04a23240c8512e4727dbbc63cc8acaaf" alt="Screenshot" | ||
<div> | ||
<label for="text">Text:</label> | ||
<input type="text" name="text" v-model="form.text"> | ||
<span v-if="form.errors.has('text')" v-text="form.errors.get('text')"></span> | ||
</div> | ||
```js | ||
import Form from 'form-backend-validation'; | ||
<div> | ||
<button :disabled="form.errors.any()">Create news item</button> | ||
</div> | ||
</form> | ||
``` | ||
//instantiate a form class with some value | ||
const form = new Form({ | ||
field1: 'value 1', | ||
field2: 'value 2', | ||
}); | ||
This is an example of a `Vue` component that uses the provided `Form` class. | ||
// a form can also be initiated with an array | ||
const form = new Form(['field1', 'field2']); | ||
```js | ||
new Vue({ | ||
el: '#app', | ||
// submitting the form, you can also use `.put`, `.patch` and `.delete` | ||
form.post(anUrl) | ||
.then(response => ...) | ||
.catch(response => ...); | ||
data: { | ||
form: new Form({ | ||
name: '', | ||
text: '' | ||
}) | ||
}, | ||
// if there were any errors, you can get to them easily | ||
methods: { | ||
onSubmit() { | ||
this.form.submit('post', '/newsItems'); | ||
} | ||
} | ||
}); | ||
// returns an object in which the keys are the field names | ||
// and the values array with error message sent by the server | ||
form.errors.all() | ||
form.errors.any(); // returns true if there were any error | ||
form.errors.has(fieldName) // return true if there is an error for the given fieldName | ||
form.errors.get(fieldName) // return an array with errors for the given fieldName | ||
form.errors.clear() // forget all errors. | ||
``` | ||
@@ -77,0 +68,0 @@ |
@@ -10,2 +10,11 @@ class Errors { | ||
/** | ||
* Get all the errors. | ||
* | ||
* @param {object} errors | ||
*/ | ||
all() { | ||
return this.errors; | ||
} | ||
/** | ||
* Determine if an errors exists for the given field. | ||
@@ -12,0 +21,0 @@ * |
@@ -11,3 +11,12 @@ import axios from 'axios'; | ||
constructor(data) { | ||
if (Array.isArray(data)) { | ||
data = data.reduce((carry, element) => { | ||
carry[element] = ''; | ||
return carry; | ||
}, {}); | ||
} | ||
this.originalData = data; | ||
this.errors = new Errors(); | ||
@@ -17,4 +26,2 @@ for (const field in data) { | ||
} | ||
this.errors = new Errors(); | ||
} | ||
@@ -48,3 +55,3 @@ | ||
* Send a POST request to the given URL. | ||
* . | ||
* | ||
* @param {string} url | ||
@@ -58,3 +65,3 @@ */ | ||
* Send a PUT request to the given URL. | ||
* . | ||
* | ||
* @param {string} url | ||
@@ -68,3 +75,3 @@ */ | ||
* Send a PATCH request to the given URL. | ||
* . | ||
* | ||
* @param {string} url | ||
@@ -78,3 +85,3 @@ */ | ||
* Send a DELETE request to the given URL. | ||
* . | ||
* | ||
* @param {string} url | ||
@@ -93,5 +100,7 @@ */ | ||
submit(requestType, url) { | ||
this.validateRequestType(requestType); | ||
return new Promise((resolve, reject) => { | ||
axios[requestType](url, this.data()) | ||
.then(response => { | ||
.then((response) => { | ||
this.onSuccess(response.data); | ||
@@ -101,6 +110,6 @@ | ||
}) | ||
.catch(error => { | ||
.catch((error) => { | ||
this.onFail(error.response.data); | ||
reject(error.response.data); | ||
reject(error.response); | ||
}); | ||
@@ -111,2 +120,16 @@ }); | ||
/** | ||
* Validate a request type. | ||
* | ||
* @param {string} requestType | ||
*/ | ||
validateRequestType(requestType) { | ||
const requestTypes = ['get', 'delete', 'head', 'post', 'put', 'patch']; | ||
if (requestTypes.indexOf(requestType) === -1) { | ||
throw new Error(`\`${requestType}\` is not a valid request type, ` + | ||
`must be one of: \`${requestTypes.join('\`, \`')}\`.`); | ||
} | ||
} | ||
/** | ||
* Handle a successful form submission. | ||
@@ -130,2 +153,2 @@ * | ||
export default Form; | ||
export default Form; |
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
131977
428
0
99