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/f017c/f017c0613a29cc688a662270daaa2954e080079b" alt="Now playing "{: class="zoom" }
data:image/s3,"s3://crabby-images/242d5/242d5b09dc57863f6b41daa41f870c614d2c6016" alt="Queue "{: class="zoom" }
data:image/s3,"s3://crabby-images/9377a/9377a4930beb3d7656a0dcceedd2b8ef0ef8ee3d" alt="Music browse "{: class="zoom" }
data:image/s3,"s3://crabby-images/118b1/118b188643d918fa5662da3afc73950043b3a981" alt="Music artists "{: class="zoom" }
data:image/s3,"s3://crabby-images/d3e71/d3e718923f3da06e1877a2c4045ba2a83a20e0fb" alt="Music artist "{: class="zoom" }
data:image/s3,"s3://crabby-images/9f2c4/9f2c45b8e93dcdebe8b8a2bb6b450f14aef4db7b" alt="Music albums "{: class="zoom" }
data:image/s3,"s3://crabby-images/b10e2/b10e2fe19a0c73e717def3bd166d920b738bfbfc" alt="Music albums options "{: class="zoom" }
data:image/s3,"s3://crabby-images/10e4b/10e4b91d26ddeba7261f5ff418521ccf82a3abbb" alt="Music album "{: class="zoom" }
2024-02-28 13:34:42 +01:00
data:image/s3,"s3://crabby-images/ee0b6/ee0b69f07a2278fb326bbad6a3579c4a26198406" alt="Spotify "{: class="zoom" }
2022-03-20 12:00:31 +01:00
data:image/s3,"s3://crabby-images/597cc/597ccf2f25bf8d70575c8fc405cfcd464fec8ab8" alt="Audiobooks authors "{: class="zoom" }
data:image/s3,"s3://crabby-images/25f5f/25f5f33ccb25f9722a4961ed162f3bcc8981b9f0" alt="Audiobooks "{: class="zoom" }
data:image/s3,"s3://crabby-images/25568/25568eef362f70df140f50ccfc935f6198cf67d5" alt="Podcasts "{: class="zoom" }
data:image/s3,"s3://crabby-images/766b3/766b319baad3c5ec48d5f65c659329b679a6b1ed" alt="Podcast "{: class="zoom" }
data:image/s3,"s3://crabby-images/ac545/ac5457ef5f465f1cb0944cfb3c8eeb0ed57d2a2f" alt="Files "{: class="zoom" }
data:image/s3,"s3://crabby-images/b9b1a/b9b1a64e84743ebee3d8079fa2caef6e0ae3c43b" alt="Search "{: class="zoom" }
data:image/s3,"s3://crabby-images/61a0f/61a0f6d3ef213fdee407253714d1ee8e92d52809" alt="Menu "{: class="zoom" }
data:image/s3,"s3://crabby-images/53eaa/53eaa7b4132f19b669803f91b3ac688b26401b89" 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` .