A nimble Mastodon web client
Find a file
2022-12-04 19:56:33 +00:00
.github ci: remove WIP 2022-12-02 16:13:33 +08:00
.vscode feat(editor): select language 2022-11-30 06:47:24 +08:00
components feat: make internal app URLs permalinks (#329) 2022-12-04 19:56:33 +00:00
composables feat: make internal app URLs permalinks (#329) 2022-12-04 19:56:33 +00:00
constants fix: improve permalink handling somewhat 2022-12-01 22:59:08 +00:00
layouts feat: adapt safe area for mobile 2022-12-04 23:35:11 +08:00
locales feat: content filters (#279) 2022-12-04 20:28:26 +01:00
middleware feat: make internal app URLs permalinks (#329) 2022-12-04 19:56:33 +00:00
modules feat: french translation (#300) 2022-12-02 21:27:58 +01:00
pages feat: make internal app URLs permalinks (#329) 2022-12-04 19:56:33 +00: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 chore: format styles 2022-12-05 03:06:02 +08: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 ci: force sort locales 2022-12-02 16:43:01 +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: show commit id (#331) 2022-12-05 02:18:39 +08:00
package.json feat: content filters (#279) 2022-12-04 20:28:26 +01:00
pnpm-lock.yaml feat: content filters (#279) 2022-12-04 20:28:26 +01: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 style: different borders for Following and Mutuals 2022-12-02 22:38:27 +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