dev/02_dev.R

# 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 ----
## Add one line by package you want to add as dependency
usethis::use_package( "thinkr" )
usethis::use_package( "DBI" )
usethis::use_package( "DT" )
usethis::use_package( "RPostgreSQL" )
usethis::use_package( "bsplus" )
usethis::use_package( "config" )
usethis::use_package( "data.table" )
usethis::use_package( "dplyr" )
usethis::use_package( "ggplot2" )
usethis::use_package( "golem" )
usethis::use_package( "igraph" )
usethis::use_package( "leaflet" )
usethis::use_package( "plotly" )
usethis::use_package( "promises" )
usethis::use_package( "purrr" )
usethis::use_package( "rintrojs" )
usethis::use_package( "rmarkdown" )
usethis::use_package( "rpostgis" )
usethis::use_package( "sf" )
usethis::use_package( "shiny" )
usethis::use_package( "shinycssloaders" )
usethis::use_package( "shinydashboard" )
usethis::use_package( "shinydashboardPlus" )
usethis::use_package( "shinyjs" )
usethis::use_package( "stats" )

## Add modules ----
## Create a module infrastructure in R/
golem::add_module( name = "clus_explorer_utils_server" )
golem::add_module( name = "clus_explorer_utils_server" )
# Chart modules
golem::add_module( name = "chart_bar" )
golem::add_module( name = "chart_heatmap" )
golem::add_module( name = "chart_treemap" )
golem::add_module( name = "chart_sankey" )
# Tabs
golem::add_module( name = "page_home" )
golem::add_module( name = "page_scenarios" )
golem::add_module( name = "page_dashboard" )
golem::add_module( name = "page_query_builder" )
golem::add_module( name = "page_map_viewer" )
golem::add_module( name = "page_map_report" )
golem::add_module( name = "page_dashboard_summary" )
golem::add_module( name = "page_dashboard_caribou" )
golem::add_module( name = "page_dashboard_climate" )
golem::add_module( name = "page_dashboard_fire" )
golem::add_module( name = "page_dashboard_fisher" )
golem::add_module( name = "page_dashboard_forestry" )
golem::add_module( name = "page_dashboard_grizzly" )

## Add helper functions ----
## Creates fct_* and utils_*
golem::add_fct( "helpers" )
golem::add_utils( "helpers" )

## 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( "custom" )

## Add internal datasets ----
## If you have data in your package
usethis::use_data_raw( name = "bootstrap", open = TRUE )

## Tests ----
## Add one line by test you want to create
usethis::use_test( "app" )

# Documentation

## Vignette ----
usethis::use_vignette("clus_explorer")
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()
# 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")
bcgov/clus_explorer documentation built on Oct. 16, 2022, 1:56 p.m.