/* @ITMillApache2LicenseForJavaFiles@ */ package com.itmill.toolkit.terminal; import com.itmill.toolkit.service.FileTypeResolver; /** * ThemeResource is a named theme dependant resource provided and * managed by a theme. The actual resource contents are dynamically resolved to * comply with the used theme by the terminal adapter. This is commonly used to * provide static images, flash, java-applets, etc for the terminals. * * @author IT Mill Ltd. * @version * @VERSION@ * @since 3.0 */ public class ThemeResource implements Resource { /** * Id of the terminal managed resource. */ private String resourceID = null; /** * Creates a resource. * * @param resourceId * the Id of the resource. */ public ThemeResource(String resourceId) { if (resourceId == null) { throw new NullPointerException("Resource ID must not be null"); } if (resourceId.length() == 0) { throw new IllegalArgumentException("Resource ID can not be empty"); } if (resourceId.charAt(0) == '/') { throw new IllegalArgumentException( "Resource ID must be relative (can not begin with /)"); } resourceID = resourceId; } /** * Tests if the given object equals this Resource. * * @param obj * the object to be tested for equality. * @return true if the given object equals this Icon, * false if not. * @see java.lang.Object#equals(Object) */ public boolean equals(Object obj) { return obj instanceof ThemeResource && resourceID.equals(((ThemeResource) obj).resourceID); } /** * @see java.lang.Object#hashCode() */ public int hashCode() { return resourceID.hashCode(); } /** * @see java.lang.Object#toString() */ public String toString() { return resourceID.toString(); } /** * Gets the resource id. * * @return the resource id. */ public String getResourceId() { return resourceID; } /** * @see com.itmill.toolkit.terminal.Resource#getMIMEType() */ public String getMIMEType() { return FileTypeResolver.getMIMEType(getResourceId()); } }