GitHub Pages is a popular hosting option for static sites. GitHub Pages can be configured in <your-repo> > Settings > Pages.
GitHub Pages offers a few build options:
We want to choose "GitHub Actions" so that we can control the build script, and make sure it's also building the TinaCMS admin
By clicking "Configure" on the action it's created for us, we can then tweak the build script to build tinacms along with our site.
Add the following step before your site's build step:
If you are using npm as your package name, you can use the following:
- name: Build TinaCMSenv:TINA_PUBLIC_CLIENT_ID: ${{ secrets.TINA_PUBLIC_CLIENT_ID }}TINA_TOKEN: ${{ secrets.TINA_TOKEN }}run: npx tinacms build
or if you are using yarn:
- name: Build TinaCMSenv:TINA_PUBLIC_CLIENT_ID: ${{ secrets.TINA_PUBLIC_CLIENT_ID }}TINA_TOKEN: ${{ secrets.TINA_TOKEN }}run: yarn build# This assumes that your "build" script in your# package.json is "tinacms build"
Your GitHub Action will look something like:
This error might occur from the following reasons:
Make sure that both the tinacms
& @tinacms/cli
dependencies are listed in your package.json.
If you are using npm make sure that npm ci
is being run before the TinaCMS build command. If you are using yarn, make sure you are running yarn install --frozen-lockfile
before running the build command.
If your CI is running something like yarn tinacms build
instead of npx tinacms build
, you'll need to add a custom script to your package.json:
"scripts": {"tinacms": "tinacms",// ...
This can happen for a number of reasons but here are the most common reasons and fixes:
If your site is deploying with GitHub Pages, it may be using GitHub's default build steps. In this case, TinaCMS won't be included in the build.
.
To fix this, you'll need to select the "GitHub Actions" source, and build the tinacms admin along with your site. You can see our doc above for help setting up this GitHub Action.
Check to make sure that the build command is running and not failing
Note: If you are using the github pages setup from hugo you will need to make sure that a package-lock.json
exists in the root of your repo.
This is usually due to a missing entrypoint file for GitHub Pages.
To fix this, you'll need to create a file named index.tsx
in the ./pages
directory. Your index.tsx
should look something like this:
import Filename, { getStaticProps as FilenameStaticProps } from './[filename]';const Index = Filename;export const getStaticProps = async ({ params }) => {return FilenameStaticProps({ params: { filename: 'home' } });}export default Index;
Assuming that your Tina clientID
and token
are setup as environment variables, you will need to add those to the GitHub Secrets for your project. The secrets we used in the code snippet above were TINA_PUBLIC_CLIENT_ID
& TINA_TOKEN
.
© TinaCMS 2019–2025