WO2002049281A2 - Methods and apparatus for creating a user interface using property paths - Google Patents

Methods and apparatus for creating a user interface using property paths Download PDF

Info

Publication number
WO2002049281A2
WO2002049281A2 PCT/US2001/048335 US0148335W WO0249281A2 WO 2002049281 A2 WO2002049281 A2 WO 2002049281A2 US 0148335 W US0148335 W US 0148335W WO 0249281 A2 WO0249281 A2 WO 0249281A2
Authority
WO
WIPO (PCT)
Prior art keywords
property
ofthe
path
application
identifier
Prior art date
Application number
PCT/US2001/048335
Other languages
French (fr)
Other versions
WO2002049281A3 (en
WO2002049281A8 (en
Inventor
Richard Hayton
Dave Otway
Original Assignee
Citrix System, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Citrix System, Inc. filed Critical Citrix System, Inc.
Priority to AU2002232582A priority Critical patent/AU2002232582A1/en
Priority to GB0309655A priority patent/GB2389292A/en
Publication of WO2002049281A2 publication Critical patent/WO2002049281A2/en
Publication of WO2002049281A3 publication Critical patent/WO2002049281A3/en
Publication of WO2002049281A8 publication Critical patent/WO2002049281A8/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • G06F8/38Creation or generation of source code for implementing user interfaces
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/44Arrangements for executing specific programs
    • G06F9/451Execution arrangements for user interfaces
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/542Event management; Broadcasting; Multicasting; Notifications
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/54Indexing scheme relating to G06F9/54
    • G06F2209/544Remote
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/54Indexing scheme relating to G06F9/54
    • G06F2209/545Gui

Definitions

  • the present invention relates to client-server networks and, in particular, to methods and
  • Contemporary computer networks consist of a number of computer systems, called nodes, communicating with other computer systems via communication links.
  • nodes communicating with other computer systems via communication links.
  • client nodes are client nodes and other nodes are server nodes.
  • a client node formulates and delivers
  • a user ofthe client node enters the queries through a user-interface operating on the client node.
  • the server node evaluates the queries and delivers responses to the
  • client node for display on the client user-interface.
  • the server nodes host a variety of application programs or processes that can be accessed and executed by client nodes.
  • client nodes launches an application program, the execution of that application program can occur at either the client node or the server node,
  • the application program is packaged and sent down to, or pre-installed on, the client node, allowing the client node to run the application using the
  • the client node must have sufficient memory, disk space, and processing power to effectively execute the application.
  • a related problem that occurs using this model is that the number of applications a given client is
  • the server node executes the application program
  • a refinement ofthe server-based model is to supplant the device driver to which the application communicates in order to send screen and device updates back and forth between the
  • This approach avoids requiring applications to be rewritten.
  • this approach requires device information to be sent between the client and the server in order to
  • server-side processing requirements are increased in order to satisfy resulting device information required for communication with each connected client.
  • a recent, further refinement ofthe server-based model is to deploy the user-interface portion
  • mark-up language document such as Hyper Text Markup Language
  • HTML HyperText
  • Standard and emerging approaches to application development for Web application delivery rely on one of two approaches.
  • the first approach is adapting 'page based' application delivery code (e.g., servlets) to more dynamic use (e.g., sequence of servlets).
  • the second approach is wiring user-interface components to server components.
  • the first approach has the advantage of
  • Generating applications with a user-interface using several pages (or dialogues) typically requires coordinating the server-side components to generate each page on an individual basis. This coordination becomes very difficult as the number of pages or the number of clients
  • UI design including layout and formatting.
  • the present invention avoids these shortcomings.
  • the present invention provides a mechanism by which the user-interface portion ofthe application can be delivered to the
  • the invention separates the user- interface from the underlying application enabling the design ofthe user interactive portion ofthe
  • the invention also permits the user interactive portion to be deployed on a wide range of
  • the invention also allows the user-interface
  • the invention connects the user-interface to objects using property paths.
  • Property paths represent abstract paths and this abstract quality allows the UI to
  • the invention relates to a method of associating an element of a user- interface to a current state of a property in a system including an application having a plurality of
  • the method comprises associating the element ofthe user-interface with a
  • the property path including a concatenation of a plurality of identifiers
  • the method includes a) examining each identifier in the concatenation ofthe property path in succession, b) determining, for the first identifier in the concatenation ofthe property path, a second state of a property with a name identical to the first identifier, a component ofthe
  • the first identifier a component ofthe application to which the second state points as a current application component, d) mapping the first identifier to the second state, e) determining for the next identifier in the concatenation ofthe property path, a next state of a property with a name
  • the method includes mapping the property path to an undefined state if no property is found that
  • the method includes generating a node tree having a plurality of nodes, wherein each node ofthe node tree represents a mapping of an identifier to one of, a state
  • the node tree represents a plurality
  • the method includes monitoring a plurality of states within the application to detect a change in one ofthe states ofthe plurality of states, each state
  • the method includes receiving a property change event
  • the method includes re-mapping the property path to a new current state in response to detecting the change in one ofthe states ofthe plurality of states. In another embodiment, the method includes re-mapping the identifier the concatenation of
  • the method includes generating a property change
  • the method includes updating one or more user-interface elements associated with the property path with a new current state in
  • the method includes, a) detecting a change in one of a plurality of states in an application, each state in the plurality corresponding to one ofthe states mapped to an identifier in the concatenation ofthe property path, b) examining each identifier in the concatenation ofthe property path in succession, starting with an identifier corresponding to the
  • the method includes terminating the
  • the method includes monitoring a new plurality of states within the application, the new plurality including the new next states mapped
  • the method includes mapping a second
  • method includes determining the second value such that replacing the wildcard identifier ofthe first property path with the second value causes the current state mapped to the first property path with the replaced wildcard identifier to be equal to the value mapped to the second property path.
  • the method includes dynamically binding the property path to one ofthe
  • the method includes transmitting to the application a request to update the current state ofthe property mapped to the property path associated with the element ofthe user-interface in response to a user modification ofthe value.
  • the method includes transmitting to the application a request to update the current state ofthe property mapped to the property path associated with the element ofthe user-interface in response to a user modification ofthe value.
  • method includes inhibiting a property change message in response to the application updating the
  • the method includes generating
  • the maximum value by copying the given element associated with the property path and associating a new property path with each additional element.
  • the method includes replacing the wildcard identifier associated with the given element with the corresponding index value ofthe additional element to define the new property path. In another embodiment, the method includes registering interest in the property path. In another
  • the method includes mapping one ofthe identifiers in the concatenation ofthe property path to a state of a property corresponding to the one ofthe identifiers.
  • the invention relates to a system for associating an element of a user-interface to a current state of a property of an application, wherein the application has a
  • the system includes a property connector module to identify an association
  • the property path including a
  • the system includes a client node.
  • the client node includes the user interface having one or more elements, and a client portion ofthe property connector
  • the system includes a server node.
  • the server node includes
  • the invention relates to a method for creating a user-interface
  • the method includes inserting at least one element into the user-interface, and associating at least one property path with one inserted element, the
  • property path including a concatenation of a plurality of identifiers, the concatenation of
  • the method includes determining a list of property
  • the method includes receiving a property path description file associated with the application, the property path description file including a plurality of identifiers associated with the application and a relationship between the plurality of identifiers.
  • the method includes executing the application, and interacting with the
  • the method includes transmitting a request to register for a property change message corresponding to the property
  • the predefined element comprises one of an image type user-interface element, an iterator type user-interface element, a text type user-interface element, a hidden type user-
  • type user-interface element a dropdown type user-interface element, a radio type user-interface element, and a script type user-interface element.
  • the invention relates to a system for creating a user-interface independently
  • the system includes a property connector module to insert at least one element into the user-interface, and to associate at least one property path with one inserted element, the property path including a concatenation of a plurality of identifiers, the
  • the system includes a client
  • the client node includes the user interface having one or more elements, and a client
  • the system includes a server node.
  • the server node includes the application, and a server portion ofthe property connector
  • the invention relates to a method using a system having an application
  • the method associates a user-interface element, which is independent ofthe application, with a property ofthe application.
  • the method includes executing a process that is independent ofthe application; representing a property ofthe application by a property path and associating, by the
  • the method determines whether a property of an object ofthe application exists that corresponds to the property path.
  • the determining process includes employing a value of a second property corresponding to a second property path (e.g., cross-
  • the method includes monitoring a state ofthe property and detecting
  • the process of detecting includes receiving a property change event from an API of a JANABEANTM compatible component.
  • the method includes updating the user-interface element in response to detecting the change in the state ofthe property.
  • the method includes generating a property change message in response to detecting the change in the state ofthe
  • the method includes registering for a property
  • method includes detecting a change in a state of one or more properties along the property path, and responding to a detected change in a value that the property path represents.
  • the method includes determining at least one property path
  • determining at least one property path includes traversing from a root object ofthe application to a corresponding property, using object pointers. In another embodiment, this includes mapping the traversal from a root object ofthe application to the corresponding property. In another
  • the process of mapping includes generating a node tree.
  • the method includes indicating which nodes in the node tree correspond to a property path that
  • the method includes dynamically binding the property path to the object containing the represented property.
  • the method includes allowing a user to modify a value associated with the user-interface element and updating the property ofthe application represented by the
  • the method includes inhibiting a property change message in response to updating the property ofthe application in response to the user modification.
  • the invention relates to a method using a server node having an application
  • the method includes executing a process that is independent ofthe application, representing a property ofthe application by a property path
  • this method includes determining whether a property of an object ofthe application exists that corresponds to the property path. In another embodiment, the
  • process of determining includes employing a value of a second property corresponding to a
  • second property path e.g., cross-mapping
  • the method includes monitoring a state ofthe property and detecting
  • the process of detecting includes receiving a property change event from an API of a JANABEANTM compatible component.
  • the method includes transmitting the changed state in response to detecting the change in the state ofthe property. In another embodiment, the method includes generating a property change message in response to detecting the change in the state ofthe property. In
  • the method includes registering the property change message ofthe request for the property represented by the property path.
  • the method includes determining at least one property path
  • the process of determining at least one property path includes traversing from a root object ofthe application to a corresponding
  • the method includes mapping the
  • the process of mapping includes generating a node tree.
  • the method includes indicating which nodes in the node tree correspond to a property path the client has registered interest in.
  • the method includes dynamically binding the property path to the object containing the represented property.
  • the invention relates to a method using a client node having a user-
  • the method includes executing a process independent ofthe
  • the application by a property path and selecting, with the application-independent process, the property path or paths to associate with the user-interface element.
  • the property path or paths to associate with the user-interface element.
  • method includes transmitting a request to register for a property change message associated with the selected property path.
  • the method includes receiving the property change message in response to a change in a state ofthe property represented by the property path.
  • the method includes updating the user-interface element in response to notification ofthe change in the state ofthe property. In another embodiment, the method includes receiving
  • the method includes inhibiting a property change message in response to transmitting the modified value associated with the user-interface element.
  • the process of employing an element includes providing to the user at least
  • the predefined element includes one or more ofthe following: displaying a property value as a piece of text, allowing the displayed property value to be edited, enabling a
  • numeric properties displaying an image dependent on a property value, displaying an embedded frame dependent on a property value, an anchor dependent on a property value, ability to hide or
  • element includes one or more ofthe following: selections of displaying one of a 'deck' of UI fragments dependent on a property value, a dropdown menu where each choice is a value from
  • radio buttons a treeview based on property paths and the ability to repeat part of a UI once for
  • Some objects of this invention are as follows: to allow simple UI development for
  • the invention includes a system for providing rich /
  • server types e.g., COM
  • the system uses a 'loose' coupling mechanism, which allows the server-side application to
  • New client types may be designed and deployed without touching the server code.
  • a third party could design a new client type without the server's
  • the user-interface for a particular application can be changed or ported to a new
  • the user-interface can be tuned or given a new look and feel without disrupting the function ofthe application.
  • the system takes advantage ofthe fact that most user-interfaces are essentially static. A large portion of a user-interface does not change at all.
  • a typical example is a form. The form
  • the dynamic aspect of a user-interface generally consists of changes to the static page 'template'
  • the invention keeps standard Web-metaphors.
  • the invention adds only the ability to fill in a page template dynamically.
  • the invention allows the static aspect of a user- interface to be developed using standard UI development tools. These tools can be extended (or additional tools provided) to add the dynamic aspect ofthe UI. Because ofthe approach taken to
  • FIG. 1 is a block diagram of an embodiment of property path associations constructed in
  • FIG. 2 is a block diagram of an embodiment ofthe sub-components ofthe property connector API of FIG. 1 constructed in accordance with the invention
  • FIG. 3 is a block diagram of another embodiment ofthe system architecture ofthe invention.
  • FIG. 4 is a screenshot of a UI development application that is being executed in combination
  • FIG. 5 is a screenshot of a UI application illustrating an embodiment ofthe invention during
  • FIG. 6 is a block diagram of an embodiment ofthe mapping of registered property paths of
  • FIG. 7 is a flow diagram of an embodiment of client and server interaction constructed in
  • FIG. 8 is a block diagram of another embodiment ofthe server portion with an extension feature according to the invention.
  • FIG. 1 depicts a block diagram of an embodiment of a system 10 for communicating
  • the 10 includes a server process 14, a client process 18 and a property connector API 22.
  • the server process 14, the client process 18 and the property connector API 22 can be located on a single computing device or distributed among several computing devices.
  • application 26 includes an application 26 with application components 34a, 34b, 34c and 34d (generally 34).
  • application components 34a, 34b, 34c and 34d are instances of objects that
  • Each ofthe application components 34a, 34b, 34c and 34d includes zero or more properties
  • This embodiment includes two types of properties.
  • a first type of properties 38 for example, 38d, 38e and 38f, have a value for a
  • a second type of properties 38 for example, 38a, 38b and 38c, have a pointer
  • application components 34 can be generated by a process using a data file.
  • application components 34 can be representations of nodes within a structured data file
  • DTD document type definition
  • the application components 34 support additional standard properties 38 such as 'parent', 'child[i] ⁇ and the like.
  • Many applications 26 are object-oriented and as such, generate a structured relationship
  • the structured relationship can be illustrated as a node tree.
  • the root node is the first object ofthe application and each object that the root object points to becomes a
  • object 34a represents a root node.
  • Objects 34b and 34c are children nodes ofthe root node 34a.
  • Object 34d is the child node of object 34c and the grandchild node of object 34a.
  • Each part ofthe application 26 state (i.e., values of application component properties 38 at a particular instant in time) is accessible via a traversal of a 'path' from one or more root objects to
  • An object and/or property may be addressable by several 'paths' from the root node, for example, an object representing an Employee may be
  • Redmond, WA Redmond, WA
  • a property-based link is an object pointer that is accessible via a standard means (e.g., 'get' and 'set' methods).
  • Applications 26 using property-based links undertake to inform the server process 14 about changes in the property-based link using, for
  • the client process 18 produces a user-interface ("UI") 42 that is displayed to a user.
  • the UI 42 includes one or more user-interface elements 46a and 46b (generally 46).
  • the UI 42 can be, for example, a Web page, an HTML document, a custom UI and the like. Though the UI is
  • the UI elements 46 are
  • the user-interface element 46 is a portion ofthe UI 42
  • the UI element 46 can be, for example, an input box for textual or numerical input and display of a value of a property 38.
  • the UI element 46 also can be, for
  • a horizontal slider for numerical input and display of a value of a property 38 As
  • the first user-interface element 46a displays and/or affects a value 50a associated with a state of a property 38 of one ofthe application components 34.
  • the second user-interface element 46b displays and/or affects two values 50b and 50c. Between the application components 34 and the user-interface elements 46 is the property
  • the property connector API 22 includes a client portion 22a and a server
  • portion 22b is a process that is independent ofthe application 26 (i.e., not a part of nor generated
  • the property connector API 22 process can be implemented as software, as hardware or as a combination of both.
  • the execution ofthe property connector API 22 can be initiated in several ways.
  • the computing device can initiate execution ofthe property connector API 22 upon power up or upon a authorized user log-in.
  • the computing device can initiate execution ofthe property connector
  • API 22 when the computing device downloads a page 42 containing UI elements 46 associated with property paths.
  • the computing device can initiate execution ofthe property connector API
  • the computing device also receives a startup argument including the name of a file
  • the property connector API 22 maps each dynamic user-
  • the interface element 46 to a property 38 of an application component 34 using the associated property path.
  • the property path defines the interaction between the client process 18 and the
  • server process 14 in terms of properties 38 ofthe application 26 rather than in terms of the user-
  • the property connector API 22 represents a property 38 of an application
  • the property path is the
  • An identifier corresponds to a property 38 within an
  • the property path defines a path through the application 26 from a root component 38 to the particular application component 34,
  • property 38a points to application component 34c and the property 38c of application component 34c points to
  • property 38d in this example is 'App.PropertyIDl.PropertyID3.PropertyID4'.
  • Each part ofthe property path i.e., App, PropertylDl, PropertyID3, PropertyID4.
  • the property connector API 22 uses these identifiers to traverse the path in the application 26 defined by the property path.
  • the 'App' identifier identifies the root node.
  • the property connector API 22 determines the value of 'PropertylDl ' by obtaining the present state (i.e., value) of a property with the same name within the root
  • connector API 22 determines the present state points to the application component 34c. Because the value of property corresponding to identifier 'PropertylDl' is component 34c, the
  • connector API 22 determines the value of 'PropertyID3' by obtaining the present state (i.e.., value) ofthe property 38c with the same name within the component 34c, which was identified
  • the property connector API 22 determines the present state points to the application component 34d. Because the value of property corresponding to identifier
  • 'PropertyID3' is component 34d
  • the 'PropertyID4' identifier identifies the property 38d within the component 34d.
  • the property connector API 22 determines the value of 'PropertyID4' by
  • Property 38d is not a pointer, but a
  • the property connector API 22 maps the current state of this
  • property 38d to the property path 'App.PropertyLDl .PropertyID3.PropertyID4'. While mapped, the property path 'App.PropertyIDl.PropertyID3.PropertyID4' has the value ofthe salary of property 38d.
  • the user-interface can display and/or affect (i.e., a loosely coupled, flexible connection).
  • the application 26 can create or delete application components 38 without any adverse affect on the user-interface elements 46.
  • the property path ⁇ pp.PropertyIDl.PropertyID3.PropertyID4' corresponds, at one point in time, to property 38d,
  • the property connector API 22 updates the
  • the property path identifies a path through the application 26 and not one specific
  • the path can change as one ofthe properties 38
  • a property path can also represent a property with a potential to exist, but that does not exist at the present time. For example, if the list of employees only contains twenty-six employees (numbered 0 to 25), the property path ⁇ RApp.Dept.Employee[26]. Salary' does not correspond to any property. When another employee is added, the property path ⁇ RApp.Dept.Employee[26]. Salary' would then point to the salary property ofthe twenty-
  • the second value 50c of UI element 46b displays the salary ofthe twenty-seventh employee of a specific department because the value 50c is associated with the property path ⁇ RApp.Dept.Employee[26]. Salary'. The client portion
  • the server portion 22a maps this association between the value 50 and the property path.
  • the server portion 22b maps this association between the value 50 and the property path.
  • the server portion 22b follows the pointers with the application components 34 that correspond to the property path.
  • the server portion 22b follows the pointers by using 'get' methods and constructing a structure
  • the ⁇ RApp' portion ofthe property path corresponds to the application 26 and the first created application component 34a (i.e., the root application component).
  • the property path corresponds to the property 38a that points to the application component 34c, which in this example represents a list of employees ofthe indicated department.
  • ⁇ mployee[26]' portion ofthe property path corresponds to the property 38c that points to the application component 34d, which in this example represents information about the twenty- seventh employee.
  • the 'Salary' portion ofthe property path corresponds to the property 38d that
  • the application component 34d can also contain other properties (not shown) that have values representing information about that particular employee, such as name, social security number, date of hire and the like.
  • application component 34d changes and subsequently points to another application component (not shown).
  • the application component 34d represented information about the twenty-seventh employee.
  • path 'App.SelectedEmployee.Boss.Boss.Name' represents the name property 38 ofthe selected
  • the property path 'App.Employee[21].Name' represents the name property 38 ofthe twenty-second employee in a table. If the table is sorted or changes size, then this property path will correctly reflect the name property 38 ofthe
  • FIG. 2 illustrates an exemplary embodiment of a system 54 that includes a first computing
  • server node 60 in communication with a second computing system (“client node”) 64
  • the communication channel 94 can be over a local-area network (LAN), such as a company Intranet, or a wide area network (WAN) such as
  • LAN local-area network
  • WAN wide area network
  • the server node 60 includes a server transceiver 108, the
  • server portion 22b a property/event interface 90 and the application 26, including one or more
  • the server node 60 can establish communication over the
  • the server portion 22b is a separate process on the server node 60.
  • ICA ICA
  • HTTP TCP/IP IPX
  • SPX SPX
  • NetBIOS NetBIOS
  • Ethernet RS232
  • server portion 22b is located on a server node (not shown) separate from
  • the application program 26 In another embodiment, the property/event interface 90 is included
  • the client node 64 includes a client transceiver 104 and an optional page interface 112.
  • page interface 112 includes the client portion 22a and generates (or edits) a page '42, containing
  • the client node 64 can be any computing device (e.g., a personal computer, or a personal computing device, or a personal computing device).
  • the client node 64 can be connected to the communication channel 94 through a variety of connections including standard telephone lines, LAN or WAN links (e.g., TI, T3, 56kb, X.25), broadband connections (ISDN, Frame Relay, ATM), and wireless connections.
  • standard telephone lines e.g., LAN or WAN links (e.g., TI, T3, 56kb, X.25), broadband connections (ISDN, Frame Relay, ATM), and wireless connections.
  • the client portion 22a is part ofthe page interface 112.
  • the page interface 112 can be, for example, a
  • Web browser e.g., a MICROSOFTTM INTERNET EXPLORER browser manufactured by Microsoft Corporation of Redmond, WA and/or a NETSCAPETM NAVIGATOR browser,
  • the client portion 22a is a separate process on the client node 64.
  • interaction between the client node 64 and the server node 60 occurs if the application 26 is executing and the user is interacting, via the page 42, with the application
  • the user creates a page 42 using
  • the page interface 112 e.g., HTML editor, DREAMWEAVERTM software by Macromedia, Inc.
  • the user locates UI elements 46 using the page interface 112. In one embodiment, the user selects a UI element 46
  • a property file has the following form:
  • start property file // List of types used in this property files (identifiers)
  • RootType Company
  • the property file has the following form:
  • RootType Company Company .Name String
  • the property file containing property paths is stored on the client node
  • the property file can contain the types of application
  • the property file can also contain information regarding
  • the file can be manually created and/or manually augmented.
  • the page interface 112 and/or the client portion 22a has a property browser.
  • the browser may examine the code ofthe application 26 (e.g.,
  • the type ofthe get/set property methods In another embodiment the property browser
  • the property browser can obtain the instantaneous values of available application components 34, their properties 38 and the relationship (e.g., child nodes) between the application components 34. After this information is obtained, the execution ofthe
  • FIG. 3 depicts the client portion 22a and the server portion 22b ofthe property connector
  • the client portion 22a includes a protocol module 70 and an event manager 74.
  • the protocol module 70 is located within the client
  • the client portion 22b also includes an optional
  • predefined UI elements portion 78 which contains data to generate specific types of UI elements 46, identified in detail below, in connection with FIG. 4.
  • the client portion 22a communicates with the UI elements 46 ofthe page 42.
  • the server portion 22b includes a protocol module 82 and a property path manager 86.
  • the protocol module 82 is located within the server transceiver 108 (e.g.,
  • the server portion 22b is in communication with the application components 34 ofthe application 26 through a property/event interface 90.
  • the client portion 22b communicate with each other over the communication channel 94, using a property path protocol as described below.
  • the client portion 22b communicates with each other over the communication channel 94, using a property path protocol as described below.
  • the client portion 22b communicates with each other over the communication channel 94, using a property path protocol as described below.
  • the client portion 22b communicates with each other over the communication channel 94, using a property path protocol as described below.
  • the server portion 22b are located on the same machine and are directly connected to each other.
  • the property connector API 22 associates the user-interface elements 46 with the application
  • the functions ofthe property connector API 22 can include:
  • the server node 60 executes the application 26 and instantiates the application components 34 (e.g., objects).
  • the application components 34 e.g., objects.
  • JAVABEANSTM compatible components and the property/event interface 90 includes a
  • server node 60 If not already executing, the server node 60 also executes the
  • server portion 22b which is independent ofthe application 26 (i.e., not a part of nor generated from the application 26).
  • the server node 60 executes the server portion 22b in response to the
  • client node 64 requesting execution ofthe application 26 and/or in response to the client node 64
  • node 64 executes the client portion 22a, which is independent ofthe application 26 (i.e., not a
  • the event manager 74 ofthe client portion 22a is written as a set of JAVASCRIPTTM files for a
  • the client node 64 executes the client portion 22a in response to a user requesting execution ofthe application 26 and/or in response to
  • the client-side event manager 74 maps the UI elements 46 to the associated property paths.
  • the event manager 74 maintains a database ofthe mapping of UI elements 46 to property paths.
  • the event manager 74 may or may not examine the individual identifiers in the concatenation of a property path. This affects the amount of information that has to be transmitted between the
  • the event manager 74 treats
  • the event manager 74 does not breakup or examine the individual identifiers in the concatenation of a property path, but instead treats the property path as a single, long variable name or as a placeholder. This allows a compression
  • each property path in the page 42 with a single id (e.g., $1).
  • a single id e.g., $1.
  • the server portion 22b must track all changes to any ofthe properties corresponding
  • the server portion 22b also only communicates changes to the client portion 22a in terms of complete property paths.
  • the client portion does examine changes corresponding to each
  • a copy ofthe property path manager 86 is located on the client
  • node 22b can communicate changes to the client portion 22a in terms of individual identifiers.
  • the event manager 74 sends to the server-side property path manager
  • the event manager 74 When the event manager 74 informs the server portion 22b about which property paths are of interest, the event manager 74 does not need to inform the server portion 22b specifically which
  • the property path manager (or how many) UI elements 46 are interested in each property path.
  • the event manager 74 notifies the property path manager 86 about the change and to which property path the change corresponds. Because the communication references property paths, the communication about the change is in terms of
  • the UI element determines the value the 50% point represents and signals an event to the event manager 74.
  • the event manager 74 can send a notice of lack
  • the event manager 74 can immediately inform the server portion 22b, not inform the server portion 22 at
  • the server portion 22b transmits to the client portion 22a any change events associated with those property paths in
  • the event manager 74 receives a property change event for a change in the state (e.g., value) of a property 38 associated with a
  • the event manager 74 determines, using the mapping
  • the event manager 74 communicates the updates due to the change event to each ofthe UI elements 46 mapped to the property path. In one embodiment,
  • the event manager 74 is configured to inform UI elements 46 that are located in other sub-windows about any applicable
  • the event manager 74 manages the database ofthe mapping so that
  • each page may contain a portion ofthe event manager 74, and
  • the UI element 46 If the user updates a UI element 46, the UI element 46 signals a change event to the event
  • the event manager 74 and is updated on the display as the user makes a change.
  • the event manager 74 receives a change event from the UI element 46
  • the event manager 74 determines, using the mapping, which other UI elements 46 are mapped to the same property path as the UI element 46 that changed.
  • the event manager 74 communicates the updates due to the change event to each
  • the event manager 74 also sends
  • the event manager 74 does not make any immediate changes to the
  • the event manager 74 first sends a change event to the server portion 22b so that
  • the server portion 22b can update the associated property 38 ofthe application component 34 in response to the user change ofthe UI element 46.
  • the application 26 can reject the change initiated by the user for security or other reasons.
  • the event manager 74 waits until the server portion 22b sends back a change event indicating that the property 38 ofthe application
  • the event manager 74 After the event manager receives that change event from the server portion 22b, then the event manager 74 communicates the
  • the event manager 74 updates the UI element 46 that the user changed back to its pre-user intervention state.
  • the property connector API 22 takes steps to avoid looping of change
  • the property comiector API 22 does not inform the original generator (i.e., UI element
  • a page 42 can also be altered dynamically when, for example, an iterator type predefined UI
  • element 78 creates additional UI elements for indexed properties, a process described in more detail below. If a page 42 is being altered dynamically, then when a UI element 46 is generated, the event manager 76 determines those property paths in which the UI element 46 is interested.
  • the event manager 74 determines that the UI
  • element 46 is no longer interested in those property paths. In one embodiment, the user has
  • the client portion 22a duplicates/clones the example (e.g., row) for all ofthe members ofthe indexed property
  • the example portion ofthe UI may be a single UI element or a more complex set of UI elements.
  • FIG. 4 depicts an embodiment of a screenshot 128 produced by the page interface 112 (FIG.
  • the screenshot 128 includes a display 130 of an HTML page 42' that a user is
  • the screenshot also includes a palette 134 of some
  • the palette 134 of available predefined UI elements 78 includes predefined UI elements 78a, 78b, 78c, 78d, 78e, 78f and 78g.
  • Predefined UI element 78a represents an image type UI
  • the image type predefined UI element 78b displays an image dependent on the value of
  • Predefined UI element 78b represents an
  • An iterator type UI element repeats a UI element for each member of a range of
  • the element 46g' represents an iterator type element, where the row 46g' is an exemplary row that the client
  • portion 22a copies when dynamically creating elements for each index value.
  • Predefined UI element 78c represents a text type UI element.
  • element 78c displays a property value as a piece of text.
  • the elements 46b', 46c' and 46d' represent text type elements. With a text type predefined UI element 78c, numeric values may be
  • Predefined UI element 78d represents a hidden type UI element.
  • Predefined UI element 78e represents a value type UI element.
  • the value type predefmed UI element 78e is an input box that displays a property value and allows it to be
  • the element 46e' represents a value type element.
  • Predefined UI element 78f represents a slider type UI element.
  • the slider type predefined UI element 78f includes a vertical slider and/or a horizontal slider for numeric properties.
  • the element 46f represents a slider type element.
  • the user also enters values associated with 'min' 'max' and 'step' values for that slider element.
  • the user enters the property paths for the values associated with 'min'
  • Predefined UI element 78g represents a treeview type UI element.
  • the element 46a' represents a treeview type element.
  • element 78g is based on the levels of a property path. For example, for the property path
  • the treeview has a root level, a child level and a child's child level.
  • the root level is App.Boss
  • the child level is App.Boss.Staff[i]
  • the child's child level is
  • the palette 134 can include other predefined UI elements 78.
  • a button type disables a button based on a property value associated with a property
  • An iframe type displays an embedded frame, where the contents ofthe frame are constructed from a page described by the value of property path.
  • An anchor type creates an anchor which links to a page described by the value of a property path.
  • UI element displays associated properties as tabs, with one tab per member of a range of indexed
  • a flipflop type changes the style of part of a UI , dependent on a property and an expression. For example the flipflop will set the style ofthe part ofthe UI to one state (the flip state) if the expression evaluates to 'false' when a placeholder in the expression is substituted by the current value ofthe property. If the expression evaluates to 'true' then the style ofthe part of
  • the UI is set to an alternative state (the flop state).
  • a deck type displays one of a 'deck' of portions of a UI , dependent on a property value (each
  • UI portion is associated with a value, an the one whose value matches the current value ofthe
  • a dropdown type is a nested dropdown menu, where each choice is a value from a range of indexed properties.
  • a radio type has one or more radio buttons, where each has a property path and an associated value to set the property path to if the button is
  • All UI elements may contain an expression in terms of a number of property paths
  • a script type element executes a script on the client node 64 whenever a value of a specified property changes
  • the user selects a UI element 46' generated by the page interface 112 and places the selected UI element 46' at the desired location in the page 42' .
  • the user can also select from the predefined UI elements 78 shown in the palette 134. The user selects a predefined UI element 78 and places the selected predefined UI element 78 at the
  • This placement can be done, for example by the click and drag
  • the user can move the cursor to the desired insertion point, and then click on the item from the palette 134.
  • the client portion 22a generates a dialog box that prompts the
  • the client portion 22a locates the selected element 78 at the cursor position.
  • the user uses the entry display 138 to edit a property path associated with a UI element 46'
  • the user can type in the property path.
  • the user can search through a list (e.g., structured
  • the list is provided through a property file containing identifiers and their relationships, and the page interface 112 accesses the property file, which is
  • portion 22a includes a property browser.
  • the property browser obtains the instantaneous values of available application components 34, their properties 38 (e.g., identifiers) and the relationship (e.g., child nodes) between the application components 34 and properties 38 to provide a list of
  • the property browser examines the code ofthe
  • FIG. 5 depicts a
  • the page 42" contains a treeview type UI element 46a" that displays the structured relationship between the employees.
  • the page 42" also contains a large number of text type UI
  • Text type UI elements 46b", 46c" and 46d that display the text values of properties that correspond to the 'selected' employee. This current selection is also reflected in (and may
  • the value type UI element 46e" i.e., input box
  • the slider type UI element 46f ' display the salary that corresponds to the selected employee.
  • the user can use any ofthe UI elements associated with the 'salary' property path (e.g., 46e", 46f ' ) to change the salary that corresponds to the selected employee. As discussed above, when a user
  • UI elements 46" is done entirely on the client node 64 without any interaction from the server
  • the client portion 22a also notifies the server portion 22b ofthe change, so the server
  • portion 22b can update the appropriate property 38.
  • the application 26 may veto the change either by not providing a 'set' method for the property 38, or by rejecting the call via veto
  • this veto might be in the form of a "throw” statement using an "exception" sub-
  • the property path manager 86 informs the client portion 22a that
  • the value has changed back to its old value, so that the correct value is displayed on the client node 64.
  • the client portion 22a similarly creates text elements 46o" - 46t" in the table 46i" from an exemplary row ofthe table (e.g., 46g' of FIG. 4) and by substituting the index values 0,
  • FIG. 6 depicts a block diagram of an embodiment of a map of registered property paths generated by the property path manager 86.
  • the property path manager 86 generates this map to track all ofthe property paths in which the client portion 22a registers interest and the properties 38 ofthe application components 34 to which the property paths correspond.
  • the map ofthe property path manager 86 is modeled as a tree structure 160.
  • the free structure 160 is associated with an application 26' including application components 34a', 34b',
  • 34c', 34d' (generally 34'), some of which include properties 38a', 38b' 38c' (generally 38').
  • tree nodes 164a, 164b, 164c, 164d (generally 164) ofthe tree 160 are associated with the root
  • the property path manager 86 generates
  • a tree 160 representing all of he available property paths currently available for a specific
  • the property path manager 86 transmits all of he available property paths to the client portion 22a for use in generating a page 42", as mentioned with respect to FIG. 4.
  • the client portion 22a has registered interests in property paths 'App.X. Y' and 'App.X.Z', represented by tree nodes 164c and 164d, respectively.
  • X, Y and Z represent
  • property path ' App.X. Y' can represent the property path 'App.Employee[3].Name' and 'App.X.Z' can represent the property path
  • the property path manager 86 notifies the property path manager 86.
  • the property path manager 86 updates the corresponding tree node(s) 164 in the property path tree 160. If the updated tree node(s) 164 represents a complete property path in which the client portion 22a has registered interest, the property path
  • the property path manager 86 sends, or queues for sending, a change event to the client portion 22a.
  • the property path manager 86 subsequently recursively examines each ofthe tree node's children nodes.
  • the property path manger 86 via the property/event interface 90, obtains a new value of a property 38' from the application 26', and if another value of a registered property
  • the property path manager 86 terminates the recursive examination when something is found to be unchanged. For example, any child node of tree node 164d is not examined, as the value ofthe tree node 164d is unchanged.
  • this change represents a change in the third employee.
  • the client portion 22a is not interested in the 'App.X' property path, so the property path manager 86 does not generate a change event for this
  • the property path manager 86 determines this change when it recursively examines the children tree nodes Y 164c and Z 164d of tree node X 164b. Significantly, this
  • the property path manager 86 converts those change events that the application 26' can generate into change events associated with property
  • application components 34b', 34c' point to application component 34d'.
  • the client portion 22a has registered in the property path 'App.X.Z' and this value remains unchanged, despite that fact that App.X now refers to a different application component 34c'.
  • the client portion 22a can
  • the cross-mapped property path is in the form, for example, Map("v#r").
  • Map("v#r" Map("v#r").
  • the cross-mapped special type represents a relationship between a value "v”, specified with a property path, and a range of possible values "r", specified with a wildcard property path.
  • mapped property path is the property path within the range "r" that has the same value as "v”.
  • Map("Session.CurrentEmployee#App.Employee[*]") is 2.
  • cross-mapping is a lookup of one property path, dependent on
  • the property path manager 86 examines the first property path "Session.Current" and determines the value v ofthe property
  • the property path manager 86 looks up the value v within the second property path, where the value v replaces a wildcard identifier ofthe second property path. The value ofthe
  • cross-mapping is the index that matches. For example if the state ofthe first property path
  • App. Employee [0] is Abe App.Employee[l] is Barbara App.Employee[2] is Charlie App.Employee[3] is Diane,
  • the second property path may contain several wildcards identifiers, and the value will be the 'route' tlirough all of these wildcard identifiers. For example, for the cross mapping is
  • the indexed property A acts like a number of properties 'A.size, A.O A.l, A.2.... A.(size-l)'.
  • the property connector API 22 follows this indexing by representing such properties in property paths ' A[], A[0], A[1],A[2] .... A[size-1]', respectively.
  • the iterator type predefined UI element 78 (FIG. 3) uses the special type indexed property path.
  • the iterator type predefined UI element 78 includes a template and is linked to an indexed
  • the template represents the layout ofthe iterator type predefined UI element 78
  • the iterator type predefined UI element 78 creates a copy ofthe template for each member ofthe
  • index value Each copy is linked to the application via its associated property path.
  • An identical approach is taken for treeviews, and rows of drop-down menus.
  • the 'iterator' UI element 78 provides a table with a 'template' row.
  • 'iterator' UI element 78 duplicates this 'template' row for each member ofthe indexed property.
  • Each row can contain arbitrary UI elements 46 with 'wildcard' pathnames (i.e., property paths)
  • the property/event interface 90 transmits data (e.g., change events, value changes) between the property path manager 86 and the application 26.
  • This interface 90 uses an appropriate API for the implementation ofthe application 26. In one embodiment, for
  • the application 26 is JAVATM technology-based, and the standard ' JAVABEANTM
  • Property API' provides the required semantics and is thus used as the property/event interface 90.
  • This standard API 90 allows the property path manager 86 to change the values of properties 38
  • This standard API 90 also notifies the property path manager 86 about changes
  • Other embodiments can include COM objects 34 and a COM property
  • the client portion 22a and the server portion 22b communicate with each other over the
  • the protocol modules 70 and 82 establish low-level communication by use of a communications layer.
  • An exemplary protocol is described in Table 1. The protocol
  • the protocol modules 70 and 82 are part ofthe client transceiver 104 (FIG. 2) and the server transceiver 108 (FIG. 2), respectively.
  • the server node 60 and the client node 64 batch the communication
  • the server node 60 and the client node 64 use HTTP as the transport protocol.
  • the client node 64 sends the server node 60 one or more messages.
  • the server node 60 processes the
  • the server node 60 batches all ofthe messages queued to be sent to the client node 64 and sends them as the response to the HTTP request from the client node 64. In one embodiment, batching involves the
  • the batching process also sorts the entries lexicographically in order to aid compression.
  • the communications protocol as illustrated in Table 1, relies on informing the client node
  • the node 64 about which ofthe client's display elements 46 to update, and how to update them.
  • the role ofthe client node 64 is to reflect the current state ofthe application 26. If network or communication channel latency is high, then the client node 64 displays an
  • the server node 60 can be completely unaware ofthe type of client, or the way in which the client node 64 chooses to reflect the changes in the state ofthe application 26. This makes the server node 60 more stable and scalable, as new client node 64 features do not
  • S server node 60
  • C client node 64
  • protocol modules 70 and 82 are configured to employ
  • a property path compression scheme is used within a batch of messages sent within the client node 64, within the
  • the client node 64 takes advantage ofthe preceding message by
  • Another scheme to shorten the length of messages is for the client node 64 to register
  • this scheme is used to register interest in all the property paths that supply values for a table.
  • this scheme is used to register interest in all the property paths that supply values for a table.
  • n is the size ofthe App.Employee indexed property.
  • n is the size ofthe App.Employee indexed property.
  • the property connector API 22 also compresses the property path names. From the server
  • the server portion 22b compresses its responses by omitting property path
  • the system 54 uses a data compression scheme in messages sent from the server node 60 to
  • the client node 64 stores, at all times, the 'last known' value 50 of each of the property paths that it is displaying in the page 42 in a current value table. In one
  • the server node 60 optionally stores a copy of this information, and uses this as a
  • the server node 60 needs to transmit to the
  • the server node 60 determines, by examining the data dictionary, that the client node 64 already has the value
  • copy Value (App.Employee[3]. Name), where copy Value is a directive to the client node 64 to use
  • protocol modules 70 and 82 are configured to employ the data compression scheme in parallel with the property path compression scheme and an array name
  • protocol modules 70 and 82 utilize this combination of schemes when
  • array name compression scheme is of particular benefit when an array of data on the server node
  • the property connector API 22 is configured so that the server node
  • connector API 22 can optimize the resource usage on the server node 60 by suspending the
  • the second class of applications 26 that can be optimized are those that act as data feeds, for
  • the property connector API 22 again stores client-specific state on the client node 64 rather than the server node 60 , allowing the server node 60 to scale to more client
  • the property connector API 22 allows a single .'worker application instance' to service many clients 64.
  • the third class of applications 26 that can be optimized are those that generate events faster than the client node 64 can collect them.
  • An example is a stock ticker application that sets the price of a stock every second and communicates with a client node 64 that reads the stock price
  • the property connector API 22 reduces the rate of event generation, without
  • the property connector API 22 adds event-buffering mechanisms so that the per- event cost is much lower. For example, only one record is updated on the server per event, rather
  • the property connector API 22 scans
  • the property connector API 22 supports different modes of operation where the per-client state and/or processing on the server node 60 is further reduced. This is at the expense of increased bandwidth and/or processing requirements when
  • client connection may move from a 'highly interactive' mode of operation to a 'resource saving'
  • the rate of event generation may be varied according to the server load.
  • connected mode The server 60 stores, for each client 64, an instance ofthe application 26 and a property graph of listener objects 34.
  • connected mode there is high per- client state stored on the server 60 and high per client event processing load. However this is low per client poll/invocation processing load, and thus low bandwidth is required.
  • the second mode of operation is disconnected mode. In disconnected mode, the client state
  • the client 64 also stores a description of each property it is
  • the property comiector API 22 allows a client 64 in
  • the additional operations are specific optimization techniques for fine tuning the connected and disconnected modes of operation for deployments with a large client population.
  • the property connector API 22 commands the application 26 to save its state
  • the client 64 sends the saved application state to the server 60 along with a list of properties 38 that the client 64 is interested in.
  • the server 60 restarts the application 26 using the saved state, re-registers interest in all properties 38, and continues in the coimected mode. This operation is invoked by a disconnected client 64 that
  • the client 64 wishes to update the server state (i.e., invoke an operation or set a property).
  • the client 64 sends the saved application
  • server 60 may restart the application 26, return the current values ofthe properties 38 and then
  • an application 26 For an application 26 to use this optimization, it must provide the required static method, for example, a single shared instance, or static method, that can take a saved state and return a suitable application instance.
  • This suitable instance may be a shared
  • the one-shot operation is invoked by a disconnected client 64 that wishes to poll, but not change the server state.
  • the property connector API 22 is further configured with additional optimizations such as timestamp, slow garbage collector, connectivity check and property set.
  • the property connector API 22 adds a timestamp-based property interface.
  • the property connector API 22 uses the two commands 'Timeid
  • the server 60 provides the current timestamp as an additional
  • the client 64 In calls to one-shot or reconnect operations, the client 64 provides this timestamp, and is informed of property values if they have changed since this timestamp was issued.
  • the property connector API 22 uses the slow garbage collector
  • the property connector API 22 uses the Connectivity Check
  • a client 64 wishing to perform reconnect or one-shot operations first determines whether the server 60 still has a valid application instance. If the server 60 does, then the saved state and property list does
  • the property connector API 22 uses the property set optimization. It is noted that if a server 60 is supporting a large number of clients 64, all of which use the same
  • the server 60 associates the set of properties 38 that the client 64 is interested in with an set identifier, and the client 64 uses this set identifier during one-shot and reconnect operations, rather than sending the complete list of properties 38.
  • the set identifier incurs a small additional memory requirement on the server 60, as many clients
  • FIG. 7 depicts a flow diagram of an embodiment of a process by which the server node 60 and client node 64 interact in accordance with the invention.
  • the first step is that the client node 64 establishes a connection with the server node 60 to connect (step 200) to an executing
  • the server node 60 authenticates the client node if required and connects the client node 64 to the
  • the client portion 22a scans the UI 42 and identifies (step 208) a UI element 46 within the
  • the client portion 22a inserts (step 212) into its table the identified UI element
  • the client portion 22a registers (step 216) interest in this
  • the client portion 22a determines (step 220) whether
  • the server portion 22a When the client portion 22a registers (step 216) interest in a property path, the server portion
  • the server portion 22b sends (step 232) the determined initial value to
  • the client portion 22a updates (step 236) the identified UI element 46
  • the client portion 22a updates (step 236) those elements 46 with the initial value also.
  • the server portion 22b updates (step 240) the tree structure map 160 with the registration of interest for the property path, received from the client portion 22a, and the determined initial value.
  • the client portion 22a determines (step 244) whether the update ofthe UI element(s) 46
  • the client portion 22a monitors (step 244) the UI elements 46 for user changes.
  • the client portion 22a determines (step 224) whether the user changed the value of an existing UI element 46. If the user does not change the
  • the client portion 22a informs (step 248) the server portion 22b ofthe change. If there are any other
  • the client portion 22a also updates (step 236) those UI elements 46 with the changed value and determines
  • step 244 whether any new UI elements 46 are created as a result ofthe change.
  • the sever portion 22b Upon being informed (step 248) by the client portion 22a, the sever portion 22b attempts to update (step 252), via the property/event interface 90, the value ofthe property 38 ofthe application component 34 affected by the user change (i.e., the property 38 at the end ofthe property path associated with the user-interface element 46 the user changed).
  • the application Upon being informed (step 248) by the client portion 22a, the sever portion 22b attempts to update (step 252), via the property/event interface 90, the value ofthe property 38 ofthe application component 34 affected by the user change (i.e., the property 38 at the end ofthe property path associated with the user-interface element 46 the user changed).
  • step 253 determines (step 253) whether to accept the change or to veto the change. If the application
  • the application 26 changes the state (e.g., value) ofthe property 38 as requested by the server portion 22b and generates a change event.
  • the server portion 22b receives the change event and determines (step 260) whether the change corresponds to a
  • the server portion 22b inhibits sending a change event to the client portion 22a for the changed property 38, because the client portion 22a originated the change. If the application 26 does not accept the change (e.g., vetoes the change), the server portion
  • step 254 a special change message to change the value ofthe property path, as displayed on the UI 42, back to the original (i.e., pre-user modification) value.
  • portion 22b continues by sending (step 232) the change message with the original value back to the client portion 22a.
  • the server portion 22b continues to monitor (step 256) the properties corresponding to the tree structure map 160. If a state (e.g.,
  • the server portion 22b determines (step 260) whether the change corresponds to a property path in which the client portion 22a has interest. If the server portion
  • step 260 the changed state ofthe property does not correspond to a registered
  • the server portion 22b continues to monitor (step 256) the states of properties
  • the server portion 22b determines (step 260) the changed state ofthe property does correspond to a registered property path, the server portion 22b generates and sends (step 232) to the client portion 22a a change event for the corresponding
  • the client portion 22a updates (step 236) any UI elements 46 associated with the
  • the property connector API 22 also can be configured to provide additional features. For example,
  • the client node 64 and/or page interface 112 e.g., browser
  • the client node 64 and/or page interface 112 is unable to run the client portion 22a or support some or all ofthe UI elements 46
  • the property connector API 22 can generate a
  • the proxy process can execute on the server node 60, or on another
  • server node 60' (not shown) logically located between the client node 64 and the server node 60 executing the application 26.
  • the proxy process acts as a client portion 22a in as far as communications with the server portion 22b, and acts as a standard server process, using an
  • a system 54' includes a client node 64' that has an older version of a Web
  • the proxy process receives the
  • the converted static page 42' includes traditional
  • the client node 64' requests a new page 42'
  • the proxy process interprets this as a click on a portion ofthe interactive page 42, and if this results in a change to a state of a property, the proxy process sends the change to the state ofthe property to the server portion 22b. The proxy process then
  • FIG. 8 depicts an embodiment ofthe server portion 22b' ofthe property connector API 22 configured to provide an additional feature of executing an extension 270.
  • the server portion 22b' includes a first property path manager 86a, a first property/event interface 90a, a second
  • extension 270 property/event interface 90b, the extension 270 and an extension manager 274.
  • extension manager 274 The extension
  • extension 270 is a process that augments the application 26, becomes an 'extension' ofthe application 26.
  • Two exemplary extensions are a page extension and a form extension. To the client portion 22a, the extension 270 acts like a part of he application 26. To the application 26,
  • the extension 270 acts like part ofthe client portion 22a.
  • the extension manager 274 includes a
  • An exemplary request command for a page extension is
  • server node 60 In accordance with the parameters ofthe command, the server portion 22b of the server portion 22b of the server portion 22b of the server portion 22b of the server portion 22b
  • extension 270 initializes the extension 270 with the values ⁇ pp.Employee[]' and 10.
  • the extension 270 registers interest in the App.Employee[] property path with the property path manager 86b, and is
  • the Page View extension 270 provides an indexed property Page[i], which is an indexed
  • Each Page object 278 provides an indexed property 'Item[j]', which is an indexed property of items on the current page 42.
  • the Page View extension 270 allows the App.Employee property to be accessed via a number of pages 42a to 42i, where i
  • the Page View extension 270 also provides other properties such as NoPages, CurrentPage, NextPage, LastPage, and the like,
  • the form extension provides a means for 'batch processing' of application data.
  • the form extension allows transactional input to an application 26. For example, a user may fill in a form 42a (not shown) displayed in a UI 42 and then cancel
  • the client portion 22a creates a form 42a by a call to
  • the 'String id' parameter includes the name of
  • the extension e.g. 'myform'
  • the 'String type' parameter includes the type ofthe extension, which for a form extension, is in the format 'Form'.
  • 'String args' parameter includes an optional argument string.
  • the format is one of " (i.e., null), 'snapshot', 'weakchanges' or 'snapshot, weakchanges'.
  • the form extension 270 is configured to accept several methods.
  • One method is 'submitO',
  • the call to create a form 42a is usually made in a script type UI element to ensure that the
  • form 42a is initialized before UI elements 46 using the form 42a are displayed.
  • the form 42a is global and may be used anywhere on the page 42, not just inside the script UI element 46.
  • An exemplary code used to create a fonn 42a is as follows:
  • the client portion 22a invokes a Session.Form.submit() method.
  • the client portion 22a invokes a Session.Form.submit() method.
  • client portion 22a invokes a 'Session.Form.submit()' when the user clicks on a UI element button labeled submit.
  • client portion 22a invokes a Session.Form.cancel() method, in which case nothing will change.
  • the form extension 270 works by acting as a filter over other properties 38. For example a
  • form 42a can be identified as 'Session.Form'. For example, this form 42a displays values
  • UI elements 46 correspond to a form 42a, as the properties 38 are associated dynamically as they are referred to by UI elements 46 within the page 42.
  • a form 42a is connected and set to preservesChanges. That is, if an application
  • the form 42a reflects the change unless the user has already changed the value. This also means that if the page 42 wishes to display new values in the form 42a, then this will happen automatically (e.g., iterator type UI elements 78b or
  • the form 42a can be set to different modes.
  • the form 42a may optionally be set to 'snapshot' mode, where it is unconnected and all values will be
  • the form 42a may also be optionally set to 'weakchanges' mode, where changes to values from the
  • data is not batched and sent to the server node 60 all at once.
  • the updates can be transmitted to the application sequentially, or in a random order.
  • the application 26 reacts to the data as if it were entered all at the same time, due to the
  • the invention also can be practiced over any other type of network (e.g., telephone, cable, LAN, WAN, wireless, fiber), within the same physical computer

Abstract

The invention relates to a system for creating a user-interface independently of an application with which the user interface interacts, wherein the application includes a plurality of components and at least one component (34) contains a property (38), wherein each property is identified with an identifier. The system includes a property connector module (22) to insert at least one element (46) into the user-interface (42), and to associate at least one property path with one inserted element (46), the property path including a concatenation of a plurality of identifiers, the concatenation of identifiers defining a path through the components (34) of the application to a property (38) at the end of the concatenation. A client node can include the user interface having one or more elements, and a client portion (22a) of the property connector module. A server node can include the application, and a server portion (22b) of the property connector module.

Description

METHODS AND APPARATUS FOR CREATING A USER INTERFACE
USING PROPERTY PATHS
Cross-Reference to Related Applications This application claims the benefit of and priority to the co-pending U.S. Provisional Application, Serial No. 60/254,995, filed December 12, 2000, entitled "Methods And Apparatus For Interactive Thin-Client Applications Using Property Paths," the entirety of which is
incorporated herein by reference. This application also claims the benefit of and priority to the
co-pending U.S. Application, Serial No. 09/846,896, filed May 01, 2001, entitled "Methods And Apparatus For Communicating Changes Between A User Interface And An Executing Application Using Property Paths," the entirety of which is incorporated herein by reference. This application also claims the benefit of and priority to the co-pending U.S. Application, Serial
No. 09/846,884, filed May 01, 2001, entitled "Methods And Apparatus For Creating A User
Interface Using Property Paths," the entirety of which is incorporated herein by reference
Field ofthe Invention The present invention relates to client-server networks and, in particular, to methods and
apparatus for creating a user-interface independently of an application with which the user
interface interacts.
Background ofthe Invention Contemporary computer networks consist of a number of computer systems, called nodes, communicating with other computer systems via communication links. Typically, some ofthe nodes are client nodes and other nodes are server nodes. A client node formulates and delivers
queries to a server node. A user ofthe client node enters the queries through a user-interface operating on the client node. The server node evaluates the queries and delivers responses to the
client node for display on the client user-interface.
Usually, the server nodes host a variety of application programs or processes that can be accessed and executed by client nodes. When a client node launches an application program, the execution of that application program can occur at either the client node or the server node,
depending upon the computing model followed by the computer network.
In a client-based computing model, the application program is packaged and sent down to, or pre-installed on, the client node, allowing the client node to run the application using the
resources ofthe client node. This approach has several drawbacks. First, the client node must have sufficient memory, disk space, and processing power to effectively execute the application.
A related problem that occurs using this model is that the number of applications a given client is
able to execute is limited due to client resource constraints. Further, applications built this way are complex to develop and maintain and typically require modification or "porting" for all supported client computer system types. Moreover, this technique exacerbates the administration burden on a network administrator.
In a server-based computing model, the server node executes the application program, and
only the control information for the client user-interface is transmitted across the computer network to the client node for display. Using this approach, user-interface events must be sent between the client and the server in order for the server application to process the events. This
may result in perceived delays of user-interface response. Further, the application program must
be specifically written, or changed, to support the user-interface on the client node. This
increases the complexity of he application and prevents this technique from being useful with off-the-shelf applications. A refinement ofthe server-based model is to supplant the device driver to which the application communicates in order to send screen and device updates back and forth between the
client and the server. This approach avoids requiring applications to be rewritten. However, this approach requires device information to be sent between the client and the server in order to
maintain the client display, again introducing perceived latency into the interface. Further, server-side processing requirements are increased in order to satisfy resulting device information required for communication with each connected client.
A recent, further refinement ofthe server-based model is to deploy the user-interface portion
ofthe application as a mark-up language document such as Hyper Text Markup Language
(HTML) document. However in using this approach, information sent from the server application to the client begins to "age" immediately. In other words the information may
change on the server but the client would not automatically be notified and updated. Further, with this approach, interactivity requires context switching between pages even to perform
simple tasks.
Standard and emerging approaches to application development for Web application delivery rely on one of two approaches. The first approach is adapting 'page based' application delivery code (e.g., servlets) to more dynamic use (e.g., sequence of servlets). The second approach is wiring user-interface components to server components. The first approach has the advantage of
remaining Web-centric and within the skill set of Web developers, but is limited by its page-
based roots. Generating applications with a user-interface using several pages (or dialogues) typically requires coordinating the server-side components to generate each page on an individual basis. This coordination becomes very difficult as the number of pages or the number of clients
increases. The second approach, wiring, still requires the application developer to deal with the
dynamic aspects ofthe application, as a developer must wire to existing object instances that the wiring tool knows about. This is typically objects that exist at application start up, or at other
well defined times. The second approach typically requires customized tools to perform all
aspects of UI design, including layout and formatting.
Summary ofthe Invention
The present invention avoids these shortcomings. The present invention provides a mechanism by which the user-interface portion ofthe application can be delivered to the
computer user either on the same machine on which the application is executing or on another
machine remote from the machine executing the application. The invention separates the user- interface from the underlying application enabling the design ofthe user interactive portion ofthe
application to be relatively straightforward.
The invention also permits the user interactive portion to be deployed on a wide range of
client hardware environments without bringing with it all the required logic for performing the
functionality of a particular application. These features give the user the effect of directly interacting with the application even though the application is potentially running somewhere
else. User-interface, event handling and screen rendering logic stay on the client, thus
dramatically reducing network traffic and latency. The invention also allows the user-interface
portion to be connected with objects that do not currently exist, but may exist in the future. This
makes it easier to specify connections. The invention connects the user-interface to objects using property paths. Property paths represent abstract paths and this abstract quality allows the UI to
be coimected to objects that may exist in the future but that do not exist at application startup or
any other well defined point in time.
In one aspect the invention relates to a method of associating an element of a user- interface to a current state of a property in a system including an application having a plurality of
components, wherein at least one component has a property, wherein each property is identified with an identifier. The method comprises associating the element ofthe user-interface with a
property path, the property path including a concatenation of a plurality of identifiers, the
concatenation of identifiers defining a path through the components ofthe application to a property at the end ofthe concatenation, and mapping the property path to a current state ofthe
property at the end ofthe path defined by the concatenation of identifiers, to associate the
element ofthe user-interface with the current state of that property. In another embodiment, the method includes a) examining each identifier in the concatenation ofthe property path in succession, b) determining, for the first identifier in the concatenation ofthe property path, a second state of a property with a name identical to the first identifier, a component ofthe
application containing that property becoming a root application component; c) identifying, for
the first identifier, a component ofthe application to which the second state points as a current application component, d) mapping the first identifier to the second state, e) determining for the next identifier in the concatenation ofthe property path, a next state of a property with a name
identical to the next identifier located within the current application component, f) identifying,
for the next identifier, a component ofthe application to which the next state points as a current
application component, g) mapping the next identifier to the next state, and h) repeating steps e, f and g until the last identifier ofthe concatenation is examined to map the property path to the
current state ofthe property with a name identical to the last identifier. In another embodiment,
the method includes mapping the property path to an undefined state if no property is found that
corresponds to an identifier in the plurality of identifiers in the concatenation.
In another embodiment, the method includes generating a node tree having a plurality of nodes, wherein each node ofthe node tree represents a mapping of an identifier to one of, a state
of a property and an undefined state. In another embodiment, the node tree represents a plurality
of property paths. In another embodiment, the method includes monitoring a plurality of states within the application to detect a change in one ofthe states ofthe plurality of states, each state
in the plurality corresponding to one of he states mapped to an identifier in the concatenation of
the property path. In another embodiment, the method includes receiving a property change event
from a JANABEAN-compatible component.
In another embodiment, the method includes re-mapping the property path to a new current state in response to detecting the change in one ofthe states ofthe plurality of states. In another embodiment, the method includes re-mapping the identifier the concatenation of
identifiers to the changed state in response to detecting the change in one ofthe states ofthe
plurality of states. In another embodiment, the method includes generating a property change
message in response to a change in a state of a property corresponding to one ofthe identifiers in the concatenation ofthe property path. In another embodiment, the method includes updating one or more user-interface elements associated with the property path with a new current state in
response to a change in the current state ofthe property.
In another embodiment, the method includes, a) detecting a change in one of a plurality of states in an application, each state in the plurality corresponding to one ofthe states mapped to an identifier in the concatenation ofthe property path, b) examining each identifier in the concatenation ofthe property path in succession, starting with an identifier corresponding to the
changed one ofthe states ofthe plurality of states, c) determining for a currently examined
identifier, a new next state of a property with a name identical to the currently examined
identifier, d) re-mapping the currently examined identifier to the new next state in response to a change in a currently mapped state, and e) repeating steps c and d for each subsequent identifier in the concatenation of identifiers. In another embodiment, the method includes terminating the
repeating in response to the new next state being identical to a state currently mapped for that
currently examined identifier. In another embodiment, the method includes monitoring a new plurality of states within the application, the new plurality including the new next states mapped
to an identifier in the concatenation ofthe property path.
In another embodiment, wherein the property path is a first property path and the concatenation of identifiers includes a wildcard identifier, the method includes mapping a second
property path to a first value, and determining a second value for the wildcard identifier in
response to the first value mapped to the second property path. In another embodiment, the
method includes determining the second value such that replacing the wildcard identifier ofthe first property path with the second value causes the current state mapped to the first property path with the replaced wildcard identifier to be equal to the value mapped to the second property path.
In another embodiment, the method includes dynamically binding the property path to one ofthe
application components including the property corresponding to the current state mapped to that
property path.
In another embodiment, the method includes transmitting to the application a request to update the current state ofthe property mapped to the property path associated with the element ofthe user-interface in response to a user modification ofthe value. In another embodiment, the
method includes inhibiting a property change message in response to the application updating the
current state ofthe property in response to the request to update. In another embodiment, wherein the user interface comprises an exemplary element associated with a property path including a wildcard identifier, the wildcard identifier corresponding to an indexed property including an index value range from a minimum value to a maximum value, the method includes generating
an additional element for each index value ofthe indexed property from the minimum value to
the maximum value by copying the given element associated with the property path, and associating a new property path with each additional element. In another embodiment, the
method includes replacing the wildcard identifier associated with the given element with the corresponding index value ofthe additional element to define the new property path. In another embodiment, the method includes registering interest in the property path. In another
embodiment, the method includes mapping one ofthe identifiers in the concatenation ofthe property path to a state of a property corresponding to the one ofthe identifiers.
In another embodiment, the invention relates to a system for associating an element of a user-interface to a current state of a property of an application, wherein the application has a
plurality of components, at least one component having a property and each property is identified
with an identifier. The system includes a property connector module to identify an association
between the element ofthe user-interface and a property path, the property path including a
concatenation of a plurality of identifiers, the concatenation of identifiers defining a path through the components ofthe application to a property at the end ofthe concatenation, and to map the
property path to a current state ofthe property at the end ofthe path defined by the concatenation
of identifiers, thereby associating the element ofthe user-interface with the current state of that
property. In another embodiment, the system includes a client node. The client node includes the user interface having one or more elements, and a client portion ofthe property connector
module. In another embodiment, the system includes a server node. The server node includes
the application, and a server portion ofthe property connector module.
In another aspect, the invention relates to a method for creating a user-interface
independently of an application with which the user interface interacts, wherein the application
includes a plurality of components and at least one component contains a property, wherein each property is identified with an identifier. The method includes inserting at least one element into the user-interface, and associating at least one property path with one inserted element, the
property path including a concatenation of a plurality of identifiers, the concatenation of
identifiers defining a path through the components ofthe application to a property at the end of the concatenation. In another embodiment, the method includes determining a list of property
paths associated with the application, and selecting the property path from the list to associate
with the one inserted element ofthe user-interface from the list of property paths.
In another embodiment, the method includes receiving a property path description file associated with the application, the property path description file including a plurality of identifiers associated with the application and a relationship between the plurality of identifiers.
In another embodiment, the method includes executing the application, and interacting with the
executing application to determine a plurality of identifiers associated with the application and a
relationship between the plurality of identifiers. In another embodiment, the method includes transmitting a request to register for a property change message corresponding to the property
path associated with the element ofthe user-interface. In another embodiment, the method
includes providing at least one predefined element, and enabling selection from the at least one
predefined element to insert the selected predefined element into the user-interface. In another embodiment, the predefined element comprises one of an image type user-interface element, an iterator type user-interface element, a text type user-interface element, a hidden type user-
interface element, a value type user-interface element, a slider type user-interface element, a
treeview type user-interface element, a button type user-interface element, an iframe type user-
interface element, a tab type user-interface element, a flipflop type user-interface element, a deck
type user-interface element, a dropdown type user-interface element, a radio type user-interface element, and a script type user-interface element.
In another aspect, the invention relates to a system for creating a user-interface independently
of an application with which the user interface interacts, wherein the application includes a plurality of components and at least one component contains a property, wherein each property is identified with an identifier. The system includes a property connector module to insert at least one element into the user-interface, and to associate at least one property path with one inserted element, the property path including a concatenation of a plurality of identifiers, the
concatenation of identifiers defining a path through the components ofthe application to a
property at the end ofthe concatenation. In another embodiment, the system includes a client
node. The client node includes the user interface having one or more elements, and a client
portion ofthe property connector module. In another embodiment, the system includes a server node. The server node includes the application, and a server portion ofthe property connector
module.
In another aspect, the invention relates to a method using a system having an application
comprising one or more objects, with at least one object including one or more properties. The
method associates a user-interface element, which is independent ofthe application, with a property ofthe application. The method includes executing a process that is independent ofthe application; representing a property ofthe application by a property path and associating, by the
application-independent process, the user-interface element with the property path. This
associates the user-interface element with the property ofthe independent application. In one
embodiment, the method determines whether a property of an object ofthe application exists that corresponds to the property path. In another embodiment, the determining process includes employing a value of a second property corresponding to a second property path (e.g., cross-
mapping).
In another embodiment, the method includes monitoring a state ofthe property and detecting
a change in the state ofthe property. In another embodiment, the process of detecting includes receiving a property change event from an API of a JANABEAN™ compatible component. In another embodiment, the method includes updating the user-interface element in response to detecting the change in the state ofthe property. In another embodiment, the method includes generating a property change message in response to detecting the change in the state ofthe
represented property. In another embodiment, the method includes registering for a property
change message for the property represented by the property path. In another embodiment, the
method includes detecting a change in a state of one or more properties along the property path, and responding to a detected change in a value that the property path represents.
In another embodiment, the method includes determining at least one property path
associated with the application and selecting the property path to associate with the user-interface
element from at least one determined property path. In another embodiment the process of
determining at least one property path includes traversing from a root object ofthe application to a corresponding property, using object pointers. In another embodiment, this includes mapping the traversal from a root object ofthe application to the corresponding property. In another
embodiment, the process of mapping includes generating a node tree. In another embodiment,
the method includes indicating which nodes in the node tree correspond to a property path that
the client has registered interest in. In another embodiment, the method includes dynamically binding the property path to the object containing the represented property.
In another embodiment, the method includes allowing a user to modify a value associated with the user-interface element and updating the property ofthe application represented by the
property path associated with the user-interface element in response to a user modification ofthe value associated with the user-interface element. In another embodiment, the method includes inhibiting a property change message in response to updating the property ofthe application in response to the user modification.
In another aspect, the invention relates to a method using a server node having an application
comprising a plurality of objects, with each object including one or more properties, the method indicating a property ofthe application to monitor. The method includes executing a process that is independent ofthe application, representing a property ofthe application by a property path
and receiving, by the application-independent process, a request to register for a property change
message associated with a property path to indicate the property ofthe independent application to monitor. In one embodiment, this method includes determining whether a property of an object ofthe application exists that corresponds to the property path. In another embodiment, the
process of determining includes employing a value of a second property corresponding to a
second property path (e.g., cross-mapping).
In another embodiment, the method includes monitoring a state ofthe property and detecting
a change in the state ofthe property. In another embodiment, the process of detecting includes receiving a property change event from an API of a JANABEAN™ compatible component. In
another embodiment, the method includes transmitting the changed state in response to detecting the change in the state ofthe property. In another embodiment, the method includes generating a property change message in response to detecting the change in the state ofthe property. In
another embodiment, the method includes registering the property change message ofthe request for the property represented by the property path.
In another embodiment, the method includes determining at least one property path
associated with the application. In another embodiment, the process of determining at least one property path includes traversing from a root object ofthe application to a corresponding
property by using object pointers. In another embodiment, the method includes mapping the
traversal from a root object ofthe application to the corresponding property. In another
embodiment the process of mapping includes generating a node tree. In another embodiment, the method includes indicating which nodes in the node tree correspond to a property path the client has registered interest in. In another embodiment, the method includes dynamically binding the property path to the object containing the represented property. In another aspect, the invention relates to a method using a client node having a user-
interface, including one or more elements, that is independent of an application, the method
creating a user-interface element. The method includes executing a process independent ofthe
application, employing an element ofthe user-interface, representing a property ofthe
application by a property path and selecting, with the application-independent process, the property path or paths to associate with the user-interface element. In one embodiment, the
method includes transmitting a request to register for a property change message associated with the selected property path.
In another embodiment, the method includes receiving the property change message in response to a change in a state ofthe property represented by the property path. In another
embodiment, the method includes updating the user-interface element in response to notification ofthe change in the state ofthe property. In another embodiment, the method includes receiving
at least one property path associated with the application. In another embodiment, the method
includes allowing a user to modify a value associated with the user-interface element and
transmitting the modified value and the associated property path. In another embodiment, the method includes inhibiting a property change message in response to transmitting the modified value associated with the user-interface element.
In another aspect, the process of employing an element includes providing to the user at least
one predefined element for the user-interface, enabling the user to select from at least one predefined element for the user-interface and employing the selected predefined element. In another embodiment, the predefined element includes one or more ofthe following: displaying a property value as a piece of text, allowing the displayed property value to be edited, enabling a
button that may be disabled based on the property value, vertical and horizontal sliders for
numeric properties, displaying an image dependent on a property value, displaying an embedded frame dependent on a property value, an anchor dependent on a property value, ability to hide or
show part ofthe UI dependent on a property and expression and the ability to change the style of
part of a UI dependent on a property and expression. In another embodiment, the predefined
element includes one or more ofthe following: selections of displaying one of a 'deck' of UI fragments dependent on a property value, a dropdown menu where each choice is a value from
an range of indexed properties, one tab per member of a range of indexed properties, a set of
radio buttons, a treeview based on property paths and the ability to repeat part of a UI once for
each member of a range of indexed properties.
Some objects of this invention are as follows: to allow simple UI development for
developers with little or no programming experience; to allow strong separation between application and UI development; to allow separation of UI static and dynamic aspects; to have
low bandwidth and latency-tolerance communications; to allow device-clients to be tailored to
the devices' capabilities; to require only a small learning curve for application and UI developers;
and to allow for scalable servers. To accomplish some of these objects, the invention includes a system for providing rich /
highly interactive client interfaces to applications running on a centralized server (or servers). A
key part ofthe system is that the interface between client and server is highly abstract and it can function with both other client types (other Web browsers and device specific clients) and other
server types (e.g., COM). The system uses a 'loose' coupling mechanism, which allows the server-side application to
be designed with little regard for the user-interface. By maintaining this strong separation it is possible for a user-interface to be completely redesigned without access to the application code, or the infi-astmcture-supporting it. For example a third party could generate a user-interface for a 'published' application without any access to the application code or runtime environment. The system also allows one application and the server on which it is located to be used with many
different types of user-interfaces. New client types may be designed and deployed without touching the server code. A third party could design a new client type without the server's
involvement. The user-interface for a particular application can be changed or ported to a new
device without having to even stop the server application, let alone redesign or rebuild it. This is
the 'number one want' on a recent survey of Web application designers. The user-interface can be tuned or given a new look and feel without disrupting the function ofthe application. This
may be done using standard tools. As the user-interface is strongly separated from the server, different user-interfaces can be developed for different device capabilities. There is no intention
that user-interfaces on difference clients should look identical. This simply makes it much easier to develop a client 'player' for a new device
The system takes advantage ofthe fact that most user-interfaces are essentially static. A large portion of a user-interface does not change at all. A typical example is a form. The form
itself is not modified during execution, but only the values that appear in the fields ofthe form.
The dynamic aspect of a user-interface generally consists of changes to the static page 'template'
such as filling in fields, changing text values and a navigation through a number of dialogs or
pages under the control ofthe user and/or the application. For a Web-client, the static aspects of a user-interface generation, and the navigation aspects (under user control) are already well
understood by users and developers alike. Rather than replace these with different notions, the
invention keeps standard Web-metaphors. The invention adds only the ability to fill in a page template dynamically.
By keeping the interface between application and user-interface very small, and by separating the static and dynamic aspects of a UI, the invention allows the static aspect of a user- interface to be developed using standard UI development tools. These tools can be extended (or additional tools provided) to add the dynamic aspect ofthe UI. Because ofthe approach taken to
the static/dynamic split, this is extremely straightforward for the UI developer. A unique aspect
that the system brings to UI technology is the way in which dynamic aspects ofthe application
(e.g., creation of new objects, changes in values) may be reflected in a static user-interface by linking UI elements.
The foregoing and other objects, features and advantages ofthe invention will be apparent from the following more particular description ofthe embodiments ofthe invention, as illustrated
in the accompanying drawings.
Brief Description ofthe Drawings Other objects, features and advantages will occur to those skilled in the art from the following description of a preferred embodiment and the accompanying drawings, in which:
FIG. 1 is a block diagram of an embodiment of property path associations constructed in
accordance with the invention;
FIG. 2 is a block diagram of an embodiment ofthe sub-components ofthe property connector API of FIG. 1 constructed in accordance with the invention;
FIG. 3 is a block diagram of another embodiment ofthe system architecture ofthe invention;
FIG. 4 is a screenshot of a UI development application that is being executed in combination
with an embodiment ofthe client portion ofthe invention;
FIG. 5 is a screenshot of a UI application illustrating an embodiment ofthe invention during
execution;
FIG. 6 is a block diagram of an embodiment ofthe mapping of registered property paths of
the invention;
FIG. 7 is a flow diagram of an embodiment of client and server interaction constructed in
accordance with the invention; and FIG. 8 is a block diagram of another embodiment ofthe server portion with an extension feature according to the invention
Detailed Description ofthe Invention
FIG. 1 depicts a block diagram of an embodiment of a system 10 for communicating
changes between a user-interface and an executing application, using property paths. The system
10 includes a server process 14, a client process 18 and a property connector API 22. The server process 14, the client process 18 and the property connector API 22 can be located on a single computing device or distributed among several computing devices. The server process 14
includes an application 26 with application components 34a, 34b, 34c and 34d (generally 34). In this embodiment, the application components 34a, 34b, 34c and 34d are instances of objects that
the application 26 generates.
Each ofthe application components 34a, 34b, 34c and 34d includes zero or more properties
38a, 38b, 38c, 38d, 38e and 38f (generally 38). This embodiment includes two types of properties. A first type of properties 38, for example, 38d, 38e and 38f, have a value for a
specific variable. A second type of properties 38, for example, 38a, 38b and 38c, have a pointer
to another application component 34 (e.g., object, class), thus this second type of property 38 represents a composite of additional application components 34 and their properties 38. In other embodiments, application components 34 can be generated by a process using a data file. For
example, application components 34 can be representations of nodes within a structured data file,
such as XML or a database, where the properties 38 are attributes specified in the structured file
or associated document type definition ("DTD") (i.e., a specific definition that follows the rules ofthe Standard Generalized Markup Language). In another embodiment, the application components 34 support additional standard properties 38 such as 'parent', 'child[i]\ and the like. Many applications 26 are object-oriented and as such, generate a structured relationship
between the objects 34. The structured relationship can be illustrated as a node tree. The root node is the first object ofthe application and each object that the root object points to becomes a
child node. Each object that the child node points to becomes a grandchild node and so on. For
example, object 34a represents a root node. Objects 34b and 34c are children nodes ofthe root node 34a. Object 34d is the child node of object 34c and the grandchild node of object 34a.
Each part ofthe application 26 state (i.e., values of application component properties 38 at a particular instant in time) is accessible via a traversal of a 'path' from one or more root objects to
the state of a property itself by following object pointers (e.g., properties 38a, 38b, 38c). This path taken by the traversal ofthe structured relationship is a property path, also referred to as a
pathname, and is described in more detail below. An object and/or property may be addressable by several 'paths' from the root node, for example, an object representing an Employee may be
accessible as 'the current employee' (root->current), the 10l employee in an index (root->index- >item 10), the manager of some other employee (root-> ... ->manager) and the like. These paths
correspond to different concepts that happen to have the same object as their current value.
Some models for application development (e.g., JANABEANS™ component architecture by
Sun Microsystems, Inc. of Palo Alto, CA and ACTIVEX™ platform by Microsoft Corporation,
Redmond, WA) provide a link between the application components 34 of an application 26 by
using a property-based link. A property-based link is an object pointer that is accessible via a standard means (e.g., 'get' and 'set' methods). Applications 26 using property-based links undertake to inform the server process 14 about changes in the property-based link using, for
example, property change events.
The client process 18 produces a user-interface ("UI") 42 that is displayed to a user. The UI 42 includes one or more user-interface elements 46a and 46b (generally 46). The UI 42 can be, for example, a Web page, an HTML document, a custom UI and the like. Though the UI is
generally hereinafter referred to as a page 42, this should be without loss of generality as the UI
42 can be displayed on a non- Web client using a native language. The UI elements 46 are
associated with one or more values 50a, 50b, 50c (generally 50) that the UI elements 46 display or make decisions in response thereto. The user-interface element 46 is a portion ofthe UI 42
that dynamically changes and is associated with a state of property 38 of an application
component 34. As described in more detail with FIG. 4, a user ofthe page 42 associates each of
the UI elements 46 to the one or more properties 38 of an application component 34 by indicating one or more property paths. The UI element 46 can be, for example, an input box for textual or numerical input and display of a value of a property 38. The UI element 46 also can be, for
example, a horizontal slider for numerical input and display of a value of a property 38. As
shown, the first user-interface element 46a displays and/or affects a value 50a associated with a state of a property 38 of one ofthe application components 34. The second user-interface element 46b displays and/or affects two values 50b and 50c. Between the application components 34 and the user-interface elements 46 is the property
connector API 22. The property connector API 22 includes a client portion 22a and a server
portion 22b. The property connector API 22, and thus the client portion 22a and the server
portion 22b, is a process that is independent ofthe application 26 (i.e., not a part of nor generated
from the application 26). The property connector API 22 process can be implemented as software, as hardware or as a combination of both. The execution ofthe property connector API 22 can be initiated in several ways. A computing device on which the property comiector API 22
resides can initiate execution ofthe property connector API 22 upon power up or upon a authorized user log-in. The computing device can initiate execution ofthe property connector
API 22 when the computing device downloads a page 42 containing UI elements 46 associated with property paths. The computing device can initiate execution ofthe property connector API
22 when the user initiates execution ofthe application 26 or requests delivery ofthe page 42. In
one embodiment, when the computing device initiates execution ofthe property connector API
22, the computing device also receives a startup argument including the name of a file
containing the UI page 42 details, and details ofthe server node 60 to connect to and the application 26 to start.
As explained in more detail below, the property connector API 22 maps each dynamic user-
interface element 46 to a property 38 of an application component 34 using the associated property path. The property path defines the interaction between the client process 18 and the
server process 14 in terms of properties 38 ofthe application 26 rather than in terms ofthe user-
interface elements 46.
In its mapping, the property connector API 22 represents a property 38 of an application
component 34 within an application 26 as a property path. The property path is the
concatenation of one or more identifiers. An identifier corresponds to a property 38 within an
application component, which can be a value or a pointer. The property path defines a path through the application 26 from a root component 38 to the particular application component 34,
and a property 38 itself of that application component. For example, property 38a points to application component 34c and the property 38c of application component 34c points to
application component 34d that contains property 38d. The property path that corresponds to the
property 38d in this example is 'App.PropertyIDl.PropertyID3.PropertyID4'.
Each part ofthe property path (i.e., App, PropertylDl, PropertyID3, PropertyID4) is an
identifier. The property connector API 22 uses these identifiers to traverse the path in the application 26 defined by the property path. The 'App' identifier identifies the root node. The
'identifies the property 38a within the root component 34a and property 38a points to application component 34c. The property connector API 22 determines the value of 'PropertylDl ' by obtaining the present state (i.e., value) of a property with the same name within the root
component ofthe application 26 identified by 'App'. For example, the property connector API
22 determines the value by using a 'get' method of an API for the application 26. The property
connector API 22 determines the present state points to the application component 34c. Because the value of property corresponding to identifier 'PropertylDl' is component 34c, the
'PropertyID3' identifier identifies the property 38c within the component 34c. The property
connector API 22 determines the value of 'PropertyID3' by obtaining the present state (i.e.., value) ofthe property 38c with the same name within the component 34c, which was identified
using 'PropertylDl ', The property connector API 22 determines the present state points to the application component 34d. Because the value of property corresponding to identifier
'PropertyID3' is component 34d, the 'PropertyID4' identifier identifies the property 38d within the component 34d. The property connector API 22 determines the value of 'PropertyID4' by
obtaining the present state (i.e., value) ofthe property 38d with the same name within the component 34d, which was identified using 'PropertyID3'. Property 38d is not a pointer, but a
number, for example, salary. The property connector API 22 maps the current state of this
property 38d to the property path 'App.PropertyLDl .PropertyID3.PropertyID4'. While mapped, the property path 'App.PropertyIDl.PropertyID3.PropertyID4' has the value ofthe salary of property 38d.
Property paths are not "wired" connections from a user-interface element 46 to the
associated application component 34, but more analogous to a description of what 'type' of data
the user-interface can display and/or affect (i.e., a loosely coupled, flexible connection). This
means that during execution, the application 26 can create or delete application components 38 without any adverse affect on the user-interface elements 46. For example, the property path Αpp.PropertyIDl.PropertyID3.PropertyID4' corresponds, at one point in time, to property 38d,
as stated above. However, if the application 26 changed property 38c, 'PropertyID3', to
subsequently point to application component 34b, instead of application component 34d, the property path 'App.PropertyIDl.PropertyID3.PropertyID4' subsequently corresponds to property
38e, not property 38d. When notified of the change, the property connector API 22 updates the
value 50 ofthe user-interface element 46 associated with the property path
'App.PropertyIDl.PropertyID3.PropertyID4' to reflect the current state of property 38e.
In another example, for a human resources application, the property path to the "salary"
property ofthe twenty-seventh employee in a list of employees of a certain department is ΗRApp.Dept.Employee[26]. Salary' (counting from 0). The property path describes an abstract
property ofthe application 26 as a whole, not a specific property of a particular instantiated object. In other words, if the user-interface element 46 was to be associated with a specific
property, then the path could be simply, for example, 'property 38d'. Then regardless of which components 34 pointed to which other components 34 would not matter, because the property
path would always reflect the state of property 38d. This, however, is not how property paths
work. The property path identifies a path through the application 26 and not one specific
property 38d located in the application 26. The path can change as one ofthe properties 38
corresponding to one ofthe identifiers in the concatenation changes. When a component 34 changes and points to a different component, the property path follows that change and the
property path reflects the state ofthe new property the path now ends at.
Similarly, a property path can also represent a property with a potential to exist, but that does not exist at the present time. For example, if the list of employees only contains twenty-six employees (numbered 0 to 25), the property path ΗRApp.Dept.Employee[26]. Salary' does not correspond to any property. When another employee is added, the property path ΗRApp.Dept.Employee[26]. Salary' would then point to the salary property ofthe twenty-
seventh employee. This example illustrates how property paths can be used to describe
properties that do not exist presently, but can exist in the future, in addition to those properties
that exist only at application startup, or at some other well defined point. In the human resources
application example, this means that as the list of employees change, the actual employee who is twenty-seventh in the list of employees can change, but the property path remains pointing to the salary property ofthe twenty-seventh employee, regardless of who that may be. This method of
using the structured relationship between application components 34 to create a property path is
important in allowing strong separation between UI elements 46 and application components 34. Using this example in connection with FIG. 1, the second value 50c of UI element 46b displays the salary ofthe twenty-seventh employee of a specific department because the value 50c is associated with the property path ΗRApp.Dept.Employee[26]. Salary'. The client portion
22a maps this association between the value 50 and the property path. The server portion 22b
maps the same property path ΗRApp.Dept.Employee[26]. Salary' to the property 38d of application component 34d. To obtain this mapping, the server portion 22b follows the pointers with the application components 34 that correspond to the property path. In one embodiment,
the server portion 22b follows the pointers by using 'get' methods and constructing a structure
tree map l60 (FIG. 6).
The ΗRApp' portion ofthe property path corresponds to the application 26 and the first created application component 34a (i.e., the root application component). The 'Dept' portion of
the property path corresponds to the property 38a that points to the application component 34c, which in this example represents a list of employees ofthe indicated department. The
Εmployee[26]' portion ofthe property path corresponds to the property 38c that points to the application component 34d, which in this example represents information about the twenty- seventh employee. The 'Salary' portion ofthe property path corresponds to the property 38d that
contains a value, which in this example represents the amount ofthe salary ofthe twenty-seventh
employee. The application component 34d can also contain other properties (not shown) that have values representing information about that particular employee, such as name, social security number, date of hire and the like.
As the list of employees for the indicated department changes, the property 38c that pointed
to application component 34d changes and subsequently points to another application component (not shown). In this example, before the change, the application component 34d represented information about the twenty-seventh employee. After the change, the new application
component (not shown) to which the property 38c points now represents the new twenty-seventh
employee. But even with the change, the property path ΗRApp.Dept.Employee[26]. Salary' still
points to the twenty-seventh employee ofthe indicated department and thus the second value 50c of UI element 46b displays the appropriate value ofthe salary ofthe new twenty-seventh employee, whoever that employee may now be.
The following are additional examples of property paths. For example, the property path
'App.CurrentSelection.Price' represents the price property 38 ofthe currently selected item
within a shopping application 26. If no item is selected or the current selection changes, then the value 50 of this property 38 changes, even though the price property 38 of each ofthe individual items 34 (e.g., objects) within the application 26 does not. For another example, the property
path 'App.SelectedEmployee.Boss.Boss.Name' represents the name property 38 ofthe selected
employee's boss's boss. This property path will display the appropriate value 50 even if the
selection changes (e.g., a different employee is selected), if there is a reorganization, or if the boss changes his/her name. In another example, the property path 'App.Employee[21].Name' represents the name property 38 ofthe twenty-second employee in a table. If the table is sorted or changes size, then this property path will correctly reflect the name property 38 ofthe
employee who is, after the revision, currently the twenty-second employee in the table.
FIG. 2 illustrates an exemplary embodiment of a system 54 that includes a first computing
system ("server node") 60 in communication with a second computing system ("client node") 64
over a communication channel 94. For example, the communication channel 94 can be over a local-area network (LAN), such as a company Intranet, or a wide area network (WAN) such as
the Internet or the World Wide Web. The server node 60 includes a server transceiver 108, the
server portion 22b, a property/event interface 90 and the application 26, including one or more
application components 34. The server node 60 can establish communication over the
communication channel 94 using a variety of communication protocols (e.g., ICA, HTTP TCP/IP, IPX, SPX, NetBIOS, Ethernet, RS232, and direct asynchronous connections). As shown, the server portion 22b is a separate process on the server node 60. In other embodiments,
the server portion 22b, or portions thereof, is located on a server node (not shown) separate from
the application program 26. In another embodiment, the property/event interface 90 is included
as part ofthe server portion 22b.
The client node 64 includes a client transceiver 104 and an optional page interface 112. The
page interface 112 includes the client portion 22a and generates (or edits) a page '42, containing
dynamic UI elements 46. The client node 64 can be any computing device (e.g., a personal
computer, set top box, phone, handheld device, kiosk, etc) used to provide a user-interface 42.
The client node 64 can be connected to the communication channel 94 through a variety of connections including standard telephone lines, LAN or WAN links (e.g., TI, T3, 56kb, X.25), broadband connections (ISDN, Frame Relay, ATM), and wireless connections. As shown, the client portion 22a is part ofthe page interface 112. The page interface 112 can be, for example, a
Web browser (e.g., a MICROSOFT™ INTERNET EXPLORER browser manufactured by Microsoft Corporation of Redmond, WA and/or a NETSCAPE™ NAVIGATOR browser,
manufactured by Netscape Communications Corporation of Mountain View, CA). In another
embodiment, for example, one without a page interface 112, the client portion 22a is a separate process on the client node 64.
In other embodiments, interaction between the client node 64 and the server node 60 occurs if the application 26 is executing and the user is interacting, via the page 42, with the application
26 (i.e., run time). If the user is creating a page 42 (i.e., build time), then there is no interaction
between the client node 64 and the server node 60. For example, the user creates a page 42 using
the page interface 112 (e.g., HTML editor, DREAMWEAVER™ software by Macromedia, Inc.
of San Francisco, CA), as described in more detail with relation to FIG. 4. The user locates UI elements 46 using the page interface 112. In one embodiment, the user selects a UI element 46
from a set of predefined UI elements 78 (FIG. 3). The user associates a property path with the
selected UI element 46. In one embodiment, a property file has the following form:
— start property file — // List of types used in this property files (identifiers)
// String and Number are built in Types: Person Company
// Identify the type ofthe root object RootType: Company
// List the properties. Ofthe format // <type of obj ect>.<name of property> <type of property>
// or
// <type of object>.<name of property>[] <type of property>
// (for indexed properties)
// A RW on the end ofthe line indicates they property is read/write //
// May contain multiple entries for a certain object, property pair
// if the property can have several types.
// Any property may also be undefined
Properties: Company .Name String Company.Boss Person Company. StaffQ Person Company.EBWQ Person Company. SalaryTotal Number Person.Name String Person. Salary Number RW Person.ID String Person.Boss Person Person. Staff[] Person
// List of methods that may be called from the client // in format <object type>.<method name>(<argument type...>) Methods:
// Hire someone given name, id, salary, boss App.Hire(String, String, Number, Person)
// Fire someone Person.Fire() — end property file —
In another embodiment, the property file has the following form:
— start property file —
RootType: Company Company .Name String
Company.Boss Person
Company. Staff[] Person
Company.EBWQ Person
Company. SalaryTotal Number Person.Name String
PersomSalary Number RW
Person.ID String
Person.Boss Person
Person. Staff[] Person App.Hire(String, String, Number, Person)
Person.FireQ
— end property file —
In one embodiment, the property file containing property paths is stored on the client node
64 for the page interface 112 to access. The property file can contain the types of application
components 34 that the application 26 creates and the type of properties 38 that each ofthe type of application components 34 contains. The property file can also contain information regarding
the structured relationship between application components 34 and/or the children application
components 34 of each type of application component 34. The file can be manually created and/or manually augmented.
In other embodiments, the page interface 112 and/or the client portion 22a has a property browser. In one embodiment, the browser may examine the code ofthe application 26 (e.g.,
JAVA™ compatible classes or source code) and determine possible property paths by examining
the type ofthe get/set property methods. In another embodiment the property browser
temporarily communicates with the server node 60 and initiates execution ofthe application 26. Upon execution, the property browser can obtain the instantaneous values of available application components 34, their properties 38 and the relationship (e.g., child nodes) between the application components 34. After this information is obtained, the execution ofthe
application 26 and communication between the client node 64 and server node are terminated.
The property browser can save the obtained results in the property file. FIG. 3 depicts the client portion 22a and the server portion 22b ofthe property connector
API 22 in more detail. The client portion 22a includes a protocol module 70 and an event manager 74. In another embodiment, the protocol module 70 is located within the client
transceiver 104 (e.g., FIG. 2). As shown, the client portion 22b also includes an optional
predefined UI elements portion 78, which contains data to generate specific types of UI elements 46, identified in detail below, in connection with FIG. 4. The client portion 22a communicates with the UI elements 46 ofthe page 42.
The server portion 22b includes a protocol module 82 and a property path manager 86. In
another embodiment, the protocol module 82 is located within the server transceiver 108 (e.g.,
FIG. 2). The server portion 22b is in communication with the application components 34 ofthe application 26 through a property/event interface 90. The client portion 22a and the server
portion 22b communicate with each other over the communication channel 94, using a property path protocol as described below. In another embodiment, as shown in FIG. 1, the client portion
22a and the server portion 22b are located on the same machine and are directly connected to each other.
The property connector API 22 associates the user-interface elements 46 with the application
components 34 using property paths as described above. In overview, the functions ofthe property connector API 22 can include:
(1) collecting and disseminating change events, (a) for the user-interface elements 46
associated with the properties 38, (b) between the user-interface elements 46 and the
server node 60;
(2) communicating change events of particular properties 54 between the client node 64 and the server node 60, and tracking those change events about which the client node 64 needs to be informed;
(3) dynamically binding property paths to specific application components 34 (e.g., objects)
within the application 26, reacting to changes in application components 34 along the
property path, and rebuilding the path as appropriate when instances of application components 34 are created or deleted; and (4) collecting events from, and communicating property changes to, individual application
components 34.
Anyone one or a combination of any of these functions can be performed by the event manager 74, the property path manager 86, the property/event interface 90 and the protocol modules 70
and 82. During operation ofthe system 54, the server node 60 executes the application 26 and instantiates the application components 34 (e.g., objects). In one embodiment, for example, the
application 26 is written in JAVA™ compatible source code, the application components 34 are
JAVABEANS™ compatible components and the property/event interface 90 includes a
JAVABEANS™ compatible API. If not already executing, the server node 60 also executes the
server portion 22b, which is independent ofthe application 26 (i.e., not a part of nor generated from the application 26). The server node 60 executes the server portion 22b in response to the
client node 64 requesting execution ofthe application 26 and/or in response to the client node 64
requesting the page 42 associated with the application 26. If not already executing, the client
node 64 executes the client portion 22a, which is independent ofthe application 26 (i.e., not a
part of nor generated from the application 26). In one embodiment, for example, the event manager 74 ofthe client portion 22a is written as a set of JAVASCRIPT™ files for a
MICROSOFT™ INTERNET EXPLORER browser manufactured by Microsoft Corporation of
Redmond, WA and/or a NETSCAPE™ NAVIGATOR browser, manufactured by Netscape Communications Corporation of Mountain View, CA. The client node 64 executes the client portion 22a in response to a user requesting execution ofthe application 26 and/or in response to
the user requesting the page 42 associated with the application 26.
The client-side event manager 74 maps the UI elements 46 to the associated property paths. The event manager 74 maintains a database ofthe mapping of UI elements 46 to property paths.
The event manager 74 may or may not examine the individual identifiers in the concatenation of a property path. This affects the amount of information that has to be transmitted between the
client portion 22a and the server portion 22b. In one embodiment, the event manager 74 treats
property paths as opaque names. In this embodiment, the event manager 74 does not breakup or examine the individual identifiers in the concatenation of a property path, but instead treats the property path as a single, long variable name or as a placeholder. This allows a compression
algorithm in the protocol between the client portion 22a and the server portion 22b that replaces
each property path in the page 42 with a single id (e.g., $1). In this embodiment, there is a dictionary (not shown) on the server node 60 so the sever portion 22b can lookup each id and
convert the id into a property path prior to accessing the corresponding property. In this
embodiment, the server portion 22b must track all changes to any ofthe properties corresponding
to identifiers in the property path and determine how those changes affect the value ofthe one or
more property paths including the identifier. The server portion 22b also only communicates changes to the client portion 22a in terms of complete property paths. In another embodiment, the client portion does examine changes corresponding to each
individual identifier in the property path and can determine itself how a change to a property
corresponding to a single identifier affects one or more property paths including that identifier. In one embodiment, for example, a copy ofthe property path manager 86 is located on the client
node 64 and sends all changes (rather than just the changes in leaf values) in a tree structure 160 (FIG. 6) between the client portion 22a and the server portion 22b. This embodiment adds
complexity to the system 54, but may give bandwidth/performance gains, because the server
node 22b can communicate changes to the client portion 22a in terms of individual identifiers.
For example, consider an indexed property A with A[0]=X, A[1]=Y and A[2]=Z and each of X, Y, and Z application components 34 with three properties 38 a, b, and c. If the table is resorted
so that A[0]=Y A[1]=Z and A[2]=X, in the system 54 (FIG. 3), nine property change events are sent from server portion 22b to the client portion 22a (i.e., one each for the properties A[0].a,
A[0].b, A[0].c, A[l].a, A[l].b, A[l].c, A[2].a, A[2].b, and A[2].c). In the embodiment where a copy ofthe property path manager 86 is located on the client node 64, the server portion 22b
sends three property change events (i.e., A[0], A[l] and A[2]), to the client portion 22a because the copy ofthe property path manager 86 on the client node 64 has all ofthe children node information and can make the applicable changes.
As depicted in FIG. 3, the event manager 74 sends to the server-side property path manager
86 all of those property paths in which the event manager 74 has interest. The event manager 74
registers interest in a property path using, for example, a 'ListenTo' command shown in Table 1.
When the event manager 74 informs the server portion 22b about which property paths are of interest, the event manager 74 does not need to inform the server portion 22b specifically which
(or how many) UI elements 46 are interested in each property path. The property path manager
86 monitors the properties 38 ofthe application components 34 corresponding to the identified
property paths and notifies the event manager 74 when any ofthe property paths in which the client portion 22b has registered interest in changes. When the user provides some input, by interacting with one ofthe user-interface elements 46, the event manager 74 notifies the property path manager 86 about the change and to which property path the change corresponds. Because the communication references property paths, the communication about the change is in terms of
the effect on the application components 34, rather than in tenns ofthe user-interface elements
46. For example, if the user slides a horizontal slider to the 50% point, the UI element determines the value the 50% point represents and signals an event to the event manager 74.
When a property path is no longer of interest, the event manager 74 can send a notice of lack
of interest to the server portion 22b in one of several different ways. For example, the event manager 74 can immediately inform the server portion 22b, not inform the server portion 22 at
all, or inform the server portion 22b after some time period or other event (e.g., when first notified about a change in the corresponding property ofthe property path). The server portion 22b transmits to the client portion 22a any change events associated with those property paths in
which the client portion 22a has indicated interest. When the event manager 74 receives a property change event for a change in the state (e.g., value) of a property 38 associated with a
property path from the server portion 22b, the event manager 74 determines, using the mapping,
which UI elements 46 must be notified. The event manager 74 communicates the updates due to the change event to each ofthe UI elements 46 mapped to the property path. In one embodiment,
there are multiple pages 42 located in separate sub-windows. The event manager 74 is configured to inform UI elements 46 that are located in other sub-windows about any applicable
changes. In this embodiment, the event manager 74 manages the database ofthe mapping so that
the closure of a window does not adversely affect the other UI elements 46. In this embodiment,
the event manager 74 and/or associated data structures may be replicated or distributed between the different pages. For example, each page may contain a portion ofthe event manager 74, and
a table of UI elements 46 that are present on that page.
If the user updates a UI element 46, the UI element 46 signals a change event to the event
manager 74 and is updated on the display as the user makes a change. When the event manager 74 receives a change event from the UI element 46, the event manager 74 determines, using the mapping, which other UI elements 46 are mapped to the same property path as the UI element 46 that changed. The event manager 74 communicates the updates due to the change event to each
ofthe other UI elements 46 mapped to the same property path. The event manager 74 also sends
a change event to the server portion 22b so that the server portion 22b can update the associated
property 38 ofthe application component 34 in response to the user change ofthe UI element 46. In another embodiment, the event manager 74 does not make any immediate changes to the
UI element 46 that the user changes or any other UI elements 46 mapped to the same property
path. Instead, the event manager 74 first sends a change event to the server portion 22b so that
the server portion 22b can update the associated property 38 ofthe application component 34 in response to the user change ofthe UI element 46. The application 26 can reject the change initiated by the user for security or other reasons. The event manager 74 waits until the server portion 22b sends back a change event indicating that the property 38 ofthe application
component 34 associated with the property path has changed. After the event manager receives that change event from the server portion 22b, then the event manager 74 communicates the
updates due to the change event to each ofthe other UI elements 46 mapped to the same property
path. If the application rejects the change, then the event manager 74 updates the UI element 46 that the user changed back to its pre-user intervention state.
In some embodiments, the property connector API 22 takes steps to avoid looping of change
events, which can result in trying to update a UI element 46 or an application component 34 that
generated the change event and has already been updated. For example a UI element 46 only
generates a change event if a user updates the UI element 46 , for example, but does not generate a change event if the event manager 74 updates the UI element 46. In another embodiment, for example, the property comiector API 22 does not inform the original generator (i.e., UI element
46, application component 34) ofthe change event, as that originator is already updated.
A page 42 can also be altered dynamically when, for example, an iterator type predefined UI
element 78 creates additional UI elements for indexed properties, a process described in more detail below. If a page 42 is being altered dynamically, then when a UI element 46 is generated, the event manager 76 determines those property paths in which the UI element 46 is interested.
Similarly, when a UI element 46 is destroyed, the event manager 74 determines that the UI
element 46 is no longer interested in those property paths. In one embodiment, the user has
previously created the page 42 separately (i.e., at build time) and thus some or all ofthe UI elements 46 on the page 42 are created prior to the application 26 executing. In an embodiment using treeview type or iterator type predefined UI elements 78, an example of a portion ofthe UI
(e.g., a row in the table) is included in the page 42 at build time. At runtime, the client portion 22a duplicates/clones the example (e.g., row) for all ofthe members ofthe indexed property
associated with the treeview type or iterator type predefined UI element 78, as described in more
detail below. The example portion ofthe UI may be a single UI element or a more complex set of UI elements.
FIG. 4 depicts an embodiment of a screenshot 128 produced by the page interface 112 (FIG.
2) (e.g., an HTML editor) that helps a user generate a UI 42' at build time according to the invention. The screenshot 128 includes a display 130 of an HTML page 42' that a user is
generating with the page interface 112. The screenshot also includes a palette 134 of some
available predefined UI elements 78 (FIG. 2) and an entry display 138 for assigning a property
path to a UI element 46 ' .
The palette 134 of available predefined UI elements 78 includes predefined UI elements 78a, 78b, 78c, 78d, 78e, 78f and 78g. Predefined UI element 78a represents an image type UI
element. The image type predefined UI element 78b displays an image dependent on the value of
the associated property (e.g., 'property- value'. gif). Predefined UI element 78b represents an
iterator type UI element. An iterator type repeats a UI element for each member of a range of
indexed properties (e.g., once each for i=0, i=l, i=2,... in App.StaffjTJ). The element 46g' represents an iterator type element, where the row 46g' is an exemplary row that the client
portion 22a copies when dynamically creating elements for each index value.
Predefined UI element 78c represents a text type UI element. The text type predefined UI
element 78c displays a property value as a piece of text. The elements 46b', 46c' and 46d' represent text type elements. With a text type predefined UI element 78c, numeric values may be
scaled, stepped and/or clipped. Predefined UI element 78d represents a hidden type UI element.
A hidden type hides and shows part ofthe UI element, dependent on a property and an expression. Predefined UI element 78e represents a value type UI element. The value type predefmed UI element 78e is an input box that displays a property value and allows it to be
edited by a user. The element 46e' represents a value type element.
Predefined UI element 78f represents a slider type UI element. The slider type predefined UI element 78f includes a vertical slider and/or a horizontal slider for numeric properties. The element 46f represents a slider type element. When the user selects the slider type UI element,
the user also enters values associated with 'min' 'max' and 'step' values for that slider element.
In another embodiment, the user enters the property paths for the values associated with 'min'
'max' and 'step' values for that slider element and the properties corresponding to those property
paths determine the associated values. Predefined UI element 78g represents a treeview type UI element. The element 46a' represents a treeview type element. The treeview type predefined UI
element 78g is based on the levels of a property path. For example, for the property path
Αpp.Boss.Staff[i]. Staff]]]' the treeview has a root level, a child level and a child's child level. The root level is App.Boss, the child level is App.Boss.Staff[i], and the child's child level is
App.Boss.Staff[i].StaffO]. In other embodiments, the palette 134 can include other predefined UI elements 78. For
example, a button type disables a button based on a property value associated with a property
path. An iframe type displays an embedded frame, where the contents ofthe frame are constructed from a page described by the value of property path. An anchor type creates an anchor which links to a page described by the value of a property path. The tab type predefined
UI element displays associated properties as tabs, with one tab per member of a range of indexed
properties. A flipflop type changes the style of part of a UI , dependent on a property and an expression. For example the flipflop will set the style ofthe part ofthe UI to one state (the flip state) if the expression evaluates to 'false' when a placeholder in the expression is substituted by the current value ofthe property. If the expression evaluates to 'true' then the style ofthe part of
the UI is set to an alternative state (the flop state).
A deck type displays one of a 'deck' of portions of a UI , dependent on a property value (each
UI portion is associated with a value, an the one whose value matches the current value ofthe
property is displayed). A dropdown type is a nested dropdown menu, where each choice is a value from a range of indexed properties. A radio type has one or more radio buttons, where each has a property path and an associated value to set the property path to if the button is
selected. All UI elements may contain an expression in terms of a number of property paths,
rather than a simple property path. For example, the expression
App. Employee[0].Salary+App.Employee[l]. Salary would use the sum ofthe value of these two
properties to update the UI element, rather than an individual property value. A script type element executes a script on the client node 64 whenever a value of a specified property changes,
and passes the value ofthe property as an argument to the script.
To create the HTML page 42', the user selects a UI element 46' generated by the page interface 112 and places the selected UI element 46' at the desired location in the page 42' . The
user can also select from the predefined UI elements 78 shown in the palette 134. The user selects a predefined UI element 78 and places the selected predefined UI element 78 at the
desired location in the page 42'. This placement can be done, for example by the click and drag
method. Alternatively, the user can move the cursor to the desired insertion point, and then click on the item from the palette 134. The client portion 22a generates a dialog box that prompts the
user to enter relevant attributes (e.g., property path, mm/max values, etc). When the user enters all ofthe relevant attributes, the client portion 22a locates the selected element 78 at the cursor position. The user uses the entry display 138 to edit a property path associated with a UI element 46'
selected in the page 42'. To make the association, the user can type in the property path. In
another embodiment, to make the association, the user can search through a list (e.g., structured
tree) of available property paths for the application 26 and select a property path from the list. As described above, in one embodiment the list is provided through a property file containing identifiers and their relationships, and the page interface 112 accesses the property file, which is
stored on the client node 64. In other embodiments, the page h terface 112 and/or the client
portion 22a includes a property browser. The property browser obtains the instantaneous values of available application components 34, their properties 38 (e.g., identifiers) and the relationship (e.g., child nodes) between the application components 34 and properties 38 to provide a list of
available property paths. In another embodiment the property browser examines the code ofthe
application and determines possible property paths by examining the types ofthe application
objects.
Once a user locates all desired UI elements 46' in the page 42' and associates them with property paths, the page 42' is ready to be used with the application 26. FIG. 5 depicts a
screenshot 150 of a page 42" being used in conjunction with an executing application (i.e., run
time). The page 42" contains a treeview type UI element 46a" that displays the structured relationship between the employees. The page 42" also contains a large number of text type UI
elements. Text type UI elements 46b", 46c" and 46d" that display the text values of properties that correspond to the 'selected' employee. This current selection is also reflected in (and may
be changed using) the tab type UI element 46g". Image type UI element 46h" displays an image
that corresponds to the selected employee . The value type UI element 46e" (i.e., input box) and the slider type UI element 46f ' display the salary that corresponds to the selected employee. The user can use any ofthe UI elements associated with the 'salary' property path (e.g., 46e", 46f ' ) to change the salary that corresponds to the selected employee. As discussed above, when a user
changes any one of these UI elements 46e", 46f ', the client portion 22a changes all ofthe other
UI elements 46" with the same property path so that they all stay consistent. This change to the
UI elements 46" is done entirely on the client node 64 without any interaction from the server
node 60. The client portion 22a also notifies the server portion 22b ofthe change, so the server
portion 22b can update the appropriate property 38. However, the application 26 may veto the change either by not providing a 'set' method for the property 38, or by rejecting the call via veto
means available in the property/event interface 90 (e.g., for JAVABEANS™ compatible
components, this veto might be in the form of a "throw" statement using an "exception" sub-
class). If the change is vetoed, the property path manager 86 informs the client portion 22a that
the value has changed back to its old value, so that the correct value is displayed on the client node 64.
Other text type elements on the page 42" include 46j" - 46n", which are all dynamically
created by copying an example treeview entry 46a' (FIG. 4) and substituting in the appropriate
property path for the position in the treeview (e.g., App.Boss.Name, App.Boss.Staff[0].Name, App.Boss.Staff[0].Staff[0].Name, App.Boss.Staff[0].Staff[l].Name, App.Boss.Staff[l].Name
respectively). The client portion 22a similarly creates text elements 46o" - 46t" in the table 46i" from an exemplary row ofthe table (e.g., 46g' of FIG. 4) and by substituting the index values 0,
1, 2, 3, and 4 into the indexed property path 'App.Employee[*]Name'.
FIG. 6 depicts a block diagram of an embodiment of a map of registered property paths generated by the property path manager 86. The property path manager 86 generates this map to track all ofthe property paths in which the client portion 22a registers interest and the properties 38 ofthe application components 34 to which the property paths correspond. In the embodiment
shown, the map ofthe property path manager 86 is modeled as a tree structure 160. The free structure 160 is associated with an application 26' including application components 34a', 34b',
34c', 34d' (generally 34'), some of which include properties 38a', 38b' 38c' (generally 38'). The
tree nodes 164a, 164b, 164c, 164d (generally 164) ofthe tree 160 are associated with the root
component 34a' and existing properties 38 of application components 34' within the application 26' if the appropriate application component 34' currently exists. If the property path does not
currently refer to a valid application component 34', then the tree node 164 is not associated with
any application component 34' . In another embodiment, the property path manager 86 generates
a tree 160 representing all of he available property paths currently available for a specific
application (not shown). In this embodiment, the property path manager 86 transmits all of he available property paths to the client portion 22a for use in generating a page 42", as mentioned with respect to FIG. 4.
As shown, the client portion 22a has registered interests in property paths 'App.X. Y' and 'App.X.Z', represented by tree nodes 164c and 164d, respectively. X, Y and Z represent
properties ofthe application components 34' and these properties correspond to the identifiers of the property paths. For further illustration, property path ' App.X. Y' can represent the property path 'App.Employee[3].Name' and 'App.X.Z' can represent the property path
'App.Employee[3].Boss'. The initial value that corresponds to the property path
'App.Employee[3].Name' is represented by property 38a', or the value 'Alf . The application
component that corresponds to the property path 'App.Employee[3].Boss' is represented by application component 34d' and the name property of that application component is 38c', or
'Chris'.
When the state ofthe application component 34' changes, the property/event interface 90
notifies the property path manager 86. The property path manager 86 updates the corresponding tree node(s) 164 in the property path tree 160. If the updated tree node(s) 164 represents a complete property path in which the client portion 22a has registered interest, the property path
manager 86 sends, or queues for sending, a change event to the client portion 22a. The property path manager 86 subsequently recursively examines each ofthe tree node's children nodes. In
this examination, the property path manger 86, via the property/event interface 90, obtains a new value of a property 38' from the application 26', and if another value of a registered property
changes, transmits a change event to the client portion 22a. The results are that the change in the
state of one property can result in many property change events being notified to the client portion 22a. The property path manager 86 terminates the recursive examination when something is found to be unchanged. For example, any child node of tree node 164d is not examined, as the value ofthe tree node 164d is unchanged.
In the embodiment shown in FIG. 6, the value of property path 'App.X' changes from
application component 34b' to 34c'. In the Αpp.Employee[3]' property path example, this change represents a change in the third employee. The client portion 22a is not interested in the 'App.X' property path, so the property path manager 86 does not generate a change event for this
change. However, the client portion 22a registered interest in the property path 'App.X. Y', and
the value ofthe property corresponding to that property path has now changed from 38a', 'Alf ,
to 38b', 'Betty'. The property path manager 86 determines this change when it recursively examines the children tree nodes Y 164c and Z 164d of tree node X 164b. Significantly, this
recursive examining is what allows the property connector API 22 to maintain the loosely coupled connection between UI elements 46 and application components 34'.
For example, consider when the application 26' is not configured to generate a change event when the name ofthe third employee has changed, the value represented by the property path 'App.Employee[3].Name', but that the application 26' is configured to generate a change event
when application components 34' are generated and/or deleted and when properties 38' of existing application components 34' change. The property path manager 86 converts those change events that the application 26' can generate into change events associated with property
paths in which the client portion 22a has interest by examining its tree structure 160.
Referring back to the change from application component 34b' to 34c', both of these
application components 34b', 34c' point to application component 34d'. The client portion 22a has registered in the property path 'App.X.Z' and this value remains unchanged, despite that fact that App.X now refers to a different application component 34c'. In the
'App.Employee[3].Boss' property path example, this represents that the boss ofthe new third
employee, represented by application component 34c', is still the application component represented by 34d'. Because there is no change associated with the registered property path 'App.X.Z', the property path manager 86 does not generate a change event.
Because the property path manager 86 converts changes to states of a properties within an
application 26' to change events associated with property paths, the client portion 22a can
register interest in special type property paths. One special type is a cross-mapped property path. The cross-mapped property path is in the form, for example, Map("v#r"). The cross-mapped special type represents a relationship between a value "v", specified with a property path, and a range of possible values "r", specified with a wildcard property path. The value ofthe cross-
mapped property path is the property path within the range "r" that has the same value as "v".
For example, if "v" is "Session.CurrentEmployee", "r" is "App.Employee[*]", and the currently
selected employee is the 3rd entry within the App. Employee enumeration then the value of Map("Session.CurrentEmployee#App.Employee[*]") is 2.
Described another way, cross-mapping is a lookup of one property path, dependent on
information from a second property path. For example, when the property path manager 86
receives the command Map("Session.Current#Apρ.Employee[*]"), the property path manager 86 examines the first property path "Session.Current" and determines the value v ofthe property
path. The property path manager 86 then looks up the value v within the second property path, where the value v replaces a wildcard identifier ofthe second property path. The value ofthe
cross-mapping is the index that matches. For example if the state ofthe first property path
"Session.Current" is 'Barbara' and the corresponding states ofthe second indexed property paths are:
App. Employee [0] is Abe App.Employee[l] is Barbara App.Employee[2] is Charlie App.Employee[3] is Diane,
then the value ofthe cross-mapping "Session. Current#App.Employee[*]" is equal to 1
The second property path may contain several wildcards identifiers, and the value will be the 'route' tlirough all of these wildcard identifiers. For example, for the cross mapping is
"Session. Current#App.Boss.Staff[*].Staff[*]". The state mapped to the first property path is
"Session.Current"=Ben. The corresponding states ofthe second indexed property are:
App.Boss.Staff[0].Staff[0] = Alice App.Boss.Staff[0].Staff[l] = Ben App.Boss.Staff[l].Staff[0] = Chelsea.
The value ofthe cross-mapping of "Session. Current#App.Boss.Staff[*].Staff[*]" is equal to 0,1.
Another special type is an indexed property path. In the JAVABEAN™ compatible API,
and other similar APIs, there is a concept of 'indexed' properties. The indexed property A acts like a number of properties 'A.size, A.O A.l, A.2.... A.(size-l)'. The property connector API 22 follows this indexing by representing such properties in property paths ' A[], A[0], A[1],A[2] .... A[size-1]', respectively. The iterator type predefined UI element 78 (FIG. 3) uses the special type indexed property path.
The iterator type predefined UI element 78 includes a template and is linked to an indexed
property path. The template represents the layout ofthe iterator type predefined UI element 78
for a single member (i.e., a single index value) ofthe property path. During execution, the iterator type predefined UI element 78 creates a copy ofthe template for each member ofthe
indexed property, and modifies the copy so that it is associated with a property path with the corresponding index value. These new copies are inserted into the user interface as additional UI
elements 78. If the range ofthe indexed property increases (or decreases), more copies are
inserted (or removed) as required, so that there is one UI element 78 for each currently available
index value. Each copy is linked to the application via its associated property path. An identical approach is taken for treeviews, and rows of drop-down menus.
For example, the 'iterator' UI element 78 provides a table with a 'template' row. The
'iterator' UI element 78 duplicates this 'template' row for each member ofthe indexed property. Each row can contain arbitrary UI elements 46 with 'wildcard' pathnames (i.e., property paths)
that have the current row number substituted in prior to registration. This is shown in the following exemplary code:
<table> <tbody style- displaymone' widget-iterator' range='App.Employee[]'> <tr>
<td>
<span widget-text' variable='App.Employee[%idx] .Name'>Name</span> </td> <td> <span widget- text' variable='Apρ.Employee[%idx].Salary'>Salary</span>
</td> </tr> </tbody> </table> There are a number of other UI elements (e.g., tab, menu, list) that also iterate over indexed
properties and share the iterator optimization of being able to display a plurality of elements
associated with indexed property paths using a single exemplary element, as described above.
Referring back to FIG. 3, the property/event interface 90 transmits data (e.g., change events, value changes) between the property path manager 86 and the application 26. This interface 90 uses an appropriate API for the implementation ofthe application 26. In one embodiment, for
example, the application 26 is JAVA™ technology-based, and the standard ' JAVABEAN™
Property API' provides the required semantics and is thus used as the property/event interface 90.
This standard API 90 allows the property path manager 86 to change the values of properties 38
of application components 34 when those values have been changed by a user through a UI element 46. This standard API 90 also notifies the property path manager 86 about changes
within the application 26. Other embodiments can include COM objects 34 and a COM property
change API 90 and/or C++ objects 34 with associated API 90.
The client portion 22a and the server portion 22b communicate with each other over the
communication channel 94. The protocol modules 70 and 82 establish low-level communication by use of a communications layer. An exemplary protocol is described in Table 1. The protocol
can vary from Table 1 depending on how the client portion 22a and the sever portion 22b are
divided between the client node 64 and the server node 60 (e.g., copy of property manager 86 on
the client node 64, server portion 22b and client portion 22a directly connected to each other on same node, etc.). In another embodiment, the protocol modules 70 and 82 are part ofthe client transceiver 104 (FIG. 2) and the server transceiver 108 (FIG. 2), respectively.
During communication, the server node 60 and the client node 64 batch the communication
into a number of messages, which may be compressed or encrypted. For example, in one embodiment, the server node 60 and the client node 64 use HTTP as the transport protocol. The client node 64 sends the server node 60 one or more messages. The server node 60 processes the
one or more messages, which may result in various property change events. The server node 60 batches all ofthe messages queued to be sent to the client node 64 and sends them as the response to the HTTP request from the client node 64. In one embodiment, batching involves the
removal of 'outdated' changes. For example if a change list in the batch of queued messages
includes A.B.C=x... A.B.C=y, the entry ' A.B.C=x' is overwritten by the subsequent entry
'A.B.C=y' and can be safely discarded. In one embodiment, the batching process also sorts the entries lexicographically in order to aid compression.
The communications protocol, as illustrated in Table 1, relies on informing the client node
64 about which property paths within the application 26 have changed. Communicating in terms
of changes to values of property paths is typically a lower overhead than informing the client
node 64 about which ofthe client's display elements 46 to update, and how to update them. In the system 54, the role ofthe client node 64 is to reflect the current state ofthe application 26. If network or communication channel latency is high, then the client node 64 displays an
incomplete state, but the application 26 can continue functioning correctly. The application 26
continues because the client node 64 and the server node 60 are more loosely coupled than in
traditional systems. The server node 60 can be completely unaware ofthe type of client, or the way in which the client node 64 chooses to reflect the changes in the state ofthe application 26. This makes the server node 60 more stable and scalable, as new client node 64 features do not
affect the server node 60 or the execution ofthe application 26.
Figure imgf000048_0001
Table 1
Notes: S= server node 60, C= client node 64, pathname ≡ property path.
In other embodiments, the protocol modules 70 and 82 are configured to employ
compression schemes within the communications layer that they establish. A property path compression scheme is used within a batch of messages sent within the client node 64, within the
server node 60 and/or between the server node 60 and the client node 64. Whenever a batch of
messages is sent, the property names used in the second and subsequent message is compressed
by sending only the difference between the required property name and the previous property name. For example, rather than sending the message C->S
'ListenTo("Session.Current.Name"),ListenTo("Session.Current.Salary")', the client node 64
sends the message 'C->S ListenTo("Session.Current.Name"),ListenTo(16+"Salary")', where 16
is the number of characters of "Session.Current.Name" that also occur in
"Session. Current.Salary". The client node 64 takes advantage ofthe preceding message by
shortening the subsequent message.
Another scheme to shorten the length of messages is for the client node 64 to register
interest in a number of property paths by using a wild card. For example, this scheme is used to register interest in all the property paths that supply values for a table. To illustrate this example,
the single message 'C->S ListenTo("App.Employee[*].Name")' registers interest in the property paths 'App.Employee[0].Name', 'App.Employee[l].Name'...'App.Employee[n-l].Name',
where n is the size ofthe App.Employee indexed property. In addition, if the size ofthe
App.Employee property changes, then the client node 64 has implicitly registered interest in all
App.Employee[0 to m-l]. Name values, where m is the new size.
The property connector API 22 also compresses the property path names. From the server
portion 22b to the client portion 22a, in response to a wildcard ListenTo request (as in the
example above) the server portion 22b compresses its responses by omitting property path
names. Rather than sending the messages:
S->C App.Employee[0].Name = Alf S->C App.Employee[l].Name = Bert S->C App.Employee[2] .Name = Carl , the server portion 22b sends
S->C array = App. Employee [*]. Name S->C arrayelement = Alf S->C arrayelement = Bert
S->C arrayelement = Carl, where array and arrayelement are special property names that may be sent efficiently.
The system 54 uses a data compression scheme in messages sent from the server node 60 to
the client node 64. The client node 64 stores, at all times, the 'last known' value 50 of each of the property paths that it is displaying in the page 42 in a current value table. In one
embodiment, the server node 60 optionally stores a copy of this information, and uses this as a
data dictionary to compress values sent. For example, the server node 60 needs to transmit to the
client node 64 the message S->C App.Employee[4].Name = "Albert". The server node 60 determines, by examining the data dictionary, that the client node 64 already has the value
App.Employee[3].Name = "Albert" by a previous transmission, and upon determining the value that was sent, then the server node 60 compresses its message to S->C App.Employee[4].Name =
copy Value(App.Employee[3]. Name), where copy Value is a directive to the client node 64 to use
a value 50 from its current value table. In another embodiment, the protocol modules 70 and 82 are configured to employ the data compression scheme in parallel with the property path compression scheme and an array name
compression scheme. The protocol modules 70 and 82 utilize this combination of schemes when
the size ofthe description ofthe 'copy Value' expression is smaller than the literal value. The
array name compression scheme is of particular benefit when an array of data on the server node
60 is sorted, and this data is displayed in the UI 42 on the client node 64. The combination of compression schemes described above compresses the message
S->C App.Employee[0] .Name = "Albert" App.Employee[l].Name = "Bert" Aρρ.Employee[2].Name = "Cathy" App.Employee[3].Name = "Doug': App.Employee[4].Name = "Elsie"
to
S->C array="App.Employee[*].Name': arrayelement = copyValue 4 arrayelement = copyValue 3 arrayelement = copyValue 2 arrayelement = copyValue 1 arrayelement = copyValue 0.
In other embodiments, the property connector API 22 is configured so that the server node
60 resource utilization is low. Generally, there are no 'per-client' threads and little 'per-client' state and background processing. There are three classes of applications 26 that can be optimized for scalability, by reducing the amount of processing or storage done per client, or per change. The first class of applications 26 that can be optimized are responsive to user input, but
do not pro-actively change values of properties 38. If the client node 64 is dormant, the property
connector API 22 can optimize the resource usage on the server node 60 by suspending the
application 26 and/or storing client-specific state on the client node 64 until the client node 64 becomes active again.
The second class of applications 26 that can be optimized are those that act as data feeds, for
example stock prices. With this class of applications 26, the per-client data is small, whereas the
shared data may be large. The property connector API 22 again stores client-specific state on the client node 64 rather than the server node 60 , allowing the server node 60 to scale to more client
nodes 64. For this class of applications 26, the property connector API 22 allows a single .'worker application instance' to service many clients 64.
The third class of applications 26 that can be optimized are those that generate events faster than the client node 64 can collect them. An example is a stock ticker application that sets the price of a stock every second and communicates with a client node 64 that reads the stock price
once every minute. The property connector API 22 reduces the rate of event generation, without
involvement from the application 26, to reduce the per-event processing load. This is particularly important for the third class of applications with a large number of clients 64. For
applications where the rate of event generation is high compared to the rate of polling by clients,
there is a higher than necessary per-client event processing load for connected clients. In one
embodiment, the property connector API 22 adds event-buffering mechanisms so that the per- event cost is much lower. For example, only one record is updated on the server per event, rather
than one per client. At a lower period of event generation, the property connector API 22 scans
these records and forwards events to the client records. The property connector API 22 matches,
in effect, the rate of event generation to the rate of polling.
For these three classes of applications 26, the property connector API 22 supports different modes of operation where the per-client state and/or processing on the server node 60 is further reduced. This is at the expense of increased bandwidth and/or processing requirements when
communication does take place, or at the expense of reduced timeliness of event notification. A
client connection may move from a 'highly interactive' mode of operation to a 'resource saving'
mode of operation and back many times during its lifetime. Equally, the rate of event generation may be varied according to the server load.
In one embodiment, there are two operating modes for property connector API 22, and
additional operations within the operating modes. The normal mode of operation, described
above, is called connected mode. The server 60 stores, for each client 64, an instance ofthe application 26 and a property graph of listener objects 34. In connected mode, there is high per- client state stored on the server 60 and high per client event processing load. However this is low per client poll/invocation processing load, and thus low bandwidth is required. The second mode of operation is disconnected mode. In disconnected mode, the client state
is removed from the server 60 and stored on the client 64. No per client event processing takes place. Either no application 26 is running on the server 60, or only a single shared instance is
executing. However, sufficient state is stored on the client 64 to allow the per-client application
26 to be recreated when necessary. The client 64 also stores a description of each property it is
interested in, as in connected mode. The property comiector API 22 allows a client 64 in
disconnected mode to poll. This poll has higher processing and bandwidth costs associated with it than in connected mode. A disconnected client 64 wishing to perform an invoke command
(Table 1) must reconnect. Moving from disconnected mode to connected mode, and back, incurs relatively high bandwidth and processing overhead.
The additional operations are specific optimization techniques for fine tuning the connected and disconnected modes of operation for deployments with a large client population. The
additional operations are disconnect, reconnect, and one-shot. For the disconnect operation,
issued by client 64, the property connector API 22 commands the application 26 to save its state
and shut down. This saved state is then sent to the client 64. No per-client state remains on the server 60. The connection then enters the disconnected mode. Heuristics determine when to enter the disconnected state. Entering the disconnected state is only possible for applications 26
that provide a suitable interface, or where a saved state can be created by logging the history of
all operations invoked.
During the reconnect operation, issued by client 64, the client 64 sends the saved application state to the server 60 along with a list of properties 38 that the client 64 is interested in. The server 60 restarts the application 26 using the saved state, re-registers interest in all properties 38, and continues in the coimected mode. This operation is invoked by a disconnected client 64 that
wishes to update the server state (i.e., invoke an operation or set a property). During the one-shot operation, issued by client 64, the client 64 sends the saved application
state to the server 60 along with the list of properties 38 that the client is interested in. The
server 60 may restart the application 26, return the current values ofthe properties 38 and then
shut down the application 26. For an application 26 to use this optimization, it must provide the required static method, for example, a single shared instance, or static method, that can take a saved state and return a suitable application instance. This suitable instance may be a shared
instance between several clients or may be a new per-client instance. After the property
connector API 22 obtains the property values, the property connector API 22 commands the
application 26 to stop execution. The one-shot operation is invoked by a disconnected client 64 that wishes to poll, but not change the server state.
In other embodiments, the property connector API 22 is further configured with additional optimizations such as timestamp, slow garbage collector, connectivity check and property set.
One optimization that the property connector API 22 uses is the timestamp. For many
applications based on data feeds (e.g. stock tickers), the majority of properties 38 that a client 64 has registered interest in may not change between polls. In the disconnected mode, this may
result in one-shot operations providing a large amount of unnecessary state data. To alleviate
this, the property connector API 22 adds a timestamp-based property interface. For example, in one embodiment, the property connector API 22 uses the two commands 'Timeid
getCurrentTimestampO' and 'Object getChangedProperty(String name, Timeid since)'. The
'getChangedProperty' command returns a property value if it has changed since the specified
timestamp. The 'getCurrentTimestamp' command returns the current time. In replies from
disconnect or one-shot operations, the server 60 provides the current timestamp as an additional
parameter. In calls to one-shot or reconnect operations, the client 64 provides this timestamp, and is informed of property values if they have changed since this timestamp was issued. In another embodiment, the property connector API 22 uses the slow garbage collector
optimization, which requires the cooperation ofthe application 26. When a client 64 performs a
reconnect and/or one-shot operation, if the previous application instance is still available (i.e., has not been garbage collected), then this instance can be used as in connected mode. This optimization does not apply if the application 26 has been 'stopped' explicitly on disconnect, but
many applications are 'passive' and do not require a stop interface.
In another embodiment, the property connector API 22 uses the Connectivity Check
collector optimization. When using the 'slow garbage collector' optimization, above, a client 64 wishing to perform reconnect or one-shot operations first determines whether the server 60 still has a valid application instance. If the server 60 does, then the saved state and property list does
not need to be sent. When successful, this optimization reduces the bandwidth requirement.
When unsuccessful, it incurs an additional 'round trip' from the client 64 to the server 60 and back.
In another embodiment, the property connector API 22 uses the property set optimization. It is noted that if a server 60 is supporting a large number of clients 64, all of which use the same
user-interface, then it is likely that many ofthe clients 64 will be interested in exactly the same
set of properties. During disconnect mode, the server 60 associates the set of properties 38 that the client 64 is interested in with an set identifier, and the client 64 uses this set identifier during one-shot and reconnect operations, rather than sending the complete list of properties 38. Using
the set identifier incurs a small additional memory requirement on the server 60, as many clients
share the same property set, but saves considerably in the bandwidth requirement ofthe one-shot
and reconnect operations.
FIG. 7 depicts a flow diagram of an embodiment of a process by which the server node 60 and client node 64 interact in accordance with the invention. The first step is that the client node 64 establishes a connection with the server node 60 to connect (step 200) to an executing
application 26 or to request (step 200) initiation of execution ofthe application 26. The server node 60 authenticates the client node if required and connects the client node 64 to the
application 26, if executing, or initiates execution ofthe application 26 as requested (step 204).
The client portion 22a scans the UI 42 and identifies (step 208) a UI element 46 within the
UI 42 that is associated with a property path and has not been initialized (e.g., inserted into table and registered). The client portion 22a inserts (step 212) into its table the identified UI element
46 and its associated property path. The client portion 22a registers (step 216) interest in this
property path with the server portion 22b. The client portion 22a determines (step 220) whether
there are any more UI elements 46 in theUI 42 that are associated with a property path and have not been initiated. If there are more UI elements 46 in the UI 42 that have not been initiated, then the client portion 22a repeats steps 208, 212 and 216 for each ofthe additional UI elements 46
that are not initiated. When all ofthe UI elements 46 have been initiated, the client portion 22a
monitors (step 224) the UI elements 46 for user changes.
When the client portion 22a registers (step 216) interest in a property path, the server portion
22b, through the property/event interface 90, determines (step 228) the initial value for the registered property path. The server portion 22b sends (step 232) the determined initial value to
the client portion 22a. The client portion 22a updates (step 236) the identified UI element 46
with the initial value. If there are any other UI elements 46 associated with the same property
path, the client portion 22a updates (step 236) those elements 46 with the initial value also. The server portion 22b updates (step 240) the tree structure map 160 with the registration of interest for the property path, received from the client portion 22a, and the determined initial value.
The client portion 22a determines (step 244) whether the update ofthe UI element(s) 46
resulted in creating one or more additional UI elements 46 (e.g., additional employees were added to the list). If one or more additional UI elements 46 were added, then the client portion
22a repeats steps 208, 212 and 216 for each ofthe additional UI elements 46. If no additional UI
elements 46 are added, the client portion 22a monitors (step 244) the UI elements 46 for user changes.
While monitoring (step 224) the UI elements 46, the client portion 22a determines (step 224) whether the user changed the value of an existing UI element 46. If the user does not change the
value of an existing UI element 46, then the client portion 22a continues to monitor (step 224)
the UI elements 46. If the user does change the value of an existing UI element 46, then the client portion 22a informs (step 248) the server portion 22b ofthe change. If there are any other
UI elements 46 associated with the same property path as the changed UI element 46, the client portion 22a also updates (step 236) those UI elements 46 with the changed value and determines
(step 244) whether any new UI elements 46 are created as a result ofthe change.
Upon being informed (step 248) by the client portion 22a, the sever portion 22b attempts to update (step 252), via the property/event interface 90, the value ofthe property 38 ofthe application component 34 affected by the user change (i.e., the property 38 at the end ofthe property path associated with the user-interface element 46 the user changed). The application
26 determines (step 253) whether to accept the change or to veto the change. If the application
26 accepts the change, the application 26 changes the state (e.g., value) ofthe property 38 as requested by the server portion 22b and generates a change event. The server portion 22b receives the change event and determines (step 260) whether the change corresponds to a
property path in which the client portion 22a has interest and acts in response to that
determination. In one embodiment, the server portion 22b inhibits sending a change event to the client portion 22a for the changed property 38, because the client portion 22a originated the change. If the application 26 does not accept the change (e.g., vetoes the change), the server portion
22b generates (step 254) a special change message to change the value ofthe property path, as displayed on the UI 42, back to the original (i.e., pre-user modification) value. The server
portion 22b continues by sending (step 232) the change message with the original value back to the client portion 22a.
After the tree structure 160 has been updated (step 240), the server portion 22b continues to monitor (step 256) the properties corresponding to the tree structure map 160. If a state (e.g.,
value) of a property changes, the server portion 22b determines (step 260) whether the change corresponds to a property path in which the client portion 22a has interest. If the server portion
22b determines (step 260) the changed state ofthe property does not correspond to a registered
property path, the server portion 22b continues to monitor (step 256) the states of properties
corresponding to the tree structure map 160. If the server portion 22b determines (step 260) the changed state ofthe property does correspond to a registered property path, the server portion 22b generates and sends (step 232) to the client portion 22a a change event for the corresponding
property path. The client portion 22a updates (step 236) any UI elements 46 associated with the
property path with the changed value.
The property connector API 22 also can be configured to provide additional features. For
one example, if in the system 54 of FIG. 3 the client node 64 and/or page interface 112 (e.g., browser) is unable to run the client portion 22a or support some or all ofthe UI elements 46
required for the specific user-interface 42, then the property connector API 22 can generate a
proxy process (not shown). The proxy process can execute on the server node 60, or on another
server node 60' (not shown) logically located between the client node 64 and the server node 60 executing the application 26. The proxy process acts as a client portion 22a in as far as communications with the server portion 22b, and acts as a standard server process, using an
alternative, compatible protocol, to communicate with the client node 64.
For example, a system 54' includes a client node 64' that has an older version of a Web
browser 112' that is unable to support the client process 22a. The proxy process receives the
interactive page 42 and the dynamic changes indicated by the property coimector API 22 and, in real-time, converts the page 42 and the dynamic changes into a static page 42' that is compatible
with the older version Web browser 112'. The converted static page 42' includes traditional
style links and input boxes to replace the dynamic mouse events and text fields used with the
client portion 22a. When the user clicks on a link, the client node 64' requests a new page 42'
from the proxy process. The proxy process interprets this as a click on a portion ofthe interactive page 42, and if this results in a change to a state of a property, the proxy process sends the change to the state ofthe property to the server portion 22b. The proxy process then
generates a new static page 42", in real time, to represent the new UI state and sends the new
page 42" to the client node 64'.
FIG. 8 depicts an embodiment ofthe server portion 22b' ofthe property connector API 22 configured to provide an additional feature of executing an extension 270. The server portion 22b' includes a first property path manager 86a, a first property/event interface 90a, a second
property/event interface 90b, the extension 270 and an extension manager 274. The extension
270 includes extension components 278, analogous to the application components 34. The
extension 270 is a process that augments the application 26, becomes an 'extension' ofthe application 26. Two exemplary extensions are a page extension and a form extension. To the client portion 22a, the extension 270 acts like a part of he application 26. To the application 26,
the extension 270 acts like part ofthe client portion 22a. The extension manager 274 includes a
second property path manager 86b and an extension event manager 282. A request to execute an extension 270 is included in the UI 42. The page interface 112 loads
the UI 42 and when the client portion 22a encounters the extension request, the client portion 22a
sends the request to the server portion 22b to initiate execution ofthe extension 270. An exemplary request command for a page extension is
'Session.PageView=newExtension('PageView','App.Employee[]',10)'. With receipt of this command, the server portion 22b initiates execution ofthe named extension 'Page View' on the
server node 60. In accordance with the parameters ofthe command, the server portion 22b
initializes the extension 270 with the values Αpp.Employee[]' and 10. The extension 270 registers interest in the App.Employee[] property path with the property path manager 86b, and is
told of all members of this indexed property, and any changes.
The Page View extension 270 provides an indexed property Page[i], which is an indexed
property of 'Page' objects 278. Each Page object 278 in turn provides an indexed property 'Item[j]', which is an indexed property of items on the current page 42. The Page View extension 270 allows the App.Employee property to be accessed via a number of pages 42a to 42i, where i
is the number of pages. For example the property path 'Session.PageView.Page[0].Item[0]' is equivalent to property path Αpp.Employee[0]'. The first employee is displayed on the first
page. Similarly, the property path 'Session.PageView.Page[l].Item[4]' is equivalent to the property path Αpp.Employee[14]' because after the first ten employees (the entered parameter
was ten), the next ten employees are displayed on a second page. The Page View extension 270 also provides other properties such as NoPages, CurrentPage, NextPage, LastPage, and the like,
to make it easy to build page based interfaces to applications 26 that do no themselves support
multiple pages 42a to 42i.
Another extension is the 'Form' extension. The form extension provides a means for 'batch processing' of application data. The form extension allows transactional input to an application 26. For example, a user may fill in a form 42a (not shown) displayed in a UI 42 and then cancel
or submit the filled in form 42a as a whole, instead of piecemeal data. If the server portion 22b'
is configured with a form extension 270, the client portion 22a creates a form 42a by a call to
Session.newExtension. This command takes two mandatory parameters, 'String id' and 'String type' and one optional parameter 'String args'. The 'String id' parameter includes the name of
the extension (e.g. 'myform') and is in the format 'Session.myform'. The 'String type' parameter includes the type ofthe extension, which for a form extension, is in the format 'Form'. The
'String args' parameter includes an optional argument string. For the form extension, the format is one of " (i.e., null), 'snapshot', 'weakchanges' or 'snapshot, weakchanges'. The snapshot and
weakchanges modes are described in more detail below.
The form extension 270 is configured to accept several methods. One method is 'submitO',
which transmits all changed values to the form extension 270 to update the application 26. Another method is 'refresh()', which refreshes all values within the form 42a, including changed
ones, to be the same as the corresponding application properties 38. Another method is
'update()', which refreshes all ofthe unchanged values to be the same as the corresponding application properties 38. The method is useful for unconnected forms. Another method is
'clearO', which resets all changed values to null. This method is useful for complex forms.
Another method is 'clear(v)', which resets all changed values to v.
The call to create a form 42a is usually made in a script type UI element to ensure that the
form 42a is initialized before UI elements 46 using the form 42a are displayed. The form 42a is global and may be used anywhere on the page 42, not just inside the script UI element 46.
An exemplary code used to create a fonn 42a is as follows:
<div widget- 'script" onstai-t="invoke_server(this,'Session.newExtension(\'FV,\'Form\')')"> <table> <tr>
<td><b>Employee</b></td> <td><b>Salary</b></td> </tr>
<tbody style='display:none' widget='iterator' range- Session.F.App.Employee[]'> <tr> <td><span widget='text' variable- %itm.Name'>Name</span></td>
<td><input widget='value' variable- %itm.Salary'></td> </tr> </tbody> </table> <input type- 'button" value- ' Clear" onclick="invoke_server(this,'Session.F.clear(0)')">
<input type="button" value="Reset" onclick="invoke_server(this,'Session.F.refresh()')"> <input type- 'button" value=" Submit" onclick="invoke_server(this,'Session.F.submit()')"> </div>
When the server portion 22b' is configured with a form extension 270, the property paths
'Session.Form.App.Name' and 'Session.Form.App.Employee[5]. Salary' have the same value as the property paths 'App.Name' and Αpp.Employee[5]. Salary'. Any change to a property starting 'Session.Form' is recorded in the form extension 270 and not applied to the application
26 until the client portion 22a invokes a Session.Form.submit() method. In one embodiment, the
client portion 22a invokes a 'Session.Form.submit()' when the user clicks on a UI element button labeled submit. Alternatively, the client portion 22a invokes a Session.Form.cancel() method, in which case nothing will change.
The form extension 270 works by acting as a filter over other properties 38. For example a
form 42a can be identified as 'Session.Form'. For example, this form 42a displays values
associated with property paths such as ' Session.Form.App.Name' ,
' Session.Form. App.Employee[2]. Salary' and the like. There is no need to define what properties
correspond to a form 42a, as the properties 38 are associated dynamically as they are referred to by UI elements 46 within the page 42.
By default, a form 42a is connected and set to preservesChanges. That is, if an application
property 38 changes during the lifetime ofthe form 42a, the form 42a reflects the change unless the user has already changed the value. This also means that if the page 42 wishes to display new values in the form 42a, then this will happen automatically (e.g., iterator type UI elements 78b or
treeview type UI elements 78g).
In various embodiments, the form 42a can be set to different modes. In one embodiment, the form 42a may optionally be set to 'snapshot' mode, where it is unconnected and all values will be
null until entered by the user or the form 42a is manually refreshed. In another embodiment, the form 42a may also be optionally set to 'weakchanges' mode, where changes to values from the
application 26 will overwrite changes made by the user.
In one embodiment, if an application property 38 changes that is an ancestor of a property 38
displayed on the form 42a, and the form 42a is connected or manually updated, then the dependent properties on the form 42a are updated even if the user has changed them. For
example, a form 42a displays App.Employee[0].Name (=Fred) and App. Employee [0]. Salary
(=100). If the user changes the salary to 200 (e.g., Fred's salary), and then the application 26 changes who App.Employee[0] is (e.g. to Bill, Salary 50), then the form 42a correctly displays
App. Employee [0] .Name = Bill and App.Employee[0].Salary=50, discarding the users original,
and now invalid, user change. As a consequence, if ancestor properties change as a result of submitting a number of changes in a form 42a, then it is possible that some of he changes are
discarded.
In some embodiments, data is not batched and sent to the server node 60 all at once. For
example, the updates can be transmitted to the application sequentially, or in a random order.
The application 26 reacts to the data as if it were entered all at the same time, due to the
interaction ofthe form extension 270 on the server node 60.
Equivalents
While the invention has been particularly shown and described with reference to several exemplary embodiments thereof, it will be understood by those skilled in the art that various changes in form and detail may be made therein without departing from the spirit and scope of
the invention.
For example, although the methods and apparatus ofthe present invention are described in
the context of a Web server and Web client process communicating over the Internet, those
skilled in the art will recognize that the present invention also can be practiced in non- Web
and/or non-Internet embodiments. The invention also can be practiced over any other type of network (e.g., telephone, cable, LAN, WAN, wireless, fiber), within the same physical computer
system, or with portions ofthe invention (e.g. the application independent client process) operating in an Internet appliance or cable TV set-top box.

Claims

CLAIMS What is claimed is:
1. In a system including an application having a plurality of components, at least one component having a property, each property being identified with an identifier, a method of associating an element of a user-interface to a current state of a property, the method comprising:
associating the element ofthe user-interface with a property path, the property path
including a concatenation of a plurality of identifiers, the concatenation of identifiers defining a
path tlirough the components ofthe application to a property at the end ofthe concatenation; and mapping the property path to a current state ofthe property at the end ofthe path defined
by the concatenation of identifiers, to associate the element ofthe user-interface with the current state of that property.
2. The method of claim 1 wherein the step of mapping the property path further comprises:
a) examining each identifier in the concatenation ofthe property path in succession; b) determining, for the first identifier in the concatenation ofthe property path, a second
state of a property with a name identical to the first identifier, a component ofthe application
containing that property becoming a root application component;
c) identifying, for the first identifier, a component ofthe application to which the second state points as a current application component; d) mapping the first identifier to the second state;
e) determining for the next identifier in the concatenation ofthe property path, a next
state of a property with a name identical to the next identifier located within the current
application component; f) identifying, for the next identifier, a component ofthe application to which the next
state points as a current application component;
g) mapping the next identifier to the next state; and
h) repeating steps e, f and g until the last identifier ofthe concatenation is examined to map the property path to the current state ofthe property with a name identical to the last identifier.
3. The method of claim 1 wherein the step of mapping the property path to the current state further comprises mappmg the property path to an undefined state if no property is found that
corresponds to an identifier in the plurality of identifiers in the concatenation.
4. The method of claim 1 wherein the step of mapping further comprises generating a node tree having a plurality of nodes, wherein each node ofthe node tree represents a mapping of an
identifier to one of, a state of a property and an undefined state.
5. The method of claim 4 wherein the node tree represents a plurality of property paths.
6. The method of claim 1 further comprising monitoring a plurality of states within the
application to detect a change in one ofthe states ofthe plurality of states, each state in the plurality corresponding to one ofthe states mapped to an identifier in the concatenation ofthe property path.
7. The method of claim 6 wherein the step of monitoring further comprises receiving a
property change event from a JAVABEAN-compatible component.
8. The method of claim 6 further comprising re-mapping the property path to a new current state in response to detecting the change in one of the states of the plurality of states.
9. The method of claim 6 further comprising re-mapping the identifier the concatenation of
identifiers to the changed state in response to detecting the change in one ofthe states ofthe plurality of states.
10. The method of claim 1 further comprising generating a property change message in
response to a change in a state of a property corresponding to one ofthe identifiers in the
concatenation of the property path.
11. The method of claim 1 further comprising updating one or more user-interface elements
associated with the property path with a new current state in response to a change in the current
state ofthe property.
12. The method of claim 1 wherein the step of re-mapping the property path further comprises: a) detecting a change in one of a plurality of states in an application, each state in the
plurality corresponding to one ofthe states mapped to an identifier in the concatenation ofthe
property path, b) examining each identifier in the concatenation ofthe property path in succession,
starting with an identifier corresponding to the changed one ofthe states ofthe plurality of states; c) determining for a currently examined identifier, a new next state of a property with a
name identical to the currently examined identifier;
d) re-mapping the currently examined identifier to the new next state in response to a
change in a currently mapped state; and e) repeating steps c and d for each subsequent identifier in the concatenation of
identifiers.
13. The method of claim 12 wherein the step of repeating for each subsequent identifier
further comprises terminating the repeating in response to the new next state being identical to a
state currently mapped for that currently examined identifier.
14. The method of claim 12 further comprising monitoring a new plurality of states within the application, the new plurality including the new next states mapped to an identifier in the concatenation ofthe property path.
15. The method of claim 1 wherein the property path is a first property path and the
concatenation of identifiers includes a wildcard identifier and further comprising:
mapping a second property path to a first value; and
determining a second value for the wildcard identifier in response to the first value
mapped to the second property path.
16. The method of claim 15 wherein the step of determining the second value further comprises determining the second value such that replacing the wildcard identifier ofthe first property path with the second value causes the current state mapped to the first property path with the replaced wildcard identifier to be equal to the value mapped to the second property path.
17. The method of claim 1 further comprising dynamically binding the property path to one
ofthe application components including the property corresponding to the current state mapped
to that property path.
18. The method of claim 1 further comprising transmitting to the application a request to update the current state ofthe property mapped to the property path associated with the element
ofthe user-interface in response to a user modification ofthe value.
19. The method of claim 18 further comprising inhibiting a property change message in
response to the application updating the current state ofthe property in response to the request to update.
20. The method of claim 1 wherein the user interface comprises an exemplary element
associated with a property path including a wildcard identifier, the wildcard identifier corresponding to an indexed property including an index value range from a minimum value to a maximum value, further comprising:
generating an additional element for each index value ofthe indexed property from the
minimum value to the maximum value by copying the given element associated with the property
path; and
associating a new property path with each additional element.
21. The method of claim 20 further comprising replacing the wildcard identifier associated
with the given element with the corresponding index value ofthe additional element to define the
new property path.
22. The method of claim 1 further comprising registering interest in the property path.
23. The method of claim 1 wherein the step of mapping further comprises mappmg one ofthe identifiers in the concatenation ofthe property path to a state of a property corresponding to the
one ofthe identifiers.
24. A system for associating an element of a user-interface to a current state of a property of an application, the application having a plurality of components, at least one component having a property, each property being identified with an identifier, the system comprising:
a property comiector module to identify an association between the element ofthe user-
interface and a property path, the property path including a concatenation of a plurality of identifiers, the concatenation of identifiers defining a path through the components ofthe
application to a property at the end ofthe concatenation, and to map the property path to a
current state ofthe property at the end ofthe path defined by the concatenation of identifiers,
thereby associating the element ofthe user-interface with the current state of that property.
25. The system of claim 24 wherein the property connector module is further configured to:
a) examine each identifier in the concatenation ofthe property path in succession; b) determine, for the first identifier in the concatenation ofthe property path, a second
state of a property with a name identical to the first identifier, a component ofthe application
containing that property becoming a root application component; c) identify, for the first identifier, a component ofthe application to which the second state points as a current application component;
d) map the first identifier to the second state;
e) determine, for the next identifier in the concatenation ofthe property path, a next state
of a property with a name identical to the next identifier located within the current application
component; f) identify, for the next identifier, a component ofthe application to which the next state
points as a current application component;
g) map the next identifier to the next state; and h) repeat steps e, f and g until the last identifier ofthe concatenation is examined to map the property path to the current state ofthe property with a name identical to the last identifier.
26. The system of claim 24 wherein the property connector module is further configured to
map the property path to the current state further comprises mapping the property path to an
undefined state if no property is found that corresponds to an identifier in the plurality of identifiers in the concatenation.
27. The system of claim 24 wherein the property connector module is further configured to
generate a node tree having a plurality of nodes, wherein each node ofthe node tree represents a
mapping of an identifier to one of, a state of a property and an undefined state.
28. The system of claim 27 wherein the node tree represents a plurality of property paths.
29. The system of claim 24 wherein the property connector module is further configured to
monitor a plurality of states within the application to detect a change in one ofthe states ofthe
plurality of states, each state in the plurality corresponding to one ofthe states mapped to an
identifier in the concatenation of the property path.
30. The system of claim 29 wherein the property connector module is further configured to receive a property change event from a JAVABEAN-compatible component.
31. The system of claim 29 wherein the property connector module is further configured to re-map the property path to a new current state in response to detecting the change in one ofthe
states ofthe plurality of states.
32. The system of claim 29 wherein the property connector module is further configured to
re-map the identifier the concatenation of identifiers to the changed state in response to detecting
the change in one ofthe states ofthe plurality of states.
33. The system of claim 24 wherein the property connector module is further configured to generate a property change message in response to a change in a state of a property
corresponding to one ofthe identifiers in the concatenation ofthe property path.
34. The system of claim 24 wherein the property connector module is further configured to update one or more user-interface elements associated with the property path with a new current
state in response to a change in the current state ofthe property.
35. The system of claim 24 wherein the property connector module is further configured to : a) detect a change in one of a plurality of states in an application, each state in the plurality corresponding to one ofthe states mapped to an identifier in the concatenation of he property path,
b) examine each identifier in the concatenation ofthe property path in succession,
starting with an identifier corresponding to the changed one ofthe states ofthe plurality of states; c) determine for a currently examined identifier, a new next state of a property with a
name identical to the currently examined identifier; d) re-map the currently examined identifier to the new next state in response to a change
in a currently mapped state; and
e) repeat steps c and d for each subsequent identifier in the concatenation of identifiers.
36. The system of claim 35 wherein the property connector module is further configured to terminate the repeating in response to the new next state being identical to a state currently
mapped for that currently examined identifier.
37. The system of claim 35 wherein the property connector module is further configured to
monitor a new plurality of states within the application, the new plurality including the new next states mapped to an identifier in the concatenation of the property path.
38. The system of claim 24 wherein the property path is a first property path and the
concatenation of identifiers includes a wildcard identifier and the property connector module is
further configured to:
map a second property path to a first value; and
determine a second value for the wildcard identifier in response to the first value mapped to the second property path.
39. The system of claim 38 wherein the property connector module is further configured to
determine the second value such that replacing the wildcard identifier ofthe first property path
with the second value causes the current state mapped to the first property path with the replaced wildcard identifier to be equal to the value mapped to the second property path.
40. The system of claim 24 wherein the property connector module is further configured to
dynamically bind the property path to one ofthe application components including the property
corresponding to the current state mapped to that property path.
41. The system of claim 24 wherein the property connector module is further configured to transmit to the application a request to update the current state ofthe property mapped to the
property path associated with the element ofthe user-interface in response to a user modification
ofthe value.
42. The system of claim 41 wherein the property connector module is further configured to inhibit a property change message in response to the application updating the current state ofthe
property in response to the request to update.
43. The system of claim 24 wherein the user interface comprises an exemplary element
associated with a property path including a wildcard identifier, the wildcard identifier
corresponding to an indexed property including an index value range from a minimum value to a maximum value, and the property connector module is further configured to:
generate an additional element for each index value ofthe indexed property from the
minimum value to the maximum value by copying the given element associated with the property
path; and
associate a new property path with each additional element.
44. The system of claim 43 wherein the property connector module is further configured to
replace the wildcard identifier associated with the given element with the corresponding index value ofthe additional element to define the new property path.
45. The system of claim 24 wherein the property connector module is further configured to
register interest in the property path.
46. The system of claim 24 wherein the property connector module is further configured to map one ofthe identifiers in the concatenation ofthe property path to a state of a property
corresponding to the one ofthe identifiers.
47. The system of claim 24 further comprising:
a client node including:
the user interface having one or more elements; and
a client portion of the property connector module.
48. The system of claim 24 further comprising:
a server node including:
the application; and
a server portion ofthe property com ector module.
49. A method for creating a user-interface independently of an application with which the
user interface interacts, the application including a plurality of components and at least one
component containing a property, each property being identified with an identifier, the method
comprising:
inserting at least one element into the user-interface; and
associating at least one property path with one inserted element, the property path including a concatenation of a plurality of identifiers, the concatenation of identifiers defining a
path through the components ofthe application to a property at the end ofthe concatenation.
50. The method of claim 49 further comprising:
determining a list of property paths associated with the application; and selecting the property path from the list to associate with the one inserted element ofthe
user-interface from the list of property paths.
51. The method of claim 50 wherein the step of determining further comprises receiving a property path description file associated with the application, the property path description file
including a plurality of identifiers associated with the application and a relationship between the
plurality of identifiers.
52. The method of claim 50 wherein the step of determining further comprises
executing the application; and
interacting with the executing application to determine a plurality of identifiers
associated with the application and a relationship between the plurality of identifiers.
53. The method of claim 49 further comprising transmitting a request to register for a
property change message corresponding to the property path associated with the element ofthe user-interface.
54. The method of claim 49 wherein the step of inserting comprises:
providing at least one predefined element; and
enabling selection from the at least one predefined element to insert the selected predefined element into the user-interface.
55. The method of claim 54 wherein the predefined element comprises one of an image type
user-interface element, an iterator type user-interface element, a text type user-interface element,
a hidden type user-interface element, a value type user-interface element, a slider type user- interface element, a treeview type user-interface element, a button type user-interface element, an
iframe type user-interface element, a tab type user-interface element, a flipflop type user- interface element, a deck type user-interface element, a dropdown type user-interface element, a
radio type user-interface element, and a script type user-interface element.
56. A system for creating a user-interface independently of an application with which the user
interface interacts, the application including a plurality of components and at least one component containing a property, each property being identified with an identifier, the system comprising:
a property connector module inserting at least one element into the user-interface, and
associating at least one property path with one inserted element, the property path including a concatenation of a plurality of identifiers, the concatenation of identifiers defining a path through
the components ofthe application to a property at the end ofthe concatenation.
57. The system of claim 56 wherein the property connector module is further configured to
determine a list of property paths associated with the application, and to select the property path
from the list to associate with the one inserted element ofthe user-interface from the list of property paths.
58. The system of claim 56 wherein the property com ector module is further configured to receive a property path description file associated with the application, the property path ' description file including a plurality of identifiers associated with the application and a
relationship between the plurality of identifiers.
59. The system of claim 56 wherein the property comiector module is further configured to execute the application, and to interact with the executing application to determine a plurality of identifiers associated with the application and a relationship between the plurality of identifiers.
60. The system of claim 56 wherein the property connector module is further configured to
transmit a request to register for a property change message corresponding to the property path
associated with the element ofthe user-interface.
61. The system of claim 56 wherein the property connector module is further configured to provide at least one predefined element, and to enable selection from the at least one predefined
element to insert the selected predefined element into the user-interface.
62. The system of claim 61 wherein the predefined element comprises one of an image type
user-interface element, an iterator type user-interface element, a text type user-interface element, a hidden type user-interface element, a value type user-interface element, a slider type user- interface element, a treeview type user-interface element, a button type user-interface element, an
iframe type user-interface element, a tab type user-interface element, a flipflop type user-
interface element, a deck type user-interface element, a dropdown type user-interface element, a radio type user-interface element, and a script type user-interface element.
63. The system of claim 56 further comprising:
a client node including:
the user interface having one or more elements; and a client portion ofthe property connector module.
64. The system of claim 56 further comprising:
a server node including:
the application; and
a server portion ofthe property connector module.
65. A method of establishing an extension interface between an application and a user interface, the method comprising:
defining an extension having at least one extension component, each extension component being identified with an extension identifier;
associating an element ofthe user-interface with a first property path, the first property
path including a concatenation of identifiers including at least one extension identifier; and
mapping the first property path to a second property path, the second property path including a concatenation of a plurality of property identifiers, the concatenation of property
identifiers defining a path through a plurality of application components to an application property at the end of the concatenation.
66. The method of claim 65 wherein the step of associating comprises associating the
element ofthe user-interface with the first property path, the first property path including a concatenation of identifiers including at least one extension identifier and at least one property
identifier, the concatenation of identifiers defining a path through the extension components to an extension property at the end of the concatenation.
67. The method of claim 65 further comprising changing an extension property at the end of the concatenation ofthe first property path to a current state ofthe application property at the end ofthe concatenation ofthe second property path in response to an extension method.
68. The method of claim 67 wherein the extension method comprises at least one of a refresh method and an update method.
69. The method of claim 65 further comprising changing the application property at the end
ofthe concatenation ofthe second property path to a current state ofthe extension property at the end ofthe concatenation ofthe first property path in response to an extension method.
70. The method of claim 69 wherein the extension method comprises a submit method.
71. The method of claim 65 wherein concatenation of identifiers of the first property path
further includes an indexed identifier and the step of mapping comprises:
mapping the first property path to a second property path, the second property path including
a concatenation of a plurality of property identifiers, the concatenation of property identifiers defining a path tlirough the application components to an indexed application property at the end
ofthe concatenation,
wherein a first index ofthe indexed identifier is mapped to a first range of indices ofthe
indexed application property, the range determined by a parameter .
72. The method of claim 71 wherein the extension is a page extension and an index ofthe
indexed identifier corresponds to a page.
73. The method of claim 65 further comprising receiving an extension command including a
parameter.
74. The method of claim 73 wherein the parameter comprises at least one of string id, string type and string args.
75. The method of claim 73 wherein the parameter comprises a value indicative of a range of
indices for an indexed application property.
76. The method of claim 65 wherein the first property path includes a wildcard identifier.
77. The method of claim 65 wherein the step of mapping comprises:
identifying a second and third property path, each property path including a
concatenation of a plurality of property identifiers, the concatenation of property identifiers
defining a respective path through a plurality of application components to a respective application property at the end ofthe concatenation;
adding a value of each respective application property ofthe second and third property
paths to generate a combined value; and
mapping the first property path to the combined value.
78. The method of claim 65 further comprising dynamically binding the first property path to
one ofthe extension components.
79. A system for establishing an extension interface between an application and a user
interface, the system comprising:
a property connector module to provide an extension having at least one extension
component, each extension component being identified with an extension identifier; to identify an association between an element ofthe user-interface and a first property path, the first property path including a concatenation of identifiers including at least one extension identifier
and to map the first property path to a second property path, the second property path including a
concatenation of a plurality of property identifiers, the concatenation of property identifiers
defining a path through a plurality of application components to an application property at the end ofthe concatenation.
80. The system of claim 79 wherein the property connector module is further configured to
identify an association between the element ofthe user-interface and the first property path, the first property path including a concatenation of identifiers including at least one extension
identifier and at least one property identifier, the concatenation of identifiers defining a path
through the extension components to an extension property at the end ofthe concatenation.
81. The system of claim 79 wherein the property comiector module is further configured to change an extension property at the end ofthe concatenation ofthe first property path to a current state ofthe application property at the end ofthe concatenation ofthe second property path in
response to an extension method.
82. The system of claim 81 wherein the extension method comprises at least one of a refresh method and an update method.
83. The system of claim 79 wherein the property connector module is further configured to
change the application property at the end ofthe concatenation ofthe second property path to a
current state ofthe extension property at the end ofthe concatenation ofthe first property path in response to an extension method.
84. The system of claim 83 wherein the extension method comprises a submit method.
85. The system of claim 79 wherein concatenation of identifiers of the first property path
further includes an indexed identifier and the property connector module is further configured to
map the first property path to a second property path, the second property path including a concatenation of a plurality of property identifiers, the concatenation of property identifiers
defining a path through the application components to an indexed application property at the end ofthe concatenation,
wherein a first index ofthe indexed identifier is mapped to a first range of indices ofthe indexed application property, the range determined by a parameter .
86. The system of claim 85 wherein the extension is a page extension and an index ofthe indexed identifier corresponds to a page.
87. The system of claim 79 wherein the property coimector module is further configured to
receive an extension command including a parameter.
88. The system of claim 87 wherein the parameter comprises at least one of string id, string type and string args.
89. The system of claim 87 wherein the parameter comprises a value indicative of a range of indices for an indexed application property.
90. The system of claim 79 wherein the first property path includes a wildcard identifier.
91. The system of claim 79 wherein the property connector module is further configured to identify a second and third property path, each property path including a concatenation of a
plurality of property identifiers, the concatenation of property identifiers defining a respective path through a plurality of application components to a respective application property at the end
ofthe concatenation to add a value of each respective application property ofthe second and
third property paths to generate a combined value and to map the first property path to the
combined value.
92. The system of claim 79 wherein the property comiector module is further configured to
dynamically bind the first property path to one ofthe extension components.
93. The system of claim 79 further comprising:
a client node including:
the user interface having one or more elements; and
a client portion ofthe property connector module. The system of claim 79 further comprising:
a server node including:
the application; and
a server portion ofthe property connector module.
PCT/US2001/048335 2000-12-12 2001-12-12 Methods and apparatus for creating a user interface using property paths WO2002049281A2 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
AU2002232582A AU2002232582A1 (en) 2000-12-12 2001-12-12 Methods and apparatus for creating a user interface using property paths
GB0309655A GB2389292A (en) 2000-12-12 2001-12-12 Methods and apparatus for creating a user interface using property paths

Applications Claiming Priority (6)

Application Number Priority Date Filing Date Title
US25499500P 2000-12-12 2000-12-12
US60/254,995 2000-12-12
US09/846,884 US20020105548A1 (en) 2000-12-12 2001-05-01 Methods and apparatus for creating a user interface using property paths
US09/846,896 US7194743B2 (en) 2000-12-12 2001-05-01 Methods and apparatus for communicating changes between a user interface and an executing application using property paths
US09/846,884 2001-05-01
US09/846,896 2001-05-01

Publications (3)

Publication Number Publication Date
WO2002049281A2 true WO2002049281A2 (en) 2002-06-20
WO2002049281A3 WO2002049281A3 (en) 2003-04-17
WO2002049281A8 WO2002049281A8 (en) 2004-05-21

Family

ID=26944358

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2001/048335 WO2002049281A2 (en) 2000-12-12 2001-12-12 Methods and apparatus for creating a user interface using property paths

Country Status (4)

Country Link
US (3) US7194743B2 (en)
AU (1) AU2002232582A1 (en)
GB (1) GB2389292A (en)
WO (1) WO2002049281A2 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112579951A (en) * 2019-09-30 2021-03-30 北京国双科技有限公司 Page element selection method and device, storage medium and equipment

Families Citing this family (194)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH08263438A (en) * 1994-11-23 1996-10-11 Xerox Corp Distribution and use control system of digital work and access control method to digital work
US7117239B1 (en) 2000-07-28 2006-10-03 Axeda Corporation Reporting the state of an apparatus to a remote computer
US8108543B2 (en) 2000-09-22 2012-01-31 Axeda Corporation Retrieving data from a server
US7185014B1 (en) 2000-09-22 2007-02-27 Axeda Corporation Retrieving data from a server
US7620731B1 (en) * 2001-02-21 2009-11-17 Microsoft Corporation Isolated persistent storage
JP2003177992A (en) * 2001-12-10 2003-06-27 Seiko Epson Corp Differential communication system, differential communication equipment, differential communication program and differential communication method
US7254601B2 (en) 2001-12-20 2007-08-07 Questra Corporation Method and apparatus for managing intelligent assets in a distributed environment
US7246325B2 (en) * 2001-12-20 2007-07-17 Nokia Corporation System and method for functional elements
US7178149B2 (en) 2002-04-17 2007-02-13 Axeda Corporation XML scripting of soap commands
US7412658B2 (en) 2002-11-14 2008-08-12 Sap Ag Modeling system for graphic user interface
US7966418B2 (en) 2003-02-21 2011-06-21 Axeda Corporation Establishing a virtual tunnel between two computer programs
US7712034B2 (en) 2003-03-24 2010-05-04 Microsoft Corporation System and method for shell browser
US7627552B2 (en) 2003-03-27 2009-12-01 Microsoft Corporation System and method for filtering and organizing items based on common elements
US7823077B2 (en) * 2003-03-24 2010-10-26 Microsoft Corporation System and method for user modification of metadata in a shell browser
US7421438B2 (en) 2004-04-29 2008-09-02 Microsoft Corporation Metadata editing control
US7240292B2 (en) * 2003-04-17 2007-07-03 Microsoft Corporation Virtual address bar user interface control
US7769794B2 (en) 2003-03-24 2010-08-03 Microsoft Corporation User interface for a file system shell
US7650575B2 (en) 2003-03-27 2010-01-19 Microsoft Corporation Rich drag drop user interface
US7925682B2 (en) 2003-03-27 2011-04-12 Microsoft Corporation System and method utilizing virtual folders
EP1477893B1 (en) * 2003-05-16 2015-09-16 Sap Se Method for inputting data in a computer system.
US7519969B2 (en) * 2003-05-17 2009-04-14 Microsoft Corporation System and method for controlling user interface properties with data
US7506341B2 (en) * 2003-05-17 2009-03-17 Microsoft Corporation System and method for controlling user interface properties with data
JP4818590B2 (en) * 2003-05-28 2011-11-16 シャープ株式会社 Service using terminal, mobile phone terminal, television receiver terminal, connector providing server, and data structure of connector data
US7869068B2 (en) * 2003-06-27 2011-01-11 Zoran Corporation Printer driver extension and related method
US20050027731A1 (en) * 2003-07-30 2005-02-03 Daniel Revel Compression dictionaries
US20050027549A1 (en) * 2003-08-01 2005-02-03 Sbc Knowledge Ventures, L.P. Multi-layer architecture for property management
CA2438362C (en) * 2003-08-26 2011-05-31 John William Comeau A method and system for synchronizing a client user interface with server backend
US7584463B2 (en) 2003-08-27 2009-09-01 Microsoft Corporation State as a first-class citizen of an imperative language
WO2005043386A1 (en) * 2003-09-30 2005-05-12 Siemens Aktiengesellschaft Method and system for configuring the language of a computer programme
US20050188174A1 (en) * 2003-10-12 2005-08-25 Microsoft Corporation Extensible creation and editing of collections of objects
US7644376B2 (en) * 2003-10-23 2010-01-05 Microsoft Corporation Flexible architecture for notifying applications of state changes
US8024335B2 (en) 2004-05-03 2011-09-20 Microsoft Corporation System and method for dynamically generating a selectable search extension
US7328217B2 (en) * 2003-11-26 2008-02-05 Symantec Operating Corporation System and method for detecting and storing file identity change information within a file system
US7421707B2 (en) * 2003-12-22 2008-09-02 Sun Microsystems, Inc. System and method for inducing asynchronous behavioral changes in a managed application process
US20050160414A1 (en) * 2004-01-21 2005-07-21 Nokia Corporation System and method for dynamically adding features to software applications
US20050240489A1 (en) * 2004-03-12 2005-10-27 Onfolio, Inc. Retaining custom item order
US20050216886A1 (en) * 2004-03-12 2005-09-29 Onfolio, Inc. Editing multi-layer documents
US7702678B2 (en) * 2004-03-12 2010-04-20 Microsoft Corporation Search capture
US20050216825A1 (en) * 2004-03-12 2005-09-29 Onfolio, Inc. Local storage of script-containing content
US20050216837A1 (en) * 2004-03-12 2005-09-29 Onfolio, Inc. Unread-state management
US20050216856A1 (en) * 2004-03-23 2005-09-29 Matti Michael C System and method for displaying information on an interface device
US7694236B2 (en) 2004-04-23 2010-04-06 Microsoft Corporation Stack icons representing multiple objects
US7657846B2 (en) 2004-04-23 2010-02-02 Microsoft Corporation System and method for displaying stack icons
US8707209B2 (en) 2004-04-29 2014-04-22 Microsoft Corporation Save preview representation of files being created
US7937413B2 (en) * 2004-05-04 2011-05-03 International Business Machines Corporation Self-adaptive prefix encoding for stable node identifiers
US7363578B2 (en) * 2004-06-03 2008-04-22 Microsoft Corporation Method and apparatus for mapping a data model to a user interface model
US7665014B2 (en) * 2004-06-03 2010-02-16 Microsoft Corporation Method and apparatus for generating forms using form types
US7424485B2 (en) * 2004-06-03 2008-09-09 Microsoft Corporation Method and apparatus for generating user interfaces based upon automation with full flexibility
US8606723B2 (en) * 2004-06-04 2013-12-10 Sap Ag Consistent set of interfaces derived from a business object model
EP1782366A2 (en) * 2004-06-04 2007-05-09 Sap Ag Consistent set of interfaces derived from a business object
US7657530B2 (en) * 2004-06-07 2010-02-02 Symantec Operating Corporation System and method for file system content processing
US8694397B2 (en) * 2004-06-18 2014-04-08 Sap Ag Consistent set of interfaces derived from a business object model
US7954110B1 (en) * 2004-06-22 2011-05-31 Apple Inc. Observing properties associated with an object in an object-oriented programming platform
US7546543B2 (en) * 2004-06-25 2009-06-09 Apple Inc. Widget authoring and editing environment
US7761800B2 (en) 2004-06-25 2010-07-20 Apple Inc. Unified interest layer for user interface
US8453065B2 (en) 2004-06-25 2013-05-28 Apple Inc. Preview and installation of user interface elements in a display environment
US8302020B2 (en) 2004-06-25 2012-10-30 Apple Inc. Widget authoring and editing environment
US7490295B2 (en) * 2004-06-25 2009-02-10 Apple Inc. Layer for accessing user interface elements
US8566732B2 (en) 2004-06-25 2013-10-22 Apple Inc. Synchronization of widgets and dashboards
US20060026522A1 (en) * 2004-07-27 2006-02-02 Microsoft Corporation Method and apparatus for revising data models and maps by example
US7523129B1 (en) * 2004-09-15 2009-04-21 Microsoft Corporation Data-binding enhancements
JP4191672B2 (en) * 2004-12-14 2008-12-03 ザイオソフト株式会社 Image processing system such as volume rendering
US8744937B2 (en) * 2005-02-25 2014-06-03 Sap Ag Consistent set of interfaces derived from a business object model
US20060195794A1 (en) * 2005-02-28 2006-08-31 Microsoft Corporation User interface element property customization
US7774366B2 (en) 2005-03-08 2010-08-10 Salesforce.Com, Inc. Systems and methods for implementing multi-application tabs and tab sets
US7483882B1 (en) * 2005-04-11 2009-01-27 Apple Inc. Dynamic management of multiple persistent data stores
US20060242591A1 (en) * 2005-04-22 2006-10-26 Microsoft Corporation File dialog user interfaces and creation of same
US8195646B2 (en) 2005-04-22 2012-06-05 Microsoft Corporation Systems, methods, and user interfaces for storing, searching, navigating, and retrieving electronic information
US8543931B2 (en) 2005-06-07 2013-09-24 Apple Inc. Preview including theme based installation of user interface elements in a display environment
US7805419B2 (en) * 2005-07-11 2010-09-28 Application Security, Inc. System for tracking and analyzing the integrity of an application
US8001076B2 (en) 2005-07-12 2011-08-16 International Business Machines Corporation Ranging scalable time stamp data synchronization
US7665028B2 (en) 2005-07-13 2010-02-16 Microsoft Corporation Rich drag drop user interface
KR100774874B1 (en) * 2005-07-30 2007-11-08 엘지전자 주식회사 Plasma display and driving method thereof
US7529726B2 (en) * 2005-08-22 2009-05-05 International Business Machines Corporation XML sub-document versioning method in XML databases using record storages
US8543614B2 (en) * 2005-08-22 2013-09-24 International Business Machines Corporation Packing nodes into records to store XML XQuery data model and other hierarchically structured data
US8572125B2 (en) 2005-08-22 2013-10-29 International Business Machines Corporation Scalable storage schemes for native XML column data of relational tables
US7743336B2 (en) 2005-10-27 2010-06-22 Apple Inc. Widget security
US7752556B2 (en) 2005-10-27 2010-07-06 Apple Inc. Workflow widgets
US7954064B2 (en) 2005-10-27 2011-05-31 Apple Inc. Multiple dashboards
US8543824B2 (en) 2005-10-27 2013-09-24 Apple Inc. Safe distribution and use of content
US9104294B2 (en) 2005-10-27 2015-08-11 Apple Inc. Linked widgets
US7707514B2 (en) * 2005-11-18 2010-04-27 Apple Inc. Management of user interface elements in a display environment
TWI287744B (en) * 2005-11-22 2007-10-01 Inst Information Industry Method and system for discover capabilities of communication device
US8374931B2 (en) * 2006-03-31 2013-02-12 Sap Ag Consistent set of interfaces derived from a business object model
US8364653B2 (en) * 2006-04-05 2013-01-29 Sap Ag Triggering server state changes with references
WO2008005102A2 (en) * 2006-05-13 2008-01-10 Sap Ag Consistent set of interfaces derived from a business object model
US7487201B1 (en) * 2006-06-30 2009-02-03 Sun Microsystems, Inc. Method and system for providing framework for Java based AJAX web applications
US8392364B2 (en) * 2006-07-10 2013-03-05 Sap Ag Consistent set of interfaces derived from a business object model
US8869027B2 (en) 2006-08-04 2014-10-21 Apple Inc. Management and generation of dashboards
US8566193B2 (en) * 2006-08-11 2013-10-22 Sap Ag Consistent set of interfaces derived from a business object model
US8402473B1 (en) 2006-09-28 2013-03-19 Sap Ag Managing consistent interfaces for demand business objects across heterogeneous systems
US8370479B2 (en) 2006-10-03 2013-02-05 Axeda Acquisition Corporation System and method for dynamically grouping devices based on present device conditions
US7614003B2 (en) * 2006-10-23 2009-11-03 Adobe Systems Incorporated Rendering hypertext markup language content
US8490117B1 (en) 2006-10-23 2013-07-16 Adobe Systems Incorporated Bridging script engines
US8020089B1 (en) 2006-10-23 2011-09-13 Adobe Systems Incorporated Rendering hypertext markup language content
US8584130B2 (en) * 2006-11-30 2013-11-12 International Business Machines Corporation Allocation of resources on computer systems
US8402060B2 (en) * 2006-12-07 2013-03-19 Sap Ag Software for managing data between a client and server
US8065397B2 (en) 2006-12-26 2011-11-22 Axeda Acquisition Corporation Managing configurations of distributed devices
US7941497B2 (en) * 2007-02-22 2011-05-10 Research In Motion Limited Community-based method and system for creating and subscribing to dynamic push channels
US8954871B2 (en) 2007-07-18 2015-02-10 Apple Inc. User-centric widgets and dashboards
JP5064134B2 (en) * 2007-08-03 2012-10-31 株式会社日立製作所 Memory management method and computer using the method
US8667415B2 (en) 2007-08-06 2014-03-04 Apple Inc. Web widgets
FR2923922A1 (en) * 2007-11-16 2009-05-22 France Telecom METHOD FOR CONTROLLING AT LEAST ONE APPLICATION PROCESS AND CORRESPONDING COMPUTER PROGRAM PRODUCT
US8417593B2 (en) * 2008-02-28 2013-04-09 Sap Ag System and computer-readable medium for managing consistent interfaces for business objects across heterogeneous systems
US8433585B2 (en) * 2008-03-31 2013-04-30 Sap Ag Managing consistent interfaces for business objects across heterogeneous systems
US8423418B2 (en) * 2008-03-31 2013-04-16 Sap Ag Managing consistent interfaces for business objects across heterogeneous systems
US8577991B2 (en) * 2008-03-31 2013-11-05 Sap Ag Managing consistent interfaces for internal service request business objects across heterogeneous systems
US8589263B2 (en) * 2008-03-31 2013-11-19 Sap Ag Managing consistent interfaces for retail business objects across heterogeneous systems
US20090248429A1 (en) * 2008-03-31 2009-10-01 Sap Ag Managing Consistent Interfaces for Sales Price Business Objects Across Heterogeneous Systems
US8364715B2 (en) 2008-03-31 2013-01-29 Sap Ag Managing consistent interfaces for automatic identification label business objects across heterogeneous systems
US8413165B2 (en) 2008-03-31 2013-04-02 Sap Ag Managing consistent interfaces for maintenance order business objects across heterogeneous systems
US8370233B2 (en) * 2008-03-31 2013-02-05 Sap Ag Managing consistent interfaces for business objects across heterogeneous systems
US8930248B2 (en) * 2008-03-31 2015-01-06 Sap Se Managing consistent interfaces for supply network business objects across heterogeneous systems
US20090248463A1 (en) * 2008-03-31 2009-10-01 Emmanuel Piochon Managing Consistent Interfaces For Trading Business Objects Across Heterogeneous Systems
US20090249358A1 (en) * 2008-03-31 2009-10-01 Sap Ag Managing Consistent Interfaces for Kanban Business Objects Across Heterogeneous Systems
US8473317B2 (en) * 2008-03-31 2013-06-25 Sap Ag Managing consistent interfaces for service part business objects across heterogeneous systems
US8261188B2 (en) * 2008-04-02 2012-09-04 Colorquick, L.L.C. Method of associating properties or fields of graphical objects with each other for efficient composition of documents
US8793117B1 (en) * 2008-04-16 2014-07-29 Scalable Network Technologies, Inc. System and method for virtualization of networking system software via emulation
KR20090110202A (en) 2008-04-17 2009-10-21 삼성전자주식회사 Method and apparatus for displaying personalized user interface
KR101560183B1 (en) * 2008-04-17 2015-10-15 삼성전자주식회사 / Method and apparatus for providing/receiving user interface
KR101545137B1 (en) * 2008-04-17 2015-08-19 삼성전자주식회사 Method and apparatus for generating user interface
US8875032B2 (en) * 2008-05-08 2014-10-28 Dialogic Corporation System and method for dynamic configuration of components of web interfaces
US20090292982A1 (en) * 2008-05-22 2009-11-26 Samar Choudhary Automated propagation of user interaction effects to equivalent ui artifacts
US8645228B2 (en) * 2008-06-26 2014-02-04 Sap Ag Managing consistent interfaces for business objects across heterogeneous systems
US20090326988A1 (en) 2008-06-26 2009-12-31 Robert Barth Managing consistent interfaces for business objects across heterogeneous systems
US8566185B2 (en) * 2008-06-26 2013-10-22 Sap Ag Managing consistent interfaces for financial instrument business objects across heterogeneous systems
US8671064B2 (en) * 2008-06-26 2014-03-11 Sap Ag Managing consistent interfaces for supply chain management business objects across heterogeneous systems
US7614047B1 (en) * 2008-08-21 2009-11-03 International Business Machines Corporation Change indication for a service offering
US8577760B2 (en) 2008-11-25 2013-11-05 Sap Ag Managing consistent interfaces for tax authority business objects across heterogeneous systems
US8463666B2 (en) * 2008-11-25 2013-06-11 Sap Ag Managing consistent interfaces for merchandise and assortment planning business objects across heterogeneous systems
US20100153297A1 (en) 2008-12-12 2010-06-17 Sap Ag Managing Consistent Interfaces for Credit Portfolio Business Objects Across Heterogeneous Systems
US9009661B2 (en) * 2008-12-18 2015-04-14 Adobe Systems Incorporated Platform sensitive application characteristics
US9009662B2 (en) * 2008-12-18 2015-04-14 Adobe Systems Incorporated Platform sensitive application characteristics
DE102009020918A1 (en) * 2009-05-12 2010-11-18 Siemens Aktiengesellschaft Method and computer system for managing parallel medical applications
US8352913B2 (en) * 2009-08-07 2013-01-08 Adobe Systems Incorporated Generating and resolving component names in an integrated development environment
US8396751B2 (en) * 2009-09-30 2013-03-12 Sap Ag Managing consistent interfaces for merchandising business objects across heterogeneous systems
US9054913B1 (en) 2009-11-30 2015-06-09 Dell Software Inc. Network protocol proxy
US20110191699A1 (en) * 2010-02-02 2011-08-04 Dynavox Systems, Llc System and method of interfacing interactive content items and shared data variables
US20110246913A1 (en) * 2010-03-30 2011-10-06 Microsoft Corporation Automated User Interface Generator
US8990427B2 (en) 2010-04-13 2015-03-24 Synactive, Inc. Method and apparatus for accessing an enterprise resource planning system via a mobile device
US9026913B2 (en) * 2010-06-11 2015-05-05 Linkedin Corporation Replacing an image with a media player
US9275685B2 (en) 2010-06-11 2016-03-01 Linkedin Corporation Smooth playing of video
US8515794B2 (en) 2010-06-15 2013-08-20 Sap Ag Managing consistent interfaces for employee time event and human capital management view of payroll process business objects across heterogeneous systems
US8417588B2 (en) 2010-06-15 2013-04-09 Sap Ag Managing consistent interfaces for goods tag, production bill of material hierarchy, and release order template business objects across heterogeneous systems
US8412603B2 (en) 2010-06-15 2013-04-02 Sap Ag Managing consistent interfaces for currency conversion and date and time business objects across heterogeneous systems
US8370272B2 (en) 2010-06-15 2013-02-05 Sap Ag Managing consistent interfaces for business document message monitoring view, customs arrangement, and freight list business objects across heterogeneous systems
US8732083B2 (en) 2010-06-15 2014-05-20 Sap Ag Managing consistent interfaces for number range, number range profile, payment card payment authorisation, and product template template business objects across heterogeneous systems
US8364608B2 (en) 2010-06-15 2013-01-29 Sap Ag Managing consistent interfaces for export declaration and export declaration request business objects across heterogeneous systems
US9135585B2 (en) 2010-06-15 2015-09-15 Sap Se Managing consistent interfaces for property library, property list template, quantity conversion virtual object, and supplier property specification business objects across heterogeneous systems
US20120102412A1 (en) * 2010-10-25 2012-04-26 Microsoft Corporation Synchronization of form fields in a client-server environment
US8898589B2 (en) 2011-06-30 2014-11-25 International Business Machines Corporation Flattening a subset of configuration user interface (UI) panels in a hierarchy of UI panels
US8442980B2 (en) * 2011-07-07 2013-05-14 Oracle International Corporation Attribute change coalescing in order to deal with component moves on a page
US8725654B2 (en) 2011-07-28 2014-05-13 Sap Ag Managing consistent interfaces for employee data replication business objects across heterogeneous systems
US8775280B2 (en) 2011-07-28 2014-07-08 Sap Ag Managing consistent interfaces for financial business objects across heterogeneous systems
US8666845B2 (en) 2011-07-28 2014-03-04 Sap Ag Managing consistent interfaces for a customer requirement business object across heterogeneous systems
US8601490B2 (en) 2011-07-28 2013-12-03 Sap Ag Managing consistent interfaces for business rule business object across heterogeneous systems
US8560392B2 (en) 2011-07-28 2013-10-15 Sap Ag Managing consistent interfaces for a point of sale transaction business object across heterogeneous systems
US8521838B2 (en) 2011-07-28 2013-08-27 Sap Ag Managing consistent interfaces for communication system and object identifier mapping business objects across heterogeneous systems
US8984050B2 (en) 2012-02-16 2015-03-17 Sap Se Consistent interface for sales territory message type set 2
US8756274B2 (en) 2012-02-16 2014-06-17 Sap Ag Consistent interface for sales territory message type set 1
US9237425B2 (en) 2012-02-16 2016-01-12 Sap Se Consistent interface for feed event, feed event document and feed event type
US9232368B2 (en) 2012-02-16 2016-01-05 Sap Se Consistent interface for user feed administrator, user feed event link and user feed settings
US8762454B2 (en) 2012-02-16 2014-06-24 Sap Ag Consistent interface for flag and tag
US8762453B2 (en) 2012-02-16 2014-06-24 Sap Ag Consistent interface for feed collaboration group and feed event subscription
US9075616B2 (en) 2012-03-19 2015-07-07 Enterpriseweb Llc Declarative software application meta-model and system for self-modification
US9069627B2 (en) * 2012-06-06 2015-06-30 Synactive, Inc. Method and apparatus for providing a dynamic execution environment in network communication between a client and a server
US9367826B2 (en) 2012-06-28 2016-06-14 Sap Se Consistent interface for entitlement product
US9246869B2 (en) 2012-06-28 2016-01-26 Sap Se Consistent interface for opportunity
US8756135B2 (en) 2012-06-28 2014-06-17 Sap Ag Consistent interface for product valuation data and product valuation level
US8615451B1 (en) 2012-06-28 2013-12-24 Sap Ag Consistent interface for goods and activity confirmation
US9400998B2 (en) 2012-06-28 2016-07-26 Sap Se Consistent interface for message-based communication arrangement, organisational centre replication request, and payment schedule
US8949855B2 (en) 2012-06-28 2015-02-03 Sap Se Consistent interface for address snapshot and approval process definition
US8521621B1 (en) 2012-06-28 2013-08-27 Sap Ag Consistent interface for inbound delivery request
WO2014000200A1 (en) 2012-06-28 2014-01-03 Sap Ag Consistent interface for document output request
US9300745B2 (en) * 2012-07-27 2016-03-29 Synactive, Inc. Dynamic execution environment in network communications
US9547833B2 (en) 2012-08-22 2017-01-17 Sap Se Consistent interface for financial instrument impairment calculation
US9076112B2 (en) 2012-08-22 2015-07-07 Sap Se Consistent interface for financial instrument impairment expected cash flow analytical result
US9043236B2 (en) 2012-08-22 2015-05-26 Sap Se Consistent interface for financial instrument impairment attribute values analytical result
US8903178B2 (en) 2012-11-02 2014-12-02 International Business Machines Corporation Adjusting application properties
US9811233B2 (en) * 2013-02-12 2017-11-07 Ab Initio Technology Llc Building applications for configuring processes
US9191343B2 (en) 2013-03-15 2015-11-17 Sap Se Consistent interface for appointment activity business object
US9191357B2 (en) 2013-03-15 2015-11-17 Sap Se Consistent interface for email activity business object
US9626163B2 (en) * 2013-04-26 2017-04-18 Limited Liability Company “1C” Method for automated application interface change
US9292616B2 (en) * 2014-01-13 2016-03-22 International Business Machines Corporation Social balancer for indicating the relative priorities of linked objects
US9489442B1 (en) 2014-02-04 2016-11-08 Emc Corporation Prevention of circular event publication in publish/subscribe model using path vector
US10963539B2 (en) * 2014-09-10 2021-03-30 Mk Systems Usa Inc. Interactive web application editor
JP2017011517A (en) * 2015-06-23 2017-01-12 株式会社リコー Device, information processing system, information processing method, and program
CN105468365B (en) * 2015-11-20 2021-04-23 厦门雅迅网络股份有限公司 Method for solving tree control node number limitation
US10656802B2 (en) 2017-04-05 2020-05-19 Microsoft Technology Licensing, Llc User interface component registry
US11216424B2 (en) 2018-06-07 2022-01-04 Spatika Technologies Inc. Dynamically rendering an application programming interface for internet of things applications
US10666718B2 (en) * 2018-06-07 2020-05-26 Spatika Technologies Inc. Dynamic data transport between enterprise and business computing systems
US10996948B2 (en) 2018-11-12 2021-05-04 Bank Of America Corporation Software code mining system for assimilating legacy system functionalities
US11368373B2 (en) * 2020-06-16 2022-06-21 Citrix Systems, Inc. Invoking microapp actions from user applications
US11379253B2 (en) 2020-11-30 2022-07-05 International Business Machines Corporation Training chatbots for remote troubleshooting

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5850548A (en) * 1994-11-14 1998-12-15 Borland International, Inc. System and methods for visual programming based on a high-level hierarchical data flow model
GB2327836A (en) * 1997-07-29 1999-02-03 Ibm User interface controls for a computer system

Family Cites Families (167)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPS57157362A (en) 1981-03-25 1982-09-28 Hitachi Ltd Method and apparatus of execution path career data pickup for architecture program
US5737622A (en) 1986-04-14 1998-04-07 National Instruments Corporation Method and apparatus for more efficient function synchronization in a data flow program
US5481740A (en) * 1986-04-14 1996-01-02 National Instruments Corporation Method and apparatus for providing autoprobe features in a graphical data flow diagram
US5291587A (en) 1986-04-14 1994-03-01 National Instruments, Inc. Graphical system for executing a process and for programming a computer to execute a process, including graphical variable inputs and variable outputs
US5341477A (en) 1989-02-24 1994-08-23 Digital Equipment Corporation Broker for computer network server selection
US5057996A (en) 1989-06-29 1991-10-15 Digital Equipment Corporation Waitable object creation system and method in an object based computer operating system
US5129084A (en) 1989-06-29 1992-07-07 Digital Equipment Corporation Object container transfer system and method in an object based computer operating system
US5297283A (en) 1989-06-29 1994-03-22 Digital Equipment Corporation Object transferring system and method in an object based computer operating system
US5187790A (en) 1989-06-29 1993-02-16 Digital Equipment Corporation Server impersonation of client processes in an object based computer operating system
US5619638A (en) 1989-07-31 1997-04-08 Hewlett-Packard Company Object based computer system having representation objects for providing interpretative views onto a data object
US5297279A (en) 1990-05-30 1994-03-22 Texas Instruments Incorporated System and method for database management supporting object-oriented programming
AU639802B2 (en) 1990-08-14 1993-08-05 Oracle International Corporation Methods and apparatus for providing dynamic invocation of applications in a distributed heterogeneous environment
US5423041A (en) 1990-09-28 1995-06-06 Texas Instruments Incorporated Coupling rules to an object-oriented program
US5204947A (en) 1990-10-31 1993-04-20 International Business Machines Corporation Application independent (open) hypermedia enablement services
US5291487A (en) * 1991-01-24 1994-03-01 Micom Communications Corp. Apparatus for, and method of, packing and unpacking information in transmission lines
JPH0546568A (en) * 1991-08-08 1993-02-26 Internatl Business Mach Corp <Ibm> Dispersion application execution device and method
EP0546682A3 (en) 1991-12-12 1993-12-08 Ibm Parent class shadowing
US5386558A (en) 1992-02-24 1995-01-31 Adapsys, Inc. Method and apparatus for executing control system functions in a computer system
US5371891A (en) 1992-04-09 1994-12-06 Microsoft Corporation Method for object construction in a compiler for an object-oriented programming language
FR2690260B1 (en) 1992-04-17 1997-01-03 Bull Sa USE OF A VERY HIGH LEVEL BIDIRECTIONAL PROTOCOL FOR COMMUNICATION BETWEEN A HYPERMEDIA SYSTEM AND A PLURALITY OF EDITORS.
US5327562A (en) 1992-05-06 1994-07-05 Microsoft Corporation Method for implementing virtual function tables in a compiler for an object-oriented programming language
US5339430A (en) 1992-07-01 1994-08-16 Telefonaktiebolaget L M Ericsson System for dynamic run-time binding of software modules in a computer system
US5515536A (en) 1992-11-13 1996-05-07 Microsoft Corporation Method and system for invoking methods of an object through a dispatching interface
DE69309485T2 (en) 1992-11-13 1997-07-10 Microsoft Corp METHOD FOR DISTRIBUTING INTERFACE POINTERS FOR REMOTE PROCEDURE CALLS
US5887133A (en) * 1997-01-15 1999-03-23 Health Hero Network System and method for modifying documents sent over a communications network
US5566302A (en) 1992-12-21 1996-10-15 Sun Microsystems, Inc. Method for executing operation call from client application using shared memory region and establishing shared memory region when the shared memory region does not exist
US5315703A (en) 1992-12-23 1994-05-24 Taligent, Inc. Object-oriented notification framework system
US5574898A (en) 1993-01-08 1996-11-12 Atria Software, Inc. Dynamic software version auditor which monitors a process to provide a list of objects that are accessed
US5437025A (en) 1993-01-26 1995-07-25 International Business Machines Corporation System and method for run time configuration of objects in an object oriented computing environment
US5369766A (en) 1993-03-25 1994-11-29 Taligent, Inc. Object-oriented loader system with support for different load formats
US5325533A (en) 1993-06-28 1994-06-28 Taligent, Inc. Engineering system for modeling computer programs
US5519867A (en) 1993-07-19 1996-05-21 Taligent, Inc. Object-oriented multitasking system
US5485617A (en) 1993-12-13 1996-01-16 Microsoft Corporation Method and system for dynamically generating object connections
US5499343A (en) 1993-12-17 1996-03-12 Taligent, Inc. Object-oriented networking system with dynamically configurable communication links
US5548726A (en) 1993-12-17 1996-08-20 Taligeni, Inc. System for activating new service in client server network by reconfiguring the multilayer network protocol stack dynamically within the server node
US5548723A (en) 1993-12-17 1996-08-20 Taligent, Inc. Object-oriented network protocol configuration system utilizing a dynamically configurable protocol stack
US5694546A (en) * 1994-05-31 1997-12-02 Reisman; Richard R. System for automatic unattended electronic information transport between a server and a client by a vendor provided transport software with a manifest list
US5517617A (en) 1994-06-29 1996-05-14 Digital Equipment Corporation Automatic assignment of addresses in a computer communications network
US5581765A (en) 1994-08-30 1996-12-03 International Business Machines Corporation System for combining a global object identifier with a local object address in a single object pointer
JP3508258B2 (en) 1994-09-09 2004-03-22 株式会社デンソー Ignition device for internal combustion engine
US5586312A (en) 1994-10-11 1996-12-17 Unisys Corporation Method and apparatus for using an independent transaction processing application as a service routine
US5838906A (en) 1994-10-17 1998-11-17 The Regents Of The University Of California Distributed hypermedia method for automatically invoking external application providing interaction and display of embedded objects within a hypermedia document
US5623656A (en) 1994-12-15 1997-04-22 Lucent Technologies Inc. Script-based data communication system and method utilizing state memory
US5530852A (en) 1994-12-20 1996-06-25 Sun Microsystems, Inc. Method for extracting profiles and topics from a first file written in a first markup language and generating files in different markup languages containing the profiles and topics for use in accessing data described by the profiles and topics
US5819093A (en) 1995-03-03 1998-10-06 Sun Microsystems, Inc. System and method for a distributed debugger for debugging distributed application programs
US5721876A (en) 1995-03-30 1998-02-24 Bull Hn Information Systems Inc. Sockets application program mechanism for proprietary based application programs running in an emulation environment
US5692183A (en) 1995-03-31 1997-11-25 Sun Microsystems, Inc. Methods and apparatus for providing transparent persistence in a distributed object operating environment
US5689664A (en) 1995-04-14 1997-11-18 Microsoft Corporation Interface sharing between objects
US5752031A (en) 1995-04-24 1998-05-12 Microsoft Corporation Queue object for controlling concurrency in a computer system
US5710918A (en) 1995-06-07 1998-01-20 International Business Machines Corporation Method for distributed task fulfillment of web browser requests
US5701451A (en) 1995-06-07 1997-12-23 International Business Machines Corporation Method for fulfilling requests of a web browser
US5737592A (en) 1995-06-19 1998-04-07 International Business Machines Corporation Accessing a relational database over the Internet using macro language files
US5657390A (en) 1995-08-25 1997-08-12 Netscape Communications Corporation Secure socket layer application program apparatus and method
US6249291B1 (en) * 1995-09-22 2001-06-19 Next Software, Inc. Method and apparatus for managing internet transactions
US5572643A (en) 1995-10-19 1996-11-05 Judson; David H. Web browser with dynamic display of information objects during linking
US5872973A (en) 1995-10-26 1999-02-16 Viewsoft, Inc. Method for managing dynamic relations between objects in dynamic object-oriented languages
US6370552B1 (en) * 1997-05-14 2002-04-09 Citrix Systems, Inc. Apparatus and method for displaying application output in an HTML document
US6169540B1 (en) * 1995-12-01 2001-01-02 Immersion Corporation Method and apparatus for designing force sensations in force feedback applications
US6161126A (en) 1995-12-13 2000-12-12 Immersion Corporation Implementing force feedback over the World Wide Web and other computer networks
US5768505A (en) 1995-12-19 1998-06-16 International Business Machines Corporation Object oriented mail server framework mechanism
US5859971A (en) 1996-02-15 1999-01-12 International Business Machines Corp. Differencing client/server communication system for use with CGI forms
US5938733A (en) 1996-03-08 1999-08-17 International Business Machines Corporation Object oriented representation of network requests in a client server model
US5764915A (en) 1996-03-08 1998-06-09 International Business Machines Corporation Object-oriented communication interface for network protocol access using the selected newly created protocol interface object and newly created protocol layer objects in the protocol stack
US5838910A (en) 1996-03-14 1998-11-17 Domenikos; Steven D. Systems and methods for executing application programs from a memory device linked to a server at an internet site
US5754830A (en) 1996-04-01 1998-05-19 Openconnect Systems, Incorporated Server and web browser terminal emulator for persistent connection to a legacy host system and method of operation
US5933841A (en) 1996-05-17 1999-08-03 Ameritech Corporation Structured document browser
US6434578B1 (en) * 1996-06-26 2002-08-13 Microsoft Corporation Generating instruction sequences using independently executable pane renderers
US6112242A (en) 1996-07-10 2000-08-29 Uln Corporation System and method for dynamic data interaction in a hypertext data processing system
US5757925A (en) * 1996-07-23 1998-05-26 Faybishenko; Yaroslav Secure platform independent cross-platform remote execution computer system and method
GB2316200A (en) 1996-08-08 1998-02-18 Ibm Accessing information about executable code
EP0853788A1 (en) 1996-08-08 1998-07-22 Agranat Systems, Inc. Embedded web server
US6658624B1 (en) * 1996-09-24 2003-12-02 Ricoh Company, Ltd. Method and system for processing documents controlled by active documents with embedded instructions
US6029182A (en) 1996-10-04 2000-02-22 Canon Information Systems, Inc. System for generating a custom formatted hypertext document by using a personal profile to retrieve hierarchical documents
US5944791A (en) 1996-10-04 1999-08-31 Contigo Software Llc Collaborative web browser
US5870545A (en) * 1996-12-05 1999-02-09 Hewlett-Packard Company System and method for performing flexible workflow process compensation in a distributed workflow management system
US5889942A (en) * 1996-12-18 1999-03-30 Orenshteyn; Alexander S. Secured system for accessing application services from a remote station
US6012087A (en) 1997-01-14 2000-01-04 Netmind Technologies, Inc. Unique-change detection of dynamic web pages using history tables of signatures
US5983268A (en) 1997-01-14 1999-11-09 Netmind Technologies, Inc. Spreadsheet user-interface for an internet-document change-detection tool
US5978842A (en) 1997-01-14 1999-11-02 Netmind Technologies, Inc. Distributed-client change-detection tool with change-detection augmented by multiple clients
US6101510A (en) 1997-01-29 2000-08-08 Microsoft Corporation Web browser control for incorporating web browser functionality into application programs
AU740007B2 (en) 1997-02-21 2001-10-25 Dudley John Mills Network-based classified information systems
US5978848A (en) 1997-03-14 1999-11-02 International Business Machines Corporation Web browser method and system for backgrounding a link access during slow link access time periods
US5905987A (en) 1997-03-19 1999-05-18 Microsoft Corporation Method, data structure, and computer program product for object state storage in a repository
US5796952A (en) 1997-03-21 1998-08-18 Dot Com Development, Inc. Method and apparatus for tracking client interaction with a network resource and creating client profiles and resource database
US6314456B1 (en) 1997-04-02 2001-11-06 Allegro Software Development Corporation Serving data from a resource limited system
US6262729B1 (en) * 1997-04-14 2001-07-17 Apple Computer, Inc. Method and apparatus for binding user interface objects to application objects
US5946697A (en) 1997-04-22 1999-08-31 Microsoft Corporation Rapid transfer of HTML files
JPH10301874A (en) 1997-04-22 1998-11-13 Internatl Business Mach Corp <Ibm> Remote operation method, server remotely operated from terminal through network and storage medium storing html file
US6230309B1 (en) * 1997-04-25 2001-05-08 Sterling Software, Inc Method and system for assembling and utilizing components in component object systems
US5937160A (en) 1997-05-01 1999-08-10 Reedy Creek Technologies, Inc. Systems, methods and computer program products for updating hypertext documents via electronic mail
US5877757A (en) 1997-05-23 1999-03-02 International Business Machines Corporation Method and system for providing user help information in network applications
US5983227A (en) * 1997-06-12 1999-11-09 Yahoo, Inc. Dynamic page generator
US5978828A (en) 1997-06-13 1999-11-02 Intel Corporation URL bookmark update notification of page content or location changes
US6304895B1 (en) * 1997-08-22 2001-10-16 Apex Inc. Method and system for intelligently controlling a remotely located computer
US6192382B1 (en) 1997-09-24 2001-02-20 Mediaone Group, Inc. Method and system for web site construction using HTML fragment caching
US6035332A (en) * 1997-10-06 2000-03-07 Ncr Corporation Method for monitoring user interactions with web pages from web server using data and command lists for maintaining information visited and issued by participants
US6081830A (en) * 1997-10-09 2000-06-27 Gateway 2000, Inc. Automatic linking to program-specific computer chat rooms
US5946687A (en) * 1997-10-10 1999-08-31 Lucent Technologies Inc. Geo-enabled personal information manager
US5907681A (en) * 1997-10-20 1999-05-25 International Business Machines Corporation Intelligent method, apparatus and computer program product for automated refreshing of internet web pages
US6311185B1 (en) 1997-10-30 2001-10-30 At&T Corp. Method and apparatus for modifying an information page transmitted in a communications network
US5999179A (en) 1997-11-17 1999-12-07 Fujitsu Limited Platform independent computer network management client
US5999941A (en) * 1997-11-25 1999-12-07 Micron Electronics, Inc. Database access using active server pages
US6490584B2 (en) 1997-11-26 2002-12-03 International Business Machines Corporation User-centered push methods and system
US6601107B1 (en) * 1998-02-02 2003-07-29 Hughes Electronics Corporation Adaptive fuzzy control of data acquisition and broadcasting
US6560639B1 (en) * 1998-02-13 2003-05-06 3565 Acquisition Corporation System for web content management based on server-side application
US6330880B1 (en) * 1998-02-27 2001-12-18 Mitsubishi Denki Kabushiki Kaisha Exhaust gas recirculation system
US6094662A (en) 1998-04-30 2000-07-25 Xerox Corporation Apparatus and method for loading and reloading HTML pages having cacheable and non-cacheable portions
US6108712A (en) 1998-05-05 2000-08-22 International Business Machines Corp. Client-server system with central application management and providing export agent capability for retrofitting existing hardware and applications into the system
US6209029B1 (en) * 1998-05-12 2001-03-27 Silverstream Software, Inc. Method and apparatus for accessing data sources in a three tier environment
AU749314B2 (en) * 1998-05-15 2002-06-20 Unicast Communications Corporation A technique for implementing browser-initiated network-distributed advertising and for interstitially displaying an advertisement
US6397231B1 (en) * 1998-08-31 2002-05-28 Xerox Corporation Virtual documents generated via combined documents or portions of documents retrieved from data repositories
US6480865B1 (en) 1998-10-05 2002-11-12 International Business Machines Corporation Facility for adding dynamism to an extensible markup language
US6397253B1 (en) * 1998-10-06 2002-05-28 Bull Hn Information Systems Inc. Method and system for providing high performance Web browser and server communications
US6313854B1 (en) 1998-10-16 2001-11-06 International Business Machines Corporation Display mechanism for HTML frames
US6271858B1 (en) 1998-10-16 2001-08-07 Microsoft Corporation Incremental update for dynamic/animated textures on three-dimensional models
US6134568A (en) 1998-10-30 2000-10-17 Kinko's Ventures, Inc. Previewing an assembled document
US6249844B1 (en) * 1998-11-13 2001-06-19 International Business Machines Corporation Identifying, processing and caching object fragments in a web environment
US6393422B1 (en) * 1998-11-13 2002-05-21 International Business Machines Corporation Navigation method for dynamically generated HTML pages
US8418131B2 (en) * 1998-11-25 2013-04-09 Helmut Emmelmann Interactive server side components
US6305012B1 (en) * 1998-12-03 2001-10-16 International Business Machines Corporation Method and apparatus for dynamic selection of instructions for compiling using tags
US6571245B2 (en) * 1998-12-07 2003-05-27 Magically, Inc. Virtual desktop in a computer network
US6360250B1 (en) * 1998-12-28 2002-03-19 Lucent Technologies Inc. Apparatus and method for sharing information in simultaneously viewed documents on a communication system
US6311187B1 (en) 1998-12-29 2001-10-30 Sun Microsystems, Inc. Propogating updates efficiently in hierarchically structured data under a push model
US6377957B1 (en) 1998-12-29 2002-04-23 Sun Microsystems, Inc. Propogating updates efficiently in hierarchically structured date
US6889379B1 (en) * 1998-12-31 2005-05-03 Microsoft Corporation Transporting objects between a client and a server
US6507856B1 (en) 1999-01-05 2003-01-14 International Business Machines Corporation Dynamic business process automation system using XML documents
JP3674351B2 (en) * 1999-01-08 2005-07-20 富士通株式会社 Master server
US6631512B1 (en) * 1999-01-15 2003-10-07 Gillis E Onyeabor Method and system for database-driven, scalable web page development, deployment-download, and execution
US6272493B1 (en) 1999-01-21 2001-08-07 Wired Solutions, Llc System and method for facilitating a windows based content manifestation environment within a WWW browser
US6870551B1 (en) * 1999-01-28 2005-03-22 International Business Machines Corporation Method and apparatus for displaying full and selected dynamic data in a data processing system
US6434738B1 (en) * 1999-04-22 2002-08-13 David Arnow System and method for testing computer software
US6515681B1 (en) 1999-05-11 2003-02-04 Prophet Financial Systems, Inc. User interface for interacting with online message board
GB9913165D0 (en) * 1999-06-08 1999-08-04 Secr Defence Access control in a web environment
US6615088B1 (en) 1999-06-09 2003-09-02 Amx Corporation System and method of device interface configuration for a control system
US6691281B1 (en) * 1999-06-15 2004-02-10 Microsoft Corporation Publishing/republishing data tables in HTML documents while maintaining formatting and functionality for restoring back the data tables
US6742045B1 (en) * 1999-07-02 2004-05-25 Cisco Technology, Inc. Handling packet fragments in a distributed network service environment
US6557076B1 (en) * 1999-07-22 2003-04-29 International Business Machines Corporation Method and apparatus for aggressively rendering data in a data processing system
US6457103B1 (en) 1999-07-22 2002-09-24 International Business Machines Corporation Method and apparatus for caching content in a data processing system with fragment granularity
US6031747A (en) 1999-08-02 2000-02-29 Lockheed Martin Missiles & Space Company Interleaved synchronous flyback converter with high efficiency over a wide operating load range
US6496849B1 (en) 1999-08-30 2002-12-17 Zaplet, Inc. Electronic media for communicating information among a group of participants
US6356933B2 (en) * 1999-09-07 2002-03-12 Citrix Systems, Inc. Methods and apparatus for efficiently transmitting interactive application data between a client and a server using markup language
US6701388B1 (en) * 1999-09-28 2004-03-02 Texas Instruments Incorporated Apparatus and method for the exchange of signal groups between a plurality of components in a digital signal processor having a direct memory access controller
US6587858B1 (en) * 1999-09-30 2003-07-01 Steven Paul Strazza Systems and methods for the control of dynamic data and request criteria in a data repository
US6920607B1 (en) * 1999-12-15 2005-07-19 Microsoft Corp. Methods and systems for dynamically creating user interfaces
AU2582401A (en) * 1999-12-17 2001-06-25 Dorado Network Systems Corporation Purpose-based adaptive rendering
US6785902B1 (en) 1999-12-20 2004-08-31 Webtv Networks, Inc. Document data structure and method for integrating broadcast television with web pages
US20020049788A1 (en) * 2000-01-14 2002-04-25 Lipkin Daniel S. Method and apparatus for a web content platform
US7412644B2 (en) 2000-02-04 2008-08-12 Aol Llc, A Delaware Limited Liability Company System and process for delivering and rendering scalable web pages
US6725335B2 (en) * 2000-02-09 2004-04-20 Hewlett-Packard Development Company, L.P. Method and system for fast unlinking of a linked branch in a caching dynamic translator
US6912571B1 (en) * 2000-02-22 2005-06-28 Frank David Serena Method of replacing content
US6655586B1 (en) * 2000-02-25 2003-12-02 Xerox Corporation Systems and methods that detect a page identification using embedded identification tags
US7509404B2 (en) * 2000-03-08 2009-03-24 Oracle International Corporation Methods and systems for partial page caching of dynamically generated content
US6622168B1 (en) * 2000-04-10 2003-09-16 Chutney Technologies, Inc. Dynamic page generation acceleration using component-level caching
US6792607B1 (en) * 2000-05-18 2004-09-14 Microsoft Corporation Databinding using server-side control objects
JP2001332630A (en) * 2000-05-19 2001-11-30 Sharp Corp Method of manufacturing semiconductor device
US6799209B1 (en) 2000-05-25 2004-09-28 Citrix Systems, Inc. Activity monitor and resource manager in a network environment
US20020065851A1 (en) * 2000-06-02 2002-05-30 Watson Emerson C. System and method for creating a website
US6826594B1 (en) 2000-07-15 2004-11-30 Commission Junction Method and system for remote content management of a designated portion of a web page
EP1475266B1 (en) * 2000-07-17 2006-07-12 Hitachi, Ltd. Control method and system for vehicle
US7039658B2 (en) * 2000-07-31 2006-05-02 Starkey James A Method and apparatus for generating web pages from templates
US6684388B1 (en) * 2000-08-22 2004-01-27 International Business Machines Corporation Method for generating platform independent, language specific computer code
US6920609B1 (en) * 2000-08-24 2005-07-19 Yahoo! Inc. Systems and methods for identifying and extracting data from HTML pages
US6738804B1 (en) * 2000-09-15 2004-05-18 Yodlee.Com, Inc. Method and apparatus for enabling sectored data refreshing of Web-site data during session
US6950850B1 (en) 2000-10-31 2005-09-27 International Business Machines Corporation System and method for dynamic runtime partitioning of model-view-controller applications
US7051084B1 (en) * 2000-11-02 2006-05-23 Citrix Systems, Inc. Methods and apparatus for regenerating and transmitting a partial page
US7346842B1 (en) 2000-11-02 2008-03-18 Citrix Systems, Inc. Methods and apparatus for incorporating a partial page on a client
US20020099738A1 (en) * 2000-11-22 2002-07-25 Grant Hugh Alexander Automated web access for back-end enterprise systems

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5850548A (en) * 1994-11-14 1998-12-15 Borland International, Inc. System and methods for visual programming based on a high-level hierarchical data flow model
GB2327836A (en) * 1997-07-29 1999-02-03 Ibm User interface controls for a computer system

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN112579951A (en) * 2019-09-30 2021-03-30 北京国双科技有限公司 Page element selection method and device, storage medium and equipment

Also Published As

Publication number Publication date
AU2002232582A1 (en) 2002-06-24
GB2389292A (en) 2003-12-03
GB0309655D0 (en) 2003-06-04
US7194743B2 (en) 2007-03-20
WO2002049281A3 (en) 2003-04-17
US20020120679A1 (en) 2002-08-29
US20020105548A1 (en) 2002-08-08
WO2002049281A8 (en) 2004-05-21
US7873965B2 (en) 2011-01-18
US20070094672A1 (en) 2007-04-26

Similar Documents

Publication Publication Date Title
US7194743B2 (en) Methods and apparatus for communicating changes between a user interface and an executing application using property paths
US6272673B1 (en) Mechanism for automatically establishing connections between executable components of a hypertext-based application
US6049664A (en) Tier-neutral development mechanism for hypertext based applications
US6356933B2 (en) Methods and apparatus for efficiently transmitting interactive application data between a client and a server using markup language
US8965864B2 (en) Method and system for efficient execution and rendering of client/server interactive applications
US7529841B2 (en) Method and apparatus for updating and synchronizing information between a client and server
US7546298B2 (en) Software, devices and methods facilitating execution of server-side applications at mobile devices
US7269664B2 (en) Network portal system and methods
US6470375B1 (en) System and method for managing the execution of system management tasks
RU2419864C2 (en) System and method of generating and transmitting requested data between network application programmes
US8136109B1 (en) Delivery of data and formatting information to allow client-side manipulation
US20040024843A1 (en) Method for provisioning distributed web applications
CA2598317C (en) Mobile device having extensible software for presenting server-side applications, software and methods
US20090025011A1 (en) Inter-process communication at a mobile device
US6446117B1 (en) Apparatus and method for saving session variables on the server side of an on-line data base management system
US7386551B1 (en) Method and apparatus for providing an availability message to a remote user
Huang et al. Development and Deployment of Web Applications

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A2

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NO NZ OM PH PL PT RO RU SD SE SG SI SK SL TJ TM TN TR TT TZ UA UG UZ VN YU ZA ZM ZW

AL Designated countries for regional patents

Kind code of ref document: A2

Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 2002550661

Country of ref document: JP

ENP Entry into the national phase

Ref document number: 0309655

Country of ref document: GB

Kind code of ref document: A

Free format text: PCT FILING DATE = 20011212

Format of ref document f/p: F

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

122 Ep: pct application non-entry in european phase
CFP Corrected version of a pamphlet front page

Free format text: REVISED ABSTRACT RECEIVED BY THE INTERNATIONAL BUREAU AFTER COMPLETION OF THE TECHNICAL PREPARATIONS FOR INTERNATIONAL PUBLICATION

NENP Non-entry into the national phase

Ref country code: JP

WWW Wipo information: withdrawn in national office

Country of ref document: JP