Render form input and textarea styles on frontend

[MAILPOET-2599]
This commit is contained in:
Rostislav Wolny
2020-03-05 14:34:34 +01:00
committed by Veljko V
parent b70884ecaa
commit 4e8fda670c
7 changed files with 111 additions and 4 deletions

View File

@ -2,13 +2,19 @@
namespace MailPoet\Form\Block;
use MailPoet\Form\TextInputStylesRenderer;
class Text {
/** @var BlockRendererHelper */
private $rendererHelper;
public function __construct(BlockRendererHelper $rendererHelper) {
/** @var TextInputStylesRenderer */
private $inputStylesRenderer;
public function __construct(BlockRendererHelper $rendererHelper, TextInputStylesRenderer $inputStylesRenderer) {
$this->rendererHelper = $rendererHelper;
$this->inputStylesRenderer = $inputStylesRenderer;
}
public function render(array $block, array $formSettings): string {
@ -17,6 +23,7 @@ class Text {
if ($block['id'] === 'email') {
$type = 'email';
}
$styles = $this->inputStylesRenderer->render($block['styles'] ?? []);
if (in_array($block['id'], ['email', 'last_name', 'first_name'], true)) {
$automationId = 'data-automation-id="form_' . $block['id'] . '" ';
@ -34,6 +41,10 @@ class Text {
$html .= 'value="' . $this->rendererHelper->getFieldValue($block) . '" ';
if ($styles) {
$html .= 'style="' . $styles . '" ';
}
$html .= $automationId;
$html .= $this->rendererHelper->renderInputPlaceholder($block);