Download presentation
Presentation is loading. Please wait.
Published byOwen Carter Modified over 9 years ago
2
Shopping Basket Stages to maintain shopping basket in framework Viewing Shopping Basket
3
First major step in effectively selling products online is the shopping basket It directly leads into the checkout process We will learn How to structure and create a shopping basket? How to manage the contents of the shopping basket? How to deal with a visitor signing up, and transferring their basket to their user accounts?
4
Shopping basket is first stage to enable online sale & purchase of products There are few others methods of online shopping than shopping basket One-Click Payments Service Subscription Payments Auctions
5
One-Click Payment Process A payment button on a product view Customer clicks on the payment button Take all of customer, product and payment data Their payment is processed Payment processor notifies the administrator of the product ▪ The customer, delivery details, and the amount paid After it, warehouse transfers the product to customer
6
One-click ordering makes things easier for the customer (Advantage) Reducing the need to go through an entire payment process Customers can easily order things by mistake (Disadvantage) Customers need to be sure their default delivery details are correct in advance It is not easy to add voucher codes without adding more clicks Discounts for multiple purchases Bundled shipping can't be taken into account Transaction charges will be applied on each transaction
7
Similar to one-click payment You first click on the subscription level, and then you pay Customer is charged based on his subscription level With a subscription payment method The transaction fees apply to less on regular and larger payments. For example, the customer may wish to make 25 purchases a month, and each purchase would not charged a transaction fee
8
Auctions lead to bidding for products Auctions involves The customer committing to purchase the product at a certain price And provided no other customer commits to a higher price within the auction time window Often, auction sites are automated The customer enters a maximum price over the duration of the auction The website will increase the customer's bid, with respect to their maximum bid when other bids comes in
9
If there is nothing in the customer's basket, show empty basket message if not empty basket if empty basket
10
If not empty, then list of items in basket
11
While creating a shopping basket, few considerations are taken into account Stock Level ▪ Sufficient stock Product Variations ▪ Different versions of a product Product Customization ▪ If customization allowed, record it Template ▪ No. of template to show empty, summary of basket etc. Subtotal ▪ Sub total of products in shopping basket
12
Our shopping basket will probably be stored on most pages Regardless of where a user is within the site Another consideration is with regards to user authentication The basket will be built in a different way We need to ensure we build the basket after any authentication processing is done
13
A single database table is required that relates these products to the customers Like standardized wish lists, we will build our shopping basket
15
Shopping basket should have following contents View the basket Add products to their basket Add customizable products to their basket Add variations of a product to their basket Edit quantities of products in their basket Remove any product from their basket We need our customers to allow to control contents of the basket
16
The following stages are involved in checking our shopping basket Select relevant data from the basket table in the database Build an array of data representing the contents of the basket Set some variables, including basket cost, empty check etc. Can a customer add a duplicate product in shopping basket? If Yes How to mange ?
17
We need a function to check and account the basket from all aspects Generate a number of variables to use later For authentication ▪ User's session ID and IP address, primarily for customers who are not logged in ▪ Username if user is authenticated and logged in Two different queries for authenticated and anonymous customers If no query result, basket is empty If there is query results, set values to generated variables
18
The controller will perform the following tasks at this stage Detect if the customer is trying to view the basket ▪ If customer click on basket icon or view basket option Get the basket contents from the model ▪ Build array of contents Cache basket contents and associate them with a template tag
19
What is needed to add a product in basket the product's ID number information of the user (User ID or Session data) As our basket will be maintained as an array product IDs acting as the keys other data such as price, name, quantity, and so on, acting as the elements
20
When a customer clicks on the Add to basket button on our store, what do we need to do? check that the product is valid and active check that it is not a customizable product, or product that has variations check to see if the product is already in the basket ▪ Yes, increment the product's quantity in the basket ▪ Default quantity is one ▪ Else, add it to the basket
21
Our controller needs to also: Detect if the customer is trying to add a product to the basket By clicking on an Add to basket button Without this, products would never be added to a customer's basket Pass data to the model to add a product to the basket Need to pass product ID and Customer ID
22
Display an error message to customer If product is invalid, inactive, not found or out of stock It helps customer to realize the product has not been added to their basket If the product was found, and was in stock Display a confirmation message to the customer the product has been added to their basket Redirect the customer to another page Basket page or product page
23
A note on etiquette When a customer adds products to their basket Add only what they add to their basket Some sites try to auto-select other products and into basket ▪ If product is unavailable, or due to promotions of product Results my be Customer unhappy Generate negative reviews about the site Damage the store's reputation
24
Customizable products, that allow customers to Upload files to associate with their product Enter text related to a number of fields associated with their product There are a number of things we need to do Restructure the basket database Change how we view the shopping basket Change how we add a product to the basket Process the customized information, if the product was customizable
25
To manage customizable products, we were added two filed in product table A filed to allow upload files A field to store custom text inputs Similarly, we restructure the basket database In our basket table we would add two fields A field to store the uploaded file A field to store the value of custom text input
26
Model needs to detect if the basket entry has A fie uploaded or A number of custom text submissions If not, Add product with basket array with ‘standard’ word as prefix If yes, Add product with basket array with ‘standard’ word as prefix Why we need this prefix in model To ensure when the customer clicks on Add to basket a second time We don't duplicate an existing product in the basket
27
Changes required to our model are: Check to see if the product is customizable If yes, process the product request differently Check to see if a file(image)is being uploaded If yes process it, else ask customer to upload it If the customer has chosen to upload a file Move it to suitable location & save its path in DB Check the uploaded file is valid If it is image then show its thumbnail
28
The product should be stored in the basket contents array with a prefix ‘standard_’ for standard products ‘customizable_’ for customizable product
29
Along with the features discussed above, controller needs to be: Display custom text inputs when viewing basket contents ▪ Customer can see which product in their basket has been customized Display an uploaded image ▪ Customer can see which product in their basket has been customized Display a link to download the file that has been uploaded ▪ Customer can verify that they had in fact uploaded the correct file
30
As discussed earlier, Product variant means a product with different sizes, colors, material etc. To manage different variants we need to change in the followings: A new table in the database Model changes Controller Changes
31
Following table is required in DB Following is the query to add table
32
Store products which have been added to the customer basket with prefix of ‘variation_’ With prefix and product ID, need to store a unique reference To indicate product is customizable Check if products in the basket have variations associated with them So that the details of the variant can be displayed When adding a product, check relevant POST data for variations that are being selected To determine which variations and attributes need to be stored
33
In addition to the features discussed our controllers needs to do: Display attributes from variations when viewing the basket So the customer is aware of exactly which products with which variant Can change the product quantities Can delete/remove a product from the basket
34
Shopping baskets need to be emptied, but this should be done only when: The customer wants to empty their basket The customer confirms an order The basket contents are old and are not tied to a customer account ▪ Known expired contents of basket ▪ If user IP is changed or session ID is changed as time changed
35
Most e-commerce websites display a small shopping basket on each page Often on top of the page or side of the page The aim is to: Reminding the customer how many products are in their basket The cost of the contents of their basket Providing a link for them to view their basket in detail Providing a link to checkout process
36
To display the basket on each page we will need: An empty basket template file If basket is empty, show suitable message A basket template file Display no. of products and link to cost, checkout process etc. A template tag in our main templates Where the basket can be inserted Something in our framework to link into the basket on each page
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.