Skip to main content

The Music Assistant frontend

Project description

Music Assistant frontend (Vue PWA)

The Music Assistant frontend/panel is developed in Vue, development instructions below.

Recommended IDE Setup

VSCode + Volar (and disable Vetur) + TypeScript Vue Plugin (Volar).

Type Support for .vue Imports in TS

TypeScript cannot handle type information for .vue imports by default, so we replace the tsc CLI with vue-tsc for type checking. In editors, we need TypeScript Vue Plugin (Volar) to make the TypeScript language service aware of .vue types.

If the standalone TypeScript plugin doesn't feel fast enough to you, Volar has also implemented a Take Over Mode that is more performant. You can enable it by the following steps:

  1. Disable the built-in TypeScript Extension
    1. Run Extensions: Show Built-in Extensions from VSCode's command palette
    2. Find TypeScript and JavaScript Language Features, right click and select Disable (Workspace)
  2. Reload the VSCode window by running Developer: Reload Window from the command palette.

Customize configuration

See Vite Configuration Reference.

Project Setup

nvm use node
yarn install

Compile and Hot-Reload for Development

yarn dev

This will launch an auto-reload development environment (usually at http://localhost:3000) Open the url in the browser and a popup will ask the location of the MA server. You can either connect to a locally launched dev server or an existing running server on port 8095.

Type-Check, Compile and Minify for Production

yarn build

Lint with ESLint

yarn lint

UI Framework

This project is migrating from Vuetify to shadcn-vue as its primary UI component library.

Development Guidelines

Components

  • Size limit: Keep components under 300–400 lines. If a component grows beyond this, split it into smaller, focused sub-components.
  • Single responsibility: Each component should do one thing well. Extract repeated logic or UI patterns into reusable components.
  • Composition over complexity: Prefer composing small components rather than building monolithic ones with many responsibilities.

UI Components

  • Use shadcn-vue: All new UI should use shadcn-vue components located in src/components/ui/. Do not introduce new Vuetify components.
  • Extend, don't override: If a shadcn-vue component needs customization, extend it via props or slots rather than overriding styles globally.
  • Avoid inline styles: Use Tailwind utility classes for styling. Avoid style="" attributes except for dynamic values that cannot be expressed as classes.

TypeScript

  • Always type props and emits: Define explicit types for all component props and emits — avoid any.
  • Prefer interface for object shapes: Use interface for defining data shapes and type for unions/intersections.
  • No implicit any: Every function parameter and return value should be typed or clearly inferrable.

State & Composables

  • Extract reusable logic into composables: Any stateful logic shared between two or more components belongs in a composable under src/composables/.
  • Keep <script setup> lean: Heavy logic (data fetching, transformations) should live in composables, not inline in the component.

Helpers & Utilities

  • Pure functions go in src/helpers/: Any standalone utility function (e.g. string manipulation, date formatting, data transformation) must be placed in src/helpers/ rather than inlined in a component or composable.
  • One file per concern: Group related helpers in a named file (e.g. src/helpers/string.ts, src/helpers/date.ts). Avoid a single catch-all utils.ts.
  • Test every helper: Each helper file must be covered by unit tests. For new helpers, add a corresponding test file colocated with the helper (e.g. src/helpers/string.test.ts). Existing tests under tests/helpers/ may remain, but new tests should follow the colocated pattern. Helpers with no test coverage should not be merged.

API Calls & User Feedback

  • Always show feedback on API calls: Every API call must be wrapped with user feedback:
    • On success: call toast.success(...) with a clear confirmation message.
    • On failure: call toast.error(...) with a meaningful error message — never silently swallow errors.
  • Example pattern:
    try {
      await api.doSomething()
      toast.success("Action completed successfully")
    } catch (e) {
      toast.error("Failed to complete action")
    }
    
  • Do not use console.error as a substitute for user-facing feedback on API errors (or for meaningful calls).

General Best Practices

  • No magic numbers/strings: Extract constants with descriptive names.
  • Meaningful naming: Variables, functions, and components should clearly describe their purpose. Avoid abbreviations unless universally understood.
  • Keep templates readable: If a template expression is complex, move it to a computed property.
  • Clean up side effects: Always clean up event listeners and intervals in onUnmounted; manually created watchers outside component setup or manual effect scopes must also be cleaned up.
  • Accessibility: Use semantic HTML elements and provide aria-* attributes where appropriate.

Translation Management

We use Lokalise to manage the translation files for the Music Assistant frontend

Lokalise logo

Contributing

If you wish to assist in translating Music Assistant into a language that it currently does not support, please see here https://music-assistant.io/help/lokalise/.


A project from the Open Home Foundation

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

music_assistant_frontend-2.17.143.tar.gz (5.0 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

music_assistant_frontend-2.17.143-py3-none-any.whl (5.1 MB view details)

Uploaded Python 3

File details

Details for the file music_assistant_frontend-2.17.143.tar.gz.

File metadata

File hashes

Hashes for music_assistant_frontend-2.17.143.tar.gz
Algorithm Hash digest
SHA256 fc0954c113595e78e4b8dc28f7e280a8a439e6676dde665f97618a2bd7f573dd
MD5 11e30cc015a297b91ee4a0d7704b30e6
BLAKE2b-256 e8a0d800fcc690b8a967e053a0ff6d8d13cc7a46d68ef306f4cb6541e1f77c99

See more details on using hashes here.

File details

Details for the file music_assistant_frontend-2.17.143-py3-none-any.whl.

File metadata

File hashes

Hashes for music_assistant_frontend-2.17.143-py3-none-any.whl
Algorithm Hash digest
SHA256 84dcf1e27ba20c85a9b7beea0b7ff168e993a03930bff50709520e25789bab2f
MD5 143c4d4d97b5d5d34d7f18fea7ce88a2
BLAKE2b-256 4aa188ac2d9e1dfc47f0c580aa2b9e06b080e857d194d6ff5da5c3ba2baae44e

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page