Book Image

React and React Native

By : Adam Boduch
Book Image

React and React Native

By: Adam Boduch

Overview of this book

para 1: Dive into the world of React and create powerful applications with responsive and streamlined UIs! With React best practices for both Android and iOS, this book demonstrates React and React Native in action, helping you to create intuitive and engaging applications. Para 2: React and React Native allow you to build desktop, mobile and native applications for all major platforms. Combined with Flux and Relay, you?ll be able to create powerful and feature-complete applications from just one code base. Para 3: Discover how to build desktop and mobile applications using Facebook?s innovative UI libraries. You?ll also learn how to craft composable UIs using React, and then apply these concepts to building Native UIs using React Native. Finally, find out how you can create React applications which run on all major platforms, and leverage Relay for feature-complete and data-driven applications. Para 4: What?s Inside ? Craft composable UIs using React & build Native UIs using React Native ? Create React applications for major platforms ? Access APIs ? Leverage Relay for data-driven web & native mobile applications
Table of Contents (34 chapters)
React and React Native
Credits
About the Author
About the Reviewer
www.PacktPub.com
Customer Feedback
Dedication
Preface

Adding todo items


In the TodoApp component, we'll add a text input that allows the user to enter new todo items. When they're done entering the todo, Relay will need to send a mutation to the backend GraphQL server. Here's what the component code looks like:

import React, { Component, PropTypes } from 'react'; 
import { 
  View, 
  TextInput, 
} from 'react-native'; 
import Relay from 'react-relay'; 
 
import styles from './styles'; 
import AddTodoMutation from './mutations/AddTodoMutation'; 
import TodoList from './TodoList'; 
 
export class TodoRelayMobile extends Component { 
  static propTypes = { 
    viewer: PropTypes.any.isRequired, 
    relay: PropTypes.shape({ 
      commitUpdate: PropTypes.func.isRequired, 
    }), 
  } 
 
  // We need to keep track of new todo item text 
  // as the user enters them. 
  state = { 
    text: '', 
  } 
 
  // When the user...