|
|
@ -80,7 +80,7 @@ var dynamicTable = new Class ({ |
|
|
|
} |
|
|
|
} |
|
|
|
tr.addEvent('click', function(e){ |
|
|
|
tr.addEvent('click', function(e){ |
|
|
|
if(e.control) { |
|
|
|
if(e.control) { |
|
|
|
found = false; |
|
|
|
// CTRL key was pressed
|
|
|
|
if(this.cur.contains(id)) { |
|
|
|
if(this.cur.contains(id)) { |
|
|
|
// remove it
|
|
|
|
// remove it
|
|
|
|
this.cur.erase(id); |
|
|
|
this.cur.erase(id); |
|
|
@ -98,8 +98,22 @@ var dynamicTable = new Class ({ |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
//TODO: handle alt key
|
|
|
|
if(e.shift && this.cur.length == 1) { |
|
|
|
// Control key is not pressed
|
|
|
|
// Shift key was pressed
|
|
|
|
|
|
|
|
ids = this.getRowIds(); |
|
|
|
|
|
|
|
beginIndex = ids.indexOf(this.cur[0]); |
|
|
|
|
|
|
|
endIndex = ids.indexOf(id); |
|
|
|
|
|
|
|
for(i=beginIndex+1; i<(endIndex+1); i++) { |
|
|
|
|
|
|
|
curID = ids[i]; |
|
|
|
|
|
|
|
this.cur[this.cur.length] = curID; |
|
|
|
|
|
|
|
// Add selected style
|
|
|
|
|
|
|
|
temptr = this.rows[curID]; |
|
|
|
|
|
|
|
if(temptr){ |
|
|
|
|
|
|
|
temptr.addClass(this.options.selectCls); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
// Simple selection
|
|
|
|
// Remove selected style from previous ones
|
|
|
|
// Remove selected style from previous ones
|
|
|
|
for(i=0; i<this.cur.length; i++) { |
|
|
|
for(i=0; i<this.cur.length; i++) { |
|
|
|
var temptr = this.rows[this.cur[i]]; |
|
|
|
var temptr = this.rows[this.cur[i]]; |
|
|
@ -114,6 +128,7 @@ var dynamicTable = new Class ({ |
|
|
|
} |
|
|
|
} |
|
|
|
this.cur[0] = id; |
|
|
|
this.cur[0] = id; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
}.bind(this)); |
|
|
|
}.bind(this)); |
|
|
|
|
|
|
|
|
|
|
|
tr.injectInside(this.table); |
|
|
|
tr.injectInside(this.table); |
|
|
|