Theme Development
The Convivio website uses a customised Ghost theme. This page sets out how to work on that theme.
Setting up for local development
Here's how to get set up with a local development installation of Ghost, ready for working on the development of our website theme.
Set up the tools
- Install Git
- Install Visual Studio Code
- Install Visual Studio Code command line tool (In VSC press F1 for the command palette. Type 'shell command' and select the option to install code command in PATH)
- Install Ghost extension for Visual Studio Code
- Install Gscan, a tool for validating themes:
npm i gscan -g
Install Ghost CLI
- Follow the instructions to install Ghost CLI, including its dependencies
- Continue to follow the instructions there to install Ghost locally. Do that in a sensible directory for you to access the files, eg ~/development/convivio-ghost. In the rest of these instructions we'll refer to this director as convivio-ghost.
- The command line output will give you a URL to access the development site.
- Check the site is working
Import the Convivio content
- In our live website, go to Settings>Labs. Next to 'Export your content' click Export and save the file locally
- In your local development version of Ghost go to Settings>Labs and click 'Open Importer'. Select the file you just downloaded from the live site
- After a few minutes check the frontend of the site to see that the content is now being shown (although the theme won't be right yet)
Install the Convivio Ghost theme
- Ensure you have access to the Github repo.
- Ensure your Github profile has SSH keys installed, or follow the instructions to set them up
- In Terminal, in the convivio-ghost directory, change to the themes directory:
cd content/themes/
- Clone the git repo for the theme into a new directory named 'banquet':
git clone git@github.com:ConvivioTeam/Convivio-Ghost-Banquet-Theme.git banquet
- Change to the new banquet directory:
cd banquet
- Install dependencies:
npm i
- Restart the ghost instance, so it discovers the new theme:
ghost restart
- Build the theme's static files:
npm run dev
- In the ghost admin user interface go to Settings>Design. In the bottom left click 'Change Theme'. In the top right click 'Advanced'.
- Click the 'Activate' button next to Banquet
- Go to the local site front end to check the theme is being used
Get Visual Studio Code set up
- Open Visual Studio code in the banquet directory:
code .
- From the 'Terminal' menu, choose 'Open New Terminal'. In normal development this is where you can issue the commands you'll need. But for now they are already running in the original terminal.
- You can choose to set up a workspace in VSC to save your configuration.
When finished
Once everything is set up and you're ready to stop:
- Return to the original terminal and press CTRL-C to stop the npm dev process watching the theme files
- Run
ghost stop
to stop the Ghost local server - Close the terminal, and close VSC.
Thats it, you're all set for any future work on the Convivio theme. You don't need to do the steps above each time. Just start from 'Working on the theme' below.
Working on the theme
Getting ready for development
- Open Visual Studio Code, choosing to open up the workspace or directory you had before.
- Use VSC's Source Control tab to Pull or Sync the latest version of the git repository
- In the VSC terminal type
cd .../.../.../
thenghost update
to update the Ghost install if there is a new version available. Then typecd content/themes/banquet
to return to the theme directory. - In the VSC terminal type
npm i
to update any dependencies - In the VSC terminal type
ghost start
, copy the URL it shows you - In the VSC terminal type
npm run dev
. That will build static copies of the theme files and watch for any changes you make in development, so the development site will always reflect your edits - In your browser, navigate to the URL that the Ghost Start command gave you.
- If it's been a while since you last used this install, or if there are very recent content changes you want to work on in the theme, you may want to reexport the content from the production site and reimport it to this local install. See 'Import the Convivio content' section above.
You're now ready to work on the theme.
Start a new branch
The main branch of the git repo is protected, meaning merges can only be made to it via pull request from another branch. So any changes you make need to be made in another branch.
- In VSCode's Source Control tab, select the 'Branches' vertical slider at the bottom.
- Click the + to create a new branch, using a naming format:
feature/some-feature-name-here
, such asfeature/add-playbook-sidebar
OR
- In the terminal, while in the main branch
git branch -m feature/some-feature-name-here
Now you're ready to make your edits, and view them in your local dev site.
Deploy your changes
Once you're happy with the changes:
- Use VSCode's Source Control tab to commit them to your feature branch (you should also do this part regularly while you are making changes, to have more atomic commits)
- Run Gscan, either from the VSCode command palette typing 'Gscan', or in the terminal with
npm run test
. Fix any issues that arise and commit any changes. - Increment the version number in the package.json file (at the time of writing, for example "version": "2.8.12")
- Run `
npm run build
- That creates a new Zip file for you, named for the version number The file is created in a dist folder in the banquet theme root (folder is made if it doesn’t exist already), so a build for v2.8.12 will be at ./dist/banquet-2.8.12.zip
- Upload this zip file to the live Convivio site at Settings>Design>Change Theme and activate it. Check everything works as expected on the live site.
- Do a final commit of changes to your branch
- Sync or Push to push the changed branch to the remote (or can do this in the Terminal with
git push -u origin feature/some-feature-name-here
) - Go to the Github repo to create a new pull request from your branch to main
- Review the Pull Request and merge it to main
- Back in VScode, switch to the main branch and do a Sync or Pull to ensure your main branch is up to date again
And now your changes have been made, committed to the codebase and deployed to the live site
Finishing up
Once your work is done and you're ready to stop:
- In the VSCode terminal, press CTRL-C to stop the npm dev process watching the theme files
- Run
ghost stop
to stop the Ghost local server - CLose the terminal, and close VSC.
- All done!
Advanced steps
Set up mail sending
In rare circumstances you may need to set up your local installation to be able to send emails for you to test, or to send you password resets.
In that case, follow these instructions (but thhey're normally not needed)
- Go to https://myaccount.google.com/apppasswords
- Enter your password for your Google account
- Select app, choose Other, and put the name (i.e "Ghost local dev install")
- Copy the displayed password and save it somewhere (you won't be able to view it again at Google). NOTE: it may copy with spaces in it, remove the spaces so you just have 16 characters.
- In the VSCode terminal for your theme folder, enter
code ../../../config.development.json
to open the config file for editing - Replace the existing "mail" section with the code shown below, changing the details for your email and password:
"mail": {
"transport": "SMTP",
"options": {
"host": "smtp.gmail.com",
"port": 587,
"auth": {
"user": "your@google.email",
"pass": "the app password you created"
}
}
},
Other useful information
- The essential concepts of Ghost theming
- The Convivio Ghost Theme Git repository (Includes a helpful readme)