mindjs/mindjs

View on GitHub
packages/core/README.md

Summary

Maintainability
Test Coverage
# Mind.js

<!--- TODO: create and add a logo
<p align="center">
  <a href="" target="blank"><img src="" width="120" alt="Mind.js Logo" /></a>
</p>
--->

<p align="center">
  Unopinionated, minimalistic, pure <a href="http://nodejs.org" target="_blank">Node.js</a> framework superpowered with <solid>Dependency Injection</solid> (Inversion Of Control) features for building efficient and scalable server-side applications.
</p>

<p align="center">
  <a href="https://www.npmjs.com/~mindjs" target="_blank"><img src="https://img.shields.io/npm/v/@mindjs/core.svg" alt="NPM Version" /></a>
  <a href="https://www.npmjs.com/~mindjs" target="_blank"><img src="https://img.shields.io/npm/l/@mindjs/core.svg" alt="Package License" /></a>
  <a href="https://www.npmjs.com/~mindjs" target="_blank"><img src="https://img.shields.io/npm/dm/@mindjs/core.svg" alt="NPM Downloads" /></a>
  <a href="https://snyk.io/test/github/mindjs/mindjs?targetFile=package.json"><img src="https://snyk.io/test/github/mindjs/mindjs/badge.svg?targetFile=package.json" alt="Known Vulnerabilities" data-canonical-src="https://snyk.io/test/github/mindjs/mindjs?targetFile=package.json" style="max-width:100%;"></a>
  <a href="https://codeclimate.com/github/mindjs/mindjs/maintainability"><img src="https://api.codeclimate.com/v1/badges/2b0a96c3615fb526ba48/maintainability" /></a>
  <a href="https://deepscan.io/dashboard#view=project&tid=7544&pid=9642&bid=127845"><img src="https://deepscan.io/api/teams/7544/projects/9642/branches/127845/badge/grade.svg" alt="DeepScan grade"></a>
</p>

## Philosophy
<p>Thanks to Node.js and its tools, front end applications have a significant   impact related to rising such superb projects like <a href="https://angular.io/" target="_blank">Angular</a>, <a href="https://github.com/facebook/react" target="_blank">React</a> and <a href="https://github.com/vuejs/vue" target="_blank">Vue</a> which improve developer productivity and enable the construction of fast, testable and extensible frontend applications.
Although on the server-side there are many awesome libraries, helpers, and tools for Node, only some of them effectively solve the architecture design problems. However, most of them either complex or requires knowledge of such tools as typescript or rxjs, which makes challenging to start using them. </p>
<p><solid>Mind.js</solid> aims to provide a simple and customizable application architecture out of the box, which allows for effortless creation of highly testable, scalable, loosely coupled and easily maintainable applications. It does not require any additional tools so that you can focus on business problems, not on technology ones. </p>

**Key features:**
* **Pure Node.js**. You don't need to transpile your code and perform extra steps in your CI/CD pipeline.
* **Modular**. You can easily split your codebase into small featured modules or even microservices.
* **Dynamic Routing**. You can build your dynamic routes before application has been run but after services are initialized.
* **Dependency injection**. Manage your dependencies in easy and convenient way.
* **No magic inside**. You have complete control and understanding of what you and your application do. You are able to customize
* **Easy to customize** and build reusable mind.js components.
* **Easy to debug** with standard Node.js inspection tools.
* It is compatible with the most popular Web/API frameworks such as `Express.js`, `Koa.js`, `Restify.js`, and others.
* Mind.js goes with `platform` support. You can use existing one as a super set of providers, which can be replaced with your custom ones.
Furthermore, it is possible to setup you own platform.
* The`HttpModule` provides an ability to make external API calls, intercept them, and configure it depending on your needs (WIP).
* The `TestingModule` allows you to test your code in an easy and convenient way.

## Getting started

* Check out the [Getting Started guide](https://github.com/mindjs/mindjs/tree/master/wiki/GETTING_STARTED.md) to start building your first Mind.js app. :rocket:

For more information look at the following sections:

* [Mind.js Anatomy](https://github.com/mindjs/mindjs/tree/master/wiki/MINDJS_ANATOMY.md)
* [Routing](https://github.com/mindjs/mindjs/tree/master/wiki/ROUTING.md)
* [Http](https://github.com/mindjs/mindjs/tree/master/wiki/HTTP.md)
* [Platforms](https://github.com/mindjs/mindjs/tree/master/wiki/PLATFORMS.md)
* [Testing](https://github.com/mindjs/mindjs/tree/master/wiki/TESTING.md)
* [Debugging](https://github.com/mindjs/mindjs/tree/master/wiki/DEBUGGING.md)
* [Contribution Guide](https://github.com/mindjs/mindjs/tree/master/CONTRIBUTION_GUIDE.md)
<!--- * [Development Guide](https://github.com/mindjs/mindjs/tree/master/wiki/DEVELOPMENT_GUIDE.md) --->

<!---
## Support

Mind.js is an MIT-licensed open source project. It can grow thanks to the sponsors and support by the amazing backers. If you'd like to join them, please [read more here]().
--->

## Roadmap

Mind.js [ROADMAP](https://github.com/mindjs/mindjs/tree/master/ROADMAP.md)

## Stay in touch

* Author - [Oleksandr Bondarenko](mailto:bondarenko.alexander.13@gmail.com)
* Slack  - [Mind.js](https://mindjs.slack.com)

## License

Mind.js is [MIT licensed](LICENSE).