/product-website-template

Conduction's Product Website Template: a quick, customizable solution for creating dedicated product pages from repository contents, ideal for open-source projects.

Primary LanguageTypeScript

Product Website Template

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.

Advantages

  • 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.

Using this template for your own GitHub repository

  1. 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.

  2. 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, press Add file (top-right corner ) copy, paste the content of the product-page-deploy.yml into the edit screen, name the file product-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.
  3. 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.

  4. 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:

  1. Open your web browser and navigate to GitHub. Go to https://github.com.

  2. 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".

  3. 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.

  4. Switch to the gh-pages branch. By default, GitHub shows the main or master branch of your repository. To switch to the gh-pages branch, click on the "Branch" dropdown menu (it's usually a button with the name of the current branch, like main or master), then select or type gh-pages and hit Enter.

    If the gh-pages branch doesn't exist, you'll need to create it. Click on the "Branch" dropdown menu, type gh-pages into the text box, and hit Enter. Confirm that you want to create a new branch named gh-pages.

  5. 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)".

  6. Save your changes. Click on the "Save" button to activate GitHub Pages.

  7. 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.

Configuration

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)"

Conclusion

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.