Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ericclemmons/polydev
Faster, route-centric development for Node.js apps with built-in Hot Module Replacement.
https://github.com/ericclemmons/polydev
Last synced: 4 days ago
JSON representation
Faster, route-centric development for Node.js apps with built-in Hot Module Replacement.
- Host: GitHub
- URL: https://github.com/ericclemmons/polydev
- Owner: ericclemmons
- Created: 2018-12-27T06:14:13.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2022-04-01T11:00:42.000Z (almost 3 years ago)
- Last Synced: 2025-01-01T01:17:00.572Z (18 days ago)
- Language: JavaScript
- Homepage:
- Size: 23.7 MB
- Stars: 282
- Watchers: 4
- Forks: 6
- Open Issues: 19
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
Awesome Lists containing this project
- awesome - polydev - Faster, route-centric development for Node.js apps with built-in Hot Module Replacement. (JavaScript)
README
![polydev](/logo.png)
> Faster, route-centric development for [Node.js][node] apps with built-in
> [Hot Module Replacement][hmr].
>
> ![Demo GIF](/polydev.gif)## Rationale
As your project grows, **working on a large or monolithic [Node.js][node] app gets slower**:
- Working on _part_ of the app means running the _entire_ app.
- The `require` tree grows so large it can take several seconds to start the server.
- Restarting the server on every change impedes development.
- Middleware for projects like [Next.js][next] & [Storybook][storybook] are expensive
to restart with each change.
- Tools like [concurrently][concurrently], [nodemon][nodemon], & [piping][piping] still
run the entire app.
- You shouldn't waste time in the terminal hitting Ctrl-C and restarting.## Features
- Fast startup.
- [Hot Module Replacement][hmr] built-in.
- Run only the parts of your app that's requested.
- Supports [yarn workspaces][workspaces].
- Pretty `404` screens with the option to create the missing route.
- Pretty `500` screens, so you spend less time in the terminal.
- Iterative adoption, so it's easy to get started.## Quick Started
1. Install
```shell
yarn add polydev --dev
```2. Run `polydev`
```shell
yarn run polydev --open
```For customizing the `node` runtime, you can use `NODE_OPTIONS`.
For example, [TypeScript][typescript] can be enabled via [ts-node][ts-node]:
```shell
polydev --require ts-node/register
# Or
NODE_OPTIONS="--require ts-node/register" polydev
```## Defining `routes`
The `routes` folder is similar to Old-Time™ HTML & PHP, where
**folders mirror the URL structure**, followed by an `index.js` file:- `routes/`
- `page/[id]/index.js`
_Has access to `req.params.id` for [/page/123](http://localhost:3000/page/123)._
- `contact-us/`
- `index.get.js`
- `index.post.js`- `posts/index.*.js`
_Responds to both `GET` & `POST` for [/posts/\*](http://localhost:3000/posts)._
- `index.js`
_Responds to both `GET` & `POST` for [/](http://localhost:3000/)._
### Route Handlers
Route handlers can be any of the following:
1. Functional middleware:
```js
module.exports = (req, res) => {
res.send("Howdy there!")
}
```2. Express apps:
```js
const express = require("express")module.exports = express().get("/", (req, res) => {
res.send(`Howdy from ${req.path}!`)
})
```3. A [yarn workspace][workspaces] package:
```js
module.exports = require("my-package-name")
```4. A `package.json` path:
```js
module.exports = require.resolve("my-app/package.json")
```These are considered stand-alone apps that will be ran via `yarn dev` or `yarn start` (whichever exists) for development only.
This is good for when you want to have a separate API server open on `process.env.PORT` that's not part of your application.
## Contributing
> See [CONTRIBUTING.md](/CONTRIBUTING.md).
## Author
- [Eric Clemmons][twitter]
[concurrently]: https://github.com/kimmobrunfeldt/concurrently
[hmr]: https://github.com/sidorares/hot-module-replacement
[issues]: https://github.com/ericclemmons/polydev/issues?q=is%3Aissue+is%3Aopen+sort%3Aupdated-desc
[next]: https://github.com/zeit/next.js/
[node]: https://nodejs.org/
[nodemon]: https://github.com/remy/nodemon
[piping]: https://www.npmjs.com/package/piping
[storybook]: https://github.com/storybooks/storybook
[ts-node]: https://github.com/TypeStrong/ts-node
[typescript]: https://www.typescriptlang.org/
[twitter]: https://twitter.com/ericclemmons
[workspaces]: https://yarnpkg.com/en/docs/workspaces