exportSubscriber(Subscriber::findOne(trim($email)), $page); return array( 'data' => $data, 'done' => count($data) < self::LIMIT, ); } private function exportSubscriber($subscriber, $page) { if (!$subscriber) return array(); $result = array(); $statistics = StatisticsNewsletters::getAllForSubscriber($subscriber) ->limit(self::LIMIT) ->offset(self::LIMIT * ($page - 1)) ->findArray(); $newsletters = $this->loadNewsletters($statistics); foreach ($statistics as $row) { $result[] = $this->exportNewsletter($row, $newsletters, $subscriber); } return $result; } private function exportNewsletter($statistics_row, $newsletters, $subscriber) { $newsletter_data = array(); $newsletter_data[] = array( 'name' => WPFunctions::get()->__('Email subject', 'mailpoet'), 'value' => $statistics_row['newsletter_rendered_subject'], ); $newsletter_data[] = array( 'name' => WPFunctions::get()->__('Sent at', 'mailpoet'), 'value' => $statistics_row['sent_at'], ); if (isset($statistics_row['opened_at'])) { $newsletter_data[] = array( 'name' => WPFunctions::get()->__('Opened', 'mailpoet'), 'value' => 'Yes', ); $newsletter_data[] = array( 'name' => WPFunctions::get()->__('Opened at', 'mailpoet'), 'value' => $statistics_row['opened_at'], ); } else { $newsletter_data[] = array( 'name' => WPFunctions::get()->__('Opened', 'mailpoet'), 'value' => WPFunctions::get()->__('No', 'mailpoet'), ); } if (isset($newsletters[$statistics_row['newsletter_id']])) { $newsletter_data[] = array( 'name' => WPFunctions::get()->__('Email preview', 'mailpoet'), 'value' => Url::getViewInBrowserUrl( '', $newsletters[$statistics_row['newsletter_id']], $subscriber, false, true ), ); } return array( 'group_id' => 'mailpoet-newsletters', 'group_label' => WPFunctions::get()->__('MailPoet Emails Sent', 'mailpoet'), 'item_id' => 'newsletter-' . $statistics_row['newsletter_id'], 'data' => $newsletter_data, ); } private function loadNewsletters($statistics) { $newsletter_ids = array_map(function ($statistics_row) { return $statistics_row['newsletter_id']; }, $statistics); if (empty($newsletter_ids)) return array(); $newsletters = Newsletter::whereIn('id', $newsletter_ids)->findMany(); $result = array(); foreach ($newsletters as $newsletter) { $result[$newsletter->id()] = $newsletter; } return $result; } }