View Javadoc
1   package fr.ifremer.quadrige3.ui.swing.table.renderer;
2   
3   /*-
4    * #%L
5    * Quadrige3 Core :: Quadrige3 UI Common
6    * $Id:$
7    * $HeadURL:$
8    * %%
9    * Copyright (C) 2017 Ifremer
10   * %%
11   * This program is free software: you can redistribute it and/or modify
12   * it under the terms of the GNU Affero General Public License as published by
13   * the Free Software Foundation, either version 3 of the License, or
14   * (at your option) any later version.
15   * 
16   * This program is distributed in the hope that it will be useful,
17   * but WITHOUT ANY WARRANTY; without even the implied warranty of
18   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19   * GNU General Public License for more details.
20   * 
21   * You should have received a copy of the GNU Affero General Public License
22   * along with this program.  If not, see <http://www.gnu.org/licenses/>.
23   * #L%
24   */
25  
26  
27  import org.apache.commons.lang3.StringUtils;
28  
29  import javax.swing.JLabel;
30  import javax.swing.JTable;
31  import javax.swing.table.TableCellRenderer;
32  import java.awt.Component;
33  
34  /**
35   * <p>DateCellRenderer class.</p>
36   *
37   * @author Ludovic Pecquot <ludovic.pecquot@e-is.pro>
38   */
39  public class DateCellRenderer extends jaxx.runtime.swing.renderer.DateCellRenderer {
40  
41      /**
42       * <p>Constructor for DateCellRenderer.</p>
43       *
44       * @param renderer a {@link TableCellRenderer} object.
45       * @param datePattern a {@link String} object.
46       */
47      public DateCellRenderer(TableCellRenderer renderer, String datePattern) {
48          super(renderer, datePattern);
49      }
50  
51      /** {@inheritDoc} */
52      @Override
53      public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) {
54          JLabel label = (JLabel) super.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, column);
55  
56          if (StringUtils.isNotBlank(label.getText())) {
57              label.setToolTipText(label.getText());
58          }
59  
60          return label;
61      }
62  
63  }