mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-21 18:42:31 -05:00
78 lines
3.1 KiB
Markdown
78 lines
3.1 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://SERVER_ADDRESS: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/672cf/672cf94729abb23adeed40cfafa745c64459b423" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/3cb81/3cb81d5e728997b3cc932016e0877aebc35228f9" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/74a86/74a863b4d4f0f49b1f463254d7f4250942a2ec34" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/157b5/157b5df93aec28a28b2e6489df8e467ea4d8fe87" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c1015/c10156e9681d97cbcc6675076b78d999e53729a2" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/358e5/358e56e1f96dfeffc30c5c14ec6cfae7ec33e5f9" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/39702/39702441c6196a6a70a3eb43f259d293d9f3bfc3" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/6e38a/6e38a933d17471a8b9b37a3b36912dd4c6d707ed" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/eb1de/eb1dec2cf060fb38fb89bd342aa01df44a9b0a46" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/99348/99348441e964d97bc3240dbaaafe977cc03e682b" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/04d3c/04d3cd03a3fa17653017366c4e1f67b760d1ee36" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/6c71b/6c71bb23bdc644038a7358d166900e4b5f5edf89" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/3664f/3664f10a17b3af10a92677ed27fa890b56c35133" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0a795/0a795db4b7295196e958e3f14c2a9c176231f721" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/99abe/99abecea6bf850da88860f6e61da6f9adbeb6e63" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/07f6c/07f6c489419766db52fcad40e300cebb05461d36" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c0623/c0623a4eb9ab2bc96160577108ba640e24f519f2" 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://SERVER_ADDRESS: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`.
|