An advanced, streamlined documentation platform built with Next.js and Nextra for InkChain.
- 
Build Docker image: docker build -t docs .
- 
Run Docker container: docker run -p 3000:3000 docs 
- Node.js: v20.11.0 or higher
This is a documentation application powered by Nextra and built on Next.js. Nextra simplifies the creation of documentation sites, allowing us to leverage the Pages Router for efficient navigation and routing. Currently, due to compatibility limitations, we have not yet upgraded to the App Router.
To get started with local development:
- Clone the repository
- Install dependencies:
pnpm install 
- Start development server:
pnpm run dev 
Our development setup includes multiple tools to maintain high-quality code and documentation:
- CSpell: Real-time spell checking to maintain documentation accuracy.
- Remark: Processes and renders Markdown content with added plugins.
- ESLint: Ensures code quality by catching potential issues.
- Prettier: Enforces consistent code formatting.
- Tailwind CSS: Utility-first CSS framework for fast, responsive UI development.
Our CI/CD setup utilizes GitHub Actions to run automated checks on every pull request (PR):
- js-lint: Ensures proper JavaScript code formatting with ESLint.
- md-lint: Checks Markdown code formatting with Remark.
- format: Enforces consistent code style with Prettier.
- spell-check: Uses CSpell to verify correct spelling in the documentation. For any unique terms (e.g., "InkChain"), add them to the ./cspell/project-words.txtfile to whitelist.
For every new PR, our CI/CD pipeline deploys a temporary environment via AWS Amplify. This real-time deployment enables live testing and review of changes before merging, ensuring a smoother workflow. The deployment URL is automatically provided within the PR checks, allowing team members to interact with new features.
The main branch is configured for automatic continuous deployment via AWS Amplify. Every merge triggers a new build and deployment, ensuring that the latest version of the documentation is available to users without manual intervention.