mirror of
https://github.com/owntone/owntone-server.git
synced 2025-03-02 14:59:15 -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/c94eb/c94ebf741ca1b7ca50dbabddfcdb4fd4cff9ab43" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/89175/891758822954f06d75b6d0c3fd23f73aa6f3d086" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/6b61f/6b61f4db28f7a4c6e47812cab5b305ea8335b87b" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0fdda/0fdda0298d1f17883e2ddadd484a7136d7bb7b83" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/16ecc/16eccec1280e923004411530edf26d59193a1efc" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c734b/c734b35ea3109c709bd4f8fb56c2be877e9350e7" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8caa7/8caa7b56dc394ddfe768e355b85b03f193368313" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/129c6/129c67a45c15f60794efb7dff1f4777abf2df325" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/28230/282305f2a041e25d42b848d4260a60f93f78244e" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ad5a5/ad5a5f9a9323d080a0b3adb51102364f9b389740" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/9d5cb/9d5cb08eff257df13110f00fcb86574889ff37f6" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/80eec/80eec7994aba67e044e7a158fd5e37565f3ba5c8" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/49830/498301b39a8f808bb22ea72d9189019890d6eb03" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/83882/83882a250d480d134231858d7a1143e58e71f156" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/b0fed/b0fed74dcdf001e93c64c08fe0d8ada5f704fede" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7b2ee/7b2ee02960ac06c0ec12e0495e53fcdc503a164b" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/277b6/277b61365cc59e7c76d7840f252216b2d6b32ca8" 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`.
|