* Update translation text domain * Escape everything that should be escaped. * Add nonce checks where needed. * Sanitize all inputs. * Apply Code style changes across the codebase. * Correct many deprecation notices. * Optimize load order of many filters. * Add Proper Build script * Use emojii flags * Fix i18n deprecation notice for translating too early * Put all scripts in footer and load async
272 lines
6.3 KiB
PHP
272 lines
6.3 KiB
PHP
<?php
|
|
/**
|
|
* WP Multisite WaaS Dashboard Tax Admin Panel
|
|
*
|
|
* @package WP_Ultimo
|
|
* @subpackage Admin_Pages
|
|
* @since 2.0.0
|
|
*/
|
|
|
|
namespace WP_Ultimo\Tax;
|
|
|
|
// Exit if accessed directly
|
|
defined('ABSPATH') || exit;
|
|
|
|
/**
|
|
* WP Multisite WaaS Dashboard Tax Admin Panel
|
|
*/
|
|
class Dashboard_Taxes_Tab {
|
|
|
|
/**
|
|
* Reference to the main admin page object so we can
|
|
* access its methods on the render functions.
|
|
*
|
|
* @since 2.0.11
|
|
* @var \WP_Ultimo\Admin_Pages\Base_Admin_Page
|
|
*/
|
|
protected $dashboard_page;
|
|
|
|
/**
|
|
* Constructor
|
|
*
|
|
* @since 2.0.0
|
|
*/
|
|
public function __construct() {
|
|
|
|
add_filter('wu_dashboard_filter_bar', [$this, 'add_tab']);
|
|
|
|
add_action('wu_dashboard_taxes_widgets', [$this, 'register_widgets'], 10, 3);
|
|
}
|
|
|
|
/**
|
|
* Checks if tax support is enabled or not.
|
|
*
|
|
* @since 2.0.0
|
|
* @return boolean
|
|
*/
|
|
protected function is_enabled() {
|
|
|
|
return wu_get_setting('enable_taxes');
|
|
}
|
|
|
|
/**
|
|
* Add_tab to dashboard
|
|
*
|
|
* @since 2.0.0
|
|
*
|
|
* @param array $dashboard_filters Dashboard tabs.
|
|
*/
|
|
public function add_tab($dashboard_filters) {
|
|
|
|
$dashboard_filters['taxes'] = [
|
|
'field' => 'type',
|
|
'label' => __('Taxes', 'wp-multisite-waas'),
|
|
'url' => add_query_arg('tab', 'taxes'),
|
|
'count' => 0,
|
|
];
|
|
|
|
return $dashboard_filters;
|
|
}
|
|
|
|
/**
|
|
* Renders the disabled message, if taxes are not enabled.
|
|
*
|
|
* @since 2.0.0
|
|
* @return void
|
|
*/
|
|
public function disabled_message(): void {
|
|
|
|
echo wu_render_empty_state(
|
|
[
|
|
'message' => __('You do not have tax support enabled yet...'),
|
|
'sub_message' => __('If you need to collect taxes, you\'ll be glad to hear that WP Multisite WaaS offers tax support!'),
|
|
'link_label' => __('Enable Tax Support', 'wp-multisite-waas'),
|
|
'link_url' => wu_network_admin_url(
|
|
'wp-ultimo-settings',
|
|
[
|
|
'tab' => 'taxes',
|
|
]
|
|
),
|
|
]
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Adds a back link to the taxes without tax.
|
|
*
|
|
* @since 2.0.0
|
|
*
|
|
* @param array $links The already existent links.
|
|
* @return array
|
|
*/
|
|
public function add_back_link($links) {
|
|
|
|
$back_link = [
|
|
[
|
|
'url' => wu_network_admin_url('wp-ultimo'),
|
|
'label' => __('Go Back', 'wp-multisite-waas'),
|
|
'icon' => 'wu-reply',
|
|
],
|
|
];
|
|
|
|
return array_merge($back_link, $links);
|
|
}
|
|
|
|
/**
|
|
* Register_widgets
|
|
*
|
|
* @since 2.0.0
|
|
*
|
|
* @param string $tab Name of selected tab.
|
|
* @param \WP_Screen $screen The current screen object.
|
|
* @param \WP_Ultimo\Admin_Pages\Dashboard_Admin_Page $dashboard_page Name of selected tab.
|
|
* @return void
|
|
*/
|
|
public function register_widgets($tab, $screen, $dashboard_page): void {
|
|
|
|
/**
|
|
* Set the dashboard page as a property
|
|
* to make the helper methods available on the render
|
|
* functions for the metaboxes.
|
|
*/
|
|
$this->dashboard_page = $dashboard_page;
|
|
|
|
/*
|
|
* Displays an empty page with the option to activate tax support.
|
|
*/
|
|
if ( ! $this->is_enabled()) {
|
|
add_filter('wu_dashboard_display_filter', '__return_false');
|
|
|
|
add_filter('wu_dashboard_display_widgets', '__return_false');
|
|
|
|
add_action('wu_dash_before_metaboxes', [$this, 'disabled_message']);
|
|
|
|
add_filter('wu_page_get_title_links', [$this, 'add_back_link']);
|
|
|
|
return;
|
|
}
|
|
|
|
$this->dashboard_page = $dashboard_page;
|
|
|
|
add_meta_box('wp-ultimo-taxes', __('Taxes', 'wp-multisite-waas'), [$this, 'output_widget_taxes'], $screen->id, 'full', 'high');
|
|
|
|
add_meta_box('wp-ultimo-taxes-by-rate', __('Taxes by Code', 'wp-multisite-waas'), [$this, 'output_widget_taxes_by_rate'], $screen->id, 'normal', 'high');
|
|
|
|
add_meta_box('wp-ultimo-taxes-by-day', __('Taxes by Day', 'wp-multisite-waas'), [$this, 'output_widget_taxes_by_day'], $screen->id, 'side', 'high');
|
|
|
|
$this->register_scripts();
|
|
}
|
|
|
|
/**
|
|
* Registers the necessary scripts to handle the tax graph.
|
|
*
|
|
* @todo: extract the calculations onto their own function.
|
|
* @since 2.0.0
|
|
* @return void
|
|
*/
|
|
public function register_scripts(): void {
|
|
|
|
$payments_per_month = [
|
|
'january' => [],
|
|
'february' => [],
|
|
'march' => [],
|
|
'april' => [],
|
|
'may' => [],
|
|
'june' => [],
|
|
'july' => [],
|
|
'august' => [],
|
|
'september' => [],
|
|
'october' => [],
|
|
'november' => [],
|
|
'december' => [],
|
|
];
|
|
|
|
$data = wu_calculate_taxes_by_month();
|
|
|
|
$index = 1;
|
|
|
|
foreach ($payments_per_month as &$month) {
|
|
$month = $data[ $index ];
|
|
|
|
++$index;
|
|
}
|
|
|
|
$month_list = [];
|
|
|
|
$current_year = date_i18n('Y');
|
|
|
|
for ($i = 1; $i <= 12; $i++) {
|
|
$month_list[] = date_i18n('M y', mktime(0, 0, 0, $i, 1, $current_year));
|
|
}
|
|
|
|
wp_register_script('wu-tax-stats', wu_get_asset('tax-statistics.js', 'js'), ['jquery', 'wu-functions', 'wu-ajax-list-table', 'moment', 'wu-block-ui', 'dashboard', 'wu-apex-charts', 'wu-vue-apex-charts'], wu_get_version(), true);
|
|
|
|
wp_localize_script(
|
|
'wu-tax-stats',
|
|
'wu_tax_statistics_vars',
|
|
[
|
|
'data' => $payments_per_month,
|
|
'start_date' => date_i18n('Y-m-d', strtotime((string) wu_request('start_date', '-1 month'))),
|
|
'end_date' => date_i18n('Y-m-d', strtotime((string) wu_request('end_date', 'tomorrow'))),
|
|
'today' => date_i18n('Y-m-d', strtotime('tomorrow')),
|
|
'month_list' => $month_list,
|
|
'i18n' => [
|
|
'net_profit_label' => __('Net Profit', 'wp-multisite-waas'),
|
|
'taxes_label' => __('Taxes Collected', 'wp-multisite-waas'),
|
|
],
|
|
]
|
|
);
|
|
|
|
wp_enqueue_script('wu-tax-stats');
|
|
}
|
|
|
|
/**
|
|
* Renders the tax graph.
|
|
*
|
|
* @since 2.0.0
|
|
* @return void
|
|
*/
|
|
public function output_widget_taxes(): void {
|
|
|
|
wu_get_template('dashboard-statistics/widget-tax-graph');
|
|
}
|
|
|
|
/**
|
|
* Renders the taxes by rate widget.
|
|
*
|
|
* @since 2.0.0
|
|
* @return void
|
|
*/
|
|
public function output_widget_taxes_by_rate(): void {
|
|
|
|
$taxes_by_rate = wu_calculate_taxes_by_rate($this->dashboard_page->start_date, $this->dashboard_page->end_date);
|
|
|
|
wu_get_template(
|
|
'dashboard-statistics/widget-tax-by-code',
|
|
[
|
|
'taxes_by_rate' => $taxes_by_rate,
|
|
'page' => $this->dashboard_page,
|
|
]
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Renders the taxes by date widget.
|
|
*
|
|
* @since 2.0.0
|
|
* @return void
|
|
*/
|
|
public function output_widget_taxes_by_day(): void {
|
|
|
|
$taxes_by_day = wu_calculate_taxes_by_day($this->dashboard_page->start_date, $this->dashboard_page->end_date);
|
|
|
|
wu_get_template(
|
|
'dashboard-statistics/widget-tax-by-day',
|
|
[
|
|
'taxes_by_day' => $taxes_by_day,
|
|
'page' => $this->dashboard_page,
|
|
]
|
|
);
|
|
}
|
|
}
|