adds support for bulk voids.
This commit is contained in:
@@ -284,7 +284,7 @@
|
||||
]]
|
||||
|
||||
[grid/body
|
||||
(for [{:keys [client payments expense-accounts invoice-number date due total outstanding-balance id vendor] :as i} invoices]
|
||||
(for [{:keys [id] :as i} invoices]
|
||||
^{:key id}
|
||||
[row {:invoice i
|
||||
:selected-client selected-client
|
||||
|
||||
@@ -1,59 +1,52 @@
|
||||
(ns auto-ap.views.pages.payments
|
||||
(:require [re-frame.core :as re-frame]
|
||||
[auto-ap.entities.clients :as client]
|
||||
[auto-ap.entities.vendors :as vendor]
|
||||
[reagent.core :as reagent]
|
||||
[goog.string :as gstring]
|
||||
[clojure.spec.alpha :as s]
|
||||
[vimsical.re-frame.cofx.inject :as inject]
|
||||
[auto-ap.views.components.sorter :refer [sorted-column]]
|
||||
[auto-ap.views.components.date-range-filter :refer [date-range-filter]]
|
||||
[auto-ap.views.components.layouts :refer [side-bar-layout]]
|
||||
[auto-ap.views.components.paginator :refer [paginator]]
|
||||
[auto-ap.views.components.sort-by-list :refer [sort-by-list]]
|
||||
[auto-ap.events :as events]
|
||||
[auto-ap.views.utils :refer [dispatch-event date->str bind-field nf with-user]]
|
||||
[auto-ap.utils :refer [by]]
|
||||
[auto-ap.views.pages.payments.side-bar :as side-bar]
|
||||
[auto-ap.views.pages.payments.table :as table]
|
||||
[auto-ap.views.pages.check :as check]
|
||||
[auto-ap.subs :as subs]
|
||||
[auto-ap.status :as status]
|
||||
[vimsical.re-frame.fx.track :as track]
|
||||
[auto-ap.effects.forward :as forward]
|
||||
[auto-ap.views.pages.data-page :as data-page]
|
||||
[clojure.set :as set]))
|
||||
(:require
|
||||
[auto-ap.effects.forward :as forward]
|
||||
[auto-ap.status :as status]
|
||||
[auto-ap.subs :as subs]
|
||||
[auto-ap.views.components.layouts :refer [side-bar-layout]]
|
||||
[auto-ap.views.components.modal :as modal]
|
||||
[auto-ap.views.pages.data-page :as data-page]
|
||||
[auto-ap.views.pages.payments.side-bar :as side-bar]
|
||||
[auto-ap.views.pages.payments.table :as table]
|
||||
[auto-ap.views.utils :refer [dispatch-event nf with-user]]
|
||||
[clojure.set :as set]
|
||||
[goog.string :as gstring]
|
||||
[re-frame.core :as re-frame]
|
||||
[reagent.core :as reagent]
|
||||
[vimsical.re-frame.fx.track :as track]))
|
||||
|
||||
(defn data-params->query-params [params]
|
||||
{:start (:start params 0)
|
||||
:per-page (:per-page params)
|
||||
:sort (:sort params)
|
||||
:client-id (:id @(re-frame/subscribe [::subs/client]))
|
||||
:vendor-id (:id (:vendor params))
|
||||
:payment-type (:payment-type params)
|
||||
:status (:status params)
|
||||
:exact-match-id (some-> (:exact-match-id params) str)
|
||||
:date-range (:date-range params)
|
||||
:amount-gte (:amount-gte (:amount-range params))
|
||||
:amount-lte (:amount-lte (:amount-range params))
|
||||
:check-number-like (str (:check-number-like params))
|
||||
:invoice-number (:invoice-number params)})
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
::params-change
|
||||
[with-user]
|
||||
(fn [{:keys [user db ]}[_ params]]
|
||||
{:graphql {:token user
|
||||
(fn [{:keys [user]}[_ params]]
|
||||
{:graphql {:token user
|
||||
:owns-state {:single [::data-page/page ::page]}
|
||||
:query-obj {:venia/queries [[:payment_page
|
||||
{:start (:start params 0)
|
||||
:per-page (:per-page params)
|
||||
:sort (:sort params)
|
||||
:client-id (:id @(re-frame/subscribe [::subs/client]))
|
||||
:vendor-id (:id (:vendor params))
|
||||
:payment-type (:payment-type params)
|
||||
:status (:status params)
|
||||
:exact-match-id (some-> (:exact-match-id params) str)
|
||||
:date-range (:date-range params)
|
||||
:amount-gte (:amount-gte (:amount-range params))
|
||||
:amount-lte (:amount-lte (:amount-range params))
|
||||
:check-number-like (str (:check-number-like params))
|
||||
:invoice-number (:invoice-number params)}
|
||||
[[:payments [:id :status :amount :type :check_number :s3_url
|
||||
[:bank-account [:name]]
|
||||
:date [:vendor [:name :id]] [:client [:name :id]]
|
||||
[:invoices [:invoice-id [:invoice [:invoice-number :id]]
|
||||
:amount]]
|
||||
[:transaction [:id :date]]]]
|
||||
:total
|
||||
:start
|
||||
:end]]]}
|
||||
:query-obj {:venia/queries [[:payment_page
|
||||
{:filters (data-params->query-params params)}
|
||||
[[:payments [:id :status :amount :type :check_number :s3_url
|
||||
[:bank-account [:name]]
|
||||
:date [:vendor [:name :id]] [:client [:name :id]]
|
||||
[:invoices [:invoice-id [:invoice [:invoice-number :id]]
|
||||
:amount]]
|
||||
[:transaction [:id :date]]]]
|
||||
:total
|
||||
:start
|
||||
:end]]]}
|
||||
:on-success (fn [result]
|
||||
(let [result (set/rename-keys (first (:payment-page result))
|
||||
{:payments :data})]
|
||||
@@ -62,14 +55,14 @@
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
::unmounted
|
||||
(fn [{:keys [db]} _]
|
||||
(fn [_ _]
|
||||
{:dispatch [::data-page/dispose ::page]
|
||||
::track/dispose {:id ::params}
|
||||
::forward/dispose {:id ::page}}))
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
::mounted
|
||||
(fn [{:keys [db]} _]
|
||||
(fn [_ _]
|
||||
{::track/register {:id ::params
|
||||
:subscription [::data-page/params ::page]
|
||||
:event-fn (fn [params]
|
||||
@@ -79,9 +72,82 @@
|
||||
:event-fn (fn [[_ {:keys [void-payment]}]]
|
||||
[::data-page/updated-entity ::page (assoc void-payment :class "live-removed")])}}))
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
::voided-selected
|
||||
(fn [_ _]
|
||||
{:dispatch-n [[::modal/modal-closed]
|
||||
[::params-change @(re-frame/subscribe [::data-page/params ::page])]
|
||||
[::data-page/reset-checked ::page]]}))
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
::void-selected
|
||||
(fn [cofx [_ which]]
|
||||
(let [checked-params (get which "header")
|
||||
specific-invoices (map :id (vals (dissoc which "header")))]
|
||||
{:graphql {:token (-> cofx :db :user)
|
||||
:owns-state {:single ::void-selected}
|
||||
:query-obj
|
||||
{:venia/operation {:operation/type :mutation
|
||||
:operation/name "VoidPayments"}
|
||||
:venia/queries [{:query/data
|
||||
[:void-payments
|
||||
{:filters (some-> checked-params data-params->query-params)
|
||||
:ids specific-invoices}
|
||||
[:message]]}]}
|
||||
:on-success (fn [_]
|
||||
[::voided-selected])}})))
|
||||
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
::void-selected-requested
|
||||
(fn [_ [_ which]]
|
||||
(let [to-delete (if (get which "header")
|
||||
"all visible payments"
|
||||
(str (count which) " payments"))]
|
||||
{:dispatch [::modal/modal-requested {:title "Confirmation"
|
||||
:body [:div (str "Are you sure you want to void " to-delete "?")]
|
||||
:cancel? true
|
||||
:confirm {:value "Void"
|
||||
:class "is-danger"
|
||||
:status-from [::status/single ::void-selected]
|
||||
:on-click (dispatch-event [::void-selected which] )}
|
||||
:close-event [::status/completed ::void-selected]}]})))
|
||||
|
||||
(defn void-selected-button []
|
||||
(let [status @(re-frame/subscribe [::status/single ::void-selected])
|
||||
checked-payments @(re-frame/subscribe [::data-page/checked ::page])
|
||||
is-admin? @(re-frame/subscribe [::subs/is-admin?])]
|
||||
(when is-admin?
|
||||
[:button.button.is-danger {:on-click (dispatch-event [::void-selected-requested checked-payments])
|
||||
:class (status/class-for status)
|
||||
:disabled (or (status/disabled-for status)
|
||||
(not (seq checked-payments)))}
|
||||
" Void"])))
|
||||
|
||||
(defn action-buttons []
|
||||
(let [checked-payments @(re-frame/subscribe [::data-page/checked ::page])]
|
||||
[:div
|
||||
[:div.is-pulled-right
|
||||
[:div.buttons
|
||||
[void-selected-button]]]
|
||||
[:div.is-pulled-right {:style {:margin-right "0.5rem"}}
|
||||
(into [:div.tags ] (map (fn [[z {:keys [id check-number type amount]}]]
|
||||
(if (= z "header")
|
||||
[:span.tag.is-medium "All visible payments"
|
||||
[:button.delete.is-small {:on-click
|
||||
(dispatch-event [::data-page/remove-check ::page z])}]]
|
||||
[:span.tag.is-medium (cond
|
||||
(= :cash type) (gstring/format "Cash (%s)" (nf amount ))
|
||||
(= :debit type) (gstring/format "Debit (%s)" (nf amount ))
|
||||
:else (gstring/format "Check #%d (%s)" check-number (nf amount )))
|
||||
[:button.delete.is-small {:on-click
|
||||
(dispatch-event [::data-page/remove-check ::page id])}]]))
|
||||
checked-payments))]]))
|
||||
|
||||
(defn content []
|
||||
[:div
|
||||
[:h1.title "Payments"]
|
||||
[action-buttons]
|
||||
[table/table {:id :payments
|
||||
:data-page ::page}]])
|
||||
|
||||
|
||||
@@ -42,7 +42,7 @@
|
||||
states :states
|
||||
}]
|
||||
(let [{:keys [client s3-url bank-account payments type check-number date amount id vendor status invoices transaction] :as check} check]
|
||||
[grid/row {:class (:class check) :id id}
|
||||
[grid/row {:class (:class check) :id id :entity check}
|
||||
(when-not selected-client
|
||||
[grid/cell {} (:name client)])
|
||||
[grid/cell {} (:name vendor)]
|
||||
@@ -95,24 +95,25 @@
|
||||
(url/map->query {:exact-match-id (:id transaction)}))}]]])]]]]])
|
||||
[:span {:style {:margin-left "1em"}}]
|
||||
|
||||
(when (or (= :pending status)
|
||||
(and (#{":cash" :cash ":debit" :debit} type)
|
||||
(not= :voided status)
|
||||
(not transaction)))
|
||||
(when (and (not= :cleared status)
|
||||
(not= :voided status)
|
||||
(not transaction))
|
||||
|
||||
[buttons/sl-icon {:event [::void-check check] :icon :icon-bin-2
|
||||
:class (status/class-for (get states (:id check)))}]
|
||||
)]]]))
|
||||
:class (status/class-for (get states (:id check)))}])]]]))
|
||||
|
||||
(defn table [{:keys [data-page]}]
|
||||
(let [selected-client @(re-frame/subscribe [::subs/client])
|
||||
{:keys [data status]} @(re-frame/subscribe [::data-page/page data-page])
|
||||
{:keys [data params]} @(re-frame/subscribe [::data-page/page data-page])
|
||||
states @(re-frame/subscribe [::status/multi ::void])]
|
||||
[grid/grid {:data-page data-page
|
||||
:check-boxes? true
|
||||
:column-count (if selected-client 7 8)}
|
||||
[grid/controls data]
|
||||
[grid/table {:fullwidth true}
|
||||
[grid/header {}
|
||||
[grid/row {}
|
||||
[grid/row {:id "header"
|
||||
:entity params}
|
||||
(when-not selected-client
|
||||
[grid/sortable-header-cell {:sort-key "client" :sort-name "Client"} "Client"])
|
||||
[grid/sortable-header-cell {:sort-key "vendor" :sort-name "Vendor"} "Vendor"]
|
||||
|
||||
@@ -132,7 +132,9 @@
|
||||
::voided-selected
|
||||
(fn [cofx [_]]
|
||||
{:dispatch-n [[::modal/modal-closed]
|
||||
[::params-change @(re-frame/subscribe [::data-page/params ::page])]]}))
|
||||
[::params-change @(re-frame/subscribe [::data-page/params ::page])]
|
||||
[::data-page/reset-checked :invoices]]}))
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
::void-selected
|
||||
(fn [cofx [_ which]]
|
||||
@@ -142,15 +144,14 @@
|
||||
:owns-state {:single ::void-selected}
|
||||
:query-obj
|
||||
{:venia/operation {:operation/type :mutation
|
||||
:operation/name "DeleteTransactions"}
|
||||
:operation/name "VoidInvoices"}
|
||||
:venia/queries [{:query/data
|
||||
[:void-invoices
|
||||
{:filters (some-> checked-params table/data-params->query-params)
|
||||
:ids specific-invoices}
|
||||
[:message]]}]}
|
||||
:on-success (fn [result]
|
||||
[::voided-selected])}
|
||||
:dispatch [::data-page/reset-checked ::page]})))
|
||||
:on-success (fn [_]
|
||||
[::voided-selected])}})))
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
::void-selected-requested
|
||||
|
||||
Reference in New Issue
Block a user