/*********************************************************************************
* SugarCRM Community Edition is a customer relationship management program developed by
* SugarCRM, Inc. Copyright (C) 2004-2013 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".
********************************************************************************/
/**
* Namespace for Sugar Objects
*/
if (typeof(SUGAR) == "undefined") {
SUGAR = {
/**
* Creates a namespace if it doesn't exist and then returns it.
*
* Note: this implementation only creates a top-level namespace. Extend this function if
* multi-level namespaces are needed.
* @param ns
*/
namespace: function(ns) {
SUGAR[ns] = SUGAR[ns] || {};
return ((typeof SUGAR[ns] === "object") && (SUGAR[ns] !== null)) ? SUGAR[ns] : false;
},
/**
* Add properties of an object to target object.
* @param target
* @param obj
*/
append: function(target, obj) {
for (var prop in obj) {
if (obj[prop] !== void 0) target[prop] = obj[prop];
}
return target;
}
};
}
// Namespaces
SUGAR.namespace("themes");
SUGAR.namespace("tour");
/**
* Namespace for Homepage
*/
SUGAR.namespace("sugarHome");
/**
* Namespace for Subpanel Utils
*/
SUGAR.namespace("subpanelUtils");
/**
* AJAX status class
*/
SUGAR.namespace("ajaxStatusClass");
/**
* Tab selector utils
*/
SUGAR.namespace("tabChooser");
/**
* General namespace for Sugar utils
*/
SUGAR.namespace("utils");
SUGAR.namespace("savedViews");
/**
* Dashlet utils
*/
SUGAR.namespace("dashlets");
SUGAR.namespace("unifiedSearchAdvanced");
SUGAR.namespace("searchForm");
SUGAR.namespace("language");
SUGAR.namespace("Studio");
SUGAR.namespace("contextMenu");
SUGAR.namespace("config");
var nameIndex = 0;
var typeIndex = 1;
var requiredIndex = 2;
var msgIndex = 3;
var jstypeIndex = 5;
var minIndex = 10;
var maxIndex = 11;
var altMsgIndex = 15;
var compareToIndex = 7;
var arrIndex = 12;
var operatorIndex = 13;
var callbackIndex = 16;
var allowblank = 8;
var validate = new Array();
var maxHours = 24;
var requiredTxt = 'Missing Required Field:';
var invalidTxt = 'Invalid Value:';
var secondsSinceLoad = 0;
var alertsTimeoutId;
var inputsWithErrors = new Array();
var tabsWithErrors = new Array();
var lastSubmitTime = 0;
var alertList = new Array();
var oldStartsWith = '';
/**
* @deprecated
*
* As of Sugar version 6.2.3 (MSIE Version 9) this function is deprecated. The preferred method is to use the
* user agent check supplied by YUI to check for IE:
*
* for checking if a browser is IE in general : if(YAHOO.env.ua.ie) {...}
*
* or for checking specific versions: if (YAHOO.env.ua.ie >= 5.5 && YAHOO.env.ua.ie < 9) {...}
*
*/
function isSupportedIE() {
var userAgent = navigator.userAgent.toLowerCase() ;
// IE Check supports ActiveX controls
if (userAgent.indexOf("msie") != -1 && userAgent.indexOf("mac") == -1 && userAgent.indexOf("opera") == -1) {
var version = navigator.appVersion.match(/MSIE (.\..)/)[1] ;
if(version >= 5.5 && version < 10) {
return true;
} else {
return false;
}
}
}
function checkMinSupported(c, s) {
var current = c.split(".");
var supported = s.split(".");
for (var i in supported) {
if (current[i] && parseInt(current[i]) > parseInt(supported[i])) return true;
else if (current[i] && parseInt(current[i]) < parseInt(supported[i])) return false;
}
return true;
}
function checkMaxSupported(c, s) {
var current = c.split(".");
var supported = s.split(".");
for (var i in supported) {
if (current[i] && parseInt(current[i]) > parseInt(supported[i])) return false;
else if (current[i] && parseInt(current[i]) < parseInt(supported[i])) return true;
}
return true;
}
SUGAR.isSupportedBrowser = function(){
var supportedBrowsers = {
msie : {min:8, max:10}, // IE 8, 9, 10
safari : {min:534}, // Safari 5.1
mozilla : {min:17}, // Firefox 17
chrome : {min:537.13} // Chrome 24
};
var current = String($.browser.version);
var supported;
if ($.browser.msie){ // Internet Explorer
supported = supportedBrowsers['msie'];
}
else if ($.browser.mozilla) { // Firefox
supported = supportedBrowsers['mozilla'];
}
else {
$.browser.chrome = /chrome/.test(navigator.userAgent.toLowerCase());
if($.browser.chrome){ // Chrome
supported = supportedBrowsers['chrome'];
}
else if($.browser.safari){ // Safari
supported = supportedBrowsers['safari'];
}
}
if (current && supported)
return checkMinSupported(current, String(supported.min)) && (!supported.max || checkMaxSupported(current, String(supported.max)));
else
return false;
}
SUGAR.isIECompatibilityMode = function(){
var agentStr = navigator.userAgent;
var mode = false;
if (agentStr.indexOf("MSIE 7.0") > -1 &&
(agentStr.indexOf("Trident/5.0") > -1 || // IE9 Compatibility View
agentStr.indexOf("Trident/4.0") > -1 // IE8 Compatibility View
)
)
{
mode = true;
}
return mode;
}
SUGAR.isIE = isSupportedIE();
var isSafari = (navigator.userAgent.toLowerCase().indexOf('safari')!=-1);
// escapes regular expression characters
RegExp.escape = function(text) { // http://simon.incutio.com/archive/2006/01/20/escape
if (!arguments.callee.sRE) {
var specials = ['/', '.', '*', '+', '?', '|','(', ')', '[', ']', '{', '}', '\\'];
arguments.callee.sRE = new RegExp('(\\' + specials.join('|\\') + ')', 'g');
}
return text.replace(arguments.callee.sRE, '\\$1');
}
function addAlert(type, name,subtitle, description,time, redirect) {
var addIndex = alertList.length;
alertList[addIndex]= new Array();
alertList[addIndex]['name'] = name;
alertList[addIndex]['type'] = type;
alertList[addIndex]['subtitle'] = subtitle;
alertList[addIndex]['description'] = replaceHTMLChars(description.replace(/
/gi, "\n"));
alertList[addIndex]['time'] = time;
alertList[addIndex]['done'] = 0;
alertList[addIndex]['redirect'] = redirect;
}
function checkAlerts() {
secondsSinceLoad += 1;
var mj = 0;
var alertmsg = '';
for(mj = 0 ; mj < alertList.length; mj++) {
if(alertList[mj]['done'] == 0) {
if(alertList[mj]['time'] < secondsSinceLoad && alertList[mj]['time'] > -1 ) {
alertmsg = alertList[mj]['type'] + ":" + alertList[mj]['name'] + "\n" +alertList[mj]['subtitle']+ "\n"+ alertList[mj]['description'] + "\n\n";
alertList[mj]['done'] = 1;
if(alertList[mj]['redirect'] == '') {
alert(alertmsg);
}
else if(confirm(alertmsg)) {
window.location = alertList[mj]['redirect'];
}
}
}
}
alertsTimeoutId = setTimeout("checkAlerts()", 1000);
}
function toggleDisplay(id) {
if(this.document.getElementById(id).style.display == 'none') {
this.document.getElementById(id).style.display = '';
if(this.document.getElementById(id+"link") != undefined) {
this.document.getElementById(id+"link").style.display = 'none';
}
if(this.document.getElementById(id+"_anchor") != undefined)
this.document.getElementById(id+"_anchor").innerHTML='[ - ]';
}
else {
this.document.getElementById(id).style.display = 'none';
if(this.document.getElementById(id+"link") != undefined) {
this.document.getElementById(id+"link").style.display = '';
}
if(this.document.getElementById(id+"_anchor") != undefined)
this.document.getElementById(id+"_anchor").innerHTML='[+]';
}
}
function checkAll(form, field, value) {
for (i = 0; i < form.elements.length; i++) {
if(form.elements[i].name == field)
form.elements[i].checked = value;
}
}
function replaceAll(text, src, rep) {
offset = text.toLowerCase().indexOf(src.toLowerCase());
while(offset != -1) {
text = text.substring(0, offset) + rep + text.substring(offset + src.length ,text.length);
offset = text.indexOf( src, offset + rep.length + 1);
}
return text;
}
function addForm(formname) {
validate[formname] = new Array();
}
function addToValidate(formname, name, type, required, msg) {
if(typeof validate[formname] == 'undefined') {
addForm(formname);
}
validate[formname][validate[formname].length] = new Array(name, type,required, msg);
}
// Bug #47961 Callback validator definition
function addToValidateCallback(formname, name, type, required, msg, callback)
{
addToValidate(formname, name, type, required, msg);
var iIndex = validate[formname].length -1;
validate[formname][iIndex][jstypeIndex] = 'callback';
validate[formname][iIndex][callbackIndex] = callback;
}
function addToValidateRange(formname, name, type,required, msg,min,max) {
addToValidate(formname, name, type,required, msg);
validate[formname][validate[formname].length - 1][jstypeIndex] = 'range';
validate[formname][validate[formname].length - 1][minIndex] = min;
validate[formname][validate[formname].length - 1][maxIndex] = max;
}
function addToValidateIsValidDate(formname, name, type, required, msg) {
addToValidate(formname, name, type, required, msg);
validate[formname][validate[formname].length - 1][jstypeIndex] = 'date';
}
function addToValidateIsValidTime(formname, name, type, required, msg) {
addToValidate(formname, name, type, required, msg);
validate[formname][validate[formname].length - 1][jstypeIndex] = 'time';
}
function addToValidateDateBefore(formname, name, type, required, msg, compareTo) {
addToValidate(formname, name, type,required, msg);
validate[formname][validate[formname].length - 1][jstypeIndex] = 'isbefore';
validate[formname][validate[formname].length - 1][compareToIndex] = compareTo;
}
function addToValidateDateBeforeAllowBlank(formname, name, type, required, msg, compareTo, allowBlank) {
addToValidate(formname, name, type,required, msg);
validate[formname][validate[formname].length - 1][jstypeIndex] = 'isbefore';
validate[formname][validate[formname].length - 1][compareToIndex] = compareTo;
validate[formname][validate[formname].length - 1][allowblank] = allowBlank;
}
function addToValidateBinaryDependency(formname, name, type, required, msg, compareTo) {
addToValidate(formname, name, type, required, msg);
validate[formname][validate[formname].length - 1][jstypeIndex] = 'binarydep';
validate[formname][validate[formname].length - 1][compareToIndex] = compareTo;
}
function addToValidateComparison(formname, name, type, required, msg, compareTo) {
addToValidate(formname, name, type, required, msg);
validate[formname][validate[formname].length - 1][jstypeIndex] = 'comparison';
validate[formname][validate[formname].length - 1][compareToIndex] = compareTo;
}
function addToValidateIsInArray(formname, name, type, required, msg, arr, operator) {
addToValidate(formname, name, type, required, msg);
validate[formname][validate[formname].length - 1][jstypeIndex] = 'in_array';
validate[formname][validate[formname].length - 1][arrIndex] = arr;
validate[formname][validate[formname].length - 1][operatorIndex] = operator;
}
function addToValidateVerified(formname, name, type, required, msg, arr, operator) {
addToValidate(formname, name, type, required, msg);
validate[formname][validate[formname].length - 1][jstypeIndex] = 'verified';
}
function addToValidateLessThan(formname, name, type, required, msg, max, max_field_msg) {
addToValidate(formname, name, type, required, msg);
validate[formname][validate[formname].length - 1][jstypeIndex] = 'less';
validate[formname][validate[formname].length - 1][maxIndex] = max;
validate[formname][validate[formname].length - 1][altMsgIndex] = max_field_msg;
}
function addToValidateMoreThan(formname, name, type, required, msg, min) {
addToValidate(formname, name, type, required, msg);
validate[formname][validate[formname].length - 1][jstypeIndex] = 'more';
validate[formname][validate[formname].length - 1][minIndex] = min;
}
function removeFromValidate(formname, name) {
for(i = 0; i < validate[formname].length; i++)
{
if(validate[formname][i][nameIndex] == name)
{
validate[formname].splice(i--,1); // We subtract 1 from i since the slice removed an element, and we'll skip over the next item we scan
}
}
}
function checkValidate(formname, name) {
if(validate[formname]){
for(i = 0; i < validate[formname].length; i++){
if(validate[formname][i][nameIndex] == name){
return true;
}
}
}
return false;
}
var formsWithFieldLogic=null;
var formWithPrecision =null;
function addToValidateFieldLogic(formId,minFieldId, maxFieldId, defaultFieldId, lenFieldId,type,msg){
this.formId = document.getElementById(formId);
this.min=document.getElementById(minFieldId);
this.max= document.getElementById(maxFieldId);
this._default= document.getElementById(defaultFieldId);
this.len = document.getElementById(lenFieldId);
this.msg = msg;
this.type= type;
}
//@params: formid- Dom id of the form containing the precision and float fields
// valudId- Dom id of the field containing a float whose precision is to be checked.
// precisionId- Dom id of the field containing precision value.
function addToValidatePrecision(formId, valueId, precisionId){
this.form = document.getElementById(formId);
this.float = document.getElementById(valueId);
this.precision = document.getElementById(precisionId);
}
//function checkLength(value, referenceValue){
// return value
//}
function isValidPrecision(value, precision){
value = trim(value.toString());
if(precision == '')
return true;
if(value == '')
return true;
//#27021
if( (precision == "0") ){
if (value.indexOf(dec_sep)== -1){
return true;
}else{
return false;
}
}
//#27021 end
if(value.charAt(value.length-precision-1) == num_grp_sep){
if(value.substr(value.indexOf(dec_sep), 1)==dec_sep){
return false;
}
return true;
}
var actualPrecision = value.substr(value.indexOf(dec_sep)+1, value.length).length;
return actualPrecision == precision;
}
function toDecimal(original, precision) {
precision = (precision == null) ? 2 : precision;
num = Math.pow(10, precision);
temp = Math.round(original*num)/num;
if((temp * 100) % 100 == 0)
return temp + '.00';
if((temp * 10) % 10 == 0)
return temp + '0';
return temp
}
function isInteger(s) {
if(typeof num_grp_sep != 'undefined' && typeof dec_sep != 'undefined')
{
s = unformatNumberNoParse(s, num_grp_sep, dec_sep).toString();
}
return /^[+-]?[0-9]*$/.test(s) ;
}
function isDecimal(s) {
if (typeof s == "string" && s == "") // bug# 46530, this is required in order to
return true; // not check empty decimal fields
if(typeof num_grp_sep != 'undefined' && typeof dec_sep != 'undefined')
{
s = unformatNumberNoParse(s, num_grp_sep, dec_sep).toString();
}
return /^[+-]?[0-9]*\.?[0-9]*$/.test(s) ;
}
function isNumeric(s) {
return isDecimal(s);
}
if (typeof date_reg_positions != "object") var date_reg_positions = {'Y': 1,'m': 2,'d': 3};
if (typeof date_reg_format != "string") var date_reg_format = '([0-9]{4})-([0-9]{1,2})-([0-9]{1,2})';
function isDate(dtStr) {
if(dtStr.length== 0) {
return true;
}
// Check that we have numbers
myregexp = new RegExp(date_reg_format)
if(!myregexp.test(dtStr))
return false
m = '';
d = '';
y = '';
var dateParts = dtStr.match(date_reg_format);
for(key in date_reg_positions) {
index = date_reg_positions[key];
if(key == 'm') {
m = dateParts[index];
} else if(key == 'd') {
d = dateParts[index];
} else {
y = dateParts[index];
}
}
// Check that date is real
var dd = new Date(y,m,0);
// reject negative years
if (y < 1)
return false;
// reject month less than 1 and greater than 12
if (m > 12 || m < 1)
return false;
// reject days less than 1 or days not in month (e.g. February 30th)
if (d < 1 || d > dd.getDate())
return false;
return true;
}
function getDateObject(dtStr) {
if(dtStr.length== 0) {
return true;
}
myregexp = new RegExp(date_reg_format)
if(myregexp.exec(dtStr)) var dt = myregexp.exec(dtStr)
else return false;
var yr = dt[date_reg_positions['Y']];
var mh = dt[date_reg_positions['m']];
var dy = dt[date_reg_positions['d']];
var dtar = dtStr.split(' ');
if(typeof(dtar[1])!='undefined' && isTime(dtar[1])) {//if it is a timedate, we should make date1 to have time value
var t1 = dtar[1].replace(/am/i,' AM');
var t1 = t1.replace(/pm/i,' PM');
//bug #37977: where time format 23.00 causes java script error
t1=t1.replace(/\./, ':');
date1 = new Date(Date.parse(mh+'/'+dy+ '/'+yr+' '+t1));
}
else
{
var date1 = new Date();
date1.setFullYear(yr); // xxxx 4 char year
date1.setMonth(mh-1); // 0-11 Bug 4048: javascript Date obj months are 0-index
date1.setDate(dy); // 1-31
}
return date1;
}
function isBefore(value1, value2) {
var d1 = getDateObject(value1);
var d2 = getDateObject(value2);
if(typeof(d2)=='boolean') {// if d2 is not set, we should let it pass, the d2 may not need to be set. the empty check should not be done here.
return true;
}
return d2 >= d1;
}
function isValidEmail(emailStr) {
if(emailStr.length== 0) {
return true;
}
// cn: bug 7128, a period at the end of the string mangles checks. (switched to accept spaces and delimiters)
var lastChar = emailStr.charAt(emailStr.length - 1);
if(!lastChar.match(/[^\.]/i)) {
return false;
}
//bug 40068, According to rules in page 6 of http://www.apps.ietf.org/rfc/rfc3696.html#sec-3,
//first character of local part of an email address
//should not be a period i.e. '.'
var firstLocalChar=emailStr.charAt(0);
if(firstLocalChar.match(/\./)){
return false;
}
//bug 40068, According to rules in page 6 of http://www.apps.ietf.org/rfc/rfc3696.html#sec-3,
//last character of local part of an email address
//should not be a period i.e. '.'
var pos=emailStr.lastIndexOf("@");
var localPart = emailStr.substr(0, pos);
var lastLocalChar=localPart.charAt(localPart.length - 1);
if(lastLocalChar.match(/\./)){
return false;
}
var reg = /@.*?;/g;
var results;
while ((results = reg.exec(emailStr)) != null) {
var original = results[0];
parsedResult = results[0].replace(';', '::;::');
emailStr = emailStr.replace (original, parsedResult);
}
reg = /.@.*?,/g;
while ((results = reg.exec(emailStr)) != null) {
var original = results[0];
//Check if we were using ; as a delimiter. If so, skip the commas
if(original.indexOf("::;::") == -1) {
var parsedResult = results[0].replace(',', '::;::');
emailStr = emailStr.replace (original, parsedResult);
}
}
// mfh: bug 15010 - more practical implementation of RFC 2822 from http://www.regular-expressions.info/email.html, modifed to accept CAPITAL LETTERS
//if(!/[a-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+(?:\.[a-zA-Z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-zA-Z0-9](?:[a-zA-Z0-9-]*[a-zA-Z0-9])?\.)+[a-zA-Z0-9](?:[a-zA-Z0-9-]*[a-zA-Z0-9])?/.test(emailStr))
// return false
//bug 40068, According to rules in page 6 of http://www.apps.ietf.org/rfc/rfc3696.html#sec-3,
//allowed special characters ! # $ % & ' * + - / = ? ^ _ ` . { | } ~ in local part
var emailArr = emailStr.split(/::;::/);
for (var i = 0; i < emailArr.length; i++) {
var emailAddress = emailArr[i];
if (trim(emailAddress) != '') {
if(!/^\s*[\w.%+\-&'#!\$\*=\?\^_`\{\}~\/]+@([A-Z0-9-]+\.)*[A-Z0-9-]+\.[\w-]{2,}\s*$/i.test(emailAddress) &&
!/^.*<[A-Z0-9._%+\-&'#!\$\*=\?\^_`\{\}~]+?@([A-Z0-9-]+\.)*[A-Z0-9-]+\.[\w-]{2,}>\s*$/i.test(emailAddress)) {
return false;
} // if
}
} // for
return true;
}
function isValidPhone(phoneStr) {
if(phoneStr.length== 0) {
return true;
}
if(!/^[0-9\-\(\)\s]+$/.test(phoneStr))
return false
return true
}
function isFloat(floatStr) {
if(floatStr.length== 0) {
return true;
}
if(!(typeof(num_grp_sep)=='undefined' || typeof(dec_sep)=='undefined')) {
floatStr = unformatNumberNoParse(floatStr, num_grp_sep, dec_sep).toString();
}
return /^(-)?[0-9\.]+$/.test(floatStr);
}
function isDBName(str) {
if(str.length== 0) {
return true;
}
// must start with a letter
if(!/^[a-zA-Z][a-zA-Z\_0-9]*$/.test(str))
return false
return true
}
var time_reg_format = "[0-9]{1,2}\:[0-9]{2}";
function isTime(timeStr) {
var timeRegex = time_reg_format;
// eliminate the am/pm from the external time_reg_format
timeRegex = timeRegex.replace(/[ ]*\([^)]*m\)/i, '');
if(timeStr.length== 0){
return true;
}
//we now support multiple time formats
myregexp = new RegExp(timeRegex);
if(!myregexp.test(timeStr)) {
return false;
}
return true;
}
function inRange(value, min, max) {
if (typeof num_grp_sep != 'undefined' && typeof dec_sep != 'undefined')
value = unformatNumberNoParse(value, num_grp_sep, dec_sep).toString();
var result = true;
if (typeof min == 'number' && value < min)
{
result = false;
}
if (typeof max == 'number' && value > max)
{
result = false;
}
return result;
}
function bothExist(item1, item2) {
if(typeof item1 == 'undefined') { return false; }
if(typeof item2 == 'undefined') { return false; }
if((item1 == '' && item2 != '') || (item1 != '' && item2 == '') ) { return false; }
return true;
}
trim = YAHOO.lang.trim;
function check_form(formname) {
if (typeof(siw) != 'undefined' && siw
&& typeof(siw.selectingSomething) != 'undefined' && siw.selectingSomething)
return false;
return validate_form(formname, '');
}
function add_error_style(formname, input, txt, flash) {
var raiseFlag = false;
if (typeof flash == "undefined")
flash = true;
try {
inputHandle = typeof input == "object" ? input : document.forms[formname][input];
style = get_current_bgcolor(inputHandle);
// strip off the colon at the end of the warning strings
if ( txt.substring(txt.length-1) == ':' )
txt = txt.substring(0,txt.length-1)
// Bug 28249 - To help avoid duplicate messages for an element, strip off extra messages and
// match on the field name itself
requiredTxt = SUGAR.language.get('app_strings', 'ERR_MISSING_REQUIRED_FIELDS');
invalidTxt = SUGAR.language.get('app_strings', 'ERR_INVALID_VALUE');
nomatchTxt = SUGAR.language.get('app_strings', 'ERR_SQS_NO_MATCH_FIELD');
matchTxt = txt.replace(requiredTxt,'').replace(invalidTxt,'').replace(nomatchTxt,'');
YUI().use('node', function (Y) {
Y.one(inputHandle).get('parentNode').get('children').each(function(node, index, nodeList){
if(node.hasClass('validation-message') && node.get('text').search(matchTxt)){
raiseFlag = true;
}
});
});
if(!raiseFlag) {
errorTextNode = document.createElement('div');
errorTextNode.className = 'required validation-message';
errorTextNode.innerHTML = txt;
if ( inputHandle.parentNode.className.indexOf('x-form-field-wrap') != -1 ) {
inputHandle.parentNode.parentNode.appendChild(errorTextNode);
}
else {
inputHandle.parentNode.appendChild(errorTextNode);
}
if (flash)
inputHandle.style.backgroundColor = "#FF0000";
inputsWithErrors.push(inputHandle);
}
if (flash)
{
// We only need to setup the flashy-flashy on the first entry, it loops through all fields automatically
if ( inputsWithErrors.length == 1 ) {
for(var wp = 1; wp <= 10; wp++) {
window.setTimeout('fade_error_style(style, '+wp*10+')',1000+(wp*50));
}
}
if(typeof (window[formname + "_tabs"]) != "undefined") {
var tabView = window[formname + "_tabs"];
var parentDiv = YAHOO.util.Dom.getAncestorByTagName(inputHandle, "div");
if ( tabView.get ) {
var tabs = tabView.get("tabs");
for (var i in tabs) {
if (tabs[i].get("contentEl") == parentDiv
|| YAHOO.util.Dom.isAncestor(tabs[i].get("contentEl"), inputHandle))
{
tabs[i].get("labelEl").style.color = "red";
if ( inputsWithErrors.length == 1 )
tabView.selectTab(i);
}
}
}
}
window.setTimeout("inputsWithErrors[" + (inputsWithErrors.length - 1) + "].style.backgroundColor = '';", 2000);
}
} catch ( e ) {
// Catch errors here so we don't allow an incomplete record through the javascript validation
}
}
/**
* removes all error messages for the current form
*/
function clear_all_errors() {
for(var wp = 0; wp < inputsWithErrors.length; wp++) {
if(typeof(inputsWithErrors[wp]) !='undefined' && typeof inputsWithErrors[wp].parentNode != 'undefined' && inputsWithErrors[wp].parentNode != null) {
if ( inputsWithErrors[wp].parentNode.className.indexOf('x-form-field-wrap') != -1 )
{
inputsWithErrors[wp].parentNode.parentNode.removeChild(inputsWithErrors[wp].parentNode.parentNode.lastChild);
}
else
{
inputsWithErrors[wp].parentNode.removeChild(inputsWithErrors[wp].parentNode.lastChild);
}
}
}
if (inputsWithErrors.length == 0) return;
if ( YAHOO.util.Dom.getAncestorByTagName(inputsWithErrors[0], "form") ) {
var formname = YAHOO.util.Dom.getAncestorByTagName(inputsWithErrors[0], "form").getAttribute("name");
if(typeof (window[formname + "_tabs"]) != "undefined") {
var tabView = window[formname + "_tabs"];
if ( tabView.get ) {
var tabs = tabView.get("tabs");
for (var i in tabs) {
if (typeof tabs[i] == "object")
tabs[i].get("labelEl").style.color = "";
}
}
}
inputsWithErrors = new Array();
}
}
function get_current_bgcolor(input) {
if(input.currentStyle) {// ie
style = input.currentStyle.backgroundColor;
return style.substring(1,7);
}
else {// moz
style = '';
styleRGB = document.defaultView.getComputedStyle(input, '').getPropertyValue("background-color");
comma = styleRGB.indexOf(',');
style += dec2hex(styleRGB.substring(4, comma));
commaPrevious = comma;
comma = styleRGB.indexOf(',', commaPrevious+1);
style += dec2hex(styleRGB.substring(commaPrevious+2, comma));
style += dec2hex(styleRGB.substring(comma+2, styleRGB.lastIndexOf(')')));
return style;
}
}
function hex2dec(hex){return(parseInt(hex,16));}
var hexDigit=new Array("0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F");
function dec2hex(dec){return(hexDigit[dec>>4]+hexDigit[dec&15]);}
function fade_error_style(normalStyle, percent) {
errorStyle = 'c60c30';
var r1 = hex2dec(errorStyle.slice(0,2));
var g1 = hex2dec(errorStyle.slice(2,4));
var b1 = hex2dec(errorStyle.slice(4,6));
var r2 = hex2dec(normalStyle.slice(0,2));
var g2 = hex2dec(normalStyle.slice(2,4));
var b2 = hex2dec(normalStyle.slice(4,6));
var pc = percent / 100;
r= Math.floor(r1+(pc*(r2-r1)) + .5);
g= Math.floor(g1+(pc*(g2-g1)) + .5);
b= Math.floor(b1+(pc*(b2-b1)) + .5);
for(var wp = 0; wp < inputsWithErrors.length; wp++) {
inputsWithErrors[wp].style.backgroundColor = "#" + dec2hex(r) + dec2hex(g) + dec2hex(b);
}
}
function isFieldTypeExceptFromEmptyCheck(fieldType)
{
var results = false;
var exemptList = ['bool','file'];
for(var i=0;imaximum) {
isError = true;
add_error_style(formname, validate[formname][i][nameIndex], validate[formname][i][msgIndex] +" " +SUGAR.language.get('app_strings', 'MSG_IS_MORE_THAN')+ ' ' + validate[formname][i][altMsgIndex]);
}
}
break;
case 'more':
value=unformatNumber(trim(form[validate[formname][i][nameIndex]].value), num_grp_sep, dec_sep);
minimum = parseFloat(validate[formname][i][minIndex]);
if( typeof minimum != 'undefined'){
if(value showErrorsOn.len.obj){
invalidLogic=true;
showErrorsOn[i].show=true;
showErrorsOn.len.show=true;
}
}
if(min!='undef' && max!='undef' && _default!='undef'){
if(!inRange(_default,min,max)){
invalidLogic=true;
showErrorsOn.min.show=true;
showErrorsOn.max.show=true;
showErrorsOn._default.show=true;
}
}
if(min!='undef' && max!= 'undef' && min > max){
invalidLogic = true;
showErrorsOn.min.show=true;
showErrorsOn.max.show=true;
}
if(min!='undef' && _default!='undef' && _default < min){
invalidLogic = true;
showErrorsOn.min.show=true;
showErrorsOn._default.show=true;
}
if(max!='undef' && _default !='undef' && _default>max){
invalidLogic = true;
showErrorsOn.max.show=true;
showErrorsOn._default.show=true;
}
if(invalidLogic){
isError=true;
for(var error in showErrorsOn)
if(showErrorsOn[error].show)
add_error_style(formname,showErrorsOn[error].value, formsWithFieldLogic.msg);
}
else if (!isError)
formsWithFieldLogic = null;
}
}
if(formWithPrecision){
if (!isValidPrecision(formWithPrecision.float.value, formWithPrecision.precision.value)){
isError = true;
add_error_style(formname, 'default', SUGAR.language.get('app_strings', 'ERR_COMPATIBLE_PRECISION_VALUE'));
}else if(!isError){
isError = false;
}
}
//END BUG# 15102
if (isError == true) {
var nw, ne, sw, se;
if (self.pageYOffset) // all except Explorer
{
nwX = self.pageXOffset;
seX = self.innerWidth;
nwY = self.pageYOffset;
seY = self.innerHeight;
}
else if (document.documentElement && document.documentElement.scrollTop) // Explorer 6 Strict
{
nwX = document.documentElement.scrollLeft;
seX = document.documentElement.clientWidth;
nwY = document.documentElement.scrollTop;
seY = document.documentElement.clientHeight;
}
else if (document.body) // all other Explorers
{
nwX = document.body.scrollLeft;
seX = document.body.clientWidth;
nwY = document.body.scrollTop;
seY = document.body.clientHeight;
}
var inView = true; // is there an error within viewport of browser
for(var wp = 0; wp < inputsWithErrors.length; wp++) {
var elementCoor = findElementPos(inputsWithErrors[wp]);
if(!(elementCoor.x >= nwX && elementCoor.y >= nwY &&
elementCoor.x <= seX+nwX && elementCoor.y <= seY+nwY)) { // if input is not within viewport, modify for SI bug 52497
inView = false;
scrollToTop = elementCoor.y - 75;
scrollToLeft = elementCoor.x - 75;
}
else { // on first input within viewport, don't scroll
break;
}
}
if(!inView) window.scrollTo(scrollToLeft,scrollToTop);
return false;
}
disableOnUnloadEditView(form);
return true;
}
/**
* This array is used to remember mark status of rows in browse mode
*/
var marked_row = new Array;
/**
* Sets/unsets the pointer and marker in browse mode
*
* @param object the table row
* @param interger the row number
* @param string the action calling this script (over, out or click)
* @param string the default background color
* @param string the color to use for mouseover
* @param string the color to use for marking a row
*
* @return boolean whether pointer is set or not
*/
function setPointer(theRow, theRowNum, theAction, theDefaultColor, thePointerColor, theMarkColor) {
var theCells = null;
// 1. Pointer and mark feature are disabled or the browser can't get the
// row -> exits
if ((thePointerColor == '' && theMarkColor == '')
|| typeof(theRow.style) == 'undefined') {
return false;
}
// 2. Gets the current row and exits if the browser can't get it
if (typeof(document.getElementsByTagName) != 'undefined') {
theCells = theRow.getElementsByTagName('td');
}
else if (typeof(theRow.cells) != 'undefined') {
theCells = theRow.cells;
}
else {
return false;
}
// 3. Gets the current color...
var rowCellsCnt = theCells.length;
var domDetect = null;
var currentColor = null;
var newColor = null;
// 3.1 ... with DOM compatible browsers except Opera that does not return
// valid values with "getAttribute"
if (typeof(window.opera) == 'undefined'
&& typeof(theCells[0].getAttribute) != 'undefined') {
currentColor = theCells[0].getAttribute('bgcolor');
domDetect = true;
}
// 3.2 ... with other browsers
else {
currentColor = theCells[0].style.backgroundColor;
domDetect = false;
} // end 3
// 4. Defines the new color
// 4.1 Current color is the default one
if (currentColor == ''
|| (currentColor!= null && (currentColor.toLowerCase() == theDefaultColor.toLowerCase()))) {
if (theAction == 'over' && thePointerColor != '') {
newColor = thePointerColor;
}
else if (theAction == 'click' && theMarkColor != '') {
newColor = theMarkColor;
marked_row[theRowNum] = true;
}
}
// 4.1.2 Current color is the pointer one
else if (currentColor!= null && (currentColor.toLowerCase() == thePointerColor.toLowerCase())
&& (typeof(marked_row[theRowNum]) == 'undefined' || !marked_row[theRowNum])) {
if (theAction == 'out') {
newColor = theDefaultColor;
}
else if (theAction == 'click' && theMarkColor != '') {
newColor = theMarkColor;
marked_row[theRowNum] = true;
}
}
// 4.1.3 Current color is the marker one
else if (currentColor!= null && (currentColor.toLowerCase() == theMarkColor.toLowerCase())) {
if (theAction == 'click') {
newColor = (thePointerColor != '')
? thePointerColor
: theDefaultColor;
marked_row[theRowNum] = (typeof(marked_row[theRowNum]) == 'undefined' || !marked_row[theRowNum])
? true
: null;
}
} // end 4
// 5. Sets the new color...
if (newColor) {
var c = null;
// 5.1 ... with DOM compatible browsers except Opera
if (domDetect) {
for (c = 0; c < rowCellsCnt; c++) {
theCells[c].setAttribute('bgcolor', newColor, 0);
} // end for
}
// 5.2 ... with other browsers
else {
for (c = 0; c < rowCellsCnt; c++) {
theCells[c].style.backgroundColor = newColor;
}
}
} // end 5
return true;
} // end of the 'setPointer()' function
/**
* listbox redirection
*/
function goToUrl(selObj, goToLocation) {
eval("document.location.href = '" + goToLocation + "pos=" + selObj.options[selObj.selectedIndex].value + "'");
}
var json_objects = new Object();
function getXMLHTTPinstance() {
var xmlhttp = false;
var userAgent = navigator.userAgent.toLowerCase() ;
// IE Check supports ActiveX controls
if (userAgent.indexOf("msie") != -1 && userAgent.indexOf("mac") == -1 && userAgent.indexOf("opera") == -1) {
var version = navigator.appVersion.match(/MSIE (.\..)/)[1] ;
if(version >= 5.5 ) {
try {
xmlhttp = new ActiveXObject("Msxml2.XMLHTTP");
}
catch (e) {
try {
xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
}
catch (E) {
xmlhttp = false;
}
}
}
}
if (!xmlhttp && typeof XMLHttpRequest!='undefined') {
xmlhttp = new XMLHttpRequest();
}
return xmlhttp;
}
// NOW LOAD THE OBJECT..
var global_xmlhttp = getXMLHTTPinstance();
function http_fetch_sync(url,post_data) {
global_xmlhttp = getXMLHTTPinstance();
var method = 'GET';
if(typeof(post_data) != 'undefined') method = 'POST';
try {
global_xmlhttp.open(method, url,false);
}
catch(e) {
alert('message:'+e.message+":url:"+url);
}
if(method == 'POST') {
global_xmlhttp.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
}
global_xmlhttp.send(post_data);
if (SUGAR.util.isLoginPage(global_xmlhttp.responseText))
return false;
var args = {"responseText" : global_xmlhttp.responseText,
"responseXML" : global_xmlhttp.responseXML,
"request_id" : typeof(request_id) != "undefined" ? request_id : 0};
return args;
}
// this is a GET unless post_data is defined
function http_fetch_async(url,callback,request_id,post_data) {
var method = 'GET';
if(typeof(post_data) != 'undefined') {
method = 'POST';
}
try {
global_xmlhttp.open(method, url,true);
}
catch(e) {
alert('message:'+e.message+":url:"+url);
}
if(method == 'POST') {
global_xmlhttp.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
}
global_xmlhttp.onreadystatechange = function() {
if(global_xmlhttp.readyState==4) {
if(global_xmlhttp.status == 200) {
if (SUGAR.util.isLoginPage(global_xmlhttp.responseText))
return false;
var args = {"responseText" : global_xmlhttp.responseText,
"responseXML" : global_xmlhttp.responseXML,
"request_id" : request_id };
callback.call(document,args);
}
else {
alert("There was a problem retrieving the XML data:\n" + global_xmlhttp.statusText);
}
}
}
global_xmlhttp.send(post_data);
}
function insert_at_cursor(field, value) {
//ie:
if (document.selection) {
field.focus();
sel = document.selection.createRange();
sel.text = value;
}
//mozilla:
else if(field.selectionStart || field.selectionStart == '0') {
var start_pos = field.selectionStart;
var end_pos = field.selectionEnd;
field.value = field.value.substring(0, start_pos) + value + field.value.substring(end_pos, field.value.length);
}
else {
field.value += value;
}
}
function checkParentType(type,button) {
if(button == null) {
return;
}
if(typeof disabledModules != 'undefined' && typeof(disabledModules[type]) != 'undefined') {
button.disabled='disabled';
}
else {
button.disabled = false;
}
}
function parseDate(input, format) {
date = input.value;
format = format.replace(/%/g, '');
sep = format.charAt(1);
yAt = format.indexOf('Y')
// 1-1-06 or 1-12-06 or 1-1-2006 or 1-12-2006
if(date.match(/^\d{1,2}[\/-]\d{1,2}[\/-]\d{2,4}$/) && yAt == 4) {
if(date.match(/^\d{1}[\/-].*$/)) date = '0' + date;
if(date.match(/^\d{2}[\/-]\d{1}[\/-].*$/)) date = date.substring(0,3) + '0' + date.substring(3,date.length);
if(date.match(/^\d{2}[\/-]\d{2}[\/-]\d{2}$/)) date = date.substring(0,6) + '20' + date.substring(6,date.length);
}
// 06-11-1 or 06-1-1
else if(date.match(/^\d{2,4}[\/-]\d{1,2}[\/-]\d{1,2}$/)) {
if(date.match(/^\d{2}[\/-].*$/)) date = '20' + date;
if(date.match(/^\d{4}[\/-]\d{1}[\/-].*$/)) date = date.substring(0,5) + '0' + date.substring(5,date.length);
if(date.match(/^\d{4}[\/-]\d{2}[\/-]\d{1}$/)) date = date.substring(0,8) + '0' + date.substring(8,date.length);
}
else if(date.match(/^\d{4,8}$/)) { // digits only
digits = 0;
if(date.match(/^\d{8}$/)) digits = 8;// match for 8 digits
else if(date.match(/\d{6}/)) digits = 6;// match for 5 digits
else if(date.match(/\d{4}/)) digits = 4;// match for 5 digits
else if(date.match(/\d{5}/)) digits = 5;// match for 5 digits
switch(yAt) {
case 0:
switch(digits) {
case 4: date = '20' + date.substring(0,2) + sep + '0' + date.substring(2, 3) + sep + '0' + date.substring(3,4); break;
case 5: date = '20' + date.substring(0,2) + sep + date.substring(2, 4) + sep + '0' + date.substring(4,5); break;
case 6: date = '20' + date.substring(0,2) + sep + date.substring(2, 4) + sep + date.substring(4,6); break;
case 8: date = date.substring(0,4) + sep + date.substring(4, 6) + sep + date.substring(6,8); break;
}
break;
case 2:
switch(digits) {
case 4: date = '0' + date.substring(0,1) + sep + '20' + date.substring(1, 3) + sep + '0' + date.substring(3,4); break;
case 5: date = date.substring(0,2) + sep + '20' + date.substring(2, 4) + sep + '0' + date.substring(4,5); break;
case 6: date = date.substring(0,2) + sep + '20' + date.substring(2, 4) + sep + date.substring(4,6); break;
case 8: date = date.substring(0,2) + sep + date.substring(2, 6) + sep + date.substring(6,8); break;
}
case 4:
switch(digits) {
case 4: date = '0' + date.substring(0,1) + sep + '0' + date.substring(1, 2) + sep + '20' + date.substring(2,4); break;
case 5: date = '0' + date.substring(0,1) + sep + date.substring(1, 3) + sep + '20' + date.substring(3,5); break;
case 6: date = date.substring(0,2) + sep + date.substring(2, 4) + sep + '20' + date.substring(4,6); break;
case 8: date = date.substring(0,2) + sep + date.substring(2, 4) + sep + date.substring(4,8); break;
}
break;
}
}
date = date.replace(/[\/-]/g, sep);
input.value = date;
}
// find obj's position
function findElementPos(obj) {
var x = 0;
var y = 0;
if (obj.offsetParent) {
while (obj.offsetParent) {
x += obj.offsetLeft;
y += obj.offsetTop;
obj = obj.offsetParent;
}
}//if offsetParent exists
else if (obj.x && obj.y) {
y += obj.y
x += obj.x
}
return new coordinate(x, y);
}//findElementPos
// get dimensions of the browser window
function getClientDim() {
var nwX, nwY, seX, seY;
if (self.pageYOffset) // all except Explorer
{
nwX = self.pageXOffset;
seX = self.innerWidth + nwX;
nwY = self.pageYOffset;
seY = self.innerHeight + nwY;
}
else if (document.documentElement && document.documentElement.scrollTop) // Explorer 6 Strict
{
nwX = document.documentElement.scrollLeft;
seX = document.documentElement.clientWidth + nwX;
nwY = document.documentElement.scrollTop;
seY = document.documentElement.clientHeight + nwY;
}
else if (document.body) // all other Explorers
{
nwX = document.body.scrollLeft;
seX = document.body.clientWidth + nwX;
nwY = document.body.scrollTop;
seY = document.body.clientHeight + nwY;
}
return {'nw' : new coordinate(nwX, nwY), 'se' : new coordinate(seX, seY)};
}
/**
* stop propagation on events
**/
function freezeEvent(e) {
if(e) {
if (e.preventDefault) e.preventDefault();
e.returnValue = false;
e.cancelBubble = true;
if (e.stopPropagation) e.stopPropagation();
return false;
}
}
/**
* coordinate class
**/
function coordinate(_x, _y) {
var x = _x;
var y = _y;
this.add = add;
this.sub = sub;
this.x = x;
this.y = y;
function add(rh) {
return new position(this.x + rh.x, this.y + rh.y);
}
function sub(rh) {
return new position(this.x + rh.x, this.y + rh.y);
}
}
// sends theForm via AJAX and fills in the theDiv
function sendAndRetrieve(theForm, theDiv, loadingStr) {
function success(data) {
document.getElementById(theDiv).innerHTML = data.responseText;
ajaxStatus.hideStatus();
}
if(typeof loadingStr == 'undefined') SUGAR.language.get('app_strings', 'LBL_LOADING');
ajaxStatus.showStatus(loadingStr);
oForm = new YAHOO.util.Element(theForm);
if ( oForm.get('enctype') && oForm.get('enctype') == 'multipart/form-data' ) {
// the second argument is true to indicate file upload.
YAHOO.util.Connect.setForm(theForm, true);
var cObj = YAHOO.util.Connect.asyncRequest('POST', 'index.php', {upload: success, failure: success});
} else {
YAHOO.util.Connect.setForm(theForm);
var cObj = YAHOO.util.Connect.asyncRequest('POST', 'index.php', {success: success, failure: success});
}
return false;
}
//save the form and redirect
function sendAndRedirect(theForm, loadingStr, redirect_location) {
function success(data) {
if(redirect_location){
location.href=redirect_location;
}
ajaxStatus.hideStatus();
}
if(typeof loadingStr == 'undefined') SUGAR.language.get('app_strings', 'LBL_LOADING');
ajaxStatus.showStatus(loadingStr);
oForm = new YAHOO.util.Element(theForm);
if ( oForm.get('enctype') && oForm.get('enctype') == 'multipart/form-data' ) {
// the second argument is true to indicate file upload.
YAHOO.util.Connect.setForm(theForm, true);
var cObj = YAHOO.util.Connect.asyncRequest('POST', 'index.php', {upload: success, failure: success});
} else {
YAHOO.util.Connect.setForm(theForm);
var cObj = YAHOO.util.Connect.asyncRequest('POST', 'index.php', {success: success, failure: success});
}
return false;
}
function saveForm(theForm, theDiv, loadingStr) {
if(check_form(theForm)){
for(i = 0; i < ajaxFormArray.length; i++){
if(ajaxFormArray[i] == theForm){
ajaxFormArray.splice(i, 1);
}
}
return sendAndRetrieve(theForm, loadingStr, theDiv);
}
else
return false;
}
// Builds a "snapshot" of the form, so we can use it to see if someone has changed it.
function snapshotForm(theForm) {
var snapshotTxt = '';
var elemList = theForm.elements;
var elem;
var elemType;
for( var i = 0; i < elemList.length ; i++ ) {
elem = elemList[i];
if ( typeof(elem.type) == 'undefined' ) {
continue;
}
elemType = elem.type.toLowerCase();
snapshotTxt = snapshotTxt + elem.name;
if ( elemType == 'text' || elemType == 'textarea' || elemType == 'password' ) {
snapshotTxt = snapshotTxt + elem.value;
}
else if ( elemType == 'select' || elemType == 'select-one' || elemType == 'select-multiple' ) {
var optionList = elem.options;
for ( var ii = 0 ; ii < optionList.length ; ii++ ) {
if ( optionList[ii].selected ) {
snapshotTxt = snapshotTxt + optionList[ii].value;
}
}
}
else if ( elemType == 'radio' || elemType == 'checkbox' ) {
if ( elem.selected ) {
snapshotTxt = snapshotTxt + 'checked';
}
}
else if ( elemType == 'hidden' ) {
snapshotTxt = snapshotTxt + elem.value;
}
}
return snapshotTxt;
}
function initEditView(theForm) {
if (SUGAR.util.ajaxCallInProgress()) {
window.setTimeout(function(){initEditView(theForm);}, 100);
return;
}
if ( theForm == null || theForm.id == null ) {
// Not much we can do here.
return;
}
// we don't need to check if the data is changed in the search popup
if (theForm.id == 'popup_query_form' || theForm.id == 'MassUpdate') {
return;
}
if ( typeof editViewSnapshots == 'undefined' || editViewSnapshots == null ) {
editViewSnapshots = new Object();
}
if ( typeof SUGAR.loadedForms == 'undefined' || SUGAR.loadedForms == null) {
SUGAR.loadedForms = new Object();
}
editViewSnapshots[theForm.id] = snapshotForm(theForm);
SUGAR.loadedForms[theForm.id] = true;
}
function onUnloadEditView(theForm) {
var dataHasChanged = false;
if ( typeof editViewSnapshots == 'undefined' ) {
// No snapshots, move along
return;
}
if ( typeof theForm == 'undefined' ) {
// Need to check all editViewSnapshots
for ( var idx in editViewSnapshots ) {
theForm = document.getElementById(idx);
// console.log('DEBUG: Checking all forms '+theForm.id);
if ( theForm == null
|| typeof editViewSnapshots[theForm.id] == 'undefined'
|| editViewSnapshots[theForm.id] == null
|| !SUGAR.loadedForms[theForm.id]) {
continue;
}
var snap = snapshotForm(theForm);
if ( editViewSnapshots[theForm.id] != snap ) {
dataHasChanged = true;
}
}
} else {
// Just need to check a single form for changes
if ( editViewSnapshots == null || typeof theForm.id == 'undefined' || typeof editViewSnapshots[theForm.id] == 'undefined' || editViewSnapshots[theForm.id] == null ) {
return;
}
// console.log('DEBUG: Checking one form '+theForm.id);
if ( editViewSnapshots[theForm.id] != snapshotForm(theForm) ) {
// Data has changed.
dataHasChanged = true;
}
}
if ( dataHasChanged == true ) {
return SUGAR.language.get('app_strings','WARN_UNSAVED_CHANGES');
} else {
return;
}
}
function disableOnUnloadEditView(theForm) {
// If you don't pass anything in, it disables all checking
if ( typeof theForm == 'undefined' || typeof editViewSnapshots == 'undefined' || theForm == null || editViewSnapshots == null) {
window.onbeforeunload = null;
editViewSnapshots = null;
// console.log('DEBUG: Disabling all edit view checks');
} else {
// Otherwise, it just disables it for this form
if ( typeof(theForm.id) != 'undefined' && typeof(editViewSnapshots[theForm.id]) != 'undefined' ) {
editViewSnapshots[theForm.id] = null;
}
// console.log('DEBUG : Disabling just checks for '+theForm.id);
}
}
/*
* save some forms using an ajax call
* theForms - the ids of all of theh forms to save
* savingStr - the string to display when saving the form
* completeStr - the string to display when the form has been saved
*/
function saveForms( savingStr, completeStr) {
index = 0;
theForms = ajaxFormArray;
function success(data) {
var theForm = document.getElementById(ajaxFormArray[0]);
document.getElementById('multiedit_'+theForm.id).innerHTML = data.responseText;
var saveAllButton = document.getElementById('ajaxsaveall');
ajaxFormArray.splice(index, 1);
if(saveAllButton && ajaxFormArray.length <= 1){
saveAllButton.style.visibility = 'hidden';
}
index++;
if(index == theForms.length){
ajaxStatus.showStatus(completeStr);
window.setTimeout('ajaxStatus.hideStatus();', 2000);
if(saveAllButton)
saveAllButton.style.visibility = 'hidden';
}
}
if(typeof savingStr == 'undefined') SUGAR.language.get('app_strings', 'LBL_LOADING');
ajaxStatus.showStatus(savingStr);
//loop through the forms saving each one
for(i = 0; i < theForms.length; i++){
var theForm = document.getElementById(theForms[i]);
if(check_form(theForm.id)){
theForm.action.value='AjaxFormSave';
YAHOO.util.Connect.setForm(theForm);
var cObj = YAHOO.util.Connect.asyncRequest('POST', 'index.php', {success: success, failure: success});
}else{
ajaxStatus.hideStatus();
}
lastSubmitTime = lastSubmitTime-2000;
}
return false;
}
// -- start sugarListView class
// js functions used for ListView
function sugarListView() {
}
sugarListView.prototype.confirm_action = function(del) {
if (del == 1) {
return confirm( SUGAR.language.get('app_strings', 'NTC_DELETE_CONFIRMATION_NUM') + sugarListView.get_num_selected() + SUGAR.language.get('app_strings', 'NTC_DELETE_SELECTED_RECORDS'));
}
else {
return confirm( SUGAR.language.get('app_strings', 'NTC_UPDATE_CONFIRMATION_NUM') + sugarListView.get_num_selected() + SUGAR.language.get('app_strings', 'NTC_DELETE_SELECTED_RECORDS'));
}
}
sugarListView.get_num_selected = function () {
var selectCount = $("input[name='selectCount[]']:first");
if(selectCount.length > 0)
return parseInt(selectCount.val().replace("+", ""));
return 0;
}
sugarListView.update_count = function(count, add) {
if(typeof document.MassUpdate != 'undefined') {
the_form = document.MassUpdate;
for(var wp = 0; wp < the_form.elements.length; wp++) {
if(typeof the_form.elements[wp].name != 'undefined' && the_form.elements[wp].name == 'selectCount[]') {
if(add) {
the_form.elements[wp].value = parseInt(the_form.elements[wp].value,10) + count;
if (the_form.select_entire_list.value == 1 && the_form.show_plus.value) {
the_form.elements[wp].value += '+';
}
} else {
if (the_form.select_entire_list.value == 1 && the_form.show_plus.value) {
the_form.elements[wp].value = count + '+';
} else {
the_form.elements[wp].value = count;
}
}
}
}
}
}
sugarListView.prototype.use_external_mail_client = function(no_record_txt, module) {
selected_records = sugarListView.get_checks_count();
if(selected_records <1) {
alert(no_record_txt);
return false;
}
if (document.MassUpdate.select_entire_list.value == 1) {
if (totalCount > 10) {
alert(totalCountError);
return;
} // if
select = false;
}
else if (document.MassUpdate.massall.checked == true)
select = false;
else
select = true;
sugarListView.get_checks();
var ids = "";
if(select) { // use selected items
ids = document.MassUpdate.uid.value;
}
else { // use current page
inputs = document.MassUpdate.elements;
ar = new Array();
for(i = 0; i < inputs.length; i++) {
if(inputs[i].name == 'mass[]' && inputs[i].checked && typeof(inputs[i].value) != 'function') {
ar.push(inputs[i].value);
}
}
ids = ar.join(',');
}
YAHOO.util.Connect.asyncRequest("POST", "index.php?", {
success: this.use_external_mail_client_callback
}, SUGAR.util.paramsToUrl({
module: "Emails",
action: "Compose",
listViewExternalClient: 1,
action_module: module,
uid: ids,
to_pdf:1
}));
return false;
}
sugarListView.prototype.use_external_mail_client_callback = function(o)
{
if (o.responseText)
location.href = 'mailto:' + o.responseText;
}
sugarListView.prototype.send_form_for_emails = function(select, currentModule, action, no_record_txt,action_module,totalCount, totalCountError) {
if ( typeof(SUGAR.config.email_sugarclient_listviewmaxselect) != 'undefined' ) {
maxCount = 10;
}
else {
maxCount = SUGAR.config.email_sugarclient_listviewmaxselect;
}
if (document.MassUpdate.select_entire_list.value == 1) {
if (totalCount > maxCount) {
alert(totalCountError);
return;
} // if
select = false;
}
else if (document.MassUpdate.massall.checked == true)
select = false;
else
select = true;
sugarListView.get_checks();
// create new form to post (can't access action property of MassUpdate form due to action input)
var newForm = document.createElement('form');
newForm.method = 'post';
newForm.action = action;
newForm.name = 'newForm';
newForm.id = 'newForm';
var uidTa = document.createElement('textarea');
uidTa.name = 'uid';
uidTa.style.display = 'none';
if(select) { // use selected items
uidTa.value = document.MassUpdate.uid.value;
}
else { // use current page
inputs = document.MassUpdate.elements;
ar = new Array();
for(i = 0; i < inputs.length; i++) {
if(inputs[i].name == 'mass[]' && inputs[i].checked && typeof(inputs[i].value) != 'function') {
ar.push(inputs[i].value);
}
}
uidTa.value = ar.join(',');
}
if(uidTa.value == '') {
alert(no_record_txt);
return false;
}
var selectedArray = uidTa.value.split(",");
if(selectedArray.length > maxCount) {
alert(totalCountError);
return;
} // if
newForm.appendChild(uidTa);
var moduleInput = document.createElement('input');
moduleInput.name = 'module';
moduleInput.type = 'hidden';
moduleInput.value = currentModule;
newForm.appendChild(moduleInput);
var actionInput = document.createElement('input');
actionInput.name = 'action';
actionInput.type = 'hidden';
actionInput.value = 'Compose';
newForm.appendChild(actionInput);
if (typeof action_module != 'undefined' && action_module!= '') {
var actionModule = document.createElement('input');
actionModule.name = 'action_module';
actionModule.type = 'hidden';
actionModule.value = action_module;
newForm.appendChild(actionModule);
}
//return_info must follow this pattern."&return_module=Accounts&return_action=index"
if (typeof return_info!= 'undefined' && return_info != '') {
var params= return_info.split('&');
if (params.length > 0) {
for (var i=0;i< params.length;i++) {
if (params[i].length > 0) {
var param_nv=params[i].split('=');
if (param_nv.length==2){
returnModule = document.createElement('input');
returnModule.name = param_nv[0];
returnModule.type = 'hidden';
returnModule.value = param_nv[1];
newForm.appendChild(returnModule);
}
}
}
}
}
var isAjaxCall = document.createElement('input');
isAjaxCall.name = 'ajaxCall';
isAjaxCall.type = 'hidden';
isAjaxCall.value = true;
newForm.appendChild(isAjaxCall);
var isListView = document.createElement('input');
isListView.name = 'ListView';
isListView.type = 'hidden';
isListView.value = true;
newForm.appendChild(isListView);
var toPdf = document.createElement('input');
toPdf.name = 'to_pdf';
toPdf.type = 'hidden';
toPdf.value = true;
newForm.appendChild(toPdf);
//Grab the Quick Compose package for the listview
YAHOO.util.Connect.setForm(newForm);
var callback =
{
success: function(o) {
var resp = YAHOO.lang.JSON.parse(o.responseText);
var quickComposePackage = new Object();
quickComposePackage.composePackage = resp;
quickComposePackage.fullComposeUrl = 'index.php?module=Emails&action=Compose&ListView=true' +
'&uid=' + uidTa.value + '&action_module=' + action_module;
SUGAR.quickCompose.init(quickComposePackage);
}
}
YAHOO.util.Connect.asyncRequest('POST','index.php', callback,null);
// awu Bug 18624: Fixing issue where a canceled Export and unselect of row will persist the uid field, clear the field
document.MassUpdate.uid.value = '';
return false;
}
sugarListView.prototype.send_form = function(select, currentModule, action, no_record_txt,action_module,return_info) {
if (document.MassUpdate.select_entire_list.value == 1) {
if(sugarListView.get_checks_count() < 1) {
alert(no_record_txt);
return false;
}
var href = action;
if ( action.indexOf('?') != -1 )
href += '&module=' + currentModule;
else
href += '?module=' + currentModule;
if (return_info)
href += return_info;
var newForm = document.createElement('form');
newForm.method = 'post';
newForm.action = href;
newForm.name = 'newForm';
newForm.id = 'newForm';
var postTa = document.createElement('textarea');
postTa.name = 'current_post';
postTa.value = document.MassUpdate.current_query_by_page.value;
postTa.style.display = 'none';
newForm.appendChild(postTa);
document.MassUpdate.parentNode.appendChild(newForm);
newForm.submit();
return;
}
else if (document.MassUpdate.massall.checked == true)
select = false;
else
select = true;
sugarListView.get_checks();
// create new form to post (can't access action property of MassUpdate form due to action input)
var newForm = document.createElement('form');
newForm.method = 'post';
newForm.action = action;
newForm.name = 'newForm';
newForm.id = 'newForm';
var uidTa = document.createElement('textarea');
uidTa.name = 'uid';
uidTa.style.display = 'none';
uidTa.value = document.MassUpdate.uid.value;
if(uidTa.value == '') {
alert(no_record_txt);
return false;
}
newForm.appendChild(uidTa);
var moduleInput = document.createElement('input');
moduleInput.name = 'module';
moduleInput.type = 'hidden';
moduleInput.value = currentModule;
newForm.appendChild(moduleInput);
var actionInput = document.createElement('input');
actionInput.name = 'action';
actionInput.type = 'hidden';
actionInput.value = 'index';
newForm.appendChild(actionInput);
if (typeof action_module != 'undefined' && action_module!= '') {
var actionModule = document.createElement('input');
actionModule.name = 'action_module';
actionModule.type = 'hidden';
actionModule.value = action_module;
newForm.appendChild(actionModule);
}
//return_info must follow this pattern."&return_module=Accounts&return_action=index"
if (typeof return_info!= 'undefined' && return_info != '') {
var params= return_info.split('&');
if (params.length > 0) {
for (var i=0;i< params.length;i++) {
if (params[i].length > 0) {
var param_nv=params[i].split('=');
if (param_nv.length==2){
returnModule = document.createElement('input');
returnModule.name = param_nv[0];
returnModule.type = 'hidden';
returnModule.value = param_nv[1];
newForm.appendChild(returnModule);
}
}
}
}
}
document.MassUpdate.parentNode.appendChild(newForm);
newForm.submit();
// awu Bug 18624: Fixing issue where a canceled Export and unselect of row will persist the uid field, clear the field
document.MassUpdate.uid.value = '';
return false;
}
//return a count of checked row.
sugarListView.get_checks_count = function() {
ar = new Array();
if(document.MassUpdate.uid.value != '') {
oldUids = document.MassUpdate.uid.value.split(',');
for(uid in oldUids) {
if(typeof(oldUids[uid]) != 'function') {
ar[oldUids[uid]] = 1;
}
}
}
// build associated array of uids, associated array ensures uniqueness
inputs = document.MassUpdate.elements;
for(i = 0; i < inputs.length; i++) {
if(inputs[i].name == 'mass[]') {
ar[inputs[i].value] = (inputs[i].checked) ? 1 : 0; // 0 of it is unchecked
}
}
// build regular array of uids
uids = new Array();
for(i in ar) {
if((typeof(ar[i]) != 'function') && ar[i] == 1) {
uids.push(i);
}
}
return uids.length;
}
// saves the checks on the current page into the uid textarea
sugarListView.get_checks = function() {
ar = new Array();
if(typeof document.MassUpdate != 'undefined' ){
if(document.MassUpdate.uid.value != '') {
oldUids = document.MassUpdate.uid.value.split(',');
for(uid in oldUids) {
if(typeof(oldUids[uid]) != 'function') {
ar[oldUids[uid]] = 1;
}
}
}
// build associated array of uids, associated array ensures uniqueness
inputs = document.MassUpdate.elements;
for(i = 0; i < inputs.length; i++) {
if(inputs[i].name == 'mass[]') {
ar[inputs[i].value] = (inputs[i].checked) ? 1 : 0; // 0 of it is unchecked
}
}
// build regular array of uids
uids = new Array();
for(i in ar) {
if(typeof(ar[i]) != 'function' && ar[i] == 1) {
uids.push(i);
}
}
document.MassUpdate.uid.value = uids.join(',');
if(uids.length == 0) return false; // return false if no checks to get
return true; // there are saved checks
}
else return false;
}
sugarListView.prototype.order_checks = function(order,orderBy,moduleString){
checks = sugarListView.get_checks();
eval('document.MassUpdate.' + moduleString + '.value = orderBy');
document.MassUpdate.lvso.value = order;
if(typeof document.MassUpdate.massupdate != 'undefined') {
document.MassUpdate.massupdate.value = 'false';
}
//we must first clear the action of massupdate, change it to index
document.MassUpdate.action.value = document.MassUpdate.return_action.value;
document.MassUpdate.return_module.value='';
document.MassUpdate.return_action.value='';
document.MassUpdate.submit();
return !checks;
}
sugarListView.prototype.save_checks = function(offset, moduleString) {
checks = sugarListView.get_checks();
if(typeof document.MassUpdate != 'undefined'){
eval('document.MassUpdate.' + moduleString + '.value = offset');
if(typeof document.MassUpdate.massupdate != 'undefined') {
document.MassUpdate.massupdate.value = 'false';
}
//we must first clear the action of massupdate, change it to index
document.MassUpdate.action.value = document.MassUpdate.return_action.value;
document.MassUpdate.return_module.value='';
document.MassUpdate.return_action.value='';
document.MassUpdate.submit();
return !checks;
}
else return false;
}
sugarListView.prototype.check_item = function(cb, form) {
if(cb.checked) {
sugarListView.update_count(1, true);
}else{
sugarListView.update_count(-1, true);
if(typeof form != 'undefined' && form != null) {
sugarListView.prototype.updateUid(cb, form);
}
}
sugarListView.prototype.toggleSelected();
}
sugarListView.prototype.toggleSelected = function() {
var numSelected = sugarListView.get_num_selected();
var selectedRecords = document.getElementById("selectedRecordsTop");
var selectActions = document.getElementById("selectActions");
var selectActionsDisabled = document.getElementById("selectActionsDisabled");
if(numSelected > 0) {
$(selectedRecords).removeAttr("style").addClass("show");
$(".selectActionsDisabled").hide();
jQuery('ul[name=selectActions]').each(function () {
jQuery(this).removeAttr("style").addClass("show");
});
} else {
$(selectedRecords).hide();
$(".selectActionsDisabled").removeAttr("style").addClass("show");
jQuery('ul[name=selectActions]').each(function () {
jQuery(this).hide();
});
}
}
/**#28000, remove the unselect record id from MassUpdate.uid **/
sugarListView.prototype.updateUid = function(cb , form){
if(form.name == 'MassUpdate' && form.uid && form.uid.value && cb.value && form.uid.value.indexOf(cb.value) != -1){
if(form.uid.value.indexOf(','+cb.value)!= -1){
form.uid.value = form.uid.value.replace(','+cb.value , '');
}else if(form.uid.value.indexOf(cb.value + ',')!= -1){
form.uid.value = form.uid.value.replace(cb.value + ',' , '');
}else if(form.uid.value.indexOf(cb.value)!= -1){
form.uid.value = form.uid.value.replace(cb.value , '');
}
}
}
sugarListView.prototype.check_entire_list = function(form, field, value, list_count) {
// count number of items
count = 0;
$(document.MassUpdate.massall).each(function(){
$(this).attr('checked', true).attr('disabled', true);
});
for (i = 0; i < form.elements.length; i++) {
if(form.elements[i].name == field && form.elements[i].disabled == false) {
if(form.elements[i].checked != value) count++;
form.elements[i].checked = value;
form.elements[i].disabled = true;
}
}
document.MassUpdate.select_entire_list.value = 1;
sugarListView.update_count(list_count, false);
sugarListView.prototype.toggleSelected();
}
sugarListView.prototype.check_all = function(form, field, value, pageTotal) {
// count number of items
count = 0;
$(document.MassUpdate.massall).each(function(){$(this).attr('checked', value);});
if (document.MassUpdate.select_entire_list &&
document.MassUpdate.select_entire_list.value == 1)
{
sugarListView.prototype.toggleSelected();
$(document.MassUpdate.massall).each(function(){$(this).attr('disabled', true);});
}
else
{
$(document.MassUpdate.massall).each(function(){$(this).attr('disabled', false);});
}
for (i = 0; i < form.elements.length; i++) {
if(form.elements[i].name == field && !(form.elements[i].disabled == true && form.elements[i].checked == false)) {
form.elements[i].disabled = false;
if(form.elements[i].checked != value)
count++;
form.elements[i].checked = value;
if(!value){
sugarListView.prototype.updateUid(form.elements[i], form);
}
}
}
if (pageTotal >= 0)
sugarListView.update_count(pageTotal);
else if(value)
sugarListView.update_count(count, true);
else
sugarListView.update_count(-1 * count, true);
sugarListView.prototype.toggleSelected();
}
sugarListView.check_all = sugarListView.prototype.check_all;
sugarListView.confirm_action = sugarListView.prototype.confirm_action;
sugarListView.prototype.check_boxes = function() {
var inputsCount = 0;
var checkedCount = 0;
var existing_onload = window.onload;
var theForm = document.MassUpdate;
inputs_array = theForm.elements;
if(typeof theForm.uid.value != 'undefined' && theForm.uid.value != "") {
checked_items = theForm.uid.value.split(",");
if (theForm.select_entire_list.value == 1) {
document.MassUpdate.massall.disabled = true;
sugarListView.prototype.toggleSelected();
$("a[name=selectall]:first").click();
}
for(var wp = 0 ; wp < inputs_array.length; wp++) {
if(inputs_array[wp].name == "mass[]") {
inputsCount++;
if (theForm.select_entire_list.value == 1) {
inputs_array[wp].checked = true;
inputs_array[wp].disabled = true;
checkedCount++;
}
else {
for(i in checked_items) {
if(inputs_array[wp].value == checked_items[i]) {
checkedCount++;
inputs_array[wp].checked = true;
//Bug#52748: Total # of checked items are calculated in back-end side
//sugarListView.prototype.check_item(inputs_array[wp], document.MassUpdate);
}
}
}
}
}
}
else {
for(var wp = 0 ; wp < inputs_array.length; wp++) {
if(inputs_array[wp].name == "mass[]") {
inputs_array[wp].checked = false;
inputs_array[wp].disabled = false;
}
}
if (document.MassUpdate.massall) {
document.MassUpdate.massall.checked = false;
document.MassUpdate.massall.disabled = false;
}
sugarListView.update_count(0)
}
if(checkedCount > 0 && checkedCount == inputsCount)
document.MassUpdate.massall.checked = true;
}
/**
* This function is used in Email Template Module's listview.
* It will check whether the templates are used in Campaing->EmailMarketing.
* If true, it will notify user.
*/
function check_used_email_templates() {
var ids = document.MassUpdate.uid.value;
var call_back = {
success:function(r) {
if(r.responseText != '') {
if(!confirm(SUGAR.language.get('app_strings','NTC_TEMPLATES_IS_USED') + r.responseText)) {
return false;
}
}
document.MassUpdate.submit();
return false;
}
};
url = "index.php?module=EmailTemplates&action=CheckDeletable&from=ListView&to_pdf=1&records="+ids;
YAHOO.util.Connect.asyncRequest('POST',url, call_back,null);
}
sugarListView.prototype.send_mass_update = function(mode, no_record_txt, del) {
formValid = check_form('MassUpdate');
if(!formValid && !del) return false;
if (document.MassUpdate.select_entire_list &&
document.MassUpdate.select_entire_list.value == 1)
mode = 'entire';
else
mode = 'selected';
var ar = new Array();
switch(mode) {
case 'selected':
for(var wp = 0; wp < document.MassUpdate.elements.length; wp++) {
var reg_for_existing_uid = new RegExp('^'+RegExp.escape(document.MassUpdate.elements[wp].value)+'[\s]*,|,[\s]*'+RegExp.escape(document.MassUpdate.elements[wp].value)+'[\s]*,|,[\s]*'+RegExp.escape(document.MassUpdate.elements[wp].value)+'$|^'+RegExp.escape(document.MassUpdate.elements[wp].value)+'$');
//when the uid is already in document.MassUpdate.uid.value, we should not add it to ar.
if(typeof document.MassUpdate.elements[wp].name != 'undefined'
&& document.MassUpdate.elements[wp].name == 'mass[]'
&& document.MassUpdate.elements[wp].checked
&& !reg_for_existing_uid.test(document.MassUpdate.uid.value)) {
ar.push(document.MassUpdate.elements[wp].value);
}
}
if(document.MassUpdate.uid.value != '') document.MassUpdate.uid.value += ',';
document.MassUpdate.uid.value += ar.join(',');
if(document.MassUpdate.uid.value == '') {
alert(no_record_txt);
return false;
}
if(typeof(current_admin_id)!='undefined' && document.MassUpdate.module!= 'undefined' && document.MassUpdate.module.value == 'Users' && (document.MassUpdate.is_admin.value!='' || document.MassUpdate.status.value!='')) {
var reg_for_current_admin_id = new RegExp('^'+current_admin_id+'[\s]*,|,[\s]*'+current_admin_id+'[\s]*,|,[\s]*'+current_admin_id+'$|^'+current_admin_id+'$');
if(reg_for_current_admin_id.test(document.MassUpdate.uid.value)) {
//if current user is admin, we should not allow massupdate the user_type and status of himself
alert(SUGAR.language.get('Users','LBL_LAST_ADMIN_NOTICE'));
return false;
}
}
break;
case 'entire':
var entireInput = document.createElement('input');
entireInput.name = 'entire';
entireInput.type = 'hidden';
entireInput.value = 'index';
document.MassUpdate.appendChild(entireInput);
//confirm(no_record_txt);
if(document.MassUpdate.module!= 'undefined' && document.MassUpdate.module.value == 'Users' && (document.MassUpdate.is_admin.value!='' || document.MassUpdate.status.value!='')) {
alert(SUGAR.language.get('Users','LBL_LAST_ADMIN_NOTICE'));
return false;
}
break;
}
if(!sugarListView.confirm_action(del))
return false;
if(del == 1) {
var deleteInput = document.createElement('input');
deleteInput.name = 'Delete';
deleteInput.type = 'hidden';
deleteInput.value = true;
document.MassUpdate.appendChild(deleteInput);
if(document.MassUpdate.module!= 'undefined' && document.MassUpdate.module.value == 'EmailTemplates') {
check_used_email_templates();
return false;
}
}
document.MassUpdate.submit();
return false;
}
sugarListView.prototype.clear_all = function() {
document.MassUpdate.uid.value = '';
document.MassUpdate.select_entire_list.value = 0;
sugarListView.check_all(document.MassUpdate, 'mass[]', false);
$(document.MassUpdate.massall).each(function(){
$(this).attr('checked', false).attr('disabled', false);
});
sugarListView.update_count(0);
sugarListView.prototype.toggleSelected();
}
sListView = new sugarListView();
// -- end sugarListView class
// format and unformat numbers
function unformatNumber(n, num_grp_sep, dec_sep) {
var x=unformatNumberNoParse(n, num_grp_sep, dec_sep);
x=x.toString();
if(x.length > 0) {
return parseFloat(x);
}
return '';
}
function unformatNumberNoParse(n, num_grp_sep, dec_sep) {
if(typeof num_grp_sep == 'undefined' || typeof dec_sep == 'undefined') return n;
n = n ? n.toString() : '';
if(n.length > 0) {
if(num_grp_sep != '')
{
num_grp_sep_re = new RegExp('\\'+num_grp_sep, 'g');
n = n.replace(num_grp_sep_re, '');
}
n = n.replace(dec_sep, '.');
if(typeof CurrencySymbols != 'undefined') {
// Need to strip out the currency symbols from the start.
for ( var idx in CurrencySymbols ) {
n = n.replace(CurrencySymbols[idx], '');
}
}
return n;
}
return '';
}
// round parameter can be negative for decimal, precision has to be postive
function formatNumber(n, num_grp_sep, dec_sep, round, precision) {
if(typeof num_grp_sep == 'undefined' || typeof dec_sep == 'undefined') return n;
n = n ? n.toString() : '';
if(n.split) n = n.split('.');
else return n;
if(n.length > 2) return n.join('.'); // that's not a num!
// round
if(typeof round != 'undefined') {
if(round > 0 && n.length > 1) { // round to decimal
n[1] = parseFloat('0.' + n[1]);
n[1] = Math.round(n[1] * Math.pow(10, round)) / Math.pow(10, round);
n[1] = n[1].toString().split('.')[1];
}
if(round <= 0) { // round to whole number
n[0] = Math.round(parseInt(n[0],10) * Math.pow(10, round)) / Math.pow(10, round);
n[1] = '';
}
}
if(typeof precision != 'undefined' && precision >= 0) {
if(n.length > 1 && typeof n[1] != 'undefined') n[1] = n[1].substring(0, precision); // cut off precision
else n[1] = '';
if(n[1].length < precision) {
for(var wp = n[1].length; wp < precision; wp++) n[1] += '0';
}
}
regex = /(\d+)(\d{3})/;
while(num_grp_sep != '' && regex.test(n[0])) n[0] = n[0].toString().replace(regex, '$1' + num_grp_sep + '$2');
return n[0] + (n.length > 1 && n[1] != '' ? dec_sep + n[1] : '');
}
// --- begin ajax status class
SUGAR.ajaxStatusClass = function() {};
SUGAR.ajaxStatusClass.prototype.statusDiv = null;
SUGAR.ajaxStatusClass.prototype.oldOnScroll = null;
SUGAR.ajaxStatusClass.prototype.shown = false; // state of the status window
// reposition the status div, top and centered
SUGAR.ajaxStatusClass.prototype.positionStatus = function() {
//this.statusDiv.style.top = document.body.scrollTop + 8 + 'px';
statusDivRegion = YAHOO.util.Dom.getRegion(this.statusDiv);
statusDivWidth = statusDivRegion.right - statusDivRegion.left;
this.statusDiv.style.left = YAHOO.util.Dom.getViewportWidth() / 2 - statusDivWidth / 2 + 'px';
}
// private func, create the status div
SUGAR.ajaxStatusClass.prototype.createStatus = function(text) {
statusDiv = document.createElement('div');
statusDiv.className = 'dataLabel';
statusDiv.id = 'ajaxStatusDiv';
document.body.appendChild(statusDiv);
this.statusDiv = document.getElementById('ajaxStatusDiv');
}
// public - show the status div with text
SUGAR.ajaxStatusClass.prototype.showStatus = function(text) {
if(!this.statusDiv) {
this.createStatus(text);
}
else {
this.statusDiv.style.display = '';
}
this.statusDiv.innerHTML = ' ' + text + ' ';
this.positionStatus();
if(!this.shown) {
this.shown = true;
this.statusDiv.style.display = '';
if(window.onscroll) this.oldOnScroll = window.onscroll; // save onScroll
window.onscroll = this.positionStatus;
}
}
// public - hide it
SUGAR.ajaxStatusClass.prototype.hideStatus = function(text) {
if(!this.shown) return;
this.shown = false;
if(this.oldOnScroll) window.onscroll = this.oldOnScroll;
else window.onscroll = '';
this.statusDiv.style.display = 'none';
}
SUGAR.ajaxStatusClass.prototype.flashStatus = function(text, time){
this.showStatus(text);
window.setTimeout('ajaxStatus.hideStatus();', time);
}
var ajaxStatus = new SUGAR.ajaxStatusClass();
// --- end ajax status class
/**
* Unified Search Advanced - for global search
*/
SUGAR.unifiedSearchAdvanced = function() {
var usa_div;
var usa_img;
var usa_open;
var usa_content;
var anim_open;
var anim_close;
return {
init: function() {
SUGAR.unifiedSearchAdvanced.usa_div = document.getElementById('unified_search_advanced_div');
SUGAR.unifiedSearchAdvanced.usa_img = document.getElementById('unified_search_advanced_img');
if(!SUGAR.unifiedSearchAdvanced.usa_div || !SUGAR.unifiedSearchAdvanced.usa_img) return;
var attributes = { height: { to: 300 } };
SUGAR.unifiedSearchAdvanced.anim_open = new YAHOO.util.Anim('unified_search_advanced_div', attributes );
SUGAR.unifiedSearchAdvanced.anim_open.duration = 0.75;
SUGAR.unifiedSearchAdvanced.anim_close = new YAHOO.util.Anim('unified_search_advanced_div', { height: {to: 0} } );
SUGAR.unifiedSearchAdvanced.anim_close.duration = 0.75;
//SUGAR.unifiedSearchAdvanced.anim_close.onComplete.subscribe(function() {SUGAR.unifiedSearchAdvanced.usa_div.style.display = 'none'});
SUGAR.unifiedSearchAdvanced.usa_img._x = YAHOO.util.Dom.getX(SUGAR.unifiedSearchAdvanced.usa_img);
SUGAR.unifiedSearchAdvanced.usa_img._y = YAHOO.util.Dom.getY(SUGAR.unifiedSearchAdvanced.usa_img);
SUGAR.unifiedSearchAdvanced.usa_open = false;
SUGAR.unifiedSearchAdvanced.usa_content = null;
YAHOO.util.Event.addListener('unified_search_advanced_img', 'click', SUGAR.unifiedSearchAdvanced.get_content);
},
get_content: function(e)
{
query_string = trim(document.getElementById('query_string').value);
if(query_string != '')
{
window.location.href = 'index.php?module=Home&action=UnifiedSearch&query_string=' + query_string;
} else {
window.location.href = 'index.php?module=Home&action=UnifiedSearch&form_only=true';
}
},
animate: function(data) {
ajaxStatus.hideStatus();
if(data) {
SUGAR.unifiedSearchAdvanced.usa_content = data.responseText;
SUGAR.unifiedSearchAdvanced.usa_div.innerHTML = SUGAR.unifiedSearchAdvanced.usa_content;
}
if(SUGAR.unifiedSearchAdvanced.usa_open) {
document.UnifiedSearch.advanced.value = 'false';
SUGAR.unifiedSearchAdvanced.anim_close.animate();
}
else {
document.UnifiedSearch.advanced.value = 'true';
SUGAR.unifiedSearchAdvanced.usa_div.style.display = '';
YAHOO.util.Dom.setX(SUGAR.unifiedSearchAdvanced.usa_div, SUGAR.unifiedSearchAdvanced.usa_img._x - 90);
YAHOO.util.Dom.setY(SUGAR.unifiedSearchAdvanced.usa_div, SUGAR.unifiedSearchAdvanced.usa_img._y + 15);
SUGAR.unifiedSearchAdvanced.anim_open.animate();
}
SUGAR.unifiedSearchAdvanced.usa_open = !SUGAR.unifiedSearchAdvanced.usa_open;
return false;
},
checkUsaAdvanced: function() {
if(document.UnifiedSearch.advanced.value == 'true') {
document.UnifiedSearchAdvanced.query_string.value = document.UnifiedSearch.query_string.value;
document.UnifiedSearchAdvanced.submit();
return false;
}
return true;
}
};
}();
if(typeof YAHOO != 'undefined') YAHOO.util.Event.addListener(window, 'load', SUGAR.unifiedSearchAdvanced.init);
SUGAR.ui = {
/**
* Toggles the header
*/
toggleHeader : function() {
var h = document.getElementById('header');
if(h != null) {
if(h != null) {
if(h.style.display == 'none') {
h.style.display = '';
} else {
h.style.display = 'none';
}
}
} else {
alert(SUGAR.language.get("app_strings", "ERR_NO_HEADER_ID"));
}
}
};
/**
* General Sugar Utils
*/
SUGAR.util = function () {
var additionalDetailsCache;
var additionalDetailsCalls;
var additionalDetailsRpcCall;
return {
getAndRemove : function (el) {
if (YAHOO && YAHOO.util && YAHOO.util.Dom)
el = YAHOO.util.Dom.get(el);
else if (typeof (el) == "string")
el = document.getElementById(el);
if (el && el.parentNode)
el.parentNode.removeChild(el);
return el;
},
paramsToUrl : function (params) {
var parts = [];
for (var i in params)
{
if (params.hasOwnProperty(i))
{
parts.push(encodeURIComponent(i) + '=' + encodeURIComponent(params[i]));
}
}
return parts.join("&")+"&";
},
// Evaluates a script in a global context
// Workarounds based on findings by Jim Driscoll
// http://weblogs.java.net/blog/driscoll/archive/2009/09/08/eval-javascript-global-context
globalEval: function( data ) {
var rnotwhite = /\S/;
if ( data && rnotwhite.test( data ) ) {
// We use execScript on Internet Explorer
// We use an anonymous function so that context is window
// rather than jQuery in Firefox
( window.execScript || function( data ) {
window[ "eval" ].call( window, data );
} )( data );
}
},
evalScript:function(text){
if (isSafari) {
var waitUntilLoaded = function(){
SUGAR.evalScript_waitCount--;
if (SUGAR.evalScript_waitCount == 0) {
var headElem = document.getElementsByTagName('head')[0];
for ( var i = 0; i < SUGAR.evalScript_evalElem.length; i++) {
var tmpElem = document.createElement('script');
tmpElem.type = 'text/javascript';
tmpElem.text = SUGAR.evalScript_evalElem[i];
headElem.appendChild(tmpElem);
}
}
};
var tmpElem = document.createElement('div');
tmpElem.innerHTML = text;
var results = tmpElem.getElementsByTagName('script');
if (results == null) {
// No scripts found, bail out
return;
}
var headElem = document.getElementsByTagName('head')[0];
var tmpElem = null;
SUGAR.evalScript_waitCount = 0;
SUGAR.evalScript_evalElem = new Array();
for (var i = 0; i < results.length; i++) {
if (typeof(results[i]) != 'object') {
continue;
};
tmpElem = document.createElement('script');
tmpElem.type = 'text/javascript';
if (results[i].src != null && results[i].src != '') {
tmpElem.src = results[i].src;
} else {
// Need to defer execution of these scripts until the
// required javascript files are fully loaded
SUGAR.evalScript_evalElem[SUGAR.evalScript_evalElem.length] = results[i].text;
continue;
}
tmpElem.addEventListener('load', waitUntilLoaded);
SUGAR.evalScript_waitCount++;
headElem.appendChild(tmpElem);
}
// Add some code to handle pages without any external scripts
SUGAR.evalScript_waitCount++;
waitUntilLoaded();
// Don't try and process things the IE way
return;
}
var objRegex = /<\s*script([^>]*)>((.|\s|\v|\0)*?)<\s*\/script\s*>/igm;
var lastIndex = -1;
var result = objRegex.exec(text);
while(result && result.index > lastIndex){
lastIndex = result.index
try{
// Bug #49205 : Subpanels fail to load when selecting subpanel tab
// Change approach to handle javascripts included to body of ajax response.
// To load & run javascripts and inline javascript in correct order load them as synchronous requests
// JQuery library uses this approach to eval scripts
if(result[1].indexOf("src=") > -1){
var srcRegex = /.*src=['"]([a-zA-Z0-9_\-\&\/\.\?=:-]*)['"].*/igm;
var srcResult = result[1].replace(srcRegex, '$1');
// Check is ulr cross domain or not
var r1 = /:\/\//igm;
if ( r1.test(srcResult) && srcResult.indexOf(window.location.hostname) == -1 )
{
// if script is cross domain it cannot be loaded via ajax request
// try load script asynchronous by creating script element in the body
// YUI 3.3 doesn't allow load scrips synchronously
// YUI 3.5 do it
YUI().use('get', function (Y)
{
var url = srcResult;
Y.Get.script(srcResult,
{
autopurge: false,
onSuccess : function(o) { },
onFailure: function(o) { },
onTimeout: function(o) { }
});
});
// TODO: for YUI 3.5 - load scripts as script object synchronous
/*
YUI().use('get', function (Y) {
var url = srcResult;
Y.Get.js([{url: url, async: false}], function (err) {});
});
*/
}
else
{
// Bug #49205 : Subpanels fail to load when selecting subpanel tab
// Create a YUI instance using the io-base module.
(function (srcResult) {
YUI().use("io-base",function(Y)
{
var cfg,response;
cfg={
method:'GET',
sync:true,
on:{
success:function(transactionid,response,arguments)
{
SUGAR.util.globalEval(response.responseText);
}
}
};
// Call synchronous request to load javascript content
// restonse will be processed in success function
response=Y.io(srcResult,cfg);
});
})(srcResult);
}
}else{
// Bug #49205 : Subpanels fail to load when selecting subpanel tab
// execute script in global context
// Bug #57288 : don't eval with html comment-out script; that causes syntax error in IE
var srcRegex = //;
var srcResult = srcRegex.exec(result[2]);
if (srcResult && srcResult.index > -1)
{
SUGAR.util.globalEval(srcResult[1]);
}
else
{
SUGAR.util.globalEval(result[2]);
}
}
}
catch(e) {
if(typeof(console) != "undefined" && typeof(console.log) == "function")
{
console.log("error adding script");
console.log(e);
console.log(result);
}
}
result = objRegex.exec(text);
}
},
/**
* Gets the sidebar object
* @return object pointer to the sidebar element
*/
getLeftColObj: function() {
leftColObj = document.getElementById('leftCol');
while(leftColObj.nodeName != 'TABLE') {
leftColObj = leftColObj.firstChild;
}
leftColTable = leftColObj;
leftColTd = leftColTable.getElementsByTagName('td')[0];
leftColTdRegion = YAHOO.util.Dom.getRegion(leftColTd);
leftColTd.style.width = (leftColTdRegion.right - leftColTdRegion.left) + 'px';
return leftColTd;
},
/**
* Fills the shortcut menu placeholders w/ actual content
* Call this on load event
*
* @param shortcutContent Array array of content to fill in
*/
fillShortcuts: function(e, shortcutContent) {
return ;
/*
// don't do this if leftCol isn't available
if (document.getElementById('leftCol') == undefined) { return; }
spans = document.getElementById('leftCol').getElementsByTagName('span');
hideCol = document.getElementById('HideMenu').getElementsByTagName('span');
w = spans.length + 1;
for(i in hideCol) {
spans[w] = hideCol[i];
w++;
}
for(je in shortcutContent) {
for(wp in spans) {
if(typeof spans[wp].innerHTML != 'undefined' && spans[wp].innerHTML == ('wp_shortcut_fill_' + je)) {
if(typeof spans[wp].parentNode.parentNode == 'object') {
if(typeof spans[wp].parentNode.parentNode.onclick != 'undefined') {
spans[wp].parentNode.parentNode.onclick = null;
}
// If the wp_shortcut span is contained by an A tag, replace the A with a DIV.
if(spans[wp].parentNode.tagName == 'A' && !isIE) {
var newDiv = document.createElement('DIV');
var parentAnchor = spans[wp].parentNode;
spans[wp].parentNode.parentNode.style.display = 'none';
// Copy styles over to the new container div
if(window.getComputedStyle) {
var parentStyle = window.getComputedStyle(parentAnchor, '');
for(var styleName in parentStyle) {
if(typeof parentStyle[styleName] != 'function'
&& styleName != 'display'
&& styleName != 'borderWidth'
&& styleName != 'visibility') {
try {
newDiv.style[styleName] = parentStyle[styleName];
} catch(e) {
// Catches .length and .parentRule, and others
}
}
}
}
// Replace the A with the DIV
newDiv.appendChild(spans[wp]);
parentAnchor.parentNode.replaceChild(newDiv, parentAnchor);
spans[wp].parentNode.parentNode.style.display = '';
}
}
spans[wp].innerHTML = shortcutContent[je]; // fill w/ content
if(spans[wp].style) spans[wp].style.display = '';
}
}
}*/
},
/**
* Make an AJAX request.
*
* @param url string resource to load
* @param theDiv string id of element to insert loaded data into
* @param postForm string if set, a POST request will be made to resource specified by url using the form named by postForm
* @param callback string name of function to invoke after HTTP response is recieved
* @param callbackParam any parameter to pass to callback when invoked
* @param appendMode bool if true, HTTP response will be appended to the contents of theDiv, or else contents will be overriten.
*/
retrieveAndFill: function(url, theDiv, postForm, callback, callbackParam, appendMode) {
if(typeof theDiv == 'string') {
try {
theDiv = document.getElementById(theDiv);
}
catch(e) {
return;
}
}
var success = function(data) {
if (typeof theDiv != 'undefined' && theDiv != null)
{
try {
if (typeof appendMode != 'undefined' && appendMode)
{
theDiv.innerHTML += data.responseText;
}
else
{
theDiv.innerHTML = data.responseText;
}
}
catch (e) {
return;
}
}
if (typeof callback != 'undefined' && callback != null) callback(callbackParam);
}
if(typeof postForm == 'undefined' || postForm == null) {
var cObj = YAHOO.util.Connect.asyncRequest('GET', url, {success: success, failure: success});
}
else {
YAHOO.util.Connect.setForm(postForm);
var cObj = YAHOO.util.Connect.asyncRequest('POST', url, {success: success, failure: success});
}
},
checkMaxLength: function() { // modified from http://www.quirksmode.org/dom/maxlength.html
var maxLength = this.getAttribute('maxlength');
var currentLength = this.value.length;
if (currentLength > maxLength) {
this.value = this.value.substring(0, maxLength);
}
// not innerHTML
},
/**
* Adds maxlength attribute to textareas
*/
setMaxLength: function() { // modified from http://www.quirksmode.org/dom/maxlength.html
var x = document.getElementsByTagName('textarea');
for (var i=0;i 0 ? $("#"+elmId) : $('').attr("id", elmId) ) : $('');
$dialog.html(helpText)
.dialog({
autoOpen: false,
title: SUGAR.language.get('app_strings', 'LBL_HELP'),
position: {
my: myPos,
at: atPos,
of: $(el)
}
});
var width = $dialog.dialog( "option", "width" );
if((pos.left + ofWidth) - 40 < width) {
$dialog.dialog("option","position",{my: 'left top',at: 'right top',of: $(el)}) ;
}
$dialog.dialog('open');
$(".ui-dialog").appendTo("#content");
},
getStaticAdditionalDetails: function(el, body, caption, show_buttons) {
if(typeof show_buttons == "undefined") {
show_buttons = false;
}
$(".ui-dialog").find(".open").dialog("close");
var $dialog = $('')
.html(body)
.dialog({
autoOpen: false,
title: caption,
width: 300,
position: {
my: 'right top',
at: 'left top',
of: $(el)
}
});
if(show_buttons) {
$(".ui-dialog").find('.ui-dialog-titlebar-close').css("display","none");
$(".ui-dialog").find('.ui-dialog-title').css("width","100%");
}
var width = $dialog.dialog( "option", "width" );
var pos = $(el).offset();
var ofWidth = $(el).width();
if((pos.left + ofWidth) - 40 < width) {
$dialog.dialog("option","position",{my: 'left top',at: 'right top',of: $(el)}) ;
}
$dialog.dialog('open');
$(".ui-dialog").appendTo("#content");
},
closeStaticAdditionalDetails: function() {
$(".ui-dialog").find(".open").dialog("close");
},
/**
* Retrieves additional details dynamically
*/
getAdditionalDetails: function(bean, id, spanId, show_buttons) {
if(typeof show_buttons == "undefined")
show_buttons = false;
var el = '#'+spanId;
go = function() {
oReturn = function(body, caption, width, theme) {
$(".ui-dialog").find(".open").dialog("close");
var $dialog = $('')
.html(body)
.dialog({
autoOpen: false,
title: caption,
width: 300,
position: {
my: 'right top',
at: 'left top',
of: $(el)
}
});
if(show_buttons) {
$(".ui-dialog").find('.ui-dialog-titlebar-close').css("display","none");
$(".ui-dialog").find('.ui-dialog-title').css("width","100%");
}
var width = $dialog.dialog( "option", "width" );
var pos = $(el).offset();
var ofWidth = $(el).width();
if((pos.left + ofWidth) - 40 < width) {
$dialog.dialog("option","position",{my: 'left top',at: 'right top',of: $(el)}) ;
}
$dialog.dialog('open');
$(".ui-dialog").appendTo("#content");
}
success = function(data) {
eval(data.responseText);
SUGAR.util.additionalDetailsCache[id] = new Array();
SUGAR.util.additionalDetailsCache[id]['body'] = result['body'];
SUGAR.util.additionalDetailsCache[id]['caption'] = result['caption'];
SUGAR.util.additionalDetailsCache[id]['width'] = result['width'];
SUGAR.util.additionalDetailsCache[id]['theme'] = result['theme'];
ajaxStatus.hideStatus();
return oReturn(SUGAR.util.additionalDetailsCache[id]['body'], SUGAR.util.additionalDetailsCache[id]['caption'], SUGAR.util.additionalDetailsCache[id]['width'], SUGAR.util.additionalDetailsCache[id]['theme']);
}
if(typeof SUGAR.util.additionalDetailsCache[id] != 'undefined')
return oReturn(SUGAR.util.additionalDetailsCache[id]['body'], SUGAR.util.additionalDetailsCache[id]['caption'], SUGAR.util.additionalDetailsCache[id]['width'], SUGAR.util.additionalDetailsCache[id]['theme']);
if(typeof SUGAR.util.additionalDetailsCalls[id] != 'undefined') // call already in progress
return;
ajaxStatus.showStatus(SUGAR.language.get('app_strings', 'LBL_LOADING'));
url = 'index.php?to_pdf=1&module=Home&action=AdditionalDetailsRetrieve&bean=' + bean + '&id=' + id;
if(show_buttons)
url += '&show_buttons=true';
SUGAR.util.additionalDetailsCalls[id] = YAHOO.util.Connect.asyncRequest('GET', url, {success: success, failure: success});
return false;
}
SUGAR.util.additionalDetailsRpcCall = window.setTimeout('go()', 250);
},
clearAdditionalDetailsCall: function() {
if(typeof SUGAR.util.additionalDetailsRpcCall == 'number') window.clearTimeout(SUGAR.util.additionalDetailsRpcCall);
},
/**
* A function that extends functionality from parent to child.
*/
extend : function(subc, superc, overrides) {
subc.prototype = new superc; // set the superclass
// overrides
if (overrides) {
for (var i in overrides) subc.prototype[i] = overrides[i];
}
},
hrefURL : function(url) {
if(SUGAR.isIE) {
// IE needs special treatment since otherwise it would not pass Referer
var trampoline = document.createElement('a');
trampoline.href = url;
document.body.appendChild(trampoline);
trampoline.click();
document.body.removeChild(trampoline);
} else {
document.location.href = url;
}
},
openWindow : function(URL, windowName, windowFeatures) {
if(SUGAR.isIE) {
// IE needs special treatment since otherwise it would not pass Referer
win = window.open('', windowName, windowFeatures);
var trampoline = document.createElement('a');
trampoline.href = URL;
trampoline.target = windowName;
document.body.appendChild(trampoline);
trampoline.click();
document.body.removeChild(trampoline);
} else {
win = window.open(URL, windowName, windowFeatures);
}
return win;
},
//Reset the scroll on the window
top : function() {
window.scroll(0,0);
},
//Based on YUI onAvailible, but will use any boolean function instead of an ID
doWhen : function(condition, fn, params, scope)
{
this._doWhenStack.push({
check:condition,
fn: fn,
obj: params,
overrideContext: scope
});
this._doWhenretryCount = 50;
this._startDoWhenInterval();
},
_startDoWhenInterval : function(){
if (!this._doWhenInterval) {
this._doWhenInterval = YAHOO.lang.later(50, this, this._doWhenCheck, null, true);
}
},
_doWhenStack : [],
_doWhenInterval : false,
_doWhenCheck : function() {
if (this._doWhenStack.length === 0) {
this._doWhenretryCount = 0;
if (this._doWhenInterval) {
// clearInterval(this._interval);
this._doWhenInterval.cancel();
this._doWhenInterval = null;
}
return;
}
if (this._doWhenLocked) {
return;
}
if (SUGAR.isIE) {
// Hold off if DOMReady has not fired and check current
// readyState to protect against the IE operation aborted
// issue.
if (!YAHOO.util.Event.DOMReady) {
this._startDoWhenInterval();
return;
}
}
this._doWhenLocked = true;
// keep trying until after the page is loaded. We need to
// check the page load state prior to trying to bind the
// elements so that we can be certain all elements have been
// tested appropriately
var tryAgain = YAHOO.util.Event.DOMReady;
if (!tryAgain) {
tryAgain = (this._doWhenretryCount > 0 && this._doWhenStack.length > 0);
}
// onAvailable
var notAvail = [];
var executeItem = function (context, item) {
if (item.overrideContext) {
if (item.overrideContext === true) {
context = item.obj;
} else {
context = item.overrideContext;
}
}
if(item.fn) {
item.fn.call(context, item.obj);
}
};
var i, len, item, test;
// onAvailable onContentReady
for (i=0, len=this._doWhenStack.length; i-1; i--) {
item = this._doWhenStack[i];
if (!item || !item.check) {
this._doWhenStack.splice(i, 1);
}
}
this._startDoWhenInterval();
} else {
if (this._doWhenInterval) {
// clearInterval(this._interval);
this._doWhenInterval.cancel();
this._doWhenInterval = null;
}
}
this._doWhenLocked = false;
},
buildAccessKeyLabels : function() {
if (typeof(Y.env.ua) !== 'undefined'){
envStr = '';
browserOS = Y.env.ua['os'];
isIE = Y.env.ua['ie'];
isCR = Y.env.ua['chrome'];
isFF = Y.env.ua['gecko'];
isWK = Y.env.ua['webkit'];
isOP = Y.env.ua['opera'];
controlKey = '';
//first determine the OS
if(browserOS=='macintosh'){
//we got a mac, lets use the mac specific commands while we check the browser
if(isIE){
//IE on a Mac? Not possible, but let's assign alt anyways for completions sake
controlKey = 'Alt+';
}else if(isWK || isFF){
//Chrome or safari on a mac
//firefox moved to webkit standard starting with FF14
controlKey = 'Ctrl+Opt+';
}else if(isOP){
//Opera on a mac
controlKey = 'Shift+Esc: ';
}else{
//default for everything else on a mac
controlKey = 'Ctrl+';
}
}else{
//this is not a mac so let's use the windows/unix commands while we check the browser
if(isFF){
//FF on windows/unix
controlKey = 'Alt+Shift+';
}else if(isOP){
//Opera on windows/unix
controlKey = 'Shift+Esc: ';
}else {
//this is the default for safari, IE and Chrome
//if this is webkit and is NOT google, then we are most likely looking at Safari
controlKey = 'Alt+';
}
}
//now lets retrieve all elements of type input
allButtons = document.getElementsByTagName('input');
//iterate through list and modify title if the accesskey is not empty
for(i=0;i 0) {
optionList[0].selected = "selected";
}
for ( var ii = 0 ; ii < optionList.length ; ii++ ) {
optionList[ii].selected = false;
}
}
else if ( elemType == 'radio' || elemType == 'checkbox' ) {
elem.checked = false;
elem.selected = false;
}
else if ( elemType == 'hidden' ) {
// We only want to reset the hidden values that link to the select boxes.
// _c custom field kludge added to fix Bug 41384
if ( ( elem.name.length > 3 && elem.name.substring(elem.name.length-3) == '_id' )
|| ((elem.name.length > 9) && (elem.name.substring(elem.name.length - 9) == '_id_basic'))
|| ( elem.name.length > 12 && elem.name.substring(elem.name.length-12) == '_id_advanced' )
|| ( elem.name.length > 2 && elem.name.substring(elem.name.length-2) == '_c' )
|| ((elem.name.length > 8) && (elem.name.substring(elem.name.length - 8) == '_c_basic'))
|| ( elem.name.length > 11 && elem.name.substring(elem.name.length-11) == '_c_advanced' ) )
{
elem.value = '';
}
}
}
SUGAR.savedViews.clearColumns = true;
}
};
}();
// Code for the column/tab chooser used on homepage and in admin section
SUGAR.tabChooser = function () {
var object_refs = new Array();
return {
/* Describe certain transfers as invalid */
frozenOptions: [],
movementCallback: function(left_side, right_side) {},
orderCallback: function(left_side, right_side) {},
freezeOptions: function(left_name, right_name, target) {
if(!SUGAR.tabChooser.frozenOptions) { SUGAR.tabChooser.frozenOptions = []; }
if(!SUGAR.tabChooser.frozenOptions[left_name]) { SUGAR.tabChooser.frozenOptions[left_name] = []; }
if(!SUGAR.tabChooser.frozenOptions[left_name][right_name]) { SUGAR.tabChooser.frozenOptions[left_name][right_name] = []; }
if(typeof target == 'array') {
for(var i in target) {
SUGAR.tabChooser.frozenOptions[left_name][right_name][target[i]] = true;
}
} else {
SUGAR.tabChooser.frozenOptions[left_name][right_name][target] = true;
}
},
buildSelectHTML: function(info) {
var text = "";
return text;
},
left_to_right: function(left_name, right_name, left_size, right_size) {
SUGAR.savedViews.clearColumns = false;
var left_td = document.getElementById(left_name+'_td');
var right_td = document.getElementById(right_name+'_td');
var display_columns_ref = left_td.getElementsByTagName('select')[0];
var hidden_columns_ref = right_td.getElementsByTagName('select')[0];
var selected_left = new Array();
var notselected_left = new Array();
var notselected_right = new Array();
var left_array = new Array();
var frozen_options = SUGAR.tabChooser.frozenOptions;
frozen_options = frozen_options && frozen_options[left_name] && frozen_options[left_name][right_name]?frozen_options[left_name][right_name]:[];
// determine which options are selected in left
for (i=0; i < display_columns_ref.options.length; i++)
{
if ( display_columns_ref.options[i].selected == true && !frozen_options[display_columns_ref.options[i].value])
{
selected_left[selected_left.length] = {text: display_columns_ref.options[i].text, value: display_columns_ref.options[i].value};
}
else
{
notselected_left[notselected_left.length] = {text: display_columns_ref.options[i].text, value: display_columns_ref.options[i].value};
}
}
for (i=0; i < hidden_columns_ref.options.length; i++)
{
notselected_right[notselected_right.length] = {text:hidden_columns_ref.options[i].text, value:hidden_columns_ref.options[i].value};
}
var left_select_html_info = new Object();
var left_options = new Array();
var left_select = new Object();
left_select['name'] = left_name+'[]';
left_select['id'] = left_name;
left_select['size'] = left_size;
left_select['multiple'] = 'true';
var right_select_html_info = new Object();
var right_options = new Array();
var right_select = new Object();
right_select['name'] = right_name+'[]';
right_select['id'] = right_name;
right_select['size'] = right_size;
right_select['multiple'] = 'true';
for (i = 0; i < notselected_right.length; i++) {
right_options[right_options.length] = notselected_right[i];
}
for (i = 0; i < selected_left.length; i++) {
right_options[right_options.length] = selected_left[i];
}
for (i = 0; i < notselected_left.length; i++) {
left_options[left_options.length] = notselected_left[i];
}
left_select_html_info['options'] = left_options;
left_select_html_info['select'] = left_select;
right_select_html_info['options'] = right_options;
right_select_html_info['select'] = right_select;
right_select_html_info['style'] = 'background: lightgrey';
var left_html = this.buildSelectHTML(left_select_html_info);
var right_html = this.buildSelectHTML(right_select_html_info);
left_td.innerHTML = left_html;
right_td.innerHTML = right_html;
object_refs[left_name] = left_td.getElementsByTagName('select')[0];
object_refs[right_name] = right_td.getElementsByTagName('select')[0];
this.movementCallback(object_refs[left_name], object_refs[right_name]);
return false;
},
right_to_left: function(left_name, right_name, left_size, right_size, max_left) {
SUGAR.savedViews.clearColumns = false;
var left_td = document.getElementById(left_name+'_td');
var right_td = document.getElementById(right_name+'_td');
var display_columns_ref = left_td.getElementsByTagName('select')[0];
var hidden_columns_ref = right_td.getElementsByTagName('select')[0];
var selected_right = new Array();
var notselected_right = new Array();
var notselected_left = new Array();
var frozen_options = SUGAR.tabChooser.frozenOptions;
frozen_options = SUGAR.tabChooser.frozenOptions && SUGAR.tabChooser.frozenOptions[right_name] && SUGAR.tabChooser.frozenOptions[right_name][left_name]?SUGAR.tabChooser.frozenOptions[right_name][left_name]:[];
for (i=0; i < hidden_columns_ref.options.length; i++)
{
if (hidden_columns_ref.options[i].selected == true && !frozen_options[hidden_columns_ref.options[i].value])
{
selected_right[selected_right.length] = {text:hidden_columns_ref.options[i].text, value:hidden_columns_ref.options[i].value};
}
else
{
notselected_right[notselected_right.length] = {text:hidden_columns_ref.options[i].text, value:hidden_columns_ref.options[i].value};
}
}
if(max_left != '' && (display_columns_ref.length + selected_right.length) > max_left) {
alert('Maximum of ' + max_left + ' columns can be displayed.');
return;
}
for (i=0; i < display_columns_ref.options.length; i++)
{
notselected_left[notselected_left.length] = {text:display_columns_ref.options[i].text, value:display_columns_ref.options[i].value};
}
var left_select_html_info = new Object();
var left_options = new Array();
var left_select = new Object();
left_select['name'] = left_name+'[]';
left_select['id'] = left_name;
left_select['multiple'] = 'true';
left_select['size'] = left_size;
var right_select_html_info = new Object();
var right_options = new Array();
var right_select = new Object();
right_select['name'] = right_name+ '[]';
right_select['id'] = right_name;
right_select['multiple'] = 'true';
right_select['size'] = right_size;
for (i = 0; i < notselected_left.length; i++) {
left_options[left_options.length] = notselected_left[i];
}
for (i = 0; i < selected_right.length; i++) {
left_options[left_options.length] = selected_right[i];
}
for (i = 0; i < notselected_right.length; i++) {
right_options[right_options.length] = notselected_right[i];
}
left_select_html_info['options'] = left_options;
left_select_html_info['select'] = left_select;
right_select_html_info['options'] = right_options;
right_select_html_info['select'] = right_select;
right_select_html_info['style'] = 'background: lightgrey';
var left_html = this.buildSelectHTML(left_select_html_info);
var right_html = this.buildSelectHTML(right_select_html_info);
left_td.innerHTML = left_html;
right_td.innerHTML = right_html;
object_refs[left_name] = left_td.getElementsByTagName('select')[0];
object_refs[right_name] = right_td.getElementsByTagName('select')[0];
this.movementCallback(object_refs[left_name], object_refs[right_name]);
return false;
},
up: function(name, left_name, right_name) {
SUGAR.savedViews.clearColumns = false;
var left_td = document.getElementById(left_name+'_td');
var right_td = document.getElementById(right_name+'_td');
var td = document.getElementById(name+'_td');
var obj = td.getElementsByTagName('select')[0];
obj = (typeof obj == "string") ? document.getElementById(obj) : obj;
if (obj.tagName.toLowerCase() != "select" && obj.length < 2)
return false;
var sel = new Array();
for (i=0; i-1; i--) {
if (obj[i].selected == true) {
sel[sel.length] = i;
}
}
for (i=0; i < sel.length; i++) {
if (sel[i] != obj.length-1 && !obj[sel[i]+1].selected) {
var tmp = new Array(obj[sel[i]+1].text, obj[sel[i]+1].value);
obj[sel[i]+1].text = obj[sel[i]].text;
obj[sel[i]+1].value = obj[sel[i]].value;
obj[sel[i]].text = tmp[0];
obj[sel[i]].value = tmp[1];
obj[sel[i]+1].selected = true;
obj[sel[i]].selected = false;
}
}
object_refs[left_name] = left_td.getElementsByTagName('select')[0];
object_refs[right_name] = right_td.getElementsByTagName('select')[0];
this.orderCallback(object_refs[left_name], object_refs[right_name]);
return false;
}
};
}(); // end tabChooser
SUGAR.language = function() {
return {
languages : new Array(),
setLanguage: function(module, data) {
if (!SUGAR.language.languages) {
}
SUGAR.language.languages[module] = data;
},
get: function(module, str) {
if(typeof SUGAR.language.languages[module] == 'undefined' || typeof SUGAR.language.languages[module][str] == 'undefined')
{
return 'undefined';
}
return SUGAR.language.languages[module][str];
},
translate: function(module, str)
{
text = this.get(module, str);
return text != 'undefined' ? text : this.get('app_strings', str);
}
}
}();
SUGAR.contextMenu = function() {
return {
objects: new Object(),
objectTypes: new Object(),
/**
* Registers a new object for the context menu.
* objectType - name of the type
* id - element id
* metaData - metaData to pass to the action function
**/
registerObject: function(objectType, id, metaData) {
SUGAR.contextMenu.objects[id] = new Object();
SUGAR.contextMenu.objects[id] = {'objectType' : objectType, 'metaData' : metaData};
},
/**
* Registers a new object type
* name - name of the type
* menuItems - array of menu items
**/
registerObjectType: function(name, menuItems) {
SUGAR.contextMenu.objectTypes[name] = new Object();
SUGAR.contextMenu.objectTypes[name] = {'menuItems' : menuItems, 'objects' : new Array()};
},
/**
* Determines which menu item was clicked
**/
getListItemFromEventTarget: function(p_oNode) {
var oLI;
if(p_oNode.tagName == "LI") {
oLI = p_oNode;
}
else {
do {
if(p_oNode.tagName == "LI") {
oLI = p_oNode;
break;
}
} while((p_oNode = p_oNode.parentNode));
}
return oLI;
},
/**
* handles movement within context menu
**/
onContextMenuMove: function() {
var oNode = this.contextEventTarget;
var bDisabled = (oNode.tagName == "UL");
var i = this.getItemGroups()[0].length - 1;
do {
this.getItem(i).cfg.setProperty("disabled", bDisabled);
}
while(i--);
},
/**
* handles clicks on a context menu ITEM
**/
onContextMenuItemClick: function(p_sType, p_aArguments, p_oItem) {
var oLI = SUGAR.contextMenu.getListItemFromEventTarget(this.parent.contextEventTarget);
id = this.parent.contextEventTarget.parentNode.id; // id of the target
funct = eval(SUGAR.contextMenu.objectTypes[SUGAR.contextMenu.objects[id]['objectType']]['menuItems'][this.index]['action']);
funct(this.parent.contextEventTarget, SUGAR.contextMenu.objects[id]['metaData']);
},
/**
* Initializes all context menus registered
**/
init: function() {
for(var i in SUGAR.contextMenu.objects) { // make a variable called objects in objectTypes containg references to all triggers
if(typeof SUGAR.contextMenu.objectTypes[SUGAR.contextMenu.objects[i]['objectType']]['objects'] == 'undefined')
SUGAR.contextMenu.objectTypes[SUGAR.contextMenu.objects[i]['objectType']]['objects'] = new Array();
SUGAR.contextMenu.objectTypes[SUGAR.contextMenu.objects[i]['objectType']]['objects'].push(document.getElementById(i));
}
// register the menus
for(var i in SUGAR.contextMenu.objectTypes) {
var oContextMenu = new YAHOO.widget.ContextMenu(i, {'trigger': SUGAR.contextMenu.objectTypes[i]['objects']});
var aMainMenuItems = SUGAR.contextMenu.objectTypes[i]['menuItems'];
var nMainMenuItems = aMainMenuItems.length;
var oMenuItem;
for(var j = 0; j < nMainMenuItems; j++) {
oMenuItem = new YAHOO.widget.ContextMenuItem(aMainMenuItems[j].text, { helptext: aMainMenuItems[j].helptext });
oMenuItem.clickEvent.subscribe(SUGAR.contextMenu.onContextMenuItemClick, oMenuItem, true);
oContextMenu.addItem(oMenuItem);
}
// Add a "move" event handler to the context menu
oContextMenu.moveEvent.subscribe(SUGAR.contextMenu.onContextMenuMove, oContextMenu, true);
// Add a "keydown" event handler to the context menu
oContextMenu.keyDownEvent.subscribe(SUGAR.contextMenu.onContextMenuItemClick, oContextMenu, true);
// Render the context menu
oContextMenu.render(document.body);
}
}
};
}();
SUGAR.contextMenu.actions = function() {
return {
/**
* redirects to a new note with the clicked on object as the target
**/
createNote: function(itemClicked, metaData) {
loc = 'index.php?module=Notes&action=EditView';
for(i in metaData) {
if(i == 'notes_parent_type') loc += '&parent_type=' + metaData[i];
else if(i != 'module' && i != 'parent_type') loc += '&' + i + '=' + metaData[i];
}
document.location = loc;
},
/**
* redirects to a new note with the clicked on object as the target
**/
scheduleMeeting: function(itemClicked, metaData) {
loc = 'index.php?module=Meetings&action=EditView';
for(i in metaData) {
if(i != 'module') loc += '&' + i + '=' + metaData[i];
}
document.location = loc;
},
/**
* redirects to a new note with the clicked on object as the target
**/
scheduleCall: function(itemClicked, metaData) {
loc = 'index.php?module=Calls&action=EditView';
for(i in metaData) {
if(i != 'module') loc += '&' + i + '=' + metaData[i];
}
document.location = loc;
},
/**
* redirects to a new contact with the clicked on object as the target
**/
createContact: function(itemClicked, metaData) {
loc = 'index.php?module=Contacts&action=EditView';
for(i in metaData) {
if(i != 'module') loc += '&' + i + '=' + metaData[i];
}
document.location = loc;
},
/**
* redirects to a new task with the clicked on object as the target
**/
createTask: function(itemClicked, metaData) {
loc = 'index.php?module=Tasks&action=EditView';
for(i in metaData) {
if(i != 'module') loc += '&' + i + '=' + metaData[i];
}
document.location = loc;
},
/**
* redirects to a new opportunity with the clicked on object as the target
**/
createOpportunity: function(itemClicked, metaData) {
loc = 'index.php?module=Opportunities&action=EditView';
for(i in metaData) {
if(i != 'module') loc += '&' + i + '=' + metaData[i];
}
document.location = loc;
},
/**
* redirects to a new opportunity with the clicked on object as the target
**/
createCase: function(itemClicked, metaData) {
loc = 'index.php?module=Cases&action=EditView';
for(i in metaData) {
if(i != 'module') loc += '&' + i + '=' + metaData[i];
}
document.location = loc;
},
/**
* handles add to favorites menu selection
**/
addToFavorites: function(itemClicked, metaData) {
success = function(data) {
}
var cObj = YAHOO.util.Connect.asyncRequest('GET', 'index.php?to_pdf=true&module=Home&action=AddToFavorites&target_id=' + metaData['id'] + '&target_module=' + metaData['module'], {success: success, failure: success});
}
};
}();
//if(typeof YAHOO != 'undefined') YAHOO.util.Event.addListener(window, 'load', SUGAR.contextMenu.init);
// initially from popup_parent_helper.js
var popup_request_data;
var close_popup;
function get_popup_request_data()
{
return YAHOO.lang.JSON.stringify(window.document.popup_request_data);
}
function get_close_popup()
{
return window.document.close_popup;
}
function open_popup(module_name, width, height, initial_filter, close_popup, hide_clear_button, popup_request_data, popup_mode, create, metadata)
{
if (typeof(popupCount) == "undefined" || popupCount == 0)
popupCount = 1;
// set the variables that the popup will pull from
window.document.popup_request_data = popup_request_data;
window.document.close_popup = close_popup;
//globally changing width and height of standard pop up window from 600 x 400 to 800 x 800
width = (width == 600) ? 800 : width;
height = (height == 400) ? 800 : height;
// launch the popup
URL = 'index.php?'
+ 'module=' + module_name
+ '&action=Popup';
if (initial_filter != '') {
URL += '&query=true' + initial_filter;
// Bug 41891 - Popup Window Name
popupName = initial_filter.replace(/[^a-z_0-9]+/ig, '_');
windowName = module_name + '_popup_window' + popupName;
} else {
windowName = module_name + '_popup_window' + popupCount;
}
popupCount++;
if (hide_clear_button) {
URL += '&hide_clear_button=true';
}
windowFeatures = 'width=' + width
+ ',height=' + height
+ ',resizable=1,scrollbars=1';
if (popup_mode == '' || popup_mode == undefined) {
popup_mode='single';
}
URL+='&mode='+popup_mode;
if (create == '' || create == undefined) {
create = 'false';
}
URL+='&create='+create;
if (metadata != '' && metadata != undefined) {
URL+='&metadata='+metadata;
}
// Bug #46842 : The relate field field_to_name_array fails to copy over custom fields
// post fields that should be populated from popup form
if(popup_request_data.jsonObject) {
var request_data = popup_request_data.jsonObject;
} else {
var request_data = popup_request_data;
}
var field_to_name_array_url = '';
if (request_data && request_data.field_to_name_array != undefined) {
for(var key in request_data.field_to_name_array) {
if ( key.toLowerCase() != 'id' ) {
field_to_name_array_url += '&field_to_name[]='+encodeURIComponent(key.toLowerCase());
}
}
}
if ( field_to_name_array_url ) {
URL+=field_to_name_array_url;
}
win = SUGAR.util.openWindow(URL, windowName, windowFeatures);
if(window.focus)
{
// put the focus on the popup if the browser supports the focus() method
win.focus();
}
win.popupCount = popupCount;
return win;
}
/**
* The reply data must be a JSON array structured with the following information:
* 1) form name to populate
* 2) associative array of input names to values for populating the form
*/
var from_popup_return = false;
//Function replaces special HTML chars for usage in text boxes
function replaceHTMLChars(value) {
return value.replace(/&/gi,'&').replace(/</gi,'<').replace(/>/gi,'>').replace(/'/gi,'\'').replace(/"/gi,'"');
}
function set_return_basic(popup_reply_data,filter)
{
var form_name = popup_reply_data.form_name;
var name_to_value_array = popup_reply_data.name_to_value_array;
for (var the_key in name_to_value_array)
{
if(the_key == 'toJSON')
{
/* just ignore */
}
else if(the_key.match(filter))
{
var displayValue=replaceHTMLChars(name_to_value_array[the_key]);
// begin andopes change: support for enum fields (SELECT)
if(window.document.forms[form_name] && window.document.forms[form_name].elements[the_key]) {
if(window.document.forms[form_name].elements[the_key].tagName == 'SELECT') {
var selectField = window.document.forms[form_name].elements[the_key];
for(var i = 0; i < selectField.options.length; i++) {
if(selectField.options[i].text == displayValue) {
selectField.options[i].selected = true;
SUGAR.util.callOnChangeListers(selectField);
break;
}
}
} else {
window.document.forms[form_name].elements[the_key].value = displayValue;
SUGAR.util.callOnChangeListers(window.document.forms[form_name].elements[the_key]);
}
}
// end andopes change: support for enum fields (SELECT)
}
}
}
function set_return(popup_reply_data)
{
from_popup_return = true;
var form_name = popup_reply_data.form_name;
var name_to_value_array = popup_reply_data.name_to_value_array;
if(typeof name_to_value_array != 'undefined' && name_to_value_array['account_id'])
{
var label_str = '';
var label_data_str = '';
var current_label_data_str = '';
var popupConfirm = popup_reply_data.popupConfirm;
for (var the_key in name_to_value_array)
{
if(the_key == 'toJSON')
{
/* just ignore */
}
else
{
var displayValue=replaceHTMLChars(name_to_value_array[the_key]);
if(window.document.forms[form_name] && document.getElementById(the_key+'_label') && !the_key.match(/account/)) {
var data_label = document.getElementById(the_key+'_label').innerHTML.replace(/\n/gi,'').replace(/<\/?[^>]+(>|$)/g, "");
label_str += data_label + ' \n';
label_data_str += data_label + ' ' + displayValue + '\n';
if(window.document.forms[form_name].elements[the_key]) {
current_label_data_str += data_label + ' ' + window.document.forms[form_name].elements[the_key].value +'\n';
}
}
}
}
if(label_data_str != label_str && current_label_data_str != label_str){
// Bug 48726 Start
if (typeof popupConfirm != 'undefined')
{
if (popupConfirm > -1) {
set_return_basic(popup_reply_data,/\S/);
} else {
set_return_basic(popup_reply_data,/account/);
}
}
// Bug 48726 End
else if(confirm(SUGAR.language.get('app_strings', 'NTC_OVERWRITE_ADDRESS_PHONE_CONFIRM') + '\n\n' + label_data_str))
{
set_return_basic(popup_reply_data,/\S/);
}
else
{
set_return_basic(popup_reply_data,/account/);
}
}else if(label_data_str != label_str && current_label_data_str == label_str){
set_return_basic(popup_reply_data,/\S/);
}else if(label_data_str == label_str){
set_return_basic(popup_reply_data,/account/);
}
}else{
set_return_basic(popup_reply_data,/\S/);
}
}
function set_return_lead_conv(popup_reply_data) {
set_return(popup_reply_data);
if (document.getElementById('lead_conv_ac_op_sel') && typeof onBlurKeyUpHandler=='function') {
onBlurKeyUpHandler();
}
}
function set_return_and_save(popup_reply_data)
{
var form_name = popup_reply_data.form_name;
var name_to_value_array = popup_reply_data.name_to_value_array;
for (var the_key in name_to_value_array)
{
if(the_key == 'toJSON')
{
/* just ignore */
}
else
{
window.document.forms[form_name].elements[the_key].value = name_to_value_array[the_key];
}
}
window.document.forms[form_name].return_module.value = window.document.forms[form_name].module.value;
window.document.forms[form_name].return_action.value = 'DetailView';
window.document.forms[form_name].return_id.value = window.document.forms[form_name].record.value;
window.document.forms[form_name].action.value = 'Save';
window.document.forms[form_name].submit();
}
/**
* This is a helper function to construct the initial filter that can be
* passed into the open_popup() function. It assumes that there is an
* account_id and account_name field in the given form_name to use to
* construct the intial filter string.
*/
function get_initial_filter_by_account(form_name)
{
var account_id = window.document.forms[form_name].account_id.value;
var account_name = escape(window.document.forms[form_name].account_name.value);
var initial_filter = "&account_id=" + account_id + "&account_name=" + account_name;
return initial_filter;
}
// end code from popup_parent_helper.js
// begin code for address copy
/**
* This is a function used by the Address widget that will fill
* in the given array fields using the fromKey and toKey as a
* prefix into the form objects HTML elements.
*
* @param form The HTML form object to parse
* @param fromKey The prefix of elements to copy from
* @param toKey The prefix of elements to copy into
* @return boolean true if successful, false otherwise
*/
function copyAddress(form, fromKey, toKey) {
var elems = new Array("address_street", "address_city", "address_state", "address_postalcode", "address_country");
var checkbox = document.getElementById(toKey + "_checkbox");
if(typeof checkbox != "undefined") {
if(!checkbox.checked) {
for(x in elems) {
t = toKey + "_" + elems[x];
document.getElementById(t).removeAttribute('readonly');
}
} else {
for(x in elems) {
f = fromKey + "_" + elems[x];
t = toKey + "_" + elems[x];
document.getElementById(t).value = document.getElementById(f).value;
document.getElementById(t).setAttribute('readonly', true);
}
}
}
return true;
}
// end code for address copy
/**
* This function is used in Email Template Module.
* It will check whether the template is used in Campaing->EmailMarketing.
* If true, it will notify user.
*/
function check_deletable_EmailTemplate() {
id = document.getElementsByName('record')[0].value;
currentForm = document.getElementById('form');
var call_back = {
success:function(r) {
if(r.responseText == 'true') {
if(!confirm(SUGAR.language.get('app_strings','NTC_TEMPLATE_IS_USED'))) {
return false;
}
} else {
if(!confirm(SUGAR.language.get('app_strings','NTC_DELETE_CONFIRMATION'))) {
return false;
}
}
currentForm.return_module.value='EmailTemplates';
currentForm.return_action.value='ListView';
currentForm.action.value='Delete';
currentForm.submit();
}
};
url = "index.php?module=EmailTemplates&action=CheckDeletable&from=DetailView&to_pdf=1&record="+id;
YAHOO.util.Connect.asyncRequest('POST',url, call_back,null);
}
SUGAR.image = {
remove_upload_imagefile : function(field_name) {
var field=document.getElementById('remove_imagefile_' + field_name);
field.value=1;
//enable the file upload button.
var field=document.getElementById( field_name);
field.style.display="";
//hide the image and remove button.
var field=document.getElementById('img_' + field_name);
field.style.display="none";
var field=document.getElementById('bt_remove_' + field_name);
field.style.display="none";
if(document.getElementById(field_name + '_duplicate')) {
var field = document.getElementById(field_name + '_duplicate');
field.value = "";
}
},
confirm_imagefile : function(field_name) {
var field=document.getElementById(field_name);
var filename=field.value;
var fileExtension = filename.substring(filename.lastIndexOf(".")+1);
fileExtension = fileExtension.toLowerCase();
if (fileExtension == "jpg" || fileExtension == "jpeg"
|| fileExtension == "gif" || fileExtension == "png" || fileExtension == "bmp"){
//image file
}
else{
field.value=null;
alert(SUGAR.language.get('app_strings', 'LBL_UPLOAD_IMAGE_FILE_INVALID'));
}
},
lightbox : function(image)
{
if (typeof(SUGAR.image.lighboxWindow) == "undefined")
SUGAR.image.lighboxWindow = new YAHOO.widget.SimpleDialog('sugarImageViewer', {
type:'message',
modal:true,
id:'sugarMsgWindow',
close:true,
title:"Alert",
msg: " ",
buttons: [ ]
});
SUGAR.image.lighboxWindow.setBody(" ");
SUGAR.image.lighboxWindow.render(document.body);
SUGAR.image.lighboxWindow.show();
SUGAR.image.lighboxWindow.center()
}
}
SUGAR.append(SUGAR.util, {
isTouchScreen: function() {
// first check if we have forced use of the touch enhanced interface
if (Get_Cookie("touchscreen") == '1') {
return true;
}
// next check if we should use the touch interface with our device
if ((navigator.userAgent.match(/iPad/i) != null)) {
return true;
}
return false;
},
isLoginPage: function(content) {
//skip if this is packageManager screen
if(SUGAR.util.isPackageManager()) {return false;}
var loginPageStart = "") != -1 && content.indexOf("login_module") != -1) {
window.location.href = window.location.protocol + window.location.pathname;
return true;
}
},
isPackageManager: function(){
if(typeof(document.the_form) !='undefined' && typeof(document.the_form.language_pack_escaped) !='undefined'){
return true;
}else{return false;}
},
ajaxCallInProgress: function(){
var t = true;
//First check if we are in a popup.
if (typeof (send_back) != "function"){
//If the page content is blank, it means we are probably still waiting on something
var c = document.getElementById("content");
if (!c) return true;
t = YAHOO.lang.trim(SUGAR.util.innerText(c));
}
return SUGAR_callsInProgress != 0 || t == "";
},
//Firefox doesn't support innerText (textContent includes script content)
innerText : function(el) {
if (el.tagName == "SCRIPT")
return "";
if(typeof(el.innerText) == "string")
return el.innerText;
var t = "";
for (var i in el.childNodes){
var c = el.childNodes[i];
if (typeof(c) != "object")
continue;
if (typeof(c.nodeName) == "string" && c.nodeName == "#text")
t += c.nodeValue;
else
t += SUGAR.util.innerText(c);
}
return t;
},
callOnChangeListers: function(field){
var listeners = YAHOO.util.Event.getListeners(field, 'change');
if (listeners != null) {
for (var i = 0; i < listeners.length; i++) {
var l = listeners[i];
l.fn.call(l.scope ? l.scope : this, l.obj);
}
}
},
closeActivityPanel: {
show:function(module,id,new_status,viewType,parentContainerId){
if (SUGAR.util.closeActivityPanel.panel)
SUGAR.util.closeActivityPanel.panel.destroy();
var singleModule = SUGAR.language.get("app_list_strings", "moduleListSingular")[module];
singleModule = typeof(singleModule != 'undefined') ? singleModule.toLowerCase() : '';
var closeText = SUGAR.language.get("app_strings", "LBL_CLOSE_ACTIVITY_CONFIRM").replace("#module#",singleModule);
SUGAR.util.closeActivityPanel.panel =
new YAHOO.widget.SimpleDialog("closeActivityDialog",
{ width: "300px",
fixedcenter: true,
visible: false,
draggable: false,
close: true,
text: closeText,
constraintoviewport: true,
buttons: [ { text:SUGAR.language.get("app_strings", "LBL_EMAIL_OK"), handler:function(){
if (SUGAR.util.closeActivityPanel.panel)
SUGAR.util.closeActivityPanel.panel.hide();
ajaxStatus.showStatus(SUGAR.language.get('app_strings', 'LBL_SAVING'));
var args = "action=save&id=" + id + "&record=" + id + "&status=" + new_status + "&module=" + module;
// 20110307 Frank Steegmans: Fix for bug 42361, Any field with a default configured in any activity will be set to this default when closed using the close dialog
// TODO: Take id out and regression test. Left id in for now to not create any other unexpected problems
//var args = "action=save&id=" + id + "&status=" + new_status + "&module=" + module;
var callback = {
success:function(o)
{
// Bug 51984: We need to submit the form just incase we have a form already submitted
// so we dont get a popup stating that the form needs to be resubmitted like it doesn,
// when you do a reload/refresh
window.setTimeout(function(){if(document.getElementById('search_form')) document.getElementById('search_form').submit(); else window.location.reload(true);}, 0);
},
argument:{'parentContainerId':parentContainerId}
};
YAHOO.util.Connect.asyncRequest('POST', 'index.php', callback, args);
}, isDefault:true },
{ text:SUGAR.language.get("app_strings", "LBL_EMAIL_CANCEL"), handler:function(){SUGAR.util.closeActivityPanel.panel.hide(); }} ]
} );
SUGAR.util.closeActivityPanel.panel.setHeader(SUGAR.language.get("app_strings", "LBL_CLOSE_ACTIVITY_HEADER"));
SUGAR.util.closeActivityPanel.panel.render(document.body);
SUGAR.util.closeActivityPanel.panel.show();
}
},
setEmailPasswordDisplay: function(id, exists, formName) {
link = document.getElementById(id+'_link');
pwd = document.getElementById(id);
if(!pwd || !link) return;
if(exists) {
pwd.style.display = 'none';
link.style.display = '';
if(typeof(formName) != 'undefined')
removeFromValidate(formName, id);
} else {
pwd.style.display = '';
link.style.display = 'none';
}
},
setEmailPasswordEdit: function(id) {
link = document.getElementById(id+'_link');
pwd = document.getElementById(id);
if(!pwd || !link) return;
pwd.style.display = '';
link.style.display = 'none';
},
/**
* Compares a filename with a supplied array of allowed file extensions.
* @param fileName string
* @param allowedTypes array of allowed file extensions
* @return bool
*/
validateFileExt: function(fileName, allowedTypes) {
var ext = fileName.split('.').pop().toLowerCase();
for (var i = allowedTypes.length; i >= 0; i--) {
if (ext === allowedTypes[i]) {
return true;
}
}
return false;
},
arrayIndexOf: function(arr, val, start) {
if (typeof arr.indexOf == "function")
return arr.indexOf(val, start);
for (var i = (start || 0), j = arr.length; i < j; i++) {
if (arr[i] === val) {
return i;
}
}
return -1;
}
});
SUGAR.clearRelateField = function(form, name, id)
{
if (typeof form[name] == "object"){
form[name].value = '';
SUGAR.util.callOnChangeListers(form[name]);
}
if (typeof form[id] == "object"){
form[id].value = '';
SUGAR.util.callOnChangeListers(form[id]);
}
};
if(typeof(SUGAR.AutoComplete) == 'undefined') SUGAR.AutoComplete = {};
SUGAR.AutoComplete.getOptionsArray = function(options_index){
var return_arr = [];
var opts = SUGAR.language.get('app_list_strings', options_index);
if(typeof(opts) != 'undefined'){
for(key in opts){
// Since we are using auto complete, we excluse blank dropdown entries since they can just leave it blank
if(key != '' && opts[key] != ''){
var item = [];
item['key'] = key;
item['text'] = opts[key];
return_arr.push(item);
}
}
}
return return_arr;
}
if(typeof(SUGAR.MultiEnumAutoComplete) == 'undefined') SUGAR.MultiEnumAutoComplete = {};
SUGAR.MultiEnumAutoComplete.getMultiSelectKeysFromValues = function(options_index, val_string){
var opts = SUGAR.language.get('app_list_strings', options_index);
var selected_values = val_string.split(", ");
// YUI AutoComplete adds a blank. We remove it automatically here
if(selected_values.length > 0 && selected_values.indexOf('') == selected_values.length - 1){
selected_values.pop();
}
var final_arr = new Array();
for(idx in selected_values){
for(o_idx in opts){
if(selected_values[idx] == opts[o_idx]){
final_arr.push(o_idx);
}
}
}
return final_arr;
}
SUGAR.MultiEnumAutoComplete.getMultiSelectValuesFromKeys = function(options_index, val_string){
var opts = SUGAR.language.get('app_list_strings', options_index);
val_string=val_string.replace(/^\^/,'').replace(/\^$/,'') //fixes bug where string starts or ends with ^
var selected_values = val_string.split("^,^");
// YUI AutoComplete adds a blank. We remove it automatically here
if(selected_values.length > 0 && selected_values.indexOf('') == selected_values.length - 1){
selected_values.pop();
}
var final_arr = new Array();
for(idx in selected_values){
for(o_idx in opts){
if(selected_values[idx] == o_idx){
final_arr.push(opts[o_idx]);
}
}
}
return final_arr;
}