summaryrefslogtreecommitdiffstats
path: root/.github/workflows/jsdoc.yml
blob: 42a2446681b5323e8d307e986cc65c9f7db470ef (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
name: GitHub pages

on:
  push:
    branches:
      - master
    paths:
      # One day we might include all htdocs folders:
      # - '**/htdocs/**'
      # Until then, follow jsdoc.conf.json:source directive
      - 'modules/luci-base/htdocs/luci-static/resources/**'
      - 'docs/**'

jobs:
  build:
    if: endsWith( github.repository, 'luci' )
    runs-on: ubuntu-latest
    # permissions:
    #   pages: write
    #   id-token: write
    # environment:
    #   name: github-pages
    #   url: ${{ steps.deployment.outputs.page_url }}
    steps:
      - name: Checkout code
        uses: actions/checkout@v6

      - name: Install
        run: npm install

      - name: Build
        run: npm run doc

      - name: Archive docs as artifact
        uses: actions/upload-pages-artifact@v4
        with:
          name: docs
          path: ./docs/

      - name: Deploy
        uses: peaceiris/actions-gh-pages@v4
        with:
          github_token: ${{ secrets.GITHUB_TOKEN }}
          publish_dir: ./docs/
          enable_jekyll: false

      # Deploy step depends on the repo settings->pages config: choose Branch
      # "gh-pages", path "/". Deploy creates a commit on the gh-pages branch,
      # with the content of built docs folder "/docs" in repo root "/".
      # This is the "luci" repo, so the result of gh-pages is deployed to
      # "<githubid>.github.io/luci"

      # - name: Deploy to GitHub Pages
      #   id: deployment
      #   uses: actions/deploy-pages@v4
      #   with:
      #     artifact_name: docs