mirror of
https://github.com/status-im/status-react.git
synced 2025-01-11 11:34:45 +00:00
Replace default keyExtractor with individual key-fns
Signed-off-by: Julien Eluard <julien.eluard@gmail.com>
This commit is contained in:
parent
946a44d257
commit
1b86179a81
@ -98,8 +98,8 @@
|
||||
[react/text {:style style/empty-chat-text}
|
||||
(i18n/label :t/empty-chat-description)]]
|
||||
[list/flat-list {:data messages
|
||||
:render-fn (fn [{:keys [message-id] :as message}]
|
||||
^{:key message-id}
|
||||
:key-fn #(or (:message-id %) (:value %))
|
||||
:render-fn (fn [message]
|
||||
[message-row {:group-chat group-chat
|
||||
:current-public-key current-public-key
|
||||
:row message}])
|
||||
|
@ -27,6 +27,7 @@
|
||||
:padding-bottom 12}}
|
||||
title]
|
||||
[list/flat-list {:data contacts
|
||||
:key-fn :address
|
||||
:render-fn (render-contact arg-index bot-db-key)
|
||||
:enableEmptySections true
|
||||
:keyboardShouldPersistTaps :always
|
||||
|
@ -76,5 +76,6 @@
|
||||
[container (* styles/item-height (count statuses))
|
||||
[list/flat-list {:contentContainerStyle styles/bottom-info-list-container
|
||||
:data statuses
|
||||
:key-fn :address
|
||||
:render-fn (render-status @contacts)
|
||||
:enableEmptySections true}]]]))})))
|
||||
|
@ -100,6 +100,11 @@
|
||||
(fn [data]
|
||||
(reagent/as-element (f (.-item data) (.-index data) (.-separators data)))))
|
||||
|
||||
(defn- wrap-key-fn [f]
|
||||
(fn [data index]
|
||||
{:post [(string? %)]}
|
||||
(f data index)))
|
||||
|
||||
(def default-separator [react/view styles/separator])
|
||||
|
||||
(def default-header [react/view styles/list-header-footer-spacing])
|
||||
@ -109,13 +114,13 @@
|
||||
(def section-separator [react/view styles/section-separator])
|
||||
|
||||
(defn- base-list-props
|
||||
[{:keys [render-fn empty-component header separator default-separator?]}]
|
||||
[{:keys [key-fn render-fn empty-component header separator default-separator?]}]
|
||||
(let [separator (or separator (when (and platform/ios? default-separator?) default-separator))]
|
||||
(merge {:keyExtractor (fn [_ i] (str i))}
|
||||
(when render-fn {:renderItem (wrap-render-fn render-fn)})
|
||||
(when separator {:ItemSeparatorComponent (fn [] (reagent/as-element separator))})
|
||||
(when empty-component {:ListEmptyComponent (fn [] (reagent/as-element empty-component))})
|
||||
(when header {:ListHeaderComponent (fn [] (reagent/as-element header))}))))
|
||||
(merge (when key-fn {:keyExtractor (wrap-key-fn key-fn)})
|
||||
(when render-fn {:renderItem (wrap-render-fn render-fn)})
|
||||
(when separator {:ItemSeparatorComponent (fn [] (reagent/as-element separator))})
|
||||
(when empty-component {:ListEmptyComponent (fn [] (reagent/as-element empty-component))})
|
||||
(when header {:ListHeaderComponent (fn [] (reagent/as-element header))}))))
|
||||
|
||||
;; Workaround an issue in reagent that does not consider JS array as JS value
|
||||
;; This forces clj <-> js serialization and breaks clj semantic
|
||||
@ -206,6 +211,7 @@
|
||||
[react/view (merge styles/action-separator
|
||||
action-separator-style)])
|
||||
:data actions
|
||||
:key-fn (fn [_ i] (str i))
|
||||
:render-fn #(render-action % styles)}]])
|
||||
|
||||
(defn list-with-label [{:keys [style]} label list]
|
||||
|
@ -37,6 +37,7 @@
|
||||
[react/view styles/accounts-container
|
||||
[react/view styles/accounts-list-container
|
||||
[list/flat-list {:data (vals accounts)
|
||||
:key-fn :address
|
||||
:render-fn (fn [account] [account-view account])
|
||||
:separator [react/view {:height 12}]}]]
|
||||
[react/view
|
||||
|
@ -43,6 +43,7 @@
|
||||
[react/text {:style open-dapp.styles/list-title}
|
||||
(i18n/label :t/contacts)]
|
||||
[list/flat-list {:data contacts
|
||||
:key-fn :address
|
||||
:render-fn render-row
|
||||
:default-separator? true
|
||||
:enableEmptySections true
|
||||
|
@ -73,5 +73,6 @@
|
||||
:font :medium}
|
||||
(i18n/label :t/selected)]]
|
||||
[list/flat-list {:data default-public-chats
|
||||
:key-fn identity
|
||||
:render-fn render-topic
|
||||
:default-separator? true}]]))
|
||||
|
@ -39,6 +39,7 @@
|
||||
[react/text {:style styles/list-title}
|
||||
(i18n/label :t/selected-dapps)]
|
||||
[list/flat-list {:data dapps
|
||||
:key-fn :dapp-url
|
||||
:render-fn render-row
|
||||
:default-separator? true
|
||||
:enableEmptySections true
|
||||
|
@ -32,6 +32,7 @@
|
||||
(letsubs [contacts [:all-added-group-contacts (:group-id group)]]
|
||||
[list/flat-list {:style styles/contacts-list
|
||||
:data contacts
|
||||
:key-fn :address
|
||||
:render-fn (render-row group edit?)
|
||||
:enableEmptySections true
|
||||
:keyboardShouldPersistTaps :always
|
||||
|
@ -51,6 +51,7 @@
|
||||
[toolbar/simple-toolbar (i18n/label :t/contacts)]
|
||||
[list/flat-list {:style st/contacts-list-modal
|
||||
:data contacts
|
||||
:key-fn :address
|
||||
:render-fn (render-row click-handler action params)
|
||||
:header (when-not (:hide-actions? params)
|
||||
[react/view
|
||||
|
@ -38,6 +38,7 @@
|
||||
true]
|
||||
(if (seq dapps)
|
||||
[list/flat-list {:data (vals dapps)
|
||||
:key-fn :dapp-url
|
||||
:render-fn render-dapp
|
||||
:horizontal true
|
||||
:default-separator? false
|
||||
@ -54,7 +55,9 @@
|
||||
(if (zero? extras)
|
||||
dapps
|
||||
(concat dapps
|
||||
(repeat (- columns extras) {:name ""})))))
|
||||
(map (fn [i] {:name ""
|
||||
:dapp-url (str "blank-" i)})
|
||||
(range (- columns extras)))))))
|
||||
|
||||
(defview main []
|
||||
(letsubs [all-dapps [:discover/all-dapps]]
|
||||
@ -65,6 +68,7 @@
|
||||
toolbar/default-nav-back
|
||||
[toolbar/content-title (i18n/label :t/dapps)]]
|
||||
[list/flat-list {:data (add-blank-dapps-for-padding columns (vals all-dapps))
|
||||
:key-fn :dapp-url
|
||||
:render-fn render-dapp
|
||||
:num-columns columns
|
||||
:content-container-style styles/all-dapps-flat-list}]]))))
|
||||
|
@ -19,6 +19,7 @@
|
||||
(defn tags-menu [tags]
|
||||
[react/view styles/tag-title-container
|
||||
[list/flat-list {:data tags
|
||||
:key-fn (fn [_ i] (str i))
|
||||
:render-fn render-tag
|
||||
:horizontal true
|
||||
:shows-horizontal-scroll-indicator false
|
||||
|
@ -126,6 +126,7 @@
|
||||
[react/view styles/public-chats-container
|
||||
[components/title-no-action :t/public-chats]
|
||||
[list/flat-list {:data public-chats-mock-data
|
||||
:key-fn :topic
|
||||
:render-fn render-public-chats-item}]])
|
||||
|
||||
(defview discover [current-view?]
|
||||
|
@ -37,6 +37,7 @@
|
||||
[react/view {:flex 1}
|
||||
[list/flat-list {:style contacts.styles/contacts-list
|
||||
:data contacts
|
||||
:key-fn :address
|
||||
:render-fn render-function
|
||||
:keyboardShouldPersistTaps :always}]])
|
||||
|
||||
|
@ -13,6 +13,7 @@
|
||||
[react/view {:flex 1}
|
||||
[list/flat-list {:data contacts
|
||||
:enableEmptySections true
|
||||
:key-fn :address
|
||||
:render-fn (fn [contact]
|
||||
[contact-view {:contact contact
|
||||
:extended? extended?
|
||||
|
@ -56,6 +56,7 @@
|
||||
[list/list-with-label {:flex 1}
|
||||
(i18n/label :t/members-title)
|
||||
[list/flat-list {:data contacts
|
||||
:key-fn :address
|
||||
:render-fn render-contact
|
||||
:bounces false
|
||||
:keyboardShouldPersistTaps :always
|
||||
|
@ -82,8 +82,9 @@
|
||||
(i18n/label :t/no-recent-chats)]]
|
||||
:else
|
||||
[list/flat-list {:data home-items
|
||||
:render-fn (fn [[home-item-id :as home-item]]
|
||||
^{:key home-item-id} [home-list-deletable home-item])}])
|
||||
:key-fn first
|
||||
:render-fn (fn [home-item]
|
||||
[home-list-deletable home-item])}])
|
||||
(when platform/android?
|
||||
[home-action-button])
|
||||
[connectivity/error-view]]))
|
||||
|
@ -66,6 +66,7 @@
|
||||
[react/view {:flex 1}
|
||||
[list/flat-list {:style styles/networks-list
|
||||
:data (vals networks)
|
||||
:key-fn :id
|
||||
:render-fn (render-network network)
|
||||
:header [react/view
|
||||
[actions-view
|
||||
|
@ -65,6 +65,7 @@
|
||||
[render-header wnodes]
|
||||
[list/flat-list {:data (vals wnodes)
|
||||
:separator? false
|
||||
:key-fn :id
|
||||
:render-fn (render-row current-wnode)
|
||||
:ListFooterComponent (reagent/as-element (render-footer))
|
||||
:style styles/wnodes-list}]]]))
|
||||
|
@ -84,6 +84,7 @@
|
||||
[react/view
|
||||
[list/flat-list {:data contacts
|
||||
:separator list/default-separator
|
||||
:key-fn :address
|
||||
:render-fn #(render-contact % admin?)}]]))
|
||||
|
||||
(defn members-list [admin?]
|
||||
|
@ -60,6 +60,7 @@
|
||||
[react/view {:style (assoc components.styles/flex :background-color :white)}
|
||||
[list/flat-list {:default-separator? true
|
||||
:data (concat [tokens/ethereum] (wallet/current-tokens visible-tokens network))
|
||||
:key-fn (comp str :symbol)
|
||||
:render-fn #(render-token % balance type)}]]]))
|
||||
|
||||
(defn send-assets []
|
||||
@ -129,6 +130,7 @@
|
||||
[components/toolbar (i18n/label :t/recipient)]
|
||||
[react/view styles/recent-recipients
|
||||
[list/flat-list {:data contacts
|
||||
:key-fn :address
|
||||
:render-fn render-contact}]]]))
|
||||
|
||||
(defn contact-code []
|
||||
|
@ -34,4 +34,5 @@
|
||||
(i18n/label :t/wallet-assets)]]
|
||||
[react/view {:style components.styles/flex}
|
||||
[list/flat-list {:data (tokens/tokens-for (ethereum/network->chain-keyword network))
|
||||
:key-fn (comp str :symbol)
|
||||
:render-fn #(render-token % visible-tokens)}]]]))
|
||||
|
@ -121,6 +121,7 @@
|
||||
(when error-message?
|
||||
(re-frame/dispatch [:wallet/show-error]))
|
||||
[list/section-list {:sections (map #(update-transactions % filter-data) transactions-history-list)
|
||||
:key-fn :hash
|
||||
:render-fn render-transaction
|
||||
:empty-component [react/text {:style styles/empty-text}
|
||||
(i18n/label :t/transactions-history-empty)]
|
||||
@ -131,6 +132,7 @@
|
||||
(letsubs [transactions [:wallet.transactions/unsigned-transactions-list]]
|
||||
[react/view {:style components.styles/flex}
|
||||
[list/flat-list {:data transactions
|
||||
:key-fn (fn [_ i] (str i))
|
||||
:render-fn render-transaction
|
||||
:empty-component [react/text {:style styles/empty-text
|
||||
:accessibility-label :no-unsigned-transactions-text}
|
||||
@ -171,7 +173,8 @@
|
||||
:accessibility-label :select-all-button}
|
||||
(i18n/label :t/transactions-filter-select-all)]]
|
||||
[react/view {:style (merge {:background-color :white} components.styles/flex)}
|
||||
[list/section-list {:sections (wrap-filter-data filter-data)}]]]))
|
||||
[list/section-list {:sections (wrap-filter-data filter-data)
|
||||
:key-fn :id}]]]))
|
||||
|
||||
(defn history-tab [active?]
|
||||
[react/text {:force-uppercase? true
|
||||
|
@ -75,6 +75,7 @@
|
||||
[list/flat-list
|
||||
{:default-separator? true
|
||||
:data assets
|
||||
:key-fn (comp str :symbol)
|
||||
:render-fn render-asset
|
||||
:on-refresh #(re-frame/dispatch [:update-wallet (map :symbol tokens)])
|
||||
:refreshing refreshing?}]]))
|
||||
|
Loading…
x
Reference in New Issue
Block a user