e44a7e37b6
git-svn-id: https://semanticscuttle.svn.sourceforge.net/svnroot/semanticscuttle/trunk@151 b3834d28-1941-0410-a4f8-b48e95affb8f
66 lines
2.1 KiB
JavaScript
66 lines
2.1 KiB
JavaScript
if(!dojo._hasResource["dojox.grid._grid.cell"]){ //_hasResource checks added by build. Do not use _hasResource directly in your code.
|
|
dojo._hasResource["dojox.grid._grid.cell"] = true;
|
|
dojo.provide("dojox.grid._grid.cell");
|
|
|
|
dojo.declare("dojox.grid.cell", null, {
|
|
// summary:
|
|
// Respresents a grid cell and contains information about column options and methods
|
|
// for retrieving cell related information.
|
|
// Each column in a grid layout has a cell object and most events and many methods
|
|
// provide access to these objects.
|
|
styles: '',
|
|
constructor: function(inProps){
|
|
dojo.mixin(this, inProps);
|
|
if(this.editor){this.editor = new this.editor(this);}
|
|
},
|
|
// data source
|
|
format: function(inRowIndex){
|
|
// summary:
|
|
// provides the html for a given grid cell.
|
|
// inRowIndex: int
|
|
// grid row index
|
|
// returns: html for a given grid cell
|
|
var f, i=this.grid.edit.info, d=this.get ? this.get(inRowIndex) : this.value;
|
|
if(this.editor && (this.editor.alwaysOn || (i.rowIndex==inRowIndex && i.cell==this))){
|
|
return this.editor.format(d, inRowIndex);
|
|
}else{
|
|
return (f = this.formatter) ? f.call(this, d, inRowIndex) : d;
|
|
}
|
|
},
|
|
// utility
|
|
getNode: function(inRowIndex){
|
|
// summary:
|
|
// gets the dom node for a given grid cell.
|
|
// inRowIndex: int
|
|
// grid row index
|
|
// returns: dom node for a given grid cell
|
|
return this.view.getCellNode(inRowIndex, this.index);
|
|
},
|
|
isFlex: function(){
|
|
var uw = this.unitWidth;
|
|
return uw && (uw=='auto' || uw.slice(-1)=='%');
|
|
},
|
|
// edit support
|
|
applyEdit: function(inValue, inRowIndex){
|
|
this.grid.edit.applyCellEdit(inValue, this, inRowIndex);
|
|
},
|
|
cancelEdit: function(inRowIndex){
|
|
this.grid.doCancelEdit(inRowIndex);
|
|
},
|
|
_onEditBlur: function(inRowIndex){
|
|
if(this.grid.edit.isEditCell(inRowIndex, this.index)){
|
|
//console.log('editor onblur', e);
|
|
this.grid.edit.apply();
|
|
}
|
|
},
|
|
registerOnBlur: function(inNode, inRowIndex){
|
|
if(this.commitOnBlur){
|
|
dojo.connect(inNode, "onblur", function(e){
|
|
// hack: if editor still thinks this editor is current some ms after it blurs, assume we've focused away from grid
|
|
setTimeout(dojo.hitch(this, "_onEditBlur", inRowIndex), 250);
|
|
});
|
|
}
|
|
}
|
|
});
|
|
|
|
}
|