Spring animation

Former-commit-id: 8892d13db4ddd5a66c9daaea7e64d70d4e4e578e
This commit is contained in:
virvar 2016-05-31 14:23:30 +03:00
parent 0543b943f7
commit 81055c30bd
6 changed files with 55 additions and 47 deletions

View File

@ -4,6 +4,8 @@
[clojure.string :as str] [clojure.string :as str]
[status-im.components.animation :as anim] [status-im.components.animation :as anim]
[status-im.components.styles :refer [default-chat-color]] [status-im.components.styles :refer [default-chat-color]]
[status-im.chat.styles.response :as response-styles]
[status-im.chat.styles.response-suggestions :as response-suggestions-styles]
[status-im.chat.suggestions :as suggestions] [status-im.chat.suggestions :as suggestions]
[status-im.protocol.api :as api] [status-im.protocol.api :as api]
[status-im.models.messages :as messages] [status-im.models.messages :as messages]
@ -21,6 +23,8 @@
[status-im.utils.phone-number :refer [format-phone-number]] [status-im.utils.phone-number :refer [format-phone-number]]
[status-im.utils.datetime :as time])) [status-im.utils.datetime :as time]))
(def delta 1)
(register-handler :set-show-actions (register-handler :set-show-actions
(fn [db [_ show-actions]] (fn [db [_ show-actions]]
(assoc db :show-actions show-actions))) (assoc db :show-actions show-actions)))
@ -45,27 +49,52 @@
(assoc-in [:chats current-chat-id :command-input] {}) (assoc-in [:chats current-chat-id :command-input] {})
(update-in [:chats current-chat-id :input-text] safe-trim)))) (update-in [:chats current-chat-id :input-text] safe-trim))))
(defn animate-cancel-command [db height] (defn animate-cancel-command [db height-anim-value]
(anim/add-listener height (fn [val] (let [to-value 1]
(when (<= (.-value val) 1) (anim/add-listener height-anim-value
(anim/remove-all-listeners height) (fn [val]
(anim/stop-animation height) (when (<= (- to-value delta) (anim/value val) (+ to-value delta))
(anim/remove-all-listeners height-anim-value)
(dispatch [:cancel-command])))) (dispatch [:cancel-command]))))
(anim/start (anim/timing height {:toValue 1, :duration response-input-hiding-duration})) (anim/stop-animation height-anim-value)
(assoc-in db [:animations :response-input-is-hiding?] true)) (anim/start (anim/spring height-anim-value {:toValue to-value
:speed 10
:bounciness 1}))
(assoc-in db [:animations :response-input-is-hiding?] true)))
(register-handler :start-cancel-command (register-handler :start-cancel-command
(fn [{{height :response-suggestions-height (fn [{{height-anim-value :response-suggestions-height
hiding? :response-input-is-hiding?} :animations :as db} _] hiding? :response-input-is-hiding?} :animations :as db} _]
(if-not hiding? (if-not hiding?
(animate-cancel-command db height) (animate-cancel-command db height-anim-value)
db))) db)))
(defn update-response-suggestions-height [db]
(when (and (not (get-in db [:animations :response-input-is-hiding?]))
(commands/get-chat-command-to-msg-id db))
(let [command (commands/get-chat-command db)
text (commands/get-chat-command-content db)
suggestions (get-content-suggestions command text)
suggestions-height (min response-suggestions-styles/max-suggestions-height
(reduce + 0 (map #(if (:header %)
response-suggestions-styles/header-height
response-suggestions-styles/suggestion-height)
suggestions)))
height (+ suggestions-height response-styles/request-info-height)
anim-value (get-in db [:animations :response-suggestions-height])]
(anim/stop-animation anim-value)
(anim/start
(anim/spring anim-value {:toValue height
:speed 10
:bounciness 10}))))
db)
(register-handler :set-chat-command-content (register-handler :set-chat-command-content
(fn [{:keys [current-chat-id] :as db} [_ content]] (fn [{:keys [current-chat-id] :as db} [_ content]]
(-> db (-> db
(commands/set-chat-command-content content) (commands/set-chat-command-content content)
(assoc-in [:chats current-chat-id :input-text] nil)))) (assoc-in [:chats current-chat-id :input-text] nil)
(update-response-suggestions-height))))
(defn update-input-text (defn update-input-text
[{:keys [current-chat-id] :as db} text] [{:keys [current-chat-id] :as db} text]
@ -83,7 +112,9 @@
(register-handler :set-response-chat-command (register-handler :set-response-chat-command
(fn [db [_ to-msg-id command-key]] (fn [db [_ to-msg-id command-key]]
(commands/set-response-chat-command db to-msg-id command-key))) (-> db
(commands/set-response-chat-command to-msg-id command-key)
(update-response-suggestions-height))))
(defn update-text (defn update-text
[db [_ text]] [db [_ text]]

View File

@ -13,7 +13,7 @@
text2-color text2-color
text3-color]])) text3-color]]))
(def min-suggestions-height 150) (def max-suggestions-height 250)
(def header-height 50) (def header-height 50)
(def suggestion-height 56) (def suggestion-height 56)
@ -51,13 +51,10 @@
:fontFamily font :fontFamily font
:color text2-color}) :color text2-color})
(defn suggestions-container [suggestions] (def suggestions-container
{:flexDirection :row {:flexDirection :row
:flex 1
:marginVertical 1 :marginVertical 1
:marginHorizontal 0 :marginHorizontal 0
:height (min 150 (reduce + 0 (map #(if (:header %)
header-height
suggestion-height)
suggestions)))
:backgroundColor color-white :backgroundColor color-white
:borderRadius 5}) :borderRadius 5})

View File

@ -1,15 +1,12 @@
(ns status-im.chat.subs (ns status-im.chat.subs
(:require-macros [reagent.ratom :refer [reaction]]) (:require-macros [reagent.ratom :refer [reaction]])
(:require [re-frame.core :refer [register-sub]] (:require [re-frame.core :refer [register-sub dispatch]]
[status-im.db :as db] [status-im.db :as db]
;todo handlers in subs?... ;todo handlers in subs?...
[status-im.chat.suggestions :refer [status-im.chat.suggestions :refer
[get-suggestions typing-command?]] [get-suggestions typing-command?]]
[status-im.models.commands :as commands] [status-im.models.commands :as commands]
[status-im.components.animation :as anim]
[status-im.constants :refer [response-suggesstion-resize-duration]] [status-im.constants :refer [response-suggesstion-resize-duration]]
[status-im.chat.styles.response :as response-styles]
[status-im.chat.styles.response-suggestions :as response-suggestions-styles]
[status-im.handlers.content-suggestions :refer [get-content-suggestions]])) [status-im.handlers.content-suggestions :refer [get-content-suggestions]]))
(register-sub :chat-properties (register-sub :chat-properties
@ -95,25 +92,8 @@
(fn [db _] (fn [db _]
(reaction (typing-command? @db)))) (reaction (typing-command? @db))))
(defn update-response-suggestions-height [db]
(when-not (get-in db [:animations :response-input-is-hiding?])
(let [command (commands/get-chat-command db)
text (commands/get-chat-command-content db)
suggestions (get-content-suggestions db command text)
suggestions-height (min response-suggestions-styles/min-suggestions-height
(reduce + 0 (map #(if (:header %)
response-suggestions-styles/header-height
response-suggestions-styles/suggestion-height)
suggestions)))
height (+ suggestions-height response-styles/request-info-height)
anim-value (get-in db [:animations :response-suggestions-height])]
(anim/start (anim/timing anim-value {:toValue height, :duration response-suggesstion-resize-duration}))))
db)
(register-sub :get-content-suggestions (register-sub :get-content-suggestions
(fn [db _] (fn [db _]
(let [command (reaction (commands/get-chat-command @db)) (let [command (reaction (commands/get-chat-command @db))
text (reaction (commands/get-chat-command-content @db)) text (reaction (commands/get-chat-command-content @db))]
suggestions (reaction (get-content-suggestions @db @command @text))] (reaction (get-content-suggestions @command @text)))))
(reaction (do (update-response-suggestions-height @db)
@suggestions)))))

View File

@ -25,13 +25,13 @@
(defview content-suggestions-view [] (defview content-suggestions-view []
[suggestions [:get-content-suggestions]] [suggestions [:get-content-suggestions]]
(when (seq suggestions) (when-let [values (not-empty (filter :value suggestions))]
[view [view
[touchable-highlight {:style st/drag-down-touchable [touchable-highlight {:style st/drag-down-touchable
;; TODO hide suggestions? ;; TODO hide suggestions?
:onPress (fn [])} :onPress (fn [])}
[view [icon :drag_down st/drag-down-icon]]] [view [icon :drag_down st/drag-down-icon]]]
[view (st/suggestions-container (count suggestions)) [view (st/suggestions-container (count values))
[list-view {:dataSource (to-datasource (filter :value suggestions)) [list-view {:dataSource (to-datasource values)
:keyboardShouldPersistTaps true :keyboardShouldPersistTaps true
:renderRow render-row}]]])) :renderRow render-row}]]]))

View File

@ -32,7 +32,7 @@
(defview response-suggestions-view [] (defview response-suggestions-view []
[suggestions [:get-content-suggestions]] [suggestions [:get-content-suggestions]]
(when (seq suggestions) (when (seq suggestions)
[view (st/suggestions-container suggestions) [view st/suggestions-container
[list-view {:dataSource (to-datasource suggestions) [list-view {:dataSource (to-datasource suggestions)
:keyboardShouldPersistTaps true :keyboardShouldPersistTaps true
:renderRow render-row}]])) :renderRow render-row}]]))

View File

@ -14,7 +14,7 @@
{:value "9171111111" {:value "9171111111"
:description "Number format 3"}]}) :description "Number format 3"}]})
(defn get-content-suggestions [db command text] (defn get-content-suggestions [command text]
(or (when command (or (when command
(when-let [command-suggestions ((:command command) suggestions)] (when-let [command-suggestions ((:command command) suggestions)]
(filterv (fn [s] (filterv (fn [s]