File: /home/greer489/public_html/wp-content/themes/betheme/muffin-options/fields/tabs/field_tabs.php
<?php
class MFN_Options_tabs extends Mfn_Options_field
{
/**
* Render
*/
public function render( $existing = false, $vb = false, $js = false )
{
$field_prefix = '';
$preview = '';
$primary = 'title';
$secondary = 'title';
// name
$name = $this->field['id'];
if ( 'new' == $existing ) {
$field_prefix = 'data-';
}
// visual builder
if( $js ){
$name = $existing;
}
// preview
if ( ! empty( $this->field['preview'] ) ){
$preview = 'preview-'. $this->field['preview'];
}
// primary
if( isset( $this->field['primary'] ) ){
$primary = $this->field['primary'];
}
if( isset( $this->field['secondary'] ) ){
$secondary = $this->field['secondary'];
}
if( empty( $this->field['options'][$primary][2] ) ){
$this->field['options'][$primary][2] = '';
}
// output -----
if( empty( $this->field['options'] ) ){
echo 'please enter default fields';
return false;
}
echo '<div class="form-group tabs mfn-form-verical">';
echo '<ul class="tabs-wrapper '. esc_attr( $preview ) .'">';
echo '<li class="tab default">';
echo '<div class="tab-header">';
echo '<a class="mfn-option-btn mfn-option-blank mfn-tab-toggle mfn-tab-show" href="#"><span class="mfn-icon mfn-icon-arrow-down"></span></a>';
echo '<a class="mfn-option-btn mfn-option-blank mfn-tab-toggle mfn-tab-hide" href="#"><span class="mfn-icon mfn-icon-arrow-up"></span></a>';
echo '<h6 class="title">'. esc_html( $this->field['options'][$primary][2] ) .'</h6>';
echo '<a class="mfn-option-btn mfn-option-blue mfn-tab-clone" href="#"><span class="mfn-icon mfn-icon-clone"></span></a>';
echo '<a class="mfn-option-btn mfn-option-blue mfn-tab-delete" href="#"><span class="mfn-icon mfn-icon-delete"></span></a>';
echo '</div>';
echo '<div class="tab-content">';
foreach( $this->field['options'] as $label => $param ){
// visual builder
if( $js ){
$field_name = $name .'[0]['. $label .']';
}else{
$field_name = $name .'['. $label .'][]';
}
$jsc = false;
if( $primary == $label ){
$jsc = 'js-title';
}
echo '<div class="mfn-form-row mfn-tabs-row">';
echo '<label class="form-label">'. esc_html( $param[1] ) .'</label>';
echo '<div class="form-content">';
if( 'input' == $param[0] ){
echo '<input data-order="0" data-label="'.$label.'" class="not-empty field-to-object mfn-form-control mfn-form-input mfn-tab-'. esc_attr($label) .' '. esc_attr($jsc) .'" type="text" data-default="'. esc_attr( $field_name ) .'" value="'. esc_html( $param[2] ) .'"/>';
} else if ( 'select' == $param[0] ){
echo '<select data-order="0" data-label="'.$label.'" class="not-empty field-to-object mfn-form-control mfn-form-select mfn-tab-'. esc_attr($label) .' '. esc_attr($jsc) .'" data-default="'. esc_attr( $field_name ) .'">';
foreach( $param[3] as $option_k => $option_v ){
echo '<option value="'. $option_k .'">'. $option_v .'</option>';
}
echo '</select>';
} else if ( 'textarea' == $param[0] ){
echo '<textarea data-order="0" data-label="'.$label.'" class="not-empty field-to-object mfn-form-control mfn-form-textarea mfn-tab-'. esc_attr($label) .' '. esc_attr($jsc) .'" rows="3" data-default="'. esc_attr( $field_name ) .'">'. esc_textarea( $param[2] ) .'</textarea>';
} else if( 'icon' == $param[0] ){
echo '<div class="form-group browse-icon has-addons has-addons-prepend not-empty"><div class="form-addon-prepend"><a href="#" class="mfn-button-upload"><span class="label"><span class="text">Browse</span><i class="icon-basket"></i></span></a></div><div class="form-control has-icon has-icon-right"><input data-default="'. esc_attr( $field_name ) .'" data-label="'.$label.'" class="not-empty field-to-object mfn-form-control mfn-form-input mfn-tab-'. esc_attr($label) .' '. esc_attr($jsc) .'" type="text" name="icon" value="'. esc_html( $param[2] ) .'" placeholder="icon-dot"><a class="mfn-option-btn mfn-button-delete" title="Delete" href="#"><span class="mfn-icon mfn-icon-delete"></span></a></div></div>';
} else if( 'image' == $param[0] ){
echo '<div class="form-group browse-image has-addons has-addons-append empty"><div class="form-control has-icon has-icon-right"><input data-default="'. esc_attr( $field_name ) .'" data-order="0" data-label="'.$label.'" class="not-empty field-to-object mfn-form-control mfn-form-input mfn-tab-'. esc_attr($label) .' '. esc_attr($jsc) .'" type="text" data-default="'. esc_attr( $field_name ) .'" value="'. esc_html( $param[2] ) .'" data-type="image"><a class="mfn-option-btn mfn-button-delete" title="Delete" href="#"><span class="mfn-icon mfn-icon-delete"></span></a></div><div class="form-addon-append"><a href="#" class="mfn-button-upload"><span class="label">Browse</span></a></div></div>';
} else if( 'color' == $param[0] ){
echo '<div class="form-group color-picker has-addons has-addons-prepend"><div class="color-picker-group"><div class="form-addon-prepend"><a href="#" class="color-picker-open"><span class="label"><i class="icon-bucket"></i></span></a></div><div class="form-control has-icon has-icon-right"><input data-default="'. esc_attr( $field_name ) .'" data-order="0" data-label="'.$label.'" class="not-empty field-to-object mfn-form-control color-picker-vb mfn-form-input mfn-tab-'. esc_attr($label) .' '. esc_attr($jsc) .'" type="text" value="'. esc_html( $param[2] ) .'" autocomplete="off" /><a class="mfn-option-btn mfn-option-text color-picker-clear" href="#"><span class="text">Clear</span></a></div></div></div>';
}
echo '</div>';
echo '</div>';
}
echo '</div>';
echo '</li>';
if( $js ){
$looped_html = '';
foreach( $this->field['options'] as $label => $param ){
if( empty( $value[$label] ) ) $value[$label] = '';
$jsc = false;
if( $primary == $label ) $jsc = 'js-title';
$looped_html .= '<div class="mfn-form-row mfn-tabs-row">';
$looped_html .= '<label class="form-label">'. esc_html( $param[1] ) .'</label>';
$looped_html .= '<div class="form-content">';
if( 'input' == $param[0] ){
$looped_html .= '<input data-order="\'+i+\'" data-label="'.$label.'" type="text" class="not-empty field-to-object mfn-form-control mfn-form-input mfn-tab-'. esc_attr( $label ) .' '. esc_attr($jsc) .'" '. esc_attr( $field_prefix ) .'name="'. $name .'[\'+i+\']['. $label .']' .'" value="\'+( typeof v.'.$label.' !== \'undefined\' ? v.'.$label.' : "" )+\'"/>';
} else if ( 'select' == $param[0] ){
$looped_html .= '<select data-order="\'+i+\'" data-label="'.$label.'" class="not-empty field-to-object mfn-form-control mfn-form-select mfn-tab-'. esc_attr($label) .' '. esc_attr($jsc) .'" rows="3" '. esc_attr( $field_prefix ) .'name="'. $name .'[\'+i+\']['. $label .']' .'">';
foreach( $param[3] as $option_k => $option_v ){
$looped_html .= '<option \'+( typeof v.'.$label.' !== \'undefined\' && v.'.$label.' == \''. $option_k .'\' ? "selected" : "" )+\' value="'. $option_k .'">'. $option_v .'</option>';
}
$looped_html .= '</select>';
} else if ( 'textarea' == $param[0] ){
$looped_html .= '<textarea data-order="\'+i+\'" data-label="'.$label.'" class="not-empty field-to-object mfn-form-control mfn-form-textarea mfn-tab-'. esc_attr($label) .' '. esc_attr($jsc) .'" rows="3" '. esc_attr( $field_prefix ) .'name="'. $name .'[\'+i+\']['. $label .']' .'">\'+v.'.$label.'+\'</textarea>';
} else if( 'icon' == $param[0] ){
$looped_html .= '<div class="form-group browse-icon has-addons has-addons-prepend not-empty"><div class="form-addon-prepend"><a href="#" class="mfn-button-upload"><span class="label"><span class="text">Browse</span><i class="icon-basket"></i></span></a></div><div class="form-control has-icon has-icon-right"><input data-order="\'+i+\'" data-label="'.$label.'" class="not-empty field-to-object mfn-form-control mfn-form-input mfn-tab-'. esc_attr($label) .' '. esc_attr($jsc) .'" type="text" name="'. $name .'[\'+i+\']['. $label .']' .'" value="\'+( typeof v.'.$label.' !== \'undefined\' ? v.'.$label.' : "" )+\'"><a class="mfn-option-btn mfn-button-delete" title="Delete" href="#"><span class="mfn-icon mfn-icon-delete"></span></a></div></div>';
} else if( 'image' == $param[0] ){
$looped_html .= '<div class="form-group browse-image has-addons has-addons-append empty"><div class="form-control has-icon has-icon-right"><input data-order="\'+i+\'" data-label="'.$label.'" class="not-empty field-to-object mfn-form-control mfn-form-input mfn-tab-'. esc_attr( $label ) .' '. esc_attr($jsc) .'" type="text" name="'. $name .'[\'+i+\']['. $label .']'.'" value="\'+( typeof v.'.$label.' !== \'undefined\' ? v.'.$label.' : "" )+\'" data-type="image"><a class="mfn-option-btn mfn-button-delete" title="Delete" href="#"><span class="mfn-icon mfn-icon-delete"></span></a></div><div class="form-addon-append"><a href="#" class="mfn-button-upload"><span class="label">Browse</span></a></div></div>';
} else if( 'color' == $param[0] ){
$looped_html .= '<div class="form-group color-picker has-addons has-addons-prepend"><div class="color-picker-group"><div class="form-addon-prepend"><a href="#" class="color-picker-open"><span class="label"><i class="icon-bucket"></i></span></a></div><div class="form-control has-icon has-icon-right"><input data-order="\'+i+\'" data-label="'.$label.'" class="not-empty field-to-object mfn-form-control mfn-form-input color-picker-vb mfn-tab-'. esc_attr( $label ) .' '. esc_attr($jsc) .'" type="text" name="'. $name .'[\'+i+\']['. $label .']'.'" value="\'+( typeof v.'.$label.' !== \'undefined\' ? v.'.$label.' : "" )+\'" autocomplete="off" /><a class="mfn-option-btn mfn-option-text color-picker-clear" href="#"><span class="text">Clear</span></a></div></div></div>';
}
$looped_html .= '</div></div>';
}
echo '\' + ('.$js.' && '.$js.'.length ? '.$js.'.map((v, i) => \'<li class="tab"><div class="tab-header"><a class="mfn-option-btn mfn-option-blank mfn-tab-toggle mfn-tab-show" href="#"><span class="mfn-icon mfn-icon-arrow-down"></span></a><a class="mfn-option-btn mfn-option-blank mfn-tab-toggle mfn-tab-hide" href="#"><span class="mfn-icon mfn-icon-arrow-up"></span></a><h6 class="title">\'+(v.'.$primary.' && typeof v.'.$primary.' !== \'undefined\' ? v.'.$primary.'.replace( /<.*?>/g, \'\' ) : v.'.$secondary.' )+\'</h6><a class="mfn-option-btn mfn-option-blue mfn-tab-clone" href="#"><span class="mfn-icon mfn-icon-clone"></span></a><a class="mfn-option-btn mfn-option-blue mfn-tab-delete" href="#"><span class="mfn-icon mfn-icon-delete"></span></a></div><div class="tab-content">'.$looped_html.'</div></li>\' ).join("") : "") +\'';
}else if ( ! empty( $this->value ) ){
if ( is_array( $this->value ) ){
foreach ( $this->value as $k => $value ) {
if( empty( $value[$primary] ) ){
$value[$primary] = '';
}
echo '<li class="tab">';
echo '<div class="tab-header">';
echo '<a class="mfn-option-btn mfn-option-blank mfn-tab-toggle mfn-tab-show" href="#"><span class="mfn-icon mfn-icon-arrow-down"></span></a>';
echo '<a class="mfn-option-btn mfn-option-blank mfn-tab-toggle mfn-tab-hide" href="#"><span class="mfn-icon mfn-icon-arrow-up"></span></a>';
echo '<h6 class="title">'. ( $value[$primary] ? esc_html( $value[$primary] ) : esc_html( $value[$secondary] ) ) .'</h6>';
echo '<a class="mfn-option-btn mfn-option-blue mfn-tab-clone" href="#"><span class="mfn-icon mfn-icon-clone"></span></a>';
echo '<a class="mfn-option-btn mfn-option-blue mfn-tab-delete" href="#"><span class="mfn-icon mfn-icon-delete"></span></a>';
echo '</div>';
echo '<div class="tab-content">';
foreach( $this->field['options'] as $label => $param ){
$field_name = $name .'['. $label .'][]';
if( empty( $value[$label] ) ){
$value[$label] = '';
}
$jsc = false;
if( $primary == $label ){
$jsc = 'js-title';
}
echo '<div class="mfn-tabs-row">';
echo '<label class="form-label">'. esc_html( $param[1] ) .'</label>';
echo '<div class="form-content">';
if ( 'textarea' == $param[0] ){
echo '<textarea class="not-empty mfn-form-control mfn-form-textarea" rows="3" '. esc_attr( $field_prefix ) .'name="'. esc_attr( $field_name ) .'">'. esc_textarea( $value[$label] ) .'</textarea>';
} else {
echo '<input type="text" class="not-empty mfn-form-control mfn-form-input mfn-tab-'. esc_attr( $label ) .' '. esc_attr($jsc) .'" '. esc_attr( $field_prefix ) .'name="'. esc_attr( $field_name ) .'" value="'. esc_html( $value[$label] ) .'"/>';
}
echo '</div>';
echo '</div>';
}
echo '</div>';
echo '</li>';
}
}
}
echo '</ul>';
echo '<a href="#" class="mfn-button-add">'. esc_html__( 'Add new', 'mfn-opts' ) .'</a>';
echo '</div>';
// visual builder
if( ! $vb ){
echo $this->get_description();
}
}
/**
* Enqueue
*/
public function enqueue()
{
wp_enqueue_script( 'mfn-opts-field-tabs', MFN_OPTIONS_URI .'fields/tabs/field_tabs.js', array( 'jquery' ), MFN_THEME_VERSION, true );
}
}