mirror of
https://github.com/owntone/owntone-server.git
synced 2025-03-01 14:29:15 -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/6011e/6011efe4333ea5fefe8bde33b37c5ad3742256cb" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f62a7/f62a7750d811b62b53c0db209b1349c3715d1053" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/054a2/054a2a7fa116b22fc713a61bdd45c901f421f1e5" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/dc91b/dc91b9aa50fc308dc07633c2d0fd9c3e96ea1ac5" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/889ea/889eae024aceb5e75b17fd09ff406e897683d038" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/60c84/60c84c0e53f353f76a3486264aa4547514d168b9" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/96a81/96a81f58b6ac304f1c07925797c13a2c5916a140" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/b4616/b4616e2f4ceaa2122d67758a33ed4e07d0819a5d" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/affba/affbae8b33587a1640e704590e9a0aa5ef0275ba" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/94523/9452378e995c03568bbde1cd85bfd8ead67e92e6" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/31772/31772f4dac1f5aa76500118b59f1658df727450d" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/cc64d/cc64dfe0a7a31425814c9496d90a58cfaa62dfd1" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/4ca1d/4ca1de7c8c25ba20916bd285b5fdd69ea60ffdc5" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c7326/c7326ec9fa6c19d616746572fef84784b9f158f7" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/897c8/897c879d22f9108329ea5231436469cf51c97e17" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/b4ce6/b4ce69cf59065cedecb58cbcb86aa4f7ae73b137" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/08658/08658f0dd148f1ee668f7dc1f8b7beed50165b57" 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`.
|