From 0f8aec00f26f0d32b67bf941270a3183671cf3fe Mon Sep 17 00:00:00 2001 From: Brian Sztamfater Date: Tue, 28 Mar 2023 11:29:54 -0300 Subject: [PATCH] Add guidelines for defining styles with apply-animations-to-style Signed-off-by: Brian Sztamfater --- doc/new-guidelines.md | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/doc/new-guidelines.md b/doc/new-guidelines.md index 21998e2b58..90b44f6a83 100644 --- a/doc/new-guidelines.md +++ b/doc/new-guidelines.md @@ -90,6 +90,28 @@ their styles in the top-level of the properties map, prefer to add them inside t ] ``` +### Always apply animated styles in the style file + +When implementing styles for reanimated views, we should always define +them in the style file and apply animations with reanimated/apply-animations-to-style +in the style definition. + +```clojure +;; bad +(defn circle + [] + (let [opacity (reanimated/use-shared-value 1)] + [reanimated/view {:style (reanimated/apply-animations-to-style + {:opacity opacity} + style/circle-container)}])) + +;; good +(defn circle + [] + (let [opacity (reanimated/use-shared-value 1)] + [reanimated/view {:style (style/circle-container opacity)}])) +``` + ### Don't use percents to define width/height In ReactNative, all layouts use the [flexbox