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

[ios] range chart editor


git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@67827 954022d7-b5bf-4e40-9824-e11837661b57
parent 0956f452
......@@ -754,22 +754,22 @@ WorksheetView.prototype.__drawFormulaRanges = function (arrRanges, offsetX, offs
if (addl > 0)
left = this.cols[colsCount - 1].left + this.defaultColWidth * addl - offsetX;
else
left = this.cols[arrRanges[i].c1].left - offsetX;
left = this.cols[Math.max(0,arrRanges[i].c1)].left - offsetX;
if (addt > 0)
top = this.rows[rowsCount - 1].top + addt * gc_dDefaultRowHeightAttribute - offsetY;
else
top = this.rows[arrRanges[i].r1].top - offsetY;
top = this.rows[Math.max(0,arrRanges[i].r1)].top - offsetY;
if (addr > 0)
right = this.cols[colsCount - 1].left + this.defaultColWidth * addr - offsetX;
else
right = this.cols[arrRanges[i].c2].left + this.cols[arrRanges[i].c2].width - offsetX;
right = this.cols[Math.max(0,arrRanges[i].c2)].left + this.cols[Math.max(0,arrRanges[i].c2)].width - offsetX;
if (addb > 0)
bottom = this.rows[rowsCount - 1].top + addb * gc_dDefaultRowHeightAttribute - offsetY;
else
bottom = this.rows[arrRanges[i].r2].top + this.rows[arrRanges[i].r2].height - offsetY;
bottom = this.rows[Math.max(0,arrRanges[i].r2)].top + this.rows[Math.max(0,arrRanges[i].r2)].height - offsetY;
}
// else if (5 === type) { // range image
......
......@@ -4308,7 +4308,8 @@ 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, pin, isViewer, isFormulaEditMode) {
function offline_mouse_down(x, y, pin, isViewerMode, isFormulaEditMode, isRangeResize, chartRange) {
_s.isShapeAction = false;
var ws = _api.wb.getWorksheet();
......@@ -4325,6 +4326,9 @@ function offline_mouse_down(x, y, pin, isViewer, isFormulaEditMode) {
var graphicsInfo = wb._onGetGraphicsInfo(x, y);
if (graphicsInfo) {
var e = {isLocked: true, Button: 0, ClickCount: 1, shiftKey: false, metaKey: false, ctrlKey: false};
ws.arrActiveChartsRanges = [];
wb._onGraphicObjectMouseDown(e, x, y);
wb._onUpdateSelectionShape(true);
......@@ -4344,6 +4348,24 @@ function offline_mouse_down(x, y, pin, isViewer, isFormulaEditMode) {
_s.cellPin = pin;
_s.isFormulaEditMode = isFormulaEditMode;
if (isRangeResize) {
var ct = ws.getCursorTypeFromXY(x, y, isViewerMode);
var rangeChange = new asc.Range(chartRange[0], chartRange[1], chartRange[2], chartRange[3]);
var target = {
formulaRange: rangeChange,
row: ct.row,
target: ct.target,
targetArr: -1,
col: ct.col,
cursor: "se-resize",
indexFormulaRange: 0
};
ws.changeSelectionMoveResizeRangeHandle(x, y, target);
} else {
if (0 != _s.cellPin) {
ws.leftTopRange = ws.activeRange.clone();
} else {
......@@ -4367,12 +4389,13 @@ function offline_mouse_down(x, y, pin, isViewer, isFormulaEditMode) {
}
}
}
}
ws.visibleRange = range;
return null;
}
function offline_mouse_move(x, y, isViewer) {
function offline_mouse_move(x, y, isViewerMode, isRangeResize, chartRange) {
var ws = _api.wb.getWorksheet();
var wb = _api.wb;
......@@ -4381,8 +4404,24 @@ function offline_mouse_move(x, y, isViewer) {
range.r1 = _s.row0;
ws.visibleRange = range;
if (isRangeResize) {
var ct = ws.getCursorTypeFromXY(x, y, isViewerMode);
var rangeChange = new asc.Range(chartRange[0], chartRange[1], chartRange[2], chartRange[3]);
var target = {
formulaRange: rangeChange,
row: ct.row,
target: ct.target,
targetArr: -1,
col: ct.col,
cursor: "se-resize",
indexFormulaRange: 0
};
ws.changeSelectionMoveResizeRangeHandle(x, y, target);
} else {
if (_s.isShapeAction) {
if (!isViewer) {
if (!isViewerMode) {
var e = {isLocked: true, Button: 0, ClickCount: 1, shiftKey: false, metaKey: false, ctrlKey: false};
ws.objectRender.graphicObjectMouseMove(e, x, y);
}
......@@ -4411,12 +4450,14 @@ function offline_mouse_move(x, y, isViewer) {
}
}
}
}
ws.visibleRange = range;
return null;
}
function offline_mouse_up(x, y, isViewer) {
function offline_mouse_up(x, y, isViewerMode, isRangeResize, chartRange) {
var ret = null;
var ws = _api.wb.getWorksheet();
var wb = _api.wb;
......@@ -4430,14 +4471,43 @@ function offline_mouse_up(x, y, isViewer) {
wb._onGraphicObjectMouseUp(e, x, y);
wb._onChangeSelectionDone(x, y);
_s.isShapeAction = false;
ret = {'isShapeAction': true};
} else {
if (isRangeResize) {
var ct = ws.getCursorTypeFromXY(x, y, isViewerMode);
var target = {
target: 5,
targetArr: -1,
cursor: "se-resize",
indexFormulaRange: 0
};
if (ws.moveRangeDrawingObjectTo) {
ws.moveRangeDrawingObjectTo.c1 = Math.max(0, ws.moveRangeDrawingObjectTo.c1);
ws.moveRangeDrawingObjectTo.c2 = Math.max(0, ws.moveRangeDrawingObjectTo.c2);
ws.moveRangeDrawingObjectTo.r1 = Math.max(0, ws.moveRangeDrawingObjectTo.r1);
ws.moveRangeDrawingObjectTo.r2 = Math.max(0, ws.moveRangeDrawingObjectTo.r2);
}
ws.applyMoveResizeRangeHandle(target);
} else {
wb._onChangeSelectionDone(-1, -1);
_s.cellPin = 0;
wb.getWorksheet().leftTopRange = undefined;
}
}
ws.visibleRange = range;
return ret;
}
function offline_get_selection(x, y, width, height, autocorrection) {
return _s.getSelection(x, y, width, height, autocorrection);
}
......@@ -4467,6 +4537,7 @@ function offline_keyboard_down(keys) {
wb._onChangeSelection(true, 0, 1, false, false, undefined);
}
}
function offline_cell_editor_draw(width, height, ratio) {
_null_object.width = width * ratio;
_null_object.height = height * ratio;
......@@ -4598,7 +4669,9 @@ function offline_cell_editor_mouse_event(events) {
cellEditor._onMouseUp(event);
_s.textSelection = 0;
} else if (2 == events[i][0]) {
cellEditor._onMouseMove(event);
} else if (3 == events[i][0]) {
cellEditor.clickCounter.clickCount = 2;
cellEditor._onMouseDown(event);
......@@ -4645,6 +4718,7 @@ function offline_cell_editor_select_range(from, to) {
cellEditor.selectionBegin = from;
cellEditor.selectionEnd = to;
}
function offline_get_cell_in_coord (x, y) {
var worksheet = _api.wb.getWorksheet(),
activeCell = worksheet.getActiveCell(x, y, true);
......
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