Commit aa447db2 authored by Alexey.Musinov's avatar Alexey.Musinov Committed by Alexander.Trofimov

[ios] tables

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@64570 954022d7-b5bf-4e40-9824-e11837661b57
parent 7dac9222
......@@ -582,3 +582,71 @@ WorksheetView.prototype._updateCache = function(c1, r1, c2, r2) {
this._prepareCellTextMetricsCache(range);
};
WorksheetView.prototype._changeSelectionTopLeft = function (x, y, isCoord, isSelectMode, isTopLeft) {
//var ar = (this.isFormulaEditMode) ? this.arrActiveFormulaRanges[this.arrActiveFormulaRanges.length - 1] : this.activeRange;
var isMoveActiveCellToLeftTop = false;
var ar = this.activeRange;
var copy = this.activeRange.clone();
var col = ar.startCol;
var row = ar.startRow;
if (isTopLeft) {
this.activeRange.startCol = this.leftTopRange.c2;
this.activeRange.startRow = this.leftTopRange.r2;
} else {
this.activeRange.startCol = this.leftTopRange.c1;
this.activeRange.startRow = this.leftTopRange.r1;
}
var newRange = isCoord ? this._calcSelectionEndPointByXY(x, y) : this._calcSelectionEndPointByOffset(x, y);
var isEqual = newRange.isEqual(ar);
if (!isEqual) {
if (newRange.c1 > col) {
col = newRange.c1;
isMoveActiveCellToLeftTop = true;
}
if (newRange.r1 > row) {
row = newRange.r1;
isMoveActiveCellToLeftTop = true;
}
ar.assign2(newRange);
this.activeRange.startCol = col;
this.activeRange.startRow = row;
if (isMoveActiveCellToLeftTop) {
this.activeRange.startCol = newRange.c1;
this.activeRange.startRow = newRange.r1;
}
//ToDo this.drawDepCells();
if (!this.isCellEditMode) {
if (!this.isSelectionDialogMode) {
this.handlers.trigger("selectionNameChanged", this.getSelectionName(/*bRangeText*/true));
if (!isSelectMode) {
this.handlers.trigger("selectionChanged", this.getSelectionInfo(false));
this.handlers.trigger("selectionMathInfoChanged", this.getSelectionMathInfo());
}
} else {
// Смена диапазона
this.handlers.trigger("selectionRangeChanged", this.getSelectionRangeValue());
}
}
} else {
this.activeRange.startCol = col;
this.activeRange.startRow = row;
}
this.model.workbook.handlers.trigger("asc_onHideComment");
return this._calcActiveRangeOffset(x,y);
};
......@@ -1760,6 +1760,8 @@ function OfflineEditor () {
this.zoom = 1.0;
this.textSelection = 0;
this.selection = [];
this.cellPin = 0;
// main
......@@ -1771,6 +1773,20 @@ function OfflineEditor () {
window.g_file_path = "native_open_file";
window.NATIVE_DOCUMENT_TYPE = window.native.GetEditorType();
_api = new window["Asc"]["spreadsheet_api"]();
var c_DocInfo = {
"Id" : "9876543210",
"Url" : undefined,
"Title" : undefined,
"Format" : undefined,
"VKey" : undefined,
"Origin" : 'localhost',
"UserId" : 'UserId',
"UserName" : 'UserName',
"ChartEditor" : true
};
_api.asc_setDocInfo(c_DocInfo);
_api.asc_nativeOpenFile(window.native["GetFileString"]());
this.registerEventsHandlers();
......@@ -1842,8 +1858,9 @@ function OfflineEditor () {
var worksheet = _api.wb.getWorksheet();
var region = this._updateRegion(worksheet, x, y, width, height);
this.selection = _api.wb.getWorksheet()._getDrawSelection_Local(region.columnBeg, region.rowBeg, region.columnEnd, region.rowEnd);
return _api.wb.getWorksheet()._getDrawSelection_Local(region.columnBeg, region.rowBeg, region.columnEnd, region.rowEnd);
return this.selection;
};
this.getNearCellCoord = function(x, y) {
......@@ -2149,15 +2166,28 @@ function offline_of() {_s.openFile();}
function offline_stz(v) {_s.zoom = v; _api.asc_setZoom(v);}
function offline_ds(x, y, width, height, ratio) {_s.drawSheet(x, y, width, height, ratio);}
function offline_dh(x, y, width, height, type, ratio) {_s.drawHeader(x, y, width, height, type, ratio);}
function offline_mouse_down(x, y) {
_api.wb.getWorksheet().changeSelectionStartPoint(x, y, true, true);
function offline_mouse_down(x, y, pin) {
var ws = _api.wb.getWorksheet();
_s.cellPin = pin;
if (0 != _s.cellPin) {
ws.leftTopRange = ws.activeRange.clone();
return;
}
ws.changeSelectionStartPoint(x, y, true, true);
}
function offline_mouse_move(x, y) {
if (-1 == _s.cellPin)
_api.wb.getWorksheet()._changeSelectionTopLeft(x, y, true, true, true);
else if (1 === _s.cellPin)
_api.wb.getWorksheet()._changeSelectionTopLeft(x, y, true, true, false);
else
_api.wb.getWorksheet().changeSelectionEndPoint(x, y, true, true);
}
function offline_mouse_up(x, y) {
//_api.wb.getWorksheet().changeSelectionDone();
_api.wb._onChangeSelectionDone(-1, -1);
_s.cellPin = 0;
_api.wb.getWorksheet().leftTopRange = undefined;
}
function offline_get_selection(x, y, width, height) {
return _s.getSelection(x, y, width, height);
......
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