json/src/main/java/org/apidesign/html/json/spi/Technology.java
author Jaroslav Tulach <jaroslav.tulach@netbeans.org>
Fri, 07 Feb 2014 07:44:34 +0100
changeset 551 7ca2253fa86d
parent 534 15907d1499fb
child 567 83879118f17e
permissions -rw-r--r--
Updating copyright headers to mention current year
jaroslav@9
     1
/**
jaroslav@358
     2
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
jaroslav@9
     3
 *
jaroslav@551
     4
 * Copyright 2013-2014 Oracle and/or its affiliates. All rights reserved.
jaroslav@9
     5
 *
jaroslav@358
     6
 * Oracle and Java are registered trademarks of Oracle and/or its affiliates.
jaroslav@358
     7
 * Other names may be trademarks of their respective owners.
jaroslav@9
     8
 *
jaroslav@358
     9
 * The contents of this file are subject to the terms of either the GNU
jaroslav@358
    10
 * General Public License Version 2 only ("GPL") or the Common
jaroslav@358
    11
 * Development and Distribution License("CDDL") (collectively, the
jaroslav@358
    12
 * "License"). You may not use this file except in compliance with the
jaroslav@358
    13
 * License. You can obtain a copy of the License at
jaroslav@358
    14
 * http://www.netbeans.org/cddl-gplv2.html
jaroslav@358
    15
 * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
jaroslav@358
    16
 * specific language governing permissions and limitations under the
jaroslav@358
    17
 * License.  When distributing the software, include this License Header
jaroslav@358
    18
 * Notice in each file and include the License file at
jaroslav@358
    19
 * nbbuild/licenses/CDDL-GPL-2-CP.  Oracle designates this
jaroslav@358
    20
 * particular file as subject to the "Classpath" exception as provided
jaroslav@358
    21
 * by Oracle in the GPL Version 2 section of the License file that
jaroslav@358
    22
 * accompanied this code. If applicable, add the following below the
jaroslav@358
    23
 * License Header, with the fields enclosed by brackets [] replaced by
jaroslav@358
    24
 * your own identifying information:
jaroslav@358
    25
 * "Portions Copyrighted [year] [name of copyright owner]"
jaroslav@358
    26
 *
jaroslav@358
    27
 * Contributor(s):
jaroslav@358
    28
 *
jaroslav@358
    29
 * The Original Software is NetBeans. The Initial Developer of the Original
jaroslav@551
    30
 * Software is Oracle. Portions Copyright 2013-2014 Oracle. All Rights Reserved.
jaroslav@358
    31
 *
jaroslav@358
    32
 * If you wish your version of this file to be governed by only the CDDL
jaroslav@358
    33
 * or only the GPL Version 2, indicate your decision by adding
jaroslav@358
    34
 * "[Contributor] elects to include this software in this distribution
jaroslav@358
    35
 * under the [CDDL or GPL Version 2] license." If you do not indicate a
jaroslav@358
    36
 * single choice of license, a recipient has the option to distribute
jaroslav@358
    37
 * your version of this file under either the CDDL, the GPL Version 2 or
jaroslav@358
    38
 * to extend the choice of license to its licensees as provided above.
jaroslav@358
    39
 * However, if you add GPL Version 2 code and therefore, elected the GPL
jaroslav@358
    40
 * Version 2 license, then the option applies only if the new code is
jaroslav@358
    41
 * made subject to such option by the copyright holder.
jaroslav@9
    42
 */
jaroslav@6
    43
package org.apidesign.html.json.spi;
jaroslav@6
    44
jaroslav@6
    45
import net.java.html.json.Model;
jaroslav@308
    46
import net.java.html.json.Models;
jaroslav@6
    47
jaroslav@6
    48
/** An implementation of a binding between model classes (see {@link Model})
jaroslav@6
    49
 * and particular technology like <a href="http://knockoutjs.com">knockout.js</a>
jaroslav@6
    50
 * in a browser window, etc.
jaroslav@6
    51
 *
jaroslav@6
    52
 * @author Jaroslav Tulach <jtulach@netbeans.org>
jaroslav@6
    53
 */
jaroslav@6
    54
public interface Technology<Data> {
jaroslav@6
    55
    /** Creates an object to wrap the provided model object. The model
jaroslav@6
    56
     * has previously been generated by annotation processor associated 
jaroslav@6
    57
     * with {@link Model} annotation.
jaroslav@6
    58
     * 
jaroslav@6
    59
     * @param model the model generated from {@link Model}
jaroslav@34
    60
     * @return internal object representing the model
jaroslav@6
    61
     */
jaroslav@6
    62
    public Data wrapModel(Object model);
jaroslav@9
    63
    
jaroslav@38
    64
    /** Converts an element potentially representing a model into the model.
jaroslav@38
    65
     * @param modelClass expected class to convert the data to
jaroslav@38
    66
     * @param data the current data provided from the browser
jaroslav@38
    67
     * @return the instance of modelClass somehow extracted from the data, may return <code>null</code>
jaroslav@38
    68
     */
jaroslav@38
    69
    public <M> M toModel(Class<M> modelClass, Object data);
jaroslav@38
    70
    
jaroslav@9
    71
    /** Binds a property between the model and the data as used by the technology.
jaroslav@9
    72
     * 
jaroslav@9
    73
     * @param b the description of the requested binding
jaroslav@9
    74
     * @param model the original instance of the model
jaroslav@9
    75
     * @param data the data to bind with the model
jaroslav@9
    76
     */
jaroslav@9
    77
    public void bind(PropertyBinding b, Object model, Data data);
jaroslav@6
    78
jaroslav@6
    79
    /** Model for given data has changed its value. The technology is
jaroslav@6
    80
     * supposed to update its state (for example DOM nodes associated
jaroslav@6
    81
     * with the model). The update usually happens asynchronously.
jaroslav@6
    82
     * 
jaroslav@6
    83
     * @param data technology's own representation of the model
jaroslav@6
    84
     * @param propertyName name of the model property that changed
jaroslav@6
    85
     */
jaroslav@6
    86
    public void valueHasMutated(Data data, String propertyName);
jaroslav@11
    87
jaroslav@11
    88
    public void expose(FunctionBinding fb, Object model, Data d);
jaroslav@14
    89
    
jaroslav@14
    90
    /** Applies given data to current context (usually an HTML page).
jaroslav@14
    91
     * @param data the data to apply
jaroslav@14
    92
     */
jaroslav@14
    93
    public void applyBindings(Data data);
jaroslav@23
    94
    
jaroslav@23
    95
    /**
jaroslav@23
    96
     * Some technologies may require wrapping a Java array into a special
jaroslav@17
    97
     * object. In such case they may return it from this method.
jaroslav@23
    98
     *
jaroslav@17
    99
     * @param arr original array
jaroslav@17
   100
     * @return wrapped array
jaroslav@17
   101
     */
jaroslav@17
   102
    public Object wrapArray(Object[] arr);
jaroslav@240
   103
    
jaroslav@240
   104
    /** 
jaroslav@240
   105
     * Run given runnable in a safe mode. If the runnable can be executed
jaroslav@240
   106
     * immediately, do it. If we need to switch to some other thread, do it
jaroslav@240
   107
     * and invoke r asynchronously immediately returning from the call to
jaroslav@240
   108
     * runSafe method.
jaroslav@240
   109
     * 
jaroslav@240
   110
     * @param r the runnable to execute
jaroslav@240
   111
     */
jaroslav@240
   112
    public void runSafe(Runnable r);
jaroslav@275
   113
jaroslav@308
   114
    /** For certain rendering technologies it may be more efficient to register
jaroslav@308
   115
     * property and function bindings for one instance of the model at once, 
jaroslav@308
   116
     * rather then doing it incrementally via 
jaroslav@308
   117
     * {@link Technology#expose(org.apidesign.html.json.spi.FunctionBinding, java.lang.Object, java.lang.Object) }
jaroslav@308
   118
     * and 
jaroslav@308
   119
     * {@link Technology#bind(org.apidesign.html.json.spi.PropertyBinding, java.lang.Object, java.lang.Object) }.
jaroslav@308
   120
     * In such case implement the {@link #wrapModel(java.lang.Object, org.apidesign.html.json.spi.PropertyBinding[], org.apidesign.html.json.spi.FunctionBinding[]) }
jaroslav@308
   121
     * method of this interface and it will be called instead of the 
jaroslav@308
   122
     * previous two ones.
jaroslav@308
   123
     * 
jaroslav@534
   124
     * @since 0.6
jaroslav@308
   125
     */
jaroslav@275
   126
    public static interface BatchInit<D> extends Technology<D> {
jaroslav@308
   127
        /** Wrap the given model into redering technology appropriate object 
jaroslav@308
   128
         * <code>D</code> and expose given properties and functions on it.
jaroslav@308
   129
         * 
jaroslav@308
   130
         * @param model the {@link Models#isModel(java.lang.Class) model} in Java
jaroslav@308
   131
         * @param propArr array of property bindings to expose
jaroslav@308
   132
         * @param funcArr array of functions to expose
jaroslav@308
   133
         * @return appropriate wrapper around the model
jaroslav@308
   134
         */
jaroslav@275
   135
        public D wrapModel(Object model, PropertyBinding[] propArr, FunctionBinding[] funcArr);
jaroslav@275
   136
    }
jaroslav@6
   137
}