acf_field_tab{}ACF 1.0

Хуков нет.

Использование

$acf_field_tab = new acf_field_tab();
// use class methods

Методы

  1. public initialize()
  2. public load_field( $field )
  3. public render_field( $field )
  4. public render_field_settings( $field )

Код acf_field_tab{} ACF 6.0.4

<?php
class acf_field_tab extends acf_field {

	public $show_in_rest = false;

	/*
	*  __construct
	*
	*  This function will setup the field type data
	*
	*  @type    function
	*  @date    5/03/2014
	*  @since   5.0.0
	*
	*  @param   n/a
	*  @return  n/a
	*/

	function initialize() {

		// vars
		$this->name     = 'tab';
		$this->label    = __( 'Tab', 'acf' );
		$this->category = 'layout';
		$this->defaults = array(
			'placement' => 'top',
			'endpoint'  => 0, // added in 5.2.8
		);

	}


	/*
	*  render_field()
	*
	*  Create the HTML interface for your field
	*
	*  @param   $field - an array holding all the field's data
	*
	*  @type    action
	*  @since   3.6
	*  @date    23/01/13
	*/

	function render_field( $field ) {

		// vars
		$atts = array(
			'href'           => '',
			'class'          => 'acf-tab-button',
			'data-placement' => $field['placement'],
			'data-endpoint'  => $field['endpoint'],
			'data-key'       => $field['key'],
		);

		if ( isset( $field['settings-type'] ) ) {
			$atts['class'] .= ' acf-settings-type-' . acf_slugify( $field['settings-type'] );
		}

		?>
	<a <?php echo acf_esc_attrs( $atts ); ?>><?php echo acf_esc_html( $field['label'] ); ?></a>
		<?php

	}



	/*
	*  render_field_settings()
	*
	*  Create extra options for your field. This is rendered when editing a field.
	*  The value of $field['name'] can be used (like bellow) to save extra data to the $field
	*
	*  @param   $field  - an array holding all the field's data
	*
	*  @type    action
	*  @since   3.6
	*  @date    23/01/13
	*/

	function render_field_settings( $field ) {

		/*
		// message
		$message = '';
		$message .= '<p>' . __( 'Use "Tab Fields" to better organize your edit screen by grouping fields together.', 'acf') . '</p>';
		$message .= '<p>' . __( 'All fields following this "tab field" (or until another "tab field" is defined) will be grouped together using this field\'s label as the tab heading.','acf') . '</p>';


		// default_value
		acf_render_field_setting( $field, array(
		'label'         => __('Instructions','acf'),
		'instructions'  => '',
		'name'          => 'notes',
		'type'          => 'message',
		'message'       => $message,
		));
		*/

		// preview_size
		acf_render_field_setting(
			$field,
			array(
				'label'   => __( 'Placement', 'acf' ),
				'type'    => 'select',
				'name'    => 'placement',
				'choices' => array(
					'top'  => __( 'Top aligned', 'acf' ),
					'left' => __( 'Left aligned', 'acf' ),
				),
			)
		);

		// endpoint
		acf_render_field_setting(
			$field,
			array(
				'label'        => __( 'New Tab Group', 'acf' ),
				'instructions' => __( 'Start a new group of tabs at this tab.', 'acf' ),
				'name'         => 'endpoint',
				'type'         => 'true_false',
				'ui'           => 1,
			)
		);

	}


	/*
	*  load_field()
	*
	*  This filter is appied to the $field after it is loaded from the database
	*
	*  @type    filter
	*  @since   3.6
	*  @date    23/01/13
	*
	*  @param   $field - the field array holding all the field options
	*
	*  @return  $field - the field array holding all the field options
	*/
	function load_field( $field ) {

		// remove name to avoid caching issue
		$field['name'] = '';

		// remove instructions
		$field['instructions'] = '';

		// remove required to avoid JS issues
		$field['required'] = 0;

		// set value other than 'null' to avoid ACF loading / caching issue
		$field['value'] = false;

		// return
		return $field;

	}

}