d10079637bee63319bb9ce85f5df669affb914fe
3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.7 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2015 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
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. |
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. |
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 +--------------------------------------------------------------------+
31 * @copyright CiviCRM LLC (c) 2004-2015
39 class CRM_SMS_Form_Schedule
extends CRM_Core_Form
{
42 * Set variables up before form is built.
46 public function preProcess() {
48 $this->_mailingID
= $this->get('mailing_id');
50 if (!$this->_mailingID
) {
51 $this->_mailingID
= CRM_Utils_Request
::retrieve('mid', 'Integer', $this, TRUE);
56 * Set default values for the form.
61 public function setDefaultValues() {
64 $count = $this->get('count');
66 $this->assign('count', $count);
72 * Build the form object for the last step of the sms wizard.
78 public function buildQuickform() {
79 $this->addDateTime('start_date', ts('Schedule SMS'), FALSE, array('formatType' => 'mailing'));
81 $this->addElement('checkbox', 'now', ts('Send Immediately'));
83 $this->addFormRule(array('CRM_SMS_Form_Schedule', 'formRule'), $this);
88 'name' => ts('Previous'),
92 'name' => ts('Submit Mass SMS'),
93 'spacing' => ' ',
95 'js' => array('onclick' => "return submitOnce(this,'" . $this->_name
. "','" . ts('Processing') . "');"),
99 'name' => ts('Continue Later'),
103 $this->addButtons($buttons);
106 $preview['type'] = CRM_Core_DAO
::getFieldValue('CRM_Mailing_DAO_Mailing', $this->_mailingID
, 'body_html') ?
'html' : 'text';
107 $preview['viewURL'] = CRM_Utils_System
::url('civicrm/mailing/view', "reset=1&id={$this->_mailingID}");
108 $this->assign_by_ref('preview', $preview);
112 * Form rule to validate the date selector and/or if we should deliver
115 * Warning: if you make changes here, be sure to also make them in
118 * @param array $params
125 * True if either we deliver immediately, or the date is properly
128 public static function formRule($params, $files, $self) {
129 if (!empty($params['_qf_Schedule_submit'])) {
131 CRM_Core_Session
::setStatus(ts("Your Mass SMS has been saved. Click the 'Continue' action to resume working on it."), ts('Saved'), 'success');
132 $url = CRM_Utils_System
::url('civicrm/mailing/browse/unscheduled', 'scheduled=false&reset=1&sms=1');
133 CRM_Utils_System
::redirect($url);
135 if (isset($params['now']) || CRM_Utils_Array
::value('_qf_Schedule_back', $params) == ts('Previous')) {
139 if (CRM_Utils_Date
::format(CRM_Utils_Date
::processDate($params['start_date'],
140 $params['start_date_time']
141 )) < CRM_Utils_Date
::format(date('YmdHi00'))
144 'start_date' => ts('Start date cannot be earlier than the current time.'),
151 * Process the posted form values. Create and schedule a Mass SMS.
157 public function postProcess() {
160 $params['mailing_id'] = $ids['mailing_id'] = $this->_mailingID
;
162 if (empty($params['mailing_id'])) {
163 CRM_Core_Error
::fatal(ts('Could not find a mailing id'));
166 foreach (array('now', 'start_date', 'start_date_time') as $parameter) {
167 $params[$parameter] = $this->controller
->exportValue($this->_name
, $parameter);
170 if ($params['now']) {
171 $params['scheduled_date'] = date('YmdHis');
174 $params['scheduled_date'] = CRM_Utils_Date
::processDate($params['start_date'] . ' ' . $params['start_date_time']);
177 $session = CRM_Core_Session
::singleton();
178 // set the scheduled_id
179 $params['scheduled_id'] = $session->get('userID');
180 $params['scheduled_date'] = date('YmdHis');
182 // set approval details if workflow is not enabled
183 if (!CRM_Mailing_Info
::workflowEnabled()) {
184 $params['approver_id'] = $session->get('userID');
185 $params['approval_date'] = date('YmdHis');
186 $params['approval_status_id'] = 1;
189 if ($params['now']) {
190 $params['scheduled_date'] = date('YmdHis');
193 $params['scheduled_date'] = CRM_Utils_Date
::processDate($params['start_date'] . ' ' . $params['start_date_time']);
196 /* Build the mailing object */
197 CRM_Mailing_BAO_Mailing
::create($params, $ids);
199 $session = CRM_Core_Session
::singleton();
200 $session->pushUserContext(CRM_Utils_System
::url('civicrm/mailing/browse/scheduled',
201 'reset=1&scheduled=true&sms=1'
206 * Display Name of the form.
211 public function getTitle() {
212 return ts('Schedule or Send');