Package Exports
- notion-jam
- notion-jam/dist/cli.mjs
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (notion-jam) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
notion-jam
Sync pages from Notion to GitHub to be used as a static website (JAM)
- Notion pages are converted to markdown files.
- Database properties are automatically added as yaml frontmatter
- All images are downloaded locally and path rewritten to relative paths
- Page cover is downloaded
- Thumbnail property is added automatically to the frontmatter using page cover, first image, icon, or image number (configured by post)
Usage
Quick Start
Create a new Notion Integration
Add Notion secret to GitHub repository
Go to
github.com/{user}/{repo}/settings/secrets/actions
Set
NOTION_SECRET
of Notion to your repository secret.
Share the Database with the integration
Create a workflow in
.github/workflows/**.yml
of your repositoryExample Workflow
# This is a basic workflow to help you get started with Actions name: NotionJAM # Controls when the workflow will run on: schedule: - cron: "0 21 * * *" # daily push: branches: [master, main] # Allows you to run this workflow manually from the Actions tab workflow_dispatch: # A workflow run is made up of one or more jobs that can run sequentially or in parallel jobs: # This workflow contains a single job called "build" build: # The type of runner that the job will run on runs-on: ubuntu-latest # Steps represent a sequence of tasks that will be executed as part of the job steps: # Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it - uses: actions/checkout@v3 - name: notion-jam uses: victornpb/notion-jam@v0.0.10 with: NOTION_SECRET: ${{ secrets.NOTION_SECRET }} NOTION_DATABASE: https://www.notion.so/9e34cee9f5bd4c4aaf0d2eaf73ead47b FILTER_PROP: Status FILTER_VALUES: Published CONVERT_PROP_CASE: snake ARTICLE_PATH: content/posts/{title}/README.md ASSETS_PATH: ./ PARALLEL_PAGES: 25 PARALLEL_DOWNLOADS_PER_PAGE: 3 DOWNLOAD_IMAGE_TIMEOUT: 30 SKIP_DOWNLOADED_IMAGES: true DOWNLOAD_FRONTMATTER_IMAGES: true - name: Save changes uses: stefanzweifel/git-auto-commit-action@v4 with: commit_message: Commit changes
Configuration
Parameters
Name | Description | Required | Default |
---|---|---|---|
NOTION_SECRET | Notion API Token secret | ✅ | |
NOTION_DATABASE | Notion Database URL or ID (example: https://notion.so/00112233445566778899aabbccddeeff) | ✅ | |
FILTER_PROP | Property on the database used to query pages | Status | |
FILTER_VALUES | Return pages with the FILTER_PROP is equal this list of values | Ready,Published | |
CONVERT_PROP_CASE | Convert the database property names before adding to the frontmatter (camel,pascal,kebab,snake,none) | snake | |
ARTICLE_PATH | Path template to where to save markdown files | posts/{title}/README.md | |
ASSETS_PATH | Path to save images, if started with . will be relative to ARTICLE_PATH, otherwise absolute | ./ | |
PARALLEL_PAGES | Fetch this amount of pages in parallel | 25 | |
PARALLEL_DOWNLOADS_PER_PAGE | Number of images to download in parallel for each page | 3 | |
DOWNLOAD_IMAGE_TIMEOUT | Timeout in seconds for each image download | 30 | |
SKIP_DOWNLOADED_IMAGES | Skip downloading images if they already exist in the path | true | |
DOWNLOAD_FRONTMATTER_IMAGES | Downloads image urls in the frontmatter | true |