element-web-Github/.github/workflows/docs.yml

116 lines
3.5 KiB
YAML
Raw Normal View History

2023-10-17 06:57:03 +08:00
name: Deploy documentation
on:
push:
branches: [develop]
workflow_dispatch: {}
2023-10-17 15:58:27 +08:00
permissions:
contents: read
pages: write
id-token: write
2023-10-17 15:58:27 +08:00
concurrency:
group: "pages"
cancel-in-progress: false
2023-10-17 15:58:27 +08:00
2023-10-17 06:57:03 +08:00
jobs:
2023-10-17 15:58:27 +08:00
build:
2023-10-17 06:57:03 +08:00
name: GitHub Pages
runs-on: ubuntu-latest
steps:
- name: Fetch element-desktop
uses: actions/checkout@v4
with:
repository: vector-im/element-desktop
path: element-desktop
- name: Fetch element-web
uses: actions/checkout@v4
with:
path: element-web
- name: Fetch matrix-react-sdk
uses: actions/checkout@v4
with:
repository: matrix-org/matrix-react-sdk
path: matrix-react-sdk
- name: Fetch matrix-js-sdk
uses: actions/checkout@v4
with:
repository: matrix-org/matrix-js-sdk
path: matrix-js-sdk
2023-10-27 21:25:38 +08:00
- uses: actions/setup-node@v3
with:
cache: "yarn"
2023-10-27 22:00:15 +08:00
cache-dependency-path: element-web/yarn.lock
2023-10-27 21:25:38 +08:00
- name: Generate automations docs
working-directory: element-web
run: |
yarn install --frozen-lockfile
2023-10-27 22:04:20 +08:00
yarn ts-node ./scripts/gen-workflow-mermaid.ts ../element-desktop ../element-web ../matrix-react-sdk ../matrix-js-sdk > docs/automations.md
2023-10-27 21:25:38 +08:00
echo "- [Automations](automations.md)" >> docs/SUMMARY.md
2023-10-17 06:57:03 +08:00
- name: Setup mdBook
uses: peaceiris/actions-mdbook@v1
with:
mdbook-version: "0.4.10"
2023-10-26 15:40:33 +08:00
- name: Install mdbook extensions
run: cargo install mdbook-combiner mdbook-mermaid
2023-10-17 06:57:03 +08:00
2023-10-17 15:48:19 +08:00
- name: Prepare docs
2023-10-17 06:57:03 +08:00
run: |
mkdir docs
2023-10-17 15:48:19 +08:00
mv element-desktop/README.md element-desktop/docs/
mv element-desktop/docs "docs/Element Desktop"
2023-10-17 15:48:19 +08:00
mv element-web/README.md element-web/docs/
mv element-web/docs/lib docs/
mv element-web/docs "docs/Element Web"
2023-10-17 15:48:19 +08:00
mv matrix-react-sdk/README.md matrix-react-sdk/docs/
mv matrix-react-sdk/docs "docs/Matrix React SDK"
mv matrix-js-sdk/README.md matrix-js-sdk/docs/
mv matrix-js-sdk/docs "docs/Matrix JS SDK"
sed -i -e 's/\.\.\/README.md/README.md/' docs/**/SUMMARY.md
2023-10-17 15:48:19 +08:00
2023-10-17 06:57:03 +08:00
mdbook-combiner -m docs
sed -i -E 's/^\t# (.+)$/- [\1]()/gm;t' SUMMARY.md
sed -i -E 's/^- \[(.+)]\(<>\)$/---\n# \1/gm;t' SUMMARY.md
sed -i -E 's/\t- \[Introduction]/- [Introduction]/gm;t' SUMMARY.md
cat <<EOF > docs/SUMMARY.md
# Summary
- [Introduction](<Element Web/README.md>)
EOF
cat SUMMARY.md >> docs/SUMMARY.md
2023-10-17 15:48:19 +08:00
mv element-web/book.toml .
- name: Build docs
run: mdbook build
2023-10-17 06:57:03 +08:00
2023-10-17 15:58:27 +08:00
- name: Upload artifact
uses: actions/upload-pages-artifact@v2
2023-10-17 06:57:03 +08:00
with:
2023-10-17 15:58:27 +08:00
path: ./book
deploy:
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@v2