PUM_Repository_Popups
Class PUM_Repository_Popups
Description Description
Source Source
File: classes/Repository/Popups.php
class PUM_Repository_Popups extends PUM_Abstract_Repository_Posts { /** * @var string */ protected $model = 'PUM_Model_Popup'; /** * @return string */ protected function get_post_type() { return 'popup'; } /** * Build the args for WP Query. * * @param array $args * * @return array */ protected function build_wp_query_args( $args = array() ) { // Ordering $orderby = array(); // Meta Query if ( ! isset( $args['meta_query'] ) ) { $args['meta_query'] = array( 'relation' => 'AND', ); } if ( isset( $args['popups'] ) ) { /** * If Looking for specific popups. No need for filtering. */ $args['post__in'] = wp_parse_id_list( $args['popups'] ); unset( $args['popups'] ); } /** * Apply easy ordering options or allow setting it manually. */ if ( ! isset( $args['orderby'] ) ) { $orderby['post_modified'] = isset( $args['order'] ) ? $args['order'] : 'DESC'; } elseif ( ! empty( $args['post__in'] ) && in_array( $args['orderby'], array( 'post__in', 'user_order' ) ) ) { // This one can't be part of an $orderby array so needs to override. $orderby = 'post__in'; } else { switch ( $args['orderby'] ) { case 'name' : $orderby['post_title'] = isset( $args['order'] ) ? $args['order'] : 'ASC'; break; case 'date' : $orderby['post_date'] = isset( $args['order'] ) ? $args['order'] : 'DESC'; break; case 'activity': $orderby['post_modified'] = isset( $args['order'] ) ? $args['order'] : 'DESC'; break; default: $orderby[ $args['orderby'] ] = isset( $args['order'] ) ? $args['order'] : 'DESC'; break; } } // Replace the orderby property with the new $orderby array. $args['orderby'] = $orderby; // Clear unneeded values. unset( $args['order'] ); return parent::build_wp_query_args( $args ); } /** * @param int $id * * @return PUM_Model_Popup|WP_Post * @throws \InvalidArgumentException */ public function get_item( $id ) { return parent::get_item( $id ); } /** * @param array $args * * @return PUM_Model_Popup[]|WP_Post[] */ public function get_items( $args = array() ) { return parent::get_items( $args ); } /** * @param array $data * * @return PUM_Model_Popup|WP_Post * @throws InvalidArgumentException */ public function create_item( $data ) { return parent::create_item( $data ); } /** * @param int $id * @param array $data * * @return PUM_Model_Popup|WP_Post * @throws Exception */ public function update_item( $id, $data ) { return parent::update_item( $id, $data ); } /** * Assert that data is valid. * * @param array $data * * @throws InvalidArgumentException */ protected function assert_data( $data ) { // REQUIRED: Implement assert_data() method. } }
Expand full source code Collapse full source code View on Trac
Methods Methods
- assert_data — Assert that data is valid.
- build_wp_query_args — Build the args for WP Query.
- create_item
- get_item
- get_items
- get_post_type
- update_item