Add NewsletterEditor page class
[MAILPOET-2200]
This commit is contained in:
committed by
M. Shull
parent
28f5c18b06
commit
c11b2313af
58
lib/AdminPages/Pages/NewsletterEditor.php
Normal file
58
lib/AdminPages/Pages/NewsletterEditor.php
Normal file
@ -0,0 +1,58 @@
|
||||
<?php
|
||||
|
||||
namespace MailPoet\AdminPages\Pages;
|
||||
|
||||
use MailPoet\AdminPages\PageRenderer;
|
||||
use MailPoet\Config\Menu;
|
||||
use MailPoet\Models\Subscriber;
|
||||
use MailPoet\Newsletter\Shortcodes\ShortcodesHelper;
|
||||
use MailPoet\Services\Bridge;
|
||||
use MailPoet\Settings\SettingsController;
|
||||
use MailPoet\Settings\UserFlagsController;
|
||||
use MailPoet\WP\Functions as WPFunctions;
|
||||
|
||||
if (!defined('ABSPATH')) exit;
|
||||
|
||||
class NewsletterEditor {
|
||||
/** @var PageRenderer */
|
||||
private $page_renderer;
|
||||
|
||||
/** @var SettingsController */
|
||||
private $settings;
|
||||
|
||||
/** @var UserFlagsController */
|
||||
private $user_flags;
|
||||
|
||||
/** @var WPFunctions */
|
||||
private $wp;
|
||||
|
||||
function __construct(
|
||||
PageRenderer $page_renderer,
|
||||
SettingsController $settings,
|
||||
UserFlagsController $user_flags,
|
||||
WPFunctions $wp
|
||||
) {
|
||||
$this->page_renderer = $page_renderer;
|
||||
$this->settings = $settings;
|
||||
$this->user_flags = $user_flags;
|
||||
$this->wp = $wp;
|
||||
}
|
||||
|
||||
function render() {
|
||||
$subscriber = Subscriber::getCurrentWPUser();
|
||||
$subscriber_data = $subscriber ? $subscriber->asArray() : [];
|
||||
$data = [
|
||||
'shortcodes' => ShortcodesHelper::getShortcodes(),
|
||||
'settings' => $this->settings->getAll(),
|
||||
'editor_tutorial_seen' => $this->user_flags->get('editor_tutorial_seen'),
|
||||
'current_wp_user' => array_merge($subscriber_data, $this->wp->wpGetCurrentUser()->to_array()),
|
||||
'sub_menu' => Menu::MAIN_PAGE_SLUG,
|
||||
'mss_active' => Bridge::isMPSendingServiceEnabled(),
|
||||
];
|
||||
$this->wp->wpEnqueueMedia();
|
||||
$this->wp->wpEnqueueScript('tinymce-wplink', $this->wp->includesUrl('js/tinymce/plugins/wplink/plugin.js'));
|
||||
$this->wp->wpEnqueueStyle('editor', $this->wp->includesUrl('css/editor.css'));
|
||||
|
||||
$this->page_renderer->displayPage('newsletter/editor.html', $data);
|
||||
}
|
||||
}
|
@ -5,6 +5,7 @@ namespace MailPoet\Config;
|
||||
use Carbon\Carbon;
|
||||
use MailPoet\AdminPages\PageRenderer;
|
||||
use MailPoet\AdminPages\Pages\Help;
|
||||
use MailPoet\AdminPages\Pages\NewsletterEditor;
|
||||
use MailPoet\AdminPages\Pages\Newsletters;
|
||||
use MailPoet\AdminPages\Pages\Settings;
|
||||
use MailPoet\AdminPages\Pages\WelcomeWizard;
|
||||
@ -18,11 +19,9 @@ use MailPoet\Models\Form;
|
||||
use MailPoet\Models\ModelValidator;
|
||||
use MailPoet\Models\Segment;
|
||||
use MailPoet\Models\Subscriber;
|
||||
use MailPoet\Newsletter\Shortcodes\ShortcodesHelper;
|
||||
use MailPoet\Services\Bridge;
|
||||
use MailPoet\Settings\Pages;
|
||||
use MailPoet\Settings\SettingsController;
|
||||
use MailPoet\Settings\UserFlagsController;
|
||||
use MailPoet\Subscribers\ImportExport\ImportExportFactory;
|
||||
use MailPoet\Util\Installation;
|
||||
use MailPoet\Util\License\Features\Subscribers as SubscribersFeature;
|
||||
@ -35,8 +34,6 @@ if (!defined('ABSPATH')) exit;
|
||||
class Menu {
|
||||
const MAIN_PAGE_SLUG = 'mailpoet-newsletters';
|
||||
|
||||
/** @var Renderer */
|
||||
public $renderer;
|
||||
public $mp_api_key_valid;
|
||||
public $premium_key_valid;
|
||||
|
||||
@ -48,8 +45,6 @@ class Menu {
|
||||
/** @var FeaturesController */
|
||||
private $features_controller;
|
||||
|
||||
/** @var UserFlagsController */
|
||||
private $user_flags;
|
||||
/** @var WPFunctions */
|
||||
private $wp;
|
||||
/** @var ServicesChecker */
|
||||
@ -75,7 +70,6 @@ class Menu {
|
||||
FeaturesController $featuresController,
|
||||
WPFunctions $wp,
|
||||
ServicesChecker $servicesChecker,
|
||||
UserFlagsController $user_flags,
|
||||
PageRenderer $page_renderer,
|
||||
Listing\PageLimit $listing_page_limit,
|
||||
Installation $installation,
|
||||
@ -86,7 +80,6 @@ class Menu {
|
||||
$this->settings = $settings;
|
||||
$this->features_controller = $featuresController;
|
||||
$this->servicesChecker = $servicesChecker;
|
||||
$this->user_flags = $user_flags;
|
||||
$this->page_renderer = $page_renderer;
|
||||
$this->listing_page_limit = $listing_page_limit;
|
||||
$this->installation = $installation;
|
||||
@ -584,21 +577,7 @@ class Menu {
|
||||
}
|
||||
|
||||
function newletterEditor() {
|
||||
$subscriber = Subscriber::getCurrentWPUser();
|
||||
$subscriber_data = $subscriber ? $subscriber->asArray() : [];
|
||||
$data = [
|
||||
'shortcodes' => ShortcodesHelper::getShortcodes(),
|
||||
'settings' => $this->settings->getAll(),
|
||||
'editor_tutorial_seen' => $this->user_flags->get('editor_tutorial_seen'),
|
||||
'current_wp_user' => array_merge($subscriber_data, $this->wp->wpGetCurrentUser()->to_array()),
|
||||
'sub_menu' => self::MAIN_PAGE_SLUG,
|
||||
'mss_active' => Bridge::isMPSendingServiceEnabled(),
|
||||
];
|
||||
$this->wp->wpEnqueueMedia();
|
||||
$this->wp->wpEnqueueScript('tinymce-wplink', $this->wp->includesUrl('js/tinymce/plugins/wplink/plugin.js'));
|
||||
$this->wp->wpEnqueueStyle('editor', $this->wp->includesUrl('css/editor.css'));
|
||||
|
||||
$this->page_renderer->displayPage('newsletter/editor.html', $data);
|
||||
$this->container->get(NewsletterEditor::class)->render();
|
||||
}
|
||||
|
||||
function import() {
|
||||
|
@ -31,6 +31,7 @@ class ContainerConfigurator implements IContainerConfigurator {
|
||||
// AdminPages
|
||||
$container->autowire(\MailPoet\AdminPages\PageRenderer::class);
|
||||
$container->autowire(\MailPoet\AdminPages\Pages\Help::class);
|
||||
$container->autowire(\MailPoet\AdminPages\Pages\NewsletterEditor::class);
|
||||
$container->autowire(\MailPoet\AdminPages\Pages\Newsletters::class);
|
||||
$container->autowire(\MailPoet\AdminPages\Pages\Settings::class);
|
||||
$container->autowire(\MailPoet\AdminPages\Pages\WelcomeWizard::class);
|
||||
|
@ -11,7 +11,6 @@ use MailPoet\DI\ContainerWrapper;
|
||||
use MailPoet\Features\FeaturesController;
|
||||
use MailPoet\Listing\PageLimit;
|
||||
use MailPoet\Settings\SettingsController;
|
||||
use MailPoet\Settings\UserFlagsController;
|
||||
use MailPoet\Util\Installation;
|
||||
use MailPoet\WP\Functions as WPFunctions;
|
||||
|
||||
@ -98,7 +97,6 @@ class MenuTest extends \MailPoetTest {
|
||||
new FeaturesController(),
|
||||
$wp,
|
||||
new ServicesChecker,
|
||||
new UserFlagsController,
|
||||
$renderer,
|
||||
new PageLimit($wp),
|
||||
new Installation($settings, $wp),
|
||||
|
Reference in New Issue
Block a user