0
Fork 0
mirror of https://github.com/penpot/penpot.git synced 2025-01-23 23:18:48 -05:00

Add partial impl for icons collections importer (wip).

This commit is contained in:
Andrey Antukh 2016-11-20 23:25:48 +01:00
parent 6d0737e4a3
commit cf1188ad47
No known key found for this signature in database
GPG key ID: 4DFEBCB8316A8B95
2 changed files with 87 additions and 5 deletions

View file

@ -15,14 +15,38 @@ delete from images
where id = :id where id = :id
and "user" = '00000000-0000-0000-0000-000000000000'::uuid; and "user" = '00000000-0000-0000-0000-000000000000'::uuid;
-- :name create-image-collection -- :name create-images-collection
insert into images_collections (id, "user", name) insert into images_collections (id, "user", name)
values (:id, '00000000-0000-0000-0000-000000000000'::uuid, :name) values (:id, '00000000-0000-0000-0000-000000000000'::uuid, :name)
on conflict (id) on conflict (id)
do update set name = :name do update set name = :name
returning *; returning *;
-- :name create-icons-collection
insert into icons_collections (id, "user", name)
values (:id, '00000000-0000-0000-0000-000000000000'::uuid, :name)
on conflict (id)
do update set name = :name
returning *;
-- :name get-image -- :name get-image
select * from images as i select * from images as i
where i.id = :id where i.id = :id
and i."user" = '00000000-0000-0000-0000-000000000000'::uuid; and i."user" = '00000000-0000-0000-0000-000000000000'::uuid;
-- :name get-icon
select * from icons as i
where i.id = :id
and i."user" = '00000000-0000-0000-0000-000000000000'::uuid;
-- :name create-icon :<! :1
insert into icons ("user", name, collection, metadata, content)
values (:user, :name, :collection, :metadata, :content)
on conflict (id)
do update set name = :name,
content = :content,
metadata = :metadata,
collection = :collection
"user" = '00000000-0000-0000-0000-000000000000'::uuid
returning *;

View file

@ -29,6 +29,7 @@
;; --- Constants & Helpers ;; --- Constants & Helpers
(def ^:const +imates-uuid-ns+ #uuid "3642a582-565f-4070-beba-af797ab27a6e") (def ^:const +imates-uuid-ns+ #uuid "3642a582-565f-4070-beba-af797ab27a6e")
(def ^:const +icons-uuid-ns+ #uuid "3642a582-565f-4070-beba-af797ab27a6f")
(s/def ::name string?) (s/def ::name string?)
(s/def ::path string?) (s/def ::path string?)
@ -41,14 +42,71 @@
[reader] [reader]
(PushbackReader. ^Reader reader)) (PushbackReader. ^Reader reader))
;; --- Colors Collections Importer ;; --- Icons Collections Importer
(defn- create-image-collection (defn- create-icons-collection
"Create or replace image collection by its name."
[conn {:keys [name] :as entry}]
(println "Creating icons collection:" name)
(let [id (uuid/namespaced +icons-uuid-ns+ name)
sqlv (sql/create-icons-collection {:id id :name name})]
(sc/execute conn sqlv)
id))
(defn- retrieve-icon
[conn id]
{:pre [(uuid? id)]}
(let [sqlv (sql/get-icon {:id id})]
(some->> (sc/fetch-one conn sqlv)
(data/normalize-attrs))))
;; (defn- create-icon
;; [conn collid iconid localpath]
;; {:pre [(fs/path? localpath)
;; (uuid? collid)
;; (uuid? imageid)]}
;; (let [filename (fs/base-name localpath)
;; storage media/images-storage
;; [width height] (time (retrieve-image-size localpath))
;; extension (second (fs/split-ext filename))
;; path @(st/save storage filename localpath)
;; params {:name filename
;; :path (str path)
;; :mimetype (case extension
;; ".jpg" "image/jpeg"
;; ".png" "image/png")
;; :width width
;; :height height
;; :collection collid
;; :id imageid}
;; sqlv (sql/create-image params)]
;; (sc/execute conn sqlv)))
(defn- import-icon
[conn id fpath]
{:pre [(uuid? id) (fs/path? fpath)]}
(println "Importing icon:" (str fpath))
(let [filename (fs/base-name fpath)
iconid (uuid/namespaced +imates-uuid-ns+ (str id filename))]
#_(create-icon conn id iconid fpath)))
(defn- process-icons-entry
[conn basedir {:keys [path regex] :as entry}]
{:pre [(us/valid? ::import-entry entry)]}
(let [id (create-icons-collection conn entry)
path (fs/resolve basedir path)]
(doseq [fpath (fs/list-files path)]
(when (re-matches regex (str fpath))
(import-icon conn id fpath)))))
;; --- Images Collections Importer
(defn- create-images-collection
"Create or replace image collection by its name." "Create or replace image collection by its name."
[conn {:keys [name] :as entry}] [conn {:keys [name] :as entry}]
(println "Creating image collection:" name) (println "Creating image collection:" name)
(let [id (uuid/namespaced +imates-uuid-ns+ name) (let [id (uuid/namespaced +imates-uuid-ns+ name)
sqlv (sql/create-image-collection {:id id :name name})] sqlv (sql/create-images-collection {:id id :name name})]
(sc/execute conn sqlv) (sc/execute conn sqlv)
id)) id))
@ -110,7 +168,7 @@
(defn- process-images-entry (defn- process-images-entry
[conn basedir {:keys [path regex] :as entry}] [conn basedir {:keys [path regex] :as entry}]
{:pre [(us/valid? ::import-entry entry)]} {:pre [(us/valid? ::import-entry entry)]}
(let [id (create-image-collection conn entry) (let [id (create-images-collection conn entry)
path (fs/resolve basedir path)] path (fs/resolve basedir path)]
(doseq [fpath (fs/list-files path)] (doseq [fpath (fs/list-files path)]
(when (re-matches regex (str fpath)) (when (re-matches regex (str fpath))