A graphical user interface (GUI) is disclosed that allows user to quickly find and select (assign) specific items from a large data source that is housed in the cloud. The GUI includes a first and second grid that display unassigned and assigned items, respectively. Each of the first and second grids allows the user to filter each grid by typing in the search criteria and forwarding the criteria to the server. items in each of the first and second grids may be moved between the two grids to quickly change the assigned state of moved items.
|
1. A system comprising:
a server for storing a large collection of data sets accessed by a user through a computing device, the server including:
one or more server processors; and
a non-transitory computer-readable medium storing computer program instructions operable to cause the one or more server processors to perform operations comprising:
performing, in response to receiving from a client computing device a service call to request data items in a database, server side paging for the return of requested data items; and
returning, in response to receiving from the client computer device a service call to filter data items based on a filter criteria, the filtered items; and
the client computing device comprising:
one or more client processors; and
a non-transitory computer-readable medium storing a program having a graphical user interface (GUI) for controlling the retrieval of items from the server, the GUI including a first grid for unassigned items, a second grid for assigned items, and a dropdown control, the program for execution by the one or more client processors to perform operations comprising:
receiving, from a user via the dropdown control, a selection of a first table in the database;
initiating, based on the received selection of the first table in the database, a service call to the server to retrieve items in the first table;
populating the second grid with retrieved items from the first table;
receiving, from the user, input into a filter area of the second grid comprising filter criteria for the second grid;
initiating a service call to the server, the service call including the filter criteria input by the user in the second grid;
receiving, from the server, filtered items retrieved by the server from the first table;
updating the second grid to only display the received filtered items;
receiving, from the user, selection of one or more first selected items in the second grid;
receiving an indication from the user to deassign the one or more first selected items from the first table;
updating the second grid to remove the one or more first selected items;
updating the first grid to include the one or more first selected items in a pending area disposed proximate a top of the first grid above a pending items separator;
receiving an indication from the user to commit pending changes; updating the first grid to move all items from the pending area to a main portion of the first grid;
receiving, from the user via the dropdown control, a selection of a second table in the database;
initiating, based on the received selection of the second table in the database, a service call to the server to retrieve items in the second table;
populating the second grid with retrieved items from the second table;
receiving, from the user, selection of one or more second selected items in the first grid;
receiving an indication from the user to assign the one or more second selected items to the second table;
updating the first grid to remove the one or more second selected items;
updating the second grid to include the one or more second selected items in a pending area disposed proximate a top of the second grid above a pending items separator;
receiving an indication from the user to commit pending changes;
updating the second grid to move all items from the pending area to a main portion of the second grid.
|
All of the material in this patent document is subject to copyright protection under the copyright laws of the United States and other countries. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in official governmental records but, otherwise, all other copyright rights whatsoever are reserved.
The present invention relates to computing devices. More specifically, the present invention relates to retrieving content for use by a computing device.
There are currently many ways to select multiple items that are contained in large data stores that cannot all be brought down to the client at once. An example is gmail's implementation in its web-based email client. In this instance, the main interface is simply a grid with checkboxes next to each item. Each checkbox must be clicked to be selected then the next page button must be pressed to make a call to the server to get the next pages worth of data. Once you navigate to the next page there is no visual representation of what has been selected on previous pages. Gmail is operated in this manner because of the potential for a large amount of data to have to be accessed each time a user wants to view information.
Timing out of the web service call timing out is a problem with big data. A web service call that requires the return of all data or the searching of all data on the server may result in the request timing out without returning all of the data requested. The web service, in this example, cannot physically handle the amount of data to display to the end user.
Therefore, there exists a need for an improved method and system for allowing user to access specific items from a large data source that is stored in the cloud. This and other needs are addressed by one or more aspects of the present invention.
The present invention includes many aspects and features. Moreover, while many aspects and features relate to, and are described in, the context of healthcare applications, the present invention is not limited to use only in this context, as will become apparent from the following summaries and detailed descriptions of aspects, features, and one or more embodiments of the present invention.
Accordingly, one aspect of the present invention relates to a system comprising a server for storing a large collection of data sets accessed by a user through a computing device. The server including one or more server processors, and a non-transitory computer-readable medium storing computer program instructions operable to cause the one or more server processors to perform operations comprising receiving from a client computing device service calls to filter the items based on a filter criteria, and forwarding the filtered items to the client computing device. The client computing device comprising one or more client processors, and a non-transitory computer-readable medium storing a program having a graphical user interface (GUI) for controlling the retrieval of items from the server, the GUI including a first and second grid. The program for execution by the one or more client processors to perform operations comprising initiating the service call to the server, the service call including the filter criteria input by a user in the second grid, receiving filtered items retrieved by the server from the collection of data sets that include a first assigned state, displaying the received filtered items in the second grid, identifying one or more filtered items selected by the user, receiving an indication from the user to move the one or more selected items from the second grid to the first grid, moving the one or more selected items, wherein the moved items first assigned state is changed to unassigned, displaying in the first grid the unassigned items, detecting the selection of one or more unassigned items by the user, and moving the selected unassigned items to the second grid, wherein the unassigned state is changed to a second assigned state.
In a feature of this aspect, the one or more client processors performs operations further comprising separating first grid existing items in the first grid from the moved items, detecting the selection by the user to save the moved items in the first grid, and eliminating the separation between the first grid existing items and the moved items, wherein the first grid existing items' state is unassigned.
In another feature of this aspect, the second grid includes filtered items including a second assigned state.
In another feature of this aspect, the one or more client processors performs operations further comprising separating the selected unassigned items moved from the first grid from the second assigned state filtered items, detecting the selection by the user to save the moved items in the second grid, eliminating the separation between the first grid existing items and the moved items, and changing the unassigned state to the second assigned state for each unassigned item moved from the first grid.
In another feature of this aspect, the GUI further includes one or more paging controls comprising an item display count for defining by the user the number of filtered items to be displayed per page in the respective first and second grids, and a page indicator for navigating between multiple pages of filtered items.
In another feature of this aspect, the one or more client processors performs operations further comprising navigating between the multiple pages in the second grid, and identifying one or more filtered items selected by the user as the user navigates between the multiple pages.
In another feature of this aspect, the moved items are displayed to the user in the first grid as the user navigates between the multiple pages in the second grid.
In another feature of this aspect, the one or more client processors performs operations further comprising detecting the input by the user of a column filter criteria, initiating a column filter in the second grid to identify to the user one or more first assigned state items that matches the column filter criteria, identifying the first assigned state items that match the column filter criteria, and displaying the identified matching items to the user in the second grid.
Another aspect of the present invention relates to a client computing device comprising one or more client processors, and a non-transitory computer-readable medium storing a program having a graphical user interface (GUI) for controlling the retrieval of items from a server, the server for storing a large collection of data sets and accessed by a user through the computing device, the GUI including a first and second grid. The program for execution by the one or more client processors to perform operations comprising initiating a service call to the server, the service call including a filter criteria input by the user in the second grid, receiving filtered items retrieved by the server from the collection of data sets that include a first assigned state, displaying the received filtered items in the second grid, identifying one or more filtered items selected by the user, receiving an indication from the user to move the one or more selected items from the second grid to the first grid, moving the one or more selected items, wherein the moved items first assigned state is changed to unassigned, displaying in the first grid the unassigned items, detecting the selection of one or more unassigned items by the user; and moving the selected unassigned items to the second grid, wherein the unassigned state is changed to a second assigned state.
In a feature of this aspect, the one or more client processors performs operations further comprising separating first grid existing items in the first grid from the moved items, detecting the selection by the user to save the moved items in the first grid, and eliminating the separation between the first grid existing items and the moved items, wherein the first grid existing items' state is unassigned.
In another feature of this aspect, the second grid includes filtered items including a second assigned state.
In another feature of this aspect, the one or more client processors performs operations further comprising separating the selected unassigned items moved from the first grid from the second assigned state filtered items, detecting the selection by the user to save the moved items in the second grid, eliminating the separation between the first grid existing items and the moved items, and changing the unassigned state to the second assigned state for each unassigned item moved from the first grid.
In another feature of this aspect, the GUI further includes one or more paging controls comprising an item display count for defining by the user the number of filtered items to be displayed per page in the respective first and second grids, and a page indicator for navigating between multiple pages of filtered items.
In another feature of this aspect, the one or more client processors performs operations further comprising navigating between the multiple pages in the second grid, and identifying one or more filtered items selected by the user as the user navigates between the multiple pages.
In another feature of this aspect, the moved items are displayed to the user in the first grid as the user navigates between the multiple pages in the second grid.
In another feature of this aspect, the one or more client processors performs operations further comprising detecting the input by the user of a column filter criteria, initiating a column filter in the second grid to identify to the user one or more first assigned state items that matches the column filter criteria, identifying the first assigned state items that match the column filter criteria, and displaying the identified matching items to the user in the second grid.
Another aspect of the present invention relates to a non-transitory computer readable medium storing a program having a graphical user interface (GUI) for controlling the retrieval of items from a server. The server for storing a large collection of data sets and accessed by a user through the computing device. The GUI comprising a first and second grid for receiving and filtering a plurality of items from the server based on a first criteria set by the user. The program for execution by one or more processors to perform operations comprising initiating a service call to the server, the service call including a filter criteria input by the user in the second grid, receiving filtered items retrieved by the server from the collection of data sets that include a first assigned state, displaying the received filtered items in the second grid, identifying one or more filtered items selected by the user, receiving an indication from the user to move the one or more selected items from the second grid to the first grid, moving the one or more selected items, wherein the moved items first assigned state is changed to unassigned, displaying in the first grid the unassigned items, detecting the selection of one or more unassigned items by the user, and moving the selected unassigned items to the second grid, wherein the unassigned state is changed to a second assigned state.
In addition to the aforementioned aspects and features of the present invention, it should be noted that the present invention further encompasses the various possible combinations and subcombinations of such aspects and features. Thus, for example, any aspect may be combined with an aforementioned feature in accordance with the present invention without requiring any other aspect or feature.
One or more preferred embodiments of the present invention now will be described in detail with reference to the accompanying drawings, wherein the same elements are referred to with the same reference numerals, and wherein,
Referring now to the drawings, one or more preferred embodiments of the present invention are next described. The following description of one or more preferred embodiments is merely exemplary in nature and is in no way intended to limit the invention, its implementations, or uses.
As a preliminary matter, it will readily be understood by one having ordinary skill in the relevant art (“Ordinary Artisan”) that the present invention has broad utility and application. As should be understood, any embodiment may incorporate only one or a plurality of the above-disclosed aspects of the invention and may further incorporate only one or a plurality of the above-disclosed features. Furthermore, any embodiment discussed and identified as being “preferred” is considered to be part of a best mode contemplated for carrying out the present invention. Other embodiments also may be discussed for additional illustrative purposes in providing a full and enabling disclosure of the present invention. As should be understood, any embodiment may incorporate only one or a plurality of the above-disclosed aspects of the invention and may further incorporate only one or a plurality of the above-disclosed features. Moreover, many embodiments, such as adaptations, variations, modifications, and equivalent arrangements, will be implicitly disclosed by the embodiments described herein and fall within the scope of the present invention.
Accordingly, while the present invention is described herein in detail in relation to one or more embodiments, it is to be understood that this disclosure is illustrative and exemplary of the present invention, and is made merely for the purposes of providing a full and enabling disclosure of the present invention. The detailed disclosure herein of one or more embodiments is not intended, nor is to be construed, to limit the scope of patent protection afforded the present invention, which scope is to be defined by the claims and the equivalents thereof. It is not intended that the scope of patent protection afforded the present invention be defined by reading into any claim a limitation found herein that does not explicitly appear in the claim itself
Thus, for example, any sequence(s) and/or temporal order of steps of various processes or methods that are described herein are illustrative and not restrictive. Accordingly, it should be understood that, although steps of various processes or methods may be shown and described as being in a sequence or temporal order, the steps of any such processes or methods are not limited to being carried out in any particular sequence or order, absent an indication otherwise. Indeed, the steps in such processes or methods generally may be carried out in various different sequences and orders while still falling within the scope of the present invention. Accordingly, it is intended that the scope of patent protection afforded the present invention is to be defined by the appended claims rather than the description set forth herein.
Additionally, it is important to note that each term used herein refers to that which the Ordinary Artisan would understand such term to mean based on the contextual use of such term herein. To the extent that the meaning of a term used herein—as understood by the Ordinary Artisan based on the contextual use of such term—differs in any way from any particular dictionary definition of such term, it is intended that the meaning of the term as understood by the Ordinary Artisan should prevail.
An example diagram of a disclosed implementation of a system including a Big Data Selector is illustrated in
An example of a suitable computing device operable in accordance with an implementation of the disclosed system and method is illustrated in
The computing device may also be implemented as a mobile computing device. The mobile computing device may be implemented by various mobile devices, such as PDAs, cellular phones, smart phones, tablets and other similar computing devices. The mobile computing device includes a bus, a display, I/O ports, Input displays, one or more processors, a memory device, a non-volatile storage, a networking device, a power source, and a transceiver for implementing wireless communication under various protocols, such as SMS or MMS messaging, CDMA, TDMA, WCDMA or GPRS, among others. The components of the computing devices as shown, their connections and relationships and their functions are meant for exemplary purposes only, and are not meant to limit implementations of the disclosed inventions described and/or claimed in this disclosure.
The display device 50 may be used to display images generated by the computing device 100, for example a graphical user interface (GUI). The display 50 may be any type of display such as a cathode ray tube (CRT), a liquid crystal display (LCD), a light emitting diode (LED) display, or other suitable display. In certain implementations of the computing device 100, the display 50 may include a touch-sensitive element, such as a touch screen.
The processor(s) 20 may provide data processing capability to execute and support one or more operating systems, computer programs, user and application interfaces, software systems and applications, and any other functions of the computing device 100 that may be stored in the memory device 30 or on the storage device 60. The processor(s) 20 may include one or more microprocessors, such as one or more “general-purpose” microprocessors, one or more special-purpose microprocessors and/or ASICS, for example.
The processor(s) 20 may communicate with a user through input interface 90 and display interface 55 coupled to the display 50. The display interface 55 may comprise appropriate circuitry for driving the display 50 to present graphical and other information to a user. The input interface 90 may receive commands from a user and convert them for submission to the processor 20.
The instructions or data to be processed by the processor(s) 20 may be stored in a memory 30. The memory 30 may be provided as a volatile memory, such as random access memory (RAM), and/or as a non-volatile memory, such as read-only memory (ROM). The memory 30 may store a variety of information and may be used for various purposes. For example, the memory 30 may store firmware executed by a processor 20 (such as for implementing a system and method for selecting items from a server storing “Big Data” as discussed herein), other programs that enable various functions of the computing device 100, user interface functions, processor functions. The memory 30 may also be another form of computer-readable medium.
The components may further include a non-volatile storage 22 for persistent storage of data and/or instructions. The non-volatile storage 22 may include flash memory, a hard drive, or any other optical, magnetic, and/or solid-state storage media. The non-volatile storage 22 may be used to store data files, software, wireless connection information (e.g., information that may enable the electronic device 100 to establish a wireless connection, and any other suitable data. In addition, the non-volatile storage 60 may also store code and/or data for implementing various functions of the electronic device 100, such as application or program code, data associated with such applications or programs, operating system code, user configured preferences, as well as code for implementing a system and method for selecting items from a server storing “Big Data” as discussed herein. In implementation, the storage device 60 may be or contain a computer-readable medium. A computer program product can be tangibly embodied in an information carrier. The computer program products may also contain instructions that, when executed, perform one or more methods, such as those described above. The information carrier is a computer- or machine-readable medium, such as the memory 30, the storage device 60, memory on processor 20, or a propagated signal.
A machine-readable medium includes any mechanism for storing or transmitting information in a form readable by a machine (e.g., a computer). For example, a machine-readable medium includes read only memory (“ROM”); random access memory (“RAM”); magnetic disk storage media; optical storage media; flash memory devices; electrical, optical, acoustical or other form of propagated signals (e.g., carrier waves, infrared signals, digital signals, etc.); etc.
The disclosed system and methods are preferably implemented by software, hardware, or a combination of hardware and software. The disclosed implementations can include implementation in one or more computer programs that are executable and/or interpretable on a programmable processor, which may be special or general purpose, coupled to receive data and instructions from, and to transmit data and instructions to, a storage system, at least one input device, and at least one output device.
These computer programs (also known as programs, software, software applications or code) include machine instructions for a programmable processor, and can be implemented in an appropriate programming language. As used herein, the terms “machine-readable medium” “computer-readable medium” refers to any computer program product, apparatus and/or device (e.g., magnetic discs, optical disks, memory) used to provide machine instruction and/or data to a programmable processor. The computer readable medium can also be distributed over network-coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
A user-interface (UI) (i.e., Big Data Selector, hereinafter BD Selector) that allows a user to quickly find and select (or assign) specific items from a large data source is disclosed. The UI control provides the user with a display that indicates what items have been selected and server side paging so that the control can be used in a disconnected manner. The control also allows the user to filter each grid by typing in search criteria that is then sent to the server to further speed up finding data in a table that could potentially have millions of records. An example of big data may be public health records, patient specific health records, and/or other health related information.
In accordance with an implementation of the disclosed system and method for accessing data housed remotely (e.g., in the cloud), a use interface (UI) control is provided to a user to allow the User to assign/unassign items from a specific state to another state within a computing environment. An example illustration of an implementation of the BD Selector 100 is shown in
In accordance with an implementation of the UI control 100, the first grid 110 (i.e., “Unassigned” grid), includes unassigned items that have not been selected for inclusion in the data extraction from the server side database.
The second grid 120 (i.e., “Assigned” grid), in the UI control 100, includes the assigned items that were selected for inclusion in the data extraction from the server side database. The assigned items grid 120 includes the items that are displayed to the User. The items 121 that are displayed in the assigned item grid 120 are a subset of the large amount of data that is available in the server.
The Unassigned and Assigned grids 110, 120 each have the functionality to page and filter the data included in the respective grids 110, 120. This functionality is performed via a web service call to the server. The User initiates this functionality by typing in filter criteria in the row at the top of each column the respective grid 110, 120 or by clicking on the column header to sort the data in the grid. An example of the filter functionality is illustrated in
Once the action icon 345 is visible to the User, the User can move the mouse over the icon and select from the context menu 446. An example of the Assigned Grid 120 including a context menu is illustrated in
Referring back to
Referring back to
An example class diagram of the disclosed Big Data Selector system and method is illustrated in
An example sequence diagram of an implementation of the operation for retrieving items from a server by the disclosed BD Selector system and method is illustrated in
In accordance with an example implementation of the disclosed BD Selector, a BD Selector is provided to a User for changing items that have been stored in the system, the items were retrieved from a remote server (e.g., a server in the cloud) that is storing a large and complex collection of data sets that is difficult to process using traditional data processing applications (i.e., Big Data). An example screen shot of a Big Data Selector in accordance the disclosed implementation is illustrated in
As disclosed, the User may filter the items that are displayed in each grid.
Based on the User's elected filter, items in the respective grid are highlighted for the User.
The User may now move the highlighted items to the “Unassigned” grid and go to the next page in the “Assigned” grid to continue filtering the items that were retrieved from the server. By moving the highlighted items to the “Unassigned” grid, the User maintains a visual of the items that meet the User's filter criteria. If the User does not move the highlighted items, the User would have to return to page 1 of the retrieved items in order to view again. An example screen shot of the Selector after the User has moved the highlighted items to the “Unassigned” grid is illustrated in
As set forth above, when the User initially moves selected items from the “Assigned” grid to the “Unassigned” grid, vice versa, the items are placed in the “Unassigned” grid above a Pending Items bar in a pending state. In order to commit this move, the “Save” button in the ribbon of the application must be clicked by the User.
Again the example Big Data Selector shows the selected items in a pending state confirming that the change was made. In order to commit this change the “Save” button on the application's ribbon is clicked.
The disclosed Big Data Selector expands existing selection controls in the ability to handle large data items without exceeding the ability of the current technology to transport the data from the cloud to a client computer. The Selector is able to implement server side paging/filter/sorting and also display items that are pending for status change.
Based on the foregoing description, it will be readily understood by those persons skilled in the art that the present invention is susceptible of broad utility and application. Many embodiments and adaptations of the present invention other than those specifically described herein, as well as many variations, modifications, and equivalent arrangements, will be apparent from or reasonably suggested by the present invention and the foregoing descriptions thereof, without departing from the substance or scope of the present invention. Accordingly, while the present invention has been described herein in detail in relation to one or more preferred embodiments, it is to be understood that this disclosure is only illustrative and exemplary of the present invention and is made merely for the purpose of providing a full and enabling disclosure of the invention. The foregoing disclosure is not intended to be construed to limit the present invention or otherwise exclude any such other embodiments, adaptations, variations, modifications or equivalent arrangements, the present invention being limited only by the claims appended hereto and the equivalents thereof.
Myers, Scott Douglas, Hedrich, Donald Robert, Rust, Chad Scott, Broadwater, Mike
Patent | Priority | Assignee | Title |
10437423, | Oct 30 2015 | HYLAND SOFTWARE, INC ; ALLSCRIPTS SOFTWARE, LLC | Methods and apparatuses for providing an infinitely scrolling accumulator |
D912074, | Mar 25 2019 | Warsaw Orthopedic, Inc. | Display screen with graphical user interface for medical treatment and/or diagnostics |
Patent | Priority | Assignee | Title |
6763377, | Mar 03 2000 | SANDPIPER CDN, LLC | Asset management and scheduling graphical user interface for media streamer |
7822707, | Sep 28 2007 | EMC IP HOLDING COMPANY LLC | Object searching and management information viewing in a storage area network environment |
20020082892, | |||
20060074879, | |||
20060206821, | |||
20120323935, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Sep 23 2014 | ALLSCRIPTS SOFTWARE, LLC | (assignment on the face of the patent) | / | |||
Dec 15 2015 | MYERS, SCOTT DOUGLAS | ALLSCRIPTS SOFTWARE, LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 040122 | /0145 | |
Dec 17 2015 | BROADWATER, MIKE | ALLSCRIPTS SOFTWARE, LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 040122 | /0145 | |
Dec 21 2015 | HEDRICH, DONALD ROBERT | ALLSCRIPTS SOFTWARE, LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 040122 | /0145 | |
Dec 21 2015 | RUST, CHAD SCOTT | ALLSCRIPTS SOFTWARE, LLC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 040122 | /0145 | |
Apr 29 2022 | ALLSCRIPTS SOFTWARE, LLC | JPMORGAN CHASE BANK, N A | GRANT OF SECURITY INTEREST IN PATENT RIGHTS | 060073 | /0613 |
Date | Maintenance Fee Events |
Sep 02 2019 | REM: Maintenance Fee Reminder Mailed. |
Nov 27 2019 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Nov 27 2019 | M1554: Surcharge for Late Payment, Large Entity. |
Aug 18 2023 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Aug 18 2023 | M1555: 7.5 yr surcharge - late pmt w/in 6 mo, Large Entity. |
Date | Maintenance Schedule |
Jan 12 2019 | 4 years fee payment window open |
Jul 12 2019 | 6 months grace period start (w surcharge) |
Jan 12 2020 | patent expiry (for year 4) |
Jan 12 2022 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jan 12 2023 | 8 years fee payment window open |
Jul 12 2023 | 6 months grace period start (w surcharge) |
Jan 12 2024 | patent expiry (for year 8) |
Jan 12 2026 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jan 12 2027 | 12 years fee payment window open |
Jul 12 2027 | 6 months grace period start (w surcharge) |
Jan 12 2028 | patent expiry (for year 12) |
Jan 12 2030 | 2 years to revive unintentionally abandoned end. (for year 12) |