Astra_Update_Sidebar_Width

Class Astra_Update_Sidebar_Width


Description


Source

File: inc/abilities/customizer/general/sidebar/class-astra-update-sidebar-width.php

class Astra_Update_Sidebar_Width extends Astra_Abstract_Ability {
	/**
	 * Configure the ability.
	 *
	 * @return void
	 */
	public function configure() {
		$this->id          = 'astra/update-sidebar-width';
		$this->category    = 'astra';
		$this->label       = __( 'Update Astra Sidebar Width', 'astra' );
		$this->description = __( 'Updates the sidebar width setting for the Astra theme (15-50%).', 'astra' );

		$this->meta = array(
			'tool_type' => 'write',
		);
	}

	/**
	 * Get tool type.
	 *
	 * @return string
	 */
	public function get_tool_type() {
		return 'write';
	}

	/**
	 * Get input schema.
	 *
	 * @return array
	 */
	public function get_input_schema() {
		return array(
			'type'       => 'object',
			'properties' => array(
				'width' => array(
					'type'        => 'integer',
					'description' => 'Sidebar width in percentage (15-50).',
					'minimum'     => 15,
					'maximum'     => 50,
				),
			),
			'required'   => array( 'width' ),
		);
	}

	/**
	 * Get examples.
	 *
	 * @return array
	 */
	public function get_examples() {
		return array(
			'set sidebar width to 30%',
			'change sidebar width to 25%',
			'update sidebar width to 35%',
			'set sidebar to 20% width',
			'make sidebar 30 percent wide',
			'change sidebar width 25',
			'set sidebar size to 30%',
			'update sidebar to 40% width',
			'change sidebar to 35 percent',
			'set sidebar width 30',
			'make sidebar width 25%',
			'update sidebar size to 30',
			'change sidebar to 20% wide',
			'set sidebar column to 30%',
			'make sidebar 35% width',
			'update sidebar width 25',
			'change sidebar area to 30%',
			'set sidebar space to 25%',
			'make sidebar 40 percent',
			'update sidebar dimension to 30',
			'change sidebar to 30 percent wide',
			'set sidebar width percentage to 25',
			'make sidebar column 30%',
			'update sidebar area width to 35',
			'change sidebar space to 30%',
			'set sidebar to 25 percent width',
			'make sidebar size 30%',
			'update site sidebar width',
			'change default sidebar width',
			'set sidebar width value to 30',
		);
	}

	/**
	 * Execute the ability.
	 *
	 * @param array $args Input arguments.
	 * @return array Result array.
	 */
	public function execute( $args ) {
		if ( ! isset( $args['width'] ) ) {
			return Astra_Abilities_Response::error(
				__( 'Width is required.', 'astra' ),
				__( 'Please provide a width value between 15 and 50.', 'astra' )
			);
		}

		$width = absint( $args['width'] );

		if ( $width < 15 || $width > 50 ) {
			return Astra_Abilities_Response::error(
				sprintf(
					/* translators: %d: width value */
					__( 'Invalid width: %d.', 'astra' ),
					$width
				),
				__( 'Width must be between 15 and 50 percent.', 'astra' )
			);
		}

		astra_update_option( 'site-sidebar-width', $width );

		$message = sprintf(
			/* translators: %d: width percentage */
			__( 'Sidebar width set to %d%%.', 'astra' ),
			$width
		);

		return Astra_Abilities_Response::success(
			$message,
			array(
				'updated' => true,
				'width'   => $width,
			)
		);
	}
}


Methods


User Contributed Notes

You must log in before being able to contribute a note or feedback.