/********************************************************************************* * 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; };