mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-28 13:59:18 -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/9612e/9612e51872d8f6eb18a3b1e79131ce4267e93931" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/43c5b/43c5bcaffd1db254b17f43df7dce63c75c2d7bb7" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/5c1c3/5c1c38d41136d1ee581d95ca8c91a02e1e1e3ee9" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/705f7/705f707d416de93b31572c6cb8b47200f4750149" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d5051/d5051a3f5af7373b75747a13728048d6b0146fc7" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c4481/c44816e4790b863ed524763e16e2ba76530ef8f2" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/627b2/627b28c233c7f34d66be9a60a0f1abb24b5cee95" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/89b63/89b63d3078db7d181c2ed61c83faaf1036146582" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/35a58/35a5838f607f208e5099374bc1a7cea1dff0f06c" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/3e560/3e560b4c5ec0b9757e8630497425f511eb35b6e3" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/c5980/c59800db1fc8197cb49e83c6e7f871a9cebd9ecb" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/0315c/0315c5bed367a4fd8d1528e8542640bc4a036228" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8ef4c/8ef4cfbab1e3c72d0f0407642fb78039a83be78d" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/14204/14204c2bf7172398dc03a8b7b01a09c3a08ac08f" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/220bb/220bbe2d7425b9bcacbca0284caa6f7b51563110" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2cab4/2cab4d5d9b2de092ab4ca4185c91247b2aae698d" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/5560c/5560cc50fa466d8926f0a32d2d2544d07ef66d39" 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`.
|