mirror of
https://gitflic.ru/project/openide/openide.git
synced 2026-02-04 15:06:56 +07:00
Enable next/prev editor tab navigation in LightEdit mode [IDEA-260302]
GitOrigin-RevId: 1d53db9ee83f4968b219b73d1a4a5be74c1bd1e8
This commit is contained in:
committed by
intellij-monorepo-bot
parent
b8452aeac7
commit
8c31def6da
@@ -1,6 +1,7 @@
|
||||
// Copyright 2000-2020 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license that can be found in the LICENSE file.
|
||||
package com.intellij.ide.lightEdit;
|
||||
|
||||
import com.intellij.openapi.actionSystem.AnAction;
|
||||
import com.intellij.openapi.application.ApplicationManager;
|
||||
import com.intellij.openapi.fileEditor.FileEditor;
|
||||
import com.intellij.openapi.project.Project;
|
||||
@@ -61,4 +62,7 @@ public interface LightEditService {
|
||||
*/
|
||||
void saveNewDocuments();
|
||||
|
||||
boolean isTabNavigationAvailable(@NotNull AnAction navigationAction);
|
||||
|
||||
void navigateToTab(@NotNull AnAction navigationAction);
|
||||
}
|
||||
|
||||
@@ -3,6 +3,6 @@ package com.intellij.ide.actions;
|
||||
|
||||
import com.intellij.ide.lightEdit.LightEditCompatible;
|
||||
|
||||
final class NextTabAction extends TabNavigationActionBase implements LightEditCompatible {
|
||||
public final class NextTabAction extends TabNavigationActionBase implements LightEditCompatible {
|
||||
public NextTabAction () { super (NavigationType.NEXT); }
|
||||
}
|
||||
|
||||
@@ -1,6 +1,8 @@
|
||||
// Copyright 2000-2020 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license that can be found in the LICENSE file.
|
||||
package com.intellij.ide.actions;
|
||||
|
||||
import com.intellij.ide.lightEdit.LightEdit;
|
||||
import com.intellij.ide.lightEdit.LightEditService;
|
||||
import com.intellij.idea.ActionsBundle;
|
||||
import com.intellij.openapi.actionSystem.*;
|
||||
import com.intellij.openapi.diagnostic.Logger;
|
||||
@@ -36,6 +38,11 @@ abstract class TabNavigationActionBase extends AnAction implements DumbAware {
|
||||
return;
|
||||
}
|
||||
|
||||
if (LightEdit.owns(project)) {
|
||||
LightEditService.getInstance().navigateToTab(this);
|
||||
return;
|
||||
}
|
||||
|
||||
ToolWindowManager windowManager = ToolWindowManager.getInstance(project);
|
||||
|
||||
if (windowManager.isEditorComponentActive()) {
|
||||
@@ -51,6 +58,12 @@ abstract class TabNavigationActionBase extends AnAction implements DumbAware {
|
||||
Presentation presentation = event.getPresentation();
|
||||
DataContext dataContext = event.getDataContext();
|
||||
Project project = CommonDataKeys.PROJECT.getData(dataContext);
|
||||
|
||||
if (LightEdit.owns(project)) {
|
||||
presentation.setEnabled(LightEditService.getInstance().isTabNavigationAvailable(this));
|
||||
return;
|
||||
}
|
||||
|
||||
presentation.setEnabled(false);
|
||||
if (project == null || project.isDisposed()) {
|
||||
return;
|
||||
|
||||
@@ -2,9 +2,12 @@
|
||||
package com.intellij.ide.lightEdit;
|
||||
|
||||
import com.intellij.ide.AppLifecycleListener;
|
||||
import com.intellij.ide.actions.NextTabAction;
|
||||
import com.intellij.ide.actions.PreviousTabAction;
|
||||
import com.intellij.ide.lightEdit.project.LightEditProjectManager;
|
||||
import com.intellij.openapi.Disposable;
|
||||
import com.intellij.openapi.actionSystem.ActionManager;
|
||||
import com.intellij.openapi.actionSystem.AnAction;
|
||||
import com.intellij.openapi.application.ApplicationBundle;
|
||||
import com.intellij.openapi.application.ApplicationInfo;
|
||||
import com.intellij.openapi.application.ApplicationManager;
|
||||
@@ -513,4 +516,14 @@ public final class LightEditServiceImpl implements LightEditService,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isTabNavigationAvailable(@NotNull AnAction navigationAction) {
|
||||
return getEditPanel().getTabs().isTabNavigationAvailable(navigationAction);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void navigateToTab(@NotNull AnAction navigationAction) {
|
||||
getEditPanel().getTabs().navigateToTab(navigationAction);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -4,13 +4,12 @@ package com.intellij.ide.lightEdit;
|
||||
import com.intellij.icons.AllIcons;
|
||||
import com.intellij.ide.IdeBundle;
|
||||
import com.intellij.ide.actions.CloseAction;
|
||||
import com.intellij.ide.actions.NextTabAction;
|
||||
import com.intellij.ide.actions.PreviousTabAction;
|
||||
import com.intellij.ide.lightEdit.project.LightEditFileEditorManagerImpl;
|
||||
import com.intellij.ide.ui.UISettings;
|
||||
import com.intellij.openapi.Disposable;
|
||||
import com.intellij.openapi.actionSystem.ActionPlaces;
|
||||
import com.intellij.openapi.actionSystem.AnActionEvent;
|
||||
import com.intellij.openapi.actionSystem.CommonDataKeys;
|
||||
import com.intellij.openapi.actionSystem.DefaultActionGroup;
|
||||
import com.intellij.openapi.actionSystem.*;
|
||||
import com.intellij.openapi.application.ApplicationBundle;
|
||||
import com.intellij.openapi.application.ApplicationManager;
|
||||
import com.intellij.openapi.editor.Document;
|
||||
@@ -18,6 +17,7 @@ import com.intellij.openapi.editor.Editor;
|
||||
import com.intellij.openapi.editor.colors.EditorColorsListener;
|
||||
import com.intellij.openapi.editor.colors.EditorColorsManager;
|
||||
import com.intellij.openapi.editor.colors.EditorColorsScheme;
|
||||
import com.intellij.openapi.editor.impl.EditorComponentImpl;
|
||||
import com.intellij.openapi.editor.markup.TextAttributes;
|
||||
import com.intellij.openapi.fileEditor.FileDocumentManager;
|
||||
import com.intellij.openapi.fileEditor.FileEditor;
|
||||
@@ -41,6 +41,7 @@ import org.jetbrains.annotations.NotNull;
|
||||
import org.jetbrains.annotations.Nullable;
|
||||
|
||||
import javax.swing.*;
|
||||
import java.awt.*;
|
||||
import java.awt.event.InputEvent;
|
||||
import java.util.Collection;
|
||||
import java.util.Collections;
|
||||
@@ -400,4 +401,42 @@ final class LightEditTabs extends JBEditorTabs implements LightEditorListener, C
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
boolean isTabNavigationAvailable(@NotNull AnAction navigationAction) {
|
||||
if (getTabCount() > 1) {
|
||||
Component focusOwner = FocusManager.getCurrentManager().getFocusOwner();
|
||||
if (focusOwner instanceof EditorComponentImpl) {
|
||||
int currIndex = getIndexOf(getSelectedInfo());
|
||||
if (currIndex >= 0) {
|
||||
if (navigationAction instanceof PreviousTabAction) {
|
||||
return currIndex > 0;
|
||||
}
|
||||
else if (navigationAction instanceof NextTabAction) {
|
||||
return currIndex < getTabCount() - 1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
void navigateToTab(@NotNull AnAction navigationAction) {
|
||||
int currIndex = getIndexOf(getSelectedInfo());
|
||||
if (currIndex >= 0) {
|
||||
if (navigationAction instanceof PreviousTabAction) {
|
||||
if (currIndex > 0) {
|
||||
currIndex --;
|
||||
TabInfo newInfo = getTabAt(currIndex);
|
||||
select(newInfo, true);
|
||||
}
|
||||
}
|
||||
else if (navigationAction instanceof NextTabAction) {
|
||||
if (currIndex < getTabCount() - 1) {
|
||||
currIndex ++;
|
||||
TabInfo newInfo = getTabAt(currIndex);
|
||||
select(newInfo, true);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user