| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394 |
- <?php
- namespace Elementor;
- if ( ! defined( 'ABSPATH' ) ) {
- exit; // Exit if accessed directly.
- }
- /**
- * Elementor elements manager.
- *
- * Elementor elements manager handler class is responsible for registering and
- * initializing all the supported elements.
- *
- * @since 1.0.0
- */
- class Elements_Manager {
- /**
- * Element types.
- *
- * Holds the list of all the element types.
- *
- * @access private
- *
- * @var Element_Base[]
- */
- private $_element_types;
- /**
- * Element categories.
- *
- * Holds the list of all the element categories.
- *
- * @access private
- *
- * @var
- */
- private $categories;
- /**
- * Elements constructor.
- *
- * Initializing Elementor elements manager.
- *
- * @since 1.0.0
- * @access public
- */
- public function __construct() {
- $this->require_files();
- }
- /**
- * Create element instance.
- *
- * This method creates a new element instance for any given element.
- *
- * @since 1.0.0
- * @access public
- *
- * @param array $element_data Element data.
- * @param array $element_args Optional. Element arguments. Default is
- * an empty array.
- * @param Element_Base $element_type Optional. Element type. Default is null.
- *
- * @return Element_Base|null Element instance if element created, or null
- * otherwise.
- */
- public function create_element_instance( array $element_data, array $element_args = [], Element_Base $element_type = null ) {
- if ( null === $element_type ) {
- if ( 'widget' === $element_data['elType'] ) {
- $element_type = Plugin::$instance->widgets_manager->get_widget_types( $element_data['widgetType'] );
- } else {
- $element_type = $this->get_element_types( $element_data['elType'] );
- }
- }
- if ( ! $element_type ) {
- return null;
- }
- $args = array_merge( $element_type->get_default_args(), $element_args );
- $element_class = $element_type->get_class_name();
- try {
- $element = new $element_class( $element_data, $args );
- } catch ( \Exception $e ) {
- return null;
- }
- return $element;
- }
- /**
- * Get element categories.
- *
- * Retrieve the list of categories the element belongs to.
- *
- * @since 1.0.0
- * @access public
- *
- * @return array Element categories.
- */
- public function get_categories() {
- if ( null === $this->categories ) {
- $this->init_categories();
- }
- return $this->categories;
- }
- /**
- * Add element category.
- *
- * Register new category for the element.
- *
- * @since 1.7.12
- * @since 2.0.0 The third parameter was deprecated.
- * @access public
- *
- * @param string $category_name Category name.
- * @param array $category_properties Category properties.
- */
- public function add_category( $category_name, $category_properties ) {
- if ( null === $this->categories ) {
- $this->get_categories();
- }
- if ( ! isset( $this->categories[ $category_name ] ) ) {
- $this->categories[ $category_name ] = $category_properties;
- }
- }
- /**
- * Register element type.
- *
- * Add new type to the list of registered types.
- *
- * @since 1.0.0
- * @access public
- *
- * @param Element_Base $element Element instance.
- *
- * @return bool Whether the element type was registered.
- */
- public function register_element_type( Element_Base $element ) {
- $this->_element_types[ $element->get_name() ] = $element;
- return true;
- }
- /**
- * Unregister element type.
- *
- * Remove element type from the list of registered types.
- *
- * @since 1.0.0
- * @access public
- *
- * @param string $name Element name.
- *
- * @return bool Whether the element type was unregister, or not.
- */
- public function unregister_element_type( $name ) {
- if ( ! isset( $this->_element_types[ $name ] ) ) {
- return false;
- }
- unset( $this->_element_types[ $name ] );
- return true;
- }
- /**
- * Get element types.
- *
- * Retrieve the list of all the element types, or if a specific element name
- * was provided retrieve his element types.
- *
- * @since 1.0.0
- * @access public
- *
- * @param string $element_name Optional. Element name. Default is null.
- *
- * @return null|Element_Base|Element_Base[] Element types, or a list of all the element
- * types, or null if element does not exist.
- */
- public function get_element_types( $element_name = null ) {
- if ( is_null( $this->_element_types ) ) {
- $this->init_elements();
- }
- if ( null !== $element_name ) {
- return isset( $this->_element_types[ $element_name ] ) ? $this->_element_types[ $element_name ] : null;
- }
- return $this->_element_types;
- }
- /**
- * Get element types config.
- *
- * Retrieve the config of all the element types.
- *
- * @since 1.0.0
- * @access public
- *
- * @return array Element types config.
- */
- public function get_element_types_config() {
- $config = [];
- foreach ( $this->get_element_types() as $element ) {
- $config[ $element->get_name() ] = $element->get_config();
- }
- return $config;
- }
- /**
- * Render elements content.
- *
- * Used to generate the elements templates on the editor.
- *
- * @since 1.0.0
- * @access public
- */
- public function render_elements_content() {
- foreach ( $this->get_element_types() as $element_type ) {
- $element_type->print_template();
- }
- }
- /**
- * Ajax discard changes.
- *
- * Ajax handler for Elementor discard_changes. Handles the discarded changes
- * in the builder by deleting auto-saved revisions.
- *
- * Fired by `wp_ajax_elementor_discard_changes` action.
- *
- * @since 1.9.0
- * @deprecated 2.0.0 Use `Plugin::$instance->documents->ajax_discard_changes()` method instead.
- * @access public
- *
- * @param $request
- *
- * @return bool
- */
- public function ajax_discard_changes( $request ) {
- _deprecated_function( __METHOD__, '2.0.0', 'Plugin::$instance->documents->ajax_discard_changes()' );
- return Plugin::$instance->documents->ajax_discard_changes( $request );
- }
- /**
- * Ajax save builder.
- *
- * Ajax handler for Elementor save_builder. Handles the saved data returned
- * by the builder.
- *
- * Fired by `wp_ajax_elementor_save_builder` action.
- *
- * @since 1.0.0
- * @deprecated 2.0.0 Use `Plugin::$instance->documents->ajax_save()` method instead.
- * @access public
- *
- * @param array $request
- *
- * @return mixed
- */
- public function ajax_save_builder( $request ) {
- _deprecated_function( __METHOD__, '2.0.0', 'Plugin::$instance->documents->ajax_save()' );
- $return_data = Plugin::$instance->documents->ajax_save( $request );
- /**
- * Returned ajax data.
- *
- * Filters the ajax data returned when saving the post on the builder.
- *
- * @since 1.0.0
- * @deprecated 2.0.0 Use `elementor/documents/ajax_save/return_data` filter instead.
- *
- * @param array $return_data The returned data. Default is an empty array.
- */
- $return_data = apply_filters_deprecated( 'elementor/ajax_save_builder/return_data', [ $return_data, $request['editor_post_id'] ], '2.0.0', 'elementor/documents/ajax_save/return_data' );
- return $return_data;
- }
- /**
- * Init elements.
- *
- * Initialize Elementor elements by registering the supported elements.
- * Elementor supports by default `section` element and `column` element.
- *
- * @since 2.0.0
- * @access private
- */
- private function init_elements() {
- $this->_element_types = [];
- foreach ( [ 'section', 'column' ] as $element_name ) {
- $class_name = __NAMESPACE__ . '\Element_' . $element_name;
- $this->register_element_type( new $class_name() );
- }
- /**
- * After elements registered.
- *
- * Fires after Elementor elements are registered.
- *
- * @since 1.0.0
- */
- do_action( 'elementor/elements/elements_registered' );
- }
- /**
- * Init categories.
- *
- * Initialize the element categories.
- *
- * @since 1.7.12
- * @access private
- */
- private function init_categories() {
- $this->categories = [
- 'basic' => [
- 'title' => __( 'Basic', 'elementor' ),
- 'icon' => 'eicon-font',
- ],
- 'pro-elements' => [
- 'title' => __( 'Pro', 'elementor' ),
- ],
- 'general' => [
- 'title' => __( 'General', 'elementor' ),
- 'icon' => 'eicon-font',
- ],
- 'theme-elements' => [
- 'title' => __( 'Site', 'elementor' ),
- 'active' => false,
- ],
- 'woocommerce-elements' => [
- 'title' => __( 'WooCommerce', 'elementor' ),
- 'active' => false,
- ],
- ];
- /**
- * When categories are registered.
- *
- * Fires after basic categories are registered, before WordPress
- * category have been registered.
- *
- * This is where categories registered by external developers are
- * added.
- *
- * @since 2.0.0
- *
- * @param Elements_Manager $this Elements manager instance.
- */
- do_action( 'elementor/elements/categories_registered', $this );
- $this->categories['pojo'] = [
- 'title' => __( 'Pojo Themes', 'elementor' ),
- 'icon' => 'eicon-pojome',
- ];
- $this->categories['wordpress'] = [
- 'title' => __( 'WordPress', 'elementor' ),
- 'icon' => 'eicon-wordpress',
- 'active' => false,
- ];
- }
- /**
- * Require files.
- *
- * Require Elementor element base class and column, section and repeater
- * elements.
- *
- * @since 1.0.0
- * @access private
- */
- private function require_files() {
- require_once ELEMENTOR_PATH . 'includes/base/element-base.php';
- require ELEMENTOR_PATH . 'includes/elements/column.php';
- require ELEMENTOR_PATH . 'includes/elements/section.php';
- require ELEMENTOR_PATH . 'includes/elements/repeater.php';
- }
- }
|