Add RevenueTrackingPermission page class

[MAILPOET-2200]
This commit is contained in:
Rostislav Wolny
2019-07-15 16:29:12 +02:00
committed by M. Shull
parent e93d1e1774
commit 73f39be4df
4 changed files with 45 additions and 16 deletions

View File

@@ -0,0 +1,42 @@
<?php
namespace MailPoet\AdminPages\Pages;
use MailPoet\AdminPages\PageRenderer;
use MailPoet\Config\Menu;
use MailPoet\Features\FeaturesController;
use MailPoet\WP\Functions as WPFunctions;
if (!defined('ABSPATH')) exit;
class RevenueTrackingPermission {
/** @var PageRenderer */
private $page_renderer;
/** @var WPFunctions */
private $wp;
/** @var FeaturesController */
private $features_controller;
function __construct(
PageRenderer $page_renderer,
WPFunctions $wp,
FeaturesController $features_controller
) {
$this->page_renderer = $page_renderer;
$this->wp = $wp;
$this->features_controller = $features_controller;
}
function render() {
if (!$this->features_controller->isSupported(FeaturesController::FEATURE_DISPLAY_WOOCOMMERCE_REVENUES)) {
return;
}
if ((bool)(defined('DOING_AJAX') && DOING_AJAX)) return;
$data = [
'finish_wizard_url' => $this->wp->adminUrl('admin.php?page=' . Menu::MAIN_PAGE_SLUG),
];
$this->page_renderer->displayPage('revenue_tracking_permission.html', $data);
}
}

View File

@@ -8,11 +8,11 @@ use MailPoet\AdminPages\Pages\Help;
use MailPoet\AdminPages\Pages\MP2Migration; use MailPoet\AdminPages\Pages\MP2Migration;
use MailPoet\AdminPages\Pages\NewsletterEditor; use MailPoet\AdminPages\Pages\NewsletterEditor;
use MailPoet\AdminPages\Pages\Newsletters; use MailPoet\AdminPages\Pages\Newsletters;
use MailPoet\AdminPages\Pages\RevenueTrackingPermission;
use MailPoet\AdminPages\Pages\Settings; use MailPoet\AdminPages\Pages\Settings;
use MailPoet\AdminPages\Pages\WelcomeWizard; use MailPoet\AdminPages\Pages\WelcomeWizard;
use MailPoet\AdminPages\Pages\WooCommerceListImport; use MailPoet\AdminPages\Pages\WooCommerceListImport;
use MailPoet\DI\ContainerWrapper; use MailPoet\DI\ContainerWrapper;
use MailPoet\Features\FeaturesController;
use MailPoet\Form\Block; use MailPoet\Form\Block;
use MailPoet\Form\Renderer as FormRenderer; use MailPoet\Form\Renderer as FormRenderer;
use MailPoet\Listing; use MailPoet\Listing;
@@ -44,9 +44,6 @@ class Menu {
/** @var SettingsController */ /** @var SettingsController */
private $settings; private $settings;
/** @var FeaturesController */
private $features_controller;
/** @var WPFunctions */ /** @var WPFunctions */
private $wp; private $wp;
/** @var ServicesChecker */ /** @var ServicesChecker */
@@ -69,7 +66,6 @@ class Menu {
function __construct( function __construct(
AccessControl $access_control, AccessControl $access_control,
SettingsController $settings, SettingsController $settings,
FeaturesController $featuresController,
WPFunctions $wp, WPFunctions $wp,
ServicesChecker $servicesChecker, ServicesChecker $servicesChecker,
PageRenderer $page_renderer, PageRenderer $page_renderer,
@@ -80,7 +76,6 @@ class Menu {
$this->access_control = $access_control; $this->access_control = $access_control;
$this->wp = $wp; $this->wp = $wp;
$this->settings = $settings; $this->settings = $settings;
$this->features_controller = $featuresController;
$this->servicesChecker = $servicesChecker; $this->servicesChecker = $servicesChecker;
$this->page_renderer = $page_renderer; $this->page_renderer = $page_renderer;
$this->listing_page_limit = $listing_page_limit; $this->listing_page_limit = $listing_page_limit;
@@ -431,14 +426,7 @@ class Menu {
} }
function revenueTrackingPermission() { function revenueTrackingPermission() {
if (!$this->features_controller->isSupported(FeaturesController::FEATURE_DISPLAY_WOOCOMMERCE_REVENUES)) { $this->container->get(RevenueTrackingPermission::class)->render();
return;
}
if ((bool)(defined('DOING_AJAX') && DOING_AJAX)) return;
$data = [
'finish_wizard_url' => $this->wp->adminUrl('admin.php?page=' . self::MAIN_PAGE_SLUG),
];
$this->page_renderer->displayPage('revenue_tracking_permission.html', $data);
} }
function update() { function update() {

View File

@@ -34,6 +34,7 @@ class ContainerConfigurator implements IContainerConfigurator {
$container->autowire(\MailPoet\AdminPages\Pages\NewsletterEditor::class); $container->autowire(\MailPoet\AdminPages\Pages\NewsletterEditor::class);
$container->autowire(\MailPoet\AdminPages\Pages\Newsletters::class); $container->autowire(\MailPoet\AdminPages\Pages\Newsletters::class);
$container->autowire(\MailPoet\AdminPages\Pages\MP2Migration::class); $container->autowire(\MailPoet\AdminPages\Pages\MP2Migration::class);
$container->autowire(\MailPoet\AdminPages\Pages\RevenueTrackingPermission::class);
$container->autowire(\MailPoet\AdminPages\Pages\Settings::class); $container->autowire(\MailPoet\AdminPages\Pages\Settings::class);
$container->autowire(\MailPoet\AdminPages\Pages\WelcomeWizard::class); $container->autowire(\MailPoet\AdminPages\Pages\WelcomeWizard::class);
$container->autowire(\MailPoet\AdminPages\Pages\WooCommerceListImport::class); $container->autowire(\MailPoet\AdminPages\Pages\WooCommerceListImport::class);

View File

@@ -8,7 +8,6 @@ use MailPoet\Config\AccessControl;
use MailPoet\Config\Menu; use MailPoet\Config\Menu;
use MailPoet\Config\ServicesChecker; use MailPoet\Config\ServicesChecker;
use MailPoet\DI\ContainerWrapper; use MailPoet\DI\ContainerWrapper;
use MailPoet\Features\FeaturesController;
use MailPoet\Listing\PageLimit; use MailPoet\Listing\PageLimit;
use MailPoet\Settings\SettingsController; use MailPoet\Settings\SettingsController;
use MailPoet\Util\Installation; use MailPoet\Util\Installation;
@@ -94,7 +93,6 @@ class MenuTest extends \MailPoetTest {
return new Menu( return new Menu(
new AccessControl(), new AccessControl(),
$settings, $settings,
new FeaturesController(),
$wp, $wp,
new ServicesChecker, new ServicesChecker,
$renderer, $renderer,