mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-19 01:22:34 -05:00
78 lines
3.1 KiB
Markdown
78 lines
3.1 KiB
Markdown
# OwnTone web interface
|
|
|
|
Mobile friendly player web interface for [OwnTone](http://owntone.github.io/owntone-server/) build
|
|
with [Vue.js](https://vuejs.org), [Bulma](http://bulma.io).
|
|
|
|
You can find the web interface at [http://owntone.local:3689](http://owntone.local:3689)
|
|
or alternatively at http://SERVER_ADDRESS:3689.
|
|
|
|
Use the web interface to control playback, trigger manual library rescans, pair
|
|
with remotes, select speakers, authenticate with Spotify, etc.
|
|
|
|
## Screenshots
|
|
|
|
data:image/s3,"s3://crabby-images/13eca/13eca1e2072a2ef6903272be335344957b3cf0cd" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/b63fc/b63fcbaaeea25dfa9932775d21eac483ee90da79" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/037df/037df95c6b66482bd57f6118197c7130807513db" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f196d/f196de5c8c94b8f6147af943278d0c510997745b" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f5b28/f5b28b9dc9c3b64de906199e6200ac4d4b692957" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a214e/a214e1d0536f64249df1d18b6ca440707e3a0f09" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/07540/075404b36158c5c26eabb4398a0ee0e46399c409" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/07ce2/07ce26e09f851db8a36b9b94dcdb1ccbf48d6a80" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/9b269/9b269149528e845461fd752b06e6e2e352e80e5d" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7ce5d/7ce5da66e8d388198a7fb9671d68298e2c753a0b" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/80f32/80f3261a7ee17e6002f5207b5b17e88c37c94a80" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0e98a/0e98afdaae12ed8893109db4055d0856f46d99a4" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c2514/c25142a0a2ba6cd3f20e7d675b88a40d27fe2300" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/51f4d/51f4d47156c9a6eb5d67da2e679279d62dbf69fd" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7e9c6/7e9c60f6a4401b54c998568f205efca902218fe5" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/1e533/1e53397a43e4fdc2bfa67f8ae46112745dccbbab" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f8dd9/f8dd9d874dd582b05df4199b0acccae582b27ef9" alt="Outputs"{: class="zoom" }
|
|
|
|
|
|
## Usage
|
|
|
|
You can find OwnTone's web interface at [http://owntone.local:3689](http://owntone.local:3689)
|
|
or alternatively at http://SERVER_ADDRESS:3689.
|
|
|
|
|
|
## Build Setup
|
|
|
|
The source is located in the `web-src` folder.
|
|
|
|
```
|
|
cd web-src
|
|
```
|
|
|
|
The web interface is built with [Vite](https://vitejs.dev/), makes use of Prettier for code formatting
|
|
and ESLint for code linting (the project was set up following the guide [ESLint and Prettier with Vite and Vue.js 3](https://vueschool.io/articles/vuejs-tutorials/eslint-and-prettier-with-vite-and-vue-js-3/)
|
|
|
|
``` bash
|
|
# install dependencies
|
|
npm install
|
|
|
|
# Serve with hot reload at localhost:3000
|
|
# (assumes that OwnTone server is running on localhost:3689)
|
|
npm run serve
|
|
|
|
# Serve with hot reload at localhost:3000
|
|
# (with remote OwnTone server reachable under owntone.local:3689)
|
|
VITE_OWNTONE_URL=http://owntone.local:3689 npm run serve
|
|
|
|
# Build for production with minification (will update web interface
|
|
# in "../htdocs")
|
|
npm run build
|
|
|
|
# Format code
|
|
npm run format
|
|
|
|
# Lint code (and fix errors that can be automatically fixed)
|
|
npm run lint
|
|
```
|
|
|
|
After running `npm run serve` the web interface is reachable at [localhost:3000](http://localhost:3000).
|
|
By default it expects **owntone** to be running at [localhost:3689](http://localhost:3689) and proxies all
|
|
JSON API calls to this location.
|
|
|
|
If the server is running at a different location you have to set the env variable `VITE_OWNTONE_URL`.
|