Customizer: Return added instances for panels, sections, controls, and settings when calling WP_Customize_Manager::add_*() methods.

Add missing phpDoc.

Props fusillicode, jubstuff.
Fixes #34596.


git-svn-id: https://develop.svn.wordpress.org/trunk@35781 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Weston Ruter 2015-12-06 18:09:42 +00:00
parent db288f6aa3
commit 1689948965
2 changed files with 133 additions and 3 deletions

View File

@ -1037,10 +1037,13 @@ final class WP_Customize_Manager {
* Add a customize setting.
*
* @since 3.4.0
* @since 4.5.0 Return added WP_Customize_Setting instance.
* @access public
*
* @param WP_Customize_Setting|string $id Customize Setting object, or ID.
* @param array $args Setting arguments; passed to WP_Customize_Setting
* constructor.
* @return WP_Customize_Setting The instance of the setting that was added.
*/
public function add_setting( $id, $args = array() ) {
if ( $id instanceof WP_Customize_Setting ) {
@ -1048,7 +1051,9 @@ final class WP_Customize_Manager {
} else {
$setting = new WP_Customize_Setting( $this, $id, $args );
}
$this->settings[ $setting->id ] = $setting;
return $setting;
}
/**
@ -1061,6 +1066,7 @@ final class WP_Customize_Manager {
* even though they are not directly created statically with code.
*
* @since 4.2.0
* @access public
*
* @param array $setting_ids The setting IDs to add.
* @return array The WP_Customize_Setting objects added.
@ -1141,10 +1147,13 @@ final class WP_Customize_Manager {
* Add a customize panel.
*
* @since 4.0.0
* @since 4.5.0 Return added WP_Customize_Panel instance.
* @access public
*
* @param WP_Customize_Panel|string $id Customize Panel object, or Panel ID.
* @param array $args Optional. Panel arguments. Default empty array.
*
* @return WP_Customize_Panel The instance of the panel that was added.
*/
public function add_panel( $id, $args = array() ) {
if ( $id instanceof WP_Customize_Panel ) {
@ -1154,6 +1163,7 @@ final class WP_Customize_Manager {
}
$this->panels[ $panel->id ] = $panel;
return $panel;
}
/**
@ -1216,9 +1226,13 @@ final class WP_Customize_Manager {
* Add a customize section.
*
* @since 3.4.0
* @since 4.5.0 Return added WP_Customize_Section instance.
* @access public
*
* @param WP_Customize_Section|string $id Customize Section object, or Section ID.
* @param array $args Section arguments.
*
* @return WP_Customize_Section The instance of the section that was added.
*/
public function add_section( $id, $args = array() ) {
if ( $id instanceof WP_Customize_Section ) {
@ -1226,7 +1240,9 @@ final class WP_Customize_Manager {
} else {
$section = new WP_Customize_Section( $this, $id, $args );
}
$this->sections[ $section->id ] = $section;
return $section;
}
/**
@ -1286,10 +1302,13 @@ final class WP_Customize_Manager {
* Add a customize control.
*
* @since 3.4.0
* @since 4.5.0 Return added WP_Customize_Control instance.
* @access public
*
* @param WP_Customize_Control|string $id Customize Control object, or ID.
* @param array $args Control arguments; passed to WP_Customize_Control
* constructor.
* @return WP_Customize_Control The instance of the control that was added.
*/
public function add_control( $id, $args = array() ) {
if ( $id instanceof WP_Customize_Control ) {
@ -1297,7 +1316,9 @@ final class WP_Customize_Manager {
} else {
$control = new WP_Customize_Control( $this, $id, $args );
}
$this->controls[ $control->id ] = $control;
return $control;
}
/**

View File

@ -492,4 +492,113 @@ class Tests_WP_Customize_Manager extends WP_UnitTestCase {
$sorted_control_ids = wp_list_pluck( $manager->get_section( $section_id )->controls, 'id' );
$this->assertEquals( $added_control_ids, $sorted_control_ids );
}
/**
* @ticket 34596
*/
function test_add_section_return_instance() {
$manager = new WP_Customize_Manager();
wp_set_current_user( self::factory()->user->create( array( 'role' => 'administrator' ) ) );
$section_id = 'foo-section';
$result_section = $manager->add_section( $section_id, array(
'title' => 'Section',
'priority' => 1,
) );
$this->assertInstanceOf( 'WP_Customize_Section', $result_section );
$this->assertEquals( $section_id, $result_section->id );
$section = new WP_Customize_Section( $manager, $section_id, array(
'title' => 'Section 2',
'priority' => 2,
) );
$result_section = $manager->add_section( $section );
$this->assertInstanceOf( 'WP_Customize_Section', $result_section );
$this->assertEquals( $section_id, $result_section->id );
$this->assertEquals( $section, $result_section );
}
/**
* @ticket 34596
*/
function test_add_setting_return_instance() {
$manager = new WP_Customize_Manager();
wp_set_current_user( self::factory()->user->create( array( 'role' => 'administrator' ) ) );
$setting_id = 'foo-setting';
$result_setting = $manager->add_setting( $setting_id );
$this->assertInstanceOf( 'WP_Customize_Setting', $result_setting );
$this->assertEquals( $setting_id, $result_setting->id );
$setting = new WP_Customize_Setting( $manager, $setting_id );
$result_setting = $manager->add_setting( $setting );
$this->assertInstanceOf( 'WP_Customize_Setting', $result_setting );
$this->assertEquals( $setting, $result_setting );
$this->assertEquals( $setting_id, $result_setting->id );
}
/**
* @ticket 34596
*/
function test_add_panel_return_instance() {
$manager = new WP_Customize_Manager();
wp_set_current_user( self::factory()->user->create( array( 'role' => 'administrator' ) ) );
$panel_id = 'foo-panel';
$result_panel = $manager->add_panel( $panel_id, array(
'title' => 'Test Panel',
'priority' => 2,
) );
$this->assertInstanceOf( 'WP_Customize_Panel', $result_panel );
$this->assertEquals( $panel_id, $result_panel->id );
$panel = new WP_Customize_Panel( $manager, $panel_id, array(
'title' => 'Test Panel 2',
) );
$result_panel = $manager->add_panel( $panel );
$this->assertInstanceOf( 'WP_Customize_Panel', $result_panel );
$this->assertEquals( $panel, $result_panel );
$this->assertEquals( $panel_id, $result_panel->id );
}
/**
* @ticket 34596
*/
function test_add_control_return_instance() {
$manager = new WP_Customize_Manager();
$section_id = 'foo-section';
wp_set_current_user( self::factory()->user->create( array( 'role' => 'administrator' ) ) );
$manager->add_section( $section_id, array(
'title' => 'Section',
'priority' => 1,
) );
$control_id = 'foo-control';
$manager->add_setting( $control_id );
$result_control = $manager->add_control( $control_id, array(
'section' => $section_id,
'priority' => 1,
'setting' => $control_id,
) );
$this->assertInstanceOf( 'WP_Customize_Control', $result_control );
$this->assertEquals( $control_id, $result_control->id );
$control = new WP_Customize_Control( $manager, $control_id, array(
'section' => $section_id,
'priority' => 1,
'setting' => $control_id,
) );
$result_control = $manager->add_control( $control );
$this->assertInstanceOf( 'WP_Customize_Control', $result_control );
$this->assertEquals( $control, $result_control );
$this->assertEquals( $control_id, $result_control->id );
}
}