Merge remote-tracking branch 'origin/staging' into develop

This commit is contained in:
Alejandro Alonso 2023-01-30 15:39:17 +01:00
commit 11db7590eb
4 changed files with 38 additions and 4 deletions

View file

@ -22,8 +22,8 @@
java-http-clj/java-http-clj {:mvn/version "0.4.3"} java-http-clj/java-http-clj {:mvn/version "0.4.3"}
funcool/yetti funcool/yetti
{:git/tag "v9.11" {:git/tag "v9.12"
:git/sha "6f9197a" :git/sha "51646d8"
:git/url "https://github.com/funcool/yetti.git" :git/url "https://github.com/funcool/yetti.git"
:exclusions [org.slf4j/slf4j-api]} :exclusions [org.slf4j/slf4j-api]}

View file

@ -323,7 +323,7 @@
where archived_at is not null") where archived_at is not null")
(defn- clean-archived (defn- clean-archived
[{:keys [pool]}] [{:keys [::db/pool]}]
(let [result (db/exec-one! pool [sql:clean-archived]) (let [result (db/exec-one! pool [sql:clean-archived])
result (:next.jdbc/update-count result)] result (:next.jdbc/update-count result)]
(l/debug :hint "delete archived audit log entries" :deleted result) (l/debug :hint "delete archived audit log entries" :deleted result)

View file

@ -18,9 +18,11 @@
[app.main.ui.shapes.frame :as frame] [app.main.ui.shapes.frame :as frame]
[app.util.dom :as dom] [app.util.dom :as dom]
[app.util.timers :as ts] [app.util.timers :as ts]
[app.util.webapi :as wapi]
[beicon.core :as rx] [beicon.core :as rx]
[cuerdas.core :as str] [cuerdas.core :as str]
[debug :refer [debug?]] [debug :refer [debug?]]
[promesa.core :as p]
[rumext.v2 :as mf])) [rumext.v2 :as mf]))
(defn- draw-thumbnail-canvas! (defn- draw-thumbnail-canvas!
@ -229,6 +231,16 @@
(.disconnect @observer-ref) (.disconnect @observer-ref)
(reset! observer-ref nil))))) (reset! observer-ref nil)))))
;; When the thumbnail-data is empty we regenerate the thumbnail
(mf/use-effect
(mf/deps (:selrect shape) thumbnail-data)
(fn []
(let [{:keys [width height]} (:selrect shape)]
(p/then (wapi/empty-png-size width height)
(fn [data]
(when (<= (count thumbnail-data) (+ 100 (count data)))
(rx/push! updates-str :update)))))))
[on-load-frame-dom [on-load-frame-dom
@render-frame? @render-frame?
(mf/html (mf/html

View file

@ -11,7 +11,8 @@
[app.common.logging :as log] [app.common.logging :as log]
[app.util.object :as obj] [app.util.object :as obj]
[beicon.core :as rx] [beicon.core :as rx]
[cuerdas.core :as str])) [cuerdas.core :as str]
[promesa.core :as p]))
(log/set-level! :warn) (log/set-level! :warn)
@ -144,3 +145,24 @@
(.observe ^js obs node) (.observe ^js obs node)
(fn [] (fn []
(.disconnect ^js obs)))))) (.disconnect ^js obs))))))
(defn empty-png-size*
[width height]
(p/create
(fn [resolve reject]
(try
(let [canvas (.createElement js/document "canvas")
_ (set! (.-width canvas) width)
_ (set! (.-height canvas) height)
_ (set! (.-background canvas) "white")
canvas-context (.getContext canvas "2d")]
(.fillRect canvas-context 0 0 width height)
(.toBlob canvas
(fn [blob]
(->> (read-file-as-data-url blob)
(rx/catch (fn [err] (reject err)))
(rx/subs (fn [result] (resolve result)))))))
(catch :default e (reject e))))))
(def empty-png-size (memoize empty-png-size*))