Refactor manage subscription form rendering to separate class
[MAILPOET-1635]
This commit is contained in:
committed by
Veljko V
parent
5ec90795e2
commit
f1eb3d6b5d
@ -264,6 +264,7 @@ class ContainerConfigurator implements IContainerConfigurator {
|
||||
$container->autowire(\MailPoet\Subscription\Comment::class)->setPublic(true);
|
||||
$container->autowire(\MailPoet\Subscription\Form::class)->setPublic(true);
|
||||
$container->autowire(\MailPoet\Subscription\Manage::class)->setPublic(true);
|
||||
$container->autowire(\MailPoet\Subscription\ManageSubscriptionFormRenderer::class)->setPublic(true);
|
||||
$container->autowire(\MailPoet\Subscription\Pages::class)->setPublic(true)
|
||||
->setShared(false); // Get a new instance each time $container->get() is called, needed for tests
|
||||
$container->autowire(\MailPoet\Subscription\Registration::class)->setPublic(true);
|
||||
|
226
lib/Subscription/ManageSubscriptionFormRenderer.php
Normal file
226
lib/Subscription/ManageSubscriptionFormRenderer.php
Normal file
@ -0,0 +1,226 @@
|
||||
<?php
|
||||
|
||||
namespace MailPoet\Subscription;
|
||||
|
||||
use MailPoet\Config\Renderer as TemplateRenderer;
|
||||
use MailPoet\Form\Block\Date as FormBlockDate;
|
||||
use MailPoet\Form\Renderer as FormRenderer;
|
||||
use MailPoet\Models\CustomField;
|
||||
use MailPoet\Models\Segment;
|
||||
use MailPoet\Models\Subscriber;
|
||||
use MailPoet\Settings\SettingsController;
|
||||
use MailPoet\Subscribers\LinkTokens;
|
||||
use MailPoet\Util\Helpers;
|
||||
use MailPoet\Util\Url as UrlHelper;
|
||||
use MailPoet\WP\Functions as WPFunctions;
|
||||
|
||||
class ManageSubscriptionFormRenderer {
|
||||
/** @var SettingsController */
|
||||
private $settings;
|
||||
|
||||
/** @var UrlHelper */
|
||||
private $urlHelper;
|
||||
|
||||
/** @var WPFunctions */
|
||||
private $wp;
|
||||
|
||||
/** @var LinkTokens */
|
||||
private $linkTokens;
|
||||
|
||||
/** @var FormRenderer */
|
||||
private $formRenderer;
|
||||
|
||||
/** @var FormBlockDate */
|
||||
private $dateBlock;
|
||||
|
||||
/** @var TemplateRenderer */
|
||||
private $templateRenderer;
|
||||
|
||||
public function __construct(
|
||||
WPFunctions $wp,
|
||||
SettingsController $settings,
|
||||
UrlHelper $urlHelper,
|
||||
LinkTokens $linkTokens,
|
||||
FormRenderer $formRenderer,
|
||||
FormBlockDate $dateBlock,
|
||||
TemplateRenderer $templateRenderer
|
||||
) {
|
||||
$this->wp = $wp;
|
||||
$this->settings = $settings;
|
||||
$this->urlHelper = $urlHelper;
|
||||
$this->linkTokens = $linkTokens;
|
||||
$this->formRenderer = $formRenderer;
|
||||
$this->dateBlock = $dateBlock;
|
||||
$this->templateRenderer = $templateRenderer;
|
||||
}
|
||||
|
||||
public function renderForm(Subscriber $subscriber): string {
|
||||
$customFields = array_map(function($customField) use($subscriber) {
|
||||
$customField->id = 'cf_' . $customField->id;
|
||||
$customField = $customField->asArray();
|
||||
$customField['params']['value'] = $subscriber->{$customField['id']};
|
||||
|
||||
if ($customField['type'] === 'date') {
|
||||
$dateFormats = $this->dateBlock->getDateFormats();
|
||||
$customField['params']['date_format'] = array_shift(
|
||||
$dateFormats[$customField['params']['date_type']]
|
||||
);
|
||||
}
|
||||
if (!isset($customField['params']['label'])) {
|
||||
$customField['params']['label'] = $customField['name'];
|
||||
}
|
||||
|
||||
return $customField;
|
||||
}, CustomField::findMany());
|
||||
|
||||
$segmentIds = $this->settings->get('subscription.segments', []);
|
||||
if (!empty($segmentIds)) {
|
||||
$segments = Segment::getPublic()
|
||||
->whereIn('id', $segmentIds)
|
||||
->findMany();
|
||||
} else {
|
||||
$segments = Segment::getPublic()
|
||||
->findMany();
|
||||
}
|
||||
$subscribedSegmentIds = [];
|
||||
if (!empty($subscriber->subscriptions)) {
|
||||
foreach ($subscriber->subscriptions as $subscription) {
|
||||
if ($subscription['status'] === Subscriber::STATUS_SUBSCRIBED) {
|
||||
$subscribedSegmentIds[] = $subscription['segment_id'];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$segments = array_map(function($segment) use($subscribedSegmentIds) {
|
||||
return [
|
||||
'id' => $segment->id,
|
||||
'name' => $segment->name,
|
||||
'is_checked' => in_array($segment->id, $subscribedSegmentIds),
|
||||
];
|
||||
}, $segments);
|
||||
|
||||
|
||||
$fields = [
|
||||
[
|
||||
'id' => 'first_name',
|
||||
'type' => 'text',
|
||||
'params' => [
|
||||
'label' => __('First name', 'mailpoet'),
|
||||
'value' => $subscriber->firstName,
|
||||
'disabled' => ($subscriber->isWPUser() || $subscriber->isWooCommerceUser()),
|
||||
],
|
||||
],
|
||||
[
|
||||
'id' => 'last_name',
|
||||
'type' => 'text',
|
||||
'params' => [
|
||||
'label' => __('Last name', 'mailpoet'),
|
||||
'value' => $subscriber->lastName,
|
||||
'disabled' => ($subscriber->isWPUser() || $subscriber->isWooCommerceUser()),
|
||||
],
|
||||
],
|
||||
[
|
||||
'id' => 'status',
|
||||
'type' => 'select',
|
||||
'params' => [
|
||||
'required' => true,
|
||||
'label' => __('Status', 'mailpoet'),
|
||||
'values' => [
|
||||
[
|
||||
'value' => [
|
||||
Subscriber::STATUS_SUBSCRIBED => __('Subscribed', 'mailpoet'),
|
||||
],
|
||||
'is_checked' => (
|
||||
$subscriber->status === Subscriber::STATUS_SUBSCRIBED
|
||||
),
|
||||
],
|
||||
[
|
||||
'value' => [
|
||||
Subscriber::STATUS_UNSUBSCRIBED => __('Unsubscribed', 'mailpoet'),
|
||||
],
|
||||
'is_checked' => (
|
||||
$subscriber->status === Subscriber::STATUS_UNSUBSCRIBED
|
||||
),
|
||||
],
|
||||
[
|
||||
'value' => [
|
||||
Subscriber::STATUS_BOUNCED => __('Bounced', 'mailpoet'),
|
||||
],
|
||||
'is_checked' => (
|
||||
$subscriber->status === Subscriber::STATUS_BOUNCED
|
||||
),
|
||||
'is_disabled' => true,
|
||||
'is_hidden' => (
|
||||
$subscriber->status !== Subscriber::STATUS_BOUNCED
|
||||
),
|
||||
],
|
||||
[
|
||||
'value' => [
|
||||
Subscriber::STATUS_INACTIVE => __('Inactive', 'mailpoet'),
|
||||
],
|
||||
'is_checked' => (
|
||||
$subscriber->status === Subscriber::STATUS_INACTIVE
|
||||
),
|
||||
'is_hidden' => (
|
||||
$subscriber->status !== Subscriber::STATUS_INACTIVE
|
||||
),
|
||||
],
|
||||
],
|
||||
],
|
||||
],
|
||||
];
|
||||
|
||||
$form = array_merge(
|
||||
$fields,
|
||||
$customFields,
|
||||
[
|
||||
[
|
||||
'id' => 'segments',
|
||||
'type' => 'segment',
|
||||
'params' => [
|
||||
'label' => __('Your lists', 'mailpoet'),
|
||||
'values' => $segments,
|
||||
],
|
||||
],
|
||||
[
|
||||
'id' => 'submit',
|
||||
'type' => 'submit',
|
||||
'params' => [
|
||||
'label' => __('Save', 'mailpoet'),
|
||||
],
|
||||
],
|
||||
]
|
||||
);
|
||||
|
||||
$templateData = [
|
||||
'actionUrl' => admin_url('admin-post.php'),
|
||||
'redirectUrl' => $this->urlHelper->getCurrentUrl(),
|
||||
'email' => $subscriber->email,
|
||||
'token' => $this->linkTokens->getToken($subscriber),
|
||||
'editEmailInfo' => __('Need to change your email address? Unsubscribe here, then simply sign up again.', 'mailpoet'),
|
||||
'formHtml' => $this->formRenderer->renderBlocks($form, [], $honeypot = false),
|
||||
];
|
||||
|
||||
if ($subscriber->isWPUser() || $subscriber->isWooCommerceUser()) {
|
||||
$wpCurrentUser = $this->wp->wpGetCurrentUser();
|
||||
if ($wpCurrentUser->user_email === $subscriber->email) { // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
$templateData['editEmailInfo'] = Helpers::replaceLinkTags(
|
||||
__('[link]Edit your profile[/link] to update your email.', 'mailpoet'),
|
||||
$this->wp->getEditProfileUrl(),
|
||||
['target' => '_blank']
|
||||
);
|
||||
} else {
|
||||
$templateData['editEmailInfo'] = Helpers::replaceLinkTags(
|
||||
__('[link]Log in to your account[/link] to update your email.', 'mailpoet'),
|
||||
$this->wp->wpLoginUrl(),
|
||||
['target' => '_blank']
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
return $this->wp->applyFilters(
|
||||
'mailpoet_manage_subscription_page',
|
||||
$this->templateRenderer->render('subscription/manage_subscription.html', $templateData)
|
||||
);
|
||||
}
|
||||
}
|
@ -5,10 +5,6 @@ namespace MailPoet\Subscription;
|
||||
use MailPoet\Config\Renderer as TemplateRenderer;
|
||||
use MailPoet\Entities\StatisticsUnsubscribeEntity;
|
||||
use MailPoet\Form\AssetsController;
|
||||
use MailPoet\Form\Block\Date as FormBlockDate;
|
||||
use MailPoet\Form\Renderer as FormRenderer;
|
||||
use MailPoet\Models\CustomField;
|
||||
use MailPoet\Models\Segment;
|
||||
use MailPoet\Models\Subscriber;
|
||||
use MailPoet\Models\SubscriberSegment;
|
||||
use MailPoet\Newsletter\Scheduler\WelcomeScheduler;
|
||||
@ -17,7 +13,6 @@ use MailPoet\Statistics\Track\Unsubscribes;
|
||||
use MailPoet\Subscribers\LinkTokens;
|
||||
use MailPoet\Subscribers\NewSubscriberNotificationMailer;
|
||||
use MailPoet\Util\Helpers;
|
||||
use MailPoet\Util\Url as UrlHelper;
|
||||
use MailPoet\WP\Functions as WPFunctions;
|
||||
|
||||
class Pages {
|
||||
@ -38,9 +33,6 @@ class Pages {
|
||||
/** @var SettingsController */
|
||||
private $settings;
|
||||
|
||||
/** @var UrlHelper */
|
||||
private $urlHelper;
|
||||
|
||||
/** @var WPFunctions */
|
||||
private $wp;
|
||||
|
||||
@ -59,46 +51,39 @@ class Pages {
|
||||
/** @var AssetsController */
|
||||
private $assetsController;
|
||||
|
||||
/** @var FormRenderer */
|
||||
private $formRenderer;
|
||||
|
||||
/** @var FormBlockDate */
|
||||
private $dateBlock;
|
||||
|
||||
/** @var TemplateRenderer */
|
||||
private $templateRenderer;
|
||||
|
||||
/** @var Unsubscribes */
|
||||
private $unsubscribesTracker;
|
||||
|
||||
/** @var ManageSubscriptionFormRenderer */
|
||||
private $manageSubscriptionFormRenderer;
|
||||
|
||||
public function __construct(
|
||||
NewSubscriberNotificationMailer $newSubscriberNotificationSender,
|
||||
WPFunctions $wp,
|
||||
SettingsController $settings,
|
||||
UrlHelper $urlHelper,
|
||||
CaptchaRenderer $captchaRenderer,
|
||||
WelcomeScheduler $welcomeScheduler,
|
||||
LinkTokens $linkTokens,
|
||||
SubscriptionUrlFactory $subscriptionUrlFactory,
|
||||
AssetsController $assetsController,
|
||||
FormRenderer $formRenderer,
|
||||
FormBlockDate $dateBlock,
|
||||
TemplateRenderer $templateRenderer,
|
||||
Unsubscribes $unsubscribesTracker
|
||||
Unsubscribes $unsubscribesTracker,
|
||||
ManageSubscriptionFormRenderer $manageSubscriptionFormRenderer
|
||||
) {
|
||||
$this->wp = $wp;
|
||||
$this->newSubscriberNotificationSender = $newSubscriberNotificationSender;
|
||||
$this->settings = $settings;
|
||||
$this->urlHelper = $urlHelper;
|
||||
$this->captchaRenderer = $captchaRenderer;
|
||||
$this->welcomeScheduler = $welcomeScheduler;
|
||||
$this->linkTokens = $linkTokens;
|
||||
$this->subscriptionUrlFactory = $subscriptionUrlFactory;
|
||||
$this->assetsController = $assetsController;
|
||||
$this->formRenderer = $formRenderer;
|
||||
$this->dateBlock = $dateBlock;
|
||||
$this->templateRenderer = $templateRenderer;
|
||||
$this->unsubscribesTracker = $unsubscribesTracker;
|
||||
$this->manageSubscriptionFormRenderer = $manageSubscriptionFormRenderer;
|
||||
}
|
||||
|
||||
public function init($action = false, $data = [], $initShortcodes = false, $initPageFilters = false) {
|
||||
@ -372,174 +357,7 @@ class Pages {
|
||||
} else {
|
||||
return $this->wp->__('Subscription management form is only available to mailing lists subscribers.', 'mailpoet');
|
||||
}
|
||||
|
||||
$customFields = array_map(function($customField) use($subscriber) {
|
||||
$customField->id = 'cf_' . $customField->id;
|
||||
$customField = $customField->asArray();
|
||||
$customField['params']['value'] = $subscriber->{$customField['id']};
|
||||
|
||||
if ($customField['type'] === 'date') {
|
||||
$dateFormats = $this->dateBlock->getDateFormats();
|
||||
$customField['params']['date_format'] = array_shift(
|
||||
$dateFormats[$customField['params']['date_type']]
|
||||
);
|
||||
}
|
||||
if (!isset($customField['params']['label'])) {
|
||||
$customField['params']['label'] = $customField['name'];
|
||||
}
|
||||
|
||||
return $customField;
|
||||
}, CustomField::findMany());
|
||||
|
||||
$segmentIds = $this->settings->get('subscription.segments', []);
|
||||
if (!empty($segmentIds)) {
|
||||
$segments = Segment::getPublic()
|
||||
->whereIn('id', $segmentIds)
|
||||
->findMany();
|
||||
} else {
|
||||
$segments = Segment::getPublic()
|
||||
->findMany();
|
||||
}
|
||||
$subscribedSegmentIds = [];
|
||||
if (!empty($this->subscriber->subscriptions)) {
|
||||
foreach ($this->subscriber->subscriptions as $subscription) {
|
||||
if ($subscription['status'] === Subscriber::STATUS_SUBSCRIBED) {
|
||||
$subscribedSegmentIds[] = $subscription['segment_id'];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$segments = array_map(function($segment) use($subscribedSegmentIds) {
|
||||
return [
|
||||
'id' => $segment->id,
|
||||
'name' => $segment->name,
|
||||
'is_checked' => in_array($segment->id, $subscribedSegmentIds),
|
||||
];
|
||||
}, $segments);
|
||||
|
||||
|
||||
$fields = [
|
||||
[
|
||||
'id' => 'first_name',
|
||||
'type' => 'text',
|
||||
'params' => [
|
||||
'label' => $this->wp->__('First name', 'mailpoet'),
|
||||
'value' => $subscriber->firstName,
|
||||
'disabled' => ($subscriber->isWPUser() || $subscriber->isWooCommerceUser()),
|
||||
],
|
||||
],
|
||||
[
|
||||
'id' => 'last_name',
|
||||
'type' => 'text',
|
||||
'params' => [
|
||||
'label' => $this->wp->__('Last name', 'mailpoet'),
|
||||
'value' => $subscriber->lastName,
|
||||
'disabled' => ($subscriber->isWPUser() || $subscriber->isWooCommerceUser()),
|
||||
],
|
||||
],
|
||||
[
|
||||
'id' => 'status',
|
||||
'type' => 'select',
|
||||
'params' => [
|
||||
'required' => true,
|
||||
'label' => $this->wp->__('Status', 'mailpoet'),
|
||||
'values' => [
|
||||
[
|
||||
'value' => [
|
||||
Subscriber::STATUS_SUBSCRIBED => $this->wp->__('Subscribed', 'mailpoet'),
|
||||
],
|
||||
'is_checked' => (
|
||||
$subscriber->status === Subscriber::STATUS_SUBSCRIBED
|
||||
),
|
||||
],
|
||||
[
|
||||
'value' => [
|
||||
Subscriber::STATUS_UNSUBSCRIBED => $this->wp->__('Unsubscribed', 'mailpoet'),
|
||||
],
|
||||
'is_checked' => (
|
||||
$subscriber->status === Subscriber::STATUS_UNSUBSCRIBED
|
||||
),
|
||||
],
|
||||
[
|
||||
'value' => [
|
||||
Subscriber::STATUS_BOUNCED => $this->wp->__('Bounced', 'mailpoet'),
|
||||
],
|
||||
'is_checked' => (
|
||||
$subscriber->status === Subscriber::STATUS_BOUNCED
|
||||
),
|
||||
'is_disabled' => true,
|
||||
'is_hidden' => (
|
||||
$subscriber->status !== Subscriber::STATUS_BOUNCED
|
||||
),
|
||||
],
|
||||
[
|
||||
'value' => [
|
||||
Subscriber::STATUS_INACTIVE => $this->wp->__('Inactive', 'mailpoet'),
|
||||
],
|
||||
'is_checked' => (
|
||||
$subscriber->status === Subscriber::STATUS_INACTIVE
|
||||
),
|
||||
'is_hidden' => (
|
||||
$subscriber->status !== Subscriber::STATUS_INACTIVE
|
||||
),
|
||||
],
|
||||
],
|
||||
],
|
||||
],
|
||||
];
|
||||
|
||||
$form = array_merge(
|
||||
$fields,
|
||||
$customFields,
|
||||
[
|
||||
[
|
||||
'id' => 'segments',
|
||||
'type' => 'segment',
|
||||
'params' => [
|
||||
'label' => $this->wp->__('Your lists', 'mailpoet'),
|
||||
'values' => $segments,
|
||||
],
|
||||
],
|
||||
[
|
||||
'id' => 'submit',
|
||||
'type' => 'submit',
|
||||
'params' => [
|
||||
'label' => $this->wp->__('Save', 'mailpoet'),
|
||||
],
|
||||
],
|
||||
]
|
||||
);
|
||||
|
||||
$templateData = [
|
||||
'actionUrl' => admin_url('admin-post.php'),
|
||||
'redirectUrl' => $this->urlHelper->getCurrentUrl(),
|
||||
'email' => $subscriber->email,
|
||||
'token' => $this->linkTokens->getToken($subscriber),
|
||||
'editEmailInfo' => __('Need to change your email address? Unsubscribe here, then simply sign up again.', 'mailpoet'),
|
||||
'formHtml' => $this->formRenderer->renderBlocks($form, [], $honeypot = false),
|
||||
];
|
||||
|
||||
if ($subscriber->isWPUser() || $subscriber->isWooCommerceUser()) {
|
||||
$wpCurrentUser = $this->wp->wpGetCurrentUser();
|
||||
if ($wpCurrentUser->user_email === $subscriber->email) { // phpcs:ignore Squiz.NamingConventions.ValidVariableName.NotCamelCaps
|
||||
$templateData['editEmailInfo'] = Helpers::replaceLinkTags(
|
||||
__('[link]Edit your profile[/link] to update your email.', 'mailpoet'),
|
||||
$this->wp->getEditProfileUrl(),
|
||||
['target' => '_blank']
|
||||
);
|
||||
} else {
|
||||
$templateData['editEmailInfo'] = Helpers::replaceLinkTags(
|
||||
__('[link]Log in to your account[/link] to update your email.', 'mailpoet'),
|
||||
$this->wp->wpLoginUrl(),
|
||||
['target' => '_blank']
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
return $this->wp->applyFilters(
|
||||
'mailpoet_manage_subscription_page',
|
||||
$this->templateRenderer->render('subscription/manage_subscription.html', $templateData)
|
||||
);
|
||||
return $this->manageSubscriptionFormRenderer->renderForm($subscriber);
|
||||
}
|
||||
|
||||
private function getUnsubscribeContent() {
|
||||
|
@ -7,8 +7,6 @@ use Codeception\Util\Fixtures;
|
||||
use MailPoet\Config\Renderer;
|
||||
use MailPoet\DI\ContainerWrapper;
|
||||
use MailPoet\Form\AssetsController;
|
||||
use MailPoet\Form\Block\Date as FormBlockDate;
|
||||
use MailPoet\Form\Renderer as FormRenderer;
|
||||
use MailPoet\Models\Newsletter;
|
||||
use MailPoet\Models\NewsletterOption;
|
||||
use MailPoet\Models\NewsletterOptionField;
|
||||
@ -24,9 +22,9 @@ use MailPoet\Statistics\Track\Unsubscribes;
|
||||
use MailPoet\Subscribers\LinkTokens;
|
||||
use MailPoet\Subscribers\NewSubscriberNotificationMailer;
|
||||
use MailPoet\Subscription\CaptchaRenderer;
|
||||
use MailPoet\Subscription\ManageSubscriptionFormRenderer;
|
||||
use MailPoet\Subscription\Pages;
|
||||
use MailPoet\Subscription\SubscriptionUrlFactory;
|
||||
use MailPoet\Util\Url as UrlHelper;
|
||||
use MailPoet\WP\Functions as WPFunctions;
|
||||
use MailPoetVendor\Carbon\Carbon;
|
||||
use MailPoetVendor\Idiorm\ORM;
|
||||
@ -194,16 +192,14 @@ class PagesTest extends \MailPoetTest {
|
||||
$newSubscriberNotificationsMock ?? $container->get(NewSubscriberNotificationMailer::class),
|
||||
$container->get(WPFunctions::class),
|
||||
$container->get(SettingsController::class),
|
||||
$container->get(UrlHelper::class),
|
||||
$container->get(CaptchaRenderer::class),
|
||||
$container->get(WelcomeScheduler::class),
|
||||
$container->get(LinkTokens::class),
|
||||
$container->get(SubscriptionUrlFactory::class),
|
||||
$container->get(AssetsController::class),
|
||||
$container->get(FormRenderer::class),
|
||||
$container->get(FormBlockDate::class),
|
||||
$container->get(Renderer::class),
|
||||
$unsubscribesMock ?? $container->get(Unsubscribes::class)
|
||||
$unsubscribesMock ?? $container->get(Unsubscribes::class),
|
||||
$container->get(ManageSubscriptionFormRenderer::class)
|
||||
);
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user