Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/mizchi/next-editor

Standalone Git Editor on Browser
https://github.com/mizchi/next-editor

editor git isomorphic-git pwa react service-worker

Last synced: 5 days ago
JSON representation

Standalone Git Editor on Browser

Awesome Lists containing this project

README

        

Next Editor

[Become a patreon](https://www.patreon.com/mizchi/overview) / [BACKERS](/BACKERS.md)

[![CircleCI](https://circleci.com/gh/mizchi/next-editor.svg?style=svg)](https://circleci.com/gh/mizchi/next-editor)

[![Coverage Status](https://coveralls.io/repos/github/mizchi/next-editor/badge.svg?branch=release)](https://coveralls.io/github/mizchi/next-editor?branch=release)

Standalone PWA Editor with Git (for Chromebook)

![](https://i.gyazo.com/4819943cb09b3c69e183eae9a5dae748.png)

Play here [nedi.app](https://nedi.app)

**Unstable**: Data may be wiped by update

I am checking only Chrome and Chrome Canary.

## How to develop

- `yarn watch`: start dev server(localhost:8099)
- `yarn test`: run jest and typescript checking

no service-worker in development.

## How to create your own next-editor

### Deploy your own apllication

Register https://www.netlify.com

- `yarn deploy`: deploy to netlify
- (Complete netlify authentication flow)

or

- `yarn build:prod`
- Deploy `public` directory to your host.

### Optional: CORS-PROXY

Register https://now.sh to deploy cors-buster
You need proxy to push GitHub

- `npm i -g now-cli`
- `now wmhilton/cors-buster` (using https://github.com/wmhilton/cors-buster)
- Set your default proxy on [src/ui/reducers/config.ts](src/ui/reducers/config.ts): `corsProxy: ""`

### Optional: Custom entry

```
mkdir src-custom
touch src-custom/index.js
SRC="src-custom" yarn build:prod
```

```js
// src-custom/index.js

import { setupInitialRepository } from "../src/domain/git/commands/setupInitialRepository"
import { run } from "../src/init"

// Write your own bootstrap
async function main() {
try {
await setupInitialRepository("/playground")
} catch (e) {
// Skip
console.error("init error", e)
}
run()
}

main()
```

This feature is for private custom build to release [next-editor.app](next-editor.app).

## How to contribute

- Fork this repository on GitHub
- Write your code to modify
- Write test under `__tests__/*.ts`
- Pass `yarn test`
- Create Pull-Request to this repository

See what @mizchi plan on [TODO.md](TODO.md)

PR is welcome!

---

## LICENSE

MIT