Composable events for dynamic user interface composition

Information

  • Patent Grant
  • 11126332
  • Patent Number
    11,126,332
  • Date Filed
    Wednesday, September 18, 2019
    5 years ago
  • Date Issued
    Tuesday, September 21, 2021
    3 years ago
Abstract
Composable events to provide a dynamic user interface are disclosed. In various embodiments, a definition of a custom user interface event is received. The definition includes an identification of a data value to be associated with the event, a scope of the event within which the event will be consumed, and an event trigger in response to which an instance of the custom user interface event is to be published. Application user interface code configured to provide one or more application user interface elements configured to publish or subscribe to the custom user interface event is generated programmatically, based at least in part on the definition.
Description
BACKGROUND OF THE INVENTION

Advanced software development tools may enable developers to define user interface elements configured to publish and/or subscribe to user interface events. In typical approaches, the events available to be published and/or subscribed to are defined in advance, and the behavior of user interface elements to publish and/or respond to receipt of user interface events is predefined by a provider of the software development tool.





BRIEF DESCRIPTION OF THE DRAWINGS

Various embodiments of the invention are disclosed in the following detailed description and the accompanying drawings.



FIG. 1 is a block diagram illustrating an embodiment of an application development system and environment.



FIG. 2 is a functional block diagram illustrating an embodiment of a system to use developer-composed custom user interface events to provide a dynamic user interface.



FIG. 3 is a flow chart illustrating an embodiment of a process to compose a custom user interface event.



FIG. 4 is a flow chart illustrating an embodiment of a process to associate a custom user interface event with a user interface element to publish the event.



FIG. 5 is a flow chart illustrating an embodiment of a process to define a user interface element to subscribe to and consume a custom user interface event.



FIG. 6 is a flow chart illustrating an embodiment of a process to provide an application user interface.





DETAILED DESCRIPTION

The invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor. In this specification, these implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processes may be altered within the scope of the invention. Unless stated otherwise, a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task. As used herein, the term ‘processor’ refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.


A detailed description of one or more embodiments of the invention is provided below along with accompanying figures that illustrate the principles of the invention. The invention is described in connection with such embodiments, but the invention is not limited to any embodiment. The scope of the invention is limited only by the claims and the invention encompasses numerous alternatives, modifications and equivalents. Numerous specific details are set forth in the following description in order to provide a thorough understanding of the invention. These details are provided for the purpose of example and the invention may be practiced according to the claims without some or all of these specific details. For the purpose of clarity, technical material that is known in the technical fields related to the invention has not been described in detail so that the invention is not unnecessarily obscured.


Composable custom user interface events to facilitate composition of dynamic user interfaces (UI) are disclosed. In various embodiments, a software development tool is provided that enables a developer to define custom user interface events. In various embodiments, a developer defines and/or selects a composable element comprising one or more of user interface elements (e.g., page element) and non-user interface elements (e.g., data service, action flow) with which to associate a custom event. In the case of a user interface element to be configured to publish a custom event, in various embodiments one of more of the following may be received: a definition of the event (e.g., structure, event content or arguments, event scope, e.g., fragment-wide, page-wide, application-wide, etc.); one or more event triggers or other conditions that may cause the user interface element to publish an instance of the event; and one or more conditions to be evaluated at runtime, for example to determine in response to an event trigger whether an instance of the event will be published, a payload or other content associated with the event, etc. In some embodiments, an event payload may be stored temporarily in a “content cache” or other structure, e.g., from which a user interface or other element configured to consume the event may read the payload. In some embodiments, an event is cached until another event of the same type is published. In the case of a user interface or other element to be configured to subscribed to and/or otherwise consume the event, one or more of the following may be received: a definition of an evaluation or other trigger associated with receipt of an instance of the user interface event; and one or more expressions to be evaluated in response to receiving an instance of the event. In some embodiments, the latter expressions may include and/or make reference to data values read from a payload associated with the received user interface event instance. In some embodiments, an event definition may indicate a scope of an event, e.g., fragment-wide, page-wide, application-wide; and the event is published and/or consumed only within the defined scope of the event.



FIG. 1 is a block diagram illustrating an embodiment of an application development system and environment. In the example shown, a plurality of client systems, representing in FIG. 1 by client systems 102, 104, and 106, connect via a network 108 to an application server 110 associated with a body of managed content 112. In some embodiments, the managed content 112 may be stored in a content management system, such as an EMC® Documentum® system. In various embodiments, a software developer or other user associated with application developer workstation 114, e.g., a personal or other computer, may use a software development tool to create an application to run on application server 110. For example, in some embodiments a developer may use the “xCP Designer” and/or other components comprising the EMC® Documentum® xCP development platform to create applications to run on application server 110, for example in a runtime environment provided on application server 110. The EMC® Documentum® xCP development platform, for example, enables a developer to use visual and other tools to build custom applications that leverage the advanced enterprise content management (ECM) capabilities of EMC® Documentum®.


In various embodiments, a visual or other development tool interface to enable developers to compose developer-composed custom user interface events, and user interface element (e.g., page element) definitions to publish, subscribe to, and consume developer-composed events, is provided, e.g., via application development workstation 114. Definitions are received via the interface and stored. The definitions are used to generate application user interface code which at runtime invokes a user interface event infrastructure, e.g., of a runtime or other environment comprising application server 110, to publish, subscribed to, and/or consume custom user interface events as defined by the developer.



FIG. 2 is a functional block diagram illustrating an embodiment of a system to use developer-composed custom user interface events to provide a dynamic user interface. In the example shown, an event publication component 202 comprising an application user interface uses a source event (i.e., event definition) 204 and one or more associated event triggers 206, along with in this example (optional) conditional evaluation 208, e.g., using contextual or other information as defined by the developer, to determine that an instance 210 of a developer-composed user interface event is to be published (see arrow labeled “1” in FIG. 2). In the example shown, the user interface event instance 210 includes and/or is otherwise associated with an event payload 212. Examples of an event payload 212 include, without limitation, a set of parameters or other values to be provided to event consumers.


In the example shown in FIG. 2, the user interface event 210 is transmitted via an event bus 214. A copy of the payload 212 is stored in a context cache 216 (see arrow labeled “2” in FIG. 2). The user interface event instance 210 is provided via event bus 214 to an event consumption component/infrastructure 218 (see arrow labeled “3” in FIG. 2) to be provided to any user interface and/or other elements that may have subscribed to receive events of that event type. An evaluation trigger 220 results in event data associated with event instance 210 being provided to be evaluated using an expression 222 (see arrow labeled “4” in FIG. 2). In the example shown, the expression 222 has been defined by the developer who composed the application user interface, including the custom user interface event of which event instance 210 is an instance in this example, to use data comprising and/or derived as defined by the developer from data included in the payload 212 of event instance 210, e.g., as one or more arguments of the expression(s) 222 defined by the developer to be evaluated at runtime (see arrow labeled “5” in FIG. 2). In this manner, a developer can incorporate highly dynamic behaviors into the application user interface, by loosely coupling user interface elements. For example, an application user interface element (e.g., a page element), may be configured to use application-level data values as determined and included in the event payload 212 at runtime to exhibit more than one different dynamic behaviors depending at least in part on the application data values included in the payload 212 of event instance 210.


In some embodiments, use of a structure such as content cache 216 to store event payloads may enable the developer to use the user interface event infrastructure, such as the one shown in FIG. 2, to temporarily store application user interface data values for consumption and use by application user interface elements, on the current or other application user interface pages, or other application components or elements.



FIG. 3 is a flow chart illustrating an embodiment of a process to compose a custom user interface event. In the example shown, an input to define a custom user interface event is received (302), e.g., via a visual or other software development tool interface. For example, an indication that a developer has selected a “define custom user interface event” option or control may be received. In response, a template to be used by the developer to define the custom user interface is provided (304). For example, a form or template to receive developer input in a structured manner may be displayed. Custom user interface event definition data is received (306) and stored (308), e.g., for later use to generate programmatically application user interface code to implement the custom user interface event and associated user interface elements and behaviors, as defined by the developer, and/or as an event definition to be used at runtime to create and publish, subscribe to, and/or consume instances of the developer-composed custom user interface event.



FIG. 4 is a flow chart illustrating an embodiment of a process to associate a custom user interface event with a user interface element to publish the event. In the example shown, a selection of page (or other user interface) element to be configured to publish a selected custom user interface event is received (402), e.g., via a development tool user interface. One or more conditions (e.g., event triggers) under which the page element is to be configured to publish an instance of the selected event is received (404). In various embodiments, a declarative or other form of input is used by a developer to define the event trigger(s) and/or condition(s). A definition (e.g., declarative), selection (e.g., drag/drop, drop down or other menu, etc.), or other indication of a payload to be included with and/or otherwise associated with instances of the selected event as published by the selected page element is received (406). Data associating the selected event, conditions (e.g., trigger), and payload definitions with the page (or other) element are stored (408), e.g., to be used at application user interface code generation time to generate programmatically code to provide and configure the application user interface page element to publish instances of the selected event, upon occurrence of the developer-defined event trigger (or other condition), with the payload as indicated and defined by the developer.



FIG. 5 is a flow chart illustrating an embodiment of a process to define a user interface element to subscribe to and consume a custom user interface event. In the example shown, an indication is received that a selected page (or other) element is to subscribe to a selected developer-composed custom user interface event (502). A definition is received of one or more expressions and/or other evaluation logic to be used by and/or on behalf of the subscribing user interface element at runtime to determine a responsive action, if any, to be performed in response to a received instance of the selected event (504). Data associating the selected event and evaluation logic (e.g., expressions) with the subscribing page (or other) element is stored (506).



FIG. 6 is a flow chart illustrating an embodiment of a process to provide an application user interface. In the example shown, an application user interface page is requested (602), e.g., the application is launched, accessed using a web browser, and/or a user or other input received in the context of a previously-provided user interface page causes a the currently-request page to be requested. An application user interface page comprising page elements configured to publish and/or subscribe to and consume developer-composed custom user interface elements, as disclosed herein, is provided (604). Upon occurrence of a developer-defined event trigger (606), an instance of a developer-composed (or other) application user interface event is published (608). In various embodiments, the user interface event may be published conditionally, based for example on conditions defined declaratively or otherwise by the developer, and/or to include a payload comprising data values as defined by the developer. If a user interface event a page element is configured to subscribe to is received (610), the event is consumed by the subscribing page element as defined by the developer (612). In various embodiments, a developer-defined expression or other logic may be evaluated to determine a dynamic behavior, if any, to be provided by the subscribing user interface element in response to receipt of the event. In some embodiments, a developer-defined expression or other logic may use one or more data values comprising and/or derived from a payload associated with the received user interface event instance, e.g., as described above. The process of FIG. 6 continues, e.g., potentially with subsequent user interface events being published and/or received and consumed as disclosed herein, until done (614), e.g., a different application user interface page is requested and/or loaded, or the user discontinues use of the application.


Using techniques disclosed herein, a highly dynamic and flexible application user interface can be defined, without constraining a developer to use of only a predefined set of application user interface events, triggers, and/or responses.


Although the foregoing embodiments have been described in some detail for purposes of clarity of understanding, the invention is not limited to the details provided. There are many alternative ways of implementing the invention. The disclosed embodiments are illustrative and not restrictive.

Claims
  • 1. A method of providing a user interface, comprising: prior to execution of an application,receiving, at a software development tool configured to build the application, a selection associated with a custom user interface event,receiving, at the software development tool, a template in response to the selection, wherein the template provides an interface to customize interface events including a definition of the custom user interface event including an identification of a data value to be associated with the custom user interface event, a definition of an event scope wherein the custom user interface event is consumable by page elements other than a first application user interface element that is associated with the custom user interface event and publishes the custom user interface event only within the defined event scope for consumption of the custom user interface event, and one or more event triggers in response to which an instance of the custom user interface event is to be published; andgenerating programmatically, at the software development tool, based at least in part on the definition, an application user interface code configured to provide to a client, at runtime during execution of the application, an application user interface page including at least the first application user interface element which is configured to publish the instance of the custom user interface event with an associated data value, wherein the application user interface code is configured to cause the associated data value to be stored in a content cache from which the data value is read until another instance of the custom user interface event is published.
  • 2. The method of claim 1, wherein the definition is received via a software development tool interface.
  • 3. The method of claim 1, wherein the identification of the data value comprises an indication of a payload to be associated with the custom user interface event.
  • 4. The method of claim 3, wherein the payload comprises a set of one or more parameters.
  • 5. The method of claim 3, wherein the associated data value is stored in a structure associated with an event bus via which the instance of the custom user interface event is published.
  • 6. The method of claim 1, further comprising receiving a definition of the first application user interface element configured to publish the custom user interface event.
  • 7. The method of claim 1, further comprising, receiving a definition of a second application user interface element of the one or more application user interface elements, the second application user interface element configured to subscribe to the custom user interface event.
  • 8. The method of claim 1, further receiving an expression to be evaluated in connection with consumption of the custom user interface event.
  • 9. The method of claim 8, wherein the expression includes the associated data value as an argument.
  • 10. The method of claim 9, wherein the associated data value is included in a payload associated with the instance of the custom user interface event.
  • 11. The method of claim 10, wherein at least one application user interface element is configured to use the expression to consume the instance of the custom user interface event and to perform a dynamic user interface action determined based at least in part on a result of evaluation of the expression.
  • 12. The method of claim 1, wherein the scope is fragment-wide, page-wide, or application-wide.
  • 13. A system, comprising: a data storage device; anda processor coupled to the data storage device and configured to:prior to execution of an application,receive, at a software development tool configured to create the application, a selection associated with a custom user interface event,receive, at the software development tool, a template in response to the selection, wherein the template provides an interface to customize interface events including a definition of the custom user interface event including an identification of a data value to be associated with the custom user interface event, a definition of an event scope wherein the custom user interface event is consumable by page elements other than a first application user interface element that is associated with the custom user interface event and publishes the custom user interface event only within the defined event scope for consumption of the custom user interface event, and one or more event triggers in response to which an instance of the custom user interface event is to be published; andgenerate programmatically, at the software development tool, based at least in part on the definition, an application user interface code configured to provide to a client, at runtime during execution of the application, an application user interface page including at least the first application user interface element which is configured to publish the instance of the custom user interface event with an associated data value, wherein the application user interface code is configured to cause the associated data value to be stored in a content cache on the data storage device from which the data value is read until another instance of the custom user interface event is published.
  • 14. The system of claim 13, wherein the data storage device comprises a memory.
  • 15. The system of claim 13, wherein the identification of the data value comprises an indication of a payload to be associated with the custom user interface event.
  • 16. The system of claim 15, wherein the application user interface code is configured to store the associated data value in a structure associated with an event bus via which the instance of the custom user interface event is published.
  • 17. The system of claim 13, wherein the processor is further configured to receive a definition of the first application user interface element configured to publish the custom user interface event.
  • 18. The system of claim 13, wherein the scope is fragment-wide, page-wide, or application-wide.
  • 19. A computer program product to provide a user interface, the computer program product being embodied in a non-transitory computer-readable storage medium and comprising computer instructions for: prior to execution of an application,receiving, at a software development tool configured to build the application, a selection associated with a custom user interface event,receiving, at the software development tool, a template in response to the selection, wherein the template provides an interface to customize interface events including a definition of the custom user interface event including an identification of a data value to be associated with the custom user interface event, a definition of an event scope wherein the custom user interface event is consumable by page elements other than a first application user interface element that is associated with the custom user interface event and publishes the custom user interface event only within the defined event scope for consumption of the custom user interface event, and one or more event triggers in response to which an instance of the custom user interface event is to be published; andgenerating programmatically, at the software development tool, based at least in part on the definition, an application user interface code configured to provide to a client, at runtime during execution of the application, an application user interface page including at least the first application user interface element which is configured to publish the instance of the custom user interface event with an associated data value, wherein the application user interface code is configured to cause the associated data value to be stored in a content cache from which the data value is read until another instance of the custom user interface event is published.
CROSS REFERENCE TO OTHER APPLICATIONS

This application is a continuation of, and claims a benefit of priority under 35 U.S.C. 120 from U.S. patent application Ser. No. 14/136,232 filed Dec. 20, 2013, entitled “COMPOSABLE EVENTS FOR DYNAMIC USER INTERFACE COMPOSITION,” which is hereby fully incorporated herein by reference for all purposes.

US Referenced Citations (84)
Number Name Date Kind
4910660 Li Mar 1990 A
5079690 Li Jan 1992 A
5644738 Goldman et al. Jul 1997 A
5754772 Leaf May 1998 A
6012067 Sarkar Jan 2000 A
6226627 Polak May 2001 B1
6233726 Bowman et al. May 2001 B1
6268852 Lindhorst Jul 2001 B1
6304886 Bernardo Oct 2001 B1
6397220 Deisinger May 2002 B1
6724403 Santoro Apr 2004 B1
7013469 Smith Mar 2006 B2
7225425 Kompalli et al. May 2007 B2
7734995 Saikaly Jun 2010 B1
7797432 Volodarsky et al. Sep 2010 B2
7933632 Flynt Apr 2011 B2
8156481 Koh et al. Apr 2012 B1
8271899 Blackburn et al. Sep 2012 B1
8321681 Tulchinsky et al. Nov 2012 B2
8346889 Chiu et al. Jan 2013 B1
8560959 Zaman Oct 2013 B2
8572268 Wray Oct 2013 B2
8645848 Lesh Feb 2014 B2
9170786 Totale Oct 2015 B1
9756147 Totale Sep 2017 B1
9851951 Ganesan Dec 2017 B1
9977703 Gall May 2018 B2
10031729 Totale Jul 2018 B1
10466872 Totale Nov 2019 B1
10540150 Totale Jan 2020 B2
10659567 Totale May 2020 B2
10942715 Totale et al. Mar 2021 B2
20020194393 Hrischuk et al. Dec 2002 A1
20030004770 Miller et al. Jan 2003 A1
20030023641 Gorman et al. Jan 2003 A1
20030222906 Fish et al. Dec 2003 A1
20040006765 Goldman et al. Jan 2004 A1
20040044987 Kompalli et al. Mar 2004 A1
20050022157 Brendle Jan 2005 A1
20050114849 Megiddo May 2005 A1
20050149908 Klianev Jul 2005 A1
20050166207 Baba et al. Jul 2005 A1
20060053421 Dickenson Mar 2006 A1
20060074704 Shukla et al. Apr 2006 A1
20060074733 Shukla et al. Apr 2006 A1
20060236304 Luo et al. Oct 2006 A1
20060236306 Debruin et al. Oct 2006 A1
20060259586 Wood Nov 2006 A1
20070055591 Enenkiel Mar 2007 A1
20070266368 Szpak et al. Nov 2007 A1
20080046868 Tsantilis Feb 2008 A1
20080126396 Gagnon May 2008 A1
20080201332 Souders Aug 2008 A1
20080281944 Vorne et al. Nov 2008 A1
20090019386 Sweetland et al. Jan 2009 A1
20090055725 Portnov Feb 2009 A1
20090193339 Nichols Jul 2009 A1
20090210631 Bosworth et al. Aug 2009 A1
20090307670 Kashyap et al. Dec 2009 A1
20100058711 Engel Mar 2010 A1
20100211420 Kodi et al. Aug 2010 A1
20100281462 Festa Nov 2010 A1
20100293056 Flynt Nov 2010 A1
20110225565 Van Velzen et al. Sep 2011 A1
20110238437 Zhou Sep 2011 A1
20110246549 Katzenberger et al. Oct 2011 A1
20120131442 Grizim May 2012 A1
20120166992 Huynh et al. Jun 2012 A1
20130019172 Kotler et al. Jan 2013 A1
20130019182 Gil et al. Jan 2013 A1
20130151571 Stumpf Jun 2013 A1
20130205193 Matsufuji et al. Aug 2013 A1
20130218919 Solonchev Aug 2013 A1
20130219263 Abrahami Aug 2013 A1
20130290380 Flickner et al. Oct 2013 A1
20140013297 Cook Jan 2014 A1
20140052681 Nitz Feb 2014 A1
20140164906 Hassler Jun 2014 A1
20140201232 Berry Jul 2014 A1
20140245262 Hill Aug 2014 A1
20160054986 Totale Feb 2016 A1
20170359445 Totale Dec 2017 A1
20200142673 Totale May 2020 A1
20210157556 Totale May 2021 A1
Non-Patent Literature Citations (30)
Entry
Notice of Allowance for U.S. Appl. No. 15/633,293, dated Jan. 15, 2020, 6 pgs.
Office Action for U.S. Appl. No. 15/633,293, dated Oct. 3, 2019, 2019, 16 pgs.
The PHP Group, What is PHP?, Jan. 23, 2009, 1 pg., retrieved.from https://web.archive.org/web/20090124160056/http://php.net/manual/en/intro-whatis.php.
Unknown, Kohana Team, Session Library, Jan. 2012, retrieved from http://www.hcs.harvard.edu/-powerpak/kohanadocs/libraries/session.html, 6 pgs.
Unknown, www.gwtproject.org. GWT, Jul. 2013, retrieved from https://web.archive.org/web/20130708095321/http://www.gwtproject.org/doc/latest/DevGuide-Html5Storage.html, 7 pgs.
Unknown, w3schools.com, “HTML5 Web Storage,” Nov. 2012, retrieved from https://web.archive.org/web/20121123023047/http://www.w3schools.com/html/html5_webstorage.asp, 3 pgs.
Office Action for U.S. Appl. No. 14/136,287, dated Dec. 17, 2014, 10 pgs.
Office Action for U.S. Appl. No. 14/136,232, dated Sep. 11, 2015, 15 pgs.
Office Action for U.S. Appl. No. 14/136,255, dated Jan. 15, 2016, 16 pgs.
Office Action for U.S. Appl. No. 14/136,232, dated Feb. 1, 2016, 17 pgs.
Office Action for U.S. Appl. No. 14/136,255, dated Apr. 22, 2016, 16 pgs.
Office Action for U.S. Appl. No. 14/136,255, dated Jul. 12, 2016, 23 pgs.
Office Action for U.S. Appl. No. 14/136,232, dated Sep. 22, 2016, 18 pgs.
Office Action for U.S. Appl. No. 14/136,255, dated Oct. 17, 2016, 21 pgs.
Office Action for U.S. Appl. No. 14/136,255, dated Feb. 6, 2017, 21 pgs.
Office Action for U.S. Appl. No. 14/136,232, dated Mar. 10, 2017, 19 pgs.
Office Action for U.S. Appl. No. 14/136,232, dated Nov. 15, 2017, 20 pgs.
Office Action for U.S. Appl. No. 15/633,293, dated Feb. 20, 2018, 23 pgs.
Office Action for U.S. Appl. No. 14/842,713, dated Mar. 9, 2018, 43 pgs.
Office Action for U.S. Appl. No. 14/136,232, dated Jun. 11, 2018, 26 pgs.
Notice of Allowance for U.S. Appl. No. 14/842,713, dated Oct. 1, 2018, 7 pages.
Office Action for U.S. Appl. No. 14/136,232, dated Nov. 6, 2018, 21 pages.
Office Action for U.S. Appl. No. 15/633,293, dated Dec. 3. 2018, 19 pages.
Notice of Allowance for U.S. Appl. No. 14/842,713, dated Jan. 28, 2019, 4 pgs.
Office Action for U.S. Appl. No. 15/633,293, dated Mar. 27, 2019, 14 pgs.
Office Action for U.S. Appl. No. 14/136,232, dated Apr. 12, 2019, 24 pgs.
Notice of Allowance for U.S. Appl. No. 14/842,713, dated May 7, 2019, 4 pgs.
Notice of Allowance for U.S. Appl. No. 14/136,232, dated Jul. 18, 2019, 6 pgs.
Notice of Allowance for U.S. Appl. No. 14/842,713, dated Aug. 15, 2019, 4 pgs.
Notice of Allowance for U.S. Appl. No. 16/735,375, dated Sep. 21, 2020, 5 pgs.
Related Publications (1)
Number Date Country
20200012402 A1 Jan 2020 US
Continuations (1)
Number Date Country
Parent 14136232 Dec 2013 US
Child 16574839 US