A nimble Mastodon web client
Find a file
2022-11-29 20:12:29 +08:00
.github chore: format files 2022-11-29 04:22:06 +08:00
.vscode feat: more i18n and sort keys 2022-11-29 14:57:32 +08:00
components refactor: unify prefix of icon name 2022-11-29 20:06:08 +08:00
composables fix: icon in command palette 2022-11-29 20:12:29 +08:00
constants feat: toggleable feature flags (#209) 2022-11-28 23:57:27 +01:00
layouts feat: command palette (#200) 2022-11-29 16:15:05 +08:00
locales i18n: remove key reference 2022-11-29 20:07:38 +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: command palette (#200) 2022-11-29 16:15:05 +08:00
plugins chore: use pinia for command registry (#223) 2022-11-29 20:01:05 +08:00
public feat: use blue favicon for dev/preview mode 2022-11-27 23:09:18 +00:00
scripts feat: support codeblock 2022-11-24 11:42:03 +08:00
server refactor: move url choice into nuxt config 2022-11-28 23:21:33 +00:00
styles fix: line height in content editor (#208) 2022-11-28 23:22:43 +00:00
tests feat: improve code block parsing 2022-11-27 14:16:02 +08:00
types refactor: improve UI & types 2022-11-24 23:48:58 +08:00
.env.example chore: update env example 2022-11-28 15:25:20 +08:00
.env.mock feat: mock user in dev (#221) 2022-11-29 10:43:01 +01:00
.eslintrc feat: support paginator in local timeline 2022-11-26 12:08:17 +08:00
.gitignore chore: install inspect 2022-11-27 14:54:56 +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 feat: custom error page (#178) 2022-11-28 09:01:14 +00:00
error.vue feat: custom error page (#178) 2022-11-28 09:01:14 +00: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: mock user in dev (#221) 2022-11-29 10:43:01 +01:00
package.json feat: mock user in dev (#221) 2022-11-29 10:43:01 +01:00
pnpm-lock.yaml feat: command palette (#200) 2022-11-29 16:15:05 +08:00
README.md docs: fix codeflow link to open a new pr 2022-11-29 04:36:54 +08: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 fix(a11y): enhance contrast of publish button (#162) 2022-11-27 13:37:06 +01:00
vitest.config.ts test: add more test for rich content 2022-11-25 16:56:18 +08:00

Vite logo


discord chat Start new PR in StackBlitz Codeflow


Elk

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 Vue 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