Merge pull request #1547 from ONLYOFFICE/feature/bug-55292

Feature/bug 55292
This commit is contained in:
Julia Radzhabova 2022-02-10 00:02:51 +03:00 committed by GitHub
commit 7e59e1bfcc
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 37 additions and 7 deletions

View file

@ -56,6 +56,7 @@ define([
this.editMode = true; this.editMode = true;
this._state = {no_slides: undefined}; this._state = {no_slides: undefined};
this._initSettings = true; this._initSettings = true;
this._priorityArr = [];
this.addListeners({ this.addListeners({
'RightMenu': { 'RightMenu': {
@ -95,8 +96,15 @@ define([
this.editMode = mode.isEdit; this.editMode = mode.isEdit;
}, },
onRightMenuClick: function(menu, type, minimized) { onRightMenuClick: function(menu, type, minimized, event) {
if (!minimized && this.editMode) { if (!minimized && this.editMode) {
if (event) { // user click event
var idx = this._priorityArr.indexOf(type);
if (idx>=0)
this._priorityArr.splice(idx, 1);
this._priorityArr.unshift(type);
}
var panel = this._settings[type].panel; var panel = this._settings[type].panel;
var props = this._settings[type].props; var props = this._settings[type].props;
if (props && panel) if (props && panel)
@ -191,6 +199,16 @@ define([
if (!this.rightmenu.minimizedMode || open) { if (!this.rightmenu.minimizedMode || open) {
var active; var active;
if (priorityactive<0 && this._priorityArr.length>0) {
for (i=0; i<this._priorityArr.length; i++) {
var type = this._priorityArr[i],
pnl = this._settings[type];
if (pnl===undefined || pnl.btn===undefined || pnl.panel===undefined || pnl.hidden) continue;
priorityactive = type;
break;
}
}
if (priorityactive>-1) active = priorityactive; if (priorityactive>-1) active = priorityactive;
else if (currentactive>=0) active = currentactive; else if (currentactive>=0) active = currentactive;
else if (lastactive>=0) active = lastactive; else if (lastactive>=0) active = lastactive;
@ -249,23 +267,35 @@ define([
}, },
onInsertTable: function() { onInsertTable: function() {
this._settings[Common.Utils.documentSettingsType.Table].needShow = true; // this._settings[Common.Utils.documentSettingsType.Table].needShow = true;
var idx = this._priorityArr.indexOf(Common.Utils.documentSettingsType.Table);
if (idx>=0)
this._priorityArr.splice(idx, 1);
this._priorityArr.unshift(Common.Utils.documentSettingsType.Table);
}, },
onInsertImage: function() { onInsertImage: function() {
this._settings[Common.Utils.documentSettingsType.Image].needShow = true; // this._settings[Common.Utils.documentSettingsType.Image].needShow = true;
var idx = this._priorityArr.indexOf(Common.Utils.documentSettingsType.Image);
if (idx>=0)
this._priorityArr.splice(idx, 1);
this._priorityArr.unshift(Common.Utils.documentSettingsType.Image);
}, },
onInsertChart: function() { onInsertChart: function() {
this._settings[Common.Utils.documentSettingsType.Chart].needShow = true; // this._settings[Common.Utils.documentSettingsType.Chart].needShow = true;
var idx = this._priorityArr.indexOf(Common.Utils.documentSettingsType.Chart);
if (idx>=0)
this._priorityArr.splice(idx, 1);
this._priorityArr.unshift(Common.Utils.documentSettingsType.Chart);
}, },
onInsertShape: function() { onInsertShape: function() {
this._settings[Common.Utils.documentSettingsType.Shape].needShow = true; // this._settings[Common.Utils.documentSettingsType.Shape].needShow = true;
}, },
onInsertTextArt: function() { onInsertTextArt: function() {
this._settings[Common.Utils.documentSettingsType.TextArt].needShow = true; // this._settings[Common.Utils.documentSettingsType.TextArt].needShow = true;
}, },
UpdateThemeColors: function() { UpdateThemeColors: function() {

View file

@ -258,7 +258,7 @@ define([
Common.localStorage.setItem("pe-hide-right-settings", 1); Common.localStorage.setItem("pe-hide-right-settings", 1);
} }
this.fireEvent('rightmenuclick', [this, btn.options.asctype, this.minimizedMode]); this.fireEvent('rightmenuclick', [this, btn.options.asctype, this.minimizedMode, e]);
}, },
SetActivePane: function(type, open) { SetActivePane: function(type, open) {