Add form preview page form rendering

[MAILPOET-2743]
This commit is contained in:
Rostislav Wolny
2020-04-15 18:29:52 +02:00
committed by Veljko V
parent db618d7948
commit 0b512fe81b
3 changed files with 120 additions and 7 deletions

View File

@ -192,6 +192,7 @@ class ContainerConfigurator implements IContainerConfigurator {
$container->autowire(\MailPoet\Form\Block\Text::class);
$container->autowire(\MailPoet\Form\Block\Textarea::class);
$container->autowire(\MailPoet\Form\FormFactory::class);
$container->autowire(\MailPoet\Form\PreviewPage::class);
$container->autowire(\MailPoet\Form\Util\Styles::class);
// Helpscout
$container->autowire(\MailPoet\Helpscout\Beacon::class);

107
lib/Form/PreviewPage.php Normal file
View File

@ -0,0 +1,107 @@
<?php
namespace MailPoet\Form;
use MailPoet\Config\Renderer as TemplateRenderer;
use MailPoet\WP\Functions as WPFunctions;
class PreviewPage {
/** @var WPFunctions */
private $wp;
/** @var Renderer */
private $formRenderer;
/** @var TemplateRenderer */
private $templateRenderer;
/** @var FormsRepository */
private $formRepository;
/** @var AssetsController */
private $assetsController;
public function __construct(
WPFunctions $wp,
Renderer $formRenderer,
TemplateRenderer $templateRenderer,
FormsRepository $formRepository,
AssetsController $assetsController
) {
$this->wp = $wp;
$this->formRenderer = $formRenderer;
$this->templateRenderer = $templateRenderer;
$this->formRepository = $formRepository;
$this->assetsController = $assetsController;
}
public function renderPage(int $formId, string $formType): string {
$this->assetsController->setupFrontEndDependencies();
$formData = $this->fetchFormData($formId);
if (!is_array($formData)) {
return '';
}
return $this->getPostContent() . $this->getFormContent($formData, $formId, $formType);
}
public function renderTitle() {
return __('Sample page to preview your form', 'mailpoet');
}
/**
* @return array|null
*/
private function fetchFormData(int $id) {
$form = $this->formRepository->findOneById($id);
if ($form) {
return [
'body' => $form->getBody(),
'styles' => $form->getStyles(),
'settings' => $form->getSettings(),
];
}
return null;
}
private function getFormContent(array $formData, int $formId, string $formType): string {
$htmlId = 'mailpoet_form_preview_' . $formId;
$templateData = [
'is_preview' => true,
'form_html_id' => $htmlId,
'form_id' => $formId,
'form_success_message' => $formData['settings']['success_message'] ?? null,
'form_type' => $formType,
'styles' => $this->formRenderer->renderStyles($formData, '#' . $htmlId),
'html' => $this->formRenderer->renderHTML($formData),
'form_element_styles' => $this->formRenderer->renderFormElementStyles($formData),
'success' => true,
'error' => true,
'delay' => 1,
'position' => $formData['settings'][$formType . '_form_position'] ?? '',
'backgroundColor' => $formData['settings']['backgroundColor'] ?? '',
];
$formPosition = $formData['settings'][$formType . '_form_position'] ?? '';
if (!$formPosition && $formType === 'fixed_bar') {
$formPosition = 'top';
}
if (!$formPosition && $formType === 'slide_in') {
$formPosition = 'left';
}
$templateData['position'] = $formPosition;
return $this->templateRenderer->render('form/front_end_form.html', $templateData);
}
private function getPostContent(): string {
$posts = $this->wp->getPosts([
'numberposts' => 1,
'orderby' => 'date',
'order' => 'DESC',
'post_status' => 'publish',
'post_type' => 'post',
]);
if (!isset($posts[0])) {
return '';
}
return $posts[0]->post_content;
}
}

View File

@ -3,6 +3,7 @@
namespace MailPoet\Router\Endpoints;
use MailPoet\Config\AccessControl;
use MailPoet\Form\PreviewPage;
use MailPoet\WP\Functions as WPFunctions;
class FormPreview {
@ -15,31 +16,35 @@ class FormPreview {
/** @var array|null */
private $data;
/** @var PreviewPage */
private $formPreviewPage;
public $allowedActions = [self::ACTION_VIEW];
public $permissions = [
'global' => AccessControl::NO_ACCESS_RESTRICTION,
];
public function __construct(
WPFunctions $wp
WPFunctions $wp,
PreviewPage $formPreviewPage
) {
$this->wp = $wp;
$this->formPreviewPage = $formPreviewPage;
}
public function view(array $data) {
$this->data = $data;
$this->wp->addFilter('the_content', [$this,'renderContent'], 10);
$this->wp->addFilter('the_title', [$this,'renderTitle'], 10);
$this->wp->addFilter('the_title', [$this->formPreviewPage,'renderTitle'], 10);
$this->wp->addFilter('show_admin_bar', function () {
return false;
});
}
public function renderContent(): string {
return '<h1>Todo render form</h1>';
if (!isset($this->data['id']) || !isset($this->data['form_type'])) {
return '';
}
public function renderTitle(): string {
return __('Sample page to preview your form', 'mailpoet');
return $this->formPreviewPage->renderPage((int)$this->data['id'], (string)$this->data['form_type']);
}
}