not using namespaced keys, due to graphql

This commit is contained in:
Bryce Covert
2018-04-10 10:51:21 -07:00
parent 4a0275f024
commit 53905c317b
19 changed files with 114 additions and 109 deletions

View File

@@ -1,3 +1,9 @@
{:db {:server "localhost"} {:db {:server "localhost"}
:scheme "http" :scheme "http"
:jwt-secret "auto ap invoices are awesome"} :jwt-secret "auto ap invoices are awesome"
:aws-access-key-id "AKIAJIS67OSJARD2E6VQ"
:aws-secret-access-key "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"
:aws-region "us-east-1"
:invoice-import-queue-url "https://sqs.us-east-1.amazonaws.com/679918342773/integreat-mail-staging"
:invoice-email "invoices-staging@mail.app.integreatconsult.com"
}

View File

@@ -1,26 +1,16 @@
(ns auto-ap.db.companies (ns auto-ap.db.companies
(:require [auto-ap.db.utils :refer [assign-namespace clj->db db->clj (:require [auto-ap.db.utils :refer [clj->db db->clj get-conn]]
get-conn]]
[auto-ap.entities.companies :as entity] [auto-ap.entities.companies :as entity]
[clojure.edn :as edn] [clojure.edn :as edn]
[clojure.java.jdbc :as j])) [clojure.java.jdbc :as j]))
(defn merge-data [{:keys [::entity/data] :as x}]
(merge x (edn/read-string data)))
(defn parse [x] (defn parse [x]
(-> x (db->clj x))
(db->clj)
(assign-namespace "auto-ap.entities.companies")
merge-data
))
(defn get-all [] (defn get-all []
(->> (j/query (get-conn) "SELECT * FROM companies") (->> (j/query (get-conn) "SELECT * FROM companies")
(map parse) (map parse)))
))
(defn upsert [id data] (defn upsert [id data]
(j/update! (get-conn) :companies (clj->db data) ["id = ?" (Integer/parseInt id)] ) (j/update! (get-conn) :companies (clj->db data) ["id = ?" (Integer/parseInt id)] )

View File

@@ -5,8 +5,7 @@
[auto-ap.db.vendors :as vendors] [auto-ap.db.vendors :as vendors]
[auto-ap.entities.companies :as company] [auto-ap.entities.companies :as company]
[auto-ap.entities.vendors :as vendor] [auto-ap.entities.vendors :as vendor]
[clojure.java.jdbc :as j] [clojure.java.jdbc :as j]))
[aggregate.core :as agg]))
(defn insert-multi! [rows] (defn insert-multi! [rows]
(j/insert-multi! (get-conn) (j/insert-multi! (get-conn)
@@ -15,13 +14,14 @@
(defn with-relations [results] (defn with-relations [results]
(let [companies (reduce (let [companies (reduce
#(assoc %1 (::company/id %2) %2) #(assoc %1 (:id %2) %2)
{} {}
(companies/get-all)) (companies/get-all))
vendors (reduce vendors (reduce
#(assoc %1 (::vendor/id %2) %2) #(assoc %1 (:id %2) %2)
{} {}
(vendors/get-all))] (vendors/get-all))]
(println companies vendors)
(->> results (->> results
(map #(assoc % :vendor (vendors (:vendor-id %)))) (map #(assoc % :vendor (vendors (:vendor-id %))))
(map #(assoc % :company (companies (:company-id %))))))) (map #(assoc % :company (companies (:company-id %)))))))
@@ -56,8 +56,8 @@
(for [{:keys [total date invoice-number customer-identifier vendor-code] :as row} parsed-invoices] (for [{:keys [total date invoice-number customer-identifier vendor-code] :as row} parsed-invoices]
(do (do
(dissoc (assoc row (dissoc (assoc row
:company-id (::company/id (parse/best-match companies customer-identifier)) :company-id (:id (parse/best-match companies customer-identifier))
:vendor-id (::vendor/id (first (filter #(= (::vendor/code %) vendor-code) vendors))) :vendor-id (:id (first (filter #(= (:code %) vendor-code) vendors)))
:imported false :imported false
:potential-duplicate false) :potential-duplicate false)
:vendor-code))))) :vendor-code)))))

View File

@@ -2,6 +2,7 @@
(:require [auto-ap.db.utils :refer [clj->db db->clj get-conn]] (:require [auto-ap.db.utils :refer [clj->db db->clj get-conn]]
[clj-time.core :as time] [clj-time.core :as time]
[clojure.java.jdbc :as j] [clojure.java.jdbc :as j]
[clj-time.jdbc :as jdbc]
[clojure.string :as str])) [clojure.string :as str]))
(defn insert [row] (defn insert [row]

View File

@@ -16,18 +16,23 @@
(fn [[k v]] (fn [[k v]]
[(keyword (snake->kebab (name k))) v]) [(keyword (snake->kebab (name k))) v])
x)) x))
merged (merge kebabed (edn/read-string (:data kebabed)))] merged (if (:data kebabed)
merged)) (update kebabed :data edn/read-string)
([x namespace] kebabed)]
(let [x (db->clj x)] merged)))
(assign-namespace x namespace))))
(defn clj->db [x] (defn clj->db [x]
(into {} (let [snaked (into {}
(map (map
(fn [[k v]] (fn [[k v]]
[(keyword (kebab->snake (name k))) v]) [(keyword (kebab->snake (name k))) v])
x))) x))
unmerged (if (:data snaked)
(update snaked :data pr-str)
snaked)]
unmerged))
(defn merge-data [{:keys [data] :as x}] (defn merge-data [{:keys [data] :as x}]
(merge x (edn/read-string data))) (merge x (edn/read-string data)))
@@ -44,14 +49,3 @@
:user "ap" :user "ap"
:password "fifteen-invoices-imported!"})) :password "fifteen-invoices-imported!"}))
(defn assign-namespace [x n]
(reduce-kv
(fn [x k v]
(assoc x (if (and (keyword? k)
(not (qualified-keyword? k)))
(keyword n (name k))
k)
v))
{}
x))

View File

@@ -1,13 +1,12 @@
(ns auto-ap.db.vendors (ns auto-ap.db.vendors
(:require [auto-ap.db.utils :refer [assign-namespace clj->db db->clj (:require [auto-ap.db.utils :refer [clj->db db->clj get-conn]]
get-conn]]
[auto-ap.entities.vendors :as entities] [auto-ap.entities.vendors :as entities]
[clojure.edn :as edn] [clojure.edn :as edn]
[clojure.java.jdbc :as j])) [clojure.java.jdbc :as j]))
(defn parse [x] (defn parse [x]
(db->clj x "auto-ap.entities.vendors")) (db->clj x))
(defn unparse [x] (defn unparse [x]
(-> x (-> x

View File

@@ -16,6 +16,7 @@
[ring.middleware.params :refer [wrap-params]] [ring.middleware.params :refer [wrap-params]]
[ring.middleware.reload :refer [wrap-reload]] [ring.middleware.reload :refer [wrap-reload]]
[ring.util.response :as response])) [ring.util.response :as response]))
(println env)
(defcredential (:aws-access-key-id env) (:aws-secret-access-key env) (:aws-region env)) (defcredential (:aws-access-key-id env) (:aws-secret-access-key env) (:aws-region env))

View File

@@ -52,10 +52,9 @@
(excel/parse-file file filename)) (excel/parse-file file filename))
(defn best-match [companies company-identifier] (defn best-match [companies company-identifier]
(println companies)
(->> companies (->> companies
(map (fn [company] (map (fn [company]
[company (apply min (map #(m/jaccard (.toLowerCase company-identifier) %) (:matches company)))])) [company (apply min (map #(m/jaccard (.toLowerCase company-identifier) %) (:matches (:data company))))]))
(filter #(< (second %) 0.25)) (filter #(< (second %) 0.25))
(sort-by second) (sort-by second)

View File

@@ -13,10 +13,10 @@
(s/def ::email (s/nilable (s/and string? (s/or :is-email #(re-matches email-regex %) (s/def ::email (s/nilable (s/and string? (s/or :is-email #(re-matches email-regex %)
:is-empty #(= % ""))))) :is-empty #(= % "")))))
(s/def ::company (s/keys :req [::name] (s/def ::company (s/keys :req-un [::name]
:opt [::email :opt-un [::email
::id])) ::id]))
(def company-spec (apply hash-map (drop 1 (s/form ::company)))) (def company-spec (apply hash-map (drop 1 (s/form ::company))))
(def all-keys (concat (:req company-spec) (:opt company-spec))) (def all-keys (map #(keyword (name %)) (concat (:req-un company-spec) (:opt-un company-spec))))

View File

@@ -31,8 +31,8 @@
(s/def ::state (s/nilable string?)) (s/def ::state (s/nilable string?))
(s/def ::zip (s/nilable string?)) (s/def ::zip (s/nilable string?))
(s/def ::vendor (s/keys :req [::name] (s/def ::vendor (s/keys :req-un [::name]
:opt [::code :opt-un [::code
::id ::id
::invoice-reminder-schedule ::invoice-reminder-schedule
::primary-contact ::primary-contact
@@ -49,4 +49,4 @@
(def vendor-spec (apply hash-map (drop 1 (s/form ::vendor)))) (def vendor-spec (apply hash-map (drop 1 (s/form ::vendor))))
(def all-keys (concat (:req vendor-spec) (:opt vendor-spec))) (def all-keys (map #(keyword (name %)) (concat (:req-un vendor-spec) (:opt-un vendor-spec))))

View File

@@ -4,7 +4,6 @@
[auto-ap.subs :as subs] [auto-ap.subs :as subs]
[auto-ap.routes :as routes] [auto-ap.routes :as routes]
[auto-ap.effects :as effects] [auto-ap.effects :as effects]
[auto-ap.entities.companies :as companies]
[bidi.bidi :as bidi])) [bidi.bidi :as bidi]))
(re-frame/reg-event-fx (re-frame/reg-event-fx
@@ -43,14 +42,14 @@
(fn [db [_ companies]] (fn [db [_ companies]]
(assoc db :companies (reduce (fn [companies company] (assoc db :companies (reduce (fn [companies company]
(assoc companies (::companies/id company) company)) (assoc companies (:id company) company))
{} {}
companies)))) companies))))
(re-frame/reg-event-db (re-frame/reg-event-db
::swap-company ::swap-company
(fn [db [_ company]] (fn [db [_ company]]
(assoc db :company (::companies/id company)))) (assoc db :company (:id company))))
(re-frame/reg-event-fx (re-frame/reg-event-fx
::set-active-page ::set-active-page
@@ -71,7 +70,7 @@
{:http {:method :post {:http {:method :post
:token (-> cofx :db :user) :token (-> cofx :db :user)
:uri (str "/api/invoices/approve" :uri (str "/api/invoices/approve"
(when-let [company-id (::companies/id @(re-frame/subscribe [::subs/company]))] (when-let [company-id (:id @(re-frame/subscribe [::subs/company]))]
(str "?company=" company-id))) (str "?company=" company-id)))
:on-success [::received-invoices :pending] :on-success [::received-invoices :pending]
}})) }}))
@@ -83,7 +82,7 @@
:http {:method :get :http {:method :get
:token (-> cofx :db :user) :token (-> cofx :db :user)
:uri (str "/api/invoices/pending" :uri (str "/api/invoices/pending"
(when-let [company-id (::companies/id @(re-frame/subscribe [::subs/company]))] (when-let [company-id (:id @(re-frame/subscribe [::subs/company]))]
(str "?company=" company-id))) (str "?company=" company-id)))
:on-success [::received-invoices :pending]}})) :on-success [::received-invoices :pending]}}))
@@ -94,7 +93,7 @@
:http {:method :get :http {:method :get
:token (-> cofx :db :user) :token (-> cofx :db :user)
:uri (str "/api/invoices/unpaid" :uri (str "/api/invoices/unpaid"
(when-let [company-id (::companies/id @(re-frame/subscribe [::subs/company]))] (when-let [company-id (:id @(re-frame/subscribe [::subs/company]))]
(str "?company=" company-id))) (str "?company=" company-id)))
:on-success [::received-invoices :unpaid]}})) :on-success [::received-invoices :unpaid]}}))
@@ -104,7 +103,7 @@
{:http {:method :post {:http {:method :post
:token (-> cofx :db :user) :token (-> cofx :db :user)
:uri (str "/api/invoices/reject" :uri (str "/api/invoices/reject"
(when-let [company-id (::companies/id @(re-frame/subscribe [::subs/company]))] (when-let [company-id (:id @(re-frame/subscribe [::subs/company]))]
(str "?company=" company-id))) (str "?company=" company-id)))
:on-success [::received-invoices :pending] :on-success [::received-invoices :pending]
}})) }}))

View File

@@ -21,7 +21,7 @@
:token (:user db) :token (:user db)
:body (pr-str edited-company) :body (pr-str edited-company)
:headers {"Content-Type" "application/edn"} :headers {"Content-Type" "application/edn"}
:uri (str "/api/companies/" (::entity/id edited-company)) :uri (str "/api/companies/" (:id edited-company))
:on-success [::save-complete] :on-success [::save-complete]
:on-error [::save-error]}}))) :on-error [::save-error]}})))
@@ -31,7 +31,7 @@
(-> db (-> db
(assoc-in [:admin :company] nil) (assoc-in [:admin :company] nil)
(assoc-in [:companies (::entity/id company)] company)))) (assoc-in [:companies (:id company)] company))))
(re-frame/reg-event-db (re-frame/reg-event-db
::save-error ::save-error

View File

@@ -26,12 +26,12 @@
(let [edited-vendor (get-in db [:admin :vendor]) (let [edited-vendor (get-in db [:admin :vendor])
fx {:db (assoc-in db [:admin :vendor :saving?] true)}] fx {:db (assoc-in db [:admin :vendor :saving?] true)}]
(when (s/valid? ::entity/vendor edited-vendor) (when (s/valid? ::entity/vendor edited-vendor)
(if (::entity/id edited-vendor) (if (:id edited-vendor)
(assoc fx :http {:method :put (assoc fx :http {:method :put
:token (:user db) :token (:user db)
:body (pr-str edited-vendor) :body (pr-str edited-vendor)
:headers {"Content-Type" "application/edn"} :headers {"Content-Type" "application/edn"}
:uri (str "/api/vendors/" (::entity/id edited-vendor)) :uri (str "/api/vendors/" (:id edited-vendor))
:on-success [::save-complete] :on-success [::save-complete]
:on-error [::save-error]}) :on-error [::save-error]})
(assoc fx :http {:method :post (assoc fx :http {:method :post
@@ -48,7 +48,7 @@
(-> db (-> db
(assoc-in [:admin :vendor] nil) (assoc-in [:admin :vendor] nil)
(assoc-in [:vendors (::entity/id vendor)] vendor)))) (assoc-in [:vendors (:id vendor)] vendor))))
(re-frame/reg-event-db (re-frame/reg-event-db
::save-error ::save-error
@@ -76,6 +76,6 @@
(fn [db [_ vendors]] (fn [db [_ vendors]]
(assoc db :vendors (reduce (fn [vendors vendor] (assoc db :vendors (reduce (fn [vendors vendor]
(assoc vendors (::entity/id vendor) vendor)) (assoc vendors (:id vendor) vendor))
{} {}
vendors)))) vendors))))

View File

@@ -17,13 +17,12 @@
[:tr [:tr
[:th "Name"] [:th "Name"]
[:th "Email"]]] [:th "Email"]]]
[:tbody (for [{:keys [::entity/id ::entity/name ::entity/email] :as c} @companies] [:tbody (for [{:keys [id name email] :as c} @companies]
^{:key (str name "-" id )} ^{:key (str name "-" id )}
[:tr {:on-click (fn [] (re-frame/dispatch [::events/edit id])) [:tr {:on-click (fn [] (re-frame/dispatch [::events/edit id]))
:style {"cursor" "pointer"}} :style {"cursor" "pointer"}}
[:td name] [:td name]
[:td email] [:td email]])]]))
])]]))
(defn admin-companies-page [] (defn admin-companies-page []
[:div {:class "inbox-messages"} [:div {:class "inbox-messages"}
@@ -55,7 +54,8 @@
[:div.control [:div.control
[bind-field [bind-field
[:input.input {:type "text" [:input.input {:type "text"
:field ::entity/name :field :name
:spec ::entity/name
:event ::events/change :event ::events/change
:subscription editing-company}]]]] :subscription editing-company}]]]]
@@ -64,7 +64,8 @@
[:div.control [:div.control
[bind-field [bind-field
[:input.input {:type "email" [:input.input {:type "email"
:field ::entity/email :field :email
:spec ::entity/name
:event ::events/change :event ::events/change
:subscription editing-company}]]]] :subscription editing-company}]]]]

View File

@@ -26,12 +26,12 @@
[:th "Email"] [:th "Email"]
[:th "Invoice Reminders"]]] [:th "Invoice Reminders"]]]
[:tbody (for [v @vendors] [:tbody (for [v @vendors]
^{:key (str (::entity/id v))} ^{:key (str (:id v))}
[:tr {:on-click (fn [] (re-frame/dispatch [::events/edit (::entity/id v)])) [:tr {:on-click (fn [] (re-frame/dispatch [::events/edit (:id v)]))
:style {"cursor" "pointer"}} :style {"cursor" "pointer"}}
[:td (::entity/name v)] [:td (:name v)]
[:td (::entity/primary-email v)] [:td (:primary-email v)]
[:td (::entity/invoice-reminder-schedule v)]])]])) [:td (:invoice-reminder-schedule v)]])]]))
(defn danger-for [[dom {:keys [field subscription class] :as keys} & rest]] (defn danger-for [[dom {:keys [field subscription class] :as keys} & rest]]
(let [keys (assoc keys :class (str class (let [keys (assoc keys :class (str class
@@ -50,9 +50,9 @@
[:div.modal-card [:div.modal-card
[:header.modal-card-head [:header.modal-card-head
[:p.modal-card-title [:p.modal-card-title
(if (::entity/id editing-vendor) (if (:id editing-vendor)
(str "Edit " (or (::entity/name editing-vendor) "<vendor>")) (str "Edit " (or (:name editing-vendor) "<vendor>"))
(str "Add " (or (::entity/name editing-vendor) "<new vendor>")))] (str "Add " (or (:name editing-vendor) "<new vendor>")))]
(when (:error editing-vendor) (when (:error editing-vendor)
[:span.icon.has-text-danger [:span.icon.has-text-danger
[:i.fa.fa-exclamation-triangle]]) [:i.fa.fa-exclamation-triangle]])
@@ -63,7 +63,8 @@
[:div.control [:div.control
[bind-field [bind-field
[:input.input {:type "text" [:input.input {:type "text"
:field ::entity/name :field :name
:spec ::entity/name
:event ::events/change :event ::events/change
:subscription editing-vendor}]]]] :subscription editing-vendor}]]]]
@@ -73,7 +74,8 @@
[bind-field [bind-field
[:input.input.is-expanded {:type "text" [:input.input.is-expanded {:type "text"
:field ::entity/code :field :code
:spec ::entity/code
:event ::events/change :event ::events/change
:subscription editing-vendor}]] :subscription editing-vendor}]]
[:p.help "The vendor code is used for invoice parsing. Only one vendor at a time can use a code"]]] [:p.help "The vendor code is used for invoice parsing. Only one vendor at a time can use a code"]]]
@@ -86,7 +88,8 @@
[bind-field [bind-field
[:input.input.is-expanded {:type "text" [:input.input.is-expanded {:type "text"
:placeholder "1700 Pennsylvania Ave" :placeholder "1700 Pennsylvania Ave"
:field ::entity/address1 :field :address1
:spec ::entity/address1
:event ::events/change :event ::events/change
:subscription editing-vendor}]]]] :subscription editing-vendor}]]]]
@@ -96,7 +99,8 @@
[bind-field [bind-field
[:input.input.is-expanded {:type "text" [:input.input.is-expanded {:type "text"
:placeholder "Suite 400" :placeholder "Suite 400"
:field ::entity/address2 :field :address2
:spec ::entity/address2
:event ::events/change :event ::events/change
:subscription editing-vendor}]]]] :subscription editing-vendor}]]]]
@@ -107,7 +111,8 @@
[bind-field [bind-field
[:input.input.is-expanded {:type "text" [:input.input.is-expanded {:type "text"
:placeholder "Cupertino" :placeholder "Cupertino"
:field ::entity/city :field :city
:spec ::entity/city
:event ::events/change :event ::events/change
:subscription editing-vendor}]]] :subscription editing-vendor}]]]
[:div.control [:div.control
@@ -115,14 +120,16 @@
[bind-field [bind-field
[:input.input {:type "text" [:input.input {:type "text"
:placeholder "CA" :placeholder "CA"
:field ::entity/state :field :state
:spec ::entity/state
:event ::events/change :event ::events/change
:subscription editing-vendor}]]] :subscription editing-vendor}]]]
[:div.control [:div.control
[:p.help "Zip"] [:p.help "Zip"]
[bind-field [bind-field
[:input.input {:type "text" [:input.input {:type "text"
:field ::entity/zip :field :zip
:spec ::entity/zip
:event ::events/change :event ::events/change
:subscription editing-vendor :subscription editing-vendor
:placeholder "95014"}]]]] :placeholder "95014"}]]]]
@@ -133,7 +140,8 @@
[:div.control.has-icons-left [:div.control.has-icons-left
[bind-field [bind-field
[:input.input.is-expanded {:type "text" [:input.input.is-expanded {:type "text"
:field ::entity/primary-contact :field :primary-contact
:spec ::entity/primary-contact
:event ::events/change :event ::events/change
:subscription editing-vendor}]] :subscription editing-vendor}]]
[:span.icon.is-small.is-left [:span.icon.is-small.is-left
@@ -144,14 +152,16 @@
[:i.fa.fa-envelope]] [:i.fa.fa-envelope]]
[bind-field [bind-field
[:input.input {:type "email" [:input.input {:type "email"
:field ::entity/primary-email :field :primary-email
:spec ::entity/primary-email
:event ::events/change :event ::events/change
:subscription editing-vendor}]]] :subscription editing-vendor}]]]
[:div.control.has-icons-left [:div.control.has-icons-left
[bind-field [bind-field
[:input.input {:type "phone" [:input.input {:type "phone"
:field ::entity/primary-phone :field :primary-phone
:spec ::entity/primary-phone
:event ::events/change :event ::events/change
:subscription editing-vendor}]] :subscription editing-vendor}]]
[:span.icon.is-small.is-left [:span.icon.is-small.is-left
@@ -162,7 +172,8 @@
[:div.control.has-icons-left [:div.control.has-icons-left
[bind-field [bind-field
[:input.input.is-expanded {:type "text" [:input.input.is-expanded {:type "text"
:field ::entity/secondary-contact :field :secondary-contact
:spec ::entity/secondary-contact
:event ::events/change :event ::events/change
:subscription editing-vendor}]] :subscription editing-vendor}]]
[:span.icon.is-small.is-left [:span.icon.is-small.is-left
@@ -172,13 +183,15 @@
[:i.fa.fa-envelope]] [:i.fa.fa-envelope]]
[bind-field [bind-field
[:input.input {:type "email" [:input.input {:type "email"
:field ::entity/secondary-email :field :secondary-email
:spec ::entity/secondary-email
:event ::events/change :event ::events/change
:subscription editing-vendor}]]] :subscription editing-vendor}]]]
[:div.control.has-icons-left [:div.control.has-icons-left
[bind-field [bind-field
[:input.input {:type "phone" [:input.input {:type "phone"
:field ::entity/secondary-phone :field :secondary-phone
:spec ::entity/secondary-phone
:event ::events/change :event ::events/change
:subscription editing-vendor}]] :subscription editing-vendor}]]
[:span.icon.is-small.is-left [:span.icon.is-small.is-left
@@ -192,7 +205,8 @@
[:input {:type "radio" [:input {:type "radio"
:name "schedule" :name "schedule"
:value "Weekly" :value "Weekly"
:field ::entity/invoice-reminder-schedule :field :invoice-reminder-schedule
:spec ::entity/invoice-reminder-schedule
:event ::events/change :event ::events/change
:subscription editing-vendor}]] :subscription editing-vendor}]]
" Send weekly"] " Send weekly"]
@@ -202,7 +216,8 @@
[:input {:type "radio" [:input {:type "radio"
:name "schedule" :name "schedule"
:value "Never" :value "Never"
:field ::entity/invoice-reminder-schedule :field :invoice-reminder-schedule
:spec ::entity/invoice-reminder-schedule
:event ::events/change :event ::events/change
:subscription editing-vendor}]] :subscription editing-vendor}]]
" Never"]]] " Never"]]]

View File

@@ -27,7 +27,7 @@
:paramName "file" :paramName "file"
:headers {"Authorization" (str "Token " @token)} :headers {"Authorization" (str "Token " @token)}
:url (str "/api/invoices/upload" :url (str "/api/invoices/upload"
(when-let [company-name (-> @company ::company/id)] (when-let [company-name (-> @company :id)]
(str "?company=" company-name))) (str "?company=" company-name)))
:previewsContainer "#dz-hidden" :previewsContainer "#dz-hidden"
:previewTemplate "<div class='dz-hidden-preview'></div>"})))}))) :previewTemplate "<div class='dz-hidden-preview'></div>"})))})))
@@ -61,9 +61,9 @@
[:tbody (for [{:keys [vendor vendor-id potential-duplicate company-id customer-identifier invoice-number date total id] :as i} @invoices] [:tbody (for [{:keys [vendor vendor-id potential-duplicate company-id customer-identifier invoice-number date total id] :as i} @invoices]
^{:key (str company-id "-" invoice-number "-" date "-" total "-" id)} ^{:key (str company-id "-" invoice-number "-" date "-" total "-" id)}
[:tr [:tr
[:td (::vendor/name (:vendor i))] [:td (:name (:vendor i))]
(if company-id (if company-id
[:td (::company/name (:company i))] [:td (:name (:company i))]
[:td [:i.icon.fa.fa-warning {:title "potential duplicate"}] [:td [:i.icon.fa.fa-warning {:title "potential duplicate"}]
(str "'" customer-identifier "' doesn't match any known company")]) (str "'" customer-identifier "' doesn't match any known company")])
[:td invoice-number] [:td invoice-number]

View File

@@ -23,11 +23,11 @@
[:th "Invoice #"] [:th "Invoice #"]
[:th "Date"] [:th "Date"]
[:th "Amount"]]] [:th "Amount"]]]
[:tbody (for [{:keys [company invoice-number date total id vendor-id] :as i} @invoices] [:tbody (for [{:keys [company vendor invoice-number date total id] :as i} @invoices]
^{:key (str company "-" invoice-number "-" date "-" total "-" id)} ^{:key (str (:id company) "-" invoice-number "-" date "-" total "-" id)}
[:tr [:tr
[:td vendor-id] [:td (:name vendor)]
[:td company] [:td (:name company)]
[:td invoice-number] [:td invoice-number]
[:td date] [:td date]
[:td total]])]])])) [:td total]])]])]))

View File

@@ -29,8 +29,8 @@
[:tbody (for [{:keys [company invoice-number date total id vendor] :as i} @invoices] [:tbody (for [{:keys [company invoice-number date total id vendor] :as i} @invoices]
^{:key (str company "-" invoice-number "-" date "-" total "-" id)} ^{:key (str company "-" invoice-number "-" date "-" total "-" id)}
[:tr [:tr
[:td (::vendor/name vendor)] [:td (:name vendor)]
[:td (::company/name company)] [:td (:name company)]
[:td invoice-number] [:td invoice-number]
[:td date] [:td date]
[:td total]])]])])) [:td total]])]])]))

View File

@@ -36,25 +36,25 @@
type)) type))
(defmethod do-bind "radio" [dom {:keys [field subscription event class value] :as keys} & rest] (defmethod do-bind "radio" [dom {:keys [field subscription event class value spec] :as keys} & rest]
(let [keys (assoc keys (let [keys (assoc keys
:on-change (dispatch-value-change [event [field]]) :on-change (dispatch-value-change [event [field]])
:checked (= (field subscription) value) :checked (= (field subscription) value)
:class (str class :class (str class
(when (not (s/valid? field (field subscription))) (when (and spec (not (s/valid? spec (field subscription))))
" is-danger"))) " is-danger")))
keys (dissoc keys :field :subscription :event)] keys (dissoc keys :field :subscription :event :spec)]
(vec (concat [dom keys] rest)))) (vec (concat [dom keys] rest))))
(defmethod do-bind :default [dom {:keys [field event subscription class] :as keys} & rest] (defmethod do-bind :default [dom {:keys [field event subscription class spec] :as keys} & rest]
(let [keys (assoc keys (let [keys (assoc keys
:on-change (dispatch-value-change [event [field]]) :on-change (dispatch-value-change [event [field]])
:value (field subscription) :value (field subscription)
:class (str class :class (str class
(when (not (s/valid? field (field subscription))) (when (and spec (not (s/valid? spec (field subscription))))
" is-danger"))) " is-danger")))
keys (dissoc keys :field :subscription :event)] keys (dissoc keys :field :subscription :event :spec)]
(vec (concat [dom keys] rest)))) (vec (concat [dom keys] rest))))
(defn bind-field [all] (defn bind-field [all]