114 lines
2.8 KiB
PHP
114 lines
2.8 KiB
PHP
<?php
|
|
namespace ElementorPro\Modules\Posts\Widgets;
|
|
|
|
use Elementor\Controls_Manager;
|
|
use ElementorPro\Modules\QueryControl\Module as Module_Query;
|
|
use ElementorPro\Modules\QueryControl\Controls\Group_Control_Related;
|
|
use ElementorPro\Modules\Posts\Skins;
|
|
|
|
if ( ! defined( 'ABSPATH' ) ) {
|
|
exit; // Exit if accessed directly
|
|
}
|
|
|
|
/**
|
|
* Class Posts
|
|
*/
|
|
class Posts extends Posts_Base {
|
|
|
|
public function get_name() {
|
|
return 'posts';
|
|
}
|
|
|
|
public function get_title() {
|
|
return esc_html__( 'Posts', 'elementor-pro' );
|
|
}
|
|
|
|
public function get_keywords() {
|
|
return [ 'posts', 'cpt', 'item', 'loop', 'query', 'cards', 'custom post type' ];
|
|
}
|
|
|
|
public function on_import( $element ) {
|
|
if ( isset( $element['settings']['posts_post_type'] ) && ! get_post_type_object( $element['settings']['posts_post_type'] ) ) {
|
|
$element['settings']['posts_post_type'] = 'post';
|
|
}
|
|
|
|
return $element;
|
|
}
|
|
|
|
protected function register_skins() {
|
|
$this->add_skin( new Skins\Skin_Classic( $this ) );
|
|
$this->add_skin( new Skins\Skin_Cards( $this ) );
|
|
$this->add_skin( new Skins\Skin_Full_Content( $this ) );
|
|
}
|
|
|
|
protected function register_controls() {
|
|
parent::register_controls();
|
|
|
|
$this->register_query_section_controls();
|
|
$this->register_pagination_section_controls();
|
|
}
|
|
|
|
/**
|
|
* Get Query Name
|
|
*
|
|
* Returns the query control name used in the widget's main query.
|
|
*
|
|
* @since 3.8.0
|
|
*
|
|
* @return string
|
|
*/
|
|
public function get_query_name() {
|
|
return $this->get_name();
|
|
}
|
|
|
|
public function query_posts() {
|
|
$query_args = [
|
|
'posts_per_page' => $this->get_posts_per_page_value(),
|
|
'paged' => $this->get_current_page(),
|
|
'has_custom_pagination' => $this->is_allow_to_use_custom_page_option(),
|
|
];
|
|
|
|
/** @var Module_Query $elementor_query */
|
|
$elementor_query = Module_Query::instance();
|
|
$this->query = $elementor_query->get_query( $this, $this->get_query_name(), $query_args, [] );
|
|
}
|
|
|
|
/**
|
|
* Get Posts Per Page Value
|
|
*
|
|
* Returns the value of the Posts Per Page control of the widget. This method was created because in some cases,
|
|
* the control is registered in the widget, and in some cases, it is registered in a widget skin.
|
|
*
|
|
* @since 3.8.0
|
|
* @access protected
|
|
*
|
|
* @return mixed
|
|
*/
|
|
protected function get_posts_per_page_value() {
|
|
return $this->get_current_skin()->get_instance_value( 'posts_per_page' );
|
|
}
|
|
|
|
protected function register_query_section_controls() {
|
|
$this->start_controls_section(
|
|
'section_query',
|
|
[
|
|
'label' => esc_html__( 'Query', 'elementor-pro' ),
|
|
'tab' => Controls_Manager::TAB_CONTENT,
|
|
]
|
|
);
|
|
|
|
$this->add_group_control(
|
|
Group_Control_Related::get_type(),
|
|
[
|
|
'name' => $this->get_name(),
|
|
'presets' => [ 'full' ],
|
|
'exclude' => [
|
|
'posts_per_page', //use the one from Layout section
|
|
],
|
|
]
|
|
);
|
|
|
|
$this->end_controls_section();
|
|
}
|
|
}
|