javaquery/api/src/main/java/org/apidesign/bck2brwsr/htmlpage/api/Element.java
author Jaroslav Tulach <jaroslav.tulach@apidesign.org>
Tue, 05 Mar 2013 19:00:36 +0100
changeset 813 2fa85847ccf7
parent 592 5e13b1ac2886
child 845 859804c78010
child 866 9b4751828ceb
permissions -rw-r--r--
Support for event parameters for methods annotated by @On(event). Basic idea by me, tests provided by Toni. Thanks a lot.
jaroslav@26
     1
/**
jaroslav@106
     2
 * Back 2 Browser Bytecode Translator
jaroslav@106
     3
 * Copyright (C) 2012 Jaroslav Tulach <jaroslav.tulach@apidesign.org>
jaroslav@26
     4
 *
jaroslav@26
     5
 * This program is free software: you can redistribute it and/or modify
jaroslav@26
     6
 * it under the terms of the GNU General Public License as published by
jaroslav@26
     7
 * the Free Software Foundation, version 2 of the License.
jaroslav@26
     8
 *
jaroslav@26
     9
 * This program is distributed in the hope that it will be useful,
jaroslav@26
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
jaroslav@26
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
jaroslav@26
    12
 * GNU General Public License for more details.
jaroslav@26
    13
 *
jaroslav@26
    14
 * You should have received a copy of the GNU General Public License
jaroslav@26
    15
 * along with this program. Look for COPYING file in the top folder.
jaroslav@26
    16
 * If not, see http://opensource.org/licenses/GPL-2.0.
jaroslav@26
    17
 */
jaroslav@26
    18
package org.apidesign.bck2brwsr.htmlpage.api;
jaroslav@26
    19
jaroslav@100
    20
import org.apidesign.bck2brwsr.core.JavaScriptBody;
jaroslav@100
    21
jaroslav@26
    22
/** Represents a generic HTML element.
jaroslav@26
    23
 *
jaroslav@26
    24
 * @author Jaroslav Tulach <jtulach@netbeans.org>
jaroslav@26
    25
 */
jaroslav@26
    26
public abstract class Element {
jaroslav@26
    27
    private final String id;
jaroslav@26
    28
    
jaroslav@26
    29
    public Element(String id) {
jaroslav@26
    30
        this.id = id;
jaroslav@26
    31
    }
jaroslav@26
    32
    
jaroslav@530
    33
    /** Id of the element in the document.
jaroslav@530
    34
     * @return the id for this element
jaroslav@530
    35
     */
jaroslav@530
    36
    public String getId() {
jaroslav@530
    37
        return id;
jaroslav@530
    38
    }
jaroslav@530
    39
    
jaroslav@26
    40
    abstract void dontSubclass();
jaroslav@27
    41
    
jaroslav@100
    42
    @JavaScriptBody(
jaroslav@100
    43
        args={"el", "property", "value"},
jaroslav@592
    44
        body="var e = window.document.getElementById(el._id());\n"
jaroslav@100
    45
           + "e[property] = value;\n"
jaroslav@100
    46
    )
jaroslav@428
    47
    static native void setAttribute(Element el, String property, Object value);
jaroslav@100
    48
jaroslav@100
    49
    @JavaScriptBody(
jaroslav@100
    50
        args={"el", "property"},
jaroslav@592
    51
        body="var e = window.document.getElementById(el._id());\n"
jaroslav@100
    52
           + "return e[property];\n"
jaroslav@100
    53
    )
jaroslav@428
    54
    static native Object getAttribute(Element el, String property);
jaroslav@28
    55
    
toni@521
    56
    @JavaScriptBody(
toni@521
    57
        args={"el"},
jaroslav@592
    58
        body="return window.document.getElementById(el._id());"
toni@521
    59
    )
toni@521
    60
    static native Object getElementById(Element el);
toni@521
    61
    
jaroslav@28
    62
    /** Executes given runnable when user performs a "click" on the given
jaroslav@28
    63
     * element.
jaroslav@813
    64
     * @param data an array of one element to fill with event parameter (if any)
jaroslav@28
    65
     * @param r the runnable to execute, never null
jaroslav@28
    66
     */
jaroslav@100
    67
    @JavaScriptBody(
jaroslav@443
    68
        args={ "ev", "r" },
jaroslav@592
    69
        body="var e = window.document.getElementById(this._id());\n"
jaroslav@813
    70
           + "e[ev._id()] = function(ev) {\n"
jaroslav@813
    71
        + "  var d = ev ? ev : null;\n"
jaroslav@813
    72
        + "  r.onEvent__VLjava_lang_Object_2(d);\n"
jaroslav@813
    73
        + "};\n"
jaroslav@100
    74
    )
jaroslav@813
    75
    final void on(OnEvent ev, OnHandler r) {
jaroslav@514
    76
    }
jaroslav@428
    77
jaroslav@428
    78
    /** Shows alert message dialog in a browser.
jaroslav@428
    79
     * @param msg the message to show
jaroslav@428
    80
     */
jaroslav@428
    81
    @JavaScriptBody(args = "msg", body = "alert(msg);")
jaroslav@428
    82
    public static native void alert(String msg);
jaroslav@436
    83
jaroslav@436
    84
    /** Generic way to query any attribute of this element.
jaroslav@436
    85
     * @param property name of the attribute
jaroslav@436
    86
     */
jaroslav@436
    87
    public final Object getAttribute(String property) {
jaroslav@436
    88
        return getAttribute(this, property);
jaroslav@436
    89
    }
jaroslav@428
    90
    
jaroslav@436
    91
    /** Generic way to change an attribute of this element.
jaroslav@436
    92
     * 
jaroslav@436
    93
     * @param property name of the attribute
jaroslav@436
    94
     * @param value value to associate with the attribute
jaroslav@436
    95
     */
jaroslav@436
    96
    public final void setAttribute(String property, Object value) {
jaroslav@436
    97
        setAttribute(this, property, value);
jaroslav@436
    98
    }
jaroslav@26
    99
}