CONTEXT-AWARE SUPPORT INTEGRATION

Information

  • Patent Application
  • 20170091778
  • Publication Number
    20170091778
  • Date Filed
    September 30, 2015
    9 years ago
  • Date Published
    March 30, 2017
    7 years ago
Abstract
Technologies for enabling support providers to integrate into a support application and provide real-time support for requests based at least partly on authorizations associated with the support providers are described. The technologies described can access authentication data associated with support providers. The technologies described can receive a request associated with a product and/or a service and determine contextual data associated with the request. The technologies described can determine authorization data associated with support providers, determine support providers for supporting the request based partly on the contextual data, determine that the support providers are authorized to receive the request, and generate task data associated with the request. The technologies described can further include sending the task data to devices corresponding to the support providers, determining that an individual support provider accepts the request, and causing a display of a graphical element indicating that the individual support provider accepts the request.
Description
BACKGROUND

When encountering issues with products and services, it is common for consumers to contact a service center for assistance. Generally, consumers can submit a request for assistance by the use of a number of technologies, some of which can include the use of an email, phone call, instant message, etc. In some systems, consumer requests are forwarded to a queue. Customer service representatives can access and service the consumer requests in the queue on a first-come, first-served basis.


In many circumstances, the first customer service representative who accesses the consumer request cannot answer the consumer's question or provide the correct type of help that the consumer requested. Sometimes, the consumer can be directed to a number of other customer service representatives before the question is answered or the correct type of help is provided. Re-direction can be time consuming for both consumers and customer service representatives and, in many circumstances, does not provide a resolution. As a result, consumers are often frustrated with products, services, and/or customer service offered for the products and/or services.


SUMMARY

Technologies for enabling support providers to integrate into a support application and provide real-time support for requests (e.g., onboarding requests, support requests, managing requests, troubleshooting requests, etc.) based at least partly on authorizations associated with the support providers are described. The technologies described herein enable devices to access authentication data associated with support providers. Technologies can receive a request associated with a product and/or a service and determine contextual data associated with the request. The technologies described can determine authorization data associated with support providers, determine support providers for supporting the request based partly on the contextual data, determine that the support providers are authorized to receive the request, and generate task data associated with the request. The technologies described can further include sending the task data to devices corresponding to the support providers, determining that an individual support provider accepts the request, and generating data indicating that the individual support provider accepts the request. In some configurations, a device can cause a display of a graphical element indicating that the individual support provider accepts the request. The graphical element can be displayed on a device corresponding to a user associated with the request, service provider(s) associated with a support application, and/or support provider(s).


It should be appreciated that the above-described subject matter can be implemented as a computer-controlled apparatus, a computer process, a computing system, or as an article of manufacture such as a computer-readable storage medium. These and various other features will be apparent from a reading of the following Detailed Description and a review of the associated drawings.


This Summary is provided to introduce a selection of technologies in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended that this Summary be used to limit the scope of the claimed subject matter. Furthermore, the claimed subject matter is not limited to implementations that solve any or all disadvantages noted in any part of this disclosure.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram showing several example components of a system for enabling support providers to integrate into a support application and provide real-time support for requests based at least partly on authorizations associated with the support providers.



FIG. 2 is a flow diagram illustrating aspects of a method for enabling real-time support of a request based at least in part on authorization data associated with support providers.



FIG. 3 is a flow diagram illustrating aspects of a method for determining one or more support providers for supporting a request and causing a graphical element corresponding to the request to be presented on devices corresponding to the one or more support providers.



FIG. 4 is a flow diagram illustrating aspects of a method for presenting user information corresponding to a request to a support provider based at least in part on the support provider accepting the request.



FIG. 5A is a block diagram showing an example user interface presenting a mechanism for a support provider to input authentication data.



FIG. 5B is a block diagram showing an example user interface presenting a task list including one or more tasks.



FIG. 5C is a block diagram showing an example user interface presenting user information corresponding to a request.



FIG. 6 is a flow diagram illustrating aspects of a method for ranking support providers based at least in part on ratings.



FIG. 7 is a computer architecture diagram illustrating an illustrative computer hardware and software architecture for a computing system capable of implementing aspects of the techniques and technologies presented herein.



FIG. 8 is a diagram illustrating a distributed computing environment capable of implementing aspects of the techniques and technologies presented herein.



FIG. 9 is a computer architecture diagram illustrating a computing device architecture for a computing device capable of implementing aspects of the techniques and technologies presented herein.





DETAILED DESCRIPTION

The following detailed description is directed to technologies for enabling support providers to integrate into a support application and provide real-time support for requests based at least partly on authorizations associated with the support providers. For illustrative purposes, support providers can include entities competent to provide support services associated with products, services, etc. Support providers can be internal to a service provider associated with a support application. For instance, support providers can be employees who provide support for the service provider. Or, support providers can be external to the service provider. For example, support providers can be entities that contract with the service provider to provide support services but are not directly employed by the service provider. In some examples, support providers can be third-party entities that include third-party vendors, partners, etc. providing support services (e.g., GODADDY®, APPRIVER®, etc.), freelance support providers providing support services (e.g., ODESK®, ELANCE®, etc.), etc. In at least one example, the third-party entities can have one or more sub-support providers who provide support for various service providers on behalf of the third-party entities. For instance, the one or more sub-support providers can be employees or contractors associated with the third-party entities.


Further, for illustrative purposes, a request can include a submission for assistance, instructions, or other types of information related to a product, a service, etc. For instance, a request can include an onboarding request. An onboarding request can be a request for assistance with getting started with a new product, service, etc. A request can include a support request. A support request can be a request for assistance associated with a product, service, etc. A request can be a managing request. A managing request can be a request for assistance with managing a product, a service, etc., such as billing, subscription, authorizations, etc. A request can be a troubleshooting request. A troubleshooting request can be a request for assistance with a technical issue associated with a product, a service, etc.


Technologies for enabling support providers to integrate into a support application and provide real-time support for requests based at least partly on authorizations associated with the support providers are described. The technologies described can receive authentication data from devices associated with support providers. The technologies described herein can authenticate the devices associated with the support providers and determine authorization data associated with the individual support providers. The technologies described can receive a request associated with a product and/or a service and determine contextual data associated with the request. The contextual data can define a status of an application associated with the product and/or the service.


Additionally, the technologies described can include determining support providers for supporting the request based partly on the contextual data and the authorization data. Moreover, the technologies described can include generating task data associated with the request. The task data can include the contextual data. The technologies described can further include causing a display of a graphical element corresponding to the task data to be presented on user interfaces of devices corresponding to the support providers and determining that an individual support provider of the support providers accepts the request based at least in part on receiving acknowledgement of the task data from a device corresponding to the individual support provider. In at least one example, the acknowledgement can be associated with acknowledgement data indicating an acknowledgment of the task data.


The technologies described herein can be useful for improving the customer support experience for users by enabling support providers to provide real-time support for requests. For instance, various support providers from around the world can access a server associated with a support application service provider. Based at least in part on the individual support providers accessing the support application via the server and authenticating themselves with the support application, the individual support providers can receive and/or access individualized task lists that include one or more tasks. Each of the one or more tasks can correspond to a request, as described above. An individual support provider can accept a task on its task list thereby causing that task to be removed from task lists associated with the other individual support providers. Based at least in part on accepting the task, the individual support provider can interact with the user who submitted the task and provide support services for resolving the request.


In a non-limiting example, a first user can be a small business owner based in Seattle, Wash. The first user can purchase a new product and while transitioning her small business from the old product to the new product, the first user can become confused on how to migrate the small business's current domains. The first user can actuate a control on a user interface associated with the new product. The control can be associated with a support application. Based at least in part on actuating the control on the user interface, the first user can receive a notification indicating that domain migration will begin momentarily.


In the non-limiting example, a second user can be executing the support application on his or her device (e.g., a freelancing support provider). In at least one example, the second user can provide authentication data each time the second user accesses the support application (i.e., every time the user signs-on). In other examples, the second user can provide authentication data when the second user creates a user profile associated with the support application. The second user can indicate that he or she is available. For illustrative purposes, the second user can be available such that the second user is signed onto the support application via a support provider profile. The second user can actively monitor a task list associated with the support application.


The second user can receive a notification on the device associated with the second user. The notification can alert the second user that a task has been added to the second user's task list. The task list can include one or more tasks that correspond to requests that have not yet been serviced. The second user can determine, from the task list, a user associated with each task and the contextual data corresponding to each task. In some examples, the second user can access additional contextual data to determine additional details about the particular issue that prompted the request. The second user can accept the request and start the domain migration for the first user. Responsive to the second user accepting the request, the first user can receive a notification confirming receipt of the request. In some examples, the notification can include a mechanism for creating a shared meeting space for the first user and the second user in addition to the response confirming receipt of the request.


Based at least in part on the second user resolving the request (or, in some examples, not resolving the request), the first user can access a mechanism associated with a user interface of the support application for receiving feedback data from the first user about at least one of the second user or resolution of the request. The support application can leverage the feedback data and/or performance data for rating individual support providers (e.g., the second user) and/or all support providers with support provider profiles associated with the support application and/or determining the satisfaction of individual support application users (e.g., the first user).


Generally, the technologies described herein can be useful for improving the customer support experience for users. That is, the technologies described herein can improve the customer support experience by reducing time that lapses between users sending requests and support providers responding to the requests and/or resolving issues associated with the requests. In some examples, the technologies described herein can conserve computing resources and reduce network bandwidth usage by streamlining requests to support providers who are available and capable of resolving the requests in near real-time based at least in part on contextual data associated with the requests.


While the subject matter described herein is presented in the general context of program modules that execute in conjunction with the execution of an operating system and application programs on a computer system, those skilled in the art will recognize that other implementations can be performed in combination with other types of program modules. Generally, program modules include routines, programs, components, data structures, and other types of structures that perform particular tasks or implement particular abstract data types. Moreover, those skilled in the art will appreciate that the subject matter described herein can be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers, and the like.


In the following detailed description, references are made to the accompanying drawings that form a part hereof, and in which are shown by way of illustration specific configurations or examples. Referring now to the drawings, in which like numerals represent like elements throughout the several figures, aspects of a computing system, computer-readable storage medium, and computer-implemented methodologies for enabling real-time support for requests based at least in part on contextual data. As will be described in more detail below with respect to FIGS. 8-10, there are a number of applications and services that can embody the functionality and techniques described herein.



FIG. 1 is a block diagram showing several example components of a system 100 for enabling support providers to integrate into a support application and provide real-time support for requests based at least partly on authorizations associated with the support providers. As shown in FIG. 1, system 100 can include at least a network 102, one or more computing devices associated with users (e.g., user device(s) 104), one or more computing devices associated with support providers (e.g., support provider device(s) 106), and a server 108. Additional computing devices (not shown) can communicatively couple to the network 102. The user device(s) 104 and/or the support provider device(s) 106 can represent computing devices that can run applications. In at least one example, the user device(s) 104 and/or the support provider device(s) 106 can be user devices, for example, such as a laptop computer, a desktop computer, a smartphone, a tablet computing device or any other computing device, communicatively connected to the support provider device(s) 106 and/or the user device(s) 104, respectively, and the server 108 through one or more local and/or wide area networks, such as the network 102. In other examples, the user device(s) 104 and/or the support provider device(s) 106 can be in the form of a server computer or a number of server computers. It should be appreciated that many more network connections can be utilized than are illustrated in FIG. 1.


The user device(s) 104 can include a local memory 110 that can include one or more modules and data structures, such as a program module 112A. The one or more modules and data structures can be in the form of stand-alone applications, productivity applications, an operating system component or any other application or software module having features that facilitate interactions between the user device(s) 104, the support provider device(s) 106, and/or the server 108. In at least one example, the program module 112A can be associated with a support application. Additional modules and components of the user device(s) 104 are explained below and shown in FIG. 8.


The user device(s) 104 can be associated with user identifier(s) 114 for identifying a user of the user device(s) 104. The program module 112A can be configured to provide mechanisms for the user to submit a request 116 associated with a product, a service, etc., and receive communications facilitating support from a support provider in real-time. For illustrative purposes, real-time refers to a time within a threshold time of a timestamp associated with when a user submits a request 116. As described below, a user can submit a request 116 by actuating a control on a user interface, requesting help via voice input, etc. The one or more modules and data structures can be configured to manage interactions between the user device(s) 104, the support provider device(s) 106, and/or the server 108.


As will be explained below, the program module 112A can be configured to send and/or receive communications from the support provider device(s) 106 and/or the server 108. In at least one example, a user can submit a request 116 based at least in part on the user actuating a control presented on a user interface associated with a product, a service, etc. The control can be associated with a support application (e.g., an application corresponding to program module 112A) or with the particular product, service, etc. In other examples, a user can provide alternative inputs, such as voice input, gaze input, etc. to submit requests 116. As described above, requests 116 can include onboarding requests, support requests, managing requests, troubleshooting requests, requests for directions, etc. In at least one example, based at least in part on determining that a user submitted a request 116, the program module 112A can send requests 116 to the server 108 and/or the support provider device(s) 106 via the network 102.


Additionally and/or alternatively, the program module 112A can receive responses from the server 108 and/or the support provider device(s) 106. The responses can include notifications confirming receipt (e.g., acknowledgement) of requests 116 and/or requesting additional information from users, mechanisms for creating shared meeting spaces for users associated with user devices (e.g., user device(s) 104) and support providers associated with support provider devices (e.g., support provider device(s) 106), mechanisms for receiving feedback from users associated with user devices (e.g., user device(s) 104), etc. The program module 112A can be configured to cause graphical elements corresponding to the controls, mechanisms (e.g., shared meeting space invites, feedback surveys, etc.), notifications, etc., described above, to be presented on a user interface of the user device(s) 104. In some examples, the notifications can include a display of a graphical element, an audio signal, a message, a status change of at least one component of a computing device, etc.


The support provider device(s) 106 can include a local memory 118 that can include one or more modules and data structures, such as a program module 112B and an authentication module 121. The one or more modules and data structures can be in the form of stand-alone applications, productivity applications, an operating system component or any other application or software module having features that facilitate interactions between the user device(s) 104, the support provider device(s) 106, and/or the server 108. In at least one example, program module 112B can be associated with the same support application as program module 112A.


The support provider device(s) 106 can be associated with support provider identifier(s) 120 for identifying support providers corresponding to individual support provider device(s) 106. In some examples, support provider device(s) 106 can be associated with a single support provider identifier 120. In at least one example, the support provider identifier can serve as authentication data, as described below. In additional and/or alternative examples, support provider device(s) 106 can be associated with more than one support identifier 120. For instance, for support providers that have sub-support providers, a support provider device 106 can be associated with a support provider identifier 120 corresponding to the support provider and individual support provider identifiers 120 corresponding to the sub-support providers. Or, for a sub-support provider, a corresponding support provider device 106 can have a support provider identifier 120 that corresponds to the sub-support provider and at least one support provider identifier 120 that corresponds to the support provider. In some examples, support provider profile(s) 132 corresponding to the sub-support providers can be mapped to the corresponding support provider's support provider profile 132 via tags, etc.


The authentication module 121 can be configured to send authentication data 121 to the server 108. In some examples, the authentication module 119 can send authentication data 121 to the server 108 at an initial set-up of the support application on the support provider device 106. In such examples, the authentication data 121 can be persistently stored in a support provider profile corresponding to a support provider. In other examples, the authentication module 121 can send authentication data 121 to the server 108 each time a support provider accesses the support application, after a session expires, after a lapse in a predetermined amount of time, etc.


As described above, the authentication module 119 can each be associated with authentication data 121. In some examples, the authentication data 121 can be input by support providers associated with the support provider device(s) 106. In at least one example, support providers can input authentication data 121 by inputting passwords to sign-on to the support application. The password can be associated with a support provider identifier 122 and/or support provider profile. In additional and/or alternative examples, support providers can provide authentication data 121 by providing biometric data (e.g., fingerprint analysis, retinal scan, hand geometry analysis, voice analysis, etc.) for accessing the support application. Moreover, in additional and/or alternative examples, authentication data 121 can be associated with devices that can be coupled (e.g., removably or not) to the support provider device(s) 106. Examples of the devices can include smart cards that can include embedded certificates used to identify the holder, hand-held tokens that can include LEDs that display numbers synchronized with an authentication server (e.g., authentication module 142 described below), etc. In some examples, the support provider identifier(s) 122 can correspond to the authentication data 121. In other examples, the support provider identifier(s) 122 can be distinct from the authentication data 121.


The program module 112B can be configured to provide mechanisms for receiving communications associated with requests 116, causing graphical elements corresponding to task data representative of the requests 116 to be presented on the support provider device(s) 106 in association with task list(s) 122, and enabling a support provider to accept the request 116 in real-time. The one or more modules and data structures can be configured to manage interactions between the user device(s) 104, the support provider device(s) 106, and/or the server 108.


The program module 112B can be configured to receive communications associated with requests 116. In some examples, the communications can include task data corresponding to requests 116. The task data can be associated with task list(s) 122. In at least one example, task list(s) 122 can be data storage components for temporarily storing task data. The program module 112B can cause a graphical representation of a task list 122 to be presented on a user interface via a display of the support provider device(s) 106. The task list 122 can be graphically represented by graphical elements corresponding to task data.


The user interface can be configured to provide functionality for the support provider to interact with individual of the graphical elements of the task list 122 to gain access to additional contextual data. For instance, a support provider can interact with the graphical elements via touch input, sound input, gaze input, etc. to access additional contextual data. Additionally, the user interface can be configured to provide functionality for the support provider to accept individual tasks on the task list 122. For instance, a support provider can accept individual tasks via touch input, sound input, gaze input, etc. In at least one example, the input can generate acknowledgement data indicating an acknowledgement of the task (e.g., 702A, 702B).


The task list(s) 122 can be associated with the support provider identifier(s) 120 and can each include one or more tasks corresponding to individual requests 116 and contextual data corresponding to each task. The task list 122 corresponding to each support provider can be unique to that support provider and can be different from task lists 122 corresponding to other support providers associated with the support application. In some examples, task list(s) 122 can be sent from the server 108 to the support provider device(s) 106. In other examples, communications can be sent from the server 108 to the support provider device(s) 106 for updating a task list 122 stored on a support provider device 106. In at least one example, the tasks can be arranged based on a timestamp associated with a time the user submits a request 116. Each of the tasks in the task list 122 can correspond to a currently outstanding request 116 has not yet been accepted by a support provider. As described above, each task on the task list 122 can be associated with task data. The task data can include tasks, contextual data corresponding to the tasks, data associated with the users who submitted the requests 116 corresponding to the tasks (e.g., name, contact information, etc.), etc. Based at least in part on determining that a support provider accepts a task, the task can be removed from task lists 122 associated with all other support providers who received task data associated with the request 116.


The program module 112B can be configured to send responses to the user device(s) 104 and/or the server 108. The responses can include notifications that a task data 137 has been received and/or acknowledged, a request 116 has been accepted, mechanisms for creating shared meeting spaces for users and support providers, etc. In at least one example, the notifications can include a display of a graphical element, an audio signal, a message, a status change of at least one component of a computing device, etc. In some examples, the responses can prompt the user for additional information associated with the request 116.


The server 108 can be in the form of a server computer or a number of server computers configured to send and receive communications from the user device(s) 104 and/or the support provider device(s) 106. The server 108 can include a local memory 124 that can include one or more modules and data structures, such as a program module 112C, a contextual data determination module 126, a data manager 128 that includes user profile(s) 130 and support provider profile(s) 132, a request routing module 134, a task management module 136, a feedback module 138, a performance module 140, an authorization module 142, etc. The one or more modules and data structures can be configured to manage interactions between the user device(s) 104, the support provider device(s) 106, and/or the server 108. In at least one example, the server 108 can provide an interface configured to receive data associated with requests, authentication data, contextual data, acknowledgement data, feedback data, performance data, data associated with users and/or support providers, etc. In additional and/or alternative examples, the server can provide an interface configured to transmit task data including contextual data, acknowledgement data, feedback data, performance data, authorization data, etc. The one or more modules and data structures can be in the form of stand-alone applications, productivity applications, an operating system component or any other application or software module having features that facilitate interactions between the user device(s) 104, the support provider device(s) 106, and/or the server 108. In at least one example, the program module 112C, the contextual data determination module 126, the data manager 128, the request routing module 134, the task management module 136, the feedback module 138, the performance module 140, and the authorization module 142 can be associated with the same support application as program module 112A and program module 112B.


The program module 112C can be configured to facilitate communications between the user device(s) 104 and the support provider device(s) 106. The program module 112C can receive requests 116 from the user device(s) 104. The program module 112C can be configured to receive responses from the support provider device(s) 106 and can be configured to send the responses to the user device(s) 104. As described above, the responses can include notifications that a request 116 has been acknowledged and/or accepted, mechanisms for creating shared meeting spaces for users and support providers, requests for additional information associated with the request 116, etc.


The contextual data determination module 126 can be configured to receive, access, and/or generate contextual data 127. Contextual data 127 can be received and/or accessed from any number of resources and contextual data 127 can be in any format. Contextual data 127 can enable support providers to access knowledge about requests 116 submitted by users. Contextual data 127 can be data that can define a status of an application associated with a product, a service, etc., a status of an interface associated with a product, a service, etc., etc. For illustrative purposes, applications are programs created by programmers to fulfill specific tasks. Non-limiting examples of applications include batch files, scripts (e.g., in a user device or a web service), etc. For example, applications can provide utility and/or productivity functionality, entertainment services, educational services, consumer management services, etc. to users of devices. For illustrative purposes, an application can include a web browser application, a wizard application, a mailbox application, a messaging services application, a social networking services application, a consumer management services application, etc. In at least one example, contextual data 127 can be obtained by an analysis of an application, an interface associated with a product, service, etc. In some examples, contextual data determination module 126 can determine contextual data 127, as described below. In other examples, the user device(s) 104 and/or third-party service providers can determine contextual data 127 and send the contextual data 127 to the contextual data determination module 126.


In a non-limiting example, an application can be a wizard application. The wizard application can guide users through several steps to complete tasks. In some examples, the wizard application can help users configure or install a software application. In other examples, the wizard application can help users complete other tasks such as configuring a product or managing a transaction. An analysis of an application, such as a wizard application, allows techniques described herein to generate contextual data 127 defining steps that the user has taken towards completing a task, steps that a user has had trouble with in the past, a status of a current step, and other status information.


In another non-limiting example, an application can be a web browser. The web browser application can retrieve, present, and traverse information resources via the Internet. Examples of web browser applications include INTERNET EXPLORER®, GOOGLE CHROME®, SAFARI®, etc. Information resources can include web pages, images, videos, other data items, etc. that are identified by Uniform Resource Identifiers (URI/URL). In some examples, users can utilize the web browser application to access various web pages, etc. The web browser application can collect data associated with web pages users visit to determine histories of web pages visited by users, frequencies associated with individual of the web pages visited by the users, numbers of times users visit individual of the web pages, etc. An analysis of an application, such as a web browser application, allows techniques described herein to generate contextual data 127 defining a current web page that a user is viewing, a history of web pages a user has accessed, a frequency that a user has visited individual of the web pages, a number of times a user has visited individual of the web pages, and other status information.


In yet another non-limiting example, an application can be a mail services application or a messaging services application. As described below in FIG. 9, a mailbox application can provide electronic mail (“email”) services, personal information management (“PIM”) services including, but not limited to, calendar services, contact management services, collaboration services, and/or other services. A messaging services application can provide instant messaging services, chat services, forum services, and/or other communication services. Users can exchange electronic communications with other users using the mail services application and/or messaging services application. An analysis of an application, such as a mail services application and/or a messaging services application, allows techniques described herein to generate contextual data 127 defining a status of a mail services application and/or messaging services application, a subject of an electronic communication sent and/or received by a mail services application and/or a messaging services application, etc. In some examples, the contextual data determination module 126 can leverage semantic parsing to determine contextual data 127 from text included in text included in electronic communications sent and/or received by a mail services application and/or a messaging services application, etc.


In another non-limiting example, an application can be a social networking services application. As described below in FIG. 9, the social networking services application can provide various social networking services including, but not limited to, services for sharing or posting status updates, instant messages, links, photos, videos, and/or other information; services for commenting or displaying interest in articles, products, blogs, or other resources, and/or other services. Additionally and/or alternatively, a social networking services application also provide commenting, blogging, and/or micro blogging services, etc. An analysis of an application, such as a social networking services application, allows techniques described herein to generate contextual data 127 defining a status of a social networking services application, an action associated with the social networking services application, etc. In some examples, the contextual data determination module 126 can leverage semantic parsing to determine contextual data 127 from text included in status update postings, comments on articles, products, blogs, etc., etc.


In yet another non-limiting example, an application can be a consumer management services application. A consumer management services application can provide various consumer management services including, but not limited to, recording transactions, generating analytics (e.g., numerical or tabular data) associated with the transactions, creating graphical elements corresponding to the analytics for presenting to users, etc. to view and analyze consumer behavior. In at least one example, the consumer management application can generate a graphical element that corresponds to a funnel that visually identifies how users move through a series of transactional steps associated with a transaction and where users abandon a transaction. An analysis of an application, such as a consumer management services application, allows techniques described herein to generate contextual data 127 defining a status of a consumer management services application, a status of funnel, a status of a transactional step associated with the funnel, etc.


In at least some examples, the contextual data determination module 126 can analyze an interface associated with an application to determine contextual data 127. In some examples, an analysis of an interface associated with an application allows techniques described herein to generate contextual data 127 defining a status of the interface, a status of a region of the interface, etc. In other examples, the contextual data 127 can define a region of an interface that a user spent an amount of time that exceeds a threshold amount of time, how much time a user spent interacting with a region of an interface, a most frequently visited region of an interface; a region of an interface that a user interacted with prior to submitting a request 116, etc.


In at least one example, the contextual data determination module 126 can prompt a user for additional contextual data 127. For instance, the contextual data determination module 126 can cause one or more questions (e.g., multiple choice questions, Likert questions, etc.) to be presented to the user and/or can cause a freeform text box to be presented to the user. The contextual data determination module 126 can leverage semantic parsing to determine additional or alternative contextual data 127 from text input into the freeform text box.


The data manager 128 can be configured to receive and/or access data associated with users corresponding to user devices (e.g., user device(s) 104) and/or support provider data associated with support providers corresponding to support provider devices (e.g., support provider device(s) 106). Individual users can be associated with user profile(s) 130. Individual user profile(s) 130 can be associated with unique identifiers (e.g., user identifier(s) 114) and can be stored in the data manager 128. The data manager 128 can receive and/or access data associated with the individual users (e.g., user data) based at least in part on data input by the individual users, third-party service providers, etc. The data manager 128 can receive and/or access the data associated with the individual users when the individual users set up user profile(s) 130, responsive to requests for data, etc. The data associated with the individual users can be mapped to corresponding user profile(s) 130.


Data associated with the individual users (i.e., user data) can include an identity of the user. An identity of an entity can include a name of entity, a type of entity (e.g., business, individual, etc.), etc. Data associated with the individual users can include a location of the user, a language of the user, a number of employees employed by a user, etc. Additionally and/or alternatively, data associated with the individual users can include a type of a subscription associated with the user as determined by the level of support services the user subscribes to, a length of the subscription associated with the user as determined by how long the user has subscribed to the support services, etc. Examples of data associated with the individual users can include data identifying a list of preferred support providers for supporting requests 116 submitted from the users, data identifying a preferred skill set associated with support providers supporting requests submitted from the users, etc. Additional and/or alternative examples of data associated with the individual users can further include a history of requests 116 associated with the user, feedback provided by the user, etc. The history of requests 116 can include contextual data 127 associated with previous requests 116, a frequency of previous requests 116, etc.


Individual support providers can be associated with support provider profile(s) 132. Individual support provider profile(s) 132 can be associated with unique identifiers (e.g., support provider identifier(s) 120) and can be stored in the data manager 128. The data manager 128 can receive and/or access data associated with the individual support providers (e.g., support provider data) based at least in part on data input by the individual support providers, third-party service providers, etc. The data manager 128 can receive and/or access the data associated with the individual support providers when the individual support providers set up support provider profile(s) 132, responsive to requests for data, etc. Data associated with individual support providers can include availability data indicating whether a support provider is signed onto the support application via a corresponding support provider profile 132. In at least one example, data associated with individual support providers (e.g., support provider data) can include an expertise associated with the support provider as determined by the requests a support provider is qualified to resolve. In some examples, the expertise associated with the support provider associated with the support provider can be determined by the support provider. In other examples, the expertise associated with the support provider associated with the support provider can be determined based on feedback data, performance data, etc. In additional and/or alternative examples, data associated with individual support providers can include a language of the support provider, a geographic location of the support provider, feedback associated with the support provider, a rating associated with the support provider, etc.


Additionally and/or alternatively, data associated with individual support providers can include a quota of requests associated with the support provider, a minimum number of requests associated with the support provider, a compensation structure associated with the support provider, etc. For instance, the support provider data can indicate a limit as to the number of requests 116 a support provider can accept in a predetermined period of time (e.g., hour, day, week, month, etc.) (i.e., quota) and/or a minimum number of requests 116 that a support provider is required to accept in a predetermined period of time (e.g., hour, day, week, month, etc.) (i.e., threshold). In other examples, the support provider data can include data associated with a compensation structure to determine how much a support provider is paid per request 116 it accepts and/or resolves.


In at least one example, the data associated with the individual support providers can include authorization data 144, as described below. In some examples, the authorization data 144 can be associated with the authorization module 142 and can be mapped to the support provider profiles 132. In other examples, the authorization data 144 can be associated with the support provider profile(s) 132. Additional details about the authorization data 144 are described below.


While the description above is directed to support providers, the same and/or similar data can be determined and/or associated with individual sub-support providers. In some examples, authorization data 144 associated with sub-support providers can be determined by a corresponding third-party entity support provider and/or based on authorization data 144 associated with the corresponding third-party entity support provider. That is, in some examples, sub-support providers can have same authorizations as corresponding third-party entity support providers and in other examples, sub-support providers can have at least some different authorizations as corresponding third-party entity support providers.


The request routing module 134 can be configured to determine one or more support providers for routing requests 116. The request routing module 134 can access user data and/or support provider data. The request routing module 134 can access the authorization data 144. Additionally, the request routing module 134 can access the requests 116 and/or contextual data 127, as described above. The request routing module 134 can compare the request 116, contextual data 127, and/or user data with the support provider data and, based at least in part on comparing the request 116, contextual data 127, and/or user data with the support provider data, can determine one or more support providers for supporting the request. In at least one example, the request routing module 134 can select one or more support providers for support the request 116 based at least in part on determining a correlation between the contextual data 127, user data, and/or support provider data.


In at least one example, the request routing module 134 can determine the one or more support providers for routing requests 116 to based at least in part on determining whether individual support providers of the one or more support providers are available and authorized to receive a request (per authorization data 144). In other examples, the request routing module 134 can determine one or more support providers for routing requests 116 to without regard to whether support providers are available. In such examples, based at least in part on determining that some of the one or more support providers are not available, the request routing module 134 can prompt a user to determine whether the user prefers support at the time with the support providers that are available or prefers to wait for one of the unavailable support providers to become available. Additional details associated with determining the one or more support providers for routing requests is described below in FIG. 3.


The task management module 136 can be configured to receive and/or access the requests 116 and generate task data 137 that corresponds to individual requests 116. The task data 137 can include a request 116, contextual data 127, user data corresponding to the user who submitted the request 116 (e.g., name, contact information, etc.), a timestamp corresponding to when the user submitted the request 116, etc. The task management module 136 can arrange the tasks in task lists 122 associated with individual support providers. As described above, a task list 122 can include one or more tasks corresponding to individual requests 116. The task management module 136 can cause a display of a graphical element corresponding to task data 137 to be presented as a task in a graphical representation of the task list 122 presented on devices corresponding to one or more support providers (e.g., support provider device(s) 106).


In at least one example, the task management module 136 can be configured to determine that a support provider corresponding to a support provider device of the support provider device(s) 106 accepts a task on the task list 122 based at least in part on data received from the program module 112B. That is, the task management module 126 can determine that the support provider accepts a particular request 116. Based at least in part on determining that a support provider accepts a request 116, the task management module 136 can remove the task from task lists 122 associated with other support providers. The task management module 136 can remove the task by removing the task data 137 from the task lists 122 and by terminating causing the display of the graphical element corresponding to the task data 137 on the task list 122 presented on the support provider device(s) 106.


The feedback module 138 can be configured to receive feedback data from users. In at least one example, the feedback module 138 can prompt users for feedback based at least in part on a user and/or support provider indicating that the request 116 is resolved (e.g., the user and/or support provider actuate corresponding controls indicating that the request 116 is resolved), observing that the request 116 is resolved (e.g., the domain has been migrated and the user is using the new domain, etc.), etc. In other examples, the feedback module 138 can prompt users for feedback based at least in part on determining that the request 116 timed out (e.g., is not resolved for a predetermined period of time). The feedback data can be associated with individual support providers and/or the overall customer support experience. The feedback data can include positive, negative, or neutral feedback about individual support providers and/or customer support experiences.


In some examples, the feedback module 138 can prompt the user for feedback via various mechanisms. In at least one example, a graphical element corresponding to a feedback survey can be caused to be presented to users of the user device(s) 104. The feedback survey can include one or more questions for collecting feedback data (e.g., multiple choice questions, Likert questions, fill-in-the-blank questions, freeform questions, etc.). The feedback module 138 can process the feedback data (e.g., via a heuristic, etc.) to determine a score or rating associated with individual support providers.


The performance module 140 can determine performance data associated with users, individual support providers, and/or all support providers who have support provider profile(s) 132 with the support application. With respect to users, the performance module 140 can determine a number of requests 116 made by a user, a number of requests 116 made by the user that were accepted, accepted and resolved, declined, timed out (e.g., unresolved after a predetermined period of time), etc., a frequency in which the user makes requests 116, etc.


With respect to individual support providers, the performance module 140 can determine a number of requests 116 accepted and/or serviced by a support provider, a number of requests 116 in which the support provider makes contact with a user associated with a request 116, a number of requests 116 that have been resolved by the support provider (e.g., as determined by the support provider and/or the user), etc. The performance module 140 can also leverage timestamps associated with requests 116 and responses to determine a lapse of time between when a request 116 is sent and a response is sent and/or received (i.e., time lapsed prior to a support provider accepting the request 116), a lapse of time between when a request 116 is sent and when a request 116 is resolved (i.e., time lapsed prior to resolution of the request 116), etc. Additionally, the performance module 140 can determine a number of responses sent to a user, an amount of time a support provider spent waiting on the user, etc. In some examples, the support provider who originally accepted the request 116 may not be able to resolve the request 116. Accordingly, the support provider can communicate with other support providers to resolve the request 116, or the server 108 can send the request 116 to another support provider. In such examples, the performance module 140 can determine a number of support providers that worked on resolving the request 116, etc. The performance module 140 can compute a number of requests 116 a support provider accepts and/or resolves per day. Additionally, the performance module 140 can access the feedback data to determine ratings associated with individual support providers. In at least one example, the performance module 140 can leverage net satisfaction scoring (NSAT) to rate individual support providers.


Additionally and/or alternatively, the performance module 140 can determine aggregated data associated with all of the support providers that have support provider profile(s) 132 associated with the support application. In at least one example, the performance module 140 can receive, access, and/or determine a number of requests 116 accepted and/or serviced by all of the support providers, a number of requests 116 in which the all of the support providers make contact with users associated with requests 116, a number of requests 116 that have been resolved by all of the support providers (e.g., as determined by the support providers and/or the users), etc. The performance module 140 can also receive, access, and/or determine averages of lapses of time between when requests 116 are sent and responses are received, lapses of time between when requests 116 are sent and when requests 116 are resolved, etc. Additionally, the performance module 140 can determine an average number of responses sent to users, an average amount of time a support provider spent waiting on the user, etc. The performance module 140 can determine an average number of support providers that worked on resolving a request 116, etc. Additionally, the performance module 140 can access the feedback data to determine ratings associated with the support application based on the performance of all of the support providers. In at least one example, the performance module 140 can leverage net satisfaction scoring (NSAT) for determining user satisfaction of the support application.


While the description above is directed to support providers, the same and/or similar performance data can be determined and/or associated with individual sub-support providers. In such examples, the aggregated data can be determined for all sub-support providers associated with a third-party entity support provider, all support providers, including the sub-support providers, and/or all support providers excluding the sub-support providers.


In some examples, the performance module 140 can leverage the feedback data, performance data, and/or aggregated data to evaluate each support provider that has a support provider profile 132. In at least one example, the performance module 140 can rank each of the support providers based on the ratings associated with the individual support providers. For instance, in a non-limiting example, the performance module 140 can perform top-box/bottom-box percentile computations to determine how to rank each support provider. In additional or alternative examples, if a support provider is a third-party entity support provider with two or more sub-support providers, the performance module 140 can rank each of the sub-support providers associated with the third-party entity support provider based on the ratings associated with each of the sub-support providers. In some examples, the sub-support providers can be ranked with other support providers without differentiating between sub-support providers and support providers.


In some examples, a predetermined number of top ranking support providers and/or support providers ranked above a predetermined threshold can receive benefits that lower ranking support providers do not receive. For instance, top ranking support providers and/or support providers ranked above a predetermined threshold can receive higher compensation per request 116 accepted than lower ranking support providers. In other examples, top ranking support providers and/or support providers ranked above a predetermined threshold can receive authorizations to access additional and/or alternative requests 116 that lower ranking support providers do not have access to and/or top ranking support providers and/or support providers ranked above a predetermined threshold can receive access to requests 116 before lower ranking support providers. While the description above is directed to support providers, the same and/or similar ranking and/or corresponding authorizations can be determined for individual sub-support providers.


The performance module 140 can leverage the feedback data, performance data, etc. to reward individual support providers. In some examples, the performance module 140 can credit an account associated with a support provider profile 132 based at least in part on determining that the support provider corresponding to the support provider profile 132 accepts a request 116, accepts a number of requests 116 above a predetermined number, resolves a request 116, resolves a number of requests 116 above a predetermined number, receives a rating above a predetermined threshold, is ranked above a predetermined rank, etc. The amount of the credit can vary based on the expertise of the support provider, the length of time the support provider has had a support provider profile 132 associated with the support application, the rating and/or ranking associated with the support provider, etc. In other examples, the performance module 140 can provide the support provider corresponding to the support provider profile 132 additional and/or alternative rewards. For instance, the performance module 140 can provide the support provider with first rights of refusal for particular requests, access to incoming requests prior to other support providers, additional and/or alternative access rights, etc. As described above, the performance module 140 can provide additional and/or alternative rewards based at least in part on the expertise of the support provider, the length of time the support provider has had a support provider profile 132 associated with the support application, the rating and/or ranking associated with the support provider, etc. While the description above is directed to support providers, the same and/or similar rewards can be determined for individual sub-support providers.


The authorization module 142 can access/receive authentication data 121 from the authentication module 121 and can determine authorizations associated with individual support providers based at least in part on authorization data associated with the individual support providers and the authentication data 121 corresponding to the individual support providers. The authorization module 142 can be configured for determining authorizations associated with individual support providers. The authorization module 142 can receive and/or access the authentication data 121 from the authentication module 121 and can leverage the authentication data 121 to determine requests 116 that individual support providers are authorized to receive. The authorization module 142 can access support provider data and/or authorization data 144 associated with support provider profile(s) 132 for determining which requests 116 the individual support providers are authorized to receive.


The authentication module 142 can be configured for receiving and/or accessing authentication data 121 from support provider device(s) 106. As described above, in some examples, the authentication module 142 can receive authentication data 121 at an initial set-up of the support application on the support provider device 106. In such examples the authentication data 121 can be persistently stored in a support provider profile 132 corresponding to the support provider. In other examples, the authentication module 142 can receive authentication data 121 each time a support provider accesses the support application, after a session expires, after a lapse in a predetermined amount of time, etc. The authentication module 142 can leverage the authentication data 121 to identify support provider profile(s) 132 corresponding to the authentication data 121. In some examples, the authentication module 142 can also leverage the support provider identifier(s) 122 for identifying support provider profile(s) 132. That is, based at least in part on the authentication module 142 receiving and/or accessing authentication data 121, the authentication module 142 can verify support providers and permit support providers to receive and/or access corresponding task lists 124.


In at least one example, the support provider profile(s) 132 can be associated with authorization data 144. Authorization data 144 can be receive and/or accessed from any number of resources and authorization data 144 can be in any format. Authorization data 144 can enable the request routing module 134 to identify what requests 116 a support provider is authorized to accept based at least in part on authentication data 121. Authorization data 144 can be data that can define authorizations of a support provider with respect to contextual data 137 associated with requests 116. Moreover, authorization data 144 can be data that can define authorizations of a support provider with respect to quotas and/or minimums associated with support providers, compensation structures associated with support providers, languages of support providers, geographic locations of support providers, ratings of support providers, etc.


In some examples, authorization data 144 can be determined by the service provider associated with the support application based on data associated with support provider profile(s) 132. For instance, the support provider profile(s) 132 can include data indicating quotas and/or minimums associated with support providers, compensation structures associated with support providers, languages of support providers, geographic locations of support providers, ratings of support providers, etc. Based at least in part on said data, the authorization module 142 can determine authorizations associated with the support providers corresponding to the support provider profile(s) 132 and can determine authorization data 144 indicating the authorizations associated with the support providers. Changes to data associated with the support provider profile(s) 132 can cause changes to authorizations associated with the support providers corresponding to the support provider profile(s) 132. The change in authorizations can be reflected in the authorization data 114. While the description above and below is directed to support providers, the same and/or similar authorization data 114 can be associated with sub-support providers. In at least one example, authorizations associated with sub-support providers can be based on authorizations determined by corresponding support providers.


For instance, support providers with a particular expertise can be authorized to accept requests 116 associated with contextual data 137 indicating that the requests 116 require the particular expertise and/or requests 116 requiring associated expertise but may not be authorized to accept other requests 116. As a non-limiting example, Support Provider A, a freelance support provider providing onboarding support services can be authorized to receive onboarding requests but may not be authorized to receive any other requests 116. As another non-limiting example, a sub-support provider of Support Provider B, can be authorized to receive requests 116 associated with a particular step of a wizard application but may not be authorized to receive any other requests 116.


Moreover, support providers that have accepted a number of requests 116 above a quota, described above, may not be authorized to accept additional requests 116, while support providers that have accepted a number of requests 116 below the quota are authorized to accept additional requests 116. For instance, Support provider A above can be associated with a quota of 25 requests 116 per day. Accordingly, Support provider A can be authorized to accept up to 25 requests in a day but may be unauthorized to accept any request 116 that exceeds 25 requests. In an additional and/or alternative example, support providers that are compensated at a value above a predetermined value may not be authorized to accept certain requests 116.


In other examples, authorization data 144 can be determined based on resolved requests 116, ratings, and/or feedback associated with support providers. For instance, after a support provider resolves a number of requests 116 above a predetermined threshold the support provider can acquire new authorizations. The new authorizations can be reflected in the authorization data 114. Additionally and/or alternatively, after a support provider resolves a predetermined number of requests 116 including particular contextual data 137, the support provider can acquire new authorizations associated with the particular contextual data 137. The new authorizations can be reflected in the authorization data 114. In some examples, after a support provider meets or exceeds a predetermined rating, the support provider can acquire new authorizations. The new authorizations can be reflected in the authorization data 114. Alternatively, after a support provider falls below a predetermined rating, the support provider can lose authorizations. The change in authorizations can be reflected in the authorization data 114. In some examples, the support provider can acquire new authorizations and/or lose some authorizations based at least in part on feedback associated with the support provider. The change in authorizations can be reflected in the authorization data 114. In other examples, after a support provider meets or exceeds a predetermined ranking, the support provider can acquire new authorizations. The ranking can be based on feedback and/or ratings. The new authorizations can be reflected in the authorization data 114. Alternatively, after a support provider falls below a predetermined ranking, the support provider can lose authorizations. The change in authorizations can be reflected in the authorization data 114.


In some examples, the authorization data 144 can identify one or more roles associated with a support provider. Each role of the one or more roles can grant a support provider different authorizations. In a non-limiting example, the one or more roles can include an administrator role, a manager role, a support provider role, etc. As a non-limiting example, support providers associated with the administrator role can be authorized to receive a greatest number and/or variety of requests 116. In some examples, each support provider associated with the administrator role can have at least some of the same authorization data 144. Additionally and/or alternatively, support providers associated with the administrator role can be authorized to define authorizations for sub-support providers. In another non-limiting example, support providers associated with manager roles can be authorized to accept some requests 116 but not other requests 116. In some examples, each support provider associated with the manager role can have at least some of the same authorization data 144. The authorizations associated with the manager roles can be determined by support providers in the administrator role and/or based on additional and/or alternative data. For instance, in some examples, a support provider can be assigned a manager role based at least in part on support provider data associated with the support provider's profile and/or based on resolved requests 116, ratings, and/or feedback associated with support provider. In an additional non-limiting example, support providers associated with a support provider role can be authorized to accept a subset of requests 116 that the support providers associated with the manager roles and/or administrator roles are authorized to accept. In some examples, each support provider associated with the support provider role can have at least some of the same authorization data 144.


In some examples, each support provider and/or sub-support provider can be associated with a role. In additional and/or alternative examples, sub-support providers associated with each support provider can have individual roles. The roles can be predetermined by the service provider and/or a support provider and/or can be determined based on support provider data, feedback data, performance data, etc. In at least one example, a support provider can be assigned new roles based on resolving a predetermined number of requests 116, a predetermined number of requests 116 associated with particular contextual data 137, achieving a predetermined rating and/or ranking, etc. Additional and/or alternative roles can be defined.



FIG. 2 is a flow diagram illustrating aspects of a method for enabling real-time support of a request 116 based at least in part on authorization data 144 associated with support providers. It should be appreciated that the logical operations described herein with respect to FIG. 2, and the other FIGURES, can be implemented (1) as a sequence of computer implemented acts or program modules running on a computing system and/or (2) as interconnected machine logic circuits or circuit modules within the computing system.


The implementation of the various components described herein is a matter of choice dependent on the performance and other requirements of the computing system. Accordingly, the logical operations described herein are referred to variously as operations, structural devices, acts, or modules. These operations, structural devices, acts, and modules can be implemented in software, in firmware, in special purpose digital logic, and any combination thereof. It should also be appreciated that more or fewer operations can be performed than shown in the FIGURES and described herein. These operations can also be performed in parallel, or in a different order than those described herein. Some or all of these operations might also be performed by components other than those specifically identified.


Block 202 illustrates receiving/accessing authentication data 121 from support provider device(s) 106. As described above, the authentication module 142 can be configured for receiving and/or accessing authentication data 121 from support provider device(s) 106. As described above, in some examples, the authentication module 142 can receive authentication data 121 at an initial set-up of the support application on the support provider device 106. In such examples the authentication data 121 can be persistently stored in a support provider profile 132 corresponding to the support provider. In other examples, the authentication module 142 can receive authentication data 121 each time a support provider accesses the support application, after a session expires, after a lapse in a predetermined amount of time, etc.


Block 204 illustrates determining authorization data 144 associated with individual support provider profiles 132. As described above, authorization data 144 can be receive and/or accessed from any number of resources and authorization data 144 can be in any format. Authorization data 144 can enable the request routing module 134 to identify what requests 116 a support provider is authorized to accept based at least in part on authentication data 121. In some examples, authorization data 144 can be determined by the service provider associated with the support application based on data associated with support provider profile(s) 132, as described above. In at least one example, authorization data 144 associated with sub-support providers can be based on authorizations determined by corresponding support providers. In other examples, authorization data 144 can be determined based on resolved requests 116, ratings, and/or feedback associated with support providers, as described above.


Block 206 illustrates receiving a request from a device associated with a user (e.g., user device 104). In at least one example, the program module 112A can send requests 116 to the program module 112C. As described above, requests 116 can include onboarding requests, support requests, managing requests, troubleshooting requests, requests for directions, etc. In at least one example, the program module 112A can send requests 116 based at least in part on determining that a user actuates a control on a user interface associated with a product, a service, etc. As described below, the control can be caused to be presented based at least in part on a number of support providers that are available. In other examples, the program module 112A can send requests 116 based at least in part on receiving additional and/or alternative inputs including, but not limited to, voice input, gaze input, etc. In additional and/or alternative examples, the program module 112A can send requests 116 based at least in part on determining that a user has not interacted with a corresponding user device 104 for a predetermined amount of time. That is, the program module 112A can send requests 116 based at least in part on determining a user has been idle for a predetermined amount of time. In other examples, the program module 112A can send requests 116 without user input. For instance, the program module 112A can send requests 116 at a predetermined frequency, after a lapse of a predetermined period of time, responsive to and/or in anticipation of triggering events. Triggering events can include subscription expirations, subscription renewals, password expirations, new features, etc.


In at least one example, the program module 112A can determine that a user actuates a control configured to provide the user with functionality to submit a request 116 associated with at least one of a product, a service, etc. To prevent a situation where a user actuates the control and does not receive a response because the number of requests 116 substantially outweighs the number of available support providers, in some examples, the program module 112A may not cause the control to be presented until the program module 112C has determined that the number of support providers that are available exceeds a threshold number. In such an example, the program module 112C can access support provider data to determine a number of support providers that are available at a particular time. Based at least in part on determining that the number of support providers that are available at the particular time equals or exceeds a threshold value, the program module 112C can send data to the program module 112A and the program module 112A cause the control to be presented on the user interface. In some examples, the program module 112C can access authentication data 121 to determine a number of support providers that are available and authenticated at the particular time equals or exceeds a threshold value. A support provider can be authenticated based on the authorization module 144 receiving authentication data 121 and determining a support provider profile 132 and/or authorization data 144 corresponds to the authentication data 121. While the description above describes support providers, in some examples, sub-support providers can be considered in determining whether the threshold number of support providers are available and/or authenticated.


In some examples, data inputs can be associated with the control configured to provide the user with functionality to submit a request 116 associated with at least one of a product, a service, etc. In at least one example, a data input associated with a control can include a freeform text box for a user to input his or her contact information (e.g., phone number, email address, etc.). In some examples, the information requested via a data input can depend on the number of available support providers at a time a request 116 is submitted. In at least one example, based at least in part on determining that the number of available support providers meets or exceeds a threshold value, the program module 112A can cause a data input requesting a first type of information to be presented with the control. In an example, the first type of information can be a phone number. Additionally and/or alternatively, based at least in part on determining that the number of available support providers is below a threshold value, the program module 112A can cause a data input requesting a second type of information to be presented with the control. The second type of information can be different from the first type of information. For instance, the second type of information can be an email address. In additional and/or alternative examples, the data inputs can request contextual data 127, as described below.


Block 208 illustrates determining contextual data 127 associated with the request 116. The contextual data determination module 126 can be configured to receive, access, and/or generate contextual data 127. As described above, contextual data 127 can be received and/or accessed from any number of resources and contextual data 127 can be in any format. Contextual data 127 can be data that can define a status of an application associated with a product, service, etc., a status of an interface associated with a product, service, etc., etc. In at least one example, contextual data 127 can be obtained by an analysis of an application, an interface associated with a product, service, etc., as described above.


Block 210 illustrates determining one or more support providers that are authorized to receive the request 116. As described above, the request routing module 134 can be configured to determine one or more support providers for routing requests 116. The request routing module 134 can access user data associated with the user profile(s) 130 and/or support provider data associated with the support provider profile(s) 132. The request routing module 134 can access authorization data 144 associated with the support provider profile(s) 132. Additionally, the request routing module 134 can access the request 116 and/or the contextual data 127, as described above. The request routing module 134 can compare the request 116, the contextual data 127, and/or the user data with the support provider data and authorization data 144 and, based at least in part on comparing the request 116, the contextual data 127, and/or the user data with the support provider data and authorization data 144, can determine one or more support providers for supporting the request 116. Additional details associated with determining the one or more support providers for routing requests 116 is described above and also below in FIG. 3.


Block 212 illustrates generating task data 137 associated with the request 116. The task management module 136 can be configured to receive and/or access the request 116 and generate task data 137 that corresponds to the request 116. The task data 137 can include the request 116, contextual data 127, user data corresponding to the user who submitted the request 116 (e.g., name, contact information, etc.), a timestamp corresponding to when the user submitted the request 116, etc. The task management module 136 can arrange the task data 137 in task lists 122 associated with individual support providers of the one or more support providers selected by the request routing module 134 as described above. As described above, a task list 122 can include one or more tasks corresponding to individual requests 116.


Block 214 illustrates sending the task data 137 to devices corresponding to individual support providers (e.g., support provider device(s) 106). In at least one example, the task management module 136 can send a communication associated with the task data 137 to the support provider device(s) 106. In additional and/or alternative examples, the task management module 136 can cause a display of a graphical element corresponding to task data 137 to be presented as a task in a graphical representation of a task list 122 presented on devices corresponding to the one or more support providers (e.g., support provider device(s) 106) selected by the request routing module 134 as described above. In at least one example, support providers that have one or more sub-support providers can route the task data 137 to the sub-support providers. In other examples, the task management module 136 can route the task data 137 directly to the sub-support providers.


Block 216 illustrates determining a support provider of the one or more support providers accepts the request 116. The user interfaces associated with the task list(s) 122 can be configured to provide functionality for support providers to accept individual tasks on the task list(s) 122. As non-limiting examples, a support provider can actuate a control associated with a graphical representation of task data to indicate that the support provider acknowledges the task, or a support provider can interact with the graphical representation of task data to acknowledge the task. In at least one example, the task management module 136 can receive a response indicating that a support provider acknowledges a task and the task management module 136 can be configured to determine that a support provider accepts the task. The response can be associated with acknowledgment data indicating an acknowledgement of the task data. The task management module 136 can determine that the support provider accepts the task based at least in part on the acknowledgement data.


Block 218 illustrates causing a display of a graphical element indicating an acknowledgement of the task data. In at least one example, the program module 112C can generate a notification indicating the acknowledgement of the task data. The notification can include a display of a graphical element, an audio signal, a message, a status change of at least one component of a computing device, etc. In some examples, program module 112C can be configured to send a response to the user device 104. The response can include the notification that the request 116 has been accepted. In at least one example, the response can be associated with a push notification, a text message, an email, etc. In other examples, the response can be associated with a control and/or graphical element corresponding to the control that the program module 112A can cause to be presented on a user interface associated with a display of the user device 104. In some examples, the response can include information about when the user associated with the request 116 can expect to receive contact (e.g., a call, email, message, etc.) from the support provider, directions for performing an action, a mechanism for creating the shared meeting space, etc.



FIG. 3 is a flow diagram illustrating aspects of a method 300 for determining one or more support providers for supporting the request 116 and causing a graphical element corresponding to the request 116 to be presented on devices corresponding to the one or more support providers (e.g., support provider device(s) 106).


Block 302 illustrates receiving a request 116, as described above.


Block 304 illustrates determining contextual data 127, as described above.


Block 306 illustrates accessing user data. As described above, the data manager 128 can receive and/or access data associated with the individual users (e.g., user data). The user data can be stored in user profile(s) 130 corresponding to user identifier(s) 114. Non-limiting examples of data associated with the individual users can include an identity of the user, a number of employees employed by the user, a type of a subscription associated with the user (e.g., the level of support services the user subscribes), a length of the subscription associated with the user (e.g., how long the user has subscribed to the support services), a location of the user, a language of the user, a history of requests associated with the user, feedback provided by the user, etc. Additional and/or alternative types of data associated with the individual users are described above.


Block 308 illustrates accessing support provider data. As described above, the data manager 128 can receive and/or access data associated with the individual support providers (e.g., support provider data). In at least one example, the support provider data can be associated with authorization data 144, as described above. The support provider data can be stored in support provider profile(s) 132 corresponding to support provider identifier(s) 120. In at least one example, data associated with individual support providers can include an availability of a support provider, an expertise associated with the support provider, a language of the support provider, a geographic location of the support provider, feedback associated with the support provider, a rating associated with the support provider, a quota of requests 116 associated with the support provider, a compensation structure associated with the support provider, etc. The authorization data 144, as described above, can be data that can define authorizations of a support provider with respect to contextual data 137 associated with requests 116. Moreover, authorization data 144 can be data that can define authorizations of a support provider with respect to quotas and/or minimums associated with support providers, compensation structures associated with support providers, languages of support providers, geographic locations of support providers, ratings of support providers, etc. Additional and/or alternative types of data associated with the support providers are described above.


Block 310 illustrates determining one or more support providers for supporting the request 116 based at least in part on a correlation between the contextual data, user data, and/or support provider data. The request routing module 134 can access the user data and/or the support provider data. The request routing module 134 can access the authorization data 144. Additionally, the request routing module 134 can access the request 116 and/or the contextual data 127, as described above. The request routing module 134 can determine individual support providers to send the request 116 to based at least in part on comparing the request 116, contextual data 127, and/or user data with the support provider data and authorization data 144. In at least one example, the request routing module 134 can determine the individual support providers to route the request 116 to based on determining a correlation between the contextual data 127 and/or support provider data. Based at least in part on determining a correlation between the contextual data 127 and/or the support provider data, the request routing module 134 can utilize the authorization data 144 to determine whether a support provider is authorized to accept requests 116 before routing the requests 116 to the support providers. In some examples, the request routing module 134 can determine the individual support providers to route the request 116 to based on rules determined by the support application. In such examples, the request routing module 134 can leverage machine learning algorithms (e.g., supervised, unsupervised, deep learning, etc.) to determine rules for routing requests 116.


As a non-limiting example, the request routing module 134 can access user data and determine, from the user data, that a user is a valuable customer that has been a subscriber to a product for a period of time greater than a threshold amount of time. Additionally, the request routing module 134 can access the request 116 and/or contextual data 127. Based at least in part on analyzing the contextual data 127, the request routing module 116 can determine that the user is trying to migrate a domain and is stuck on the third step of a domain migration wizard application. Moreover, the request routing module 134 can access support provider data, and determine, from the support provider data, a plurality of individual support providers who have the expertise to resolve the request 116 (e.g., migrating the domain) and have a rating above a predetermined threshold. Furthermore, the request routing module 134 can access authorization data 144 to determine whether the plurality of individual support providers are authorized to receive the request 116. After confirming that each of the individual support providers of the plurality of individual support providers are authorized to receive the request 116, the request routing module 134 can determine to route the request to the plurality of individual support providers. That is, the request routing module 134 can route requests 116 from valuable customers to high rating support providers to maximize the satisfaction of the valuable customers.


In an additional and/or alternative non-limiting example, the request routing module 134 can access user data and determine, from the user data, that a user is an English speaking user who lives in Seattle, Wash. (e.g., Pacific Standard Time). Additionally, the request routing module 134 can access the request 116 and/or contextual data 127. Based at least in part on analyzing the contextual data 127, the request routing module 116 can determine that the user is trying to upload a photo via a social networking services application. Moreover, the request routing module 134 can access support provider data, and determine, from the support provider data, that a plurality of individual support providers who have the expertise to resolve the request 116 (e.g., upload a photo via the social networking services application), who are also English speaking and are located in a geographic location in a same time zone as the user or a time zone a predetermined number of time zones away from the same time zone as the user. Furthermore, the request routing module 134 can access authorization data 144 to determine whether the plurality of individual support providers are authorized to receive the request 116. After confirming that each of the individual support providers of the plurality of individual support providers are authorized to receive the request 116, the request routing module 134 can determine to route the request 116 to the plurality of individual support providers. That is, the request routing module 134 can route requests 116 associated with users who speak a certain language and live in a certain area with support providers who speak the same language and are in a similar time zone to maximize the satisfaction of the users.


In an additional and/or alternative non-limiting example, the request routing module 134 can access user data and determine, from the user data, that a user is a new user (e.g., a subscriber for a period of time below a threshold) and that the user has initiated a number of requests 116 above a predetermined frequency. Additionally, the request routing module 134 can access the request 116 and/or contextual data 127. Based at least in part on analyzing the contextual data 127, the request routing module 116 can determine that the user received a reminder about downloading security software in an electronic communication associated with a mail services application. Moreover, the request routing module 134 can access support provider data, and determine, from the support provider data, that a plurality of individual support providers who have the expertise to resolve the request 116 (e.g., recommend and help procure security software) and are associated with a compensation structure that pays the individual support providers at a rate below a threshold value (e.g., support providers who are compensated $1.00/request vs. support providers who are compensated $1000.00/request). Furthermore, the request routing module 134 can access authorization data 144 to determine whether the plurality of individual support providers are authorized to receive the request 116. After confirming that each of the individual support providers of the plurality of individual support providers are authorized to receive the request 116, the request routing module 134 can determine to route the request 116 to the plurality of individual support providers. That is, the request routing module 134 can route requests 116 associated with new users who frequently ask questions to support providers who are relatively inexpensive to maximize the satisfaction of the new users without causing excessive costs to a service provider (e.g., an entity ultimately paying the support providers for their support services).


Block 312 describes generating task data 137 associated with the request 116, as described above.


Block 314 illustrates sending the task data 137 to devices corresponding to individual support providers (e.g., support provider device(s) 106), as described above. While the description above is directed to support providers, the same method 300 can apply for sub-support providers. That is, in some examples, the request routing module 134 can consider sub-support providers to be support providers and may not distinguish between the two. In other examples, the request routing module 134 can consider the third-party entity support providers and the third-party entity support providers can route requests to the sub-support providers.



FIG. 4 is a flow diagram illustrating aspects of a method 400 for presenting user information corresponding to a request to a support provider based at least in part on the support provider accepting the request. FIG. 4 can represent a method from the perspective of the support provider device(s) 106.


Block 402 illustrates sending authentication data 121 to the authorization module 142, as described above. FIG. 5A is a block diagram showing an example user interface 500 presenting a mechanism 502 for a support provider to input authentication data 121. The mechanism 502 can vary depending on the type of authentication data 121 input by the support provider. In the non-limiting example illustrated in FIG. 5A, the mechanism 502 can be configured to enable the corresponding support provider to input a password. The program module 112B can be configured to send authentication data 121 to the authentication module 142.


Block 404 illustrates causing task data 137 to be communicated to at least one support provider. As described above, the task management module 136 can be configured to receive and/or access the requests 116 and generate task data 137 that corresponds to the requests 116. The task management module 136 can arrange the tasks in task lists 122 corresponding to individual support providers, based at least in part on the task data 137. The task management module 136 can send task data 137 and can cause graphical elements corresponding to the task data 137 to be presented in a graphical representation of a task list 122 on a user interface via a display of a corresponding support provider device(s) 106. As described above, in some examples, based at least in part on adding a new task to the task list 136, the task management module 136 can cause a notification to be presented to the support provider. The notification can include a push notification, text message, email, etc., that notifies the support provider that a new task has been added to the task list 122 corresponding to the support provider. In other examples, the support provider can simply view its task list 122 and observe that a new task has been added based at least in part on observing a new graphical element corresponding to the new task data 137. In at least one example, program module 112B can cause the task data to be communicated to the support provider.



FIG. 5B is a block diagram showing an example user interface 504 presenting a task list 124 including one or more tasks (e.g., 506A, 506B). Each task (e.g., 506A, 506B) is represented by a graphical element corresponding to task data 137 associated with each task. As illustrated in FIG. 5B, the task list 124 includes context data 118 associated with each task (e.g., 506A, 506B) (e.g., verify domain, onboard). The task list 124 illustrated in FIG. 5B can be associated with a particular support provider and other support providers can have same or different task lists 124 depending on how the request routing module 134 determines to route the requests 116. Additional or alternative layouts or presentations are available.


Returning to FIG. 4, block 406 illustrates sending acknowledgement data to the server 108. The user interface presenting the task list 122 can be configured to provide functionality for the support provider to accept individual tasks (e.g., 702A, 702B) on the task list 122 (e.g., via touch input, voice input, etc.). In at least one example, based at least in part on detecting input from the support provider via a corresponding support provider device 106 acknowledgement data indicating an acknowledgement of the task (e.g., 702A, 702B) can be generated. Based at least in part on the support provider accepting an individual task, acknowledgement data indicating that the acknowledgement can be sent to the server 108.


Block 408 illustrates causing a display of a graphical element indicating an acknowledgement of the task data 137, as described above.


Block 410 illustrates causing user information to be presented to the support provider. Based at least in part on determining that the support provider accepted the request 116, the task management module 126 can cause information associated with the user (e.g., phone number, email address, etc.) to be presented to the support provider via the support provider device(s) 106. FIG. 5C is a block diagram showing an example user interface 508 presenting user information 510 corresponding to a request 116. As shown in FIG. 5C, the user information 510 includes the name of the user (e.g., Amy Jacobs), context data 118 (e.g., needs help verifying her domain), and contact information (e.g., phone number). Additional and/or alternative data can be presented to the support provider.


While the description above is directed to support providers, the same method 400 can apply for sub-support providers.



FIG. 6 is a flow diagram illustrating aspects of a method 600 for ranking support providers based at least in part on ratings.


Block 602 illustrates receiving feedback data. As described above, the feedback module 138 can be configured to receive feedback data from users. Based at least in part on determining that a request 116 is resolved, the feedback module 138 can cause a mechanism for receiving feedback data to be sent to the program module 112A. In some examples, the feedback module 138 can cause a mechanism for receiving feedback data to be sent to the program module 112A based at least in part on determining that a request 116 timed out. The feedback module 138 can receive the feedback data via various mechanisms, as described above.


Block 604 illustrates determining performance data. The performance module 140 can determine performance data associated with users, individual support providers, individual sub-support providers and/or all support providers and/or sub-support providers who have support provider profile(s) 132 with the support application, as described above. The performance module 140 can determine performance data at a predetermined frequency (e.g., one time per hour, one time per day, etc.), after a lapse of a predetermined period of time (e.g., one hour, twenty-four hours, etc.), etc.


Block 606 illustrates determining a rating based on feedback data and/or performance data. The feedback module 138 can process the feedback data (e.g., via a heuristic, etc.) to determine a feedback rating associated with individual support providers and/or sub-support providers. Additionally and/or alternatively, the performance module 140 can process the performance data (e.g., via a heuristic, etc.) to determine a performance rating associated with individual support providers and/or sub-support providers. The rating associated with each support provider can be based on the feedback rating and/or the performance rating.


Block 608 illustrates ranking support providers and/or sub-support providers based at least in part on the support provider ratings. As described above, the performance module 140 can rank each of the support providers and/or sub-support providers based on ratings associated with the individual support providers and/or individual sub-support providers. For instance, in a non-limiting example, the performance module 140 can perform top-box/bottom-box percentile computations to determine how to rank each support provider. In some examples, the performance module 140 can rank the sub-support providers with the support providers (e.g., without distinguishing between the sub-support providers and the support providers). In other examples, the performance module 140 can rank the support providers and the sub-support providers can be ranked in the context of the third-party entity support provider.



FIG. 7 shows additional details of an example computer architecture 700 for a computer, such as user device(s) 104, support provider device(s) 106, and/or server(s) 108 (FIG. 1), capable of executing the program components described above for enabling support providers to integrate into a support application and provide real-time support for requests (e.g., onboarding requests, support requests, managing requests, troubleshooting requests, etc.) based at least partly on authorizations associated with the support providers. Thus, the computer architecture 700 illustrated in FIG. 7 illustrates an architecture for a server computer, mobile phone, a PDA, a smart phone, a desktop computer, a netbook computer, a tablet computer, and/or a laptop computer. The computer architecture 700 can be utilized to execute any aspects of the software components presented herein.


The computer architecture 700 illustrated in FIG. 7 includes a central processing unit 702 (“CPU”), a system memory 704, including a random access memory 706 (“RAM”) and a read-only memory (“ROM”) 708, and a system bus 710 that couples the memory 704 to the CPU 702. A basic input/output system containing the basic routines that help to transfer information between elements within the computer architecture 700, such as during startup, is stored in the ROM 706. The computer architecture 700 further includes a mass storage device 712 for storing an operating system 707, and one or more application programs, etc.


The mass storage device 712 is connected to the CPU 702 through a mass storage controller (not shown) connected to the bus 710. The mass storage device 712 and its associated computer-readable media provide non-volatile storage for the computer architecture 700. Although the description of computer-readable media contained herein refers to a mass storage device, such as a solid state drive, a hard disk or CD-ROM drive, it should be appreciated by those skilled in the art that computer-readable media can be any available computer storage media or communication media that can be accessed by the computer architecture 700.


Communication media includes computer readable instructions, data structures, program modules, or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any delivery media. The term “modulated data signal” means a signal that has one or more of its characteristics changed or set in a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared and other wireless media. Combinations of the any of the above should also be included within the scope of computer-readable media.


By way of example, and not limitation, computer storage media can include volatile and non-volatile, removable and non-removable media implemented in any method or technology for storage of information such as computer-readable instructions, data structures, program modules or other data. For example, computer media includes, but is not limited to, RAM, ROM, EPROM, EEPROM, flash memory or other solid state memory technology, CD-ROM, digital versatile disks (“DVD”), HD-DVD, BLU-RAY, or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by the computer architecture 700. For purposes the claims, the phrase “computer storage medium,” “computer-readable storage medium” and variations thereof, does not include waves, signals, and/or other transitory and/or intangible communication media, per se.


According to various configurations, the computer architecture 700 can operate in a networked environment using logical connections to remote computers through the network 104 and/or another network (not shown). The computer architecture 700 can connect to the network 104 through a network interface unit 714 connected to the bus 710. It should be appreciated that the network interface unit 714 also can be utilized to connect to other types of networks and remote computer systems. The computer architecture 700 also can include an input/output controller 716 for receiving and processing input from a number of other devices, including a keyboard, mouse, or electronic stylus (not shown in FIG. 7). Similarly, the input/output controller 716 can provide output to a display screen, a printer, or other type of output device (also not shown in FIG. 7).


It should be appreciated that the software components described herein can, when loaded into the CPU 702 and executed, transform the CPU 702 and the overall computer architecture 700 from a general-purpose computing system into a special-purpose computing system customized to facilitate the functionality presented herein. The CPU 702 can be constructed from any number of transistors or other discrete circuit elements, which can individually or collectively assume any number of states. More specifically, the CPU 702 can operate as a finite-state machine, in response to executable instructions contained within the software modules disclosed herein. These computer-executable instructions can transform the CPU 702 by specifying how the CPU 702 transitions between states, thereby transforming the transistors or other discrete hardware elements constituting the CPU 702.


Encoding the software modules presented herein also can transform the physical structure of the computer-readable media presented herein. The specific transformation of physical structure can depend on various factors, in different implementations of this description. Examples of such factors can include, but are not limited to, the technology used to implement the computer-readable media, whether the computer-readable media is characterized as primary or secondary storage, and the like. For example, if the computer-readable media is implemented as semiconductor-based memory, the software disclosed herein can be encoded on the computer-readable media by transforming the physical state of the semiconductor memory. For example, the software can transform the state of transistors, capacitors, or other discrete circuit elements constituting the semiconductor memory. The software also can transform the physical state of such components in order to store data thereupon.


As another example, the computer-readable media disclosed herein can be implemented using magnetic or optical technology. In such implementations, the software presented herein can transform the physical state of magnetic or optical media, when the software is encoded therein. These transformations can include altering the magnetic characteristics of particular locations within given magnetic media. These transformations also can include altering the physical features or characteristics of particular locations within given optical media, to change the optical characteristics of those locations. Other transformations of physical media are possible without departing from the scope and spirit of the present description, with the foregoing examples provided only to facilitate this discussion.


In light of the above, it should be appreciated that many types of physical transformations take place in the computer architecture 700 in order to store and execute the software components presented herein. It also should be appreciated that the computer architecture 700 can include other types of computing entities, including hand-held computers, embedded computer systems, personal digital assistants, and other types of computing entities known to those skilled in the art. It is also contemplated that the computer architecture 700 may not include all of the components shown in FIG. 7, can include other components that are not explicitly shown in FIG. 7, or can utilize an architecture completely different than that shown in FIG. 7.



FIG. 8 depicts an illustrative distributed computing environment 800 capable of executing the software components described herein for enabling support providers to integrate into a support application and provide real-time support for requests based at least partly on authorizations associated with the support providers. Thus, the distributed computing environment 800 illustrated in FIG. 8 can be utilized to execute any aspects of the software components presented herein. For example, the distributed computing environment 800 can be utilized to execute aspects of the techniques described herein.


According to various implementations, the distributed computing environment 800 includes a computing environment 802 operating on, in communication with, or as part of the network 104. In at least one example, at least some of computing environment 802 can correspond to the servers 108. The network 104 can be or can include the network 104, described above with reference to FIG. 7. The network 104 also can include various access networks. One or more client devices 806A-806N (hereinafter referred to collectively and/or generically as “clients 806”) can communicate with the computing environment 802 via the network 104 and/or other connections (not illustrated in FIG. 8). The client devices 806A-806N can correspond to any of user device(s) 104 and/or support provider device(s) 106 in



FIG. 1. In one illustrated configuration, the clients 806 include a computing device 806A such as a laptop computer, a desktop computer, or other computing device; a slate or tablet computing device (“tablet computing device”) 806B; a mobile computing device 806C such as a mobile telephone, a smart phone, or other mobile computing device; a server computer 806D; and/or other devices 806N. It should be understood that any number of clients 806 can communicate with the computing environment 802. Two example computing architectures for the clients 806 are illustrated and described herein with reference to FIGS. 7 and 9. It should be understood that the illustrated clients 806 and computing architectures illustrated and described herein are illustrative, and should not be construed as being limited in any way.


In the illustrated configuration, the computing environment 802 includes application servers 808, data storage 810, and one or more network interfaces 812. According to various implementations, the functionality of the application servers 808 can be provided by one or more server computers that are executing as part of, or in communication with, the network 104. The computing environment 802 can correspond to the servers 108 in FIG. 1. The application servers 808 can host various services, virtual machines, portals, and/or other resources. In the illustrated configuration, the application servers 808 can host one or more virtual machines for executing applications or other functionality. According to various implementations, the virtual machines can execute one or more applications and/or software modules for enabling support providers to integrate into a support application and provide real-time support for requests based at least partly on authorizations associated with the support providers. It should be understood that this configuration is illustrative, and should not be construed as being limiting in any way. The application servers 808 also host or provide access to one or more portals, link pages, Web sites, and/or other information (“Web portals”) 816. The Web portals 816 can be used to communicate with one or more client computers.


According to various implementations, the application servers 808 also include one or more mailbox services 818 and one or more messaging services 820. The mailbox services 818 can include electronic mail (“email”) services. The mailbox services 818 also can include various personal information management (“PIM”) services including, but not limited to, calendar services, contact management services, collaboration services, and/or other services. The messaging services 820 can include, but are not limited to, instant messaging services, chat services, forum services, and/or other communication services.


The application servers 808 also may include one or more social networking services 822. The social networking services 822 can include various social networking services including, but not limited to, services for sharing or posting status updates, instant messages, links, photos, videos, and/or other information; services for commenting or displaying interest in articles, products, blogs, or other resources; and/or other services. In some configurations, the social networking services 822 are provided by or include the FACEBOOK social networking service, the LINKEDIN professional networking service, the MYSPACE social networking service, the FOURSQUARE geographic networking service, the YAMMER office colleague networking service, and the like. In other configurations, the social networking services 822 are provided by other services, sites, and/or providers that may or may not be explicitly known as social networking providers. For example, some web sites allow users to interact with one another via email, chat services, and/or other means during various activities and/or contexts such as reading published articles, commenting on goods or services, publishing, collaboration, gaming, and the like. Examples of such services include, but are not limited to, the WINDOWS LIVE service and the XBOX LIVE service from Microsoft Corporation in Redmond, Wash. Other services are possible and are contemplated.


The social networking services 822 also can include commenting, blogging, and/or micro blogging services. Examples of such services include, but are not limited to, the YELP commenting service, the KUDZU review service, the OFFICETALK enterprise micro blogging service, the TWITTER messaging service, the GOOGLE BUZZ service, and/or other services. It should be appreciated that the above lists of services are not exhaustive and that numerous additional and/or alternative social networking services 822 are not mentioned herein for the sake of brevity. As such, the above configurations are illustrative, and should not be construed as being limited in any way. According to various implementations, the social networking services 822 may host one or more applications and/or software modules for providing the functionality described herein for providing contextually-aware location sharing services for computing devices. For instance, any one of the application servers 808 may communicate or facilitate the functionality and features described herein. For instance, a social networking application, mail client, messaging client, a browser running on a phone or any other client 806 may communicate with a networking service 822.


As shown in FIG. 8, the application servers 808 also can host other services, applications, portals, and/or other resources (“other resources”) 824. The other resources 824 can deploy a service-oriented architecture or any other client-server management software. It thus can be appreciated that the computing environment 802 can provide integration of the technologies disclosed herein provided herein with various mailbox, messaging, social networking, and/or other services or resources.


As mentioned above, the computing environment 802 can include the data storage 810. According to various implementations, the functionality of the data storage 810 is provided by one or more databases operating on, or in communication with, the network 104. The functionality of the data storage 810 also can be provided by one or more server computers configured to host data for the computing environment 802. The data storage 810 can include, host, or provide one or more real or virtual containers 826A-826N (hereinafter referred to collectively and/or generically as “containers 826”). Although not illustrated in FIG. 8, the containers 826 also can host or store data structures and/or algorithms for execution by a module, such as the program module 112A, etc. Aspects of the containers 826 can be associated with a database program, file system and/or any program that stores data with secure access features. Aspects of the containers 826 can also be implemented using products or services, such as ACTIVE DIRECTORY, DKM, ONEDRIVE, DROPBOX or GOOGLEDRIVE.


The computing environment 802 can communicate with, or be accessed by, the network interfaces 812. The network interfaces 812 can include various types of network hardware and software for supporting communications between two or more computing entities including, but not limited to, the clients 806 and the application servers 808. It should be appreciated that the network interfaces 812 also can be utilized to connect to other types of networks and/or computer systems.


It should be understood that the distributed computing environment 800 described herein can provide any aspects of the software elements described herein with any number of virtual computing resources and/or other distributed computing functionality that can be configured to execute any aspects of the software components disclosed herein. According to various implementations of the technologies disclosed herein, the distributed computing environment 800 provides the software functionality described herein as a service to the clients 806. It should be understood that the clients 806 can include real or virtual machines including, but not limited to, server computers, web servers, personal computers, mobile computing entities, smart phones, and/or other devices. As such, various configurations of the technologies disclosed herein enable any device configured to access the distributed computing environment 800 to utilize the functionality described herein for enabling support providers to integrate into a support application and provide real-time support for requests based at least partly on authorizations associated with the support providers, among other aspects. In one specific example, as summarized above, techniques described herein can be implemented, at least in part, by a web browser application that can work in conjunction with the application servers 808 of FIG. 8.


Turning now to FIG. 9, an illustrative computing device architecture 900 for a computing device that is capable of executing various software components described herein for enabling support providers to integrate into a support application and provide real-time support for requests based at least partly on authorizations associated with the support providers. The computing device architecture 900 is applicable to computing entities that facilitate mobile computing due, in part, to form factor, wireless connectivity, and/or battery-powered operation. In some configurations, the computing entities include, but are not limited to, mobile telephones, tablet devices, slate devices, portable video game devices, and the like. The computing device architecture 900 is applicable to any of the clients 806 shown in FIG. 8 (e.g., user device(s) 104, support provider device(s) 106, etc.). Moreover, aspects of the computing device architecture 900 can be applicable to traditional desktop computers, portable computers (e.g., laptops, notebooks, ultra-portables, and netbooks), server computers, and other computer systems, such as described herein with reference to FIG. 8 (e.g., server (108)). For example, the single touch and multi-touch aspects disclosed herein below can be applied to desktop computers that utilize a touchscreen or some other touch-enabled device, such as a touch-enabled track pad or touch-enabled mouse.


The computing device architecture 900 illustrated in FIG. 9 includes a processor 902, memory components 904, network connectivity components 906, sensor components 908, input/output components 910, and power components 912.


In the illustrated configuration, the processor 902 is in communication with the memory components 904, the network connectivity components 906, the sensor components 908, the input/output (“I/O”) components 910, and the power components 912. Although no connections are shown between the individuals components illustrated in FIG. 9, the components can interact to carry out device functions. In some configurations, the components are arranged so as to communicate via one or more busses (not shown).


The processor 902 includes a central processing unit (“CPU”) configured to process data, execute computer-executable instructions of one or more application programs, and communicate with other components of the computing device architecture 900 in order to perform various functionality described herein. The processor 902 can be utilized to execute aspects of the software components presented herein and, particularly, those that utilize, at least in part, a touch-enabled input.


In some configurations, the processor 902 includes a graphics processing unit (“GPU”) configured to accelerate operations performed by the CPU, including, but not limited to, operations performed by executing general-purpose scientific and/or engineering computing applications, as well as graphics-intensive computing applications such as high resolution video (e.g., 920P, 1080P, and higher resolution), video games, three-dimensional (“3D”) modeling applications, and the like. In some configurations, the processor 902 is configured to communicate with a discrete GPU (not shown). In any case, the CPU and GPU can be configured in accordance with a co-processing CPU/GPU computing model, wherein the sequential part of an application executes on the CPU and the computationally-intensive part is accelerated by the GPU.


In some configurations, the processor 902 is, or is included in, a system-on-chip (“SoC”) along with one or more of the other components described herein below. For example, the SoC can include the processor 902, a GPU, one or more of the network connectivity components 906, and one or more of the sensor components 908. In some configurations, the processor 902 is fabricated, in part, utilizing a package-on-package (“PoP”) integrated circuit packaging technique. The processor 902 can be a single core or multi-core processor.


The processor 902 can be created in accordance with an ARM architecture, available for license from ARM HOLDINGS of Cambridge, United Kingdom. Alternatively, the processor 902 can be created in accordance with an x86 architecture, such as is available from INTEL CORPORATION of Mountain View, Calif. and others. In some configurations, the processor 902 is a SNAPDRAGON SoC, available from QUALCOMM of San Diego, Calif., a TEGRA SoC, available from NVIDIA of Santa Clara, Calif., a HUMMINGBIRD SoC, available from SAMSUNG of Seoul, South Korea, an Open Multimedia Application Platform (“OMAP”) SoC, available from TEXAS INSTRUMENTS of Dallas, Tex., a customized version of any of the above SoCs, or a proprietary SoC.


The memory components 904 include a random access memory (“RAM”) 914, a read-only memory (“ROM”) 916, an integrated storage memory (“integrated storage”) 918, and a removable storage memory (“removable storage”) 920. In some configurations, the RAM 914 or a portion thereof, the ROM 916 or a portion thereof, and/or some combination the RAM 914 and the ROM 916 is integrated in the processor 902. In some configurations, the ROM 916 is configured to store a firmware, an operating system or a portion thereof (e.g., operating system kernel), and/or a bootloader to load an operating system kernel from the integrated storage 918 and/or the removable storage 920.


The integrated storage 918 can include a solid-state memory, a hard disk, or a combination of solid-state memory and a hard disk. The integrated storage 918 can be soldered or otherwise connected to a logic board upon which the processor 902 and other components described herein also can be connected. As such, the integrated storage 918 is integrated in the computing device. The integrated storage 918 is configured to store an operating system or portions thereof, application programs, data, and other software components described herein.


The removable storage 920 can include a solid-state memory, a hard disk, or a combination of solid-state memory and a hard disk. In some configurations, the removable storage 920 is provided in lieu of the integrated storage 918. In other configurations, the removable storage 920 is provided as additional optional storage. In some configurations, the removable storage 920 is logically combined with the integrated storage 918 such that the total available storage is made available as a total combined storage capacity. In some configurations, the total combined capacity of the integrated storage 918 and the removable storage 920 is shown to a user instead of separate storage capacities for the integrated storage 918 and the removable storage 920.


The removable storage 920 is configured to be inserted into a removable storage memory slot (not shown) or other mechanism by which the removable storage 920 is inserted and secured to facilitate a connection over which the removable storage 920 can communicate with other components of the computing device, such as the processor 902. The removable storage 920 can be embodied in various memory card formats including, but not limited to, PC card, CompactFlash card, memory stick, secure digital (“SD”), miniSD, microSD, universal integrated circuit card (“UICC”) (e.g., a subscriber identity module (“SIM”) or universal SIM (“USIM”)), a proprietary format, or the like.


It can be understood that one or more of the memory components 904 can store an operating system. According to various configurations, the operating system includes, but is not limited to, SYMBIAN OS from SYMBIAN LIMITED, WINDOWS MOBILE OS from Microsoft Corporation of Redmond, Wash., WINDOWS PHONE OS from Microsoft Corporation, WINDOWS from Microsoft Corporation, PALM WEBOS from Hewlett-Packard Company of Palo Alto, Calif., BLACKBERRY OS from Research In Motion Limited of Waterloo, Ontario, Canada, IOS from Apple Inc. of Cupertino, Calif., and ANDROID OS from Google Inc. of Mountain View, Calif. Other operating systems are contemplated.


The network connectivity components 906 include a wireless wide area network component (“WWAN component”) 922, a wireless local area network component (“WLAN component”) 924, and a wireless personal area network component (“WPAN component”) 926. The network connectivity components 906 facilitate communications to and from the network 104 or another network, which can be a WWAN, a WLAN, or a WPAN. Although only the network 104 is illustrated, the network connectivity components 906 can facilitate simultaneous communication with multiple networks, including the network 104 of FIG. 9. For example, the network connectivity components 906 can facilitate simultaneous communications with multiple networks via one or more of a WWAN, a WLAN, or a WPAN.


The network 104 can be or can include a WWAN, such as a mobile telecommunications network utilizing one or more mobile telecommunications technologies to provide voice and/or data services to a computing device utilizing the computing device architecture 900 via the WWAN component 922. The mobile telecommunications technologies can include, but are not limited to, Global System for Mobile communications (“GSM”), Code Division Multiple Access (“CDMA”) ONE, CDMA2000, Universal Mobile Telecommunications System (“UMTS”), Long Term Evolution (“LTE”), and Worldwide Interoperability for Microwave Access (“WiMAX”). Moreover, the network 104 can utilize various channel access methods (which can or cannot be used by the aforementioned standards) including, but not limited to, Time Division Multiple Access (“TDMA”), Frequency Division Multiple Access (“FDMA”), CDMA, wideband CDMA (“W-CDMA”), Orthogonal Frequency Division Multiplexing (“OFDM”), Space Division Multiple Access (“SDMA”), and the like. Data communications can be provided using General Packet Radio Service (“GPRS”), Enhanced Data rates for Global Evolution (“EDGE”), the High-Speed Packet Access (“HSPA”) protocol family including High-Speed Downlink Packet Access (“HSDPA”), Enhanced Uplink (“EUL”) or otherwise termed High-Speed Uplink Packet Access (“HSUPA”), Evolved HSPA (“HSPA+”), LTE, and various other current and future wireless data access standards. The network 104 can be configured to provide voice and/or data communications with any combination of the above technologies. The network 104 can be configured to or adapted to provide voice and/or data communications in accordance with future generation technologies.


In some configurations, the WWAN component 922 is configured to provide dual-multi-mode connectivity to the network 104. For example, the WWAN component 922 can be configured to provide connectivity to the network 104, wherein the network 104 provides service via GSM and UMTS technologies, or via some other combination of technologies. Alternatively, multiple WWAN components 922 can be utilized to perform such functionality, and/or provide additional functionality to support other non-compatible technologies (i.e., incapable of being supported by a single WWAN component). The WWAN component 922 can facilitate similar connectivity to multiple networks (e.g., a UMTS network and an LTE network).


The network 104 can be a WLAN operating in accordance with one or more Institute of Electrical and Electronic Engineers (“IEEE”) 802.11 standards, such as IEEE 802.11a, 802.11b, 802.11g, 802.11n, and/or future 802.11 standard (referred to herein collectively as WI-FI). Draft 802.11 standards are also contemplated. In some configurations, the WLAN is implemented utilizing one or more wireless WI-FI access points. In some configurations, one or more of the wireless WI-FI access points are another computing device with connectivity to a WWAN that are functioning as a WI-FI hotspot. The WLAN component 924 is configured to connect to the network 104 via the WI-FI access points. Such connections can be secured via various encryption technologies including, but not limited, WI-FI Protected Access (“WPA”), WPA2, Wired Equivalent Privacy (“WEP”), and the like.


The network 104 can be a WPAN operating in accordance with Infrared Data Association (“IrDA”), BLUETOOTH, wireless Universal Serial Bus (“USB”), Z-Wave, ZIGBEE, or some other short-range wireless technology. In some configurations, the WPAN component 926 is configured to facilitate communications with other devices, such as peripherals, computers, or other computing entities via the WPAN.


The sensor components 908 include a magnetometer 928, an ambient light sensor 930, a proximity sensor 932, an accelerometer 934, a gyroscope 936, and a Global Positioning System sensor (“GPS sensor”) 938. It is contemplated that other sensors, such as, but not limited to, temperature sensors or shock detection sensors, also can be incorporated in the computing device architecture 900.


The magnetometer 928 is configured to measure the strength and direction of a magnetic field. In some configurations the magnetometer 928 provides measurements to a compass application program stored within one of the memory components 904 in order to provide a user with accurate directions in a frame of reference including the cardinal directions, north, south, east, and west. Similar measurements can be provided to a navigation application program that includes a compass component. Other uses of measurements obtained by the magnetometer 928 are contemplated.


The ambient light sensor 930 is configured to measure ambient light. In some configurations, the ambient light sensor 930 provides measurements to an application program stored within one the memory components 904 in order to automatically adjust the brightness of a display (described below) to compensate for low-light and high-light environments. Other uses of measurements obtained by the ambient light sensor 930 are contemplated.


The proximity sensor 932 is configured to detect the presence of an object or thing in proximity to the computing device without direct contact. In some configurations, the proximity sensor 932 detects the presence of a user's body (e.g., the user's face) and provides this information to an application program stored within one of the memory components 904 that utilizes the proximity information to enable or disable some functionality of the computing device. For example, a telephone application program can automatically disable a touchscreen (described below) in response to receiving the proximity information so that the user's face does not inadvertently end a call or enable/disable other functionality within the telephone application program during the call. Other uses of proximity as detected by the proximity sensor 928 are contemplated.


The accelerometer 934 is configured to measure proper acceleration. In some configurations, output from the accelerometer 934 is used by an application program as an input mechanism to control some functionality of the application program. For example, the application program can be a video game in which a character, a portion thereof, or an object is moved or otherwise manipulated in response to input received via the accelerometer 934. In some configurations, output from the accelerometer 934 is provided to an application program for use in switching between landscape and portrait modes, calculating coordinate acceleration, or detecting a fall. Other uses of the accelerometer 934 are contemplated.


The gyroscope 936 is configured to measure and maintain orientation. In some configurations, output from the gyroscope 936 is used by an application program as an input mechanism to control some functionality of the application program. For example, the gyroscope 936 can be used for accurate recognition of movement within a 3D environment of a video game application or some other application. In some configurations, an application program utilizes output from the gyroscope 936 and the accelerometer 934 to enhance control of some functionality of the application program. Other uses of the gyroscope 936 are contemplated.


The GPS sensor 938 is configured to receive signals from GPS satellites for use in calculating a location. The location calculated by the GPS sensor 938 can be used by any application program that requires or benefits from location information. For example, the location calculated by the GPS sensor 938 can be used with a navigation application program to provide directions from the location to a destination or directions from the destination to the location. Moreover, the GPS sensor 938 can be used to provide location information to an external location-based service, such as E911 service. The GPS sensor 938 can obtain location information generated via WI-FI, WIMAX, and/or cellular triangulation techniques utilizing one or more of the network connectivity components 906 to aid the GPS sensor 938 in obtaining a location fix. The GPS sensor 938 can also be used in Assisted GPS (“A-GPS”) systems.


The I/O components 910 include a display 940, a touchscreen 942, a data I/O interface component (“data I/O”) 944, an audio I/O interface component (“audio I/O”) 946, a video I/O interface component (“video I/O”) 948, and a camera 950. In some configurations, the display 940 and the touchscreen 942 are combined. In some configurations two or more of the data I/O component 944, the audio I/O component 946, and the video I/O component 948 are combined. The I/O components 910 can include discrete processors configured to support the various interface described below, or can include processing functionality built-in to the processor 902.


The display 940 is an output device configured to present information in a visual form. In particular, the display 940 can present graphical user interface (“GUI”) elements, text, images, video, notifications, virtual buttons, virtual keyboards, messaging data, Internet content, device status, time, date, calendar data, preferences, map information, location information, and any other information that is capable of being presented in a visual form. In some configurations, the display 940 is a liquid crystal display (“LCD”) utilizing any active or passive matrix technology and any backlighting technology (if used). In some configurations, the display 940 is an organic light emitting diode (“OLED”) display. Other display types are contemplated.


The touchscreen 942, also referred to herein as a “touch-enabled screen,” is an input device configured to detect the presence and location of a touch. The touchscreen 942 can be a resistive touchscreen, a capacitive touchscreen, a surface acoustic wave touchscreen, an infrared touchscreen, an optical imaging touchscreen, a dispersive signal touchscreen, an acoustic pulse recognition touchscreen, or can utilize any other touchscreen technology. In some configurations, the touchscreen 942 is incorporated on top of the display 940 as a transparent layer to enable a user to use one or more touches to interact with objects or other information presented on the display 940. In other configurations, the touchscreen 942 is a touch pad incorporated on a surface of the computing device that does not include the display 940. For example, the computing device can have a touchscreen incorporated on top of the display 940 and a touch pad on a surface opposite the display 940.


In some configurations, the touchscreen 942 is a single-touch touchscreen. In other configurations, the touchscreen 942 is a multi-touch touchscreen. In some configurations, the touchscreen 942 is configured to detect discrete touches, single touch gestures, and/or multi-touch gestures. These are collectively referred to herein as gestures for convenience. Several gestures will now be described. It should be understood that these gestures are illustrative and are not intended to limit the scope of the appended claims. Moreover, the described gestures, additional gestures, and/or alternative gestures can be implemented in software for use with the touchscreen 942. As such, a developer can create gestures that are specific to a particular application program.


In some configurations, the touchscreen 942 supports a tap gesture in which a user taps the touchscreen 942 once on an item presented on the display 940. The tap gesture can be used for various reasons including, but not limited to, opening or launching whatever the user taps. In some configurations, the touchscreen 942 supports a double tap gesture in which a user taps the touchscreen 942 twice on an item presented on the display 940. The double tap gesture can be used for various reasons including, but not limited to, zooming in or zooming out in stages. In some configurations, the touchscreen 942 supports a tap and hold gesture in which a user taps the touchscreen 942 and maintains contact for at least a pre-defined time. The tap and hold gesture can be used for various reasons including, but not limited to, opening a context-specific menu.


In some configurations, the touchscreen 942 supports a pan gesture in which a user places a finger on the touchscreen 942 and maintains contact with the touchscreen 942 while moving the finger on the touchscreen 942. The pan gesture can be used for various reasons including, but not limited to, moving through screens, images, or menus at a controlled rate. Multiple finger pan gestures are also contemplated. In some configurations, the touchscreen 942 supports a flick gesture in which a user swipes a finger in the direction the user wants the screen to move. The flick gesture can be used for various reasons including, but not limited to, scrolling horizontally or vertically through menus or pages. In some configurations, the touchscreen 942 supports a pinch and stretch gesture in which a user makes a pinching motion with two fingers (e.g., thumb and forefinger) on the touchscreen 942 or moves the two fingers apart. The pinch and stretch gesture can be used for various reasons including, but not limited to, zooming gradually in or out of a website, map, or picture.


Although the above gestures have been described with reference to the use one or more fingers for performing the gestures, other appendages such as toes or objects such as styluses can be used to interact with the touchscreen 942. As such, the above gestures should be understood as being illustrative and should not be construed as being limiting in any way.


The data I/O interface component 944 is configured to facilitate input of data to the computing device and output of data from the computing device. In some configurations, the data I/O interface component 944 includes a connector configured to provide wired connectivity between the computing device and a computer system, for example, for synchronization operation purposes. The connector can be a proprietary connector or a standardized connector such as USB, micro-USB, mini-USB, or the like. In some configurations, the connector is a dock connector for docking the computing device with another device such as a docking station, audio device (e.g., a digital music player), or video device.


The audio I/O interface component 946 is configured to provide audio input and/or output capabilities to the computing device. In some configurations, the audio I/O interface component 946 includes a microphone configured to collect audio signals. In some configurations, the audio I/O interface component 946 includes a headphone jack configured to provide connectivity for headphones or other external speakers. In some configurations, the audio I/O interface component 946 includes a speaker for the output of audio signals. In some configurations, the audio I/O interface component 946 includes an optical audio cable out.


The video I/O interface component 948 is configured to provide video input and/or output capabilities to the computing device. In some configurations, the video I/O interface component 948 includes a video connector configured to receive video as input from another device (e.g., a video media player such as a DVD or BLURAY player) or send video as output to another device (e.g., a monitor, a television, or some other external display). In some configurations, the video I/O interface component 948 includes a High-Definition Multimedia Interface (“HDMI”), mini-HDMI, micro-HDMI, DisplayPort, or proprietary connector to input/output video content. In some configurations, the video I/O interface component 948 or portions thereof is combined with the audio I/O interface component 946 or portions thereof.


The camera 950 can be configured to capture still images and/or video. The camera 950 can utilize a charge coupled device (“CCD”) or a complementary metal oxide semiconductor (“CMOS”) image sensor to capture images. In some configurations, the camera 950 includes a flash to aid in taking pictures in low-light environments. Settings for the camera 950 can be implemented as hardware or software buttons.


Although not illustrated, one or more hardware buttons can also be included in the computing device architecture 900. The hardware buttons can be used for controlling some operational aspect of the computing device. The hardware buttons can be dedicated buttons or multi-use buttons. The hardware buttons can be mechanical or sensor-based.


The illustrated power components 912 include one or more batteries 952, which can be connected to a battery gauge 954. The batteries 952 can be rechargeable or disposable. Rechargeable battery types include, but are not limited to, lithium polymer, lithium ion, nickel cadmium, and nickel metal hydride. Each of the batteries 952 can be made of one or more cells.


The battery gauge 954 can be configured to measure battery parameters such as current, voltage, and temperature. In some configurations, the battery gauge 954 is configured to measure the effect of a battery's discharge rate, temperature, age and other factors to predict remaining life within a certain percentage of error. In some configurations, the battery gauge 954 provides measurements to an application program that is configured to utilize the measurements to present useful power management data to a user. Power management data can include one or more of a percentage of battery used, a percentage of battery remaining, a battery condition, a remaining time, a remaining capacity (e.g., in watt hours), a current draw, and a voltage.


The power components 912 can also include a power connector, which can be combined with one or more of the aforementioned I/O components 910. The power components 912 can interface with an external power system or charging equipment via a power I/O component.


A. A computing device, comprising: a processor; a computer-readable storage medium in communication with the processor, the computer-readable storage medium having computer-executable instructions stored thereupon which, when executed by the processor, cause the computing device to: access authentication data associated with a plurality of support providers; receive a request associated with at least one of a product or a service; determine contextual data associated with the request, the contextual data defining a status of an application associated with the product or the service; determine one or more individual support providers for supporting the request based at least in part on the contextual data; determine authorization data associated with the one or more individual support providers, the authorization data defining requests that the individual support providers are authorized to receive; based, at least in part, on the authorization data, determine that the one or more individual support providers are authorized to receive the request; generate task data associated with the request; send the task data to devices corresponding to the one or more individual support providers; receive acknowledgement data indicating an acknowledgement of the task data from a device of the devices corresponding to an individual support provider of the one or more individual support providers; determine that the individual support provider accepts the request based at least in part on the acknowledgement data; and cause a display of a graphical element indicating the acknowledgement of the task data.


B. The computing device as paragraph A recites, wherein the contextual data defines at least one of a status of a web browser application, a status of a wizard application, a status of an interface of the application, a status of a mail services application or a messaging services application, or a status of a social networking services application.


C. The computing device as paragraph B recites, wherein the computing device is further configured determine, from the authorization data, that the one or more individual support providers are authorized to receive the request based at least in part on the contextual data.


D. The computing device as any of paragraphs A-C recite, wherein the computing device is further configured to: determine roles associated with individual support provider profiles corresponding to the one or more individual support providers; and determine, from the authorization data, that the one or more individual support providers are authorized to receive the request based at least in part on the roles associated with the corresponding support provider profiles.


E. The computing device as any of paragraphs A-D recite, wherein the computing device is further configured to: determine compensation structures associated with individual support provider profiles corresponding to the one or more individual support providers; and determine, from the authorization data, that the one or more individual support providers are authorized to receive the request based at least in part on the compensation structures.


F. The computing device as any of paragraphs A-E recite, wherein the computing device is further configured to: determine quotas associated with individual support provider profiles corresponding to the one or more individual support providers, a quota comprising a maximum number of requests that an individual support provider can accept in a predetermined period of time; and determine, from the authorization data, that the one or more individual support providers are authorized to receive the request based at least in part on the quotas.


G. The computing device as any of paragraphs A-F recite, wherein the computing device is further configured to: determine ratings associated with individual support provider profiles corresponding to the one or more individual support providers; and determine, from the authorization data, that the one or more individual support providers are authorized to receive the request based at least in part on the ratings.


H. The computing device as any of paragraphs A-G recite, wherein the computing device is further configured to: determine rankings associated with individual support provider profiles corresponding to the one or more individual support providers; and determine, from the authorization data, that the one or more individual support providers are authorized to receive the request based at least in part on the rankings.


I. The computing device as any of paragraphs A-H recite, having computer-executable instructions stored thereupon that cause the computing device to provide an interface configured to receive at least one of the authentication data, data associated with the request, the contextual data, the acknowledgement data, or feedback data, wherein the interface is configured to transmit at least one of the task data including the contextual data, the authorization data, or performance data.


J. A computer-implemented method, comprising computer-implemented operations for: receiving authentication data from a plurality of support provider devices; receiving a request associated with at least one of a product or a service; determining contextual data associated with the request, the contextual data defining a status of an application associated with the product or the service; determining, based at least in part on the authentication data, authorization data corresponding to support provider profiles associated with the plurality of support provider devices; determining, from data associated with a plurality of support providers and the authentication data, one or more support providers that are authorized to support the request; generating task data associated with the request, the task data including the contextual data; sending the task data to devices corresponding to the one or more support providers; receiving acknowledgement data indicating an acknowledgement of the task data from a device of the devices corresponding to an individual support provider of the one or more support providers; determining that the individual support provider accepts the request; and causing a display of a first graphical element indicating at least one of the acknowledgement of the task data and a mechanism for creating a shared meeting space.


K. The computer-implemented method as paragraph J recites, wherein at least some of the plurality of support providers are freelance support providers.


L. The computer-implemented method as paragraphs J or K recite, wherein at least some of the plurality of support providers are third-party entities that employ one or more sub-support providers.


M. The computer-implemented method as paragraph L recites, wherein the third-party entities route the request to an individual sub-support provider of the one or more sub-support providers.


N. The computer-implemented method as any of paragraphs J-M recite, comprising computer-implemented operations for: causing a display of a second graphical element comprising a control configured to provide functionality to generate the request in response to an actuation of the control; and receiving the request based at least in part on receiving data indicating that the control was actuated.


O. The computer-implemented method as paragraph N recites, comprising computer-implemented operations for: determining, based on the authentication data, a number of support providers in the plurality of support providers that are signed into the support provider profiles and are authenticated; determining that the number meets or exceeds a threshold value; and based at least in part on determining that the number meets or exceeds the threshold value, causing the display of the second graphical element.


P. The computer-implemented method as any of paragraphs J-O recite, wherein determining the one or more support providers for supporting the request comprises: accessing the data associated with the plurality of support providers, the data defining at least one of an availability associated with the individual support providers, an expertise associated with the individual support providers, a rating associated with the individual support providers, a language of the individual support providers, a geographic location of the individual support providers, a quota of requests associated with the individual support providers, or a compensation structure associated with the individual support providers; determining a correlation between the contextual data and the data associated with the plurality of support providers; and determining the one or more support providers based at least in part on determining the correlation between the contextual data and the data associated with the plurality of support providers.


Q. One or more computer-readable media encoded with instructions that, when executed by a processor, configure a computer to perform a method as any of paragraphs J-P recite.


R. A device comprising one or more processors and one or more computer readable media encoded with instructions that, when executed by the one or more processors, configure a computer to perform a computer-implemented method as any of paragraphs J-P recite.


S. One or more computer storage media having computer-executable instructions that, when executed by one or more processors, configure the one or more processors to perform operations comprising: receiving a request associated with a product or a service; determining contextual data associated with the request, the contextual data defining a status of an application associated with the product or the service; accessing data associated with a plurality of support providers associated with remote devices, the data associated with the plurality of support providers including authorization data; causing a selection of one or more support providers of the plurality of support providers based at least in part on a correlation between the contextual data and the data associated with the plurality of support providers; sending a communication of the request comprising the contextual data to remote devices associated with the one or more support providers; receiving acknowledgement data indicating acknowledgement of the communication from a remote device of the remote devices corresponding to an individual support provider of the one or more support providers; determining that the individual support provider accepts the request based at least in part on the acknowledgment data; and generating a notification indicating the acknowledgement of the communication, wherein the notification comprises a display of a graphical element, an audio signal, a message, or a status change of at least one component of a computing device.


T. One or more computer storage media as paragraph S recites, wherein operations further comprise: at least one of accessing authentication data corresponding to the plurality of support providers or receiving authentication data from support provider devices corresponding to the plurality of support providers; and determining the authorization data based at least in part on the authentication data.


U. One or more computer storage media as paragraphs S or T recite, wherein operations further comprise: determining performance data associated with the individual support provider; determining a rating associated with the individual support provider based at least in part on the performance data; and ranking the individual support provider and one or more other individual support providers based at least in part on the rating.


V. One or more computer storage media as any of paragraphs S-U recite, wherein operations further comprise: determining that the individual support provider resolves the request; based at least in part on determining that the individual support provider resolves the request, sending a mechanism to a user device to prompt a user associated with the user device for feedback data; determining a rating associated with the individual support provider based at least in part on the feedback data; and ranking the individual support provider and one or more other support providers based at least in part on the rating.


Based on the foregoing, it should be appreciated that technologies have been disclosed herein that enable real-time support for requests 116 based at least in part on contextual data 127. Although the subject matter presented herein has been described in language specific to computer structural features, methodological and transformative acts, specific computing machinery, and computer readable media, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features, acts, or media described herein. Rather, the specific features, acts and mediums are disclosed as example forms of implementing the claims.


The subject matter described above is provided by way of illustration only and should not be construed as limiting. Various modifications and changes can be made to the subject matter described herein without following the example configurations and applications illustrated and described, and without departing from the true spirit and scope of the present invention, which is set forth in the following claims.

Claims
  • 1. A computing device, comprising: a processor;a computer-readable storage medium in communication with the processor, the computer-readable storage medium having computer-executable instructions stored thereupon which, when executed by the processor, cause the computing device to: access authentication data associated with a plurality of support providers;receive a request associated with at least one of a product or a service;determine contextual data associated with the request, the contextual data defining a status of an application associated with the product or the service;determine one or more individual support providers for supporting the request based at least in part on the contextual data;determine authorization data associated with the one or more individual support providers, the authorization data defining requests that the individual support providers are authorized to receive;based, at least in part, on the authorization data, determine that the one or more individual support providers are authorized to receive the request;generate task data associated with the request;send the task data to devices corresponding to the one or more individual support providers;receive acknowledgement data indicating an acknowledgement of the task data from a device of the devices corresponding to an individual support provider of the one or more individual support providers;determine that the individual support provider accepts the request based at least in part on the acknowledgement data; andcause a display of a graphical element indicating the acknowledgement of the task data.
  • 2. The computing device as claim 1 recites, wherein the contextual data defines at least one of a status of a web browser application, a status of a wizard application, a status of an interface of the application, a status of a mail services application or a messaging services application, or a status of a social networking services application.
  • 3. The computing device as claim 2 recites, wherein the computing device is further configured determine, from the authorization data, that the one or more individual support providers are authorized to receive the request based at least in part on the contextual data.
  • 4. The computing device as claim 1 recites, wherein the computing device is further configured to: determine roles associated with individual support provider profiles corresponding to the one or more individual support providers; anddetermine, from the authorization data, that the one or more individual support providers are authorized to receive the request based at least in part on the roles associated with the corresponding support provider profiles.
  • 5. The computing device as claim 1 recites, wherein the computing device is further configured to: determine compensation structures associated with individual support provider profiles corresponding to the one or more individual support providers; anddetermine, from the authorization data, that the one or more individual support providers are authorized to receive the request based at least in part on the compensation structures.
  • 6. The computing device as claim 1 recites, wherein the computing device is further configured to: determine quotas associated with individual support provider profiles corresponding to the one or more individual support providers, a quota comprising a maximum number of requests that an individual support provider can accept in a predetermined period of time; anddetermine, from the authorization data, that the one or more individual support providers are authorized to receive the request based at least in part on the quotas.
  • 7. The computing device as claim 1 recites, wherein the computing device is further configured to: determine ratings associated with individual support provider profiles corresponding to the one or more individual support providers; anddetermine, from the authorization data, that the one or more individual support providers are authorized to receive the request based at least in part on the ratings.
  • 8. The computing device as claim 1 recites, wherein the computing device is further configured to: determine rankings associated with individual support provider profiles corresponding to the one or more individual support providers; anddetermine, from the authorization data, that the one or more individual support providers are authorized to receive the request based at least in part on the rankings.
  • 9. The computing device as claim 1 recites, having computer-executable instructions stored thereupon that cause the computing device to provide an interface configured to receive at least one of the authentication data, data associated with the request, the contextual data, or the acknowledgement data, wherein the interface is configured to transmit at least the task data including the contextual data.
  • 10. A computer-implemented method, comprising computer-implemented operations for: receiving authentication data from a plurality of support provider devices;receiving a request associated with at least one of a product or a service;determining contextual data associated with the request, the contextual data defining a status of an application associated with the product or the service;determining, based at least in part on the authentication data, authorization data corresponding to support provider profiles associated with the plurality of support provider devices;determining, from data associated with a plurality of support providers and the authentication data, one or more support providers that are authorized to support the request;generating task data associated with the request, the task data including the contextual data;sending the task data to devices corresponding to the one or more support providers;receiving acknowledgement data indicating an acknowledgement of the task data from a device of the devices corresponding to an individual support provider of the one or more support providers;determining that the individual support provider accepts the request; andcausing a display of a first graphical element indicating at least one of the acknowledgement of the task data and a mechanism for creating a shared meeting space.
  • 11. The computer-implemented method as claim 10 recites, wherein at least some of the plurality of support providers are freelance support providers.
  • 12. The computer-implemented method as claim 10 recites, wherein at least some of the plurality of support providers are third-party entities that employ one or more sub-support providers.
  • 13. The computer-implemented method as claim 12 recites, wherein the third-party entities route the request to an individual sub-support provider of the one or more sub-support providers.
  • 14. The computer-implemented method as claim 10 recites, comprising computer-implemented operations for: causing a display of a second graphical element comprising a control configured to provide functionality to generate the request in response to an actuation of the control; andreceiving the request based at least in part on receiving data indicating that the control was actuated.
  • 15. The computer-implemented method as claim 14 recites, comprising computer-implemented operations for: determining, based on the authentication data, a number of support providers in the plurality of support providers that are signed into the support provider profiles and are authenticated;determining that the number meets or exceeds a threshold value; andbased at least in part on determining that the number meets or exceeds the threshold value, causing the display of the second graphical element.
  • 16. The computer-implemented method as claim 10 recites, wherein determining the one or more support providers for supporting the request comprises: accessing the data associated with the plurality of support providers, the data defining at least one of an availability associated with the individual support providers, an expertise associated with the individual support providers, a rating associated with the individual support providers, a language of the individual support providers, a geographic location of the individual support providers, a quota of requests associated with the individual support providers, or a compensation structure associated with the individual support providers;determining a correlation between the contextual data and the data associated with the plurality of support providers; anddetermining the one or more support providers based at least in part on determining the correlation between the contextual data and the data associated with the plurality of support providers.
  • 17. One or more computer storage media having computer-executable instructions that, when executed by one or more processors, configure the one or more processors to perform operations comprising: receiving a request associated with a product or a service;determining contextual data associated with the request, the contextual data defining a status of an application associated with the product or the service;accessing data associated with a plurality of support providers associated with remote devices, the data associated with the plurality of support providers including authorization data;causing a selection of one or more support providers of the plurality of support providers based at least in part on a correlation between the contextual data and the data associated with the plurality of support providers;sending a communication of the request comprising the contextual data to remote devices associated with the one or more support providers;receiving acknowledgement data indicating acknowledgement of the communication from a remote device of the remote devices corresponding to an individual support provider of the one or more support providers;determining that the individual support provider accepts the request based at least in part on the acknowledgment data; andgenerating a notification indicating the acknowledgement of the communication, wherein the notification comprises a display of a graphical element, an audio signal, a message, or a status change of at least one component of a computing device.
  • 18. One or more computer storage media as claim 17 recites, wherein operations further comprise: at least one of accessing authentication data corresponding to the plurality of support providers or receiving authentication data from support provider devices corresponding to the plurality of support providers; anddetermining the authorization data based at least in part on the authentication data.
  • 19. One or more computer storage media as claim 17 recites, wherein operations further comprise: determining performance data associated with the individual support provider;determining a rating associated with the individual support provider based at least in part on the performance data; andranking the individual support provider and one or more other individual support providers based at least in part on the rating.
  • 20. One or more computer storage media as claim 17 recites, wherein operations further comprise: determining that the individual support provider resolves the request;based at least in part on determining that the individual support provider resolves the request, sending a mechanism to a user device to prompt a user associated with the user device for feedback data;determining a rating associated with the individual support provider based at least in part on the feedback data; andranking the individual support provider and one or more other support providers based at least in part on the rating.