2024-02-04 18:30:51 +01:00
|
|
|
#!/usr/bin/env bash
|
2024-01-13 15:19:36 +03:00
|
|
|
RUN="docker compose run --rm"
|
2023-06-18 01:32:45 +03:00
|
|
|
|
2023-07-01 16:17:25 +03:00
|
|
|
ansi() { echo -e "\e[${1}m${*:2}\e[0m"; }
|
|
|
|
bold() { ansi 1 "$@"; }
|
|
|
|
# italic() { ansi 3 "$@"; }
|
|
|
|
underline() { ansi 4 "$@"; }
|
|
|
|
# strikethrough() { ansi 9 "$@"; }
|
2024-02-04 18:30:51 +01:00
|
|
|
red() { ansi 31 "$@"; }
|
2023-07-01 16:17:25 +03:00
|
|
|
|
2023-06-18 01:32:45 +03:00
|
|
|
name=$(basename $0)
|
2023-06-11 01:15:31 +03:00
|
|
|
command=$1
|
|
|
|
args=${@:2}
|
|
|
|
|
|
|
|
case $command in
|
|
|
|
|
2024-01-13 15:19:36 +03:00
|
|
|
build)
|
|
|
|
docker compose build $args
|
|
|
|
;;
|
|
|
|
|
2023-06-11 01:15:31 +03:00
|
|
|
sh)
|
2024-01-14 01:05:47 +03:00
|
|
|
$RUN mermaid sh
|
2023-06-11 01:15:31 +03:00
|
|
|
;;
|
|
|
|
|
2023-06-27 14:11:06 +03:00
|
|
|
pnpm)
|
2024-01-13 15:19:36 +03:00
|
|
|
$RUN mermaid sh -c "pnpm $args"
|
2023-06-11 01:15:31 +03:00
|
|
|
;;
|
|
|
|
|
2023-06-18 01:32:45 +03:00
|
|
|
dev)
|
2024-01-13 15:19:36 +03:00
|
|
|
$RUN --service-ports mermaid sh -c "pnpm run dev"
|
2023-06-25 01:18:38 +03:00
|
|
|
;;
|
|
|
|
|
|
|
|
docs:dev)
|
2024-01-14 01:07:37 +03:00
|
|
|
$RUN --service-ports mermaid sh -c "pnpm run --filter mermaid docs:dev:docker"
|
2023-06-18 01:32:45 +03:00
|
|
|
;;
|
|
|
|
|
2023-07-01 16:17:25 +03:00
|
|
|
cypress)
|
2023-07-02 01:10:06 +03:00
|
|
|
$RUN cypress $args
|
2023-07-01 16:17:25 +03:00
|
|
|
;;
|
|
|
|
|
2024-02-04 18:30:51 +01:00
|
|
|
help|"")
|
2023-06-29 19:51:46 +03:00
|
|
|
|
|
|
|
# Alignment of help message must be as it is, it will be nice looking when printed
|
2023-06-18 01:32:45 +03:00
|
|
|
usage=$(
|
2023-06-11 01:15:31 +03:00
|
|
|
cat <<EOF
|
2023-06-27 14:11:06 +03:00
|
|
|
|
2023-07-01 16:17:25 +03:00
|
|
|
$(bold MERMAID LOCAL DOCKER DEVELOPMENT)
|
|
|
|
|
2023-07-02 01:10:06 +03:00
|
|
|
Welcome! Thank you for joining the development.
|
2023-07-01 16:17:25 +03:00
|
|
|
This is a script for running commands within docker containers at ease.
|
2023-06-29 20:16:25 +03:00
|
|
|
__________________________________________________________________________________________
|
|
|
|
|
2024-01-13 15:19:36 +03:00
|
|
|
Development Quick Start Guide:
|
|
|
|
|
|
|
|
$(bold ./$name pnpm install) # Install packages
|
|
|
|
$(bold ./$name dev) # Launch dev server with examples, open http://localhost:9000
|
|
|
|
$(bold ./$name docs:dev) # Launch official website, open http://localhost:3333
|
2023-06-11 01:15:31 +03:00
|
|
|
|
2024-01-13 15:19:36 +03:00
|
|
|
$(bold ./$name pnpm vitest) # Run watcher for unit tests
|
|
|
|
$(bold ./$name cypress) # Run integration tests (after starting dev server)
|
|
|
|
$(bold ./$name pnpm build) # Prepare it for production
|
2023-06-29 20:16:25 +03:00
|
|
|
__________________________________________________________________________________________
|
2023-06-18 01:32:45 +03:00
|
|
|
|
2023-06-27 14:11:06 +03:00
|
|
|
Commands:
|
2023-06-11 01:15:31 +03:00
|
|
|
|
2024-01-13 15:19:36 +03:00
|
|
|
$(bold ./$name build) # Build image
|
|
|
|
$(bold ./$name cypress) # Run integration tests
|
|
|
|
$(bold ./$name dev) # Run dev server with examples, open http://localhost:9000
|
|
|
|
$(bold ./$name docs:dev) # For docs contributions, open http://localhost:3333
|
|
|
|
$(bold ./$name help) # Show this help
|
|
|
|
$(bold ./$name pnpm) # Run any 'pnpm' command
|
|
|
|
$(bold ./$name sh) # Open 'sh' inside docker container for development
|
2023-06-29 20:16:25 +03:00
|
|
|
__________________________________________________________________________________________
|
2023-06-27 14:11:06 +03:00
|
|
|
|
2024-02-14 23:17:44 +01:00
|
|
|
Examples of frequently used commands:
|
2023-06-27 14:11:06 +03:00
|
|
|
|
2023-07-01 16:17:25 +03:00
|
|
|
$(bold ./$name pnpm add --filter mermaid) $(underline package)
|
|
|
|
Add package to mermaid
|
|
|
|
|
2024-01-05 21:05:10 +03:00
|
|
|
$(bold ./$name pnpm -w run lint:fix)
|
|
|
|
Run prettier and ES lint
|
|
|
|
|
2023-07-01 16:17:25 +03:00
|
|
|
$(bold git diff --name-only develop \| xargs ./$name pnpm prettier --write)
|
|
|
|
Prettify everything you added so far
|
|
|
|
|
2023-07-02 01:10:06 +03:00
|
|
|
$(bold ./$name cypress open --project .)
|
|
|
|
Open cypress interactive GUI
|
|
|
|
|
|
|
|
$(bold ./$name cypress run --spec cypress/integration/rendering/)$(underline test.spec.ts)
|
2024-01-13 15:19:36 +03:00
|
|
|
Run specific test in cypress
|
2023-07-01 16:17:25 +03:00
|
|
|
|
2023-08-17 23:52:56 +03:00
|
|
|
$(bold xhost +local:)
|
|
|
|
Allow local connections for x11 server
|
|
|
|
|
2023-06-11 01:15:31 +03:00
|
|
|
EOF
|
2023-06-18 01:32:45 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
echo -n -e "$usage"
|
2023-06-11 01:15:31 +03:00
|
|
|
;;
|
|
|
|
|
|
|
|
*)
|
2024-02-04 18:30:51 +01:00
|
|
|
message="$(red Unknown command: $command). See $(bold ./$name help) for available commands."
|
|
|
|
echo -n -e "$message\n" >&2
|
|
|
|
$0 help
|
|
|
|
exit 1
|
2023-06-11 01:15:31 +03:00
|
|
|
;;
|
|
|
|
|
2023-06-19 04:34:41 +03:00
|
|
|
esac
|