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
33 class CRM_SMS_Form_Schedule
extends CRM_Core_Form
{
36 * Set variables up before form is built.
38 public function preProcess() {
40 $this->_mailingID
= $this->get('mailing_id');
42 if (!$this->_mailingID
) {
43 $this->_mailingID
= CRM_Utils_Request
::retrieve('mid', 'Integer', $this, TRUE);
48 * Set default values for the form.
50 public function setDefaultValues() {
53 $count = $this->get('count');
55 $this->assign('count', $count);
61 * Build the form object for the last step of the sms wizard.
63 public function buildQuickform() {
64 $this->addDateTime('start_date', ts('Schedule SMS'), FALSE, array('formatType' => 'mailing'));
66 $this->addElement('checkbox', 'now', ts('Send Immediately'));
68 $this->addFormRule(array('CRM_SMS_Form_Schedule', 'formRule'), $this);
73 'name' => ts('Previous'),
77 'name' => ts('Submit Mass SMS'),
78 'spacing' => ' ',
80 'js' => array('onclick' => "return submitOnce(this,'" . $this->_name
. "','" . ts('Processing') . "');"),
84 'name' => ts('Continue Later'),
88 $this->addButtons($buttons);
91 $preview['type'] = CRM_Core_DAO
::getFieldValue('CRM_Mailing_DAO_Mailing', $this->_mailingID
, 'body_html') ?
'html' : 'text';
92 $preview['viewURL'] = CRM_Utils_System
::url('civicrm/mailing/view', "reset=1&id={$this->_mailingID}");
93 $this->assign_by_ref('preview', $preview);
97 * Form rule to validate the date selector and/or if we should deliver
100 * Warning: if you make changes here, be sure to also make them in
103 * @param array $params
110 * True if either we deliver immediately, or the date is properly
113 public static function formRule($params, $files, $self) {
114 if (!empty($params['_qf_Schedule_submit'])) {
116 CRM_Core_Session
::setStatus(ts("Your Mass SMS has been saved. Click the 'Continue' action to resume working on it."), ts('Saved'), 'success');
117 $url = CRM_Utils_System
::url('civicrm/mailing/browse/unscheduled', 'scheduled=false&reset=1&sms=1');
118 CRM_Utils_System
::redirect($url);
120 if (isset($params['now']) || CRM_Utils_Array
::value('_qf_Schedule_back', $params) == ts('Previous')) {
124 if (CRM_Utils_Date
::format(CRM_Utils_Date
::processDate($params['start_date'],
125 $params['start_date_time']
126 )) < CRM_Utils_Date
::format(date('YmdHi00'))
129 'start_date' => ts('Start date cannot be earlier than the current time.'),
136 * Process the posted form values. Create and schedule a Mass SMS.
138 public function postProcess() {
141 $params['mailing_id'] = $ids['mailing_id'] = $this->_mailingID
;
143 if (empty($params['mailing_id'])) {
144 CRM_Core_Error
::fatal(ts('Could not find a mailing id'));
147 foreach (array('now', 'start_date', 'start_date_time') as $parameter) {
148 $params[$parameter] = $this->controller
->exportValue($this->_name
, $parameter);
151 if ($params['now']) {
152 $params['scheduled_date'] = date('YmdHis');
155 $params['scheduled_date'] = CRM_Utils_Date
::processDate($params['start_date'] . ' ' . $params['start_date_time']);
158 $session = CRM_Core_Session
::singleton();
159 // set the scheduled_id
160 $params['scheduled_id'] = $session->get('userID');
161 $params['scheduled_date'] = date('YmdHis');
163 // set approval details if workflow is not enabled
164 if (!CRM_Mailing_Info
::workflowEnabled()) {
165 $params['approver_id'] = $session->get('userID');
166 $params['approval_date'] = date('YmdHis');
167 $params['approval_status_id'] = 1;
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 // Build the mailing object.
178 CRM_Mailing_BAO_Mailing
::create($params, $ids);
180 $session = CRM_Core_Session
::singleton();
181 $session->pushUserContext(CRM_Utils_System
::url('civicrm/mailing/browse/scheduled',
182 'reset=1&scheduled=true&sms=1'
187 * Display Name of the form.
192 public function getTitle() {
193 return ts('Schedule or Send');