Content item activity feed for presenting events associated with content items

Information

  • Patent Grant
  • 11170345
  • Patent Number
    11,170,345
  • Date Filed
    Wednesday, February 20, 2019
    6 years ago
  • Date Issued
    Tuesday, November 9, 2021
    3 years ago
Abstract
A content management system aggregates and provides users' interaction with a content item for display in an activity feed. Events corresponding to the users' interaction with the content item are provided in conjunction with a user interface of a native application displaying the content item. Though provided in conjunction with the native application, the events are maintained separate from the content data of the content item and displayed in the activity feed by an application separate from the native application of the content item. The activity feed permits users to exchange chat messages and retrieve information for multiple versions of the content item.
Description
BACKGROUND

This disclosure relates generally to facilitating collaborating on content items, and particularly to synchronizing interactions with content items among collaborators.


Content management systems permit devices to synchronize content items with a content management system and other devices. A device stores a local copy of content items. When content items are added, deleted, or edited on a device, these modifications are sent to the content management system for storage and synchronization with other devices. To interact with a content item, users typically execute a native application on the device to view and modify the content item. Modifications to a content item may be synchronized with the content management system separately from the execution of the native application.


Accordingly, multiple users may use respective devices to separately view and edit a particular content item. When multiple users collaboratively edit, draft, or otherwise work with the same content item; however, it becomes difficult for the users identify changes made by other users, to determine if they have opened the latest version of the content item, to know if other users have made changes to the content item since they last opened the content item, and so forth. Such an environment where multiple users are separately viewing and editing a content item can lead to confusion and other inefficiencies.


SUMMARY

A content management system maintains events related to a content item that correspond to users' interaction with the content item and provide the events for display in an activity feed to client devices of various users that collaborate on the content item. The activity feed includes a list of event notifications that provide users with information of all users' interaction with the content item. The activity feed provides users who have access to the content item with edits and comments the content item, previews of edits and previous versions of the content item, whether edits and comments have been seen by other users, different versions of the content item, and/or messages exchanged with other users.


A computing device, via a client application of the content management system, stores a local copy of a content item that is also stored, maintained, and synchronized between devices by the content management system. The device also includes a native content application, such as a word processor, media viewer, media editor, and so forth that can be used to access the content item. The native application displays content data of the content item in a user interface element, such as a window. The client application is programmatically configured to interact with the content management system and access the events related to the content item to monitor activity or interactions with the content item on the device and communicate information about these events to the content management system, which then provides this data to other devices sharing the content item. The client application provides a particular user's interaction with the content item including event data that describe an event to the content management system. The content management system aggregates events from various devices and provides the aggregated events to each device. Event data includes, for example, the user generating the event, the type of event, when the event occurred, what version of the content item the event corresponds to, and so forth, to facilitate collaboration between users.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 shows an embodiment of an environment for content item synchronization including the display of event information to other users in a shared environment.



FIG. 2 shows various modules and components of a device, according to one embodiment.



FIGS. 3A and 3B illustrate displaying a content item with an activity feed across user devices, according to one embodiment.



FIGS. 4A and 4B illustrate displaying a content item with an activity feed across user devices, according to one embodiment.



FIG. 5 illustrates displaying a content item with an activity feed in a web browser, according to one embodiment.



FIG. 6 shows an interaction diagram for displaying activity information for a content item, according to one embodiment.



FIG. 7 shows an interaction diagram for displaying activity information for a content item, according to one embodiment.



FIG. 8 shows components of a content management system, according to one embodiment.



FIG. 9 shows an example process for providing event information for display to collaborators of a content item, according to one embodiment.





The figures depict various embodiments of the present invention for purposes of illustration only. One skilled in the art will readily recognize from the following discussion that alternative embodiments of the structures and methods illustrated herein may be employed without departing from the principles of the invention described herein.


DETAILED DESCRIPTION


FIG. 1 shows an example system environment for content item synchronization providing users with an activity feed of events associated with a content item to facilitate collaborative editing of content items. Events associated with the content item represent users' various interactions with the content item such as retrieving/opening, editing, commenting on, reviewing, closing/saving, and sharing a content item, as well as sending messages to other users. FIG. 1 includes devices 100A, 100B, 100C (referred to generally as devices 100), content management system 110, and network 120. Three devices are shown for purpose of illustration; in practice, however, any number of devices may be present in the environment. Similarly, other modules or components described and illustrated throughout may include single or multiple instances as appropriate to the needs of the implementer and without loss of generality.


Devices 100 may be any suitable computing device for locally storing and viewing content items and synchronizing the content items with content management system 110. Examples of devices include desktop and laptop computers, hand-held mobile devices, tablet computers, and other computing devices. The operation of device 100 in various embodiments is further described below. In particular, each device 100 is configured by particular client application 200 (described with respect to FIG. 2) that extends the operation of device 100 beyond the functionality for a generic computer device, as will be further described, and thereby improves the overall functionality of device 100.


Each device 100 communicates with content management system 110 through network 120. Network 120 is any suitable network and may include local networks, corporate networks, global networks, and any combination of these. In typical configurations, devices 100 communicate via a wired or wireless communication network to a local network service provider, and communicate with content management system 110 through the Internet.


Content management system 110 provides content sharing and synchronization services for users of devices 100. These services allow users to share content with users of other devices 100. In addition to content sharing, content management system 110 updates shared content responsive to changes and enables synchronized changes to content items across multiple devices 100. Users who register with content management system 110 are provided with a user account and a user may synchronize content across multiple devices 100 associated with the user's account, and the user may share content that is synchronized with devices associated with other users' accounts.


Content stored by content management system 110 can include any type of data, such as digital data, documents, media (e.g., images, photos, videos, audio, streaming content), data files and databases, source and object code, recordings, and any other type of data or file, collectively referred to here as “content items.” Content items stored by content management system 110 may also be used to organize other content items, such as folders, tables, collections, albums, playlists, or in other database structures (e.g., object oriented, key/value etc.). In practice, various devices 100 will be synchronized with different groups of content items, based on user associations, permissions, content sharing permissions, and so forth. The operation of content management system 110 in various embodiments is further described below.



FIG. 2 shows exemplary modules and components of device 100 in accordance with one embodiment. Device 100 includes display 220 for providing information to the user, and in certain client devices 100, display 220 may be a touchscreen. Device 100 also includes network interface 225 for communicating with content management system 110 via network 120. Device 100 also includes user input module 260, which receives user inputs from various user input devices, such as a keyboard, a mouse, a trackpad, or other device. Other conventional components of device 100 that are not material are not shown, for example one or more computer processors, local fixed memory (RAM and ROM), as well as optionally removable memory (e.g., SD-card), power sources, and audio-video outputs.


Software modules include operating system 245 and one or more native applications 255. Native applications 255 vary based on client device, and may include various applications for creating, viewing, consuming, and modifying content stored on content management system 110, such as word processors, spreadsheets, database management systems, code editors, image and video editors, e-book readers, audio and video players, and the like. Operating system 245 on each device provides a local file management system and executes the various software modules such as content management system client application 200 and native application 255. A contact directory 240 stores information about the user's contacts, such as name, picture, telephone numbers, company, email addresses, physical address, website URLs, and the like. Further operation of native applications 255, operating system 245, and content management system client application 200 are described below.


Device 100 may include additional components such as camera 230 and location module 235. Camera 230 may be used to capture images or video for upload to the online content management system 110. Location module 235 determines the location of device 100, using for example a global positioning satellite signal, cellular tower triangulation, or other methods. Location module 235 may be used by client application 200 to obtain location data and add the location data to metadata about a content item, such as an image captured by camera 230.


Client device 100 accesses content management system 110 in a variety of ways. Client application 200 can be a dedicated application or module that provides access to the services of content management system 110, providing both user access to shared files through a user interface, as well as programmatic access for other applications. Client device 100 may also access content management system 110 through web browser 250 by signing into a user account through a content management system webpage. As an alternative, client application 200 may integrate access to content management system 110 with the local file management system provided by operating system 245. When access to content management system 110 is integrated in the local file management system, a file organization scheme maintained at content management system 110 is represented as a local file structure by operating system 245 in conjunction with client application 200. Client application 200 may take various forms, such as a stand-alone application, an application plug-in, a browser extension, and so forth. Client application 200 includes user interface module 202, event management module 204, access module 206, activity feed module 207, local content data store 208, and event data store 210. The various modules and data stores are described separately throughout this disclosure for convenience and in various implementations may be combined or further divided into separate components as desired. The client application 200 generally, and the various modules specifically, are not conventional or routine elements of generic computing device 100.


Activity feed module 207 provides a user-interface activity feed displayed with the content item and includes a list or history of users' interactions with a content item, and is one means for performing these functions. Users' interactions with the content item include, for example, when a user reviews the content item, edits the content item (i.e., changes the content data of a content item), comments on the content item, views other users' interaction with the content item such as changes or comments, renames the content item, creates a new version of the content item, shares the content item, and so forth. Activity feed module 207 displays a list of event notifications corresponding to users' interactions with the content item in the user-interface activity feed. That is, activity feed module 207 displays a list of event notifications corresponding to events associated with the content item. Activity feed module 207 may display event data associated with the events that are related to the content item in the user-interface activity feed. Event data, for example, includes a time stamp associated with the event, an event type (e.g., comment, view, edit, retrieve/open, save/close) associated with the event, the content (e.g., texts and/or images of the comment, the specifics of the edit) of the event, a content item version, and one or more associated events. Activity feed module 207 allows a user to configure which events and/or event data associated with the events should be displayed in the user-interface activity feed. For example, a user may configure to mute events with the event types of retrieve or open, in which case activity feed module 207 does not display event notifications corresponding to users retrieving or opening content items. As another example, a user may configure not to show event content of events and activity feed module 207 does not display details of other users' edits.


The activity feed provides the content of the content item to all users that work on a content item. Event notifications indicate to various users that work on the content item of all users' interaction with the content item. Activity feed module 207 may present events that are associated with each other as one event notification. In various embodiments, activity feed module 207 presents those events that are associated with the section of a content item that is being currently presented to a user. When the user requests to view another section of the content item, activity feed module 207 presents other events that are associated with the other section of the content item. Activity feed module 207 presents the event notifications chronologically in the user-interface activity feed. Within each event notification, activity feed module 207 presents the events chronologically according to the event time stamps.


Content management system 110 may store each event in a manner that persistently associates the events with one or more particular content items. Accordingly, information related to a content item that is helpful to the collaborative drafting, editing, and review of the content item can be displayed in the activity feed with the content item. The activity feed is stored separately from the native application of the content item and separate from the data of the content item itself; this is beneficial since it allows the activity feed and the events therein to be associated with multiple different versions of a given document. In some embodiments, the activity feed may be displayed cohesively with the native application. In some embodiments, the activity feed is displayed separately from the native application of the content item. In some embodiments, activity feed module 207 provides a message or chat interface enabling users to send public or private messages to one or more other users who also work on the content item. A user can send messages to users who are online or offline. Further, maintaining the events separate from the content items themselves enables users who do not have access to the native content application can review context of content items in the activity feed thereby to contribute to the collaboration. This further extends the functionality of device 100 beyond its generic capabilities.


Event management module 204 receives and processes events for providing to activity feed module 207 for display, and is one means for performing this function. Event management module 204 receives events related to a content item from the content management system (e.g., an event module of the content management system). The events received include various users' interaction with the particular content item. In addition, event management module 204 receives events including the particular user's interaction with the content item from access module 206 and provides these events to the content management system (e.g., an event module of the content management system). In addition, event management module 204 may further receive events including the particular user's interaction with the content item from activity feed module 207 and provides these events to the content management system (e.g., an event module of the content management system). Event management module 204 provides events including the particular user's interaction with the content item to the content management system in real time. For a particular content item, event management module 204 sends events including a particular user's interaction with the content item to the content management system in real time. The content management system receives events including various users' interactions with the content item from various user devices. Periodically, event management module 204 receives events including various users' interaction with the content item from the content management system. As such, event management module 204 obtains and manages information with respect to users' interaction with a particular content item.


Each event comprises event data such as an event type (e.g., comment, view, revision, message, retrieve/open, save/close), a user ID, a content item ID (e.g., a unique ID, file name, pathname, or the like), a content item version, a time stamp, an event content (e.g., texts and/or images of the comments, the specifics of the revision), and/or an associated event ID. For example, a first event of a user reviewing another user's comment on a content item is associated with a second event of the other user's commenting on the content item. For events with the message event types, the event data may further include a recipient user ID and the message type (e.g., private or public). It should be appreciated that event management module 204 could alternatively reside with content management system 110 or at least some of the processes described herein can be performed by content management system 110. Event management module 204 may store the events including the associated event data in event data store 210.


In addition, event management module 204 processes the events received from content management system 110 and/or access module 206 prior to providing to activity feed module 207 for display. Event management module 204 receives, periodically from content management system 110, events that content management system 110 has received from different devices. Event management module 204 processes the events according to the time stamps, event types, and/or the content of the events such that the events provided to activity feed module 207 are organized. For example, event management module 204 orders the events received according to the associated time stamps. Event management module 204 may associate each event with the relevant section (e.g., page, paragraph, etc.) of the content item. In addition, event management module 204 may associate those events that are associated with the same section of the content item with each other. In one event notification, the associated events may be presented chronologically. Furthermore, event management module 204 may associate events based on their content. For example, event management module 204 may process the content of the comments or messages to determine the topic and associate those comments or messages having the same topic.


Access module 206 provides event management module 204 with a particular user's interaction with a content item as events, such as when a user opens or closes a content item, edits a content item, comments on a content item, and renames or creates a new version of a content item, and is one means for performing this function. For example, when a user edits a content item, access module 206 receives data corresponding to the edits the user makes to the content item and creates an event including the event data such as the time stamp, the user ID, the specifics of the edits, and the like. As another example, when a user has viewed a comment (or edits) made by another user, access module 206 receives corresponding data and creates an event. Access module 206 sends the event to event management module 204, and event management module 204 sends the event to content management system 110. In one embodiment, access module 206 may additionally provide interaction information for user submitted messages received via the activity feed to event management module 204. Alternatively, the interaction information for message events may be provided to event management module 204 by activity feed module 207.


Client application 200 may store accesses from a content storage at content management system 110 in local content data store 208. While represented here as within client application 200, local content data store 208 may be stored with other data for client device 100 in non-volatile storage. When local content data store 208 is stored this way, the content is available to the user and other applications or modules, such as native application 255, when client application 200 is not in communication with content management system 110.


Access module 206 manages updates to local content data store 208 and uses a synchronization logic to communicate with content management system 110 to synchronize content modified by client device 100 with content maintained on content management system 110, and is one means for performing this function. One example of such synchronization is provided in U.S. Pat. Pub. 2015/0012488 filed Sep. 27, 2013 and is hereby incorporated by reference in its entirety.


Accordingly, device 100 receives content items from content management system 110, stores such items to local content data store 208, where they may be accessed and edited with various native applications 255 stored on device 100. For example, device 100 may include a photo editing application that manipulates image content items, a word processing application that permits modification of text content items, or a computer-aided design (CAD) application that permits modification of drawing content items. Additionally, content management system 110 can share a content item with other users upon user request and provide users with read and write access.



FIGS. 3-5 illustrate examples of the collaborative editing that includes multiple users interacting with content item 302. FIGS. 3A and 3B show content item 302 displayed on desktop 300A to a first user (clear background) while content item 302 is also displayed on desktop 300B to a second user (striped background). In this example, content item 302 may be displayed simultaneously on desktop 300A and 300B where the collaboration is in substantially real time (synchronous collaboration), or the corresponding interactions by the different users captured in these figures may occur at different times (asynchronous collaboration). In this example, content item 302 is a word processing document and is displayed in FIGS. 3A and 3B by native application 255 such as a word processor, on both desktops 300A and 300B,


Additionally, content item 302 is displayed concurrently with activity feed 306 on both desktops 300A and 300B, thereby to provide a currently updated-list or history of content item events and user submitted messages. As such, the events that are specific to content item 302 are reflected essentially in real time as they occur on any device that has access to the content item 302. In this example, activity feed 306 includes event notifications 308 and 310, scroll button 316 for controlling displaying other event notifications, and interaction icon 312 for selectively displaying activity feed 306 (e.g., displaying or hiding activity feed 306). The event notifications are associated with the section of the content item that is being presented to the user. Activity feed 306 may further include a chat or message interface (not shown) that includes a text field for receiving messages from users or posting comments. Users may interact with a content item via activity feed 306. For example, a user may add a new comment to a content item or interact with an event such as like a comment, mark a comment as resolved, delete or restore another version, and the like.


As shown in FIGS. 3A and 3B, activity feed 306 displays a list of events as event notifications 308 and 310. Each event notification corresponds to one or more events and displays event data associated with the one or more events. As illustrated, event notification 308 corresponds to a first event of a first user commenting on content item 302 and a second event of a second user commenting on the content item 302; the first and second events are both comment type events. The second event is associated with the first event because the second user made the comment to in response to the first user's comment. Event notification 308 accordingly illustrates event data of the first and second events because they are associated with each other. Event notification 308 illustrates event data of the first event such as the user icon of the first user, the content of the first user's comment, the time stamp of the first user's comment, as well as the version (e.g., v2) of content item 302. In addition, event notification 308 illustrates event data of the second event such as the user icon of the second user, the content of the second user's comment, the time stamp of the second user's comment, as well as the version (e.g., v3) of content item 302.


Furthermore, event notification 310 corresponds to a third event of the second user editing content item 302 and a fourth event of the first user viewing the edits made by the second user. The fourth event is a view-type event and is associated with the third event that is an edit-type event because the first user has viewed the edits made by the second user. Event notification 310 illustrates event data of the third event such as the user icon of the second user who edits the content item, the details of the edits, the time stamp of the edits, as well as the content item version (e.g., v3) associated with the edits. In addition, event notification 310 illustrates event data of the fourth event such as the user icon of the first user who has viewed the edits made by the second user, the time stamp of the first user viewing the edits, as well as the content item version (e.g., v3) associated with the edits. Additionally, as shown in FIGS. 3A-B, within each event notification, event data of events is presented chronologically according to the time stamps associated with the events. Additional event notifications that are older or newer in time, or associated with other sections of the content item can be viewed by scrolling up or down using scroll button 316. In addition, as different users may retrieve, create, and/or work on different versions of a content item, the concurrent display of event notifications associated with different versions of a content item provides users with a more complete view of the overall history and development of the content item.


Similarly, FIGS. 4A and 4B show content item 302 being displayed on desktop 300A to the first user and on desktop 300B to the second user reflecting changes made by a third user. In this example, event notification 408 corresponds to the first event of a first user commenting on content item 302, the second event of a second user commenting on content item 302, and a fifth event of the third user commenting on content item 302. The first and second events are described previously with respect to FIGS. 3A and 3B. The first, second, and fifth events are all comment-type events. The fifth event is associated with the second event because the third user made the comment in response to the second user's comment corresponding to the second event. Similar to event notification 308 shown in FIGS. 3A and 3B, event notification 408 accordingly illustrates event data of the first, second, and fifth events because they are associated with each other. In addition to the event data of first and second events shown in event notification 308 in FIGS. 3A and 3B, event notification 408 further illustrates event data of the fifth event such as the user icon of the third user, the content of the third user's comment, the time stamp of the third user's comment, as well as the version (e.g., v4) of the content item 302.


Furthermore, event notification 410 corresponds to the third event of the second user editing content item 302, the fourth event of the first user viewing the edits made by the second user, and a sixth event of the third user viewing the edits made by the second user. The third and fourth events are described previously with respect to FIGS. 3A and 3B. The sixth event is a view-type event and is associated with the third event that is an edit-type event because the third user has viewed the edits made by the second user. Similar to event notification 310 shown in FIGS. 3A and 3B, event notification 410 illustrates event data of the third event, of the fourth event, as well as of the sixth event because they are associated with each other. In addition to the event data of the third and fourth events shown in event notification 310 in FIGS. 3A and 3B, event notification 410 further illustrates event data of the sixth event such as the user icon of the third user who has viewed the edits made by the second user, the time stamp of the third user viewing the edits, as well as the content item version (e.g., v3) associated with the edits.


Furthermore, as illustrated in FIG. 4B, additional event notification 412 is illustrated by using scroll button 316. Event notification 412 corresponds to a seventh event of the third user editing the content item 302. Event notification 412 includes event data of the seventh event such as the user icon of the third user who edits the content item, the details of the edits, the time stamp of the edits, as well as the content item version associated with the edits. Additional event notifications that are older or newer in time, or associated with other sections of the content item can be viewed by scrolling up or down using scroll button 316. Additionally, as shown in FIGS. 4A-B, within each event notification, event data of events is organized chronologically.


In addition, as different users may retrieve, create, and/or work on different versions of a content item, the concurrent display of event notifications associated with different versions of a content item provides users with a more complete view of the overall history and development of the content item. The third user accepted the edits made by the second user, thus the most recent version (e.g., v4) of content item 302 is illustrated. The edits made by the second user are no longer tracked and only the edits made by the third user are tracked in the view of native application 255. However, the details of the second user's edits are still illustrated in activity feed 306.



FIG. 5 shows content item 302 displayed on desktop 300C to a fourth user in a web preview of content item 302 as displayed by web browser 250. In this example, the device of desktop 300C displaying content item 302 does not include client application 200. Thus, the fourth user has logged into their user account with content management system 110 though a webpage to access their content items. In order to view a content item in a web preview, content management system 110 accesses the content item, converts the content item from the format of its native application to a preview format, such as PDF, and renders the content item for display in a web browser. In this case, a user can view the content items as web previews or download a content item for local editing or viewing, however, changes made to a content item that is downloaded from the web cannot be synchronized with content management system 110. The web preview, thus, enables the fourth user to view revisions to a content item 302 made by other users and updates to activity feed 306 in substantially real time or upon refreshing the browser, for example.


Activity feed 306 for a web preview, however, still includes activity feed 306 that displays event notifications 508 and 512. Event notification 508 corresponds to the first event of a first user commenting on content item 302, the second event of a second user commenting on content item 302, the fifth event of the third user commenting on content item 302, and an eighth event of a fourth user commenting on content item 302. The first and second events are described above with respect to FIGS. 3A and 3B, and the fifth event is described above with respect to FIGS. 4A and 4B. The first, second, fifth, and eighth events are all comment-type events. The eighth event is associated with the fifth event because the fourth user made the comment in response to the third user's comment. Similar to event notification 308 shown in FIGS. 3A and 3B and event notification 408 shown in FIGS. 4A and 4B, event notification 508 accordingly illustrates event data of the first, second, fifth, and eighth events because they are associated with each other. The fourth user may be unable to make their desired changes; however, they can comment on content item 302 so that other users can make the edits.


Additionally, event notification 512 corresponds to the seventh event of the second user editing content item 302 and a ninth event of the fourth user viewing the edits made by the second user. The seventh event is described above with respect to FIGS. 4A and 4B. The ninth event is a view-type event and is associated with the seventh event that is an edit-type event because the fourth user has viewed the edits made by the third user. Similar to event notification 310 shown in FIGS. 3A and 3B and event notification 410 shown in FIGS. 4A and 4B, event notification 512 illustrates event data of the seventh event and the ninth event because they are associated with each other.


In the illustrated example, the fourth user minimizes event notification 410 illustrated in FIGS. 4A and 4B. Event notifications corresponding to users opening or closing content items may be for user views should be displayed to other users in activity feed 306 may be configured to be muted. The examples illustrated in FIGS. 3A through 5 therefore do not show event notifications corresponding to first through fourth users opening and closing content item 302.



FIG. 6 shows an interaction diagram for providing events for displaying in activity feed 306 in response to receiving a request from device 100 to display content item 302. In this example, native client application 255 sends a request to launch content item 302 from a file folder. The request is received 602 by access module 206 of client application 200. In response to the request, access module 206 generates an event corresponding to the user's requesting to open content item 302. The event includes the associated event data such as the user ID associated with the user, the time stamp, the retrieve event type, the content item ID of content item 302, the version of content item 302, and the like. Access module 206 sends 604 the generated event including the associated event data to event management module 204, and is one means for performing this function. Access module 206 generates events corresponding to the user's interaction with content items. Example interaction with the content item include the user retrieving, opening, closing, commenting on, editing, viewing edits, private chat messages with other users, creating new versions of, and the like.


Subsequently, event management module 204 sends the event associated with content item 302 to content management system 110. Event management module 204 may send the event in real time to content management system 110 responsive to content item 302 being opened or retrieved at client application 200. In addition, in response to the user's request to open content item 302, content management system 110 sends 608 events related to content item 302 to event management module 204. Content management system 110 sends cumulative events including event data that are associated with content item 302 to event management module 204. In some embodiments, the cumulative events may include all events associated with content item 302 that content management system 110 has received. Alternatively, the cumulative events may include only events associated with content item 302 that content management system 110 has received since the most recent time point of content management system 110 sending events to event management module 204. Event management module 204 may provide a time stamp of the latest event associated with content item 302 stored in local event data store 204 or content management system 110 may track sending events to event management module 204. Event management module 204 may store 610 the received events at event data store 204. Event data store 204 may include multiple sub-data stores and each sub-data store is configured to store events of a particular event type.


Event management module 204 processes 612 the received events. Event management module 204 may process the received events according to the event data associated with the received events. For example, event management module 204 may organize the received events according to the event types, the event time stamp, and/or the content item version. Event management module 204 may associate events based on the event data associated with the received events. For example, event management module 204 may associate a first event with a comment event type with a second event with a comment event type if the comment corresponding to the second event is made in response to the comment corresponding to the first event. Event management module 204 may associate a first view-type event with a second edit-type event if a first user corresponding to the first event has seen edits corresponding to the second event. Event management module 204 may update the event data associated with the events to reflect that the first and second events are associated with each other.


Event management module 204 provides 614 the processed events to activity feed module 207 for display. Activity feed module 207 displays a list of event notifications corresponding to the processed events and the associated event data provided by event management module 204. An event notification may correspond to one or more events. For example, an event notification may correspond to multiple events that are associated with each other. Activity feed module 207 displays the event notifications according to an order of the events received from event management module 204 in the activity feed. An event notification may display event data of the corresponding events such as the user ID or the corresponding user icon, the time stamp, the event content (e.g., details of edits, texts or images of a comment, texts or images of a message, etc.), or a version of the content item. In some embodiments, activity feed module 207 may generate an image to present the event content in an event notification. For example, an event notification may include a preview of a user's edits of a content item. In some embodiments, activity feed module 207 may generate an image to present a previous version of the content item in an event notification.



FIG. 7 illustrates an interaction diagram for displaying events related to content item 302 on client device 100. In this example, a user views, edits, and/or comments on content item 302 and/or messages other users via native client application 255. Access module 206 receives 702 a user request from client application 200 to interact with content item 302. For example, the client may request to view a version of content item 302, to edit content item 302, to comment on content item 302, and view a comment on content item 302, to message another collaborator of content item 302, and the like. In response to the user request, access module 206 generates an event corresponding to the user's requested interaction with content item 302. Example interaction with the content item includes the user retrieving, opening, closing, commenting on, editing, viewing interactions such as comments or edits, public or private chat messages with other users, creating new versions of a content item, and the like. The event includes the associated event data such as the user ID associated with the user, the time stamp, the event type (e.g., view, edit, comment, message, etc.), the content of the event (e.g., details of an edit, texts and/or images of a comment, texts and/or images of a message, etc.), an associated event, content item ID of content item 302, the version of content item 302, and the like. Access module 206 sends 704 the generated event including the associated event data to event management module 204, and is one means for performing this function.


Event management module 204 sends 706 the event to content management system 110. Event management module 204 may send events corresponding to the user's interactions with content item 302 to content management system 110 in real time when the user is interacting with content item 302. Simultaneously, content management system 110 aggregates 708 events related to content item 302. Content management system 110 may receive from a set of other devices (not shown) where other users are also working on content item 302. Periodically, content management system 110 sends 710 the aggregated events related to content item 302 to event management module 204. Event management module 204 may store 712 the received aggregated events at event data store 204.


Event management module 204 processes 714 events related to content item 302 that event management module 204 has received from content management system 110. That is, event management module 204 may process the received events at block 710 along with other events related to content item 302 that event management module 204 received from content management system 110. Event management module 204 may process the events according to the associated event data. For example, event management module 204 may also organize the received events according to the event types, the event time stamp, and/or the content item version. Event management module 204 may associate events based on the event data associated with the received events. For example, event management module 204 may associate a first comment type event with a second comment type event if the second event is made in response to the first event. Event management module 204 may associate a first view event with a second edit type event if a first user corresponding to the first event has seen edits corresponding to the second event. Event management module 204 may update the event data associated with the events to reflect that the first and second events are associated with each other.


Event management module 204 provides 716 the processed events to activity feed module 207 for display. Activity feed module 207 displays 718 a list of event notifications corresponding to the processed events and the associated event data provided by event management module 204. An event notification may correspond to one or more events. For example, an event notification may correspond to multiple events that are associated with each other. Activity feed module 207 displays the event notifications according to an order of the events received from event management module 204 in the activity feed. An event notification may display event data of the corresponding events such as the user ID or the corresponding user icon, the time stamp, the event content (e.g., details of edits, texts or images of a comment, texts or images of a message, etc.), or a version of the content item. In some embodiments, activity feed module 207 may generate a preview of event content in an event notification. In some embodiments, activity feed module 207 may generate an image to present a previous version of the content item in an event notification.



FIG. 8 shows components of content management system 110 of FIG. 1, according to one embodiment. In one configuration, components described below with reference to content management system 110 are incorporated into devices 100 that share and synchronize content items without management by content management system 110. These devices 100 may synchronize content and share interaction information over network 120 or via a direct connection as described above. In this configuration, devices 100 may incorporate functionality of synchronization module 812, conflict management module 814, event synchronization module 816, and other modules and data stores for incorporating functionality described below as provided by content management system 110. Accordingly, devices 100 in this configuration operate in a peer-to-peer configuration and may do so without content management system 110 or network 120.


When using content management system 110, to facilitate the various content management services, a user can create an account with content management system 110. The account information can be maintained in user account database 818, and is one means for performing this function. User account database 818 can store profile information for registered users. In some cases, the only personal information in the user profile can be a username and/or email address. However, content management system 110 can also be configured to accept additional user information, such as password recovery information, demographics information, payment information, and other details. Each user is associated with an identifier, such as a user ID or a user name.


User account database 818 can also include account management information, such as account type, e.g., free or paid; usage information for each user, e.g., file edit history; maximum storage space authorized; storage space used; content storage locations; security settings; personal configuration settings; content sharing data; etc. Account management module 804 can be configured to update and/or obtain user account details in user account database 818. Account management module 804 can be configured to interact with any number of other modules in content management system 110.


An account can be associated with multiple devices 100, and content items can be stored in association with an account. The stored content can also include folders of various types with different behaviors, or other content item grouping methods. For example, an account can include a public folder that is accessible to any user. The public folder can be assigned a web-accessible address. A link to the web-accessible address can be used to access the contents of the public folder. In another example, an account can include a photo folder that is intended for photo content items and that provides specific attributes and actions tailored for photos; an audio folder that provides the ability to play back audio file content items and perform other audio related actions; or other special purpose folders. An account can also include shared folders or group folders that are linked with and available to multiple user accounts. The permissions for multiple users may be different for a shared folder. In one embodiment, the account is a namespace that may be associated with several users, each of whom may be associated with permissions to interact with the namespace.


The content can be stored in content storage 820, which is one means for performing this function. Content storage 820 can be a storage device, multiple storage devices, or a server. Alternatively, content storage 820 can be a cloud storage provider or network storage accessible via one or more communications networks. In one configuration, content management system 110 stores the content items in the same organizational structure as they appear on the device. However, content management system 110 can store the content items in its own order, arrangement, or hierarchy.


Content storage 820 can also store metadata describing content items, content item types, and the relationship of content items to various accounts, folders, or groups. The metadata for a content item can be stored as part of the content item or can be stored separately. In one configuration, each content item stored in content storage 820 can be assigned a system-wide unique identifier.


Content storage 820 can decrease the amount of storage space required by identifying duplicate content items or duplicate segments of content items. In one embodiment, for example, a content item may be shared among different users by including identifiers of the users within ownership metadata of the content item (e.g., an ownership list), while storing only a single copy of the content item and using pointers or other mechanisms to link duplicates with the single copy. Similarly, content storage 820 stores content items using a version control mechanism that tracks changes to content items, different versions of content items (such as a diverging version tree), and a change history. The change history includes a set of changes that, when applied to the original content item version, produces the changed content item version.


Content management system 110 automatically synchronizes content items from one or more devices, using synchronization module 812, which is one means for performing this function. The synchronization is platform-agnostic. That is, the content items are synchronized across multiple devices 100 of varying type, capabilities, operating systems, etc. For example, client application 200 synchronizes, via synchronization module 812 at content management system 110, content in the file system of device 100 with the content items in an associated user account on system 110. Client application 200 synchronizes any changes to content items in a designated folder and its sub-folders with the synchronization module 812. Such changes include new, deleted, modified, copied, or moved files or folders. Synchronization module 812 also provides any changes to content associated with device 100 to client application 200. This synchronizes the local content at device 100 with the content items at content management system 110.


Conflict management module 814 determines whether there are any discrepancies between versions of a content item located at different devices 100. For example, when a content item is modified at one device and a second device, differing versions of the content item may exist at each device. Synchronization module 812 determines such versioning conflicts, for example by identifying the modification time of the content item modifications. Conflict management module 814 resolves the conflict between versions by any suitable means, such as by merging the versions, or by notifying the device of the later-submitted version.


A user can also view or interact with a content item via a web interface generated by user interface module 802. For example, the user can navigate in web browser 250 to a web address provided by content management system 110. Changes or updates to content in content storage 620 made through the web interface, such as uploading a new version of a file, are synchronized back to other devices 100 associated with the user's account. Multiple devices 100 may be associated with a single account and files in the account are synchronized between each of the multiple devices 100.


Content management system 110 includes communications interface 800 for interfacing with various devices 100, and with other content and/or service providers via an Application Programming Interface (API), which is one means for performing this function. Certain software applications access content storage 820 via an API on behalf of a user. For example, a software package, such as an app on a smartphone or tablet computing device, can programmatically make calls directly to content management system 110, when a user provides credentials, to read, write, create, delete, share, or otherwise manipulate content. Similarly, the API can allow users to access all or part of content storage 820 through a web site.


Content management system 110 can also include authenticator module 806, which verifies user credentials, security tokens, API calls, specific devices, etc., to determine whether access to requested content items is authorized, and is one means for performing this function. Authenticator module 806 can generate one-time use authentication tokens for a user account. Authenticator module 806 assigns an expiration period or date to each authentication token. In addition to sending the authentication tokens to requesting devices, authenticator module 806 can store generated authentication tokens in authentication token database 822. Upon receiving a request to validate an authentication token, authenticator module 806 checks authentication token database 822 for a matching authentication token assigned to the user. Once the authenticator module 806 identifies a matching authentication token, authenticator module 806 determines if the matching authentication token is still valid. For example, authenticator module 806 verifies that the authentication token has not expired or was not marked as used or invalid. After validating an authentication token, authenticator module 806 may invalidate the matching authentication token, such as a single-use token. For example, authenticator module 806 can mark the matching authentication token as used or invalid, or delete the matching authentication token from authentication token database 822.


Content management system 110 includes sharing module 810 for sharing content publicly or privately. Sharing content publicly can include making the content item accessible from any computing device in network communication with content management system 110. Sharing content privately can include linking a content item in content storage 820 with two or more user accounts so that each user account has access to the content item. The content can also be shared across varying types of user accounts.


In some embodiments, content management system 110 includes content management module 808 for maintaining a content directory that identifies the location of each content item in content storage 820, and allows client applications to request access to content items in the storage 820, and which is one means for performing this function. A content entry in the content directory can also include a content pointer that identifies the location of the content item in content storage 820. For example, the content entry can include a content pointer designating the storage address of the content item in memory. In some embodiments, the content entry includes multiple content pointers that point to multiple locations, each of which contains a portion of the content item.


In addition to a content path and content pointer, a content entry in some configurations also includes a user account identifier that identifies the user account that has access to the content item. In some embodiments, multiple user account identifiers can be associated with a single content entry indicating that the content item has shared access by the multiple user accounts.


To share a content item privately, sharing module 810 adds a user account identifier to the content entry associated with the content item, thus granting the added user account access to the content item. Sharing module 810 can also be configured to remove user account identifiers from a content entry to restrict a user account's access to the content item.


To share content publicly, sharing module 810 generates a custom network address, such as a URL, which allows any web browser to access the content in content management system 110 without any authentication. Sharing module 810 includes content identification data in the generated URL, which can later be used by content management system 110 to properly identify and return the requested content item. For example, sharing module 810 can be configured to include the user account identifier and the content path in the generated URL. The content identification data included in the URL can be transmitted to content management system 110 by a device to access the content item. In addition to generating the URL, sharing module 810 can also be configured to record that a URL to the content item has been created. In some embodiments, the content entry associated with a content item can include a URL flag indicating whether a URL to the content item has been created.


Event synchronization module 816 manages synchronization of events among user devices for content management system, and is one means for performing this function. Event synchronization module 816 receives events including the associated event data that are related to a content item from all devices where the content item is being opened. That is, event synchronization module 816 receives events corresponding to user interactions from all devices where users are interacting with the content item. Event synchronization module 816 receives events corresponding to interactions with the content item from devices in real time. In addition, event synchronization module 816 sends the events received from all devices where a content item is being opened to those devices. Event synchronization module 816 may send the events to the devices periodically such that interactions with the content item by different users are synchronized among all users. Event synchronization module 816 may store the events in content item event data store 824 of content management system 110.



FIG. 9 illustrates an example process for providing activity feeds illustrating users' interaction with a content item, according to one embodiment. Content management system 110 stores 902 content data for content item 302 in content storage 820 that can be retrieved by users authorized to access content item 302. For example, a first user creates content item 302 via native application 255 on device 100 and saves content item 302 to their account with content management system 110. In this example, the first user and one or more other users collaborate on content item 302. Content management system 110 may create a link that a user can use to invite another user to also work on content item 302. In order to grant users access to content item 302, content management system 110 associates metadata with content item 302 indicating that the invited users can now save content item 302 with their user account and have content item 302 synchronized across all users via synchronization module 812 and event synchronization module 816. Accordingly, content management system 110 provides 904 shared content item 302 for display to each user.


In order to facilitate the various features herein, content management system 110 maintains content data of content item 302. Content management system 110 maintains content data of content item 302 for multiple versions in content storage 820. Additionally, content management system 110 may also maintain version data of content item 302 in content storage 820.


Content management system 110 provides 906 activity feeds 306 for display with content item 302 to the users on devices 100. Activity feed 306, though provided for display with content item 302, is separate from the content data of content item 302 and separate from native application 255 associated with content item 302. Activity feed 306 displays users' interactions with the content item such as edits, views, comments, and/or messages to other users. Activity feed 306 displays a set of event notifications corresponding to the users' interactions. In one example, content item 302 is displayed by native application 255 and activity feed 306 is provided by content management system 110 in a layer separate from native application 255.


Content management system 110 receives 908 events related to content item 302 from devices 100. The received events correspond to users' interactions with content item 302 and comprise event data. A Device 100 may send an event corresponding to a user's interaction with content item 302 in real time. Users' interactions with the content item include, for example, when a user reviews the content item, edits the content item (i.e., changes the content data of a content item), views changes made to the content item by other users, comments on the content item, views other users' comments on the content item, renames the content item, creates a new version of the content item, shares the content item, and so forth. Event data, for example, includes an event ID, a time stamp associated with the event, an event type (e.g., comment, view, edit, retrieve/open, save/close) associated with the event, the content (e.g., texts and/or images of the comment, the specifics of the edit) of the event, a content item version, a user ID, a device ID, and one or more associated events. Content management system 110 may store the received events in content item event data store 824. Content item event data store 824 may comprise a sub-store for storing edit type events, a sub-store for storing view type events, and a sub-store for storing comment type events. Users' interactions with content item 302, that is, events related to content item 302, are maintained separately from the content data of content item 302.


Content management system 110 sends received events related to content item 302 to devices 100. Content management system 110 sends events comprising event data to devices 100 periodically. Content management system 110 sends events to device 100 for display with content item 302 in activity feed 306. As such, users' interaction with content item 302 is synchronized among devices 100. Activity feed 306 includes a list of event notifications corresponding to events provided by content management system 110 to device 100. Device 100 may process events received from content management system 100 for generating event notifications in activity feed 306. Device 100 may process events, for example, based on event data. An event notification in activity feed 306 may correspond to one or more events related to content item 302. Events associated with each other may be presented in one event notification. In one embodiment, activity feed 306 displays a preview of a user's edits of content item 302. In one embodiment, activity feed 306 displays an event notification of a user viewing another user's edits or comment.


Content management system 110 may be implemented using a single computer, or a network of computers, including cloud-based computer implementations. For the purposes of this disclosure, a computer is device having one or more processors, memory, storage devices, and networking resources. The computers are preferably server class computers including one or more high-performance CPUs and 1 G or more of main memory, as well as 500 Gb to 2 Tb of computer readable, persistent storage, and running an operating system such as LINUX or variants thereof. The operations of content management system 110 as described herein can be controlled through either hardware or through computer programs installed in computer storage and executed by the processors of such server to perform the functions described herein. These systems include other hardware elements necessary for the operations described here, including network interfaces and protocols, input devices for data entry, and output devices for display, printing, or other presentations of data, but which are not described herein. Similarly, conventional elements, such as firewalls, load balancers, failover servers, network management tools and so forth are not shown so as not to obscure the features of the system. Finally, the functions and operations of content management system 110 are sufficiently complex as to require implementation on a computer system, and cannot be performed in the human mind simply by mental steps.


The foregoing description of the embodiments of the invention has been presented for the purpose of illustration; it is not intended to be exhaustive or to limit the invention to the precise forms disclosed. Persons skilled in the relevant art can appreciate that many modifications and variations are possible in light of the above disclosure.


Some portions of this description describe the embodiments of the invention in terms of algorithms and symbolic representations of operations on information. These algorithmic descriptions and representations are commonly used by those skilled in the data processing arts to convey the substance of their work effectively to others skilled in the art. These operations, while described functionally, computationally, or logically, are understood to be implemented by computer programs or equivalent electrical circuits, microcode, or the like. Furthermore, it has also proven convenient at times, to refer to these arrangements of operations as modules, without loss of generality. The described operations and their associated modules may be embodied in software, firmware, hardware, or any combinations thereof.


Any of the steps, operations, or processes described herein may be performed or implemented by a combination of hardware and software modules, alone or in combination with other devices. In one embodiment, a software module is implemented with a computer program product comprising a non-transitory computer-readable medium containing computer program code, which can be executed by a computer processor for performing any or all of the steps, operations, or processes described.


Finally, the language used in the specification has been principally selected for readability and instructional purposes, and it may not have been selected to delineate or circumscribe the inventive subject matter. It is therefore intended that the scope of the invention be limited not by this detailed description, but rather by any claims that issue on an application based hereon. Accordingly, the disclosure of the embodiments of the invention is intended to be illustrative, but not limiting, of the scope of the invention, which is set forth in the following claims.

Claims
  • 1. A method, comprising: providing, by a content management system, a content item for display by a native application in a first interface window controlled by the native application of a first computing device associated with a first user account of a first user, the content item synchronized between the first user account and a second user account of a second user, the content item being editable by the first user and the second user, and the synchronization causing edits made by the first user to the content item to be viewable by the second user and edits made by the second user to the content item to be viewable by the first user;providing to the first computing device an activity feed separate from the content item and displayed by a client application in a second interface window controlled by the client application, the activity feed showing at least a partial history of edits made by users to the collaborative content item, the client application being different from the native application and the second interface window being different from the first interface window;receiving in real-time from a second computing device an event corresponding to an interaction of the second user with the content item; andproviding to the first computing device an update to the activity feed to include an indication of the event.
  • 2. The method of claim 1, wherein the content item is associated with a plurality of versions of the content item, the method further comprising: maintaining, for each respective version of the plurality of versions of the content item, respective content data in a content storage of a content management system; andmaintaining, separate from the respective content data, respective version data associated with creation of each respective version in the content storage of the content management system.
  • 3. The method of claim 1, further comprising: receiving in real-time from the second computing device a second event corresponding to a second interaction of the second user with the content item; andproviding to the first computing device a second update to the activity feed to include a second indication of the second event.
  • 4. The method of claim 1, wherein the event includes event data comprising at least one of an event type corresponding to a type of the interaction, a time stamp of the interaction, a content of the event, and a content item version.
  • 5. The method of claim 1, further comprising: providing to the first computing device an option to mute the update to the activity feed.
  • 6. The method of claim 1, wherein the update further includes an event notification including a preview of details of the second user's interaction.
  • 7. The method of claim 6, wherein the event notification contains information about more than one event.
  • 8. A method executed by a computing device, comprising: receiving, from a content management system, a content item for display to a first user in a first interface window controlled by a native application associated with a first user account of the first user, the content item synchronized between the first user account and a second user account of a second user, the content item being editable by the first user and the second user, and the synchronization causing edits made by the first user to the content item to be viewable by the second user and edits made by the second user to the content item to be viewable by the first user;generating for display an activity feed separate from the content item and displayed by a client application in a second interface window controlled by the client application, the activity feed showing at least a partial history of edits made by users to the collaborative content item, the client application being different from the native application and the second interface window being different from the first interface window; andgenerating for display an update to the activity feed to include an indication of an event corresponding to an interaction of the second user with the content item.
  • 9. The method of claim 8, further comprising: generating for display a second update to the activity feed to include a second indication of a second event corresponding to a second interaction of the second user with the content item.
  • 10. The method of claim 8, wherein the event includes event data comprising at least one of an event type corresponding to a type of the interaction, a time stamp of the interaction, a content of the event, and a content item version.
  • 11. The method of claim 8, further comprising: providing the first user with an option to mute the update to the activity feed.
  • 12. The method of claim 8, wherein the update further includes an event notification including a preview of details of the second user's interaction.
  • 13. The method of claim 12, wherein the event notification contains information about more than one event.
  • 14. A non-transitory computer-readable storage medium storing instructions that, when executed by at least one processor, cause a computing device to: provide, by a content management system, a content item for display by a native application in a first interface window controlled by the native application of a first computing device associated with a first user account of a first user, the content item synchronized between the first user account and a second user account of a second user, the content item being editable by the first user and the second user, and the synchronization causing edits made by the first user to the content item to be viewable by the second user and edits made by the second user to the content item to be viewable by the first user;provide to the first computing device an activity feed separate from the content item and displayed by a client application in a second interface window controlled by the client application, the activity feed showing at least a partial history of edits made by users to the collaborative content item, the client application being different from the native application and the second interface window being different from the first interface window;receive in real-time from a second computing device an event corresponding to an interaction of the second user with the content item; andprovide to the first computing device an update to the activity feed to include an indication of the event.
  • 15. The non-transitory computer-readable storage medium of claim 14, wherein the content item is associated with a plurality of versions of the content item, further comprising instructions that cause the computing device to: maintain, for each respective version of the plurality of versions of the content item, respective content data in a content storage of the content management system; andmaintain, separate from the respective content data, respective version data associated with creation of each respective version in the content storage of the content management system.
  • 16. The non-transitory computer-readable storage medium of claim 14, further comprising: receive in real-time from the second computing device a second event corresponding to a second interaction of the second user with the content item; andprovide to the first computing device a second update to the activity feed to include a second indication of the second event.
  • 17. The non-transitory computer-readable storage medium of claim 14, wherein the event includes event data comprising at least one of an event type corresponding to a type of the interaction, a time stamp of the interaction, a content of the event, and a content item version.
  • 18. The non-transitory computer-readable storage medium of claim 14, further comprising: provide to the first computing device an option to mute the update to the activity feed.
  • 19. The non-transitory computer-readable storage medium of claim 14, wherein the update provided to the activity feed of the first computing device further includes an event notification including a preview of details of the second user's interaction.
  • 20. The non-transitory computer-readable storage medium of claim 19, wherein the event notification contains information about more than one event.
CROSS REFERENCE TO RELATED APPLICATIONS

This application is a continuation of U.S. application Ser. No. 14/983,094, filed Dec. 29, 2015, now U.S. Pat. No. 10,248,933, which is incorporated by reference in its entirety.

US Referenced Citations (220)
Number Name Date Kind
5337407 Bates et al. Aug 1994 A
5960173 Tang et al. Sep 1999 A
6065026 Cornelia et al. May 2000 A
6088707 Bates et al. Jul 2000 A
6260040 Kauffman et al. Jul 2001 B1
6938042 Aboulhosn et al. Aug 2005 B2
7089307 Zintel et al. Aug 2006 B2
7386529 Kiessig et al. Jun 2008 B2
7401104 Shah et al. Jul 2008 B2
7496633 Szeto et al. Feb 2009 B2
7533134 Terry et al. May 2009 B2
7558797 Li Jul 2009 B2
7603357 Gourdol et al. Oct 2009 B1
7610280 O'Toole et al. Oct 2009 B2
7620659 Novik et al. Nov 2009 B2
7631007 Morris Dec 2009 B2
7640506 Pratley Dec 2009 B2
7676526 Beloussov et al. Mar 2010 B1
7769810 Kaufman Aug 2010 B1
7818419 McAllister et al. Oct 2010 B1
7822711 Ranade et al. Oct 2010 B1
7912916 Rakowski et al. Mar 2011 B2
8019877 Li et al. Sep 2011 B2
8041807 Bao et al. Oct 2011 B2
8055644 Crowley et al. Nov 2011 B2
8086698 Rakowski et al. Dec 2011 B2
8140513 Ghods et al. Mar 2012 B2
8156078 Tsinman et al. Apr 2012 B2
8230348 Peters et al. Jul 2012 B2
8244830 Robinson et al. Aug 2012 B2
8301606 Futatsugi et al. Oct 2012 B2
8386558 Schleifer et al. Feb 2013 B2
8452959 Brown et al. May 2013 B2
8468132 O'Neill et al. Jun 2013 B1
8495015 Freedman et al. Jul 2013 B2
8521732 Wood et al. Aug 2013 B2
8543637 Kent et al. Sep 2013 B2
8555177 Junee et al. Oct 2013 B1
8600934 Strong et al. Dec 2013 B2
8615552 Shah et al. Dec 2013 B2
8635209 Freedman et al. Jan 2014 B2
8655840 Simelius et al. Feb 2014 B2
8700759 Chakra et al. Apr 2014 B2
8719225 Rath et al. May 2014 B1
8825597 Houston et al. Sep 2014 B1
8843441 Rath et al. Sep 2014 B1
8868500 Giampaolo et al. Oct 2014 B2
8930312 Rath et al. Jan 2015 B1
8930488 Dantec et al. Jan 2015 B2
8997007 Bennett et al. Mar 2015 B1
9021113 Carr et al. Apr 2015 B2
9053165 Van Rossum et al. Jun 2015 B2
9240962 Jung et al. Jan 2016 B2
9280613 Smith et al. Mar 2016 B2
9298355 Beausoleil et al. Mar 2016 B1
9298834 Kleppner et al. Mar 2016 B2
9307006 Micucci et al. Apr 2016 B2
9338242 Suchland et al. May 2016 B1
9432457 Marano et al. Aug 2016 B2
9519886 Berger et al. Dec 2016 B2
9575981 Dorman et al. Feb 2017 B2
9602560 Moody et al. Mar 2017 B1
9614880 Davis et al. Apr 2017 B1
9646023 Mccabe May 2017 B1
9652741 Goldberg et al. May 2017 B2
9690785 Vagell Jun 2017 B1
9773010 Ganesh et al. Sep 2017 B1
9773051 Smith Sep 2017 B2
9832237 Lock et al. Nov 2017 B2
9998555 Larabie-Belanger Jun 2018 B2
10091287 Larabie-Belanger Oct 2018 B2
10133720 Rothschiller et al. Nov 2018 B2
10171579 Larabie-Belanger Jan 2019 B2
10235022 Eccleston et al. Mar 2019 B2
10270871 Larabie-Belanger Apr 2019 B2
10318492 Eisner Jun 2019 B2
20010042073 Saether et al. Nov 2001 A1
20020049786 Bibliowicz et al. Apr 2002 A1
20030018719 Ruths et al. Jan 2003 A1
20030112273 Hadfield et al. Jun 2003 A1
20030159136 Huang et al. Aug 2003 A1
20040021686 Barberis Feb 2004 A1
20040024795 Hind et al. Feb 2004 A1
20040058710 Timmins et al. Mar 2004 A1
20040199514 Rosenblatt et al. Oct 2004 A1
20040221010 Butler Nov 2004 A1
20050022210 Zintel et al. Jan 2005 A1
20050044187 Jhaveri et al. Feb 2005 A1
20050223047 Shah et al. Oct 2005 A1
20050246544 Moore et al. Nov 2005 A1
20050278392 Hansen et al. Dec 2005 A1
20060004911 Becker et al. Jan 2006 A1
20060101064 Strong et al. May 2006 A1
20060190117 Weczorek et al. Aug 2006 A1
20060235984 Kraus et al. Oct 2006 A1
20060259957 Tam et al. Nov 2006 A1
20060288053 Holt et al. Dec 2006 A1
20070027853 Hajela et al. Feb 2007 A1
20070168490 Kent et al. Jul 2007 A1
20070174787 Rhee et al. Jul 2007 A1
20070271502 Bedi et al. Nov 2007 A1
20080005188 Li et al. Jan 2008 A1
20080005235 Hegde et al. Jan 2008 A1
20080109547 Bao et al. May 2008 A1
20080178117 Gelman et al. Jul 2008 A1
20080195759 Novik et al. Aug 2008 A1
20080222296 Lippincott et al. Sep 2008 A1
20080243807 Gaucas et al. Oct 2008 A1
20080244418 Manolescu et al. Oct 2008 A1
20080307102 Galloway et al. Dec 2008 A1
20090006498 Freedman et al. Jan 2009 A1
20090113412 Shribman et al. Apr 2009 A1
20090138808 Moromisato et al. May 2009 A1
20090157627 Arthursson Jun 2009 A1
20090222763 Dukhon et al. Sep 2009 A1
20090228504 Brown et al. Sep 2009 A1
20090249224 Davis et al. Oct 2009 A1
20090271696 Bailor et al. Oct 2009 A1
20090271708 Peters et al. Oct 2009 A1
20090288150 Toomim et al. Nov 2009 A1
20090292681 Wood et al. Nov 2009 A1
20090292709 Tsinman et al. Nov 2009 A1
20090313311 Hoffmann et al. Dec 2009 A1
20090327358 Lukiyanov et al. Dec 2009 A1
20100017879 Kuegler et al. Jan 2010 A1
20100131868 Chawla et al. May 2010 A1
20100138387 Simelius et al. Jun 2010 A1
20100191884 Holenstein et al. Jul 2010 A1
20100198784 Serlet Aug 2010 A1
20100198874 Futatsugi et al. Aug 2010 A1
20100251340 Martin et al. Sep 2010 A1
20100257450 Go et al. Oct 2010 A1
20100257457 De Goes Oct 2010 A1
20100281384 Lyons et al. Nov 2010 A1
20110055177 Chakra et al. Mar 2011 A1
20110106880 Strong et al. May 2011 A1
20110113092 Rakowski et al. May 2011 A1
20110208805 Kasetty et al. Aug 2011 A1
20110231499 Stovicek Sep 2011 A1
20110296042 Li et al. Dec 2011 A1
20120005159 Wang et al. Jan 2012 A1
20120054279 Dantec et al. Mar 2012 A1
20120089710 Rakowski et al. Apr 2012 A1
20120101980 Taleghani et al. Apr 2012 A1
20120124486 Robinson et al. May 2012 A1
20120130953 Hind et al. May 2012 A1
20120151495 Burckhardt et al. Jun 2012 A1
20120185434 Giampaolo et al. Jul 2012 A1
20120227059 Fleming Sep 2012 A1
20120233554 Vagell et al. Sep 2012 A1
20120278127 Kirakosyan et al. Nov 2012 A1
20120303716 Peters et al. Nov 2012 A1
20120317239 Mulder et al. Dec 2012 A1
20120324121 Carr et al. Dec 2012 A1
20120331108 Ferdowsi et al. Dec 2012 A1
20130006947 Akinyemi et al. Jan 2013 A1
20130013560 Goldberg et al. Jan 2013 A1
20130054509 Kass et al. Feb 2013 A1
20130060859 Olsen Mar 2013 A1
20130091205 Kotler et al. Apr 2013 A1
20130117376 Filman et al. May 2013 A1
20130124638 Barreto et al. May 2013 A1
20130124967 Hatfield et al. May 2013 A1
20130124978 Horns et al. May 2013 A1
20130138608 Smith May 2013 A1
20130151596 Strong et al. Jun 2013 A1
20130185651 Wionzek et al. Jul 2013 A1
20130191339 Haden et al. Jul 2013 A1
20130191451 Tse et al. Jul 2013 A1
20130204841 Obusek et al. Aug 2013 A1
20130212250 Kleppner et al. Aug 2013 A1
20130212480 Ben-Shaul et al. Aug 2013 A1
20130247004 DeLuca et al. Sep 2013 A1
20130254656 Florian et al. Sep 2013 A1
20130275509 Micucci et al. Oct 2013 A1
20130282656 O'Neill et al. Oct 2013 A1
20130297680 Smith et al. Nov 2013 A1
20130332523 Luu Dec 2013 A1
20140019626 Hubler et al. Jan 2014 A1
20140040202 Hagan et al. Feb 2014 A1
20140101310 Savage et al. Apr 2014 A1
20140156749 Kanter et al. Jun 2014 A1
20140160153 Singh Jun 2014 A1
20140172799 Dorman Jun 2014 A1
20140201289 Wheeler et al. Jul 2014 A1
20140215302 Little et al. Jul 2014 A1
20140223333 Pegg et al. Aug 2014 A1
20140237387 Ryall et al. Aug 2014 A1
20140244580 Eisner Aug 2014 A1
20140244583 Wang et al. Aug 2014 A1
20140250064 Hopmann et al. Sep 2014 A1
20140279846 Srinivasan et al. Sep 2014 A1
20140280377 Frew Sep 2014 A1
20140280603 Rideout et al. Sep 2014 A1
20140330776 Chen Nov 2014 A1
20140372852 Rothschiller et al. Dec 2014 A1
20150012488 Van Rossum Jan 2015 A1
20150032686 Kuchoor Jan 2015 A1
20150077326 Kramer et al. Mar 2015 A1
20150082196 Berger et al. Mar 2015 A1
20150106750 Konami et al. Apr 2015 A1
20150112927 Lee et al. Apr 2015 A1
20150142742 Hong May 2015 A1
20150149404 Lock et al. May 2015 A1
20150261411 Snook et al. Sep 2015 A1
20150278330 Hawa et al. Oct 2015 A1
20150281869 Ramachandran et al. Oct 2015 A1
20150286655 Von Haden et al. Oct 2015 A1
20150288757 Larabie-Belanger Oct 2015 A1
20150288774 Larabie-Belanger et al. Oct 2015 A1
20150288775 Larabie-Belanger Oct 2015 A1
20150370769 Pereira et al. Dec 2015 A1
20150379879 Selkirk Dec 2015 A1
20160078237 Tan Mar 2016 A1
20160105859 Zhu Apr 2016 A1
20160119414 Westaway et al. Apr 2016 A1
20160259508 Eccleston et al. Sep 2016 A1
20160308940 Procopio et al. Oct 2016 A1
20170249328 Liang et al. Aug 2017 A1
20180113862 Glover Apr 2018 A1
Foreign Referenced Citations (32)
Number Date Country
102342080 Feb 2012 CN
H06214743 Aug 1994 JP
H10187619 Jul 1998 JP
2002351730 Dec 2002 JP
2003157225 May 2003 JP
2003178015 Jun 2003 JP
2007500407 Jan 2007 JP
2008210192 Sep 2008 JP
2010517122 May 2010 JP
2010211569 Sep 2010 JP
2010218432 Sep 2010 JP
2011526034 Sep 2011 JP
2012038210 Feb 2012 JP
2012150647 Aug 2012 JP
2012519890 Aug 2012 JP
2012173780 Sep 2012 JP
2012209614 Oct 2012 JP
2013161481 Aug 2013 JP
2013196233 Sep 2013 JP
2014095960 May 2014 JP
2015505627 Feb 2015 JP
2015513713 May 2015 JP
20110124797 Nov 2011 KR
20150069397 Jun 2015 KR
WO-2005114383 Dec 2005 WO
2010100354 Sep 2010 WO
WO-2011109416 Sep 2011 WO
WO-2013109552 Jul 2013 WO
WO-2013109557 Jul 2013 WO
2014003781 Jan 2014 WO
WO-2014021031 Feb 2014 WO
WO-2015139179 Sep 2015 WO
Non-Patent Literature Citations (108)
Entry
Non-Final Office Action from U.S. Appl. No. 16/784,747, dated Oct. 15, 2020, 19 pages.
Notice of Allowance for Japanese Application No. 2019-036310 dated Oct. 16, 2020, 5 pages.
United States Office Action, U.S. Appl. No. 14/983,094, dated Sep. 6, 2018, 20 pages.
United States Office Action, U.S. Appl. No. 14/983,094, dated Feb. 8, 2018, 19 pages.
Examination Report No. 2 for Australian Application No. 2019257465 dated Dec. 18, 2020, 4 pages.
Notice of Allowance from U.S. Appl. No. 16/784,747, dated Feb. 9, 2021, 8 pages.
Examination Report No. 3 for Australian Application No. 20190257465 dated Oct. 22, 2020, 5 pages.
Final Office Action from U.S. Appl. No. 16/510,018, dated Oct. 27, 2020, 15 pages.
Anonymous: “Event (computing)—Wikipedia,” XP055728697, Apr. 3, 2014, retrieved from the Internet:URL:https://en.wikipedia.org/w/index.php?title=Event_(computing)&oldid=602539019 on Sep. 8, 2020, 5 pages.
Bishop J., et al., “Developing Principles of GUI Programming using Views,” Computer Science Education, ACM, Mar. 1, 2004, pp. 373-377.
Brief Communication of Oral Proceedings on Sep. 28, 2020 for European application No. 15736316.9 dated Sep. 16, 2020, 4 pages.
Bruce K.B., et al., “Event-Driven Programming Facilitates Learning Standard Programming Concepts,” Object-Oriented Programming Systems, Languages and Applications, ACM, Oct. 23, 2004, pp. 96-100.
Examination Report No. 1, for Australian Application No. 2019284033, dated Dec. 17, 2020, 5 pages.
Ganov S., et al., “Event Listener Analysis and Symbolic Execution for Testing GUI Applications,” Formal Methods and Software Engineering, Dec. 9, 2009, pp. 69-87.
Non-Final Office Action from U.S. Appl. No. 16/510,018, dated Mar. 19, 2021, 14 pages.
Advisory Action from U.S. Appl. No. 16/257,503, dated Apr. 21, 2021, 3 pages.
Examination Report No. 3 for Australian Application No. 2019257465, dated Mar. 23, 2021, 6 pages.
Examination Report. No. 2, for Australian Application No. 2019264563, dated Feb. 22, 2021, 4 pages.
Examination Report No. 2, for Australian Application No. 2019284033, dated Feb. 10, 2021, 6 pages.
Final Office Action from U.S. Appl. No. 16/257,503, dated Mar. 12, 2021, 22 pages.
Adahl J., “Shared Resource for Collaborative Editing Over a Wireless Network,” Master of Science Thesis, University of Gothenburg, Dec. 2010, 274 pages.
Advisory Action from U.S. Appl. No. 16/296,104, dated Apr. 14, 2020, 3 pages.
Anonymous, “c#—Is there Windows System Event on Active Window Changed?” Stack Overflow, Nov. 15, 2015, retrieved from https://web.archive.org/web/20151115134250/https://stackoverflow.com/questions/4407631/is-there-windows-system-eventon-active-wi ndow-changed on Mar. 25, 2019, 1 page.
Decision of Refusal for Japanese Application No. 2018-517385 dated Nov. 11, 2019, 7 pages.
European Summons to Attend Oral Proceedings Pursuant to Rule 115(1) EPC for EP Application No. 15736317.7 dated Oct. 24, 2019, 7 pages.
European Summons to Attend Oral Proceedings Pursuant to Rule 115(1) EPC for EP Application No. 16767369.8 dated Nov. 6, 2019, 8 pages.
European Summons to Attend Oral Proceedings Pursuant to Rule 115(1) EPC for EP Application No. 15736316.9 dated Oct. 24, 2019, 7 pages.
Examination Report No. 4, for Australian Application No. 2016381225, dated Nov. 28, 2019, 5 pages.
Examination Report for EP Application No. 15736316.9 dated Oct. 30, 2017, 5 pages.
Examination Report for EP Application No. 15736317.7 dated Oct. 30, 2017, 4 pages.
Examination Report No. 1, for Australian Application No. 2015246019, dated Apr. 11, 2019, 4 pages.
Examination Report No. 2, for Australian Application No. 2015246019, dated Jul. 10, 2019, 3 pages.
Examination Report No. 3, for Australian Application No. 2016381225, dated Sep. 2, 2019, 4 pages.
Examination Report No. 1 for Australian Application No. 2016381225 dated Feb. 28, 2019, 4 pages.
Final Office Action from U.S. Appl. No. 15/867,693, dated Jan. 28, 2020, 17 pages.
Final Office Action from U.S. Appl. No. 16/257,503, dated Jun. 25, 2020, 17 pages.
Final Office Action from U.S. Appl. No. 16/296,104, dated Feb. 19, 2020, 13 pages.
First Office Action for Australian Application No. 2015246020, dated Apr. 12, 2019, 4 pages.
First Office Action for Japanese Application No. 2018517385 dated Mar. 18, 2019, 5 pages.
First Office Action for Japanese Application No. 2018517385, dated Mar. 18, 2019, 5 pages (with English concise explanation of relevance) .
International Search Report and Written Opinion for PCT Application No. PCT/IB2015/052519 dated Jun. 18, 2015, 9 pages.
International Search Report and Written Opinion for PCT Application No. PCT/IB2015/052521 dated Sep. 24, 2015, 8 pages.
International Search Report and Written Opinion for PCT Application No. PCT/IB2015/052522 dated Jun. 18, 2015, 11 pages.
International Search Report and Written Opinion for PCT Application No. PCT/IB2015/052523 dated Sep. 24, 2015, 7 pages.
International Search Report and Written Opinion for PCT Application No. PCT/IB2016/055286 dated Oct. 31, 2016, 12 pages.
International Search Report and Written Opinion for PCT Application No. PCT/US2014/045631 dated Oct. 6, 2014, 14 pages.
Lim H., et al., “Ubi-Jector”, CHI 2013: Changing Perspectives, Paris, France, Apr. 27-May 2, 2013, pp. 1695-1700.
Non-Final Office Action from U.S. Appl. No. 14/983,847, dated Oct. 31, 2019, 14 pages.
Non-Final Office Action from U.S. Appl. No. 15/867,693, dated Sep. 17, 2019, 19 pages.
Non-Final Office Action from U.S. Appl. No. 16/115,563, dated Oct. 3, 2019, 8 pages.
Non-Final Office Action from U.S. Appl. No. 16/257,503, dated Feb. 14, 2020, 18 pages.
Notice of acceptance for Australian Application No. 2015246018 dated Oct. 21, 2019, 3 pages.
Notice of Acceptance for Australian Application No. 2016381225, dated Feb. 13, 2020, 3 pages.
Notice of Allowance from U.S. Appl. No. 14/983,847, dated Jan. 30, 2020, 10 pages.
Notice of Allowance from U.S. Appl. No. 16/115,563, dated Dec. 13, 2019, 7 pages.
Notice of Allowance for Japanese Application No. 2018517385, dated Mar. 27, 2020, 5 pages.
Notice of Reasons for Refusal for Japanese Application No. 2018-517385, dated Mar. 18, 2019, 7 pages.
Notice of Reasons for Refusal for Japanese Application No. 2019-036310 dated Mar. 16, 2020, 7 pages.
Notice of Reasons for Refusal of Japanese Application No. 2019-029541, dated Mar. 19, 2020, 4 pages.
Office Action for U.S. Appl. No. 14/248,158, dated Apr. 4, 2018, 16 pages.
Office Action for U.S. Appl. No. 14/248,158, dated Dec. 14, 2017, 19 pages.
Office Action for U.S. Appl. No. 14/248,158, dated Dec. 30, 2016, 12 pages.
Office Action for U.S. Appl. No. 14/248,158, dated Feb. 20, 2018, 4 pages.
Office Action for U.S. Appl. No. 14/248,158, dated Jun. 17, 2016, 15 pages.
Office Action for U.S. Appl. No. 14/248,158, dated Jun. 29, 2017, 17 pages.
Office Action for U.S. Appl. No. 14/248,158, dated Oct. 18, 2018, 15 pages.
Office Action for Australian Application No. 2015246018, dated Apr. 5, 2019, 6 pages.
Office Action for EP Application No. 16767369.8, dated Apr. 1, 2019, 7 pages.
Office Action for EP Application No. 16767369.8, dated Nov. 6, 2019, 8 pages.
Office Action for European Application No. 16767369.8 dated Apr. 1, 2019, 7 pages.
Office Action for Japanese Application No. 2016-553439 dated Oct. 19, 2018, 7 pages.
Office Action for Japanese Application No. 2016-553452 dated Oct. 19, 2018, 11 pages.
Office Action for Japanese Application No. 2016-553454 dated Nov. 16, 2018, 5 pages.
Office Action for U.S. Appl. No. 14/248,155 dated Jan. 23, 2017, 14 pages.
Office Action for U.S. Appl. No. 14/248,155 dated Jun. 12, 2017, 15 pages.
Office Action for U.S. Appl. No. 14/248,155 dated Jun. 7, 2016, 13 pages.
Office Action for U.S. Appl. No. 14/635,192 dated May 4, 2017, 12 pages.
Office Action for U.S. Appl. No. 16/195,607 dated Jun. 26, 2019, 6 pages.
Office Action for U.S. Appl. No. 16/296,104 dated Sep. 6, 2019, 13 pages.
Office Action from European Patent Application No. 15719292.3 dated Nov. 28, 2019, 13 pages.
Second Office Action for Australian Application No. 2016381225, dated May 10, 2019, 6 pages.
Second Office Action for Australia Application No. 2016381225, dated May 10, 2019, 6 pages.
Stack Overflow, “Is there Windows system event on active window changed?” Nov. 15, 2015, retrieved from https://web.archive.org/web/20151115134250/https://stackoverflow.com/questions/4407631/is-there-windows-system-event-on-active-window-changed on Mar. 25, 2019, 1 page.
Terry D.B., et al., “Managing Update Conflicts in Bayou, A Weakly Connected Replicated Storage System,” Proceedings of the 15th ACM Symposium on Operating System Principles, Dec. 3-6, 1995, pp. 172-183.
Wikipedia, “Concurrent Versions System,” Jun. 20, 2013, retrieved from the Internet URL: http://en.wikipedia.org/w/index.php?title=Concurrent_Versions_System&oldid=560712674 on Sep. 23, 2014, 9 pages.
Wikipedia, “Operational Transformation,” Last Modified Oct. 28, 2013, Retrieved from the Internet URL: http://en.wikipedia.org/wiki/Operational—transforma- tion on Jan. 6, 2014, 8 pages.
Wikipedia, “Rsync,” Jun. 26, 2013, Retrieved from the internet URL:http://en.wikipedia.org/w/index.php?title=Rsync&oldid=561- 668126 on Sep. 23, 2014, 8 pages.
Non-Final Office Action from U.S. Appl. No. 16/296,104, dated Jul. 22, 2020, 13 pages.
Non-Final Office Action from U.S. Appl. No. 16/510,018, dated Jul. 23, 2020, 19 pages.
Non-Final Office Action from U.S. Appl. No. 16/560,901, dated Aug. 5, 2020, 7 pages.
Notice of Allowance from U.S. Appl. No. 15/867,693, dated Jul. 28, 2020, 9 pages.
“Document Object Model Events,” retrieved from https://web.archive.org/web/20120218183544/http:/ /www.w3.org/TR/DOM-Levei-2-Events/events.html, Feb. 18, 2012, 23 pages.
Examination Report No. 1, for Australian Application No. 2019264563, dated Nov. 10, 2020, 6 pages.
“Listeners Supported by Swing Components,” retrieved from https:/ /web.archive.org/web/20131010082743/http:/ /docs.oracle.com/javase/tutorial/uiswing/events/eventsandcomponents.html, Oct. 10, 2013, 3 pages.
Notice of Allowance from U.S. Appl. No. 15/867,693, dated Aug. 13, 2020, 2 pages.
Notice of Allowance from U.S. Appl. No. 15/867,693, dated Aug. 21, 2020, 2 pages.
Notice of Allowance from U.S. Appl. No. 16/560,901, dated Nov. 27, 2020, 8 pages.
Final Office Action from U.S. Appl. No. 16/296,104, dated Oct. 1, 2020, 12 pages.
Non-Final Office Action from U.S. Appl. No. 16/257,503, dated Oct. 1, 2020, 16 pages.
Notice of Allowance from U.S. Appl. No. 16/560,901, dated Sep. 14, 2020, 8 pages.
Notice of Allowance from U.S. Appl. No. 16/560,901, dated Sep. 24, 2020, 5 pages.
Notice of Allowance for Japanese Application No. 2019-124719, dated Oct. 5, 2020, 5 pages.
Notice of allowance of Japanese Application No. 2019-080438, dated Jun. 1, 2020, 5 pages.
Notice of allowance of Japanese Application No. 2019-029541, dated Jun. 8, 2020, 5 pages.
Notice of Acceptance for Australian Application No. 2019257465, dated Jun. 22, 2021, 3 pages.
Notice of Acceptance for Australian Application No. 2019284033 dated May 20, 2021, 3 pages.
Notice of Allowance from U.S. Appl. No. 16/257,503, dated Jul. 1, 2021, 16 pages.
Notice of Reasons for Refusal for Japanese Application No. 2020-113157 dated Jun. 14, 2021, 7 pages.
Related Publications (1)
Number Date Country
20190180242 A1 Jun 2019 US
Continuations (1)
Number Date Country
Parent 14983094 Dec 2015 US
Child 16280845 US