Better pagination behavior on filter change.
This commit is contained in:
@@ -40,6 +40,11 @@
|
||||
(fn [url]
|
||||
(.open js/window url)))
|
||||
|
||||
#_(re-frame/reg-fx
|
||||
:dispatch-sync
|
||||
(fn [event]
|
||||
(re-frame/dispatch-sync event)))
|
||||
|
||||
(re-frame/reg-fx
|
||||
:set-local-storage
|
||||
(fn [[name value]]
|
||||
|
||||
@@ -142,7 +142,9 @@
|
||||
(let [children (r/children (r/current-component))]
|
||||
[:> Consumer {}
|
||||
(fn [consume]
|
||||
(let [{:strs [on-params-change params check-boxes? on-check-changed checked] :as consume} (js->clj consume)]
|
||||
(let [on-check-changed (aget consume "on-check-changed")
|
||||
check-boxes? (aget consume "check-boxes?")
|
||||
checked (aget consume "checked")]
|
||||
(apply r/create-element "tr" #js {:className class}
|
||||
(when check-boxes?
|
||||
(r/as-element [:th {:style {:width "35px"}}
|
||||
|
||||
@@ -68,6 +68,7 @@
|
||||
(re-frame/reg-event-db
|
||||
::dispose
|
||||
(fn [db [_ id]]
|
||||
(println "TABLE" (::table-params db) (::table-params (update db ::table-params dissoc id)))
|
||||
(-> db
|
||||
(update ::data dissoc id)
|
||||
(update ::checked dissoc id)
|
||||
@@ -132,7 +133,9 @@
|
||||
(re-frame/reg-event-fx
|
||||
::filters-settled
|
||||
(fn [{:keys [db]} [_ id]]
|
||||
{:db (assoc-in db [::settled-filters id] @(re-frame/subscribe [::filters id]))}))
|
||||
{:db (-> db
|
||||
(assoc-in [::settled-filters id] @(re-frame/subscribe [::filters id]))
|
||||
(update-in [::table-params id ] dissoc :start))}))
|
||||
|
||||
(re-frame/reg-sub
|
||||
::settled-filters
|
||||
@@ -146,7 +149,8 @@
|
||||
[which val] (if (= 3 (count params))
|
||||
[(into [a] b) c]
|
||||
[[a] b])]
|
||||
{:db (assoc-in db (into [::filters id] which) val)
|
||||
{:db (-> db
|
||||
(assoc-in (into [::filters id] which) val))
|
||||
:dispatch-debounce
|
||||
{:event [::filters-settled id]
|
||||
:time 800
|
||||
|
||||
@@ -97,13 +97,13 @@
|
||||
::forward/register [{:id ::received
|
||||
:events #{::data-page/received}
|
||||
:event-fn (fn [[_ _ {:keys [data]}]]
|
||||
[::received data])}]
|
||||
:dispatch [::data-page/dispose :import-invoices]}))
|
||||
[::received data])}]}))
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
::unmounted
|
||||
(fn [cofx [_ params]]
|
||||
{::track/dispose {:id ::params}}))
|
||||
{::track/dispose {:id ::params}
|
||||
:dispatch [::data-page/dispose :import-invoices]}))
|
||||
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
|
||||
@@ -61,6 +61,7 @@
|
||||
(re-frame/reg-event-fx
|
||||
::mounted
|
||||
(fn [{:keys [db]} _]
|
||||
(println "MOUNTING")
|
||||
{::track/register [{:id ::params
|
||||
:subscription [::data-page/params :invoices]
|
||||
:event-fn (fn [params]
|
||||
@@ -195,7 +196,7 @@
|
||||
(defn unpaid-invoices-page [params]
|
||||
(r/create-class
|
||||
{:display-name "invoices-page"
|
||||
:component-will-unmount #(re-frame/dispatch [::unmounted])
|
||||
:component-will-unmount #(re-frame/dispatch-sync [::unmounted])
|
||||
:component-did-mount #(re-frame/dispatch [::mounted])
|
||||
:reagent-render
|
||||
(fn []
|
||||
|
||||
Reference in New Issue
Block a user