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
困ったCSVファイルの話
mottyzzz
0
230
あの夜、私たちは「人間」に戻った。 ── 災害ユートピア、贈与、そしてアジャイルの再構築 / 20260108 Hiromitsu Akiba
shift_evolve
PRO
0
670
これまでのネットワーク運用を変えるかもしれないアプデをおさらい
hatahata021
2
150
Models vs Bounded Contexts for Domain Modularizati...
ewolff
0
190
業務の煩悩を祓うAI活用術108選 / AI 108 Usages
smartbank
9
22k
ALB「証明書上限問題」からの脱却
nishiokashinji
0
160
AI Agent Standards and Protocols: a Walkthrough of MCP, A2A, and more...
glaforge
0
290
純粋なイミュータブルモデルを設計してからイベントソーシングと組み合わせるDeciderの実践方法の紹介 /Introducing Decider Pattern with Event Sourcing
tomohisa
1
1.1k
Oracle Database@AWS:サービス概要のご紹介
oracle4engineer
PRO
2
880
20260114_データ横丁 新年LT大会:2026年の抱負
taromatsui_cccmkhd
0
250
ファインディにおけるフロントエンド技術選定の歴史
puku0x
2
1.5k
CQRS/ESになぜアクターモデルが必要なのか
j5ik2o
0
1k
Featured
See All Featured
Imperfection Machines: The Place of Print at Facebook
scottboms
269
13k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.6k
Test your architecture with Archunit
thirion
1
2.1k
Evolving SEO for Evolving Search Engines
ryanjones
0
99
Become a Pro
speakerdeck
PRO
31
5.8k
Measuring Dark Social's Impact On Conversion and Attribution
stephenakadiri
1
100
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
58
41k
Avoiding the “Bad Training, Faster” Trap in the Age of AI
tmiket
0
52
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
65
Making the Leap to Tech Lead
cromwellryan
135
9.7k
Leadership Guide Workshop - DevTernity 2021
reverentgeek
1
180
The Director’s Chair: Orchestrating AI for Truly Effective Learning
tmiket
1
76
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