A nimble Mastodon web client
 
 
 
 
 
Go to file
renovate[bot] 97826c00bc
chore(deps): update dependency eslint to ^9.11.1 (#2981)
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
2024-09-30 01:33:14 +00:00
.github chore: bump and patch dependencies to augment `vue` (#2918) 2024-08-16 13:31:43 +00:00
.stackblitz chore: make Codeflow bot comment every issue (#984) 2023-01-12 10:26:46 +01:00
.vscode chore: bump to eslint-config `v2.8.0` (#2651) 2024-03-05 14:48:58 +00:00
components fix: change page reload and account switch logic (#2975) 2024-09-25 15:55:32 +00:00
composables fix: change page reload and account switch logic (#2975) 2024-09-25 15:55:32 +00:00
config fix: add new service worker (#2971) 2024-09-23 12:45:46 +00:00
constants chore(deps): update dependency @antfu/eslint-config to ^2.19.0 (#2726) 2024-08-16 14:52:08 +00:00
docs chore(deps): update devdependencies (#2959) 2024-09-19 11:58:15 +00:00
https-dev-config feat: added a profile settings and settings nav (#432) 2022-12-26 09:50:11 +01:00
images docs: fix images in readme 2023-01-02 18:06:06 +01:00
layouts chore: unify script setup lang order (#2943) 2024-09-07 07:38:18 +00:00
locales fix(i18n): Fix redundant Japanese translation (#2938) 2024-09-02 06:54:39 +00:00
middleware chore: update nuxt to 3.10.3 (#2610) 2024-02-24 16:46:14 +00:00
mocks fix: fix emoji placement (#2626) (#2645) 2024-03-04 19:56:59 +00:00
modules fix: add new service worker (#2971) 2024-09-23 12:45:46 +00:00
pages fix: change page reload and account switch logic (#2975) 2024-09-25 15:55:32 +00:00
patches chore(deps): update dependency nuxt to ^3.13.1 (#2946) 2024-09-11 14:37:59 +00:00
plugins fix: change page reload and account switch logic (#2975) 2024-09-25 15:55:32 +00:00
public fix: add new service worker (#2971) 2024-09-23 12:45:46 +00:00
public-dev chore: add generate pwa icons script (#2130) 2023-05-29 16:52:27 +02:00
public-staging chore: add generate pwa icons script (#2130) 2023-05-29 16:52:27 +02:00
scripts chore(deps): update dependency nuxt to ^3.13.1 (#2946) 2024-09-11 14:37:59 +00:00
server fix: bump `unstorage` and address type issues (#2951) 2024-09-11 11:20:26 +00:00
service-worker fix: add new service worker (#2971) 2024-09-23 12:45:46 +00:00
styles fix(ui): add loading indicator (#2769) 2024-09-07 09:37:01 +00:00
tests chore(deps): update dependency @antfu/eslint-config to ^2.19.0 (#2726) 2024-08-16 14:52:08 +00:00
types feat: add threaded drafts & posts (#2715) 2024-04-08 09:53:26 +00:00
utils feat: bump to latest vue 3.4.19 (#2607) 2024-02-24 12:24:21 +00:00
.dockerignore refactor: migrate from shiki to shikiji (#2520) 2023-12-20 18:54:40 +00:00
.env.example feat: add Vercel KV (#2533) 2024-01-02 10:58:37 +00:00
.env.mock fix: key current instance on user server, not user id (#466) 2022-12-20 01:16:15 +01:00
.gitattributes chore: include `.gitattributes` for eol (#2606) 2024-02-23 13:32:51 +00:00
.gitignore feat: show emoji tooltip (#2485) 2023-12-22 12:16:46 +00:00
.npmrc chore: set package-manager-strict to false (#2873) 2024-05-28 14:23:45 +02:00
.nvmrc chore(deps): update dependency node to v20 (#2501) 2023-12-05 10:18:22 +00:00
.stackblitzrc feat: mock user in dev (#221) 2022-11-29 10:43:01 +01:00
CODE_OF_CONDUCT.md chore: add code of conduct (#1743) 2023-02-13 02:11:06 -08:00
CONTRIBUTING.md docs(contributing): update node and pnpm version (#2913) 2024-08-09 05:57:18 +00:00
Dockerfile chore: copy across `.npmrc` to docker build (#2152) 2023-06-08 10:53:33 +01:00
LICENSE chore: add license 2022-11-24 11:53:23 +01:00
README.md docs: add crab.bumscode.com to list of community elk deployments (#2887) 2024-06-17 17:34:59 +00:00
app.vue chore: update nuxt to 3.10.3 (#2610) 2024-02-24 16:46:14 +00:00
docker-compose.yaml fix: extended docker-compose.yml to addres Bug #1696 (#1701) 2023-03-01 08:17:34 +01:00
elk.svg refactor: compress svg files 2023-01-09 17:25:48 +08:00
emoji-mart-traslation.d.ts chore: update nuxt to 3.10.3 (#2610) 2024-02-24 16:46:14 +00:00
error.vue chore: update nuxt to 3.10.3 (#2610) 2024-02-24 16:46:14 +00:00
eslint.config.js chore: bump to eslint-config `v2.8.0` (#2651) 2024-03-05 14:48:58 +00:00
netlify.toml chore: bump to eslint-config `v2.8.0` (#2651) 2024-03-05 14:48:58 +00:00
nuxt.config.ts fix: fix invalid permissions-policy value for fullscreen (#2941) 2024-09-19 12:00:39 +00:00
package.json chore(deps): update dependency eslint to ^9.11.1 (#2981) 2024-09-30 01:33:14 +00:00
page-lifecycle.d.ts chore: update nuxt to 3.10.3 (#2610) 2024-02-24 16:46:14 +00:00
pnpm-lock.yaml chore(deps): update dependency eslint to ^9.11.1 (#2981) 2024-09-30 01:33:14 +00:00
pnpm-workspace.yaml docs: add initial documentation (#842) 2023-01-08 22:42:59 +01:00
shims.d.ts refactor: inject pwa client plugin from module (#1758) 2023-02-16 10:23:26 +01:00
tsconfig.json refactor: switch nuxt module of vue macros (#27) 2022-11-23 09:07:28 +01:00
unocss.config.ts chore(deps): update dependency @antfu/eslint-config to ^2.19.0 (#2726) 2024-08-16 14:52:08 +00:00
vitest.config.ts chore(tests): fix vitest can't terminate worker (#2644) 2024-03-04 16:41:38 +00:00
vue-compiler-options.d.ts fix: augment vueCompilerOptions in `pkg-types` 2023-07-31 17:15:53 +01:00

README.md

Elk logo

Elk alpha

A nimble Mastodon web client


discord chat Start new PR in StackBlitz Codeflow Open board on Volta


Elk screenshots

⚠️ Elk is in Alpha

It is already quite usable, but it isn't ready for wide adoption yet. We recommend you use it if you would like to help us build it. We appreciate your feedback and contributions. Check out the Open Issues and jump in the action. Join the Elk discord server to chat with us and learn more about the project.

Deployment

Official Deployment

The Elk team maintains a deployment at:

Self-Host Docker Deployment

In order to host Elk yourself you can use the provided Dockerfile to build a container with elk. Be aware, that Elk only loads properly if the connection is done via SSL/TLS. The Docker container itself does not provide any SSL/TLS handling. You'll have to add this bit yourself. One could put Elk behind popular reverse proxies with SSL Handling like Traefik, NGINX etc.

  1. checkout source git clone https://github.com/elk-zone/elk.git
  2. got into new source dir: cd elk
  3. build Docker image: docker build .
  4. create local storage directory for settings: mkdir elk-storage
  5. adjust permissions of storage dir: sudo chown 911:911 ./elk-storage
  6. start container: docker-compose up -d

[!NOTE] The provided Dockerfile creates a container which will eventually run Elk as non-root user and create a persistent named Docker volume upon first start (if that volume does not yet exist). This volume is always created with root permission. Failing to change the permissions of /elk/data inside this volume to UID:GID 911 (as specified for Elk in the Dockerfile) will prevent Elk from storing it's config for user accounts. You either have to fix the permission in the created named volume, or mount a directory with the correct permission to /elk/data into the container.

Ecosystem

These are known deployments using Elk as an alternative Web client for Mastodon servers or as a base for other projects in the fediverse:

Note: Community deployments are NOT maintained by the Elk team. It may not be synced with Elk's source code. Please do your own research about the host servers before using them.

πŸ’– Sponsors

We are grateful for the generous sponsorship and help of:

NuxtLabs

StackBlitz

And all the companies and individuals sponsoring Elk Team and the members. If you're enjoying the app, consider sponsoring us:

Or you can sponsor our core team members individually:

We would also appreciate sponsoring other contributors to the Elk project. If someone helps you solve an issue or implement a feature you wanted, supporting them would help make this project and OS more sustainable.

πŸ“ Roadmap

Open board on Volta

πŸ§‘β€πŸ’» Contributing

We're really excited that you're interested in contributing to Elk! Before submitting your contribution, please read through the following guide.

Online

You can use StackBlitz Codeflow to fix bugs or implement features. You'll also see a Codeflow button on PRs to review them without a local setup. Once the elk repo has been cloned in Codeflow, the dev server will start automatically and print the URL to open the App. You should receive a prompt in the bottom-right suggesting to open it in the Editor or in another Tab. To learn more, check out the Codeflow docs.

Open in Codeflow

Local Setup

Clone the repository and run on the root folder:

pnpm i
pnpm run dev

Warning: you will need corepack enabled, check out the Elk Contributing Guide for a detailed guide on how to set up the project locally.

We recommend installing ni, that will use the right package manager in each of your projects. If ni is installed, you can instead run:

ni
nr dev

Testing

Elk uses Vitest. You can run the test suite with:

nr test

πŸ“² PWA

You can consult the PWA documentation to learn more about the PWA capabilities on Elk, how to install Elk PWA in your desktop or mobile device and some hints about PWA stuff on Elk.

πŸ¦„ Stack

  • Vite - Next Generation Frontend Tooling
  • Nuxt - The Intuitive Web Framework
  • Vue - The Progressive JavaScript Framework
  • VueUse - Collection of Vue Composition Utilities
  • Pinia - The Vue Store that you will enjoy using
  • Vue Macros - More macros and syntax sugar for Vue
  • UnoCSS - The instant on-demand atomic CSS engine
  • Iconify - Iconify icon sets in JSON format
  • Masto.js - Mastodon API client in TypeScript
  • shiki - A beautiful yet powerful syntax highlighter
  • vite-plugin-pwa - Prompt for update, Web Push Notifications and Web Share Target API

πŸ‘¨β€πŸ’» Contributors

πŸ“„ License

MIT Β© 2022-PRESENT Elk contributors