diff options
author | Jochen Topf <jochen@topf.org> | 2014-05-16 11:47:40 +0200 |
---|---|---|
committer | Jochen Topf <jochen@topf.org> | 2014-05-16 11:47:40 +0200 |
commit | bd45ed150c8a909250ad2d26c591746bb1f60bb6 (patch) | |
tree | a0683755d05349f4f0ff86b0414540c30aae5050 /web | |
parent | e4d240e695a98df6f9555be7eb56e464ec0eb41f (diff) | |
download | taginfo-bd45ed150c8a909250ad2d26c591746bb1f60bb6.tar taginfo-bd45ed150c8a909250ad2d26c591746bb1f60bb6.tar.gz |
Remove carriage returns and clean up whitespaces.
Diffstat (limited to 'web')
-rw-r--r-- | web/public/js/flexigrid.js | 3056 |
1 files changed, 1528 insertions, 1528 deletions
diff --git a/web/public/js/flexigrid.js b/web/public/js/flexigrid.js index e578c5b..4b17a75 100644 --- a/web/public/js/flexigrid.js +++ b/web/public/js/flexigrid.js @@ -1,1528 +1,1528 @@ -/*
- * Flexigrid for jQuery - New Wave Grid
- *
- * Copyright (c) 2008 Paulo P. Marinas (webplicity.net/flexigrid)
- * Dual licensed under the MIT (MIT-LICENSE.txt)
- * and GPL (GPL-LICENSE.txt) licenses.
- *
- * $Date: 2008-07-14 00:09:43 +0800 (Tue, 14 Jul 2008) $
- */
-
-(function($){
-
- $.addFlex = function(t,p)
- {
-
- if (t.grid) return false; //return if already exist
-
- // apply default properties
- p = $.extend({
- height: 200, //default height
- width: 'auto', //auto width
- striped: true, //apply odd even stripes
- novstripe: false,
- minwidth: 30, //min width of columns
- minheight: 80, //min height of columns
- resizable: true, //resizable table
- url: false, //ajax url
- method: 'POST', // data sending method
- dataType: 'xml', // type of data loaded
- errormsg: 'Connection Error',
- usepager: false, //
- nowrap: true, //
- page: 1, //current page
- total: 1, //total pages
- useRp: true, //use the results per page select box
- rp: 15, // results per page
- rpOptions: [10,15,20,25,40],
- title: false,
- pagestat: 'Displaying {from} to {to} of {total} items',
- pagetext: 'Page',
- outof: 'of',
- findtext: 'Find',
- procmsg: 'Processing, please wait ...',
- query: '',
- qtype: '',
- nomsg: 'No items',
- minColToggle: 1, //minimum allowed column to be hidden
- showToggleBtn: true, //show or hide column toggle popup
- hideOnSubmit: true,
- autoload: true,
- blockOpacity: 0.5,
- onDragCol: false,
- onToggleCol: false,
- onChangeSort: false,
- onSuccess: false,
- onError: false,
- onSubmit: false // using a custom populate function
- }, p);
-
-
- $(t)
- .show() //show if hidden
- .attr({cellPadding: 0, cellSpacing: 0, border: 0}) //remove padding and spacing
- .removeAttr('width') //remove width properties
- ;
-
- //create grid class
- var g = {
- hset : {},
- rePosDrag: function () {
-
- var cdleft = 0 - this.hDiv.scrollLeft;
- if (this.hDiv.scrollLeft>0) cdleft -= Math.floor(p.cgwidth/2);
- $(g.cDrag).css({top:g.hDiv.offsetTop+1});
- var cdpad = this.cdpad;
-
- $('div',g.cDrag).hide();
-
- $('thead tr:first th:visible',this.hDiv).each
- (
- function ()
- {
- var n = $('thead tr:first th:visible',g.hDiv).index(this),
- cdpos = parseInt($('div',this).width());
- if (cdleft==0)
- cdleft -= Math.floor(p.cgwidth/2);
-
- cdpos = cdpos + cdleft + cdpad;
-
- $('div:eq('+n+')',g.cDrag).css({'left':cdpos+'px'}).show();
-
- cdleft = cdpos;
- }
- );
-
- },
- getRp: function() {
- return p.rp;
- },
- newRp: function(value) {
- p.newp = 1;
- p.rp = value;
- g.populate();
- },
- fixHeight: function (newH) {
- newH = false;
- if (!newH) newH = $(g.bDiv).height();
- var hdHeight = $(this.hDiv).height();
- $('div',this.cDrag).each(
- function ()
- {
- $(this).height(newH+hdHeight);
- }
- );
-
- var nd = parseInt($(g.nDiv).height());
-
- if (nd>newH)
- $(g.nDiv).height(newH).width(200);
- else
- $(g.nDiv).height('auto').width('auto');
-
- $(g.block).css({height:newH,marginBottom:(newH * -1)});
-
- var hrH = g.bDiv.offsetTop + newH;
- if (p.height != 'auto' && p.resizable) hrH = g.vDiv.offsetTop;
- $(g.rDiv).css({height: hrH});
-
- var width_pDiv = jQuery(g.pDiv).width();
- var width_hDiv = jQuery(g.hDiv).find('tr').width() - 1;
- jQuery(g.pDiv).find('.pDiv2').width( Math.min(width_pDiv, width_hDiv) );
-
- },
- dragStart: function (dragtype,e,obj) { //default drag function start
-
- if (dragtype=='colresize') //column resize
- {
- $(g.nDiv).hide();$(g.nBtn).hide();
- var n = $('div',this.cDrag).index(obj),
- ow = $('th:visible div:eq('+n+')',this.hDiv).width();
- $(obj).addClass('dragging').siblings().hide();
- $(obj).prev().addClass('dragging').show();
-
- this.colresize = {startX: e.pageX, ol: parseInt(obj.style.left), ow: ow, n : n };
- $('body').css('cursor','col-resize');
- }
- else if (dragtype=='vresize') //table resize
- {
- var hgo = false;
- $('body').css('cursor','row-resize');
- if (obj)
- {
- hgo = true;
- $('body').css('cursor','col-resize');
- }
- this.vresize = {h: p.height, sy: e.pageY, w: p.width, sx: e.pageX, hgo: hgo};
-
- }
-
- else if (dragtype=='colMove') //column header drag
- {
- $(g.nDiv).hide();$(g.nBtn).hide();
- this.hset = $(this.hDiv).offset();
- this.hset.right = this.hset.left + $('table',this.hDiv).width();
- this.hset.bottom = this.hset.top + $('table',this.hDiv).height();
- this.dcol = obj;
- this.dcoln = $('th',this.hDiv).index(obj);
-
- this.colCopy = document.createElement("div");
- this.colCopy.className = "colCopy";
- this.colCopy.innerHTML = obj.innerHTML;
- if ($.browser.msie)
- {
- this.colCopy.className = "colCopy ie";
- }
-
-
- $(this.colCopy).css({position:'absolute','float':'left',display:'none', textAlign: obj.align});
- $('body').append(this.colCopy);
- $(this.cDrag).hide();
-
- }
-
- $('body').noSelect();
-
- },
- dragMove: function (e) {
-
- if (this.colresize) //column resize
- {
- var n = this.colresize.n,
- diff = e.pageX-this.colresize.startX,
- nleft = this.colresize.ol + diff,
- nw = this.colresize.ow + diff;
- if (nw > p.minwidth)
- {
- $('div:eq('+n+')',this.cDrag).css('left',nleft);
- this.colresize.nw = nw;
- }
- }
- else if (this.vresize) //table resize
- {
- var v = this.vresize,
- y = e.pageY,
- diff = y-v.sy;
-
- if (!p.defwidth) p.defwidth = p.width;
-
- if (p.width != 'auto' && !p.nohresize && v.hgo)
- {
- var x = e.pageX,
- xdiff = x - v.sx,
- newW = v.w + xdiff;
- if (newW > p.defwidth)
- {
- this.gDiv.style.width = newW + 'px';
- p.width = newW;
- }
- }
-
- var newH = v.h + diff;
- if ((newH > p.minheight || p.height < p.minheight) && !v.hgo)
- {
- this.bDiv.style.height = newH + 'px';
- p.height = newH;
- this.fixHeight(newH);
- }
- v = null;
- }
- else if (this.colCopy) {
- $(this.dcol).addClass('thMove').removeClass('thOver');
- if (e.pageX > this.hset.right || e.pageX < this.hset.left || e.pageY > this.hset.bottom || e.pageY < this.hset.top)
- {
- //this.dragEnd();
- $('body').css('cursor','move');
- }
- else
- $('body').css('cursor','pointer');
- $(this.colCopy).css({top:e.pageY + 10,left:e.pageX + 20, display: 'block'});
- }
-
- },
- dragEnd: function () {
-
- if (this.colresize)
- {
- var n = this.colresize.n,
- nw = this.colresize.nw;
-
- $('th:visible div:eq('+n+')',this.hDiv).css('width',nw);
- $('tr',this.bDiv).each (
- function ()
- {
- $('td:visible div:eq('+n+')',this).css('width',nw);
- }
- );
- this.hDiv.scrollLeft = this.bDiv.scrollLeft;
-
-
- $('div:eq('+n+')',this.cDrag).siblings().show();
- $('.dragging',this.cDrag).removeClass('dragging');
- this.rePosDrag();
- this.fixHeight();
- this.colresize = false;
- this.populate();
- }
- else if (this.vresize)
- {
- this.vresize = false;
- }
- else if (this.colCopy)
- {
- $(this.colCopy).remove();
- if (this.dcolt != null)
- {
-
-
- if (this.dcoln>this.dcolt)
- $('th:eq('+this.dcolt+')',this.hDiv).before(this.dcol);
- else
- $('th:eq('+this.dcolt+')',this.hDiv).after(this.dcol);
-
-
-
- this.switchCol(this.dcoln,this.dcolt);
- $(this.cdropleft).remove();
- $(this.cdropright).remove();
- this.rePosDrag();
-
- if (p.onDragCol) p.onDragCol(this.dcoln, this.dcolt);
-
- }
-
- this.dcol = null;
- this.hset = null;
- this.dcoln = null;
- this.dcolt = null;
- this.colCopy = null;
-
- $('.thMove',this.hDiv).removeClass('thMove');
- $(this.cDrag).show();
- }
- $('body').css('cursor','default');
- $('body').noSelect(false);
- },
- toggleCol: function(cid,visible) {
-
- var ncol = $("th[axis='col"+cid+"']",this.hDiv)[0],
- n = $('thead th',g.hDiv).index(ncol),
- cb = $('input[value='+cid+']',g.nDiv)[0];
-
- if (visible==null)
- {
- visible = ncol.hide;
- }
-
- if ($('input:checked',g.nDiv).length<p.minColToggle&&!visible) return false;
-
- if (visible)
- {
- ncol.hide = false;
- $(ncol).show();
- cb.checked = true;
- }
- else
- {
- ncol.hide = true;
- $(ncol).hide();
- cb.checked = false;
- }
-
- $('tbody tr',t).each
- (
- function ()
- {
- if (visible)
- $('td:eq('+n+')',this).show();
- else
- $('td:eq('+n+')',this).hide();
- }
- );
-
- this.rePosDrag();
-
- if (p.onToggleCol) p.onToggleCol(cid,visible);
-
- return visible;
- },
- switchCol: function(cdrag,cdrop) { //switch columns
-
- $('tbody tr',t).each
- (
- function ()
- {
- if (cdrag>cdrop)
- $('td:eq('+cdrop+')',this).before($('td:eq('+cdrag+')',this));
- else
- $('td:eq('+cdrop+')',this).after($('td:eq('+cdrag+')',this));
- }
- );
-
- //switch order in nDiv
- if (cdrag>cdrop)
- $('tr:eq('+cdrop+')',this.nDiv).before($('tr:eq('+cdrag+')',this.nDiv));
- else
- $('tr:eq('+cdrop+')',this.nDiv).after($('tr:eq('+cdrag+')',this.nDiv));
-
- if ($.browser.msie&&$.browser.version<7.0) $('tr:eq('+cdrop+') input',this.nDiv)[0].checked = true;
-
- this.hDiv.scrollLeft = this.bDiv.scrollLeft;
- },
- scroll: function() {
- this.hDiv.scrollLeft = this.bDiv.scrollLeft;
- this.rePosDrag();
- },
- addData: function (data) { //parse data
-
- if (p.preProcess)
- data = p.preProcess(data);
-
- if (this.pDiv) {
- this.domElements.pReload.removeClass('loading');
- }
- this.loading = false;
-
- if (!data)
- {
- if (this.pDiv) {
- this.domElements.pPageStat.html(p.errormsg);
- }
- return false;
- }
-
- if (p.dataType=='xml')
- p.total = +$('rows total',data).text();
- else
- p.total = data.total;
-
- if (p.total==0)
- {
- $('tr, a, td, div',t).unbind();
- $(t).empty();
- p.pages = 1;
- p.page = 1;
- this.buildpager();
- if (this.pDiv) {
- this.domElements.pPageStat.html(p.nomsg);
- }
- return false;
- }
-
- p.pages = Math.ceil(p.total/p.rp);
-
- if (p.dataType=='xml')
- p.page = +$('rows page',data).text();
- else
- p.page = data.page;
-
- this.buildpager();
-
- //build new body
- var tbody = document.createElement('tbody');
-
- if (p.dataType=='json')
- {
- $.each
- (
- data.rows,
- function(i,row)
- {
- var tr = document.createElement('tr');
- if (i % 2 && p.striped) tr.className = 'erow';
-
- if (row.id) tr.id = 'row' + row.id;
-
- //add cell
- $('thead tr:first th',g.hDiv).each
- (
- function ()
- {
-
- var td = document.createElement('td'),
- idx = $(this).attr('axis').substr(3);
- td.align = this.align;
- td.innerHTML = row.cell[idx];
- $(tr).append(td);
- td = null;
- }
- );
-
-
- if ($('thead',this.gDiv).length<1) //handle if grid has no headers
- {
-
- for (var idx=0;idx<cell.length;idx++)
- {
- var td = document.createElement('td');
- td.innerHTML = row.cell[idx];
- $(tr).append(td);
- td = null;
- }
- }
-
- $(tbody).append(tr);
- tr = null;
- }
- );
-
- } else if (p.dataType=='xml') {
-
- var i = 1;
-
- $("rows row",data).each
- (
-
- function ()
- {
-
- i++;
-
- var tr = document.createElement('tr');
- if (i % 2 && p.striped) tr.className = 'erow';
-
- var nid =$(this).attr('id');
- if (nid) tr.id = 'row' + nid;
-
- nid = null;
-
- var robj = this;
-
-
-
- $('thead tr:first th',g.hDiv).each
- (
- function ()
- {
-
- var td = document.createElement('td'),
- idx = $(this).attr('axis').substr(3);
- td.align = this.align;
- td.innerHTML = $("cell:eq("+ idx +")",robj).text();
- $(tr).append(td);
- td = null;
- }
- );
-
-
- if ($('thead',this.gDiv).length<1) //handle if grid has no headers
- {
- $('cell',this).each
- (
- function ()
- {
- var td = document.createElement('td');
- td.innerHTML = $(this).text();
- $(tr).append(td);
- td = null;
- }
- );
- }
-
- $(tbody).append(tr);
- tr = null;
- robj = null;
- }
- );
-
- }
-
- $('tr',t).unbind();
- $(t).empty();
-
- $(t).append(tbody);
- this.addCellProp();
- this.addRowProp();
-
- //this.fixHeight($(this.bDiv).height());
-
- this.rePosDrag();
-
- tbody = null; data = null; i = null;
-
- if (p.onSuccess) p.onSuccess(g);
- if (p.hideOnSubmit) $(g.block).remove();//$(t).show();
-
- this.hDiv.scrollLeft = this.bDiv.scrollLeft;
- if ($.browser.opera) $(t).css('visibility','visible');
-
- },
- changeSort: function(th) { //change sortorder
-
- if (this.loading) return true;
-
- $(g.nDiv).hide();$(g.nBtn).hide();
-
- if (p.sortname == $(th).attr('abbr'))
- {
- if (p.sortorder=='asc') p.sortorder = 'desc';
- else p.sortorder = 'asc';
- }
-
- $(th).addClass('sorted').siblings().removeClass('sorted');
- $('.sdesc',this.hDiv).removeClass('sdesc');
- $('.sasc',this.hDiv).removeClass('sasc');
- $('div',th).addClass('s'+p.sortorder);
- p.sortname= $(th).attr('abbr');
-
- if (p.onChangeSort)
- p.onChangeSort(p.sortname,p.sortorder);
- else
- this.populate();
-
- },
- buildpager: function(){ //rebuild pager based on new properties
-
- if (this.pDiv) {
- this.domElements.pcontrol_input.val(p.page);
- this.domElements.pcontrol_span.html(p.pages);
- }
-
- var r1 = (p.page-1) * p.rp + 1,
- r2 = r1 + p.rp - 1;
-
- if (p.total<r2) r2 = p.total;
-
- var stat = p.pagestat;
-
- stat = stat.replace(/{from}/,r1);
- stat = stat.replace(/{to}/,r2);
- stat = stat.replace(/{total}/,p.total);
-
- if (this.pDiv) {
- this.domElements.pPageStat.html(stat);
- }
-
- },
- populate: function () { //get latest data
-
- if (this.loading) return true;
-
- if (p.onSubmit)
- {
- var gh = p.onSubmit();
- if (!gh) return false;
- }
-
- this.loading = true;
- if (!p.url) return false;
-
- if (this.pDiv) {
- this.domElements.pPageStat.html(p.procmsg);
- this.domElements.pReload.addClass('loading');
- }
-
- $(g.block).css({top:g.bDiv.offsetTop, width: jQuery(g.pDiv).find('.pDiv2').width()});
-
- if (p.hideOnSubmit) $(this.gDiv).prepend(g.block); //$(t).hide();
-
- if ($.browser.opera) $(t).css('visibility','hidden');
-
- if (!p.newp) p.newp = 1;
-
- if (p.page>p.pages) p.page = p.pages;
- //var param = {page:p.newp, rp: p.rp, sortname: p.sortname, sortorder: p.sortorder, query: p.query, qtype: p.qtype};
- var param = [
- { name : 'sortname', value : p.sortname}
- ,{ name : 'sortorder', value : p.sortorder }
- ];
- if (p.usepager) {
- param.push({ name: 'page', value: p.newp });
- param.push({ name: 'rp', value: p.rp });
- }
- if (p.query != '') {
- param.push({ name: 'query', value: p.query });
- }
- if (p.qtype != '') {
- param.push({ name: 'qtype', value: p.qtype });
- }
-
- if (p.params)
- {
- for (var pi = 0; pi < p.params.length; pi++) param[param.length] = p.params[pi];
- }
-
- $.ajax({
- type: p.method,
- url: p.url,
- data: param,
- dataType: p.dataType,
- success: function(data){g.addData(data);},
- error: function(XMLHttpRequest, textStatus, errorThrown) { try { if (p.onError) p.onError(XMLHttpRequest, textStatus, errorThrown); } catch (e) {} }
- });
-
- $('.pJSON a').attr('href', p.url + ( p.url.indexOf('?') == -1 ? '?' : '&') + jQuery.param(param));
- },
- doSearch: function () {
- p.query = $('input[name=q]',g.sDiv).val();
- p.qtype = $('select[name=qtype]',g.sDiv).val();
- p.newp = 1;
-
- this.populate();
- },
- changePage: function (ctype){ //change page
-
- if (this.loading) return true;
-
- switch(ctype)
- {
- case 'first': p.newp = 1; break;
- case 'prev': if (p.page>1) p.newp = parseInt(p.page) - 1; break;
- case 'next': if (p.page<p.pages) p.newp = parseInt(p.page) + 1; break;
- case 'last': p.newp = p.pages; break;
- case 'input':
- if (this.pDiv) {
- var nv = parseInt(this.domElements.pcontrol_input.val());
- if (isNaN(nv)) nv = 1;
- if (nv<1) nv = 1;
- else if (nv > p.pages) nv = p.pages;
- this.domElements.pcontrol_input.val(nv);
- p.newp =nv;
- break;
- }
- }
-
- if (p.newp==p.page) return false;
-
- if (p.onChangePage)
- p.onChangePage(p.newp);
- else
- this.populate();
-
- },
- addCellProp: function ()
- {
-
- $('tbody tr td',g.bDiv).each
- (
- function ()
- {
- var tdDiv = document.createElement('div'),
- n = $('td',$(this).parent()).index(this),
- pth = $('th:eq('+n+')',g.hDiv).get(0);
-
- if (pth!=null)
- {
- if (p.sortname==$(pth).attr('abbr')&&p.sortname)
- {
- this.className = 'sorted';
- }
- $(tdDiv).css({textAlign:pth.align,width: $('div:first',pth)[0].style.width});
-
- if (pth.hide) $(this).css('display','none');
-
- }
-
- if (p.nowrap==false) $(tdDiv).css('white-space','normal');
-
- if (this.innerHTML=='') this.innerHTML = ' ';
-
- //tdDiv.value = this.innerHTML; //store preprocess value
- tdDiv.innerHTML = this.innerHTML;
-
- var prnt = $(this).parent()[0],
- pid = false;
- if (prnt.id) pid = prnt.id.substr(3);
-
- if (pth!=null)
- {
- if (pth.process) pth.process(tdDiv,pid);
- }
-
- $(this).empty().append(tdDiv).removeAttr('width'); //wrap content
-
- //add editable event here 'dblclick'
-
- }
- );
-
- },
- getCellDim: function (obj) // get cell prop for editable event
- {
- var ht = parseInt($(obj).height()),
- pht = parseInt($(obj).parent().height()),
- wt = parseInt(obj.style.width),
- pwt = parseInt($(obj).parent().width()),
- top = obj.offsetParent.offsetTop,
- left = obj.offsetParent.offsetLeft,
- pdl = parseInt($(obj).css('paddingLeft')),
- pdt = parseInt($(obj).css('paddingTop'));
- return {ht:ht,wt:wt,top:top,left:left,pdl:pdl, pdt:pdt, pht:pht, pwt: pwt};
- },
- addRowProp: function()
- {
- $('tbody tr',g.bDiv).each
- (
- function ()
- {
- $(this)
- .click(
- function (e)
- {
- var obj = (e.target || e.srcElement); if (obj.href || obj.type) return true;
- $(this).toggleClass('trSelected');
- if (p.singleSelect) $(this).siblings().removeClass('trSelected');
- }
- )
- .mousedown(
- function (e)
- {
- if (e.shiftKey)
- {
- $(this).toggleClass('trSelected');
- g.multisel = true;
- this.focus();
- $(g.gDiv).noSelect();
- }
- }
- )
- .mouseup(
- function ()
- {
- if (g.multisel)
- {
- g.multisel = false;
- $(g.gDiv).noSelect(false);
- }
- }
- )
- .hover(
- function (e)
- {
- if (g.multisel)
- {
- $(this).toggleClass('trSelected');
- }
- },
- function () {}
- )
- ;
-
- if ($.browser.msie&&$.browser.version<7.0)
- {
- $(this)
- .hover(
- function () { $(this).addClass('trOver'); },
- function () { $(this).removeClass('trOver'); }
- )
- ;
- }
- }
- );
-
-
- },
- pager: 0
- };
-
- //create model if any
- if (p.colModel)
- {
- var thead = document.createElement('thead');
- var tr = document.createElement('tr');
-
- for (var i=0;i<p.colModel.length;i++)
- {
- var cm = p.colModel[i],
- th = document.createElement('th');
-
- th.innerHTML = cm.display;
-
- if (cm.name&&cm.sortable)
- $(th).attr('abbr',cm.name);
-
- //th.idx = i;
- $(th).attr('axis','col'+i);
-
- if (cm.align)
- th.align = cm.align;
-
- if (cm.width)
- $(th).attr('width',cm.width);
-
- if (cm.hide)
- {
- th.hide = true;
- }
-
- if (cm.process)
- {
- th.process = cm.process;
- }
-
- $(tr).append(th);
- }
- $(thead).append(tr);
- $(t).prepend(thead);
- } // end if p.colmodel
-
- //init divs
- g.gDiv = document.createElement('div'); //create global container
- g.mDiv = document.createElement('div'); //create title container
- g.hDiv = document.createElement('div'); //create header container
- g.bDiv = document.createElement('div'); //create body container
- g.vDiv = document.createElement('div'); //create grip
- g.rDiv = document.createElement('div'); //create horizontal resizer
- g.cDrag = document.createElement('div'); //create column drag
- g.block = document.createElement('div'); //creat blocker
- g.nDiv = document.createElement('div'); //create column show/hide popup
- g.nBtn = document.createElement('div'); //create column show/hide button
- g.iDiv = document.createElement('div'); //create editable layer
- g.tDiv = document.createElement('div'); //create toolbar
- g.sDiv = document.createElement('div');
-
- if (p.usepager) g.pDiv = document.createElement('div'); //create pager container
- g.hTable = document.createElement('table');
-
- //set gDiv
- g.gDiv.className = 'flexigrid';
- if (p.width!='auto') g.gDiv.style.width = p.width + 'px';
-
- //add conditional classes
- if ($.browser.msie)
- $(g.gDiv).addClass('ie');
-
- if (p.novstripe)
- $(g.gDiv).addClass('novstripe');
-
- $(t).before(g.gDiv);
- $(g.gDiv)
- .append(t)
- ;
-
- //set toolbar
- if (p.buttons)
- {
- g.tDiv.className = 'tDiv';
- var tDiv2 = document.createElement('div');
- tDiv2.className = 'tDiv2';
-
- for (i=0;i<p.buttons.length;i++)
- {
- var btn = p.buttons[i];
- if (!btn.separator)
- {
- var btnDiv = document.createElement('div');
- btnDiv.className = 'fbutton';
- btnDiv.innerHTML = "<div><span>"+btn.name+"</span></div>";
- if (btn.bclass)
- $('span',btnDiv)
- .addClass(btn.bclass)
- .css({paddingLeft:20})
- ;
- btnDiv.onpress = btn.onpress;
- btnDiv.name = btn.name;
- if (btn.onpress)
- {
- $(btnDiv).click
- (
- function ()
- {
- this.onpress(this.name,g.gDiv);
- }
- );
- }
- $(tDiv2).append(btnDiv);
- if ($.browser.msie&&$.browser.version<7.0)
- {
- $(btnDiv).hover(function(){$(this).addClass('fbOver');},function(){$(this).removeClass('fbOver');});
- }
-
- } else {
- $(tDiv2).append("<div class='btnseparator'></div>");
- }
- }
- $(g.tDiv).append(tDiv2);
- $(g.tDiv).append("<div style='clear:both'></div>");
- $(g.gDiv).prepend(g.tDiv);
- }
-
- //set hDiv
- g.hDiv.className = 'hDiv';
-
- $(t).before(g.hDiv);
-
- //set hTable
- g.hTable.cellPadding = 0;
- g.hTable.cellSpacing = 0;
- $(g.hDiv).append('<div class="hDivBox"></div>');
- $('div',g.hDiv).append(g.hTable);
- var thead = $("thead:first",t).get(0);
- if (thead) $(g.hTable).append(thead);
- thead = null;
-
- if (!p.colmodel) var ci = 0;
-
- //setup thead
- $('thead tr:first th',g.hDiv).each
- (
- function ()
- {
- var thdiv = document.createElement('div');
-
-
-
- if ($(this).attr('abbr'))
- {
- $(this).click(
- function (e)
- {
-
- if (!$(this).hasClass('thOver')) return false;
- var obj = (e.target || e.srcElement);
- if (obj.href || obj.type) return true;
- g.changeSort(this);
- }
- )
- ;
-
- if ($(this).attr('abbr')==p.sortname)
- {
- this.className = 'sorted';
- thdiv.className = 's'+p.sortorder;
- }
- }
-
- if (this.hide) $(this).hide();
-
- if (!p.colmodel)
- {
- $(this).attr('axis','col' + ci++);
- }
-
-
- $(thdiv).css({textAlign:this.align, width: this.width + 'px'});
- thdiv.innerHTML = this.innerHTML;
-
- $(this).empty().append(thdiv).removeAttr('width')
- .mousedown(function (e)
- {
- g.dragStart('colMove',e,this);
- })
- .hover(
- function(){
- if (!g.colresize&&!$(this).hasClass('thMove')&&!g.colCopy) $(this).addClass('thOver');
-
- if ($(this).attr('abbr')!=p.sortname&&!g.colCopy&&!g.colresize&&$(this).attr('abbr')) $('div',this).addClass('s'+p.sortorder);
- else if ($(this).attr('abbr')==p.sortname&&!g.colCopy&&!g.colresize&&$(this).attr('abbr'))
- {
- var no = '';
- if (p.sortorder=='asc') no = 'desc';
- else no = 'asc';
- $('div',this).removeClass('s'+p.sortorder).addClass('s'+no);
- }
-
- if (g.colCopy)
- {
- var n = $('th',g.hDiv).index(this);
-
- if (n==g.dcoln) return false;
-
-
-
- if (n<g.dcoln) $(this).append(g.cdropleft);
- else $(this).append(g.cdropright);
-
- g.dcolt = n;
-
- } else if (!g.colresize) {
-
- var nv = $('th:visible',g.hDiv).index(this),
- onl = parseInt($('div:eq('+nv+')',g.cDrag).css('left')),
- nw = jQuery(g.nBtn).outerWidth(),
- nl = onl - nw + Math.floor(p.cgwidth/2);
-
- $(g.nDiv).hide();$(g.nBtn).hide();
-
- $(g.nBtn).css({'left':nl,top:g.hDiv.offsetTop}).show();
-
- var ndw = parseInt($(g.nDiv).width());
-
- $(g.nDiv).css({top:g.bDiv.offsetTop});
-
- if ((nl+ndw)>$(g.gDiv).width())
- $(g.nDiv).css('left',onl-ndw+1);
- else
- $(g.nDiv).css('left',nl);
-
- if ($(this).hasClass('sorted'))
- $(g.nBtn).addClass('srtd');
- else
- $(g.nBtn).removeClass('srtd');
-
- }
-
- },
- function(){
- $(this).removeClass('thOver');
- if ($(this).attr('abbr')!=p.sortname) $('div',this).removeClass('s'+p.sortorder);
- else if ($(this).attr('abbr')==p.sortname)
- {
- var no = '';
- if (p.sortorder=='asc') no = 'desc';
- else no = 'asc';
-
- $('div',this).addClass('s'+p.sortorder).removeClass('s'+no);
- }
- if (g.colCopy)
- {
- $(g.cdropleft).remove();
- $(g.cdropright).remove();
- g.dcolt = null;
- }
- })
- ; //wrap content
- }
- );
-
- //set bDiv
- g.bDiv.className = 'bDiv';
- $(t).before(g.bDiv);
- $(g.bDiv)
- .css({ height: (p.height=='auto') ? 'auto' : p.height+"px"})
- .scroll(function (e) {g.scroll()})
- .append(t)
- ;
-
- if (p.height == 'auto')
- {
- $('table',g.bDiv).addClass('autoht');
- }
-
-
- //add td properties
- g.addCellProp();
-
- //add row properties
- g.addRowProp();
-
- //set cDrag
-
- var cdcol = $('thead tr:first th:first',g.hDiv).get(0);
-
- if (cdcol != null)
- {
- g.cDrag.className = 'cDrag';
- g.cdpad = 0;
-
- g.cdpad += (isNaN(parseInt($('div',cdcol).css('borderLeftWidth'))) ? 0 : parseInt($('div',cdcol).css('borderLeftWidth')));
- g.cdpad += (isNaN(parseInt($('div',cdcol).css('borderRightWidth'))) ? 0 : parseInt($('div',cdcol).css('borderRightWidth')));
- g.cdpad += (isNaN(parseInt($('div',cdcol).css('paddingLeft'))) ? 0 : parseInt($('div',cdcol).css('paddingLeft')));
- g.cdpad += (isNaN(parseInt($('div',cdcol).css('paddingRight'))) ? 0 : parseInt($('div',cdcol).css('paddingRight')));
- g.cdpad += (isNaN(parseInt($(cdcol).css('borderLeftWidth'))) ? 0 : parseInt($(cdcol).css('borderLeftWidth')));
- g.cdpad += (isNaN(parseInt($(cdcol).css('borderRightWidth'))) ? 0 : parseInt($(cdcol).css('borderRightWidth')));
- g.cdpad += (isNaN(parseInt($(cdcol).css('paddingLeft'))) ? 0 : parseInt($(cdcol).css('paddingLeft')));
- g.cdpad += (isNaN(parseInt($(cdcol).css('paddingRight'))) ? 0 : parseInt($(cdcol).css('paddingRight')));
-
- $(g.bDiv).before(g.cDrag);
-
- var cdheight = $(g.bDiv).height(),
- hdheight = $(g.hDiv).height();
-
- $(g.cDrag).css({top: -hdheight + 'px'});
-
- $('thead tr:first th',g.hDiv).each
- (
- function ()
- {
- var cgDiv = document.createElement('div');
- $(g.cDrag).append(cgDiv);
- if (!p.cgwidth) p.cgwidth = $(cgDiv).width();
- $(cgDiv).css({height: cdheight + hdheight})
- .mousedown(function(e){g.dragStart('colresize',e,this);})
- ;
- if ($.browser.msie&&$.browser.version<7.0)
- {
- g.fixHeight($(g.gDiv).height());
- $(cgDiv).hover(
- function ()
- {
- g.fixHeight();
- $(this).addClass('dragging')
- },
- function () { if (!g.colresize) $(this).removeClass('dragging') }
- );
- }
- }
- );
-
- //g.rePosDrag();
-
- }
-
-
- //add strip
- if (p.striped)
- $('tbody tr:odd',g.bDiv).addClass('erow');
-
-
- if (p.resizable && p.height !='auto')
- {
- g.vDiv.className = 'vGrip';
- $(g.vDiv)
- .mousedown(function (e) { g.dragStart('vresize',e)})
- .html('<span></span>');
- $(g.bDiv).after(g.vDiv);
- }
-
- if (p.resizable && p.width !='auto' && !p.nohresize)
- {
- g.rDiv.className = 'hGrip';
- $(g.rDiv)
- .mousedown(function (e) {g.dragStart('vresize',e,true);})
- .html('<span></span>')
- .css('height',$(g.gDiv).height())
- ;
- if ($.browser.msie&&$.browser.version<7.0)
- {
- $(g.rDiv).hover(function(){$(this).addClass('hgOver');},function(){$(this).removeClass('hgOver');});
- }
- $(g.gDiv).append(g.rDiv);
- }
-
- // add pager
- if (p.usepager)
- {
- g.pDiv.className = 'pDiv';
- g.pDiv.innerHTML = '<div class="pDiv2"></div>';
- $(g.bDiv).parent().prepend(g.pDiv);
- var html = ' <div class="pGroup"> <div class="pFirst pButton"><span></span></div><div class="pPrev pButton"><span></span></div> </div> <div class="btnseparator"></div> <div class="pGroup"><span class="pcontrol">'+p.pagetext+' <input type="text" size="4" value="1" /> '+p.outof+' <span> 1 </span></span></div> <div class="btnseparator"></div> <div class="pGroup"> <div class="pNext pButton"><span></span></div><div class="pLast pButton"><span></span></div> </div> <div class="btnseparator"></div> <div class="pGroup"> <div class="pReload pButton"><span></span></div> </div> <div class="btnseparator"></div> <div class="pGroup"> <div class="pJSON pButton"><a href="" target="_blank">JSON</a></div> </div> <div class="btnseparator"></div> <div class="pGroup"><span class="pPageStat"></span></div>';
- $('div',g.pDiv).html(html);
-
- g.domElements = {
- pReload: $('.pReload', g.pDiv),
- pPageStat: $('.pPageStat', g.pDiv),
- pcontrol_input: $('.pcontrol input', g.pDiv),
- pcontrol_span: $('.pcontrol span', g.pDiv)
- };
-
- g.domElements.pReload.click(function(){g.populate()});
- $('.pFirst',g.pDiv).click(function(){g.changePage('first')});
- $('.pPrev',g.pDiv).click(function(){g.changePage('prev')});
- $('.pNext',g.pDiv).click(function(){g.changePage('next')});
- $('.pLast',g.pDiv).click(function(){g.changePage('last')});
- g.domElements.pcontrol_input.keydown(function(e){if(e.keyCode==13) g.changePage('input')});
- if ($.browser.msie&&$.browser.version<7) $('.pButton',g.pDiv).hover(function(){$(this).addClass('pBtnOver');},function(){$(this).removeClass('pBtnOver');});
-
- if (p.useRp)
- {
- var opt = "";
- for (var nx=0;nx<p.rpOptions.length;nx++)
- {
- var sel = '';
- if (p.rp == p.rpOptions[nx]) sel = 'selected="selected"';
- opt += "<option value='" + p.rpOptions[nx] + "' " + sel + " >" + p.rpOptions[nx] + " </option>";
- };
- $('.pDiv2',g.pDiv).prepend("<div class='pGroup'><select name='rp'>"+opt+"</select></div> <div class='btnseparator'></div>");
- $('select',g.pDiv).change(
- function ()
- {
- if (p.onRpChange)
- p.onRpChange(+this.value);
- else
- {
- p.newp = 1;
- p.rp = +this.value;
- g.populate();
- }
- }
- );
- }
-
- //add search button
- if (p.searchitems)
- {
-/* $('.pDiv2',g.pDiv).prepend("<div class='pGroup'> <div class='pSearch pButton'><span></span></div> </div> <div class='btnseparator'></div>");
- $('.pSearch',g.pDiv).click(function(){$(g.sDiv).slideToggle('fast',function(){$('.sDiv:visible input:first',g.gDiv).trigger('focus');});}); */
- //add search box
- g.sDiv.className = 'sDiv';
-
- sitems = p.searchitems;
-
- var sopt = "";
- for (var s = 0; s < sitems.length; s++)
- {
- if (p.qtype=='' && sitems[s].isdefault==true)
- {
- p.qtype = sitems[s].name;
- sel = 'selected="selected"';
- } else sel = '';
- sopt += "<option value='" + sitems[s].name + "' " + sel + " >" + sitems[s].display + " </option>";
- }
-
- if (p.qtype=='') p.qtype = sitems[0].name;
-
- $(g.sDiv).append("<div class='btnseparator'></div> <div class='sDiv2'>"/*+p.findtext*/+" <input title='" + texts.misc.search_for + ': ' + sitems[0].display + "' type='text' size='20' name='q' class='qsbox' />"); // <select name='qtype'>"+sopt+"</select> <!--input type='button' value='Clear' /--></div>");
-
- $('input[name=q],select[name=qtype]',g.sDiv).keydown(function(e){if(e.keyCode==13) g.doSearch()});
- $('input[value=Clear]',g.sDiv).click(function(){$('input[name=q]',g.sDiv).val(''); p.query = ''; g.doSearch(); });
- $(g.pDiv).children().first().append(g.sDiv);
-
- }
-
- }
- $(g.pDiv,g.sDiv).append("<div style='clear:both'></div>");
-
- // add title
- if (p.title)
- {
- g.mDiv.className = 'mDiv';
- g.mDiv.innerHTML = '<div class="ftitle">'+p.title+'</div>';
- $(g.gDiv).prepend(g.mDiv);
- if (p.showTableToggleBtn)
- {
- $(g.mDiv).append('<div class="ptogtitle" title="Minimize/Maximize Table"><span></span></div>');
- $('div.ptogtitle',g.mDiv).click
- (
- function ()
- {
- $(g.gDiv).toggleClass('hideBody');
- $(this).toggleClass('vsble');
- }
- );
- }
- //g.rePosDrag();
- }
-
- //setup cdrops
- g.cdropleft = document.createElement('span');
- g.cdropleft.className = 'cdropleft';
- g.cdropright = document.createElement('span');
- g.cdropright.className = 'cdropright';
-
- //add block
- g.block.className = 'gBlock';
- var gh = $(g.bDiv).height(),
- gtop = g.bDiv.offsetTop;
- $(g.block).css(
- {
- //width: g.bDiv.style.width,
- width: jQuery(g.pDiv).find('.pDiv2').width(),
- height: gh,
- background: 'white',
- position: 'relative',
- marginBottom: (gh * -1),
- zIndex: 1,
- top: gtop,
- left: '0px'
- }
- );
- $(g.block).fadeTo(0,p.blockOpacity);
-
- // add column control
- if ($('th',g.hDiv).length)
- {
-
- g.nDiv.className = 'nDiv';
- g.nDiv.innerHTML = "<table cellpadding='0' cellspacing='0'><tbody></tbody></table>";
- $(g.nDiv).css(
- {
- marginBottom: (gh * -1),
- display: 'none',
- top: gtop
- }
- ).noSelect()
- ;
-
- var cn = 0;
-
- $('th div',g.hDiv).each
- (
- function ()
- {
- var kcol = $("th[axis='col" + cn + "']",g.hDiv)[0],
- chk = 'checked="checked"';
- if (kcol.style.display=='none') chk = '';
-
- $('tbody',g.nDiv).append('<tr><td class="ndcol1"><input type="checkbox" '+ chk +' class="togCol" value="'+ cn +'" /></td><td class="ndcol2">'+this.innerHTML+'</td></tr>');
- cn++;
- }
- );
-
- if ($.browser.msie&&$.browser.version<7.0)
- $('tr',g.nDiv).hover
- (
- function () {$(this).addClass('ndcolover');},
- function () {$(this).removeClass('ndcolover');}
- );
-
- $('td.ndcol2',g.nDiv).click
- (
- function ()
- {
- if ($('input:checked',g.nDiv).length<=p.minColToggle&&$(this).prev().find('input')[0].checked) return false;
- return g.toggleCol($(this).prev().find('input').val());
- }
- );
-
- $('input.togCol',g.nDiv).click
- (
- function ()
- {
-
- if ($('input:checked',g.nDiv).length<p.minColToggle&&this.checked==false) return false;
- $(this).parent().next().trigger('click');
- //return false;
- }
- );
-
-
- $(g.gDiv).prepend(g.nDiv);
-
- $(g.nBtn).addClass('nBtn')
- .html('<div></div>')
- .attr('title','Hide/Show Columns')
- .click
- (
- function ()
- {
- $(g.nDiv).toggle(); return true;
- }
- );
-
- if (p.showToggleBtn) $(g.gDiv).prepend(g.nBtn);
-
- }
-
- // add date edit layer
- $(g.iDiv)
- .addClass('iDiv')
- .css({display:'none'})
- ;
- $(g.bDiv).append(g.iDiv);
-
- // add flexigrid events
- $(g.bDiv)
- .hover(function(){$(g.nDiv).hide();$(g.nBtn).hide();},function(){if (g.multisel) g.multisel = false;})
- ;
- $(g.gDiv)
- .hover(function(){},function(){$(g.nDiv).hide();$(g.nBtn).hide();})
- ;
-
- //add document events
- $(document)
- .mousemove(function(e){g.dragMove(e)})
- .mouseup(function(e){g.dragEnd()})
- .hover(function(){},function (){g.dragEnd()})
- ;
-
- //browser adjustments
- if ($.browser.msie&&$.browser.version<7.0)
- {
- $('.hDiv,.bDiv,.mDiv,.pDiv,.vGrip,.tDiv, .sDiv',g.gDiv)
- .css({width: '100%'});
- $(g.gDiv).addClass('ie6');
- if (p.width!='auto') $(g.gDiv).addClass('ie6fullwidthbug');
- }
-
- g.rePosDrag();
- g.fixHeight();
-
- //make grid functions accessible
- t.p = p;
- t.grid = g;
-
- // load data
- if (p.url&&p.autoload)
- {
- g.populate();
- }
-
- return t;
-
- };
-
- var docloaded = false;
-
- $(document).ready(function () {docloaded = true} );
-
- $.fn.flexigrid = function(p) {
-
- return this.each( function() {
- if (!docloaded)
- {
- $(this).hide();
- var t = this;
- $(document).ready
- (
- function ()
- {
- $.addFlex(t,p);
- }
- );
- } else {
- $.addFlex(this,p);
- }
- });
-
- }; //end flexigrid
-
- $.fn.flexReload = function(p) { // function to reload grid
-
- return this.each( function() {
- if (this.grid&&this.p.url) this.grid.populate();
- });
-
- }; //end flexReload
-
- $.fn.flexOptions = function(p) { //function to update general options
-
- return this.each( function() {
- if (this.grid) $.extend(this.p,p);
- });
-
- }; //end flexOptions
-
- $.fn.flexToggleCol = function(cid,visible) { // function to reload grid
-
- return this.each( function() {
- if (this.grid) this.grid.toggleCol(cid,visible);
- });
-
- }; //end flexToggleCol
-
- $.fn.flexAddData = function(data) { // function to add data to grid
-
- return this.each( function() {
- if (this.grid) this.grid.addData(data);
- });
-
- };
-
- $.fn.noSelect = function(p) { //no select plugin by me :-)
-
- if (p == null)
- prevent = true;
- else
- prevent = p;
-
- if (prevent) {
-
- return this.each(function ()
- {
- if ($.browser.msie||$.browser.safari) $(this).bind('selectstart',function(){return false;});
- else if ($.browser.mozilla)
- {
- $(this).css('MozUserSelect','none');
- $('body').trigger('focus');
- }
- else if ($.browser.opera) $(this).bind('mousedown',function(){return false;});
- else $(this).attr('unselectable','on');
- });
-
- } else {
-
-
- return this.each(function ()
- {
- if ($.browser.msie||$.browser.safari) $(this).unbind('selectstart');
- else if ($.browser.mozilla) $(this).css('MozUserSelect','inherit');
- else if ($.browser.opera) $(this).unbind('mousedown');
- else $(this).removeAttr('unselectable','on');
- });
-
- }
-
- }; //end noSelect
-
-})(jQuery);
+/* + * Flexigrid for jQuery - New Wave Grid + * + * Copyright (c) 2008 Paulo P. Marinas (webplicity.net/flexigrid) + * Dual licensed under the MIT (MIT-LICENSE.txt) + * and GPL (GPL-LICENSE.txt) licenses. + * + * $Date: 2008-07-14 00:09:43 +0800 (Tue, 14 Jul 2008) $ + */ + +(function($){ + + $.addFlex = function(t,p) + { + + if (t.grid) return false; //return if already exist + + // apply default properties + p = $.extend({ + height: 200, //default height + width: 'auto', //auto width + striped: true, //apply odd even stripes + novstripe: false, + minwidth: 30, //min width of columns + minheight: 80, //min height of columns + resizable: true, //resizable table + url: false, //ajax url + method: 'POST', // data sending method + dataType: 'xml', // type of data loaded + errormsg: 'Connection Error', + usepager: false, // + nowrap: true, // + page: 1, //current page + total: 1, //total pages + useRp: true, //use the results per page select box + rp: 15, // results per page + rpOptions: [10,15,20,25,40], + title: false, + pagestat: 'Displaying {from} to {to} of {total} items', + pagetext: 'Page', + outof: 'of', + findtext: 'Find', + procmsg: 'Processing, please wait ...', + query: '', + qtype: '', + nomsg: 'No items', + minColToggle: 1, //minimum allowed column to be hidden + showToggleBtn: true, //show or hide column toggle popup + hideOnSubmit: true, + autoload: true, + blockOpacity: 0.5, + onDragCol: false, + onToggleCol: false, + onChangeSort: false, + onSuccess: false, + onError: false, + onSubmit: false // using a custom populate function + }, p); + + + $(t) + .show() //show if hidden + .attr({cellPadding: 0, cellSpacing: 0, border: 0}) //remove padding and spacing + .removeAttr('width') //remove width properties + ; + + //create grid class + var g = { + hset : {}, + rePosDrag: function () { + + var cdleft = 0 - this.hDiv.scrollLeft; + if (this.hDiv.scrollLeft>0) cdleft -= Math.floor(p.cgwidth/2); + $(g.cDrag).css({top:g.hDiv.offsetTop+1}); + var cdpad = this.cdpad; + + $('div',g.cDrag).hide(); + + $('thead tr:first th:visible',this.hDiv).each + ( + function () + { + var n = $('thead tr:first th:visible',g.hDiv).index(this), + cdpos = parseInt($('div',this).width()); + if (cdleft==0) + cdleft -= Math.floor(p.cgwidth/2); + + cdpos = cdpos + cdleft + cdpad; + + $('div:eq('+n+')',g.cDrag).css({'left':cdpos+'px'}).show(); + + cdleft = cdpos; + } + ); + + }, + getRp: function() { + return p.rp; + }, + newRp: function(value) { + p.newp = 1; + p.rp = value; + g.populate(); + }, + fixHeight: function (newH) { + newH = false; + if (!newH) newH = $(g.bDiv).height(); + var hdHeight = $(this.hDiv).height(); + $('div',this.cDrag).each( + function () + { + $(this).height(newH+hdHeight); + } + ); + + var nd = parseInt($(g.nDiv).height()); + + if (nd>newH) + $(g.nDiv).height(newH).width(200); + else + $(g.nDiv).height('auto').width('auto'); + + $(g.block).css({height:newH,marginBottom:(newH * -1)}); + + var hrH = g.bDiv.offsetTop + newH; + if (p.height != 'auto' && p.resizable) hrH = g.vDiv.offsetTop; + $(g.rDiv).css({height: hrH}); + + var width_pDiv = jQuery(g.pDiv).width(); + var width_hDiv = jQuery(g.hDiv).find('tr').width() - 1; + jQuery(g.pDiv).find('.pDiv2').width( Math.min(width_pDiv, width_hDiv) ); + + }, + dragStart: function (dragtype,e,obj) { //default drag function start + + if (dragtype=='colresize') //column resize + { + $(g.nDiv).hide();$(g.nBtn).hide(); + var n = $('div',this.cDrag).index(obj), + ow = $('th:visible div:eq('+n+')',this.hDiv).width(); + $(obj).addClass('dragging').siblings().hide(); + $(obj).prev().addClass('dragging').show(); + + this.colresize = {startX: e.pageX, ol: parseInt(obj.style.left), ow: ow, n : n }; + $('body').css('cursor','col-resize'); + } + else if (dragtype=='vresize') //table resize + { + var hgo = false; + $('body').css('cursor','row-resize'); + if (obj) + { + hgo = true; + $('body').css('cursor','col-resize'); + } + this.vresize = {h: p.height, sy: e.pageY, w: p.width, sx: e.pageX, hgo: hgo}; + + } + + else if (dragtype=='colMove') //column header drag + { + $(g.nDiv).hide();$(g.nBtn).hide(); + this.hset = $(this.hDiv).offset(); + this.hset.right = this.hset.left + $('table',this.hDiv).width(); + this.hset.bottom = this.hset.top + $('table',this.hDiv).height(); + this.dcol = obj; + this.dcoln = $('th',this.hDiv).index(obj); + + this.colCopy = document.createElement("div"); + this.colCopy.className = "colCopy"; + this.colCopy.innerHTML = obj.innerHTML; + if ($.browser.msie) + { + this.colCopy.className = "colCopy ie"; + } + + + $(this.colCopy).css({position:'absolute','float':'left',display:'none', textAlign: obj.align}); + $('body').append(this.colCopy); + $(this.cDrag).hide(); + + } + + $('body').noSelect(); + + }, + dragMove: function (e) { + + if (this.colresize) //column resize + { + var n = this.colresize.n, + diff = e.pageX-this.colresize.startX, + nleft = this.colresize.ol + diff, + nw = this.colresize.ow + diff; + if (nw > p.minwidth) + { + $('div:eq('+n+')',this.cDrag).css('left',nleft); + this.colresize.nw = nw; + } + } + else if (this.vresize) //table resize + { + var v = this.vresize, + y = e.pageY, + diff = y-v.sy; + + if (!p.defwidth) p.defwidth = p.width; + + if (p.width != 'auto' && !p.nohresize && v.hgo) + { + var x = e.pageX, + xdiff = x - v.sx, + newW = v.w + xdiff; + if (newW > p.defwidth) + { + this.gDiv.style.width = newW + 'px'; + p.width = newW; + } + } + + var newH = v.h + diff; + if ((newH > p.minheight || p.height < p.minheight) && !v.hgo) + { + this.bDiv.style.height = newH + 'px'; + p.height = newH; + this.fixHeight(newH); + } + v = null; + } + else if (this.colCopy) { + $(this.dcol).addClass('thMove').removeClass('thOver'); + if (e.pageX > this.hset.right || e.pageX < this.hset.left || e.pageY > this.hset.bottom || e.pageY < this.hset.top) + { + //this.dragEnd(); + $('body').css('cursor','move'); + } + else + $('body').css('cursor','pointer'); + $(this.colCopy).css({top:e.pageY + 10,left:e.pageX + 20, display: 'block'}); + } + + }, + dragEnd: function () { + + if (this.colresize) + { + var n = this.colresize.n, + nw = this.colresize.nw; + + $('th:visible div:eq('+n+')',this.hDiv).css('width',nw); + $('tr',this.bDiv).each ( + function () + { + $('td:visible div:eq('+n+')',this).css('width',nw); + } + ); + this.hDiv.scrollLeft = this.bDiv.scrollLeft; + + + $('div:eq('+n+')',this.cDrag).siblings().show(); + $('.dragging',this.cDrag).removeClass('dragging'); + this.rePosDrag(); + this.fixHeight(); + this.colresize = false; + this.populate(); + } + else if (this.vresize) + { + this.vresize = false; + } + else if (this.colCopy) + { + $(this.colCopy).remove(); + if (this.dcolt != null) + { + + + if (this.dcoln>this.dcolt) + $('th:eq('+this.dcolt+')',this.hDiv).before(this.dcol); + else + $('th:eq('+this.dcolt+')',this.hDiv).after(this.dcol); + + + + this.switchCol(this.dcoln,this.dcolt); + $(this.cdropleft).remove(); + $(this.cdropright).remove(); + this.rePosDrag(); + + if (p.onDragCol) p.onDragCol(this.dcoln, this.dcolt); + + } + + this.dcol = null; + this.hset = null; + this.dcoln = null; + this.dcolt = null; + this.colCopy = null; + + $('.thMove',this.hDiv).removeClass('thMove'); + $(this.cDrag).show(); + } + $('body').css('cursor','default'); + $('body').noSelect(false); + }, + toggleCol: function(cid,visible) { + + var ncol = $("th[axis='col"+cid+"']",this.hDiv)[0], + n = $('thead th',g.hDiv).index(ncol), + cb = $('input[value='+cid+']',g.nDiv)[0]; + + if (visible==null) + { + visible = ncol.hide; + } + + if ($('input:checked',g.nDiv).length<p.minColToggle&&!visible) return false; + + if (visible) + { + ncol.hide = false; + $(ncol).show(); + cb.checked = true; + } + else + { + ncol.hide = true; + $(ncol).hide(); + cb.checked = false; + } + + $('tbody tr',t).each + ( + function () + { + if (visible) + $('td:eq('+n+')',this).show(); + else + $('td:eq('+n+')',this).hide(); + } + ); + + this.rePosDrag(); + + if (p.onToggleCol) p.onToggleCol(cid,visible); + + return visible; + }, + switchCol: function(cdrag,cdrop) { //switch columns + + $('tbody tr',t).each + ( + function () + { + if (cdrag>cdrop) + $('td:eq('+cdrop+')',this).before($('td:eq('+cdrag+')',this)); + else + $('td:eq('+cdrop+')',this).after($('td:eq('+cdrag+')',this)); + } + ); + + //switch order in nDiv + if (cdrag>cdrop) + $('tr:eq('+cdrop+')',this.nDiv).before($('tr:eq('+cdrag+')',this.nDiv)); + else + $('tr:eq('+cdrop+')',this.nDiv).after($('tr:eq('+cdrag+')',this.nDiv)); + + if ($.browser.msie&&$.browser.version<7.0) $('tr:eq('+cdrop+') input',this.nDiv)[0].checked = true; + + this.hDiv.scrollLeft = this.bDiv.scrollLeft; + }, + scroll: function() { + this.hDiv.scrollLeft = this.bDiv.scrollLeft; + this.rePosDrag(); + }, + addData: function (data) { //parse data + + if (p.preProcess) + data = p.preProcess(data); + + if (this.pDiv) { + this.domElements.pReload.removeClass('loading'); + } + this.loading = false; + + if (!data) + { + if (this.pDiv) { + this.domElements.pPageStat.html(p.errormsg); + } + return false; + } + + if (p.dataType=='xml') + p.total = +$('rows total',data).text(); + else + p.total = data.total; + + if (p.total==0) + { + $('tr, a, td, div',t).unbind(); + $(t).empty(); + p.pages = 1; + p.page = 1; + this.buildpager(); + if (this.pDiv) { + this.domElements.pPageStat.html(p.nomsg); + } + return false; + } + + p.pages = Math.ceil(p.total/p.rp); + + if (p.dataType=='xml') + p.page = +$('rows page',data).text(); + else + p.page = data.page; + + this.buildpager(); + + //build new body + var tbody = document.createElement('tbody'); + + if (p.dataType=='json') + { + $.each + ( + data.rows, + function(i,row) + { + var tr = document.createElement('tr'); + if (i % 2 && p.striped) tr.className = 'erow'; + + if (row.id) tr.id = 'row' + row.id; + + //add cell + $('thead tr:first th',g.hDiv).each + ( + function () + { + + var td = document.createElement('td'), + idx = $(this).attr('axis').substr(3); + td.align = this.align; + td.innerHTML = row.cell[idx]; + $(tr).append(td); + td = null; + } + ); + + + if ($('thead',this.gDiv).length<1) //handle if grid has no headers + { + + for (var idx=0;idx<cell.length;idx++) + { + var td = document.createElement('td'); + td.innerHTML = row.cell[idx]; + $(tr).append(td); + td = null; + } + } + + $(tbody).append(tr); + tr = null; + } + ); + + } else if (p.dataType=='xml') { + + var i = 1; + + $("rows row",data).each + ( + + function () + { + + i++; + + var tr = document.createElement('tr'); + if (i % 2 && p.striped) tr.className = 'erow'; + + var nid =$(this).attr('id'); + if (nid) tr.id = 'row' + nid; + + nid = null; + + var robj = this; + + + + $('thead tr:first th',g.hDiv).each + ( + function () + { + + var td = document.createElement('td'), + idx = $(this).attr('axis').substr(3); + td.align = this.align; + td.innerHTML = $("cell:eq("+ idx +")",robj).text(); + $(tr).append(td); + td = null; + } + ); + + + if ($('thead',this.gDiv).length<1) //handle if grid has no headers + { + $('cell',this).each + ( + function () + { + var td = document.createElement('td'); + td.innerHTML = $(this).text(); + $(tr).append(td); + td = null; + } + ); + } + + $(tbody).append(tr); + tr = null; + robj = null; + } + ); + + } + + $('tr',t).unbind(); + $(t).empty(); + + $(t).append(tbody); + this.addCellProp(); + this.addRowProp(); + + //this.fixHeight($(this.bDiv).height()); + + this.rePosDrag(); + + tbody = null; data = null; i = null; + + if (p.onSuccess) p.onSuccess(g); + if (p.hideOnSubmit) $(g.block).remove();//$(t).show(); + + this.hDiv.scrollLeft = this.bDiv.scrollLeft; + if ($.browser.opera) $(t).css('visibility','visible'); + + }, + changeSort: function(th) { //change sortorder + + if (this.loading) return true; + + $(g.nDiv).hide();$(g.nBtn).hide(); + + if (p.sortname == $(th).attr('abbr')) + { + if (p.sortorder=='asc') p.sortorder = 'desc'; + else p.sortorder = 'asc'; + } + + $(th).addClass('sorted').siblings().removeClass('sorted'); + $('.sdesc',this.hDiv).removeClass('sdesc'); + $('.sasc',this.hDiv).removeClass('sasc'); + $('div',th).addClass('s'+p.sortorder); + p.sortname= $(th).attr('abbr'); + + if (p.onChangeSort) + p.onChangeSort(p.sortname,p.sortorder); + else + this.populate(); + + }, + buildpager: function(){ //rebuild pager based on new properties + + if (this.pDiv) { + this.domElements.pcontrol_input.val(p.page); + this.domElements.pcontrol_span.html(p.pages); + } + + var r1 = (p.page-1) * p.rp + 1, + r2 = r1 + p.rp - 1; + + if (p.total<r2) r2 = p.total; + + var stat = p.pagestat; + + stat = stat.replace(/{from}/,r1); + stat = stat.replace(/{to}/,r2); + stat = stat.replace(/{total}/,p.total); + + if (this.pDiv) { + this.domElements.pPageStat.html(stat); + } + + }, + populate: function () { //get latest data + + if (this.loading) return true; + + if (p.onSubmit) + { + var gh = p.onSubmit(); + if (!gh) return false; + } + + this.loading = true; + if (!p.url) return false; + + if (this.pDiv) { + this.domElements.pPageStat.html(p.procmsg); + this.domElements.pReload.addClass('loading'); + } + + $(g.block).css({top:g.bDiv.offsetTop, width: jQuery(g.pDiv).find('.pDiv2').width()}); + + if (p.hideOnSubmit) $(this.gDiv).prepend(g.block); //$(t).hide(); + + if ($.browser.opera) $(t).css('visibility','hidden'); + + if (!p.newp) p.newp = 1; + + if (p.page>p.pages) p.page = p.pages; + //var param = {page:p.newp, rp: p.rp, sortname: p.sortname, sortorder: p.sortorder, query: p.query, qtype: p.qtype}; + var param = [ + { name : 'sortname', value : p.sortname} + ,{ name : 'sortorder', value : p.sortorder } + ]; + if (p.usepager) { + param.push({ name: 'page', value: p.newp }); + param.push({ name: 'rp', value: p.rp }); + } + if (p.query != '') { + param.push({ name: 'query', value: p.query }); + } + if (p.qtype != '') { + param.push({ name: 'qtype', value: p.qtype }); + } + + if (p.params) + { + for (var pi = 0; pi < p.params.length; pi++) param[param.length] = p.params[pi]; + } + + $.ajax({ + type: p.method, + url: p.url, + data: param, + dataType: p.dataType, + success: function(data){g.addData(data);}, + error: function(XMLHttpRequest, textStatus, errorThrown) { try { if (p.onError) p.onError(XMLHttpRequest, textStatus, errorThrown); } catch (e) {} } + }); + + $('.pJSON a').attr('href', p.url + ( p.url.indexOf('?') == -1 ? '?' : '&') + jQuery.param(param)); + }, + doSearch: function () { + p.query = $('input[name=q]',g.sDiv).val(); + p.qtype = $('select[name=qtype]',g.sDiv).val(); + p.newp = 1; + + this.populate(); + }, + changePage: function (ctype){ //change page + + if (this.loading) return true; + + switch(ctype) + { + case 'first': p.newp = 1; break; + case 'prev': if (p.page>1) p.newp = parseInt(p.page) - 1; break; + case 'next': if (p.page<p.pages) p.newp = parseInt(p.page) + 1; break; + case 'last': p.newp = p.pages; break; + case 'input': + if (this.pDiv) { + var nv = parseInt(this.domElements.pcontrol_input.val()); + if (isNaN(nv)) nv = 1; + if (nv<1) nv = 1; + else if (nv > p.pages) nv = p.pages; + this.domElements.pcontrol_input.val(nv); + p.newp =nv; + break; + } + } + + if (p.newp==p.page) return false; + + if (p.onChangePage) + p.onChangePage(p.newp); + else + this.populate(); + + }, + addCellProp: function () + { + + $('tbody tr td',g.bDiv).each + ( + function () + { + var tdDiv = document.createElement('div'), + n = $('td',$(this).parent()).index(this), + pth = $('th:eq('+n+')',g.hDiv).get(0); + + if (pth!=null) + { + if (p.sortname==$(pth).attr('abbr')&&p.sortname) + { + this.className = 'sorted'; + } + $(tdDiv).css({textAlign:pth.align,width: $('div:first',pth)[0].style.width}); + + if (pth.hide) $(this).css('display','none'); + + } + + if (p.nowrap==false) $(tdDiv).css('white-space','normal'); + + if (this.innerHTML=='') this.innerHTML = ' '; + + //tdDiv.value = this.innerHTML; //store preprocess value + tdDiv.innerHTML = this.innerHTML; + + var prnt = $(this).parent()[0], + pid = false; + if (prnt.id) pid = prnt.id.substr(3); + + if (pth!=null) + { + if (pth.process) pth.process(tdDiv,pid); + } + + $(this).empty().append(tdDiv).removeAttr('width'); //wrap content + + //add editable event here 'dblclick' + + } + ); + + }, + getCellDim: function (obj) // get cell prop for editable event + { + var ht = parseInt($(obj).height()), + pht = parseInt($(obj).parent().height()), + wt = parseInt(obj.style.width), + pwt = parseInt($(obj).parent().width()), + top = obj.offsetParent.offsetTop, + left = obj.offsetParent.offsetLeft, + pdl = parseInt($(obj).css('paddingLeft')), + pdt = parseInt($(obj).css('paddingTop')); + return {ht:ht,wt:wt,top:top,left:left,pdl:pdl, pdt:pdt, pht:pht, pwt: pwt}; + }, + addRowProp: function() + { + $('tbody tr',g.bDiv).each + ( + function () + { + $(this) + .click( + function (e) + { + var obj = (e.target || e.srcElement); if (obj.href || obj.type) return true; + $(this).toggleClass('trSelected'); + if (p.singleSelect) $(this).siblings().removeClass('trSelected'); + } + ) + .mousedown( + function (e) + { + if (e.shiftKey) + { + $(this).toggleClass('trSelected'); + g.multisel = true; + this.focus(); + $(g.gDiv).noSelect(); + } + } + ) + .mouseup( + function () + { + if (g.multisel) + { + g.multisel = false; + $(g.gDiv).noSelect(false); + } + } + ) + .hover( + function (e) + { + if (g.multisel) + { + $(this).toggleClass('trSelected'); + } + }, + function () {} + ) + ; + + if ($.browser.msie&&$.browser.version<7.0) + { + $(this) + .hover( + function () { $(this).addClass('trOver'); }, + function () { $(this).removeClass('trOver'); } + ) + ; + } + } + ); + + + }, + pager: 0 + }; + + //create model if any + if (p.colModel) + { + var thead = document.createElement('thead'); + var tr = document.createElement('tr'); + + for (var i=0;i<p.colModel.length;i++) + { + var cm = p.colModel[i], + th = document.createElement('th'); + + th.innerHTML = cm.display; + + if (cm.name&&cm.sortable) + $(th).attr('abbr',cm.name); + + //th.idx = i; + $(th).attr('axis','col'+i); + + if (cm.align) + th.align = cm.align; + + if (cm.width) + $(th).attr('width',cm.width); + + if (cm.hide) + { + th.hide = true; + } + + if (cm.process) + { + th.process = cm.process; + } + + $(tr).append(th); + } + $(thead).append(tr); + $(t).prepend(thead); + } // end if p.colmodel + + //init divs + g.gDiv = document.createElement('div'); //create global container + g.mDiv = document.createElement('div'); //create title container + g.hDiv = document.createElement('div'); //create header container + g.bDiv = document.createElement('div'); //create body container + g.vDiv = document.createElement('div'); //create grip + g.rDiv = document.createElement('div'); //create horizontal resizer + g.cDrag = document.createElement('div'); //create column drag + g.block = document.createElement('div'); //creat blocker + g.nDiv = document.createElement('div'); //create column show/hide popup + g.nBtn = document.createElement('div'); //create column show/hide button + g.iDiv = document.createElement('div'); //create editable layer + g.tDiv = document.createElement('div'); //create toolbar + g.sDiv = document.createElement('div'); + + if (p.usepager) g.pDiv = document.createElement('div'); //create pager container + g.hTable = document.createElement('table'); + + //set gDiv + g.gDiv.className = 'flexigrid'; + if (p.width!='auto') g.gDiv.style.width = p.width + 'px'; + + //add conditional classes + if ($.browser.msie) + $(g.gDiv).addClass('ie'); + + if (p.novstripe) + $(g.gDiv).addClass('novstripe'); + + $(t).before(g.gDiv); + $(g.gDiv) + .append(t) + ; + + //set toolbar + if (p.buttons) + { + g.tDiv.className = 'tDiv'; + var tDiv2 = document.createElement('div'); + tDiv2.className = 'tDiv2'; + + for (i=0;i<p.buttons.length;i++) + { + var btn = p.buttons[i]; + if (!btn.separator) + { + var btnDiv = document.createElement('div'); + btnDiv.className = 'fbutton'; + btnDiv.innerHTML = "<div><span>"+btn.name+"</span></div>"; + if (btn.bclass) + $('span',btnDiv) + .addClass(btn.bclass) + .css({paddingLeft:20}) + ; + btnDiv.onpress = btn.onpress; + btnDiv.name = btn.name; + if (btn.onpress) + { + $(btnDiv).click + ( + function () + { + this.onpress(this.name,g.gDiv); + } + ); + } + $(tDiv2).append(btnDiv); + if ($.browser.msie&&$.browser.version<7.0) + { + $(btnDiv).hover(function(){$(this).addClass('fbOver');},function(){$(this).removeClass('fbOver');}); + } + + } else { + $(tDiv2).append("<div class='btnseparator'></div>"); + } + } + $(g.tDiv).append(tDiv2); + $(g.tDiv).append("<div style='clear:both'></div>"); + $(g.gDiv).prepend(g.tDiv); + } + + //set hDiv + g.hDiv.className = 'hDiv'; + + $(t).before(g.hDiv); + + //set hTable + g.hTable.cellPadding = 0; + g.hTable.cellSpacing = 0; + $(g.hDiv).append('<div class="hDivBox"></div>'); + $('div',g.hDiv).append(g.hTable); + var thead = $("thead:first",t).get(0); + if (thead) $(g.hTable).append(thead); + thead = null; + + if (!p.colmodel) var ci = 0; + + //setup thead + $('thead tr:first th',g.hDiv).each + ( + function () + { + var thdiv = document.createElement('div'); + + + + if ($(this).attr('abbr')) + { + $(this).click( + function (e) + { + + if (!$(this).hasClass('thOver')) return false; + var obj = (e.target || e.srcElement); + if (obj.href || obj.type) return true; + g.changeSort(this); + } + ) + ; + + if ($(this).attr('abbr')==p.sortname) + { + this.className = 'sorted'; + thdiv.className = 's'+p.sortorder; + } + } + + if (this.hide) $(this).hide(); + + if (!p.colmodel) + { + $(this).attr('axis','col' + ci++); + } + + + $(thdiv).css({textAlign:this.align, width: this.width + 'px'}); + thdiv.innerHTML = this.innerHTML; + + $(this).empty().append(thdiv).removeAttr('width') + .mousedown(function (e) + { + g.dragStart('colMove',e,this); + }) + .hover( + function(){ + if (!g.colresize&&!$(this).hasClass('thMove')&&!g.colCopy) $(this).addClass('thOver'); + + if ($(this).attr('abbr')!=p.sortname&&!g.colCopy&&!g.colresize&&$(this).attr('abbr')) $('div',this).addClass('s'+p.sortorder); + else if ($(this).attr('abbr')==p.sortname&&!g.colCopy&&!g.colresize&&$(this).attr('abbr')) + { + var no = ''; + if (p.sortorder=='asc') no = 'desc'; + else no = 'asc'; + $('div',this).removeClass('s'+p.sortorder).addClass('s'+no); + } + + if (g.colCopy) + { + var n = $('th',g.hDiv).index(this); + + if (n==g.dcoln) return false; + + + + if (n<g.dcoln) $(this).append(g.cdropleft); + else $(this).append(g.cdropright); + + g.dcolt = n; + + } else if (!g.colresize) { + + var nv = $('th:visible',g.hDiv).index(this), + onl = parseInt($('div:eq('+nv+')',g.cDrag).css('left')), + nw = jQuery(g.nBtn).outerWidth(), + nl = onl - nw + Math.floor(p.cgwidth/2); + + $(g.nDiv).hide();$(g.nBtn).hide(); + + $(g.nBtn).css({'left':nl,top:g.hDiv.offsetTop}).show(); + + var ndw = parseInt($(g.nDiv).width()); + + $(g.nDiv).css({top:g.bDiv.offsetTop}); + + if ((nl+ndw)>$(g.gDiv).width()) + $(g.nDiv).css('left',onl-ndw+1); + else + $(g.nDiv).css('left',nl); + + if ($(this).hasClass('sorted')) + $(g.nBtn).addClass('srtd'); + else + $(g.nBtn).removeClass('srtd'); + + } + + }, + function(){ + $(this).removeClass('thOver'); + if ($(this).attr('abbr')!=p.sortname) $('div',this).removeClass('s'+p.sortorder); + else if ($(this).attr('abbr')==p.sortname) + { + var no = ''; + if (p.sortorder=='asc') no = 'desc'; + else no = 'asc'; + + $('div',this).addClass('s'+p.sortorder).removeClass('s'+no); + } + if (g.colCopy) + { + $(g.cdropleft).remove(); + $(g.cdropright).remove(); + g.dcolt = null; + } + }) + ; //wrap content + } + ); + + //set bDiv + g.bDiv.className = 'bDiv'; + $(t).before(g.bDiv); + $(g.bDiv) + .css({ height: (p.height=='auto') ? 'auto' : p.height+"px"}) + .scroll(function (e) {g.scroll()}) + .append(t) + ; + + if (p.height == 'auto') + { + $('table',g.bDiv).addClass('autoht'); + } + + + //add td properties + g.addCellProp(); + + //add row properties + g.addRowProp(); + + //set cDrag + + var cdcol = $('thead tr:first th:first',g.hDiv).get(0); + + if (cdcol != null) + { + g.cDrag.className = 'cDrag'; + g.cdpad = 0; + + g.cdpad += (isNaN(parseInt($('div',cdcol).css('borderLeftWidth'))) ? 0 : parseInt($('div',cdcol).css('borderLeftWidth'))); + g.cdpad += (isNaN(parseInt($('div',cdcol).css('borderRightWidth'))) ? 0 : parseInt($('div',cdcol).css('borderRightWidth'))); + g.cdpad += (isNaN(parseInt($('div',cdcol).css('paddingLeft'))) ? 0 : parseInt($('div',cdcol).css('paddingLeft'))); + g.cdpad += (isNaN(parseInt($('div',cdcol).css('paddingRight'))) ? 0 : parseInt($('div',cdcol).css('paddingRight'))); + g.cdpad += (isNaN(parseInt($(cdcol).css('borderLeftWidth'))) ? 0 : parseInt($(cdcol).css('borderLeftWidth'))); + g.cdpad += (isNaN(parseInt($(cdcol).css('borderRightWidth'))) ? 0 : parseInt($(cdcol).css('borderRightWidth'))); + g.cdpad += (isNaN(parseInt($(cdcol).css('paddingLeft'))) ? 0 : parseInt($(cdcol).css('paddingLeft'))); + g.cdpad += (isNaN(parseInt($(cdcol).css('paddingRight'))) ? 0 : parseInt($(cdcol).css('paddingRight'))); + + $(g.bDiv).before(g.cDrag); + + var cdheight = $(g.bDiv).height(), + hdheight = $(g.hDiv).height(); + + $(g.cDrag).css({top: -hdheight + 'px'}); + + $('thead tr:first th',g.hDiv).each + ( + function () + { + var cgDiv = document.createElement('div'); + $(g.cDrag).append(cgDiv); + if (!p.cgwidth) p.cgwidth = $(cgDiv).width(); + $(cgDiv).css({height: cdheight + hdheight}) + .mousedown(function(e){g.dragStart('colresize',e,this);}) + ; + if ($.browser.msie&&$.browser.version<7.0) + { + g.fixHeight($(g.gDiv).height()); + $(cgDiv).hover( + function () + { + g.fixHeight(); + $(this).addClass('dragging') + }, + function () { if (!g.colresize) $(this).removeClass('dragging') } + ); + } + } + ); + + //g.rePosDrag(); + + } + + + //add strip + if (p.striped) + $('tbody tr:odd',g.bDiv).addClass('erow'); + + + if (p.resizable && p.height !='auto') + { + g.vDiv.className = 'vGrip'; + $(g.vDiv) + .mousedown(function (e) { g.dragStart('vresize',e)}) + .html('<span></span>'); + $(g.bDiv).after(g.vDiv); + } + + if (p.resizable && p.width !='auto' && !p.nohresize) + { + g.rDiv.className = 'hGrip'; + $(g.rDiv) + .mousedown(function (e) {g.dragStart('vresize',e,true);}) + .html('<span></span>') + .css('height',$(g.gDiv).height()) + ; + if ($.browser.msie&&$.browser.version<7.0) + { + $(g.rDiv).hover(function(){$(this).addClass('hgOver');},function(){$(this).removeClass('hgOver');}); + } + $(g.gDiv).append(g.rDiv); + } + + // add pager + if (p.usepager) + { + g.pDiv.className = 'pDiv'; + g.pDiv.innerHTML = '<div class="pDiv2"></div>'; + $(g.bDiv).parent().prepend(g.pDiv); + var html = ' <div class="pGroup"> <div class="pFirst pButton"><span></span></div><div class="pPrev pButton"><span></span></div> </div> <div class="btnseparator"></div> <div class="pGroup"><span class="pcontrol">'+p.pagetext+' <input type="text" size="4" value="1" /> '+p.outof+' <span> 1 </span></span></div> <div class="btnseparator"></div> <div class="pGroup"> <div class="pNext pButton"><span></span></div><div class="pLast pButton"><span></span></div> </div> <div class="btnseparator"></div> <div class="pGroup"> <div class="pReload pButton"><span></span></div> </div> <div class="btnseparator"></div> <div class="pGroup"> <div class="pJSON pButton"><a href="" target="_blank">JSON</a></div> </div> <div class="btnseparator"></div> <div class="pGroup"><span class="pPageStat"></span></div>'; + $('div',g.pDiv).html(html); + + g.domElements = { + pReload: $('.pReload', g.pDiv), + pPageStat: $('.pPageStat', g.pDiv), + pcontrol_input: $('.pcontrol input', g.pDiv), + pcontrol_span: $('.pcontrol span', g.pDiv) + }; + + g.domElements.pReload.click(function(){g.populate()}); + $('.pFirst',g.pDiv).click(function(){g.changePage('first')}); + $('.pPrev',g.pDiv).click(function(){g.changePage('prev')}); + $('.pNext',g.pDiv).click(function(){g.changePage('next')}); + $('.pLast',g.pDiv).click(function(){g.changePage('last')}); + g.domElements.pcontrol_input.keydown(function(e){if(e.keyCode==13) g.changePage('input')}); + if ($.browser.msie&&$.browser.version<7) $('.pButton',g.pDiv).hover(function(){$(this).addClass('pBtnOver');},function(){$(this).removeClass('pBtnOver');}); + + if (p.useRp) + { + var opt = ""; + for (var nx=0;nx<p.rpOptions.length;nx++) + { + var sel = ''; + if (p.rp == p.rpOptions[nx]) sel = 'selected="selected"'; + opt += "<option value='" + p.rpOptions[nx] + "' " + sel + " >" + p.rpOptions[nx] + " </option>"; + }; + $('.pDiv2',g.pDiv).prepend("<div class='pGroup'><select name='rp'>"+opt+"</select></div> <div class='btnseparator'></div>"); + $('select',g.pDiv).change( + function () + { + if (p.onRpChange) + p.onRpChange(+this.value); + else + { + p.newp = 1; + p.rp = +this.value; + g.populate(); + } + } + ); + } + + //add search button + if (p.searchitems) + { +/* $('.pDiv2',g.pDiv).prepend("<div class='pGroup'> <div class='pSearch pButton'><span></span></div> </div> <div class='btnseparator'></div>"); + $('.pSearch',g.pDiv).click(function(){$(g.sDiv).slideToggle('fast',function(){$('.sDiv:visible input:first',g.gDiv).trigger('focus');});}); */ + //add search box + g.sDiv.className = 'sDiv'; + + sitems = p.searchitems; + + var sopt = ""; + for (var s = 0; s < sitems.length; s++) + { + if (p.qtype=='' && sitems[s].isdefault==true) + { + p.qtype = sitems[s].name; + sel = 'selected="selected"'; + } else sel = ''; + sopt += "<option value='" + sitems[s].name + "' " + sel + " >" + sitems[s].display + " </option>"; + } + + if (p.qtype=='') p.qtype = sitems[0].name; + + $(g.sDiv).append("<div class='btnseparator'></div> <div class='sDiv2'>"/*+p.findtext*/+" <input title='" + texts.misc.search_for + ': ' + sitems[0].display + "' type='text' size='20' name='q' class='qsbox' />"); // <select name='qtype'>"+sopt+"</select> <!--input type='button' value='Clear' /--></div>"); + + $('input[name=q],select[name=qtype]',g.sDiv).keydown(function(e){if(e.keyCode==13) g.doSearch()}); + $('input[value=Clear]',g.sDiv).click(function(){$('input[name=q]',g.sDiv).val(''); p.query = ''; g.doSearch(); }); + $(g.pDiv).children().first().append(g.sDiv); + + } + + } + $(g.pDiv,g.sDiv).append("<div style='clear:both'></div>"); + + // add title + if (p.title) + { + g.mDiv.className = 'mDiv'; + g.mDiv.innerHTML = '<div class="ftitle">'+p.title+'</div>'; + $(g.gDiv).prepend(g.mDiv); + if (p.showTableToggleBtn) + { + $(g.mDiv).append('<div class="ptogtitle" title="Minimize/Maximize Table"><span></span></div>'); + $('div.ptogtitle',g.mDiv).click + ( + function () + { + $(g.gDiv).toggleClass('hideBody'); + $(this).toggleClass('vsble'); + } + ); + } + //g.rePosDrag(); + } + + //setup cdrops + g.cdropleft = document.createElement('span'); + g.cdropleft.className = 'cdropleft'; + g.cdropright = document.createElement('span'); + g.cdropright.className = 'cdropright'; + + //add block + g.block.className = 'gBlock'; + var gh = $(g.bDiv).height(), + gtop = g.bDiv.offsetTop; + $(g.block).css( + { + //width: g.bDiv.style.width, + width: jQuery(g.pDiv).find('.pDiv2').width(), + height: gh, + background: 'white', + position: 'relative', + marginBottom: (gh * -1), + zIndex: 1, + top: gtop, + left: '0px' + } + ); + $(g.block).fadeTo(0,p.blockOpacity); + + // add column control + if ($('th',g.hDiv).length) + { + + g.nDiv.className = 'nDiv'; + g.nDiv.innerHTML = "<table cellpadding='0' cellspacing='0'><tbody></tbody></table>"; + $(g.nDiv).css( + { + marginBottom: (gh * -1), + display: 'none', + top: gtop + } + ).noSelect() + ; + + var cn = 0; + + $('th div',g.hDiv).each + ( + function () + { + var kcol = $("th[axis='col" + cn + "']",g.hDiv)[0], + chk = 'checked="checked"'; + if (kcol.style.display=='none') chk = ''; + + $('tbody',g.nDiv).append('<tr><td class="ndcol1"><input type="checkbox" '+ chk +' class="togCol" value="'+ cn +'" /></td><td class="ndcol2">'+this.innerHTML+'</td></tr>'); + cn++; + } + ); + + if ($.browser.msie&&$.browser.version<7.0) + $('tr',g.nDiv).hover + ( + function () {$(this).addClass('ndcolover');}, + function () {$(this).removeClass('ndcolover');} + ); + + $('td.ndcol2',g.nDiv).click + ( + function () + { + if ($('input:checked',g.nDiv).length<=p.minColToggle&&$(this).prev().find('input')[0].checked) return false; + return g.toggleCol($(this).prev().find('input').val()); + } + ); + + $('input.togCol',g.nDiv).click + ( + function () + { + + if ($('input:checked',g.nDiv).length<p.minColToggle&&this.checked==false) return false; + $(this).parent().next().trigger('click'); + //return false; + } + ); + + + $(g.gDiv).prepend(g.nDiv); + + $(g.nBtn).addClass('nBtn') + .html('<div></div>') + .attr('title','Hide/Show Columns') + .click + ( + function () + { + $(g.nDiv).toggle(); return true; + } + ); + + if (p.showToggleBtn) $(g.gDiv).prepend(g.nBtn); + + } + + // add date edit layer + $(g.iDiv) + .addClass('iDiv') + .css({display:'none'}) + ; + $(g.bDiv).append(g.iDiv); + + // add flexigrid events + $(g.bDiv) + .hover(function(){$(g.nDiv).hide();$(g.nBtn).hide();},function(){if (g.multisel) g.multisel = false;}) + ; + $(g.gDiv) + .hover(function(){},function(){$(g.nDiv).hide();$(g.nBtn).hide();}) + ; + + //add document events + $(document) + .mousemove(function(e){g.dragMove(e)}) + .mouseup(function(e){g.dragEnd()}) + .hover(function(){},function (){g.dragEnd()}) + ; + + //browser adjustments + if ($.browser.msie&&$.browser.version<7.0) + { + $('.hDiv,.bDiv,.mDiv,.pDiv,.vGrip,.tDiv, .sDiv',g.gDiv) + .css({width: '100%'}); + $(g.gDiv).addClass('ie6'); + if (p.width!='auto') $(g.gDiv).addClass('ie6fullwidthbug'); + } + + g.rePosDrag(); + g.fixHeight(); + + //make grid functions accessible + t.p = p; + t.grid = g; + + // load data + if (p.url&&p.autoload) + { + g.populate(); + } + + return t; + + }; + + var docloaded = false; + + $(document).ready(function () {docloaded = true} ); + + $.fn.flexigrid = function(p) { + + return this.each( function() { + if (!docloaded) + { + $(this).hide(); + var t = this; + $(document).ready + ( + function () + { + $.addFlex(t,p); + } + ); + } else { + $.addFlex(this,p); + } + }); + + }; //end flexigrid + + $.fn.flexReload = function(p) { // function to reload grid + + return this.each( function() { + if (this.grid&&this.p.url) this.grid.populate(); + }); + + }; //end flexReload + + $.fn.flexOptions = function(p) { //function to update general options + + return this.each( function() { + if (this.grid) $.extend(this.p,p); + }); + + }; //end flexOptions + + $.fn.flexToggleCol = function(cid,visible) { // function to reload grid + + return this.each( function() { + if (this.grid) this.grid.toggleCol(cid,visible); + }); + + }; //end flexToggleCol + + $.fn.flexAddData = function(data) { // function to add data to grid + + return this.each( function() { + if (this.grid) this.grid.addData(data); + }); + + }; + + $.fn.noSelect = function(p) { //no select plugin by me :-) + + if (p == null) + prevent = true; + else + prevent = p; + + if (prevent) { + + return this.each(function () + { + if ($.browser.msie||$.browser.safari) $(this).bind('selectstart',function(){return false;}); + else if ($.browser.mozilla) + { + $(this).css('MozUserSelect','none'); + $('body').trigger('focus'); + } + else if ($.browser.opera) $(this).bind('mousedown',function(){return false;}); + else $(this).attr('unselectable','on'); + }); + + } else { + + + return this.each(function () + { + if ($.browser.msie||$.browser.safari) $(this).unbind('selectstart'); + else if ($.browser.mozilla) $(this).css('MozUserSelect','inherit'); + else if ($.browser.opera) $(this).unbind('mousedown'); + else $(this).removeAttr('unselectable','on'); + }); + + } + + }; //end noSelect + +})(jQuery); |