US20220224309A1 - Integrating Predefined Templates with Open Ticket Functionality - Google Patents
Integrating Predefined Templates with Open Ticket Functionality Download PDFInfo
- Publication number
- US20220224309A1 US20220224309A1 US17/703,821 US202217703821A US2022224309A1 US 20220224309 A1 US20220224309 A1 US 20220224309A1 US 202217703821 A US202217703821 A US 202217703821A US 2022224309 A1 US2022224309 A1 US 2022224309A1
- Authority
- US
- United States
- Prior art keywords
- transaction
- merchant
- ticket
- open
- customer
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 claims abstract description 112
- 230000000007 visual effect Effects 0.000 claims abstract description 75
- 230000002452 interceptive effect Effects 0.000 claims description 116
- 230000008569 process Effects 0.000 claims description 101
- 230000003993 interaction Effects 0.000 description 17
- 238000004891 communication Methods 0.000 description 9
- 238000010586 diagram Methods 0.000 description 9
- 238000005516 engineering process Methods 0.000 description 5
- 230000006870 function Effects 0.000 description 5
- 230000004044 response Effects 0.000 description 4
- 230000001413 cellular effect Effects 0.000 description 2
- 230000000454 anti-cipatory effect Effects 0.000 description 1
- 230000008901 benefit Effects 0.000 description 1
- 230000010267 cellular communication Effects 0.000 description 1
- 239000000835 fiber Substances 0.000 description 1
- 238000007639 printing Methods 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q30/00—Commerce
- G06Q30/06—Buying, selling or leasing transactions
- G06Q30/0601—Electronic shopping [e-shopping]
- G06Q30/0633—Lists, e.g. purchase orders, compilation or processing
- G06Q30/0635—Processing of requisition or of purchase orders
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/21—Design, administration or maintenance of databases
- G06F16/219—Managing data history or versioning
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/04—Payment circuits
- G06Q20/045—Payment circuits using payment protocols involving tickets
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/08—Payment architectures
- G06Q20/085—Payment architectures involving remote charge determination or related payment systems
- G06Q20/0855—Payment architectures involving remote charge determination or related payment systems involving a third party
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/08—Payment architectures
- G06Q20/12—Payment architectures specially adapted for electronic shopping systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/08—Payment architectures
- G06Q20/20—Point-of-sale [POS] network systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/30—Payment architectures, schemes or protocols characterised by the use of specific devices or networks
- G06Q20/32—Payment architectures, schemes or protocols characterised by the use of specific devices or networks using wireless devices
- G06Q20/322—Aspects of commerce using mobile devices [M-devices]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/30—Payment architectures, schemes or protocols characterised by the use of specific devices or networks
- G06Q20/32—Payment architectures, schemes or protocols characterised by the use of specific devices or networks using wireless devices
- G06Q20/327—Short range or proximity payments by means of M-devices
- G06Q20/3276—Short range or proximity payments by means of M-devices using a pictured code, e.g. barcode or QR-code, being read by the M-device
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q50/00—Information and communication technology [ICT] specially adapted for implementation of business processes of specific business sectors, e.g. utilities or tourism
- G06Q50/10—Services
- G06Q50/12—Hotels or restaurants
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03H—IMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
- H03H9/00—Networks comprising electromechanical or electro-acoustic devices; Electromechanical resonators
- H03H9/02—Details
- H03H9/02228—Guided bulk acoustic wave devices or Lamb wave devices having interdigital transducers situated in parallel planes on either side of a piezoelectric layer
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03H—IMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
- H03H9/00—Networks comprising electromechanical or electro-acoustic devices; Electromechanical resonators
- H03H9/02—Details
- H03H9/02535—Details of surface acoustic wave devices
- H03H9/02543—Characteristics of substrate, e.g. cutting angles
- H03H9/02574—Characteristics of substrate, e.g. cutting angles of combined substrates, multilayered substrates, piezoelectrical layers on not-piezoelectrical substrate
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03H—IMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
- H03H9/00—Networks comprising electromechanical or electro-acoustic devices; Electromechanical resonators
- H03H9/02—Details
- H03H9/02535—Details of surface acoustic wave devices
- H03H9/02818—Means for compensation or elimination of undesirable effects
- H03H9/02866—Means for compensation or elimination of undesirable effects of bulk wave excitation and reflections
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03H—IMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
- H03H9/00—Networks comprising electromechanical or electro-acoustic devices; Electromechanical resonators
- H03H9/02—Details
- H03H9/02535—Details of surface acoustic wave devices
- H03H9/02992—Details of bus bars, contact pads or other electrical connections for finger electrodes
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03H—IMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
- H03H9/00—Networks comprising electromechanical or electro-acoustic devices; Electromechanical resonators
- H03H9/02—Details
- H03H9/125—Driving means, e.g. electrodes, coils
- H03H9/13—Driving means, e.g. electrodes, coils for networks consisting of piezoelectric or electrostrictive materials
- H03H9/131—Driving means, e.g. electrodes, coils for networks consisting of piezoelectric or electrostrictive materials consisting of a multilayered structure
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03H—IMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
- H03H9/00—Networks comprising electromechanical or electro-acoustic devices; Electromechanical resonators
- H03H9/02—Details
- H03H9/125—Driving means, e.g. electrodes, coils
- H03H9/145—Driving means, e.g. electrodes, coils for networks using surface acoustic waves
- H03H9/14538—Formation
- H03H9/14541—Multilayer finger or busbar electrode
-
- H—ELECTRICITY
- H03—ELECTRONIC CIRCUITRY
- H03H—IMPEDANCE NETWORKS, e.g. RESONANT CIRCUITS; RESONATORS
- H03H9/00—Networks comprising electromechanical or electro-acoustic devices; Electromechanical resonators
- H03H9/15—Constructional features of resonators consisting of piezoelectric or electrostrictive material
- H03H9/17—Constructional features of resonators consisting of piezoelectric or electrostrictive material having a single resonator
Definitions
- POS point-of-sale
- a merchant can input data into a POS device, such as items ordered by a customer during a transaction.
- the POS device can then use the data to generate a ticket for the transaction.
- the POS device can present the ticket to the merchant.
- the merchant can then use the ticket when conducting the transaction with the customer.
- the merchant can use the ticket to process the transaction for the customer.
- FIG. 1 illustrates an example system for handling open ticket transactions among customers and merchants.
- FIG. 2 is an example illustration of merchant devices integrating predefined templates with open ticket functionality.
- the merchant devices then synchronize data associated with generated open tickets.
- FIG. 3 is an example illustration of a third-party service integrating predefined templates with open ticket functionality for merchant devices.
- FIG. 4 is an example illustration of open tickets that were generated using predefined templates and/or transaction flows.
- FIGS. 5A-5B are example illustrations of user interfaces for creating open tickets using predefined templates.
- FIG. 6 is an example illustration of merging two open tickets in order to create a merged open ticket.
- FIGS. 7A-7B are a flow diagram illustrating an example process for integrating predefined templates with open ticket functionality.
- FIG. 8 is a flow diagram of illustrating an example process for updating an open ticket based on a type of transaction between a merchant and a customer changing.
- FIG. 9 is a flow diagram of an example process for merging two open tickets in order to generate a merged open ticket.
- FIG. 10 is a flow diagram illustrating an example process of a third-party service integrating predefined templates with open ticket functionality.
- a merchant can utilize a point-of-sale (POS) to conduct transactions with customers. For instance, the merchant can input data associated with each of the transactions into the POS device. The POS device can then generate open tickets for the transactions using the inputted data.
- an open ticket is a data structure that stores information associated with interactions between the merchant and customers during the course of a transaction.
- the open ticket data structure can include an associated versioning data structure that the POS device uses when synchronizing the open ticket data structure with other merchant devices (e.g., other POS devices).
- the associated versioning data structure can include a vector that indicates each time the open ticket data structure is updated by one of the POS devices.
- the POS device can generate the open tickets using predefined ticket templates (e.g., predefined ticket types).
- predefined ticket templates can define which elements are included within open tickets.
- a predefined ticket template can define which graphics, text, interactive elements, or the like are included within an open ticket.
- the predefined ticket templates can further define a layout for the elements within the open tickets.
- the predefined ticket template above can define a layout for the graphics, text, interactive elements, or the like.
- the POS device selects which predefined ticket template to use for an open ticket of a transaction based on a type of transaction that the merchant is conducting the customer.
- the POS device can associate predefined ticket templates with various types of transactions.
- Types of transactions can include transactions that occur at the physical establishment of the merchant and/or transactions that occur outside of the physical establishment of the merchant.
- types of transactions can be based zones/stations within the physical establishment of the merchant.
- the types of transactions can include restaurant area transactions, bar area transactions, waiting area transactions, patio area transactions, or the like.
- types of merchants can include delivery type transactions.
- the POS device identifies the type of transaction that is being conducted between the merchant and the customer. For instance, the POS device can receive input associated with a transaction between the merchant and the customer. In some examples, the input can indicate the type of transaction that is being conducted between the merchant and the customer (e.g., a restaurant area transaction). Additionally or alternatively, in some examples, the input can indicate a group (e.g., the zone/station) associated with the customer. In such examples, the POS device can determine the type of transaction based on the group. The POS device can then select the predefined ticket template for the transaction based on the association between the predefined ticket template and the identified type of transaction. Using the predefined ticket template, the POS device can then generate an open ticket for the transaction between the merchant and the customer.
- the POS device can receive input associated with a transaction between the merchant and the customer.
- the input can indicate the type of transaction that is being conducted between the merchant and the customer (e.g., a restaurant area transaction).
- the input can indicate a group (
- the POS device can further associated transaction flows with the open ticket.
- Transaction flows can define one or more process(es) that the merchant is to perform during the transaction with the customer.
- a transaction flow can include various steps associated with the transaction, such as when to input data associated with the customer, when to input data associated with customer orders, when to process the transaction, whether to provide the customer with a physical and/or digital receipt, or the like.
- the POS device selects the transaction flow for the open ticket based on the predefined ticket template that the POS device uses to generate the open ticket.
- the POS device can present the open ticket to the merchant. For instance, the POS device can generate a visual representation of data associated with the open ticket, and present the visual representation of the data via a display device. The merchant can then utilize the visual representation during the course of the transaction with the customer. For instance, in some examples, the merchant can utilize the visual representation to add additional orders made by the customer to the open ticket. In some examples, the merchant can utilize the visual representation to merge the open ticket with an additional open ticket. In some examples, the merchant can utilize the visual representation to modify the type of transaction associated with the transaction. When modifying the type of transaction, the POS device can update the open ticket using a new predefined ticket template and/or transaction flow. Additionally, in some examples, the merchant can utilize the visual representation to process the transaction with the customer.
- a third-party service can generate the open tickets for the merchant using a similar process as the POS device above.
- the third-party service can receive, from the POS device, data associated with a transaction between the merchant and a customer.
- the third-party service can then use the data to identify a type of transaction for the transaction between the merchant and the customer.
- the third-party service can generate an open ticket for the transaction using a predefined ticket template.
- the third-party service can further associate a transaction flow with the open ticket.
- the third-party service can send data associated with the open ticket to the POS device and/or another POS device associated with the merchant.
- FIG. 1 illustrates an example system 100 for handling open ticket transactions among customers and merchants. More particularly, FIG. 1 provides a framework for integrating predefined ticket templates with POS functionality on merchant devices. For instance, in some examples, the system 100 can generate open tickets for a merchant using predefined ticket templates. Additionally, in some examples, the system 100 can associate transaction flows with generated open tickets.
- the system 100 may include one or more user(s) 102 (e.g. customers), one or more user device(s) 104 associated with the user(s) 102 , one or more merchants 106 , one or more merchant devices 108 associated with the one or more merchants 106 , one or more network(s) 110 , and one or more computing device(s) 112 .
- the user(s) 102 may operate the user device(s) 104 , which may include one or more processor(s) 114 , computer-readable media 116 , a display 118 and a network interface 120 .
- the computer-readable media 116 may store a payment service interface 122 and a POS module 124 .
- the merchant(s) 106 may operate the merchant device(s) 108 , which may include one or more processor(s) 126 , computer-readable media 128 , a card reader 130 , a display 132 and a network interface 134 .
- the computer-readable media 126 may store a payment service interface 136 and a POS module 138 .
- the computing device(s) 112 may also include one or more processor(s) 140 , computer-readable media 142 and a network interface 144 .
- the computer readable media 142 may store a user interaction module 146 , a merchant interaction module 148 , a payment module 150 , an open ticket module 152 , and a database 154 .
- one of the users 102 may operate a user device 104 to perform various functions associated with the user device 104 .
- a user of the user(s) 102 may utilize the user device 104 , and particularly the payment service interface 122 thereof, to interact with the computing device(s) 112 via the network interface 120 to establish a user account with the payment service of the computing device(s) 112 .
- a user of the user(s) 102 may utilize POS module 124 of the user device 104 to interface with the POS module 138 of the merchant device(s) 108 , e.g. as part of a transaction using the payment service of the computing device(s) 112 .
- the processor(s) 114 of the user device 104 may execute one or more modules and/or processes to cause the user device 104 to perform a variety of functions, as set forth above and explained in further detail in the following disclosure.
- the processor(s) 114 may include a central processing unit (CPU), a graphics processing unit (GPU), both CPU and GPU, or other processing units or components known in the art. Additionally, each of the processor(s) 114 may possess its own local memory, which also may store program modules, program data, and/or one or more operating systems.
- the computer-readable media 116 may include volatile memory (such as RAM), non-volatile memory (such as ROM, flash memory, miniature hard drive, memory card, or the like), or some combination thereof.
- volatile memory such as RAM
- non-volatile memory such as ROM, flash memory, miniature hard drive, memory card, or the like
- the user device 104 may also have input device(s) such as a keyboard, a mouse, a pen, a voice input device, a touch input device, etc.
- the user device 104 may also include the display 118 and other output device(s), such as speakers, a printer, etc.
- the user 102 may utilize the foregoing features to interact with the user device 104 , merchant device(s) 108 or the computing device(s) 112 via the network(s) 110 .
- the display 118 of the user device 104 may include any type of display 118 known in the art that is configured to present (e.g., display) information to the users 102 .
- the one or more merchants 106 may be any individual, entity, or machine that offers products, services or the like according to the examples herein. Moreover, each of the merchants 106 may be associated with one or more merchant devices 108 , which may be the same as, similar to, or different from the user devices 104 .
- the merchant devices 108 may include any number of components such as the one or more processor(s) 126 , the computer-readable media 128 , the card reader 130 , the display 132 and/or network interface 134 .
- the merchants 106 may utilize the merchant devices 108 to interact with the user device(s) 104 and/or computing device(s) 112 in any manner.
- the merchant devices 108 may be used to access an interface associated with the computing device(s) 112 (e.g. the payment service interface 136 ).
- a merchant device 108 may utilize information obtained from interacting with the POS module 124 of the user device 104 to execute the payment from the user 102 to the merchant 106 through the payment service of the computing device(s) 112 .
- the POS module 138 may control the operation of the card reader 130 to read payment information from credit cards, debit cards, gift cards and the like.
- the POS module 138 may operate to interact with the card payment network computing devices(s) 162 and/or bank(s) computing device(s) 164 to execute payments from the user 102 to the merchant 106 .
- the user devices 104 and merchant devices 108 are shown as including different modules, this is merely for ease of illustration and not intended as limiting. In various implementations, the user devices 104 and merchant devices 108 may be identical, similar or distinct. Moreover, the modules shown and described for the user devices 104 and merchant devices 108 may be implemented as more modules or as fewer modules and functions described for the modules may be redistributed depending on the details of the implementation. Further, in some implementations, the user devices 104 and/or merchant devices 108 may vary from device to device. In general, the user devices 104 and the merchant devices 108 can each be any appropriate device operable to send and receive requests, messages, or other types of information over the one or more networks 110 or directly to each other. Additionally, in some implementation, there may be thousands, hundreds of thousands, or more, of the user devices 104 and the merchant devices 108 .
- the network(s) 110 may be any type of network known in the art, such as a local area network or a wide area network, such as the Internet, and may include a wireless network, such as a cellular network, a local wireless network, such as Wi-Fi and/or close-range wireless communications, such as Bluetooth® and Bluetooth® low energy, near field communications (NFC), a wired network, or any other such network, or any combination thereof.
- the one or more networks 110 may include both wired and/or wireless communication technologies, including Bluetooth®, Bluetooth® low energy, Wi-Fi and cellular communication technologies, as well as wired or fiber optic technologies. Components used for such communications can depend at least in part upon the type of network, the environment selected, or both.
- the user devices 104 , the merchant devices 108 , and the computing device(s) 112 may communicatively couple to the network(s) 110 in any manner, such as by a wired or wireless connection.
- the network(s) 110 may also facilitate communication between the user devices 104 , the merchant devices 108 , and the computing device(s) 112 .
- the network interfaces 120 , 134 and 144 of the user devices 104 , the merchant devices 108 , and the computing device(s) 112 may be any network interface hardware components that may allow user devices 104 , the merchant devices 108 , and the computing device(s) 112 communicate over the network(s) 110 .
- the network interfaces 120 and 134 of the user devices 104 and merchant devices 108 may include near field communication capabilities for performing the communications there between involved in POS operations.
- the computing device(s) 112 may include the one or more processor(s) 140 , the computer-readable media 142 and network interface 144 .
- the computing device(s) 112 may also include additional components not listed above that may perform any function associated with the computing device(s) 112 .
- the computing device(s) 112 may be any type of computing device, such as a network-accessible server, and may be one of multiple servers included in a server cluster or server farm.
- the processor(s) 140 and the computer-readable media 142 of the computing device(s) 112 may be the same as, similar to, or different from the processor(s) 114 and the computer-readable media 116 , respectively, of the user device(s) 104 .
- the computer-readable media 142 may store the user interaction module 146 , the merchant interaction module 148 , the payment module 150 , the open ticket module 152 , and the database 154 .
- the database 154 may store various information including user account information 156 , merchant information 158 , and open tickets 160 .
- the user interaction module 146 and merchant interaction module 148 operate to interface with the user devices 104 and merchant devices 108 , respectively.
- the modules 146 and 148 may operate in accordance with instructions from the payment module 150 to request or provide information on behalf of the payment module 150 .
- the payment module 150 may handle the processing of payments.
- the payment module 150 may utilize the user interaction module 146 and the merchant interaction module 148 to handle communication with the user 102 and merchant 106 , respectively.
- the payment module 150 may utilize information from the database 154 , such as the user account information 156 and merchant information 158 to provide handling of payments between merchants and users.
- user account information 156 may include information regarding electronic payment accounts of the customers (e.g. users 102 ).
- the payment module 150 may handle payments between merchants and users.
- a user 102 can provide the amount of payment that is due to a merchant 106 using cash, check, a payment card, NFC, or by electronic payment through a payment service of the computing device(s) 112 .
- the merchant 106 can interact with the merchant device 108 to process the transaction.
- the service of the computing devise 112 may handle some payments while other payments may at least at times be handled by point of sale (POS) transactions.
- POS point of sale
- the point of sale may be the place where the user 102 with user device 104 interacts with the merchant 106 with merchant device 108 and executes a transaction (e.g. purchases items from a street vendor merchant or a restaurant merchant).
- POS point-of-sale
- the merchant device 108 can determine and send data describing the transactions, including, for example, services provided, item(s) being purchased, the amount of the services or item(s), buyer information, and so forth.
- the payment service enables card-less payments, i.e., electronic payments, for transactions between the users 102 and the merchants 106 based on interaction of the user 102 with the user device 104 and interaction of the merchant 106 with the merchant device 108 .
- a card-less payment transaction may include a transaction conducted between a user 102 and a merchant 106 at a POS location during which an electronic payment account of the user 102 is charged without the user 102 having to physically present a payment card to the merchant 106 at the POS location. Consequently, the merchant 106 need not receive any details about the financial account of the user 102 for the transaction to be processed.
- the electronic payment may be charged to a credit card issuer or credit card number that the user 102 provided when signing up with the service of the computing device(s) 112 for an electronic payment account.
- the user 102 may have a quantity of money pre-paid in an account maintained for use in making the electronic payments.
- Other variations will also be apparent to those of skill in the art having the benefit of the disclosure herein.
- the user 102 Before conducting an electronic payment transaction, the user 102 typically creates a user account with the service of the computing device(s) 112 .
- the user 102 can create the user account, for example, by interacting with an application of the user device 104 that is configured to perform electronic payment transactions and that may execute on the user device 104 (e.g. the payment service interface 122 ).
- the user 102 may provide an image including the face of the user, data describing a financial account of the user 102 (e.g., a credit card number, expiration date), and a billing address.
- This user information can be securely stored by the computing device(s) 112 , for example, in the user account information 156 in the database 154 .
- the user account information 156 may be created for each user 102 , which may include information about the user and transactions conducted by the user.
- the merchant 106 may create a merchant account with the service of the computing device(s) 112 by providing information describing the merchant including, for example, a merchant name, contact information, e.g., telephone numbers, the merchant's geographic location address, and one or more financial accounts to which funds collected from users will be deposited.
- This merchant information 158 can be securely stored by the service, for example, in the database 154 along with the user account information 156 .
- a merchant profile may be created for each merchant, which may include information about the merchant and transactions conducted by the merchant.
- the service of the computing device(s) 112 may be configured to enable electronic payments for transactions.
- the computing device(s) 112 can include one or more servers that are configured to perform secure electronic financial transactions, e.g., electronic payments for transactions between a user and a merchant, for example, through data communicated between the user device 104 and the merchant device 108 .
- secure electronic financial transactions e.g., electronic payments for transactions between a user and a merchant, for example, through data communicated between the user device 104 and the merchant device 108 .
- the transaction is processed by electronically transferring funds from a financial account associated with the user account to a financial account associated with the merchant account.
- the user may have a balance of funds maintained by the payment service as part of the user account which may be used in transactions.
- the payment module 150 may be configured to send and receive data to and from the user device 104 and the merchant device 108 .
- the payment module 150 can be configured to send information describing merchants to an application on the user device 104 using, for example, the information stored in the database 154 .
- the payment module 150 can communicate data describing merchants 106 that are within a threshold geographic distance from a geographic location of the user device 104 .
- the data describing the merchants 106 can include, for example, a merchant name, geographic location, contact information, and an electronic catalogue, e.g., a menu that describes items that are available from the merchant.
- the payment module 150 is configured to determine whether a geographic location of the user device 104 is within a threshold geographic distance from a geographic location of the merchant device 108 .
- the payment module 150 can determine a geographic location of the user device 104 using, for example, geolocation data provided by the user device 104 .
- the payment module 150 can determine a geographic location of the merchant device 108 using, for example, geolocation data provided by the merchant device 108 or using a geographic address, e.g., street address, provided by the merchant.
- the threshold geographic distance can be specified by the payment module 150 , by the user, or by the merchant.
- Determining whether the user device 104 is within a threshold geographic distance of the merchant device 108 can be accomplished in different ways including, for example, determining whether the user device 104 is within a threshold geographic radius of the merchant device 108 , determining whether the user device 104 is within a particular geofence, or determining whether the user device 104 can communicate with the merchant device 108 using a specified wireless technology, e.g., Bluetooth® or Bluetooth® low energy (BLE).
- the payment module 150 restricts electronic payment transactions between the user 102 and the merchant 106 to situations where the geographic location of the user device 104 is within a threshold geographic distance from a geographic location of the merchant device 108 .
- the computing device(s) 112 can also be configured to communicate with one or more card payment network computing devices(s) 162 of a card payment network (e.g., MasterCard®, VISA®) over the one or more networks 110 to conduct financial transactions electronically.
- the computing device(s) 112 can also communicate with one or more bank computing devices 164 of one or more banks over the one or more networks 110 .
- the computing device(s) 112 may communicate with an acquiring bank, and/or an issuing bank, and/or a bank maintaining user accounts for electronic payments.
- An acquiring bank may be a registered member of a card association (e.g., Visa®, MasterCard®), and may be part of a card payment network.
- An issuing bank may issue payment cards to users, and may pay acquiring banks for purchases made by cardholders to which the issuing bank has issued a payment card.
- the computing device(s) of an acquiring bank may be included in the card payment network and may communicate with the computing devices of a card-issuing bank to obtain payment.
- the user may use a debit card or gift card instead of a credit card, in which case, the bank computing device(s) of a bank or other institution corresponding to the debit card or gift card may receive communications regarding a transaction in which the user is participating.
- the merchant device(s) 108 may perform interactions similar to those described above with regard to the card payment network computing devices(s) 162 of a card payment network and the bank computing devices 164 when processing transactions for payment instruments that do not involve the payment service of the computing device(s) 112 .
- the user 102 operating the user device 104 that is within a threshold geographic distance of the merchant device 108 can interact with an application executed on the user device 104 to conduct an electronic payment transaction with the merchant 106 . While interacting with the application, the user 102 can select the merchant 106 , from a listing of merchants 106 , with whom the user wants to enter into an electronic payment transaction. The user 102 can select the merchant 106 , for example, by selecting a “check in” option associated with the merchant 106 .
- the user device 104 can communicate data to the computing device(s) 112 indicating that the user 102 has checked in with the merchant 106 . In response, the computing device(s) 112 can communicate data to notify the merchant device 108 that the user has checked in.
- An application executing on the merchant device 108 can notify the merchant 106 that the user has electronically checked in with the merchant 106 through a display of the merchant device 108 .
- the user 102 can receive, obtain or request items, services or appointments that are available to be acquired from the merchant 106 .
- the user 102 can, for example, approach a point of sale for the merchant 106 and identify him or herself.
- the user 102 can verbally notify the merchant 106 that the user 102 wants to enter into a card-less payment transaction and can provide the merchant 106 with the user's name.
- the merchant 106 can then interact with the application executing on the merchant's device to select the user 102 , from a listing of users that have checked in with the merchant 106 , to initiate an electronic payment transaction for the item(s) being acquired by the user 102 .
- the merchant 106 can determine a total amount to charge the user for the item(s) being acquired.
- the user can verbally approve the total amount to be paid and, in response, the merchant 106 can submit a request for an electronic payment transaction for the total amount of the transaction to the computing device(s) 112 .
- the computing device(s) 112 can obtain, for example, from the user account information 156 , data describing a financial account associated with the electronic purchase account of the user 102 to which the total amount will be charged.
- the computing device(s) 112 can then communicate with the card payment network computing devices(s) 162 of a card payment network to complete an electronic payment transaction for the total amount to be charged to user's electronic payment account. Once the electronic payment transaction is complete, the computing device(s) 112 can communicate data describing the electronic payment for the transaction to the user device 104 , e.g., as an electronic receipt, which can, for example, notify the user 102 of the total amount charged to the user for the electronic payment for the transaction with the particular merchant. Further, while a mobile user device 104 is described in this example for purposes of explanation, additional or alternative types of devices may be used in other examples.
- a merchant 106 can utilize a merchant device 108 (e.g., a POS device) to conduct transactions with user(s) 102 .
- the merchant 106 can input data associated with the transactions into the merchant device 108 .
- the input can include identities of the user(s) 102 , personal information associated with the user(s) 102 (e.g., contact information, addresses, etc.), locations of the user(s) 102 within a physical establishment of the merchant 106 (e.g., restaurant area, bar area, waiting area, patio area, etc.), orders made by the user(s) 102 during a course of the transactions with the merchant 106 , or the like.
- the merchant device 108 can generate open tickets for the transactions between the merchant 106 and the user(s) 102 .
- an open ticket is a data structure that stores information associated with interactions between the merchant 106 and user(s) 102 during a course of a transaction.
- the interactions can include an identity of the merchant 106 , a location of the merchant 106 , identities of the user(s) 102 , the personal information associated with the user(s) 102 , the locations of the user(s) 102 within the physical establishment of the merchant 106 , the items order by the user(s) 102 during the transaction (e.g., cart information), timestamps for each of the items ordered by the user(s) 102 during the transaction, a cost associated with each of the items, a cost associated with the open ticket, or other information associated with the transaction.
- the merchant device 108 can further update the data structures for the open tickets. For instance, the merchant device 108 can add (e.g., store) additional information associated with interactions between the merchant 106 and the user(s) 102 to the data structures.
- the open ticket data structures further include associated versioning data structures that the merchant device 108 uses to when synchronizing open tickets with other merchant devices 108 (e.g., a second POS device).
- an associated versioning data structure for an open ticket data structure can include a vector that indicates each time the open ticket data structure is updated by the merchant device 108 (and/or any other of the merchant device(s) 108 ).
- the merchant device 108 may cause the vector of the versioning data structure to include a count of one. The merchant device 108 can then increase the count of the vector each time the merchant device 108 updates the open ticket.
- Open ticket data structures described herein may be generated, maintained, and/or synchronized using some or all of the techniques described in U.S. patent application Ser. No. 14/686,381, filed on Apr. 14, 2015 and entitled “Open Ticket Payment Handling with Offline Mode”, and U.S. patent application Ser. No. 14/871,776, filed Sep. 30, 2015, entitled “Anticipatory Creation of Point-Of-Sale Structures,” which are incorporated herein by reference in its entirety.
- the merchant device 108 can generate the open tickets using predefined ticket templates (e.g., predefined types of tickets).
- Predefined ticket templates can define which elements are included within open tickets.
- a predefined ticket template can define which graphics, text, interactive elements, or the like are included within an open ticket.
- the predefined ticket templates can further define a layout for the elements within the open tickets.
- the predefined ticket template above can define a layout for the graphics, text, interactive elements, or the like.
- the merchant device 108 selects which predefined ticket template to use for an open ticket of a transaction based on a type of transaction that the merchant is conducting with the user(s) 102 .
- the merchant device 108 can associate predefined ticket templates with various types of transactions.
- Types of transactions can include transactions that occur at the physical establishment of the merchant 106 and/or transactions that occur outside of the physical establishment of the merchant 106 .
- types of transaction can be based zones/stations within the physical establishment of the merchant 106 .
- the types of transactions can include restaurant area transactions, bar area transactions, waiting area transactions, patio area transactions, or the like.
- types of merchants can include delivery type transactions.
- the merchant device 108 identifies the type of transaction that is being conducted between the merchant 106 and user(s) 102 . For instance, the merchant device 108 can receive input associated with a transaction between the merchant 106 and user(s) 102 . In some examples, the input can indicate the type of transaction that is being conducted between the merchant 106 and the user(s) 102 . Additionally or alternatively, in some examples, the input can indicate a group (e.g., the zone/station) associated with the user(s) 102 . In such examples, the merchant device 108 can determine the type of transaction based on the group.
- the group e.g., the zone/station
- the merchant device 108 can then select a predefined ticket template for the transaction based on the association between the predefined ticket template and the identified type of transaction. Using the predefined ticket template, the POS device can then generate an open ticket for the transaction between the merchant 106 and the user(s) 102 .
- the merchant device 108 can further associated transaction flows with the open tickets.
- Transaction flows can define one or more process(es) that the merchant 106 is to perform during a transaction with the user(s) 102 .
- a transaction flow can include various steps associated with the transaction, such as when to input data associated with the user(s) 102 , when to input data associated with orders made by the user(s) 102 , when to process the transaction, whether to provide the user(s) 102 with a physical and/or digital receipt, or the like.
- the merchant device 108 selects a transaction flow for an open ticket based on the predefined ticket template that the merchant device 108 uses when generating the open ticket.
- the merchant device 108 can present the open ticket to the merchant 106 .
- the merchant device 108 can generate a visual representation of data associated with the open ticket, and present the visual representation of the data via the display 132 .
- a layout of data associated with the open ticket is based on the predefined ticket template and/or the transaction flow.
- the elements within the visual representation include the layout defined by the predefined ticket template.
- any messages and/or alerts associated with the process(es) for the transaction flow are provided to the merchant 106 via the visual representation.
- the merchant 106 can then utilize the visual representation during the course of the transaction with the user(s) 102 .
- the merchant 106 can utilize the visual representation to add additional orders made by the user(s) 102 to the open ticket.
- the merchant device 108 can receive input associated with the orders from the merchant 106 , such as indications of items ordered by the user(s) 102 .
- the merchant device 108 can then add data associated with the orders to the open ticket data structure of the open ticket.
- the merchant device 108 can further update the associated versioning data structure for the open ticket data structure in to order to indicate that the open ticket was updated. Additionally, the merchant device 108 can update the visual representation of the open ticket based on the order.
- the merchant 106 can further utilize the visual representation to merge the open ticket with an additional open ticket.
- Merging the open ticket with the additional open ticket can include merging the information from the open ticket data structure of the open ticket with information from the open ticket data structure of the additional open ticket in order to generate a merged open ticket data structure.
- the merged open ticket data structure can include the identity of the merchant 106 , a location of the merchant 106 , identities of the user(s) 102 of the open tickets, the personal information associated with the user(s) 102 of the open tickets, the locations of the user(s) 102 within the physical establishment of the merchant 106 , the items order by the user(s) 102 during the transactions (e.g., cart information), timestamps for each of the items ordered by the user(s) 102 during the transaction, a cost associated with each of the items, a cost associated with the merged open ticket, or other information associated with the transactions.
- the merchant device 108 can then generate a new visual representation of data associated with the merged open ticket, and present the new visual representation of the data via the display device.
- the merchant 106 can further utilize the visual representation to modify the type of transaction associated with the transaction.
- the merchant device 108 can receive input identifying a new type of transaction for the transaction between the merchant 106 and the user(s) 102 .
- the merchant device 108 can then select (and/or determine) a new predetermined ticket template associated with the new type of transaction.
- the merchant device 108 can update the open ticket for the transaction in order to generate a new open ticket.
- the merchant device 108 can then select (and/or determine) a new transaction flow for the new open ticket, and associated the new transaction flow with the new open ticket.
- the merchant device 108 can generate a new visual representation of data associated with the new open ticket, and present the new visual representation of the data via the display device.
- the computing device(s) 112 can generate the open tickets 160 for the merchant 106 using a similar process as the merchant device 108 above. For instance, the computing device(s) 112 can receive, from a merchant device 108 , data associated with the transactions between the merchant 106 and the user(s) 102 . The computing device(s) 112 can then use the data to identify a types of transactions for the transactions between the merchant 106 and the user(s) 112 . Based on the identified types of transactions, computing device(s) 112 can utilize the open ticket module 152 to generate open tickets 160 for the transactions using predefined ticket templates. The computing device(s) 112 can further associate transaction flows with the open tickets 160 . After generating the open tickets 160 , the computing device(s) 112 can send data associated with the open tickets 160 to the merchant device(s) 108 .
- the merchant device 108 and/or the computing device(s) 112 can further synchronize data associated with open tickets. For instance, each time a merchant device 108 updates an open ticket, the merchant device 108 can send data associated with the update to the other merchant device(s) 108 and/or the computing device(s) 112 . When synchronizing the data for the open tickets, the merchant device(s) 108 and/or the computing device(s) 112 can use the associated versioning data structures for the open tickets, as described above.
- FIG. 2 is an example illustration of merchant devices integrating predefined templates with open ticket functionality.
- a first point-of-sale (POS) device 202 and second POS device 204 can generate open tickets using predefined ticket templates and/or transaction flows.
- the first POS device 202 and the second POS device 204 can each represent one of merchant device(s) 108 .
- the processor(s) 206 , the computer-readable media 208 , the card reader 210 , the display 212 , the network interface 214 , the payment service interface 216 , and the POS module 218 of the first merchant device 202 can represent the processor(s) 126 , the computer-readable media 128 , the card reader 130 , the display 132 , the network interface 134 , the payment service interface 136 , and the POS module 138 , respectively.
- the second POS device 204 can include one or more of the components 206 - 232 of the first POS device 202 .
- the first POS device 202 can use the open ticket module 220 to generate open tickets 222 for transactions.
- a merchant e.g., one of merchant(s) 106
- the input can include identities of customers (e.g., user(s) 102 ) associated with the transactions, personal information associated with the customers (e.g., contact information, addresses, etc.), locations of the customers within a physical establishment of the merchant (e.g., stations/zones within the physical establishment, such as restaurant area, bar area, waiting area, patio area, etc.), orders made by the customers during a course of the transactions with the merchant, or the like.
- the first POS device 202 can utilize the open ticket module 152 to generate the open tickets 222 for the transactions.
- open tickets 222 are data structures that store information associated with interactions between the merchant and the customers during a course of the transactions.
- the open tickets 222 further include associated versioning data structures that the first POS device 202 uses when synchronizing the open tickets 222 with other merchant devices, such as the second POS device 204 .
- the first POS device 202 can further update the data structures for the open tickets 222 . For instance, the first POS device 202 can add (e.g., store) additional information associated with interactions between the merchant and the customers to the data structures.
- the first POS device 202 can generate the open tickets 222 using predefined ticket template(s) 224 .
- the predefined ticket template(s) 224 can define which elements are included within the open tickets 222 .
- the predefined ticket template(s) 224 can define which graphics, text, interactive elements, or the like are included within the open tickets 222 .
- the predefined ticket template(s) 224 can define a layout for the elements within the open tickets 222 .
- the predefined ticket template(s) 224 can define the layout (e.g., the locations) for the graphics, text, interactive elements, or the like within the open tickets 222 .
- the first POS device 202 selects which predefined ticket template(s) 224 to utilize when generating open tickets 222 based on types of transactions that the merchant is conducting with customers.
- the first POS device 202 can associate the predefined ticket template(s) 224 with various types of transactions.
- Types of transactions can include transactions that occur at the physical establishment of the merchant and/or transactions that occur outside of the physical establishment of the merchant.
- types of transaction can be based zones/stations (e.g., groups) within the physical establishment of the merchant.
- the types of transactions can include restaurant area transactions, bar area transactions, waiting area transactions, patio area transactions, or the like.
- types of merchants can include delivery type transactions.
- the first POS device 202 identifies the type of transaction that is being conducted between the merchant and a customer. For instance, the first POS device 202 can receive input associated with the transaction between the merchant and the customer. In some examples, the input can indicate the type of transaction that is being conducted between the merchant and the customer. For instance, the input can indicate that the type of transaction includes a restaurant area type of transaction. Additionally or alternatively, in some examples, the input can indicate a group (e.g., a zone/station within the physical establishment) associated with the customer. For instance, the input can indicate that the customer is located within the restaurant area of the physical establishment of the merchant. The first POS device 202 can then determine the type of transaction based on the group.
- the input can indicate the type of transaction that is being conducted between the merchant and the customer. For instance, the input can indicate that the type of transaction includes a restaurant area type of transaction.
- the input can indicate a group (e.g., a zone/station within the physical establishment) associated with the customer. For instance, the input can indicate
- the first POS device 202 selects the predefined ticket template 226 for the transaction. For instance, the first POS device 202 can determine that the predefined ticket template 226 is associated with the identified type of transaction using the association between the predefined ticket template 226 and the identified type of transaction. Based on the determination, the first POS device 202 can select the predetermined ticket template 226 from the predefined ticket template(s) 224 .
- the first POS device 202 After selecting the predefined ticket template 226 , the first POS device 202 generates the open ticket 228 using the predefined ticket template 226 . For instance, the first POS device 202 uses the predefined ticket template 226 to determine which elements to include in the open ticket 228 . The elements can include graphics, text, interactive elements, or the like. The first POS device 202 then uses the predefined ticket template 226 to determine a layout for the elements within the open ticket 228 . For instance, the layout can define a location for each of the elements within the open ticket 228 . In some examples, the first POS device 202 then generates the open ticket 228 based on the elements, the layout, and data input by the merchant that is associated with the transaction. For instance, the first POS device 202 can utilize the elements and/or the layout for the elements within the open ticket 228 in order to place the data received from the merchant within the open ticket 228 .
- the predefined ticket template 226 and/or the transaction flow 232 for the open ticket 228 can define the layout of elements of the open ticket 228 to include a first text portion at a top portion of the open ticket 228 that includes general information about the merchant, a second text portion in a middle portion of the open ticket 228 that includes a list of items, an interactive element below the list of items for adding additional items to the open ticket 228 , and an interactive element at a bottom portion of the open ticket 228 for processing the open ticket 228 .
- the first POS device 202 can generate the layout of the elements for the open ticket 228 .
- the first POS device 202 can then add text to the first text portion and the second text portion based on input that the first POS device 202 receives from the merchant.
- the first POS device 202 can further associate transaction flow(s) 230 with the open tickets 222 .
- Transaction flow(s) 230 can include metadata indicating one or more process(es) that the merchant is to perform during transactions with the customers.
- each of the transaction flow(s) 230 can include data indicating various steps associated with a respective transaction, such as when to input data associated with the customers of the respective transaction, when to input data associated with orders made by the customers of the respective transaction, when to process the respective transaction, whether to provide a digital and/or printed receipt to the customers, or the like.
- the transaction flow(s) 230 cause the first POS device 202 to provide messages and/or alerts to the merchant based on the process(es) that the merchant is to perform during the transactions.
- a transaction flow 230 can cause the first POS device 202 to present a message to the merchant notifying the merchant to input information associated with a customer of the transaction.
- the transaction flow can further cause the first POS device to provide an interactive element on an open ticket 222 of the transaction that the merchant can use to input the information about the customer.
- the transaction flow 230 can cause the first POS device to present a message to the merchant notifying the merchant to input data associated with a customer order.
- the transaction flow 230 can cause the first POS device to provide an interactive element on the open ticket 222 of the transaction that the merchant can use to input the data.
- the transaction flow 230 can then continue to provide the merchant with messages, during a course of the transaction, that notify the merchant of processes to take with the customer.
- the first POS device 202 selects the transaction flow(s) 230 for the open tickets 222 based on the predefined ticket template(s) 224 that the first POS device 202 uses when generating the open tickets 222 .
- the first POS device 202 can associate each of the transaction flow(s) 230 with one or more of the predefined ticket template(s) 224 .
- the associations between the transaction flow(s) 230 and the predefined ticket template(s) 224 are based on the types of transactions. For instance, a transaction flow 230 that defines one or more process(es) that the merchant is to perform during a restaurant area type of transaction can be associated with the predefined ticket template(s) 224 that the merchant associates with restaurant area types of transactions.
- the first POS device 202 can then use the associations between the transaction flow(s) 230 and the predefined ticket template(s) 224 when selecting transaction flow(s) 230 for open tickets 222 .
- the first POS device 202 can determine that the open ticket module 220 generated the open ticket 228 using the predefined ticket template 226 . Based on the determination, the first POS device 202 can determine that the transaction flow 232 from the transaction flow(s) 230 is associated with the predefined ticket template 226 . In response, the first POS device can then select the transaction flow for the open ticket 228 . The first POS device 202 can further associate the transaction flow 232 with the open ticket 228 .
- the first POS device 202 can present the open tickets 222 to the merchant via the display 212 .
- the first POS device 202 can generate a visual representation of data associated with the open ticket 228 .
- the first POS device 202 can then present the visual representation of the data via the display 212 .
- a layout of the data associated with the visual representation is based on the predefined ticket template 226 and/or the transaction flow 232 .
- the elements within the visual representation include the layout defined by the predefined ticket template 226 .
- any messages and/or alerts associated with the process(es) for the transaction flow 232 are provided to the merchant via the visual representation.
- the transaction flow 232 for open ticket 228 may indicate that a process for the transaction includes inputting data associated with the customer (e.g., an address) at a beginning of the transaction.
- the first POS device 202 can provide a message on the visual representation that notifies the merchant to input the data.
- the first POS device 202 can further present an interactive element on the visual representation that the merchant can utilize to input the information.
- the transaction flow 232 for the open ticket 228 can indicate that a process for the transaction includes asking the customer if he/she would like another drink every ten minutes.
- the first POS device 202 can provide an alert on the visual representation every ten minutes when the first POS device 202 does not receive input associated with drink orders for the transaction. The alert can notify the merchant that the merchant is to ask the customer if he/she would like another drink.
- the first POS device 202 can further present an interactive element on the visual representation that the merchant can utilize to input the drink orders for the customer.
- the merchant can utilize the visual representation during the course of the transaction with the customer. For instance, in some examples, the merchant can utilize the visual representation to add additional orders made by the customer to the open ticket 228 .
- the first POS device 202 can receive input associated with the orders from the merchant. The input can indicate one or more items ordered by the customer from the merchant. The first POS device 202 can then add data associated with the orders to the open ticket 228 . Additionally, the first POS device 202 can update the visual representation of the open ticket 228 based on the order. For instance, the first POS device 202 can add indications associated with the one or more items ordered by the customer to the visual representation.
- the merchant can further utilize the visual representation to merge the open ticket 228 with an additional open ticket.
- Merging the open ticket 228 with the additional open ticket can include merging the information from the open ticket data structure of the open ticket 228 with information from the open ticket data structure of the additional open ticket in order to generate a merged open ticket data structure.
- the first POS device 202 can then generate a new visual representation of data associated with the merged open ticket, and present the new visual representation of the data via the display 212 .
- the merchant can further utilize the visual representation to modify the type of transaction associated with the transaction.
- the first POS device 202 can receive input identifying a new type of transaction for the transaction between the merchant and the customer. The first POS device 202 can then select a new predetermined ticket template 224 associated with the new type of transaction. Using the new predetermine ticket template 224 , the first POS device 202 can update the open ticket 228 for the transaction in order to generate a new open ticket. The first POS device 202 can then select a new transaction flow 230 for the new open ticket, and associated the new transaction flow 230 with the new open ticket. After generating the new open ticket, the first POS device 202 can generate a new visual representation of data associated with the new open ticket, and present the new visual representation of the data via the display 212 .
- the first POS device 202 and the second POS device 204 can synchronize open tickets 222 .
- the first POS device 202 can send open ticket data 234 to the second POS device 204 .
- the open ticket data 234 can include data associated with one or more of the open tickets 222 .
- the first POS device 202 sends the open ticket data 234 to the second POS device 204 each time the first POS device 202 updates one of the open tickets 222 .
- the first POS device 202 sends the open ticket data 234 to the second POS device 204 at given time intervals. For instance, the first POS device 202 can send the open ticket data 234 to the second POS device 204 every second, five seconds, minute, or the like.
- the second POS device 204 can send open ticket data 236 to the first POS device 202 .
- the open ticket data 236 can include data associated with one or more of the open tickets stored on the second POS device 204 (which can include open tickets 222 ).
- the second POS device 204 sends the open ticket data 236 to the first POS device 202 each time the second POS device 204 updates one of the open tickets.
- the second POS device 204 sends the open ticket data 236 to the first POS device 202 at given time intervals. For instance, the second POS device 204 can send the open ticket data 236 to the first POS device 202 every second, five seconds, minute, or the like.
- the first POS device 202 and the second POS device 204 use associated versioning data structures for open tickets when performing the synchronization. For instance, the first POS device 202 and/or the second POS device 204 can update the associated versioning data structure of an open ticket each time the first POS device 202 and/or the second POS device updates the open ticket. By updating the associated versioning data structure, the POS device that did not perform the updating can determine that the open ticket was updated by another POS device based on the associated versioning data structure.
- the first POS device 202 can select predefined ticket template(s) 224 for open tickets 222 using customer profiles (e.g., user account information 156 ).
- customer profiles e.g., user account information 156
- the first POS device 202 can store information associated with a customer in a customer profile. The information can include an identity of the customer, contact information associated with the customers, items that the customer ordered from the merchant in previous transactions, payment information associated with the customer, or the like.
- the first POS device 202 can then use the customer profile to determine a type of transaction that the customer prefers when conducting transactions with the merchant. Based on the type of transaction, the first POS device 202 can create an open ticket for the transaction using the processes above.
- the POS device 302 can receive input corresponding to customer orders associated with transactions between the merchant and customers. Based on receiving the input, the POS device 302 can send transactional data 304 associated with the transactions to the computing device(s) 112 .
- the transactional data 304 can include data indicating an identity of the merchant, a location of the merchant, identities of the customers associated with the transaction, the personal information associated with the customers, the locations of the customers within the physical establishment of the merchant, the items order by the customers during a course of the transactions (e.g., cart information), timestamps for each of the items ordered by the customers during the course of the transactions, a cost associated with each of the items, or other information associated with the transactions.
- the POS device 302 sends the computing device(s) 112 transaction data 304 for the transactions each time the POS device 302 receives input associated with one of the transactions. Additionally or alternatively, in some examples, the POS device 302 sends the computing device(s) 112 transaction data 304 at given time intervals, such as every second, minute, five minutes, or the like.
- the computing device(s) 112 can receive the transactional data 304 from the POS device 302 . After receiving the transaction data 304 , the computing device(s) 112 utilize the open ticket module 152 to generate the open tickets 160 (which can represent the open tickets 222 ) for the transactions using the transactional data 304 . For instance, the computing device(s) 112 can generate open tickets 160 for the transactions using a similar process as the first POS device 202 generating the open tickets 222 as described above.
- the computing device(s) 112 can generate the open tickets 160 using predefined ticket template(s) 306 , which can represent predefined ticket template(s) 224 .
- the computing device(s) 112 can determine and/or select predefined ticket template(s) 306 for the open tickets 160 using an association between the predefined ticket templates(s) 306 and types of transactions being conducted by the merchant.
- the computing device(s) 112 can further associate transaction flow(s) 308 with the open tickets 160 , where the transaction flow(s) 308 can represent the transaction flow(s) 230 .
- the computing device(s) 112 can determine and/or select transaction flow(s) 308 for open tickets 160 using associations between the transaction flow(s) 308 and the predefined ticket template(s) 306 .
- the computing device(s) 112 can generate an open ticket 310 for a transaction between the merchant and a customer. To generate the open ticket 310 , the computing device(s) 112 can determine a type of transaction for the transaction using the transaction data 304 . For instance, in some examples, the transaction data 304 can indicate that the type of transaction includes a restaurant area type of transaction. Additionally or alternatively, in some examples, the transaction data 304 can indicate that the customer is associated with the restaurant area group, and the computing device(s) 112 can determine that the type of transaction includes a restaurant area type of transaction based on the group. The computing device(s) 112 can then use the type of transaction to select the predefined ticket template 312 from the predefined ticket template(s) 306 for the open ticket 310 .
- the computing device(s) 112 can utilize the open ticket module 152 to generate the open ticket 310 using the predefined ticket template 312 .
- the computing device(s) 112 can further select, based on the predefined ticket template 312 , a transaction flow 314 from the transaction flow(s) 308 for the open ticket 310 .
- the computing device(s) 112 can determine that the transaction flow 31 is associated with the predefined ticket template 312 . Based on the association, the computing device(s) 112 can select the transaction flow 314 from the transaction flow(s) 308 . The computing device(s) 112 can then associate the transaction flow 314 with the open ticket 310 .
- the computing device(s) 112 can send open ticket data 316 to the POS device 302 .
- the open ticket data 316 can include data associated with one or more of the open tickets 160 .
- the open ticket data 316 can include data indicating identities of the open tickets 160 , identities of the customers associated with the open tickets 160 , the personal information associated with the customers, the locations of the customers within the physical establishment of the merchant, the items order by the customers during a course of the transactions (e.g., cart information), timestamps for each of the items ordered by the customers during the course of the transactions, a cost associated with each of the items, or other information associated with the transactions.
- the POS device 302 can use the open ticket data 316 to generate visual representations of one or more of the open tickets 160 . The POS device 302 can then display the visual representations of the one or more open tickets 160 to the merchant.
- the POS device 302 can continue to send the computing device(s) 112 transaction data 304 associated with transactions between the merchant and customers. For instance, each time the POS device 302 receives input associated with a transaction, the POS device 302 can send the computing device(s) 112 transaction data 304 associated with the input.
- the input can include additional customer orders for the transaction, a request to merge an open ticket 310 for the transaction with another open ticket, an indication that a type of transaction for the transaction has changed, or the like.
- the computing device(s) 112 can use the transaction data 304 from the POS device 302 to update the open ticket 310 for the merchant using a similar process as the POS device 202 above.
- the computing device(s) 112 can synchronize open tickets 160 with additional merchant devices (e.g., POS device) associated with the merchant. For instance, the computing device(s) 112 can receive transaction data associated with transactions from one or more additional merchant devices. Using the transaction data, the computing device(s) 112 can generate open tickets 160 for the transactions. The computing device(s) 112 can then send open ticket data associated with the open tickets 160 to the POS device 302 and/or to the one or more additional merchant devices.
- additional merchant devices e.g., POS device
- FIG. 4 is an example illustration of open tickets that were generated using predefined templates and/or transaction flows.
- a POS device 402 which can represent one of merchant device(s) 108 , is presenting an open ticket interface 404 (which can represent the payment service interface 136 ) to the merchant.
- the open ticket interface 404 includes visual representation of four open tickets 406 - 412 .
- each of the open tickets 406 - 412 can correspond to a respective transaction between the merchant and a customer.
- the first open ticket 406 can include a restaurant area 414 type of transaction between the merchant and a first customer.
- elements included in the first open ticket 406 for the restaurant area 414 type of transaction include a table number 416 , a list of items 418 , an interactive add items 420 button, an interactive merge 422 tickets button, and an interactive process 424 the transaction button.
- the table number 416 can include text indicating a table that the first customer is seated at within the restaurant area of the physical establishment of the merchant. For instance, the table number 416 can indicate that the first customer is seated at table five.
- the list of items 418 can indicate one or more items ordered by the first customer during a course of the transaction.
- the interactive add items 420 button can include an interactive element of the first open ticket 406 that the merchant can select to add additional items to the first open ticket 406 .
- the interactive merge 422 button can include an interactive element of the first open ticket 406 that the merchant can select to merge the first open ticket 406 with one or more additional open tickets (e.g., open tickets 408 - 412 ).
- the interactive process 424 transaction button can include an interactive element of the first open ticket 406 that the merchant can select to process the first open ticket 406 at the end of the transaction.
- a predefined ticket template and/or the transaction flow for the first open ticket 406 can configure the first open ticket 406 to include the elements 414 - 424 .
- the predefined ticket template for the first open ticket 606 can define that the first open ticket 406 includes text indicating the restaurant area 414 type of transaction, the table number 416 , and the list of items 418 .
- the predefined ticket template and/or the transaction flow for the first open ticket 406 can define that the first open ticket 406 include the interactive add items 420 button, the interactive merge 422 items button, and the interactive process 424 the transaction button.
- the transaction flow for the first open ticket 406 can define when messages and/or alerts are presented via the first open ticket 406 based on process(es) for a restaurant area 414 type of transaction.
- the transaction flow for the restaurant area 414 type of transaction can cause the first open ticket 406 to present messages indicating when the merchant should take drink orders, food orders, or desert orders from the first customer. Additionally, the transaction flow for the restaurant area 414 type of transaction can cause the POS device 402 to print a physical receipt (instead of sending a digital receipt) for the transaction.
- the second open ticket 408 can include a bar area 414 type of transaction between the merchant and a second customer. As illustrated in FIG. 4 , elements included in the second open ticket 408 for the bar area 426 type of transaction include a seat number 428 , a list of items 430 , an interactive add items 432 button, an interactive merge 434 tickets button, and an interactive process 436 the transaction button.
- the seat number 428 can include text indicating a seat that the second customer is seated at within the bar area of the physical establishment of the merchant. For instance, the seat number 428 can indicate that the second customer is seated at seat six.
- the list of items 430 can indicate one or more items ordered by the second customer during a course of the transaction.
- the interactive add items 432 button can include an interactive element of the second open ticket 408 that the merchant can select to add additional items to the second open ticket 408 .
- the interactive merge 434 button can include an interactive element of the second open ticket 408 that the merchant can select to merge the second open ticket 408 with one or more additional open tickets (e.g., open tickets 406 , 410 , 412 ).
- the interactive process 436 transaction button can include an interactive element of the second open ticket 408 that the merchant can select to process the second open ticket 408 at the end of the transaction.
- a predefined ticket template and/or the transaction flow for the second open ticket 408 can configure the second open ticket 408 to include the elements 426 - 436 .
- the predefined ticket template of the second open ticket 408 can define that the second open ticket 408 includes text indicating the bar area 426 type of transaction, the seat number 428 , and the list of items 430 .
- the predefined ticket template and/or the transaction flow for the second open ticket 408 can define that the second open ticket 408 includes the interactive add items 432 button, the interactive merge 434 tickets button, and the interactive process 436 the transaction button.
- the transaction flow for the second open ticket 408 can define when messages and/or alerts are presented via the second open ticket 408 based on process(es) for a bar area 426 type of transaction.
- the transaction flow for the bar area 426 type of transaction can cause the second open ticket 408 to present messages indicating when the merchant should ask the second customer if he/she would like another drink. Additionally, the transaction flow for the bar area 426 type of transaction can cause the second open ticket 408 to present a message indicating that the merchant should ask the second customer if he/she would like to order food. Moreover, the transaction flow for the bar area 426 type of transaction can cause the POS device 402 to print a physical receipt (instead of sending a digital receipt) for the transaction.
- the third open ticket 410 can include a waitlist area 438 type of transaction between the merchant and a third customer. As illustrated in FIG. 4 , elements included in the third open ticket 410 for the waitlist area 438 type of transaction include a waitlist position 440 , a list of items 442 , an interactive add items 444 button, an interactive transaction type 446 button, and an interactive process 448 the transaction button.
- the waitlist position 440 can include text indicating a position on a waitlist associated with the third customer. For instance, the waitlist position 440 can indicate that the third customer is next to be seated and/or that the estimated wait time for the third customer is five minutes.
- the list of items 442 can indicate one or more items ordered by the third customer during a course of the transaction.
- the interactive add items 444 button can include an interactive element of the third open ticket 410 that the merchant can select to add additional items to the third open ticket 410 .
- the interactive transaction type 446 button can include an interactive element of the third open ticket 410 that the merchant can select to update a type of transaction associated with the third open ticket 410 when the customer is seated at the physical establishment of the merchant.
- the interactive process 448 transaction button can include an interactive element of the third open ticket 410 that the merchant can select to process the third open ticket 410 at the end of the transaction.
- a predefined ticket template and/or the transaction flow for the third open ticket 410 can configure the third open ticket 410 to include the elements 438 - 448 .
- the predefined ticket template can define that the third open ticket 410 includes text indicating the waiting area 438 type of transaction, the waitlist position 440 , and the list of items 442 .
- the predefined ticket template and/or the transaction flow for the third open ticket 410 can define that the third open ticket 410 include the interactive add items 444 button, the interactive transaction type 446 button, and the interactive process 448 the transaction button.
- the transaction flow for the third open ticket 410 can define when messages and/or alerts are presented via the third open ticket 410 based on process(es) for a waitlist area 438 type of transaction.
- the transaction flow for the waitlist area 438 type of transaction can cause the third open ticket 410 to present messages indicating when to update the third customer about the estimated wait time. Additionally, if the merchant closes the transaction before seating the third customer, the transaction flow for the waitlist area 438 type of transaction can cause the POS device 402 to print a physical receipt (instead of sending a digital receipt) for the transaction.
- the fourth open ticket 412 can include a delivery 450 type of transaction between the merchant and a fourth customer. As illustrated in FIG. 4 , elements included in the fourth open ticket 412 for the delivery 450 type of transaction include an address 452 , a list of items 454 , an interactive add items 456 button, an interactive route to driver 458 button, and an interactive process 460 the transaction button.
- the address 452 can include text indicating an address associated with the fourth customer.
- the list of items 454 can indicate one or more items ordered by the fourth customer for delivery.
- the interactive add items 456 button can include an interactive element of the fourth open ticket 412 that the merchant can select to add additional items to the third open ticket 410 .
- the interactive route to driver 458 button can include an interactive element of the fourth open ticket 412 that the merchant can select to route the order to one of the merchant's drivers.
- the interactive process 460 transaction button can include an interactive element of the fourth open ticket 412 that the merchant can select to process the fourth open ticket 412 at the end of the transaction.
- a predefined ticket template and/or the transaction flow for the fourth open ticket 412 can configure the fourth open ticket 412 to include the elements 450 - 460 .
- the predefined ticket template can define that the fourth open ticket 412 includes text indicating the delivery 450 type of transaction, the address 452 , and the list of items 454 .
- the predefined ticket template and/or the transaction flow for the fourth open ticket 412 can define that the fourth open ticket 412 include the interactive add items 456 button, the interactive route to driver 458 button, and the interactive process 460 the transaction button.
- the transaction flow for the fourth open ticket 412 can define when messages and/or alerts are presented via the fourth open ticket 412 based on process(es) for a delivery 450 type of transaction.
- the transaction flow for the delivery 450 type of transaction can cause the fourth open ticket 412 to present a message indicating that the merchant needs to input the address 452 of the fourth customer. Additionally, the transaction flow for the delivery 450 type of transaction can cause the fourth open ticket 412 to indicate that the merchant needs to route the delivery to a driver. Moreover, the transaction flow for the delivery 450 type of transaction can cause the POS device 402 to send a digital receipt (instead of printing a physical receipt) for the transaction to the fourth customer.
- FIGS. 5A-5B are example illustrations of user interfaces for creating open tickets using predefined templates.
- the merchant location interface 502 (which can represent the payment service interface 136 ) includes a representation of a merchant's physical location.
- the merchant's physical location can include a restaurant area 504 , a bar area 506 , and a waitlist area 508 .
- the merchant location interface 502 includes a position for delivery 510 type transactions.
- the merchant can use the merchant location interface 502 to generate open tickets for customers.
- the merchant can use one of the interactive create tickets 512 ( 1 )-( 6 ) buttons within the restaurant area 504 of the merchant location interface 502 to create open tickets for restaurant area types of transactions (e.g., the first open ticket 406 ).
- the merchant is able to create tickets 512 ( 1 )-( 6 ) for the restaurant area 504 are around table one 514 ( 1 ).
- the merchant can further use one of the interactive view tickets 516 ( 1 )-( 6 ) to view open tickets that are already open for transactions with customers.
- FIG. 5A the merchant location interface 502 to generate open tickets for customers.
- the merchant can use one of the interactive create tickets 512 ( 1 )-( 6 ) buttons within the restaurant area 504 of the merchant location interface 502 to create open tickets for restaurant area types of transactions (e.g., the first open ticket 406 ).
- the merchant is able to create tickets 512 ( 1 )-( 6 ) for
- the merchant is able to view tickets 516 ( 1 )-( 6 ) for the restaurant area 504 around table two 514 ( 2 ).
- table one 514 ( 1 ) within the restaurant area 504 may be open, however, table two 514 ( 2 ) within the restaurant area may be filled with customers.
- the merchant can use the interactive create tickets 518 ( 1 )-( 2 ) buttons within the bar area 506 of the merchant location interface 502 to create open tickets for bar area types of transactions (e.g., the second open ticket 408 ). Additionally, the merchant can use the interactive view tickets 520 ( 1 )-( 3 ) buttons to view open tickets that are already open for transaction with customers within the bar area 506 . In some examples, each of the interactive create tickets 518 ( 1 )-( 2 ) buttons and each of the interactive view tickets 520 ( 1 )-( 3 ) buttons can be associated with a respective seat within the bar area 506 of the merchant's physical establishment.
- each of the interactive create tickets 518 ( 1 )-( 2 ) buttons and each of the interactive view tickets 520 ( 1 )-( 3 ) buttons can be associated with either a seat and/or a defined location within the bar area 506 of the merchant's physical establishment.
- the merchant can use the interactive create tickets 522 button within the waiting area 508 of the merchant location interface 502 to create open tickets for waiting area types of transactions (e.g., the third open ticket 410 ). Additionally, the merchant can use the interactive view tickets 524 ( 1 )-( 3 ) buttons to view open tickets that are already open for transaction with customers within the waiting area 508 . In some examples, each of the view tickets 524 ( 1 )-( 3 ) may correspond to a respective customer within the waiting area 508 . In some examples, the merchant can use the interactive create tickets 522 button to create any number open tickets for the waiting area 508 .
- the merchant can use the interactive create tickets button 526 within the delivery area 510 of the merchant location interface 502 to create open tickets for delivery types of transaction (e.g., the fourth open ticket 412 ). Additionally, the merchant can use the interactive view tickets 528 button to view open tickets that were already created for delivery types of transaction.
- the each of the interactive buttons 512 ( 1 )-( 6 ), 516 ( 1 )-( 6 ), 518 ( 1 )-( 2 ), and 520 ( 1 )-( 3 ) can correspond to a specific location within the merchant's physical establishment.
- the merchant location interface 502 may not allow the merchant to create open tickets for a specific location when there is already an open ticket at the specific location (e.g., when the interactive button includes a “view ticket” button).
- the merchant location interface 502 can update the interactive button for the specific location to indicate that the specific location is now open (e.g., update with an interactive “create ticket” button). The merchant can then use the interactive “create ticket” button at the specific location to create a new open ticket at the specific location.
- the merchant location interface 502 includes lists for the different stations/zones of the merchant's physical establishment. For instance, the merchant location interface 502 includes a list for the restaurant area 504 that includes the interactive create tickets 512 ( 1 )-( 6 ) buttons for table one 514 ( 1 ) and the interactive view tickets 516 ( 1 )-( 6 ) buttons for table two 514 ( 2 ). The merchant location interface 502 further includes a list for the bar area 506 that includes the interactive create tickets 518 ( 1 )-( 2 ) buttons and the interactive view tickets 520 ( 1 )-( 3 ) buttons.
- the merchant location interface 502 includes a list for the waiting area 508 that includes the interactive create tickets 522 button and the interactive view tickets 524 ( 1 )-( 3 ) buttons. Finally, the merchant location interface 502 includes a list for the delivery area 510 that includes the interactive create tickets 526 button and the interactive view tickets 528 button.
- the merchant location interface 502 can either present the merchant with a physical layout of the merchant's physical establishment or a list of different stations/zones within the merchant's physical establishment. Using either the physical layout or the list of different stations/zones, the merchant can use the merchant location interface 502 to generate open tickets for transactions that are based on the types of transactions that the merchant is conducting with customers.
- FIG. 6 is an example illustration of merging two open tickets in order to create a merged open ticket.
- the POS device 602 is presenting an open ticket interface 604 that includes a first open ticket 606 and a second open ticket 608 .
- the POS device 602 , the open ticket interface 604 , and each of the open tickets 606 - 608 can correspond to the POS device 402 , the open ticket interface 404 , and the second open ticket 408 , respectively.
- the bar area 610 type of transaction can correspond to the bar area 426 type of transaction, the seat number 428 , the list of items 430 , the interactive add items 432 button, the interactive merge 434 tickets button, and the interactive process 436 the transaction button, respectively.
- a merchant can utilize the interactive merge 618 tickets button on one of the open tickets 606 - 608 to merge the open tickets 606 - 608 .
- merging the open tickets 606 - 608 together can include combining information included within the open ticket data structure of the first open ticket 606 with information included within the open ticket data structure of the second open ticket 608 in order to generate a merged open ticket data structure.
- the list of items 612 ( 2 ) of the merged open ticket 622 includes seat number “(X)” from the first open ticket 606 and set number “(Y)” from the second open ticket 608 .
- the list of items 614 ( 3 ) of the merged open ticket 622 includes items “A” and “B” from the first open ticket 606 and item “C” from the second open ticket 608 .
- merging the open tickets 606 - 608 can further include creating a new associated versioning data structure for the merged open ticket 622 .
- the POS device 602 can create the new associated versioning data structure for the merged open ticket 622 using the associated versioning data structure from the first open ticket 606 and the associated versioning data structure from the second open ticket 608 .
- POS devices that synchronize data with the POS device 602 can use the new associated versioning data structure to determine that the open tickets 606 - 608 were merged in order to create the merged open ticket 622 .
- FIGS. 7A-7B are a flow diagram illustrating an example process 700 for integrating predefined templates with open ticket functionality.
- the process 700 and other processes described herein are illustrated as collections of blocks in logical flow diagrams, which represent a sequence of operations, some or all of which can be implemented in hardware, software or a combination thereof.
- the blocks may represent computer-executable instructions stored on one or more computer-readable media that, when executed by one or more processors, program the processors to perform the recited operations.
- computer-executable instructions include routines, programs, objects, components, data structures and the like that perform particular functions or implement particular data types. The order in which the blocks are described should not be construed as a limitation.
- any number of the described blocks can be combined in any order and/or in parallel to implement the process, or alternative processes, and not all of the blocks need be executed.
- the processes are described with reference to the environments, architectures and systems described in the examples herein, although the processes may be implemented in a wide variety of other environments, architectures and systems.
- the process 700 , and other processes described herein, may be performed by a remote payment service (e.g., computing device(s) 112 ), a POS device (e.g., merchant device(s) 108 ), by another entity, or by a combination thereof.
- the process 700 identifies a type of transaction between a merchant and a customer.
- a POS device can identify the type of transaction between the merchant and the customer.
- the POS device receives input, via an input device, that identifies the type of transaction.
- the POS device receives input, via the input device, identifying a group associated with the customer. In such examples, the POS device can use the group to determine the type of transaction.
- the process 700 selects a ticket type for the transaction from a plurality of predefined ticket types.
- the POS device can associate predetermined ticket templates (e.g., ticket types) with various types of transactions.
- the POS device can then use the associations to determine which predetermine ticket template (e.g., ticket type) from the predetermined ticket templates is associated with the identified type of transaction. Based on the determination, the POS device can select the predetermined ticket template.
- the process 700 generates an open ticket based at least in part on the ticket type.
- the POS device can generate an open ticket for the transaction using the predefined ticket template.
- the open ticket can include a data structure that stores cart information indicating items that are ordered by the customer from the merchant during the transaction. Additionally, in some examples, the open ticket can further include an associated versioning data structure indicating a version of the open ticket.
- the process 700 selects a transaction flow from a plurality of transaction flows and at block 710 , the process 700 associates the transaction flow with the open ticket.
- the POS device can associate transaction flows with the predetermined ticket templates. The POS device can then use the associations to determine which transaction flow from the transaction flows is associated with the selected predetermined ticket template. Based on the determination, the POS device can select the transaction flow for the open ticket. Additionally, the POS device can associate the transaction flow with the open ticket.
- the process 700 generates a visual representation of data associated with the open ticket and at block 714 , the process 700 presents the visual representation of the data.
- the POS device can generate the visual representation of the open ticket using data from the data structure of the open ticket.
- a layout of the data within the visual representation can be based on the predetermined ticket template and/or the transaction flow.
- the POS device can then present the visual representation of the data via a display device.
- the process 700 receives input corresponding to a customer order for the transaction and at block 718 , the process 700 adds information associated with the customer order to the open ticket.
- the POS device can receive, via the input device, data indicating one or more items item ordered by the customer from the merchant during a course of the transaction. Based on the input, the POS device can update the open ticket for the transaction. For instance, the POS device can add information associated with the one or more items to the data structure of the open ticket. In some examples, the POS device can further update the associated versioning data structure of the open ticket in order to indicate that the open ticket was updated.
- FIG. 8 is a flow diagram of illustrating an example process 800 for updating an open ticket based on a type of transaction between a merchant and a customer changing.
- the process 800 generates an open ticket for a transaction based at least in part on a first type of transaction, the first type of transaction being associated with a first ticket type and a first transaction flow.
- a POS device can generate the open ticket using the first predetermined template (e.g., the first ticket type) and the first transaction flow for the first type of transaction.
- the process 800 receives input identifying a second type of transaction for the transaction.
- the POS device can receive input, via an input device, that identifies the second type of transaction.
- the first POS device can receive input, via the input device, identifying a new group associated with the customer. In such examples, the POS device can identify the second type of transaction based on the new group.
- the process 800 determines a second ticket type for the transaction based at least in part on the second type of transaction and at block 808 , the process 800 updates, based at least in part on the second ticket type, the open ticket in order to generate an updated open ticket.
- the POS device can use an association between the second type of transaction and a second predetermined ticket template (e.g., the second ticket type) to determine and/or select the second predetermined ticket template.
- the POS device can then update the open ticket using the second predetermined ticket template.
- the POS device can update elements included within the open ticket and/or a layout of the elements included within the open ticket based on the second predetermined ticket template.
- the POS device can further update an associated versioning data structure associated with the open ticket.
- the process 800 selects, based at least in part on the second ticket type, a second transaction flow and at block 812 , the process 800 associates the second transaction flow with the updated open ticket.
- the POS device can select the second transaction flow based on an association between the second transaction flow and the second predetermined ticket template. The POS device can then associate the second transaction flow with the updated open ticket.
- the process presents a visual representation of data associated with the updated open ticket.
- the POS device can generate the visual representation of the data using the data structure of the open ticket.
- a layout of the visual representation of the data is based on the second predefined ticket template and the second transaction flow.
- the POS device can then present the visual representation of the data via a display device.
- the POS device can further synchronize the updated open ticket with one or more other POS devices associated with the merchant. For instance, the POS device can send ticket data associated with the updated open ticket to the one or more other POS devices.
- the ticket data can include the updated associated versioning data structure.
- the updated associated versioning data structure of the updated open ticket can cause the one or more other POS devices to update the open ticket stored locally on the one or more other POS devices to the updated open ticket.
- FIG. 9 is a flow diagram of an example process 900 for merging two open tickets in order to generate a merged open ticket.
- the process 900 generates a first open ticket for a first transaction between a merchant and a first customer.
- a POS device can receive input associated with the first transaction.
- the POS device can then generate a first open ticket data structure for the first transaction based on the input.
- the first open ticket data structure includes at least data indicating items ordered by the first customer from the merchant.
- the process 900 generates a second open ticket for a second transaction between the merchant and a second customer.
- the POS device can receive input associated with the second transaction.
- the POS device can then generate a second open ticket data structure for the second transaction based on the input.
- the second open ticket data structure includes at least data indicating items ordered by the second customer from the merchant.
- the process 900 presents a visual representation of data associated with the merged open ticket.
- the POS device can generate the visual representation of the data using the merged open ticket data structure.
- a layout of the visual representation of the data is based on a type of transaction associated with the merged open ticket data structure.
- the POS device can then present the visual representation of the data via a display device.
- FIG. 10 is a flow diagram illustrating an example process 1000 of a third-party service integrating predefined templates with open ticket functionality.
- the process 1000 receives data associated with a transaction between a merchant and a customer.
- a third-party service e.g., the computing device(s) 112
- the data can indicate an identity of the merchant, a location of the merchant, an identity of the customer associated with the transaction, the personal information associated with the customer, a location of the customer within the physical establishment of the merchant, items order by the customer during a course of the transaction (e.g., cart information), timestamps for each of the items ordered by the customer during the course of the transaction, a cost associated with each of the items, or other information associated with the transaction.
- an identity of the merchant a location of the merchant, an identity of the customer associated with the transaction, the personal information associated with the customer, a location of the customer within the physical establishment of the merchant, items order by the customer during a course of the transaction (e.g., cart information), timestamps for each of the items ordered by the customer during the course of the transaction, a cost associated with each of the items, or other information associated with the transaction.
- the process 1000 identifies a type of transaction between the merchant and the customer.
- third-party service can identify the type of transaction between the merchant and the customer using the received data.
- the data identifies the type of transaction.
- the data identifies a group associated with the customer. In such examples, the third-party service can use the group to determine the type of transaction.
- the process 1000 selects, based at least in part on the type of transaction, a ticket type for the transaction from a plurality of predefined ticket types.
- the third-party service can associate predetermined ticket templates (e.g., ticket types) with various types of transactions.
- the third-party service can then use the associations to determine which predetermine ticket template (e.g., ticket type) from the predetermined ticket templates is associated with the identified type of transaction. Based on the determination, the third-party service can select the predetermined ticket template.
- the process 1000 generates, based at least in part on the ticket type, an open ticket for the transaction.
- the third-party service can generate an open ticket for the transaction using the predefined ticket template.
- the open ticket can include a data structure that stores cart information indicating items that are ordered by the customer from the merchant during the transaction. Additionally, in some examples, the open ticket can further include an associated versioning data structure indicating a version of the open ticket.
- the process 1000 selects, based at least in part on the ticket type, a transaction flow from a plurality of transaction flows and at block 1012 , the process 1000 associates the transaction flow with the open ticket.
- the third-party service can associate transaction flows with the predetermined ticket templates. The third-party service can then use the associations to determine which transaction flow from the transaction flows is associated with the selected predetermined ticket template. Based on the determination, the third-party service can select the transaction flow for the open ticket. Additionally, the third-party service can associate the transaction with the open ticket.
- the process 1000 sends data associated with the open ticket to at least one merchant device.
- the third-party service can send data associated with the open ticket to one or more POS device associated with the merchant.
- the one or more POS device can then use the received data to present a visual representation of data for the open ticket.
- a layout of the visual representation of the data is based on the predetermined ticket template and/or the transaction flow.
Landscapes
- Business, Economics & Management (AREA)
- Physics & Mathematics (AREA)
- Engineering & Computer Science (AREA)
- Accounting & Taxation (AREA)
- Theoretical Computer Science (AREA)
- Acoustics & Sound (AREA)
- General Physics & Mathematics (AREA)
- Strategic Management (AREA)
- General Business, Economics & Management (AREA)
- Finance (AREA)
- Economics (AREA)
- Marketing (AREA)
- Databases & Information Systems (AREA)
- Tourism & Hospitality (AREA)
- Development Economics (AREA)
- Computer Networks & Wireless Communication (AREA)
- Data Mining & Analysis (AREA)
- General Engineering & Computer Science (AREA)
- Health & Medical Sciences (AREA)
- General Health & Medical Sciences (AREA)
- Human Resources & Organizations (AREA)
- Primary Health Care (AREA)
- Cash Registers Or Receiving Machines (AREA)
Abstract
Description
- This application is a continuation of, and claims priority to, U.S. patent application Ser. No. 16/807,036, filed on Mar. 2, 2020, that claims priority to U.S. patent application Ser. No. 15/195,557, filed on Jun. 28, 2016, now known as U.S. Pat. No. 10,580,062, issued on Mar. 3, 2020, and entitled “Integrating Predefined Templates with Open Ticket Functionality”, which is fully incorporated by reference herein.
- In today's commerce, merchants utilize point-of-sale (POS) devices when conducting transactions with customers. For instance, a merchant can input data into a POS device, such as items ordered by a customer during a transaction. The POS device can then use the data to generate a ticket for the transaction. After generating the ticket, the POS device can present the ticket to the merchant. The merchant can then use the ticket when conducting the transaction with the customer. Additionally, at the end of the transaction, the merchant can use the ticket to process the transaction for the customer.
- The detailed description is set forth with reference to the accompanying figures, in which the left-most digit of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in the same or different figures indicates similar or identical items or features.
-
FIG. 1 illustrates an example system for handling open ticket transactions among customers and merchants. -
FIG. 2 is an example illustration of merchant devices integrating predefined templates with open ticket functionality. In the example ofFIG. 2 , the merchant devices then synchronize data associated with generated open tickets. -
FIG. 3 is an example illustration of a third-party service integrating predefined templates with open ticket functionality for merchant devices. -
FIG. 4 is an example illustration of open tickets that were generated using predefined templates and/or transaction flows. -
FIGS. 5A-5B are example illustrations of user interfaces for creating open tickets using predefined templates. -
FIG. 6 is an example illustration of merging two open tickets in order to create a merged open ticket. -
FIGS. 7A-7B are a flow diagram illustrating an example process for integrating predefined templates with open ticket functionality. -
FIG. 8 is a flow diagram of illustrating an example process for updating an open ticket based on a type of transaction between a merchant and a customer changing. -
FIG. 9 is a flow diagram of an example process for merging two open tickets in order to generate a merged open ticket. -
FIG. 10 is a flow diagram illustrating an example process of a third-party service integrating predefined templates with open ticket functionality. - This disclosure describes systems and processes for integrating predefined templates with open ticket functionality. In some examples, a merchant can utilize a point-of-sale (POS) to conduct transactions with customers. For instance, the merchant can input data associated with each of the transactions into the POS device. The POS device can then generate open tickets for the transactions using the inputted data. In some examples, an open ticket is a data structure that stores information associated with interactions between the merchant and customers during the course of a transaction. In some examples, the open ticket data structure can include an associated versioning data structure that the POS device uses when synchronizing the open ticket data structure with other merchant devices (e.g., other POS devices). For instance, the associated versioning data structure can include a vector that indicates each time the open ticket data structure is updated by one of the POS devices.
- In some examples, the POS device can generate the open tickets using predefined ticket templates (e.g., predefined ticket types). Predefined ticket templates can define which elements are included within open tickets. For instance, a predefined ticket template can define which graphics, text, interactive elements, or the like are included within an open ticket. The predefined ticket templates can further define a layout for the elements within the open tickets. For instance, the predefined ticket template above can define a layout for the graphics, text, interactive elements, or the like. In some examples, the POS device selects which predefined ticket template to use for an open ticket of a transaction based on a type of transaction that the merchant is conducting the customer.
- For instance, the POS device can associate predefined ticket templates with various types of transactions. Types of transactions can include transactions that occur at the physical establishment of the merchant and/or transactions that occur outside of the physical establishment of the merchant. At the physical establishment of the merchant, types of transactions can be based zones/stations within the physical establishment of the merchant. For instance, in some examples, the types of transactions can include restaurant area transactions, bar area transactions, waiting area transactions, patio area transactions, or the like. Outside of the physical establishment of the merchant, types of merchants can include delivery type transactions.
- To generate an open ticket using the predefined ticket templates, the POS device identifies the type of transaction that is being conducted between the merchant and the customer. For instance, the POS device can receive input associated with a transaction between the merchant and the customer. In some examples, the input can indicate the type of transaction that is being conducted between the merchant and the customer (e.g., a restaurant area transaction). Additionally or alternatively, in some examples, the input can indicate a group (e.g., the zone/station) associated with the customer. In such examples, the POS device can determine the type of transaction based on the group. The POS device can then select the predefined ticket template for the transaction based on the association between the predefined ticket template and the identified type of transaction. Using the predefined ticket template, the POS device can then generate an open ticket for the transaction between the merchant and the customer.
- In some examples, the POS device can further associated transaction flows with the open ticket. Transaction flows can define one or more process(es) that the merchant is to perform during the transaction with the customer. For instance, a transaction flow can include various steps associated with the transaction, such as when to input data associated with the customer, when to input data associated with customer orders, when to process the transaction, whether to provide the customer with a physical and/or digital receipt, or the like. In some examples, the POS device selects the transaction flow for the open ticket based on the predefined ticket template that the POS device uses to generate the open ticket.
- After generating the open ticket, the POS device can present the open ticket to the merchant. For instance, the POS device can generate a visual representation of data associated with the open ticket, and present the visual representation of the data via a display device. The merchant can then utilize the visual representation during the course of the transaction with the customer. For instance, in some examples, the merchant can utilize the visual representation to add additional orders made by the customer to the open ticket. In some examples, the merchant can utilize the visual representation to merge the open ticket with an additional open ticket. In some examples, the merchant can utilize the visual representation to modify the type of transaction associated with the transaction. When modifying the type of transaction, the POS device can update the open ticket using a new predefined ticket template and/or transaction flow. Additionally, in some examples, the merchant can utilize the visual representation to process the transaction with the customer.
- It should be noted that, in some examples, a third-party service (e.g., payment service) can generate the open tickets for the merchant using a similar process as the POS device above. For instance, the third-party service can receive, from the POS device, data associated with a transaction between the merchant and a customer. The third-party service can then use the data to identify a type of transaction for the transaction between the merchant and the customer. Based on the identified type of transaction, the third-party service can generate an open ticket for the transaction using a predefined ticket template. The third-party service can further associate a transaction flow with the open ticket. After generating the open ticket, the third-party service can send data associated with the open ticket to the POS device and/or another POS device associated with the merchant.
- By generating open tickets using the processes described above, computer-related technology on POS devices (and/or third-party services) that generate open tickets is improved. For instance, the POS devices generate open tickets that are personalized to the types of data that the merchant inputs into the POS devices for the transactions. For instance, in some examples, an open ticket for a delivery type transaction may include interactive elements utilized by the merchant to input data associated with an address of the customer, while an open ticket associated with a restaurant type transaction may not include the same functionality. Additionally, processes performed by the POS device are personalized towards the type of transaction being performed by the merchant. For instance, a transaction flow associated with an open ticket may cause the POS device to generate and provide messages and/or alerts to the merchant that are specific to the type of transaction that is being conducted by the merchant.
-
FIG. 1 illustrates anexample system 100 for handling open ticket transactions among customers and merchants. More particularly,FIG. 1 provides a framework for integrating predefined ticket templates with POS functionality on merchant devices. For instance, in some examples, thesystem 100 can generate open tickets for a merchant using predefined ticket templates. Additionally, in some examples, thesystem 100 can associate transaction flows with generated open tickets. - As shown in
FIG. 1 , thesystem 100 may include one or more user(s) 102 (e.g. customers), one or more user device(s) 104 associated with the user(s) 102, one ormore merchants 106, one ormore merchant devices 108 associated with the one ormore merchants 106, one or more network(s) 110, and one or more computing device(s) 112. In various implementations, the user(s) 102 may operate the user device(s) 104, which may include one or more processor(s) 114, computer-readable media 116, adisplay 118 and anetwork interface 120. The computer-readable media 116 may store apayment service interface 122 and aPOS module 124. Similarly, the merchant(s) 106 may operate the merchant device(s) 108, which may include one or more processor(s) 126, computer-readable media 128, acard reader 130, adisplay 132 and anetwork interface 134. The computer-readable media 126 may store apayment service interface 136 and aPOS module 138. The computing device(s) 112 may also include one or more processor(s) 140, computer-readable media 142 and anetwork interface 144. The computerreadable media 142 may store a user interaction module 146, amerchant interaction module 148, apayment module 150, anopen ticket module 152, and adatabase 154. - In some implementations, one of the users 102 may operate a user device 104 to perform various functions associated with the user device 104. For example, a user of the user(s) 102 may utilize the user device 104, and particularly the
payment service interface 122 thereof, to interact with the computing device(s) 112 via thenetwork interface 120 to establish a user account with the payment service of the computing device(s) 112. In addition, a user of the user(s) 102 may utilizePOS module 124 of the user device 104 to interface with thePOS module 138 of the merchant device(s) 108, e.g. as part of a transaction using the payment service of the computing device(s) 112. For example, the user device 104 may communicate via thenetwork interface 120 with the merchant device(s) 108 and thenetwork interface 134. As an example of such a payment operation, thePOS module 138 of themerchant device 108 may communicate with thePOS module 124 of the user device 104 to obtain information for processing a payment from the user 102 to themerchant 106 using the payment service of the computing device(s) 112. - In some implementations, the user device 104 may be any type of device that is capable of interacting with the merchant device(s) 108 and/or the computing device(s) 112. For instance, the user device 104 may include a personal computer, a laptop computer, a cellular telephone, a PDA, a tablet device, or any other device. The user device 104 shown in
FIG. 1 is only one example of a user device 104 and is not intended to suggest any limitation as to the scope of use or functionality of any user device 104 utilized to perform the processes and/or procedures described herein. For example, the user device 104 may include various other applications or modules, such as a module for a user dashboard to enable the user to control information in a user's profile, set user preferences, and so forth. - The processor(s) 114 of the user device 104 may execute one or more modules and/or processes to cause the user device 104 to perform a variety of functions, as set forth above and explained in further detail in the following disclosure. In some implementations, the processor(s) 114 may include a central processing unit (CPU), a graphics processing unit (GPU), both CPU and GPU, or other processing units or components known in the art. Additionally, each of the processor(s) 114 may possess its own local memory, which also may store program modules, program data, and/or one or more operating systems.
- Depending on the exact configuration and type of the user device 104, the computer-
readable media 116 may include volatile memory (such as RAM), non-volatile memory (such as ROM, flash memory, miniature hard drive, memory card, or the like), or some combination thereof. - In various implementations, the user device 104 may also have input device(s) such as a keyboard, a mouse, a pen, a voice input device, a touch input device, etc. The user device 104 may also include the
display 118 and other output device(s), such as speakers, a printer, etc. The user 102 may utilize the foregoing features to interact with the user device 104, merchant device(s) 108 or the computing device(s) 112 via the network(s) 110. More particularly, thedisplay 118 of the user device 104 may include any type ofdisplay 118 known in the art that is configured to present (e.g., display) information to the users 102. - In various implementations, the one or
more merchants 106 may be any individual, entity, or machine that offers products, services or the like according to the examples herein. Moreover, each of themerchants 106 may be associated with one ormore merchant devices 108, which may be the same as, similar to, or different from the user devices 104. Themerchant devices 108 may include any number of components such as the one or more processor(s) 126, the computer-readable media 128, thecard reader 130, thedisplay 132 and/ornetwork interface 134. Themerchants 106 may utilize themerchant devices 108 to interact with the user device(s) 104 and/or computing device(s) 112 in any manner. For instance, themerchant devices 108 may be used to access an interface associated with the computing device(s) 112 (e.g. the payment service interface 136). Continuing the above example, amerchant device 108 may utilize information obtained from interacting with thePOS module 124 of the user device 104 to execute the payment from the user 102 to themerchant 106 through the payment service of the computing device(s) 112. Further, thePOS module 138 may control the operation of thecard reader 130 to read payment information from credit cards, debit cards, gift cards and the like. Moreover, thePOS module 138 may operate to interact with the card payment network computing devices(s) 162 and/or bank(s) computing device(s) 164 to execute payments from the user 102 to themerchant 106. - While the user devices 104 and
merchant devices 108 are shown as including different modules, this is merely for ease of illustration and not intended as limiting. In various implementations, the user devices 104 andmerchant devices 108 may be identical, similar or distinct. Moreover, the modules shown and described for the user devices 104 andmerchant devices 108 may be implemented as more modules or as fewer modules and functions described for the modules may be redistributed depending on the details of the implementation. Further, in some implementations, the user devices 104 and/ormerchant devices 108 may vary from device to device. In general, the user devices 104 and themerchant devices 108 can each be any appropriate device operable to send and receive requests, messages, or other types of information over the one ormore networks 110 or directly to each other. Additionally, in some implementation, there may be thousands, hundreds of thousands, or more, of the user devices 104 and themerchant devices 108. - In some implementations, the network(s) 110 may be any type of network known in the art, such as a local area network or a wide area network, such as the Internet, and may include a wireless network, such as a cellular network, a local wireless network, such as Wi-Fi and/or close-range wireless communications, such as Bluetooth® and Bluetooth® low energy, near field communications (NFC), a wired network, or any other such network, or any combination thereof. Accordingly, the one or
more networks 110 may include both wired and/or wireless communication technologies, including Bluetooth®, Bluetooth® low energy, Wi-Fi and cellular communication technologies, as well as wired or fiber optic technologies. Components used for such communications can depend at least in part upon the type of network, the environment selected, or both. Protocols for communicating over such networks are well known and will not be discussed herein in detail. Consequently, the user devices 104, themerchant devices 108, and the computing device(s) 112 may communicatively couple to the network(s) 110 in any manner, such as by a wired or wireless connection. The network(s) 110 may also facilitate communication between the user devices 104, themerchant devices 108, and the computing device(s) 112. In turn, the network interfaces 120, 134 and 144 of the user devices 104, themerchant devices 108, and the computing device(s) 112 may be any network interface hardware components that may allow user devices 104, themerchant devices 108, and the computing device(s) 112 communicate over the network(s) 110. For example, in a particular implementation, the network interfaces 120 and 134 of the user devices 104 andmerchant devices 108 may include near field communication capabilities for performing the communications there between involved in POS operations. - In addition, and as mentioned previously, the computing device(s) 112 may include the one or more processor(s) 140, the computer-
readable media 142 andnetwork interface 144. The computing device(s) 112 may also include additional components not listed above that may perform any function associated with the computing device(s) 112. In various implementations, the computing device(s) 112 may be any type of computing device, such as a network-accessible server, and may be one of multiple servers included in a server cluster or server farm. In other implementations, the processor(s) 140 and the computer-readable media 142 of the computing device(s) 112 may be the same as, similar to, or different from the processor(s) 114 and the computer-readable media 116, respectively, of the user device(s) 104. As discussed above, the computer-readable media 142 may store the user interaction module 146, themerchant interaction module 148, thepayment module 150, theopen ticket module 152, and thedatabase 154. Thedatabase 154 may store various information including user account information 156,merchant information 158, andopen tickets 160. - The user interaction module 146 and
merchant interaction module 148 operate to interface with the user devices 104 andmerchant devices 108, respectively. For example, themodules 146 and 148 may operate in accordance with instructions from thepayment module 150 to request or provide information on behalf of thepayment module 150. Thepayment module 150 may handle the processing of payments. For example, thepayment module 150 may utilize the user interaction module 146 and themerchant interaction module 148 to handle communication with the user 102 andmerchant 106, respectively. In addition, thepayment module 150 may utilize information from thedatabase 154, such as the user account information 156 andmerchant information 158 to provide handling of payments between merchants and users. In some implementations, user account information 156 may include information regarding electronic payment accounts of the customers (e.g. users 102). - As mentioned above, the
payment module 150 may handle payments between merchants and users. When paying for a transaction, a user 102 can provide the amount of payment that is due to amerchant 106 using cash, check, a payment card, NFC, or by electronic payment through a payment service of the computing device(s) 112. Themerchant 106 can interact with themerchant device 108 to process the transaction. In some examples, the service of the computing devise 112 may handle some payments while other payments may at least at times be handled by point of sale (POS) transactions. In such cases, the point of sale may be the place where the user 102 with user device 104 interacts with themerchant 106 withmerchant device 108 and executes a transaction (e.g. purchases items from a street vendor merchant or a restaurant merchant). During point-of-sale (POS) transactions, themerchant device 108 can determine and send data describing the transactions, including, for example, services provided, item(s) being purchased, the amount of the services or item(s), buyer information, and so forth. - In some implementations, the payment service enables card-less payments, i.e., electronic payments, for transactions between the users 102 and the
merchants 106 based on interaction of the user 102 with the user device 104 and interaction of themerchant 106 with themerchant device 108. Accordingly, in some examples, a card-less payment transaction may include a transaction conducted between a user 102 and amerchant 106 at a POS location during which an electronic payment account of the user 102 is charged without the user 102 having to physically present a payment card to themerchant 106 at the POS location. Consequently, themerchant 106 need not receive any details about the financial account of the user 102 for the transaction to be processed. As one example, the electronic payment may be charged to a credit card issuer or credit card number that the user 102 provided when signing up with the service of the computing device(s) 112 for an electronic payment account. As another example, the user 102 may have a quantity of money pre-paid in an account maintained for use in making the electronic payments. Other variations will also be apparent to those of skill in the art having the benefit of the disclosure herein. - Before conducting an electronic payment transaction, the user 102 typically creates a user account with the service of the computing device(s) 112. The user 102 can create the user account, for example, by interacting with an application of the user device 104 that is configured to perform electronic payment transactions and that may execute on the user device 104 (e.g. the payment service interface 122). When creating an electronic payment account with the service of the computing device(s) 112, the user 102 may provide an image including the face of the user, data describing a financial account of the user 102 (e.g., a credit card number, expiration date), and a billing address. This user information can be securely stored by the computing device(s) 112, for example, in the user account information 156 in the
database 154. Further, the user account information 156 may be created for each user 102, which may include information about the user and transactions conducted by the user. - To accept electronic payments for POS transactions, the
merchant 106 may create a merchant account with the service of the computing device(s) 112 by providing information describing the merchant including, for example, a merchant name, contact information, e.g., telephone numbers, the merchant's geographic location address, and one or more financial accounts to which funds collected from users will be deposited. Thismerchant information 158 can be securely stored by the service, for example, in thedatabase 154 along with the user account information 156. Further, a merchant profile may be created for each merchant, which may include information about the merchant and transactions conducted by the merchant. - The service of the computing device(s) 112 may be configured to enable electronic payments for transactions. The computing device(s) 112 can include one or more servers that are configured to perform secure electronic financial transactions, e.g., electronic payments for transactions between a user and a merchant, for example, through data communicated between the user device 104 and the
merchant device 108. Generally, when a user and a merchant enter into an electronic payment transaction, the transaction is processed by electronically transferring funds from a financial account associated with the user account to a financial account associated with the merchant account. Alternatively, the user may have a balance of funds maintained by the payment service as part of the user account which may be used in transactions. - The
payment module 150 may be configured to send and receive data to and from the user device 104 and themerchant device 108. For example, thepayment module 150 can be configured to send information describing merchants to an application on the user device 104 using, for example, the information stored in thedatabase 154. For example, thepayment module 150 can communicatedata describing merchants 106 that are within a threshold geographic distance from a geographic location of the user device 104. The data describing themerchants 106 can include, for example, a merchant name, geographic location, contact information, and an electronic catalogue, e.g., a menu that describes items that are available from the merchant. - In some embodiments, the
payment module 150 is configured to determine whether a geographic location of the user device 104 is within a threshold geographic distance from a geographic location of themerchant device 108. Thepayment module 150 can determine a geographic location of the user device 104 using, for example, geolocation data provided by the user device 104. Similarly, thepayment module 150 can determine a geographic location of themerchant device 108 using, for example, geolocation data provided by themerchant device 108 or using a geographic address, e.g., street address, provided by the merchant. Depending on the implementation, the threshold geographic distance can be specified by thepayment module 150, by the user, or by the merchant. - Determining whether the user device 104 is within a threshold geographic distance of the
merchant device 108 can be accomplished in different ways including, for example, determining whether the user device 104 is within a threshold geographic radius of themerchant device 108, determining whether the user device 104 is within a particular geofence, or determining whether the user device 104 can communicate with themerchant device 108 using a specified wireless technology, e.g., Bluetooth® or Bluetooth® low energy (BLE). In some embodiments, thepayment module 150 restricts electronic payment transactions between the user 102 and themerchant 106 to situations where the geographic location of the user device 104 is within a threshold geographic distance from a geographic location of themerchant device 108. - The computing device(s) 112 can also be configured to communicate with one or more card payment network computing devices(s) 162 of a card payment network (e.g., MasterCard®, VISA®) over the one or
more networks 110 to conduct financial transactions electronically. The computing device(s) 112 can also communicate with one or morebank computing devices 164 of one or more banks over the one ormore networks 110. For example, the computing device(s) 112 may communicate with an acquiring bank, and/or an issuing bank, and/or a bank maintaining user accounts for electronic payments. - An acquiring bank may be a registered member of a card association (e.g., Visa®, MasterCard®), and may be part of a card payment network. An issuing bank may issue payment cards to users, and may pay acquiring banks for purchases made by cardholders to which the issuing bank has issued a payment card. Accordingly, in some examples, the computing device(s) of an acquiring bank may be included in the card payment network and may communicate with the computing devices of a card-issuing bank to obtain payment. Further, in some examples, the user may use a debit card or gift card instead of a credit card, in which case, the bank computing device(s) of a bank or other institution corresponding to the debit card or gift card may receive communications regarding a transaction in which the user is participating. Additionally, there may be computing devices of other financial institutions involved in some types of transactions or in alternative system architectures, and thus, the foregoing are merely several examples for discussion purposes. In addition, the merchant device(s) 108 may perform interactions similar to those described above with regard to the card payment network computing devices(s) 162 of a card payment network and the
bank computing devices 164 when processing transactions for payment instruments that do not involve the payment service of the computing device(s) 112. - The user 102 operating the user device 104 that is within a threshold geographic distance of the
merchant device 108 can interact with an application executed on the user device 104 to conduct an electronic payment transaction with themerchant 106. While interacting with the application, the user 102 can select themerchant 106, from a listing ofmerchants 106, with whom the user wants to enter into an electronic payment transaction. The user 102 can select themerchant 106, for example, by selecting a “check in” option associated with themerchant 106. The user device 104 can communicate data to the computing device(s) 112 indicating that the user 102 has checked in with themerchant 106. In response, the computing device(s) 112 can communicate data to notify themerchant device 108 that the user has checked in. An application executing on themerchant device 108 can notify themerchant 106 that the user has electronically checked in with themerchant 106 through a display of themerchant device 108. - Once checked in, the user 102 can receive, obtain or request items, services or appointments that are available to be acquired from the
merchant 106. When the user 102 is ready to enter into the card-less payment transaction, the user 102 can, for example, approach a point of sale for themerchant 106 and identify him or herself. For example, the user 102 can verbally notify themerchant 106 that the user 102 wants to enter into a card-less payment transaction and can provide themerchant 106 with the user's name. Themerchant 106 can then interact with the application executing on the merchant's device to select the user 102, from a listing of users that have checked in with themerchant 106, to initiate an electronic payment transaction for the item(s) being acquired by the user 102. For example, themerchant 106 can determine a total amount to charge the user for the item(s) being acquired. The user can verbally approve the total amount to be paid and, in response, themerchant 106 can submit a request for an electronic payment transaction for the total amount of the transaction to the computing device(s) 112. In response, the computing device(s) 112 can obtain, for example, from the user account information 156, data describing a financial account associated with the electronic purchase account of the user 102 to which the total amount will be charged. - The computing device(s) 112 can then communicate with the card payment network computing devices(s) 162 of a card payment network to complete an electronic payment transaction for the total amount to be charged to user's electronic payment account. Once the electronic payment transaction is complete, the computing device(s) 112 can communicate data describing the electronic payment for the transaction to the user device 104, e.g., as an electronic receipt, which can, for example, notify the user 102 of the total amount charged to the user for the electronic payment for the transaction with the particular merchant. Further, while a mobile user device 104 is described in this example for purposes of explanation, additional or alternative types of devices may be used in other examples.
- In some examples, a
merchant 106 can utilize a merchant device 108 (e.g., a POS device) to conduct transactions with user(s) 102. For instance, themerchant 106 can input data associated with the transactions into themerchant device 108. The input can include identities of the user(s) 102, personal information associated with the user(s) 102 (e.g., contact information, addresses, etc.), locations of the user(s) 102 within a physical establishment of the merchant 106 (e.g., restaurant area, bar area, waiting area, patio area, etc.), orders made by the user(s) 102 during a course of the transactions with themerchant 106, or the like. Based on the input, themerchant device 108 can generate open tickets for the transactions between themerchant 106 and the user(s) 102. - In some examples, an open ticket is a data structure that stores information associated with interactions between the
merchant 106 and user(s) 102 during a course of a transaction. The interactions can include an identity of themerchant 106, a location of themerchant 106, identities of the user(s) 102, the personal information associated with the user(s) 102, the locations of the user(s) 102 within the physical establishment of themerchant 106, the items order by the user(s) 102 during the transaction (e.g., cart information), timestamps for each of the items ordered by the user(s) 102 during the transaction, a cost associated with each of the items, a cost associated with the open ticket, or other information associated with the transaction. After creating the open tickets, and during the course of the transactions, themerchant device 108 can further update the data structures for the open tickets. For instance, themerchant device 108 can add (e.g., store) additional information associated with interactions between themerchant 106 and the user(s) 102 to the data structures. - In some examples, the open ticket data structures further include associated versioning data structures that the
merchant device 108 uses to when synchronizing open tickets with other merchant devices 108 (e.g., a second POS device). For instance, an associated versioning data structure for an open ticket data structure can include a vector that indicates each time the open ticket data structure is updated by the merchant device 108 (and/or any other of the merchant device(s) 108). For instance, when an open ticket data structure is first created, themerchant device 108 may cause the vector of the versioning data structure to include a count of one. Themerchant device 108 can then increase the count of the vector each time themerchant device 108 updates the open ticket. - Open ticket data structures described herein may be generated, maintained, and/or synchronized using some or all of the techniques described in U.S. patent application Ser. No. 14/686,381, filed on Apr. 14, 2015 and entitled “Open Ticket Payment Handling with Offline Mode”, and U.S. patent application Ser. No. 14/871,776, filed Sep. 30, 2015, entitled “Anticipatory Creation of Point-Of-Sale Structures,” which are incorporated herein by reference in its entirety.
- In some examples, the
merchant device 108 can generate the open tickets using predefined ticket templates (e.g., predefined types of tickets). Predefined ticket templates can define which elements are included within open tickets. For instance, a predefined ticket template can define which graphics, text, interactive elements, or the like are included within an open ticket. The predefined ticket templates can further define a layout for the elements within the open tickets. For instance, the predefined ticket template above can define a layout for the graphics, text, interactive elements, or the like. In some examples, themerchant device 108 selects which predefined ticket template to use for an open ticket of a transaction based on a type of transaction that the merchant is conducting with the user(s) 102. - For instance, the
merchant device 108 can associate predefined ticket templates with various types of transactions. Types of transactions can include transactions that occur at the physical establishment of themerchant 106 and/or transactions that occur outside of the physical establishment of themerchant 106. At the physical establishment of themerchant 106, types of transaction can be based zones/stations within the physical establishment of themerchant 106. For instance, in some examples, the types of transactions can include restaurant area transactions, bar area transactions, waiting area transactions, patio area transactions, or the like. Outside of the physical establishment of themerchant 106, types of merchants can include delivery type transactions. - To generate open tickets using the predefined ticket templates, the
merchant device 108 identifies the type of transaction that is being conducted between themerchant 106 and user(s) 102. For instance, themerchant device 108 can receive input associated with a transaction between themerchant 106 and user(s) 102. In some examples, the input can indicate the type of transaction that is being conducted between themerchant 106 and the user(s) 102. Additionally or alternatively, in some examples, the input can indicate a group (e.g., the zone/station) associated with the user(s) 102. In such examples, themerchant device 108 can determine the type of transaction based on the group. Themerchant device 108 can then select a predefined ticket template for the transaction based on the association between the predefined ticket template and the identified type of transaction. Using the predefined ticket template, the POS device can then generate an open ticket for the transaction between themerchant 106 and the user(s) 102. - In some examples, the
merchant device 108 can further associated transaction flows with the open tickets. Transaction flows can define one or more process(es) that themerchant 106 is to perform during a transaction with the user(s) 102. For instance, a transaction flow can include various steps associated with the transaction, such as when to input data associated with the user(s) 102, when to input data associated with orders made by the user(s) 102, when to process the transaction, whether to provide the user(s) 102 with a physical and/or digital receipt, or the like. In some examples, themerchant device 108 selects a transaction flow for an open ticket based on the predefined ticket template that themerchant device 108 uses when generating the open ticket. - After generating the open ticket, the
merchant device 108 can present the open ticket to themerchant 106. For instance, themerchant device 108 can generate a visual representation of data associated with the open ticket, and present the visual representation of the data via thedisplay 132. In some examples, a layout of data associated with the open ticket is based on the predefined ticket template and/or the transaction flow. For instance, the elements within the visual representation include the layout defined by the predefined ticket template. Additionally, any messages and/or alerts associated with the process(es) for the transaction flow are provided to themerchant 106 via the visual representation. - In some examples, the
merchant 106 can then utilize the visual representation during the course of the transaction with the user(s) 102. For instance, in some examples, themerchant 106 can utilize the visual representation to add additional orders made by the user(s) 102 to the open ticket. To add additional orders, themerchant device 108 can receive input associated with the orders from themerchant 106, such as indications of items ordered by the user(s) 102. Themerchant device 108 can then add data associated with the orders to the open ticket data structure of the open ticket. In some examples, themerchant device 108 can further update the associated versioning data structure for the open ticket data structure in to order to indicate that the open ticket was updated. Additionally, themerchant device 108 can update the visual representation of the open ticket based on the order. - In some examples, the
merchant 106 can further utilize the visual representation to merge the open ticket with an additional open ticket. Merging the open ticket with the additional open ticket can include merging the information from the open ticket data structure of the open ticket with information from the open ticket data structure of the additional open ticket in order to generate a merged open ticket data structure. For instance, the merged open ticket data structure can include the identity of themerchant 106, a location of themerchant 106, identities of the user(s) 102 of the open tickets, the personal information associated with the user(s) 102 of the open tickets, the locations of the user(s) 102 within the physical establishment of themerchant 106, the items order by the user(s) 102 during the transactions (e.g., cart information), timestamps for each of the items ordered by the user(s) 102 during the transaction, a cost associated with each of the items, a cost associated with the merged open ticket, or other information associated with the transactions. Themerchant device 108 can then generate a new visual representation of data associated with the merged open ticket, and present the new visual representation of the data via the display device. - In some examples, the
merchant 106 can further utilize the visual representation to modify the type of transaction associated with the transaction. For instance, themerchant device 108 can receive input identifying a new type of transaction for the transaction between themerchant 106 and the user(s) 102. Themerchant device 108 can then select (and/or determine) a new predetermined ticket template associated with the new type of transaction. Using the new predetermine ticket template, themerchant device 108 can update the open ticket for the transaction in order to generate a new open ticket. Themerchant device 108 can then select (and/or determine) a new transaction flow for the new open ticket, and associated the new transaction flow with the new open ticket. After generating the new open ticket, themerchant device 108 can generate a new visual representation of data associated with the new open ticket, and present the new visual representation of the data via the display device. - It should be noted that, in some examples, the computing device(s) 112 can generate the
open tickets 160 for themerchant 106 using a similar process as themerchant device 108 above. For instance, the computing device(s) 112 can receive, from amerchant device 108, data associated with the transactions between themerchant 106 and the user(s) 102. The computing device(s) 112 can then use the data to identify a types of transactions for the transactions between themerchant 106 and the user(s) 112. Based on the identified types of transactions, computing device(s) 112 can utilize theopen ticket module 152 to generateopen tickets 160 for the transactions using predefined ticket templates. The computing device(s) 112 can further associate transaction flows with theopen tickets 160. After generating theopen tickets 160, the computing device(s) 112 can send data associated with theopen tickets 160 to the merchant device(s) 108. - It should further be noted that, in some examples, the
merchant device 108 and/or the computing device(s) 112 can further synchronize data associated with open tickets. For instance, each time amerchant device 108 updates an open ticket, themerchant device 108 can send data associated with the update to the other merchant device(s) 108 and/or the computing device(s) 112. When synchronizing the data for the open tickets, the merchant device(s) 108 and/or the computing device(s) 112 can use the associated versioning data structures for the open tickets, as described above. -
FIG. 2 is an example illustration of merchant devices integrating predefined templates with open ticket functionality. For instance, a first point-of-sale (POS)device 202 andsecond POS device 204 can generate open tickets using predefined ticket templates and/or transaction flows. In some examples, thefirst POS device 202 and thesecond POS device 204 can each represent one of merchant device(s) 108. For instance, the processor(s) 206, the computer-readable media 208, thecard reader 210, thedisplay 212, thenetwork interface 214, thepayment service interface 216, and thePOS module 218 of thefirst merchant device 202 can represent the processor(s) 126, the computer-readable media 128, thecard reader 130, thedisplay 132, thenetwork interface 134, thepayment service interface 136, and thePOS module 138, respectively. Also, in some examples, thesecond POS device 204 can include one or more of the components 206-232 of thefirst POS device 202. - In the example of
FIG. 2 , thefirst POS device 202 can use theopen ticket module 220 to generateopen tickets 222 for transactions. For instance, a merchant (e.g., one of merchant(s) 106) can input data associated with the transactions into thefirst POS device 202. The input can include identities of customers (e.g., user(s) 102) associated with the transactions, personal information associated with the customers (e.g., contact information, addresses, etc.), locations of the customers within a physical establishment of the merchant (e.g., stations/zones within the physical establishment, such as restaurant area, bar area, waiting area, patio area, etc.), orders made by the customers during a course of the transactions with the merchant, or the like. Based on the input, thefirst POS device 202 can utilize theopen ticket module 152 to generate theopen tickets 222 for the transactions. - As discussed above,
open tickets 222 are data structures that store information associated with interactions between the merchant and the customers during a course of the transactions. In some examples, theopen tickets 222 further include associated versioning data structures that thefirst POS device 202 uses when synchronizing theopen tickets 222 with other merchant devices, such as thesecond POS device 204. After creating theopen tickets 222, and during the course of the transactions, thefirst POS device 202 can further update the data structures for theopen tickets 222. For instance, thefirst POS device 202 can add (e.g., store) additional information associated with interactions between the merchant and the customers to the data structures. - In the example of
FIG. 2 , thefirst POS device 202 can generate theopen tickets 222 using predefined ticket template(s) 224. In some examples, the predefined ticket template(s) 224 can define which elements are included within theopen tickets 222. For instance, the predefined ticket template(s) 224 can define which graphics, text, interactive elements, or the like are included within theopen tickets 222. Additionally, the predefined ticket template(s) 224 can define a layout for the elements within theopen tickets 222. For instance, the predefined ticket template(s) 224 can define the layout (e.g., the locations) for the graphics, text, interactive elements, or the like within theopen tickets 222. In some examples, thefirst POS device 202 selects which predefined ticket template(s) 224 to utilize when generatingopen tickets 222 based on types of transactions that the merchant is conducting with customers. - For instance, the
first POS device 202 can associate the predefined ticket template(s) 224 with various types of transactions. Types of transactions can include transactions that occur at the physical establishment of the merchant and/or transactions that occur outside of the physical establishment of the merchant. At the physical establishment of the merchant, types of transaction can be based zones/stations (e.g., groups) within the physical establishment of the merchant. For instance, in some examples, the types of transactions can include restaurant area transactions, bar area transactions, waiting area transactions, patio area transactions, or the like. Outside of the physical establishment of the merchant, types of merchants can include delivery type transactions. - To select a predefined ticket template 226 (from the predefined ticket templates(s) 224) for an
open ticket 228 of theopen tickets 222, thefirst POS device 202 identifies the type of transaction that is being conducted between the merchant and a customer. For instance, thefirst POS device 202 can receive input associated with the transaction between the merchant and the customer. In some examples, the input can indicate the type of transaction that is being conducted between the merchant and the customer. For instance, the input can indicate that the type of transaction includes a restaurant area type of transaction. Additionally or alternatively, in some examples, the input can indicate a group (e.g., a zone/station within the physical establishment) associated with the customer. For instance, the input can indicate that the customer is located within the restaurant area of the physical establishment of the merchant. Thefirst POS device 202 can then determine the type of transaction based on the group. - After identifying the type of transaction, the
first POS device 202 selects thepredefined ticket template 226 for the transaction. For instance, thefirst POS device 202 can determine that thepredefined ticket template 226 is associated with the identified type of transaction using the association between thepredefined ticket template 226 and the identified type of transaction. Based on the determination, thefirst POS device 202 can select thepredetermined ticket template 226 from the predefined ticket template(s) 224. - After selecting the
predefined ticket template 226, thefirst POS device 202 generates theopen ticket 228 using thepredefined ticket template 226. For instance, thefirst POS device 202 uses thepredefined ticket template 226 to determine which elements to include in theopen ticket 228. The elements can include graphics, text, interactive elements, or the like. Thefirst POS device 202 then uses thepredefined ticket template 226 to determine a layout for the elements within theopen ticket 228. For instance, the layout can define a location for each of the elements within theopen ticket 228. In some examples, thefirst POS device 202 then generates theopen ticket 228 based on the elements, the layout, and data input by the merchant that is associated with the transaction. For instance, thefirst POS device 202 can utilize the elements and/or the layout for the elements within theopen ticket 228 in order to place the data received from the merchant within theopen ticket 228. - For examples, the
predefined ticket template 226 and/or thetransaction flow 232 for theopen ticket 228 can define the layout of elements of theopen ticket 228 to include a first text portion at a top portion of theopen ticket 228 that includes general information about the merchant, a second text portion in a middle portion of theopen ticket 228 that includes a list of items, an interactive element below the list of items for adding additional items to theopen ticket 228, and an interactive element at a bottom portion of theopen ticket 228 for processing theopen ticket 228. In such an examples, thefirst POS device 202 can generate the layout of the elements for theopen ticket 228. Thefirst POS device 202 can then add text to the first text portion and the second text portion based on input that thefirst POS device 202 receives from the merchant. - In some examples, the
first POS device 202 can further associate transaction flow(s) 230 with theopen tickets 222. Transaction flow(s) 230 can include metadata indicating one or more process(es) that the merchant is to perform during transactions with the customers. For instance, each of the transaction flow(s) 230 can include data indicating various steps associated with a respective transaction, such as when to input data associated with the customers of the respective transaction, when to input data associated with orders made by the customers of the respective transaction, when to process the respective transaction, whether to provide a digital and/or printed receipt to the customers, or the like. In some examples, the transaction flow(s) 230 cause thefirst POS device 202 to provide messages and/or alerts to the merchant based on the process(es) that the merchant is to perform during the transactions. - For instance, at the start of transaction, a
transaction flow 230 can cause thefirst POS device 202 to present a message to the merchant notifying the merchant to input information associated with a customer of the transaction. In some examples, the transaction flow can further cause the first POS device to provide an interactive element on anopen ticket 222 of the transaction that the merchant can use to input the information about the customer. Next, during the transaction, thetransaction flow 230 can cause the first POS device to present a message to the merchant notifying the merchant to input data associated with a customer order. Additionally, in some examples, thetransaction flow 230 can cause the first POS device to provide an interactive element on theopen ticket 222 of the transaction that the merchant can use to input the data. Thetransaction flow 230 can then continue to provide the merchant with messages, during a course of the transaction, that notify the merchant of processes to take with the customer. - In some examples, the
first POS device 202 selects the transaction flow(s) 230 for theopen tickets 222 based on the predefined ticket template(s) 224 that thefirst POS device 202 uses when generating theopen tickets 222. For instance, thefirst POS device 202 can associate each of the transaction flow(s) 230 with one or more of the predefined ticket template(s) 224. In some examples, the associations between the transaction flow(s) 230 and the predefined ticket template(s) 224 are based on the types of transactions. For instance, atransaction flow 230 that defines one or more process(es) that the merchant is to perform during a restaurant area type of transaction can be associated with the predefined ticket template(s) 224 that the merchant associates with restaurant area types of transactions. Thefirst POS device 202 can then use the associations between the transaction flow(s) 230 and the predefined ticket template(s) 224 when selecting transaction flow(s) 230 foropen tickets 222. - For instance, in the example of
FIG. 2 , thefirst POS device 202 can determine that theopen ticket module 220 generated theopen ticket 228 using thepredefined ticket template 226. Based on the determination, thefirst POS device 202 can determine that thetransaction flow 232 from the transaction flow(s) 230 is associated with thepredefined ticket template 226. In response, the first POS device can then select the transaction flow for theopen ticket 228. Thefirst POS device 202 can further associate thetransaction flow 232 with theopen ticket 228. - After generating the
open tickets 222, thefirst POS device 202 can present theopen tickets 222 to the merchant via thedisplay 212. For instance, in the example ofFIG. 2 , thefirst POS device 202 can generate a visual representation of data associated with theopen ticket 228. Thefirst POS device 202 can then present the visual representation of the data via thedisplay 212. In some examples, a layout of the data associated with the visual representation is based on thepredefined ticket template 226 and/or thetransaction flow 232. For instance, the elements within the visual representation include the layout defined by thepredefined ticket template 226. Additionally, any messages and/or alerts associated with the process(es) for thetransaction flow 232 are provided to the merchant via the visual representation. - For example, the
transaction flow 232 foropen ticket 228 may indicate that a process for the transaction includes inputting data associated with the customer (e.g., an address) at a beginning of the transaction. Based on thetransaction flow 232, thefirst POS device 202 can provide a message on the visual representation that notifies the merchant to input the data. Thefirst POS device 202 can further present an interactive element on the visual representation that the merchant can utilize to input the information. - For another example, the
transaction flow 232 for theopen ticket 228 can indicate that a process for the transaction includes asking the customer if he/she would like another drink every ten minutes. Based on thetransaction flow 232, thefirst POS device 202 can provide an alert on the visual representation every ten minutes when thefirst POS device 202 does not receive input associated with drink orders for the transaction. The alert can notify the merchant that the merchant is to ask the customer if he/she would like another drink. Thefirst POS device 202 can further present an interactive element on the visual representation that the merchant can utilize to input the drink orders for the customer. - In some examples, the merchant can utilize the visual representation during the course of the transaction with the customer. For instance, in some examples, the merchant can utilize the visual representation to add additional orders made by the customer to the
open ticket 228. To add additional orders, thefirst POS device 202 can receive input associated with the orders from the merchant. The input can indicate one or more items ordered by the customer from the merchant. Thefirst POS device 202 can then add data associated with the orders to theopen ticket 228. Additionally, thefirst POS device 202 can update the visual representation of theopen ticket 228 based on the order. For instance, thefirst POS device 202 can add indications associated with the one or more items ordered by the customer to the visual representation. - In some examples, the merchant can further utilize the visual representation to merge the
open ticket 228 with an additional open ticket. Merging theopen ticket 228 with the additional open ticket can include merging the information from the open ticket data structure of theopen ticket 228 with information from the open ticket data structure of the additional open ticket in order to generate a merged open ticket data structure. Thefirst POS device 202 can then generate a new visual representation of data associated with the merged open ticket, and present the new visual representation of the data via thedisplay 212. - In some examples, the merchant can further utilize the visual representation to modify the type of transaction associated with the transaction. For instance, the
first POS device 202 can receive input identifying a new type of transaction for the transaction between the merchant and the customer. Thefirst POS device 202 can then select a newpredetermined ticket template 224 associated with the new type of transaction. Using the newpredetermine ticket template 224, thefirst POS device 202 can update theopen ticket 228 for the transaction in order to generate a new open ticket. Thefirst POS device 202 can then select anew transaction flow 230 for the new open ticket, and associated thenew transaction flow 230 with the new open ticket. After generating the new open ticket, thefirst POS device 202 can generate a new visual representation of data associated with the new open ticket, and present the new visual representation of the data via thedisplay 212. - Also illustrated in the example of
FIG. 2 , thefirst POS device 202 and thesecond POS device 204 can synchronizeopen tickets 222. For instance, thefirst POS device 202 can sendopen ticket data 234 to thesecond POS device 204. Theopen ticket data 234 can include data associated with one or more of theopen tickets 222. In some examples, thefirst POS device 202 sends theopen ticket data 234 to thesecond POS device 204 each time thefirst POS device 202 updates one of theopen tickets 222. In some examples, thefirst POS device 202 sends theopen ticket data 234 to thesecond POS device 204 at given time intervals. For instance, thefirst POS device 202 can send theopen ticket data 234 to thesecond POS device 204 every second, five seconds, minute, or the like. - Additionally, the
second POS device 204 can sendopen ticket data 236 to thefirst POS device 202. Theopen ticket data 236 can include data associated with one or more of the open tickets stored on the second POS device 204 (which can include open tickets 222). In some examples, thesecond POS device 204 sends theopen ticket data 236 to thefirst POS device 202 each time thesecond POS device 204 updates one of the open tickets. In some examples, thesecond POS device 204 sends theopen ticket data 236 to thefirst POS device 202 at given time intervals. For instance, thesecond POS device 204 can send theopen ticket data 236 to thefirst POS device 202 every second, five seconds, minute, or the like. - In some examples, the
first POS device 202 and thesecond POS device 204 use associated versioning data structures for open tickets when performing the synchronization. For instance, thefirst POS device 202 and/or thesecond POS device 204 can update the associated versioning data structure of an open ticket each time thefirst POS device 202 and/or the second POS device updates the open ticket. By updating the associated versioning data structure, the POS device that did not perform the updating can determine that the open ticket was updated by another POS device based on the associated versioning data structure. - It should further be noted that, in some examples, the
first POS device 202 can select predefined ticket template(s) 224 foropen tickets 222 using customer profiles (e.g., user account information 156). For instance, thefirst POS device 202 can store information associated with a customer in a customer profile. The information can include an identity of the customer, contact information associated with the customers, items that the customer ordered from the merchant in previous transactions, payment information associated with the customer, or the like. Thefirst POS device 202 can then use the customer profile to determine a type of transaction that the customer prefers when conducting transactions with the merchant. Based on the type of transaction, thefirst POS device 202 can create an open ticket for the transaction using the processes above. -
FIG. 3 is an example illustration of a third-party service integrating predefined templates with open ticket functionality for merchant devices. In the example ofFIG. 3 , aPOS device 302 can utilize the computing device(s) 112 to generate open tickets for transactions between a merchant and customers. In some examples, thePOS device 302 can represent one of merchant device(s) 108. In some examples, the computing device(s) 112 processes transactions for the merchant. In some examples, the computing device(s) 112 may include a service that only generatesopen tickets 160 for the merchant. - In the example of
FIG. 3 , thePOS device 302 can receive input corresponding to customer orders associated with transactions between the merchant and customers. Based on receiving the input, thePOS device 302 can sendtransactional data 304 associated with the transactions to the computing device(s) 112. Thetransactional data 304 can include data indicating an identity of the merchant, a location of the merchant, identities of the customers associated with the transaction, the personal information associated with the customers, the locations of the customers within the physical establishment of the merchant, the items order by the customers during a course of the transactions (e.g., cart information), timestamps for each of the items ordered by the customers during the course of the transactions, a cost associated with each of the items, or other information associated with the transactions. In some examples, thePOS device 302 sends the computing device(s) 112transaction data 304 for the transactions each time thePOS device 302 receives input associated with one of the transactions. Additionally or alternatively, in some examples, thePOS device 302 sends the computing device(s) 112transaction data 304 at given time intervals, such as every second, minute, five minutes, or the like. - The computing device(s) 112 can receive the
transactional data 304 from thePOS device 302. After receiving thetransaction data 304, the computing device(s) 112 utilize theopen ticket module 152 to generate the open tickets 160 (which can represent the open tickets 222) for the transactions using thetransactional data 304. For instance, the computing device(s) 112 can generateopen tickets 160 for the transactions using a similar process as thefirst POS device 202 generating theopen tickets 222 as described above. - For instance, in the example of
FIG. 3 , the computing device(s) 112 can generate theopen tickets 160 using predefined ticket template(s) 306, which can represent predefined ticket template(s) 224. When generating theopen tickets 160 using the predefined ticket templates(s) 306, the computing device(s) 112 can determine and/or select predefined ticket template(s) 306 for theopen tickets 160 using an association between the predefined ticket templates(s) 306 and types of transactions being conducted by the merchant. In some examples, the computing device(s) 112 can further associate transaction flow(s) 308 with theopen tickets 160, where the transaction flow(s) 308 can represent the transaction flow(s) 230. For instance, the computing device(s) 112 can determine and/or select transaction flow(s) 308 foropen tickets 160 using associations between the transaction flow(s) 308 and the predefined ticket template(s) 306. - For instance, in the example of
FIG. 3 , the computing device(s) 112 can generate anopen ticket 310 for a transaction between the merchant and a customer. To generate theopen ticket 310, the computing device(s) 112 can determine a type of transaction for the transaction using thetransaction data 304. For instance, in some examples, thetransaction data 304 can indicate that the type of transaction includes a restaurant area type of transaction. Additionally or alternatively, in some examples, thetransaction data 304 can indicate that the customer is associated with the restaurant area group, and the computing device(s) 112 can determine that the type of transaction includes a restaurant area type of transaction based on the group. The computing device(s) 112 can then use the type of transaction to select thepredefined ticket template 312 from the predefined ticket template(s) 306 for theopen ticket 310. - After selecting the
predefined ticket template 312, the computing device(s) 112 can utilize theopen ticket module 152 to generate theopen ticket 310 using thepredefined ticket template 312. In some example, the computing device(s) 112 can further select, based on thepredefined ticket template 312, atransaction flow 314 from the transaction flow(s) 308 for theopen ticket 310. For instance, the computing device(s) 112 can determine that the transaction flow 31 is associated with thepredefined ticket template 312. Based on the association, the computing device(s) 112 can select thetransaction flow 314 from the transaction flow(s) 308. The computing device(s) 112 can then associate thetransaction flow 314 with theopen ticket 310. - In the example of
FIG. 3 , the computing device(s) 112 can sendopen ticket data 316 to thePOS device 302. Theopen ticket data 316 can include data associated with one or more of theopen tickets 160. For instance, theopen ticket data 316 can include data indicating identities of theopen tickets 160, identities of the customers associated with theopen tickets 160, the personal information associated with the customers, the locations of the customers within the physical establishment of the merchant, the items order by the customers during a course of the transactions (e.g., cart information), timestamps for each of the items ordered by the customers during the course of the transactions, a cost associated with each of the items, or other information associated with the transactions. In some examples, thePOS device 302 can use theopen ticket data 316 to generate visual representations of one or more of theopen tickets 160. ThePOS device 302 can then display the visual representations of the one or moreopen tickets 160 to the merchant. - It should be noted that, in some examples, the
POS device 302 can continue to send the computing device(s) 112transaction data 304 associated with transactions between the merchant and customers. For instance, each time thePOS device 302 receives input associated with a transaction, thePOS device 302 can send the computing device(s) 112transaction data 304 associated with the input. In some examples, the input can include additional customer orders for the transaction, a request to merge anopen ticket 310 for the transaction with another open ticket, an indication that a type of transaction for the transaction has changed, or the like. The computing device(s) 112 can use thetransaction data 304 from thePOS device 302 to update theopen ticket 310 for the merchant using a similar process as thePOS device 202 above. - Additionally, it should be noted that, in some examples, the computing device(s) 112 can synchronize
open tickets 160 with additional merchant devices (e.g., POS device) associated with the merchant. For instance, the computing device(s) 112 can receive transaction data associated with transactions from one or more additional merchant devices. Using the transaction data, the computing device(s) 112 can generateopen tickets 160 for the transactions. The computing device(s) 112 can then send open ticket data associated with theopen tickets 160 to thePOS device 302 and/or to the one or more additional merchant devices. -
FIG. 4 is an example illustration of open tickets that were generated using predefined templates and/or transaction flows. For instance, in the examples ofFIG. 4 , aPOS device 402, which can represent one of merchant device(s) 108, is presenting an open ticket interface 404 (which can represent the payment service interface 136) to the merchant. Theopen ticket interface 404 includes visual representation of four open tickets 406-412. In some examples, each of the open tickets 406-412 can correspond to a respective transaction between the merchant and a customer. - For instance, the first
open ticket 406 can include arestaurant area 414 type of transaction between the merchant and a first customer. As illustrated inFIG. 4 , elements included in the firstopen ticket 406 for therestaurant area 414 type of transaction include atable number 416, a list ofitems 418, aninteractive add items 420 button, aninteractive merge 422 tickets button, and aninteractive process 424 the transaction button. - The
table number 416 can include text indicating a table that the first customer is seated at within the restaurant area of the physical establishment of the merchant. For instance, thetable number 416 can indicate that the first customer is seated at table five. The list ofitems 418 can indicate one or more items ordered by the first customer during a course of the transaction. The interactive additems 420 button can include an interactive element of the firstopen ticket 406 that the merchant can select to add additional items to the firstopen ticket 406. Theinteractive merge 422 button can include an interactive element of the firstopen ticket 406 that the merchant can select to merge the firstopen ticket 406 with one or more additional open tickets (e.g., open tickets 408-412). Finally, theinteractive process 424 transaction button can include an interactive element of the firstopen ticket 406 that the merchant can select to process the firstopen ticket 406 at the end of the transaction. - In some examples, a predefined ticket template and/or the transaction flow for the first
open ticket 406 can configure the firstopen ticket 406 to include the elements 414-424. For instance, the predefined ticket template for the firstopen ticket 606 can define that the firstopen ticket 406 includes text indicating therestaurant area 414 type of transaction, thetable number 416, and the list ofitems 418. Additionally, the predefined ticket template and/or the transaction flow for the firstopen ticket 406 can define that the firstopen ticket 406 include the interactive additems 420 button, theinteractive merge 422 items button, and theinteractive process 424 the transaction button. Moreover, in some examples, the transaction flow for the firstopen ticket 406 can define when messages and/or alerts are presented via the firstopen ticket 406 based on process(es) for arestaurant area 414 type of transaction. - For instance, the transaction flow for the
restaurant area 414 type of transaction can cause the firstopen ticket 406 to present messages indicating when the merchant should take drink orders, food orders, or desert orders from the first customer. Additionally, the transaction flow for therestaurant area 414 type of transaction can cause thePOS device 402 to print a physical receipt (instead of sending a digital receipt) for the transaction. - The second
open ticket 408 can include abar area 414 type of transaction between the merchant and a second customer. As illustrated inFIG. 4 , elements included in the secondopen ticket 408 for thebar area 426 type of transaction include aseat number 428, a list ofitems 430, aninteractive add items 432 button, aninteractive merge 434 tickets button, and aninteractive process 436 the transaction button. - The
seat number 428 can include text indicating a seat that the second customer is seated at within the bar area of the physical establishment of the merchant. For instance, theseat number 428 can indicate that the second customer is seated at seat six. The list ofitems 430 can indicate one or more items ordered by the second customer during a course of the transaction. The interactive additems 432 button can include an interactive element of the secondopen ticket 408 that the merchant can select to add additional items to the secondopen ticket 408. Theinteractive merge 434 button can include an interactive element of the secondopen ticket 408 that the merchant can select to merge the secondopen ticket 408 with one or more additional open tickets (e.g.,open tickets interactive process 436 transaction button can include an interactive element of the secondopen ticket 408 that the merchant can select to process the secondopen ticket 408 at the end of the transaction. - In some examples, a predefined ticket template and/or the transaction flow for the second
open ticket 408 can configure the secondopen ticket 408 to include the elements 426-436. For instance, the predefined ticket template of the secondopen ticket 408 can define that the secondopen ticket 408 includes text indicating thebar area 426 type of transaction, theseat number 428, and the list ofitems 430. Additionally, the predefined ticket template and/or the transaction flow for the secondopen ticket 408 can define that the secondopen ticket 408 includes the interactive additems 432 button, theinteractive merge 434 tickets button, and theinteractive process 436 the transaction button. Moreover, in some examples, the transaction flow for the secondopen ticket 408 can define when messages and/or alerts are presented via the secondopen ticket 408 based on process(es) for abar area 426 type of transaction. - For instance, the transaction flow for the
bar area 426 type of transaction can cause the secondopen ticket 408 to present messages indicating when the merchant should ask the second customer if he/she would like another drink. Additionally, the transaction flow for thebar area 426 type of transaction can cause the secondopen ticket 408 to present a message indicating that the merchant should ask the second customer if he/she would like to order food. Moreover, the transaction flow for thebar area 426 type of transaction can cause thePOS device 402 to print a physical receipt (instead of sending a digital receipt) for the transaction. - The third
open ticket 410 can include awaitlist area 438 type of transaction between the merchant and a third customer. As illustrated inFIG. 4 , elements included in the thirdopen ticket 410 for thewaitlist area 438 type of transaction include awaitlist position 440, a list ofitems 442, aninteractive add items 444 button, aninteractive transaction type 446 button, and aninteractive process 448 the transaction button. - The
waitlist position 440 can include text indicating a position on a waitlist associated with the third customer. For instance, thewaitlist position 440 can indicate that the third customer is next to be seated and/or that the estimated wait time for the third customer is five minutes. The list ofitems 442 can indicate one or more items ordered by the third customer during a course of the transaction. The interactive additems 444 button can include an interactive element of the thirdopen ticket 410 that the merchant can select to add additional items to the thirdopen ticket 410. Theinteractive transaction type 446 button can include an interactive element of the thirdopen ticket 410 that the merchant can select to update a type of transaction associated with the thirdopen ticket 410 when the customer is seated at the physical establishment of the merchant. Finally, theinteractive process 448 transaction button can include an interactive element of the thirdopen ticket 410 that the merchant can select to process the thirdopen ticket 410 at the end of the transaction. - In some examples, a predefined ticket template and/or the transaction flow for the third
open ticket 410 can configure the thirdopen ticket 410 to include the elements 438-448. For instance, the predefined ticket template can define that the thirdopen ticket 410 includes text indicating the waitingarea 438 type of transaction, thewaitlist position 440, and the list ofitems 442. Additionally, the predefined ticket template and/or the transaction flow for the thirdopen ticket 410 can define that the thirdopen ticket 410 include the interactive additems 444 button, theinteractive transaction type 446 button, and theinteractive process 448 the transaction button. Moreover, in some examples, the transaction flow for the thirdopen ticket 410 can define when messages and/or alerts are presented via the thirdopen ticket 410 based on process(es) for awaitlist area 438 type of transaction. - For instance, the transaction flow for the
waitlist area 438 type of transaction can cause the thirdopen ticket 410 to present messages indicating when to update the third customer about the estimated wait time. Additionally, if the merchant closes the transaction before seating the third customer, the transaction flow for thewaitlist area 438 type of transaction can cause thePOS device 402 to print a physical receipt (instead of sending a digital receipt) for the transaction. - The fourth
open ticket 412 can include adelivery 450 type of transaction between the merchant and a fourth customer. As illustrated inFIG. 4 , elements included in the fourthopen ticket 412 for thedelivery 450 type of transaction include anaddress 452, a list ofitems 454, aninteractive add items 456 button, an interactive route todriver 458 button, and aninteractive process 460 the transaction button. - The
address 452 can include text indicating an address associated with the fourth customer. The list ofitems 454 can indicate one or more items ordered by the fourth customer for delivery. The interactive additems 456 button can include an interactive element of the fourthopen ticket 412 that the merchant can select to add additional items to the thirdopen ticket 410. The interactive route todriver 458 button can include an interactive element of the fourthopen ticket 412 that the merchant can select to route the order to one of the merchant's drivers. Finally, theinteractive process 460 transaction button can include an interactive element of the fourthopen ticket 412 that the merchant can select to process the fourthopen ticket 412 at the end of the transaction. - In some examples, a predefined ticket template and/or the transaction flow for the fourth
open ticket 412 can configure the fourthopen ticket 412 to include the elements 450-460. For instance, the predefined ticket template can define that the fourthopen ticket 412 includes text indicating thedelivery 450 type of transaction, theaddress 452, and the list ofitems 454. Additionally, the predefined ticket template and/or the transaction flow for the fourthopen ticket 412 can define that the fourthopen ticket 412 include the interactive additems 456 button, the interactive route todriver 458 button, and theinteractive process 460 the transaction button. Moreover, in some examples, the transaction flow for the fourthopen ticket 412 can define when messages and/or alerts are presented via the fourthopen ticket 412 based on process(es) for adelivery 450 type of transaction. - For instance, the transaction flow for the
delivery 450 type of transaction can cause the fourthopen ticket 412 to present a message indicating that the merchant needs to input theaddress 452 of the fourth customer. Additionally, the transaction flow for thedelivery 450 type of transaction can cause the fourthopen ticket 412 to indicate that the merchant needs to route the delivery to a driver. Moreover, the transaction flow for thedelivery 450 type of transaction can cause thePOS device 402 to send a digital receipt (instead of printing a physical receipt) for the transaction to the fourth customer. -
FIGS. 5A-5B are example illustrations of user interfaces for creating open tickets using predefined templates. For instance, in the example ofFIG. 5A , the merchant location interface 502 (which can represent the payment service interface 136) includes a representation of a merchant's physical location. For instance, the merchant's physical location can include arestaurant area 504, abar area 506, and awaitlist area 508. Additionally, themerchant location interface 502 includes a position fordelivery 510 type transactions. - In the example of
FIG. 5A , the merchant can use themerchant location interface 502 to generate open tickets for customers. For instance, the merchant can use one of the interactive create tickets 512(1)-(6) buttons within therestaurant area 504 of themerchant location interface 502 to create open tickets for restaurant area types of transactions (e.g., the first open ticket 406). As illustrated inFIG. 5A , the merchant is able to create tickets 512(1)-(6) for therestaurant area 504 are around table one 514(1). The merchant can further use one of the interactive view tickets 516(1)-(6) to view open tickets that are already open for transactions with customers. As illustrated inFIG. 5A , the merchant is able to view tickets 516(1)-(6) for therestaurant area 504 around table two 514(2). For instance, table one 514(1) within therestaurant area 504 may be open, however, table two 514(2) within the restaurant area may be filled with customers. - In the example of
FIG. 5A , the merchant can use the interactive create tickets 518(1)-(2) buttons within thebar area 506 of themerchant location interface 502 to create open tickets for bar area types of transactions (e.g., the second open ticket 408). Additionally, the merchant can use the interactive view tickets 520(1)-(3) buttons to view open tickets that are already open for transaction with customers within thebar area 506. In some examples, each of the interactive create tickets 518(1)-(2) buttons and each of the interactive view tickets 520(1)-(3) buttons can be associated with a respective seat within thebar area 506 of the merchant's physical establishment. In some examples, each of the interactive create tickets 518(1)-(2) buttons and each of the interactive view tickets 520(1)-(3) buttons can be associated with either a seat and/or a defined location within thebar area 506 of the merchant's physical establishment. - In the example of
FIG. 5A , the merchant can use the interactive createtickets 522 button within the waitingarea 508 of themerchant location interface 502 to create open tickets for waiting area types of transactions (e.g., the third open ticket 410). Additionally, the merchant can use the interactive view tickets 524(1)-(3) buttons to view open tickets that are already open for transaction with customers within the waitingarea 508. In some examples, each of the view tickets 524(1)-(3) may correspond to a respective customer within the waitingarea 508. In some examples, the merchant can use the interactive createtickets 522 button to create any number open tickets for the waitingarea 508. - In the example of
FIG. 5A , the merchant can use the interactive createtickets button 526 within thedelivery area 510 of themerchant location interface 502 to create open tickets for delivery types of transaction (e.g., the fourth open ticket 412). Additionally, the merchant can use theinteractive view tickets 528 button to view open tickets that were already created for delivery types of transaction. - It should be noted that, in some examples, the each of the interactive buttons 512(1)-(6), 516(1)-(6), 518(1)-(2), and 520(1)-(3) can correspond to a specific location within the merchant's physical establishment. In such examples, the
merchant location interface 502 may not allow the merchant to create open tickets for a specific location when there is already an open ticket at the specific location (e.g., when the interactive button includes a “view ticket” button). Additionally, when an open ticket is closed by the merchant, themerchant location interface 502 can update the interactive button for the specific location to indicate that the specific location is now open (e.g., update with an interactive “create ticket” button). The merchant can then use the interactive “create ticket” button at the specific location to create a new open ticket at the specific location. - In the example of
FIG. 5B , themerchant location interface 502 includes lists for the different stations/zones of the merchant's physical establishment. For instance, themerchant location interface 502 includes a list for therestaurant area 504 that includes the interactive create tickets 512(1)-(6) buttons for table one 514(1) and the interactive view tickets 516(1)-(6) buttons for table two 514(2). Themerchant location interface 502 further includes a list for thebar area 506 that includes the interactive create tickets 518(1)-(2) buttons and the interactive view tickets 520(1)-(3) buttons. Additionally, themerchant location interface 502 includes a list for the waitingarea 508 that includes the interactive createtickets 522 button and the interactive view tickets 524(1)-(3) buttons. Finally, themerchant location interface 502 includes a list for thedelivery area 510 that includes the interactive createtickets 526 button and theinteractive view tickets 528 button. - As such, in some examples, the
merchant location interface 502 can either present the merchant with a physical layout of the merchant's physical establishment or a list of different stations/zones within the merchant's physical establishment. Using either the physical layout or the list of different stations/zones, the merchant can use themerchant location interface 502 to generate open tickets for transactions that are based on the types of transactions that the merchant is conducting with customers. -
FIG. 6 is an example illustration of merging two open tickets in order to create a merged open ticket. For instance, in the example ofFIG. 6 , thePOS device 602 is presenting anopen ticket interface 604 that includes a firstopen ticket 606 and a secondopen ticket 608. In the example ofFIG. 6 , thePOS device 602, theopen ticket interface 604, and each of the open tickets 606-608 can correspond to thePOS device 402, theopen ticket interface 404, and the secondopen ticket 408, respectively. For instance, thebar area 610 type of transaction, seat numbers 612(1)-(2), lists of items 614(1)-(2), interactive additems 616 button,interactive merge 618 tickets button, andinteractive process 620 the transaction button can correspond to thebar area 426 type of transaction, theseat number 428, the list ofitems 430, the interactive additems 432 button, theinteractive merge 434 tickets button, and theinteractive process 436 the transaction button, respectively. - In the example of
FIG. 6 , a merchant can utilize theinteractive merge 618 tickets button on one of the open tickets 606-608 to merge the open tickets 606-608. In some examples, merging the open tickets 606-608 together can include combining information included within the open ticket data structure of the firstopen ticket 606 with information included within the open ticket data structure of the secondopen ticket 608 in order to generate a merged open ticket data structure. For instance, in the example ofFIG. 6 , the list of items 612(2) of the mergedopen ticket 622 includes seat number “(X)” from the firstopen ticket 606 and set number “(Y)” from the secondopen ticket 608. Additionally, the list of items 614(3) of the mergedopen ticket 622 includes items “A” and “B” from the firstopen ticket 606 and item “C” from the secondopen ticket 608. - It should be noted that, in some examples, merging the open tickets 606-608 can further include creating a new associated versioning data structure for the merged
open ticket 622. For instance, in some examples, thePOS device 602 can create the new associated versioning data structure for the mergedopen ticket 622 using the associated versioning data structure from the firstopen ticket 606 and the associated versioning data structure from the secondopen ticket 608. By creating the new associated versioning data structure for the mergedopen ticket 622, POS devices that synchronize data with thePOS device 602 can use the new associated versioning data structure to determine that the open tickets 606-608 were merged in order to create the mergedopen ticket 622. -
FIGS. 7A-7B are a flow diagram illustrating anexample process 700 for integrating predefined templates with open ticket functionality. Theprocess 700 and other processes described herein are illustrated as collections of blocks in logical flow diagrams, which represent a sequence of operations, some or all of which can be implemented in hardware, software or a combination thereof. In the context of software, the blocks may represent computer-executable instructions stored on one or more computer-readable media that, when executed by one or more processors, program the processors to perform the recited operations. Generally, computer-executable instructions include routines, programs, objects, components, data structures and the like that perform particular functions or implement particular data types. The order in which the blocks are described should not be construed as a limitation. Any number of the described blocks can be combined in any order and/or in parallel to implement the process, or alternative processes, and not all of the blocks need be executed. For discussion purposes, the processes are described with reference to the environments, architectures and systems described in the examples herein, although the processes may be implemented in a wide variety of other environments, architectures and systems. Theprocess 700, and other processes described herein, may be performed by a remote payment service (e.g., computing device(s) 112), a POS device (e.g., merchant device(s) 108), by another entity, or by a combination thereof. - At
block 702, theprocess 700 identifies a type of transaction between a merchant and a customer. For instance, a POS device can identify the type of transaction between the merchant and the customer. To identify the type of transaction, in some examples, the POS device receives input, via an input device, that identifies the type of transaction. In some examples, the POS device receives input, via the input device, identifying a group associated with the customer. In such examples, the POS device can use the group to determine the type of transaction. - At
block 704, theprocess 700 selects a ticket type for the transaction from a plurality of predefined ticket types. For instance, the POS device can associate predetermined ticket templates (e.g., ticket types) with various types of transactions. The POS device can then use the associations to determine which predetermine ticket template (e.g., ticket type) from the predetermined ticket templates is associated with the identified type of transaction. Based on the determination, the POS device can select the predetermined ticket template. - At
block 706, theprocess 700 generates an open ticket based at least in part on the ticket type. For instance, the POS device can generate an open ticket for the transaction using the predefined ticket template. As discussed above, the open ticket can include a data structure that stores cart information indicating items that are ordered by the customer from the merchant during the transaction. Additionally, in some examples, the open ticket can further include an associated versioning data structure indicating a version of the open ticket. - At
block 708, theprocess 700 selects a transaction flow from a plurality of transaction flows and atblock 710, theprocess 700 associates the transaction flow with the open ticket. For instance, the POS device can associate transaction flows with the predetermined ticket templates. The POS device can then use the associations to determine which transaction flow from the transaction flows is associated with the selected predetermined ticket template. Based on the determination, the POS device can select the transaction flow for the open ticket. Additionally, the POS device can associate the transaction flow with the open ticket. - At
block 712, theprocess 700 generates a visual representation of data associated with the open ticket and atblock 714, theprocess 700 presents the visual representation of the data. For instance, the POS device can generate the visual representation of the open ticket using data from the data structure of the open ticket. In some examples, a layout of the data within the visual representation can be based on the predetermined ticket template and/or the transaction flow. The POS device can then present the visual representation of the data via a display device. - At
block 716, theprocess 700 receives input corresponding to a customer order for the transaction and atblock 718, theprocess 700 adds information associated with the customer order to the open ticket. For instance, the POS device can receive, via the input device, data indicating one or more items item ordered by the customer from the merchant during a course of the transaction. Based on the input, the POS device can update the open ticket for the transaction. For instance, the POS device can add information associated with the one or more items to the data structure of the open ticket. In some examples, the POS device can further update the associated versioning data structure of the open ticket in order to indicate that the open ticket was updated. - At
block 720, theprocess 700 updates the visual representation of the data based at least in part on the customer order. For instance, the POS device can update the visual representation of the data to indicate the one or more items ordered by the customer. In some examples, additionally or alternatively to updating the visual representation, the POS device can generate a new visual representation of the updated open ticket and present the new visual representation via the display device. - At
block 722, theprocess 700 processes the transaction using the open ticket. For instance, in some examples, the POS device can receive payment information associated with a payment instrument of the customer. The POS device can then attempt to authorize the payment instrument for a cost of the open ticket. For instance, in some examples, the POS device can send the payment information to a third-party service (e.g., the computing device(s) 112) in order to cause the third-party service to process the payment instrument. In some examples, the POS device can send the payment information to a card payment network computing device (e.g., card payment network computing device(s) 164) in order to process the payment instrument. -
FIG. 8 is a flow diagram of illustrating anexample process 800 for updating an open ticket based on a type of transaction between a merchant and a customer changing. Atblock 802, theprocess 800 generates an open ticket for a transaction based at least in part on a first type of transaction, the first type of transaction being associated with a first ticket type and a first transaction flow. For instance, a POS device can generate the open ticket using the first predetermined template (e.g., the first ticket type) and the first transaction flow for the first type of transaction. - At
block 804, theprocess 800 receives input identifying a second type of transaction for the transaction. For instance, in some examples, the POS device can receive input, via an input device, that identifies the second type of transaction. Additionally or alternatively, in some examples, the first POS device can receive input, via the input device, identifying a new group associated with the customer. In such examples, the POS device can identify the second type of transaction based on the new group. - At
block 806, theprocess 800 determines a second ticket type for the transaction based at least in part on the second type of transaction and atblock 808, theprocess 800 updates, based at least in part on the second ticket type, the open ticket in order to generate an updated open ticket. For instance, the POS device can use an association between the second type of transaction and a second predetermined ticket template (e.g., the second ticket type) to determine and/or select the second predetermined ticket template. The POS device can then update the open ticket using the second predetermined ticket template. For instance, the POS device can update elements included within the open ticket and/or a layout of the elements included within the open ticket based on the second predetermined ticket template. In some examples, the POS device can further update an associated versioning data structure associated with the open ticket. - At
block 810, theprocess 800 selects, based at least in part on the second ticket type, a second transaction flow and atblock 812, theprocess 800 associates the second transaction flow with the updated open ticket. For instance, the POS device can select the second transaction flow based on an association between the second transaction flow and the second predetermined ticket template. The POS device can then associate the second transaction flow with the updated open ticket. - At
block 814, the process presents a visual representation of data associated with the updated open ticket. For instance, the POS device can generate the visual representation of the data using the data structure of the open ticket. In some examples, a layout of the visual representation of the data is based on the second predefined ticket template and the second transaction flow. The POS device can then present the visual representation of the data via a display device. - In some examples, the POS device can further synchronize the updated open ticket with one or more other POS devices associated with the merchant. For instance, the POS device can send ticket data associated with the updated open ticket to the one or more other POS devices. In some examples, the ticket data can include the updated associated versioning data structure. In such examples, the updated associated versioning data structure of the updated open ticket can cause the one or more other POS devices to update the open ticket stored locally on the one or more other POS devices to the updated open ticket.
-
FIG. 9 is a flow diagram of anexample process 900 for merging two open tickets in order to generate a merged open ticket. Atblock 902, theprocess 900 generates a first open ticket for a first transaction between a merchant and a first customer. For instance, a POS device can receive input associated with the first transaction. The POS device can then generate a first open ticket data structure for the first transaction based on the input. In some examples, the first open ticket data structure includes at least data indicating items ordered by the first customer from the merchant. - At
block 904, theprocess 900 generates a second open ticket for a second transaction between the merchant and a second customer. For instance, the POS device can receive input associated with the second transaction. The POS device can then generate a second open ticket data structure for the second transaction based on the input. In some examples, the second open ticket data structure includes at least data indicating items ordered by the second customer from the merchant. - At
block 906, theprocess 900 receives input associated with merging the first open ticket with the second open ticket and atblock 908, theprocess 900 merges the first open ticket with the second open ticket in order to generate a merged open ticket. For instance, the POS device can receive input associated with merging the first open ticket data structure with the second open ticket data structure. Based on the input, the POS device can merge the first open ticket data structure with the second open ticket data structure in order to generate a merged open ticket data structure. In some examples, the merged open ticket data structure can include at least the items order by the first customer from the merchant and the items ordered by the second customer from the merchant. - At
block 910, theprocess 900 presents a visual representation of data associated with the merged open ticket. For instance, the POS device can generate the visual representation of the data using the merged open ticket data structure. In some examples, a layout of the visual representation of the data is based on a type of transaction associated with the merged open ticket data structure. The POS device can then present the visual representation of the data via a display device. -
FIG. 10 is a flow diagram illustrating anexample process 1000 of a third-party service integrating predefined templates with open ticket functionality. Atblock 1002, theprocess 1000 receives data associated with a transaction between a merchant and a customer. For instance, a third-party service (e.g., the computing device(s) 112) can receive the data associated with the transaction from a POS device. In some examples, the data can indicate an identity of the merchant, a location of the merchant, an identity of the customer associated with the transaction, the personal information associated with the customer, a location of the customer within the physical establishment of the merchant, items order by the customer during a course of the transaction (e.g., cart information), timestamps for each of the items ordered by the customer during the course of the transaction, a cost associated with each of the items, or other information associated with the transaction. - At
block 1004, theprocess 1000 identifies a type of transaction between the merchant and the customer. For instance, third-party service can identify the type of transaction between the merchant and the customer using the received data. In some examples, the data identifies the type of transaction. In some examples, the data identifies a group associated with the customer. In such examples, the third-party service can use the group to determine the type of transaction. - At
block 1006, theprocess 1000 selects, based at least in part on the type of transaction, a ticket type for the transaction from a plurality of predefined ticket types. For instance, the third-party service can associate predetermined ticket templates (e.g., ticket types) with various types of transactions. The third-party service can then use the associations to determine which predetermine ticket template (e.g., ticket type) from the predetermined ticket templates is associated with the identified type of transaction. Based on the determination, the third-party service can select the predetermined ticket template. - At
block 1008, theprocess 1000 generates, based at least in part on the ticket type, an open ticket for the transaction. For instance, the third-party service can generate an open ticket for the transaction using the predefined ticket template. As discussed above, the open ticket can include a data structure that stores cart information indicating items that are ordered by the customer from the merchant during the transaction. Additionally, in some examples, the open ticket can further include an associated versioning data structure indicating a version of the open ticket. - At
block 1010, theprocess 1000 selects, based at least in part on the ticket type, a transaction flow from a plurality of transaction flows and atblock 1012, theprocess 1000 associates the transaction flow with the open ticket. For instance, the third-party service can associate transaction flows with the predetermined ticket templates. The third-party service can then use the associations to determine which transaction flow from the transaction flows is associated with the selected predetermined ticket template. Based on the determination, the third-party service can select the transaction flow for the open ticket. Additionally, the third-party service can associate the transaction with the open ticket. - At
block 1014, theprocess 1000 sends data associated with the open ticket to at least one merchant device. For instance, the third-party service can send data associated with the open ticket to one or more POS device associated with the merchant. The one or more POS device can then use the received data to present a visual representation of data for the open ticket. In some examples, a layout of the visual representation of the data is based on the predetermined ticket template and/or the transaction flow. - Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described. Rather, the specific features and acts are disclosed as illustrative forms of implementing the claims.
Claims (20)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US17/703,821 US20220224309A1 (en) | 2016-06-28 | 2022-03-24 | Integrating Predefined Templates with Open Ticket Functionality |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/195,557 US10580062B1 (en) | 2016-06-28 | 2016-06-28 | Integrating predefined templates with open ticket functionality |
US16/807,306 US11133790B2 (en) | 2017-09-07 | 2020-03-03 | Acoustic wave device |
US17/703,821 US20220224309A1 (en) | 2016-06-28 | 2022-03-24 | Integrating Predefined Templates with Open Ticket Functionality |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US16/807,306 Continuation US11133790B2 (en) | 2016-06-28 | 2020-03-03 | Acoustic wave device |
Publications (1)
Publication Number | Publication Date |
---|---|
US20220224309A1 true US20220224309A1 (en) | 2022-07-14 |
Family
ID=69645414
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/195,557 Active 2037-07-13 US10580062B1 (en) | 2016-06-28 | 2016-06-28 | Integrating predefined templates with open ticket functionality |
US16/807,036 Active 2036-12-14 US11295371B2 (en) | 2016-06-28 | 2020-03-02 | Integrating predefined templates with open ticket functionality |
US17/703,821 Pending US20220224309A1 (en) | 2016-06-28 | 2022-03-24 | Integrating Predefined Templates with Open Ticket Functionality |
Family Applications Before (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US15/195,557 Active 2037-07-13 US10580062B1 (en) | 2016-06-28 | 2016-06-28 | Integrating predefined templates with open ticket functionality |
US16/807,036 Active 2036-12-14 US11295371B2 (en) | 2016-06-28 | 2020-03-02 | Integrating predefined templates with open ticket functionality |
Country Status (1)
Country | Link |
---|---|
US (3) | US10580062B1 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11847657B2 (en) | 2018-12-13 | 2023-12-19 | Block, Inc. | Batch-processing transactions in response to an event |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10043162B1 (en) | 2015-03-31 | 2018-08-07 | Square, Inc. | Open ticket payment handling with bill splitting |
US10311420B1 (en) | 2016-06-17 | 2019-06-04 | Square, Inc. | Synchronizing open ticket functionality with kitchen display systems |
US10580062B1 (en) | 2016-06-28 | 2020-03-03 | Square, Inc. | Integrating predefined templates with open ticket functionality |
US10796280B2 (en) | 2017-06-29 | 2020-10-06 | Simplified Technologies, Inc. | System for preparation of modifiable recipe-based products |
US10943311B1 (en) | 2017-09-29 | 2021-03-09 | Square, Inc. | Order fulfillment and tracking systems and methods |
US11138680B1 (en) | 2018-11-21 | 2021-10-05 | Square, Inc. | Updating menus based on predicted efficiencies |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20140164234A1 (en) * | 2012-12-12 | 2014-06-12 | Capital One Financial Corporation | Systems and methods for splitting a bill associated with a receipt |
US20160162889A1 (en) * | 2013-07-26 | 2016-06-09 | Visa International Service Association | Provisioning payment credentials to a consumer |
US9430784B1 (en) * | 2012-03-30 | 2016-08-30 | David Frederick | System for E-commerce accessibility |
US9959529B1 (en) * | 2014-05-11 | 2018-05-01 | Square, Inc. | Open tab transactions |
US10026062B1 (en) * | 2015-06-04 | 2018-07-17 | Square, Inc. | Apparatuses, methods, and systems for generating interactive digital receipts |
US11295371B2 (en) * | 2016-06-28 | 2022-04-05 | Block, Inc. | Integrating predefined templates with open ticket functionality |
Family Cites Families (187)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4485300A (en) | 1982-03-18 | 1984-11-27 | Visa U.S.A., Inc. | Loss control system |
US6373950B1 (en) | 1996-06-17 | 2002-04-16 | Hewlett-Packard Company | System, method and article of manufacture for transmitting messages within messages utilizing an extensible, flexible architecture |
US5980089A (en) | 1997-03-27 | 1999-11-09 | Showbiz Pizza Time, Inc. | Automatic token dispensing apparatus and method |
US6473740B2 (en) * | 1998-11-29 | 2002-10-29 | Qpass, Inc. | Electronic commerce using a transaction network |
US7571139B1 (en) | 1999-02-19 | 2009-08-04 | Giordano Joseph A | System and method for processing financial transactions |
AU775464B2 (en) | 1999-04-27 | 2004-08-05 | Mobilserv Technologies Inc. | Remote ordering system |
US7536307B2 (en) * | 1999-07-01 | 2009-05-19 | American Express Travel Related Services Company, Inc. | Ticket tracking and redeeming system and method |
US8875990B2 (en) | 1999-11-05 | 2014-11-04 | Lead Core Fund, L.L.C. | Systems and methods for allocating a payment authorization request to a payment processor |
US6727925B1 (en) | 1999-12-20 | 2004-04-27 | Michelle Lyn Bourdelais | Browser-based room designer |
US6516056B1 (en) | 2000-01-07 | 2003-02-04 | Vesta Corporation | Fraud prevention system and method |
AU2001238105A1 (en) | 2000-02-10 | 2001-08-20 | Jon Shore | Apparatus, systems and methods for wirelessly transacting financial transfers, electronically recordable authorization transfers, and other information transfers |
US20060178986A1 (en) | 2000-02-17 | 2006-08-10 | Giordano Joseph A | System and method for processing financial transactions using multi-payment preferences |
US7685052B2 (en) | 2000-06-01 | 2010-03-23 | Pipeline Financial Group, Inc. | Confidential block trading system and method |
US8260723B2 (en) | 2000-12-01 | 2012-09-04 | Carrott Richard F | Transactional security over a network |
US6732934B2 (en) | 2001-01-12 | 2004-05-11 | Symbol Technologies, Inc. | Escorted shopper system |
US7856377B2 (en) | 2001-03-29 | 2010-12-21 | American Express Travel Related Services Company, Inc. | Geographic loyalty system and method |
US7797204B2 (en) | 2001-12-08 | 2010-09-14 | Balent Bruce F | Distributed personal automation and shopping method, apparatus, and process |
US7071842B1 (en) | 2002-06-27 | 2006-07-04 | Earthcomber, Llc | System and method for locating and notifying a user of a person, place or thing having attributes matching the user's stated preferences |
US9563890B2 (en) * | 2002-10-01 | 2017-02-07 | Dylan T X Zhou | Facilitating mobile device payments using product code scanning |
US9576285B2 (en) * | 2002-10-01 | 2017-02-21 | Dylan T X Zhou | One gesture, one blink, and one-touch payment and buying using haptic control via messaging and calling multimedia system on mobile and wearable device, currency token interface, point of sale device, and electronic payment card |
US20050004843A1 (en) | 2003-07-01 | 2005-01-06 | Heflin Steven S. | System and method for providing restaurant related services |
US7293254B2 (en) | 2003-09-18 | 2007-11-06 | Microsoft Corporation | Extensibility application programming interface and framework for meta-model objects |
US7958029B1 (en) | 2003-10-20 | 2011-06-07 | Thomas Bobich | Method for minimizing financial risk for wireless services |
US7571468B1 (en) | 2004-04-06 | 2009-08-04 | Sun Microsystems, Inc. | Personal authorisation device |
US9940374B2 (en) | 2004-04-26 | 2018-04-10 | Right90, Inc. | Providing feedback in a operating plan data aggregation system |
US8885894B2 (en) | 2004-06-14 | 2014-11-11 | Michael John Rowen | Reduction of transaction fraud through the use of automatic centralized signature/sign verification combined with credit and fraud scoring during real-time payment card authorization processes |
US9519898B2 (en) * | 2004-10-22 | 2016-12-13 | Smart Cellco, Inc. | Wearable electronic devices and mobile transactions and/or actions |
US20060143087A1 (en) | 2004-12-28 | 2006-06-29 | Tripp Travis S | Restaurant management using network with customer-operated computing devices |
US7805382B2 (en) * | 2005-04-11 | 2010-09-28 | Mkt10, Inc. | Match-based employment system and method |
US7748621B2 (en) | 2005-06-06 | 2010-07-06 | International Business Machines Corporation | Method and system for dissemination of paperless transaction receipts in non-networked environments |
US20070018041A1 (en) | 2005-07-07 | 2007-01-25 | Butler Ernest M | Model aircraft |
US20070033134A1 (en) | 2005-08-02 | 2007-02-08 | Bank Of America Corporation | Automatic Savings Program |
US7896242B2 (en) * | 2005-08-26 | 2011-03-01 | Reagan Inventions, Llc | System and method for issuing digital receipts for purchase transactions over a network |
US9064359B2 (en) | 2005-12-02 | 2015-06-23 | Modiv Media, Inc. | System for queue and service management |
US7370794B2 (en) | 2006-03-15 | 2008-05-13 | Fleming Trane | Device and system for presenting and facilitating payment of a restaurant bill |
US20070235533A1 (en) | 2006-04-08 | 2007-10-11 | Advanced Payment Products, Llc | System and/or method for self-serve purchases |
US7756745B2 (en) | 2006-04-18 | 2010-07-13 | Qsr Automations, Inc. | Method for accurately quoting wait time for a restaurant table |
US8190483B2 (en) | 2006-05-02 | 2012-05-29 | Nextep Systems, Inc. | Computer-based ordering system |
US7644042B2 (en) | 2006-06-30 | 2010-01-05 | Amazon Technologies, Inc. | Managing transaction accounts |
US10607435B2 (en) | 2007-04-11 | 2020-03-31 | Cfph, Llc | Game of chance display |
US8370207B2 (en) | 2006-12-30 | 2013-02-05 | Red Dot Square Solutions Limited | Virtual reality system including smart objects |
US20100010906A1 (en) | 2007-01-23 | 2010-01-14 | William Grecia | Point of sale payment method for multiple recipients using a digital payment service |
WO2008111426A1 (en) | 2007-03-05 | 2008-09-18 | National Institute Of Information And Communications Technology | Multiple-viewing-point aerial video display element |
US20130290172A1 (en) | 2007-04-02 | 2013-10-31 | Alex Mashinsky | System and method for crowdsourcing, selecting, transacting gifts and financial discounts in physical stores and e-commerce environments |
US20080270230A1 (en) | 2007-04-27 | 2008-10-30 | Bradley Marshall Hendrickson | System and method for improving customer wait time, customer service, and marketing efficiency in the restaurant, retail, travel, and entertainment industries |
US9342823B2 (en) | 2007-06-18 | 2016-05-17 | Lemon, Inc. | Payment clearing network for electronic financial transactions and related personal financial transaction device |
US10068225B2 (en) * | 2007-08-18 | 2018-09-04 | Espensify, Inc. | System and method for utilizing a universal prepaid card |
US20090063312A1 (en) | 2007-08-28 | 2009-03-05 | Hurst Douglas J | Method and System for Processing Secure Wireless Payment Transactions and for Providing a Virtual Terminal for Merchant Processing of Such Transactions |
US20090070691A1 (en) | 2007-09-12 | 2009-03-12 | Devicefidelity, Inc. | Presenting web pages through mobile host devices |
US20090083069A1 (en) | 2007-09-21 | 2009-03-26 | Mpay Gateway. Inc. | Medical payment system with delayed settlement |
US20090094123A1 (en) | 2007-10-03 | 2009-04-09 | Patrick Killian | Payment services provider methods in connection with personalized payments system |
US9799028B2 (en) | 2007-11-30 | 2017-10-24 | U.S. Bank National Association | Seller routing arrangements and methods for disparate network systems |
JP5662632B2 (en) | 2008-01-29 | 2015-02-04 | インターナショナル・ビジネス・マシーンズ・コーポレーションInternational Business Machines Corporation | Electronic payment system, portable terminal, electronic payment terminal, electronic payment method, and computer program |
US20090240624A1 (en) | 2008-03-20 | 2009-09-24 | Modasolutions Corporation | Risk detection and assessment of cash payment for electronic purchase transactions |
US8738451B2 (en) * | 2008-04-04 | 2014-05-27 | Metabank | System, program product, and method for debit card and checking account autodraw |
US9444932B2 (en) | 2008-07-21 | 2016-09-13 | Tillster, Inc. | System and method of providing digital media management in a quick service restaurant environment |
US8977567B2 (en) * | 2008-09-22 | 2015-03-10 | Visa International Service Association | Recordation of electronic payment transaction information |
US20100088207A1 (en) | 2008-09-25 | 2010-04-08 | Mastercard International Incorporated | Method and System for Linkage of Generally Available Healthcare Accounts to Credit Card |
GB2466810A (en) | 2009-01-08 | 2010-07-14 | Visa Europe Ltd | Processing payment authorisation requests |
US9569768B2 (en) | 2009-02-20 | 2017-02-14 | First Data Corporation | Systems, methods and apparatus for selecting a payment account for a payment transaction |
CA2753576A1 (en) | 2009-02-25 | 2010-09-02 | Miri Systems, Llc | Payment system and method |
US20110087592A1 (en) | 2009-10-13 | 2011-04-14 | Van Der Veen Larry | Systems and methods for facilitating transactions |
US9195982B2 (en) * | 2010-02-04 | 2015-11-24 | Rick N. Orr | System and method for interfacing a client device with a point of sale system |
US9965755B2 (en) * | 2011-02-28 | 2018-05-08 | Shopkeep.Com, Inc. | System and method for remote management of sale transaction data |
US20150278789A1 (en) | 2010-03-02 | 2015-10-01 | Shopkeep.Com, Inc. | System and method for remote management of sale transaction data |
US8762207B2 (en) | 2010-03-15 | 2014-06-24 | Ncr Corporation | Apparatus, system and method for controlling the flow of customers |
US20130226805A1 (en) | 2010-04-01 | 2013-08-29 | Bank Of America Corporation | Protection for exceeding a credit threshold |
US20110251909A1 (en) | 2010-04-09 | 2011-10-13 | Clark Clark S | Credit card payment system for handling numerous payors |
US9400978B2 (en) | 2010-04-09 | 2016-07-26 | Paypal, Inc. | Methods and systems for selecting accounts and offers in payment transactions |
US8380177B2 (en) | 2010-04-09 | 2013-02-19 | Paydiant, Inc. | Mobile phone payment processing methods and systems |
US20110288967A1 (en) | 2010-05-20 | 2011-11-24 | Bank Of America Corporation | Card-Based Banking |
WO2012006098A2 (en) | 2010-06-28 | 2012-01-12 | Vivotech Inc. | Methods, systems, and computer readable media for facilitating in-store or near-store ordering and payment of goods and services through a single-tap of a near field communication (nfc) device |
US20110320345A1 (en) | 2010-06-29 | 2011-12-29 | Ebay, Inc. | Smart wallet |
US8799037B2 (en) | 2010-10-14 | 2014-08-05 | Palto Alto Research Center Incorporated | Computer-implemented system and method for managing motor vehicle parking reservations |
US8676708B1 (en) | 2010-10-29 | 2014-03-18 | Aton Behavioral Finance, LLC | Methods and apparatus for facilitating a financial transaction |
US8831677B2 (en) * | 2010-11-17 | 2014-09-09 | Antony-Euclid C. Villa-Real | Customer-controlled instant-response anti-fraud/anti-identity theft devices (with true-personal identity verification), method and systems for secured global applications in personal/business e-banking, e-commerce, e-medical/health insurance checker, e-education/research/invention, e-disaster advisor, e-immigration, e-airport/aircraft security, e-military/e-law enforcement, with or without NFC component and system, with cellular/satellite phone/internet/multi-media functions |
US20120130899A1 (en) | 2010-11-18 | 2012-05-24 | Mcmonagle Patrick Shawn | Check21 processing of non-dda transactions |
US10043209B2 (en) * | 2010-11-19 | 2018-08-07 | Mastercard International Incorporated | Method and system for consumer transactions using voice or human based gesture actions |
US20120130787A1 (en) | 2010-11-24 | 2012-05-24 | Grodo, Inc. | Multi-Purse Prepaid Consumer Discount Card Systems and Methods |
US8626597B2 (en) | 2010-11-30 | 2014-01-07 | Verizon Patent And Licensing Inc. | Automatic tab payment from a user device |
US20120173350A1 (en) | 2011-01-04 | 2012-07-05 | Doug Robson | Mobile application facilitating restaurant activities and methods thereof |
CN109118199A (en) | 2011-02-16 | 2019-01-01 | 维萨国际服务协会 | Snap mobile payment device, method and system |
CA2828107C (en) | 2011-02-25 | 2015-09-08 | Store Financial Services, Llc | Method and system for activation and funding of prepaid card accounts within a restricted authorization network |
US9043217B2 (en) | 2011-03-31 | 2015-05-26 | HealthSpot Inc. | Medical kiosk and method of use |
US10089701B2 (en) | 2011-05-10 | 2018-10-02 | Restaurant Revolution Technologies, Inc. | Systems and methods for take-out order sharing |
US9842342B2 (en) | 2011-05-10 | 2017-12-12 | Restaurant Revolution Technologies, Inc. | Systems and methods for take-out order analytics |
WO2012167165A2 (en) | 2011-06-01 | 2012-12-06 | Visa International Service Association | Account linking system and method |
US9218413B2 (en) | 2011-06-13 | 2015-12-22 | Opus Deli, Inc. | Venue-related multi-media management, streaming, online ticketing, and electronic commerce techniques implemented via computer networks and mobile devices |
US8856170B2 (en) | 2012-06-13 | 2014-10-07 | Opus Deli, Inc. | Bandscanner, multi-media management, streaming, and electronic commerce techniques implemented over a computer network |
US9734463B2 (en) | 2015-12-21 | 2017-08-15 | Opus Deli, Inc. | Automated, conditional event ticketing, reservation, and promotion techniques implemented over computer networks |
US9349108B2 (en) | 2011-06-13 | 2016-05-24 | Opus Deli, Inc. | Automated, conditional event ticketing and reservation techniques implemented over a computer network |
US8732193B2 (en) | 2011-06-13 | 2014-05-20 | Opus Deli, Inc. | Multi-media management and streaming techniques implemented over a computer network |
US8700659B2 (en) | 2012-06-13 | 2014-04-15 | Opus Deli, Inc. | Venue-related multi-media management, streaming, and electronic commerce techniques implemented via computer networks and mobile devices |
US9582598B2 (en) * | 2011-07-05 | 2017-02-28 | Visa International Service Association | Hybrid applications utilizing distributed models and views apparatuses, methods and systems |
US8694456B2 (en) | 2011-08-19 | 2014-04-08 | Bank Of America Corporation | Predicting future travel based on a user's historical financial institution transaction data and providing offers based on the predicted future travel |
EP2751754A4 (en) * | 2011-08-30 | 2015-06-03 | C Douglas Yeager | Systems and methods for authorizing a transaction with an unexpected cryptogram |
WO2013036850A2 (en) | 2011-09-09 | 2013-03-14 | University Of Massachusetts | Modulation of midbody derivatives |
DE202012100620U1 (en) | 2011-11-22 | 2012-06-13 | Square, Inc. | System for processing cardless payment transactions |
US9355470B2 (en) | 2011-11-30 | 2016-05-31 | The Board Of Trustees Of The Leland Stanford Junior University | Method and system for interactive layout |
US9515999B2 (en) | 2011-12-21 | 2016-12-06 | Ssh Communications Security Oyj | Automated access, key, certificate, and credential management |
WO2013098661A1 (en) | 2011-12-29 | 2013-07-04 | Bhatia Shashank | Collaborative, improved system and method for processing commercial transactions |
US9477995B2 (en) | 2012-03-04 | 2016-10-25 | Quick Check Ltd. | System, device, and method of electronic payment |
US9633344B2 (en) * | 2012-03-04 | 2017-04-25 | Quick Check Ltd. | Device, system, and method of electronic payment |
US10147130B2 (en) | 2012-09-27 | 2018-12-04 | Groupon, Inc. | Online ordering for in-shop service |
US8799111B2 (en) | 2012-05-04 | 2014-08-05 | Nintendo Of America Inc. | Systems and/or methods for selling non-inventory items at point-of-sale (POS) locations |
US20130304559A1 (en) | 2012-05-09 | 2013-11-14 | Cashstar, Inc. | Systems, methods and devices for conducting transactions with portable electronic devices using virtual points |
US9972003B2 (en) | 2012-06-06 | 2018-05-15 | II Melvin B. Mooring | Pregame electronic commerce integrator |
US10134081B2 (en) | 2012-08-15 | 2018-11-20 | Visa International Service Association | Single order multiple payment processing |
US20140058902A1 (en) | 2012-08-21 | 2014-02-27 | Ovni, Inc. | Distributed system for remote ordering |
US9165276B2 (en) | 2012-08-31 | 2015-10-20 | Wal-Mart Stores, Inc. | Locating and organizing digital receipt data for use in in-store audits |
US8985464B2 (en) | 2012-10-08 | 2015-03-24 | Carlos Tovar | Payment card storage apparatus and tab management system |
US10108951B2 (en) | 2012-11-30 | 2018-10-23 | Walmart Apollo, Llc | Splitting a purchase among multiple parties using an electronic receipt after the transaction |
EP2763040A1 (en) * | 2013-02-04 | 2014-08-06 | Buhl Data Service GmbH | Intelligent automated online transaction system for automated interaction with online transaction web sites |
US20140279534A1 (en) | 2013-03-13 | 2014-09-18 | Capital One Financial Corporation | System and method for providing an account holder a notification |
US20140263622A1 (en) * | 2013-03-14 | 2014-09-18 | Blitzpay, Inc. | Methods and systems for authenticating a transaction with the use of a portable electronic device |
US9002584B2 (en) | 2013-03-19 | 2015-04-07 | Ford Global Technologies, Llc | Rain onset detection glazing auto-close |
US20140330654A1 (en) | 2013-05-02 | 2014-11-06 | Christopher Michael Turney | Payment of restaurant bills |
US20140351130A1 (en) | 2013-05-22 | 2014-11-27 | Tab Solutions, Llc | Multi-User Funding Sources |
US20140372300A1 (en) | 2013-06-14 | 2014-12-18 | Simon Blythe | Smart card electronic wallet system |
US9426183B2 (en) | 2013-07-28 | 2016-08-23 | Acceptto Corporation | Authentication policy orchestration for a user device |
US10628815B1 (en) | 2013-09-27 | 2020-04-21 | Groupon, Inc. | Systems and methods for programmatically grouping consumers |
US20150095225A1 (en) | 2013-10-02 | 2015-04-02 | Mastercard International Incorporated | Enabling synchronization between disparate payment account systems |
US9721314B2 (en) | 2013-10-28 | 2017-08-01 | Square, Inc. | Apportioning shared financial expenses |
US10319013B2 (en) | 2013-10-28 | 2019-06-11 | Square, Inc. | Electronic ordering system |
US9799380B2 (en) * | 2013-11-05 | 2017-10-24 | Google Inc. | Managing open tabs of an application |
US9799021B1 (en) | 2013-11-26 | 2017-10-24 | Square, Inc. | Tip processing at a point-of-sale system |
CA2932180A1 (en) | 2013-12-02 | 2015-06-11 | Wal-Mart Stores, Inc. | System and method for conducting a multi-channel order |
US10157380B2 (en) | 2013-12-19 | 2018-12-18 | Opentable, Inc. | Mobile payments integrated with a booking system |
US9875469B1 (en) | 2013-12-24 | 2018-01-23 | Square, Inc. | Bill splitting |
US10019149B2 (en) | 2014-01-07 | 2018-07-10 | Toshiba Global Commerce Solutions Holdings Corporation | Systems and methods for implementing retail processes based on machine-readable images and user gestures |
US10783595B2 (en) | 2014-01-24 | 2020-09-22 | Tillster, Inc. | System and method for a wireless mobile device interface integrated with a restaurant point of sale system and with a cloud-accessible data center for querying a database of customer information |
US9311639B2 (en) * | 2014-02-11 | 2016-04-12 | Digimarc Corporation | Methods, apparatus and arrangements for device to device communication |
CA2883039C (en) | 2014-02-25 | 2017-04-18 | The Toronto-Dominion Bank | Remote synchronization of pin-pad records with a central transactions database |
US9817646B1 (en) | 2014-03-17 | 2017-11-14 | Google Llc | Multiplatform and multichannel distribution of web applications across devices |
US9824408B2 (en) * | 2014-03-31 | 2017-11-21 | Monticello Enterprises LLC | Browser payment request API |
US20150287006A1 (en) | 2014-04-08 | 2015-10-08 | Clipp Pty Ltd | Tab Management Method And Apparatus |
WO2015168128A1 (en) | 2014-04-28 | 2015-11-05 | Reserve Media, Inc. | System and method for bill splitting |
US9922324B2 (en) | 2014-05-21 | 2018-03-20 | Square, Inc. | Verified purchasing by email |
US10055722B1 (en) | 2014-05-21 | 2018-08-21 | Square, Inc. | Transitioning point-of-sale devices between modes |
US10007953B1 (en) | 2014-07-17 | 2018-06-26 | Square, Inc. | Fund withholding for payroll payments |
US9666023B2 (en) * | 2014-07-18 | 2017-05-30 | Scientific Games International, Inc. | Logistics methods for processing lottery and contest tickets with generic hardware |
US9582797B1 (en) | 2014-08-15 | 2017-02-28 | Square, Inc. | Dynamic adjustment of item fulfillment times |
AU2015342727B2 (en) | 2014-11-07 | 2020-07-02 | Breville Pty Limited | Food and beverage preparation sequence recording and playback |
US9699610B1 (en) | 2014-12-26 | 2017-07-04 | Groupon, Inc. | Location based discovery of real-time merchant device activity |
US9824394B1 (en) | 2015-02-06 | 2017-11-21 | Square, Inc. | Payment processor financing of customer purchases |
US10019698B1 (en) * | 2015-02-13 | 2018-07-10 | Square, Inc. | Merchant cash advance payment deferrals |
US9269103B1 (en) | 2015-02-19 | 2016-02-23 | Square, Inc. | Combining orders for delivery |
US20160247113A1 (en) | 2015-02-23 | 2016-08-25 | Flybuy Technologies, Inc. | Systems and methods for servicing curb-side deliveries |
US10410188B2 (en) | 2015-03-11 | 2019-09-10 | Ntn Buzztime, Inc. | Electronic check splitting system, method and apparatus |
US10043162B1 (en) | 2015-03-31 | 2018-08-07 | Square, Inc. | Open ticket payment handling with bill splitting |
US10528945B1 (en) | 2015-03-31 | 2020-01-07 | Square, Inc. | Open ticket payment handling with incremental authorization |
US10147079B2 (en) | 2015-04-14 | 2018-12-04 | Square, Inc. | Open ticket payment handling with offline mode |
US20160353235A1 (en) | 2015-06-01 | 2016-12-01 | Accenture Global Services Limited | Location-based order recommendations |
US9442377B1 (en) * | 2015-06-15 | 2016-09-13 | Rohm And Haas Electronic Materials Llc | Wet-strippable silicon-containing antireflectant |
US10210569B1 (en) * | 2015-06-23 | 2019-02-19 | Square, Inc. | Encouraging spending goals and discouraging impulse purchases |
US11481750B2 (en) * | 2015-06-30 | 2022-10-25 | Block, Inc. | Pairing a payment object reader with a point-of-sale terminal |
US10402920B2 (en) | 2015-07-13 | 2019-09-03 | David C. Fox | Order management system and process for drive-through and pickup window restaurants |
US10049349B1 (en) | 2015-09-29 | 2018-08-14 | Square, Inc. | Processing electronic payment transactions in offline-mode |
US10043149B1 (en) | 2015-09-30 | 2018-08-07 | Square, Inc. | Add-on orders for delivery |
US9569757B1 (en) * | 2015-09-30 | 2017-02-14 | Square, Inc. | Anticipatory creation of point-of-sale data structures |
US10319042B2 (en) * | 2015-10-20 | 2019-06-11 | Mastercard International Incorporated | Computerized-methods and systems for identifying duplicate entries in a database of merchant data |
US20170124671A1 (en) * | 2015-11-03 | 2017-05-04 | Transportation Technology Partners L.L.C. | Systems and methods for transit-related transactions |
US9824233B2 (en) | 2015-11-17 | 2017-11-21 | International Business Machines Corporation | Posixly secure open and access files by inode number |
US20170161851A1 (en) | 2015-12-08 | 2017-06-08 | Toast, Inc. | Restaurant Notification System |
US10607200B2 (en) | 2015-12-28 | 2020-03-31 | Square, Inc. | Point of sale system having a customer terminal and a merchant terminal |
US11151528B2 (en) | 2015-12-31 | 2021-10-19 | Square, Inc. | Customer-based suggesting for ticket splitting |
US10078820B2 (en) | 2015-12-31 | 2018-09-18 | Square, Inc. | Split ticket handling |
US10853835B2 (en) | 2016-01-04 | 2020-12-01 | Scvngr, Inc. | Payment system with item-level promotional campaigns redeemable automatically at point-of-sale devices |
US9811838B1 (en) | 2016-03-16 | 2017-11-07 | Square, Inc. | Utilizing a computing system to batch deliveries for logistical efficiency |
US10313383B2 (en) * | 2016-06-01 | 2019-06-04 | Mastercard International Incorporated | Systems and methods for use in evaluating vulnerability risks associated with payment applications |
US10289991B1 (en) * | 2016-06-13 | 2019-05-14 | Square, Inc. | Utilizing APIs to facilitate open ticket synchronization |
US10289992B1 (en) * | 2016-06-17 | 2019-05-14 | Square, Inc. | Kitchen display interfaces with in flight capabilities |
US10311420B1 (en) | 2016-06-17 | 2019-06-04 | Square, Inc. | Synchronizing open ticket functionality with kitchen display systems |
US10360648B1 (en) | 2016-06-22 | 2019-07-23 | Square, Inc. | Synchronizing KDS functionality with POS waitlist generation |
US10346605B2 (en) * | 2016-06-28 | 2019-07-09 | Paypal, Inc. | Visual data processing of response images for authentication |
US9785930B1 (en) | 2016-06-29 | 2017-10-10 | Square, Inc. | Expedited processing of electronic payment transactions |
US9934784B2 (en) * | 2016-06-30 | 2018-04-03 | Paypal, Inc. | Voice data processor for distinguishing multiple voice inputs |
US10762482B2 (en) | 2016-09-29 | 2020-09-01 | Square, Inc. | Centralized restaurant management |
US10546344B2 (en) | 2016-09-29 | 2020-01-28 | Square, Inc. | Dynamically modifiable user interface |
US10255645B1 (en) | 2016-12-22 | 2019-04-09 | Worldpay, Llc | Systems and methods for personalized dining checks and individualized payment by associating device with dining session |
US10327583B2 (en) | 2017-03-06 | 2019-06-25 | Keenwawa, Inc. | Automatic food preparation apparatus |
KR102396801B1 (en) | 2017-03-23 | 2022-05-13 | 십일번가 주식회사 | System of providing product information using copy/paste function of electronic commerce shopping cart, method thereof and computer readable medium having computer program recorded thereon |
US10467559B1 (en) | 2017-09-29 | 2019-11-05 | Square, Inc. | Order fulfillment and tracking systems and methods |
US10019011B1 (en) | 2017-10-09 | 2018-07-10 | Uber Technologies, Inc. | Autonomous vehicles featuring machine-learned yield model |
US11449925B2 (en) | 2018-01-22 | 2022-09-20 | Taco Bell Corp. | Systems and methods for ordering graphical user interface |
US11138680B1 (en) | 2018-11-21 | 2021-10-05 | Square, Inc. | Updating menus based on predicted efficiencies |
US10915905B1 (en) | 2018-12-13 | 2021-02-09 | Square, Inc. | Batch-processing transactions in response to an event |
-
2016
- 2016-06-28 US US15/195,557 patent/US10580062B1/en active Active
-
2020
- 2020-03-02 US US16/807,036 patent/US11295371B2/en active Active
-
2022
- 2022-03-24 US US17/703,821 patent/US20220224309A1/en active Pending
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9430784B1 (en) * | 2012-03-30 | 2016-08-30 | David Frederick | System for E-commerce accessibility |
US20140164234A1 (en) * | 2012-12-12 | 2014-06-12 | Capital One Financial Corporation | Systems and methods for splitting a bill associated with a receipt |
US20160162889A1 (en) * | 2013-07-26 | 2016-06-09 | Visa International Service Association | Provisioning payment credentials to a consumer |
US9959529B1 (en) * | 2014-05-11 | 2018-05-01 | Square, Inc. | Open tab transactions |
US10026062B1 (en) * | 2015-06-04 | 2018-07-17 | Square, Inc. | Apparatuses, methods, and systems for generating interactive digital receipts |
US11295371B2 (en) * | 2016-06-28 | 2022-04-05 | Block, Inc. | Integrating predefined templates with open ticket functionality |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11847657B2 (en) | 2018-12-13 | 2023-12-19 | Block, Inc. | Batch-processing transactions in response to an event |
Also Published As
Publication number | Publication date |
---|---|
US10580062B1 (en) | 2020-03-03 |
US20200273086A1 (en) | 2020-08-27 |
US11295371B2 (en) | 2022-04-05 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11295371B2 (en) | Integrating predefined templates with open ticket functionality | |
US11017361B2 (en) | Reprogrammable point-of-sale transaction flows | |
US11151535B1 (en) | Utilizing APIs to facilitate open ticket synchronization | |
US11080666B2 (en) | Open ticket payment handling with bill splitting | |
US11182762B1 (en) | Synchronizing open ticket functionality with kitchen display systems | |
US10360648B1 (en) | Synchronizing KDS functionality with POS waitlist generation | |
US10289992B1 (en) | Kitchen display interfaces with in flight capabilities | |
US12086860B2 (en) | Using data analysis to connect merchants | |
US10929822B2 (en) | Graphical user interfaces for facilitating end-to-end transactions on computing devices | |
US12118579B2 (en) | Systems and methods for rewards redemption ATM banners | |
AU2017301640B2 (en) | Reprogrammable point of sale transaction flows | |
US10496973B2 (en) | Reprogrammable point-of-sale transaction flows | |
US10872320B2 (en) | Reprogrammable point-of-sale transaction flows | |
CN116171449A (en) | Systems, methods, and computer program products for operating a group transaction network | |
US20180033014A1 (en) | Reprogrammable point-of-sale transaction flows | |
US20180032984A1 (en) | Reprogrammable point-of-sale transaction flows | |
US20200242578A1 (en) | System and method for generating cohorts | |
US20150286998A1 (en) | Methods and Systems for Facilitating Transactions | |
US20240378575A1 (en) | Graphical user interfaces for facilitating end-to-end transactions on computing devices | |
US20200193506A1 (en) | Systems and methods for generic digital wallet and remote ordering and payment |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: BLOCK, INC., CALIFORNIA Free format text: CHANGE OF NAME;ASSIGNOR:SQUARE, INC.;REEL/FRAME:059499/0476 Effective date: 20211209 Owner name: SQUARE, INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BELL, BRUCE;WILSON, MATHEW;ROCKLIN, WILLIAM;AND OTHERS;SIGNING DATES FROM 20160711 TO 20160812;REEL/FRAME:059395/0695 |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: NON FINAL ACTION MAILED |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER |