class: center, middle, inverse, title-slide # Programmieraufgabeoder Lückentext? ## Wir visualisieren Daten und automatisieren Reports(für Anfänger:innen) ### --- # Wer wir sind .pull-left[ <br><br><br><br><br><br> <img src="libs/img/group.png" width=800 height=300> ] .pull-right[ <img src="libs/img/ninacosima.png" width=400 height=200> <br><br><br><br><br><br>Wir sind ein deutschlandweites Netzwerk von über 1300 Data Scientists, die die Welt durch Data Science verbessern wollen. **#MetaWeltretter** ] --- ## Agenda 1. **Vorstellung** (5 Minuten) <br> 2. **Allgemeine Einführung** (20 Minuten) <br> 3. **Übung 1-5 gemeinsam** (35 Minuten) - Übung durchlaufen lassen - Lösung durchlaufen lassen <br> 4. **Pause** (5 Minuten) <br> 5. **Übung 6-10 Peer Learning in Break Outs** (40 Minuten) <br> 6. **Hosting, Ausblick, Weiterbildung** (10 Minuten) <br> 7. **Evaluation** (5 Minuten) <br> 8. **Kaffeeplausch** (60 Minuten) --- class: inverse, middle, center background-image: url("libs/img/red.png") background-position: 0% 100%; background-size: cover # Und wer seid Ihr? --- class: bg_img, hide-logo, progress-bar-hide .full-width[.content-box-grey[ ## Spielregeln für unsere Zusammenarbeit <br><br> 1. Fragen gerne immer am Chat bzw. zum Ende der einzelnen Abschnitte <br><br> 2. Aktiv und gemeinsam Neues lernen <br><br> 3. Praktisch arbeiten statt Theorien wiederholen <br><br><br><br> ]] --- ## Ziele des Workshops <br><br> - Anwendungsmöglichkeiten für die Technologie RShiny erkennen <br><br> - Code zu lesen <br><br> - Grundverständnis für die technische Implementierung <br><br> - Gewecktes Interesse mehr zu lernen --- ## Prinzipien des Workshops <br><br> - Alle Pflichtaufgaben können durch das Kopieren von Codesegmenten mit kleinen Änderungen erledigt werden <br><br> - Bitte lest die Aufgabenstellungen gründlich durch (##### Übung X) <br><br> - Grüner Text kennzeichnet Kommentare, in denen wichtige Informationen für Euch stehen --- class: inverse, middle, center background-image: url("libs/img/blue.png") background-position: 0% 100%; background-size: cover # Web-Applikationen begegnen uns überall – doch was ist das eigentlich? --- ### Visualisierung von Covid-19-Daten [](https://vac-lshtm.shinyapps.io/ncov_tracker/?_ga=2.169619937.1955604536.1616424760-1179854739.1615478835) --- ### Suchmaschine (1) [](https://cosima-meyer.shinyapps.io/coro2vid-19-shinyapp/) --- ### Suchmaschine (2) [](https://cultureofinsight.shinyapps.io/crime-watch/?_ga=2.173579619.1955604536.1616424760-1179854739.1615478835) --- ### Und so viel mehr... [](https://shiny.rstudio.com/gallery/) --- ## Und was ist Shiny? Ein R-Package, das es Euch ermöglicht ganz leicht interaktive Web-Applikationen zu bauen <img src="libs/img/img3.png" width=1200 height=500> --- ## Und was ist Shiny? Ein R-Package, das es Euch ermöglicht ganz leicht interaktive Web-Applikationen zu bauen <img src="libs/img/img2.png" width=1200 height=500> --- class: inverse, middle, center background-image: url("libs/img/red.png") background-position: 0% 100%; background-size: cover # Wie erstelle ich eine ShinyApp in R? --- class: inverse, center, middle  --- # Aufsetzen einer ShinyApp <img src="libs/img/75.png" width=1200 height=500> --- # Aufsetzen einer ShinyApp <img src="libs/img/74.png" width=1200 height=500> --- # Aufsetzen einer ShinyApp <img src="libs/img/72.png" width=1200 height=500> --- class: hide-logo background-image: url("libs/img/fullbody.png") background-size: 120px background-position: 95% 8% ### `ui.R` Bestimmt das **Aussehen** der App <img src="libs/img/ui.png" width=1200 height=500> --- class: hide-logo background-image: url("libs/img/fullbody.png") background-size: 120px background-position: 95% 8% ### `ui.R` Bestimmt das **Aussehen** der App <img src="libs/img/ui2.png" width=1200 height=500> --- class: hide-logo background-image: url("libs/img/head.png") background-size: 200px background-position: 95% 8% ### `server.R` Kreiert das **Gehirn** der App <img src="libs/img/18.png" width=2000 height=500> --- ## Alles muss miteinander verbunden sein <img src="libs/img/21.png" width=2000 height=480> --- ### `shinyApp()` **Als letzter Schritt:** <br> Das **UI** mit dem **Server** kombinieren <br> <br> <br> <br> .center[ ```r shinyApp(ui = ui, server = server) ``` ] ---  --- class: inverse, center, middle # Jetzt bauen wir Eure erste ShinyApp <span style="font-size:8em">💻</span> --- class: inverse, center, middle ## Alles was Ihr braucht  --- ### Und jetzt? Ihr könnt den Code ganz leicht auf andere Projekte übertragen...  --- ### Oder Eure ShinyApp veröffentlichen - Mit unsensiblen Daten kann man die ShinyApp ganz einfach und kostenlos über [**shinyapp.ios**](http://www.shinyapps.io/?_ga=2.133360206.1145896271.1604733011-115282237.1604416772) veröffentlichen - Vor dem Veröffentlichen auf jeden Fall beachten: Alle Packages müssen installiert sein (mit `install.packages(...)`) -- das darf allerdings nicht im Code erscheinen. - Schritt-für-Schritt-Anleitung: 1. Installiert ```rsconnect``` (`install.packages('rsconnect')`) 2. Erstellt ein kostenloses Benutzerkonto auf [**shinyapps.io**](http://www.shinyapps.io/?_ga=2.133360206.1145896271.1604733011-115282237.1604416772) 3. Folgt Methode 1 wie [**hier**](https://shiny.rstudio.com/articles/shinyapps.html) beschrieben: Kopiert das Token und fügt es in Euer RStudio ein 4. (Wenn Ihr die App vorab noch einmal testen wollt: `runApp()`) 5. Zum Schluss: Veröffentlicht Eure ShinyApp mit `deployApp()` Einen kleinen Moment warten... **und das war's! Eure App ist online!** --- class: inverse ## Online findet Ihr tolle Weiterbildungsformate, ... [](https://www.dataquest.io) --- class: inverse background-image: url("libs/img/computer.png") background-size: 200px background-position: 95% 8% <br><br><br> ## ... noch mehr Ressourcen .pull-left[.small[ - Shiny - [R Studio Tutorial](https://shiny.rstudio.com/tutorial/) - [Hadley Wickham: "Mastering Shiny"](https://mastering-shiny.org) - [Konstantin Gavras and Nick Baumann: "Shiny Apps: Development and Deployment"](https://www.mzes.uni-mannheim.de/socialsciencedatalab/article/shiny-apps/) auf Methods Bites - [Julie Scholler: "Intro to Shiny Web App"](https://juliescholler.gitlab.io/files/M2/M2-CM3-Shiny.html#1) - [Kaleen L. Medeiros: "Introduction to Shiny"](https://github.com/klmedeiros/rladies-tunisia-july2020-intro-shiny) - [Garrett Grolemund: "How to understand reactivity in R"](https://shiny.rstudio.com/articles/understanding-reactivity.html) ]] .pull-right[.small[ - ShinyApps hosten - [Hosting and deployment](https://shiny.rstudio.com/articles/shinyapps.html) - [Shinyapps.io - Step-by-step guide](https://shiny.rstudio.com/articles/shinyapps.html) - Shiny dashboards - [R Studio tutorial](https://rstudio.github.io/shinydashboard/) - [Themes](https://github.com/nik01010/dashboardthemes) - Optimieren von ShinyApps - [Make your ShinyApp faster](https://appsilon.com/r-shiny-faster-updateinput-css-javascript/) - [shiny.worker](https://www.r-bloggers.com/shiny-worker-speed-up-r-shiny-apps-by-offloading-heavy-calculations/) - Visualisierungen leicht erstellen - [Per Click-and-Drop mit "esquisse"](https://cran.r-project.org/web/packages/esquisse/vignettes/get-started.html) ]] --- class: inverse ## ... und natürlich Angebote bei CorrelAid! <br> ![:col_row <img src="libs/img/projekte.png" width=220 height=150>, <img src="libs/img/bildung.png" width=220 height=150>, <img src="libs/img/dialog.png" width=220 height=150>] <br> ![:col_row <b>PROJEKTE</b>, <b>BILDUNG</b>, <b>DIALOG</b>] <br> ![:col_row Wir führen pro-bono Datenanalyseprojekte für gemeinnützige Organisationen durch., Wir vernetzen engagierte sozial denkende Datenanalyst:innen und bieten ihnen Möglichkeiten ihr Wissen anzuwenden und zu erweitern., Wir treten in den Dialog über den Wert und Nutzen von Daten und Datenanalysen für das Gemeinwohl.] --- class: inverse, middle, center <img src="libs/img/CorrelAid_Dach-zentriert_white-negativ.png" width=200 height=150> <svg style="height:0.8em;top:.04em;position:relative;fill:white;" viewBox="0 0 496 512"><path d="M336.5 160C322 70.7 287.8 8 248 8s-74 62.7-88.5 152h177zM152 256c0 22.2 1.2 43.5 3.3 64h185.3c2.1-20.5 3.3-41.8 3.3-64s-1.2-43.5-3.3-64H155.3c-2.1 20.5-3.3 41.8-3.3 64zm324.7-96c-28.6-67.9-86.5-120.4-158-141.6 24.4 33.8 41.2 84.7 50 141.6h108zM177.2 18.4C105.8 39.6 47.8 92.1 19.3 160h108c8.7-56.9 25.5-107.8 49.9-141.6zM487.4 192H372.7c2.1 21 3.3 42.5 3.3 64s-1.2 43-3.3 64h114.6c5.5-20.5 8.6-41.8 8.6-64s-3.1-43.5-8.5-64zM120 256c0-21.5 1.2-43 3.3-64H8.6C3.2 212.5 0 233.8 0 256s3.2 43.5 8.6 64h114.6c-2-21-3.2-42.5-3.2-64zm39.5 96c14.5 89.3 48.7 152 88.5 152s74-62.7 88.5-152h-177zm159.3 141.6c71.4-21.2 129.4-73.7 158-141.6h-108c-8.8 56.9-25.6 107.8-50 141.6zM19.3 352c28.6 67.9 86.5 120.4 158 141.6-24.4-33.8-41.2-84.7-50-141.6h-108z"/></svg> [correlaid.org](https://correlaid.org) <svg style="height:0.8em;top:.04em;position:relative;fill:white;" viewBox="0 0 512 512"><path d="M459.37 151.716c.325 4.548.325 9.097.325 13.645 0 138.72-105.583 298.558-298.558 298.558-59.452 0-114.68-17.219-161.137-47.106 8.447.974 16.568 1.299 25.34 1.299 49.055 0 94.213-16.568 130.274-44.832-46.132-.975-84.792-31.188-98.112-72.772 6.498.974 12.995 1.624 19.818 1.624 9.421 0 18.843-1.3 27.614-3.573-48.081-9.747-84.143-51.98-84.143-102.985v-1.299c13.969 7.797 30.214 12.67 47.431 13.319-28.264-18.843-46.781-51.005-46.781-87.391 0-19.492 5.197-37.36 14.294-52.954 51.655 63.675 129.3 105.258 216.365 109.807-1.624-7.797-2.599-15.918-2.599-24.04 0-57.828 46.782-104.934 104.934-104.934 30.213 0 57.502 12.67 76.67 33.137 23.715-4.548 46.456-13.32 66.599-25.34-7.798 24.366-24.366 44.833-46.132 57.827 21.117-2.273 41.584-8.122 60.426-16.243-14.292 20.791-32.161 39.308-52.628 54.253z"/></svg> [@CorrelAid](https://twitter.com/correlaid?lang=en) <svg style="height:0.8em;top:.04em;position:relative;fill:white;" viewBox="0 0 448 512"><path d="M416 32H31.9C14.3 32 0 46.5 0 64.3v383.4C0 465.5 14.3 480 31.9 480H416c17.6 0 32-14.5 32-32.3V64.3c0-17.8-14.4-32.3-32-32.3zM135.4 416H69V202.2h66.5V416zm-33.2-243c-21.3 0-38.5-17.3-38.5-38.5S80.9 96 102.2 96c21.2 0 38.5 17.3 38.5 38.5 0 21.3-17.2 38.5-38.5 38.5zm282.1 243h-66.4V312c0-24.8-.5-56.7-34.5-56.7-34.6 0-39.9 27-39.9 54.9V416h-66.4V202.2h63.7v29.2h.9c8.9-16.8 30.6-34.5 62.9-34.5 67.2 0 79.7 44.3 79.7 101.9V416z"/></svg> [correlaid](https://www.linkedin.com/company/correlaid/)