The present disclosure generally relates to data processing and, in particular, user interfaces.
User interfaces provide a way to present information and allow interactions between an application and a user. For example, the user interface may be implemented as a browser, a client application, and/or a graphical user interface. The user interface can be used to present data, enter data, and/or provide other interactions with an application. In the age of cloud-based applications, the user interface has become a primary mechanism for the user to interact with a backend application hosted at a server, such as a cloud server.
Methods and apparatus, including computer program products, are provided for monitoring user interface state transitions.
In one aspect, there is provided a method. The method may include monitoring a plurality of operations performed at a user interface; recording, at a cache, the plurality of operations, each of the recorded plurality of operations having a predefined format including a value and a target; moving, in response to a first request to move to a prior state at the user interface, back in the cache to determine the prior state at the user interface; and moving, in response to a second request to move to a subsequent state at the user interface, forward in the cache to determine the subsequent state at the user interface.
In some implementations, the above-noted aspects may further include additional features described herein including one or more of the following. The controller at the user interface may monitor the plurality of operation being performed. The controller may include a plurality of event listeners at a plurality of user interface elements. The event listener may provide the monitored plurality of operations to the cache. The cache may include an array where the plurality of operations are stored. The target may represent a user interface element, the value being entered into the user interface element. A first operation stored in the cache and a second, subsequent operation stored in the cache may be compress by ignoring and/or deleting the first operation stored in cache, when the first operation does not affect a final value of the corresponding target. The moving back in the cache to determine the prior state at the user interface may occur after the compressing. The moving forward in the cache may occur after the compressing.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory only and are not restrictive. Further features and/or variations may be provided in addition to those set forth herein. For example, the implementations described herein may be directed to various combinations and subcombinations of the disclosed features and/or combinations and subcombinations of several further features disclosed below in the detailed description.
In the drawings,
Like labels are used to refer to same or similar items in the drawings.
User interfaces have become increasingly complex and, as such, allow a user to perform relatively complex edits to what is presented via a user interface. Each edit represents a state of the user interface at any given instance in time. Thus, it is becoming increasingly complex to track and move between states at a user interface as the operations performed at the user interface have become increasingly complex. To that end, there is provided a way of monitoring the state of a user interface, in accordance with some example embodiments.
As noted, users may want to perform complicated edits at a user interface. Thus, the user interface may have many states due to these changes or edits. It is quite often the case that a user may want to jump between these states. However, traditional solutions may be inefficient—wasting precious computing and memory resources. The subject matter disclosed herein may provide a way to support efficient monitoring of user interface state transitions. To that end, instead of only storing the final state of a user interface, each of the operations at the user interface may be monitored and recorded. Each operation may be stored in a cache as a record. Each record may include a value and a target associated with the operation. The value may be any type of value or action that is provided or input at the user interface (for example, a numerical value, action such as click, and/or the like). The target may be a target of the operation performed at the user interface such as a user interface element or field at the user interface (e.g., a document object model, control element, text entry field, or other user interface element).
The system 100 may include a user interface 110, such as a browser or other type of user interface that can be generated and presented at a display. For example, the user interface may be a client application, browser, and/or the like associated with a web application 116 or a corresponding cloud-based application 162 accessible via network 150 at server 160. As a change occurs at the user interface 110 due to for example entering data into a user interface element, deleting data from a user interface element, updating data at a user interface element, moving data at the user interface element an element, and/or any other action, the change may represent a state change at the user interface 110. In addition, as noted above, these state changes may be monitored and recorded as records to enable stepping through the records to determine the prior states of the user interface 110.
In the example of
In some example embodiments, as changes are made to a user interface view (or the user interface elements therein) being displayed at user interface 110, those changes are monitored by user interface (UI) state controller 114. Those changes may then be recorded as records in cache 112. Once recorded, the UI state controller 114 may compress the records in cache 112 by for example combining and/or deleting records. Moreover, the UI state controller 114 may record the records in a predefined format at cache 112. If a back command 122 is received, the UI state controller 114 may provide a prior state of the UI 110 by stepping back to a prior record stored in cache. For example, if operations 1, 2, 3 and so forth are performed at the user interface 110, the UI state controller 114 may record the operations as records at cache 112. In this example, when a back command 122 is received, it triggers UI state controller 114 to step back from operation 3 (which in this example is a current state) to prior operation 2. The moving back may cause the prior state, such as prior state 2, to be displayed at user interface 110 and/or provided as a file to another application, such as web application 116, cloud application 162, and/or the like. While UI state controller 114 is in prior state 2, the selection of the forward command 120 may also cause the UI state controller 114 to move forward in the operations records in cache from state 2 to subsequent state 3, for example. Moreover, this forward step in state may trigger the next state, such as state 3, to be displayed at user interface 110 and/or provided as a file to another application, such as web application 116, cloud application 162, and/or the like.
At 210, operations at a user interface may be monitored. For example, UI state controller 114 may monitor any operations being performed at user interfaces, such as text entry, deletions, selections, mouse clicks, copies, pastes, and/or any other actions including operations.
In some example embodiments, the UI state controller 114 may monitor atomic operations, which are operations that cannot be subdivided. For example, an atomic operation may comprise entering data into a text input user interface element of a web page. To illustrate further, a user enters “abc” then deletes “c” and later enters “c”. Here, we have 3 atomic operations corresponding to (1) the entry of “abc”, the (2) the deletion of “c” and (3) the re-entry of “c.” Each of these atomic operations may be monitored and formatted in a record that is stored in cache 112. Moreover, the monitoring at 210 may be continuous, periodic, and/or aperiodic so that any operations performed at the user interface are captured as part of the controller's 114 monitoring.
At 212, each operation may be recorded in cache. For example, the UI state controller 114 may record the monitored operations as records at cache 112. In some example embodiments, each monitored operation is recorded as a record having a predetermined format. The predetermined format may include a value field of the operation and a target field. In some example embodiments, the cache 112 is configured as an array. The record (representing the atomic operation, for example) may be accessed via an index that points to a location in the array. Moreover, the cache 112 may be stored in memory along with the browser.
Referring again to
The UI state controller 114 may determine whether any of the records should be compressed, in which case UI state controller 114 may combine, ignore, and/or remove one or more records stored in cache 112 (yes at 215 and 220).
Referring to Table 1, there may be a first atomic operation, AO1, and a second, subsequent atomic operation, AO3 and both atomic operations in this example modify the same field, such as external name. In this example, the UI state controller 114 can compress AO1 and AO3 by ignoring AO1. To compress, the UI state controller 114 may remove a record for a given atomic operation if the atomic operation has no effect on the final state. For example, in Table 1, AO1 does not have any effect on final state. Specifically, the final external name will be “name3” because AO3 sets it to “name3” no matter what AO1 sets it to. In fact, AO1 sets it to “name2” but AO3 later overrides that change to “name2” to “name3.” As such, the compression can ignore or delete the record for AO1.
In some example embodiments, the UI state controller 114 may have a configurable compression algorithm. For example, the server 160 may indicate to the UI state controller 114 which compression algorithm to use to reduce the quantity of records for a given session at the user interface. To compress, the UI state controller 114 may process the array of records, and if two atomic operations, such as AOx and AOy, have the same targets and AOy occurs later in time, the earlier atomic operation, AOx, may be ignored. Alternatively or additionally, the user interface 110 may prompt a selection (by for example the user) of a compression algorithm that will be used by the UI state controller 114 to reduce the quantity of records processed for a given session at the user interface. Alternatively or additionally, the web application 116 may select a compression algorithm to use to reduce the quantity of records for a given session at the user interface.
In some example embodiments, the UI state controller 114 may automatically compress by combining AO1 and AO3 (as shown in Table 1, for example) to form a temporary atomic operation record, AO-temp, of the form external field name (name1, name3). In this example, processing yields two AOs: (1) AO2: gold(123, 1,235) and (2) AOtemp: external name(name1, name3). As such, AOtemp can be stored in cache 112 and later rolled back (or undone so to speak).
Referring again to Table 1, it shows four states. In this example, a first selection of the back user interface element 122, triggers the UI state controller to move back (in the cached records of the operations) to a prior state 2; a second selection of the back user interface element 122, triggers the UI state controller to move back to a prior state 1; and a third selection of the back user interface element 122, triggers the UI state controller to move back to a prior state 0.
At 230, the UI state controller 114 may receive a command to move forward. For example, the command may be received from the user interface triggered by a selection of user interface element 120, although the forward command may be received or triggered in other ways (for example, by application 116, application 162, and/or the like). When UI state controller 114 receives the forward command, the UI may move or step forward, at 235, from a given state in the cache to another state. Referring to Table 1, the forward command may trigger the UI state controller 114 to move from state 2 (AO2: gold (123, 1,235)) to state 3 (AO3: externalName (name2, name3)). In this example, the external name would change from name2 to name3 as part of the forward step.
At 240, the UI state controller 114 may receive a command to move back. For example, the command may be received from the user interface triggered by a selection of user interface element 122, although the forward command may be received or triggered in other ways (for example, by application 116, application 162, and/or the like). When UI state controller 114 receives the back command, the UI may move step back, at 245, from a given state in the cache to another state. Referring to Table 1, the back command may trigger the UI state controller 114 to move from state 3 (AO3: externalName (name2, name3)) to state 2 (AO2: gold (123, 1,235)). In this example, the gold field would change from 123 to 1,235 as part of the back step.
Without in any way limiting the scope, interpretation, or application of the claims appearing herein, a technical effect of one or more of the example embodiments disclosed herein may include enhanced monitoring and control of user interface states.
To provide for interaction with a user, the subject matter described herein may be implemented on a computer having a display device (e.g., a CRT (cathode ray tube) or LCD (liquid crystal display) monitor) for displaying information to the user and a keyboard and a pointing device (e.g., a mouse or a trackball) by which the user may provide input to the computer. Other kinds of devices may be used to provide for interaction with a user as well; for example, feedback provided to the user may be any form of sensory feedback (e.g., visual feedback, auditory feedback, or tactile feedback); and input from the user may be received in any form, including acoustic, speech, or tactile input.
The subject matter described herein may be implemented in a computing system that includes a back-end component (e.g., as a data server), or that includes a middleware component (e.g., an application server), or that includes a front-end component (e.g., a client computer having a graphical user interface or a Web browser through which a user may interact with an implementation of the subject matter described herein), or any combination of such back-end, middleware, or front-end components. The components of the system may be interconnected by any form or medium of digital data communication (e.g., a communication network). Examples of communication networks include a local area network (“LAN”), a wide area network (“WAN”), and the Internet.
These computer programs (also known as programs, software, software applications or code) include machine instructions for a programmable processor, and may be implemented in a high-level procedural and/or object-oriented programming language, and/or in assembly/machine language. As used herein, the term “machine-readable medium” refers to any computer program product, apparatus and/or device (e.g., magnetic discs, optical disks, memory, Programmable Logic Devices (PLDs)) used to provide machine instructions and/or data to a programmable processor, including a machine-readable medium that receives machine instructions as a machine-readable signal. The term “machine-readable signal” refers to any signal used to provide machine instructions and/or data to a programmable processor.
The computing system may include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
Although a few variations have been described in detail above, other modifications are possible. For example, the logic flow depicted in the accompanying figures and described herein does not require the particular order shown, or sequential order, to achieve desirable results. In addition, other processing attributes other than threads can be used to determine whether to selectively change the speed of a core scheduled to process the corresponding tasks. Moreover, the term task can be construed, unless explicitly stated otherwise, to include jobs and other broader groupings of related computing activities. Other embodiments may be within the scope of the following claims.
Number | Name | Date | Kind |
---|---|---|---|
5333302 | Hensley | Jul 1994 | A |
5826253 | Bredenberg | Oct 1998 | A |
6184880 | Okada | Feb 2001 | B1 |
6222537 | Smith | Apr 2001 | B1 |
6357038 | Scouten | Mar 2002 | B1 |
6424354 | Matheny | Jul 2002 | B1 |
6535912 | Anupam | Mar 2003 | B1 |
6549216 | Schumacher | Apr 2003 | B1 |
6633878 | Underwood | Oct 2003 | B1 |
6954859 | Simerly | Oct 2005 | B1 |
7013329 | Paul | Mar 2006 | B1 |
7099893 | Bischof | Aug 2006 | B2 |
7275240 | Cole | Sep 2007 | B2 |
7461342 | McLean | Dec 2008 | B2 |
7685248 | Fein | Mar 2010 | B1 |
7712074 | Ren | May 2010 | B2 |
8407574 | Forstall | Mar 2013 | B2 |
8433996 | Paulsami | Apr 2013 | B2 |
8667421 | Grunberger | Mar 2014 | B2 |
20030112271 | Batalden | Jun 2003 | A1 |
20030164850 | Rojewski | Sep 2003 | A1 |
20030169264 | Emerson | Sep 2003 | A1 |
20040111488 | Allan | Jun 2004 | A1 |
20040221262 | Hampapuram | Nov 2004 | A1 |
20040261026 | Corson | Dec 2004 | A1 |
20050034148 | Jaeger | Feb 2005 | A1 |
20050278728 | Klementiev | Dec 2005 | A1 |
20060010420 | Peterson | Jan 2006 | A1 |
20060224960 | Baird-Smith | Oct 2006 | A1 |
20090112949 | Ergan | Apr 2009 | A1 |
20090172582 | Miyawaki | Jul 2009 | A1 |
20090199096 | Pop-Jordanov | Aug 2009 | A1 |
20100077329 | Korn | Mar 2010 | A1 |
20100131927 | Pinjala | May 2010 | A1 |
20100241479 | Chaushev | Sep 2010 | A1 |
20100306665 | Milic-Frayling | Dec 2010 | A1 |
20110004868 | Bharadwaj | Jan 2011 | A1 |
20110041117 | Grechanlk | Feb 2011 | A1 |
20120131456 | Lin | May 2012 | A1 |
20130019171 | Mounty | Jan 2013 | A1 |
20130061159 | Tseng | Mar 2013 | A1 |
20130159784 | Rossi | Jun 2013 | A1 |
20130290875 | Dixit | Oct 2013 | A1 |
20140059113 | Adams | Feb 2014 | A1 |
20140237389 | Ryall | Aug 2014 | A1 |
20160026730 | Hasan | Jan 2016 | A1 |
20160336023 | Guyott | Nov 2016 | A1 |
20170060368 | Kochura | Mar 2017 | A1 |
20170060713 | Wang | Mar 2017 | A1 |
20170132511 | Gong | May 2017 | A1 |
20170286191 | Israeli | Oct 2017 | A1 |
20170300196 | Simpson | Oct 2017 | A1 |
Number | Date | Country | |
---|---|---|---|
20170228238 A1 | Aug 2017 | US |
Number | Date | Country | |
---|---|---|---|
62291396 | Feb 2016 | US |