/*
 * Copyright (c) 2005-2009 Laf-Widget Kirill Grouchnikov. All Rights Reserved.
 *
 * Redistribution and use in source and binary forms, with or without 
 * modification, are permitted provided that the following conditions are met:
 * 
 *  o Redistributions of source code must retain the above copyright notice, 
 *    this list of conditions and the following disclaimer. 
 *     
 *  o Redistributions in binary form must reproduce the above copyright notice, 
 *    this list of conditions and the following disclaimer in the documentation 
 *    and/or other materials provided with the distribution. 
 *     
 *  o Neither the name of Laf-Widget Kirill Grouchnikov nor the names of 
 *    its contributors may be used to endorse or promote products derived 
 *    from this software without specific prior written permission. 
 *     
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, 
 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR 
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; 
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 
 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, 
 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
 */
package org.jvnet.lafwidget.utils;

import org.jvnet.lafwidget.animation.*;


/**
 * Constants for the <b>laf-widget</b> classes.
 * 
 * @author Kirill Grouchnikov
 */
public class LafConstants {

	/**
	 * Animation kind.
	 */
	public static class AnimationKind {
		/**
		 * No animation.
		 */
		public static final AnimationKind NONE = new AnimationKind(
				new FadeConstantStep(1.1f), "none");

		/**
		 * Animation for debug purposes (extremely-slow).
		 */
		public static final AnimationKind DEBUG_SLOW = new AnimationKind(
				new FadeConstantStep(.002f), "debugSlow");

		/**
		 * Animation for debug purposes (ultra-slow).
		 */
		public static final AnimationKind DEBUG = new AnimationKind(
				new FadeConstantStep(.01f), "debug");

		/**
		 * Animation for debug purposes (slow).
		 */
		public static final AnimationKind DEBUG_FAST = new AnimationKind(
				new FadeConstantStep(.05f), "debugFast");

		/**
		 * Slow animation.
		 */
		public static final AnimationKind SLOW = new AnimationKind(
				new FadeConstantStep(.1f), "slow");

		/**
		 * Regular (default) animation.
		 */
		public static final AnimationKind REGULAR = new AnimationKind(
				new FadeConstantStep(.2f), "regular");

		/**
		 * Fast animation.
		 */
		public static final AnimationKind FAST = new AnimationKind(
				new FadeConstantStep(.3f), "fast");

		/**
		 * Animation increment step.
		 */
		private FadeStep step;

		/**
		 * Animation kind name.
		 */
		private String name;

		/**
		 * Creates a new animation kind.
		 * 
		 * @param step
		 *            Animation increment step.
		 * @param name
		 *            Animation kind name.
		 */
		public AnimationKind(FadeStep step, String name) {
			this.step = step;
			this.name = name;
		}

		/**
		 * Returns the step of <code>this</code> animation in seconds.
		 * 
		 * @return Step of <code>this</code> animation in seconds.
		 */
		public FadeStep getStep() {
			return this.step;
		}

		/**
		 * Returns the name of <code>this</code> animation.
		 * 
		 * @return Name of <code>this</code> animation.
		 */
		public String getName() {
			return this.name;
		}

		/**
		 * Creates a derived (accelerated or decelerated) animation kind.
		 * 
		 * @param factor
		 *            Derivation factor. Should be greater than zero.
		 * @return Derived animation kind.
		 */
		public AnimationKind derive(float factor) {
			final FadeStep origStep = this.step;
			final String origName = this.name;
			return new AnimationKind(
					new FadeAccelerationStep(origStep, factor), origName
							+ ".derived." + factor);
		}
	}

	/**
	 * Password strength.
	 * 
	 * @author Kirill Grouchnikov
	 */
	public static class PasswordStrength {
		/**
		 * Private constructor to prevent initialization.
		 */
		private PasswordStrength() {
		}

		/**
		 * Weak strength.
		 */
		public static final PasswordStrength WEAK = new PasswordStrength();

		/**
		 * Medium strength.
		 */
		public static final PasswordStrength MEDIUM = new PasswordStrength();

		/**
		 * Strong strength.
		 */
		public static final PasswordStrength STRONG = new PasswordStrength();
	}

	/**
	 * Enumerates all available kinds of tab overview dialog.
	 * 
	 * @author Kirill Grouchnikov
	 */
	public static class TabOverviewKind {
		/**
		 * Shows a grid with all tab thumbnails.
		 */
		public static final TabOverviewKind GRID = new TabOverviewKind("grid");

		/**
		 * Shows a round carousel with all tab thumbnails.
		 */
		public static final TabOverviewKind ROUND_CAROUSEL = new TabOverviewKind(
				"round carousel");

		/**
		 * Shows a menu carousel with all tab thumbnails.
		 */
		public static final TabOverviewKind MENU_CAROUSEL = new TabOverviewKind(
				"menu carousel");

		/**
		 * Animation kind name.
		 */
		private String name;

		/**
		 * Creates a new tab overview kind.
		 * 
		 * @param name
		 *            Tab overview kind name.
		 */
		public TabOverviewKind(String name) {
			this.name = name;
		}

		/**
		 * Returns the name of <code>this</code> animation.
		 * 
		 * @return Name of <code>this</code> animation.
		 */
		public String getName() {
			return this.name;
		}
	}
}
