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/fbbbd/fbbbd290776fb2b671eb3f275f4a352aaae0d172" alt="Now playing "{: class="zoom" }
data:image/s3,"s3://crabby-images/1ccd2/1ccd22d93bfa965a762701eefafb96f81631f72c" alt="Queue "{: class="zoom" }
data:image/s3,"s3://crabby-images/0e8f1/0e8f15e86c931620448ce6ef8dc767af2a9979f6" alt="Music browse "{: class="zoom" }
data:image/s3,"s3://crabby-images/c98c1/c98c1469edc45418cbdb663eadc4d2f4a9803557" alt="Music artists "{: class="zoom" }
data:image/s3,"s3://crabby-images/c613e/c613ec5478e2c057c607d4cfc19724bae0cdab0e" alt="Music artist "{: class="zoom" }
data:image/s3,"s3://crabby-images/c8990/c89909e138dd814388838d7d3c558817dbe4c3e6" alt="Music albums "{: class="zoom" }
data:image/s3,"s3://crabby-images/28fe6/28fe61ef346df8ba1b3dd7c908b1e6792ef12322" alt="Music albums options "{: class="zoom" }
data:image/s3,"s3://crabby-images/05a37/05a3728e5d770a1bb96e7ba9177119aa19e180c3" alt="Music album "{: class="zoom" }
2024-02-28 13:34:42 +01:00
data:image/s3,"s3://crabby-images/ff807/ff8073d9a8cf42422516e93ac86a4184ce479cbd" alt="Spotify "{: class="zoom" }
2022-03-20 12:00:31 +01:00
data:image/s3,"s3://crabby-images/a2b6b/a2b6b83431c85218904e69b7e56bfc451cac45fb" alt="Audiobooks authors "{: class="zoom" }
data:image/s3,"s3://crabby-images/9d7b3/9d7b3d09cd53af2e4fe3b106de0579dd156387d1" alt="Audiobooks "{: class="zoom" }
data:image/s3,"s3://crabby-images/61ca7/61ca73badb1ae3dddd2555c59e0c301a1af4aed2" alt="Podcasts "{: class="zoom" }
data:image/s3,"s3://crabby-images/ae796/ae796f252dafdc1f9fa8830713b61997de747724" alt="Podcast "{: class="zoom" }
data:image/s3,"s3://crabby-images/aae9b/aae9b4be23473e35a790aee53167dd0958b4c413" alt="Files "{: class="zoom" }
data:image/s3,"s3://crabby-images/e2bdf/e2bdf85c217c020cdc47a92c9f6b3b029125a74d" alt="Search "{: class="zoom" }
data:image/s3,"s3://crabby-images/6a5b4/6a5b4b5c355b92d8d010997f4701d59bc7b2ef05" alt="Menu "{: class="zoom" }
data:image/s3,"s3://crabby-images/bdd0c/bdd0c215e10f9affcf7c546b4529b952fcb389d0" 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` .