Many third party viewers that support thumbnail views of documents or other sets of objects have a restriction of certain formats and size of the document or other object set. The thumbnails are also typically solely used for the purpose of navigating within a document or other object set. Maintaining the integrity of very large documents while allowing page modification or other operations, for example, is a big challenge. As a result, typical client side frameworks that support an infinite view of datasets (i.e., not limited by number of pages or other objects to be displayed, e.g., as thumbnails) typically only allow a user to view and navigation through them.
For a large document or other dataset, the viewer typically cannot maintain persistently any changes done by a user to the dataset, if permitted, as they get overwritten when fetched again from server. Current viewers typically do not support selection of items within infinite datasets; instead, knowledge of the selected state of a selected object typically gets lost during scrolling.
Various embodiments of the invention are disclosed in the following detailed description and the accompanying drawings.
The invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor. In this specification, these implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processes may be altered within the scope of the invention. Unless stated otherwise, a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task. As used herein, the term ‘processor’ refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
A detailed description of one or more embodiments of the invention is provided below along with accompanying figures that illustrate the principles of the invention. The invention is described in connection with such embodiments, but the invention is not limited to any embodiment. The scope of the invention is limited only by the claims and the invention encompasses numerous alternatives, modifications and equivalents. Numerous specific details are set forth in the following description in order to provide a thorough understanding of the invention. These details are provided for the purpose of example and the invention may be practiced according to the claims without some or all of these specific details. For the purpose of clarity, technical material that is known in the technical fields related to the invention has not been described in detail so that the invention is not unnecessarily obscured.
In various embodiments, a viewer framework component is provided, which can embed any 3rd party viewer and provides an integrated thumbnail panel which has the capability to load thumbnails for huge documents with any number of pages. The thumbnail panel would also allow inline operations to reorder thumbnail images which would in turn rearrange the pages of the document when committed to the server. The user is able to rearrange the rows (thumbnail images) of a large dataset in any order via easy to use gestures like drag drop, context menu, up/down keys etc. For example, if the user is viewing a 100,000 page document and wishes to move a sequence of pages say 2-5 after page 56000, he would be able to use the context menu after selecting those, navigate to the target location in thumbnail panel and paste. He could continue to rearrange the large dataset of thumbnails and commit once he is done with all of them.
In various embodiments, a client such as clients 102, 104, and 106 is configured to provide an infinite grid display of a set of thumbnails each representing a component part of a larger document or other dataset. For example, a viewer may be provided which is configured to show a currently selected subset of thumbnails corresponding to a currently displayed range of pages or other objects comprising the larger document or other dataset. As used herein, unless otherwise indicated techniques described with respect to a dataset comprising a very large document made up of component pages may be applied to other datasets comprising other component object each of which may be represented by a corresponding thumbnail image.
In some embodiments, the viewer component is embedded in a client-side viewer framework, for example a runtime or other environment in which the third party viewer executes and/or is otherwise associated. The framework extends the basic functionality of the third party viewer—which is to display a current set of thumbnails and provide the ability to use them to navigate through the document—to include additional functionality as disclosed herein, including without limitation one or more of the following: the ability to display a range of thumbnails for a contiguous subset of pages comprising a very large document, regardless of document size (sometimes referred to herein as an “infinite” thumbnail and/or grid display); the ability to support reorder operations, including drag and drop or other selection and insertion gestures, regardless of document size and including to locations not initially in view, such that it is necessary to scroll to reach the desired insertion point; and the ability to remember operations, such as thumbnail selection, deletion, reorder, or page modification, until committed to the server, including the ability to indicate visually that such actions have been taken and have not yet been committed.
In the example shown in
In various embodiments, other modifications, and persistence and consistent displaying of same until committed, are supported, including without limitation deletion of pages and/or changes to page content.
Some documents, for example in the enterprise context, can be very large, such as 10,000 or 100,000 pages. Typical browsers cannot handle 100,000 images in a thumbnail panel at a time and would crash. Hence an effective mechanism to fetch the range of thumbnails required is provided in various embodiments. The thumbnails images are stored on the server side as renditions to the document. As the user scrolls through the thumbnail panel or jumps to a particular page, the appropriate range of thumbnails is fetched and displayed.
In various embodiments, the fetched thumbnails are displayed in a manner that reflects any reorder operations that have been performed by the user before scrolling to a new location within the document. In some embodiments, a reorder cache is provided at the client side and used to keep track of reorder and/or other changes that have not been committed. In response to a request to fetch a sequence of thumbnails, the viewer and/or viewer framework first looks into this reorder cache maintained at the client side, and if the need thumbnails are not found the browser is used to obtain the needed thumbnails from the server.
In various embodiments, the aforementioned grid or other display structure is the client side representation of the thumbnail panel where the thumbnails are shown. At any point of time, the thumbnail panel shows only a prescribed number of images, e.g., 15 images, and swaps data in and out as required while scrolling. When user scrolls to an arbitrary position in the thumbnail panel, the logic 304 automatically fetches from the server and stores in the intermediate store 306 any thumbnails in the range of thumbnails to be displayed which are not already in the intermediate store 306 (e.g., as a result of having been displayed previously) and populates the data store 308 with the thumbnails to be displayed.
The logic 304 updates the intermediate store as required to keep track of all the reorder or other (e.g., delete) operations done within the thumbnails. As the user keeps reordering (or deleting) pages within the thumbnail panel, the changes are immediately recorded in the intermediate store. All reorder (and delete) operations are persisted only at the intermediate store, until committed to the server by the user, and the thumbnails panel would reflect these changes when a thumbnail range that has been affected by a previous but not yet committed user action is revisited by scrolling. In some embodiments, the logic 304 reads operation persistence data stored in intermediate store 306 to determine which thumbnails are to be displayed, in which order and with which display attributes (e.g., indication of selected state, indication of previously having been reordered, etc.), and causes the correct thumbnails to be stored in data store 308 and used by viewer component 310 to populate and display the grid of thumbnails.
Referring further to
In various embodiments, techniques disclosed herein may allow one or more of the following to be accomplished: enhance the capability of infinite grid implementations to handle user interactions, such as page reorder, modification, and deletion, and not just viewing; scale up to any size of document having large number of pages; leverage the power of paged chunks for infinite content augmented by easy to use gestures that makes life easier for the user while reordering/modifying huge documents; give the user a visual confirmation of the new order of pages of that he would commit and hence prevents errors while modifying important documents; and/or maintain the selection of page(s) while scrolling in the thumbnail panel and preserves the context for the user.
Although the foregoing embodiments have been described in some detail for purposes of clarity of understanding, the invention is not limited to the details provided. There are many alternative ways of implementing the invention. The disclosed embodiments are illustrative and not restrictive.
This is a continuation, and claims a benefit of priority under 35 U.S.C. § 120, of U.S. patent application Ser. No. 15/682,195 filed Aug. 21, 2017, entitled “REORDER AND SELECTION PERSISTENCE OF DISPLAYED OBJECTS,” issued as U.S. Pat. No. 10,474,327, which is a continuation, and claims a benefit of priority under 35 U.S.C. § 120, of U.S. patent application Ser. No. 13/628,402 filed Sep. 27, 2012, entitled “REORDER AND SELECTION PERSISTENCE OF DISPLAYED OBJECTS,” issued as U.S. Pat. No. 9,785,307, which are fully incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
5761655 | Hoffman | Jun 1998 | A |
5859623 | Meyn | Jan 1999 | A |
6496206 | Mernyk | Dec 2002 | B1 |
6643672 | Lebel | Nov 2003 | B1 |
6665838 | Brown | Dec 2003 | B1 |
6856415 | Simchik | Feb 2005 | B1 |
7002700 | Motamed | Feb 2006 | B1 |
7457820 | Viger | Nov 2008 | B1 |
7574669 | Braun | Aug 2009 | B1 |
8108779 | Rein | Jan 2012 | B1 |
8205150 | Gelman | Jun 2012 | B2 |
8347228 | Kates | Jan 2013 | B1 |
8533605 | Cha | Sep 2013 | B1 |
8549435 | Bushore | Oct 2013 | B1 |
8583614 | Dilts | Nov 2013 | B1 |
8615721 | Hara | Dec 2013 | B2 |
8868506 | Bhargava | Oct 2014 | B1 |
8887052 | Young | Nov 2014 | B1 |
9003445 | Rowe | Apr 2015 | B1 |
9785307 | Ganesan | Oct 2017 | B1 |
20010054089 | Tso et al. | Dec 2001 | A1 |
20020133486 | Yanagihara | Sep 2002 | A1 |
20030079179 | Brown | Apr 2003 | A1 |
20030115546 | Dubey | Jun 2003 | A1 |
20040064471 | Brown | Apr 2004 | A1 |
20040070678 | Toyama | Apr 2004 | A1 |
20060174198 | Watanabe | Mar 2006 | A1 |
20060195507 | Baek | Aug 2006 | A1 |
20060218004 | Dworkin | Sep 2006 | A1 |
20060242163 | Miller | Oct 2006 | A1 |
20060288124 | Kraft | Dec 2006 | A1 |
20070198534 | Hon | Aug 2007 | A1 |
20070279438 | Takakura | Dec 2007 | A1 |
20080077597 | Butler | Mar 2008 | A1 |
20080079972 | Goodwin | Apr 2008 | A1 |
20080092051 | Sidon | Apr 2008 | A1 |
20080092054 | Bhurnkar | Apr 2008 | A1 |
20080098173 | Chidambaran | Apr 2008 | A1 |
20080222678 | Burke | Sep 2008 | A1 |
20080270930 | Slosar | Oct 2008 | A1 |
20080298697 | Lee | Dec 2008 | A1 |
20080301583 | Akagi | Dec 2008 | A1 |
20080309644 | Arimoto | Dec 2008 | A1 |
20090013244 | Cudich | Jan 2009 | A1 |
20100026711 | Muramoto | Feb 2010 | A1 |
20100050073 | Yamamoto | Feb 2010 | A1 |
20100077316 | Omansky | Mar 2010 | A1 |
20100115003 | Soules | May 2010 | A1 |
20100162126 | Donaldson | Jun 2010 | A1 |
20100180196 | Matsusaka | Jun 2010 | A1 |
20100185733 | Hon | Jun 2010 | A1 |
20100168888 | Ryuutou | Jul 2010 | A1 |
20100182412 | Taniguchi | Jul 2010 | A1 |
20100228746 | Harada | Sep 2010 | A1 |
20100262647 | Malek | Oct 2010 | A1 |
20110016169 | Cahill | Jan 2011 | A1 |
20110032562 | McCuen | Feb 2011 | A1 |
20110035660 | Lussier | Feb 2011 | A1 |
20110055066 | Themmen | Mar 2011 | A1 |
20110125755 | Kaila | May 2011 | A1 |
20110126119 | Young | May 2011 | A1 |
20110154212 | Gharpure | Jun 2011 | A1 |
20110219297 | Oda | Sep 2011 | A1 |
20110283242 | Chew | Nov 2011 | A1 |
20110289079 | LuVogt | Nov 2011 | A1 |
20110295879 | Logis | Dec 2011 | A1 |
20120013944 | Ehara | Jan 2012 | A1 |
20120033254 | Numata | Feb 2012 | A1 |
20120042251 | Rodriguez | Feb 2012 | A1 |
20120109776 | Fagans | May 2012 | A1 |
20120110044 | Nagpal | May 2012 | A1 |
20120173490 | Gould | Jul 2012 | A1 |
20120185568 | Broyde | Jul 2012 | A1 |
20120260195 | Hon | Oct 2012 | A1 |
20120284624 | Ording | Nov 2012 | A1 |
20120317476 | Goldman | Dec 2012 | A1 |
20130080884 | Lisse | Mar 2013 | A1 |
20130113936 | Cohen | May 2013 | A1 |
20130124956 | Hatfield | May 2013 | A1 |
20130205246 | Schmidt | Aug 2013 | A1 |
20130227495 | Rydenhag | Aug 2013 | A1 |
20130298014 | Kodimer | Nov 2013 | A1 |
20140074964 | Cortes et al. | Mar 2014 | A1 |
20140101605 | Udvardy | Apr 2014 | A1 |
20140143229 | Wu | May 2014 | A1 |
20170136877 | Boss | May 2017 | A1 |
20170344203 | Ganesan | Nov 2017 | A1 |
20170352285 | Selen | Dec 2017 | A1 |
Entry |
---|
Office Action for U.S. Appl. No. 13/628,402, dated Jul. 16, 2014, 23 pages. |
Office Action for U.S. Appl. No. 13/628,402, dated Jan. 6, 2015, 7 pages. |
Office Action for U.S. Appl. No. 13/628,402, dated Apr. 27, 2015, 29 pages. |
Office Action for U.S. Appl. No. 13/628,402, dated Nov. 5, 2015, 26 pages. |
Notice of Allowance for U.S. Appl. No. 15/682,195, dated Jul. 2, 2019, 8 pgs. |
Number | Date | Country | |
---|---|---|---|
20200050328 A1 | Feb 2020 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15682195 | Aug 2017 | US |
Child | 16659281 | US | |
Parent | 13628402 | Sep 2012 | US |
Child | 15682195 | US |