High consideration purchases do not work with today's e-commerce platforms. E-commerce has been solely focused on automation and cost reduction. High consideration purchases require a live conversation with an advisor (not a high-pressure salesman), establishing trust in the consumer by providing personal recommendations to the consumer.
One advisor may help multiple clients simultaneously and receive commission based compensation. Advisor ranking allows more business to be given to better advisors and advisors are matched to a client's need. Though better matching, direct communication, personalized advice, and a custom curation, clients feel a personal connection which results in a high conversion rate and repeat business. The custom curation is a personalized recommendation of at least one product based upon a category of interest, determined client intent, and a conversation between the client and an advisor. Advantageously, clients have a higher confidence that they are purchasing the right item since with advice the client purchases the right product the first time, which results in a higher client satisfaction and a lower product return rate, as compared to conventional ecommerce sites. Clients may share their advisors with their network (referrals/network effect) resulting in additional leads.
In one embodiment, a method manages interaction between one advisor of a plurality of advisors and a client. Client intent is determined based upon request details that indicate a category of interest to the client. The one advisor is selected from the plurality of advisors to advise the client based, at least in part, upon the category of interest and the client intent. The client is added to a sales pipeline of the one advisor, and the one advisor is prompted, at intervals, to interact with the client. The one advisor is prompted to generate a curation for the client, and the curation is sent to the client.
In another embodiment, a path module includes a path builder having machine readable instructions stored in memory that, when executed by at least one processor, cause the processor to implement an interface for creating and editing sets of question types and answer types to form a path schema. The path module also includes a selection algorithm having machine readable instructions stored in the memory that, when executed by the processor, cause the at least one processor to generate a path flow based, at least in part, upon the path schema, the path flow comprising at least one web page with a set of questions for receiving request details from a client. The request details include at least one answer to one or more of the set of questions.
In another embodiment, a client trust interface method has optimized workflow and includes specifying a spend on leads to identify a plurality of clients; capturing intent of one client of the plurality of clients; matching one advisor of a plurality of advisors to the one client; triggering actions of the one advisor to correspond with the one client; and generating a curation based at least in part upon request details of the one client.
In another embodiment, a client trust interface system includes a workload optimizer for determining a current workload of each of a plurality of advisors and for determining a workload capacity of each of the plurality of advisors. The workload optimizer defines a spend for generating new leads based upon the current workload and the workload capacity of each of the plurality of advisors. The client trust interface system also includes a client interface for interacting with each of a plurality of clients to determine intent of each of the plurality of clients, and an advisor matcher for matching one advisor of the plurality of advisors with one client of the plurality of clients based upon the intent of the one client and a capability of the one advisor. The client trust interface system also includes a trigger algorithm for prompting a next action for the one advisor based upon a history of actions by the one advisor and responses by the one client, and a communication channel controller (path) for switching between communication channels to maintain communication between the one client and the one advisor.
In another embodiment, an e-commerce method for card fraud protection includes: determining, at an e-commerce site, a value to be charged to a card of a client; generating a random code; including the random code in a transaction for the card; sending the transaction to a card provider corresponding to the card, wherein the transaction is posted as pending in a transaction list of an account corresponding to the card; receiving, from the client, a code value determined from display of the transaction; and finalizing the transaction with the card provider for the value to be charged when the code value matches the random code.
Systems and methods disclosed herein describe an advance in e-commerce sites and include a computer based platform where independent advisors may enroll with the system to communicate with clients through multiple online channels, and provide advice, make tailored product and service recommendations (curations), and sell products to the clients. The advisor may earn a commission and gratuity on sold products. However, by providing advisors (e.g., experts in specific products and services, sometimes referred to as “experts” herein) that interact with potential clients, product sales are increased multifold as compared to e-commerce sites that do not provides advisors.
One aspect of the present embodiments includes the realization that clients require greater confidence when purchasing products and services above a certain price range. For example, a client is unlikely to purchase a new sailing boat costing $100,000 by simply selecting a ‘buy now” button on a web page advertising the sailing boat. The present embodiments solve this problem by matching the client with an advisor (who may also be known as an expert) on the product, or in a field of the product, and allowing the advisor to create tailored product and service recommendations (a curation) for the client based upon the client's needs. Advantageously, interaction with the advisor and receiving the curation builds client confidence in making the purchase.
Another aspect of the present embodiments includes the realization that lack of trust to make a purchase may result from a client being uncertain as to which product, variant, etc., they should purchase to meet their needs. The present embodiments solve this problem by automatically interacting with the client to determine intent and needs of the client and then automatically selecting an advisor who will best help the client make correct product choices through their experience in the product field. The advisor not only answers the client's questions about the product, but, through awareness of the client's intent, experience, and demographic, may advise the client on selecting the most appropriate product to meet the client's needs. Advantageously, the interaction with the advisor builds client confidence to make the purchase.
Another aspect of the present embodiments includes the realization that an advisor may have conversations with hundreds of clients, each client having different needs, budgets, timescales, etc., and that it is therefore difficult for the advisor to prioritize conversations and keep track of which ones need responses and/or follow-ups. The present embodiments solve this problem by providing the advisor with sales pipeline (e.g., an interactive dashboard) that displays folders for tracking and prioritizing the advisor's conversations, and recommends the best next step to be taken with the client.
System 100 receives leads 109, identifying a particular client 106 and a product category 107 that the client 106 is interested in, from at least one lead generator 108. Each lead 109 directly corresponds to one client 106 and the term lead and client may be used interchangeably herein. Lead generator 108 is for example a service that provides leads based upon advertising, social media, and so on. Examples of lead generator 108 include Google™ Facebook™, etc.
For each product category 107, system 100 may implement at least one path flow 110 that defines question types, answer types, and an order of questions that may be used to generate a path flow as a series of interactive screens designed to learn, from client 106, information about the client's interest in certain products within that product category. For example, based, at least in part, upon lead 109 that identifies client 106 and indicates an interest in golf, system 100 automatically invites client 106 to interact with path flow 110 corresponding to golf. In other embodiments, where lead 109 does not indicate any categories 107, path flow 110 may be selected to learn (e.g., a screen where client selects one of categories 107) which category 107 client 106 is interested in. System 100 processes the interaction (e.g., responses, selections, comments, timing, etc.) made by client 106 to automatically determine intent 112 of client 106 towards one or more golf products. For example, as client 106 interacts with path flow 110, system 100 may track the amount of time the client spends viewing information of product 105 (e.g., a certain brand and selection of golf clubs), thereby learning intent 112 of client 106 towards product 105. Path flow 110 may also allow system 100 to learn more about client 106, such as a skill level, time investment level, and so on. For example, system 100 may learn whether client 106 is a good golfer (low handicap), intermediate golfer (average handicap), or just beginning to play golf.
System 100 may then select a most suitable advisor 102 that is available to help advise client 106 on selection of product 105. For example, system 100 selects advisor 102 based upon the indicated product category 107, client characteristics 111, and client intent 112. System 100 provides advisor 102 with a sales pipeline 114 that allows advisor 102 to converse with client 106 and build confidence in the client's understanding and suitability of product 105 for their needs. Sales pipeline 114 is based upon folders that allow advisor 102 to easily track and prioritize conversations (see for example conversation 270,
At a certain point in conversation 270 between client 106 and advisor 102, system 100 may generate recommended action 115 to prompt advisor 102 to generate curation 116 tailoring product 105 towards needs of client 106. For example, as shown in
Advantageously, by matching advisor 102 to needs and intent 112 of client 106, and providing client 106 with a personal curation 116 for product 105, client 106 is at least six times more likely to purchase product 105 as compares to client 106 finding product 105 on a website without conversing with advisor 102.
Functionality of system 100 is implemented through cooperation of a plurality of software modules including a path module 202, a workload optimizer 204, a trigger module 206, a lead ranking algorithm 208, an advisor matcher 210 (e.g., an algorithm—see also
System 100 implements an attribute store 220, shown as lead store 220(1), advisor store 220(2), path store 220(3), and trigger store 220(4), that facilitates core functionality of system 100 by providing advanced data storage and search capabilities specifically tailored to operation of system 100. Attribute store 220 provides flexible, but structured, storage for “sellables” (e.g., products and services), path schemas (e.g., path schema 308,
An attribute schema is created to define an attribute (e.g., information types, data, etc.) for storage within attribute store 220 and encodes a range of information such as the attribute name, display name, formatting rules, validation rules, inferred attributes, and many others. Table 1 through Table 12 show example fields and code of an attribute schema for use within the attribute store 220 of
Table 1 through Table 3 show example fields of an attribute schema for use within attribute store 220.
Table 4 shows an attribute search function and Table 10 shows the associated code for this enumeration.
Table 5 shows how enumeration values are mapped between internal names and display names.
Inferring missing attributes has two major components; “mappers,” and the missing attribute metadata that says which and how a specific mapper should be used to fill it out. In certain situations, it is useful to infer values for missing attributes, for example when client 106 does not provide such data. Inferring missing attributes has two major components; “mappers,” and the missing attribute metadata that says which and how a specific mapper should be used to fill it out. Table 6 and Table 7 show example information for attached MissingAttribute metadata for a “charterDurationType.” Mappers may be hard coded within attribute storage 220, since these mappers are used for specific purposes, including gender, winter sports skill level, and so on. However, generic mappers are also supported for use in many cases. In these examples, “enum value mapper” may be created to take enumeration values from one attribute, and transform them into enum values for another attribute, using a mapping table. Attribute values contain the attribute schema and a list of zero or more values of the attribute schema data type.
Table 12 shows a list of example trigger events used within system 100 of
In one embodiment, attribute storage 220 has over five-hundred attribute schemas defined. These attribute schemas allow data to be programmatically used to automatically build recommendations around certain attributes.
Multi-channel communication 214 assigns a unique contact number 265 (e.g., a text/telephone number) to each advisor 102 and assigns a unique email address 267 to each advisor 102. For example, when advisor 102 joins system 100 for the first time, multi-channel communication 214 assigns unique contact number 265 and unique email address 267 to advisor 102. Contact number 265 and email address 267 remain consistent (e.g., do not change and are not used for anyone else) for advisor 102 such that when a previous client uses contact number 265 and/or email address 267 outside of any conversation 270, system 100 will automatically forward that communication to advisor 102. Where the corresponding advisor 102 is no longer working as an advisor with system 100, system 100 may automatically forward the communication to another suitable advisor 102.
Multi-channel communications 214 may implement one or more of an application interface 262, a web interface 264, a SMS interface 266, and an email interface 268, and may implement other communication interfaces as needed. Application interface 262 provides communication with a client application 282 running on a mobile communication device 280 (e.g., a smartphone, tablet computer, etc.) of client 106(1) and with an advisor application 290 running on a mobile communication device 288 of advisor 102(1). Web interface 264 may implement one or more web sites that allow (a) client 106(2) to use a browser 286 running on a computer 284 (e.g., a desktop, laptop, mobile, table or any other type of computer) to access system 100 and (b) advisor 102(2) to use a browser 294 running on a computer 292 (e.g., a desktop, laptop, mobile, table or any other type of computer) to access system 100. Application interface 262 and/or web interface 264 may also indicate when each client 106 and/or advisor 102 is online (e.g., logged into system 100). SMS interface 266 allows system 100 to communicate with clients 106 using short-message-service (e.g., texts), such as when client 106 has a message waiting but has not logged into system 100 for a defined period, or when texting is a preferred method of communication for client 106. Similarly, email interface 268 allows system 100 to communicate with clients 106 using email, such as when email is the preferred communication method for client 106. Multi-channel communication 214 manages these different communication methods seamlessly within system 100, allowing the client 106 to change between methods and automatically adopting the method used by the client for following communications.
In certain embodiments, when client 106 uses a particular communication channel (e.g., sends a message to advisor 102 using SMS), multi-channel communications 214 automatically switches future communications to use that channel (e.g., system 100 may respond using SMS). However, if the communication channel does not appear to be successful (e.g., system 100 sends a SMS to client 106, but client 106 has not responded within a defined period), multi-channel communications 214 may resend the message using a different channel (e.g., via client application 282 and/or email interface 268). Advantageously, multi-channel communication 214 makes communication familiar and natural for both client 106 and advisor 102.
SMS interface 266 automatically forwards text messages received for contact number 265 to the appropriate conversation 270 within sales pipeline 114 for viewing by advisor 102. Any text message sent to contact number 265 is delivered to system 100 (e.g., not delivered directly to a mobile device of advisor 102). Similarly, all email messages sent to email address 267 are delivered to system 100 and are then forwarded to the appropriate conversation 270. Advantageously, advisor 102 may view the messages in the correct context of conversation 270. When advisor 102 sends a text message and/or email message to client 106, multi-channel communication 214 automatically sends the message from the appropriate contact number 265 and/or email address 267. Advantageously, to client 106, the communications with advisor 102 appears personal and direct to further build confidence in conversation 270.
Where multi-channel communication 214 determines that client 106 is currently online (e.g., connected through client application 282 and/or browser 286), messages from advisor 102 to client 106 are first sent through the online channel (e.g., via application interface 262 or web interface 264). However, where the client is not online, or has not read a waiting message for a defined period, multi-channel communication 214 may automatically send the waiting message via one or both of SMS interface 266 and/or email interface 268. advantageously, through multi-channel communication 214, messages are not lost when a particular communication channel fails.
Multi-channel communication 214 makes communication between client 106 and advisor 102 simple, natural and convenient for client 106. For example, to continue a conversation, client 106 may use any convenient channel (e.g., text, email, web browser, application) and is not otherwise restricted. Different environments of client 106 may make one communication channel more convenient that others, and/or may make other communication channels less convenient. Advantageously, multi-channel communication 214 automatically switches between channels. Further, multi-channel communication 214 combines the multi-channels into a single conversation thread for advisor 102, such that advisor 102 is not affected by the different channels used by client 106. Therefore, advisor 102 sees the entire conversation irrespective of which communication channel was used. Where client 106 switches channels (e.g., from email to SMS), system 100 may automatically include one SMS message that introduces the conversation and includes a link that allows client 106 to review previous communications without having to search for previous emails.
As shown in
A designer 303 (e.g., an operator/manager) of system 100 may use an interactive design tool 302 to interactively and graphically create and store at least one path schema 308 in a path store 220(3). In certain embodiments, each path schema 308 may be associated with a specific category 107 (e.g., winter sports or golf) and is used to generate path flow 110 for a particular client 106. Unlike conventional survey type interactive screens, each question and/or answer of path flow 110 may include an attribute that links the question/answer with specific products 217 of e-commerce module 216, one or more of categories 107, and/or other parameters of system 100. For example, where client 106, during interaction with path flow 110, selects winter sports, subsequently asked questions/answers may include a winter sport attribute, such that these questions/answers are specifically related to that category. For the golf category, where the product is a golf club, questions and answers relating to one of shaft stiffness and shaft length may have corresponding attributes of shaft stiffness and shaft length. This provides a distinct advantage over prior art survey procedures, where answers alone are recorded and the answer must be interpreted in view of the question to discern the relevance of the answer. By including attributes with questions of path flow 110 and corresponding attributes with answers in request details 113 (e.g., answers and selections provided by client 106), path flow 110 prompts client 106 to provide request details 113 that are immediately usable by system 100.
When a new lead 109 is received from lead generator 108, path module 202 may operate automatically, without direction from any person, and invoke a selection algorithm 306 to generate, based, at least in part, upon category information of lead 109, one path flow 110 based upon path schema 308 from path store 220(3). For example, where lead 109 indicates an interest of client 106 in the golf category, selection algorithm 306 selects one path schema 308 corresponding to the golf category and generates path flow 110. Each category has at least one path schema 308, for example where each path schema 308 corresponds to a sub-category. Using the above example, the golf category may have sub-categories of golf clubs and golf carts, each with a corresponding path schema 308 that may be used to generate a more relevant path flow 110 for client 106.
Path module 202 invites client 106, identified within new lead 109, to interact, via web interface 264 (or application interface 262 where client 106 uses client application 282), with the generated path flow 110, and collects request details 113 (e.g., selections, textual responses, timing of response, and so on) from that interaction. When client 106 has completed path flow 110, path module 202 may invoke a classifier 310 (e.g., an artificial intelligence based analyzer) to process request details 113 and determine intent 112 of client 106 towards one or more products 105. For example, classifier 310 may determine intent 112 as an experienced golfer in need of a full set of new golf clubs. Advantageously, through operation of path module 202, system 100 learns more detail of client 106, including intent 112 of client 106 towards product 105.
System 100 relies upon advisors 102 to provide advice to clients 106 such that the clients purchase products through e-commerce module 216. Path module 202 may also be used by system 100 to recruit new advisors 102. See “Automated Advisor Recruitment” below for further details.
Path module 202 also implements path flow statistics that allow a designer of path schemas 308 to determine which paths, questions, and branches are more effective than others. See “Flow Optimizer” below.
System 100 pays money (referred to as “spend”) to receive new leads 109 from lead generator 108. Conventionally, spend is controlled by a marketing campaign; however, workload optimizer 204 of system 100 automatically controls spend for each category 107. Where spend is too high, too many new leads 109 are received from lead generator 108 and some may not get assigned to, or accepted by, an advisor 102; thus, the money spent to receive the lead is wasted. On the other hand, when system 100 receives too few leads 109 from lead generator 108, one or more advisors 102 may not have enough leads 109 to follow, resulting in the advisor becoming less engaged with system 100. Workload optimizer 204 controls the number of new leads 109 acquired from lead generator(s) 108 based, at least in part, on real time capacity of system 100 to process these leads, and availability of advisors 102. Accordingly, workload optimizer 204 automatically balances the spend against the capacity of system 100.
In the example of table 2900, column 2902 lists categories 107 of system 100 including electric bikes 107(1), golf 107(2), mountain bikes 107(3), skis 107(4), snowboards 107(5), and yacht carter 107(6). However, more or fewer categories may be included without departing from the scope hereof. Column 2904 groups advisors 102 within each category based upon rank 428. As described in more detail below, advisor ranker 404 (
Each advisor 102 may provide a working schedule 426 that defines when advisor 102 will be online with system 100. Workload optimizer 204 uses at least rank 428 and schedule 426 to determine a work capacity of advisor 102. Further Workload optimizer 204 then determines the workload (column 2908) and capacity of system 100 more accurately, workload optimizer 204 evaluates each rank (e.g.,) of advisor in each category.
In certain embodiments, when workload optimizer 204 determines that new leads 109 are not being assigned to advisors 102 (e.g., because advisors are offline or are already too busy to accept new leads), workload optimizer 204 may automatically notify offline advisors 102 that new leads 109 are available. Particularly, workload optimizer 204 optimizes the workload (e.g., current number of active conversations 270 taking place) based upon a number of leads 109 requested and the number of advisors 102 online, to maximize throughput of system 100. Capacity of system 100 may be defined as a total number of active conversations 270 that may be currently handled, which is computed as a sum of the number of advisors 102 by rank tier (e.g., bronze, silver, gold, platinum) times an average number of active conversations 270 one advisor 102 in that rank tier can handle. For example, at the lowest rank tier of bronze, each advisor may only handle one conversation at any one time; at the silver rank tier each advisor may handle two conversations at any one time; at the gold rank tier each advisor may handle four conversations at any one time; and at the platinum rank tier each advisor may handle eight conversations at any one time.
Workload optimizer 204 may automatically decrease workload of system 100 when fewer advisors 102 are online. Workload optimizer 204 modulates, in real-time, an amount of money spent to acquire new leads 109 through lead generator 108 (e.g., a paid campaign based on the availability of resources (advisors 102) to work on these new leads. For example, workload optimizer 204 automatically reduces the amount of money spent on new leads when fewer advisors are online, and automatically increases the amount of money spent on obtaining new leads when more advisors come online. In certain embodiments, the amount of money spent on new leads is a combination of a marketing campaign budget. In certain other embodiments, the amount of money spent on new leads is an amount bid for a click against an ad platform, such as Facebook. When the amount of money spent on new leads is increased (or the bid for the click is increased), the number of new leads that sent to system 100 increases. Conversely, when the amount of money spent on new leads is decreased (or bid for the click is decreased), the number of new leads sent to system 100 decreases. In certain embodiments, adjustment of the amount to spend on new leads has an almost instantaneous effect on the number of new leads being received by system 100. In other embodiments, an effect of adjustment of the amount to spend on new leads may take more time (e.g., hours) to affect the number of new leads being received by system 100.
In one embodiment, system 100 automatically increases capacity when the workload increases (e.g., when a number of leads receive by system 100 increases), by notifying advisors 102 to come online. In another embodiment, system 100 automatically adjusts other factors (e.g., game dynamics —brownie points, stars, points to get to the next rank tier) or implements other techniques to entice more advisors to come online.
System 100 operates with many advisors 102, each with his or her own operating schedule. As such, system 100 does not impose a working schedule on advisors 102. Each of the plurality of advisors 102 are experienced to advise clients 106 in at least one of the categories 107 supported by system 100, and advisors 102 collectively cover all supported categories 107. A capacity for system 100 to handle new leads 109 is based, at least in part, upon a number of available (e.g., online, or expected to be online) advisors 102, advisor current workload, and advisor capacity to handle more leads. System 100 includes an advisor store 220(2) that has advisor information 242 for each advisor 102. Advisor information 242 includes a unique identifier (ID) 422, advisor characteristics 424, a work schedule 426, a rank 428, a current workload 430, and a workload cap 432. Advisor ID 422 and characteristics 424 (e.g., gender, age, geographic location, qualifications, skills, other demographics, and so on) uniquely identify the advisor 102 and define the advice that advisor 102 may provide to client 106. Schedule 426 defines an expected work schedule for advisor 102. For example, schedule 426 may define a number of hours advisor 102 is expecting to be logged in to system 100 each day, indicate when advisor 102 is unavailable, and so on.
Workload optimizer 204 includes an advisor ranker 404 that may be invoked, at intervals, to determine a current rank 428 of each advisor 102 within system 100 based upon current and past performance of each advisor 102. For example, system 100 tracks conversations 270, curations 116, and client commitments 272 (illustratively shown within sales pipeline 114), a number of current conversations 270 that advisor 102 is participating in, how may leads 109 resulted in a positive outcome, and so on, to determine one or more of workload 430 and rank 428 of each advisor 102. Rank 428 indicates the ability and success of advisor 102 in providing advice to clients 106, and may therefore be used to select one of the plurality of advisors 102 registered with system 100 for handling a new lead 109.
Workload optimizer 204 includes a capacity calculator 402 that is invoked to determine a new lead capacity 406 for system 100 for an upcoming period (e.g., the next day) based, at least in part, upon a current workload 430 of each advisor 102, schedule 426 of each advisor 102, and a workload cap 432 of each advisor 102. For example, based upon current workload 430 of each advisor 102, capacity calculator 402 may determine how much spare capacity each advisor has. Capacity calculator 402 may then compare a current lead rate 408 (e.g., a current number of leads per day being received) against new lead capacity 406 (e.g., an estimated number of leads system 100 can handle) to determine a new lead rate 410 (e.g., a number of leads required for the upcoming period). New lead rate 410 may also be known as a lead spend rate, since it defines a marketing cost of obtaining the required number of new leads from lead generator 108.
In certain embodiments, workload optimizer 204 may also invoke capacity calculator 402 and advisor ranker 404, at intervals (e.g., hourly), to determine how well system 100 is currently handling new leads 109 from lead generator 108. For example, a current lead rate 408 (e.g., a rate at which new leads 109 are being supplied by lead generator 108) may be based, at least in part, upon previously determined new lead rate 140 for the current period. However, where advisors 102 are unavailable, advisor matcher 210 may be unable to assign new leads 109 to advisors 102. Accordingly, when capacity calculator 402 determines that new leads 109 are not being assigned and/or handled, capacity calculator 402 may automatically and immediately pause marketing spend for the remainder of the current period (e.g., a remainder of the current day), such that lead generator 108 stops sending new leads to system 100.
Workload optimizer 204 thereby controls marketing spend based upon a workload capacity of system 100 for handling new leads. Such control is necessary because when too many new leads are received, they cannot be handled efficiently by advisors 102, and therefore are less likely to have positive results. Conversely, when system 100 does not receive sufficient new leads 109, advisors 102 may not have sufficient client 106 to maintain interest, and therefore these advisors 102 may become less involved with system 100, such that system 100 efficiency and workload capacity reduces.
Each trigger sequence 252 is constructed of one or more of the following: a trigger component, a delay component, a filter component, a branch component, an action component, and a template component. The trigger component identifies the event that initiates the trigger sequence.
In one example, trigger sequence 252(1) is formed of three components, a trigger component, a delay component, and an action component. The trigger component defines the triggering event as “OrderLineItemShipped,” which causes trigger sequence 252(1) to be invoked whenever system 100 generates an OrderLineItemShipped event 254. The delay component defines a period of fifteen minutes, which causes trigger sequence 252(1) to pause for fifteen minutes when invoked. The action component is a send notification action, that causes trigger sequence 252(1) to send a notification. Accordingly, when an item ships, as determined by e-commerce module 216 for example, event 254 of type OrderLineItemShipped is generated and trigger sequence 252(1) is invoked to automatically send a notification to the ordering client 106 fifteen minutes later. Trigger sequences 252 may have a significantly more complex set of components that control automatic functions within system 100.
During operation, system 100 generates a plurality of events 254, such as one of a message, an action, and other such occurrences within system 100. These events 254 are queued within distributed queue 213 and processed by an event handler 502 of trigger module 206. In certain embodiments, event handler 502 may be invoked as each event 254 occurs. In other embodiments, event handler 502 may be invoked at intervals to handle any events 254 that may have occurred during that interval. Event handler 502 processes each event 254 against each of the plurality of trigger sequences 252, stored within trigger store 220(4). Trigger module 206 is a powerful tool that allows a designer, a business developer, and/or marketing person develop at least one trigger sequence 252 that allows system 100 to automatically respond to certain events and/or conditions that are related to conversations 270.
Trigger module 206 may be used in different areas of system 100 to implement one or more of: escalation management, new client on-boarding, client re-engagement, and order fulfillment workflow. For example, trigger module 206 may be used to monitor a service level agreement (SLA) for an advisor to respond to a message from a new client 106. If there is no response from an advisor within a first period, trigger module 206 escalates the issue by sending notifications to advisors currently online. If there is still no response from an advisor within a second period, trigger module 206 escalates the issue further by sending notifications to all advisors. If there is still no response from an advisor within a third period, trigger module 206 escalates the issue further by sending notifications to a support team of system 100. In another example, trigger module 206 may send an alert to an advisor when an order has not resulted in a corresponding shipment within three days. In another example, trigger module 206 may re-engage clients by sending emails based on their actions in system 100, such as when a client views a product or when a client adds an item to an online shopping cart but then does not follow through with an order.
Each trigger sequence 252 may include at least one trigger component 520 that is processed in response to a triggering event 254. For example, one trigger sequence 252 may include trigger components 520 that evaluate certain conditions and generate at an action 508 to prompt, at an appropriate time, advisor 102 to send a message to client 106. In the example of
In one example is using wait component 250(3), during conversation 270 between client 106 and advisor 102, event 254 is generated when advisor 102 sends a message to client 106 and trigger sequence 252 is initiated. Wait component 520(3) is defined to wait for either a defined period (e.g., a reasonable period for client to respond, such as eight hours, one day, etc.) or for a subsequent event 254 that indicates that client 106 has responded. When the subsequent event 254 occurs before the wait period expires, trigger sequence 252 follows a first path 522, and when client 106 does not respond within the defined wait period, trigger sequence 252 follows a second path 524. Accordingly, trigger sequence 252 behaves intelligently by causing an appropriate action based upon whether the client does or does not respond. For example, the action may prompt advisor 102 to send a follow-up message to client 106 to keep the conversation going. Branch component 520(4) causes trigger sequence 252 to follow one of two paths based upon a defined Boolean condition. In the example of
Trigger module 206 may communicate with any of client 106; advisors 102, for example when their applications have been approved; and support agents, for example when a new escalation has been created.
As noted above, interactive design tools 302 and 510 are similar. Accordingly, path schemas 308 and trigger sequences 252 have certain similarities in the way they are developed. To aid development of path schemas 308 and trigger sequences 252, path module 202 and trigger module 206 may track flow through each corresponding path flow 110 and trigger sequence 252, indicating how many times each route (and/or each step or component) through the flow has been used. Accordingly, designers 303/503 may review their corresponding flow/sequences 110/252 to determine how many times each route, step, or component is used. For example, a route (or step) that has no, or few, uses, may indicate that the corresponding condition, or set of conditions, is incorrect. In another example, designer 303/503 may notice that a route is followed frequently and that it may be advantageous to include additional branches to learn more information of the clients following those paths.
For each advisor 102, sales pipeline 114 tracks at least one conversation 270 between the advisor and a client 106 and may include a commitment 272 (e.g., agreement to purchase) of client 106 for product 105. System 100 may generate a trigger event 254 based upon certain activity within system 100. For example, based upon interactions of one or both of advisor 102 and/or client 106, sales pipeline 114 may generate trigger event 254 indicating the interaction within sales pipeline 114. In another example, lead database 220 may generate trigger event 254 when a new lead 109 is received by lead database 220.
Sales pipeline 114, in cooperation with trigger module 206 and for each conversation 270, generates recommended action 115 that prompts advisor 102 in a next step of advising client 106. Advantageously, sales pipeline 114 and/or trigger module 206 takes into account many different factors, including a response time of client 106, a number of messages exchanged during conversation 270, activities of client 106 such as viewing products recommended in curation 116, adding items to a shopping cart, and so on.
Sales pipeline 114 and trigger module 206 cooperate to provide advisor 102 with at least one recommended action 115 for each conversation 270. For example, input from both advisor 102 and clients 106 may generate events 254 that are processed by trigger module 206 as described above and may result in one or more recommended actions 115 for each conversation 270. Recommended action 115 may be one of sending a message, making a product or service recommendation, snoozing a conversation, archiving a conversation, etc. Advisor 102 may view the context of each conversation within advisor dashboard 630 and may thereby learn why recommended action 115 is suggested, and may thereby determine what kind of message to send to client 106. For example, when client 106 views curation 116 without replying with feedback, trigger module 206 may generate a recommended action 115 for advisor 102 to follow up with the client.
Sales pipeline 114 includes a conversation ranker 610 that tracks quality and progress of each conversation 270, and collects data that allows each conversation to be steered towards a positive outcome based at least in part upon previous conversations. Conversation ranker 610 orders conversations 270 based upon recommended actions 115, and prompts advisor 102 to respond, and/or take other actions, at a most beneficial time in the conversation through advisor dashboard 630. For example, of leads 109, advisor dashboard 360 may indicate leads assigned advisor 602, leads needing curation 604, leads already having curation 606, and leads committed 608 towards a positive result. Advantageously, through advisor dashboard 630, advisor 102 may immediately see their current workload, the progress, and be prompted on how to respond to the more urgent conversations. Sales pipeline 114 allows advisor 102 to support and advise many clients 106 simultaneously. A further advantage of sales pipeline 114 is that clients 106 that take longer to respond are not forgotten. Particularly, since new leads are assigned to advisors 102 daily, existing, slow moving, conversations 270 could be forgotten. However, sales pipeline 114 automatically moves each current conversation 270 to a top of advisor dashboard 630 when an action or response to that conversation is due, and thus conversations are not accidently forgotten.
Advisor activity summary 702 includes a “needs action” folder 704, showing a count of conversations 270 that are waiting for action by advisor 102, and an “active” folder 706, showing a count of all active conversations 270 assigned to advisor 102. Collectively, these displayed counts provide a workload summary of advisor 102.
When advisor 102 selects “needs action” folder 704, dashboard 630 displays conversation list 730 with an ordered, most urgent first, list of conversations 270 that are awaiting action by advisor 102. Particularly, items within “needs action” folder 704 may include an associated recommendation 115 such that advisor 102 may easily select and act on the more urgent conversations. When an item is then selected from conversation list 730, advisor dashboard 630 displays the full context of the selected conversation in conversation thread 740, information sources 750, and request details 113, such that advisor 102 has all relevant information accessible and may therefore resume the conversation effortlessly.
When advisor 102 selects active folder 706, dashboard 630 displays conversation list 730 with an ordered, most recent activity first, list of conversations 270 that are in progress (e.g., active) with advisor 102. Accordingly, active folder 706 may be conveniently used by advisor 102 to follow current conversation where the corresponding clients 106 are responsive (e.g., live conversations). Active folder 706 allows advisor 102 to find conversations that are not waiting for any action by advisor 102 (e.g., conversations that await a response from client 106). Conversations may be automatically archived after fourteen days of inactivity unless the conversation is starred or snoozed (see starred folder 722 and snoozed folder 724 described below).
Sales pipeline summary 710 includes folders that allow advisor 102 to see conversations 270 in various stages of sales pipeline 114. For example, sales pipeline 114 automatically progresses conversations based on the whether the client 106 is reviewing a curation 116 (e.g., has offer) or is yet to receive curation 116 (need offer), and also based on a length of the conversation (as an indication of quality of the conversation). Sales pipeline summary 710 has three folders: a “need offer” folder 712 that displays a count of conversations 270 with advisor 102 that are waiting for advisor 102 to provide a curation 116, a “has offer” folder 714 that displays a count of conversations 270 with advisor 102 that have received curation 116 but not responded positively or negatively, and a “sold” folder 716 that displays a count of conversations 270 with advisor 102 that have responded positively (e.g., made a purchased based upon curation 116). Each of these folders 712, 714, and 716, may also display a monetary value indicative of a sum of potential or actual sales revenue corresponding to each conversation in that folder, thereby providing advisor 102 with an indication of where conversations may be nurtured to result in positive outcomes with the greatest value.
Folders 720 allows advisor 102 to track conversations 270, and corresponding clients 106, independent of sales pipeline 114. For example, a starred folder 722 contains conversations flagged by advisor 102 as being of importance, thereby allowing advisor 102 to easily find important conversations in the future. For example, where advisor 102 has a strong relationship with a frequently returning client 106, advisor 102 may star these conversations such that they may be easily retrieved and referenced in future conversations with the same client, or retrieved and references to learn techniques used in successful conversations. Snoozed folder 724 stores conversations that advisor 102 has put on hold, whereby the conversation does not appear in the active folder 706 and system 100 does not generate actions or automatic prompts to keep the conversation current. When advisor 102 snoozes a conversation, advisor may specify a duration of the snooze period, or an end time/date of the snooze, whereby the conversation is automatically reactivated (e.g., moved from snoozed folder 724 to active folder 706) at the appropriate time. Optionally, a message may also be generated for the conversation at the end of the snooze period. For example, where advisor 102 learns that client 106 needs time to consider an offer, or learns that client 106 is away on business trip, advisor 102 may snooze the conversation to prevent unwanted prompts being sent to the client. Archived folder 726 may be used to store conversations 270 that are no longer active. For example, conversations that have had no activity for at least fourteen days (and do not appear in starred folder 722 or snoozed folder 724) may be automatically archived, but may be found by advisor 102 in archived folder 726. No replies folder 728 stores conversations where the corresponding client 106 has made no reply at all. These conversations are started for leads 109, wherein at least one message is sent to the provided contact information to initiate a conversation (e.g., inviting a client to interact with a path flow 110), but the client has not responded. Conversations with no reply from the client do not appear in any active folder 706; however, advisor 102 may find these conversations/leads in no replies folder 728, and may attempt to illicit interaction to engage the corresponding client 106.
Advisor 102 may select one of need offer folder 712, has offer folder 714, and sold folder 716 to display corresponding conversations in conversation list 730. In the example of
Information sources 750 may include a plurality of pull-down panels that indicate provide a summary of the information available. In the example of
Request details 113 represents information captured by path module 202 using path flow 110 for example. This allows advisor 102 to see specific responses (selections and answers) made by client 106 during interaction with path flow 110, which may be useful to advisor 102 when providing advice to client 106.
Advisor dashboard 630 also includes an edit offer button 770 that, when selected by advisor 102, opens an interactive edit screen that allows advisor 102 to generate curation 116.
Advantageously, advisor dashboard 630 provides advisor 102 with all needed information for advising each client 106, responding to respective conversations 270, and recommended actions 115 for each conversation 270.
Trigger sequences 252 that generate recommended actions 115 may become more useful and context aware over time, since advisors 102 may generate their own rules for generating recommended actions 115 and/or automatically sending messages or curations 116. For example, advisor 102 may tag a created action, curation, and/or message for use in other scenarios and/or for use with different types of leads. Rules created by advisor 102 may be stored in a library such the other advisors 102 may view and use the best rules.
Based, at least in part, upon curation 116, sales pipeline 114 and/or trigger module 206 may generate a recommendation 274 for client 106 that indicates where other advisors have provided a similar curation 116 to other clients. For example, where curation 116 recommends a particular brand and configuration of golf clubs for client 106, sales pipeline 114 may generate recommendation 274 to define advisors 102 that have recommended similar golf clubs to other clients 106. Unlike conventional retail websites that indicate what other clients view and/or purchase after looking at a product, sales pipeline 114 generates recommendation 274 to indicate where that product has been recommended by other advisors 102 to other clients 106. Accordingly, recommendation 274 builds confidence in curation 116 for client 106, thereby increasing likelihood of a positive outcome.
Prior to assigning each lead 109 to one advisor 102, and after invoking path module 202 to determine client intent 112, advisor interface system 100 may invoke lead ranking algorithm 208 to rank leads 109 in order of likeliness of a positive outcome. Accordingly, leads 109 that are more likely to have a positive outcome may have a higher value. For example, for a current lead 109, based upon request details 113 received in response to path flow 110, and/or client intent 112, lead ranking algorithm 208 may predict a likely outcome and value of lead 109 based upon previous outcomes and values of similar leads, path flow, and client intent 112 in historical data. That is, based upon a number of previously determined request details 113 and client intents 112 that match request details 113 and client intent 112 for a current lead 109 in the same category 107, lead ranking algorithm 208 may predict that the current lead 109 will have a similar outcome and therefore have a similar value. Accordingly, each new lead 109 may be ranked, and those predicted to have a more positive outcome may be given priority for assignment to one advisor 102. For example, historical data may indicate that a client in the golf category who is searching for a new driver is more likely to spend more money than a client in the golf category who is looking for a full set of clubs. Accordingly, the lead for the client searching for a new driver may have a higher ranking than the lead of the client searching for a full set of golf clubs.
After ranking new leads 109, advisor matcher 210 is invoked to assign these unassigned leads 109, in the ranking order (leads with the highest ranking—most likely positive outcome—first), to a most suitable advisor 102. Advisor matcher 210 uses machine learning, neural networks, and/or other types of artificial intelligence (AI) to match a given lead 109 (i.e., the corresponding client 106) with one advisor 102 that is most likely to provide client 106 with the most relevant advice and/or service recommendations. Matching advisors with leads is not as simple as assigning the highest-ranking lead to the highest-ranking advisor. Advisor matcher 210 may use category 107 defined by lead 109, client information (e.g., client characteristics 111, client intent 112, and/or request details 113), and advisor information (e.g., advisor characteristics 424, past performance—ratio of positive/negative outcomes, quality of conversations, advisor schedule 426, advisor rank 428 and workload 430). Advisor matcher 210 may also process conversations 270 associated with advisor 102 for the identified category 107 to determine a conversation quality 271 and a content level 273 of the conversations 270. Advisor matcher 210 may then uses the conversation quality 271 and content level 273 when matching lead 109 to advisor 102. For example, where conversations 270 of advisor 102 have high technical content (e.g., high content level 273), advisor 102 may be more suitably assigned to leads 109 with corresponding client characteristics 111, client intent 112 and/or request details 113 that indicate client 106 is looking for technical information. Conversely, where conversations 270 of advisor 102 have limited technical content, advisor 102 may be more suitably assigned to leads 109 with corresponding client characteristics 111, client intent 112 and/or request details 113 that indicate client 106 has no interest in technical data.
In certain embodiments, where client 106 is identified as having previously used system 100, advisor matcher 210 may analyze previous conversations of client 106 to better determine client intent 112. Where the previously assigned advisor resulted in a successful outcome with client 106, the same advisor may be assigned again; however, where the previously assigned advisor did not result in a successful outcome, an alternative advisor may be assigned.
Accordingly, the ability of advisor 102 to handle new lead 109 is also evaluated based upon past performance (e.g., from historical data) of the advisor's handling of similar leads, considering request details 113, client intent 112, client characteristics 111, and so on. For example, one advisor 102 who gets more positive results when helping inexperienced clients is more likely to be assigned to a new lead 109 for a client 106 who is inexperienced.
System 100 thereby takes other nuances into account when ranking and assigning leads 109 to ranked advisors 102. For example, in the golf category 107, the number of positive results from conversations 270 increases when clients 106 believe they are talking with an advisor who has a similar ability level. That is, a client who is a scratch golfer prefers to receive advice from an advisor who is also a scratch golfer. Similarly, a client who is an average golfer prefers to receive advice from an advisor wo is also an average golfer. However, this is not the case for other categories 107. In the winter sports category, more positive outcomes are achieved when the client receives advice from an advisor that skis/board at locations used by the client.
In the example of
Lead ranker 3120 processes at least request details 113 corresponding to each lead 109 to determine a ranking of the lead, and a lead persona ID 3122 processes request details 113 and output from lead ranker 3120 to segment each lead 109 into certain personas. For example, for each lead 109, lead ranker 3120 determines a probability of the corresponding client 106 having a positive result (e.g., a sale of a product to the client). Leads 109 are then ranked, based at least in part upon these probabilities. Particularly, a client 106 corresponding to a lead 109 determined to have a high intent of making a purchase may receive a more preferential treatment, as compared to a client corresponding to a lead determined as having a low intent. More preferential treatment includes giving priority to assignment of the lead 109 to a best available advisor 102 before a lower ranked lead is assigned. Output of lead ranker 3120 is a list of ranked leads that may be denoted as RLi⇒{i∈1, 2, . . . n}.
For each lead 109, lead persona identification 3122 may process request details 113 to determine personality traits of client 106. Identified personality traits may include one or more of skill level, demographics, thrifty, deal seeker, loyal/return user, determined shopper—always wants the best, impatient, brand loyalist, sarcastic, mentor, and so on. Thus, for each new lead 109, lead persona identification 3122 may be based upon interaction of client 106 with web interface 264, and, within system 100, client 106 may be tagged with these determined personality traits. Output from lead persona identifier 3122 may be denoted as Personified Ranked Lead—PRLi⇒{i∈1, 2, . . . n}.
Advisor persona identifier 3126 determines personality traits of each advisor 102 registered with system 100. Initially, advisor persona identifier 3126 determines personality traits of advisor 102 based upon one or more of a personality test, product specific questions in an advisor application form. Over time, advisor persona identifier 3126 may determine personality traits of advisor 102 based upon analysis of conversations between advisor 102 and multiple clients 106. For example, advisor persona identifier 3126 may use natural language processing to infer additional personality traits from conversations between advisor 102 and multiple clients 106. Within system 100, each advisor 102 may be tagged with these determined personality traits. Output from advisor persona identifier 3126 may be denoted as Personified Advisor—PAj⇒{j∈1, 2, . . . m}.
Each advisor 102 has an optimal number of leads that they can concurrently handle. This number is very personal to the advisor and may depend on one or more of the advisor's style of engaging in conversations with leads, the advisor's style of selling, the number of hours the advisor is actively logged into system 100, and the responsiveness of the clients that they are conversing with.
In certain embodiments, engagement of advisor 102 is based on the notion of an activity time window, and may not be based upon a number of leads assigned to the advisor. A conversation between one advisor 102 and one client 106 may last over several hours, days or weeks, but conversations typically have bursts of activity followed by periods of inactivity. Where an advisor 102 converses with a client 106 who has long periods of inactivity, the advisor 102 may engage with a new lead during those periods. Engagement capacity filter 3128 filters out advisors 102 that are online with system 100 but that do not have the capacity (e.g., that are already over their optimal engagement capacity) to accept new leads. The output of engagement capacity filter 3128 may be denoted as Personified Available Advisors—PAAj⇒{j∈1, 2, . . . m}. Engagement capacity filter 3128 may also generate a list of advisors that are not online with system 100, denoted as Personified Offline Advisors—POAk in
Matcher 3130 inputs the PRLi from lead persona ID 3122 and PAAj from engagement capacity filter 3128 and, for each lead 109, provides a ranked list of advisors 102 that are candidate assignments to that lead. Advisor 102 are ranked in order of their closeness to lead 109. For example, closeness of an advisor to a lead may be based upon a combination of lead and advisor persona, conversation probability, and advisor ranking. Matcher 3130 generates a list of leads (PRLi), where each lead has a list of Ranked (closest) Personified Available Advisors (RPAAj):
PRLi←→List<RPAAj>{i∈1,2 . . . n&&j∈1,2 . . . m} and m≤n
Assigner 3140 processes list of leads PRLi, each with its list of closes available advisors RPAAj to generate lead-available advisor pairs 3150 (Li, AAj), and may also generate a lead-unavailable advisor pairs 3152, and a list of unassigned leads 3154 (Li), as described below and shown in
In block 3202, algorithm 3200 inputs lead-advisor pairs for processing, and iteratively selects each lead and associated advisor list. In one example of block 3202, assigner 3140 receives PRLi, List<RPAAj> from matcher 3130, selecting PRL1 and list <RPAA1> in a first iteration. Block 3204 is a decision. If, in block 3204, algorithm 3200 determines that the selected lead matches the advisor, algorithm 3200 continues with block 3206; otherwise, algorithm 3200 continues with block 3212. Block 3206 is a decision. If, in block 3206, algorithm 3200 determines that the matched advisor has capacity, algorithm 3200 continues with block 3208. In block 3208, algorithm 3200 adds the matched lead and advisor to a list of matched lead and advisor pairs. In one example of block 3208, lead Li and advisor Aj are added to a temporary list of matched pairs. Block 3210 is a decision. If, in block 3210, algorithm 3200 determines that there are more leads to match, algorithm 3200 continues with block 3202; otherwise, algorithm 3200 continues with block 3214.
When none of the advisors listed for a lead are available to accept the lead, algorithm 3200 continues from block 3204 to block 3212 where algorithm 3200 adds the lead to an unclaimed lead list. Accordingly, algorithm 3200 builds a list of selected lead-advisor pairs (block 3208) and builds a list of unclaimed leads (block 3212). When there are no more new leads to assign, algorithm 3200 continues from block 3210 to block 3214.
Accordingly, a “happy path” through algorithm 3200 occurs when, for each new lead 109 received in block 3202, the top matched advisor 102 has capacity to access the lead. Thus, blocks 3202 through 3210 implement a first assignment strategy. Since algorithm 3200 is greedy, the success probabilities of assignments are ignored and each matched lead 109 is greedily assigned to the highest ordered available advisor 102.
Block 3214 is a decision. If, in block 3214, algorithm 3200 determines that there is at least one unclaimed lead in the unclaimed lead list (block 3212), algorithm 3200 continues with block 3218; otherwise, algorithm 3200 assigns the leads to the advisors 102 and/or initiates chats with between the corresponding clients 106 and assigned advisors 102.
A second assignment strategy is implemented to match any lead 109 not matched by the first assignment strategy (e.g., blocks 3202 through 3210) to one advisor 102 that, although not currently online with system 100, may be activated. In block 3218, algorithm 3200 matches offline advisors, determined as POAk by engagement capacity filter 2128 and input in block 3216, to each lead in the unclaimed lead list created by block 3212. An offline advisor may be activated (e.g., by sending a text and/or email) with a certain probability, which may be learned by system 100. Accordingly, block 3218 may include functionality similar to blocks 3202 through 3210, but operates to assign advisors from list POAk to each lead of the unclaimed lead list of block 3212. Each offline advisor 102 may have a threshold (e.g., 5) that defines a minimum number of assigned leads that result in activation of that offline advisor. That is, when the offline advisor is assigned too few leads, the advisor is not activated. This prevent the offline advisor from being activated too eagerly without sufficient reason.
In blocks 3220 through 3226, algorithm 3200 balances distribution of the unclaimed leads to the offline advisors. For example, unclaimed leads of an advisor with too many leads (e.g., exceeding capacity of the advisor) may be distributed to offline advisors that do not have sufficient leads to be activated. Block 3220 is a decision. If, in block 3220, algorithm 3200 determines that the advisor is underutilized, algorithm 3200 continues with block 3222; otherwise algorithm 3200 continues with block 3226. Block 3226 is a decision. If, in block 3226, algorithm 3200 determines that any advisor is over capacity, algorithm 3200 continues with block 3222; otherwise algorithm 320 continues with block 3230. In block 3230, algorithm 3200 activates the offline advisor and forms a list of selected offline lead-advisor pairs (li-Aj) in block 3234. In one example of block 3230, system 100 sends one or more of a notification, text, email, and voice call to offline advisor 102 indicating that new leads are waiting online. System 100 then processes the selected offline lead-advisor pairs of block 3234 and the leads 109 are assigned to the advisors 102 and/or chats between the advisor 102 and the client 106 corresponding to the lead 109 are initiated.
Block 3222 is a decision. If, in block 3222, algorithm 3200 determines that a convergence threshold has been reached, algorithm 3200 continues with block 3228; otherwise algorithm 3200 continues with block 3224. In block 3224, algorithm 3200 reassigns underutilized advisors to next best match advisor. In one example of block 3224, unclaimed leads 109 of an offline advisor 102 that has too few leads to be activated are reassigned to a next best matched offline advisor, and unclaimed leads 109 that exceed an offline advisor 102 capacity are reassigned to a next best advisor. The convergence threshold of block 3222 prevents a cyclic effect of continually reassigning leads between offline advisors. For example, the convergence threshold may limit the number of iterations that may be performed by blocks 3220 through 3226 to balance distribution of unclaimed leads to offline advisors. Accordingly, blocks 3220 through 3226 iterate over an assignment to optimize assigning multiple leads to a single offline advisor to stay within the lower and upper capacity threshold.
In block 3228, algorithm 3200 processes the unclaimed lead—offline advisor matches, continuing with block 3230 for offline advisors that have enough leads to be activated, and continuing with block 3232 for advisors that are underused (e.g., where the number of leads matched to the advisor is below the advisor's activation threshold). Accordingly, blocks 3230 and 3234 activate the advisor 102 and initiates handling to the assigned leads. For underused advisors, block 3232 is a decision. If, in block 3232, algorithm 3200 determines that the unclaimed leads of the offline advisor have a high intent level, algorithm 3200 assigns the lead to support staff; otherwise, algorithm 3200 sends the client corresponding to the lead 109 with lower intent to browse further information. For example, a higher intent lead 109 may trigger an alert for a support agent (e.g., a Delegate expert or an Assistant) to manually assign the lead 109 to an agent 102.
System 100 relies upon advisors 102 to provide advice to, and to meet the needs of, clients 106. Workload optimizer 204 automatically purchases sufficient new leads 109 to provide work for available advisors 102, automatically tailoring supply of new leads 109 to advisor capability, workload capacity, experiences, and so on. However, for system 100 to grow in size, system 100 may recruit new advisors 102 based upon referrals and interest of the potential advisor. A person wishing to become an advisor in one or more categories 107 may apply through an advisor recruiting web site (e.g., implemented by web interface 264). System 100 then invokes at least one experienced advisor in the same category to virtually screen and activate, when the new advisor meets certain criteria, the new advisor by creating a new account (e.g., with unique contact number 265 and email address 267) so that the new advisor may start receiving leads. System 100 invokes, at intervals, advisor ranker 404 to rank advisors 102 (e.g., one of platinum, gold, silver, and bronze, where platinum is highest and bronze is lowest) based upon performance (e.g., historical revenue per assigned lead). Ranking may determine shift prioritization and when the advisor receives additional leads. Rank 428 is determined by calculating a score for each advisor based at least in part upon success of advisor 102 in converting each assigned lead 109 into a successful result (e.g., a sale based upon the provided curation 116).
In block 802, method 800 receives, from a lead source, a new lead defining a category. In one example of block 802, path module 202 receives, from lead generator 108, new lead 109 identifying one of categories 170. In block 804, method 800 selects a path schema based upon the identified category. In one example of block 804, path module 202 selects path schema 308 from path database 203 based upon at least category 107. In block 806, method 800 sends, using the contact information, a link to a web site implementing a path flow generated from the path schema to the client. In one example of block 806, path module 202 sends a URL to a web site implemented by web interface 264 to client 106. In block 808, method 800 determines client intent based upon request details captured by the path flow. In one example of block 808, path module 202 receives request details 113 derived from interaction of client 106 with path flow 110 on web interface 264 and then invokes classifier 310 to determine client intent 112 from request details 113.
In block 810, method 800 selects one of a plurality of advisors to advise the client based, at least in part, upon the category and the client intent. In one example of block 810, advisor matcher 210 matches advisor information 242 of advisor database 240 to the identified category 107 of new lead 109 and corresponding client intent 112 to select advisor 102 to advise client 106. In block 812, method 800 adds the client to a sales pipeline of the one advisor. In one example of block 812, advisor matcher 210 adds a conversation 270, identifying client 106 and with a recommended action 115 to start a conversation, to sales pipeline 114 of advisor 102. In block 814, method 800 prompts, at intervals, the one advisor to interact with the client. In one example of block 814, trigger module 206 generates at least one recommended action 115 for conversation 270 based upon events 254 corresponding to conversation 270. In block 816, method 800 prompts the one advisor to generate a curation for the client. In one example of block 816, trigger module 206, in response to one or more events 254 and/or a determined conversation quality 271, adds recommended action 115 to conversation 270 to recommend that advisor 102 generates curation 116 for client 106. In block 818, method 800 sends the curation to the client. In one example of block 818, multi-channel communications 214 sends curation 116 to client 106 using one or more of application interface 262, web interface 264, SMS interface 266, and email interface 268.
System 100 may allow each advisor 102 to save messages and curations as templates such that they may be reused. Advisor 102 may name each message template, making it easier to select the appropriate message template when creating a new message. Advisor 102 may name each curation template, making it easier to select the appropriate curation template when creating a new curation 116. These templates are stored by system 100 and may be displayed to advisor 102 in a corresponding message template list and curation template list. Advisor 102 may select a message template from a message template list when creating a new message to start a new conversation or when replying to a message from client 106 in an existing conversation. Similarly, advisor 102 may select a curation template from a curation template list when creating a new curation 116. An example curation template list includes: “Skilled player Irons and Drivers,” “Game Improver Irons and Drivers,” “Top Wedges,” “B+ bikes,” and “Full beginner box sets.”
In addition to saving templated messages for use in specific contexts, advisor 102 may also customize a curation template for automatic selection and delivery to client 106 when client 106 is unresponsive (e.g., when client 106 would prefer not to start conversation 270).
Certain advisors 102 may be more successful than others. For example, one advisor 102 may, through conversational style and timing of recommendations, imbue confidence in clients 106 more successfully that another advisor 102 who may appear too “pushy” by providing curation 116 too soon during a conversation discussing requirements of client 102. Accordingly, certain actions and conversational techniques may be identified by system 100 as being more successful than others. System 100 may also determine, for unsuccessful conversations between advisors 102 and clients 106, when recommendations are provided too soon, or too late, during the conversations.
Behavior analyzer 2406, using MVLR model 2408, may determine behavior characteristics including one or more of: snoozes per active lead, quick replies used per active lead, stars per active lead, archives per active lead, profile completeness, out of shift messages percent, curated orders per active lead, curated items per active lead, active leads with curated orders, active leads with curated items, active leads with custom curated items, active leads with curated items with notes, calls per active lead, inactive leads messaged, notes authored per curated item sent, curated items added to cart, curated items with tags, curated items with custom price, percent of active leads within sla, image message percentage, video message percentage, file message percentage, questions asked, price mentions, message length, pauses per shift, message sentiment, early message sentiment, late message sentiment, early questions asked, late questions asked, early price mentions, late price mentions, early message length, late message length, and expert to user message ratio.
Snoozes per active lead is the percentage of active leads that advisor 102 has snoozed at any point in time. Quick replies used per active lead is the number of quick reply messages sent/the number of active leads. For example, advisor 102 may create templated messages that they may later use as quick replies to efficiently send common messages. Stars per active lead is the percentage of active leads that advisor 102 has starred at any point in time. Archives per active lead is the percentage of active leads that advisor 102 has archived at any point in time. Profile completeness is a score between 0 and 1 that represents how many fields are filled in on a profile of advisor 102. Out of shift messages percent is the percentage of messages that advisor 102 sent while not accepting new leads (not including pauses). Curated orders per active lead is an average number of experience (ex. Yacht Charters) recommendations per active lead by advisor 102. Curated items per active lead is an average number of product (e.g., Golf Club) recommendations per active lead of advisor 102. Active leads with curated orders is the percentage of active leads that has received an experience recommendation from advisor 102. Active leads with curated items is the percentage of active leads that have received a product recommendation from advisor 102. Active leads with custom curated items is the percentage of active leads that have received a custom offer. Active leads with curated items with notes is the percentage of active leads that have received a product recommendation with advisor notes. Calls per active lead is the percentage of active leads that have had a phone call with advisor 102. Inactive leads messaged is the percentage of active leads that have received a custom offer. Notes authored per curated item sent is the percentage of inactive leads advisor 102 has messaged (i.e. advisor 102 sent client 106 a manual message without client 106 ever sending a message). Curated items added to cart is the percentage of product recommendations that advisor 102 added directly to the cart of client 106. Curated items with tags is the percentage of product recommendations with tags (i.e. “Expert Pick,” “Special Offer,” “The Alternative”). Curated items with custom price is the percentage of product recommendations for which advisor 102 manually updated the price. Percent of active leads within sla is the percentage of active leads for which advisor 102 responded to the first message of client 106 within 1 minute. Image message percentage is the percentage of messages from advisor 102 where the message body was an image. Video message percentage is the percentage of messages sent by advisor 102 where the message body was a video. File message percentage is the percentage of messages sent by advisor 102 where the message body was a file (e.g., a voice recording). Questions asked is the percentage of messages send by advisor 102 containing a question. Price mentions is the percentage of messages send by advisor 102 referencing price. For example, this may include messages confirming budget, price matching, talking about discounts, etc. Message length is the average length of messages send by advisor 102. Pauses per shift is the average number of times advisor 102 pauses per shift. Message sentiment is the average sentiment of messages send by advisor 102. For example, messages with positive sentiment contain happy, friendly, etc. words that convey a positive emotion; the greater the number of happy words, the higher the message sentiment score. Early message sentiment is the average sentiment of the first 5 messages sent by advisor 102 to client 106. Late message sentiment is the average sentiment of messages, after the first 5, sent by advisor 102. Early questions asked is the percentage of the first 5 messages sent by advisor 102 containing a question. Late questions asked is the percentage of messages, after the first 5, sent by advisor 102 containing a question. Early price mentions is the percentage of the first 5 messages sent by advisor 102 referencing price. For example, this may include messages confirming budget, price matching, talking about discounts, etc. Late price mentions is the percentage of messages, after the first 5, sent by advisor 102 referencing price. For example, this may include messages confirming budget, price matching, talking about discounts, etc. Early message length is the average length of the first 5 messages sent by advisor 102. Late message length is the average length of messages, after the first 5, sent by advisor 102. Expert to user message ratio is the number of messages sent by advisor 102/the number of messages send by client 106. Advisor 102 may send more messages than client 106. For example, at the high end, advisor 102 sends on average 1.6 messages for every message sent by client 106.
MVLR model 2408 is trained to identify behavior of advisors 102 that corresponds to success (higher conversion rate of clients 106 making purchases based upon curations 116) for advisor 102. For each advisor 102, MVLR model 2408 may generate performance 2430 that indicates an overall performance of advisor 102 within system 100, strengths 2432 that indicate behavior of advisor 102 that is strong, and development 2434 that indicates behavior of advisor 102 that may benefit from further effort to improve performance 2430.
MVLR model 2408 calculates an advisor score 2450 based, at least in part, upon one or more of advisor activity 2420, advisor results 2421, and behavior data 2422. Advisor score 2450 is not only based upon results, since MVLR model 2408 takes into account behavior of advisor 102, quality of leads 109, category 107, and so on. Accordingly, advisor score 2450 is an accurate evaluation of advisor 102 and may be used to compare advisor 102 against peers. As described above, advisor ranker 404 may process advisor scores 2450 to generate rank 428 for each advisor 102. Rank 428 thereby accurately defines expected capability of advisor 102 as used to control capacity of system 100, as described above.
Fraud Protection using Dynamic Statement Descriptors
Credit card fraud is the largest type of Identity theft fraud and is therefore a big problem in the payment industry. For example, worldwide in 2018, $24.6 billion was lost to payment card fraud. The United States is the country most prone to credit fraud with 38.6% of reported card fraud losses in 2018 and with more than 167,000 people reporting that a credit card was fraudulently opened in their name. This high fraud rate has an impact on e-commerce based companies that process payments. For example, an increase in chargebacks and frauds reported using a particular company name may result in that company being listed as a High-Risk Merchant, which may impact processing legitimate transactions and may impact the company receiving payouts from Payment Processors.
Given the economic impact of such fraud, it is in the interest of an online e-commerce company to make a best effort to prevent fraud. The credit card processing industry recommends several best practices to prevent fraud; using basic verification such as a corresponding zip code, and/or a card verification value (CVV), and/or using a more modern approach with 3D secure (three-domain structure) cards that implement a third-party verification step (e.g., a onetime PIN). Unfortunately, 3D secure is not mandatory and many payment cards still rely only upon the Zip code and/or the CVV to prevent fraud. Unfortunately, credit card identity theft typically results in stolen zip code, CCV and/or other information.
Dynamic statement descriptors may provide another level of defense against fraudulent use of stolen credit card information on an e-commerce site, and does not require the payment card or client be enrolled in a third-party scheme (e.g., 3D secure). A statement descriptor is included for each transaction made using a payment card and appears on the account statement (e.g., a credit card statement, a bank statement, etc.). To allow the client to recognize the transaction on their statement, most e-commerce sites use some form of static name, product name, and/or title of service rendered, as the statement descriptor. However, the statement descriptor is not limited to a static value. Advantageously, the statement descriptor may be used dynamically as a second level of fraud protection.
E-commerce site 2804 generates a random code 2818 (e.g., six alphanumeric characters) that is included in statement descriptor 2812 together with a description 2816 of product 2806 and/or e-commerce site 2804 (e.g., a company name, trading name, web name, etc.). Statement descriptor 2812 is for example a string of characters formed by description 2816 and code 2818. E-commerce site 2804 submits transaction 2810 to a transaction processor 2820 (e.g., an entity that handles card transactions), which in turn interacts with a card provider 2830 corresponding to card information 2808. Transcription processor 2820 and card provider 2830 represent financial entities that network to support financial transactions for credit card services, banking, and so on. Accordingly, transaction 2810 is added to an account 2832 corresponding to card information 2808. However, transaction 2810 is not captured (e.g., the transaction is not completed/confirmed/finalized) and therefore transaction 2810 appears as pending in a transaction list 2834 of account 2832 and does not result in a debit of funds from account 2832. Within transaction list 2834, statement descriptor 2810 of transaction 2810 include code 2818. As a secondary fraud prevention check, e-commerce site 2804 requires client 2802 to retrieve code 2818 from statement descriptor 2812 within transaction list 2634 stored by card provider 2830, and provide the obtained code to e-commerce site 2804. For example, client 2802 may interact (e.g., using an app running on a smartphone, or using a web browser) with a portal 2836 of card provider 2830, logging in to account 2832, to retrieve code 2818. In another example, client 2802 may call card provider 2830 to retrieve code 2818 from statement descriptor 2812.
E-commerce site 2804 compares the code provided by client 2802 to code 2818 (e.g., stored in a database in association with transaction 2810), and when they match, transaction 2810 is approved and captured (e.g., through interaction with transaction processor 2820) and funds corresponding to value 2814 are debited from account 2832. Where the returned code does not match code 2818, or no code is returned within a defined period (e.g., ten minutes, one hour, one day, and so on), the payment process is failed and transaction 2810 is cancelled.
Advantageously, through use of code 2818 within statement descriptor 2812, e-commerce site 2804 may gain confidence that client 2802 is in rightful control of card information 2808 provided for transaction 2810, since client 2802 also has access to corresponding account 2832. Particularly, no additional parties are required to provide this additional validation of client 2802, and without access to account 2832, no adverse party can fraudulently use card information 2808.
Certain card providers 2830 (e.g., American Express) may not display statement descriptor 2812 for pending transactions within account 2832, and thus, client 2802 cannot respond to e-commerce site 2804 and provide code 2818. Card provider 2830 may provide certain transaction data 2811 (e.g., transaction date and time), that may allow client 2802 to distinguish between other transactions within transaction list 2834.
E-commerce site 2804 requires client 2802 to retrieve temporary value 2815 from transaction 2810 within transaction list 2634 by interacting with card provider 2830, as described above, and to provide at least the decimal portion of temporary value 2815 to e-commerce site 2804. E-commerce site 2804 compares the provided decimal value with the temporary value 2815, and when they match (e.g., when client 2802 provides at least the correct decimal portion of temporary value 2815, temporary value 2814 is replaced by the actual value 2814 within transaction 2810, and transaction 2810 is approved and captured (e.g., through interaction with transaction processor 2820) and funds corresponding to value 2814 are debited from account 2832. Where the returned value does not match temporary value 2815, or no code is returned within a defined period (e.g., ten minutes, one hour, one day, and so on), the payment process is failed and transaction 2810 is cancelled.
Advantageously, through use of random value 2813 and corresponding temporary value 2815 of transaction 2810, e-commerce site 2804 may gain confidence that client 2802 is in rightful control of card information 2808 provided for transaction 2810, since client 2802 also has access to corresponding account 2832. Again, no additional parties are required to provide this additional validation of client 2802, and without access to account 2832, no adverse party can fraudulently use card information 2808.
Changes may be made in the above methods and systems without departing from the scope hereof. It should thus be noted that the matter contained in the above description or shown in the accompanying drawings should be interpreted as illustrative and not in a limiting sense. The following claims are intended to cover all generic and specific features described herein, as well as all statements of the scope of the present method and system, which, as a matter of language, might be said to fall therebetween. In particular, the following embodiments are specifically contemplated, as well as any combinations of such embodiments that are compatible with one another:
(A) A method for managing interaction between one advisor of a plurality of advisors and a client, including: determining client intent based upon request details that indicate a category of interest to the client; selecting the one advisor from the plurality of advisors to advise the client based, at least in part, upon the category of interest and the client intent; adding the client to a sales pipeline of the one advisor; prompting, at intervals, the one advisor to interact with the client; prompting the one advisor to generate a curation for the client; and sending the curation to the client.
(B) The method denoted as (A), further including receiving, in response to the curation, an agreement from the client.
(C) Either of the methods denoted as (A) or (B), further including interactively capturing the request details from the client prior to the step of determining the client intent.
(D) In any of the methods denoted as (A)-(C), the interactively capturing including: receiving a new lead from a lead source, the new lead defining the category of interest and including contact information of the client; selecting a path schema based, at least in part, upon the category of interest; generating a path flow based upon the path schema; sending, using the contact information, a link to a web site implementing the path flow to the client; and capturing the request details based upon interaction of the client with the path flow.
(E) In any of the methods denoted as (A)-(D), the step of selecting the one advisor further including: determining a workload of each of the plurality of advisors; determining client characteristics based upon the interaction of the client with the path flow; determining a ranking of each of the plurality of advisors based, at least in part, upon one or more of the category of interest, the client intent, and the client characteristics; and selecting the one advisor with the highest ranking.
(F) In any of the methods denoted as (A)-(E), the prompting the one advisor to interact with the client including: determining, based upon prior interaction of the one advisor with the client stored within the sales pipeline, a next suggested action for the one advisor in association with the client; and indicating, to the one advisor within a display of the sales pipeline, the next suggested action for the client.
(G) Any of the methods denoted as (A)-(F), further including: ordering the sales pipeline based upon an urgency of the next suggested action; and displaying the ordered sales pipeline to the one advisor to indicate the next suggested action for the client.
(H) In any of the methods denoted as (A)-(G), the prompting the one advisor to generate the curation including: determining, based, at least in part, upon the sales pipeline, a curation time indicative of when the client is likely to accept the curation; adding, at the curation time, a next suggested action for the one advisor in association with the client; and indicating, to the one advisor within a display of the sales pipeline, the next suggested action for the client.
(I) In any of the methods denoted as (A)-(H), the curation including a personalized recommendation of at least one product based upon the category of interest, the client intent, and a conversation between the client and the one advisor stored in the sale pipeline.
(J) Any of the methods denoted as (A)-(I), further including: for each of a plurality of categories handled by the method: for each of the plurality of advisors: determining an expected new lead capacity for an upcoming period, based, at least in part, upon a current workload of the one advisor and a schedule of the one advisor for the upcoming period; and determining a max lead cap for the one advisor based, at least in part, upon one or both of the current workload of the one advisor, and a ranking of the one advisor; determining, for the upcoming period, a total new lead capacity for the category by summing a new lead capacity for each of the plurality of advisors; determining, for the upcoming period, a new lead spend amount for the category based, at least in part, upon the total new lead capacity and characteristics of at least one lead generator.
(K) In any of the methods denoted as (A)-(J), the upcoming period is one day.
(L) In any of the methods denoted as (A)-(K), further including: determining an unassigned lead count of new leads not yet assigned to any of the plurality of advisors; and setting the new lead spend amount to zero when the unassigned lead count is greater than the total new lead capacity.
(M) Any of the methods denoted as (A)-(L), further including: determining an event; processing at least one trigger sequence against the event, the at least one trigger sequence evaluating one or more conditions and defining at least one action when the conditions are met; and implementing the action.
(N) In any of the methods denoted as (A)-(M), the at least one action being selected from the group consisting of: sending a notification to the one advisor, sending a notification to an operator, generating a next suggested action for the one advisor.
(O) In any of the methods denoted as (A)-(N), the step of selecting the one advisor including: determining, for each of the plurality of advisors, an advisor score based, at last in part, upon one or more of the category of interest, a ranking of the advisor, a workload of the advisor, and characteristics of the client; and selecting the advisor having the highest score.
(P) A path module, including: a path builder having machine readable instructions stored in memory that, when executed by at least one processor, cause the processor to implement an interface for creating and editing sets of question types and answer types to form a path schema; a selection algorithm having machine readable instructions stored in the memory that, when executed by the processor, cause the at least one processor to generate a path flow based, at least in part, upon the path schema, the path flow comprising at least one web page with a set of questions for receiving request details from a client; wherein the request details include at least one answer to one or more of the set of questions.
(R) In the path module denoted as (P), the path flow being generated in response to the client visiting a web site and based upon client characteristics.
(S) A client trust interface method with optimized workflow, including: specifying a spend on leads to identify a plurality of clients; capturing intent of one client of the plurality of clients; matching one advisor of a plurality of advisors to the one client; triggering actions of the one advisor to correspond with the one client; and generating a curation based at least in part upon request details of the one client.
(T) The client trust interface method denoted as (S), further including determining the spend based at least in part upon a workload capacity of each of the plurality of advisors and a current workload of each of the plurality of advisors.
(U) Either of the client trust interface methods denoted as (S) or (T), further including switching from a first communication channel to a second communication channel when the one client goes offline.
(V) A client trust interface system, including: a workload optimizer for determining a current workload of each of a plurality of advisors and for determining a workload capacity of each of the plurality of advisors, the workload optimizer defining a spend for generating new leads based upon the current workload and the workload capacity of each of the plurality of advisors; a client interface for interacting with each of a plurality of clients to determine intent of each of the plurality of clients; an advisor matcher for matching one advisor of the plurality of advisors with one client of the plurality of clients based upon the intent of the one client and a capability of the one advisor; a trigger algorithm for prompting a next action for the one advisor based upon a history of actions by the one advisor and responses by the one client; and a communication channel controller (path) for switching between communication channels to maintain communication between the one client and the one advisor.
(W) An e-commerce method for card fraud protection, including: determining, at an e-commerce site, a value to be charged to a card of a client; generating a random code; including the random code in a transaction for the card; sending the transaction to a card provider corresponding to the card, wherein the transaction is posted as pending in a transaction list of an account corresponding to the card; receiving, from the client, a code value determined from display of the transaction; and finalizing the transaction with the card provider for the value to be charged when the code value matches the random code.
(X) The e-commerce method denoted as (W), further including: determining, based upon an entity associated with the card, whether statement descriptors of pending transactions are displayed in the transaction list; when statement descriptors of pending transactions are displayed: generating the random code as a string of visible characters; and including the string of visible characters in a statement descriptor of the transaction; when statement descriptors are not displayed: generating the random code as a random value between 0.01 and 1.00; and adding the random value to the value to be charged to form a temporary value that is included within the transaction in place of the value to be charged; and requesting the client provide a pending transaction value of the transaction as the code value, wherein the code value is matched to the temporary value.
This application claims priority to U.S. Provisional Application No. 62/928,340, filed Oct. 30, 2019, and to U.S. Provisional Application No. 63/022,120, filed May 8, 2020, each of which is incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
62928340 | Oct 2019 | US | |
63022120 | May 2020 | US |