@teawithsand/tws-filesend
TypeScript icon, indicating that this package has built-in type declarations

0.0.3 • Public • Published

tws-filesend

Library and accompanying web application using it, which allows for transferring files between devices.

This library is kind of showcase how to use tws-async-peer

Docs

Go to github pages for documentation

How does the library work?

See app as an example. Also you can take a look at the docs.

How does the app work?

From user perspective:

  1. Sending party picks files that they want to send.
  2. One party(either receiving or sending) generates token.
  3. The other party somehow receives that token, either via string, scanning QRCode or sth like that.
  4. Both parties accept each other(explicit step) and files are streamed over WebRTC connection from sender to receiver.
  5. User either saves(AKA downloads; we are in web world) those files, or programmer does something fancy with them.

In case you need more detailed info, check out the docs available directly with code.

A few notes at the end

It uses my homegrown event busses, which are so-so but work more than OK

This library uses @teawithsand/tws-async-peer EventBus type from @teawithsand/ttws-lts, because it was first built on top of tws-stl (part of tws-libs). It's something like ~100sloc implementation of RxJS, but it's quite convenient to use nevertheless.

There is nothing wrong in this lib using my own implementation of event bus for handling events, but IMHO it's kind of unsound of me to reinvent the wheel. Just check out the docs for tws-lts.

Also if you use react, check out tws-lts-react, which provides some neat hooks, which make it really easy to hook to busses and especially sticky busses.

Package Sidebar

Install

npm i @teawithsand/tws-filesend

Weekly Downloads

0

Version

0.0.3

License

MIT

Unpacked Size

81.1 kB

Total Files

47

Last publish

Collaborators

  • teawithsand