mirror of
https://github.com/status-im/status-react.git
synced 2025-01-28 03:36:23 +00:00
chats list UI refresh
This commit is contained in:
parent
9345f77dd8
commit
9f2af87393
BIN
android/app/src/main/assets/fonts/Roboto-Bold.ttf
Normal file
BIN
android/app/src/main/assets/fonts/Roboto-Bold.ttf
Normal file
Binary file not shown.
BIN
android/app/src/main/assets/fonts/Roboto-Light.ttf
Normal file
BIN
android/app/src/main/assets/fonts/Roboto-Light.ttf
Normal file
Binary file not shown.
BIN
android/app/src/main/assets/fonts/Roboto-Medium.ttf
Normal file
BIN
android/app/src/main/assets/fonts/Roboto-Medium.ttf
Normal file
Binary file not shown.
BIN
android/app/src/main/assets/fonts/Roboto-Regular.ttf
Normal file
BIN
android/app/src/main/assets/fonts/Roboto-Regular.ttf
Normal file
Binary file not shown.
Binary file not shown.
Before Width: | Height: | Size: 353 B After Width: | Height: | Size: 522 B |
@ -27,6 +27,19 @@
|
|||||||
:toolbar-with-search-content {:padding-left 30}
|
:toolbar-with-search-content {:padding-left 30}
|
||||||
:sized-text {:margin-top 0
|
:sized-text {:margin-top 0
|
||||||
:additional-height 0}
|
:additional-height 0}
|
||||||
|
:chat-list {:list-container {:background-color styles/color-light-gray}
|
||||||
|
:chat-container {:height 76}
|
||||||
|
:chat-icon-container {:height 76}
|
||||||
|
:chat-info-container {:margin-top 16}
|
||||||
|
:chat-options-container {:margin-top 16}
|
||||||
|
:item-lower-container {:margin-top 4}
|
||||||
|
:chat-name {:height 24}
|
||||||
|
:last-message {:font-size 14
|
||||||
|
:height 24}
|
||||||
|
:last-message-timestamp {:font-size 14}
|
||||||
|
:unread-count {:top 2}
|
||||||
|
:public-group-icon-container {:margin-top 4}
|
||||||
|
:private-group-icon-container {:margin-top 4}}
|
||||||
:chat {:new-message {:border-top-color styles/color-transparent
|
:chat {:new-message {:border-top-color styles/color-transparent
|
||||||
:border-top-width 0.5}}
|
:border-top-width 0.5}}
|
||||||
:discover {:subtitle {:color styles/color-gray2
|
:discover {:subtitle {:color styles/color-gray2
|
||||||
@ -114,11 +127,11 @@
|
|||||||
:font-size 12}})
|
:font-size 12}})
|
||||||
|
|
||||||
(def fonts
|
(def fonts
|
||||||
{:light {:font-family "sans-serif-light"}
|
{:light {:font-family "Roboto-Light"}
|
||||||
:default {:font-family "sans-serif"}
|
:default {:font-family "Roboto-Regular"}
|
||||||
:medium {:font-family "sans-serif-medium"}
|
:medium {:font-family "Roboto-Medium"}
|
||||||
|
|
||||||
:toolbar-title {:font-family "sans-serif"}})
|
:toolbar-title {:font-family "Roboto-Regular"}})
|
||||||
|
|
||||||
;; Dialogs
|
;; Dialogs
|
||||||
|
|
||||||
@ -140,7 +153,8 @@
|
|||||||
:list-selection-fn show-dialog
|
:list-selection-fn show-dialog
|
||||||
:tabs {:tab-shadows? true}
|
:tabs {:tab-shadows? true}
|
||||||
:chats {:action-button? true
|
:chats {:action-button? true
|
||||||
:new-chat-in-toolbar? false}
|
:new-chat-in-toolbar? false
|
||||||
|
:render-separator? false}
|
||||||
:uppercase? true
|
:uppercase? true
|
||||||
:contacts {:action-button? true
|
:contacts {:action-button? true
|
||||||
:new-contact-in-toolbar? false
|
:new-contact-in-toolbar? false
|
||||||
|
@ -14,74 +14,99 @@
|
|||||||
[status-im.components.drawer.view :refer [open-drawer]]
|
[status-im.components.drawer.view :refer [open-drawer]]
|
||||||
[status-im.components.styles :refer [color-blue]]
|
[status-im.components.styles :refer [color-blue]]
|
||||||
[status-im.components.status-bar :refer [status-bar]]
|
[status-im.components.status-bar :refer [status-bar]]
|
||||||
[status-im.components.toolbar.view :refer [toolbar-with-search]]
|
[status-im.components.toolbar-new.view :refer [toolbar toolbar-with-search]]
|
||||||
[status-im.components.toolbar.actions :as act]
|
[status-im.components.toolbar-new.actions :as act]
|
||||||
|
[status-im.components.toolbar-new.styles :as tst]
|
||||||
[status-im.components.icons.custom-icons :refer [ion-icon]]
|
[status-im.components.icons.custom-icons :refer [ion-icon]]
|
||||||
[status-im.components.react :refer [linear-gradient]]
|
[status-im.components.react :refer [linear-gradient]]
|
||||||
[status-im.components.sync-state.offline :refer [offline-view]]
|
[status-im.components.sync-state.offline :refer [offline-view]]
|
||||||
|
[status-im.components.context-menu :refer [context-menu]]
|
||||||
|
[status-im.components.tabs.styles :refer [tabs-height]]
|
||||||
[status-im.utils.listview :refer [to-datasource]]
|
[status-im.utils.listview :refer [to-datasource]]
|
||||||
[status-im.chats-list.views.chat-list-item :refer [chat-list-item]]
|
[status-im.chats-list.views.chat-list-item :refer [chat-list-item]]
|
||||||
[status-im.i18n :refer [label]]
|
|
||||||
[status-im.utils.platform :refer [platform-specific]]
|
|
||||||
[status-im.chats-list.styles :as st]
|
[status-im.chats-list.styles :as st]
|
||||||
[status-im.components.tabs.styles :refer [tabs-height]]))
|
[status-im.i18n :refer [label]]
|
||||||
|
[status-im.utils.platform :refer [platform-specific ios?]]))
|
||||||
|
|
||||||
(defview toolbar-view []
|
(def android-toolbar-popup-options
|
||||||
[chats-scrolled? [:get :chats-scrolled?]]
|
[{:text (label :t/edit) :value #(dispatch [:set-in [:chat-list-ui-props :edit?] true])}])
|
||||||
(let [new-chat? (get-in platform-specific [:chats :new-chat-in-toolbar?])
|
|
||||||
actions (if new-chat?
|
(defn android-toolbar-actions []
|
||||||
[(act/add #(dispatch [:navigate-to :group-contacts :people]))])]
|
[(act/search #(dispatch [:set-in [:toolbar-search :show] true]))
|
||||||
[toolbar-with-search
|
(act/opts android-toolbar-popup-options)])
|
||||||
{:show-search? false
|
|
||||||
:search-key :chat-list
|
(def ios-toolbar-popup-options
|
||||||
:title (label :t/chats)
|
[{:text (label :t/edit-chats) :value #(dispatch [:set-in [:chat-list-ui-props :edit?] true])}
|
||||||
:search-placeholder (label :t/search-for)
|
{:text (label :t/search-chats) :value #(dispatch [:set-in [:toolbar-search :show] true])}])
|
||||||
:nav-action (act/hamburger open-drawer)
|
|
||||||
:style (st/toolbar chats-scrolled?)
|
(defn ios-toolbar-actions []
|
||||||
:actions actions}]))
|
[(act/opts ios-toolbar-popup-options)
|
||||||
|
(act/add #(dispatch [:navigate-to :group-contacts :people]))])
|
||||||
|
|
||||||
|
(defn toolbar-view []
|
||||||
|
[toolbar {:title (label :t/chats)
|
||||||
|
:nav-action (act/hamburger open-drawer)
|
||||||
|
:actions (if ios?
|
||||||
|
(ios-toolbar-actions)
|
||||||
|
(android-toolbar-actions))}])
|
||||||
|
|
||||||
|
(defn toolbar-edit []
|
||||||
|
[toolbar {:nav-action (act/back #(dispatch [:set-in [:chat-list-ui-props :edit?] false]))
|
||||||
|
:title (label :t/edit-chats)}])
|
||||||
|
|
||||||
|
(defn toolbar-search []
|
||||||
|
[toolbar-with-search
|
||||||
|
{:show-search? true
|
||||||
|
:search-key :chat-list
|
||||||
|
:title (label :t/chats)
|
||||||
|
:search-placeholder (label :t/search-for)}])
|
||||||
|
|
||||||
(defn chats-action-button []
|
(defn chats-action-button []
|
||||||
[action-button {:button-color color-blue
|
[action-button {:button-color color-blue
|
||||||
:offset-x 16
|
:offset-x 16
|
||||||
:offset-y 22
|
:offset-y 22
|
||||||
:hide-shadow true
|
:hide-shadow true
|
||||||
:spacing 13}
|
:spacing 13
|
||||||
[action-button-item
|
:on-press #(dispatch [:navigate-to :group-contacts :people])}])
|
||||||
{:title (label :t/new-chat)
|
|
||||||
:buttonColor :#9b59b6
|
(defn chat-list-padding []
|
||||||
:onPress #(dispatch [:navigate-to :group-contacts :people])}
|
[view {:height (if ios? 0 8)
|
||||||
[ion-icon {:name :md-create
|
:background-color :white}])
|
||||||
:style st/create-icon}]]
|
|
||||||
[action-button-item
|
|
||||||
{:title (label :t/new-group-chat)
|
|
||||||
:buttonColor :#1abc9c
|
|
||||||
:onPress #(dispatch [:open-contact-toggle-list :chat-group])}
|
|
||||||
[icon :private_group_big st/group-icon]]
|
|
||||||
[action-button-item
|
|
||||||
{:title (label :t/new-public-group-chat)
|
|
||||||
:buttonColor :#1abc9c
|
|
||||||
:onPress #(dispatch [:navigate-to :new-public-group])}
|
|
||||||
[icon :public_group_big st/group-icon]]])
|
|
||||||
|
|
||||||
(defn chat-shadow-item []
|
(defn chat-shadow-item []
|
||||||
[view {:height 3}
|
(when-not ios?
|
||||||
[linear-gradient {:style {:height 3}
|
[view {:height 12}
|
||||||
:colors st/gradient-top-bottom-shadow}]])
|
[chat-list-padding]
|
||||||
|
[linear-gradient {:style {:height 4}
|
||||||
|
:colors st/gradient-top-bottom-shadow}]]))
|
||||||
|
|
||||||
|
(defn render-separator-fn [chats]
|
||||||
|
(fn [_ row-id _]
|
||||||
|
(list-item
|
||||||
|
(when (< row-id (dec (count chats)))
|
||||||
|
^{:key (str "separator-" row-id)}
|
||||||
|
[view st/chat-separator-wrapper
|
||||||
|
[view st/chat-separator-item]]))))
|
||||||
|
|
||||||
(defview chats-list []
|
(defview chats-list []
|
||||||
[chats [:get :chats]]
|
[chats [:filtered-chats]
|
||||||
|
edit? [:get-in [:chat-list-ui-props :edit?]]
|
||||||
|
search? [:get-in [:toolbar-search :show]]]
|
||||||
[view st/chats-container
|
[view st/chats-container
|
||||||
[toolbar-view]
|
(cond
|
||||||
|
edit? [toolbar-edit]
|
||||||
|
search? [toolbar-search]
|
||||||
|
:else [toolbar-view])
|
||||||
[list-view {:dataSource (to-datasource chats)
|
[list-view {:dataSource (to-datasource chats)
|
||||||
:renderRow (fn [[id :as row] _ _]
|
:renderRow (fn [[id :as row] _ _]
|
||||||
(list-item ^{:key id} [chat-list-item row]))
|
(list-item ^{:key id} [chat-list-item row edit?]))
|
||||||
:renderFooter #(list-item [chat-shadow-item])
|
:renderHeader #(when (seq chats) (list-item [chat-list-padding]))
|
||||||
:renderSeparator #(list-item
|
:renderFooter #(when (seq chats) (list-item [chat-shadow-item]))
|
||||||
(when (< %2 (- (count chats) 1))
|
:renderSeparator (when (get-in platform-specific [:chats :render-separator?])
|
||||||
^{:key (str "separator-" %2)}
|
(render-separator-fn chats))
|
||||||
[view st/chat-separator-wrapper
|
|
||||||
[view st/chat-separator-item]]))
|
|
||||||
:style st/list-container}]
|
:style st/list-container}]
|
||||||
(when (get-in platform-specific [:chats :action-button?])
|
(when (and (not edit?)
|
||||||
|
(not search?)
|
||||||
|
(get-in platform-specific [:chats :action-button?]))
|
||||||
[chats-action-button])
|
[chats-action-button])
|
||||||
[offline-view]])
|
[offline-view]])
|
||||||
|
@ -1,20 +1,20 @@
|
|||||||
(ns status-im.chats-list.styles
|
(ns status-im.chats-list.styles
|
||||||
(:require [status-im.components.styles :refer [color-white
|
(:require [status-im.components.styles :refer [color-white
|
||||||
color-light-gray
|
color-light-gray
|
||||||
color-separator
|
|
||||||
color-blue
|
color-blue
|
||||||
|
color-gray5
|
||||||
text1-color
|
text1-color
|
||||||
text2-color
|
text2-color
|
||||||
|
text4-color
|
||||||
|
separator-color
|
||||||
new-messages-count-color]]
|
new-messages-count-color]]
|
||||||
[status-im.components.tabs.styles :refer [tabs-height]]
|
[status-im.components.tabs.styles :refer [tabs-height]]
|
||||||
[status-im.components.toolbar.styles :refer [toolbar-background1
|
[status-im.components.toolbar.styles :refer [toolbar-background1
|
||||||
toolbar-background2]]
|
toolbar-background2]]
|
||||||
[status-im.utils.platform :as p]))
|
[status-im.utils.platform :as p]))
|
||||||
|
|
||||||
(defn toolbar [chats-scrolled?]
|
(defn toolbar []
|
||||||
(merge {:background-color (if chats-scrolled?
|
(merge {:background-color toolbar-background1}
|
||||||
toolbar-background1
|
|
||||||
toolbar-background2)}
|
|
||||||
(get-in p/platform-specific [:component-styles :toolbar])))
|
(get-in p/platform-specific [:component-styles :toolbar])))
|
||||||
|
|
||||||
|
|
||||||
@ -25,84 +25,89 @@
|
|||||||
|
|
||||||
(def chat-separator-wrapper
|
(def chat-separator-wrapper
|
||||||
{:background-color color-white
|
{:background-color color-white
|
||||||
:height 0.5
|
:opacity 0.5
|
||||||
:padding-left 74})
|
:height 1
|
||||||
|
:padding-left 72})
|
||||||
|
|
||||||
(def chat-separator-item
|
(def chat-separator-item
|
||||||
{:border-bottom-width 0.5
|
{:border-bottom-width 1
|
||||||
:border-bottom-color color-separator})
|
:border-bottom-color color-gray5})
|
||||||
|
|
||||||
(def chat-container
|
(def chat-container
|
||||||
{:flex-direction :row
|
(merge {:flex-direction :row
|
||||||
:background-color color-white
|
:background-color color-white}
|
||||||
:height 94})
|
(get-in p/platform-specific [:component-styles :chat-list :chat-container])))
|
||||||
|
|
||||||
(def chat-icon-container
|
(def chat-icon-container
|
||||||
{:margin-top -2
|
(merge {:padding-top 18
|
||||||
:margin-left -4
|
:padding-bottom 18
|
||||||
:padding 16
|
:padding-left 12
|
||||||
:width 48
|
:padding-right 20
|
||||||
:height 48})
|
:width 72}
|
||||||
|
(get-in p/platform-specific [:component-styles :chat-list :chat-icon-container])))
|
||||||
|
|
||||||
(def item-container
|
(def chat-info-container
|
||||||
{:flex-direction :column
|
(merge {:margin-bottom 13
|
||||||
:margin-left 30
|
:justify-content :space-between
|
||||||
:padding-top 16
|
:flex 1
|
||||||
:padding-right 16
|
:flex-direction :column}
|
||||||
:flex 1})
|
(get-in p/platform-specific [:component-styles :chat-list :chat-info-container])))
|
||||||
|
|
||||||
|
(def chat-options-container
|
||||||
|
(merge {:margin-right 16
|
||||||
|
:padding-top 10}
|
||||||
|
(get-in p/platform-specific [:component-styles :chat-list :chat-options-container])))
|
||||||
|
|
||||||
|
(def item-upper-container
|
||||||
|
{:flex 1
|
||||||
|
:flex-direction :row
|
||||||
|
:justify-content :space-between})
|
||||||
|
|
||||||
|
(def item-lower-container
|
||||||
|
(merge {:flex 1
|
||||||
|
:flex-direction :row
|
||||||
|
:justify-content :space-between}
|
||||||
|
(get-in p/platform-specific [:component-styles :chat-list :item-lower-container])))
|
||||||
|
|
||||||
(def name-view
|
(def name-view
|
||||||
{:flex-direction :row})
|
{:flex-direction :row
|
||||||
|
:flex-shrink 1})
|
||||||
|
|
||||||
(def name-text
|
(def name-text
|
||||||
{:color text1-color
|
(merge {:color text1-color
|
||||||
:font-size 14})
|
:font-size 16}
|
||||||
|
(get-in p/platform-specific [:component-styles :chat-list :chat-name])))
|
||||||
|
|
||||||
(def private-group-icon-container
|
(def private-group-icon-container
|
||||||
{:width 16
|
(merge {:width 16
|
||||||
:height 9
|
:height 12
|
||||||
:padding-top -4
|
:margin-right 6}
|
||||||
:margin-top (get-in p/platform-specific [:private-group-icon-container :margin-top])
|
(get-in p/platform-specific [:component-styles :chat-list :private-group-icon-container])))
|
||||||
:margin-right 6})
|
|
||||||
|
|
||||||
(def private-group-icon
|
(def private-group-icon
|
||||||
{:width 16
|
{:width 16
|
||||||
:height 16})
|
:height 16})
|
||||||
|
|
||||||
(def public-group-icon-container
|
(def public-group-icon-container
|
||||||
{:width 16
|
(merge {:width 16
|
||||||
:height 12
|
:height 12
|
||||||
:padding-top -2
|
:margin-right 6}
|
||||||
:margin-top (get-in p/platform-specific [:public-group-icon-container :margin-top])
|
(get-in p/platform-specific [:component-styles :chat-list :public-group-icon-container])))
|
||||||
:margin-right 6})
|
|
||||||
|
|
||||||
(def public-group-icon
|
(def public-group-icon
|
||||||
{:width 16
|
{:width 16
|
||||||
:height 16
|
:height 16})
|
||||||
:margin-bottom -20})
|
|
||||||
|
|
||||||
(def memebers-text
|
|
||||||
{:marginTop 2
|
|
||||||
:marginLeft 4
|
|
||||||
:fontSize 12
|
|
||||||
:color text2-color})
|
|
||||||
|
|
||||||
(def last-message-container
|
(def last-message-container
|
||||||
{:margin-top 5
|
{:flex-shrink 1})
|
||||||
:margin-right 40})
|
|
||||||
|
|
||||||
(def last-message-text
|
(def last-message-text
|
||||||
{:color text1-color
|
(merge {:color text4-color}
|
||||||
:fontSize 14
|
(get-in p/platform-specific [:component-styles :chat-list :last-message])))
|
||||||
:lineHeight 20})
|
|
||||||
|
|
||||||
(def last-message-text-no-messages
|
|
||||||
(merge last-message-text
|
|
||||||
{:color text2-color}))
|
|
||||||
|
|
||||||
(def status-container
|
(def status-container
|
||||||
{:flex-direction :row
|
{:flex-direction :row
|
||||||
:top 18
|
:top 16
|
||||||
:right 16})
|
:right 16})
|
||||||
|
|
||||||
(def status-image
|
(def status-image
|
||||||
@ -111,33 +116,46 @@
|
|||||||
:height 7})
|
:height 7})
|
||||||
|
|
||||||
(def datetime-text
|
(def datetime-text
|
||||||
{:fontSize 12
|
(merge {:color text4-color}
|
||||||
:color text2-color
|
(get-in p/platform-specific [:component-styles :chat-list :last-message-timestamp])))
|
||||||
:marginLeft 5})
|
|
||||||
|
|
||||||
(def new-messages-container
|
(def new-messages-container
|
||||||
{:position :absolute
|
{:width 22
|
||||||
:top 54
|
:height 22
|
||||||
:right 16
|
:margin-left 15
|
||||||
:width 24
|
|
||||||
:height 24
|
|
||||||
:backgroundColor new-messages-count-color
|
:backgroundColor new-messages-count-color
|
||||||
:borderRadius 50})
|
:borderRadius 50})
|
||||||
|
|
||||||
(def new-messages-text
|
(def new-messages-text
|
||||||
{:top 5
|
(merge {:left 0
|
||||||
:left 0
|
:fontSize 12
|
||||||
:fontSize 10
|
:color color-blue
|
||||||
:color color-blue
|
:textAlign :center}
|
||||||
:textAlign :center})
|
(get-in p/platform-specific [:component-styles :chat-list :unread-count])))
|
||||||
|
|
||||||
(def chats-container
|
(def chats-container
|
||||||
{:flex 1})
|
{:flex 1})
|
||||||
|
|
||||||
(def list-container
|
(def list-container
|
||||||
(merge (get-in p/platform-specific [:component-styles :main-tab-list])
|
(merge (get-in p/platform-specific [:component-styles :main-tab-list])
|
||||||
{:background-color color-light-gray}))
|
(get-in p/platform-specific [:component-styles :chat-list :list-container])))
|
||||||
|
|
||||||
|
(def toolbar-actions
|
||||||
|
{:flex-direction :row
|
||||||
|
:padding-right 14})
|
||||||
|
|
||||||
|
(def toolbar-btn
|
||||||
|
{:width 24
|
||||||
|
:height 56
|
||||||
|
:margin-left 24
|
||||||
|
:alignItems :center
|
||||||
|
:justifyContent :center})
|
||||||
|
|
||||||
|
(def opts-btn
|
||||||
|
{:width 24
|
||||||
|
:height 24
|
||||||
|
:alignItems :center
|
||||||
|
:justifyContent :center})
|
||||||
|
|
||||||
(def create-icon
|
(def create-icon
|
||||||
{:fontSize 20
|
{:fontSize 20
|
||||||
@ -145,6 +163,8 @@
|
|||||||
:color color-white})
|
:color color-white})
|
||||||
|
|
||||||
(def group-icon
|
(def group-icon
|
||||||
{:height 22
|
{:margin-top 8
|
||||||
:width 22
|
:margin-right 6
|
||||||
:tint-color :white})
|
:width 14
|
||||||
|
:height 9
|
||||||
|
:tint-color :white})
|
||||||
|
19
src/status_im/chats_list/subs.cljs
Normal file
19
src/status_im/chats_list/subs.cljs
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
(ns status-im.chats-list.subs
|
||||||
|
(:require-macros [reagent.ratom :refer [reaction]])
|
||||||
|
(:require [re-frame.core :refer [register-sub subscribe]]
|
||||||
|
[clojure.string :as str]))
|
||||||
|
|
||||||
|
(defn search-filter [text item]
|
||||||
|
(let [name (-> (or (:name item) "")
|
||||||
|
(str/lower-case))
|
||||||
|
text (str/lower-case text)]
|
||||||
|
(not= (str/index-of name text) nil)))
|
||||||
|
|
||||||
|
(register-sub :filtered-chats
|
||||||
|
(fn [_ _]
|
||||||
|
(let [chats (subscribe [:get :chats])
|
||||||
|
search-text (subscribe [:get-in [:toolbar-search :text]])]
|
||||||
|
(reaction
|
||||||
|
(if @search-text
|
||||||
|
(filter #(search-filter @search-text (second %)) @chats)
|
||||||
|
@chats)))))
|
@ -6,7 +6,7 @@
|
|||||||
touchable-highlight]]
|
touchable-highlight]]
|
||||||
[status-im.chats-list.views.inner-item :refer [chat-list-item-inner-view]]))
|
[status-im.chats-list.views.inner-item :refer [chat-list-item-inner-view]]))
|
||||||
|
|
||||||
(defn chat-list-item [[chat-id chat]]
|
(defn chat-list-item [[chat-id chat] edit?]
|
||||||
[touchable-highlight {:on-press #(dispatch [:navigate-to :chat chat-id])}
|
[touchable-highlight {:on-press #(dispatch [:navigate-to :chat chat-id])}
|
||||||
[view
|
[view
|
||||||
[chat-list-item-inner-view (assoc chat :chat-id chat-id)]]])
|
[chat-list-item-inner-view (assoc chat :chat-id chat-id) edit?]]])
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
[clojure.string :as str]
|
[clojure.string :as str]
|
||||||
[status-im.components.react :refer [view image icon text]]
|
[status-im.components.react :refer [view image icon text]]
|
||||||
[status-im.components.chat-icon.screen :refer [chat-icon-view-chat-list]]
|
[status-im.components.chat-icon.screen :refer [chat-icon-view-chat-list]]
|
||||||
|
[status-im.components.context-menu :refer [context-menu]]
|
||||||
[status-im.models.commands :refer [parse-command-message-content]]
|
[status-im.models.commands :refer [parse-command-message-content]]
|
||||||
[status-im.chats-list.styles :as st]
|
[status-im.chats-list.styles :as st]
|
||||||
[status-im.utils.utils :refer [truncate-str]]
|
[status-im.utils.utils :refer [truncate-str]]
|
||||||
@ -36,16 +37,16 @@
|
|||||||
(cond
|
(cond
|
||||||
|
|
||||||
(not message)
|
(not message)
|
||||||
[text {:style st/last-message-text-no-messages}
|
[text {:style st/last-message-text}
|
||||||
(label :t/no-messages)]
|
(label :t/no-messages)]
|
||||||
|
|
||||||
(str/blank? content)
|
(str/blank? content)
|
||||||
[text {:style st/last-message-text-no-messages}
|
[text {:style st/last-message-text}
|
||||||
""]
|
""]
|
||||||
|
|
||||||
(:content content)
|
(:content content)
|
||||||
[text {:style st/last-message-text
|
[text {:style st/last-message-text
|
||||||
:number-of-lines 2}
|
:number-of-lines 1}
|
||||||
(:content content)]
|
(:content content)]
|
||||||
|
|
||||||
(:command content)
|
(:command content)
|
||||||
@ -53,7 +54,7 @@
|
|||||||
|
|
||||||
:else
|
:else
|
||||||
[text {:style st/last-message-text
|
[text {:style st/last-message-text
|
||||||
:number-of-lines 2}
|
:number-of-lines 1}
|
||||||
content])]))})))
|
content])]))})))
|
||||||
|
|
||||||
(defview message-status [{:keys [chat-id contacts]}
|
(defview message-status [{:keys [chat-id contacts]}
|
||||||
@ -85,40 +86,51 @@
|
|||||||
:font :medium}
|
:font :medium}
|
||||||
unviewed-messages]]))
|
unviewed-messages]]))
|
||||||
|
|
||||||
(defn chat-list-item-inner-view [{:keys [chat-id name color
|
(defn options-btn [chat-id]
|
||||||
online group-chat contacts public?]
|
(let [options [{:value #(dispatch [:remove-chat chat-id])
|
||||||
:as chat}]
|
:text (label :t/delete-chat)
|
||||||
(let [last-message (subscribe [:get-last-message chat-id])
|
:destructive? true}]]
|
||||||
name (or (get-contact-translated chat-id :name name)
|
[view st/opts-btn
|
||||||
(generate-gfy))
|
[context-menu
|
||||||
private-group? (and group-chat (not public?))
|
[icon :options_gray]
|
||||||
public-group? (and group-chat public?)]
|
options]]))
|
||||||
|
|
||||||
|
(defn chat-list-item-name [name group-chat? public?]
|
||||||
|
(let [private-group? (and group-chat? (not public?))
|
||||||
|
public-group? (and group-chat? public?)
|
||||||
|
chat-name (if (str/blank? name)
|
||||||
|
(generate-gfy)
|
||||||
|
(truncate-str name 30))]
|
||||||
|
[view st/name-view
|
||||||
|
(when public-group?
|
||||||
|
[view st/public-group-icon-container
|
||||||
|
[icon :public_group st/public-group-icon]])
|
||||||
|
(when private-group?
|
||||||
|
[view st/private-group-icon-container
|
||||||
|
[icon :private_group st/private-group-icon]])
|
||||||
|
[text {:style st/name-text}
|
||||||
|
(if public-group?
|
||||||
|
(str "#" chat-name)
|
||||||
|
chat-name)]]))
|
||||||
|
|
||||||
|
(defn chat-list-item-inner-view [{:keys [chat-id name color online
|
||||||
|
group-chat contacts public?] :as chat}
|
||||||
|
edit?]
|
||||||
|
(let [last-message (subscribe [:get-last-message chat-id])
|
||||||
|
name (or (get-contact-translated chat-id :name name)
|
||||||
|
(generate-gfy))]
|
||||||
[view st/chat-container
|
[view st/chat-container
|
||||||
[view st/chat-icon-container
|
[view st/chat-icon-container
|
||||||
[chat-icon-view-chat-list chat-id group-chat name color online]]
|
[chat-icon-view-chat-list chat-id group-chat name color online]]
|
||||||
[view st/item-container
|
[view st/chat-info-container
|
||||||
[view st/name-view
|
[view st/item-upper-container
|
||||||
(when public-group?
|
[chat-list-item-name name group-chat public?]
|
||||||
[view st/public-group-icon-container
|
(when (and (not edit?) @last-message)
|
||||||
[icon :public_group st/public-group-icon]])
|
[view
|
||||||
(when private-group?
|
[message-status chat @last-message]
|
||||||
[view st/private-group-icon-container
|
[message-timestamp @last-message]])]
|
||||||
[icon :private_group st/private-group-icon]])
|
[view st/item-lower-container
|
||||||
(let [chat-name (if (str/blank? name)
|
[message-content-text chat-id]
|
||||||
(generate-gfy)
|
(when-not edit? [unviewed-indicator chat-id])]]
|
||||||
(truncate-str name 30))]
|
[view st/chat-options-container
|
||||||
[text {:style st/name-text
|
(when edit? [options-btn chat-id])]]))
|
||||||
:font :medium}
|
|
||||||
(if public-group?
|
|
||||||
(str "#" chat-name)
|
|
||||||
chat-name)])
|
|
||||||
#_(when private-group?
|
|
||||||
[text {:style st/memebers-text}
|
|
||||||
(label-pluralize (inc (count contacts)) :t/members)])]
|
|
||||||
[message-content-text chat-id]]
|
|
||||||
[view
|
|
||||||
(when @last-message
|
|
||||||
[view st/status-container
|
|
||||||
[message-status chat @last-message]
|
|
||||||
[message-timestamp @last-message]])
|
|
||||||
[unviewed-indicator chat-id]]]))
|
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
online-color]]))
|
online-color]]))
|
||||||
|
|
||||||
(defn default-chat-icon [color]
|
(defn default-chat-icon [color]
|
||||||
{:margin 4
|
{:margin 0
|
||||||
:width 40
|
:width 40
|
||||||
:height 40
|
:height 40
|
||||||
:alignItems :center
|
:alignItems :center
|
||||||
@ -204,8 +204,8 @@
|
|||||||
|
|
||||||
(def pending-wrapper
|
(def pending-wrapper
|
||||||
{:position :absolute
|
{:position :absolute
|
||||||
:bottom 4
|
:bottom 0
|
||||||
:right 5
|
:right 0
|
||||||
:width 12
|
:width 12
|
||||||
:height 12
|
:height 12
|
||||||
:border-radius 6
|
:border-radius 6
|
||||||
|
@ -27,12 +27,13 @@
|
|||||||
(def list-selection-fn (:list-selection-fn platform-specific))
|
(def list-selection-fn (:list-selection-fn platform-specific))
|
||||||
|
|
||||||
(defn open-ios-menu [options]
|
(defn open-ios-menu [options]
|
||||||
(list-selection-fn {:options (mapv :text options)
|
(let [cancel-option {:text (label :t/cancel)}
|
||||||
:callback (fn [index]
|
options (conj options cancel-option)]
|
||||||
(when (< index (count options))
|
(list-selection-fn {:options options
|
||||||
(when-let [handler (:value (nth options index))]
|
:callback (fn [index]
|
||||||
(handler))))
|
(when (< index (count options))
|
||||||
:cancel-text (label :t/cancel)})
|
(when-let [handler (:value (nth options index))]
|
||||||
|
(handler))))}))
|
||||||
nil)
|
nil)
|
||||||
|
|
||||||
(defn context-menu [trigger options]
|
(defn context-menu [trigger options]
|
||||||
@ -44,8 +45,8 @@
|
|||||||
[menu {:onSelect #(when % (do (%) nil))}
|
[menu {:onSelect #(when % (do (%) nil))}
|
||||||
[menu-trigger trigger]
|
[menu-trigger trigger]
|
||||||
[menu-options st/context-menu-options
|
[menu-options st/context-menu-options
|
||||||
(for [{:keys [style value] :as option} options]
|
(for [{:keys [style value destructive?] :as option} options]
|
||||||
^{:key option}
|
^{:key option}
|
||||||
[menu-option {:value value}
|
[menu-option {:value value}
|
||||||
[text {:style (merge st/context-menu-text style)}
|
[text {:style (merge (st/context-menu-text destructive?) style)}
|
||||||
(:text option)]])]]))
|
(:text option)]])]]))
|
@ -24,6 +24,7 @@
|
|||||||
(def text1-disabled-color "#555555")
|
(def text1-disabled-color "#555555")
|
||||||
(def text2-color color-gray)
|
(def text2-color color-gray)
|
||||||
(def text3-color color-blue)
|
(def text3-color color-blue)
|
||||||
|
(def text4-color color-gray4)
|
||||||
(def online-color color-light-blue)
|
(def online-color color-light-blue)
|
||||||
(def new-messages-count-color color-blue-transparent)
|
(def new-messages-count-color color-blue-transparent)
|
||||||
(def chat-background color-light-gray)
|
(def chat-background color-light-gray)
|
||||||
@ -107,7 +108,7 @@
|
|||||||
:justify-content :center
|
:justify-content :center
|
||||||
:height 48}}})
|
:height 48}}})
|
||||||
|
|
||||||
(def context-menu-text
|
(defn context-menu-text [destructive?]
|
||||||
{:font-size 15
|
{:font-size 15
|
||||||
:line-height 20
|
:line-height 20
|
||||||
:color text1-color})
|
:color (if destructive? color-light-red text1-color)})
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
(ns status-im.ios.platform
|
(ns status-im.ios.platform
|
||||||
(:require [status-im.components.styles :as styles]))
|
(:require [status-im.components.styles :as styles]
|
||||||
|
[status-im.utils.utils :as utils]))
|
||||||
|
|
||||||
(def component-styles
|
(def component-styles
|
||||||
{:status-bar {:default {:height 20
|
{:status-bar {:default {:height 20
|
||||||
@ -27,6 +28,19 @@
|
|||||||
:additional-height 5}
|
:additional-height 5}
|
||||||
:actions-list-view {:border-bottom-color styles/color-gray3
|
:actions-list-view {:border-bottom-color styles/color-gray3
|
||||||
:border-bottom-width 0.5}
|
:border-bottom-width 0.5}
|
||||||
|
:chat-list {:list-container {:background-color styles/color-white}
|
||||||
|
:chat-container {:height 74}
|
||||||
|
:chat-icon-container {:height 74}
|
||||||
|
:chat-info-container {:margin-top 14}
|
||||||
|
:chat-options-container {:margin-top 14}
|
||||||
|
:item-lower-container {:margin-top 6}
|
||||||
|
:chat-name {:height 20}
|
||||||
|
:last-message {:font-size 15
|
||||||
|
:height 24}
|
||||||
|
:last-message-timestamp {:font-size 15}
|
||||||
|
:unread-count {:top 3}
|
||||||
|
:public-group-icon-container {:margin-top 2}
|
||||||
|
:private-group-icon-container {:margin-top 2}}
|
||||||
:chat {:new-message {:border-top-color styles/color-gray3
|
:chat {:new-message {:border-top-color styles/color-gray3
|
||||||
:border-top-width 0.5}}
|
:border-top-width 0.5}}
|
||||||
:discover {:subtitle {:color styles/color-steel
|
:discover {:subtitle {:color styles/color-steel
|
||||||
@ -150,10 +164,15 @@
|
|||||||
|
|
||||||
(def react-native (js/require "react-native"))
|
(def react-native (js/require "react-native"))
|
||||||
|
|
||||||
(defn show-action-sheet [{:keys [options callback cancel-text]}]
|
(defn action-sheet-options [options]
|
||||||
|
(let [destructive-opt-index (utils/first-index :destructive? options)]
|
||||||
|
(clj->js (merge {:options (mapv :text options)
|
||||||
|
:cancelButtonIndex (count options)}
|
||||||
|
(when destructive-opt-index {:destructiveButtonIndex destructive-opt-index})))))
|
||||||
|
|
||||||
|
(defn show-action-sheet [{:keys [options callback]}]
|
||||||
(.showActionSheetWithOptions (.-ActionSheetIOS react-native)
|
(.showActionSheetWithOptions (.-ActionSheetIOS react-native)
|
||||||
(clj->js {:options (conj options cancel-text)
|
(action-sheet-options options)
|
||||||
:cancelButtonIndex (count options)})
|
|
||||||
callback))
|
callback))
|
||||||
|
|
||||||
;; Structure to be exported
|
;; Structure to be exported
|
||||||
@ -164,7 +183,8 @@
|
|||||||
:list-selection-fn show-action-sheet
|
:list-selection-fn show-action-sheet
|
||||||
:tabs {:tab-shadows? false}
|
:tabs {:tab-shadows? false}
|
||||||
:chats {:action-button? false
|
:chats {:action-button? false
|
||||||
:new-chat-in-toolbar? true}
|
:new-chat-in-toolbar? true
|
||||||
|
:render-separator? true}
|
||||||
:uppercase? false
|
:uppercase? false
|
||||||
:contacts {:action-button? false
|
:contacts {:action-button? false
|
||||||
:new-contact-in-toolbar? true
|
:new-contact-in-toolbar? true
|
||||||
@ -174,4 +194,3 @@
|
|||||||
:private-group-icon-container {:margin-top 2}
|
:private-group-icon-container {:margin-top 2}
|
||||||
:group-chat-focus-line-height 1
|
:group-chat-focus-line-height 1
|
||||||
:public-group-chat-hash-style {:top 6 :left 3}})
|
:public-group-chat-hash-style {:top 6 :left 3}})
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
(:require-macros [reagent.ratom :refer [reaction]])
|
(:require-macros [reagent.ratom :refer [reaction]])
|
||||||
(:require [re-frame.core :refer [register-sub subscribe]]
|
(:require [re-frame.core :refer [register-sub subscribe]]
|
||||||
status-im.chat.subs
|
status-im.chat.subs
|
||||||
|
status-im.chats-list.subs
|
||||||
status-im.group-settings.subs
|
status-im.group-settings.subs
|
||||||
status-im.discover.subs
|
status-im.discover.subs
|
||||||
status-im.contacts.subs
|
status-im.contacts.subs
|
||||||
|
@ -122,8 +122,11 @@
|
|||||||
;chats
|
;chats
|
||||||
:chats "Chats"
|
:chats "Chats"
|
||||||
:new-chat "New chat"
|
:new-chat "New chat"
|
||||||
|
:delete-chat "Delete chat"
|
||||||
:new-group-chat "New group chat"
|
:new-group-chat "New group chat"
|
||||||
:new-public-group-chat "Join public group chat"
|
:new-public-group-chat "Join public chat"
|
||||||
|
:edit-chats "Edit chats"
|
||||||
|
:search-chats "Search chats"
|
||||||
:empty-topic "Empty topic"
|
:empty-topic "Empty topic"
|
||||||
:topic-format "Wrong format [a-z0-9\\-]+"
|
:topic-format "Wrong format [a-z0-9\\-]+"
|
||||||
:public-group-topic "Topic"
|
:public-group-topic "Topic"
|
||||||
|
@ -30,7 +30,7 @@
|
|||||||
(t/day today-date))
|
(t/day today-date))
|
||||||
yesterday (plus today (days -1))]
|
yesterday (plus today (days -1))]
|
||||||
(cond
|
(cond
|
||||||
(before? local yesterday) (unparse (formatter "dd MMM") local)
|
(before? local yesterday) (unparse (formatter "dd MMM hh:mm") local)
|
||||||
(before? local today) (label :t/datetime-yesterday)
|
(before? local today) (label :t/datetime-yesterday)
|
||||||
:else (today-format-fn local)))))
|
:else (today-format-fn local)))))
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user