The [Cancel] and [Join] buttons are hidden within 'Join Community' overlay (#14971)

* The [Cancel] and [Join] buttons are hidden within 'Join Community' overlay

* Lint

* Fixes

* Lint fix
This commit is contained in:
Alexander 2023-02-10 13:59:36 +01:00 committed by GitHub
parent d1514ec52d
commit c12cab27f4
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 98 additions and 84 deletions

View File

@ -3,8 +3,7 @@
(defn container (defn container
[] []
{:flex 1 {:flex-direction :row
:flex-direction :row
:background-color (colors/theme-colors colors/neutral-5 colors/neutral-80-opa-40) :background-color (colors/theme-colors colors/neutral-5 colors/neutral-80-opa-40)
:padding 11 :padding 11
:align-self :stretch :align-self :stretch

View File

@ -31,13 +31,13 @@
:overflow :hidden}) :overflow :hidden})
(defn content-style (defn content-style
[insets] [insets bottom-safe-area-spacing?]
{:position :absolute {:position :absolute
:left 0 :left 0
:right 0 :right 0
:top 0 :top 0
:padding-top border-radius :padding-top border-radius
:padding-bottom (:bottom insets)}) :padding-bottom (if bottom-safe-area-spacing? (:bottom insets) 0)})
(defn selected-background (defn selected-background
[] []

View File

@ -87,17 +87,19 @@
visible? :visible? visible? :visible?
backdrop-dismiss? :backdrop-dismiss? backdrop-dismiss? :backdrop-dismiss?
expandable? :expandable? expandable? :expandable?
bottom-safe-area-spacing? :bottom-safe-area-spacing?
selected-item :selected-item selected-item :selected-item
is-initially-expaned? :expanded? is-initially-expanded? :expanded?
:or {show-handle? true :or {show-handle? true
backdrop-dismiss? true backdrop-dismiss? true
expandable? false expandable? false
is-initially-expaned? false}} bottom-safe-area-spacing? true
is-initially-expanded? false}}
props props
content-height (reagent/atom nil) content-height (reagent/atom nil)
show-bottom-sheet? (reagent/atom nil) show-bottom-sheet? (reagent/atom nil)
keyboard-was-shown? (reagent/atom false) keyboard-was-shown? (reagent/atom false)
expanded? (reagent/atom is-initially-expaned?) expanded? (reagent/atom is-initially-expanded?)
gesture-running? (reagent/atom false) gesture-running? (reagent/atom false)
reset-atoms (fn [] reset-atoms (fn []
(reset! show-bottom-sheet? nil) (reset! show-bottom-sheet? nil)
@ -226,7 +228,7 @@
{:behaviour (if platform/ios? :padding :height) {:behaviour (if platform/ios? :padding :height)
:style {:flex 1}} :style {:flex 1}}
[rn/view [rn/view
{:style (styles/content-style insets) {:style (styles/content-style insets bottom-safe-area-spacing?)
:on-layout (when-not (and :on-layout (when-not (and
(some? @content-height) (some? @content-height)
(> @content-height 0)) (> @content-height 0))

View File

@ -36,8 +36,7 @@
:margin-bottom 20}) :margin-bottom 20})
(def title-container (def title-container
{:flex 1 {:flex-direction :row
:flex-direction :row
:align-items :center :align-items :center
:justify-content :space-between}) :justify-content :space-between})
@ -56,10 +55,10 @@
{:flex 1 {:flex 1
:margin-right 12}) :margin-right 12})
(def request-button (defn bottom-container
{:margin-top 32 [safe-area-insets]
:margin-bottom 16 {:padding-top 32
:flex 1 :padding-bottom (:bottom safe-area-insets)
:flex-direction :row :flex-direction :row
:align-items :center :align-items :center
:justify-content :space-evenly}) :justify-content :space-evenly})

View File

@ -1,9 +1,10 @@
(ns status-im2.contexts.communities.menus.request-to-join.view (ns status-im2.contexts.communities.menus.request-to-join.view
(:require [quo.react-native :as rn] (:require [react-native.core :as rn]
[quo2.core :as quo] [react-native.safe-area :as safe-area]
[reagent.core :as reagent] [reagent.core :as reagent]
[utils.i18n :as i18n]
[status-im2.contexts.communities.menus.request-to-join.style :as style] [status-im2.contexts.communities.menus.request-to-join.style :as style]
[quo2.core :as quo]
[utils.i18n :as i18n]
[utils.re-frame :as rf] [utils.re-frame :as rf]
[utils.requests :as requests])) [utils.requests :as requests]))
@ -73,13 +74,22 @@
:render-fn community-rule-item}]) :render-fn community-rule-item}])
(defn request-to-join (defn request-to-join
[{:keys [permissions name id images [{:keys [permissions
can-join? can-request-access? name
id
images
can-join?
can-request-access?
requested-to-join-at]}] requested-to-join-at]}]
(let [agreed-to-rules? (reagent/atom false) (let [agreed-to-rules? (reagent/atom false)]
is-open? (not= 3 (:access permissions))] [safe-area/consumer
(fn [insets]
[:f>
(fn [] (fn []
[rn/scroll-view {:style style/page-container} (let [{window-height :height} (rn/use-window-dimensions)
is-open? (not= 3 (:access permissions))]
[rn/scroll-view {:style {:max-height (- window-height (:top insets))}}
[rn/view style/page-container
[rn/view [rn/view
{:style style/title-container} {:style style/title-container}
@ -102,6 +112,7 @@
:weight :semi-bold :weight :semi-bold
:size :paragraph-1} :size :paragraph-1}
(i18n/label :t/community-rules)] (i18n/label :t/community-rules)]
[community-rules-list community-rules] [community-rules-list community-rules]
[quo/disclaimer [quo/disclaimer
@ -109,13 +120,14 @@
:container-style {:margin-top 20} :container-style {:margin-top 20}
:on-change #(swap! agreed-to-rules? not)} :on-change #(swap! agreed-to-rules? not)}
(i18n/label :t/accept-community-rules)] (i18n/label :t/accept-community-rules)]
[rn/view
{:style style/request-button} [rn/view {:style (style/bottom-container insets)}
[quo/button [quo/button
{:accessibility-label :cancel {:accessibility-label :cancel
:on-press #(rf/dispatch [:bottom-sheet/hide]) :on-press #(rf/dispatch [:bottom-sheet/hide])
:type :grey :type :grey
:style style/cancel-button} (i18n/label :t/cancel)] :style style/cancel-button} (i18n/label :t/cancel)]
[quo/button [quo/button
{:accessibility-label :join-community-button {:accessibility-label :join-community-button
:on-press (fn [] :on-press (fn []
@ -125,8 +137,9 @@
(rf/dispatch [:bottom-sheet/hide])) (rf/dispatch [:bottom-sheet/hide]))
(do (and can-request-access? (do (and can-request-access?
(not (pos? requested-to-join-at)) (not (pos? requested-to-join-at))
(requests/can-request-access-again? requested-to-join-at)) (requests/can-request-access-again?
requested-to-join-at))
(rf/dispatch [:communities/request-to-join id]) (rf/dispatch [:communities/request-to-join id])
(rf/dispatch [:bottom-sheet/hide])))) (rf/dispatch [:bottom-sheet/hide]))))
:disabled (not @agreed-to-rules?) :disabled (not @agreed-to-rules?)
:style {:flex 1}} (request-to-join-text is-open?)]]]))) :style {:flex 1}} (request-to-join-text is-open?)]]]]))])]))

View File

@ -121,6 +121,7 @@
[:bottom-sheet/show-sheet [:bottom-sheet/show-sheet
{:content (fn [] [join-menu/request-to-join {:content (fn [] [join-menu/request-to-join
community]) community])
:bottom-safe-area-spacing? false
:content-height 300}]) :content-height 300}])
:accessibility-label :show-request-to-join-screen-button :accessibility-label :show-request-to-join-screen-button
:override-background-color community-color :override-background-color community-color