Commit b0cab8c6 authored by Dmitry.Shahtanov's avatar Dmitry.Shahtanov Committed by Alexander.Trofimov

поправлен переход по именованным диапазонам через поле адреса.

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@66766 954022d7-b5bf-4e40-9824-e11837661b57
parent 0824f20f
...@@ -692,7 +692,7 @@ cArea.prototype.index = function ( r, c, n ) { ...@@ -692,7 +692,7 @@ cArea.prototype.index = function ( r, c, n ) {
/** @constructor */ /** @constructor */
function cArea3D( val, wsFrom, wsTo, wb ) {/*Area3D means "Sheat1!A1:E5" for example*/ function cArea3D( val, wsFrom, wsTo, wb ) {/*Area3D means "Sheat1!A1:E5" for example*/
this.constructor.call( this, val, cElementType.cellsRange ); this.constructor.call( this, val, cElementType.cellsRange3D );
this._wb = wb; this._wb = wb;
this._cells = val; this._cells = val;
...@@ -1167,7 +1167,7 @@ cRef.prototype.getBBox0 = function () { ...@@ -1167,7 +1167,7 @@ cRef.prototype.getBBox0 = function () {
/** @constructor */ /** @constructor */
function cRef3D( val, _wsFrom, wb ) {/*Ref means Sheat1!A1 for example*/ function cRef3D( val, _wsFrom, wb ) {/*Ref means Sheat1!A1 for example*/
this.constructor.call( this, val, cElementType.cell ); this.constructor.call( this, val, cElementType.cell3D );
this.wb = this._wb = wb; this.wb = this._wb = wb;
this._cells = val; this._cells = val;
this.isAbsolute = false; this.isAbsolute = false;
......
...@@ -10043,64 +10043,75 @@ ...@@ -10043,64 +10043,75 @@
}; };
WorksheetView.prototype.findCell = function (reference) { WorksheetView.prototype.findCell = function (reference) {
var range = asc.g_oRangeCache.getAscRange(reference); var range = asc.g_oRangeCache.getAscRange( reference );
if(!range){ if ( !range ) {
var actRange = this.getActiveRangeObj(), ascRange; var _C2H50H_ = this.model.workbook.getDefinesNames( reference, this.model.workbook.getActiveWs().getId() ), sheetName, ref;
var mc = this.model.getMergedByCell(actRange.startRow, actRange.startCol); if ( !_C2H50H_ ) {
var c1 = mc ? mc.c1 : actRange.c1;
var r1 = mc ? mc.r1 : actRange.r1;
var ar_norm = actRange.normalize(),
mc_norm = mc ? mc.normalize() : null;
var c2 = mc_norm ? ( mc_norm.isEqual(ar_norm) ? mc_norm.c1 : ar_norm.c2 ) : ar_norm.c2; var actRange = this.getActiveRangeObj(), ascRange,
var r2 = mc_norm ? ( mc_norm.isEqual(ar_norm) ? mc_norm.r1 : ar_norm.r2 ) : ar_norm.r2; mc = this.model.getMergedByCell( actRange.startRow, actRange.startCol ),
c1 = mc ? mc.c1 : actRange.c1,
r1 = mc ? mc.r1 : actRange.r1,
ar_norm = actRange.normalize(),
mc_norm = mc ? mc.normalize() : null,
c2 = mc_norm ? ( mc_norm.isEqual( ar_norm ) ? mc_norm.c1 : ar_norm.c2 ) : ar_norm.c2,
r2 = mc_norm ? ( mc_norm.isEqual( ar_norm ) ? mc_norm.r1 : ar_norm.r2 ) : ar_norm.r2,
defName;
ascRange = new asc_Range(c1, r1, c2, r2 ); ascRange = new asc_Range( c1, r1, c2, r2 );
/*TODO: сделать поиск по названиям автофигур, должен искать до того как вызвать поиск по именованным диапазонам*/ /*TODO: сделать поиск по названиям автофигур, должен искать до того как вызвать поиск по именованным диапазонам*/
var defName = new Asc.asc_CDefName( reference, this.model.getName()+"!"+ascRange.getAbsName(), null ), defName = new Asc.asc_CDefName( reference, this.model.getName() + "!" + ascRange.getAbsName() );
_C2H50H_, sheetName = "", ref = "";
_C2H50H_ = this.model.workbook.getDefinesNames( reference, this.model.workbook.getActiveWs().getId() );
if( !_C2H50H_ ){
if ( this.collaborativeEditing.getGlobalLock() || !this.handlers.trigger("getLockDefNameManagerStatus") ){ if ( this.collaborativeEditing.getGlobalLock() || !this.handlers.trigger( "getLockDefNameManagerStatus" ) ) {
this.handlers.trigger("onErrorEvent",c_oAscError.ID.LockCreateDefName,c_oAscError.Level.NoCritical); this.handlers.trigger( "onErrorEvent", c_oAscError.ID.LockCreateDefName, c_oAscError.Level.NoCritical );
this._updateSelectionNameAndInfo(); this._updateSelectionNameAndInfo();
return true; return true;
} }
_C2H50H_ = this.model.workbook.editDefinesNames( null, defName ); _C2H50H_ = this.model.workbook.editDefinesNames( null, defName );
} }
if(_C2H50H_){ if ( _C2H50H_ ) {
range = true; range = true;
this._isLockedDefNames(null, _C2H50H_.nodeId); this._isLockedDefNames( null, _C2H50H_.nodeId );
sheetName = _C2H50H_.Ref.split("!");
if ( _C2H50H_.isTable ) {
sheetName = _C2H50H_.Ref.split( "!" );
ref = sheetName[1]; ref = sheetName[1];
sheetName = sheetName[0]; sheetName = sheetName[0];
if ( sheetName[0] == "'" && sheetName[sheetName.length - 1] == "'" ) {
if(_C2H50H_.isTable || (_C2H50H_.parsedRef.RefPos.length == 1 && _C2H50H_.parsedRef.outStack.length == 1) ){ sheetName = sheetName.substring( 1, range.sheet.length - 1 );
range = asc.g_oRangeCache.getAscRange(ref);
ar_norm = range.normalize();
mc = this.model.getMergedByCell(ar_norm.r1, ar_norm.c1);
range = {range:mc?mc:range, sheet:sheetName};
if( sheetName[0] == "'" && sheetName[sheetName.length-1] == "'" ){
range.sheet = range.sheet.substring(1,range.sheet.length-1);
} }
range = asc.g_oRangeCache.getAscRange( ref );
sheetName = this.model.workbook.getWorksheetByName( sheetName );
} }
if( !_C2H50H_.isTable && _C2H50H_.parsedRef.RefPos.length == 1 && _C2H50H_.parsedRef.outStack.length == 1 ){ else if ( _C2H50H_.parsedRef.RefPos.length == 1 && _C2H50H_.parsedRef.outStack.length == 1 ) {
this.model.workbook.handlers.trigger("asc_onDefName", defName); ref = _C2H50H_.parsedRef.outStack[0];
if ( ref.type == cElementType.cell3D ) {
range = ref.range.getBBox0().clone( true );
sheetName = ref.getWS();
} }
else if ( ref.type == cElementType.cellsRange3D && ref.wsFrom == ref.wsTo ) {
range = ref.getRange()[0].getBBox0().clone( true );
sheetName = this.model.workbook.getWorksheetById( ref.wsFrom );
} }
} }
else{
if ( range && sheetName ) {
ar_norm = range.normalize();
mc = sheetName.getMergedByCell( ar_norm.r1, ar_norm.c1 )
range = {range: mc ? mc : range, sheet: sheetName.getName()};
}
}
}
else {
var ar_norm = range.normalize(), var ar_norm = range.normalize(),
mc = this.model.getMergedByCell(ar_norm.r1, ar_norm.c1); mc = this.model.getMergedByCell( ar_norm.r1, ar_norm.c1 );
range = {range:mc?mc:range, sheet:this.model.getName()}; range = {range: mc ? mc : range, sheet: this.model.getName()};
} }
return range;// ? this.setSelection(range, true) : null; return range;// ? this.setSelection(range, true) : null;
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment