Refactor block registering

[MAILPOET-1798]
This commit is contained in:
Pavel Dohnal
2020-02-06 14:05:23 +01:00
committed by Jack Kitterhing
parent f4b9836332
commit fd2c13a2e3
4 changed files with 82 additions and 37 deletions

View File

@ -5,6 +5,7 @@ namespace MailPoet\Config;
use MailPoet\API\JSON\API; use MailPoet\API\JSON\API;
use MailPoet\AutomaticEmails\AutomaticEmails; use MailPoet\AutomaticEmails\AutomaticEmails;
use MailPoet\Cron\CronTrigger; use MailPoet\Cron\CronTrigger;
use MailPoet\PostEditorBlocks\PostEditorBlock;
use MailPoet\Router; use MailPoet\Router;
use MailPoet\Settings\SettingsController; use MailPoet\Settings\SettingsController;
use MailPoet\Util\ConflictResolver; use MailPoet\Util\ConflictResolver;
@ -68,7 +69,7 @@ class Initializer {
/** @var WooCommerceHelper */ /** @var WooCommerceHelper */
private $wcHelper; private $wcHelper;
/** @var PostEditorBlock */ /** @var \MailPoet\PostEditorBlocks\PostEditorBlock */
private $postEditorBlock; private $postEditorBlock;
const INITIALIZED = 'MAILPOET_INITIALIZED'; const INITIALIZED = 'MAILPOET_INITIALIZED';

View File

@ -101,7 +101,6 @@ class ContainerConfigurator implements IContainerConfigurator {
$container->autowire(\MailPoet\Config\MP2Migrator::class); $container->autowire(\MailPoet\Config\MP2Migrator::class);
$container->autowire(\MailPoet\Config\RendererFactory::class)->setPublic(true); $container->autowire(\MailPoet\Config\RendererFactory::class)->setPublic(true);
$container->autowire(\MailPoet\Config\ServicesChecker::class); $container->autowire(\MailPoet\Config\ServicesChecker::class);
$container->autowire(\MailPoet\Config\PostEditorBlock::class);
$container->autowire(\MailPoet\Config\Shortcodes::class) $container->autowire(\MailPoet\Config\Shortcodes::class)
->setShared(false); // Get a new instance each time $container->get() is called, needed for tests ->setShared(false); // Get a new instance each time $container->get() is called, needed for tests
$container->register(\MailPoet\Config\Renderer::class) $container->register(\MailPoet\Config\Renderer::class)
@ -125,6 +124,8 @@ class ContainerConfigurator implements IContainerConfigurator {
$container->autowire(\MailPoet\Doctrine\Validator\ValidatorFactory::class); $container->autowire(\MailPoet\Doctrine\Validator\ValidatorFactory::class);
$container->autowire(\MailPoetVendor\Symfony\Component\Validator\Validator\ValidatorInterface::class) $container->autowire(\MailPoetVendor\Symfony\Component\Validator\Validator\ValidatorInterface::class)
->setFactory([new Reference(\MailPoet\Doctrine\Validator\ValidatorFactory::class), 'createValidator']); ->setFactory([new Reference(\MailPoet\Doctrine\Validator\ValidatorFactory::class), 'createValidator']);
$container->autowire(\MailPoet\PostEditorBlocks\PostEditorBlock::class);
$container->autowire(\MailPoet\PostEditorBlocks\SubscriptionFormBlock::class);
// Dynamic segments // Dynamic segments
$container->autowire(\MailPoet\DynamicSegments\DynamicSegmentHooks::class); $container->autowire(\MailPoet\DynamicSegments\DynamicSegmentHooks::class);
// Cron // Cron

View File

@ -0,0 +1,66 @@
<?php
namespace MailPoet\PostEditorBlocks;
use MailPoet\Config\Env;
use MailPoet\Config\Renderer;
use MailPoet\Entities\FormEntity;
use MailPoet\Form\FormsRepository;
use MailPoet\Form\Widget;
use MailPoet\WP\Functions as WPFunctions;
class PostEditorBlock {
/** @var Renderer */
private $renderer;
/** @var WPFunctions */
private $wp;
/** @var SubscriptionFormBlock */
private $subscriptionFormBlock;
public function __construct(
Renderer $renderer,
WPFunctions $wp,
SubscriptionFormBlock $subscriptionFormBlock
) {
$this->renderer = $renderer;
$this->wp = $wp;
$this->subscriptionFormBlock = $subscriptionFormBlock;
}
public function init() {
// this has to be here until we drop support for WordPress < 5.0
if (!function_exists('register_block_type')) return;
$this->subscriptionFormBlock->init();
if (is_admin()) {
$this->initAdmin();
} else {
$this->initFrontend();
}
}
private function initAdmin() {
$this->wp->wpEnqueueScript(
'mailpoet-block-form-block-js',
Env::$assetsUrl . '/dist/js/' . $this->renderer->getJsAsset('post_editor_block.js'),
['wp-blocks', 'wp-components', 'wp-server-side-render', 'wp-block-editor'],
Env::$version,
true
);
$this->wp->wpEnqueueStyle(
'mailpoetblock-form-block-css',
Env::$assetsUrl . '/dist/css/' . $this->renderer->getCssAsset('post-editor-block.css'),
['wp-edit-blocks'],
Env::$version
);
$this->subscriptionFormBlock->initAdmin();
}
private function initFrontend() {
$this->subscriptionFormBlock->initFrontend();
}
}

View File

@ -1,13 +1,15 @@
<?php <?php
namespace MailPoet\Config; namespace MailPoet\PostEditorBlocks;
use MailPoet\Config\Env;
use MailPoet\Config\Renderer;
use MailPoet\Entities\FormEntity; use MailPoet\Entities\FormEntity;
use MailPoet\Form\FormsRepository; use MailPoet\Form\FormsRepository;
use MailPoet\Form\Widget; use MailPoet\Form\Widget;
use MailPoet\WP\Functions as WPFunctions; use MailPoet\WP\Functions as WPFunctions;
class PostEditorBlock { class SubscriptionFormBlock {
/** @var Renderer */ /** @var Renderer */
private $renderer; private $renderer;
@ -28,16 +30,7 @@ class PostEditorBlock {
} }
public function init() { public function init() {
// this has to be here until we drop support for WordPress < 5.0 $this->wp->registerBlockType('mailpoet/subscription-form-block-render', [
if (!function_exists('register_block_type')) return;
if (is_admin()) {
$this->initAdmin();
} else {
$this->initFrontend();
}
$this->wp->registerBlockType('mailpoet/form-block-render', [
'attributes' => [ 'attributes' => [
'form' => [ 'form' => [
'type' => 'number', 'type' => 'number',
@ -48,25 +41,10 @@ class PostEditorBlock {
]); ]);
} }
private function initAdmin() { public function initAdmin() {
$this->wp->wpEnqueueScript( $this->wp->registerBlockType('mailpoet/subscription-form-block', [
'mailpoet-block-form-block-js',
Env::$assetsUrl . '/dist/js/' . $this->renderer->getJsAsset('post_editor_block.js'),
['wp-blocks', 'wp-components', 'wp-server-side-render', 'wp-block-editor'],
Env::$version,
true
);
$this->wp->wpEnqueueStyle(
'mailpoetblock-form-block-css',
Env::$assetsUrl . '/dist/css/' . $this->renderer->getCssAsset('post-editor-block.css'),
['wp-edit-blocks'],
Env::$version
);
$this->wp->registerBlockType('mailpoet/form-block', [
'style' => 'mailpoetblock-form-block-css', 'style' => 'mailpoetblock-form-block-css',
'editor_script' => 'mailpoet/form-block', 'editor_script' => 'mailpoet/subscription-form-block',
]); ]);
$this->wp->addAction('admin_head', function() { $this->wp->addAction('admin_head', function() {
@ -86,21 +64,20 @@ class PostEditorBlock {
}); });
} }
private function initFrontend() { public function initFrontend() {
$this->wp->registerBlockType('mailpoet/form-block', [ $this->wp->registerBlockType('mailpoet/subscription-form-block', [
'render_callback' => [$this, 'renderForm'], 'render_callback' => [$this, 'renderForm'],
]); ]);
} }
public function renderForm(array $attributes = []): string { public function renderForm(array $attributes = []): string {
if (!$attributes || !isset($attributes['form'])) { if (!$attributes || !isset($attributes['formId'])) {
return ''; return '';
} }
$basicForm = new Widget(); $basicForm = new Widget();
return $basicForm->widget([ return $basicForm->widget([
'form' => (int)$attributes['form'], 'form' => (int)$attributes['formId'],
'form_type' => 'html', 'form_type' => 'html',
]); ]);
} }
} }