-
-
Notifications
You must be signed in to change notification settings - Fork 266
/
Copy pathuseValidation.js
66 lines (57 loc) · 1.64 KB
/
useValidation.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
import { useState, useEffect } from 'react';
import {
useSelect,
useDispatch,
} from '@wordpress/data';
const useValidation = ( defaultRules = [], value, fieldName, storeKey ) => {
const [ validationRules, setValidationRules ] = useState( defaultRules );
//Validation messages for this field
const validationMessages = useSelect( ( select ) => {
const currentMessages = select( storeKey ).getValidationMessages();
//Return for this field
if ( currentMessages.hasOwnProperty( fieldName ) ) {
return currentMessages[ fieldName ];
}
return [];
}, [ fieldName ] );
//Set validation messages for this field
const { setValidationMessages } = useDispatch( storeKey );
const needsValidation = useSelect( ( select ) => {
return select( storeKey ).getNeedsValidating();
}, [] );
const toggleNeedsValidating = useDispatch( storeKey ).toggleNeedsValidating();
useEffect( () => {
const newMessages = [];
validationRules.forEach( ( rule ) => {
if ( ! rule.condition() ) {
return;
}
try {
rule.rule( value );
} catch ( error ) {
if ( typeof error === 'string' ) {
newMessages.push( error );
}
}
} );
setValidationMessages( fieldName, newMessages );
if ( needsValidation ) {
toggleNeedsValidating();
}
}, [ value, validationRules, needsValidation, toggleNeedsValidating, setValidationMessages ] );
const addValidationRules = ( rules = [] ) => {
rules.forEach( ( rule ) => {
setValidationRules( ( previousValidationRules ) => {
return [
...previousValidationRules,
rule,
];
} );
} );
};
return [
validationMessages,
addValidationRules,
];
};
export default useValidation;