Merge pull request #1034 from ONLYOFFICE/feature/sse-foreign-cursor

Feature/sse foreign cursor
This commit is contained in:
Julia Radzhabova 2021-07-30 17:54:18 +03:00 committed by GitHub
commit be3714bf98
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -104,7 +104,10 @@ define([
}, },
filter: {ttHeight: 40}, filter: {ttHeight: 40},
func_arg: {}, func_arg: {},
input_msg: {} input_msg: {},
foreignSelect: {
ttHeight: 20
}
}; };
me.mouse = {}; me.mouse = {};
me.popupmenu = false; me.popupmenu = false;
@ -114,6 +117,8 @@ define([
me._currentParaObjDisabled = false; me._currentParaObjDisabled = false;
me._isDisabled = false; me._isDisabled = false;
me._state = {}; me._state = {};
me.fastcoauthtips = [];
me._TtHeight = 20;
/** coauthoring begin **/ /** coauthoring begin **/
this.wrapEvents = { this.wrapEvents = {
apiHideComment: _.bind(this.onApiHideComment, this) apiHideComment: _.bind(this.onApiHideComment, this)
@ -160,10 +165,12 @@ define([
}, },
'modal:show': function(e){ 'modal:show': function(e){
me.hideCoAuthTips(); me.hideCoAuthTips();
me.hideForeignSelectTips();
}, },
'layout:changed': function(e){ 'layout:changed': function(e){
me.hideHyperlinkTip(); me.hideHyperlinkTip();
me.hideCoAuthTips(); me.hideCoAuthTips();
me.hideForeignSelectTips();
me.onDocumentResize(); me.onDocumentResize();
}, },
'cells:range': function(status){ 'cells:range': function(status){
@ -332,6 +339,9 @@ define([
this.api.asc_registerCallback('asc_onTableTotalMenu', _.bind(this.onTableTotalMenu, this)); this.api.asc_registerCallback('asc_onTableTotalMenu', _.bind(this.onTableTotalMenu, this));
this.api.asc_registerCallback('asc_onShowPivotGroupDialog', _.bind(this.onShowPivotGroupDialog, this)); this.api.asc_registerCallback('asc_onShowPivotGroupDialog', _.bind(this.onShowPivotGroupDialog, this));
} }
this.api.asc_registerCallback('asc_onShowForeignCursorLabel', _.bind(this.onShowForeignCursorLabel, this));
this.api.asc_registerCallback('asc_onHideForeignCursorLabel', _.bind(this.onHideForeignCursorLabel, this));
return this; return this;
}, },
@ -1017,6 +1027,15 @@ define([
} }
}, },
hideForeignSelectTips: function() {
if (this.tooltips.foreignSelect.ref) {
$(this.tooltips.foreignSelect.ref).remove();
this.tooltips.foreignSelect.ref = undefined;
this.tooltips.foreignSelect.x_point = undefined;
this.tooltips.foreignSelect.y_point = undefined;
}
},
hideHyperlinkTip: function() { hideHyperlinkTip: function() {
if (!this.tooltips.hyperlink.isHidden && this.tooltips.hyperlink.ref) { if (!this.tooltips.hyperlink.isHidden && this.tooltips.hyperlink.ref) {
this.tooltips.hyperlink.ref.hide(); this.tooltips.hyperlink.ref.hide();
@ -1035,7 +1054,8 @@ define([
index_locked, index_locked,
index_column, index_row, index_column, index_row,
index_filter, index_filter,
index_slicer; index_slicer,
index_foreign;
for (var i = dataarray.length; i > 0; i--) { for (var i = dataarray.length; i > 0; i--) {
switch (dataarray[i-1].asc_getType()) { switch (dataarray[i-1].asc_getType()) {
case Asc.c_oAscMouseMoveType.Hyperlink: case Asc.c_oAscMouseMoveType.Hyperlink:
@ -1061,6 +1081,9 @@ define([
case Asc.c_oAscMouseMoveType.Tooltip: case Asc.c_oAscMouseMoveType.Tooltip:
index_slicer = i; index_slicer = i;
break; break;
case Asc.c_oAscMouseMoveType.ForeignSelect:
index_foreign = i;
break;
} }
} }
@ -1074,6 +1097,7 @@ define([
row_columnTip = me.tooltips.row_column, row_columnTip = me.tooltips.row_column,
filterTip = me.tooltips.filter, filterTip = me.tooltips.filter,
slicerTip = me.tooltips.slicer, slicerTip = me.tooltips.slicer,
foreignSelect = me.tooltips.foreignSelect,
pos = [ pos = [
me.documentHolder.cmpEl.offset().left - $(window).scrollLeft(), me.documentHolder.cmpEl.offset().left - $(window).scrollLeft(),
me.documentHolder.cmpEl.offset().top - $(window).scrollTop() me.documentHolder.cmpEl.offset().top - $(window).scrollTop()
@ -1111,6 +1135,9 @@ define([
if (!index_locked) { if (!index_locked) {
me.hideCoAuthTips(); me.hideCoAuthTips();
} }
if (!index_foreign) {
me.hideForeignSelectTips();
}
if (index_slicer===undefined) { if (index_slicer===undefined) {
if (!slicerTip.isHidden && slicerTip.ref) { if (!slicerTip.isHidden && slicerTip.ref) {
slicerTip.ref.hide(); slicerTip.ref.hide();
@ -1129,17 +1156,6 @@ define([
} }
} }
// show tooltips // show tooltips
/** coauthoring begin **/
var getUserName = function(id){
var usersStore = SSE.getCollection('Common.Collections.Users');
if (usersStore){
var rec = usersStore.findUser(id);
if (rec)
return AscCommon.UserInfoParser.getParsedName(rec.get('username'));
}
return me.guestText;
};
/** coauthoring end **/
if (index_hyperlink) { if (index_hyperlink) {
if (!hyperlinkTip.parentEl) { if (!hyperlinkTip.parentEl) {
@ -1305,8 +1321,8 @@ define([
if (showPoint[1] >= coAuthTip.XY[1] && if (showPoint[1] >= coAuthTip.XY[1] &&
showPoint[1] + coAuthTip.ttHeight < coAuthTip.XY[1] + coAuthTip.apiHeight) { showPoint[1] + coAuthTip.ttHeight < coAuthTip.XY[1] + coAuthTip.apiHeight) {
src.text(getUserName(data.asc_getUserId())); src.text(me.getUserName(data.asc_getUserId()));
if (coAuthTip.bodyWidth - showPoint[0] < coAuthTip.ref.width() ) { if (coAuthTip.bodyWidth - showPoint[0] < coAuthTip.ref.outerWidth() ) {
src.css({ src.css({
visibility : 'visible', visibility : 'visible',
left : '0px', left : '0px',
@ -1321,6 +1337,45 @@ define([
} }
} }
} }
if (index_foreign) {
data = dataarray[index_foreign-1];
if (!coAuthTip.XY)
me.onDocumentResize();
if (foreignSelect.x_point != data.asc_getX() || foreignSelect.y_point != data.asc_getY()) {
me.hideForeignSelectTips();
foreignSelect.x_point = data.asc_getX();
foreignSelect.y_point = data.asc_getY();
var src = $(document.createElement("div")),
color = data.asc_getColor();
foreignSelect.ref = src;
src.addClass('username-tip');
src.css({
height : foreignSelect.ttHeight + 'px',
position : 'absolute',
zIndex : '900',
visibility : 'visible',
'background-color': '#'+Common.Utils.ThemeColor.getHexColor(color.get_r(), color.get_g(), color.get_b())
});
$(document.body).append(src);
showPoint = [
foreignSelect.x_point + coAuthTip.XY[0],
foreignSelect.y_point + coAuthTip.XY[1] - foreignSelect.ttHeight
];
src.text(me.getUserName(data.asc_getUserId()));
src.css({
visibility : 'visible',
left : ((showPoint[0]+foreignSelect.ref.outerWidth()>coAuthTip.bodyWidth-coAuthTip.rightMenuWidth) ? coAuthTip.bodyWidth-coAuthTip.rightMenuWidth-foreignSelect.ref.outerWidth() : showPoint[0]) + 'px',
top : showPoint[1] + 'px'
});
}
}
} }
if (index_filter!==undefined && !(me.dlgFilter && me.dlgFilter.isVisible()) && !(me.currentMenu && me.currentMenu.isVisible()) && !dataarray[index_filter-1].asc_getFilter().asc_getPivotObj()) { if (index_filter!==undefined && !(me.dlgFilter && me.dlgFilter.isVisible()) && !(me.currentMenu && me.currentMenu.isVisible()) && !dataarray[index_filter-1].asc_getFilter().asc_getPivotObj()) {
@ -3620,7 +3675,64 @@ define([
win.setActiveCategory(2); win.setActiveCategory(2);
} }
}, },
onShowForeignCursorLabel: function(UserId, X, Y, color) {
/** coauthoring begin **/
var src;
var me = this;
for (var i=0; i<me.fastcoauthtips.length; i++) {
if (me.fastcoauthtips[i].attr('userid') == UserId) {
src = me.fastcoauthtips[i];
break;
}
}
var coAuthTip = this.tooltips.coauth;
if (X<0 || X+coAuthTip.XY[0]>coAuthTip.bodyWidth-coAuthTip.rightMenuWidth || Y<0 || Y>coAuthTip.apiHeight) {
src && this.onHideForeignCursorLabel(UserId);
return;
}
if (!src) {
src = $(document.createElement("div"));
src.addClass('username-tip');
src.attr('userid', UserId);
src.css({height: me._TtHeight + 'px', position: 'absolute', zIndex: '900', display: 'none', 'pointer-events': 'none',
'background-color': '#'+Common.Utils.ThemeColor.getHexColor(color.get_r(), color.get_g(), color.get_b())});
src.text(me.getUserName(UserId));
$('#editor_sdk').append(src);
me.fastcoauthtips.push(src);
src.fadeIn(150);
}
src.css({
left : ((X+coAuthTip.XY[0]+src.outerWidth()>coAuthTip.bodyWidth-coAuthTip.rightMenuWidth) ? coAuthTip.bodyWidth-coAuthTip.rightMenuWidth-src.outerWidth()-coAuthTip.XY[0] : X) + 'px',
top : (Y-me._TtHeight) + 'px'
});
/** coauthoring end **/
},
onHideForeignCursorLabel: function(UserId) {
var me = this;
for (var i=0; i<me.fastcoauthtips.length; i++) {
if (me.fastcoauthtips[i].attr('userid') == UserId) {
var src = me.fastcoauthtips[i];
me.fastcoauthtips[i].fadeOut(150, function(){src.remove()});
me.fastcoauthtips.splice(i, 1);
break;
}
}
},
getUserName: function(id){
var usersStore = SSE.getCollection('Common.Collections.Users');
if (usersStore){
var rec = usersStore.findUser(id);
if (rec)
return AscCommon.UserInfoParser.getParsedName(rec.get('username'));
}
return this.guestText;
},
SetDisabled: function(state, canProtect) { SetDisabled: function(state, canProtect) {
this._isDisabled = state; this._isDisabled = state;
this._canProtect = canProtect; this._canProtect = canProtect;