/bs-react-native-navigation

📱 BuckleScript bindings for `react-native-navigation`

Primary LanguageOCamlMIT LicenseMIT

[@bs.module "react-native-navigation"]

BuckleScript bindings for react-native-navigation (from @Wix).

Getting started

(work in progress)

Usage example

(work in progress)

src/index.re

open BsReactNativeNavigation;

type screenId =
  | Drawer
  | Welcome;

let screenId = screenId =>
  (
    switch screenId {
    | Drawer => "screen.drawer"
    | Welcome => "screen.welcome"
    }
  )
  |> Core.asScreenId;

let registerScreens = () =>
  [
    (Welcome, Screens.Welcome.default),
    (Drawer, Screens.Drawer.default),
  ]
  |> List.iter(((screen, component)) =>
       Navigation.registerComponent(screenId(screen), () => component)
     );

let startApplication = () =>
  Navigation.(
    startSingleScreenApp(
      ~screen=
        Screen.make(
          ~screen=screenId(Welcome),
          ~title="Playground / TestApp",
          ()
        ),
      ~drawer=
        Drawer.(
          config(
            ~left=make(~screen=screenId(Drawer), ()),
            ~animationType=Animation.Parallax,
            ()
          )
        ),
      ~animationType=Animation.SlideDown,
      ()
    )
  );

index.js

import { registerScreens, startApplication } from './lib/js/src'

registerScreens()
startApplication()

Welcome.re (component)

open ReasonReact;

open BsReactNative;

open BsReactNativeNavigation;

let component = statelessComponent("Welcome");

let make = (~navigator, _children) => {
  ...component,
  render: _self =>
    /* whatever */
};

let default = Utils.nativeScreen(~component, ~make);

Utils.setNavigatorStyle(
  ~nativeScreen=default,
  ~navigatorStyle=
    Navigator.Style.(
      create([
        navBarTextColor("#fff"),
        navBarNoBorder(true),
        navBarBackgroundColor("#2575E6")
      ])
    )
);

Status

Check the current status here.

Disclaimer

This is work in progress, use with caution.

License

The MIT License.

See LICENSE