...
Date
...
...
Owner
...
Michal Wojtas, Antonio Elena
...
Intended audience
...
Partner agencies
Introduction
...
Info |
---|
This page and its sub-pages explain how to style content for a newly created |
...
Styla storefront. |
Introduction
Styla expects partners agencies to set up the styling for every new client during the onboarding phase, based on their the client's CI guides. This can be done via our account management tool - the Organization Manager.
Table of Contents | ||||
---|---|---|---|---|
|
Styling levels
Styling can be applied on several levels, depending on how specific a rule should be. Each of the levels inherits settings from its parent and can override them for its own scope.
...
Level | When to apply rules here: | |
---|---|---|
1 | Application defaults | These can only be changed by Styla developers by deploying changes to the Layout Engine (Styla front-endfrontend) project. If you create a new front storefront and don't configure any Theme or Module settings, every module will use these defaults. By configuring settings you override these. If you configure something in a wrong way, the application will probably fall back to these defaults. |
2 | Front Storefront | These are CSS and other settings influencing any piece of content you create for this frontstorefront. "frontA storefront" is Styla lingo for a store store’s or a locale locale’s frontend within an a client’s organization (client). If you change one of them in the future, the changes will be applied retroactively to any existing content. This CSS is fetched from the top-level settings every time a Styla page is requested. |
3 | Presets for Modules | If you want to use several style variants of a module, you can apply some changes with the Editor UI and then reuse the resulting preset for any module of the same type. Which means that by selecting a different preset from the dropdown in the "Settings" tab, a different set of CSS rules will be applied. You can also apply any CSS rule to any HTML node, even if there is no UI for it in the Editor. CSS from such preset will be merged into any other CSS applied for the module and override any module settings from the higher levels. If you update a preset itself, you need to reapply it to all modules you need the changes to be reflected on. Creating presets only makes sense if they really will be reused on multiple modules. |
4 | Module instance | You can apply CSS settings on a single module level as well - with the Editor UI or directly in the JSON editor. This makes sense if you only want the changes to be applied to one module and don't want to reuse them. |
Breakpoints
Any of the four levels rules above are applied to all view port widths and then can be overridden for mobile widths specifically.
...
You can apply any CSS property (not just widths, margins or font-sizes) to any Styla HTML element separately. This is in line with the Editor UI which lets users override certain settings from desktop on mobile.
Organization Manager (admin.styla.eu)
The Organization Manager tool in which you create new organizations, fronts storefronts and users, is also where you configure CSS per frontstorefront. You do this in the THEME SETTINGS and MODULE SETTINGS tabs:
...
Theme settings
This is where settings affecting any module are set. This includes typography, colours, sizes, gutters etc. They are inherited and can be modified on lower CSS levels.
Base unit:
Almost all sizes in this tab are defined in base unit which itself is defined in pixels. You define it by simply setting: "baseUnit": 10, on the highest JSON level. Setting it to 10 will make every other setting multiply its value by 10px. This way you can make every CSS property larger/smaller by changing this one setting. This will not be possible if you use px, rem, vw or any other CSS unit on a (lower) module level. These would keep their values in standard CSS units no matter what you change the base unit to.
Defaults: all: 8, smallScreen: 7
...
Defining fonts families:
Info |
---|
|
Styla can use external sources of font files to be loaded by Styla front-end frontend and Editor preview. Setting them up is only needed for displaying text with a specific font outside of the parent website. Styla content embedded on a website will use font files loaded by this website, so the only thing you need to set up for such case is proper font-family
rules.
...
The only thing you need is to set up a list of font names that will populate the font-family
CSS property in Styla front-endfrontend. They need to match font files loaded by the website or installed on user's machine, otherwise browser will fall back to whatever is defined in the fallback
field.
...
Info |
---|
The feature Flag |
Leading and line height
Instead of directly setting up font-size
and line-height
for each font format, Styla front-end frontend needs them to be configured in leading
and lineHeight
fields, which will result in the above CSS properties in pixels. It's done this way to enable baseUnit
changes influence any text size.
...
Info |
---|
Font formats
Once you've set up your font-families, you use them to set up font formats. These are typography definitions which you can reuse on any number of modules and presets by adding a "fonts.formats" : "formatName"
reference there. You can then update this format for all modules using it by changing its properties in Theme settings.
...
The bodyCopy
is the most important format and should always be defined. It is per default used for every module paragraph text and inherited by many other fields, for instance, price and product name fields in Product module.
...
Color
The same way you create font formats to be reused in many different modules, you configure colours to be able to reference their name and change them in Theme settings for any module using it. You set them up by giving them a name and then assigning a CSS hex or RGB scheme value.
...
Colours you define here can also be selected by users in the Editor in the "Advanced" tab for any module. Selecting them from the below dropdown list updates will apply a CSS property with this colour to a given HTML element.
...
Examples
The contrast
is per default used for all background elements and in 90% of cases will be white. The bodyCopy
will per default be applied to paragraph copy and in 90% of cases will be black or dark grey. Some other names like primary
or link
will also be automatically applied to some HTML elements in some modules unless you override them in module settings.
...
Expand | ||
---|---|---|
| ||
|
...
Max widths, page margins and gutters
Theme settings feature a property for setting a max-width for any Styla content (which will be used for the row "Default Width" in Editor) and a separate one for the "Smaller" width. These are set in pixels. "Full Bleed" will always use 100% of browser width unless Styla content sits in an external HTML that has its own width or margins/paddings set.
...
The smallScreenMaxWidth
sets the only breakpoint for Styla content, usually separating mobile phone layouts from any wider ones. You can modify it in Theme settings by setting a different pixel value if you want smallScreen
overrides to kick in on a lower or higher width. The default is 767px.
...
Other settings of importance
Quality compression for Images
imgixParams
- you can modify image compression across all pieces of content with it. The setting will be used by Styla's imgix account, which provides image analysis and manipulation. Useful if your client tells you the load sizes/times for Styla content are too big. The default is 45.
Using presets from other
...
storefronts
templateModuleIds
- this array holds references to preset modules that can be used by this frontstorefront. It is updated automatically every time you add a new preset in the presets management list in the Editor. You can add new IDs manually if you want a front storefront to use presets you've created for another one.
Max width for Texts
textMaxWidth
- this field sets a max-width
value (in base units) for the textWrapper
HTML div in which content of Text module sits. The default is 88.
Code Block |
---|
{ "gutters": { "textMaxWidth": 88 }, "imgixParams": { "q": 20 }, "templateModuleIds": [ 123565, 128574, 270166 ] } |
Info |
---|
There is a .json file with all the defaults for theme settings linked to on this page below. Download it to see how exactly the setting look like and modify them. |
...
Module Settings
Once Theme settings have been configured, you can start configuring Module settings. We recommend creating a page with each of the module types you or your client want to use in the future. This way you will see how each of them looks with only theme settings applied (typography, colours and spacings).
...
Remember that you can override every general setting from all
node in smallScreen
just for mobile views. Even without any explicit settings in smallScreen
most modules will look differently once you make you shrink your browser window below 767px as they inherit a set of CSS for this media query from default Layout Engine app settings. This is especially valid for Banner, Product and Editorial Shopping modules.
Naming convention and property values
CSS properties are represented by JSON nodes named after them, but written in camel cases. So, for instance, align-content
becomes alignContent
. Property values, however, stay as in CSS, so flex-start
does not change and if you want to set it, you write: "alignContent": "flex-start"
in module styles JSON.
...
Any JSON you enter into the Organization Manager or Editor will be validated before saving. If it's invalid the changes won't be saved and will be lost, so if you're planning to enter a big chunk of JSON into the editor, better validate it somewhere else beforehand or back it up. The best approach is small incremental changes.
...
App
This is where you set CSS properties that you want inherited to every other module. Examples would be: a background colour and some instructions for browsers on how to render fonts.
Expand | ||
---|---|---|
| ||
|
...
Banner
This is one of the most complex and definitely the most often used module. It consists of a text and buttons (in textLayer
container) and an image (in imageLayer
container).
Expand | ||
---|---|---|
| ||
|
...
Carousel Controls
This is a generic module reused for carousel arrows left and right on Product slider and Product Details modules. If you change settings here, they will be updated for both of them.
Expand | ||
---|---|---|
| ||
|
...
Divider / Section Title
This is the module used for graphically separating some other modules (groups) while not being semantically a headline. When updating its appearance, you should pay attention to Section Title too, where default font format will come from and whose module settings will influence it too.
Expand | ||
---|---|---|
| ||
|
...
Image
A simple module consisting of an image and caption text. Still, you can adjust typography or caption background for it.
Expand | ||
---|---|---|
| ||
|
...
Navigation
This module displays a list with relative or absolute links that you set in the Editor. As the Editor features a very advanced UI with which you can set colours, paddings, margins and flex box properties, make sure you only apply settings you always want inherited here (example: a font format).
Expand | ||
---|---|---|
| ||
|
...
Slider
This actually is not a module, but a set of row settings that lets you manage every new slider row created in the Editor. The most important is selecting between three types of navigation available and setting an animation delay.
...
Expand | ||
---|---|---|
| ||
|
...
Product details
This module consisting of a product slider, product text with multiple fields and a button.
...
Expand | ||
---|---|---|
| ||
|
...
Text
A very straightforward module consisting of a text field for which background and paddings can be customised with the Editor UI. Its width is per default set to 88 base units, which you can change in Theme settings.
Expand | ||
---|---|---|
| ||
|
...
Text on video
This module is a banner with an .mp4 video file in the background. Same as banner, it displays a text container with CTA buttons that can be customised with the Editor UI.
Expand | ||
---|---|---|
| ||
|
All the defaults and settings as .json files
In order to make working with Styla easier for you, we prepared some .json files with all the default theme and module settings and inline comments where needed. You can download them as a .zip pack below.
One pair of files is a valid JSON with all the defaults while the other one in addition contains comments hence does not validate but will probably be even module useful.
Download a .zip pack with examples here.
Info |
---|
There might still be some CSS classes not included in those files as the app sets no default properties for them and also the project evolves. The files are valid as of October 2021. |
Setting up Module Presets
If your client need several appearance variants of the same module and cannot achieve it with the default set of presets available for every client, you will need to create a set of custom presets for them.
As the Editor features a UI to create and manage such presets, clients themselves can create presets there. But the usual UI in the Editor does not enable them to apply any CSS property to any HTML element. Therefore, you will need to set up some more advanced things directly in module JSON data.
Here’s how you create a preset:
Log in as the target user/storefront, click your user name top-right, then "Preset Manager" on the overlay menu.
Click "the Create" button top-left of the list. Then select module type from the dropdown, fill in the new Preset's name and click "Create" bottom-right.
Configure any CSS properties you can with the usual Editor UI on the next screen and click "Save changes" top-right.
Anything you cannot configure with the UI, you need to enter into this module's styles JSON directly.
Click the "edit as JSON" button bottom-left or simply add /json to the page's URL and then add nodes for HTML elements and their CSS properties as you'd do in the storefront's Module settings.
Once you are done, save the changes and check desktop and module preview if the modules looks all right. You will probably need to go through several iterations.
Once this is done, the CSS and other settings from the preset you've just created can be applied to any other module of the same type with the "Presets" dropdown in the "Settings" tab. They will be saved in the "presets" node of its JSON data and merged to any other CSS it already has set. In case the same CSS property is set differently on both of them, the original settings in the module will prevail, being on a lower-level.
The preset that you've created will be available in the "Preset Manager" until you remove it. You can modify its JSON data and the changes will be reflected on any module you apply the preset to. The changes won't be automatically reflected on the modules you'd applied the preset to before. You'll need to re-apply it.
Info |
---|
Presets that you set in the way described above are added in the templateModuleIds JSON node in Theme settings, as in the example below: You can copy this into another storefront to reuse the presets. |