name: docs on: push: branches: - main paths: - "docs/**" - "mkdocs.yml" - ".github/workflows/docs.yaml" pull_request: paths: - "docs/**" - "mkdocs.yml" - ".github/workflows/docs.yaml" workflow_dispatch: permissions: contents: read pages: write id-token: write concurrency: group: pages cancel-in-progress: false jobs: build: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 with: fetch-depth: 0 - uses: actions/setup-python@v5 with: python-version: "3.12" cache: pip cache-dependency-path: docs/requirements.txt - name: Install MkDocs and plugins run: pip install -r docs/requirements.txt - name: Build site run: mkdocs build - name: Upload Pages artifact if: github.event_name != 'pull_request' uses: actions/upload-pages-artifact@v3 with: path: site deploy: if: github.event_name != 'pull_request' needs: build runs-on: ubuntu-latest environment: name: github-pages url: ${{ steps.deployment.outputs.page_url }} steps: - name: Deploy to GitHub Pages id: deployment uses: actions/deploy-pages@v4