A nimble Mastodon web client
 
 
 
 
 
Go to file
Emanuel Pina 015d8a944e
fix(i18n): update portuguese from Portugal translation (#1788)
2023-02-20 07:06:01 +01:00
.github
.stackblitz
.vscode chore(i18n): `en` as source language (#1597) 2023-02-18 12:21:09 +01:00
components feat(pwa): add FAQ to PWA docs and link on push subscription error (#1767) 2023-02-17 12:11:19 +01:00
composables refactor: inject pwa client plugin from module (#1758) 2023-02-16 10:23:26 +01:00
config feat(i18n): add Euskara/Basque localisation (#1779) 2023-02-18 16:40:28 +01:00
constants
docs docs(pwa): typo in `Other browsers on iOS` entry (#1783) 2023-02-18 13:01:17 +01:00
https-dev-config
images
layouts
locales fix(i18n): update portuguese from Portugal translation (#1788) 2023-02-20 07:06:01 +01:00
middleware refactor: move single instance config to runtime (#1664) 2023-02-07 04:10:43 -08:00
mocks
modules refactor: upgrade stale-dep 2023-02-17 15:17:47 +01:00
pages fix: better loading handling on status page (#1729) 2023-02-17 23:11:35 +01:00
patches
plugins refactor: inject pwa client plugin from module (#1758) 2023-02-16 10:23:26 +01:00
public
public-dev
public-staging
scripts fix: installing deps on main error (#1790) 2023-02-18 13:44:28 +01:00
server fix: use callback url with route param rather than query 2023-02-12 13:18:07 +01:00
service-worker
styles
tests
types feat: add translation status to language settings (#1717) 2023-02-11 21:42:55 +01:00
utils
.dockerignore
.env.example refactor: move single instance config to runtime (#1664) 2023-02-07 04:10:43 -08:00
.env.mock
.eslintignore feat: add translation status to language settings (#1717) 2023-02-11 21:42:55 +01:00
.eslintrc
.gitignore feat: add translation status to language settings (#1717) 2023-02-11 21:42:55 +01:00
.npmrc
.nvmrc chore: add .nvmrc to ensure node v18 (#1579) 2023-02-08 10:23:07 +01:00
.stackblitzrc
CODE_OF_CONDUCT.md chore: add code of conduct (#1743) 2023-02-13 02:11:06 -08:00
CONTRIBUTING.md docs: Readme.md for docs and guide/index additions (#1773) 2023-02-17 17:32:45 +01:00
Dockerfile
LICENSE
README.md docs: add PWA cookbook (#1747) 2023-02-15 13:07:30 +01:00
app.vue
docker-compose.yaml
elk.svg
emoji-mart-traslation.d.ts feat(i18n): Emojimart localization and `fetching` entry at `en` … (#1731) 2023-02-15 20:15:11 +01:00
error.vue
netlify.toml
nuxt.config.ts refactor: specific package manager for stale-dep 2023-02-17 15:30:23 +01:00
package.json chore: upgrade nuxt devtools 2023-02-18 10:57:09 +01:00
page-lifecycle.d.ts
pnpm-lock.yaml chore: upgrade nuxt devtools 2023-02-18 10:57:09 +01:00
pnpm-workspace.yaml
shims.d.ts refactor: inject pwa client plugin from module (#1758) 2023-02-16 10:23:26 +01:00
tsconfig.json
unocss.config.ts fix: prevent videos from clipping when in fullscreen mode (#1397) 2023-02-07 06:32:37 -08:00
vitest.config.mjs

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:

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 Syntax Highlighter
  • vite-plugin-pwa - Prompt for update, Web Push Notifications and Web Share Target API

👨‍💻 Contributors

📄 License

MIT © 2022-PRESENT Elk contributors