655 lines
20 KiB
PHP
655 lines
20 KiB
PHP
|
<?php
|
||
|
/*
|
||
|
+--------------------------------------------------------------------+
|
||
|
| CiviCRM version 4.7 |
|
||
|
+--------------------------------------------------------------------+
|
||
|
| Copyright CiviCRM LLC (c) 2004-2017 |
|
||
|
+--------------------------------------------------------------------+
|
||
|
| This file is a part of CiviCRM. |
|
||
|
| |
|
||
|
| CiviCRM is free software; you can copy, modify, and distribute it |
|
||
|
| under the terms of the GNU Affero General Public License |
|
||
|
| Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
|
||
|
| |
|
||
|
| CiviCRM is distributed in the hope that it will be useful, but |
|
||
|
| WITHOUT ANY WARRANTY; without even the implied warranty of |
|
||
|
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
|
||
|
| See the GNU Affero General Public License for more details. |
|
||
|
| |
|
||
|
| You should have received a copy of the GNU Affero General Public |
|
||
|
| License and the CiviCRM Licensing Exception along |
|
||
|
| with this program; if not, contact CiviCRM LLC |
|
||
|
| at info[AT]civicrm[DOT]org. If you have questions about the |
|
||
|
| GNU Affero General Public License or the licensing of CiviCRM, |
|
||
|
| see the CiviCRM license FAQ at http://civicrm.org/licensing |
|
||
|
+--------------------------------------------------------------------+
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
*
|
||
|
* @package CRM
|
||
|
* @copyright CiviCRM LLC (c) 2004-2017
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* This class is used to browse past mailings.
|
||
|
*/
|
||
|
class CRM_Mailing_Selector_Browse extends CRM_Core_Selector_Base implements CRM_Core_Selector_API {
|
||
|
|
||
|
/**
|
||
|
* Array of supported links, currently null
|
||
|
*
|
||
|
* @var array
|
||
|
*/
|
||
|
static $_links = NULL;
|
||
|
|
||
|
/**
|
||
|
* We use desc to remind us what that column is, name is used in the tpl
|
||
|
*
|
||
|
* @var array
|
||
|
*/
|
||
|
static $_columnHeaders;
|
||
|
|
||
|
protected $_parent;
|
||
|
|
||
|
/**
|
||
|
* Class constructor.
|
||
|
*
|
||
|
*
|
||
|
* @return \CRM_Mailing_Selector_Browse
|
||
|
*/
|
||
|
public function __construct() {
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* This method returns the links that are given for each search row.
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public static function &links() {
|
||
|
return self::$_links;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Getter for array of the parameters required for creating pager.
|
||
|
*
|
||
|
* @param $action
|
||
|
* @param array $params
|
||
|
*/
|
||
|
public function getPagerParams($action, &$params) {
|
||
|
$params['csvString'] = NULL;
|
||
|
$params['rowCount'] = CRM_Utils_Pager::ROWCOUNT;
|
||
|
$params['status'] = ts('Mailings %%StatusMessage%%');
|
||
|
$params['buttonTop'] = 'PagerTopButton';
|
||
|
$params['buttonBottom'] = 'PagerBottomButton';
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the column headers as an array of tuples:
|
||
|
* (name, sortName (key to the sort array))
|
||
|
*
|
||
|
* @param string $action
|
||
|
* The action being performed.
|
||
|
* @param string $output
|
||
|
* What should the result set include (web/email/csv).
|
||
|
*
|
||
|
* @return array
|
||
|
* the column headers that need to be displayed
|
||
|
*/
|
||
|
public function &getColumnHeaders($action = NULL, $output = NULL) {
|
||
|
$mailing = CRM_Mailing_BAO_Mailing::getTableName();
|
||
|
$job = CRM_Mailing_BAO_MailingJob::getTableName();
|
||
|
if (!isset(self::$_columnHeaders)) {
|
||
|
$completedOrder = NULL;
|
||
|
|
||
|
// Set different default sort depending on type of mailings (CRM-7652)
|
||
|
$unscheduledOrder = $scheduledOrder = $archivedOrder = CRM_Utils_Sort::DONTCARE;
|
||
|
if ($this->_parent->get('unscheduled')) {
|
||
|
$unscheduledOrder = CRM_Utils_Sort::DESCENDING;
|
||
|
}
|
||
|
elseif ($this->_parent->get('scheduled')) {
|
||
|
$scheduledOrder = CRM_Utils_Sort::DESCENDING;
|
||
|
}
|
||
|
else {
|
||
|
// sort by completed date for archived and undefined get
|
||
|
$completedOrder = CRM_Utils_Sort::DESCENDING;
|
||
|
}
|
||
|
$nameHeaderLabel = ($this->_parent->get('sms')) ? ts('SMS Name') : ts('Mailing Name');
|
||
|
|
||
|
self::$_columnHeaders = array(
|
||
|
array(
|
||
|
'name' => $nameHeaderLabel,
|
||
|
'sort' => 'name',
|
||
|
'direction' => CRM_Utils_Sort::DONTCARE,
|
||
|
),
|
||
|
);
|
||
|
|
||
|
if (CRM_Core_I18n::isMultilingual()) {
|
||
|
self::$_columnHeaders = array_merge(
|
||
|
self::$_columnHeaders,
|
||
|
array(
|
||
|
array(
|
||
|
'name' => ts('Language'),
|
||
|
'sort' => 'language',
|
||
|
'direction' => CRM_Utils_Sort::DONTCARE,
|
||
|
),
|
||
|
)
|
||
|
);
|
||
|
}
|
||
|
|
||
|
self::$_columnHeaders = array_merge(
|
||
|
self::$_columnHeaders,
|
||
|
array(
|
||
|
array(
|
||
|
'name' => ts('Status'),
|
||
|
'sort' => 'status',
|
||
|
'direction' => CRM_Utils_Sort::DONTCARE,
|
||
|
),
|
||
|
array(
|
||
|
'name' => ts('Created By'),
|
||
|
'sort' => 'created_by',
|
||
|
'direction' => CRM_Utils_Sort::DONTCARE,
|
||
|
),
|
||
|
array(
|
||
|
'name' => ts('Created Date'),
|
||
|
'sort' => 'created_date',
|
||
|
'direction' => $unscheduledOrder,
|
||
|
),
|
||
|
array(
|
||
|
'name' => ts('Sent By'),
|
||
|
'sort' => 'scheduled_by',
|
||
|
'direction' => CRM_Utils_Sort::DONTCARE,
|
||
|
),
|
||
|
array(
|
||
|
'name' => ts('Scheduled'),
|
||
|
'sort' => 'scheduled_date',
|
||
|
'direction' => $scheduledOrder,
|
||
|
),
|
||
|
array(
|
||
|
'name' => ts('Started'),
|
||
|
'sort' => 'start_date',
|
||
|
'direction' => CRM_Utils_Sort::DONTCARE,
|
||
|
),
|
||
|
array(
|
||
|
'name' => ts('Completed'),
|
||
|
'sort' => 'end_date',
|
||
|
'direction' => $completedOrder,
|
||
|
),
|
||
|
)
|
||
|
);
|
||
|
|
||
|
if (CRM_Campaign_BAO_Campaign::isCampaignEnable()) {
|
||
|
self::$_columnHeaders[] = array(
|
||
|
'name' => ts('Campaign'),
|
||
|
'sort' => 'campaign_id',
|
||
|
'direction' => CRM_Utils_Sort::DONTCARE,
|
||
|
);
|
||
|
}
|
||
|
|
||
|
if ($output != CRM_Core_Selector_Controller::EXPORT) {
|
||
|
self::$_columnHeaders[] = array('name' => ts('Action'));
|
||
|
}
|
||
|
}
|
||
|
|
||
|
CRM_Core_Smarty::singleton()->assign('multilingual', CRM_Core_I18n::isMultilingual());
|
||
|
return self::$_columnHeaders;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns total number of rows for the query.
|
||
|
*
|
||
|
* @param string $action
|
||
|
*
|
||
|
* @return int
|
||
|
* Total number of rows
|
||
|
*/
|
||
|
public function getTotalCount($action) {
|
||
|
$job = CRM_Mailing_BAO_MailingJob::getTableName();
|
||
|
$mailing = CRM_Mailing_BAO_Mailing::getTableName();
|
||
|
$mailingACL = CRM_Mailing_BAO_Mailing::mailingACL();
|
||
|
|
||
|
// get the where clause.
|
||
|
$params = array();
|
||
|
$whereClause = "$mailingACL AND " . $this->whereClause($params);
|
||
|
|
||
|
// CRM-11919 added addition ON clauses to mailing_job to match getRows
|
||
|
$query = "
|
||
|
SELECT COUNT( DISTINCT $mailing.id ) as count
|
||
|
FROM $mailing
|
||
|
LEFT JOIN $job ON ( $mailing.id = $job.mailing_id AND civicrm_mailing_job.is_test = 0 AND civicrm_mailing_job.parent_id IS NULL )
|
||
|
LEFT JOIN civicrm_contact createdContact ON ( $mailing.created_id = createdContact.id )
|
||
|
LEFT JOIN civicrm_contact scheduledContact ON ( $mailing.scheduled_id = scheduledContact.id )
|
||
|
WHERE $whereClause";
|
||
|
|
||
|
return CRM_Core_DAO::singleValueQuery($query, $params);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns all the rows in the given offset and rowCount.
|
||
|
*
|
||
|
* @param string $action
|
||
|
* The action being performed.
|
||
|
* @param int $offset
|
||
|
* The row number to start from.
|
||
|
* @param int $rowCount
|
||
|
* The number of rows to return.
|
||
|
* @param string $sort
|
||
|
* The sql string that describes the sort order.
|
||
|
* @param string $output
|
||
|
* What should the result set include (web/email/csv).
|
||
|
*
|
||
|
* @return int
|
||
|
* the total number of rows for this action
|
||
|
*/
|
||
|
public function &getRows($action, $offset, $rowCount, $sort, $output = NULL) {
|
||
|
static $actionLinks = NULL;
|
||
|
if (empty($actionLinks)) {
|
||
|
$cancelExtra = ts('Are you sure you want to cancel this mailing?');
|
||
|
$deleteExtra = ts('Are you sure you want to delete this mailing?');
|
||
|
$archiveExtra = ts('Are you sure you want to archive this mailing?');
|
||
|
|
||
|
$actionLinks = array(
|
||
|
CRM_Core_Action::ENABLE => array(
|
||
|
'name' => ts('Approve/Reject'),
|
||
|
'url' => 'civicrm/mailing/approve',
|
||
|
'qs' => 'mid=%%mid%%&reset=1',
|
||
|
'title' => ts('Approve/Reject Mailing'),
|
||
|
),
|
||
|
CRM_Core_Action::VIEW => array(
|
||
|
'name' => ts('Report'),
|
||
|
'url' => 'civicrm/mailing/report',
|
||
|
'qs' => 'mid=%%mid%%&reset=1',
|
||
|
'title' => ts('View Mailing Report'),
|
||
|
),
|
||
|
CRM_Core_Action::UPDATE => array(
|
||
|
'name' => ts('Re-Use'),
|
||
|
'url' => 'civicrm/mailing/send',
|
||
|
'qs' => 'mid=%%mid%%&reset=1',
|
||
|
'title' => ts('Re-Send Mailing'),
|
||
|
),
|
||
|
CRM_Core_Action::DISABLE => array(
|
||
|
'name' => ts('Cancel'),
|
||
|
'url' => 'civicrm/mailing/browse',
|
||
|
'qs' => 'action=disable&mid=%%mid%%&reset=1',
|
||
|
'extra' => 'onclick="if (confirm(\'' . $cancelExtra . '\')) this.href+=\'&confirmed=1\'; else return false;"',
|
||
|
'title' => ts('Cancel Mailing'),
|
||
|
),
|
||
|
CRM_Core_Action::PREVIEW => array(
|
||
|
'name' => ts('Continue'),
|
||
|
'url' => 'civicrm/mailing/send',
|
||
|
'qs' => 'mid=%%mid%%&continue=true&reset=1',
|
||
|
'title' => ts('Continue Mailing'),
|
||
|
),
|
||
|
CRM_Core_Action::DELETE => array(
|
||
|
'name' => ts('Delete'),
|
||
|
'url' => 'civicrm/mailing/browse',
|
||
|
'qs' => 'action=delete&mid=%%mid%%&reset=1',
|
||
|
'extra' => 'onclick="if (confirm(\'' . $deleteExtra . '\')) this.href+=\'&confirmed=1\'; else return false;"',
|
||
|
'title' => ts('Delete Mailing'),
|
||
|
),
|
||
|
CRM_Core_Action::RENEW => array(
|
||
|
'name' => ts('Archive'),
|
||
|
'url' => 'civicrm/mailing/browse/archived',
|
||
|
'qs' => 'action=renew&mid=%%mid%%&reset=1',
|
||
|
'extra' => 'onclick="if (confirm(\'' . $archiveExtra . '\')) this.href+=\'&confirmed=1\'; else return false;"',
|
||
|
'title' => ts('Archive Mailing'),
|
||
|
),
|
||
|
);
|
||
|
}
|
||
|
|
||
|
$allAccess = TRUE;
|
||
|
$workFlow = $showApprovalLinks = $showScheduleLinks = $showCreateLinks = FALSE;
|
||
|
if (CRM_Mailing_Info::workflowEnabled()) {
|
||
|
$allAccess = FALSE;
|
||
|
$workFlow = TRUE;
|
||
|
// supercedes all permission
|
||
|
if (CRM_Core_Permission::check('access CiviMail')) {
|
||
|
$allAccess = TRUE;
|
||
|
}
|
||
|
|
||
|
if (CRM_Core_Permission::check('approve mailings')) {
|
||
|
$showApprovalLinks = TRUE;
|
||
|
}
|
||
|
|
||
|
if (CRM_Core_Permission::check('create mailings')) {
|
||
|
$showCreateLinks = TRUE;
|
||
|
}
|
||
|
|
||
|
if (CRM_Core_Permission::check('schedule mailings')) {
|
||
|
$showScheduleLinks = TRUE;
|
||
|
}
|
||
|
}
|
||
|
$mailing = new CRM_Mailing_BAO_Mailing();
|
||
|
|
||
|
$params = array();
|
||
|
|
||
|
$whereClause = ' AND ' . $this->whereClause($params);
|
||
|
|
||
|
if (empty($params)) {
|
||
|
$this->_parent->assign('isSearch', 0);
|
||
|
}
|
||
|
else {
|
||
|
$this->_parent->assign('isSearch', 1);
|
||
|
}
|
||
|
$rows = &$mailing->getRows($offset, $rowCount, $sort, $whereClause, $params);
|
||
|
|
||
|
// get the search base mailing Ids, CRM-3711.
|
||
|
$searchMailings = $mailing->searchMailingIDs();
|
||
|
|
||
|
// check for delete CRM-4418
|
||
|
$allowToDelete = CRM_Core_Permission::check('delete in CiviMail');
|
||
|
|
||
|
if ($output != CRM_Core_Selector_Controller::EXPORT) {
|
||
|
|
||
|
// create the appropriate $op to use for hook_civicrm_links
|
||
|
$pageTypes = array('view', 'mailing', 'browse');
|
||
|
if ($this->_parent->_unscheduled) {
|
||
|
$pageTypes[] = 'unscheduled';
|
||
|
}
|
||
|
if ($this->_parent->_scheduled) {
|
||
|
$pageTypes[] = 'scheduled';
|
||
|
}
|
||
|
if ($this->_parent->_archived) {
|
||
|
$pageTypes[] = 'archived';
|
||
|
}
|
||
|
$opString = implode('.', $pageTypes);
|
||
|
|
||
|
// get languages for later conversion
|
||
|
$languages = CRM_Core_I18n::languages();
|
||
|
|
||
|
foreach ($rows as $key => $row) {
|
||
|
$actionMask = NULL;
|
||
|
if ($row['sms_provider_id']) {
|
||
|
$actionLinks[CRM_Core_Action::PREVIEW]['url'] = 'civicrm/sms/send';
|
||
|
}
|
||
|
|
||
|
if (!($row['status'] == 'Not scheduled') && !$row['sms_provider_id']) {
|
||
|
if ($allAccess || $showCreateLinks) {
|
||
|
$actionMask = CRM_Core_Action::VIEW;
|
||
|
}
|
||
|
|
||
|
if (!in_array($row['id'], $searchMailings)) {
|
||
|
if ($allAccess || $showCreateLinks) {
|
||
|
$actionMask |= CRM_Core_Action::UPDATE;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
else {
|
||
|
if ($allAccess || ($showCreateLinks || $showScheduleLinks)) {
|
||
|
$actionMask = CRM_Core_Action::PREVIEW;
|
||
|
}
|
||
|
}
|
||
|
if (in_array($row['status'], array(
|
||
|
'Scheduled',
|
||
|
'Running',
|
||
|
'Paused',
|
||
|
))) {
|
||
|
if ($allAccess ||
|
||
|
($showApprovalLinks && $showCreateLinks && $showScheduleLinks)
|
||
|
) {
|
||
|
|
||
|
$actionMask |= CRM_Core_Action::DISABLE;
|
||
|
}
|
||
|
if ($row['status'] == 'Scheduled' &&
|
||
|
empty($row['approval_status_id'])
|
||
|
) {
|
||
|
if ($workFlow && ($allAccess || $showApprovalLinks)) {
|
||
|
$actionMask |= CRM_Core_Action::ENABLE;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if (in_array($row['status'], array('Complete', 'Canceled')) &&
|
||
|
!$row['archived']
|
||
|
) {
|
||
|
if ($allAccess || $showCreateLinks) {
|
||
|
$actionMask |= CRM_Core_Action::RENEW;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// check for delete permission.
|
||
|
if ($allowToDelete) {
|
||
|
$actionMask |= CRM_Core_Action::DELETE;
|
||
|
}
|
||
|
|
||
|
if ($actionMask == NULL) {
|
||
|
$actionMask = CRM_Core_Action::ADD;
|
||
|
}
|
||
|
// get status strings as per locale settings CRM-4411.
|
||
|
$rows[$key]['status'] = CRM_Mailing_BAO_MailingJob::status($row['status']);
|
||
|
|
||
|
// get language string
|
||
|
$rows[$key]['language'] = (isset($row['language']) ? $languages[$row['language']] : NULL);
|
||
|
|
||
|
$validLinks = $actionLinks;
|
||
|
if (($mailingUrl = CRM_Mailing_BAO_Mailing::getPublicViewUrl($row['id'])) != FALSE) {
|
||
|
$validLinks[] = array(
|
||
|
'name' => ts('Public View'),
|
||
|
'url' => 'civicrm/mailing/view',
|
||
|
'qs' => 'id=%%mid%%&reset=1',
|
||
|
'title' => ts('Public View'),
|
||
|
'fe' => TRUE,
|
||
|
);
|
||
|
}
|
||
|
|
||
|
$rows[$key]['action'] = CRM_Core_Action::formLink(
|
||
|
$validLinks,
|
||
|
$actionMask,
|
||
|
array('mid' => $row['id']),
|
||
|
"more",
|
||
|
FALSE,
|
||
|
$opString,
|
||
|
"Mailing",
|
||
|
$row['id']
|
||
|
);
|
||
|
|
||
|
// unset($rows[$key]['id']);
|
||
|
// if the scheduled date is 0, replace it with an empty string
|
||
|
if ($rows[$key]['scheduled_iso'] == '0000-00-00 00:00:00') {
|
||
|
$rows[$key]['scheduled'] = '';
|
||
|
}
|
||
|
unset($rows[$key]['scheduled_iso']);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// also initialize the AtoZ pager
|
||
|
$this->pagerAtoZ();
|
||
|
return $rows;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Name of export file.
|
||
|
*
|
||
|
* @param string $output
|
||
|
* Type of output.
|
||
|
*
|
||
|
* @return string
|
||
|
* name of the file
|
||
|
*/
|
||
|
public function getExportFileName($output = 'csv') {
|
||
|
return ts('CiviMail Mailings');
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param $parent
|
||
|
*/
|
||
|
public function setParent($parent) {
|
||
|
$this->_parent = $parent;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param array $params
|
||
|
* @param bool $sortBy
|
||
|
*
|
||
|
* @return int|string
|
||
|
*/
|
||
|
public function whereClause(&$params, $sortBy = TRUE) {
|
||
|
$values = $clauses = array();
|
||
|
$isFormSubmitted = $this->_parent->get('hidden_find_mailings');
|
||
|
|
||
|
$title = $this->_parent->get('mailing_name');
|
||
|
if ($title) {
|
||
|
$clauses[] = 'name LIKE %1';
|
||
|
if (strpos($title, '%') !== FALSE) {
|
||
|
$params[1] = array($title, 'String', FALSE);
|
||
|
}
|
||
|
else {
|
||
|
$params[1] = array($title, 'String', TRUE);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$dateClause1 = $dateClause2 = array();
|
||
|
$from = $this->_parent->get('mailing_from');
|
||
|
if (!CRM_Utils_System::isNull($from)) {
|
||
|
if ($this->_parent->get('unscheduled')) {
|
||
|
$dateClause1[] = 'civicrm_mailing.created_date >= %2';
|
||
|
}
|
||
|
else {
|
||
|
$dateClause1[] = 'civicrm_mailing_job.start_date >= %2';
|
||
|
$dateClause2[] = 'civicrm_mailing_job.scheduled_date >= %2';
|
||
|
}
|
||
|
$params[2] = array($from, 'String');
|
||
|
}
|
||
|
|
||
|
$to = $this->_parent->get('mailing_to');
|
||
|
if (!CRM_Utils_System::isNull($to)) {
|
||
|
if ($this->_parent->get('unscheduled')) {
|
||
|
$dateClause1[] = ' civicrm_mailing.created_date <= %3 ';
|
||
|
}
|
||
|
else {
|
||
|
$dateClause1[] = 'civicrm_mailing_job.start_date <= %3';
|
||
|
$dateClause2[] = 'civicrm_mailing_job.scheduled_date <= %3';
|
||
|
}
|
||
|
$params[3] = array($to, 'String');
|
||
|
}
|
||
|
|
||
|
$dateClauses = array();
|
||
|
if (!empty($dateClause1)) {
|
||
|
$dateClauses[] = implode(' AND ', $dateClause1);
|
||
|
}
|
||
|
if (!empty($dateClause2)) {
|
||
|
$dateClauses[] = implode(' AND ', $dateClause2);
|
||
|
}
|
||
|
$dateClauses = implode(' OR ', $dateClauses);
|
||
|
if (!empty($dateClauses)) {
|
||
|
$clauses[] = "({$dateClauses})";
|
||
|
}
|
||
|
|
||
|
if ($this->_parent->get('sms')) {
|
||
|
$clauses[] = "civicrm_mailing.sms_provider_id IS NOT NULL";
|
||
|
}
|
||
|
else {
|
||
|
$clauses[] = "civicrm_mailing.sms_provider_id IS NULL";
|
||
|
}
|
||
|
|
||
|
// get values submitted by form
|
||
|
$isDraft = $this->_parent->get('status_unscheduled');
|
||
|
$isArchived = $this->_parent->get('is_archived');
|
||
|
$mailingStatus = $this->_parent->get('mailing_status');
|
||
|
|
||
|
if (!$isFormSubmitted && $this->_parent->get('scheduled')) {
|
||
|
// mimic default behavior for scheduled screen
|
||
|
$isArchived = 0;
|
||
|
$mailingStatus = array('Scheduled' => 1, 'Complete' => 1, 'Running' => 1, 'Canceled' => 1);
|
||
|
}
|
||
|
if (!$isFormSubmitted && $this->_parent->get('archived')) {
|
||
|
// mimic default behavior for archived screen
|
||
|
$isArchived = 1;
|
||
|
}
|
||
|
if (!$isFormSubmitted && $this->_parent->get('unscheduled')) {
|
||
|
// mimic default behavior for draft screen
|
||
|
$isDraft = 1;
|
||
|
}
|
||
|
|
||
|
$statusClauses = array();
|
||
|
if ($isDraft) {
|
||
|
$statusClauses[] = "civicrm_mailing.scheduled_id IS NULL";
|
||
|
}
|
||
|
if (!empty($mailingStatus)) {
|
||
|
$statusClauses[] = "civicrm_mailing_job.status IN ('" . implode("', '", array_keys($mailingStatus)) . "')";
|
||
|
}
|
||
|
if (!empty($statusClauses)) {
|
||
|
$clauses[] = "(" . implode(' OR ', $statusClauses) . ")";
|
||
|
}
|
||
|
|
||
|
if (isset($isArchived)) {
|
||
|
if ($isArchived) {
|
||
|
$clauses[] = "civicrm_mailing.is_archived = 1";
|
||
|
}
|
||
|
else {
|
||
|
$clauses[] = "(civicrm_mailing.is_archived IS NULL OR civicrm_mailing.is_archived = 0)";
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if ($sortBy &&
|
||
|
$this->_parent->_sortByCharacter !== NULL
|
||
|
) {
|
||
|
$clauses[] = "name LIKE '" . strtolower(CRM_Core_DAO::escapeWildCardString($this->_parent->_sortByCharacter)) . "%'";
|
||
|
}
|
||
|
|
||
|
// dont do a the below assignement when doing a
|
||
|
// AtoZ pager clause
|
||
|
if ($sortBy) {
|
||
|
if (count($clauses) > 1) {
|
||
|
$this->_parent->assign('isSearch', 1);
|
||
|
}
|
||
|
else {
|
||
|
$this->_parent->assign('isSearch', 0);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$createOrSentBy = $this->_parent->get('sort_name');
|
||
|
if (!CRM_Utils_System::isNull($createOrSentBy)) {
|
||
|
$clauses[] = '(createdContact.sort_name LIKE %4 OR scheduledContact.sort_name LIKE %4)';
|
||
|
$params[4] = array('%' . $createOrSentBy . '%', 'String');
|
||
|
}
|
||
|
|
||
|
$createdId = $this->_parent->get('createdId');
|
||
|
if ($createdId) {
|
||
|
$clauses[] = "(created_id = {$createdId})";
|
||
|
$params[5] = array($createdId, 'Integer');
|
||
|
}
|
||
|
|
||
|
$campainIds = $this->_parent->get('campaign_id');
|
||
|
if (!CRM_Utils_System::isNull($campainIds)) {
|
||
|
if (!is_array($campainIds)) {
|
||
|
$campaignIds = array($campaignIds);
|
||
|
}
|
||
|
$clauses[] = '( campaign_id IN ( ' . implode(' , ', array_values($campainIds)) . ' ) )';
|
||
|
}
|
||
|
|
||
|
if ($language = $this->_parent->get('language')) {
|
||
|
$clauses[] = "civicrm_mailing.language = %6";
|
||
|
$params[6] = array($language, 'String');
|
||
|
}
|
||
|
|
||
|
if (empty($clauses)) {
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
return implode(' AND ', $clauses);
|
||
|
}
|
||
|
|
||
|
public function pagerAtoZ() {
|
||
|
|
||
|
$params = array();
|
||
|
$whereClause = $this->whereClause($params, FALSE);
|
||
|
|
||
|
$query = "
|
||
|
SELECT DISTINCT UPPER(LEFT(name, 1)) as sort_name
|
||
|
FROM civicrm_mailing
|
||
|
LEFT JOIN civicrm_mailing_job ON (civicrm_mailing_job.mailing_id = civicrm_mailing.id)
|
||
|
LEFT JOIN civicrm_contact createdContact ON ( civicrm_mailing.created_id = createdContact.id )
|
||
|
LEFT JOIN civicrm_contact scheduledContact ON ( civicrm_mailing.scheduled_id = scheduledContact.id )
|
||
|
WHERE $whereClause
|
||
|
ORDER BY UPPER(LEFT(name, 1))
|
||
|
";
|
||
|
|
||
|
$dao = CRM_Core_DAO::executeQuery($query, $params);
|
||
|
|
||
|
$aToZBar = CRM_Utils_PagerAToZ::getAToZBar($dao, $this->_parent->_sortByCharacter, TRUE);
|
||
|
$this->_parent->assign('aToZ', $aToZBar);
|
||
|
}
|
||
|
|
||
|
}
|