%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /proc/self/root/home/infra/new-ong/bethemeold/muffin-options/fields/tabs/
Upload File :
Create Path :
Current File : //proc/self/root/home/infra/new-ong/bethemeold/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 );
	}
}

Zerion Mini Shell 1.0