fix: Collectible screen design issues (#19721)

fix: Collectible screen design issues (#19721)
This commit is contained in:
Omar Basem 2024-05-13 12:40:31 +04:00 committed by GitHub
parent f50ca4606f
commit 12515a4904
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
10 changed files with 59 additions and 44 deletions

View File

@ -9,10 +9,17 @@
:size-20 20 :size-20 20
nil)) nil))
(defn collection-avatar (defn collection-avatar-container
[theme size] [theme size]
{:width (get-dimensions size) {:width (get-dimensions size)
:height (get-dimensions size) :height (get-dimensions size)
:border-width 1 :border-width 1
:border-color (colors/theme-colors colors/neutral-80-opa-10 colors/white-opa-10 theme) :border-color (colors/theme-colors colors/neutral-80-opa-10 colors/white-opa-10 theme)
:border-radius 6}) :border-radius 6
:justify-content :center
:align-items :center})
(defn collection-avatar
[size]
{:width (get-dimensions size)
:height (get-dimensions size)})

View File

@ -2,6 +2,7 @@
(:require (:require
[quo.components.avatars.collection-avatar.style :as style] [quo.components.avatars.collection-avatar.style :as style]
[quo.theme :as quo.theme] [quo.theme :as quo.theme]
[react-native.core :as rn]
[react-native.fast-image :as fast-image])) [react-native.fast-image :as fast-image]))
(defn view (defn view
@ -11,9 +12,10 @@
:theme - keyword -> :light/:dark" :theme - keyword -> :light/:dark"
[{:keys [image size on-load-end on-error] :or {size :size-24}}] [{:keys [image size on-load-end on-error] :or {size :size-24}}]
(let [theme (quo.theme/use-theme)] (let [theme (quo.theme/use-theme)]
[fast-image/fast-image [rn/view {:style (style/collection-avatar-container theme size)}
{:accessibility-label :collection-avatar [fast-image/fast-image
:source image {:accessibility-label :collection-avatar
:on-load-end on-load-end :source image
:on-error on-error :on-load-end on-load-end
:style (style/collection-avatar theme size)}])) :on-error on-error
:style (style/collection-avatar size)}]]))

View File

@ -70,24 +70,23 @@
:type => :neutral/:negative/:positive :type => :neutral/:negative/:positive
" "
[{:keys [type icon title text action undo-duration undo-on-press container-style theme user] [{:keys [type icon title text action undo-duration undo-on-press container-style user]
:or {type :neutral icon :i/placeholder}}] :or {type :neutral icon :i/placeholder}}]
(let [context-theme (quo.theme/use-theme) (let [theme (quo.theme/use-theme)
context-theme (or theme context-theme) icon-name (case type
icon-name (case type :positive (if (= theme :light)
:positive (if (= theme :light) :i/correct
:i/correct :i/correct-dark)
:i/correct-dark) :negative (if (= theme :light)
:negative (if (= theme :light) :i/incorrect
:i/incorrect :i/incorrect-dark)
:i/incorrect-dark) :neutral icon)]
:neutral icon)] [quo.theme/provider theme
[quo.theme/provider context-theme
[toast-container [toast-container
{:left (cond user {:left (cond user
[user-avatar/user-avatar user] [user-avatar/user-avatar user]
icon-name icon-name
[icon/icon icon-name (style/icon type context-theme)]) [icon/icon icon-name (style/icon type theme)])
:title title :title title
:text text :text text
:right (if undo-duration :right (if undo-duration
@ -96,3 +95,4 @@
:undo-on-press undo-on-press}] :undo-on-press undo-on-press}]
action) action)
:container-style container-style}]])) :container-style container-style}]]))

View File

@ -3,7 +3,7 @@
[quo.foundations.colors :as colors])) [quo.foundations.colors :as colors]))
(defn container (defn container
[size card? blur? theme] [{:keys [size card? blur? actionable? theme]}]
{:flex-direction :row {:flex-direction :row
:justify-content :space-between :justify-content :space-between
:padding-vertical (when (= size :default) 8) :padding-vertical (when (= size :default) 8)
@ -11,8 +11,11 @@
:border-radius 16 :border-radius 16
:border-width (when (and card? (not= size :small)) 1) :border-width (when (and card? (not= size :small)) 1)
:background-color (if blur? :background-color (if blur?
colors/white-opa-5 (if actionable? :transparent colors/white-opa-5)
(colors/theme-colors colors/white colors/neutral-95 theme)) (colors/theme-colors
(if actionable? colors/white colors/neutral-2_5)
(if actionable? colors/neutral-95 colors/neutral-90)
theme))
:border-color (if blur? :border-color (if blur?
colors/white-opa-10 colors/white-opa-10
(colors/theme-colors colors/neutral-10 (colors/theme-colors colors/neutral-10

View File

@ -125,7 +125,12 @@
{:accessibility-label :data-item {:accessibility-label :data-item
:disabled (not icon-right?) :disabled (not icon-right?)
:on-press on-press :on-press on-press
:style (merge (style/container size card? blur? theme) container-style)} :style (merge (style/container {:size size
:card? card?
:blur? blur?
:actionable? on-press
:theme theme})
container-style)}
[left-side props] [left-side props]
(when (and (= :default status) (not= :small size)) (when (and (= :default status) (not= :small size))
[right-side [right-side

View File

@ -16,4 +16,4 @@
(def ^:const default-dimension 1000) (def ^:const default-dimension 1000)
(def ^:const margin 8) (def ^:const margin 16)

View File

@ -64,7 +64,8 @@
[quo/page-nav [quo/page-nav
(cond-> {:margin-top (safe-area/get-top) (cond-> {:margin-top (safe-area/get-top)
:type :no-title :type :no-title
:background (if (= 1 (reanimated/get-shared-value opacity-animation)) :background (if (or (:blur? page-nav-props)
(= 1 (reanimated/get-shared-value opacity-animation)))
:blur :blur
:photo) :photo)
:right-side page-nav-right-section-buttons :right-side page-nav-right-section-buttons

View File

@ -2,7 +2,6 @@
(:require (:require
[oops.core :as oops] [oops.core :as oops]
[quo.core :as quo] [quo.core :as quo]
[react-native.platform :as platform]
[reagent.core :as reagent] [reagent.core :as reagent]
[status-im.common.lightbox.constants :as constants] [status-im.common.lightbox.constants :as constants]
[status-im.contexts.chat.messenger.messages.content.lightbox.style :as style] [status-im.contexts.chat.messenger.messages.content.lightbox.style :as style]
@ -36,7 +35,6 @@
[:lightbox/save-image-to-gallery [:lightbox/save-image-to-gallery
uri uri
#(rf/dispatch [:toasts/upsert #(rf/dispatch [:toasts/upsert
{:id :random-id {:id :random-id
:type :positive :type :positive
:container-style {:bottom (when platform/android? 20)} :text (i18n/label :t/photo-saved)}])]))}]]]))
:text (i18n/label :t/photo-saved)}])]))}]]]))

View File

@ -1,7 +1,6 @@
(ns status-im.contexts.wallet.collectible.options.view (ns status-im.contexts.wallet.collectible.options.view
(:require (:require
[quo.core :as quo] [quo.core :as quo]
[react-native.platform :as platform]
[status-im.contexts.wallet.common.utils.external-links :as external-links] [status-im.contexts.wallet.common.utils.external-links :as external-links]
[utils.i18n :as i18n] [utils.i18n :as i18n]
[utils.re-frame :as rf] [utils.re-frame :as rf]
@ -28,10 +27,9 @@
[:lightbox/save-image-to-gallery [:lightbox/save-image-to-gallery
uri uri
#(rf/dispatch [:toasts/upsert #(rf/dispatch [:toasts/upsert
{:id :random-id {:id :random-id
:type :positive :type :positive
:container-style {:bottom (when platform/android? 20)} :text (i18n/label :t/photo-saved)}])]))}]
:text (i18n/label :t/photo-saved)}])]))}]
[{:icon :i/share [{:icon :i/share
:accessibility-label :share-collectible :accessibility-label :share-collectible
:label (i18n/label :t/share-collectible) :label (i18n/label :t/share-collectible)

View File

@ -106,7 +106,8 @@
{:name collectible-name {:name collectible-name
:image preview-uri}]) :image preview-uri}])
:theme theme}])}] :theme theme}])}]
:picture preview-uri}} :picture preview-uri
:blur? true}}
[rn/view {:style style/container} [rn/view {:style style/container}
[quo/expanded-collectible [quo/expanded-collectible
{:image-src preview-uri {:image-src preview-uri