File size: 1,245 Bytes
4cadbaf
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61

#	web-editor ![logo](./app/favicon.ico)

A WebSocket based text file synchronizer between disk and web browser.

## Installation

```bash
npm install @k-l-lambda/web-editor --save
```

## Usage

* Backend example:

```javascript
import http from "http";
import * as webEditor from "@k-l-lambda/web-editor";



// setup a web socket server over HTTP
const httpServer = http.createServer();
httpServer.listen("8080", "127.0.0.1", () => {
	console.log("WebEditor server is online.");
});


webEditor.service.createServer(httpServer, {rootDir: "/my-assets-folder"});
```

* Frontend example:

```javascript
import * as webEditor from "@k-l-lambda/web-editor";



// assume you have a textarea with id 'my-textarea' in DOM
const $textarea = document.querySelector("#my-textarea");

const remoteFile = new webEditor.RemoteFile();


remoteFile.on("sync", ({timestamp}) => {
	// receive change from disk
	$textarea.value = remoteFile.content;
	console.log("Disk change synchronized:", new Date(timestamp));
});


$textarea.onchange = () => {
	// send browser modification to disk
	remoteFile.content = $textarea.value;
};


// assume you have a file '/my-assets-folder/my-text.txt' on disk
remoteFile.connect("ws://127.0.0.1:8080", "my-text.txt");
```