Skip to content
Snippets Groups Projects
Select Git revision
  • 714bb276e95e4a93853e7af3802a2c235e43eb4b
  • main default protected
  • renovate/main-ghcr.io-renovatebot-base-image-10.x
  • renovate/main-ghcr.io-containerbase-devcontainer-13.x
  • next
  • revert-31645-feat/rename-gradle-wrapper-validation-action
  • renovate/main-redis-5.x
  • fix/36615b-branch-reuse-no-cache
  • chore/punycode
  • fix/36615-branch-reuse-bug
  • refactor/pin-new-value
  • feat/36219--git-x509-signing
  • feat/structured-logger
  • hotfix/39.264.1
  • feat/skip-dangling
  • gh-readonly-queue/next/pr-36034-7a061c4ca1024a19e2c295d773d9642625d1c2be
  • hotfix/39.238.3
  • refactor/gitlab-auto-approve
  • feat/template-strings
  • gh-readonly-queue/next/pr-35654-137d934242c784e0c45d4b957362214f0eade1d7
  • fix/32307-global-extends-merging
  • 41.31.1
  • 41.31.0
  • 41.30.5
  • 41.30.4
  • 41.30.3
  • 41.30.2
  • 41.30.1
  • 41.30.0
  • 41.29.1
  • 41.29.0
  • 41.28.2
  • 41.28.1
  • 41.28.0
  • 41.27.1
  • 41.27.0
  • 41.26.2
  • 41.26.1
  • 41.26.0
  • 41.25.1
  • 41.25.0
41 results

update.spec.ts

Blame
  • gatsby-node.js 1.33 KiB
    'use strict'
    
    /*
     * Implement Gatsby's Node APIs in this file.
     *
     * See: https://www.gatsbyjs.org/docs/node-apis/
     */
    
    const fs = require('fs')
    const yaml = require('js-yaml')
    const envFlag = require('node-env-flag')
    
    const includeDevPages = envFlag(process.env.INCLUDE_DEV_PAGES, true)
    
    const { categories } = yaml.safeLoad(
      fs.readFileSync('./service-definitions.yml', 'utf8')
    )
    
    // Often in Gatsby context gets piped through GraphQL, but GraphQL adds
    // unnecessary complexity here, so this uses the programmatic API.
    // https://www.gatsbyjs.org/docs/using-gatsby-without-graphql/#the-approach-fetch-data-and-use-gatsbys-createpages-api
    async function createPages({ actions: { createPage } }) {
      if (includeDevPages) {
        createPage({
          path: '/dev/styles',
          component: require.resolve(
            './frontend/components/development/style-page.tsx'
          ),
        })
        createPage({
          path: '/dev/logos',
          component: require.resolve(
            './frontend/components/development/logo-page.tsx'
          ),
        })
      }
    
      categories.forEach(category => {
        const { id } = category
        createPage({
          path: `/category/${id}`,
          component: require.resolve('./frontend/components/main.tsx'),
          // `context` provided here becomes `props.pageContext` on the page.
          context: { category },
        })
      })
    }
    
    module.exports = { createPages }