mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-21 10:32: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/d0be2/d0be26284afa849d42133beb32d7895e3246b9ed" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/6cb7d/6cb7deda1076426ddcf9c4551c9d176f86b3cc86" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c9ca3/c9ca3af9eb7c28d493bf7361e1faa41b974aa876" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0abeb/0abeb0fc10b4c6e3e567d0ce6908ea3cf3be673c" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a3d00/a3d008b3779ac870720108ca5eadff0f9667b39a" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e0e11/e0e11e3c3eb7f12106e31d8074b602d11c58c7cf" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f8910/f8910d50ce216b715e06e37322d7b3635fae9f60" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/65976/6597666f3877d78f82a52e06606910a3b329062d" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/38338/38338dabbe5b76085257c900a4448ea01a556633" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/aa069/aa0691e5fd3f64ee695af2d0843fc0d8dc848ac2" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/884ba/884ba2b66b101d649c6f48cc369365ecca323211" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/4f255/4f255406721b1516f5b28a0a2d4bddcc3e6623d2" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/6237b/6237b3c5081f4689653ef5bb7e663ccafa5e503d" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c8a45/c8a45abd4281160f6ce127bc5566203d3b7fe45c" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/1b996/1b9962e14780c659e13189be64454e8d98948a14" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/4dbc2/4dbc2878297967b5b842a42c78ca7c2c3a17a15f" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7d184/7d184cda73a2b0edd0bea00a0e1ffe287898cca6" 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`.
|