# [\#48 Issue](https://github.com/milahu/alchi/issues/48) `open`: inplace-editing, decentral, nocloud, dapp, p2p, crdt, collaboration, local-first, offline-first
####
[milahu](https://github.com/milahu) opened issue at [2022-11-04 10:20](https://github.com/milahu/alchi/issues/48):
my book should be an inplace-editable document like
[dokieli](https://dokie.li/)
which can be shared over peer-to-peer networking (wifi, bluetooth)
editing should be inplace = zero barriers:
no need to create an account (github, facebook, instagram, ...)
no need to open a separate editor ("click here to edit this page")
zero install = must work in browser
## inplace-editing
document is a html page
by default, it is read-only (not editable)
when i click "edit" then load the editor
= make the document editable \*in place\* = no page reload
early draft
### solidjs
web framework, faster alternative to react
### prosemirror
- 1K stars
(underrated)
rich-text editor
see also:
- based on react,
prosemirror - 100 stars
- based on react,
prosemirror - 300 stars
#### yjs
- 9K stars
CRDT, track micro-changes
persistence
### isomorphic-git
- 7K stars
- 200K downloads
A pure JavaScript implementation of git for node and browsers
does not work with github, because github refuses to add CORS headers
(fuck them)
works with gitea → example:
overkill?
we just need to fetch like 10 versions of \*one file\*
→ github rest api should work
#### js-git
- 4K stars
- 1M downloads
A JavaScript implementation of Git
> I've been asking Github to enable CORS headers to their HTTPS git
> servers, but they've refused to do it. This means that a browser can
> never clone from github because the browser will disallow XHR requests
> to the domain.
- 160 stars
A js-git mixin that uses github as the data storage backend.
example with indexeddb caching
### gitea
- 30K stars
web frontend for git repos, alternative to github, gitlab
works with isomorphic-git
selfhosted, localfirst, nocloud, anyone can start a new instance
### html first
javascript is optional
no build steps, no SSR, no markdown
## progressive web app
## offline-first
aka: local-first, dweb
### pazguille/offline-first
Everything you need to know to create offline-first web apps
### workbox
JavaScript libraries for Progressive Web Apps
service workers
### berty
peer-to-peer messaging app that works with or without internet access
### UpUp
create sites that work offline as well as online
### vuejs-templates/pwa
PWA template for vue-cli based on the webpack template
### client-side-databases
An implementation of the exact same app in Firestore, AWS Datastore,
PouchDB, RxDB and WatermelonDB
### pouchdb
- 15K stars
> PouchDB is an open-source JavaScript database inspired by [Apache
> CouchDB](http://couchdb.apache.org/) that is designed to run well
> within the browser.
>
> PouchDB was created to help web developers build applications that
> work as well offline as they do online.
>
### couchdb
> [The Couch Replication
> Protocol](https://docs.couchdb.org/en/stable/replication/protocol.html)
> lets your data flow seamlessly between server clusters to mobile
> phones and web browsers, enabling a compelling
> [offline-first](https://offlinefirst.org/) user-experience while
> maintaining high performance and strong reliability.
### kinto
### wora
Write Once, Render Anywhere.
documentation for typescript libraries: cache-persist, apollo-offline,
relay-offline, offline-first, apollo-cache, relay-store, netinfo,
detect-network
### git-documentdb
Offline-first Database that Syncs with Git
demo app
### tool-db
A peer-to-peer decentralized database
### offlinefirst.org
via
> We live in a disconnected & battery powered world, but our technology
> and best practices are a leftover from the always connected & steadily
> powered past.
>
> Offline capability is a key characteristic of modern Progressive Web
> Applications.
> Tools and techniques for building offline capable apps
### inkandswitch.com
> Cloud apps like Google Docs and Trello are popular because they enable
> real-time collaboration with colleagues, and they make it easy for us
> to access our work from all of our devices. However, by centralizing
> data storage on servers, cloud apps also **take away ownership** and
> agency from users. If a service shuts down, the software stops
> functioning, and data created with that software is lost.
>
> In this article we propose “local-first software”: a set of principles
> for software that enables both **collaboration and ownership** for
> users. Local-first ideals include the ability to work offline and
> collaborate across multiple devices, while also improving the
> security, privacy, long-term preservation, and user control of data.
> It’s amazing how easily we can collaborate online nowadays. ... We
> depend on these and many other online services ... As we run more and
> more of our lives and work through these cloud apps, they become more
> and more critical to us. The more time we invest in using one of these
> apps, the more valuable the data in it becomes to us. ... downsides of
> cloud apps ... When you have put a lot of creative energy and effort
> into making something, you tend to have a deep emotional attachment to
> it. ...
>
> you typically produce files and data: documents, presentations,
> spreadsheets, code, notes, drawings, and so on. And you will want to
> keep that data: for reference and inspiration in the future, to
> include it in a portfolio, or simply to archive because you feel proud
> of it.
> It is important to feel ownership of that data, because the creative
> expression is something so personal.
>
> Unfortunately, cloud apps are problematic in this regard. Although
> they let you access your data anywhere, all data access must go via
> the server, and you can only do the things that the server will let
> you do. In a sense, you don’t have full ownership of that data — the
> cloud provider does. In the words of a [bumper
> sticker](http://www.chriswatterston.com/blog/my-there-is-no-cloud-sticker):
> “**There is no cloud, it’s just someone else’s computer**.”
>
>
> > There is no cloud! It's just someone else's computer...
> >
> > ![there is no cloud its just someone elses
> > computer](https://user-images.githubusercontent.com/12958815/199947625-0fc0dbcb-2a1c-4446-b91a-2008e6e547aa.jpg)
> >
> > It’s actually rather scary how many people don’t have a bloody clue
> > on what the ‘Cloud’ actually is.
> >
> > > Tell me again about your mythical cloud thingy
> When data is stored on “someone else’s computer”, that third party
> assumes a degree of control over that data. Cloud apps are provided as
> a service; if the service is unavailable, you cannot use the software,
> and you can no longer access your data
= dependency, vendor lock-in, prison
> you might be able to export your data, without the servers there is
> normally no way for you to continue running your own copy of that
> software. Thus, you are at the mercy of the company providing the
> service.
> In old-fashioned apps, the data lives in files on your local disk, so
> you have full agency and ownership of that data: you can do anything
> you like, including long-term archiving, making backups, manipulating
> the files using other programs, or deleting the files if you no longer
> want them. **You don’t need anybody’s permission to access your
> files**, since they are yours. **You don’t have to depend on servers
> operated by another company.**
> To sum up: the cloud gives us collaboration, but old-fashioned apps
> give us ownership. Can’t we have the best of both worlds?
>
> We would like both the convenient cross-device access and real-time
> collaboration provided by cloud apps, and also the personal ownership
> of your own data embodied by “old-fashioned” software.
rabbithole
## CRDT
aka: distributed database
### gun
protocol for syncing decentralized graph data
### automerge
- 14K stars
CRDT, data structures for building collaborative applications.
Pixelpusher: Real-time peer-to-peer collaboration with React
- 400 stars
We built Trellis to demo [MPL](https://github.com/automerge/mpl), a
distributed persistence library that allows developers to build
collaborative applications that are realtime, offline, and network
partition tolerant.
- 200 stars
a p2p document synchronization system for automerge
### yjs
- 9K stars
## collaborative editors
### etherpad
- 13K stars
online editor providing collaborative editing. No more sending your
stuff back and forth via email, just set up a pad, share the link and
start collaborating!
features: timeslider, revisions, chat plugin
selfhosted: You don't need to set up a server and install Etherpad in
order to use it. Just pick one of publicly available instances that
friendly people from everywhere around the world have set up.
Alternatively, you can set up your own instance by following our
installation guide
based on ace editor
public instances:
...
formats: HTML, RTF
> for the record: im moving from etherpad to
> [tiptap](https://tiptap.dev/guide/collaborative-editing)
>
> etherpad: based on ace editor, jquery
> tiptap: based on prosemirror, yjs -> more modern, flexible, modular
### cryptpad
- 4K stars
All the content stored on CryptPad is encrypted before being sent, which
means nobody can access your data unless you give them the keys.
CryptPad is a suite of zero knowledge, realtime collaborative editors
and applications
public instances:
...
formats: doc, xls, ...
broken:
> Aborting because eval should not be permitted.
>
> This error is linked to Content-Security-Policy headers, it could be
> due to: an outdated browser that does not support them, browser
> extensions that interfere with their correct behaviour, or an
> incorrect configuration of this CryptPad instance.
### foam
- 13K stars
knowledge management
knowledge sharing
built on Visual Studio Code and GitHub
You can use Foam for organising your research, keeping re-discoverable
notes, writing long-form content and, optionally, publishing it to the
web.
formats: MD
### hedgedoc
hedgedoc is easily the best markdown document editor out there.
Documents can be shared privately as well as publicly. Multiple people
can work together on the same document with great visual feedback.
export/import with github gist
download markdown or html
based on CodiMD, HackMD
formats: MD
### prosemirror
- 1K stars
(underrated)
ProseMirror is a simple but effective editor that favours minimalism,
speed, and precision. It's an attempt to bridge the gap between Markdown
text editing and classical "what you see is what you get" (WYSIWYG) word
processors. It is specifically intended as a platform for customization,
so if your organization is looking into developing a custom editor, this
is a great place to start. Even without customization, though,
ProseMirror is a nice, minimal, and easy editor for collaboration.
see also:
- based on react,
prosemirror - 100 stars
- based on react,
prosemirror - 300 stars
formats: HTML, MD, ...
### Twake
real-time teamwork platform
suite of collaborative tools that includes the specificities of some
bestsellers (Slack, Trello, Google Drive...).
messaging, storage space, online collaborative editors (Words, Excel,
PowerPoint), task manager, team calendar
Twake is available in SaaS or self-hosted.
### documize
making it dead-simple for anyone to compose & contribute content and
share knowledge
A single place to compose docs and share know-how, without the mess of
email, chat apps and sync folders
Has both open source and enterprise edition
### fiduswriter
online collaborative LaTeX editor especially made for academics who need
to use citations and/or formulas
The editor focuses on the content rather than the layout, so that with
the same text, you can later on publish it in multiple ways: On a
website, as a printed book, or as an ebook. In each case, you can choose
from a number of layouts that are adequate for the medium of choice.
### gobby
Gobby is a **text editor** that allows real-time, lock-free
collaborative text editing. Before you start sharing and co-editing your
documents, you'll need to choose a private key and a certificate or
create a new pair. You can open an existing document or create a new one
that can be later saved into its own native format or exported as an
HTML file.
### firepad
- 4K stars
based on Firebase
Firepad allows synchronous document (with CodeMirror) and code (via ACE)
co-editing.
Since it uses Firebase as a backend, Firepad requires no server-side
code. You can easily embed it into any web app using the available
JavaScript files
### draft.js
- 20K stars
based on react
deprecated in favor of - 10K stars
based on react
### react-contenteditable
- 1K stars
based on react
### react-simple-code-editor
-
1K stars
based on react
## dapps
### hypercore
secure, distributed append-only log
- 2K stars
### picostack
- 20 stars
demo
> Pico-stack is a virtual p2p machine
>
> It allows you to build Progressive Web Apps that work completely
> without a server/backend/REST-API and without a central database.
>
> If you stash your entire Backend inside Frontend you get "Blockend".
### browser apps
- 200 stars
In-browser knowledge base on top of local plain-text files
based on react
### solidjs
lazy loading, infinite scroll
drag and drop toolkit
### dataviz
interactive graphs
similar to d3.js
could be useful for alchi-maps, would need to render an infinite pattern
(the pallas pattern)
via
### mindmap, journal, diary, notes
- 15K stars
Organize world's knowledge, explore connections and curate learning
paths
knowledge graph
based on solidjs
associative note-taking application
Novel fusion of hierarchical and graph-based approaches to taking notes,
based on ideas from Roam Research, TheBrain and others
similar: zettelkasten, roam research
Offline-first note taking and knowledge management application for
desktop and the web. Supports nested notebooks, tags, real-time sync,
images and file attachments. Optimised for efficiency with keyboard
navigation, full-text search and version control. Never lose a thought.
Private, fast, notorious
### knowledge management
aka: collaboration, teamwork
usually overfeatured for my use case, still interesting
- desktop app
### rxdb
- 18K stars
A fast, offline-first, reactive database for JavaScript Applications
> Premium Plugins
> [IndexedDB RxStorage](https://rxdb.info/rx-storage-indexeddb.html)
found the problem. we need IndexedDB but it must be open source, not
"Premium"
------------------------------------------------------------------------
\[Export of Github issue for
[milahu/alchi](https://github.com/milahu/alchi).\]