Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/flexsurfer/rn-shadow-steroid
React Native with shadow-cljs on steroids
https://github.com/flexsurfer/rn-shadow-steroid
re-frame react react-native reagent shadow-cljs
Last synced: 3 months ago
JSON representation
React Native with shadow-cljs on steroids
- Host: GitHub
- URL: https://github.com/flexsurfer/rn-shadow-steroid
- Owner: flexsurfer
- Created: 2020-02-22T15:00:06.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2022-08-10T19:35:43.000Z (over 2 years ago)
- Last Synced: 2024-10-23T14:03:01.260Z (3 months ago)
- Topics: re-frame, react, react-native, reagent, shadow-cljs
- Language: Clojure
- Size: 2.88 MB
- Stars: 69
- Watchers: 4
- Forks: 8
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# rn-shadow-steroid
A Clojure library with a few functions-steroids for react native app, **can be used only with shadow-cljs**
![IMG](screencast.gif)
[![Clojars](https://img.shields.io/clojars/v/rn-shadow-steroid.svg)](https://clojars.org/rn-shadow-steroid)
## Usage
```clojure
{:dependencies [[rn-shadow-steroid "0.2.8"]]}
```Register root reagent component in app registry
```clojure
(:require [steroid.rn.core :as rn])(defn root-comp []
[rn/view
[rn/text "HELLO WORLD"]])(defn init []
(rn/register-comp "app-name" root-comp))
```Register root component with **HOT RELOAD**
```clojure
(:require [steroid.rn.core :as rn])(defn root-comp []
[rn/view
[rn/text "HELLO WORLD"]])(defn init []
(rn/register-reload-comp "app-name" root-comp))
```shadow-cljs.edn
```clojure
{:source-paths ["src"]:dependencies [[rn-shadow-steroid "0.2.6"]]
:builds {:dev
{:target :react-native
:init-fn app.core/init
:output-dir "app"
:devtools {:after-load steroid.rn.core/reload
:build-notify steroid.rn.core/build-notify}}}}
```Now each time you change your code it will be hot reloaded keeping an app state. **NOTE react native fast refresh should be turned off**
### React Native components
#### Basic components
```clojure
[steroid.rn.core :as rn]
rn/app-registry rn/view rn/text rn/image rn/text-input rn/scroll-view
rn/touchable-highlight rn/touchable-native-feedback rn/touchable-opacity rn/touchable-without-feedback
```#### UI components
```clojure
[steroid.rn.components.ui :as ui]
ui/button ui/switch
```#### List components
```clojure
[steroid.rn.components.list :as list]
list/flat-list list/section-list
```#### Platform
```clojure
[steroid.rn.components.platform :as platform]
platform/platform platform/os platform/version platform/android? platform/ios?
```#### Other components
```clojure
[steroid.rn.components.other :as other]
other/activity-indicator other/alert other/dimensions other/keyboard-avoiding-view other/modal other/refresh-control
```#### StatusBar components
```clojure
[steroid.rn.components.status-bar :as status-bar]
(status-bar/set-bar-style bar-style)
(status-bar/set-background-color background-color)
(status-bar/set-hidden hidden)
(status-bar/set-network-activity-indicator-visible network-activity-indicator-visible)
(status-bar/set-translucent translucent)
```#### Picker component
````bash
yarn add @react-native-picker/picker
```````clojure
[steroid.rn.components.picker :as picker]
picker/picker picker/item
```#### DateTimePicker component
````bash
yarn add @react-native-community/datetimepicker
```````clojure
[steroid.rn.components.datetimepicker :as datetimepicker]
datetimepicker/date-time-picker
```#### Async storage component
````bash
yarn add @react-native-async-storage/async-storage
```````clojure
[steroid.rn.components.async-storage :as async-storage]
(async-storage/set-item "key" {:my-value "value"})
(async-storage/get-item "key" #(println "value" %))
(async-storage/remove-item "key")
(async-storage/get-all-keys #(println "keys" %))
(async-storage/clear)
```
#### EXAMPLE```clojure
(:require [steroid.rn.core :as rn]
[steroid.rn.components.list :as list])(defn item-render [{:keys [title image-url description]}]
[rn/touchable-opacity {:on-press #(do "smth")}
[rn/view {:style {:padding 5 :flex-direction :row :align-items :center}}
[rn/image {:style {:width 50 :height 50 :margin 5 :border-radius 25 :margin-right 10}
:source {:uri image-url}}]
[rn/view {:style {:flex 1}}
[rn/text {:style {:font-size 18 :font-family "Inter" :flex-shrink 1}} title]
[rn/text {:style {:font-family "Inter" :flex-shrink 1 :color :gray :margin-top 5}
:number-of-lines 2}
description]]]])(defn myapp []
[rn/view {:style {:flex 1 :background-color :white}}
[rn/text {:style {:font-size 22 :align-self :center :margin 10 :font-family "Inter"}}
"MyApp"]
[list/flat-list {:data data-vector :render-fn item-render}]])
```
### React Navigation with HOT RELOAD#### Navigation container component
````bash
yarn add @react-navigation/native
```````clojure
[steroid.rn.navigation.core :as rnn]
rnn/navigation-container
rnn/create-navigation-container-reload
```#### Stack components
````bash
yarn add @react-navigation/stack
```````clojure
[steroid.rn.navigation.stack :as stack]
stack/stack
```#### Bottom tabs components
````bash
yarn add @react-navigation/bottom-tabs
```````clojure
[steroid.rn.navigation.bottom-tabs :as bottom-tabs]
bottom-tabs/bottom-tab
```#### Safe area components
````bash
yarn add react-native-safe-area-context
```````clojure
[steroid.rn.navigation.safe-area :as safe-area]
safe-area/safe-area-provider safe-area/safe-area-consumer safe-area/safe-area-view
```#### EXAMPLE
````bash
`yarn add @react-navigation/native @react-navigation/stack @react-navigation/bottom-tab react-native-reanimated react-native-gesture-handler react-native-screens react-native-safe-area-context @react-native-masked-view/masked-view``cd ios; pod install; cd ..`
```````clojure
(:require [steroid.rn.core :as rn]
[re-frame.core :as re-frame]
[steroid.rn.navigation.core :as rnn]
[steroid.rn.navigation.stack :as stack]
[steroid.rn.navigation.bottom-tabs :as bottom-tabs]
[clojurernproject.views :as screens]
[steroid.rn.navigation.safe-area :as safe-area]
steroid.rn.navigation.events))(defn main-screens []
[bottom-tabs/bottom-tab
[{:name :home
:component screens/home-screen}
{:name :basic
:component screens/basic-screen}]])(defn root-stack []
[safe-area/safe-area-provider
[(rnn/create-navigation-container-reload
{:on-ready #(re-frame/dispatch [:init-app-db])}
[stack/stack {:mode :modal :header-mode :none}
[{:name :main
:component main-screens}
{:name :modal
:component screens/modal-screen}]])]])(defn init []
(rn/register-comp "ClojureRNProject" root-stack))
```Notice that we register root-stack without hot reload but create navigation-container-reload.
#### re-frame navigation events `steroid.rn.navigation.events`
After `steroid.rn.navigation.events` has been required once, re-frame events are registered and you can use them for navigation
`(re-frame/dispatch [:navigate-to :modal])`
`(re-frame/dispatch [:navigate-to :basic])`
`(re-frame/dispatch [:navigate-back])`
ENJOY!