name: Build and Deploy Documentation on: push: branches: [ main ] paths: - 'docs/**' - 'mkdocs.yml' - 'docs-requirements.txt' - '.github/workflows/docs.yml' pull_request: branches: [ main ] paths: - 'docs/**' - 'mkdocs.yml' - 'docs-requirements.txt' permissions: contents: read pages: write id-token: write concurrency: group: "pages" cancel-in-progress: false jobs: build: runs-on: ubuntu-latest steps: - name: Checkout uses: actions/checkout@v4 with: fetch-depth: 0 # Needed for git-revision-date-localized plugin - name: Setup Python uses: actions/setup-python@v4 with: python-version: '3.11' - name: Install dependencies run: | pip install -r docs-requirements.txt - name: Build documentation run: | mkdocs build --strict - name: Upload documentation artifact if: github.ref == 'refs/heads/main' uses: actions/upload-pages-artifact@v3 with: path: ./site deploy: if: github.ref == 'refs/heads/main' environment: name: github-pages url: ${{ steps.deployment.outputs.page_url }} runs-on: ubuntu-latest needs: build steps: - name: Deploy to GitHub Pages id: deployment uses: actions/deploy-pages@v4