mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-22 02:52: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/8c0bf/8c0bfe04cfc03276cf4ff09b39103904f4cdd144" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f9c2e/f9c2e082ce0d91aedc35dd632b3ad765947868a8" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0a23a/0a23a485f470fd8ea5e989c95e711ea424f334c0" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d79f5/d79f5e32d5e6cf60bbae1f4859dfe852b8326b83" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/3b90d/3b90d56c206bc9d76669acaaa2a5c53c4bf688a0" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/b83bc/b83bcdf537006df076c72a18cff5a491f9cd6fc0" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/cee57/cee57a4de8d063a17616d3b5f82a824db191f215" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ff6bb/ff6bb383debc16a9fcf759b43321fa8fb3d5badc" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/74e40/74e4067cc22b479f84ebc573ba009eed59d9b25c" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/5d8ad/5d8ad7a83af08a6b93afd2def723cdc701bcaaaf" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/591fd/591fd144f825079ca5dbd04c3a261936d2c082f0" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c186b/c186b8ab435c6effbaff38ba609add578004624a" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/016b8/016b813250e16bc2c954e62e8f637246d26f6688" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/06f61/06f6165edd3b1b2bc94df8f3d8e18d1743200275" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/b5415/b541526bf5407ec4e6b7b5ffe7824de50e14daaa" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/063d5/063d54cbfef4399a07cfb051f0541c2cb8e9feee" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/03e18/03e1865c87c178539fe4b761ed3ecbb5977b9e1e" 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`.
|