mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-20 18:12:32 -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/312c3/312c32088de588d6ee38088ab4b71e3fa889a890" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/62a08/62a082c73fcea9ff591199746aebe22d1a89e7e2" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8baab/8baab4b5fd8db50935abda04cccbac47e41be85e" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/cbb4e/cbb4e9f0a9b869f95cac9c2f7969c99bdc62c399" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/09693/09693f53ae936b115ee60866f5972ee50355db3d" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0c0a4/0c0a4fdbb31e9b7ba381ab45545355cfed12f5dc" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/5617a/5617ab9b82d03c13c2375608229944ef43fe545c" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c0cfd/c0cfdab43f57dfa2b546be56e6d81a19036aaa19" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/39590/395902e2a3aeae319a338cf9aa9cf6e9f5f6dcea" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/9aa34/9aa3409deeaa7af1b70c637f0fda70c05d2b364b" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a48f3/a48f3e6619c3c0e79a2f1b229364cd5ec2fb8c37" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8dec5/8dec586f339827ca096a637b1d4a69faca79a1bd" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a87b9/a87b90ed0eb6c00bae3e5276a0f9c6510bac5554" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a51f1/a51f19ded68de4f6b204c083c44653651919af16" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8e03f/8e03f16663231e254be3a5e11513b3241e50bf47" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7e621/7e6219be2e2cd078fa5e3b749ca81bfa0c195245" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/4abd7/4abd7465554f00ce81db30b7f6480ab90796d3cd" 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`.
|