mirror of
https://github.com/owntone/owntone-server.git
synced 2025-03-02 23:09:15 -05:00
78 lines
3.2 KiB
Markdown
78 lines
3.2 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://[your_server_address_here]:3689](http://[your_server_address_here]: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/86de9/86de9337288c9c5a3f968ab7d1559d52a375292c" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/dcb87/dcb8782739bf6bc5a5f5394db4305ad1cb14729c" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0ca87/0ca87e2fc346aff9e240b75010bd179f02b39b30" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/db775/db775918b6cf89a025f67b9d43f13d38ddb936f3" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/fcf53/fcf53d550a2ca8ece53b2cf1483fb36eacc02e1f" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7cdc2/7cdc25d73b1c0d78b373512ea2d042a7c51f91a5" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/b667a/b667a5d394674f42757ef29b1f198225fd7b0fe5" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a0d12/a0d1261525cbc58bcbf0ed51c185b93e6e1a28e0" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/37a2a/37a2ac5bb744a47ba745654a4092fb35dbb3a968" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0ac80/0ac805b59a8a3edb06fcfa28f446da642ad89b22" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/1d8e4/1d8e40b25a97a8bf0a22c9176db9151ac1eeb03b" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f1a56/f1a56a820735e5c365ef3e7a0a8b97b5aea0d58d" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/66276/66276340ff29aefb05898de166d61611ffefecae" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/17e51/17e51f2387bfc99d92f79eb9632ed79ba434f04d" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7adcb/7adcb16a136dbaf93f2073bd8e66210a5afec5d8" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ca1d6/ca1d6325edb9cf3a5a29ee2c88e02f663fa9ec10" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/622cb/622cbe23a3c14df2b5e7fca41f4316440b31cfc3" 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://[your_server_address_here]:3689](http://[your_server_address_here]: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`.
|