A fork of Elk, which is a nimble Mastodon web client https://yolk.ayo.run
Find a file
2025-07-27 18:39:04 +02:00
.github chore(deps): update actions/setup-node action to v4.4.0 (#3268) 2025-04-21 10:25:41 +01: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
app feat(yolk): replace client_name 2025-07-27 18:39:04 +02:00
config refactor: migrate to nuxt compatibilityVersion: 4 (#3298) 2025-05-20 14:05:01 +00:00
docs chore(deps): update devdependencies (#3323) 2025-07-21 18:23:05 +02: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
locales feat(yolk): change app name & logo 2025-07-27 10:50:27 +02:00
mocks fix: move to mocked-exports rather than implicit unenv dep (#3232) 2025-03-14 05:07:11 +00:00
modules refactor: migrate to nuxt compatibilityVersion: 4 (#3298) 2025-05-20 14:05:01 +00:00
patches chore: update @nuxtjs/i18n to 9.1.1 (#3078) 2024-12-08 08:14:32 +00:00
public feat(yolk): replace icons & logo 2025-07-27 18:38:45 +02:00
public-dev feat(yolk): replace icons & logo 2025-07-27 18:38:45 +02:00
public-staging feat(yolk): replace icons & logo 2025-07-27 18:38:45 +02:00
scripts refactor: migrate to nuxt compatibilityVersion: 4 (#3298) 2025-05-20 14:05:01 +00:00
server refactor: migrate to nuxt compatibilityVersion: 4 (#3298) 2025-05-20 14:05:01 +00:00
service-worker refactor: migrate to nuxt compatibilityVersion: 4 (#3298) 2025-05-20 14:05:01 +00:00
shared/types refactor: migrate to nuxt compatibilityVersion: 4 (#3298) 2025-05-20 14:05:01 +00:00
tests refactor: migrate to nuxt compatibilityVersion: 4 (#3298) 2025-05-20 14:05:01 +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: bump node version (#3227) 2025-03-06 14:34:45 +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 chore: pause codeflow (#3242) 2025-03-21 16:18:07 +00:00
docker-compose.yaml fix: extended docker-compose.yml to addres Bug #1696 (#1701) 2023-03-01 08:17:34 +01:00
Dockerfile chore: workaround for npm registry key change for Dockerfile 2025-02-03 12:48:39 +09: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
eslint.config.js chore: bump to eslint-config v2.8.0 (#2651) 2024-03-05 14:48:58 +00:00
LICENSE chore: add license 2022-11-24 11:53:23 +01:00
netlify.toml feat: redirect code.elk.zone to github repository (#3166) 2025-01-31 03:18:46 +00:00
nuxt.config.ts refactor: migrate to nuxt compatibilityVersion: 4 (#3298) 2025-05-20 14:05:01 +00:00
package.json chore(deps): update devdependencies (#3323) 2025-07-21 18:23:05 +02:00
page-lifecycle.d.ts chore: update nuxt to 3.10.3 (#2610) 2024-02-24 16:46:14 +00:00
pnpm-lock.yaml fix(deps): update dependency form-data to v4.0.4 [security] (#3338) 2025-07-22 08:27:17 +02:00
pnpm-workspace.yaml docs: add initial documentation (#842) 2023-01-08 22:42:59 +01:00
README.md chore(yolk): add background to README 2025-07-27 10:52:36 +02: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 v3 (#2984) 2024-09-30 08:11:56 +00:00
vitest.config.ts refactor: migrate to nuxt compatibilityVersion: 4 (#3298) 2025-05-20 14:05:01 +00:00
vue-compiler-options.d.ts fix: augment vueCompilerOptions in pkg-types 2023-07-31 17:15:53 +01:00

Yolk

Hi! Yolk is my custom fork of Elk, a nimble Mastodon client.

I decided to have a personal fork of Elk because I really like the cross-account functionalities I use it for (e.g., I can open the Explore tab of my fosstodon account, then engage in a post with my self-hosted account, etc)... but I find sometimes I want to change little things which will make the app a bit more opinionated on my tastes (e.g., icons, colors, spacing, etc)... and some behavioral features.

I think doing this will make me use it as my main app daily. I have been switching between multiple apps because each one have strengths & weaknesses of their own.

Crucial fixes (if I find them), quality of life improvements, and mastodon API feature parity will still go upstream to the main Elk project.

~ Ayo Ayco


⚠️ 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. create local storage directory for settings: mkdir elk-storage
  4. adjust permissions of storage dir: sudo chown 911:911 ./elk-storage
  5. start container: docker-compose up --build -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.

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.

🧑‍💻 Contributing

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

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