base-select-check-radio
2 years ago
presets
2 years ago
post.property.select.js
2 years ago
user.property.select.js
2 years ago
user.property.select.js
48 lines
| 1 | const { |
| 2 | TextControl, |
| 3 | } = wp.components; |
| 4 | const { |
| 5 | useContext, |
| 6 | } = wp.element; |
| 7 | const { |
| 8 | CurrentActionEditContext, |
| 9 | ActionFieldsMapContext, |
| 10 | CurrentPropertyMapContext, |
| 11 | } = JetFBComponents; |
| 12 | |
| 13 | function UserPropertySelect() { |
| 14 | // context with action props |
| 15 | const { |
| 16 | FieldSelect, |
| 17 | property, |
| 18 | } = useContext( CurrentPropertyMapContext ); |
| 19 | const { |
| 20 | setMapField, |
| 21 | getMapField, |
| 22 | } = useContext( CurrentActionEditContext ); |
| 23 | // context with current field in fields map |
| 24 | const { |
| 25 | name, |
| 26 | index, |
| 27 | } = useContext( ActionFieldsMapContext ); |
| 28 | |
| 29 | switch ( property ) { |
| 30 | case 'user_meta': |
| 31 | return <div |
| 32 | className="components-base-control jet-margin-bottom-wrapper" |
| 33 | > |
| 34 | { FieldSelect } |
| 35 | <TextControl |
| 36 | key={ name + index + '_text' } |
| 37 | value={ getMapField( { name } ) } |
| 38 | onChange={ value => setMapField( |
| 39 | { nameField: name, value }, |
| 40 | ) } |
| 41 | /> |
| 42 | </div>; |
| 43 | default: |
| 44 | return FieldSelect; |
| 45 | } |
| 46 | } |
| 47 | |
| 48 | export default UserPropertySelect; |