javaquery/api/src/main/java/org/apidesign/bck2brwsr/htmlpage/api/OnController.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Tue, 24 Feb 2015 11:12:53 +0100
changeset 1787 ea12a3bb4b33
parent 813 2fa85847ccf7
permissions -rw-r--r--
Using year range 2012-2015 in copyright header
     1 /**
     2  * Back 2 Browser Bytecode Translator
     3  * Copyright (C) 2012-2015 Jaroslav Tulach <jaroslav.tulach@apidesign.org>
     4  *
     5  * This program is free software: you can redistribute it and/or modify
     6  * it under the terms of the GNU General Public License as published by
     7  * the Free Software Foundation, version 2 of the License.
     8  *
     9  * This program is distributed in the hope that it will be useful,
    10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
    11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    12  * GNU General Public License for more details.
    13  *
    14  * You should have received a copy of the GNU General Public License
    15  * along with this program. Look for COPYING file in the top folder.
    16  * If not, see http://opensource.org/licenses/GPL-2.0.
    17  */
    18 package org.apidesign.bck2brwsr.htmlpage.api;
    19 
    20 /** Controller created via {@link OnEvent#of(org.apidesign.bck2brwsr.htmlpage.api.Element[])}.
    21  *
    22  * @author Jaroslav Tulach <jtulach@netbeans.org>
    23  */
    24 public final class OnController {
    25     private final Element[] arr;
    26     private final OnEvent event;
    27     
    28     OnController(OnEvent event, Element[] arr) {
    29         this.event = event;
    30         this.arr = arr;
    31     }
    32     
    33     /** Registers an event handler on associated {@link OnEvent}
    34      * and {@link Element}
    35      * 
    36      * @param handler the handler to be called when the event occurs
    37      */
    38     public void perform(final OnHandler handler) {
    39         for (Element e : arr) {
    40             e.on(event, handler);
    41         }
    42     }
    43     
    44     /** Registers a runnable to be performed on associated {@link OnEvent} 
    45      * and {@link Element}.
    46      * 
    47      * @see OnEvent#of
    48      */
    49     public void perform(final Runnable r) {
    50         class W implements OnHandler {
    51             @Override
    52             public void onEvent(Object event) throws Exception {
    53                 r.run();
    54             }
    55         }
    56         perform(new W());
    57         OnHandler w = new W();
    58         for (Element e : arr) {
    59             e.on(event, w);
    60         }
    61     }
    62 }