/*********************************************************************************
* SugarCRM Community Edition is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004-2012 SugarCRM Inc.
*
* This program is free software; you can redistribute it and/or modify it under
* the terms of the GNU Affero General Public License version 3 as published by the
* Free Software Foundation with the addition of the following permission added
* to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
* IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
* OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
*
* This program 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 along with
* this program; if not, see http://www.gnu.org/licenses or write to the Free
* Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
* 02110-1301 USA.
*
* You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
* SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
*
* The interactive user interfaces in modified source and object code versions
* of this program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU Affero General Public License version 3.
*
* In accordance with Section 7(b) of the GNU Affero General Public License version 3,
* these Appropriate Legal Notices must retain the display of the "Powered by
* SugarCRM" logo. If the display of the logo is not reasonably feasible for
* technical reasons, the Appropriate Legal Notices must display the words
* "Powered by SugarCRM".
********************************************************************************/
/**
* Time.js
*/
/*
* Time constructor
* @param time
* @param fieldname
* @param timeformat
* @param tabindex
*/
function Time (timeval, field, timeformat, tabindex) {
this.timeval = timeval;
if(typeof this.timeval == "undefined") {
this.datetime = "";
}
this.fieldname = field;
//Get hours and minutes and adjust as necessary
this.hrs = parseInt(timeval.substring(0,2), 10);
this.mins = parseInt(timeval.substring(3,5), 10);
//A safety scan to make sure hrs and minutes are formatted correctly
if (this.mins > 0 && this.mins < 15) {
this.mins = 15;
} else if (this.mins > 15 && this.mins < 30) {
this.mins = 30;
} else if (this.mins > 30 && this.mins < 45) {
this.mins = 45;
} else if (this.mins > 45) {
this.hrs += 1;
this.mins = 0;
} //if-else
this.timeformat = timeformat; //23:00 || 11:00
this.tabindex = tabindex == null || isNaN(tabindex) ? 1 : tabindex;
// Calculate other derived values
this.timeseparator = this.timeformat.substring(2,3);
this.has12Hours = /^11/.test(this.timeformat);
this.hasMeridiem = /am|pm/i.test(this.timeformat);
if(this.hasMeridiem) {
this.pm = /pm/.test(this.timeformat);
}
this.meridiem = this.hasMeridiem ? trim(this.timeval.substring(5)) : '';
}
/**
* html
* This function renders the HTML form elements for this widget
*/
Time.prototype.html = function(callback) {
//Now render the items
var text = ' ';
text += this.timeseparator;
text += '\n ';
if(this.hasMeridiem) {
text += '\n ';
text += '\n';
}
return text;
};
/**
* update
* This method handles events on the hour, minute and meridiem elements for the widget
*
*/
Time.prototype.update = function() {
id = this.fieldname + '_hours';
h = window.document.getElementById(id).value;
id = this.fieldname + '_minutes';
m = window.document.getElementById(id).value;
if(h == "" && m == "") {
document.getElementById(this.fieldname).value = "";
return;
}
newdate = h + this.timeseparator + m;
if(this.hasMeridiem) {
ampm = document.getElementById(this.fieldname + "_meridiem").value;
newdate += ampm;
}
document.getElementById(this.fieldname).value = newdate;
};