Refactor block registering
[MAILPOET-1798]
This commit is contained in:
committed by
Jack Kitterhing
parent
f4b9836332
commit
fd2c13a2e3
@ -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';
|
||||
|
@ -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
|
||||
|
66
lib/PostEditorBlocks/PostEditorBlock.php
Normal file
66
lib/PostEditorBlocks/PostEditorBlock.php
Normal 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();
|
||||
}
|
||||
}
|
@ -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',
|
||||
]);
|
||||
}
|
||||
|
||||
}
|
Reference in New Issue
Block a user