A nimble Mastodon web client
Find a file
2022-12-02 15:02:44 +08:00
.github chore: format files 2022-11-29 04:22:06 +08:00
.vscode feat(editor): select language 2022-11-30 06:47:24 +08:00
components refactor: modal dialog (#277) 2022-12-02 15:02:44 +08:00
composables feat: show and stream new notifications (#282) 2022-12-02 10:21:10 +08:00
constants fix: improve permalink handling somewhat 2022-12-01 22:59:08 +00:00
layouts feat: add offline check (#247) 2022-12-01 11:08:09 +08:00
locales feat(i18n): plurals support (#278) 2022-12-02 10:18:36 +08:00
middleware feat: disable SSR 2022-11-23 07:08:36 +08:00
modules refactor: drop Setup suffix for setup components 2022-11-25 16:08:30 +00:00
pages feat: show and stream new notifications (#282) 2022-12-02 10:21:10 +08:00
plugins fix: scrollToTop does not work as expected (#271) 2022-12-01 20:33:07 +08:00
public feat: use blue favicon for dev/preview mode 2022-11-27 23:09:18 +00:00
scripts chore: switch to shiki-es 2022-11-30 13:45:42 +08:00
server feat: Additional instance configuration (#260) 2022-11-30 22:17:20 +01:00
styles feat: direct messages bubbles (#262) 2022-12-01 08:32:07 +01:00
tests fix: render code block without language (#276) 2022-12-02 10:19:31 +08:00
types feat: improve editor 2022-11-30 12:50:29 +08:00
.env.example fix: move config into nuxt.config 2022-11-30 21:28:55 +00:00
.env.mock feat: mock user in dev (#221) 2022-11-29 10:43:01 +01:00
.eslintignore i18n: improve translations 2022-11-30 07:26:07 +08:00
.eslintrc feat: support paginator in local timeline 2022-11-26 12:08:17 +08:00
.gitignore chore: ignore vim temp files (#280) 2022-12-02 04:05:45 +08:00
.npmrc chore: enable shell emulator on windows and start preview with correct port 2022-11-26 18:13:47 +00:00
.stackblitzrc feat: mock user in dev (#221) 2022-11-29 10:43:01 +01:00
app.vue chore: fix lint 2022-12-01 23:42:03 +08:00
error.vue feat: i18n lazy load 2022-11-30 08:22:35 +08:00
html.d.ts chore: init 2022-11-13 13:34:43 +08:00
LICENSE chore: add license 2022-11-24 11:53:23 +01:00
netlify.toml chore: issue templates (#202) 2022-11-28 15:48:50 +01:00
nuxt.config.ts feat(i18n): plurals support (#278) 2022-12-02 10:18:36 +08:00
package.json chore: switch to shiki-es 2022-11-30 13:45:42 +08:00
pnpm-lock.yaml chore: switch to shiki-es 2022-11-30 13:45:42 +08:00
README.md chore: update readme 2022-12-01 20:59:57 +01:00
shims.d.ts feat: support attachment uploading 2022-11-24 01:17:54 +08:00
tsconfig.json refactor: switch nuxt module of vue macros (#27) 2022-11-23 09:07:28 +01:00
unocss.config.ts feat: direct messages bubbles (#262) 2022-12-01 08:32:07 +01:00
vitest.config.ts test: add more test for rich content 2022-11-25 16:56:18 +08:00

Elk

Vite logo


discord chat Start new PR in StackBlitz Codeflow


A nimble Mastodon web client made with 🧡

Elk is in early alpha, but it is already quite usable. We would love your feedback and contributions.

Check out the Open Issues and jump in the action. Join the Elk discord server to learn more and get involved!

The client is deployed to elk.zone, you can share screenshots on social media but avoid sharing this URL or the discord server until we open the repo.

Note

If you would like to contribute, until the repo is open, please create branches in the main repository and send a PR from there.

Contributing

Hi! 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.

Open in Codeflow

Local Setup

Clone the repository and run on the root folder:

pnpm i
pnpm run dev

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

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 Syntax Highlighter

License

MIT