Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thisistonydang/liveview-svelte-pwa
Local-First LiveView Svelte ToDo App
https://github.com/thisistonydang/liveview-svelte-pwa
elixir liveview local-first phoenix pubsub pwa real-time svelte websocket
Last synced: about 1 month ago
JSON representation
Local-First LiveView Svelte ToDo App
- Host: GitHub
- URL: https://github.com/thisistonydang/liveview-svelte-pwa
- Owner: thisistonydang
- License: mit
- Created: 2023-12-24T05:22:32.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-09-26T20:38:49.000Z (4 months ago)
- Last Synced: 2024-12-01T16:43:58.247Z (about 1 month ago)
- Topics: elixir, liveview, local-first, phoenix, pubsub, pwa, real-time, svelte, websocket
- Language: Elixir
- Homepage: https://liveview-svelte-pwa.fly.dev
- Size: 3.63 MB
- Stars: 215
- Watchers: 9
- Forks: 22
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# Local-First LiveView Svelte ToDo App
This to-do app is a demo of an installable [Phoenix](https://www.phoenixframework.org/)
Progressive Web App ([PWA](https://developer.mozilla.org/en-US/docs/Web/Progressive_web_apps))
that can sync real-time across multiple devices while also being able to work locally offline.https://github.com/tonydangblog/liveview-svelte-pwa/assets/63323230/726487b0-926d-4f5d-b54a-e93dcdd9dc6a
## Detailed Video Walkthrough
[![Working in Elevators: How to build an offline-enabled, real-time todo app w/ LiveView, Svelte, & Yjs](https://img.youtube.com/vi/PX9-lq0LL9Q/maxresdefault.jpg)](https://www.youtube.com/watch?v=PX9-lq0LL9Q)
## Live Demo
A live demo of the app can be found [here](https://liveview-svelte-pwa.fly.dev/).
## Running Locally
You can run this app locally by following the steps below after cloning the repo.
1. Install the Phoenix dependencies.
```sh
mix deps.get
```2. Install the Node.js dependencies. The `--prefix assets` is required when running
the command from the root directory in order to install the dependencies in the
`assets` directory.```sh
npm install --prefix assets
```3. Create the database.
```sh
mix ecto.create
```4. Start the Phoenix server.
```sh
mix phx.server
```## Deploying the Project
To deploy this app to [Fly.io](https://fly.io/), run the following commands.
**Note:** You will need to have an account with Fly and
[`flyctl`](https://fly.io/docs/hands-on/install-flyctl/) installed.1. Remove the `fly.toml` file. A new one will be created when you run `fly launch`.
```sh
rm fly.toml
```2. Initialize and deploy the project. Fly will automatically detect the app type
and set up the necessary configuration. You can tweak the settings or stick with
the defaults, but make sure that a Postgres database is included in the
configuration settings.```sh
fly launch
```## Technologies Used
- Phoenix [LiveView](https://github.com/phoenixframework/phoenix_live_view),
[PubSub](https://hexdocs.pm/phoenix/channels.html#pubsub), and
[Ecto](https://github.com/elixir-ecto/ecto/tree/v3.11.1)/[PostgreSQL](https://www.postgresql.org/)
for real-time syncing and data persistence.
- [Svelte](https://svelte.dev/) (via [LiveSvelte](https://github.com/woutdp/live_svelte))
for the frontend UI and state management.
- [Service Workers](https://developer.mozilla.org/en-US/docs/Web/API/Service_Worker_API),
[Web Storage](https://developer.mozilla.org/en-US/docs/Web/API/Web_Storage_API), and
[IndexedDB](https://developer.mozilla.org/en-US/docs/Web/API/IndexedDB_API)
(via [y-indexeddb](https://github.com/yjs/y-indexeddb)) for offline support.
- [CRDTs](https://crdt.tech/) (via [Yjs](https://github.com/yjs/yjs)) to resolve conflicts between
distributed app states.## Inspired By
- Wout De Puysseleir - [LiveSvelte - Render Svelte directly into Phoenix LiveView with E2E reactivity.](https://www.youtube.com/watch?v=JMkvbW35QvA)
- Ryan Cooke - [Ryan Cooke - E2E Reactivity - using Svelte with Phoenix LiveView](https://www.youtube.com/watch?v=asm2TTm035o)
- Daniils Petrovs - [SvelteKit: From landing page to offline PWAs](https://speakerdeck.com/danirukun/svelte-hololive-fan-booth-project)## Contact
Created by [Tony Dang](https://tonydang.com). Please feel free send any questions or feedback to
[[email protected]](mailto:[email protected]).