Skip to content

Commit

Permalink
fixes #609 - extract tableHeader and use it later to reenable sort ar…
Browse files Browse the repository at this point in the history
…rows
  • Loading branch information
matthiasgeiger committed Mar 2, 2016
1 parent a824074 commit 26a1e41
Show file tree
Hide file tree
Showing 4 changed files with 58 additions and 33 deletions.
3 changes: 2 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,8 @@ to [sourceforge feature requests](https://sourceforge.net/p/jabref/features/) by
- Fixed [#824](https://github.com/JabRef/jabref/issues/824): MimeTypeDetector can now also handle local file links
- Fixed [#803](https://github.com/JabRef/jabref/issues/803): Fixed dynamically group, free-form search
- Fixed [#743](https://github.com/JabRef/jabref/issues/743): Logger not configured when JAR is started
- Fixed [#822](https://github.com/JabRef/jabref/issues/822):OSX - Exception when adding the icon to the dock
- Fixed [#822](https://github.com/JabRef/jabref/issues/822): OSX - Exception when adding the icon to the dock
- Fixed [#609](https://github.com/JabRef/jabref/issues/609): Sort Arrows are shown in the main table if table is sorted
- Fixed [#685](https://github.com/JabRef/jabref/issues/685): Fixed MySQL exporting for more than one entry
- Fixed [#815](https://github.com/JabRef/jabref/issues/815): Curly Braces no longer ignored in OpenOffice/LibreOffice citation
- Fixed [#855](https://github.com/JabRef/jabref/issues/856): Fixed OpenOffice Manual connect - Clicking on browse does now work correctly
Expand Down
4 changes: 3 additions & 1 deletion src/main/java/net/sf/jabref/gui/maintable/MainTable.java
Original file line number Diff line number Diff line change
Expand Up @@ -177,6 +177,9 @@ public MainTable(MainTableFormat tableFormat, EventList<BibEntry> list, JabRefFr

this.tableColumnListener = new PersistenceTableColumnListener(this);

// set table header render AFTER creation of comparatorChooser (this enables sort arrow rendering)
this.getTableHeader().setDefaultRenderer(new MainTableHeaderRenderer(this.getTableHeader().getDefaultRenderer()));

// TODO: Figure out, whether this call is needed.
getSelected();

Expand All @@ -189,7 +192,6 @@ public MainTable(MainTableFormat tableFormat, EventList<BibEntry> list, JabRefFr
setupComparatorChooser();
refreshSorting();
setWidths();

}

public void refreshSorting() {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
/* Copyright (C) 2016 JabRef contributors.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
package net.sf.jabref.gui.maintable;

import javax.swing.*;
import javax.swing.table.TableCellRenderer;
import java.awt.*;

public class MainTableHeaderRenderer implements TableCellRenderer {

private final TableCellRenderer delegate;

public MainTableHeaderRenderer(TableCellRenderer delegate) {
this.delegate = delegate;
}

@Override
public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected,
boolean hasFocus, int row, int column) {
// delegate to previously used TableCellRenderer which styles the component
Component resultFromDelegate = delegate.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, column);

// Changing style is only possible if both value and resultFromDelegate are JLabels
if ((value instanceof JLabel) && (resultFromDelegate instanceof JLabel)) {
String text = ((JLabel) value).getText();
Icon icon = ((JLabel) value).getIcon();
if (icon == null) {
((JLabel) resultFromDelegate).setText(text);
} else {
((JLabel) resultFromDelegate).setIcon(icon);
((JLabel) resultFromDelegate).setText(null);
}
}

return resultFromDelegate;
}
}
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/* Copyright (C) 2003-2015 JabRef contributors.
/* Copyright (C) 2003-2016 JabRef contributors.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
Expand All @@ -17,9 +17,7 @@

import javax.swing.*;
import javax.swing.table.JTableHeader;
import javax.swing.table.TableCellRenderer;
import javax.swing.table.TableColumn;
import java.awt.*;
import java.awt.event.MouseEvent;
import java.util.Collections;
import java.util.Enumeration;
Expand All @@ -36,25 +34,21 @@
* @author Fabian Bieker
* @since 12/2008
*/
class PreventDraggingJTableHeader extends JTableHeader implements TableCellRenderer {
class PreventDraggingJTableHeader extends JTableHeader {

private final MainTableFormat tableFormat;

private final TableCellRenderer delegate;

public PreventDraggingJTableHeader(JTable table, MainTableFormat tableFormat) {
super(table.getColumnModel());
this.setTable(table);
this.tableFormat = tableFormat;
this.delegate = table.getTableHeader().getDefaultRenderer();
setupTableHeaderIcons();
}

private void setupTableHeaderIcons() {

Enumeration<TableColumn> columns = columnModel.getColumns();
for (TableColumn column : Collections.list(columns)) {
column.setHeaderRenderer(this);
MainTableColumn mainTableColumn = tableFormat.getTableColumn(column.getModelIndex());
column.setHeaderValue(mainTableColumn.getHeaderLabel());
}
Expand All @@ -76,7 +70,7 @@ public String getToolTipText(MouseEvent event) {
public void setDraggedColumn(TableColumn column) {

if ((column != null) && (column.getModelIndex() == 0)) {
return;
return;
}
super.setDraggedColumn(column);
}
Expand All @@ -94,28 +88,6 @@ public TableColumn getDraggedColumn() {
return column;
}

@Override
public Component getTableCellRendererComponent(JTable table, Object value,
boolean isSelected, boolean hasFocus, int row, int column) {

// delegate to previously used TableCellRenderer which styles the component
Component resultFromDelegate = delegate.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, column);

// Changing style is only possible if both value and resultFromDelegate are JLabels
if ((value instanceof JLabel) && (resultFromDelegate instanceof JLabel)) {
String text = ((JLabel) value).getText();
Icon icon = ((JLabel) value).getIcon();
if (icon == null) {
((JLabel) resultFromDelegate).setText(text);
} else {
((JLabel) resultFromDelegate).setIcon(icon);
((JLabel) resultFromDelegate).setText(null);
}
}

return resultFromDelegate;
}

/**
* Transform model index <code>modelIndex</code> to a view based index and
* prevent dragging before model index <code>toIndex</code> (inclusive).
Expand Down

0 comments on commit 26a1e41

Please sign in to comment.