class: center, middle background-image: url(img/mire.jpg) .footnote.preintro[Connection to projector seems good, we can start] --- name: inverse layout: true class: inverse --- class: center, middle #What the Flux? .footnote[http://twidi.github.io/what-the-flux/] --- class: center # Presentation in 3 parts: .left[
##I. Theory
##II. Practice
##III. “Flux-react” ] .footnote[Part I and II are (very) highly inspired by a [blog post by Jonathan Creamer](http://jonathancreamer.com/what-the-flux/)] --- class: center, middle # I. Theory --- class: center, middle #“Flux”, a
concept
from Facebook .footnote[Boooh, bad guys. But they made React.] --- class: center, middle ## “Application
Architecture
for Building User Interfaces” .footnote[For React. Or not] --- class: center, middle ## Some excerpts... .footnote[Read them. No, I'm kidding ;)] --- class: justified, middle > “Flux applications have three major parts: the dispatcher, the stores, and the views (React components).” .footnote[Even my child could understand this one] --- class: justified, middle > “These should not be confused with Model-View-Controller. Controllers do exist in a Flux application, but they are controller-views — views often found at the top of the hierarchy that retrieve data from the stores and pass this data down to their children.” .footnote[Even mYk has to read it again] --- class: justified, middle > “Additionally, action creators — dispatcher helper methods — are used to support a semantic API that describes all changes that are possible in the application.” .footnote[Seriously, make an effort] --- class: justified, middle > “Flux eschews MVC in favor of a unidirectional data flow.” .footnote[Understood?] --- class: justified, middle > When a user interacts with a React view, the view propagates an action through a central dispatcher, to the various stores that hold the application's data and business logic, which updates all of the views that are affected. .footnote[Is everything clear?] --- class: center, middle data:image/s3,"s3://crabby-images/1c81b/1c81b21a5c1c64e58255fbbfafac90f885480826" alt="Default-aligned image" --- class: center, middle ## OK, maybe with a diagram .footnote[Hold on...] --- class: center, middle background-image: url(img/flux-diagram.png) --- class: center, middle data:image/s3,"s3://crabby-images/e89b3/e89b33f5156c140caece47a7d5ed71527647b6e8" alt="Default-aligned image" --- class: center, middle ## Let's rework a little .footnote[It's all about some stuff] --- class: center, middle background-image: url(img/flux-diagram-easy.jpg) --- class: center, middle background-image: url(img/flux-diagram.png) --- class: center, middle background-image: url(img/flux-diagram-easy.jpg) --- class: center, middle background-image: url(img/flux-diagram.png) --- class: center, middle # II. Practice
## Let's break this all down... .footnote[Oh yes daddy, show us some code!] --- class: center, middle # Think “EVENTS” .footnote[Or dispatcher, ... It's how everything happen] --- class: twocols-inverse layout: false .left-column[ ## View ] .right-column[.middle[.center.alone[ # Show some stuff ]]] --- .left-column[ ## View .detail[Show some stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/8bd25/8bd25566b9725172aa222ced9ecf9619a2587ef4" alt="Default-aligned image"]] ] --- .left-column[ ## View .detail[Show some stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/425ac/425ac6c384b3d8155c3dccd42e03d8f5a6a5d0ff" alt="Default-aligned image"]] ] --- .left-column[ ## View .detail[Show some stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/7a36f/7a36f68f59f94c8f7f682083732bbd015de32be1" alt="Default-aligned image"]] ] --- .left-column[ ## View .detail[Show some stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/0786d/0786d2498f00460094fb4dcdfa9b7f1235c5d98a" alt="Default-aligned image"]] ] --- class: twocols-inverse .left-column[ ## View ## Action Creators ] .right-column[.middle[.center.alone[ # Go get some more stuff ]]] --- .left-column[ ## View ## Action Creators .detail[Go get some more stuff] ] .right-column[.middle[ ### - What's the main purpose in life of an "action creator"? ### - *To create actions?* ### - Yes ### - *It was hard!* ### - I know ### - *...* ### - But note that "creating" an action, is actually doing it ### - *Kill me* ]] --- class: twocols-inverse .left-column[ ## View ## Action Creators ## Actions ] .right-column[.middle[.center.alone[ # Do something with stuff ]]] --- .left-column[ ## View ## Action Creators ## Actions .detail[Do something with stuff] ] .right-column[ ## Define allowed actions .img-code[data:image/s3,"s3://crabby-images/b2df2/b2df231d245d415bf3ea24aedd1aeb9576769403" alt="Default-aligned image"] ] --- .left-column[ ## View ## Action Creators ## Actions .detail[Do something with stuff] ] .right-column[ ## Define the actions .img-code[data:image/s3,"s3://crabby-images/ec1f2/ec1f2df28aab71d565c295a6f97558a88be780a1" alt="Default-aligned image"] ] --- .left-column[ ## View ## Action Creators ## Actions .detail[Do something with stuff] ] .right-column[ ## Define the actions .img-code[data:image/s3,"s3://crabby-images/4af22/4af2220aa4a2618a5f01099ae5ff2e5a13e320b0" alt="Default-aligned image"] ] --- .left-column[ ## View ## Action Creators ## Actions .detail[Do something with stuff] ] .right-column[ ## Define the actions .img-code[data:image/s3,"s3://crabby-images/0eb5f/0eb5f6a96efce73a8af54c1b8c4acd64c06caac4" alt="Default-aligned image"] ] --- .left-column[ ## View ## Action Creators ## Actions .detail[Do something with stuff] ] .right-column[ ## Define the actions .img-code[data:image/s3,"s3://crabby-images/64736/6473631aceccba658655ce590021ea23dddb1d39" alt="Default-aligned image"] ] --- .left-column[ ## View ## Action Creators ## Actions .detail[Do something with stuff] ] .right-column[ ## Actually do something .img-code[data:image/s3,"s3://crabby-images/bf787/bf7876b01f492e70eb130ee44bbe57e5fcfa4597" alt="Default-aligned image"] ] --- .left-column[ ## View ## Action Creators ## Actions .detail[Do something with stuff] ] .right-column[ ## Define the actions .img-code[data:image/s3,"s3://crabby-images/87ad7/87ad7d0839f2503320595d1e9bf829b0b95d322e" alt="Default-aligned image"] ] --- .left-column[ ## View ## Action Creators ## Actions .detail[Do something with stuff] ] .right-column[ ## Define the actions .img-code[data:image/s3,"s3://crabby-images/ab291/ab2914763a1ce60aa6586515d40de0be2d75563c" alt="Default-aligned image"] ] --- class: twocols-inverse .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ] .right-column[.middle[.center.alone[ # Hey Everyone! There's new stuff! ]]] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher .detail[Hey Everyone! There's new stuff!] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/3c735/3c735740498aeac4e9960a8ec6f6a1cd67bf3655" alt="Default-aligned image"]] ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher .detail[Hey Everyone! There's new stuff!] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/0feaa/0feaae6c0b47b1be485498bd3799e059cf86fcb1" alt="Default-aligned image"]] ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher .detail[Hey Everyone! There's new stuff!] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/695c8/695c863309fd4e2544fcc0723536e61db5036d1c" alt="Default-aligned image"]] ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher .detail[Hey Everyone! There's new stuff!] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/9e7b5/9e7b5193327f57fdfa10906f031d61181261d5f5" alt="Default-aligned image"]] ] --- class: twocols-inverse .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store ] .right-column[.middle[.center.alone[ # Keep track of stuff ]]] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store .detail[Keep track of stuff] ] .right-column[ ## Main points:
> “Stores hold application state and business logic”
> “Stores are also emitters” ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store .detail[Keep track of stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/832e7/832e70f028aacd1f58fcfc17a0ade61d1c07267a" alt="Default-aligned image"]] ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store .detail[Keep track of stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/ef8d8/ef8d85af482ecc1b357188f6e107a82008e14a29" alt="Default-aligned image"]] ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store .detail[Keep track of stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/18dd4/18dd40a6c8294211539cb470371cffc748fba39a" alt="Default-aligned image"]] ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store .detail[Keep track of stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/36850/36850a80123cbb1d3caff19318cfde4cd4b449a3" alt="Default-aligned image"]] ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store .detail[Keep track of stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/12571/125714571961d2b9930cd4573aa3f2342a5cba57" alt="Default-aligned image"]] ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store .detail[Keep track of stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/0ad84/0ad841bf21597825de994482396cecbc81c4137b" alt="Default-aligned image"]] ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store .detail[Keep track of stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/53c2c/53c2c4e01ecfe8886a5018ca4a31e6b80b7e84cf" alt="Default-aligned image"]] ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store .detail[Keep track of stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/8d33c/8d33c72d24c2f0ea2ad2e4621c65eb17d08165b6" alt="Default-aligned image"]] ] --- class: twocols-inverse .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store ## View, again .detail[It's a loop, remember] ] .right-column[.middle[.center.alone[ # Change events ]]] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store ## View .detail[Change events] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/f4756/f47568cd6e8faf720313dfc8322b5859d5e0065e" alt="Default-aligned image"]] ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store ## View .detail[Change events] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/6511a/6511ac423d02cd681428c560b19e0fd05a1cb840" alt="Default-aligned image"]] ] --- .left-column[ ## View ## Action Creators ## Actions ## Dispatcher ## Store ## View .detail[Change events] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/c4f44/c4f44d3203d5611d8d72af9c80a1f02bd8354b62" alt="Default-aligned image"]] ] --- class: inverse, center #Summary
.left[ View renders ↪ Click triggers action creator ↪ Go get data ↪ Create action for received data ↪ Send action to dispatcher ↪ Dispatcher publishes action ↪ Store listens for action ↪ Store updates state ↪ View updates ] --- class: center, middle background-image: url(img/please-simple.jpg) --- class: inverse, center, middle #III. Introducing “flux-react” .footnote[by [Christian Alfoni](https://github.com/christianalfoni/flux-react/)] --- class: inverse, center #Same concepts, but takes care of the dispatcher for you, so:
.left[
- less code
- less repetitions
- better view of the whole process ] --- class: inverse, center, middle # Same example .footnote[MOAR CODE!] --- class: twocols-inverse .left-column[ ## Actions ] .right-column[.middle[.center.alone[ # What stuff we can do ]]] --- .left-column[ ## Actions .detail[What stuff we can do] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/602bd/602bd9074cb118fef782217711b35f2fa862360c" alt="Default-aligned image"]] ] --- .left-column[ ## Actions .detail[What stuff we can do] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/ab902/ab902f153680ce49f4dba2fa5c30edd5cf43257d" alt="Default-aligned image"]] ] --- class: twocols-inverse .left-column[ ## Actions ## Store ] .right-column[.middle[.center.alone[ # Work on stuff ]]] --- .left-column[ ## Actions ## Store .detail[Work on stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/90df4/90df4ba09362ffb8ffa8da6b5980fe7c41973d82" alt="Default-aligned image"]] ] --- .left-column[ ## Actions ## Store .detail[Work on stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/e2f86/e2f86d057277633935de0ccbd9984a225d728446" alt="Default-aligned image"]] ] --- .left-column[ ## Actions ## Store .detail[Work on stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/1c979/1c9791b473db3fee1b82576216fbcc8e08014850" alt="Default-aligned image"]] ] --- .left-column[ ## Actions ## Store .detail[Work on stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/25c0f/25c0f0617788d8a9626669b32a1626df1ce1d00b" alt="Default-aligned image"]] ] --- .left-column[ ## Actions ## Store .detail[Work on stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/786f6/786f6930d9f3ed8241527698ac5792f68d9d5952" alt="Default-aligned image"]] ] --- .left-column[ ## Actions ## Store .detail[Work on stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/a07c9/a07c9aed16ad15626836eafdd9d68b98f3ade9f2" alt="Default-aligned image"]] ] --- class: twocols-inverse .left-column[ ## Actions ## Store ## View ] .right-column[.middle[.center.alone[ # Show some stuff ]]] --- .left-column[ ## Actions ## Store ## View .detail[Show some stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/4ddfa/4ddfa7df3e4f1b61e44fa3e7f95d445d6ec4e11d" alt="Default-aligned image"]] ] --- .left-column[ ## Actions ## Store ## View .detail[Show some stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/3ae22/3ae2207d427cdbf735825a1515e62acf951ae2c5" alt="Default-aligned image"]] ] --- .left-column[ ## Actions ## Store ## View .detail[Show some stuff] ] .right-column[ .middle[.img-code[data:image/s3,"s3://crabby-images/1ff18/1ff1874d0887d85368b3592b7a3848b4cc2a3dff" alt="Default-aligned image"]] ] --- class: inverse, center # I'm done
## How do you feel?
.pull-left[ Good... data:image/s3,"s3://crabby-images/7a380/7a380fca073d0e57be803270ea90545de666edee" alt="Default-aligned image" ] .pull-right[ Or still... data:image/s3,"s3://crabby-images/3f252/3f252d0ed2d91f2d46dfcec170b6067d414e7855" alt="Default-aligned image" ] --- class: inverse, center, middle # THANK YOU! .footnote[This presentation was proposed to you by [Stéphane "Twidi" Angel](http://twidi.com)] --- class: center, middle background-image: url(img/mire.jpg) .footnote.preintro[Signal lost...]