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
withSelectFormFields.js
57 lines
| 1 | const { applyFilters } = wp.hooks; |
| 2 | |
| 3 | const getFormFields = ( blockParserFunc, blocks ) => { |
| 4 | blocks.map( block => { |
| 5 | blockParserFunc( block ); |
| 6 | |
| 7 | if ( block.innerBlocks.length ) { |
| 8 | getFormFields( blockParserFunc, block.innerBlocks ); |
| 9 | } |
| 10 | } ); |
| 11 | }; |
| 12 | |
| 13 | const withSelectFormFields = ( |
| 14 | exclude = [], |
| 15 | placeholder = false, |
| 16 | suppressFilter = false, |
| 17 | ) => select => { |
| 18 | |
| 19 | let formFields = []; |
| 20 | let skipFields = [ |
| 21 | 'submit', |
| 22 | 'form-break', |
| 23 | 'heading', |
| 24 | 'group-break', |
| 25 | 'conditional', |
| 26 | ...exclude, |
| 27 | ]; |
| 28 | |
| 29 | getFormFields( block => { |
| 30 | if ( block.name.includes( 'jet-forms/' ) |
| 31 | && block.attributes.name |
| 32 | && !skipFields.find( field => block.name.includes( field ) ) |
| 33 | ) { |
| 34 | |
| 35 | /*const blockType = select( blocksStore ).getBlockType( block.name );*/ |
| 36 | |
| 37 | formFields.push( { |
| 38 | blockName: block.name, |
| 39 | name: block.attributes.name, |
| 40 | label: block.attributes.label || block.attributes.name, |
| 41 | value: block.attributes.name, |
| 42 | //icon: blockType.icon.src, |
| 43 | } ); |
| 44 | } |
| 45 | }, select( 'core/block-editor' ).getBlocks() ); |
| 46 | |
| 47 | formFields = placeholder |
| 48 | ? [ { value: '', label: placeholder }, ...formFields ] |
| 49 | : formFields; |
| 50 | |
| 51 | return { |
| 52 | formFields: suppressFilter ? formFields : applyFilters( |
| 53 | 'jet.fb.getFormFieldsBlocks', formFields ), |
| 54 | }; |
| 55 | }; |
| 56 | |
| 57 | export default withSelectFormFields; |