Shopify integration (Debut theme)
This guide covers adding customizable products to a Shopify store by integrating jQuery widget to allow product customizations. We’ll use image processing operations to render resized image previews of your customized Shopify products.
We are using the Debut “vintage” theme in this guide. If you want to use the new Dawn theme, check the latest version of Shopify guide.
Shopify is an eCommerce platform that allows you to build online stores. However, you can add static item images only for your items. Uploadcare can help you create custom print sweatshirts, mugs with a logo, etc.
Specifically, we’ll be building a product page for a customizable poster print:
A user uploads an image of a future poster and will see a product preview updated in real-time. We have added a condition that if the user hasn’t selected an image, he will not be able to add the poster to the cart.
Let’s get started.
Before we begin
Make a Shopify account
If you don’t have one yet, create a Shopify account. It’s free for 14 days. We’ll go with the Debut theme (this is a “vintage” theme, so the templates for it are different for other themes), but you can pick anyone you like. 🦄
Create an Uploadcare account
Same here: if you aren’t with us yet, sign up. Once you have an account, navigate to your Dashboard to create a new Project or discover API keys for an existing one. To go through the steps of this guide, you will need the Public API Key, which tells Uploadcare which project your file uploads should go to.
All files added by users will be stored in Uploadcare storage. You can view them in the Dashboard on the File tab.
Step 1. Setting up the product
Navigate to the Shopify admin panel to create your product. Go to the Products section and hit the Add product button. Fill out all the necessary fields such as product name, description, price, etc. Now, let’s use Shopify’s built-in uploader to upload a product image.
Click Add media from URL and upload a poster template image from a URL or you can upload a picture directly.
Note that the product image must have a transparent area, which will be “filled” with the loaded image.
Fill in the inventory to add the item to the cart later. Also, make sure that Product Status is set to Active to appear in the store. Click Save to apply the changes.
Adding tags
Add a customizable
tag to the Tags field. If the product doesn’t
have a customizable
tag, the widget will not add to it.
Click Save to apply the changes.
Disable the image zoom effect
You’ll also need to disable the image zoom effect for the uploaded product pictures to ensure our customized products will work correctly. Go to the Online store → Theme → Сustomize. Instead of Home at the top of the page, select a Product. Hit Product pages in the sidebar and uncheck Enable image zoom. This way, Shopify won’t interfere with our upcoming image resize feature.
Disable cart notification
Go to the Online store → Theme → Сustomize. Instead of Home at the top of the page, select a Product, and hit Product pages in the sidebar. Hit at the bottom of the sidebar Theme settings and uncheck Show notification when item is added to cart.
We’ve just added a product to your shop! 🚀 Now, let’s make it customizable.
Step 2. Adding the Uploading Widget
Now, we’ll need some prints to customize. Your users will upload them, so we need to add the Uploading Widget by including the Uploadcare library.
Shopify allows modifying themes, so let’s add some code. It’s pretty simple:
go to the Online store, hit Themes, Customize, and select
Edit code in the menu on the top of the page. Create a new file in the
Snippets section. Name it uploadcare-settings.liquid
, and add the
uploader <script>
element followed by another element containing
your public API key:
Add another snippet named uploadcare-fields.liquid
. We’ll be adding
an <input>
element that’ll become the uploader button. Put the following
lines in the snippet:
As you see, our <input>
comes with some attributes. Here’s what they do:
data-images-only
tells the Uploading Widget to accept images only. See more about the images-only option.data-crop
defines the aspect ratio of the Uploading Widget crop option. Here we enable image cropping in the uploader withdata-crop="5:7"
. In this case, 5:7 represents the ratio of the transparent area in the product image template. It may be different for your product.name="properties[Upload]"
link the Uploader with a custom property namedUpload
. As a result, a CDN URL of the uploaded file will be saved on Shopify’s end and attached to the order. We’ll access it from within the Cart and other pages.
Add the following lines to the theme.liquid
file placed in the Layout
section right before the closing </head>
tag:
Discover the product-template.liquid
file under the Sections category,
find the <form>
element, and put the following somewhere within it:
We’re using the if
statement to render the uploader only on products
that have been tagged as customizable
.
In this example, we decided to put the snippet right before the variants selector dropdown like in the screenshot below:
There you go! You’ve just added the Uploading Widget to your product page. Users can now add their prints; our next step will show them a poster preview.
Step 3. Live product preview
Add settings that will allow us to preview our product to be generated once an image has been uploaded. We can accomplish that using some JavaScript and the jQuery widget API.
Create a new file in the Snippets section. Name it
uploadcare-customizable-product.liquid
, and add the <script>
:
Note that the class names of the elements in your theme may be different.
Use developer tools to find the actual selectors in your theme.
Also, the values of the backgroundSize
and backgroundPosition
parameters
need to be adjusted to your product image and the actual position and
size of the transparent area.
Add this snippet to product-template.liquid
. It’s better to place
it at the bottom before the schema
section:
Step 4. Preview in the cart
We stored CDN URLs of uploaded images in a dedicated property
and can render previews of customized products on the Cart page.
In cart-template.liquid
find the cart image wrapper.
In the Debut theme it looks like this:
Replace it with the following lines:
As a result, if there’s a URL in the Upload property, Shopify will
add it as a data attribute (data-image-upload) to the corresponding
preview image. Also, it will add the custom-product-preview
class
to this image. To make use of this attribute, we need to add some
JavaScript.
Create a new file in the Snippets section. Name it
uploadcare-cart-preview.liquid
, and add the <script>
:
The script will take all images of the custom-product-preview
class
and set the CDN URL from the data-image-upload attribute as
a background — the same as we did on the product page.
You can also apply the same changes to Shopify email templates, for instance, to the order confirmation email (Store settings → Notifications → Order confirmation).
Results
If everything is correct, your product page should now look like this:
You should now see the uploaded image and custom product fields:
Conclusion
Yay! You have just created a customizable product. The flexibility of Uploadcare is now enhancing your Shopify store.