cleaning up interface for account.
This commit is contained in:
@@ -6,7 +6,7 @@
|
||||
[auto-ap.subs :as subs]
|
||||
[auto-ap.views.components.dropdown :refer [drop-down]]
|
||||
[auto-ap.views.components.typeahead :refer [typeahead]]
|
||||
[auto-ap.views.components.expense-accounts-field :refer [expense-accounts-field recalculate-amounts]]
|
||||
[auto-ap.views.components.expense-accounts-field :refer [expense-accounts-field recalculate-amounts] :as expense-accounts-field]
|
||||
[auto-ap.views.pages.invoices.common :refer [invoice-read]]
|
||||
[auto-ap.views.utils
|
||||
:refer
|
||||
@@ -101,19 +101,12 @@
|
||||
submit-query)
|
||||
|
||||
;; EVENTS
|
||||
(re-frame/reg-event-db
|
||||
::adding
|
||||
(fn [db [_ new]]
|
||||
(-> db (forms/start-form ::form (assoc new :expense-accounts [{:amount 0
|
||||
:id (str "new-" (random-uuid))
|
||||
:amount-percentage 100
|
||||
:amount-mode "%"}])))))
|
||||
|
||||
(re-frame/reg-event-db
|
||||
::editing
|
||||
(fn [db [_ which]]
|
||||
(let [edit-invoice (update which :date #(date->str % standard))
|
||||
edit-invoice (assoc edit-invoice :original edit-invoice)]
|
||||
edit-invoice (assoc edit-invoice :original edit-invoice)
|
||||
locations @(re-frame/subscribe [::subs/locations-for-client (:id (:client which))])]
|
||||
(-> db
|
||||
(forms/start-form ::form {:id (:id edit-invoice)
|
||||
:status (:status edit-invoice)
|
||||
@@ -124,19 +117,9 @@
|
||||
:vendor-id (:id (:vendor edit-invoice))
|
||||
:vendor-name (:name (:vendor edit-invoice))
|
||||
:client-id (:id (:client edit-invoice))
|
||||
:expense-accounts (if (seq (:expense-accounts which))
|
||||
(vec (map
|
||||
(fn [a]
|
||||
(-> a
|
||||
(update :amount #(js/parseFloat %))
|
||||
(assoc :amount-percentage (* 100 (/ (js/parseFloat (:amount a))
|
||||
(Math/abs (js/parseFloat (:total which))))))
|
||||
(assoc :amount-mode "%")))
|
||||
(:expense-accounts edit-invoice)))
|
||||
[{:id (str "new-" (random-uuid))
|
||||
:amount-mode "$"
|
||||
:amount (Math/abs (:total edit-invoice))
|
||||
:amount-percentage 100}])
|
||||
:expense-accounts (expense-accounts-field/from-graphql (:expense-accounts which)
|
||||
(:amount which)
|
||||
locations)
|
||||
:client-name (:name (:client edit-invoice))})))))
|
||||
|
||||
|
||||
@@ -159,25 +142,18 @@
|
||||
field value
|
||||
[:expense-accounts] (recalculate-amounts (:expense-accounts data) value)]}))
|
||||
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
::change-vendor
|
||||
[(forms/in-form ::form)]
|
||||
(fn [{{:keys [data]} :db} [_ location field value]]
|
||||
(let [has-only-one-expense-account? (and value
|
||||
(or (not (seq (:expense-accounts data)))
|
||||
(<= 1 (count (:expense-accounts data))))
|
||||
(not (get-in data [:expense-accounts 0 :account :id])))]
|
||||
(if has-only-one-expense-account?
|
||||
{:dispatch [::forms/change ::form
|
||||
field value
|
||||
[:expense-accounts] [{:id (str "new-" (random-uuid))
|
||||
:amount (:total data)
|
||||
:amount-percentage 100
|
||||
:amount-mode "%"
|
||||
:account @(re-frame/subscribe [::subs/vendor-default-account value])}]]}
|
||||
{:dispatch [::forms/change ::form
|
||||
field value]}))))
|
||||
|
||||
(fn [{{:keys [data]} :db} [_ field value]]
|
||||
(if (and value (expense-accounts-field/can-replace-with-default? (:expense-accounts data)))
|
||||
{:dispatch [::forms/change ::form
|
||||
field value
|
||||
[:expense-accounts] (expense-accounts-field/default-account (:expense-accounts data)
|
||||
@(re-frame/subscribe [::subs/vendor-default-account value])
|
||||
(:amount data))]}
|
||||
{:dispatch [::forms/change ::form field value]})))
|
||||
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
@@ -267,9 +243,8 @@
|
||||
:disabled exists?
|
||||
:auto-focus (if @(re-frame/subscribe [::subs/client]) true false)
|
||||
:field [:vendor-id]
|
||||
:text-field [:vendor-name]
|
||||
:text-event change-event
|
||||
:event [::change-vendor [::form]]
|
||||
:event [::change-vendor]
|
||||
:spec (s/nilable ::invoice/vendor-id)
|
||||
:subscription data}]]]]
|
||||
|
||||
|
||||
Reference in New Issue
Block a user