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
GitHub Issue Templates + Coding Agentで簡単みんなでIaC/Easy IaC for Everyone with GitHub Issue Templates + Coding Agent
aeonpeople
1
230
Red Hat OpenStack Services on OpenShift
tamemiya
0
110
Bill One 開発エンジニア 紹介資料
sansan33
PRO
5
17k
Bill One急成長の舞台裏 開発組織が直面した失敗と教訓
sansantech
PRO
2
380
ブロックテーマでサイトをリニューアルした話 / 2026-01-31 Kansai WordPress Meetup
torounit
0
470
Agile Leadership Summit Keynote 2026
m_seki
1
620
超初心者からでも大丈夫!オープンソース半導体の楽しみ方〜今こそ!オレオレチップをつくろう〜
keropiyo
0
110
モダンUIでフルサーバーレスなAIエージェントをAmplifyとCDKでサクッとデプロイしよう
minorun365
4
210
Digitization部 紹介資料
sansan33
PRO
1
6.8k
量子クラウドサービスの裏側 〜Deep Dive into OQTOPUS〜
oqtopus
0
120
【Oracle Cloud ウェビナー】[Oracle AI Database + AWS] Oracle Database@AWSで広がるクラウドの新たな選択肢とAI時代のデータ戦略
oracle4engineer
PRO
2
150
Kiro IDEのドキュメントを全部読んだので地味だけどちょっと嬉しい機能を紹介する
khmoryz
0
200
Featured
See All Featured
Bash Introduction
62gerente
615
210k
Deep Space Network (abreviated)
tonyrice
0
49
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
2.1k
ReactJS: Keep Simple. Everything can be a component!
pedronauck
666
130k
Believing is Seeing
oripsolob
1
55
The agentic SEO stack - context over prompts
schlessera
0
640
How to Talk to Developers About Accessibility
jct
2
130
Hiding What from Whom? A Critical Review of the History of Programming languages for Music
tomoyanonymous
2
420
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
1
53
Game over? The fight for quality and originality in the time of robots
wayneb77
1
120
Building a Scalable Design System with Sketch
lauravandoore
463
34k
Collaborative Software Design: How to facilitate domain modelling decisions
baasie
0
140
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