# Building a Prod-Ready, Robust Shiny Application.
#
# README: each step of the dev files is optional, and you don't have to
# fill every dev scripts before getting started.
# 01_start.R should be filled at start.
# 02_dev.R should be used to keep track of your development during the project.
# 03_deploy.R should be used once you need to deploy your app.
#
#
###################################
#### CURRENT FILE: DEV SCRIPT #####
###################################
# Engineering
## Dependencies ----
## Amend DESCRIPTION with dependencies read from package code parsing
#attachment::att_amend_desc()
#attachment::att_from_rscripts()
usethis::use_pipe()
usethis::use_tidy_eval()
usethis::use_package("thinkr")
usethis::use_package("dplyr")
usethis::use_package("tidyr")
usethis::use_package("plotly")
usethis::use_package("leaflet")
usethis::use_package("RTL")
usethis::use_package("lubridate")
usethis::use_package("leafpop")
usethis::use_package("ggplot2")
usethis::use_package("sf")
usethis::use_package("purrr")
usethis::use_package("rlang")
usethis::use_package("DT")
usethis::use_package("tidyselect")
usethis::use_package("MASS")
usethis::use_package("stringr")
usethis::use_package("stats")
usethis::use_package("Matrix")
devtools::document()
spelling::spell_check_package()
spelling::update_wordlist()
## Add modules ----
## Create a module infrastructure in R/
golem::add_module(name = "compute", with_test = FALSE) # Name of the module
golem::add_module(name = "context", with_test = FALSE) # Name of the module
golem::add_module(name = "markowitz", with_test = FALSE) # Name of the module
golem::add_module(name = "npvAtRisk", with_test = FALSE) # Name of the module
golem::add_module(name = "portfolio", with_test = FALSE) # Name of the module
## Add helper functions ----
## Creates fct_* and utils_*
golem::add_fct("tcycle", with_test = FALSE)
golem::add_fct("dynamicInputs", with_test = FALSE)
golem::add_utils("ui", with_test = FALSE)
## External resources
## Creates .js and .css files at inst/app/www
golem::add_js_file("script")
#golem::add_js_handler("handlers")
golem::add_css_file("style")
file.copy(from = "~/core/css/apps.css", to = "./inst/app/www/style.css", overwrite = TRUE)
#golem::add_sass_file("custom")
## Add internal datasets ----
## If you have data in your package
usethis::use_data_raw(name = "DATASET", open = TRUE)
## Tests ----
## Add one line by test you want to create
#usethis::use_test("app")
# Documentation
## Vignette ----
#usethis::use_vignette("RTLappStrat")
#devtools::build_vignettes()
## Code Coverage----
## Set the code coverage service ("codecov" or "coveralls")
usethis::use_coverage()
# Create a summary readme for the testthat subdirectory
#covrpage::covrpage()
## CI ----
## Use this part of the script if you need to set up a CI
## service for your application
##
## (You'll need GitHub there)
usethis::use_github()
# GitHub Actions
#usethis::use_github_action()
usethis::use_github_actions_badge(name = "R-CMD-check", repo_spec = NULL)
# Chose one of the three
# See https://usethis.r-lib.org/reference/use_github_action.html
usethis::use_github_action_check_release()
#usethis::use_github_action_check_standard()
#usethis::use_github_action_check_full()
# Add action for PR
#usethis::use_github_action_pr_commands()
# Travis CI
#usethis::use_travis()
#usethis::use_travis_badge()
# AppVeyor
#usethis::use_appveyor()
#usethis::use_appveyor_badge()
# Circle CI
#usethis::use_circleci()
#usethis::use_circleci_badge()
# Jenkins
#usethis::use_jenkins()
# GitLab CI
#usethis::use_gitlab_ci()
# You're now set! ----
# go to dev/03_deploy.R
rstudioapi::navigateToFile("dev/03_deploy.R")
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.