EVOLUTION-MANAGER
Edit File: shinyjs.html
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title>shinyjs</title> <script type="text/javascript"> window.onload = function() { var imgs = document.getElementsByTagName('img'), i, img; for (i = 0; i < imgs.length; i++) { img = imgs[i]; // center an image if it is the only element of its parent if (img.parentElement.childElementCount === 1) img.parentElement.style.textAlign = 'center'; } }; </script> <style type="text/css"> body, td { font-family: sans-serif; background-color: white; font-size: 13px; } body { max-width: 800px; margin: auto; padding: 1em; line-height: 20px; } tt, code, pre { font-family: 'DejaVu Sans Mono', 'Droid Sans Mono', 'Lucida Console', Consolas, Monaco, monospace; } h1 { font-size:2.2em; } h2 { font-size:1.8em; } h3 { font-size:1.4em; } h4 { font-size:1.0em; } h5 { font-size:0.9em; } h6 { font-size:0.8em; } a:visited { color: rgb(50%, 0%, 50%); } pre, img { max-width: 100%; } pre { overflow-x: auto; } pre code { display: block; padding: 0.5em; } code { font-size: 92%; border: 1px solid #ccc; } code[class] { background-color: #F8F8F8; } table, td, th { border: none; } blockquote { color:#666666; margin:0; padding-left: 1em; border-left: 0.5em #EEE solid; } hr { height: 0px; border-bottom: none; border-top-width: thin; border-top-style: dotted; border-top-color: #999999; } @media print { * { background: transparent !important; color: black !important; filter:none !important; -ms-filter: none !important; } body { font-size:12pt; max-width:100%; } a, a:visited { text-decoration: underline; } hr { visibility: hidden; page-break-before: always; } pre, blockquote { padding-right: 1em; page-break-inside: avoid; } tr, img { page-break-inside: avoid; } img { max-width: 100% !important; } @page :left { margin: 15mm 20mm 15mm 10mm; } @page :right { margin: 15mm 10mm 15mm 20mm; } p, h2, h3 { orphans: 3; widows: 3; } h2, h3 { page-break-after: avoid; } } </style> </head> <body> <h3 align="center">shinyjs</h3> <h4 align="center">Easily improve the user experience of your Shiny apps in seconds <br><br> <a href="https://deanattali.com/shinyjs/">Official website</a> · by <a href="https://deanattali.com">Dean Attali</a> </h4> <p align="center"> <a href="https://github.com/daattali/shinyjs/actions"> <img src="https://github.com/daattali/shinyjs/workflows/R-CMD-check/badge.svg" alt="R Build Status" /> </a> <a href="https://cran.r-project.org/package=shinyjs"> <img src="https://www.r-pkg.org/badges/version/shinyjs" alt="CRAN version" /> </a> <a href="https://xscode.com/daattali/shinyjs"> <img src="https://img.shields.io/badge/Available%20on-xs%3Acode-blue?style=?style=plastic&logo=appveyor&logo=" alt="Purchase shinyjs services on xcode" /> </a> </p> <p></p></p> <hr/> <p><img src="" width="170" align="right"/></p> <p>{shinyjs} lets you perform common useful JavaScript operations in Shiny apps that will greatly improve your apps without having to know any JavaScript.</p> <p>Examples include: hiding an element, disabling an input, resetting an input back to its original value, delaying code execution by a few seconds, and many more useful functions for both the end user and the developer. {shinyjs} can also be used to easily call your own custom JavaScript functions from R.</p> <p><strong>Need Shiny help? <a href="https://attalitech.com/">I'm available for consulting</a>.</strong><br/> <strong>If you find {shinyjs} useful, please consider <a href="https://github.com/sponsors/daattali">supporting my work</a> to unlock rewards! ❤</strong></p> <p align="center"> <a style="display: inline-block; margin-left: 10px;" href="https://github.com/sponsors/daattali"> <img height="35" src="https://i.imgur.com/034B8vq.png" /> </a> <a style="display: inline-block;" href="https://www.paypal.com/donate/?hosted_button_id=DG8NNBJHRKM46"> <img height="35" src="https://camo.githubusercontent.com/0e9e5cac101f7093336b4589c380ab5dcfdcbab0/68747470733a2f2f63646e2e6a7364656c6976722e6e65742f67682f74776f6c66736f6e2f70617970616c2d6769746875622d627574746f6e40312e302e302f646973742f627574746f6e2e737667" /> </a> </p> <blockquote> <p>This package is part of a larger ecosystem of packages with a shared vision: solving common Shiny issues and improving Shiny apps with minimal effort, minimal code changes, and straightforward documentation. Other packages for your Shiny apps:</p> </blockquote> <table><thead> <tr> <th>Package</th> <th>Description</th> <th>Demo</th> </tr> </thead><tbody> <tr> <td><a href="https://github.com/daattali/shinyalert">shinyalert</a></td> <td>🗯️ Easily create pretty popup messages (modals) in Shiny</td> <td><a href="https://daattali.com/shiny/shinyalert-demo/">🔗</a></td> </tr> <tr> <td><a href="https://github.com/daattali/shinyscreenshot/">shinyscreenshot</a></td> <td>📷 Capture screenshots of entire pages or parts of pages in Shiny apps</td> <td><a href="https://daattali.com/shiny/shinyscreenshot-demo/">🔗</a></td> </tr> <tr> <td><a href="https://github.com/daattali/timevis/">timevis</a></td> <td>📅 Create interactive timeline visualizations in R</td> <td><a href="https://daattali.com/shiny/timevis-demo/">🔗</a></td> </tr> <tr> <td><a href="https://github.com/daattali/shinycssloaders/">shinycssloaders</a></td> <td>⌛ Add loading animations to a Shiny output while it's recalculating</td> <td><a href="https://daattali.com/shiny/shinycssloaders-demo/">🔗</a></td> </tr> <tr> <td><a href="https://github.com/daattali/colourpicker/">colourpicker</a></td> <td>🎨 A colour picker tool for Shiny and for selecting colours in plots</td> <td><a href="https://daattali.com/shiny/colourInput/">🔗</a></td> </tr> <tr> <td><a href="https://github.com/daattali/shinybrowser/">shinybrowser</a></td> <td>🌐 Find out information about a user's web browser in Shiny apps</td> <td><a href="https://daattali.com/shiny/shinybrowser-demo/">🔗</a></td> </tr> <tr> <td><a href="https://github.com/daattali/shinydisconnect/">shinydisconnect</a></td> <td>🔌 Show a nice message when a Shiny app disconnects or errors</td> <td><a href="https://daattali.com/shiny/shinydisconnect-demo/">🔗</a></td> </tr> <tr> <td><a href="https://github.com/daattali/shinyforms/">shinyforms</a></td> <td>📝 Easily create questionnaire-type forms with Shiny</td> <td>WIP</td> </tr> </tbody></table> <h1>Table of contents</h1> <ul> <li><a href="#demos">Demos and tutorials</a></li> <li><a href="#sponsors">Sponsors 🏆</a></li> <li><a href="#overview-main">Overview of main functions</a></li> <li><a href="#install">Installation</a></li> <li><a href="#usage">How to use</a></li> <li><a href="#usecase">Basic use case - complete working example</a></li> <li><a href="#extendshinyjs">Calling your own JavaScript functions from R</a></li> <li><a href="#faq-tricks">FAQ and extra tricks</a></li> <li><a href="#support">Support</a></li> </ul> <h2 id="demos">Demos and tutorials</h2> <ul> <li><a href="https://deanattali.com/shinyjs/demo">Demo Shiny app</a> that lets you play around with some of the functionality in {shinyjs}.</li> <li><a href="https://deanattali.com/shinyjs-shinydevcon-2016/">Video of my {shinyjs} talk</a> (30 min) and the corresponding <a href="https://docs.google.com/presentation/d/1XyBrIA97ZWIkm8NICAyWHo4J9hj_i2-mJmKEq_CR2A8/edit?usp=sharing">presentation slides</a> from the 2016 Shiny Developer Conference.</li> <li><a href="https://deanattali.com/shinyjs-user-2016/">Video of my {shinyjs} talk</a> (5 min) and the corresponding <a href="https://docs.google.com/presentation/d/1owJpLTmfV-53Ca9NJIweBMANsmjaErKXNzw_sCTuBAw/edit?usp=sharing">presentation slides</a> from the 2016 useR Conference.</li> </ul> <h2 id="sponsors">Sponsors 🏆</h2> <blockquote> <p>There are no sponsors yet</p> </blockquote> <p><a href="https://github.com/sponsors/daattali/sponsorships?tier_id=39856">Become the first sponsor for {shinyjs} and unlock special rewards!</a></p> <h2 id="overview-main">Overview of main functions</h2> <p><strong>Note: In order to use any {shinyjs} function in a Shiny app, you must first call <code>useShinyjs()</code> anywhere in the app's UI.</strong></p> <table><thead> <tr> <th>Function</th> <th>Description</th> </tr> </thead><tbody> <tr> <td><code>show</code>/<code>hide</code>/<code>toggle</code></td> <td>Display or hide an element (optionally with an animation).</td> </tr> <tr> <td><code>hidden</code></td> <td>Initialize a Shiny tag as invisible (can be shown later with a call to <code>show</code>).</td> </tr> <tr> <td><code>enable</code>/<code>disable</code>/<code>toggleState</code></td> <td>Enable or disable an input element, such as a button or a text input.</td> </tr> <tr> <td><code>disabled</code></td> <td>Initialize a Shiny input as disabled.</td> </tr> <tr> <td><code>reset</code></td> <td>Reset a Shiny input widget back to its original value.</td> </tr> <tr> <td><code>refresh</code></td> <td>Refresh the page.</td> </tr> <tr> <td><code>delay</code></td> <td>Execute R code (including any {shinyjs} functions) after a specified amount of time.</td> </tr> <tr> <td><code>alert</code></td> <td>Show a message to the user.</td> </tr> <tr> <td><code>click</code></td> <td>Simulate a click on a button.</td> </tr> <tr> <td><code>html</code></td> <td>Change the text/HTML of an element.</td> </tr> <tr> <td><code>onclick</code></td> <td>Run R code when a specific element is clicked. Was originally developed with the sole purpose of running a {shinyjs} function when an element is clicked, though any R code can be used.</td> </tr> <tr> <td><code>onevent</code></td> <td>Similar to <code>onclick</code>, but can be used with many other events instead of click (for example, listen for a key press, mouse hover, etc).</td> </tr> <tr> <td><code>removeEvent</code></td> <td>Remove an event that was added to an HTML element with <code>onclick()</code> or <code>onevent()</code>.</td> </tr> <tr> <td><code>addClass</code>/<code>removeClass</code>/<code>toggleClass</code></td> <td>add or remove a CSS class from an element.</td> </tr> <tr> <td><code>runjs</code></td> <td>Run arbitrary JavaScript code.</td> </tr> <tr> <td><code>extendShinyjs</code></td> <td>Allows you to write your own JavaScript functions and use {shinyjs} to call them as if they were regular R code. More information is available in the section “Calling your own JavaScript functions from R” below.</td> </tr> </tbody></table> <h3>Functions that help you during Shiny app development</h3> <table><thead> <tr> <th>Function</th> <th>Description</th> </tr> </thead><tbody> <tr> <td><code>runcodeUI</code>+<code>runcodeServer</code></td> <td>Adds a text input to your app that lets you run arbitrary R code live.</td> </tr> <tr> <td><code>showLog</code></td> <td>Print any JavaScript <code>console.log()</code> messages in the R console, to make it easier and quicker to debug apps without having to open the JS console.</td> </tr> <tr> <td><code>logjs</code></td> <td>Print a message to the JavaScript console (mainly used for debugging purposes).</td> </tr> <tr> <td><code>inlineCSS</code></td> <td>Easily add inline CSS to a Shiny app.</td> </tr> </tbody></table> <p><a href="https://deanattali.com/shinyjs/demo">Check out the {shinyjs} demo app</a> to see some of these in action, or install {shinyjs} and run <code>shinyjs::runExample()</code> to see more demos.</p> <h2 id="install">Installation</h2> <p>To install the stable CRAN version:</p> <pre><code>install.packages("shinyjs") </code></pre> <p>To install the latest development version from GitHub:</p> <pre><code>install.packages("remotes") remotes::install_github("daattali/shinyjs") </code></pre> <h2 id="usage">How to use</h2> <p>A typical Shiny app has a UI portion and a server portion. Before using most {shinyjs} functions, you need to call <code>useShinyjs()</code> in the app's UI. It's best to include it near the top as a convention.</p> <p>Here is a minimal Shiny app that uses {shinyjs}:</p> <pre><code>library(shiny) library(shinyjs) ui <- fluidPage( useShinyjs(), # Include shinyjs actionButton("button", "Click me"), textInput("text", "Text") ) server <- function(input, output) { observeEvent(input$button, { toggle("text") # toggle is a shinyjs function }) } shinyApp(ui, server) </code></pre> <p>This is how most Shiny apps should initialize {shinyjs} - by calling <code>useShinyjs()</code> near the top of the UI.</p> <p>However, if you use {shinyjs} in any of the following cases:</p> <ul> <li>In Shiny dashboards (built using the <code>shinydashboard</code> package)</li> <li>In Shiny apps that use a <code>navbarPage</code> layout</li> <li>In Rmd documents</li> <li>In Shiny apps that manually build the user interface with an HTML file or template (instead of using Shiny's UI functions)</li> </ul> <p>Then you should see the <a href="https://deanattali.com/shinyjs/advanced"><em>Including {shinyjs} in different types of apps</em></a> document.</p> <p>If your Shiny app doesn't fall into any of these categories, then the above code sample should be enough to get your started with including {shinyjs} in your app.</p> <h2 id="usecase">Basic use case - complete working example</h2> <p>See the <a href="https://deanattali.com/shinyjs/example"><em>{shinyjs} example app walk-through</em></a> document for a step-by-step guide on how to add a variety of {shinyjs} features to a simple app in order to make it more user friendly.</p> <h2 id="extendshinyjs">Calling your own JavaScript functions from R</h2> <p>You can also use {shinyjs} to add your own JavaScript functions that can be called from R as if they were regular R functions using <code>extendShinyjs()</code>. This is only suitable for advanced users who are familiar with JavaScript and wish to facilitate the communication between R and JavaScript.</p> <p>To learn about this feature and see how useful it can be, see the <a href="https://deanattali.com/shinyjs/extend"><em>extendShinyjs: Calling your own JavaScript functions from R</em></a> document.</p> <h2 id="faq-tricks">FAQ and extra tricks</h2> <p>There are several questions that pop up very frequently in my email or on StackOverflow about “How do I use {shinyjs} to do ___?” Here is a list of a few of these common questions with links to a solution that could be useful. Note that all of these require using <code>extendShinyjs()</code>.</p> <ul> <li><a href="https://stackoverflow.com/a/31306707/3943160">How do I show/hide the <code>shinydashboard</code> sidebar programmatically?</a></li> <li><a href="https://stackoverflow.com/a/31719425/3943160">How do I hide/disable a tab?</a></li> <li><a href="https://stackoverflow.com/a/34758024/3943160">How do I refresh the page?</a></li> <li><a href="https://github.com/timelyportfolio/sweetalertR/issues/1#issuecomment-151685005">How do I call a JavaScript function from a different JavaScript library?</a></li> <li><a href="https://stackoverflow.com/a/31066997/3943160">How do I change the values of a <code>sliderInput</code>?</a></li> <li><a href="https://stackoverflow.com/a/34728125/3943160">How do I call JavaScript code and use the return value?</a></li> </ul> <p>I also keep a long <a href="https://deanattali.com/blog/advanced-shiny-tips/">list of various Shiny tips & tricks</a> for solving common Shiny problems, many of which make use of {shinyjs}.</p> <h2 id="support">Support</h2> <p>This document is only an overview of {shinyjs}. There are more in-depth resources available on the <a href="https://deanattali.com/shinyjs/">{shinyjs} website</a>.</p> <p>If you need help with {shinyjs}, free support is available on <a href="https://stackoverflow.com/questions/ask?tags=r+shiny+shinyjs">StackOverflow</a>, <a href="https://community.rstudio.com/new-topic?category=shiny&tags=shinyjs">RStudio Community</a>, and <a href="https://twitter.com/hashtag/rstats">Twitter</a>. </p> <p><strong>Due to the large volume of requests I receive, I'm unable to provide free support. If you can't solve any issue and require my personal help, please visit <a href="https://xscode.com/daattali/shinyjs">https://xscode.com/daattali/shinyjs</a> or <a href="https://attalitech.com/contact">contact me</a>.</strong></p> <h2>Credits</h2> <p>Logo design by <a href="https://aldomann.com/">Alfredo Hernández</a>.</p> </body> </html>