Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mraible/angular-book
The Angular Mini-Book
https://github.com/mraible/angular-book
angular angular-material bootstrap kotlin oidc spring-boot typescript
Last synced: 3 months ago
JSON representation
The Angular Mini-Book
- Host: GitHub
- URL: https://github.com/mraible/angular-book
- Owner: mraible
- License: apache-2.0
- Created: 2020-06-25T18:33:39.000Z (over 4 years ago)
- Default Branch: main
- Last Pushed: 2024-09-30T14:17:09.000Z (3 months ago)
- Last Synced: 2024-10-05T04:51:37.760Z (3 months ago)
- Topics: angular, angular-material, bootstrap, kotlin, oidc, spring-boot, typescript
- Language: TypeScript
- Homepage: https://www.infoq.com/minibooks/angular-mini-book/
- Size: 120 MB
- Stars: 7
- Watchers: 2
- Forks: 7
- Open Issues: 5
-
Metadata Files:
- Readme: README.adoc
- Changelog: CHANGELOG.adoc
- License: LICENSE
Awesome Lists containing this project
README
= Angular Mini-Book
image::https://github.com/mraible/angular-book/workflows/Book%20CI/badge.svg[link="https://github.com/mraible/angular-book/actions",alt="Actions Status"]
This is an awesome book. It's written in AsciiDoc and compiles to HTML, PDF, and EPUB using the
http://asciidoctor.org/docs/asciidoctor-gradle-plugin/[Asciidoctor Gradle plugin].== Installing
----
npm run setup
----== Building
To convert this book to HTML and EPUB, run the following command:
----
npm run build
----* Open _build/asciidoc/html5/index.html_ in your browser to see the generated HTML file.
* Open _build/asciidoc/pdf-prepress/index.pdf_ to see the 6x9" printable PDF file.
* Open _build/asciidoc/pdf-screen/index.pdf_ to see the downloadable 8.5x11" PDF file.
* Open _build/asciidoc/epub3/index.epub_ in iBooks to see the generated EPUB file.To generate a static site using Antora, run the following command:
npm run build:site
== Sweet Authoring Experience
If you'd like a very pleasant authoring experience, the project provides build files that make it possible. First of all,
you'll need to run `gradlew` once. After running it once, you can run `./gradlew watch` to watch for any changes and
recompile files as you save them.To have a similar awesome experience (watch and auto-reload) in your browser, install https://nodejs.org/[Node.js] on your machine.
After installing Node, you can run the following command to install development tools (like http://www.browsersync.io/[Browsersync]).
----
npm install
----TIP: You will only need to run this command when dependencies change in `package.json`.
Now you can run the following command:
----
npm start
----This will start two daemons:
. Gradle, which will watch the file system and rebuild the HTML version continuously using Asciidoctor
. BrowserSync, which will serve the updated HTML version all of the time and make it available over HTTPThanks to this, you'll have a constantly up to date HTML version available in your browser while editing.
Similarly, you can run the following command to continuously watch the file system and rebuild the static site:
----
npm run watch:site
----== Update Dependencies
To update the dependencies in `build.gradle`, run:
----
./gradlew useLatestVersions
----To update the dependencies in `package.json`, install https://www.npmjs.com/package/npm-check-updates[npm-check-updates] and run it:
----
npm i -g npm-check-updates
ncu
----== Releasing/Publishing
This project includes GitHub action workflows to build and publish the book (PDF, EPUB, HTML). To trigger this, you have two options:
* Run the following script: `npm run release`
* Use GitHub's UI to create the release from your book repositoryOnce completed, the publish workflow will attach the generated files to the release page.
The benefit of the release npm script is that the version will be updated automatically in the `package.json` and `version.txt` files. The version will be reflected in the generated files because the version in `version.txt` is used as the Gradle project version when building the book.
Note that in order for the release npm script to work, you'll need to make sure that a `GITHUB_TOKEN` environment variable is available, as explained in https://github.com/release-it/release-it/blob/master/docs/environment-variables.md[release-it's documentation].
== Deploy to Netlify
To deploy this repository to https://www.netlify.com/[Netlify], create an account and log in.
. Select **New site from Git**
. Select your Git provider
. Select your repository
. Select the branch to deploy
. Build command: `npm run build:site`
. Publish directory: `public/`
. Click **Deploy site**Your site should take less than a minute to deploy, depending on the size of your book.
== Netlify Preview
This repository is using a `netlify.toml` configuration file to build and publish the static site to Netlify. You can see the result at https://angular-book.org.