mirror of
https://github.com/owntone/owntone-server.git
synced 2025-03-01 06:19:16 -05:00
78 lines
3.2 KiB
Markdown
78 lines
3.2 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://[your_server_address_here]:3689](http://[your_server_address_here]: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/b3154/b31546766e42175755d02596a6434bed1da6ba78" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7dc57/7dc571c2d00fbca38779d278cb842c2c532c8d79" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0bd2f/0bd2f1222552f632ab007a9d27e950bbb611fbd0" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/bda9f/bda9f5dea527e365a81f7d09201a4810ceebb760" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/70391/703910a36ed23d71a25a986373c84dcc9ae8ffd4" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a5a0c/a5a0c3b2cdcab5b2769e10f4c9b91a10f63b1eec" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c7ab6/c7ab6b1381caf579f9db3852379432282a2796af" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/27c77/27c77af472293e561598339f07ccaecb1e511c06" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/68a0d/68a0da2ac85e363e951adf9d77a602f6693aaed2" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/6b96f/6b96fb807627e20d1f6a91564c638d5bd5dced72" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/dff77/dff773906caa59af9d5c534773db2b9fd5bb6243" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7f53c/7f53cdfaac4abf2c22bcc6c9d6f0363414e50f3b" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e5fad/e5fad47aafb2904b9d18a4eac2fd6e96561aace2" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/6153e/6153e7bd8ef271928a98f8d7aeff032bdf69e4d8" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7ac79/7ac797df7774ccdacbb3badae9bfd7aafb785382" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/36f05/36f050af1cf229e3e9227027748acbf69bcf3af1" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2f510/2f5100036a268c07414eb8813da50240f7809cb2" 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://[your_server_address_here]:3689](http://[your_server_address_here]: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`.
|