whitespace fixups
[jSite2.git] / src / net / pterodactylus / jsite / i18n / gui / I18nLabel.java
index 06f6b6e..10dbfac 100644 (file)
@@ -28,19 +28,31 @@ import net.pterodactylus.jsite.i18n.I18nable;
 
 /**
  * Label that can update itself from {@link I18n}.
- * 
+ *
  * @author David ‘Bombe’ Roden <bombe@freenetproject.org>
- * @version $Id$
  */
 public class I18nLabel extends JLabel implements I18nable {
 
        /** The I18n basename of the label. */
        private final String i18nBasename;
 
+       /** Optional arguments for i18n replacement. */
+       private final Object[] arguments;
+
+       /**
+        * Creates a new label with the given I18n basename.
+        *
+        * @param i18nBasename
+        *            The I18n basename of the label
+        */
+       public I18nLabel(String i18nBasename) {
+               this(i18nBasename, (Component) null);
+       }
+
        /**
         * Creates a new label with the given I18n basename that optionally is a
         * label for the given component.
-        * 
+        *
         * @param i18nBasename
         *            The I18n basename of the label
         * @param component
@@ -49,20 +61,55 @@ public class I18nLabel extends JLabel implements I18nable {
         *            component
         */
        public I18nLabel(String i18nBasename, Component component) {
+               this(i18nBasename, component, (Object[]) null);
+       }
+
+       /**
+        * Creates a new label with the given I18n basename that optionally is a
+        * label for the given component.
+        *
+        * @param i18nBasename
+        *            The I18n basename of the label
+        * @param arguments
+        *            Optional arguments that are handed in to
+        *            {@link I18n#get(String, Object...)}
+        */
+       public I18nLabel(String i18nBasename, Object... arguments) {
+               this(i18nBasename, null, arguments);
+       }
+
+       /**
+        * Creates a new label with the given I18n basename that optionally is a
+        * label for the given component.
+        *
+        * @param i18nBasename
+        *            The I18n basename of the label
+        * @param component
+        *            The component that is activated by the label, or
+        *            <code>null</code> if this label should not activate a
+        *            component
+        * @param arguments
+        *            Optional arguments that are handed in to
+        *            {@link I18n#get(String, Object...)}
+        */
+       public I18nLabel(String i18nBasename, Component component, Object... arguments) {
                super();
                this.i18nBasename = i18nBasename;
-               updateI18n();
+               this.arguments = arguments;
                if (component != null) {
                        setLabelFor(component);
                }
+               updateI18n();
        }
 
        /**
         * {@inheritDoc}
         */
        public void updateI18n() {
-               setText(I18n.get(i18nBasename + ".name"));
-               setDisplayedMnemonic(I18n.getKey(i18nBasename + ".mnemonic"));
+               setText(I18n.get(i18nBasename + ".name", arguments));
+               if (getLabelFor() != null) {
+                       setDisplayedMnemonic(I18n.getKey(i18nBasename + ".mnemonic"));
+               }
        }
 
 }