mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-21 02:22: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/fb8f8/fb8f80c179c14df1a66d2e6ae51cb67a261e8e41" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e1ad8/e1ad8f9ee7402913ce6abe2be37a299be87e1e74" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0474e/0474efdf28b9a0d9c7a9ebff4908be2459216bed" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/45a99/45a995013dbd78ac7f17ae2127b4b5764dc7c020" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c080a/c080a6f5885c2cbf21485d88e63e4c4abff2d343" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c34a2/c34a2513b098e499e74bddffb9f94cb17654510f" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2c8d1/2c8d17d61b209b43ac4f6580a4e4bcacafaa70ef" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e4c6f/e4c6f4167307156d26161f12a67a0b7a2079eb52" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0594d/0594da1f648a0896716ad88ddb54f11616c6b341" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/de291/de291b93158ffe050fafed4938a295f4396ffb55" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/86724/867248aeb62e5579a0cdd15c3c833c40af6d7e83" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2c7da/2c7da03703d2371ce3f0c886e0ed0286d5e3b36f" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/6ab09/6ab09e7aa6b9ddd5995e1ebe9c557460097f2fd3" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/87456/8745613981e0477be5d95061a5c3db9331f2de2e" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/52566/52566719713e7ad1f0e70863df54be27e2533cf7" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e9889/e98892a4265aeaf1ca187704bb562c5420ba674f" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/bbcd6/bbcd61186cebfc29723510471062f3b6b68c791f" 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`.
|