__('Line Item', 'wp-multisite-waas'), // singular name of the listed records
'plural' => __('Line Items', 'wp-multisite-waas'), // plural name of the listed records
'ajax' => true, // does this table support ajax?
]
);
}
/**
* Get the payment object.
*
* @since 2.0.0
* @return \WP_Ultimo\Models\Payment
*/
public function get_payment() {
$payment_id = wu_request('id');
return wu_get_payment($payment_id);
}
/**
* Overrides the parent get_items to add a total line.
*
* @since 2.0.0
*
* @param integer $per_page Items per page. This gets overridden as well.
* @param integer $page_number The page number.
* @param boolean $count Return as count or not.
* @return array
*/
public function get_items($per_page = 5, $page_number = 1, $count = false) {
$payment = $this->get_payment();
$items = $payment->get_line_items();
if ($count) {
return count($items);
}
return $items;
}
/**
* Displays the name of the product and description being hired.
*
* @since 2.0.0
*
* @param \WP_Ultimo\Checkout\Line_Item $item Payment object.
* @return string
*/
public function column_service($item) {
if ( ! $item) {
return '--';
}
$url_atts = [
'id' => $this->get_payment()->get_id(),
'line_item_id' => $item->get_id(),
];
$actions = [
'edit' => sprintf('%s', __('Edit Item', 'wp-multisite-waas'), wu_get_form_url('edit_line_item', $url_atts), __('Edit', 'wp-multisite-waas')),
'delete' => sprintf('%s', __('Delete Item', 'wp-multisite-waas'), wu_get_form_url('delete_line_item', $url_atts), __('Delete', 'wp-multisite-waas')),
];
$html = sprintf('%s', $item->get_title());
$html .= sprintf('%s', $item->get_description());
return $html . $this->row_actions($actions);
}
/**
* Displays the tax rate for the item.
*
* @since 2.0.0
*
* @param \WP_Ultimo\Models\Payment $item Payment object.
* @return string
*/
public function column_unit_price($item) {
$html = wu_format_currency($item->get_unit_price());
$quantity = sprintf(__('Quantity: %s', 'wp-multisite-waas'), $item->get_quantity()); // phpcs:ignore
return $html . sprintf('%s', $quantity);
}
/**
* Displays the tax rate for the item.
*
* @since 2.0.0
*
* @param \WP_Ultimo\Models\Payment $item Payment object.
* @return string
*/
public function column_tax_total($item) {
$html = wu_format_currency($item->get_tax_total());
$tax_rate = '';
if ($item->get_tax_type() === 'percentage' && $item->get_tax_rate()) {
$tax_rate = $item->get_tax_rate() . '%';
}
$tax_label = $item->get_tax_rate() ? ($item->get_tax_label() ?: __('Tax Applied', 'wp-multisite-waas')) : __('No Taxes Applied', 'wp-multisite-waas');
return $html . sprintf('%s (%s)', $tax_rate, $tax_label);
}
/**
* Displays the tax rate for the item.
*
* @since 2.0.0
*
* @param \WP_Ultimo\Models\Payment $item Payment object.
* @return string
*/
public function column_discounts_total($item) {
$html = wu_format_currency($item->get_discount_total());
$tax_rate = '';
if ($item->get_discount_type() === 'percentage' && $item->get_discount_rate()) {
$tax_rate = $item->get_discount_rate() . '%';
}
$tax_label = $item->get_discount_rate() ? ($item->get_discount_label() ?: __('Discount', 'wp-multisite-waas')) : __('No discount', 'wp-multisite-waas');
return $html . sprintf('%s (%s)', $tax_rate, $tax_label);
}
/**
* Displays the total column.
*
* @since 2.0.0
*
* @param \WP_Ultimo\Models\Payment $item Payment object.
* @return string
*/
public function column_total($item) {
return wu_format_currency($item->get_total());
}
/**
* Displays the subtotal column.
*
* @since 2.0.0
*
* @param \WP_Ultimo\Models\Payment $item Payment object.
* @return string
*/
public function column_subtotal($item) {
return wu_format_currency($item->get_subtotal());
}
/**
* Returns the list of columns for this particular List Table.
*
* @since 2.0.0
* @return array
*/
public function get_columns() {
$columns = [
'service' => __('Service', 'wp-multisite-waas'),
'unit_price' => __('Unit Price', 'wp-multisite-waas'),
'discounts_total' => __('discounts', 'wp-multisite-waas'),
'subtotal' => __('Subtotal', 'wp-multisite-waas'),
'tax_total' => __('Taxes', 'wp-multisite-waas'),
'total' => __('Total', 'wp-multisite-waas'),
];
return $columns;
}
/**
* Leaves no sortable items on the columns.
*
* @since 2.0.0
* @return array
*/
public function get_sortable_columns() {
return [];
}
}