1 /*********************************************************************************
2 * SugarCRM Community Edition is a customer relationship management program developed by
3 * SugarCRM, Inc. Copyright (C) 2004-2011 SugarCRM Inc.
5 * This program is free software; you can redistribute it and/or modify it under
6 * the terms of the GNU Affero General Public License version 3 as published by the
7 * Free Software Foundation with the addition of the following permission added
8 * to Section 15 as permitted in Section 7(a): FOR ANY PART OF THE COVERED WORK
9 * IN WHICH THE COPYRIGHT IS OWNED BY SUGARCRM, SUGARCRM DISCLAIMS THE WARRANTY
10 * OF NON INFRINGEMENT OF THIRD PARTY RIGHTS.
12 * This program is distributed in the hope that it will be useful, but WITHOUT
13 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14 * FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
17 * You should have received a copy of the GNU Affero General Public License along with
18 * this program; if not, see http://www.gnu.org/licenses or write to the Free
19 * Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
22 * You can contact SugarCRM, Inc. headquarters at 10050 North Wolfe Road,
23 * SW2-130, Cupertino, CA 95014, USA. or at email address contact@sugarcrm.com.
25 * The interactive user interfaces in modified source and object code versions
26 * of this program must display Appropriate Legal Notices, as required under
27 * Section 5 of the GNU Affero General Public License version 3.
29 * In accordance with Section 7(b) of the GNU Affero General Public License version 3,
30 * these Appropriate Legal Notices must retain the display of the "Powered by
31 * SugarCRM" logo. If the display of the logo is not reasonably feasible for
32 * technical reasons, the Appropriate Legal Notices must display the words
33 * "Powered by SugarCRM".
34 ********************************************************************************/
39 SUGAR.dashlets = function() {
42 * Generic javascript method to use post a form
44 * @param object theForm pointer to the form object
45 * @param function callback function to call after for form is sent
49 postForm: function(theForm, callback) {
50 var success = function(data) {
52 callback(data.responseText);
55 YAHOO.util.Connect.setForm(theForm);
56 var cObj = YAHOO.util.Connect.asyncRequest('POST', 'index.php', {success: success, failure: success});
60 * Generic javascript method to use Dashlet methods
62 * @param string dashletId Id of the dashlet being call
63 * @param string methodName method to be called (function in the dashlet class)
64 * @param string postData data to send (eg foo=bar&foo2=bar2...)
65 * @param bool refreshAfter refreash the dashlet after sending data
66 * @param function callback function to be called after dashlet is refreshed (or not refresed)
68 callMethod: function(dashletId, methodName, postData, refreshAfter, callback) {
69 ajaxStatus.showStatus(SUGAR.language.get('app_strings', 'LBL_SAVING'));
70 response = function(data) {
71 ajaxStatus.hideStatus();
72 if(refreshAfter) SUGAR.mySugar.retrieveDashlet(dashletId);
74 callback(data.responseText);
77 post = 'to_pdf=1&module=Home&action=CallMethodDashlet&method=' + methodName + '&id=' + dashletId + '&' + postData;
78 var cObj = YAHOO.util.Connect.asyncRequest('POST','index.php',
79 {success: response, failure: response}, post);
84 if(SUGAR.util.isTouchScreen() && typeof iScroll == 'undefined') {
86 with (document.getElementsByTagName("head")[0].appendChild(document.createElement("script")))
88 setAttribute("id", "newScript", 0);
89 setAttribute("type", "text/javascript", 0);
90 setAttribute("src", "include/javascript/iscroll.js", 0);