mirror of
https://github.com/owntone/owntone-server.git
synced 2025-02-28 22:09:15 -05:00
124 lines
4.3 KiB
Markdown
124 lines
4.3 KiB
Markdown
# Web Interface
|
|
|
|
The web interface is a mobile-friendly music player and browser for OwnTone.
|
|
|
|
You can reach it at [http://owntone.local:3689](http://owntone.local:3689)
|
|
or depending on the OwnTone installation at `http://<server-address>:<port>`.
|
|
|
|
This interface becomes useful when you need to control playback, trigger
|
|
manual library rescans, pair with remotes, select speakers, grant access to
|
|
Spotify, and for many other operations.
|
|
|
|
## Screenshots
|
|
|
|
Below you have a selection of screenshots that shows different part of the
|
|
interface.
|
|
|
|
data:image/s3,"s3://crabby-images/a99af/a99aff682909788e2b21c6b1df32fc2849cd2f60" alt="Now playing"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/cc5de/cc5de0f82cbc4404f8e8976614a641d419de8810" alt="Queue"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/3e5c0/3e5c021e7b8304e027d14b3032b8feed624159bc" alt="Music browse"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/1cedf/1cedf2e4471b80cfdb2545bb8187d24f1c114bb8" alt="Music artists"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/eba80/eba803ebd0c4fe35c5378eabb351feea0333882d" alt="Music artist"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e9f3c/e9f3ccce9d86cf6bda61fbd9c8ec07f818a14202" alt="Music albums"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/9dbdb/9dbdbde37cc66305f0f1c82a276ad27b53526247" alt="Music albums options"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/9cac1/9cac157e44cdc3c169b7349ca580b646d878774f" alt="Music album"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/09ce9/09ce9d5bf7df3ad40f550cb794fb5edcaaf528c6" alt="Spotify"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/51f4c/51f4ce94e4c15792d28ab7ed2868d40bdb4eb1ab" alt="Audiobooks authors"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/399ca/399cad3a47ce66055d138aa885bd1e66da78626f" alt="Audiobooks"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/d6af7/d6af7ad3e01329f0857873e902ba10be4b0693ee" alt="Podcasts"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/5d751/5d75144e98dc5d3f6adf9c94ccdca1df3bf7843f" alt="Podcast"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/2e774/2e774e0499421ae7ddaf54e76b1fac7ca18f9d8e" alt="Files"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e4f43/e4f43ad552c0cca3c40efe1b8518f0f6201d48d7" alt="Search"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/8aad8/8aad8e47ec7a3b65c7860e1178eb94447a2d6442" alt="Menu"{: class="zoom" }
|
|
data:image/s3,"s3://crabby-images/e922e/e922e7b1e5b5e360fff8affe4ab667e46ff13ab1" alt="Outputs"{: class="zoom" }
|
|
|
|
## Usage
|
|
|
|
The web interface is usually reachable at [http://owntone.local:3689](http://owntone.local:3689).
|
|
But depending on the setup of OwnTone you might need to adjust the server name
|
|
and port of the server accordingly `http://<server-name>:<port>`.
|
|
|
|
## Building and Serving
|
|
|
|
The web interface is built with [Vite](https://vitejs.dev/) and [Bulma](http://bulma.io).
|
|
|
|
Its source code is located in the `web-src` folder and therefore all `npm`
|
|
commands must be run under this folder.
|
|
|
|
To switch to this folder, run the command hereafter.
|
|
|
|
```shell
|
|
cd web-src
|
|
```
|
|
|
|
### Dependencies Installation
|
|
|
|
First of all, the dependencies to libraries must be installed with the command
|
|
below.
|
|
|
|
```shell
|
|
npm install
|
|
```
|
|
|
|
Once the libraries installed, you can either [build](#source-code-building),
|
|
[format](#source-code-formatting), and [lint](#source-code-linting) the source
|
|
code, or [serve](#serving) the web interface locally.
|
|
|
|
### Source Code Building
|
|
|
|
The following command builds the web interface for production with minification
|
|
and stores it under the folder `../htdocs`.
|
|
|
|
```shell
|
|
npm run build
|
|
```
|
|
|
|
### Source Code Formatting
|
|
|
|
The source code follows certain formatting conventions for maintainability and
|
|
readability. To ensure that the source code follows these conventions,
|
|
[Prettier](https://prettier.io/) is used.
|
|
|
|
The command below applies formatting conventions to the source code based on a
|
|
preset configuration. Note that a additional configuration is made in the file
|
|
`.prettierrc.json`.
|
|
|
|
```shell
|
|
npm run format
|
|
```
|
|
|
|
### Source Code Linting
|
|
|
|
In order to flag programming errors, bugs, stylistic errors and suspicious
|
|
constructs in the source code, [ESLint](https://eslint.org) is used.
|
|
|
|
Note that ESLint has been configured following this [guide](https://vueschool.io/articles/vuejs-tutorials/eslint-and-prettier-with-vite-and-vue-js-3/).
|
|
|
|
The following command lints the source code and fixes all automatically fixable
|
|
errors.
|
|
|
|
```shell
|
|
npm run lint
|
|
```
|
|
|
|
### Serving
|
|
|
|
In order to serve locally the web interface, the following command can be run.
|
|
|
|
```shell
|
|
npm run serve
|
|
```
|
|
|
|
After running `npm run serve` the web interface is reachable at [localhost:3000](http://localhost:3000).
|
|
|
|
By default the above command expects the OwnTone server to be running at
|
|
[localhost:3689](http://localhost:3689) and proxies API calls to this location.
|
|
|
|
If the server is running at a different location you have to set the
|
|
environment variable `VITE_OWNTONE_URL`, like in the example below.
|
|
|
|
```shell
|
|
export VITE_OWNTONE_URL=http://owntone.local:3689
|
|
npm run serve
|
|
```
|