Merge pull request #4981 from totten/master-cbf2
[civicrm-core.git] / CRM / Contact / Form / Task / Email.php
CommitLineData
6a488035
TO
1<?php
2/*
3 +--------------------------------------------------------------------+
39de6fd5 4 | CiviCRM version 4.6 |
6a488035 5 +--------------------------------------------------------------------+
06b69b18 6 | Copyright CiviCRM LLC (c) 2004-2014 |
6a488035
TO
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
9 | |
10 | CiviCRM is free software; you can copy, modify, and distribute it |
11 | under the terms of the GNU Affero General Public License |
12 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
13 | |
14 | CiviCRM is distributed in the hope that it will be useful, but |
15 | WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17 | See the GNU Affero General Public License for more details. |
18 | |
19 | You should have received a copy of the GNU Affero General Public |
20 | License and the CiviCRM Licensing Exception along |
21 | with this program; if not, contact CiviCRM LLC |
22 | at info[AT]civicrm[DOT]org. If you have questions about the |
23 | GNU Affero General Public License or the licensing of CiviCRM, |
24 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
25 +--------------------------------------------------------------------+
d25dd0ee 26 */
6a488035
TO
27
28/**
29 *
30 * @package CRM
06b69b18 31 * @copyright CiviCRM LLC (c) 2004-2014
6a488035
TO
32 * $Id$
33 *
34 */
35
36/**
37 * This class provides the functionality to email a group of
38 * contacts.
39 */
40class CRM_Contact_Form_Task_Email extends CRM_Contact_Form_Task {
41
42 /**
43 * Are we operating in "single mode", i.e. sending email to one
44 * specific contact?
45 *
46 * @var boolean
47 */
48 public $_single = FALSE;
49
50 /**
51 * Are we operating in "single mode", i.e. sending email to one
52 * specific contact?
53 *
54 * @var boolean
55 */
56 public $_noEmails = FALSE;
57
58 /**
100fef9d 59 * All the existing templates in the system
6a488035
TO
60 *
61 * @var array
62 */
63 public $_templates = NULL;
64
16947fa6 65 /**
100fef9d 66 * Store "to" contact details
16947fa6 67 * @var array
68 */
69 public $_toContactDetails = array();
70
71 /**
100fef9d 72 * Store all selected contact id's, that includes to, cc and bcc contacts
16947fa6 73 * @var array
74 */
75 public $_allContactIds = array();
76
77 /**
100fef9d 78 * Store only "to" contact ids
16947fa6 79 * @var array
80 */
81 public $_toContactIds = array();
82
83 /**
100fef9d 84 * Store only "cc" contact ids
16947fa6 85 * @var array
86 */
87 public $_ccContactIds = array();
88
89 /**
100fef9d 90 * Store only "bcc" contact ids
16947fa6 91 * @var array
92 */
93 public $_bccContactIds = array();
94
6a488035 95 /**
100fef9d 96 * Build all the data structures needed to build the form
6a488035
TO
97 *
98 * @return void
bbe69194 99 */
00be9182 100 public function preProcess() {
6a488035 101 // store case id if present
9cb404b4 102 $this->_caseId = CRM_Utils_Request::retrieve('caseid', 'String', $this, FALSE);
6a488035
TO
103 $this->_context = CRM_Utils_Request::retrieve('context', 'String', $this);
104
9cb404b4 105 $cid = CRM_Utils_Request::retrieve('cid', 'String', $this, FALSE);
8e4aa90c
CW
106
107 // Allow request to specify email id rather than contact id
108 $toEmailId = CRM_Utils_Request::retrieve('email_id', 'String', $this);
109 if ($toEmailId) {
110 $toEmail = civicrm_api('email', 'getsingle', array('version' => 3, 'id' => $toEmailId));
111 if (!empty($toEmail['email']) && !empty($toEmail['contact_id'])) {
112 $this->_toEmail = $toEmail;
113 }
114 if (!$cid) {
115 $cid = $toEmail['contact_id'];
116 $this->set('cid', $cid);
117 }
118 }
119
120 if ($cid) {
353ffa53 121 $cid = explode(',', $cid);
b3dbca23 122 $displayName = array();
9cb404b4 123
b3dbca23 124 foreach ($cid as $val) {
515f739d
M
125 $displayName[] = CRM_Contact_BAO_Contact::displayName($val);
126 }
6a488035 127
b3dbca23 128 CRM_Utils_System::setTitle(implode(',', $displayName) . ' - ' . ts('Email'));
515f739d 129 }
b3dbca23 130 else {
d75f2f47 131 CRM_Utils_System::setTitle(ts('New Email'));
515f739d 132 }
6a488035
TO
133 CRM_Contact_Form_Task_EmailCommon::preProcessFromAddress($this);
134
135 if (!$cid && $this->_context != 'standalone') {
136 parent::preProcess();
137 }
138
139 //early prevent, CRM-6209
140 if (count($this->_contactIds) > CRM_Contact_Form_Task_EmailCommon::MAX_EMAILS_KILL_SWITCH) {
141 CRM_Core_Error::statusBounce(ts('Please do not use this task to send a lot of emails (greater than %1). We recommend using CiviMail instead.', array(1 => CRM_Contact_Form_Task_EmailCommon::MAX_EMAILS_KILL_SWITCH)));
142 }
143
144 $this->assign('single', $this->_single);
145 if (CRM_Core_Permission::check('administer CiviCRM')) {
146 $this->assign('isAdmin', 1);
147 }
148 }
149
150 /**
c490a46a 151 * Build the form object
6a488035 152 *
6a488035
TO
153 *
154 * @return void
155 */
156 public function buildQuickForm() {
157 //enable form element
158 $this->assign('suppressForm', FALSE);
159 $this->assign('emailTask', TRUE);
160
161 CRM_Contact_Form_Task_EmailCommon::buildQuickForm($this);
162 }
163
164 /**
100fef9d 165 * Process the form after the input has been submitted and validated
6a488035 166 *
6a488035 167 *
355ba699 168 * @return void
6a488035
TO
169 */
170 public function postProcess() {
171 CRM_Contact_Form_Task_EmailCommon::postProcess($this);
172 }
96025800 173
6a488035 174}