mirror of
https://github.com/penpot/penpot.git
synced 2025-01-08 07:50:43 -05:00
🐛 Fix thumbnails handling on dashboard libraries
This commit is contained in:
parent
2db5925e60
commit
2a81d8563a
3 changed files with 35 additions and 21 deletions
|
@ -5,19 +5,24 @@
|
||||||
### :boom: Breaking changes & Deprecations
|
### :boom: Breaking changes & Deprecations
|
||||||
|
|
||||||
### :sparkles: New features
|
### :sparkles: New features
|
||||||
|
|
||||||
- Default naming of text layers [Taiga #2836](https://tree.taiga.io/project/penpot/us/2836)
|
- Default naming of text layers [Taiga #2836](https://tree.taiga.io/project/penpot/us/2836)
|
||||||
- Create typography style from a selected text layer[Taiga #3041](https://tree.taiga.io/project/penpot/us/3041)
|
- Create typography style from a selected text layer[Taiga #3041](https://tree.taiga.io/project/penpot/us/3041)
|
||||||
- Board as ruler origin [Taiga #4833](https://tree.taiga.io/project/penpot/us/4833)
|
- Board as ruler origin [Taiga #4833](https://tree.taiga.io/project/penpot/us/4833)
|
||||||
- Access tokens support [Taiga #4460](https://tree.taiga.io/project/penpot/us/4460)
|
- Access tokens support [Taiga #4460](https://tree.taiga.io/project/penpot/us/4460)
|
||||||
- Show interactions setting at the view mode [Taiga #1330](https://tree.taiga.io/project/penpot/issue/1330)
|
- Show interactions setting at the view mode [Taiga #1330](https://tree.taiga.io/project/penpot/issue/1330)
|
||||||
|
- Improve dashboard performance related to thumbnails; now the thumbnails are
|
||||||
|
rendered as bitmap images.
|
||||||
|
|
||||||
### :bug: Bugs fixed
|
### :bug: Bugs fixed
|
||||||
|
|
||||||
- Fix files can be opened from multiple urls [Taiga #5310](https://tree.taiga.io/project/penpot/issue/5310)
|
- Fix files can be opened from multiple urls [Taiga #5310](https://tree.taiga.io/project/penpot/issue/5310)
|
||||||
- Fix asset color item was created from the selected layer [Taiga #5180](https://tree.taiga.io/project/penpot/issue/5180)
|
- Fix asset color item was created from the selected layer [Taiga #5180](https://tree.taiga.io/project/penpot/issue/5180)
|
||||||
|
|
||||||
### :arrow_up: Deps updates
|
### :arrow_up: Deps updates
|
||||||
|
|
||||||
### :heart: Community contributions by (Thank you!)
|
### :heart: Community contributions by (Thank you!)
|
||||||
|
|
||||||
- Update Typography palette order (by @akshay-gupta7) [Github #3156](https://github.com/penpot/penpot/pull/3156)
|
- Update Typography palette order (by @akshay-gupta7) [Github #3156](https://github.com/penpot/penpot/pull/3156)
|
||||||
- Palettes (color, typographies) empty state (by @akshay-gupta7) [Github #3160](https://github.com/penpot/penpot/pull/3160)
|
- Palettes (color, typographies) empty state (by @akshay-gupta7) [Github #3160](https://github.com/penpot/penpot/pull/3160)
|
||||||
- Duplicate objects via drag + alt (by @akshay-gupta7) [Github #3147](https://github.com/penpot/penpot/pull/3147)
|
- Duplicate objects via drag + alt (by @akshay-gupta7) [Github #3147](https://github.com/penpot/penpot/pull/3147)
|
||||||
|
|
|
@ -549,9 +549,11 @@
|
||||||
f.created_at,
|
f.created_at,
|
||||||
f.modified_at,
|
f.modified_at,
|
||||||
f.name,
|
f.name,
|
||||||
f.is_shared
|
f.is_shared,
|
||||||
|
ft.media_id
|
||||||
from file as f
|
from file as f
|
||||||
inner join project as p on (p.id = f.project_id)
|
inner join project as p on (p.id = f.project_id)
|
||||||
|
left join file_thumbnail as ft on (ft.file_id = f.id and ft.revn = f.revn)
|
||||||
where f.is_shared = true
|
where f.is_shared = true
|
||||||
and f.deleted_at is null
|
and f.deleted_at is null
|
||||||
and p.deleted_at is null
|
and p.deleted_at is null
|
||||||
|
@ -582,6 +584,12 @@
|
||||||
(->> (db/exec! conn [sql:team-shared-files team-id])
|
(->> (db/exec! conn [sql:team-shared-files team-id])
|
||||||
(into #{} (comp
|
(into #{} (comp
|
||||||
(map decode-row)
|
(map decode-row)
|
||||||
|
(map (fn [row]
|
||||||
|
(if-let [media-id (:media-id row)]
|
||||||
|
(-> row
|
||||||
|
(dissoc :media-id)
|
||||||
|
(assoc :thumbnail-uri (resolve-public-uri media-id)))
|
||||||
|
(dissoc row :media-id))))
|
||||||
(map #(assoc % :library-summary (library-summary %)))
|
(map #(assoc % :library-summary (library-summary %)))
|
||||||
(map #(dissoc % :data)))))))
|
(map #(dissoc % :data)))))))
|
||||||
|
|
||||||
|
|
|
@ -23,38 +23,39 @@
|
||||||
[{:keys [team] :as props}]
|
[{:keys [team] :as props}]
|
||||||
(let [files-map (mf/deref refs/dashboard-shared-files)
|
(let [files-map (mf/deref refs/dashboard-shared-files)
|
||||||
projects (mf/deref refs/dashboard-projects)
|
projects (mf/deref refs/dashboard-projects)
|
||||||
|
|
||||||
default-project (->> projects vals (d/seek :is-default))
|
default-project (->> projects vals (d/seek :is-default))
|
||||||
files (if (nil? files-map)
|
|
||||||
nil
|
files (mf/with-memo [files-map]
|
||||||
(->> (vals files-map)
|
(if (nil? files-map)
|
||||||
(sort-by :modified-at)
|
nil
|
||||||
(reverse)))
|
(->> (vals files-map)
|
||||||
|
(sort-by :modified-at)
|
||||||
|
(reverse))))
|
||||||
|
|
||||||
components-v2 (features/use-feature :components-v2)
|
components-v2 (features/use-feature :components-v2)
|
||||||
|
|
||||||
width (mf/use-state nil)
|
width (mf/use-state nil)
|
||||||
rowref (mf/use-ref)
|
rowref (mf/use-ref)
|
||||||
itemsize (if (>= @width 1030)
|
|
||||||
280
|
itemsize (if (>= @width 1030) 280 230)
|
||||||
230)
|
|
||||||
ratio (if (some? @width) (/ @width itemsize) 0)
|
ratio (if (some? @width) (/ @width itemsize) 0)
|
||||||
nitems (mth/floor ratio)
|
nitems (mth/floor ratio)
|
||||||
limit (min 10 nitems)
|
limit (min 10 nitems)
|
||||||
limit (max 1 limit)]
|
limit (max 1 limit)]
|
||||||
(mf/use-effect
|
|
||||||
(mf/deps team)
|
|
||||||
(fn []
|
|
||||||
(when team
|
|
||||||
(let [tname (if (:is-default team)
|
|
||||||
(tr "dashboard.your-penpot")
|
|
||||||
(:name team))]
|
|
||||||
(dom/set-html-title (tr "title.dashboard.shared-libraries" tname))))))
|
|
||||||
|
|
||||||
(mf/use-effect
|
(mf/with-effect [team]
|
||||||
#(st/emit! (dd/fetch-shared-files)
|
(when team
|
||||||
|
(let [tname (if (:is-default team)
|
||||||
|
(tr "dashboard.your-penpot")
|
||||||
|
(:name team))]
|
||||||
|
(dom/set-html-title (tr "title.dashboard.shared-libraries" tname)))))
|
||||||
|
|
||||||
|
(mf/with-effect []
|
||||||
|
(st/emit! (dd/fetch-shared-files)
|
||||||
(dd/clear-selected-files)))
|
(dd/clear-selected-files)))
|
||||||
|
|
||||||
(mf/with-effect
|
(mf/with-effect []
|
||||||
(let [node (mf/ref-val rowref)
|
(let [node (mf/ref-val rowref)
|
||||||
mnt? (volatile! true)
|
mnt? (volatile! true)
|
||||||
sub (->> (wapi/observe-resize node)
|
sub (->> (wapi/observe-resize node)
|
||||||
|
@ -73,7 +74,7 @@
|
||||||
[:header.dashboard-header {:ref rowref}
|
[:header.dashboard-header {:ref rowref}
|
||||||
[:div.dashboard-title#dashboard-libraries-title
|
[:div.dashboard-title#dashboard-libraries-title
|
||||||
[:h1 (tr "dashboard.libraries-title")]]]
|
[:h1 (tr "dashboard.libraries-title")]]]
|
||||||
[:section.dashboard-container.no-bg.dashboard-shared
|
[:section.dashboard-container.no-bg.dashboard-shared
|
||||||
[:& grid {:files files
|
[:& grid {:files files
|
||||||
:project default-project
|
:project default-project
|
||||||
:origin :libraries
|
:origin :libraries
|
||||||
|
|
Loading…
Reference in a new issue