diff options
author | Tim <contact@bytim.eu> | 2025-06-07 13:09:24 +0200 |
---|---|---|
committer | Tim <contact@bytim.eu> | 2025-06-07 13:09:24 +0200 |
commit | 294f71fb3c5ca3f0fee62e70c9c6a3427a9afc12 (patch) | |
tree | a9e0ca6460ce9361b967b42c59572bc053633775 /src/chef | |
parent | 82da261f168454cd606f4f150313844b9d4b9eea (diff) | |
download | chef-294f71fb3c5ca3f0fee62e70c9c6a3427a9afc12.tar.xz chef-294f71fb3c5ca3f0fee62e70c9c6a3427a9afc12.zip |
Add features to upload and delete thumbnails
Diffstat (limited to 'src/chef')
-rw-r--r-- | src/chef/core.clj | 3 | ||||
-rw-r--r-- | src/chef/database/init.clj | 3 | ||||
-rw-r--r-- | src/chef/pages/admin.clj | 2 | ||||
-rw-r--r-- | src/chef/pages/admin/api.clj | 37 | ||||
-rw-r--r-- | src/chef/pages/admin/recipe_editor.clj | 14 | ||||
-rw-r--r-- | src/chef/routes.clj | 7 | ||||
-rw-r--r-- | src/chef/utils.clj | 11 |
7 files changed, 68 insertions, 9 deletions
diff --git a/src/chef/core.clj b/src/chef/core.clj index f3422d5..cfe72f9 100644 --- a/src/chef/core.clj +++ b/src/chef/core.clj @@ -2,9 +2,12 @@ (:require [org.httpkit.server :as http-server] [chef.routes :as croutes] [chef.database :as cdb]) + (:import java.io.File) (:gen-class)) (defn -main [& args] + (println "Creating thumbnails folder...") + (.mkdirs (File. "./thumbnails/")) (println "Running db patches...") (cdb/run-patches!) (println "Starting http server...") diff --git a/src/chef/database/init.clj b/src/chef/database/init.clj index ef4bd2f..192b775 100644 --- a/src/chef/database/init.clj +++ b/src/chef/database/init.clj @@ -14,5 +14,4 @@ [:title :text] [:unit :integer] [:ingredients :text] - [:preparation :text] - [:thumbnail :text]]}))) + [:preparation :text]]}))) diff --git a/src/chef/pages/admin.clj b/src/chef/pages/admin.clj index 8ffadcc..ea19cc3 100644 --- a/src/chef/pages/admin.clj +++ b/src/chef/pages/admin.clj @@ -69,7 +69,7 @@ [:button {:class ["button" "primary"] :onclick (str "window.open(\"/admin/recipe-editor/" (:recipes/id recipe) - "\", \"\", \"width=500,height=500\")")} + "\", \"\", \"width=900,height=900\")")} "Bearbeiten"] [:button {:class ["button error"] :hx-trigger "click" diff --git a/src/chef/pages/admin/api.clj b/src/chef/pages/admin/api.clj index 9696eb5..1119607 100644 --- a/src/chef/pages/admin/api.clj +++ b/src/chef/pages/admin/api.clj @@ -1,9 +1,12 @@ (ns chef.pages.admin.api (:require [chef.utils :as cutils] [chef.database :as cdb] + [clojure.string :as cstr] [next.jdbc :as jdbc] [honey.sql :as sql] - [ring.util.response :as ruresp])) + [ring.util.response :as ruresp] + [clojure.java.io :as cjio]) + (:import java.io.File)) (defn create-category [req] (cutils/auth-only req @@ -81,7 +84,22 @@ ingredients (get-in req [:params "ingredients"])] (if (and (some? id) (cutils/valid-ingredients? ingredients)) - (do (jdbc/execute! @cdb/db + (do (when-let [thumbnail (get-in req [:params "thumbnail"])] + (when-let [existing-thumbnail-file (->> {:select [:*] + :from [:recipes] + :where [:= :id id]} + sql/format + (jdbc/execute! @cdb/db) + first + cutils/get-thumbnail-file)] + (.delete ^File existing-thumbnail-file)) + (cjio/copy (:tempfile thumbnail) + (File. (str "./thumbnails/" id "." + (-> thumbnail + :filename + (cstr/split #"\.") + last))))) + (jdbc/execute! @cdb/db (sql/format {:update :recipes :set {:title (get-in req [:params "title"]) :category (get-in req [:params "category"]) @@ -91,3 +109,18 @@ :where [:= :id id]})) (ruresp/response "Saved.")) (ruresp/bad-request "Bad request."))))) + +(defn delete-thumbnail [req] + (cutils/auth-only req + (if-let [id (try (Integer/parseInt (get-in req [:path-params :id])) + (catch Exception _ nil))] + (when-let [thumbnail-file (->> {:select [:*] + :from [:recipes] + :where [:= :id id]} + sql/format + (jdbc/execute! @cdb/db) + first + cutils/get-thumbnail-file)] + (.delete ^File thumbnail-file) + (ruresp/response "Done.")) + (ruresp/bad-request "Bad request.")))) diff --git a/src/chef/pages/admin/recipe_editor.clj b/src/chef/pages/admin/recipe_editor.clj index 6afd591..cc30942 100644 --- a/src/chef/pages/admin/recipe_editor.clj +++ b/src/chef/pages/admin/recipe_editor.clj @@ -13,9 +13,20 @@ [:h1 "Rezept bearbeiten"] [:form {:style {:width "50%"} :hx-post (str "/api/admin/edit-recipe/" (:recipes/id recipe)) - :hx-swap "none"} + :hx-swap "none" + :enctype "multipart/form-data"} [:input {:type :text :name "title" :placeholder "Titel" :value (:recipes/title recipe)}] + [:div {:style {:display :flex}} + [:p {:style {:margin-right "0.5em"}} "Thumbnail: "] + [:input {:type :file :name "thumbnail" + :style {:height :fit-content + :padding "0.3em"}}]] + [:button {:class ["button" "error"] + :hx-trigger "click" + :hx-delete (str "/api/admin/delete-thumbnail/" (:recipes/id recipe)) + :hx-swap :none} + "Thumbnail entfernen"] [:h2 "Kategorie"] [:select {:name "category"} (for [category (->> (sql/format {:select [:*] @@ -36,7 +47,6 @@ [:p ":"]] [:textarea {:name "ingredients"} (:recipes/ingredients recipe)] - ;; Regex: ([A-z0-9 ]*)=([0-9]*) ?([A-z]*) [:p "(Je Zeile eine Zutat, in dem Format " [:code "[Beschreibung der Zutat]=[Menge als Zahl][Einheit der Menge]"] ".)"] [:h2 "Zubereitung"] [:textarea {:name "preparation"} diff --git a/src/chef/routes.clj b/src/chef/routes.clj index 6b57f4f..03d2e5b 100644 --- a/src/chef/routes.clj +++ b/src/chef/routes.clj @@ -2,7 +2,9 @@ (:require [reitit.ring :as rring] [ring.middleware.oauth2 :as rmoauth2] [ring.middleware.params :as rmparams] + [ring.middleware.multipart-params :as rmmultiparams] [ring.middleware.session :as rmsession] + [ring.middleware.reload :as rmreload] [dotenv :as env] [clojure.string :as cstr] @@ -33,7 +35,9 @@ ["/create-recipe" {:post {:handler cpaapi/create-recipe}}] ["/delete-recipe/:id" {:delete {:handler cpaapi/delete-recipe}}] - ["/edit-recipe/:id" {:post {:handler cpaapi/edit-recipe}}]]]]) + ["/edit-recipe/:id" {:post {:handler cpaapi/edit-recipe}}] + + ["/delete-thumbnail/:id" {:delete {:handler cpaapi/delete-thumbnail}}]]]]) (def ring-handler (delay (-> router rring/router @@ -48,4 +52,5 @@ :landing-uri "/admin" :pkce? true}}) rmparams/wrap-params + rmmultiparams/wrap-multipart-params rmsession/wrap-session))) diff --git a/src/chef/utils.clj b/src/chef/utils.clj index 7ccaf88..e2725ce 100644 --- a/src/chef/utils.clj +++ b/src/chef/utils.clj @@ -3,7 +3,8 @@ [honey.sql :as sql] [next.jdbc :as jdbc] [ring.util.response :as ruresp] - [clojure.string :as cstr])) + [clojure.string :as cstr]) + (:import java.io.File)) (defn gen-page [title & content] [:html @@ -54,3 +55,11 @@ (->> s (re-matches #"(([A-z0-9 ]*)=([0-9]*) ?([A-z]*)\n?)*") some?))) + +(defn get-thumbnail-file [recipe] + (let [thumbnails-folder (File. "./thumbnails/")] + (->> thumbnails-folder + .listFiles + (filter #(cstr/starts-with? (.getName ^File %) + (str (:recipes/id recipe) "."))) + first))) |