useIsHasAttribute.js
2 years ago
useMetaState.js
2 years ago
useRepeaterState.js
2 years ago
useSelectPostMeta.js
2 years ago
useStateLoadingClasses.js
2 years ago
useStateValidClasses.js
2 years ago
useSuccessNotice.js
2 years ago
withSelectFormFields.js
2 years ago
useStateValidClasses.js
41 lines
| 1 | export const initClasses = [ 'jet-form-validate-button' ]; |
| 2 | |
| 3 | const { |
| 4 | useState, |
| 5 | } = wp.element; |
| 6 | |
| 7 | function useStateValidClasses( initialValid ) { |
| 8 | const validClass = 'is-valid'; |
| 9 | const invalidClass = 'is-invalid'; |
| 10 | |
| 11 | const initStateClasses = () => { |
| 12 | if ( initialValid ) { |
| 13 | return [ validClass ]; |
| 14 | } |
| 15 | |
| 16 | return false === initialValid ? [ invalidClass ] : []; |
| 17 | }; |
| 18 | |
| 19 | const [ classes, setClasses ] = useState( () => ( |
| 20 | [ ...initClasses, ...initStateClasses() ] |
| 21 | ) ); |
| 22 | |
| 23 | const setValidClass = () => { |
| 24 | setClasses( [ ...initClasses, validClass ] ); |
| 25 | }; |
| 26 | const setInvalidClass = () => { |
| 27 | setClasses( [ ...initClasses, invalidClass ] ); |
| 28 | }; |
| 29 | const setLoadingClass = () => { |
| 30 | setClasses( [ ...initClasses, 'loading' ] ); |
| 31 | }; |
| 32 | |
| 33 | return [ |
| 34 | classes.join( ' ' ), |
| 35 | setValidClass, |
| 36 | setInvalidClass, |
| 37 | setLoadingClass, |
| 38 | ]; |
| 39 | } |
| 40 | |
| 41 | export default useStateValidClasses; |