js.beangle.js Maven / Gradle / Ivy
/**
* Beangle, Agile Java/Scala Development Scaffold and Toolkit
*
* Copyright (c) 2005-2020, Beangle Software.
*
* Beangle is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* Beangle 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Beangle. If not, see .
*/
(function( window, undefined ) {
if(beangle) return;
var beangle=function (){
return true;
};
beangle.version="0.2.1";
/** extend function */
beangle.extend= function(map){
for(attr in map){
var attrs=attr.split("."),obj=beangle,i;
for(i=0 ;ibeangle.history.maxStates)History.reset();
}
});
});
},
Go : function(url,target){
jQuery.ajax({
url: url,cache:false,
type: "GET",dataType: "html",
complete: function( jqXHR) {
target="#"+target;
if(jQuery(target).html().length>0){
beangle.history.snapshot();
History.pushState({content:jqXHR.responseText,container:target},"",url);
}else{
var state=History.getState();
History.replaceState({content:jqXHR.responseText,container:target,updatedAt:(new Date()).getTime()},state.title,state.url);
try{
jQuery(target).html(jqXHR.responseText);
}catch(e){alert(e)}
}
beangle.hideAjaxMessage();
},
beforeSend: beangle.displayAjaxMessage
});
},
snapshot:function(){
var state = History.getState();
if(state.data.content){
var _t = [];
jQuery(state.data.container +' .box:checked').each(function(index, e) {_t[_t.length] = e.value;});
state.data.boxes=_t;
state.updatedAt=(new Date()).getTime();
if(_t.length>0) History.replaceState(state.data,state.title,state.url);
}
},
applyState:function(state){
if(state.data.boxes){
jQuery(state.data.boxes).each(function(index, value) {
jQuery(state.data.container +' .box[value=' + value + ']').prop('checked', true);
});
}
if(typeof afterApplyState=="function"){
afterApplyState();
afterApplyState=null;
}
},
submit : function(form,action,target){
if(jQuery.type(form)=="string" && form.indexOf("#")!=0){
form = "#" + form;
}
if(jQuery.type(target)=="string" && target.indexOf("#")!=0){
target = "#" + target;
}
beangle.displayAjaxMessage();
require(["jquery-form"],function(){
jQuery(form).ajaxForm({
success:function(result) {
beangle.history.snapshot();
History.pushState({content:result,container:target},"",action);
beangle.hideAjaxMessage();
return false;},
error:function (response) {
try{jQuery(target).html(response.responseText);}catch(e){alert(e)}
beangle.hideAjaxMessage();
return false;},
url:action
});
jQuery(form).submit();
});
}
};
//Go and ajax---------------------------------
beangle.extend({
//jump to href or anchor
Go : function (obj,target){
var url=obj;
if(typeof obj =="object" && obj.tagName.toLowerCase()=="a"){
url=obj.href;
if(!target){
target=beangle.findTarget(obj);
}
}
if(!target) target="_self";
if("_self"==target){ self.location=url;}
else if("_parent"==target){self.parent.location=url;}
else if("_top" ==target){self.top.location=url;}
else if("_blank" ==target ){window.open(url);}
else{
if(!beangle.isAjaxTarget(target)){
//FIXME _blank,_top
document.getElementById(target).src=url;
}else{
if(beangle.ajaxhistory){
beangle.history.Go(url,target);
}else {
//using post ,hack ie8 get cache
jQuery('#'+target).load(url,{});
}
}
}
return false;
},
ready:function (fn){
jQuery(document).ready(fn);
},
isAjaxTarget : function (target){
if(!target) return false;
if(target==""||target=="_blank"||target=="_self"||target=="_parent"||target=="_top"){
return false;
}
targetEle=document.getElementById(target);
if(!targetEle) return false;
tagName=targetEle.tagName.toLowerCase();
if(tagName=="iframe" || tagName=="object"){
return false;
}
return true;
},
normalTarget : function(target){
if(target==""||target=="_blank"||target=="_self"||target=="_parent"){
return target;
}
var targetObj = document.getElementById(target);
if(!targetObj || targetObj.tagName.toLowerCase()!="iframe") return "_self";
else return target;
},
findTarget : function(ele){
var p = ele.parentNode,finalTarget = "_self";
while(p){
//FIXME ui-tabs-panel
if(p.id && p.className && (p.className.indexOf("ajax_container")>-1 )){//||p.className.indexOf("ui-tabs-panel")>-1
finalTarget = p.id;
break;
}else{
if(p==p.parentNode) p=null;
else p=p.parentNode;
}
}
ele.target=finalTarget;
return finalTarget;
}
});
// Assert------------------------
beangle.extend({
assert:{
notNull : function(object,message){
if(null==object) alert(message);
}
}
});
beangle.extend({
randomInt:function(){
var num=Math.random()*10000000;
num -= num%1;
return num;
}
});
// Logger----------------------------
beangle.extend({
logger:{
// debug=0;info=1;warn=2;error=3;fatal=4;disabled=5
level : 1,
debug : function(message){
if(beangle.logger.level<=0){
var msg = '[beangle] ' + message;
if (window.console && window.console.log) {
window.console.log(message);
}else if (window.opera && window.opera.postError) {
window.opera.postError(msg);
}else{
alert(msg);
}
}
}
}
});
// Event--------------------------------------------------
beangle.extend({
event:{
portable: function (e){
if(!e) return window.event;
else return e;
},
/**获得事件背后的元素*/
getTarget: function (e){
e=beangle.event.portable(e);
return e.target || e.srcElement;
}
}
});
// Input----------------------------------------------------
beangle.extend({
input:{
toggleCheckBox : function (chk,event){
beangle.input.boxAction(chk, "toggle",event);
},
/**
* 返回单选列表中选择的值
* @return 没有选中时,返回""
*/
getRadioValue : function (radioName){
return beangle.input.boxAction(document.getElementsByName(radioName), "value");
},
/**
* 返回多选列表中选择的值
* @return 多个值以,相隔.没有选中时,返回""
*/
getCheckBoxValues : function (chkname){
var tmpIds= beangle.input.boxAction(document.getElementsByName(chkname), "value");
if(tmpIds==null)return "";
else return tmpIds;
},
/**
* modify by chaostone 2006-8-2
* 将反选取消,改为全选或者全部取消
*/
boxAction : function (box, action,event){
var val = "",srcElement,i;
if (box){
if (! box[0]){
if (action == "selected"){
return box.checked;
} else if (action == "value"){
if (box.checked)
val = box.value;
} else if (action == "toggle"){
srcElement = beangle.event.getTarget(event);
box.checked = srcElement.checked;
if(typeof box.onchange =="function"){
box.onchange();
}
}
} else{
for (i=0; i0) && totalHeight> myHeight){
targWin.style.height = totalHeight+"px";
beangle.logger.debug('adapt frame:'+targObj.name+" height "+targWin.style.height);
}
}
beangle.iframe.adapt(targObj.parent);
}
}
});
//About From
beangle.extend({
form:{
submit : function (myForm,action,target,onsubmit,ajax,noHistory){
var submitTarget, rs,origin_target, origin_action;
if((typeof myForm)=='string') myForm = document.getElementById(myForm);
//First native onsubmit will benefit to user's onsubmit hook on data validation.
//1.native onsubmit
if(myForm.onsubmit){
rs=null;
try{rs=myForm.onsubmit();}catch(e){alert(e);return;}
if(!rs){
return;
}
}
//2. submit hook
if(onsubmit){
rs=null;
if(typeof onsubmit == "function"){
try{rs=onsubmit(myForm);}catch(e){alert(e);return;}
}else{
rs=eval(onsubmit);
}
if(!rs){
return;
}
}
//3. check target and action
submitTarget = (null!=target)?target:myForm.target;
if(!submitTarget) submitTarget=beangle.findTarget(myForm);
if(action==null) action=myForm.action;
if(action.indexOf("http://")==0) action=action.substring(action.indexOf("/",7));
if(null==ajax || ajax) ajax=beangle.isAjaxTarget(submitTarget);
// 4. fire
if(ajax){
if(null==myForm.id||''==myForm.id){
myForm.setAttribute("id",myForm.name);
}
if(!noHistory && !jQuery("input:file",myForm).length && beangle.ajaxhistory){
beangle.history.submit(myForm.id,action,submitTarget);
}else{
beangle.form.ajaxSubmit(myForm.id,action,submitTarget);
}
}else{
origin_target=myForm.target;
origin_action=myForm.action;
myForm.action=action;
myForm.target = beangle.normalTarget(submitTarget);
myForm.submit();
myForm.target = origin_target;
myForm.action = origin_action;
}
},
ajaxSubmit : function(formId,action,target){
if(!action) action=document.getElementById(formId).action;
require(["jquery-form"],function(){
jQuery('#'+formId).ajaxForm({
success:function(result) {try{jQuery('#'+target).html(result);}catch(e){alert(e)}},
error:function (response) {try{jQuery('#'+target).html(response.responseText);}catch(e){alert(e)}},
url:action
});
jQuery('#'+formId).submit();
});
},
/**
* 提交要求含有id的表单
* @param form 带提交的表单
* @param id 要提交id的名称
* @param isMulti(可选)是否允许多个id选择,默认支持一个
* @param action (可选) 指定form的action
*/
submitId : function (form,id,isMulti,action,promptMsg,ajax){
var selectId = beangle.input.getCheckBoxValues(id);
if(null==isMulti) isMulti=false;
if(""==selectId){
alert(isMulti?"请选择一个或多个进行操作":"请选择一个进行操作");
return;
}
if(!isMulti && (selectId.indexOf(",")>0)){
alert("请仅选择一个");
return;
}
if(null!=action){
form.action=action;
}else{
action=form.action;
}
beangle.form.addInput(form,(isMulti?(id+'s'):id),selectId,"hidden");
if(null!=promptMsg){
if(!confirm(promptMsg))return;
}
beangle.form.submit(form,action,null,null,ajax);
},
/**
* 向form中添加一个input。
* @param form 要添加输入的form
* @param name input的名字
* @param value input的值
* @param type input的类型,默认为hidden
* @author chaostone 2006-4-7
*/
addInput : function (form,name,value,type){
//防止设置form的属性
if(form[name]!=null && (typeof form[name].tagName)!="undefined"){
form[name].value=value;
}else{
if(null==type) type="hidden";
var input = document.createElement('input');
input.setAttribute("name",name);
input.setAttribute("value",value);
input.setAttribute("type",type);
form.appendChild(input);
}
},
addInputs : function (form,name,value,type){
if(null==type) type="hidden";
for(i=0;i
* 但不收集params的input,这个作为保留名称
* @param form
* @param prefix 指明所有input||select的前缀,如果没有前缀可以忽略
* @param getEmpty 是否收集值为空的属性
* @return 返回参数列表串形如:&input1=...&input2=...
* @author chaostone 2006-4-7
*
*/
getInputParams : function (form,prefix,getEmpty){
var elems = form.elements, params = "", i;
if(null==getEmpty) getEmpty=true;
for(i = 0;i < elems.length; i++){
if(""!=elems[i].name){
if("_params"==elems[i].name) continue;
//alert(elems[i].tagName+":"+elems[i].value);
if((elems[i].value=="")&&(!getEmpty)) continue;
if(null!=prefix){
if(elems[i].name.indexOf(prefix)==0&&elems[i].name.indexOf(".")>1){
if((elems[i].type=="radio" ||elems[i].type=="checkbox")&& !elems[i].checked)
continue;
if(elems[i].value.indexOf('&')!=-1){
params+="&" + elems[i].name + "=" + escape(elems[i].value);
}else{
params+="&" + elems[i].name + "=" + elems[i].value;
}
}
}else{
if((elems[i].type=="radio" ||elems[i].type=="checkbox")&& !elems[i].checked)
continue;
if(elems[i].value.indexOf('&')!=-1){
params+="&" + elems[i].name + "=" + escape(elems[i].value);
}else{
params+="&" + elems[i].name + "=" + elems[i].value;
}
}
}
}
//alert("[getInputParams]:"+params);
return params;
},
goToPage : function (form,pageIndex,pageSize,orderBy){
if((typeof form)!="object"){alert("[goToPage:]form is not well defined.");return;}
//form.method="post"; for avoid "method" input
if(null!=pageIndex){
if(!/^[1-9]\d*$/.test(pageIndex)){
alert("输入分页的页码是:"+pageIndex+",它不是个整数");
return;
}
beangle.form.addInput(form,"pageIndex",pageIndex,"hidden");
}else{
beangle.form.addInput(form,"pageIndex",1,"hidden");
}
if(null!=pageSize){
if(!/^[1-9]\d*$/.test(pageSize)){
alert("输入分页的页长是:"+pageSize+",它不是个整数");
return;
}
beangle.form.addInput(form,"pageSize",pageSize,"hidden");
}else{
beangle.form.addInput(form,"pageSize","","hidden");
}
if(null!=orderBy&&orderBy!="null"){
beangle.form.addInput(form,"orderBy",orderBy,"hidden");
}else{
beangle.form.addInput(form,"orderBy","","hidden");
}
//alert("in goToPage");
form.submit();
},
goToFirstPage : function (form){
beangle.form.goToPage(form,1);
}
}
});
//select---------------------
beangle.extend({
select:{
getValues : function (select){
var val = "", i, options = select.options;
for (i = 0; i< options.length; i++){
if (val != "")
val = val + ",";
val = val + options[i].value;
}
return val;
},
getSelectedValues : function (select){
var val = "", i, options = select.options;
for (i = 0; i < options.length; i++){
if (options[i].selected){
if (val != "")
val = val + ",";
val = val + options[i].value;
}
}
return val;
},
hasOption : function (select, op){
for (var i = 0; i< select.length; i++ ){
if (select.options[i].value == op.value)
return true;
}
return false;
},
moveSelected : function (srcSelect, destSelect){
var i, op;
for (i = 0; i < srcSelect.length; i++){
if (srcSelect.options[i].selected){
op = srcSelect.options[i];
if (!beangle.select.hasOption(destSelect, op)){
destSelect.options[destSelect.length]= new Option(op.text, op.value);
}
}
}
beangle.select.removeSelected(srcSelect);
beangle.select.clearStatus(srcSelect);
},
clearStatus : function (select){
for (var i=0; i0;
},
removeSelected : function (select){
var options = select.options, i;
for (i = options.length-1; i >= 0; i--){
if (options[i].selected){
options[i] = null;
}
}
},
/**
* 设定选择框中的选择项(单项)
*/
setSelected : function (select,idSeq){
if(idSeq.indexOf(',')!=0){
idSeq=","+idSeq;
}
if(idSeq.lastIndexOf(',')!=idSeq.length-1){
idSeq=idSeq+",";
}
for(var i=0;ithis.totalPages){
pageIndex=this.totalPages;
}
}
this.paramMap['pageIndex']=pageIndex;
}
if(null!=pageSize){
if(!/^[1-9]\d*$/.test(pageSize)){
beangle.alert("输入分页的页长是:"+pageSize+",它不是个整数");
return false;
}
this.paramMap["pageSize"]=pageSize;
}
if(null!=orderBy && orderBy!="null"){
this.paramMap["orderBy"]=orderBy;
}
return true;
}
this.goPage = function (pageIndex,pageSize,orderBy){
var myForm=this.getForm(), key, value;
if(this.checkPageParams(pageIndex,pageSize,orderBy)){
for(key in this.paramMap){
value=this.paramMap[key];
if(value!="") beangle.form.addInput(myForm,key,value,"hidden");
}
if(this.target && document.getElementById(this.target)){
beangle.form.submit(this.formid,this.actionurl,this.target);
}else{
myForm.submit();
}
}
}
}
beangle.extend({
page:function (action,target){return new Page(action,target);}
});
beangle.onReturn = function(event, action) {
if (!event) {
event = window.event;
}
if (event && event.keyCode && event.keyCode == 13) {
action();
}
};
beangle.extend({
styleCache:{},
modules:{},
register:function(base,modules){
if(!beangle.base){
beangle.base=base;
}
var registed=false;
for(var m in modules){
if(!beangle.modules[m]){
beangle.modules[m]=modules[m];
registed=true;
}
}
if(registed){
var paths= {};
var shim={}
for(var m in beangle.modules){
var bm=beangle.modules[m]
if(bm.js){
paths[m]=bm.js.substring(0,bm.js.length-3);
if(bm.deps){
shim[m]=bm.deps
}
}
}
require.config({baseUrl: base,paths: paths,shim:shim});
}
},
load:function(names,callBack){
var requireModules=[]
for(var i=0;i0){
require(requireModules,callBack)
}else if(callBack){
try{
callBack();
}catch(e){
}
}
},
require : function(urls, callBack) {
if(arguments.length==3){
require([arguments[0]],arguments[2]);
}else{
if(typeof urls ==="string"){
require([urls],callBack);
}else{
require(urls,callBack);
}
}
},
/** Load required CSS Files */
requireCss : function(cssFile, basePath) {
var path = (basePath || "") + cssFile;
if (!beangle.styleCache[path]) {
var link = document.createElement("link");
link.setAttribute("rel", "stylesheet");
link.setAttribute("type", "text/css");
link.setAttribute("href", path);
document.getElementsByTagName("head")[0].appendChild(link);
beangle.styleCache[path] = true;
}
}
});
beangle.ready(beangle.iframe.adaptSelf);
if(beangle.ajaxhistory)beangle.history.init();
//register as a module
if ( typeof module === "object" && module && typeof module.exports === "object" ) {
module.exports = beangle;
} else {
window.beangle=beangle;
window.bg=beangle;
if ( typeof define === "function" && define.amd ) {
define( "beangle", [], function () { return beangle; } );
}
}
})(window);
// fix jquery ready bug
(function(){
var jqReady = jQuery.prototype.ready;
jQuery.prototype.ready = function( fn ) {
return jqReady(function(){
try{
fn();
}catch(e){
alert(e);
}
});
}
})();
© 2015 - 2025 Weber Informatics LLC | Privacy Policy