1
0
Fork 0
mirror of https://github.com/heyarne/airsonic-ui.git synced 2026-05-06 18:33:38 +02:00

Add loading indicator to breadcrumbs (#29)

Also moves the current route data into a level 3 subscription (finally).
This commit is contained in:
Arne Schlüter 2018-10-17 12:58:37 +02:00 committed by GitHub
commit ec4504e475
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
5 changed files with 83 additions and 35 deletions

View file

@ -1,16 +1,21 @@
(ns airsonic-ui.views.breadcrumbs
(:require [airsonic-ui.routes :as routes :refer [url-for]]))
(:require [re-frame.core :refer [subscribe]]
[airsonic-ui.routes :as routes :refer [url-for]]
[airsonic-ui.views.loading-spinner :refer [loading-spinner]]))
;; Breadcrumbs are implemented in such a way that they provide a stringent
;; hierarchy no matter how you came to the url. They should allow easy
;; navigation upwards that hierarchy (e.g. album -> artist)
(defn- bulma-breadcrumbs [& items]
[:div.container>nav.breadcrumb {:aria-label "breadcrumbs"}
[:ul
(for [[idx [href label]] (map-indexed vector (butlast items))]
[:li {:key idx} [:a {:href href} label]])
[:li.is-active>a (last items)]]])
(let [content-pending? @(subscribe [:api/content-pending?])]
[:div.container
[:nav.breadcrumb {:aria-label "breadcrumbs"}
[:ul
(for [[idx [href label]] (map-indexed vector (butlast items))]
[:li {:key idx} [:a {:href href} label]])
[:li.is-active>a (last items)
(when content-pending? [loading-spinner])]]]]))
(defmulti breadcrumbs
(fn dispatch-on [[route-id] content] route-id))