GC_Customize_Nav_Menu_Item_Setting::sanitize()

最后更新于:2021-11-27 05:35:10

GC_Customize_Nav_Menu_Item_Setting::sanitize( array$menu_item_value)

Sanitize an input.

参数

$menu_item_value

(array) (Required) The value to sanitize.

响应

(array|false|null|GC_Error) Null or GC_Error if an input isn’t valid. False if it is marked for deletion. Otherwise the sanitized value.

源文件

文件: gc-includes/customize/class-gc-customize-nav-menu-item-setting.php

	public function sanitize( $menu_item_value ) {
		// Menu is marked for deletion.
		if ( false === $menu_item_value ) {
			return $menu_item_value;
		}

		// Invalid.
		if ( ! is_array( $menu_item_value ) ) {
			return null;
		}

		$default                     = array(
			'object_id'        => 0,
			'object'           => '',
			'menu_item_parent' => 0,
			'position'         => 0,
			'type'             => 'custom',
			'title'            => '',
			'url'              => '',
			'target'           => '',
			'attr_title'       => '',
			'description'      => '',
			'classes'          => '',
			'xfn'              => '',
			'status'           => 'publish',
			'original_title'   => '',
			'nav_menu_term_id' => 0,
			'_invalid'         => false,
		);
		$menu_item_value             = array_merge( $default, $menu_item_value );
		$menu_item_value             = gc_array_slice_assoc( $menu_item_value, array_keys( $default ) );
		$menu_item_value['position'] = (int) $menu_item_value['position'];

		foreach ( array( 'object_id', 'menu_item_parent', 'nav_menu_term_id' ) as $key ) {
			// Note we need to allow negative-integer IDs for previewed objects not inserted yet.
			$menu_item_value[ $key ] = (int) $menu_item_value[ $key ];
		}

		foreach ( array( 'type', 'object', 'target' ) as $key ) {
			$menu_item_value[ $key ] = sanitize_key( $menu_item_value[ $key ] );
		}

		foreach ( array( 'xfn', 'classes' ) as $key ) {
			$value = $menu_item_value[ $key ];
			if ( ! is_array( $value ) ) {
				$value = explode( ' ', $value );
			}
			$menu_item_value[ $key ] = implode( ' ', array_map( 'sanitize_html_class', $value ) );
		}

		$menu_item_value['original_title'] = sanitize_text_field( $menu_item_value['original_title'] );

		// Apply the same filters as when calling gc_insert_post().

		/** This filter is documented in gc-includes/post.php */
		$menu_item_value['title'] = gc_unslash( apply_filters( 'title_save_pre', gc_slash( $menu_item_value['title'] ) ) );

		/** This filter is documented in gc-includes/post.php */
		$menu_item_value['attr_title'] = gc_unslash( apply_filters( 'excerpt_save_pre', gc_slash( $menu_item_value['attr_title'] ) ) );

		/** This filter is documented in gc-includes/post.php */
		$menu_item_value['description'] = gc_unslash( apply_filters( 'content_save_pre', gc_slash( $menu_item_value['description'] ) ) );

		if ( '' !== $menu_item_value['url'] ) {
			$menu_item_value['url'] = esc_url_raw( $menu_item_value['url'] );
			if ( '' === $menu_item_value['url'] ) {
				return new GC_Error( 'invalid_url', __( 'Invalid URL.' ) ); // Fail sanitization if URL is invalid.
			}
		}
		if ( 'publish' !== $menu_item_value['status'] ) {
			$menu_item_value['status'] = 'draft';
		}

		$menu_item_value['_invalid'] = (bool) $menu_item_value['_invalid'];

		/** This filter is documented in gc-includes/class-gc-customize-setting.php */
		return apply_filters( "customize_sanitize_{$this->id}", $menu_item_value, $this );
	}