Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Craft Commerce Workshop Peers 2016
Search
Luke Holder
April 13, 2017
Technology
0
51
Craft Commerce Workshop Peers 2016
Workshop given on Craft Commerce 1.1 by Luke Holder at Peers conference 2016
Luke Holder
April 13, 2017
Tweet
Share
More Decks by Luke Holder
See All by Luke Holder
Update on Craft Commerce
lukeholder
0
70
Future of Craft Commerce
lukeholder
0
340
Other Decks in Technology
See All in Technology
AI駆動開発を事業のコアに置く
tasukuonizawa
1
200
Frontier Agents (Kiro autonomous agent / AWS Security Agent / AWS DevOps Agent) の紹介
msysh
3
170
Claude_CodeでSEOを最適化する_AI_Ops_Community_Vol.2__マーケティングx_AIはここまで進化した.pdf
riku_423
2
570
インフラエンジニア必見!Kubernetesを用いたクラウドネイティブ設計ポイント大全
daitak
1
360
Data Hubグループ 紹介資料
sansan33
PRO
0
2.7k
AIエージェントを開発しよう!-AgentCore活用の勘所-
yukiogawa
0
170
小さく始めるBCP ― 多プロダクト環境で始める最初の一歩
kekke_n
1
420
Amazon S3 Vectorsを使って資格勉強用AIエージェントを構築してみた
usanchuu
3
450
Context Engineeringの取り組み
nutslove
0
350
今日から始めるAmazon Bedrock AgentCore
har1101
4
410
ファインディの横断SREがTakumi byGMOと取り組む、セキュリティと開発スピードの両立
rvirus0817
1
1.4k
登壇駆動学習のすすめ — CfPのネタの見つけ方と書くときに意識していること
bicstone
3
110
Featured
See All Featured
Navigating Weather and Climate Data
rabernat
0
110
Six Lessons from altMBA
skipperchong
29
4.1k
Agile Actions for Facilitating Distributed Teams - ADO2019
mkilby
0
110
Un-Boring Meetings
codingconduct
0
200
Joys of Absence: A Defence of Solitary Play
codingconduct
1
290
Marketing Yourself as an Engineer | Alaka | Gurzu
gurzu
0
130
Claude Code のすすめ
schroneko
67
210k
Odyssey Design
rkendrick25
PRO
1
500
Building AI with AI
inesmontani
PRO
1
700
4 Signs Your Business is Dying
shpigford
187
22k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.6k
Prompt Engineering for Job Search
mfonobong
0
160
Transcript
None
None
None
None
Outline • Core concepts • Initial setup • Front-end build-out
• Write a plugin
Core Concepts
Elements • Products • Variants • Orders
Products • Think “Entry” (URL, post date, localizable)
• Think “Section” • Product URL format • Title format
• Automatic SKU? • Dimensions? • Multiple variants? • Field layout(s) Product Types
Laptop Manufacturer Model number Product Type Examples T-shirt Brand Graphic
Product type != taxonomy
Variants • Provides different versions of a single product
Variant Examples Laptop CPU Memory Screen size T-shirt Color Size
All products have at least one variant
Default Variant Default Variant Product A Product B Default Variant
Default Variant Default Variant
Variants • SKU • Price • Stock
Purchasables • Variants are a type of purchasable • All
purchasables define a unique SKU and a price
Purchasable Possibilities • Digital products • Events/tickets • Bookings •
Gift vouchers • Donations
Cart / Order • Carts become Orders when completed. •
Completed is currently triggered when paid or authorized in full.
Orders Order Default Variant Default Variant Line Items Default Variant
Default Variant Transactions Default Variant Default Variant History Default Variant Default Variant Adjustments Status Purchasable
Line Items • Belong to an Order • Populated by
a Purchasable. • Costs added and subtracted by adjustments.
Adjustments • Affect costs in cart during recalculation. Core Adjusters
• Shipping • Discounts • Tax
Transactions • Financial records on the order Types • Payment
• Authorize only • Refund
Order Statuses • Define a custom order processing workflow •
A default status is assigned when an order is first completed
Order History • Status changes are recorded in the order’s
history, along with the reason for the change • Can optionally trigger an email to customer or administrator
Promotions • Sales • Discounts
Sales • Rules that affect a product’s price before it
is added to the cart
Discounts • Rules that affect a product’s price after it
has been added to the cart
Tax • Rules that affect taxes applied to the cart
Shipping • Rules that affect shipping costs applied to the
cart
Setup
General Setup
Order Fields Setup
Order Statuses Setup
Order Statuses Emails Setup
Order Status Emails Status Default Variant Default Variant Emails
Order Status Emails Status Default Variant Default Variant History Status
Tax Categories Setup
Payment Methods Setup
Product Types Setup
Tax Setup
Shipping Setup
Build
$ git clone http://github.com/lukeholder/peers
peers/style.css ➜ public peers/script.js ➜ public peers/_layout.html ➜ craft/templates/store
_layout.html
{% set cart = craft.commerce.cart %} Cart Once per page
but no penalty for multiple calls
{{ craft.session.getFlash('notice') }} {{ craft.session.getFlash('error') }} {% for key, error
in cart.allErrors %} <li>{{ error }}</li> {% endfor %} {% if cart.getErrors('email') %}email-error{% endif %} Notices & Errors
_products.html
{% set products = craft.commerce.products %} {% for product in
products %} {% for variant in product.variants %} Products
{% set purchasable = product.defaultVariant %} {% set purchasable =
product.variant[0] ?? null %} Products
{% set products = craft.commerce.products({ type: 'clothing', hasVariant: { color:
'red' } }) %} Only returns products that have a red variant. Variants
{% set products = craft.commerce.products({ type: 'clothing', with: ['variants'] })
%} Eager Loading
{% set products = craft.commerce.products({ type: 'clothing', with: [‘variants',{ color:
'red' }] }) %} Only populates variants that are red. Eager Loading
index.html {% extends 'store/_layout' %} {% block body %} {%
include 'store/_products' %} {% endblock %}
<form method="post"> <input type="hidden" name="action" value="commerce/cart/updateCart"> <input type="hidden" name="redirect" value="store">
<form> Update Cart
Adding to cart Update Cart purchasableId qty note options
Adding to cart <form method="post"> <input type="hidden" name="action" value="commerce/cart/updateCart"> <input
type="hidden" name="redirect" value="store"> <input type="hidden" name="qty" value="1"> <input name=“purchasableId" value="{{ variant.purchasableId }}"> <form> Update Cart
Options Update Cart <select name="options[giftWrapped]"> <option value="no">No gift wrap.</option> <option
value="yes">Gift wrapped.</option> </select> Note <input name=“note" value=""/>
Updating Addresses Update Cart shippingAddressId or new shippingAddress billingAddressId or
new billingAddress sameAddress
{{ variant.salePrice|currency(cart.currency) }} {{ variant.price }} Price
None
_cart.html
Cart Line Items {% for item in cart.lineItems %}
Line Items item.subtotalWithSale Subtotal of line item item.total Total cost
of line item including adjustments
_index.html {% if cart.lineItems|length %} {% include "store/_cart" %} {%
endif %}
Update Line Item <input name="action" value="commerce/cart/updateLineItem"/> <input name="lineItemId" value="{{ item.id
}}"/> qty note options
Remove Line Item <input name="action" value="commerce/cart/removeLineItem"/> <input name="lineItemId" value="{{ item.id
}}"/>
None
Adjustments {% for adjustment in cart.adjustments %}
_info.html
_index.html {% if cart.lineItems|length %} {% include "store/_info" %} {%
endif %}
Email Email defaults to logged in users email
_payment.html
Plugin
craft/plugins/merch/MerchPlugin.php
Order Number Generation
Options Validation
Address Validation
Stock Notifier
Thank you @lukeholder