HEX
Server: Apache
System: Linux WWW 6.1.0-40-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.153-1 (2025-09-20) x86_64
User: web11 (1011)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: /var/www/lcc.kaunokolegija.lt/wp-content/plugins/so-widgets-bundle/base/inc/meta-box-manager.php
<?php

class SiteOrigin_Widget_Meta_Box_Manager extends SiteOrigin_Widget {
	const POST_META_KEY = 'siteorigin-widgets-post-meta';

	/**
	 * @var array Fields which have been added for each widget.
	 */
	private $widget_form_fields;

	/**
	 * @var array Post types for which fields have been added.
	 */
	private $post_types;

	/**
	 * Get the single instance.
	 *
	 * @return SiteOrigin_Widget_Meta_Box_Manager
	 */
	public static function single() {
		static $single = false;

		if ( empty( $single ) ) {
			$single = new SiteOrigin_Widget_Meta_Box_Manager();
		}

		return $single;
	}

	/**
	 * Private
	 */
	public function __construct() {
		parent::__construct(
			'sow-meta-box-manager',
			__( 'SiteOrigin Meta Box Manager', 'so-widgets-bundle' ),
			array(
				'has_preview' => false,
				'help' => false,
			),
			array(),
			array()
		);
	}

	public function initialize() {
		// Initialize number for field name attributes.
		$this->number = 1;
		$this->post_types = array();
		$this->widget_form_fields = array();

		add_action( 'add_meta_boxes', array( $this, 'add_meta_boxes' ) );
		add_action( 'save_post', array( $this, 'save_widget_post_meta' ), 10, 3 );
	}

	/**
	 * This handles the 'add_meta_boxes' action. It merges widget fields into the form_options array before adding the
	 * meta box
	 */
	public function add_meta_boxes( $post_type ) {
		$this->form_options = array();

		foreach ( $this->widget_form_fields as $widget_id => $post_type_form_fields ) {
			foreach ( $post_type_form_fields as $form_fields ) {
				if ( in_array( 'all', $form_fields['post_types'] ) || in_array( $post_type, $form_fields['post_types'] ) ) {
					foreach ( $form_fields['fields'] as $field_name => $field ) {
						$this->form_options[ $widget_id . '_' . $field_name ] = $field;
					}
				}
			}
		}

		if ( ! empty( $this->form_options ) ) {
			add_meta_box(
				'siteorigin-widgets-meta-box',
				__( 'Widgets Bundle Post Meta Data', 'so-widgets-bundle' ),
				array( $this, 'render_widgets_meta_box' ),
				$post_type,
				'advanced',
				'default',
				array(
					'__back_compat_meta_box' => true,
					'__block_editor_compatible_meta_box' => false,
				)
			);
		}
	}

	/**
	 * This is the callback used by add_meta_box to render the widgets meta box form and enqueue any necessary scripts.
	 */
	public function render_widgets_meta_box( $post ) {
		wp_enqueue_script(
			'sow-meta-box-manager-js',
			plugin_dir_url( SOW_BUNDLE_BASE_FILE ) . 'base/js/meta-box-manager' . SOW_BUNDLE_JS_SUFFIX . '.js',
			array( 'jquery' ),
			SOW_BUNDLE_VERSION,
			true
		);
		$widget_post_meta = get_post_meta( $post->ID, self::POST_META_KEY, true );

		if ( empty( $widget_post_meta ) ) {
			$widget_post_meta = array();
		}
		$this->form( $widget_post_meta );
		?><input type="hidden" id="widget_post_meta" name="widget_post_meta"> <?php
		wp_nonce_field( 'widget_post_meta_save', '_widget_post_meta_nonce' );
	}

	/**
	 * This method should be called by any widgets that want to be able to store post meta data. It may be called
	 * multiple times by a widget and the additional fields for a widget will be appended and rendered.
	 *
	 * @param string       $widget_id  Base id of the widget adding the fields.
	 * @param array        $fields     The fields to add.
	 * @param string|array $post_types A post type string, 'all' or an array of post types
	 */
	public function append_to_form( $widget_id, $fields, $post_types = 'all' ) {
		if ( empty( $fields ) || empty( $post_types ) ) {
			return;
		}

		if ( $post_types == 'all' ) {
			$post_types = array( 'all' );
		}

		foreach ( $post_types as $post_type ) {
			if ( ! in_array( $post_type, $this->post_types ) ) {
				$this->post_types[] = $post_type;
			}
		}

		if ( ! isset( $this->widget_form_fields[ $widget_id ] ) ) {
			$this->widget_form_fields [$widget_id ] = array();
		}

		$this->widget_form_fields[ $widget_id ][] = array(
			'post_types' => $post_types,
			'fields' => $fields,
		);
	}

	/**
	 * This handles the 'save_post' action. It checks for a nonce, checks user permissions, and filters the input data
	 * and decodes it from the JSON format before storing it in the post's meta data.
	 */
	public function save_widget_post_meta( $post_id ) {
		if ( empty( $_POST['_widget_post_meta_nonce'] ) || !wp_verify_nonce( $_POST['_widget_post_meta_nonce'], 'widget_post_meta_save' ) ) {
			return;
		}

		if ( !current_user_can( 'edit_post', $post_id ) ) {
			return;
		}

		$widget_post_meta = isset( $_POST['widget_post_meta'] ) ? stripslashes_deep( $_POST['widget_post_meta'] ) : '';
		$widget_post_meta = json_decode( $widget_post_meta, true );

		update_post_meta( $post_id, self::POST_META_KEY, $widget_post_meta );
	}

	/**
	 * This function is used to retrieve a widget's post meta data.
	 *
	 * @param $post_id string The id of the post for which the meta data is stored.
	 * @param $widget_id string The id of the widget for which the meta data is stored.
	 * @param $meta_key string The key of the meta data value which is to be retrieved.
	 *
	 * @return mixed An empty string if the meta data is not found, else the meta data in whatever format it was stored.
	 */
	public function get_widget_post_meta( $post_id, $widget_id, $meta_key ) {
		$widget_post_meta = get_post_meta( $post_id, self::POST_META_KEY, true );

		if ( empty( $widget_post_meta ) ) {
			return '';
		}
		$widget_post_meta_field = $widget_id . '_' . $meta_key;

		if ( ! isset( $widget_post_meta[ $widget_post_meta_field ] ) ) {
			return '';
		}

		return $widget_post_meta[ $widget_post_meta_field ];
	}
}