SYSTEMS AND METHODS FOR MANAGING TASKS
Systems and methods for creating and sharing tasks over one or more networks are disclosed. In one embodiment, a system comprises a message retrieval module configured to retrieve electronic messages and parse them into a plurality of tasks. The system can also include a task creation module configured to process the message to identify task information and one or more task recipients. The task creation module can also be configured to create a task based on the identified task information. A task notification module can be configured to notify the one or more task recipients about the created task. The system may also include a multi-layer network management module configured to organize the tasks and task participants into multiple networks and clouds and into a federation of clouds. The system can also include a task analytics module programmed to analyze the tasks performed by users of the system.
Latest BroadVision, Inc. Patents:
This application is a continuation of U.S. patent application Ser. No. 13/758,831, filed Feb. 4, 2013, entitled “SYSTEMS AND METHODS FOR CREATING AND SHARING TASKS,” which claims the benefit of U.S. Provisional Patent Application No. 61/756,398, filed Jan. 24, 2013, entitled “SYSTEMS AND METHODS FOR CREATING AND SHARING TASKS,” each of which is hereby incorporated by reference herein in its entirety and for all purposes.
BACKGROUND1. Field of the Invention
The present invention relates to systems and methods for creating and sharing tasks across one or more networks.
2. Description of the Related Art
Global communications networks have enabled users to collaborate on projects, whether the collaborating users are located near one another or are separated by thousands of miles. Users can collaborate over one or more networks using real-time communications tools (e.g., voice communications and online real-time messaging) or using time-delay communications tools (e.g., e-mail). When collaborating on projects, there may be various tasks that need to be accomplished according to a particular timeline. Further, it may be desirable to assign different tasks to different users that are connected over the one or more networks. Because the users may be physically or temporally separated from one another, it can be difficult to efficiently manage the various tasks that are required for a project.
Furthermore, some projects and tasks may be performed by users within a company or organization. In other circumstances, however, it may be desirable for a task to be performed by users that may be members of different companies or organizations, or that may be unaffiliated with any particular company or organization.
However, for tasks that include multiple users and assignments, it can be difficult to create and manage the tasks over one or more communications networks. Conventional electronic mail (e-mail) systems can be used to communicate with multiple users. However, e-mail alone may not adequately create a virtual environment where users are accountable for accomplishing their assigned tasks according to the desired task schedule. Sending an e-mail to a group of users does not of itself indicate that the recipient(s) agree to, or are able to, perform the assigned task(s) according to the desired timeline.
Furthermore, in e-mail systems, it can be difficult to share content data and manage task assignments in real-time. For example, when one user updates a spreadsheet with new data, the other users cannot readily see the updates unless the user re-sends the spreadsheet to all the users. When multiple documents are being created and edited by multiple users, the back-and-forth nature of e-mail can create confusion, as users may be unsure which version of a document is the most updated or which assignments are being performed by which users. In addition, the back-and-forth nature of e-mail can create confusion as to whether and when assignments have been accomplished and may not adequately ensure that the task assignments are being completed according to the desired schedule.
SUMMARYThe systems, methods and devices of the present disclosure each have several innovative aspects, no single one of which is solely responsible for the desirable attributes disclosed herein.
In one embodiment, a method in a server for sharing content over one or more networks with a plurality of users is disclosed. The method can comprise receiving a message from a task creator. Further, the method can include processing the message to identify task information and one or more task recipients. In addition, a task can be created based on the identified task information. The one or more task recipients can be notified about the created task.
In another embodiment, a system for sharing content over one or more networks is disclosed. The system can include a message retrieval module programmed to receive a message from a task creator. The system can further include a task creation module programmed to process the message to identify task information and one or more task recipients. The task creation module can also be programmed to create a task based on the identified task information. The system can include a task notification module programmed to notify the one or more task recipients about the created task.
In yet another embodiment, a non-transitory computer-readable medium is disclosed. The non-transitory computer-readable medium can have stored thereon code that when executed performs a method comprising receiving a message from a task creator. The method can include processing the message to identify task information and one or more task recipients. Further, the method can comprise creating a task based on the identified task information. The one or more task recipients can be notified about the created task.
In one embodiment, a system programmed to support one or more networked networks is disclosed. The system can comprise a task management module programmed to organize a plurality of tasks and a plurality of task participants associated with the plurality of tasks. The system can further include a multi-layered network management module programmed to organize the plurality of tasks into a plurality of networks based at least in part on a network identifier associated with each task. The multi-layered network management module can be programmed to organize the plurality of networks into a plurality of clouds based at least in part on affiliations among the plurality of networks. The multi-layered network management module can be programmed to organize the plurality of clouds into a federation of clouds based at least in part on interactions among the plurality of clouds.
In another embodiment, a method for organizing one or more networks is disclosed. The method can comprise sorting a plurality of tasks and a plurality of task participants associated with the plurality of tasks. Further, the plurality of tasks can be organized into a plurality of networks based at least in part on a network identifier associated with each task. The plurality of networks can be organized into a plurality of clouds based at least in part on affiliations among the plurality of networks. The plurality of clouds can be organized into a cloud federation based at least in part on interactions among the plurality of clouds.
In one embodiment, a computer-implemented method for analyzing task data associated with a plurality of tasks and a plurality of task participants is disclosed. The method can include identifying the plurality of task participants. The method can also comprise associating the plurality of task participants with the plurality of tasks. Task data associated with the tasks and the task participants can be aggregated. The aggregated task data can be analyzed.
In another embodiment, a system for analyzing task data associated with a plurality of tasks and a plurality of task participants is disclosed. The system can comprise a task analytics module programmed to identify the plurality of task participants. The task analytics module can be programmed to associate the plurality of task participants with the plurality of tasks. Further, the task analytics module can be programmed to aggregate task data associated with the tasks and the task participants. The task analytics module can be programmed to analyze the aggregated task data.
In one embodiment, a computer-implemented method for managing computer objects stored on a system of one or more networks is disclosed. The method can comprise providing a graphical user interface that lists a plurality of computer objects, wherein each object comprises content. Further, the method can include associating each computer object with one or more authorized users. A status can be assigned to each computer object that indicates the status of that computer object within the system. The assigned status can be indicated on the graphical user interface to each of the authorized users associated with the computer object.
In another embodiment, a system for managing a plurality of computer objects stored on one or more networks is disclosed. The system can comprise an object management module programmed to associate each computer object with one or more authorized users, each computer object comprising content. The object management module can be programmed to assign a status to each computer object that indicates the status of that computer object within the system. The system can also comprise an integrated interface module programmed to provide a graphical user interface that lists the plurality of computer objects. The integrated interface module can be programmed to indicate the assigned status on the graphical user interface to each of the authorized users associated with the computer object.
In one embodiment, a computer-implemented method for managing tasks is disclosed. The method can comprise identifying a new task to be shared by a plurality of users in a computer memory. One or more users can be invited to share the new task. The method can further include receiving an acceptance of the new task from the one or more users. The one or more users that accepted the new task can be associated with private task information. A status can be assigned to the new task based on the stage of completion of the new task by the one or more associated users. The method can include organizing the new task and a plurality of other tasks into a network of tasks based at least in part on a network identifier associated with the new task.
In another embodiment, system having one or more processors and configured for managing tasks is disclosed. The system can comprise a task management module configured to run on the one or more processors and programmed to identify a new task to be shared by a plurality of users. The task management module can also be programmed to invite one or more users to share the new task. Further, the task management module can be programmed to receive an acceptance of the new task from the one or more users. The task management module can be programmed to associate the one or more users that accepted the new task with private task information. In addition, the task management module can be programmed to assign a status to the new task based on the stage of completion of the new task by the one or more associated users. The system can further include a multi-layered network management module configured to run on the one or more processors and programmed to organize the new task and a plurality of other tasks into a network of tasks based at least in part on a network identifier associated with the new task.
In yet another embodiment, a non-transitory computer-readable medium is disclosed. The computer-readable medium can have stored thereon code that when executed by a processor performs a method. The method can comprise identifying a new task to be shared by a plurality of users. The method performed by the processor can also include inviting one or more users to share the new task. Further, the method can include receiving an acceptance of the new task from the one or more users. The one or more users that accepted the new task can be associated with private task information. The method can also include assigning a status to the new task based on the stage of completion of the new task by the one or more associated users. The new task and a plurality of other tasks can be organized into a network of tasks based at least in part on a network identifier associated with the new task.
Details of one or more implementations of the subject matter described in this specification are set forth in the accompanying drawings and the description below. Other features, aspects, and advantages will become apparent from the description, the drawings, and the claims. Note that the relative dimensions of the following figures may not be drawn to scale.
Specific embodiments of the invention will now be described with reference to the following drawings, which are provided by way of example, and not limitation.
The following detailed description of certain embodiments presents various descriptions of specific embodiments of the invention. However, the invention can be embodied in a multitude of different ways as defined and covered by the claims. In this description, reference is made to the drawings where like reference numerals indicate identical or functionally similar elements.
Embodiments of the invention relate to systems and methods for sharing content and managing tasks within and between networks. For example, a company or organization may set up one or more communications networks to connect its employees to one another. The employees of the company or organization may participate in various projects, and each project can include one or more tasks. When a project needs to be completed, embodiments of the invention can automatically setup and schedule multiple tasks between users. These tasks can be assigned to multiple employees to complete over a predetermined timeline or schedule. As described herein, the tasks can be created and assigned over the one or more communications networks, and task content data can be shared among the employees across the network(s). Tasks can be very short term tasks, such as completing a letter, or longer term tasks, such as completing a series of laboratory experiments or designing a new product. Any type of scheduled event managed by one or more parties can be used within embodiments of the system to track and manage their progress towards task completion. In addition to managing tasks to be performed by task participants, the system can also manage and organize documents associated with the tasks and task participants. The system can employ a user interface to share documents among task participants and can ensure that task participants are accountable for tasks that they are assigned to complete.
For example, a user Bob may wish to schedule a task to be completed by Alice and Mary. Using embodiments of the invention, Bob would send an e-mail message with a specific subject line to Alice and Mary asking them to perform the task. In the email message, Bob would copy a specific email address of a task management system. The task management system would receive the email from Bob and first identify that Alice and Mary are all part of the same task group as Bob, based on header information in the email message, such as user e-mail addresses. In addition, the task management system would review the subject line and parse the text of the email message to determine the subject, or type of task to be created. In an alternate embodiment, the system may look for keywords or a specific formatting of text or fields within the e-mail message to determine the type of task, name of task, and due date for completion.
Once the task management system has identified the parties and the task to be completed, a record is created in the task management system corresponding to the new task. This record would include information regarding the task, its timeline for completion, and the parties that are involved in working on the task. In one embodiment, the system tracks the subject line of the message and the sending party, and if other messages from the same party, with the same subject line, are sent, they can also be posted to the same newly created task. This allows the system to move messages from the originator, and also other individuals in the email, into a chat page within the task management system.
After the record has been created, the task management system, in one embodiment, may send out a link to a webpage that manages that task and any communication between the parties regarding the task. For example, the task management system may create an electronic chat room specific to the task so that the parties can review and post messages regarding the task that do not need to circulate through email. The webpage may also display a calendar of due dates or milestones for the project, and also allow authorized individuals associated with the task to modify task parameters or add/remove individuals from the task. By removing the task from being managed by email communication between all the parties, the parties can efficiently communicate and manage completion of their task in a far more efficient manner.
It should also be realized that the task management system is not limited to only communicating to parties through a web interface or electronic chat room, and that certain parties could indicate within the system that they prefer to be notified of new task messages or changes by way of email, text or other mode of communication.
Moreover, in certain embodiments, users within a company or organization may wish to share content and/or collaborate on tasks with users outside of the company or organization. And thus, there is no limitation on Bob, Alice and Mary being part of the same organization. The task management system can be configured to setup new tasks for multiple users across one to many organizations without departing from the spirit of the invention.
In one embodiment, the system is configured to store party preferences and can thus, for example, predefine deadlines for certain parties. Thus, any email from Bob that starts a new task can automatically be scheduled to be completed within two days. In addition, the task management system can be configured to store and monitor activities of the parties and set task schedules based on past preferences and settings by a party. Thus, by knowing that Bob always sets two day deadlines for his tasks, the system can monitor and review that information and automatically being to default all of Bob's tasks to have two day deadlines.
In addition, embodiments of the system include a robust status monitoring and user management system for monitoring and reporting on the status of tasks that are being performed by the parties. For example, a manager can review status reports indicating all those employees under his management and determine which employee is completing their tasks on time, which employees are completing their tasks within several days of the deadline, and which employees are habitually late in completing assignments. Because the task management system stores data relating to start time the task was initiated, the scheduled due date, and the progress made towards completion by each party to the task, the system can generate management reports that are very useful in managing the work requirements for each employee. Further, in various embodiments, the task management system can assist managers in monitoring the productivity of employees. For example, the system can monitor the efficiency of each employee, e.g., the time it takes each employee to complete a task. Further, the system may monitor the productivity based on feedback given by other task participants.
In addition, because the task management system tracks external tasks, such as from customers, vendors and collaborators, the system is configured to track which outside individuals are most closely working with the company. For example, an engineering company may work with dozens of outside vendors, but not have an easy mechanism for rating how well each vendor is providing service. By placing the vendor's projects within the task management system, the company can then track and report on which vendors are providing timely service and which vendors are late or do not complete service as expected. In addition, the system can also monitor and report on the length of time each vendor is taking to complete particular projects and their associated cost. Further, the task management system may monitor the quality of each vendor's services or products based on feedback given by other task participants or by third parties. By monitoring this information in the task management system, the company can gain insight on which vendor is actually providing high quality, timely service, at the agreed-upon price. In various other embodiments, the task management system can monitor the customers of a company, such as by monitoring how frequently each customer interacts with the company or participants in a task with employees of the company. For example, customers that interact frequently with the company may be prioritized by the company, because the company may desire to focus their efforts and resources on current, fresh customers and contacts, rather than older, stale customers and contacts.
In various embodiments, the task management system can facilitate task collaborations in a multi-layered network environment. For example, in a first layer, the system can enable collaboration on tasks within a particular user group or department of a company, such as the company's engineering group. In various embodiments, a company or organization can be a user group. In a second layer, the system can enable collaboration across user groups or departments within the company. In a third layer, the system can facilitate communications and collaborations among users in different companies or organizations. The system may also regulate communications and collaborations between different groups of companies, such as groups of companies within various geographic or political divisions. For example, access controls can be established to facilitate task collaborations between users associated with organizations in different countries.
In yet other embodiments, the task management system can include a task analytics module or system that enables users to spawn networks within their own companies or organizations and that enables organizations to analyze relationships associated with tasks performed by members of the organization. Indeed, because the task management system can monitor the e-mail and/or network IDs of the users that utilize the system, the task management system can sort the system users and task participants according to organizations and/or companies with which they are affiliated. As users of new organizations or companies are invited to participate in tasks with current users, the task management system can enable the newly added or invited users to create, or spawn, their own networks within their company or organization. For example, one embodiment is a people-relationship map that is generated to allow managers of a company to view the relationships of people in their organization with others. In this embodiment, the system tracks ongoing projects between different individuals within, and outside of, a company and can map those relationships. This allows the system to create graphs and maps of relationships that can be used to determine who is currently working with particular individuals, the scope of work being performed, and who is completing and performing their tasks in a timely manner.
For example, if Rose, a current system user affiliated with Company X, collaborates with Sue, a non-user of the task management system affiliated with Company Y, on a particular task, then Sue may become a new user of the task management system. As the authorized users of Company Y are added to the global network, Sue's contacts and collaborators can leverage the members of Company Y in any tasks in which they collaborate with Sue or any other employees of Company Y. Thus, if Company X and Company Y are collaborating on a new product design, an engineering team member of Company X can utilize the expertise of the marketing team of Company Y to improve sales of the new design. By providing multiple layers of networks that connect users across different organizations and companies, the task management system can advantageously leverage the expertise of users across multiple organizations and companies.
Indeed, the embodiments disclosed herein enable users to spawn their own networks and create their own intra-organization and/or inter-organization relationships. As explained herein, new users may be invited into the disclosed task management system, for example, by e-mail, and may participate in many types of tasks in the system. Once a new user joins the task management system, the user may create or join their own company or intra-organization network that provides a platform and security for task or object management within the organization. In some arrangements, the user-created network can also include an association of companies. By upgrading a new user's individual network to a company- (or association of companies) or organization-wide network, new networks and relationships can be created between different companies or organizations, as explained herein with respect to FIGS. 1 and 8A-8B, for example. As with real world relationships between companies and between individuals in different companies, the disclosed systems can thereby automatically create new networks and connections between companies and individuals by automatically recognizing common users or contacts.
In various embodiments, a task analytics dashboard, or user interface, can be presented to company- or organization-level executives or managers. The dashboard can include various pages that illustrate user productivity and user relationships, as well as project data and topic data. The dashboard can analyze task data that is aggregated by the task management system and can be presented to a decision-maker to assist in making decisions. For example, in some embodiments, the dashboard can help decision-makers with internal personnel or task assignment decisions. In addition, the dashboard can help decision-makers with high-level decisions regarding competitors, business partners, the future direction of a particular product line, etc.
Furthermore, in various embodiments, each user (e.g., task participant) can be presented with a user inbox-outbox interface. The user inbox-outbox interface can list multiple objects that are associated with the user. For example, as used herein, an object may refer to a task, a message, a document, etc. The objects can be stored on one or more servers accessible by various authorized users. The stored objects can be modified by the authorized users such that a persistent copy of the objects can always be available to each authorized user. Furthermore, the stored objects may be presented in a centralized interface accessible by the authorized users, such as on a webpage.
For example, a document stored on one or more servers may be created by User 1, edited by User 2, and edited again by User 1 (or another user). The document may be presented as a single object to each authorized user so that only one version of the object (e.g., the document in this example) is viewed and manipulated by the authorized users. Similarly, a message from User 2 to User 1 can be presented in the inbox of User 1 and the outbox of User 2. If User 1 replies to User 2 or forwards the original message to User 3, the message object may nevertheless appear as a persistent object in the User 1's, User 2's, and User 3's respective inbox-outbox interfaces. Users 1, 2, and 3 can therefore transmit and receive multiple messages using the same persistent object in a convenient and intuitive interface.
In addition, tasks may be presented in a user's inbox-outbox interface. For example, Task 1 that is created by User 1 and assigned to User 2 may appear in User 1's outbox and in User 2's inbox. The inbox-outbox interface can present the schedule for completing the task, such as the timeline for completing each step of the task. Further, the inbox-outbox interface can display the status of the task. For example, the interface can indicate whether the task is assigned, pending, or completed. Other status types may also be possible. An assigned task may be a task that has been assigned by the task creator to the task recipient(s), but that has not yet been accepted by the task recipient(s) and/or not yet begun by the task recipient(s). A pending task may be a task that has been accepted by the task recipient(s) but that is currently being performed by the task participants. A completed task may be a task that has been fully performed by the task participants. The inbox-outbox interface may also sort the tasks by status, such that tasks that are to be performed by the user are presented before tasks that are to be performed by another user. Further, the inbox-outbox interface may sort the tasks by due date, such that tasks that are due sooner are presented before tasks that are due later.
As with documents and messages, the tasks stored on the server(s) and presented in the inbox-outbox interface may be updated by the authorized users (e.g., task participants). Authorized users may be notified when the objects are updated. For example, when one user has begun a task, the user may update the task status to “pending.” Similarly, when a user completes a task, the user can update the task status to “completed.” These updated task statuses may be presented to other authorized users on their respective inbox-outbox interfaces. Furthermore, the inbox-outbox interface can indicate the date and/or time that various actions have been taken and by whom. The inbox-outbox interface can therefore act as a common interface that holds all authorized users or task participants accountable for their assigned responsibilities and ensures that the task timelines are followed. Thus, the inbox-outbox interface may also serve as a persistent interface for storing and editing tasks, in addition to documents and messages. Moreover, the inbox-outbox provides a centralized real-time platform for knowing the status of all ongoing tasks by the authorized users.
Communications platforms, such as the Clearvale systems developed by BroadVision, Inc., of Redwood City, Calif., may be used to implement some or all of the embodiments disclosed herein. Various details of the Clearvale system have been described in U.S. Patent Publication No. US 2011/0282944, filed May 12, 2011, and published on Nov. 17, 2011, which is hereby incorporated by reference herein in its entirety and for all purposes. In various embodiments, the embodiments described herein may be implemented over the Internet.
DEFINITIONSAs used herein, an input device can be, for example, a keyboard, rollerball, mouse, voice recognition system or other device capable of transmitting information from a user to a computer. The input device can also be a touch screen associated with the display, in which case the user responds to prompts on the display by touching the screen. The user may enter textual information through the input device such as the keyboard or the touch-screen.
Embodiments of the invention are operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well-known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
As used herein, instructions refer to computer-implemented steps for processing information in the system. Instructions can be implemented in software, firmware or hardware and include any type of programmed step undertaken by components of the system.
A Local Area Network (LAN) or Wide Area Network (WAN) may be a corporate computing network, including access to the Internet, to which computers and computing devices comprising the system are connected. In one embodiment, the LAN conforms to the Transmission Control Protocol/Internet Protocol (TCP/IP) industry standard.
As used herein, media refers to images, sounds, video or any other multimedia type data that is entered into the system.
A microprocessor may be any conventional general purpose single- or multi-chip microprocessor such as a Pentium® processor, Itanium® processor or an ALPHA® processor. In addition, the microprocessor may be any conventional special purpose microprocessor such as a digital signal processor (DSP) or a graphics processor.
The system is comprised of various modules as discussed in detail below. As can be appreciated by one of ordinary skill in the art, each of the modules comprises various sub-routines, procedures, definitional statements and macros. Each of the modules are typically separately compiled and linked into a single executable program. Therefore, the following description of each of the modules is used for convenience to describe the functionality of the preferred system. Thus, the processes that are undergone by each of the modules may be arbitrarily redistributed to one of the other modules, combined together in a single module, or made available in, for example, a shareable dynamic link library.
The system may be used in connection with various operating systems such as LINUX, UNIX or MICROSOFT WINDOWS®.
The system may be written in any conventional programming language such as C, C++, BASIC, Pascal, Perl, or Java, and run under a conventional operating system.
A web browser comprising a web browser user interface may be used to display information (such as textual and graphical information) to a user. The web browser may comprise any type of visual display capable of displaying information received via a network. Examples of web browsers include Microsoft's Internet Explorer browser, Apple's Safari Browser, Mozilla's Firefox browser, Google's Chrome browser or any other browsing or other application software capable of communicating with a network. Further, information may also be configured for and displayed in other suitable applications, such as applications programmed for implementation in mobile devices, such as mobile phones or other mobile computing devices.
The invention disclosed herein may be implemented as a method, apparatus or article of manufacture using standard programming or engineering techniques to produce software, firmware, hardware, or any combination thereof. The term “article of manufacture” as used herein refers to code or logic implemented in hardware or computer readable media such as optical storage devices, and volatile or non-volatile memory devices. Such hardware may include, but is not limited to, field programmable gate arrays (FPGAs), application-specific integrated circuits (ASICs), complex programmable logic devices (CPLDs), programmable logic arrays (PLAs), microprocessors, or other similar processing devices.
System OverviewEach network 105 can be, for example, a company intranet or support Website hosted on one or more servers. The users 102 can be members of the network 105, and can interact with the network 105 using a user interface (UI) through a device such as a computer, tablet, personal digital assistant (PDA) and/or mobile phone. Each user can be prompted for a password before logging into the network 105 in some embodiments. In other arrangements, however, each network 105 can be accessed over the World Wide Web. The global network 100 can include all associated users 102. Each user 102 of the global network 100 may belong to one or more individual networks 105, or may only belong to the global network 100 and not to any particular individual network 105. If a user 102 is a member of a particular individual network 105, the user 102 can log in to the network 105, create a task 104 in the network 105, and assign the task 104 to network users 102. Alternatively, a user 102 may create tasks 104 in the global network 100 and assign the task 104 to the user's contacts. A particular task 104 may be created in and may belong to a particular network 105. As explained herein, a network identifier, or network ID, can associate a task 104 with a particular network 105, or with the global network 100.
In the global network 100 of
Each of the users 102 of the global network 100 shown in
The multiple users 102 may collaborate with each other on a variety of tasks 104. As shown in
The illustrated Task 2 may also be associated with Network 1. For example, Task 2 may be assigned to User 3, User 4, and User 5, all of whom are within Network 1, e.g., associated with Company A, whether by being employees of Company A or by being associated with colleagues that are employees of Company A. As an example, User 4 and User 5 may be members of Company A's marketing department. User 4 and User 5 may collaborate with User 3 on Task 2 to integrate the final product design into Company A's marketing materials. Turning to Task 3, User 1, User 6, and User 7 may collaborate on Task 3 entirely within Network 2, e.g., only with users 102 that are employees of Company B, the printing company, or that are associated with employees of Company B. In this example, User 6 and User 7 may be employees of Company B, while User 1 (an employee of Company A) may have collaborated on various projects in the past with User 7. For example, Users 1, 6, and 7 may collaborate on Task 3 to print technical specification booklets of the new product to be delivered for Company A's product release banquet. As with Tasks 1 and 2, Task 3 may be performed by users 102 that are located entirely within their respective networks, e.g., by users within the same company or organization, or users that are associated with other users that are members of the same company or organization.
Task 4 illustrates a task 104 that may be performed by users 102 that are located within different networks 105, e.g., by users 102 located within Networks 1 and 2. For example, User 1, User 2, and User 3 from Network 1 may collaborate with User 6 from Network 2 on Task 4 to organize various details of Company A's product release banquet, e.g., collaborating on high-quality product display boards to be set up for the banquet. Because the users collaborating on Task 4 are not necessarily members of the same individual network 105, Task 104 may be performed within the global network 100.
Similarly, Task 5 is a task 104 that may be performed by users 102 across multiple networks 105, e.g., by users 102 located within Network 1 (User 5), Network 2 (Users 6 and 7), and users unaffiliated with a particular individual network 105 (User 8, the banquet facility owner). For example, User 5 from Network 1 may collaborate with Users 6 and 7 from Network 2 and unaffiliated User 8 from the global network 100 on Task 5 to organize the delivery and set up of the marketing and promotional materials in the banquet facilities owned by User 8. Thus, as shown in the global network 100 of
One embodiment of a system for managing tasks is shown in
As used herein, the task creator 211 can be a user that initiates the task 204, and the task recipient(s) 214 can be user(s) that are assigned to, or requested to be assigned to, the task 204. Both the task creator 211 and the task recipient(s) 214 can be task participants, because they all may participate in the completion of the task 204. In some cases, however, a task recipient 214 may decline to participate in the task 204 and may therefore not be considered a task participant.
The task creation packet 213 can also include a task recipients entry 221 that includes information that identifies one or more recipients 214 of the task. For example, the task recipients entry 221 can include the name and/or username of the task recipients 214. The task recipients entry 221 can also include a network or e-mail address of the task recipients 214. While multiple task recipients 214 are shown in
The task creation packet 213 can also include task content data 223. The task content data 223 can include details of the task 204, such as the overall goals and objectives of the task 204. The task content data 223 can also include a listing of the task assignments that are assigned to each user associated with the task 204. Further, the task content data 223 can include a task schedule that manages the progression of the task 204. The task content data 223 can also include various accountability measures, such as a schedule of reminder notification that can be sent to the task participants to remind them of their assignments.
The task creation packet 213 can also include a server address field 222. The server address field 222 can include a network ID of the server 215. The network ID may be used at run time to identify whether the user logs in to a specific network 105 or to the global network 100 (
The task creation packet 213 can be implemented in any suitable format. In one embodiment explained herein, the task creation packet 213 can be implemented in an e-mail message. However, in other embodiments, the task creation packet 213 can be implemented in other formats or using other structures. For example, the task creation packet 213 can be implemented in a website. In other arrangements, the task creation packet 213 can be implemented in a text message (e.g., an SMS message), a voice communication, or a video communication. In such arrangements, the task creator 211 initiates the task 204 by composing an SMS message, a voice communication, or a video communication that outlines the details of the task, the task assignments, and/or the task schedule.
The e-mail task creation packet 220 of
The task creator entry 219 can correspond to the “From” field of the e-mail message. Thus, the task creator 211 can initiate the task 204 by opening a new e-mail message using the task creator's 211 own e-mail account. In the example of
The task content data 223 can correspond to data within the e-mail message field. For example, task objectives and task schedules can be listed in text or image data within the message field of the e-mail. As shown in the example of
Thus, the task creation packet 213, which can correspond to an e-mail task creation packet 220, can be sent by e-mail from the task creator 211 to the task recipients 214 and to the server 215. The packet 220 can include task identifying information as well as task content data which can be viewed by the task participants. As explained below in more detail, the server 215 can receive and process the task creation packet 213, and can perform various other task management functions. For example, the server 215 can coordinate scheduling and accountability for performance of the tasks 204 and can also process and analyze data about the users, e.g., the task participants.
The object management module 346 can be configured to manage computer objects shared over one or more networks. Examples of such objects include tasks, documents, messages, etc. For example, in some embodiments, the object management module can include instructions to associate each computer object with one or more authorized users and to assign a status to each computer object that indicates the status of that computer object within the system. In various embodiments, the object management module 346 can include instructions to receive a plurality of objects that include object content associated with the object, associate objects with one or more authorized users, assign an object status to each object, process update data for the objects, and update the objects according to the processed update data. As explained herein with reference to
The user interface module 341 can include various modules for processing, sorting, and displaying task information. In some implementations, for example, the task information, e.g., information about the task and task assignments, can be shared among the task participants using the user interface module 341. The user interface module 341 can include a task assignment module 343. The task assignment module 343 can be configured to assign portions or divisions of the task to one or more task participants associated with the task. For example, referring back to the examples of
The user interface module 341 can also include a task scheduling module 349. The task scheduling module 349 can be configured to provide a schedule for performance of the task. For example, the task scheduling module 349 can store information about the overall timeline for completion of the task. Further, the task scheduling module 349 can be configured to notify task participants with reminders about due dates for completing their assigned portions of the tasks. The task scheduling module 349 can also request confirmation of receipt of instructions for participants' assigned portions of the task. By reminding participants about their task obligations, the task scheduling module 349 can thereby increase accountability for participating users and can improve the coordination among task participants.
In addition, the user interface module 341 can include a content distribution module 345. The content distribution module 345 can be configured to share various types of content. For example, the content distribution module 345 can be configured to share a document (such as a text or word processing document), a digital video, a blog entry, or a forum post with one or more tasks participants associated with the task. Task participants can work on common documents, such as common word processing documents, presentation files, or spreadsheets. The task participants can edit the documents and can save the updates to the task management system 315. By providing a central content distribution module 345, documents can be easily edited such that confusion regarding version control and user assignments is minimized.
The user interface module 341 can also include a user collaboration module 351. The user collaboration module 351 can be configured to facilitate communication among the one or more task participants associated with the task. For example, in some arrangements, the user collaboration module 351 can include instant electronic messaging systems to allow task participants to communicate with one another in real-time. In other arrangements, the user collaboration module 351 can include real-time video and/or voice communications modules to enable participants to visually and/or verbally communicate with one another. The task management system 315 can thereby provide a central workspace and task management center that enables multiple task participates to effectively perform their assigned task elements.
The user interface module 341 can comprise a graphical interface module 347 configured to render task information for display on a user device. For example, the various modules of the user interface module 341 can be presented on a website hosted on the World Wide Web. Users can interact with the task management system 315 using various input devices to post content on the task management system 315, including documents, messages to other task participants, and any other data that can be used in the performance of a task. As explained herein with respect to
Furthermore, the user interface module 341 can include an integrated interface module 348 that may be programmed to incorporate the functionalities of the other modules of the user interface module 341 and that can be programmed to implement a user inbox-outbox interface, such as an interface implemented on a webpage. For example, the integrated interface module 348 may include instructions to provide a graphical user interface that lists the plurality of computer objects and to indicate the assigned status on the graphical user interface to each of the authorized users associated with the computer object. As described herein with reference to
The task management system 315 can further comprise a communications module 353 configured to provide communication among the task participants. The communications module 353 can comprise a message retrieval module 355 that is configured to receive a message from the task creator. As explained above with respect to
The communications module 353 can also comprise a notification module 357 configured to notify the task participants, e.g., the task creator and/or the task recipients, that the task has been created. The notification module 357 can further be configured to send reminder notices and confirmation notices to the task participants. In various embodiments, the notification module 357 can send such notices to the participants using e-mail.
The task management system 315 can also comprise a user management module 359 configured to process a plurality of tasks (and task initiation messages). The user management module 359 can identify task participant information for the plurality of tasks and can sort the task participant information according to desired sorting criteria. In general, the user management module 359 can gather and sort information about the users that participate in tasks processed by the task management system 315. The user management module 359 can analyze information about the users associated with the tasks in order to identify the users that are most active and/or most valuable to the owner and/or operator of the task management system 315.
For example, in some arrangements, the user management module 359 can analyze task participant information for each task participant or user to determine the number of tasks associated with the task participant or user. Further, the user management module 359 can analyze task participant information for each task participant or user to determine the frequency with which each user or participant interacts with the task management system 315 or participates in a task. By analyzing the number and frequency of interactions with the task management system 315, the user management module 359 can identify the most valuable users associated with the task management system 315. Operators and/or owners of the server can thereby use the information processed by the user management module 359 to identify the most valuable and/or current users of the server. The server operators and/or owners can in turn tailor advertisements, promotions, or other opportunities to the users that are most valuable to the operator and/or owner. As just one example, if User 1 has participated in ten tasks over the past month, while User 2 has participated in only two tasks over the past year, the server operator and/or owner may conclude that User 1 is a more valuable user. The server operator and/or owner may therefore prefer to send User 1 opportunities that arise, because User 1 has demonstrated an active, continuing, fresh commitment to participating in tasks on the server.
In various embodiments, the user management module 359 can monitor the users or participants in the system to determine how effective the users are in meeting task deadlines and expectations. For example, the user management module 359 may monitor the number and/or percentage of tasks in which each user meets or beats the listed deadline, e.g., due date, for a task. The user management module 359 may also monitor the productivity of each user or task participant. For example, the user management module 359 can measure the efficiency of each user, e.g., how long it takes the user to complete a task. In further arrangements, the user management module 359 can measure the productivity of a user based on feedback given by other task participants. For example, if User 1 is viewed as being a team player or an exceptionally talented contributor by User 1's collaborators, then the user management module 359 may determine that User 1 is a valuable user. The user management module 359 can accordingly sort and organize users according to task efficiency and productivity, and can prioritize users (e.g., employees, vendors, customers, etc.), according to their efficiency, quality of work, and/or productivity.
In various embodiments, the user management module 359 can monitor the number of tasks created by or assigned to a particular user. For example, the user management module 359 can track the users that have assigned tasks to a particular task participant and the dates and task identifiers or names that are associated with those assigned tasks. Similarly, user management module 359 can track the users, tasks, and dates of users that have been assigned tasks created by a particular task participant or user. In addition, the user management module 359 may track the number of tasks assigned or created over time, and can monitor whether those tasks are open tasks (e.g., ongoing), closed tasks (e.g., finished), or declined tasks (e.g., the task recipient elected not to participate in the assigned task). In some aspects, the user management module 359 may track the percentage or number of tasks completed over time to track the overall level of progress on one or more tasks or on a project. The user management module 359 can also track the average time to completion for a task or a project. As explained herein with respect to the task analytics module 374, task tracking may also be performed at a company- or organization-wide manner, in which case the total number of tasks or projects may be monitored to determine the number or percentage of tasks that are complete and an average time to complete the tasks or projects.
In addition, the user management module 359 may organize the processed tasks and task participants into one or more user groups. For example, the user management module 359 can recognize when groups of users, e.g., task participants, are affiliated with one another, such as by being employees of the same company or members of the same organization. In various arrangements, the user management module 359 can recognize affiliated users by processing their e-mail addresses. For instance, if two users share the same e-mail domain (e.g., their e-mail addresses are both listed as “@company.com”), then the user management module 359 may organize the two users into the same user group. The user management module 359 can thereby recognize and sort users based on their affiliations with a company or organization.
The user management module 359 may also associate documents, media and other data files with processed tasks and system users. For example, as explained herein, users may work on shared word processing, spreadsheet, presentation, text, or other types of documents or data files when collaborating on a task. The documents may be received from the users and stored on the task management system 315. The user management module 359 may associate the stored documents and media (e.g., video, audio, etc.) with the task participants and the tasks. For example, the user management module 359 can associate a word processing document containing an action item list, a spreadsheet listing cash flow projections, and engineering drawings with a project (e.g., group of tasks) related to a new product design and roll-out. The user management module 359 may also associate the documents or media with the task participants associated with the documents and can display the documents or media on a user interface using the user interface module 341. The task management system 315 may thereby effectively associate the plurality of tasks with the plurality of task participants and any documents or media associated with the task.
Moreover, when one or more tasks are directed to related subject matter, the user management module 359 may group the tasks into a task group. For example, if Cindy works on a task related to testing the reliability of a Widget, then the user management module 359 can store the task information that associates Cindy with the task that relates to the Widget test. If Dan subsequently works on a task relating to testing the same or a similar Widget, even on an unrelated task or project, then the user management module 359 may recognize that Dan's task is related to Cindy's task. For example, the user management module 359 may recognize similar keywords between Dan's and Cindy's tasks, or the user management module 359 may recognize that the subject matter is similar by way of, e.g., subject matter tags. In such arrangements, the user management module 359 may create task groups that include tasks that are directed to related subject matter. Indeed, the user management module 359 may also store tasks in a task history field so that future users may learn from and exploit the experiences of users who have collaborated on similar or related tasks.
In yet other arrangements, tasks may be grouped into one or more projects. A project may be, for example, a complex or long-term endeavor that includes multiple tasks that may or may not be directed to related subject matter. For example, if a project's objective is to roll out a new product design, then a company may assign disparate tasks to its multiple divisions. Executives may assign product development to the engineering department, product sales to its sales or marketing department, and product manufacturing to its manufacturing arm or to a third-party contractor. The user management module 359 can recognize that each task in a project, although potentially relating to different subject matter, is related to achieving the overall objectives of the project.
Further, the user management module 359 can monitor projects to determine the degree of completion of the projects by, e.g., monitoring the status of the task(s) that make up the projects. If, for example, a project includes five tasks, and if two tasks are completed while three remain uncompleted, then the user management module 359 may determine that the project is about 40% complete. In further arrangements, the user management module 359 can determine the overall degree of completion of the project by accounting for even partially completed tasks. For example, if there are five tasks in the projects, and if two tasks are each 25% completed and the other three tasks are each 50% completed, then the overall project status may be computed. In this example, therefore, the overall project completion may be determined by a linear combination of the partially completed tasks. For example, the two tasks (out of five total) that are only 25% completed yield a project completion status of (2/5)*25%=10%. The other three tasks that are each 50% completed contribute to a completion status of (3/5)*50%=30%. Thus, the total degree of completion of the project will be about 10%+30%, for a total degree of completion of about 40%. In sum, the user management module 359 can estimate the degree of completion of a project that includes one or more tasks.
In addition, each task participant or user can be associated with multiple other users over the course of participating in numerous tasks with the other users. Thus, each user can have or be associated with a contact list. The contact list can include a list of one or more contacts that have participated in at least one task with the task participant. Thus, each user and/or task participant can form a network of related contacts that have participated in task(s) on the task management system 315. For example, the task management system 315 can sort the contact list based at least in part on the frequency with which the contact(s) have participated in tasks with the task participant. Fresh and valuable relationships can therefore be prioritized. In some instances, for example, weights can be assigned to contacts on each user's contact list based on the value of each contact on the contact list. For instance, contact weights can be assigned to contacts based on the frequency with which the contact(s) have participated in tasks with the task participant. Thus, a first contact may be assigned a first contact weight, and a second contact may be assigned a second contact weight. If the first contact has more frequent and/or more recent interaction with the task management system 315 and participation in tasks than the second contact, then the first contact weight may be assigned a greater value than the second contact weight. The task management system 315 can thereby prioritize user contacts on the contact list based on the value of the user contacts and the underlying value of the contacts.
By monitoring tasks, task due dates, task participants, and interactions among task participants, the user management module 359 can provide valuable information to a company or organization. For example, the user management module 359 can inform executives and/or decision-makers about upcoming due dates or milestones of projects and/or tasks. By providing a company-wide schedule, the user management system 359 can give companies a high-level picture of the work that is being performed by its employees. The company can use these metrics to prioritize tasks or to make new investments. By monitoring user productivity, efficiency, and responsibility, companies can recognize valuable employees, vendors, and customers, and can prioritize its relationships accordingly. Further, by organizing documents associated with the tasks and task participants, the company or organization can easily and efficiently access the content associated with the tasks and/or projects at issue.
As shown in
Thus, by gathering and sorting information about users that have participated in tasks on the server, the owner and/or operator of the server can utilize user information to optimize system performance or to otherwise benefit the owner and/or operator of the server. For example, relationships with active and/or valuable contacts can be prioritized over relationships with stale or otherwise inactive or less valuable contacts. The task management system 315 can also include a multi-layered network management module 372. As explained in more detail below, the multi-layered network management module 372 may advantageously manage the interrelationships among multiple individual networks and global networks. Further, as explained herein with respect to
The task management system 315 can also include content management 371 that can store data associated with the functions performed by the task management system 315. For example, the content management 371 can include memory configured to permanently store instructions encoded as software that is configured to perform the functions on the task management system 315, as described herein. Further the content management 371 can store data received and processed by the task management system 315, including, e.g., task content information and user information.
Task Management Process OverviewThe illustrated method 400 is depicted from the point of view of a server, such as a server hosting the task management system 315 of
The method 400 then moves to a block 479 to process the message to identify task information and one or more task recipients. For example, the server can process task content data that includes information about the task, such as task objectives and goals. In some arrangements, the processed task information can include a schedule of assignments for the task to ensure that the task proceeds according to the desired timeline. The server can also identify the task creator and the one or more task recipients. As explained herein, when sent in an e-mail message, the task creator may be processed in information in a “From” field of the e-mail message, while the task recipients may be processed in information in a “To,” “CC,” or “BCC” field of the e-mail message. Further, the server can identify a unique task identifier in the “Subject” and/or message fields of the e-mail. The server's address may also be listed in the “To,” “CC,” or “BCC” fields of the message.
The method 400 then proceeds to a decision block 481 to determine whether task information and task recipient(s) information is identified. If the answer to the decision block 481 is no, then the method 400 ends. However, if the answer to the decision block 481 is yes, then the method proceeds to a block 483, in which a task is created based on the identified task information. The server can therefore store the task content data, the task participant information, and any other data associated with the task.
The method 400 then moves to a block 485 to notify the one or more task recipients about the created task. For example, the server can send a notification e-mail to the task recipients. In turn, the task recipients can send a response e-mail either confirming acceptance or rejection of the task assignments. In some arrangements, the server can notify the task creator about whether or not the task recipients accept or reject the assigned task.
The method 400 then proceeds to a decision block 487 to determine whether additional messages are received. If additional messages are received, then the method 400 moves back to the block 477 to receive the message from a task creator. If no additional messages are received, then the method 400 ends.
In various other related methods, a task comment can be received from a first task participant. The task comment can be published for other task participants to review. For example, a forum or electronic message can be displayed on a web page to share messages among the task participants.
User InterfaceTurning to
The user interface 590 can also include a list 591 of user communities and/or contacts. The list 591 can include a list of the contacts with whom the user has participated in various tasks. In various implementations, for example, users may use the list 591 of user communities and/or contacts to identify and communicate with users on their list 591 of communities and/or contacts. Further, a list 593 of active tasks may also be displayed on the user interface 590. The user may select a particular task to manipulate task content data and/or to interface with participants in the particular task. For example, the list 593 of active tasks may be used to select a particular task that a user would like work on at that moment.
In addition, the user interface 590 can include a real-time messaging window 595 that can provide for real-time communications among task participants. For example, the messaging window 595 can include a real-time messaging window for the exchange of electronic text messages. Alternatively, the messaging window 595 can include a video and/or audio interface to provide for the real-time video and/or audio communication among task participants. The user interface 590 may also include a document sharing window 596 that displays a list of documents that are relevant to a particular task. As explained above, text or word processing documents, videos, audio files, presentation files, spreadsheets, and any other suitable data may be shared by way of the document sharing window 596. For example, users can see if and when other users edited or reviewed a particular file.
Furthermore, an e-mail window 597 can be displayed on the user interface 590. The e-mail window can display e-mail messages received by the user on a portion of the interface 590. In some arrangements, the user can send and receive e-mails by way of the e-mail window 597 built into the user interface 590.
Moreover, a calendar 598 and/or a schedule of tasks can be presented in the user interface 590. The calendar 598 can list the portions of a task that are assigned to the user and can enforce accountability for timely performance of the task. In some embodiments, the user can check off assignments that have been completed and may prioritize the remaining assignments. In some arrangements, other users can view the user's calendar 598, and/or notifications may be sent to all task participants when the user completes an assignment. In some embodiments, blogs 599 or other types of electronic forums may be displayed on the user interface 590. Blogs or other news streams can provide a centralized source of news or opinion relating to the task. Skilled artisans will appreciate that other windows may be presented on the user interface 590. Further examples of a user interface are discussed herein with respect to a user inbox-outbox interface, such as the interface disclosed in
In various embodiments, a multi-layered network infrastructure may be employed to organize the interconnections among tasks, task participants, and documents associated with the tasks and task participants. The multi-layered infrastructure can facilitate interactions among tasks and users within a department or group (e.g., networks), and can further organize departments and groups within larger companies, organizations, or affiliates (e.g., clouds). The multi-layered infrastructure can organize the companies, organizations, and affiliates into a cloud of interconnected entities belonging to a particular geopolitical zone. In some embodiments, multiple clouds of interconnected entities can be organized into a “federation” of clouds. The federation of associated clouds can allow entities within a particular cloud to be connected with entities in another cloud. In various embodiments, the federation of clouds can facilitate communications between clouds based on previously determined access controls that regulate the interactions between and among entities belonging to different clouds.
For example,
The cloud federation 600 can manage communications between and among Clouds 1-3 based on various security and access controls established by each cloud 601. For example, the governments or managers of Cloud 1 may require particular security controls that restrict how its users interact with users of other clouds 601. For example, Cloud 1 may only allow users to collaborate on tasks and projects with users within Cloud 1 (e.g., users within North America), or Cloud 3 may restrict collaboration to users that have various types of security or anti-virus software installed. The cloud federation 600 can facilitate communications between entities in different clouds (e.g., users in Clouds 1 and 2) that meet the access requirements or permissions of the participating clouds. In other arrangements, certain entities may require that their data be hosted by a particular local service provider. For example, the countries associated with Cloud 2 may require that all entities within or associated with that countries in the Asia-Pacific Zone participate in tasks over a local host provider. Thus, security concerns may be addressed by managing the security controls associated with a particular cloud 601.
In general, as disclosed herein, a first layer can include individual networks 605, which may correspond to an internal company network associated with a division or organization of the company, or even the entire company itself. The employees within the company, and tasks performed by employees within the company, may be organized into one or more user groups associated or affiliated with the company or organization by the multi-layered network management module 372 of
In some embodiments, each cloud 601 can include a plurality of networks 605. The networks 605 may correspond to, e.g., a company or a division within a company, such as an engineering division of a company. As explained above, the clouds 601 may organize networks 605 within a particular geopolitical zone. As shown in, e.g.,
A second cloud 601, Cloud 2, can include two additional networks 605 associated with companies or organizations within the Asia-Pacific Zone. For example, Cloud 2 can include Networks 2A and 2B, which can correspond to Japanese Company A and Korean Company B, respectively. The users within Network 2A, for example, may interact with one another over the network 605 labeled Network 2A. At the second network layer, however, users may communicate across Cloud 2, e.g., between Networks 2A and 2B. For example, employees of Japanese Company A may collaborate with employees of Korean Company B on various projects. Further, the cloud federation 600, e.g., the third network layer, enables users within Cloud 2 to communicate with the users in Cloud 1 in order to exploit the contacts and expertise of the users in both clouds 601. For example, the cloud federation 600 may enable Japanese Company A of Network 2A to collaborate with its American division, U.S. Company A of Network 1A. Similarly, Cloud 3 can include networks 605 related to different companies or organizations within the European Zone, including, e.g., Network 3A related to United Kingdom Company A and Network 3B related to French Company B. In various arrangements, therefore, a cloud 601 can connect affiliated or associated companies within a geopolitical zone. The companies within Cloud 3 may communicate with each other through networking architecture programmed into Cloud 3; however, these companies may also be in network communication with the entities and companies of Clouds 1 and 2 as well by way of the third layer, e.g., the cloud federation 600. The cloud federation 600 can thereby provide network communication within or across multiple clouds 601 corresponding to multiple geopolitical zones, by way of, e.g., the multi-layered network management module 372 of
The method then moves to a block 706 to organize networks into a plurality of clouds. Each cloud can represent a company or group of companies and can include a plurality of networks, as explained above with respect to
Furthermore, the multi-layered network management module 372 can be configured to track tasks that are associated with two or more networks or two or more clouds, and can organize tasks into one or more task groups based at least in part on the association of the tasks with the two or more networks or the two or more clouds. The system can also organize documents based at least in part on the association of the tasks with the two or more networks or the two or more clouds. The multi-layered network management module 372 can thereby organize multiple tasks and task participants, and their associated documents, across and within multiple clouds and networks.
Task AnalyticsIn various embodiments, users create tasks by sending an e-mail message to the server and to the other task participants. The use of e-mail can be particularly advantageous in some circumstances because many or most users are familiar with e-mail and its capabilities. Further, e-mail already has a built-in contact list of users that are connected to one another. Harnessing the power and ubiquity of e-mail to create and manage tasks can advantageously allow for the disclosed embodiments to rapidly spawn user contacts across multiple networks and to monitor interconnections among users at a company- or organizational level. For example, a particular user can create tasks using e-mail by sending an e-mail message to anyone with a standard e-mail address. In turn, this initial recipient can create tasks with anyone on their list of e-mail contacts, and the network of task participants can increase accordingly. By allowing for the easy creation and management of tasks based on a standard e-mail platform, the number of users interacting with the server and participating in tasks can be increased substantially.
Furthermore, the ubiquity of e-mail communications can allow users to collaborate with other users in different organizations or companies on a variety of different projects and tasks. In various embodiments, the systems disclosed herein can map the interconnections of each user based on the user's contacts, interactions with other companies, projects, topics, and documents. In some embodiments, by leveraging the ubiquity of e-mail, the system can recognize users in a particular user group (e.g., a company, organization, or a department within a company) based on their company or organization e-mail address. For example, some users may be recognized as belonging to the group “engineers” while others are recognized as belonging to the group “human resources”. Users may also be recognized as belonging to a particular company, such as Company A or Company B, which may be user groups.
Companies or organizations that participate in the disclosed systems may take advantage of rich information associated with the tasks performed by users of the company or organization. For example, the task analytics module 374 and/or the user management module 359 of
In some embodiments, the task analytics module 374 can generate the map 800 of task participant relationships by identifying, for each task participant or user, other users that have participated in one or more tasks with the task participant. Thus, in
Companies and organizations can advantageously use the generated map 800 to monitor various relationships of interest. For example, if User 1 of Company A wants to contact User 8 of Company C regarding a potential collaboration, User 1 may not initially be connected to User 8 because they have not yet participated in any tasks together. However, the task analytics module 374 can monitor the relationships of the generated map 800 and can determine that User 2 of Company A has participated in, or is participating in, one or more tasks with User 8. The task analytics module 374 can then inform User 1 that User 2 may have a relationship with User 8, and User 2 can introduce User 8 to User 1 in order to facilitate a potential future collaboration. Alternatively, the task analytics module 374 may recognize that User 9 is within the same company (Company C) as User 8 and can inform User 1 that User 9 may have a relationship with User 8. Because User 1 already has a relationship with User 9 based on prior or current task participation, User 1 may try to contact User 8 through User 9's internal company networks.
In various embodiments, a company can monitor which other companies or organizations it frequently interacts with, e.g., which companies its employees collaborate with frequently on tasks. For example, the task analytics module 374 may determine that Company B has strong interactions with Company A and Company B based on User 5's frequent task collaborations with User 2 of Company A and User 8 of Company C. The task analytics module 374 may therefore inform a system administrator that Company B has ties with Companies A and B that the system administrator may not have previously realized. The task analytics module 374 may also sort the task participant relationships based on how active the relationships are. For example, if two users have recently participated in tasks together, the task analytics module 374 may assign a high score to the relationship, whereas, if two users participated in tasks long ago, the task analytics module 374 may assign a lower score to the relationship. In addition, the task analytics module 374 can analyze the frequency that users interact with one another on various tasks. In some embodiments, the task analytics module 374 can assign higher values or priorities to relationships that involve frequent interactions, and lower values or priorities on relationships that involve less frequent or one-time-only transactions.
The task analytics module 374 can sort the project relationships to identify other companies with which a particular company has frequent or recent collaborations. For example, user groups 801 that are involved in frequent or recent collaborations may be assigned a high score, while user groups 801 that are involved in less frequent or less recent collaborations may be assigned a lower score. In various embodiments, the task analytics module 374 may also monitor the documents that are shared or used by different user groups 801. For example, the task analytics module 374 may monitor the documents edited or viewed by Company A that are shared with other companies, such as Company B. The task analytics module 374 may thereby also monitor the content that is shared across different user groups 801. It should be appreciated that, while
The method 900 then moves to a block 904, wherein the task participants are associated with the plurality of tasks. As explained above with respect to the user management module 359 of
Turning to
Managers and executives can utilize the rich information gleaned from tasks performed by users within a company to make important business decisions. In some embodiments, the dashboard 1000 can help managers and executives in making internal decisions based on each employee's or division's productivity, on-time percentage, or other measure of performance. For example, the dashboard 1000 can enable managers and executives to utilize data aggregated by the task analytics module 374 and/or the user management module 359 when making decisions regarding which employees to promote or to put in charge of a particular new project. In addition to assisting with internal decisions, in various embodiments, the dashboard 1000 can help managers and executives in making high-level decisions about company or organizational strategy in relation to other competitors or business partners. For example, the dashboard 1000 can assist decision-makers in analyzing which business partnerships are valuable and fresh for the company. The dashboard can also utilize the known task relationships between company employees and other users of a different company to recognize the reach of a company's relationships. If, for example, Company A is developing a new product that requires a novel material set, decision-makers can analyze employee task relationships to determine if any employees are connected to other users at a materials development company.
For example, as shown in
Furthermore, the user analytics page 1002 can include a user snapshot view 1010. The user snapshot view 1010 can include a user list box 1014 that lists every user or employee within the company or organization. Alternatively, a search box can be provided to allow the decision-maker to search for a particular employee or user. When a particular user is selected, such as User 3 in the example of
Turning to
Further, the project analytics page 1004 can include a project description box 1024 that lists the description or objectives of Project 4. For example, as shown in the project description box 1024, the goal of Project 4 is to organize a banquet for Company A. A due date box 1026 can list the due date for completing the project, which is Jan. 10, 2013, for Project 4. In addition, a project completion percentage box 1028 can list the completion percentage for Project 4, which is shown to be 35%. While various data sets are illustrated in the project analytics page 1004 of
As shown in
The method 1100 then proceeds to a block 1106 to aggregate task data associated with the tasks and the task participants. For example, as explained herein with respect to
The method then moves to a block 1108 to analyze the aggregated task data. For example, the task analytics module 374 and/or the user management module 359 can sort the aggregated data according to data sets selected by a decision-maker or user. For example, the system can sort user data by productivity (number of tasks), efficiency, timeliness, user relationships, etc. In various embodiments, the aggregated task data can be presented to a user in a dashboard, such as the interfaces shown in
Example objects that are managed by the object management module 346 can include tasks, documents, messages, requests, reports, etc. For example, messages can include conversations between one or more users (e.g., a continuous chat stream between users), e-mails (which may be converted to a form suitable for display in the interface 1200 in some arrangements), alerts (e.g., a communication sharing or forwarding a document), and any other type of communication that can be shared among authorized users. In addition, tasks can include various categories or types of tasks, including actions, approvals, etc. For example, User 1 can send User 2 an action-type task to review a draft contract, and User 1 or User 2 can forward the reviewed draft contract to a supervisor as an approval-type task, in which case the supervisor would be asked to review and approve the draft contract. As another example, request-type objects may include invitations to join networks or communities and/or to join the task management system, invitations to events (such as calendar-based invitations and schedules), and requests for contact connections (e.g., requesting to be connected with another individual or organization). Furthermore, report objects can include technical-type report objects in which users can report technical problems to system administrators. Further, report objects can also include complaint-type report objects, in which users can complain to system administrators about other users or non-users that abuse or spam the system or that otherwise violate the system's terms of service.
For example, the inbox-outbox interface 1200 of
The inbox-outbox interface 1200 can provide users with a high-level summary of objects in their interface 1200. For example, the inbox 1200 can show in a concise manner the overall status of the object (e.g., a pending task), the aggregate performance of the object (e.g., what percentage of an overall task has been completed by the task participants), the number of comments or messages associated with the objects, the number and/or type of documents associated with the objects (e.g., whether the documents are files, videos, photos, etc.), object due date, and object importance/urgency. It should be appreciated that other details of the objects can also be presented in the user interface.
Furthermore, the inbox-outbox interface 1200 can include a show-all button 1205 that illustrates the objects in the inbox 1201, objects in the outbox 1203, and, in various arrangements, objects in other folders. In the example implementation of
In some embodiments, the object management module 346 and/or the integrated interface module 348 can include persistent containers for objects that serve to organize the objects into desired workspaces. Advantageously, the containers can organize users (e.g., people) and objects (e.g., tasks, documents, messages, etc.) according to a particular topic or grouping. The persistent containers can thereby maintain a persistent organizational structure for objects and users over time. For example, in the case of a group of users working on a particular project, the users may work on several tasks, may create and edit multiple documents, and may send and receive numerous messages over the course of the project. The object management module 346 and/or the integrated interface module 348 may be programmed to track and organize the objects worked on during the course of the project in a single container. Thus, the container can track when each task was created and by whom and can track the performance of each task over time by each task participant (including all the status updates associated with the task). The container can track the messages sent and received by users, and can track the history of edits to documents over the course of the project. Further, the container can track the actions of each user. For example, the container can track each participant's actions and can monitor when a user begins or quits working on the project, and/or when and what a user says in a message or communication. Thus, even long after a project is completed, for example, an auditor can track the entire history of the project (including the progression of objects such as tasks, documents, messages, etc.) in the persistent container that collects the objects associated with the project.
The persistent containers described herein can take any suitable form. For example, a container can include a single object, such as a single task. In such cases, the container can track all the activities (including messages, documents, users, etc.) associated with the task. At another level, the container can include a folder of multiple objects (such as a folder including multiple tasks, messages, documents, and other types of objects). The container can thus track the history of the group of objects in the folder. For example, in some embodiments, the inbox-outbox interface 1200 can include one or more folders 1207 that include objects shared between the user and a particular group of other users, or that include objects associated with a particular topic or project. For example, User 1 may include folders 1207 for each of User 1's clients and colleagues. Thus, User 1 may include a first folder for Bank A that handles User 1's accounts, a second folder for Lawyer B that handles User 1's legal work, a third folder for Partner C that is User 1's business partner, and a fourth, Personal folder that includes objects shared with family members. Thus, the task management module 327 (including, e.g., the object management module 346 and the integrated interface module 348) can include instructions to automatically route objects associated with a particular user group. For example, the object management module 346 can include instructions to route bank statements sent by Bank A to User 1 in the “Bank A” folder. Messages sent between User 1 and Lawyer B can be stored and presented in the “Lawyer B” folder. Tasks, messages, or documents shared between User 1 and Partner C may be routed to the “Partner C” folder, while objects associated with User 1's family may be routed to the “Personal” folder. Further, the folders 1207 can sort objects according to a particular topic or project, such as a folder for a project directed to designing a particular widget. In some embodiments, the persistent containers disclosed herein can include communities (e.g., groups of related folders) and networks (e.g., groups of related communities, such as divisions of a company or an association of related companies). Thus, the object management module 346 can include instructions to sort objects according to their subject matter and organize them in the user inbox-outbox interface 1200 accordingly.
In the user inbox-outbox interface 1200 of
Similarly, Document 3 is the object in the object field 1209 of the second line, which has an object type 1211 of “document.” The object content field 1213 indicates that the document includes a spreadsheet of User 1's accounts receivable, while the status field 1215 indicates that Document 3 is pending for User 1 to edit or revise by the due date of Feb. 1, 2013.
In the third line of the interface 1200 shown in
On the fourth line or entry of the interface 1200, Task 4 is listed as the object in the object field 1209, which has an object type 1211 of a task. The object content field 1213 describes the task as “Complete product reliability testing.” The status field 1215 indicates that Task 4 is pending for User 3. Thus, an authorized user (such as User 1 or another task participant) may have assigned Task 4 to User 3 to complete, such that the remaining task participants are waiting for User 3 to complete assigned Task 4. The inbox-outbox interface 1200 will therefore display Task 4 as pending for User 3 until User 3 completes Task 4 or otherwise assigns it to another user. The due date field 1217 indicates that Task 4 is due by Mar. 1, 2013.
The final line of the interface 1200 lists Task 5 (which has an object type field 1211 of task) in the object field 1209. For Task 5, the object content field 1213 indicates that Task 5 includes planning a seminar. In the status field 1215, Task 5 is illustrated as being assigned by User 1 to User 4 with a due date listed in the due date field 1217 of Mar. 13, 2013. If User 4 accepts the assignment of Task 5, then the user inbox-outbox interface 1200 may update to indicate that Task 5 is “pending for User 4,” rather than just “Assigned by You to User 4.” Further, when User 4 completes Task 5, the status field 1215 may be updated to “Completed by User 4.” Although various examples have been described herein with respect to the interface 1200 of
As described herein, the objects listed in the inbox-outbox interface 1200 may be updated in real-time and shared with other authorized users. For example, the status field 1215 may change to reflect the current status when a user takes a particular action. For example, when User 1 replies to Mary in Message 2, the status field 1215 may update to indicate that Message 2 has been “Completed by You [User 1]” and/or that Message 2 is “Pending for Mary” to respond. Further, if User 1 edits Document 3 and requests that User 6 review and revise User 1's edits, the status field 1215 may read “Completed by You [User 1]” and/or “Pending for User 6” to review and revise. Similarly, when a task has been accepted, completed, begun, etc., as explained above, the status field 1215 for Tasks 1, 2, or 5 may be appropriately updated. While the status described with reference to
In addition, User 1 can sort the objects listed in the interface 1200 according to various parameters. For example, User 1 can sort the objects by the status field 1215 such that objects that are pending with User 1 (e.g., those objects that are awaiting action from User 1) are listed first, whereas objects pending with other users are listed later. In the example of
In other arrangements, the objects listed in the interface 1200 may be sorted by due date field 1217 such that upcoming due dates appear near the top of the interface 1200 and that due dates coming later appear nearer the bottom of the interface 1200. The order listed in
By allowing authorized users to sort objects in the inbox-outbox interface 1200, the task management module 327 can enable users to see which items require their immediate attention and which items may be deferred to a later date. Further, the status field 1215 allows authorized users to identify which objects are awaiting actions from which users. For example, User 1 may notice that other users are waiting for him to update Document 3 and respond to Message 2. The status field 1215 and the due date field 1217 can thereby enforce real-time accountability for authorized users, such as task participants, by identifying other users that are impeding progress on a task (or other object) and by encouraging users to timely meet the specified deadlines.
Authorized users may be any system user that has permission to share objects (e.g., tasks, messages, documents, etc.) in the system. Any suitable authentication or permission mechanism may be suitable. In some embodiments, for example, the disclosed networks can include members, guests, and public categories. For example, members can be officially recognized users of the system, such as employees of a particular company or members of a particular organization or association of companies. A guest may be a system customer that is given various permissions to use the system. In some arrangements, a public category user may be a visitor to the system or a prospective future user of the system given limited permissions to use the system. Any other suitable mechanisms may be used to categorize users as authorized users. The containers or spaces disclosed above may be configured to share objects with contacts according to their permission category, allowing multiple levels of authorization and access in some arrangements.
The method moves to a block 1303 to associate each object with one or more authorized users. For example, a group of users working on a particular task, e.g., a group of task participants, may be associated with the task. Thus, if Users 1, 2, and 3 are collaborating on Task 1, the task management module 327 (e.g., the object management module 346) may associate Users 1, 2, and 3 with Task 1. In various arrangements, authentication procedures may be implemented by the task management module 327 (e.g., the object management module 346) and/or the user management module 359 to manage access to the object.
Turning to a block 1305, an object status is assigned to each computer object of the plurality of objects that indicates the status of that computer object within the system. In some arrangements, the object management module 346 may assign the object status to the objects. For example, the object status may indicate that the object has been assigned to a particular user to be performed, or that the object is pending action by a particular user. Further, the status may also show that the status has been completed by a particular user. For example, as explained herein with respect to
The method then moves to a block 1307 to indicate the assigned status on the graphical user interface to each of the authorized users associated with the computer object. In various arrangements, the integrated interface module 348 can include instructions to indicate the status of each object in real-time to authorized users. As explained herein with respect to
The method then moves to a decision block 1309 to determine if there are additional objects. If a decision is made that there are additional objects, then the method 1300 moves to the block 1303 to associate the objects with the one or more authorized users. If a decision is made that there are no additional objects, then the method 1300 ends.
All of the features described above may be embodied in, and automated by, software modules executed processors or integrated circuits of general purpose computers. The software modules may be stored in any type of computer storage device or medium. All combinations of the various embodiments and features described herein fall within the scope of the present invention.
Although the various inventive features and services have been described in terms of certain preferred embodiments, other embodiments that are apparent to those of ordinary skill in the art, including embodiments which do not provide all of the benefits and features set forth herein and do not address all of the problems set forth herein, are also within the scope of this invention. The scope of the present invention is defined only by reference to the appended claims.
Claims
1. (canceled)
2. A computer-implemented method for managing tasks stored on a system of one or more networks, the method comprising:
- providing a graphical user interface that lists a plurality of tasks, wherein each task comprises task information;
- associating each task with one or more authorized users;
- organizing each task into one or more persistent containers;
- updating a status to each task that indicates the status of that task within the system;
- displaying the assigned status on the graphical user interface to each of the authorized users associated with the task; and
- tracking a history of one or more tasks in each of the one or more persistent containers over time.
3. The method of claim 1, further comprising tracking the status of each task over time.
4. The method of claim 1, further comprising notifying at least one authorized user about at least one of the status of a task, documents associated with the task, comments associated with the task, other users associated with the task, and changes to the task information.
5. The method of claim 1, further comprising tracking actions of the one or more authorized users over time.
6. The method of claim 1, wherein indicating the assigned status comprises presenting the object status to the authorized users on the graphical user interface.
7. The method of claim 1, wherein organizing each task into one or more persistent containers comprises organizing each task based at least in part on a topic associated with the task, a project associated with the task, or a group of authorized users associated with the task.
8. The method of claim 1, wherein the one or more persistent container comprises a folder including multiple tasks.
9. The method of claim 1, further comprising organizing a plurality of computer objects into the one or more persistent containers, each computer object comprising at least one of a task, a message, and a document.
10. The method of claim 1, wherein updating the status comprises sorting the plurality of tasks based at least in part on whether the task is assigned, pending, or completed.
11. The method of claim 1, wherein updating the status comprises sorting the plurality of tasks based at least in part on at least one of due dates associated with the respective tasks, importance of the respective tasks, activity level of the respective tasks, and number of authorized users associated with the respective tasks.
12. The method of claim 1, further comprising identifying a task recipient and a task creator for each task.
13. A system for managing a plurality of tasks stored on one or more networks, the system comprising:
- an object management module programmed to: associate each task with one or more authorized users; organize each task into one or more persistent containers; update a status to each task that indicates the status of that task within the system; and track a history of one or more tasks in each of the one or more persistent containers over time; and
- an integrated interface module programmed to: provide a graphical user interface that lists the plurality of tasks, wherein each task comprises task information; and display the assigned status on the graphical user interface to each of the authorized users associated with the task.
14. The system of claim 13, wherein the one or more persistent container comprises a folder including multiple tasks.
15. The system of claim 13, wherein the integrated interface module is programmed to notify at least one authorized user about at least one of the status of a task, documents associated with the task, comments associated with the task, other users associated with the task, and changes to the task information.
16. The system of claim 13, wherein the object management module is programmed to track the status of each task over time.
17. The system of claim 13, wherein the object management module is programmed to track actions of the one or more authorized users over time.
18. The system of claim 13, wherein the object management module is programmed to organize each task into the one or more persistent containers based at least in part on a topic associated with the task, a project associated with the task, or a group of authorized users associated with the task.
19. The system of claim 13, wherein the integrated interface module is programmed to present the status to the authorized users using the graphical user interface.
20. The system of claim 13, wherein the object management module is programmed to receive at least one of a task, a message, and a document.
21. The system of claim 13, wherein the object management module is programmed to sort the plurality of tasks based at least in part on whether the task is assigned, pending, or completed.
22. The system of claim 13, wherein the object management module is programmed to sort the plurality of tasks based at least in part on at least one of due dates associated with the respective tasks, importance of the respective tasks, activity level of the respective tasks, and number of authorized users associated with the respective tasks.
23. The system of claim 13, wherein the object management module is programmed to identify a task recipient and a task creator for each task.
24. The system of claim 13, wherein the object management module is programmed to receive data from the authorized users regarding whether the tasks are assigned, pending, or completed.
25. A non-transitory computer-readable medium having instructions stored thereon that, when executed by a processor, perform a method comprising:
- providing a graphical user interface that lists a plurality of tasks, wherein each task comprises task information;
- associating each task with one or more authorized users;
- organizing each task into one or more persistent containers;
- updating a status to each task that indicates the status of that task within the system;
- displaying the assigned status on the graphical user interface to each of the authorized users associated with the task; and
- tracking a history of one or more tasks in each of the one or more persistent containers over time.
26. The non-transitory computer-readable medium of claim 25, wherein the one or more persistent container comprises a folder including multiple tasks.
Type: Application
Filed: Jan 23, 2014
Publication Date: Jul 24, 2014
Applicant: BroadVision, Inc. (Redwood City, CA)
Inventors: Pehong Chen (Atherton, CA), James Wu (Sunnyvale, CA), Dongfeng Lu (Leawood, KS), Peter Chu (Cupertino, CA)
Application Number: 14/162,643
International Classification: G06F 9/48 (20060101);