Commit 18d3f456 authored by Alexander.Trofimov's avatar Alexander.Trofimov Committed by Alexander.Trofimov

В asc_CEventsController scrollVertical и scrollHorizontal объединил в один scroll.

Теперь handlers не для каждого WorksheetView, а для всех одни.

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@57630 954022d7-b5bf-4e40-9824-e11837661b57
parent 50aea9d5
...@@ -253,6 +253,16 @@ ...@@ -253,6 +253,16 @@
return this; return this;
}; };
/**
* @param delta {Object}
*/
asc_CEventsController.prototype.scroll = function (delta) {
if (delta) {
if (delta.deltaX) {this.scrollHorizontal(delta.deltaX);}
if (delta.deltaY) {this.scrollVertical(delta.deltaY);}
}
};
/** /**
* @param delta {Number} * @param delta {Number}
* @param [event] {MouseEvent} * @param [event] {MouseEvent}
...@@ -403,8 +413,7 @@ ...@@ -403,8 +413,7 @@
this.handlers.trigger("changeSelection", /*isStartPoint*/false, coord.x, coord.y, this.handlers.trigger("changeSelection", /*isStartPoint*/false, coord.x, coord.y,
/*isCoord*/true, /*isSelectMode*/isSelectMode, /*isCoord*/true, /*isSelectMode*/isSelectMode,
function (d) { function (d) {
if (d.deltaX) {t.scrollHorizontal(d.deltaX);} t.scroll(d);
if (d.deltaY) {t.scrollVertical(d.deltaY);}
if (t.isFormulaEditMode) if (t.isFormulaEditMode)
t.handlers.trigger("enterCellRange"); t.handlers.trigger("enterCellRange");
...@@ -516,8 +525,7 @@ ...@@ -516,8 +525,7 @@
this.handlers.trigger("changeFillHandle", coord.x, coord.y, this.handlers.trigger("changeFillHandle", coord.x, coord.y,
function (d) { function (d) {
if (!d) return; if (!d) return;
if (d.deltaX) {t.scrollHorizontal(d.deltaX);} t.scroll(d);
if (d.deltaY) {t.scrollVertical(d.deltaY);}
asc_applyFunction(callback); asc_applyFunction(callback);
}); });
}; };
...@@ -562,8 +570,7 @@ ...@@ -562,8 +570,7 @@
this.handlers.trigger("moveRangeHandle", coord.x, coord.y, this.handlers.trigger("moveRangeHandle", coord.x, coord.y,
function (d) { function (d) {
if (!d) return; if (!d) return;
if (d.deltaX) {t.scrollHorizontal(d.deltaX);} t.scroll(d);
if (d.deltaY) {t.scrollVertical(d.deltaY);}
asc_applyFunction(callback); asc_applyFunction(callback);
}, event.metaKey || event.ctrlKey); }, event.metaKey || event.ctrlKey);
}; };
...@@ -601,8 +608,7 @@ ...@@ -601,8 +608,7 @@
this.handlers.trigger("moveResizeRangeHandle", coord.x, coord.y, target, this.handlers.trigger("moveResizeRangeHandle", coord.x, coord.y, target,
function (d) { function (d) {
if (!d) return; if (!d) return;
if (d.deltaX) {t.scrollHorizontal(d.deltaX);} t.scroll(d);
if (d.deltaY) {t.scrollVertical(d.deltaY);}
asc_applyFunction(callback); asc_applyFunction(callback);
}); });
}; };
...@@ -942,11 +948,7 @@ ...@@ -942,11 +948,7 @@
// Проверка на движение в выделенной области // Проверка на движение в выделенной области
if (selectionActivePointChanged) { if (selectionActivePointChanged) {
t.handlers.trigger("selectionActivePointChanged", dc, dr, t.handlers.trigger("selectionActivePointChanged", dc, dr, function (d) {t.scroll(d);});
function (d) {
if (d.deltaX) {t.scrollHorizontal(d.deltaX);}
if (d.deltaY) {t.scrollVertical(d.deltaY);}
});
} else { } else {
if (this.isCellEditMode && !this.isFormulaEditMode) { if (this.isCellEditMode && !this.isFormulaEditMode) {
if (!t.handlers.trigger("stopCellEditing")) {return true;} if (!t.handlers.trigger("stopCellEditing")) {return true;}
...@@ -962,8 +964,7 @@ ...@@ -962,8 +964,7 @@
t.handlers.trigger("changeSelection", /*isStartPoint*/!shiftKey, dc, dr, t.handlers.trigger("changeSelection", /*isStartPoint*/!shiftKey, dc, dr,
/*isCoord*/false, /*isSelectMode*/false, /*isCoord*/false, /*isSelectMode*/false,
function (d) { function (d) {
if (d.deltaX) {t.scrollHorizontal(d.deltaX);} t.scroll(d);
if (d.deltaY) {t.scrollVertical(d.deltaY);}
if (t.isFormulaEditMode) { if (t.isFormulaEditMode) {
t.handlers.trigger("enterCellRange"); t.handlers.trigger("enterCellRange");
...@@ -1291,8 +1292,7 @@ ...@@ -1291,8 +1292,7 @@
t.handlers.trigger("changeSelection", /*isStartPoint*/true, coord.x, coord.y, t.handlers.trigger("changeSelection", /*isStartPoint*/true, coord.x, coord.y,
/*isCoord*/true, /*isSelectMode*/true, /*isCoord*/true, /*isSelectMode*/true,
function (d) { function (d) {
if (d.deltaX) {t.scrollHorizontal(d.deltaX);} t.scroll(d);
if (d.deltaY) {t.scrollVertical(d.deltaY);}
if (t.isFormulaEditMode) { if (t.isFormulaEditMode) {
t.handlers.trigger("enterCellRange"); t.handlers.trigger("enterCellRange");
......
...@@ -76,6 +76,7 @@ ...@@ -76,6 +76,7 @@
this.model = model; this.model = model;
this.controller = controller; this.controller = controller;
this.handlers = handlers; this.handlers = handlers;
this.wsViewHandlers = null;
this.element = elem; this.element = elem;
this.input = inputElem; this.input = inputElem;
this.settings = $.extend(true, {}, this.defaults, settings); this.settings = $.extend(true, {}, this.defaults, settings);
...@@ -347,6 +348,24 @@ ...@@ -347,6 +348,24 @@
}); });
} }
this.wsViewHandlers = new asc.asc_CHandlersList(/*handlers*/{
"getViewerMode" : function () { return self.controller.getViewerMode ? self.controller.getViewerMode() : true; },
"reinitializeScroll" : function () {self.controller.reinitializeScroll(/*All*/);},
"reinitializeScrollY" : function () {self.controller.reinitializeScroll(/*vertical*/1);},
"reinitializeScrollX" : function () {self.controller.reinitializeScroll(/*horizontal*/2);},
"selectionChanged" : function () {self._onWSSelectionChanged.apply(self, arguments);},
"selectionNameChanged" : function () {self._onSelectionNameChanged.apply(self, arguments);},
"selectionMathInfoChanged" : function () {self._onSelectionMathInfoChanged.apply(self, arguments);},
"onErrorEvent" : function (errorId, level) {self.handlers.trigger("asc_onError", errorId, level);},
"slowOperation" : function (isStart) {self.handlers.trigger((isStart ? "asc_onStartAction" : "asc_onEndAction"), c_oAscAsyncActionType.BlockInteraction, c_oAscAsyncAction.SlowOperation);},
"setAutoFiltersDialog" : function (arrVal) {self.handlers.trigger("asc_onSetAFDialog", arrVal);},
"selectionRangeChanged" : function (val) {self.handlers.trigger("asc_onSelectionRangeChanged", val);},
"onRenameCellTextEnd" : function (countFind, countReplace) {self.handlers.trigger("asc_onRenameCellTextEnd", countFind, countReplace);},
"onStopFormatPainter" : function () {self.handlers.trigger("asc_onStopFormatPainter");},
"onDocumentPlaceChanged" : function () {self._onDocumentPlaceChanged();},
"updateSheetViewSettings" : function () {self.handlers.trigger("asc_onUpdateSheetViewSettings");}
});
this.model.handlers.add("cleanCellCache", function (wsId, range, canChangeColWidth, bLockDraw) { this.model.handlers.add("cleanCellCache", function (wsId, range, canChangeColWidth, bLockDraw) {
var ws = self.getWorksheetById(wsId); var ws = self.getWorksheetById(wsId);
if (ws) if (ws)
...@@ -484,24 +503,8 @@ ...@@ -484,24 +503,8 @@
}; };
WorkbookView.prototype._createWorksheetView = function (wsModel) { WorkbookView.prototype._createWorksheetView = function (wsModel) {
var self = this, opt = $.extend(true, {}, this.settings.worksheetDefaults); var opt = $.extend(true, {}, this.settings.worksheetDefaults);
return new asc_WSV(wsModel, /*handlers*/{ return new asc_WSV(wsModel, this.wsViewHandlers, this.buffers, this.stringRender, this.maxDigitWidth, this.collaborativeEditing, opt);
"getViewerMode" : function () { return self.controller.getViewerMode ? self.controller.getViewerMode() : true; },
"reinitializeScroll" : function () {self.controller.reinitializeScroll(/*All*/);},
"reinitializeScrollY" : function () {self.controller.reinitializeScroll(/*vertical*/1);},
"reinitializeScrollX" : function () {self.controller.reinitializeScroll(/*horizontal*/2);},
"selectionChanged" : function () {self._onWSSelectionChanged.apply(self, arguments);},
"selectionNameChanged" : function () {self._onSelectionNameChanged.apply(self, arguments);},
"selectionMathInfoChanged" : function () {self._onSelectionMathInfoChanged.apply(self, arguments);},
"onErrorEvent" : function (errorId, level) {self.handlers.trigger("asc_onError", errorId, level);},
"slowOperation" : function (isStart) {self.handlers.trigger((isStart ? "asc_onStartAction" : "asc_onEndAction"), c_oAscAsyncActionType.BlockInteraction, c_oAscAsyncAction.SlowOperation);},
"setAutoFiltersDialog" : function (arrVal) {self.handlers.trigger("asc_onSetAFDialog", arrVal);},
"selectionRangeChanged" : function (val) {self.handlers.trigger("asc_onSelectionRangeChanged", val);},
"onRenameCellTextEnd" : function (countFind, countReplace) {self.handlers.trigger("asc_onRenameCellTextEnd", countFind, countReplace);},
"onStopFormatPainter" : function () {self.handlers.trigger("asc_onStopFormatPainter");},
"onDocumentPlaceChanged" : function () {self._onDocumentPlaceChanged();},
"updateSheetViewSettings" : function () {self.handlers.trigger("asc_onUpdateSheetViewSettings");}
}, this.buffers, this.stringRender, this.maxDigitWidth, this.collaborativeEditing, opt);
}; };
WorkbookView.prototype._onSelectionNameChanged = function (name) { WorkbookView.prototype._onSelectionNameChanged = function (name) {
...@@ -577,10 +580,7 @@ ...@@ -577,10 +580,7 @@
var ws = this.getWorksheet(); var ws = this.getWorksheet();
ws._checkSelectionShape(); ws._checkSelectionShape();
var d = ws.setSelectionUndoRedo(range, validRange); var d = ws.setSelectionUndoRedo(range, validRange);
if (d) { this.controller.scroll(d);
if (d.deltaX) {this.controller.scrollHorizontal(d.deltaX);}
if (d.deltaY) {this.controller.scrollVertical(d.deltaY);}
}
}; };
WorkbookView.prototype._onGetSelection = function () { WorkbookView.prototype._onGetSelection = function () {
...@@ -602,10 +602,7 @@ ...@@ -602,10 +602,7 @@
ws.objectRender.controller.setSelectionState(state); ws.objectRender.controller.setSelectionState(state);
ws.setSelectionShape(true); ws.setSelectionShape(true);
var d = ws._calcActiveCellOffset(ws.objectRender.getSelectedDrawingsRange()); var d = ws._calcActiveCellOffset(ws.objectRender.getSelectedDrawingsRange());
if (d) { this.controller.scroll(d);
if (d.deltaX) {this.controller.scrollHorizontal(d.deltaX);}
if (d.deltaY) {this.controller.scrollVertical(d.deltaY);}
}
ws.objectRender.showDrawingObjectsEx(true); ws.objectRender.showDrawingObjectsEx(true);
ws.objectRender.controller.updateOverlay(); ws.objectRender.controller.updateOverlay();
ws.objectRender.controller.updateSelectionState(); ws.objectRender.controller.updateSelectionState();
......
...@@ -331,7 +331,7 @@ ...@@ -331,7 +331,7 @@
* Widget for displaying and editing Worksheet object * Widget for displaying and editing Worksheet object
* ----------------------------------------------------------------------------- * -----------------------------------------------------------------------------
* @param {Woorksheet} model Worksheet * @param {Woorksheet} model Worksheet
* @param {Object} handlers Event handlers * @param {asc_CHandlersList} handlers Event handlers
* @param {Object} buffers DrawingContext + Overlay * @param {Object} buffers DrawingContext + Overlay
* @param {StringRender} stringRender StringRender * @param {StringRender} stringRender StringRender
* @param {Number} maxDigitWidth Максимальный размер цифры * @param {Number} maxDigitWidth Максимальный размер цифры
...@@ -342,10 +342,6 @@ ...@@ -342,10 +342,6 @@
* @memberOf Asc * @memberOf Asc
*/ */
function WorksheetView(model, handlers, buffers, stringRender, maxDigitWidth, collaborativeEditing, settings) { function WorksheetView(model, handlers, buffers, stringRender, maxDigitWidth, collaborativeEditing, settings) {
if ( !(this instanceof WorksheetView) ) {
return new WorksheetView(model, handlers, buffers, stringRender, maxDigitWidth, collaborativeEditing, settings);
}
this.defaults = new WorksheetViewSettings(); this.defaults = new WorksheetViewSettings();
this.settings = $.extend(true, {}, this.defaults, settings); this.settings = $.extend(true, {}, this.defaults, settings);
...@@ -355,8 +351,7 @@ ...@@ -355,8 +351,7 @@
this.vspRatio = 1.275; this.vspRatio = 1.275;
this.handlers = new asc.asc_CHandlersList(handlers); this.handlers = handlers;
this.model = model; this.model = model;
this.buffers = buffers; this.buffers = buffers;
......
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