mirror of
https://codeberg.org/forgejo/docs.git
synced 2024-11-20 17:26:56 -05:00
tooling: add live preview script
This commit is contained in:
parent
a3c639ff49
commit
1de27e8949
4 changed files with 44 additions and 0 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -1,2 +1,3 @@
|
|||
*~
|
||||
node_modules
|
||||
.preview
|
||||
|
|
|
@ -57,6 +57,13 @@ website will not be available.
|
|||
If a commit is meant to be backported to a stable branch, it must be
|
||||
labelled with `backport/v1.20`, `backport/v1.19`, etc.
|
||||
|
||||
### Previewing changes
|
||||
|
||||
Run `pnpm run preview` to clone the [website repo](https://codeberg.org/forgejo/forgejo)
|
||||
and launch a local development server. The current docs branch will be opened in the browser.
|
||||
|
||||
Modifications can be made to the docs while the dev server is running, and the preview will live-reload.
|
||||
|
||||
### Links
|
||||
|
||||
All internal links within the documentation content should be relative to each page's path
|
||||
|
|
|
@ -6,6 +6,7 @@
|
|||
"license": "CC-BY-SA-4.0",
|
||||
"private": true,
|
||||
"scripts": {
|
||||
"preview": "./scripts/preview.sh",
|
||||
"test": "echo \"Error: no test specified\" && exit 1",
|
||||
"lint:remark": "remark . --quiet --frail",
|
||||
"lint:prettier": "prettier --check .",
|
||||
|
|
35
scripts/preview.sh
Executable file
35
scripts/preview.sh
Executable file
|
@ -0,0 +1,35 @@
|
|||
#!/usr/bin/env sh
|
||||
|
||||
current_branch=$(git branch --show-current)
|
||||
repo_path=$(pwd)
|
||||
|
||||
# Clone the website repo, or make sure the current clone is up to date
|
||||
if [ ! -e "./.preview" ];then
|
||||
git clone https://codeberg.org/forgejo/website.git .preview
|
||||
cd .preview
|
||||
else
|
||||
cd .preview
|
||||
git checkout main
|
||||
git pull
|
||||
fi
|
||||
|
||||
# make sure the docs content of the website is up to date
|
||||
git submodule update --remote
|
||||
|
||||
# install the website dependencies
|
||||
pnpm install
|
||||
|
||||
# symlink the current docs branch from the website content repo
|
||||
rm -rf ./src/content/docs/$current_branch
|
||||
mkdir -p $(dirname ./src/content/docs/$current_branch) # in case of branch names with slashes
|
||||
ln -s $repo_path/docs/ ./src/content/docs/$current_branch
|
||||
|
||||
rm -rf ./public/images/$current_branch
|
||||
mkdir -p $(dirname ./src/content/images/$current_branch) # in case of branch names with slashes
|
||||
ln -s $repo_path/images/ ./public/images/$current_branch
|
||||
|
||||
# once the dev server is running, open the current docs branch in the browser
|
||||
sleep 3 && open http://localhost:3000/docs/$current_branch/ &
|
||||
|
||||
# start the dev server
|
||||
pnpm run dev
|
Loading…
Reference in a new issue