commit bd2841ca90b675695feba5cb33c5835e8d1c1fc9 Author: Kamran Ahmed Date: Thu Dec 2 16:45:03 2021 +0000 Updates diff --git a/.nojekyll b/.nojekyll new file mode 100644 index 000000000..e69de29bb diff --git a/404.html b/404.html new file mode 100644 index 000000000..208bc30fd --- /dev/null +++ b/404.html @@ -0,0 +1 @@ +404: This page could not be found
We now have a YouTube Channel. Subscribe for the video content.

404

This page could not be found.

\ No newline at end of file diff --git a/CNAME b/CNAME new file mode 100644 index 000000000..8515fa9c8 --- /dev/null +++ b/CNAME @@ -0,0 +1 @@ +roadmap.sh diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/android.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/android.json new file mode 100644 index 000000000..0174c0720 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/android.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Android Developer Roadmap: Learn to become an Android developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for android development. Learn to become a modern Android developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an android developer","android developer roadmap","android roadmap","become android developer","android developer skills","android skills test","skills for android development","learn android development","what is android","android quiz","android interview questions"]},"title":"Android Developer","description":"Step by step guide to becoming an Android developer in 2021","featuredTitle":"Android","featuredDescription":"Step by step guide to becoming an Android Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/105-android/landscape.md","resourcesPath":"/roadmaps/105-android/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"android","metaPath":"/roadmaps/105-android/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/android/interactive.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/android/interactive.json new file mode 100644 index 000000000..1837882a2 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/android/interactive.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Android Developer Roadmap: Learn to become an Android developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for android development. Learn to become a modern Android developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an android developer","android developer roadmap","android roadmap","become android developer","android developer skills","android skills test","skills for android development","learn android development","what is android","android quiz","android interview questions"]},"title":"Android Developer","description":"Step by step guide to becoming an Android developer in 2021","featuredTitle":"Android","featuredDescription":"Step by step guide to becoming an Android Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/105-android/landscape.md","resourcesPath":"/roadmaps/105-android/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"android","metaPath":"/roadmaps/105-android/meta.json","isUpcoming":false},"json":{"mockup":{"controls":{"control":[{"ID":"0","h":"88","measuredH":"87","measuredW":"139","properties":{"color":"10027263","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":139,"y":87},"p1":{"x":0.4839132782964279,"y":0.06388395957102075},"p2":{"x":0,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"140","x":"764","y":"409","zOrder":"42"},{"ID":"1","h":"54","measuredH":"53","measuredW":"167","properties":{"color":"10027263","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":167,"y":53},"p1":{"x":0.46628444849827344,"y":0.04019805850544009},"p2":{"x":0,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"168","x":"745","y":"398","zOrder":"43"},{"ID":"2","h":"46","measuredH":"45","measuredW":"142","properties":{"color":"10027263","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"x":142,"y":0},"p1":{"x":0.5393433342768186,"y":-0.060147183696575034},"p2":{"x":0,"y":45},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"143","x":"760","y":"353","zOrder":"44"},{"ID":"5","h":"177","measuredH":"176","measuredW":"28","properties":{"color":"10027263","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":20,"y":0},"p1":{"x":0.553261492147643,"y":0.10567048073208744},"p2":{"x":0,"y":176},"rightArrow":"false","shape":"bezier","size":"10"},"typeID":"Arrow","w":"29","x":"672","y":"404","zOrder":"45"},{"ID":"6","h":"99","measuredH":"98","measuredW":"28","properties":{"color":"10027263","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":12,"y":0},"p1":{"x":0.5196669310071372,"y":-0.19421094369547975},"p2":{"x":28,"y":98},"rightArrow":"false","shape":"bezier"},"typeID":"Arrow","w":"29","x":"646","y":"251","zOrder":"46"},{"ID":"7","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"292","x":"887","y":"280","zOrder":"47"},{"ID":"8","measuredH":"23","measuredW":"154","properties":{"bold":"true","size":"15","text":"Install Android Studio"},"typeID":"Label","x":"956","y":"290","zOrder":"48"},{"ID":"9","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"292","x":"887","y":"328","zOrder":"49"},{"ID":"10","measuredH":"23","measuredW":"187","properties":{"bold":"true","size":"15","text":"Learn the Basics of Kotlin"},"typeID":"Label","x":"940","y":"338","zOrder":"50"},{"ID":"11","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"203","x":"568","y":"376","zOrder":"51"},{"ID":"12","measuredH":"23","measuredW":"133","properties":{"bold":"true","size":"15","text":"The Fundamentals"},"typeID":"Label","x":"603","y":"388","zOrder":"52"},{"ID":"17","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"292","x":"887","y":"377","zOrder":"53"},{"ID":"18","measuredH":"23","measuredW":"106","properties":{"bold":"true","size":"15","text":"Basics of OOP"},"typeID":"Label","x":"980","y":"387","zOrder":"54"},{"ID":"21","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"292","x":"887","y":"425","zOrder":"55"},{"ID":"22","measuredH":"23","measuredW":"222","properties":{"bold":"true","size":"15","text":"DataStructures and Algorithms"},"typeID":"Label","x":"922","y":"435","zOrder":"56"},{"ID":"25","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"292","x":"887","y":"474","zOrder":"57"},{"ID":"26","measuredH":"23","measuredW":"226","properties":{"bold":"true","size":"15","text":"What is and how to use Gradle?"},"typeID":"Label","x":"920","y":"484","zOrder":"58"},{"ID":"29","h":"26","measuredH":"25","measuredW":"130","properties":{"color":"10027263","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":130,"y":0},"p1":{"x":0.45592011412268185,"y":0.050784593437945794},"p2":{"x":0,"y":25},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"131","x":"456","y":"349","zOrder":"59"},{"ID":"30","h":"17","measuredH":"16","measuredW":"128","properties":{"color":"10027263","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":128,"y":16},"p1":{"x":0.5393433342768185,"y":-0.0601471836965751},"p2":{"x":0,"y":4},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"129","x":"458","y":"327","zOrder":"60"},{"ID":"33","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"178","x":"302","y":"304","zOrder":"61"},{"ID":"34","measuredH":"23","measuredW":"41","properties":{"bold":"true","size":"15","text":"Kotlin"},"typeID":"Label","x":"371","y":"314","zOrder":"62"},{"ID":"35","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"13421772"},"typeID":"Canvas","w":"178","x":"302","y":"352","zOrder":"63"},{"ID":"36","measuredH":"23","measuredW":"32","properties":{"bold":"true","size":"15","text":"Java"},"typeID":"Label","x":"375","y":"362","zOrder":"64"},{"ID":"40","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"203","x":"569","y":"324","zOrder":"65"},{"ID":"41","measuredH":"23","measuredW":"117","properties":{"bold":"true","size":"15","text":"Pick a Language"},"typeID":"Label","x":"612","y":"336","zOrder":"66"},{"ID":"45","h":"6","measuredH":"5","measuredW":"170","properties":{"color":"10027263","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":170,"y":0},"p1":{"x":0.4766942707453101,"y":0.008585431806658779},"p2":{"x":0,"y":5},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"171","x":"757","y":"397","zOrder":"40"},{"ID":"46","h":"97","measuredH":"96","measuredW":"146","properties":{"color":"10027263","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"x":146,"y":0},"p1":{"x":0.5393433342768187,"y":-0.06014718369657506},"p2":{"x":0,"y":96},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"147","x":"764","y":"297","zOrder":"41"},{"ID":"47","h":"93","measuredH":"92","measuredW":"141","properties":{"color":"10027263","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"length":141,"x":141,"y":0},"p1":{"length":0.5426867567349194,"x":0.5393433342768186,"y":-0.06014718369657501},"p2":{"length":92,"x":0,"y":92},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"142","x":"770","y":"700","zOrder":"67"},{"ID":"48","h":"4","measuredH":"3","measuredW":"156","properties":{"color":"10027263","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"length":156,"x":156,"y":0},"p1":{"length":0.4915147996747852,"x":0.49149672119334153,"y":-0.004215608560928125},"p2":{"length":3,"x":0,"y":3},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"157","x":"764","y":"799","zOrder":"68"},{"ID":"49","h":"55","measuredH":"54","measuredW":"144","properties":{"color":"10027263","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"length":144,"x":144,"y":0},"p1":{"length":0.5426867567349194,"x":0.5393433342768186,"y":-0.060147183696575034},"p2":{"length":54,"x":0,"y":54},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"145","x":"767","y":"749","zOrder":"69"},{"ID":"50","h":"3","measuredH":"2","measuredW":"115","properties":{"color":"10027263","curvature":"0","direction":"top","leftArrow":"false","p0":{"length":115.0173899895142,"x":115,"y":2},"p1":{"length":0.48703415530227634,"x":0.4869565217391304,"y":-0.008695652173913042},"p2":{"length":1,"x":0,"y":1},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"116","x":"476","y":"797","zOrder":"70"},{"ID":"51","h":"42","measuredH":"41","measuredW":"128","properties":{"color":"10027263","curvature":"-1","direction":"top","leftArrow":"false","p0":{"length":134.40610105199838,"x":128,"y":41},"p1":{"length":0.5426867567349194,"x":0.5393433342768186,"y":-0.06014718369657536},"p2":{"length":0,"x":0,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"129","x":"471","y":"753","zOrder":"71"},{"ID":"53","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"343","x":"161","y":"680","zOrder":"72"},{"ID":"54","measuredH":"23","measuredW":"279","properties":{"bold":"true","size":"15","text":"Using Activities and Activity Lifecycles"},"typeID":"Label","x":"192","y":"690","zOrder":"73"},{"ID":"55","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"343","x":"161","y":"728","zOrder":"74"},{"ID":"56","measuredH":"23","measuredW":"317","properties":{"bold":"true","size":"15","text":"Building Flexible Interfaces using Fragments"},"typeID":"Label","x":"173","y":"738","zOrder":"75"},{"ID":"57","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"203","x":"577","y":"774","zOrder":"76"},{"ID":"58","measuredH":"23","measuredW":"141","properties":{"bold":"true","size":"15","text":"Build an Application"},"typeID":"Label","x":"608","y":"786","zOrder":"77"},{"ID":"59","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"236","x":"896","y":"731","zOrder":"78"},{"ID":"60","measuredH":"23","measuredW":"96","properties":{"bold":"true","size":"15","text":"Using Intents"},"typeID":"Label","x":"966","y":"741","zOrder":"79"},{"ID":"61","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"236","x":"896","y":"778","zOrder":"80"},{"ID":"62","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"343","x":"161","y":"775","zOrder":"81"},{"ID":"63","measuredH":"23","measuredW":"297","properties":{"bold":"true","size":"15","text":"Debugging using Android Studio Debugger"},"typeID":"Label","x":"183","y":"785","zOrder":"82"},{"ID":"64","measuredH":"23","measuredW":"145","properties":{"bold":"true","size":"15","text":"Understand Context"},"typeID":"Label","x":"942","y":"788","zOrder":"83"},{"ID":"65","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"236","x":"896","y":"684","zOrder":"84"},{"ID":"66","measuredH":"23","measuredW":"201","properties":{"bold":"true","size":"15","text":"Handling App Configurations"},"typeID":"Label","x":"914","y":"694","zOrder":"85"},{"ID":"67","h":"48","measuredH":"47","measuredW":"97","properties":{"color":"10027263","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"length":97,"x":97,"y":0},"p1":{"length":0.4944237486591682,"x":0.4917173607861488,"y":0.0516612072999532},"p2":{"length":47,"x":0,"y":47},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"98","x":"501","y":"1019","zOrder":"15"},{"ID":"68","h":"44","measuredH":"43","measuredW":"2","properties":{"color":"10027263","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":2,"y":43},"p1":{"x":0.4750000000000001,"y":0.012500000000000008},"p2":{"x":1,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"3","x":"1032","y":"1035","zOrder":"20"},{"ID":"69","h":"5","measuredH":"4","measuredW":"104","properties":{"color":"10027263","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"length":104,"x":104,"y":0},"p1":{"length":0.43658008061825626,"x":0.4365079365079367,"y":0.007936507936507943},"p2":{"length":4,"x":0,"y":4},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"105","x":"499","y":"1015","zOrder":"12"},{"ID":"70","h":"3","measuredH":"2","measuredW":"163","properties":{"color":"10027263","curvature":"0","direction":"top","leftArrow":"false","p0":{"length":163.01226947687098,"x":163,"y":2},"p1":{"length":0.4969610318915033,"x":0.49695144900263466,"y":-0.003086187429431695},"p2":{"length":1,"x":0,"y":1},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"164","x":"771","y":"1021","zOrder":"21"},{"ID":"71","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"236","x":"915","y":"1005","zOrder":"22"},{"ID":"72","measuredH":"23","measuredW":"148","properties":{"bold":"true","size":"15","text":"Learn Multithreading"},"typeID":"Label","x":"959","y":"1015","zOrder":"23"},{"ID":"73","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"304","x":"846","y":"937","zOrder":"24"},{"ID":"74","measuredH":"23","measuredW":"180","properties":{"bold":"true","size":"15","text":"Why would we need that?"},"typeID":"Label","x":"908","y":"947","zOrder":"25"},{"ID":"75","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"304","x":"847","y":"1169","zOrder":"26"},{"ID":"76","measuredH":"23","measuredW":"264","properties":{"bold":"true","size":"15","text":"How android uses threads internally?"},"typeID":"Label","x":"867","y":"1179","zOrder":"27"},{"ID":"77","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"304","x":"847","y":"1121","zOrder":"28"},{"ID":"78","measuredH":"23","measuredW":"130","properties":{"bold":"true","size":"15","text":"Memory Concerns"},"typeID":"Label","x":"934","y":"1131","zOrder":"29"},{"ID":"79","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"304","x":"847","y":"1073","zOrder":"30"},{"ID":"80","measuredH":"23","measuredW":"208","properties":{"bold":"true","size":"15","text":"How to write threaded code?"},"typeID":"Label","x":"895","y":"1083","zOrder":"31"},{"ID":"81","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"187","x":"327","y":"1046","zOrder":"32"},{"ID":"82","measuredH":"23","measuredW":"53","properties":{"bold":"true","size":"15","text":"Testing"},"typeID":"Label","x":"394","y":"1056","zOrder":"33"},{"ID":"83","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"187","x":"327","y":"998","zOrder":"34"},{"ID":"84","measuredH":"23","measuredW":"61","properties":{"bold":"true","size":"15","text":"Security"},"typeID":"Label","x":"390","y":"1008","zOrder":"35"},{"ID":"85","h":"41","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"90","x":"167","y":"998","zOrder":"36"},{"ID":"86","measuredH":"23","measuredW":"39","properties":{"bold":"true","size":"15","text":"JUnit"},"typeID":"Label","w":"41","x":"192","y":"1007","zOrder":"37"},{"ID":"87","h":"43","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"91","x":"167","y":"1046","zOrder":"38"},{"ID":"88","measuredH":"23","measuredW":"66","properties":{"bold":"true","size":"15","text":"Espresso"},"typeID":"Label","x":"180","y":"1056","zOrder":"39"},{"ID":"90","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"342","x":"161","y":"825","zOrder":"86"},{"ID":"91","measuredH":"23","measuredW":"208","properties":{"bold":"true","size":"15","text":"Components and their Usage"},"typeID":"Label","x":"228","y":"837","zOrder":"87"},{"ID":"92","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"145","x":"359","y":"927","zOrder":"88"},{"ID":"93","measuredH":"23","measuredW":"75","properties":{"bold":"true","size":"15","text":"Navigation"},"typeID":"Label","x":"394","y":"939","zOrder":"89"},{"ID":"94","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"90","x":"161","y":"876","zOrder":"90"},{"ID":"95","measuredH":"23","measuredW":"41","properties":{"bold":"true","size":"15","text":"Room"},"typeID":"Label","x":"186","y":"888","zOrder":"91"},{"ID":"96","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"190","x":"161","y":"927","zOrder":"92"},{"ID":"97","measuredH":"23","measuredW":"103","properties":{"bold":"true","size":"15","text":"Work Manager"},"typeID":"Label","x":"205","y":"939","zOrder":"93"},{"ID":"98","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"112","x":"259","y":"876","zOrder":"94"},{"ID":"99","measuredH":"23","measuredW":"67","properties":{"bold":"true","size":"15","text":"Live Data"},"typeID":"Label","w":"71","x":"280","y":"888","zOrder":"95"},{"ID":"100","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"127","x":"377","y":"876","zOrder":"96"},{"ID":"101","measuredH":"23","measuredW":"91","properties":{"bold":"true","size":"15","text":"Data Binding"},"typeID":"Label","x":"395","y":"888","zOrder":"97"},{"ID":"102","h":"43","measuredH":"42","measuredW":"101","properties":{"color":"10027263","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"length":101,"x":101,"y":0},"p1":{"length":0.4870341553022764,"x":0.48695652173913045,"y":-0.008695652173913057},"p2":{"length":42,"x":0,"y":42},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"102","x":"492","y":"805","zOrder":"19"},{"ID":"103","h":"83","measuredH":"82","measuredW":"109","properties":{"color":"10027263","curvature":"-1","direction":"top","leftArrow":"false","p0":{"length":136.40014662748715,"x":109,"y":82},"p1":{"length":0.5426867567349194,"x":0.5393433342768186,"y":-0.06014718369657522},"p2":{"length":0,"x":0,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"110","x":"481","y":"699","zOrder":"18"},{"ID":"106","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"203","x":"587","y":"999","zOrder":"98"},{"ID":"107","measuredH":"23","measuredW":"147","properties":{"bold":"true","size":"15","text":"Writing Robust Apps"},"typeID":"Label","w":"151","x":"613","y":"1011","zOrder":"99"},{"ID":"108","h":"214","measuredH":"213","measuredW":"37","properties":{"color":"10027263","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5220159151193634,"y":0.12042440318302387},"p2":{"x":21,"y":213},"rightArrow":"false","shape":"bezier","size":"10"},"typeID":"Arrow","w":"38","x":"686","y":"805","zOrder":"17"},{"ID":"109","h":"81","measuredH":"80","measuredW":"1","properties":{"color":"10027263","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":1,"y":80},"p1":{"x":0.4750000000000001,"y":0.012500000000000008},"p2":{"x":1,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"2","x":"1033","y":"943","zOrder":"14"},{"ID":"110","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"229","x":"288","y":"1096","zOrder":"100"},{"ID":"111","measuredH":"23","measuredW":"185","properties":{"bold":"true","size":"15","text":"Dependency Management"},"typeID":"Label","x":"313","y":"1106","zOrder":"101"},{"ID":"113","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"236","x":"896","y":"636","zOrder":"102"},{"ID":"114","measuredH":"23","measuredW":"130","properties":{"bold":"true","size":"15","text":"Content Providers"},"typeID":"Label","x":"949","y":"646","zOrder":"103"},{"ID":"116","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"235","x":"897","y":"827","zOrder":"104"},{"ID":"117","measuredH":"23","measuredW":"134","properties":{"bold":"true","size":"15","text":"3rd Party Libraries"},"typeID":"Label","x":"948","y":"837","zOrder":"105"},{"ID":"118","measuredH":"23","measuredW":"266","properties":{"bold":"true","size":"15","text":"e.g. Glide, Retrofit, Crashlytics, GSON"},"typeID":"Label","x":"867","y":"877","zOrder":"106"},{"ID":"119","h":"89","measuredH":"88","measuredW":"87","properties":{"color":"10027263","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"length":87,"x":87,"y":0},"p1":{"length":0.47891314261057566,"x":0.4788990825688073,"y":-0.003669724770642195},"p2":{"length":88,"x":0,"y":88},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"88","x":"512","y":"1030","zOrder":"16"},{"ID":"121","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"226","x":"290","y":"1148","zOrder":"107"},{"ID":"122","measuredH":"23","measuredW":"91","properties":{"bold":"true","size":"15","text":"Concurrency"},"typeID":"Label","x":"376","y":"1158","zOrder":"108"},{"ID":"125","h":"130","measuredH":"129","measuredW":"96","properties":{"color":"10027263","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"length":96,"x":96,"y":0},"p1":{"length":0.47891314261057577,"x":0.4788990825688074,"y":-0.003669724770641983},"p2":{"length":129,"x":0,"y":129},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"97","x":"506","y":"1040","zOrder":"13"},{"ID":"155","h":"44","measuredH":"43","measuredW":"88","properties":{"color":"10027263","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":88,"y":43},"p1":{"x":0.6296257687897425,"y":-0.055978317523193995},"p2":{"x":0,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"89","x":"415","y":"590","zOrder":"11"},{"ID":"156","h":"45","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"186","x":"227","y":"512","zOrder":"109"},{"ID":"157","measuredH":"25","measuredW":"57","properties":{"bold":"true","size":"17","text":"GitHub"},"typeID":"Label","w":"64","x":"288","y":"522","zOrder":"110"},{"ID":"158","h":"45","measuredH":"140","measuredW":"200","properties":{"backgroundAlpha":"0.5","borderColor":"0","color":"10066329"},"typeID":"TextArea","w":"186","x":"228","y":"561","zOrder":"111"},{"ID":"159","measuredH":"25","measuredW":"55","properties":{"bold":"true","color":"0","size":"17","text":"GitLab"},"typeID":"Label","x":"294","y":"571","zOrder":"112"},{"ID":"160","h":"23","measuredH":"22","measuredW":"156","properties":{"color":"10027263","curvature":"1","direction":"top","leftArrow":"false","p0":{"length":157.54364474646383,"x":156,"y":22},"p1":{"length":0.5092219658218046,"x":0.5081385979049154,"y":0.03319903303787269},"p2":{"length":0,"x":0,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"157","x":"733","y":"576","zOrder":"113"},{"ID":"161","h":"25","measuredH":"24","measuredW":"151","properties":{"color":"10027263","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"length":151,"x":151,"y":0},"p1":{"length":0.5453706051628192,"x":0.5443384523249346,"y":-0.03353723745561875},"p2":{"length":24,"x":0,"y":24},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"152","x":"744","y":"550","zOrder":"114"},{"ID":"162","h":"54","measuredH":"53","measuredW":"1","properties":{"color":"10027263","curvature":"0","direction":"top","leftArrow":"false","p0":{"length":53.009433122794285,"x":1,"y":53},"p1":{"length":0.5446701443933412,"x":0.5446682073291514,"y":0.001452624628590294},"p2":{"length":1,"x":1,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"2","x":"534","y":"504","zOrder":"115"},{"ID":"163","h":"149","measuredH":"148","measuredW":"30","properties":{"color":"10027263","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":21,"y":0},"p1":{"x":0.5694444444444444,"y":-0.1736111111111111},"p2":{"x":30,"y":148},"rightArrow":"false","shape":"bezier","size":"10"},"typeID":"Arrow","w":"31","x":"639","y":"636","zOrder":"8"},{"ID":"165","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"276","x":"484","y":"554","zOrder":"116"},{"ID":"166","measuredH":"23","measuredW":"176","properties":{"bold":"true","size":"15","text":"Version Control Systems"},"typeID":"Label","x":"535","y":"566","zOrder":"117"},{"ID":"167","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"304","x":"875","y":"528","zOrder":"118"},{"ID":"168","measuredH":"23","measuredW":"254","properties":{"bold":"true","size":"15","text":"What are Version Control Systems?"},"typeID":"Label","x":"900","y":"538","zOrder":"119"},{"ID":"169","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"304","x":"875","y":"576","zOrder":"120"},{"ID":"170","measuredH":"23","measuredW":"178","properties":{"bold":"true","size":"15","text":"Why you should use one?"},"typeID":"Label","x":"938","y":"586","zOrder":"121"},{"ID":"171","h":"42","measuredH":"70","measuredW":"100","properties":{"color":"16776960"},"typeID":"Canvas","w":"156","x":"484","y":"471","zOrder":"122"},{"ID":"172","measuredH":"23","measuredW":"117","properties":{"bold":"true","size":"15","text":"Learn to use Git"},"typeID":"Label","x":"504","y":"481","zOrder":"123"},{"ID":"173","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"275","x":"485","y":"610","zOrder":"124"},{"ID":"174","measuredH":"23","measuredW":"163","properties":{"bold":"true","size":"15","text":"Repo Hosting Services"},"typeID":"Label","x":"541","y":"622","zOrder":"125"},{"ID":"175","h":"45","measuredH":"140","measuredW":"200","properties":{"backgroundAlpha":"0.5","borderColor":"0","color":"10066329"},"typeID":"TextArea","w":"184","x":"229","y":"610","zOrder":"126"},{"ID":"176","measuredH":"25","measuredW":"78","properties":{"bold":"true","color":"0","size":"17","text":"Bitbucket"},"typeID":"Label","x":"282","y":"620","zOrder":"127"},{"ID":"180","h":"5","measuredH":"4","measuredW":"87","properties":{"color":"10027263","curvature":"0","direction":"top","leftArrow":"false","p0":{"x":87,"y":4},"p1":{"x":0.44838497033618985,"y":-0.0023731048121292024},"p2":{"x":0,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"88","x":"411","y":"634","zOrder":"9"},{"ID":"181","h":"92","measuredH":"91","measuredW":"82","properties":{"color":"10027263","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":82,"y":91},"p1":{"x":0.6164611796067977,"y":-0.07197600799733421},"p2":{"x":0,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"83","x":"411","y":"534","zOrder":"10"},{"ID":"182","h":"43","measuredH":"42","measuredW":"139","properties":{"color":"10027263","curvature":"0","direction":"top","leftArrow":"false","p0":{"x":139,"y":42},"p1":{"x":0.49149672119334153,"y":-0.004215608560928125},"p2":{"x":0,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"140","x":"771","y":"808","zOrder":"7"},{"ID":"183","h":"130","measuredH":"129","measuredW":"136","properties":{"color":"10027263","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"x":136,"y":0},"p1":{"x":0.5393433342768186,"y":-0.06014718369657501},"p2":{"x":0,"y":129},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"137","x":"772","y":"657","zOrder":"6"},{"ID":"184","h":"210","measuredH":"209","measuredW":"1","properties":{"color":"10027263","curvature":"0","direction":"top","leftArrow":"false","p0":{"x":1,"y":0},"p1":{"x":0.5542035800419328,"y":-0.004702289336225807},"p2":{"x":1,"y":209},"rightArrow":"false","shape":"bezier","size":"10"},"typeID":"Arrow","w":"2","x":"692","y":"1020","zOrder":"5"},{"ID":"185","h":"46","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"203","x":"587","y":"1202","zOrder":"128"},{"ID":"186","measuredH":"23","measuredW":"103","properties":{"bold":"true","size":"15","text":"Keep Learning"},"typeID":"Label","x":"637","y":"1214","zOrder":"129"},{"ID":"187","h":"91","measuredH":"90","measuredW":"1","properties":{"color":"10027263","curvature":"0","direction":"top","leftArrow":"false","p0":{"x":1,"y":0},"p1":{"x":0.5542035800419328,"y":-0.004702289336225807},"p2":{"x":1,"y":90},"rightArrow":"false","shape":"bezier","size":"10","stroke":"dotted"},"typeID":"Arrow","w":"2","x":"692","y":"1220","zOrder":"4"},{"ID":"188","measuredH":"40","measuredW":"279","properties":{"bold":"true","size":"32","text":"Android Developer"},"typeID":"Label","x":"536","y":"195","zOrder":"130"},{"ID":"189","h":"87","measuredH":"86","measuredW":"32","properties":{"color":"10027263","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":32,"y":0},"p1":{"x":0.5422802850356294,"y":0.07387173396674585},"p2":{"x":0,"y":86},"rightArrow":"false","shape":"bezier","size":"10","stroke":"dotted"},"typeID":"Arrow","w":"33","x":"686","y":"92","zOrder":"131"},{"ID":"190","h":"52","measuredH":"51","measuredW":"111","properties":{"color":"10027263","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":111,"y":51},"p1":{"x":0.5671491757137114,"y":-0.018697225572979495},"p2":{"x":0,"y":0},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"112","x":"244","y":"1017","zOrder":"3"},{"ID":"191","h":"3","measuredH":"2","measuredW":"95","properties":{"color":"10027263","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":95,"y":0},"p1":{"x":0.4235598227474151,"y":0.012555391432791729},"p2":{"x":0,"y":2},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"96","x":"246","y":"1067","zOrder":"2"},{"ID":"192","h":"41","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"90","x":"169","y":"1096","zOrder":"132"},{"ID":"193","measuredH":"23","measuredW":"51","properties":{"bold":"true","size":"15","text":"Dagger"},"typeID":"Label","x":"189","y":"1105","zOrder":"133"},{"ID":"194","h":"43","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"91","x":"169","y":"1144","zOrder":"134"},{"ID":"195","measuredH":"23","measuredW":"31","properties":{"bold":"true","size":"15","text":"Koin"},"typeID":"Label","x":"199","y":"1154","zOrder":"135"},{"ID":"196","h":"3","measuredH":"2","measuredW":"95","properties":{"color":"10027263","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":95,"y":0,"length":95},"p1":{"x":0.4235598227474151,"y":0.012555391432791725,"length":0.4237458687702481},"p2":{"x":0,"y":2,"length":2},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"96","x":"227","y":"1116","zOrder":"1"},{"ID":"197","h":"56","measuredH":"55","measuredW":"56","properties":{"color":"10027263","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":56,"y":0},"p1":{"x":0.4235598227474151,"y":0.012555391432791725},"p2":{"x":0,"y":55},"rightArrow":"false","shape":"bezier","stroke":"dotted"},"typeID":"Arrow","w":"57","x":"246","y":"1115","zOrder":"0"},{"ID":"198","h":"43","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"112","x":"402","y":"1196","zOrder":"136"},{"ID":"199","measuredH":"23","measuredW":"78","properties":{"bold":"true","size":"15","text":"Coroutines"},"typeID":"Label","x":"418","y":"1206","zOrder":"137"},{"ID":"200","h":"43","measuredH":"70","measuredW":"100","properties":{"color":"16770457"},"typeID":"Canvas","w":"103","x":"291","y":"1196","zOrder":"138"},{"ID":"201","measuredH":"23","measuredW":"51","properties":{"bold":"true","size":"15","text":"RxJava"},"typeID":"Label","x":"317","y":"1206","zOrder":"139"}]},"measuredH":"1311","measuredW":"1179","mockupH":"1219","mockupW":"1018","version":"1.0"}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/android/resources.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/android/resources.json new file mode 100644 index 000000000..0174c0720 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/android/resources.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Android Developer Roadmap: Learn to become an Android developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for android development. Learn to become a modern Android developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an android developer","android developer roadmap","android roadmap","become android developer","android developer skills","android skills test","skills for android development","learn android development","what is android","android quiz","android interview questions"]},"title":"Android Developer","description":"Step by step guide to becoming an Android developer in 2021","featuredTitle":"Android","featuredDescription":"Step by step guide to becoming an Android Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/105-android/landscape.md","resourcesPath":"/roadmaps/105-android/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"android","metaPath":"/roadmaps/105-android/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/angular.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/angular.json new file mode 100644 index 000000000..e436d79e8 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/angular.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Angular Developer Roadmap: Learn to become a Angular developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for angular development. Learn to become a modern Angular developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a angular developer","angular developer roadmap","angular roadmap","become angular developer","angular developer skills","angular skills test","skills for angular development","learn angular development","what is angular","angular quiz","angular interview questions"]},"title":"Angular Developer","description":"Everything that is there to learn about Angular and the ecosystem in 2021.","featuredTitle":"Angular","featuredDescription":"Step by step guide to become a Angular Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/104-angular/landscape.md","resourcesPath":"/roadmaps/104-angular/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/angular-roadmap","id":"angular","metaPath":"/roadmaps/104-angular/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/angular/interactive.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/angular/interactive.json new file mode 100644 index 000000000..d5a5b0256 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/angular/interactive.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Angular Developer Roadmap: Learn to become a Angular developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for angular development. Learn to become a modern Angular developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a angular developer","angular developer roadmap","angular roadmap","become angular developer","angular developer skills","angular skills test","skills for angular development","learn angular development","what is angular","angular quiz","angular interview questions"]},"title":"Angular Developer","description":"Everything that is there to learn about Angular and the ecosystem in 2021.","featuredTitle":"Angular","featuredDescription":"Step by step guide to become a Angular Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/104-angular/landscape.md","resourcesPath":"/roadmaps/104-angular/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/angular-roadmap","id":"angular","metaPath":"/roadmaps/104-angular/meta.json","isUpcoming":false},"json":{"mockup":{"controls":{"control":[{"ID":"1411","typeID":"Arrow","zOrder":"39","w":"16","h":"68","measuredW":"150","measuredH":"100","x":"474","y":"242","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4869331283627979,"y":0.16641045349730976},"p2":{"x":8,"y":68},"color":"10027263"}},{"ID":"1412","typeID":"Canvas","zOrder":"40","w":"454","h":"90","measuredW":"100","measuredH":"70","x":"108","y":"183"},{"ID":"1413","typeID":"Label","zOrder":"41","measuredW":"97","measuredH":"36","x":"421","y":"318","properties":{"size":"28","text":"Angular"}},{"ID":"1414","typeID":"Arrow","zOrder":"42","w":"19","h":"81","measuredW":"150","measuredH":"100","x":"432","y":"364","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":19,"y":0},"p1":{"x":0.5567523389124819,"y":-0.13813347062029335},"p2":{"x":6.934965300090653,"y":81.42459516339846}}},{"ID":"1415","typeID":"Label","zOrder":"43","measuredW":"396","measuredH":"28","x":"137","y":"202","properties":{"size":"20","text":"Frontend Roadmap till Framework Selection"}},{"ID":"1416","typeID":"Label","zOrder":"44","measuredW":"152","measuredH":"24","x":"258","y":"232","properties":{"size":"16","color":"10027263","text":"roadmap.sh/frontend"}},{"ID":"1426","typeID":"Arrow","zOrder":"38","w":"33","h":"73","measuredW":"150","measuredH":"100","x":"428","y":"129","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","stroke":"dotted","p0":{"x":6,"y":0},"p1":{"x":0.4744027303754264,"y":-0.21757679180887365},"p2":{"x":33,"y":72.5}}},{"ID":"1427","typeID":"Canvas","zOrder":"46","w":"262","h":"43","measuredW":"100","measuredH":"70","x":"354","y":"437","properties":{"color":"16776960"}},{"ID":"1428","typeID":"Label","zOrder":"47","measuredW":"175","measuredH":"24","x":"397","y":"447","properties":{"size":"16","text":"Learn TypeScript Basics"}},{"ID":"1429","typeID":"Arrow","zOrder":"32","w":"107","h":"51","measuredW":"150","measuredH":"100","x":"276","y":"405","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":107,"y":51},"p1":{"x":0.5245584633234497,"y":0.05852778135877272},"p2":{"x":0,"y":0}}},{"ID":"1430","typeID":"Arrow","zOrder":"33","w":"102","h":"51","measuredW":"150","measuredH":"100","x":"282","y":"462","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":102,"y":0},"p1":{"x":0.5656811947576955,"y":-0.05547089302042049},"p2":{"x":0.00391587828403317,"y":50.680759201315595}}},{"ID":"1431","typeID":"Arrow","zOrder":"34","w":"115","h":"5","measuredW":"150","measuredH":"100","x":"274","y":"457","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":115,"y":1},"p1":{"x":0.5205160087037612,"y":0.03901150139881877},"p2":{"x":0,"y":0}}},{"ID":"1442","typeID":"Arrow","zOrder":"31","w":"88","h":"88","measuredW":"150","measuredH":"100","x":"284","y":"468","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":88.85873396459311,"y":-0.1566834906291774},"p1":{"x":0.5656811947576954,"y":-0.05547089302042051},"p2":{"x":0.3637812831232736,"y":88.33826919084072}}},{"ID":"1445","typeID":"Arrow","zOrder":"30","w":"117","h":"50","measuredW":"150","measuredH":"100","x":"598","y":"401","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":117.03921766627673,"y":-0.41284752854630824},"p1":{"x":0.5198780554566917,"y":0.06964721983543032},"p2":{"x":0.22588012673645608,"y":49.14432597307683}}},{"ID":"1448","typeID":"Arrow","zOrder":"29","w":"109","h":"5","measuredW":"150","measuredH":"100","x":"608","y":"453","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":108.21915036869632,"y":-0.4958086220839846},"p1":{"x":0.5209787928221856,"y":0.005742251223491233},"p2":{"x":-0.3346582539068095,"y":4.2239221875944395}}},{"ID":"1451","typeID":"Arrow","zOrder":"28","w":"131","h":"37","measuredW":"150","measuredH":"100","x":"594","y":"465","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":130.47867928563346,"y":37.061364879539155},"p1":{"x":0.54496644295302,"y":-0.04519015659955236},"p2":{"x":-0.49385068294191115,"y":0.483451104531639}}},{"ID":"1452","typeID":"__group__","zOrder":"36","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"69","y":"486","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"121","measuredH":"24","x":"50","y":"9","properties":{"size":"16","text":"Structural Typing"}}]}}},{"ID":"1453","typeID":"__group__","zOrder":"37","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"69","y":"533","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"109","measuredH":"24","x":"65","y":"9","properties":{"size":"16","text":"Type Inference"}}]}}},{"ID":"1454","typeID":"__group__","zOrder":"48","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"69","y":"439","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"148","measuredH":"24","x":"37","y":"9","properties":{"size":"16","text":"Why use TypeScript?"}}]}}},{"ID":"1455","typeID":"__group__","zOrder":"35","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"69","y":"392","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"141","measuredH":"24","x":"44","y":"9","properties":{"size":"16","text":"What is TypeScript?"}}]}}},{"ID":"1456","typeID":"__group__","zOrder":"51","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"706","y":"477","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"94","measuredW":"92","measuredH":"24","x":"64","y":"9","properties":{"size":"16","text":"Type Guards"}}]}}},{"ID":"1457","typeID":"__group__","zOrder":"50","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"706","y":"429","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"94","measuredH":"24","x":"64","y":"9","properties":{"size":"16","text":"Built-in types"}}]}}},{"ID":"1458","typeID":"__group__","zOrder":"49","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"707","y":"382","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"89","measuredH":"24","x":"65","y":"9","properties":{"size":"16","text":"Union Types"}}]}}},{"ID":"1460","typeID":"Canvas","zOrder":"52","w":"262","h":"43","measuredW":"100","measuredH":"70","x":"354","y":"485","properties":{"color":"16776960"}},{"ID":"1461","typeID":"Label","zOrder":"53","measuredW":"136","measuredH":"24","x":"417","y":"495","properties":{"size":"16","text":"Learn RxJS Basics"}},{"ID":"1463","typeID":"Arrow","zOrder":"27","w":"95","h":"112","measuredW":"150","measuredH":"100","x":"287","y":"511","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":-0.27635331203754276,"y":109.64460147270881},"p1":{"x":0.4337829756129974,"y":-0.30427270915010957},"p2":{"x":94.11826288153031,"y":-0.08913985231384913}}},{"ID":"1465","typeID":"Canvas","zOrder":"54","w":"238","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"599","properties":{"color":"16770457"}},{"ID":"1466","typeID":"Label","zOrder":"55","measuredW":"197","measuredH":"24","x":"89","y":"608","properties":{"size":"16","text":"What is Observable Pattern"}},{"ID":"1467","typeID":"Canvas","zOrder":"56","w":"238","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"646","properties":{"color":"16770457"}},{"ID":"1468","typeID":"Label","zOrder":"57","measuredW":"151","measuredH":"24","x":"112","y":"655","properties":{"size":"16","text":"Observable Lifecycle"}},{"ID":"1469","typeID":"Arrow","zOrder":"26","w":"112","h":"156","measuredW":"150","measuredH":"100","x":"282","y":"509","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0.00391587828403317,"y":155.30211146223394},"p1":{"x":0.4337829756128934,"y":-0.304272709150173},"p2":{"x":107.37779179846751,"y":-0.44900525715303274}}},{"ID":"1470","typeID":"Canvas","zOrder":"58","w":"238","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"693","properties":{"color":"16770457"}},{"ID":"1471","typeID":"Label","zOrder":"59","measuredW":"125","measuredH":"24","x":"112","y":"702","properties":{"size":"16","text":"Marble Diagrams"}},{"ID":"1472","typeID":"Arrow","zOrder":"25","w":"115","h":"196","measuredW":"150","measuredH":"100","x":"291","y":"517","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0.44337749764082446,"y":196.26931861264734},"p1":{"x":0.4101610216546365,"y":-0.2726818434203219},"p2":{"x":108.9971861202439,"y":0.40049001099396264}}},{"ID":"1473","typeID":"Canvas","zOrder":"60","w":"250","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"741","properties":{"color":"16770457"}},{"ID":"1474","typeID":"Label","zOrder":"61","measuredW":"74","measuredH":"24","x":"151","y":"750","properties":{"size":"16","text":"Operators"}},{"ID":"1476","typeID":"Arrow","zOrder":"24","w":"131","h":"245","measuredW":"150","measuredH":"100","x":"290","y":"516","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0.26344479522123265,"y":245.64655941185083},"p1":{"x":0.41016102165463675,"y":-0.2726818434203223},"p2":{"x":118.2567150371811,"y":0.22055730857437084}}},{"ID":"1479","typeID":"Canvas","zOrder":"62","w":"94","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"810","properties":{"color":"16770457"}},{"ID":"1480","typeID":"Label","zOrder":"63","measuredW":"59","measuredH":"24","x":"86","y":"819","properties":{"size":"16","text":"Filtering"}},{"ID":"1481","typeID":"Canvas","zOrder":"64","w":"148","h":"42","measuredW":"100","measuredH":"70","x":"171","y":"810","properties":{"color":"16770457"}},{"ID":"1482","typeID":"Label","zOrder":"65","measuredW":"96","measuredH":"24","x":"197","y":"819","properties":{"size":"16","text":"Rate Limiting"}},{"ID":"1483","typeID":"Canvas","zOrder":"66","w":"129","h":"42","measuredW":"100","measuredH":"70","x":"70","y":"858","properties":{"color":"16770457"}},{"ID":"1484","typeID":"Label","zOrder":"67","measuredW":"109","measuredH":"24","x":"80","y":"867","properties":{"size":"16","text":"Transformation"}},{"ID":"1487","typeID":"Canvas","zOrder":"68","w":"112","h":"42","measuredW":"100","measuredH":"70","x":"207","y":"858","properties":{"color":"16770457"}},{"ID":"1488","typeID":"Label","zOrder":"69","measuredW":"92","measuredH":"24","x":"217","y":"867","properties":{"size":"16","text":"Combination"}},{"ID":"1489","typeID":"Arrow","zOrder":"23","w":"2","h":"63","measuredW":"150","measuredH":"100","x":"121","y":"763","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":-0.08632597255774499,"y":0.41645846548021836},"p1":{"x":0.5516778523489941,"y":0.02617449664429551},"p2":{"x":-0.08632597255774499,"y":62.952891693718925}}},{"ID":"1490","typeID":"Arrow","zOrder":"22","w":"2","h":"63","measuredW":"150","measuredH":"100","x":"241","y":"763","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":-0.08632597255774499,"y":0.41645846548021836},"p1":{"x":0.5516778523489941,"y":0.02617449664429551},"p2":{"x":-0.08632597255774499,"y":62.952891693718925}}},{"ID":"1491","typeID":"Arrow","zOrder":"21","w":"135","h":"58","measuredW":"150","measuredH":"100","x":"588","y":"511","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":135.29874658321387,"y":58.31752891745634},"p1":{"x":0.5639435268094195,"y":0.13721829941668096},"p2":{"x":0.25671503718109534,"y":0.22055730857437084}}},{"ID":"1493","typeID":"Canvas","zOrder":"70","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"706","y":"546","properties":{"color":"16770457"}},{"ID":"1494","typeID":"Label","zOrder":"71","measuredW":"129","measuredH":"24","x":"752","y":"555","properties":{"size":"16","text":"RxJS vs Promises"}},{"ID":"1495","typeID":"Arrow","zOrder":"20","w":"77","h":"126","measuredW":"150","measuredH":"100","x":"488","y":"514","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":0.4921388017137929,"y":-0.13930809626481278},"p1":{"x":0.5172259793288243,"y":0.14374122751052712},"p2":{"x":77.18776445898766,"y":126.11349106263219}}},{"ID":"1496","typeID":"Canvas","zOrder":"72","w":"198","h":"43","measuredW":"100","measuredH":"70","x":"437","y":"617","properties":{"color":"16776960"}},{"ID":"1497","typeID":"Label","zOrder":"73","measuredW":"108","measuredH":"24","x":"482","y":"627","properties":{"size":"16","text":"Angular Basics"}},{"ID":"1498","typeID":"Arrow","zOrder":"19","w":"96","h":"10","measuredW":"150","measuredH":"100","x":"620","y":"624","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":96.21915036869632,"y":1.9542986335969772},"p1":{"x":0.5330762632088566,"y":-0.057856824198413107},"p2":{"x":-0.2758023127736351,"y":10.213827550534234}}},{"ID":"1499","typeID":"Canvas","zOrder":"74","w":"221","h":"42","measuredW":"100","measuredH":"70","x":"699","y":"606","properties":{"color":"16770457"}},{"ID":"1500","typeID":"Label","zOrder":"75","measuredW":"149","measuredH":"24","x":"735","y":"615","properties":{"size":"16","text":"Angular.js vs Angular"}},{"ID":"1501","typeID":"Canvas","zOrder":"76","w":"221","h":"42","measuredW":"100","measuredH":"70","x":"699","y":"654","properties":{"color":"16770457"}},{"ID":"1502","typeID":"Label","zOrder":"77","measuredW":"162","measuredH":"24","x":"729","y":"663","properties":{"size":"16","text":"Architectural Overview"}},{"ID":"1503","typeID":"Arrow","zOrder":"18","w":"91","h":"28","measuredW":"150","measuredH":"100","x":"620","y":"646","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":90.31948685659836,"y":28.331539432800582},"p1":{"x":0.48745256552117705,"y":0.07265743813183477},"p2":{"x":-0.2758023127736351,"y":0.01315457473015158}}},{"ID":"1504","typeID":"Canvas","zOrder":"78","w":"198","h":"42","measuredW":"100","measuredH":"70","x":"437","y":"665","properties":{"color":"16770457"}},{"ID":"1505","typeID":"Label","zOrder":"79","measuredW":"75","measuredH":"24","x":"498","y":"674","properties":{"size":"16","text":"Templates"}},{"ID":"1524","typeID":"Arrow","zOrder":"17","w":"95","h":"62","measuredW":"150","measuredH":"100","x":"620","y":"685","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":95.03921766627673,"y":62.487366982815615},"p1":{"x":0.5564186379541387,"y":-0.13163875019958368},"p2":{"x":-0.2758023127736351,"y":0.21382755053423352}}},{"ID":"1526","typeID":"Canvas","zOrder":"84","w":"198","h":"42","measuredW":"100","measuredH":"70","x":"437","y":"712","properties":{"color":"16770457"}},{"ID":"1527","typeID":"Label","zOrder":"85","measuredW":"127","measuredH":"24","x":"472","y":"721","properties":{"size":"16","text":"Rendering Topics"}},{"ID":"1528","typeID":"__group__","zOrder":"81","measuredW":"149","measuredH":"42","w":"149","h":"42","x":"831","y":"709","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"149","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"120","measuredH":"24","x":"13","y":"9","properties":{"size":"16","text":"Property Binding"}}]}}},{"ID":"1529","typeID":"__group__","zOrder":"80","measuredW":"127","measuredH":"42","w":"127","h":"42","x":"699","y":"709","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"127","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"92","measuredH":"24","x":"18","y":"9","properties":{"size":"16","text":"Interpolation"}}]}}},{"ID":"1530","typeID":"__group__","zOrder":"82","measuredW":"127","measuredH":"42","w":"127","h":"42","x":"700","y":"756","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"127","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"101","measuredH":"24","x":"15","y":"9","properties":{"size":"16","text":"Event Binding"}}]}}},{"ID":"1531","typeID":"__group__","zOrder":"83","measuredW":"149","measuredH":"42","w":"149","h":"42","x":"831","y":"757","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"149","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"100","measuredH":"24","x":"25","y":"9","properties":{"size":"16","text":"#ref variables"}}]}}},{"ID":"1532","typeID":"__group__","zOrder":"45","measuredW":"350","measuredH":"141","w":"350","h":"141","x":"626","y":"169","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"350","h":"141","measuredW":"100","measuredH":"70","x":"0","y":"0"},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"314","measuredH":"25","x":"14","y":"17","properties":{"size":"17","text":"Find the detailed version of this roadmap"}},{"ID":"2","typeID":"Label","zOrder":"2","measuredW":"319","measuredH":"25","x":"14","y":"45","properties":{"size":"17","text":"along with resources and other roadmaps"}},{"ID":"3","typeID":"Canvas","zOrder":"3","w":"320","h":"45","measuredW":"100","measuredH":"70","x":"15","y":"81","properties":{"borderColor":"4273622","color":"4273622"}},{"ID":"4","typeID":"Label","zOrder":"4","measuredW":"105","measuredH":"28","x":"156","y":"89","properties":{"color":"16777215","size":"20","text":"roadmap.sh"}},{"ID":"5","typeID":"Label","zOrder":"5","measuredW":"35","measuredH":"28","x":"91","y":"89","properties":{"color":"16777215","size":"20","text":"http"}},{"ID":"6","typeID":"Label","zOrder":"6","measuredW":"5","measuredH":"28","x":"128","y":"89","properties":{"color":"16777215","size":"20","text":":"}},{"ID":"7","typeID":"Label","zOrder":"7","measuredW":"10","measuredH":"28","x":"135","y":"90","properties":{"color":"16777215","size":"20","text":"/"}},{"ID":"8","typeID":"Label","zOrder":"8","measuredW":"10","measuredH":"28","x":"143","y":"90","properties":{"color":"16777215","size":"20","text":"/"}}]}}},{"ID":"1533","typeID":"Arrow","zOrder":"16","w":"84","h":"99","measuredW":"150","measuredH":"100","x":"627","y":"731","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":83.31948685659836,"y":99.08265615218761},"p1":{"x":0.6853310980720871,"y":-0.12841575859178522},"p2":{"x":-0.4557350151932269,"y":1.1482418513609218}}},{"ID":"1535","typeID":"Canvas","zOrder":"86","w":"172","h":"42","measuredW":"100","measuredH":"70","x":"700","y":"810","properties":{"color":"16770457"}},{"ID":"1536","typeID":"Label","zOrder":"87","measuredW":"147","measuredH":"24","x":"715","y":"819","properties":{"size":"16","text":"ngIf, "}},{"ID":"1537","typeID":"Canvas","zOrder":"88","w":"99","h":"42","measuredW":"100","measuredH":"70","x":"881","y":"810","properties":{"color":"16770457"}},{"ID":"1538","typeID":"Label","zOrder":"89","measuredW":"43","measuredH":"24","x":"909","y":"819","properties":{"size":"16","text":"ngFor"}},{"ID":"1539","typeID":"Canvas","zOrder":"90","w":"89","h":"42","measuredW":"100","measuredH":"70","x":"702","y":"858","properties":{"color":"16770457"}},{"ID":"1540","typeID":"Label","zOrder":"91","measuredW":"58","measuredH":"24","x":"717","y":"867","properties":{"size":"16","text":"ngClass"}},{"ID":"1541","typeID":"Canvas","zOrder":"92","w":"89","h":"42","measuredW":"100","measuredH":"70","x":"800","y":"858","properties":{"color":"16770457"}},{"ID":"1542","typeID":"Label","zOrder":"93","measuredW":"54","measuredH":"24","x":"818","y":"867","properties":{"size":"16","text":"ngStyle"}},{"ID":"1543","typeID":"Canvas","zOrder":"94","w":"83","h":"42","measuredW":"100","measuredH":"70","x":"897","y":"858","properties":{"color":"16770457"}},{"ID":"1544","typeID":"Label","zOrder":"95","measuredW":"41","measuredH":"24","x":"918","y":"867","properties":{"size":"16","text":"Pipes"}},{"ID":"1545","typeID":"Canvas","zOrder":"96","w":"198","h":"43","measuredW":"100","measuredH":"70","x":"230","y":"969","properties":{"color":"16776960"}},{"ID":"1546","typeID":"Label","zOrder":"97","measuredW":"139","measuredH":"24","x":"259","y":"979","properties":{"size":"16","text":"State Management"}},{"ID":"1547","typeID":"Canvas","zOrder":"98","w":"198","h":"42","measuredW":"100","measuredH":"70","x":"437","y":"758","properties":{"color":"16770457"}},{"ID":"1548","typeID":"Label","zOrder":"99","measuredW":"174","measuredH":"24","x":"449","y":"767","properties":{"size":"16","text":"Forms, Inputs, Validation"}},{"ID":"1549","typeID":"Canvas","zOrder":"100","w":"198","h":"42","measuredW":"100","measuredH":"70","x":"437","y":"804","properties":{"color":"16770457"}},{"ID":"1550","typeID":"Label","zOrder":"101","measuredW":"140","measuredH":"24","x":"466","y":"813","properties":{"size":"16","text":"Services and HTTP"}},{"ID":"1551","typeID":"Canvas","zOrder":"102","w":"198","h":"42","measuredW":"100","measuredH":"70","x":"437","y":"850","properties":{"color":"16770457"}},{"ID":"1552","typeID":"Label","zOrder":"103","measuredW":"114","measuredH":"24","x":"479","y":"859","properties":{"size":"16","text":"Lifecycle Hooks"}},{"ID":"1553","typeID":"Canvas","zOrder":"104","w":"198","h":"42","measuredW":"100","measuredH":"70","x":"437","y":"896","properties":{"color":"16770457"}},{"ID":"1554","typeID":"Label","zOrder":"105","measuredW":"145","measuredH":"24","x":"463","y":"905","properties":{"size":"16","text":"Routing and Guards"}},{"ID":"1555","typeID":"Arrow","zOrder":"15","w":"114","h":"77","measuredW":"150","measuredH":"100","x":"411","y":"912","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":113.49213880171379,"y":-0.13930809626481278},"p1":{"x":0.48035332213415083,"y":0.1877545196165364},"p2":{"x":-0.38341955797972105,"y":76.78360462762362}}},{"ID":"1556","typeID":"Canvas","zOrder":"106","w":"112","h":"42","measuredW":"100","measuredH":"70","x":"66","y":"945","properties":{"color":"14540253"}},{"ID":"1557","typeID":"Label","zOrder":"107","measuredW":"43","measuredH":"24","x":"100","y":"954","properties":{"size":"16","text":"NGXS"}},{"ID":"1558","typeID":"Canvas","zOrder":"108","w":"112","h":"42","measuredW":"100","measuredH":"70","x":"66","y":"994","properties":{"color":"16770457"}},{"ID":"1559","typeID":"Label","zOrder":"109","measuredW":"47","measuredH":"24","x":"98","y":"1003","properties":{"size":"16","text":"@ngrx"}},{"ID":"1560","typeID":"Arrow","zOrder":"14","w":"87","h":"21","measuredW":"150","measuredH":"100","x":"162","y":"995","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":-0.29036382738183875,"y":21.570879075617313},"p1":{"x":0.41689655172413825,"y":0.047241379310345236},"p2":{"x":87.02465615166847,"y":0.3320904320645468}}},{"ID":"1561","typeID":"Arrow","zOrder":"13","w":"91","h":"26","measuredW":"150","measuredH":"100","x":"161","y":"962","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":-0.47029652980143055,"y":0.29397476431574887},"p1":{"x":0.3722126929674102,"y":-0.07547169811320738},"p2":{"x":90.38452155650765,"y":26.252494217546996}}},{"ID":"1562","typeID":"Arrow","zOrder":"12","w":"163","h":"4","measuredW":"150","measuredH":"100","x":"382","y":"996","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":162.56837013721133,"y":0.4531671933509642},"p1":{"x":0.5713380847918264,"y":0.00009045798840656983},"p2":{"x":-0.38341955797972105,"y":4.7836046276236175}}},{"ID":"1563","typeID":"Canvas","zOrder":"110","w":"176","h":"43","measuredW":"100","measuredH":"70","x":"508","y":"973","properties":{"color":"16776960"}},{"ID":"1564","typeID":"Label","zOrder":"111","measuredW":"122","measuredH":"24","x":"535","y":"983","properties":{"size":"16","text":"Advanced Topics"}},{"ID":"1575","typeID":"Arrow","zOrder":"11","w":"64","h":"43","measuredW":"150","measuredH":"100","x":"669","y":"951","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0.13983554215440108,"y":42.82783099986625},"p1":{"x":0.45957640430083985,"y":-0.04513426163109045},"p2":{"x":63.92699743495791,"y":-0.44621493077136165}}},{"ID":"1576","typeID":"__group__","zOrder":"112","measuredW":"250","measuredH":"42","w":"250","h":"42","x":"729","y":"929","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"250","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"199","measuredH":"24","x":"25","y":"9","properties":{"size":"16","text":"Creating Custom Directives"}}]}}},{"ID":"1577","typeID":"__group__","zOrder":"113","measuredW":"250","measuredH":"42","w":"250","h":"42","x":"729","y":"974","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"250","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"167","measuredH":"24","x":"41","y":"9","properties":{"size":"16","text":"Creating Custom Pipes"}}]}}},{"ID":"1578","typeID":"__group__","zOrder":"114","measuredW":"250","measuredH":"42","w":"250","h":"42","x":"729","y":"1020","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"250","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"113","measuredH":"24","x":"68","y":"9","properties":{"size":"16","text":"Reactive Forms"}}]}}},{"ID":"1579","typeID":"__group__","zOrder":"115","measuredW":"250","measuredH":"42","w":"250","h":"42","x":"729","y":"1066","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"250","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"192","measuredH":"24","x":"29","y":"9","properties":{"size":"16","text":"Modules and Lazy Loading"}}]}}},{"ID":"1580","typeID":"__group__","zOrder":"116","measuredW":"250","measuredH":"42","w":"250","h":"42","x":"729","y":"1112","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"250","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"223","measuredH":"24","x":"13","y":"9","properties":{"size":"16","text":"Dependency Injection & Zones"}}]}}},{"ID":"1581","typeID":"Arrow","zOrder":"9","w":"73","h":"3","measuredW":"150","measuredH":"100","x":"672","y":"994","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":-0.3587071287161052,"y":2.830745658125352},"p1":{"x":0.5510688836104509,"y":-0.019002375296912517},"p2":{"x":72.18355541604092,"y":0.32928832899574445}}},{"ID":"1582","typeID":"Arrow","zOrder":"10","w":"76","h":"44","measuredW":"150","measuredH":"100","x":"665","y":"999","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0.3876495484601037,"y":0.33220298725484554},"p1":{"x":0.6014961585119298,"y":-0.048321876263648623},"p2":{"x":76.68209808691131,"y":44.10770624702195}}},{"ID":"1583","typeID":"Arrow","zOrder":"8","w":"71","h":"88","measuredW":"150","measuredH":"100","x":"669","y":"1001","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0.13983554215440108,"y":-0.41706834818035077},"p1":{"x":0.6103816419192543,"y":-0.039882194134249226},"p2":{"x":71.4313694223465,"y":87.13393817135398}}},{"ID":"1584","typeID":"Arrow","zOrder":"7","w":"76","h":"131","measuredW":"150","measuredH":"100","x":"662","y":"999","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":-0.3645364452341937,"y":0.33220298725484554},"p1":{"x":0.6281168248802743,"y":-0.05749468283743387},"p2":{"x":75.92991209321701,"y":131.65871276655616}}},{"ID":"1585","typeID":"Arrow","zOrder":"6","w":"102","h":"130","measuredW":"150","measuredH":"100","x":"489","y":"1003","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":0.03490784482687559,"y":129.53480576340348},"p1":{"x":0.45483345114655443,"y":-0.26083682860175045},"p2":{"x":101.61658044202028,"y":-0.2163953723763825}}},{"ID":"1586","typeID":"Canvas","zOrder":"117","w":"205","h":"43","measuredW":"100","measuredH":"70","x":"305","y":"1111","properties":{"color":"16776960"}},{"ID":"1587","typeID":"Label","zOrder":"118","measuredW":"153","measuredH":"24","x":"331","y":"1121","properties":{"size":"16","text":"Testing Angular Apps"}},{"ID":"1589","typeID":"Canvas","zOrder":"119","w":"187","h":"42","measuredW":"100","measuredH":"70","x":"50","y":"1062","properties":{"color":"16770457"}},{"ID":"1590","typeID":"Label","zOrder":"120","measuredW":"98","measuredH":"24","x":"95","y":"1071","properties":{"size":"16","text":"Testing Pipes"}},{"ID":"1591","typeID":"Canvas","zOrder":"121","w":"187","h":"42","measuredW":"100","measuredH":"70","x":"50","y":"1109","properties":{"color":"16770457"}},{"ID":"1592","typeID":"Label","zOrder":"122","measuredW":"138","measuredH":"24","x":"75","y":"1118","properties":{"size":"16","text":"Services with Deps"}},{"ID":"1593","typeID":"Canvas","zOrder":"123","w":"187","h":"42","measuredW":"100","measuredH":"70","x":"50","y":"1156","properties":{"color":"16770457"}},{"ID":"1594","typeID":"Label","zOrder":"124","measuredW":"152","measuredH":"24","x":"68","y":"1165","properties":{"size":"16","text":"Component Bindings"}},{"ID":"1595","typeID":"Canvas","zOrder":"125","w":"186","h":"42","measuredW":"100","measuredH":"70","x":"51","y":"1201","properties":{"color":"16770457"}},{"ID":"1596","typeID":"Label","zOrder":"126","measuredW":"129","measuredH":"24","x":"79","y":"1210","properties":{"size":"16","text":"Testing Directives"}},{"ID":"1597","typeID":"Canvas","zOrder":"127","w":"186","h":"42","measuredW":"100","measuredH":"70","x":"51","y":"1247","properties":{"color":"16770457"}},{"ID":"1598","typeID":"Label","zOrder":"128","measuredW":"163","measuredH":"24","x":"62","y":"1256","properties":{"size":"16","text":"Component Templates"}},{"ID":"1599","typeID":"Arrow","zOrder":"5","w":"93","h":"131","measuredW":"150","measuredH":"100","x":"226","y":"1139","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0.38188828622421056,"y":131.740323197811},"p1":{"x":0.34713047694079135,"y":-0.060117568632204146},"p2":{"x":92.9358094640175,"y":0.4138134185095623}}},{"ID":"1600","typeID":"Arrow","zOrder":"4","w":"93","h":"83","measuredW":"150","measuredH":"100","x":"221","y":"1136","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0.37897362796510947,"y":82.20971928609038},"p1":{"x":0.34713047694079147,"y":-0.06011756863220413},"p2":{"x":92.9328948057584,"y":-0.3383725751846214}}},{"ID":"1601","typeID":"Arrow","zOrder":"3","w":"94","h":"45","measuredW":"150","measuredH":"100","x":"221","y":"1132","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0.37897362796510947,"y":44.93567335545299},"p1":{"x":0.34713047694079147,"y":-0.060117568632204355},"p2":{"x":94.1836234703232,"y":-0.09055856887903246}}},{"ID":"1602","typeID":"Arrow","zOrder":"1","w":"90","h":"4","measuredW":"150","measuredH":"100","x":"221","y":"1129","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0.37897362796510947,"y":0.40798410199136015},"p1":{"x":0.38516298239040825,"y":-0.038965904833270275},"p2":{"x":90.43143747662884,"y":1.6587127665561638}}},{"ID":"1603","typeID":"Arrow","zOrder":"2","w":"93","h":"44","measuredW":"150","measuredH":"100","x":"220","y":"1078","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0.1282449634003342,"y":0.12810885483577295},"p1":{"x":0.385162982390408,"y":-0.038965904833270296},"p2":{"x":92.68216614119365,"y":43.903612114602765}}},{"ID":"1604","typeID":"Arrow","zOrder":"129","w":"4","h":"89","measuredW":"150","measuredH":"100","x":"548","y":"1412","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"length":3,"x":3,"y":0},"p1":{"length":0.5327426604018495,"x":0.5326751848090503,"y":0.008478779433645868},"p2":{"length":88,"x":0,"y":88},"rightArrow":"false"}},{"ID":"1605","typeID":"Canvas","zOrder":"130","w":"576","h":"105","measuredW":"100","measuredH":"70","x":"229","y":"1342"},{"ID":"1606","typeID":"Label","zOrder":"131","measuredW":"502","measuredH":"32","x":"269","y":"1364","properties":{"size":"24","text":"Frontend Roadmap after Framework Selection"}},{"ID":"1607","typeID":"Label","zOrder":"132","measuredW":"171","measuredH":"26","x":"434","y":"1400","properties":{"text":"roadmap.sh/frontend","size":"18","color":"10027263"}},{"ID":"1608","typeID":"Arrow","zOrder":"0","w":"113","h":"230","measuredW":"150","measuredH":"100","x":"437","y":"1133","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":-0.47237880082087713,"y":0.16017009568577123},"p1":{"x":0.6283070838905471,"y":0.08759531380403048},"p2":{"x":110.81915507937128,"y":229.6688800433219}}}]},"attributes":{"name":"New Wireframe 4","order":1000032.3806938329,"parentID":null,"notes":null},"branchID":"Master","resourceID":"AA71F98D-882E-4299-BD98-5490AABB3AAE","mockupH":"1372","mockupW":"930","measuredW":"980","measuredH":"1501","version":"1.0"}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/angular/resources.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/angular/resources.json new file mode 100644 index 000000000..e436d79e8 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/angular/resources.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Angular Developer Roadmap: Learn to become a Angular developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for angular development. Learn to become a modern Angular developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a angular developer","angular developer roadmap","angular roadmap","become angular developer","angular developer skills","angular skills test","skills for angular development","learn angular development","what is angular","angular quiz","angular interview questions"]},"title":"Angular Developer","description":"Everything that is there to learn about Angular and the ecosystem in 2021.","featuredTitle":"Angular","featuredDescription":"Step by step guide to become a Angular Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/104-angular/landscape.md","resourcesPath":"/roadmaps/104-angular/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/angular-roadmap","id":"angular","metaPath":"/roadmaps/104-angular/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/aws.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/aws.json new file mode 100644 index 000000000..7b790b850 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/aws.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"AWS Roadmap: Learn to use AWS","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to aws","aws roadmap","aws skills","aws skills test","skills for aws","cloud development","what is aws","aws quiz","aws interview questions"]},"title":"AWS","description":"Everything that is there to learn about AWS and the ecosystem in 2021.","featuredTitle":"AWS","featuredDescription":"Step by step guide to learn AWS in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":true,"featured":true,"contentPath":"/roadmaps/110-aws/landscape.md","resourcesPath":"/roadmaps/110-aws/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"aws","metaPath":"/roadmaps/110-aws/meta.json"}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/aws/interactive.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/aws/interactive.json new file mode 100644 index 000000000..9a219f781 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/aws/interactive.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"AWS Roadmap: Learn to use AWS","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to aws","aws roadmap","aws skills","aws skills test","skills for aws","cloud development","what is aws","aws quiz","aws interview questions"]},"title":"AWS","description":"Everything that is there to learn about AWS and the ecosystem in 2021.","featuredTitle":"AWS","featuredDescription":"Step by step guide to learn AWS in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":true,"featured":true,"contentPath":"/roadmaps/110-aws/landscape.md","resourcesPath":"/roadmaps/110-aws/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"aws","metaPath":"/roadmaps/110-aws/meta.json"},"json":{}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/aws/resources.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/aws/resources.json new file mode 100644 index 000000000..7b790b850 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/aws/resources.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"AWS Roadmap: Learn to use AWS","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to aws","aws roadmap","aws skills","aws skills test","skills for aws","cloud development","what is aws","aws quiz","aws interview questions"]},"title":"AWS","description":"Everything that is there to learn about AWS and the ecosystem in 2021.","featuredTitle":"AWS","featuredDescription":"Step by step guide to learn AWS in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":true,"featured":true,"contentPath":"/roadmaps/110-aws/landscape.md","resourcesPath":"/roadmaps/110-aws/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"aws","metaPath":"/roadmaps/110-aws/meta.json"}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/backend.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/backend.json new file mode 100644 index 000000000..144120cd5 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/backend.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a modern backend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern backend development. Learn to become a modern backend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a backend developer","backend developer","backend engineer","backend skills","backend development","javascript developer","backend development skills","backend development skills test","backend engineer roadmap","backend developer roadmap","become a backend developer","backend developer career path","javascript developer","modern javascript developer","node developer","skills for backend development","learn backend development","what is backend development","backend developer quiz","backend developer interview questions"]},"title":"Backend Developer","description":"Step by step guide to becoming a modern backend developer in 2021","featuredTitle":"Backend","featuredDescription":"Step by step guide to becoming a backend developer in 2021","featured":true,"imagePath":"/roadmaps/backend.png","resourcesPath":"/roadmaps/101-backend/resources.md","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/backend-roadmap","id":"backend","metaPath":"/roadmaps/101-backend/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/backend/interactive.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/backend/interactive.json new file mode 100644 index 000000000..06ad5e01f --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/backend/interactive.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a modern backend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern backend development. Learn to become a modern backend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a backend developer","backend developer","backend engineer","backend skills","backend development","javascript developer","backend development skills","backend development skills test","backend engineer roadmap","backend developer roadmap","become a backend developer","backend developer career path","javascript developer","modern javascript developer","node developer","skills for backend development","learn backend development","what is backend development","backend developer quiz","backend developer interview questions"]},"title":"Backend Developer","description":"Step by step guide to becoming a modern backend developer in 2021","featuredTitle":"Backend","featuredDescription":"Step by step guide to becoming a backend developer in 2021","featured":true,"imagePath":"/roadmaps/backend.png","resourcesPath":"/roadmaps/101-backend/resources.md","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/backend-roadmap","id":"backend","metaPath":"/roadmaps/101-backend/meta.json","isUpcoming":false},"json":{"mockup":{"controls":{"control":[{"ID":"729","h":"114","measuredH":"113","measuredW":"61","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":61,"y":113},"p1":{"x":0.4724095467073242,"y":0.05641236146132645},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"62","x":"937","y":"1226","zOrder":"0"},{"ID":"730","h":"68","measuredH":"67","measuredW":"51","properties":{"color":"2848996","curvature":"0","direction":"top","leftArrow":"false","p0":{"x":51,"y":67},"p1":{"x":0.5053615617266979,"y":-0.006323893318669233},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"52","x":"946","y":"1225","zOrder":"1"},{"ID":"731","h":"39","measuredH":"38","measuredW":"64","properties":{"color":"2848996","curvature":"0","direction":"top","leftArrow":"false","p0":{"x":64,"y":38},"p1":{"x":0.5053615617266979,"y":-0.006323893318669233},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"65","x":"936","y":"1209","zOrder":"2"},{"ID":"732","h":"20","measuredH":"20","measuredW":"88","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":20},"p1":{"x":0.48230378246905115,"y":0.08955689294957749},"p2":{"x":87.5,"y":1},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"88","x":"1005","y":"1604","zOrder":"3"},{"ID":"733","h":"68","measuredH":"68","measuredW":"116","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.3912553025849605,"y":-0.008865445417136677},"p2":{"x":116,"y":68},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"116","x":"850","y":"2910","zOrder":"4"},{"ID":"734","h":"34","measuredH":"34","measuredW":"133","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.3912553025849605,"y":-0.008865445417136665},"p2":{"x":133,"y":34},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"133","x":"840","y":"2900","zOrder":"5"},{"ID":"735","h":"89","measuredH":"88","measuredW":"1","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":1,"y":88},"p1":{"x":0.4072427393330943,"y":0.00953746862674794},"p2":{"x":1,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"2","x":"727","y":"3123","zOrder":"6"},{"ID":"736","h":"166","measuredH":"165","measuredW":"7","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":7,"y":165},"p1":{"x":0.4072427393330943,"y":0.009537468626747932},"p2":{"x":0,"y":0},"rightArrow":"false"},"typeID":"Arrow","w":"8","x":"727","y":"2945","zOrder":"7"},{"ID":"737","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"207","x":"632","y":"3094","zOrder":"8"},{"ID":"738","measuredH":"25","measuredW":"117","properties":{"bold":"true","size":"17","text":"Keep Learning"},"typeID":"Label","x":"677","y":"3107","zOrder":"9"},{"ID":"739","h":"1","measuredH":"1","measuredW":"131","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.3912553025849605,"y":-0.00886544541713669},"p2":{"x":131,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"131","x":"850","y":"2890","zOrder":"10"},{"ID":"740","h":"11","measuredH":"11","measuredW":"71","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":10},"p1":{"x":0.47411668036154464,"y":-0.018898931799506993},"p2":{"x":71,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"71","x":"256","y":"2910","zOrder":"11"},{"ID":"741","h":"31","measuredH":"31","measuredW":"71","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":30},"p1":{"x":0.4995603935524387,"y":-0.017416788779568766},"p2":{"x":71,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"71","x":"255","y":"2912","zOrder":"12"},{"ID":"742","h":"17","measuredH":"17","measuredW":"64","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5429504182819833,"y":0.006529279738828819},"p2":{"x":64,"y":16.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"64","x":"256","y":"2894","zOrder":"13"},{"ID":"743","h":"52","measuredH":"52","measuredW":"81","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":80,"y":-0.5},"p1":{"x":0.5609364241450541,"y":0.021803993573559728},"p2":{"x":-0.5,"y":51.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"81","x":"238","y":"2791","zOrder":"14"},{"ID":"744","h":"35","measuredH":"35","measuredW":"87","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4113913751017088,"y":-0.0006509357200978165},"p2":{"x":87,"y":34.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"87","x":"236","y":"2732","zOrder":"15"},{"ID":"745","h":"39","measuredH":"39","measuredW":"88","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":38.5},"p1":{"x":0.447876447876448,"y":-0.02702702702702703},"p2":{"x":88,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"88","x":"238","y":"2779","zOrder":"16"},{"ID":"746","h":"15","measuredH":"15","measuredW":"92","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":14.5},"p1":{"x":0.4816429170159262,"y":-0.01441743503772003},"p2":{"x":92,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"92","x":"238","y":"2775","zOrder":"17"},{"ID":"747","h":"11","measuredH":"11","measuredW":"84","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":-0.5},"p1":{"x":0.5429934072099873,"y":0.02076027493337075},"p2":{"x":84,"y":10.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"84","x":"237","y":"2761","zOrder":"18"},{"ID":"748","h":"2","measuredH":"2","measuredW":"131","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":0.5},"p1":{"x":0.4113947465778763,"y":0.00850906400295968},"p2":{"x":131,"y":2},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"131","x":"462","y":"2914","zOrder":"19"},{"ID":"749","h":"112","measuredH":"112","measuredW":"83","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":-0.5},"p1":{"x":0.5543793266543408,"y":-0.07832480543492278},"p2":{"x":83,"y":111.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"83","x":"501","y":"2780","zOrder":"20"},{"ID":"750","h":"123","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"335","x":"938","y":"2962","zOrder":"21"},{"ID":"751","measuredH":"25","measuredW":"276","properties":{"bold":"true","size":"17","text":"Building with Observability in mind"},"typeID":"Label","w":"281","x":"968","y":"2974","zOrder":"22"},{"ID":"752","h":"95","measuredH":"95","measuredW":"35","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":95},"p1":{"x":0.4529742373542117,"y":-0.12147103732822093},"p2":{"x":35,"y":0},"rightArrow":"false"},"typeID":"Arrow","w":"35","x":"802","y":"2754","zOrder":"23"},{"ID":"753","h":"1","measuredH":"1","measuredW":"162","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":162,"y":0.5},"p1":{"x":0.6028331464402591,"y":-0.001968098496464288},"p2":{"x":0,"y":0.5},"rightArrow":"false"},"typeID":"Arrow","w":"162","x":"623","y":"2742","zOrder":"24"},{"ID":"754","h":"80","measuredH":"80","measuredW":"2","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.465256538516507,"y":0.0007431756467057328},"p2":{"x":2,"y":80},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"2","x":"1078","y":"2129","zOrder":"25"},{"ID":"755","h":"1","measuredH":"1","measuredW":"88","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":88,"y":-0.5},"p1":{"x":0.50296668188042,"y":0.0027384755819260557},"p2":{"x":0,"y":-0.5},"rightArrow":"false"},"typeID":"Arrow","w":"88","x":"811","y":"2137","zOrder":"26"},{"ID":"756","h":"196","measuredH":"196","measuredW":"98","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":98,"y":-0.5},"p1":{"x":0.6528545119705341,"y":0.09576427255985268},"p2":{"x":0,"y":195.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"98","x":"407","y":"2156","zOrder":"27"},{"ID":"757","h":"160","measuredH":"160","measuredW":"95","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":95,"y":-0.5},"p1":{"x":0.6657039711191336,"y":0.05776173285198556},"p2":{"x":0,"y":159.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"95","x":"409","y":"2147","zOrder":"28"},{"ID":"758","h":"80","measuredH":"80","measuredW":"108","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":108,"y":79.5},"p1":{"x":0.5603029663253457,"y":-0.07492346669481689},"p2":{"x":0,"y":0},"rightArrow":"false"},"typeID":"Arrow","w":"108","x":"649","y":"2053","zOrder":"29"},{"ID":"759","h":"91","measuredH":"91","measuredW":"99","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":99,"y":-0.5},"p1":{"x":0.5321867050105077,"y":-0.014434243999557572},"p2":{"x":0,"y":90.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"99","x":"410","y":"2135","zOrder":"30"},{"ID":"760","h":"36","measuredH":"36","measuredW":"67","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0.5},"p1":{"x":0.3904422315954255,"y":0.08001043614384486},"p2":{"x":67,"y":36},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"67","x":"452","y":"1787","zOrder":"31"},{"ID":"761","h":"46","measuredH":"46","measuredW":"103","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":103,"y":-0.5},"p1":{"x":0.4965025071914738,"y":-0.0092742505933948},"p2":{"x":0,"y":45.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"103","x":"404","y":"2132","zOrder":"32"},{"ID":"762","h":"4","measuredH":"4","measuredW":"121","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":121,"y":-0.5},"p1":{"x":0.5411972474270752,"y":0.004810912855489929},"p2":{"x":0,"y":3},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"121","x":"387","y":"2128","zOrder":"33"},{"ID":"763","h":"38","measuredH":"38","measuredW":"107","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":107,"y":37.5},"p1":{"x":0.5259135372707648,"y":-0.007273293012582408},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"107","x":"401","y":"2086","zOrder":"34"},{"ID":"764","h":"128","measuredH":"128","measuredW":"105","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":105,"y":-0.5},"p1":{"x":0.6569739866467219,"y":0.04673647342113905},"p2":{"x":0,"y":127.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"105","x":"402","y":"2136","zOrder":"35"},{"ID":"765","h":"105","measuredH":"105","measuredW":"57","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":56,"y":105},"p1":{"x":0.4999836027940837,"y":-0.17754894565965978},"p2":{"x":0,"y":0},"rightArrow":"false"},"typeID":"Arrow","w":"57","x":"741","y":"2132","zOrder":"36"},{"ID":"766","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"317","x":"887","y":"2111","zOrder":"37"},{"ID":"767","measuredH":"25","measuredW":"179","properties":{"bold":"true","size":"17","text":"Architectural Patterns"},"typeID":"Label","w":"183","x":"954","y":"2124","zOrder":"38"},{"ID":"768","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"243","x":"958","y":"2179","zOrder":"39"},{"ID":"769","measuredH":"25","measuredW":"121","properties":{"size":"17","text":"Monolithic Apps"},"typeID":"Label","w":"123","x":"1018","y":"2187","zOrder":"40"},{"ID":"770","h":"37","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"244","x":"958","y":"2224","zOrder":"41"},{"ID":"771","measuredH":"25","measuredW":"109","properties":{"size":"17","text":"Microservices"},"typeID":"Label","w":"112","x":"1024","y":"2231","zOrder":"42"},{"ID":"772","h":"37","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"245","x":"957","y":"2306","zOrder":"43"},{"ID":"773","measuredH":"25","measuredW":"207","properties":{"size":"17","text":"CQRS and Event Sourcing"},"typeID":"Label","w":"209","x":"975","y":"2312","zOrder":"44"},{"ID":"774","h":"63","measuredH":"63","measuredW":"0","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":-0.5},"p1":{"x":0.5029239766081871,"y":0},"p2":{"x":0,"y":62},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"1","x":"582","y":"2245","zOrder":"45"},{"ID":"775","h":"181","measuredH":"181","measuredW":"1","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":1,"y":181},"p1":{"x":0.5094807194082528,"y":0.00566965794315323},"p2":{"x":1,"y":0},"rightArrow":"false"},"typeID":"Arrow","w":"1","x":"799","y":"2235","zOrder":"46"},{"ID":"776","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"313","x":"512","y":"2210","zOrder":"47"},{"ID":"777","measuredH":"25","measuredW":"124","properties":{"bold":"true","size":"17","text":"Search Engines"},"typeID":"Label","w":"126","x":"606","y":"2222","zOrder":"48"},{"ID":"778","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"160","x":"514","y":"2290","zOrder":"49"},{"ID":"779","measuredH":"25","measuredW":"104","properties":{"size":"17","text":"Elasticsearch"},"typeID":"Label","w":"106","x":"546","y":"2298","zOrder":"50"},{"ID":"780","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"157","x":"514","y":"2334","zOrder":"51"},{"ID":"781","measuredH":"25","measuredW":"31","properties":{"size":"17","text":"Solr"},"typeID":"Label","w":"36","x":"575","y":"2342","zOrder":"52"},{"ID":"782","h":"37","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"244","x":"958","y":"2265","zOrder":"53"},{"ID":"783","measuredH":"25","measuredW":"35","properties":{"size":"17","text":"SOA"},"typeID":"Label","w":"38","x":"1061","y":"2272","zOrder":"54"},{"ID":"784","h":"109","measuredH":"109","measuredW":"4","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":4,"y":-0.5},"p1":{"x":0.5130929473772274,"y":-0.0344683343093784},"p2":{"x":3,"y":108.5},"rightArrow":"false"},"typeID":"Arrow","w":"4","x":"598","y":"2630","zOrder":"55"},{"ID":"785","h":"3","measuredH":"3","measuredW":"96","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":96,"y":-0.5},"p1":{"x":0.6163558106169299,"y":0.017503586800573956},"p2":{"x":0,"y":2},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"96","x":"394","y":"2622","zOrder":"56"},{"ID":"786","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"144","x":"259","y":"2603","zOrder":"57"},{"ID":"787","measuredH":"25","measuredW":"47","properties":{"size":"17","text":"Neo4j"},"typeID":"Label","w":"51","x":"305","y":"2611","zOrder":"58"},{"ID":"788","h":"29","measuredH":"29","measuredW":"120","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":119.5,"y":0},"p1":{"x":0.6629629629629628,"y":-0.06296296296296298},"p2":{"x":0,"y":29},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"120","x":"851","y":"2537","zOrder":"59"},{"ID":"789","h":"13","measuredH":"13","measuredW":"121","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":120.5,"y":11},"p1":{"x":0.567277856135402,"y":0.05867418899858959},"p2":{"x":-0.5,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"121","x":"849","y":"2570","zOrder":"60"},{"ID":"790","h":"66","measuredH":"66","measuredW":"188","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":-0.5,"y":62},"p1":{"x":0.4529742373542121,"y":-0.12147103732822194},"p2":{"x":187,"y":0},"rightArrow":"false"},"typeID":"Arrow","w":"188","x":"619","y":"2559","zOrder":"61"},{"ID":"791","h":"25","measuredH":"25","measuredW":"75","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":75,"y":25},"p1":{"x":0.6629629629629629,"y":-0.06296296296296301},"p2":{"x":0,"y":1},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"75","x":"311","y":"2462","zOrder":"62"},{"ID":"792","h":"4","measuredH":"3","measuredW":"78","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":78,"y":0},"p1":{"x":0.6163558106169298,"y":0.017503586800573952},"p2":{"x":0,"y":3},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"78","x":"310","y":"2498","zOrder":"63"},{"ID":"793","h":"47","measuredH":"47","measuredW":"96","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":96,"y":0},"p1":{"x":0.6026715722139769,"y":0.08829985157932198},"p2":{"x":0,"y":47},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"96","x":"304","y":"2499","zOrder":"64"},{"ID":"794","h":"84","measuredH":"84","measuredW":"199","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":199,"y":84},"p1":{"x":0.4955621301775147,"y":0.03934911242603547},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"199","x":"885","y":"2745","zOrder":"65"},{"ID":"795","h":"42","measuredH":"42","measuredW":"199","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":199,"y":42},"p1":{"x":0.4825515947467167,"y":0.004502814258911812},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"199","x":"887","y":"2746","zOrder":"66"},{"ID":"796","h":"5","measuredH":"5","measuredW":"196","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":196,"y":5},"p1":{"x":0.4695991671004685,"y":-0.020718375845913583},"p2":{"x":0,"y":3},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"196","x":"894","y":"2736","zOrder":"67"},{"ID":"797","h":"42","measuredH":"42","measuredW":"197","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":197,"y":2},"p1":{"x":0.44620243269441234,"y":-0.0644132453644352},"p2":{"x":0,"y":42},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"197","x":"892","y":"2696","zOrder":"68"},{"ID":"798","h":"54","measuredH":"54","measuredW":"199","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":199,"y":48},"p1":{"x":0.6485783579517326,"y":0.15106944331292413},"p2":{"x":0,"y":-0.5},"rightArrow":"false"},"typeID":"Arrow","w":"199","x":"540","y":"2507","zOrder":"69"},{"ID":"799","h":"55","measuredH":"56","measuredW":"192","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":55.5},"p1":{"x":0.432369591589163,"y":0.09644156894460168},"p2":{"x":192,"y":0.5},"rightArrow":"false"},"typeID":"Arrow","w":"192","x":"526","y":"2437","zOrder":"70"},{"ID":"800","h":"15","measuredH":"15","measuredW":"149","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":149,"y":14},"p1":{"x":0.47363590855998655,"y":-0.003754380110128476},"p2":{"x":0,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"149","x":"876","y":"2441","zOrder":"71"},{"ID":"801","h":"9","measuredH":"9","measuredW":"106","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":106,"y":0},"p1":{"x":0.42286675073560326,"y":0.002311895754518704},"p2":{"x":0,"y":8.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"106","x":"910","y":"2422","zOrder":"72"},{"ID":"802","measuredH":"32","measuredW":"95","properties":{"align":"center","color":"16770457","size":"18","text":"RabbitMQ"},"typeID":"TextInput","w":"183","x":"1006","y":"2403","zOrder":"73"},{"ID":"803","measuredH":"32","measuredW":"63","properties":{"align":"center","color":"16770457","size":"18","text":"Kafka"},"typeID":"TextInput","w":"183","x":"1006","y":"2439","zOrder":"74"},{"ID":"804","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"221","x":"701","y":"2413","zOrder":"75"},{"ID":"805","measuredH":"25","measuredW":"139","properties":{"bold":"true","size":"17","text":"Message Brokers"},"typeID":"Label","w":"141","x":"741","y":"2425","zOrder":"76"},{"ID":"806","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"294","x":"383","y":"2470","zOrder":"77"},{"ID":"807","measuredH":"25","measuredW":"269","properties":{"bold":"true","size":"17","text":"Containerization vs Virtualization"},"typeID":"Label","w":"270","x":"396","y":"2483","zOrder":"78"},{"ID":"808","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"163","x":"750","y":"2716","zOrder":"79"},{"ID":"809","measuredH":"25","measuredW":"104","properties":{"bold":"true","size":"17","text":"Web Servers"},"typeID":"Label","w":"108","x":"784","y":"2729","zOrder":"80"},{"ID":"810","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"144","x":"1053","y":"2675","zOrder":"81"},{"ID":"811","measuredH":"25","measuredW":"43","properties":{"size":"17","text":"Nginx"},"typeID":"Label","w":"46","x":"1102","y":"2683","zOrder":"82"},{"ID":"812","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"144","x":"1053","y":"2721","zOrder":"83"},{"ID":"813","measuredH":"25","measuredW":"58","properties":{"size":"17","text":"Apache"},"typeID":"Label","w":"60","x":"1095","y":"2729","zOrder":"84"},{"ID":"814","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"144","x":"1053","y":"2766","zOrder":"85"},{"ID":"815","measuredH":"25","measuredW":"50","properties":{"size":"17","text":"Caddy"},"typeID":"Label","w":"53","x":"1098","y":"2774","zOrder":"86"},{"ID":"816","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"144","x":"1053","y":"2810","zOrder":"87"},{"ID":"817","measuredH":"25","measuredW":"53","properties":{"size":"17","text":"MS IIS"},"typeID":"Label","w":"55","x":"1102","y":"2818","zOrder":"88"},{"ID":"818","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"144","x":"170","y":"2436","zOrder":"89"},{"ID":"819","measuredH":"25","measuredW":"55","properties":{"size":"17","text":"Docker"},"typeID":"Label","w":"58","x":"217","y":"2444","zOrder":"90"},{"ID":"820","h":"40","measuredH":"140","measuredW":"200","properties":{"borderColor":"6710886","color":"15658734","textColor":"6710886"},"typeID":"TextArea","w":"144","x":"170","y":"2482","zOrder":"91"},{"ID":"821","measuredH":"25","measuredW":"22","properties":{"color":"3355443","size":"17","text":"rkt"},"typeID":"Label","w":"24","x":"230","y":"2490","zOrder":"92"},{"ID":"822","h":"40","measuredH":"140","measuredW":"200","properties":{"borderColor":"6710886","color":"14540253","textColor":"6710886"},"typeID":"TextArea","w":"144","x":"170","y":"2527","zOrder":"93"},{"ID":"823","measuredH":"25","measuredW":"34","properties":{"color":"3355443","size":"17","text":"LXC"},"typeID":"Label","w":"37","x":"223","y":"2535","zOrder":"94"},{"ID":"824","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"163","x":"695","y":"2535","zOrder":"95"},{"ID":"825","measuredH":"25","measuredW":"72","properties":{"bold":"true","size":"17","text":"GraphQL"},"typeID":"Label","w":"79","x":"737","y":"2548","zOrder":"96"},{"ID":"826","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"144","x":"957","y":"2518","zOrder":"97"},{"ID":"827","measuredH":"25","measuredW":"47","properties":{"size":"17","text":"Apollo"},"typeID":"Label","w":"50","x":"1004","y":"2526","zOrder":"98"},{"ID":"828","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"144","x":"957","y":"2564","zOrder":"99"},{"ID":"829","measuredH":"25","measuredW":"106","properties":{"size":"17","text":"Relay Modern"},"typeID":"Label","w":"108","x":"975","y":"2572","zOrder":"100"},{"ID":"830","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"184","x":"454","y":"2597","zOrder":"101"},{"ID":"831","measuredH":"25","measuredW":"140","properties":{"bold":"true","size":"17","text":"Graph Databases"},"typeID":"Label","w":"143","x":"474","y":"2610","zOrder":"102"},{"ID":"832","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"159","x":"549","y":"2718","zOrder":"103"},{"ID":"833","measuredH":"25","measuredW":"101","properties":{"bold":"true","size":"17","text":"WebSockets"},"typeID":"Label","w":"104","x":"577","y":"2731","zOrder":"104"},{"ID":"834","h":"75","measuredH":"75","measuredW":"85","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":85,"y":0},"p1":{"x":0.6098445595854923,"y":-0.2025906735751296},"p2":{"x":0,"y":74.5},"rightArrow":"false"},"typeID":"Arrow","w":"85","x":"602","y":"1137","zOrder":"105"},{"ID":"835","h":"62","measuredH":"62","measuredW":"14","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":12,"y":62},"p1":{"x":0.5415800415800416,"y":0.21101871101871103},"p2":{"x":14,"y":0},"rightArrow":"false"},"typeID":"Arrow","w":"14","x":"590","y":"1983","zOrder":"106"},{"ID":"836","h":"48","measuredH":"48","measuredW":"78","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":48},"p1":{"x":0.469926650366748,"y":-0.0004889975550122233},"p2":{"x":78,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"78","x":"464","y":"1975","zOrder":"107"},{"ID":"837","h":"4","measuredH":"4","measuredW":"81","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":4},"p1":{"x":0.4699266503667479,"y":-0.0004889975550122077},"p2":{"x":81,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"81","x":"455","y":"1973","zOrder":"108"},{"ID":"838","h":"33","measuredH":"33","measuredW":"86","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.469926650366748,"y":-0.0004889975550122311},"p2":{"x":86,"y":33},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"86","x":"457","y":"1932","zOrder":"109"},{"ID":"839","h":"129","measuredH":"129","measuredW":"106","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":128},"p1":{"x":0.47671351663836425,"y":-0.2605051125483238},"p2":{"x":106,"y":-0.5},"rightArrow":"false"},"typeID":"Arrow","w":"107","x":"683","y":"1839","zOrder":"110"},{"ID":"840","h":"1","measuredH":"1","measuredW":"80","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":-0.5},"p1":{"x":0.5633394785356862,"y":-0.002106926520937582},"p2":{"x":80,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"80","x":"959","y":"1833","zOrder":"111"},{"ID":"841","h":"5","measuredH":"5","measuredW":"123","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":123,"y":0},"p1":{"x":0.5029666818804199,"y":0.002738475581926061},"p2":{"x":0,"y":4.5},"rightArrow":"false"},"typeID":"Arrow","w":"123","x":"642","y":"1839","zOrder":"112"},{"ID":"842","h":"52","measuredH":"52","measuredW":"94","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":51.5},"p1":{"x":0.44142114384748704,"y":-0.10589254766031196},"p2":{"x":94,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"94","x":"693","y":"1630","zOrder":"113"},{"ID":"843","h":"1","measuredH":"1","measuredW":"70","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":1},"p1":{"x":0.469926650366748,"y":-0.0004889975550122329},"p2":{"x":70,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"70","x":"386","y":"1682","zOrder":"114"},{"ID":"844","h":"282","measuredH":"140","measuredW":"200","typeID":"TextArea","w":"248","x":"165","y":"1472","zOrder":"115"},{"ID":"845","measuredH":"32","measuredW":"63","properties":{"align":"center","color":"16770457","size":"18","text":"OAuth"},"typeID":"TextInput","w":"223","x":"177","y":"1524","zOrder":"116"},{"ID":"846","measuredH":"32","measuredW":"180","properties":{"align":"center","color":"16770457","size":"18","text":"Basic Authentication"},"typeID":"TextInput","w":"223","x":"177","y":"1560","zOrder":"117"},{"ID":"847","measuredH":"32","measuredW":"183","properties":{"align":"center","color":"16770457","size":"18","text":"Token Authentication"},"typeID":"TextInput","w":"223","x":"177","y":"1596","zOrder":"118"},{"ID":"848","measuredH":"32","measuredW":"55","properties":{"align":"center","color":"16770457","size":"18","text":"JWT"},"typeID":"TextInput","w":"223","x":"177","y":"1633","zOrder":"119"},{"ID":"849","measuredH":"32","measuredW":"77","properties":{"align":"center","color":"16770457","size":"18","text":"OpenID"},"typeID":"TextInput","w":"223","x":"178","y":"1669","zOrder":"120"},{"ID":"850","measuredH":"32","measuredW":"63","properties":{"align":"center","color":"16770457","size":"18","text":"SAML"},"typeID":"TextInput","w":"223","x":"178","y":"1706","zOrder":"121"},{"ID":"851","h":"33","measuredH":"33","measuredW":"57","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":33},"p1":{"x":0.4920052363364346,"y":-0.09642807050352983},"p2":{"x":57,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"57","x":"456","y":"1843","zOrder":"122"},{"ID":"852","h":"3","measuredH":"3","measuredW":"95","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":3},"p1":{"x":0.4699266503667481,"y":-0.000488997555012226},"p2":{"x":95,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"95","x":"427","y":"1832","zOrder":"123"},{"ID":"853","h":"20","measuredH":"20","measuredW":"81","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":-0.5,"y":19.5},"p1":{"x":0.4816763425253991,"y":-0.05932510885341123},"p2":{"x":80,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"81","x":"269","y":"1836","zOrder":"124"},{"ID":"854","h":"23","measuredH":"23","measuredW":"87","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":-0.5,"y":1},"p1":{"x":0.5043513295729252,"y":0.08807413376309427},"p2":{"x":86,"y":23},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"87","x":"262","y":"1809","zOrder":"125"},{"ID":"855","h":"203","measuredH":"203","measuredW":"242","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":242,"y":0},"p1":{"x":0.5151777033596199,"y":0.14994058550286277},"p2":{"x":0,"y":202.5},"rightArrow":"false"},"typeID":"Arrow","w":"242","x":"646","y":"1622","zOrder":"126"},{"ID":"856","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"159","x":"502","y":"1809","zOrder":"127"},{"ID":"857","measuredH":"25","measuredW":"65","properties":{"bold":"true","size":"17","text":"Caching"},"typeID":"Label","w":"70","x":"545","y":"1822","zOrder":"128"},{"ID":"858","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"144","x":"145","y":"1790","zOrder":"129"},{"ID":"859","measuredH":"25","measuredW":"44","properties":{"size":"17","text":"Redis"},"typeID":"Label","w":"46","x":"194","y":"1798","zOrder":"130"},{"ID":"860","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"144","x":"145","y":"1836","zOrder":"131"},{"ID":"861","measuredH":"25","measuredW":"93","properties":{"size":"17","text":"Memcached"},"typeID":"Label","w":"96","x":"173","y":"1844","zOrder":"132"},{"ID":"862","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"129","x":"341","y":"1814","zOrder":"133"},{"ID":"863","measuredH":"25","measuredW":"93","properties":{"size":"17","text":"Server Side"},"typeID":"Label","w":"95","x":"360","y":"1822","zOrder":"134"},{"ID":"864","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"128","x":"341","y":"1859","zOrder":"135"},{"ID":"865","measuredH":"25","measuredW":"85","properties":{"size":"17","text":"Client Side"},"typeID":"Label","w":"88","x":"362","y":"1867","zOrder":"136"},{"ID":"866","h":"37","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"129","x":"342","y":"1772","zOrder":"137"},{"ID":"867","measuredH":"25","measuredW":"36","properties":{"size":"17","text":"CDN"},"typeID":"Label","w":"40","x":"387","y":"1779","zOrder":"138"},{"ID":"868","h":"16","measuredH":"15","measuredW":"102","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":15},"p1":{"x":0.4615951248911806,"y":0.017310654255675347},"p2":{"x":102,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"103","x":"988","y":"1446","zOrder":"139"},{"ID":"869","h":"23","measuredH":"22","measuredW":"103","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.45604025566412953,"y":-0.030700026684625844},"p2":{"x":103,"y":22},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"103","x":"989","y":"1469","zOrder":"140"},{"ID":"870","h":"15","measuredH":"15","measuredW":"100","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":15},"p1":{"x":0.4699266503667482,"y":-0.000488997555012225},"p2":{"x":100,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"100","x":"688","y":"1622","zOrder":"141"},{"ID":"871","h":"24","measuredH":"24","measuredW":"109","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":-0.5,"y":1},"p1":{"x":0.5043513295729251,"y":0.08807413376309428},"p2":{"x":108.5,"y":24},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"109","x":"676","y":"1592","zOrder":"142"},{"ID":"872","h":"75","measuredH":"75","measuredW":"104","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":75},"p1":{"x":0.5126056879323597,"y":0.057109915449654144},"p2":{"x":103.5,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"104","x":"995","y":"1539","zOrder":"143"},{"ID":"873","h":"37","measuredH":"36","measuredW":"96","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":-0.5,"y":0},"p1":{"x":0.553292254417681,"y":-0.1507867800580538},"p2":{"x":95.5,"y":33},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"96","x":"1001","y":"1615","zOrder":"144"},{"ID":"874","h":"66","measuredH":"66","measuredW":"93","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":-0.5,"y":0},"p1":{"x":0.5583937813065076,"y":-0.1856462910232163},"p2":{"x":92.5,"y":65},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"93","x":"1004","y":"1625","zOrder":"145"},{"ID":"875","h":"147","measuredH":"147","measuredW":"20","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":3,"y":0},"p1":{"x":0.5150179959193967,"y":0.1283510235895555},"p2":{"x":0,"y":147},"rightArrow":"false"},"typeID":"Arrow","w":"21","x":"892","y":"1465","zOrder":"146"},{"ID":"876","h":"58","measuredH":"57","measuredW":"104","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":57},"p1":{"x":0.43648681345269785,"y":0.055165739172513925},"p2":{"x":104,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"105","x":"984","y":"1399","zOrder":"147"},{"ID":"877","h":"227","measuredH":"226","measuredW":"6","properties":{"color":"2848996","curvature":"0","direction":"top","leftArrow":"false","p0":{"x":1,"y":0},"p1":{"x":0.5023004996784247,"y":-0.007519912927323998},"p2":{"x":6,"y":226},"rightArrow":"false"},"typeID":"Arrow","w":"7","x":"844","y":"1221","zOrder":"148"},{"ID":"878","h":"58","measuredH":"58","measuredW":"81","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":81,"y":0},"p1":{"x":0.6458011220568096,"y":0.05946017581835049},"p2":{"x":0,"y":58},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"82","x":"690","y":"1471","zOrder":"149"},{"ID":"879","h":"8","measuredH":"7","measuredW":"80","properties":{"color":"2848996","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"x":80,"y":0},"p1":{"x":0.5775782957636026,"y":-0.025361653846795687},"p2":{"x":0,"y":7},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"81","x":"689","y":"1471","zOrder":"150"},{"ID":"880","h":"29","measuredH":"28","measuredW":"84","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":84,"y":28},"p1":{"x":0.6101477809142017,"y":-0.07187418459567801},"p2":{"x":0,"y":1},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"85","x":"685","y":"1436","zOrder":"151"},{"ID":"881","h":"69","measuredH":"68","measuredW":"96","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":96,"y":68},"p1":{"x":0.6632615833637359,"y":-0.099598686610726},"p2":{"x":0,"y":1},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"97","x":"675","y":"1385","zOrder":"152"},{"ID":"882","h":"94","measuredH":"92","measuredW":"73","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":73,"y":93},"p1":{"x":0.6010928961748633,"y":-0.054644808743169335},"p2":{"x":0,"y":1},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"74","x":"693","y":"1343","zOrder":"153"},{"ID":"883","h":"213","measuredH":"212","measuredW":"82","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":0,"y":1},"p1":{"x":0.2883988681822617,"y":0.12014830715191724},"p2":{"x":82,"y":212},"rightArrow":"false"},"typeID":"Arrow","w":"83","x":"711","y":"1226","zOrder":"154"},{"ID":"884","h":"5","measuredH":"4","measuredW":"81","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":81,"y":4},"p1":{"x":0.4444444444444445,"y":-0.04938271604938272},"p2":{"x":0,"y":4},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"82","x":"926","y":"1201","zOrder":"155"},{"ID":"885","h":"111","measuredH":"111","measuredW":"67","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":67,"y":0},"p1":{"x":0.5,"y":0},"p2":{"x":0,"y":111},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"67","x":"428","y":"1241","zOrder":"156"},{"ID":"886","h":"157","measuredH":"157","measuredW":"78","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":78,"y":0},"p1":{"x":0.4932456861133936,"y":0.07316351684470009},"p2":{"x":0,"y":157},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"78","x":"426","y":"1242","zOrder":"157"},{"ID":"887","h":"79","measuredH":"79","measuredW":"73","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":73,"y":0},"p1":{"x":0.5,"y":0},"p2":{"x":0,"y":79},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"73","x":"421","y":"1229","zOrder":"158"},{"ID":"888","h":"32","measuredH":"32","measuredW":"86","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":86,"y":0},"p1":{"x":0.5,"y":0},"p2":{"x":0,"y":32},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"86","x":"414","y":"1222","zOrder":"159"},{"ID":"889","h":"14","measuredH":"14","measuredW":"125","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":125,"y":14},"p1":{"x":0.5,"y":0},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"125","x":"405","y":"1207","zOrder":"160"},{"ID":"890","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"229","x":"488","y":"1201","zOrder":"161"},{"ID":"891","measuredH":"25","measuredW":"172","properties":{"bold":"true","size":"17","text":"Relational Databases"},"typeID":"Label","w":"174","x":"516","y":"1214","zOrder":"162"},{"ID":"892","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"191","x":"243","y":"1192","zOrder":"163"},{"ID":"893","measuredH":"25","measuredW":"95","properties":{"size":"17","text":"PostgreSQL"},"typeID":"Label","w":"96","x":"291","y":"1200","zOrder":"164"},{"ID":"894","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"235","y":"1185","zOrder":"165"},{"ID":"895","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"235","y":"1185","zOrder":"166"},{"ID":"896","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"235","y":"1185","zOrder":"167"},{"ID":"897","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"191","x":"243","y":"1238","zOrder":"168"},{"ID":"898","measuredH":"25","measuredW":"58","properties":{"size":"17","text":"MySQL"},"typeID":"Label","w":"60","x":"309","y":"1246","zOrder":"169"},{"ID":"899","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"235","y":"1235","zOrder":"170"},{"ID":"900","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"235","y":"1235","zOrder":"171"},{"ID":"901","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"235","y":"1235","zOrder":"172"},{"ID":"902","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"191","x":"243","y":"1283","zOrder":"173"},{"ID":"903","measuredH":"25","measuredW":"65","properties":{"size":"17","text":"MariaDB"},"typeID":"Label","w":"68","x":"305","y":"1291","zOrder":"174"},{"ID":"904","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"235","y":"1280","zOrder":"175"},{"ID":"905","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"235","y":"1280","zOrder":"176"},{"ID":"906","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"235","y":"1280","zOrder":"177"},{"ID":"907","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"191","x":"243","y":"1329","zOrder":"178"},{"ID":"908","measuredH":"25","measuredW":"66","properties":{"size":"17","text":"MS SQL"},"typeID":"Label","w":"67","x":"305","y":"1337","zOrder":"179"},{"ID":"909","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"235","y":"1326","zOrder":"180"},{"ID":"910","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"235","y":"1326","zOrder":"181"},{"ID":"911","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"235","y":"1326","zOrder":"182"},{"ID":"912","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"191","x":"243","y":"1375","zOrder":"183"},{"ID":"913","measuredH":"25","measuredW":"51","properties":{"size":"17","text":"Oracle"},"typeID":"Label","w":"54","x":"312","y":"1383","zOrder":"184"},{"ID":"914","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"235","y":"1372","zOrder":"185"},{"ID":"915","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"235","y":"1372","zOrder":"186"},{"ID":"916","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"235","y":"1372","zOrder":"187"},{"ID":"917","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"191","x":"756","y":"1187","zOrder":"188"},{"ID":"918","measuredH":"25","measuredW":"149","properties":{"bold":"true","size":"17","text":"NoSQL Databases"},"typeID":"Label","w":"151","x":"775","y":"1199","zOrder":"189"},{"ID":"919","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"326","x":"990","y":"1182","zOrder":"190"},{"ID":"920","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1221","y":"1315","zOrder":"191"},{"ID":"921","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"171","x":"528","y":"1326","zOrder":"192"},{"ID":"922","measuredH":"25","measuredW":"41","properties":{"size":"17","text":"ACID"},"typeID":"Label","w":"43","x":"592","y":"1334","zOrder":"193"},{"ID":"923","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"238","x":"762","y":"1432","zOrder":"194"},{"ID":"924","measuredH":"25","measuredW":"184","properties":{"bold":"true","size":"17","text":"More about Databases"},"typeID":"Label","w":"186","x":"792","y":"1445","zOrder":"195"},{"ID":"925","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"171","x":"528","y":"1370","zOrder":"196"},{"ID":"926","measuredH":"25","measuredW":"100","properties":{"size":"17","text":"Transactions"},"typeID":"Label","w":"105","x":"568","y":"1377","zOrder":"197"},{"ID":"927","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"171","x":"528","y":"1414","zOrder":"198"},{"ID":"928","measuredH":"25","measuredW":"96","properties":{"size":"17","text":"N+1 Problem"},"typeID":"Label","w":"98","x":"571","y":"1421","zOrder":"199"},{"ID":"929","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"206","x":"1080","y":"1425","zOrder":"200"},{"ID":"930","measuredH":"25","measuredW":"153","properties":{"size":"17","text":"Sharding Strategies"},"typeID":"Label","w":"155","x":"1107","y":"1432","zOrder":"201"},{"ID":"931","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"266","x":"435","y":"1460","zOrder":"202"},{"ID":"932","measuredH":"25","measuredW":"184","properties":{"size":"17","text":"Database Normalization"},"typeID":"Label","w":"188","x":"482","y":"1468","zOrder":"203"},{"ID":"933","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"207","x":"1080","y":"1380","zOrder":"204"},{"ID":"934","measuredH":"25","measuredW":"126","properties":{"size":"17","text":"Data Replication"},"typeID":"Label","w":"129","x":"1122","y":"1387","zOrder":"205"},{"ID":"935","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"268","x":"434","y":"1506","zOrder":"206"},{"ID":"936","measuredH":"25","measuredW":"210","properties":{"size":"17","text":"Indexes and how they work"},"typeID":"Label","w":"214","x":"466","y":"1514","zOrder":"207"},{"ID":"937","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"238","x":"776","y":"1592","zOrder":"208"},{"ID":"938","measuredH":"25","measuredW":"142","properties":{"bold":"true","size":"17","text":"Learn about APIs"},"typeID":"Label","w":"143","x":"823","y":"1605","zOrder":"209"},{"ID":"939","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"188","x":"1085","y":"1520","zOrder":"210"},{"ID":"940","measuredH":"25","measuredW":"46","properties":{"size":"17","text":"REST"},"typeID":"Label","w":"49","x":"1155","y":"1528","zOrder":"211"},{"ID":"941","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"188","x":"1085","y":"1584","zOrder":"212"},{"ID":"942","measuredH":"25","measuredW":"89","properties":{"size":"17","text":"JSON APIs"},"typeID":"Label","w":"90","x":"1134","y":"1592","zOrder":"213"},{"ID":"943","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"188","x":"1085","y":"1630","zOrder":"214"},{"ID":"944","measuredH":"25","measuredW":"45","properties":{"size":"17","text":"SOAP"},"typeID":"Label","w":"49","x":"1154","y":"1638","zOrder":"215"},{"ID":"945","measuredH":"22","measuredW":"168","properties":{"size":"14","text":"Read Roy Fielding’s Paper"},"typeID":"Label","w":"179","x":"1092","y":"1560","zOrder":"216"},{"ID":"946","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"268","x":"434","y":"1570","zOrder":"217"},{"ID":"947","measuredH":"25","measuredW":"76","properties":{"size":"17","text":"HATEOAS"},"typeID":"Label","w":"78","x":"529","y":"1578","zOrder":"218"},{"ID":"948","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"268","x":"434","y":"1616","zOrder":"219"},{"ID":"949","measuredH":"25","measuredW":"227","properties":{"size":"17","text":"Open API Spec and Swagger"},"typeID":"Label","w":"230","x":"456","y":"1623","zOrder":"220"},{"ID":"950","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"206","x":"1081","y":"1471","zOrder":"221"},{"ID":"951","measuredH":"25","measuredW":"106","properties":{"size":"17","text":"CAP Theorem"},"typeID":"Label","w":"109","x":"1129","y":"1478","zOrder":"222"},{"ID":"952","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"268","x":"434","y":"1663","zOrder":"223"},{"ID":"953","measuredH":"25","measuredW":"109","properties":{"size":"17","text":"Authentication"},"typeID":"Label","w":"111","x":"512","y":"1671","zOrder":"224"},{"ID":"954","h":"156","measuredH":"156","measuredW":"0","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":-0.5},"p1":{"x":0.4652565385165071,"y":0.0007431756467057314},"p2":{"x":0,"y":155},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"1","x":"920","y":"1832","zOrder":"225"},{"ID":"955","h":"54","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"240","x":"739","y":"1808","zOrder":"226"},{"ID":"956","measuredH":"25","measuredW":"202","properties":{"bold":"true","size":"17","text":"Web Security Knowledge"},"typeID":"Label","w":"203","x":"762","y":"1823","zOrder":"227"},{"ID":"957","h":"171","measuredH":"140","measuredW":"200","typeID":"TextArea","w":"456","x":"834","y":"1915","zOrder":"228"},{"ID":"958","h":"42","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"163","x":"849","y":"1979","zOrder":"229"},{"ID":"959","measuredH":"25","measuredW":"49","properties":{"bold":"true","size":"17","text":"CORS"},"typeID":"Label","w":"51","x":"905","y":"1988","zOrder":"230"},{"ID":"960","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"166","x":"848","y":"1929","zOrder":"231"},{"ID":"961","measuredH":"25","measuredW":"57","properties":{"bold":"true","size":"17","text":"HTTPS"},"typeID":"Label","w":"63","x":"899","y":"1939","zOrder":"232"},{"ID":"962","h":"44","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"257","x":"1019","y":"1929","zOrder":"233"},{"ID":"963","measuredH":"25","measuredW":"191","properties":{"bold":"true","size":"17","text":"Content Security Policy"},"typeID":"Label","w":"196","x":"1050","y":"1939","zOrder":"234"},{"ID":"964","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"427","x":"848","y":"2027","zOrder":"235"},{"ID":"965","measuredH":"25","measuredW":"183","properties":{"bold":"true","size":"17","text":"OWASP Security Risks"},"typeID":"Label","w":"187","x":"968","y":"2037","zOrder":"236"},{"ID":"966","h":"185","measuredH":"140","measuredW":"200","typeID":"TextArea","w":"270","x":"1018","y":"1719","zOrder":"237"},{"ID":"967","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"239","x":"1033","y":"1727","zOrder":"238"},{"ID":"968","measuredH":"25","measuredW":"201","properties":{"size":"17","text":"MD5 and why not to use it"},"typeID":"Label","w":"203","x":"1053","y":"1735","zOrder":"239"},{"ID":"969","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"237","x":"1034","y":"1772","zOrder":"240"},{"ID":"970","measuredH":"25","measuredW":"87","properties":{"size":"17","text":"SHA Family"},"typeID":"Label","w":"93","x":"1106","y":"1779","zOrder":"241"},{"ID":"971","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"119","x":"1035","y":"1818","zOrder":"242"},{"ID":"972","measuredH":"25","measuredW":"50","properties":{"size":"17","text":"scrypt"},"typeID":"Label","w":"62","x":"1073","y":"1825","zOrder":"243"},{"ID":"973","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"111","x":"1161","y":"1818","zOrder":"244"},{"ID":"974","measuredH":"25","measuredW":"51","properties":{"size":"17","text":"bcrypt"},"typeID":"Label","w":"53","x":"1196","y":"1825","zOrder":"245"},{"ID":"975","measuredH":"25","measuredW":"150","properties":{"size":"17","text":"Hashing Algorithms"},"typeID":"Label","w":"155","x":"1075","y":"1866","zOrder":"246"},{"ID":"976","measuredH":"32","measuredW":"127","properties":{"align":"center","color":"16770457","size":"18","text":"Cookie Based"},"typeID":"TextInput","w":"223","x":"177","y":"1486","zOrder":"247"},{"ID":"977","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"258","x":"1018","y":"1979","zOrder":"248"},{"ID":"978","measuredH":"25","measuredW":"73","properties":{"bold":"true","size":"17","text":"SSL/TLS"},"typeID":"Label","w":"75","x":"1109","y":"1988","zOrder":"249"},{"ID":"979","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"159","x":"527","y":"1945","zOrder":"250"},{"ID":"980","measuredH":"25","measuredW":"60","properties":{"bold":"true","size":"17","text":"Testing"},"typeID":"Label","w":"63","x":"575","y":"1958","zOrder":"251"},{"ID":"981","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"192","x":"279","y":"1914","zOrder":"252"},{"ID":"982","measuredH":"25","measuredW":"146","properties":{"size":"17","text":"Integration Testing"},"typeID":"Label","w":"150","x":"300","y":"1922","zOrder":"253"},{"ID":"983","h":"37","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"193","x":"278","y":"1961","zOrder":"254"},{"ID":"984","measuredH":"25","measuredW":"95","properties":{"size":"17","text":"Unit Testing"},"typeID":"Label","w":"99","x":"325","y":"1968","zOrder":"255"},{"ID":"985","h":"37","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"193","x":"278","y":"2002","zOrder":"256"},{"ID":"986","measuredH":"25","measuredW":"142","properties":{"size":"17","text":"Functional Testing"},"typeID":"Label","w":"151","x":"299","y":"2009","zOrder":"257"},{"ID":"987","h":"152","measuredH":"152","measuredW":"42","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4470340174304187,"y":0.25307843688501525},"p2":{"x":9,"y":151.5},"rightArrow":"false"},"typeID":"Arrow","w":"42","x":"744","y":"513","zOrder":"258"},{"ID":"988","h":"112","measuredH":"112","measuredW":"26","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":26,"y":0},"p1":{"x":0.540933899332929,"y":-0.1946634323832626},"p2":{"x":18,"y":112},"rightArrow":"false"},"typeID":"Arrow","w":"26","x":"672","y":"317","zOrder":"259"},{"ID":"989","measuredH":"40","measuredW":"131","properties":{"bold":"true","size":"32","text":"Backend"},"typeID":"Label","x":"644","y":"263","zOrder":"260"},{"ID":"990","h":"80","measuredH":"79","measuredW":"18","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":17,"y":0},"p1":{"x":0.4835868694955965,"y":0.10168134507606086},"p2":{"x":0,"y":79},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"19","x":"741","y":"176","zOrder":"261"},{"ID":"991","h":"141","measuredH":"70","measuredW":"100","typeID":"Canvas","w":"350","x":"949","y":"169","zOrder":"262"},{"ID":"992","measuredH":"25","measuredW":"314","properties":{"size":"17","text":"Find the detailed version of this roadmap"},"typeID":"Label","x":"963","y":"186","zOrder":"263"},{"ID":"993","measuredH":"25","measuredW":"322","properties":{"size":"17","text":"along with resources and other roadmaps"},"typeID":"Label","x":"963","y":"214","zOrder":"264"},{"ID":"994","h":"45","measuredH":"70","measuredW":"100","properties":{"borderColor":"4273622","color":"4273622"},"typeID":"Canvas","w":"320","x":"964","y":"250","zOrder":"265"},{"ID":"995","measuredH":"28","measuredW":"103","properties":{"color":"16777215","size":"20","text":"roadmap.sh"},"typeID":"Label","x":"1105","y":"258","zOrder":"266"},{"ID":"996","measuredH":"28","measuredW":"36","properties":{"color":"16777215","size":"20","text":"http"},"typeID":"Label","x":"1040","y":"258","zOrder":"267"},{"ID":"997","measuredH":"28","measuredW":"10","properties":{"bold":"true","color":"16777215","size":"20","text":":"},"typeID":"Label","x":"1077","y":"258","zOrder":"268"},{"ID":"998","measuredH":"28","measuredW":"10","properties":{"color":"16777215","size":"20","text":"/"},"typeID":"Label","x":"1084","y":"259","zOrder":"269"},{"ID":"999","measuredH":"28","measuredW":"10","properties":{"color":"16777215","size":"20","text":"/"},"typeID":"Label","x":"1092","y":"259","zOrder":"270"},{"ID":"1000","h":"162","measuredH":"70","measuredW":"100","typeID":"Canvas","w":"408","x":"137","y":"159","zOrder":"271"},{"ID":"1001","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"160","y":"180","zOrder":"272"},{"ID":"1002","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"160","y":"180","zOrder":"273"},{"ID":"1003","measuredH":"24","measuredW":"263","properties":{"size":"16","text":"Personal Recommendation / Opinion"},"typeID":"Label","x":"196","y":"180","zOrder":"274"},{"ID":"1004","measuredH":"24","measuredW":"159","properties":{"size":"16","text":"I wouldn't recommend"},"typeID":"Label","x":"196","y":"277","zOrder":"275"},{"ID":"1005","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"160","y":"277","zOrder":"276"},{"ID":"1006","measuredH":"24","measuredW":"319","properties":{"size":"16","text":"Order in roadmap not strict (Learn anytime)"},"typeID":"Label","w":"324","x":"197","y":"245","zOrder":"277"},{"ID":"1007","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"160","y":"245","zOrder":"278"},{"ID":"1008","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"160","y":"245","zOrder":"279"},{"ID":"1009","measuredH":"24","measuredW":"277","properties":{"size":"16","text":"Alternative Option - Pick this or purple"},"typeID":"Label","x":"196","y":"213","zOrder":"280"},{"ID":"1010","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"160","y":"212","zOrder":"281"},{"ID":"1011","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"160","y":"212","zOrder":"282"},{"ID":"1012","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"160","y":"212","zOrder":"283"},{"ID":"1013","h":"264","measuredH":"264","measuredW":"41","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":28,"y":-0.5},"p1":{"x":0.4709081800615472,"y":-0.12924926644242468},"p2":{"x":41,"y":263.5},"rightArrow":"false"},"typeID":"Arrow","w":"41","x":"718","y":"675","zOrder":"284"},{"ID":"1014","h":"151","measuredH":"151","measuredW":"87","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":72,"y":0},"p1":{"x":0.4164731105949616,"y":0.25156333750223336},"p2":{"x":0,"y":151},"rightArrow":"false"},"typeID":"Arrow","w":"87","x":"687","y":"951","zOrder":"285"},{"ID":"1015","h":"82","measuredH":"82","measuredW":"43","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":-0.5,"y":82},"p1":{"x":0.5274187832250412,"y":-0.12252805670406892},"p2":{"x":42.5,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"43","x":"830","y":"856","zOrder":"286"},{"ID":"1016","h":"73","measuredH":"73","measuredW":"48","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":48,"y":72.5},"p1":{"x":0.5228612603170445,"y":0.14935150006550507},"p2":{"x":0,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"48","x":"612","y":"866","zOrder":"287"},{"ID":"1017","h":"74","measuredH":"74","measuredW":"118","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":118,"y":-0.5},"p1":{"x":0.5873541588257404,"y":0.06127211140383051},"p2":{"x":0,"y":73.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"118","x":"457","y":"962","zOrder":"288"},{"ID":"1018","h":"61","measuredH":"61","measuredW":"91","properties":{"color":"2848996","leftArrow":"false","p0":{"x":91,"y":60},"p1":{"x":0.486318838754369,"y":0.01448408325199147},"p2":{"x":0,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"91","x":"940","y":"960","zOrder":"289"},{"ID":"1019","h":"24","measuredH":"24","measuredW":"93","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":93,"y":23},"p1":{"x":0.4798692360633174,"y":-0.0049896765313145654},"p2":{"x":0,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"93","x":"936","y":"949","zOrder":"290"},{"ID":"1020","h":"18","measuredH":"18","measuredW":"115","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":115,"y":0},"p1":{"x":0.4495149461236092,"y":-0.004886187015480865},"p2":{"x":0,"y":17.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"115","x":"931","y":"922","zOrder":"291"},{"ID":"1021","h":"45","measuredH":"45","measuredW":"131","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":131,"y":-0.5},"p1":{"x":0.5873541588257396,"y":0.061272111403828454},"p2":{"x":0,"y":44.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"131","x":"447","y":"946","zOrder":"292"},{"ID":"1022","h":"5","measuredH":"5","measuredW":"141","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":141,"y":0},"p1":{"x":0.5,"y":0},"p2":{"x":0,"y":5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"141","x":"458","y":"937","zOrder":"293"},{"ID":"1023","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"136","x":"800","y":"827","zOrder":"294"},{"ID":"1024","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"136","x":"329","y":"921","zOrder":"295"},{"ID":"1025","measuredH":"25","measuredW":"36","properties":{"size":"17","text":"Java"},"typeID":"Label","w":"38","x":"378","y":"929","zOrder":"296"},{"ID":"1026","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"136","x":"542","y":"831","zOrder":"297"},{"ID":"1027","measuredH":"25","measuredW":"37","properties":{"size":"17","text":"Rust"},"typeID":"Label","w":"39","x":"590","y":"839","zOrder":"298"},{"ID":"1028","measuredH":"25","measuredW":"22","properties":{"size":"17","text":"Go"},"typeID":"Label","w":"26","x":"855","y":"834","zOrder":"299"},{"ID":"1029","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"136","x":"329","y":"970","zOrder":"300"},{"ID":"1030","measuredH":"25","measuredW":"24","properties":{"size":"17","text":"C#"},"typeID":"Label","w":"27","x":"383","y":"978","zOrder":"301"},{"ID":"1031","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"792","y":"819","zOrder":"302"},{"ID":"1032","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"792","y":"819","zOrder":"303"},{"ID":"1033","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"792","y":"819","zOrder":"304"},{"ID":"1034","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"321","y":"914","zOrder":"305"},{"ID":"1035","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"321","y":"914","zOrder":"306"},{"ID":"1036","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"321","y":"914","zOrder":"307"},{"ID":"1037","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"534","y":"822","zOrder":"308"},{"ID":"1038","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"534","y":"822","zOrder":"309"},{"ID":"1039","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"534","y":"822","zOrder":"310"},{"ID":"1040","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"321","y":"964","zOrder":"311"},{"ID":"1041","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"321","y":"964","zOrder":"312"},{"ID":"1042","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"321","y":"964","zOrder":"313"},{"ID":"1043","h":"98","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"380","x":"566","y":"920","zOrder":"314"},{"ID":"1044","measuredH":"25","measuredW":"146","properties":{"bold":"true","size":"17","text":"Learn a Language"},"typeID":"Label","w":"149","x":"681","y":"933","zOrder":"315"},{"ID":"1045","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"136","x":"329","y":"1017","zOrder":"316"},{"ID":"1046","measuredH":"25","measuredW":"33","properties":{"size":"17","text":"PHP"},"typeID":"Label","w":"34","x":"380","y":"1025","zOrder":"317"},{"ID":"1047","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"321","y":"1013","zOrder":"318"},{"ID":"1048","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"321","y":"1013","zOrder":"319"},{"ID":"1049","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"321","y":"1013","zOrder":"320"},{"ID":"1050","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"136","x":"1019","y":"906","zOrder":"321"},{"ID":"1051","measuredH":"25","measuredW":"82","properties":{"size":"17","text":"JavaScript"},"typeID":"Label","w":"85","x":"1046","y":"914","zOrder":"322"},{"ID":"1052","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"136","x":"1019","y":"952","zOrder":"323"},{"ID":"1053","measuredH":"25","measuredW":"53","properties":{"size":"17","text":"Python"},"typeID":"Label","w":"56","x":"1059","y":"960","zOrder":"324"},{"ID":"1054","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"136","x":"1019","y":"998","zOrder":"325"},{"ID":"1055","measuredH":"25","measuredW":"39","properties":{"size":"17","text":"Ruby"},"typeID":"Label","w":"42","x":"1066","y":"1006","zOrder":"326"},{"ID":"1056","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1140","y":"899","zOrder":"327"},{"ID":"1057","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1140","y":"899","zOrder":"328"},{"ID":"1058","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1141","y":"947","zOrder":"329"},{"ID":"1059","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1141","y":"947","zOrder":"330"},{"ID":"1060","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1141","y":"947","zOrder":"331"},{"ID":"1061","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1141","y":"991","zOrder":"332"},{"ID":"1062","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1141","y":"991","zOrder":"333"},{"ID":"1063","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1141","y":"991","zOrder":"334"},{"ID":"1064","h":"40","measuredH":"40","measuredW":"154","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4299387442572742,"y":0.06087289433384378},"p2":{"x":154,"y":40},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"154","x":"844","y":"500","zOrder":"335"},{"ID":"1065","h":"83","measuredH":"83","measuredW":"152","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5124862467909179,"y":-0.09515553629180144},"p2":{"x":152,"y":83},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"152","x":"852","y":"502","zOrder":"336"},{"ID":"1066","h":"57","measuredH":"57","measuredW":"124","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":124,"y":0},"p1":{"x":0.4977437042068999,"y":-0.11213547479256634},"p2":{"x":0,"y":57},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"124","x":"488","y":"504","zOrder":"337"},{"ID":"1067","h":"29","measuredH":"28","measuredW":"150","properties":{"color":"2848996","leftArrow":"false","p0":{"x":150,"y":28},"p1":{"x":0.4823054457996908,"y":0.02336368321594228},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"151","x":"852","y":"454","zOrder":"338"},{"ID":"1068","h":"13","measuredH":"12","measuredW":"152","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":152,"y":0},"p1":{"x":0.4798692360633173,"y":-0.004989676531314521},"p2":{"x":0,"y":12},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"153","x":"854","y":"437","zOrder":"339"},{"ID":"1069","h":"60","measuredH":"59","measuredW":"149","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":149,"y":0},"p1":{"x":0.4552212800557556,"y":-0.05494250203275647},"p2":{"x":0,"y":59},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","x":"852","y":"388","zOrder":"340"},{"ID":"1070","h":"36","measuredH":"36","measuredW":"129","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":129,"y":0},"p1":{"x":0.4772874058127019,"y":0.05888051668460705},"p2":{"x":0,"y":36},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"129","x":"473","y":"456","zOrder":"341"},{"ID":"1071","h":"9","measuredH":"7","measuredW":"129","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":129,"y":7},"p1":{"x":0.4652789342214826,"y":-0.001332223147377271},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"131","x":"473","y":"445","zOrder":"342"},{"ID":"1072","h":"53","measuredH":"51","measuredW":"141","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":141,"y":51},"p1":{"x":0.45522128005575574,"y":-0.054942502032756434},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"143","x":"463","y":"398","zOrder":"343"},{"ID":"1073","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"272","x":"592","y":"424","zOrder":"344"},{"ID":"1074","measuredH":"25","measuredW":"68","properties":{"bold":"true","size":"17","text":"Internet"},"typeID":"Label","w":"69","x":"693","y":"437","zOrder":"345"},{"ID":"1075","h":"44","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"299","x":"196","y":"375","zOrder":"346"},{"ID":"1076","measuredH":"25","measuredW":"221","properties":{"size":"17","text":"How does the internet work?"},"typeID":"Label","w":"223","x":"234","y":"385","zOrder":"347"},{"ID":"1077","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"299","x":"196","y":"425","zOrder":"348"},{"ID":"1078","measuredH":"25","measuredW":"117","properties":{"size":"17","text":"What is HTTP?"},"typeID":"Label","w":"119","x":"286","y":"433","zOrder":"349"},{"ID":"1079","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"299","x":"196","y":"471","zOrder":"350"},{"ID":"1080","measuredH":"25","measuredW":"229","properties":{"size":"17","text":"Browsers and how they work?"},"typeID":"Label","w":"230","x":"230","y":"479","zOrder":"351"},{"ID":"1081","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"280","x":"989","y":"370","zOrder":"352"},{"ID":"1082","measuredH":"25","measuredW":"178","properties":{"size":"17","text":"DNS and how it works?"},"typeID":"Label","w":"179","x":"1040","y":"378","zOrder":"353"},{"ID":"1083","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"280","x":"988","y":"416","zOrder":"354"},{"ID":"1084","measuredH":"25","measuredW":"179","properties":{"size":"17","text":"What is Domain Name?"},"typeID":"Label","w":"179","x":"1039","y":"424","zOrder":"355"},{"ID":"1085","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"280","x":"989","y":"462","zOrder":"356"},{"ID":"1086","measuredH":"25","measuredW":"129","properties":{"size":"17","text":"What is hosting?"},"typeID":"Label","w":"133","x":"1063","y":"470","zOrder":"357"},{"ID":"1087","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"586","y":"414","zOrder":"358"},{"ID":"1088","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"586","y":"414","zOrder":"359"},{"ID":"1089","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"189","y":"366","zOrder":"360"},{"ID":"1090","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"189","y":"366","zOrder":"361"},{"ID":"1091","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"188","y":"418","zOrder":"362"},{"ID":"1092","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"188","y":"418","zOrder":"363"},{"ID":"1093","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"188","y":"463","zOrder":"364"},{"ID":"1094","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"188","y":"463","zOrder":"365"},{"ID":"1095","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1255","y":"361","zOrder":"366"},{"ID":"1096","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1255","y":"361","zOrder":"367"},{"ID":"1097","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1254","y":"411","zOrder":"368"},{"ID":"1098","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1254","y":"411","zOrder":"369"},{"ID":"1099","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1254","y":"456","zOrder":"370"},{"ID":"1100","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1254","y":"456","zOrder":"371"},{"ID":"1101","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"272","x":"592","y":"480","zOrder":"372"},{"ID":"1102","measuredH":"25","measuredW":"215","properties":{"bold":"true","size":"17","text":"Basic Frontend Knowledge"},"typeID":"Label","w":"221","x":"620","y":"492","zOrder":"373"},{"ID":"1103","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"142","x":"353","y":"536","zOrder":"374"},{"ID":"1104","measuredH":"25","measuredW":"47","properties":{"size":"17","text":"HTML"},"typeID":"Label","w":"49","x":"399","y":"546","zOrder":"375"},{"ID":"1105","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"142","x":"989","y":"515","zOrder":"376"},{"ID":"1106","measuredH":"25","measuredW":"36","properties":{"size":"17","text":"CSS"},"typeID":"Label","w":"38","x":"1041","y":"525","zOrder":"377"},{"ID":"1107","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"142","x":"989","y":"566","zOrder":"378"},{"ID":"1108","h":"195","measuredH":"195","measuredW":"135","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":134.5,"y":195},"p1":{"x":0.5227813114793675,"y":0.0017380179353795955},"p2":{"x":-0.5,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"135","x":"867","y":"674","zOrder":"379"},{"ID":"1109","h":"131","measuredH":"131","measuredW":"136","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":135.5,"y":131},"p1":{"x":0.5227813114793675,"y":0.0017380179353796794},"p2":{"x":-0.5,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"136","x":"872","y":"672","zOrder":"380"},{"ID":"1110","h":"76","measuredH":"76","measuredW":"138","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":137.5,"y":76},"p1":{"x":0.524315747719159,"y":-0.026418088060293544},"p2":{"x":-0.5,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"138","x":"865","y":"666","zOrder":"381"},{"ID":"1111","h":"30","measuredH":"30","measuredW":"141","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":140.5,"y":30},"p1":{"x":0.5227813114793672,"y":0.0017380179353795478},"p2":{"x":-0.5,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"141","x":"864","y":"660","zOrder":"382"},{"ID":"1112","h":"5","measuredH":"5","measuredW":"144","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":143.5,"y":0},"p1":{"x":0.5227813114793672,"y":0.001738017935379522},"p2":{"x":-0.5,"y":5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"144","x":"861","y":"649","zOrder":"383"},{"ID":"1113","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"267","x":"989","y":"626","zOrder":"384"},{"ID":"1114","measuredH":"25","measuredW":"167","properties":{"size":"17","text":"Memory Management"},"typeID":"Label","w":"170","x":"1039","y":"636","zOrder":"385"},{"ID":"1115","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"268","x":"989","y":"675","zOrder":"386"},{"ID":"1116","measuredH":"25","measuredW":"221","properties":{"size":"17","text":"Interprocess Communication"},"typeID":"Label","w":"224","x":"1012","y":"684","zOrder":"387"},{"ID":"1117","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"268","x":"989","y":"725","zOrder":"388"},{"ID":"1118","measuredH":"25","measuredW":"132","properties":{"size":"17","text":"I/O Management"},"typeID":"Label","w":"135","x":"1055","y":"735","zOrder":"389"},{"ID":"1119","h":"65","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"268","x":"989","y":"775","zOrder":"390"},{"ID":"1120","measuredH":"25","measuredW":"113","properties":{"bold":"true","size":"17","text":"POSIX Basics"},"typeID":"Label","w":"115","x":"1067","y":"786","zOrder":"391"},{"ID":"1121","measuredH":"23","measuredW":"179","properties":{"size":"15","text":"stdin, stdout, stderr, pipes"},"typeID":"Label","w":"180","x":"1033","y":"807","zOrder":"392"},{"ID":"1122","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"268","x":"989","y":"847","zOrder":"393"},{"ID":"1123","measuredH":"25","measuredW":"215","properties":{"size":"17","text":"Basic Networking Concepts"},"typeID":"Label","w":"218","x":"1014","y":"856","zOrder":"394"},{"ID":"1124","h":"151","measuredH":"151","measuredW":"128","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":128,"y":0},"p1":{"x":0.4075757037878519,"y":-0.014129007064503547},"p2":{"x":0,"y":151},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"128","x":"486","y":"678","zOrder":"395"},{"ID":"1125","h":"107","measuredH":"107","measuredW":"125","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":125,"y":0},"p1":{"x":0.4291571249168944,"y":-0.03135849892886164},"p2":{"x":0,"y":107},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"125","x":"487","y":"671","zOrder":"396"},{"ID":"1126","h":"55","measuredH":"55","measuredW":"119","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":119,"y":0},"p1":{"x":0.513033864773653,"y":-0.03543581985336902},"p2":{"x":0,"y":55},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"119","x":"489","y":"669","zOrder":"397"},{"ID":"1127","h":"11","measuredH":"11","measuredW":"131","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":131,"y":0},"p1":{"x":0.4401290896950813,"y":-0.005675495214778532},"p2":{"x":0,"y":11},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"131","x":"482","y":"663","zOrder":"398"},{"ID":"1128","h":"32","measuredH":"32","measuredW":"138","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":138,"y":32},"p1":{"x":0.4566473988439307,"y":-0.03179190751445087},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"138","x":"477","y":"629","zOrder":"399"},{"ID":"1129","measuredH":"25","measuredW":"82","properties":{"size":"17","text":"JavaScript"},"typeID":"Label","w":"84","x":"1023","y":"575","zOrder":"400"},{"ID":"1130","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"272","x":"605","y":"643","zOrder":"401"},{"ID":"1131","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"269","x":"228","y":"603","zOrder":"402"},{"ID":"1132","measuredH":"25","measuredW":"121","properties":{"size":"17","text":"Terminal Usage"},"typeID":"Label","w":"123","x":"301","y":"613","zOrder":"403"},{"ID":"1133","h":"101","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"269","x":"228","y":"802","zOrder":"404"},{"ID":"1134","measuredH":"25","measuredW":"214","properties":{"bold":"true","size":"17","text":"Basic Terminal Commands"},"typeID":"Label","w":"210","x":"258","y":"814","zOrder":"405"},{"ID":"1135","measuredH":"25","measuredW":"234","properties":{"size":"17","text":"grep, awk, sed, lsof, curl, wget"},"typeID":"Label","w":"238","x":"244","y":"840","zOrder":"406"},{"ID":"1136","measuredH":"25","measuredW":"215","properties":{"size":"17","text":"tail, head, less, find, ssh, kill"},"typeID":"Label","w":"216","x":"255","y":"866","zOrder":"407"},{"ID":"1137","measuredH":"25","measuredW":"220","properties":{"bold":"true","size":"17","text":"OS and General Knowledge"},"typeID":"Label","w":"222","x":"633","y":"655","zOrder":"408"},{"ID":"1138","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"267","x":"229","y":"702","zOrder":"409"},{"ID":"1139","measuredH":"25","measuredW":"169","properties":{"size":"17","text":"Process Management"},"typeID":"Label","w":"172","x":"277","y":"711","zOrder":"410"},{"ID":"1140","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"268","x":"229","y":"752","zOrder":"411"},{"ID":"1141","measuredH":"25","measuredW":"201","properties":{"size":"17","text":"Threads and Concurrency"},"typeID":"Label","w":"202","x":"262","y":"762","zOrder":"412"},{"ID":"1142","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"268","x":"229","y":"652","zOrder":"413"},{"ID":"1143","measuredH":"25","measuredW":"196","properties":{"size":"17","text":"How OSs work in General"},"typeID":"Label","w":"197","x":"264","y":"661","zOrder":"414"},{"ID":"1144","measuredH":"23","measuredW":"347","properties":{"size":"15","text":"Make sure to learn its quirks. Core details about its"},"typeID":"Label","w":"347","x":"582","y":"961","zOrder":"415"},{"ID":"1145","measuredH":"23","measuredW":"301","properties":{"size":"15","text":"runtime e.g. concurrency, memory model etc."},"typeID":"Label","w":"306","x":"603","y":"984","zOrder":"416"},{"ID":"1146","h":"1","measuredH":"1","measuredW":"58","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":58,"y":1},"p1":{"x":0.4872751951136749,"y":-0.011876484560570062},"p2":{"x":0,"y":1},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"58","x":"1124","y":"1120","zOrder":"417"},{"ID":"1147","h":"3","measuredH":"1","measuredW":"83","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":83,"y":1},"p1":{"x":0.4872751951136748,"y":-0.01187648456057007},"p2":{"x":0,"y":1},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"85","x":"787","y":"1116","zOrder":"418"},{"ID":"1148","h":"1","measuredH":"0","measuredW":"56","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":-0.5,"y":0},"p1":{"x":0.4872751951136748,"y":-0.011876484560570066},"p2":{"x":55,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"56","x":"420","y":"1122","zOrder":"419"},{"ID":"1149","h":"54","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"216","x":"210","y":"1094","zOrder":"420"},{"ID":"1150","measuredH":"25","measuredW":"153","properties":{"bold":"true","size":"17","text":"Basic Usage of Git"},"typeID":"Label","w":"155","x":"241","y":"1109","zOrder":"421"},{"ID":"1151","h":"49","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"131","x":"1178","y":"996","zOrder":"422"},{"ID":"1152","measuredH":"25","measuredW":"57","properties":{"bold":"true","size":"17","text":"GitHub"},"typeID":"Label","w":"64","x":"1212","y":"1009","zOrder":"423"},{"ID":"1153","h":"78","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"319","x":"833","y":"1079","zOrder":"424"},{"ID":"1154","measuredH":"25","measuredW":"180","properties":{"bold":"true","size":"17","text":"Repo hosting services"},"typeID":"Label","w":"189","x":"899","y":"1094","zOrder":"425"},{"ID":"1155","measuredH":"23","measuredW":"278","properties":{"size":"15","text":"Create account and Learn to use GitHub"},"typeID":"Label","w":"279","x":"854","y":"1120","zOrder":"426"},{"ID":"1156","h":"77","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"336","x":"464","y":"1080","zOrder":"427"},{"ID":"1157","measuredH":"25","measuredW":"199","properties":{"bold":"true","size":"17","text":"Version Control Systems"},"typeID":"Label","w":"201","x":"529","y":"1095","zOrder":"428"},{"ID":"1158","measuredH":"23","measuredW":"290","properties":{"size":"15","text":"What are they and why you should use one"},"typeID":"Label","w":"292","x":"483","y":"1120","zOrder":"429"},{"ID":"1159","h":"49","measuredH":"140","measuredW":"200","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"10066329"},"typeID":"TextArea","w":"131","x":"1178","y":"1104","zOrder":"430"},{"ID":"1160","measuredH":"25","measuredW":"78","properties":{"bold":"true","color":"3355443","size":"17","text":"Bitbucket"},"typeID":"Label","w":"80","x":"1204","y":"1116","zOrder":"431"},{"ID":"1161","h":"48","measuredH":"140","measuredW":"200","properties":{"backgroundAlpha":"0.25","borderColor":"6710886","color":"15658734"},"typeID":"TextArea","w":"131","x":"1178","y":"1104","zOrder":"432"},{"ID":"1162","h":"49","measuredH":"140","measuredW":"200","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"10066329"},"typeID":"TextArea","w":"131","x":"1178","y":"1050","zOrder":"433"},{"ID":"1163","measuredH":"25","measuredW":"55","properties":{"bold":"true","color":"3355443","size":"17","text":"GitLab"},"typeID":"Label","w":"52","x":"1218","y":"1062","zOrder":"434"},{"ID":"1164","h":"49","measuredH":"140","measuredW":"200","properties":{"backgroundAlpha":"0.25","borderColor":"6710886","color":"15658734"},"typeID":"TextArea","w":"131","x":"1178","y":"1050","zOrder":"435"},{"ID":"1165","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"202","y":"1086","zOrder":"436"},{"ID":"1166","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1292","y":"988","zOrder":"437"},{"ID":"1167","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1294","y":"1045","zOrder":"438"},{"ID":"1168","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1294","y":"1045","zOrder":"439"},{"ID":"1169","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1294","y":"1045","zOrder":"440"},{"ID":"1170","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1294","y":"1100","zOrder":"441"},{"ID":"1171","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1294","y":"1100","zOrder":"442"},{"ID":"1172","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1294","y":"1100","zOrder":"443"},{"ID":"1173","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"171","x":"528","y":"1282","zOrder":"444"},{"ID":"1174","measuredH":"25","measuredW":"48","properties":{"size":"17","text":"ORMs"},"typeID":"Label","w":"49","x":"592","y":"1290","zOrder":"445"},{"ID":"1175","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"140","x":"533","y":"2029","zOrder":"446"},{"ID":"1176","measuredH":"25","measuredW":"61","properties":{"bold":"true","size":"17","text":"CI / CD"},"typeID":"Label","w":"62","x":"572","y":"2042","zOrder":"447"},{"ID":"1177","h":"50","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"324","x":"501","y":"2113","zOrder":"448"},{"ID":"1178","measuredH":"25","measuredW":"284","properties":{"bold":"true","size":"17","text":"Design and Development Principles"},"typeID":"Label","w":"292","x":"525","y":"2126","zOrder":"449"},{"ID":"1179","h":"37","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"261","x":"155","y":"2203","zOrder":"450"},{"ID":"1180","measuredH":"25","measuredW":"53","properties":{"size":"17","text":"SOLID"},"typeID":"Label","w":"55","x":"258","y":"2210","zOrder":"451"},{"ID":"1181","h":"37","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"261","x":"155","y":"2245","zOrder":"452"},{"ID":"1182","measuredH":"25","measuredW":"40","properties":{"size":"17","text":"KISS"},"typeID":"Label","w":"44","x":"264","y":"2252","zOrder":"453"},{"ID":"1183","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"260","x":"156","y":"2286","zOrder":"454"},{"ID":"1184","measuredH":"25","measuredW":"49","properties":{"size":"17","text":"YAGNI"},"typeID":"Label","w":"53","x":"259","y":"2294","zOrder":"455"},{"ID":"1185","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"260","x":"156","y":"2330","zOrder":"456"},{"ID":"1186","measuredH":"25","measuredW":"35","properties":{"size":"17","text":"DRY"},"typeID":"Label","w":"38","x":"267","y":"2338","zOrder":"457"},{"ID":"1187","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"260","x":"156","y":"2067","zOrder":"458"},{"ID":"1188","measuredH":"25","measuredW":"165","properties":{"size":"17","text":"GOF Design Patterns"},"typeID":"Label","w":"168","x":"202","y":"2074","zOrder":"459"},{"ID":"1189","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"260","x":"156","y":"2112","zOrder":"460"},{"ID":"1190","measuredH":"25","measuredW":"171","properties":{"size":"17","text":"Domain Driven Design"},"typeID":"Label","w":"175","x":"198","y":"2119","zOrder":"461"},{"ID":"1191","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"260","x":"156","y":"2157","zOrder":"462"},{"ID":"1192","measuredH":"25","measuredW":"194","properties":{"size":"17","text":"Test Driven Development"},"typeID":"Label","w":"196","x":"188","y":"2164","zOrder":"463"},{"ID":"1193","h":"37","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"245","x":"957","y":"2347","zOrder":"464"},{"ID":"1194","measuredH":"25","measuredW":"84","properties":{"size":"17","text":"Serverless"},"typeID":"Label","w":"87","x":"1036","y":"2353","zOrder":"465"},{"ID":"1195","h":"129","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"318","x":"571","y":"2833","zOrder":"466"},{"ID":"1196","measuredH":"25","measuredW":"143","properties":{"bold":"true","size":"17","text":"Building for Scale"},"typeID":"Label","w":"147","x":"656","y":"2849","zOrder":"467"},{"ID":"1197","measuredH":"24","measuredW":"260","properties":{"size":"16","text":"General topics that you should learn"},"typeID":"Label","w":"264","x":"598","y":"2877","zOrder":"468"},{"ID":"1198","measuredH":"24","measuredW":"263","properties":{"size":"16","text":"and care about for the sustainability"},"typeID":"Label","w":"270","x":"595","y":"2900","zOrder":"469"},{"ID":"1199","measuredH":"24","measuredW":"106","properties":{"size":"16","text":"of the product."},"typeID":"Label","w":"108","x":"676","y":"2924","zOrder":"470"},{"ID":"1200","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"199","x":"315","y":"2758","zOrder":"471"},{"ID":"1201","measuredH":"25","measuredW":"157","properties":{"size":"17","text":"Mitigation Strategies"},"typeID":"Label","w":"159","x":"335","y":"2765","zOrder":"472"},{"ID":"1202","measuredH":"23","measuredW":"294","properties":{"size":"15","text":"Metrics logging and other observable items"},"typeID":"Label","w":"299","x":"957","y":"3002","zOrder":"473"},{"ID":"1203","measuredH":"23","measuredW":"302","properties":{"size":"15","text":"that could help you in debugging and solving"},"typeID":"Label","w":"305","x":"954","y":"3025","zOrder":"474"},{"ID":"1204","measuredH":"23","measuredW":"225","properties":{"size":"15","text":"the issues when things go wrong"},"typeID":"Label","w":"229","x":"992","y":"3049","zOrder":"475"},{"ID":"1205","h":"36","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"198","x":"316","y":"2895","zOrder":"476"},{"ID":"1206","measuredH":"25","measuredW":"81","properties":{"size":"17","text":"Monitoring"},"typeID":"Label","w":"84","x":"169","y":"2906","zOrder":"477"},{"ID":"1207","measuredH":"25","measuredW":"75","properties":{"size":"17","text":"Throttling"},"typeID":"Label","w":"78","x":"162","y":"2749","zOrder":"478"},{"ID":"1208","measuredH":"25","measuredW":"107","properties":{"size":"17","text":"Backpressure"},"typeID":"Label","w":"109","x":"131","y":"2777","zOrder":"479"},{"ID":"1209","measuredH":"25","measuredW":"97","properties":{"size":"17","text":"Loadshifting"},"typeID":"Label","w":"100","x":"140","y":"2805","zOrder":"480"},{"ID":"1210","measuredH":"25","measuredW":"66","properties":{"size":"17","text":"Graceful"},"typeID":"Label","w":"70","x":"168","y":"2699","zOrder":"481"},{"ID":"1211","measuredH":"25","measuredW":"78","properties":{"size":"17","text":"Telemetry"},"typeID":"Label","w":"84","x":"167","y":"2931","zOrder":"482"},{"ID":"1212","measuredH":"25","measuredW":"122","properties":{"size":"17","text":"Instrumentation"},"typeID":"Label","w":"124","x":"129","y":"2881","zOrder":"483"},{"ID":"1213","measuredH":"25","measuredW":"154","properties":{"size":"17","text":"Understand the Diff."},"typeID":"Label","w":"155","x":"338","y":"2901","zOrder":"484"},{"ID":"1214","measuredH":"25","measuredW":"115","properties":{"size":"17","text":"Circuit Breaker"},"typeID":"Label","w":"118","x":"122","y":"2830","zOrder":"485"},{"ID":"1215","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"333","x":"938","y":"2868","zOrder":"486"},{"ID":"1216","measuredH":"25","measuredW":"152","properties":{"size":"17","text":"Migration Strategies"},"typeID":"Label","w":"154","x":"1031","y":"2875","zOrder":"487"},{"ID":"1217","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"332","x":"939","y":"2914","zOrder":"488"},{"ID":"1218","measuredH":"25","measuredW":"228","properties":{"size":"17","text":"Horizontal vs Vertical Scaling"},"typeID":"Label","w":"230","x":"993","y":"2921","zOrder":"489"},{"ID":"1219","measuredH":"25","measuredW":"93","properties":{"size":"17","text":"Degradation"},"typeID":"Label","w":"96","x":"142","y":"2719","zOrder":"490"},{"ID":"1220","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"587","y":"475","zOrder":"491"},{"ID":"1221","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"587","y":"475","zOrder":"492"},{"ID":"1222","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"601","y":"633","zOrder":"493"},{"ID":"1223","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"601","y":"633","zOrder":"494"},{"ID":"1224","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"222","y":"594","zOrder":"495"},{"ID":"1225","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"222","y":"594","zOrder":"496"},{"ID":"1226","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"222","y":"647","zOrder":"497"},{"ID":"1227","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"222","y":"647","zOrder":"498"},{"ID":"1228","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"222","y":"695","zOrder":"499"},{"ID":"1229","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"222","y":"695","zOrder":"500"},{"ID":"1230","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"222","y":"746","zOrder":"501"},{"ID":"1231","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"222","y":"746","zOrder":"502"},{"ID":"1232","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"222","y":"797","zOrder":"503"},{"ID":"1233","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"222","y":"797","zOrder":"504"},{"ID":"1234","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"347","y":"527","zOrder":"505"},{"ID":"1235","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"347","y":"527","zOrder":"506"},{"ID":"1236","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1115","y":"508","zOrder":"507"},{"ID":"1237","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1115","y":"508","zOrder":"508"},{"ID":"1238","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1115","y":"561","zOrder":"509"},{"ID":"1239","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1115","y":"561","zOrder":"510"},{"ID":"1240","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1241","y":"618","zOrder":"511"},{"ID":"1241","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1241","y":"618","zOrder":"512"},{"ID":"1242","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1241","y":"671","zOrder":"513"},{"ID":"1243","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1241","y":"671","zOrder":"514"},{"ID":"1244","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1241","y":"721","zOrder":"515"},{"ID":"1245","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1241","y":"721","zOrder":"516"},{"ID":"1246","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1241","y":"771","zOrder":"517"},{"ID":"1247","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1241","y":"771","zOrder":"518"},{"ID":"1248","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1241","y":"846","zOrder":"519"},{"ID":"1249","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1241","y":"846","zOrder":"520"},{"ID":"1250","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"521","y":"1274","zOrder":"521"},{"ID":"1251","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"521","y":"1274","zOrder":"522"},{"ID":"1252","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"521","y":"1322","zOrder":"523"},{"ID":"1253","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"521","y":"1322","zOrder":"524"},{"ID":"1254","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"521","y":"1365","zOrder":"525"},{"ID":"1255","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"521","y":"1365","zOrder":"526"},{"ID":"1256","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"521","y":"1411","zOrder":"527"},{"ID":"1257","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"521","y":"1411","zOrder":"528"},{"ID":"1258","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"429","y":"1451","zOrder":"529"},{"ID":"1259","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"429","y":"1451","zOrder":"530"},{"ID":"1260","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"431","y":"1501","zOrder":"531"},{"ID":"1261","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"431","y":"1501","zOrder":"532"},{"ID":"1262","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1271","y":"1371","zOrder":"533"},{"ID":"1263","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1271","y":"1371","zOrder":"534"},{"ID":"1264","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1271","y":"1421","zOrder":"535"},{"ID":"1265","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1271","y":"1421","zOrder":"536"},{"ID":"1266","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1271","y":"1466","zOrder":"537"},{"ID":"1267","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1271","y":"1466","zOrder":"538"},{"ID":"1268","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"428","y":"1562","zOrder":"539"},{"ID":"1269","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"428","y":"1562","zOrder":"540"},{"ID":"1270","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"428","y":"1610","zOrder":"541"},{"ID":"1271","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"428","y":"1610","zOrder":"542"},{"ID":"1272","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"429","y":"1657","zOrder":"543"},{"ID":"1273","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"429","y":"1657","zOrder":"544"},{"ID":"1274","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1257","y":"1511","zOrder":"545"},{"ID":"1275","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1257","y":"1511","zOrder":"546"},{"ID":"1276","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1258","y":"1577","zOrder":"547"},{"ID":"1277","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1258","y":"1577","zOrder":"548"},{"ID":"1278","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1258","y":"1625","zOrder":"549"},{"ID":"1279","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1258","y":"1625","zOrder":"550"},{"ID":"1280","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"170","y":"1520","zOrder":"551"},{"ID":"1281","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"170","y":"1520","zOrder":"552"},{"ID":"1282","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"170","y":"1556","zOrder":"553"},{"ID":"1283","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"170","y":"1556","zOrder":"554"},{"ID":"1284","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"170","y":"1593","zOrder":"555"},{"ID":"1285","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"170","y":"1593","zOrder":"556"},{"ID":"1286","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"170","y":"1629","zOrder":"557"},{"ID":"1287","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"170","y":"1629","zOrder":"558"},{"ID":"1288","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"171","y":"1664","zOrder":"559"},{"ID":"1289","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"171","y":"1664","zOrder":"560"},{"ID":"1290","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"171","y":"1702","zOrder":"561"},{"ID":"1291","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"171","y":"1702","zOrder":"562"},{"ID":"1292","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"171","y":"1480","zOrder":"563"},{"ID":"1293","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"171","y":"1480","zOrder":"564"},{"ID":"1294","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"136","y":"1782","zOrder":"565"},{"ID":"1295","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"136","y":"1782","zOrder":"566"},{"ID":"1296","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"138","y":"1831","zOrder":"567"},{"ID":"1297","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"138","y":"1831","zOrder":"568"},{"ID":"1298","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"138","y":"1831","zOrder":"569"},{"ID":"1299","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"333","y":"1763","zOrder":"570"},{"ID":"1300","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"333","y":"1763","zOrder":"571"},{"ID":"1301","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"334","y":"1855","zOrder":"572"},{"ID":"1302","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"334","y":"1855","zOrder":"573"},{"ID":"1303","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1272","y":"1703","zOrder":"574"},{"ID":"1304","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1272","y":"1703","zOrder":"575"},{"ID":"1305","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1277","y":"1910","zOrder":"576"},{"ID":"1306","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1277","y":"1910","zOrder":"577"},{"ID":"1307","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"272","y":"1905","zOrder":"578"},{"ID":"1308","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"272","y":"1905","zOrder":"579"},{"ID":"1309","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"272","y":"1954","zOrder":"580"},{"ID":"1310","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"272","y":"1954","zOrder":"581"},{"ID":"1311","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"272","y":"1996","zOrder":"582"},{"ID":"1312","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"272","y":"1996","zOrder":"583"},{"ID":"1313","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"525","y":"2022","zOrder":"584"},{"ID":"1314","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"525","y":"2022","zOrder":"585"},{"ID":"1315","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1187","y":"2171","zOrder":"586"},{"ID":"1316","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1187","y":"2171","zOrder":"587"},{"ID":"1317","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1187","y":"2220","zOrder":"588"},{"ID":"1318","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1187","y":"2220","zOrder":"589"},{"ID":"1319","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1187","y":"2261","zOrder":"590"},{"ID":"1320","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1187","y":"2261","zOrder":"591"},{"ID":"1321","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1189","y":"2303","zOrder":"592"},{"ID":"1322","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1189","y":"2303","zOrder":"593"},{"ID":"1323","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1187","y":"2344","zOrder":"594"},{"ID":"1324","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1187","y":"2344","zOrder":"595"},{"ID":"1325","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"148","y":"2200","zOrder":"596"},{"ID":"1326","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"148","y":"2200","zOrder":"597"},{"ID":"1327","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"147","y":"2243","zOrder":"598"},{"ID":"1328","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"147","y":"2243","zOrder":"599"},{"ID":"1329","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"147","y":"2285","zOrder":"600"},{"ID":"1330","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"147","y":"2285","zOrder":"601"},{"ID":"1331","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"149","y":"2328","zOrder":"602"},{"ID":"1332","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"149","y":"2328","zOrder":"603"},{"ID":"1333","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"148","y":"2154","zOrder":"604"},{"ID":"1334","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"148","y":"2154","zOrder":"605"},{"ID":"1335","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"148","y":"2107","zOrder":"606"},{"ID":"1336","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"148","y":"2107","zOrder":"607"},{"ID":"1337","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"148","y":"2061","zOrder":"608"},{"ID":"1338","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"148","y":"2061","zOrder":"609"},{"ID":"1339","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"507","y":"2284","zOrder":"610"},{"ID":"1340","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"507","y":"2284","zOrder":"611"},{"ID":"1341","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"507","y":"2329","zOrder":"612"},{"ID":"1342","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"507","y":"2329","zOrder":"613"},{"ID":"1343","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"162","y":"2430","zOrder":"614"},{"ID":"1344","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"162","y":"2430","zOrder":"615"},{"ID":"1345","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1088","y":"2510","zOrder":"616"},{"ID":"1346","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1088","y":"2510","zOrder":"617"},{"ID":"1347","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1062","y":"2510","zOrder":"618"},{"ID":"1348","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1062","y":"2510","zOrder":"619"},{"ID":"1349","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1086","y":"2560","zOrder":"620"},{"ID":"1350","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1086","y":"2560","zOrder":"621"},{"ID":"1351","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1086","y":"2560","zOrder":"622"},{"ID":"1352","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"447","y":"2585","zOrder":"623"},{"ID":"1353","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"447","y":"2585","zOrder":"624"},{"ID":"1354","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"253","y":"2595","zOrder":"625"},{"ID":"1355","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"253","y":"2595","zOrder":"626"},{"ID":"1356","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"844","y":"2527","zOrder":"627"},{"ID":"1357","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"844","y":"2527","zOrder":"628"},{"ID":"1358","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1174","y":"2394","zOrder":"629"},{"ID":"1359","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1174","y":"2394","zOrder":"630"},{"ID":"1360","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1151","y":"2393","zOrder":"631"},{"ID":"1361","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1151","y":"2393","zOrder":"632"},{"ID":"1362","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"907","y":"2403","zOrder":"633"},{"ID":"1363","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"907","y":"2403","zOrder":"634"},{"ID":"1364","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1175","y":"2434","zOrder":"635"},{"ID":"1365","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1175","y":"2434","zOrder":"636"},{"ID":"1366","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1175","y":"2434","zOrder":"637"},{"ID":"1367","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"541","y":"2710","zOrder":"638"},{"ID":"1368","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"541","y":"2710","zOrder":"639"},{"ID":"1369","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"896","y":"2704","zOrder":"640"},{"ID":"1370","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"896","y":"2704","zOrder":"641"},{"ID":"1371","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1181","y":"2666","zOrder":"642"},{"ID":"1372","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1181","y":"2666","zOrder":"643"},{"ID":"1373","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1155","y":"2666","zOrder":"644"},{"ID":"1374","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1155","y":"2666","zOrder":"645"},{"ID":"1375","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1181","y":"2717","zOrder":"646"},{"ID":"1376","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1181","y":"2717","zOrder":"647"},{"ID":"1377","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1181","y":"2717","zOrder":"648"},{"ID":"1378","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1181","y":"2806","zOrder":"649"},{"ID":"1379","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1181","y":"2806","zOrder":"650"},{"ID":"1380","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1181","y":"2806","zOrder":"651"},{"ID":"1381","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1181","y":"2762","zOrder":"652"},{"ID":"1382","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1181","y":"2762","zOrder":"653"},{"ID":"1383","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1181","y":"2762","zOrder":"654"},{"ID":"1384","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"501","y":"2750","zOrder":"655"},{"ID":"1385","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"501","y":"2750","zOrder":"656"},{"ID":"1386","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"561","y":"2824","zOrder":"657"},{"ID":"1387","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"561","y":"2824","zOrder":"658"},{"ID":"1388","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1256","y":"2859","zOrder":"659"},{"ID":"1389","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1256","y":"2859","zOrder":"660"},{"ID":"1390","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1256","y":"2912","zOrder":"661"},{"ID":"1391","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1256","y":"2912","zOrder":"662"},{"ID":"1392","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1256","y":"2958","zOrder":"663"},{"ID":"1393","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1256","y":"2958","zOrder":"664"},{"ID":"1394","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"188","x":"1086","y":"1674","zOrder":"665"},{"ID":"1395","measuredH":"25","measuredW":"46","properties":{"align":"center","size":"17","text":"gRPC"},"typeID":"Label","w":"90","x":"1135","y":"1682","zOrder":"666"},{"ID":"1396","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"1259","y":"1667","zOrder":"667"},{"ID":"1397","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"1259","y":"1667","zOrder":"668"},{"ID":"1398","measuredH":"25","measuredW":"83","properties":{"bold":"true","size":"17","text":"Document"},"typeID":"Label","x":"1005","y":"1190","zOrder":"669"},{"ID":"1399","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"326","x":"990","y":"1227","zOrder":"670"},{"ID":"1400","measuredH":"25","measuredW":"98","properties":{"bold":"true","size":"17","text":"Column DBs"},"typeID":"Label","x":"1005","y":"1235","zOrder":"671"},{"ID":"1401","measuredH":"25","measuredW":"87","properties":{"bold":"true","size":"17","text":"{color:blue}Cassandra{color}"},"typeID":"Label","x":"1110","y":"1235","zOrder":"672"},{"ID":"1402","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"328","x":"989","y":"1272","zOrder":"673"},{"ID":"1403","measuredH":"25","measuredW":"96","properties":{"bold":"true","size":"17","text":"Time series"},"typeID":"Label","x":"1005","y":"1280","zOrder":"674"},{"ID":"1404","measuredH":"25","measuredW":"183","properties":{"bold":"true","size":"17","text":"{color:blue}InfluxDB{color}, TimescaleDB"},"typeID":"Label","x":"1109","y":"1281","zOrder":"675"},{"ID":"1405","measuredH":"25","measuredW":"157","properties":{"bold":"true","size":"17","text":"{color:blue}MongoDB{color}, CouchDB"},"typeID":"Label","x":"1095","y":"1190","zOrder":"676"},{"ID":"1406","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"328","x":"989","y":"1317","zOrder":"677"},{"ID":"1407","measuredH":"25","measuredW":"73","properties":{"bold":"true","size":"17","text":"Realtime"},"typeID":"Label","x":"1005","y":"1325","zOrder":"678"},{"ID":"1408","measuredH":"25","measuredW":"162","properties":{"bold":"true","size":"17","text":"{color:blue}Firebase{color}, RethinkDB"},"typeID":"Label","x":"1088","y":"1325","zOrder":"679"}]},"measuredH":"3212","measuredW":"1318","mockupH":"3053","mockupW":"1196","version":"1.0"}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/backend/resources.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/backend/resources.json new file mode 100644 index 000000000..144120cd5 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/backend/resources.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a modern backend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern backend development. Learn to become a modern backend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a backend developer","backend developer","backend engineer","backend skills","backend development","javascript developer","backend development skills","backend development skills test","backend engineer roadmap","backend developer roadmap","become a backend developer","backend developer career path","javascript developer","modern javascript developer","node developer","skills for backend development","learn backend development","what is backend development","backend developer quiz","backend developer interview questions"]},"title":"Backend Developer","description":"Step by step guide to becoming a modern backend developer in 2021","featuredTitle":"Backend","featuredDescription":"Step by step guide to becoming a backend developer in 2021","featured":true,"imagePath":"/roadmaps/backend.png","resourcesPath":"/roadmaps/101-backend/resources.md","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/backend-roadmap","id":"backend","metaPath":"/roadmaps/101-backend/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/devops.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/devops.json new file mode 100644 index 000000000..df9389165 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/devops.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"DevOps Roadmap: Learn to become a DevOps Engineer or SRE","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a devops enginer","devops roadmap","sre roadmap","site reliability engineer roadmap","operations roles","become devops","devops skills","modern devops skills","devops skills test","skills for devops","learn devops","what is devops","what is sre","devops quiz","devops interview questions"]},"title":"DevOps Roadmap","description":"Step by step guide for DevOps, SRE or any other Operations Role in 2021","featuredTitle":"DevOps","featuredDescription":"Step by step guide for DevOps or operations role in 2021","featured":true,"imagePath":"/roadmaps/devops.png","resourcesPath":"/roadmaps/102-devops/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/devops-roadmap","id":"devops","metaPath":"/roadmaps/102-devops/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/devops/interactive.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/devops/interactive.json new file mode 100644 index 000000000..2051ae5a6 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/devops/interactive.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"DevOps Roadmap: Learn to become a DevOps Engineer or SRE","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a devops enginer","devops roadmap","sre roadmap","site reliability engineer roadmap","operations roles","become devops","devops skills","modern devops skills","devops skills test","skills for devops","learn devops","what is devops","what is sre","devops quiz","devops interview questions"]},"title":"DevOps Roadmap","description":"Step by step guide for DevOps, SRE or any other Operations Role in 2021","featuredTitle":"DevOps","featuredDescription":"Step by step guide for DevOps or operations role in 2021","featured":true,"imagePath":"/roadmaps/devops.png","resourcesPath":"/roadmaps/102-devops/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/devops-roadmap","id":"devops","metaPath":"/roadmaps/102-devops/meta.json","isUpcoming":false},"json":{"mockup":{"controls":{"control":[{"ID":"2047","h":"91","measuredH":"91","measuredW":"187","properties":{"color":"2848996","leftArrow":"false","p0":{"x":187,"y":91},"p1":{"x":0.3433950804737264,"y":0.04300030367447366},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"187","x":"810","y":"348","zOrder":"0"},{"ID":"2048","h":"130","measuredH":"130","measuredW":"0","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":-0.5},"p1":{"x":0.5153846153846153,"y":0.007692307692307692},"p2":{"x":0,"y":129.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"1","x":"78","y":"993","zOrder":"1"},{"ID":"2049","h":"204","measuredH":"204","measuredW":"0","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":-0.5},"p1":{"x":0.5331695331695332,"y":0},"p2":{"x":0,"y":203},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"1","x":"212","y":"1140","zOrder":"2"},{"ID":"2050","h":"60","measuredH":"60","measuredW":"1","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":-0.5},"p1":{"x":0.5409978308026031,"y":0.032104121475054294},"p2":{"x":0,"y":59},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"2","x":"140","y":"1132","zOrder":"3"},{"ID":"2051","h":"51","measuredH":"51","measuredW":"33","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":33,"y":-0.5},"p1":{"x":0.5409978308026031,"y":0.032104121475054294},"p2":{"x":0,"y":50.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"33","x":"165","y":"1065","zOrder":"4"},{"ID":"2052","h":"149","measuredH":"149","measuredW":"0","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":148.5},"p1":{"x":0.46874741514792245,"y":-0.0047699137004053056},"p2":{"x":0,"y":-0.5},"rightArrow":"false"},"typeID":"Arrow","w":"1","x":"762","y":"2114","zOrder":"5"},{"ID":"2053","h":"97","measuredH":"97","measuredW":"197","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":-0.5},"p1":{"x":0.4988000000000001,"y":0.03159999999999993},"p2":{"x":197,"y":96.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"197","x":"872","y":"2124","zOrder":"6"},{"ID":"2054","h":"63","measuredH":"63","measuredW":"191","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":-0.5},"p1":{"x":0.4988,"y":0.03159999999999996},"p2":{"x":191,"y":62.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"191","x":"876","y":"2117","zOrder":"7"},{"ID":"2055","h":"31","measuredH":"31","measuredW":"202","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":-0.5},"p1":{"x":0.4988000000000001,"y":0.031599999999999975},"p2":{"x":202,"y":30.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"202","x":"866","y":"2107","zOrder":"8"},{"ID":"2056","h":"11","measuredH":"11","measuredW":"201","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":10.666666666666742},"p1":{"x":0.4988000000000001,"y":0.03159999999999996},"p2":{"x":201,"y":2.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"201","x":"873","y":"2087","zOrder":"9"},{"ID":"2057","h":"49","measuredH":"49","measuredW":"1","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":1,"y":0},"p1":{"x":0.5684273538382602,"y":-0.01687523160685271},"p2":{"x":1,"y":49},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"1","x":"1262","y":"1400","zOrder":"10"},{"ID":"2058","h":"1","measuredH":"1","measuredW":"217","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":1},"p1":{"x":0.6451475897218093,"y":-0.0029730303673816097},"p2":{"x":217,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"217","x":"987","y":"1450","zOrder":"11"},{"ID":"2059","h":"54","measuredH":"54","measuredW":"1","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":1,"y":0},"p1":{"x":0.35250000000000004,"y":-0.01750000000000001},"p2":{"x":1,"y":53.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"1","x":"801","y":"504","zOrder":"12"},{"ID":"2060","h":"54","measuredH":"54","measuredW":"1","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":1,"y":0},"p1":{"x":0.35250000000000004,"y":-0.01750000000000001},"p2":{"x":1,"y":53.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"1","x":"802","y":"584","zOrder":"13"},{"ID":"2061","h":"84","measuredH":"84","measuredW":"67","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.3525,"y":-0.01749999999999999},"p2":{"x":67,"y":84},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"67","x":"412","y":"469","zOrder":"14"},{"ID":"2062","h":"37","measuredH":"37","measuredW":"114","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":114,"y":-0.5},"p1":{"x":0.5684273538382604,"y":-0.01687523160685276},"p2":{"x":0,"y":36.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"114","x":"1059","y":"1750","zOrder":"15"},{"ID":"2063","h":"46","measuredH":"46","measuredW":"21","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":21,"y":0},"p1":{"x":0.56842735383826,"y":-0.016875231606852847},"p2":{"x":0,"y":46},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"21","x":"133","y":"1566","zOrder":"16"},{"ID":"2064","h":"64","measuredH":"64","measuredW":"75","properties":{"color":"2848996","leftArrow":"false","p0":{"x":75,"y":0},"p1":{"x":0.5494290710832219,"y":-0.21551280732434935},"p2":{"x":0,"y":64},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"75","x":"207","y":"2114","zOrder":"17"},{"ID":"2065","h":"65","measuredH":"65","measuredW":"88","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":64.5},"p1":{"x":0.3777257916283734,"y":0.09599799481995154},"p2":{"x":88,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"88","x":"1009","y":"1202","zOrder":"18"},{"ID":"2066","h":"56","measuredH":"56","measuredW":"92","properties":{"color":"2848996","leftArrow":"false","p0":{"x":92,"y":54},"p1":{"x":0.3404217926186292,"y":0.12372583479789104},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"92","x":"777","y":"1221","zOrder":"19"},{"ID":"2067","h":"54","measuredH":"54","measuredW":"30","properties":{"color":"2848996","leftArrow":"false","p0":{"x":30,"y":54},"p1":{"x":0.31900452488687786,"y":-0.0067873303167421736},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"30","x":"600","y":"1232","zOrder":"20"},{"ID":"2068","h":"66","measuredH":"66","measuredW":"45","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":66},"p1":{"x":0.31900452488687786,"y":-0.006787330316742089},"p2":{"x":45,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"45","x":"494","y":"1221","zOrder":"21"},{"ID":"2069","h":"39","measuredH":"39","measuredW":"1","properties":{"color":"2848996","leftArrow":"false","p0":{"x":1,"y":38.5},"p1":{"x":0.4246153846153848,"y":0.003076923076923076},"p2":{"x":0,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"1","x":"1233","y":"679","zOrder":"22"},{"ID":"2070","h":"53","measuredH":"53","measuredW":"24","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":52.5},"p1":{"x":0.4573248407643314,"y":-0.2050955414012743},"p2":{"x":23,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"25","x":"1215","y":"728","zOrder":"23"},{"ID":"2071","h":"2","measuredH":"1","measuredW":"99","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":99,"y":0},"p1":{"x":0.5556179058793521,"y":0.012345364111720445},"p2":{"x":0,"y":0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"99","x":"166","y":"796","zOrder":"24"},{"ID":"2072","h":"3","measuredH":"2","measuredW":"78","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":78,"y":0},"p1":{"x":0.540997830802603,"y":0.03210412147505423},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"78","x":"347","y":"841","zOrder":"25"},{"ID":"2073","h":"69","measuredH":"69","measuredW":"92","properties":{"color":"2848996","leftArrow":"false","p0":{"x":92,"y":68},"p1":{"x":0.343395080473732,"y":0.043000303674461074},"p2":{"x":0,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"92","x":"850","y":"574","zOrder":"26"},{"ID":"2074","h":"76","measuredH":"76","measuredW":"79","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":76},"p1":{"x":0.3525,"y":-0.01749999999999997},"p2":{"x":79,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"79","x":"405","y":"583","zOrder":"27"},{"ID":"2075","h":"26","measuredH":"26","measuredW":"91","properties":{"color":"2848996","leftArrow":"false","p0":{"x":91,"y":25},"p1":{"x":0.34339508047373385,"y":0.0430003036744574},"p2":{"x":0,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"91","x":"851","y":"571","zOrder":"28"},{"ID":"2076","h":"65","measuredH":"65","measuredW":"90","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":90,"y":0},"p1":{"x":0.4151543498596817,"y":-0.02656688493919538},"p2":{"x":0,"y":65},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"90","x":"851","y":"503","zOrder":"29"},{"ID":"2077","h":"126","measuredH":"126","measuredW":"33","properties":{"color":"2848996","leftArrow":"false","p0":{"x":33,"y":-0.5},"p1":{"x":0.5325409551518356,"y":-0.2212487395235813},"p2":{"x":24,"y":125.5},"rightArrow":"false"},"typeID":"Arrow","w":"33","x":"549","y":"584","zOrder":"30"},{"ID":"2078","h":"23","measuredH":"23","measuredW":"110","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":110,"y":0},"p1":{"x":0.4203821656050955,"y":0.020700636942675137},"p2":{"x":0,"y":22.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"110","x":"838","y":"548","zOrder":"31"},{"ID":"2079","h":"36","measuredH":"35","measuredW":"91","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":35},"p1":{"x":0.3525,"y":-0.017500000000000012},"p2":{"x":91,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"92","x":"401","y":"575","zOrder":"32"},{"ID":"2080","h":"8","measuredH":"7","measuredW":"85","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.35250000000000004,"y":-0.01750000000000001},"p2":{"x":85,"y":7},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"86","x":"399","y":"567","zOrder":"33"},{"ID":"2081","h":"60","measuredH":"59","measuredW":"95","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.3525,"y":-0.017500000000000036},"p2":{"x":95,"y":59},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"96","x":"398","y":"515","zOrder":"34"},{"ID":"2082","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"223","x":"192","y":"451","zOrder":"35"},{"ID":"2083","measuredH":"23","measuredW":"155","properties":{"bold":"true","size":"15","text":"Process Management"},"typeID":"Label","w":"156","x":"226","y":"460","zOrder":"36"},{"ID":"2084","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"223","x":"192","y":"496","zOrder":"37"},{"ID":"2085","measuredH":"23","measuredW":"184","properties":{"bold":"true","size":"15","text":"Threads and Concurrency"},"typeID":"Label","w":"187","x":"210","y":"506","zOrder":"38"},{"ID":"2086","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"223","x":"192","y":"544","zOrder":"39"},{"ID":"2087","measuredH":"23","measuredW":"58","properties":{"bold":"true","size":"15","text":"Sockets"},"typeID":"Label","w":"66","x":"271","y":"553","zOrder":"40"},{"ID":"2088","children":{"controls":{"control":[{"ID":"0","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"23","measuredW":"119","properties":{"bold":"true","size":"15","text":"Memory/Storage"},"typeID":"Label","w":"123","x":"37","y":"8","zOrder":"1"}]}},"h":"40","measuredH":"40","measuredW":"200","typeID":"__group__","w":"200","x":"933","y":"576","zOrder":"41"},{"ID":"2089","children":{"controls":{"control":[{"ID":"0","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"23","measuredW":"120","properties":{"bold":"true","size":"15","text":"I/O Management"},"typeID":"Label","w":"123","x":"39","y":"9","zOrder":"1"}]}},"h":"40","measuredH":"40","measuredW":"200","typeID":"__group__","w":"200","x":"933","y":"486","zOrder":"42"},{"ID":"2090","children":{"controls":{"control":[{"ID":"0","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"23","measuredW":"95","properties":{"bold":"true","size":"15","text":"Virtualization"},"typeID":"Label","w":"102","x":"49","y":"9","zOrder":"1"}]}},"h":"40","measuredH":"40","measuredW":"200","typeID":"__group__","w":"200","x":"933","y":"531","zOrder":"43"},{"ID":"2091","children":{"controls":{"control":[{"ID":"0","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"23","measuredW":"93","properties":{"bold":"true","size":"15","text":"File Systems"},"typeID":"Label","w":"104","x":"53","y":"8","zOrder":"1"}]}},"h":"40","measuredH":"40","measuredW":"200","typeID":"__group__","w":"200","x":"933","y":"621","zOrder":"44"},{"ID":"2092","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"222","x":"193","y":"639","zOrder":"45"},{"ID":"2093","measuredH":"23","measuredW":"153","properties":{"bold":"true","size":"15","text":"Networking Concepts"},"typeID":"Label","w":"156","x":"226","y":"649","zOrder":"46"},{"ID":"2094","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"222","x":"193","y":"589","zOrder":"47"},{"ID":"2095","measuredH":"23","measuredW":"100","properties":{"bold":"true","size":"15","text":"POSIX Basics"},"typeID":"Label","w":"102","x":"253","y":"599","zOrder":"48"},{"ID":"2096","h":"54","measuredH":"53","measuredW":"42","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5684273538382603,"y":-0.01687523160685284},"p2":{"x":42,"y":53},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"43","x":"953","y":"1551","zOrder":"49"},{"ID":"2097","h":"65","measuredH":"64","measuredW":"43","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":43,"y":0},"p1":{"x":0.56842735383826,"y":-0.0168752316068528},"p2":{"x":0,"y":64},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"44","x":"900","y":"1541","zOrder":"50"},{"ID":"2098","h":"60","measuredH":"60","measuredW":"202","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.6469975327179537,"y":0.1075014446130803},"p2":{"x":202,"y":60},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"202","x":"978","y":"1464","zOrder":"51"},{"ID":"2099","h":"4","measuredH":"4","measuredW":"184","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5602565472016198,"y":0.008192419689672631},"p2":{"x":184,"y":3.5},"rightArrow":"false"},"typeID":"Arrow","w":"184","x":"518","y":"2110","zOrder":"52"},{"ID":"2100","h":"48","measuredH":"47","measuredW":"70","properties":{"color":"2848996","leftArrow":"false","p0":{"x":70,"y":45},"p1":{"x":0.5073725600337035,"y":0.26414829377896404},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"70","x":"211","y":"2057","zOrder":"53"},{"ID":"2101","h":"57","measuredH":"57","measuredW":"42","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":41.6666666666672,"y":0},"p1":{"x":0.5941112538286724,"y":0.04050983104436302},"p2":{"x":0,"y":56.66666666666674},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"42","x":"656","y":"1951","zOrder":"54"},{"ID":"2102","h":"282","measuredH":"281","measuredW":"49","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":281},"p1":{"x":0.4804581786141355,"y":-0.13676128138964064},"p2":{"x":22,"y":0},"rightArrow":"false"},"typeID":"Arrow","w":"50","x":"425","y":"1813","zOrder":"55"},{"ID":"2103","h":"1","measuredH":"2","measuredW":"43","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":42.66666666666663,"y":1.328384025265565},"p1":{"x":0.5684273538382602,"y":-0.016875231606852725},"p2":{"x":0,"y":0.383271768326493},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"43","x":"652","y":"1935","zOrder":"56"},{"ID":"2104","h":"43","measuredH":"43","measuredW":"39","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":39,"y":43},"p1":{"x":0.5684273538382602,"y":-0.016875231606852777},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"39","x":"655","y":"1892","zOrder":"57"},{"ID":"2105","h":"34","measuredH":"34","measuredW":"40","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":33.66666666666674},"p1":{"x":0.4988,"y":0.031599999999999955},"p2":{"x":39.41051612824472,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"39","x":"655","y":"1942","zOrder":"58"},{"ID":"2106","h":"125","measuredH":"126","measuredW":"21","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":20.33333333333337,"y":125.33333333333326},"p1":{"x":0.5684273538382596,"y":-0.016875231606852812},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"20","x":"753","y":"1803","zOrder":"59"},{"ID":"2107","h":"79","measuredH":"79","measuredW":"64","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":64,"y":78.5},"p1":{"x":0.5684273538382597,"y":-0.016875231606852663},"p2":{"x":0,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"64","x":"1005","y":"1861","zOrder":"60"},{"ID":"2108","h":"72","measuredH":"72","measuredW":"31","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":71.5},"p1":{"x":0.5684273538382596,"y":-0.016875231606852795},"p2":{"x":31,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"31","x":"940","y":"1863","zOrder":"61"},{"ID":"2109","h":"165","measuredH":"166","measuredW":"113","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":112.33333333333326,"y":165.33333333333326},"p1":{"x":0.5684273538382603,"y":-0.016875231606852836},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"112","x":"1051","y":"1800","zOrder":"62"},{"ID":"2110","h":"41","measuredH":"41","measuredW":"113","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":112.33333333333336,"y":40.66666666666674},"p1":{"x":0.5684273538382599,"y":-0.016875231606852725},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"112","x":"751","y":"1813","zOrder":"63"},{"ID":"2111","h":"112","measuredH":"112","measuredW":"105","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":104.33333333333326,"y":111.66666666666674},"p1":{"x":0.5684273538382603,"y":-0.01687523160685287},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"104","x":"1059","y":"1809","zOrder":"64"},{"ID":"2112","h":"72","measuredH":"73","measuredW":"103","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":103,"y":72.33333333333326},"p1":{"x":0.5684273538382603,"y":-0.016875231606852687},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"103","x":"1061","y":"1803","zOrder":"65"},{"ID":"2113","h":"36","measuredH":"36","measuredW":"105","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":104.66666666666674,"y":35.66666666666674},"p1":{"x":0.56842735383826,"y":-0.01687523160685275},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"105","x":"1062","y":"1795","zOrder":"66"},{"ID":"2114","h":"8","measuredH":"9","measuredW":"112","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":112,"y":8.5},"p1":{"x":0.5684273538382604,"y":-0.016875231606852763},"p2":{"x":0,"y":0.3303160195192092},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"112","x":"1058","y":"1787","zOrder":"67"},{"ID":"2115","h":"154","measuredH":"153","measuredW":"5","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":5,"y":153},"p1":{"x":0.3921652300076813,"y":0.00025603823504313615},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"6","x":"1194","y":"795","zOrder":"68"},{"ID":"2116","h":"108","measuredH":"107","measuredW":"3","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":3,"y":107},"p1":{"x":0.39221504625589126,"y":-0.0109966835398848},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"4","x":"1150","y":"795","zOrder":"69"},{"ID":"2117","h":"73","measuredH":"72","measuredW":"5","properties":{"color":"2848996","leftArrow":"false","p0":{"x":5,"y":72},"p1":{"x":0.3433950804737322,"y":0.04300030367446098},"p2":{"x":1,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"6","x":"1094","y":"791","zOrder":"70"},{"ID":"2118","h":"64","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"286","x":"943","y":"932","zOrder":"71"},{"ID":"2119","measuredH":"23","measuredW":"199","properties":{"bold":"true","size":"15","text":"Compiling apps from source"},"typeID":"Label","w":"204","x":"984","y":"941","zOrder":"72"},{"ID":"2120","h":"41","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"188","x":"943","y":"845","zOrder":"73"},{"ID":"2121","measuredH":"23","measuredW":"151","properties":{"bold":"true","size":"15","text":"Learn Bash Scripting"},"typeID":"Label","w":"153","x":"961","y":"854","zOrder":"74"},{"ID":"2122","measuredH":"23","measuredW":"251","properties":{"bold":"true","size":"15","text":"(gcc, make and other related stuff)"},"typeID":"Label","w":"255","x":"959","y":"961","zOrder":"75"},{"ID":"2123","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"230","x":"943","y":"889","zOrder":"76"},{"ID":"2124","measuredH":"23","measuredW":"207","properties":{"bold":"true","size":"15","text":"Vim/Nano/PowerShell/Emacs"},"typeID":"Label","w":"211","x":"953","y":"897","zOrder":"77"},{"ID":"2125","h":"104","measuredH":"140","measuredW":"200","typeID":"TextArea","w":"270","x":"668","y":"845","zOrder":"78"},{"ID":"2126","h":"40","measuredH":"140","measuredW":"200","properties":{"borderColor":"16777215","color":"16770457"},"typeID":"TextArea","w":"218","x":"699","y":"851","zOrder":"79"},{"ID":"2127","measuredH":"23","measuredW":"165","properties":{"bold":"true","size":"15","text":"Text Manipulation Tools"},"typeID":"Label","w":"169","x":"723","y":"861","zOrder":"80"},{"ID":"2128","measuredH":"22","measuredW":"224","properties":{"bold":"true","size":"14","text":"awk, sed, grep, sort, uniq, cat, cut"},"typeID":"Label","w":"231","x":"692","y":"894","zOrder":"81"},{"ID":"2129","measuredH":"22","measuredW":"208","properties":{"bold":"true","size":"14","text":"echo, fmt, tr, nl, egrep, fgrep, wc"},"typeID":"Label","w":"228","x":"694","y":"917","zOrder":"82"},{"ID":"2130","h":"78","measuredH":"140","measuredW":"200","typeID":"TextArea","w":"268","x":"670","y":"953","zOrder":"83"},{"ID":"2131","h":"40","measuredH":"140","measuredW":"200","properties":{"borderColor":"16777215","color":"16770457"},"typeID":"TextArea","w":"218","x":"704","y":"956","zOrder":"84"},{"ID":"2132","measuredH":"23","measuredW":"138","properties":{"bold":"true","size":"15","text":"Process Monitoring"},"typeID":"Label","w":"169","x":"727","y":"966","zOrder":"85"},{"ID":"2133","measuredH":"22","measuredW":"146","properties":{"bold":"true","size":"14","text":"ps, top, htop, atop, lsof"},"typeID":"Label","w":"159","x":"735","y":"999","zOrder":"86"},{"ID":"2134","h":"78","measuredH":"140","measuredW":"200","typeID":"TextArea","w":"285","x":"944","y":"1000","zOrder":"87"},{"ID":"2135","h":"40","measuredH":"140","measuredW":"200","properties":{"borderColor":"16777215","color":"16770457"},"typeID":"TextArea","w":"218","x":"978","y":"1004","zOrder":"88"},{"ID":"2136","measuredH":"23","measuredW":"152","properties":{"bold":"true","size":"15","text":"System Performance"},"typeID":"Label","w":"169","x":"1002","y":"1014","zOrder":"89"},{"ID":"2137","measuredH":"22","measuredW":"163","properties":{"bold":"true","size":"14","text":"nmon, iostat, sar, vmstat"},"typeID":"Label","w":"172","x":"1001","y":"1047","zOrder":"90"},{"ID":"2138","h":"126","measuredH":"140","measuredW":"200","typeID":"TextArea","w":"302","x":"636","y":"1036","zOrder":"91"},{"ID":"2139","h":"40","measuredH":"140","measuredW":"200","properties":{"borderColor":"16777215","color":"16770457"},"typeID":"TextArea","w":"218","x":"678","y":"1050","zOrder":"92"},{"ID":"2140","measuredH":"23","measuredW":"59","properties":{"bold":"true","size":"15","text":"Network"},"typeID":"Label","w":"68","x":"753","y":"1060","zOrder":"93"},{"ID":"2141","measuredH":"22","measuredW":"266","properties":{"bold":"true","size":"14","text":"nmap, tcpdump, ping, mtr, traceroute, dig"},"typeID":"Label","x":"653","y":"1097","zOrder":"94"},{"ID":"2142","measuredH":"22","measuredW":"228","properties":{"bold":"true","size":"14","text":"airmon, airodump, iptables, netstat"},"typeID":"Label","x":"664","y":"1119","zOrder":"95"},{"ID":"2143","h":"78","measuredH":"140","measuredW":"200","typeID":"TextArea","w":"285","x":"944","y":"1083","zOrder":"96"},{"ID":"2144","h":"40","measuredH":"140","measuredW":"200","properties":{"borderColor":"16777215","color":"16770457"},"typeID":"TextArea","w":"76","x":"955","y":"1101","zOrder":"97"},{"ID":"2145","measuredH":"23","measuredW":"50","properties":{"bold":"true","size":"15","text":"Others"},"typeID":"Label","x":"967","y":"1110","zOrder":"98"},{"ID":"2146","measuredH":"22","measuredW":"171","properties":{"bold":"true","size":"14","text":"strace, dtrace, systemtap"},"typeID":"Label","w":"172","x":"1042","y":"1100","zOrder":"99"},{"ID":"2147","measuredH":"22","measuredW":"116","properties":{"bold":"true","size":"14","text":"uname, df, history"},"typeID":"Label","w":"172","x":"1042","y":"1120","zOrder":"100"},{"ID":"2148","h":"12","measuredH":"12","measuredW":"118","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":118,"y":0},"p1":{"x":0.5684273538382598,"y":-0.016875231606852746},"p2":{"x":0,"y":12},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"118","x":"751","y":"1794","zOrder":"101"},{"ID":"2149","h":"226","measuredH":"226","measuredW":"97","properties":{"color":"2848996","leftArrow":"false","p0":{"x":97,"y":226},"p1":{"x":0.48668227841703593,"y":0.17571642771703422},"p2":{"x":6,"y":0},"rightArrow":"false"},"typeID":"Arrow","w":"97","x":"346","y":"1562","zOrder":"102"},{"ID":"2150","h":"46","measuredH":"46","measuredW":"23","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5684273538382602,"y":-0.01687523160685285},"p2":{"x":23,"y":46},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"23","x":"236","y":"1566","zOrder":"103"},{"ID":"2151","h":"108","measuredH":"108","measuredW":"411","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":411,"y":10},"p1":{"x":0.6352396370618576,"y":-0.14317232031926508},"p2":{"x":0,"y":108},"rightArrow":"false"},"typeID":"Arrow","w":"411","x":"299","y":"1441","zOrder":"104"},{"ID":"2152","h":"55","measuredH":"54","measuredW":"207","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":207,"y":0},"p1":{"x":0.6815856777493605,"y":-0.0997442455242967},"p2":{"x":0,"y":54},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"208","x":"509","y":"1465","zOrder":"105"},{"ID":"2153","h":"54","measuredH":"53","measuredW":"42","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5684273538382603,"y":-0.01687523160685284},"p2":{"x":42,"y":53},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"43","x":"693","y":"1551","zOrder":"106"},{"ID":"2154","h":"65","measuredH":"64","measuredW":"43","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":43,"y":0},"p1":{"x":0.56842735383826,"y":-0.0168752316068528},"p2":{"x":0,"y":64},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"44","x":"640","y":"1541","zOrder":"107"},{"ID":"2155","h":"70","measuredH":"69","measuredW":"36","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":36,"y":0},"p1":{"x":0.56842735383826,"y":-0.016875231606852722},"p2":{"x":0,"y":69},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"37","x":"759","y":"1463","zOrder":"108"},{"ID":"2156","h":"66","measuredH":"65","measuredW":"2","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":1,"y":0},"p1":{"x":0.56842735383826,"y":-0.01687523160685271},"p2":{"x":2,"y":65},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"3","x":"1179","y":"1546","zOrder":"109"},{"ID":"2157","h":"45","measuredH":"45","measuredW":"32","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5684273538382599,"y":-0.01687523160685271},"p2":{"x":32,"y":45},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"32","x":"927","y":"1479","zOrder":"110"},{"ID":"2158","children":{"controls":{"control":[{"ID":"0","h":"51","measuredH":"51","measuredW":"0","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":50.5},"p1":{"x":0.4034892942109438,"y":-0.01554321966693101},"p2":{"x":0,"y":-0.5},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"1","x":"55","y":"68","zOrder":"0"},{"ID":"1","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"112","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"23","measuredW":"31","properties":{"bold":"true","size":"15","text":"DNS"},"typeID":"Label","w":"35","x":"38","y":"9","zOrder":"2"},{"ID":"3","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"112","x":"0","y":"44","zOrder":"3"},{"ID":"4","measuredH":"23","measuredW":"74","properties":{"bold":"true","size":"15","text":"OSI Model"},"typeID":"Label","x":"18","y":"53","zOrder":"4"}]}},"h":"119","measuredH":"119","measuredW":"112","typeID":"__group__","w":"112","x":"246","y":"923","zOrder":"111"},{"ID":"2159","children":{"controls":{"control":[{"ID":"0","h":"63","measuredH":"63","measuredW":"1","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":1,"y":63},"p1":{"x":0.521922991319831,"y":0.015579790785666594},"p2":{"x":1,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"1","x":"68","y":"0","zOrder":"0"},{"ID":"1","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"150","x":"1","y":"38","zOrder":"1"},{"ID":"2","measuredH":"23","measuredW":"40","properties":{"bold":"true","size":"15","text":"HTTP"},"typeID":"Label","w":"45","x":"53","y":"47","zOrder":"2"},{"ID":"3","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"150","x":"1","y":"82","zOrder":"3"},{"ID":"4","measuredH":"23","measuredW":"50","properties":{"bold":"true","size":"15","text":"HTTPS"},"typeID":"Label","w":"52","x":"50","y":"91","zOrder":"4"},{"ID":"5","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"151","x":"0","y":"126","zOrder":"5"},{"ID":"6","measuredH":"23","measuredW":"29","properties":{"bold":"true","size":"15","text":"FTP"},"typeID":"Label","w":"30","x":"61","y":"135","zOrder":"6"},{"ID":"7","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"151","x":"0","y":"170","zOrder":"7"},{"ID":"8","measuredH":"23","measuredW":"73","properties":{"bold":"true","size":"15","text":"SSL / TLS"},"typeID":"Label","w":"74","x":"39","y":"179","zOrder":"8"},{"ID":"9","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"151","x":"0","y":"214","zOrder":"9"},{"ID":"10","measuredH":"23","measuredW":"31","properties":{"bold":"true","size":"15","text":"SSH"},"typeID":"Label","w":"33","x":"59","y":"223","zOrder":"10"},{"ID":"11","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"152","x":"0","y":"258","zOrder":"11"},{"ID":"12","measuredH":"23","measuredW":"112","properties":{"bold":"true","size":"15","text":"Port Forwarding"},"typeID":"Label","w":"113","x":"19","y":"267","zOrder":"12"}]}},"h":"298","measuredH":"298","measuredW":"152","typeID":"__group__","w":"152","x":"232","y":"1070","zOrder":"112"},{"ID":"2160","h":"58","measuredH":"58","measuredW":"215","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.6660415435106101,"y":0.10479646125935138},"p2":{"x":215,"y":58},"rightArrow":"false"},"typeID":"Arrow","w":"215","x":"853","y":"724","zOrder":"113"},{"ID":"2161","h":"57","measuredH":"56","measuredW":"2","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":2,"y":0},"p1":{"x":0.35250000000000015,"y":-0.017499999999999967},"p2":{"x":1,"y":56},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"3","x":"311","y":"729","zOrder":"114"},{"ID":"2162","h":"220","measuredH":"219","measuredW":"149","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4950543028990049,"y":0.1974288076166585},"p2":{"x":149,"y":219},"rightArrow":"false"},"typeID":"Arrow","w":"149","x":"682","y":"1230","zOrder":"115"},{"ID":"2163","h":"96","measuredH":"95","measuredW":"83","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.3999439854362135,"y":-0.036969612099145746},"p2":{"x":83,"y":95},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"84","x":"1010","y":"1290","zOrder":"116"},{"ID":"2164","h":"60","measuredH":"59","measuredW":"75","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.39994398543621346,"y":-0.03696961209914577},"p2":{"x":75,"y":59},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"76","x":"1016","y":"1280","zOrder":"117"},{"ID":"2165","h":"16","measuredH":"15","measuredW":"71","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.3488372093023254,"y":0.005813953488372056},"p2":{"x":71,"y":15},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"72","x":"1020","y":"1274","zOrder":"118"},{"ID":"2166","h":"19","measuredH":"18","measuredW":"74","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":18},"p1":{"x":0.348837209302325,"y":0.005813953488372172},"p2":{"x":74,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"75","x":"1010","y":"1248","zOrder":"119"},{"ID":"2167","h":"130","measuredH":"129","measuredW":"160","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4699936081058687,"y":-0.10231765346464336},"p2":{"x":160,"y":129},"rightArrow":"false"},"typeID":"Arrow","w":"161","x":"434","y":"1075","zOrder":"120"},{"ID":"2168","h":"260","measuredH":"260","measuredW":"166","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":164,"y":-0.5},"p1":{"x":0.46455424481946656,"y":0.17574311799322478},"p2":{"x":0,"y":259},"rightArrow":"false"},"typeID":"Arrow","w":"166","x":"438","y":"801","zOrder":"121"},{"ID":"2169","h":"4","measuredH":"3","measuredW":"146","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.35159873077861853,"y":-0.002318769831584085},"p2":{"x":146,"y":3},"rightArrow":"false"},"typeID":"Arrow","w":"147","x":"347","y":"722","zOrder":"122"},{"ID":"2170","h":"127","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"386","x":"481","y":"686","zOrder":"123"},{"ID":"2171","measuredH":"25","measuredW":"248","properties":{"bold":"true","size":"17","text":"Learn about Managing Servers"},"typeID":"Label","x":"549","y":"701","zOrder":"124"},{"ID":"2172","measuredH":"23","measuredW":"351","properties":{"size":"15","text":"Get some administration knowledge in some OS. Go"},"typeID":"Label","x":"498","y":"728","zOrder":"125"},{"ID":"2173","measuredH":"23","measuredW":"368","properties":{"size":"15","text":"with any Linux distro. Pick Ubuntu if you have a little to"},"typeID":"Label","w":"352","x":"498","y":"752","zOrder":"126"},{"ID":"2174","measuredH":"23","measuredW":"172","properties":{"size":"15","text":"no experience with Linux."},"typeID":"Label","w":"183","x":"582","y":"777","zOrder":"127"},{"ID":"2175","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"114","x":"250","y":"775","zOrder":"128"},{"ID":"2176","measuredH":"23","measuredW":"37","properties":{"bold":"true","size":"15","text":"Linux"},"typeID":"Label","w":"38","x":"291","y":"784","zOrder":"129"},{"ID":"2177","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"113","x":"250","y":"820","zOrder":"130"},{"ID":"2178","measuredH":"23","measuredW":"31","properties":{"bold":"true","size":"15","text":"Unix"},"typeID":"Label","w":"35","x":"292","y":"829","zOrder":"131"},{"ID":"2179","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"112","x":"251","y":"864","zOrder":"132"},{"ID":"2180","measuredH":"23","measuredW":"63","properties":{"bold":"true","size":"15","text":"Windows"},"typeID":"Label","w":"67","x":"274","y":"873","zOrder":"133"},{"ID":"2181","h":"49","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"364","x":"92","y":"1031","zOrder":"134"},{"ID":"2182","measuredH":"25","measuredW":"284","properties":{"bold":"true","size":"17","text":"Networking, Security and Protocols"},"typeID":"Label","x":"133","y":"1043","zOrder":"135"},{"ID":"2183","h":"49","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"386","x":"400","y":"1194","zOrder":"136"},{"ID":"2184","measuredH":"25","measuredW":"325","properties":{"bold":"true","size":"17","text":"What is and how to setup a ____________"},"typeID":"Label","w":"337","x":"426","y":"1206","zOrder":"137"},{"ID":"2185","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"161","x":"858","y":"1258","zOrder":"138"},{"ID":"2186","measuredH":"23","measuredW":"84","properties":{"bold":"true","size":"15","text":"Web Server"},"typeID":"Label","x":"894","y":"1267","zOrder":"139"},{"ID":"2187","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"144","x":"402","y":"1320","zOrder":"140"},{"ID":"2188","measuredH":"23","measuredW":"101","properties":{"bold":"true","size":"15","text":"Forward Proxy"},"typeID":"Label","w":"108","x":"423","y":"1329","zOrder":"141"},{"ID":"2189","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"161","x":"552","y":"1277","zOrder":"142"},{"ID":"2190","measuredH":"23","measuredW":"110","properties":{"bold":"true","size":"15","text":"Caching Server"},"typeID":"Label","w":"110","x":"578","y":"1286","zOrder":"143"},{"ID":"2191","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"102","x":"1085","y":"1273","zOrder":"144"},{"ID":"2192","measuredH":"23","measuredW":"54","properties":{"bold":"true","size":"15","text":"Apache"},"typeID":"Label","w":"64","x":"1107","y":"1282","zOrder":"145"},{"ID":"2193","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"104","x":"1085","y":"1228","zOrder":"146"},{"ID":"2194","measuredH":"23","measuredW":"39","properties":{"bold":"true","size":"15","text":"Nginx"},"typeID":"Label","w":"43","x":"1116","y":"1237","zOrder":"147"},{"ID":"2195","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"104","x":"1084","y":"1317","zOrder":"148"},{"ID":"2196","measuredH":"23","measuredW":"53","properties":{"bold":"true","size":"15","text":"Tomcat"},"typeID":"Label","w":"57","x":"1109","y":"1326","zOrder":"149"},{"ID":"2197","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"104","x":"1086","y":"1362","zOrder":"150"},{"ID":"2198","measuredH":"23","measuredW":"45","properties":{"bold":"true","size":"15","text":"Caddy"},"typeID":"Label","w":"49","x":"1114","y":"1371","zOrder":"151"},{"ID":"2199","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"104","x":"1085","y":"1183","zOrder":"152"},{"ID":"2200","measuredH":"23","measuredW":"21","properties":{"bold":"true","size":"15","text":"IIS"},"typeID":"Label","w":"29","x":"1123","y":"1192","zOrder":"153"},{"ID":"2201","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"143","x":"403","y":"1276","zOrder":"154"},{"ID":"2202","measuredH":"23","measuredW":"102","properties":{"bold":"true","size":"15","text":"Reverse Proxy"},"typeID":"Label","w":"119","x":"416","y":"1285","zOrder":"155"},{"ID":"2203","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"161","x":"551","y":"1320","zOrder":"156"},{"ID":"2204","measuredH":"23","measuredW":"105","properties":{"bold":"true","size":"15","text":"Load Balancer"},"typeID":"Label","w":"110","x":"577","y":"1329","zOrder":"157"},{"ID":"2205","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"311","x":"402","y":"1365","zOrder":"158"},{"ID":"2206","measuredH":"23","measuredW":"53","properties":{"bold":"true","size":"15","text":"Firewall"},"typeID":"Label","w":"60","x":"528","y":"1374","zOrder":"159"},{"ID":"2207","h":"49","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"311","x":"693","y":"1432","zOrder":"160"},{"ID":"2208","measuredH":"25","measuredW":"240","properties":{"bold":"true","size":"17","text":"Learn Infrastructure as Code"},"typeID":"Label","x":"728","y":"1443","zOrder":"161"},{"ID":"2209","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","x":"215","y":"704","zOrder":"162"},{"ID":"2210","measuredH":"23","measuredW":"129","properties":{"bold":"true","size":"15","text":"Operating System"},"typeID":"Label","w":"130","x":"250","y":"713","zOrder":"163"},{"ID":"2211","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"216","x":"1004","y":"761","zOrder":"164"},{"ID":"2212","measuredH":"23","measuredW":"171","properties":{"bold":"true","size":"15","text":"Learn to live in Terminal"},"typeID":"Label","x":"1026","y":"770","zOrder":"165"},{"ID":"2213","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"253","x":"1060","y":"1516","zOrder":"166"},{"ID":"2214","measuredH":"25","measuredW":"217","properties":{"bold":"true","size":"17","text":"Infrastructure Provisioning"},"typeID":"Label","x":"1081","y":"1524","zOrder":"167"},{"ID":"2215","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"152","x":"1103","y":"1577","zOrder":"168"},{"ID":"2216","measuredH":"23","measuredW":"71","properties":{"bold":"true","size":"15","text":"Terraform"},"typeID":"Label","w":"75","x":"1141","y":"1586","zOrder":"169"},{"ID":"2217","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"152","x":"1103","y":"1621","zOrder":"170"},{"ID":"2218","measuredH":"23","measuredW":"112","properties":{"bold":"true","size":"15","text":"CloudFormation"},"typeID":"Label","x":"1122","y":"1630","zOrder":"171"},{"ID":"2219","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"253","x":"571","y":"1515","zOrder":"172"},{"ID":"2220","measuredH":"25","measuredW":"217","properties":{"bold":"true","size":"17","text":"Configuration Management"},"typeID":"Label","x":"590","y":"1523","zOrder":"173"},{"ID":"2221","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"116","x":"577","y":"1595","zOrder":"174"},{"ID":"2222","measuredH":"23","measuredW":"52","properties":{"bold":"true","size":"15","text":"Ansible"},"typeID":"Label","w":"59","x":"606","y":"1604","zOrder":"175"},{"ID":"2223","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"116","x":"577","y":"1638","zOrder":"176"},{"ID":"2224","measuredH":"23","measuredW":"36","properties":{"bold":"true","size":"15","text":"Chef"},"typeID":"Label","w":"48","x":"611","y":"1648","zOrder":"177"},{"ID":"2225","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"107","x":"696","y":"1638","zOrder":"178"},{"ID":"2226","measuredH":"23","measuredW":"52","properties":{"bold":"true","size":"15","text":"Puppet"},"typeID":"Label","x":"726","y":"1647","zOrder":"179"},{"ID":"2227","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"107","x":"697","y":"1595","zOrder":"180"},{"ID":"2228","measuredH":"23","measuredW":"29","properties":{"bold":"true","size":"15","text":"Salt"},"typeID":"Label","w":"51","x":"731","y":"1604","zOrder":"181"},{"ID":"2229","h":"49","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"311","x":"65","y":"1529","zOrder":"182"},{"ID":"2230","measuredH":"25","measuredW":"189","properties":{"bold":"true","size":"17","text":"Learn some CI/CD Tool"},"typeID":"Label","x":"126","y":"1541","zOrder":"183"},{"ID":"2231","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"124","x":"203","y":"1600","zOrder":"184"},{"ID":"2232","measuredH":"23","measuredW":"54","properties":{"bold":"true","size":"15","text":"Jenkins"},"typeID":"Label","w":"59","x":"235","y":"1609","zOrder":"185"},{"ID":"2233","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"124","x":"203","y":"1643","zOrder":"186"},{"ID":"2234","measuredH":"23","measuredW":"63","properties":{"bold":"true","size":"15","text":"Travis CI"},"typeID":"Label","w":"65","x":"232","y":"1652","zOrder":"187"},{"ID":"2235","h":"58","measuredH":"57","measuredW":"1","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":1,"y":0},"p1":{"x":0.56842735383826,"y":-0.016875231606852763},"p2":{"x":1,"y":57},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"2","x":"487","y":"1541","zOrder":"188"},{"ID":"2236","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"139","x":"425","y":"1515","zOrder":"189"},{"ID":"2237","measuredH":"25","measuredW":"89","properties":{"bold":"true","size":"17","text":"Containers"},"typeID":"Label","x":"450","y":"1523","zOrder":"190"},{"ID":"2238","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"116","x":"425","y":"1595","zOrder":"191"},{"ID":"2239","measuredH":"23","measuredW":"51","properties":{"bold":"true","size":"15","text":"Docker"},"typeID":"Label","w":"59","x":"454","y":"1604","zOrder":"192"},{"ID":"2242","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"116","x":"425","y":"1639","zOrder":"193"},{"ID":"2243","measuredH":"23","measuredW":"30","properties":{"bold":"true","size":"15","text":"LXC"},"typeID":"Label","w":"38","x":"469","y":"1648","zOrder":"194"},{"ID":"2244","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"125","x":"202","y":"1687","zOrder":"195"},{"ID":"2245","measuredH":"23","measuredW":"68","properties":{"bold":"true","size":"15","text":"TeamCity"},"typeID":"Label","x":"229","y":"1696","zOrder":"196"},{"ID":"2246","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"125","x":"202","y":"1732","zOrder":"197"},{"ID":"2247","measuredH":"23","measuredW":"63","properties":{"bold":"true","size":"15","text":"Circle CI"},"typeID":"Label","w":"65","x":"232","y":"1740","zOrder":"198"},{"ID":"2248","h":"49","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"453","x":"319","y":"1786","zOrder":"199"},{"ID":"2249","measuredH":"25","measuredW":"402","properties":{"bold":"true","size":"17","text":"Learn how to monitor software and infrastructure"},"typeID":"Label","x":"347","y":"1798","zOrder":"200"},{"ID":"2250","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"206","x":"861","y":"1774","zOrder":"201"},{"ID":"2251","measuredH":"23","measuredW":"181","properties":{"bold":"true","size":"15","text":"Infrastructure Monitoring"},"typeID":"Label","w":"185","x":"873","y":"1783","zOrder":"202"},{"ID":"2252","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"130","x":"1161","y":"1773","zOrder":"203"},{"ID":"2253","measuredH":"23","measuredW":"48","properties":{"bold":"true","size":"15","text":"Nagios"},"typeID":"Label","x":"1201","y":"1782","zOrder":"204"},{"ID":"2254","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"130","x":"1161","y":"1817","zOrder":"205"},{"ID":"2255","measuredH":"23","measuredW":"57","properties":{"bold":"true","size":"15","text":"Grafana"},"typeID":"Label","x":"1197","y":"1826","zOrder":"206"},{"ID":"2256","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"130","x":"1160","y":"1948","zOrder":"207"},{"ID":"2257","measuredH":"23","measuredW":"60","properties":{"bold":"true","size":"15","text":"Datadog"},"typeID":"Label","x":"1194","y":"1957","zOrder":"208"},{"ID":"2258","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"129","x":"1161","y":"1861","zOrder":"209"},{"ID":"2259","measuredH":"23","measuredW":"48","properties":{"bold":"true","size":"15","text":"Zabbix"},"typeID":"Label","x":"1201","y":"1870","zOrder":"210"},{"ID":"2260","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"206","x":"855","y":"1840","zOrder":"211"},{"ID":"2261","measuredH":"23","measuredW":"158","properties":{"bold":"true","size":"15","text":"Application Monitoring"},"typeID":"Label","w":"185","x":"868","y":"1849","zOrder":"212"},{"ID":"2262","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"129","x":"1161","y":"1904","zOrder":"213"},{"ID":"2263","measuredH":"23","measuredW":"40","properties":{"bold":"true","size":"15","text":"Monit"},"typeID":"Label","w":"41","x":"1205","y":"1913","zOrder":"214"},{"ID":"2264","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"127","x":"892","y":"1924","zOrder":"215"},{"ID":"2265","measuredH":"23","measuredW":"50","properties":{"bold":"true","size":"15","text":"Jaeger"},"typeID":"Label","x":"930","y":"1933","zOrder":"216"},{"ID":"2266","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"92","x":"1026","y":"1924","zOrder":"217"},{"ID":"2267","measuredH":"23","measuredW":"71","properties":{"bold":"true","size":"15","text":"New Relic"},"typeID":"Label","x":"1036","y":"1933","zOrder":"218"},{"ID":"2268","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"189","x":"691","y":"1925","zOrder":"219"},{"ID":"2269","measuredH":"23","measuredW":"131","properties":{"bold":"true","size":"15","text":"Logs Management"},"typeID":"Label","x":"720","y":"1933","zOrder":"220"},{"ID":"2270","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"149","x":"508","y":"1871","zOrder":"221"},{"ID":"2271","measuredH":"23","measuredW":"95","properties":{"bold":"true","size":"15","text":"Elastic Stack"},"typeID":"Label","x":"536","y":"1880","zOrder":"222"},{"ID":"2272","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"149","x":"509","y":"1915","zOrder":"223"},{"ID":"2273","measuredH":"23","measuredW":"54","properties":{"bold":"true","size":"15","text":"Graylog"},"typeID":"Label","w":"59","x":"550","y":"1924","zOrder":"224"},{"ID":"2274","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"149","x":"509","y":"1959","zOrder":"225"},{"ID":"2275","measuredH":"23","measuredW":"47","properties":{"bold":"true","size":"15","text":"Splunk"},"typeID":"Label","w":"53","x":"558","y":"1967","zOrder":"226"},{"ID":"2276","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"149","x":"510","y":"2003","zOrder":"227"},{"ID":"2277","measuredH":"23","measuredW":"69","properties":{"bold":"true","size":"15","text":"Papertrail"},"typeID":"Label","w":"79","x":"549","y":"2011","zOrder":"228"},{"ID":"2278","h":"49","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"258","x":"268","y":"2087","zOrder":"229"},{"ID":"2279","measuredH":"25","measuredW":"127","properties":{"bold":"true","size":"17","text":"Cloud Providers"},"typeID":"Label","x":"333","y":"2099","zOrder":"230"},{"ID":"2280","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"149","x":"129","y":"1848","zOrder":"231"},{"ID":"2281","measuredH":"23","measuredW":"34","properties":{"bold":"true","size":"15","text":"AWS"},"typeID":"Label","w":"43","x":"182","y":"1857","zOrder":"232"},{"ID":"2282","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"149","x":"129","y":"1892","zOrder":"233"},{"ID":"2283","measuredH":"23","measuredW":"95","properties":{"bold":"true","size":"15","text":"Google Cloud"},"typeID":"Label","w":"100","x":"154","y":"1901","zOrder":"234"},{"ID":"2284","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"149","x":"129","y":"1936","zOrder":"235"},{"ID":"2285","measuredH":"23","measuredW":"42","properties":{"bold":"true","size":"15","text":"Azure"},"typeID":"Label","w":"47","x":"180","y":"1945","zOrder":"236"},{"ID":"2286","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"149","x":"126","y":"2166","zOrder":"237"},{"ID":"2287","measuredH":"23","measuredW":"97","properties":{"bold":"true","size":"15","text":"Digital Ocean"},"typeID":"Label","w":"99","x":"154","y":"2175","zOrder":"238"},{"ID":"2288","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"149","x":"129","y":"1980","zOrder":"239"},{"ID":"2289","measuredH":"23","measuredW":"51","properties":{"bold":"true","size":"15","text":"Heroku"},"typeID":"Label","w":"66","x":"171","y":"1988","zOrder":"240"},{"ID":"2290","measuredH":"32","measuredW":"165","properties":{"bold":"true","size":"24","text":"Keep Learning"},"typeID":"Label","x":"671","y":"2271","zOrder":"241"},{"ID":"2291","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"219","x":"833","y":"1515","zOrder":"242"},{"ID":"2292","measuredH":"25","measuredW":"196","properties":{"bold":"true","size":"17","text":"Container Orchestration"},"typeID":"Label","x":"843","y":"1523","zOrder":"243"},{"ID":"2293","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"124","x":"833","y":"1596","zOrder":"244"},{"ID":"2294","measuredH":"23","measuredW":"84","properties":{"bold":"true","size":"15","text":"Kubernetes"},"typeID":"Label","w":"88","x":"851","y":"1605","zOrder":"245"},{"ID":"2295","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"99","x":"963","y":"1597","zOrder":"246"},{"ID":"2296","measuredH":"23","measuredW":"47","properties":{"bold":"true","size":"15","text":"Mesos"},"typeID":"Label","w":"51","x":"984","y":"1606","zOrder":"247"},{"ID":"2297","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"124","x":"833","y":"1639","zOrder":"248"},{"ID":"2298","measuredH":"23","measuredW":"103","properties":{"bold":"true","size":"15","text":"Docker Swarm"},"typeID":"Label","x":"843","y":"1648","zOrder":"249"},{"ID":"2299","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"99","x":"963","y":"1640","zOrder":"250"},{"ID":"2300","measuredH":"23","measuredW":"50","properties":{"bold":"true","size":"15","text":"Nomad"},"typeID":"Label","w":"51","x":"984","y":"1649","zOrder":"251"},{"ID":"2301","h":"131","measuredH":"131","measuredW":"1","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":1,"y":-0.5},"p1":{"x":0.549618320610687,"y":-0.0076335877862595426},"p2":{"x":1,"y":130.5},"rightArrow":"false"},"typeID":"Arrow","w":"1","x":"584","y":"436","zOrder":"252"},{"ID":"2302","h":"97","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"341","x":"482","y":"370","zOrder":"253"},{"ID":"2303","h":"52","measuredH":"51","measuredW":"194","properties":{"color":"2848996","leftArrow":"false","p0":{"x":194,"y":51},"p1":{"x":0.3433950804737322,"y":0.04300030367446101},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"194","x":"806","y":"340","zOrder":"254"},{"ID":"2304","h":"11","measuredH":"11","measuredW":"194","properties":{"color":"2848996","leftArrow":"false","p0":{"x":194,"y":11},"p1":{"x":0.35191347753743757,"y":0.010815307820299498},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"194","x":"809","y":"335","zOrder":"255"},{"ID":"2305","h":"30","measuredH":"30","measuredW":"192","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":192,"y":1},"p1":{"x":0.3789527084155347,"y":-0.03545459669691678},"p2":{"x":0,"y":30},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"192","x":"807","y":"301","zOrder":"256"},{"ID":"2306","h":"41","measuredH":"40","measuredW":"120","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":40},"p1":{"x":0.3525,"y":-0.0175},"p2":{"x":120,"y":0},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"121","x":"381","y":"351","zOrder":"257"},{"ID":"2307","h":"5","measuredH":"4","measuredW":"118","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":4},"p1":{"x":0.3816771970132108,"y":0.01895462377943711},"p2":{"x":118,"y":2},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"119","x":"386","y":"341","zOrder":"258"},{"ID":"2308","h":"34","measuredH":"33","measuredW":"109","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":1},"p1":{"x":0.3586981790003874,"y":0.059434327779930254},"p2":{"x":109,"y":33},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"110","x":"385","y":"300","zOrder":"259"},{"ID":"2309","measuredH":"40","measuredW":"119","properties":{"bold":"true","size":"32","text":"DevOps"},"typeID":"Label","x":"613","y":"139","zOrder":"260"},{"ID":"2310","h":"71","measuredH":"71","measuredW":"13","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":10,"y":0},"p1":{"x":0.46601941747572834,"y":0.1067961165048544},"p2":{"x":0,"y":71},"rightArrow":"false","stroke":"dotted"},"typeID":"Arrow","w":"14","x":"680","y":"64","zOrder":"261"},{"ID":"2311","h":"146","measuredH":"146","measuredW":"40","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":40,"y":0},"p1":{"x":0.5627573858549687,"y":-0.13008057296329453},"p2":{"x":8,"y":146},"rightArrow":"false"},"typeID":"Arrow","w":"40","x":"622","y":"184","zOrder":"262"},{"ID":"2312","h":"53","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"341","x":"482","y":"311","zOrder":"263"},{"ID":"2313","measuredH":"25","measuredW":"255","properties":{"bold":"true","size":"17","text":"Learn a Programming Language"},"typeID":"Label","x":"525","y":"326","zOrder":"264"},{"ID":"2314","h":"41","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"141","x":"257","y":"321","zOrder":"265"},{"ID":"2315","measuredH":"25","measuredW":"40","properties":{"bold":"true","size":"17","text":"Ruby"},"typeID":"Label","w":"45","x":"297","y":"330","zOrder":"266"},{"ID":"2316","h":"41","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"141","x":"257","y":"276","zOrder":"267"},{"ID":"2317","measuredH":"25","measuredW":"56","properties":{"bold":"true","size":"17","text":"Python"},"typeID":"Label","w":"68","x":"296","y":"285","zOrder":"268"},{"ID":"2318","h":"43","measuredH":"140","measuredW":"200","properties":{"color":"16770457","textColor":"16776960"},"typeID":"TextArea","w":"141","x":"257","y":"367","zOrder":"269"},{"ID":"2319","measuredH":"25","measuredW":"61","properties":{"bold":"true","size":"17","text":"Node.js"},"typeID":"Label","w":"68","x":"297","y":"376","zOrder":"270"},{"ID":"2320","children":{"controls":{"control":[{"ID":"0","children":{"controls":{"control":[{"ID":"0","h":"41","measuredH":"140","measuredW":"200","properties":{"color":"16770457","textColor":"16776960"},"typeID":"TextArea","w":"141","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"25","measuredW":"23","properties":{"bold":"true","size":"17","text":"Go"},"typeID":"Label","x":"59","y":"8","zOrder":"1"}]}},"h":"41","measuredH":"41","measuredW":"141","typeID":"__group__","w":"141","x":"0","y":"0","zOrder":"0"}]}},"h":"41","measuredH":"41","measuredW":"141","typeID":"__group__","w":"141","x":"983","y":"281","zOrder":"271"},{"ID":"2321","children":{"controls":{"control":[{"ID":"0","h":"41","measuredH":"140","measuredW":"200","properties":{"color":"16770457","textColor":"16776960"},"typeID":"TextArea","w":"141","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"25","measuredW":"38","properties":{"bold":"true","size":"17","text":"Rust"},"typeID":"Label","x":"51","y":"8","zOrder":"1"}]}},"h":"41","measuredH":"41","measuredW":"141","typeID":"__group__","w":"141","x":"984","y":"326","zOrder":"272"},{"ID":"2322","children":{"controls":{"control":[{"ID":"0","h":"41","measuredH":"140","measuredW":"200","properties":{"color":"16770457","textColor":"16776960"},"typeID":"TextArea","w":"141","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"25","measuredW":"13","properties":{"bold":"true","size":"17","text":"C"},"typeID":"Label","x":"64","y":"8","zOrder":"1"}]}},"h":"41","measuredH":"41","measuredW":"141","typeID":"__group__","w":"141","x":"983","y":"371","zOrder":"273"},{"ID":"2323","measuredH":"25","measuredW":"290","properties":{"size":"17","text":"It doesn't matter which language you "},"typeID":"Label","x":"497","y":"380","zOrder":"274"},{"ID":"2324","measuredH":"25","measuredW":"289","properties":{"size":"17","text":"pick, key is to get some programming"},"typeID":"Label","x":"497","y":"406","zOrder":"275"},{"ID":"2325","measuredH":"25","measuredW":"199","properties":{"size":"17","text":"knowledge for automation"},"typeID":"Label","x":"497","y":"432","zOrder":"276"},{"ID":"2326","h":"141","measuredH":"70","measuredW":"100","typeID":"Canvas","w":"350","x":"883","y":"51","zOrder":"277"},{"ID":"2327","measuredH":"25","measuredW":"314","properties":{"size":"17","text":"Find the detailed version of this roadmap"},"typeID":"Label","x":"897","y":"68","zOrder":"278"},{"ID":"2328","measuredH":"25","measuredW":"322","properties":{"size":"17","text":"along with resources and other roadmaps"},"typeID":"Label","x":"897","y":"96","zOrder":"279"},{"ID":"2329","h":"45","measuredH":"70","measuredW":"100","properties":{"borderColor":"4273622","color":"4273622"},"typeID":"Canvas","w":"320","x":"898","y":"132","zOrder":"280"},{"ID":"2330","children":{"controls":{"control":[{"ID":"0","measuredH":"28","measuredW":"103","properties":{"color":"16777215","size":"20","text":"roadmap.sh"},"typeID":"Label","x":"65","y":"0","zOrder":"0"},{"ID":"1","measuredH":"28","measuredW":"36","properties":{"color":"16777215","size":"20","text":"http"},"typeID":"Label","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"28","measuredW":"10","properties":{"bold":"true","color":"16777215","size":"20","text":":"},"typeID":"Label","x":"37","y":"0","zOrder":"2"},{"ID":"3","measuredH":"28","measuredW":"10","properties":{"color":"16777215","size":"20","text":"/"},"typeID":"Label","x":"44","y":"1","zOrder":"3"},{"ID":"4","measuredH":"28","measuredW":"10","properties":{"color":"16777215","size":"20","text":"/"},"typeID":"Label","x":"52","y":"1","zOrder":"4"}]}},"h":"29","measuredH":"29","measuredW":"168","typeID":"__group__","w":"168","x":"974","y":"140","zOrder":"281"},{"ID":"2331","h":"162","measuredH":"70","measuredW":"100","typeID":"Canvas","w":"408","x":"79","y":"41","zOrder":"282"},{"ID":"2332","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"102","y":"62","zOrder":"283"},{"ID":"2333","measuredH":"24","measuredW":"263","properties":{"size":"16","text":"Personal Recommendation / Opinion"},"typeID":"Label","x":"138","y":"62","zOrder":"284"},{"ID":"2334","measuredH":"24","measuredW":"159","properties":{"size":"16","text":"I wouldn't recommend"},"typeID":"Label","x":"138","y":"159","zOrder":"285"},{"ID":"2335","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"102","y":"159","zOrder":"286"},{"ID":"2336","measuredH":"24","measuredW":"319","properties":{"size":"16","text":"Order in roadmap not strict (Learn anytime)"},"typeID":"Label","w":"324","x":"139","y":"127","zOrder":"287"},{"ID":"2337","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"102","y":"127","zOrder":"288"},{"ID":"2338","measuredH":"24","measuredW":"277","properties":{"size":"16","text":"Alternative Option - Pick this or purple"},"typeID":"Label","x":"138","y":"95","zOrder":"289"},{"ID":"2339","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"102","y":"94","zOrder":"290"},{"ID":"2340","h":"54","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"386","x":"475","y":"543","zOrder":"291"},{"ID":"2341","measuredH":"25","measuredW":"282","properties":{"bold":"true","size":"17","text":"Understand different OS Concepts"},"typeID":"Label","x":"524","y":"558","zOrder":"292"},{"ID":"2342","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"122","x":"404","y":"825","zOrder":"293"},{"ID":"2343","measuredH":"23","measuredW":"63","properties":{"bold":"true","size":"15","text":"FreeBSD"},"typeID":"Label","w":"65","x":"432","y":"834","zOrder":"294"},{"ID":"2344","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"122","x":"404","y":"869","zOrder":"295"},{"ID":"2345","measuredH":"23","measuredW":"69","properties":{"bold":"true","size":"15","text":"OpenBSD"},"typeID":"Label","w":"70","x":"430","y":"878","zOrder":"296"},{"ID":"2346","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"122","x":"404","y":"913","zOrder":"297"},{"ID":"2347","measuredH":"23","measuredW":"57","properties":{"bold":"true","size":"15","text":"NetBSD"},"typeID":"Label","w":"59","x":"435","y":"922","zOrder":"298"},{"ID":"2348","children":{"controls":{"control":[{"ID":"0","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"110","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"23","measuredW":"40","properties":{"bold":"true","size":"15","text":"RHEL"},"typeID":"Label","w":"42","x":"34","y":"9","zOrder":"1"}]}},"h":"40","measuredH":"40","measuredW":"110","typeID":"__group__","w":"110","x":"86","y":"916","zOrder":"299"},{"ID":"2349","children":{"controls":{"control":[{"ID":"0","h":"39","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"110","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"23","measuredW":"57","properties":{"bold":"true","size":"15","text":"CentOS"},"typeID":"Label","w":"58","x":"26","y":"9","zOrder":"1"}]}},"h":"39","measuredH":"39","measuredW":"110","typeID":"__group__","w":"110","x":"86","y":"873","zOrder":"300"},{"ID":"2350","children":{"controls":{"control":[{"ID":"0","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"110","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"23","measuredW":"51","properties":{"bold":"true","size":"15","text":"Ubuntu"},"typeID":"Label","w":"55","x":"27","y":"9","zOrder":"1"}]}},"h":"40","measuredH":"40","measuredW":"110","typeID":"__group__","w":"110","x":"86","y":"829","zOrder":"301"},{"ID":"2351","children":{"controls":{"control":[{"ID":"0","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"110","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"23","measuredW":"49","properties":{"bold":"true","size":"15","text":"Fedora"},"typeID":"Label","w":"52","x":"29","y":"9","zOrder":"1"}]}},"h":"40","measuredH":"40","measuredW":"110","typeID":"__group__","w":"110","x":"86","y":"785","zOrder":"302"},{"ID":"2352","children":{"controls":{"control":[{"ID":"0","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"110","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"23","measuredW":"50","properties":{"bold":"true","size":"15","text":"Debian"},"typeID":"Label","w":"52","x":"29","y":"9","zOrder":"1"}]}},"h":"40","measuredH":"40","measuredW":"110","typeID":"__group__","w":"110","x":"86","y":"741","zOrder":"303"},{"ID":"2353","children":{"controls":{"control":[{"ID":"0","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"110","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"23","measuredW":"82","properties":{"bold":"true","size":"15","text":"SUSE Linux"},"typeID":"Label","w":"84","x":"16","y":"9","zOrder":"1"}]}},"h":"40","measuredH":"40","measuredW":"110","typeID":"__group__","w":"110","x":"86","y":"697","zOrder":"304"},{"ID":"2354","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"137","x":"1146","y":"651","zOrder":"305"},{"ID":"2355","measuredH":"23","measuredW":"35","properties":{"bold":"true","size":"15","text":"tmux"},"typeID":"Label","x":"1197","y":"660","zOrder":"306"},{"ID":"2356","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"137","x":"1146","y":"608","zOrder":"307"},{"ID":"2357","measuredH":"23","measuredW":"50","properties":{"bold":"true","size":"15","text":"screen"},"typeID":"Label","x":"1189","y":"616","zOrder":"308"},{"ID":"2358","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"186","x":"1097","y":"705","zOrder":"309"},{"ID":"2359","measuredH":"23","measuredW":"149","properties":{"bold":"true","size":"15","text":"terminal multiplexers"},"typeID":"Label","x":"1115","y":"713","zOrder":"310"},{"ID":"2360","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"14540253"},"typeID":"TextArea","w":"149","x":"129","y":"2024","zOrder":"311"},{"ID":"2361","measuredH":"23","measuredW":"99","properties":{"bold":"true","color":"6710886","size":"15","text":"Alibaba Cloud"},"typeID":"Label","x":"154","y":"2032","zOrder":"312"},{"ID":"2362","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"149","x":"126","y":"2209","zOrder":"313"},{"ID":"2363","measuredH":"23","measuredW":"48","properties":{"bold":"true","size":"15","text":"Linode"},"typeID":"Label","x":"176","y":"2218","zOrder":"314"},{"ID":"2364","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"149","x":"126","y":"2252","zOrder":"315"},{"ID":"2365","measuredH":"23","measuredW":"34","properties":{"bold":"true","size":"15","text":"Vultr"},"typeID":"Label","x":"183","y":"2261","zOrder":"316"},{"ID":"2366","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"131","x":"68","y":"1599","zOrder":"317"},{"ID":"2367","measuredH":"23","measuredW":"64","properties":{"bold":"true","size":"15","text":"Gitlab CI"},"typeID":"Label","x":"101","y":"1608","zOrder":"318"},{"ID":"2368","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"130","x":"69","y":"1644","zOrder":"319"},{"ID":"2369","measuredH":"23","measuredW":"108","properties":{"bold":"true","size":"15","text":"GitHub Actions"},"typeID":"Label","x":"79","y":"1653","zOrder":"320"},{"ID":"2370","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"129","x":"69","y":"1687","zOrder":"321"},{"ID":"2371","measuredH":"23","measuredW":"59","properties":{"bold":"true","size":"15","text":"Bamboo"},"typeID":"Label","x":"104","y":"1696","zOrder":"322"},{"ID":"2372","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"128","x":"70","y":"1732","zOrder":"323"},{"ID":"2373","measuredH":"23","measuredW":"170","properties":{"bold":"true","size":"15","text":"Azure DevOps Services"},"typeID":"Label","w":"105","x":"81","y":"1741","zOrder":"324"},{"ID":"2374","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"130","x":"1161","y":"1729","zOrder":"325"},{"ID":"2375","measuredH":"23","measuredW":"86","properties":{"bold":"true","size":"15","text":"Prometheus"},"typeID":"Label","x":"1182","y":"1738","zOrder":"326"},{"ID":"2376","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"127","x":"894","y":"1968","zOrder":"327"},{"ID":"2377","measuredH":"23","measuredW":"97","properties":{"bold":"true","size":"15","text":"AppDynamics"},"typeID":"Label","w":"103","x":"908","y":"1977","zOrder":"328"},{"ID":"2378","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"91","x":"1027","y":"1968","zOrder":"329"},{"ID":"2379","measuredH":"23","measuredW":"55","properties":{"bold":"true","size":"15","text":"Instana"},"typeID":"Label","x":"1045","y":"1977","zOrder":"330"},{"ID":"2380","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"224","x":"894","y":"2012","zOrder":"331"},{"ID":"2381","measuredH":"23","measuredW":"91","properties":{"bold":"true","size":"15","text":"OpenTracing"},"typeID":"Label","x":"960","y":"2021","zOrder":"332"},{"ID":"2382","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"152","x":"1103","y":"1664","zOrder":"333"},{"ID":"2383","measuredH":"23","measuredW":"47","properties":{"bold":"true","size":"15","text":"Pulumi"},"typeID":"Label","x":"1155","y":"1673","zOrder":"334"},{"ID":"2384","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"250","x":"611","y":"482","zOrder":"335"},{"ID":"2385","measuredH":"23","measuredW":"198","properties":{"bold":"true","size":"15","text":"Startup Management (intid)"},"typeID":"Label","x":"636","y":"491","zOrder":"336"},{"ID":"2386","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"252","x":"610","y":"615","zOrder":"337"},{"ID":"2387","measuredH":"23","measuredW":"229","properties":{"bold":"true","size":"15","text":"Service Management (systemd)"},"typeID":"Label","x":"621","y":"624","zOrder":"338"},{"ID":"2388","children":{"controls":{"control":[{"ID":"0","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"99","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"23","measuredW":"32","properties":{"bold":"true","size":"15","text":"Istio"},"typeID":"Label","x":"33","y":"9","zOrder":"1"},{"ID":"2","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"99","x":"0","y":"86","zOrder":"2"},{"ID":"3","measuredH":"23","measuredW":"52","properties":{"bold":"true","size":"15","text":"Linkerd"},"typeID":"Label","x":"23","y":"95","zOrder":"3"},{"ID":"4","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"99","x":"0","y":"43","zOrder":"4"},{"ID":"5","measuredH":"23","measuredW":"41","properties":{"bold":"true","size":"15","text":"Envoy"},"typeID":"Label","x":"29","y":"52","zOrder":"5"},{"ID":"6","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"99","x":"0","y":"129","zOrder":"6"},{"ID":"7","measuredH":"23","measuredW":"48","properties":{"bold":"true","size":"15","text":"Consul"},"typeID":"Label","x":"25","y":"138","zOrder":"7"}]}},"h":"169","measuredH":"169","measuredW":"99","typeID":"__group__","w":"99","x":"1207","y":"1244","zOrder":"339"},{"ID":"2389","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"152","x":"1161","y":"1432","zOrder":"340"},{"ID":"2390","measuredH":"23","measuredW":"98","properties":{"bold":"true","size":"15","text":"Service Mesh"},"typeID":"Label","x":"1187","y":"1441","zOrder":"341"},{"ID":"2391","h":"71","measuredH":"140","measuredW":"200","properties":{"color":"16776960"},"typeID":"TextArea","w":"258","x":"628","y":"2071","zOrder":"342"},{"ID":"2392","measuredH":"25","measuredW":"180","properties":{"bold":"true","size":"17","text":"Cloud Design Patterns"},"typeID":"Label","x":"666","y":"2082","zOrder":"343"},{"ID":"2393","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"231","x":"1055","y":"2071","zOrder":"344"},{"ID":"2394","measuredH":"23","measuredW":"75","properties":{"bold":"true","size":"15","text":"Availability"},"typeID":"Label","x":"1133","y":"2080","zOrder":"345"},{"ID":"2395","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"230","x":"1056","y":"2115","zOrder":"346"},{"ID":"2396","measuredH":"23","measuredW":"130","properties":{"bold":"true","size":"15","text":"Data Management"},"typeID":"Label","x":"1105","y":"2124","zOrder":"347"},{"ID":"2397","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"232","x":"1055","y":"2158","zOrder":"348"},{"ID":"2398","measuredH":"23","measuredW":"195","properties":{"bold":"true","size":"15","text":"Design and Implementation"},"typeID":"Label","x":"1073","y":"2167","zOrder":"349"},{"ID":"2399","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"232","x":"1055","y":"2202","zOrder":"350"},{"ID":"2400","measuredH":"23","measuredW":"202","properties":{"bold":"true","size":"15","text":"Management and Monitoring"},"typeID":"Label","x":"1069","y":"2211","zOrder":"351"},{"ID":"2401","measuredH":"23","measuredW":"213","properties":{"size":"15","text":"http://bit.ly/cloud-arch-patterns"},"typeID":"Label","x":"650","y":"2108","zOrder":"352"},{"ID":"2402","h":"77","measuredH":"77","measuredW":"0","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":76},"p1":{"x":0.4687474151479224,"y":-0.0047699137004053056},"p2":{"x":0,"y":-0.5},"rightArrow":"false"},"typeID":"Arrow","w":"1","x":"761","y":"2320","zOrder":"353"},{"ID":"2403","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"155","x":"70","y":"1108","zOrder":"354"},{"ID":"2404","measuredH":"23","measuredW":"47","properties":{"bold":"true","size":"15","text":"Emails"},"typeID":"Label","x":"124","y":"1117","zOrder":"355"},{"ID":"2405","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"129","x":"71","y":"1171","zOrder":"356"},{"ID":"2406","measuredH":"23","measuredW":"42","properties":{"bold":"true","size":"15","text":"SMTP"},"typeID":"Label","x":"114","y":"1180","zOrder":"357"},{"ID":"2407","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"129","x":"71","y":"1214","zOrder":"358"},{"ID":"2408","measuredH":"23","measuredW":"48","properties":{"bold":"true","size":"15","text":"IMAPS"},"typeID":"Label","x":"111","y":"1223","zOrder":"359"},{"ID":"2409","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"129","x":"71","y":"1258","zOrder":"360"},{"ID":"2410","measuredH":"23","measuredW":"50","properties":{"bold":"true","size":"15","text":"POP3S"},"typeID":"Label","x":"110","y":"1267","zOrder":"361"},{"ID":"2411","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"129","x":"96","y":"1310","zOrder":"362"},{"ID":"2412","measuredH":"23","measuredW":"55","properties":{"bold":"true","size":"15","text":"DMARC"},"typeID":"Label","x":"133","y":"1319","zOrder":"363"},{"ID":"2413","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"129","x":"96","y":"1354","zOrder":"364"},{"ID":"2414","measuredH":"23","measuredW":"29","properties":{"bold":"true","size":"15","text":"SPF"},"typeID":"Label","x":"146","y":"1363","zOrder":"365"},{"ID":"2415","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"129","x":"96","y":"1398","zOrder":"366"},{"ID":"2416","measuredH":"23","measuredW":"91","properties":{"bold":"true","size":"15","text":"Domain Keys"},"typeID":"Label","x":"115","y":"1407","zOrder":"367"},{"ID":"2417","h":"40","measuredH":"140","measuredW":"200","properties":{"color":"16770457"},"typeID":"TextArea","w":"164","x":"65","y":"968","zOrder":"368"},{"ID":"2418","measuredH":"23","measuredW":"135","properties":{"bold":"true","size":"15","text":"White/Grey Listing"},"typeID":"Label","x":"79","y":"976","zOrder":"369"},{"ID":"2419","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"477","y":"300","zOrder":"370"},{"ID":"2420","children":{"controls":{"control":[{"ID":"0","h":"41","measuredH":"140","measuredW":"200","properties":{"color":"16770457","textColor":"16776960"},"typeID":"TextArea","w":"141","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"25","measuredW":"35","properties":{"bold":"true","size":"17","text":"C++"},"typeID":"Label","x":"53","y":"8","zOrder":"1"}]}},"h":"41","measuredH":"41","measuredW":"141","typeID":"__group__","w":"141","x":"983","y":"416","zOrder":"371"},{"ID":"2421","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1108","y":"273","zOrder":"372"},{"ID":"2422","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1109","y":"324","zOrder":"373"},{"ID":"2423","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1109","y":"369","zOrder":"374"},{"ID":"2424","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1109","y":"414","zOrder":"375"},{"ID":"2425","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"250","y":"269","zOrder":"376"},{"ID":"2426","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"250","y":"316","zOrder":"377"},{"ID":"2427","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"250","y":"364","zOrder":"378"},{"ID":"2428","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"187","y":"443","zOrder":"379"},{"ID":"2429","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"187","y":"492","zOrder":"380"},{"ID":"2430","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"187","y":"540","zOrder":"381"},{"ID":"2431","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"187","y":"586","zOrder":"382"},{"ID":"2432","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"187","y":"636","zOrder":"383"},{"ID":"2433","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1116","y":"481","zOrder":"384"},{"ID":"2434","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1116","y":"528","zOrder":"385"},{"ID":"2435","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1116","y":"573","zOrder":"386"},{"ID":"2436","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1116","y":"619","zOrder":"387"},{"ID":"2437","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"846","y":"477","zOrder":"388"},{"ID":"2438","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"846","y":"611","zOrder":"389"},{"ID":"2439","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"246","y":"770","zOrder":"390"},{"ID":"2440","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"245","y":"816","zOrder":"391"},{"ID":"2441","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"245","y":"859","zOrder":"392"},{"ID":"2442","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"79","y":"913","zOrder":"393"},{"ID":"2443","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"79","y":"869","zOrder":"394"},{"ID":"2444","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"78","y":"827","zOrder":"395"},{"ID":"2445","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"78","y":"783","zOrder":"396"},{"ID":"2446","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"78","y":"738","zOrder":"397"},{"ID":"2447","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"78","y":"691","zOrder":"398"},{"ID":"2448","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1266","y":"701","zOrder":"399"},{"ID":"2449","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1264","y":"602","zOrder":"400"},{"ID":"2450","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1266","y":"648","zOrder":"401"},{"ID":"2451","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"509","y":"822","zOrder":"402"},{"ID":"2452","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"509","y":"865","zOrder":"403"},{"ID":"2453","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"509","y":"911","zOrder":"404"},{"ID":"2454","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"661","y":"837","zOrder":"405"},{"ID":"2455","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"661","y":"949","zOrder":"406"},{"ID":"2456","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"631","y":"1029","zOrder":"407"},{"ID":"2457","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1213","y":"1079","zOrder":"408"},{"ID":"2458","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1213","y":"999","zOrder":"409"},{"ID":"2459","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1213","y":"927","zOrder":"410"},{"ID":"2460","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"937","y":"837","zOrder":"411"},{"ID":"2461","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"935","y":"881","zOrder":"412"},{"ID":"2462","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"88","y":"1024","zOrder":"413"},{"ID":"2463","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"365","y":"1100","zOrder":"414"},{"ID":"2464","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"365","y":"1148","zOrder":"415"},{"ID":"2465","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"365","y":"1191","zOrder":"416"},{"ID":"2466","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"365","y":"1239","zOrder":"417"},{"ID":"2467","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"365","y":"1280","zOrder":"418"},{"ID":"2468","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"366","y":"1325","zOrder":"419"},{"ID":"2469","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"66","y":"1100","zOrder":"420"},{"ID":"2470","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"526","y":"1271","zOrder":"421"},{"ID":"2471","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"698","y":"1270","zOrder":"422"},{"ID":"2472","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"698","y":"1319","zOrder":"423"},{"ID":"2473","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"698","y":"1362","zOrder":"424"},{"ID":"2474","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"526","y":"1313","zOrder":"425"},{"ID":"2475","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1172","y":"1225","zOrder":"426"},{"ID":"2476","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1172","y":"1270","zOrder":"427"},{"ID":"2477","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1172","y":"1314","zOrder":"428"},{"ID":"2478","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1172","y":"1359","zOrder":"429"},{"ID":"2479","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1172","y":"1177","zOrder":"430"},{"ID":"2480","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1288","y":"1238","zOrder":"431"},{"ID":"2481","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1291","y":"1373","zOrder":"432"},{"ID":"2482","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1292","y":"1283","zOrder":"433"},{"ID":"2483","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1292","y":"1328","zOrder":"434"},{"ID":"2484","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1001","y":"1249","zOrder":"435"},{"ID":"2485","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"987","y":"1426","zOrder":"436"},{"ID":"2486","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1297","y":"1426","zOrder":"437"},{"ID":"2487","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"420","y":"1510","zOrder":"438"},{"ID":"2488","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"418","y":"1588","zOrder":"439"},{"ID":"2490","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"420","y":"1635","zOrder":"440"},{"ID":"2491","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"571","y":"1588","zOrder":"441"},{"ID":"2492","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"572","y":"1633","zOrder":"442"},{"ID":"2493","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"786","y":"1589","zOrder":"443"},{"ID":"2494","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"786","y":"1633","zOrder":"444"},{"ID":"2495","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"825","y":"1587","zOrder":"445"},{"ID":"2496","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"825","y":"1629","zOrder":"446"},{"ID":"2497","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1045","y":"1590","zOrder":"447"},{"ID":"2498","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1045","y":"1638","zOrder":"448"},{"ID":"2499","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1238","y":"1575","zOrder":"449"},{"ID":"2500","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1239","y":"1617","zOrder":"450"},{"ID":"2501","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1240","y":"1660","zOrder":"451"},{"ID":"2502","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"568","y":"1508","zOrder":"452"},{"ID":"2503","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"828","y":"1507","zOrder":"453"},{"ID":"2504","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1296","y":"1511","zOrder":"454"},{"ID":"2505","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"58","y":"1522","zOrder":"455"},{"ID":"2506","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"308","y":"1596","zOrder":"456"},{"ID":"2507","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"58","y":"1636","zOrder":"457"},{"ID":"2508","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"58","y":"1591","zOrder":"458"},{"ID":"2509","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"58","y":"1683","zOrder":"459"},{"ID":"2510","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"58","y":"1726","zOrder":"460"},{"ID":"2511","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"311","y":"1643","zOrder":"461"},{"ID":"2512","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"310","y":"1683","zOrder":"462"},{"ID":"2513","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"311","y":"1727","zOrder":"463"},{"ID":"2514","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"314","y":"1778","zOrder":"464"},{"ID":"2515","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"123","y":"1839","zOrder":"465"},{"ID":"2516","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"118","y":"2159","zOrder":"466"},{"ID":"2517","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"123","y":"1888","zOrder":"467"},{"ID":"2518","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"123","y":"1930","zOrder":"468"},{"ID":"2519","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"122","y":"1975","zOrder":"469"},{"ID":"2520","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"118","y":"2203","zOrder":"470"},{"ID":"2521","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"118","y":"2245","zOrder":"471"},{"ID":"2522","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"501","y":"1865","zOrder":"472"},{"ID":"2523","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"501","y":"1912","zOrder":"473"},{"ID":"2524","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"501","y":"1954","zOrder":"474"},{"ID":"2525","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"501","y":"2002","zOrder":"475"},{"ID":"2526","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"887","y":"1918","zOrder":"476"},{"ID":"2527","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1104","y":"1964","zOrder":"477"},{"ID":"2528","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"885","y":"1965","zOrder":"478"},{"ID":"2529","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"885","y":"2008","zOrder":"479"},{"ID":"2530","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1101","y":"1914","zOrder":"480"},{"ID":"2531","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1275","y":"1723","zOrder":"481"},{"ID":"2532","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1275","y":"1768","zOrder":"482"},{"ID":"2533","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1275","y":"1858","zOrder":"483"},{"ID":"2534","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1275","y":"1902","zOrder":"484"},{"ID":"2535","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"},{"ID":"2","measuredH":"24","measuredW":"24","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"2"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1275","y":"1945","zOrder":"485"},{"ID":"2536","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1275","y":"1816","zOrder":"486"},{"ID":"2537","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1049","y":"1764","zOrder":"487"},{"ID":"2538","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"1044","y":"1832","zOrder":"488"},{"ID":"2539","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"262","y":"2077","zOrder":"489"},{"ID":"2540","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"870","y":"2059","zOrder":"490"},{"ID":"2541","children":{"controls":{"control":[{"ID":"0","measuredH":"24","measuredW":"24","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"0"},{"ID":"1","measuredH":"24","measuredW":"24","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}},"typeID":"Icon","x":"0","y":"0","zOrder":"1"}]}},"h":"24","measuredH":"24","measuredW":"24","typeID":"__group__","w":"24","x":"845","y":"2059","zOrder":"491"}]},"measuredH":"2397","measuredW":"1321","mockupH":"2356","mockupW":"1263","version":"1.0"}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/devops/resources.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/devops/resources.json new file mode 100644 index 000000000..df9389165 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/devops/resources.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"DevOps Roadmap: Learn to become a DevOps Engineer or SRE","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a devops enginer","devops roadmap","sre roadmap","site reliability engineer roadmap","operations roles","become devops","devops skills","modern devops skills","devops skills test","skills for devops","learn devops","what is devops","what is sre","devops quiz","devops interview questions"]},"title":"DevOps Roadmap","description":"Step by step guide for DevOps, SRE or any other Operations Role in 2021","featuredTitle":"DevOps","featuredDescription":"Step by step guide for DevOps or operations role in 2021","featured":true,"imagePath":"/roadmaps/devops.png","resourcesPath":"/roadmaps/102-devops/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/devops-roadmap","id":"devops","metaPath":"/roadmaps/102-devops/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/frontend.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/frontend.json new file mode 100644 index 000000000..3bf030e28 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/frontend.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a modern frontend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern frontend development. Learn to become a modern frontend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a frontend developer","frontend developer","frontend engineer","frontend skills","frontend development","javascript developer","frontend development skills","frontend development skills test","frontend engineer roadmap","frontend developer roadmap","become a frontend developer","frontend developer career path","javascript developer","modern javascript developer","node developer","skills for frontend development","learn frontend development","what is frontend development","frontend developer quiz","frontend developer interview questions"]},"title":"Frontend Developer","description":"Step by step guide to becoming a modern frontend developer in 2021","featuredTitle":"Frontend","featuredDescription":"Step by step guide to becoming a frontend developer in 2021","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"featured":true,"imagePath":"/roadmaps/frontend.png","resourcesPath":"/roadmaps/100-frontend/resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/frontend-roadmap","id":"frontend","metaPath":"/roadmaps/100-frontend/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/frontend/interactive.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/frontend/interactive.json new file mode 100644 index 000000000..c5d1931a0 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/frontend/interactive.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a modern frontend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern frontend development. Learn to become a modern frontend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a frontend developer","frontend developer","frontend engineer","frontend skills","frontend development","javascript developer","frontend development skills","frontend development skills test","frontend engineer roadmap","frontend developer roadmap","become a frontend developer","frontend developer career path","javascript developer","modern javascript developer","node developer","skills for frontend development","learn frontend development","what is frontend development","frontend developer quiz","frontend developer interview questions"]},"title":"Frontend Developer","description":"Step by step guide to becoming a modern frontend developer in 2021","featuredTitle":"Frontend","featuredDescription":"Step by step guide to becoming a frontend developer in 2021","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"featured":true,"imagePath":"/roadmaps/frontend.png","resourcesPath":"/roadmaps/100-frontend/resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/frontend-roadmap","id":"frontend","metaPath":"/roadmaps/100-frontend/meta.json","isUpcoming":false},"json":{"mockup":{"controls":{"control":[{"ID":"711","typeID":"Arrow","zOrder":"6","w":"105","h":"43","measuredW":"150","measuredH":"100","x":"952","y":"2014","properties":{"color":"10027263","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":42},"p1":{"x":0.3246422893481717,"y":0.04197138314785374},"p2":{"x":104,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"712","typeID":"Arrow","zOrder":"7","w":"128","h":"9","measuredW":"150","measuredH":"100","x":"940","y":"2060","properties":{"color":"10027263","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":8},"p1":{"x":0.3321152059461133,"y":0.04465778878909879},"p2":{"x":127,"y":4},"rightArrow":"false","stroke":"dotted"}},{"ID":"713","typeID":"Arrow","zOrder":"8","w":"129","h":"34","measuredW":"150","measuredH":"100","x":"941","y":"2075","properties":{"color":"10027263","curvature":"0","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.3458601686475002,"y":-0.005245335635083992},"p2":{"x":128,"y":33},"rightArrow":"false","stroke":"dotted"}},{"ID":"714","typeID":"Arrow","zOrder":"9","w":"119","h":"123","measuredW":"150","measuredH":"100","x":"617","y":"2067","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","rightArrow":"false","p0":{"x":119,"y":0},"p1":{"x":0.5330602565484531,"y":-0.2424921849735906},"p2":{"x":0,"y":122.5}}},{"ID":"715","typeID":"Arrow","zOrder":"10","w":"140","h":"73","measuredW":"150","measuredH":"100","x":"588","y":"1981","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.3865808955652986,"y":-0.19467404585639328},"p2":{"x":139,"y":72},"rightArrow":"false"}},{"ID":"716","typeID":"Arrow","zOrder":"11","w":"135","h":"49","measuredW":"150","measuredH":"100","x":"367","y":"1974","properties":{"color":"10027263","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":134,"y":0},"p1":{"x":0.503622802344166,"y":0.003676078849227487},"p2":{"x":0,"y":48},"rightArrow":"false","stroke":"dotted"}},{"ID":"717","typeID":"Arrow","zOrder":"12","w":"98","h":"3","measuredW":"150","measuredH":"100","x":"1073","y":"1947","properties":{"color":"10027263","leftArrow":"false","p0":{"x":0,"y":2},"p1":{"x":0.30434782608695654,"y":0.014492753623188411},"p2":{"x":97,"y":2},"rightArrow":"false","stroke":"dotted"}},{"ID":"719","typeID":"Arrow","zOrder":"13","w":"148","h":"1","measuredW":"150","measuredH":"100","x":"353","y":"1972","properties":{"color":"10027263","curvature":"0","leftArrow":"false","p0":{"x":147,"y":0},"p1":{"x":0.5036228023441662,"y":0.003676078849227491},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"720","typeID":"Arrow","zOrder":"14","w":"137","h":"33","measuredW":"150","measuredH":"100","x":"358","y":"1937","properties":{"color":"10027263","curvature":"-1","leftArrow":"false","p0":{"x":136,"y":32},"p1":{"x":0.5049180327868853,"y":-0.02090163934426227},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"721","typeID":"Arrow","zOrder":"15","w":"146","h":"65","measuredW":"150","measuredH":"100","x":"350","y":"1900","properties":{"color":"10027263","curvature":"-1","leftArrow":"false","p0":{"x":145,"y":64},"p1":{"x":0.49185940050157245,"y":-0.05186895426137495},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"722","typeID":"Arrow","zOrder":"16","w":"105","h":"89","measuredW":"150","measuredH":"100","x":"653","y":"1881","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":104,"y":0},"p1":{"x":0.5150450252580716,"y":0.2856358444981331},"p2":{"x":0,"y":86},"rightArrow":"false"}},{"ID":"723","typeID":"Arrow","zOrder":"17","w":"118","h":"26","measuredW":"150","measuredH":"100","x":"1065","y":"1871","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":117,"y":25},"p1":{"x":0.47388515577275486,"y":0.002290775809407195},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"724","typeID":"Arrow","zOrder":"18","w":"124","h":"21","measuredW":"150","measuredH":"100","x":"1059","y":"1847","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":123,"y":0},"p1":{"x":0.473885155772755,"y":0.00229077580940721},"p2":{"x":0,"y":20},"rightArrow":"false","stroke":"dotted"}},{"ID":"725","typeID":"Arrow","zOrder":"19","w":"117","h":"18","measuredW":"150","measuredH":"100","x":"1056","y":"1773","properties":{"color":"10027263","leftArrow":"false","p0":{"x":0,"y":2},"p1":{"x":0.3238461538461538,"y":0.04076923076923073},"p2":{"x":116,"y":17},"rightArrow":"false","stroke":"dotted"}},{"ID":"726","typeID":"Arrow","zOrder":"20","w":"108","h":"23","measuredW":"150","measuredH":"100","x":"1053","y":"1748","properties":{"color":"10027263","direction":"bottom","leftArrow":"false","p0":{"x":107,"y":0},"p1":{"x":0.3813139650049522,"y":-0.013865962363816473},"p2":{"x":0,"y":22},"rightArrow":"false","stroke":"dotted"}},{"ID":"727","typeID":"Arrow","zOrder":"21","w":"112","h":"58","measuredW":"150","measuredH":"100","x":"854","y":"1889","properties":{"color":"10027263","leftArrow":"false","p0":{"x":111,"y":57},"p1":{"x":0.4939621628874279,"y":0.14832953173218838},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"728","typeID":"Arrow","zOrder":"22","w":"117","h":"5","measuredW":"150","measuredH":"100","x":"864","y":"1864","properties":{"color":"10027263","direction":"bottom","leftArrow":"false","p0":{"x":116,"y":1},"p1":{"x":0.5309292397129627,"y":-0.01571441547824508},"p2":{"x":0,"y":4},"rightArrow":"false","stroke":"dotted"}},{"ID":"729","typeID":"Arrow","zOrder":"23","w":"86","h":"96","measuredW":"150","measuredH":"100","x":"850","y":"1768","properties":{"color":"10027263","direction":"bottom","leftArrow":"false","p0":{"x":85,"y":0},"p1":{"x":0.48716362511599137,"y":-0.18836993504485},"p2":{"x":0,"y":95},"rightArrow":"false","stroke":"dotted"}},{"ID":"730","typeID":"Arrow","zOrder":"24","w":"57","h":"244","measuredW":"150","measuredH":"100","x":"689","y":"1629","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":39,"y":0},"p1":{"x":0.5504287774151931,"y":-0.19435379828489027},"p2":{"x":56,"y":243},"rightArrow":"false"}},{"ID":"731","typeID":"Arrow","zOrder":"25","w":"51","h":"116","measuredW":"150","measuredH":"100","x":"576","y":"1632","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":50,"y":0},"p1":{"x":0.6557048619594426,"y":0.20855118494991431},"p2":{"x":0,"y":115},"rightArrow":"false","stroke":"dotted"}},{"ID":"732","typeID":"Arrow","zOrder":"26","w":"116","h":"8","measuredW":"150","measuredH":"100","x":"302","y":"1753","properties":{"color":"10027263","direction":"bottom","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":8},"p1":{"x":0.44386976428692576,"y":-0.021282007800576565},"p2":{"x":116,"y":0}}},{"ID":"733","typeID":"Arrow","zOrder":"27","w":"102","h":"75","measuredW":"150","measuredH":"100","x":"316","y":"1672","properties":{"color":"10027263","direction":"bottom","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":0},"p1":{"x":0.40594249201277954,"y":-0.011437699680511216},"p2":{"x":102,"y":75}}},{"ID":"734","typeID":"Arrow","zOrder":"28","w":"71","h":"36","measuredW":"150","measuredH":"100","x":"1081","y":"1631","properties":{"color":"10027263","curvature":"-1","leftArrow":"false","p0":{"x":70,"y":35},"p1":{"x":0.5309292397129621,"y":-0.01571441547824513},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"735","typeID":"Arrow","zOrder":"29","w":"106","h":"10","measuredW":"150","measuredH":"100","x":"1079","y":"1621","properties":{"color":"10027263","direction":"bottom","leftArrow":"false","p0":{"x":105,"y":0},"p1":{"x":0.5309292397129626,"y":-0.01571441547824508},"p2":{"x":0,"y":9},"rightArrow":"false","stroke":"dotted"}},{"ID":"736","typeID":"Arrow","zOrder":"30","w":"85","h":"59","measuredW":"150","measuredH":"100","x":"1079","y":"1570","properties":{"color":"10027263","direction":"bottom","leftArrow":"false","p0":{"x":84,"y":0},"p1":{"x":0.4951386388188694,"y":-0.0763413755851639},"p2":{"x":-0.5,"y":59},"rightArrow":"false","stroke":"dotted"}},{"ID":"737","typeID":"Arrow","zOrder":"31","w":"133","h":"4","measuredW":"150","measuredH":"100","x":"780","y":"1629","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":2},"p1":{"x":0.4434300336167677,"y":0.014243775690876917},"p2":{"x":132,"y":3},"rightArrow":"false","stroke":"dotted"}},{"ID":"738","typeID":"Arrow","zOrder":"32","w":"129","h":"54","measuredW":"150","measuredH":"100","x":"482","y":"1572","properties":{"color":"2848996","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":0.5},"p1":{"x":0.3865623561895996,"y":0.07654548243595644},"p2":{"x":129,"y":54.5}}},{"ID":"740","typeID":"Arrow","zOrder":"33","w":"104","h":"3","measuredW":"150","measuredH":"100","x":"297","y":"1569","properties":{"color":"2848996","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":0.5},"p1":{"x":0.44339622641509424,"y":0.014150943396226412},"p2":{"x":104,"y":2.5}}},{"ID":"741","typeID":"Arrow","zOrder":"34","w":"41","h":"110","measuredW":"150","measuredH":"100","x":"772","y":"1500","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":36,"y":0},"p1":{"x":0.4797753661683236,"y":0.15845791910146467},"p2":{"x":0,"y":109},"rightArrow":"false"}},{"ID":"742","typeID":"Arrow","zOrder":"35","w":"50","h":"2","measuredW":"150","measuredH":"100","x":"301","y":"1447","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":49,"y":1},"p1":{"x":0.4872751951136748,"y":-0.01187648456057007},"p2":{"x":0,"y":1},"rightArrow":"false","stroke":"dotted"}},{"ID":"743","typeID":"Arrow","zOrder":"36","w":"165","h":"43","measuredW":"150","measuredH":"100","x":"660","y":"1411","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.46185893674451367,"y":-0.10438915620232368},"p2":{"x":164,"y":40},"rightArrow":"false"}},{"ID":"744","typeID":"Arrow","zOrder":"37","w":"85","h":"3","measuredW":"150","measuredH":"100","x":"1091","y":"1449","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":83,"y":1},"p1":{"x":0.4872751951136748,"y":-0.01187648456057007},"p2":{"x":0,"y":1},"rightArrow":"false","stroke":"dotted"}},{"ID":"745","typeID":"Arrow","zOrder":"38","w":"54","h":"129","measuredW":"150","measuredH":"100","x":"607","y":"1283","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":1,"y":0},"p1":{"x":0.4618589367445136,"y":-0.10438915620232368},"p2":{"x":53,"y":128},"rightArrow":"false"}},{"ID":"746","typeID":"Arrow","zOrder":"39","w":"21","h":"98","measuredW":"150","measuredH":"100","x":"877","y":"1112","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4592720970537261,"y":-0.022530329289428077},"p2":{"x":20,"y":97},"rightArrow":"false","stroke":"dotted"}},{"ID":"747","typeID":"Arrow","zOrder":"40","w":"117","h":"139","measuredW":"150","measuredH":"100","x":"607","y":"1115","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":116,"y":0},"p1":{"x":0.5113995183302114,"y":-0.17615734546427614},"p2":{"x":0,"y":138},"rightArrow":"false"}},{"ID":"748","typeID":"Arrow","zOrder":"41","w":"175","h":"55","measuredW":"150","measuredH":"100","x":"361","y":"1273","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":54},"p1":{"x":0.4434300336167671,"y":0.014243775690876872},"p2":{"x":174,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"750","typeID":"Arrow","zOrder":"43","w":"171","h":"9","measuredW":"150","measuredH":"100","x":"352","y":"1258","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":170,"y":8},"p1":{"x":0.4651735508633531,"y":-0.0009522699259062856},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"751","typeID":"Arrow","zOrder":"44","w":"109","h":"161","measuredW":"150","measuredH":"100","x":"748","y":"931","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5674918262494162,"y":0.22092480149462868},"p2":{"x":102,"y":160},"rightArrow":"false"}},{"ID":"752","typeID":"Arrow","zOrder":"45","w":"1","h":"77","measuredW":"150","measuredH":"100","x":"1114","y":"934","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":76},"p1":{"x":0.487275195113675,"y":-0.01187648456057007},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"753","typeID":"Arrow","zOrder":"46","w":"85","h":"3","measuredW":"150","measuredH":"100","x":"845","y":"918","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":83,"y":1},"p1":{"x":0.4872751951136748,"y":-0.01187648456057007},"p2":{"x":0,"y":1},"rightArrow":"false","stroke":"dotted"}},{"ID":"754","typeID":"Arrow","zOrder":"47","w":"2","h":"74","measuredW":"150","measuredH":"100","x":"622","y":"924","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":1,"y":73},"p1":{"x":0.4872751951136749,"y":-0.01187648456057007},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"755","typeID":"Arrow","zOrder":"48","w":"120","h":"3","measuredW":"150","measuredH":"100","x":"772","y":"706","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":119,"y":2},"p1":{"x":0.5436210493779461,"y":0.006954640290549417},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"756","typeID":"Arrow","zOrder":"49","w":"108","h":"5","measuredW":"150","measuredH":"100","x":"783","y":"653","properties":{"color":"2848996","leftArrow":"false","p0":{"x":107,"y":2},"p1":{"x":0.589278350515464,"y":0.035876288659793816},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"757","typeID":"Arrow","zOrder":"50","w":"100","h":"45","measuredW":"150","measuredH":"100","x":"783","y":"607","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":99,"y":0},"p1":{"x":0.5773195876288659,"y":-0.06466729147141519},"p2":{"x":0,"y":44},"rightArrow":"false","stroke":"dotted"}},{"ID":"758","typeID":"Arrow","zOrder":"51","w":"40","h":"139","measuredW":"150","measuredH":"100","x":"656","y":"490","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5674918262494162,"y":0.22092480149462868},"p2":{"x":15,"y":138},"rightArrow":"false"}},{"ID":"759","typeID":"Arrow","zOrder":"52","w":"151","h":"29","measuredW":"150","measuredH":"100","x":"737","y":"482","properties":{"color":"2848996","leftArrow":"false","p0":{"x":150,"y":28},"p1":{"x":0.4823054457996908,"y":0.02336368321594228},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"760","typeID":"Arrow","zOrder":"53","w":"153","h":"13","measuredW":"150","measuredH":"100","x":"739","y":"465","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":152,"y":0},"p1":{"x":0.4798692360633173,"y":-0.004989676531314521},"p2":{"x":0,"y":12},"rightArrow":"false","stroke":"dotted"}},{"ID":"761","typeID":"Arrow","zOrder":"54","h":"60","measuredW":"150","measuredH":"100","x":"737","y":"416","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":149,"y":0},"p1":{"x":0.4552212800557556,"y":-0.05494250203275647},"p2":{"x":0,"y":59},"rightArrow":"false","stroke":"dotted"}},{"ID":"762","typeID":"Arrow","zOrder":"55","w":"134","h":"36","measuredW":"150","measuredH":"100","x":"447","y":"483","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":132,"y":0},"p1":{"x":0.4652789342214826,"y":-0.001332223147377271},"p2":{"x":0,"y":34},"rightArrow":"false","stroke":"dotted"}},{"ID":"763","typeID":"Arrow","zOrder":"56","w":"131","h":"9","measuredW":"150","measuredH":"100","x":"447","y":"470","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":129,"y":7},"p1":{"x":0.4652789342214826,"y":-0.001332223147377271},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"764","typeID":"Arrow","zOrder":"57","w":"143","h":"53","measuredW":"150","measuredH":"100","x":"437","y":"423","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":141,"y":51},"p1":{"x":0.45522128005575574,"y":-0.054942502032756434},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"765","typeID":"Arrow","zOrder":"58","w":"45","h":"139","measuredW":"150","measuredH":"100","x":"634","y":"327","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":44,"y":0},"p1":{"x":0.540933899332929,"y":-0.1946634323832626},"p2":{"x":16,"y":138},"rightArrow":"false"}},{"ID":"766","typeID":"HRule","zOrder":"59","measuredW":"100","measuredH":"10","x":"1136","y":"754","properties":{"color":"10027263","stroke":"dotted"}},{"ID":"767","typeID":"Arrow","zOrder":"60","w":"71","h":"134","measuredW":"150","measuredH":"100","x":"646","y":"765","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":9,"y":0},"p1":{"x":0.5549276224469561,"y":-0.26264128494943484},"p2":{"x":70,"y":133},"rightArrow":"false"}},{"ID":"768","typeID":"Arrow","zOrder":"61","w":"130","h":"213","measuredW":"150","measuredH":"100","x":"428","y":"776","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":129,"y":0},"p1":{"x":0.5007550539904198,"y":0.04527076398473655},"p2":{"x":0,"y":212},"rightArrow":"false","stroke":"dotted"}},{"ID":"769","typeID":"Arrow","zOrder":"62","w":"110","h":"157","measuredW":"150","measuredH":"100","x":"442","y":"769","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":109,"y":0},"p1":{"x":0.46686783637115814,"y":0.0018494634122600195},"p2":{"x":0,"y":156},"rightArrow":"false","stroke":"dotted"}},{"ID":"770","typeID":"Arrow","zOrder":"63","w":"119","h":"120","measuredW":"150","measuredH":"100","x":"434","y":"762","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":118,"y":0},"p1":{"x":0.46376334167874567,"y":-0.006127289497957557},"p2":{"x":0,"y":119},"rightArrow":"false","stroke":"dotted"}},{"ID":"771","typeID":"Arrow","zOrder":"64","w":"128","h":"82","measuredW":"150","measuredH":"100","x":"429","y":"751","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":127,"y":0},"p1":{"x":0.4682571775171856,"y":0.0018196522442377747},"p2":{"x":0,"y":81},"rightArrow":"false","stroke":"dotted"}},{"ID":"772","typeID":"Arrow","zOrder":"65","w":"123","h":"34","measuredW":"150","measuredH":"100","x":"429","y":"753","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":122,"y":0},"p1":{"x":0.4501850789844116,"y":0.009280016683176094},"p2":{"x":0,"y":33},"rightArrow":"false","stroke":"dotted"}},{"ID":"773","typeID":"Arrow","zOrder":"66","w":"106","h":"99","measuredW":"150","measuredH":"100","x":"784","y":"713","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":105,"y":98},"p1":{"x":0.48727519511367495,"y":-0.011876484560570073},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"774","typeID":"Arrow","zOrder":"67","w":"109","h":"54","measuredW":"150","measuredH":"100","x":"781","y":"707","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":108,"y":53},"p1":{"x":0.44795435569162256,"y":-0.008627887559142778},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"775","typeID":"Arrow","zOrder":"68","w":"111","h":"59","measuredW":"150","measuredH":"100","x":"432","y":"579","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":110,"y":58},"p1":{"x":0.45522128005575574,"y":-0.054942502032756434},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"776","typeID":"Arrow","zOrder":"69","w":"112","h":"58","measuredW":"150","measuredH":"100","x":"430","y":"661","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":111,"y":0},"p1":{"x":0.47938350680544434,"y":0.06064851881505207},"p2":{"x":0,"y":57},"rightArrow":"false","stroke":"dotted"}},{"ID":"777","typeID":"Arrow","zOrder":"70","w":"112","h":"23","measuredW":"150","measuredH":"100","x":"434","y":"651","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":111,"y":0},"p1":{"x":0.4453729012104649,"y":0.01983600156188987},"p2":{"x":0,"y":22},"rightArrow":"false","stroke":"dotted"}},{"ID":"778","typeID":"Arrow","zOrder":"71","w":"120","h":"20","measuredW":"150","measuredH":"100","x":"431","y":"628","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":119,"y":19},"p1":{"x":0.4652789342214826,"y":-0.001332223147377271},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"781","typeID":"Arrow","zOrder":"72","w":"19","h":"80","measuredW":"150","measuredH":"100","x":"721","y":"186","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":17,"y":0},"p1":{"x":0.4835868694955965,"y":0.10168134507606086},"p2":{"x":0,"y":79},"rightArrow":"false","stroke":"dotted"}},{"ID":"816","typeID":"Canvas","zOrder":"83","w":"350","h":"141","measuredW":"100","measuredH":"70","x":"933","y":"169"},{"ID":"817","typeID":"Label","zOrder":"84","measuredW":"314","measuredH":"25","x":"947","y":"186","properties":{"size":"17","text":"Find the detailed version of this roadmap"}},{"ID":"818","typeID":"Label","zOrder":"85","measuredW":"319","measuredH":"25","x":"947","y":"214","properties":{"size":"17","text":"along with resources and other roadmaps"}},{"ID":"923","typeID":"Arrow","zOrder":"106","w":"96","h":"111","measuredW":"150","measuredH":"100","x":"318","y":"1626","properties":{"color":"10027263","curvature":"-1","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":0},"p1":{"x":0.4514556344894832,"y":-0.030087755954868366},"p2":{"x":96,"y":111}}},{"ID":"976","typeID":"Arrow","zOrder":"123","w":"201","h":"4","measuredW":"150","measuredH":"100","x":"603","y":"3042","properties":{"color":"2848996","leftArrow":"false","p0":{"x":200,"y":0},"p1":{"x":0.5976298194338792,"y":0.018096648917003643},"p2":{"x":0,"y":0},"rightArrow":"false"}},{"ID":"977","typeID":"Arrow","zOrder":"124","w":"41","h":"124","measuredW":"150","measuredH":"100","x":"742","y":"2909","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":37,"y":0},"p1":{"x":0.5697582243361078,"y":-0.30657946888624726},"p2":{"x":40,"y":123},"rightArrow":"false"}},{"ID":"978","typeID":"Arrow","zOrder":"125","w":"97","h":"17","measuredW":"150","measuredH":"100","x":"897","y":"2880","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":96,"y":0},"p1":{"x":0.4835193355826628,"y":0.007267064624967626},"p2":{"x":0,"y":16},"rightArrow":"false","stroke":"dotted"}},{"ID":"979","typeID":"Arrow","zOrder":"126","w":"78","h":"22","measuredW":"150","measuredH":"100","x":"903","y":"2911","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":77,"y":21},"p1":{"x":0.4835193355826629,"y":0.0072670646249675805},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"981","typeID":"Arrow","zOrder":"127","w":"158","h":"72","measuredW":"150","measuredH":"100","x":"286","y":"2958","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4319942611190819,"y":-0.006169296987087513},"p2":{"x":157,"y":71},"rightArrow":"false","stroke":"dotted"}},{"ID":"982","typeID":"Arrow","zOrder":"128","w":"134","h":"145","measuredW":"150","measuredH":"100","x":"1059","y":"3059","properties":{"color":"2848996","leftArrow":"false","p0":{"x":133,"y":144},"p1":{"x":0.5642023346303501,"y":0.02723735408560301},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"983","typeID":"Arrow","zOrder":"129","w":"144","h":"111","measuredW":"150","measuredH":"100","x":"1049","y":"3049","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":143,"y":110},"p1":{"x":0.5591257349884183,"y":0.009087129536140616},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"984","typeID":"Arrow","zOrder":"130","w":"145","h":"78","measuredW":"150","measuredH":"100","x":"1053","y":"3043","properties":{"color":"2848996","leftArrow":"false","p0":{"x":144,"y":77},"p1":{"x":0.5642023346303502,"y":0.027237354085603124},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"985","typeID":"Arrow","zOrder":"131","w":"29","h":"229","measuredW":"150","measuredH":"100","x":"824","y":"2678","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":228},"p1":{"x":0.4409025564097753,"y":-0.09294330895680976},"p2":{"x":15,"y":0},"rightArrow":"false"}},{"ID":"986","typeID":"Arrow","zOrder":"133","h":"33","measuredW":"150","measuredH":"100","x":"1049","y":"3040","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":149,"y":32},"p1":{"x":0.5905801701155262,"y":-0.014345563031611016},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"987","typeID":"Arrow","zOrder":"134","w":"141","h":"16","measuredW":"150","measuredH":"100","x":"1054","y":"3022","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":140,"y":0},"p1":{"x":0.5446556671449067,"y":-0.004842180774748907},"p2":{"x":0,"y":15},"rightArrow":"false","stroke":"dotted"}},{"ID":"988","typeID":"Arrow","zOrder":"135","w":"144","h":"60","measuredW":"150","measuredH":"100","x":"1048","y":"2973","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":143,"y":0},"p1":{"x":0.5359734790789354,"y":0.012722874294418268},"p2":{"x":0,"y":59},"rightArrow":"false","stroke":"dotted"}},{"ID":"1001","typeID":"Arrow","zOrder":"140","w":"2","h":"104","measuredW":"150","measuredH":"100","x":"564","y":"3059","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.523291249455812,"y":0.00130605137135394},"p2":{"x":1,"y":103},"rightArrow":"false"}},{"ID":"1002","typeID":"Arrow","zOrder":"141","w":"180","h":"45","measuredW":"150","measuredH":"100","x":"280","y":"3052","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":44},"p1":{"x":0.4319942611190816,"y":-0.0061692969870875015},"p2":{"x":179,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"1003","typeID":"Arrow","zOrder":"142","w":"87","h":"128","measuredW":"150","measuredH":"100","x":"995","y":"2689","properties":{"color":"2848996","leftArrow":"false","p0":{"x":86,"y":127},"p1":{"x":0.3984434389140272,"y":0.2406877828054298},"p2":{"x":1,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"1004","typeID":"Arrow","zOrder":"143","w":"71","h":"81","measuredW":"150","measuredH":"100","x":"1007","y":"2686","properties":{"color":"2848996","leftArrow":"false","p0":{"x":70,"y":80},"p1":{"x":0.4436256975246818,"y":0.1679067105451423},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"1005","typeID":"Arrow","zOrder":"144","w":"98","h":"1","measuredW":"150","measuredH":"100","x":"997","y":"2676","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":97,"y":0},"p1":{"x":0.48351933558266286,"y":0.007267064624967593},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"1006","typeID":"Arrow","zOrder":"146","w":"134","h":"109","measuredW":"150","measuredH":"100","x":"697","y":"2562","properties":{"color":"2848996","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.6566784235546694,"y":0.1877932832387666},"p2":{"x":132,"y":108},"rightArrow":"false"}},{"ID":"1007","typeID":"Arrow","zOrder":"147","w":"1","h":"86","measuredW":"150","measuredH":"100","x":"554","y":"2562","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4770488047048041,"y":0.005193614908729856},"p2":{"x":0,"y":85},"rightArrow":"false","stroke":"dotted"}},{"ID":"1008","typeID":"Arrow","zOrder":"148","w":"177","h":"1","measuredW":"150","measuredH":"100","x":"358","y":"2552","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":176,"y":0},"p1":{"x":0.477048804704804,"y":0.005193614908729856},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"1009","typeID":"Arrow","zOrder":"150","w":"116","h":"1","measuredW":"150","measuredH":"100","x":"729","y":"2551","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":115,"y":0},"p1":{"x":0.477048804704804,"y":0.005193614908729856},"p2":{"x":0,"y":0},"rightArrow":"false"}},{"ID":"1010","typeID":"Arrow","zOrder":"151","w":"119","h":"88","measuredW":"150","measuredH":"100","x":"800","y":"2446","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":118,"y":87},"p1":{"x":0.3818452519424929,"y":-0.18457172102545016},"p2":{"x":0,"y":0},"rightArrow":"false"}},{"ID":"1011","typeID":"Arrow","zOrder":"152","w":"76","h":"5","measuredW":"150","measuredH":"100","x":"343","y":"2366","properties":{"color":"10027263","direction":"bottom","leftArrow":"false","p0":{"x":74,"y":1},"p1":{"x":0.5049180327868853,"y":-0.02090163934426228},"p2":{"x":0,"y":3},"rightArrow":"false","stroke":"dotted"}},{"ID":"1012","typeID":"Arrow","zOrder":"154","w":"1","h":"81","measuredW":"150","measuredH":"100","x":"616","y":"2209","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5750000000000001,"y":0},"p2":{"x":0,"y":80},"rightArrow":"false"}},{"ID":"1013","typeID":"Arrow","zOrder":"155","w":"191","h":"3","measuredW":"150","measuredH":"100","x":"682","y":"2199","properties":{"color":"10027263","curvature":"0","leftArrow":"false","p0":{"x":190,"y":2},"p1":{"x":0.5105398742417108,"y":-0.0025761059250436276},"p2":{"x":0,"y":1},"rightArrow":"false","stroke":"dotted"}},{"ID":"1066","typeID":"Arrow","zOrder":"164","w":"79","h":"16","measuredW":"150","measuredH":"100","x":"1026","y":"2558","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4835193355826628,"y":0.007267064624967568},"p2":{"x":78,"y":15},"rightArrow":"false","stroke":"dotted"}},{"ID":"1067","typeID":"Arrow","zOrder":"165","w":"85","h":"23","measuredW":"150","measuredH":"100","x":"1030","y":"2528","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":84,"y":0},"p1":{"x":0.48351933558266297,"y":0.007267064624967475},"p2":{"x":0,"y":22},"rightArrow":"false","stroke":"dotted"}},{"ID":"1095","typeID":"Arrow","zOrder":"172","w":"66","h":"23","measuredW":"150","measuredH":"100","x":"1169","y":"2677","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":65,"y":22},"p1":{"x":0.4835193355826627,"y":0.007267064624967518},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"1096","typeID":"Arrow","zOrder":"173","w":"96","h":"27","measuredW":"150","measuredH":"100","x":"1168","y":"2651","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":95,"y":0},"p1":{"x":0.48351933558266286,"y":0.007267064624967588},"p2":{"x":0,"y":26},"rightArrow":"false","stroke":"dotted"}},{"ID":"1103","typeID":"Arrow","zOrder":"177","w":"65","h":"4","measuredW":"150","measuredH":"100","x":"1172","y":"2763","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":3},"p1":{"x":0.4807692307692308,"y":-0.01923076923076923},"p2":{"x":64,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"1108","typeID":"Arrow","zOrder":"179","w":"65","h":"2","measuredW":"150","measuredH":"100","x":"1172","y":"2819","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4807692307692308,"y":-0.01923076923076923},"p2":{"x":64,"y":1},"rightArrow":"false","stroke":"dotted"}},{"ID":"1113","typeID":"Arrow","zOrder":"181","w":"87","h":"43","measuredW":"150","measuredH":"100","x":"673","y":"3175","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.43199426111908185,"y":-0.006169296987087567},"p2":{"x":86,"y":42},"rightArrow":"false","stroke":"dotted"}},{"ID":"1114","typeID":"Arrow","zOrder":"182","w":"95","h":"8","measuredW":"150","measuredH":"100","x":"666","y":"3165","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.43199426111908185,"y":-0.006169296987087555},"p2":{"x":94,"y":7},"rightArrow":"false","stroke":"dotted"}},{"ID":"1115","typeID":"Arrow","zOrder":"183","w":"98","h":"36","measuredW":"150","measuredH":"100","x":"665","y":"3129","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":35},"p1":{"x":0.4319942611190818,"y":-0.006169296987087552},"p2":{"x":97,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"1122","typeID":"Arrow","zOrder":"186","w":"179","h":"2","measuredW":"150","measuredH":"100","x":"280","y":"3045","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":1},"p1":{"x":0.431994261119082,"y":-0.006169296987087527},"p2":{"x":178,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"1123","typeID":"Arrow","zOrder":"187","w":"161","h":"34","measuredW":"150","measuredH":"100","x":"286","y":"3002","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4319942611190819,"y":-0.006169296987087513},"p2":{"x":160,"y":33},"rightArrow":"false","stroke":"dotted"}},{"ID":"1141","typeID":"Arrow","zOrder":"191","w":"2","h":"89","measuredW":"150","measuredH":"100","x":"296","y":"3529","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":1,"y":88},"p1":{"x":0.4072427393330943,"y":0.00953746862674794},"p2":{"x":1,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"1142","typeID":"Arrow","zOrder":"1","w":"166","h":"171","measuredW":"150","measuredH":"100","x":"279","y":"3163","properties":{"color":"2848996","direction":"bottom","leftArrow":"false","p0":{"x":165,"y":0},"p1":{"x":0.5101799412144239,"y":-0.2666499390637321},"p2":{"x":1,"y":170},"rightArrow":"false"}},{"ID":"1143","typeID":"Arrow","zOrder":"192","w":"8","h":"166","measuredW":"150","measuredH":"100","x":"286","y":"3351","properties":{"color":"2848996","curvature":"0","leftArrow":"false","p0":{"x":7,"y":165},"p1":{"x":0.4072427393330943,"y":0.009537468626747932},"p2":{"x":0,"y":0},"rightArrow":"false"}},{"ID":"1395","typeID":"Arrow","zOrder":"199","w":"128","h":"180","measuredW":"150","measuredH":"100","x":"1055","y":"3064","properties":{"color":"2848996","leftArrow":"false","p0":{"x":128,"y":180},"p1":{"x":0.56420233463035,"y":0.027237354085603037},"p2":{"x":0.142857142856883,"y":-0.12135922330026006},"rightArrow":"false","stroke":"dotted"}},{"ID":"1396","typeID":"__group__","zOrder":"114","measuredW":"408","measuredH":"162","w":"408","h":"162","x":"151","y":"183","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"408","h":"162","measuredW":"100","measuredH":"70","x":"0","y":"0"},{"ID":"1","typeID":"Icon","zOrder":"1","measuredW":"24","measuredH":"24","x":"23","y":"21","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"23","y":"21","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}},{"ID":"3","typeID":"Label","zOrder":"3","measuredW":"269","measuredH":"24","x":"59","y":"21","properties":{"size":"16","text":"Personal Recommendation / Opinion"}},{"ID":"4","typeID":"Label","zOrder":"4","measuredW":"159","measuredH":"24","x":"59","y":"118","properties":{"size":"16","text":"I wouldn't recommend"}},{"ID":"5","typeID":"Icon","zOrder":"5","measuredW":"24","measuredH":"24","x":"23","y":"118","properties":{"color":"10066329","icon":{"ID":"circle","size":"small"}}},{"ID":"6","typeID":"Label","zOrder":"6","w":"324","measuredW":"315","measuredH":"24","x":"60","y":"86","properties":{"size":"16","text":"Order in roadmap not strict (Learn anytime)"}},{"ID":"7","typeID":"Icon","zOrder":"7","measuredW":"24","measuredH":"24","x":"23","y":"86","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"8","typeID":"Icon","zOrder":"8","measuredW":"24","measuredH":"24","x":"23","y":"86","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}},{"ID":"9","typeID":"Label","zOrder":"9","measuredW":"272","measuredH":"24","x":"59","y":"54","properties":{"size":"16","text":"Alternative Option - Pick this or purple"}},{"ID":"10","typeID":"Icon","zOrder":"10","measuredW":"24","measuredH":"24","x":"23","y":"53","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"11","typeID":"Icon","zOrder":"11","measuredW":"24","measuredH":"24","x":"23","y":"53","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"12","typeID":"Icon","zOrder":"12","measuredW":"24","measuredH":"24","x":"23","y":"53","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1398","typeID":"__group__","zOrder":"93","measuredW":"320","measuredH":"45","w":"320","h":"45","x":"948","y":"250","properties":{"controlName":"ext_link:roadmap.sh"},"children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"320","h":"45","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"borderColor":"4273622","color":"4273622"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"105","measuredH":"28","x":"139","y":"8","properties":{"color":"16777215","size":"20","text":"roadmap.sh"}},{"ID":"2","typeID":"Label","zOrder":"2","measuredW":"35","measuredH":"28","x":"76","y":"8","properties":{"color":"16777215","size":"20","text":"http"}},{"ID":"3","typeID":"Label","zOrder":"3","measuredW":"5","measuredH":"28","x":"113","y":"8","properties":{"bold":"true","color":"16777215","size":"20","text":":"}},{"ID":"4","typeID":"Label","zOrder":"4","measuredW":"10","measuredH":"28","x":"120","y":"9","properties":{"color":"16777215","size":"20","text":"/"}},{"ID":"5","typeID":"Label","zOrder":"5","measuredW":"10","measuredH":"28","x":"128","y":"9","properties":{"color":"16777215","size":"20","text":"/"}}]}}},{"ID":"1399","typeID":"__group__","zOrder":"74","measuredW":"145","measuredH":"40","w":"145","h":"40","x":"624","y":"273","properties":{"controlName":"roadmap:frontend"},"children":{"controls":{"control":[{"ID":"0","typeID":"Label","zOrder":"0","measuredW":"145","measuredH":"40","x":"0","y":"0","properties":{"size":"32","text":"Front-end","bold":"true"}}]}}},{"ID":"1400","typeID":"__group__","zOrder":"95","measuredW":"306","measuredH":"53","w":"306","h":"53","x":"153","y":"391","properties":{"controlName":"100-internet:how-does-the-internet-work"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"299","h":"44","measuredW":"200","measuredH":"140","x":"7","y":"9","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"223","measuredW":"219","measuredH":"25","x":"45","y":"19","properties":{"size":"17","text":"How does the internet work?"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1401","typeID":"__group__","zOrder":"94","measuredW":"187","measuredH":"60","w":"187","h":"60","x":"564","y":"439","properties":{"controlName":"100-internet"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"178","h":"50","measuredW":"200","measuredH":"140","x":"9","y":"10","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"75","measuredW":"63","measuredH":"25","x":"64","y":"23","properties":{"size":"17","text":"Internet","bold":"true"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1402","typeID":"__group__","zOrder":"96","measuredW":"307","measuredH":"47","w":"307","h":"47","x":"152","y":"443","properties":{"controlName":"101-internet:what-is-http"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"299","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"7","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"119","measuredW":"113","measuredH":"25","x":"98","y":"15","properties":{"size":"17","text":"What is HTTP?"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1403","typeID":"__group__","zOrder":"97","measuredW":"307","measuredH":"48","w":"307","h":"48","x":"152","y":"488","properties":{"controlName":"102-internet:browsers-and-how-they-work"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"299","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"8","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"230","measuredW":"225","measuredH":"25","x":"42","y":"16","properties":{"size":"17","text":"Browsers and how they work?"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1404","typeID":"__group__","zOrder":"98","measuredW":"289","measuredH":"49","w":"289","h":"49","x":"875","y":"388","properties":{"controlName":"103-internet:dns-and-how-it-works"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"280","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"9","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"179","measuredW":"175","measuredH":"25","x":"51","y":"17","properties":{"size":"17","text":"DNS and how it works?"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"265","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"265","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1405","typeID":"__group__","zOrder":"99","measuredW":"289","measuredH":"45","w":"289","h":"45","x":"874","y":"438","properties":{"controlName":"104-internet:what-is-domain-name"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"280","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"5","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"189","measuredW":"180","measuredH":"25","x":"51","y":"13","properties":{"size":"17","text":"What is Domain Name?"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"265","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"265","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1406","typeID":"__group__","zOrder":"100","measuredW":"288","measuredH":"46","w":"288","h":"46","x":"875","y":"483","properties":{"controlName":"105-internet:what-is-hosting"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"280","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"6","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"133","measuredW":"126","measuredH":"25","x":"74","y":"14","properties":{"size":"17","text":"What is hosting?"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"264","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"264","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1407","typeID":"__group__","zOrder":"73","measuredW":"250","measuredH":"55","w":"250","h":"55","x":"543","y":"619","properties":{"controlName":"101-html"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"250","h":"55","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"47","measuredH":"25","x":"101","y":"16","properties":{"bold":"true","size":"17","text":"HTML"}}]}}},{"ID":"1409","typeID":"__group__","zOrder":"75","measuredW":"304","measuredH":"47","w":"304","h":"47","x":"152","y":"552","properties":{"controlName":"100-html:learn-the-basics"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"296","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"7","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"134","measuredW":"128","measuredH":"25","x":"90","y":"15","properties":{"size":"17","text":"Learn the basics"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1410","typeID":"__group__","zOrder":"76","measuredW":"304","measuredH":"45","w":"304","h":"45","x":"152","y":"601","properties":{"controlName":"101-html:writing-semantic-html"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"296","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"5","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"189","measuredW":"183","measuredH":"25","x":"63","y":"13","properties":{"size":"17","text":"Writing Semantic HTML"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1411","typeID":"__group__","zOrder":"77","measuredW":"304","measuredH":"45","w":"304","h":"45","x":"152","y":"647","properties":{"controlName":"102-html:forms-and-validations"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"296","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"5","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"172","measuredW":"169","measuredH":"25","x":"71","y":"13","properties":{"size":"17","text":"Forms and Validations"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1412","typeID":"__group__","zOrder":"78","measuredW":"304","measuredH":"49","w":"304","h":"49","x":"152","y":"690","properties":{"controlName":"103-html:conventions-and-best-practices"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"296","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"9","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"248","measuredW":"246","measuredH":"25","x":"33","y":"17","properties":{"size":"17","text":"Conventions and Best Practices"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1413","typeID":"__group__","zOrder":"101","measuredW":"288","measuredH":"48","w":"288","h":"48","x":"875","y":"581","properties":{"controlName":"104-html:accessibility"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"280","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"8","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"101","measuredW":"94","measuredH":"25","x":"89","y":"16","properties":{"size":"17","text":"Accessibility"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"264","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"264","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1415","typeID":"__group__","zOrder":"102","measuredW":"289","measuredH":"46","w":"289","h":"46","x":"875","y":"630","properties":{"controlName":"105-html:seo-basics"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"280","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"6","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"94","measuredW":"90","measuredH":"25","x":"93","y":"14","properties":{"size":"17","text":"SEO Basics"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"265","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"265","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1416","typeID":"__group__","zOrder":"79","measuredW":"250","measuredH":"50","w":"250","h":"50","x":"543","y":"681","properties":{"controlName":"102-css"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"250","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"33","measuredH":"25","x":"108","y":"14","properties":{"bold":"true","size":"17","text":"CSS"}}]}}},{"ID":"1417","typeID":"__group__","zOrder":"81","measuredW":"289","measuredH":"47","w":"289","h":"47","x":"875","y":"679","properties":{"controlName":"100-css:learn-the-basics"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"280","h":"43","measuredW":"200","measuredH":"140","x":"0","y":"4","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"140","measuredW":"128","measuredH":"25","x":"70","y":"13","properties":{"size":"17","text":"Learn the basics"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"265","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"265","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1418","typeID":"__group__","zOrder":"82","measuredW":"290","measuredH":"51","w":"290","h":"51","x":"874","y":"728","properties":{"controlName":"101-css:making-layouts"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"281","h":"47","measuredW":"200","measuredH":"140","x":"0","y":"4","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"130","measuredW":"120","measuredH":"25","x":"76","y":"15","properties":{"size":"17","text":"Making Layouts"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"266","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"266","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1419","typeID":"__group__","zOrder":"86","measuredW":"288","measuredH":"45","w":"288","h":"45","x":"874","y":"783","properties":{"controlName":"102-css:responsive-design-and-media-queries"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"280","h":"43","measuredW":"200","measuredH":"140","x":"0","y":"2","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"248","measuredW":"246","measuredH":"22","x":"18","y":"12","properties":{"size":"14","text":"Responsive design and Media Queries"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"264","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"264","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1420","typeID":"__group__","zOrder":"80","measuredW":"123","measuredH":"193","w":"123","h":"193","x":"1183","y":"652","properties":{"controlName":"101-css:making-layouts"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"116","h":"185","measuredW":"200","measuredH":"140","x":"0","y":"8","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"47","measuredH":"25","x":"35","y":"21","properties":{"size":"17","text":"Floats"}},{"ID":"2","typeID":"Label","zOrder":"2","measuredW":"84","measuredH":"25","x":"16","y":"48","properties":{"size":"17","text":"Positioning"}},{"ID":"3","typeID":"Label","zOrder":"3","measuredW":"56","measuredH":"25","x":"30","y":"75","properties":{"size":"17","text":"Display"}},{"ID":"4","typeID":"Label","zOrder":"4","measuredW":"82","measuredH":"25","x":"19","y":"102","properties":{"size":"17","text":"Box Model"}},{"ID":"5","typeID":"Label","zOrder":"5","measuredW":"70","measuredH":"25","x":"22","y":"129","properties":{"size":"17","text":"CSS Grid"}},{"ID":"6","typeID":"Label","zOrder":"6","measuredW":"65","measuredH":"25","x":"26","y":"156","properties":{"size":"17","text":"Flex Box"}},{"ID":"7","typeID":"Icon","zOrder":"7","measuredW":"24","measuredH":"24","x":"99","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"8","typeID":"Icon","zOrder":"8","measuredW":"24","measuredH":"24","x":"99","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1421","typeID":"__group__","zOrder":"87","measuredW":"250","measuredH":"50","w":"250","h":"50","x":"543","y":"738","properties":{"controlName":"103-javascript"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"250","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"82","measuredH":"25","x":"82","y":"13","properties":{"bold":"true","size":"17","text":"JavaScript"}}]}}},{"ID":"1424","typeID":"__group__","zOrder":"88","measuredW":"304","measuredH":"48","w":"304","h":"48","x":"152","y":"753","properties":{"controlName":"100-javascript:syntax-and-basic-constructs"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"296","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"8","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"228","measuredW":"219","measuredH":"25","x":"43","y":"16","properties":{"size":"17","text":"Syntax and Basic Constructs"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1425","typeID":"__group__","zOrder":"89","measuredW":"305","measuredH":"45","w":"305","h":"45","x":"152","y":"802","properties":{"controlName":"101-javascript:learn-dom-manipulation"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"297","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"5","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"197","measuredW":"193","measuredH":"25","x":"59","y":"13","properties":{"size":"17","text":"Learn DOM Manipulation"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1426","typeID":"__group__","zOrder":"91","measuredW":"304","measuredH":"45","w":"304","h":"45","x":"152","y":"849","properties":{"controlName":"102-javascript:learn-fetch-api-ajax-xhr"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"296","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"5","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"234","measuredW":"224","measuredH":"25","x":"40","y":"13","properties":{"size":"17","text":"Learn Fetch API / Ajax (XHR)"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1427","typeID":"__group__","zOrder":"92","measuredW":"305","measuredH":"47","w":"305","h":"47","x":"151","y":"895","properties":{"controlName":"103-javascript:es6-and-modular-javascript"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"296","h":"40","measuredW":"200","measuredH":"140","x":"9","y":"7","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"234","measuredW":"228","measuredH":"25","x":"41","y":"15","properties":{"size":"17","text":"ES6+ and modular JavaScript"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1428","typeID":"__group__","zOrder":"90","measuredW":"305","measuredH":"117","w":"305","h":"117","x":"151","y":"947","properties":{"controlName":"104-javascript:concepts"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"296","h":"113","measuredW":"200","measuredH":"140","x":"9","y":"4","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"247","measuredW":"246","measuredH":"25","x":"34","y":"49","properties":{"size":"17","text":"Hoisting, Event Bubbling, Scope,"}},{"ID":"2","typeID":"Label","zOrder":"2","w":"245","measuredW":"234","measuredH":"25","x":"36","y":"78","properties":{"size":"17","text":"Prototype, Shadow DOM, strict,"}},{"ID":"3","typeID":"Label","zOrder":"3","w":"202","measuredW":"195","measuredH":"25","x":"57","y":"19","properties":{"size":"17","text":"Understand the concepts"}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"5","typeID":"Icon","zOrder":"5","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1429","typeID":"__group__","zOrder":"107","measuredW":"336","measuredH":"77","w":"336","h":"77","x":"522","y":"882","properties":{"controlName":"104-version-control-systems"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"336","h":"77","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"201","measuredW":"189","measuredH":"25","x":"65","y":"15","properties":{"bold":"true","size":"17","text":"Version Control Systems"}},{"ID":"2","typeID":"Label","zOrder":"2","w":"292","measuredW":"285","measuredH":"23","x":"19","y":"40","properties":{"size":"15","text":"What are they and why you should use one"}}]}}},{"ID":"1430","typeID":"__group__","zOrder":"103","measuredW":"225","measuredH":"62","w":"225","h":"62","x":"513","y":"972","properties":{"controlName":"100-version-control-systems:basic-usage-of-git"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"216","h":"54","measuredW":"200","measuredH":"140","x":"9","y":"8","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"155","measuredW":"146","measuredH":"25","x":"40","y":"23","properties":{"bold":"true","size":"17","text":"Basic Usage of Git"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1431","typeID":"__group__","zOrder":"105","measuredW":"352","measuredH":"78","w":"352","h":"78","x":"885","y":"882","properties":{"controlName":"105-repo-hosting-services"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"352","h":"78","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"189","measuredW":"171","measuredH":"25","x":"77","y":"15","properties":{"bold":"true","size":"17","text":"Repo hosting services"}},{"ID":"2","typeID":"Label","zOrder":"2","w":"279","measuredW":"275","measuredH":"23","x":"32","y":"41","properties":{"size":"15","text":"Create account and Learn to use GitHub"}}]}}},{"ID":"1432","typeID":"__group__","zOrder":"104","measuredW":"240","measuredH":"58","w":"240","h":"58","x":"994","y":"974","properties":{"controlName":"100-repo-hosting-services:github"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"230","h":"49","measuredW":"200","measuredH":"140","x":"10","y":"9","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"64","measuredW":"55","measuredH":"25","x":"97","y":"22","properties":{"bold":"true","size":"17","text":"GitHub"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1433","typeID":"__group__","zOrder":"112","measuredW":"238","measuredH":"55","w":"238","h":"55","x":"996","y":"1033","properties":{"controlName":"101-repo-hosting-services:gitlab"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"230","h":"49","measuredW":"200","measuredH":"140","x":"8","y":"6","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"10066329"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"52","measuredH":"25","x":"93","y":"18","properties":{"bold":"true","color":"3355443","size":"17","text":"GitLab"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"230","h":"49","measuredW":"200","measuredH":"140","x":"8","y":"6","properties":{"backgroundAlpha":"0.25","borderColor":"6710886","color":"15658734"}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"5","typeID":"Icon","zOrder":"5","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1434","typeID":"__group__","zOrder":"111","measuredW":"238","measuredH":"54","w":"238","h":"54","x":"996","y":"1090","properties":{"controlName":"102-repo-hosting-services:bitbucket"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"230","h":"49","measuredW":"200","measuredH":"140","x":"8","y":"5","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"10066329"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"80","measuredW":"75","measuredH":"25","x":"83","y":"17","properties":{"bold":"true","color":"3355443","size":"17","text":"Bitbucket"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"230","h":"48","measuredW":"200","measuredH":"140","x":"8","y":"5","properties":{"backgroundAlpha":"0.25","borderColor":"6710886","color":"15658734"}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"5","typeID":"Icon","zOrder":"5","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1435","typeID":"__group__","zOrder":"113","measuredW":"381","measuredH":"62","w":"381","h":"62","x":"564","y":"1065","properties":{"controlName":"106-web-security-knowledge"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"372","h":"54","measuredW":"200","measuredH":"140","x":"9","y":"8","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"203","measuredW":"192","measuredH":"25","x":"94","y":"23","properties":{"bold":"true","size":"17","text":"Web Security Knowledge"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1437","typeID":"__group__","zOrder":"110","measuredW":"297","measuredH":"107","w":"297","h":"107","x":"160","y":"1108","properties":{"controlName":"package-managers"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"297","h":"107","measuredW":"200","measuredH":"140","x":"0","y":"0"},{"ID":"1","typeID":"Label","zOrder":"1","w":"261","measuredW":"244","measuredH":"25","x":"16","y":"14","properties":{"size":"17","text":"npm and yarn both are fine, pick"}},{"ID":"2","typeID":"Label","zOrder":"2","w":"132","measuredW":"127","measuredH":"25","x":"16","y":"67","properties":{"size":"17","text":"much difference."}},{"ID":"3","typeID":"Label","zOrder":"3","w":"248","measuredW":"226","measuredH":"25","x":"16","y":"41","properties":{"size":"17","text":"one or learn both, there is not"}}]}}},{"ID":"1438","typeID":"__group__","zOrder":"108","measuredW":"211","measuredH":"53","w":"211","h":"53","x":"508","y":"1244","properties":{"controlName":"107-package-managers"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"211","h":"53","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"154","measuredW":"150","measuredH":"25","x":"29","y":"14","properties":{"bold":"true","size":"17","text":"Package Managers"}}]}}},{"ID":"1439","typeID":"__group__","zOrder":"109","measuredW":"158","measuredH":"58","w":"158","h":"58","x":"228","y":"1229","properties":{"controlName":"100-package-managers:npm"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"151","h":"49","measuredW":"200","measuredH":"140","x":"7","y":"9","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"36","measuredW":"34","measuredH":"25","x":"64","y":"21","properties":{"bold":"true","size":"17","text":"npm"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1440","typeID":"__group__","zOrder":"42","measuredW":"158","measuredH":"56","w":"158","h":"56","x":"228","y":"1290","properties":{"controlName":"101-package-managers:yarn"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"151","h":"49","measuredW":"200","measuredH":"140","x":"7","y":"7","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"36","measuredW":"34","measuredH":"25","x":"65","y":"19","properties":{"bold":"true","size":"17","text":"yarn"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1441","typeID":"__group__","zOrder":"136","measuredW":"392","measuredH":"141","w":"392","h":"141","x":"312","y":"1378","properties":{"controlName":"108-css-architecture"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"392","h":"141","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"148","measuredW":"133","measuredH":"25","x":"122","y":"18","properties":{"bold":"true","size":"17","text":"CSS Architecture"}},{"ID":"2","typeID":"Label","zOrder":"2","w":"351","measuredW":"335","measuredH":"23","x":"19","y":"51","properties":{"size":"15","text":"With modern frameworks and CSS-in-JS you don't"}},{"ID":"3","typeID":"Label","zOrder":"3","w":"359","measuredW":"344","measuredH":"23","x":"19","y":"77","properties":{"size":"15","text":"have to worry about these anymore but still it would"}},{"ID":"4","typeID":"Label","zOrder":"4","w":"359","measuredW":"347","measuredH":"23","x":"19","y":"103","properties":{"size":"15","text":"be a good idea to get familiarized with BEM atleast."}}]}}},{"ID":"1442","typeID":"__group__","zOrder":"137","measuredW":"156","measuredH":"48","w":"156","h":"48","x":"141","y":"1369","properties":{"controlName":"100-css-architecture:bem"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"146","h":"40","measuredW":"200","measuredH":"140","x":"10","y":"8","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"45","measuredW":"38","measuredH":"25","x":"66","y":"16","properties":{"size":"17","text":"BEM"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1443","typeID":"__group__","zOrder":"139","measuredW":"145","measuredH":"44","w":"145","h":"44","x":"152","y":"1423","properties":{"controlName":"101-css-architecture:oocss"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"145","h":"44","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"10066329"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"62","measuredW":"58","measuredH":"25","x":"42","y":"10","properties":{"bold":"true","color":"3355443","size":"17","text":"OOCSS"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"145","h":"44","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.25","borderColor":"6710886","color":"15658734"}}]}}},{"ID":"1444","typeID":"__group__","zOrder":"138","measuredW":"145","measuredH":"44","w":"145","h":"44","x":"151","y":"1474","properties":{"controlName":"102-css-architecture:smacss"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"145","h":"44","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"10066329"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"73","measuredW":"68","measuredH":"25","x":"36","y":"10","properties":{"bold":"true","color":"3355443","size":"17","text":"SMACSS"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"145","h":"44","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.25","borderColor":"6710886","color":"15658734"}}]}}},{"ID":"1445","typeID":"__group__","zOrder":"132","measuredW":"392","measuredH":"141","w":"392","h":"141","x":"723","y":"1381","properties":{"controlName":"109-css-preprocessors"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"392","h":"141","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"157","measuredW":"151","measuredH":"25","x":"113","y":"17","properties":{"bold":"true","size":"17","text":"CSS Preprocessors"}},{"ID":"2","typeID":"Label","zOrder":"2","w":"350","measuredW":"332","measuredH":"23","x":"18","y":"49","properties":{"size":"15","text":"With how the modern frameworks there has been"}},{"ID":"3","typeID":"Label","zOrder":"3","w":"356","measuredW":"344","measuredH":"23","x":"18","y":"76","properties":{"size":"15","text":"more push towards CSS-in-JS so you may not need"}},{"ID":"4","typeID":"Label","zOrder":"4","w":"350","measuredW":"324","measuredH":"23","x":"18","y":"102","properties":{"size":"15","text":"these but still a good idea to familiarize yourself."}}]}}},{"ID":"1446","typeID":"__group__","zOrder":"248","measuredW":"156","measuredH":"48","w":"156","h":"48","x":"1147","y":"1374","properties":{"controlName":"100-css-preprocessors:sass"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"146","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"7","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"46","measuredW":"37","measuredH":"25","x":"50","y":"15","properties":{"size":"17","text":"Sass"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"132","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"132","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1447","typeID":"__group__","zOrder":"247","measuredW":"155","measuredH":"48","w":"155","h":"48","x":"1147","y":"1423","properties":{"controlName":"101-css-preprocessors:postcss"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"146","h":"43","measuredW":"200","measuredH":"140","x":"0","y":"5","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"74","measuredW":"66","measuredH":"25","x":"39","y":"15","properties":{"size":"17","text":"PostCSS"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"131","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"131","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1448","typeID":"__group__","zOrder":"175","measuredW":"145","measuredH":"44","w":"145","h":"44","x":"1148","y":"1476","properties":{"controlName":"102-css-preprocessors:less"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"145","h":"44","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"10066329"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"41","measuredW":"37","measuredH":"25","x":"52","y":"10","properties":{"bold":"true","color":"3355443","size":"17","text":"Less"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"145","h":"44","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.25","borderColor":"6710886","color":"15658734"}}]}}},{"ID":"1449","typeID":"__group__","zOrder":"145","measuredW":"214","measuredH":"50","w":"214","h":"50","x":"596","y":"1603","properties":{"controlName":"110-build-tools"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"214","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"85","measuredH":"25","x":"62","y":"13","properties":{"bold":"true","size":"17","text":"Build Tools"}}]}}},{"ID":"1450","typeID":"__group__","zOrder":"149","measuredW":"138","measuredH":"50","w":"138","h":"50","x":"365","y":"1546","properties":{"controlName":"100-build-tools:task-runners"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"138","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"105","measuredH":"25","x":"17","y":"14","properties":{"bold":"true","size":"17","text":"Task Runners"}}]}}},{"ID":"1451","typeID":"__group__","zOrder":"156","measuredW":"225","measuredH":"50","w":"225","h":"50","x":"868","y":"1604","properties":{"controlName":"102-build-tools:linters-formatters"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"225","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"179","measuredH":"25","x":"19","y":"13","properties":{"bold":"true","size":"17","text":"Linters and Formatters"}}]}}},{"ID":"1452","typeID":"__group__","zOrder":"157","measuredW":"155","measuredH":"46","w":"155","h":"46","x":"1150","y":"1549","properties":{"controlName":"100-build-tools:linters-formatters:prettier"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"145","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"6","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"66","measuredW":"58","measuredH":"25","x":"44","y":"14","properties":{"size":"17","text":"Prettier"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"131","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"131","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1453","typeID":"__group__","zOrder":"158","measuredW":"155","measuredH":"44","w":"155","h":"44","x":"1150","y":"1596","properties":{"controlName":"101-build-tools:linters-formatters:eslint"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"145","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"4","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"53","measuredW":"51","measuredH":"25","x":"46","y":"12","properties":{"size":"17","text":"ESLint"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"131","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"131","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1454","typeID":"__group__","zOrder":"159","measuredW":"145","measuredH":"44","w":"145","h":"44","x":"1151","y":"1646","properties":{"controlName":"102-build-tools:linters-formatters:standardjs"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"145","h":"44","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"10066329"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"91","measuredH":"25","x":"26","y":"10","properties":{"bold":"true","color":"3355443","size":"17","text":"StandardJS"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"145","h":"44","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.25","borderColor":"6710886","color":"15658734"}}]}}},{"ID":"1455","typeID":"__group__","zOrder":"153","measuredW":"183","measuredH":"56","w":"183","h":"56","x":"146","y":"1536","properties":{"controlName":"100-build-tools:task-runners:npm-scripts"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"176","h":"45","measuredW":"200","measuredH":"140","x":"7","y":"11","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"97","measuredW":"89","measuredH":"25","x":"47","y":"21","properties":{"size":"17","text":"npm scripts"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1457","typeID":"__group__","zOrder":"163","measuredW":"177","measuredH":"50","w":"177","h":"50","x":"411","y":"1723","properties":{"controlName":"101-build-tools:module-bundlers"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"177","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"133","measuredH":"25","x":"23","y":"13","properties":{"bold":"true","size":"17","text":"Module Bundlers"}}]}}},{"ID":"1458","typeID":"__group__","zOrder":"160","measuredW":"185","measuredH":"47","w":"185","h":"47","x":"143","y":"1601","properties":{"controlName":"100-build-tools:module-bundlers:webpack"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"176","h":"40","measuredW":"200","measuredH":"140","x":"9","y":"7","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"72","measuredW":"72","measuredH":"25","x":"61","y":"15","properties":{"size":"17","text":"Webpack"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"176","h":"40","measuredW":"200","measuredH":"140","x":"9","y":"7","properties":{"color":"16776960"}},{"ID":"3","typeID":"Label","zOrder":"3","w":"90","measuredW":"72","measuredH":"25","x":"61","y":"15","properties":{"size":"17","text":"Webpack"}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"5","typeID":"Icon","zOrder":"5","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1465","typeID":"__group__","zOrder":"250","measuredW":"185","measuredH":"47","w":"185","h":"47","x":"142","y":"1648","properties":{"controlName":"101-build-tools:module-bundlers:esbuild"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"176","h":"40","measuredW":"200","measuredH":"140","x":"9","y":"7","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"72","measuredW":"72","measuredH":"25","x":"61","y":"15","properties":{"size":"17","text":"Webpack"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"176","h":"40","measuredW":"200","measuredH":"140","x":"9","y":"7","properties":{"color":"16776960"}},{"ID":"3","typeID":"Label","zOrder":"3","measuredW":"55","measuredH":"25","x":"69","y":"14","properties":{"size":"17","text":"esbuild"}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"5","typeID":"Icon","zOrder":"5","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1468","typeID":"__group__","zOrder":"161","measuredW":"184","measuredH":"44","w":"184","h":"44","x":"143","y":"1696","properties":{"controlName":"102-build-tools:module-bundlers:rollup"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"176","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"4","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"46","measuredW":"49","measuredH":"25","x":"73","y":"12","properties":{"size":"17","text":"Rollup"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"176","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"4","properties":{"color":"16770457"}},{"ID":"3","typeID":"Label","zOrder":"3","w":"63","measuredW":"49","measuredH":"25","x":"73","y":"12","properties":{"size":"17","text":"Rollup"}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"5","typeID":"Icon","zOrder":"5","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"6","typeID":"Icon","zOrder":"6","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1469","typeID":"__group__","zOrder":"162","measuredW":"184","measuredH":"44","w":"184","h":"44","x":"143","y":"1741","properties":{"controlName":"103-build-tools:module-bundlers:parcel"},"children":{"controls":{"control":[{"ID":"0","typeID":"Label","zOrder":"0","w":"46","measuredW":"49","measuredH":"25","x":"73","y":"12","properties":{"size":"17","text":"Parcel"}},{"ID":"1","typeID":"TextArea","zOrder":"1","w":"176","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"4","properties":{"color":"16770457"}},{"ID":"2","typeID":"Label","zOrder":"2","w":"63","measuredW":"49","measuredH":"25","x":"73","y":"12","properties":{"size":"17","text":"Parcel"}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"5","typeID":"Icon","zOrder":"5","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1470","typeID":"Arrow","zOrder":"4","w":"111","h":"37","measuredW":"150","measuredH":"100","x":"307","y":"1714","properties":{"color":"10027263","direction":"bottom","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":0},"p1":{"x":0.40594249201277954,"y":-0.011437699680511181},"p2":{"x":111,"y":37}}},{"ID":"1471","typeID":"__group__","zOrder":"251","measuredW":"184","measuredH":"44","w":"184","h":"44","x":"143","y":"1787","properties":{"controlName":"104-build-tools:module-bundlers:vite"},"children":{"controls":{"control":[{"ID":"0","typeID":"Label","zOrder":"0","w":"46","measuredW":"49","measuredH":"25","x":"73","y":"12","properties":{"size":"17","text":"Parcel"}},{"ID":"1","typeID":"TextArea","zOrder":"1","w":"176","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"4","properties":{"color":"16770457"}},{"ID":"2","typeID":"Label","zOrder":"2","measuredW":"30","measuredH":"25","x":"81","y":"11","properties":{"size":"17","text":"Vite"}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"5","typeID":"Icon","zOrder":"5","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1473","typeID":"Arrow","zOrder":"3","w":"114","h":"62","measuredW":"150","measuredH":"100","x":"311","y":"1749","properties":{"color":"10027263","direction":"bottom","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":62},"p1":{"x":0.4230344065220394,"y":-0.06791488185712315},"p2":{"x":114,"y":0}}},{"ID":"1474","typeID":"__group__","zOrder":"166","measuredW":"267","measuredH":"53","w":"267","h":"53","x":"622","y":"1840","properties":{"controlName":"111-pick-a-framework"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"267","h":"53","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"142","measuredW":"138","measuredH":"25","x":"63","y":"14","properties":{"bold":"true","size":"17","text":"Pick a Framework"}}]}}},{"ID":"1475","typeID":"__group__","zOrder":"167","measuredW":"152","measuredH":"48","w":"152","h":"48","x":"913","y":"1742","properties":{"controlName":"100-pick-a-framework:react-js"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"145","h":"40","measuredW":"200","measuredH":"140","x":"7","y":"8","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"68","measuredW":"62","measuredH":"25","x":"46","y":"16","properties":{"size":"17","text":"React.js"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1483","typeID":"__group__","zOrder":"252","measuredW":"93","measuredH":"41","w":"93","h":"41","x":"1246","y":"1770","properties":{"controlName":"102-pick-a-framework:react-js:recoil"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"85","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"1","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"49","measuredH":"25","x":"14","y":"8","properties":{"size":"17","text":"Recoil"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"69","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"69","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"69","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1484","typeID":"__group__","zOrder":"170","measuredW":"185","measuredH":"47","w":"185","h":"47","x":"1155","y":"1719","properties":{"controlName":"100-pick-a-framework:react-js:redux"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"177","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"7","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"52","measuredW":"50","measuredH":"25","x":"63","y":"15","properties":{"size":"17","text":"Redux"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"161","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"161","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1486","typeID":"__group__","zOrder":"171","measuredW":"88","measuredH":"43","w":"88","h":"43","x":"1155","y":"1768","properties":{"controlName":"101-pick-a-framework:react-js:mobx"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"84","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"3","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"47","measuredW":"44","measuredH":"25","x":"13","y":"10","properties":{"size":"17","text":"MobX"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"64","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"64","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"64","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1487","typeID":"__group__","zOrder":"168","measuredW":"153","measuredH":"50","w":"153","h":"50","x":"944","y":"1833","properties":{"controlName":"101-pick-a-framework:angular"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"145","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"10","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"64","measuredW":"59","measuredH":"25","x":"49","y":"18","properties":{"size":"17","text":"Angular"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1488","typeID":"__group__","zOrder":"178","measuredW":"185","measuredH":"48","w":"185","h":"48","x":"1155","y":"1818","properties":{"controlName":"100-pick-a-framework:angular:rxjs"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"177","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"8","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"44","measuredW":"40","measuredH":"25","x":"67","y":"16","properties":{"size":"17","text":"RxJS"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"161","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"161","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"161","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1489","typeID":"__group__","zOrder":"180","measuredW":"185","measuredH":"44","w":"185","h":"44","x":"1155","y":"1868","properties":{"controlName":"101-pick-a-framework:angular:ngrx"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"177","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"4","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"46","measuredW":"43","measuredH":"25","x":"67","y":"12","properties":{"size":"17","text":"NgRx"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"161","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"161","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"161","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1490","typeID":"__group__","zOrder":"169","measuredW":"152","measuredH":"50","w":"152","h":"50","x":"945","y":"1917","properties":{"controlName":"102-pick-a-framework:vue-js"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"145","h":"40","measuredW":"200","measuredH":"140","x":"7","y":"10","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"45","measuredH":"25","x":"58","y":"17","properties":{"text":"Vue.js","size":"17"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1491","typeID":"__group__","zOrder":"176","measuredW":"185","measuredH":"49","w":"185","h":"49","x":"1155","y":"1918","properties":{"controlName":"100-pick-a-framework:vue-js:vuex"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"177","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"9","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"44","measuredW":"39","measuredH":"25","x":"64","y":"18","properties":{"size":"17","text":"VueX"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"161","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"161","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"161","y":"0","properties":{"color":"40463","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1492","typeID":"__group__","zOrder":"174","measuredW":"203","measuredH":"50","w":"203","h":"50","x":"483","y":"1942","properties":{"controlName":"112-modern-css"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"203","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"98","measuredH":"25","x":"53","y":"13","properties":{"bold":"true","size":"17","text":"Modern CSS"}}]}}},{"ID":"1493","typeID":"__group__","zOrder":"184","measuredW":"229","measuredH":"48","w":"229","h":"48","x":"141","y":"1856","properties":{"controlName":"100-modern-css:styled-components"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"221","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"8","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"151","measuredW":"150","measuredH":"25","x":"43","y":"16","properties":{"size":"17","text":"Styled Components"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1494","typeID":"__group__","zOrder":"185","measuredW":"230","measuredH":"44","w":"230","h":"44","x":"140","y":"1904","properties":{"controlName":"101-modern-css:css-modules"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"221","h":"40","measuredW":"200","measuredH":"140","x":"9","y":"4","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"103","measuredW":"103","measuredH":"25","x":"68","y":"12","properties":{"size":"17","text":"CSS Modules"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1495","typeID":"__group__","zOrder":"249","measuredW":"230","measuredH":"44","w":"230","h":"44","x":"139","y":"1950","properties":{"controlName":"102-modern-css:styled-jsx"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"221","h":"40","measuredW":"200","measuredH":"140","x":"9","y":"4","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"90","measuredW":"80","measuredH":"25","x":"75","y":"12","properties":{"size":"17","text":"Styled JSX"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1496","typeID":"__group__","zOrder":"188","measuredW":"229","measuredH":"44","w":"229","h":"44","x":"140","y":"1996","properties":{"controlName":"103-modern-css:emotion"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"221","h":"40","measuredW":"200","measuredH":"140","x":"8","y":"4","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"64","measuredH":"25","x":"88","y":"12","properties":{"text":"Emotion","size":"17"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1497","typeID":"__group__","zOrder":"242","measuredW":"238","measuredH":"60","w":"238","h":"60","x":"722","y":"2028","properties":{"controlName":"113-web-components"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"230","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"10","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"138","measuredH":"25","x":"44","y":"23","properties":{"bold":"true","size":"17","text":"Web Components"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"214","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"214","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1498","typeID":"__group__","zOrder":"243","measuredW":"199","measuredH":"46","w":"199","h":"46","x":"1047","y":"1991","properties":{"controlName":"100-web-components:html-templates"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"190","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"6","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"132","measuredW":"131","measuredH":"25","x":"30","y":"14","properties":{"size":"17","text":"HTML Templates"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"175","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"175","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1499","typeID":"__group__","zOrder":"244","measuredW":"199","measuredH":"42","w":"199","h":"42","x":"1047","y":"2040","properties":{"controlName":"101-web-components:custom-elements"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"190","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"2","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"139","measuredW":"136","measuredH":"25","x":"30","y":"10","properties":{"size":"17","text":"Custom Elements"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"175","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"175","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1500","typeID":"__group__","zOrder":"245","measuredW":"199","measuredH":"44","w":"199","h":"44","x":"1047","y":"2083","properties":{"controlName":"102-web-components:shadow-dom"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"190","h":"40","measuredW":"200","measuredH":"140","x":"0","y":"4","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"105","measuredW":"105","measuredH":"25","x":"38","y":"12","properties":{"size":"17","text":"Shadow DOM"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"175","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"175","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1501","typeID":"__group__","zOrder":"200","measuredW":"261","measuredH":"50","w":"261","h":"50","x":"526","y":"2173","properties":{"controlName":"114-css-frameworks"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"261","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"132","measuredH":"25","x":"63","y":"13","properties":{"size":"17","text":"CSS Frameworks","bold":"true"}}]}}},{"ID":"1510","typeID":"__group__","zOrder":"207","measuredW":"213","measuredH":"42","w":"213","h":"42","x":"844","y":"2211","properties":{"controlName":"101-css-frameworks:js-first:chakra-ui"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"205","h":"39","measuredW":"200","measuredH":"140","x":"8","y":"3","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"78","measuredH":"25","x":"72","y":"11","properties":{"size":"17","text":"Chakra UI"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1511","typeID":"__group__","zOrder":"206","measuredW":"213","measuredH":"41","w":"213","h":"41","x":"844","y":"2256","properties":{"controlName":"102-css-frameworks:js-first:material-ui"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"205","h":"37","measuredW":"200","measuredH":"140","x":"8","y":"4","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"86","measuredH":"25","x":"68","y":"11","properties":{"size":"17","text":"Material UI"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1512","typeID":"__group__","zOrder":"253","measuredW":"213","measuredH":"41","w":"213","h":"41","x":"844","y":"2300","properties":{"controlName":"103-css-frameworks:js-first:radix-ui"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"205","h":"37","measuredW":"200","measuredH":"140","x":"8","y":"4","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"66","measuredH":"25","x":"78","y":"11","properties":{"size":"17","text":"Radix UI"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1514","typeID":"__group__","zOrder":"205","measuredW":"210","measuredH":"46","w":"210","h":"46","x":"847","y":"2161","properties":{"controlName":"100-css-frameworks:js-first:tailwind-css"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"205","h":"40","measuredW":"200","measuredH":"140","x":"5","y":"6","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"98","measuredH":"25","x":"59","y":"13","properties":{"size":"17","text":"Tailwind CSS"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1532","typeID":"Arrow","zOrder":"2","w":"102","h":"1","measuredW":"150","measuredH":"100","x":"479","y":"2198","properties":{"color":"10027263","curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":101,"y":0},"p1":{"x":0.5105398742417109,"y":-0.0025761059250436276},"p2":{"x":-0.5,"y":0}}},{"ID":"1534","typeID":"__group__","zOrder":"202","measuredW":"130","measuredH":"57","w":"130","h":"57","x":"143","y":"2096","properties":{"controlName":"100-css-frameworks:css-first:bootstrap"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"127","h":"52","measuredW":"200","measuredH":"140","x":"0","y":"5","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"81","measuredW":"75","measuredH":"25","x":"27","y":"18","properties":{"size":"17","text":"Bootstrap"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"106","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"106","y":"0","properties":{"icon":{"ID":"check-circle","size":"small"},"color":"3700253"}}]}}},{"ID":"1535","typeID":"__group__","zOrder":"203","measuredW":"133","measuredH":"52","w":"133","h":"52","x":"143","y":"2155","properties":{"controlName":"101-css-frameworks:css-first:bulma"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"127","h":"49","measuredW":"200","measuredH":"140","x":"0","y":"3","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"50","measuredW":"49","measuredH":"25","x":"39","y":"15","properties":{"size":"17","text":"Bulma"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"109","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"109","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"109","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1537","typeID":"__group__","zOrder":"201","measuredW":"369","measuredH":"137","w":"369","h":"137","x":"127","y":"2086","properties":{"controlName":"114-css-frameworks:css-first"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"369","h":"137","measuredW":"200","measuredH":"140","x":"0","y":"0"},{"ID":"2","typeID":"Label","zOrder":"1","w":"206","measuredW":"195","measuredH":"24","x":"154","y":"13","properties":{"size":"16","text":"CSS first frameworks which"}},{"ID":"3","typeID":"Label","zOrder":"2","w":"206","measuredW":"192","measuredH":"24","x":"154","y":"41","properties":{"size":"16","text":"don't come with JavaScript"}},{"ID":"4","typeID":"Label","zOrder":"3","measuredW":"190","measuredH":"24","x":"154","y":"69","properties":{"size":"16","text":"framework components by"}},{"ID":"5","typeID":"Label","zOrder":"4","measuredW":"53","measuredH":"24","x":"153","y":"97","properties":{"size":"16","text":"default."}}]}}},{"ID":"1538","typeID":"__group__","zOrder":"204","measuredW":"236","measuredH":"281","w":"236","h":"281","x":"836","y":"2149","properties":{"controlName":"114-css-frameworks:js-first"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"236","h":"281","measuredW":"200","measuredH":"140","x":"0","y":"0"},{"ID":"1","typeID":"Label","zOrder":"1","w":"205","measuredW":"196","measuredH":"24","x":"16","y":"198","properties":{"size":"16","text":"JS based and better to use"}},{"ID":"2","typeID":"Label","zOrder":"2","w":"201","measuredW":"192","measuredH":"24","x":"16","y":"223","properties":{"size":"16","text":"with your framework based"}},{"ID":"3","typeID":"Label","zOrder":"3","w":"205","measuredW":"171","measuredH":"24","x":"16","y":"247","properties":{"size":"16","text":"JavaScript applications."}}]}}},{"ID":"1539","typeID":"__group__","zOrder":"213","measuredW":"405","measuredH":"158","w":"405","h":"158","x":"395","y":"2259","properties":{"controlName":"115-testing-your-apps"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"405","h":"158","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"144","measuredH":"26","x":"125","y":"19","properties":{"size":"18","text":"Testing your Apps","bold":"true"}},{"ID":"2","typeID":"Label","zOrder":"2","w":"349","measuredW":"328","measuredH":"25","x":"22","y":"86","properties":{"size":"17","text":"and {color:blue}Functional{color} tests and learn how to write"}},{"ID":"3","typeID":"Label","zOrder":"3","w":"302","measuredW":"275","measuredH":"25","x":"21","y":"115","properties":{"size":"17","text":"them with the tools listed on the left."}},{"ID":"4","typeID":"Label","zOrder":"4","w":"362","measuredW":"361","measuredH":"25","x":"21","y":"56","properties":{"size":"17","text":"Learn the difference between {color:blue}Unit{color}, {color:blue}Integration{color}, "}}]}}},{"ID":"1544","typeID":"__group__","zOrder":"208","measuredW":"247","measuredH":"257","w":"247","h":"257","x":"125","y":"2255","properties":{"controlName":"115-testing-your-apps"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"247","h":"257","measuredW":"200","measuredH":"140","x":"0","y":"0"},{"ID":"1","typeID":"Label","zOrder":"1","w":"205","measuredW":"185","measuredH":"24","x":"22","y":"193","properties":{"size":"16","text":"You can fill all your testing"}},{"ID":"2","typeID":"Label","zOrder":"2","w":"165","measuredW":"155","measuredH":"24","x":"22","y":"218","properties":{"size":"16","text":"needs with just these."}}]}}},{"ID":"1545","typeID":"__group__","zOrder":"211","measuredW":"223","measuredH":"46","w":"223","h":"46","x":"134","y":"2263","properties":{"controlName":"100-testing-your-apps:jest"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"216","h":"40","measuredW":"200","measuredH":"140","x":"7","y":"6","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"39","measuredW":"33","measuredH":"25","x":"96","y":"14","properties":{"size":"17","text":"Jest"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1546","typeID":"__group__","zOrder":"209","measuredW":"223","measuredH":"42","w":"223","h":"42","x":"134","y":"2312","properties":{"controlName":"101-testing-your-apps:react-testing-library"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"216","h":"40","measuredW":"200","measuredH":"140","x":"7","y":"2","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"164","measuredW":"152","measuredH":"25","x":"33","y":"10","properties":{"size":"17","text":"react-testing-library"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1547","typeID":"__group__","zOrder":"212","measuredW":"223","measuredH":"42","w":"223","h":"42","x":"134","y":"2355","properties":{"controlName":"102-testing-your-apps:cypress"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"216","h":"39","measuredW":"200","measuredH":"140","x":"7","y":"3","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"70","measuredW":"63","measuredH":"25","x":"81","y":"10","properties":{"size":"17","text":"Cypress"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1548","typeID":"__group__","zOrder":"210","measuredW":"223","measuredH":"41","w":"223","h":"41","x":"134","y":"2398","properties":{"controlName":"103-testing-your-apps:enzyme"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"216","h":"37","measuredW":"200","measuredH":"140","x":"7","y":"4","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"68","measuredW":"61","measuredH":"25","x":"82","y":"10","properties":{"size":"17","text":"Enzyme"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1549","typeID":"__group__","zOrder":"215","measuredW":"234","measuredH":"60","w":"234","h":"60","x":"819","y":"2517","properties":{"controlName":"116-type-checkers"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"226","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"10","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"115","measuredH":"25","x":"53","y":"23","properties":{"size":"17","bold":"true","text":"Type Checkers"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"210","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"210","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1550","typeID":"__group__","zOrder":"216","measuredW":"206","measuredH":"48","w":"206","h":"48","x":"1104","y":"2501","properties":{"controlName":"100-type-checkers:typescript"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"199","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"7","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"91","measuredW":"81","measuredH":"25","x":"54","y":"15","properties":{"size":"17","text":"TypeScript"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"182","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"182","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"156","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"5","typeID":"Icon","zOrder":"5","measuredW":"24","measuredH":"24","x":"156","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1551","typeID":"__group__","zOrder":"189","measuredW":"199","measuredH":"41","w":"199","h":"41","x":"1104","y":"2557","properties":{"controlName":"101-type-checkers:flow"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"199","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.5","color":"10066329"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"38","measuredW":"35","measuredH":"25","x":"81","y":"8","properties":{"color":"3355443","size":"17","text":"Flow"}}]}}},{"ID":"1552","typeID":"__group__","zOrder":"217","measuredW":"247","measuredH":"61","w":"247","h":"61","x":"496","y":"2516","properties":{"controlName":"117-progressive-web-apps"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"241","h":"50","measuredW":"200","measuredH":"140","x":"6","y":"11","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"173","measuredH":"25","x":"37","y":"24","properties":{"size":"17","text":"Progressive Web Apps","bold":"true"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1553","typeID":"__group__","zOrder":"219","measuredW":"269","measuredH":"290","w":"269","h":"290","x":"388","y":"2626","properties":{"controlName":"101-progressive-web-apps:performance"},"children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"262","h":"281","measuredW":"100","measuredH":"70","x":"7","y":"9"},{"ID":"1","typeID":"TextInput","zOrder":"1","w":"225","measuredW":"124","measuredH":"32","x":"27","y":"28","properties":{"align":"center","color":"16776960","size":"18","text":"PRPL Pattern"}},{"ID":"2","typeID":"TextInput","zOrder":"2","w":"225","measuredW":"110","measuredH":"32","x":"27","y":"66","properties":{"align":"center","color":"16776960","size":"18","text":"RAIL Model"}},{"ID":"3","typeID":"TextInput","zOrder":"3","w":"225","measuredW":"185","measuredH":"32","x":"27","y":"104","properties":{"align":"center","color":"16776960","size":"18","text":"Performance Metrics"}},{"ID":"4","typeID":"TextInput","zOrder":"4","w":"225","measuredW":"156","measuredH":"32","x":"27","y":"141","properties":{"align":"center","color":"16776960","size":"18","text":"Using Lighthouse"}},{"ID":"5","typeID":"TextInput","zOrder":"5","w":"225","measuredW":"141","measuredH":"32","x":"27","y":"179","properties":{"align":"center","color":"16776960","size":"18","text":"Using DevTools"}},{"ID":"6","typeID":"Label","zOrder":"6","w":"185","measuredW":"176","measuredH":"25","x":"47","y":"224","properties":{"size":"17","text":"Calculating, Measuring"}},{"ID":"7","typeID":"Label","zOrder":"7","w":"224","measuredW":"212","measuredH":"25","x":"27","y":"251","properties":{"size":"17","text":"and improving performance"}},{"ID":"8","typeID":"Icon","zOrder":"8","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"9","typeID":"Icon","zOrder":"9","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1554","typeID":"__group__","zOrder":"218","measuredW":"237","measuredH":"400","w":"237","h":"400","x":"134","y":"2516","properties":{"controlName":"100-progressive-web-apps:apis"},"children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"228","h":"389","measuredW":"100","measuredH":"70","x":"9","y":"11"},{"ID":"1","typeID":"TextInput","zOrder":"1","w":"177","measuredW":"147","measuredH":"32","x":"35","y":"100","properties":{"align":"center","color":"16776960","size":"18","text":"Service Workers"}},{"ID":"2","typeID":"TextInput","zOrder":"2","w":"177","measuredW":"78","measuredH":"32","x":"35","y":"26","properties":{"align":"center","color":"16776960","size":"18","text":"Storage"}},{"ID":"3","typeID":"TextInput","zOrder":"3","w":"177","measuredW":"84","measuredH":"32","x":"35","y":"137","properties":{"align":"center","color":"16770457","size":"18","text":"Location"}},{"ID":"4","typeID":"TextInput","zOrder":"4","w":"177","measuredW":"115","measuredH":"32","x":"35","y":"175","properties":{"align":"center","color":"16770457","size":"18","text":"Notifications"}},{"ID":"5","typeID":"TextInput","zOrder":"5","w":"177","measuredW":"167","measuredH":"32","x":"35","y":"212","properties":{"align":"center","color":"16770457","size":"18","text":"Device Orientation"}},{"ID":"6","typeID":"TextInput","zOrder":"6","w":"177","measuredW":"94","measuredH":"32","x":"35","y":"249","properties":{"align":"center","color":"16770457","size":"18","text":"Payments"}},{"ID":"7","typeID":"TextInput","zOrder":"7","w":"177","measuredW":"108","measuredH":"32","x":"35","y":"286","properties":{"align":"center","color":"16770457","size":"18","text":"Credentials"}},{"ID":"8","typeID":"TextInput","zOrder":"8","w":"177","measuredW":"120","measuredH":"32","x":"35","y":"63","properties":{"align":"center","color":"16776960","size":"18","text":"Web Sockets"}},{"ID":"9","typeID":"Label","zOrder":"9","w":"156","measuredW":"151","measuredH":"25","x":"46","y":"331","properties":{"size":"17","text":"Learn different Web"}},{"ID":"10","typeID":"Label","zOrder":"10","w":"148","measuredW":"143","measuredH":"25","x":"50","y":"357","properties":{"size":"17","text":"APIs used in PWAs"}},{"ID":"11","typeID":"Icon","zOrder":"11","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"12","typeID":"Icon","zOrder":"12","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1555","typeID":"__group__","zOrder":"220","measuredW":"285","measuredH":"59","w":"285","h":"59","x":"740","y":"2641","properties":{"controlName":"118-server-side-rendering"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"278","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"9","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"225","measuredH":"25","x":"22","y":"22","properties":{"size":"17","text":"Server Side Rendering (SSR)","bold":"true"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"261","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"261","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1556","typeID":"__group__","zOrder":"221","measuredW":"125","measuredH":"52","w":"125","h":"52","x":"1062","y":"2644","properties":{"controlName":"100-server-side-rendering:react-js"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"116","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"11","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"69","measuredW":"62","measuredH":"25","x":"23","y":"19","properties":{"size":"17","text":"React.js"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"101","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"101","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1557","typeID":"__group__","zOrder":"222","measuredW":"104","measuredH":"49","w":"104","h":"49","x":"1235","y":"2627","properties":{"controlName":"100-server-side-rendering:react-js:next-js"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"94","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"8","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"61","measuredW":"52","measuredH":"25","x":"20","y":"16","properties":{"size":"17","text":"Next.js"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"80","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"80","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1558","typeID":"__group__","zOrder":"223","measuredW":"94","measuredH":"41","w":"94","h":"41","x":"1235","y":"2682","properties":{"controlName":"101-server-side-rendering:react-js:after-js"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"94","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.5","color":"10066329"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"60","measuredW":"52","measuredH":"25","x":"21","y":"8","properties":{"color":"3355443","size":"17","text":"After.js"}}]}}},{"ID":"1560","typeID":"__group__","zOrder":"224","measuredW":"123","measuredH":"52","w":"123","h":"52","x":"1066","y":"2735","properties":{"controlName":"101-server-side-rendering:angular"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"115","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"11","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"69","measuredW":"59","measuredH":"25","x":"31","y":"19","properties":{"size":"17","text":"Angular"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"99","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"99","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"99","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1561","typeID":"__group__","zOrder":"225","measuredW":"121","measuredH":"52","w":"121","h":"52","x":"1218","y":"2735","properties":{"controlName":"100-server-side-rendering:angular:universal"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"111","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"11","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"73","measuredW":"72","measuredH":"25","x":"19","y":"19","properties":{"size":"17","text":"Universal"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"97","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"97","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"97","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1562","typeID":"__group__","zOrder":"226","measuredW":"124","measuredH":"51","w":"124","h":"51","x":"1066","y":"2789","properties":{"controlName":"102-server-side-rendering:vue-js"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"115","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"10","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"48","measuredW":"45","measuredH":"25","x":"34","y":"18","properties":{"size":"17","text":"Vue.js"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"100","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"100","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"100","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1563","typeID":"__group__","zOrder":"227","measuredW":"122","measuredH":"51","w":"122","h":"51","x":"1218","y":"2789","properties":{"controlName":"100-server-side-rendering:vue-js:nuxt-js"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"111","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"10","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"55","measuredW":"52","measuredH":"25","x":"28","y":"18","properties":{"size":"17","text":"Nuxt.js"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"98","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"98","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"98","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1564","typeID":"__group__","zOrder":"237","measuredW":"154","measuredH":"59","w":"154","h":"59","x":"759","y":"2869","properties":{"controlName":"119-graphql"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"146","h":"50","measuredW":"200","measuredH":"140","x":"8","y":"9","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"71","measuredH":"25","x":"45","y":"22","properties":{"size":"17","text":"GraphQL","bold":"true"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1565","typeID":"__group__","zOrder":"190","measuredW":"177","measuredH":"47","w":"177","h":"47","x":"975","y":"2854","properties":{"controlName":"100-graphql:apollo"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"167","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"6","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"49","measuredW":"48","measuredH":"25","x":"50","y":"14","properties":{"size":"17","text":"Apollo"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"153","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"153","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1566","typeID":"__group__","zOrder":"238","measuredW":"178","measuredH":"45","w":"178","h":"45","x":"975","y":"2905","properties":{"controlName":"101-graphql:relay-modern"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"168","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"4","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"115","measuredW":"107","measuredH":"25","x":"33","y":"12","properties":{"size":"17","text":"Relay Modern"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"154","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"154","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"154","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1567","typeID":"__group__","zOrder":"193","measuredW":"285","measuredH":"59","w":"285","h":"59","x":"776","y":"3006","properties":{"controlName":"120-static-site-generators"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"281","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"9","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"172","measuredH":"25","x":"49","y":"22","properties":{"size":"17","text":"Static Site Generators","bold":"true"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"261","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"261","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1568","typeID":"__group__","zOrder":"195","measuredW":"157","measuredH":"50","w":"157","h":"50","x":"1183","y":"2944","properties":{"controlName":"100-static-site-generators:next-js"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"147","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"9","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"58","measuredW":"52","measuredH":"25","x":"45","y":"17","properties":{"size":"17","text":"Next.js"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"133","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"133","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1569","typeID":"__group__","zOrder":"194","measuredW":"156","measuredH":"45","w":"156","h":"45","x":"1183","y":"2995","properties":{"controlName":"101-static-site-generators:gatsbyjs"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"147","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"4","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"78","measuredW":"73","measuredH":"25","x":"35","y":"12","properties":{"size":"17","text":"GatsbyJS"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"132","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"132","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1570","typeID":"__group__","zOrder":"196","measuredW":"156","measuredH":"44","w":"156","h":"44","x":"1183","y":"3042","properties":{"controlName":"102-static-site-generators:nuxt-js"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"147","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"3","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"56","measuredW":"52","measuredH":"25","x":"46","y":"11","properties":{"size":"17","text":"Nuxt.js"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"132","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"132","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"132","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1571","typeID":"__group__","zOrder":"197","measuredW":"156","measuredH":"43","w":"156","h":"43","x":"1183","y":"3088","properties":{"controlName":"103-static-site-generators:vuepress"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"147","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"2","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"76","measuredW":"72","measuredH":"25","x":"40","y":"10","properties":{"size":"17","text":"Vuepress"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"132","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"132","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"132","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1572","typeID":"__group__","zOrder":"198","measuredW":"157","measuredH":"45","w":"157","h":"45","x":"1183","y":"3132","properties":{"controlName":"104-static-site-generators:jekyll"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"147","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"4","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"49","measuredW":"43","measuredH":"25","x":"52","y":"12","properties":{"size":"17","text":"Jekyll"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"133","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"133","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"133","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1573","typeID":"__group__","zOrder":"235","measuredW":"157","measuredH":"44","w":"157","h":"44","x":"1183","y":"3179","properties":{"controlName":"105-static-site-generators:hugo"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"147","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"3","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"43","measuredW":"42","measuredH":"25","x":"52","y":"11","properties":{"size":"17","text":"Hugo"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"133","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"133","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"4","typeID":"Icon","zOrder":"4","measuredW":"24","measuredH":"24","x":"133","y":"0","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1574","typeID":"__group__","zOrder":"5","measuredW":"157","measuredH":"41","w":"157","h":"41","x":"1183","y":"3228","properties":{"controlName":"106-static-site-generators:gridsome"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"147","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16770457","align":"center","size":"17"}},{"ID":"1","typeID":"Icon","zOrder":"1","measuredW":"24","measuredH":"24","x":"133","y":"5","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"133","y":"5","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}},{"ID":"3","typeID":"Label","zOrder":"3","w":"87","measuredW":"75","measuredH":"25","x":"41","y":"9","properties":{"text":"Gridsome","size":"17"}}]}}},{"ID":"1575","typeID":"__group__","zOrder":"231","measuredW":"220","measuredH":"59","w":"220","h":"59","x":"437","y":"3009","properties":{"controlName":"121-mobile-applications"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"210","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"9","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"169","measuredW":"152","measuredH":"25","x":"27","y":"22","properties":{"size":"17","text":"Mobile Applications","bold":"true"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"196","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"196","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1576","typeID":"__group__","zOrder":"232","measuredW":"156","measuredH":"51","w":"156","h":"51","x":"137","y":"2928","properties":{"controlName":"100-mobile-applications:react-native"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"147","h":"41","measuredW":"200","measuredH":"140","x":"9","y":"10","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"101","measuredW":"100","measuredH":"25","x":"32","y":"18","properties":{"size":"17","text":"React Native"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1577","typeID":"__group__","zOrder":"233","measuredW":"147","measuredH":"41","w":"147","h":"41","x":"146","y":"2983","properties":{"controlName":"101-mobile-applications:nativescript"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"147","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"101","measuredW":"94","measuredH":"25","x":"23","y":"8","properties":{"size":"17","text":"NativeScript"}}]}}},{"ID":"1578","typeID":"__group__","zOrder":"234","measuredW":"147","measuredH":"41","w":"147","h":"41","x":"146","y":"3029","properties":{"controlName":"102-mobile-applications:flutter"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"147","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"53","measuredW":"50","measuredH":"25","x":"47","y":"8","properties":{"size":"17","text":"Flutter"}}]}}},{"ID":"1579","typeID":"__group__","zOrder":"236","measuredW":"147","measuredH":"41","w":"147","h":"41","x":"146","y":"3075","properties":{"controlName":"103-mobile-applications:ionic"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"147","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"40","measuredW":"38","measuredH":"25","x":"54","y":"8","properties":{"size":"17","text":"Ionic"}}]}}},{"ID":"1580","typeID":"__group__","zOrder":"228","measuredW":"249","measuredH":"59","w":"249","h":"59","x":"441","y":"3131","properties":{"controlName":"122-desktop-applications"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"241","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"9","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"163","measuredH":"25","x":"43","y":"22","properties":{"size":"17","text":"Desktop Applications","bold":"true"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"225","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"225","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1581","typeID":"__group__","zOrder":"229","measuredW":"196","measuredH":"47","w":"196","h":"47","x":"755","y":"3097","properties":{"controlName":"100-desktop-applications:electron"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"188","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"6","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"69","measuredW":"65","measuredH":"25","x":"63","y":"14","properties":{"size":"17","text":"Electron"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"172","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"172","y":"0","properties":{"color":"10027263","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1582","typeID":"__group__","zOrder":"230","measuredW":"188","measuredH":"41","w":"188","h":"41","x":"756","y":"3151","properties":{"controlName":"101-desktop-applications:carlo"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"188","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"13421772","textColor":"3355443"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"48","measuredW":"42","measuredH":"25","x":"73","y":"9","properties":{"color":"3355443","size":"17","text":"Carlo"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"186","h":"41","measuredW":"200","measuredH":"140","x":"1","y":"0","properties":{"backgroundAlpha":"0.5","color":"10066329"}}]}}},{"ID":"1583","typeID":"__group__","zOrder":"246","measuredW":"188","measuredH":"42","w":"188","h":"42","x":"756","y":"3199","properties":{"controlName":"102-desktop-applications:proton-native"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"188","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"1","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"13421772","textColor":"3355443"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"115","measuredW":"104","measuredH":"25","x":"42","y":"9","properties":{"color":"3355443","size":"17","text":"Proton Native"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"186","h":"41","measuredW":"200","measuredH":"140","x":"1","y":"0","properties":{"backgroundAlpha":"0.5","color":"10066329"}}]}}},{"ID":"1584","typeID":"__group__","zOrder":"239","measuredW":"221","measuredH":"61","w":"221","h":"61","x":"176","y":"3313","properties":{"controlName":"123-web-assembly"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"210","h":"50","measuredW":"200","measuredH":"140","x":"11","y":"11","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"112","measuredH":"25","x":"57","y":"24","properties":{"size":"17","text":"Web Assembly","bold":"true"}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"3","typeID":"Icon","zOrder":"3","measuredW":"24","measuredH":"24","x":"0","y":"0","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]}}},{"ID":"1585","typeID":"__group__","zOrder":"240","measuredW":"207","measuredH":"50","w":"207","h":"50","x":"201","y":"3500","properties":{"controlName":"ext_link:google.com"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"207","h":"50","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16776960"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"114","measuredH":"25","x":"45","y":"13","properties":{"size":"17","text":"Keep Learning","bold":"true"}}]}}},{"ID":"1587","typeID":"__group__","zOrder":"214","measuredW":"405","measuredH":"44","w":"405","h":"44","x":"395","y":"2425","properties":{"controlName":"104-testing-your-apps:other-options"},"children":{"controls":{"control":[{"ID":"0","typeID":"__group__","zOrder":"0","measuredW":"93","measuredH":"43","w":"93","h":"43","x":"109","y":"1","properties":{"controlName":"testing-your-apps:chai"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"93","h":"43","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"10066329"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"38","measuredW":"36","measuredH":"25","x":"28","y":"9","properties":{"size":"17","text":"Chai"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"93","h":"43","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.25","borderColor":"6710886","color":"15658734"}}]}}},{"ID":"1","typeID":"__group__","zOrder":"1","measuredW":"75","measuredH":"43","w":"75","h":"43","x":"210","y":"1","properties":{"controlName":"testing-your-apps:ava"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"75","h":"43","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"10066329"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"32","measuredW":"28","measuredH":"25","x":"22","y":"9","properties":{"size":"17","text":"Ava"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"75","h":"43","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.25","borderColor":"6710886","color":"15658734"}}]}}},{"ID":"2","typeID":"__group__","zOrder":"2","measuredW":"112","measuredH":"43","w":"112","h":"43","x":"293","y":"0","properties":{"controlName":"testing-your-apps:jasmine"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"112","h":"43","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"10066329"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"67","measuredW":"65","measuredH":"25","x":"23","y":"9","properties":{"size":"17","text":"Jasmine"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"112","h":"43","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.25","borderColor":"6710886","color":"15658734"}}]}}},{"ID":"3","typeID":"__group__","zOrder":"3","measuredW":"101","measuredH":"43","w":"101","h":"43","x":"0","y":"0","properties":{"controlName":"testing-your-apps:mocha"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"101","h":"43","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.5","borderColor":"16777215","color":"10066329"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"55","measuredW":"53","measuredH":"25","x":"23","y":"9","properties":{"size":"17","text":"Mocha"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"101","h":"43","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"backgroundAlpha":"0.25","borderColor":"6710886","color":"15658734"}}]}}}]}}},{"ID":"1588","typeID":"__group__","zOrder":"254","measuredW":"157","measuredH":"41","w":"157","h":"41","x":"1184","y":"3274","properties":{"controlName":"107-static-site-generators:eleventy"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"147","h":"41","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16770457","align":"center","size":"17"}},{"ID":"1","typeID":"Icon","zOrder":"1","measuredW":"24","measuredH":"24","x":"133","y":"5","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"2","typeID":"Icon","zOrder":"2","measuredW":"24","measuredH":"24","x":"133","y":"5","properties":{"color":"3700253","icon":{"ID":"check-circle","size":"small"}}},{"ID":"3","typeID":"Label","zOrder":"3","measuredW":"66","measuredH":"25","x":"41","y":"8","properties":{"text":"Eleventy","size":"17"}}]}}},{"ID":"1589","typeID":"Arrow","zOrder":"0","w":"144","h":"237","measuredW":"150","measuredH":"100","x":"1045","y":"3058","properties":{"color":"2848996","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":143.5,"y":237},"p1":{"x":0.56420233463035,"y":0.027237354085603065},"p2":{"x":-0.5,"y":0}}},{"ID":"1590","typeID":"__group__","zOrder":"241","measuredW":"582","measuredH":"188","w":"582","h":"188","x":"464","y":"3296","children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"582","h":"188","measuredW":"200","measuredH":"140","x":"0","y":"0"},{"ID":"1","typeID":"Label","zOrder":"1","w":"536","measuredW":"498","measuredH":"25","x":"20","y":"20","properties":{"size":"17","text":"Web Assembly or WASM is the binary instructions generated from"}},{"ID":"2","typeID":"Label","zOrder":"2","w":"537","measuredW":"508","measuredH":"25","x":"20","y":"50","properties":{"size":"17","text":"higher level languages such as Go, C, C++ or Rust. It is faster than"}},{"ID":"3","typeID":"Label","zOrder":"3","w":"528","measuredW":"523","measuredH":"25","x":"19","y":"81","properties":{"size":"17","text":"JavaScript and WASM 1.0 has already shipped in the major browsers."}},{"ID":"4","typeID":"Label","zOrder":"4","w":"536","measuredW":"360","measuredH":"25","x":"19","y":"142","properties":{"size":"17","text":"take quite some time to go mainstream though."}},{"ID":"5","typeID":"Label","zOrder":"5","w":"539","measuredW":"520","measuredH":"25","x":"19","y":"111","properties":{"size":"17","text":"W3C accepted it as an official standard at the end of 2019. It will still"}}]}}},{"ID":"2164","typeID":"TextArea","zOrder":"115","w":"456","h":"161","measuredW":"200","measuredH":"140","x":"837","y":"1168"},{"ID":"2165","typeID":"__group__","zOrder":"116","measuredW":"163","measuredH":"48","w":"163","h":"48","x":"852","y":"1267","properties":{"controlName":"102-web-security-knowledge:cors"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"163","h":"48","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"51","measuredW":"47","measuredH":"25","x":"56","y":"12","properties":{"bold":"true","size":"17","text":"CORS"}}]}}},{"ID":"2166","typeID":"__group__","zOrder":"117","measuredW":"166","measuredH":"49","w":"166","h":"49","x":"851","y":"1212","properties":{"controlName":"100-web-security-knowledge:https"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"166","h":"49","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"63","measuredW":"53","measuredH":"25","x":"54","y":"12","properties":{"bold":"true","size":"17","text":"HTTPS"}}]}}},{"ID":"2167","typeID":"__group__","zOrder":"118","measuredW":"257","measuredH":"49","w":"257","h":"49","x":"1022","y":"1212","properties":{"controlName":"101-web-security-knowledge:content-security-policy"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"257","h":"49","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"196","measuredW":"179","measuredH":"25","x":"31","y":"12","properties":{"bold":"true","size":"17","text":"Content Security Policy"}}]}}},{"ID":"2168","typeID":"__group__","zOrder":"119","measuredW":"257","measuredH":"49","w":"257","h":"49","x":"1022","y":"1266","properties":{"controlName":"103-web-security-knowledge:owasp-security-risks"},"children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"257","h":"49","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"187","measuredW":"172","measuredH":"25","x":"43","y":"12","properties":{"bold":"true","size":"17","text":"OWASP Security Risks"}}]}}},{"ID":"2169","typeID":"Label","zOrder":"120","w":"372","measuredW":"344","measuredH":"25","x":"853","y":"1181","properties":{"size":"17","text":"Get at least a basic knowledge of all of these"}},{"ID":"2170","typeID":"Icon","zOrder":"121","measuredW":"24","measuredH":"24","x":"828","y":"1159","properties":{"color":"16777215","icon":{"ID":"circle","size":"small"}}},{"ID":"2171","typeID":"Icon","zOrder":"122","measuredW":"24","measuredH":"24","x":"828","y":"1159","properties":{"color":"10066329","icon":{"ID":"check-circle","size":"small"}}}]},"attributes":{"name":"frontend","order":1000076.8179159599,"parentID":null,"notes":""},"branchID":"Master","resourceID":"A451988B-49CC-410A-A8B7-C129C14D5D14","mockupH":"3449","mockupW":"1216","measuredW":"1341","measuredH":"3618","version":"1.0"}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/frontend/resources.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/frontend/resources.json new file mode 100644 index 000000000..3bf030e28 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/frontend/resources.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a modern frontend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern frontend development. Learn to become a modern frontend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a frontend developer","frontend developer","frontend engineer","frontend skills","frontend development","javascript developer","frontend development skills","frontend development skills test","frontend engineer roadmap","frontend developer roadmap","become a frontend developer","frontend developer career path","javascript developer","modern javascript developer","node developer","skills for frontend development","learn frontend development","what is frontend development","frontend developer quiz","frontend developer interview questions"]},"title":"Frontend Developer","description":"Step by step guide to becoming a modern frontend developer in 2021","featuredTitle":"Frontend","featuredDescription":"Step by step guide to becoming a frontend developer in 2021","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"featured":true,"imagePath":"/roadmaps/frontend.png","resourcesPath":"/roadmaps/100-frontend/resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/frontend-roadmap","id":"frontend","metaPath":"/roadmaps/100-frontend/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/golang.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/golang.json new file mode 100644 index 000000000..cb323e03c --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/golang.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a Go developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a golang developer","guide to becoming a go developer","golang developer","go developer","guide to golang","guide to go","golang roadmap","go roadmap","golang skills","go skills","golang skills test","go skills test","skills for golang","skills for go","cloud development","what is golang","what is go","golang quiz","go quiz","golang interview questions","go interview questions"]},"title":"Go Developer","description":"Step by step guide to becoming a Go developer in 2021","featuredTitle":"Go","featuredDescription":"Step by step guide to becoming a Go developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"/roadmaps/107-golang/landscape.md","resourcesPath":"/roadmaps/107-golang/resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/go-roadmap","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"golang","metaPath":"/roadmaps/107-golang/meta.json"}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/golang/interactive.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/golang/interactive.json new file mode 100644 index 000000000..3512ae0c6 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/golang/interactive.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a Go developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a golang developer","guide to becoming a go developer","golang developer","go developer","guide to golang","guide to go","golang roadmap","go roadmap","golang skills","go skills","golang skills test","go skills test","skills for golang","skills for go","cloud development","what is golang","what is go","golang quiz","go quiz","golang interview questions","go interview questions"]},"title":"Go Developer","description":"Step by step guide to becoming a Go developer in 2021","featuredTitle":"Go","featuredDescription":"Step by step guide to becoming a Go developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"/roadmaps/107-golang/landscape.md","resourcesPath":"/roadmaps/107-golang/resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/go-roadmap","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"golang","metaPath":"/roadmaps/107-golang/meta.json"},"json":{"mockup":{"controls":{"control":[{"ID":"0","typeID":"Arrow","zOrder":"43","w":"33","h":"73","measuredW":"150","measuredH":"100","x":"428","y":"129","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","stroke":"dotted","p0":{"x":6,"y":0},"p1":{"x":0.4744027303754264,"y":-0.21757679180887365},"p2":{"x":33,"y":72.5}}},{"ID":"1","typeID":"Arrow","zOrder":"44","w":"16","h":"68","measuredW":"150","measuredH":"100","x":"474","y":"242","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4869331283627979,"y":0.16641045349730976},"p2":{"x":8,"y":68},"color":"10027263"}},{"ID":"2","typeID":"Canvas","zOrder":"45","w":"454","h":"90","measuredW":"100","measuredH":"70","x":"108","y":"183"},{"ID":"3","typeID":"Arrow","zOrder":"46","w":"126","h":"299","measuredW":"150","measuredH":"100","x":"479","y":"467","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":0,"y":0},"p1":{"x":0.5666915052160955,"y":0.2790611028315946},"p2":{"x":69,"y":298.5}}},{"ID":"4","typeID":"Arrow","zOrder":"47","w":"98","h":"47","measuredW":"150","measuredH":"100","x":"601","y":"406","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":97.5,"y":-0.5},"p1":{"x":0.5537800308573949,"y":0.044853427374917355},"p2":{"x":0,"y":46}}},{"ID":"5","typeID":"Arrow","zOrder":"48","w":"120","h":"44","measuredW":"150","measuredH":"100","x":"597","y":"465","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":120,"y":44},"p1":{"x":0.5846756207563067,"y":-0.036972790801407494},"p2":{"x":0,"y":0}}},{"ID":"6","typeID":"Arrow","zOrder":"49","w":"107","h":"51","measuredW":"150","measuredH":"100","x":"276","y":"405","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":107,"y":51},"p1":{"x":0.5245584633234497,"y":0.05852778135877272},"p2":{"x":0,"y":0}}},{"ID":"7","typeID":"Arrow","zOrder":"50","w":"108","h":"44","measuredW":"150","measuredH":"100","x":"276","y":"462","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":108,"y":0},"p1":{"x":0.5656811947576956,"y":-0.05547089302042055},"p2":{"x":0,"y":44}}},{"ID":"8","typeID":"Arrow","zOrder":"51","w":"115","h":"5","measuredW":"150","measuredH":"100","x":"274","y":"457","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":115,"y":1},"p1":{"x":0.5205160087037612,"y":0.03901150139881877},"p2":{"x":0,"y":0}}},{"ID":"9","typeID":"Arrow","zOrder":"52","w":"123","h":"3","measuredW":"150","measuredH":"100","x":"577","y":"458","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":122.5,"y":-0.5},"p1":{"x":0.5536354056902003,"y":0.01338250790305583},"p2":{"x":0,"y":1}}},{"ID":"10","typeID":"Label","zOrder":"53","measuredW":"37","measuredH":"36","x":"451","y":"318","properties":{"size":"28","text":"Go"}},{"ID":"11","typeID":"Arrow","zOrder":"54","w":"20","h":"81","measuredW":"150","measuredH":"100","x":"431","y":"364","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":20,"y":0},"p1":{"x":0.486153846153846,"y":-0.2492307692307692},"p2":{"x":20,"y":81}}},{"ID":"12","typeID":"Canvas","zOrder":"55","w":"262","h":"43","measuredW":"100","measuredH":"70","x":"354","y":"437","properties":{"color":"16776960"}},{"ID":"13","typeID":"Label","zOrder":"56","measuredW":"123","measuredH":"24","x":"423","y":"447","properties":{"size":"16","text":"Learn the Basics"}},{"ID":"14","typeID":"__group__","zOrder":"57","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"69","y":"392","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"95","measuredW":"92","measuredH":"24","x":"64","y":"9","properties":{"size":"16","text":"Basic Syntax"}}]}}},{"ID":"15","typeID":"__group__","zOrder":"58","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"69","y":"438","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"183","measuredH":"24","x":"16","y":"9","properties":{"size":"16","text":"Variables and declaration"}}]}}},{"ID":"16","typeID":"Canvas","zOrder":"59","w":"280","h":"42","measuredW":"100","measuredH":"70","x":"688","y":"484","properties":{"color":"16770457"}},{"ID":"17","typeID":"Label","zOrder":"60","measuredW":"222","measuredH":"24","x":"717","y":"493","properties":{"size":"16","text":"Packages, imports and exports"}},{"ID":"18","typeID":"Canvas","zOrder":"61","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"484","properties":{"color":"16770457"}},{"ID":"19","typeID":"Label","zOrder":"62","measuredW":"81","measuredH":"24","x":"139","y":"493","properties":{"size":"16","text":"Data Types"}},{"ID":"22","typeID":"Canvas","zOrder":"63","w":"280","h":"42","measuredW":"100","measuredH":"70","x":"688","y":"438","properties":{"color":"16770457"}},{"ID":"23","typeID":"Label","zOrder":"64","measuredW":"247","measuredH":"24","x":"704","y":"447","properties":{"text":"Functions, multiple/named returns","size":"16"}},{"ID":"26","typeID":"Label","zOrder":"65","measuredW":"384","measuredH":"28","x":"140","y":"202","properties":{"size":"20","text":"Backend Roadmap till Language Selection"}},{"ID":"27","typeID":"Label","zOrder":"66","measuredW":"153","measuredH":"24","x":"255","y":"231","properties":{"size":"16","text":"roadmap.sh/backend","color":"10027263"}},{"ID":"28","typeID":"Canvas","zOrder":"67","w":"350","h":"141","measuredW":"100","measuredH":"70","x":"594","y":"171"},{"ID":"29","typeID":"Label","zOrder":"68","measuredW":"314","measuredH":"25","x":"608","y":"188","properties":{"size":"17","text":"Find the detailed version of this roadmap"}},{"ID":"30","typeID":"Label","zOrder":"69","measuredW":"319","measuredH":"25","x":"608","y":"216","properties":{"size":"17","text":"along with resources and other roadmaps"}},{"ID":"31","typeID":"Canvas","zOrder":"70","w":"320","h":"45","measuredW":"100","measuredH":"70","x":"609","y":"252","properties":{"borderColor":"4273622","color":"4273622"}},{"ID":"32","typeID":"Label","zOrder":"71","measuredW":"105","measuredH":"28","x":"750","y":"260","properties":{"color":"16777215","size":"20","text":"roadmap.sh"}},{"ID":"33","typeID":"Label","zOrder":"72","measuredW":"35","measuredH":"28","x":"685","y":"260","properties":{"color":"16777215","size":"20","text":"http"}},{"ID":"34","typeID":"Label","zOrder":"73","measuredW":"5","measuredH":"28","x":"722","y":"260","properties":{"color":"16777215","size":"20","text":":"}},{"ID":"35","typeID":"Label","zOrder":"74","measuredW":"10","measuredH":"28","x":"729","y":"261","properties":{"color":"16777215","size":"20","text":"/"}},{"ID":"36","typeID":"Label","zOrder":"75","measuredW":"10","measuredH":"28","x":"737","y":"261","properties":{"color":"16777215","size":"20","text":"/"}},{"ID":"37","typeID":"Canvas","zOrder":"76","w":"280","h":"42","measuredW":"100","measuredH":"70","x":"688","y":"393","properties":{"color":"16770457"}},{"ID":"38","typeID":"Label","zOrder":"77","w":"92","measuredW":"90","measuredH":"24","x":"782","y":"402","properties":{"size":"16","text":"Conditionals"}},{"ID":"39","typeID":"Canvas","zOrder":"78","w":"57","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"549","properties":{"color":"16770457"}},{"ID":"40","typeID":"Label","zOrder":"79","measuredW":"31","measuredH":"24","x":"82","y":"558","properties":{"size":"16","text":"bool"}},{"ID":"41","typeID":"Canvas","zOrder":"80","w":"161","h":"42","measuredW":"100","measuredH":"70","x":"130","y":"549","properties":{"color":"16770457"}},{"ID":"42","typeID":"Label","zOrder":"81","measuredW":"129","measuredH":"24","x":"146","y":"558","properties":{"size":"16","text":"int, int8/16/32/64"}},{"ID":"43","typeID":"Canvas","zOrder":"82","w":"51","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"595","properties":{"color":"16770457"}},{"ID":"44","typeID":"Label","zOrder":"83","measuredW":"31","measuredH":"24","x":"80","y":"604","properties":{"size":"16","text":"byte"}},{"ID":"47","typeID":"Canvas","zOrder":"84","w":"166","h":"42","measuredW":"100","measuredH":"70","x":"125","y":"595","properties":{"color":"16770457"}},{"ID":"48","typeID":"Label","zOrder":"85","measuredW":"147","measuredH":"24","x":"134","y":"604","properties":{"size":"16","text":"uint, uint8/16/32/64"}},{"ID":"49","typeID":"Canvas","zOrder":"86","w":"76","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"641","properties":{"color":"16770457"}},{"ID":"50","typeID":"Label","zOrder":"87","measuredW":"34","measuredH":"24","x":"90","y":"650","properties":{"size":"16","text":"rune"}},{"ID":"51","typeID":"Canvas","zOrder":"88","w":"142","h":"42","measuredW":"100","measuredH":"70","x":"149","y":"641","properties":{"color":"16770457"}},{"ID":"52","typeID":"Label","zOrder":"89","measuredW":"108","measuredH":"24","x":"166","y":"650","properties":{"size":"16","text":"float32, float64"}},{"ID":"53","typeID":"Canvas","zOrder":"90","w":"138","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"688","properties":{"color":"16770457"}},{"ID":"54","typeID":"Label","zOrder":"91","measuredW":"113","measuredH":"24","x":"80","y":"697","properties":{"size":"16","text":"complex64/128"}},{"ID":"55","typeID":"Canvas","zOrder":"92","w":"80","h":"42","measuredW":"100","measuredH":"70","x":"211","y":"688","properties":{"color":"16770457"}},{"ID":"56","typeID":"Label","zOrder":"93","measuredW":"47","measuredH":"24","x":"227","y":"697","properties":{"size":"16","text":"uintptr"}},{"ID":"58","typeID":"Arrow","zOrder":"42","w":"1","h":"51","measuredW":"150","measuredH":"100","x":"181","y":"517","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":51},"p1":{"x":0.5145945945945946,"y":-0.0075675675675675675},"p2":{"x":0,"y":0}}},{"ID":"59","typeID":"Arrow","zOrder":"41","w":"2","h":"68","measuredW":"150","measuredH":"100","x":"100","y":"506","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":2,"y":68},"p1":{"x":0.5297297297297298,"y":0.021621621621621623},"p2":{"x":1,"y":0}}},{"ID":"60","typeID":"Arrow","zOrder":"40","w":"1","h":"51","measuredW":"150","measuredH":"100","x":"241","y":"517","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":51},"p1":{"x":0.5145945945945946,"y":-0.0075675675675675675},"p2":{"x":0,"y":0}}},{"ID":"61","typeID":"Canvas","zOrder":"94","w":"127","h":"42","measuredW":"100","measuredH":"70","x":"688","y":"531","properties":{"color":"16770457"}},{"ID":"62","typeID":"Label","zOrder":"95","measuredW":"94","measuredH":"24","x":"705","y":"540","properties":{"size":"16","text":"Type Casting"}},{"ID":"63","typeID":"Canvas","zOrder":"96","w":"146","h":"42","measuredW":"100","measuredH":"70","x":"822","y":"531","properties":{"color":"16770457"}},{"ID":"64","typeID":"Label","zOrder":"97","measuredW":"109","measuredH":"24","x":"840","y":"540","properties":{"size":"16","text":"Type Inference"}},{"ID":"65","typeID":"Arrow","zOrder":"39","w":"101","h":"83","measuredW":"150","measuredH":"100","x":"602","y":"469","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":101,"y":83},"p1":{"x":0.5714745465184319,"y":-0.07492685781158573},"p2":{"x":0,"y":0}}},{"ID":"66","typeID":"Canvas","zOrder":"98","w":"106","h":"42","measuredW":"100","measuredH":"70","x":"322","y":"526","properties":{"color":"16770457"}},{"ID":"67","typeID":"Label","zOrder":"99","measuredW":"65","measuredH":"24","x":"342","y":"535","properties":{"size":"16","text":"For Loop"}},{"ID":"68","typeID":"Canvas","zOrder":"100","w":"192","h":"42","measuredW":"100","measuredH":"70","x":"321","y":"571","properties":{"color":"16770457"}},{"ID":"69","typeID":"Label","zOrder":"101","measuredW":"145","measuredH":"24","x":"344","y":"580","properties":{"size":"16","text":"if, switch statements"}},{"ID":"75","typeID":"Arrow","zOrder":"38","w":"2","h":"83","measuredW":"150","measuredH":"100","x":"392","y":"463","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":1,"y":83},"p1":{"x":0.48192771084337344,"y":0.018072289156626505},"p2":{"x":1,"y":0}}},{"ID":"76","typeID":"Canvas","zOrder":"102","w":"262","h":"43","measuredW":"100","measuredH":"70","x":"354","y":"750","properties":{"color":"16776960"}},{"ID":"77","typeID":"Label","zOrder":"103","measuredW":"103","measuredH":"24","x":"433","y":"760","properties":{"size":"16","text":"Going Deeper"}},{"ID":"80","typeID":"Canvas","zOrder":"104","w":"181","h":"42","measuredW":"100","measuredH":"70","x":"786","y":"626","properties":{"color":"16770457"}},{"ID":"81","typeID":"Label","zOrder":"105","measuredW":"51","measuredH":"24","x":"851","y":"635","properties":{"size":"16","text":"Structs"}},{"ID":"82","typeID":"Canvas","zOrder":"106","w":"143","h":"42","measuredW":"100","measuredH":"70","x":"684","y":"746","properties":{"color":"16770457"}},{"ID":"83","typeID":"Label","zOrder":"107","measuredW":"74","measuredH":"24","x":"719","y":"756","properties":{"size":"16","text":"Interfaces"}},{"ID":"84","typeID":"Canvas","zOrder":"108","w":"84","h":"42","measuredW":"100","measuredH":"70","x":"688","y":"578","properties":{"color":"16770457"}},{"ID":"85","typeID":"Label","zOrder":"109","measuredW":"46","measuredH":"24","x":"707","y":"587","properties":{"size":"16","text":"Arrays"}},{"ID":"86","typeID":"Canvas","zOrder":"110","w":"92","h":"42","measuredW":"100","measuredH":"70","x":"778","y":"578","properties":{"color":"16770457"}},{"ID":"87","typeID":"Label","zOrder":"111","measuredW":"43","measuredH":"24","x":"802","y":"587","properties":{"size":"16","text":"Slices"}},{"ID":"88","typeID":"Canvas","zOrder":"112","w":"94","h":"42","measuredW":"100","measuredH":"70","x":"687","y":"626","properties":{"color":"16770457"}},{"ID":"89","typeID":"Label","zOrder":"113","measuredW":"52","measuredH":"24","x":"708","y":"635","properties":{"size":"16","text":"make()"}},{"ID":"90","typeID":"Canvas","zOrder":"114","w":"81","h":"42","measuredW":"100","measuredH":"70","x":"432","y":"526","properties":{"color":"16770457"}},{"ID":"91","typeID":"Label","zOrder":"115","measuredW":"43","measuredH":"24","x":"451","y":"535","properties":{"size":"16","text":"range"}},{"ID":"92","typeID":"Arrow","zOrder":"37","w":"4","h":"78","measuredW":"150","measuredH":"100","x":"468","y":"464","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":4.5,"y":78},"p1":{"x":0.4819277108433735,"y":0.018072289156626516},"p2":{"x":0.5,"y":0}}},{"ID":"93","typeID":"Arrow","zOrder":"36","w":"125","h":"133","measuredW":"150","measuredH":"100","x":"577","y":"471","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":125,"y":132.5},"p1":{"x":0.6144660011301564,"y":-0.09666603880203428},"p2":{"x":0,"y":0}}},{"ID":"94","typeID":"Canvas","zOrder":"116","w":"92","h":"42","measuredW":"100","measuredH":"70","x":"875","y":"578","properties":{"color":"16770457"}},{"ID":"95","typeID":"Label","zOrder":"117","measuredW":"41","measuredH":"24","x":"900","y":"587","properties":{"size":"16","text":"Maps"}},{"ID":"96","typeID":"Canvas","zOrder":"118","w":"281","h":"42","measuredW":"100","measuredH":"70","x":"685","y":"700","properties":{"color":"16770457"}},{"ID":"97","typeID":"Label","zOrder":"119","measuredW":"233","measuredH":"24","x":"709","y":"709","properties":{"size":"16","text":"Types, Type Assertions, Switches"}},{"ID":"98","typeID":"Arrow","zOrder":"35","w":"141","h":"181","measuredW":"150","measuredH":"100","x":"557","y":"469","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":141,"y":180.5},"p1":{"x":0.5960734774514647,"y":-0.08589149348429012},"p2":{"x":0,"y":-0.5}}},{"ID":"105","typeID":"Canvas","zOrder":"120","w":"192","h":"42","measuredW":"100","measuredH":"70","x":"321","y":"617","properties":{"color":"16770457"}},{"ID":"106","typeID":"Label","zOrder":"121","measuredW":"160","measuredH":"24","x":"337","y":"626","properties":{"size":"16","text":"Errors, Panic, Recover"}},{"ID":"108","typeID":"Arrow","zOrder":"32","w":"107","h":"4","measuredW":"150","measuredH":"100","x":"595","y":"766","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":107,"y":0},"p1":{"x":0.599303135888502,"y":0.013937282229965165},"p2":{"x":0,"y":3}}},{"ID":"109","typeID":"Arrow","zOrder":"33","w":"95","h":"34","measuredW":"150","measuredH":"100","x":"601","y":"779","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":95,"y":34},"p1":{"x":0.6311916037373608,"y":-0.052796621016254944},"p2":{"x":0,"y":0}}},{"ID":"110","typeID":"Arrow","zOrder":"34","w":"109","h":"57","measuredW":"150","measuredH":"100","x":"593","y":"712","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":108,"y":0},"p1":{"x":0.5854522369608072,"y":0.026930401951284707},"p2":{"x":-0.5,"y":56.5}}},{"ID":"111","typeID":"Canvas","zOrder":"122","w":"142","h":"42","measuredW":"100","measuredH":"70","x":"685","y":"792","properties":{"color":"16770457"}},{"ID":"112","typeID":"Label","zOrder":"123","measuredW":"80","measuredH":"24","x":"716","y":"801","properties":{"size":"16","text":"Goroutines"}},{"ID":"113","typeID":"Canvas","zOrder":"124","w":"134","h":"42","measuredW":"100","measuredH":"70","x":"832","y":"792","properties":{"color":"16770457"}},{"ID":"114","typeID":"Label","zOrder":"125","measuredW":"69","measuredH":"24","x":"864","y":"801","properties":{"size":"16","text":"Channels"}},{"ID":"115","typeID":"Canvas","zOrder":"126","w":"142","h":"42","measuredW":"100","measuredH":"70","x":"685","y":"838","properties":{"color":"16770457"}},{"ID":"116","typeID":"Label","zOrder":"127","measuredW":"44","measuredH":"24","x":"734","y":"847","properties":{"size":"16","text":"Buffer"}},{"ID":"119","typeID":"Canvas","zOrder":"128","w":"134","h":"42","measuredW":"100","measuredH":"70","x":"832","y":"838","properties":{"color":"16770457"}},{"ID":"120","typeID":"Label","zOrder":"129","measuredW":"46","measuredH":"24","x":"872","y":"847","properties":{"size":"16","text":"Select"}},{"ID":"121","typeID":"Canvas","zOrder":"130","w":"281","h":"42","measuredW":"100","measuredH":"70","x":"685","y":"884","properties":{"color":"16770457"}},{"ID":"122","typeID":"Label","zOrder":"131","measuredW":"45","measuredH":"24","x":"803","y":"893","properties":{"size":"16","text":"Mutex"}},{"ID":"123","typeID":"Arrow","zOrder":"31","w":"91","h":"69","measuredW":"150","measuredH":"100","x":"600","y":"783","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":90.5,"y":69},"p1":{"x":0.6311916037373609,"y":-0.0527966210162549},"p2":{"x":-0.5,"y":0}}},{"ID":"124","typeID":"Arrow","zOrder":"30","w":"107","h":"125","measuredW":"150","measuredH":"100","x":"589","y":"785","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":106.5,"y":125},"p1":{"x":0.6311916037373609,"y":-0.05279662101625488},"p2":{"x":-0.5,"y":0}}},{"ID":"125","typeID":"Arrow","zOrder":"29","w":"1","h":"58","measuredW":"150","measuredH":"100","x":"467","y":"709","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":0},"p1":{"x":0.4819277108433734,"y":0.018072289156626505},"p2":{"x":0,"y":57.5}}},{"ID":"126","typeID":"Canvas","zOrder":"132","w":"145","h":"42","measuredW":"100","measuredH":"70","x":"395","y":"683","properties":{"color":"16770457"}},{"ID":"127","typeID":"Label","zOrder":"133","measuredW":"88","measuredH":"24","x":"424","y":"692","properties":{"size":"16","text":"Go Modules"}},{"ID":"128","typeID":"Canvas","zOrder":"134","w":"222","h":"43","measuredW":"100","measuredH":"70","x":"69","y":"749","properties":{"color":"16776960"}},{"ID":"129","typeID":"Label","zOrder":"135","measuredW":"97","measuredH":"24","x":"131","y":"759","properties":{"size":"16","text":"Building CLIs"}},{"ID":"130","typeID":"Arrow","zOrder":"28","w":"98","h":"2","measuredW":"150","measuredH":"100","x":"270","y":"770","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":98,"y":0.5},"p1":{"x":0.5245467907888293,"y":0.010387065164135229},"p2":{"x":0,"y":-0.5}}},{"ID":"131","typeID":"Canvas","zOrder":"136","w":"237","h":"66","measuredW":"100","measuredH":"70","x":"354","y":"808","properties":{"color":"16770457"}},{"ID":"132","typeID":"Label","zOrder":"137","measuredW":"207","measuredH":"24","x":"369","y":"817","properties":{"size":"16","text":"Marshalling & Unmarshalling"}},{"ID":"133","typeID":"Arrow","zOrder":"27","w":"1","h":"54","measuredW":"150","measuredH":"100","x":"465","y":"773","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":0},"p1":{"x":0.48192771084337327,"y":0.018072289156626505},"p2":{"x":0,"y":54}}},{"ID":"136","typeID":"Label","zOrder":"138","measuredW":"43","measuredH":"24","x":"451","y":"841","properties":{"size":"16","text":"JSON"}},{"ID":"141","typeID":"Canvas","zOrder":"139","w":"134","h":"42","measuredW":"100","measuredH":"70","x":"832","y":"746","properties":{"color":"16770457"}},{"ID":"142","typeID":"Label","zOrder":"140","measuredW":"56","measuredH":"24","x":"871","y":"755","properties":{"size":"16","text":"Context"}},{"ID":"143","typeID":"Canvas","zOrder":"141","w":"73","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"808","properties":{"color":"16770457"}},{"ID":"144","typeID":"Label","zOrder":"142","measuredW":"44","measuredH":"24","x":"84","y":"817","properties":{"size":"16","text":"Cobra"}},{"ID":"145","typeID":"Canvas","zOrder":"143","h":"42","measuredW":"100","measuredH":"70","x":"149","y":"808","properties":{"color":"15658734"}},{"ID":"146","typeID":"Label","zOrder":"144","measuredW":"68","measuredH":"24","x":"165","y":"817","properties":{"size":"16","text":"urfave/cli"}},{"ID":"149","typeID":"Arrow","zOrder":"25","w":"2","h":"68","measuredW":"150","measuredH":"100","x":"107","y":"766","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":2,"y":68},"p1":{"x":0.5297297297297298,"y":0.021621621621621623},"p2":{"x":1,"y":0}}},{"ID":"150","typeID":"Arrow","zOrder":"26","w":"1","h":"51","measuredW":"150","measuredH":"100","x":"197","y":"777","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":51},"p1":{"x":0.5145945945945946,"y":-0.0075675675675675675},"p2":{"x":0,"y":0}}},{"ID":"155","typeID":"Arrow","zOrder":"24","w":"1","h":"118","measuredW":"150","measuredH":"100","x":"271","y":"775","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":1,"y":117},"p1":{"x":0.4340835430661428,"y":0.0048163102717775075},"p2":{"x":0,"y":-0.5}}},{"ID":"159","typeID":"Canvas","zOrder":"145","w":"275","h":"43","measuredW":"100","measuredH":"70","x":"343","y":"986","properties":{"color":"16776960"}},{"ID":"160","typeID":"Label","zOrder":"146","measuredW":"125","measuredH":"24","x":"418","y":"996","properties":{"size":"16","text":"Web Frameworks"}},{"ID":"161","typeID":"Canvas","zOrder":"147","w":"79","h":"42","measuredW":"100","measuredH":"70","x":"323","y":"896","properties":{"color":"16770457"}},{"ID":"162","typeID":"Label","zOrder":"148","measuredW":"49","measuredH":"24","x":"338","y":"905","properties":{"size":"16","text":"Beego"}},{"ID":"163","typeID":"Canvas","zOrder":"149","w":"54","h":"42","measuredW":"100","measuredH":"70","x":"408","y":"896","properties":{"color":"16770457"}},{"ID":"164","typeID":"Label","zOrder":"150","measuredW":"25","measuredH":"24","x":"422","y":"905","properties":{"size":"16","text":"Gin"}},{"ID":"165","typeID":"Canvas","zOrder":"151","w":"76","h":"42","measuredW":"100","measuredH":"70","x":"469","y":"896","properties":{"color":"16770457"}},{"ID":"166","typeID":"Label","zOrder":"152","measuredW":"42","measuredH":"24","x":"486","y":"905","properties":{"size":"16","text":"Revel"}},{"ID":"167","typeID":"Canvas","zOrder":"153","w":"76","h":"42","measuredW":"100","measuredH":"70","x":"552","y":"896","properties":{"color":"16770457"}},{"ID":"168","typeID":"Label","zOrder":"154","measuredW":"37","measuredH":"24","x":"571","y":"905","properties":{"size":"16","text":"Echo"}},{"ID":"169","typeID":"Canvas","zOrder":"155","w":"205","h":"42","measuredW":"100","measuredH":"70","x":"687","y":"983","properties":{"color":"16770457"}},{"ID":"170","typeID":"Label","zOrder":"156","measuredW":"50","measuredH":"24","x":"765","y":"992","properties":{"size":"16","text":"Buffalo"}},{"ID":"171","typeID":"Canvas","zOrder":"157","w":"205","h":"42","measuredW":"100","measuredH":"70","x":"687","y":"936","properties":{"color":"16770457"}},{"ID":"172","typeID":"Label","zOrder":"158","measuredW":"47","measuredH":"24","x":"766","y":"945","properties":{"size":"16","text":"Gorilla"}},{"ID":"173","typeID":"Arrow","zOrder":"23","w":"97","h":"40","measuredW":"150","measuredH":"100","x":"605","y":"958","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":97,"y":-0.5},"p1":{"x":0.5439101123595506,"y":0.05905617977528093},"p2":{"x":0,"y":39.5}}},{"ID":"174","typeID":"Arrow","zOrder":"22","w":"94","h":"1","measuredW":"150","measuredH":"100","x":"616","y":"1008","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":94,"y":0.5},"p1":{"x":0.6535117710266678,"y":-0.0007814789489108132},"p2":{"x":0,"y":0.5}}},{"ID":"175","typeID":"Arrow","zOrder":"21","w":"1","h":"69","measuredW":"150","measuredH":"100","x":"374","y":"924","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":0},"p1":{"x":0.4819277108433732,"y":0.018072289156626505},"p2":{"x":0,"y":68.5}}},{"ID":"176","typeID":"Arrow","zOrder":"20","w":"1","h":"69","measuredW":"150","measuredH":"100","x":"434","y":"927","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":0},"p1":{"x":0.4819277108433732,"y":0.018072289156626505},"p2":{"x":0,"y":68.5}}},{"ID":"177","typeID":"Arrow","zOrder":"19","w":"1","h":"69","measuredW":"150","measuredH":"100","x":"506","y":"925","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":0},"p1":{"x":0.4819277108433732,"y":0.018072289156626505},"p2":{"x":0,"y":68.5}}},{"ID":"178","typeID":"Arrow","zOrder":"18","w":"1","h":"69","measuredW":"150","measuredH":"100","x":"589","y":"922","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":0},"p1":{"x":0.4819277108433732,"y":0.018072289156626505},"p2":{"x":0,"y":68.5}}},{"ID":"179","typeID":"Canvas","zOrder":"159","w":"110","h":"43","measuredW":"100","measuredH":"70","x":"182","y":"874","properties":{"color":"16776960"}},{"ID":"180","typeID":"Label","zOrder":"160","measuredW":"46","measuredH":"24","x":"214","y":"884","properties":{"size":"16","text":"ORMs"}},{"ID":"181","typeID":"Arrow","zOrder":"17","w":"99","h":"108","measuredW":"150","measuredH":"100","x":"270","y":"899","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":99,"y":107.5},"p1":{"x":0.4816540477577168,"y":0.3011065812463601},"p2":{"x":1,"y":0}}},{"ID":"182","typeID":"Canvas","zOrder":"161","w":"89","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"875","properties":{"color":"16770457"}},{"ID":"183","typeID":"Label","zOrder":"162","measuredW":"50","measuredH":"24","x":"89","y":"884","properties":{"size":"16","text":"GORM"}},{"ID":"184","typeID":"Arrow","zOrder":"16","w":"77","h":"1","measuredW":"150","measuredH":"100","x":"150","y":"895","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":1.5},"p1":{"x":0.4819277108433731,"y":0.018072289156626502},"p2":{"x":77,"y":1.5}}},{"ID":"185","typeID":"Canvas","zOrder":"163","w":"275","h":"43","measuredW":"100","measuredH":"70","x":"343","y":"1033","properties":{"color":"16776960"}},{"ID":"186","typeID":"Label","zOrder":"164","measuredW":"59","measuredH":"24","x":"443","y":"1043","properties":{"size":"16","text":"Logging"}},{"ID":"187","typeID":"Canvas","zOrder":"165","w":"187","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"1033","properties":{"color":"16770457"}},{"ID":"188","typeID":"Label","zOrder":"166","measuredW":"29","measuredH":"24","x":"148","y":"1042","properties":{"size":"16","text":"Zap"}},{"ID":"189","typeID":"Canvas","zOrder":"167","w":"187","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"985","properties":{"color":"16770457"}},{"ID":"190","typeID":"Label","zOrder":"168","measuredW":"50","measuredH":"24","x":"138","y":"994","properties":{"size":"16","text":"Logrus"}},{"ID":"193","typeID":"Canvas","zOrder":"169","w":"275","h":"43","measuredW":"100","measuredH":"70","x":"343","y":"1080","properties":{"color":"16776960"}},{"ID":"194","typeID":"Label","zOrder":"170","measuredW":"184","measuredH":"24","x":"389","y":"1090","properties":{"size":"16","text":"Real time communication"}},{"ID":"195","typeID":"Arrow","zOrder":"15","w":"121","h":"3","measuredW":"150","measuredH":"100","x":"235","y":"1054","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":120.5,"y":2},"p1":{"x":0.5993031358885019,"y":0.01393728222996517},"p2":{"x":0,"y":0}}},{"ID":"196","typeID":"Arrow","zOrder":"14","w":"111","h":"43","measuredW":"150","measuredH":"100","x":"244","y":"1005","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":110.5,"y":43},"p1":{"x":0.5740822925252013,"y":0.09902998795409876},"p2":{"x":0,"y":0}}},{"ID":"197","typeID":"Canvas","zOrder":"171","w":"205","h":"42","measuredW":"100","measuredH":"70","x":"687","y":"1032","properties":{"color":"16770457"}},{"ID":"198","typeID":"Label","zOrder":"172","measuredW":"53","measuredH":"24","x":"763","y":"1041","properties":{"size":"16","text":"Melody"}},{"ID":"199","typeID":"Canvas","zOrder":"173","w":"205","h":"42","measuredW":"100","measuredH":"70","x":"687","y":"1080","properties":{"color":"16770457"}},{"ID":"200","typeID":"Label","zOrder":"174","measuredW":"77","measuredH":"24","x":"751","y":"1089","properties":{"size":"16","text":"Centrifugo"}},{"ID":"201","typeID":"Arrow","zOrder":"12","w":"92","h":"4","measuredW":"150","measuredH":"100","x":"605","y":"1101","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":91.5,"y":-0.5},"p1":{"x":0.6535117710266678,"y":-0.0007814789489108073},"p2":{"x":0,"y":3.5}}},{"ID":"202","typeID":"Arrow","zOrder":"13","w":"93","h":"49","measuredW":"150","measuredH":"100","x":"604","y":"1048","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":92.5,"y":-0.5},"p1":{"x":0.5439101123595507,"y":0.059056179775280944},"p2":{"x":0,"y":48.5}}},{"ID":"206","typeID":"Canvas","zOrder":"175","w":"275","h":"43","measuredW":"100","measuredH":"70","x":"342","y":"1128","properties":{"color":"16776960"}},{"ID":"207","typeID":"Label","zOrder":"176","measuredW":"80","measuredH":"24","x":"440","y":"1138","properties":{"size":"16","text":"API Clients"}},{"ID":"209","typeID":"Canvas","zOrder":"177","w":"90","h":"42","measuredW":"100","measuredH":"70","x":"220","y":"1109","properties":{"color":"16770457"}},{"ID":"210","typeID":"Label","zOrder":"178","measuredW":"41","measuredH":"24","x":"244","y":"1118","properties":{"size":"16","text":"REST"}},{"ID":"211","typeID":"Canvas","zOrder":"179","w":"113","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"1089","properties":{"color":"16770457"}},{"ID":"212","typeID":"Label","zOrder":"180","measuredW":"64","measuredH":"24","x":"94","y":"1098","properties":{"size":"16","text":"Heimdall"}},{"ID":"213","typeID":"Canvas","zOrder":"181","w":"113","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"1136","properties":{"color":"16770457"}},{"ID":"214","typeID":"Label","zOrder":"182","measuredW":"82","measuredH":"24","x":"85","y":"1145","properties":{"size":"16","text":"GRequests"}},{"ID":"215","typeID":"Arrow","zOrder":"11","w":"70","h":"24","measuredW":"150","measuredH":"100","x":"300","y":"1123","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":69.5,"y":23},"p1":{"x":0.5649908976333847,"y":0.09399243803388879},"p2":{"x":-0.5,"y":-0.5}}},{"ID":"216","typeID":"Arrow","zOrder":"10","w":"64","h":"19","measuredW":"150","measuredH":"100","x":"173","y":"1107","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":63.5,"y":18.5},"p1":{"x":0.5728068207314337,"y":0.12317702490464438},"p2":{"x":-0.5,"y":-0.5}}},{"ID":"217","typeID":"Arrow","zOrder":"9","w":"68","h":"26","measuredW":"150","measuredH":"100","x":"165","y":"1134","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":67.5,"y":-0.5},"p1":{"x":0.5348310364357182,"y":-0.0641872758164999},"p2":{"x":-0.5,"y":25.5}}},{"ID":"218","typeID":"Canvas","zOrder":"183","w":"90","h":"42","measuredW":"100","measuredH":"70","x":"220","y":"1158","properties":{"color":"16770457"}},{"ID":"219","typeID":"Label","zOrder":"184","measuredW":"67","measuredH":"24","x":"231","y":"1167","properties":{"size":"16","text":"GraphQL"}},{"ID":"220","typeID":"Arrow","zOrder":"8","w":"57","h":"28","measuredW":"150","measuredH":"100","x":"305","y":"1151","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":56.5,"y":-0.5},"p1":{"x":0.6131911728242003,"y":-0.0731465410364493},"p2":{"x":-0.5,"y":27.5}}},{"ID":"221","typeID":"Canvas","zOrder":"185","w":"113","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"1186","properties":{"color":"16770457"}},{"ID":"222","typeID":"Label","zOrder":"186","measuredW":"79","measuredH":"24","x":"86","y":"1195","properties":{"size":"16","text":"graphql-go"}},{"ID":"223","typeID":"Canvas","zOrder":"187","w":"113","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"1232","properties":{"color":"16770457"}},{"ID":"224","typeID":"Label","zOrder":"188","measuredW":"50","measuredH":"24","x":"101","y":"1241","properties":{"size":"16","text":"gqlgen"}},{"ID":"225","typeID":"Arrow","zOrder":"7","w":"68","h":"61","measuredW":"150","measuredH":"100","x":"171","y":"1188","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":67.5,"y":-0.5},"p1":{"x":0.5024657534246576,"y":0.1665753424657536},"p2":{"x":-0.5,"y":60.5}}},{"ID":"226","typeID":"Arrow","zOrder":"6","w":"68","h":"20","measuredW":"150","measuredH":"100","x":"174","y":"1187","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":67.5,"y":0.5},"p1":{"x":0.5100630820066085,"y":-0.10093121057374592},"p2":{"x":-0.5,"y":19.5}}},{"ID":"227","typeID":"Arrow","zOrder":"5","w":"203","h":"97","measuredW":"150","measuredH":"100","x":"598","y":"1151","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":0,"y":0},"p1":{"x":0.6598560011876191,"y":0.20776405967785833},"p2":{"x":203,"y":96.5}}},{"ID":"230","typeID":"Canvas","zOrder":"189","w":"275","h":"43","measuredW":"100","measuredH":"70","x":"685","y":"1229","properties":{"color":"16776960"}},{"ID":"231","typeID":"Label","zOrder":"190","measuredW":"128","measuredH":"24","x":"759","y":"1239","properties":{"size":"16","text":"Testing your Apps"}},{"ID":"232","typeID":"Canvas","zOrder":"191","w":"313","h":"43","measuredW":"100","measuredH":"70","x":"306","y":"1225","properties":{"color":"16776960"}},{"ID":"233","typeID":"Label","zOrder":"192","measuredW":"167","measuredH":"24","x":"379","y":"1235","properties":{"size":"16","text":"Tools for Microservices"}},{"ID":"234","typeID":"Arrow","zOrder":"4","w":"121","h":"3","measuredW":"150","measuredH":"100","x":"588","y":"1248","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":120.5,"y":2},"p1":{"x":0.5993031358885019,"y":0.01393728222996517},"p2":{"x":0,"y":0}}},{"ID":"235","typeID":"Canvas","zOrder":"193","w":"179","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"1315","properties":{"color":"16770457"}},{"ID":"236","typeID":"Label","zOrder":"194","measuredW":"67","measuredH":"24","x":"125","y":"1324","properties":{"size":"16","text":"Watermill"}},{"ID":"237","typeID":"Canvas","zOrder":"195","w":"148","h":"42","measuredW":"100","measuredH":"70","x":"260","y":"1315","properties":{"color":"16770457"}},{"ID":"238","typeID":"Label","zOrder":"196","measuredW":"32","measuredH":"24","x":"318","y":"1324","properties":{"size":"16","text":"rpcx"}},{"ID":"241","typeID":"Canvas","zOrder":"197","w":"148","h":"42","measuredW":"100","measuredH":"70","x":"260","y":"1360","properties":{"color":"16770457"}},{"ID":"242","typeID":"Label","zOrder":"198","measuredW":"44","measuredH":"24","x":"312","y":"1369","properties":{"size":"16","text":"Go-kit"}},{"ID":"243","typeID":"Canvas","zOrder":"199","w":"148","h":"42","measuredW":"100","measuredH":"70","x":"260","y":"1406","properties":{"color":"16770457"}},{"ID":"244","typeID":"Label","zOrder":"200","measuredW":"41","measuredH":"24","x":"313","y":"1415","properties":{"size":"16","text":"Micro"}},{"ID":"245","typeID":"Canvas","zOrder":"201","w":"148","h":"42","measuredW":"100","measuredH":"70","x":"260","y":"1452","properties":{"color":"16770457"}},{"ID":"246","typeID":"Label","zOrder":"202","measuredW":"56","measuredH":"24","x":"306","y":"1461","properties":{"size":"16","text":"go-zero"}},{"ID":"255","typeID":"Canvas","zOrder":"203","w":"148","h":"42","measuredW":"100","measuredH":"70","x":"424","y":"1315","properties":{"color":"16770457"}},{"ID":"256","typeID":"Label","zOrder":"204","measuredW":"115","measuredH":"24","x":"440","y":"1324","properties":{"size":"16","text":"Protocol Buffers"}},{"ID":"257","typeID":"Canvas","zOrder":"205","w":"148","h":"42","measuredW":"100","measuredH":"70","x":"424","y":"1361","properties":{"color":"16770457"}},{"ID":"258","typeID":"Label","zOrder":"206","measuredW":"69","measuredH":"24","x":"463","y":"1370","properties":{"size":"16","text":"gRPC-Go"}},{"ID":"259","typeID":"Canvas","zOrder":"207","w":"148","h":"42","measuredW":"100","measuredH":"70","x":"424","y":"1407","properties":{"color":"16770457"}},{"ID":"260","typeID":"Label","zOrder":"208","measuredW":"108","measuredH":"24","x":"444","y":"1416","properties":{"size":"16","text":"gRPC-gateway"}},{"ID":"261","typeID":"Canvas","zOrder":"209","w":"148","h":"42","measuredW":"100","measuredH":"70","x":"424","y":"1453","properties":{"color":"16770457"}},{"ID":"262","typeID":"Label","zOrder":"210","measuredW":"35","measuredH":"24","x":"480","y":"1462","properties":{"size":"16","text":"twirp"}},{"ID":"263","typeID":"Arrow","zOrder":"3","w":"140","h":"78","measuredW":"150","measuredH":"100","x":"217","y":"1245","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":139.5,"y":1},"p1":{"x":0.5976080058579448,"y":-0.22367586038564805},"p2":{"x":-0.5,"y":78.5}}},{"ID":"264","typeID":"Arrow","zOrder":"2","w":"1","h":"69","measuredW":"150","measuredH":"100","x":"344","y":"1250","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":-0.5,"y":0},"p1":{"x":0.37281767955801104,"y":0.003535911602209944},"p2":{"x":-0.5,"y":69}}},{"ID":"266","typeID":"Arrow","zOrder":"1","w":"1","h":"69","measuredW":"150","measuredH":"100","x":"497","y":"1261","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":-0.5,"y":0},"p1":{"x":0.37281767955801104,"y":0.003535911602209944},"p2":{"x":-0.5,"y":69}}},{"ID":"267","typeID":"Arrow","zOrder":"0","w":"206","h":"329","measuredW":"150","measuredH":"100","x":"576","y":"1249","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":0,"y":0},"p1":{"x":0.4190752404149273,"y":0.21784346648791786},"p2":{"x":206,"y":329}}},{"ID":"268","typeID":"Arrow","zOrder":"211","w":"1","h":"98","measuredW":"150","measuredH":"100","x":"781","y":"1606","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":-0.5,"y":-0.5},"p1":{"x":0.5259259259259262,"y":0},"p2":{"x":-0.5,"y":97},"stroke":"dotted"}},{"ID":"269","typeID":"Canvas","zOrder":"212","w":"468","h":"84","measuredW":"100","measuredH":"70","x":"480","y":"1551"},{"ID":"270","typeID":"Label","zOrder":"213","measuredW":"407","measuredH":"28","x":"510","y":"1567","properties":{"size":"20","text":"Backend Roadmap after Language Selection"}},{"ID":"271","typeID":"Label","zOrder":"214","measuredW":"153","measuredH":"24","x":"637","y":"1595","properties":{"size":"16","text":"roadmap.sh/backend","color":"10027263"}}]},"attributes":{"name":"New Wireframe 5","order":1000041.0338040869,"parentID":null,"notes":null},"branchID":"Master","resourceID":"9F49BED8-E849-48D8-8656-2D19484CE0B0","mockupH":"1575","mockupW":"899","measuredW":"968","measuredH":"1704","version":"1.0"}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/golang/resources.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/golang/resources.json new file mode 100644 index 000000000..cb323e03c --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/golang/resources.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a Go developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a golang developer","guide to becoming a go developer","golang developer","go developer","guide to golang","guide to go","golang roadmap","go roadmap","golang skills","go skills","golang skills test","go skills test","skills for golang","skills for go","cloud development","what is golang","what is go","golang quiz","go quiz","golang interview questions","go interview questions"]},"title":"Go Developer","description":"Step by step guide to becoming a Go developer in 2021","featuredTitle":"Go","featuredDescription":"Step by step guide to becoming a Go developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"/roadmaps/107-golang/landscape.md","resourcesPath":"/roadmaps/107-golang/resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/go-roadmap","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"golang","metaPath":"/roadmaps/107-golang/meta.json"}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides.json new file mode 100644 index 000000000..3bfcd48ad --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides.json @@ -0,0 +1 @@ +{"pageProps":{"guides":[{"id":"avoid-render-blocking-javascript-with-async-defer","title":"Async and Defer Script Loading","description":"Learn how to avoid render blocking JavaScript using async and defer scripts.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-09-10T19:59:14.191Z","createdAt":"2021-09-10T19:59:14.191Z","formattedCreatedAt":"September 10, 2021","formattedUpdatedAt":"September 10, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"what-are-web-vitals","title":"What are Web Vitals?","description":"Learn what are the core web vitals and how to measure them.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-09-05T19:59:14.191Z","createdAt":"2021-09-05T19:59:14.191Z","formattedCreatedAt":"September 5, 2021","formattedUpdatedAt":"September 5, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"what-is-sli-slo-sla","title":"SLIs, SLOs and SLAs","description":"Learn what are different indicators for performance identification of any service.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-08-31T19:59:14.191Z","createdAt":"2021-08-31T19:59:14.191Z","formattedCreatedAt":"August 31, 2021","formattedUpdatedAt":"August 31, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"ci-cd","title":"What is CI and CD?","description":"Learn the basics of CI/CD and how to implement that with GitHub Actions.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-07-09T19:59:14.191Z","createdAt":"2021-07-09T19:59:14.191Z","formattedCreatedAt":"July 9, 2021","formattedUpdatedAt":"July 9, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"sso","title":"SSO — Single Sign On","description":"Learn the basics of SAML and understand how does Single Sign On work.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-07-01T19:59:14.191Z","createdAt":"2021-07-01T19:59:14.191Z","formattedCreatedAt":"July 1, 2021","formattedUpdatedAt":"July 1, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"oauth","title":"OAuth — Open Authorization","description":"Learn and understand what is OAuth and how it works","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-06-28T19:59:14.191Z","createdAt":"2021-06-28T19:59:14.191Z","formattedCreatedAt":"June 28, 2021","formattedUpdatedAt":"June 28, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"jwt-authentication","title":"JWT Authentication","description":"Understand what is JWT authentication and how is it implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-06-20T19:59:14.191Z","createdAt":"2021-06-20T19:59:14.191Z","formattedCreatedAt":"June 20, 2021","formattedUpdatedAt":"June 20, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"token-authentication","title":"Token Based Authentication","description":"Understand what is token based authentication and how it is implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-06-02T20:59:14.191Z","createdAt":"2021-06-02T20:59:14.191Z","formattedCreatedAt":"June 2, 2021","formattedUpdatedAt":"June 2, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"session-authentication","title":"Session Based Authentication","description":"Understand what is session based authentication and how it is implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-26T20:59:14.191Z","createdAt":"2021-05-26T20:59:14.191Z","formattedCreatedAt":"May 26, 2021","formattedUpdatedAt":"May 26, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"basic-authentication","title":"Basic Authentication","description":"Understand what is basic authentication and how it is implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-19T20:59:14.191Z","createdAt":"2021-05-19T20:59:14.191Z","formattedCreatedAt":"May 19, 2021","formattedUpdatedAt":"May 19, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"character-encodings","title":"Character Encodings","description":"Covers the basics of character encodings and explains ASCII vs Unicode","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-14T20:59:14.191Z","createdAt":"2021-05-14T20:59:14.191Z","formattedCreatedAt":"May 14, 2021","formattedUpdatedAt":"May 14, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"unfamiliar-codebase","title":"Unfamiliar Codebase","description":"Tips on getting getting familiar with an unfamiliar codebase","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-04T20:59:14.191Z","createdAt":"2021-05-04T20:59:14.191Z","formattedCreatedAt":"May 4, 2021","formattedUpdatedAt":"May 4, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"why-build-it-and-they-will-come-wont-work-anymore","title":"Build it and they will come?","description":"Why “build it and they will come” alone won’t work anymore","isPro":false,"authorUsername":"spekulatius","updatedAt":"2021-05-04T12:59:14.191Z","createdAt":"2021-05-04T12:59:14.191Z","formattedCreatedAt":"May 4, 2021","formattedUpdatedAt":"May 4, 2021","author":{"username":"spekulatius","name":"Peter Thaleikis","twitter":"spekulatius1984","picture":"/authors/spekulatius.jpg","bio":"Developer building side-projects for fun, lover of the web and open source"}},{"id":"dhcp-in-one-picture","title":"DHCP in One Picture","description":"Here is what happens when a new device joins the network.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-04-28T15:48:21.191Z","createdAt":"2021-04-28T15:48:21.191Z","formattedCreatedAt":"April 28, 2021","formattedUpdatedAt":"April 28, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"ssl-tls-https-ssh","title":"SSL vs TLS vs SSH","description":"Quick tidbit on the differences between SSL, TLS, HTTPS and SSH","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-04-22T15:48:21.191Z","createdAt":"2021-04-22T15:48:21.191Z","formattedCreatedAt":"April 22, 2021","formattedUpdatedAt":"April 22, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"asymptotic-notation","title":"Asymptotic Notation","description":"Learn the basics of measuring the time and space complexity of algorithms","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-04-03T15:48:21.191Z","createdAt":"2021-04-03T15:48:21.191Z","formattedCreatedAt":"April 3, 2021","formattedUpdatedAt":"April 3, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"big-o-notation","title":"Big-O Notation","description":"Easy to understand explanation of Big-O notation without any fancy terms","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-03-15T15:48:21.191Z","createdAt":"2021-03-15T15:48:21.191Z","formattedCreatedAt":"March 15, 2021","formattedUpdatedAt":"March 15, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"random-numbers","title":"Random Numbers: Are they?","description":"Learn how they are generated and why they may not be truly random.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-03-14T15:48:21.191Z","createdAt":"2021-03-14T15:48:21.191Z","formattedCreatedAt":"March 14, 2021","formattedUpdatedAt":"March 14, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"what-is-internet","title":"How does the internet work?","description":"Learn the basics of internet and everything involved with this short video series","isPro":false,"authorUsername":"dmytrobol","updatedAt":"2021-02-29T15:48:21.191Z","createdAt":"2021-02-29T15:48:21.191Z","formattedCreatedAt":"March 1, 2021","formattedUpdatedAt":"March 1, 2021","author":{"username":"dmytrobol","name":"Dmytro Bolkachov","twitter":"dmytrobol","picture":"/authors/dmytrobol.png","bio":"JavaScript Lad, Movie buff and coder interested in everything web related"}},{"id":"scaling-databases","title":"Scaling Databases","description":"Learn the ups and downs of different database scaling strategies","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-02-18T15:48:21.191Z","createdAt":"2021-02-18T15:48:21.191Z","formattedCreatedAt":"February 18, 2021","formattedUpdatedAt":"February 18, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"torrent-client","title":"Building a BitTorrent Client","description":"Learn everything you need to know about BitTorrent by writing a client in Go","isPro":false,"authorUsername":"jesse","updatedAt":"2021-01-17T15:48:21.191Z","createdAt":"2021-01-17T15:48:21.191Z","canonical":"https://blog.jse.li/posts/torrent/","formattedCreatedAt":"January 17, 2021","formattedUpdatedAt":"January 17, 2021","author":{"username":"jesse","name":"Jesse Li","twitter":"__jesse_li","picture":"/authors/jesse.png","bio":"Software engineer."}},{"id":"levels-of-seniority","title":"Levels of Seniority","description":"How to Step Up as a Junior, Mid Level or a Senior Developer?","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2020-12-03T12:13:00.860Z","createdAt":"2020-12-03T12:13:00.860Z","formattedCreatedAt":"December 3, 2020","formattedUpdatedAt":"December 3, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"design-patterns-for-humans","title":"Design Patterns for Humans","description":"A language agnostic, ultra-simplified explanation to design patterns","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2019-10-09T12:00:00.860Z","createdAt":"2019-01-23T17:00:00.860Z","formattedCreatedAt":"January 23, 2019","formattedUpdatedAt":"October 9, 2019","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"dns-in-one-picture","title":"DNS in One Picture","description":"Quick illustrative guide on how a website is found on the internet.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2018-12-04T12:00:00.860Z","createdAt":"2018-12-04T17:00:00.860Z","formattedCreatedAt":"December 4, 2018","formattedUpdatedAt":"December 4, 2018","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"http-caching","title":"HTTP Caching","description":"Everything you need to know about web caching","isPro":false,"authorUsername":"kamranahmedse","createdAt":"2018-11-29T17:00:00.860Z","updatedAt":"2018-11-29T17:00:00.860Z","formattedCreatedAt":"November 29, 2018","formattedUpdatedAt":"November 29, 2018","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"history-of-javascript","title":"Brief History of JavaScript","description":"How JavaScript was introduced and evolved over the years","isPro":false,"authorUsername":"kamranahmedse","createdAt":"2017-10-28T17:00:00.860Z","updatedAt":"2017-10-28T17:00:00.860Z","formattedCreatedAt":"October 28, 2017","formattedUpdatedAt":"October 28, 2017","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"proxy-servers","title":"Proxy Servers","description":"How do proxy servers work and what are forward and reverse proxies?","isPro":false,"authorUsername":"ebrahimbharmal007","createdAt":"2017-10-24T17:00:00.860Z","updatedAt":"2017-10-24T17:00:00.860Z","formattedCreatedAt":"October 24, 2017","formattedUpdatedAt":"October 24, 2017","author":{"username":"ebrahimbharmal007","name":"Ebrahim Bharmal","twitter":"BharmalEbrahim","picture":"/authors/ebrahimbharmal007.png","bio":"Love building projects using tools completely new to me. Python forever. Senior at University of Texas at Arlington (2021)"}}]},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/asymptotic-notation.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/asymptotic-notation.json new file mode 100644 index 000000000..bfd87e789 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/asymptotic-notation.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"asymptotic-notation","title":"Asymptotic Notation","description":"Learn the basics of measuring the time and space complexity of algorithms","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-04-03T15:48:21.191Z","createdAt":"2021-04-03T15:48:21.191Z","formattedCreatedAt":"April 3, 2021","formattedUpdatedAt":"April 3, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/avoid-render-blocking-javascript-with-async-defer.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/avoid-render-blocking-javascript-with-async-defer.json new file mode 100644 index 000000000..7d1b3d4df --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/avoid-render-blocking-javascript-with-async-defer.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"avoid-render-blocking-javascript-with-async-defer","title":"Async and Defer Script Loading","description":"Learn how to avoid render blocking JavaScript using async and defer scripts.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-09-10T19:59:14.191Z","createdAt":"2021-09-10T19:59:14.191Z","formattedCreatedAt":"September 10, 2021","formattedUpdatedAt":"September 10, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/basic-authentication.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/basic-authentication.json new file mode 100644 index 000000000..7e3b18828 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/basic-authentication.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"basic-authentication","title":"Basic Authentication","description":"Understand what is basic authentication and how it is implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-19T20:59:14.191Z","createdAt":"2021-05-19T20:59:14.191Z","formattedCreatedAt":"May 19, 2021","formattedUpdatedAt":"May 19, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/big-o-notation.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/big-o-notation.json new file mode 100644 index 000000000..1bcfa8119 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/big-o-notation.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"big-o-notation","title":"Big-O Notation","description":"Easy to understand explanation of Big-O notation without any fancy terms","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-03-15T15:48:21.191Z","createdAt":"2021-03-15T15:48:21.191Z","formattedCreatedAt":"March 15, 2021","formattedUpdatedAt":"March 15, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/character-encodings.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/character-encodings.json new file mode 100644 index 000000000..13ac5dc7c --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/character-encodings.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"character-encodings","title":"Character Encodings","description":"Covers the basics of character encodings and explains ASCII vs Unicode","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-14T20:59:14.191Z","createdAt":"2021-05-14T20:59:14.191Z","formattedCreatedAt":"May 14, 2021","formattedUpdatedAt":"May 14, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/ci-cd.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/ci-cd.json new file mode 100644 index 000000000..61a834e1d --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/ci-cd.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"ci-cd","title":"What is CI and CD?","description":"Learn the basics of CI/CD and how to implement that with GitHub Actions.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-07-09T19:59:14.191Z","createdAt":"2021-07-09T19:59:14.191Z","formattedCreatedAt":"July 9, 2021","formattedUpdatedAt":"July 9, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/design-patterns-for-humans.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/design-patterns-for-humans.json new file mode 100644 index 000000000..b047ded94 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/design-patterns-for-humans.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"design-patterns-for-humans","title":"Design Patterns for Humans","description":"A language agnostic, ultra-simplified explanation to design patterns","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2019-10-09T12:00:00.860Z","createdAt":"2019-01-23T17:00:00.860Z","formattedCreatedAt":"January 23, 2019","formattedUpdatedAt":"October 9, 2019","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/dhcp-in-one-picture.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/dhcp-in-one-picture.json new file mode 100644 index 000000000..ea93afc69 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/dhcp-in-one-picture.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"dhcp-in-one-picture","title":"DHCP in One Picture","description":"Here is what happens when a new device joins the network.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-04-28T15:48:21.191Z","createdAt":"2021-04-28T15:48:21.191Z","formattedCreatedAt":"April 28, 2021","formattedUpdatedAt":"April 28, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/dns-in-one-picture.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/dns-in-one-picture.json new file mode 100644 index 000000000..6fd155770 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/dns-in-one-picture.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"dns-in-one-picture","title":"DNS in One Picture","description":"Quick illustrative guide on how a website is found on the internet.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2018-12-04T12:00:00.860Z","createdAt":"2018-12-04T17:00:00.860Z","formattedCreatedAt":"December 4, 2018","formattedUpdatedAt":"December 4, 2018","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/history-of-javascript.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/history-of-javascript.json new file mode 100644 index 000000000..1884484d6 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/history-of-javascript.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"history-of-javascript","title":"Brief History of JavaScript","description":"How JavaScript was introduced and evolved over the years","isPro":false,"authorUsername":"kamranahmedse","createdAt":"2017-10-28T17:00:00.860Z","updatedAt":"2017-10-28T17:00:00.860Z","formattedCreatedAt":"October 28, 2017","formattedUpdatedAt":"October 28, 2017","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/http-caching.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/http-caching.json new file mode 100644 index 000000000..b7acc472d --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/http-caching.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"http-caching","title":"HTTP Caching","description":"Everything you need to know about web caching","isPro":false,"authorUsername":"kamranahmedse","createdAt":"2018-11-29T17:00:00.860Z","updatedAt":"2018-11-29T17:00:00.860Z","formattedCreatedAt":"November 29, 2018","formattedUpdatedAt":"November 29, 2018","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/jwt-authentication.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/jwt-authentication.json new file mode 100644 index 000000000..e1c486fa7 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/jwt-authentication.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"jwt-authentication","title":"JWT Authentication","description":"Understand what is JWT authentication and how is it implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-06-20T19:59:14.191Z","createdAt":"2021-06-20T19:59:14.191Z","formattedCreatedAt":"June 20, 2021","formattedUpdatedAt":"June 20, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/levels-of-seniority.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/levels-of-seniority.json new file mode 100644 index 000000000..07704edaf --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/levels-of-seniority.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"levels-of-seniority","title":"Levels of Seniority","description":"How to Step Up as a Junior, Mid Level or a Senior Developer?","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2020-12-03T12:13:00.860Z","createdAt":"2020-12-03T12:13:00.860Z","formattedCreatedAt":"December 3, 2020","formattedUpdatedAt":"December 3, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/oauth.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/oauth.json new file mode 100644 index 000000000..f07f5cab3 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/oauth.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"oauth","title":"OAuth — Open Authorization","description":"Learn and understand what is OAuth and how it works","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-06-28T19:59:14.191Z","createdAt":"2021-06-28T19:59:14.191Z","formattedCreatedAt":"June 28, 2021","formattedUpdatedAt":"June 28, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/proxy-servers.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/proxy-servers.json new file mode 100644 index 000000000..0e1c3de5e --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/proxy-servers.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"proxy-servers","title":"Proxy Servers","description":"How do proxy servers work and what are forward and reverse proxies?","isPro":false,"authorUsername":"ebrahimbharmal007","createdAt":"2017-10-24T17:00:00.860Z","updatedAt":"2017-10-24T17:00:00.860Z","formattedCreatedAt":"October 24, 2017","formattedUpdatedAt":"October 24, 2017","author":{"username":"ebrahimbharmal007","name":"Ebrahim Bharmal","twitter":"BharmalEbrahim","picture":"/authors/ebrahimbharmal007.png","bio":"Love building projects using tools completely new to me. Python forever. Senior at University of Texas at Arlington (2021)"}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/random-numbers.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/random-numbers.json new file mode 100644 index 000000000..45da5a209 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/random-numbers.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"random-numbers","title":"Random Numbers: Are they?","description":"Learn how they are generated and why they may not be truly random.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-03-14T15:48:21.191Z","createdAt":"2021-03-14T15:48:21.191Z","formattedCreatedAt":"March 14, 2021","formattedUpdatedAt":"March 14, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/scaling-databases.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/scaling-databases.json new file mode 100644 index 000000000..be2081b31 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/scaling-databases.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"scaling-databases","title":"Scaling Databases","description":"Learn the ups and downs of different database scaling strategies","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-02-18T15:48:21.191Z","createdAt":"2021-02-18T15:48:21.191Z","formattedCreatedAt":"February 18, 2021","formattedUpdatedAt":"February 18, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/session-authentication.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/session-authentication.json new file mode 100644 index 000000000..b30c9a097 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/session-authentication.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"session-authentication","title":"Session Based Authentication","description":"Understand what is session based authentication and how it is implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-26T20:59:14.191Z","createdAt":"2021-05-26T20:59:14.191Z","formattedCreatedAt":"May 26, 2021","formattedUpdatedAt":"May 26, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/ssl-tls-https-ssh.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/ssl-tls-https-ssh.json new file mode 100644 index 000000000..fc9775eca --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/ssl-tls-https-ssh.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"ssl-tls-https-ssh","title":"SSL vs TLS vs SSH","description":"Quick tidbit on the differences between SSL, TLS, HTTPS and SSH","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-04-22T15:48:21.191Z","createdAt":"2021-04-22T15:48:21.191Z","formattedCreatedAt":"April 22, 2021","formattedUpdatedAt":"April 22, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/sso.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/sso.json new file mode 100644 index 000000000..40fe7be33 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/sso.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"sso","title":"SSO — Single Sign On","description":"Learn the basics of SAML and understand how does Single Sign On work.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-07-01T19:59:14.191Z","createdAt":"2021-07-01T19:59:14.191Z","formattedCreatedAt":"July 1, 2021","formattedUpdatedAt":"July 1, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/token-authentication.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/token-authentication.json new file mode 100644 index 000000000..2b799e09e --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/token-authentication.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"token-authentication","title":"Token Based Authentication","description":"Understand what is token based authentication and how it is implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-06-02T20:59:14.191Z","createdAt":"2021-06-02T20:59:14.191Z","formattedCreatedAt":"June 2, 2021","formattedUpdatedAt":"June 2, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/torrent-client.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/torrent-client.json new file mode 100644 index 000000000..f6339801c --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/torrent-client.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"torrent-client","title":"Building a BitTorrent Client","description":"Learn everything you need to know about BitTorrent by writing a client in Go","isPro":false,"authorUsername":"jesse","updatedAt":"2021-01-17T15:48:21.191Z","createdAt":"2021-01-17T15:48:21.191Z","canonical":"https://blog.jse.li/posts/torrent/","formattedCreatedAt":"January 17, 2021","formattedUpdatedAt":"January 17, 2021","author":{"username":"jesse","name":"Jesse Li","twitter":"__jesse_li","picture":"/authors/jesse.png","bio":"Software engineer."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/unfamiliar-codebase.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/unfamiliar-codebase.json new file mode 100644 index 000000000..adb4756b8 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/unfamiliar-codebase.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"unfamiliar-codebase","title":"Unfamiliar Codebase","description":"Tips on getting getting familiar with an unfamiliar codebase","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-04T20:59:14.191Z","createdAt":"2021-05-04T20:59:14.191Z","formattedCreatedAt":"May 4, 2021","formattedUpdatedAt":"May 4, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/what-are-web-vitals.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/what-are-web-vitals.json new file mode 100644 index 000000000..ee99bd0d9 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/what-are-web-vitals.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"what-are-web-vitals","title":"What are Web Vitals?","description":"Learn what are the core web vitals and how to measure them.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-09-05T19:59:14.191Z","createdAt":"2021-09-05T19:59:14.191Z","formattedCreatedAt":"September 5, 2021","formattedUpdatedAt":"September 5, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/what-is-internet.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/what-is-internet.json new file mode 100644 index 000000000..1f5c43012 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/what-is-internet.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"what-is-internet","title":"How does the internet work?","description":"Learn the basics of internet and everything involved with this short video series","isPro":false,"authorUsername":"dmytrobol","updatedAt":"2021-02-29T15:48:21.191Z","createdAt":"2021-02-29T15:48:21.191Z","formattedCreatedAt":"March 1, 2021","formattedUpdatedAt":"March 1, 2021","author":{"username":"dmytrobol","name":"Dmytro Bolkachov","twitter":"dmytrobol","picture":"/authors/dmytrobol.png","bio":"JavaScript Lad, Movie buff and coder interested in everything web related"}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/what-is-sli-slo-sla.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/what-is-sli-slo-sla.json new file mode 100644 index 000000000..69786addf --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/what-is-sli-slo-sla.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"what-is-sli-slo-sla","title":"SLIs, SLOs and SLAs","description":"Learn what are different indicators for performance identification of any service.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-08-31T19:59:14.191Z","createdAt":"2021-08-31T19:59:14.191Z","formattedCreatedAt":"August 31, 2021","formattedUpdatedAt":"August 31, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/why-build-it-and-they-will-come-wont-work-anymore.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/why-build-it-and-they-will-come-wont-work-anymore.json new file mode 100644 index 000000000..a3e5e5546 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/guides/why-build-it-and-they-will-come-wont-work-anymore.json @@ -0,0 +1 @@ +{"pageProps":{"guide":{"id":"why-build-it-and-they-will-come-wont-work-anymore","title":"Build it and they will come?","description":"Why “build it and they will come” alone won’t work anymore","isPro":false,"authorUsername":"spekulatius","updatedAt":"2021-05-04T12:59:14.191Z","createdAt":"2021-05-04T12:59:14.191Z","formattedCreatedAt":"May 4, 2021","formattedUpdatedAt":"May 4, 2021","author":{"username":"spekulatius","name":"Peter Thaleikis","twitter":"spekulatius1984","picture":"/authors/spekulatius.jpg","bio":"Developer building side-projects for fun, lover of the web and open source"}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/index.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/index.json new file mode 100644 index 000000000..9a73e4e8a --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/index.json @@ -0,0 +1 @@ +{"pageProps":{"roadmaps":[{"seo":{"title":"Learn to become a modern frontend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern frontend development. Learn to become a modern frontend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a frontend developer","frontend developer","frontend engineer","frontend skills","frontend development","javascript developer","frontend development skills","frontend development skills test","frontend engineer roadmap","frontend developer roadmap","become a frontend developer","frontend developer career path","javascript developer","modern javascript developer","node developer","skills for frontend development","learn frontend development","what is frontend development","frontend developer quiz","frontend developer interview questions"]},"title":"Frontend Developer","description":"Step by step guide to becoming a modern frontend developer in 2021","featuredTitle":"Frontend","featuredDescription":"Step by step guide to becoming a frontend developer in 2021","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"featured":true,"imagePath":"/roadmaps/frontend.png","resourcesPath":"/roadmaps/100-frontend/resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/frontend-roadmap","id":"frontend","metaPath":"/roadmaps/100-frontend/meta.json","isUpcoming":false},{"seo":{"title":"Learn to become a modern backend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern backend development. Learn to become a modern backend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a backend developer","backend developer","backend engineer","backend skills","backend development","javascript developer","backend development skills","backend development skills test","backend engineer roadmap","backend developer roadmap","become a backend developer","backend developer career path","javascript developer","modern javascript developer","node developer","skills for backend development","learn backend development","what is backend development","backend developer quiz","backend developer interview questions"]},"title":"Backend Developer","description":"Step by step guide to becoming a modern backend developer in 2021","featuredTitle":"Backend","featuredDescription":"Step by step guide to becoming a backend developer in 2021","featured":true,"imagePath":"/roadmaps/backend.png","resourcesPath":"/roadmaps/101-backend/resources.md","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/backend-roadmap","id":"backend","metaPath":"/roadmaps/101-backend/meta.json","isUpcoming":false},{"seo":{"title":"DevOps Roadmap: Learn to become a DevOps Engineer or SRE","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a devops enginer","devops roadmap","sre roadmap","site reliability engineer roadmap","operations roles","become devops","devops skills","modern devops skills","devops skills test","skills for devops","learn devops","what is devops","what is sre","devops quiz","devops interview questions"]},"title":"DevOps Roadmap","description":"Step by step guide for DevOps, SRE or any other Operations Role in 2021","featuredTitle":"DevOps","featuredDescription":"Step by step guide for DevOps or operations role in 2021","featured":true,"imagePath":"/roadmaps/devops.png","resourcesPath":"/roadmaps/102-devops/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/devops-roadmap","id":"devops","metaPath":"/roadmaps/102-devops/meta.json","isUpcoming":false},{"seo":{"title":"React Developer Roadmap: Learn to become a React developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a react developer","react developer roadmap","react roadmap","become react developer","react developer skills","react skills test","skills for react development","learn react development","what is react","react quiz","react interview questions"]},"title":"React Developer","description":"Everything that is there to learn about React and the ecosystem in 2021.","featuredTitle":"React","featuredDescription":"Step by step guide to become a React Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/103-react/landscape.md","resourcesPath":"/roadmaps/103-react/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/react-roadmap","id":"react","metaPath":"/roadmaps/103-react/meta.json","isUpcoming":false},{"seo":{"title":"Angular Developer Roadmap: Learn to become a Angular developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for angular development. Learn to become a modern Angular developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a angular developer","angular developer roadmap","angular roadmap","become angular developer","angular developer skills","angular skills test","skills for angular development","learn angular development","what is angular","angular quiz","angular interview questions"]},"title":"Angular Developer","description":"Everything that is there to learn about Angular and the ecosystem in 2021.","featuredTitle":"Angular","featuredDescription":"Step by step guide to become a Angular Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/104-angular/landscape.md","resourcesPath":"/roadmaps/104-angular/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/angular-roadmap","id":"angular","metaPath":"/roadmaps/104-angular/meta.json","isUpcoming":false},{"seo":{"title":"Android Developer Roadmap: Learn to become an Android developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for android development. Learn to become a modern Android developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an android developer","android developer roadmap","android roadmap","become android developer","android developer skills","android skills test","skills for android development","learn android development","what is android","android quiz","android interview questions"]},"title":"Android Developer","description":"Step by step guide to becoming an Android developer in 2021","featuredTitle":"Android","featuredDescription":"Step by step guide to becoming an Android Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/105-android/landscape.md","resourcesPath":"/roadmaps/105-android/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"android","metaPath":"/roadmaps/105-android/meta.json","isUpcoming":false},{"seo":{"title":"Learn to become a modern Python developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for python development. Learn to become a modern Python developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an python developer","python developer roadmap","python roadmap","become python developer","python developer skills","python skills test","skills for python development","learn python development","what is python","python quiz","python interview questions"]},"title":"Python Developer","description":"Step by step guide to becoming a Python developer in 2021","featuredTitle":"Python","featuredDescription":"Step by step guide to becoming a Python Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"resourcesPath":"/roadmaps/106-python/resources.md","contentPath":"/roadmaps/106-python/landscape.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/python-roadmap","versions":["latest"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"python","metaPath":"/roadmaps/106-python/meta.json","isUpcoming":false},{"seo":{"title":"Learn to become a Go developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a golang developer","guide to becoming a go developer","golang developer","go developer","guide to golang","guide to go","golang roadmap","go roadmap","golang skills","go skills","golang skills test","go skills test","skills for golang","skills for go","cloud development","what is golang","what is go","golang quiz","go quiz","golang interview questions","go interview questions"]},"title":"Go Developer","description":"Step by step guide to becoming a Go developer in 2021","featuredTitle":"Go","featuredDescription":"Step by step guide to becoming a Go developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"/roadmaps/107-golang/landscape.md","resourcesPath":"/roadmaps/107-golang/resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/go-roadmap","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"golang","metaPath":"/roadmaps/107-golang/meta.json"},{"seo":{"title":"Learn to become a modern Java developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a java developer","java developer","java engineer","java skills","guide to java","java roadmap","java skills","java skills test","skills for java","cloud development","what is java","java quiz","java interview questions","java engineer roadmap","java developer roadmap","become a java developer","java developer career path","java developer","modern java developer"]},"title":"Java Developer","description":"Step by step guide to becoming a Java developer in 2021","featuredTitle":"Java","featuredDescription":"Step by step guide to becoming a Java Developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"/roadmaps/108-java/landscape.md","resourcesPath":"/roadmaps/108-java/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/java-roadmap","id":"java","metaPath":"/roadmaps/108-java/meta.json"},{"seo":{"title":"DBA Roadmap: Learn to become a database administrator with PostgreSQL","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a database administrator","guide to becoming a DBA","dba roadmap","db administrator roadmap","database administrator roadmap","postgresql roadmap","dba skills","db administrator skills","become dba","postgresql skills","modern dba skills","dba skills test","skills for dba","skills for database administrator","learn dba","what is dba","database administrator quiz","dba interview questions"]},"title":"PostgreSQL DBA","description":"Step by step guide to becoming a modern PostgreSQL DB Administrator in 2021","featuredTitle":"DBA","featuredDescription":"Step by step guide to become a PostgreSQL DBA in 2021","contentPath":"/roadmaps/109-postgresql-dba/landscape.md","resourcesPath":"/roadmaps/109-postgresql-dba/resources.md","author":{"name":"Alexey Lesovsky","url":"https://github.com/lesovsky"},"isCommunity":false,"isTextHeavy":true,"featured":true,"detailed":false,"versions":[],"id":"postgresql-dba","metaPath":"/roadmaps/109-postgresql-dba/meta.json","isUpcoming":false},{"seo":{"title":"AWS Roadmap: Learn to use AWS","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to aws","aws roadmap","aws skills","aws skills test","skills for aws","cloud development","what is aws","aws quiz","aws interview questions"]},"title":"AWS","description":"Everything that is there to learn about AWS and the ecosystem in 2021.","featuredTitle":"AWS","featuredDescription":"Step by step guide to learn AWS in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":true,"featured":true,"contentPath":"/roadmaps/110-aws/landscape.md","resourcesPath":"/roadmaps/110-aws/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"aws","metaPath":"/roadmaps/110-aws/meta.json"},{"seo":{"title":"QA Roadmap: Learn to become a modern QA engineer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern QA development. Learn to become a modern QA engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a QA engineer","QA engineer","QA skills","QA development skills","QA development skills test","QA engineer roadmap","become a QA engineer","QA engineer career path","skills for QA development","what is QA engineer","QA engineer quiz","QA engineer interview questions"]},"title":"QA Engineer","description":"Steps to follow in order to become a modern QA Engineer in 2021","featuredTitle":"QA","featuredDescription":"Step by step guide to becoming a modern QA Engineer in 2021","isUpcoming":true,"featured":true,"contentPath":"/roadmaps/111-qa/landscape.md","resourcesPath":"/roadmaps/111-qa/resources.md","author":{"name":"Anas Fitiani","url":"https://github.com/anas-qa"},"id":"qa","metaPath":"/roadmaps/111-qa/meta.json"}],"guides":[{"id":"avoid-render-blocking-javascript-with-async-defer","title":"Async and Defer Script Loading","description":"Learn how to avoid render blocking JavaScript using async and defer scripts.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-09-10T19:59:14.191Z","createdAt":"2021-09-10T19:59:14.191Z","formattedCreatedAt":"September 10, 2021","formattedUpdatedAt":"September 10, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"what-are-web-vitals","title":"What are Web Vitals?","description":"Learn what are the core web vitals and how to measure them.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-09-05T19:59:14.191Z","createdAt":"2021-09-05T19:59:14.191Z","formattedCreatedAt":"September 5, 2021","formattedUpdatedAt":"September 5, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"what-is-sli-slo-sla","title":"SLIs, SLOs and SLAs","description":"Learn what are different indicators for performance identification of any service.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-08-31T19:59:14.191Z","createdAt":"2021-08-31T19:59:14.191Z","formattedCreatedAt":"August 31, 2021","formattedUpdatedAt":"August 31, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"ci-cd","title":"What is CI and CD?","description":"Learn the basics of CI/CD and how to implement that with GitHub Actions.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-07-09T19:59:14.191Z","createdAt":"2021-07-09T19:59:14.191Z","formattedCreatedAt":"July 9, 2021","formattedUpdatedAt":"July 9, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"sso","title":"SSO — Single Sign On","description":"Learn the basics of SAML and understand how does Single Sign On work.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-07-01T19:59:14.191Z","createdAt":"2021-07-01T19:59:14.191Z","formattedCreatedAt":"July 1, 2021","formattedUpdatedAt":"July 1, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"oauth","title":"OAuth — Open Authorization","description":"Learn and understand what is OAuth and how it works","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-06-28T19:59:14.191Z","createdAt":"2021-06-28T19:59:14.191Z","formattedCreatedAt":"June 28, 2021","formattedUpdatedAt":"June 28, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"jwt-authentication","title":"JWT Authentication","description":"Understand what is JWT authentication and how is it implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-06-20T19:59:14.191Z","createdAt":"2021-06-20T19:59:14.191Z","formattedCreatedAt":"June 20, 2021","formattedUpdatedAt":"June 20, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"token-authentication","title":"Token Based Authentication","description":"Understand what is token based authentication and how it is implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-06-02T20:59:14.191Z","createdAt":"2021-06-02T20:59:14.191Z","formattedCreatedAt":"June 2, 2021","formattedUpdatedAt":"June 2, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"session-authentication","title":"Session Based Authentication","description":"Understand what is session based authentication and how it is implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-26T20:59:14.191Z","createdAt":"2021-05-26T20:59:14.191Z","formattedCreatedAt":"May 26, 2021","formattedUpdatedAt":"May 26, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"basic-authentication","title":"Basic Authentication","description":"Understand what is basic authentication and how it is implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-19T20:59:14.191Z","createdAt":"2021-05-19T20:59:14.191Z","formattedCreatedAt":"May 19, 2021","formattedUpdatedAt":"May 19, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}],"videos":[{"id":"what-is-eventual-consistency","title":"What is Eventual Consistency?","description":"Learn about the different consistency models in distributed systems","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=rpqsSkTIdAw","authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2021-11-30T19:59:14.191Z","createdAt":"2021-11-30T19:59:14.191Z","formattedCreatedAt":"November 30, 2021","formattedUpdatedAt":"November 30, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"ssh-ssl-tls","title":"SSH vs TLS vs SSL","description":"Learn the difference between SSH, TLS and SSL","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=k3rFFLmQCuY","authorUsername":"kamranahmedse","duration":"3 minutes","updatedAt":"2021-11-25T19:59:14.191Z","createdAt":"2021-11-25T19:59:14.191Z","formattedCreatedAt":"November 25, 2021","formattedUpdatedAt":"November 25, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"async-javascript","title":"Asynchronous JavaScript","description":"Learn how to write asynchronous JavaScript using Async/Await","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=VyIK6SV5f7o","authorUsername":"kamranahmedse","duration":"15 minutes","updatedAt":"2021-11-14T19:59:14.191Z","createdAt":"2021-11-14T19:59:14.191Z","formattedCreatedAt":"November 14, 2021","formattedUpdatedAt":"November 14, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"random-number-generators","title":"Random Number Generators","description":"How do random number generators work?","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=nDv3yXdD0rk","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-11-03T19:59:14.191Z","createdAt":"2021-11-03T19:59:14.191Z","formattedCreatedAt":"November 3, 2021","formattedUpdatedAt":"November 3, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"big-o-notation","title":"Big O Notation","description":"Learn what the Big-O notation is and how to calculate the time complexity of an algorithm.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=Z0bH0cMY0E8","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-10-25T19:59:14.191Z","createdAt":"2021-10-25T19:59:14.191Z","formattedCreatedAt":"October 25, 2021","formattedUpdatedAt":"October 25, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"yaml-in-depth","title":"YAML in Depth","description":"Everything you need to know about YAML","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=ImHSpwUlNVc","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-10-18T19:59:14.191Z","createdAt":"2021-10-18T19:59:14.191Z","formattedCreatedAt":"October 18, 2021","formattedUpdatedAt":"October 18, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"floating-point-arithmetic","title":"Floating Point Arithmetic","description":"Learn how ow the arithmetic operations work on floating-point numbers and why the results might be different from what you may expect.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=RIiq4tTt6rI","authorUsername":"kamranahmedse","duration":"4 minutes","updatedAt":"2021-10-10T19:59:14.191Z","createdAt":"2021-10-10T19:59:14.191Z","formattedCreatedAt":"October 10, 2021","formattedUpdatedAt":"October 10, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"what-is-cap-theorem","title":"What is CAP Theorem?","description":"An illustrated explanation to CAP theorem with examples and proof.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=_RbsFXWRZ10","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-10-05T19:59:14.191Z","createdAt":"2021-10-05T19:59:14.191Z","formattedCreatedAt":"October 5, 2021","formattedUpdatedAt":"October 5, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"acid-explained","title":"ACID Explained","description":"Learn what it means for a database to be ACID compliant with examples.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=yaQ5YMWkxq4","authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2021-09-26T19:59:14.191Z","createdAt":"2021-09-26T19:59:14.191Z","formattedCreatedAt":"September 26, 2021","formattedUpdatedAt":"September 26, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"transport-protocols-tcp-vs-udp","title":"Transport Protocols: TCP vs UDP","description":"Learn about the Transport Layer of the TCP/IP model and different transport protocols.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=37AFBZv4_6Y","authorUsername":"kamranahmedse","duration":"10 minutes","updatedAt":"2020-11-21T19:59:14.191Z","createdAt":"2020-11-21T19:59:14.191Z","formattedCreatedAt":"November 21, 2020","formattedUpdatedAt":"November 21, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}]},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/java.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/java.json new file mode 100644 index 000000000..1e52c6dbd --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/java.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a modern Java developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a java developer","java developer","java engineer","java skills","guide to java","java roadmap","java skills","java skills test","skills for java","cloud development","what is java","java quiz","java interview questions","java engineer roadmap","java developer roadmap","become a java developer","java developer career path","java developer","modern java developer"]},"title":"Java Developer","description":"Step by step guide to becoming a Java developer in 2021","featuredTitle":"Java","featuredDescription":"Step by step guide to becoming a Java Developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"/roadmaps/108-java/landscape.md","resourcesPath":"/roadmaps/108-java/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/java-roadmap","id":"java","metaPath":"/roadmaps/108-java/meta.json"}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/java/interactive.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/java/interactive.json new file mode 100644 index 000000000..6cfe20fa4 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/java/interactive.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a modern Java developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a java developer","java developer","java engineer","java skills","guide to java","java roadmap","java skills","java skills test","skills for java","cloud development","what is java","java quiz","java interview questions","java engineer roadmap","java developer roadmap","become a java developer","java developer career path","java developer","modern java developer"]},"title":"Java Developer","description":"Step by step guide to becoming a Java developer in 2021","featuredTitle":"Java","featuredDescription":"Step by step guide to becoming a Java Developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"/roadmaps/108-java/landscape.md","resourcesPath":"/roadmaps/108-java/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/java-roadmap","id":"java","metaPath":"/roadmaps/108-java/meta.json"},"json":{"mockup":{"controls":{"control":[{"ID":"1","typeID":"Arrow","zOrder":"39","w":"13","h":"63","measuredW":"150","measuredH":"100","x":"457","y":"283","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":4,"y":0},"p1":{"x":0.48693312836279784,"y":0.16641045349730976},"p2":{"x":0,"y":63}}},{"ID":"3","typeID":"Arrow","zOrder":"40","w":"87","h":"177","measuredW":"150","measuredH":"100","x":"479","y":"467","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":0,"y":0},"p1":{"x":0.5656248906310154,"y":0.32313022783746903},"p2":{"x":49,"y":177}}},{"ID":"4","typeID":"Arrow","zOrder":"41","w":"98","h":"47","measuredW":"150","measuredH":"100","x":"601","y":"406","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":97.5,"y":-0.5},"p1":{"x":0.5537800308573949,"y":0.044853427374917355},"p2":{"x":0,"y":46}}},{"ID":"5","typeID":"Arrow","zOrder":"42","w":"120","h":"44","measuredW":"150","measuredH":"100","x":"597","y":"465","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":120,"y":44},"p1":{"x":0.5846756207563067,"y":-0.036972790801407494},"p2":{"x":0,"y":0}}},{"ID":"6","typeID":"Arrow","zOrder":"43","w":"107","h":"51","measuredW":"150","measuredH":"100","x":"276","y":"405","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":107,"y":51},"p1":{"x":0.5245584633234497,"y":0.05852778135877272},"p2":{"x":0,"y":0}}},{"ID":"7","typeID":"Arrow","zOrder":"44","w":"108","h":"44","measuredW":"150","measuredH":"100","x":"276","y":"462","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":108,"y":0},"p1":{"x":0.5656811947576956,"y":-0.05547089302042055},"p2":{"x":0,"y":44}}},{"ID":"8","typeID":"Arrow","zOrder":"45","w":"115","h":"5","measuredW":"150","measuredH":"100","x":"274","y":"457","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":115,"y":1},"p1":{"x":0.5205160087037612,"y":0.03901150139881877},"p2":{"x":0,"y":0}}},{"ID":"9","typeID":"Arrow","zOrder":"46","w":"123","h":"3","measuredW":"150","measuredH":"100","x":"577","y":"458","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":122.5,"y":-0.5},"p1":{"x":0.5536354056902003,"y":0.01338250790305583},"p2":{"x":0,"y":1}}},{"ID":"10","typeID":"Label","zOrder":"47","measuredW":"60","measuredH":"36","x":"415","y":"349","properties":{"size":"28","text":"Java"}},{"ID":"11","typeID":"Arrow","zOrder":"48","w":"24","h":"51","measuredW":"150","measuredH":"100","x":"427","y":"394","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":5,"y":0},"p1":{"x":0.4861538461538458,"y":-0.24923076923076912},"p2":{"x":24,"y":51}}},{"ID":"12","typeID":"Canvas","zOrder":"49","w":"262","h":"43","measuredW":"100","measuredH":"70","x":"354","y":"437","properties":{"color":"16776960"}},{"ID":"13","typeID":"Label","zOrder":"50","measuredW":"177","measuredH":"24","x":"396","y":"446","properties":{"size":"16","text":"Learn the Fundamentals"}},{"ID":"14","typeID":"__group__","zOrder":"51","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"69","y":"392","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"95","measuredW":"92","measuredH":"24","x":"64","y":"9","properties":{"size":"16","text":"Basic Syntax"}}]}}},{"ID":"15","typeID":"__group__","zOrder":"52","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"69","y":"438","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"150","measuredH":"24","x":"36","y":"9","properties":{"size":"16","text":"DataTypes, Variables"}}]}}},{"ID":"16","typeID":"Canvas","zOrder":"53","w":"280","h":"42","measuredW":"100","measuredH":"70","x":"688","y":"430","properties":{"color":"16770457"}},{"ID":"17","typeID":"Label","zOrder":"65","measuredW":"178","measuredH":"24","x":"739","y":"439","properties":{"size":"16","text":"OOP, Interfaces, Classes"}},{"ID":"18","typeID":"Canvas","zOrder":"54","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"484","properties":{"color":"16770457"}},{"ID":"19","typeID":"Label","zOrder":"55","measuredW":"90","measuredH":"24","x":"135","y":"493","properties":{"size":"16","text":"Conditionals"}},{"ID":"22","typeID":"Canvas","zOrder":"56","w":"280","h":"42","measuredW":"100","measuredH":"70","x":"688","y":"384","properties":{"color":"16770457"}},{"ID":"37","typeID":"Canvas","zOrder":"58","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"529","properties":{"color":"16770457"}},{"ID":"38","typeID":"Label","zOrder":"59","measuredW":"71","measuredH":"24","x":"144","y":"538","properties":{"size":"16","text":"Functions"}},{"ID":"39","typeID":"Canvas","zOrder":"60","w":"280","h":"42","measuredW":"100","measuredH":"70","x":"688","y":"476","properties":{"color":"16770457"}},{"ID":"41","typeID":"Canvas","zOrder":"61","w":"280","h":"42","measuredW":"100","measuredH":"70","x":"688","y":"522","properties":{"color":"16770457"}},{"ID":"42","typeID":"Label","zOrder":"62","measuredW":"199","measuredH":"24","x":"728","y":"531","properties":{"size":"16","text":"Working with Files and APIs"}},{"ID":"43","typeID":"Arrow","zOrder":"38","w":"100","h":"93","measuredW":"150","measuredH":"100","x":"274","y":"467","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":100,"y":-0.5},"p1":{"x":0.5656811947576956,"y":-0.055470893020420485},"p2":{"x":0,"y":92.5}}},{"ID":"44","typeID":"Canvas","zOrder":"63","w":"186","h":"42","measuredW":"100","measuredH":"70","x":"338","y":"511","properties":{"color":"16770457"}},{"ID":"45","typeID":"Label","zOrder":"64","measuredW":"45","measuredH":"24","x":"408","y":"520","properties":{"size":"16","text":"Loops"}},{"ID":"46","typeID":"Arrow","zOrder":"37","w":"1","h":"75","measuredW":"150","measuredH":"100","x":"430","y":"466","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":1,"y":-0.5},"p1":{"x":0.5467472449342339,"y":-0.006043370067543547},"p2":{"x":0,"y":74.5}}},{"ID":"47","typeID":"Label","zOrder":"66","measuredW":"71","measuredH":"24","x":"792","y":"485","properties":{"size":"16","text":"Packages"}},{"ID":"48","typeID":"Arrow","zOrder":"36","w":"103","h":"70","measuredW":"150","measuredH":"100","x":"599","y":"469","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":103,"y":69.5},"p1":{"x":0.5846756207563066,"y":-0.036972790801407494},"p2":{"x":0,"y":-0.5}}},{"ID":"51","typeID":"Label","zOrder":"67","measuredW":"109","measuredH":"24","x":"773","y":"393","properties":{"size":"16","text":"DataStructures"}},{"ID":"54","typeID":"Canvas","zOrder":"68","w":"284","h":"43","measuredW":"100","measuredH":"70","x":"383","y":"634","properties":{"color":"16776960"}},{"ID":"55","typeID":"Label","zOrder":"69","measuredW":"113","measuredH":"24","x":"468","y":"644","properties":{"size":"16","text":"Getting Deeper"}},{"ID":"56","typeID":"Canvas","zOrder":"70","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"739","y":"588","properties":{"color":"16770457"}},{"ID":"57","typeID":"Label","zOrder":"71","measuredW":"121","measuredH":"24","x":"789","y":"597","properties":{"size":"16","text":"How JVM works?"}},{"ID":"58","typeID":"Canvas","zOrder":"72","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"739","y":"634","properties":{"color":"16770457"}},{"ID":"59","typeID":"Label","zOrder":"73","measuredW":"141","measuredH":"24","x":"779","y":"643","properties":{"size":"16","text":"Garbage Collection"}},{"ID":"60","typeID":"Canvas","zOrder":"74","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"739","y":"680","properties":{"color":"16770457"}},{"ID":"61","typeID":"Label","zOrder":"75","measuredW":"130","measuredH":"24","x":"785","y":"689","properties":{"size":"16","text":"Basics of Threads"}},{"ID":"64","typeID":"Arrow","zOrder":"35","w":"115","h":"1","measuredW":"150","measuredH":"100","x":"643","y":"655","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":114.5,"y":0},"p1":{"x":0.5194288003393264,"y":0.0023328699012654486},"p2":{"x":-0.5,"y":1}}},{"ID":"65","typeID":"Arrow","zOrder":"34","w":"114","h":"48","measuredW":"150","measuredH":"100","x":"631","y":"608","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":114,"y":-0.5},"p1":{"x":0.42392803686203145,"y":0.09827429342881466},"p2":{"x":0,"y":47}}},{"ID":"66","typeID":"Arrow","zOrder":"33","w":"105","h":"40","measuredW":"150","measuredH":"100","x":"642","y":"659","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":104,"y":39.5},"p1":{"x":0.4372442019099593,"y":-0.09720327421555257},"p2":{"x":-0.5,"y":-0.5}}},{"ID":"69","typeID":"Canvas","zOrder":"76","w":"186","h":"42","measuredW":"100","measuredH":"70","x":"338","y":"557","properties":{"color":"16770457"}},{"ID":"70","typeID":"Label","zOrder":"77","measuredW":"141","measuredH":"24","x":"360","y":"566","properties":{"size":"16","text":"Exception Handling"}},{"ID":"71","typeID":"Canvas","zOrder":"78","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"585","properties":{"color":"16770457"}},{"ID":"72","typeID":"Label","zOrder":"79","measuredW":"159","measuredH":"24","x":"100","y":"594","properties":{"size":"16","text":"Memory Management"}},{"ID":"73","typeID":"Canvas","zOrder":"80","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"630","properties":{"color":"16770457"}},{"ID":"74","typeID":"Label","zOrder":"81","measuredW":"157","measuredH":"24","x":"101","y":"639","properties":{"size":"16","text":"Collection Framework"}},{"ID":"77","typeID":"Canvas","zOrder":"82","w":"117","h":"42","measuredW":"100","measuredH":"70","x":"583","y":"575","properties":{"color":"16770457"}},{"ID":"78","typeID":"Label","zOrder":"83","measuredW":"66","measuredH":"24","x":"609","y":"584","properties":{"size":"16","text":"Generics"}},{"ID":"79","typeID":"Canvas","zOrder":"84","w":"117","h":"42","measuredW":"100","measuredH":"70","x":"583","y":"695","properties":{"color":"16770457"}},{"ID":"80","typeID":"Label","zOrder":"85","measuredW":"60","measuredH":"24","x":"612","y":"704","properties":{"size":"16","text":"Streams"}},{"ID":"81","typeID":"Arrow","zOrder":"32","w":"1","h":"126","measuredW":"150","measuredH":"100","x":"638","y":"591","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":1,"y":-0.5},"p1":{"x":0.546747244934234,"y":-0.006043370067543548},"p2":{"x":1,"y":125.5}}},{"ID":"82","typeID":"Canvas","zOrder":"86","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"675","properties":{"color":"16770457"}},{"ID":"83","typeID":"Label","zOrder":"87","measuredW":"89","measuredH":"24","x":"135","y":"684","properties":{"size":"16","text":"Serialization"}},{"ID":"84","typeID":"Canvas","zOrder":"88","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"720","properties":{"color":"16770457"}},{"ID":"85","typeID":"Label","zOrder":"89","measuredW":"158","measuredH":"24","x":"101","y":"729","properties":{"size":"16","text":"Networking & Sockets"}},{"ID":"86","typeID":"Arrow","zOrder":"31","w":"139","h":"1","measuredW":"150","measuredH":"100","x":"261","y":"653","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":139,"y":0.5},"p1":{"x":0.5194288003393264,"y":0.00233286990126545},"p2":{"x":0,"y":-0.5}}},{"ID":"87","typeID":"Arrow","zOrder":"30","w":"120","h":"39","measuredW":"150","measuredH":"100","x":"277","y":"660","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":120,"y":-0.5},"p1":{"x":0.5543621631807046,"y":-0.06350103636706236},"p2":{"x":0,"y":38.5}}},{"ID":"88","typeID":"Arrow","zOrder":"29","w":"118","h":"83","measuredW":"150","measuredH":"100","x":"277","y":"664","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":118,"y":-0.5},"p1":{"x":0.5576080853453116,"y":-0.077653003930376},"p2":{"x":0,"y":82.5}}},{"ID":"90","typeID":"Arrow","zOrder":"28","w":"114","h":"41","measuredW":"150","measuredH":"100","x":"279","y":"604","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":114,"y":40.5},"p1":{"x":0.5332865705904859,"y":0.09074097691620968},"p2":{"x":0,"y":-0.5}}},{"ID":"91","typeID":"Arrow","zOrder":"27","w":"181","h":"131","measuredW":"150","measuredH":"100","x":"331","y":"661","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":181,"y":-0.5},"p1":{"x":0.47484417739114826,"y":0.025178243128110726},"p2":{"x":0,"y":130.5}}},{"ID":"94","typeID":"Canvas","zOrder":"90","w":"169","h":"43","measuredW":"100","measuredH":"70","x":"239","y":"774","properties":{"color":"16776960"}},{"ID":"95","typeID":"Label","zOrder":"91","measuredW":"78","measuredH":"24","x":"285","y":"784","properties":{"size":"16","text":"Build Tools"}},{"ID":"96","typeID":"Canvas","zOrder":"92","w":"116","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"773","properties":{"color":"16770457"}},{"ID":"97","typeID":"Label","zOrder":"93","measuredW":"49","measuredH":"24","x":"102","y":"782","properties":{"size":"16","text":"Gradle"}},{"ID":"98","typeID":"Canvas","zOrder":"94","w":"116","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"819","properties":{"color":"16770457"}},{"ID":"99","typeID":"Label","zOrder":"95","measuredW":"49","measuredH":"24","x":"102","y":"828","properties":{"size":"16","text":"Maven"}},{"ID":"100","typeID":"Canvas","zOrder":"96","w":"116","h":"42","measuredW":"100","measuredH":"70","x":"71","y":"866","properties":{"color":"16770457"}},{"ID":"101","typeID":"Label","zOrder":"97","measuredW":"24","measuredH":"24","x":"117","y":"875","properties":{"size":"16","text":"Ant"}},{"ID":"102","typeID":"Arrow","zOrder":"26","w":"92","h":"4","measuredW":"150","measuredH":"100","x":"165","y":"789","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":92,"y":0},"p1":{"x":0.5115764636484295,"y":0.01858133018728801},"p2":{"x":0,"y":3.5}}},{"ID":"103","typeID":"Arrow","zOrder":"25","w":"78","h":"47","measuredW":"150","measuredH":"100","x":"172","y":"798","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":77,"y":0},"p1":{"x":0.5286705624543463,"y":-0.1044558071585099},"p2":{"x":-0.5,"y":46.5}}},{"ID":"104","typeID":"Arrow","zOrder":"24","w":"72","h":"83","measuredW":"150","measuredH":"100","x":"177","y":"805","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":71,"y":0},"p1":{"x":0.49238578680203043,"y":-0.1065989847715736},"p2":{"x":-0.5,"y":82.5}}},{"ID":"105","typeID":"Canvas","zOrder":"98","w":"218","h":"43","measuredW":"100","measuredH":"70","x":"470","y":"772","properties":{"color":"16776960"}},{"ID":"106","typeID":"Label","zOrder":"99","measuredW":"125","measuredH":"24","x":"516","y":"782","properties":{"size":"16","text":"Web Frameworks"}},{"ID":"107","typeID":"Arrow","zOrder":"23","w":"142","h":"1","measuredW":"150","measuredH":"100","x":"373","y":"794","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":142,"y":0.5},"p1":{"x":0.4577237788246963,"y":-0.003223406893131664},"p2":{"x":0,"y":1.5}}},{"ID":"108","typeID":"Canvas","zOrder":"100","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"740","y":"733","properties":{"color":"16770457"}},{"ID":"109","typeID":"Label","zOrder":"101","measuredW":"47","measuredH":"24","x":"827","y":"742","properties":{"size":"16","text":"Spring"}},{"ID":"110","typeID":"Canvas","zOrder":"102","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"740","y":"779","properties":{"color":"16770457"}},{"ID":"111","typeID":"Label","zOrder":"103","measuredW":"85","measuredH":"24","x":"808","y":"788","properties":{"size":"16","text":"Spring Boot"}},{"ID":"114","typeID":"Canvas","zOrder":"104","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"740","y":"825","properties":{"color":"16770457"}},{"ID":"115","typeID":"Label","zOrder":"105","measuredW":"114","measuredH":"24","x":"794","y":"834","properties":{"size":"16","text":"Play Framework"}},{"ID":"116","typeID":"Canvas","zOrder":"106","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"740","y":"872","properties":{"color":"16770457"}},{"ID":"117","typeID":"Label","zOrder":"107","measuredW":"42","measuredH":"24","x":"830","y":"881","properties":{"size":"16","text":"Spark"}},{"ID":"118","typeID":"Arrow","zOrder":"22","w":"75","h":"34","measuredW":"150","measuredH":"100","x":"674","y":"750","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":75,"y":-0.5},"p1":{"x":0.5901794145420208,"y":0.12086874409820589},"p2":{"x":0,"y":32.5}}},{"ID":"119","typeID":"Arrow","zOrder":"21","w":"87","h":"8","measuredW":"150","measuredH":"100","x":"665","y":"792","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":87,"y":7.5},"p1":{"x":0.46115550897419105,"y":-0.015066160094327265},"p2":{"x":0,"y":-0.5}}},{"ID":"120","typeID":"Arrow","zOrder":"20","w":"71","h":"52","measuredW":"150","measuredH":"100","x":"677","y":"795","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":71,"y":51.5},"p1":{"x":0.5176834659593281,"y":-0.07117595048629538},"p2":{"x":0,"y":-0.5}}},{"ID":"121","typeID":"Arrow","zOrder":"19","w":"69","h":"90","measuredW":"150","measuredH":"100","x":"674","y":"796","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":69,"y":89.5},"p1":{"x":0.517683465959328,"y":-0.07117595048629538},"p2":{"x":0,"y":-0.5}}},{"ID":"122","typeID":"Arrow","zOrder":"18","w":"169","h":"138","measuredW":"150","measuredH":"100","x":"389","y":"807","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":0,"y":137.5},"p1":{"x":0.5796146044624716,"y":-0.25050709939147836},"p2":{"x":168,"y":-0.5}}},{"ID":"123","typeID":"Canvas","zOrder":"108","w":"129","h":"43","measuredW":"100","measuredH":"70","x":"279","y":"922","properties":{"color":"16776960"}},{"ID":"124","typeID":"Label","zOrder":"109","measuredW":"38","measuredH":"24","x":"325","y":"932","properties":{"size":"16","text":"ORM"}},{"ID":"125","typeID":"Canvas","zOrder":"110","w":"92","h":"42","measuredW":"100","measuredH":"70","x":"278","y":"855","properties":{"color":"16770457"}},{"ID":"126","typeID":"Label","zOrder":"111","measuredW":"28","measuredH":"24","x":"310","y":"864","properties":{"size":"16","text":"JPA"}},{"ID":"127","typeID":"Canvas","zOrder":"112","w":"169","h":"42","measuredW":"100","measuredH":"70","x":"74","y":"967","properties":{"color":"16770457"}},{"ID":"128","typeID":"Label","zOrder":"113","measuredW":"73","measuredH":"24","x":"122","y":"976","properties":{"size":"16","text":"Hibernate"}},{"ID":"129","typeID":"Arrow","zOrder":"17","w":"1","h":"62","measuredW":"150","measuredH":"100","x":"322","y":"876","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":-0.5},"p1":{"x":0.5467472449342341,"y":-0.006043370067543647},"p2":{"x":0,"y":61.5}}},{"ID":"131","typeID":"Canvas","zOrder":"114","w":"169","h":"42","measuredW":"100","measuredH":"70","x":"74","y":"921","properties":{"color":"16770457"}},{"ID":"132","typeID":"Label","zOrder":"115","measuredW":"117","measuredH":"24","x":"100","y":"930","properties":{"size":"16","text":"Spring Data JPA"}},{"ID":"133","typeID":"Arrow","zOrder":"16","w":"74","h":"3","measuredW":"150","measuredH":"100","x":"219","y":"940","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":2.5},"p1":{"x":0.5467472449342342,"y":-0.006043370067543645},"p2":{"x":74,"y":0}}},{"ID":"134","typeID":"Arrow","zOrder":"15","w":"72","h":"45","measuredW":"150","measuredH":"100","x":"225","y":"951","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":45},"p1":{"x":0.5642946317103621,"y":0.14731585518102372},"p2":{"x":72,"y":0}}},{"ID":"135","typeID":"Canvas","zOrder":"116","w":"169","h":"42","measuredW":"100","measuredH":"70","x":"74","y":"1013","properties":{"color":"16770457"}},{"ID":"136","typeID":"Label","zOrder":"117","measuredW":"50","measuredH":"24","x":"134","y":"1022","properties":{"size":"16","text":"EBean"}},{"ID":"137","typeID":"Arrow","zOrder":"14","w":"71","h":"91","measuredW":"150","measuredH":"100","x":"235","y":"949","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":91},"p1":{"x":0.6008857528899565,"y":0.11717459840864736},"p2":{"x":71,"y":0}}},{"ID":"138","typeID":"Canvas","zOrder":"118","w":"239","h":"43","measuredW":"100","measuredH":"70","x":"501","y":"967","properties":{"color":"16776960"}},{"ID":"139","typeID":"Label","zOrder":"119","measuredW":"151","measuredH":"24","x":"545","y":"977","properties":{"size":"16","text":"Logging Frameworks"}},{"ID":"140","typeID":"Arrow","zOrder":"13","h":"34","measuredW":"150","measuredH":"100","x":"360","y":"956","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":149.5,"y":32.5},"p1":{"x":0.6803934308695361,"y":0.12103152376044628},"p2":{"x":0,"y":-0.5}}},{"ID":"141","typeID":"Arrow","zOrder":"10","w":"1","h":"62","measuredW":"150","measuredH":"100","x":"627","y":"921","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":-0.5},"p1":{"x":0.5467472449342341,"y":-0.006043370067543647},"p2":{"x":0,"y":61.5}}},{"ID":"142","typeID":"Canvas","zOrder":"11","w":"116","h":"42","measuredW":"100","measuredH":"70","x":"570","y":"907","properties":{"color":"16770457"}},{"ID":"143","typeID":"Label","zOrder":"12","measuredW":"51","measuredH":"24","x":"602","y":"916","properties":{"size":"16","text":"Log4j2"}},{"ID":"144","typeID":"Canvas","zOrder":"120","w":"116","h":"42","measuredW":"100","measuredH":"70","x":"571","y":"861","properties":{"color":"16770457"}},{"ID":"145","typeID":"Label","zOrder":"121","measuredW":"62","measuredH":"24","x":"598","y":"870","properties":{"size":"16","text":"Logback"}},{"ID":"146","typeID":"Canvas","zOrder":"122","w":"168","h":"42","measuredW":"100","measuredH":"70","x":"794","y":"968","properties":{"color":"16770457"}},{"ID":"147","typeID":"Label","zOrder":"123","measuredW":"57","measuredH":"24","x":"849","y":"977","properties":{"size":"16","text":"TinyLog"}},{"ID":"148","typeID":"Arrow","zOrder":"9","w":"105","h":"1","measuredW":"150","measuredH":"100","x":"725","y":"988","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":105,"y":0.5},"p1":{"x":0.5467472449342341,"y":-0.006043370067543645},"p2":{"x":0,"y":0.5}}},{"ID":"149","typeID":"Canvas","zOrder":"124","w":"129","h":"43","measuredW":"100","measuredH":"70","x":"279","y":"1013","properties":{"color":"16776960"}},{"ID":"150","typeID":"Label","zOrder":"125","measuredW":"43","measuredH":"24","x":"322","y":"1023","properties":{"size":"16","text":"JDBC"}},{"ID":"151","typeID":"Arrow","zOrder":"8","w":"16","h":"89","measuredW":"150","measuredH":"100","x":"326","y":"953","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":16,"y":88.5},"p1":{"x":0.49438202247191015,"y":0.1460674157303371},"p2":{"x":11,"y":-0.5}}},{"ID":"152","typeID":"Canvas","zOrder":"126","w":"169","h":"42","measuredW":"100","measuredH":"70","x":"74","y":"1073","properties":{"color":"16770457"}},{"ID":"153","typeID":"Label","zOrder":"127","measuredW":"47","measuredH":"24","x":"135","y":"1082","properties":{"size":"16","text":"JDBI3"}},{"ID":"154","typeID":"Canvas","zOrder":"128","w":"169","h":"42","measuredW":"100","measuredH":"70","x":"74","y":"1119","properties":{"color":"16770457"}},{"ID":"155","typeID":"Label","zOrder":"129","measuredW":"114","measuredH":"24","x":"102","y":"1128","properties":{"size":"16","text":"JDBC Template"}},{"ID":"156","typeID":"Arrow","zOrder":"7","w":"89","h":"57","measuredW":"150","measuredH":"100","x":"224","y":"1036","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":89,"y":-0.5},"p1":{"x":0.4221511395441838,"y":0.24854058376649316},"p2":{"x":0,"y":56}}},{"ID":"157","typeID":"Arrow","zOrder":"6","w":"102","h":"97","measuredW":"150","measuredH":"100","x":"224","y":"1039","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":102,"y":0},"p1":{"x":0.555359394703657,"y":0.21664564943253461},"p2":{"x":0,"y":97}}},{"ID":"158","typeID":"Arrow","zOrder":"5","w":"190","h":"101","measuredW":"150","measuredH":"100","x":"339","y":"1040","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":189.60923090179483,"y":100.34652634056556},"p1":{"x":0.49438202247191004,"y":0.14606741573033685},"p2":{"x":-0.5,"y":0}}},{"ID":"159","typeID":"Canvas","zOrder":"130","w":"201","h":"43","measuredW":"100","measuredH":"70","x":"501","y":"1117","properties":{"color":"16776960"}},{"ID":"160","typeID":"Label","zOrder":"131","measuredW":"128","measuredH":"24","x":"538","y":"1126","properties":{"size":"16","text":"Testing your Apps"}},{"ID":"175","typeID":"__group__","zOrder":"132","measuredW":"177","measuredH":"42","w":"177","h":"42","x":"525","y":"1052","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"177","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"62","measuredH":"24","x":"18","y":"9","properties":{"size":"16","text":"Mocking"}},{"ID":"2","typeID":"Label","zOrder":"2","measuredW":"57","measuredH":"24","x":"102","y":"9","properties":{"size":"16","text":"Mockito"}},{"ID":"3","typeID":"Label","zOrder":"3","measuredW":"10","measuredH":"21","x":"85","y":"10","properties":{"text":">","bold":"true"}}]}}},{"ID":"202","typeID":"Arrow","zOrder":"4","w":"101","h":"1","measuredW":"150","measuredH":"100","x":"681","y":"1138","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":100.54590590319128,"y":0.21503750628403395},"p1":{"x":0.5467472449342339,"y":-0.006043370067543644},"p2":{"x":-0.34456558612976096,"y":0.21503750628403395}}},{"ID":"214","typeID":"__group__","zOrder":"133","measuredW":"192","measuredH":"133","w":"192","h":"133","x":"758","y":"1052","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"192","h":"133","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"121","measuredH":"24","x":"29","y":"8","properties":{"size":"16","text":"Behavior Testing"}},{"ID":"2","typeID":"Canvas","zOrder":"2","w":"172","h":"42","measuredW":"100","measuredH":"70","x":"10","y":"37"},{"ID":"3","typeID":"Label","zOrder":"3","measuredW":"114","measuredH":"24","x":"39","y":"46","properties":{"size":"16","text":"Cucumber-JVM"}},{"ID":"4","typeID":"Canvas","zOrder":"4","w":"76","h":"42","measuredW":"100","measuredH":"70","x":"10","y":"83"},{"ID":"5","typeID":"Label","zOrder":"5","measuredW":"46","measuredH":"24","x":"25","y":"92","properties":{"size":"16","text":"Cukes"}},{"ID":"6","typeID":"Canvas","zOrder":"6","w":"91","h":"42","measuredW":"100","measuredH":"70","x":"91","y":"83"},{"ID":"7","typeID":"Label","zOrder":"7","measuredW":"64","measuredH":"24","x":"105","y":"92","properties":{"size":"16","text":"JBehave"}}]}}},{"ID":"215","typeID":"__group__","zOrder":"134","measuredW":"168","measuredH":"133","w":"168","h":"133","x":"239","y":"1188","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"168","h":"133","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"135","measuredH":"24","x":"16","y":"9","properties":{"size":"16","text":"Integration Testing"}},{"ID":"2","typeID":"Canvas","zOrder":"2","w":"148","h":"42","measuredW":"100","measuredH":"70","x":"10","y":"37"},{"ID":"3","typeID":"Label","zOrder":"3","measuredW":"104","measuredH":"24","x":"39","y":"46","properties":{"size":"16","text":"REST Assured"}},{"ID":"4","typeID":"Canvas","zOrder":"4","w":"148","h":"42","measuredW":"100","measuredH":"70","x":"10","y":"83"},{"ID":"5","typeID":"Label","zOrder":"5","measuredW":"52","measuredH":"24","x":"58","y":"92","properties":{"size":"16","text":"JMeter"}}]}}},{"ID":"216","typeID":"__group__","zOrder":"135","measuredW":"154","measuredH":"133","w":"154","h":"133","x":"89","y":"1188","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"154","h":"133","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"86","measuredH":"24","x":"34","y":"8","properties":{"size":"16","text":"Unit Testing"}},{"ID":"2","typeID":"Canvas","zOrder":"2","w":"125","h":"42","measuredW":"100","measuredH":"70","x":"14","y":"36"},{"ID":"3","typeID":"Label","zOrder":"3","measuredW":"39","measuredH":"24","x":"57","y":"45","properties":{"size":"16","text":"JUnit"}},{"ID":"6","typeID":"Canvas","zOrder":"4","w":"125","h":"42","measuredW":"100","measuredH":"70","x":"14","y":"82"},{"ID":"7","typeID":"Label","zOrder":"5","measuredW":"55","measuredH":"24","x":"49","y":"91","properties":{"size":"16","text":"TestNG"}}]}}},{"ID":"219","typeID":"__group__","zOrder":"136","measuredW":"468","measuredH":"153","w":"468","h":"153","x":"500","y":"1263","children":{"controls":{"control":[{"ID":"0","typeID":"Arrow","zOrder":"0","w":"1","h":"98","measuredW":"150","measuredH":"100","x":"233","y":"55","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":-0.5,"y":-0.5},"p1":{"x":0.5259259259259262,"y":0},"p2":{"x":-0.5,"y":97},"stroke":"dotted"}},{"ID":"1","typeID":"__group__","zOrder":"1","measuredW":"468","measuredH":"84","w":"468","h":"84","x":"0","y":"0","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"468","h":"84","measuredW":"100","measuredH":"70","x":"0","y":"0"},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"407","measuredH":"28","x":"30","y":"16","properties":{"size":"20","text":"Backend Roadmap after Language Selection"}},{"ID":"2","typeID":"Label","zOrder":"2","measuredW":"153","measuredH":"24","x":"157","y":"44","properties":{"size":"16","text":"roadmap.sh/backend","color":"10027263"}}]}}}]}}},{"ID":"226","typeID":"Arrow","zOrder":"3","w":"1","h":"62","measuredW":"150","measuredH":"100","x":"607","y":"1071","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":-0.5},"p1":{"x":0.5467472449342341,"y":-0.006043370067543647},"p2":{"x":0,"y":61.5}}},{"ID":"227","typeID":"Arrow","zOrder":"2","w":"1","h":"153","measuredW":"150","measuredH":"100","x":"604","y":"1138","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":1,"y":-0.5},"p1":{"x":0.5467472449342342,"y":-0.006043370067543646},"p2":{"x":1,"y":152.12975218407814}}},{"ID":"228","typeID":"Arrow","zOrder":"1","w":"164","h":"80","measuredW":"150","measuredH":"100","x":"360","y":"1150","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":163.54590590319128,"y":0.21503750628403395},"p1":{"x":0.3415936949541605,"y":0.2360486189239869},"p2":{"x":-0.4888832845319939,"y":78.4480648241979}}},{"ID":"232","typeID":"__group__","zOrder":"57","measuredW":"350","measuredH":"141","w":"350","h":"141","x":"616","y":"171","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"350","h":"141","measuredW":"100","measuredH":"70","x":"0","y":"0"},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"314","measuredH":"25","x":"14","y":"17","properties":{"size":"17","text":"Find the detailed version of this roadmap"}},{"ID":"2","typeID":"Label","zOrder":"2","measuredW":"319","measuredH":"25","x":"14","y":"45","properties":{"size":"17","text":"along with resources and other roadmaps"}},{"ID":"3","typeID":"Canvas","zOrder":"3","w":"320","h":"45","measuredW":"100","measuredH":"70","x":"15","y":"81","properties":{"borderColor":"4273622","color":"4273622"}},{"ID":"4","typeID":"Label","zOrder":"4","measuredW":"105","measuredH":"28","x":"156","y":"89","properties":{"color":"16777215","size":"20","text":"roadmap.sh"}},{"ID":"5","typeID":"Label","zOrder":"5","measuredW":"35","measuredH":"28","x":"91","y":"89","properties":{"color":"16777215","size":"20","text":"http"}},{"ID":"6","typeID":"Label","zOrder":"6","measuredW":"5","measuredH":"28","x":"128","y":"89","properties":{"color":"16777215","size":"20","text":":"}},{"ID":"7","typeID":"Label","zOrder":"7","measuredW":"10","measuredH":"28","x":"135","y":"90","properties":{"color":"16777215","size":"20","text":"/"}},{"ID":"8","typeID":"Label","zOrder":"8","measuredW":"10","measuredH":"28","x":"143","y":"90","properties":{"color":"16777215","size":"20","text":"/"}}]}}},{"ID":"233","typeID":"__group__","zOrder":"137","measuredW":"454","measuredH":"90","w":"454","h":"90","x":"125","y":"203","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"454","h":"90","measuredW":"100","measuredH":"70","x":"0","y":"0"},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"384","measuredH":"28","x":"35","y":"19","properties":{"size":"20","text":"Backend Roadmap till Language Selection"}},{"ID":"2","typeID":"Label","zOrder":"2","measuredW":"153","measuredH":"24","x":"150","y":"48","properties":{"size":"16","text":"roadmap.sh/backend","color":"10027263"}}]}}},{"ID":"234","typeID":"Arrow","zOrder":"0","w":"29","h":"56","measuredW":"150","measuredH":"100","x":"386","y":"155","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":1,"y":0},"p1":{"x":0.5189460476787955,"y":-0.17340025094102887},"p2":{"x":29,"y":56},"stroke":"dotted"}}]},"attributes":{"name":"New Wireframe 5 copy","order":1000048.9377613901,"parentID":null,"notes":null},"branchID":"Master","resourceID":"3171FA3F-E344-493D-8EA8-E957C760DC45","mockupH":"1261","mockupW":"899","measuredW":"968","measuredH":"1416","version":"1.0"}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/java/resources.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/java/resources.json new file mode 100644 index 000000000..1e52c6dbd --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/java/resources.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a modern Java developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a java developer","java developer","java engineer","java skills","guide to java","java roadmap","java skills","java skills test","skills for java","cloud development","what is java","java quiz","java interview questions","java engineer roadmap","java developer roadmap","become a java developer","java developer career path","java developer","modern java developer"]},"title":"Java Developer","description":"Step by step guide to becoming a Java developer in 2021","featuredTitle":"Java","featuredDescription":"Step by step guide to becoming a Java Developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"/roadmaps/108-java/landscape.md","resourcesPath":"/roadmaps/108-java/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/java-roadmap","id":"java","metaPath":"/roadmaps/108-java/meta.json"}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/postgresql-dba.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/postgresql-dba.json new file mode 100644 index 000000000..c7e2321ad --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/postgresql-dba.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"DBA Roadmap: Learn to become a database administrator with PostgreSQL","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a database administrator","guide to becoming a DBA","dba roadmap","db administrator roadmap","database administrator roadmap","postgresql roadmap","dba skills","db administrator skills","become dba","postgresql skills","modern dba skills","dba skills test","skills for dba","skills for database administrator","learn dba","what is dba","database administrator quiz","dba interview questions"]},"title":"PostgreSQL DBA","description":"Step by step guide to becoming a modern PostgreSQL DB Administrator in 2021","featuredTitle":"DBA","featuredDescription":"Step by step guide to become a PostgreSQL DBA in 2021","contentPath":"/roadmaps/109-postgresql-dba/landscape.md","resourcesPath":"/roadmaps/109-postgresql-dba/resources.md","author":{"name":"Alexey Lesovsky","url":"https://github.com/lesovsky"},"isCommunity":false,"isTextHeavy":true,"featured":true,"detailed":false,"versions":[],"id":"postgresql-dba","metaPath":"/roadmaps/109-postgresql-dba/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/postgresql-dba/interactive.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/postgresql-dba/interactive.json new file mode 100644 index 000000000..68c60038e --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/postgresql-dba/interactive.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"DBA Roadmap: Learn to become a database administrator with PostgreSQL","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a database administrator","guide to becoming a DBA","dba roadmap","db administrator roadmap","database administrator roadmap","postgresql roadmap","dba skills","db administrator skills","become dba","postgresql skills","modern dba skills","dba skills test","skills for dba","skills for database administrator","learn dba","what is dba","database administrator quiz","dba interview questions"]},"title":"PostgreSQL DBA","description":"Step by step guide to becoming a modern PostgreSQL DB Administrator in 2021","featuredTitle":"DBA","featuredDescription":"Step by step guide to become a PostgreSQL DBA in 2021","contentPath":"/roadmaps/109-postgresql-dba/landscape.md","resourcesPath":"/roadmaps/109-postgresql-dba/resources.md","author":{"name":"Alexey Lesovsky","url":"https://github.com/lesovsky"},"isCommunity":false,"isTextHeavy":true,"featured":true,"detailed":false,"versions":[],"id":"postgresql-dba","metaPath":"/roadmaps/109-postgresql-dba/meta.json","isUpcoming":false},"json":{}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/postgresql-dba/resources.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/postgresql-dba/resources.json new file mode 100644 index 000000000..c7e2321ad --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/postgresql-dba/resources.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"DBA Roadmap: Learn to become a database administrator with PostgreSQL","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a database administrator","guide to becoming a DBA","dba roadmap","db administrator roadmap","database administrator roadmap","postgresql roadmap","dba skills","db administrator skills","become dba","postgresql skills","modern dba skills","dba skills test","skills for dba","skills for database administrator","learn dba","what is dba","database administrator quiz","dba interview questions"]},"title":"PostgreSQL DBA","description":"Step by step guide to becoming a modern PostgreSQL DB Administrator in 2021","featuredTitle":"DBA","featuredDescription":"Step by step guide to become a PostgreSQL DBA in 2021","contentPath":"/roadmaps/109-postgresql-dba/landscape.md","resourcesPath":"/roadmaps/109-postgresql-dba/resources.md","author":{"name":"Alexey Lesovsky","url":"https://github.com/lesovsky"},"isCommunity":false,"isTextHeavy":true,"featured":true,"detailed":false,"versions":[],"id":"postgresql-dba","metaPath":"/roadmaps/109-postgresql-dba/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/python.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/python.json new file mode 100644 index 000000000..0100e373c --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/python.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a modern Python developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for python development. Learn to become a modern Python developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an python developer","python developer roadmap","python roadmap","become python developer","python developer skills","python skills test","skills for python development","learn python development","what is python","python quiz","python interview questions"]},"title":"Python Developer","description":"Step by step guide to becoming a Python developer in 2021","featuredTitle":"Python","featuredDescription":"Step by step guide to becoming a Python Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"resourcesPath":"/roadmaps/106-python/resources.md","contentPath":"/roadmaps/106-python/landscape.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/python-roadmap","versions":["latest"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"python","metaPath":"/roadmaps/106-python/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/python/interactive.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/python/interactive.json new file mode 100644 index 000000000..ea2d3916c --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/python/interactive.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a modern Python developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for python development. Learn to become a modern Python developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an python developer","python developer roadmap","python roadmap","become python developer","python developer skills","python skills test","skills for python development","learn python development","what is python","python quiz","python interview questions"]},"title":"Python Developer","description":"Step by step guide to becoming a Python developer in 2021","featuredTitle":"Python","featuredDescription":"Step by step guide to becoming a Python Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"resourcesPath":"/roadmaps/106-python/resources.md","contentPath":"/roadmaps/106-python/landscape.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/python-roadmap","versions":["latest"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"python","metaPath":"/roadmaps/106-python/meta.json","isUpcoming":false},"json":{"mockup":{"controls":{"control":[{"ID":"3","typeID":"Arrow","zOrder":"43","w":"115","h":"5","measuredW":"150","measuredH":"100","x":"274","y":"457","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":115,"y":1},"p1":{"x":0.5205160087037612,"y":0.03901150139881877},"p2":{"x":0,"y":0}}},{"ID":"5","typeID":"Arrow","zOrder":"44","w":"143","h":"3","measuredW":"150","measuredH":"100","x":"577","y":"457","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":143,"y":0},"p1":{"x":0.5536354056902003,"y":0.01338250790305583},"p2":{"x":0,"y":2}}},{"ID":"6","typeID":"Arrow","zOrder":"1","w":"16","h":"68","measuredW":"150","measuredH":"100","x":"474","y":"242","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4869331283627979,"y":0.16641045349730976},"p2":{"x":8,"y":68},"color":"10027263"}},{"ID":"7","typeID":"Label","zOrder":"45","measuredW":"87","measuredH":"36","x":"421","y":"318","properties":{"text":"Python","size":"28"}},{"ID":"8","typeID":"Arrow","zOrder":"46","w":"20","h":"81","measuredW":"150","measuredH":"100","x":"431","y":"364","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":20,"y":0},"p1":{"x":0.486153846153846,"y":-0.2492307692307692},"p2":{"x":20,"y":81}}},{"ID":"9","typeID":"Canvas","zOrder":"47","w":"262","h":"43","measuredW":"100","measuredH":"70","x":"354","y":"437","properties":{"color":"16776960"}},{"ID":"10","typeID":"Label","zOrder":"48","measuredW":"123","measuredH":"24","x":"423","y":"447","properties":{"size":"16","text":"Learn the Basics"}},{"ID":"24","typeID":"Arrow","zOrder":"42","w":"108","h":"44","measuredW":"150","measuredH":"100","x":"276","y":"462","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":108,"y":0},"p1":{"x":0.5656811947576956,"y":-0.05547089302042055},"p2":{"x":0,"y":44}}},{"ID":"26","typeID":"Arrow","zOrder":"41","w":"107","h":"51","measuredW":"150","measuredH":"100","x":"276","y":"405","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":107,"y":51},"p1":{"x":0.5245584633234497,"y":0.05852778135877272},"p2":{"x":0,"y":0}}},{"ID":"29","typeID":"__group__","zOrder":"50","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"69","y":"438","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"188","measuredW":"183","measuredH":"24","x":"16","y":"9","properties":{"size":"16","text":"Variables and Data Types"}}]}}},{"ID":"30","typeID":"__group__","zOrder":"49","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"69","y":"392","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","w":"95","measuredW":"92","measuredH":"24","x":"64","y":"9","properties":{"size":"16","text":"Basic Syntax"}}]}}},{"ID":"32","typeID":"Canvas","zOrder":"53","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"484","properties":{"color":"16770457"}},{"ID":"33","typeID":"Label","zOrder":"54","w":"92","measuredW":"90","measuredH":"24","x":"123","y":"493","properties":{"size":"16","text":"Conditionals"}},{"ID":"35","typeID":"Canvas","zOrder":"57","w":"256","h":"42","measuredW":"100","measuredH":"70","x":"688","y":"438","properties":{"color":"16770457"}},{"ID":"36","typeID":"Label","zOrder":"58","w":"200","measuredW":"198","measuredH":"24","x":"716","y":"447","properties":{"text":"Functions, Builtin Functions","size":"16"}},{"ID":"37","typeID":"Canvas","zOrder":"51","w":"256","h":"42","measuredW":"100","measuredH":"70","x":"688","y":"484","properties":{"color":"16770457"}},{"ID":"38","typeID":"Label","zOrder":"52","measuredW":"221","measuredH":"24","x":"705","y":"493","properties":{"size":"16","text":"Lists, Tuples, Sets, Dictionaries"}},{"ID":"39","typeID":"Arrow","zOrder":"40","w":"120","h":"44","measuredW":"150","measuredH":"100","x":"597","y":"465","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":120,"y":44},"p1":{"x":0.5846756207563067,"y":-0.036972790801407494},"p2":{"x":0,"y":0}}},{"ID":"40","typeID":"Canvas","zOrder":"59","w":"262","h":"43","measuredW":"100","measuredH":"70","x":"354","y":"485","properties":{"color":"16776960"}},{"ID":"41","typeID":"Label","zOrder":"60","measuredW":"219","measuredH":"24","x":"375","y":"495","properties":{"size":"16","text":"Datastructures and Algorithms"}},{"ID":"43","typeID":"Canvas","zOrder":"55","w":"254","h":"42","measuredW":"100","measuredH":"70","x":"688","y":"391","properties":{"color":"16770457"}},{"ID":"44","typeID":"Label","zOrder":"56","measuredW":"181","measuredH":"24","x":"725","y":"400","properties":{"size":"16","text":"Type Casting, Exceptions"}},{"ID":"45","typeID":"Arrow","zOrder":"39","w":"120","h":"45","measuredW":"150","measuredH":"100","x":"601","y":"407","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":120,"y":0},"p1":{"x":0.5537800308573948,"y":0.04485342737491732},"p2":{"x":0,"y":45}}},{"ID":"68","typeID":"__group__","zOrder":"61","measuredW":"223","measuredH":"134","w":"223","h":"134","x":"69","y":"545","children":{"controls":{"control":[{"ID":"0","typeID":"__group__","zOrder":"0","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"0","y":"0","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"168","measuredH":"24","x":"27","y":"9","properties":{"size":"16","text":"Arrays and Linked Lists"}}]}}},{"ID":"1","typeID":"__group__","zOrder":"1","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"0","y":"46","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"195","measuredH":"24","x":"14","y":"8","properties":{"size":"16","text":"Heaps, Stacks and Queues"}}]}}},{"ID":"2","typeID":"__group__","zOrder":"2","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"1","y":"92","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"89","measuredH":"24","x":"66","y":"9","properties":{"size":"16","text":"Hash Tables"}}]}}}]}}},{"ID":"69","typeID":"__group__","zOrder":"62","measuredW":"222","measuredH":"135","w":"222","h":"135","x":"688","y":"544","children":{"controls":{"control":[{"ID":"0","typeID":"__group__","zOrder":"0","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"0","y":"0","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"146","measuredH":"24","x":"38","y":"9","properties":{"size":"16","text":"Binary Search Trees"}}]}}},{"ID":"1","typeID":"__group__","zOrder":"1","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"0","y":"46","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"74","measuredH":"24","x":"74","y":"9","properties":{"size":"16","text":"Recursion"}}]}}},{"ID":"2","typeID":"__group__","zOrder":"2","measuredW":"222","measuredH":"42","w":"222","h":"42","x":"0","y":"93","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"222","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"132","measuredH":"24","x":"45","y":"9","properties":{"size":"16","text":"Sorting Algorithms"}}]}}}]}}},{"ID":"70","typeID":"Arrow","zOrder":"38","w":"157","h":"63","measuredW":"150","measuredH":"100","x":"256","y":"503","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":157,"y":0},"p1":{"x":0.6016998827667055,"y":0.11606096131301237},"p2":{"x":0,"y":59}}},{"ID":"71","typeID":"Arrow","zOrder":"37","w":"131","h":"89","measuredW":"150","measuredH":"100","x":"265","y":"519","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":131,"y":0},"p1":{"x":0.6016998827667047,"y":0.11606096131301123},"p2":{"x":0,"y":89}}},{"ID":"72","typeID":"Arrow","zOrder":"36","w":"130","h":"138","measuredW":"150","measuredH":"100","x":"272","y":"518","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":130,"y":0},"p1":{"x":0.6016998827667047,"y":0.11606096131301115},"p2":{"x":0,"y":138}}},{"ID":"74","typeID":"Arrow","zOrder":"35","w":"109","h":"43","measuredW":"150","measuredH":"100","x":"587","y":"519","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":109,"y":42.5},"p1":{"x":0.5504392774297248,"y":0.14122632376847066},"p2":{"x":0,"y":0}}},{"ID":"75","typeID":"Arrow","zOrder":"34","w":"122","h":"92","measuredW":"150","measuredH":"100","x":"583","y":"518","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":122,"y":91.5},"p1":{"x":0.5504392774297248,"y":0.14122632376847064},"p2":{"x":0,"y":-0.5}}},{"ID":"76","typeID":"Arrow","zOrder":"33","w":"131","h":"139","measuredW":"150","measuredH":"100","x":"579","y":"523","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":131,"y":138.5},"p1":{"x":0.5504392774297246,"y":0.14122632376847055},"p2":{"x":0,"y":-0.5}}},{"ID":"77","typeID":"Arrow","zOrder":"32","w":"99","h":"326","measuredW":"150","measuredH":"100","x":"494","y":"511","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":0,"y":0},"p1":{"x":0.5666915052160955,"y":0.2790611028315947},"p2":{"x":14,"y":326}}},{"ID":"78","typeID":"Canvas","zOrder":"63","w":"279","h":"43","measuredW":"100","measuredH":"70","x":"240","y":"813","properties":{"color":"16776960"}},{"ID":"79","typeID":"Label","zOrder":"64","measuredW":"122","measuredH":"24","x":"319","y":"823","properties":{"size":"16","text":"Advanced Topics"}},{"ID":"80","typeID":"Arrow","zOrder":"31","w":"2","h":"62","measuredW":"150","measuredH":"100","x":"456","y":"764","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":62},"p1":{"x":0.5494505494505496,"y":0},"p2":{"x":2,"y":0}}},{"ID":"84","typeID":"Canvas","zOrder":"65","w":"169","h":"42","measuredW":"100","measuredH":"70","x":"364","y":"752","properties":{"color":"16770457"}},{"ID":"85","typeID":"Label","zOrder":"66","measuredW":"35","measuredH":"24","x":"429","y":"761","properties":{"text":"OOP","size":"16"}},{"ID":"106","typeID":"Arrow","zOrder":"30","w":"2","h":"52","measuredW":"150","measuredH":"100","x":"454","y":"712","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":2,"y":52},"p1":{"x":0.5494505494505497,"y":-2.6238653462337527e-18},"p2":{"x":0,"y":0}}},{"ID":"110","typeID":"Arrow","zOrder":"29","w":"45","h":"48","measuredW":"150","measuredH":"100","x":"272","y":"781","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":43,"y":47.5},"p1":{"x":0.506217070600632,"y":-0.3447839831401475},"p2":{"x":0,"y":0.5}}},{"ID":"111","typeID":"Arrow","zOrder":"28","w":"59","h":"90","measuredW":"150","measuredH":"100","x":"270","y":"733","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":59,"y":90.5},"p1":{"x":0.638419958419957,"y":-0.2587110187110215},"p2":{"x":0,"y":1.5}}},{"ID":"112","typeID":"Canvas","zOrder":"71","w":"169","h":"42","measuredW":"100","measuredH":"70","x":"364","y":"686","properties":{"color":"16770457"}},{"ID":"113","typeID":"Label","zOrder":"72","measuredW":"125","measuredH":"24","x":"384","y":"695","properties":{"text":"Methods, Dunder","size":"16"}},{"ID":"114","typeID":"Canvas","zOrder":"69","w":"169","h":"42","measuredW":"100","measuredH":"70","x":"364","y":"640","properties":{"color":"16770457"}},{"ID":"115","typeID":"Label","zOrder":"70","w":"86","measuredW":"83","measuredH":"24","x":"406","y":"649","properties":{"size":"16","text":"Inheritance"}},{"ID":"116","typeID":"Canvas","zOrder":"67","w":"169","h":"42","measuredW":"100","measuredH":"70","x":"364","y":"594","properties":{"color":"16770457"}},{"ID":"117","typeID":"Label","zOrder":"68","w":"60","measuredW":"58","measuredH":"24","x":"419","y":"603","properties":{"size":"16","text":"Classes"}},{"ID":"120","typeID":"Arrow","zOrder":"27","w":"92","h":"1","measuredW":"150","measuredH":"100","x":"180","y":"834","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":0},"p1":{"x":0.5494505494505496,"y":0},"p2":{"x":92,"y":0}}},{"ID":"121","typeID":"__group__","zOrder":"73","measuredW":"223","measuredH":"42","w":"223","h":"42","x":"69","y":"763","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"223","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"81","measuredH":"24","x":"71","y":"9","properties":{"size":"16","text":"Decorators"}}]}}},{"ID":"122","typeID":"__group__","zOrder":"74","measuredW":"223","measuredH":"42","w":"223","h":"42","x":"69","y":"713","children":{"controls":{"control":[{"ID":"0","typeID":"Canvas","zOrder":"0","w":"223","h":"42","measuredW":"100","measuredH":"70","x":"0","y":"0","properties":{"color":"16770457"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"150","measuredH":"24","x":"37","y":"9","properties":{"size":"16","text":"Regular Expressions"}}]}}},{"ID":"125","typeID":"Canvas","zOrder":"77","w":"136","h":"42","measuredW":"100","measuredH":"70","x":"630","y":"728","properties":{"color":"16770457"}},{"ID":"126","typeID":"Label","zOrder":"78","measuredW":"62","measuredH":"24","x":"667","y":"737","properties":{"size":"16","text":"Modules"}},{"ID":"127","typeID":"Arrow","zOrder":"26","w":"205","h":"88","measuredW":"150","measuredH":"100","x":"493","y":"757","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":0,"y":84.5},"p1":{"x":0.6985268644291276,"y":-0.23904197066138563},"p2":{"x":203,"y":0}}},{"ID":"128","typeID":"Canvas","zOrder":"79","w":"136","h":"42","measuredW":"100","measuredH":"70","x":"807","y":"702","properties":{"color":"16770457"}},{"ID":"129","typeID":"Label","zOrder":"80","measuredW":"45","measuredH":"24","x":"852","y":"711","properties":{"size":"16","text":"Builtin"}},{"ID":"130","typeID":"Canvas","zOrder":"81","w":"136","h":"42","measuredW":"100","measuredH":"70","x":"808","y":"749","properties":{"color":"16770457"}},{"ID":"131","typeID":"Label","zOrder":"82","measuredW":"56","measuredH":"24","x":"848","y":"758","properties":{"size":"16","text":"Custom"}},{"ID":"132","typeID":"Arrow","zOrder":"24","w":"70","h":"31","measuredW":"150","measuredH":"100","x":"751","y":"717","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":70,"y":-0.5},"p1":{"x":0.4559594471643343,"y":0.06498851869503056},"p2":{"x":0,"y":30}}},{"ID":"133","typeID":"Arrow","zOrder":"25","w":"68","h":"20","measuredW":"150","measuredH":"100","x":"756","y":"754","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":68,"y":19.5},"p1":{"x":0.4980092542774131,"y":-0.04046056171311737},"p2":{"x":0,"y":-0.5}}},{"ID":"139","typeID":"Arrow","zOrder":"85","w":"56","h":"1","measuredW":"150","measuredH":"100","x":"195","y":"881","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","p0":{"x":-0.5,"y":0},"p1":{"x":0.4872751951136748,"y":-0.011876484560570066},"p2":{"x":55,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"164","typeID":"Canvas","zOrder":"86","w":"279","h":"43","measuredW":"100","measuredH":"70","x":"239","y":"861","properties":{"color":"16776960"}},{"ID":"165","typeID":"Label","zOrder":"87","measuredW":"175","measuredH":"24","x":"291","y":"871","properties":{"size":"16","text":"Version Control Systems"}},{"ID":"167","typeID":"Canvas","zOrder":"83","w":"139","h":"42","measuredW":"100","measuredH":"70","x":"628","y":"774","properties":{"color":"16770457"}},{"ID":"168","typeID":"Label","zOrder":"84","measuredW":"62","measuredH":"24","x":"667","y":"783","properties":{"size":"16","text":"Iterators"}},{"ID":"170","typeID":"Canvas","zOrder":"88","w":"146","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"861","properties":{"color":"16770457"}},{"ID":"171","typeID":"Label","zOrder":"89","measuredW":"117","measuredH":"24","x":"83","y":"870","properties":{"size":"16","text":"Basic Git Usage"}},{"ID":"172","typeID":"Canvas","zOrder":"75","w":"146","h":"42","measuredW":"100","measuredH":"70","x":"69","y":"814","properties":{"color":"16770457"}},{"ID":"173","typeID":"Label","zOrder":"76","measuredW":"67","measuredH":"24","x":"108","y":"823","properties":{"text":"Lambdas","size":"16"}},{"ID":"176","typeID":"Canvas","zOrder":"90","w":"209","h":"43","measuredW":"100","measuredH":"70","x":"554","y":"860","properties":{"color":"16776960"}},{"ID":"177","typeID":"Label","zOrder":"91","measuredW":"166","measuredH":"24","x":"576","y":"870","properties":{"size":"16","text":"Repo Hosting Services"}},{"ID":"178","typeID":"Arrow","zOrder":"23","w":"114","h":"1","measuredW":"150","measuredH":"100","x":"492","y":"882","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","rightArrow":"false","p0":{"x":-0.5,"y":0},"p1":{"x":0.48727519511367473,"y":-0.011876484560570066},"p2":{"x":113,"y":0}}},{"ID":"179","typeID":"Canvas","zOrder":"92","w":"136","h":"42","measuredW":"100","measuredH":"70","x":"808","y":"816","properties":{"color":"16770457"}},{"ID":"180","typeID":"Label","zOrder":"93","measuredW":"51","measuredH":"24","x":"850","y":"825","properties":{"size":"16","text":"GitHub"}},{"ID":"181","typeID":"Canvas","zOrder":"94","w":"136","h":"42","measuredW":"100","measuredH":"70","x":"808","y":"862","properties":{"color":"14540253"}},{"ID":"182","typeID":"Label","zOrder":"95","measuredW":"48","measuredH":"24","x":"852","y":"871","properties":{"size":"16","text":"GitLab"}},{"ID":"183","typeID":"Canvas","zOrder":"96","w":"136","h":"42","measuredW":"100","measuredH":"70","x":"808","y":"908","properties":{"color":"14540253"}},{"ID":"184","typeID":"Label","zOrder":"97","measuredW":"70","measuredH":"24","x":"841","y":"917","properties":{"size":"16","text":"BitBucket"}},{"ID":"185","typeID":"Arrow","zOrder":"22","w":"63","h":"46","measuredW":"150","measuredH":"100","x":"755","y":"834","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":62.5,"y":-0.5},"p1":{"x":0.45595944716433434,"y":0.06498851869503053},"p2":{"x":0,"y":45}}},{"ID":"186","typeID":"Arrow","zOrder":"21","w":"90","h":"45","measuredW":"150","measuredH":"100","x":"735","y":"887","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":89.5,"y":44.5},"p1":{"x":0.5182829888712243,"y":-0.06677265500794909},"p2":{"x":-0.5,"y":-0.5}}},{"ID":"187","typeID":"Arrow","zOrder":"20","w":"85","h":"1","measuredW":"150","measuredH":"100","x":"749","y":"883","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","stroke":"dotted","color":"10027263","p0":{"x":84.5,"y":-0.5},"p1":{"x":0.45889842236368666,"y":0.006365900913368392},"p2":{"x":-0.5,"y":0.5}}},{"ID":"188","typeID":"Arrow","zOrder":"19","w":"121","h":"135","measuredW":"150","measuredH":"100","x":"537","y":"876","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":119.5,"y":-0.5},"p1":{"x":0.5161658071270696,"y":0.2998642832215285},"p2":{"x":0,"y":133.5}}},{"ID":"189","typeID":"Canvas","zOrder":"98","w":"240","h":"43","measuredW":"100","measuredH":"70","x":"336","y":"988","properties":{"color":"16776960"}},{"ID":"190","typeID":"Label","zOrder":"99","measuredW":"141","measuredH":"24","x":"382","y":"998","properties":{"size":"16","text":"Package Managers"}},{"ID":"191","typeID":"Arrow","zOrder":"18","w":"1","h":"39","measuredW":"150","measuredH":"100","x":"520","y":"965","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":-0.5},"p1":{"x":0.4872751951136748,"y":-0.011876484560570064},"p2":{"x":0,"y":38}}},{"ID":"192","typeID":"Canvas","zOrder":"100","w":"110","h":"42","measuredW":"100","measuredH":"70","x":"466","y":"928","properties":{"color":"16770457"}},{"ID":"193","typeID":"Label","zOrder":"101","measuredW":"24","measuredH":"24","x":"509","y":"937","properties":{"size":"16","text":"Pip"}},{"ID":"194","typeID":"Arrow","zOrder":"15","w":"1","h":"39","measuredW":"150","measuredH":"100","x":"406","y":"965","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":-0.5},"p1":{"x":0.4872751951136748,"y":-0.011876484560570064},"p2":{"x":0,"y":38}}},{"ID":"195","typeID":"Canvas","zOrder":"16","w":"121","h":"42","measuredW":"100","measuredH":"70","x":"337","y":"928","properties":{"color":"16770457"}},{"ID":"196","typeID":"Label","zOrder":"17","measuredW":"33","measuredH":"24","x":"381","y":"937","properties":{"size":"16","text":"PyPI"}},{"ID":"198","typeID":"Canvas","zOrder":"102","w":"240","h":"43","measuredW":"100","measuredH":"70","x":"337","y":"1036","properties":{"color":"16776960"}},{"ID":"199","typeID":"Label","zOrder":"103","measuredW":"140","measuredH":"24","x":"387","y":"1046","properties":{"size":"16","text":"Learn a Framework"}},{"ID":"204","typeID":"Arrow","zOrder":"14","w":"66","h":"42","measuredW":"150","measuredH":"100","x":"280","y":"1007","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":0},"p1":{"x":0.6082405345211582,"y":-0.15211581291759485},"p2":{"x":66,"y":41}}},{"ID":"205","typeID":"Canvas","zOrder":"104","w":"237","h":"43","measuredW":"100","measuredH":"70","x":"61","y":"988","properties":{"color":"16770457"}},{"ID":"206","typeID":"Label","zOrder":"105","measuredW":"93","measuredH":"24","x":"133","y":"998","properties":{"size":"16","text":"Synchronous"}},{"ID":"207","typeID":"Canvas","zOrder":"106","w":"76","h":"42","measuredW":"100","measuredH":"70","x":"61","y":"929","properties":{"color":"16770457"}},{"ID":"208","typeID":"Label","zOrder":"107","measuredW":"52","measuredH":"24","x":"73","y":"938","properties":{"size":"16","text":"Django"}},{"ID":"211","typeID":"Canvas","zOrder":"108","w":"69","h":"42","measuredW":"100","measuredH":"70","x":"142","y":"929","properties":{"color":"14540253"}},{"ID":"212","typeID":"Label","zOrder":"109","measuredW":"38","measuredH":"24","x":"158","y":"938","properties":{"size":"16","text":"Flask"}},{"ID":"213","typeID":"Canvas","zOrder":"110","w":"86","h":"42","measuredW":"100","measuredH":"70","x":"215","y":"929","properties":{"color":"14540253"}},{"ID":"214","typeID":"Label","zOrder":"111","measuredW":"58","measuredH":"24","x":"229","y":"938","properties":{"size":"16","text":"Pyramid"}},{"ID":"215","typeID":"Arrow","zOrder":"13","w":"1","h":"39","measuredW":"150","measuredH":"100","x":"101","y":"961","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":-0.5},"p1":{"x":0.4872751951136748,"y":-0.011876484560570064},"p2":{"x":0,"y":38}}},{"ID":"216","typeID":"Arrow","zOrder":"12","w":"1","h":"39","measuredW":"150","measuredH":"100","x":"176","y":"961","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":-0.5},"p1":{"x":0.4872751951136748,"y":-0.011876484560570064},"p2":{"x":0,"y":38}}},{"ID":"217","typeID":"Arrow","zOrder":"11","w":"1","h":"39","measuredW":"150","measuredH":"100","x":"258","y":"961","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":-0.5},"p1":{"x":0.4872751951136748,"y":-0.011876484560570064},"p2":{"x":0,"y":38}}},{"ID":"218","typeID":"Canvas","zOrder":"112","w":"237","h":"43","measuredW":"100","measuredH":"70","x":"61","y":"1037","properties":{"color":"16770457"}},{"ID":"219","typeID":"Label","zOrder":"113","measuredW":"101","measuredH":"24","x":"129","y":"1047","properties":{"size":"16","text":"Asynchronous"}},{"ID":"220","typeID":"Arrow","zOrder":"10","w":"67","h":"2","measuredW":"150","measuredH":"100","x":"282","y":"1058","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":0},"p1":{"x":0.31327581408293903,"y":0.007013637628722516},"p2":{"x":67,"y":1.5}}},{"ID":"223","typeID":"Canvas","zOrder":"114","w":"126","h":"42","measuredW":"100","measuredH":"70","x":"61","y":"1096","properties":{"color":"14540253"}},{"ID":"224","typeID":"Label","zOrder":"115","measuredW":"50","measuredH":"24","x":"99","y":"1105","properties":{"size":"16","text":"gevent"}},{"ID":"225","typeID":"Canvas","zOrder":"116","w":"105","h":"42","measuredW":"100","measuredH":"70","x":"193","y":"1096","properties":{"color":"16770457"}},{"ID":"226","typeID":"Label","zOrder":"117","measuredW":"50","measuredH":"24","x":"221","y":"1105","properties":{"size":"16","text":"aiohttp"}},{"ID":"227","typeID":"Canvas","zOrder":"118","w":"126","h":"42","measuredW":"100","measuredH":"70","x":"61","y":"1143","properties":{"color":"14540253"}},{"ID":"228","typeID":"Label","zOrder":"119","measuredW":"60","measuredH":"24","x":"94","y":"1152","properties":{"size":"16","text":"Tornado"}},{"ID":"229","typeID":"Canvas","zOrder":"120","w":"105","h":"42","measuredW":"100","measuredH":"70","x":"193","y":"1143","properties":{"color":"14540253"}},{"ID":"230","typeID":"Label","zOrder":"121","measuredW":"41","measuredH":"24","x":"225","y":"1152","properties":{"size":"16","text":"Sanic"}},{"ID":"231","typeID":"Arrow","zOrder":"9","w":"1","h":"54","measuredW":"150","measuredH":"100","x":"120","y":"1065","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":1,"y":-0.5},"p1":{"x":0.4872751951136748,"y":-0.011876484560570062},"p2":{"x":1,"y":53.5}}},{"ID":"232","typeID":"Arrow","zOrder":"8","w":"1","h":"54","measuredW":"150","measuredH":"100","x":"245","y":"1065","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":1,"y":-0.5},"p1":{"x":0.4872751951136748,"y":-0.011876484560570062},"p2":{"x":1,"y":53.5}}},{"ID":"235","typeID":"Arrow","zOrder":"7","w":"183","h":"57","measuredW":"150","measuredH":"100","x":"557","y":"1045","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":56},"p1":{"x":0.7132832764505119,"y":-0.16909215017064846},"p2":{"x":183,"y":0}}},{"ID":"236","typeID":"Canvas","zOrder":"124","w":"154","h":"42","measuredW":"100","measuredH":"70","x":"663","y":"1018","properties":{"color":"16770457"}},{"ID":"237","typeID":"Label","zOrder":"125","measuredW":"116","measuredH":"24","x":"682","y":"1027","properties":{"size":"16","text":"unittest / pyUnit"}},{"ID":"238","typeID":"Canvas","zOrder":"126","w":"154","h":"42","measuredW":"100","measuredH":"70","x":"663","y":"972","properties":{"color":"14540253"}},{"ID":"239","typeID":"Label","zOrder":"127","measuredW":"44","measuredH":"24","x":"718","y":"981","properties":{"size":"16","text":"pytest"}},{"ID":"240","typeID":"Canvas","zOrder":"128","w":"122","h":"42","measuredW":"100","measuredH":"70","x":"822","y":"972","properties":{"color":"14540253"}},{"ID":"241","typeID":"Label","zOrder":"129","measuredW":"54","measuredH":"24","x":"856","y":"981","properties":{"size":"16","text":"doctest"}},{"ID":"242","typeID":"Canvas","zOrder":"130","w":"122","h":"42","measuredW":"100","measuredH":"70","x":"822","y":"1018","properties":{"color":"14540253"}},{"ID":"243","typeID":"Label","zOrder":"131","measuredW":"36","measuredH":"24","x":"865","y":"1027","properties":{"size":"16","text":"nose"}},{"ID":"244","typeID":"Arrow","zOrder":"6","w":"311","h":"69","measuredW":"150","measuredH":"100","x":"567","y":"1044","properties":{"color":"2848996","curvature":"-1","leftArrow":"false","rightArrow":"false","stroke":"dotted","p0":{"x":0,"y":67},"p1":{"x":0.7345469815235649,"y":-0.12769983203240787},"p2":{"x":311,"y":0}}},{"ID":"246","typeID":"Canvas","zOrder":"122","w":"240","h":"43","measuredW":"100","measuredH":"70","x":"337","y":"1084","properties":{"color":"16776960"}},{"ID":"247","typeID":"Label","zOrder":"123","measuredW":"128","measuredH":"24","x":"393","y":"1094","properties":{"size":"16","text":"Testing your Apps"}},{"ID":"711","typeID":"Arrow","zOrder":"4","w":"1","h":"142","measuredW":"150","measuredH":"100","x":"451","y":"1108","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":-0.5,"y":-0.5},"p1":{"x":0.5259259259259259,"y":0},"p2":{"x":-0.5,"y":141.5}}},{"ID":"712","typeID":"Label","zOrder":"132","measuredW":"245","measuredH":"28","x":"325","y":"1234","properties":{"size":"20","text":"Look at Backend Roadmap"}},{"ID":"713","typeID":"Label","zOrder":"133","measuredW":"153","measuredH":"24","x":"371","y":"1262","properties":{"size":"16","text":"roadmap.sh/backend","color":"10027263"}},{"ID":"714","typeID":"Canvas","zOrder":"5","w":"305","h":"84","measuredW":"100","measuredH":"70","x":"295","y":"1218"},{"ID":"715","typeID":"Arrow","zOrder":"3","w":"1","h":"98","measuredW":"150","measuredH":"100","x":"450","y":"1272","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":-0.5,"y":-0.5},"p1":{"x":0.5259259259259262,"y":0},"p2":{"x":-0.5,"y":97},"stroke":"dotted"}},{"ID":"716","typeID":"Canvas","zOrder":"2","w":"454","h":"90","measuredW":"100","measuredH":"70","x":"108","y":"183"},{"ID":"719","typeID":"Arrow","zOrder":"0","w":"33","h":"73","measuredW":"150","measuredH":"100","x":"428","y":"129","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","stroke":"dotted","p0":{"x":6,"y":0},"p1":{"x":0.4744027303754264,"y":-0.21757679180887365},"p2":{"x":33,"y":72.5}}},{"ID":"724","typeID":"Label","zOrder":"134","measuredW":"384","measuredH":"28","x":"143","y":"201","properties":{"size":"20","text":"Backend Roadmap till Language Selection"}},{"ID":"725","typeID":"Label","zOrder":"135","measuredW":"153","measuredH":"24","x":"258","y":"230","properties":{"size":"16","text":"roadmap.sh/backend","color":"10027263"}},{"ID":"735","typeID":"Canvas","zOrder":"136","w":"350","h":"141","measuredW":"100","measuredH":"70","x":"594","y":"171"},{"ID":"736","typeID":"Label","zOrder":"137","measuredW":"314","measuredH":"25","x":"608","y":"188","properties":{"size":"17","text":"Find the detailed version of this roadmap"}},{"ID":"737","typeID":"Label","zOrder":"138","measuredW":"319","measuredH":"25","x":"608","y":"216","properties":{"size":"17","text":"along with resources and other roadmaps"}},{"ID":"738","typeID":"Canvas","zOrder":"139","w":"320","h":"45","measuredW":"100","measuredH":"70","x":"609","y":"252","properties":{"borderColor":"4273622","color":"4273622"}},{"ID":"739","typeID":"Label","zOrder":"140","measuredW":"105","measuredH":"28","x":"750","y":"260","properties":{"color":"16777215","size":"20","text":"roadmap.sh"}},{"ID":"740","typeID":"Label","zOrder":"141","measuredW":"35","measuredH":"28","x":"685","y":"260","properties":{"color":"16777215","size":"20","text":"http"}},{"ID":"741","typeID":"Label","zOrder":"142","measuredW":"5","measuredH":"28","x":"722","y":"260","properties":{"color":"16777215","size":"20","text":":"}},{"ID":"742","typeID":"Label","zOrder":"143","measuredW":"10","measuredH":"28","x":"729","y":"261","properties":{"color":"16777215","size":"20","text":"/"}},{"ID":"743","typeID":"Label","zOrder":"144","measuredW":"10","measuredH":"28","x":"737","y":"261","properties":{"color":"16777215","size":"20","text":"/"}}]},"attributes":{"name":"New Wireframe 3","order":1000021.6092143646,"parentID":null,"notes":null},"branchID":"Master","resourceID":"D97C1354-BDA0-473B-89B0-4A4B6C35159C","mockupH":"1241","mockupW":"883","measuredW":"944","measuredH":"1370","version":"1.0"}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/python/resources.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/python/resources.json new file mode 100644 index 000000000..0100e373c --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/python/resources.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"Learn to become a modern Python developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for python development. Learn to become a modern Python developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an python developer","python developer roadmap","python roadmap","become python developer","python developer skills","python skills test","skills for python development","learn python development","what is python","python quiz","python interview questions"]},"title":"Python Developer","description":"Step by step guide to becoming a Python developer in 2021","featuredTitle":"Python","featuredDescription":"Step by step guide to becoming a Python Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"resourcesPath":"/roadmaps/106-python/resources.md","contentPath":"/roadmaps/106-python/landscape.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/python-roadmap","versions":["latest"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"python","metaPath":"/roadmaps/106-python/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/qa.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/qa.json new file mode 100644 index 000000000..632184d0d --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/qa.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"QA Roadmap: Learn to become a modern QA engineer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern QA development. Learn to become a modern QA engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a QA engineer","QA engineer","QA skills","QA development skills","QA development skills test","QA engineer roadmap","become a QA engineer","QA engineer career path","skills for QA development","what is QA engineer","QA engineer quiz","QA engineer interview questions"]},"title":"QA Engineer","description":"Steps to follow in order to become a modern QA Engineer in 2021","featuredTitle":"QA","featuredDescription":"Step by step guide to becoming a modern QA Engineer in 2021","isUpcoming":true,"featured":true,"contentPath":"/roadmaps/111-qa/landscape.md","resourcesPath":"/roadmaps/111-qa/resources.md","author":{"name":"Anas Fitiani","url":"https://github.com/anas-qa"},"id":"qa","metaPath":"/roadmaps/111-qa/meta.json"}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/qa/interactive.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/qa/interactive.json new file mode 100644 index 000000000..6906d75ff --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/qa/interactive.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"QA Roadmap: Learn to become a modern QA engineer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern QA development. Learn to become a modern QA engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a QA engineer","QA engineer","QA skills","QA development skills","QA development skills test","QA engineer roadmap","become a QA engineer","QA engineer career path","skills for QA development","what is QA engineer","QA engineer quiz","QA engineer interview questions"]},"title":"QA Engineer","description":"Steps to follow in order to become a modern QA Engineer in 2021","featuredTitle":"QA","featuredDescription":"Step by step guide to becoming a modern QA Engineer in 2021","isUpcoming":true,"featured":true,"contentPath":"/roadmaps/111-qa/landscape.md","resourcesPath":"/roadmaps/111-qa/resources.md","author":{"name":"Anas Fitiani","url":"https://github.com/anas-qa"},"id":"qa","metaPath":"/roadmaps/111-qa/meta.json"},"json":{}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/qa/resources.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/qa/resources.json new file mode 100644 index 000000000..632184d0d --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/qa/resources.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"QA Roadmap: Learn to become a modern QA engineer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern QA development. Learn to become a modern QA engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a QA engineer","QA engineer","QA skills","QA development skills","QA development skills test","QA engineer roadmap","become a QA engineer","QA engineer career path","skills for QA development","what is QA engineer","QA engineer quiz","QA engineer interview questions"]},"title":"QA Engineer","description":"Steps to follow in order to become a modern QA Engineer in 2021","featuredTitle":"QA","featuredDescription":"Step by step guide to becoming a modern QA Engineer in 2021","isUpcoming":true,"featured":true,"contentPath":"/roadmaps/111-qa/landscape.md","resourcesPath":"/roadmaps/111-qa/resources.md","author":{"name":"Anas Fitiani","url":"https://github.com/anas-qa"},"id":"qa","metaPath":"/roadmaps/111-qa/meta.json"}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/react.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/react.json new file mode 100644 index 000000000..18dc7e1f4 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/react.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"React Developer Roadmap: Learn to become a React developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a react developer","react developer roadmap","react roadmap","become react developer","react developer skills","react skills test","skills for react development","learn react development","what is react","react quiz","react interview questions"]},"title":"React Developer","description":"Everything that is there to learn about React and the ecosystem in 2021.","featuredTitle":"React","featuredDescription":"Step by step guide to become a React Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/103-react/landscape.md","resourcesPath":"/roadmaps/103-react/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/react-roadmap","id":"react","metaPath":"/roadmaps/103-react/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/react/interactive.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/react/interactive.json new file mode 100644 index 000000000..8b7d1793e --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/react/interactive.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"React Developer Roadmap: Learn to become a React developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a react developer","react developer roadmap","react roadmap","become react developer","react developer skills","react skills test","skills for react development","learn react development","what is react","react quiz","react interview questions"]},"title":"React Developer","description":"Everything that is there to learn about React and the ecosystem in 2021.","featuredTitle":"React","featuredDescription":"Step by step guide to become a React Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/103-react/landscape.md","resourcesPath":"/roadmaps/103-react/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/react-roadmap","id":"react","metaPath":"/roadmaps/103-react/meta.json","isUpcoming":false},"json":{"mockup":{"controls":{"control":[{"ID":"0","typeID":"Arrow","zOrder":"4","w":"105","h":"15","measuredW":"150","measuredH":"100","x":"248","y":"1040","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":104,"y":0},"p1":{"x":0.5740721807586137,"y":0.016256006543298233},"p2":{"x":0,"y":14},"rightArrow":"false","stroke":"dotted"}},{"ID":"1","typeID":"Arrow","zOrder":"5","w":"92","h":"22","measuredW":"150","measuredH":"100","x":"259","y":"1012","properties":{"color":"2848996","curvature":"0","direction":"top","leftArrow":"false","p0":{"x":91,"y":21},"p1":{"x":0.5676406229888018,"y":0.009525035397091009},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"2","typeID":"Arrow","zOrder":"6","w":"89","h":"19","measuredW":"150","measuredH":"100","x":"255","y":"983","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":88,"y":0},"p1":{"x":0.5740721807586137,"y":0.016256006543298233},"p2":{"x":0,"y":18},"rightArrow":"false","stroke":"dotted"}},{"ID":"3","typeID":"Arrow","zOrder":"7","w":"6","h":"75","measuredW":"150","measuredH":"100","x":"908","y":"1063","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"length":74.16872656315464,"x":5,"y":74},"p1":{"length":0.5062618190857066,"x":0.5058572949946751,"y":0.020234291799786995},"p2":{"length":1,"x":1,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"4","typeID":"Arrow","zOrder":"8","w":"140","h":"446","measuredW":"150","measuredH":"100","x":"489","y":"953","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":133,"y":0},"p1":{"x":0.6169504337496851,"y":0.15190237932399842},"p2":{"x":0,"y":445},"rightArrow":"false","stroke":"dotted"}},{"ID":"5","typeID":"Arrow","zOrder":"9","w":"95","h":"1","measuredW":"150","measuredH":"100","x":"251","y":"1396","properties":{"color":"2848996","curvature":"0","direction":"top","leftArrow":"false","p0":{"length":0,"x":0,"y":0},"p1":{"length":0.638011617080294,"x":0.6380090497737556,"y":-0.0018099547511312248},"p2":{"length":94,"x":94,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"6","typeID":"Arrow","zOrder":"10","w":"101","h":"33","measuredW":"150","measuredH":"100","x":"984","y":"1311","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"length":0,"x":0,"y":0},"p1":{"length":0.49484881151760673,"x":0.49473684210526325,"y":-0.01052631578947367},"p2":{"length":104.9952379872535,"x":100,"y":32},"rightArrow":"false","stroke":"dotted"}},{"ID":"7","typeID":"Arrow","zOrder":"11","w":"88","h":"7","measuredW":"150","measuredH":"100","x":"987","y":"1293","properties":{"color":"2848996","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"length":6,"x":0,"y":6},"p1":{"length":0.4948488115176065,"x":0.49473684210526303,"y":-0.010526315789473628},"p2":{"length":87,"x":87,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"8","typeID":"Arrow","zOrder":"12","w":"86","h":"55","measuredW":"150","measuredH":"100","x":"987","y":"1242","properties":{"color":"2848996","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"length":54,"x":0,"y":54},"p1":{"length":0.4948488115176066,"x":0.49473684210526314,"y":-0.010526315789473687},"p2":{"length":85,"x":85,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"9","typeID":"Arrow","zOrder":"13","w":"6","h":"564","measuredW":"150","measuredH":"100","x":"673","y":"955","properties":{"color":"2848996","curvature":"0","direction":"top","leftArrow":"false","rightArrow":"false","p0":{"x":3,"y":0},"p1":{"x":0.5326751848090502,"y":0.008478779433645877},"p2":{"x":0.33333333333337123,"y":563.6666666666667}}},{"ID":"10","typeID":"Arrow","zOrder":"14","w":"1","h":"82","measuredW":"150","measuredH":"100","x":"925","y":"1297","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"length":81,"x":0,"y":81},"p1":{"length":0.4948488115176067,"x":0.4947368421052632,"y":-0.010526315789473686},"p2":{"length":0,"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"11","typeID":"Arrow","zOrder":"15","w":"170","h":"343","measuredW":"150","measuredH":"100","x":"702","y":"957","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.6386805175102196,"y":-0.15317754646213494},"p2":{"x":169,"y":342},"rightArrow":"false","stroke":"dotted"}},{"ID":"12","typeID":"Arrow","zOrder":"16","w":"65","h":"99","measuredW":"150","measuredH":"100","x":"480","y":"939","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":64,"y":0},"p1":{"x":0.6971153846153847,"y":0.14182692307692307},"p2":{"x":0,"y":98},"rightArrow":"false","stroke":"dotted"}},{"ID":"13","typeID":"Arrow","zOrder":"17","w":"64","h":"109","measuredW":"150","measuredH":"100","x":"728","y":"948","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.7038144329896907,"y":-0.09391752577319588},"p2":{"x":63,"y":108},"rightArrow":"false","stroke":"dotted"}},{"ID":"14","typeID":"Arrow","zOrder":"18","w":"58","h":"42","measuredW":"150","measuredH":"100","x":"976","y":"841","properties":{"color":"2848996","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"x":57,"y":0},"p1":{"x":0.35054421156786897,"y":-0.018800035980930063},"p2":{"x":0,"y":41},"rightArrow":"false","stroke":"dotted"}},{"ID":"15","typeID":"Arrow","zOrder":"19","w":"67","h":"3","measuredW":"150","measuredH":"100","x":"972","y":"885","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":66,"y":0},"p1":{"x":0.5343850513095418,"y":0.03614642364833821},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"16","typeID":"Arrow","zOrder":"20","w":"60","h":"103","measuredW":"150","measuredH":"100","x":"976","y":"980","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":59,"y":102},"p1":{"x":0.5058572949946751,"y":0.020234291799787023},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"17","typeID":"Arrow","zOrder":"21","w":"66","h":"75","measuredW":"150","measuredH":"100","x":"975","y":"971","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":65,"y":74},"p1":{"x":0.5567467271415318,"y":-0.043088341408102256},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"18","typeID":"Arrow","zOrder":"22","w":"74","h":"27","measuredW":"150","measuredH":"100","x":"974","y":"965","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":73,"y":26},"p1":{"x":0.5398834304746045,"y":-0.05428809325562032},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"19","typeID":"Arrow","zOrder":"23","w":"63","h":"24","measuredW":"150","measuredH":"100","x":"730","y":"945","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.4043899289864429,"y":-0.01368624919302776},"p2":{"x":62,"y":23},"rightArrow":"false","stroke":"dotted"}},{"ID":"20","typeID":"Arrow","zOrder":"24","w":"74","h":"44","measuredW":"150","measuredH":"100","x":"974","y":"896","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":73,"y":43},"p1":{"x":0.4578313253012048,"y":-0.012048192771084336},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"21","typeID":"Arrow","zOrder":"25","w":"95","h":"18","measuredW":"150","measuredH":"100","x":"251","y":"1162","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"length":1,"x":0,"y":1},"p1":{"length":0.48824871437239115,"x":0.48542738182708794,"y":0.05241244183198628},"p2":{"length":95.524865872714,"x":94,"y":17},"rightArrow":"false","stroke":"dotted"}},{"ID":"22","typeID":"Arrow","zOrder":"26","w":"94","h":"59","measuredW":"150","measuredH":"100","x":"251","y":"1116","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"length":1,"x":0,"y":1},"p1":{"length":0.3714921097791618,"x":0.35753908219868885,"y":0.10085728693898134},"p2":{"length":109.60383204979652,"x":93,"y":58},"rightArrow":"false","stroke":"dotted"}},{"ID":"23","typeID":"Arrow","zOrder":"27","w":"2","h":"96","measuredW":"150","measuredH":"100","x":"411","y":"1181","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"length":95,"x":0,"y":95},"p1":{"length":0.4737749079645269,"x":0.4737425216042544,"y":-0.005539552404165743},"p2":{"length":1,"x":1,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"24","typeID":"Arrow","zOrder":"28","w":"83","h":"101","measuredW":"150","measuredH":"100","x":"261","y":"1195","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"length":100,"x":0,"y":100},"p1":{"length":0.48824871437239115,"x":0.48542738182708794,"y":0.05241244183198633},"p2":{"length":82,"x":82,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"25","typeID":"Arrow","zOrder":"29","w":"93","h":"153","measuredW":"150","measuredH":"100","x":"259","y":"1185","properties":{"color":"2848996","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"length":152,"x":0,"y":152},"p1":{"length":0.2803995773177261,"x":0.2781297516472377,"y":-0.035605676634566624},"p2":{"length":92,"x":92,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"26","typeID":"Arrow","zOrder":"30","w":"94","h":"61","measuredW":"150","measuredH":"100","x":"256","y":"1182","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"length":60,"x":0,"y":60},"p1":{"length":0.48824871437239115,"x":0.48542738182708794,"y":0.05241244183198629},"p2":{"length":93,"x":93,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"27","typeID":"Arrow","zOrder":"31","w":"68","h":"51","measuredW":"150","measuredH":"100","x":"728","y":"886","properties":{"color":"2848996","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"x":67,"y":0},"p1":{"x":0.44040635284017743,"y":-0.08985548719416225},"p2":{"x":0,"y":50},"rightArrow":"false","stroke":"dotted"}},{"ID":"28","typeID":"Arrow","zOrder":"32","w":"106","h":"16","measuredW":"150","measuredH":"100","x":"248","y":"937","properties":{"color":"2848996","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"x":0,"y":11},"p1":{"x":0.418664047151277,"y":-0.08212180746561885},"p2":{"x":105,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"29","typeID":"Arrow","zOrder":"33","w":"94","h":"31","measuredW":"150","measuredH":"100","x":"251","y":"899","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5210888020482415,"y":0.050532273278533865},"p2":{"x":93,"y":30},"rightArrow":"false","stroke":"dotted"}},{"ID":"30","typeID":"Arrow","zOrder":"34","w":"109","h":"5","measuredW":"150","measuredH":"100","x":"450","y":"932","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"length":108,"x":108,"y":0},"p1":{"length":0.638011617080294,"x":0.6380090497737556,"y":-0.001809954751131225},"p2":{"length":4,"x":0,"y":4},"rightArrow":"false","stroke":"dotted"}},{"ID":"31","typeID":"Arrow","zOrder":"35","w":"104","h":"234","measuredW":"150","measuredH":"100","x":"474","y":"947","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":102,"y":0},"p1":{"x":0.6562581123678843,"y":0.2116447246430558},"p2":{"x":0,"y":233},"rightArrow":"false","stroke":"dotted"}},{"ID":"32","typeID":"Arrow","zOrder":"36","w":"103","h":"132","measuredW":"150","measuredH":"100","x":"848","y":"653","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":102,"y":131},"p1":{"x":0.5003083620533285,"y":0.08372936695084346},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"33","typeID":"Arrow","zOrder":"37","w":"49","h":"292","measuredW":"150","measuredH":"100","x":"689","y":"641","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":0,"y":0},"p1":{"x":0.5185682873198143,"y":0.16381627168336182},"p2":{"x":1,"y":291},"rightArrow":"false"}},{"ID":"34","typeID":"Arrow","zOrder":"38","w":"117","h":"92","measuredW":"150","measuredH":"100","x":"838","y":"643","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":116,"y":91},"p1":{"x":0.4263237797304136,"y":0.049960896167824446},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"35","typeID":"Arrow","zOrder":"39","w":"111","h":"53","measuredW":"150","measuredH":"100","x":"840","y":"635","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"x":110,"y":52},"p1":{"x":0.4531207781680627,"y":0.04147527695217509},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"36","typeID":"Arrow","zOrder":"40","w":"119","h":"7","measuredW":"150","measuredH":"100","x":"839","y":"627","properties":{"color":"2848996","curvature":"0","direction":"top","leftArrow":"false","p0":{"x":118,"y":6},"p1":{"x":0.4652789342214827,"y":-0.0013322231473772738},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"37","typeID":"Arrow","zOrder":"41","w":"89","h":"106","measuredW":"150","measuredH":"100","x":"498","y":"654","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":88,"y":0},"p1":{"x":0.694396551724138,"y":0.14525862068965517},"p2":{"x":0,"y":104},"rightArrow":"false","stroke":"dotted"}},{"ID":"38","typeID":"Arrow","zOrder":"42","w":"93","h":"65","measuredW":"150","measuredH":"100","x":"490","y":"650","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":92,"y":0},"p1":{"x":0.5165605095541401,"y":0.08630573248407643},"p2":{"x":0,"y":64},"rightArrow":"false","stroke":"dotted"}},{"ID":"39","typeID":"Arrow","zOrder":"43","w":"69","h":"35","measuredW":"150","measuredH":"100","x":"295","y":"616","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"length":34,"x":0,"y":34},"p1":{"length":0.4078400012423434,"x":0.4078368652538985,"y":0.001599360255897608},"p2":{"length":68,"x":68,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"40","typeID":"Arrow","zOrder":"44","w":"81","h":"20","measuredW":"150","measuredH":"100","x":"307","y":"593","properties":{"color":"2848996","curvature":"0","direction":"top","leftArrow":"false","p0":{"x":80,"y":19},"p1":{"x":0.46527893422148264,"y":-0.0013322231473772645},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"41","typeID":"Arrow","zOrder":"45","w":"114","h":"76","measuredW":"150","measuredH":"100","x":"828","y":"426","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"length":135.6244815658294,"x":113,"y":75},"p1":{"length":0.49034679797322295,"x":0.4873025247305478,"y":0.05455485014026291},"p2":{"length":0,"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"42","typeID":"Arrow","zOrder":"46","w":"88","h":"21","measuredW":"150","measuredH":"100","x":"497","y":"610","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":87,"y":20},"p1":{"x":0.46091103024218855,"y":-0.0549629815535199},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"43","typeID":"Arrow","zOrder":"47","w":"105","h":"29","measuredW":"150","measuredH":"100","x":"487","y":"633","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":104,"y":0},"p1":{"x":0.47141024775535,"y":0.024843043272800916},"p2":{"x":0,"y":28},"rightArrow":"false","stroke":"dotted"}},{"ID":"44","typeID":"Arrow","zOrder":"48","w":"108","h":"118","measuredW":"150","measuredH":"100","x":"472","y":"425","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":107,"y":0},"p1":{"x":0.5565339359463882,"y":0.11104184524273356},"p2":{"x":0,"y":117},"rightArrow":"false","stroke":"dotted"}},{"ID":"45","typeID":"Arrow","zOrder":"49","w":"102","h":"66","measuredW":"150","measuredH":"100","x":"471","y":"426","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":101,"y":0},"p1":{"x":0.49432499118787465,"y":0.03919633415579831},"p2":{"x":0,"y":65},"rightArrow":"false","stroke":"dotted"}},{"ID":"46","typeID":"Arrow","zOrder":"50","w":"66","h":"65","measuredW":"150","measuredH":"100","x":"1061","y":"507","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"length":91.21951545584967,"x":65,"y":64},"p1":{"length":0.4412347883439139,"x":0.41749789688739336,"y":-0.14277130152625886},"p2":{"length":0,"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"47","typeID":"Arrow","zOrder":"51","w":"114","h":"32","measuredW":"150","measuredH":"100","x":"837","y":"421","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"length":117.17508267545622,"x":113,"y":31},"p1":{"length":0.49034679797322256,"x":0.4873025247305474,"y":0.0545548501402628},"p2":{"length":0,"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"48","typeID":"Arrow","zOrder":"52","w":"50","h":"77","measuredW":"150","measuredH":"100","x":"998","y":"504","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"length":76,"x":0,"y":76},"p1":{"length":0.4763317432510617,"x":0.4659313041049986,"y":0.09899469421949178},"p2":{"length":49,"x":49,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"49","typeID":"Arrow","zOrder":"53","w":"129","h":"11","measuredW":"150","measuredH":"100","x":"826","y":"404","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"length":128,"x":128,"y":0},"p1":{"length":0.4652808414804905,"x":0.4652789342214827,"y":-0.0013322231473772849},"p2":{"length":10,"x":0,"y":10},"rightArrow":"false","stroke":"dotted"}},{"ID":"50","typeID":"Arrow","zOrder":"54","w":"110","h":"19","measuredW":"150","measuredH":"100","x":"462","y":"423","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","p0":{"x":109,"y":0},"p1":{"x":0.49432499118787454,"y":0.03919633415579837},"p2":{"x":0,"y":18},"rightArrow":"false","stroke":"dotted"}},{"ID":"51","typeID":"Arrow","zOrder":"55","w":"67","h":"29","measuredW":"150","measuredH":"100","x":"267","y":"438","properties":{"color":"2848996","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"length":28,"x":0,"y":28},"p1":{"length":0.45024852627028145,"x":0.4470817120622568,"y":-0.053307392996108954},"p2":{"length":66,"x":66,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"52","typeID":"Arrow","zOrder":"56","w":"70","h":"27","measuredW":"150","measuredH":"100","x":"268","y":"413","properties":{"color":"2848996","curvature":"1","direction":"top","leftArrow":"false","p0":{"length":0,"x":0,"y":0},"p1":{"length":0.4463661980631013,"x":0.44581164221486,"y":0.022243256034074732},"p2":{"length":73.7360156233031,"x":69,"y":26},"rightArrow":"false","stroke":"dotted"}},{"ID":"53","typeID":"Arrow","zOrder":"57","w":"38","h":"210","measuredW":"150","measuredH":"100","x":"648","y":"424","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":23,"y":0},"p1":{"x":0.4841230221604845,"y":-0.13778134699281577},"p2":{"x":37,"y":209},"rightArrow":"false"}},{"ID":"54","typeID":"Arrow","zOrder":"58","w":"30","h":"92","measuredW":"150","measuredH":"100","x":"676","y":"309","properties":{"color":"2848996","curvature":"-1","direction":"bottom","leftArrow":"false","rightArrow":"false","p0":{"x":24.028182754193494,"y":0.15641534085972353},"p1":{"x":0.4488347077805664,"y":0.15539619935460736},"p2":{"x":0,"y":92}}},{"ID":"57","typeID":"Canvas","zOrder":"59","w":"350","h":"141","measuredW":"100","measuredH":"70","x":"884","y":"74"},{"ID":"58","typeID":"Label","zOrder":"60","measuredW":"314","measuredH":"25","x":"898","y":"91","properties":{"size":"17","text":"Find the detailed version of this roadmap"}},{"ID":"59","typeID":"Label","zOrder":"61","measuredW":"319","measuredH":"25","x":"898","y":"119","properties":{"size":"17","text":"along with resources and other roadmaps"}},{"ID":"60","typeID":"Canvas","zOrder":"62","w":"320","h":"45","measuredW":"100","measuredH":"70","x":"899","y":"155","properties":{"borderColor":"4273622","color":"4273622"}},{"ID":"61","typeID":"Label","zOrder":"63","measuredW":"105","measuredH":"28","x":"1040","y":"163","properties":{"color":"16777215","size":"20","text":"roadmap.sh"}},{"ID":"62","typeID":"Label","zOrder":"64","measuredW":"35","measuredH":"28","x":"975","y":"163","properties":{"color":"16777215","size":"20","text":"http"}},{"ID":"63","typeID":"Label","zOrder":"65","measuredW":"5","measuredH":"28","x":"1012","y":"163","properties":{"color":"16777215","size":"20","text":":"}},{"ID":"64","typeID":"Label","zOrder":"66","measuredW":"10","measuredH":"28","x":"1019","y":"164","properties":{"color":"16777215","size":"20","text":"/"}},{"ID":"65","typeID":"Label","zOrder":"67","measuredW":"10","measuredH":"28","x":"1027","y":"164","properties":{"color":"16777215","size":"20","text":"/"}},{"ID":"79","typeID":"Arrow","zOrder":"68","w":"118","h":"51","measuredW":"150","measuredH":"100","x":"824","y":"356","properties":{"color":"2848996","curvature":"1","direction":"bottom","leftArrow":"false","p0":{"x":117,"y":0},"p1":{"x":0.45522128005575546,"y":-0.05494250203275646},"p2":{"x":0,"y":50},"rightArrow":"false","stroke":"dotted"}},{"ID":"80","typeID":"Arrow","zOrder":"69","w":"128","h":"35","measuredW":"150","measuredH":"100","x":"443","y":"385","properties":{"color":"2848996","curvature":"0","direction":"top","leftArrow":"false","p0":{"x":127,"y":34},"p1":{"x":0.4652789342214826,"y":-0.0013322231473772712},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"81","typeID":"Arrow","zOrder":"70","w":"109","h":"80","measuredW":"150","measuredH":"100","x":"462","y":"332","properties":{"color":"2848996","curvature":"-1","direction":"top","leftArrow":"false","p0":{"x":108,"y":79},"p1":{"x":0.45522128005575585,"y":-0.054942502032756343},"p2":{"x":0,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"82","typeID":"TextArea","zOrder":"71","w":"272","h":"50","measuredW":"200","measuredH":"140","x":"562","y":"394","properties":{"color":"16776960"}},{"ID":"83","typeID":"Label","zOrder":"72","measuredW":"155","measuredH":"25","x":"617","y":"407","properties":{"size":"17","text":"Fundamental Topics"}},{"ID":"84","typeID":"TextArea","zOrder":"73","w":"159","h":"44","measuredW":"200","measuredH":"140","x":"322","y":"415","properties":{"color":"16770457"}},{"ID":"85","typeID":"Label","zOrder":"74","measuredW":"99","measuredH":"25","x":"351","y":"425","properties":{"size":"17","text":"Components"}},{"ID":"86","typeID":"TextArea","zOrder":"75","w":"255","h":"44","measuredW":"200","measuredH":"140","x":"932","y":"433","properties":{"color":"16770457"}},{"ID":"87","typeID":"Label","zOrder":"76","measuredW":"210","measuredH":"25","x":"954","y":"443","properties":{"size":"17","text":"Composition vs Inheritance"}},{"ID":"88","typeID":"TextArea","zOrder":"77","w":"213","h":"44","measuredW":"200","measuredH":"140","x":"73","y":"392","properties":{"color":"16770457"}},{"ID":"89","typeID":"Label","zOrder":"78","measuredW":"183","measuredH":"25","x":"89","y":"402","properties":{"size":"17","text":"Functional Components"}},{"ID":"90","typeID":"TextArea","zOrder":"79","w":"213","h":"44","measuredW":"200","measuredH":"140","x":"73","y":"442","properties":{"color":"16770457"}},{"ID":"91","typeID":"Label","zOrder":"80","measuredW":"146","measuredH":"25","x":"106","y":"452","properties":{"size":"17","text":"Class Components"}},{"ID":"92","typeID":"TextArea","zOrder":"81","w":"159","h":"44","measuredW":"200","measuredH":"140","x":"322","y":"365","properties":{"color":"16770457"}},{"ID":"93","typeID":"Label","zOrder":"82","measuredW":"30","measuredH":"25","x":"385","y":"375","properties":{"size":"17","text":"JSX"}},{"ID":"94","typeID":"TextArea","zOrder":"83","w":"159","h":"44","measuredW":"200","measuredH":"140","x":"322","y":"467","properties":{"color":"16770457"}},{"ID":"95","typeID":"Label","zOrder":"84","measuredW":"110","measuredH":"25","x":"344","y":"477","properties":{"size":"17","text":"Props vs State"}},{"ID":"96","typeID":"TextArea","zOrder":"85","w":"254","h":"42","measuredW":"200","measuredH":"140","x":"933","y":"483","properties":{"color":"16770457"}},{"ID":"97","typeID":"Label","zOrder":"86","measuredW":"96","measuredH":"25","x":"1013","y":"492","properties":{"size":"17","text":"Basic Hooks"}},{"ID":"98","typeID":"TextArea","zOrder":"87","w":"153","h":"44","measuredW":"200","measuredH":"140","x":"906","y":"551","properties":{"color":"16770457"}},{"ID":"99","typeID":"Label","zOrder":"88","measuredW":"69","measuredH":"25","x":"947","y":"561","properties":{"size":"17","text":"useState"}},{"ID":"100","typeID":"TextArea","zOrder":"89","w":"153","h":"44","measuredW":"200","measuredH":"140","x":"1066","y":"551","properties":{"color":"16770457"}},{"ID":"101","typeID":"Label","zOrder":"90","measuredW":"73","measuredH":"25","x":"1105","y":"561","properties":{"size":"17","text":"useEffect"}},{"ID":"102","typeID":"TextArea","zOrder":"91","w":"255","h":"44","measuredW":"200","measuredH":"140","x":"932","y":"384","properties":{"color":"16770457"}},{"ID":"103","typeID":"Label","zOrder":"92","measuredW":"111","measuredH":"25","x":"1002","y":"394","properties":{"size":"17","text":"Lists and Keys"}},{"ID":"104","typeID":"TextArea","zOrder":"93","w":"215","h":"44","measuredW":"200","measuredH":"140","x":"268","y":"517","properties":{"color":"16770457"}},{"ID":"105","typeID":"Label","zOrder":"94","measuredW":"173","measuredH":"25","x":"291","y":"527","properties":{"size":"17","text":"Conditional Rendering"}},{"ID":"106","typeID":"TextArea","zOrder":"95","w":"214","h":"44","measuredW":"200","measuredH":"140","x":"268","y":"315","properties":{"color":"16770457"}},{"ID":"107","typeID":"Label","zOrder":"96","measuredW":"139","measuredH":"25","x":"305","y":"325","properties":{"size":"17","text":"Create React App"}},{"ID":"108","typeID":"TextArea","zOrder":"97","w":"255","h":"44","measuredW":"200","measuredH":"140","x":"932","y":"333","properties":{"color":"16770457"}},{"ID":"109","typeID":"Label","zOrder":"98","measuredW":"170","measuredH":"25","x":"974","y":"343","properties":{"size":"17","text":"Component Life Cycle"}},{"ID":"110","typeID":"TextArea","zOrder":"99","w":"272","h":"50","measuredW":"200","measuredH":"140","x":"578","y":"609","properties":{"color":"16776960"}},{"ID":"111","typeID":"Label","zOrder":"100","measuredW":"130","measuredH":"25","x":"646","y":"622","properties":{"size":"17","text":"Advanced Topics"}},{"ID":"112","typeID":"TextArea","zOrder":"101","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"351","y":"590","properties":{"color":"16770457"}},{"ID":"113","typeID":"Label","zOrder":"102","measuredW":"49","measuredH":"25","x":"406","y":"600","properties":{"size":"17","text":"Hooks"}},{"ID":"114","typeID":"TextArea","zOrder":"103","w":"243","h":"44","measuredW":"200","measuredH":"140","x":"75","y":"569","properties":{"color":"16770457"}},{"ID":"115","typeID":"Label","zOrder":"104","measuredW":"183","measuredH":"25","x":"103","y":"579","properties":{"size":"17","text":"Writing your Own Hooks"}},{"ID":"116","typeID":"__group__","zOrder":"105","measuredW":"243","measuredH":"248","w":"243","h":"248","x":"75","y":"620","children":{"controls":{"control":[{"ID":"0","typeID":"TextArea","zOrder":"0","w":"243","h":"248","measuredW":"200","measuredH":"140","x":"0","y":"0","properties":{"color":"16777215"}},{"ID":"1","typeID":"Label","zOrder":"1","measuredW":"124","measuredH":"25","x":"59","y":"15","properties":{"bold":"true","size":"17","text":"Common Hooks"}},{"ID":"2","typeID":"TextArea","zOrder":"2","w":"93","h":"43","measuredW":"200","measuredH":"140","x":"139","y":"49","properties":{"color":"16770457"}},{"ID":"3","typeID":"Label","zOrder":"3","measuredW":"56","measuredH":"25","x":"157","y":"58","properties":{"size":"17","text":"useRef"}},{"ID":"4","typeID":"TextArea","zOrder":"4","w":"120","h":"44","measuredW":"200","measuredH":"140","x":"14","y":"48","properties":{"color":"16770457"}},{"ID":"5","typeID":"Label","zOrder":"5","measuredW":"94","measuredH":"25","x":"26","y":"58","properties":{"size":"17","text":"useCallback"}},{"ID":"6","typeID":"TextArea","zOrder":"6","w":"217","h":"44","measuredW":"200","measuredH":"140","x":"14","y":"96","properties":{"color":"16770457"}},{"ID":"7","typeID":"Label","zOrder":"7","measuredW":"77","measuredH":"25","x":"86","y":"106","properties":{"size":"17","text":"useMemo"}},{"ID":"8","typeID":"TextArea","zOrder":"8","w":"217","h":"43","measuredW":"200","measuredH":"140","x":"14","y":"145","properties":{"color":"16770457"}},{"ID":"9","typeID":"Label","zOrder":"9","measuredW":"95","measuredH":"25","x":"75","y":"154","properties":{"size":"17","text":"useReducer"}},{"ID":"10","typeID":"TextArea","zOrder":"10","w":"217","h":"43","measuredW":"200","measuredH":"140","x":"13","y":"193","properties":{"color":"16770457"}},{"ID":"11","typeID":"Label","zOrder":"11","measuredW":"88","measuredH":"25","x":"77","y":"202","properties":{"size":"17","text":"useContext"}}]}}},{"ID":"117","typeID":"TextArea","zOrder":"106","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"351","y":"639","properties":{"color":"16770457"}},{"ID":"118","typeID":"Label","zOrder":"107","measuredW":"60","measuredH":"25","x":"399","y":"649","properties":{"size":"17","text":"Context"}},{"ID":"119","typeID":"TextArea","zOrder":"108","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"351","y":"689","properties":{"color":"16770457"}},{"ID":"120","typeID":"Label","zOrder":"109","measuredW":"36","measuredH":"25","x":"411","y":"699","properties":{"size":"17","text":"Refs"}},{"ID":"121","typeID":"TextArea","zOrder":"110","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"351","y":"739","properties":{"color":"16770457"}},{"ID":"122","typeID":"Label","zOrder":"111","measuredW":"107","measuredH":"25","x":"376","y":"749","properties":{"size":"17","text":"Render Props"}},{"ID":"123","typeID":"TextArea","zOrder":"112","w":"224","h":"44","measuredW":"200","measuredH":"140","x":"942","y":"612","properties":{"color":"16770457"}},{"ID":"124","typeID":"Label","zOrder":"113","measuredW":"188","measuredH":"25","x":"960","y":"622","properties":{"size":"17","text":"High Order Components"}},{"ID":"125","typeID":"TextArea","zOrder":"114","w":"224","h":"44","measuredW":"200","measuredH":"140","x":"942","y":"662","properties":{"color":"16770457"}},{"ID":"126","typeID":"Label","zOrder":"115","measuredW":"53","measuredH":"25","x":"1027","y":"672","properties":{"size":"17","text":"Portals"}},{"ID":"127","typeID":"TextArea","zOrder":"116","w":"224","h":"44","measuredW":"200","measuredH":"140","x":"942","y":"711","properties":{"color":"16770457"}},{"ID":"128","typeID":"Label","zOrder":"117","measuredW":"132","measuredH":"25","x":"989","y":"721","properties":{"size":"17","text":"Error Boundaries"}},{"ID":"129","typeID":"TextArea","zOrder":"118","w":"224","h":"44","measuredW":"200","measuredH":"140","x":"942","y":"760","properties":{"color":"16770457"}},{"ID":"130","typeID":"Label","zOrder":"119","measuredW":"138","measuredH":"25","x":"985","y":"770","properties":{"size":"17","text":"Fiber Architecture"}},{"ID":"131","typeID":"TextArea","zOrder":"120","w":"201","h":"50","measuredW":"200","measuredH":"140","x":"534","y":"912","properties":{"color":"16776960"}},{"ID":"132","typeID":"Label","zOrder":"121","measuredW":"84","measuredH":"25","x":"590","y":"924","properties":{"size":"17","text":"Ecosystem"}},{"ID":"135","typeID":"TextArea","zOrder":"122","w":"202","h":"44","measuredW":"200","measuredH":"140","x":"780","y":"867","properties":{"color":"16767334"}},{"ID":"136","typeID":"Label","zOrder":"123","measuredW":"48","measuredH":"25","x":"857","y":"877","properties":{"size":"17","text":"Forms"}},{"ID":"137","typeID":"TextArea","zOrder":"124","w":"171","h":"44","measuredW":"200","measuredH":"140","x":"1029","y":"819","properties":{"color":"16770457"}},{"ID":"138","typeID":"Label","zOrder":"125","measuredW":"135","measuredH":"25","x":"1048","y":"829","properties":{"size":"17","text":"React Hook Form"}},{"ID":"139","typeID":"TextArea","zOrder":"126","w":"171","h":"44","measuredW":"200","measuredH":"140","x":"1029","y":"867","properties":{"color":"16770457"}},{"ID":"140","typeID":"Label","zOrder":"127","measuredW":"52","measuredH":"25","x":"1089","y":"877","properties":{"size":"17","text":"Formik"}},{"ID":"141","typeID":"TextArea","zOrder":"128","w":"171","h":"44","measuredW":"200","measuredH":"140","x":"1029","y":"915","properties":{"color":"16770457"}},{"ID":"142","typeID":"Label","zOrder":"129","measuredW":"82","measuredH":"25","x":"1075","y":"925","properties":{"size":"17","text":"Final Form"}},{"ID":"151","typeID":"TextArea","zOrder":"130","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"335","y":"911","properties":{"color":"16767334"}},{"ID":"152","typeID":"Label","zOrder":"131","measuredW":"61","measuredH":"25","x":"383","y":"921","properties":{"size":"17","text":"Routers"}},{"ID":"153","typeID":"TextArea","zOrder":"132","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"110","y":"877","properties":{"color":"16770457"}},{"ID":"154","typeID":"Label","zOrder":"133","measuredW":"104","measuredH":"25","x":"136","y":"887","properties":{"size":"17","text":"React Router"}},{"ID":"157","typeID":"TextArea","zOrder":"134","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"109","y":"927","properties":{"color":"16770457"}},{"ID":"158","typeID":"Label","zOrder":"135","measuredW":"108","measuredH":"25","x":"135","y":"937","properties":{"size":"17","text":"Reach Router"}},{"ID":"162","typeID":"TextArea","zOrder":"136","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"335","y":"1157","properties":{"color":"16767334"}},{"ID":"163","typeID":"Label","zOrder":"137","measuredW":"69","measuredH":"25","x":"378","y":"1167","properties":{"size":"17","text":"API Calls"}},{"ID":"164","typeID":"TextArea","zOrder":"138","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"110","y":"1219","properties":{"color":"16770457"}},{"ID":"165","typeID":"Label","zOrder":"139","measuredW":"41","measuredH":"25","x":"167","y":"1229","properties":{"size":"17","text":"Axios"}},{"ID":"168","typeID":"TextArea","zOrder":"140","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"109","y":"1269","properties":{"color":"16770457"}},{"ID":"169","typeID":"Label","zOrder":"141","measuredW":"61","measuredH":"25","x":"158","y":"1279","properties":{"size":"17","text":"Unfetch"}},{"ID":"173","typeID":"TextArea","zOrder":"142","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"109","y":"1318","properties":{"color":"16770457"}},{"ID":"174","typeID":"Label","zOrder":"143","measuredW":"88","measuredH":"25","x":"144","y":"1328","properties":{"size":"17","text":"superagent"}},{"ID":"178","typeID":"Label","zOrder":"144","measuredW":"25","measuredH":"117","x":"75","y":"1230","properties":{"size":"17","text":"REST API Calls","textOrientation":"up"}},{"ID":"180","typeID":"TextArea","zOrder":"145","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"335","y":"1240","properties":{"color":"16770457"}},{"ID":"181","typeID":"Label","zOrder":"146","measuredW":"64","measuredH":"25","x":"380","y":"1250","properties":{"size":"17","text":"use-http"}},{"ID":"184","typeID":"TextArea","zOrder":"147","w":"156","h":"44","measuredW":"200","measuredH":"140","x":"109","y":"1093","properties":{"color":"16770457"}},{"ID":"185","typeID":"Label","zOrder":"148","measuredW":"48","measuredH":"25","x":"164","y":"1103","properties":{"size":"17","text":"Apollo"}},{"ID":"186","typeID":"TextArea","zOrder":"149","w":"156","h":"44","measuredW":"200","measuredH":"140","x":"109","y":"1141","properties":{"color":"16770457"}},{"ID":"187","typeID":"Label","zOrder":"150","measuredW":"107","measuredH":"25","x":"134","y":"1151","properties":{"size":"17","text":"Relay Modern"}},{"ID":"193","typeID":"Label","zOrder":"151","measuredW":"25","measuredH":"71","x":"75","y":"1108","properties":{"size":"17","text":"GraphQL","textOrientation":"up"}},{"ID":"194","typeID":"TextArea","zOrder":"152","w":"202","h":"44","measuredW":"200","measuredH":"140","x":"780","y":"945","properties":{"color":"16767334"}},{"ID":"195","typeID":"Label","zOrder":"153","measuredW":"56","measuredH":"25","x":"852","y":"955","properties":{"size":"17","text":"Testing"}},{"ID":"196","typeID":"TextArea","zOrder":"154","w":"218","h":"44","measuredW":"200","measuredH":"140","x":"1029","y":"974","properties":{"color":"16770457"}},{"ID":"197","typeID":"Label","zOrder":"155","measuredW":"33","measuredH":"25","x":"1121","y":"984","properties":{"size":"17","text":"Jest"}},{"ID":"198","typeID":"TextArea","zOrder":"156","w":"218","h":"44","measuredW":"200","measuredH":"140","x":"1029","y":"1023","properties":{"color":"16770457"}},{"ID":"199","typeID":"Label","zOrder":"157","measuredW":"164","measuredH":"25","x":"1054","y":"1033","properties":{"size":"17","text":"React Testing Library"}},{"ID":"204","typeID":"TextArea","zOrder":"158","w":"218","h":"44","measuredW":"200","measuredH":"140","x":"1029","y":"1072","properties":{"color":"16770457"}},{"ID":"205","typeID":"Label","zOrder":"159","measuredW":"63","measuredH":"25","x":"1105","y":"1082","properties":{"size":"17","text":"Cypress"}},{"ID":"208","typeID":"TextArea","zOrder":"160","w":"202","h":"44","measuredW":"200","measuredH":"140","x":"787","y":"1034","properties":{"color":"16767334"}},{"ID":"209","typeID":"Label","zOrder":"161","measuredW":"148","measuredH":"25","x":"814","y":"1044","properties":{"size":"17","text":"State Management"}},{"ID":"210","typeID":"TextArea","zOrder":"162","w":"155","h":"44","measuredW":"200","measuredH":"140","x":"837","y":"1117","properties":{"color":"16770457"}},{"ID":"211","typeID":"Label","zOrder":"163","measuredW":"117","measuredH":"25","x":"854","y":"1127","properties":{"size":"17","text":"Context / State"}},{"ID":"212","typeID":"TextArea","zOrder":"164","w":"155","h":"44","measuredW":"200","measuredH":"140","x":"837","y":"1166","properties":{"color":"16770457"}},{"ID":"213","typeID":"Label","zOrder":"165","measuredW":"50","measuredH":"25","x":"890","y":"1176","properties":{"size":"17","text":"Redux"}},{"ID":"214","typeID":"TextArea","zOrder":"166","w":"155","h":"44","measuredW":"200","measuredH":"140","x":"837","y":"1214","properties":{"color":"16770457"}},{"ID":"215","typeID":"Label","zOrder":"167","measuredW":"44","measuredH":"25","x":"893","y":"1224","properties":{"size":"17","text":"MobX"}},{"ID":"223","typeID":"TextArea","zOrder":"168","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"334","y":"963","properties":{"color":"16767334"}},{"ID":"224","typeID":"Label","zOrder":"169","measuredW":"33","measuredH":"25","x":"395","y":"973","properties":{"size":"17","text":"SSR"}},{"ID":"225","typeID":"TextArea","zOrder":"170","w":"158","h":"44","measuredW":"200","measuredH":"140","x":"107","y":"984","properties":{"color":"16770457"}},{"ID":"226","typeID":"Label","zOrder":"171","measuredW":"52","measuredH":"25","x":"159","y":"994","properties":{"size":"17","text":"Next.js"}},{"ID":"229","typeID":"TextArea","zOrder":"172","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"843","y":"1277","properties":{"color":"16767334"}},{"ID":"230","typeID":"Label","zOrder":"173","measuredW":"51","measuredH":"25","x":"894","y":"1287","properties":{"size":"17","text":"Styling"}},{"ID":"231","typeID":"TextArea","zOrder":"174","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"1060","y":"1223","properties":{"color":"16770457"}},{"ID":"232","typeID":"Label","zOrder":"175","measuredW":"78","measuredH":"25","x":"1100","y":"1233","properties":{"size":"17","text":"Chakra UI"}},{"ID":"233","typeID":"TextArea","zOrder":"176","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"1060","y":"1272","properties":{"color":"16770457"}},{"ID":"234","typeID":"Label","zOrder":"177","measuredW":"86","measuredH":"25","x":"1096","y":"1282","properties":{"size":"17","text":"Material UI"}},{"ID":"241","typeID":"TextArea","zOrder":"178","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"1060","y":"1320","properties":{"color":"16770457"}},{"ID":"242","typeID":"Label","zOrder":"179","measuredW":"84","measuredH":"25","x":"1095","y":"1330","properties":{"size":"17","text":"Ant Design"}},{"ID":"246","typeID":"TextArea","zOrder":"180","w":"191","h":"44","measuredW":"200","measuredH":"140","x":"829","y":"1351","properties":{"color":"16770457"}},{"ID":"247","typeID":"Label","zOrder":"181","measuredW":"150","measuredH":"25","x":"848","y":"1361","properties":{"size":"17","text":"Styled Components"}},{"ID":"248","typeID":"TextArea","zOrder":"182","w":"191","h":"44","measuredW":"200","measuredH":"140","x":"829","y":"1400","properties":{"color":"16770457"}},{"ID":"249","typeID":"Label","zOrder":"183","measuredW":"64","measuredH":"25","x":"894","y":"1410","properties":{"size":"17","text":"Emotion"}},{"ID":"250","typeID":"TextArea","zOrder":"184","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"107","y":"1033","properties":{"color":"16770457"}},{"ID":"251","typeID":"Label","zOrder":"185","measuredW":"54","measuredH":"25","x":"158","y":"1043","properties":{"size":"17","text":"Gatsby"}},{"ID":"255","typeID":"TextArea","zOrder":"186","w":"159","h":"44","measuredW":"200","measuredH":"140","x":"334","y":"1374","properties":{"color":"16767334"}},{"ID":"256","typeID":"Label","zOrder":"187","measuredW":"52","measuredH":"25","x":"389","y":"1384","properties":{"size":"17","text":"Mobile"}},{"ID":"257","typeID":"TextArea","zOrder":"188","w":"159","h":"44","measuredW":"200","measuredH":"140","x":"126","y":"1374","properties":{"color":"16770457"}},{"ID":"258","typeID":"Label","zOrder":"189","measuredW":"100","measuredH":"25","x":"156","y":"1384","properties":{"size":"17","text":"React Native"}},{"ID":"262","typeID":"Arrow","zOrder":"190","w":"4","h":"89","measuredW":"150","measuredH":"100","x":"670","y":"1557","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"length":3,"x":3,"y":0},"p1":{"length":0.5327426604018495,"x":0.5326751848090503,"y":0.008478779433645868},"p2":{"length":88,"x":0,"y":88},"rightArrow":"false"}},{"ID":"269","typeID":"TextArea","zOrder":"191","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"334","y":"1014","properties":{"color":"16767334"}},{"ID":"270","typeID":"Label","zOrder":"192","measuredW":"34","measuredH":"25","x":"395","y":"1024","properties":{"size":"17","text":"SSG"}},{"ID":"271","typeID":"TextArea","zOrder":"193","w":"157","h":"44","measuredW":"200","measuredH":"140","x":"334","y":"1082","properties":{"color":"16770457"}},{"ID":"272","typeID":"Label","zOrder":"194","measuredW":"90","measuredH":"25","x":"368","y":"1091","properties":{"size":"17","text":"react-query"}},{"ID":"277","typeID":"Arrow","zOrder":"3","w":"2","h":"96","measuredW":"150","measuredH":"100","x":"411","y":"1091","properties":{"color":"2848996","curvature":"0","direction":"bottom","leftArrow":"false","p0":{"length":95,"x":0,"y":95},"p1":{"length":0.4737749079645269,"x":0.4737425216042544,"y":-0.005539552404165743},"p2":{"length":1,"x":1,"y":0},"rightArrow":"false","stroke":"dotted"}},{"ID":"281","typeID":"Canvas","zOrder":"195","w":"542","h":"96","measuredW":"100","measuredH":"70","x":"295","y":"108"},{"ID":"284","typeID":"Arrow","zOrder":"2","w":"27","measuredW":"150","measuredH":"100","x":"638","y":"27","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","stroke":"dotted","p0":{"x":20.66666666666663,"y":-0.33333333333333215},"p1":{"x":0.4525527916281198,"y":0.13367847141227748},"p2":{"x":-0.019880609337405986,"y":99.62109147224172}}},{"ID":"286","typeID":"Arrow","zOrder":"0","w":"24","h":"77","measuredW":"150","measuredH":"100","x":"618","y":"183","properties":{"curvature":"0","leftArrow":"false","rightArrow":"false","color":"10027263","p0":{"x":10,"y":-0.3333333333333428},"p1":{"x":0.5175865027166142,"y":-0.21132399199313673},"p2":{"x":24.66666666666663,"y":77}}},{"ID":"287","typeID":"Label","zOrder":"1","measuredW":"76","measuredH":"36","x":"647","y":"267","properties":{"size":"28","text":"React"}},{"ID":"288","typeID":"Canvas","zOrder":"198","w":"576","h":"105","measuredW":"100","measuredH":"70","x":"351","y":"1487"},{"ID":"290","typeID":"Label","zOrder":"196","measuredW":"475","measuredH":"32","x":"329","y":"126","properties":{"size":"24","text":"Frontend Roadmap till Framework Selection"}},{"ID":"291","typeID":"Label","zOrder":"197","measuredW":"171","measuredH":"26","x":"496","y":"162","properties":{"size":"18","text":"roadmap.sh/frontend","color":"10027263"}},{"ID":"292","typeID":"Label","zOrder":"199","measuredW":"502","measuredH":"32","x":"391","y":"1509","properties":{"size":"24","text":"Frontend Roadmap after Framework Selection"}},{"ID":"293","typeID":"Label","zOrder":"200","measuredW":"171","measuredH":"26","x":"556","y":"1545","properties":{"text":"roadmap.sh/frontend","size":"18","color":"10027263"}}]},"attributes":{"name":"New Wireframe 2","order":1000010.3738670473,"parentID":null,"notes":null},"branchID":"Master","resourceID":"D99BBD4B-2F60-48E7-8996-D075F997D617","mockupH":"1619","mockupW":"1174","measuredW":"1247","measuredH":"1646","version":"1.0"}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/react/resources.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/react/resources.json new file mode 100644 index 000000000..18dc7e1f4 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/react/resources.json @@ -0,0 +1 @@ +{"pageProps":{"roadmap":{"seo":{"title":"React Developer Roadmap: Learn to become a React developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a react developer","react developer roadmap","react roadmap","become react developer","react developer skills","react skills test","skills for react development","learn react development","what is react","react quiz","react interview questions"]},"title":"React Developer","description":"Everything that is there to learn about React and the ecosystem in 2021.","featuredTitle":"React","featuredDescription":"Step by step guide to become a React Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/103-react/landscape.md","resourcesPath":"/roadmaps/103-react/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/react-roadmap","id":"react","metaPath":"/roadmaps/103-react/meta.json","isUpcoming":false}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/roadmaps.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/roadmaps.json new file mode 100644 index 000000000..a3bca8f31 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/roadmaps.json @@ -0,0 +1 @@ +{"pageProps":{"roadmaps":[{"seo":{"title":"Learn to become a modern frontend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern frontend development. Learn to become a modern frontend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a frontend developer","frontend developer","frontend engineer","frontend skills","frontend development","javascript developer","frontend development skills","frontend development skills test","frontend engineer roadmap","frontend developer roadmap","become a frontend developer","frontend developer career path","javascript developer","modern javascript developer","node developer","skills for frontend development","learn frontend development","what is frontend development","frontend developer quiz","frontend developer interview questions"]},"title":"Frontend Developer","description":"Step by step guide to becoming a modern frontend developer in 2021","featuredTitle":"Frontend","featuredDescription":"Step by step guide to becoming a frontend developer in 2021","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"featured":true,"imagePath":"/roadmaps/frontend.png","resourcesPath":"/roadmaps/100-frontend/resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/frontend-roadmap","id":"frontend","metaPath":"/roadmaps/100-frontend/meta.json","isUpcoming":false},{"seo":{"title":"Learn to become a modern backend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern backend development. Learn to become a modern backend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a backend developer","backend developer","backend engineer","backend skills","backend development","javascript developer","backend development skills","backend development skills test","backend engineer roadmap","backend developer roadmap","become a backend developer","backend developer career path","javascript developer","modern javascript developer","node developer","skills for backend development","learn backend development","what is backend development","backend developer quiz","backend developer interview questions"]},"title":"Backend Developer","description":"Step by step guide to becoming a modern backend developer in 2021","featuredTitle":"Backend","featuredDescription":"Step by step guide to becoming a backend developer in 2021","featured":true,"imagePath":"/roadmaps/backend.png","resourcesPath":"/roadmaps/101-backend/resources.md","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/backend-roadmap","id":"backend","metaPath":"/roadmaps/101-backend/meta.json","isUpcoming":false},{"seo":{"title":"DevOps Roadmap: Learn to become a DevOps Engineer or SRE","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a devops enginer","devops roadmap","sre roadmap","site reliability engineer roadmap","operations roles","become devops","devops skills","modern devops skills","devops skills test","skills for devops","learn devops","what is devops","what is sre","devops quiz","devops interview questions"]},"title":"DevOps Roadmap","description":"Step by step guide for DevOps, SRE or any other Operations Role in 2021","featuredTitle":"DevOps","featuredDescription":"Step by step guide for DevOps or operations role in 2021","featured":true,"imagePath":"/roadmaps/devops.png","resourcesPath":"/roadmaps/102-devops/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/devops-roadmap","id":"devops","metaPath":"/roadmaps/102-devops/meta.json","isUpcoming":false},{"seo":{"title":"React Developer Roadmap: Learn to become a React developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a react developer","react developer roadmap","react roadmap","become react developer","react developer skills","react skills test","skills for react development","learn react development","what is react","react quiz","react interview questions"]},"title":"React Developer","description":"Everything that is there to learn about React and the ecosystem in 2021.","featuredTitle":"React","featuredDescription":"Step by step guide to become a React Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/103-react/landscape.md","resourcesPath":"/roadmaps/103-react/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/react-roadmap","id":"react","metaPath":"/roadmaps/103-react/meta.json","isUpcoming":false},{"seo":{"title":"Angular Developer Roadmap: Learn to become a Angular developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for angular development. Learn to become a modern Angular developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a angular developer","angular developer roadmap","angular roadmap","become angular developer","angular developer skills","angular skills test","skills for angular development","learn angular development","what is angular","angular quiz","angular interview questions"]},"title":"Angular Developer","description":"Everything that is there to learn about Angular and the ecosystem in 2021.","featuredTitle":"Angular","featuredDescription":"Step by step guide to become a Angular Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/104-angular/landscape.md","resourcesPath":"/roadmaps/104-angular/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/angular-roadmap","id":"angular","metaPath":"/roadmaps/104-angular/meta.json","isUpcoming":false},{"seo":{"title":"Android Developer Roadmap: Learn to become an Android developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for android development. Learn to become a modern Android developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an android developer","android developer roadmap","android roadmap","become android developer","android developer skills","android skills test","skills for android development","learn android development","what is android","android quiz","android interview questions"]},"title":"Android Developer","description":"Step by step guide to becoming an Android developer in 2021","featuredTitle":"Android","featuredDescription":"Step by step guide to becoming an Android Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/105-android/landscape.md","resourcesPath":"/roadmaps/105-android/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"android","metaPath":"/roadmaps/105-android/meta.json","isUpcoming":false},{"seo":{"title":"Learn to become a modern Python developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for python development. Learn to become a modern Python developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an python developer","python developer roadmap","python roadmap","become python developer","python developer skills","python skills test","skills for python development","learn python development","what is python","python quiz","python interview questions"]},"title":"Python Developer","description":"Step by step guide to becoming a Python developer in 2021","featuredTitle":"Python","featuredDescription":"Step by step guide to becoming a Python Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"resourcesPath":"/roadmaps/106-python/resources.md","contentPath":"/roadmaps/106-python/landscape.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/python-roadmap","versions":["latest"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"python","metaPath":"/roadmaps/106-python/meta.json","isUpcoming":false},{"seo":{"title":"Learn to become a Go developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a golang developer","guide to becoming a go developer","golang developer","go developer","guide to golang","guide to go","golang roadmap","go roadmap","golang skills","go skills","golang skills test","go skills test","skills for golang","skills for go","cloud development","what is golang","what is go","golang quiz","go quiz","golang interview questions","go interview questions"]},"title":"Go Developer","description":"Step by step guide to becoming a Go developer in 2021","featuredTitle":"Go","featuredDescription":"Step by step guide to becoming a Go developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"/roadmaps/107-golang/landscape.md","resourcesPath":"/roadmaps/107-golang/resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/go-roadmap","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"golang","metaPath":"/roadmaps/107-golang/meta.json"},{"seo":{"title":"Learn to become a modern Java developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a java developer","java developer","java engineer","java skills","guide to java","java roadmap","java skills","java skills test","skills for java","cloud development","what is java","java quiz","java interview questions","java engineer roadmap","java developer roadmap","become a java developer","java developer career path","java developer","modern java developer"]},"title":"Java Developer","description":"Step by step guide to becoming a Java developer in 2021","featuredTitle":"Java","featuredDescription":"Step by step guide to becoming a Java Developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"/roadmaps/108-java/landscape.md","resourcesPath":"/roadmaps/108-java/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/java-roadmap","id":"java","metaPath":"/roadmaps/108-java/meta.json"},{"seo":{"title":"DBA Roadmap: Learn to become a database administrator with PostgreSQL","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a database administrator","guide to becoming a DBA","dba roadmap","db administrator roadmap","database administrator roadmap","postgresql roadmap","dba skills","db administrator skills","become dba","postgresql skills","modern dba skills","dba skills test","skills for dba","skills for database administrator","learn dba","what is dba","database administrator quiz","dba interview questions"]},"title":"PostgreSQL DBA","description":"Step by step guide to becoming a modern PostgreSQL DB Administrator in 2021","featuredTitle":"DBA","featuredDescription":"Step by step guide to become a PostgreSQL DBA in 2021","contentPath":"/roadmaps/109-postgresql-dba/landscape.md","resourcesPath":"/roadmaps/109-postgresql-dba/resources.md","author":{"name":"Alexey Lesovsky","url":"https://github.com/lesovsky"},"isCommunity":false,"isTextHeavy":true,"featured":true,"detailed":false,"versions":[],"id":"postgresql-dba","metaPath":"/roadmaps/109-postgresql-dba/meta.json","isUpcoming":false},{"seo":{"title":"AWS Roadmap: Learn to use AWS","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to aws","aws roadmap","aws skills","aws skills test","skills for aws","cloud development","what is aws","aws quiz","aws interview questions"]},"title":"AWS","description":"Everything that is there to learn about AWS and the ecosystem in 2021.","featuredTitle":"AWS","featuredDescription":"Step by step guide to learn AWS in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":true,"featured":true,"contentPath":"/roadmaps/110-aws/landscape.md","resourcesPath":"/roadmaps/110-aws/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"aws","metaPath":"/roadmaps/110-aws/meta.json"},{"seo":{"title":"QA Roadmap: Learn to become a modern QA engineer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern QA development. Learn to become a modern QA engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a QA engineer","QA engineer","QA skills","QA development skills","QA development skills test","QA engineer roadmap","become a QA engineer","QA engineer career path","skills for QA development","what is QA engineer","QA engineer quiz","QA engineer interview questions"]},"title":"QA Engineer","description":"Steps to follow in order to become a modern QA Engineer in 2021","featuredTitle":"QA","featuredDescription":"Step by step guide to becoming a modern QA Engineer in 2021","isUpcoming":true,"featured":true,"contentPath":"/roadmaps/111-qa/landscape.md","resourcesPath":"/roadmaps/111-qa/resources.md","author":{"name":"Anas Fitiani","url":"https://github.com/anas-qa"},"id":"qa","metaPath":"/roadmaps/111-qa/meta.json"}]},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch.json new file mode 100644 index 000000000..44f5e0bd0 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch.json @@ -0,0 +1 @@ +{"pageProps":{"videos":[{"id":"what-is-eventual-consistency","title":"What is Eventual Consistency?","description":"Learn about the different consistency models in distributed systems","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=rpqsSkTIdAw","authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2021-11-30T19:59:14.191Z","createdAt":"2021-11-30T19:59:14.191Z","formattedCreatedAt":"November 30, 2021","formattedUpdatedAt":"November 30, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"ssh-ssl-tls","title":"SSH vs TLS vs SSL","description":"Learn the difference between SSH, TLS and SSL","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=k3rFFLmQCuY","authorUsername":"kamranahmedse","duration":"3 minutes","updatedAt":"2021-11-25T19:59:14.191Z","createdAt":"2021-11-25T19:59:14.191Z","formattedCreatedAt":"November 25, 2021","formattedUpdatedAt":"November 25, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"async-javascript","title":"Asynchronous JavaScript","description":"Learn how to write asynchronous JavaScript using Async/Await","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=VyIK6SV5f7o","authorUsername":"kamranahmedse","duration":"15 minutes","updatedAt":"2021-11-14T19:59:14.191Z","createdAt":"2021-11-14T19:59:14.191Z","formattedCreatedAt":"November 14, 2021","formattedUpdatedAt":"November 14, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"random-number-generators","title":"Random Number Generators","description":"How do random number generators work?","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=nDv3yXdD0rk","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-11-03T19:59:14.191Z","createdAt":"2021-11-03T19:59:14.191Z","formattedCreatedAt":"November 3, 2021","formattedUpdatedAt":"November 3, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"big-o-notation","title":"Big O Notation","description":"Learn what the Big-O notation is and how to calculate the time complexity of an algorithm.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=Z0bH0cMY0E8","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-10-25T19:59:14.191Z","createdAt":"2021-10-25T19:59:14.191Z","formattedCreatedAt":"October 25, 2021","formattedUpdatedAt":"October 25, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"yaml-in-depth","title":"YAML in Depth","description":"Everything you need to know about YAML","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=ImHSpwUlNVc","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-10-18T19:59:14.191Z","createdAt":"2021-10-18T19:59:14.191Z","formattedCreatedAt":"October 18, 2021","formattedUpdatedAt":"October 18, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"floating-point-arithmetic","title":"Floating Point Arithmetic","description":"Learn how ow the arithmetic operations work on floating-point numbers and why the results might be different from what you may expect.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=RIiq4tTt6rI","authorUsername":"kamranahmedse","duration":"4 minutes","updatedAt":"2021-10-10T19:59:14.191Z","createdAt":"2021-10-10T19:59:14.191Z","formattedCreatedAt":"October 10, 2021","formattedUpdatedAt":"October 10, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"what-is-cap-theorem","title":"What is CAP Theorem?","description":"An illustrated explanation to CAP theorem with examples and proof.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=_RbsFXWRZ10","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-10-05T19:59:14.191Z","createdAt":"2021-10-05T19:59:14.191Z","formattedCreatedAt":"October 5, 2021","formattedUpdatedAt":"October 5, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"acid-explained","title":"ACID Explained","description":"Learn what it means for a database to be ACID compliant with examples.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=yaQ5YMWkxq4","authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2021-09-26T19:59:14.191Z","createdAt":"2021-09-26T19:59:14.191Z","formattedCreatedAt":"September 26, 2021","formattedUpdatedAt":"September 26, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"transport-protocols-tcp-vs-udp","title":"Transport Protocols: TCP vs UDP","description":"Learn about the Transport Layer of the TCP/IP model and different transport protocols.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=37AFBZv4_6Y","authorUsername":"kamranahmedse","duration":"10 minutes","updatedAt":"2020-11-21T19:59:14.191Z","createdAt":"2020-11-21T19:59:14.191Z","formattedCreatedAt":"November 21, 2020","formattedUpdatedAt":"November 21, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"tcp-ip-model","title":"TCP/IP Model Explained","description":"Learn what is TCP/IP Model and the different layers involved.","isPro":false,"authorUsername":"kamranahmedse","youtubeLink":"https://www.youtube.com/watch?v=F5rni9fr1yE","duration":"5 minutes","updatedAt":"2020-11-06T19:59:14.191Z","createdAt":"2020-11-06T19:59:14.191Z","formattedCreatedAt":"November 6, 2020","formattedUpdatedAt":"November 6, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"osi-model","title":"OSI Model Explained","description":"Learn what is OSI Model and the different layers involved.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=dV8mjZd1OtU","authorUsername":"kamranahmedse","duration":"7 minutes","updatedAt":"2020-10-24T19:59:14.191Z","createdAt":"2020-10-24T19:59:14.191Z","formattedCreatedAt":"October 24, 2020","formattedUpdatedAt":"October 24, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"freeze-and-seal-objects-in-javascript","title":"Freeze and Seal in JavaScript","description":"Learn what is OSI Model and the different layers involved.","youtubeLink":"https://www.youtube.com/watch?v=O3uT2l6vgZ8","isPro":false,"authorUsername":"kamranahmedse","duration":"6 minutes","updatedAt":"2020-10-16T19:59:14.191Z","createdAt":"2020-10-16T19:59:14.191Z","formattedCreatedAt":"October 16, 2020","formattedUpdatedAt":"October 16, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"all-about-http-caching","title":"All about HTTP Caching","description":"Learn what is HTTP caching, places for caching and different caching headers.","youtubeLink":"https://www.youtube.com/watch?v=HiBDZgTNpXY","isPro":false,"authorUsername":"kamranahmedse","duration":"13 minutes","updatedAt":"2020-10-04T19:59:14.191Z","createdAt":"2020-10-04T19:59:14.191Z","formattedCreatedAt":"October 4, 2020","formattedUpdatedAt":"October 4, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"content-delivery-networks","title":"Content Delivery Networks","description":"Learn what the CDNs are and the difference between push CDN vs pull CDN.","youtubeLink":"https://www.youtube.com/watch?v=6DXEPcXKQNY","isPro":false,"authorUsername":"kamranahmedse","duration":"4 minutes","updatedAt":"2020-09-26T19:59:14.191Z","createdAt":"2020-09-26T19:59:14.191Z","formattedCreatedAt":"September 26, 2020","formattedUpdatedAt":"September 26, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"load-balancers-101","title":"Load Balancers 101","description":"Learn the basics of load balancers, types and different algorithms.","youtubeLink":"https://www.youtube.com/watch?v=galcDRNd5Ow","isPro":false,"authorUsername":"kamranahmedse","duration":"9 minutes","updatedAt":"2020-09-18T19:59:14.191Z","createdAt":"2020-09-18T19:59:14.191Z","formattedCreatedAt":"September 18, 2020","formattedUpdatedAt":"September 18, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"dns-records","title":"DNS Records","description":"Learn what the DNS is and how a website is found on the internet.","youtubeLink":"https://www.youtube.com/watch?v=7lxgpKh_fRY","isPro":false,"authorUsername":"kamranahmedse","duration":"6 minutes","updatedAt":"2020-08-31T19:59:14.191Z","createdAt":"2020-08-31T19:59:14.191Z","formattedCreatedAt":"August 31, 2020","formattedUpdatedAt":"August 31, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"dns-explained","title":"DNS and how does it work?","description":"Learn what the DNS is and how a website is found on the internet.","youtubeLink":"https://www.youtube.com/watch?v=Wj0od2ag5sk","isPro":false,"authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2020-08-17T19:59:14.191Z","createdAt":"2020-08-17T19:59:14.191Z","formattedCreatedAt":"August 17, 2020","formattedUpdatedAt":"August 17, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"system-design-101","title":"System Design 101","description":"Learn about all the bits and pieces of system design.","youtubeLink":"https://www.youtube.com/watch?v=Y-Gl4HEyeUQ","isPro":false,"authorUsername":"kamranahmedse","duration":"7 minutes","updatedAt":"2020-08-08T19:59:14.191Z","createdAt":"2020-08-08T19:59:14.191Z","formattedCreatedAt":"August 8, 2020","formattedUpdatedAt":"August 8, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"javascript-fetch-api","title":"JavaScript Fetch API","description":"Learn how to use JavaScript's Fetch API to interact with remote API.","youtubeLink":"https://www.youtube.com/watch?v=-ZI0ea5O2oA","isPro":false,"authorUsername":"kamranahmedse","duration":"3 minutes","updatedAt":"2020-08-02T19:59:14.191Z","createdAt":"2020-08-02T19:59:14.191Z","formattedCreatedAt":"August 2, 2020","formattedUpdatedAt":"August 2, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"scaling-the-unscalable","title":"Scaling the Unscalable","description":"Learn the basics of System Design and understand how to build a scalable application.","youtubeLink":"https://www.youtube.com/watch?v=a2rcgzludDU","isPro":false,"authorUsername":"kamranahmedse","duration":"10 minutes","updatedAt":"2020-07-26T19:59:14.191Z","createdAt":"2020-07-26T19:59:14.191Z","formattedCreatedAt":"July 26, 2020","formattedUpdatedAt":"July 26, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"promises-in-javascript","title":"All about Promises in JavaScript","youtubeLink":"https://www.youtube.com/watch?v=BvrkobaCVVE","description":"Learn how to write asynchronous code in JavaScript using promises.","isPro":false,"authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2020-07-20T19:59:14.191Z","createdAt":"2020-07-20T19:59:14.191Z","formattedCreatedAt":"July 20, 2020","formattedUpdatedAt":"July 20, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"what-is-dom-shadow-dom-virtual-dom","title":"DOM, Shadow DOM, Virtual DOM","description":"Learn what is DOM, Shadow DOM and Virtual DOM and how they work.","youtubeLink":"https://www.youtube.com/watch?v=7Tok22qxPzQ","isPro":false,"authorUsername":"kamranahmedse","duration":"6 minutes","updatedAt":"2020-07-20T19:59:14.191Z","createdAt":"2020-07-20T19:59:14.191Z","formattedCreatedAt":"July 20, 2020","formattedUpdatedAt":"July 20, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"how-to-use-github-actions","title":"Automate with GitHub Actions","description":"Learn how to implement CI/CD with GitHub Actions","youtubeLink":"https://www.youtube.com/watch?v=nyKZTKQS_EQ","isPro":false,"authorUsername":"kamranahmedse","duration":"6 minutes","updatedAt":"2020-07-13T19:59:14.191Z","createdAt":"2020-07-13T19:59:14.191Z","formattedCreatedAt":"July 13, 2020","formattedUpdatedAt":"July 13, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"practical-intro-to-react","title":"Practical Introduction to React","description":"Learn how to create a React Application with practical example.","youtubeLink":"https://www.youtube.com/watch?v=NyG7YJWJd6s&list=PLkZYeFmDuaN3NDLnBG01-sH2-nwn43mYu","isPro":false,"authorUsername":"kamranahmedse","duration":"40 minutes","updatedAt":"2020-07-09T19:59:14.191Z","createdAt":"2020-07-09T19:59:14.191Z","formattedCreatedAt":"July 9, 2020","formattedUpdatedAt":"July 9, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"what-is-dependency-injection","title":"What is Dependency Injection?","description":"Learn what is dependency injection and how to write better code with the help of it.","youtubeLink":"https://www.youtube.com/watch?v=0yc2UANSDiw","isPro":false,"authorUsername":"kamranahmedse","duration":"3 minutes","updatedAt":"2020-07-04T19:59:14.191Z","createdAt":"2020-07-04T19:59:14.191Z","formattedCreatedAt":"July 4, 2020","formattedUpdatedAt":"July 4, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"how-to-use-css-variables","title":"How to use CSS Variables?","description":"Learn how to write scalable CSS using CSS Variables.","youtubeLink":"https://www.youtube.com/watch?v=lgaxU7CRmxU","isPro":false,"authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2020-07-03T19:59:14.191Z","createdAt":"2020-07-03T19:59:14.191Z","formattedCreatedAt":"July 3, 2020","formattedUpdatedAt":"July 3, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}},{"id":"arrays-and-objects-in-javascript","title":"Arrays and Objects in JavaScript","description":"Learn how to manipulate arrays and objects in JavaScript.","youtubeLink":"https://www.youtube.com/watch?v=n3NKGsM3iEw","isPro":false,"authorUsername":"kamranahmedse","duration":"12 minutes","updatedAt":"2020-05-09T19:59:14.191Z","createdAt":"2020-05-09T19:59:14.191Z","formattedCreatedAt":"May 9, 2020","formattedUpdatedAt":"May 9, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}]},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/acid-explained.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/acid-explained.json new file mode 100644 index 000000000..d4f1c2bc9 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/acid-explained.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"acid-explained","title":"ACID Explained","description":"Learn what it means for a database to be ACID compliant with examples.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=yaQ5YMWkxq4","authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2021-09-26T19:59:14.191Z","createdAt":"2021-09-26T19:59:14.191Z","formattedCreatedAt":"September 26, 2021","formattedUpdatedAt":"September 26, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/all-about-http-caching.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/all-about-http-caching.json new file mode 100644 index 000000000..8e2725cf9 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/all-about-http-caching.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"all-about-http-caching","title":"All about HTTP Caching","description":"Learn what is HTTP caching, places for caching and different caching headers.","youtubeLink":"https://www.youtube.com/watch?v=HiBDZgTNpXY","isPro":false,"authorUsername":"kamranahmedse","duration":"13 minutes","updatedAt":"2020-10-04T19:59:14.191Z","createdAt":"2020-10-04T19:59:14.191Z","formattedCreatedAt":"October 4, 2020","formattedUpdatedAt":"October 4, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/arrays-and-objects-in-javascript.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/arrays-and-objects-in-javascript.json new file mode 100644 index 000000000..027bea57c --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/arrays-and-objects-in-javascript.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"arrays-and-objects-in-javascript","title":"Arrays and Objects in JavaScript","description":"Learn how to manipulate arrays and objects in JavaScript.","youtubeLink":"https://www.youtube.com/watch?v=n3NKGsM3iEw","isPro":false,"authorUsername":"kamranahmedse","duration":"12 minutes","updatedAt":"2020-05-09T19:59:14.191Z","createdAt":"2020-05-09T19:59:14.191Z","formattedCreatedAt":"May 9, 2020","formattedUpdatedAt":"May 9, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/async-javascript.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/async-javascript.json new file mode 100644 index 000000000..3485c59ab --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/async-javascript.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"async-javascript","title":"Asynchronous JavaScript","description":"Learn how to write asynchronous JavaScript using Async/Await","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=VyIK6SV5f7o","authorUsername":"kamranahmedse","duration":"15 minutes","updatedAt":"2021-11-14T19:59:14.191Z","createdAt":"2021-11-14T19:59:14.191Z","formattedCreatedAt":"November 14, 2021","formattedUpdatedAt":"November 14, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/big-o-notation.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/big-o-notation.json new file mode 100644 index 000000000..4cbd0648c --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/big-o-notation.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"big-o-notation","title":"Big O Notation","description":"Learn what the Big-O notation is and how to calculate the time complexity of an algorithm.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=Z0bH0cMY0E8","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-10-25T19:59:14.191Z","createdAt":"2021-10-25T19:59:14.191Z","formattedCreatedAt":"October 25, 2021","formattedUpdatedAt":"October 25, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/content-delivery-networks.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/content-delivery-networks.json new file mode 100644 index 000000000..734582505 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/content-delivery-networks.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"content-delivery-networks","title":"Content Delivery Networks","description":"Learn what the CDNs are and the difference between push CDN vs pull CDN.","youtubeLink":"https://www.youtube.com/watch?v=6DXEPcXKQNY","isPro":false,"authorUsername":"kamranahmedse","duration":"4 minutes","updatedAt":"2020-09-26T19:59:14.191Z","createdAt":"2020-09-26T19:59:14.191Z","formattedCreatedAt":"September 26, 2020","formattedUpdatedAt":"September 26, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/dns-explained.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/dns-explained.json new file mode 100644 index 000000000..c07f37a5a --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/dns-explained.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"dns-explained","title":"DNS and how does it work?","description":"Learn what the DNS is and how a website is found on the internet.","youtubeLink":"https://www.youtube.com/watch?v=Wj0od2ag5sk","isPro":false,"authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2020-08-17T19:59:14.191Z","createdAt":"2020-08-17T19:59:14.191Z","formattedCreatedAt":"August 17, 2020","formattedUpdatedAt":"August 17, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/dns-records.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/dns-records.json new file mode 100644 index 000000000..cd921b0b4 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/dns-records.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"dns-records","title":"DNS Records","description":"Learn what the DNS is and how a website is found on the internet.","youtubeLink":"https://www.youtube.com/watch?v=7lxgpKh_fRY","isPro":false,"authorUsername":"kamranahmedse","duration":"6 minutes","updatedAt":"2020-08-31T19:59:14.191Z","createdAt":"2020-08-31T19:59:14.191Z","formattedCreatedAt":"August 31, 2020","formattedUpdatedAt":"August 31, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/floating-point-arithmetic.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/floating-point-arithmetic.json new file mode 100644 index 000000000..7aa012deb --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/floating-point-arithmetic.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"floating-point-arithmetic","title":"Floating Point Arithmetic","description":"Learn how ow the arithmetic operations work on floating-point numbers and why the results might be different from what you may expect.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=RIiq4tTt6rI","authorUsername":"kamranahmedse","duration":"4 minutes","updatedAt":"2021-10-10T19:59:14.191Z","createdAt":"2021-10-10T19:59:14.191Z","formattedCreatedAt":"October 10, 2021","formattedUpdatedAt":"October 10, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/freeze-and-seal-objects-in-javascript.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/freeze-and-seal-objects-in-javascript.json new file mode 100644 index 000000000..7e950ae2a --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/freeze-and-seal-objects-in-javascript.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"freeze-and-seal-objects-in-javascript","title":"Freeze and Seal in JavaScript","description":"Learn what is OSI Model and the different layers involved.","youtubeLink":"https://www.youtube.com/watch?v=O3uT2l6vgZ8","isPro":false,"authorUsername":"kamranahmedse","duration":"6 minutes","updatedAt":"2020-10-16T19:59:14.191Z","createdAt":"2020-10-16T19:59:14.191Z","formattedCreatedAt":"October 16, 2020","formattedUpdatedAt":"October 16, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/how-to-use-css-variables.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/how-to-use-css-variables.json new file mode 100644 index 000000000..eabd9ecb1 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/how-to-use-css-variables.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"how-to-use-css-variables","title":"How to use CSS Variables?","description":"Learn how to write scalable CSS using CSS Variables.","youtubeLink":"https://www.youtube.com/watch?v=lgaxU7CRmxU","isPro":false,"authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2020-07-03T19:59:14.191Z","createdAt":"2020-07-03T19:59:14.191Z","formattedCreatedAt":"July 3, 2020","formattedUpdatedAt":"July 3, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/how-to-use-github-actions.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/how-to-use-github-actions.json new file mode 100644 index 000000000..e2d4cad9f --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/how-to-use-github-actions.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"how-to-use-github-actions","title":"Automate with GitHub Actions","description":"Learn how to implement CI/CD with GitHub Actions","youtubeLink":"https://www.youtube.com/watch?v=nyKZTKQS_EQ","isPro":false,"authorUsername":"kamranahmedse","duration":"6 minutes","updatedAt":"2020-07-13T19:59:14.191Z","createdAt":"2020-07-13T19:59:14.191Z","formattedCreatedAt":"July 13, 2020","formattedUpdatedAt":"July 13, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/javascript-fetch-api.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/javascript-fetch-api.json new file mode 100644 index 000000000..1e8a7dbed --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/javascript-fetch-api.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"javascript-fetch-api","title":"JavaScript Fetch API","description":"Learn how to use JavaScript's Fetch API to interact with remote API.","youtubeLink":"https://www.youtube.com/watch?v=-ZI0ea5O2oA","isPro":false,"authorUsername":"kamranahmedse","duration":"3 minutes","updatedAt":"2020-08-02T19:59:14.191Z","createdAt":"2020-08-02T19:59:14.191Z","formattedCreatedAt":"August 2, 2020","formattedUpdatedAt":"August 2, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/load-balancers-101.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/load-balancers-101.json new file mode 100644 index 000000000..b11183601 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/load-balancers-101.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"load-balancers-101","title":"Load Balancers 101","description":"Learn the basics of load balancers, types and different algorithms.","youtubeLink":"https://www.youtube.com/watch?v=galcDRNd5Ow","isPro":false,"authorUsername":"kamranahmedse","duration":"9 minutes","updatedAt":"2020-09-18T19:59:14.191Z","createdAt":"2020-09-18T19:59:14.191Z","formattedCreatedAt":"September 18, 2020","formattedUpdatedAt":"September 18, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/osi-model.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/osi-model.json new file mode 100644 index 000000000..fcd860acd --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/osi-model.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"osi-model","title":"OSI Model Explained","description":"Learn what is OSI Model and the different layers involved.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=dV8mjZd1OtU","authorUsername":"kamranahmedse","duration":"7 minutes","updatedAt":"2020-10-24T19:59:14.191Z","createdAt":"2020-10-24T19:59:14.191Z","formattedCreatedAt":"October 24, 2020","formattedUpdatedAt":"October 24, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/practical-intro-to-react.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/practical-intro-to-react.json new file mode 100644 index 000000000..018b26b9e --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/practical-intro-to-react.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"practical-intro-to-react","title":"Practical Introduction to React","description":"Learn how to create a React Application with practical example.","youtubeLink":"https://www.youtube.com/watch?v=NyG7YJWJd6s&list=PLkZYeFmDuaN3NDLnBG01-sH2-nwn43mYu","isPro":false,"authorUsername":"kamranahmedse","duration":"40 minutes","updatedAt":"2020-07-09T19:59:14.191Z","createdAt":"2020-07-09T19:59:14.191Z","formattedCreatedAt":"July 9, 2020","formattedUpdatedAt":"July 9, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/promises-in-javascript.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/promises-in-javascript.json new file mode 100644 index 000000000..4bf201040 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/promises-in-javascript.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"promises-in-javascript","title":"All about Promises in JavaScript","youtubeLink":"https://www.youtube.com/watch?v=BvrkobaCVVE","description":"Learn how to write asynchronous code in JavaScript using promises.","isPro":false,"authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2020-07-20T19:59:14.191Z","createdAt":"2020-07-20T19:59:14.191Z","formattedCreatedAt":"July 20, 2020","formattedUpdatedAt":"July 20, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/random-number-generators.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/random-number-generators.json new file mode 100644 index 000000000..1689cc6c2 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/random-number-generators.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"random-number-generators","title":"Random Number Generators","description":"How do random number generators work?","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=nDv3yXdD0rk","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-11-03T19:59:14.191Z","createdAt":"2021-11-03T19:59:14.191Z","formattedCreatedAt":"November 3, 2021","formattedUpdatedAt":"November 3, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/scaling-the-unscalable.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/scaling-the-unscalable.json new file mode 100644 index 000000000..dfce4ed6b --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/scaling-the-unscalable.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"scaling-the-unscalable","title":"Scaling the Unscalable","description":"Learn the basics of System Design and understand how to build a scalable application.","youtubeLink":"https://www.youtube.com/watch?v=a2rcgzludDU","isPro":false,"authorUsername":"kamranahmedse","duration":"10 minutes","updatedAt":"2020-07-26T19:59:14.191Z","createdAt":"2020-07-26T19:59:14.191Z","formattedCreatedAt":"July 26, 2020","formattedUpdatedAt":"July 26, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/ssh-ssl-tls.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/ssh-ssl-tls.json new file mode 100644 index 000000000..dba08e8c7 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/ssh-ssl-tls.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"ssh-ssl-tls","title":"SSH vs TLS vs SSL","description":"Learn the difference between SSH, TLS and SSL","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=k3rFFLmQCuY","authorUsername":"kamranahmedse","duration":"3 minutes","updatedAt":"2021-11-25T19:59:14.191Z","createdAt":"2021-11-25T19:59:14.191Z","formattedCreatedAt":"November 25, 2021","formattedUpdatedAt":"November 25, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/system-design-101.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/system-design-101.json new file mode 100644 index 000000000..190b8780d --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/system-design-101.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"system-design-101","title":"System Design 101","description":"Learn about all the bits and pieces of system design.","youtubeLink":"https://www.youtube.com/watch?v=Y-Gl4HEyeUQ","isPro":false,"authorUsername":"kamranahmedse","duration":"7 minutes","updatedAt":"2020-08-08T19:59:14.191Z","createdAt":"2020-08-08T19:59:14.191Z","formattedCreatedAt":"August 8, 2020","formattedUpdatedAt":"August 8, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/tcp-ip-model.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/tcp-ip-model.json new file mode 100644 index 000000000..4b84bd248 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/tcp-ip-model.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"tcp-ip-model","title":"TCP/IP Model Explained","description":"Learn what is TCP/IP Model and the different layers involved.","isPro":false,"authorUsername":"kamranahmedse","youtubeLink":"https://www.youtube.com/watch?v=F5rni9fr1yE","duration":"5 minutes","updatedAt":"2020-11-06T19:59:14.191Z","createdAt":"2020-11-06T19:59:14.191Z","formattedCreatedAt":"November 6, 2020","formattedUpdatedAt":"November 6, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/transport-protocols-tcp-vs-udp.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/transport-protocols-tcp-vs-udp.json new file mode 100644 index 000000000..443731e4e --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/transport-protocols-tcp-vs-udp.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"transport-protocols-tcp-vs-udp","title":"Transport Protocols: TCP vs UDP","description":"Learn about the Transport Layer of the TCP/IP model and different transport protocols.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=37AFBZv4_6Y","authorUsername":"kamranahmedse","duration":"10 minutes","updatedAt":"2020-11-21T19:59:14.191Z","createdAt":"2020-11-21T19:59:14.191Z","formattedCreatedAt":"November 21, 2020","formattedUpdatedAt":"November 21, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/what-is-cap-theorem.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/what-is-cap-theorem.json new file mode 100644 index 000000000..92dcd1b6a --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/what-is-cap-theorem.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"what-is-cap-theorem","title":"What is CAP Theorem?","description":"An illustrated explanation to CAP theorem with examples and proof.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=_RbsFXWRZ10","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-10-05T19:59:14.191Z","createdAt":"2021-10-05T19:59:14.191Z","formattedCreatedAt":"October 5, 2021","formattedUpdatedAt":"October 5, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/what-is-dependency-injection.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/what-is-dependency-injection.json new file mode 100644 index 000000000..2be365028 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/what-is-dependency-injection.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"what-is-dependency-injection","title":"What is Dependency Injection?","description":"Learn what is dependency injection and how to write better code with the help of it.","youtubeLink":"https://www.youtube.com/watch?v=0yc2UANSDiw","isPro":false,"authorUsername":"kamranahmedse","duration":"3 minutes","updatedAt":"2020-07-04T19:59:14.191Z","createdAt":"2020-07-04T19:59:14.191Z","formattedCreatedAt":"July 4, 2020","formattedUpdatedAt":"July 4, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/what-is-dom-shadow-dom-virtual-dom.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/what-is-dom-shadow-dom-virtual-dom.json new file mode 100644 index 000000000..79cd3874f --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/what-is-dom-shadow-dom-virtual-dom.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"what-is-dom-shadow-dom-virtual-dom","title":"DOM, Shadow DOM, Virtual DOM","description":"Learn what is DOM, Shadow DOM and Virtual DOM and how they work.","youtubeLink":"https://www.youtube.com/watch?v=7Tok22qxPzQ","isPro":false,"authorUsername":"kamranahmedse","duration":"6 minutes","updatedAt":"2020-07-20T19:59:14.191Z","createdAt":"2020-07-20T19:59:14.191Z","formattedCreatedAt":"July 20, 2020","formattedUpdatedAt":"July 20, 2020","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/what-is-eventual-consistency.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/what-is-eventual-consistency.json new file mode 100644 index 000000000..faaa5f1ee --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/what-is-eventual-consistency.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"what-is-eventual-consistency","title":"What is Eventual Consistency?","description":"Learn about the different consistency models in distributed systems","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=rpqsSkTIdAw","authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2021-11-30T19:59:14.191Z","createdAt":"2021-11-30T19:59:14.191Z","formattedCreatedAt":"November 30, 2021","formattedUpdatedAt":"November 30, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/yaml-in-depth.json b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/yaml-in-depth.json new file mode 100644 index 000000000..92f086a42 --- /dev/null +++ b/_next/data/LmGbU0IUVBiI5EeoTB-hg/watch/yaml-in-depth.json @@ -0,0 +1 @@ +{"pageProps":{"video":{"id":"yaml-in-depth","title":"YAML in Depth","description":"Everything you need to know about YAML","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=ImHSpwUlNVc","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-10-18T19:59:14.191Z","createdAt":"2021-10-18T19:59:14.191Z","formattedCreatedAt":"October 18, 2021","formattedUpdatedAt":"October 18, 2021","author":{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."}}},"__N_SSG":true} \ No newline at end of file diff --git a/_next/static/LmGbU0IUVBiI5EeoTB-hg/_buildManifest.js b/_next/static/LmGbU0IUVBiI5EeoTB-hg/_buildManifest.js new file mode 100644 index 000000000..14a6e04b8 --- /dev/null +++ b/_next/static/LmGbU0IUVBiI5EeoTB-hg/_buildManifest.js @@ -0,0 +1 @@ +self.__BUILD_MANIFEST=function(s,a,c,e,t,i,d,u){return{__rewrites:{beforeFiles:[],afterFiles:[],fallback:[]},"/":[s,u,a,"static/chunks/pages/index-19a8c654fbd2ca38.js"],"/_error":["static/chunks/pages/_error-2280fa386d040b66.js"],"/about":[s,c,a,"static/chunks/pages/about-2dec605257ffbd71.js"],"/guides":[s,a,"static/chunks/pages/guides-e61a557809b96f50.js"],"/guides/[guide]":[s,c,a,e,"static/chunks/pages/guides/[guide]-2a49c051f9f82e5c.js"],"/privacy":[s,c,a,"static/chunks/pages/privacy-e96a291996f8a98d.js"],"/roadmaps":[s,c,u,a,e,t,i,d,"static/chunks/pages/roadmaps-30633e34350afdfd.js"],"/signup":[s,"static/chunks/116-bd3fdc1b341415ed.js",a,"static/chunks/pages/signup-e204cb2417dac19b.js"],"/terms":[s,c,a,i,"static/chunks/pages/terms-35f0718a7ec434c5.js"],"/thanks":[s,a,"static/chunks/pages/thanks-5e2842e9b4eb35f1.js"],"/watch":[s,a,"static/chunks/pages/watch-d45c0b24ca989cf7.js"],"/watch/[video]":[s,c,a,t,"static/chunks/pages/watch/[video]-7fb6122753c44e36.js"],"/[roadmap]":[s,c,a,e,t,i,d,"static/chunks/pages/[roadmap]-c842a459dee095ee.js"],"/[roadmap]/interactive":[s,a,"static/chunks/pages/[roadmap]/interactive-0976535f2226cf8d.js"],"/[roadmap]/resources":[s,c,a,e,t,i,d,"static/chunks/pages/[roadmap]/resources-9641aca7b38e43e4.js"],sortedPages:["/","/_app","/_error","/about","/guides","/guides/[guide]","/privacy","/roadmaps","/signup","/terms","/thanks","/watch","/watch/[video]","/[roadmap]","/[roadmap]/interactive","/[roadmap]/resources"]}}("static/chunks/709-4e9b8e1d6266b258.js","static/chunks/515-100e7e5de90f7342.js","static/chunks/22-5e16bc1f52d67473.js","static/chunks/231-3feb9c260957057b.js","static/chunks/70-0e8008ae0f695c42.js","static/chunks/636-52036803fc755265.js","static/chunks/939-636fa0313541db68.js","static/chunks/153-36778881c9b9f8c6.js"),self.__BUILD_MANIFEST_CB&&self.__BUILD_MANIFEST_CB(); \ No newline at end of file diff --git a/_next/static/LmGbU0IUVBiI5EeoTB-hg/_middlewareManifest.js b/_next/static/LmGbU0IUVBiI5EeoTB-hg/_middlewareManifest.js new file mode 100644 index 000000000..a17fc8bf9 --- /dev/null +++ b/_next/static/LmGbU0IUVBiI5EeoTB-hg/_middlewareManifest.js @@ -0,0 +1 @@ +self.__MIDDLEWARE_MANIFEST=[];self.__MIDDLEWARE_MANIFEST_CB&&self.__MIDDLEWARE_MANIFEST_CB() \ No newline at end of file diff --git a/_next/static/LmGbU0IUVBiI5EeoTB-hg/_ssgManifest.js b/_next/static/LmGbU0IUVBiI5EeoTB-hg/_ssgManifest.js new file mode 100644 index 000000000..fa86d1ba0 --- /dev/null +++ b/_next/static/LmGbU0IUVBiI5EeoTB-hg/_ssgManifest.js @@ -0,0 +1 @@ +self.__SSG_MANIFEST=new Set(["\u002Fguides","\u002Fwatch","\u002F","\u002Froadmaps","\u002F[roadmap]\u002Finteractive","\u002Fwatch\u002F[video]","\u002F[roadmap]","\u002F[roadmap]\u002Fresources","\u002Fguides\u002F[guide]"]);self.__SSG_MANIFEST_CB&&self.__SSG_MANIFEST_CB() \ No newline at end of file diff --git a/_next/static/chunks/116-bd3fdc1b341415ed.js b/_next/static/chunks/116-bd3fdc1b341415ed.js new file mode 100644 index 000000000..26ebd7a96 --- /dev/null +++ b/_next/static/chunks/116-bd3fdc1b341415ed.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[116],{9116:function(e,a,r){r.d(a,{II:function(){return T}});var n=r(7375),l=r(2846),t=r(5031),i=r(6450),s=r(7294),d=r(894);function o(){return(o=Object.assign||function(e){for(var a=1;a=0||(l[r]=e[r]);return l}var c=["id","isRequired","isInvalid","isDisabled","isReadOnly"],p=["getRootProps","htmlProps"],m=(0,i.kr)({strict:!1,name:"FormControlContext"}),v=m[0],f=m[1];var h=(0,l.Gp)((function(e,a){var r=(0,l.jC)("Form",e),d=function(e){var a=e.id,r=e.isRequired,l=e.isInvalid,d=e.isDisabled,p=e.isReadOnly,m=u(e,c),v=(0,n.Me)(),f=a||"field-"+v,h=f+"-label",b=f+"-feedback",y=f+"-helptext",I=s.useState(!1),g=I[0],N=I[1],E=s.useState(!1),_=E[0],x=E[1],R=(0,n.kt)(),k=R[0],T=R[1],q=s.useCallback((function(e,a){return void 0===e&&(e={}),void 0===a&&(a=null),o({id:y},e,{ref:(0,i.lq)(a,(function(e){e&&x(!0)}))})}),[y]),F=s.useCallback((function(e,a){var r,n;return void 0===e&&(e={}),void 0===a&&(a=null),o({},e,{ref:a,"data-focus":(0,t.PB)(k),"data-disabled":(0,t.PB)(d),"data-invalid":(0,t.PB)(l),"data-readonly":(0,t.PB)(p),id:null!=(r=e.id)?r:h,htmlFor:null!=(n=e.htmlFor)?n:f})}),[f,d,k,l,p,h]),O=s.useCallback((function(e,a){return void 0===e&&(e={}),void 0===a&&(a=null),o({id:b},e,{ref:(0,i.lq)(a,(function(e){e&&N(!0)})),"aria-live":"polite"})}),[b]),P=s.useCallback((function(e,a){return void 0===e&&(e={}),void 0===a&&(a=null),o({},e,m,{ref:a,role:"group"})}),[m]),C=s.useCallback((function(e,a){return void 0===e&&(e={}),void 0===a&&(a=null),o({},e,{ref:a,role:"presentation","aria-hidden":!0,children:e.children||"*"})}),[]);return{isRequired:!!r,isInvalid:!!l,isReadOnly:!!p,isDisabled:!!d,isFocused:!!k,onFocus:T.on,onBlur:T.off,hasFeedbackText:g,setHasFeedbackText:N,hasHelpText:_,setHasHelpText:x,id:f,labelId:h,feedbackId:b,helpTextId:y,htmlProps:m,getHelpTextProps:q,getErrorMessageProps:O,getRootProps:P,getLabelProps:F,getRequiredIndicatorProps:C}}((0,l.Lr)(e)),m=d.getRootProps;d.htmlProps;var f=u(d,p),h=(0,t.cx)("chakra-form-control",e.className),b=s.useMemo((function(){return f}),[f]);return s.createElement(v,{value:b},s.createElement(l.Fo,{value:r},s.createElement(l.m$.div,o({},m({},a),{className:h,__css:r.container}))))}));t.Ts&&(h.displayName="FormControl");var b=(0,l.Gp)((function(e,a){var r=f(),n=(0,l.yK)(),i=(0,t.cx)("chakra-form__helper-text",e.className);return s.createElement(l.m$.div,o({},null==r?void 0:r.getHelpTextProps(e,a),{__css:n.helperText,className:i}))}));t.Ts&&(b.displayName="FormHelperText");var y=["isDisabled","isInvalid","isReadOnly","isRequired"],I=["id","disabled","readOnly","required","isRequired","isInvalid","isReadOnly","isDisabled","onFocus","onBlur"];function g(e){var a=function(e){var a,r,n,l=f(),i=e.id,s=e.disabled,d=e.readOnly,c=e.required,p=e.isRequired,m=e.isInvalid,v=e.isReadOnly,h=e.isDisabled,b=e.onFocus,y=e.onBlur,g=u(e,I),N=e["aria-describedby"]?[e["aria-describedby"]]:[];null!=l&&l.hasFeedbackText&&null!=l&&l.isInvalid&&N.push(l.feedbackId);null!=l&&l.hasHelpText&&N.push(l.helpTextId);return o({},g,{"aria-describedby":N.join(" ")||void 0,id:null!=i?i:null==l?void 0:l.id,isDisabled:null!=(a=null!=s?s:h)?a:null==l?void 0:l.isDisabled,isReadOnly:null!=(r=null!=d?d:v)?r:null==l?void 0:l.isReadOnly,isRequired:null!=(n=null!=c?c:p)?n:null==l?void 0:l.isRequired,isInvalid:null!=m?m:null==l?void 0:l.isInvalid,onFocus:(0,t.v0)(null==l?void 0:l.onFocus,b),onBlur:(0,t.v0)(null==l?void 0:l.onBlur,y)})}(e),r=a.isDisabled,n=a.isInvalid,l=a.isReadOnly,i=a.isRequired;return o({},u(a,y),{disabled:r,readOnly:l,required:i,"aria-invalid":(0,t.Qm)(n),"aria-required":(0,t.Qm)(i),"aria-readonly":(0,t.Qm)(l)})}var N=(0,l.Gp)((function(e,a){var r=(0,l.jC)("FormError",e),n=(0,l.Lr)(e),i=f();return null!=i&&i.isInvalid?s.createElement(l.Fo,{value:r},s.createElement(l.m$.div,o({},null==i?void 0:i.getErrorMessageProps(n,a),{className:(0,t.cx)("chakra-form__error-message",e.className),__css:o({display:"flex",alignItems:"center"},r.text)}))):null}));t.Ts&&(N.displayName="FormErrorMessage");var E=(0,l.Gp)((function(e,a){var r=(0,l.yK)(),n=f();if(null==n||!n.isInvalid)return null;var i=(0,t.cx)("chakra-form__error-icon",e.className);return s.createElement(d.ZP,o({ref:a,"aria-hidden":!0},e,{__css:r.icon,className:i}),s.createElement("path",{fill:"currentColor",d:"M11.983,0a12.206,12.206,0,0,0-8.51,3.653A11.8,11.8,0,0,0,0,12.207,11.779,11.779,0,0,0,11.8,24h.214A12.111,12.111,0,0,0,24,11.791h0A11.766,11.766,0,0,0,11.983,0ZM10.5,16.542a1.476,1.476,0,0,1,1.449-1.53h.027a1.527,1.527,0,0,1,1.523,1.47,1.475,1.475,0,0,1-1.449,1.53h-.027A1.529,1.529,0,0,1,10.5,16.542ZM11,12.5v-6a1,1,0,0,1,2,0v6a1,1,0,1,1-2,0Z"}))}));t.Ts&&(E.displayName="FormErrorIcon");var _=["className","children","requiredIndicator"],x=(0,l.Gp)((function(e,a){var r,n=(0,l.mq)("FormLabel",e),i=(0,l.Lr)(e);i.className;var d=i.children,c=i.requiredIndicator,p=void 0===c?s.createElement(R,null):c,m=u(i,_),v=f(),h=null!=(r=null==v?void 0:v.getLabelProps(m,a))?r:o({ref:a},m);return s.createElement(l.m$.label,o({},h,{className:(0,t.cx)("chakra-form__label",i.className),__css:o({display:"block",textAlign:"start"},n)}),d,null!=v&&v.isRequired?p:null)}));t.Ts&&(x.displayName="FormLabel");var R=(0,l.Gp)((function(e,a){var r=f(),n=(0,l.yK)();if(null==r||!r.isRequired)return null;var i=(0,t.cx)("chakra-form__required-indicator",e.className);return s.createElement(l.m$.span,o({},null==r?void 0:r.getRequiredIndicatorProps(e,a),{__css:n.requiredIndicator,className:i}))}));function k(){return(k=Object.assign||function(e){for(var a=1;a=0||(l[r]=e[r]);return l}t.Ts&&(T.displayName="Input"),T.id="Input";var F=["placement"],O={left:{marginEnd:"-1px",borderEndRadius:0,borderEndColor:"transparent"},right:{marginStart:"-1px",borderStartRadius:0,borderStartColor:"transparent"}},P=(0,l.m$)("div",{baseStyle:{flex:"0 0 auto",width:"auto",display:"flex",alignItems:"center",whiteSpace:"nowrap"}}),C=(0,l.Gp)((function(e,a){var r,n=e.placement,t=void 0===n?"left":n,i=q(e,F),d=null!=(r=O[t])?r:{},o=(0,l.yK)();return s.createElement(P,k({ref:a},i,{__css:k({},o.addon,d)}))}));t.Ts&&(C.displayName="InputAddon");var G=(0,l.Gp)((function(e,a){return s.createElement(C,k({ref:a,placement:"left"},e,{className:(0,t.cx)("chakra-input__left-addon",e.className)}))}));t.Ts&&(G.displayName="InputLeftAddon"),G.id="InputLeftAddon";var L=(0,l.Gp)((function(e,a){return s.createElement(C,k({ref:a,placement:"right"},e,{className:(0,t.cx)("chakra-input__right-addon",e.className)}))}));t.Ts&&(L.displayName="InputRightAddon"),L.id="InputRightAddon";var j=["children","className"],S=(0,l.Gp)((function(e,a){var r=(0,l.jC)("Input",e),n=(0,l.Lr)(e),d=n.children,o=n.className,u=q(n,j),c=(0,t.cx)("chakra-input__group",o),p={},m=(0,i.WR)(d),v=r.field;m.forEach((function(e){if(r){var a,n;if(v&&"InputLeftElement"===e.type.id)p.paddingStart=null!=(a=v.height)?a:v.h;if(v&&"InputRightElement"===e.type.id)p.paddingEnd=null!=(n=v.height)?n:v.h;"InputRightAddon"===e.type.id&&(p.borderEndRadius=0),"InputLeftAddon"===e.type.id&&(p.borderStartRadius=0)}}));var f=m.map((function(a){var r,n,l={size:(null==(r=a.props)?void 0:r.size)||e.size,variant:(null==(n=a.props)?void 0:n.variant)||e.variant};return"Input"!==a.type.id?s.cloneElement(a,l):s.cloneElement(a,Object.assign(l,p,a.props))}));return s.createElement(l.m$.div,k({className:c,ref:a,__css:{width:"100%",display:"flex",position:"relative"}},u),s.createElement(l.Fo,{value:r},f))}));t.Ts&&(S.displayName="InputGroup");var A=["placement"],w=["className"],B=["className"],D=(0,l.m$)("div",{baseStyle:{display:"flex",alignItems:"center",justifyContent:"center",position:"absolute",top:"0",zIndex:2}}),$=(0,l.Gp)((function(e,a){var r,n,t,i=e.placement,d=void 0===i?"left":i,o=q(e,A),u=(0,l.yK)().field,c=((t={})["left"===d?"insetStart":"insetEnd"]="0",t.width=null!=(r=null==u?void 0:u.height)?r:null==u?void 0:u.h,t.height=null!=(n=null==u?void 0:u.height)?n:null==u?void 0:u.h,t.fontSize=null==u?void 0:u.fontSize,t);return s.createElement(D,k({ref:a,__css:c},o))}));$.id="InputElement",t.Ts&&($.displayName="InputElement");var H=(0,l.Gp)((function(e,a){var r=e.className,n=q(e,w),l=(0,t.cx)("chakra-input__left-element",r);return s.createElement($,k({ref:a,placement:"left",className:l},n))}));H.id="InputLeftElement",t.Ts&&(H.displayName="InputLeftElement");var M=(0,l.Gp)((function(e,a){var r=e.className,n=q(e,B),l=(0,t.cx)("chakra-input__right-element",r);return s.createElement($,k({ref:a,placement:"right",className:l},n))}));M.id="InputRightElement",t.Ts&&(M.displayName="InputRightElement")}}]); \ No newline at end of file diff --git a/_next/static/chunks/153-36778881c9b9f8c6.js b/_next/static/chunks/153-36778881c9b9f8c6.js new file mode 100644 index 000000000..0ce4c83e0 --- /dev/null +++ b/_next/static/chunks/153-36778881c9b9f8c6.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[153],{3153:function(t,e,n){n.d(e,{u:function(){return ku}});var r=n(6450);function o(t,e){void 0===e&&(e=!1);var n=t.getBoundingClientRect();return{width:n.width/1,height:n.height/1,top:n.top/1,right:n.right/1,bottom:n.bottom/1,left:n.left/1,x:n.left/1,y:n.top/1}}function i(t){if(null==t)return window;if("[object Window]"!==t.toString()){var e=t.ownerDocument;return e&&e.defaultView||window}return t}function a(t){var e=i(t);return{scrollLeft:e.pageXOffset,scrollTop:e.pageYOffset}}function s(t){return t instanceof i(t).Element||t instanceof Element}function u(t){return t instanceof i(t).HTMLElement||t instanceof HTMLElement}function l(t){return"undefined"!==typeof ShadowRoot&&(t instanceof i(t).ShadowRoot||t instanceof ShadowRoot)}function c(t){return t?(t.nodeName||"").toLowerCase():null}function f(t){return((s(t)?t.ownerDocument:t.document)||window.document).documentElement}function d(t){return o(f(t)).left+a(t).scrollLeft}function p(t){return i(t).getComputedStyle(t)}function v(t){var e=p(t),n=e.overflow,r=e.overflowX,o=e.overflowY;return/auto|scroll|overlay|hidden/.test(n+o+r)}function h(t,e,n){void 0===n&&(n=!1);var r=u(e),s=u(e)&&function(t){var e=t.getBoundingClientRect(),n=e.width/t.offsetWidth||1,r=e.height/t.offsetHeight||1;return 1!==n||1!==r}(e),l=f(e),p=o(t,s),h={scrollLeft:0,scrollTop:0},m={x:0,y:0};return(r||!r&&!n)&&(("body"!==c(e)||v(l))&&(h=function(t){return t!==i(t)&&u(t)?{scrollLeft:(e=t).scrollLeft,scrollTop:e.scrollTop}:a(t);var e}(e)),u(e)?((m=o(e,!0)).x+=e.clientLeft,m.y+=e.clientTop):l&&(m.x=d(l))),{x:p.left+h.scrollLeft-m.x,y:p.top+h.scrollTop-m.y,width:p.width,height:p.height}}function m(t){var e=o(t),n=t.offsetWidth,r=t.offsetHeight;return Math.abs(e.width-n)<=1&&(n=e.width),Math.abs(e.height-r)<=1&&(r=e.height),{x:t.offsetLeft,y:t.offsetTop,width:n,height:r}}function g(t){return"html"===c(t)?t:t.assignedSlot||t.parentNode||(l(t)?t.host:null)||f(t)}function y(t){return["html","body","#document"].indexOf(c(t))>=0?t.ownerDocument.body:u(t)&&v(t)?t:y(g(t))}function b(t,e){var n;void 0===e&&(e=[]);var r=y(t),o=r===(null==(n=t.ownerDocument)?void 0:n.body),a=i(r),s=o?[a].concat(a.visualViewport||[],v(r)?r:[]):r,u=e.concat(s);return o?u:u.concat(b(g(s)))}function x(t){return["table","td","th"].indexOf(c(t))>=0}function w(t){return u(t)&&"fixed"!==p(t).position?t.offsetParent:null}function E(t){for(var e=i(t),n=w(t);n&&x(n)&&"static"===p(n).position;)n=w(n);return n&&("html"===c(n)||"body"===c(n)&&"static"===p(n).position)?e:n||function(t){var e=-1!==navigator.userAgent.toLowerCase().indexOf("firefox");if(-1!==navigator.userAgent.indexOf("Trident")&&u(t)&&"fixed"===p(t).position)return null;for(var n=g(t);u(n)&&["html","body"].indexOf(c(n))<0;){var r=p(n);if("none"!==r.transform||"none"!==r.perspective||"paint"===r.contain||-1!==["transform","perspective"].indexOf(r.willChange)||e&&"filter"===r.willChange||e&&r.filter&&"none"!==r.filter)return n;n=n.parentNode}return null}(t)||e}var P="top",O="bottom",S="right",A="left",T="auto",C=[P,O,S,A],V="start",R="end",k="viewport",M="popper",D=C.reduce((function(t,e){return t.concat([e+"-"+V,e+"-"+R])}),[]),j=[].concat(C,[T]).reduce((function(t,e){return t.concat([e,e+"-"+V,e+"-"+R])}),[]),L=["beforeRead","read","afterRead","beforeMain","main","afterMain","beforeWrite","write","afterWrite"];function F(t){var e=new Map,n=new Set,r=[];function o(t){n.add(t.name),[].concat(t.requires||[],t.requiresIfExists||[]).forEach((function(t){if(!n.has(t)){var r=e.get(t);r&&o(r)}})),r.push(t)}return t.forEach((function(t){e.set(t.name,t)})),t.forEach((function(t){n.has(t.name)||o(t)})),r}function B(t){var e;return function(){return e||(e=new Promise((function(n){Promise.resolve().then((function(){e=void 0,n(t())}))}))),e}}var I={placement:"bottom",modifiers:[],strategy:"absolute"};function U(){for(var t=arguments.length,e=new Array(t),n=0;n=0?"x":"y"}function X(t){var e,n=t.reference,r=t.element,o=t.placement,i=o?H(o):null,a=o?q(o):null,s=n.x+n.width/2-r.width/2,u=n.y+n.height/2-r.height/2;switch(i){case P:e={x:s,y:n.y-r.height};break;case O:e={x:s,y:n.y+n.height};break;case S:e={x:n.x+n.width,y:u};break;case A:e={x:n.x-r.width,y:u};break;default:e={x:n.x,y:n.y}}var l=i?Y(i):null;if(null!=l){var c="y"===l?"height":"width";switch(a){case V:e[l]=e[l]-(n[c]/2-r[c]/2);break;case R:e[l]=e[l]+(n[c]/2-r[c]/2)}}return e}var _={name:"popperOffsets",enabled:!0,phase:"read",fn:function(t){var e=t.state,n=t.name;e.modifiersData[n]=X({reference:e.rects.reference,element:e.rects.popper,strategy:"absolute",placement:e.placement})},data:{}},G=Math.max,$=Math.min,Z=Math.round,K={top:"auto",right:"auto",bottom:"auto",left:"auto"};function J(t){var e,n=t.popper,r=t.popperRect,o=t.placement,a=t.variation,s=t.offsets,u=t.position,l=t.gpuAcceleration,c=t.adaptive,d=t.roundOffsets,v=!0===d?function(t){var e=t.x,n=t.y,r=window.devicePixelRatio||1;return{x:Z(Z(e*r)/r)||0,y:Z(Z(n*r)/r)||0}}(s):"function"===typeof d?d(s):s,h=v.x,m=void 0===h?0:h,g=v.y,y=void 0===g?0:g,b=s.hasOwnProperty("x"),x=s.hasOwnProperty("y"),w=A,T=P,C=window;if(c){var V=E(n),k="clientHeight",M="clientWidth";V===i(n)&&"static"!==p(V=f(n)).position&&"absolute"===u&&(k="scrollHeight",M="scrollWidth"),V=V,o!==P&&(o!==A&&o!==S||a!==R)||(T=O,y-=V[k]-r.height,y*=l?1:-1),o!==A&&(o!==P&&o!==O||a!==R)||(w=S,m-=V[M]-r.width,m*=l?1:-1)}var D,j=Object.assign({position:u},c&&K);return l?Object.assign({},j,((D={})[T]=x?"0":"",D[w]=b?"0":"",D.transform=(C.devicePixelRatio||1)<=1?"translate("+m+"px, "+y+"px)":"translate3d("+m+"px, "+y+"px, 0)",D)):Object.assign({},j,((e={})[T]=x?y+"px":"",e[w]=b?m+"px":"",e.transform="",e))}var Q={left:"right",right:"left",bottom:"top",top:"bottom"};function tt(t){return t.replace(/left|right|bottom|top/g,(function(t){return Q[t]}))}var et={start:"end",end:"start"};function nt(t){return t.replace(/start|end/g,(function(t){return et[t]}))}function rt(t,e){var n=e.getRootNode&&e.getRootNode();if(t.contains(e))return!0;if(n&&l(n)){var r=e;do{if(r&&t.isSameNode(r))return!0;r=r.parentNode||r.host}while(r)}return!1}function ot(t){return Object.assign({},t,{left:t.x,top:t.y,right:t.x+t.width,bottom:t.y+t.height})}function it(t,e){return e===k?ot(function(t){var e=i(t),n=f(t),r=e.visualViewport,o=n.clientWidth,a=n.clientHeight,s=0,u=0;return r&&(o=r.width,a=r.height,/^((?!chrome|android).)*safari/i.test(navigator.userAgent)||(s=r.offsetLeft,u=r.offsetTop)),{width:o,height:a,x:s+d(t),y:u}}(t)):u(e)?function(t){var e=o(t);return e.top=e.top+t.clientTop,e.left=e.left+t.clientLeft,e.bottom=e.top+t.clientHeight,e.right=e.left+t.clientWidth,e.width=t.clientWidth,e.height=t.clientHeight,e.x=e.left,e.y=e.top,e}(e):ot(function(t){var e,n=f(t),r=a(t),o=null==(e=t.ownerDocument)?void 0:e.body,i=G(n.scrollWidth,n.clientWidth,o?o.scrollWidth:0,o?o.clientWidth:0),s=G(n.scrollHeight,n.clientHeight,o?o.scrollHeight:0,o?o.clientHeight:0),u=-r.scrollLeft+d(t),l=-r.scrollTop;return"rtl"===p(o||n).direction&&(u+=G(n.clientWidth,o?o.clientWidth:0)-i),{width:i,height:s,x:u,y:l}}(f(t)))}function at(t,e,n){var r="clippingParents"===e?function(t){var e=b(g(t)),n=["absolute","fixed"].indexOf(p(t).position)>=0&&u(t)?E(t):t;return s(n)?e.filter((function(t){return s(t)&&rt(t,n)&&"body"!==c(t)})):[]}(t):[].concat(e),o=[].concat(r,[n]),i=o[0],a=o.reduce((function(e,n){var r=it(t,n);return e.top=G(r.top,e.top),e.right=$(r.right,e.right),e.bottom=$(r.bottom,e.bottom),e.left=G(r.left,e.left),e}),it(t,i));return a.width=a.right-a.left,a.height=a.bottom-a.top,a.x=a.left,a.y=a.top,a}function st(t){return Object.assign({},{top:0,right:0,bottom:0,left:0},t)}function ut(t,e){return e.reduce((function(e,n){return e[n]=t,e}),{})}function lt(t,e){void 0===e&&(e={});var n=e,r=n.placement,i=void 0===r?t.placement:r,a=n.boundary,u=void 0===a?"clippingParents":a,l=n.rootBoundary,c=void 0===l?k:l,d=n.elementContext,p=void 0===d?M:d,v=n.altBoundary,h=void 0!==v&&v,m=n.padding,g=void 0===m?0:m,y=st("number"!==typeof g?g:ut(g,C)),b=p===M?"reference":M,x=t.rects.popper,w=t.elements[h?b:p],E=at(s(w)?w:w.contextElement||f(t.elements.popper),u,c),A=o(t.elements.reference),T=X({reference:A,element:x,strategy:"absolute",placement:i}),V=ot(Object.assign({},x,T)),R=p===M?V:A,D={top:E.top-R.top+y.top,bottom:R.bottom-E.bottom+y.bottom,left:E.left-R.left+y.left,right:R.right-E.right+y.right},j=t.modifiersData.offset;if(p===M&&j){var L=j[i];Object.keys(D).forEach((function(t){var e=[S,O].indexOf(t)>=0?1:-1,n=[P,O].indexOf(t)>=0?"y":"x";D[t]+=L[n]*e}))}return D}function ct(t,e,n){return G(t,$(e,n))}function ft(t,e,n){return void 0===n&&(n={x:0,y:0}),{top:t.top-e.height-n.y,right:t.right-e.width+n.x,bottom:t.bottom-e.height+n.y,left:t.left-e.width-n.x}}function dt(t){return[P,S,O,A].some((function(e){return t[e]>=0}))}var pt=z({defaultModifiers:[W,_,{name:"computeStyles",enabled:!0,phase:"beforeWrite",fn:function(t){var e=t.state,n=t.options,r=n.gpuAcceleration,o=void 0===r||r,i=n.adaptive,a=void 0===i||i,s=n.roundOffsets,u=void 0===s||s,l={placement:H(e.placement),variation:q(e.placement),popper:e.elements.popper,popperRect:e.rects.popper,gpuAcceleration:o};null!=e.modifiersData.popperOffsets&&(e.styles.popper=Object.assign({},e.styles.popper,J(Object.assign({},l,{offsets:e.modifiersData.popperOffsets,position:e.options.strategy,adaptive:a,roundOffsets:u})))),null!=e.modifiersData.arrow&&(e.styles.arrow=Object.assign({},e.styles.arrow,J(Object.assign({},l,{offsets:e.modifiersData.arrow,position:"absolute",adaptive:!1,roundOffsets:u})))),e.attributes.popper=Object.assign({},e.attributes.popper,{"data-popper-placement":e.placement})},data:{}},{name:"applyStyles",enabled:!0,phase:"write",fn:function(t){var e=t.state;Object.keys(e.elements).forEach((function(t){var n=e.styles[t]||{},r=e.attributes[t]||{},o=e.elements[t];u(o)&&c(o)&&(Object.assign(o.style,n),Object.keys(r).forEach((function(t){var e=r[t];!1===e?o.removeAttribute(t):o.setAttribute(t,!0===e?"":e)})))}))},effect:function(t){var e=t.state,n={popper:{position:e.options.strategy,left:"0",top:"0",margin:"0"},arrow:{position:"absolute"},reference:{}};return Object.assign(e.elements.popper.style,n.popper),e.styles=n,e.elements.arrow&&Object.assign(e.elements.arrow.style,n.arrow),function(){Object.keys(e.elements).forEach((function(t){var r=e.elements[t],o=e.attributes[t]||{},i=Object.keys(e.styles.hasOwnProperty(t)?e.styles[t]:n[t]).reduce((function(t,e){return t[e]="",t}),{});u(r)&&c(r)&&(Object.assign(r.style,i),Object.keys(o).forEach((function(t){r.removeAttribute(t)})))}))}},requires:["computeStyles"]},{name:"offset",enabled:!0,phase:"main",requires:["popperOffsets"],fn:function(t){var e=t.state,n=t.options,r=t.name,o=n.offset,i=void 0===o?[0,0]:o,a=j.reduce((function(t,n){return t[n]=function(t,e,n){var r=H(t),o=[A,P].indexOf(r)>=0?-1:1,i="function"===typeof n?n(Object.assign({},e,{placement:t})):n,a=i[0],s=i[1];return a=a||0,s=(s||0)*o,[A,S].indexOf(r)>=0?{x:s,y:a}:{x:a,y:s}}(n,e.rects,i),t}),{}),s=a[e.placement],u=s.x,l=s.y;null!=e.modifiersData.popperOffsets&&(e.modifiersData.popperOffsets.x+=u,e.modifiersData.popperOffsets.y+=l),e.modifiersData[r]=a}},{name:"flip",enabled:!0,phase:"main",fn:function(t){var e=t.state,n=t.options,r=t.name;if(!e.modifiersData[r]._skip){for(var o=n.mainAxis,i=void 0===o||o,a=n.altAxis,s=void 0===a||a,u=n.fallbackPlacements,l=n.padding,c=n.boundary,f=n.rootBoundary,d=n.altBoundary,p=n.flipVariations,v=void 0===p||p,h=n.allowedAutoPlacements,m=e.options.placement,g=H(m),y=u||(g===m||!v?[tt(m)]:function(t){if(H(t)===T)return[];var e=tt(t);return[nt(t),e,nt(e)]}(m)),b=[m].concat(y).reduce((function(t,n){return t.concat(H(n)===T?function(t,e){void 0===e&&(e={});var n=e,r=n.placement,o=n.boundary,i=n.rootBoundary,a=n.padding,s=n.flipVariations,u=n.allowedAutoPlacements,l=void 0===u?j:u,c=q(r),f=c?s?D:D.filter((function(t){return q(t)===c})):C,d=f.filter((function(t){return l.indexOf(t)>=0}));0===d.length&&(d=f);var p=d.reduce((function(e,n){return e[n]=lt(t,{placement:n,boundary:o,rootBoundary:i,padding:a})[H(n)],e}),{});return Object.keys(p).sort((function(t,e){return p[t]-p[e]}))}(e,{placement:n,boundary:c,rootBoundary:f,padding:l,flipVariations:v,allowedAutoPlacements:h}):n)}),[]),x=e.rects.reference,w=e.rects.popper,E=new Map,R=!0,k=b[0],M=0;M=0,U=I?"width":"height",z=lt(e,{placement:L,boundary:c,rootBoundary:f,altBoundary:d,padding:l}),N=I?B?S:A:B?O:P;x[U]>w[U]&&(N=tt(N));var W=tt(N),Y=[];if(i&&Y.push(z[F]<=0),s&&Y.push(z[N]<=0,z[W]<=0),Y.every((function(t){return t}))){k=L,R=!1;break}E.set(L,Y)}if(R)for(var X=function(t){var e=b.find((function(e){var n=E.get(e);if(n)return n.slice(0,t).every((function(t){return t}))}));if(e)return k=e,"break"},_=v?3:1;_>0;_--){if("break"===X(_))break}e.placement!==k&&(e.modifiersData[r]._skip=!0,e.placement=k,e.reset=!0)}},requiresIfExists:["offset"],data:{_skip:!1}},{name:"preventOverflow",enabled:!0,phase:"main",fn:function(t){var e=t.state,n=t.options,r=t.name,o=n.mainAxis,i=void 0===o||o,a=n.altAxis,s=void 0!==a&&a,u=n.boundary,l=n.rootBoundary,c=n.altBoundary,f=n.padding,d=n.tether,p=void 0===d||d,v=n.tetherOffset,h=void 0===v?0:v,g=lt(e,{boundary:u,rootBoundary:l,padding:f,altBoundary:c}),y=H(e.placement),b=q(e.placement),x=!b,w=Y(y),T="x"===w?"y":"x",C=e.modifiersData.popperOffsets,R=e.rects.reference,k=e.rects.popper,M="function"===typeof h?h(Object.assign({},e.rects,{placement:e.placement})):h,D={x:0,y:0};if(C){if(i||s){var j="y"===w?P:A,L="y"===w?O:S,F="y"===w?"height":"width",B=C[w],I=C[w]+g[j],U=C[w]-g[L],z=p?-k[F]/2:0,N=b===V?R[F]:k[F],W=b===V?-k[F]:-R[F],X=e.elements.arrow,_=p&&X?m(X):{width:0,height:0},Z=e.modifiersData["arrow#persistent"]?e.modifiersData["arrow#persistent"].padding:{top:0,right:0,bottom:0,left:0},K=Z[j],J=Z[L],Q=ct(0,R[F],_[F]),tt=x?R[F]/2-z-Q-K-M:N-Q-K-M,et=x?-R[F]/2+z+Q+J+M:W+Q+J+M,nt=e.elements.arrow&&E(e.elements.arrow),rt=nt?"y"===w?nt.clientTop||0:nt.clientLeft||0:0,ot=e.modifiersData.offset?e.modifiersData.offset[e.placement][w]:0,it=C[w]+tt-ot-rt,at=C[w]+et-ot;if(i){var st=ct(p?$(I,it):I,B,p?G(U,at):U);C[w]=st,D[w]=st-B}if(s){var ut="x"===w?P:A,ft="x"===w?O:S,dt=C[T],pt=dt+g[ut],vt=dt-g[ft],ht=ct(p?$(pt,it):pt,dt,p?G(vt,at):vt);C[T]=ht,D[T]=ht-dt}}e.modifiersData[r]=D}},requiresIfExists:["offset"]},{name:"arrow",enabled:!0,phase:"main",fn:function(t){var e,n=t.state,r=t.name,o=t.options,i=n.elements.arrow,a=n.modifiersData.popperOffsets,s=H(n.placement),u=Y(s),l=[A,S].indexOf(s)>=0?"height":"width";if(i&&a){var c=function(t,e){return st("number"!==typeof(t="function"===typeof t?t(Object.assign({},e.rects,{placement:e.placement})):t)?t:ut(t,C))}(o.padding,n),f=m(i),d="y"===u?P:A,p="y"===u?O:S,v=n.rects.reference[l]+n.rects.reference[u]-a[u]-n.rects.popper[l],h=a[u]-n.rects.reference[u],g=E(i),y=g?"y"===u?g.clientHeight||0:g.clientWidth||0:0,b=v/2-h/2,x=c[d],w=y-f[l]-c[p],T=y/2-f[l]/2+b,V=ct(x,T,w),R=u;n.modifiersData[r]=((e={})[R]=V,e.centerOffset=V-T,e)}},effect:function(t){var e=t.state,n=t.options.element,r=void 0===n?"[data-popper-arrow]":n;null!=r&&("string"!==typeof r||(r=e.elements.popper.querySelector(r)))&&rt(e.elements.popper,r)&&(e.elements.arrow=r)},requires:["popperOffsets"],requiresIfExists:["preventOverflow"]},{name:"hide",enabled:!0,phase:"main",requiresIfExists:["preventOverflow"],fn:function(t){var e=t.state,n=t.name,r=e.rects.reference,o=e.rects.popper,i=e.modifiersData.preventOverflow,a=lt(e,{elementContext:"reference"}),s=lt(e,{altBoundary:!0}),u=ft(a,r),l=ft(s,o,i),c=dt(u),f=dt(l);e.modifiersData[n]={referenceClippingOffsets:u,popperEscapeOffsets:l,isReferenceHidden:c,hasPopperEscaped:f},e.attributes.popper=Object.assign({},e.attributes.popper,{"data-popper-reference-hidden":c,"data-popper-escaped":f})}}]}),vt=n(7294);function ht(){return(ht=Object.assign||function(t){for(var e=1;e=0||(o[n]=t[n]);return o}(n,Rt),{ref:e,"data-popper-arrow":"",style:Mt(t)})}),[]),B=(0,vt.useCallback)((function(t,e){return void 0===t&&(t={}),void 0===e&&(e=null),ht({},t,{ref:e,"data-popper-arrow-inner":""})}),[]);return{update:function(){var t;null==(t=C.current)||t.update()},forceUpdate:function(){var t;null==(t=C.current)||t.forceUpdate()},transformOrigin:gt.transformOrigin.varRef,referenceRef:M,popperRef:j,getPopperProps:L,getArrowProps:F,getArrowInnerProps:B,getReferenceProps:D}}function Mt(t){var e=t.size,n=t.shadowColor,r=t.bg,o=ht({},t.style,{position:"absolute"});return e&&(o["--popper-arrow-size"]=e),n&&(o["--popper-arrow-shadow-color"]=n),r&&(o["--popper-arrow-bg"]=r),o}var Dt=n(6871),jt=n(2846),Lt=n(5031),Ft=n(1358),Bt=function(t,e){return(Bt=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n])})(t,e)};function It(t,e){if("function"!==typeof e&&null!==e)throw new TypeError("Class extends value "+String(e)+" is not a constructor or null");function n(){this.constructor=t}Bt(t,e),t.prototype=null===e?Object.create(e):(n.prototype=e.prototype,new n)}var Ut=function(){return(Ut=Object.assign||function(t){for(var e,n=1,r=arguments.length;n=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}};throw new TypeError(e?"Object is not iterable.":"Symbol.iterator is not defined.")}function Wt(t,e){var n="function"===typeof Symbol&&t[Symbol.iterator];if(!n)return t;var r,o,i=n.call(t),a=[];try{for(;(void 0===e||e-- >0)&&!(r=i.next()).done;)a.push(r.value)}catch(s){o={error:s}}finally{try{r&&!r.done&&(n=i.return)&&n.call(i)}finally{if(o)throw o.error}}return a}function Ht(t,e,n){if(n||2===arguments.length)for(var r,o=0,i=e.length;operformance.now():()=>Date.now(),pe="undefined"!==typeof window?t=>window.requestAnimationFrame(t):t=>setTimeout((()=>t(de())),fe);let ve=!0,he=!1,me=!1;const ge={delta:0,timestamp:0},ye=["read","update","preRender","render","postRender"],be=ye.reduce(((t,e)=>(t[e]=function(t){let e=[],n=[],r=0,o=!1,i=!1;const a=new WeakSet,s={schedule:(t,i=!1,s=!1)=>{const u=s&&o,l=u?e:n;return i&&a.add(t),-1===l.indexOf(t)&&(l.push(t),u&&o&&(r=e.length)),t},cancel:t=>{const e=n.indexOf(t);-1!==e&&n.splice(e,1),a.delete(t)},process:u=>{if(o)i=!0;else{if(o=!0,[e,n]=[n,e],n.length=0,r=e.length,r)for(let n=0;nhe=!0)),t)),{}),xe=ye.reduce(((t,e)=>{const n=be[e];return t[e]=(t,e=!1,r=!1)=>(he||Se(),n.schedule(t,e,r)),t}),{}),we=ye.reduce(((t,e)=>(t[e]=be[e].cancel,t)),{}),Ee=ye.reduce(((t,e)=>(t[e]=()=>be[e].process(ge),t)),{}),Pe=t=>be[t].process(ge),Oe=t=>{he=!1,ge.delta=ve?fe:Math.max(Math.min(t-ge.timestamp,40),1),ge.timestamp=t,me=!0,ye.forEach(Pe),me=!1,he&&(ve=!1,pe(Oe))},Se=()=>{he=!0,ve=!0,me||pe(Oe)},Ae=()=>ge;var Te=xe;const Ce=(t,e,n)=>-n*t+n*e+t;function Ve(t,e){return e?t*(1e3/e):0}function Re(t,e){-1===t.indexOf(e)&&t.push(e)}function ke(t,e){var n=t.indexOf(e);n>-1&&t.splice(n,1)}var Me=function(){function t(){this.subscriptions=[]}return t.prototype.add=function(t){var e=this;return Re(this.subscriptions,t),function(){return ke(e.subscriptions,t)}},t.prototype.notify=function(t,e,n){var r=this.subscriptions.length;if(r)if(1===r)this.subscriptions[0](t,e,n);else for(var o=0;oMath.min(Math.max(n,t),e),Be=.001;function Ie({duration:t=800,bounce:e=.25,velocity:n=0,mass:r=1}){let o,i,a=1-e;a=Fe(.05,1,a),t=Fe(.01,10,t/1e3),a<1?(o=e=>{const r=e*a,o=r*t,i=r-n,s=Ue(e,a),u=Math.exp(-o);return Be-i/s*u},i=e=>{const r=e*a*t,i=r*n+n,s=Math.pow(a,2)*Math.pow(e,2)*t,u=Math.exp(-r),l=Ue(Math.pow(e,2),a);return(-o(e)+Be>0?-1:1)*((i-s)*u)/l}):(o=e=>Math.exp(-e*t)*((e-n)*t+1)-.001,i=e=>Math.exp(-e*t)*(t*t*(n-e)));const s=function(t,e,n){let r=n;for(let o=1;o<12;o++)r-=t(r)/e(r);return r}(o,i,5/t);if(t*=1e3,isNaN(s))return{stiffness:100,damping:10,duration:t};{const e=Math.pow(s,2)*r;return{stiffness:e,damping:2*a*Math.sqrt(r*e),duration:t}}}function Ue(t,e){return t*Math.sqrt(1-e*e)}const ze=["duration","bounce"],Ne=["stiffness","damping","mass"];function We(t,e){return e.some((e=>void 0!==t[e]))}function He(t){var{from:e=0,to:n=1,restSpeed:r=2,restDelta:o}=t,i=zt(t,["from","to","restSpeed","restDelta"]);const a={done:!1,value:e};let{stiffness:s,damping:u,mass:l,velocity:c,duration:f,isResolvedFromDuration:d}=function(t){let e=Object.assign({velocity:0,stiffness:100,damping:10,mass:1,isResolvedFromDuration:!1},t);if(!We(t,Ne)&&We(t,ze)){const n=Ie(t);e=Object.assign(Object.assign(Object.assign({},e),n),{velocity:0,mass:1}),e.isResolvedFromDuration=!0}return e}(i),p=qe,v=qe;function h(){const t=c?-c/1e3:0,r=n-e,i=u/(2*Math.sqrt(s*l)),a=Math.sqrt(s/l)/1e3;if(null!==o&&void 0!==o||(o=Math.abs(n-e)<=1?.01:.4),i<1){const e=Ue(a,i);p=o=>{const s=Math.exp(-i*a*o);return n-s*((t+i*a*r)/e*Math.sin(e*o)+r*Math.cos(e*o))},v=n=>{const o=Math.exp(-i*a*n);return i*a*o*(Math.sin(e*n)*(t+i*a*r)/e+r*Math.cos(e*n))-o*(Math.cos(e*n)*(t+i*a*r)-e*r*Math.sin(e*n))}}else if(1===i)p=e=>n-Math.exp(-a*e)*(r+(t+a*r)*e);else{const e=a*Math.sqrt(i*i-1);p=o=>{const s=Math.exp(-i*a*o),u=Math.min(e*o,300);return n-s*((t+i*a*r)*Math.sinh(u)+e*r*Math.cosh(u))/e}}}return h(),{next:t=>{const e=p(t);if(d)a.done=t>=f;else{const i=1e3*v(t),s=Math.abs(i)<=r,u=Math.abs(n-e)<=o;a.done=s&&u}return a.value=a.done?n:e,a},flipTarget:()=>{c=-c,[e,n]=[n,e],h()}}}He.needsInterpolation=(t,e)=>"string"===typeof t||"string"===typeof e;const qe=t=>0,Ye=(t,e,n)=>{const r=e-t;return 0===r?1:(n-t)/r},Xe=(t,e)=>n=>Math.max(Math.min(n,e),t),_e=t=>t%1?Number(t.toFixed(5)):t,Ge=/(-)?([\d]*\.?[\d])+/g,$e=/(#[0-9a-f]{6}|#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\((-?[\d\.]+%?[,\s]+){2,3}\s*\/*\s*[\d\.]+%?\))/gi,Ze=/^(#[0-9a-f]{3}|#(?:[0-9a-f]{2}){2,4}|(rgb|hsl)a?\((-?[\d\.]+%?[,\s]+){2,3}\s*\/*\s*[\d\.]+%?\))$/i;function Ke(t){return"string"===typeof t}const Je={test:t=>"number"===typeof t,parse:parseFloat,transform:t=>t},Qe=Object.assign(Object.assign({},Je),{transform:Xe(0,1)}),tn=Object.assign(Object.assign({},Je),{default:1}),en=(t,e)=>n=>Boolean(Ke(n)&&Ze.test(n)&&n.startsWith(t)||e&&Object.prototype.hasOwnProperty.call(n,e)),nn=(t,e,n)=>r=>{if(!Ke(r))return r;const[o,i,a,s]=r.match(Ge);return{[t]:parseFloat(o),[e]:parseFloat(i),[n]:parseFloat(a),alpha:void 0!==s?parseFloat(s):1}},rn=Xe(0,255),on=Object.assign(Object.assign({},Je),{transform:t=>Math.round(rn(t))}),an={test:en("rgb","red"),parse:nn("red","green","blue"),transform:({red:t,green:e,blue:n,alpha:r=1})=>"rgba("+on.transform(t)+", "+on.transform(e)+", "+on.transform(n)+", "+_e(Qe.transform(r))+")"};const sn={test:en("#"),parse:function(t){let e="",n="",r="",o="";return t.length>5?(e=t.substr(1,2),n=t.substr(3,2),r=t.substr(5,2),o=t.substr(7,2)):(e=t.substr(1,1),n=t.substr(2,1),r=t.substr(3,1),o=t.substr(4,1),e+=e,n+=n,r+=r,o+=o),{red:parseInt(e,16),green:parseInt(n,16),blue:parseInt(r,16),alpha:o?parseInt(o,16)/255:1}},transform:an.transform},un=t=>({test:e=>Ke(e)&&e.endsWith(t)&&1===e.split(" ").length,parse:parseFloat,transform:e=>`${e}${t}`}),ln=un("deg"),cn=un("%"),fn=un("px"),dn=un("vh"),pn=un("vw"),vn=Object.assign(Object.assign({},cn),{parse:t=>cn.parse(t)/100,transform:t=>cn.transform(100*t)}),hn={test:en("hsl","hue"),parse:nn("hue","saturation","lightness"),transform:({hue:t,saturation:e,lightness:n,alpha:r=1})=>"hsla("+Math.round(t)+", "+cn.transform(_e(e))+", "+cn.transform(_e(n))+", "+_e(Qe.transform(r))+")"};function mn(t,e,n){return n<0&&(n+=1),n>1&&(n-=1),n<1/6?t+6*(e-t)*n:n<.5?e:n<2/3?t+(e-t)*(2/3-n)*6:t}function gn({hue:t,saturation:e,lightness:n,alpha:r}){t/=360,n/=100;let o=0,i=0,a=0;if(e/=100){const r=n<.5?n*(1+e):n+e-n*e,s=2*n-r;o=mn(s,r,t+1/3),i=mn(s,r,t),a=mn(s,r,t-1/3)}else o=i=a=n;return{red:Math.round(255*o),green:Math.round(255*i),blue:Math.round(255*a),alpha:r}}const yn=(t,e,n)=>{const r=t*t,o=e*e;return Math.sqrt(Math.max(0,n*(o-r)+r))},bn=[sn,an,hn],xn=t=>bn.find((e=>e.test(t))),wn=t=>`'${t}' is not an animatable color. Use the equivalent color code instead.`,En=(t,e)=>{let n=xn(t),r=xn(e);wn(t),wn(e);let o=n.parse(t),i=r.parse(e);n===hn&&(o=gn(o),n=an),r===hn&&(i=gn(i),r=an);const a=Object.assign({},o);return t=>{for(const e in a)"alpha"!==e&&(a[e]=yn(o[e],i[e],t));return a.alpha=Ce(o.alpha,i.alpha,t),n.transform(a)}},Pn={test:t=>an.test(t)||sn.test(t)||hn.test(t),parse:t=>an.test(t)?an.parse(t):hn.test(t)?hn.parse(t):sn.parse(t),transform:t=>Ke(t)?t:t.hasOwnProperty("red")?an.transform(t):hn.transform(t)},On="${c}",Sn="${n}";function An(t){"number"===typeof t&&(t=`${t}`);const e=[];let n=0;const r=t.match($e);r&&(n=r.length,t=t.replace($e,On),e.push(...r.map(Pn.parse)));const o=t.match(Ge);return o&&(t=t.replace(Ge,Sn),e.push(...o.map(Je.parse))),{values:e,numColors:n,tokenised:t}}function Tn(t){return An(t).values}function Cn(t){const{values:e,numColors:n,tokenised:r}=An(t),o=e.length;return t=>{let e=r;for(let r=0;r"number"===typeof t?0:t;const Rn={test:function(t){var e,n,r,o;return isNaN(t)&&Ke(t)&&(null!==(n=null===(e=t.match(Ge))||void 0===e?void 0:e.length)&&void 0!==n?n:0)+(null!==(o=null===(r=t.match($e))||void 0===r?void 0:r.length)&&void 0!==o?o:0)>0},parse:Tn,createTransformer:Cn,getAnimatableNone:function(t){const e=Tn(t);return Cn(t)(e.map(Vn))}},kn=t=>"number"===typeof t,Mn=(t,e)=>n=>e(t(n)),Dn=(...t)=>t.reduce(Mn);function jn(t,e){return kn(t)?n=>Ce(t,e,n):Pn.test(t)?En(t,e):In(t,e)}const Ln=(t,e)=>{const n=[...t],r=n.length,o=t.map(((t,n)=>jn(t,e[n])));return t=>{for(let e=0;e{const n=Object.assign(Object.assign({},t),e),r={};for(const o in n)void 0!==t[o]&&void 0!==e[o]&&(r[o]=jn(t[o],e[o]));return t=>{for(const e in r)n[e]=r[e](t);return n}};function Bn(t){const e=Rn.parse(t),n=e.length;let r=0,o=0,i=0;for(let a=0;a{const n=Rn.createTransformer(e),r=Bn(t),o=Bn(e);return r.numHSL===o.numHSL&&r.numRGB===o.numRGB&&r.numNumbers>=o.numNumbers?Dn(Ln(r.parsed,o.parsed),n):n=>`${n>0?e:t}`},Un=(t,e)=>n=>Ce(t,e,n);function zn(t,e,n){const r=[],o=n||("number"===typeof(i=t[0])?Un:"string"===typeof i?Pn.test(i)?En:In:Array.isArray(i)?Ln:"object"===typeof i?Fn:void 0);var i;const a=t.length-1;for(let s=0;st[i-1]&&(t=[].concat(t),e=[].concat(e),t.reverse(),e.reverse());const a=zn(e,r,o),s=2===i?function([t,e],[n]){return r=>n(Ye(t,e,r))}(t,a):function(t,e){const n=t.length,r=n-1;return o=>{let i=0,a=!1;if(o<=t[0]?a=!0:o>=t[r]&&(i=r-1,a=!0),!a){let e=1;for(;eo||e===r);e++);i=e-1}const s=Ye(t[i],t[i+1],o);return e[i](s)}}(t,a);return n?e=>s(Fe(t[0],t[i-1],e)):s}const Wn=t=>e=>1-t(1-e),Hn=t=>e=>e<=.5?t(2*e)/2:(2-t(2*(1-e)))/2,qn=t=>e=>e*e*((t+1)*e-t),Yn=t=>t,Xn=(_n=2,t=>Math.pow(t,_n));var _n;const Gn=Wn(Xn),$n=Hn(Xn),Zn=t=>1-Math.sin(Math.acos(t)),Kn=Wn(Zn),Jn=Hn(Kn),Qn=qn(1.525),tr=Wn(Qn),er=Hn(Qn),nr=(t=>{const e=qn(t);return t=>(t*=2)<1?.5*e(t):.5*(2-Math.pow(2,-10*(t-1)))})(1.525),rr=t=>{if(1===t||0===t)return t;const e=t*t;return t<.36363636363636365?7.5625*e:t<.7272727272727273?9.075*e-9.9*t+3.4:t<.9?12.066481994459833*e-19.63545706371191*t+8.898060941828255:10.8*t*t-20.52*t+10.72},or=Wn(rr);function ir(t,e){return t.map((()=>e||$n)).splice(0,t.length-1)}function ar({from:t=0,to:e=1,ease:n,offset:r,duration:o=300}){const i={done:!1,value:t},a=Array.isArray(e)?e:[t,e],s=function(t,e){return t.map((t=>t*e))}(r&&r.length===a.length?r:function(t){const e=t.length;return t.map(((t,n)=>0!==n?n/(e-1):0))}(a),o);function u(){return Nn(s,a,{ease:Array.isArray(n)?n:ir(a,n)})}let l=u();return{next:t=>(i.value=l(t),i.done=t>=o,i),flipTarget:()=>{a.reverse(),l=u()}}}const sr={keyframes:ar,spring:He,decay:function({velocity:t=0,from:e=0,power:n=.8,timeConstant:r=350,restDelta:o=.5,modifyTarget:i}){const a={done:!1,value:e};let s=n*t;const u=e+s,l=void 0===i?u:i(u);return l!==u&&(s=l-e),{next:t=>{const e=-s*Math.exp(-t/r);return a.done=!(e>o||e<-o),a.value=a.done?l:l+e,a},flipTarget:()=>{}}}};const ur=1/60*1e3,lr="undefined"!==typeof performance?()=>performance.now():()=>Date.now(),cr="undefined"!==typeof window?t=>window.requestAnimationFrame(t):t=>setTimeout((()=>t(lr())),ur);let fr=!0,dr=!1,pr=!1;const vr={delta:0,timestamp:0},hr=["read","update","preRender","render","postRender"],mr=hr.reduce(((t,e)=>(t[e]=function(t){let e=[],n=[],r=0,o=!1,i=!1;const a=new WeakSet,s={schedule:(t,i=!1,s=!1)=>{const u=s&&o,l=u?e:n;return i&&a.add(t),-1===l.indexOf(t)&&(l.push(t),u&&o&&(r=e.length)),t},cancel:t=>{const e=n.indexOf(t);-1!==e&&n.splice(e,1),a.delete(t)},process:u=>{if(o)i=!0;else{if(o=!0,[e,n]=[n,e],n.length=0,r=e.length,r)for(let n=0;ndr=!0)),t)),{}),gr=hr.reduce(((t,e)=>{const n=mr[e];return t[e]=(t,e=!1,r=!1)=>(dr||wr(),n.schedule(t,e,r)),t}),{}),yr=hr.reduce(((t,e)=>(t[e]=mr[e].cancel,t)),{}),br=(hr.reduce(((t,e)=>(t[e]=()=>mr[e].process(vr),t)),{}),t=>mr[t].process(vr)),xr=t=>{dr=!1,vr.delta=fr?ur:Math.max(Math.min(t-vr.timestamp,40),1),vr.timestamp=t,pr=!0,hr.forEach(br),pr=!1,dr&&(fr=!1,cr(xr))},wr=()=>{dr=!0,fr=!0,pr||cr(xr)};var Er=gr;function Pr(t,e,n=0){return t-e-n}const Or=t=>{const e=({delta:e})=>t(e);return{start:()=>Er.update(e,!0),stop:()=>yr.update(e)}};function Sr(t){var e,n,{from:r,autoplay:o=!0,driver:i=Or,elapsed:a=0,repeat:s=0,repeatType:u="loop",repeatDelay:l=0,onPlay:c,onStop:f,onComplete:d,onRepeat:p,onUpdate:v}=t,h=zt(t,["from","autoplay","driver","elapsed","repeat","repeatType","repeatDelay","onPlay","onStop","onComplete","onRepeat","onUpdate"]);let m,g,y,{to:b}=h,x=0,w=h.duration,E=!1,P=!0;const O=function(t){if(Array.isArray(t.to))return ar;if(sr[t.type])return sr[t.type];const e=new Set(Object.keys(t));return e.has("ease")||e.has("duration")&&!e.has("dampingRatio")?ar:e.has("dampingRatio")||e.has("stiffness")||e.has("mass")||e.has("damping")||e.has("restSpeed")||e.has("restDelta")?He:ar}(h);(null===(n=(e=O).needsInterpolation)||void 0===n?void 0:n.call(e,r,b))&&(y=Nn([0,100],[r,b],{clamp:!1}),r=0,b=100);const S=O(Object.assign(Object.assign({},h),{from:r,to:b}));function A(){x++,"reverse"===u?(P=x%2===0,a=function(t,e,n=0,r=!0){return r?Pr(e+-t,e,n):e-(t-e)+n}(a,w,l,P)):(a=Pr(a,w,l),"mirror"===u&&S.flipTarget()),E=!1,p&&p()}function T(t){if(P||(t=-t),a+=t,!E){const t=S.next(Math.max(0,a));g=t.value,y&&(g=y(g)),E=P?t.done:a<=0}null===v||void 0===v||v(g),E&&(0===x&&(null!==w&&void 0!==w||(w=a)),x=e+n:t<=-n}(a,w,l,P)&&A():(m.stop(),d&&d()))}return o&&(null===c||void 0===c||c(),m=i(T),m.start()),{stop:()=>{null===f||void 0===f||f(),m.stop()}}}function Ar({from:t=0,velocity:e=0,min:n,max:r,power:o=.8,timeConstant:i=750,bounceStiffness:a=500,bounceDamping:s=10,restDelta:u=1,modifyTarget:l,driver:c,onUpdate:f,onComplete:d,onStop:p}){let v;function h(t){return void 0!==n&&tr}function m(t){return void 0===n?r:void 0===r||Math.abs(n-t){var n;null===f||void 0===f||f(e),null===(n=t.onUpdate)||void 0===n||n.call(t,e)},onComplete:d,onStop:p}))}function y(t){g(Object.assign({type:"spring",stiffness:a,damping:s,restDelta:u},t))}if(h(t))y({from:t,velocity:e,to:m(t)});else{let r=o*e+t;"undefined"!==typeof l&&(r=l(r));const a=m(r),s=a===n?-1:1;let c,f;const d=t=>{c=f,f=t,e=Ve(t-c,vr.delta),(1===s&&t>a||-1===s&&tnull===v||void 0===v?void 0:v.stop()}}var Tr=function(t){return 1e3*t};const Cr=(t,e)=>1-3*e+3*t,Vr=(t,e)=>3*e-6*t,Rr=t=>3*t,kr=(t,e,n)=>((Cr(e,n)*t+Vr(e,n))*t+Rr(e))*t,Mr=(t,e,n)=>3*Cr(e,n)*t*t+2*Vr(e,n)*t+Rr(e);const Dr=.1;function jr(t,e,n,r){if(t===e&&n===r)return Yn;const o=new Float32Array(11);for(let a=0;a<11;++a)o[a]=kr(a*Dr,t,n);function i(e){let r=0,i=1;for(;10!==i&&o[i]<=e;++i)r+=Dr;--i;const a=r+(e-o[i])/(o[i+1]-o[i])*Dr,s=Mr(a,t,n);return s>=.001?function(t,e,n,r){for(let o=0;o<8;++o){const o=Mr(e,n,r);if(0===o)return e;e-=(kr(e,n,r)-t)/o}return e}(e,a,t,n):0===s?a:function(t,e,n,r,o){let i,a,s=0;do{a=e+(n-e)/2,i=kr(a,r,o)-t,i>0?n=a:e=a}while(Math.abs(i)>1e-7&&++s<10);return a}(e,r,r+Dr,t,n)}return t=>0===t||1===t?t:kr(i(t),e,r)}var Lr={linear:Yn,easeIn:Xn,easeInOut:$n,easeOut:Gn,circIn:Zn,circInOut:Jn,circOut:Kn,backIn:Qn,backInOut:er,backOut:tr,anticipate:nr,bounceIn:or,bounceInOut:t=>t<.5?.5*(1-rr(1-2*t)):.5*rr(2*t-1)+.5,bounceOut:rr},Fr=function(t){if(Array.isArray(t)){t.length;var e=Wt(t,4);return jr(e[0],e[1],e[2],e[3])}return"string"===typeof t?("Invalid easing type '".concat(t,"'"),Lr[t]):t},Br=function(t,e){return"zIndex"!==t&&(!("number"!==typeof e&&!Array.isArray(e))||!("string"!==typeof e||!Rn.test(e)||e.startsWith("url(")))},Ir=function(t){return Array.isArray(t)},Ur=function(){return{type:"spring",stiffness:500,damping:25,restDelta:.5,restSpeed:10}},zr=function(t){return{type:"spring",stiffness:550,damping:0===t?2*Math.sqrt(550):30,restDelta:.01,restSpeed:10}},Nr=function(){return{type:"keyframes",ease:"linear",duration:.3}},Wr=function(t){return{type:"keyframes",duration:.8,values:t}},Hr={x:Ur,y:Ur,z:Ur,rotate:Ur,rotateX:Ur,rotateY:Ur,rotateZ:Ur,scaleX:zr,scaleY:zr,scale:zr,opacity:Nr,backgroundColor:Nr,color:Nr,default:zr};const qr=new Set(["brightness","contrast","saturate","opacity"]);function Yr(t){let[e,n]=t.slice(0,-1).split("(");if("drop-shadow"===e)return t;const[r]=n.match(Ge)||[];if(!r)return t;const o=n.replace(r,"");let i=qr.has(e)?1:0;return r!==n&&(i*=100),e+"("+i+o+")"}const Xr=/([a-z-]*)\(.*?\)/g,_r=Object.assign(Object.assign({},Rn),{getAnimatableNone:t=>{const e=t.match(Xr);return e?e.map(Yr).join(" "):t}});var Gr=Ut(Ut({},Je),{transform:Math.round}),$r={borderWidth:fn,borderTopWidth:fn,borderRightWidth:fn,borderBottomWidth:fn,borderLeftWidth:fn,borderRadius:fn,radius:fn,borderTopLeftRadius:fn,borderTopRightRadius:fn,borderBottomRightRadius:fn,borderBottomLeftRadius:fn,width:fn,maxWidth:fn,height:fn,maxHeight:fn,size:fn,top:fn,right:fn,bottom:fn,left:fn,padding:fn,paddingTop:fn,paddingRight:fn,paddingBottom:fn,paddingLeft:fn,margin:fn,marginTop:fn,marginRight:fn,marginBottom:fn,marginLeft:fn,rotate:ln,rotateX:ln,rotateY:ln,rotateZ:ln,scale:tn,scaleX:tn,scaleY:tn,scaleZ:tn,skew:ln,skewX:ln,skewY:ln,distance:fn,translateX:fn,translateY:fn,translateZ:fn,x:fn,y:fn,z:fn,perspective:fn,transformPerspective:fn,opacity:Qe,originX:vn,originY:vn,originZ:fn,zIndex:Gr,fillOpacity:Qe,strokeOpacity:Qe,numOctaves:Gr},Zr=Ut(Ut({},$r),{color:Pn,backgroundColor:Pn,outlineColor:Pn,fill:Pn,stroke:Pn,borderColor:Pn,borderTopColor:Pn,borderRightColor:Pn,borderBottomColor:Pn,borderLeftColor:Pn,filter:_r,WebkitFilter:_r}),Kr=function(t){return Zr[t]};function Jr(t,e){var n,r=Kr(t);return r!==_r&&(r=Rn),null===(n=r.getAnimatableNone)||void 0===n?void 0:n.call(r,e)}var Qr=!1,to=function(t){return Ir(t)?t[t.length-1]||0:t};function eo(t){var e=t.ease,n=t.times,r=t.yoyo,o=t.flip,i=t.loop,a=zt(t,["ease","times","yoyo","flip","loop"]),s=Ut({},a);return n&&(s.offset=n),a.duration&&(s.duration=Tr(a.duration)),a.repeatDelay&&(s.repeatDelay=Tr(a.repeatDelay)),e&&(s.ease=function(t){return Array.isArray(t)&&"number"!==typeof t[0]}(e)?e.map(Fr):Fr(e)),"tween"===a.type&&(s.type="keyframes"),(r||i||o)&&(!0,r?s.repeatType="reverse":i?s.repeatType="loop":o&&(s.repeatType="mirror"),s.repeat=i||r||o||a.repeat),"spring"!==a.type&&(s.type="keyframes"),s}function no(t,e,n){var r;return Array.isArray(e.to)&&(null!==(r=t.duration)&&void 0!==r||(t.duration=.8)),function(t){Array.isArray(t.to)&&null===t.to[0]&&(t.to=Ht([],Wt(t.to),!1),t.to[0]=t.from)}(e),function(t){t.when,t.delay,t.delayChildren,t.staggerChildren,t.staggerDirection,t.repeat,t.repeatType,t.repeatDelay,t.from;var e=zt(t,["when","delay","delayChildren","staggerChildren","staggerDirection","repeat","repeatType","repeatDelay","from"]);return!!Object.keys(e).length}(t)||(t=Ut(Ut({},t),function(t,e){var n;return n=Ir(e)?Wr:Hr[t]||Hr.default,Ut({to:e},n(e))}(n,e.to))),Ut(Ut({},e),eo(t))}function ro(t){return 0===t||"string"===typeof t&&0===parseFloat(t)&&-1===t.indexOf(" ")}function oo(t){return"number"===typeof t?0:Jr("",t)}function io(t,e){return t[e]||t.default||t}function ao(t,e,n,r){return void 0===r&&(r={}),Qr&&(r={type:!1}),e.start((function(o){var i,a,s=function(t,e,n,r,o){var i,a=io(r,t),s=null!==(i=a.from)&&void 0!==i?i:e.get(),u=Br(t,n);"none"===s&&u&&"string"===typeof n?s=Jr(t,n):ro(s)&&"string"===typeof n?s=oo(n):!Array.isArray(n)&&ro(n)&&"string"===typeof s&&(n=oo(s));var l=Br(t,s);return"You are trying to animate ".concat(t,' from "').concat(s,'" to "').concat(n,'". ').concat(s," is not an animatable value - to enable this animation set ").concat(s," to a value animatable to ").concat(n," via the `style` property."),l&&u&&!1!==a.type?function(){var r={from:s,to:n,velocity:e.getVelocity(),onComplete:o,onUpdate:function(t){return e.set(t)}};return"inertia"===a.type||"decay"===a.type?Ar(Ut(Ut({},r),a)):Sr(Ut(Ut({},no(a,r,t)),{onUpdate:function(t){var e;r.onUpdate(t),null===(e=a.onUpdate)||void 0===e||e.call(a,t)},onComplete:function(){var t;r.onComplete(),null===(t=a.onComplete)||void 0===t||t.call(a)}}))}:function(){var t,r,i=to(n);return e.set(i),o(),null===(t=null===a||void 0===a?void 0:a.onUpdate)||void 0===t||t.call(a,i),null===(r=null===a||void 0===a?void 0:a.onComplete)||void 0===r||r.call(a),{stop:function(){}}}}(t,e,n,r,o),u=function(t,e){var n,r;return null!==(r=null!==(n=(io(t,e)||{}).delay)&&void 0!==n?n:t.delay)&&void 0!==r?r:0}(r,t),l=function(){return a=s()};return u?i=setTimeout(l,Tr(u)):l(),function(){clearTimeout(i),null===a||void 0===a||a.stop()}}))}var so=["TopLeft","TopRight","BottomLeft","BottomRight"],uo=so.length;function lo(t,e){var n;return null!==(n=t[e])&&void 0!==n?n:t.borderRadius}var co=po(0,.5,Kn),fo=po(.5,.95,Yn);function po(t,e,n){return function(r){return re?1:n(Ye(t,e,r))}}function vo(t,e){t.min=e.min,t.max=e.max}function ho(t,e){vo(t.x,e.x),vo(t.y,e.y)}function mo(t){return void 0===t||1===t}function go(t){var e=t.scale,n=t.scaleX,r=t.scaleY;return!mo(e)||!mo(n)||!mo(r)}function yo(t){return go(t)||bo(t.x)||bo(t.y)||t.z||t.rotate||t.rotateX||t.rotateY}function bo(t){return t&&"0%"!==t}function xo(t,e,n){return n+e*(t-n)}function wo(t,e,n,r,o){return void 0!==o&&(t=xo(t,o,r)),xo(t,n,r)+e}function Eo(t,e,n,r,o){void 0===e&&(e=0),void 0===n&&(n=1),t.min=wo(t.min,e,n,r,o),t.max=wo(t.max,e,n,r,o)}function Po(t,e){var n=e.x,r=e.y;Eo(t.x,n.translate,n.scale,n.originPoint),Eo(t.y,r.translate,r.scale,r.originPoint)}function Oo(t,e){t.min=t.min+e,t.max=t.max+e}function So(t,e,n){var r=Wt(n,3),o=r[0],i=r[1],a=r[2],s=void 0!==e[a]?e[a]:.5,u=Ce(t.min,t.max,s);Eo(t,e[o],e[i],u,e.scale)}var Ao=["x","scaleX","originX"],To=["y","scaleY","originY"];function Co(t,e){So(t.x,e,Ao),So(t.y,e,To)}const Vo=t=>t.hasOwnProperty("x")&&t.hasOwnProperty("y"),Ro=t=>Vo(t)&&t.hasOwnProperty("z"),ko=(t,e)=>Math.abs(t-e);function Mo(t,e){if(kn(t)&&kn(e))return ko(t,e);if(Vo(t)&&Vo(e)){const n=ko(t.x,e.x),r=ko(t.y,e.y),o=Ro(t)&&Ro(e)?ko(t.z,e.z):0;return Math.sqrt(Math.pow(n,2)+Math.pow(r,2)+Math.pow(o,2))}}function Do(t){return t.max-t.min}function jo(t,e,n){return void 0===e&&(e=0),void 0===n&&(n=.01),Mo(t,e)=0;r--){var o=this.members[r];if(!1!==o.isPresent){e=o;break}}return!!e&&(this.promote(e),!0)},t.prototype.promote=function(t,e){var n,r=this.lead;t!==r&&(this.prevLead=r,this.lead=t,t.show(),r&&(r.instance&&r.scheduleRender(),t.scheduleRender(),t.resumeFrom=r,e&&(t.resumeFrom.preserveOpacity=!0),r.snapshot&&(t.snapshot=r.snapshot,t.snapshot.latestValues=r.animationValues||r.latestValues,t.snapshot.isShared=!0),(null===(n=t.root)||void 0===n?void 0:n.isUpdating)&&(t.isLayoutDirty=!0),!1===t.options.crossfade&&r.hide()))},t.prototype.exitAnimationComplete=function(){this.members.forEach((function(t){var e,n,r,o,i;null===(n=(e=t.options).onExitComplete)||void 0===n||n.call(e),null===(i=null===(r=t.resumingFrom)||void 0===r?void 0:(o=r.options).onExitComplete)||void 0===i||i.call(o)}))},t.prototype.scheduleRender=function(){this.members.forEach((function(t){t.instance&&t.scheduleRender(!1)}))},t.prototype.removeLeadSnapshot=function(){this.lead&&this.lead.snapshot&&(this.lead.snapshot=void 0)},t}(),$o={};function Zo(t,e,n){var r=t.x.translate/e.x,o=t.y.translate/e.y,i="translate3d(".concat(r,"px, ").concat(o,"px, 0) ");if(n){var a=n.rotate,s=n.rotateX,u=n.rotateY;a&&(i+="rotate(".concat(a,"deg) ")),s&&(i+="rotateX(".concat(s,"deg) ")),u&&(i+="rotateY(".concat(u,"deg) "))}return"translate3d(0px, 0px, 0) scale(1, 1)"===(i+="scale(".concat(t.x.scale,", ").concat(t.y.scale,")"))?"none":i}function Ko(t){return[t("x"),t("y")]}var Jo=["","X","Y","Z"],Qo=["transformPerspective","x","y","z"];function ti(t,e){return Qo.indexOf(t)-Qo.indexOf(e)}["translate","scale","rotate","skew"].forEach((function(t){return Jo.forEach((function(e){return Qo.push(t+e)}))}));var ei=new Set(Qo);function ni(t){return ei.has(t)}var ri=new Set(["originX","originY","originZ"]);function oi(t){return ri.has(t)}var ii=function(t,e){return t.depth-e.depth},ai=function(){function t(){this.children=[],this.isDirty=!1}return t.prototype.add=function(t){Re(this.children,t),this.isDirty=!0},t.prototype.remove=function(t){ke(this.children,t),this.isDirty=!0},t.prototype.forEach=function(t){this.isDirty&&this.children.sort(ii),this.isDirty=!1,this.children.forEach(t)},t}();function si(t){var e,n=Le(t)?t.get():t;return e=n,Boolean(e&&"object"===typeof e&&e.mix&&e.toValue)?n.toValue():n}var ui={hasAnimatedSinceResize:!0,hasEverUpdated:!1};function li(t){var e=t.attachResizeListener,n=t.defaultParent,r=t.measureScroll,o=t.resetTransform;return function(){function t(t,e,r){var o=this;void 0===e&&(e={}),void 0===r&&(r=null===n||void 0===n?void 0:n()),this.children=new Set,this.options={},this.isTreeAnimating=!1,this.isAnimationBlocked=!1,this.isLayoutDirty=!1,this.updateManuallyBlocked=!1,this.updateBlockedByResize=!1,this.isUpdating=!1,this.isSVG=!1,this.needsReset=!1,this.shouldResetTransform=!1,this.treeScale={x:1,y:1},this.eventHandlers=new Map,this.potentialNodes=new Map,this.checkUpdateFailed=function(){o.isUpdating&&(o.isUpdating=!1,o.clearAllSnapshots())},this.updateProjection=function(){o.nodes.forEach(mi),o.nodes.forEach(gi)},this.hasProjected=!1,this.isVisible=!0,this.animationProgress=0,this.sharedNodes=new Map,this.id=t,this.latestValues=e,this.root=r?r.root||r:this,this.path=r?Ht(Ht([],Wt(r.path),!1),[r],!1):[],this.parent=r,this.depth=r?r.depth+1:0,t&&this.root.registerPotentialNode(t,this);for(var i=0;i=0;r--)if(Boolean(t.path[r].instance)){n=t.path[r];break}var o=(n&&n!==t.root?n.instance:document).querySelector('[data-projection-id="'.concat(e,'"]'));o&&t.mount(o,!0)}function Si(t){t.min=Math.round(t.min),t.max=Math.round(t.max)}function Ai(t){Si(t.x),Si(t.y)}var Ti=1;var Ci=(0,vt.createContext)({}),Vi=(0,vt.createContext)({});var Ri=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return It(e,t),e.prototype.getSnapshotBeforeUpdate=function(){return this.updateProps(),null},e.prototype.componentDidUpdate=function(){},e.prototype.updateProps=function(){var t=this.props,e=t.visualElement,n=t.props;e&&e.setProps(n)},e.prototype.render=function(){return this.props.children},e}(vt.Component);function ki(t){var e=t.preloadedFeatures,n=t.createVisualElement,r=t.projectionNodeConstructor,o=t.useRender,i=t.useVisualState,a=t.Component;return e&&function(t){for(var e in t)null!==t[e]&&("projectionNodeConstructor"===e?Yt.projectionNodeConstructor=t[e]:Yt[e].Component=t[e])}(e),(0,vt.forwardRef)((function(t,e){var s=function(t){var e,n=t.layoutId,r=null===(e=(0,vt.useContext)(Ci))||void 0===e?void 0:e.id;return r&&void 0!==n?r+"-"+n:n}(t);t=Ut(Ut({},t),{layoutId:s});var u=(0,vt.useContext)($t),l=null,c=ue(t),f=ce((function(){if(ui.hasEverUpdated)return Ti++})),d=i(t,u.isStatic);return!u.isStatic&&Jt&&(c.visualElement=te(a,d,Ut(Ut({},u),t),n),function(t,e,n,r){var o,i=e.layoutId,a=e.layout,s=e.drag,u=e.dragConstraints,l=e.layoutScroll,c=(0,vt.useContext)(Vi);r&&n&&!(null===n||void 0===n?void 0:n.projection)&&(n.projection=new r(t,n.getLatestValues(),null===(o=n.parent)||void 0===o?void 0:o.projection),n.projection.setOptions({layoutId:i,layout:a,alwaysMeasureLayout:Boolean(s)||u&&ee(u),visualElement:n,scheduleRender:function(){return n.scheduleRender()},animationType:"string"===typeof a?a:"both",initialPromotionConfig:c,layoutScroll:l}))}(f,t,c.visualElement,r||Yt.projectionNodeConstructor),l=function(t,e,n){var r=[];if((0,vt.useContext)(Xt),!e)return null;for(var o=0;o-1||/[A-Z]/.test(t))}function Li(t,e){var n=e.layout,r=e.layoutId;return ni(t)||oi(t)||(n||void 0!==r)&&(!!$o[t]||"opacity"===t)}var Fi={x:"translateX",y:"translateY",z:"translateZ",transformPerspective:"perspective"};function Bi(t){return t.startsWith("--")}var Ii=function(t,e){return e&&"number"===typeof t?e.transform(t):t};function Ui(t,e,n,r){var o,i=t.style,a=t.vars,s=t.transform,u=t.transformKeys,l=t.transformOrigin;u.length=0;var c=!1,f=!1,d=!0;for(var p in e){var v=e[p];if(Bi(p))a[p]=v;else{var h=$r[p],m=Ii(v,h);if(ni(p)){if(c=!0,s[p]=m,u.push(p),!d)continue;v!==(null!==(o=h.default)&&void 0!==o?o:0)&&(d=!1)}else oi(p)?(l[p]=m,f=!0):i[p]=m}}c?i.transform=function(t,e,n,r){var o=t.transform,i=t.transformKeys,a=e.enableHardwareAcceleration,s=void 0===a||a,u=e.allowTransformNone,l=void 0===u||u,c="";i.sort(ti);for(var f=!1,d=i.length,p=0;pv&&g,E=Array.isArray(m)?m:[m],P=E.reduce(i,{});!1===y&&(P={});var O=h.prevResolvedValues,S=void 0===O?{}:O,A=Ut(Ut({},S),P),T=function(t){w=!0,d.delete(t),h.needsAnimating[t]=!0};for(var C in A){var V=P[C],R=S[C];p.hasOwnProperty(C)||(V!==R?Ir(V)&&Ir(R)?!Ka(V,R)||x?T(C):h.protectedKeys[C]=!0:void 0!==V?T(C):d.add(C):void 0!==V&&d.has(C)?T(C):h.protectedKeys[C]=!0)}h.prevProp=m,h.prevResolvedValues=P,h.isActive&&(p=Ut(Ut({},p),P)),o&&t.blockInitialAnimation&&(w=!1),w&&!b&&f.push.apply(f,Ht([],Wt(E.map((function(t){return{animation:t,options:Ut({type:r},a)}}))),!1))},m=0;m=3;if(e||n){var o=t.point,i=Ae().timestamp;r.history.push(Ut(Ut({},o),{timestamp:i}));var a=r.handlers,s=a.onStart,u=a.onMove;e||(s&&s(r.lastMoveEvent,t),r.startEvent=r.lastMoveEvent),u&&u(r.lastMoveEvent,t)}}},this.handlePointerMove=function(t,e){r.lastMoveEvent=t,r.lastMoveEventInfo=bs(e,r.transformPagePoint),ga(t)&&0===t.buttons?r.handlePointerUp(t,e):Te.update(r.updatePoint,!0)},this.handlePointerUp=function(t,e){r.end();var n=r.handlers,o=n.onEnd,i=n.onSessionEnd,a=ws(bs(e,r.transformPagePoint),r.history);r.startEvent&&o&&o(t,a),i&&i(t,a)},!(ya(t)&&t.touches.length>1)){this.handlers=e,this.transformPagePoint=o;var i=bs(Ea(t),this.transformPagePoint),a=i.point,s=Ae().timestamp;this.history=[Ut(Ut({},a),{timestamp:s})];var u=e.onSessionStart;u&&u(t,ws(i,this.history)),this.removeListeners=Dn(Ta(window,"pointermove",this.handlePointerMove),Ta(window,"pointerup",this.handlePointerUp),Ta(window,"pointercancel",this.handlePointerUp))}}return t.prototype.updateHandlers=function(t){this.handlers=t},t.prototype.end=function(){this.removeListeners&&this.removeListeners(),we.update(this.updatePoint)},t}();function bs(t,e){return e?{point:e(t.point)}:t}function xs(t,e){return{x:t.x-e.x,y:t.y-e.y}}function ws(t,e){var n=t.point;return{point:n,delta:xs(n,Ps(e)),offset:xs(n,Es(e)),velocity:Os(e,.1)}}function Es(t){return t[0]}function Ps(t){return t[t.length-1]}function Os(t,e){if(t.length<2)return{x:0,y:0};for(var n=t.length-1,r=null,o=Ps(t);n>=0&&(r=t[n],!(o.timestamp-r.timestamp>Tr(e)));)n--;if(!r)return{x:0,y:0};var i=(o.timestamp-r.timestamp)/1e3;if(0===i)return{x:0,y:0};var a={x:(o.x-r.x)/i,y:(o.y-r.y)/i};return a.x===1/0&&(a.x=0),a.y===1/0&&(a.y=0),a}function Ss(t,e,n){return{min:void 0!==e?t.min+e:void 0,max:void 0!==n?t.max+n-(t.max-t.min):void 0}}function As(t,e){var n,r=e.min-t.min,o=e.max-t.max;return e.max-e.mine?n="y":Math.abs(t.x)>e&&(n="x");return n}(u),void(null!==n.currentDirection&&(null===a||void 0===a||a(n.currentDirection)));n.updateAxis("x",e.point,u),n.updateAxis("y",e.point,u),n.visualElement.syncRender(),null===s||void 0===s||s(t,e)}},onSessionEnd:function(t,e){return n.stop(t,e)}},{transformPagePoint:this.visualElement.getTransformPagePoint()})}},t.prototype.stop=function(t,e){var n=this.isDragging;if(this.cancel(),n){var r=e.velocity;this.startAnimation(r);var o=this.getProps().onDragEnd;null===o||void 0===o||o(t,e)}},t.prototype.cancel=function(){var t,e;this.isDragging=!1,this.visualElement.projection&&(this.visualElement.projection.isAnimationBlocked=!1),null===(t=this.panSession)||void 0===t||t.end(),this.panSession=void 0,!this.getProps().dragPropagation&&this.openGlobalLock&&(this.openGlobalLock(),this.openGlobalLock=null),null===(e=this.visualElement.animationState)||void 0===e||e.setActive(da.Drag,!1)},t.prototype.updateAxis=function(t,e,n){var r=this.getProps().drag;if(n&&js(t,r,this.currentDirection)){var o=this.getAxisMotionValue(t),i=this.originPoint[t]+n[t];this.constraints&&this.constraints[t]&&(i=function(t,e,n){var r=e.min,o=e.max;return void 0!==r&&to&&(t=n?Ce(o,t,n.max):Math.min(t,o)),t}(i,this.constraints[t],this.elastic[t])),o.set(i)}},t.prototype.resolveConstraints=function(){var t=this,e=this.getProps(),n=e.dragConstraints,r=e.dragElastic,o=(this.visualElement.projection||{}).layout,i=this.constraints;n&&ee(n)?this.constraints||(this.constraints=this.resolveRefConstraints()):this.constraints=!(!n||!o)&&function(t,e){var n=e.top,r=e.left,o=e.bottom,i=e.right;return{x:Ss(t.x,r,i),y:Ss(t.y,n,o)}}(o.actual,n),this.elastic=function(t){return void 0===t&&(t=Ts),!1===t?t=0:!0===t&&(t=Ts),{x:Cs(t,"left","right"),y:Cs(t,"top","bottom")}}(r),i!==this.constraints&&o&&this.constraints&&!this.hasMutatedConstraints&&Ko((function(e){t.getAxisMotionValue(e)&&(t.constraints[e]=function(t,e){var n={};return void 0!==e.min&&(n.min=e.min-t.min),void 0!==e.max&&(n.max=e.max-t.min),n}(o.actual[e],t.constraints[e]))}))},t.prototype.resolveRefConstraints=function(){var t=this.getProps(),e=t.dragConstraints,n=t.onMeasureDragConstraints;if(!e||!ee(e))return!1;var r=e.current,o=this.visualElement.projection;if(!o||!o.layout)return!1;var i=function(t,e,n){var r=ks(t,n),o=e.scroll;return o&&(Oo(r.x,o.x),Oo(r.y,o.y)),r}(r,o.root,this.visualElement.getTransformPagePoint()),a=function(t,e){return{x:As(t.x,e.x),y:As(t.y,e.y)}}(o.layout.actual,i);if(n){var s=n(function(t){var e=t.x,n=t.y;return{top:n.min,right:e.max,bottom:n.max,left:e.min}}(a));this.hasMutatedConstraints=!!s,s&&(a=Rs(s))}return a},t.prototype.startAnimation=function(t){var e=this,n=this.getProps(),r=n.drag,o=n.dragMomentum,i=n.dragElastic,a=n.dragTransition,s=n.dragSnapToOrigin,u=n.onDragTransitionEnd,l=this.constraints||{},c=Ko((function(n){var u;if(js(n,r,e.currentDirection)){var c=null!==(u=null===l||void 0===l?void 0:l[n])&&void 0!==u?u:{};s&&(c={min:0,max:0});var f=i?200:1e6,d=i?40:1e7,p=Ut(Ut({type:"inertia",velocity:o?t[n]:0,bounceStiffness:f,bounceDamping:d,timeConstant:750,restDelta:1,restSpeed:10},a),c);return e.startAxisValueAnimation(n,p)}}));return Promise.all(c).then(u)},t.prototype.startAxisValueAnimation=function(t,e){return ao(t,this.getAxisMotionValue(t),0,e)},t.prototype.stopAnimation=function(){var t=this;Ko((function(e){return t.getAxisMotionValue(e).stop()}))},t.prototype.getAxisMotionValue=function(t){var e,n,r="_drag"+t.toUpperCase(),o=this.visualElement.getProps()[r];return o||this.visualElement.getValue(t,null!==(n=null===(e=this.visualElement.getProps().initial)||void 0===e?void 0:e[t])&&void 0!==n?n:0)},t.prototype.snapToCursor=function(t){var e=this;Ko((function(n){if(js(n,e.getProps().drag,e.currentDirection)){var r=e.visualElement.projection,o=e.getAxisMotionValue(n);if(r&&r.layout){var i=r.layout.actual[n],a=i.min,s=i.max;o.set(t[n]-Ce(a,s,.5))}}}))},t.prototype.scalePositionWithinConstraints=function(){var t,e=this,n=this.getProps(),r=n.drag,o=n.dragConstraints,i=this.visualElement.projection;if(ee(o)&&i&&this.constraints){this.stopAnimation();var a={x:0,y:0};Ko((function(t){var n=e.getAxisMotionValue(t);if(n){var r=n.get();a[t]=function(t,e){var n=.5,r=Do(t),o=Do(e);return o>r?n=Ye(e.min,e.max-r,t.min):r>o&&(n=Ye(t.min,t.max-o,e.min)),Fe(0,1,n)}({min:r,max:r},e.constraints[t])}}));var s=this.visualElement.getProps().transformTemplate;this.visualElement.getInstance().style.transform=s?s({},""):"none",null===(t=i.root)||void 0===t||t.updateScroll(),i.updateLayout(),this.resolveConstraints(),Ko((function(t){if(js(t,r,null)){var n=e.getAxisMotionValue(t),o=e.constraints[t],i=o.min,s=o.max;n.set(Ce(i,s,a[t]))}}))}},t.prototype.addListeners=function(){var t,e=this;Ms.set(this.visualElement,this);var n=Ta(this.visualElement.getInstance(),"pointerdown",(function(t){var n=e.getProps(),r=n.drag,o=n.dragListener;r&&(void 0===o||o)&&e.start(t)})),r=function(){ee(e.getProps().dragConstraints)&&(e.constraints=e.resolveRefConstraints())},o=this.visualElement.projection,i=o.addEventListener("measure",r);o&&!o.layout&&(null===(t=o.root)||void 0===t||t.updateScroll(),o.updateLayout()),r();var a=ha(window,"resize",(function(){e.scalePositionWithinConstraints()}));return o.addEventListener("didUpdate",(function(t){var n=t.delta,r=t.hasLayoutChanged;e.isDragging&&r&&(Ko((function(t){var r=e.getAxisMotionValue(t);r&&(e.originPoint[t]+=n[t].translate,r.set(r.get()+n[t].translate))})),e.visualElement.syncRender())})),function(){a(),n(),i()}},t.prototype.getProps=function(){var t=this.visualElement.getProps(),e=t.drag,n=void 0!==e&&e,r=t.dragDirectionLock,o=void 0!==r&&r,i=t.dragPropagation,a=void 0!==i&&i,s=t.dragConstraints,u=void 0!==s&&s,l=t.dragElastic,c=void 0===l?Ts:l,f=t.dragMomentum,d=void 0===f||f;return Ut(Ut({},t),{drag:n,dragDirectionLock:o,dragPropagation:a,dragConstraints:u,dragElastic:c,dragMomentum:d})},t}();function js(t,e,n){return(!0===e||e===t)&&(null===n||n===t)}var Ls={pan:Ya((function(t){var e=t.onPan,n=t.onPanStart,r=t.onPanEnd,o=t.onPanSessionStart,i=t.visualElement,a=e||n||r||o,s=(0,vt.useRef)(null),u=(0,vt.useContext)($t).transformPagePoint,l={onSessionStart:o,onStart:n,onMove:e,onEnd:function(t,e){s.current=null,r&&r(t,e)}};(0,vt.useEffect)((function(){null!==s.current&&s.current.updateHandlers(l)})),Ca(i,"pointerdown",a&&function(t){s.current=new ys(t,l,{transformPagePoint:u})}),Fa((function(){return s.current&&s.current.end()}))})),drag:Ya((function(t){var e=t.dragControls,n=t.visualElement,r=ce((function(){return new Ds(n)}));(0,vt.useEffect)((function(){return e&&e.subscribe(r)}),[r,e]),(0,vt.useEffect)((function(){return r.addListeners()}),[r])}))},Fs=["LayoutMeasure","BeforeLayoutMeasure","LayoutUpdate","ViewportBoxUpdate","Update","Render","AnimationComplete","LayoutAnimationComplete","AnimationStart","SetAxisTarget","Unmount"];var Bs=function(t){var e=t.treeType,n=void 0===e?"":e,r=t.build,o=t.getBaseTarget,i=t.makeTargetAnimatable,a=t.measureViewportBox,s=t.render,u=t.readValueFromInstance,l=t.removeValueFromRenderState,c=t.sortNodePosition,f=t.scrapeMotionValuesFromProps;return function(t,e){var d=t.parent,p=t.props,v=t.presenceId,h=t.blockInitialAnimation,m=t.visualState;void 0===e&&(e={});var g,y,b=!1,x=m.latestValues,w=m.renderState,E=function(){var t=Fs.map((function(){return new Me})),e={},n={clearAllListeners:function(){return t.forEach((function(t){return t.clear()}))},updatePropListeners:function(t){Fs.forEach((function(r){var o,i="on"+r,a=t[i];null===(o=e[r])||void 0===o||o.call(e),a&&(e[r]=n[i](a))}))}};return t.forEach((function(t,e){n["on"+Fs[e]]=function(e){return t.add(e)},n["notify"+Fs[e]]=function(){for(var e=[],n=0;n5)return o;var u=Rn.createTransformer(t),l="number"!==typeof s[0]?1:0,c=r.x.scale*n.x,f=r.y.scale*n.y;s[0+l]/=c,s[1+l]/=f;var d=Ce(c,f,.5);"number"===typeof s[2+l]&&(s[2+l]/=d),"number"===typeof s[3+l]&&(s[3+l]/=d);var p=u(s);if(i){var v=0;p=p.replace(uu,(function(){var t=a[v];return v++,t}))}return p}},cu=function(t){function e(){return null!==t&&t.apply(this,arguments)||this}return It(e,t),e.prototype.componentDidMount=function(){var t,e=this,n=this.props,r=n.visualElement,o=n.layoutGroup,i=n.switchLayoutGroup,a=n.layoutId,s=r.projection;t=fu,Object.assign($o,t),s&&((null===o||void 0===o?void 0:o.group)&&o.group.add(s),(null===i||void 0===i?void 0:i.register)&&a&&i.register(s),s.root.didUpdate(),s.addEventListener("animationComplete",(function(){e.safeToRemove()})),s.setOptions(Ut(Ut({},s.options),{onExitComplete:function(){return e.safeToRemove()}}))),ui.hasEverUpdated=!0},e.prototype.getSnapshotBeforeUpdate=function(t){var e=this,n=this.props,r=n.layoutDependency,o=n.visualElement,i=n.drag,a=n.isPresent,s=o.projection;return s?(s.isPresent=a,i||t.layoutDependency!==r||void 0===r?s.willUpdate():this.safeToRemove(),t.isPresent!==a&&(a?s.promote():s.relegate()||Te.postRender((function(){var t;(null===(t=s.getStack())||void 0===t?void 0:t.members.length)||e.safeToRemove()}))),null):null},e.prototype.componentDidUpdate=function(){var t=this.props.visualElement.projection;t&&(t.root.didUpdate(),!t.currentAnimation&&t.isLead()&&this.safeToRemove())},e.prototype.componentWillUnmount=function(){var t=this.props,e=t.visualElement,n=t.layoutGroup,r=t.switchLayoutGroup,o=e.projection;o&&(o.scheduleCheckAfterUnmount(),(null===n||void 0===n?void 0:n.group)&&n.group.remove(o),(null===r||void 0===r?void 0:r.deregister)&&r.deregister(o))},e.prototype.safeToRemove=function(){var t=this.props.safeToRemove;null===t||void 0===t||t()},e.prototype.render=function(){return null},e}(vt.Component);var fu={borderRadius:Ut(Ut({},su),{applyTo:["borderTopLeftRadius","borderTopRightRadius","borderBottomLeftRadius","borderBottomRightRadius"]}),borderTopLeftRadius:su,borderTopRightRadius:su,borderBottomLeftRadius:su,borderBottomRightRadius:su,boxShadow:lu},du={measureLayout:function(t){var e=Wt(_a(),2),n=e[0],r=e[1],o=(0,vt.useContext)(Ci);return vt.createElement(cu,Ut({},t,{layoutGroup:o,switchLayoutGroup:(0,vt.useContext)(Vi),isPresent:n,safeToRemove:r}))}},pu=li({attachResizeListener:function(t,e){return t.addEventListener("resize",e,{passive:!0}),function(){return t.removeEventListener("resize",e)}},measureScroll:function(){return{x:document.documentElement.scrollLeft||document.body.scrollLeft,y:document.documentElement.scrollTop||document.body.scrollTop}}}),vu={current:void 0},hu=li({measureScroll:function(t){return{x:t.scrollLeft,y:t.scrollTop}},defaultParent:function(){if(!vu.current){var t=new pu(0,{});t.mount(window),t.setOptions({layoutScroll:!0}),vu.current=t}return vu.current},resetTransform:function(t,e){t.style.transform=null!==e&&void 0!==e?e:"none"}}),mu=Ut(Ut(Ut(Ut({},gs),Xa),Ls),du),gu=Mi((function(t,e){return function(t,e,n,r,o){var i=e.forwardMotionProps,a=void 0!==i&&i,s=ji(t)?pa:va;return Ut(Ut({},s),{preloadedFeatures:n,useRender:ta(a),createVisualElement:r,projectionNodeConstructor:o,Component:t})}(t,e,mu,iu,hu)}));var yu=0;function bu(){var t=yu;return yu++,t}var xu=function(t){var e=t.children,n=t.initial,r=t.isPresent,o=t.onExitComplete,i=t.custom,a=t.presenceAffectsLayout,s=ce(wu),u=ce(bu),l=(0,vt.useMemo)((function(){return{id:u,initial:n,isPresent:r,custom:i,onExitComplete:function(t){var e,n;s.set(t,!0);try{for(var r=Nt(s.values()),i=r.next();!i.done;i=r.next()){if(!i.value)return}}catch(a){e={error:a}}finally{try{i&&!i.done&&(n=r.return)&&n.call(r)}finally{if(e)throw e.error}}null===o||void 0===o||o()},register:function(t){return s.set(t,!1),function(){return s.delete(t)}}}}),a?void 0:[r]);return(0,vt.useMemo)((function(){s.forEach((function(t,e){return s.set(e,!1)}))}),[r]),vt.useEffect((function(){!r&&!s.size&&(null===o||void 0===o||o())}),[r]),vt.createElement(Kt.Provider,{value:l},e)};function wu(){return new Map}function Eu(t){return t.key||""}var Pu=function(t){var e=t.children,n=t.custom,r=t.initial,o=void 0===r||r,i=t.onExitComplete,a=t.exitBeforeEnter,s=t.presenceAffectsLayout,u=void 0===s||s,l=Wt(function(){var t=(0,vt.useRef)(!1),e=Wt((0,vt.useState)(0),2),n=e[0],r=e[1];Fa((function(){return t.current=!0}));var o=(0,vt.useCallback)((function(){!t.current&&r(n+1)}),[n]);return[(0,vt.useCallback)((function(){return Te.postRender(o)}),[o]),n]}(),1)[0],c=(0,vt.useContext)(Ci).forceRender;c&&(l=c);var f=(0,vt.useRef)(!0),d=(0,vt.useRef)(!0);(0,vt.useEffect)((function(){return function(){d.current=!1}}),[]);var p=function(t){var e=[];return vt.Children.forEach(t,(function(t){(0,vt.isValidElement)(t)&&e.push(t)})),e}(e),v=(0,vt.useRef)(p),h=(0,vt.useRef)(new Map).current,m=(0,vt.useRef)(new Set).current;if(function(t,e){t.forEach((function(t){var n=Eu(t);e.set(n,t)}))}(p,h),f.current)return f.current=!1,vt.createElement(vt.Fragment,null,p.map((function(t){return vt.createElement(xu,{key:Eu(t),isPresent:!0,initial:!!o&&void 0,presenceAffectsLayout:u},t)})));for(var g=Ht([],Wt(p),!1),y=v.current.map(Eu),b=p.map(Eu),x=y.length,w=0;w=0||(o[n]=t[n]);return o}var Tu={exit:{scale:.85,opacity:0,transition:{opacity:{duration:.15,easings:"easeInOut"},scale:{duration:.2,easings:"easeInOut"}}},enter:{scale:1,opacity:1,transition:{opacity:{easings:"easeOut",duration:.2},scale:{duration:.2,ease:[.175,.885,.4,1.1]}}}},Cu=["openDelay","closeDelay","closeOnClick","closeOnMouseDown","onOpen","onClose","placement","id","isOpen","defaultIsOpen","arrowSize","arrowShadowColor","arrowPadding","modifiers","isDisabled","gutter","offset","direction"];var Vu=["children","label","shouldWrapChildren","aria-label","hasArrow","bg","portalProps"],Ru=(0,jt.m$)(gu.div),ku=(0,jt.Gp)((function(t,e){var n=(0,jt.mq)("Tooltip",t),o=(0,jt.Lr)(t),i=(0,jt.Fg)(),a=o.children,s=o.label,u=o.shouldWrapChildren,l=o["aria-label"],c=o.hasArrow,f=o.bg,d=o.portalProps,p=Au(o,Vu);f&&(n.bg=f,n[gt.arrowBg.var]=(0,Lt.K1)(i,"colors",f));var v,h=function(t){void 0===t&&(t={});var e=t,n=e.openDelay,o=void 0===n?0:n,i=e.closeDelay,a=void 0===i?0:i,s=e.closeOnClick,u=void 0===s||s,l=e.closeOnMouseDown,c=e.onOpen,f=e.onClose,d=e.placement,p=e.id,v=e.isOpen,h=e.defaultIsOpen,m=e.arrowSize,g=void 0===m?10:m,y=e.arrowShadowColor,b=e.arrowPadding,x=e.modifiers,w=e.isDisabled,E=e.gutter,P=e.offset,O=e.direction,S=Au(e,Cu),A=(0,Ou.qY)({isOpen:v,defaultIsOpen:h,onOpen:c,onClose:f}),T=A.isOpen,C=A.onOpen,V=A.onClose,R=kt({enabled:T,placement:d,arrowPadding:b,modifiers:x,gutter:E,offset:P,direction:O}),k=R.referenceRef,M=R.getPopperProps,D=R.getArrowInnerProps,j=R.getArrowProps,L=(0,Ou.Me)(p,"tooltip"),F=vt.useRef(null),B=vt.useRef(),I=vt.useRef(),U=vt.useCallback((function(){w||(B.current=window.setTimeout(C,o))}),[w,C,o]),z=vt.useCallback((function(){B.current&&clearTimeout(B.current),I.current=window.setTimeout(V,a)}),[a,V]),N=vt.useCallback((function(){u&&z()}),[u,z]),W=vt.useCallback((function(){l&&z()}),[l,z]);(0,Ou.OR)("keydown",(function(t){T&&"Escape"===t.key&&z()})),vt.useEffect((function(){return function(){clearTimeout(B.current),clearTimeout(I.current)}}),[]),(0,Ou.OR)("mouseleave",z,(function(){return F.current}));var H=vt.useCallback((function(t,e){return void 0===t&&(t={}),void 0===e&&(e=null),Su({},t,{ref:(0,r.lq)(F,e,k),onMouseEnter:(0,Lt.v0)(t.onMouseEnter,U),onClick:(0,Lt.v0)(t.onClick,N),onMouseDown:(0,Lt.v0)(t.onMouseDown,W),onFocus:(0,Lt.v0)(t.onFocus,U),onBlur:(0,Lt.v0)(t.onBlur,z),"aria-describedby":T?L:void 0})}),[U,z,W,T,L,N,k]),q=vt.useCallback((function(t,e){var n;return void 0===t&&(t={}),void 0===e&&(e=null),M(Su({},t,{style:Su({},t.style,(n={},n[gt.arrowSize.var]=g?(0,Lt.px)(g):void 0,n[gt.arrowShadowColor.var]=y,n))}),e)}),[M,g,y]),Y=vt.useCallback((function(t,e){return void 0===t&&(t={}),void 0===e&&(e=null),Su({ref:e},S,t,{id:L,role:"tooltip",style:Su({},t.style,{position:"relative",transformOrigin:gt.transformOrigin.varRef})})}),[S,L]);return{isOpen:T,show:U,hide:z,getTriggerProps:H,getTooltipProps:Y,getTooltipPositionerProps:q,getArrowProps:j,getArrowInnerProps:D}}(Su({},p,{direction:i.direction}));if((0,Lt.HD)(a)||u)v=vt.createElement(jt.m$.span,Su({tabIndex:0},h.getTriggerProps()),a);else{var m=vt.Children.only(a);v=vt.cloneElement(m,h.getTriggerProps(m.props,m.ref))}var g=!!l,y=h.getTooltipProps({},e),b=g?(0,Lt.CE)(y,["role","id"]):y,x=(0,Lt.ei)(y,["role","id"]);return s?vt.createElement(vt.Fragment,null,v,vt.createElement(Pu,null,h.isOpen&&vt.createElement(Dt.h_,d,vt.createElement(jt.m$.div,Su({},h.getTooltipPositionerProps(),{__css:{zIndex:n.zIndex,pointerEvents:"none"}}),vt.createElement(Ru,Su({variants:Tu},b,{initial:"exit",animate:"enter",exit:"exit",__css:n}),s,g&&vt.createElement(Ft.TX,x,l),c&&vt.createElement(jt.m$.div,{"data-popper-arrow":!0,className:"chakra-tooltip__arrow-wrapper"},vt.createElement(jt.m$.div,{"data-popper-arrow-inner":!0,className:"chakra-tooltip__arrow",__css:{bg:n.bg}}))))))):vt.createElement(vt.Fragment,null,a)}));Lt.Ts&&(ku.displayName="Tooltip")}}]); \ No newline at end of file diff --git a/_next/static/chunks/22-5e16bc1f52d67473.js b/_next/static/chunks/22-5e16bc1f52d67473.js new file mode 100644 index 000000000..6d3a3cc9a --- /dev/null +++ b/_next/static/chunks/22-5e16bc1f52d67473.js @@ -0,0 +1 @@ +(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[22],{4137:function(e,t,r){"use strict";r.d(t,{Zo:function(){return u},kt:function(){return h}});var n=r(7294);function a(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function i(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function o(e){for(var t=1;t=0||(a[r]=e[r]);return a}(e,t);if(Object.getOwnPropertySymbols){var i=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(a[r]=e[r])}return a}var c=n.createContext({}),l=function(e){var t=n.useContext(c),r=t;return e&&(r="function"===typeof e?e(t):o(o({},t),e)),r},u=function(e){var t=l(e.components);return n.createElement(c.Provider,{value:t},e.children)},f={inlineCode:"code",wrapper:function(e){var t=e.children;return n.createElement(n.Fragment,{},t)}},d=n.forwardRef((function(e,t){var r=e.components,a=e.mdxType,i=e.originalType,c=e.parentName,u=s(e,["components","mdxType","originalType","parentName"]),d=l(r),h=a,p=d["".concat(c,".").concat(h)]||d[h]||f[h]||i;return r?n.createElement(p,o(o({ref:t},u),{},{components:r})):n.createElement(p,o({ref:t},u))}));function h(e,t){var r=arguments,a=t&&t.mdxType;if("string"===typeof e||a){var i=r.length,o=new Array(i);o[0]=d;var s={};for(var c in t)hasOwnProperty.call(t,c)&&(s[c]=t[c]);s.originalType=e,s.mdxType="string"===typeof e?e:a,o[1]=s;for(var l=2;lh)&&(L=(H=H.replace(" ",":")).length),0n&&(n=(t=t.trim()).charCodeAt(0)),n){case 38:return t.replace(m,"$1"+e.trim());case 58:return e.trim()+t.replace(m,"$1"+e.trim());default:if(0<1*r&&0c.charCodeAt(8))break;case 115:o=o.replace(c,"-webkit-"+c)+";"+o;break;case 207:case 102:o=o.replace(c,"-webkit-"+(102n.charCodeAt(0)&&(n=n.trim()),n=[n],01?t-1:0),n=1;n0?" Args: "+r.join(", "):""))}var O=function(){function e(e){this.groupSizes=new Uint32Array(512),this.length=512,this.tag=e}var t=e.prototype;return t.indexOfGroup=function(e){for(var t=0,r=0;r=this.groupSizes.length){for(var r=this.groupSizes,n=r.length,a=n;e>=a;)(a<<=1)<0&&x(16,""+e);this.groupSizes=new Uint32Array(a),this.groupSizes.set(r),this.length=a;for(var i=n;i=this.length||0===this.groupSizes[e])return t;for(var r=this.groupSizes[e],n=this.indexOfGroup(e),a=n+r,i=n;i=I&&(I=t+1),P.set(e,t),E.set(t,e)},T="style["+S+'][data-styled-version="5.3.3"]',$=new RegExp("^"+S+'\\.g(\\d+)\\[id="([\\w\\d-]+)"\\].*?"([^"]*)'),N=function(e,t,r){for(var n,a=r.split(","),i=0,o=a.length;i=0;r--){var n=t[r];if(n&&1===n.nodeType&&n.hasAttribute(S))return n}}(r),i=void 0!==a?a.nextSibling:null;n.setAttribute(S,"active"),n.setAttribute("data-styled-version","5.3.3");var o=z();return o&&n.setAttribute("nonce",o),r.insertBefore(n,i),n},L=function(){function e(e){var t=this.element=M(e);t.appendChild(document.createTextNode("")),this.sheet=function(e){if(e.sheet)return e.sheet;for(var t=document.styleSheets,r=0,n=t.length;r=0){var r=document.createTextNode(t),n=this.nodes[e];return this.element.insertBefore(r,n||null),this.length++,!0}return!1},t.deleteRule=function(e){this.element.removeChild(this.nodes[e]),this.length--},t.getRule=function(e){return e0&&(l+=e+",")})),n+=""+s+c+'{content:"'+l+'"}/*!sc*/\n'}}}return n}(this)},e}(),G=/(a)(d)/gi,q=function(e){return String.fromCharCode(e+(e>25?39:97))};function V(e){var t,r="";for(t=Math.abs(e);t>52;t=t/52|0)r=q(t%52)+r;return(q(t%52)+r).replace(G,"$1-$2")}var W=function(e,t){for(var r=t.length;r;)e=33*e^t.charCodeAt(--r);return e},X=function(e){return W(5381,e)};function Z(e){for(var t=0;t>>0);if(!t.hasNameForId(n,o)){var s=r(i,"."+o,void 0,n);t.insertRules(n,o,s)}a.push(o),this.staticRulesId=o}else{for(var c=this.rules.length,l=W(this.baseHash,r.hash),u="",f=0;f>>0);if(!t.hasNameForId(n,g)){var m=r(u,"."+g,void 0,n);t.insertRules(n,g,m)}a.push(g)}}return a.join(" ")},e}(),Q=/^\s*\/\/.*$/gm,ee=[":","[",".","#"];function te(e){var t,r,n,a,i=void 0===e?y:e,o=i.options,c=void 0===o?y:o,l=i.plugins,u=void 0===l?v:l,f=new s(c),d=[],h=function(e){function t(t){if(t)try{e(t+"}")}catch(e){}}return function(r,n,a,i,o,s,c,l,u,f){switch(r){case 1:if(0===u&&64===n.charCodeAt(0))return e(n+";"),"";break;case 2:if(0===l)return n+"/*|*/";break;case 3:switch(l){case 102:case 112:return e(a[0]+n),"";default:return n+(0===f?"/*|*/":"")}case-2:n.split("/*|*/}").forEach(t)}}}((function(e){d.push(e)})),p=function(e,n,i){return 0===n&&-1!==ee.indexOf(i[r.length])||i.match(a)?e:"."+t};function g(e,i,o,s){void 0===s&&(s="&");var c=e.replace(Q,""),l=i&&o?o+" "+i+" { "+c+" }":c;return t=s,r=i,n=new RegExp("\\"+r+"\\b","g"),a=new RegExp("(\\"+r+"\\b){2,}"),f(o||!i?"":i,l)}return f.use([].concat(u,[function(e,t,a){2===e&&a.length&&a[0].lastIndexOf(r)>0&&(a[0]=a[0].replace(n,p))},h,function(e){if(-2===e){var t=d;return d=[],t}}])),g.hash=u.length?u.reduce((function(e,t){return t.name||x(15),W(e,t.name)}),5381).toString():"",g}var re=a.createContext(),ne=(re.Consumer,a.createContext()),ae=(ne.Consumer,new U),ie=te();function oe(){return(0,a.useContext)(re)||ae}function se(){return(0,a.useContext)(ne)||ie}function ce(e){var t=(0,a.useState)(e.stylisPlugins),r=t[0],n=t[1],i=oe(),s=(0,a.useMemo)((function(){var t=i;return e.sheet?t=e.sheet:e.target&&(t=t.reconstructWithOptions({target:e.target},!1)),e.disableCSSOMInjection&&(t=t.reconstructWithOptions({useCSSOMInjection:!1})),t}),[e.disableCSSOMInjection,e.sheet,e.target]),c=(0,a.useMemo)((function(){return te({options:{prefix:!e.disableVendorPrefixes},plugins:r})}),[e.disableVendorPrefixes,r]);return(0,a.useEffect)((function(){o()(r,e.stylisPlugins)||n(e.stylisPlugins)}),[e.stylisPlugins]),a.createElement(re.Provider,{value:s},a.createElement(ne.Provider,{value:c},e.children))}var le=function(){function e(e,t){var r=this;this.inject=function(e,t){void 0===t&&(t=ie);var n=r.name+t.hash;e.hasNameForId(r.id,n)||e.insertRules(r.id,n,t(r.rules,n,"@keyframes"))},this.toString=function(){return x(12,String(r.name))},this.name=e,this.id="sc-keyframes-"+e,this.rules=t}return e.prototype.getName=function(e){return void 0===e&&(e=ie),this.name+e.hash},e}(),ue=/([A-Z])/,fe=/([A-Z])/g,de=/^ms-/,he=function(e){return"-"+e.toLowerCase()};function pe(e){return ue.test(e)?e.replace(fe,he).replace(de,"-ms-"):e}var ge=function(e){return null==e||!1===e||""===e};function me(e,t,r,n){if(Array.isArray(e)){for(var a,i=[],o=0,s=e.length;o1?t-1:0),n=1;n?@[\\\]^`{|}~-]+/g,we=/(^-|-$)/g;function Se(e){return e.replace(ke,"-").replace(we,"")}var Ce=function(e){return V(X(e)>>>0)};function Ae(e){return"string"==typeof e&&!0}var xe=function(e){return"function"==typeof e||"object"==typeof e&&null!==e&&!Array.isArray(e)},Oe=function(e){return"__proto__"!==e&&"constructor"!==e&&"prototype"!==e};function Pe(e,t,r){var n=e[r];xe(t)&&xe(n)?Ee(n,t):e[r]=t}function Ee(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n=0||(a[r]=e[r]);return a}(t,["componentId"]),i=n&&n+"-"+(Ae(e)?e:Se(k(e)));return je(e,p({},a,{attrs:m,componentId:i}),r)},Object.defineProperty(C,"defaultProps",{get:function(){return this._foldedDefaultProps},set:function(t){this._foldedDefaultProps=n?Ee({},e.defaultProps,t):t}}),C.toString=function(){return"."+C.styledComponentId},i&&d()(C,e,{attrs:!0,componentStyle:!0,displayName:!0,foldedComponentIds:!0,shouldForwardProp:!0,styledComponentId:!0,target:!0,withComponent:!0}),C}var Re=function(e){return function e(t,r,a){if(void 0===a&&(a=y),!(0,n.isValidElementType)(r))return x(1,String(r));var i=function(){return t(r,a,ye.apply(void 0,arguments))};return i.withConfig=function(n){return e(t,r,p({},a,{},n))},i.attrs=function(n){return e(t,r,p({},a,{attrs:Array.prototype.concat(a.attrs,n).filter(Boolean)}))},i}(je,e)};["a","abbr","address","area","article","aside","audio","b","base","bdi","bdo","big","blockquote","body","br","button","canvas","caption","cite","code","col","colgroup","data","datalist","dd","del","details","dfn","dialog","div","dl","dt","em","embed","fieldset","figcaption","figure","footer","form","h1","h2","h3","h4","h5","h6","head","header","hgroup","hr","html","i","iframe","img","input","ins","kbd","keygen","label","legend","li","link","main","map","mark","marquee","menu","menuitem","meta","meter","nav","noscript","object","ol","optgroup","option","output","p","param","picture","pre","progress","q","rp","rt","ruby","s","samp","script","section","select","small","source","span","strong","style","sub","summary","sup","table","tbody","td","textarea","tfoot","th","thead","time","title","tr","track","u","ul","var","video","wbr","circle","clipPath","defs","ellipse","foreignObject","g","image","line","linearGradient","marker","mask","path","pattern","polygon","polyline","radialGradient","rect","stop","svg","text","textPath","tspan"].forEach((function(e){Re[e]=Re(e)}));!function(){function e(e,t){this.rules=e,this.componentId=t,this.isStatic=Z(e),U.registerId(this.componentId+1)}var t=e.prototype;t.createStyles=function(e,t,r,n){var a=n(me(this.rules,t,r,n).join(""),""),i=this.componentId+e;r.insertRules(i,i,a)},t.removeStyles=function(e,t){t.clearRules(this.componentId+e)},t.renderStyles=function(e,t,r,n){e>2&&U.registerId(this.componentId+e),this.removeStyles(e,r),this.createStyles(e,t,r,n)}}();!function(){function e(){var e=this;this._emitSheetCSS=function(){var t=e.instance.toString();if(!t)return"";var r=z();return""},this.getStyleTags=function(){return e.sealed?x(2):e._emitSheetCSS()},this.getStyleElement=function(){var t;if(e.sealed)return x(2);var r=((t={})[S]="",t["data-styled-version"]="5.3.3",t.dangerouslySetInnerHTML={__html:e.instance.toString()},t),n=z();return n&&(r.nonce=n),[a.createElement("style",p({},r,{key:"sc-0-0"}))]},this.seal=function(){e.sealed=!0},this.instance=new U({isServer:!0}),this.sealed=!1}var t=e.prototype;t.collectStyles=function(e){return this.sealed?x(2):a.createElement(ce,{sheet:this.instance},e)},t.interleaveWithNodeStream=function(e){return x(3)}}();var Te=Re}}]); \ No newline at end of file diff --git a/_next/static/chunks/231-3feb9c260957057b.js b/_next/static/chunks/231-3feb9c260957057b.js new file mode 100644 index 000000000..12537201c --- /dev/null +++ b/_next/static/chunks/231-3feb9c260957057b.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[231],{8025:function(e,a,t){t.d(a,{Z:function(){return ee}});var n=t(5893),s=t(7294),o=t(4137),c=t(3606),p=t(8527),i=t(8797);function r(){var e,a,t=(e=["\n line-height: 27px;\n font-size: 16px;\n color: black;\n margin-bottom: 18px;\n"],a||(a=e.slice(0)),Object.freeze(Object.defineProperties(e,{raw:{value:Object.freeze(a)}})));return r=function(){return t},t}var m,k=i.ZP.p(r());function l(){return(l=Object.assign||function(e){for(var a=1;a iframe {\n overflow: hidden;\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n display: flex;\n justify-content: center;\n align-items: center;\n width: 100%;\n height: 100%;\n }\n'],a||(a=e.slice(0)),Object.freeze(Object.defineProperties(e,{raw:{value:Object.freeze(a)}})));return H=function(){return t},t}var B=i.ZP.div(H());function W(){var e,a,t=(e=["\n max-width: 100%;\n margin: 25px auto;\n display: block;\n"],a||(a=e.slice(0)),Object.freeze(Object.defineProperties(e,{raw:{value:Object.freeze(a)}})));return W=function(){return t},t}var L=i.ZP.img(W());function R(){var e,a,t=(e=["\n font-weight: 600;\n text-decoration: underline;\n"],a||(a=e.slice(0)),Object.freeze(Object.defineProperties(e,{raw:{value:Object.freeze(a)}})));return R=function(){return t},t}var z=i.ZP.a(R()),F=function(e){var a=/(^http(s)?:\/\/)|(\.(png|svg|jpeg|jpg)$)/.test(e.href);return(0,n.jsx)(z,{href:e.href,target:a?"_blank":"_self",children:e.children})};function _(e,a){return a||(a=e.slice(0)),Object.freeze(Object.defineProperties(e,{raw:{value:Object.freeze(a)}}))}function J(){var e=_(["\n margin-left: 40px;\n margin-bottom: 18px;\n \n ul {\n margin-top: 18px;\n }\n"]);return J=function(){return e},e}function X(){var e=_(["\n margin-bottom: 7px;\n"]);return X=function(){return e},e}var U=i.ZP.ul(J()),Y=i.ZP.li(X()),G=t(6723),K=t(9876);function Z(e,a,t){return a in e?Object.defineProperty(e,a,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[a]=t,e}var V=function(e){for(var a=1;a=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={title:"WebStorm \u2014 Project History",description:"Learn how to peek through the history of any git repository to learn how it grew.",url:"/guides/project-history",fileName:"project-history",featured:!0,author:"kamranahmedse",updatedAt:"2020-07-16T19:59:14.191Z",createdAt:"2020-07-16T19:59:14.191Z"},c={guideMeta:o};function p(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},c,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,'Asymptotic notation is the standard way of measuring the time and space that an algorithm will consume as the input grows. In one of my last guides, I covered "Big-O notation" and a lot of you asked for a similar one for Asymptotic notation. You can find the ',(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/big-o-notation"}),"previous guide here"),"."),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/asymptotic-notation.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/asymptotic-notation.png",alt:null})))))}p.isMDXComponent=!0},4109:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/avoid-render-blocking-javascript-with-async-defer.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/avoid-render-blocking-javascript-with-async-defer.png",alt:null})))))}c.isMDXComponent=!0},4048:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/basic-authentication.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/basic-authentication.png",alt:null})))))}c.isMDXComponent=!0},4340:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"Big-O notation is the mathematical notation that helps analyse the algorithms to get an idea about how they might perform as the input grows. The image below explains Big-O in a simple way without using any fancy terminology. "),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/big-o-notation.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/big-o-notation.png",alt:null})))))}c.isMDXComponent=!0},2963:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/character-encodings.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/character-encodings.png",alt:null})))))}c.isMDXComponent=!0},1123:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"The image below details the differences between the continuous integration and continuous delivery. Also, here is the ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://www.youtube.com/watch?v=nyKZTKQS_EQ"}),"accompanying video on implementing that with GitHub actions"),"."),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/ci-cd.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/ci-cd.png",alt:null})))))}c.isMDXComponent=!0},5298:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"Design patterns are solutions to recurring problems; ",(0,n.kt)("strong",{parentName:"p"},"guidelines on how to tackle certain problems"),". They are not classes, packages or libraries that you can plug into your application and wait for the magic to happen. These are, rather, guidelines on how to tackle certain problems in certain situations."),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Design patterns are solutions to recurring problems; guidelines on how to tackle certain problems")),(0,n.kt)("p",null,"Wikipedia describes them as"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In software engineering, a software design pattern is a general reusable solution to a commonly occurring problem within a given context in software design. It is not a finished design that can be transformed directly into source or machine code. It is a description or template for how to solve a problem that can be used in many different situations.")),(0,n.kt)("h2",null,"Be Careful"),(0,n.kt)("p",null,"Developers, mostly beginners, make the mistake of over-thinking and forcing the design patterns which results in a horrible un-maintainable mess. The rule of thumb is to keep the codebase as simple as possible, once you start developing, you will start to see the patterns repeating in the codebase in which case you can go ahead and implement the relevant design patterns."),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"Design patterns are not a silver bullet to all your problems."),(0,n.kt)("li",{parentName:"ul"},"Do not try to force them; bad things are supposed to happen, if done so. "),(0,n.kt)("li",{parentName:"ul"},"Keep in mind that design patterns are solutions ",(0,n.kt)("strong",{parentName:"li"},"to")," problems, not solutions ",(0,n.kt)("strong",{parentName:"li"},"finding")," problems; so don't overthink."),(0,n.kt)("li",{parentName:"ul"},"If used in a correct place in a correct manner, they can prove to be a savior; or else they can result in a horrible mess of a code.")),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Also note that the code samples below are in PHP-7, however this shouldn't stop you because the concepts are same anyways.")),(0,n.kt)("h2",null,"Types of Design Patterns"),(0,n.kt)("p",null,"This guide is about Gang of Four (GoF) design patterns, which refers to the four authors of ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://en.wikipedia.org/wiki/Design_Patterns"}),"the book which introduced these design patterns"),". There are three types of design patterns:"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#creational-design-patterns"}),"Creational")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#structural-design-patterns"}),"Structural")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#behavioral-design-patterns"}),"Behavioral"))),(0,n.kt)("h2",null,"Creational Design Patterns"),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Creational patterns are focused towards how to instantiate an object or group of related objects.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In software engineering, creational design patterns are design patterns that deal with object creation mechanisms, trying to create objects in a manner suitable to the situation. The basic form of object creation could result in design problems or added complexity to the design. Creational design patterns solve this problem by somehow controlling this object creation.")),(0,n.kt)("p",null,"There are 6 types of Creational patterns"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-simple-factory"}),"Simple Factory")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-factory-method"}),"Factory Method")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-abstract-factory"}),"Abstract Factory")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-builder"}),"Builder")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-prototype"}),"Prototype")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-singleton"}),"Singleton"))),(0,n.kt)("h2",null,"\ud83c\udfe0 Simple Factory"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Consider, you are building a house and you need doors. You can either put on your carpenter clothes, bring some wood, glue, nails and all the tools required to build the door and start building it in your house or you can simply call the factory and get the built door delivered to you so that you don't need to learn anything about the door making or to deal with the mess that comes with making it.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Simple factory simply generates an instance for client without exposing any instantiation logic to the client")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},'In object-oriented programming (OOP), a factory is an object for creating other objects \u2013 formally a factory is a function or method that returns objects of a varying prototype or class from some method call, which is assumed to be "new".')),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"First of all we have a door interface and the implementation"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Door"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getWidth"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"float"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getHeight"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"float"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"WoodenDoor")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Door"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$width"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$height"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$width"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$height"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"width")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$width"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"height")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$height"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getWidth"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"float"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"width"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getHeight"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"float"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"height"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we have our door factory that makes the door and returns it"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"DoorFactory"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"static")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"makeDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$width"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$height"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"Door"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"WoodenDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$width"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$height"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And then it can be used as"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Make me a door of 100x200"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token scope"}),"DoorFactory",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"::")),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"makeDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"100"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"200"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Width: '")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getWidth"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Height: '")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getHeight"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Make me a door of 50x100"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door2")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token scope"}),"DoorFactory",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"::")),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"makeDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"50"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"100"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"When to Use?")),(0,n.kt)("p",null,"When creating an object is not just a few assignments and involves some logic, it makes sense to put it in a dedicated factory instead of repeating the same code everywhere."),(0,n.kt)("h2",null,"\ud83c\udfed Factory Method"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Consider the case of a hiring manager. It is impossible for one person to interview for each of the positions. Based on the job opening, she has to decide and delegate the interview steps to different people.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"It provides a way to delegate the instantiation logic to child classes.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In class-based programming, the factory method pattern is a creational pattern that uses factory methods to deal with the problem of creating objects without having to specify the exact class of the object that will be created. This is done by creating objects by calling a factory method\u2014either specified in an interface and implemented by child classes, or implemented in a base class and optionally overridden by derived classes\u2014rather than by calling a constructor.")),(0,n.kt)("p",null," ",(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"Taking our hiring manager example above. First of all we have an interviewer interface and some implementations for it"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Interviewer"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"askQuestions"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Developer")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Interviewer"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"askQuestions"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Asking about design patterns!'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"CommunityExecutive")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Interviewer"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"askQuestions"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Asking about community building'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Now let us create our ",(0,n.kt)("inlineCode",{parentName:"p"},"HiringManager")),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"abstract")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"HiringManager"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Factory method"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"abstract")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"makeInterviewer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"Interviewer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"takeInterview"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$interviewer")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"makeInterviewer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$interviewer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"askQuestions"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n")),(0,n.kt)("p",null,"Now any child can extend it and provide the required interviewer"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"DevelopmentManager")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"extends")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"HiringManager"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"makeInterviewer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"Interviewer"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Developer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"MarketingManager")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"extends")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"HiringManager"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"makeInterviewer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"Interviewer"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"CommunityExecutive"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"and then it can be used as"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$devManager")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"DevelopmentManager"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$devManager"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"takeInterview"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output: Asking about design patterns"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$marketingManager")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"MarketingManager"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$marketingManager"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"takeInterview"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output: Asking about community building."),"\n")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"When to use?")),(0,n.kt)("p",null,"Useful when there is some generic processing in a class but the required sub-class is dynamically decided at runtime. Or putting it in other words, when the client doesn't know what exact sub-class it might need."),(0,n.kt)("h2",null,"\ud83d\udd28 Abstract Factory"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Extending our door example from Simple Factory. Based on your needs you might get a wooden door from a wooden door shop, iron door from an iron shop or a PVC door from the relevant shop. Plus you might need a guy with different kind of specialities to fit the door, for example a carpenter for wooden door, welder for iron door etc. As you can see there is a dependency between the doors now, wooden door needs carpenter, iron door needs a welder etc.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"A factory of factories; a factory that groups the individual but related/dependent factories together without specifying their concrete classes.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"The abstract factory pattern provides a way to encapsulate a group of individual factories that have a common theme without specifying their concrete classes")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"Translating the door example above. First of all we have our ",(0,n.kt)("inlineCode",{parentName:"p"},"Door")," interface and some implementation for it"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Door"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"WoodenDoor")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Door"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'I am a wooden door'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"IronDoor")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Door"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'I am an iron door'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we have some fitting experts for each door type"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"DoorFittingExpert"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Welder")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"DoorFittingExpert"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'I can only fit iron doors'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Carpenter")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"DoorFittingExpert"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'I can only fit wooden doors'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Now we have our abstract factory that would let us make family of related objects i.e. wooden door factory would create a wooden door and wooden door fitting expert and iron door factory would create an iron door and iron door fitting expert"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"DoorFactory"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"makeDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"Door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"makeFittingExpert"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"DoorFittingExpert"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Wooden factory to return carpenter and wooden door"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"WoodenDoorFactory")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"DoorFactory"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"makeDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"Door"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"WoodenDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"makeFittingExpert"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"DoorFittingExpert"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Carpenter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Iron door factory to get iron door and the relevant fitting expert"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"IronDoorFactory")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"DoorFactory"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"makeDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"Door"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"IronDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"makeFittingExpert"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"DoorFittingExpert"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Welder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And then it can be used as"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$woodenFactory")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"WoodenDoorFactory"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$woodenFactory"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"makeDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$expert")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$woodenFactory"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"makeFittingExpert"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output: I am a wooden door"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$expert"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output: I can only fit wooden doors"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Same for Iron Factory"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$ironFactory")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"IronDoorFactory"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$ironFactory"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"makeDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$expert")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$ironFactory"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"makeFittingExpert"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output: I am an iron door"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$expert"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output: I can only fit iron doors"),"\n")),(0,n.kt)("p",null,"As you can see the wooden door factory has encapsulated the ",(0,n.kt)("inlineCode",{parentName:"p"},"carpenter")," and the ",(0,n.kt)("inlineCode",{parentName:"p"},"wooden door")," also iron door factory has encapsulated the ",(0,n.kt)("inlineCode",{parentName:"p"},"iron door")," and ",(0,n.kt)("inlineCode",{parentName:"p"},"welder"),". And thus it had helped us make sure that for each of the created door, we do not get a wrong fitting expert. "),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"When to use?")),(0,n.kt)("p",null,"When there are interrelated dependencies with not-that-simple creation logic involved"),(0,n.kt)("h2",null,"\ud83d\udc77 Builder"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},'Imagine you are at Hardee\'s and you order a specific deal, lets say, "Big Hardee" and they hand it over to you without ',(0,n.kt)("em",{parentName:"p"},"any questions"),"; this is the example of simple factory. But there are cases when the creation logic might involve more steps. For example you want a customized Subway deal, you have several options in how your burger is made e.g what bread do you want? what types of sauces would you like? What cheese would you want? etc. In such cases builder pattern comes to the rescue.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Allows you to create different flavors of an object while avoiding constructor pollution. Useful when there could be several flavors of an object. Or when there are a lot of steps involved in creation of an object.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"The builder pattern is an object creation software design pattern with the intentions of finding a solution to the telescoping constructor anti-pattern.")),(0,n.kt)("p",null,"Having said that let me add a bit about what telescoping constructor anti-pattern is. At one point or the other we have all seen a constructor like below:"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$size"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$cheese")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"true"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$pepperoni")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"true"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$tomato")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"false"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lettuce")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"true"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"As you can see; the number of constructor parameters can quickly get out of hand and it might become difficult to understand the arrangement of parameters. Plus this parameter list could keep on growing if you would want to add more options in future. This is called telescoping constructor anti-pattern."),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"The sane alternative is to use the builder pattern. First of all we have our burger that we want to make"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Burger"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$size"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$cheese")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"false"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$pepperoni")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"false"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lettuce")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"false"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$tomato")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"false"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"BurgerBuilder")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$builder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"size")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$builder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"size"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"cheese")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$builder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"cheese"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"pepperoni")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$builder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"pepperoni"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"lettuce")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$builder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"lettuce"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"tomato")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$builder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"tomato"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And then we have the builder"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"BurgerBuilder"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$size"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$cheese")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"false"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$pepperoni")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"false"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lettuce")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"false"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$tomato")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"false"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"int")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$size"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"size")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$size"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"addPepperoni"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"pepperoni")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"true"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"addLettuce"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"lettuce")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"true"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"addCheese"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"cheese")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"true"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"addTomato"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"tomato")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant boolean"}),"true"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"build"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"Burger"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Burger"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And then it can be used as:"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$burger")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"BurgerBuilder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"14"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"addPepperoni"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"addLettuce"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"addTomato"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"build"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"When to use?")),(0,n.kt)("p",null,"When there could be several flavors of an object and to avoid the constructor telescoping. The key difference from the factory pattern is that; factory pattern is to be used when the creation is a one step process while builder pattern is to be used when the creation is a multi step process."),(0,n.kt)("h2",null,"\ud83d\udc11 Prototype"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Remember dolly? The sheep that was cloned! Lets not get into the details but the key point here is that it is all about cloning")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Create object based on an existing object through cloning.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"The prototype pattern is a creational design pattern in software development. It is used when the type of objects to create is determined by a prototypical instance, which is cloned to produce new objects.")),(0,n.kt)("p",null,"In short, it allows you to create a copy of an existing object and modify it to your needs, instead of going through the trouble of creating an object from scratch and setting it up."),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"In PHP, it can be easily done using ",(0,n.kt)("inlineCode",{parentName:"p"},"clone")),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Sheep"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$category"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$category")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Mountain Sheep'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"name")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"category")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$category"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"setName"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"name")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getName"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"setCategory"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$category"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"category")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$category"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getCategory"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"category"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then it can be cloned like below"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$original")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Sheep"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Jolly'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$original"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getName"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Jolly"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$original"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getCategory"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Mountain Sheep"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Clone and modify what is required"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$cloned")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"clone")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$original"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$cloned"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"setName"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Dolly'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$cloned"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getName"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Dolly"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$cloned"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getCategory"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Mountain sheep"),"\n")),(0,n.kt)("p",null,"Also you could use the magic method ",(0,n.kt)("inlineCode",{parentName:"p"},"__clone")," to modify the cloning behavior."),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"When to use?")),(0,n.kt)("p",null,"When an object is required that is similar to existing object or when the creation would be expensive as compared to cloning."),(0,n.kt)("h2",null,"\ud83d\udc8d Singleton"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"There can only be one president of a country at a time. The same president has to be brought to action, whenever duty calls. President here is singleton.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Ensures that only one object of a particular class is ever created.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In software engineering, the singleton pattern is a software design pattern that restricts the instantiation of a class to one object. This is useful when exactly one object is needed to coordinate actions across the system.")),(0,n.kt)("p",null,"Singleton pattern is actually considered an anti-pattern and overuse of it should be avoided. It is not necessarily bad and could have some valid use-cases but should be used with caution because it introduces a global state in your application and change to it in one place could affect in the other areas and it could become pretty difficult to debug. The other bad thing about them is it makes your code tightly coupled plus mocking the singleton could be difficult."),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"To create a singleton, make the constructor private, disable cloning, disable extension and create a static variable to house the instance"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"final")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"President"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"private")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"static")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$instance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"private")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Hide the constructor"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"static")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getInstance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"President"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token scope"}),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token keyword"}),"self"),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"::")),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$instance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token scope"}),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token keyword"}),"self"),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"::")),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$instance")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"self"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token scope"}),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token keyword"}),"self"),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"::")),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$instance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"private")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__clone"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Disable cloning"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"private")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__wakeup"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Disable unserialize"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then in order to use"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$president1")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token scope"}),"President",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"::")),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getInstance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$president2")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token scope"}),"President",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"::")),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getInstance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"var_dump"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$president1")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"===")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$president2"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// true"),"\n")),(0,n.kt)("h2",null,"Structural Design Patterns"),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},'Structural patterns are mostly concerned with object composition or in other words how the entities can use each other. Or yet another explanation would be, they help in answering "How to build a software component?"')),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In software engineering, structural design patterns are design patterns that ease the design by identifying a simple way to realize relationships between entities.")),(0,n.kt)("p",null,"There are 7 types of structural patterns"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-adapter"}),"Adapter")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-bridge"}),"Bridge")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-composite"}),"Composite")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-decorator"}),"Decorator")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-facade"}),"Facade")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-flyweight"}),"Flyweight")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-proxy"}),"Proxy"))),(0,n.kt)("h2",null,"\ud83d\udd0c Adapter"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Consider that you have some pictures in your memory card and you need to transfer them to your computer. In order to transfer them you need some kind of adapter that is compatible with your computer ports so that you can attach memory card to your computer. In this case card reader is an adapter.\nAnother example would be the famous power adapter; a three legged plug can't be connected to a two pronged outlet, it needs to use a power adapter that makes it compatible with the two pronged outlet.\nYet another example would be a translator translating words spoken by one person to another")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Adapter pattern lets you wrap an otherwise incompatible object in an adapter to make it compatible with another class.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In software engineering, the adapter pattern is a software design pattern that allows the interface of an existing class to be used as another interface. It is often used to make existing classes work with others without modifying their source code.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"Consider a game where there is a hunter and he hunts lions."),(0,n.kt)("p",null,"First we have an interface ",(0,n.kt)("inlineCode",{parentName:"p"},"Lion")," that all types of lions have to implement"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Lion"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"roar"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"AfricanLion")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Lion"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"roar"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"AsianLion")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Lion"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"roar"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And hunter expects any implementation of ",(0,n.kt)("inlineCode",{parentName:"p"},"Lion")," interface to hunt."),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Hunter"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"hunt"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Lion")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"roar"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Now let's say we have to add a ",(0,n.kt)("inlineCode",{parentName:"p"},"WildDog")," in our game so that hunter can hunt that also. But we can't do that directly because dog has a different interface. To make it compatible for our hunter, we will have to create an adapter that is compatible"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// This needs to be added to the game"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"WildDog"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"bark"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Adapter around wild dog to make it compatible with our game"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"WildDogAdapter")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Lion"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dog"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"WildDog")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dog"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"dog")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dog"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"roar"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"dog"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"bark"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And now the ",(0,n.kt)("inlineCode",{parentName:"p"},"WildDog")," can be used in our game using ",(0,n.kt)("inlineCode",{parentName:"p"},"WildDogAdapter"),"."),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$wildDog")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"WildDog"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$wildDogAdapter")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"WildDogAdapter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$wildDog"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$hunter")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Hunter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$hunter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"hunt"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$wildDogAdapter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n")),(0,n.kt)("h2",null,"\ud83d\udea1 Bridge"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Consider you have a website with different pages and you are supposed to allow the user to change the theme. What would you do? Create multiple copies of each of the pages for each of the themes or would you just create separate theme and load them based on the user's preferences? Bridge pattern allows you to do the second i.e.")),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"https://cloud.githubusercontent.com/assets/11269635/23065293/33b7aea0-f515-11e6-983f-98823c9845ee.png",alt:"With and without the bridge pattern"}))),(0,n.kt)("p",null,"In Plain Words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Bridge pattern is about preferring composition over inheritance. Implementation details are pushed from a hierarchy to another object with a separate hierarchy.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},'The bridge pattern is a design pattern used in software engineering that is meant to "decouple an abstraction from its implementation so that the two can vary independently"')),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"Translating our WebPage example from above. Here we have the ",(0,n.kt)("inlineCode",{parentName:"p"},"WebPage")," hierarchy"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"WebPage"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Theme")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$theme"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getContent"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"About")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"WebPage"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$theme"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Theme")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$theme"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"theme")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$theme"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getContent"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"About page in "')," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"theme"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getColor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Careers")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"WebPage"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$theme"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Theme")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$theme"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"theme")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$theme"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getContent"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Careers page in "')," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"theme"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getColor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And the separate theme hierarchy"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Theme"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getColor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"DarkTheme")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Theme"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getColor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Dark Black'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"LightTheme")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Theme"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getColor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Off white'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"AquaTheme")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Theme"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getColor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Light blue'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And both the hierarchies"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$darkTheme")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"DarkTheme"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$about")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"About"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$darkTheme"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$careers")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Careers"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$darkTheme"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$about"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getContent"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),'// "About page in Dark Black";'),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$careers"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getContent"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),'// "Careers page in Dark Black";'),"\n")),(0,n.kt)("h2",null,"\ud83c\udf3f Composite"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Every organization is composed of employees. Each of the employees has the same features i.e. has a salary, has some responsibilities, may or may not report to someone, may or may not have some subordinates etc.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Composite pattern lets clients treat the individual objects in a uniform manner.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},'In software engineering, the composite pattern is a partitioning design pattern. The composite pattern describes that a group of objects is to be treated in the same way as a single instance of an object. The intent of a composite is to "compose" objects into tree structures to represent part-whole hierarchies. Implementing the composite pattern lets clients treat individual objects and compositions uniformly.')),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"Taking our employees example from above. Here we have different employee types"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Employee"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getName"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"string"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"setSalary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getSalary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"float"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getRoles"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"array"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Developer")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Employee"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$roles"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n \n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"name")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"salary")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getName"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"string"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"setSalary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"salary")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getSalary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"float"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getRoles"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"array"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"roles"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Designer")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Employee"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$roles"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"name")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"salary")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getName"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"string"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"setSalary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"salary")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getSalary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"float"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"salary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getRoles"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"array"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"roles"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we have an organization which consists of several different types of employees"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Organization"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$employees"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"addEmployee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Employee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$employee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"employees"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$employee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getNetSalaries"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"float"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$netSalary")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"0"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"foreach")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"employees")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"as")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$employee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$netSalary")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$employee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getSalary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$netSalary"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And then it can be used as"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Prepare the employees"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$john")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Developer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'John Doe'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"12000"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jane")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Designer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Jane Doe'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"15000"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Add them to organization"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$organization")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Organization"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$organization"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"addEmployee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$john"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$organization"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"addEmployee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jane"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Net salaries: "')," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$organization"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getNetSalaries"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Net Salaries: 27000"),"\n")),(0,n.kt)("h2",null,"\u2615 Decorator"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Imagine you run a car service shop offering multiple services. Now how do you calculate the bill to be charged? You pick one service and dynamically keep adding to it the prices for the provided services till you get the final cost. Here each type of service is a decorator.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Decorator pattern lets you dynamically change the behavior of an object at run time by wrapping them in an object of a decorator class.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In object-oriented programming, the decorator pattern is a design pattern that allows behavior to be added to an individual object, either statically or dynamically, without affecting the behavior of other objects from the same class. The decorator pattern is often useful for adhering to the Single Responsibility Principle, as it allows functionality to be divided between classes with unique areas of concern.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"Lets take coffee for example. First of all we have a simple coffee implementing the coffee interface"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Coffee"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getCost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"SimpleCoffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Coffee"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getCost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"10"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Simple coffee'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"We want to make the code extensible to allow options to modify it if required. Lets make some add-ons (decorators)"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"MilkCoffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Coffee"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Coffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"coffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getCost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getCost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"2"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"', milk'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"WhipCoffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Coffee"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Coffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"coffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getCost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getCost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"5"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"', whip'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"VanillaCoffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Coffee"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Coffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"coffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getCost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getCost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"3"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"coffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"', vanilla'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Lets make a coffee now"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"SimpleCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getCost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// 10"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Simple Coffee"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"MilkCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getCost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// 12"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Simple Coffee, milk"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"WhipCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getCost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// 17"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Simple Coffee, milk, whip"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"VanillaCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getCost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// 20"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$someCoffee"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getDescription"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Simple Coffee, milk, whip, vanilla"),"\n")),(0,n.kt)("h2",null,"\ud83d\udce6 Facade"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},'How do you turn on the computer? "Hit the power button" you say! That is what you believe because you are using a simple interface that computer provides on the outside, internally it has to do a lot of stuff to make it happen. This simple interface to the complex subsystem is a facade.')),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Facade pattern provides a simplified interface to a complex subsystem.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"A facade is an object that provides a simplified interface to a larger body of code, such as a class library.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"Taking our computer example from above. Here we have the computer class"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Computer"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getElectricShock"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Ouch!"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"makeSound"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Beep beep!"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"showLoadingScreen"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Loading.."'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"bam"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Ready to be used!"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"closeEverything"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Bup bup bup buzzzz!"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"sooth"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Zzzzz"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"pullCurrent"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Haaah!"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Here we have the facade"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"ComputerFacade"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Computer")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"computer")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"turnOn"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getElectricShock"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"makeSound"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"showLoadingScreen"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"bam"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"turnOff"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"closeEverything"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"pullCurrent"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"sooth"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Now to use the facade"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$computer")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"ComputerFacade"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"turnOn"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Ouch! Beep beep! Loading.. Ready to be used!"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$computer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"turnOff"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Bup bup buzzz! Haah! Zzzzz"),"\n")),(0,n.kt)("h2",null,"\ud83c\udf43 Flyweight"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Did you ever have fresh tea from some stall? They often make more than one cup that you demanded and save the rest for any other customer so to save the resources e.g. gas etc. Flyweight pattern is all about that i.e. sharing.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"It is used to minimize memory usage or computational expenses by sharing as much as possible with similar objects.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In computer programming, flyweight is a software design pattern. A flyweight is an object that minimizes memory use by sharing as much data as possible with other similar objects; it is a way to use objects in large numbers when a simple repeated representation would use an unacceptable amount of memory.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic example")),(0,n.kt)("p",null,"Translating our tea example from above. First of all we have tea types and tea maker"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Anything that will be cached is flyweight."),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Types of tea here will be flyweights."),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"KarakTea"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Acts as a factory and saves the tea"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"TeaMaker"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$availableTea")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$preference"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"empty"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"availableTea"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$preference"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"availableTea"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$preference"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"KarakTea"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"availableTea"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$preference"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we have the ",(0,n.kt)("inlineCode",{parentName:"p"},"TeaShop")," which takes orders and serves them"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"TeaShop"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$orders"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$teaMaker"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"TeaMaker")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$teaMaker"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"teaMaker")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$teaMaker"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"takeOrder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$teaType"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"int")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$table"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"orders"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$table"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"teaMaker"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$teaType"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"serve"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"foreach")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"orders")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"as")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$table")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=>")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$tea"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Serving tea to table# "')," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$table"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And it can be used as below"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$teaMaker")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"TeaMaker"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$shop")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"TeaShop"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$teaMaker"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$shop"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"takeOrder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'less sugar'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"1"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$shop"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"takeOrder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'more milk'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"2"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$shop"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"takeOrder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'without sugar'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"5"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$shop"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"serve"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Serving tea to table# 1"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Serving tea to table# 2"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Serving tea to table# 5"),"\n")),(0,n.kt)("h2",null,"\ud83c\udfb1 Proxy"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Have you ever used an access card to go through a door? There are multiple options to open that door i.e. it can be opened either using access card or by pressing a button that bypasses the security. The door's main functionality is to open but there is a proxy added on top of it to add some functionality. Let me better explain it using the code example below.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Using the proxy pattern, a class represents the functionality of another class.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"A proxy, in its most general form, is a class functioning as an interface to something else. A proxy is a wrapper or agent object that is being called by the client to access the real serving object behind the scenes. Use of the proxy can simply be forwarding to the real object, or can provide additional logic. In the proxy extra functionality can be provided, for example caching when operations on the real object are resource intensive, or checking preconditions before operations on the real object are invoked.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"Taking our security door example from above. Firstly we have the door interface and an implementation of door"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Door"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"open"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"close"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"LabDoor")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Door"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"open"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Opening lab door"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"close"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Closing the lab door"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we have a proxy to secure any doors that we want"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"SecuredDoor"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Door")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"door")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"open"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$password"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"authenticate"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$password"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"open"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"else")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Big no! It ain\'t possible."'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"authenticate"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$password"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$password")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"===")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'$ecr@t'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"close"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"close"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And here is how it can be used"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"SecuredDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"LabDoor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"open"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'invalid'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Big no! It ain't possible."),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"open"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'$ecr@t'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Opening lab door"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$door"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"close"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Closing lab door"),"\n")),(0,n.kt)("p",null,"Yet another example would be some sort of data-mapper implementation. For example, I recently made an ODM (Object Data Mapper) for MongoDB using this pattern where I wrote a proxy around mongo classes while utilizing the magic method ",(0,n.kt)("inlineCode",{parentName:"p"},"__call()"),". All the method calls were proxied to the original mongo class and result retrieved was returned as it is but in case of ",(0,n.kt)("inlineCode",{parentName:"p"},"find")," or ",(0,n.kt)("inlineCode",{parentName:"p"},"findOne")," data was mapped to the required class objects and the object was returned instead of ",(0,n.kt)("inlineCode",{parentName:"p"},"Cursor"),"."),(0,n.kt)("h2",null,"Behavioral Design Patterns"),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},'It is concerned with assignment of responsibilities between the objects. What makes them different from structural patterns is they don\'t just specify the structure but also outline the patterns for message passing/communication between them. Or in other words, they assist in answering "How to run a behavior in software component?"')),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In software engineering, behavioral design patterns are design patterns that identify common communication patterns between objects and realize these patterns. By doing so, these patterns increase flexibility in carrying out this communication.")),(0,n.kt)("p",null,"There are 10 types of behavioral design patterns"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-chain-of-responsibility"}),"Chain of Responsibility")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-command"}),"Command")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-iterator"}),"Iterator")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-mediator"}),"Mediator")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-memento"}),"Memento")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-observer"}),"Observer")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-visitor"}),"Visitor")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-strategy"}),"Strategy")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-state"}),"State")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#-template-method"}),"Template Method"))),(0,n.kt)("h2",null,"\ud83d\udd17 Chain of Responsibility"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"For example, you have three payment methods (",(0,n.kt)("inlineCode",{parentName:"p"},"A"),", ",(0,n.kt)("inlineCode",{parentName:"p"},"B")," and ",(0,n.kt)("inlineCode",{parentName:"p"},"C"),") setup in your account; each having a different amount in it. ",(0,n.kt)("inlineCode",{parentName:"p"},"A")," has 100 USD, ",(0,n.kt)("inlineCode",{parentName:"p"},"B")," has 300 USD and ",(0,n.kt)("inlineCode",{parentName:"p"},"C")," having 1000 USD and the preference for payments is chosen as ",(0,n.kt)("inlineCode",{parentName:"p"},"A")," then ",(0,n.kt)("inlineCode",{parentName:"p"},"B")," then ",(0,n.kt)("inlineCode",{parentName:"p"},"C"),". You try to purchase something that is worth 210 USD. Using Chain of Responsibility, first of all account ",(0,n.kt)("inlineCode",{parentName:"p"},"A")," will be checked if it can make the purchase, if yes purchase will be made and the chain will be broken. If not, request will move forward to account ",(0,n.kt)("inlineCode",{parentName:"p"},"B")," checking for amount if yes chain will be broken otherwise the request will keep forwarding till it finds the suitable handler. Here ",(0,n.kt)("inlineCode",{parentName:"p"},"A"),", ",(0,n.kt)("inlineCode",{parentName:"p"},"B")," and ",(0,n.kt)("inlineCode",{parentName:"p"},"C")," are links of the chain and the whole phenomenon is Chain of Responsibility.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"It helps building a chain of objects. Request enters from one end and keeps going from object to object till it finds the suitable handler.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In object-oriented design, the chain-of-responsibility pattern is a design pattern consisting of a source of command objects and a series of processing objects. Each processing object contains logic that defines the types of command objects that it can handle; the rest are passed to the next processing object in the chain.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"Translating our account example above. First of all we have a base account having the logic for chaining the accounts together and some accounts"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"abstract")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Account"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$successor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$balance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"setNext"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Account")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$account"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"successor")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$account"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"pay"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$amountToPay"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"canPay"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$amountToPay"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"sprintf"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Paid %s using %s'")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant"}),"PHP_EOL"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$amountToPay"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"get_called_class"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"elseif")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"successor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"sprintf"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Cannot pay using %s. Proceeding ..'")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant"}),"PHP_EOL"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"get_called_class"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"successor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"pay"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$amountToPay"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"else")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"throw")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Exception"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'None of the accounts have enough balance'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"canPay"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$amount"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"bool"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"balance")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),">=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$amount"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Bank")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"extends")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Account"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$balance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$balance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"balance")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$balance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Paypal")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"extends")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Account"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$balance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$balance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"balance")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$balance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Bitcoin")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"extends")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Account"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$balance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$balance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"balance")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$balance"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Now let's prepare the chain using the links defined above (i.e. Bank, Paypal, Bitcoin)"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Let's prepare a chain like below"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// $bank->$paypal->$bitcoin"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"//"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// First priority bank"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// If bank can't pay then paypal"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// If paypal can't pay then bit coin"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bank")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Bank"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"100"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Bank with balance 100"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$paypal")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Paypal"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"200"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Paypal with balance 200"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bitcoin")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Bitcoin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"300"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Bitcoin with balance 300"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bank"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"setNext"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$paypal"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$paypal"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"setNext"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bitcoin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Let's try to pay using the first priority i.e. bank"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bank"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"pay"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"259"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output will be"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// =============="),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Cannot pay using bank. Proceeding .."),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Cannot pay using paypal. Proceeding ..:"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Paid 259 using Bitcoin!"),"\n")),(0,n.kt)("h2",null,"\ud83d\udc6e Command"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"A generic example would be you ordering food at a restaurant. You (i.e. ",(0,n.kt)("inlineCode",{parentName:"p"},"Client"),") ask the waiter (i.e. ",(0,n.kt)("inlineCode",{parentName:"p"},"Invoker"),") to bring some food (i.e. ",(0,n.kt)("inlineCode",{parentName:"p"},"Command"),") and waiter simply forwards the request to Chef (i.e. ",(0,n.kt)("inlineCode",{parentName:"p"},"Receiver"),") who has the knowledge of what and how to cook.\nAnother example would be you (i.e. ",(0,n.kt)("inlineCode",{parentName:"p"},"Client"),") switching on (i.e. ",(0,n.kt)("inlineCode",{parentName:"p"},"Command"),") the television (i.e. ",(0,n.kt)("inlineCode",{parentName:"p"},"Receiver"),") using a remote control (",(0,n.kt)("inlineCode",{parentName:"p"},"Invoker"),").")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Allows you to encapsulate actions in objects. The key idea behind this pattern is to provide the means to decouple client from receiver.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In object-oriented programming, the command pattern is a behavioral design pattern in which an object is used to encapsulate all information needed to perform an action or trigger an event at a later time. This information includes the method name, the object that owns the method and values for the method parameters.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"First of all we have the receiver that has the implementation of every action that could be performed"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Receiver"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Bulb"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"turnOn"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Bulb has been lit"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"turnOff"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Darkness!"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"then we have an interface that each of the commands are going to implement and then we have a set of commands"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Command"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"execute"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"undo"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"redo"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Command"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"TurnOn")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Command"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Bulb")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"bulb")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"execute"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"turnOn"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"undo"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"turnOff"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"redo"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"execute"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"TurnOff")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Command"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Bulb")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"bulb")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"execute"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"turnOff"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"undo"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"turnOn"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"redo"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"execute"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we have an ",(0,n.kt)("inlineCode",{parentName:"p"},"Invoker")," with whom the client will interact to process any commands"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Invoker"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"RemoteControl"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"submit"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Command")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$command"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$command"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"execute"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Finally let's see how we can use it in our client"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bulb")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$turnOn")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"TurnOn"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$turnOff")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"TurnOff"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$bulb"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$remote")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"RemoteControl"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$remote"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"submit"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$turnOn"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Bulb has been lit!"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$remote"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"submit"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$turnOff"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Darkness!"),"\n")),(0,n.kt)("p",null,"Command pattern can also be used to implement a transaction based system. Where you keep maintaining the history of commands as soon as you execute them. If the final command is successfully executed, all good otherwise just iterate through the history and keep executing the ",(0,n.kt)("inlineCode",{parentName:"p"},"undo")," on all the executed commands."),(0,n.kt)("h2",null,"\u27bf Iterator"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"An old radio set will be a good example of iterator, where user could start at some channel and then use next or previous buttons to go through the respective channels. Or take an example of MP3 player or a TV set where you could press the next and previous buttons to go through the consecutive channels or in other words they all provide an interface to iterate through the respective channels, songs or radio stations. ")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"It presents a way to access the elements of an object without exposing the underlying presentation.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In object-oriented programming, the iterator pattern is a design pattern in which an iterator is used to traverse a container and access the container's elements. The iterator pattern decouples algorithms from containers; in some cases, algorithms are necessarily container-specific and thus cannot be decoupled.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic example")),(0,n.kt)("p",null,"In PHP it is quite easy to implement using SPL (Standard PHP Library). Translating our radio stations example from above. First of all we have ",(0,n.kt)("inlineCode",{parentName:"p"},"RadioStation")),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"RadioStation"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$frequency"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"float")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$frequency"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"frequency")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$frequency"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getFrequency"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"float"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"frequency"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we have our iterator"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"use")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token package"}),"Countable"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"use")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token package"}),"Iterator"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"StationList")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Countable"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," Iterator\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token doc-comment comment"}),"/** ",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token keyword"}),"@var")," ",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token class-name"}),"RadioStation",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"]"))," ",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token parameter"}),"$stations")," */"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$stations")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token doc-comment comment"}),"/** ",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token keyword"}),"@var")," ",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token class-name"}),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token keyword"}),"int"))," ",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token parameter"}),"$counter")," */"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$counter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"addStation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"RadioStation")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$station"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"stations"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$station"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"removeStation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"RadioStation")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$toRemove"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$toRemoveFrequency")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$toRemove"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getFrequency"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"stations")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"array_filter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"stations"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"RadioStation")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$station"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"use")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$toRemoveFrequency"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$station"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getFrequency"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!==")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$toRemoveFrequency"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"count"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"int"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"count"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"stations"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"current"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name return-type"}),"RadioStation"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"stations"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"counter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"key"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"counter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"next"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"counter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"++"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"rewind"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"counter")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"0"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"valid"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"bool"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"isset"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"stations"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"counter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And then it can be used as"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$stationList")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"StationList"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$stationList"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"addStation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"RadioStation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"89"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$stationList"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"addStation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"RadioStation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"101"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$stationList"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"addStation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"RadioStation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"102"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$stationList"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"addStation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"RadioStation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"103.2"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"foreach"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$stationList")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"as")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$station"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$station"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getFrequency"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token constant"}),"PHP_EOL"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$stationList"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"removeStation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"RadioStation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"89"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Will remove station 89"),"\n")),(0,n.kt)("h2",null,"\ud83d\udc7d Mediator"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"A general example would be when you talk to someone on your mobile phone, there is a network provider sitting between you and them and your conversation goes through it instead of being directly sent. In this case network provider is mediator.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Mediator pattern adds a third party object (called mediator) to control the interaction between two objects (called colleagues). It helps reduce the coupling between the classes communicating with each other. Because now they don't need to have the knowledge of each other's implementation.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In software engineering, the mediator pattern defines an object that encapsulates how a set of objects interact. This pattern is considered to be a behavioral pattern due to the way it can alter the program's running behavior.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"Here is the simplest example of a chat room (i.e. mediator) with users (i.e. colleagues) sending messages to each other."),(0,n.kt)("p",null,"First of all, we have the mediator i.e. the chat room"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"ChatRoomMediator")," \n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"showMessage"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"User")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$user"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$message"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Mediator"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"ChatRoom")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"ChatRoomMediator"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"showMessage"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"User")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$user"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$message"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$time")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"date"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'M d, y H:i'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$sender")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$user"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getName"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$time")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'['")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$sender")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"']:'")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$message"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we have our users i.e. colleagues"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"User")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$chatMediator"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"ChatRoomMediator")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$chatMediator"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"name")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"chatMediator")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$chatMediator"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getName"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"send"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$message"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"chatMediator"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"showMessage"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$message"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And the usage"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$mediator")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"ChatRoom"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$john")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"User"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'John Doe'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$mediator"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jane")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"User"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Jane Doe'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$mediator"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$john"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"send"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Hi there!'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jane"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"send"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Hey!'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output will be"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Feb 14, 10:58 [John]: Hi there!"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Feb 14, 10:58 [Jane]: Hey!"),"\n")),(0,n.kt)("h2",null,"\ud83d\udcbe Memento"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Take the example of calculator (i.e. originator), where whenever you perform some calculation the last calculation is saved in memory (i.e. memento) so that you can get back to it and maybe get it restored using some action buttons (i.e. caretaker).")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Memento pattern is about capturing and storing the current state of an object in a manner that it can be restored later on in a smooth manner.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"The memento pattern is a software design pattern that provides the ability to restore an object to its previous state (undo via rollback).")),(0,n.kt)("p",null,"Usually useful when you need to provide some sort of undo functionality."),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"Lets take an example of text editor which keeps saving the state from time to time and that you can restore if you want."),(0,n.kt)("p",null,"First of all we have our memento object that will be able to hold the editor state"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"EditorMemento"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$content"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$content"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"content")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$content"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getContent"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"content"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we have our editor i.e. originator that is going to use memento object"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Editor"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$content")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"''"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"type"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$words"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"content")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"content")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"' '")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$words"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getContent"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"content"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"save"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"EditorMemento"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"content"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"restore"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"EditorMemento")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$memento"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"content")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$memento"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getContent"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And then it can be used as"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Type some stuff"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"type"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'This is the first sentence.'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"type"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'This is second.'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Save the state to restore to : This is the first sentence. This is second."),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$saved")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"save"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Type some more"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"type"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'And this is third.'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output: Content before Saving"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getContent"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// This is the first sentence. This is second. And this is third."),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Restoring to last saved state"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"restore"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$saved"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getContent"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// This is the first sentence. This is second."),"\n")),(0,n.kt)("h2",null,"\ud83d\ude0e Observer"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"A good example would be the job seekers where they subscribe to some job posting site and they are notified whenever there is a matching job opportunity. ")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Defines a dependency between objects so that whenever an object changes its state, all its dependents are notified.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"The observer pattern is a software design pattern in which an object, called the subject, maintains a list of its dependents, called observers, and notifies them automatically of any state changes, usually by calling one of their methods.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic example")),(0,n.kt)("p",null,"Translating our example from above. First of all we have job seekers that need to be notified for a job posting"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"JobPost"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$title"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$title"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"title")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$title"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"getTitle"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"title"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"JobSeeker")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Observer"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"name")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$name"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"onJobPosted"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"JobPost")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$job"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Do something with the job posting"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Hi '")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"name")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'! New job posted: '"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),".")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$job"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"getTitle"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we have our job postings to which the job seekers will subscribe"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"EmploymentAgency")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Observable"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$observers")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"notify"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"JobPost")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jobPosting"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"foreach")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"observers")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"as")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$observer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$observer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"onJobPosted"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jobPosting"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"attach"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Observer")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$observer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"observers"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$observer"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"addJob"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"JobPost")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jobPosting"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"notify"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jobPosting"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then it can be used as"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Create subscribers"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$johnDoe")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"JobSeeker"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'John Doe'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$janeDoe")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"JobSeeker"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Jane Doe'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Create publisher and attach subscribers"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jobPostings")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"EmploymentAgency"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jobPostings"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"attach"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$johnDoe"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jobPostings"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"attach"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$janeDoe"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Add a new job and see if subscribers get notified"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jobPostings"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"addJob"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"JobPost"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Software Engineer'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Hi John Doe! New job posted: Software Engineer"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Hi Jane Doe! New job posted: Software Engineer"),"\n")),(0,n.kt)("h2",null,"\ud83c\udfc3 Visitor"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Consider someone visiting Dubai. They just need a way (i.e. visa) to enter Dubai. After arrival, they can come and visit any place in Dubai on their own without having to ask for permission or to do some leg work in order to visit any place here; just let them know of a place and they can visit it. Visitor pattern lets you do just that, it helps you add places to visit so that they can visit as much as they can without having to do any legwork.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Visitor pattern lets you add further operations to objects without having to modify them.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In object-oriented programming and software engineering, the visitor design pattern is a way of separating an algorithm from an object structure on which it operates. A practical result of this separation is the ability to add new operations to existing object structures without modifying those structures. It is one way to follow the open/closed principle.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic example")),(0,n.kt)("p",null,"Let's take an example of a zoo simulation where we have several different kinds of animals and we have to make them Sound. Let's translate this using visitor pattern"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Visitee"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Animal"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"AnimalOperation")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$operation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Visitor"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"AnimalOperation"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"visitMonkey"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Monkey")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$monkey"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"visitLion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Lion")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"visitDolphin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Dolphin")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dolphin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we have our implementations for the animals"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Monkey")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Animal"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"shout"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Ooh oo aa aa!'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"AnimalOperation")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$operation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$operation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"visitMonkey"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Lion")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Animal"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"roar"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Roaaar!'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"AnimalOperation")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$operation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$operation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"visitLion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Dolphin")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Animal"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"speak"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Tuut tuttu tuutt!'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"AnimalOperation")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$operation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$operation"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"visitDolphin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Let's implement our visitor"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Speak")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"AnimalOperation"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"visitMonkey"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Monkey")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$monkey"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$monkey"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"shout"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"visitLion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Lion")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"roar"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"visitDolphin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Dolphin")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dolphin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dolphin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"speak"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And then it can be used as"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$monkey")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Monkey"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lion")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Lion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dolphin")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Dolphin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$speak")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Speak"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$monkey"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$speak"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Ooh oo aa aa! "),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$speak"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Roaaar!"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dolphin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$speak"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Tuut tutt tuutt!"),"\n")),(0,n.kt)("p",null,"We could have done this simply by having an inheritance hierarchy for the animals but then we would have to modify the animals whenever we would have to add new actions to animals. But now we will not have to change them. For example, let's say we are asked to add the jump behavior to the animals, we can simply add that by creating a new visitor i.e."),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Jump")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"AnimalOperation"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"visitMonkey"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Monkey")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$monkey"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Jumped 20 feet high! on to the tree!'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"visitLion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Lion")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Jumped 7 feet! Back on the ground!'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"visitDolphin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"Dolphin")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dolphin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Walked on water a little and disappeared'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And for the usage"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jump")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Jump"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$monkey"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$speak"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Ooh oo aa aa!"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$monkey"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jump"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Jumped 20 feet high! on to the tree!"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$speak"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Roaaar!"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$lion"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jump"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Jumped 7 feet! Back on the ground!"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dolphin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$speak"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Tuut tutt tuutt!"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dolphin"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"accept"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$jump"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Walked on water a little and disappeared"),"\n")),(0,n.kt)("h2",null,"\ud83d\udca1 Strategy"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Consider the example of sorting, we implemented bubble sort but the data started to grow and bubble sort started getting very slow. In order to tackle this we implemented Quick sort. But now although the quick sort algorithm was doing better for large datasets, it was very slow for smaller datasets. In order to handle this we implemented a strategy where for small datasets, bubble sort will be used and for larger, quick sort.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Strategy pattern allows you to switch the algorithm or strategy based upon the situation.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In computer programming, the strategy pattern (also known as the policy pattern) is a behavioural software design pattern that enables an algorithm's behavior to be selected at runtime.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic example")),(0,n.kt)("p",null,"Translating our example from above. First of all we have our strategy interface and different strategy implementations"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"SortStrategy"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"sort"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"array")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dataset"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"array"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"BubbleSortStrategy")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"SortStrategy"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"sort"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"array")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dataset"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"array"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Sorting using bubble sort"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Do sorting"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dataset"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"QuickSortStrategy")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"SortStrategy"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"sort"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"array")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dataset"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"array"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string double-quoted-string"}),'"Sorting using quick sort"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Do sorting"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dataset"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And then we have our client that is going to use any strategy"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Sorter"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$sorter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"SortStrategy")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$sorter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"sorter")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$sorter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"sort"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"array")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dataset"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword return-type"}),"array"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"sorter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"sort"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dataset"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And it can be used as"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dataset")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"1"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"5"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"4"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"3"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"2"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"8"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$sorter")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Sorter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"BubbleSortStrategy"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$sorter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"sort"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dataset"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output : Sorting using bubble sort"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$sorter")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Sorter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"QuickSortStrategy"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$sorter"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"sort"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$dataset"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output : Sorting using quick sort"),"\n")),(0,n.kt)("h2",null,"\ud83d\udca2 State"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Imagine you are using some drawing application, you choose the paint brush to draw. Now the brush changes its behavior based on the selected color i.e. if you have chosen red color it will draw in red, if blue then it will be in blue etc. ")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"It lets you change the behavior of a class when the state changes.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"The state pattern is a behavioral software design pattern that implements a state machine in an object-oriented way. With the state pattern, a state machine is implemented by implementing each individual state as a derived class of the state pattern interface, and implementing state transitions by invoking methods defined by the pattern's superclass.\nThe state pattern can be interpreted as a strategy pattern which is able to switch the current strategy through invocations of methods defined in the pattern's interface.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic example")),(0,n.kt)("p",null,"Let's take an example of text editor, it lets you change the state of text that is typed i.e. if you have selected bold, it starts writing in bold, if italic then in italics etc."),(0,n.kt)("p",null,"First of all we have our state interface and some state implementations"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"interface")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"WritingState"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"write"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$words"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"UpperCase")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"WritingState"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"write"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$words"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"strtoupper"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$words"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"LowerCase")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"WritingState"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"write"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$words"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"strtolower"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$words"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"DefaultText")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"implements")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"WritingState"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"write"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$words"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$words"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we have our editor"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"TextEditor"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"protected")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$state"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"__construct"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"WritingState")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$state"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"state")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$state"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"setState"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name type-declaration"}),"WritingState")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$state"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"state")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$state"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"type"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword type-hint"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$words"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token property"}),"state"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"write"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$words"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And then it can be used as"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"TextEditor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"DefaultText"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"type"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'First line'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"setState"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"UpperCase"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"type"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Second line'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"type"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Third line'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"setState"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"LowerCase"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"type"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Fourth line'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$editor"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"type"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Fifth line'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output:"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// First line"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// SECOND LINE"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// THIRD LINE"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// fourth line"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// fifth line"),"\n")),(0,n.kt)("h2",null,"\ud83d\udcd2 Template Method"),(0,n.kt)("p",null,"Real world example"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Suppose we are getting some house built. The steps for building might look like"),(0,n.kt)("ul",{parentName:"blockquote"},(0,n.kt)("li",{parentName:"ul"},"Prepare the base of house"),(0,n.kt)("li",{parentName:"ul"},"Build the walls"),(0,n.kt)("li",{parentName:"ul"},"Add roof"),(0,n.kt)("li",{parentName:"ul"},"Add other floors"))),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"The order of these steps could never be changed i.e. you can't build the roof before building the walls etc but each of the steps could be modified for example walls can be made of wood or polyester or stone.")),(0,n.kt)("p",null,"In plain words"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Template method defines the skeleton of how a certain algorithm could be performed, but defers the implementation of those steps to the children classes.")),(0,n.kt)("p",null,"Wikipedia says"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"In software engineering, the template method pattern is a behavioral design pattern that defines the program skeleton of an algorithm in an operation, deferring some steps to subclasses. It lets one redefine certain steps of an algorithm without changing the algorithm's structure.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"Programmatic Example")),(0,n.kt)("p",null,"Imagine we have a build tool that helps us test, lint, build, generate build reports (i.e. code coverage reports, linting report etc) and deploy our app on the test server."),(0,n.kt)("p",null,"First of all we have our base class that specifies the skeleton for the build algorithm"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"abstract")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"Builder"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Template method"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"final")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"build"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"test"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"lint"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"assemble"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token this"}),"$this"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"deploy"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"abstract")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"test"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"abstract")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"lint"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"abstract")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"assemble"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"abstract")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"deploy"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Then we can have our implementations"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"AndroidBuilder")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"extends")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Builder"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"test"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Running android tests'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"lint"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Linting the android code'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"assemble"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Assembling the android build'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"deploy"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Deploying android build to server'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"class")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name-definition class-name"}),"IosBuilder")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"extends")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"Builder"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"test"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Running ios tests'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"lint"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Linting the ios code'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"assemble"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Assembling the ios build'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"public")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"function")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function-definition function"}),"deploy"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"echo")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string single-quoted-string"}),"'Deploying ios build to server'"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"And then it can be used as"),(0,n.kt)("pre",Object.assign({},{className:"language-php"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-php"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$androidBuilder")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"AndroidBuilder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$androidBuilder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"build"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output:"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Running android tests"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Linting the android code"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Assembling the android build"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Deploying android build to server"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$iosBuilder")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"new")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token class-name"}),"IosBuilder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token variable"}),"$iosBuilder"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"->"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"build"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Output:"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Running ios tests"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Linting the ios code"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Assembling the ios build"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Deploying ios build to server"),"\n")),(0,n.kt)("h2",null,"Wrap Up Folks"),(0,n.kt)("p",null,"And that about wraps it up. I will continue to improve this, so you might want to watch/star this repository to revisit. Also, I have plans on writing the same about the architectural patterns, stay tuned for it."))}c.isMDXComponent=!0},8303:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/dhcp.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/dhcp.png",alt:null})))))}c.isMDXComponent=!0},6210:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"DNS or Domain Name System is one of the fundamental blocks of the internet. As a developer, you should have at-least the basic understanding of how it works. This article is a brief introduction to what is DNS and how it works."),(0,n.kt)("p",null,"DNS at its simplest is like a phonebook on your mobile phone. Whenever you have to call one of your contacts, you can either dial their number from your memory or use their name which will then be used by your mobile phone to search their number in your phone book to call them. Every time you make a new friend, or your existing friend gets a mobile phone, you have to memorize their phone number or save it in your phonebook to be able to call them later on. DNS or Domain Name System, in a similar fashion, is a mechanism that allows you to browse websites on the internet. Just like your mobile phone does not know how to call without knowing the phone number, your browser does not know how to open a website just by the domain name; it needs to know the IP Address for the website to open. You can either type the IP Address to open, or provide the domain name and press enter which will then be used by your browser to find the IP address by going through several hoops. The picture below is the illustration of how your browser finds a website on the internet."),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://i.imgur.com/z9rwm5A.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"https://i.imgur.com/z9rwm5A.png",alt:null})))))}c.isMDXComponent=!0},5263:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"Around 10 years ago, Jeff Atwood (the founder of stackoverflow) made a case that JavaScript is going to be the future and he coined the \u201cAtwood Law\u201d which states that ",(0,n.kt)("em",{parentName:"p"},"Any application that can be written in JavaScript will eventually be written in JavaScript"),". Fast-forward to today, 10 years later, if you look at it it rings truer than ever. JavaScript is continuing to gain more and more adoption."),(0,n.kt)("h3",null,"JavaScript is announced"),(0,n.kt)("p",null,"JavaScript was initially created by ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://twitter.com/BrendanEich"}),"Brendan Eich")," of NetScape and was first announced in a press release by Netscape in 1995. It has a bizarre history of naming; initally it was named ",(0,n.kt)("inlineCode",{parentName:"p"},"Mocha")," by the creator, which was later renamed to ",(0,n.kt)("inlineCode",{parentName:"p"},"LiveScript"),". In 1996, about a year later after the release, NetScape decided to rename it to be ",(0,n.kt)("inlineCode",{parentName:"p"},"JavaScript")," with hopes of capitalizing on the Java community (although JavaScript did not have any relationship with Java) and released Netscape 2.0 with the official support of JavaScript."),(0,n.kt)("h3",null,"ES1, ES2 and ES3"),(0,n.kt)("p",null,"In 1996, Netscape decided to submit it to ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://en.wikipedia.org/wiki/Ecma_International"}),"ECMA International")," with the hopes of getting it standardized. First edition of the standard specification was released in 1997 and the language was standardized. After the initial release, ",(0,n.kt)("inlineCode",{parentName:"p"},"ECMAScript")," was continued to be worked upon and in no-time two more versions were released ECMAScript 2 in 1998 and ECMAScript 3 in 1999."),(0,n.kt)("h3",null,"Decade of Silence and ES4"),(0,n.kt)("p",null,"After the release of ES3 in 1999, there was a complete silence for a decade and no changes were made to the official standard. There was some work on the fourth edition in the initial days; some of the features that were being discussed included classes, modules, static typings, destructuring etc. It was being targeted to be released by 2008 but was abandoned due to political differences concerning language complexity. However, the vendors kept introducing the extensions to the language and the developers were left scratching their heads \u2014 adding polyfills to battle compatibility issues between different browsers."),(0,n.kt)("h3",null,"From silence to ES5"),(0,n.kt)("p",null,"Google, Microsoft, Yahoo and other disputers of ES4 came together and decided to work on a less ambitious update to ES3 tentatively named ES3.1. But the teams were still fighting about what to include from ES4 and what not. Finally, in 2009 ES5 was released mainly focusing on fixing the compatibility and security issues etc. But there wasn\u2019t much of a splash in the water \u2014 it took ages for the vendors to incorporate the standards and many developers were still using ES3 without being aware of the \u201cmodern\u201d standards."),(0,n.kt)("h3",null,"Release of ES6 \u2014 ECMAScript 2015"),(0,n.kt)("p",null,"After a few years of the release of ES5, things started to change, TC39 (the committee under ECMA international responsible for ECMAScript standardization) kept working on the next version of ECMAScript (ES6) which was originally named ES Harmony, before being eventually released with the name ES2015. ES2015 adds significant features and syntactic sugar to allow writing complex applications. Some of the features that ES6 has to offer, include Classes, Modules, Arrows, Enhanced object literals, Template strings, Destructuring, Default param values + rest + spread, Let and Const, Iterators + for..of, Generators, Maps + Sets, Proxies, Symbols, Promises, math + number + string + array + object APIs ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"http://es6-features.org/#Constants"}),"etc")),(0,n.kt)("p",null,"Browser support for ES6 is still scarce but everything that ES6 has to offer is still available to developers by transpiling the ES6 code to ES5. With the release of 6th version of ECMAScript, TC39 decided to move to yearly model of releasing updates to ECMAScript so to make sure that the new features are added as soon as they are approved and we don\u2019t have to wait for the full specification to be drafted and approved \u2014 thus 6th version of ECMAScript was renamed as ECMAScript 2015 or ES2015 before the release in June 2015. And the next versions of ECMAScript were decided to published in June of every year."),(0,n.kt)("h3",null,"Release of ES7 \u2014 ECMAScript 2016"),(0,n.kt)("p",null,"In June 2016, seventh version of ECMAScript was released. As ECMAScript has been moved to an yearly release model, ECMAScript 2016 (ES2016) comparatively did not have much to offer. ES2016 includes just two new features"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"Exponentiation operator ",(0,n.kt)("inlineCode",{parentName:"li"},"**")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("inlineCode",{parentName:"li"},"Array.prototype.includes"))),(0,n.kt)("h3",null,"Release of ES8 \u2014 ECMAScript 2017"),(0,n.kt)("p",null,"The eighth version of ECMAScript was released in June 2017. The key highlight of ES8 was the addition of async functions. Here is the list of new features in ES8"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("inlineCode",{parentName:"li"},"Object.values()")," and ",(0,n.kt)("inlineCode",{parentName:"li"},"Object.entries()")),(0,n.kt)("li",{parentName:"ul"},"String padding i.e. ",(0,n.kt)("inlineCode",{parentName:"li"},"String.prototype.padEnd()")," and ",(0,n.kt)("inlineCode",{parentName:"li"},"String.prototype.padStart()")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("inlineCode",{parentName:"li"},"Object.getOwnPropertyDescriptors")),(0,n.kt)("li",{parentName:"ul"},"Trailing commas in function parameter lists and calls"),(0,n.kt)("li",{parentName:"ul"},"Async functions")),(0,n.kt)("h3",null,"What is ESNext then?"),(0,n.kt)("p",null,"ESNext is a dynamic name that refers to whatever the current version of ECMAScript is at the given time. For example, at the time of this writing ",(0,n.kt)("inlineCode",{parentName:"p"},"ES2017")," or ",(0,n.kt)("inlineCode",{parentName:"p"},"ES8")," is ",(0,n.kt)("inlineCode",{parentName:"p"},"ESNext"),"."),(0,n.kt)("h3",null,"What does the future hold?"),(0,n.kt)("p",null,"Since the release of ES6, ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/tc39"}),"TC39")," has quite streamlined their process. TC39 operates through a Github organization now and there are ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/tc39/proposals"}),"several proposals")," for new features or syntax to be added to the next versions of ECMAScript. Any one can go ahead and ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/tc39/proposals"}),"submit a proposal")," thus resulting in increasing the participation from the community. Every proposal goes through ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://tc39.github.io/process-document/"}),"four stages of maturity")," before it makes it into the specification."),(0,n.kt)("p",null,"And that about wraps it up. Feel free to leave your feedback in the comments section below. Also here are the links to original language specifications ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://www.ecma-international.org/ecma-262/6.0/"}),"ES6"),", ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://www.ecma-international.org/ecma-262/7.0/"}),"ES7")," and ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://www.ecma-international.org/ecma-262/8.0/"}),"ES8"),"."))}c.isMDXComponent=!0},299:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"As users, we easily get frustrated by the buffering videos, the images that take seconds to load, pages that got stuck because the content is being loaded. Loading the resources from some cache is much faster than fetching the same from the originating server. It reduces latency, speeds up the loading of resources, decreases the load on server, cuts down the bandwidth costs etc. "),(0,n.kt)("h3",null,"Introduction"),(0,n.kt)("p",null,"What is web cache? It is something that sits somewhere between the client and the server, continuously looking at the requests and their responses, looking for any responses that can be cached. So that there is less time consumed when the same request is made again. "),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"https://i.imgur.com/mJYVvTh.png",alt:"Web Cache"}))),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Note that this image is just to give you an idea. Depending upon the type of cache, the place where it is implemented could vary. More on this later.")),(0,n.kt)("p",null,"Before we get into further details, let me give you an overview of the terms that will be used, further in the article"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("strong",{parentName:"li"},"Client")," could be your browser or any application requesting the server for some resource"),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("strong",{parentName:"li"},"Origin Server"),", the source of truth, houses all the content required by the client and is responsible for fulfilling the client requests."),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("strong",{parentName:"li"},"Stale Content")," is the cached but expired content"),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("strong",{parentName:"li"},"Fresh Content")," is the content available in cache that hasn't expired yet"),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("strong",{parentName:"li"},"Cache Validation")," is the process of contacting the server to check the validity of the cached content and get it updated for when it is going to expire"),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("strong",{parentName:"li"},"Cache Invalidation")," is the process of removing any stale content available in the cache")),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"https://i.imgur.com/9MjlzvW.png",alt:null}))),(0,n.kt)("h3",null,"Caching Locations"),(0,n.kt)("p",null,"Web cache can be shared or private depending upon the location where it exists. Here is the list of different caching locations"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#browser-cache"}),"Browser Cache")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#proxy-cache"}),"Proxy Cache")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#reverse-proxy-cache"}),"Reverse Proxy Cache"))),(0,n.kt)("h4",null,"Browser Cache"),(0,n.kt)("p",null,"You might have noticed that when you click the back button in your browser it takes less time to load the page than the time that it took during the first load; this is the browser cache in play. Browser cache is the most common location for caching and browsers usually reserve some space for it."),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"https://i.imgur.com/mJYVvTh.png",alt:"Web Cache"}))),(0,n.kt)("p",null,'A browser cache is limited to just one user and unlike other caches, it can store the "private" responses. More on it later.'),(0,n.kt)("h4",null,"Proxy Cache"),(0,n.kt)("p",null,"Unlike browser cache which serves a single user, proxy caches may serve hundreds of different users accessing the same content. They are usually implemented on a broader level by ISPs or any other independent entities for example."),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"https://i.imgur.com/3mj6e1O.png",alt:"Proxy Cache"}))),(0,n.kt)("h4",null,"Reverse Proxy Cache"),(0,n.kt)("p",null,"Reverse proxy cache or surrogate cache is implemented close to the origin servers in order to reduce the load on server. Unlike proxy caches which are implemented by ISPs etc to reduce the bandwidth usage in a network, surrogates or reverse proxy caches are implemented near to the origin servers by the server administrators to reduce the load on server."),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"http://i.imgur.com/Eg4Cru3.png",alt:"Reverse Proxy Cache"}))),(0,n.kt)("p",null,"Although you can control the reverse proxy caches (since it is implemented by you on your server) you can not avoid or control browser and proxy caches. And if your website is not configured to use these caches properly, it will still be cached using whatever the defaults are set on these caches."),(0,n.kt)("h3",null,"Caching Headers"),(0,n.kt)("p",null,"So, how do we control the web cache? Whenever the server emits some response, it is accompanied with some HTTP headers to guide the caches whether and how to cache this response. Content provider is the one that has to make sure to return proper HTTP headers to force the caches on how to cache the content."),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#expires"}),"Expires")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#pragma"}),"Pragma")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#cache-control"}),"Cache-Control"),(0,n.kt)("ul",{parentName:"li"},(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#private"}),"private")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#public"}),"public")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#no-store"}),"no-store")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#no-cache"}),"no-cache")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#max-age"}),"max-age: seconds")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#s-maxage"}),"s-maxage: seconds")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#must-revalidate"}),"must-revalidate")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#proxy-revalidate"}),"proxy-revalidate")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#mixing-values"}),"Mixing Values")))),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#validators"}),"Validators"),(0,n.kt)("ul",{parentName:"li"},(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#etag"}),"ETag")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#last-modified"}),"Last-Modified"))))),(0,n.kt)("h4",null,"Expires"),(0,n.kt)("p",null,"Before HTTP/1.1 and introduction of ",(0,n.kt)("inlineCode",{parentName:"p"},"Cache-Control"),", there was ",(0,n.kt)("inlineCode",{parentName:"p"},"Expires")," header which is simply a timestamp telling the caches how long should some content be considered fresh. Possible value to this header is absolute expiry date; where date has to be in GMT. Below is the sample header"),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"Expires: Mon, 13 Mar 2017 12:22:00 GMT\n")),(0,n.kt)("p",null,"It should be noted that the date cannot be more than a year and if the date format is wrong, content will be considered stale. Also, the clock on cache has to be in sync with the clock on server, otherwise the desired results might not be achieved. "),(0,n.kt)("p",null,"Although, ",(0,n.kt)("inlineCode",{parentName:"p"},"Expires")," header is still valid and is supported widely by the caches, preference should be given to HTTP/1.1 successor of it i.e. ",(0,n.kt)("inlineCode",{parentName:"p"},"Cache-Control"),". "),(0,n.kt)("h4",null,"Pragma"),(0,n.kt)("p",null,"Another one from the old, pre HTTP/1.1 days, is ",(0,n.kt)("inlineCode",{parentName:"p"},"Pragma"),". Everything that it could do is now possible using the cache-control header given below. However, one thing I would like to point out about it is, you might see ",(0,n.kt)("inlineCode",{parentName:"p"},"Pragma: no-cache")," being used here and there in hopes of stopping the response from being cached. It might not necessarily work; as HTTP specification discusses it in the request headers and there is no mention of it in the response headers. Rather ",(0,n.kt)("inlineCode",{parentName:"p"},"Cache-Control")," header should be used to control the caching."),(0,n.kt)("h4",null,"Cache-Control"),(0,n.kt)("p",null,"Cache-Control specifies how long and in what manner should the content be cached. This family of headers was introduced in HTTP/1.1 to overcome the limitations of the ",(0,n.kt)("inlineCode",{parentName:"p"},"Expires")," header."),(0,n.kt)("p",null,"Value for the ",(0,n.kt)("inlineCode",{parentName:"p"},"Cache-Control")," header is composite i.e. it can have multiple directive/values. Let's look at the possible values that this header may contain. "),(0,n.kt)("h5",null,"private"),(0,n.kt)("p",null,"Setting the cache to ",(0,n.kt)("inlineCode",{parentName:"p"},"private")," means that the content will not be cached in any of the proxies and it will only be cached by the client (i.e. browser)"),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"Cache-Control: private\n")),(0,n.kt)("p",null,"Having said that, don't let it fool you in to thinking that setting this header will make your data any secure; you still have to use SSL for that purpose. "),(0,n.kt)("h5",null,"public"),(0,n.kt)("p",null,"If set to ",(0,n.kt)("inlineCode",{parentName:"p"},"public"),", apart from being cached by the client, it can also be cached by the proxies; serving many other users"),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"Cache-Control: public\n")),(0,n.kt)("h5",null,"no-store"),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},(0,n.kt)("inlineCode",{parentName:"strong"},"no-store"))," specifies that the content is not to be cached by any of the caches"),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"Cache-Control: no-store\n")),(0,n.kt)("h5",null,"no-cache"),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},(0,n.kt)("inlineCode",{parentName:"strong"},"no-cache"))," indicates that the cache can be maintained but the cached content is to be re-validated (using ",(0,n.kt)("inlineCode",{parentName:"p"},"ETag")," for example) from the server before being served. That is, there is still a request to server but for validation and not to download the cached content."),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"Cache-Control: max-age=3600, no-cache, public\n")),(0,n.kt)("h5",null,"max-age: seconds"),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},(0,n.kt)("inlineCode",{parentName:"strong"},"max-age"))," specifies the number of seconds for which the content will be cached. For example, if the ",(0,n.kt)("inlineCode",{parentName:"p"},"cache-control")," looks like below:"),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"Cache-Control: max-age=3600, public\n")),(0,n.kt)("p",null,"it would mean that the content is publicly cacheable and will be considered stale after 60 minutes"),(0,n.kt)("h5",null,"s-maxage: seconds"),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},(0,n.kt)("inlineCode",{parentName:"strong"},"s-maxage"))," here ",(0,n.kt)("inlineCode",{parentName:"p"},"s-")," prefix stands for shared. This directive specifically targets the shared caches. Like ",(0,n.kt)("inlineCode",{parentName:"p"},"max-age")," it also gets the number of seconds for which something is to be cached. If present, it will override ",(0,n.kt)("inlineCode",{parentName:"p"},"max-age")," and ",(0,n.kt)("inlineCode",{parentName:"p"},"expires")," headers for shared caching."),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"Cache-Control: s-maxage=3600, public\n")),(0,n.kt)("h5",null,"must-revalidate"),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},(0,n.kt)("inlineCode",{parentName:"strong"},"must-revalidate"))," it might happen sometimes that if you have network problems and the content cannot be retrieved from the server, browser may serve stale content without validation. ",(0,n.kt)("inlineCode",{parentName:"p"},"must-revalidate")," avoids that. If this directive is present, it means that stale content cannot be served in any case and the data must be re-validated from the server before serving. "),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"Cache-Control: max-age=3600, public, must-revalidate\n")),(0,n.kt)("h5",null,"proxy-revalidate"),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},(0,n.kt)("inlineCode",{parentName:"strong"},"proxy-revalidate"))," is similar to ",(0,n.kt)("inlineCode",{parentName:"p"},"must-revalidate")," but it specifies the same for shared or proxy caches. In other words ",(0,n.kt)("inlineCode",{parentName:"p"},"proxy-revalidate")," is to ",(0,n.kt)("inlineCode",{parentName:"p"},"must-revalidate")," as ",(0,n.kt)("inlineCode",{parentName:"p"},"s-maxage")," is to ",(0,n.kt)("inlineCode",{parentName:"p"},"max-age"),". But why did they not call it ",(0,n.kt)("inlineCode",{parentName:"p"},"s-revalidate"),"?. I have no idea why, if you have any clue please leave a comment below. "),(0,n.kt)("h5",null,"Mixing Values"),(0,n.kt)("p",null,"You can combine these directives in different ways to achieve different caching behaviors, however ",(0,n.kt)("inlineCode",{parentName:"p"},"no-cache/no-store")," and ",(0,n.kt)("inlineCode",{parentName:"p"},"public/private")," are mutually exclusive. "),(0,n.kt)("p",null,"If you specify both ",(0,n.kt)("inlineCode",{parentName:"p"},"no-store")," and ",(0,n.kt)("inlineCode",{parentName:"p"},"no-cache"),", ",(0,n.kt)("inlineCode",{parentName:"p"},"no-store")," will be given precedence over ",(0,n.kt)("inlineCode",{parentName:"p"},"no-cache"),"."),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"; If specified both\nCache-Control: no-store, no-cache\n\n; Below will be considered\nCache-Control: no-store\n")),(0,n.kt)("p",null,"For ",(0,n.kt)("inlineCode",{parentName:"p"},"private/public"),", for any unauthenticated requests cache is considered ",(0,n.kt)("inlineCode",{parentName:"p"},"public")," and for any authenticated ones cache is considered ",(0,n.kt)("inlineCode",{parentName:"p"},"private"),"."),(0,n.kt)("h3",null,"Validators"),(0,n.kt)("p",null,"Up until now we only discussed how the content is cached and how long the cached content is to be considered fresh but we did not discuss how the client does the validation from the server. Below we discuss the headers used for this purpose."),(0,n.kt)("h4",null,"ETag"),(0,n.kt)("p",null,'Etag or "entity tag" was introduced in HTTP/1.1 specs. Etag is just a unique identifier that the server attaches with some resource. This ETag is later on used by the client to make conditional HTTP requests stating ',(0,n.kt)("inlineCode",{parentName:"p"},'"give me this resource if ETag is not same as the ETag that I have"')," and the content is downloaded only if the etags do not match. "),(0,n.kt)("p",null,"Method by which ETag is generated is not specified in the HTTP docs and usually some collision-resistant hash function is used to assign etags to each version of a resource. There could be two types of etags i.e. strong and weak"),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),'ETag: "j82j8232ha7sdh0q2882" - Strong Etag\nETag: W/"j82j8232ha7sdh0q2882" - Weak Etag (prefixed with `W/`)\n')),(0,n.kt)("p",null,"A strong validating ETag means that two resources are ",(0,n.kt)("strong",{parentName:"p"},"exactly")," same and there is no difference between them at all. While a weak ETag means that two resources are although not strictly same but could be considered same. Weak etags might be useful for dynamic content, for example."),(0,n.kt)("p",null,"Now you know what etags are but how does the browser make this request? by making a request to server while sending the available Etag in ",(0,n.kt)("inlineCode",{parentName:"p"},"If-None-Match")," header."),(0,n.kt)("p",null,"Consider the scenario, you opened a web page which loaded a logo image with caching period of 60 seconds and ETag of ",(0,n.kt)("inlineCode",{parentName:"p"},"abc123xyz"),". After about 30 minutes you reload the page, browser will notice that the logo which was fresh for 60 seconds is now stale; it will trigger a request to server, sending the ETag of the stale logo image in ",(0,n.kt)("inlineCode",{parentName:"p"},"if-none-match")," header"),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),'If-None-Match: "abc123xyz"\n')),(0,n.kt)("p",null,"Server will then compare this ETag with the ETag of the current version of resource. If both etags are matched, server will send back the response of ",(0,n.kt)("inlineCode",{parentName:"p"},"304 Not Modified")," which will tell the client that the copy that it has is still good and it will be considered fresh for another 60 seconds. If both the etags do not match i.e. the logo has likely changed and client will be sent the new logo which it will use to replace the stale logo that it has."),(0,n.kt)("h4",null,"Last-Modified"),(0,n.kt)("p",null,"Server might include the ",(0,n.kt)("inlineCode",{parentName:"p"},"Last-Modified")," header indicating the date and time at which some content was last modified on."),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"Last-Modified: Wed, 15 Mar 2017 12:30:26 GMT\n")),(0,n.kt)("p",null,"When the content gets stale, client will make a conditional request including the last modified date that it has inside the header called ",(0,n.kt)("inlineCode",{parentName:"p"},"If-Modified-Since")," to server to get the updated ",(0,n.kt)("inlineCode",{parentName:"p"},"Last-Modified")," date; if it matches the date that the client has, ",(0,n.kt)("inlineCode",{parentName:"p"},"Last-Modified")," date for the content is updated to be considered fresh for another ",(0,n.kt)("inlineCode",{parentName:"p"},"n")," seconds. If the received ",(0,n.kt)("inlineCode",{parentName:"p"},"Last-Modified")," date does not match the one that the client has, content is reloaded from the server and replaced with the content that client has."),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"If-Modified-Since: Wed, 15 Mar 2017 12:30:26 GMT\n")),(0,n.kt)("p",null,"You might be questioning now, what if the cached content has both the ",(0,n.kt)("inlineCode",{parentName:"p"},"Last-Modified")," and ",(0,n.kt)("inlineCode",{parentName:"p"},"ETag")," assigned to it? Well, in that case both are to be used i.e. there will not be any re-downloading of the resource if and only if ",(0,n.kt)("inlineCode",{parentName:"p"},"ETag")," matches the newly retrieved one and so does the ",(0,n.kt)("inlineCode",{parentName:"p"},"Last-Modified")," date. If either the ",(0,n.kt)("inlineCode",{parentName:"p"},"ETag")," does not match or the ",(0,n.kt)("inlineCode",{parentName:"p"},"Last-Modified")," is greater than the one from the server, content has to be downloaded again. "),(0,n.kt)("h3",null,"Where do I start?"),(0,n.kt)("p",null,"Now that we have got ",(0,n.kt)("em",{parentName:"p"},"everything")," covered, let us put everything in perspective and see how you can use this information."),(0,n.kt)("h4",null,"Utilizing Server"),(0,n.kt)("p",null,"Before we get into the possible caching strategies , let me add the fact that most of the servers including Apache and Nginx allow you to implement your caching policy through the server so that you don't have to juggle with headers in your code. "),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"For example"),", if you are using Apache and you have your static content placed at ",(0,n.kt)("inlineCode",{parentName:"p"},"/static"),", you can put below ",(0,n.kt)("inlineCode",{parentName:"p"},".htaccess")," file in the directory to make all the content in it be cached for an year using below"),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),'# Cache everything for an year\nHeader set Cache-Control "max-age=31536000, public"\n')),(0,n.kt)("p",null,"You can further use ",(0,n.kt)("inlineCode",{parentName:"p"},"filesMatch")," directive to add conditionals and use different caching strategy for different kinds of files e.g."),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"# Cache any images for one year\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token tag"}),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token tag"}),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"<"),"filesMatch")," ",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token attr-name"}),'".(png|jpg|jpeg|gif)$"'),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),">")),'\n Header set Cache-Control "max-age=31536000, public"\n',(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token tag"}),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token tag"}),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"")),"\n\n# Cache any CSS and JS files for a month\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token tag"}),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token tag"}),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"<"),"filesMatch")," ",(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token attr-name"}),'".(css|js)$"'),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),">")),'\n Header set Cache-Control "max-age=2628000, public"\n',(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token tag"}),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token tag"}),(0,n.kt)("span",Object.assign({parentName:"span"},{className:"token punctuation"}),"")),"\n")),(0,n.kt)("p",null,"Or if you don't want to use the ",(0,n.kt)("inlineCode",{parentName:"p"},".htaccess")," file you can modify Apache's configuration file ",(0,n.kt)("inlineCode",{parentName:"p"},"http.conf"),". Same goes for Nginx, you can add the caching information in the location or server block. "),(0,n.kt)("h4",null,"Caching Recommendations"),(0,n.kt)("p",null,"There is no golden rule or set standards about how your caching policy should look like, each of the application is different and you have to look and find what suits your application the best. However, just to give you a rough idea"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"You can have aggressive caching (e.g. cache for an year) on any static content and use fingerprinted filenames (e.g. ",(0,n.kt)("inlineCode",{parentName:"li"},"style.ju2i90.css"),") so that the cache is automatically rejected whenever the files are updated.\nAlso it should be noted that you should not cross the upper limit of one year as it ",(0,n.kt)("a",Object.assign({parentName:"li"},{href:"https://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.9"}),"might not be honored")," "),(0,n.kt)("li",{parentName:"ul"},"Look and decide do you even need caching for any dynamic content, if yes how long it should be. For example, in case of some RSS feed of a blog there could be the caching of a few hours but there couldn't be any caching for inventory items in an ERP."),(0,n.kt)("li",{parentName:"ul"},"Always add the validators (preferably ETags) in your response."),(0,n.kt)("li",{parentName:"ul"},"Pay attention while choosing the visibility (private or public) of the cached content. Make sure that you do not accidentally cache any user-specific or sensitive content in any public proxies. When in doubt, do not use cache at all."),(0,n.kt)("li",{parentName:"ul"},"Separate the content that changes often from the content that doesn't change that often (e.g. in javascript bundles) so that when it is updated it doesn't need to make the whole cached content stale. "),(0,n.kt)("li",{parentName:"ul"},"Test and monitor the caching headers being served by your site. You can use the browser console or ",(0,n.kt)("inlineCode",{parentName:"li"},"curl -I http://some-url.com")," for that purpose. ")),(0,n.kt)("p",null,"And that about wraps it up. Stay tuned for more!"))}c.isMDXComponent=!0},2518:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"HTTP is the protocol that every web developer should know as it powers the whole web and knowing it is definitely going to help you develop better applications. In this guide, I am going to be discussing what HTTP is, how it came to be, where it is today and how did we get here."),(0,n.kt)("h3",null,"What is HTTP?"),(0,n.kt)("p",null,"First things first, what is HTTP? HTTP is the ",(0,n.kt)("inlineCode",{parentName:"p"},"TCP/IP")," based application layer communication protocol which standardizes how the client and server communicate with each other. It defines how the content is requested and transmitted across the internet. By application layer protocol, I mean it's just an abstraction layer that standardizes how the hosts (clients and servers) communicate and itself it depends upon ",(0,n.kt)("inlineCode",{parentName:"p"},"TCP/IP")," to get request and response between the client and server. By default TCP port ",(0,n.kt)("inlineCode",{parentName:"p"},"80")," is used but other ports can be used as well. HTTPS, however, uses port ",(0,n.kt)("inlineCode",{parentName:"p"},"443"),"."),(0,n.kt)("h3",null,"HTTP/0.9 \u2013 The One Liner (1991)"),(0,n.kt)("p",null,"The first documented version of HTTP was ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://www.w3.org/Protocols/HTTP/AsImplemented.html"}),(0,n.kt)("inlineCode",{parentName:"a"},"HTTP/0.9"))," which was put forward in 1991. It was the simplest protocol ever; having a single method called ",(0,n.kt)("inlineCode",{parentName:"p"},"GET"),". If a client had to access some webpage on the server, it would have made the simple request like below"),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"GET /index.html\n")),(0,n.kt)("p",null,"And the response from server would have looked as follows"),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"(response body)\n(connection closed)\n")),(0,n.kt)("p",null,"That is, the server would get the request, reply with the HTML in response and as soon as the content has been transferred, the connection will be closed. There were "),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"No headers"),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("inlineCode",{parentName:"li"},"GET")," was the only allowed method "),(0,n.kt)("li",{parentName:"ul"},"Response had to be HTML")),(0,n.kt)("p",null,"As you can see, the protocol really had nothing more than being a stepping stone for what was to come."),(0,n.kt)("h3",null,"HTTP/1.0 - 1996"),(0,n.kt)("p",null,"In 1996, the next version of HTTP i.e. ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.0")," evolved that vastly improved over the original version. "),(0,n.kt)("p",null,"Unlike ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/0.9")," which was only designed for HTML response, ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.0")," could now deal with other response formats i.e. images, video files, plain text or any other content type as well. It added more methods (i.e. ",(0,n.kt)("inlineCode",{parentName:"p"},"POST")," and ",(0,n.kt)("inlineCode",{parentName:"p"},"HEAD"),"), request/response formats got changed, HTTP headers got added to both the request and responses, status codes were added to identify the response, character set support was introduced, multi-part types, authorization, caching, content encoding and more was included."),(0,n.kt)("p",null,"Here is how a sample ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.0")," request and response might have looked like:"),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"GET / HTTP/1.0\nHost: kamranahmed.info\nUser-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_5)\nAccept: */*\n")),(0,n.kt)("p",null,"As you can see, alongside the request, client has also sent its personal information, required response type etc. While in ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/0.9")," client could never send such information because there were no headers."),(0,n.kt)("p",null,"Example response to the request above may have looked like below"),(0,n.kt)("pre",Object.assign({},{className:"language-html"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-html"}),"HTTP/1.0 200 OK \nContent-Type: text/plain\nContent-Length: 137582\nExpires: Thu, 05 Dec 1997 16:00:00 GMT\nLast-Modified: Wed, 5 August 1996 15:55:28 GMT\nServer: Apache 0.84\n\n(response body)\n(connection closed)\n")),(0,n.kt)("p",null,"In the very beginning of the response there is ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.0")," (HTTP followed by the version number), then there is the status code ",(0,n.kt)("inlineCode",{parentName:"p"},"200")," followed by the reason phrase (or description of the status code, if you will). "),(0,n.kt)("p",null,"In this newer version, request and response headers were still kept as ",(0,n.kt)("inlineCode",{parentName:"p"},"ASCII"),' encoded, but the response body could have been of any type i.e. image, video, HTML, plain text or any other content type. So, now that server could send any content type to the client; not so long after the introduction, the term "Hyper Text" in ',(0,n.kt)("inlineCode",{parentName:"p"},"HTTP")," became misnomer. ",(0,n.kt)("inlineCode",{parentName:"p"},"HMTP")," or Hypermedia transfer protocol might have made more sense but, I guess, we are stuck with the name for life."),(0,n.kt)("p",null,"One of the major drawbacks of ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.0")," were you couldn't have multiple requests per connection. That is, whenever a client will need something from the server, it will have to open a new TCP connection and after that single request has been fulfilled, connection will be closed. And for any next requirement, it will have to be on a new connection. Why is it bad? Well, let's assume that you visit a webpage having ",(0,n.kt)("inlineCode",{parentName:"p"},"10")," images, ",(0,n.kt)("inlineCode",{parentName:"p"},"5")," stylesheets and ",(0,n.kt)("inlineCode",{parentName:"p"},"5")," javascript files, totalling to ",(0,n.kt)("inlineCode",{parentName:"p"},"20")," items that needs to fetched when request to that webpage is made. Since the server closes the connection as soon as the request has been fulfilled, there will be a series of ",(0,n.kt)("inlineCode",{parentName:"p"},"20")," separate connections where each of the items will be served one by one on their separate connections. This large number of connections results in a serious performance hit as requiring a new ",(0,n.kt)("inlineCode",{parentName:"p"},"TCP")," connection imposes a significant performance penalty because of three-way handshake followed by slow-start."),(0,n.kt)("h4",null,"Three-way Handshake"),(0,n.kt)("p",null,"Three-way handshake in its simplest form is that all the ",(0,n.kt)("inlineCode",{parentName:"p"},"TCP")," connections begin with a three-way handshake in which the client and the server share a series of packets before starting to share the application data. "),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("inlineCode",{parentName:"li"},"SYN")," - Client picks up a random number, let's say ",(0,n.kt)("inlineCode",{parentName:"li"},"x"),", and sends it to the server."),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("inlineCode",{parentName:"li"},"SYN ACK")," - Server acknowledges the request by sending an ",(0,n.kt)("inlineCode",{parentName:"li"},"ACK")," packet back to the client which is made up of a random number, let's say ",(0,n.kt)("inlineCode",{parentName:"li"},"y")," picked up by server and the number ",(0,n.kt)("inlineCode",{parentName:"li"},"x+1")," where ",(0,n.kt)("inlineCode",{parentName:"li"},"x")," is the number that was sent by the client"),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("inlineCode",{parentName:"li"},"ACK")," - Client increments the number ",(0,n.kt)("inlineCode",{parentName:"li"},"y")," received from the server and sends an ",(0,n.kt)("inlineCode",{parentName:"li"},"ACK")," packet back with the number ",(0,n.kt)("inlineCode",{parentName:"li"},"y+1"))),(0,n.kt)("p",null,"Once the three-way handshake is completed, the data sharing between the client and server may begin. It should be noted that the client may start sending the application data as soon as it dispatches the last ",(0,n.kt)("inlineCode",{parentName:"p"},"ACK")," packet but the server will still have to wait for the ",(0,n.kt)("inlineCode",{parentName:"p"},"ACK")," packet to be recieved in order to fulfill the request."),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"http://i.imgur.com/uERG2G2.png",alt:null}))),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Please note that there is a minor issue with the image, the last ",(0,n.kt)("inlineCode",{parentName:"p"},"ACK")," packet sent by the client to end the handshake contains only ",(0,n.kt)("inlineCode",{parentName:"p"},"y+1")," i.e. it should have been ",(0,n.kt)("inlineCode",{parentName:"p"},"ACK:y+1")," instead of ",(0,n.kt)("inlineCode",{parentName:"p"},"ACK: x+1, y+1")," ")),(0,n.kt)("p",null,"However, some implementations of ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.0")," tried to overcome this issue by introducing a new header called ",(0,n.kt)("inlineCode",{parentName:"p"},"Connection: keep-alive"),' which was meant to tell the server "Hey server, do not close this connection, I need it again". But still, it wasn\'t that widely supported and the problem still persisted.'),(0,n.kt)("p",null,"Apart from being connectionless, ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP")," also is a stateless protocol i.e. server doesn't maintain the information about the client and so each of the requests has to have the information necessary for the server to fulfill the request on its own without any association with any old requests. And so this adds fuel to the fire i.e. apart from the large number of connections that the client has to open, it also has to send some redundant data on the wire causing increased bandwidth usage."),(0,n.kt)("h3",null,"HTTP/1.1 - 1999"),(0,n.kt)("p",null,"After merely 3 years of ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.0"),", the next version i.e. ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1")," was released in 1999; which made alot of improvements over its predecessor. The major improvements over ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.0")," included"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},(0,n.kt)("strong",{parentName:"p"},"New HTTP methods")," were added, which introduced ",(0,n.kt)("inlineCode",{parentName:"p"},"PUT"),", ",(0,n.kt)("inlineCode",{parentName:"p"},"PATCH"),", ",(0,n.kt)("inlineCode",{parentName:"p"},"OPTIONS"),", ",(0,n.kt)("inlineCode",{parentName:"p"},"DELETE"))),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},(0,n.kt)("strong",{parentName:"p"},"Hostname Identification")," In ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.0")," ",(0,n.kt)("inlineCode",{parentName:"p"},"Host")," header wasn't required but ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1")," made it required.")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},(0,n.kt)("strong",{parentName:"p"},"Persistent Connections")," As discussed above, in ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.0")," there was only one request per connection and the connection was closed as soon as the request was fulfilled which resulted in accute performance hit and latency problems. ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1")," introduced the persistent connections i.e. ",(0,n.kt)("strong",{parentName:"p"},"connections weren't closed by default")," and were kept open which allowed multiple sequential requests. To close the connections, the header ",(0,n.kt)("inlineCode",{parentName:"p"},"Connection: close")," had to be available on the request. Clients usually send this header in the last request to safely close the connection.")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},(0,n.kt)("strong",{parentName:"p"},"Pipelining")," It also introduced the support for pipelining, where the client could send multiple requests to the server without waiting for the response from server on the same connection and server had to send the response in the same sequence in which requests were received. But how does the client know that this is the point where first response download completes and the content for next response starts, you may ask! Well, to solve this, there must be ",(0,n.kt)("inlineCode",{parentName:"p"},"Content-Length")," header present which clients can use to identify where the response ends and it can start waiting for the next response."),(0,n.kt)("blockquote",{parentName:"li"},(0,n.kt)("p",{parentName:"blockquote"},"It should be noted that in order to benefit from persistent connections or pipelining, ",(0,n.kt)("inlineCode",{parentName:"p"},"Content-Length")," header must be available on the response, because this would let the client know when the transmission completes and it can send the next request (in normal sequential way of sending requests) or start waiting for the the next response (when pipelining is enabled). ")),(0,n.kt)("blockquote",{parentName:"li"},(0,n.kt)("p",{parentName:"blockquote"},"But there was still an issue with this approach. And that is, what if the data is dynamic and server cannot find the content length before hand? Well in that case, you really can't benefit from persistent connections, could you?! In order to solve this ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1")," introduced chunked encoding. In such cases server may omit content-Length in favor of chunked encoding (more to it in a moment). However, if none of them are available, then the connection must be closed at the end of request."))),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},(0,n.kt)("strong",{parentName:"p"},"Chunked Transfers")," In case of dynamic content, when the server cannot really find out the ",(0,n.kt)("inlineCode",{parentName:"p"},"Content-Length")," when the transmission starts, it may start sending the content in pieces (chunk by chunk) and add the ",(0,n.kt)("inlineCode",{parentName:"p"},"Content-Length")," for each chunk when it is sent. And when all of the chunks are sent i.e. whole transmission has completed, it sends an empty chunk i.e. the one with ",(0,n.kt)("inlineCode",{parentName:"p"},"Content-Length")," set to zero in order to identify the client that transmission has completed. In order to notify the client about the chunked transfer, server includes the header ",(0,n.kt)("inlineCode",{parentName:"p"},"Transfer-Encoding: chunked"))),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},"Unlike ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.0")," which had Basic authentication only, ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1")," included digest and proxy authentication")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},"Caching")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},"Byte Ranges")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},"Character sets")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},"Language negotiation")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},"Client cookies")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},"Enhanced compression support")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},"New status codes")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("p",{parentName:"li"},"..and more "))),(0,n.kt)("p",null,"I am not going to dwell about all the ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1")," features in this post as it is a topic in itself and you can already find a lot about it. The one such document that I would recommend you to read is ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"http://www.ra.ethz.ch/cdstore/www8/data/2136/pdf/pd1.pdf"}),"Key differences between ",(0,n.kt)("inlineCode",{parentName:"a"},"HTTP/1.0")," and HTTP/1.1")," and here is the link to ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://tools.ietf.org/html/rfc2616"}),"original RFC")," for the overachievers."),(0,n.kt)("p",null,(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1")," was introduced in 1999 and it had been a standard for many years. Although, it improved alot over its predecessor; with the web changing everyday, it started to show its age. Loading a web page these days is more resource-intensive than it ever was. A simple webpage these days has to open more than 30 connections. Well ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1")," has persistent connections, then why so many connections? you say! The reason is, in ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1")," it can only have one outstanding connection at any moment of time. ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1")," tried to fix this by introducing pipelining but it didn't completely address the issue because of the ",(0,n.kt)("strong",{parentName:"p"},"head-of-line blocking")," where a slow or heavy request may block the requests behind and once a request gets stuck in a pipeline, it will have to wait for the next requests to be fulfilled. To overcome these shortcomings of ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1"),", the developers started implementing the workarounds, for example use of spritesheets, encoded images in CSS, single humungous CSS/Javascript files, ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://www.maxcdn.com/one/visual-glossary/domain-sharding-2/"}),"domain sharding")," etc."),(0,n.kt)("h3",null,"SPDY - 2009"),(0,n.kt)("p",null,"Google went ahead and started experimenting with alternative protocols to make the web faster and improving web security while reducing the latency of web pages. In 2009, they announced ",(0,n.kt)("inlineCode",{parentName:"p"},"SPDY"),". "),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},(0,n.kt)("inlineCode",{parentName:"p"},"SPDY")," is a trademark of Google and isn't an acronym.")),(0,n.kt)("p",null,"It was seen that if we keep increasing the bandwidth, the network performance increases in the beginning but a point comes when there is not much of a performance gain. But if you do the same with latency i.e. if we keep dropping the latency, there is a constant performance gain. This was the core idea for performance gain behind ",(0,n.kt)("inlineCode",{parentName:"p"},"SPDY"),", decrease the latency to increase the network performance."),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"For those who don't know the difference, latency is the delay i.e. how long it takes for data to travel between the source and destination (measured in milliseconds) and bandwidth is the amount of data transfered per second (bits per second).")),(0,n.kt)("p",null,"The features of ",(0,n.kt)("inlineCode",{parentName:"p"},"SPDY")," included, multiplexing, compression, prioritization, security etc. I am not going to get into the details of SPDY, as you will get the idea when we get into the nitty gritty of ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," in the next section as I said ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," is mostly inspired from SPDY."),(0,n.kt)("p",null,(0,n.kt)("inlineCode",{parentName:"p"},"SPDY")," didn't really try to replace HTTP; it was a translation layer over HTTP which existed at the application layer and modified the request before sending it over to the wire. It started to become a defacto standards and majority of browsers started implementing it. "),(0,n.kt)("p",null,"In 2015, at Google, they didn't want to have two competing standards and so they decided to merge it into HTTP while giving birth to ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," and deprecating SPDY. "),(0,n.kt)("h3",null,"HTTP/2 - 2015"),(0,n.kt)("p",null,"By now, you must be convinced that why we needed another revision of the HTTP protocol. ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," was designed for low latency transport of content. The key features or differences from the old version of ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1")," include"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"Binary instead of Textual"),(0,n.kt)("li",{parentName:"ul"},"Multiplexing - Multiple asynchronous HTTP requests over a single connection"),(0,n.kt)("li",{parentName:"ul"},"Header compression using HPACK"),(0,n.kt)("li",{parentName:"ul"},"Server Push - Multiple responses for single request"),(0,n.kt)("li",{parentName:"ul"},"Request Prioritization"),(0,n.kt)("li",{parentName:"ul"},"Security")),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"http://i.imgur.com/S85j8gg.png",alt:null}))),(0,n.kt)("h4",null,"1. Binary Protocol"),(0,n.kt)("p",null,(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," tends to address the issue of increased latency that existed in HTTP/1.x by making it a binary protocol. Being a binary protocol, it easier to parse but unlike ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.x")," it is no longer readable by the human eye. The major building blocks of ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," are Frames and Streams"),(0,n.kt)("h5",null,"Frames and Streams"),(0,n.kt)("p",null,"HTTP messages are now composed of one or more frames. There is a ",(0,n.kt)("inlineCode",{parentName:"p"},"HEADERS")," frame for the meta data and ",(0,n.kt)("inlineCode",{parentName:"p"},"DATA")," frame for the payload and there exist several other types of frames (",(0,n.kt)("inlineCode",{parentName:"p"},"HEADERS"),", ",(0,n.kt)("inlineCode",{parentName:"p"},"DATA"),", ",(0,n.kt)("inlineCode",{parentName:"p"},"RST_STREAM"),", ",(0,n.kt)("inlineCode",{parentName:"p"},"SETTINGS"),", ",(0,n.kt)("inlineCode",{parentName:"p"},"PRIORITY")," etc) that you can check through ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://http2.github.io/http2-spec/#FrameTypes"}),"the ",(0,n.kt)("inlineCode",{parentName:"a"},"HTTP/2")," specs"),". "),(0,n.kt)("p",null,"Every ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," request and response is given a unique stream ID and it is divided into frames. Frames are nothing but binary pieces of data. A collection of frames is called a Stream. Each frame has a stream id that identifies the stream to which it belongs and each frame has a common header. Also, apart from stream ID being unique, it is worth mentioning that, any request initiated by client uses odd numbers and the response from server has even numbers stream IDs."),(0,n.kt)("p",null,"Apart from the ",(0,n.kt)("inlineCode",{parentName:"p"},"HEADERS")," and ",(0,n.kt)("inlineCode",{parentName:"p"},"DATA"),", another frame type that I think worth mentioning here is ",(0,n.kt)("inlineCode",{parentName:"p"},"RST_STREAM")," which is a special frame type that is used to abort some stream i.e. client may send this frame to let the server know that I don't need this stream anymore. In ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/1.1")," the only way to make the server stop sending the response to client was closing the connection which resulted in increased latency because a new connection had to be opened for any consecutive requests. While in HTTP/2, client can use ",(0,n.kt)("inlineCode",{parentName:"p"},"RST_STREAM")," and stop receiving a specific stream while the connection will still be open and the other streams will still be in play."),(0,n.kt)("h4",null,"2. Multiplexing"),(0,n.kt)("p",null,"Since ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," is now a binary protocol and as I said above that it uses frames and streams for requests and responses, once a TCP connection is opened, all the streams are sent asynchronously through the same connection without opening any additional connections. And in turn, the server responds in the same asynchronous way i.e. the response has no order and the client uses the assigned stream id to identify the stream to which a specific packet belongs. This also solves the ",(0,n.kt)("strong",{parentName:"p"},"head-of-line blocking")," issue that existed in HTTP/1.x i.e. the client will not have to wait for the request that is taking time and other requests will still be getting processed."),(0,n.kt)("h4",null,"3. HPACK Header Compression"),(0,n.kt)("p",null,"It was part of a separate RFC which was specifically aimed at optimizing the sent headers. The essence of it is that when we are constantly accessing the server from a same client there is alot of redundant data that we are sending in the headers over and over, and sometimes there might be cookies increasing the headers size which results in bandwidth usage and increased latency. To overcome this, ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," introduced header compression."),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"http://i.imgur.com/3IPWXvR.png",alt:null}))),(0,n.kt)("p",null,"Unlike request and response, headers are not compressed in ",(0,n.kt)("inlineCode",{parentName:"p"},"gzip")," or ",(0,n.kt)("inlineCode",{parentName:"p"},"compress")," etc formats but there is a different mechanism in place for header compression which is literal values are encoded using Huffman code and a headers table is maintained by the client and server and both the client and server omit any repetitive headers (e.g. user agent etc) in the subsequent requests and reference them using the headers table maintained by both."),(0,n.kt)("p",null,"While we are talking headers, let me add here that the headers are still the same as in HTTP/1.1, except for the addition of some pseudo headers i.e. ",(0,n.kt)("inlineCode",{parentName:"p"},":method"),", ",(0,n.kt)("inlineCode",{parentName:"p"},":scheme"),", ",(0,n.kt)("inlineCode",{parentName:"p"},":host")," and ",(0,n.kt)("inlineCode",{parentName:"p"},":path")),(0,n.kt)("h4",null,"4. Server Push"),(0,n.kt)("p",null,"Server push is another tremendous feature of ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," where the server, knowing that the client is going to ask for a certain resource, can push it to the client without even client asking for it. For example, let's say a browser loads a web page, it parses the whole page to find out the remote content that it has to load from the server and then sends consequent requests to the server to get that content."),(0,n.kt)("p",null,"Server push allows the server to decrease the roundtrips by pushing the data that it knows that client is going to demand. How it is done is, server sends a special frame called ",(0,n.kt)("inlineCode",{parentName:"p"},"PUSH_PROMISE"),' notifying the client that, "Hey, I am about to send this resource to you! Do not ask me for it." The ',(0,n.kt)("inlineCode",{parentName:"p"},"PUSH_PROMISE")," frame is associated with the stream that caused the push to happen and it contains the promised stream ID i.e. the stream on which the server will send the resource to be pushed."),(0,n.kt)("h4",null,"5. Request Prioritization"),(0,n.kt)("p",null,"A client can assign a priority to a stream by including the prioritization information in the ",(0,n.kt)("inlineCode",{parentName:"p"},"HEADERS")," frame by which a stream is opened. At any other time, client can send a ",(0,n.kt)("inlineCode",{parentName:"p"},"PRIORITY")," frame to change the priority of a stream."),(0,n.kt)("p",null,"Without any priority information, server processes the requests asynchronously i.e. without any order. If there is priority assigned to a stream, then based on this prioritization information, server decides how much of the resources need to be given to process which request."),(0,n.kt)("h4",null,"6. Security"),(0,n.kt)("p",null,"There was extensive discussion on whether security (through ",(0,n.kt)("inlineCode",{parentName:"p"},"TLS"),") should be made mandatory for ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," or not. In the end, it was decided not to make it mandatory. However, most vendors stated that they will only support ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," when it is used over ",(0,n.kt)("inlineCode",{parentName:"p"},"TLS"),". So, although ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," doesn't require encryption by specs but it has kind of become mandatory by default anyway. With that out of the way, ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," when implemented over ",(0,n.kt)("inlineCode",{parentName:"p"},"TLS")," does impose some requirementsi.e. ",(0,n.kt)("inlineCode",{parentName:"p"},"TLS")," version ",(0,n.kt)("inlineCode",{parentName:"p"},"1.2")," or higher must be used, there must be a certain level of minimum keysizes, ephemeral keys are required etc."),(0,n.kt)("p",null,(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," is here and it has already ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"http://caniuse.com/#search=http2"}),"surpassed SPDY in adaption")," which is gradually increasing. ",(0,n.kt)("inlineCode",{parentName:"p"},"HTTP/2")," has alot to offer in terms of performance gain and it is about time we should start using it. "),(0,n.kt)("p",null,"For anyone interested in further details here is the ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://http2.github.io/http2-spec"}),"link to specs")," and a link ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"http://www.http2demo.io/"}),"demonstrating the performance benefits of ",(0,n.kt)("inlineCode",{parentName:"a"},"HTTP/2")),". "),(0,n.kt)("p",null,"And that about wraps it up. Until next time! stay tuned."))}c.isMDXComponent=!0},3275:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/jwt-authentication.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/jwt-authentication.png",alt:null})))))}c.isMDXComponent=!0},7824:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"I have been working on redoing the ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://roadmap.sh"}),"roadmaps")," \u2013 splitting the skillset based on the seniority levels to make them easier to follow and not scare the new developers away. Since the roadmaps are going to be just about the technical knowledge, I thought it would be a good idea to reiterate and have an article on what I think of different seniority roles."),(0,n.kt)("p",null,'I have seen many organizations decide the seniority of developers by giving more significance to the years of experience than they should. I have seen developers labeled "Junior" doing the work of Senior Developers and I have seen "Lead" developers who weren\'t even qualified to be called "Senior". The seniority of a developer cannot just be decided by their age, years of experience or technical knowledge that they have got. There are other factors in play here -- their perception of work, how they interact with their peers and how they approach problems. We discuss these three key factors in detail for each of the seniority levels below.'),(0,n.kt)("h3",null,"Different Seniority Titles"),(0,n.kt)("p",null,"Different organizations might have different seniority titles but they mainly fall into three categories:"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"Junior Developer"),(0,n.kt)("li",{parentName:"ul"},"Mid Level Developer"),(0,n.kt)("li",{parentName:"ul"},"Senior Developer")),(0,n.kt)("h3",null,"Junior Developer"),(0,n.kt)("p",null,"Junior developers are normally fresh graduates and it's either they don't have or they have minimal industry experience. Not only they have weak coding skills but there are also a few other things that give Junior developers away:"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},'Their main mantra is "making it work" without giving much attention to how the solution is achieved. To them, a working software and good software are equivalent. '),(0,n.kt)("li",{parentName:"ul"},"They usually require very specific and structured directions to achieve something. They suffer from tunnel vision, need supervision and continuous guidance to be effective team members."),(0,n.kt)("li",{parentName:"ul"},"Most of the Junior developers just try to live up to the role and, when stuck, they might leave work for a senior developer instead of at least trying to take a stab at something."),(0,n.kt)("li",{parentName:"ul"},"They don't know about the business side of the company and don't realize how management/sales/marketing/etc think and they don't realize how much rework, wasted effort, and end-user aggravation could be saved by getting to know the business domain."),(0,n.kt)("li",{parentName:"ul"},"Over-engineering is a major problem, often leading to fragility and bugs."),(0,n.kt)("li",{parentName:"ul"},"When given a problem, they often try to fix just the current problem a.k.a. fixing the symptoms instead of fixing the root problem."),(0,n.kt)("li",{parentName:"ul"},'You might notice the "',(0,n.kt)("a",Object.assign({parentName:"li"},{href:"https://en.wikipedia.org/wiki/Somebody_else%27s_problem"}),"Somebody Else's Problem"),'" behavior from them.'),(0,n.kt)("li",{parentName:"ul"},"They don't know what or how much they don't know, thanks to the ",(0,n.kt)("a",Object.assign({parentName:"li"},{href:"https://en.wikipedia.org/wiki/Dunning%E2%80%93Kruger_effect"}),"Dunning\u2013Kruger effect"),"."),(0,n.kt)("li",{parentName:"ul"},"They don't take initiatives and they might be afraid to work on an unfamiliar codebase."),(0,n.kt)("li",{parentName:"ul"},"They don't participate in team discussions.")),(0,n.kt)("p",null,'Being a Junior developer in the team is not necessarily a bad thing; since you are just starting out, you are not expected to be a know-it-all person. However, it is your responsibility to learn, gain experience, not get stuck with the "Junior" title and improve yourself. Here are a few tips for Junior developers to help move up the ladder of seniority:'),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},'All sorts of problems can be solved if you work on them long enough. Do not give up if Stack Overflow or an issue on GitHub doesn\'t have an answer. Saying "I am stuck, but I have tried X, Y, and Z. Do you have any pointers?" to your lead is much better than saying "This is beyond me."'),(0,n.kt)("li",{parentName:"ul"},"Read a lot of code, not just code in the projects that you are working on, but reference/framework source code, open-source. Ask your fellow developers, perhaps on Reddit too, about the good open-source examples for the language/tools of your choice. "),(0,n.kt)("li",{parentName:"ul"},"Do personal side-projects, share them with people, contribute to the open-source community. Reach out to people for help. You will be surprised how much support you can get from the community. I still remember my first open-source project on GitHub from around 6 years ago which was a small PHP script (a library) that fetched details for a given address from Google's Geocoding API. The codebase was super messy, it did not have any tests, did not have any linters or sniffers, and it did not have any CI because I didn't know about any of this at that time. I am not sure how but one kind soul somehow found the project, forked it, refactored it, \"modernized\" it, added linting, code sniffing, added CI and opened the pull request. This one pull request taught me so many things that I might have never learned that fast on my own because I was still in college, working for a small service-based company and doing just small websites all on my own without knowing what is right and what is not. This one PR on GitHub was my introduction to open-source and I owe everything to that. "),(0,n.kt)("li",{parentName:"ul"},"Avoid what is known as ",(0,n.kt)("a",Object.assign({parentName:"li"},{href:"https://en.wikipedia.org/wiki/Somebody_else%27s_problem"}),'"Somebody Else\'s Problem Field"')," behavior. "),(0,n.kt)("li",{parentName:"ul"},"When given a problem to solve, try to identify the root cause and fix that instead of fixing the symptoms. And remember, not being able to reproduce means not solved. It is solved when you understand why it occurred and why it no longer does."),(0,n.kt)("li",{parentName:"ul"},'Have respect for the code that was written before you. Be generous when passing judgment on the architecture or the design decisions made in the codebase. Understand that code is often ugly and weird for a reason other than incompetence. Learning to live with and thrive with legacy code is a great skill. Never assume anybody is stupid. Instead, figure out how these intelligent, well-intentioned and experienced people have come to a decision that is stupid now. Approach inheriting legacy code with an "opportunity mindset" rather than a complaining one.'),(0,n.kt)("li",{parentName:"ul"},"It's okay to not know things. You don't need to be ashamed of not knowing things already. There are no stupid questions, ask however many questions that would allow you to work effectively."),(0,n.kt)("li",{parentName:"ul"},"Don't let yourself be limited by the job title that you have. Keep working on your self-improvement."),(0,n.kt)("li",{parentName:"ul"},"Do your homework. Predict what\u2019s coming down the pipe. Be involved in the team discussions. Even if you are wrong, you will learn something."),(0,n.kt)("li",{parentName:"ul"},"Learn about the domain that you are working with. Understand the product end-to-end as an end-user. Do not assume things, ask questions and get things cleared when in doubt."),(0,n.kt)("li",{parentName:"ul"},"Learn to communicate effectively - soft skills matter. Learn how to write good emails, how to present your work, how to phrase your questions in a thoughtful manner."),(0,n.kt)("li",{parentName:"ul"},"Sit with the senior developers, watch them work, find a mentor. No one likes a know-it-all. Get hold of your ego and be humble enough to take lessons from experienced people."),(0,n.kt)("li",{parentName:"ul"},'Don\'t just blindly follow the advice of "experts", take it with a grain of salt.'),(0,n.kt)("li",{parentName:"ul"},"If you are asked to provide an estimate for some work, do not give an answer unless you have all the details to make a reasonable estimate. If you are forced to do that, pad it 2x or more depending on how much you don't know about what needs to be done for the task to be marked 'done'."),(0,n.kt)("li",{parentName:"ul"},"Take some time to learn how to use a debugger. Debuggers are quite beneficial when navigating new, undocumented or poorly documented codebase, or to debug weird issues. "),(0,n.kt)("li",{parentName:"ul"},'Avoid saying "it works on my machine" -- yes, I have heard that a lot.'),(0,n.kt)("li",{parentName:"ul"},"Try to turn any feelings of inadequacy or imposter syndrome into energy to push yourself forward and increase your skills and knowledge.")),(0,n.kt)("h3",null,"Mid Level Developers"),(0,n.kt)("p",null,"The next level after the Junior developers is Mid Level developers. They are technically stronger than the Junior developers and can work with minimal supervision. They still have some issues to address in order to jump to Senior level."),(0,n.kt)("p",null,'Intermediate developers are more competent than the Junior developer. They start to see the flaws in their old codebase. They gain the knowledge but they get trapped into the next chain i.e. messing things up while trying to do them "the right way" e.g. hasty abstractions, overuse or unnecessary usage of Design Patterns -- they may be able to provide solution faster than the Junior developers but the solution might put you into another rabbit-hole in the long run. Without supervision, they might delay the execution while trying to "do things properly". They don\'t know when to make tradeoffs and they still don\'t know when to be dogmatic and when to be pragmatic. They can easily become attached to their solution, become myopic, and be unable to take feedback.'),(0,n.kt)("p",null,'Mid-level developers are quite common. Most of the organizations wrongly label them as "Senior Developers". However, they need further mentoring in order to become Senior Developers. The next section describes the responsibilities of a senior developer and how you can become one.'),(0,n.kt)("h3",null,"Senior Developers"),(0,n.kt)("p",null,"Senior developers are the next level after the Mid-level developers. They are the people who can get things done on their own without any supervision and without creating any issues down the road. They are more mature, have gained experience by delivering both good and bad software in the past and have learned from it \u2014 they know how to be pragmatic. Here is the list of things that are normally expected of a Senior Developer:"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"With their past experiences, mistakes made, issues faced by over-designed or under-designed software, they can foresee the problems and persuade the direction of the codebase or the architecture. "),(0,n.kt)("li",{parentName:"ul"},'They don\'t have a "Shiny-Toy" syndrome. They are pragmatic in the execution. They can make the tradeoffs when required, and they know why. They know where to be dogmatic and where to be pragmatic.'),(0,n.kt)("li",{parentName:"ul"},"They have a good picture of the field, know what the best tool for the job is in most cases (even if they don't know the tool). They have the innate ability to pick up a new tool/language/paradigm/etc in order to solve a problem that requires it."),(0,n.kt)("li",{parentName:"ul"},"They are aware they're on a team. They view it as a part of their responsibility to mentor others. This can range from pair programming with junior devs to taking un-glorious tasks of writing docs or tests or whatever else needs to be done."),(0,n.kt)("li",{parentName:"ul"},"They have a deep understanding of the domain - they know about the business side of the company and realize how management/sales/marketing/etc think and benefit from their knowledge of the business domain during the development."),(0,n.kt)("li",{parentName:"ul"},"They don't make empty complaints, they make judgments based on the empirical evidence and they have suggestions for solutions."),(0,n.kt)("li",{parentName:"ul"},"They think much more than just code - they know that their job is to provide solutions to the problems and not just to write code."),(0,n.kt)("li",{parentName:"ul"},"They have the ability to take on large ill-defined problems, define them, break them up, and execute the pieces. A senior developer can take something big and abstract, and run with it. They will come up with a few options, discuss them with the team and implement them."),(0,n.kt)("li",{parentName:"ul"},'They have respect for the code that was written before them. They are generous when passing judgment on the architecture or the design decisions made in the codebase. They approach inheriting legacy code with an "opportunity mindset" rather than a complaining one.'),(0,n.kt)("li",{parentName:"ul"},"They know how to give feedback without hurting anyone.")),(0,n.kt)("h3",null,"Conclusion"),(0,n.kt)("p",null,'All teams are made up of a mix of all these seniority roles. Being content with your role is a bad thing and you should always strive to improve yourself for the next step. This article is based on my beliefs and observations in the industry. Lots of companies care more for the years of experience to decide the seniority which is a crappy metric -- you don\'t gain experience just by spending years. You gain it by continuously solving different sorts of problems, irrespective of the number of years you spend in the industry. I have seen fresh graduates having no industry experience get up to speed quickly and producing work of a Senior Engineer and I have seen Senior developers labeled "senior" merely because of their age and "years of experience". '),(0,n.kt)("p",null,"The most important traits that you need to have in order to step up in your career are: not settling with mediocrity, having an open mindset, being humble, learning from your mistakes, working on the challenging problems and having an opportunity mindset rather than a complaining one."),(0,n.kt)("p",null,"With that said, this post comes to an end. What are your thoughts on the levels of seniority of developers? Feel free to send improvements to this guide. Until next time, stay tuned!"))}c.isMDXComponent=!0},7118:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/oauth.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/oauth.png",alt:null})))))}c.isMDXComponent=!0},319:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"One of my favorite pastimes is going through the history of my favorite projects to learn how they grew over time or how certain features were implemented."),(0,n.kt)("p",null,"The image below describes how I do that in WebStorm."),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/project-history.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/project-history.png",alt:null})))))}c.isMDXComponent=!0},5282:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"Internet has connected people across the world using social media and audio/video calling features along with providing an overabundance of knowledge and tools. All this comes with an inherent danger of security and privacy breaches. In this guide we will talk about ",(0,n.kt)("strong",{parentName:"p"},"proxies")," which play a vital role in mitigating these risks. We will cover the following topics in this guide: "),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#proxy-server"}),"Proxy Server")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#forward-proxy-server"}),"Forward Proxy Server")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#reverse-proxy-server"}),"Reverse Proxy Server")),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("a",Object.assign({parentName:"li"},{href:"#summary"}),"Summary"))),(0,n.kt)("h2",null,"Proxy Server"),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},(0,n.kt)("em",{parentName:"strong"},"Every web request which is sent from the client to a web server goes through some type of proxy server."))," A proxy server acts as a gateway between client ",(0,n.kt)("em",{parentName:"p"},"(you)")," and the internet and separates end-users from the websites you browse. It replaces the source IP address of the web request with the proxy server's IP address and then forwards it to the web server. The web server is unaware of the client, it only sees the proxy server. "),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/proxy/proxy-example.png",alt:"Proxy Server Description"}))," "),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"NOTE: This is not an accurate description rather just an illustration. ")),(0,n.kt)("p",null,"Proxy servers serve as a single point of control making it easier to enforce security policies. It also provides caching mechanism which stores the requested web pages on the proxy server to improve performance. If the requested web-page is available in cache memory then instead of forwarding the request to the web-server it will send the cached webpage back to the client. This ",(0,n.kt)("strong",{parentName:"p"},"saves big companies thousands of dollars")," by reducing load on their servers as their website is visited by millions of users every day."),(0,n.kt)("h2",null,"Forward Proxy Server"),(0,n.kt)("p",null,"A forward proxy is generally implemented on the client side and ",(0,n.kt)("strong",{parentName:"p"},"sits in front of multiple clients")," or client sources. Forward proxy servers are mainly used by companies to ",(0,n.kt)("strong",{parentName:"p"},"manage internet usage")," of their employees and ",(0,n.kt)("strong",{parentName:"p"},"restrict content"),". It is also used as a ",(0,n.kt)("strong",{parentName:"p"},"firewall")," to secure company's network by blocking any request which would pose threat to the companies's network. Proxy servers are also used to ",(0,n.kt)("strong",{parentName:"p"},"bypass geo-restriction")," and browse content which might be blocked in user's country. It enables users to ",(0,n.kt)("strong",{parentName:"p"},"browse anonymously"),", as the proxy server masks their details from the website's servers. "),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/proxy/forward-proxy.png",alt:"Forward Proxy Description"}))," "),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"NOTE: This is not an accurate description rather just an illustration")),(0,n.kt)("h2",null,"Reverse Proxy Server"),(0,n.kt)("p",null,"Reverse proxy servers are implemented on the ",(0,n.kt)("strong",{parentName:"p"},"server side")," instead of the client side. It ",(0,n.kt)("strong",{parentName:"p"},"sits in front of multiple webservers")," and manages the incoming requests by forwarding them to the web servers. It provides anonymity for the ",(0,n.kt)("strong",{parentName:"p"},"back-end web servers and not the client"),". Reverse proxy servers are generally used to perform tasks such as ",(0,n.kt)("strong",{parentName:"p"},"authentication, content caching, and encryption/decryption")," on behalf of the web server. These tasks would ",(0,n.kt)("strong",{parentName:"p"},"hog CPU cycles")," on the web server and degrade performance of the website by introducing high amount of delay in loading the webpage. Reverse proxies are also used as ",(0,n.kt)("strong",{parentName:"p"},"load balancers")," to distribute the incoming traffic efficiently among the web servers but it is ",(0,n.kt)("strong",{parentName:"p"},"not optimized")," for this task. In essence, reverse proxy server is a gateway to a web-server or group of web-servers. "),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/proxy/reverse-proxy.png",alt:"Reverse Proxy Description"}))," "),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"NOTE: This is not an accurate description rather just an illustration. Red lines represent server's response and black lines represent initial request from client(s). ")),(0,n.kt)("h2",null,"Summary"),(0,n.kt)("p",null,"A proxy server acts as a gateway between client ",(0,n.kt)("em",{parentName:"p"},"(you)")," and the internet and separates end-users from the websites you browse. ",(0,n.kt)("strong",{parentName:"p"},(0,n.kt)("em",{parentName:"strong"},"The position of the proxy server on the network determines whether it is a forward or a reverse proxy server")),". Forward proxy is implemented on the client side and ",(0,n.kt)("strong",{parentName:"p"},"sits in front of multiple clients")," or client sources and forwards requests to the web server. Reverse proxy servers are implemented on the ",(0,n.kt)("strong",{parentName:"p"},"server side")," it ",(0,n.kt)("strong",{parentName:"p"},"sits in front of multiple webservers")," and manages the incoming requests by forwarding them to the web servers. "),(0,n.kt)("p",null,"If all this was too much to take in, I have a simple analogy for you. "),(0,n.kt)("p",null,"At a restaurant the waiter/waitress takes your order and gives it to the kitchen head chef. The head chef then calls out the order and assigns tasks to everyone in the kitchen. "),(0,n.kt)("p",null,"In this analogy: "),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"You are the client"),(0,n.kt)("li",{parentName:"ul"},"Your order is the web request"),(0,n.kt)("li",{parentName:"ul"},"Waiter/Waitress is your forward proxy server"),(0,n.kt)("li",{parentName:"ul"},"Kitchen head chef is the reverse proxy server"),(0,n.kt)("li",{parentName:"ul"},"Other chefs working in the kitchen are the web servers")),(0,n.kt)("p",null,"With that said our guide comes to an end. Thank you for reading and feel free to submit any updates to the guide using the links below."))}c.isMDXComponent=!0},9177:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"Random numbers are everywhere from computer games to lottery systems, graphics software, statistical sampling, computer simulation and cryptography. Graphic below is a quick explanation to how the random numbers are generated and why they may not be truly random. "),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/random-numbers.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/random-numbers.png",alt:null})))))}c.isMDXComponent=!0},5301:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"The chart below aims to give you a really basic understanding of how the capability of a DBMS is increased to handle a growing amount of load."),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/scaling-databases.svg"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/scaling-databases.svg",alt:null})))))}c.isMDXComponent=!0},4403:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/session-authentication.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/session-authentication.png",alt:null})))))}c.isMDXComponent=!0},5740:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/ssl-tls-https-ssh.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/ssl-tls-https-ssh.png",alt:null})))))}c.isMDXComponent=!0},2303:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/sso.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/sso.png",alt:null})))))}c.isMDXComponent=!0},5726:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/token-authentication.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/token-authentication.png",alt:null})))))}c.isMDXComponent=!0},9263:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"BitTorrent is a protocol for downloading and distributing files across the Internet. In contrast with the traditional client/server relationship, in which downloaders connect to a central server (for example: watching a movie on Netflix, or loading the web page you're reading now), participants in the BitTorrent network, called ",(0,n.kt)("strong",{parentName:"p"},"peers"),", download pieces of files from ",(0,n.kt)("em",{parentName:"p"},"each other"),"\u2014this is what makes it a ",(0,n.kt)("strong",{parentName:"p"},"peer-to-peer")," protocol. In this article we will investigate how this works, and build our own client that can find peers and exchange data between them."),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/torrent-client/client-server-p2p.png",alt:"diagram showing the difference between client/server (all clients connecting to one server) and peer-to-peer (peers connecting to each other) relationships"}))),(0,n.kt)("p",null,"The protocol evolved organically over the past 20 years, and various people and organizations added extensions for features like encryption, private torrents, and new ways of finding peers. We'll be implementing the ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://www.bittorrent.org/beps/bep_0003.html"}),"original spec")," from 2001 to keep this a weekend-sized project."),(0,n.kt)("p",null,"I'll be using a ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://cdimage.debian.org/debian-cd/current/amd64/bt-cd/#indexlist"}),"Debian ISO")," file as my guinea pig because it's big, but not huge, at 350MB. As a popular Linux distribution, there will be lots of fast and cooperative peers for us to connect to. And we'll avoid the legal and ethical issues related to downloading pirated content."),(0,n.kt)("h2",null,"Finding peers"),(0,n.kt)("p",null,"Here\u2019s a problem: we want to download a file with BitTorrent, but it\u2019s a peer-to-peer protocol and we have no idea where to find peers to download it from. This is a lot like moving to a new city and trying to make friends\u2014maybe we\u2019ll hit up a local pub or a meetup group! Centralized locations like these are the big idea behind trackers, which are central servers that introduce peers to each other. They\u2019re just web servers running over HTTP, and you can find Debian\u2019s at ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"http://bttracker.debian.org:6969/"}),"http://bttracker.debian.org:6969/")),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/torrent-client/trackers.png",alt:"illustration of a desktop computer and laptop sitting at a pub"}))),(0,n.kt)("p",null,"Of course, these central servers are liable to get raided by the feds if they facilitate peers exchanging illegal content. You may remember reading about trackers like TorrentSpy, Popcorn Time, and KickassTorrents getting seized and shut down. New methods cut out the middleman by making even ",(0,n.kt)("strong",{parentName:"p"},"peer discovery")," a distributed process. We won't be implementing them, but if you're interested, some terms you can research are ",(0,n.kt)("strong",{parentName:"p"},"DHT"),", ",(0,n.kt)("strong",{parentName:"p"},"PEX"),", and ",(0,n.kt)("strong",{parentName:"p"},"magnet links"),"."),(0,n.kt)("h3",null,"Parsing a .torrent file"),(0,n.kt)("p",null,"A .torrent file describes the contents of a torrentable file and information for connecting to a tracker. It's all we need in order to kickstart the process of downloading a torrent. Debian's .torrent file looks like this:"),(0,n.kt)("pre",Object.assign({},{className:"language-markdown"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-markdown"}),'d8:announce41:http://bttracker.debian.org:6969/announce7:comment35:"Debian CD from cdimage.debian.org"13:creation datei1573903810e9:httpseedsl145:https://cdimage.debian.org/cdimage/release/10.2.0//srv/cdbuilder.debian.org/dst/deb-cd/weekly-builds/amd64/iso-cd/debian-10.2.0-amd64-netinst.iso145:https://cdimage.debian.org/cdimage/archive/10.2.0//srv/cdbuilder.debian.org/dst/deb-cd/weekly-builds/amd64/iso-cd/debian-10.2.0-amd64-netinst.isoe4:infod6:lengthi351272960e4:name31:debian-10.2.0-amd64-netinst.iso12:piece lengthi262144e6:pieces26800:\ufffd\x1f\ufffd\x0f\ufffd\ufffd\ufffdPS\ufffd^\ufffd\ufffd (binary blob of the hashes of each piece)ee\n')),(0,n.kt)("p",null,"That mess is encoded in a format called ",(0,n.kt)("strong",{parentName:"p"},"Bencode")," (pronounced ",(0,n.kt)("em",{parentName:"p"},"bee-encode"),"), and we'll need to decode it."),(0,n.kt)("p",null,"Bencode can encode roughly the same types of structures as JSON\u2014strings, integers, lists, and dictionaries. Bencoded data is not as human-readable/writable as JSON, but it can efficiently handle binary data and it's really simple to parse from a stream. Strings come with a length prefix, and look like ",(0,n.kt)("inlineCode",{parentName:"p"},"4:spam"),". Integers go between ",(0,n.kt)("em",{parentName:"p"},"start")," and ",(0,n.kt)("em",{parentName:"p"},"end")," markers, so ",(0,n.kt)("inlineCode",{parentName:"p"},"7")," would encode to ",(0,n.kt)("inlineCode",{parentName:"p"},"i7e"),". Lists and dictionaries work in a similar way: ",(0,n.kt)("inlineCode",{parentName:"p"},"l4:spami7ee")," represents ",(0,n.kt)("inlineCode",{parentName:"p"},"['spam', 7]"),", while ",(0,n.kt)("inlineCode",{parentName:"p"},"d4:spami7ee")," means ",(0,n.kt)("inlineCode",{parentName:"p"},"{spam: 7}"),"."),(0,n.kt)("p",null,"In a prettier format, our .torrent file looks like this:"),(0,n.kt)("pre",Object.assign({},{className:"language-markdown"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-markdown"}),'d\n 8:announce\n 41:http://bttracker.debian.org:6969/announce\n 7:comment\n 35:"Debian CD from cdimage.debian.org"\n 13:creation date\n i1573903810e\n 4:info\n d\n 6:length\n i351272960e\n 4:name\n 31:debian-10.2.0-amd64-netinst.iso\n 12:piece length\n i262144e\n 6:pieces\n 26800:\ufffd\x1f\ufffd\x0f\ufffd\ufffd\ufffdPS\ufffd^\ufffd\ufffd (binary blob of the hashes of each piece)\n e\ne\n')),(0,n.kt)("p",null,"In this file, we can spot the URL of the tracker, the creation date (as a Unix timestamp), the name and size of the file, and a big binary blob containing the SHA-1 hashes of each ",(0,n.kt)("strong",{parentName:"p"},"piece"),", which are equally-sized parts of the file we want to download. The exact size of a piece varies between torrents, but they are usually somewhere between 256KB and 1MB. This means that a large file might be made up of ",(0,n.kt)("em",{parentName:"p"},"thousands")," of pieces. We'll download these pieces from our peers, check them against the hashes from our torrent file, assemble them together, and boom, we've got a file!"),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/torrent-client/pieces.png",alt:'"illustration of a file being cut with scissors into multiple pieces, starting with piece 0'}))),(0,n.kt)("p",null,"This mechanism allows us to verify the integrity of each piece as we go. It makes BitTorrent resistant to accidental corruption or intentional ",(0,n.kt)("strong",{parentName:"p"},"torrent poisoning"),". Unless an attacker is capable of breaking SHA-1 with a preimage attack, we will get exactly the content we asked for."),(0,n.kt)("p",null,"It would be really fun to write a bencode parser, but parsing isn't our focus today. But I found Fredrik Lundh's ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://effbot.org/zone/bencode.htm"}),"50 line parser")," to be especially illuminating. For this project, I used ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/jackpal/bencode-go"}),"github.com/jackpal/bencode-go"),":"),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"import")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"github.com/jackpal/bencode-go"'),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"type")," bencodeInfo ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"struct")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n Pieces ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'`bencode:"pieces"`'),"\n PieceLength ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"int")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'`bencode:"piece length"`'),"\n Length ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"int")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'`bencode:"length"`'),"\n Name ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'`bencode:"name"`'),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"type")," bencodeTorrent ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"struct")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n Announce ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'`bencode:"announce"`'),"\n Info bencodeInfo ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'`bencode:"info"`'),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Open parses a torrent file"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Open"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"r io",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Reader",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"bencodeTorrent",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"error"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n bto ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," bencodeTorrent",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," bencode",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Unmarshal"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"r",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"&"),"bto",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"&"),"bto",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"Because I like to keep my structures relatively flat, and I like to keep my application structs separate from my serialization structs, I exported a different, flatter struct named ",(0,n.kt)("inlineCode",{parentName:"p"},"TorrentFile")," and wrote a few helper functions to convert between the two."),(0,n.kt)("p",null,"Notably, I split ",(0,n.kt)("inlineCode",{parentName:"p"},"pieces")," (previously a string) into a slice of hashes (each ",(0,n.kt)("inlineCode",{parentName:"p"},"[20]byte"),") so that I can easily access individual hashes later. I also computed the SHA-1 hash of the entire bencoded ",(0,n.kt)("inlineCode",{parentName:"p"},"info")," dict (the one which contained the name, size, and piece hashes). We know this as the ",(0,n.kt)("strong",{parentName:"p"},"infohash")," and it uniquely identifies files when we talk to trackers and peers. More on this later."),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/torrent-client/info-hash.png",alt:"a name tag saying 'Hello my name is 86d4c80024a469be4c50bc5a102cf71780310074'"}))),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"type")," TorrentFile ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"struct")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n Announce ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string"),"\n InfoHash ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"20"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),"\n PieceHashes ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"20"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),"\n PieceLength ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"int"),"\n Length ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"int"),"\n Name ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"bto ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"bencodeTorrent",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"toTorrentFile"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"TorrentFile",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"error"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// ..."),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("h3",null,"Retrieving peers from the tracker"),(0,n.kt)("p",null,"Now that we have information about the file and its tracker, let's talk to the tracker to ",(0,n.kt)("strong",{parentName:"p"},"announce")," our presence as a peer and to retrieve a list of other peers. We just need to make a GET request to the ",(0,n.kt)("inlineCode",{parentName:"p"},"announce")," URL supplied in the .torrent file, with a few query parameters:"),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"t ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"TorrentFile",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"buildTrackerURL"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"peerID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"20"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," port ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"uint16"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"error"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n base",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," url",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Parse"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Announce",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'""'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n params ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," url",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Values",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"info_hash"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"string"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"InfoHash",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),","),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"peer_id"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"string"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"peerID",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),","),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"port"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"strconv",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Itoa"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"int"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"Port",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),","),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"uploaded"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"0"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),","),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"downloaded"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"0"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),","),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"compact"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"1"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),","),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"left"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"strconv",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Itoa"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Length",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),","),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n base",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"RawQuery ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," params",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Encode"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," base",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"String"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"The important ones:"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("strong",{parentName:"li"},"info_hash"),": Identifies the ",(0,n.kt)("em",{parentName:"li"},"file")," we're trying to download. It's the infohash we calculated earlier from the bencoded ",(0,n.kt)("inlineCode",{parentName:"li"},"info")," dict. The tracker will use this to figure out which peers to show us."),(0,n.kt)("li",{parentName:"ul"},(0,n.kt)("strong",{parentName:"li"},"peer_id"),": A 20 byte name to identify ",(0,n.kt)("em",{parentName:"li"},"ourselves")," to trackers and peers. We'll just generate 20 random bytes for this. Real BitTorrent clients have IDs like ",(0,n.kt)("inlineCode",{parentName:"li"},"-TR2940-k8hj0wgej6ch")," which identify the client software and version\u2014in this case, TR2940 stands for Transmission client 2.94.")),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/torrent-client/info-hash-peer-id.png",alt:"a file with a name tag saying 'info_hash' and a person with a name tag 'peer_id'"}))),(0,n.kt)("h3",null,"Parsing the tracker response"),(0,n.kt)("p",null,"We get back a bencoded response:"),(0,n.kt)("pre",Object.assign({},{className:"language-markdown"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-markdown"}),"d\n 8:interval\n i900e\n 5:peers\n 252:(another long binary blob)\ne\n")),(0,n.kt)("p",null,(0,n.kt)("inlineCode",{parentName:"p"},"Interval")," tells us how often we're supposed to connect to the tracker again to refresh our list of peers. A value of 900 means we should reconnect every 15 minutes (900 seconds)."),(0,n.kt)("p",null,(0,n.kt)("inlineCode",{parentName:"p"},"Peers")," is another long binary blob containing the IP addresses of each peer. It's made out of ",(0,n.kt)("strong",{parentName:"p"},"groups of six bytes"),". The first four bytes in each group represent the peer's IP address\u2014each byte represents a number in the IP. The last two bytes represent the port, as a big-endian ",(0,n.kt)("inlineCode",{parentName:"p"},"uint16"),". ",(0,n.kt)("strong",{parentName:"p"},"Big-endian"),", or ",(0,n.kt)("strong",{parentName:"p"},"network order"),", means that we can interpret a group of bytes as an integer by just squishing them together left to right. For example, the bytes ",(0,n.kt)("inlineCode",{parentName:"p"},"0x1A"),", ",(0,n.kt)("inlineCode",{parentName:"p"},"0xE1")," make ",(0,n.kt)("inlineCode",{parentName:"p"},"0x1AE1"),", or 6881 in decimal."),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/torrent-client/address.png",alt:"diagram showing how 192, 0, 2, 123, 0x1A, 0xE1 can be interpreted as 192.0.1.123:6881"}))),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Peer encodes connection information for a peer"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"type")," Peer ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"struct")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n IP net",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"IP\n Port ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"uint16"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Unmarshal parses peer IP addresses and ports from a buffer"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Unmarshal"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"peersBin ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),"Peer",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"error"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"const")," peerSize ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"6")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// 4 for IP, 2 for port"),"\n numPeers ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"len"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"peersBin",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"/")," peerSize\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"len"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"peersBin",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"%"),"peerSize ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"0")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," fmt",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Errorf"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"Received malformed peers"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n peers ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),"Peer",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," numPeers",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"for")," i ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"0"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," i ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<")," numPeers",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),";")," i",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"++")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n offset ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," i ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*")," peerSize\n peers",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),"i",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"IP ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," net",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"IP"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"peersBin",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),"offset ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," offset",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"4"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n peers",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),"i",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Port ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," binary",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"BigEndian",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Uint16"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"peersBin",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),"offset",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"4")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," offset",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"6"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," peers",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("h2",null,"Downloading from peers"),(0,n.kt)("p",null,"Now that we have a list of peers, it's time to connect with them and start downloading pieces! We can break down the process into a few steps. For each peer, we want to:"),(0,n.kt)("ol",null,(0,n.kt)("li",{parentName:"ol"},"Start a TCP connection with the peer. This is like starting a phone call."),(0,n.kt)("li",{parentName:"ol"},"Complete a two-way BitTorrent ",(0,n.kt)("strong",{parentName:"li"},"handshake"),". ",(0,n.kt)("em",{parentName:"li"},'"Hello?" "Hello."')),(0,n.kt)("li",{parentName:"ol"},"Exchange ",(0,n.kt)("strong",{parentName:"li"},"messages")," to download ",(0,n.kt)("strong",{parentName:"li"},"pieces"),". ",(0,n.kt)("em",{parentName:"li"},'"I\'d like piece #231 please."'))),(0,n.kt)("h2",null,"Start a TCP connection"),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),"conn",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," net",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"DialTimeout"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"tcp"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," peer",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"String"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"3"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"time",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Second",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"I set a timeout so that I don't waste too much time on peers that aren't going to let me connect. For the most part, it's a pretty standard TCP connection."),(0,n.kt)("h3",null,"Complete the handshake"),(0,n.kt)("p",null,"We've just set up a connection with a peer, but we want do a handshake to validate our assumptions that the peer"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"can communicate using the BitTorrent protocol"),(0,n.kt)("li",{parentName:"ul"},"is able to understand and respond to our messages"),(0,n.kt)("li",{parentName:"ul"},"has the file that we want, or at least knows what we're talking about")),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/torrent-client/handshake.png",alt:"Two computers communicating. One asks 'do you speak BitTorrent and have this file?' and the other replies 'I speak BitTorrent and have that file'"}))),(0,n.kt)("p",null,"My father told me that the secret to a good handshake is a firm grip and eye contact. The secret to a good BitTorrent handshake is that it's made up of five parts:"),(0,n.kt)("ol",null,(0,n.kt)("li",{parentName:"ol"},"The length of the protocol identifier, which is always 19 (0x13 in hex)"),(0,n.kt)("li",{parentName:"ol"},"The protocol identifier, called the ",(0,n.kt)("strong",{parentName:"li"},"pstr")," which is always ",(0,n.kt)("inlineCode",{parentName:"li"},"BitTorrent protocol")),(0,n.kt)("li",{parentName:"ol"},"Eight ",(0,n.kt)("strong",{parentName:"li"},"reserved bytes"),", all set to 0. We'd flip some of them to 1 to indicate that we support certain ",(0,n.kt)("a",Object.assign({parentName:"li"},{href:"http://www.bittorrent.org/beps/bep_0010.html"}),"extensions"),". But we don't, so we'll keep them at 0."),(0,n.kt)("li",{parentName:"ol"},"The ",(0,n.kt)("strong",{parentName:"li"},"infohash")," that we calculated earlier to identify which file we want"),(0,n.kt)("li",{parentName:"ol"},"The ",(0,n.kt)("strong",{parentName:"li"},"Peer ID")," that we made up to identify ourselves")),(0,n.kt)("p",null,"Put together, a handshake string might look like this:"),(0,n.kt)("pre",Object.assign({},{className:"language-markdown"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-markdown"}),"\\x13BitTorrent protocol\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x00\\x86\\xd4\\xc8\\x00\\x24\\xa4\\x69\\xbe\\x4c\\x50\\xbc\\x5a\\x10\\x2c\\xf7\\x17\\x80\\x31\\x00\\x74-TR2940-k8hj0wgej6ch\n")),(0,n.kt)("p",null,"After we send a handshake to our peer, we should receive a handshake back in the same format. The infohash we get back should match the one we sent so that we know that we're talking about the same file. If everything goes as planned, we're good to go. If not, we can sever the connection because there's something wrong. ",(0,n.kt)("em",{parentName:"p"},'"Hello?" "\u8fd9\u662f\u8c01\uff1f \u4f60\u60f3\u8981\u4ec0\u4e48\uff1f" "Okay, wow, wrong number."')),(0,n.kt)("p",null,"In our code, let's make a struct to represent a handshake, and write a few methods for serializing and reading them:"),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// A Handshake is a special message that a peer uses to identify itself"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"type")," Handshake ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"struct")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n Pstr ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"string"),"\n InfoHash ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"20"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),"\n PeerID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"20"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Serialize serializes the handshake to a buffer"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"h ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"Handshake",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Serialize"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n buf ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"len"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"h",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Pstr",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"49"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"0"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"len"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"h",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Pstr",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n curr ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"1"),"\n curr ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"copy"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),"curr",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," h",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Pstr",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n curr ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"copy"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),"curr",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"8"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// 8 reserved bytes"),"\n curr ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"copy"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),"curr",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," h",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"InfoHash",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n curr ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"copy"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),"curr",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," h",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"PeerID",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," buf\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Read parses a handshake from a stream"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Read"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"r io",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Reader",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"Handshake",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"error"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Do Serialize(), but backwards"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// ..."),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("h3",null,"Send and receive messages"),(0,n.kt)("p",null,"Once we've completed the initial handshake, we can send and receive ",(0,n.kt)("strong",{parentName:"p"},"messages"),". Well, not quite\u2014if the other peer isn't ready to accept messages, we can't send any until they tell us they're ready. In this state, we're considered ",(0,n.kt)("strong",{parentName:"p"},"choked")," by the other peer. They'll send us an ",(0,n.kt)("strong",{parentName:"p"},"unchoke")," message to let us know that we can begin asking them for data. By default, we assume that we're choked until proven otherwise."),(0,n.kt)("p",null,"Once we've been unchoked, we can then begin sending ",(0,n.kt)("strong",{parentName:"p"},"requests")," for pieces, and they can send us messages back containing pieces."),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/torrent-client/choke.png",alt:"\"A cartoon in which person 1 says 'hello I would like piece number\u2014' and person 2 grabs him by the neck and says '00 00 00 01 00 (choke)'"}))),(0,n.kt)("h4",null,"Interpreting messages"),(0,n.kt)("p",null,"A message has a length, an ",(0,n.kt)("strong",{parentName:"p"},"ID")," and a ",(0,n.kt)("strong",{parentName:"p"},"payload"),". On the wire, it looks like:"),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/torrent-client/message.png",alt:"A message with 4 byte for the length, 1 byte for ID, and an optional payload"}))),(0,n.kt)("p",null,"A message starts with a length indicator which tells us how many bytes long the message will be. It's a 32-bit integer, meaning it's made out of four bytes smooshed together in big-endian order. The next byte, the ",(0,n.kt)("strong",{parentName:"p"},"ID"),", tells us which type of message we're receiving\u2014for example, a ",(0,n.kt)("inlineCode",{parentName:"p"},"2"),' byte means "interested." Finally, the optional ',(0,n.kt)("strong",{parentName:"p"},"payload")," fills out the remaining length of the message."),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"type")," messageID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"uint8"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"const")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"\n MsgChoke messageID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"0"),"\n MsgUnchoke messageID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"1"),"\n MsgInterested messageID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"2"),"\n MsgNotInterested messageID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"3"),"\n MsgHave messageID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"4"),"\n MsgBitfield messageID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"5"),"\n MsgRequest messageID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"6"),"\n MsgPiece messageID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"7"),"\n MsgCancel messageID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"8"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Message stores ID and payload of a message"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"type")," Message ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"struct")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ID messageID\n Payload ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Serialize serializes a message into a buffer of the form"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// "),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Interprets `nil` as a keep-alive message"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"m ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"Message",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Serialize"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," m ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"==")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"4"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n length ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"uint32"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"len"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"m",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Payload",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"1"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// +1 for id"),"\n buf ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"4"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+"),"length",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n binary",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"BigEndian",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"PutUint32"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"0"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"4"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," length",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"4"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"m",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"ID",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"copy"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"5"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," m",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Payload",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," buf\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("p",null,"To read a message from a stream, we just follow the format of a message. We read four bytes and interpret them as a ",(0,n.kt)("inlineCode",{parentName:"p"},"uint32")," to get the ",(0,n.kt)("strong",{parentName:"p"},"length")," of the message. Then, we read that number of bytes to get the ",(0,n.kt)("strong",{parentName:"p"},"ID")," (the first byte) and the ",(0,n.kt)("strong",{parentName:"p"},"payload")," (the remaining bytes)."),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Read parses a message from a stream. Returns `nil` on keep-alive message"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Read"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"r io",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Reader",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"Message",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"error"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n lengthBuf ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"4"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"_"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," io",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"ReadFull"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"r",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," lengthBuf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n length ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," binary",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"BigEndian",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Uint32"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"lengthBuf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// keep-alive message"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," length ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"==")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"0")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n messageBuf ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," length",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"_"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," io",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"ReadFull"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"r",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," messageBuf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n m ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," Message",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ID",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"messageID"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"messageBuf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"0"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),","),"\n Payload",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," messageBuf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"1"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),","),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"&"),"m",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("h4",null,"Bitfields"),(0,n.kt)("p",null,"One of the most interesting types of message is the ",(0,n.kt)("strong",{parentName:"p"},"bitfield"),", which is a data structure that peers use to efficiently encode which pieces they are able to send us. A bitfield looks like a byte array, and to check which pieces they have, we just need to look at the positions of the ",(0,n.kt)("em",{parentName:"p"},"bits")," set to 1. You can think of it like the digital equivalent of a coffee shop loyalty card. We start with a blank card of all ",(0,n.kt)("inlineCode",{parentName:"p"},"0"),", and flip bits to ",(0,n.kt)("inlineCode",{parentName:"p"},"1"),' to mark their positions as "stamped."'),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/torrent-client/bitfield.png",alt:"a coffee shop loyalty card with eight slots, with stamps on the first four slots and a stamp on the second to last slot, represented as 11110010"}))),(0,n.kt)("p",null,"By working with ",(0,n.kt)("em",{parentName:"p"},"bits")," instead of ",(0,n.kt)("em",{parentName:"p"},"bytes"),", this data structure is super compact. We can stuff information about eight pieces in the space of a single byte\u2014the size of a ",(0,n.kt)("inlineCode",{parentName:"p"},"bool"),". The tradeoff is that accessing values becomes a little more tricky. The smallest unit of memory that computers can address are bytes, so to get to our bits, we have to do some bitwise manipulation:"),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// A Bitfield represents the pieces that a peer has"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"type")," Bitfield ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// HasPiece tells if a bitfield has a particular index set"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"bf Bitfield",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"HasPiece"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"index ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"int"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"bool")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n byteIndex ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," index ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"/")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"8"),"\n offset ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," index ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"%")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"8"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," bf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),"byteIndex",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),">>"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"7"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"-"),"offset",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"&"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"1")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"0"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// SetPiece sets a bit in the bitfield"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"bf Bitfield",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"SetPiece"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"index ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"int"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n byteIndex ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," index ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"/")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"8"),"\n offset ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," index ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"%")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"8"),"\n bf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),"byteIndex",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"|=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"1")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<<")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"7")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"-")," offset",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("h3",null,"Putting it all together"),(0,n.kt)("p",null,"We now have all the tools we need to download a torrent: we have a list of peers obtained from the tracker, and we can communicate with them by dialing a TCP connection, initiating a handshake, and sending and receiving messages. Our last big problems are handling the ",(0,n.kt)("strong",{parentName:"p"},"concurrency")," involved in talking to multiple peers at once, and managing the ",(0,n.kt)("strong",{parentName:"p"},"state")," of our peers as we interact with them. These are both classically Hard problems."),(0,n.kt)("h4",null,"Managing concurrency: channels as queues"),(0,n.kt)("p",null,"In Go, we ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://blog.golang.org/share-memory-by-communicating"}),"share memory by communicating"),", and we can think of a Go channel as a cheap thread-safe queue."),(0,n.kt)("p",null,"We'll set up two channels to synchronize our concurrent workers: one for dishing out work (pieces to download) between peers, and another for collecting downloaded pieces. As downloaded pieces come in through the results channel, we can copy them into a buffer to start assembling our complete file."),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Init queues for workers to retrieve work and send results"),"\nworkQueue ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"chan")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"pieceWork",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"len"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"PieceHashes",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\nresults ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"chan")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"pieceResult",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"for")," index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," hash ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"range")," t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"PieceHashes ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n length ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"calculatePieceSize"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n workQueue ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<-")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"&"),"pieceWork",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," hash",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," length",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Start workers"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"for")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"_"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," peer ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"range")," t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Peers ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"go")," t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"startDownloadWorker"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"peer",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," workQueue",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," results",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Collect results into a buffer until full"),"\nbuf ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Length",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\ndonePieces ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"0"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"for")," donePieces ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"len"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"PieceHashes",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n res ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<-"),"results\n begin",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," end ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"calculateBoundsForPiece"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"res",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"copy"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),"begin",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),"end",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," res",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n donePieces",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"++"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"close"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"workQueue",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n")),(0,n.kt)("p",null,"We'll spawn a worker goroutine for each peer we've received from the tracker. It'll connect and handshake with the peer, and then start retrieving work from the ",(0,n.kt)("inlineCode",{parentName:"p"},"workQueue"),", attempting to download it, and sending downloaded pieces back through the ",(0,n.kt)("inlineCode",{parentName:"p"},"results")," channel."),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/torrent-client/download.png",alt:"a flow chart of the download strategy"}))),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"t ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"Torrent",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"startDownloadWorker"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"peer peers",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Peer",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," workQueue ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"chan")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"pieceWork",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," results ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"chan")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"pieceResult",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n c",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," client",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"New"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"peer",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"PeerID",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," t",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"InfoHash",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n log",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Printf"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"Could not handshake with %s. Disconnecting\\n"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," peer",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"IP",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"defer")," c",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Conn",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Close"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n log",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Printf"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"Completed handshake with %s\\n"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," peer",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"IP",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n\n c",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"SendUnchoke"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n c",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"SendInterested"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"for")," pw ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"range")," workQueue ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!"),"c",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Bitfield",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"HasPiece"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n workQueue ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<-")," pw ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Put piece back on the queue"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"continue"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Download the piece"),"\n buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"attemptDownloadPiece"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"c",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n log",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Println"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"Exiting"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n workQueue ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<-")," pw ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Put piece back on the queue"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"checkIntegrity"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n log",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Printf"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"Piece #%d failed integrity check\\n"'),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n workQueue ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<-")," pw ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Put piece back on the queue"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"continue"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n c",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"SendHave"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n results ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<-")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"&"),"pieceResult",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("h4",null,"Managing state"),(0,n.kt)("p",null,"We'll keep track of each peer in a struct, and modify that struct as we read messages. It'll include data like how much we've downloaded from the peer, how much we've requested from them, and whether we're choked. If we wanted to scale this further, we could formalize this as a finite state machine. But a struct and a switch are good enough for now."),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"type")," pieceProgress ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"struct")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n index ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"int"),"\n client ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"client",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Client\n buf ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),"\n downloaded ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"int"),"\n requested ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"int"),"\n backlog ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"int"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"state ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"pieceProgress",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"readMessage"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"error")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n msg",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"client",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Read"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// this call blocks"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"switch")," msg",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"ID ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"case")," message",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"MsgUnchoke",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),"\n state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"client",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Choked ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"false"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"case")," message",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"MsgChoke",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),"\n state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"client",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Choked ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"true"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"case")," message",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"MsgHave",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),"\n index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," message",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"ParseHave"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"msg",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"client",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Bitfield",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"SetPiece"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"case")," message",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"MsgPiece",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":"),"\n n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," message",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"ParsePiece"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," msg",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"downloaded ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+=")," n\n state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"backlog",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"--"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("h4",null,"Time to make requests!"),(0,n.kt)("p",null,"Files, pieces, and piece hashes aren't the full story\u2014we can go further by breaking down pieces into ",(0,n.kt)("strong",{parentName:"p"},"blocks"),". A block is a part of a piece, and we can fully define a block by the ",(0,n.kt)("strong",{parentName:"p"},"index")," of the piece it's part of, its byte ",(0,n.kt)("strong",{parentName:"p"},"offset")," within the piece, and its ",(0,n.kt)("strong",{parentName:"p"},"length"),". When we make requests for data from peers, we are actually requesting ",(0,n.kt)("em",{parentName:"p"},"blocks"),". A block is usually 16KB large, meaning that a single 256 KB piece might actually require 16 requests."),(0,n.kt)("p",null,"A peer is supposed to sever the connection if they receive a request for a block larger than 16KB. However, based on my experience, they're often perfectly happy to satisfy requests up to 128KB. I only got moderate gains in overall speed with larger block sizes, so it's probably better to stick with the spec."),(0,n.kt)("h4",null,"Pipelining"),(0,n.kt)("p",null,"Network round-trips are expensive, and requesting each block one by one will absolutely tank the performance of our download. Therefore, it's important to ",(0,n.kt)("strong",{parentName:"p"},"pipeline")," our requests such that we keep up a constant pressure of some number of unfulfilled requests. This can increase the throughput of our connection by an order of magnitude."),(0,n.kt)("p",null,(0,n.kt)("img",Object.assign({parentName:"p"},{src:"/guides/torrent-client/pipelining.png",alt:"Two email threads simulating peer connections. The thread on the left shows a request followed by a reply, repeated three times. The thread on the left sends three requests, and receives three replies in quick succession."}))),(0,n.kt)("p",null,"Classically, BitTorrent clients kept a queue of five pipelined requests, and that's the value I'll be using. I found that increasing it can up to double the speed of a download. Newer clients use an ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://luminarys.com/posts/writing-a-bittorrent-client.html"}),"adaptive")," queue size to better accommodate modern network speeds and conditions. This is definitely a parameter worth tweaking, and it's pretty low hanging fruit for future performance optimization."),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// MaxBlockSize is the largest number of bytes a request can ask for"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"const")," MaxBlockSize ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"16384"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// MaxBacklog is the number of unfulfilled requests a client can have in its pipeline"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"const")," MaxBacklog ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"5"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"attemptDownloadPiece"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"c ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"client",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Client",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," pw ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*"),"pieceWork",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"error"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n state ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," pieceProgress",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),","),"\n client",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," c",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),","),"\n buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),":")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"make"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token builtin"}),"byte"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"length",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),","),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Setting a deadline helps get unresponsive peers unstuck."),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// 30 seconds is more than enough time to download a 262 KB piece"),"\n c",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Conn",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"SetDeadline"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"time",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Now"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Add"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"30")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"*")," time",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Second",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"defer")," c",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Conn",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"SetDeadline"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"time",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Time",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Disable the deadline"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"for")," state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"downloaded ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<")," pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"length ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// If unchoked, send requests until we have enough unfulfilled requests"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!"),"state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"client",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Choked ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"for")," state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"backlog ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<")," MaxBacklog ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"&&")," state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"requested ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<")," pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"length ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n blockSize ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," MaxBlockSize\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token comment"}),"// Last block might be shorter than the typical block"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"length",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"-"),"state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"requested ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"<")," blockSize ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n blockSize ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"length ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"-")," state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"requested\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," c",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"SendRequest"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"pw",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"index",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"requested",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," blockSize",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"backlog",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"++"),"\n state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"requested ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"+=")," blockSize\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"readMessage"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"return")," state",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"buf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("h4",null,"main.go"),(0,n.kt)("p",null,"This is a short one. We're almost there."),(0,n.kt)("pre",Object.assign({},{className:"language-go"}),(0,n.kt)("code",Object.assign({parentName:"pre"},{className:"language-go"}),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"package")," main\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"import")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"log"'),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"os"'),"\n\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token string"}),'"github.com/veggiedefender/torrent-client/torrentfile"'),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"func")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"main"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n inPath ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," os",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Args",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"1"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),"\n outPath ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," os",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),"Args",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"["),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token number"}),"2"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"]"),"\n\n tf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),",")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),":=")," torrentfile",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Open"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"inPath",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n log",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Fatal"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"err",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n\n err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"=")," tf",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"DownloadToFile"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"outPath",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token keyword"}),"if")," err ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token operator"}),"!=")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token boolean"}),"nil")," ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"{"),"\n log",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"."),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token function"}),"Fatal"),(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"("),"err",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),")"),"\n ",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n",(0,n.kt)("span",Object.assign({parentName:"code"},{className:"token punctuation"}),"}"),"\n")),(0,n.kt)("script",{id:"asciicast-xqRSB0Jec8RN91Zt89rbb9PcL",src:"https://asciinema.org/a/xqRSB0Jec8RN91Zt89rbb9PcL.js",async:!0}),(0,n.kt)("h2",null,"This isn't the full story"),(0,n.kt)("p",null,"For brevity, I included only a few of the important snippets of code. Notably, I left out all the glue code, parsing, unit tests, and the boring parts that build character. View my ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/veggiedefender/torrent-client"}),"full implementation")," if you're interested."))}c.isMDXComponent=!0},8686:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/unfamiliar-codebase.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/unfamiliar-codebase.png",alt:null})))))}c.isMDXComponent=!0},4876:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},(0,n.kt)("strong",{parentName:"p"},"Roadmap is not ready yet"),". Please check back later or ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,n.kt)("p",null,"While we prepare the roadmap, follow this simple advice to learn anything"),(0,n.kt)("blockquote",null,(0,n.kt)("p",{parentName:"blockquote"},"Just ",(0,n.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,n.kt)("p",null,(0,n.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")," "))}c.isMDXComponent=!0},9405:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/web-vitals.png"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/web-vitals.png",alt:null})))))}c.isMDXComponent=!0},9069:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"Since the explosive growth of web-based applications, every developer could stand to benefit from understanding how the Internet works. In this article, accompanied with an introductory series of short videos about the Internet from ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://code.org"}),"code.org"),", you will learn the basics of the Internet and how it works. After going through this article, you will be able to answer the below questions:"),(0,n.kt)("ul",null,(0,n.kt)("li",{parentName:"ul"},"What is the Internet?"),(0,n.kt)("li",{parentName:"ul"},"How does the information move on the internet?"),(0,n.kt)("li",{parentName:"ul"},"How do the networks talk to each other and the protocols involved?"),(0,n.kt)("li",{parentName:"ul"},"What's the relationship between packets, routers, and reliability? "),(0,n.kt)("li",{parentName:"ul"},"HTTP and the HTML \u2013 How are you viewing this webpage in your browser?"),(0,n.kt)("li",{parentName:"ul"},"How is the information transfer on the internet made secure?"),(0,n.kt)("li",{parentName:"ul"},"What is cybersecurity and what are some common internet crimes?")),(0,n.kt)("h2",null,"What is the Internet?"),(0,n.kt)("p",null,"The Internet is a global network of computers connected to each other which communicate through a standardized set of protocols. "),(0,n.kt)("p",null,'In the video below, Vint Cerf, one of the "fathers of the internet," explains the history of how the Internet works and how no one person or organization is really in charge of it. '),(0,n.kt)("iframe",{width:"100%",height:"400",src:"https://www.youtube.com/embed/Dxcc6ycZ73M",frameborder:"0",allow:"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture",allowfullscreen:!0}),(0,n.kt)("h2",null,"Wires, Cables, and Wi-Fi"),(0,n.kt)("p",null,"Information on the Internet moves from computer to another in the form of bits over various mediums, including Ethernet cables, fiber optic cables, and wireless signals (i.e., radio waves)."),(0,n.kt)("p",null,"In the video linked below, you will learn about the different mediums for data transfer on the Internet and the pros and cons for each. "),(0,n.kt)("iframe",{width:"100%",height:"400",src:"https://www.youtube.com/embed/ZhEf7e4kopM",frameborder:"0",allow:"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture",allowfullscreen:!0}),(0,n.kt)("h2",null,"IP Addresses and DNS"),(0,n.kt)("p",null,"Now that you know about the physical medium for the data transfer over the internet, it's time to learn about the protocols involved. How does the information traverse from one computer to another in this massive global network of computers? "),(0,n.kt)("p",null,"In the video below, you will get a brief introduction to IP, DNS, and how these protocols make the Internet work. "),(0,n.kt)("iframe",{width:"100%",height:"400",src:"https://www.youtube.com/embed/5o8CwafCxnU",frameborder:"0",allow:"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture",allowfullscreen:!0}),(0,n.kt)("h2",null,"Packets, Routing, and Reliability"),(0,n.kt)("p",null,"Information transfer on the Internet from one computer to another does not need to follow a fixed path; in fact, it may change paths during the transfer. This information transfer is done in the form of packets and these packets may follow different routes depending on certain factors."),(0,n.kt)("p",null,"In this video, you will learn about how the packets of information are routed from one computer to another to reach the destination. "),(0,n.kt)("iframe",{width:"100%",height:"400",src:"https://www.youtube.com/embed/AYdF7b3nMto",frameborder:"0",allow:"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture",allowfullscreen:!0}),(0,n.kt)("h2",null,"HTTP and HTML"),(0,n.kt)("p",null,"HTTP is the standard protocol by which webpages are transferred over the Internet. The video below is a brief introduction to HTTP and how web browsers load websites for you."),(0,n.kt)("iframe",{width:"100%",height:"400",src:"https://www.youtube.com/embed/kBXQZMmiA4s",frameborder:"0",allow:"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture",allowfullscreen:!0}),(0,n.kt)("h2",null,"Encryption and Public Keys"),(0,n.kt)("p",null,"Cryptography is what keeps our communication secure on the Internet. In this short video, you will learn the basics of cryptograpy, SSL/TLS, and how they help make the communication on the Internet secure."),(0,n.kt)("iframe",{width:"100%",height:"400",src:"https://www.youtube.com/embed/ZghMPWGXexs",frameborder:"0",allow:"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture",allowfullscreen:!0}),(0,n.kt)("h2",null,"Cybersecurity and Crime"),(0,n.kt)("p",null,"In this video, you will learn about the basics of cybersecurity and common cybercrimes"),(0,n.kt)("iframe",{width:"100%",height:"400",src:"https://www.youtube.com/embed/AuYNXgO_f3Y",frameborder:"0",allow:"accelerometer; autoplay; encrypted-media; gyroscope; picture-in-picture",allowfullscreen:!0}),(0,n.kt)("p",null,"And that wraps it up for this article. To learn more about the Internet, ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://twitter.com/kamranahmedse"}),"Kamran Ahmed")," has a nice little guide on ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/dns-in-one-picture"}),"DNS: How a website is found on the Internet"),". Also, go through the episodes of ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://howdns.works/"}),"howdns.works")," and read this ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://hacks.mozilla.org/2018/05/a-cartoon-intro-to-dns-over-https/"}),"cartoon intro to DNS over HTTPS"),"."))}c.isMDXComponent=!0},8681:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"/guides/sli-slo-sla.jpeg"}),(0,n.kt)("img",Object.assign({parentName:"a"},{src:"/guides/sli-slo-sla.jpeg",alt:null})))))}c.isMDXComponent=!0},2935:function(e,a,t){t.r(a),t.d(a,{default:function(){return c}});t(7294);var n=t(4137);function s(e,a){if(null==e)return{};var t,n,s=function(e,a){if(null==e)return{};var t,n,s={},o=Object.keys(e);for(n=0;n=0||(s[t]=e[t]);return s}(e,a);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,t)&&(s[t]=e[t])}return s}var o={};function c(e){var a=e.components,t=s(e,["components"]);return(0,n.kt)("wrapper",Object.assign({},o,t,{components:a,mdxType:"MDXLayout"}),(0,n.kt)("p",null,"We all have heard the mantra ",(0,n.kt)("em",{parentName:"p"},'"build it and they will come"')," many times. Stories of people building a startup or project and seemingly stumbling upon a goldmine aren't few, but they aren't the rule. These stories are still the exception in the mass of launched projects and startups."),(0,n.kt)("p",null,"Before the ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://en.wikipedia.org/wiki/Wright_brothers"}),"Wright brothers"),' built their Kitty Hawk, people generally believed heavy objects could not fly - physics simply forbade it. The idea to regularly board airplanes as we do it these days was unthinkable. It was considered an unrealistic daydream for humans to ever claim the sky. When the first airplanes took off, people were fascinated, of course. It was a topic people continued to talk about for ages. Technology had made something impossible possible. While the wording "build it and they will come" originated from the movie ',(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://en.wikipedia.org/wiki/Field_of_Dreams"}),"Field of Dreams"),", this and similar historic events gave birth to the idea behind it."),(0,n.kt)("p",null,"The engineers' and inventors' dreams came true: spend time doing what you love while the success follows magically. The internet and web-standards democratized access to this dream. But with it, the idea behind it faded and became less and less powerful. In 2020, there are very strong signs the popular saying isn't correct anymore."),(0,n.kt)("h2",null,'Why doesn\'t "build it and they will come" work anymore?'),(0,n.kt)("p",null,"There are a few reasons working hard to make \"build it and they will come\" a thing of the past. This being said, it doesn't mean you can't succeed building a side-project anymore. You've just got to adjust the way you are building it."),(0,n.kt)("h3",null,"Building got much easier"),(0,n.kt)("p",null,"As a software engineer, some websites are a blessing. Most of us couldn't work without GitHub, Stackoverflow and of course Google, ahem, DuckDuckGo. These powerful sites help us to solve problems, learn new techniques and find the right libraries to make building projects easier. If any of these sites are down, most engineers take a break and go for a coffee instead of trying to continue working. Combine this with more sophisticated web-standards and easier access to tooling, and you arrive at a world where building projects isn't just a job for highly specialist developers anymore. Powerful frameworks such as ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://laravel.com/"}),"Laravel")," and ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://quasar.dev/"}),"Quasar Framework")," are available for anyone to build projects on - for free."),(0,n.kt)("p",null,'In fact, building projects got to a point where some people simply build them as an exercise or hobby. If you spend some time browsing GitHub you will be surprised by the open source projects people built without any commercial goals. "Low code" and "No code" are the next wave of people building projects with less technological background.'),(0,n.kt)("h3",null,"Too much going on: information overload"),(0,n.kt)("p",null,"We are living in a world with information overload. In the online sphere, you can find a lot of useful information. But there is also a lot of noise. For each piece of information or advice you can find a number of opposing statements. This is partly due to the fact that the internet made it much easier to publish and share information. Everyone has been given a voice - for good or bad. This makes it much harder to reach potential users. Your new project probably just drowns amongst kitten videos, opinions, and news. Never has the average lifetime of published content been so low. You've got to come up with a marketing plan before setting out on the journey."),(0,n.kt)("h3",null,"Smaller Problems"),(0,n.kt)("p",null,"Besides building being easier than ever before and attention being in short supply, there is another issue making the life of makers, inventors and engineers harder: today's problems are much smaller. Back when the previously mentioned Wright Brothers set out, they fascinated people with the problem they were aiming to address: flying. Unless your name is Elon, your problem is unlikely to attract many people naturally. As a solo developer or indie hacker, the chances are higher for having a much smaller problem in a niche (of a niche). With the information overload mentioned before, niches are pretty much the only way to build a side-project or startup and succeed."),(0,n.kt)("p",null,"Does sound pretty grim for inventors, developers and engineers? Well, yes and no. We've got to tweak the approach to get in front of the eye of potential users and customers."),(0,n.kt)("h2",null,"How to market your project nowadays?"),(0,n.kt)("p",null,"The very first step to improving the odds of success is ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://peterthaleikis.com/business-idea-validation/"}),"idea validation"),". While this sounds fairly obvious, many engineers and developers still don't validate their ideas before starting to build the MVP. The result is another stale project and wasted effort. To succeed you need to work on marketing before you start building anything. In the link mentioned before, I describe my approach to validation and collecting useful marketing information at the same time."),(0,n.kt)("h3",null,"Build your Audience first and the project after."),(0,n.kt)("p",null,"Build your audience before you build your project. Spend your time connecting with potential users, learn from their needs and talk about their problems. This will help you market your project later on. Audience first, project second. There are numerous ways to build an audience. One of the simplest and easiest is to start with a personal or ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://startupnamecheck.com/blog/how-to-start-a-small-business-blog"}),"project blog"),"."),(0,n.kt)("p",null,"Don't use Medium or a similar service - opt for a self-hosted blog as it allows you to build the blog freely to your needs and have decent links back to your project later on. Don't forget to add a newsletter. Newsletters are a key to reconnect in our world of short attention spans."),(0,n.kt)("h3",null,"Tool by Tool"),(0,n.kt)("p",null,'Another approach is the "Tool by Tool" approach. I\'ve first noticed this approach being used by Shopify. The team at Shopify are providing little tools such as a ',(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://hatchful.shopify.com/"}),"logo generator")," and release these tools free for anyone to use. This not just builds goodwill with people; it also allows Shopify to attract powerful backlinks to their projects. As developers we are in the perfect position to build such mini-tools. It boosts morale and drives attention at the same time."),(0,n.kt)("p",null,"Spend some time evaluating where your project or product will deliver value to the end-user. Look at options to split off small, independent tools. Build these and launch them before launching the whole product. This allows you to practice launching and promoting your part-projects at the same time. With each backlink to your part-projects you will enhance your ranking in Google. An example for a maker following this approach is ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://kambanthemaker.com/"}),"Kamban")," with ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://flatga.io/"}),"FlatGA"),". He built FlatGA as phase one of a bigger project currently in development."),(0,n.kt)("h3",null,"Join a Maker community"),(0,n.kt)("p",null,"While you are building your part-projects, don't forget to discuss the progress publicly. This helps to attract an audience around your work and makes the launches easier. You can use Twitter threads and Reddit posts to share updates. A maker community such as ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://getmakerlog.com/"}),"makerlog")," or ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://wip.chat"}),"WIP.chat")," can also extend your reach. These allow you to get instant feedback, keep yourself accountable and they will enhance your reach at the same time."),(0,n.kt)("h3",null,"Getting ready to Launch"),(0,n.kt)("p",null,"Launching seems like this special moment when you release your project into the wide world. Often this moment is combined with high expectations and developers consider launching their project the key - if not only - part of their approach to marketing. While launching can help to attract some initial customers, it shouldn't be your only idea when it comes to marketing. You should also know that launching isn't a single event. You can (and should) launch again and again. Every time you launch you are increasing the chance to reach more and new customers. After the launch is before the launch."),(0,n.kt)("h3",null,"Marketing Is an On-going Fight"),(0,n.kt)("p",null,"Many developers plan to launch their product on a few sites and see where it takes their project from there on. This works well, if your product goes viral by luck. A much more sustainable approach is constantly working a little on it. Marketing is most effective, if done consistently. That holds true for blogging as well as most other forms of marketing. A simple approach to keep you on the path to market your project regularly is subscribing to a free ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://wheretopost.email"}),"newsletter with small marketing opportunities"),". This way, you are regularly reminded and given bite-sized tasks to complete."),(0,n.kt)("h2",null,"Closing Words"),(0,n.kt)("p",null,"I hope the article helped you to wrap your head around the idea that building side-projects alone doesn't solve any issues anymore. If you like what you've just read and want to read more, please consider subscribing to ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://peterthaleikis.com/newsletter"}),"my newsletter"),". I'll send out the occasional email about interesting new articles or side-projects."),(0,n.kt)("h2",null,"About the author"),(0,n.kt)("p",null,(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://peterthaleikis.com/"}),"Peter Thaleikis")," a software engineer and business owner. He has been developing web applications since around 2000. Before he started his own software development company ",(0,n.kt)("a",Object.assign({parentName:"p"},{href:"https://bringyourownideas.com/"}),"Bring Your Own Ideas Ltd."),", he has been Lead Developer for multiple organisations."))}c.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/_next/static/chunks/515-100e7e5de90f7342.js b/_next/static/chunks/515-100e7e5de90f7342.js new file mode 100644 index 000000000..cdd753d05 --- /dev/null +++ b/_next/static/chunks/515-100e7e5de90f7342.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[515],{6673:function(e,t,r){r.d(t,{$:function(){return c}});var n=r(5893),o=r(8527),i=r(4651),a=r(8641);function s(){return(0,n.jsxs)(n.Fragment,{children:[(0,n.jsxs)(o.Kq,{isInline:!0,d:["none","none","flex"],color:"gray.400",fontWeight:600,spacing:"30px",children:[(0,n.jsx)(o.rU,{_hover:{color:"white"},href:"/roadmaps",children:"Roadmaps"}),(0,n.jsx)(o.rU,{_hover:{color:"white"},href:"/guides",children:"Guides"}),(0,n.jsx)(o.rU,{_hover:{color:"white"},href:"/watch",children:"Videos"}),(0,n.jsx)(o.rU,{_hover:{color:"white"},href:"/about",children:"About"}),(0,n.jsx)(o.rU,{_hover:{color:"white"},href:a.url.youtube,target:"_blank",children:"YouTube"})]}),(0,n.jsxs)(o.Kq,{d:["flex","flex","none"],color:"gray.400",fontWeight:600,spacing:0,children:[(0,n.jsx)(o.rU,{py:"7px",borderBottomWidth:1,borderBottomColor:"gray.800",_hover:{color:"white"},href:"/roadmaps",children:"Roadmaps"}),(0,n.jsx)(o.rU,{py:"7px",borderBottomWidth:1,borderBottomColor:"gray.800",_hover:{color:"white"},href:"/guides",children:"Guides"}),(0,n.jsx)(o.rU,{py:"7px",borderBottomWidth:1,borderBottomColor:"gray.800",_hover:{color:"white"},href:"/watch",children:"Videos"}),(0,n.jsx)(o.rU,{py:"7px",borderBottomWidth:1,borderBottomColor:"gray.800",_hover:{color:"white"},href:"/thanks",children:"Thanks"}),(0,n.jsx)(o.rU,{py:"7px",borderBottomWidth:1,borderBottomColor:"gray.800",_hover:{color:"white"},href:"/about",children:"About"}),(0,n.jsx)(o.rU,{py:"7px",_hover:{color:"white"},target:"_blank",href:a.url.youtube,children:"YouTube"})]})]})}function c(){return(0,n.jsxs)(o.xu,{bg:"brand.hero",p:["25px 0","25px 0","40px 0"],children:[(0,n.jsxs)(o.W2,{maxW:"container.md",children:[(0,n.jsx)(s,{}),(0,n.jsxs)(o.xu,{mt:["40px","40px","50px"],mb:"40px",maxW:"500px",children:[(0,n.jsxs)(o.kC,{spacing:0,alignItems:"center",color:"gray.400",children:[(0,n.jsxs)(o.rU,{d:"flex",alignItems:"center",fontWeight:600,_hover:{textDecoration:"none",color:"white"},href:"/",children:[(0,n.jsx)(i.Ee,{alt:"",h:"25px",w:"25px",src:"/logo.svg",mr:"6px"}),"roadmap.sh"]}),(0,n.jsx)(o.xv,{as:"span",mx:"7px",children:"by"}),(0,n.jsx)(o.rU,{bg:"blue.500",px:"6px",py:"2px",rounded:"4px",color:"white",fontWeight:600,fontSize:"13px",_hover:{textDecoration:"none",bg:"blue.600"},href:a.url.twitter,target:"_blank",children:"@kamranahmedse"})]}),(0,n.jsx)(o.xv,{my:"15px",fontSize:"14px",color:"gray.500",children:"Community created roadmaps, articles, resources and journeys to help you choose your path and grow in your career."}),(0,n.jsxs)(o.xv,{fontSize:"14px",color:"gray.500",children:[(0,n.jsx)(o.xv,{as:"span",mr:"10px",children:"\xa9 roadmap.sh"}),"\xb7",(0,n.jsx)(o.rU,{href:"/about",_hover:{textDecoration:"none",color:"white"},color:"gray.400",mx:"10px",children:"FAQs"}),"\xb7",(0,n.jsx)(o.rU,{href:"/terms",_hover:{textDecoration:"none",color:"white"},color:"gray.400",mx:"10px",children:"Terms"}),"\xb7",(0,n.jsx)(o.rU,{href:"/privacy",_hover:{textDecoration:"none",color:"white"},color:"gray.400",mx:"10px",children:"Privacy"})]})]})]}),(0,n.jsx)("script",{async:!0,type:"text/javascript",src:"//cdn.carbonads.com/carbon.js?serve=CE7DLK3Y&placement=roadmapsh",id:"_carbonads_js"})]})}},2438:function(e,t,r){r.d(t,{e:function(){return g}});var n,o,i=r(5893),a=r(7294),s=r(9876),c=r(8527),x=r(6723),l=r(4746);function p(){return(p=Object.assign||function(e){for(var t=1;t=0||(r[o]=e[o]);return r}(e,t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);for(a=0;a=0||Object.prototype.propertyIsEnumerable.call(e,o)&&(r[o]=e[o])}return r}var n={};function i(e){var t=e.components,o=r(e,["components"]);return(0,a.kt)("wrapper",Object.assign({},n,o,{components:t,mdxType:"MDXLayout"}),(0,a.kt)("h1",null,"Terms of Service"),(0,a.kt)("p",null,"PLEASE NOTE THAT YOUR USE OF AND ACCESS TO OUR SERVICES (DEFINED BELOW) ARE SUBJECT TO THE FOLLOWING TERMS; IF YOU DO NOT AGREE TO ALL OF THE FOLLOWING, YOU MAY NOT USE OR ACCESS THE SERVICES IN ANY MANNER."),(0,a.kt)("p",null,"Welcome to roadmap.sh. Please read on to learn the rules and restrictions that govern your use of our website(s), products, services and applications (the \u201cServices\u201d). If you have any questions, comments, or concerns regarding these terms or the Services, please contact us at ",(0,a.kt)("a",Object.assign({parentName:"p"},{href:"mailto:kamranahmed.se@gmail.com"}),"kamranahmed.se@gmail.com"),"."),(0,a.kt)("p",null,"These Terms of Use (the \u201cTerms\u201d) are a binding contract between you and roadmap.sh (\u201croadmap.sh,\u201d \u201cwe\u201d, and \u201cus\u201d). You must agree to and accept all of the Terms, or you don\u2019t have the right to use the Services. Your using the Services in any way means that you agree to all of these Terms, and these Terms will remain in effect while you use the Services. These Terms include the provisions in this document, as well as those in the Privacy Policy and Copyright Dispute Policy."),(0,a.kt)("h2",null,"Will these Terms ever change?"),(0,a.kt)("p",null,"We are constantly trying to improve our Services, so these Terms may need to change along with the Services. We reserve the right to change the Terms at any time, but if we do, we will bring it to your attention by updating the terms on the roadmap.sh website, by sending you an email, and/or by some other means."),(0,a.kt)("p",null,"If you don\u2019t agree with the new Terms, you are free to reject them, however it means you will no longer be able to use the Services. If you use the Services in any way after a change to the Terms is effective, that means you agree to all of the changes."),(0,a.kt)("p",null,"Except for changes by us as described here, no other amendment or modification of these Terms will be effective unless in writing and signed by both you and us."),(0,a.kt)("h2",null,"Do these terms cover privacy?"),(0,a.kt)("p",null,"You can view the current roadmap.sh Privacy Policy ",(0,a.kt)("a",Object.assign({parentName:"p"},{href:"/privacy"}),"here"),"."),(0,a.kt)("p",null,"The Children\u2019s Online Privacy Protection Act (\u201cCOPPA\u201d) requires that online service providers obtain parental consent before they knowingly collect personally identifiable information online from children who are under 13. We do not knowingly collect or solicit personally identifiable information from children under 13. If you are a child under 13, please do not attempt to register for the Services or send any personal information about yourself to us. If we learn we have collected personal information from a child under 13, we will delete that information as quickly as possible. If you believe that a child under 13 may have provided us personal information, please contact us at ",(0,a.kt)("a",Object.assign({parentName:"p"},{href:"mailto:kamranahmed.se@gmail.com"}),"kamranahmed.se@gmail.com"),"."),(0,a.kt)("h2",null,"What are the basics of using roadmap.sh?"),(0,a.kt)("p",null,"You may be required to sign up for an account, and select a password and username. You agree to provide us with accurate, complete, and up-to-date registration information about yourself. You may not select as your username a name that you don\u2019t have the right to use, or another person\u2019s name with the intent to impersonate that person. You may not transfer your account to anyone else without our prior written permission."),(0,a.kt)("p",null,"You represent and warrant that you are an individual of legal age to form a binding contract, or if not, you\u2019ve received your parent\u2019s or guardian\u2019s permission to use the Services and gotten your parent or guardian to agree to these Terms on your behalf."),(0,a.kt)("p",null,"You will only use the Services for your own internal, personal, non-commercial use, and not on behalf of or for the benefit of any third party, and only in a manner that complies with all laws that apply to you. If your use of the Services is prohibited by applicable laws, then you aren\u2019t authorized to use the Services. We can\u2019t and won\u2019t be responsible for your using the Services in a way that breaks the law."),(0,a.kt)("p",null,"You will not share your account or password with anyone, and you must protect the security of your account and your password. You\u2019re responsible for any activity associated with your account."),(0,a.kt)("h2",null,"Your use of the Services is subject to the following additional restrictions:"),(0,a.kt)("p",null,"You represent, warrant, and agree that you will not contribute any Content or User Submission (each of those terms is defined below) or otherwise use the Services or interact with the Services in a manner that:"),(0,a.kt)("p",null,"(a) Infringes or violates the intellectual property rights or any other rights of anyone else (including roadmap.sh); (b) Violates any law or regulation, including any applicable export control laws; (c) Is harmful, fraudulent, deceptive, threatening, harassing, defamatory, obscene, or otherwise objectionable; (d) Jeopardizes the security of your roadmap.sh account or anyone else\u2019s (such as allowing someone else to log in to the Services as you); (e) Attempts, in any manner, to obtain the password, account, or other security information from any other user; (f) Violates the security of any computer network, or cracks any passwords or security encryption codes; (g) Runs Maillist, Listserv, any form of auto-responder or \u201cspam\u201d on the Services, or any processes that run or are activated while you are not logged into the Services, or that otherwise interfere with the proper working of the Services (including by placing an unreasonable load on the Services\u2019 infrastructure); (h) \u201cCrawls,\u201d \u201cscrapes,\u201d or \u201cspiders\u201d any page, data, or portion of or relating to the Services or Content (through use of manual or automated means); (i) Copies or stores any significant portion of the Content; (j) Decompiles, reverse engineers, or otherwise attempts to obtain the source code or underlying ideas or information of or relating to the Services."),(0,a.kt)("p",null,"A violation of any of the foregoing is grounds for termination of your right to use or access the Services."),(0,a.kt)("h2",null,"What are my rights in roadmap.sh?"),(0,a.kt)("p",null,"The materials displayed or performed or available on or through the Services, including, but not limited to, text, graphics, data, articles, photos, images, illustrations, User Submissions, and so forth (all of the foregoing, the \u201cContent\u201d) are protected by copyright and/or other intellectual property laws. You promise to abide by all copyright notices, trademark rules, information, and restrictions contained in any Content you access through the Services, and you won\u2019t use, copy, reproduce, modify, translate, publish, broadcast, transmit, distribute, perform, upload, display, license, sell or otherwise exploit for any purpose any Content not owned by you, (i) without the prior consent of the owner of that Content or (ii) in a way that violates someone else\u2019s (including roadmap.sh\u2019s) rights."),(0,a.kt)("p",null,"You understand that roadmap.sh owns the Services. You won\u2019t modify, publish, transmit, participate in the transfer or sale of, reproduce (except as expressly provided in this Section), create derivative works based on, or otherwise exploit any of the Services."),(0,a.kt)("p",null,"The Services may allow you to copy or download certain Content; please remember that just because this functionality exists, doesn\u2019t mean that all the restrictions above don\u2019t apply \u2013 they do!"),(0,a.kt)("h2",null,"Do I have to grant any licenses to roadmap.sh or to other users?"),(0,a.kt)("p",null,"Anything you post, upload, share, store, or otherwise provide through the Services is your \u201cUser Submission.\u201d Some User Submissions are viewable by other users. In order to display your User Submissions on the Services, and to allow other users to enjoy them (where applicable), you grant us certain rights in those User Submissions. Please note that all of the following licenses are subject to our Privacy Policy to the extent they relate to User Submissions that are also your personally-identifiable information."),(0,a.kt)("p",null,"For all User Submissions, you hereby grant roadmap.sh a license to translate, modify (for technical purposes, for example making sure your content is viewable on an iPhone as well as a computer) and reproduce and otherwise act with respect to such User Submissions, in each case to enable us to operate the Services, as described in more detail below. This is a license only \u2013 your ownership in User Submissions is not affected."),(0,a.kt)("p",null,"If you store a User Submission in your own personal roadmap.sh account, in a manner that is not viewable by any other user except you (a \u201cPersonal User Submission\u201d), you grant roadmap.sh the license above, as well as a license to display, perform, and distribute your Personal User Submission for the sole purpose of making that Personal User Submission accessible to you and providing the Services necessary to do so."),(0,a.kt)("p",null,"If you share a User Submission only in a manner that only certain specified users can view (for example, a private message to one or more other users) (a \u201cLimited Audience User Submission\u201d), then you grant roadmap.sh the licenses above, as well as a license to display, perform, and distribute your Limited Audience User Submission for the sole purpose of making that Limited Audience User Submission accessible to such other specified users, and providing the Services necessary to do so. Also, you grant such other specified users a license to access that Limited Audience User Submission, and to use and exercise all rights in it, as permitted by the functionality of the Services."),(0,a.kt)("p",null,"If you share a User Submission publicly on the Services and/or in a manner that more than just you or certain specified users can view, or if you provide us (in a direct email or otherwise) with any feedback, suggestions, improvements, enhancements, and/or feature requests relating to the Services] (each of the foregoing, a \u201cPublic User Submission\u201d), then you grant roadmap.sh the licenses above, as well as a license to display, perform, and distribute your Public User Submission for the purpose of making that Public User Submission accessible to all roadmap.sh users and providing the Services necessary to do so, as well as all other rights necessary to use and exercise all rights in that Public User Submission in connection with the Services and/or otherwise in connection with roadmap.sh\u2019s business for any purpose, provided that roadmap.sh will try to notify you if it uses your Public User Submission for any reason other than displaying it on the Services. Also, you grant all other users of the Services a license to access that Public User Submission, and to use and exercise all rights in it, as permitted by the functionality of the Services."),(0,a.kt)("p",null,"You agree that the licenses you grant are royalty-free, perpetual, sublicenseable, irrevocable, and worldwide, provided that when you delete your roadmap.sh account, we will stop displaying your User Submissions (other than Public User Submissions, which may remain fully available)] to other users (if applicable), but you understand and agree that it may not be possible to completely delete that content from roadmap.sh\u2019s records, and that your User Submissions may remain viewable elsewhere to the extent that they were copied or stored by other users."),(0,a.kt)("p",null,"Finally, you understand and agree that roadmap.sh, in performing the required technical steps to provide the Services to our users (including you), may need to make changes to your User Submissions to conform and adapt those User Submissions to the technical requirements of connection networks, devices, services, or media, and the foregoing licenses include the rights to do so."),(0,a.kt)("h2",null,"What if I see something on the Services that infringes my copyright?"),(0,a.kt)("p",null,"You may have heard of the Digital Millennium Copyright Act (the \u201cDMCA\u201d), as it relates to online service providers, like roadmap.sh, being asked to remove material that allegedly violates someone\u2019s copyright. We respect others\u2019 intellectual property rights, and we reserve the right to delete or disable Content alleged to be infringing, and to terminate the accounts of repeat alleged infringers."),(0,a.kt)("h2",null,"Who is responsible for what I see and do on the Services?"),(0,a.kt)("p",null,"Any information or content publicly posted or privately transmitted through the Services is the sole responsibility of the person from whom such content originated, and you access all such information and content at your own risk, and we aren\u2019t liable for any errors or omissions in that information or content or for any damages or loss you might suffer in connection with it. We cannot control and have no duty to take any action regarding how you may interpret and use the Content or what actions you may take as a result of having been exposed to the Content, and you hereby release us from all liability for you having acquired or not acquired Content through the Services. We can\u2019t guarantee the identity of any users with whom you interact in using the Services and are not responsible for which users gain access to the Services."),(0,a.kt)("p",null,"You are responsible for all Content you contribute, in any manner, to the Services, and you represent and warrant you have all rights necessary to do so, in the manner in which you contribute it. You will keep all your registration information accurate and current. You are responsible for all your activity in connection with the Services."),(0,a.kt)("p",null,"The Services may contain links or connections to third party websites or services that are not owned or controlled by roadmap.sh. When you access third party websites or use third party services, you accept that there are risks in doing so, and that roadmap.sh is not responsible for such risks. We encourage you to be aware when you leave the Services and to read the terms and conditions and privacy policy of each third party website or service that you visit or utilize."),(0,a.kt)("p",null,"roadmap.sh has no control over, and assumes no responsibility for, the content, accuracy, privacy policies, or practices of or opinions expressed in any third party websites or by any third party that you interact with through the Services. In addition, roadmap.sh will not and cannot monitor, verify, censor or edit the content of any third party site or service. By using the Services, you release and hold us harmless from any and all liability arising from your use of any third party website or service."),(0,a.kt)("p",null,"Your interactions with organizations and/or individuals found on or through the Services, including payment and delivery of goods or services, and any other terms, conditions, warranties or representations associated with such dealings, are solely between you and such organizations and/or individuals. You should make whatever investigation you feel necessary or appropriate before proceeding with any online or offline transaction with any of these third parties. You agree that roadmap.sh shall not be responsible or liable for any loss or damage of any sort incurred as the result of any such dealings."),(0,a.kt)("p",null,'If there is a dispute between participants on this site, or between users and any third party, you agree that roadmap.sh is under no obligation to become involved. In the event that you have a dispute with one or more other users, you release roadmap.sh, its officers, employees, agents, and successors from claims, demands, and damages of every kind or nature, known or unknown, suspected or unsuspected, disclosed or undisclosed, arising out of or in any way related to such disputes and/or our Services. If you are a California resident, you shall and hereby do waive California Civil Code Section 1542, which says: "A general release does not extend to claims which the creditor does not know or suspect to exist in his or her favor at the time of executing the release, which, if known by him or her must have materially affected his or her settlement with the debtor."'),(0,a.kt)("h2",null,"Will roadmap.sh ever change the Services?"),(0,a.kt)("p",null,"We\u2019re always trying to improve the Services, so they may change over time. We may suspend or discontinue any part of the Services, or we may introduce new features or impose limits on certain features or restrict access to parts or all of the Services. We\u2019ll try to give you notice when we make a material change to the Services that would adversely affect you, but this isn\u2019t always practical. Similarly, we reserve the right to remove any Content from the Services at any time, for any reason (including, but not limited to, if someone alleges you contributed that Content in violation of these Terms), in our sole discretion, and without notice."),(0,a.kt)("h2",null,"Does roadmap.sh cost anything?"),(0,a.kt)("p",null,"The roadmap.sh Services are currently free, but we reserve the right to charge for certain or all Services in the future. We will notify you before any Services you are then using begin carrying a fee, and if you wish to continue using such Services, you must pay all applicable fees for such Services."),(0,a.kt)("h2",null,"What if I want to stop using roadmap.sh?"),(0,a.kt)("p",null,"You\u2019re free to do that at any time, by contacting us at ",(0,a.kt)("a",Object.assign({parentName:"p"},{href:"mailto:kamranahmed.se@gmail.com"}),"kamranahmed.se@gmail.com"),"; please refer to our Privacy Policy, as well as the licenses above, to understand how we treat information you provide to us after you have stopped using our Services. roadmap.sh is also free to terminate (or suspend access to) your use of the Services or your account, for any reason in our discretion, including your breach of these Terms. roadmap.sh has the sole right to decide whether you are in violation of any of the restrictions set forth in these Terms."),(0,a.kt)("p",null,"Account termination may result in destruction of any Content associated with your account, so keep that in mind before you decide to terminate your account. We will try to provide advance notice to you prior to our terminating your account so that you are able to retrieve any important User Submissions you may have stored in your account (to the extent allowed by law and these Terms), but we may not do so if we determine it would be impractical, illegal, not in the interest of someone\u2019s safety or security, or otherwise harmful to the rights or property of roadmap.sh."),(0,a.kt)("p",null,"Provisions that, by their nature, should survive termination of these Terms shall survive termination. By way of example, all of the following will survive termination: any obligation you have to pay us or indemnify us, any limitations on our liability, any terms regarding ownership or intellectual property rights, and terms regarding disputes between us."),(0,a.kt)("h2",null,"What if I use roadmap.sh via an app available on the Apple App Store?"),(0,a.kt)("p",null,"These Terms apply to your use of all the Services, including the iOS applications available via the Apple, Inc. (\u201cApple\u201d) App Store (the \u201cApplication\u201d), but the following additional terms also apply to the Application:"),(0,a.kt)("p",null,"(a) Both you and roadmap.sh acknowledge that the Terms are concluded between you and roadmap.sh only, and not with Apple, and that Apple is not responsible for the Application or the Content; (b) The Application is licensed to you on a limited, non-exclusive, non-transferrable, non-sublicensable basis, solely to be used in connection with the Services for your private, personal, non-commercial use, subject to all the terms and conditions of these Terms as they are applicable to the Services; (c) You will only use the Application in connection with an Apple device that you own or control; (d) You acknowledge and agree that Apple has no obligation whatsoever to furnish any maintenance and support services with respect to the Application; (e) In the event of any failure of the Application to conform to any applicable warranty, including those implied by law, you may notify Apple of such failure; upon notification, Apple\u2019s sole warranty obligation to you will be to refund to you the purchase price, if any, of the Application; (f) You acknowledge and agree that roadmap.sh, and not Apple, is responsible for addressing any claims you or any third party may have in relation to the Application; (g) You acknowledge and agree that, in the event of any third party claim that the Application or your possession and use of the Application infringes that third party\u2019s intellectual property rights, roadmap.sh, and not Apple, will be responsible for the investigation, defense, settlement and discharge of any such infringement claim; (h) You represent and warrant that you are not located in a country subject to a U.S. Government embargo, or that has been designated by the U.S. Government as a \u201cterrorist supporting\u201d country, and that you are not listed on any U.S. Government list of prohibited or restricted parties; (i) Both you and roadmap.sh acknowledge and agree that, in your use of the Application, you will comply with any applicable third party terms of agreement which may affect or be affected by such use; and (j) Both you and roadmap.sh acknowledge and agree that Apple and Apple\u2019s subsidiaries are third party beneficiaries of these Terms, and that upon your acceptance of these Terms, Apple will have the right (and will be deemed to have accepted the right) to enforce these Terms against you as the third party beneficiary hereof."),(0,a.kt)("h2",null,"What are roadmap.sh's Terms of Sale?"),(0,a.kt)("p",null,"If you purchase any goods or services or license any software through the site whether or not in connection with an Offer or Discount, in addition to agreeing to these Terms of Use, you are agreeing to the Terms of Sale, available here."),(0,a.kt)("h2",null,"What else do I need to know?"),(0,a.kt)("p",null,"Warranty Disclaimer. Neither roadmap.sh nor its licensors or suppliers makes any representations or warranties concerning any content contained in or accessed through the Services, and we will not be responsible or liable for the accuracy, copyright compliance, legality, or decency of material contained in or accessed through the Services. We (and our licensors and suppliers) make no representations or warranties regarding suggestions or recommendations of services or products offered or purchased through the Services. Products and services purchased or offered (whether or not following such recommendations and suggestions) through the Services are provided \u201cAS IS\u201d and without any warranty of any kind from roadmap.sh or others (unless, with respect to such others only, provided expressly and unambiguously in writing by a designated third party for a specific product). THE SERVICES AND CONTENT ARE PROVIDED BY ROADMAP.SH (AND ITS LICENSORS AND SUPPLIERS) ON AN \u201cAS-IS\u201d BASIS, WITHOUT WARRANTIES OR ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, WITHOUT LIMITATION, IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, NON-INFRINGEMENT, OR THAT USE OF THE SERVICES WILL BE UNINTERRUPTED OR ERROR-FREE. SOME STATES DO NOT ALLOW LIMITATIONS ON HOW LONG AN IMPLIED WARRANTY LASTS, SO THE ABOVE LIMITATIONS MAY NOT APPLY TO YOU."),(0,a.kt)("p",null,"Limitation of Liability. TO THE FULLEST EXTENT ALLOWED BY APPLICABLE LAW, UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY (INCLUDING, WITHOUT LIMITATION, TORT, CONTRACT, STRICT LIABILITY, OR OTHERWISE) SHALL ROADMAP.SH (OR ITS LICENSORS OR SUPPLIERS) BE LIABLE TO YOU OR TO ANY OTHER PERSON FOR (A) ANY INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY KIND, INCLUDING DAMAGES FOR LOST PROFITS, LOSS OF GOODWILL, WORK STOPPAGE, ACCURACY OF RESULTS, OR COMPUTER FAILURE OR MALFUNCTION, OR (B) ANY AMOUNT, IN THE AGGREGATE, IN EXCESS OF THE GREATER OF (I) $100 OR (II) THE AMOUNTS PAID BY YOU TO ROADMAP.SH IN CONNECTION WITH THE SERVICES IN THE TWELVE (12) MONTH PERIOD PRECEDING THIS APPLICABLE CLAIM, OR (III) ANY MATTER BEYOND OUR REASONABLE CONTROL. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF CERTAIN DAMAGES, SO THE ABOVE LIMITATION AND EXCLUSIONS MAY NOT APPLY TO YOU."),(0,a.kt)("p",null,"Indemnity. To the fullest extent allowed by applicable law, You agree to indemnify and hold roadmap.sh, its affiliates, officers, agents, employees, and partners harmless from and against any and all claims, liabilities, damages (actual and consequential), losses and expenses (including attorneys\u2019 fees) arising from or in any way related to any third party claims relating to (a) your use of the Services (including any actions taken by a third party using your account), and (b) your violation of these Terms. In the event of such a claim, suit, or action (\u201cClaim\u201d), we will attempt to provide notice of the Claim to the contact information we have for your account (provided that failure to deliver such notice shall not eliminate or reduce your indemnification obligations hereunder)."),(0,a.kt)("p",null,"Assignment. You may not assign, delegate or transfer these Terms or your rights or obligations hereunder, or your Services account, in any way (by operation of law or otherwise) without roadmap.sh\u2019s prior written consent. We may transfer, assign, or delegate these Terms and our rights and obligations without consent."),(0,a.kt)("p",null,'Choice of Law; Arbitration. These Terms are governed by and will be construed under the laws of the State of California, without regard to the conflicts of laws provisions thereof. Any dispute arising from or relating to the subject matter of these Terms shall be finally settled in San Francisco County, California, in English, in accordance with the Streamlined Arbitration Rules and Procedures of Judicial Arbitration and Mediation Services, Inc. ("JAMS") then in effect, by one commercial arbitrator with substantial experience in resolving intellectual property and commercial contract disputes, who shall be selected from the appropriate list of JAMS arbitrators in accordance with such Rules. Judgment upon the award rendered by such arbitrator may be entered in any court of competent jurisdiction. Notwithstanding the foregoing obligation to arbitrate disputes, each party shall have the right to pursue injunctive or other equitable relief at any time, from any court of competent jurisdiction. For all purposes of this Agreement, the parties consent to exclusive jurisdiction and venue in the state or federal courts located in, respectively, San Francisco County, California, or the Northern District of California. Any arbitration under this Agreement will take place on an individual basis: class arbitrations and class actions are not permitted. YOU UNDERSTAND AND AGREE THAT BY ENTERING INTO THIS AGREEMENT, YOU AND ROADMAP.SH ARE EACH WAIVING THE RIGHT TO TRIAL BY JURY OR TO PARTICIPATE IN A CLASS ACTION.'),(0,a.kt)("p",null,"Miscellaneous. You will be responsible for paying, withholding, filing, and reporting all taxes, duties, and other governmental assessments associated with your activity in connection with the Services, provided that roadmap.sh may, in its sole discretion, do any of the foregoing on your behalf or for itself as it sees fit. The failure of either you or us to exercise, in any way, any right herein shall not be deemed a waiver of any further rights hereunder. If any provision of these Terms is found to be unenforceable or invalid, that provision will be limited or eliminated, to the minimum extent necessary, so that these Terms shall otherwise remain in full force and effect and enforceable. You and roadmap.sh agree that these Terms are the complete and exclusive statement of the mutual understanding between you and roadmap.sh, and that it supersedes and cancels all previous written and oral agreements, communications and other understandings relating to the subject matter of these Terms. You hereby acknowledge and agree that you are not an employee, agent, partner, or joint venture of roadmap.sh, and you do not have any authority of any kind to bind roadmap.sh in any respect whatsoever. Except as expressly set forth in the section above regarding the Apple Application, you and roadmap.sh agree there are no third party beneficiaries intended under these Terms."))}i.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/_next/static/chunks/70-0e8008ae0f695c42.js b/_next/static/chunks/70-0e8008ae0f695c42.js new file mode 100644 index 000000000..638b3c991 --- /dev/null +++ b/_next/static/chunks/70-0e8008ae0f695c42.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[70],{5292:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/yaQ5YMWkxq4",title:"Acid Explained with Examples"}))}i.isMDXComponent=!0},1568:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/HiBDZgTNpXY",title:"All about HTTP Caching"}))}i.isMDXComponent=!0},8259:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/n3NKGsM3iEw",title:"Arrays and Objects in JavaScript"}))}i.isMDXComponent=!0},7210:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/VyIK6SV5f7o",title:"Asynchronous JavaScript"}))}i.isMDXComponent=!0},3501:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/Z0bH0cMY0E8",title:"Big O Notation \u2014 Calculating Time Complexity"}))}i.isMDXComponent=!0},1830:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/6DXEPcXKQNY",title:"Content Delivery Networks"}))}i.isMDXComponent=!0},9970:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/Wj0od2ag5sk",title:"DNS and how does it work?"}))}i.isMDXComponent=!0},4997:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/7lxgpKh_fRY",title:"DNS Records"}))}i.isMDXComponent=!0},8813:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/RIiq4tTt6rI",title:"Floating Point Arithmetic"}))}i.isMDXComponent=!0},6789:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/O3uT2l6vgZ8",title:"Freeze and Seal in JavaScript"}))}i.isMDXComponent=!0},9320:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/lgaxU7CRmxU",title:"How to use CSS Variables?"}))}i.isMDXComponent=!0},7624:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/nyKZTKQS_EQ",title:"Automate with GitHub Actions"}))}i.isMDXComponent=!0},6634:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/-ZI0ea5O2oA",title:"JavaScript Fetch API"}))}i.isMDXComponent=!0},4121:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/galcDRNd5Ow",title:"Load Balancers 101"}))}i.isMDXComponent=!0},8635:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/dV8mjZd1OtU",title:"OSI Model Explained"}))}i.isMDXComponent=!0},1051:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("p",null,"In this short series of lessons, we are going to create a react app from scratch. We are mainly going to use React and Chakra UI and see how we can build an application that fetches the trending projects from GitHub's API and shows you in the form of listing."),(0,r.kt)("p",null,"If you want to get an idea of what we are going to be building have a look at ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://kamranahmed.info/githunt"}),"GitHunt"),". Also the complete source code can be found at ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/kamranahmedse/githunt"}),"@kamranahmedse/githunt")),(0,r.kt)("h2",null,"Intro and Basic Setup"),(0,r.kt)("p",null,"The video below gives you the basic introduction about the project and explains what we are going to build."),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/NyG7YJWJd6s",title:"Practical Introduction to React Part 1"}),(0,r.kt)("h2",null,"Building the Interface"),(0,r.kt)("p",null,"In this second lesson we are going to create all the required components and the UI using Chakra UI and in the next lesson of this series we are going to start adding interactivity to our application."),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/zPqzKqjtEL4",title:"Practical Introduction to React Part 1"}),(0,r.kt)("h2",null,"Building the View Switcher"),(0,r.kt)("p",null,'In this lesson we start adding interactivity to the interface. We will be building the view switcher where you can switch between the "Grid View" and the "List View" and in the next and last lesson of the series, we are going to integrate GitHub API and show the repositories.'),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/EYzPJsJwjFg",title:"Practical Introduction to React Part 1"}),(0,r.kt)("h2",null,"Fetching Remote Data"),(0,r.kt)("p",null,"Below is the final lesson where we complete the application by integrating the GitHub API to make the data dynamic."),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/G2IbP9B_4PU",title:"Practical Introduction to React Part 1"}))}i.isMDXComponent=!0},5491:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/BvrkobaCVVE",title:"All about Promises in JavaScript"}))}i.isMDXComponent=!0},7730:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/nDv3yXdD0rk",title:"Random Number Generators"}))}i.isMDXComponent=!0},9351:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/a2rcgzludDU",title:"Scaling the Unscalable"}))}i.isMDXComponent=!0},6765:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/k3rFFLmQCuY",title:"SSH vs TLS vs SSL"}))}i.isMDXComponent=!0},4322:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/Y-Gl4HEyeUQ",title:"System Design 101"}))}i.isMDXComponent=!0},2142:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/F5rni9fr1yE",title:"TCP/IP Model Explained"}))}i.isMDXComponent=!0},2034:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/37AFBZv4_6Y",title:"Transport Protocols: TCP vs UDP"}))}i.isMDXComponent=!0},6672:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/_RbsFXWRZ10",title:"What is CAP Theorem?"}))}i.isMDXComponent=!0},1454:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/0yc2UANSDiw",title:"What is Dependency Injection?"}))}i.isMDXComponent=!0},6315:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/7Tok22qxPzQ",title:"DOM, Shadow DOM, Virtual DOM"}))}i.isMDXComponent=!0},104:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/rpqsSkTIdAw",title:"What is Eventual Consistency?"}))}i.isMDXComponent=!0},8734:function(t,e,n){n.r(e),n.d(e,{default:function(){return i}});n(7294);var r=n(4137);function o(t,e){if(null==t)return{};var n,r,o=function(t,e){if(null==t)return{};var n,r,o={},u=Object.keys(t);for(r=0;r=0||(o[n]=t[n]);return o}(t,e);if(Object.getOwnPropertySymbols){var u=Object.getOwnPropertySymbols(t);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(t,n)&&(o[n]=t[n])}return o}var u={};function i(t){var e=t.components,n=o(t,["components"]);return(0,r.kt)("wrapper",Object.assign({},u,n,{components:e,mdxType:"MDXLayout"}),(0,r.kt)("iframe",{src:"https://www.youtube.com/embed/ImHSpwUlNVc",title:"YAML in Depth"}))}i.isMDXComponent=!0}}]); \ No newline at end of file diff --git a/_next/static/chunks/709-4e9b8e1d6266b258.js b/_next/static/chunks/709-4e9b8e1d6266b258.js new file mode 100644 index 000000000..262aa16b0 --- /dev/null +++ b/_next/static/chunks/709-4e9b8e1d6266b258.js @@ -0,0 +1 @@ +(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[709],{6723:function(e,a,t){"use strict";t.d(a,{zx:function(){return k},hU:function(){return w}});var n=t(7375),l=t(2846),r=t(5031),c=t(8554),i=t.n(c),o=t(7294),s=t(6450),d=t(917),m=t(1358);function p(){return(p=Object.assign||function(e){for(var a=1;a=0||(l[t]=e[t]);return l}(n,u),g=(0,r.cx)("chakra-spinner",y),E=p({display:"inline-block",borderColor:"currentColor",borderStyle:"solid",borderRadius:"99999px",borderWidth:d,borderBottomColor:I,borderLeftColor:I,animation:h+" "+f+" linear infinite"},t);return o.createElement(l.m$.div,p({ref:a,__css:E,className:g},v),i&&o.createElement(m.TX,null,i))}));function f(e,a){if(null==e)return{};var t,n,l={},r=Object.keys(e);for(n=0;n=0||(l[t]=e[t]);return l}function C(){return(C=Object.assign||function(e){for(var a=1;a *:first-of-type:not(:last-of-type)":{borderEndRadius:0},"> *:not(:first-of-type):not(:last-of-type)":{borderRadius:0},"> *:not(:first-of-type):last-of-type":{borderStartRadius:0}}:{"& > *:not(style) ~ *:not(style)":{marginStart:d}}),o.createElement(v,{value:L},o.createElement(l.m$.div,C({ref:a,role:"group",__css:y,className:h},u)))}));r.Ts&&(E.displayName="ButtonGroup");var M=["label","placement","spacing","children","className","__css"],A=function(e){var a=e.label,t=e.placement;e.spacing;var n=e.children,c=void 0===n?o.createElement(L,{color:"currentColor",width:"1em",height:"1em"}):n,i=e.className,s=e.__css,d=f(e,M),m=(0,r.cx)("chakra-button__spinner",i),p="start"===t?"marginEnd":"marginStart",u=o.useMemo((function(){var e;return C(((e={display:"flex",alignItems:"center",position:a?"relative":"absolute"})[p]=a?"0.5rem":0,e.fontSize="1em",e.lineHeight="normal",e),s)}),[s,a,p]);return o.createElement(l.m$.div,C({className:m},d,{__css:u}),c)};r.Ts&&(A.displayName="ButtonSpinner");var N=["children","className"],b=function(e){var a=e.children,t=e.className,n=f(e,N),c=o.isValidElement(a)?o.cloneElement(a,{"aria-hidden":!0,focusable:!1}):a,i=(0,r.cx)("chakra-button__icon",t);return o.createElement(l.m$.span,C({display:"inline-flex",alignSelf:"center",flexShrink:0},n,{className:i}),c)};r.Ts&&(b.displayName="ButtonIcon");var Z=["isDisabled","isLoading","isActive","isFullWidth","children","leftIcon","rightIcon","loadingText","iconSpacing","type","spinner","spinnerPlacement","className","as"],k=(0,l.Gp)((function(e,a){var t=g(),c=(0,l.mq)("Button",C({},t,e)),s=(0,l.Lr)(e),d=s.isDisabled,m=void 0===d?null==t?void 0:t.isDisabled:d,p=s.isLoading,u=s.isActive,h=s.isFullWidth,L=s.children,I=s.leftIcon,y=s.rightIcon,v=s.loadingText,E=s.iconSpacing,M=void 0===E?"0.5rem":E,N=s.type,b=s.spinner,k=s.spinnerPlacement,x=void 0===k?"start":k,w=s.className,S=s.as,V=f(s,Z),z=o.useMemo((function(){var e,a=i()({},null!=(e=null==c?void 0:c._focus)?e:{},{zIndex:1});return C({display:"inline-flex",appearance:"none",alignItems:"center",justifyContent:"center",userSelect:"none",position:"relative",whiteSpace:"nowrap",verticalAlign:"middle",outline:"none",width:h?"100%":"auto"},c,!!t&&{_focus:a})}),[c,t,h]),_=function(e){var a=o.useState(!e),t=a[0],n=a[1];return{ref:o.useCallback((function(e){e&&n("BUTTON"===e.tagName)}),[]),type:t?"button":void 0}}(S),H=_.ref,O=_.type,B={rightIcon:y,leftIcon:I,iconSpacing:M,children:L};return o.createElement(l.m$.button,C({disabled:m||p,ref:(0,n.qq)(a,H),as:S,type:null!=N?N:O,"data-active":(0,r.PB)(u),"data-loading":(0,r.PB)(p),__css:z,className:(0,r.cx)("chakra-button",w)},V),p&&"start"===x&&o.createElement(A,{className:"chakra-button__spinner--start",label:v,placement:"start"},b),p?v||o.createElement(l.m$.span,{opacity:0},o.createElement(U,B)):o.createElement(U,B),p&&"end"===x&&o.createElement(A,{className:"chakra-button__spinner--end",label:v,placement:"end"},b))}));function U(e){var a=e.leftIcon,t=e.rightIcon,n=e.children,l=e.iconSpacing;return o.createElement(o.Fragment,null,a&&o.createElement(b,{marginEnd:l},a),n,t&&o.createElement(b,{marginStart:l},t))}r.Ts&&(k.displayName="Button");var x=["icon","children","isRound","aria-label"],w=(0,l.Gp)((function(e,a){var t=e.icon,n=e.children,l=e.isRound,r=e["aria-label"],c=f(e,x),i=t||n,s=o.isValidElement(i)?o.cloneElement(i,{"aria-hidden":!0,focusable:!1}):null;return o.createElement(k,C({padding:"0",borderRadius:l?"full":void 0,ref:a,"aria-label":r},c),s)}));r.Ts&&(w.displayName="IconButton")},4746:function(e,a,t){"use strict";t.d(a,{P:function(){return d}});var n=t(894),l=t(2846),r=t(5031),c=t(7294);function i(){return(i=Object.assign||function(e){for(var a=1;a=0||(l[t]=e[t]);return l}(n,o);return c.createElement(l.m$.button,i({type:"button","aria-label":"Close",ref:a,disabled:d,__css:i({},{outline:0,display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0},t,m)},p),r||c.createElement(s,{width:"1em",height:"1em"}))}));r.Ts&&(d.displayName="CloseButton")},9876:function(e,a,t){"use strict";t.d(a,{Rp:function(){return o},Km:function(){return s},rE:function(){return r},_8:function(){return i},Uq:function(){return m},sz:function(){return d},mB:function(){return c}});var n=t(894),l=t(7294),r=((0,n.IU)({d:"M16 1H4c-1.1 0-2 .9-2 2v14h2V3h12V1zm3 4H8c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h11c1.1 0 2-.9 2-2V7c0-1.1-.9-2-2-2zm0 16H8V7h11v14z",displayName:"CopyIcon"}),(0,n.IU)({d:"M23.384,21.619,16.855,15.09a9.284,9.284,0,1,0-1.768,1.768l6.529,6.529a1.266,1.266,0,0,0,1.768,0A1.251,1.251,0,0,0,23.384,21.619ZM2.75,9.5a6.75,6.75,0,1,1,6.75,6.75A6.758,6.758,0,0,1,2.75,9.5Z",displayName:"SearchIcon"}),(0,n.IU)({d:"M23.414,20.591l-4.645-4.645a10.256,10.256,0,1,0-2.828,2.829l4.645,4.644a2.025,2.025,0,0,0,2.828,0A2,2,0,0,0,23.414,20.591ZM10.25,3.005A7.25,7.25,0,1,1,3,10.255,7.258,7.258,0,0,1,10.25,3.005Z",displayName:"Search2Icon"}),(0,n.IU)({d:"M21.4,13.7C20.6,13.9,19.8,14,19,14c-5,0-9-4-9-9c0-0.8,0.1-1.6,0.3-2.4c0.1-0.3,0-0.7-0.3-1 c-0.3-0.3-0.6-0.4-1-0.3C4.3,2.7,1,7.1,1,12c0,6.1,4.9,11,11,11c4.9,0,9.3-3.3,10.6-8.1c0.1-0.3,0-0.7-0.3-1 C22.1,13.7,21.7,13.6,21.4,13.7z",displayName:"MoonIcon"}),(0,n.IU)({displayName:"SunIcon",path:l.createElement("g",{strokeLinejoin:"round",strokeLinecap:"round",strokeWidth:"2",fill:"none",stroke:"currentColor"},l.createElement("circle",{cx:"12",cy:"12",r:"5"}),l.createElement("path",{d:"M12 1v2"}),l.createElement("path",{d:"M12 21v2"}),l.createElement("path",{d:"M4.22 4.22l1.42 1.42"}),l.createElement("path",{d:"M18.36 18.36l1.42 1.42"}),l.createElement("path",{d:"M1 12h2"}),l.createElement("path",{d:"M21 12h2"}),l.createElement("path",{d:"M4.22 19.78l1.42-1.42"}),l.createElement("path",{d:"M18.36 5.64l1.42-1.42"}))}),(0,n.IU)({d:"M0,12a1.5,1.5,0,0,0,1.5,1.5h8.75a.25.25,0,0,1,.25.25V22.5a1.5,1.5,0,0,0,3,0V13.75a.25.25,0,0,1,.25-.25H22.5a1.5,1.5,0,0,0,0-3H13.75a.25.25,0,0,1-.25-.25V1.5a1.5,1.5,0,0,0-3,0v8.75a.25.25,0,0,1-.25.25H1.5A1.5,1.5,0,0,0,0,12Z",displayName:"AddIcon"}),(0,n.IU)({displayName:"SmallAddIcon",viewBox:"0 0 20 20",path:l.createElement("path",{fill:"currentColor",d:"M14 9h-3V6c0-.55-.45-1-1-1s-1 .45-1 1v3H6c-.55 0-1 .45-1 1s.45 1 1 1h3v3c0 .55.45 1 1 1s1-.45 1-1v-3h3c.55 0 1-.45 1-1s-.45-1-1-1z",fillRule:"evenodd"})}),(0,n.IU)({viewBox:"0 0 14 14",d:"M14,7.77 L14,6.17 L12.06,5.53 L11.61,4.44 L12.49,2.6 L11.36,1.47 L9.55,2.38 L8.46,1.93 L7.77,0.01 L6.17,0.01 L5.54,1.95 L4.43,2.4 L2.59,1.52 L1.46,2.65 L2.37,4.46 L1.92,5.55 L0,6.23 L0,7.82 L1.94,8.46 L2.39,9.55 L1.51,11.39 L2.64,12.52 L4.45,11.61 L5.54,12.06 L6.23,13.98 L7.82,13.98 L8.45,12.04 L9.56,11.59 L11.4,12.47 L12.53,11.34 L11.61,9.53 L12.08,8.44 L14,7.75 L14,7.77 Z M7,10 C5.34,10 4,8.66 4,7 C4,5.34 5.34,4 7,4 C8.66,4 10,5.34 10,7 C10,8.66 8.66,10 7,10 Z",displayName:"SettingsIcon"}),(0,n.IU)({displayName:"CheckCircleIcon",d:"M12,0A12,12,0,1,0,24,12,12.014,12.014,0,0,0,12,0Zm6.927,8.2-6.845,9.289a1.011,1.011,0,0,1-1.43.188L5.764,13.769a1,1,0,1,1,1.25-1.562l4.076,3.261,6.227-8.451A1,1,0,1,1,18.927,8.2Z"})),c=(0,n.IU)({d:"M19.5,9.5h-.75V6.75a6.75,6.75,0,0,0-13.5,0V9.5H4.5a2,2,0,0,0-2,2V22a2,2,0,0,0,2,2h15a2,2,0,0,0,2-2V11.5A2,2,0,0,0,19.5,9.5Zm-9.5,6a2,2,0,1,1,3,1.723V19.5a1,1,0,0,1-2,0V17.223A1.994,1.994,0,0,1,10,15.5ZM7.75,6.75a4.25,4.25,0,0,1,8.5,0V9a.5.5,0,0,1-.5.5H8.25a.5.5,0,0,1-.5-.5Z",displayName:"LockIcon"}),i=((0,n.IU)({d:"M19.5,9.5h-.75V6.75A6.751,6.751,0,0,0,5.533,4.811a1.25,1.25,0,1,0,2.395.717A4.251,4.251,0,0,1,16.25,6.75V9a.5.5,0,0,1-.5.5H4.5a2,2,0,0,0-2,2V22a2,2,0,0,0,2,2h15a2,2,0,0,0,2-2V11.5A2,2,0,0,0,19.5,9.5Zm-9.5,6a2,2,0,1,1,3,1.723V19.5a1,1,0,0,1-2,0V17.223A1.994,1.994,0,0,1,10,15.5Z",displayName:"UnlockIcon"}),(0,n.IU)({displayName:"ViewIcon",path:l.createElement("g",{fill:"currentColor"},l.createElement("path",{d:"M23.432,10.524C20.787,7.614,16.4,4.538,12,4.6,7.6,4.537,3.213,7.615.568,10.524a2.211,2.211,0,0,0,0,2.948C3.182,16.351,7.507,19.4,11.839,19.4h.308c4.347,0,8.671-3.049,11.288-5.929A2.21,2.21,0,0,0,23.432,10.524ZM7.4,12A4.6,4.6,0,1,1,12,16.6,4.6,4.6,0,0,1,7.4,12Z"}),l.createElement("circle",{cx:"12",cy:"12",r:"2"}))}),(0,n.IU)({displayName:"ViewOffIcon",path:l.createElement("g",{fill:"currentColor"},l.createElement("path",{d:"M23.2,10.549a20.954,20.954,0,0,0-4.3-3.6l4-3.995a1,1,0,1,0-1.414-1.414l-.018.018a.737.737,0,0,1-.173.291l-19.5,19.5c-.008.007-.018.009-.026.017a1,1,0,0,0,1.631,1.088l4.146-4.146a11.26,11.26,0,0,0,4.31.939h.3c4.256,0,8.489-2.984,11.051-5.8A2.171,2.171,0,0,0,23.2,10.549ZM16.313,13.27a4.581,4.581,0,0,1-3,3.028,4.3,4.3,0,0,1-3.1-.19.253.253,0,0,1-.068-.407l5.56-5.559a.252.252,0,0,1,.407.067A4.3,4.3,0,0,1,16.313,13.27Z"}),l.createElement("path",{d:"M7.615,13.4a.244.244,0,0,0,.061-.24A4.315,4.315,0,0,1,7.5,12,4.5,4.5,0,0,1,12,7.5a4.276,4.276,0,0,1,1.16.173.244.244,0,0,0,.24-.062l1.941-1.942a.254.254,0,0,0-.1-.421A10.413,10.413,0,0,0,12,4.75C7.7,4.692,3.4,7.7.813,10.549a2.15,2.15,0,0,0-.007,2.9,21.209,21.209,0,0,0,3.438,3.03.256.256,0,0,0,.326-.029Z"}))}),(0,n.IU)({d:"M11.2857,6.05714 L10.08571,4.85714 L7.85714,7.14786 L7.85714,1 L6.14286,1 L6.14286,7.14786 L3.91429,4.85714 L2.71429,6.05714 L7,10.42857 L11.2857,6.05714 Z M1,11.2857 L1,13 L13,13 L13,11.2857 L1,11.2857 Z",displayName:"DownloadIcon",viewBox:"0 0 14 14"})),o=((0,n.IU)({displayName:"DeleteIcon",path:l.createElement("g",{fill:"currentColor"},l.createElement("path",{d:"M19.452 7.5H4.547a.5.5 0 00-.5.545l1.287 14.136A2 2 0 007.326 24h9.347a2 2 0 001.992-1.819L19.95 8.045a.5.5 0 00-.129-.382.5.5 0 00-.369-.163zm-9.2 13a.75.75 0 01-1.5 0v-9a.75.75 0 011.5 0zm5 0a.75.75 0 01-1.5 0v-9a.75.75 0 011.5 0zM22 4h-4.75a.25.25 0 01-.25-.25V2.5A2.5 2.5 0 0014.5 0h-5A2.5 2.5 0 007 2.5v1.25a.25.25 0 01-.25.25H2a1 1 0 000 2h20a1 1 0 000-2zM9 3.75V2.5a.5.5 0 01.5-.5h5a.5.5 0 01.5.5v1.25a.25.25 0 01-.25.25h-5.5A.25.25 0 019 3.75z"}))}),(0,n.IU)({displayName:"RepeatIcon",path:l.createElement("g",{fill:"currentColor"},l.createElement("path",{d:"M10.319,4.936a7.239,7.239,0,0,1,7.1,2.252,1.25,1.25,0,1,0,1.872-1.657A9.737,9.737,0,0,0,9.743,2.5,10.269,10.269,0,0,0,2.378,9.61a.249.249,0,0,1-.271.178l-1.033-.13A.491.491,0,0,0,.6,9.877a.5.5,0,0,0-.019.526l2.476,4.342a.5.5,0,0,0,.373.248.43.43,0,0,0,.062,0,.5.5,0,0,0,.359-.152l3.477-3.593a.5.5,0,0,0-.3-.844L5.15,10.172a.25.25,0,0,1-.2-.333A7.7,7.7,0,0,1,10.319,4.936Z"}),l.createElement("path",{d:"M23.406,14.1a.5.5,0,0,0,.015-.526l-2.5-4.329A.5.5,0,0,0,20.546,9a.489.489,0,0,0-.421.151l-3.456,3.614a.5.5,0,0,0,.3.842l1.848.221a.249.249,0,0,1,.183.117.253.253,0,0,1,.023.216,7.688,7.688,0,0,1-5.369,4.9,7.243,7.243,0,0,1-7.1-2.253,1.25,1.25,0,1,0-1.872,1.656,9.74,9.74,0,0,0,9.549,3.03,10.261,10.261,0,0,0,7.369-7.12.251.251,0,0,1,.27-.179l1.058.127a.422.422,0,0,0,.06,0A.5.5,0,0,0,23.406,14.1Z"}))}),(0,n.IU)({displayName:"RepeatClockIcon",path:l.createElement("g",{fill:"currentColor"},l.createElement("path",{d:"M12.965,6a1,1,0,0,0-1,1v5.5a1,1,0,0,0,1,1h5a1,1,0,0,0,0-2h-3.75a.25.25,0,0,1-.25-.25V7A1,1,0,0,0,12.965,6Z"}),l.createElement("path",{d:"M12.567,1.258A10.822,10.822,0,0,0,2.818,8.4a.25.25,0,0,1-.271.163L.858,8.309a.514.514,0,0,0-.485.213.5.5,0,0,0-.021.53l2.679,4.7a.5.5,0,0,0,.786.107l3.77-3.746a.5.5,0,0,0-.279-.85L5.593,9.007a.25.25,0,0,1-.192-.35,8.259,8.259,0,1,1,7.866,11.59,1.25,1.25,0,0,0,.045,2.5h.047a10.751,10.751,0,1,0-.792-21.487Z"}))}),(0,n.IU)({displayName:"EditIcon",path:l.createElement("g",{fill:"none",stroke:"currentColor",strokeLinecap:"round",strokeWidth:"2"},l.createElement("path",{d:"M11 4H4a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2v-7"}),l.createElement("path",{d:"M18.5 2.5a2.121 2.121 0 0 1 3 3L12 15l-4 1 1-4 9.5-9.5z"}))}),(0,n.IU)({d:"M15.41 7.41L14 6l-6 6 6 6 1.41-1.41L10.83 12z",displayName:"ChevronLeftIcon"}),(0,n.IU)({d:"M10 6L8.59 7.41 13.17 12l-4.58 4.59L10 18l6-6z",displayName:"ChevronRightIcon"}),(0,n.IU)({displayName:"ChevronDownIcon",d:"M16.59 8.59L12 13.17 7.41 8.59 6 10l6 6 6-6z"}),(0,n.IU)({d:"M12 8l-6 6 1.41 1.41L12 10.83l4.59 4.58L18 14z",displayName:"ChevronUpIcon"}),(0,n.IU)({d:"M20 11H7.83l5.59-5.59L12 4l-8 8 8 8 1.41-1.41L7.83 13H20v-2z",displayName:"ArrowBackIcon"})),s=((0,n.IU)({d:"M12 4l-1.41 1.41L16.17 11H4v2h12.17l-5.58 5.59L12 20l8-8z",displayName:"ArrowForwardIcon"}),(0,n.IU)({d:"M4 12l1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z",displayName:"ArrowUpIcon"}),(0,n.IU)({viewBox:"0 0 16 16",d:"M11.891 9.992a1 1 0 1 1 1.416 1.415l-4.3 4.3a1 1 0 0 1-1.414 0l-4.3-4.3A1 1 0 0 1 4.71 9.992l3.59 3.591 3.591-3.591zm0-3.984L8.3 2.417 4.709 6.008a1 1 0 0 1-1.416-1.415l4.3-4.3a1 1 0 0 1 1.414 0l4.3 4.3a1 1 0 1 1-1.416 1.415z",displayName:"ArrowUpDownIcon"}),(0,n.IU)({d:"M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z",displayName:"ArrowDownIcon"}),(0,n.IU)({displayName:"ExternalLinkIcon",path:l.createElement("g",{fill:"none",stroke:"currentColor",strokeLinecap:"round",strokeWidth:"2"},l.createElement("path",{d:"M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6"}),l.createElement("path",{d:"M15 3h6v6"}),l.createElement("path",{d:"M10 14L21 3"}))}),(0,n.IU)({displayName:"LinkIcon",path:l.createElement("g",{fill:"currentColor"},l.createElement("path",{d:"M10.458,18.374,7.721,21.11a2.853,2.853,0,0,1-3.942,0l-.892-.891a2.787,2.787,0,0,1,0-3.941l5.8-5.8a2.789,2.789,0,0,1,3.942,0l.893.892A1,1,0,0,0,14.94,9.952l-.893-.892a4.791,4.791,0,0,0-6.771,0l-5.8,5.8a4.787,4.787,0,0,0,0,6.77l.892.891a4.785,4.785,0,0,0,6.771,0l2.736-2.735a1,1,0,1,0-1.414-1.415Z"}),l.createElement("path",{d:"M22.526,2.363l-.892-.892a4.8,4.8,0,0,0-6.77,0l-2.905,2.9a1,1,0,0,0,1.414,1.414l2.9-2.9a2.79,2.79,0,0,1,3.941,0l.893.893a2.786,2.786,0,0,1,0,3.942l-5.8,5.8a2.769,2.769,0,0,1-1.971.817h0a2.766,2.766,0,0,1-1.969-.816,1,1,0,1,0-1.415,1.412,4.751,4.751,0,0,0,3.384,1.4h0a4.752,4.752,0,0,0,3.385-1.4l5.8-5.8a4.786,4.786,0,0,0,0-6.771Z"}))}),(0,n.IU)({displayName:"PlusSquareIcon",path:l.createElement("g",{fill:"none",stroke:"currentColor",strokeLinecap:"round",strokeWidth:"2"},l.createElement("rect",{height:"18",width:"18",rx:"2",ry:"2",x:"3",y:"3"}),l.createElement("path",{d:"M12 8v8"}),l.createElement("path",{d:"M8 12h8"}))}),(0,n.IU)({displayName:"CalendarIcon",viewBox:"0 0 14 14",d:"M10.8889,5.5 L3.11111,5.5 L3.11111,7.05556 L10.8889,7.05556 L10.8889,5.5 Z M12.4444,1.05556 L11.6667,1.05556 L11.6667,0 L10.1111,0 L10.1111,1.05556 L3.88889,1.05556 L3.88889,0 L2.33333,0 L2.33333,1.05556 L1.55556,1.05556 C0.692222,1.05556 0.00777777,1.75556 0.00777777,2.61111 L0,12.5 C0,13.3556 0.692222,14 1.55556,14 L12.4444,14 C13.3,14 14,13.3556 14,12.5 L14,2.61111 C14,1.75556 13.3,1.05556 12.4444,1.05556 Z M12.4444,12.5 L1.55556,12.5 L1.55556,3.94444 L12.4444,3.94444 L12.4444,12.5 Z M8.55556,8.61111 L3.11111,8.61111 L3.11111,10.1667 L8.55556,10.1667 L8.55556,8.61111 Z"}),(0,n.IU)({d:"M0.913134,0.920639 C1.49851,0.331726 2.29348,0 3.12342,0 L10.8766,0 C11.7065,0 12.5015,0.331725 13.0869,0.920639 C13.6721,1.50939 14,2.30689 14,3.13746 L14,8.12943 C13.9962,8.51443 13.9059,8.97125 13.7629,9.32852 C13.6128,9.683 13.3552,10.0709 13.0869,10.3462 C12.813,10.6163 12.4265,10.8761 12.0734,11.0274 C11.7172,11.1716 11.2607,11.263 10.8766,11.2669 L10.1234,11.2669 L10.1234,12.5676 L10.1209,12.5676 C10.1204,12.793 10.0633,13.0791 9.97807,13.262 C9.8627,13.466 9.61158,13.7198 9.40818,13.8382 L9.40824,13.8383 C9.4077,13.8386 9.40716,13.8388 9.40661,13.8391 C9.40621,13.8393 9.4058,13.8396 9.40539,13.8398 L9.40535,13.8397 C9.22958,13.9254 8.94505,13.9951 8.75059,14 L8.74789,14 C8.35724,13.9963 7.98473,13.8383 7.71035,13.5617 L5.39553,11.2669 L3.12342,11.2669 C2.29348,11.2669 1.49851,10.9352 0.913134,10.3462 C0.644826,10.0709 0.387187,9.683 0.23711,9.32852 C0.0941235,8.97125 0.00379528,8.51443 0,8.12943 L0,3.13746 C0,2.30689 0.327915,1.50939 0.913134,0.920639 Z M3.12342,1.59494 C2.71959,1.59494 2.33133,1.75628 2.04431,2.04503 C1.75713,2.33395 1.59494,2.72681 1.59494,3.13746 L1.59494,8.12943 C1.59114,8.35901 1.62114,8.51076 1.71193,8.72129 C1.79563,8.9346 1.88065,9.06264 2.04431,9.22185 C2.33133,9.5106 2.71959,9.67195 3.12342,9.67195 L5.72383,9.67195 C5.93413,9.67195 6.13592,9.75502 6.28527,9.90308 L8.52848,12.1269 L8.52848,10.4694 C8.52848,10.029 8.88552,9.67195 9.32595,9.67195 L10.8766,9.67195 C11.1034,9.67583 11.2517,9.64614 11.4599,9.55518 C11.6712,9.47132 11.7976,9.38635 11.9557,9.22185 C12.1193,9.06264 12.2044,8.9346 12.2881,8.72129 C12.3789,8.51076 12.4089,8.35901 12.4051,8.12943 L12.4051,3.13746 C12.4051,2.72681 12.2429,2.33394 11.9557,2.04503 C11.6687,1.75628 11.2804,1.59494 10.8766,1.59494 L3.12342,1.59494 Z",displayName:"ChatIcon",viewBox:"0 0 14 14"}),(0,n.IU)({displayName:"TimeIcon",path:l.createElement("g",{fill:"currentColor"},l.createElement("path",{d:"M12,0A12,12,0,1,0,24,12,12.014,12.014,0,0,0,12,0Zm0,22A10,10,0,1,1,22,12,10.011,10.011,0,0,1,12,22Z"}),l.createElement("path",{d:"M17.134,15.81,12.5,11.561V6.5a1,1,0,0,0-2,0V12a1,1,0,0,0,.324.738l4.959,4.545a1.01,1.01,0,0,0,1.413-.061A1,1,0,0,0,17.134,15.81Z"}))}),(0,n.IU)({displayName:"ArrowRightIcon",path:l.createElement("g",{fill:"currentColor"},l.createElement("path",{d:"M13.584,12a2.643,2.643,0,0,1-.775,1.875L3.268,23.416a1.768,1.768,0,0,1-2.5-2.5l8.739-8.739a.25.25,0,0,0,0-.354L.768,3.084a1.768,1.768,0,0,1,2.5-2.5l9.541,9.541A2.643,2.643,0,0,1,13.584,12Z"}),l.createElement("path",{d:"M23.75,12a2.643,2.643,0,0,1-.775,1.875l-9.541,9.541a1.768,1.768,0,0,1-2.5-2.5l8.739-8.739a.25.25,0,0,0,0-.354L10.934,3.084a1.768,1.768,0,0,1,2.5-2.5l9.541,9.541A2.643,2.643,0,0,1,23.75,12Z"}))}),(0,n.IU)({displayName:"ArrowLeftIcon",path:l.createElement("g",{fill:"currentColor"},l.createElement("path",{d:"M10.416,12a2.643,2.643,0,0,1,.775-1.875L20.732.584a1.768,1.768,0,0,1,2.5,2.5l-8.739,8.739a.25.25,0,0,0,0,.354l8.739,8.739a1.768,1.768,0,0,1-2.5,2.5l-9.541-9.541A2.643,2.643,0,0,1,10.416,12Z"}),l.createElement("path",{d:"M.25,12a2.643,2.643,0,0,1,.775-1.875L10.566.584a1.768,1.768,0,0,1,2.5,2.5L4.327,11.823a.25.25,0,0,0,0,.354l8.739,8.739a1.768,1.768,0,0,1-2.5,2.5L1.025,13.875A2.643,2.643,0,0,1,.25,12Z"}))}),(0,n.IU)({displayName:"AtSignIcon",d:"M12,.5A11.634,11.634,0,0,0,.262,12,11.634,11.634,0,0,0,12,23.5a11.836,11.836,0,0,0,6.624-2,1.25,1.25,0,1,0-1.393-2.076A9.34,9.34,0,0,1,12,21a9.132,9.132,0,0,1-9.238-9A9.132,9.132,0,0,1,12,3a9.132,9.132,0,0,1,9.238,9v.891a1.943,1.943,0,0,1-3.884,0V12A5.355,5.355,0,1,0,12,17.261a5.376,5.376,0,0,0,3.861-1.634,4.438,4.438,0,0,0,7.877-2.736V12A11.634,11.634,0,0,0,12,.5Zm0,14.261A2.763,2.763,0,1,1,14.854,12,2.812,2.812,0,0,1,12,14.761Z"})),d=((0,n.IU)({displayName:"AttachmentIcon",d:"M21.843,3.455a6.961,6.961,0,0,0-9.846,0L1.619,13.832a5.128,5.128,0,0,0,7.252,7.252L17.3,12.653A3.293,3.293,0,1,0,12.646,8L7.457,13.184A1,1,0,1,0,8.871,14.6L14.06,9.409a1.294,1.294,0,0,1,1.829,1.83L7.457,19.67a3.128,3.128,0,0,1-4.424-4.424L13.411,4.869a4.962,4.962,0,1,1,7.018,7.018L12.646,19.67a1,1,0,1,0,1.414,1.414L21.843,13.3a6.96,6.96,0,0,0,0-9.846Z"}),(0,n.IU)({displayName:"UpDownIcon",viewBox:"-1 -1 9 11",d:"M 3.5 0L 3.98809 -0.569442L 3.5 -0.987808L 3.01191 -0.569442L 3.5 0ZM 3.5 9L 3.01191 9.56944L 3.5 9.98781L 3.98809 9.56944L 3.5 9ZM 0.488094 3.56944L 3.98809 0.569442L 3.01191 -0.569442L -0.488094 2.43056L 0.488094 3.56944ZM 3.01191 0.569442L 6.51191 3.56944L 7.48809 2.43056L 3.98809 -0.569442L 3.01191 0.569442ZM -0.488094 6.56944L 3.01191 9.56944L 3.98809 8.43056L 0.488094 5.43056L -0.488094 6.56944ZM 3.98809 9.56944L 7.48809 6.56944L 6.51191 5.43056L 3.01191 8.43056L 3.98809 9.56944Z"}),(0,n.IU)({d:"M23.555,8.729a1.505,1.505,0,0,0-1.406-.98H16.062a.5.5,0,0,1-.472-.334L13.405,1.222a1.5,1.5,0,0,0-2.81,0l-.005.016L8.41,7.415a.5.5,0,0,1-.471.334H1.85A1.5,1.5,0,0,0,.887,10.4l5.184,4.3a.5.5,0,0,1,.155.543L4.048,21.774a1.5,1.5,0,0,0,2.31,1.684l5.346-3.92a.5.5,0,0,1,.591,0l5.344,3.919a1.5,1.5,0,0,0,2.312-1.683l-2.178-6.535a.5.5,0,0,1,.155-.543l5.194-4.306A1.5,1.5,0,0,0,23.555,8.729Z",displayName:"StarIcon"}),(0,n.IU)({displayName:"EmailIcon",path:l.createElement("g",{fill:"currentColor"},l.createElement("path",{d:"M11.114,14.556a1.252,1.252,0,0,0,1.768,0L22.568,4.87a.5.5,0,0,0-.281-.849A1.966,1.966,0,0,0,22,4H2a1.966,1.966,0,0,0-.289.021.5.5,0,0,0-.281.849Z"}),l.createElement("path",{d:"M23.888,5.832a.182.182,0,0,0-.2.039l-6.2,6.2a.251.251,0,0,0,0,.354l5.043,5.043a.75.75,0,1,1-1.06,1.061l-5.043-5.043a.25.25,0,0,0-.354,0l-2.129,2.129a2.75,2.75,0,0,1-3.888,0L7.926,13.488a.251.251,0,0,0-.354,0L2.529,18.531a.75.75,0,0,1-1.06-1.061l5.043-5.043a.251.251,0,0,0,0-.354l-6.2-6.2a.18.18,0,0,0-.2-.039A.182.182,0,0,0,0,6V18a2,2,0,0,0,2,2H22a2,2,0,0,0,2-2V6A.181.181,0,0,0,23.888,5.832Z"}))}),(0,n.IU)({d:"M2.20731,0.0127209 C2.1105,-0.0066419 1.99432,-0.00664663 1.91687,0.032079 C0.871279,0.438698 0.212942,1.92964 0.0580392,2.95587 C-0.426031,6.28627 2.20731,9.17133 4.62766,11.0689 C6.77694,12.7534 10.9012,15.5223 13.3409,12.8503 C13.6507,12.5211 14.0186,12.037 13.9993,11.553 C13.9412,10.7397 13.186,10.1588 12.6051,9.71349 C12.1598,9.38432 11.2304,8.47427 10.6495,8.49363 C10.1267,8.51299 9.79754,9.05515 9.46837,9.38432 L8.88748,9.96521 C8.79067,10.062 7.55145,9.24878 7.41591,9.15197 C6.91248,8.8228 6.4284,8.45491 6.00242,8.04829 C5.57644,7.64167 5.18919,7.19632 4.86002,6.73161 C4.7632,6.59607 3.96933,5.41495 4.04678,5.31813 C4.04678,5.31813 4.72448,4.58234 4.91811,4.2919 C5.32473,3.67229 5.63453,3.18822 5.16982,2.45243 C4.99556,2.18135 4.78257,1.96836 4.55021,1.73601 C4.14359,1.34875 3.73698,0.942131 3.27227,0.612963 C3.02055,0.419335 2.59457,0.0708094 2.20731,0.0127209 Z",displayName:"PhoneIcon",viewBox:"0 0 14 14"}),(0,n.IU)({viewBox:"0 0 10 10",d:"M3,2 C2.44771525,2 2,1.55228475 2,1 C2,0.44771525 2.44771525,0 3,0 C3.55228475,0 4,0.44771525 4,1 C4,1.55228475 3.55228475,2 3,2 Z M3,6 C2.44771525,6 2,5.55228475 2,5 C2,4.44771525 2.44771525,4 3,4 C3.55228475,4 4,4.44771525 4,5 C4,5.55228475 3.55228475,6 3,6 Z M3,10 C2.44771525,10 2,9.55228475 2,9 C2,8.44771525 2.44771525,8 3,8 C3.55228475,8 4,8.44771525 4,9 C4,9.55228475 3.55228475,10 3,10 Z M7,2 C6.44771525,2 6,1.55228475 6,1 C6,0.44771525 6.44771525,0 7,0 C7.55228475,0 8,0.44771525 8,1 C8,1.55228475 7.55228475,2 7,2 Z M7,6 C6.44771525,6 6,5.55228475 6,5 C6,4.44771525 6.44771525,4 7,4 C7.55228475,4 8,4.44771525 8,5 C8,5.55228475 7.55228475,6 7,6 Z M7,10 C6.44771525,10 6,9.55228475 6,9 C6,8.44771525 6.44771525,8 7,8 C7.55228475,8 8,8.44771525 8,9 C8,9.55228475 7.55228475,10 7,10 Z",displayName:"DragHandleIcon"}),(0,n.IU)({displayName:"SpinnerIcon",path:l.createElement(l.Fragment,null,l.createElement("defs",null,l.createElement("linearGradient",{x1:"28.154%",y1:"63.74%",x2:"74.629%",y2:"17.783%",id:"a"},l.createElement("stop",{stopColor:"currentColor",offset:"0%"}),l.createElement("stop",{stopColor:"#fff",stopOpacity:"0",offset:"100%"}))),l.createElement("g",{transform:"translate(2)",fill:"none"},l.createElement("circle",{stroke:"url(#a)",strokeWidth:"4",cx:"10",cy:"12",r:"10"}),l.createElement("path",{d:"M10 2C4.477 2 0 6.477 0 12",stroke:"currentColor",strokeWidth:"4"}),l.createElement("rect",{fill:"currentColor",x:"8",width:"4",height:"4",rx:"8"})))}),(0,n.IU)({displayName:"CloseIcon",d:"M.439,21.44a1.5,1.5,0,0,0,2.122,2.121L11.823,14.3a.25.25,0,0,1,.354,0l9.262,9.263a1.5,1.5,0,1,0,2.122-2.121L14.3,12.177a.25.25,0,0,1,0-.354l9.263-9.262A1.5,1.5,0,0,0,21.439.44L12.177,9.7a.25.25,0,0,1-.354,0L2.561.44A1.5,1.5,0,0,0,.439,2.561L9.7,11.823a.25.25,0,0,1,0,.354Z"}),(0,n.IU)({displayName:"SmallCloseIcon",viewBox:"0 0 16 16",path:l.createElement("path",{d:"M9.41 8l2.29-2.29c.19-.18.3-.43.3-.71a1.003 1.003 0 0 0-1.71-.71L8 6.59l-2.29-2.3a1.003 1.003 0 0 0-1.42 1.42L6.59 8 4.3 10.29c-.19.18-.3.43-.3.71a1.003 1.003 0 0 0 1.71.71L8 9.41l2.29 2.29c.18.19.43.3.71.3a1.003 1.003 0 0 0 .71-1.71L9.41 8z",fillRule:"evenodd",fill:"currentColor"})}),(0,n.IU)({d:"M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm0 18c-4.42 0-8-3.58-8-8 0-1.85.63-3.55 1.69-4.9L16.9 18.31C15.55 19.37 13.85 20 12 20zm6.31-3.1L7.1 5.69C8.45 4.63 10.15 4 12 4c4.42 0 8 3.58 8 8 0 1.85-.63 3.55-1.69 4.9z",displayName:"NotAllowedIcon"}),(0,n.IU)({d:"M21,5H3C2.621,5,2.275,5.214,2.105,5.553C1.937,5.892,1.973,6.297,2.2,6.6l9,12 c0.188,0.252,0.485,0.4,0.8,0.4s0.611-0.148,0.8-0.4l9-12c0.228-0.303,0.264-0.708,0.095-1.047C21.725,5.214,21.379,5,21,5z",displayName:"TriangleDownIcon"}),(0,n.IU)({d:"M12.8,5.4c-0.377-0.504-1.223-0.504-1.6,0l-9,12c-0.228,0.303-0.264,0.708-0.095,1.047 C2.275,18.786,2.621,19,3,19h18c0.379,0,0.725-0.214,0.895-0.553c0.169-0.339,0.133-0.744-0.095-1.047L12.8,5.4z",displayName:"TriangleUpIcon"}),(0,n.IU)({displayName:"InfoOutlineIcon",path:l.createElement("g",{fill:"currentColor",stroke:"currentColor",strokeLinecap:"square",strokeWidth:"2"},l.createElement("circle",{cx:"12",cy:"12",fill:"none",r:"11",stroke:"currentColor"}),l.createElement("line",{fill:"none",x1:"11.959",x2:"11.959",y1:"11",y2:"17"}),l.createElement("circle",{cx:"11.959",cy:"7",r:"1",stroke:"none"}))}),(0,n.IU)({displayName:"BellIcon",d:"M12 22c1.1 0 2-.9 2-2h-4c0 1.1.89 2 2 2zm6-6v-5c0-3.07-1.64-5.64-4.5-6.32V4c0-.83-.67-1.5-1.5-1.5s-1.5.67-1.5 1.5v.68C7.63 5.36 6 7.92 6 11v5l-2 2v1h16v-1l-2-2z"}),(0,n.IU)({d:"M12,0A12,12,0,1,0,24,12,12.013,12.013,0,0,0,12,0Zm.25,5a1.5,1.5,0,1,1-1.5,1.5A1.5,1.5,0,0,1,12.25,5ZM14.5,18.5h-4a1,1,0,0,1,0-2h.75a.25.25,0,0,0,.25-.25v-4.5a.25.25,0,0,0-.25-.25H10.5a1,1,0,0,1,0-2h1a2,2,0,0,1,2,2v4.75a.25.25,0,0,0,.25.25h.75a1,1,0,1,1,0,2Z"})),m=((0,n.IU)({d:"M12,0A12,12,0,1,0,24,12,12.013,12.013,0,0,0,12,0Zm0,19a1.5,1.5,0,1,1,1.5-1.5A1.5,1.5,0,0,1,12,19Zm1.6-6.08a1,1,0,0,0-.6.917,1,1,0,1,1-2,0,3,3,0,0,1,1.8-2.75A2,2,0,1,0,10,9.255a1,1,0,1,1-2,0,4,4,0,1,1,5.6,3.666Z",displayName:"QuestionIcon"}),(0,n.IU)({displayName:"QuestionOutlineIcon",path:l.createElement("g",{stroke:"currentColor",strokeWidth:"1.5"},l.createElement("path",{strokeLinecap:"round",fill:"none",d:"M9,9a3,3,0,1,1,4,2.829,1.5,1.5,0,0,0-1,1.415V14.25"}),l.createElement("path",{fill:"none",strokeLinecap:"round",d:"M12,17.25a.375.375,0,1,0,.375.375A.375.375,0,0,0,12,17.25h0"}),l.createElement("circle",{fill:"none",strokeMiterlimit:"10",cx:"12",cy:"12",r:"11.25"}))}),(0,n.IU)({d:"M11.983,0a12.206,12.206,0,0,0-8.51,3.653A11.8,11.8,0,0,0,0,12.207,11.779,11.779,0,0,0,11.8,24h.214A12.111,12.111,0,0,0,24,11.791h0A11.766,11.766,0,0,0,11.983,0ZM10.5,16.542a1.476,1.476,0,0,1,1.449-1.53h.027a1.527,1.527,0,0,1,1.523,1.47,1.475,1.475,0,0,1-1.449,1.53h-.027A1.529,1.529,0,0,1,10.5,16.542ZM11,12.5v-6a1,1,0,0,1,2,0v6a1,1,0,1,1-2,0Z",displayName:"WarningIcon"}),(0,n.IU)({displayName:"WarningTwoIcon",d:"M23.119,20,13.772,2.15h0a2,2,0,0,0-3.543,0L.881,20a2,2,0,0,0,1.772,2.928H21.347A2,2,0,0,0,23.119,20ZM11,8.423a1,1,0,0,1,2,0v6a1,1,0,1,1-2,0Zm1.05,11.51h-.028a1.528,1.528,0,0,1-1.522-1.47,1.476,1.476,0,0,1,1.448-1.53h.028A1.527,1.527,0,0,1,13.5,18.4,1.475,1.475,0,0,1,12.05,19.933Z"}),(0,n.IU)({viewBox:"0 0 14 14",path:l.createElement("g",{fill:"currentColor"},l.createElement("polygon",{points:"5.5 11.9993304 14 3.49933039 12.5 2 5.5 8.99933039 1.5 4.9968652 0 6.49933039"}))}),(0,n.IU)({displayName:"MinusIcon",path:l.createElement("g",{fill:"currentColor"},l.createElement("rect",{height:"4",width:"20",x:"2",y:"10"}))}),(0,n.IU)({displayName:"HamburgerIcon",viewBox:"0 0 24 24",d:"M 3 5 A 1.0001 1.0001 0 1 0 3 7 L 21 7 A 1.0001 1.0001 0 1 0 21 5 L 3 5 z M 3 11 A 1.0001 1.0001 0 1 0 3 13 L 21 13 A 1.0001 1.0001 0 1 0 21 11 L 3 11 z M 3 17 A 1.0001 1.0001 0 1 0 3 19 L 21 19 A 1.0001 1.0001 0 1 0 21 17 L 3 17 z"}))},4651:function(e,a,t){"use strict";t.d(a,{Ee:function(){return p}});var n=t(2846),l=t(5031),r=t(7294),c=t(7375);function i(){return(i=Object.assign||function(e){for(var a=1;a=0||(l[t]=e[t]);return l}var s=["htmlWidth","htmlHeight","alt"],d=["fallbackSrc","fallback","src","srcSet","align","fit","loading","ignoreFallback","crossOrigin"],m=r.forwardRef((function(e,a){var t=e.htmlWidth,n=e.htmlHeight,l=e.alt,c=o(e,s);return r.createElement("img",i({width:t,height:n,ref:a,alt:l},c))})),p=(0,n.Gp)((function(e,a){var t=e.fallbackSrc,s=e.fallback,p=e.src,u=e.srcSet,h=e.align,L=e.fit,f=e.loading,C=e.ignoreFallback,I=e.crossOrigin,y=o(e,d),v=null!=f||C||void 0===t&&void 0===s,g=function(e){var a=e.loading,t=e.src,n=e.srcSet,l=e.onLoad,i=e.onError,o=e.crossOrigin,s=e.sizes,d=e.ignoreFallback,m=(0,r.useState)("pending"),p=m[0],u=m[1];(0,r.useEffect)((function(){u(t?"loading":"pending")}),[t]);var h=(0,r.useRef)(),L=(0,r.useCallback)((function(){if(t){f();var e=new Image;e.src=t,o&&(e.crossOrigin=o),n&&(e.srcset=n),s&&(e.sizes=s),a&&(e.loading=a),e.onload=function(e){f(),u("loaded"),null==l||l(e)},e.onerror=function(e){f(),u("failed"),null==i||i(e)},h.current=e}}),[t,o,n,s,l,i,a]),f=function(){h.current&&(h.current.onload=null,h.current.onerror=null,h.current=null)};return(0,c.Gw)((function(){if(!d)return"loading"===p&&L(),function(){f()}}),[p,L,d]),d?"loaded":p}(i({},e,{ignoreFallback:v})),E=i({ref:a,objectFit:L,objectPosition:h},v?y:(0,l.CE)(y,["onError","onLoad"]));return"loaded"!==g?s||r.createElement(n.m$.img,i({as:m,className:"chakra-image__placeholder",src:t},E)):r.createElement(n.m$.img,i({as:m,src:p,srcSet:u,crossOrigin:I,loading:f,className:"chakra-image"},E))}));l.Ts&&(p.displayName="Image")},1358:function(e,a,t){"use strict";t.d(a,{TX:function(){return c}});var n=t(2846),l=t(5031),r={border:"0px",clip:"rect(0px, 0px, 0px, 0px)",height:"1px",width:"1px",margin:"-1px",padding:"0px",overflow:"hidden",whiteSpace:"nowrap",position:"absolute"},c=(0,n.m$)("span",{baseStyle:r});l.Ts&&(c.displayName="VisuallyHidden");var i=(0,n.m$)("input",{baseStyle:r});l.Ts&&(i.displayName="VisuallyHiddenInput")},9008:function(e,a,t){e.exports=t(5443)}}]); \ No newline at end of file diff --git a/_next/static/chunks/939-636fa0313541db68.js b/_next/static/chunks/939-636fa0313541db68.js new file mode 100644 index 000000000..d365d4264 --- /dev/null +++ b/_next/static/chunks/939-636fa0313541db68.js @@ -0,0 +1 @@ +(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[939],{9280:function(e,t,n){var r={"./authors":8712,"./authors.json":8712,"./guides":9552,"./guides.json":9552,"./guides/asymptotic-notation.md":3406,"./guides/avoid-render-blocking-javascript-with-async-defer.md":4109,"./guides/basic-authentication.md":4048,"./guides/big-o-notation.md":4340,"./guides/character-encodings.md":2963,"./guides/ci-cd.md":1123,"./guides/design-patterns-for-humans.md":5298,"./guides/dhcp-in-one-picture.md":8303,"./guides/dns-in-one-picture.md":6210,"./guides/history-of-javascript.md":5263,"./guides/http-caching.md":299,"./guides/journey-to-http2.md":2518,"./guides/jwt-authentication.md":3275,"./guides/levels-of-seniority.md":7824,"./guides/oauth.md":7118,"./guides/project-history.md":319,"./guides/proxy-servers.md":5282,"./guides/random-numbers.md":9177,"./guides/scaling-databases.md":5301,"./guides/session-authentication.md":4403,"./guides/ssl-tls-https-ssh.md":5740,"./guides/sso.md":2303,"./guides/token-authentication.md":5726,"./guides/torrent-client.md":9263,"./guides/unfamiliar-codebase.md":8686,"./guides/upcoming.md":4876,"./guides/what-are-web-vitals.md":9405,"./guides/what-is-internet.md":9069,"./guides/what-is-sli-slo-sla.md":8681,"./guides/why-build-it-and-they-will-come-wont-work-anymore.md":2935,"./pages/about.md":7480,"./pages/privacy.md":2612,"./pages/terms.md":9636,"./roadmaps":1662,"./roadmaps.json":1662,"./roadmaps/100-frontend/content-paths":8359,"./roadmaps/100-frontend/content-paths.json":8359,"./roadmaps/100-frontend/content/100-internet/100-how-does-the-internet-work.md":1080,"./roadmaps/100-frontend/content/100-internet/101-what-is-http.md":3592,"./roadmaps/100-frontend/content/100-internet/102-browsers-and-how-they-work.md":1995,"./roadmaps/100-frontend/content/100-internet/103-dns-and-how-it-works.md":2229,"./roadmaps/100-frontend/content/100-internet/104-what-is-domain-name.md":4898,"./roadmaps/100-frontend/content/100-internet/105-what-is-hosting.md":6747,"./roadmaps/100-frontend/content/100-internet/readme.md":2217,"./roadmaps/100-frontend/content/101-html/100-learn-the-basics.md":1244,"./roadmaps/100-frontend/content/101-html/101-writing-semantic-html.md":8234,"./roadmaps/100-frontend/content/101-html/102-forms-and-validations.md":3392,"./roadmaps/100-frontend/content/101-html/103-conventions-and-best-practices.md":102,"./roadmaps/100-frontend/content/101-html/104-accessibility.md":2053,"./roadmaps/100-frontend/content/101-html/105-seo-basics.md":2783,"./roadmaps/100-frontend/content/101-html/readme.md":6630,"./roadmaps/100-frontend/content/102-css/100-learn-the-basics.md":6729,"./roadmaps/100-frontend/content/102-css/101-making-layouts.md":8371,"./roadmaps/100-frontend/content/102-css/102-responsive-design-and-media-queries.md":9738,"./roadmaps/100-frontend/content/102-css/readme.md":4814,"./roadmaps/100-frontend/content/103-javascript/100-syntax-and-basic-constructs.md":9536,"./roadmaps/100-frontend/content/103-javascript/101-learn-dom-manipulation.md":4964,"./roadmaps/100-frontend/content/103-javascript/102-learn-fetch-api-ajax-xhr.md":7522,"./roadmaps/100-frontend/content/103-javascript/103-es6-and-modular-javascript.md":7919,"./roadmaps/100-frontend/content/103-javascript/104-concepts.md":2132,"./roadmaps/100-frontend/content/103-javascript/readme.md":2009,"./roadmaps/100-frontend/content/104-version-control-systems/100-basic-usage-of-git.md":1343,"./roadmaps/100-frontend/content/104-version-control-systems/readme.md":1688,"./roadmaps/100-frontend/content/105-repo-hosting-services/100-github.md":622,"./roadmaps/100-frontend/content/105-repo-hosting-services/101-gitlab.md":9597,"./roadmaps/100-frontend/content/105-repo-hosting-services/102-bitbucket.md":1752,"./roadmaps/100-frontend/content/105-repo-hosting-services/readme.md":5863,"./roadmaps/100-frontend/content/106-web-security-knowledge/100-https.md":3598,"./roadmaps/100-frontend/content/106-web-security-knowledge/101-content-security-policy.md":1342,"./roadmaps/100-frontend/content/106-web-security-knowledge/102-cors.md":8215,"./roadmaps/100-frontend/content/106-web-security-knowledge/103-owasp-security-risks.md":6432,"./roadmaps/100-frontend/content/106-web-security-knowledge/readme.md":9e3,"./roadmaps/100-frontend/content/107-package-managers/100-npm.md":7897,"./roadmaps/100-frontend/content/107-package-managers/101-yarn.md":6741,"./roadmaps/100-frontend/content/107-package-managers/readme.md":9897,"./roadmaps/100-frontend/content/108-css-architecture/100-bem.md":2002,"./roadmaps/100-frontend/content/108-css-architecture/101-oocss.md":9085,"./roadmaps/100-frontend/content/108-css-architecture/102-smacss.md":6235,"./roadmaps/100-frontend/content/108-css-architecture/readme.md":814,"./roadmaps/100-frontend/content/109-css-preprocessors/100-sass.md":1516,"./roadmaps/100-frontend/content/109-css-preprocessors/101-postcss.md":2238,"./roadmaps/100-frontend/content/109-css-preprocessors/102-less.md":3765,"./roadmaps/100-frontend/content/109-css-preprocessors/readme.md":8241,"./roadmaps/100-frontend/content/110-build-tools/100-task-runners/npm-scripts.md":1166,"./roadmaps/100-frontend/content/110-build-tools/100-task-runners/readme.md":3619,"./roadmaps/100-frontend/content/110-build-tools/101-module-bundlers/esbuild.md":5888,"./roadmaps/100-frontend/content/110-build-tools/101-module-bundlers/parcel.md":3593,"./roadmaps/100-frontend/content/110-build-tools/101-module-bundlers/readme.md":401,"./roadmaps/100-frontend/content/110-build-tools/101-module-bundlers/rollup.md":8107,"./roadmaps/100-frontend/content/110-build-tools/101-module-bundlers/vite.md":7261,"./roadmaps/100-frontend/content/110-build-tools/101-module-bundlers/webpack.md":7537,"./roadmaps/100-frontend/content/110-build-tools/102-linters-formatters/eslint.md":488,"./roadmaps/100-frontend/content/110-build-tools/102-linters-formatters/prettier.md":3518,"./roadmaps/100-frontend/content/110-build-tools/102-linters-formatters/readme.md":3247,"./roadmaps/100-frontend/content/110-build-tools/102-linters-formatters/standardjs.md":2483,"./roadmaps/100-frontend/content/110-build-tools/readme.md":749,"./roadmaps/100-frontend/content/111-pick-a-framework/100-react-js/mobx.md":5703,"./roadmaps/100-frontend/content/111-pick-a-framework/100-react-js/readme.md":355,"./roadmaps/100-frontend/content/111-pick-a-framework/100-react-js/recoil.md":3101,"./roadmaps/100-frontend/content/111-pick-a-framework/100-react-js/redux.md":687,"./roadmaps/100-frontend/content/111-pick-a-framework/101-angular/ngrx.md":6849,"./roadmaps/100-frontend/content/111-pick-a-framework/101-angular/readme.md":9092,"./roadmaps/100-frontend/content/111-pick-a-framework/101-angular/rxjs.md":6230,"./roadmaps/100-frontend/content/111-pick-a-framework/102-vue-js/readme.md":7917,"./roadmaps/100-frontend/content/111-pick-a-framework/102-vue-js/vuex.md":5325,"./roadmaps/100-frontend/content/111-pick-a-framework/readme.md":8111,"./roadmaps/100-frontend/content/112-modern-css/100-styled-components.md":7038,"./roadmaps/100-frontend/content/112-modern-css/101-css-modules.md":6533,"./roadmaps/100-frontend/content/112-modern-css/102-styled-jsx.md":509,"./roadmaps/100-frontend/content/112-modern-css/103-emotion.md":2719,"./roadmaps/100-frontend/content/112-modern-css/readme.md":7576,"./roadmaps/100-frontend/content/113-web-components/100-html-templates.md":5281,"./roadmaps/100-frontend/content/113-web-components/101-custom-elements.md":9013,"./roadmaps/100-frontend/content/113-web-components/102-shadow-dom.md":8696,"./roadmaps/100-frontend/content/113-web-components/readme.md":5689,"./roadmaps/100-frontend/content/114-css-frameworks/114-css-first/bootstrap.md":112,"./roadmaps/100-frontend/content/114-css-frameworks/114-css-first/bulma.md":6792,"./roadmaps/100-frontend/content/114-css-frameworks/114-css-first/readme.md":590,"./roadmaps/100-frontend/content/114-css-frameworks/114-js-first/chakra-ui.md":131,"./roadmaps/100-frontend/content/114-css-frameworks/114-js-first/material-ui.md":815,"./roadmaps/100-frontend/content/114-css-frameworks/114-js-first/radix-ui.md":2779,"./roadmaps/100-frontend/content/114-css-frameworks/114-js-first/readme.md":6121,"./roadmaps/100-frontend/content/114-css-frameworks/114-js-first/tailwind-css.md":5901,"./roadmaps/100-frontend/content/114-css-frameworks/readme.md":4093,"./roadmaps/100-frontend/content/115-testing-your-apps/100-jest.md":3303,"./roadmaps/100-frontend/content/115-testing-your-apps/101-react-testing-library.md":6832,"./roadmaps/100-frontend/content/115-testing-your-apps/102-cypress.md":5505,"./roadmaps/100-frontend/content/115-testing-your-apps/103-enzyme.md":4459,"./roadmaps/100-frontend/content/115-testing-your-apps/104-other-options.md":7814,"./roadmaps/100-frontend/content/115-testing-your-apps/readme.md":2632,"./roadmaps/100-frontend/content/116-type-checkers/100-typescript.md":846,"./roadmaps/100-frontend/content/116-type-checkers/101-flow.md":4835,"./roadmaps/100-frontend/content/116-type-checkers/readme.md":8285,"./roadmaps/100-frontend/content/117-progressive-web-apps/100-apis.md":2552,"./roadmaps/100-frontend/content/117-progressive-web-apps/101-performance.md":8030,"./roadmaps/100-frontend/content/117-progressive-web-apps/readme.md":9759,"./roadmaps/100-frontend/content/118-server-side-rendering/100-react-js/after-js.md":4071,"./roadmaps/100-frontend/content/118-server-side-rendering/100-react-js/next-js.md":5502,"./roadmaps/100-frontend/content/118-server-side-rendering/100-react-js/readme.md":2522,"./roadmaps/100-frontend/content/118-server-side-rendering/101-angular/readme.md":3669,"./roadmaps/100-frontend/content/118-server-side-rendering/101-angular/universal.md":8379,"./roadmaps/100-frontend/content/118-server-side-rendering/102-vue-js/nuxt-js.md":9454,"./roadmaps/100-frontend/content/118-server-side-rendering/102-vue-js/readme.md":2590,"./roadmaps/100-frontend/content/118-server-side-rendering/readme.md":583,"./roadmaps/100-frontend/content/119-graphql/100-apollo.md":1285,"./roadmaps/100-frontend/content/119-graphql/101-relay-modern.md":9135,"./roadmaps/100-frontend/content/119-graphql/readme.md":7175,"./roadmaps/100-frontend/content/120-static-site-generators/100-next-js.md":7505,"./roadmaps/100-frontend/content/120-static-site-generators/101-gatsbyjs.md":3683,"./roadmaps/100-frontend/content/120-static-site-generators/102-nuxt-js.md":4978,"./roadmaps/100-frontend/content/120-static-site-generators/103-vuepress.md":4264,"./roadmaps/100-frontend/content/120-static-site-generators/104-jekyll.md":6975,"./roadmaps/100-frontend/content/120-static-site-generators/105-hugo.md":1280,"./roadmaps/100-frontend/content/120-static-site-generators/106-gridsome.md":648,"./roadmaps/100-frontend/content/120-static-site-generators/107-eleventy.md":3221,"./roadmaps/100-frontend/content/120-static-site-generators/readme.md":6798,"./roadmaps/100-frontend/content/121-mobile-applications/100-react-native.md":368,"./roadmaps/100-frontend/content/121-mobile-applications/101-nativescript.md":5412,"./roadmaps/100-frontend/content/121-mobile-applications/102-flutter.md":9911,"./roadmaps/100-frontend/content/121-mobile-applications/103-ionic.md":342,"./roadmaps/100-frontend/content/121-mobile-applications/readme.md":1483,"./roadmaps/100-frontend/content/122-desktop-applications/100-electron.md":3557,"./roadmaps/100-frontend/content/122-desktop-applications/101-carlo.md":3759,"./roadmaps/100-frontend/content/122-desktop-applications/102-proton-native.md":3752,"./roadmaps/100-frontend/content/122-desktop-applications/readme.md":1027,"./roadmaps/100-frontend/content/123-web-assembly.md":7862,"./roadmaps/100-frontend/content/readme.md":5261,"./roadmaps/100-frontend/meta":9258,"./roadmaps/100-frontend/meta.json":9258,"./roadmaps/100-frontend/resources.md":3158,"./roadmaps/101-backend/meta":6782,"./roadmaps/101-backend/meta.json":6782,"./roadmaps/101-backend/resources.md":1325,"./roadmaps/102-devops/meta":4017,"./roadmaps/102-devops/meta.json":4017,"./roadmaps/102-devops/resources.md":8558,"./roadmaps/103-react/landscape.md":7499,"./roadmaps/103-react/meta":8477,"./roadmaps/103-react/meta.json":8477,"./roadmaps/103-react/resources.md":8274,"./roadmaps/104-angular/landscape.md":892,"./roadmaps/104-angular/meta":8834,"./roadmaps/104-angular/meta.json":8834,"./roadmaps/104-angular/resources.md":2710,"./roadmaps/105-android/landscape.md":8814,"./roadmaps/105-android/meta":9508,"./roadmaps/105-android/meta.json":9508,"./roadmaps/105-android/resources.md":2151,"./roadmaps/106-python/landscape.md":8751,"./roadmaps/106-python/meta":4099,"./roadmaps/106-python/meta.json":4099,"./roadmaps/106-python/resources.md":1894,"./roadmaps/107-golang/landscape.md":3331,"./roadmaps/107-golang/meta":2737,"./roadmaps/107-golang/meta.json":2737,"./roadmaps/107-golang/resources.md":3923,"./roadmaps/108-java/landscape.md":4464,"./roadmaps/108-java/meta":2507,"./roadmaps/108-java/meta.json":2507,"./roadmaps/108-java/resources.md":4764,"./roadmaps/109-postgresql-dba/landscape.md":4592,"./roadmaps/109-postgresql-dba/meta":8951,"./roadmaps/109-postgresql-dba/meta.json":8951,"./roadmaps/109-postgresql-dba/resources.md":165,"./roadmaps/110-aws/landscape.md":2014,"./roadmaps/110-aws/meta":7559,"./roadmaps/110-aws/meta.json":7559,"./roadmaps/110-aws/resources.md":3737,"./roadmaps/111-qa/landscape.md":611,"./roadmaps/111-qa/meta":3204,"./roadmaps/111-qa/meta.json":3204,"./roadmaps/111-qa/resources.md":4541,"./site":8641,"./site.json":8641,"./videos":1797,"./videos.json":1797,"./videos/acid-explained.md":5292,"./videos/all-about-http-caching.md":1568,"./videos/arrays-and-objects-in-javascript.md":8259,"./videos/async-javascript.md":7210,"./videos/big-o-notation.md":3501,"./videos/content-delivery-networks.md":1830,"./videos/dns-explained.md":9970,"./videos/dns-records.md":4997,"./videos/floating-point-arithmetic.md":8813,"./videos/freeze-and-seal-objects-in-javascript.md":6789,"./videos/how-to-use-css-variables.md":9320,"./videos/how-to-use-github-actions.md":7624,"./videos/javascript-fetch-api.md":6634,"./videos/load-balancers-101.md":4121,"./videos/osi-model.md":8635,"./videos/practical-intro-to-react.md":1051,"./videos/promises-in-javascript.md":5491,"./videos/random-number-generators.md":7730,"./videos/scaling-the-unscalable.md":9351,"./videos/ssh-ssl-tls.md":6765,"./videos/system-design-101.md":4322,"./videos/tcp-ip-model.md":2142,"./videos/transport-protocols-tcp-vs-udp.md":2034,"./videos/what-is-cap-theorem.md":6672,"./videos/what-is-dependency-injection.md":1454,"./videos/what-is-dom-shadow-dom-virtual-dom.md":6315,"./videos/what-is-eventual-consistency.md":104,"./videos/yaml-in-depth.md":8734};function o(e){var t=a(e);return n(t)}function a(e){if(!n.o(r,e)){var t=new Error("Cannot find module '"+e+"'");throw t.code="MODULE_NOT_FOUND",t}return r[e]}o.keys=function(){return Object.keys(r)},o.resolve=a,e.exports=o,o.id=9280},1524:function(e,t,n){"use strict";n.d(t,{m:function(){return a}});var r=n(5893),o=n(8527);n(7294);function a(e){var t=e.title,n=e.subtitle,a=e.children,s=e.beforeTitle,i=void 0===s?null:s;return(0,r.jsxs)(o.xu,{pt:["25px","20px","45px"],pb:["20px","15px","30px"],borderBottomWidth:1,mb:"30px",children:[(0,r.jsxs)(o.W2,{maxW:"container.md",position:"relative",children:[i,(0,r.jsx)(o.X6,{as:"h1",color:"black",fontSize:["28px","33px","40px"],fontWeight:700,mb:["2px","2px","5px"],children:t}),(0,r.jsx)(o.xv,{fontSize:["13px","14px","15px"],children:n})]}),a&&(0,r.jsx)(o.W2,{maxW:"container.md",children:a})]})}},7480:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h2",null,"What is roadmap.sh?"),(0,r.kt)("p",null,"Roadmap.sh is the place containing community curated roadmaps, study plans, paths and resources for the budding\ndevelopers. It started as a ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/kamranahmedse/developer-roadmap"}),"set of charts to guide the developers"),"\nwho are confused about what should they learn next but that alone wasn't enough so I expanded it into the website to get\nmore contributors involved."),(0,r.kt)("h2",null,"What are the plans for roadmap.sh?"),(0,r.kt)("p",null,"The website started off as\na ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/kamranahmedse/developer-roadmap"}),"simple repository containing a few charts")," for developers and\nbased on my personal opinions but it could have been much more than that so I decided to expand it to a website where\npeople can contribute to study plans with their areas of expertise as well, add more roadmaps, write guides etc."),(0,r.kt)("p",null,"We haven't opened up the sign ups for now but we will be doing. My long term plans for this website are to turn it into\na goto place for the developers to seek guidance about their careers, help others, share their journeys, incentivize the\nlearnings, get feedbacks on their projects etc."),(0,r.kt)("h2",null,"How did you build roadmap.sh?"),(0,r.kt)("p",null,"The basic version of the website has been built with ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/zeit/next.js/"}),"Next.js"),", is opensource and can\nbe found on ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/kamranahmedse/roadmap.sh"}),"github"),". It was hastily done to get it out in front of the\npeople and get people to start contributing, so it might be rough on the edges, but that is where we need your help."),(0,r.kt)("h2",null,"How does it make money?"),(0,r.kt)("p",null,"It doesn't make any money. I have been using my personal time and budget to build it. I did not create this website with\nany intentions of monetization but as a good will, to help the people get out of the frustration that I was once in."),(0,r.kt)("p",null,"Having said that, I love teaching and my future plans are to be able to work full-time on roadmap.sh for which it has to\nmake enough money to pay for my rent, groceries, bills, travel expenses, etc but even if it doesn't it's likely I'll\ncontinue growing the site however I can. My focus at the moment is not making money from it and just add content that\ncreates value for the people."),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Sponsor the efforts by ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/sponsors/kamranahmedse"}),"paying as little as 5$ per month")," or with ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://paypal.me/kamranahmedse"}),"one time payment via paypal"),". Alternatively, reach out to me at ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"mailto:kamranahmed.se@gmail.com"}),"kamranahmed.se@gmail.com"),".")),(0,r.kt)("h2",null,"Can I contribute?"),(0,r.kt)("p",null,"You definitely can, infact you are encouraged to do that. Even your minor contributions such as typo fixes count. The\nsource code of the website can be ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/kamranahmedse/roadmap.sh"}),"found on Github"),". Your contributions can\nbe:"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"Adding a new roadmap"),(0,r.kt)("li",{parentName:"ul"},"Updating existing roadmap"),(0,r.kt)("li",{parentName:"ul"},"Suggesting changes to the existing roadmaps"),(0,r.kt)("li",{parentName:"ul"},"Writing a Guide"),(0,r.kt)("li",{parentName:"ul"},"Updating an existing guide"),(0,r.kt)("li",{parentName:"ul"},"Fixing grammar mistakes, typos on the website or the content"),(0,r.kt)("li",{parentName:"ul"},"Updating the UI of the website"),(0,r.kt)("li",{parentName:"ul"},"Refactoring the codebase"),(0,r.kt)("li",{parentName:"ul"},"Becoming a sponsor")),(0,r.kt)("p",null,"Just make sure\nto ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/kamranahmedse/roadmap.sh/tree/master/contributing"}),"follow the contribution guidelines")," when you\ndecide to contribute."),(0,r.kt)("h2",null,"Can I redistribute the content?"),(0,r.kt)("p",null,"No, the license of the content on this website does not allow you to redistribute any of the content on this website\nanywhere. You can use it for personal use or share the link to the content if you have to but redistribution is not\nallowed."),(0,r.kt)("h2",null,"What is the best way to contact you?"),(0,r.kt)("p",null,"Tweet or send me a message ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://twitter.com/kamranahmedse"}),"@kamranahmedse")," or email me\nat ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"mailto:kamranahmed.se@gmail.com"}),"kamranahmed.se@gmail.com"),". I get lots of messages so apologies in advance if you don't hear back\nfrom me soon but I do reply to everyone."))}s.isMDXComponent=!0},2612:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("h1",null,"Privacy Policy"),(0,r.kt)("p",null,"By using or accessing the Services in any manner, you acknowledge that you accept the practices and policies outlined in this Privacy Policy, and you hereby consent that we will collect, use, and share your information in the following ways. Remember that your use of roadmap.sh\u2019s Services is at all times subject to the ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/terms"}),"Terms of Use"),", which incorporates this Privacy Policy. Any terms we use in this Policy without defining them have the definitions given to them in the Terms of Use."),(0,r.kt)("h2",null,"What does this Privacy Policy cover?"),(0,r.kt)("p",null,'This Privacy Policy covers our treatment of personally identifiable information ("Personal Information") that we gather when you are accessing or using our Services, but not to the practices of companies we don\u2019t own or control, or people that we don\u2019t manage. We gather various types of Personal Information from our users, as explained in more detail below, and we use this Personal Information internally in connection with our Services, including to personalize, provide, and improve our services, to allow you to set up a user account and profile, to contact you and allow other users to contact you, to fulfill your requests for certain products and services, and to analyze how you use the Services. In certain cases, we may also share some Personal Information with third parties, but only as described below.'),(0,r.kt)("p",null,"As noted in the Terms of Use, we do not knowingly collect or solicit personal information from anyone under the age of 13. If you are under 13, please do not attempt to register for the Services or send any personal information about yourself to us. If we learn that we have collected personal information from a child under age 13, we will delete that information as quickly as possible. If you believe that a child under 13 may have provided us personal information, please contact us at ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"mailto:kamranahmed.se@gmail.com"}),"kamranahmed.se@gmail.com"),"."),(0,r.kt)("h2",null,"Will roadmap.sh ever change this Privacy Policy?"),(0,r.kt)("p",null,"We\u2019re constantly trying to improve our Services, so we may need to change this Privacy Policy from time to time as well, but we will alert you to changes by updating the services on the website, placing a notice on the Services, by sending you an email, and/or by some other means. Please note that if you\u2019ve opted not to receive legal notice emails from us (or you haven\u2019t provided us with your email address), those legal notices will still govern your use of the Services, and you are still responsible for reading and understanding them. If you use the Services after any changes to the Privacy Policy have been posted, that means you agree to all of the changes. Use of information we collect now is subject to the Privacy Policy in effect at the time such information is used or collected."),(0,r.kt)("h2",null,"What Information does roadmap.sh Collect?"),(0,r.kt)("p",null,"Information You Provide to Us:"),(0,r.kt)("p",null,"We receive and store any information you knowingly provide to us. For example, through the registration process and/or through your account settings, we may collect Personal Information such as your name, title, email address, phone number, and third-party account credentials (for example, your log-in credentials for Twitter or other third party sites. If you provide your third-party account credentials to us or otherwise sign in to the Services through a third party site or service, you understand some content and/or information in those accounts (\u201cThird Party Account Information\u201d) may be transmitted into your account with us if you authorize such transmissions], and that Third Party Account Information transmitted to our Services is covered by this Privacy Policy. Certain information may be required to register with us or to take advantage of some of our features."),(0,r.kt)("p",null,"We may communicate with you if you\u2019ve provided us the means to do so. For example, if you\u2019ve given us your email address, we may send you promotional email offers on behalf of other businesses, or email you about your use of the Services. Also, we may receive a confirmation when you open an email from us. This confirmation helps us make our communications with you more interesting and improve our services. If you do not want to receive communications from us, please email us at ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"mailto:kamranahmed.se@gmail.com"}),"kamranahmed.se@gmail.com"),"."),(0,r.kt)("h2",null,"Information Collected Automatically"),(0,r.kt)("p",null,"Whenever you interact with our Services, we automatically receive and record information on our server logs from your browser or device, which may include your IP address, geolocation data, device identification, \u201ccookie\u201d information, the type of browser and/or device you\u2019re using to access our Services, and the page or feature you requested. \u201cCookies\u201d are identifiers we transfer to your browser or device that allow us to recognize your browser or device and tell us how and when pages and features in our Services are visited and by how many people. You may be able to change the preferences on your browser or device to prevent or limit your device\u2019s acceptance of cookies, but this may prevent you from taking advantage of some of our features. Our advertising partners may also transmit cookies to your browser or device, when you click on ads that appear on the Services. Also if you click on a link to a third party website or service, such third party may also transmit cookies to you. Again, this Privacy Policy does not cover the use of cookies by any third parties, and we aren\u2019t responsible for their privacy policies and practices."),(0,r.kt)("p",null,"When we collect the usage information described above, we only use this data in aggregate form, and not in a manner that would identify you personally. For example, this aggregate data can tell us how often users use a particular feature of the Services, and we can use that knowledge to make the Services interesting to as many users as possible."),(0,r.kt)("h2",null,"Will roadmap.sh Share Any of the Personal Information it Receives?"),(0,r.kt)("p",null,"We may share your Personal Information with third parties as described in this section:"),(0,r.kt)("p",null,"Information that\u2019s no longer personally identifiable. We may anonymize your Personal Information so that you are not individually identified, and provide that information to our partners. We may also provide aggregate usage information to our partners, who may use such information to understand how often and in what ways people use our Services, so that they, too, can provide you with an optimal online experience. However, we never disclose aggregate information to a partner in a manner that would identify you personally, as an individual."),(0,r.kt)("p",null,"Advertisers: We may allow advertisers and/or merchant partners (\u201cAdvertisers\u201d) to choose the demographic information of users who will see their advertisements and/or promotional offers and you agree that we may provide any of the information we have collected from you in non-personally identifiable form to an Advertiser, in order for that Advertiser to select the appropriate audience for those advertisements and/or offers. For example, we might use the fact you are located in San Francisco to show you ads or offers for San Francisco businesses, but we will not tell such businesses who you are. Note that if an advertiser asks us to show an ad to a certain audience or audience segment and you respond to that ad, the advertiser may conclude that you fit the description of the audience they were trying to reach."),(0,r.kt)("p",null,"We may deliver a file to you through the Services (known as a \u201cweb beacon\u201d) from an ad network. Web beacons allow ad networks to provide anonymized, aggregated auditing, research and reporting for us and for advertisers. Web beacons also enable ad networks to serve targeted advertisements to you when you visit other websites. Because your web browser must request these advertisements and web beacons from the ad network\u2019s servers, these companies can view, edit, or set their own cookies, just as if you had requested a web page from their site. You may be able to opt-out of web beacon tracking by adjusting the settings on your browser."),(0,r.kt)("p",null,"Affiliated Businesses: In certain situations, businesses or third party websites we\u2019re affiliated with may sell or provide products or services to you through or in connection with the Services (either alone or jointly with us). You can recognize when an affiliated business is associated with such a transaction or service, and we will share your Personal Information with that affiliated business only to the extent that it is related to such transaction or service. One such service may include the ability for you to automatically transmit Third Party Account Information to your Services profile or to automatically transmit information in your Services profile to your third party account; for example, you may sign into your roadmap.sh account using your Twitter account. We have no control over the policies and practices of third party websites or businesses as to privacy or anything else, so if you choose to take part in any transaction or service relating to an affiliated website or business, please review all such business\u2019 or websites\u2019 policies."),(0,r.kt)("p",null,"Our Agents: We employ other companies and people to perform tasks on our behalf and need to share your information with them to provide products or services to you. Unless we tell you differently, our agents do not have any right to use the Personal Information we share with them beyond what is necessary to assist us."),(0,r.kt)("p",null,"User Profiles and Submissions: Certain user profile information, including your name, location, and any video or image content that such user has uploaded to the Services, may be displayed to other users to facilitate user interaction within the Services or address your request for our services. Please remember that any content you upload to your public user profile, along with any Personal Information or content that you voluntarily disclose online in a manner other users can view (on discussion boards, in messages and chat areas, etc.) becomes publicly available, and can be collected and used by anyone. Your user name may also be displayed to other users if and when you send messages or comments or upload images or videos through the Services and other users can contact you through messages and comments. Additionally, if you sign into the Services through a third party social networking site or service, your list of \u201cfriends\u201d from that site or service may be automatically imported to the Services, and such \u201cfriends,\u201d if they are also registered users of the Services, may be able to access certain non-public information you have entered in your Services user profile. Again, we do not control the policies and practices of any other third party site or service."),(0,r.kt)("p",null,"Business Transfers: We may choose to buy or sell assets. In these types of transactions, customer information is typically one of the business assets that would be transferred. Also, if we (or our assets) are acquired, or if we go out of business, enter bankruptcy, or go through some other change of control, Personal Information could be one of the assets transferred to or acquired by a third party."),(0,r.kt)("p",null,"Protection of roadmap.sh and Others: We reserve the right to access, read, preserve, and disclose any information that we reasonably believe is necessary to comply with law or court order; enforce or apply our terms of use and other agreements; or protect the rights, property, or safety of roadmap.sh, our employees, our users, or others."),(0,r.kt)("h2",null,"Is Personal Information about me secure?"),(0,r.kt)("p",null,"Your account is protected by a password for your privacy and security. If you access your account via a third party site or service, you may have additional or different sign-on protections via that third party site or service. You must prevent unauthorized access to your account and Personal Information by selecting and protecting your password and/or other sign-on mechanism appropriately and limiting access to your computer or device and browser by signing off after you have finished accessing your account. We endeavor to protect the privacy of your account and other Personal Information we hold in our records, but unfortunately, we cannot guarantee complete security. Unauthorized entry or use, hardware or software failure, and other factors, may compromise the security of user information at any time."),(0,r.kt)("h2",null,"What Personal Information can I access?"),(0,r.kt)("p",null,"Through your account settings, you may access, and, in some cases, edit or delete the following information you\u2019ve provided to us:"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"first and last name"),(0,r.kt)("li",{parentName:"ul"},"location of residence"),(0,r.kt)("li",{parentName:"ul"},"age or birthday"),(0,r.kt)("li",{parentName:"ul"},"username")),(0,r.kt)("p",null,"The information you can view, update, and delete may change as the Services change. If you have any questions about viewing or updating information we have on file about you, please contact us at ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"mailto:kamranahmed.se@gmail.com"}),"kamranahmed.se@gmail.com"),"."),(0,r.kt)("p",null,"Under California Civil Code Sections 1798.83-1798.84, California residents are entitled to ask us for a notice identifying the categories of Personal Information which we share with our affiliates and/or third parties for marketing purposes, and providing contact information for such affiliates and/or third parties. If you are a California resident and would like a copy of this notice, please submit a written request to: ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"mailto:kamranahmed.se@gmail.com"}),"kamranahmed.se@gmail.com"),"."),(0,r.kt)("h2",null,"What choices do I have?"),(0,r.kt)("p",null,"You can always opt not to disclose information to us, but keep in mind some information may be needed to register with us or to take advantage of some of our features."),(0,r.kt)("p",null,"You may be able to add, update, or delete information as explained above. When you update information, however, we may maintain a copy of the unrevised information in our records. You may request deletion of your account by contacting us at ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"mailto:kamranahmed.se@gmail.com"}),"kamranahmed.se@gmail.com")," and we will disassociate our email address and Twitter account from any content or other information provided to us. Some information may remain in our records after your deletion of such information from your account. We may use any aggregated data derived from or incorporating your Personal Information after you update or delete it, but not in a manner that would identify you personally."),(0,r.kt)("h2",null,"What if I have questions about this policy?"),(0,r.kt)("p",null,"If you have any questions or concerns regarding our privacy policies, please send us a detailed message to ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"mailto:kamranahmed.se@gmail.com"}),"kamranahmed.se@gmail.com"),", and we will try to resolve your concerns."))}s.isMDXComponent=!0},1080:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3592:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},1995:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2229:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},4898:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6747:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2217:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},1244:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},8234:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3392:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},102:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2053:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2783:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6630:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6729:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},8371:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},9738:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},4814:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},9536:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},4964:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},7522:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},7919:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2132:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2009:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},1343:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},1688:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},622:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},9597:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},1752:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},5863:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3598:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},1342:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},8215:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6432:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},9e3:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},7897:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6741:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},9897:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2002:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},9085:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6235:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},814:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},1516:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2238:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3765:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},8241:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},1166:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3619:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},5888:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3593:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},401:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},8107:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},7261:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},7537:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},488:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3518:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3247:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2483:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},749:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},5703:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},355:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3101:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},687:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6849:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},9092:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6230:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},7917:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},5325:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},8111:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},7038:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6533:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},509:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2719:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},7576:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},5281:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},9013:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},8696:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},5689:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},112:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6792:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},590:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},131:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},815:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2779:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6121:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},5901:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},4093:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3303:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6832:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},5505:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},4459:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},7814:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2632:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},846:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},4835:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},8285:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2552:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},8030:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},9759:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},4071:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},5502:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2522:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3669:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},8379:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},9454:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},2590:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},583:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},1285:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},9135:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},7175:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},7505:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3683:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},4978:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},4264:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6975:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},1280:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},648:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3221:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},6798:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},368:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},5412:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},9911:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},342:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},1483:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3557:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3759:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3752:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},1027:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},7862:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},5261:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}))}s.isMDXComponent=!0},3158:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return l}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a,s=(a="BadgeLink",function(e){return console.warn("Component "+a+" was not imported, exported, or provided by MDXProvider as global scope"),(0,r.kt)("div",Object.assign({},e))}),i={};function l(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},i,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("div",{className:"alert alert-primary",style:{marginBottom:"-10px"}},"This page is incomplete and is being worked upon. Please check back later or ",(0,r.kt)("a",{href:"/signup"},"subscribe")," / ",(0,r.kt)("a",{href:"https://twitter.com/kamranahmedse"},"follow me on twitter")," to get notified. Also, feel free to contribute by suggesting the resources in ",(0,r.kt)("a",{href:"https://github.com/kamranahmedse/developer-roadmap"},"the issues"),"."),(0,r.kt)("h1",null,"Become a Frontend Developer"),(0,r.kt)("p",null,"Before I go ahead and list down the resources, please know that the roadmap and the list below is exhaustive and you don't need to know it all from the get go. For frontend development, all you need to get started with is learn some basic HTML, CSS and JavaScript and start working on projects; everything else you will learn along the way. "),(0,r.kt)("h2",null,"Internet and how it works?"),(0,r.kt)("p",null,"Get the basic understanding of internet, browsers, networks and other relevant knowledge. "),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"/guides/what-is-internet",mdxType:"BadgeLink"},"What is Internet?")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://www.youtube.com/watch?v=7_LPdttKXPc",mdxType:"BadgeLink"},"How the internet works in 5 minutes")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://kamranahmed.info/blog/2016/08/13/http-in-depth/",mdxType:"BadgeLink"},"What is HTTP and how it evolved?")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://blog.cloudflare.com/http3-the-past-present-and-future/",mdxType:"BadgeLink"},"HTTP/3: the past, the present, and the future")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://kinsta.com/blog/http3/",mdxType:"BadgeLink"},"What Is HTTP/3 \u2013 Lowdown on the Fast New UDP-Based Protocol")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://www.html5rocks.com/en/tutorials/internals/howbrowserswork/",mdxType:"BadgeLink"},"How Browsers Work: Behind the scenes of modern web browsers")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://www.youtube.com/watch?v=Rck3BALhI5c",mdxType:"BadgeLink"},"DNS as Fast As Possible")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://howdns.works/",mdxType:"BadgeLink"},"How DNS works?")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"/guides/dns-in-one-picture",mdxType:"BadgeLink"},"DNS in One Picture"))),(0,r.kt)("h2",null,"Learn HTML"),(0,r.kt)("p",null,"HTML provides the skeleton of a webpage. Learn the basics of HTML; learn the basic tags, learn how to write semantic HTML, understand basic SEO, learn how to divide your pages into sections that will help you style them. "),(0,r.kt)("p",null,"Please know that I have put multiple links for each resource. While you may pick something new while going through each, you don't need to go through all of them - if you feel like you have understood the concepts and are just repeating what you learnt, you may skip the resource and move to exercises section."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://www.youtube.com/watch?v=UB1O30fR-EE",mdxType:"BadgeLink"},"HTML Crash Course For Absolute Beginners")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://www.w3schools.com/html/default.asp",mdxType:"BadgeLink"},"W3Schools \u2013 HTML Tutorial")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://www.youtube.com/watch?v=pQN-pnXPaVg",mdxType:"BadgeLink"},"HTML Full Course - Build a Website Tutorial")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://hacks.mozilla.org/2016/08/a-few-html-tips/",mdxType:"BadgeLink"},"A few HTML tips")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://hackernoon.com/six-tips-to-set-up-a-better-html-document-ud1033z3z",mdxType:"BadgeLink"},"Six tips to set up a better HTML document")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://www.w3schools.com/html/html5_semantic_elements.asp",mdxType:"BadgeLink"},"HTML Semantic Elements")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://developer.mozilla.org/en-US/docs/Web/HTML/Element",mdxType:"BadgeLink"},"HTML elements reference"))),(0,r.kt)("h2",null,"Style your pages with CSS"),(0,r.kt)("p",null,"With the help of HTML, you create structure for your pages. CSS allows you to style your pages and make them pretty. If you take the analogy of human body, the skeleton would be the HTML, skin would be the CSS and muscles that help us move would be JavaScript - we will learn more about JavaScript in the coming sections."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://www.w3schools.com/css/",mdxType:"BadgeLink"},"W3Schools \u2013 CSS Tutorial")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://www.youtube.com/watch?v=yfoY53QXEnI",mdxType:"BadgeLink"},"CSS Crash Course For Absolute Beginners")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://www.youtube.com/watch?v=Wm6CUkswsNw",mdxType:"BadgeLink"},"Build An HTML5 Website With A Responsive Layout")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://youtu.be/JJSoEo8JSnc?t=46",mdxType:"BadgeLink"},"Flexbox CSS In 20 Minutes"))),(0,r.kt)("h2",null,"Basics of JavaScript"),(0,r.kt)("p",null,"JavaScript allows you to add interactivity to your pages. Common examples that you may have seen on the websites are sliders, click interactions, popups and so on. In this section, you will learn the basics of JavaScript."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://www.w3schools.com/js/",mdxType:"BadgeLink"},"W3Schools \u2013 JavaScript Tutorial")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://youtu.be/hdI2bqOjy3c?t=2",mdxType:"BadgeLink"},"JavaScript Crash Course for Beginners")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://youtu.be/P7t13SGytRk?t=22",mdxType:"BadgeLink"},"Build a Netflix Landing Page Clone with HTML, CSS & JS"))),(0,r.kt)("h2",null,"Version Control Systems and Git"),(0,r.kt)("p",null,"Version control systems allow you to track changes to your codebase/files over time. They allow you to go back to some previous version of the codebase without any issues. Also, they help in collaborating with people working on the same code \u2013 if you\u2019ve ever collaborated with other people on a project, you might already know the frustration of copying and merging the changes from someone else into your codebase; version control systems allow you to get rid of this issue."),(0,r.kt)("p",null,"In this section, you will learn what version control systems are and understand how to use Git which is the de facto VCS. "),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://www.youtube.com/watch?v=zbKdDsNNOhg",mdxType:"BadgeLink"},"Version Control System Introduction")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://www.youtube.com/watch?v=SWYqp7iY_Tc",mdxType:"BadgeLink"},"Git & GitHub Crash Course For Beginners")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://youtu.be/Y9XZQO1n_7c?t=21",mdxType:"BadgeLink"},"Learn Git in 20 Minutes"))),(0,r.kt)("p",null,"Now that you know what git is go ahead and create an account on ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com"}),"GitHub")," and push everything that you do from now on to GitHub so that you can get the practice and get it reviewed from the other people in the community."),(0,r.kt)("h2",null,"Modern JavaScript"),(0,r.kt)("p",null,'In this section you will learn how to use package managers and get started with the "modern JavaScript".'),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Read",href:"https://medium.com/the-node-js-collection/modern-javascript-explained-for-dinosaurs-f695e9747b70",mdxType:"BadgeLink"},"Modern JavaScript for Dinosaurs (Don't worry if you don't understand some parts of it)")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://www.youtube.com/watch?v=8Rmj5UY5mJk",mdxType:"BadgeLink"},"What is NPM and how to use it")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)(s,{badgeText:"Watch",href:"https://www.youtube.com/watch?v=jHDhaSSKmB0",mdxType:"BadgeLink"},"NPM Crash Course"))),(0,r.kt)("br",null),(0,r.kt)("br",null),(0,r.kt)("br",null),(0,r.kt)("br",null),(0,r.kt)("br",null),(0,r.kt)("br",null))}l.isMDXComponent=!0},1325:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"We are still preparing the resources"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the list, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")))}s.isMDXComponent=!0},8558:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"We are still preparing the resources"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the list, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")))}s.isMDXComponent=!0},7499:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("p",null,"The intent of this guide is to give you an idea about the React ecosystem and to help guide your learning if you are confused. We have another ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/frontend"}),"roadmap on the Frontend Development")," that focuses on the frontend development if you are interested in that."),(0,r.kt)("p",null,"Also, please note that the list below is exhaustive, and the items are listed in no particular order. You don't need to learn everything listed in the picture, however knowing what you don't know is as important as knowing things."),(0,r.kt)("p",null,(0,r.kt)("img",Object.assign({parentName:"p"},{src:"/roadmaps/react.png",alt:null}))),(0,r.kt)("p",null,"Please note that the list is opinionated, and you might have different opinions than those of the author. Having said that, ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/kamranahmedse/roadmap.sh/issues/new"}),"we would love to hear your opinions")," and incorporate them in the picture if suitable."))}s.isMDXComponent=!0},8274:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"We are still preparing the resources"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the list, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")))}s.isMDXComponent=!0},892:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("p",null,"The intent of this guide is to give you an idea about the Angular ecosystem and to help guide your learning if you are confused. We have another ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/frontend"}),"roadmap on the Frontend Development")," that focuses on the frontend development if you are interested in that."),(0,r.kt)("p",null,"Also, please note that the list below is exhaustive, and the items are listed in no particular order. You don't need to learn everything listed in the picture, however knowing what you don't know is as important as knowing things."),(0,r.kt)("p",null,(0,r.kt)("img",Object.assign({parentName:"p"},{src:"/roadmaps/angular.png",alt:null}))),(0,r.kt)("p",null,"Please note that the list is opinionated, and you might have different opinions than those of the author. Having said that, ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/kamranahmedse/roadmap.sh/issues/new"}),"we would love to hear your opinions")," and incorporate them in the picture if suitable."))}s.isMDXComponent=!0},2710:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"We are still preparing the resources"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the list, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")))}s.isMDXComponent=!0},8814:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("p",null,"The intent of this guide is to give you an idea about the Android development landscape and to help guide your learning if you are confused. Before we start, please note that the roadmap is opinionated, and you might have different opinions than those of the author. Having said that, ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/kamranahmedse/roadmap.sh/issues/new"}),"we would love to hear your opinions")," and incorporate them in the roadmap if suitable."),(0,r.kt)("p",null,"There are multiple ways to develop applications for the android; you can go down the path of hybrid application development where ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://flutter.dev/"}),"flutter"),", ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://reactnative.dev/"}),"react-native"),", or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://www.nativescript.org/"}),"NativeScript")," are the most common contenders. Flutter uses Dart, whereas React Native and Native Script rely on JavaScript. Answering the question of hybrid vs native is out of the scope of this roadmap. This roadmap is focused on the native Android apps development but if you are interested in learning any hybrid framework, my personal preference is ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://reactnative.dev"}),"react-native")," and I would recommend you to checkout the ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/frontend"}),"Frontend Developer Roadmap"),"."),(0,r.kt)("h2",null,"Complete Roadmap"),(0,r.kt)("p",null,"Here is the full version of the roadmap in a single image and after that we have the broken down version with the resources and links to learn more about each of the boxes."),(0,r.kt)("p",null,(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps/android/roadmap.png"}),(0,r.kt)("img",Object.assign({parentName:"a"},{src:"/roadmaps/android/roadmap.svg",alt:null})))),(0,r.kt)("h2",null,"Broken Down Version"),(0,r.kt)("p",null,"Below is the broken down version of the roadmap with links and resources to learn more about each of the items listed in the complete roadmap above."),(0,r.kt)("h2",null,"Pick a Language"),(0,r.kt)("p",null,"For the languages, you can develop android apps either by using Kotlin or Java."),(0,r.kt)("p",null,(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps/android/pick-language.svg"}),(0,r.kt)("img",Object.assign({parentName:"a"},{src:"/roadmaps/android/pick-language.svg",alt:null})))),(0,r.kt)("p",null,"Although, you can use both ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://en.wikipedia.org/wiki/Kotlin_(programming_language)"}),"Kotlin")," and ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://en.wikipedia.org/wiki/Java_(programming_language)"}),"Java")," to develop native android apps, ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://android-developers.googleblog.com/2019/05/google-io-2019-empowering-developers-to-build-experiences-on-Android-Play.html"}),"Google announced in 2019")," to make Kotlin the preferred way of developing android applications. If you were to start learning android development today, Kotlin should be your language of choice."),(0,r.kt)("h2",null,"The Fundamentals"),(0,r.kt)("p",null,"Install the ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://developer.android.com/studio"}),"Android Studio")," and learn the basics of Kotlin to get started. "),(0,r.kt)("p",null,(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps/android/the-fundamentals.png"}),(0,r.kt)("img",Object.assign({parentName:"a"},{src:"/roadmaps/android/the-fundamentals.png",alt:null})))),(0,r.kt)("p",null,"We have also listed down some free resources which you can use for the items listed in the image above. If you have some better ones, please do suggest. Also, you don't need to go through all of them, just go through them and pick what you like."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://blog.teamtreehouse.com/absolute-beginners-guide-kotlin"}),"Learn the basics of Kotlin")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://kotlinlang.org/docs/reference/basic-syntax.html"}),"Kotlin Docs")," and ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://kotlinlang.org/docs/tutorials/"}),"Official Kotlin Tutorials")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.studytonight.com/data-structures/introduction-to-data-structures"}),"Data Structures and Algorithms"),". Also ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.tutorialspoint.com/data_structures_algorithms/index.htm"}),"check this"),"."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://kotlinlang.org/docs/reference/collections-overview.html"}),"Kotlin DataStructures")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://github.com/bmaslakov/kotlin-algorithm-club"}),"Algorithms and DataStructures in Kotlin"))),(0,r.kt)("h2",null,"Version Control Systems"),(0,r.kt)("p",null,"Version control systems record your changes to the codebase and allow you to recall specific versions later. There are multiple Version Control Systems available but ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://git-scm.com/"}),"Git")," is the most common one these days."),(0,r.kt)("p",null,(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps/android/git-github.png"}),(0,r.kt)("img",Object.assign({parentName:"a"},{src:"/roadmaps/android/git-github.png",alt:null})))),(0,r.kt)("p",null,"Here are some of the resources to get you started. Feel free to google and find something else that you find easier."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.udacity.com/course/version-control-with-git--ud123"}),"Udacity \u2014 Version Control with Git")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://guides.github.com/activities/hello-world/"}),"GitHub Hello World"))),(0,r.kt)("h2",null,"Building an Application"),(0,r.kt)("p",null,"Here is the list of items that you are going to need when developing Android applications. Please note that, this is an exhaustive list, and you don't need to know it all from the get-go. Get an idea of the items listed, and just start building some apps and keep the items listed in the back of your mind and have a deep dive when using them. "),(0,r.kt)("p",null,(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps/android/build-an-application.png"}),(0,r.kt)("img",Object.assign({parentName:"a"},{src:"/roadmaps/android/build-an-application.png",alt:null})))),(0,r.kt)("p",null,"To learn more about the items listed in the image above, here are the links to the relevant docs"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/guide/components/activities/intro-activities"}),"Using Activities and Activity Life Cycles")),(0,r.kt)("li",{parentName:"ul"},"Building Flexible Interfaces using ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/guide/components/fragments"}),"Fragments")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/studio/debug"}),"Debugging using Android Studio Debugger")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/work/managed-configurations"}),"Handling App Configurations")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/guide/components/intents-filters"}),"Using Intents and Intent Filters")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://guides.codepath.com/android/Using-Context"}),"Understand Context")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/training/multiple-threads"}),"Learn about Multithreading")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.raywenderlich.com/6901838-data-privacy-for-android"}),"Data Privacy")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.raywenderlich.com/5634-securing-network-data-tutorial-for-android"}),"Securing Network Data")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/training/dependency-injection"}),"Dependency Injection")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/guide/topics/providers/content-providers"}),"Content Providers")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://github.com/bumptech/glide"}),"Glide"),", ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://square.github.io/retrofit/"}),"Retrofit"),", ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://firebase.google.com/docs/crashlytics/get-started"}),"Crashlytics"),", ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://github.com/google/gson"}),"GSON")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/topic/libraries/architecture/room"}),"Room"),", ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/guide/navigation/navigation-getting-started"}),"Navigation"),", ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/topic/libraries/architecture/workmanager"}),"Work Manager"),", ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/topic/libraries/architecture/livedata"}),"LiveData"),", ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/topic/libraries/data-binding"}),"Data Binding")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://github.com/ReactiveX/RxJava"}),"RxJava"),", ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://github.com/ReactiveX/RxKotlin"}),"RxKotlin")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/topic/performance/memory-overview"}),"Memory Management Overview")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://proandroiddev.com/diving-deeper-into-context-oriented-programming-in-kotlin-3ecb4ec38814"}),"Diving deeper into context-oriented programming in Kotlin")," ")),(0,r.kt)("p",null,"I would highly recommend watching ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://www.udacity.com/course/developing-android-apps-with-kotlin--ud9012"}),"this free course")," from google on Developing Android Apps with Kotlin. Also, here are some of the resources to learn more about the topics listed above."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.udacity.com/course/developing-android-apps-with-kotlin--ud9012"}),"Developing Android Apps with Kotlin")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://developer.android.com/guide"}),"Android Developer Guides")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.raywenderlich.com"}),"Raywenderlich"))),(0,r.kt)("h2",null,"Wrap Up"),(0,r.kt)("p",null,"That wraps it up for the android developer roadmap. Again, remember to not be exhausted by the list; just learn the basics and start working on some project, rest of the learnings will come along the way. Good luck!"),(0,r.kt)("p",null,"For any suggestions, improvements and feedback, feel free to ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://github.com/kamranahmedse/roadmap.sh"}),"submit an issue")," or reach out to me on twitter ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"https://twitter.com/kamranahmedse"}),"@kamranahmedse"),"."),(0,r.kt)("br",null),(0,r.kt)("br",null),(0,r.kt)("br",null))}s.isMDXComponent=!0},2151:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"We are still preparing the resources"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the list, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")))}s.isMDXComponent=!0},8751:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("p",null,"The intent of this guide is to give you an idea about the Python ecosystem and to help guide your learning if you are confused. We have another roadmap on the ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/backend"}),"Backend Development")," that focuses on the backend development if you are interested in that."),(0,r.kt)("p",null,"Also, please note that the list below is exhaustive, and the items are listed in no particular order. You don't need to learn everything listed in the picture, however knowing what you don't know is as important as knowing things."),(0,r.kt)("p",null,(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps/python.png"}),(0,r.kt)("img",Object.assign({parentName:"a"},{src:"/roadmaps/python.png",alt:null})))))}s.isMDXComponent=!0},1894:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"We are still preparing the resources"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the list, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")))}s.isMDXComponent=!0},3331:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("p",null,"The intent of this guide is to give you an idea about the Go ecosystem and to help guide your learning if you are confused. We have another roadmap on the ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/backend"}),"Backend Development")," that focuses on the backend development if you are interested in that."),(0,r.kt)("p",null,"Also, please note that the list below is exhaustive, and the items are listed in no particular order. You don't need to learn everything listed in the picture, however knowing what you don't know is as important as knowing things."),(0,r.kt)("p",null,(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps/golang.png"}),(0,r.kt)("img",Object.assign({parentName:"a"},{src:"/roadmaps/golang.png",alt:null})))))}s.isMDXComponent=!0},3923:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"We are still preparing the resources"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the list, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")))}s.isMDXComponent=!0},4464:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("p",null,"The intent of this guide is to give you an idea about the Java ecosystem and to help guide your learning if you are confused. We have another roadmap on the ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/backend"}),"Backend Development")," that focuses on the backend development if you are interested in that."),(0,r.kt)("p",null,"Also, please note that the list below is exhaustive, and the items are listed in no particular order. You don't need to learn everything listed in the picture, however knowing what you don't know is as important as knowing things."),(0,r.kt)("p",null,(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps/java.png"}),(0,r.kt)("img",Object.assign({parentName:"a"},{src:"/roadmaps/java.png",alt:null})))))}s.isMDXComponent=!0},4764:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"We are still preparing the resources"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the list, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")))}s.isMDXComponent=!0},4592:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("p",null,"The intent of this guide is to give you an idea about the DBA landscape and to help guide your learning if you are confused. The roadmap is highly opinionated \u2014 neither, knowing everything listed in the roadmap, nor the order of items given in the roadmap is required to be followed in order to be a DBA."),(0,r.kt)("h2",null,"Learn basic RDBMS terms and concepts"),(0,r.kt)("p",null,"Get basic understanding of Postgres key terms and basic RDBMS concepts."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Object model"),": data types, columns, rows, tables, schemas, databases, queries."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Relational model"),": domains, attributes, tuples, relations, constraints, NULL."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Databases high-level concepts"),": ACID, MVCC, transactions, write-ahead log, query processing."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Links"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresql.org/docs/13/glossary.html"}),"Postgres Glossary")," "),(0,r.kt)("li",{parentName:"ul"},"SQL and Relational Theory - Christopher J. Date, 2009"),(0,r.kt)("li",{parentName:"ul"},"Database Design and Relational Theory - Christopher J. Date, 2012")))),(0,r.kt)("h2",null,"Learn how to install and run PostgreSQL"),(0,r.kt)("p",null,"Get practical skills of how to set up and run Postgres to get a working environment for further learning."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"Using package managers (APT, YUM, etc.)"),(0,r.kt)("li",{parentName:"ul"},"Using ",(0,r.kt)("inlineCode",{parentName:"li"},"docker"),"."),(0,r.kt)("li",{parentName:"ul"},"Managing Postgres service using ",(0,r.kt)("inlineCode",{parentName:"li"},"systemd")," (start, stop, restart, reload)."),(0,r.kt)("li",{parentName:"ul"},"Managing Postgres service using ",(0,r.kt)("inlineCode",{parentName:"li"},"pg_ctl"),", or OS-specific tools (like ",(0,r.kt)("inlineCode",{parentName:"li"},"pg_ctlcluster"),")."),(0,r.kt)("li",{parentName:"ul"},"Connect to Postgres using ",(0,r.kt)("inlineCode",{parentName:"li"},"psql"),"."),(0,r.kt)("li",{parentName:"ul"},"Deploy database service in cloud environment (AWS, GCE, Azure, Heroku, DigitalOcean, etc...)."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Links"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresql.org/download/"}),"Official download and install instructions")," "),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://hub.docker.com/_/postgres"}),"Official Docker images")," ")))),(0,r.kt)("h2",null,"Learn SQL concepts"),(0,r.kt)("p",null,"Get practical skills of how to create and manipulate database objects and how to execute queries using ",(0,r.kt)("inlineCode",{parentName:"p"},"psql")," client."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"Understand basic data types."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"DML queries"),": querying data, modifying data, filtering data, joining tables.",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Advanced topics"),": transactions, CTE, subqueries, lateral join, grouping, set operations."))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"DDL queries"),": managing tables and schemas (create, alter, drop)."),(0,r.kt)("li",{parentName:"ul"},"Import and export data using ",(0,r.kt)("inlineCode",{parentName:"li"},"COPY"),"."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Links"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.db-fiddle.com/"}),"DB Fiddle")," "),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresqltutorial.com/"}),"PostgreSQL Tutorial")," "),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresql.org/docs/current/tutorial-sql.html"}),"PostgreSQL SQL Getting Started")," "),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresql.org/docs/current/sql.html"}),"The SQL Language"))))),(0,r.kt)("h2",null,"Learn how to configure Postgres"),(0,r.kt)("p",null,"Get understanding of the main aspects of how Postgres could be configured. Deep understanding of Postgres internals is not yet necessary here."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"postgresql.conf:",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Resources usage"),(0,r.kt)("li",{parentName:"ul"},"Write-ahead Log"),(0,r.kt)("li",{parentName:"ul"},"Checkpoints and Background Writer"),(0,r.kt)("li",{parentName:"ul"},"Cost-based vacuum and auto-vacuum"),(0,r.kt)("li",{parentName:"ul"},"Replication"),(0,r.kt)("li",{parentName:"ul"},"Query planner"),(0,r.kt)("li",{parentName:"ul"},"Reporting, logging and statistics"),(0,r.kt)("li",{parentName:"ul"},"Adding extra extensions"),(0,r.kt)("li",{parentName:"ul"},"...keep exploring other configuration options"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Links"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"http://postgresqlco.nf/"}),"Postgresqlco.nf")," ")))),(0,r.kt)("h2",null,"Learn Postgres security concepts"),(0,r.kt)("p",null,"Get understanding about basic security concepts and common ways of how to deploy secure configurations."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"Authentication models, roles, pg_hba.conf, SSL settings."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Objects privileges"),": grant/revoke, default privileges."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Advanced topics")," - row-level security, selinux."),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Links"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresql.org/docs/current/client-authentication.html"}),"Client authentication")," "),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresql.org/docs/current/user-manag.html"}),"Roles and users managements"))))),(0,r.kt)("h2",null,"Develop infrastructure DBA skills"),(0,r.kt)("p",null,"Get practical skills of how to deploy, extend, maintain and support Postgres installations and 3rd-party Postgres ecosystem software."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Replication"),": streaming replication, logical replication"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Backup/recovery tools"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Built-in: ",(0,r.kt)("inlineCode",{parentName:"li"},"pg_dump"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"pg_dumpall"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"pg_restore"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"pg_basebackup")),(0,r.kt)("li",{parentName:"ul"},"3rd-party: ",(0,r.kt)("inlineCode",{parentName:"li"},"barman"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"pgbackrest"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"pg_probackup"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"WAL-G")),(0,r.kt)("li",{parentName:"ul"},"Backup validation procedures"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Upgrading procedures"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Minor and major upgrades using ",(0,r.kt)("inlineCode",{parentName:"li"},"pg_upgrade")),(0,r.kt)("li",{parentName:"ul"},"Upgrades using logical replication"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Connection pooling"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("inlineCode",{parentName:"li"},"Pgbouncer")),(0,r.kt)("li",{parentName:"ul"},"Alternatives: ",(0,r.kt)("inlineCode",{parentName:"li"},"Pgpool-II"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Odyssey"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Pgagroal")))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Infrastructure monitoring"),": ",(0,r.kt)("inlineCode",{parentName:"li"},"Prometheus"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Zabbix"),", other favourite monitoring solution"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"High availability and cluster management tools"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("inlineCode",{parentName:"li"},"Patroni")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Alternatives"),": ",(0,r.kt)("inlineCode",{parentName:"li"},"Repmgr"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Stolon"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"pg_auto_failover"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"PAF")))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Applications Load Balancing and Service Discovery"),": ",(0,r.kt)("inlineCode",{parentName:"li"},"Haproxy"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Keepalived"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Consul"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Etcd")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Deploy Postgres on ",(0,r.kt)("inlineCode",{parentName:"strong"},"Kubernetes")),": Simple ",(0,r.kt)("inlineCode",{parentName:"li"},"StatefulSet")," setup, ",(0,r.kt)("inlineCode",{parentName:"li"},"HELM"),", operators"),(0,r.kt)("li",{parentName:"ul"},"Resource usage and provisioning, capacity planning")),(0,r.kt)("h2",null,"Learn how to automate routines"),(0,r.kt)("p",null,"Get practical skills, learn automation tools and automate existing routine tasks."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"Automation using shell scripts or any other favourite language (",(0,r.kt)("inlineCode",{parentName:"li"},"Bash"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Python"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Perl"),", etc)"),(0,r.kt)("li",{parentName:"ul"},"Configuration management: ",(0,r.kt)("inlineCode",{parentName:"li"},"Ansible"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Salt"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Chef"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Puppet"))),(0,r.kt)("h2",null,"Develop application DBA skills"),(0,r.kt)("p",null,"Learn theory and get practical skills of how applications should work with Postgres"),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Migrations"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"practical patterns and antipatterns"),(0,r.kt)("li",{parentName:"ul"},"tools: ",(0,r.kt)("inlineCode",{parentName:"li"},"liquibase"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"sqitch"),", language-specific tools"))),(0,r.kt)("li",{parentName:"ul"},"Data import/export, bulk loading and processing"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Queues"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"practical patterns and anti-patterns"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("inlineCode",{parentName:"li"},"Skytools PGQ")))),(0,r.kt)("li",{parentName:"ul"},"Data partitioning and sharding patterns."),(0,r.kt)("li",{parentName:"ul"},"Database normalization and normal forms."),(0,r.kt)("li",{parentName:"ul"},"Books:",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"The Art of PostgreSQL - Dimitri Fontaine, 2020")))),(0,r.kt)("h2",null,"Learn Postgres advanced topics"),(0,r.kt)("p",null,"Here is important to continuously extend and develop existing knowledge about Postgres."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Low level internals"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Processes and memory architecture"),(0,r.kt)("li",{parentName:"ul"},"Vacuum processing"),(0,r.kt)("li",{parentName:"ul"},"Buffer management"),(0,r.kt)("li",{parentName:"ul"},"Lock management"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresql.org/docs/current/storage.html"}),"Physical storage and file layout")," "),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresql.org/docs/current/catalogs.html"}),"System catalog")," "))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Fine-grained tuning"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"Per-user, per-database settings"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresql.org/docs/current/sql-createtable.html#SQL-CREATETABLE-STORAGE-PARAMETERS"}),"Storage parameters")," "),(0,r.kt)("li",{parentName:"ul"},"Workload-dependant tuning: OLTP, OLAP, HTAP"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Advanced SQL topics"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"PL/pgSQL, procedures and functions, triggers"),(0,r.kt)("li",{parentName:"ul"},"Aggregate and window functions"),(0,r.kt)("li",{parentName:"ul"},"Recursive CTE"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Links"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"http://www.interdb.jp/pg/index.html"}),"The Internals of PostgreSQL")," for database administrators and system developers"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresql.org/docs/current/plpgsql.html"}),"PL/pgSQL Guide"))))),(0,r.kt)("h2",null,"Learn Postgres troubleshooting techniques"),(0,r.kt)("p",null,"Get basic understanding about troubleshooting tools and get practical skills of how to detect and resolve problems."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Operating system tools"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("inlineCode",{parentName:"li"},"top")," (",(0,r.kt)("inlineCode",{parentName:"li"},"htop"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"atop"),")"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("inlineCode",{parentName:"li"},"sysstat")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("inlineCode",{parentName:"li"},"iotop")))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Postgres system views"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("inlineCode",{parentName:"li"},"pg_stat_activity")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("inlineCode",{parentName:"li"},"pg_stat_statements")))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Postgres tools"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("inlineCode",{parentName:"li"},"pgcenter")," - ",(0,r.kt)("em",{parentName:"li"},"personal recommendation")))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Query analyzing"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresql.org/docs/current/sql-explain.html"}),"EXPLAIN")),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://explain.depesz.com/"}),"Depesz")," online EXPLAIN visualization tool"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://tatiyants.com/pev/#/plans"}),"PEV")," online EXPLAIN visualization tool"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://explain.tensor.ru/"}),"Tensor")," online EXPLAIN visualization tool, RU language only"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Log analyzing"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("inlineCode",{parentName:"li"},"pgBadger")),(0,r.kt)("li",{parentName:"ul"},"Ad-hoc analyzing using ",(0,r.kt)("inlineCode",{parentName:"li"},"grep"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"awk"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"sed"),", etc."))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"External tracing/profiling tools"),": ",(0,r.kt)("inlineCode",{parentName:"li"},"gdb"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"strace"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"perf-tools"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"ebpf"),", core dumps"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Troubleshooting methods"),": USE, RED, Golden signals"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Links"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"http://www.brendangregg.com/linuxperf.html"}),"Linux Performance")," by Brendan Gregg"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"http://www.brendangregg.com/usemethod.html"}),"USE Method"))))),(0,r.kt)("h2",null,"Learn SQL optimization technics"),(0,r.kt)("p",null,"Get understanding and practical skills of how to optimize SQL queries."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Indexes, and their use cases"),": B-tree, Hash, GiST, SP-GiST, GIN, BRIN"),(0,r.kt)("li",{parentName:"ul"},"SQL queries patterns and anti-patterns"),(0,r.kt)("li",{parentName:"ul"},"SQL schema design patterns and anti-patterns"),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Links"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://use-the-index-luke.com/"}),"Use the Index, Luke")," - a Guide to Database Performance for Developers"))),(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Books"),":",(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"SQL Antipatterns: Avoiding the Pitfalls of Database Programming - Bill Karwin, 2010 ")))),(0,r.kt)("h2",null,"Develop architect skills"),(0,r.kt)("p",null,"Get deeper understanding of Postgres use cases and where Postgres is suitable and where is not."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},(0,r.kt)("strong",{parentName:"li"},"Postgres forks and extensions"),": ",(0,r.kt)("inlineCode",{parentName:"li"},"Greenplum"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Timescaledb"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Citus"),", ",(0,r.kt)("inlineCode",{parentName:"li"},"Postgres-XL"),", etc."),(0,r.kt)("li",{parentName:"ul"},"RDBMS in general, benefits and limitations"),(0,r.kt)("li",{parentName:"ul"},"Differences between Postgres and other RDBMS and NoSQL databases")),(0,r.kt)("h2",null,"Develop Postgres hacker skills"),(0,r.kt)("p",null,"Get involved to Postgres community and contribute to Postgres; be a useful member of Postgres, and the open source community; use personal experience to help other people."),(0,r.kt)("ul",null,(0,r.kt)("li",{parentName:"ul"},"Daily reading and answering in ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://www.postgresql.org/list/"}),"mailing lists"),(0,r.kt)("ul",{parentName:"li"},(0,r.kt)("li",{parentName:"ul"},"pgsql-general"),(0,r.kt)("li",{parentName:"ul"},"pgsql-admin"),(0,r.kt)("li",{parentName:"ul"},"pgsql-performance"),(0,r.kt)("li",{parentName:"ul"},"pgsql-hackers"),(0,r.kt)("li",{parentName:"ul"},"pgsql-bugs"))),(0,r.kt)("li",{parentName:"ul"},"Reviewing patches"),(0,r.kt)("li",{parentName:"ul"},"Writing patches, attending in ",(0,r.kt)("a",Object.assign({parentName:"li"},{href:"https://commitfest.postgresql.org/"}),"Commitfests"))),(0,r.kt)("br",null),(0,r.kt)("br",null),(0,r.kt)("br",null))}s.isMDXComponent=!0},165:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"We are still preparing the resources"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the list, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")))}s.isMDXComponent=!0},2014:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"Roadmap is not ready yet"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the roadmap, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")," "))}s.isMDXComponent=!0},3737:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"We are still preparing the resources"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the list, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")))}s.isMDXComponent=!0},611:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"Roadmap is not ready yet"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the roadmap, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")," "))}s.isMDXComponent=!0},4541:function(e,t,n){"use strict";n.r(t),n.d(t,{default:function(){return s}});n(7294);var r=n(4137);function o(e,t){if(null==e)return{};var n,r,o=function(e,t){if(null==e)return{};var n,r,o={},a=Object.keys(e);for(r=0;r=0||(o[n]=e[n]);return o}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(r=0;r=0||Object.prototype.propertyIsEnumerable.call(e,n)&&(o[n]=e[n])}return o}var a={};function s(e){var t=e.components,n=o(e,["components"]);return(0,r.kt)("wrapper",Object.assign({},a,n,{components:t,mdxType:"MDXLayout"}),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},(0,r.kt)("strong",{parentName:"p"},"We are still preparing the resources"),". Please check back later or ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"subscribe to get notified"),".")),(0,r.kt)("p",null,"While we prepare the list, follow this simple advice to learn anything"),(0,r.kt)("blockquote",null,(0,r.kt)("p",{parentName:"blockquote"},"Just ",(0,r.kt)("strong",{parentName:"p"},"pick a project and start working on it"),", you will learn all that you need along the way.")),(0,r.kt)("p",null,(0,r.kt)("strong",{parentName:"p"},"\u2192")," ","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/roadmaps"}),"All Roadmaps")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/guides"}),"Programming guides")," ","\xa0","\u2022","\xa0"," ",(0,r.kt)("a",Object.assign({parentName:"p"},{href:"/signup"}),"Subscribe")))}s.isMDXComponent=!0},8712:function(e){"use strict";e.exports=JSON.parse('[{"username":"kamranahmedse","name":"Kamran Ahmed","twitter":"kamranahmedse","picture":"/authors/kamranahmedse.jpeg","bio":"Lead engineer at Tajawal. Lover of all things web and opensource. Created roadmap.sh to help the confused ones."},{"username":"jesse","name":"Jesse Li","twitter":"__jesse_li","picture":"/authors/jesse.png","bio":"Software engineer."},{"username":"dmytrobol","name":"Dmytro Bolkachov","twitter":"dmytrobol","picture":"/authors/dmytrobol.png","bio":"JavaScript Lad, Movie buff and coder interested in everything web related"},{"username":"spekulatius","name":"Peter Thaleikis","twitter":"spekulatius1984","picture":"/authors/spekulatius.jpg","bio":"Developer building side-projects for fun, lover of the web and open source"},{"username":"ebrahimbharmal007","name":"Ebrahim Bharmal","twitter":"BharmalEbrahim","picture":"/authors/ebrahimbharmal007.png","bio":"Love building projects using tools completely new to me. Python forever. Senior at University of Texas at Arlington (2021)"},{"username":"lesovsky","name":"Alexey Lesovsky","bio":"Linux system administrator and PostgreSQL DBA at DataEgret.","picture":"/authors/lesovsky.jpeg"}]')},9552:function(e){"use strict";e.exports=JSON.parse('[{"id":"avoid-render-blocking-javascript-with-async-defer","title":"Async and Defer Script Loading","description":"Learn how to avoid render blocking JavaScript using async and defer scripts.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-09-10T19:59:14.191Z","createdAt":"2021-09-10T19:59:14.191Z"},{"id":"what-are-web-vitals","title":"What are Web Vitals?","description":"Learn what are the core web vitals and how to measure them.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-09-05T19:59:14.191Z","createdAt":"2021-09-05T19:59:14.191Z"},{"id":"what-is-sli-slo-sla","title":"SLIs, SLOs and SLAs","description":"Learn what are different indicators for performance identification of any service.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-08-31T19:59:14.191Z","createdAt":"2021-08-31T19:59:14.191Z"},{"id":"ci-cd","title":"What is CI and CD?","description":"Learn the basics of CI/CD and how to implement that with GitHub Actions.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-07-09T19:59:14.191Z","createdAt":"2021-07-09T19:59:14.191Z"},{"id":"sso","title":"SSO \u2014 Single Sign On","description":"Learn the basics of SAML and understand how does Single Sign On work.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-07-01T19:59:14.191Z","createdAt":"2021-07-01T19:59:14.191Z"},{"id":"oauth","title":"OAuth \u2014 Open Authorization","description":"Learn and understand what is OAuth and how it works","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-06-28T19:59:14.191Z","createdAt":"2021-06-28T19:59:14.191Z"},{"id":"jwt-authentication","title":"JWT Authentication","description":"Understand what is JWT authentication and how is it implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-06-20T19:59:14.191Z","createdAt":"2021-06-20T19:59:14.191Z"},{"id":"token-authentication","title":"Token Based Authentication","description":"Understand what is token based authentication and how it is implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-06-02T20:59:14.191Z","createdAt":"2021-06-02T20:59:14.191Z"},{"id":"session-authentication","title":"Session Based Authentication","description":"Understand what is session based authentication and how it is implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-26T20:59:14.191Z","createdAt":"2021-05-26T20:59:14.191Z"},{"id":"basic-authentication","title":"Basic Authentication","description":"Understand what is basic authentication and how it is implemented","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-19T20:59:14.191Z","createdAt":"2021-05-19T20:59:14.191Z"},{"id":"character-encodings","title":"Character Encodings","description":"Covers the basics of character encodings and explains ASCII vs Unicode","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-14T20:59:14.191Z","createdAt":"2021-05-14T20:59:14.191Z"},{"id":"unfamiliar-codebase","title":"Unfamiliar Codebase","description":"Tips on getting getting familiar with an unfamiliar codebase","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-05-04T20:59:14.191Z","createdAt":"2021-05-04T20:59:14.191Z"},{"id":"why-build-it-and-they-will-come-wont-work-anymore","title":"Build it and they will come?","description":"Why \u201cbuild it and they will come\u201d alone won\u2019t work anymore","isPro":false,"authorUsername":"spekulatius","updatedAt":"2021-05-04T12:59:14.191Z","createdAt":"2021-05-04T12:59:14.191Z"},{"id":"dhcp-in-one-picture","title":"DHCP in One Picture","description":"Here is what happens when a new device joins the network.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-04-28T15:48:21.191Z","createdAt":"2021-04-28T15:48:21.191Z"},{"id":"ssl-tls-https-ssh","title":"SSL vs TLS vs SSH","description":"Quick tidbit on the differences between SSL, TLS, HTTPS and SSH","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-04-22T15:48:21.191Z","createdAt":"2021-04-22T15:48:21.191Z"},{"id":"asymptotic-notation","title":"Asymptotic Notation","description":"Learn the basics of measuring the time and space complexity of algorithms","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-04-03T15:48:21.191Z","createdAt":"2021-04-03T15:48:21.191Z"},{"id":"big-o-notation","title":"Big-O Notation","description":"Easy to understand explanation of Big-O notation without any fancy terms","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-03-15T15:48:21.191Z","createdAt":"2021-03-15T15:48:21.191Z"},{"id":"random-numbers","title":"Random Numbers: Are they?","description":"Learn how they are generated and why they may not be truly random.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-03-14T15:48:21.191Z","createdAt":"2021-03-14T15:48:21.191Z"},{"id":"scaling-databases","title":"Scaling Databases","description":"Learn the ups and downs of different database scaling strategies","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2021-02-18T15:48:21.191Z","createdAt":"2021-02-18T15:48:21.191Z"},{"id":"what-is-internet","title":"How does the internet work?","description":"Learn the basics of internet and everything involved with this short video series","isPro":false,"authorUsername":"dmytrobol","updatedAt":"2021-02-29T15:48:21.191Z","createdAt":"2021-02-29T15:48:21.191Z"},{"id":"torrent-client","title":"Building a BitTorrent Client","description":"Learn everything you need to know about BitTorrent by writing a client in Go","isPro":false,"authorUsername":"jesse","updatedAt":"2021-01-17T15:48:21.191Z","createdAt":"2021-01-17T15:48:21.191Z","canonical":"https://blog.jse.li/posts/torrent/"},{"id":"levels-of-seniority","title":"Levels of Seniority","description":"How to Step Up as a Junior, Mid Level or a Senior Developer?","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2020-12-03T12:13:00.860Z","createdAt":"2020-12-03T12:13:00.860Z"},{"id":"design-patterns-for-humans","title":"Design Patterns for Humans","description":"A language agnostic, ultra-simplified explanation to design patterns","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2019-10-09T12:00:00.860Z","createdAt":"2019-01-23T17:00:00.860Z"},{"id":"journey-to-http2","title":"Journey to HTTP/2","description":"The evolution of HTTP. How it all started and where we stand today","isPro":false,"authorUsername":"kamranahmedse","createdAt":"2018-12-04T12:00:00.860Z","updatedAt":"2018-12-04T12:00:00.860Z","isDraft":true},{"id":"dns-in-one-picture","title":"DNS in One Picture","description":"Quick illustrative guide on how a website is found on the internet.","isPro":false,"authorUsername":"kamranahmedse","updatedAt":"2018-12-04T12:00:00.860Z","createdAt":"2018-12-04T17:00:00.860Z"},{"id":"http-caching","title":"HTTP Caching","description":"Everything you need to know about web caching","isPro":false,"authorUsername":"kamranahmedse","createdAt":"2018-11-29T17:00:00.860Z","updatedAt":"2018-11-29T17:00:00.860Z"},{"id":"history-of-javascript","title":"Brief History of JavaScript","description":"How JavaScript was introduced and evolved over the years","isPro":false,"authorUsername":"kamranahmedse","createdAt":"2017-10-28T17:00:00.860Z","updatedAt":"2017-10-28T17:00:00.860Z"},{"id":"proxy-servers","title":"Proxy Servers","description":"How do proxy servers work and what are forward and reverse proxies?","isPro":false,"authorUsername":"ebrahimbharmal007","createdAt":"2017-10-24T17:00:00.860Z","updatedAt":"2017-10-24T17:00:00.860Z"}]')},1662:function(e){"use strict";e.exports=JSON.parse('[{"seo":{"title":"Learn to become a modern frontend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern frontend development. Learn to become a modern frontend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a frontend developer","frontend developer","frontend engineer","frontend skills","frontend development","javascript developer","frontend development skills","frontend development skills test","frontend engineer roadmap","frontend developer roadmap","become a frontend developer","frontend developer career path","javascript developer","modern javascript developer","node developer","skills for frontend development","learn frontend development","what is frontend development","frontend developer quiz","frontend developer interview questions"]},"title":"Frontend Developer","description":"Step by step guide to becoming a modern frontend developer in 2021","featuredTitle":"Frontend","featuredDescription":"Step by step guide to becoming a frontend developer in 2021","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"featured":true,"imagePath":"/roadmaps/frontend.png","resourcesPath":"/roadmaps/100-frontend/resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/frontend-roadmap","id":"frontend","metaPath":"/roadmaps/100-frontend/meta.json","isUpcoming":false},{"seo":{"title":"Learn to become a modern backend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern backend development. Learn to become a modern backend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a backend developer","backend developer","backend engineer","backend skills","backend development","javascript developer","backend development skills","backend development skills test","backend engineer roadmap","backend developer roadmap","become a backend developer","backend developer career path","javascript developer","modern javascript developer","node developer","skills for backend development","learn backend development","what is backend development","backend developer quiz","backend developer interview questions"]},"title":"Backend Developer","description":"Step by step guide to becoming a modern backend developer in 2021","featuredTitle":"Backend","featuredDescription":"Step by step guide to becoming a backend developer in 2021","featured":true,"imagePath":"/roadmaps/backend.png","resourcesPath":"/roadmaps/101-backend/resources.md","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/backend-roadmap","id":"backend","metaPath":"/roadmaps/101-backend/meta.json","isUpcoming":false},{"seo":{"title":"DevOps Roadmap: Learn to become a DevOps Engineer or SRE","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a devops enginer","devops roadmap","sre roadmap","site reliability engineer roadmap","operations roles","become devops","devops skills","modern devops skills","devops skills test","skills for devops","learn devops","what is devops","what is sre","devops quiz","devops interview questions"]},"title":"DevOps Roadmap","description":"Step by step guide for DevOps, SRE or any other Operations Role in 2021","featuredTitle":"DevOps","featuredDescription":"Step by step guide for DevOps or operations role in 2021","featured":true,"imagePath":"/roadmaps/devops.png","resourcesPath":"/roadmaps/102-devops/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/devops-roadmap","id":"devops","metaPath":"/roadmaps/102-devops/meta.json","isUpcoming":false},{"seo":{"title":"React Developer Roadmap: Learn to become a React developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a react developer","react developer roadmap","react roadmap","become react developer","react developer skills","react skills test","skills for react development","learn react development","what is react","react quiz","react interview questions"]},"title":"React Developer","description":"Everything that is there to learn about React and the ecosystem in 2021.","featuredTitle":"React","featuredDescription":"Step by step guide to become a React Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/103-react/landscape.md","resourcesPath":"/roadmaps/103-react/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/react-roadmap","id":"react","metaPath":"/roadmaps/103-react/meta.json","isUpcoming":false},{"seo":{"title":"Angular Developer Roadmap: Learn to become a Angular developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for angular development. Learn to become a modern Angular developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a angular developer","angular developer roadmap","angular roadmap","become angular developer","angular developer skills","angular skills test","skills for angular development","learn angular development","what is angular","angular quiz","angular interview questions"]},"title":"Angular Developer","description":"Everything that is there to learn about Angular and the ecosystem in 2021.","featuredTitle":"Angular","featuredDescription":"Step by step guide to become a Angular Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/104-angular/landscape.md","resourcesPath":"/roadmaps/104-angular/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/angular-roadmap","id":"angular","metaPath":"/roadmaps/104-angular/meta.json","isUpcoming":false},{"seo":{"title":"Android Developer Roadmap: Learn to become an Android developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for android development. Learn to become a modern Android developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an android developer","android developer roadmap","android roadmap","become android developer","android developer skills","android skills test","skills for android development","learn android development","what is android","android quiz","android interview questions"]},"title":"Android Developer","description":"Step by step guide to becoming an Android developer in 2021","featuredTitle":"Android","featuredDescription":"Step by step guide to becoming an Android Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"contentPath":"/roadmaps/105-android/landscape.md","resourcesPath":"/roadmaps/105-android/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"android","metaPath":"/roadmaps/105-android/meta.json","isUpcoming":false},{"seo":{"title":"Learn to become a modern Python developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for python development. Learn to become a modern Python developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an python developer","python developer roadmap","python roadmap","become python developer","python developer skills","python skills test","skills for python development","learn python development","what is python","python quiz","python interview questions"]},"title":"Python Developer","description":"Step by step guide to becoming a Python developer in 2021","featuredTitle":"Python","featuredDescription":"Step by step guide to becoming a Python Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"resourcesPath":"/roadmaps/106-python/resources.md","contentPath":"/roadmaps/106-python/landscape.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/python-roadmap","versions":["latest"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"python","metaPath":"/roadmaps/106-python/meta.json","isUpcoming":false},{"seo":{"title":"Learn to become a Go developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a golang developer","guide to becoming a go developer","golang developer","go developer","guide to golang","guide to go","golang roadmap","go roadmap","golang skills","go skills","golang skills test","go skills test","skills for golang","skills for go","cloud development","what is golang","what is go","golang quiz","go quiz","golang interview questions","go interview questions"]},"title":"Go Developer","description":"Step by step guide to becoming a Go developer in 2021","featuredTitle":"Go","featuredDescription":"Step by step guide to becoming a Go developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"/roadmaps/107-golang/landscape.md","resourcesPath":"/roadmaps/107-golang/resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/go-roadmap","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"golang","metaPath":"/roadmaps/107-golang/meta.json"},{"seo":{"title":"Learn to become a modern Java developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a java developer","java developer","java engineer","java skills","guide to java","java roadmap","java skills","java skills test","skills for java","cloud development","what is java","java quiz","java interview questions","java engineer roadmap","java developer roadmap","become a java developer","java developer career path","java developer","modern java developer"]},"title":"Java Developer","description":"Step by step guide to becoming a Java developer in 2021","featuredTitle":"Java","featuredDescription":"Step by step guide to becoming a Java Developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"/roadmaps/108-java/landscape.md","resourcesPath":"/roadmaps/108-java/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/java-roadmap","id":"java","metaPath":"/roadmaps/108-java/meta.json"},{"seo":{"title":"DBA Roadmap: Learn to become a database administrator with PostgreSQL","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a database administrator","guide to becoming a DBA","dba roadmap","db administrator roadmap","database administrator roadmap","postgresql roadmap","dba skills","db administrator skills","become dba","postgresql skills","modern dba skills","dba skills test","skills for dba","skills for database administrator","learn dba","what is dba","database administrator quiz","dba interview questions"]},"title":"PostgreSQL DBA","description":"Step by step guide to becoming a modern PostgreSQL DB Administrator in 2021","featuredTitle":"DBA","featuredDescription":"Step by step guide to become a PostgreSQL DBA in 2021","contentPath":"/roadmaps/109-postgresql-dba/landscape.md","resourcesPath":"/roadmaps/109-postgresql-dba/resources.md","author":{"name":"Alexey Lesovsky","url":"https://github.com/lesovsky"},"isCommunity":false,"isTextHeavy":true,"featured":true,"detailed":false,"versions":[],"id":"postgresql-dba","metaPath":"/roadmaps/109-postgresql-dba/meta.json","isUpcoming":false},{"seo":{"title":"AWS Roadmap: Learn to use AWS","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to aws","aws roadmap","aws skills","aws skills test","skills for aws","cloud development","what is aws","aws quiz","aws interview questions"]},"title":"AWS","description":"Everything that is there to learn about AWS and the ecosystem in 2021.","featuredTitle":"AWS","featuredDescription":"Step by step guide to learn AWS in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":true,"featured":true,"contentPath":"/roadmaps/110-aws/landscape.md","resourcesPath":"/roadmaps/110-aws/resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"id":"aws","metaPath":"/roadmaps/110-aws/meta.json"},{"seo":{"title":"QA Roadmap: Learn to become a modern QA engineer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern QA development. Learn to become a modern QA engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a QA engineer","QA engineer","QA skills","QA development skills","QA development skills test","QA engineer roadmap","become a QA engineer","QA engineer career path","skills for QA development","what is QA engineer","QA engineer quiz","QA engineer interview questions"]},"title":"QA Engineer","description":"Steps to follow in order to become a modern QA Engineer in 2021","featuredTitle":"QA","featuredDescription":"Step by step guide to becoming a modern QA Engineer in 2021","isUpcoming":true,"featured":true,"contentPath":"/roadmaps/111-qa/landscape.md","resourcesPath":"/roadmaps/111-qa/resources.md","author":{"name":"Anas Fitiani","url":"https://github.com/anas-qa"},"id":"qa","metaPath":"/roadmaps/111-qa/meta.json"}]')},8359:function(e){"use strict";e.exports=JSON.parse('{"home":"/100-frontend/content/readme.md","internet":"/100-frontend/content/100-internet/readme.md","internet:how-does-the-internet-work":"/100-frontend/content/100-internet/100-how-does-the-internet-work.md","internet:what-is-http":"/100-frontend/content/100-internet/101-what-is-http.md","internet:browsers-and-how-they-work":"/100-frontend/content/100-internet/102-browsers-and-how-they-work.md","internet:dns-and-how-it-works":"/100-frontend/content/100-internet/103-dns-and-how-it-works.md","internet:what-is-domain-name":"/100-frontend/content/100-internet/104-what-is-domain-name.md","internet:what-is-hosting":"/100-frontend/content/100-internet/105-what-is-hosting.md","html":"/100-frontend/content/101-html/readme.md","html:learn-the-basics":"/100-frontend/content/101-html/100-learn-the-basics.md","html:writing-semantic-html":"/100-frontend/content/101-html/101-writing-semantic-html.md","html:forms-and-validations":"/100-frontend/content/101-html/102-forms-and-validations.md","html:conventions-and-best-practices":"/100-frontend/content/101-html/103-conventions-and-best-practices.md","html:accessibility":"/100-frontend/content/101-html/104-accessibility.md","html:seo-basics":"/100-frontend/content/101-html/105-seo-basics.md","css":"/100-frontend/content/102-css/readme.md","css:learn-the-basics":"/100-frontend/content/102-css/100-learn-the-basics.md","css:making-layouts":"/100-frontend/content/102-css/101-making-layouts.md","css:responsive-design-and-media-queries":"/100-frontend/content/102-css/102-responsive-design-and-media-queries.md","javascript":"/100-frontend/content/103-javascript/readme.md","javascript:syntax-and-basic-constructs":"/100-frontend/content/103-javascript/100-syntax-and-basic-constructs.md","javascript:learn-dom-manipulation":"/100-frontend/content/103-javascript/101-learn-dom-manipulation.md","javascript:learn-fetch-api-ajax-xhr":"/100-frontend/content/103-javascript/102-learn-fetch-api-ajax-xhr.md","javascript:es6-and-modular-javascript":"/100-frontend/content/103-javascript/103-es6-and-modular-javascript.md","javascript:concepts":"/100-frontend/content/103-javascript/104-concepts.md","version-control-systems":"/100-frontend/content/104-version-control-systems/readme.md","version-control-systems:basic-usage-of-git":"/100-frontend/content/104-version-control-systems/100-basic-usage-of-git.md","repo-hosting-services":"/100-frontend/content/105-repo-hosting-services/readme.md","repo-hosting-services:github":"/100-frontend/content/105-repo-hosting-services/100-github.md","repo-hosting-services:gitlab":"/100-frontend/content/105-repo-hosting-services/101-gitlab.md","repo-hosting-services:bitbucket":"/100-frontend/content/105-repo-hosting-services/102-bitbucket.md","web-security-knowledge":"/100-frontend/content/106-web-security-knowledge/readme.md","web-security-knowledge:cors":"/100-frontend/content/106-web-security-knowledge/102-cors.md","web-security-knowledge:https":"/100-frontend/content/106-web-security-knowledge/100-https.md","web-security-knowledge:content-security-policy":"/100-frontend/content/106-web-security-knowledge/101-content-security-policy.md","web-security-knowledge:owasp-security-risks":"/100-frontend/content/106-web-security-knowledge/103-owasp-security-risks.md","package-managers":"/100-frontend/content/107-package-managers/readme.md","package-managers:npm":"/100-frontend/content/107-package-managers/100-npm.md","package-managers:yarn":"/100-frontend/content/107-package-managers/101-yarn.md","css-architecture":"/100-frontend/content/108-css-architecture/readme.md","css-architecture:bem":"/100-frontend/content/108-css-architecture/100-bem.md","css-architecture:oocss":"/100-frontend/content/108-css-architecture/101-oocss.md","css-architecture:smacss":"/100-frontend/content/108-css-architecture/102-smacss.md","css-preprocessors":"/100-frontend/content/109-css-preprocessors/readme.md","css-preprocessors:sass":"/100-frontend/content/109-css-preprocessors/100-sass.md","css-preprocessors:postcss":"/100-frontend/content/109-css-preprocessors/101-postcss.md","css-preprocessors:less":"/100-frontend/content/109-css-preprocessors/102-less.md","build-tools":"/100-frontend/content/110-build-tools/readme.md","build-tools:task-runners":"/100-frontend/content/110-build-tools/100-task-runners/readme.md","build-tools:100-task-runners/npm-scripts":"/100-frontend/content/110-build-tools/100-task-runners/npm-scripts.md","build-tools:linters-formatters":"/100-frontend/content/110-build-tools/102-linters-formatters/readme.md","build-tools:102-linters-formatters/prettier":"/100-frontend/content/110-build-tools/102-linters-formatters/prettier.md","build-tools:102-linters-formatters/eslint":"/100-frontend/content/110-build-tools/102-linters-formatters/eslint.md","build-tools:102-linters-formatters/standardjs":"/100-frontend/content/110-build-tools/102-linters-formatters/standardjs.md","build-tools:module-bundlers":"/100-frontend/content/110-build-tools/101-module-bundlers/readme.md","build-tools:101-module-bundlers/webpack":"/100-frontend/content/110-build-tools/101-module-bundlers/webpack.md","build-tools:101-module-bundlers/esbuild":"/100-frontend/content/110-build-tools/101-module-bundlers/esbuild.md","build-tools:101-module-bundlers/rollup":"/100-frontend/content/110-build-tools/101-module-bundlers/rollup.md","build-tools:101-module-bundlers/parcel":"/100-frontend/content/110-build-tools/101-module-bundlers/parcel.md","build-tools:101-module-bundlers/vite":"/100-frontend/content/110-build-tools/101-module-bundlers/vite.md","pick-a-framework":"/100-frontend/content/111-pick-a-framework/readme.md","pick-a-framework:react-js":"/100-frontend/content/111-pick-a-framework/100-react-js/readme.md","pick-a-framework:100-react-js/recoil":"/100-frontend/content/111-pick-a-framework/100-react-js/recoil.md","pick-a-framework:100-react-js/redux":"/100-frontend/content/111-pick-a-framework/100-react-js/redux.md","pick-a-framework:100-react-js/mobx":"/100-frontend/content/111-pick-a-framework/100-react-js/mobx.md","pick-a-framework:angular":"/100-frontend/content/111-pick-a-framework/101-angular/readme.md","pick-a-framework:101-angular/rxjs":"/100-frontend/content/111-pick-a-framework/101-angular/rxjs.md","pick-a-framework:101-angular/ngrx":"/100-frontend/content/111-pick-a-framework/101-angular/ngrx.md","pick-a-framework:vue-js":"/100-frontend/content/111-pick-a-framework/102-vue-js/readme.md","pick-a-framework:102-vue-js/vuex":"/100-frontend/content/111-pick-a-framework/102-vue-js/vuex.md","modern-css":"/100-frontend/content/112-modern-css/readme.md","modern-css:styled-components":"/100-frontend/content/112-modern-css/100-styled-components.md","modern-css:css-modules":"/100-frontend/content/112-modern-css/101-css-modules.md","modern-css:styled-jsx":"/100-frontend/content/112-modern-css/102-styled-jsx.md","modern-css:emotion":"/100-frontend/content/112-modern-css/103-emotion.md","web-components":"/100-frontend/content/113-web-components/readme.md","web-components:html-templates":"/100-frontend/content/113-web-components/100-html-templates.md","web-components:custom-elements":"/100-frontend/content/113-web-components/101-custom-elements.md","web-components:shadow-dom":"/100-frontend/content/113-web-components/102-shadow-dom.md","css-frameworks":"/100-frontend/content/114-css-frameworks/readme.md","css-frameworks:js-first":"/100-frontend/content/114-css-frameworks/114-js-first/readme.md","css-frameworks:114-js-first/chakra-ui":"/100-frontend/content/114-css-frameworks/114-js-first/chakra-ui.md","css-frameworks:114-js-first/material-ui":"/100-frontend/content/114-css-frameworks/114-js-first/material-ui.md","css-frameworks:114-js-first/radix-ui":"/100-frontend/content/114-css-frameworks/114-js-first/radix-ui.md","css-frameworks:114-js-first/tailwind-css":"/100-frontend/content/114-css-frameworks/114-js-first/tailwind-css.md","css-frameworks:css-first":"/100-frontend/content/114-css-frameworks/114-css-first/readme.md","css-frameworks:114-css-first/bootstrap":"/100-frontend/content/114-css-frameworks/114-css-first/bootstrap.md","css-frameworks:114-css-first/bulma":"/100-frontend/content/114-css-frameworks/114-css-first/bulma.md","testing-your-apps":"/100-frontend/content/115-testing-your-apps/readme.md","testing-your-apps:jest":"/100-frontend/content/115-testing-your-apps/100-jest.md","testing-your-apps:react-testing-library":"/100-frontend/content/115-testing-your-apps/101-react-testing-library.md","testing-your-apps:cypress":"/100-frontend/content/115-testing-your-apps/102-cypress.md","testing-your-apps:enzyme":"/100-frontend/content/115-testing-your-apps/103-enzyme.md","testing-your-apps:other-options":"/100-frontend/content/115-testing-your-apps/104-other-options.md","type-checkers":"/100-frontend/content/116-type-checkers/readme.md","type-checkers:typescript":"/100-frontend/content/116-type-checkers/100-typescript.md","type-checkers:flow":"/100-frontend/content/116-type-checkers/101-flow.md","progressive-web-apps":"/100-frontend/content/117-progressive-web-apps/readme.md","progressive-web-apps:performance":"/100-frontend/content/117-progressive-web-apps/101-performance.md","progressive-web-apps:apis":"/100-frontend/content/117-progressive-web-apps/100-apis.md","server-side-rendering":"/100-frontend/content/118-server-side-rendering/readme.md","server-side-rendering:react-js":"/100-frontend/content/118-server-side-rendering/100-react-js/readme.md","server-side-rendering:100-react-js/next-js":"/100-frontend/content/118-server-side-rendering/100-react-js/next-js.md","server-side-rendering:100-react-js/after-js":"/100-frontend/content/118-server-side-rendering/100-react-js/after-js.md","server-side-rendering:angular":"/100-frontend/content/118-server-side-rendering/101-angular/readme.md","server-side-rendering:101-angular/universal":"/100-frontend/content/118-server-side-rendering/101-angular/universal.md","server-side-rendering:vue-js":"/100-frontend/content/118-server-side-rendering/102-vue-js/readme.md","server-side-rendering:102-vue-js/nuxt-js":"/100-frontend/content/118-server-side-rendering/102-vue-js/nuxt-js.md","graphql":"/100-frontend/content/119-graphql/readme.md","graphql:apollo":"/100-frontend/content/119-graphql/100-apollo.md","graphql:relay-modern":"/100-frontend/content/119-graphql/101-relay-modern.md","static-site-generators":"/100-frontend/content/120-static-site-generators/readme.md","static-site-generators:next-js":"/100-frontend/content/120-static-site-generators/100-next-js.md","static-site-generators:gatsbyjs":"/100-frontend/content/120-static-site-generators/101-gatsbyjs.md","static-site-generators:nuxt-js":"/100-frontend/content/120-static-site-generators/102-nuxt-js.md","static-site-generators:vuepress":"/100-frontend/content/120-static-site-generators/103-vuepress.md","static-site-generators:jekyll":"/100-frontend/content/120-static-site-generators/104-jekyll.md","static-site-generators:hugo":"/100-frontend/content/120-static-site-generators/105-hugo.md","static-site-generators:gridsome":"/100-frontend/content/120-static-site-generators/106-gridsome.md","static-site-generators:eleventy":"/100-frontend/content/120-static-site-generators/107-eleventy.md","mobile-applications":"/100-frontend/content/121-mobile-applications/readme.md","mobile-applications:react-native":"/100-frontend/content/121-mobile-applications/100-react-native.md","mobile-applications:nativescript":"/100-frontend/content/121-mobile-applications/101-nativescript.md","mobile-applications:flutter":"/100-frontend/content/121-mobile-applications/102-flutter.md","mobile-applications:ionic":"/100-frontend/content/121-mobile-applications/103-ionic.md","desktop-applications":"/100-frontend/content/122-desktop-applications/readme.md","desktop-applications:electron":"/100-frontend/content/122-desktop-applications/100-electron.md","desktop-applications:carlo":"/100-frontend/content/122-desktop-applications/101-carlo.md","desktop-applications:proton-native":"/100-frontend/content/122-desktop-applications/102-proton-native.md","web-assembly":"/100-frontend/content/123-web-assembly.md"}')},9258:function(e){"use strict";e.exports=JSON.parse('{"seo":{"title":"Learn to become a modern frontend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern frontend development. Learn to become a modern frontend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a frontend developer","frontend developer","frontend engineer","frontend skills","frontend development","javascript developer","frontend development skills","frontend development skills test","frontend engineer roadmap","frontend developer roadmap","become a frontend developer","frontend developer career path","javascript developer","modern javascript developer","node developer","skills for frontend development","learn frontend development","what is frontend development","frontend developer quiz","frontend developer interview questions"]},"title":"Frontend Developer","description":"Step by step guide to becoming a modern frontend developer in 2021","featuredTitle":"Frontend","featuredDescription":"Step by step guide to becoming a frontend developer in 2021","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"featured":true,"imagePath":"/roadmaps/frontend.png","resourcesPath":"./resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/frontend-roadmap"}')},6782:function(e){"use strict";e.exports=JSON.parse('{"seo":{"title":"Learn to become a modern backend developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern backend development. Learn to become a modern backend developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a backend developer","backend developer","backend engineer","backend skills","backend development","javascript developer","backend development skills","backend development skills test","backend engineer roadmap","backend developer roadmap","become a backend developer","backend developer career path","javascript developer","modern javascript developer","node developer","skills for backend development","learn backend development","what is backend development","backend developer quiz","backend developer interview questions"]},"title":"Backend Developer","description":"Step by step guide to becoming a modern backend developer in 2021","featuredTitle":"Backend","featuredDescription":"Step by step guide to becoming a backend developer in 2021","featured":true,"imagePath":"/roadmaps/backend.png","resourcesPath":"./resources.md","author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/backend-roadmap"}')},4017:function(e){"use strict";e.exports=JSON.parse('{"seo":{"title":"DevOps Roadmap: Learn to become a DevOps Engineer or SRE","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a devops enginer","devops roadmap","sre roadmap","site reliability engineer roadmap","operations roles","become devops","devops skills","modern devops skills","devops skills test","skills for devops","learn devops","what is devops","what is sre","devops quiz","devops interview questions"]},"title":"DevOps Roadmap","description":"Step by step guide for DevOps, SRE or any other Operations Role in 2021","featuredTitle":"DevOps","featuredDescription":"Step by step guide for DevOps or operations role in 2021","featured":true,"imagePath":"/roadmaps/devops.png","resourcesPath":"./resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/devops-roadmap"}')},8477:function(e){"use strict";e.exports=JSON.parse('{"seo":{"title":"React Developer Roadmap: Learn to become a React developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a react developer","react developer roadmap","react roadmap","become react developer","react developer skills","react skills test","skills for react development","learn react development","what is react","react quiz","react interview questions"]},"title":"React Developer","description":"Everything that is there to learn about React and the ecosystem in 2021.","featuredTitle":"React","featuredDescription":"Step by step guide to become a React Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"./landscape.md","resourcesPath":"./resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/react-roadmap"}')},8834:function(e){"use strict";e.exports=JSON.parse('{"seo":{"title":"Angular Developer Roadmap: Learn to become a Angular developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for angular development. Learn to become a modern Angular developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a angular developer","angular developer roadmap","angular roadmap","become angular developer","angular developer skills","angular skills test","skills for angular development","learn angular development","what is angular","angular quiz","angular interview questions"]},"title":"Angular Developer","description":"Everything that is there to learn about Angular and the ecosystem in 2021.","featuredTitle":"Angular","featuredDescription":"Step by step guide to become a Angular Developer in 2021","isTextHeavy":false,"isCommunity":false,"featured":true,"contentPath":"./landscape.md","resourcesPath":"./resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/angular-roadmap"}')},9508:function(e){"use strict";e.exports=JSON.parse('{"seo":{"title":"Android Developer Roadmap: Learn to become an Android developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for android development. Learn to become a modern Android developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an android developer","android developer roadmap","android roadmap","become android developer","android developer skills","android skills test","skills for android development","learn android development","what is android","android quiz","android interview questions"]},"title":"Android Developer","description":"Step by step guide to becoming an Android developer in 2021","featuredTitle":"Android","featuredDescription":"Step by step guide to becoming an Android Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"contentPath":"./landscape.md","resourcesPath":"./resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"}}')},4099:function(e){"use strict";e.exports=JSON.parse('{"seo":{"title":"Learn to become a modern Python developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for python development. Learn to become a modern Python developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming an python developer","python developer roadmap","python roadmap","become python developer","python developer skills","python skills test","skills for python development","learn python development","what is python","python quiz","python interview questions"]},"title":"Python Developer","description":"Step by step guide to becoming a Python developer in 2021","featuredTitle":"Python","featuredDescription":"Step by step guide to becoming a Python Developer in 2021","isTextHeavy":true,"isCommunity":false,"featured":true,"resourcesPath":"./resources.md","contentPath":"./landscape.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/python-roadmap","versions":["latest"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"}}')},2737:function(e){"use strict";e.exports=JSON.parse('{"seo":{"title":"Learn to become a Go developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a golang developer","guide to becoming a go developer","golang developer","go developer","guide to golang","guide to go","golang roadmap","go roadmap","golang skills","go skills","golang skills test","go skills test","skills for golang","skills for go","cloud development","what is golang","what is go","golang quiz","go quiz","golang interview questions","go interview questions"]},"title":"Go Developer","description":"Step by step guide to becoming a Go developer in 2021","featuredTitle":"Go","featuredDescription":"Step by step guide to becoming a Go developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"./landscape.md","resourcesPath":"./resources.md","pdfUrl":"https://kamranahmedse.gumroad.com/l/go-roadmap","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"}}')},2507:function(e){"use strict";e.exports=JSON.parse('{"seo":{"title":"Learn to become a modern Java developer","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a developer","guide to becoming a java developer","java developer","java engineer","java skills","guide to java","java roadmap","java skills","java skills test","skills for java","cloud development","what is java","java quiz","java interview questions","java engineer roadmap","java developer roadmap","become a java developer","java developer career path","java developer","modern java developer"]},"title":"Java Developer","description":"Step by step guide to becoming a Java developer in 2021","featuredTitle":"Java","featuredDescription":"Step by step guide to becoming a Java Developer in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":false,"featured":true,"contentPath":"./landscape.md","resourcesPath":"./resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"},"pdfUrl":"https://kamranahmedse.gumroad.com/l/java-roadmap"}')},8951:function(e){"use strict";e.exports=JSON.parse('{"seo":{"title":"DBA Roadmap: Learn to become a database administrator with PostgreSQL","description":"Community driven, articles, resources, guides, interview questions, quizzes for DevOps. Learn to become a modern DevOps engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a database administrator","guide to becoming a DBA","dba roadmap","db administrator roadmap","database administrator roadmap","postgresql roadmap","dba skills","db administrator skills","become dba","postgresql skills","modern dba skills","dba skills test","skills for dba","skills for database administrator","learn dba","what is dba","database administrator quiz","dba interview questions"]},"title":"PostgreSQL DBA","description":"Step by step guide to becoming a modern PostgreSQL DB Administrator in 2021","featuredTitle":"DBA","featuredDescription":"Step by step guide to become a PostgreSQL DBA in 2021","contentPath":"./landscape.md","resourcesPath":"./resources.md","author":{"name":"Alexey Lesovsky","url":"https://github.com/lesovsky"},"isCommunity":false,"isTextHeavy":true,"featured":true,"detailed":false,"versions":[]}')},7559:function(e){"use strict";e.exports=JSON.parse('{"seo":{"title":"AWS Roadmap: Learn to use AWS","description":"Community driven, articles, resources, guides, interview questions, quizzes for react development. Learn to become a modern React developer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to aws","aws roadmap","aws skills","aws skills test","skills for aws","cloud development","what is aws","aws quiz","aws interview questions"]},"title":"AWS","description":"Everything that is there to learn about AWS and the ecosystem in 2021.","featuredTitle":"AWS","featuredDescription":"Step by step guide to learn AWS in 2021","isTextHeavy":false,"isCommunity":false,"isUpcoming":true,"featured":true,"contentPath":"./landscape.md","resourcesPath":"./resources.md","versions":["latest","2018","2017"],"author":{"name":"Kamran Ahmed","url":"https://twitter.com/kamranahmedse"}}')},3204:function(e){"use strict";e.exports=JSON.parse('{"seo":{"title":"QA Roadmap: Learn to become a modern QA engineer","description":"Community driven, articles, resources, guides, interview questions, quizzes for modern QA development. Learn to become a modern QA engineer by following the steps, skills, resources and guides listed in this roadmap.","keywords":["guide to becoming a QA engineer","QA engineer","QA skills","QA development skills","QA development skills test","QA engineer roadmap","become a QA engineer","QA engineer career path","skills for QA development","what is QA engineer","QA engineer quiz","QA engineer interview questions"]},"title":"QA Engineer","description":"Steps to follow in order to become a modern QA Engineer in 2021","featuredTitle":"QA","featuredDescription":"Step by step guide to becoming a modern QA Engineer in 2021","isUpcoming":true,"featured":true,"contentPath":"./landscape.md","resourcesPath":"./resources.md","author":{"name":"Anas Fitiani","url":"https://github.com/anas-qa"}}')},1797:function(e){"use strict";e.exports=JSON.parse('[{"id":"what-is-eventual-consistency","title":"What is Eventual Consistency?","description":"Learn about the different consistency models in distributed systems","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=rpqsSkTIdAw","authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2021-11-30T19:59:14.191Z","createdAt":"2021-11-30T19:59:14.191Z"},{"id":"ssh-ssl-tls","title":"SSH vs TLS vs SSL","description":"Learn the difference between SSH, TLS and SSL","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=k3rFFLmQCuY","authorUsername":"kamranahmedse","duration":"3 minutes","updatedAt":"2021-11-25T19:59:14.191Z","createdAt":"2021-11-25T19:59:14.191Z"},{"id":"async-javascript","title":"Asynchronous JavaScript","description":"Learn how to write asynchronous JavaScript using Async/Await","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=VyIK6SV5f7o","authorUsername":"kamranahmedse","duration":"15 minutes","updatedAt":"2021-11-14T19:59:14.191Z","createdAt":"2021-11-14T19:59:14.191Z"},{"id":"random-number-generators","title":"Random Number Generators","description":"How do random number generators work?","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=nDv3yXdD0rk","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-11-03T19:59:14.191Z","createdAt":"2021-11-03T19:59:14.191Z"},{"id":"big-o-notation","title":"Big O Notation","description":"Learn what the Big-O notation is and how to calculate the time complexity of an algorithm.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=Z0bH0cMY0E8","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-10-25T19:59:14.191Z","createdAt":"2021-10-25T19:59:14.191Z"},{"id":"yaml-in-depth","title":"YAML in Depth","description":"Everything you need to know about YAML","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=ImHSpwUlNVc","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-10-18T19:59:14.191Z","createdAt":"2021-10-18T19:59:14.191Z"},{"id":"floating-point-arithmetic","title":"Floating Point Arithmetic","description":"Learn how ow the arithmetic operations work on floating-point numbers and why the results might be different from what you may expect.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=RIiq4tTt6rI","authorUsername":"kamranahmedse","duration":"4 minutes","updatedAt":"2021-10-10T19:59:14.191Z","createdAt":"2021-10-10T19:59:14.191Z"},{"id":"what-is-cap-theorem","title":"What is CAP Theorem?","description":"An illustrated explanation to CAP theorem with examples and proof.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=_RbsFXWRZ10","authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2021-10-05T19:59:14.191Z","createdAt":"2021-10-05T19:59:14.191Z"},{"id":"acid-explained","title":"ACID Explained","description":"Learn what it means for a database to be ACID compliant with examples.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=yaQ5YMWkxq4","authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2021-09-26T19:59:14.191Z","createdAt":"2021-09-26T19:59:14.191Z"},{"id":"transport-protocols-tcp-vs-udp","title":"Transport Protocols: TCP vs UDP","description":"Learn about the Transport Layer of the TCP/IP model and different transport protocols.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=37AFBZv4_6Y","authorUsername":"kamranahmedse","duration":"10 minutes","updatedAt":"2020-11-21T19:59:14.191Z","createdAt":"2020-11-21T19:59:14.191Z"},{"id":"tcp-ip-model","title":"TCP/IP Model Explained","description":"Learn what is TCP/IP Model and the different layers involved.","isPro":false,"authorUsername":"kamranahmedse","youtubeLink":"https://www.youtube.com/watch?v=F5rni9fr1yE","duration":"5 minutes","updatedAt":"2020-11-06T19:59:14.191Z","createdAt":"2020-11-06T19:59:14.191Z"},{"id":"osi-model","title":"OSI Model Explained","description":"Learn what is OSI Model and the different layers involved.","isPro":false,"youtubeLink":"https://www.youtube.com/watch?v=dV8mjZd1OtU","authorUsername":"kamranahmedse","duration":"7 minutes","updatedAt":"2020-10-24T19:59:14.191Z","createdAt":"2020-10-24T19:59:14.191Z"},{"id":"freeze-and-seal-objects-in-javascript","title":"Freeze and Seal in JavaScript","description":"Learn what is OSI Model and the different layers involved.","youtubeLink":"https://www.youtube.com/watch?v=O3uT2l6vgZ8","isPro":false,"authorUsername":"kamranahmedse","duration":"6 minutes","updatedAt":"2020-10-16T19:59:14.191Z","createdAt":"2020-10-16T19:59:14.191Z"},{"id":"all-about-http-caching","title":"All about HTTP Caching","description":"Learn what is HTTP caching, places for caching and different caching headers.","youtubeLink":"https://www.youtube.com/watch?v=HiBDZgTNpXY","isPro":false,"authorUsername":"kamranahmedse","duration":"13 minutes","updatedAt":"2020-10-04T19:59:14.191Z","createdAt":"2020-10-04T19:59:14.191Z"},{"id":"content-delivery-networks","title":"Content Delivery Networks","description":"Learn what the CDNs are and the difference between push CDN vs pull CDN.","youtubeLink":"https://www.youtube.com/watch?v=6DXEPcXKQNY","isPro":false,"authorUsername":"kamranahmedse","duration":"4 minutes","updatedAt":"2020-09-26T19:59:14.191Z","createdAt":"2020-09-26T19:59:14.191Z"},{"id":"load-balancers-101","title":"Load Balancers 101","description":"Learn the basics of load balancers, types and different algorithms.","youtubeLink":"https://www.youtube.com/watch?v=galcDRNd5Ow","isPro":false,"authorUsername":"kamranahmedse","duration":"9 minutes","updatedAt":"2020-09-18T19:59:14.191Z","createdAt":"2020-09-18T19:59:14.191Z"},{"id":"dns-records","title":"DNS Records","description":"Learn what the DNS is and how a website is found on the internet.","youtubeLink":"https://www.youtube.com/watch?v=7lxgpKh_fRY","isPro":false,"authorUsername":"kamranahmedse","duration":"6 minutes","updatedAt":"2020-08-31T19:59:14.191Z","createdAt":"2020-08-31T19:59:14.191Z"},{"id":"dns-explained","title":"DNS and how does it work?","description":"Learn what the DNS is and how a website is found on the internet.","youtubeLink":"https://www.youtube.com/watch?v=Wj0od2ag5sk","isPro":false,"authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2020-08-17T19:59:14.191Z","createdAt":"2020-08-17T19:59:14.191Z"},{"id":"system-design-101","title":"System Design 101","description":"Learn about all the bits and pieces of system design.","youtubeLink":"https://www.youtube.com/watch?v=Y-Gl4HEyeUQ","isPro":false,"authorUsername":"kamranahmedse","duration":"7 minutes","updatedAt":"2020-08-08T19:59:14.191Z","createdAt":"2020-08-08T19:59:14.191Z"},{"id":"javascript-fetch-api","title":"JavaScript Fetch API","description":"Learn how to use JavaScript\'s Fetch API to interact with remote API.","youtubeLink":"https://www.youtube.com/watch?v=-ZI0ea5O2oA","isPro":false,"authorUsername":"kamranahmedse","duration":"3 minutes","updatedAt":"2020-08-02T19:59:14.191Z","createdAt":"2020-08-02T19:59:14.191Z"},{"id":"scaling-the-unscalable","title":"Scaling the Unscalable","description":"Learn the basics of System Design and understand how to build a scalable application.","youtubeLink":"https://www.youtube.com/watch?v=a2rcgzludDU","isPro":false,"authorUsername":"kamranahmedse","duration":"10 minutes","updatedAt":"2020-07-26T19:59:14.191Z","createdAt":"2020-07-26T19:59:14.191Z"},{"id":"promises-in-javascript","title":"All about Promises in JavaScript","youtubeLink":"https://www.youtube.com/watch?v=BvrkobaCVVE","description":"Learn how to write asynchronous code in JavaScript using promises.","isPro":false,"authorUsername":"kamranahmedse","duration":"8 minutes","updatedAt":"2020-07-20T19:59:14.191Z","createdAt":"2020-07-20T19:59:14.191Z"},{"id":"how-to-use-github-actions","title":"Automate with GitHub Actions","description":"Learn how to implement CI/CD with GitHub Actions","youtubeLink":"https://www.youtube.com/watch?v=nyKZTKQS_EQ","isPro":false,"authorUsername":"kamranahmedse","duration":"6 minutes","updatedAt":"2020-07-13T19:59:14.191Z","createdAt":"2020-07-13T19:59:14.191Z"},{"id":"what-is-dependency-injection","title":"What is Dependency Injection?","description":"Learn what is dependency injection and how to write better code with the help of it.","youtubeLink":"https://www.youtube.com/watch?v=0yc2UANSDiw","isPro":false,"authorUsername":"kamranahmedse","duration":"3 minutes","updatedAt":"2020-07-04T19:59:14.191Z","createdAt":"2020-07-04T19:59:14.191Z"},{"id":"how-to-use-css-variables","title":"How to use CSS Variables?","description":"Learn how to write scalable CSS using CSS Variables.","youtubeLink":"https://www.youtube.com/watch?v=lgaxU7CRmxU","isPro":false,"authorUsername":"kamranahmedse","duration":"5 minutes","updatedAt":"2020-07-03T19:59:14.191Z","createdAt":"2020-07-03T19:59:14.191Z"},{"id":"what-is-dom-shadow-dom-virtual-dom","title":"DOM, Shadow DOM, Virtual DOM","description":"Learn what is DOM, Shadow DOM and Virtual DOM and how they work.","youtubeLink":"https://www.youtube.com/watch?v=7Tok22qxPzQ","isPro":false,"authorUsername":"kamranahmedse","duration":"6 minutes","updatedAt":"2020-07-20T19:59:14.191Z","createdAt":"2020-07-20T19:59:14.191Z"},{"id":"practical-intro-to-react","title":"Practical Introduction to React","description":"Learn how to create a React Application with practical example.","youtubeLink":"https://www.youtube.com/watch?v=NyG7YJWJd6s&list=PLkZYeFmDuaN3NDLnBG01-sH2-nwn43mYu","isPro":false,"authorUsername":"kamranahmedse","duration":"40 minutes","updatedAt":"2020-07-09T19:59:14.191Z","createdAt":"2020-07-09T19:59:14.191Z"},{"id":"arrays-and-objects-in-javascript","title":"Arrays and Objects in JavaScript","description":"Learn how to manipulate arrays and objects in JavaScript.","youtubeLink":"https://www.youtube.com/watch?v=n3NKGsM3iEw","isPro":false,"authorUsername":"kamranahmedse","duration":"12 minutes","updatedAt":"2020-05-09T19:59:14.191Z","createdAt":"2020-05-09T19:59:14.191Z"}]')}}]); \ No newline at end of file diff --git a/_next/static/chunks/framework-91d7f78b5b4003c8.js b/_next/static/chunks/framework-91d7f78b5b4003c8.js new file mode 100644 index 000000000..9b44a2107 --- /dev/null +++ b/_next/static/chunks/framework-91d7f78b5b4003c8.js @@ -0,0 +1 @@ +"use strict";(self.webpackChunk_N_E=self.webpackChunk_N_E||[]).push([[774],{4448:function(e,t,n){var r=n(7294),l=n(6086),a=n(3840);function o(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n