三生石上 15588d275b v4.2.4.1
2017-09-05 10:49:48 +08:00

1473 lines
52 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

// FineUI应用程序域
var F = function (cmpName) {
return Ext.getCmp(cmpName);
};
F.target = function (target) {
return F.util.getTargetWindow(target);
};
F.alert = function () {
F.util.alert.apply(window, arguments);
};
F.init = function () {
F.util.init.apply(window, arguments);
};
F.load = function () {
F.util.load.apply(window, arguments);
};
F.ready = function () {
F.util.ready.apply(window, arguments);
};
F.ajaxReady = function () {
F.util.ajaxReady.apply(window, arguments);
//if (typeof (onAjaxReady) == 'function') {
// onAjaxReady();
//}
};
F.beforeAjax = function () {
F.util.beforeAjax.apply(window, arguments);
};
F.beforeAjaxSuccess = function () {
F.util.beforeAjaxSuccess.apply(window, arguments);
};
F.stop = function () {
var event = arguments.callee.caller.arguments[0] || window.event;
F.util.stopEventPropagation(event);
};
F.confirm = function () {
F.util.confirm.apply(null, arguments);
};
F.toggle = function (el, className) {
Ext.get(el).toggleCls(className);
};
F.fieldValue = function (cmp) {
return F.util.getFormFieldValue(cmp);
};
F.getHidden = function () {
return F.util.getHiddenFieldValue.apply(window, arguments);
};
F.setHidden = function () {
return F.util.setHiddenFieldValue.apply(window, arguments);
};
F.addCSS = function () {
F.util.addCSS.apply(window, arguments);
};
F.initTreeTabStrip = function () {
F.util.initTreeTabStrip.apply(window, arguments);
};
F.addMainTab = function () {
F.util.addMainTab.apply(window, arguments);
};
F.getActiveWindow = function () {
return F.wnd.getActiveWindow.apply(window, arguments);
};
// 记录最后一个控件的序号
F.f_objectIndex = 0;
// 标识这个页面是由 FineUI 创建的
F.fineui = '4.2.4';
// 为了兼容保留函数签名F.customEvent
F.f_customEvent = F.customEvent = function (argument, validate) {
//var pmv = F.f_pagemanager.validate;
//if (validate && pmv) {
// if (!F.util.validForms(pmv.forms, pmv.target, pmv.messagebox)) {
// return false;
// }
//}
//__doPostBack(F.f_pagemanager.name, argument);
var enableAjax;
if (typeof(argument) === 'boolean') {
enableAjax = argument;
argument = validate;
validate = arguments[2];
}
var pmv = F.f_pagemanager.validate;
if (validate && pmv) {
if (!F.util.validForms(pmv.forms, pmv.target, pmv.messagebox)) {
return false;
}
}
if (typeof (enableAjax) === 'boolean') {
__doPostBack(enableAjax, F.f_pagemanager.name, argument);
} else {
__doPostBack(F.f_pagemanager.name, argument);
}
};
// 更新EventValidation的值
F.f_eventValidation = function (newValue) {
F.setHidden("__EVENTVALIDATION", newValue);
};
F.f_state = function (cmp, state) {
F.util.setFState(cmp, state);
};
// 为了兼容保留函数签名F.enable
F.f_enable = F.enable = function (id) {
F.util.enableSubmitControl(id);
};
// 为了兼容保留函数签名F.disable
F.f_disable = F.disable = function (id) {
F.util.disableSubmitControl(id);
};
// 更新ViewState的值
F.f_viewState = function (viewStateBeforeAJAX, newValue, startIndex) {
var viewStateHiddenFiledId = '__VIEWSTATE';
var oldValue = F.getHidden(viewStateHiddenFiledId);
var viewStateChanged = false;
if (oldValue !== viewStateBeforeAJAX) {
viewStateChanged = true;
}
if (typeof (newValue) === 'undefined') {
// AJAX过程中ViewState值没变化
if (viewStateChanged) {
F.setHidden(viewStateHiddenFiledId, viewStateBeforeAJAX);
}
} else {
// AJAX过程中ViewState值有变化
if (Ext.type(startIndex) === 'number' && startIndex > 0) {
// 只返回startIndex之后的内容
if (viewStateChanged) {
// 无法处理!
return false;
} else {
F.setHidden(viewStateHiddenFiledId, oldValue.substr(0, startIndex) + newValue);
}
} else {
// 返回完整的ViewState
F.setHidden(viewStateHiddenFiledId, newValue);
}
}
// 更新成功!
return true;
};
// cookie('theme');
// cookie('theme', 'gray');
// cookie('theme', 'gray', { 'expires': 3 });
// expires: 天
// 新增 或者 修改Cookie
F.cookie = function (key, value, options) {
if (typeof (value) === 'undefined') {
var cookies = document.cookie ? document.cookie.split('; ') : [];
var result = key ? '' : {};
Ext.Array.each(cookies, function (cookie, index) {
var parts = cookie.split('=');
var partName = decodeURIComponent(Ext.String.trim(parts[0]));
var partValue = decodeURIComponent(Ext.String.trim(parts[1]));
if (key) {
if (key === partName) {
result = partValue;
return false;
}
} else {
result[partName] = partValue;
}
});
return result;
} else {
// Set cookie
options = Ext.apply(options || {}, {
path: '/'
});
var expTime;
if (typeof (options.expires) === 'number') {
expTime = new Date();
expTime.setTime(expTime.getTime() + options.expires * 24 * 60 * 60 * 1000);
}
document.cookie = [
encodeURIComponent(key), '=', encodeURIComponent(value),
options.expires ? '; expires=' + expTime.toUTCString() : '',
options.path ? '; path=' + options.path : '',
options.domain ? '; domain=' + options.domain : '',
options.secure ? '; secure' : ''
].join('');
}
};
// 删除Cookie
F.removeCookie = function (key, options) {
options = Ext.apply(options || {}, {
path: '/',
'expires': -1
});
F.cookie(key, '', options);
};
// 能否访问 iframe 中的 window.F 对象
F.canAccess = function (iframeWnd) {
// 访问 iframeWnd.F 时,可能出现错误 Blocked a frame with origin "http://fineui.com/" from accessing a cross-origin frame.
// Blocked这个问题出现在 http://fineui.com/ 页面加载一个 http://baidu.com/ 的 iframe 页面
try {
iframeWnd.F;
iframeWnd.window;
} catch (e) {
return false;
}
if (!iframeWnd.F || !iframeWnd.window) {
return false;
}
return true;
};
Ext.onReady(function () {
// 加延迟,以保证在 zh_CN 中通过 Ext.onReady 注册的脚本先执行(其中对 Ext.Date 进行了初始化)
window.setTimeout(function () {
F.util.triggerLoad();
F.util.triggerReady();
F.util.hidePageLoading();
}, 0);
});
(function () {
// 遍历定义了 renderTo 属性的对象
// callback: 'return false' to prevent loop continue
function resolveRenderToObj(callback) {
Ext.ComponentManager.each(function (key, cmp) {
if (cmp.isXType && cmp.renderTo) {
var result = callback.apply(cmp, [cmp]);
if (result === false) {
return false; // break
}
}
});
}
/*
// 能否访问 iframe 中的 window.F 对象
function canIFrameWindowAccessed(iframeWnd) {
// 访问 iframeWnd.F 时,可能出现错误 Blocked a frame with origin "http://fineui.com/" from accessing a cross-origin frame.
// Blocked这个问题出现在 http://fineui.com/ 页面加载一个 http://baidu.com/ 的 iframe 页面
try {
iframeWnd.F;
} catch (e) {
return false;
}
if (!iframeWnd.F) {
return false;
}
return true;
}
*/
// FineUI常用函数域Utility
F.util = {
alertTitle: "Alert Dialog",
confirmTitle: "Confirm Dialog",
formAlertMsg: "Please provide valid value for {0}!",
formAlertTitle: "Form Invalid",
loading: "Loading...",
// 下拉列表的模板
ddlTPL: '<tpl for="."><div class="x-boundlist-item<tpl if="!enabled"> x-boundlist-item-disabled</tpl>">{prefix}{text}</div></tpl>',
// 初始化
init: function (options) { // msgTarget, labelWidth, labelSeparator, blankImageUrl, enableAjaxLoading, ajaxLoadingType, enableAjax, themeName, formChangeConfirm) {
Ext.apply(F, options, {
language: 'zh_CN',
msgTarget: 'side',
labelWidth: 100,
labelSeparator: '',
//blankImageUrl: '',
enableAjaxLoading: true,
ajaxLoadingType: 'default',
enableAjax: true,
theme: 'neptune',
formChangeConfirm: false,
ajaxTimeout: 120
});
// Ext.QuickTips.init(true); 在原生的IE7非IE8下的IE7模式会有问题
// 表现为iframe中的页面出现滚动条时页面上的所有按钮都不能点击了。
// 测试例子在aspnet/test.aspx
//Ext.QuickTips.init(false);
Ext.tip.QuickTipManager.init();
F.ajax.hookPostBack();
//F.global_enable_ajax = F.enableAjax;
//F.global_enable_ajax_loading = F.enableAjaxLoading;
//F.global_ajax_loading_type = F.ajaxLoadingType;
// 添加Ajax Loading提示节点
F.ajaxLoadingDefault = Ext.get(F.util.appendLoadingNode());
F.ajaxLoadingMask = Ext.create('Ext.LoadMask', Ext.getBody(), { msg: F.util.loading });
//F.form_upload_file = false;
//F.global_disable_ajax = false;
//F.x_window_manager = new Ext.WindowManager();
//F.x_window_manager.zseed = 6000;
F.util.setHiddenFieldValue('F_CHANGED', 'false');
document.forms[0].autocomplete = 'off';
Ext.getBody().addCls('f-body');
Ext.Ajax.timeout = F.ajaxTimeout * 1000;
// 向document.body添加主题类
if (F.theme) {
Ext.getBody().addCls('f-theme-' + F.theme);
}
if (Ext.form.field) {
var fieldPro = Ext.form.field.Base.prototype;
fieldPro.msgTarget = F.msgTarget;
fieldPro.labelWidth = F.labelWidth;
fieldPro.labelSeparator = F.labelSeparator;
fieldPro.autoFitErrors = true;
}
if (Ext.form.CheckboxGroup) {
var checkboxgroupPro = Ext.form.CheckboxGroup.prototype;
checkboxgroupPro.msgTarget = F.msgTarget;
checkboxgroupPro.labelWidth = F.labelWidth;
checkboxgroupPro.labelSeparator = F.labelSeparator;
checkboxgroupPro.autoFitErrors = true;
}
F.beforeunloadCheck = true;
// 启用表单改变确认对话框
if (F.formChangeConfirm) {
// 下面这个方法在 Chrome、 Firefox下无效
//Ext.EventManager.on(window, 'beforeunload', function (event) {
window.onbeforeunload = function () {
// 允许关闭页面前提示,并且表单改变
if (F.beforeunloadCheck && F.util.formChanged()) {
return F.wnd.formChangeConfirmMsg;
}
};
}
//if (enableBigFont) {
// Ext.getBody().addCls('bigfont');
//}
/*
// IE6&7不支持IE8以上支持""
if (Ext.isIE6 || Ext.isIE7) {
Ext.BLANK_IMAGE_URL = F.blankImageUrl;
}
*/
// Submit
F.ready(function () {
if (F.submitbutton) {
Ext.ComponentManager.each(function (key, cmp) {
if (cmp.isXType && cmp.renderTo) {
if (cmp.isXType('tooltip')) {
return true; // continue
}
if (cmp.isXType('panel') || cmp.isXType('formviewport')) {
F.util.registerPanelEnterKey(cmp);
}
}
});
}
});
// 为了防止【页面中只有一个input[type=text]则回车会提交表单】的问题现在页面上创建一个input[type=text]的空元素
F.util.appendFormNode('<input type="text" class="f-input-text-hidden">');
},
_readyList: [],
_ajaxReadyList: [],
_beforeAjaxList: [],
_beforeAjaxSuccessList: [],
_loadList: [],
ready: function (callback) {
F.util._readyList.push(callback);
},
triggerReady: function () {
Ext.Array.each(F.util._readyList, function (item, index) {
item.apply(window);
});
},
ajaxReady: function (callback) {
F.util._ajaxReadyList.push(callback);
},
triggerAjaxReady: function () {
Ext.Array.each(F.util._ajaxReadyList, function (item, index) {
item.apply(window);
});
},
beforeAjax: function (callback) {
F.util._beforeAjaxList.push(callback);
},
triggerBeforeAjax: function () {
var result = true, args = arguments;
Ext.Array.each(F.util._beforeAjaxList, function (item, index) {
if (item.apply(window, args) === false) {
result = false;
}
});
return result;
},
beforeAjaxSuccess: function (callback) {
F.util._beforeAjaxSuccessList.push(callback);
},
triggerBeforeAjaxSuccess: function () {
var result = true, args = arguments;
Ext.Array.each(F.util._beforeAjaxSuccessList, function (item, index) {
if (item.apply(window, args) === false) {
result = false;
}
});
return result;
},
load: function (callback) {
F.util._loadList.push(callback);
},
triggerLoad: function () {
Ext.Array.each(F.util._loadList, function (item, index) {
item.apply(window);
});
},
setFState: function (cmp, state) {
if (!cmp || !cmp['f_state']) {
return;
}
var oldValue, newValue, el;
// 如果state中包含CssClass也就是在服务器端修改了CssClass属性则需要首先删除原来的CssClass属性。
if (typeof (state['CssClass']) !== 'undefined') {
newValue = state['CssClass'];
oldValue = cmp['f_state']['CssClass'];
if (!oldValue) {
oldValue = cmp.initialConfig.cls;
}
el = cmp.el;
el.removeCls(oldValue);
el.addCls(newValue);
}
//if (typeof (state['FormItemClass']) !== 'undefined') {
// newValue = state['FormItemClass'];
// oldValue = cmp['f_state']['FormItemClass'];
// if (!oldValue) {
// oldValue = cmp.initialConfig.itemCls;
// }
// // Search for max 10 depth.
// el = cmp.el.findParent('.x-form-item', 10, true);
// el.removeCls(oldValue);
// el.addCls(newValue);
//}
Ext.apply(cmp['f_state'], state);
},
stopEventPropagation: function (event) {
event = event || window.event;
if (typeof (event.cancelBubble) === 'boolean') {
event.cancelBubble = true;
} else {
event.stopPropagation();
}
},
// 绑定函数的上下文
bind: function (fn, scope) {
return function () {
return fn.apply(scope, arguments);
};
},
// 在页面上查找id为findId的节点替换成replaceHtml
replace: function (findId, replaceHtml) {
// 在findId外面添加一个DIV层然后更新此wrapper的InnerHTML
var findedControl = Ext.get(findId);
if (findedControl) {
var wrapper = findedControl.wrap().update(replaceHtml);
// 将新增的节点移到wrapper上面
wrapper.first().insertBefore(wrapper);
// 然后删除wrapper
wrapper.remove();
}
},
// 隐藏PageLoading节点
hidePageLoading: function () {
/*
if (fadeOut) {
Ext.get("loading").remove();
Ext.get("loading-mask").fadeOut({ remove: true });
}
else {
Ext.get("loading").remove();
Ext.get("loading-mask").remove();
}
*/
Ext.get("loading").hide();
Ext.get("loading-mask").hide();
},
// 去掉字符串中的html标签
stripHtmlTags: function (str) {
return str.replace(/<[^>]*>/g, "");
},
// 向页面添加Loading...节点
appendLoadingNode: function () {
return F.util.appendFormNode({ tag: 'div', id: 'f_ajax_loading', cls: 'f-ajax-loading', html: F.util.loading });
},
// 向页面的 form 节点最后添加新的节点
appendFormNode: function (htmlOrObj) {
return Ext.DomHelper.append(document.forms[0], htmlOrObj);
},
// 向页面添加一个隐藏字段,如果已经存在则更新值
setHiddenFieldValue: function (fieldId, fieldValue) {
var itemNode = Ext.get(fieldId);
if (!itemNode) {
// Ext.DomHelper.append 有问题,例如下面这个例子得到的结果是错的;变通一下,先插入节点,在设置节点的值。
// Ext.DomHelper.append(document.forms[0], { tag: "input", type: "hidden", value: '{"X_Items":[["Value1","可选项1",1],["Value2","可选项2不可选择",0],["Value3","可选项3不可选择",0],["Value4","可选项4",1],["Value5","可选项5",1],["Value6","可选项6",1],["Value7","可选择项7",1],["Value8","可选择项8",1],["Value9","可选择项9",1]],"SelectedValue":"Value1"}'});
// 上面的这个字符串在IETest的IE8模式下会变成
// {"DropDownList1":{"X_Items":[["Value1","\u9009\u9879 1",1],["Value2","\u9009\u9879 2\uff08\u4e0d\u53ef\u9009\u62e9\uff09",0],["Value3","\u9009\u9879 3\uff08\u4e0d\u53ef\u9009\u62e9\uff09",0],["Value4","\u9009\u9879 4",1],["Value5","\u9009\u9879 5",1],["Value6","\u9009\u9879 6",1],["Value7","\u9009\u9879 7",1],["Value8","\u9009\u9879 8",1],["Value9","\u9009\u9879 9",1]],"SelectedValue":"Value1"}}
F.util.appendFormNode({ tag: "input", type: "hidden", id: fieldId, name: fieldId });
Ext.get(fieldId).dom.value = fieldValue;
}
else {
itemNode.dom.value = fieldValue;
}
},
// 从表单中删除隐藏字段
removeHiddenField: function (fieldId) {
var itemNode = Ext.get(fieldId);
if (itemNode) {
itemNode.remove();
}
},
// 获取页面中一个隐藏字段的值
getHiddenFieldValue: function (fieldId) {
var itemNode = Ext.get(fieldId);
if (itemNode) {
return itemNode.getValue();
}
return null;
},
// 禁用提交按钮(在回发之前禁用以防止重复提交)
disableSubmitControl: function (controlClientID) {
F(controlClientID).disable();
F.util.setHiddenFieldValue('F_TARGET', controlClientID);
},
// 启用提交按钮(在回发之后启用提交按钮)
enableSubmitControl: function (controlClientID) {
F(controlClientID).enable();
F.util.setHiddenFieldValue('F_TARGET', '');
},
/*
// 更新ViewState的值
updateViewState: function (newValue, startIndex, gzipped) {
if (typeof (startIndex) === 'boolean') {
gzipped = startIndex;
startIndex = -1;
}
var viewStateHiddenFiledID = "__VIEWSTATE";
if (gzipped) {
viewStateHiddenFiledID = "__VIEWSTATE_GZ";
}
var oldValue = F.util.getHiddenFieldValue(viewStateHiddenFiledID);
if (Ext.type(startIndex) == "number" && startIndex > 0) {
if (startIndex < oldValue.length) {
oldValue = oldValue.substr(0, startIndex);
}
} else {
// Added on 2011-5-2, this is a horrible mistake.
oldValue = '';
}
F.util.setHiddenFieldValue(viewStateHiddenFiledID, oldValue + newValue);
},
// 更新EventValidation的值
updateEventValidation: function (newValue) {
F.util.setHiddenFieldValue("__EVENTVALIDATION", newValue);
},
*/
// 设置页面状态是否改变
setPageStateChanged: function (changed) {
var pageState = Ext.get("F_CHANGED");
if (pageState) {
pageState.dom.value = changed;
}
},
// 页面状态是否改变
isPageStateChanged: function () {
var pageState = Ext.get("F_CHANGED");
if (pageState && pageState.getValue() == "true") {
return true;
}
return false;
},
// 阻止页面关闭页面中iframe内的表单已改变或者页面中iframe定义了beforeunload
preventPageClose: function (el) {
var me = this;
// 是否阻止关闭
var preventClose = false;
var iframeEls;
if (el) {
iframeEls = el.select('iframe');
} else {
iframeEls = Ext.select('iframe');
}
iframeEls.each(function (iframeEl) {
var iframeWnd = iframeEl.dom.contentWindow;
if (!F.canAccess(iframeWnd)) {
return true; // continue
}
if (iframeWnd && iframeWnd.F) {
var iframeF = iframeWnd.F;
// 启用表单改变确认对话框 并且 表单已改变
if (iframeF.formChangeConfirm && iframeF.util.formChanged()) {
// 阻止关闭当前面板
if (!window.confirm(F.wnd.formChangeConfirmMsg)) {
preventClose = true;
return false; // break
} else {
// 没有阻止,不要在触发 $(window).beforeunload 事件了
iframeF.beforeunloadCheck = false;
}
}
/*
// 是否自定义了 beforeunload 事件
var beforeunloadCallbacks = iframeF.util._fjs_getEvent('beforeunload');
if (beforeunloadCallbacks) {
for (var i = 0, count = beforeunloadCallbacks.length; i < count; i++) {
var beforeunloadCallback = beforeunloadCallbacks[i];
var confirmMsg = beforeunloadCallback.apply(iframeWnd);
if (confirmMsg) {
// 阻止关闭当前面板
if (!window.confirm(confirmMsg)) {
preventClose = true;
return false; // break
} else {
// 没有阻止,不要在触发 $(window).beforeunload 事件了
iframeF.beforeunloadCheck = false;
}
}
}
}
*/
// 子页面是否阻止关闭
var childrenPreventClose = iframeF.util.preventPageClose();
if (childrenPreventClose) {
// 被子页面阻止了,则恢复父页面的 beforeunloadCheck 标识
iframeF.beforeunloadCheck = true;
preventClose = true;
return false; // break
}
}
});
return preventClose;
},
// 页面中表单字段是否改变
formChanged: function () {
var changed = false;
resolveRenderToObj(function (obj) {
if (obj.isXType('container') && obj.f_isDirty()) {
changed = true;
return false; // break
}
});
return changed;
},
// 验证多个表单,返回数组[是否验证通过,第一个不通过的表单字段]
validForms: function (forms, targetName, showBox) {
var target = F.util.getTargetWindow(targetName);
var valid = true;
var firstInvalidField = null;
for (var i = 0; i < forms.length; i++) {
var result = F(forms[i]).f_isValid();
if (!result[0]) {
valid = false;
if (firstInvalidField == null) {
firstInvalidField = result[1];
}
}
}
if (!valid) {
if (showBox) {
var alertMsg = Ext.String.format(F.util.formAlertMsg, firstInvalidField.fieldLabel);
target.F.util.alert(alertMsg, F.util.formAlertTitle, Ext.MessageBox.INFO);
}
return false;
}
return true;
},
// 判断隐藏字段值数组是否包含value
isHiddenFieldContains: function (domId, testValue) {
testValue += "";
var domValue = Ext.get(domId).dom.value;
if (domValue === "") {
//console.log(domId);
return false;
}
else {
var sourceArray = domValue.split(",");
return Ext.Array.indexOf(sourceArray, testValue) >= 0 ? true : false;
}
},
// 将一个字符添加到字符列表中将2添加到[5,3,4]
addValueToHiddenField: function (domId, addValue) {
addValue += "";
var domValue = Ext.get(domId).dom.value;
if (domValue == "") {
Ext.get(domId).dom.value = addValue + "";
}
else {
var sourceArray = domValue.split(",");
if (Ext.Array.indexOf(sourceArray, addValue) < 0) {
sourceArray.push(addValue);
Ext.get(domId).dom.value = sourceArray.join(",");
}
}
},
// 从字符列表中移除一个字符将2从dom的值"5,3,4,2"移除
removeValueFromHiddenField: function (domId, addValue) {
addValue += "";
var domValue = Ext.get(domId).dom.value;
if (domValue != "") {
var sourceArray = domValue.split(",");
if (Ext.Array.indexOf(sourceArray, addValue) >= 0) {
sourceArray = sourceArray.remove(addValue);
Ext.get(domId).dom.value = sourceArray.join(",");
}
}
},
// 取得隐藏字段的值
getHiddenFieldValue: function (fieldId) {
var itemNode = Ext.get(fieldId);
if (!itemNode) {
return "";
}
else {
return itemNode.dom.value;
}
},
// 取得表单字段的值
getFormFieldValue: function (cmp) {
if (typeof (cmp) === 'string') {
cmp = F(cmp);
}
var value = cmp.getValue();
if (cmp.isXType('displayfield')) {
value = value.replace(/<\/?span[^>]*>/ig, '');
}
return value;
},
// 由target获取window对象
getTargetWindow: function (target) {
var wnd = window;
if (target === '_self') {
wnd = window;
} else if (target === '_parent') {
wnd = parent;
} else if (target === '_top') {
wnd = top;
}
return wnd;
},
// 预加载图片
preloadImages: function (images) {
var imageInstance = [];
for (var i = 0; i < images.length; i++) {
imageInstance[i] = new Image();
imageInstance[i].src = images[i];
}
},
hasCSS: function (id) {
return !!Ext.get(id);
},
addCSS: function (id, content, isCSSFile) {
// 如果此节点已经存在,则先删除此节点
var node = Ext.get(id);
if (node) {
Ext.removeNode(node.dom);
}
/*
var ss1;
if (isCSSFile) {
ss1 = document.createElement('link');
ss1.setAttribute('type', 'text/css');
ss1.setAttribute('rel', 'stylesheet');
ss1.setAttribute('id', id);
ss1.setAttribute('href', content);
} else {
// Tricks From: http://www.phpied.com/dynamic-script-and-style-elements-in-ie/
ss1 = document.createElement("style");
ss1.setAttribute("type", "text/css");
ss1.setAttribute("id", id);
if (ss1.styleSheet) { // IE
ss1.styleSheet.cssText = content;
} else { // the world
var tt1 = document.createTextNode(content);
ss1.appendChild(tt1);
}
}
var hh1 = document.getElementsByTagName("head")[0];
hh1.appendChild(ss1);
*/
var ss1;
var hh1 = document.getElementsByTagName('head')[0];
if (isCSSFile) {
ss1 = document.createElement('link');
//ss1.setAttribute('type', 'text/css');
ss1.setAttribute('rel', 'stylesheet');
ss1.setAttribute('id', id);
ss1.setAttribute('href', content);
hh1.appendChild(ss1);
} else {
// Tricks From: http://www.phpied.com/dynamic-script-and-style-elements-in-ie/
ss1 = document.createElement('style');
//ss1.setAttribute('type', 'text/css');
ss1.setAttribute('id', id);
// Update: note that it's important for IE that you append the style to the head *before* setting its content. Otherwise IE678 will *crash* is the css string contains an @import.
hh1.appendChild(ss1);
if (ss1.styleSheet) { // IE
ss1.styleSheet.cssText = content;
} else { // the world
var tt1 = document.createTextNode(content);
ss1.appendChild(tt1);
}
}
},
/*
// 在启用AJAX的情况下使所有的Asp.net的提交按钮type="submit"不要响应默认的submit行为而是自定义的AJAX
makeAspnetSubmitButtonAjax: function (buttonId) {
// 低版本IE浏览器不允许使用JS修改input标签的type属性导致此函数无效
function resetButton(button) {
button.set({ "type": "button" });
button.addListener("click", function (event, el) {
__doPostBack(el.getAttribute("name"), "");
event.stopEvent();
});
}
if (typeof (buttonId) === "undefined") {
Ext.Array.each(Ext.DomQuery.select("input[type=submit]"), function (item, index) {
resetButton(Ext.get(item));
});
} else {
var button = Ext.get(buttonId);
if (button.getAttribute("type") === "submit") {
resetButton(button);
}
}
},
*/
htmlEncode: function (str) {
var div = document.createElement("div");
div.appendChild(document.createTextNode(str));
return div.innerHTML;
},
htmlDecode: function (str) {
var div = document.createElement("div");
div.innerHTML = str;
return div.innerHTML;
},
// Whether a object is empty (With no property) or not.
// 可以使用 Ext.Object.isEmpty
isObjectEmpty: function (obj) {
for (var prop in obj) {
if (obj.hasOwnProperty(prop)) {
return false;
}
}
return true;
},
// Convert an array to object.
// ['Text', 'Icon'] -> {'Text':true, 'Icon': true}
arrayToObject: function (arr) {
var obj = {};
Ext.Array.each(arr, function (item, index) {
obj[item] = true;
});
return obj;
},
hideScrollbar: function () {
if (Ext.isIE) {
window.document.body.scroll = 'no';
} else {
window.document.body.style.overflow = 'hidden';
}
},
// 动态添加一个标签页
// mainTabStrip 选项卡实例
// id 选项卡ID
// url: 选项卡IFrame地址
// text 选项卡标题
// icon 选项卡图标
// addTabCallback 创建选项卡前的回调函数接受tabConfig参数
// refreshWhenExist 添加选项卡时如果选项卡已经存在是否刷新内部IFrame
addMainTab: function (mainTabStrip, id, url, text, icon, createToolbar, refreshWhenExist) {
var iconId, iconCss, tabId, currentTab, tabConfig;
// 兼容 addMainTab(mainTabStrip, treeNode, addTabCallback, refreshWhenExist) 调用方式
if (typeof (id) !== 'string') {
refreshWhenExist = text;
createToolbar = url;
url = id.data.href;
icon = id.data.icon;
text = id.data.text;
id = id.getId();
}
//var href = node.attributes.href;
if (icon) {
iconId = icon.replace(/\W/ig, '_');
if (!F.util.hasCSS(iconId)) {
iconCss = [];
iconCss.push('.');
iconCss.push(iconId);
iconCss.push('{background-image:url("');
iconCss.push(icon);
iconCss.push('")}');
F.util.addCSS(iconId, iconCss.join(''));
}
}
// 动态添加一个带工具栏的标签页
//tabId = 'dynamic_added_tab' + id.replace('__', '-');
currentTab = mainTabStrip.getTab(id);
if (!currentTab) {
tabConfig = {
'id': id,
'url': url,
'title': text,
'closable': true,
'bodyStyle': 'padding:0px;'
};
if (icon) {
tabConfig['iconCls'] = iconId;
}
if (createToolbar) {
var addTabCallbackResult = createToolbar.apply(window, [tabConfig]);
// 兼容之前的方法,函数返回值如果不为空,则将返回值作为顶部工具条实例
if (addTabCallbackResult) {
tabConfig['tbar'] = addTabCallbackResult;
}
}
mainTabStrip.addTab(tabConfig);
} else {
mainTabStrip.setActiveTab(currentTab);
currentTab.setTitle(text);
if (icon) {
currentTab.setIconCls(iconId);
}
if (refreshWhenExist) {
var iframeNode = currentTab.body.query('iframe')[0];
if (iframeNode) {
if (url) {
iframeNode.contentWindow.location.href = url;
} else {
iframeNode.contentWindow.location.reload();
}
}
}
}
},
// 初始化左侧树(或者手风琴+树)与右侧选项卡控件的交互
// treeMenu 主框架中的树控件实例,或者内嵌树控件的手风琴控件实例
// mainTabStrip 选项卡实例
// createToolbar 创建选项卡前的回调函数接受tabConfig参数
// updateLocationHash: 切换Tab时是否更新地址栏Hash值
// refreshWhenExist 添加选项卡时如果选项卡已经存在是否刷新内部IFrame
// refreshWhenTabChange: 切换选项卡时是否刷新内部IFrame
// hashWindow需要更新Hash值的窗口对象默认为当前window
initTreeTabStrip: function (treeMenu, mainTabStrip, createToolbar, updateLocationHash, refreshWhenExist, refreshWhenTabChange, hashWindow) {
if (!hashWindow) {
hashWindow = window;
}
// 注册树的节点点击事件
function registerTreeClickEvent(treeInstance) {
treeInstance.on('itemclick', function (view, record, item, index, event) {
var href = record.data.href;
// record.isLeaf()
// 不管当前节点是否子节点,只要有 href 属性都需要打开一个新Tab
if (href) {
// 阻止事件传播
event.stopEvent();
if (updateLocationHash) {
// 修改地址栏
hashWindow.location.hash = '#' + href;
}
// 新增Tab节点
F.util.addMainTab(mainTabStrip, record, createToolbar, refreshWhenExist);
}
});
}
// treeMenu可能是Accordion或者Tree
if (treeMenu.getXType() === 'panel') {
treeMenu.items.each(function (item) {
var tree = item.items.getAt(0);
if (tree && tree.getXType() === 'treepanel') {
registerTreeClickEvent(tree);
}
});
} else if (treeMenu.getXType() === 'treepanel') {
registerTreeClickEvent(treeMenu);
}
// 切换主窗口的Tab
mainTabStrip.on('tabchange', function (tabStrip, tab) {
var tabHash = '#' + (tab.url || '');
// 只有当浏览器地址栏的Hash值和将要改变的不一样时才进行如下两步处理
// 1. 更新地址栏Hash值
// 2. 刷新Tab内的IFrame
if (tabHash !== hashWindow.location.hash) {
if (updateLocationHash) {
hashWindow.location.hash = tabHash;
}
if (refreshWhenTabChange) {
var iframeNode = tab.body.query('iframe')[0];
if (iframeNode) {
var currentLocationHref = iframeNode.contentWindow.location.href;
if (/^http(s?):\/\//.test(currentLocationHref)) {
iframeNode.contentWindow.location.reload();
}
}
}
}
});
// 页面第一次加载时根据URL地址在主窗口加载页面
var HASH = hashWindow.location.hash.substr(1);
if (HASH) {
var FOUND = false;
function initTreeMenu(treeInstance, node) {
var i, currentNode, nodes, node, path;
if (!FOUND && node.hasChildNodes()) {
nodes = node.childNodes;
for (i = 0; i < nodes.length; i++) {
currentNode = nodes[i];
if (currentNode.isLeaf()) {
if (currentNode.data.href === HASH) {
path = currentNode.getPath();
treeInstance.expandPath(path); //node.expand();
treeInstance.selectPath(path); // currentNode.select();
F.util.addMainTab(mainTabStrip, currentNode, createToolbar);
FOUND = true;
return;
}
} else {
arguments.callee(treeInstance, currentNode);
}
}
}
}
if (treeMenu.getXType() === 'panel') {
treeMenu.items.each(function (item) {
var tree = item.items.getAt(0);
if (tree && tree.getXType() === 'treepanel') {
initTreeMenu(tree, tree.getRootNode());
// 找到树节点
if (FOUND) {
item.expand();
return false;
}
}
});
} else if (treeMenu.getXType() === 'treepanel') {
initTreeMenu(treeMenu, treeMenu.getRootNode());
}
}
},
// 复选框分组处理
resolveCheckBoxGroup: function (name, xstateContainer, isradiogroup) {
var items = [], i, count, xitem, xitemvalue, xitems, xselectedarray, xselected, xchecked, xitemname;
xitems = xstateContainer.F_Items;
xselectedarray = xstateContainer.SelectedValueArray;
xselected = xstateContainer.SelectedValue;
if (xitems && xitems.length > 0) {
for (i = 0, count = xitems.length; i < count; i++) {
xitem = xitems[i];
xitemvalue = xitem[1];
xchecked = false;
if (!isradiogroup) {
// xselectedarray 可能是undefined, [], ["value1", "value2"]
if (xselectedarray) {
xchecked = (Ext.Array.indexOf(xselectedarray, xitemvalue) >= 0) ? true : false;
}
xitemname = name + '_' + i;
} else {
xchecked = (xselected === xitemvalue) ? true : false;
xitemname = name;
}
items.push({
'inputValue': xitemvalue,
'boxLabel': xitem[0],
'name': xitemname,
'checked': xchecked
});
}
}
/*
else {
items.push({
'inputValue': "tobedeleted",
'boxLabel': "&nbsp;",
'name': "tobedeleted"
});
}
*/
return items;
},
// 防止在短时间内同一GroupName的单选框触发两次事件
// 用于 MenuCheckBox 和 RadioButton
checkGroupLastTime: function (groupName) {
var checkName = groupName + '_lastupdatetime';
var checkValue = F.util[checkName];
F.util[checkName] = new Date();
if (typeof (checkValue) === 'undefined') {
return true;
} else {
if ((new Date() - checkValue) < 100) {
return false;
} else {
return true;
}
}
},
// 对话框图标
getMessageBoxIcon: function (iconShortName) {
var icon = iconShortName || Ext.MessageBox.WARNING;
if (iconShortName === 'info') {
icon = Ext.MessageBox.INFO;
} else if (iconShortName === 'warning') {
icon = Ext.MessageBox.WARNING;
} else if (iconShortName === 'question') {
icon = Ext.MessageBox.QUESTION;
} else if (iconShortName === 'error') {
icon = Ext.MessageBox.ERROR;
}
return icon;
},
// 弹出Alert对话框
alert: function (target, message, title, messageIcon, ok) { // 老的顺序msg, title, icon, okscript
var args = [].slice.call(arguments, 0);
var options = args[0];
if (typeof (options) === 'string') {
if (!/^_self|_parent|_top$/.test(args[0])) {
args.splice(0, 0, '_self');
}
options = {
target: args[0],
message: args[1],
title: args[2],
messageIcon: args[3],
ok: args[4]
};
}
var wnd = F.util.getTargetWindow(options.target);
if (!F.canAccess(wnd)) {
return; // return
}
var icon = Ext.MessageBox.INFO;
if (options.messageIcon) {
icon = F.util.getMessageBoxIcon(options.messageIcon);
}
wnd.Ext.MessageBox.show({
cls: options.cls || '',
title: options.title || F.util.alertTitle,
msg: options.message,
buttons: Ext.MessageBox.OK,
icon: icon,
fn: function (buttonId) {
if (buttonId === "ok") {
if (typeof (options.ok) === "function") {
options.ok.call(window);
}
}
}
});
},
// 确认对话框
confirm: function (target, message, title, messageIcon, ok, cancel) { // 老的顺序targetName, title, msg, okScript, cancelScript, iconShortName)
var args = [].slice.call(arguments, 0); //$.makeArray(arguments);
var options = args[0];
if (typeof (options) === 'string') {
if (!/^_self|_parent|_top$/.test(args[0])) {
args.splice(0, 0, '_self');
}
options = {
target: args[0],
message: args[1],
title: args[2],
messageIcon: args[3],
ok: args[4],
cancel: args[5]
};
}
var wnd = F.util.getTargetWindow(options.target);
if (!F.canAccess(wnd)) {
return; // return
}
var icon = F.util.getMessageBoxIcon(options.messageIcon);
wnd.Ext.MessageBox.show({
cls: options.cls || '',
title: options.title || F.util.confirmTitle,
msg: options.message,
buttons: Ext.MessageBox.OKCANCEL,
icon: icon,
fn: function (btn) {
if (btn == 'cancel') {
if (options.cancel) {
if (typeof (options.cancel) === 'string') {
new Function(options.cancel)();
} else {
options.cancel.apply(wnd);
}
} else {
return false;
}
} else {
if (options.ok) {
if (typeof (options.ok) === 'string') {
new Function(options.ok)();
} else {
options.ok.apply(wnd);
}
} else {
return false;
}
}
}
});
},
summaryType: function (gridId) {
return function (records, dataIndex) {
var summary = F(gridId).f_state['SummaryData'];
if (summary) {
var value = summary[dataIndex];
if (typeof (value) !== 'undefined') {
return value;
}
}
return '';
};
},
// 表单字段内按回车键触发提交按钮
registerPanelEnterKey: function (panel) {
if (F.submitbutton) {
Ext.create('Ext.util.KeyNav', panel.el, {
enter: function (e) {
var el = Ext.Element.getActiveElement();
if (el.type !== 'textarea') {
F(F.submitbutton).el.dom.click();
}
},
scope: panel
});
}
},
reset: function () {
Ext.ComponentManager.each(function (key, cmp) {
if (cmp.isXType && cmp.isXType('panel') && cmp.renderTo) {
cmp.f_reset();
}
});
},
isDate: function (value) {
return Object.prototype.toString.call(value) === '[object Date]';
},
resolveGridDateToString: function (fields, fieldName, fieldValue) {
var i, fieldConfig, result = fieldValue;
for (i = 0, count = fields.length; i < count; i++) {
fieldConfig = fields[i];
if (fieldConfig.name === fieldName && fieldConfig.type === 'date' && fieldConfig.dateFormat) {
result = Ext.util.Format.date(fieldValue, fieldConfig.dateFormat);
}
}
return result;
},
noop: function () { }
};
})();