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/7b0ed/7b0ed953434b85a17be7409f16b79ddfd59a0a33" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/ae71b/ae71badb7ffad0a5f5038c50614f667bfd679381" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/94bdf/94bdf6a2013561ee59deed9d343c4f2ae39ae145" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/f4ea9/f4ea97961555806bf44a50228c41b64f166a2626" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/da50f/da50f99474953a395ec9b26d4a54fb3e793c1364" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/eaab6/eaab6bb4cc1358d3fa04e9d9ff7f5bba3bd815b0" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/b2ac7/b2ac7e1502fd410aedebcd80fc6dffcbd872ffdb" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/7a8a5/7a8a54b38d88427d0c89525d313bca7bfebd1eba" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/36a65/36a657ae81c67cedeb2b348a99f82ae19d00c6cd" alt="Spotiy"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d92f6/d92f6d9cb5ee311ee38c83ca26bea9b10c6886c8" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/13c87/13c877325f1083bc9426047f605d53ba669078e1" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/045b8/045b84818d42cc65a4657c55de48f729e4667f4e" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e5d40/e5d405da10c113a0d7b1186cf00fa811d3030d4d" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/46084/460845e75ad45144a0d7e7257f876a1197bc2017" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/713ff/713ff90e493c46b15df898b5bfffde6b4dcc3ca8" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/08e37/08e371d73e21a70654a2a22b78f5707ad898c17f" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2eeb5/2eeb539dfe992c403a4fd44ba60b3311b0f09bce" 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`.
|