mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-21 02:22: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/36c27/36c27af9db29b7736a9b63c58368f4bae76aa9c2" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/94f67/94f670bb34ded40f00c12ab77d0701e39f74e290" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/57a7e/57a7e5063f8f44af6375c44d8cc198448dec5b7d" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2b2c9/2b2c9b1195fa39c1ea9a0f418b7fb3697ae769a1" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/244a4/244a47a5e0b7381b7a1953a4f11c9f9a8bcb29dd" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f1bc9/f1bc969049e20d5998467d73ff6724b0bff73c4e" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/45727/45727082526d50f9cd636623a276a38de43d81ae" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e6e65/e6e653313dead3b312a1d21e0eb6bf38aeb3dd55" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/66c12/66c12e491a783498f9203d8fc529040a7ed789be" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/49ff4/49ff4838e9b3862cc0b1068b9076bd06da69fd0e" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8822c/8822cd34d572339300f8900a0532f86bf1b93fc3" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/fee6d/fee6df46b675e170935e156263f3d0342fe2366e" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/262d8/262d8b47b2770dd22dd3fc83515b4e1978c56222" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d5ffa/d5ffa46a8a88aec83af9541968eeb76b7ac52ff6" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/657c8/657c8ae2ddb6dd287ae18e8aee5e22519bbde4bf" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/6e973/6e973580030112dab80c73080edaa3492f8b8e78" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/baefb/baefb89ffb0c1db8ac1225b343d6d649a1474683" 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`.
|