@k-l-lambda/web-editor
TypeScript icon, indicating that this package has built-in type declarations

0.1.1 • Public • Published

web-editor logo

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

Installation

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

Usage

  • Backend example:
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:
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");

Package Sidebar

Install

npm i @k-l-lambda/web-editor

Weekly Downloads

0

Version

0.1.1

License

ISC

Unpacked Size

191 kB

Total Files

24

Last publish

Collaborators

  • k-l-lambda