All Downloads are FREE. Search and download functionalities are using the official Maven repository.

js.beangle.js Maven / Gradle / Ivy

There is a newer version: 0.6.5
Show newest version
/**
 * 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