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\Comment::class)->setPublic(true);
|
||||||
$container->autowire(\MailPoet\Subscription\Form::class)->setPublic(true);
|
$container->autowire(\MailPoet\Subscription\Form::class)->setPublic(true);
|
||||||
$container->autowire(\MailPoet\Subscription\Manage::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)
|
$container->autowire(\MailPoet\Subscription\Pages::class)->setPublic(true)
|
||||||
->setShared(false); // Get a new instance each time $container->get() is called, needed for tests
|
->setShared(false); // Get a new instance each time $container->get() is called, needed for tests
|
||||||
$container->autowire(\MailPoet\Subscription\Registration::class)->setPublic(true);
|
$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\Config\Renderer as TemplateRenderer;
|
||||||
use MailPoet\Entities\StatisticsUnsubscribeEntity;
|
use MailPoet\Entities\StatisticsUnsubscribeEntity;
|
||||||
use MailPoet\Form\AssetsController;
|
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\Subscriber;
|
||||||
use MailPoet\Models\SubscriberSegment;
|
use MailPoet\Models\SubscriberSegment;
|
||||||
use MailPoet\Newsletter\Scheduler\WelcomeScheduler;
|
use MailPoet\Newsletter\Scheduler\WelcomeScheduler;
|
||||||
@ -17,7 +13,6 @@ use MailPoet\Statistics\Track\Unsubscribes;
|
|||||||
use MailPoet\Subscribers\LinkTokens;
|
use MailPoet\Subscribers\LinkTokens;
|
||||||
use MailPoet\Subscribers\NewSubscriberNotificationMailer;
|
use MailPoet\Subscribers\NewSubscriberNotificationMailer;
|
||||||
use MailPoet\Util\Helpers;
|
use MailPoet\Util\Helpers;
|
||||||
use MailPoet\Util\Url as UrlHelper;
|
|
||||||
use MailPoet\WP\Functions as WPFunctions;
|
use MailPoet\WP\Functions as WPFunctions;
|
||||||
|
|
||||||
class Pages {
|
class Pages {
|
||||||
@ -38,9 +33,6 @@ class Pages {
|
|||||||
/** @var SettingsController */
|
/** @var SettingsController */
|
||||||
private $settings;
|
private $settings;
|
||||||
|
|
||||||
/** @var UrlHelper */
|
|
||||||
private $urlHelper;
|
|
||||||
|
|
||||||
/** @var WPFunctions */
|
/** @var WPFunctions */
|
||||||
private $wp;
|
private $wp;
|
||||||
|
|
||||||
@ -59,46 +51,39 @@ class Pages {
|
|||||||
/** @var AssetsController */
|
/** @var AssetsController */
|
||||||
private $assetsController;
|
private $assetsController;
|
||||||
|
|
||||||
/** @var FormRenderer */
|
|
||||||
private $formRenderer;
|
|
||||||
|
|
||||||
/** @var FormBlockDate */
|
|
||||||
private $dateBlock;
|
|
||||||
|
|
||||||
/** @var TemplateRenderer */
|
/** @var TemplateRenderer */
|
||||||
private $templateRenderer;
|
private $templateRenderer;
|
||||||
|
|
||||||
/** @var Unsubscribes */
|
/** @var Unsubscribes */
|
||||||
private $unsubscribesTracker;
|
private $unsubscribesTracker;
|
||||||
|
|
||||||
|
/** @var ManageSubscriptionFormRenderer */
|
||||||
|
private $manageSubscriptionFormRenderer;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
NewSubscriberNotificationMailer $newSubscriberNotificationSender,
|
NewSubscriberNotificationMailer $newSubscriberNotificationSender,
|
||||||
WPFunctions $wp,
|
WPFunctions $wp,
|
||||||
SettingsController $settings,
|
SettingsController $settings,
|
||||||
UrlHelper $urlHelper,
|
|
||||||
CaptchaRenderer $captchaRenderer,
|
CaptchaRenderer $captchaRenderer,
|
||||||
WelcomeScheduler $welcomeScheduler,
|
WelcomeScheduler $welcomeScheduler,
|
||||||
LinkTokens $linkTokens,
|
LinkTokens $linkTokens,
|
||||||
SubscriptionUrlFactory $subscriptionUrlFactory,
|
SubscriptionUrlFactory $subscriptionUrlFactory,
|
||||||
AssetsController $assetsController,
|
AssetsController $assetsController,
|
||||||
FormRenderer $formRenderer,
|
|
||||||
FormBlockDate $dateBlock,
|
|
||||||
TemplateRenderer $templateRenderer,
|
TemplateRenderer $templateRenderer,
|
||||||
Unsubscribes $unsubscribesTracker
|
Unsubscribes $unsubscribesTracker,
|
||||||
|
ManageSubscriptionFormRenderer $manageSubscriptionFormRenderer
|
||||||
) {
|
) {
|
||||||
$this->wp = $wp;
|
$this->wp = $wp;
|
||||||
$this->newSubscriberNotificationSender = $newSubscriberNotificationSender;
|
$this->newSubscriberNotificationSender = $newSubscriberNotificationSender;
|
||||||
$this->settings = $settings;
|
$this->settings = $settings;
|
||||||
$this->urlHelper = $urlHelper;
|
|
||||||
$this->captchaRenderer = $captchaRenderer;
|
$this->captchaRenderer = $captchaRenderer;
|
||||||
$this->welcomeScheduler = $welcomeScheduler;
|
$this->welcomeScheduler = $welcomeScheduler;
|
||||||
$this->linkTokens = $linkTokens;
|
$this->linkTokens = $linkTokens;
|
||||||
$this->subscriptionUrlFactory = $subscriptionUrlFactory;
|
$this->subscriptionUrlFactory = $subscriptionUrlFactory;
|
||||||
$this->assetsController = $assetsController;
|
$this->assetsController = $assetsController;
|
||||||
$this->formRenderer = $formRenderer;
|
|
||||||
$this->dateBlock = $dateBlock;
|
|
||||||
$this->templateRenderer = $templateRenderer;
|
$this->templateRenderer = $templateRenderer;
|
||||||
$this->unsubscribesTracker = $unsubscribesTracker;
|
$this->unsubscribesTracker = $unsubscribesTracker;
|
||||||
|
$this->manageSubscriptionFormRenderer = $manageSubscriptionFormRenderer;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function init($action = false, $data = [], $initShortcodes = false, $initPageFilters = false) {
|
public function init($action = false, $data = [], $initShortcodes = false, $initPageFilters = false) {
|
||||||
@ -372,174 +357,7 @@ class Pages {
|
|||||||
} else {
|
} else {
|
||||||
return $this->wp->__('Subscription management form is only available to mailing lists subscribers.', 'mailpoet');
|
return $this->wp->__('Subscription management form is only available to mailing lists subscribers.', 'mailpoet');
|
||||||
}
|
}
|
||||||
|
return $this->manageSubscriptionFormRenderer->renderForm($subscriber);
|
||||||
$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)
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getUnsubscribeContent() {
|
private function getUnsubscribeContent() {
|
||||||
|
@ -7,8 +7,6 @@ use Codeception\Util\Fixtures;
|
|||||||
use MailPoet\Config\Renderer;
|
use MailPoet\Config\Renderer;
|
||||||
use MailPoet\DI\ContainerWrapper;
|
use MailPoet\DI\ContainerWrapper;
|
||||||
use MailPoet\Form\AssetsController;
|
use MailPoet\Form\AssetsController;
|
||||||
use MailPoet\Form\Block\Date as FormBlockDate;
|
|
||||||
use MailPoet\Form\Renderer as FormRenderer;
|
|
||||||
use MailPoet\Models\Newsletter;
|
use MailPoet\Models\Newsletter;
|
||||||
use MailPoet\Models\NewsletterOption;
|
use MailPoet\Models\NewsletterOption;
|
||||||
use MailPoet\Models\NewsletterOptionField;
|
use MailPoet\Models\NewsletterOptionField;
|
||||||
@ -24,9 +22,9 @@ use MailPoet\Statistics\Track\Unsubscribes;
|
|||||||
use MailPoet\Subscribers\LinkTokens;
|
use MailPoet\Subscribers\LinkTokens;
|
||||||
use MailPoet\Subscribers\NewSubscriberNotificationMailer;
|
use MailPoet\Subscribers\NewSubscriberNotificationMailer;
|
||||||
use MailPoet\Subscription\CaptchaRenderer;
|
use MailPoet\Subscription\CaptchaRenderer;
|
||||||
|
use MailPoet\Subscription\ManageSubscriptionFormRenderer;
|
||||||
use MailPoet\Subscription\Pages;
|
use MailPoet\Subscription\Pages;
|
||||||
use MailPoet\Subscription\SubscriptionUrlFactory;
|
use MailPoet\Subscription\SubscriptionUrlFactory;
|
||||||
use MailPoet\Util\Url as UrlHelper;
|
|
||||||
use MailPoet\WP\Functions as WPFunctions;
|
use MailPoet\WP\Functions as WPFunctions;
|
||||||
use MailPoetVendor\Carbon\Carbon;
|
use MailPoetVendor\Carbon\Carbon;
|
||||||
use MailPoetVendor\Idiorm\ORM;
|
use MailPoetVendor\Idiorm\ORM;
|
||||||
@ -194,16 +192,14 @@ class PagesTest extends \MailPoetTest {
|
|||||||
$newSubscriberNotificationsMock ?? $container->get(NewSubscriberNotificationMailer::class),
|
$newSubscriberNotificationsMock ?? $container->get(NewSubscriberNotificationMailer::class),
|
||||||
$container->get(WPFunctions::class),
|
$container->get(WPFunctions::class),
|
||||||
$container->get(SettingsController::class),
|
$container->get(SettingsController::class),
|
||||||
$container->get(UrlHelper::class),
|
|
||||||
$container->get(CaptchaRenderer::class),
|
$container->get(CaptchaRenderer::class),
|
||||||
$container->get(WelcomeScheduler::class),
|
$container->get(WelcomeScheduler::class),
|
||||||
$container->get(LinkTokens::class),
|
$container->get(LinkTokens::class),
|
||||||
$container->get(SubscriptionUrlFactory::class),
|
$container->get(SubscriptionUrlFactory::class),
|
||||||
$container->get(AssetsController::class),
|
$container->get(AssetsController::class),
|
||||||
$container->get(FormRenderer::class),
|
|
||||||
$container->get(FormBlockDate::class),
|
|
||||||
$container->get(Renderer::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