How to Create a Customizable Logo Bar Section

How to Create a Customizable Logo Bar Section

Very often clients will want to highlight the businesses that they deal with and assert themselves as a trustworthy and in-demand company. One of the easiest ways to achieve this effect is with the use of a logo bar on their website.

As we learned in a previous Web Design and Development Blog post:

“Out of all the forms of social proof, perhaps none is as immediately impactful as including brand logos in the design of your ecommerce homepage.”

A highly visible, deliberately placed logo bar establishes credibility for your clients, and allows for brand storytelling through imagery, rather than text.

Logo bars can also be used on your own developer portfolio sites, as visual indicators of the services you provide. Theme developers Maestrooo use this technique to great effect on their site, displaying the different aspects of development they can assist with.

logo bar: maestrooo

In this article, I’ll demonstrate how to use Liquid to build a dynamic logo bar section, extending the functionality of your custom themes, or bespoke client work. I’ll also look at how Liquid’s section settings can be leveraged to allow customizable options, which empowers clients to personalize their online store.

Build themes for Shopify

When you sign up as a Shopify Partner, you get access to an unlimited number of free development stores, allowing you to test and tweak your themes as you build them.

Sign up today

Creating a custom logo section

The first step when creating a logo list is to decide what types of elements we would like to contain in this section. Depending on your client’s requirements you may need text, headings, or other input settings.

In this example, I’d like to include a section heading, and allow for hyperlinks to be associated with logo images. By using Liquid’s section objects, we can create settings which can be accessed from the Theme Editor to assign the heading text, link URLs, and choose which images we would like to appear.

Creating the heading text for our section is straightforward and demonstrates how we can link Liquid objects to section settings. For example, we can write markdown, which appears like this:

<h2>{{ section.settings.title | escape }}</h2>

Here we’re using the section object to create a property with the ID of title. When we create settings within the schema tags of the section, we can reference this ID and assign a specific type to this property. In this case we would like this to be a text box, so the type we assign is text. Once this is configured within the schema array, it would appear like this:

"type": "text",
"id": "title",
"label": "Heading",
"default": "Logo list"

Later when the section is set up correctly, clients will be able to navigate to the Theme Editor and assign a heading to this section. The heading will be a <h2> header and the escape Liquid filter is used to ensure the output will be outputted correctly.

Next we’ll need to use a mixture of Liquid logic tags, HTML, and block settings to build the code that displays the images themselves.

Since our logos will be blocks—meaning the images can be moved around within the section, as well as added and removed—we’ll be looping through section.blocks in order to output the block content. The whole for loop containing the logos can appear like this:

Within the for loop we see that each logo block will be a list item and the {{ block.shopify_attributes }} property is used by the theme editor to identify blocks and listen for events.

Similar to how the header was referenced within the schema tags earlier, we can use the block.settings property to create setting values by referencing the block's unique ID. For our purposes, the two key properties here are and block.settings.image, and the IDs we’ll reference are link and image.

When these properties are referenced within the schema tags of the section, and assigned the appropriate type, it will be possible for clients to upload images from the theme editor, as well as enter a URL that the image should link to. In this case, the array for the blocks would look like this:

As we can see above, the IDs we have used within the list item, image and link are associated with two block settings with types of image_picker and url. This will output as two separate settings for each specific logo block that’s added to the section. You can see how that would look like to a client below:

Since I would like this section to be available from the home page, I am going to add presets to the end to the schema array. When presets are present in a section, the theme editor recognizes that this section is a dynamic section and can be add to the home page.

Within the presets, I can assign a name for this section, and indicate which category this section should appear in. I can also set a default number of empty logo blocks that should appear, by adding in a separate array for each block—in this case I’ll add in four empty blocks.

Finally, we want to create a section setting that allows clients to adjust the size of the logos straight from the theme editor. To achieve this, we can link a section object with a CSS value within the section.

For example, my list item has a class of logo-bar-section, and if I add <style> tags within this section, I can add styles to this class. By assigning a Liquid section settings object as the value of max-width, I can create a variable which is controlled by section settings.

The styling within the section can appear like this:

.logo-bar-section {
max-width: {{ section.settings.logo_width }};
display: inline-block;

This means now that the value of max-width is determined by a Liquid section setting variable, and I can set up possible parameters within the section’s <schema> array. The ID for this section setting is logo_width, and I can use this ID to reference the section setting. Within the same array I can define what type of setting it is, and specify what options are available.

When this is all set up within the schema tags, the array can appear like this:

Here we are referencing the section setting object with an ID of "logo_width" which we can then assign different properties to. In this case I’m choosing a type of select, which generates a drop down box, where there are four available options, ranging from Extra Small to Extra Large.

The different options have labels, which appear on the theme editor, and pixel values, which are assigned to the associated CSS value when a specific option is selected. Now, when a client is customizing their logo bar, and selects ‘Large’, the value of 200px is assigned to the max-width property of the logo-bar-section list item.

logo bar: customize

Once we are finished, the entire section would appear like this:

Now when your clients are uploading logos they will be able to add a heading title, attach a hyperlink to the logo, and adjust the sizes of the logo. You can also get creative with other customizations, like adding a text overlay or a background color to the logo section.

You might also like: Understanding hreflang Tags for Multilingual Stores.

Connecting with logos

Creating a striking and well-positioned logo bar can highlight the various brands your clients work with, and boost their conversion by improving their social proof. As we’ve seen, theme sections can be leveraged to create intuitive logo bars that your clients can customize.

If you’re also designing logos for your clients, Hatchful is a really useful logo generator to consider. Hatchful is a mobile app built by Shopify for iOS and Android that helps you build a visual identity from scratch and right from the palm of your hand.

From there, you can customize your brand’s colors and fonts, and download all of the brand assets your clients need, including perfectly-sized images for all of their social media platforms.

Regardless of how you use logos in your custom theme builds, there’s no doubt that they’re a powerful tool for connecting with brands and customers. Hopefully with the help of this article, adding that extra value for clients will be a little bit easier.

Have you created a logo bar before? Tell us in the comments below!

About the Author

Liam is a Partner Education and Front End Developer Advocate at Shopify. He's passionate about promoting community engagement and developing learner resources. Whenever he’s not reading about code you can catch Liam making friends with cats and collecting records.

Grow your business with the Shopify Partner Program

Learn more