mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-21 18:42:31 -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/f6b2a/f6b2a74daaae1ec483849dcd3f75a984ea6a20a2" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d0b20/d0b20ce9eb8ba71c8d57138a0ac9f477d5821aea" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/74aef/74aefdd5260c7c2e72a15552f057ea5e8939fbd9" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0d34c/0d34ceff92aee454b72fa1f2a7e9c9b7015ab29f" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8e106/8e106353b9705147dee7f0846313dd13c132c0bc" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8713d/8713d9277dfd911ef711103a368e6e6f0544996a" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/1139c/1139c0af4da2b85595f08b229b3d5880f280a966" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/9b121/9b121cb93ea9b45882d5b7f9615b813ae474769a" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/55271/55271360c5df2618a2d14936b96193fd30aac26a" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2fddf/2fddff9562de69727d0e3fc3affab130c11c2461" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/4a3a9/4a3a9f10a68415a57ea4928c7f4730d66a7c086e" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c75d6/c75d62f48c3964d7ffbc80f8f1d60c8f9270c7d0" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/4380d/4380da13be6e23577e75ea242a900e9a3c3e0068" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2b105/2b105f49768cc81173217b06db0bbee31b2c5dac" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/3beec/3beece704a52dc0a4db7b240a271c114a83e2bed" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/75a8e/75a8e2dfa56d599446a4f11d1bebcf0fd4600a73" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/a6f29/a6f292165d45869c43485c791ef520a4471e31e4" 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`.
|