# Part 08
miroslav.binas@tuke.sk / [**SMART**](https://kurzy.kpi.fei.tuke.sk/smart)
## Example: Torch App
Turn On
## Project Structure
## What is Component?
> Component is small isolated, independent and reusable part for componsing the UI. ([React Native](https://reactjs.org/docs/components-and-props.html))
## Share Data Between the Components
## Existing Relationships
1. parent to child component
2. child to parent component
3. between siblings
4. sharing data between not related components
## Parent to Child
data:image/s3,"s3://crabby-images/be108/be108d11b9e490a1b140948171a0dccabe31145c" alt="Parent to Child"
## Properties
## Properties are Read-Only!
they are immutable!
## Pure Function
**All React components must act like pure functions with respect to their props.**
## Child to Parent
data:image/s3,"s3://crabby-images/d9d89/d9d895c88376bd291d0598afb0f4f273e464f973" alt="Child to Parent"
## Between Siblings
data:image/s3,"s3://crabby-images/e223b/e223b42b557063300cb05a8fcb463f1a0b53fbda" alt="Sibling to Sibling"
## ### Sharing data between not related components
data:image/s3,"s3://crabby-images/7cecd/7cecd6ee982a103cc20a7b5cd0a2a1acc50e0307" alt="Any to Any"
data:image/s3,"s3://crabby-images/3a4fa/3a4fa85f33fc042cc54e8ae4c639cfafa5220ab7" alt="The Problem"
## Existing Approaches
* Global Variables
* Context
* Observer Pattern
data:image/s3,"s3://crabby-images/081cd/081cd37ec879dd3daf502336156ccdae55cbff12" alt="Redux"
## Questions?