Creating custom templates
Creating custom templates
Introduction
Until now, you've learned how to use CSS, Tachyons, and Markdown in order to customize your blocks on Store Framework. However, it's also important to learn how to create custom templates, so your store can have custom landing pages, for example, with a well-defined URL and specific content to display.
Stores are made up of several different pages, each with a specific content and layout. When creating a store from scratch in VTEX IO, some default pages with preset URLs are already available. Below, we have a list of some of these default pages:
store.home
(Home page)store.product
(Product page)store.search
(Search Results page)store.account
(Client Account page)store.login
(Login page)store.orderplaced
(Order Placed page)
In this step, you'll learn how to create a custom template from scratch.
Creating a Landing Page
Just a few steps are needed to create a custom landing page:
- Create a new template in your store's theme
- Create a new path to access this template
Template
A template defines the page layout. However, if you want to create a custom page, you will also need to create a new template in your theme.
Let's imagine that you want to create a simple page containing information about your store. Inside the blocks
folder, you can create a file that would contain the following code, declaring a new template for a custom page,
{
"store.custom#{templatename}": {
"blocks": []
}
}
where {templateName}
must be replaced with the template's identifying name.
Then, you should fill in the code with the components needed to create the layout, this will be better shown in the activity.
Path
Now that a new template with the page layout has been defined in the store theme's code, the next step is to establish the page's page that would lead to this layout.
We must create a routes.json
file in your theme's store
folder. Afterwards, insert the code below,
{
"store.custom#about-us": {
"path": "/{URL}"
}
}
where {URL}
is the name of the desired path.
Creating a custom template
Let's create a page containing information about your store, as in the example below:
-
In the
blocks
folder, create a file calledabout-us.jsonc
; -
Declare a
store.custom#about-us
template in this file; -
Include a "flex-layout.row#about-us" block in this template:
{ "store.custom#about-us": { "blocks": ["flex-layout.row#about-us"] } }
-
In the same file, add the code block below, right afer the declaration of
store.custom#about-us
. It's responsible for definingflex-layout.row#about-us
."flex-layout.row#about-us": { "children": [ "image#about-us", "flex-layout.col#text-about-us" ] },
-
Now, let's define its children blocks in order to create the complete layout:
"flex-layout.col#text-about-us": { "children": [ "rich-text#about-title", "rich-text#about-content" ], "props": { "preventVerticalStretch": true } }, "rich-text#about-title": { "props": { "text": "# About Minimum Theme" } }, "rich-text#about-content": { "props": { "text": " This is the VTEX Minimum Theme, you can use it to test blocks usage and build your first store from scratch." } }, "image#about-us": { "props": { "src": "https://appliancetheme.vteximg.com.br/arquivos/cozinha-about-us.png", "maxHeight": "600px" } }
-
In the
store
folder, create a file calledroutes.json
; -
In this file, declare an
/about-us
path:{ "store.custom#about-us": { "path": "/about-us" } }
-
Once the code is linked, access
{workspace}--appliancetheme.myvtex.com/about-us
to see your new landing page.
Any questions?
See the answersheet for this step or check our [office hours] on the VTEX Developers channel(https://www.youtube.com/c/VTEXDevelopers)
Help us make this content better!
VTEX IO courses are open source. If you see something wrong, you can open a pull request!
Make a contributionUpdated 11 months ago