2024-02-28 13:34:42 +01:00
# Web Interface
2022-03-20 10:12:16 +01:00
Mobile friendly player web interface for [OwnTone ](http://owntone.github.io/owntone-server/ ) build
with [Vue.js ](https://vuejs.org ), [Bulma ](http://bulma.io ).
2022-03-20 12:00:31 +01:00
You can find the web interface at [http://owntone.local:3689 ](http://owntone.local:3689 )
2023-06-22 22:21:27 +02:00
or alternatively at http://SERVER_ADDRESS:3689.
2022-03-20 12:00:31 +01:00
Use the web interface to control playback, trigger manual library rescans, pair
with remotes, select speakers, authenticate with Spotify, etc.
2022-03-20 10:12:16 +01:00
## Screenshots
2022-03-20 12:00:31 +01:00
data:image/s3,"s3://crabby-images/3f26e/3f26e0e183ed18f2e95d2d2c1be01fd6d3c3c9bf" alt="Now playing "{: class="zoom" }
data:image/s3,"s3://crabby-images/1c7e7/1c7e7129d7fa903c8c08874432b74d878bae3c84" alt="Queue "{: class="zoom" }
data:image/s3,"s3://crabby-images/dec88/dec8803ef402aa036c61a1644642f525a7fb1419" alt="Music browse "{: class="zoom" }
data:image/s3,"s3://crabby-images/f3735/f373586db1040a0af0eca9b70844d434fde30530" alt="Music artists "{: class="zoom" }
data:image/s3,"s3://crabby-images/c9dbf/c9dbf0962e098e1ea5f6971fc1d5913854009749" alt="Music artist "{: class="zoom" }
data:image/s3,"s3://crabby-images/91066/910667488b408262f94b2cbef46b65a1d032c473" alt="Music albums "{: class="zoom" }
data:image/s3,"s3://crabby-images/78a2b/78a2b002a208b8c72be583360f2b34708c399eee" alt="Music albums options "{: class="zoom" }
data:image/s3,"s3://crabby-images/1fb61/1fb61ba745d6def0fa318e412b29f05900704c08" alt="Music album "{: class="zoom" }
2024-02-28 13:34:42 +01:00
data:image/s3,"s3://crabby-images/95abc/95abcd0e4fc42b5fb0e1093423b8feb0d1dcaf5a" alt="Spotify "{: class="zoom" }
2022-03-20 12:00:31 +01:00
data:image/s3,"s3://crabby-images/e3dca/e3dcae4575f0e88dfdf5089ca7681b1fd244fadc" alt="Audiobooks authors "{: class="zoom" }
data:image/s3,"s3://crabby-images/16e63/16e631dd695a46660807e53fdcd7f948a1ed82a7" alt="Audiobooks "{: class="zoom" }
data:image/s3,"s3://crabby-images/8ac26/8ac26064b64ed184e60a4c117ac8e07d6685b305" alt="Podcasts "{: class="zoom" }
data:image/s3,"s3://crabby-images/bdea2/bdea22e89170b657c731b61d7dd653793d79d7b1" alt="Podcast "{: class="zoom" }
data:image/s3,"s3://crabby-images/83770/837708dd066676431c118840a8c65fdf9f232f45" alt="Files "{: class="zoom" }
data:image/s3,"s3://crabby-images/8d1c4/8d1c4579d90824d520e59633f3a0a7afdefde3bf" alt="Search "{: class="zoom" }
data:image/s3,"s3://crabby-images/38380/38380770d2005571871b1e807f3b9b60ec527114" alt="Menu "{: class="zoom" }
data:image/s3,"s3://crabby-images/ebe7e/ebe7e30a83936c6ed38669e20b9c825f63f04a3e" alt="Outputs "{: class="zoom" }
2022-03-20 10:12:16 +01:00
## Usage
You can find OwnTone's web interface at [http://owntone.local:3689 ](http://owntone.local:3689 )
2023-06-22 22:21:27 +02:00
or alternatively at http://SERVER_ADDRESS:3689.
2022-03-20 10:12:16 +01:00
## Build Setup
The source is located in the `web-src` folder.
2024-02-28 13:34:42 +01:00
```bash
2022-03-20 10:12:16 +01:00
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/ )
2024-02-28 13:34:42 +01:00
```bash
2022-03-20 10:12:16 +01:00
# 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)
2024-02-28 13:34:42 +01:00
export VITE_OWNTONE_URL=http://owntone.local:3689 npm run serve
2022-03-20 10:12:16 +01:00
# 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 ).
2024-02-28 13:34:42 +01:00
By default it expects **OwnTone** to be running at [localhost:3689 ](http://localhost:3689 ) and proxies all
2022-03-20 10:12:16 +01:00
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` .