mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-22 02:52:31 -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/03ae5/03ae547e9c42febd5822bf2e0b5bc85e5f7dcdfe" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/18980/18980a5515cab5535852019f9d7ce6ef1c9164ee" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/fbdb3/fbdb398d2329da6431982b7582d2b3319cd8d5a8" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/1b6cd/1b6cd8c7b52b5f1144c57567f69467048dec23b9" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8d817/8d817b02137935aaa26c56d0b3b9f4a9a3f47640" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0cee0/0cee00041f01f8b1560d85400bb4e6abe63bc2dc" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/10f0b/10f0b70f8d6fba7fce076938c034ca80489a5da4" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/23cb5/23cb514fac8cb27f5967340953844c0f2c9da9cd" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a9220/a92202680678a8557079c4aec417c12397a64696" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/676f0/676f0cb21a5520d9df145b89b3d1c5623f5e02ff" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/5991b/5991b5b58f6641802e6269a3601643c70b62688b" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/dc683/dc6836c89bdeb5d80c00ca8d9ccf7074eb7ab429" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/73eb6/73eb6d8adb9493c812b45799cfa9435702e020b8" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e15e5/e15e5a8c8905b33d1b4207d7feed70fd363ddf86" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/83a20/83a200ada1cd9f64bf1bb08698f35b77dd08262f" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e387d/e387dba0b826d28ef19dc16c985efc935bb4b070" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e1c5c/e1c5c291c474deeb923dd6a01228f73b9efe1a6e" 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`.
|