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

org.netbeans.api.htmlui.HTMLDialog 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.netbeans.api.htmlui;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
import java.util.Locale;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import org.netbeans.html.context.spi.Contexts.Id;
import org.netbeans.modules.htmlui.HTMLDialogBase;

/** Generates method that opens an HTML based modal dialog. Sample of a typical
 * usage follows.
 * 
HTML Page dialog.html
*

* {@snippet file="org/netbeans/api/htmlui/dialog.html" region="org.netbeans.api.htmlui.dialog.html"} * The dialog.html page defines two buttons as hidden - * they are re-rendered by the embedding "chrome" (for example as Swing buttons), * but they can be enabled/disabled. For example the ok property * (defined in the Java model below) connects the state of the checkbox and * the Good button. * *

Java Source AskQuestion.java
* {@snippet file="org/netbeans/api/htmlui/AskQuestion.java" region="ask"} *

* The method is generated into AskPages class (specified in the * {@code className} attribute) * in the same package and has the same name, * and parameters as the method annotated by the {@code HTMLDialog} annotation. *

* When the method {@code AskPages.showHelloWorld(true)} * is invoked, it opens a dialog, loads an HTML page {@code dialog.html} * into it. When the page is * loaded, it calls back the method {@code AskQuestion.showHelloWorld} * and passes it * its own arguments. The method is supposed to make the page live, preferably * by using {@link net.java.html.json.Model} generated class and calling * applyBindings() on it. The method is suggested to return * an instance of {@link OnSubmit} callback to be notified about user pressing * one of the dialog buttons. *

* The HTML page may contain hidden <button> elements. If it does so, * those buttons are copied to the dialog frame and displayed underneath the page. * Their enabled/disabled state reflects the state of the buttons in the page. * When one of the buttons is selected a callback to {@link OnSubmit} instance * is made. If it returns {@code true}, the dialog closes otherwise its closing * is prevented. A {@code null} 'id' signals user closing or cancelling the dialog. *

* By default, if the HTML defines no hidden * <button> elements, two buttons are added. One representing * the OK choice (with id="OK") and one representing * the cancel choice (with null id). Both buttons are always * enabled. One can check the callback 'id' * to be "OK" to know whether the user approved the dialog. * * * @author Jaroslav Tulach */ @Retention(RetentionPolicy.SOURCE) @Target(ElementType.METHOD) public @interface HTMLDialog { /** URL of the page to display. Usually relative to the annotated class. * Will be resolved by the annotation processor and converted into * nbresloc protocol - as such the HTML page can be L10Ned * later by adding classical L10N suffixes. E.g. index_cs.html * will take precedence over index.html if the user is * running in Czech {@link Locale}. * * @return relative path to the HTML page */ String url(); /** List of resources to make available for the {@link #url()} page. * The rendering system shall make sure these resources are available when * the {@link #url() main page} is loaded and are at the same relative * locations like the page. * * @return list of resources * @since 1.25 */ String[] resources() default {}; /** Name of the file to generate the method that opens the dialog * into. Class of such name will be generated into the same * package. * * @return name of class to generate */ String className() default "Pages"; /** Selects some of provided technologies. The HTML/Java API @ version 1.1 * supports {@link Id technology ids}. One can specify the preferred ones * to use in this NetBeans component by using this attribute. * * @return list of preferred technology ids * @since 1.3 */ String[] techIds() default {}; /** Callback to be notified when user closes a dialog. Return an * implementation of this interface from a method annotated by * {@link HTMLDialog} annotation: *

* {@snippet file="org/netbeans/api/htmlui/AskQuestion.java" region="ask"} * * The example returns a lambda function which gets automatically * converted into {@code OnSubmit} instance. * * @since 1.23 */ @FunctionalInterface public interface OnSubmit { /** Callback when a button is pressed. * * @param button the ID of the pressed button or {@code null} on cancel * @return {@code true} to close the dialog, {@code false} to ignore * the button press and leave the dialog open * @since 1.23 */ boolean onSubmit(String button); } /** Rather than using this class directly, consider * {@link HTMLDialog}. The {@link HTMLDialog} annotation * generates boilderplate code for you * and can do some compile times checks helping you to get warnings * as soon as possible. */ public static final class Builder { private final String url; private List resources = new ArrayList<>(); private List techIds = new ArrayList<>(); private Runnable onPageLoad; private Builder(String u) { this.url = u; } /** Starts creation of a new HTML dialog. The page * can contain hidden buttons as described at * {@link HTMLDialog}. * * @param url URL (usually using nbresloc protocol) * of the page to display in the dialog. * @return instance of the builder */ public static Builder newDialog(String url) { return new Builder(url); } /** Registers a runnable to be executed when the page * becomes ready. * * @param run runnable to run * @return this builder */ public Builder loadFinished(Runnable run) { this.onPageLoad = run; return this; } /** Registers resources to be available for the {@link #url()} page. * The rendering system shall make sure these resources are available when * the {@link #url() main page} is loaded and are at the same relative * locations like the page. * * @param res list of resources to add to the builder * @return instance of the builder * @since 1.25 */ public Builder addResources(String... res) { resources.addAll(Arrays.asList(res)); return this; } /** Requests some of provided technologies. The HTML/Java API @ version 1.1 * supports {@link Id technology ids}. One can specify the preferred ones * to use in this NetBeans component by using calling this method. * * @param ids list of preferred technology ids to add to the builder * @return instance of the builder * @since 1.3 */ public Builder addTechIds(String... ids) { techIds.addAll(Arrays.asList(ids)); return this; } /** Displays the dialog and waits. This method blocks waiting for the * dialog to be shown and closed by the user. * * @return 'id' of a selected button element or null * if the dialog was closed without selecting a button */ public String showAndWait() { HTMLDialogBase impl = HTMLDialogBase.create(url, resources.toArray(new String[0]), onPageLoad, null, techIds.toArray(new String[0]), null); return impl.showAndWait(); } /** Displays the dialog and returns immediately. * * @param s callback to call when a button is clicked and dialog * is about to be closed * @since 1.23 */ public void show(OnSubmit s) { HTMLDialogBase impl = HTMLDialogBase.create(url, resources.toArray(new String[0]), onPageLoad, s, techIds.toArray(new String[0]), null); impl.show(s); } /** Obtains the component from the builder. The parameter * can either be {@link javafx.embed.swing.JFXPanel}.class or * {@link javafx.scene.web.WebView}.class. After calling this * method the builder becomes useless. * * @param requested component type * @param type either {@link javafx.embed.swing.JFXPanel} or {@link javafx.scene.web.WebView} class * @return instance of the requested component */ public C component(Class type) { HTMLDialogBase impl = HTMLDialogBase.create(url, resources.toArray(new String[0]), onPageLoad, null, techIds.toArray(new String[0]), type); return impl.component(type); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy