All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.openide.filesystems.FileSystem$HtmlStatus Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you 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.openide.filesystems;

import java.util.Set;

/**
 * Extension interface for Status provides HTML-formatted annotations.
 * Principally this is used to deemphasize status text by presenting it in a
 * lighter color, by placing it inside <font color=!controlShadow> tags.
 * Note that it is preferable to use logical colors (such as controlShadow)
 * which are resolved by calling UIManager.getColor(key) - this way they will
 * always fit with the look and feel. To use a logical color, prefix the color
 * name with a ! character.
 * 

* Please use only the limited markup subset of HTML supported by the * lightweight HTML renderer. *

* This interface was part of FileSystems API. It was superseded by {@link StatusDecorator} * @see * HtmlRenderer * @since FileSystems API, 4.30 */ public interface FileSystem$HtmlStatus extends FileSystem$Status { /** Annotate a name such that the returned value contains HTML markup. * The return value less the HTML content should typically be the same * as the return value from annotateName(). This is used, * for example, by VCS filesystems to deemphasize the status information * included in the file name by using a light grey font color. *

* For consistency with Node.getHtmlDisplayName(), * filesystems that proxy other filesystems (and so must implement * this interface to supply HTML annotations) should return null if * the filesystem they proxy does not provide an implementation of * {@link FileSystem.HtmlStatus}. *

Note that since the {@code name} argument must be free of HTML, * it is tricky to use this decorator on a {@code Node} arising from * foreign code, to chain decorators, or otherwise when you wish to add * decorations to an HTML label whose creation you do not control. * As a workaround, pass in an arbitrary but HTML-free string as an argument * (something unlikely to occur elsewhere) and replace that string in the * result with the original HTML label - under the assumption that the * decorator does not inspect its argument but merely adds some prefix * and/or suffix. * * @param name the name suggested by default. It cannot contain HTML * markup tags but must escape HTML metacharacters. For example * "<default package>" is illegal but "&lt;default package&gt;" * is fine. * @param files an immutable set of {@link FileObject}s belonging to this filesystem * @return the annotated name. It may be the same as the passed-in name. * It may be null if getStatus returned status that doesn't implement * HtmlStatus but plain Status. * * @since 4.30 * @see DataNode.getHtmlDisplayName() * @see Node.getHtmlDisplayName() **/ public String annotateNameHtml(String name, Set files); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy