laipower/wp-content/plugins/easy-digital-downloads/includes/admin/discounts/class-discount-codes-table.php

460 lines
12 KiB
PHP

<?php
/**
* Discount Codes Table Class
*
* @package EDD
* @subpackage Admin/Discounts
* @copyright Copyright (c) 2018, Easy Digital Downloads, LLC
* @license http://opensource.org/licenses/gpl-2.0.php GNU Public License
* @since 1.4
*/
// Exit if accessed directly
defined( 'ABSPATH' ) || exit;
use EDD\Admin\List_Table;
/**
* EDD_Discount_Codes_Table Class
*
* Renders the Discount Codes table on the Discount Codes page
*
* @since 1.4
* @since 3.0 Updated to work with the discount code migration to custom tables.
*/
class EDD_Discount_Codes_Table extends List_Table {
/**
* Get things started
*
* @since 1.4
* @see WP_List_Table::__construct()
*/
public function __construct() {
parent::__construct( array(
'singular' => 'discount',
'plural' => 'discounts',
'ajax' => false,
) );
$this->process_bulk_action();
$this->get_counts();
}
/**
* Get the base URL for the discount list table
*
* @since 3.0
*
* @return string
*/
public function get_base_url() {
// Remove some query arguments
$base = remove_query_arg( edd_admin_removable_query_args(), edd_get_admin_base_url() );
// Add base query args
return add_query_arg( array(
'page' => 'edd-discounts',
), $base );
}
/**
* Retrieve the table columns
*
* @since 1.4
*
* @return array $columns Array of all the list table columns
*/
public function get_columns() {
return apply_filters( 'edd_discounts_table_columns', array(
'cb' => '<input type="checkbox" />',
'name' => __( 'Name', 'easy-digital-downloads' ),
'code' => __( 'Code', 'easy-digital-downloads' ),
'amount' => __( 'Amount', 'easy-digital-downloads' ),
'use_count' => __( 'Uses', 'easy-digital-downloads' ),
'start_date' => __( 'Start Date', 'easy-digital-downloads' ),
'end_date' => __( 'End Date', 'easy-digital-downloads' )
) );
}
/**
* Retrieve the sortable columns
*
* @since 1.4
*
* @return array Array of all the sortable columns
*/
public function get_sortable_columns() {
return apply_filters( 'edd_discounts_table_sortable_columns', array(
'name' => array( 'name', false ),
'code' => array( 'code', false ),
'use_count' => array( 'use_count', false ),
'start_date' => array( 'start_date', false ),
'end_date' => array( 'end_date', false )
) );
}
/**
* Gets the name of the primary column.
*
* @since 2.5
* @access protected
*
* @return string Name of the primary column.
*/
protected function get_primary_column_name() {
return 'name';
}
/**
* This function renders most of the columns in the list table.
*
* @since 1.4
*
* @param EDD_Discount $discount Discount object.
* @param string $column_name The name of the column
*
* @return string Column Name
*/
public function column_default( $discount, $column_name ) {
$value = property_exists( $discount, $column_name ) ? $discount->$column_name : '';
return apply_filters( 'edd_discounts_table_column', $value, $discount, $column_name );
}
/**
* This function renders the amount column.
*
* @since 3.0
*
* @param EDD_Discount $discount Data for the discount code.
* @return string Formatted amount.
*/
public function column_amount( $discount ) {
return edd_format_discount_rate( $discount->type, $discount->amount );
}
/**
* This function renders the start column.
*
* @since 3.0
*
* @param EDD_Discount $discount Discount object.
* @return string Start date
*/
public function column_start_date( $discount ) {
$start_date = $discount->start_date;
$timezone_abbreviation = edd_get_timezone_abbr();
if ( $start_date ) {
$display = edd_date_i18n( $start_date, 'M. d, Y' ) . '<br>' . edd_date_i18n( $start_date, 'H:i' ) . ' ' . $timezone_abbreviation;
} else {
$display = '&mdash;';
}
return $display;
}
/**
* Render the Expiration column.
*
* @since 3.0
*
* @param EDD_Discount $discount Discount object.
* @return string Expiration date.
*/
public function column_end_date( $discount ) {
$expiration = $discount->end_date;
$timezone_abbreviation = edd_get_timezone_abbr();
if ( $expiration ) {
$display = edd_date_i18n( $expiration, 'M. d, Y' ) . '<br>' . edd_date_i18n( $expiration, 'H:i' ) . ' ' . $timezone_abbreviation;
} else {
$display = '&mdash;';
}
return $display;
}
/**
* Render the Name column.
*
* @since 1.4
*
* @param EDD_Discount $discount Discount object.
* @return string Data shown in the Name column
*/
public function column_name( $discount ) {
$base = $this->get_base_url();
$state = '';
$row_actions = array();
$status = $this->get_status();
// Bail if current user cannot manage discounts
if ( ! current_user_can( 'manage_shop_discounts' ) ) {
return;
}
// State
if ( ( ! empty( $status ) && ( $status !== $discount->status ) ) || ( 'active' !== $discount->status ) ) {
$state = ' &mdash; ' . edd_get_discount_status_label( $discount->id );
}
// Edit
$row_actions['edit'] = '<a href="' . esc_url( add_query_arg( array(
'edd-action' => 'edit_discount',
'discount' => absint( $discount->id ),
), $base ) ) . '">' . __( 'Edit', 'easy-digital-downloads' ) . '</a>';
// Active, so add "deactivate" action
if ( 'active' === strtolower( $discount->status ) ) {
$row_actions['cancel'] = '<a href="' . esc_url( wp_nonce_url( add_query_arg( array(
'edd-action' => 'deactivate_discount',
'discount' => absint( $discount->id ),
), $base ), 'edd_discount_nonce' ) ) . '">' . __( 'Deactivate', 'easy-digital-downloads' ) . '</a>';
// Inactive, so add "activate" action
} elseif ( 'inactive' === strtolower( $discount->status ) ) {
$row_actions['activate'] = '<a href="' . esc_url( wp_nonce_url( add_query_arg( array(
'edd-action' => 'activate_discount',
'discount' => absint( $discount->id ),
), $base ), 'edd_discount_nonce' ) ) . '">' . __( 'Activate', 'easy-digital-downloads' ) . '</a>';
}
// Delete
if ( 0 === (int) $discount->use_count ) {
$row_actions['delete'] = '<a href="' . esc_url( wp_nonce_url( add_query_arg( array(
'edd-action' => 'delete_discount',
'discount' => absint( $discount->id ),
), $base ), 'edd_discount_nonce' ) ) . '">' . __( 'Delete', 'easy-digital-downloads' ) . '</a>';
} else {
$row_actions['orders'] = '<a href="' . esc_url(
edd_get_admin_url(
array(
'page' => 'edd-payment-history',
'discount_id' => absint( $discount->id ),
)
)
) . '">' . __( 'View Orders', 'easy-digital-downloads' ) . '</a>';
}
// Filter all discount row actions
$row_actions = apply_filters( 'edd_discount_row_actions', $row_actions, $discount );
// Wrap discount title in strong anchor
$discount_title = '<strong><a class="row-title" href="' . esc_url( add_query_arg( array(
'edd-action' => 'edit_discount',
'discount' => absint( $discount->id ),
), $base ) ) . '">' . stripslashes( $discount->name ) . '</a>' . esc_html( $state ) . '</strong>';
/**
* Filter to allow additional content to be appended to the discount title.
*
* @since 3.0
*
* @param EDD_Discount $discount Discount object.
* @param string $base The base URL for the discount list table.
* @param string $status The queried discount status.
* @return string Additional data shown in the Name column
*/
$additional_content = apply_filters( 'edd_discount_row_after_title', '', $discount, $base, $status );
// Return discount title & row actions
return $discount_title . $additional_content . $this->row_actions( $row_actions );
}
/**
* Render the checkbox column.
*
* @since 1.4
*
* @param EDD_Discount $discount Discount object.
* @return string Checkbox HTML.
*/
public function column_cb( $discount ) {
return sprintf(
'<input type="checkbox" name="%1$s[]" id="%1$s-%2$s" value="%2$s" /><label for="%1$s-%2$s" class="screen-reader-text">%3$s</label>',
/*$1%s*/ 'discount',
/*$2%s*/ absint( $discount->id ),
/* translators: discount name */
esc_html( sprintf( __( 'Select %s', 'easy-digital-downloads' ), $discount->name ) )
);
}
/**
* Return discount code wrapped in a `<code>` tag.
*
* @since 3.0
*
* @param EDD_Discount $discount Discount object.
* @return string Discount code HTML.
*/
public function column_code( $discount ) {
return '<code class="edd-discount-code">' . $discount->code . '</code>';
}
/**
* Message to be displayed when there are no items.
*
* @since 1.7.2
*/
public function no_items() {
esc_html_e( 'No discounts found.', 'easy-digital-downloads' );
}
/**
* Retrieve the bulk actions
*
* @since 1.4
* @return array $actions Array of the bulk actions
*/
public function get_bulk_actions() {
return array(
'activate' => __( 'Activate', 'easy-digital-downloads' ),
'deactivate' => __( 'Deactivate', 'easy-digital-downloads' ),
'delete' => __( 'Delete', 'easy-digital-downloads' )
);
}
/**
* Process bulk actions.
*
* @since 1.4
*/
public function process_bulk_action() {
// Bail if a nonce was not supplied.
if ( ! isset( $_REQUEST['_wpnonce'] ) ) {
return;
}
if ( ! wp_verify_nonce( $_REQUEST['_wpnonce'], 'bulk-discounts' ) ) {
return;
}
check_admin_referer( 'bulk-discounts' );
$ids = wp_parse_id_list( (array) $this->get_request_var( 'discount', false ) );
// Bail if no IDs
if ( empty( $ids ) ) {
return;
}
foreach ( $ids as $id ) {
switch ( $this->current_action() ) {
case 'delete':
edd_delete_discount( $id );
break;
case 'cancel':
edd_update_discount_status( $id, 'cancelled' );
break;
case 'activate':
edd_update_discount_status( $id, 'active' );
break;
case 'deactivate':
edd_update_discount_status( $id, 'inactive' );
break;
}
}
}
/**
* Retrieve the discount code counts.
*
* @since 1.4
*/
public function get_counts() {
$this->counts = edd_get_discount_counts();
}
/**
* Retrieves all the data for all the discount codes.
*
* @since 1.4
* @deprecated 3.0 Use get_data()
*
* @return array Discount codes.
*/
public function discount_codes_data() {
_edd_deprecated_function( __METHOD__, '3.0', 'EDD_Discount_Codes_Table::get_data()' );
return $this->get_data();
}
/**
* Retrieves all of the table data for the discount codes.
*
* @since 3.0
*
* @return array Discount codes table data.
*/
public function get_data() {
// Parse pagination
$this->args = $this->parse_pagination_args( array(
'status' => $this->get_status(),
'search' => $this->get_search(),
) );
// Return data
return edd_get_discounts( $this->args );
}
/**
* Setup the final data for the table
*
* @since 1.4
*/
public function prepare_items() {
$columns = $this->get_columns();
$hidden = array();
$sortable = $this->get_sortable_columns();
$this->_column_headers = array( $columns, $hidden, $sortable );
$this->items = $this->get_data();
$status = $this->get_status( 'total' );
// Setup pagination
$this->set_pagination_args( array(
'total_pages' => ceil( $this->counts[ $status ] / $this->per_page ),
'total_items' => $this->counts[ $status ],
'per_page' => $this->per_page,
) );
}
/**
* Generate the table navigation above or below the table.
* We're overriding this to turn off the referer param in `wp_nonce_field()`.
*
* @param string $which
* @since 3.1.0.4
*/
protected function display_tablenav( $which ) {
if ( 'top' === $which ) {
wp_nonce_field( 'bulk-' . $this->_args['plural'], '_wpnonce', false );
}
?>
<div class="tablenav <?php echo esc_attr( $which ); ?>">
<?php if ( $this->has_items() ) : ?>
<div class="alignleft actions bulkactions">
<?php $this->bulk_actions( $which ); ?>
</div>
<?php
endif;
$this->extra_tablenav( $which );
$this->pagination( $which );
?>
<br class="clear"/>
</div>
<?php
}
}