From e1ceb050e19c7574bca146a8da7047ee4ff456b5 Mon Sep 17 00:00:00 2001
From: Marius Burkard <m.burkard@pixcept.de>
Date: Sun, 10 Jul 2016 05:02:35 -0400
Subject: [PATCH] Merge branch 'stable-3.1'
---
interface/lib/classes/validate_autoresponder.inc.php | 47 ++++++++++++++++++++++++-----------------------
1 files changed, 24 insertions(+), 23 deletions(-)
diff --git a/interface/lib/classes/validate_autoresponder.inc.php b/interface/lib/classes/validate_autoresponder.inc.php
index c5e989e..98d49fd 100755
--- a/interface/lib/classes/validate_autoresponder.inc.php
+++ b/interface/lib/classes/validate_autoresponder.inc.php
@@ -27,41 +27,42 @@
EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
-include_once('validate_datetime.inc.php');
+include_once 'validate_datetime.inc.php';
-class validate_autoresponder extends validate_datetime
+class validate_autoresponder extends validate_datetime
{
function start_date($field_name, $field_value, $validator)
{
- # save field value for later use in end_date()
- $this->start_date = $field_value;
+ global $app;
- if ($this->_datetime_selected($field_value)) {
- # We just require a start date be set
- return;
- }
- if($_POST['autoresponder'] == 'y') {
- return "No start date selected";
+ // save field value for later use in end_date()
+ $this->start_date = $field_value;
+
+ if($_POST['autoresponder'] == 'y' && $field_value == '') {
+ // we need a start date when autoresponder is on
+ return $app->tform->lng($validator['errmsg']).'<br />';
}
}
-
+
function end_date($field_name, $field_value, $validator)
{
global $app;
-
+
$start_date = $this->start_date;
//$start_date = $app->tform_actions->dataRecord['autoresponder_start_date'];
- $_msg = $this->not_empty('autoresponder_start_date', $start_date, $validator);
- if (!$_msg) // Start date set
- {
- if ( !($_msg = $this->not_empty($field_name, $field_value, $validator)) ) // End date set
- {
- $validator['compare'] = $this->_get_timestamp_value($start_date);
- $_msg = $this->is_greater($field_name, $field_value, $validator);
- }
-
- return $_msg;
+ // Parse date
+ $start_date_array = date_parse_from_format($app->lng('conf_format_datetime'),$start_date);
+ $end_date_array = date_parse_from_format($app->lng('conf_format_datetime'),$field_value);
+
+ //calculate timestamps
+ $start_date_tstamp = mktime($start_date_array['hour'], $start_date_array['minute'], $start_date_array['second'], $start_date_array['month'], $start_date_array['day'], $start_date_array['year']);
+ $end_date_tstamp = mktime($end_date_array['hour'], $end_date_array['minute'], $end_date_array['second'], $end_date_array['month'], $end_date_array['day'], $end_date_array['year']);
+
+ // End date has to be > start date
+ if($end_date_tstamp <= $start_date_tstamp && ($start_date || $field_value)) {
+ return $app->tform->lng($validator['errmsg']).'<br />';
}
}
-}
\ No newline at end of file
+
+}
--
Gitblit v1.9.1