/** * $RCSfile: ,v $ * $Revision: $ * $Date: $ * * Copyright (C) 2004-2011 Jive Software. All rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.jivesoftware.sparkplugin; import org.jivesoftware.spark.component.FileDragLabel; import javax.swing.BorderFactory; import javax.swing.Icon; import javax.swing.JLabel; import javax.swing.JPanel; import java.awt.Color; import java.awt.Font; import java.awt.GridBagConstraints; import java.awt.GridBagLayout; import java.awt.Insets; /** * UI for simple chat room notifications with Jingle. */ public class GenericNotification extends JPanel { private static final long serialVersionUID = -90291335105747619L; private FileDragLabel imageLabel = new FileDragLabel(); private JLabel titleLabel = new JLabel(); /** * Creates a generic notification panel. * * @param title the title of the notification. * @param icon the icon to use in the notification. */ public GenericNotification(String title, Icon icon) { setLayout(new GridBagLayout()); setBackground(new Color(250, 249, 242)); add(imageLabel, new GridBagConstraints(0, 0, 1, 3, 0.0, 0.0, GridBagConstraints.NORTHWEST, GridBagConstraints.NONE, new Insets(5, 5, 5, 5), 0, 0)); add(titleLabel, new GridBagConstraints(1, 0, 2, 1, 1.0, 0.0, GridBagConstraints.NORTHWEST, GridBagConstraints.NONE, new Insets(5, 5, 5, 5), 0, 0)); titleLabel.setFont(new Font("Dialog", Font.BOLD, 11)); titleLabel.setForeground(new Color(211, 174, 102)); setBorder(BorderFactory.createMatteBorder(0, 0, 1, 0, Color.white)); titleLabel.setText(title); imageLabel.setIcon(icon); } /** * Sets the title of the notification. * * @param title the title. */ public void setTitle(String title) { titleLabel.setText(title); } /** * Sets the icon. * * @param icon the icon. */ public void setIcon(Icon icon) { imageLabel.setIcon(icon); } /** * Changes the background color. If alert is true, the background will reflect that the ui * needs attention. * * @param alert true to notify users that their attention is needed. */ public void showAlert(boolean alert) { if (alert) { titleLabel.setForeground(new Color(211, 174, 102)); setBackground(new Color(250, 249, 242)); } else { setBackground(new Color(239, 245, 250)); titleLabel.setForeground(new Color(65, 139, 179)); } } }