Refactor code duplication
[MAILPOET-3168]
This commit is contained in:
@ -29,10 +29,7 @@ class SegmentsResponseBuilder {
|
|||||||
$this->segmentSubscriberRepository = $segmentSubscriberRepository;
|
$this->segmentSubscriberRepository = $segmentSubscriberRepository;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
public function build(SegmentEntity $segment): array {
|
||||||
* @return array
|
|
||||||
*/
|
|
||||||
public function build(SegmentEntity $segment) {
|
|
||||||
return [
|
return [
|
||||||
'id' => (string)$segment->getId(), // (string) for BC
|
'id' => (string)$segment->getId(), // (string) for BC
|
||||||
'name' => $segment->getName(),
|
'name' => $segment->getName(),
|
||||||
@ -58,20 +55,14 @@ class SegmentsResponseBuilder {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private function buildListingItem(SegmentEntity $segment, array $scheduledNewsletterSubjectsMap, array $automatedNewsletterSubjectsMap): array {
|
private function buildListingItem(SegmentEntity $segment, array $scheduledNewsletterSubjectsMap, array $automatedNewsletterSubjectsMap): array {
|
||||||
return [
|
$data = $this->build($segment);
|
||||||
'id' => (string)$segment->getId(), // (string) for BC
|
|
||||||
'name' => $segment->getName(),
|
$data['automated_emails_subjects'] = $automatedNewsletterSubjectsMap[$segment->getId()] ?? [];
|
||||||
'type' => $segment->getType(),
|
$data['scheduled_emails_subjects'] = $scheduledNewsletterSubjectsMap[$segment->getId()] ?? [];
|
||||||
'description' => $segment->getDescription(),
|
$data['subscribers_count'] = $this->segmentSubscriberRepository->getSubscribersStatisticsCount($segment);
|
||||||
'created_at' => $segment->getCreatedAt()->format(self::DATE_FORMAT),
|
$data['subscribers_url'] = $this->wp->adminUrl(
|
||||||
'updated_at' => $segment->getUpdatedAt()->format(self::DATE_FORMAT),
|
|
||||||
'deleted_at' => ($deletedAt = $segment->getDeletedAt()) ? $deletedAt->format(self::DATE_FORMAT) : null,
|
|
||||||
'automated_emails_subjects' => $automatedNewsletterSubjectsMap[$segment->getId()] ?? [],
|
|
||||||
'scheduled_emails_subjects' => $scheduledNewsletterSubjectsMap[$segment->getId()] ?? [],
|
|
||||||
'subscribers_count' => $this->segmentSubscriberRepository->getSubscribersStatisticsCount($segment),
|
|
||||||
'subscribers_url' => $this->wp->adminUrl(
|
|
||||||
'admin.php?page=mailpoet-subscribers#/filter[segment=' . $segment->getId() . ']'
|
'admin.php?page=mailpoet-subscribers#/filter[segment=' . $segment->getId() . ']'
|
||||||
),
|
);
|
||||||
];
|
return $data;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user