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/2b9c9/2b9c996b8d6ea68eaef2f62ddd7cee6bf2657211" alt="Now playing "{: class="zoom" }
data:image/s3,"s3://crabby-images/a8152/a81523244944b5701b4cf2264460e15746191182" alt="Queue "{: class="zoom" }
data:image/s3,"s3://crabby-images/cfcfc/cfcfc35e5cb4c213c79c9d551fac9dff9bb033f3" alt="Music browse "{: class="zoom" }
data:image/s3,"s3://crabby-images/75fa6/75fa6d16a39acc15127df352f0ddcd6f0e113f31" alt="Music artists "{: class="zoom" }
data:image/s3,"s3://crabby-images/2dedc/2dedc09ba682ad39439f44fb7f6ecf5f76ac0d60" alt="Music artist "{: class="zoom" }
data:image/s3,"s3://crabby-images/c37e6/c37e6bf6ff0351a6cbd8a269558ec8f6dad985e8" alt="Music albums "{: class="zoom" }
data:image/s3,"s3://crabby-images/ca882/ca882f0329cef69a6420e02ee79379c5f18825e3" alt="Music albums options "{: class="zoom" }
data:image/s3,"s3://crabby-images/8cd65/8cd6546e18a447a100e22dcb6119167e207c6a3e" alt="Music album "{: class="zoom" }
2024-02-28 13:34:42 +01:00
data:image/s3,"s3://crabby-images/7c641/7c641c77a3c50f19117235416a42fbe6ff1adf77" alt="Spotify "{: class="zoom" }
2022-03-20 12:00:31 +01:00
data:image/s3,"s3://crabby-images/b953b/b953bab7d15c18abb43ced06144085d628804f6e" alt="Audiobooks authors "{: class="zoom" }
data:image/s3,"s3://crabby-images/c3ef5/c3ef546407861081c490d2721c1183f684462f10" alt="Audiobooks "{: class="zoom" }
data:image/s3,"s3://crabby-images/f1dd5/f1dd5a90314c05a570004f42ce8558ab200a682e" alt="Podcasts "{: class="zoom" }
data:image/s3,"s3://crabby-images/31c28/31c2801fcce71c759a8f28045fc2a63ab183cfb6" alt="Podcast "{: class="zoom" }
data:image/s3,"s3://crabby-images/42672/426723dfe43fa456eed3b7c3b8f08df072370358" alt="Files "{: class="zoom" }
data:image/s3,"s3://crabby-images/7b07c/7b07c7f12a357002d056f46a29cbdfbf6dff5405" alt="Search "{: class="zoom" }
data:image/s3,"s3://crabby-images/79662/796626d5b94e270631a0f50b17ea5ab6f6b5f894" alt="Menu "{: class="zoom" }
data:image/s3,"s3://crabby-images/95ecd/95ecd509c9740d129bbe124351ab11c307de200f" 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` .