EP3214827A1 - Application session recording and replaying - Google Patents

Application session recording and replaying Download PDF

Info

Publication number
EP3214827A1
EP3214827A1 EP17157892.5A EP17157892A EP3214827A1 EP 3214827 A1 EP3214827 A1 EP 3214827A1 EP 17157892 A EP17157892 A EP 17157892A EP 3214827 A1 EP3214827 A1 EP 3214827A1
Authority
EP
European Patent Office
Prior art keywords
data card
application
data
interaction
running application
Prior art date
Legal status (The legal status 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 status listed.)
Granted
Application number
EP17157892.5A
Other languages
German (de)
French (fr)
Other versions
EP3214827B1 (en
Inventor
Jeffrey Catania
Tiffany Dharma
Aaron Pang
Teresa Sheausan Tung
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Accenture Global Solutions Ltd
Original Assignee
Accenture Global Solutions Ltd
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 Accenture Global Solutions Ltd filed Critical Accenture Global Solutions Ltd
Publication of EP3214827A1 publication Critical patent/EP3214827A1/en
Application granted granted Critical
Publication of EP3214827B1 publication Critical patent/EP3214827B1/en
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0481Interaction techniques based on graphical user interfaces [GUI] based on specific properties of the displayed interaction object or a metaphor-based environment, e.g. interaction with desktop elements like windows or icons, or assisted by a cursor's changing behaviour or appearance
    • G06F3/0482Interaction with lists of selectable items, e.g. menus
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3003Monitoring arrangements specially adapted to the computing system or computing system component being monitored
    • G06F11/302Monitoring arrangements specially adapted to the computing system or computing system component being monitored where the computing system component is a software system
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/3089Monitoring arrangements determined by the means or processing involved in sensing the monitored data, e.g. interfaces, connectors, sensors, probes, agents
    • G06F11/3093Configuration details thereof, e.g. installation, enabling, spatial arrangement of the probes
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3438Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment monitoring of user actions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/30Monitoring
    • G06F11/34Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
    • G06F11/3466Performance evaluation by tracing or monitoring
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/22Indexing; Data structures therefor; Storage structures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/951Indexing; Web crawling techniques
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q30/00Commerce
    • G06Q30/02Marketing; Price estimation or determination; Fundraising
    • G06Q30/0201Market modelling; Market analysis; Collecting market data
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/14Session management
    • H04L67/142Managing session states for stateless protocols; Signalling session states; State transitions; Keeping-state mechanisms
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/14Session management
    • H04L67/148Migration or transfer of sessions
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/535Tracking the activity of the user
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3668Software testing
    • G06F11/3672Test management
    • G06F11/3684Test management for test design, e.g. generating new test cases
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/86Event-based monitoring
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2201/00Indexing scheme relating to error detection, to error correction, and to monitoring
    • G06F2201/865Monitoring of software
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/02Protocols based on web technology, e.g. hypertext transfer protocol [HTTP]

Definitions

  • Application development programs may offer a number of different operational features for achieving a desired operational result, navigating to a desired destination, or creating a new desired component.
  • an image editing program may implement dozens of image editing functions to adjust colors, modify resolution or image size, add special effects, manage image layers, and provide other functions.
  • one user may use a first set of features to take one series of interactions with an application to accomplish the desired result, while another user may use another set of features to take a different series of interactions with the same application to achieve the same result. That is, within the same application, different users may arrive at different, same, or similar desired results via very different sequences of operational interactions with the application.
  • a web-based application is generally understood to be an application stored and configured to operate, at least in part, on a web server accessible to other communication devices connected to a common communication network.
  • a user operating their communication device may communicate with the web-server through the common communication network to access and operate the web-based application.
  • the web-based application offers many features, such as accessibility to remote users, based on its framework being stored on web server(s).
  • the web-based application also has access to a vast amount of information available through the communication network. Such features give a user of the web-based application many different options for interacting with the web-based application.
  • the interaction tracking system (“system”) described below provides an interaction tracking platform configured to provide the tools, including the instrumentation and software instructions, for tracking a user's interaction with an application.
  • the disclosure references web-based applications, the interaction tracking platform is also applicable to static applications locally running on a computing system, as well as mobile applications running, at least in part, on a user's mobile computing device.
  • Tracking the user's interactions may include recording the user's interactions with the application that changes a state of the application, analyzing the user's interactions to detect and store metadata related to the user's interactions, storing information related to a state of the application based on the user's interaction with the application, and storing information describing the application's state changes.
  • the system may be initiated to track interactions during an application session period when the application is active.
  • Specific identifiable interactions may be stored into individual data structures referred to as a data card, and the data cards that are generated during the application session may be stored into a data structure referred to as a data card deck. Note that while the examples below may make specific reference to web-based applications, the tracking platform may be applied to any application, whether web-based or running stand-alone on an individual computing platform.
  • the system also provides a unique way of presenting information to a user through the data cards.
  • the system generates the data cards, including information and data points related to the user's interactions with the application, so that the data cards may act as a gateway to the application's state.
  • the data cards also include application state information that may result from the user's interactions with the application. By including both interaction and state information, the user may later activate the data card to cause the application to revert back to a state described by the data card. In cases where the application is not currently running, the data card activation may consequently initiate the application to begin running and transition to the state described in the activated data card.
  • the data cards provide a technological improvement over simply providing a video recording of user interactions.
  • the data cards offer the technological improvement by being embodied as a unique data format that includes application state information that may be interpreted to initiate execution of an application to run and revert back to a state described by the application state information.
  • Tracking a user's interactions with an application may be beneficial to record how a user achieved a desired result on the application, particularly where complex applications provide many different ways to the desired result.
  • the data cards that are included in the data card deck may describe interactive steps the user took with the application to achieve the desired result.
  • the tracked interactions may be presented through the data cards as a time lapsed video recording of the user's interactions on the application, a written description of the user's interactions on the application, an audio description of the user's interactions on the application, or some combination thereof.
  • the tracked interactions may include the user's selection of selectable options on the application, the user's input into input field of the application (e.g., search input fields), or some combination thereof.
  • the data card deck (or individual data cards from the data card deck) may be stored so that the user (or other user) may later retrieve the data card deck and review the interactions described by the data cards in an effort to recreate the desired result.
  • the user may retrieve the data card deck from a database in which the data card deck is stored, or the data card deck may be transmitted to another user to present the tracked interactions to the other user.
  • the other user may then be able to recreate the same desired result on the application as the user having created the data card deck.
  • this other user may be able to identify or validate the scenario presented to the user to identify the critical components for improving future prioritization or presentation and development of data cards.
  • Figure 1 illustrates exemplary system architecture for interaction tracking system 100 that includes component devices for implementing the described features.
  • the system 100 includes an application server 140 configured to include the hardware, software, and/or middleware for operating the described data card interaction tracking tool 150.
  • Application server 140 is shown to include a processor 141, a memory 144, a communication interface 142, and a database interface 143.
  • the data card interaction tracking tool 150 may be operated as part of an add-on tool for an application also running on the application server 140.
  • the data card interaction tracking tool 150 may be run independently of the application being tracked by the data card interaction tracking tool 150.
  • the application being tracked by the data card interaction tracking tool 150 may be running on a secondary application server 160, or a communication device 110, within the system 100.
  • the application being tracked may also be running independently on the application server 140.
  • portions, or all, of the data card interaction tracking tool 150 may be running on the communication device 110.
  • the system 100 further includes a database 120 configured to store data card decks, wherein each data card deck may include one or more data cards.
  • the data card decks that are stored on the database 120 may have been received from application server 140 based on an operation of the data card interaction tracking tool 150.
  • the data card decks that are stored on the database 120 may later be retrieved by the application server 140 based on an operation of the data card interaction tracking tool 150.
  • the transmission of data card decks to the database 120, and the retrieval of data card decks from the database 120 may be accomplished by the application server 140 controlling the database interface 143.
  • the secondary application server 160 may be configured to communicate with the application server 140 either directly, or through network 130.
  • the secondary application server 160 may be configured to store and/or operate a web-based application that is being tracked by the data card interaction tracking tool 150, according to some embodiments.
  • the system 100 communicates with any number and type of client devices, as represented by the communication device 110.
  • the communication device 110 may include well known computing systems, environments, and/or configurations that may be suitable for implementing features of the data card interaction tracking tool 150 such as, but are not limited to, smart phones, tablet computers, personal computers (PCs), server computers, handheld or laptop devices, multiprocessor systems, microprocessor-based systems, network PCs, server computers, minicomputers, mainframe computers, embedded systems, distributed computing environments that include any of the above systems or devices, and the like.
  • Figure 1 shows that the communication device 110 includes a processor 111, a memory 114 configured to store the instructions for operating a web application browser, an input/output devices 113, and a communication interface 112.
  • a user operating the communication device 110 may run the web application browser to access the data card interaction tracking tool 150 running on the application server 140.
  • at least some portions of the data card interaction tracking tool 150 may be stored on the memory 114 and/or operated to run on the communication device 110.
  • Data card interaction tracking tool 150 may be a representation of software, hardware, and/or middleware configured to implement features described herein, such as for the tracking of user interactions with an application and application state information for the application based on the user's interactions.
  • the application being tracked and/or the data card interaction tracking tool 150 may be a web-based application operating, for example, according to a .NET framework within the system 100.
  • the data card interaction tracking tool 150 may include control circuitry 151, data card tracking circuitry 152, and data card utilization circuitry 153.
  • Each of the control circuitry 151, the data card tracking circuitry 152, and the data card utilization circuitry 153 may be a representation of software, hardware, and/or middleware configured to implement respective features of the data card interaction tracking tool 150.
  • Control circuitry 151 may be configured to include configuration controls, e.g., graphical user interfaces, through which a user (e.g., an authorized user) may configure certain features of data card interaction tracking tool 150.
  • the control circuitry 151 may allow a user to filter the types of interactions recorded into data cards (e.g., track all user interactions with an application being tracked, track user interactions with the application that change a state of the application, track user interactions with the application that include search queries input by the user, track user interactions with the application that include access to additional information obtained through a network), and/or filter the type of information included on the data cards (e.g., select metadata, data visualizations, hyperlinks, timestamps, priority level information, or interaction information to present on the data cards).
  • configuration controls e.g., graphical user interfaces, through which a user (e.g., an authorized user) may configure certain features of data card interaction tracking tool 150.
  • the control circuitry 151 may allow a user to filter the types of interactions recorded into data cards (
  • Metadata generated for inclusion on a data card may include application information identifying the application being tracked, industry information identifying an industry corresponding to the application being tracked, data card generation information (e.g., date of data card generation, time of data card generation), data card deck generation information (e.g., date of data card deck generation, time of data card deck generation), tracked interaction type information (e.g., user search query input type for written/voice/visual search queries, mapping input type, user click tracking type, application configuration type), user tagging information (e.g., user name, address, phone number, user identification number, or other attributes), tracked interaction description information (e.g., attribute information for a location identified based on a selection of the mapping feature), application session identification, or identification information identifying a user associated with the tracked interaction.
  • data card generation information e.g., date of data card generation, time of data card generation
  • data card deck generation information e.g., date of data card deck generation, time of data card deck generation
  • tracked interaction type information e.g., user
  • the data card may also be generated to include data visualizations of data gathered through user interactions with the tracked application, hyperlinks related to the user interactions with the tracked application, timestamps corresponding to the user interactions with the tracked application, priority level information set by the user to associate with selected user interactions with the tracked application, or interaction information to present on the data cards.
  • the data card interaction tracking tool 150 may later read the information (e.g., metadata) stored on the data cards to identify an application and an application state described by the data cards, and the data card interaction tracking tool 150 may initiate execution of the application to begin running in the application state based on the information read from the data cards.
  • the data card interaction tracking tool 150 may also be configured by control circuitry 151 to set the parameters of what defines an application session for tracking user interactions into data cards that will be stored into a common data card deck that represents the application session.
  • the application session may be defined by a predetermined time period.
  • the application may also be defined by the detection of a predetermined initialization event, and the detection of a predetermined ending event, or class of events.
  • Control circuitry 151 may further be configured to include security controls for authenticating users to access, use, and/or configure features of the data card interaction tracking tool 150. The resulting interactions and state presented may be based on the user's role as authenticated. Control circuitry 151 may further be configured to include log-in controls that control a log-in process enabling the communication device 110 to log-in and access the data card interaction tracking tool 150 running on application server 140.
  • a user may open a web application browser on the communication device 110 and control the web application browser to initiate an application stored, for example, on the application server 140 to run through the web application browser.
  • the initiation of the application by the web application browser may also automatically initiate activation of the data card interaction tracking tool 150 to begin tracking the application by generating data cards that describe user interactions with the application.
  • the user may manually control activation of the data card interaction tracking tool 150.
  • the data card interaction tracking tool 150 While the data card interaction tracking tool 150 is running, the user's interaction with the application may be recorded into data cards.
  • Each data card generated by the data card interaction tracking tool 150 may correspond to user interactions for each unique application feature detected by the data card interaction tracking tool 150.
  • distinct application features may include user interactions during a definable application feature such as creating a data visualization, revising application control settings, navigating through a set of connected application pages, interacting under a common application menu option, inserting information into a common data table, or other distinct application feature.
  • each data card may correspond to distinct sessions of time where the user is interacting with the application. For example, a session may last while the user is detected to be actively interacting with the application, or a session may last from initiating the application to ending the application.
  • Data cards generated during an application session of the user interacting with the application may be stored into a data card deck, where each data card in the same data card deck corresponds to a common application.
  • the user's session may be defined by, for example, starting from the initiation of the data card interaction tracking tool 150 or the initiation of the application being tracked, and lasting until a predetermined time period has passed, a predetermined interaction with the application is detected, or a predetermined number of data cards has been generated to store within a data card deck that defines the session.
  • the data card tracking circuitry 152 may track the user's interactions with the application.
  • the tracked interactions may, for example, describe an input into a search query field available on the application, a selection of a dashboard navigation feature available on the application (e.g., menu option, search query option, or a control configuration option), or a selection of a mapping feature available with the running application (e.g., a zooming feature).
  • the dashboard may be a web application that is comprised of elements which illustrate data in a visual manner, such as a data visualization (e.g., chart, graph, table, or other visual feature representing data).
  • the data card tracking circuitry 152 may also track information related to the application's state, where the application's state corresponds to an operational state of the application resulting from the user's interactions.
  • the data card tracking circuitry 152 may generate a data card to include the user interaction information and the application state information.
  • One or more data cards may be generated by the data card tracking circuitry 152 to include in a data card deck corresponding to an application session.
  • the data card tracking circuitry 152 may also generate metadata to include with the generated data cards and/or data card decks.
  • the information stored on a data card may be presented in various forms.
  • the information may be presented on the data cards as charts that show the state of the data and/or application relevant to the data card at the time of data card creation, selectable link/button/action options that allow the user to view a rolled back application state of the application upon selection of the table link/button/action options, priority level indicator that provides a visual indication of a priority level (e.g., in the form of highlighted colors, colored stars, or other indicators) assigned to a particular data card as identified by the user.
  • a priority level e.g., in the form of highlighted colors, colored stars, or other indicators
  • Figure 6 illustrates an exemplary graphical user interface (GUI) 600 of a data visualization development application, where the data card tracking circuitry 152 may simultaneously be running to track user interactions with the data visualization development application.
  • the GUI 600 may include a legend elements panel 610 for navigating the data visualization development application.
  • the legend elements panel 610 may include a search query input field for receiving the user's search query searching for a particular data visualization, a navigation pane that includes one or more navigational options for navigating to different features available in the data visualization development application, and a configuration menu for controlling configuration options of the data visualization development application.
  • the user may interact with the legend elements panel 610 by scrolling over portions of the legend elements panel 610, selecting (e.g., clicking) a component of the legend elements panel 610 that may result in a state change for the data visualization development application, or inputting information into an input field.
  • the data card interaction tracking tool 150 may generate a data card so that the user interactions, as well as any state changes to the data visualization development application resulting from the user interactions, and corresponding metadata generated for the user interactions, may be stored into the generated data card.
  • a state change may be a detectable change in the application such as navigating to another page, navigating to another menu screen, navigating to another application feature, saving work progress, logging onto the application, logging off the application, changing data provided by the application, changing information that results in changes to a data visualization, or the like.
  • the GUI 600 may further include a chart element panel 620 that includes interactive features for a user to develop a data visualization.
  • chart element panel 620 includes a data visualization section 621 that displays a data visualization 622 (e.g., bar chart type data visualization).
  • the user may interact with the data visualization section 621 by scrolling over portions of the data visualization 622, or selecting (e.g., clicking) a portion of the data visualization 622 to obtain information on the selected portion of the data visualization 622.
  • the user interactions, as well as any state changes to the data visualization development application resulting from the user interactions with the chart element panel 620, and corresponding metadata generated for the user interactions, may be stored into a generated data card.
  • the GUI 600 may further include a data visualization menu 623 and a data visualization sub-menu 624 corresponding to the data visualization menu 623.
  • the user may interact with the data visualization menu 623 and the data visualization sub-menu 624 by scrolling over portions of the data visualization menu 623 and the data visualization sub-menu 624, or selecting (e.g., clicking) selectable options of the data visualization menu 623 and the data visualization sub-menu 624.
  • a user interaction identifying a selection of the "sources" option from the data visualization menu 623, and selection of the "BarChart.jsx" template from the data visualization sub-menu 624 may be stored into a data card as a user interaction.
  • the user interactions, as well as any state changes to the data visualization development application resulting from the user interactions with the data visualization menu 623, and corresponding metadata generated for the user interactions may be stored into a generated data card.
  • the GUI 600 may further include a data visualization modification panel 625 for controlling the data visualization 622, and modifying attributes of the data visualization 622.
  • a user interaction with the data visualization modification panel 625 may include a recording of changes to the code within the data visualization modification panel 625.
  • the user interactions, as well as any state changes to the data visualization development application resulting from the user interactions with the data visualization modification panel 625, and corresponding metadata generated for the user interactions, may be stored into a generated data card.
  • a user interaction detected from the GUI 600 may be stored in a generated data card.
  • user interactions with the data visualization development application as detected by data card tracking circuitry 152, may be stored into a first data card 631, a second data card 632, and a third data card 633.
  • Each of the first data card 631, the second data card 632, and the third data card 633 may then be stored into a data card deck 630, where the data card deck 630 represents an application session.
  • Figure 7 illustrates an exemplary graphical user interface (GUI) 700 of a health visualization lab application, where the data card tracking circuitry 152 may simultaneously be running to track user interactions with the health visualization lab application.
  • the GUI 700 may include a legend elements panel 710 for navigating the health visualization lab application.
  • the legend elements panel 710 may include a search query input field for receiving the user's search query searching for a particular hospital address on a map, a navigation pane that includes one or more navigational options for navigating to different features available in the health visualization lab application, and a configuration menu for controlling configuration options of the health visualization lab application.
  • the user may interact with the legend elements panel 710 by scrolling over portions of the legend elements panel 710, or selecting (e.g., clicking) a component of the legend elements panel 610 that may result in a state change for the data visualization development application, or inputting information into an input field.
  • the user interactions, as well as any state changes to the health visualization lab application resulting from the user interactions, and corresponding metadata generated for the user interactions, may be stored into a generated data card.
  • the GUI 700 may further include a map element panel 720 that includes interactive features for a user to view information on a map layout.
  • map element panel 720 includes a map that highlights different locations for health related businesses, hospitals, clinics, or other health related locations.
  • One or more of the locations identified in the map layout may be inserted as a result to the user's search query input.
  • the user may interact with the map element panel 720 by scrolling over portions of the map layout that include interactive information. For example, after scrolling to different portions of the map layout, the user may scroll over, or select (e.g., click on), the interactive portion 721 of the map layout.
  • the health visualization lab application may cause an information sub-screen 722 to display on the GUI 700, where the information sub-screen 722 includes information corresponding to the interactive portion 721.
  • information sub-screen 722 may include information for a health facility located at the location identified by the interactive portion 721.
  • the user interactions, as well as any state changes to the health visualization lab application resulting from the user interactions from map element panel 720, and corresponding metadata generated for the user interactions, may be stored into a generated data card.
  • a user interaction detected from the GUI 700 may be stored in a generated data card.
  • user interactions with the data visualization development application may be stored into a first data card 731 (e.g., presented as "load Chicago area map"), a second data card 732 (e.g., presented as "add hospitals from Provider B"), a third data card 733 (e.g., presented as "switch map to zip code view"), a fourth data card 734 (e.g., presented as "color map according to percentile of flu admissions"), a fifth data card 735 (e.g., presented as "drill down on service area of Hospital 54"), and a sixth data card 736 (e.g., presented as "add zip code 60084").
  • a first data card 731 e.g., presented as "load Chicago area map”
  • second data card 732 e.g., presented as "add hospitals from Provider B
  • a third data card 733 e.g., presented as "switch map to zip code
  • Each of the first data card 731, the second data card 732, the third data card 733, the fourth data card 734, the fifth data card 735, and the sixth data card 736 may be generated to present a description of a respective user interaction.
  • Each of the first data card 731, the second data card 732, the third data card 733, the fourth data card 734, the fifth data card 735, and the sixth data card 736 may then be stored into a data card deck 730, where the data card deck 730 represents an application session.
  • the data card interaction tracking tool 150 may further include a data card utilization circuitry 153.
  • the data card utilization circuitry may control utilization of previously generated data cards.
  • the user may operate the communication device 110 to access database 120 to retrieve a data card deck, or one or more data cards, that are stored on the database 120.
  • the retrieved data cards may be activated.
  • Activation of a data card may correspond to a selection (e.g., clicking) of the data card.
  • Activation of the data card may cause information included in the activated data card to be presented to the user.
  • the presentation of the information included in the data card may take on various visual and/or audio forms to describe the respective user interactions with the application.
  • Figure 8 illustrates an exemplary GUI 800 of the data card interaction tracking tool 150 that includes a data card deck 830 retrieved from database 120, where data card deck 830 includes at least a first data card 831 and a second data card 834.
  • the first data card 831 may have been generated to describe a user interaction corresponding to clicking on a manhole on a water sewage facility's monitoring map within a sewage facility monitoring application. Selection of the first data card 831 may be represented by the click input 832 over a surface of the first data card 831. Selection of the first data card 831 causes activation of the first data card 831, where the activation of the first data card 831 may cause the data card interaction tracking tool 150 to present metadata describing tracked interactions stored in the first data card 831.
  • the metadata may be presented in a presentation window 833 generated by the data card interaction tracking tool 150 in response to activation of the first data card 831. For example, amongst other information, information identifying a date and time when the first data card 831 was generated to track user interactions within the sewage facility monitoring application (e.g., August 24, 2015 at 01:00:00) may be presented within presentation window 833.
  • the metadata displayed in the presentation window 833 also includes a data visualization graph 836 and a priority level indicator 837. For example, each of the data visualization graph 836, the priority level indicator 837, and/or other metadata included with first data card 831 may be associated with a date and/or time of the user interaction captured by the first data card 831.
  • the presentation window 833 also includes navigation legend 838 that includes a number of navigation options (e.g., site details, real-time data, water quality, navigation tools), where selection of a navigation option may cause the presentation window 833 to display additional information corresponding to the selected navigation option. For example, selection of one of the navigation tools (e.g., right arrow, or left arrow), may cause the presentation window 833 to display additional metadata not currently displayed within the presentation window 833.
  • Selection of the site details navigation option may cause the data card interaction tracking tool 150 to initiate access to information corresponding to the site details. For example, selection of the site details navigation option may cause the data card interaction tracking tool 150 to parse through the network 130 to locate and retrieve information corresponding to the site details.
  • the retrieved site details information may then be displayed within the presentation window 833.
  • the metadata may include certain navigation options that behave like a hyperlink for providing instructions for retrieving information, without storing such information to be retrieved within the metadata. For example, selection of such navigation options may cause the data card interaction tracking tool 150 to navigate to another server within the network 130, retrieve information from the server, and display the retrieved information within the presentation window 833.
  • the GUI 800 may also include a transmission option 835 for transmitting selected data card deck(s), and/or selected data cards, to another communication device.
  • the sewage facility monitoring application corresponding to the first data card 831 may be initiated to run in a state identified in the first data card 831 based on the activation of the first data card 831.
  • a preview of the sewage facility monitoring application running in the state identified in the first data card 831 may be previewed in an application preview window 840.
  • Each of communication device 110, database 120, application server 140, and secondary application server 160 may include one or more components of computer system 200 illustrated in Figure 2 .
  • Figure 2 illustrates exemplary computer architecture for computer system 200.
  • Computer system 200 includes a network interface 220 that allows communication with other computers via a network 226, where network 226 may be represented by network 130 in Figure 1 .
  • Network 226 may be any suitable network and may support any appropriate protocol suitable for communication to computer system 200.
  • network 226 may support wireless communications.
  • network 226 may support hard-wired communications, such as a telephone line or cable.
  • network 226 may support the Ethernet IEEE (Institute of Electrical and Electronics Engineers) 802.3x specification.
  • network 226 may be the Internet and may support IP (Internet Protocol).
  • network 226 may be a LAN or a WAN.
  • network 226 may be a hotspot service provider network.
  • network 226 may be an intranet.
  • network 226 may be a GPRS (General Packet Radio Service) network.
  • network 226 may be any appropriate cellular data network or cell-based radio network technology.
  • network 226 may be an IEEE 802.11 wireless network.
  • network 226 may be any suitable network or combination of networks. Although one network 226 is shown in Figure 2 , network 226 may be representative of any number of networks (of the same or different types) that may be utilized.
  • the computer system 200 may also include a processor 202, a main memory 204, a static memory 206, an output device 210 (e.g., a display or speaker), an input device 212, and a storage device 216, communicating via a bus 208.
  • a processor 202 may also include a main memory 204, a static memory 206, an output device 210 (e.g., a display or speaker), an input device 212, and a storage device 216, communicating via a bus 208.
  • Processor 202 represents a central processing unit of any type of architecture, such as a CISC (Complex Instruction Set Computing), RISC (Reduced Instruction Set Computing), VLIW (Very Long Instruction Word), or a hybrid architecture, although any appropriate processor may be used.
  • Processor 202 executes instructions 224 stored on one or more of the main memory 204, static memory 206, or storage device 215.
  • Processor 202 may also include portions of the computer system 200 that control the operation of the entire computer system 200.
  • Processor 202 may also represent a controller that organizes data and program storage in memory and transfers data and other information between the various parts of the computer system 200.
  • Processor 202 is configured to receive input data and/or user commands through input device 212.
  • Input device 212 may be a keyboard, mouse or other pointing device, trackball, scroll, button, touchpad, touch screen, keypad, microphone, speech recognition device, video recognition device, accelerometer, gyroscope, global positioning system (GPS) transceiver, or any other appropriate mechanism for the user to input data to computer system 200 and control operation of computer system 200 and/or operation of the data card interaction tracking tool 150.
  • Input device 212 as illustrated in Figure 2 may be representative of any number and type of input devices.
  • Processor 202 may also communicate with other computer systems via network 226 to receive instructions 224, where processor 202 may control the storage of such instructions 224 into any one or more of the main memory 204 (e.g., random access memory (RAM)), static memory 206 (e.g., read only memory (ROM)), or the storage device 216. Processor 202 may then read and execute instructions 224 from any one or more of the main memory 204, static memory 206, or storage device 216. The instructions 224 may also be stored onto any one or more of the main memory 204, static memory 206, or storage device 216 through other sources. The instructions 224 may correspond to, for example, instructions that make up the data card interaction tracking tool 150.
  • main memory 204 e.g., random access memory (RAM)
  • static memory 206 e.g., read only memory (ROM)
  • Processor 202 may then read and execute instructions 224 from any one or more of the main memory 204, static memory 206, or storage device 216.
  • the instructions 224 may
  • computer system 200 is represented in Figure 2 as a single processor 202 and a single bus 208, the disclosed embodiments applies equally to computer systems that may have multiple processors and to computer systems that may have multiple busses with some or all performing different functions in different ways.
  • Storage device 216 represents one or more mechanisms for storing data.
  • storage device 216 may include a computer readable medium 222 such as read-only memory (ROM), RAM, non-volatile storage media, optical storage media, flash memory devices, and/or other machine-readable media. In other embodiments, any appropriate type of storage device may be used. Although only one storage device 216 is shown, multiple storage devices and multiple types of storage devices may be present.
  • computer system 200 is drawn to contain the storage device 216, it may be distributed across other computer systems that are in communication with computer system 200, such as a server in communication with computer system 200. For example, when computer system 200 is representative of communication device 110, storage device 216 may be distributed across to application server 140 when communication device 110 is in communication with application server 140 during operation of the data card interaction tracking tool 150.
  • Storage device 216 may include a controller (not shown) and a computer readable medium 222 having instructions 224 capable of being executed by processor 202 to carry out features of the data card interaction tracking tool 150. In another embodiment, some or all of the functions are carried out via hardware in lieu of a processor-based system.
  • the controller included in storage device 216 is a web application browser, but in other embodiments the controller may be a database system, a file system, an electronic mail system, a media manager, an image manager, or may include any other functions capable of accessing data items.
  • Storage device 216 may also contain additional software and data (not shown), for implementing described features.
  • Output device 210 is configured to present information to the user.
  • output device 210 may be a display such as a liquid crystal display (LCD), a gas or plasma-based flat-panel display, or a traditional cathode-ray tube (CRT) display or other well-known type of display in the art of computer hardware. Accordingly in some embodiments, output device 210 displays a user interface. In other embodiments, output device 210 may be a speaker configured to output audible information to the user. In still other embodiments, any combination of output devices may be represented by the output device 210.
  • LCD liquid crystal display
  • CRT cathode-ray tube
  • Network interface 220 provides the computer system 200 with connectivity to the network 226 through any compatible communications protocol.
  • Network interface 220 sends and/or receives data from the network 226 via a wireless or wired transceiver 214.
  • Transceiver 214 may be a cellular frequency, radio frequency (RF), infrared (IR) or any of a number of known wireless or wired transmission systems capable of communicating with network 226 or other computer device having some or all of the features of computer system 200.
  • Bus 208 may represent one or more busses, e.g., USB, PCI, ISA (Industry Standard Architecture), X-Bus, EISA (Extended Industry Standard Architecture), or any other appropriate bus and/or bridge (also called a bus controller).
  • Network interface 220 as illustrated in Figure 2 may be representative of a single network interface card configured to communicate with one or more different data sources.
  • the communications interface 142 i.e., a communications network interface
  • database interface 143 i.e., a database network interface
  • communications interface 142 and database interface 143 may be representative of a single network interface card hardware component configured to communicate with different data sources.
  • Computer system 200 may be implemented using any suitable hardware and/or software, such as a personal computer or other electronic computing device.
  • computer system 200 may also be a portable computer, laptop, tablet or notebook computer, PDA, pocket computer, appliance, telephone, server computer device, or mainframe computer.
  • Figure 3 illustrates an exemplary client-server block diagram describing components of the data card interaction tracking tool 150 operating on a server side device (e.g., operating on application server 140), and components of the data card interaction tracking tool 150 operating on a client side device (e.g., operating on communication device 110).
  • server side device e.g., operating on application server 140
  • client side device e.g., operating on communication device 110
  • application components of the data card interaction tracking tool 150 may be running on, for example, at least portions of the application server 140, and the database 120, and/or secondary application server 160.
  • the application components may include a database management system (DBMS) 301, an application program interface (API) data controller 302, and a server side routing component 303.
  • DBMS 301 may be implemented by memory components of the application server 140, the database 120, and/or the secondary application server 160 during operation of the data card interaction tracking tool 150.
  • API data controller 302 may be implemented by processor and/or controller components of application server 140.
  • Server side routing component 303 may be implemented by network interface components and/or router components of application server 140.
  • client side application logic components and visualization user interface components may be running on, for example, at least portions of communication device 110, the database 120, and/or application server 140.
  • the client side application logic components may include a client side router 304, a controller 305, data filters 306, and an event handling component 307.
  • the GUIs for the data card interaction tracking tool 150 described herein may include an exemplary dashboard layout styling 308.
  • Dashboard layout styling 308 for the data card interaction tracking tool 150 is illustrated by at least portions of the exemplary GUI 600 illustrated in Figure 6 , at least portions of the exemplary GUI 700 illustrated in Figure 7 , and at least portions of the exemplary GUI 800 illustrated in Figure 8 .
  • Figure 4 illustrates a flow diagram 400 of logic that the data card interaction tracking tool 150 may implement to track user interactions with an application and identify corresponding application states of the application resulting from the tracked user interactions. References are made to components illustrated in Figure 1 during the description of the flow diagram 400 for exemplary purposes.
  • the data card interaction tracking tool 150 may detect an activation state for activating tracking features of the data card interaction tracking tool 150 (401).
  • the activation state may be a detection of an application for tracking being initiated, a manual selection for activating the data card interaction tracking tool 150, or some other predetermined activation state that causes the data card interaction tracking tool 150 to activate.
  • the activation state may be detected by the control circuitry 151 of the data card interaction tracking tool 150.
  • the data card interaction tracking tool 150 may initiate user interaction tracking for tracking a corresponding application (402).
  • the interaction tracking may be implemented by the data card tracking circuitry 152 of the data card interaction tracking tool 150.
  • the data card tracking circuitry 152 may track the identifiable user interaction into a data card (403). The data card tracking circuitry 152 may continue to store tracked user interactions into data cards during an interaction session of the application.
  • the data card tracking circuitry 152 may further create metadata related to the information stored in the data card, and store the created metadata into the corresponding data card (404).
  • the data card tracking circuitry 152 may generate a data card deck to represent the interaction session for the application, and store data cards and corresponding metadata created during the interaction session into the data card deck (405). The data card tracking circuitry 152 may control the data card deck to be stored on database 120.
  • Figure 5 illustrates a flow diagram 500 of logic that the data card interaction tracking tool 150 may implement to activate previously generated data cards that are part of a data card deck. References are made to components illustrated in Figure 1 during the description of the flow diagram 500 for exemplary purposes.
  • the data card interaction tracking tool 150 may detect an activation state for activating data card utilization features of the data card interaction tracking tool 150 (501).
  • the activation state may be a detection of a previously tracked application being initiated, a manual selection for activating the data card interaction tracking tool 150, or some other predetermined activation state that causes the data card interaction tracking tool 150 to activate.
  • the activation state may be detected by the control circuitry 151 of the data card interaction tracking tool 150.
  • the data card interaction tracking tool 150 may initiate data card utilization features (502).
  • the data card utilization features may be implemented by the data card utilization circuitry 153 of the data card interaction tracking tool 150.
  • the data card utilization circuitry 153 may control a search for a data card deck (503). For example, the data card utilization circuitry 153 may receive a data card deck search query, and access database 120 to search database 120 for one or more data card decks that satisfy the received data card deck search query. The data card utilization circuitry 153 may then return one or more data card decks that satisfy the received data card deck search query, and present it to the user within a graphical user interface.
  • the data card deck search query may be input into a written input field, or received through a microphone as a voice command input. Data card decks may be searched according any of the information that is included in the data card deck and corresponding data cards.
  • the data card utilization circuitry 153 may receive the user's data card deck selection that selects a data card deck from the one or more data card decks presented in the graphical user interface (504).
  • data cards that comprise the selected data card deck may be presented to the user (505).
  • the data card utilization circuitry 153 may present the selected data card deck within GUI 800 as illustrated by data card deck 830 in Figure 8 .
  • the data card utilization circuitry 153 may receive the user's selection of the first data card 831 from the data card deck 830 (506). Although the first data card 831 is described as being selected based on a click action, other selection tools may be available. For example, the data card utilization circuitry 153 may utilize a sliding bar tool 860 for scrolling through the available data cards, first data card 831 and second data card 834.
  • the data card utilization circuitry 153 may activate the selected first data card 831 (507). Selection of the first data card 831 may cause the data card utilization circuitry 153 to activate and present information included in the first data card 831. For example, GUI 800 shows presentation window 833 being displayed in response to the click input 832 selection of the first data card 831.
  • Selection of the first data card 831 may also cause the data card utilization circuitry 153 to present additional actions for the selected first data card 831.
  • additional actions window 850 may include a transmit selected data card option 851 and a convert selected data card option 852.
  • the transmit selected data card option 851 may cause the data card utilization circuitry 153 to provide additional prompts for the user to input information (e.g., email address, phone number, mailing address, IP address information) for transmitting the selected first data card 831, or data card deck 830.
  • the data card utilization circuitry 153 may then control a process for transmitting the selected first data card 831, and/or data card deck 830, to the identified address.
  • the convert selected data card option 852 may cause the data card utilization circuitry 153 to provide options to the user to convert the data card into another data structure format. It follows that the data card utilization circuitry 153 may provide additional actions to implement for a selected data card.
  • Selection of the first data card 831 may also cause the data card utilization circuitry 153 to preview the tracked application operating in an application state identified in the selected first data card 831.
  • the preview of the tracked application may be presented in the application preview window 840 of GUI 800.
  • the application preview window 840 may display the application in an application state that includes information input into input fields of the application. It follows, that the data card utilization circuitry 153 may cause the tracked application to be previewed within application preview window 840, where the tracked application will be operating in an application state identified by a selected data card.
  • the data card utilization circuitry 153 may also receive user selection of the data card deck 830, and/or individual data cards within data card deck 830, for transmission to another communication device, where the selected data card deck 830, and/or data cards within the selected data card deck 830, identifies a respective application and a final state of the respective application that results from the steps recorded in the selected data card deck 830, and/or data cards within the selected data card deck 830.
  • the data card utilization circuitry 153 may also provide additional prompts for the user to input address information (e.g., email address, phone number, IP address information, or other type of digital address) for transmitting the selected data card deck 830, and/or data cards within the selected data card deck 830.
  • address information e.g., email address, phone number, IP address information, or other type of digital address
  • Sharing the selected data card deck 830, and/or data cards within the selected data card deck 830, with other users allows the other users to trace the steps recorded in the selected data card deck 830, and/or data cards within the selected data card deck 830, to accomplish the same results while operating the respective application.
  • an indicator may be presented on the receiving communication device announcing the receipt of the selected data card deck 830, and/or data cards within the selected data card deck 830.
  • the respective application may be caused to begin operation in the final state of the respective application when the respective application is next activated on the receiving communication device following the receipt of the selected data card deck 830, and/or data cards within the selected data card deck 830.
  • an option for activating the respective application in the final state of the respective application may be presented on the receiving communication device based on the receipt of the selected data card deck 830, and/or data cards within the selected data card deck 830.
  • the option for activating the respective application in the final state of the respective application may be presented on the receiving communication device to include one or more of the components of GUI 800 described in Figure 8 .
  • the transmission of the selected data card deck 830, and/or data cards within the selected data card deck 830, may be activated by selection of the transmission option 835 illustrated in GUI 800.
  • flow diagram 400 and flow diagram 500 may be implemented in different combinations.
  • reference to data card decks and data cards may be interchangeable.
  • circuitry that includes an instruction processor, such as a Central Processing Unit (CPU), microcontroller, or a microprocessor; or as an Application Specific Integrated Circuit (ASIC), Programmable Logic Device (PLD), or Field Programmable Gate Array (FPGA); or as circuitry that includes discrete logic or other circuit components, including analog circuit components, digital circuit components or both; or any combination thereof.
  • instruction processor such as a Central Processing Unit (CPU), microcontroller, or a microprocessor
  • ASIC Application Specific Integrated Circuit
  • PLD Programmable Logic Device
  • FPGA Field Programmable Gate Array
  • the circuitry may include discrete interconnected hardware components or may be combined on a single integrated circuit die, distributed among multiple integrated circuit dies, or implemented in a Multiple Chip Module (MCM) of multiple integrated circuit dies in a common package, as examples.
  • MCM Multiple Chip Module
  • the circuitry may store or access instructions for execution, or may implement its functionality in hardware alone.
  • the instructions may be stored in a tangible storage medium that is other than a transitory signal, such as a flash memory, a Random Access Memory (RAM), a Read Only Memory (ROM), an Erasable Programmable Read Only Memory (EPROM); or on a magnetic or optical disc, such as a Compact Disc Read Only Memory (CDROM), Hard Disk Drive (HDD), or other magnetic or optical disk; or in or on another machine-readable medium.
  • a product such as a computer program product, may include a storage medium and instructions stored in or on the medium, and the instructions when executed by the circuitry in a device may cause the device to implement any of the processing described above or illustrated in the drawings.
  • the circuitry may include multiple distinct system components, such as multiple processors and memories, and may span multiple distributed processing systems.
  • Parameters, databases, and other data structures may be separately stored and managed, may be incorporated into a single memory or database, may be logically and physically organized in many different ways, and may be implemented in many different ways.
  • Example implementations include linked lists, program variables, hash tables, arrays, records (e.g., database records), objects, and implicit storage mechanisms. Instructions may form parts (e.g., subroutines or other code sections) of a single program, may form multiple separate programs, may be distributed across multiple memories and processors, and may be implemented in many different ways.
  • Example implementations include stand-alone programs, and as part of a library, such as a shared library like a Dynamic Link Library (DLL).
  • the library may contain shared data and one or more shared programs that include instructions that perform any of the processing described above or illustrated in the drawings, when executed by the circuitry.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Business, Economics & Management (AREA)
  • Strategic Management (AREA)
  • Finance (AREA)
  • Databases & Information Systems (AREA)
  • Accounting & Taxation (AREA)
  • Data Mining & Analysis (AREA)
  • Development Economics (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Hardware Design (AREA)
  • Quality & Reliability (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Game Theory and Decision Science (AREA)
  • Economics (AREA)
  • Marketing (AREA)
  • General Business, Economics & Management (AREA)
  • Software Systems (AREA)
  • Computing Systems (AREA)
  • Human Computer Interaction (AREA)
  • Mathematical Physics (AREA)
  • User Interface Of Digital Computer (AREA)

Abstract

An interaction tracking system tracks user interactions with an application. The tracked interactions may be stored in a data structure along with information describing an application state of the tracked application resulting from the tracked interactions. The interaction tracking system stores the data structure in a database for subsequent search and retrieval, which allows different users to activate the stored data structure and initiate the application in application state described in the data structure. The interaction tracking system also transmits the data structure to other communication devices, where the data structure is activated on the receiving communication device.

Description

    BACKGROUND
  • Application development programs, as well as the applications being developed by the application development programs, may offer a number of different operational features for achieving a desired operational result, navigating to a desired destination, or creating a new desired component. For instance, an image editing program may implement dozens of image editing functions to adjust colors, modify resolution or image size, add special effects, manage image layers, and provide other functions. Given the number of options and features made available by applications to achieve desired results, one user may use a first set of features to take one series of interactions with an application to accomplish the desired result, while another user may use another set of features to take a different series of interactions with the same application to achieve the same result. That is, within the same application, different users may arrive at different, same, or similar desired results via very different sequences of operational interactions with the application.
  • DESCRIPTION OF THE FIGURES
    • Figure 1 illustrates an exemplary interaction tracking platform system.
    • Figure 2 illustrates a block diagram of an exemplary computer architecture for a device in the exemplary interaction tracking system illustrated in Figure 1.
    • Figure 3 illustrates an exemplary client-server block diagram describing components of a data card interaction tracking tool running on a client-side communication device and a server-side communication device, according to some embodiments.
    • Figure 4 illustrates a flow diagram of logic that a data card interaction tracking tool may implement.
    • Figure 5 illustrates an additional flow diagram of logic that a data card interaction tracking tool may implement.
    • Figure 6 illustrates an exemplary graphical interface of an application and a data card interaction tracking tool.
    • Figure 7 illustrates an exemplary graphical interface of an application and a data card interaction tracking tool.
    • Figure 8 illustrates an exemplary graphical interface of a data card interaction tracking tool.
    DETAILED DESCRIPTION
  • The methods, devices, systems, and other features discussed below may be embodied in a number of different forms. Not all of the depicted components may be required, however, and some implementations may include additional, different, or fewer components from those expressly described in this disclosure. Variations in the arrangement and type of the components may be made without departing from the spirit or scope of the claims as set forth herein. Further, variations in the processes described, including the addition, deletion, or rearranging and order of logical operations, may be made without departing from the spirit or scope of the claims as set forth herein.
  • Given the increasing level of connectivity between users through communication networks (e.g., the Internet), there has been increased interest and use of web-based applications. A web-based application is generally understood to be an application stored and configured to operate, at least in part, on a web server accessible to other communication devices connected to a common communication network. A user operating their communication device may communicate with the web-server through the common communication network to access and operate the web-based application. The web-based application offers many features, such as accessibility to remote users, based on its framework being stored on web server(s). The web-based application also has access to a vast amount of information available through the communication network. Such features give a user of the web-based application many different options for interacting with the web-based application.
  • The interaction tracking system ("system") described below provides an interaction tracking platform configured to provide the tools, including the instrumentation and software instructions, for tracking a user's interaction with an application. Although the disclosure references web-based applications, the interaction tracking platform is also applicable to static applications locally running on a computing system, as well as mobile applications running, at least in part, on a user's mobile computing device. Tracking the user's interactions may include recording the user's interactions with the application that changes a state of the application, analyzing the user's interactions to detect and store metadata related to the user's interactions, storing information related to a state of the application based on the user's interaction with the application, and storing information describing the application's state changes. The system may be initiated to track interactions during an application session period when the application is active. Specific identifiable interactions may be stored into individual data structures referred to as a data card, and the data cards that are generated during the application session may be stored into a data structure referred to as a data card deck. Note that while the examples below may make specific reference to web-based applications, the tracking platform may be applied to any application, whether web-based or running stand-alone on an individual computing platform.
  • The system also provides a unique way of presenting information to a user through the data cards. The system generates the data cards, including information and data points related to the user's interactions with the application, so that the data cards may act as a gateway to the application's state. The data cards also include application state information that may result from the user's interactions with the application. By including both interaction and state information, the user may later activate the data card to cause the application to revert back to a state described by the data card. In cases where the application is not currently running, the data card activation may consequently initiate the application to begin running and transition to the state described in the activated data card. In view of at least this feature, the data cards provide a technological improvement over simply providing a video recording of user interactions. The data cards offer the technological improvement by being embodied as a unique data format that includes application state information that may be interpreted to initiate execution of an application to run and revert back to a state described by the application state information.
  • Tracking a user's interactions with an application may be beneficial to record how a user achieved a desired result on the application, particularly where complex applications provide many different ways to the desired result. For example, the data cards that are included in the data card deck may describe interactive steps the user took with the application to achieve the desired result. The tracked interactions may be presented through the data cards as a time lapsed video recording of the user's interactions on the application, a written description of the user's interactions on the application, an audio description of the user's interactions on the application, or some combination thereof. The tracked interactions may include the user's selection of selectable options on the application, the user's input into input field of the application (e.g., search input fields), or some combination thereof.
  • Without the generation of the data cards and the data card deck, a subsequent user, development team, or other supervisory or regulatory entity desiring to understand the steps for achieving the same application result, may have difficulty recalling how certain results were achieved. The data card deck (or individual data cards from the data card deck) may be stored so that the user (or other user) may later retrieve the data card deck and review the interactions described by the data cards in an effort to recreate the desired result. The user may retrieve the data card deck from a database in which the data card deck is stored, or the data card deck may be transmitted to another user to present the tracked interactions to the other user. By reviewing the interactions described by the data cards, the other user may then be able to recreate the same desired result on the application as the user having created the data card deck. By reviewing the interactions and the state of the data cards, this other user may be able to identify or validate the scenario presented to the user to identify the critical components for improving future prioritization or presentation and development of data cards.
  • These and other features of the interaction tracking system are described in this disclosure.
  • Figure 1 illustrates exemplary system architecture for interaction tracking system 100 that includes component devices for implementing the described features. The system 100 includes an application server 140 configured to include the hardware, software, and/or middleware for operating the described data card interaction tracking tool 150. Application server 140 is shown to include a processor 141, a memory 144, a communication interface 142, and a database interface 143. The data card interaction tracking tool 150 may be operated as part of an add-on tool for an application also running on the application server 140. Alternatively, the data card interaction tracking tool 150 may be run independently of the application being tracked by the data card interaction tracking tool 150. For example, the application being tracked by the data card interaction tracking tool 150 may be running on a secondary application server 160, or a communication device 110, within the system 100. The application being tracked may also be running independently on the application server 140. According to some embodiments, portions, or all, of the data card interaction tracking tool 150 may be running on the communication device 110.
  • The system 100 further includes a database 120 configured to store data card decks, wherein each data card deck may include one or more data cards. The data card decks that are stored on the database 120 may have been received from application server 140 based on an operation of the data card interaction tracking tool 150. The data card decks that are stored on the database 120 may later be retrieved by the application server 140 based on an operation of the data card interaction tracking tool 150. The transmission of data card decks to the database 120, and the retrieval of data card decks from the database 120, may be accomplished by the application server 140 controlling the database interface 143.
  • The secondary application server 160 may be configured to communicate with the application server 140 either directly, or through network 130. The secondary application server 160 may be configured to store and/or operate a web-based application that is being tracked by the data card interaction tracking tool 150, according to some embodiments.
  • The system 100 communicates with any number and type of client devices, as represented by the communication device 110. The communication device 110 may include well known computing systems, environments, and/or configurations that may be suitable for implementing features of the data card interaction tracking tool 150 such as, but are not limited to, smart phones, tablet computers, personal computers (PCs), server computers, handheld or laptop devices, multiprocessor systems, microprocessor-based systems, network PCs, server computers, minicomputers, mainframe computers, embedded systems, distributed computing environments that include any of the above systems or devices, and the like.
  • Figure 1 shows that the communication device 110 includes a processor 111, a memory 114 configured to store the instructions for operating a web application browser, an input/output devices 113, and a communication interface 112. A user operating the communication device 110 may run the web application browser to access the data card interaction tracking tool 150 running on the application server 140. As mentioned, according to some embodiments at least some portions of the data card interaction tracking tool 150 may be stored on the memory 114 and/or operated to run on the communication device 110.
  • Data card interaction tracking tool 150 may be a representation of software, hardware, and/or middleware configured to implement features described herein, such as for the tracking of user interactions with an application and application state information for the application based on the user's interactions. For example, the application being tracked and/or the data card interaction tracking tool 150 may be a web-based application operating, for example, according to a .NET framework within the system 100.
  • More specifically, the data card interaction tracking tool 150 may include control circuitry 151, data card tracking circuitry 152, and data card utilization circuitry 153. Each of the control circuitry 151, the data card tracking circuitry 152, and the data card utilization circuitry 153 may be a representation of software, hardware, and/or middleware configured to implement respective features of the data card interaction tracking tool 150.
  • Control circuitry 151 may be configured to include configuration controls, e.g., graphical user interfaces, through which a user (e.g., an authorized user) may configure certain features of data card interaction tracking tool 150. For example, the control circuitry 151 may allow a user to filter the types of interactions recorded into data cards (e.g., track all user interactions with an application being tracked, track user interactions with the application that change a state of the application, track user interactions with the application that include search queries input by the user, track user interactions with the application that include access to additional information obtained through a network), and/or filter the type of information included on the data cards (e.g., select metadata, data visualizations, hyperlinks, timestamps, priority level information, or interaction information to present on the data cards). For example, metadata generated for inclusion on a data card may include application information identifying the application being tracked, industry information identifying an industry corresponding to the application being tracked, data card generation information (e.g., date of data card generation, time of data card generation), data card deck generation information (e.g., date of data card deck generation, time of data card deck generation), tracked interaction type information (e.g., user search query input type for written/voice/visual search queries, mapping input type, user click tracking type, application configuration type), user tagging information (e.g., user name, address, phone number, user identification number, or other attributes), tracked interaction description information (e.g., attribute information for a location identified based on a selection of the mapping feature), application session identification, or identification information identifying a user associated with the tracked interaction. The data card may also be generated to include data visualizations of data gathered through user interactions with the tracked application, hyperlinks related to the user interactions with the tracked application, timestamps corresponding to the user interactions with the tracked application, priority level information set by the user to associate with selected user interactions with the tracked application, or interaction information to present on the data cards. The data card interaction tracking tool 150 may later read the information (e.g., metadata) stored on the data cards to identify an application and an application state described by the data cards, and the data card interaction tracking tool 150 may initiate execution of the application to begin running in the application state based on the information read from the data cards.
  • The data card interaction tracking tool 150 may also be configured by control circuitry 151 to set the parameters of what defines an application session for tracking user interactions into data cards that will be stored into a common data card deck that represents the application session. For example, the application session may be defined by a predetermined time period. The application may also be defined by the detection of a predetermined initialization event, and the detection of a predetermined ending event, or class of events.
  • Control circuitry 151 may further be configured to include security controls for authenticating users to access, use, and/or configure features of the data card interaction tracking tool 150. The resulting interactions and state presented may be based on the user's role as authenticated. Control circuitry 151 may further be configured to include log-in controls that control a log-in process enabling the communication device 110 to log-in and access the data card interaction tracking tool 150 running on application server 140.
  • To initiate activation of the data card interaction tracking tool 150, a user may open a web application browser on the communication device 110 and control the web application browser to initiate an application stored, for example, on the application server 140 to run through the web application browser. The initiation of the application by the web application browser may also automatically initiate activation of the data card interaction tracking tool 150 to begin tracking the application by generating data cards that describe user interactions with the application. Alternatively, the user may manually control activation of the data card interaction tracking tool 150. While the data card interaction tracking tool 150 is running, the user's interaction with the application may be recorded into data cards. Each data card generated by the data card interaction tracking tool 150 may correspond to user interactions for each unique application feature detected by the data card interaction tracking tool 150. For example, distinct application features may include user interactions during a definable application feature such as creating a data visualization, revising application control settings, navigating through a set of connected application pages, interacting under a common application menu option, inserting information into a common data table, or other distinct application feature. In addition or alternatively, each data card may correspond to distinct sessions of time where the user is interacting with the application. For example, a session may last while the user is detected to be actively interacting with the application, or a session may last from initiating the application to ending the application.
  • Data cards generated during an application session of the user interacting with the application may be stored into a data card deck, where each data card in the same data card deck corresponds to a common application. The user's session may be defined by, for example, starting from the initiation of the data card interaction tracking tool 150 or the initiation of the application being tracked, and lasting until a predetermined time period has passed, a predetermined interaction with the application is detected, or a predetermined number of data cards has been generated to store within a data card deck that defines the session.
  • During operation of the data card interaction tracking tool 150, the data card tracking circuitry 152 may track the user's interactions with the application. The tracked interactions may, for example, describe an input into a search query field available on the application, a selection of a dashboard navigation feature available on the application (e.g., menu option, search query option, or a control configuration option), or a selection of a mapping feature available with the running application (e.g., a zooming feature). The dashboard may be a web application that is comprised of elements which illustrate data in a visual manner, such as a data visualization (e.g., chart, graph, table, or other visual feature representing data). The data card tracking circuitry 152 may also track information related to the application's state, where the application's state corresponds to an operational state of the application resulting from the user's interactions. The data card tracking circuitry 152 may generate a data card to include the user interaction information and the application state information. One or more data cards may be generated by the data card tracking circuitry 152 to include in a data card deck corresponding to an application session. The data card tracking circuitry 152 may also generate metadata to include with the generated data cards and/or data card decks. The information stored on a data card may be presented in various forms. For example, the information may be presented on the data cards as charts that show the state of the data and/or application relevant to the data card at the time of data card creation, selectable link/button/action options that allow the user to view a rolled back application state of the application upon selection of the table link/button/action options, priority level indicator that provides a visual indication of a priority level (e.g., in the form of highlighted colors, colored stars, or other indicators) assigned to a particular data card as identified by the user.
  • Figure 6 illustrates an exemplary graphical user interface (GUI) 600 of a data visualization development application, where the data card tracking circuitry 152 may simultaneously be running to track user interactions with the data visualization development application. The GUI 600 may include a legend elements panel 610 for navigating the data visualization development application. For example, the legend elements panel 610 may include a search query input field for receiving the user's search query searching for a particular data visualization, a navigation pane that includes one or more navigational options for navigating to different features available in the data visualization development application, and a configuration menu for controlling configuration options of the data visualization development application. The user may interact with the legend elements panel 610 by scrolling over portions of the legend elements panel 610, selecting (e.g., clicking) a component of the legend elements panel 610 that may result in a state change for the data visualization development application, or inputting information into an input field. The data card interaction tracking tool 150 may generate a data card so that the user interactions, as well as any state changes to the data visualization development application resulting from the user interactions, and corresponding metadata generated for the user interactions, may be stored into the generated data card. A state change may be a detectable change in the application such as navigating to another page, navigating to another menu screen, navigating to another application feature, saving work progress, logging onto the application, logging off the application, changing data provided by the application, changing information that results in changes to a data visualization, or the like.
  • The GUI 600 may further include a chart element panel 620 that includes interactive features for a user to develop a data visualization. For example, chart element panel 620 includes a data visualization section 621 that displays a data visualization 622 (e.g., bar chart type data visualization). The user may interact with the data visualization section 621 by scrolling over portions of the data visualization 622, or selecting (e.g., clicking) a portion of the data visualization 622 to obtain information on the selected portion of the data visualization 622. The user interactions, as well as any state changes to the data visualization development application resulting from the user interactions with the chart element panel 620, and corresponding metadata generated for the user interactions, may be stored into a generated data card.
  • The GUI 600 may further include a data visualization menu 623 and a data visualization sub-menu 624 corresponding to the data visualization menu 623. The user may interact with the data visualization menu 623 and the data visualization sub-menu 624 by scrolling over portions of the data visualization menu 623 and the data visualization sub-menu 624, or selecting (e.g., clicking) selectable options of the data visualization menu 623 and the data visualization sub-menu 624. For example, a user interaction identifying a selection of the "sources" option from the data visualization menu 623, and selection of the "BarChart.jsx" template from the data visualization sub-menu 624, may be stored into a data card as a user interaction. The user interactions, as well as any state changes to the data visualization development application resulting from the user interactions with the data visualization menu 623, and corresponding metadata generated for the user interactions, may be stored into a generated data card.
  • The GUI 600 may further include a data visualization modification panel 625 for controlling the data visualization 622, and modifying attributes of the data visualization 622. For example, a user interaction with the data visualization modification panel 625 may include a recording of changes to the code within the data visualization modification panel 625. The user interactions, as well as any state changes to the data visualization development application resulting from the user interactions with the data visualization modification panel 625, and corresponding metadata generated for the user interactions, may be stored into a generated data card.
  • A user interaction detected from the GUI 600 may be stored in a generated data card. For example, user interactions with the data visualization development application, as detected by data card tracking circuitry 152, may be stored into a first data card 631, a second data card 632, and a third data card 633. Each of the first data card 631, the second data card 632, and the third data card 633 may then be stored into a data card deck 630, where the data card deck 630 represents an application session.
  • Figure 7 illustrates an exemplary graphical user interface (GUI) 700 of a health visualization lab application, where the data card tracking circuitry 152 may simultaneously be running to track user interactions with the health visualization lab application. The GUI 700 may include a legend elements panel 710 for navigating the health visualization lab application. For example, the legend elements panel 710 may include a search query input field for receiving the user's search query searching for a particular hospital address on a map, a navigation pane that includes one or more navigational options for navigating to different features available in the health visualization lab application, and a configuration menu for controlling configuration options of the health visualization lab application. The user may interact with the legend elements panel 710 by scrolling over portions of the legend elements panel 710, or selecting (e.g., clicking) a component of the legend elements panel 610 that may result in a state change for the data visualization development application, or inputting information into an input field. The user interactions, as well as any state changes to the health visualization lab application resulting from the user interactions, and corresponding metadata generated for the user interactions, may be stored into a generated data card.
  • The GUI 700 may further include a map element panel 720 that includes interactive features for a user to view information on a map layout. For example, map element panel 720 includes a map that highlights different locations for health related businesses, hospitals, clinics, or other health related locations. One or more of the locations identified in the map layout may be inserted as a result to the user's search query input. The user may interact with the map element panel 720 by scrolling over portions of the map layout that include interactive information. For example, after scrolling to different portions of the map layout, the user may scroll over, or select (e.g., click on), the interactive portion 721 of the map layout. By interacting with the interactive portion 721 of the map layout, the health visualization lab application may cause an information sub-screen 722 to display on the GUI 700, where the information sub-screen 722 includes information corresponding to the interactive portion 721. For example, information sub-screen 722 may include information for a health facility located at the location identified by the interactive portion 721. The user interactions, as well as any state changes to the health visualization lab application resulting from the user interactions from map element panel 720, and corresponding metadata generated for the user interactions, may be stored into a generated data card.
  • A user interaction detected from the GUI 700 may be stored in a generated data card. For example, user interactions with the data visualization development application, as detected by the data card tracking circuitry 152, may be stored into a first data card 731 (e.g., presented as "load Chicago area map"), a second data card 732 (e.g., presented as "add hospitals from Provider B"), a third data card 733 (e.g., presented as "switch map to zip code view"), a fourth data card 734 (e.g., presented as "color map according to percentile of flu admissions"), a fifth data card 735 (e.g., presented as "drill down on service area of Hospital 54"), and a sixth data card 736 (e.g., presented as "add zip code 60084"). Each of the first data card 731, the second data card 732, the third data card 733, the fourth data card 734, the fifth data card 735, and the sixth data card 736 may be generated to present a description of a respective user interaction. Each of the first data card 731, the second data card 732, the third data card 733, the fourth data card 734, the fifth data card 735, and the sixth data card 736 may then be stored into a data card deck 730, where the data card deck 730 represents an application session.
  • Referring back to Figure 1, the data card interaction tracking tool 150 may further include a data card utilization circuitry 153. The data card utilization circuitry may control utilization of previously generated data cards. For example, the user may operate the communication device 110 to access database 120 to retrieve a data card deck, or one or more data cards, that are stored on the database 120. Then while running the data card interaction tracking tool 150, the retrieved data cards may be activated. Activation of a data card may correspond to a selection (e.g., clicking) of the data card. Activation of the data card may cause information included in the activated data card to be presented to the user. The presentation of the information included in the data card may take on various visual and/or audio forms to describe the respective user interactions with the application. For example, Figure 8 illustrates an exemplary GUI 800 of the data card interaction tracking tool 150 that includes a data card deck 830 retrieved from database 120, where data card deck 830 includes at least a first data card 831 and a second data card 834. The first data card 831 may have been generated to describe a user interaction corresponding to clicking on a manhole on a water sewage facility's monitoring map within a sewage facility monitoring application. Selection of the first data card 831 may be represented by the click input 832 over a surface of the first data card 831. Selection of the first data card 831 causes activation of the first data card 831, where the activation of the first data card 831 may cause the data card interaction tracking tool 150 to present metadata describing tracked interactions stored in the first data card 831. The metadata may be presented in a presentation window 833 generated by the data card interaction tracking tool 150 in response to activation of the first data card 831. For example, amongst other information, information identifying a date and time when the first data card 831 was generated to track user interactions within the sewage facility monitoring application (e.g., August 24, 2015 at 01:00:00) may be presented within presentation window 833. The metadata displayed in the presentation window 833 also includes a data visualization graph 836 and a priority level indicator 837. For example, each of the data visualization graph 836, the priority level indicator 837, and/or other metadata included with first data card 831 may be associated with a date and/or time of the user interaction captured by the first data card 831. The presentation window 833 also includes navigation legend 838 that includes a number of navigation options (e.g., site details, real-time data, water quality, navigation tools), where selection of a navigation option may cause the presentation window 833 to display additional information corresponding to the selected navigation option. For example, selection of one of the navigation tools (e.g., right arrow, or left arrow), may cause the presentation window 833 to display additional metadata not currently displayed within the presentation window 833. Selection of the site details navigation option may cause the data card interaction tracking tool 150 to initiate access to information corresponding to the site details. For example, selection of the site details navigation option may cause the data card interaction tracking tool 150 to parse through the network 130 to locate and retrieve information corresponding to the site details. The retrieved site details information may then be displayed within the presentation window 833. It follows that the metadata may include certain navigation options that behave like a hyperlink for providing instructions for retrieving information, without storing such information to be retrieved within the metadata. For example, selection of such navigation options may cause the data card interaction tracking tool 150 to navigate to another server within the network 130, retrieve information from the server, and display the retrieved information within the presentation window 833.
  • The GUI 800 may also include a transmission option 835 for transmitting selected data card deck(s), and/or selected data cards, to another communication device.
  • In addition, the sewage facility monitoring application corresponding to the first data card 831 may be initiated to run in a state identified in the first data card 831 based on the activation of the first data card 831. For example, a preview of the sewage facility monitoring application running in the state identified in the first data card 831 may be previewed in an application preview window 840.
  • Each of communication device 110, database 120, application server 140, and secondary application server 160 may include one or more components of computer system 200 illustrated in Figure 2.
  • Figure 2 illustrates exemplary computer architecture for computer system 200. Computer system 200 includes a network interface 220 that allows communication with other computers via a network 226, where network 226 may be represented by network 130 in Figure 1. Network 226 may be any suitable network and may support any appropriate protocol suitable for communication to computer system 200. In an embodiment, network 226 may support wireless communications. In another embodiment, network 226 may support hard-wired communications, such as a telephone line or cable. In another embodiment, network 226 may support the Ethernet IEEE (Institute of Electrical and Electronics Engineers) 802.3x specification. In another embodiment, network 226 may be the Internet and may support IP (Internet Protocol). In another embodiment, network 226 may be a LAN or a WAN. In another embodiment, network 226 may be a hotspot service provider network. In another embodiment, network 226 may be an intranet. In another embodiment, network 226 may be a GPRS (General Packet Radio Service) network. In another embodiment, network 226 may be any appropriate cellular data network or cell-based radio network technology. In another embodiment, network 226 may be an IEEE 802.11 wireless network. In still another embodiment, network 226 may be any suitable network or combination of networks. Although one network 226 is shown in Figure 2, network 226 may be representative of any number of networks (of the same or different types) that may be utilized.
  • The computer system 200 may also include a processor 202, a main memory 204, a static memory 206, an output device 210 (e.g., a display or speaker), an input device 212, and a storage device 216, communicating via a bus 208.
  • Processor 202 represents a central processing unit of any type of architecture, such as a CISC (Complex Instruction Set Computing), RISC (Reduced Instruction Set Computing), VLIW (Very Long Instruction Word), or a hybrid architecture, although any appropriate processor may be used. Processor 202 executes instructions 224 stored on one or more of the main memory 204, static memory 206, or storage device 215. Processor 202 may also include portions of the computer system 200 that control the operation of the entire computer system 200. Processor 202 may also represent a controller that organizes data and program storage in memory and transfers data and other information between the various parts of the computer system 200.
  • Processor 202 is configured to receive input data and/or user commands through input device 212. Input device 212 may be a keyboard, mouse or other pointing device, trackball, scroll, button, touchpad, touch screen, keypad, microphone, speech recognition device, video recognition device, accelerometer, gyroscope, global positioning system (GPS) transceiver, or any other appropriate mechanism for the user to input data to computer system 200 and control operation of computer system 200 and/or operation of the data card interaction tracking tool 150. Input device 212 as illustrated in Figure 2 may be representative of any number and type of input devices.
  • Processor 202 may also communicate with other computer systems via network 226 to receive instructions 224, where processor 202 may control the storage of such instructions 224 into any one or more of the main memory 204 (e.g., random access memory (RAM)), static memory 206 (e.g., read only memory (ROM)), or the storage device 216. Processor 202 may then read and execute instructions 224 from any one or more of the main memory 204, static memory 206, or storage device 216. The instructions 224 may also be stored onto any one or more of the main memory 204, static memory 206, or storage device 216 through other sources. The instructions 224 may correspond to, for example, instructions that make up the data card interaction tracking tool 150.
  • Although computer system 200 is represented in Figure 2 as a single processor 202 and a single bus 208, the disclosed embodiments applies equally to computer systems that may have multiple processors and to computer systems that may have multiple busses with some or all performing different functions in different ways.
  • Storage device 216 represents one or more mechanisms for storing data. For example, storage device 216 may include a computer readable medium 222 such as read-only memory (ROM), RAM, non-volatile storage media, optical storage media, flash memory devices, and/or other machine-readable media. In other embodiments, any appropriate type of storage device may be used. Although only one storage device 216 is shown, multiple storage devices and multiple types of storage devices may be present. Further, although computer system 200 is drawn to contain the storage device 216, it may be distributed across other computer systems that are in communication with computer system 200, such as a server in communication with computer system 200. For example, when computer system 200 is representative of communication device 110, storage device 216 may be distributed across to application server 140 when communication device 110 is in communication with application server 140 during operation of the data card interaction tracking tool 150.
  • Storage device 216 may include a controller (not shown) and a computer readable medium 222 having instructions 224 capable of being executed by processor 202 to carry out features of the data card interaction tracking tool 150. In another embodiment, some or all of the functions are carried out via hardware in lieu of a processor-based system. In one embodiment, the controller included in storage device 216 is a web application browser, but in other embodiments the controller may be a database system, a file system, an electronic mail system, a media manager, an image manager, or may include any other functions capable of accessing data items. Storage device 216 may also contain additional software and data (not shown), for implementing described features.
  • Output device 210 is configured to present information to the user. For example, output device 210 may be a display such as a liquid crystal display (LCD), a gas or plasma-based flat-panel display, or a traditional cathode-ray tube (CRT) display or other well-known type of display in the art of computer hardware. Accordingly in some embodiments, output device 210 displays a user interface. In other embodiments, output device 210 may be a speaker configured to output audible information to the user. In still other embodiments, any combination of output devices may be represented by the output device 210.
  • Network interface 220 provides the computer system 200 with connectivity to the network 226 through any compatible communications protocol. Network interface 220 sends and/or receives data from the network 226 via a wireless or wired transceiver 214. Transceiver 214 may be a cellular frequency, radio frequency (RF), infrared (IR) or any of a number of known wireless or wired transmission systems capable of communicating with network 226 or other computer device having some or all of the features of computer system 200. Bus 208 may represent one or more busses, e.g., USB, PCI, ISA (Industry Standard Architecture), X-Bus, EISA (Extended Industry Standard Architecture), or any other appropriate bus and/or bridge (also called a bus controller). Network interface 220 as illustrated in Figure 2 may be representative of a single network interface card configured to communicate with one or more different data sources. For example, according to some embodiments the communications interface 142 (i.e., a communications network interface) and database interface 143 (i.e., a database network interface) may be separate network interface card hardware components dedicated to communicating with different data sources. In other embodiments, communications interface 142 and database interface 143 may be representative of a single network interface card hardware component configured to communicate with different data sources.
  • Computer system 200 may be implemented using any suitable hardware and/or software, such as a personal computer or other electronic computing device. In addition, computer system 200 may also be a portable computer, laptop, tablet or notebook computer, PDA, pocket computer, appliance, telephone, server computer device, or mainframe computer.
  • Figure 3 illustrates an exemplary client-server block diagram describing components of the data card interaction tracking tool 150 operating on a server side device (e.g., operating on application server 140), and components of the data card interaction tracking tool 150 operating on a client side device (e.g., operating on communication device 110).
  • On the server side operations, application components of the data card interaction tracking tool 150 may be running on, for example, at least portions of the application server 140, and the database 120, and/or secondary application server 160. The application components may include a database management system (DBMS) 301, an application program interface (API) data controller 302, and a server side routing component 303. DBMS 301 may be implemented by memory components of the application server 140, the database 120, and/or the secondary application server 160 during operation of the data card interaction tracking tool 150. API data controller 302 may be implemented by processor and/or controller components of application server 140. Server side routing component 303 may be implemented by network interface components and/or router components of application server 140.
  • On the client side operations, client side application logic components and visualization user interface components may be running on, for example, at least portions of communication device 110, the database 120, and/or application server 140. The client side application logic components may include a client side router 304, a controller 305, data filters 306, and an event handling component 307. The GUIs for the data card interaction tracking tool 150 described herein may include an exemplary dashboard layout styling 308. Dashboard layout styling 308 for the data card interaction tracking tool 150 is illustrated by at least portions of the exemplary GUI 600 illustrated in Figure 6, at least portions of the exemplary GUI 700 illustrated in Figure 7, and at least portions of the exemplary GUI 800 illustrated in Figure 8.
  • Figure 4 illustrates a flow diagram 400 of logic that the data card interaction tracking tool 150 may implement to track user interactions with an application and identify corresponding application states of the application resulting from the tracked user interactions. References are made to components illustrated in Figure 1 during the description of the flow diagram 400 for exemplary purposes.
  • The data card interaction tracking tool 150 may detect an activation state for activating tracking features of the data card interaction tracking tool 150 (401). The activation state may be a detection of an application for tracking being initiated, a manual selection for activating the data card interaction tracking tool 150, or some other predetermined activation state that causes the data card interaction tracking tool 150 to activate. The activation state may be detected by the control circuitry 151 of the data card interaction tracking tool 150.
  • Based on the detection of the activation state, the data card interaction tracking tool 150 may initiate user interaction tracking for tracking a corresponding application (402). The interaction tracking may be implemented by the data card tracking circuitry 152 of the data card interaction tracking tool 150.
  • For each identifiable user interaction with the application, the data card tracking circuitry 152 may track the identifiable user interaction into a data card (403). The data card tracking circuitry 152 may continue to store tracked user interactions into data cards during an interaction session of the application.
  • For each data card generated by the data card tracking circuitry 152, the data card tracking circuitry 152 may further create metadata related to the information stored in the data card, and store the created metadata into the corresponding data card (404).
  • The data card tracking circuitry 152 may generate a data card deck to represent the interaction session for the application, and store data cards and corresponding metadata created during the interaction session into the data card deck (405). The data card tracking circuitry 152 may control the data card deck to be stored on database 120.
  • Figure 5 illustrates a flow diagram 500 of logic that the data card interaction tracking tool 150 may implement to activate previously generated data cards that are part of a data card deck. References are made to components illustrated in Figure 1 during the description of the flow diagram 500 for exemplary purposes.
  • The data card interaction tracking tool 150 may detect an activation state for activating data card utilization features of the data card interaction tracking tool 150 (501). The activation state may be a detection of a previously tracked application being initiated, a manual selection for activating the data card interaction tracking tool 150, or some other predetermined activation state that causes the data card interaction tracking tool 150 to activate. The activation state may be detected by the control circuitry 151 of the data card interaction tracking tool 150.
  • Based on the detection of the activation state, the data card interaction tracking tool 150 may initiate data card utilization features (502). The data card utilization features may be implemented by the data card utilization circuitry 153 of the data card interaction tracking tool 150.
  • As part of utilizing the data cards, the data card utilization circuitry 153 may control a search for a data card deck (503). For example, the data card utilization circuitry 153 may receive a data card deck search query, and access database 120 to search database 120 for one or more data card decks that satisfy the received data card deck search query. The data card utilization circuitry 153 may then return one or more data card decks that satisfy the received data card deck search query, and present it to the user within a graphical user interface. The data card deck search query may be input into a written input field, or received through a microphone as a voice command input. Data card decks may be searched according any of the information that is included in the data card deck and corresponding data cards.
  • As part of utilizing the data cards, the data card utilization circuitry 153 may receive the user's data card deck selection that selects a data card deck from the one or more data card decks presented in the graphical user interface (504).
  • Based on the selected data card deck, data cards that comprise the selected data card deck may be presented to the user (505). For example, the data card utilization circuitry 153 may present the selected data card deck within GUI 800 as illustrated by data card deck 830 in Figure 8.
  • The data card utilization circuitry 153 may receive the user's selection of the first data card 831 from the data card deck 830 (506). Although the first data card 831 is described as being selected based on a click action, other selection tools may be available. For example, the data card utilization circuitry 153 may utilize a sliding bar tool 860 for scrolling through the available data cards, first data card 831 and second data card 834.
  • Based on the selection of the first data card 831, the data card utilization circuitry 153 may activate the selected first data card 831 (507). Selection of the first data card 831 may cause the data card utilization circuitry 153 to activate and present information included in the first data card 831. For example, GUI 800 shows presentation window 833 being displayed in response to the click input 832 selection of the first data card 831.
  • Selection of the first data card 831 may also cause the data card utilization circuitry 153 to present additional actions for the selected first data card 831. For example, additional actions window 850 may include a transmit selected data card option 851 and a convert selected data card option 852. The transmit selected data card option 851 may cause the data card utilization circuitry 153 to provide additional prompts for the user to input information (e.g., email address, phone number, mailing address, IP address information) for transmitting the selected first data card 831, or data card deck 830. The data card utilization circuitry 153 may then control a process for transmitting the selected first data card 831, and/or data card deck 830, to the identified address.
  • The convert selected data card option 852 may cause the data card utilization circuitry 153 to provide options to the user to convert the data card into another data structure format. It follows that the data card utilization circuitry 153 may provide additional actions to implement for a selected data card.
  • Selection of the first data card 831 may also cause the data card utilization circuitry 153 to preview the tracked application operating in an application state identified in the selected first data card 831. The preview of the tracked application may be presented in the application preview window 840 of GUI 800. For example, the application preview window 840 may display the application in an application state that includes information input into input fields of the application. It follows, that the data card utilization circuitry 153 may cause the tracked application to be previewed within application preview window 840, where the tracked application will be operating in an application state identified by a selected data card.
  • Separate, or in addition to the logic described for flow diagram 500, the data card utilization circuitry 153 may also receive user selection of the data card deck 830, and/or individual data cards within data card deck 830, for transmission to another communication device, where the selected data card deck 830, and/or data cards within the selected data card deck 830, identifies a respective application and a final state of the respective application that results from the steps recorded in the selected data card deck 830, and/or data cards within the selected data card deck 830. The data card utilization circuitry 153 may also provide additional prompts for the user to input address information (e.g., email address, phone number, IP address information, or other type of digital address) for transmitting the selected data card deck 830, and/or data cards within the selected data card deck 830. Sharing the selected data card deck 830, and/or data cards within the selected data card deck 830, with other users allows the other users to trace the steps recorded in the selected data card deck 830, and/or data cards within the selected data card deck 830, to accomplish the same results while operating the respective application. When the communication device receiving the selected data card deck 830, and/or data cards within the selected data card deck 830, also includes the data card interaction tracking tool, an indicator may be presented on the receiving communication device announcing the receipt of the selected data card deck 830, and/or data cards within the selected data card deck 830. According to some embodiments, the respective application may be caused to begin operation in the final state of the respective application when the respective application is next activated on the receiving communication device following the receipt of the selected data card deck 830, and/or data cards within the selected data card deck 830. According to some embodiments, an option for activating the respective application in the final state of the respective application may be presented on the receiving communication device based on the receipt of the selected data card deck 830, and/or data cards within the selected data card deck 830. The option for activating the respective application in the final state of the respective application may be presented on the receiving communication device to include one or more of the components of GUI 800 described in Figure 8. The transmission of the selected data card deck 830, and/or data cards within the selected data card deck 830, may be activated by selection of the transmission option 835 illustrated in GUI 800.
  • The described logic relating to flow diagram 400 and flow diagram 500 may be implemented in different combinations. For example, reference to data card decks and data cards may be interchangeable.
  • The methods, devices, processing, circuitry, and logic described above may be implemented in many different ways and in many different combinations of hardware and software. For example, all or parts of the implementations may be circuitry that includes an instruction processor, such as a Central Processing Unit (CPU), microcontroller, or a microprocessor; or as an Application Specific Integrated Circuit (ASIC), Programmable Logic Device (PLD), or Field Programmable Gate Array (FPGA); or as circuitry that includes discrete logic or other circuit components, including analog circuit components, digital circuit components or both; or any combination thereof. The circuitry may include discrete interconnected hardware components or may be combined on a single integrated circuit die, distributed among multiple integrated circuit dies, or implemented in a Multiple Chip Module (MCM) of multiple integrated circuit dies in a common package, as examples.
  • Accordingly, the circuitry may store or access instructions for execution, or may implement its functionality in hardware alone. The instructions may be stored in a tangible storage medium that is other than a transitory signal, such as a flash memory, a Random Access Memory (RAM), a Read Only Memory (ROM), an Erasable Programmable Read Only Memory (EPROM); or on a magnetic or optical disc, such as a Compact Disc Read Only Memory (CDROM), Hard Disk Drive (HDD), or other magnetic or optical disk; or in or on another machine-readable medium. A product, such as a computer program product, may include a storage medium and instructions stored in or on the medium, and the instructions when executed by the circuitry in a device may cause the device to implement any of the processing described above or illustrated in the drawings.
  • The implementations may be distributed. For instance, the circuitry may include multiple distinct system components, such as multiple processors and memories, and may span multiple distributed processing systems. Parameters, databases, and other data structures may be separately stored and managed, may be incorporated into a single memory or database, may be logically and physically organized in many different ways, and may be implemented in many different ways. Example implementations include linked lists, program variables, hash tables, arrays, records (e.g., database records), objects, and implicit storage mechanisms. Instructions may form parts (e.g., subroutines or other code sections) of a single program, may form multiple separate programs, may be distributed across multiple memories and processors, and may be implemented in many different ways. Example implementations include stand-alone programs, and as part of a library, such as a shared library like a Dynamic Link Library (DLL). The library, for example, may contain shared data and one or more shared programs that include instructions that perform any of the processing described above or illustrated in the drawings, when executed by the circuitry.

Claims (15)

  1. A system, comprising:
    a database interface configured to communicate with a database;
    a communication interface configured to communicate with a client device;
    a processor configured to communicate with the database interface and the communication interface, the processor further configured to:
    receive, through the communication interface, an activation request from the client device, the activation request requesting activation of a data card interaction tracking tool;
    activate the data card interaction tracking tool based on the received activation request;
    in response to the activated data card interaction tracking tool, track interactions of the client device resulting in a changed state of a running application;
    generate a data card, wherein the data card identifies a tracked interaction with the running application and a state of the running application resulting from the tracked interaction;
    store the data card into a data card deck for the running application; and
    transmit, through the database interface, the data card deck to the database.
  2. The system of claim 1, wherein the processor is further configured to store metadata into the data card deck, the metadata including at least one of application information identifying the running application, industry information identifying an industry corresponding to the running application, data card generation information, tracked interaction type information, user tagging information, or identification information identifying a user associated with the tracked interaction.
  3. The system of claim 1 or 2, wherein the tracked interaction identifies at least one of an input into a search query field available with the running application or a selection of a dashboard navigation feature available with the running application;
    wherein the dashboard navigation feature may be at least one of a menu option, search query option, or a control configuration option;
    wherein the control configuration option may be one of a data filter or a modal popup option.
  4. The system of any one of the preceding claims, wherein the tracked interaction identifies a selection of a mapping feature available with the running application.
  5. The system of claim 4, wherein the mapping feature is a zooming feature, and wherein the tracked interaction identifies an address corresponding to the selection of the mapping feature.
  6. The system of claim 4, wherein the tracked interaction identifies an attribute for a location identified based on the selection of the mapping feature, wherein the attribute for the location is at least one of an address corresponding to the location, a business name corresponding to the address, a telephone number corresponding to the location, a type of business corresponding to the location, or contextual metadata relating to the location.
  7. The system of any one of the preceding claims, wherein the processor is further configured to:
    receive, through the communication interface, a search query from the client device;
    select the data card deck from the database based on the search query;
    receive, through the communication interface, a data card selection from the client device;
    activate the data card based on the data card selection; and
    wherein the processor may be further configured to control the running application to transition to the state of the running application resulting from the tracked interaction identified in the data card.
  8. The system of any one of the preceding claims, wherein the processor is further configured to:
    receive, through the communication interface, destination information from the client device, the destination information identifying a communication device for receiving the data card deck;
    select the data card deck from the database; and
    control transmission of the data card deck to the communication device identified in the destination information.
  9. A method for tracking application interactions, comprising:
    monitoring a data card interaction tracking tool;
    detecting an activation state for the data card interaction tracking tool based on the monitoring;
    activating a data card interaction tracking tool based on the detected activation state;
    in response to the activated data card interaction tracking tool, tracking interactions resulting in a changed state of a running application detected during an application session;
    generating a data card, wherein the data card identifies a tracked interaction with the running application and a state of the running application resulting from the tracked interaction;
    storing the data card into a data card deck; and
    transmitting, through a database interface, the data card deck to a database for storing.
  10. The method of claim 9, further comprising:
    storing metadata into the data card deck, the metadata including at least one of application information identifying the running application, industry information identifying an industry corresponding to the running application, or identification information identifying a user associated with the tracked interaction.
  11. The method of claim 9 or 10, wherein the tracked interaction identifies at least one of an input into a search query field available with the running application, a selection of a dashboard navigation feature available with the running application, or a selection of a mapping feature available with the running application.
  12. The method of claim 11, wherein the tracked interaction identifies an attribute for a location identified based on the selection of the mapping feature;
    wherein the attribute for the location may be at least one of an address corresponding to the location, a business name corresponding to the address, a telephone number corresponding to the location, a type of business corresponding to the location, or contextual metadata relating to the location.
  13. The method of any one of claims 9 to 12, further comprising:
    receiving, through a communication interface, a search query from a client device;
    selecting the data card deck from the database based on the search query;
    receiving, through the communication interface, a data card selection from the client device; and
    activating the data card based on the data card selection;
    wherein activating the data card may comprise controlling the running application to transition to the state of the running application resulting from the tracked interaction identified in the data card.
  14. The method of any one of claims 9 to 13, further comprising:
    receiving, through a communication interface, destination information from a client device, the destination information identifying a communication device for receiving the data card deck;
    selecting the data card deck from the database; and
    controlling transmission of the data card deck to the communication device identified in the destination information.
  15. A computer program product comprising computer-readable instructions, which, when loaded and executed on a computer system, cause the computer system to perform operations according to the method of any one of claims 9 to 14.
EP17157892.5A 2016-03-01 2017-02-24 Application session recording and replaying Active EP3214827B1 (en)

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US15/057,844 US10394422B2 (en) 2016-03-01 2016-03-01 Data interaction cards for capturing and replaying logic in visual analyses

Publications (2)

Publication Number Publication Date
EP3214827A1 true EP3214827A1 (en) 2017-09-06
EP3214827B1 EP3214827B1 (en) 2022-02-02

Family

ID=58192120

Family Applications (1)

Application Number Title Priority Date Filing Date
EP17157892.5A Active EP3214827B1 (en) 2016-03-01 2017-02-24 Application session recording and replaying

Country Status (3)

Country Link
US (1) US10394422B2 (en)
EP (1) EP3214827B1 (en)
AU (2) AU2017201210A1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109101227A (en) * 2018-08-09 2018-12-28 佛山市苔藓云链科技有限公司 A kind of system of tracking application program interaction

Families Citing this family (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
AU2015234604B2 (en) * 2014-03-25 2019-11-14 Monash University Image processing method and system for irregular output patterns
US10176073B2 (en) * 2017-02-24 2019-01-08 International Business Machines Corporation Controlling a system under test using a cognitive control based test runner
CN110868422B (en) * 2019-11-20 2023-04-18 杭州安恒信息技术股份有限公司 Http site detection method, apparatus, device, and medium
WO2023279355A1 (en) * 2021-07-09 2023-01-12 Citrix Systems, Inc. History preview and shortcut to restore a work scene for a remote app

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070050844A1 (en) * 2005-08-26 2007-03-01 Pierre Lebel Methods, systems and computer program products for monitoring a browsing session
US20110029665A1 (en) * 2008-08-14 2011-02-03 Tealeaf Technology, Inc. Dynamically configurable session agent
US20140258402A1 (en) * 2013-03-08 2014-09-11 Oracle International Corporation System for repetitively executing rules-based configurable business application operations
US20140359735A1 (en) * 2013-05-29 2014-12-04 Sap Portals Israel Ltd Maintaining application session continuity across devices

Family Cites Families (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6405222B1 (en) * 1998-12-17 2002-06-11 International Business Machines Corporation Requesting concurrent entries via bookmark set
US7536672B1 (en) 2004-03-05 2009-05-19 Adobe Systems Incorporated Management of user interaction history with software applications
US8205172B2 (en) * 2005-03-31 2012-06-19 Microsoft Corporation Graphical web browser history toolbar
US7899847B2 (en) * 2008-12-17 2011-03-01 International Business Machines Corporation System and method for authoring new lightweight web applications using application traces on existing websites
US9237383B2 (en) * 2010-08-27 2016-01-12 Intel Corporation Peer to peer streaming of DVR buffered program data
US9043706B2 (en) * 2010-08-31 2015-05-26 Anders Nancke-Krogh System and method for using state replication between application instances to provide a collaborative desktop environment
US20150193394A1 (en) * 2012-01-25 2015-07-09 Google Inc. Scheduling processing of resource requests to ensure fulfillment of foreground requests
GB2521364A (en) * 2013-12-17 2015-06-24 Ibm Recording GUI data
US20160188742A1 (en) * 2014-12-30 2016-06-30 Quixey, Inc. Bookmarking Search Results
US10387834B2 (en) * 2015-01-21 2019-08-20 Palantir Technologies Inc. Systems and methods for accessing and storing snapshots of a remote application in a document
US10228831B2 (en) * 2015-07-09 2019-03-12 Samsung Electronics Co., Ltd. Sharing cards to a target application
US10157210B2 (en) * 2015-12-11 2018-12-18 Samsung Electronics Co., Ltd. Searching and accessing software application functionality using application connections

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20070050844A1 (en) * 2005-08-26 2007-03-01 Pierre Lebel Methods, systems and computer program products for monitoring a browsing session
US20110029665A1 (en) * 2008-08-14 2011-02-03 Tealeaf Technology, Inc. Dynamically configurable session agent
US20140258402A1 (en) * 2013-03-08 2014-09-11 Oracle International Corporation System for repetitively executing rules-based configurable business application operations
US20140359735A1 (en) * 2013-05-29 2014-12-04 Sap Portals Israel Ltd Maintaining application session continuity across devices

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109101227A (en) * 2018-08-09 2018-12-28 佛山市苔藓云链科技有限公司 A kind of system of tracking application program interaction

Also Published As

Publication number Publication date
US20170255343A1 (en) 2017-09-07
AU2017201210A1 (en) 2017-09-21
US10394422B2 (en) 2019-08-27
EP3214827B1 (en) 2022-02-02
AU2018206691A1 (en) 2018-08-02
AU2018206691B2 (en) 2020-02-06

Similar Documents

Publication Publication Date Title
AU2018206691B2 (en) Data interaction cards for capturing and replaying logic in visual analyses
US10289630B2 (en) Integrated developer workflow for data visualization development
US9589233B2 (en) Automatic recognition and insights of data
CN105229678B (en) Process modeling and interface
US8930851B2 (en) Visually representing a menu structure
KR101794373B1 (en) Temporary formatting and charting of selected data
US20150378529A1 (en) Interaction in orbit visualization
EP2801898B1 (en) Quick Time-Related Data Entry
US10042920B2 (en) Chart navigation system
CN105339957B (en) Method and system for displaying different views of an entity
US20170212942A1 (en) Database grid search methods and systems
US6816855B2 (en) Building software statements such as search queries to a tabular database through a user-interactive computer display interface
US7647558B2 (en) User interface for presenting object representations
CN112882623A (en) Text processing method and device, electronic equipment and storage medium
US20140327608A1 (en) Transforming visualized data through visual analytics based on interactivity
JPH08314949A (en) Data management device
JPH02267671A (en) Retrieval display device for table format database
JPH07230476A (en) Data base retrieval device
KR20150096003A (en) Relative contents display system and providing method thereof

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: THE APPLICATION HAS BEEN PUBLISHED

AK Designated contracting states

Kind code of ref document: A1

Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR

AX Request for extension of the european patent

Extension state: BA ME

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: REQUEST FOR EXAMINATION WAS MADE

17P Request for examination filed

Effective date: 20180208

RBV Designated contracting states (corrected)

Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: EXAMINATION IS IN PROGRESS

17Q First examination report despatched

Effective date: 20181210

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: EXAMINATION IS IN PROGRESS

GRAP Despatch of communication of intention to grant a patent

Free format text: ORIGINAL CODE: EPIDOSNIGR1

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: GRANT OF PATENT IS INTENDED

RIC1 Information provided on ipc code assigned before grant

Ipc: G06F 11/36 20060101ALN20210917BHEP

Ipc: G06Q 10/10 20120101ALN20210917BHEP

Ipc: G06F 16/951 20190101ALI20210917BHEP

Ipc: G06F 16/22 20190101ALI20210917BHEP

Ipc: G06F 11/30 20060101ALI20210917BHEP

Ipc: G06Q 30/02 20120101ALI20210917BHEP

Ipc: G06F 11/34 20060101ALI20210917BHEP

Ipc: H04L 29/08 20060101AFI20210917BHEP

INTG Intention to grant announced

Effective date: 20211006

GRAS Grant fee paid

Free format text: ORIGINAL CODE: EPIDOSNIGR3

GRAA (expected) grant

Free format text: ORIGINAL CODE: 0009210

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: THE PATENT HAS BEEN GRANTED

AK Designated contracting states

Kind code of ref document: B1

Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR

REG Reference to a national code

Ref country code: GB

Ref legal event code: FG4D

REG Reference to a national code

Ref country code: CH

Ref legal event code: EP

Ref country code: AT

Ref legal event code: REF

Ref document number: 1466883

Country of ref document: AT

Kind code of ref document: T

Effective date: 20220215

REG Reference to a national code

Ref country code: DE

Ref legal event code: R096

Ref document number: 602017052982

Country of ref document: DE

REG Reference to a national code

Ref country code: IE

Ref legal event code: FG4D

REG Reference to a national code

Ref country code: LT

Ref legal event code: MG9D

REG Reference to a national code

Ref country code: NL

Ref legal event code: MP

Effective date: 20220202

REG Reference to a national code

Ref country code: AT

Ref legal event code: MK05

Ref document number: 1466883

Country of ref document: AT

Kind code of ref document: T

Effective date: 20220202

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: SE

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: RS

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: PT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220602

Ref country code: NO

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220502

Ref country code: NL

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: LT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: HR

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: ES

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: BG

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220502

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: PL

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: LV

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: GR

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220503

Ref country code: FI

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: AT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: IS

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220602

REG Reference to a national code

Ref country code: CH

Ref legal event code: PL

REG Reference to a national code

Ref country code: BE

Ref legal event code: MM

Effective date: 20220228

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: SM

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: SK

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: RO

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: LU

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20220224

Ref country code: EE

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: DK

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: CZ

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

REG Reference to a national code

Ref country code: DE

Ref legal event code: R097

Ref document number: 602017052982

Country of ref document: DE

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: MC

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: AL

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

PLBE No opposition filed within time limit

Free format text: ORIGINAL CODE: 0009261

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT

26N No opposition filed

Effective date: 20221103

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: LI

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20220228

Ref country code: CH

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20220228

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: SI

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

Ref country code: BE

Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES

Effective date: 20220228

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: FR

Payment date: 20230110

Year of fee payment: 7

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: GB

Payment date: 20230105

Year of fee payment: 7

Ref country code: DE

Payment date: 20221229

Year of fee payment: 7

P01 Opt-out of the competence of the unified patent court (upc) registered

Effective date: 20230523

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: IT

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT

Effective date: 20220202

PGFP Annual fee paid to national office [announced via postgrant information from national office to epo]

Ref country code: IE

Payment date: 20231211

Year of fee payment: 8

PG25 Lapsed in a contracting state [announced via postgrant information from national office to epo]

Ref country code: HU

Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT; INVALID AB INITIO

Effective date: 20170224