158 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			158 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * WPSEO plugin file.
 | |
|  *
 | |
|  * @package WPSEO\Admin\Menu
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * Renders a replacement variable editor.
 | |
|  */
 | |
| class WPSEO_Replacevar_Editor {
 | |
| 
 | |
| 	/**
 | |
| 	 * Yoast Forms instance.
 | |
| 	 *
 | |
| 	 * @var Yoast_Form
 | |
| 	 */
 | |
| 	private $yform;
 | |
| 
 | |
| 	/**
 | |
| 	 * The arguments required for the div to render.
 | |
| 	 *
 | |
| 	 * @var array {
 | |
| 	 *      @type string $title                   The title field id.
 | |
| 	 *      @type string $description             The description field id.
 | |
| 	 *      @type string $page_type_recommended   The page type for the context of the recommended replace vars.
 | |
| 	 *      @type string $page_type_specific      The page type for the context of the editor specific replace vars.
 | |
| 	 *      @type bool   $paper_style             Optional. Whether the editor has paper style.
 | |
| 	 *      @type string $label_title             Optional. The label to use for the title field.
 | |
| 	 *      @type string $label_description       Optional. The label to use for the description field.
 | |
| 	 *      @type string $description_placeholder Optional. The placeholder text to use for the description field.
 | |
| 	 *      @type bool   $has_new_badge           Optional. Whether to show the "New" badge.
 | |
| 	 *      @type bool   $has_premium_badge       Optional. Whether to show the "Premium" badge.
 | |
| 	 * }
 | |
| 	 */
 | |
| 	private $arguments;
 | |
| 
 | |
| 	/**
 | |
| 	 * Constructs the object.
 | |
| 	 *
 | |
| 	 * @param Yoast_Form $yform     Yoast forms.
 | |
| 	 * @param array      $arguments {
 | |
| 	 *      The arguments that can be given.
 | |
| 	 *
 | |
| 	 *      @type string $title                   The title field id.
 | |
| 	 *      @type string $description             The description field id.
 | |
| 	 *      @type string $page_type_recommended   The page type for the context of the recommended replace vars.
 | |
| 	 *      @type string $page_type_specific      The page type for the context of the editor specific replace vars.
 | |
| 	 *      @type bool   $paper_style             Optional. Whether the editor has paper style.
 | |
| 	 *      @type string $label_title             Optional. The label to use for the title field.
 | |
| 	 *      @type string $label_description       Optional. The label to use for the description field.
 | |
| 	 *      @type string $description_placeholder Optional. The placeholder text to use for the description field.
 | |
| 	 *      @type bool   $has_new_badge           Optional. Whether to show the "New" badge.
 | |
| 	 *      @type bool   $has_premium_badge       Optional. Whether to show the "Premium" badge.
 | |
| 	 * }
 | |
| 	 */
 | |
| 	public function __construct( Yoast_Form $yform, $arguments ) {
 | |
| 		$arguments = wp_parse_args(
 | |
| 			$arguments,
 | |
| 			[
 | |
| 				'paper_style'             => true,
 | |
| 				'label_title'             => '',
 | |
| 				'label_description'       => '',
 | |
| 				'description_placeholder' => '',
 | |
| 				'has_new_badge'           => false,
 | |
| 				'is_disabled'             => false,
 | |
| 				'has_premium_badge'       => false,
 | |
| 			]
 | |
| 		);
 | |
| 
 | |
| 		$this->validate_arguments( $arguments );
 | |
| 
 | |
| 		$this->yform     = $yform;
 | |
| 		$this->arguments = [
 | |
| 			'title'                   => (string) $arguments['title'],
 | |
| 			'description'             => (string) $arguments['description'],
 | |
| 			'page_type_recommended'   => (string) $arguments['page_type_recommended'],
 | |
| 			'page_type_specific'      => (string) $arguments['page_type_specific'],
 | |
| 			'paper_style'             => (bool) $arguments['paper_style'],
 | |
| 			'label_title'             => (string) $arguments['label_title'],
 | |
| 			'label_description'       => (string) $arguments['label_description'],
 | |
| 			'description_placeholder' => (string) $arguments['description_placeholder'],
 | |
| 			'has_new_badge'           => (bool) $arguments['has_new_badge'],
 | |
| 			'is_disabled'             => (bool) $arguments['is_disabled'],
 | |
| 			'has_premium_badge'       => (bool) $arguments['has_premium_badge'],
 | |
| 		];
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Renders a div for the react application to mount to, and hidden inputs where
 | |
| 	 * the app should store it's value so they will be properly saved when the form
 | |
| 	 * is submitted.
 | |
| 	 *
 | |
| 	 * @return void
 | |
| 	 */
 | |
| 	public function render() {
 | |
| 		$this->yform->hidden( $this->arguments['title'], $this->arguments['title'] );
 | |
| 		$this->yform->hidden( $this->arguments['description'], $this->arguments['description'] );
 | |
| 
 | |
| 		printf(
 | |
| 			'<div
 | |
| 				data-react-replacevar-editor
 | |
| 				data-react-replacevar-title-field-id="%1$s"
 | |
| 				data-react-replacevar-metadesc-field-id="%2$s"
 | |
| 				data-react-replacevar-page-type-recommended="%3$s"
 | |
| 				data-react-replacevar-page-type-specific="%4$s"
 | |
| 				data-react-replacevar-paper-style="%5$s"
 | |
| 				data-react-replacevar-label-title="%6$s"
 | |
| 				data-react-replacevar-label-description="%7$s"
 | |
| 				data-react-replacevar-description-placeholder="%8$s"
 | |
| 				data-react-replacevar-has-new-badge="%9$s"
 | |
| 				data-react-replacevar-is-disabled="%10$s"
 | |
| 				data-react-replacevar-has-premium-badge="%11$s"
 | |
| 			></div>',
 | |
| 			esc_attr( $this->arguments['title'] ),
 | |
| 			esc_attr( $this->arguments['description'] ),
 | |
| 			esc_attr( $this->arguments['page_type_recommended'] ),
 | |
| 			esc_attr( $this->arguments['page_type_specific'] ),
 | |
| 			esc_attr( $this->arguments['paper_style'] ),
 | |
| 			esc_attr( $this->arguments['label_title'] ),
 | |
| 			esc_attr( $this->arguments['label_description'] ),
 | |
| 			esc_attr( $this->arguments['description_placeholder'] ),
 | |
| 			esc_attr( $this->arguments['has_new_badge'] ),
 | |
| 			esc_attr( $this->arguments['is_disabled'] ),
 | |
| 			esc_attr( $this->arguments['has_premium_badge'] )
 | |
| 		);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Validates the replacement variable editor arguments.
 | |
| 	 *
 | |
| 	 * @param array $arguments The arguments to validate.
 | |
| 	 *
 | |
| 	 * @throws InvalidArgumentException Thrown when not all required arguments are present.
 | |
| 	 */
 | |
| 	protected function validate_arguments( array $arguments ) {
 | |
| 		$required_arguments = [
 | |
| 			'title',
 | |
| 			'description',
 | |
| 			'page_type_recommended',
 | |
| 			'page_type_specific',
 | |
| 			'paper_style',
 | |
| 		];
 | |
| 
 | |
| 		foreach ( $required_arguments as $field_name ) {
 | |
| 			if ( ! array_key_exists( $field_name, $arguments ) ) {
 | |
| 				throw new InvalidArgumentException(
 | |
| 					sprintf(
 | |
| 						/* translators: %1$s expands to the missing field name.  */
 | |
| 						__( 'Not all required fields are given. Missing field %1$s', 'wordpress-seo' ),
 | |
| 						$field_name
 | |
| 					)
 | |
| 				);
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| }
 |