can edit.
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
(ns auto-ap.db.reminders
|
(ns auto-ap.db.reminders
|
||||||
(:require [auto-ap.db.utils :refer [clj->db db->clj get-conn query]]
|
(:require [auto-ap.db.utils :refer [clj->db db->clj get-conn query execute!]]
|
||||||
[clj-time.core :as time]
|
[clj-time.core :as time]
|
||||||
[amazonica.aws.simpleemail :as ses]
|
[amazonica.aws.simpleemail :as ses]
|
||||||
[clojure.java.jdbc :as j]
|
[clojure.java.jdbc :as j]
|
||||||
@@ -9,6 +9,8 @@
|
|||||||
[honeysql.core :as sql]
|
[honeysql.core :as sql]
|
||||||
[honeysql.helpers :as helpers]))
|
[honeysql.helpers :as helpers]))
|
||||||
|
|
||||||
|
(def all-keys #{:id :vendor-id :email :body :subject :sent :scheduled})
|
||||||
|
|
||||||
(defn insert [row]
|
(defn insert [row]
|
||||||
(db->clj (first (j/insert! (get-conn)
|
(db->clj (first (j/insert! (get-conn)
|
||||||
:reminders
|
:reminders
|
||||||
@@ -17,12 +19,19 @@
|
|||||||
(def base-query (sql/build :select :reminders.*
|
(def base-query (sql/build :select :reminders.*
|
||||||
:from :reminders))
|
:from :reminders))
|
||||||
|
|
||||||
(defn get-all []
|
(defn get-by-id [id]
|
||||||
(map db->clj (j/query (get-conn)
|
(query (-> base-query
|
||||||
(str
|
(helpers/merge-where [:= :id id]))))
|
||||||
" SELECT reminders.*, vendors.name as vendor_name "
|
|
||||||
" FROM reminders INNER join vendors on reminders.vendor_id = vendors.id "
|
(defn update! [id data]
|
||||||
" ORDER BY sent DESC, scheduled DESC"))))
|
(println data)
|
||||||
|
(-> (sql/build
|
||||||
|
:update :reminders
|
||||||
|
:set (select-keys data all-keys )
|
||||||
|
:where [:= :id id])
|
||||||
|
execute!)
|
||||||
|
(get-by-id id))
|
||||||
|
|
||||||
|
|
||||||
(defn delete-all []
|
(defn delete-all []
|
||||||
(j/delete! (get-conn) :reminders []))
|
(j/delete! (get-conn) :reminders []))
|
||||||
@@ -48,7 +57,7 @@
|
|||||||
(defn finish [id]
|
(defn finish [id]
|
||||||
(j/update! (get-conn) :reminders {:sent (time/now)} ["id = ?" id] ))
|
(j/update! (get-conn) :reminders {:sent (time/now)} ["id = ?" id] ))
|
||||||
|
|
||||||
(def all-keys #{:id :vendor-id :email :body :subject :sent :scheduled})
|
|
||||||
|
|
||||||
(defn add-sort-by [q sort-by asc]
|
(defn add-sort-by [q sort-by asc]
|
||||||
(let [sort-by-key (keyword sort-by)]
|
(let [sort-by-key (keyword sort-by)]
|
||||||
|
|||||||
@@ -10,7 +10,7 @@
|
|||||||
[clj-time.periodic :as p]
|
[clj-time.periodic :as p]
|
||||||
[clj-time.predicates :as pred]
|
[clj-time.predicates :as pred]
|
||||||
[clojure.data.json :as json]
|
[clojure.data.json :as json]
|
||||||
[compojure.core :refer [GET POST context defroutes
|
[compojure.core :refer [GET PUT POST context defroutes
|
||||||
wrap-routes]])
|
wrap-routes]])
|
||||||
(:import (org.joda.time DateTime)))
|
(:import (org.joda.time DateTime)))
|
||||||
|
|
||||||
@@ -52,6 +52,7 @@
|
|||||||
|
|
||||||
(defroutes routes
|
(defroutes routes
|
||||||
(context "/reminders" []
|
(context "/reminders" []
|
||||||
|
|
||||||
(POST "/send" {:keys [query-params headers body] :as x}
|
(POST "/send" {:keys [query-params headers body] :as x}
|
||||||
(let [notification-type (get headers "x-amz-sns-message-type")]
|
(let [notification-type (get headers "x-amz-sns-message-type")]
|
||||||
(println "Received notification " notification-type)
|
(println "Received notification " notification-type)
|
||||||
@@ -70,9 +71,14 @@
|
|||||||
{:status 200
|
{:status 200
|
||||||
:body "{}"
|
:body "{}"
|
||||||
:headers {"Content-Type" "application/edn"}})
|
:headers {"Content-Type" "application/edn"}})
|
||||||
|
(wrap-routes
|
||||||
(wrap-routes (GET "/" {:keys [query-params]}
|
(PUT "/:id" {:keys [ edn-params] {:keys [id] } :route-params}
|
||||||
{:status 200
|
(let [id (if (int? id)
|
||||||
:body (pr-str (map replace-joda (reminders/get-all)))
|
id
|
||||||
:headers {"Content-Type" "application/edn"}})
|
(Integer/parseInt id))]
|
||||||
wrap-secure)))
|
(assert (not (:sent (reminders/get-by-id id))))
|
||||||
|
(reminders/update! id edn-params)
|
||||||
|
{:status 200
|
||||||
|
:body "{}"
|
||||||
|
:headers {"Content-Type" "application/edn"}}))
|
||||||
|
wrap-secure)))
|
||||||
|
|||||||
@@ -3,14 +3,18 @@
|
|||||||
(:require [re-frame.core :as re-frame]
|
(:require [re-frame.core :as re-frame]
|
||||||
[auto-ap.views.components.paginator :refer [paginator]]
|
[auto-ap.views.components.paginator :refer [paginator]]
|
||||||
[auto-ap.views.components.sorter :refer [sorted-column]]
|
[auto-ap.views.components.sorter :refer [sorted-column]]
|
||||||
|
[auto-ap.entities.vendors :as entity]
|
||||||
[reagent.core :as reagent]
|
[reagent.core :as reagent]
|
||||||
[auto-ap.subs :as subs]
|
[auto-ap.subs :as subs]
|
||||||
[auto-ap.events.admin.reminders :as events]
|
[auto-ap.views.utils :refer [login-url dispatch-value-change dispatch-event date-time->str date->str horizontal-field bind-field]]
|
||||||
[auto-ap.views.utils :refer [login-url dispatch-value-change dispatch-event date-time->str date->str]]
|
|
||||||
[cljs.reader :as edn]
|
[cljs.reader :as edn]
|
||||||
|
|
||||||
[auto-ap.routes :as routes]
|
[auto-ap.routes :as routes]
|
||||||
[bidi.bidi :as bidi]))
|
[bidi.bidi :as bidi]))
|
||||||
|
(re-frame/reg-sub
|
||||||
|
::editing-reminder
|
||||||
|
(fn [db]
|
||||||
|
(::editing-reminder db)))
|
||||||
|
|
||||||
(re-frame/reg-sub
|
(re-frame/reg-sub
|
||||||
::reminder-page
|
::reminder-page
|
||||||
@@ -22,6 +26,16 @@
|
|||||||
(fn [db]
|
(fn [db]
|
||||||
(::reminder-params db)))
|
(::reminder-params db)))
|
||||||
|
|
||||||
|
(re-frame/reg-event-db
|
||||||
|
::edit
|
||||||
|
(fn [db [_ which]]
|
||||||
|
(assoc db ::editing-reminder which)))
|
||||||
|
|
||||||
|
(re-frame/reg-event-db
|
||||||
|
::change
|
||||||
|
(fn [db [_ field v]]
|
||||||
|
(assoc-in db (into [::editing-reminder] field) v)))
|
||||||
|
|
||||||
(re-frame/reg-event-fx
|
(re-frame/reg-event-fx
|
||||||
::mounted
|
::mounted
|
||||||
(fn [{:keys [db]} _]
|
(fn [{:keys [db]} _]
|
||||||
@@ -34,6 +48,29 @@
|
|||||||
{:db (update db ::reminder-params merge params)
|
{:db (update db ::reminder-params merge params)
|
||||||
:dispatch [::invalidated]}))
|
:dispatch [::invalidated]}))
|
||||||
|
|
||||||
|
(re-frame/reg-event-fx
|
||||||
|
::save
|
||||||
|
(fn [{:keys [db]}]
|
||||||
|
(let [edited-reminder (::editing-reminder db)]
|
||||||
|
(println edited-reminder)
|
||||||
|
{:http {:token (:user db)
|
||||||
|
:method :put
|
||||||
|
:body (pr-str (dissoc edited-reminder :sent :scheduled))
|
||||||
|
:headers {"Content-Type" "application/edn"}
|
||||||
|
:uri (str "/api/reminders/" (:id edited-reminder))
|
||||||
|
:on-success [::save-complete]
|
||||||
|
:on-error [::save-error]}})))
|
||||||
|
|
||||||
|
(re-frame/reg-event-fx
|
||||||
|
::save-complete
|
||||||
|
(fn [{:keys [db]}]
|
||||||
|
{:dispatch [::edit nil]}))
|
||||||
|
|
||||||
|
(re-frame/reg-event-fx
|
||||||
|
::save-error
|
||||||
|
(fn [{:keys [db]}]
|
||||||
|
{:dispatch [::change [:error] true]}))
|
||||||
|
|
||||||
(re-frame/reg-event-fx
|
(re-frame/reg-event-fx
|
||||||
::invalidated
|
::invalidated
|
||||||
(fn [{:keys [db]}]
|
(fn [{:keys [db]}]
|
||||||
@@ -54,14 +91,70 @@
|
|||||||
(fn [db [_ reminders]]
|
(fn [db [_ reminders]]
|
||||||
(assoc db ::reminder-page (first (:reminder-page reminders)))))
|
(assoc db ::reminder-page (first (:reminder-page reminders)))))
|
||||||
|
|
||||||
|
(defn edit-dialog []
|
||||||
|
(let [editing-reminder @(re-frame/subscribe [::editing-reminder])]
|
||||||
|
[:div.modal.is-active
|
||||||
|
[:div.modal-background {:on-click (fn [] (re-frame/dispatch [::edit nil]))}]
|
||||||
|
|
||||||
|
[:div.modal-card
|
||||||
|
[:header.modal-card-head
|
||||||
|
[:p.modal-card-title
|
||||||
|
(str "Reminder for " (:name (:vendor editing-reminder)))]
|
||||||
|
(when (:error editing-reminder)
|
||||||
|
[:span.icon.has-text-danger
|
||||||
|
[:i.fa.fa-exclamation-triangle]])
|
||||||
|
[:button.delete {:on-click (fn [] (re-frame/dispatch [::edit nil]))}]]
|
||||||
|
[:section.modal-card-body
|
||||||
|
[horizontal-field
|
||||||
|
[:label.label "Email"]
|
||||||
|
[:div.control
|
||||||
|
[bind-field
|
||||||
|
[:input.input {:type "text"
|
||||||
|
:field :email
|
||||||
|
:event ::change
|
||||||
|
:subscription editing-reminder}]]]]
|
||||||
|
[horizontal-field
|
||||||
|
[:label.label "Subject"]
|
||||||
|
[:div.control
|
||||||
|
[bind-field
|
||||||
|
[:input.input {:type "text"
|
||||||
|
:field :subject
|
||||||
|
:event ::change
|
||||||
|
:subscription editing-reminder}]]]]
|
||||||
|
|
||||||
|
[horizontal-field
|
||||||
|
[:label.label "Body"]
|
||||||
|
[:div.control
|
||||||
|
|
||||||
|
[bind-field
|
||||||
|
[:textarea.textarea.is-expanded {:type "text"
|
||||||
|
:field :body
|
||||||
|
:event ::change
|
||||||
|
:subscription editing-reminder}]]]]
|
||||||
|
|
||||||
|
(when (:saving? editing-reminder) [:div.is-overlay {:style {"backgroundColor" "rgba(150,150,150, 0.5)"}}])]
|
||||||
|
|
||||||
|
[:footer.modal-card-foot
|
||||||
|
[:button.button.is-primary {:on-click (fn [] (re-frame/dispatch [::save]))
|
||||||
|
#_#_:disabled (when (not (s/valid? ::entity/vendor editing-reminder ))
|
||||||
|
"disabled")}
|
||||||
|
[:span "Save"]
|
||||||
|
(when (:saving? editing-reminder)
|
||||||
|
[:span.icon
|
||||||
|
[:i.fa.fa-spin.fa-spinner]])]]]]))
|
||||||
|
|
||||||
(defn reminders-table []
|
(defn reminders-table []
|
||||||
(let [{:keys [reminders start end total count]} @(re-frame/subscribe [::reminder-page])
|
(let [{:keys [reminders start end total count]} @(re-frame/subscribe [::reminder-page])
|
||||||
{:keys [sort-by asc]} @(re-frame/subscribe [::reminder-params])
|
{:keys [sort-by asc]} @(re-frame/subscribe [::reminder-params])
|
||||||
reminders (or reminders [])]
|
reminders (or reminders [])]
|
||||||
[:div
|
[:div
|
||||||
[:div.is-pulled-right
|
[:div.is-pulled-right
|
||||||
[paginator {:start start :end end :total total :count count :on-change (fn [params]
|
[paginator {:start start
|
||||||
(re-frame/dispatch [::params-changed params]))}]]
|
:end end
|
||||||
|
:total total
|
||||||
|
:count count
|
||||||
|
:on-change (fn [params]
|
||||||
|
(re-frame/dispatch [::params-changed params]))}]]
|
||||||
[:table {:class "table", :style {:width "100%"}}
|
[:table {:class "table", :style {:width "100%"}}
|
||||||
[:thead
|
[:thead
|
||||||
[:tr
|
[:tr
|
||||||
@@ -71,19 +164,23 @@
|
|||||||
["email" "Email"]]]
|
["email" "Email"]]]
|
||||||
^{:key name}
|
^{:key name}
|
||||||
[sorted-column {:on-sort (fn [params] (re-frame/dispatch [::params-changed params]))
|
[sorted-column {:on-sort (fn [params] (re-frame/dispatch [::params-changed params]))
|
||||||
:style {:width "20%" :cursor "pointer"}
|
:style {:width "20%" :cursor "pointer"}
|
||||||
:sort-key sort-key
|
:sort-key sort-key
|
||||||
:sort-by sort-by
|
:sort-by sort-by
|
||||||
:asc asc}
|
:asc asc}
|
||||||
name])]]
|
name])]]
|
||||||
[:tbody (for [{:keys [id vendor scheduled sent email ]} reminders]
|
[:tbody (for [{:keys [id vendor scheduled sent email ] :as r} reminders]
|
||||||
^{:key id}
|
^{:key id}
|
||||||
[:tr
|
[:tr (when-not sent
|
||||||
|
{:on-click (fn [] (re-frame/dispatch [::edit r])) :style {:cursor "pointer"}})
|
||||||
[:td (:name vendor)]
|
[:td (:name vendor)]
|
||||||
[:td (date->str scheduled)]
|
[:td (date->str scheduled)]
|
||||||
[:td (when sent
|
[:td (when sent
|
||||||
[:span [:span.icon [:i.fa.fa-check]] "Sent " (date-time->str sent)]) ]
|
[:span [:span.icon [:i.fa.fa-check]] "Sent " (date-time->str sent)]) ]
|
||||||
[:td email]])]]]))
|
[:td email]])]]
|
||||||
|
|
||||||
|
(when @(re-frame/subscribe [::editing-reminder])
|
||||||
|
[edit-dialog])]))
|
||||||
|
|
||||||
|
|
||||||
(defn admin-reminders-page []
|
(defn admin-reminders-page []
|
||||||
|
|||||||
Reference in New Issue
Block a user