mirror of
https://gitflic.ru/project/openide/openide.git
synced 2026-03-22 23:31:05 +07:00
Java: rework "Unused Overriding Methods" dialog (IDEA-350217)
- fixes preview - adds double-click to (de)select - text improved - more space for the method names GitOrigin-RevId: f898d142fe0d407cd2ff205f67c8368a95f63823
This commit is contained in:
committed by
intellij-monorepo-bot
parent
d85933d67d
commit
c73ad72726
@@ -1,4 +1,4 @@
|
||||
// Copyright 2000-2024 JetBrains s.r.o. and contributors. Use of this source code is governed by the Apache 2.0 license.
|
||||
// Copyright 2000-2025 JetBrains s.r.o. and contributors. Use of this source code is governed by the Apache 2.0 license.
|
||||
package com.intellij.refactoring.safeDelete;
|
||||
|
||||
import com.intellij.java.refactoring.JavaRefactoringBundle;
|
||||
@@ -16,13 +16,16 @@ import com.intellij.psi.util.PsiFormatUtilBase;
|
||||
import com.intellij.refactoring.HelpID;
|
||||
import com.intellij.refactoring.safeDelete.usageInfo.SafeDeleteOverridingMethodUsageInfo;
|
||||
import com.intellij.ui.BooleanTableCellRenderer;
|
||||
import com.intellij.ui.DoubleClickListener;
|
||||
import com.intellij.ui.ScrollPaneFactory;
|
||||
import com.intellij.ui.TableUtil;
|
||||
import com.intellij.ui.table.JBTable;
|
||||
import com.intellij.usageView.UsageInfo;
|
||||
import com.intellij.usages.UsageViewPresentation;
|
||||
import com.intellij.usages.impl.UsagePreviewPanel;
|
||||
import com.intellij.util.ui.UIUtil;
|
||||
import org.jetbrains.annotations.NonNls;
|
||||
import org.jetbrains.annotations.NotNull;
|
||||
|
||||
import javax.swing.*;
|
||||
import javax.swing.event.ListSelectionEvent;
|
||||
@@ -33,6 +36,7 @@ import javax.swing.table.TableColumnModel;
|
||||
import java.awt.*;
|
||||
import java.awt.event.ActionEvent;
|
||||
import java.awt.event.KeyEvent;
|
||||
import java.awt.event.MouseEvent;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.Collections;
|
||||
@@ -46,7 +50,7 @@ class OverridingMethodsDialog extends DialogWrapper {
|
||||
|
||||
private static final int CHECK_COLUMN = 0;
|
||||
private JBTable myTable;
|
||||
private final UsagePreviewPanel myUsagePreviewPanel;
|
||||
private final UsagePreviewPanel myUsagePreviewPanel;
|
||||
|
||||
OverridingMethodsDialog(Project project, List<? extends UsageInfo> overridingMethods) {
|
||||
super(project, true);
|
||||
@@ -58,11 +62,12 @@ class OverridingMethodsDialog extends DialogWrapper {
|
||||
myMethodText = new String[myOverridingMethods.size()];
|
||||
for (int i = 0; i < myMethodText.length; i++) {
|
||||
PsiElement overridingMethod = ((SafeDeleteOverridingMethodUsageInfo)myOverridingMethods.get(i)).getOverridingMethod();
|
||||
if (overridingMethod instanceof PsiMethod) {
|
||||
myMethodText[i] = PsiFormatUtil.formatMethod((PsiMethod)overridingMethod,
|
||||
PsiSubstitutor.EMPTY,
|
||||
PsiFormatUtilBase.SHOW_CONTAINING_CLASS | PsiFormatUtilBase.SHOW_NAME | PsiFormatUtilBase.SHOW_PARAMETERS | PsiFormatUtilBase.SHOW_TYPE,
|
||||
PsiFormatUtilBase.SHOW_TYPE);
|
||||
if (overridingMethod instanceof PsiMethod method) {
|
||||
int options = PsiFormatUtilBase.SHOW_CONTAINING_CLASS |
|
||||
PsiFormatUtilBase.SHOW_NAME |
|
||||
PsiFormatUtilBase.SHOW_PARAMETERS |
|
||||
PsiFormatUtilBase.SHOW_TYPE;
|
||||
myMethodText[i] = PsiFormatUtil.formatMethod(method, PsiSubstitutor.EMPTY, options, PsiFormatUtilBase.SHOW_TYPE);
|
||||
}
|
||||
else {
|
||||
myMethodText[i] = SymbolPresentationUtil.getSymbolPresentableText(overridingMethod);
|
||||
@@ -81,7 +86,7 @@ class OverridingMethodsDialog extends DialogWrapper {
|
||||
public ArrayList<UsageInfo> getSelected() {
|
||||
ArrayList<UsageInfo> result = new ArrayList<>();
|
||||
for (int i = 0; i < myChecked.length; i++) {
|
||||
if(myChecked[i]) {
|
||||
if (myChecked[i]) {
|
||||
result.add(myOverridingMethods.get(i));
|
||||
}
|
||||
}
|
||||
@@ -93,15 +98,6 @@ class OverridingMethodsDialog extends DialogWrapper {
|
||||
return HelpID.SAFE_DELETE_OVERRIDING;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected JComponent createNorthPanel() {
|
||||
JPanel panel = new JPanel();
|
||||
panel.setLayout(new BoxLayout(panel, BoxLayout.Y_AXIS));
|
||||
panel.add(new JLabel(JavaRefactoringBundle.message("there.are.unused.methods.that.override.methods.you.delete")));
|
||||
panel.add(new JLabel(JavaRefactoringBundle.message("choose.the.ones.you.want.to.be.deleted")));
|
||||
return panel;
|
||||
}
|
||||
|
||||
@Override
|
||||
public JComponent getPreferredFocusedComponent() {
|
||||
return myTable;
|
||||
@@ -115,15 +111,15 @@ class OverridingMethodsDialog extends DialogWrapper {
|
||||
|
||||
@Override
|
||||
protected JComponent createCenterPanel() {
|
||||
JPanel panel = new JPanel(new BorderLayout());
|
||||
panel.setBorder(BorderFactory.createEmptyBorder(8, 0, 4, 0));
|
||||
JPanel panel = new JPanel(new BorderLayout(0, UIUtil.DEFAULT_VGAP));
|
||||
panel.add(new JLabel(JavaRefactoringBundle.message("there.are.unused.methods.that.override.methods.you.delete")), BorderLayout.NORTH);
|
||||
final MyTableModel tableModel = new MyTableModel();
|
||||
myTable = new JBTable(tableModel);
|
||||
myTable.setShowGrid(false);
|
||||
|
||||
TableColumnModel columnModel = myTable.getColumnModel();
|
||||
TableColumn checkboxColumn = columnModel.getColumn(CHECK_COLUMN);
|
||||
TableUtil.setupCheckboxColumn(checkboxColumn);
|
||||
TableUtil.setupCheckboxColumn(checkboxColumn, columnModel.getColumnMargin());
|
||||
checkboxColumn.setCellRenderer(new BooleanTableCellRenderer());
|
||||
|
||||
// make SPACE check/uncheck selected rows
|
||||
@@ -136,40 +132,32 @@ class OverridingMethodsDialog extends DialogWrapper {
|
||||
if (myTable.isEditing()) return;
|
||||
int[] rows = myTable.getSelectedRows();
|
||||
if (rows.length > 0) {
|
||||
boolean valueToBeSet = false;
|
||||
for (int row : rows) {
|
||||
if (!myChecked[row]) {
|
||||
valueToBeSet = true;
|
||||
break;
|
||||
}
|
||||
myChecked[row] = !myChecked[row];
|
||||
}
|
||||
for (int row : rows) {
|
||||
myChecked[row] = valueToBeSet;
|
||||
}
|
||||
|
||||
tableModel.updateData();
|
||||
myTable.repaint();
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
|
||||
/*Border titledBorder = IdeBorderFactory.createBoldTitledBorder("Select methods");
|
||||
Border emptyBorder = BorderFactory.createEmptyBorder(0, 5, 5, 5);
|
||||
Border border = BorderFactory.createCompoundBorder(titledBorder, emptyBorder);
|
||||
panel.setBorder(border);*/
|
||||
panel.setLayout(new BorderLayout());
|
||||
new DoubleClickListener() {
|
||||
@Override
|
||||
protected boolean onDoubleClick(@NotNull MouseEvent event) {
|
||||
int row = myTable.getSelectedRow();
|
||||
if (row < 0 || row >= myOverridingMethods.size()) return false;
|
||||
myChecked[row] = !myChecked[row];
|
||||
myTable.repaint();
|
||||
return true;
|
||||
}
|
||||
}.installOn(myTable);
|
||||
|
||||
JScrollPane scrollPane = ScrollPaneFactory.createScrollPane(myTable);
|
||||
|
||||
panel.add(scrollPane, BorderLayout.CENTER);
|
||||
ListSelectionListener selectionListener = new ListSelectionListener() {
|
||||
@Override
|
||||
public void valueChanged(final ListSelectionEvent e) {
|
||||
int index = myTable.getSelectionModel().getLeadSelectionIndex();
|
||||
if (index != -1) {
|
||||
UsageInfo usageInfo = myOverridingMethods.get(index);
|
||||
myUsagePreviewPanel.updateLayout(usageInfo.getProject(), Collections.singletonList(usageInfo));
|
||||
myUsagePreviewPanel.updateLayout(myProject, Collections.singletonList(usageInfo));
|
||||
}
|
||||
else {
|
||||
myUsagePreviewPanel.updateLayout(myProject, null);
|
||||
@@ -178,22 +166,21 @@ class OverridingMethodsDialog extends DialogWrapper {
|
||||
};
|
||||
myTable.getSelectionModel().addListSelectionListener(selectionListener);
|
||||
|
||||
final Splitter splitter = new Splitter(true, 0.3f);
|
||||
splitter.setFirstComponent(panel);
|
||||
final Splitter splitter = new Splitter(true, 0.4f);
|
||||
splitter.setFirstComponent(scrollPane);
|
||||
splitter.setSecondComponent(myUsagePreviewPanel);
|
||||
myUsagePreviewPanel.updateLayout(myProject,null);
|
||||
|
||||
Disposer.register(myDisposable, new Disposable(){
|
||||
@Override
|
||||
public void dispose() {
|
||||
splitter.dispose();
|
||||
}
|
||||
});
|
||||
panel.add(splitter, BorderLayout.CENTER);
|
||||
|
||||
if (tableModel.getRowCount() != 0) {
|
||||
myTable.getSelectionModel().addSelectionInterval(0,0);
|
||||
SwingUtilities.invokeLater(() -> myTable.setRowSelectionInterval(0, 0));
|
||||
}
|
||||
return splitter;
|
||||
return panel;
|
||||
}
|
||||
|
||||
class MyTableModel extends AbstractTableModel {
|
||||
@@ -208,14 +195,10 @@ class OverridingMethodsDialog extends DialogWrapper {
|
||||
}
|
||||
|
||||
@Override
|
||||
public Class getColumnClass(int columnIndex) {
|
||||
if (columnIndex == CHECK_COLUMN) {
|
||||
return Boolean.class;
|
||||
}
|
||||
return String.class;
|
||||
public Class<?> getColumnClass(int columnIndex) {
|
||||
return columnIndex == CHECK_COLUMN ? Boolean.class : String.class;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public int getColumnCount() {
|
||||
return 2;
|
||||
@@ -223,17 +206,12 @@ class OverridingMethodsDialog extends DialogWrapper {
|
||||
|
||||
@Override
|
||||
public Object getValueAt(int rowIndex, int columnIndex) {
|
||||
if(columnIndex == CHECK_COLUMN) {
|
||||
return Boolean.valueOf(myChecked[rowIndex]);
|
||||
}
|
||||
else {
|
||||
return myMethodText[rowIndex];
|
||||
}
|
||||
return columnIndex == CHECK_COLUMN ? Boolean.valueOf(myChecked[rowIndex]) : myMethodText[rowIndex];
|
||||
}
|
||||
|
||||
@Override
|
||||
public void setValueAt(Object aValue, int rowIndex, int columnIndex) {
|
||||
if(columnIndex == CHECK_COLUMN) {
|
||||
if (columnIndex == CHECK_COLUMN) {
|
||||
myChecked[rowIndex] = ((Boolean) aValue).booleanValue();
|
||||
}
|
||||
}
|
||||
@@ -242,9 +220,5 @@ class OverridingMethodsDialog extends DialogWrapper {
|
||||
public boolean isCellEditable(int rowIndex, int columnIndex) {
|
||||
return columnIndex == CHECK_COLUMN;
|
||||
}
|
||||
|
||||
void updateData() {
|
||||
fireTableDataChanged();
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user