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/7f6b6/7f6b65a16bb9a67a05c302ab694d24b4030f3a26" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a35f2/a35f21dce69e8c93538fde99235963407cefad8d" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d0817/d0817aed51e94628af47b1c96449021a2af85124" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/cd24b/cd24b02adbbc0e5404b3ac935792dcb40b9707b1" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/778e4/778e484f301db19c831d68c01163bbcdf46c3249" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/70f7b/70f7beb84ee98af6b4541cc676a5aa28324f7575" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2ede7/2ede703b698149a9b7c06a73d60f5503be2b9aab" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ac973/ac973eec88bd06ce722c3e1a2e7bf744ec5f48a4" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/dab49/dab49e80212434c329c2cf7674d65b7934b983f6" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/637ed/637edc506b3e7960902207cb3a146e4d324db131" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/9809c/9809cb0b7536847688d84b6c426acefc00b7543d" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/15a52/15a52b8eafc2aad22aa22c50019b2e4a08af95dd" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2ac79/2ac79795c8a3d81cf3b98a6b9ffc7056d9a7b9f6" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d3734/d3734646bcf38c2ec0f3aea6129aaf7e242dcceb" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/3efb7/3efb73d838beb42a806ece3a21f22e973e37c65b" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/3918c/3918c9c25a3cbbc12464227ccfddec32cd93e017" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2d6f0/2d6f0253f933702689702da30c5e2a8cad9e460f" 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`.
|