Install the theme
Follow the steps below to upload the theme:
- Log in to your publication admin section at
yoursite.com/ghost/
- Go to Settings > Design (
yoursite.com/ghost/#/settings/design/
) - Click Change theme (
yoursite.com/ghost/#/settings/design/change-theme
) - Click Upload theme and select the
array.zip
file. - After the upload is complete, under Installed themes click Activate
Routes setup
Caution
For the theme to function properly you must upload the routes.yaml
file.
The file is located inside the array.zip
Follow the steps below to upload the routes.yaml
file (this is a separate step from theme upload)
- Log in to your publication admin section at
yoursite.com/ghost/
- Go to Settings > Labs (
yoursite.com/ghost/#/settings/labs
) - Under Beta features click on Upload routes file button and select the file from the root directory of the theme.
This is a testing ground for new or experimental features. They may change, break or inexplicably disappear at any time.
more info in the docs
Custom settings
The theme comes with custom design settings, which are accessible from the Ghost Admin panel.
To view and edit these settings go to Settings > Design & Branding ( yoursite.com/ghost/#/settings/design/
)
Custom settings are defined in the package.json
file.
These settings are placed under three categories:
- Site-wide settings
- Homepage settings
- Post settings
Here's a preview of the available settings:
Homepage
The homepage is defined by the home.hbs
file and it has several sections
based on your theme settings:
Note
Elements like the header and footer are included in all other templates (posts, pages)
Hero
The hero section is completely customizable from Settings > Design > Homepage, with the following options:
-
Hero headline - the hero section title
Here you can include HTML elements, so you can add links, or format texts. Example from the demo:
Navigating the exciting world of <a href="/tag/design/">design</a>, <mark>code</mark>, and <span><em>technology</em></span>.
-
Hero subheading - the hero section description
Here you can also use HTML elements like links, bold text, etc.
-
Hero subscribe - when enabled the subscribe form will be rendered for capturing emails
-
Hero background - the hero section background style, with the following options:
- accent-color - the brand accent color will be in the background with and svg pattern (
partials/hero-bg.hbs
) - publication-cover - the site cover image is used as background
- none - the default option
- accent-color - the brand accent color will be in the background with and svg pattern (
Tags section
By default the tags with the most articles will be rendered in this section, but you can feature specific tags. The featured tags can be set from Settings > Design & Branding > Homepage > Featured tags.
Example from the demo:
design,ui-ux,ar,vr,graphics,code,ai,gadgets,cloud
Important
Important: use the tag slugs separated by commas, and no spaces.
You can find the slug of a tag in your Admin > Tags, opening a specific tag and check the Slug field.
You can limit the number of tags from Settings > Design & Branding > Homepage > Tags limit:
3
6
9
12
18
30
all
The layout for the tags section can be set from Settings > Design & Branding > Homepage > Tags layout. The options are:
asymmetric-grid
- the default options which renders the tags in a 3 column grid with some offsets making the layout asymmetricbento-grid
- the tags are rendered in a bento style grid, some cards spanning an additional row or columnclassic-grid
- classic 3-column gridsections-with-posts
- each tag is rendered in it's own section including a maximum of 5 posts
Additionally, you can set the tag card background style from Settings > Design & Branding > Homepage > Tag card background. The options are:
accent-color
- the tag accent color is set as the backgroundaccent-color-pattern
- the default option, using the tag accent color as background with a geometric pattern appliedfeature-image
- the tag feature image is set as the background
Post feed
The logic and the layout is defined in the partials/post-feed.hbs
file.
The layout of the feed is based on what you set in Settings > Design & Branding > Homepage > Post feed layout.
and the possible values are 1-column
, 2-column
and 3-column
.
Note
This layout is used on the homepage for the latest section as well as the tag and author templates.
There is one additional setting for the homepage only, which lets you decide what the feed will render:
- latest posts
- featured posts
- none
Header
The header is defined in the partials/header.hbs
and it renders your publication
logo, primary navigation, the native search button.
Customizing options:
-
header primary navigation
- By default the header will include your primary navigation, but you can disable this, in case you prefer a minimal header. To change this go to Settings > Design & Branding > Site-wide > Header primary navigation -
header last nav item styled
- By default the header will include special styling for the last navigation item. To disable this special styling go to Settings > Design & Branding > Site-wide > Header last nav item styled
Footer
The footer is defined in the partials/footer.hbs
and it renders your publication
logo, site description, a subscribe form, primary & secondary navigation,
social links and finally copyright.
Post templates
The theme comes with 3 custom post templates, these templates can be selected from the Post Settings menu:
custom-post-with-narrow-feature-image.hbs
- a post template with a narrow feature image (same as the content)custom-post-with-no-feature-image.hbs
- a post template with a no feature imagecustom-post-with-wide-feature-image.hbs
- a post template with wide feature imagecustom-post-with-table-of-contents.hbs
- a post template with table of contents
Note
You can set one of the above templates as the default post template for your posts from Settings > Design & Branding > Post > Default post template
Custom templates
The theme comes with a couple of custom page templates, these templates can be selected from the Page Settings menu, under Template:
custom-template-membership.hbs
- select this to create a membership page including your tierscustom-template-signin.hbs
- select this to create a sign in pagecustom-template-signup.hbs
- select this to create a sign up pagecustom-template-tags.hbs
- select this to create a tags page - you can create multiple such pages
Custom collections
The theme comes with one custom collection: /archive/
, which lists all your posts.
To active it you must upload the routes.yaml file.
Setting meta data
Note
To control the meta data for this page you have to create a page in your admin with the same URL and add the data property in the routes file.
Here are the exact steps:
- Change the routes file and add the data property:
/archive/:
controller: channel
template: archive
data: page.archive
- Create a new page in your admin and make sure the page URL is
archive
- Re-upload the routes.yaml
Color customization
You can change the main accent color from Settings > Design > Brand. Additionally, under Settings > Design > Site-wide you can change three other colors:
- Background color - site wide background color
- Text color - used for most of the text
- Border color - used for elements which have border, for example the footer
With these options you can easily configure and set a custom color scheme. For specific examples and to play around with the options check out the demo https://array.brightthemes.com/colors/
Some useful tools for choosing colors and gradients:
Fonts
You can set the font family from the Admin section, going to Settings > Design > Site-wide. There are two options, one for the headings and another for the rest of the elements:
Headings font options:
- Arima
- Bricolage Grotesque
- Figtree
- Inter
- Kalnia
- Outfit
- Podkova
- Sen
- Syne
- Unbounded
- System - loads the system font (no requests to Google Fonts)
Body font options:
- Arima
- Bricolage Grotesque
- Figtree
- Inter
- Kalnia
- Outfit
- Podkova
- Sen
- Syne
- Unbounded
- System - loads the system font (no requests to Google Fonts)
Tip
With the System font option, you can avoid requests to the Google servers in case GDPR is a concern.
If you still want to use Google fonts and want to self-host the font files check out this guide for self-hosting Google Fonts.
Dropdown menus
array comes with a custom feature to create
dropdown menus easily for your header navigation. All you have to do is add the
minus sign (-
) in front of the items in Settings > Navigation
Items having the -
sign will be added as subitems to the previous navigation item.
For example from the demo:
- Membership
,- Sign up
and- Sign in
will belong to the Members item
Ghost config
Some configurations in Ghost themes can be defined in the package.json
file, including
Posts per page, Image sizes, and Custom settings.
Posts per page
The posts_per_page
defines the number of posts that appear in your collections until it's paginated.
For example, the value of posts_per_page
is used on the home page, tag, and author templates.
You can change it in the package.json
file:
"config": {
"posts_per_page": 12
}
Image sizes
Ghost can handle responsive image sizes,
and this is defined in the package.json
file, under the image_sizes
property.
You can change the default configuration by editing this file before uploading the theme.
"image_sizes": {
"xxs": {
"width": 30
},
"xs": {
"width": 100
},
"s": {
"width": 320
},
"m": {
"width": 640
},
"l": {
"width": 960
},
"xl": {
"width": 1280
},
"xxl": {
"width": 2000
}
}
The sizes defined will be used to generate copies of images at the specified sizes when uploading images in your Ghost Admin.
Comments
The theme uses the native Ghost comment feature. The Native Comment System requires at least Ghost v5.9.0, you have to enable it from Settings > Membership > Access > Commenting.
Here are the options you can choose from:
All members
- Logged-in membersPaid-members only
- Only logged-in members with an active subscriptionNobody
- Disable commenting completely
Icons
The icons used in the theme are from Tabler Icons, the library consists of 5000+ icons.
Only the icons used in the theme are included in the partials/icons
directory
in separate .hbs
files.
Here are the steps to add new icons:
- Go to Tabler Icons and click on the Icon you want to add, this will copy the code to your clipboard.
- Go into the
partials/icons
directory and create a new file:your-icon.hbs
- Open the new file and paste the copied code from the clipboard.
- Save the file.
For using the icons inside the theme files, there is a special partial file
partials/icon.hbs
which accepts name and size as parameters.
Let's see an example and try to add a new icon. Assuming we want to add the icon
camera
and by clicking on the icon on the website, we get this code:
<svg xmlns="http://www.w3.org/2000/svg" class="icon icon-tabler icon-tabler-camera" width="24" height="24" viewBox="0 0 24 24" strokeWidth="1.5" stroke="#2c3e50" fill="none" strokeLinecap="round" strokeLinejoin="round">
<path stroke="none" d="M0 0h24v24H0z" fill="none"/>
<path d="M5 7h1a2 2 0 0 0 2 -2a1 1 0 0 1 1 -1h6a1 1 0 0 1 1 1a2 2 0 0 0 2 2h1a2 2 0 0 1 2 2v9a2 2 0 0 1 -2 2h-14a2 2 0 0 1 -2 -2v-9a2 2 0 0 1 2 -2" />
<circle cx="12" cy="13" r="3" />
</svg>
The next step is to create a new file: partials/icons/camera.hbs
and paste the copied code in the file.
The new file must be of .hbs
type, so we can use it into the theme files:
{{>icon name="camera"}}
Social links
Social links are shown in the footer by default. The basic social links that Ghost comes with can be edited from Settings > General settings > Social accounts:
- X(Twitter)
The theme also comes with the following list of social platforms:
- threads
- discord
- github
- telegram
- tiktok
- youtube
To activate any of these platforms, add the following in your Admin Settings > Code Injection > Site footer. For example to activate GitHub:
<script>
socials.github = 'https://github.com/brightthemes'
</script>
Note
If you want to add a social that isn't listed, you have to add the corresponding
icon then modify the partials/social-links.hbs
file, adding the block
similar to the other platforms there.
Social sharing
Social sharing is part of the post layout and the following is included:
- X(Twitter)
- Copy to clipboard
To add other social sharing options you need to edit the partials/social-share.hbs
file.
Translations
By default, everything is in English (en.json
), additionally, the theme comes with translations in:
- 🇩🇪 German (
de.json
) - 🇪🇸 Spanish (
es.json
) - 🇫🇷 French (
fr.json
) - 🇮🇹 Italian (
it.json
) - 🇳🇱 Dutch (
nl.json
) - 🇵🇹 Portuguese (
pt.json
)
Note
For a translation to apply, you have to set the language in Settings > General Settings > Publication language.
If you want to edit the translation in a specific language, you have to edit the corresponding translation file.
The files are stored in the locales
directory (inside the theme zip).
|__ locales
| |__ de.json
| |__ en.json
| |__ es.json
| |__ fr.json
If the language file for your language doesn't exist, you have to create it (make sure to use the correct language code)
The best way is to copy the content en.json
file in your new language file, then change the translations.
Theme development
If you want to make more advanced changes to the theme, or you want to implement your own components, you can take advantage of the developer-friendly setup of the theme.
All the assets are combined and minified for better speed and performance. To customize the theme make sure you have Node.js installed.
The theme is built with TailwindCSS and Alpine.js. The development environment is based on Vite, the tasks can ran with npm scripts.
This guide is assuming that you have installed Ghost locally.
Add the theme directory inside Ghost's content/themes/
directory then move to the
theme directory in your command line. Run the npm install
command to install all
the dependencies.
After that is done, you have access to run the npm scripts:
-
npm run dev
(vite build --watch & vite
) The dev script will start the development process, watching for changes and building. Thevite.config.js
file contains the main configuration for Vite. -
npm run build
(vite build
) The build script will start the build process. -
npm run test
(gscan . --verbose
) The test will test the theme using gscan the official Ghost test tool. -
npm run zip
The zip script will create a zip file in thedist
directory.
Code Snippets
Frequently asked questions and useful snippets you can use to make some quick changes to your site.
How to change the logo size?
Go to the Admin, Settings > Code Injection and in the Site Header add, changing the values as needed:
<style>
:root {
--logo-h-mobile: 28px;
--logo-w-mobile: auto;
--logo-h-desktop: 32px;
--logo-w-desktop: auto;
}
</style>