The Product Website Template by Conduction is a powerful tool designed to alleviate the common issue faced by many open source and Common Ground projects: the need for a dedicated product page and the cost (in time) to build one. This template enables users to quickly and easily set up a product page based on the contents of their repository without actually making a page.
The template is highly customizable, allowing users to style their product page using their organization's NL design token. This template maintains a consistent look and feel across all your products and services, reinforcing your brand identity.
One of the key advantages of this template is its simplicity. You can have a fully functional product page up and running in minutes without writing any additional code or documentation. This template saves time and makes it accessible to users with varying technical expertise.
Whether you're a seasoned developer or a newcomer to open-source projects, the Product Website Template is a valuable resource that can help you showcase your work professionally and appealingly.
- No coding needed just copy the workflow to your repository
- No server needed GitHub pages will host your site
- No content needed the page will use the documentation that you already have in your repository
- No maintenance or updates, the page will always fetch the latest version of your documentation
- Follows your organization's style; just use your existing NL Design tokens to style the page
All in all, it's a simple, quick, fire-and-forget solution for providing a simple product page that is always up-to-date.
-
Download the GitHub Workflow File Download the product page workflow file on GitHub. Download the file to your local machine. You can refer to the GitHub Actions documentation for more information on GitHub workflows.
-
Place the Workflow File in Your Repository
- In your browser, navigate to your repository. Inside the repository, look for a folder named
.github/workflows
. If it doesn't exist, create it. When in the folder, pressAdd file
(top-right corner ) copy, paste the content of theproduct-page-deploy.yml
into the edit screen, name the fileproduct-page-deploy.yml
and hit commit, and push - OR On your local machine, navigate to your repository. Inside the repository, look for a folder named
.github/workflows
. If it doesn't exist, create it. Place the downloaded workflow file into this folder. For more information on the structure of a GitHub repository, you can refer to the GitHub Docs.
- In your browser, navigate to your repository. Inside the repository, look for a folder named
-
Configure the Workflow File Open the workflow file in a text editor. Modify the configuration settings according to your needs. Be sure to save your changes. Refer to the GitHub Actions documentation for more information on configuring a workflow file.
-
Commit and Push the Workflow File to Your Repository Open a terminal and navigate to your repository. Use the following commands to add the workflow file to your repository, commit the changes, and push them to GitHub:
git add .github/workflows/product-page-deploy.yml git commit -m "Added workflow file for product page" git push
For more information on using Git, refer to the Git documentation.
If you don't have GitHub pages set up yet, follow the following steps:
-
Open your web browser and navigate to GitHub. Go to https://github.com.
-
Log in to your GitHub account. Click on the "Sign in" button in the top right corner of the page. Enter your username, email address, and password, then click "Sign in".
-
Navigate to the repository where you want to activate GitHub Pages. You can do this by clicking on the repository's name under "Your repositories" if it's a recent repository, or by clicking on "Repositories", then clicking on the repository's name.
-
Switch to the
gh-pages
branch. By default, GitHub shows themain
ormaster
branch of your repository. To switch to thegh-pages
branch, click on the "Branch" dropdown menu (it's usually a button with the name of the current branch, likemain
ormaster
), then select or typegh-pages
and hit Enter.If the
gh-pages
branch doesn't exist, you'll need to create it. Click on the "Branch" dropdown menu, typegh-pages
into the text box, and hit Enter. Confirm that you want to create a new branch namedgh-pages
. -
Activate GitHub Pages. Click on the "Settings" tab at the top of the repository. Scroll down to the "GitHub Pages" section. In the "Source" dropdown, select the
gh-pages
branch. For the folder, make sure it's set to "/ (root)". -
Save your changes. Click on the "Save" button to activate GitHub Pages.
-
Confirm that GitHub Pages is activated. After saving, scroll down to the "GitHub Pages" section again. You should see a message saying, "Your site is published at [link]", and your GitHub Page can be accessed at that link.
You can configure the Product Website template through the workflow YAML file, specifically via the environment (env) variables found within this YAML file. When you open this file, you'll notice the environment variables located at the top, which can be altered to suit your preferences. Any image URL you include here can also be a base-encoded image. The variables should appear in this format:
name: Deploy the Product Page to GitHub Pages
on:
push:
branches:
- main
- development
permissions:
contents: write
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Create the Product Page
uses: OpenCatalogi/productpage-action@latest
with:
# Connect Repository
github_repository_name_as_prefix: true
github_repository_name: ${{ github.event.repository.name }}
github_repository_url: ${{ github.event.repository.url }}
github_api_base_url: https://api.github.com/repos/${{ github.repository }}/contents
github_docs_directory_paths: '[{"name": "Features", "location": "/docs/features"}, {"name": "Roadmap", "location": "/docs/roadmap"}, {"name": "Usecases", "location": "/docs/usecases"}]'
pull_from_branche: "development"
# Links
slack_url: "false"
read_the_docs_url: "false"
# Navbar
navbar_content: "https://raw.githubusercontent.com/ConductionNL/product-website-template/main/pwa/src/templates/templateParts/header/HeaderContent.json"
# Footer
footer_show_logo: "true"
footer_logo_href: https://conduction.nl
footer_content: "https://raw.githubusercontent.com/ConductionNL/product-website-template/main/pwa/src/templates/templateParts/footer/FooterContent.json"
footer_content_header: "heading-3"
# Jumbotron
jumbotron_title: "Product Website Template"
jumbotron_subtitle: "Product page"
jumbotron_description: "Conduction's Product Website Template: a quick, customizable solution for creating dedicated product pages from repository contents, ideal for open-source projects."
jumbotron_image: "https://www.conduction.nl/wp-content/uploads/2021/07/cropped-Conduction_HOME_0000_afb1-1.png"
# Nl-Desgin Theme
nl_design_theme_classname: "conduction-theme"
# Other
favicon_image: ""
page_title: "Product Website Template"
We currently support the following configurations option's
Variable Name | Default Value | Optional Values and Their Use |
---|---|---|
github_repository_name |
${{ github.event.repository.name }} |
The name of the GitHub repository. |
github_repository_name_as_prefix |
true |
Uses the repository name as the Gatsby URL prefix, options: "true" or "false" |
github_repository_url |
${{ github.event.repository.url }} |
The URL of the GitHub repository. |
github_api_base_url |
https://api.github.com/repos/${{ github.repository }}/contents |
The base URL for the GitHub API. |
github_docs_directory_paths |
'[{"name": "Features", "location": "/docs/features"}, {"name": "Roadmap", "location": "/docs/roadmap"}, {"name": "Usecases", "location": "/docs/usecases"}]' |
The paths to the directories containing your documentation. |
pull_from_branche |
"development" |
The branche on witch to base the build e.g. main or development. |
slack_url |
"false" |
The URL for your Slack workspace. (set to "false" to omit Slack from your menu). |
read_the_docs_url |
"false" |
The URL for your Read the Docs documentation. (set to "false" to omit documentation from your menu). |
navbar_content |
"https://raw.githubusercontent.com/ConductionNL/product-website-template/main/pwa/src/templates/templateParts/header/HeaderContent.json" |
A link to the json file that manages the navbar content. |
footer_show_logo |
"true" |
Whether to show to logo in the footer or not. |
footer_logo_href |
"https://conduction.nl" |
The URL that the footer image will link to (set to blank to not link). |
footer_content |
"https://raw.githubusercontent.com/ConductionNL/product-website-template/main/pwa/src/templates/templateParts/footer/FooterContent.json" |
A link to the json file that manages the footer content. |
footer_content_header |
"heading-3" |
The heading size used in the footer ("heading-1" to "heading-5"). |
jumbotron_title |
"Product Website Template" |
The title on your jumbotron. |
jumbotron_subtitle |
${{ github.event.repository.url }} |
The subtitle on your jumbotron. |
jumbotron_description |
${{ github.event.repository.description }} |
The description on your jumbotron. |
jumbotron_image |
"https://www.conduction.nl/wp-content/uploads/2021/07/cropped-Conduction_HOME_0000_afb1-1.png" |
A base64 encoded SVG file or URL to the image used in the jumbotron. |
nl_design_theme_classname |
"conduction-theme" |
The class name for your NL Design theme. |
favicon_image |
"data:image/svg+xml;base64,..." |
A base64 encoded SVG file or URL to the image used as favicon. |
page_title |
"Product Page" |
The title of your page. The title of the page will always look like "PAGE_TITLE(Product Page)" | "{page_location}(Home)" |
By following the steps mentioned in this guide, anyone can leverage the power of GitHub to deploy an engaging and informative product page with just a few clicks. So, whether you want to display the features of your newest software or give an overview of your portfolio, our Product Website Template will equip you with the right tool for the job.
We are delighted to offer this template to the community, and we look forward to seeing the creative and innovative ways you will use it to present your projects.