mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-22 11:02: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/fbd79/fbd795063c1988f94d6f5220e59f7cd710394bef" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/61d29/61d29527d26fd562267ea44091087c58150cad95" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f653e/f653e55906379529be4716fc5584f964c478ba31" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0bd2e/0bd2e68968aad2cea0cc0efd5d2e0097dcf6088f" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/b2aa7/b2aa79250e65bcd12b382e4a6f52d7265ed1adb6" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0b798/0b798a2a8fedfb2b1fbb358782e0c5c971823091" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/495ab/495ab9194efbb5f31e2155dfeeb72b5c84112fbf" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/1f2b7/1f2b790c7f1c14b65156bf580b74a8c830d680dd" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f38a0/f38a0649aa3c7974c7ff0221acb3fb211f15dcae" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7fa6b/7fa6b18c2788e7c3e6da47ebe427898165f17ebf" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/513b7/513b7b7dc16700838a3680dc941b58ad62e8da4f" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/99448/99448a02e3b7b9b8761b9b8ffd8cf3ff5a0a7548" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/efeb6/efeb6086a0b0e076fe591bd88b9ce5b7c11ba749" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/62979/62979e44efe65f7e090748cd9e614115d3702225" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/458b9/458b9085230390f511fa9c78c1fd89e58e44db23" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d0572/d05727bc6745c4e42a9eebfe9afcab09a45b7f41" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/3b085/3b08501dfab9561035d79c1a0c2121b3768c7325" 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`.
|