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\AutomaticEmails\AutomaticEmails;
use MailPoet\Cron\CronTrigger;
use MailPoet\PostEditorBlocks\PostEditorBlock;
use MailPoet\Router;
use MailPoet\Settings\SettingsController;
use MailPoet\Util\ConflictResolver;
@ -68,7 +69,7 @@ class Initializer {
/** @var WooCommerceHelper */
private $wcHelper;
/** @var PostEditorBlock */
/** @var \MailPoet\PostEditorBlocks\PostEditorBlock */
private $postEditorBlock;
const INITIALIZED = 'MAILPOET_INITIALIZED';

View File

@ -101,7 +101,6 @@ class ContainerConfigurator implements IContainerConfigurator {
$container->autowire(\MailPoet\Config\MP2Migrator::class);
$container->autowire(\MailPoet\Config\RendererFactory::class)->setPublic(true);
$container->autowire(\MailPoet\Config\ServicesChecker::class);
$container->autowire(\MailPoet\Config\PostEditorBlock::class);
$container->autowire(\MailPoet\Config\Shortcodes::class)
->setShared(false); // Get a new instance each time $container->get() is called, needed for tests
$container->register(\MailPoet\Config\Renderer::class)
@ -125,6 +124,8 @@ class ContainerConfigurator implements IContainerConfigurator {
$container->autowire(\MailPoet\Doctrine\Validator\ValidatorFactory::class);
$container->autowire(\MailPoetVendor\Symfony\Component\Validator\Validator\ValidatorInterface::class)
->setFactory([new Reference(\MailPoet\Doctrine\Validator\ValidatorFactory::class), 'createValidator']);
$container->autowire(\MailPoet\PostEditorBlocks\PostEditorBlock::class);
$container->autowire(\MailPoet\PostEditorBlocks\SubscriptionFormBlock::class);
// Dynamic segments
$container->autowire(\MailPoet\DynamicSegments\DynamicSegmentHooks::class);
// 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
namespace MailPoet\Config;
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 {
class SubscriptionFormBlock {
/** @var Renderer */
private $renderer;
@ -28,16 +30,7 @@ class PostEditorBlock {
}
public function init() {
// this has to be here until we drop support for WordPress < 5.0
if (!function_exists('register_block_type')) return;
if (is_admin()) {
$this->initAdmin();
} else {
$this->initFrontend();
}
$this->wp->registerBlockType('mailpoet/form-block-render', [
$this->wp->registerBlockType('mailpoet/subscription-form-block-render', [
'attributes' => [
'form' => [
'type' => 'number',
@ -48,25 +41,10 @@ class PostEditorBlock {
]);
}
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->wp->registerBlockType('mailpoet/form-block', [
public function initAdmin() {
$this->wp->registerBlockType('mailpoet/subscription-form-block', [
'style' => 'mailpoetblock-form-block-css',
'editor_script' => 'mailpoet/form-block',
'editor_script' => 'mailpoet/subscription-form-block',
]);
$this->wp->addAction('admin_head', function() {
@ -86,21 +64,20 @@ class PostEditorBlock {
});
}
private function initFrontend() {
$this->wp->registerBlockType('mailpoet/form-block', [
public function initFrontend() {
$this->wp->registerBlockType('mailpoet/subscription-form-block', [
'render_callback' => [$this, 'renderForm'],
]);
}
public function renderForm(array $attributes = []): string {
if (!$attributes || !isset($attributes['form'])) {
if (!$attributes || !isset($attributes['formId'])) {
return '';
}
$basicForm = new Widget();
return $basicForm->widget([
'form' => (int)$attributes['form'],
'form' => (int)$attributes['formId'],
'form_type' => 'html',
]);
}
}