Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/RinteRface/charpente
Seamlessly design robust 'shiny' extensions
https://github.com/RinteRface/charpente
css development esbuild html javascript r shiny
Last synced: about 1 month ago
JSON representation
Seamlessly design robust 'shiny' extensions
- Host: GitHub
- URL: https://github.com/RinteRface/charpente
- Owner: RinteRface
- License: other
- Created: 2020-09-03T10:56:15.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2024-07-18T15:08:33.000Z (6 months ago)
- Last Synced: 2024-12-04T05:22:39.071Z (about 1 month ago)
- Topics: css, development, esbuild, html, javascript, r, shiny
- Language: R
- Homepage: https://rinterface.github.io/charpente/
- Size: 4.75 MB
- Stars: 51
- Watchers: 4
- Forks: 9
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- Changelog: NEWS.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- jimsghstars - RinteRface/charpente - Seamlessly design robust 'shiny' extensions (R)
README
# charpente
[![R-CMD-check](https://github.com/RinteRface/charpente/actions/workflows/R-CMD-check.yaml/badge.svg)](https://github.com/RinteRface/charpente/actions/workflows/R-CMD-check.yaml)
[![CRAN status](https://www.r-pkg.org/badges/version/charpente)](https://CRAN.R-project.org/package=charpente)
[![Lifecycle: experimental](https://img.shields.io/badge/lifecycle-experimental-orange.svg)](https://www.tidyverse.org/lifecycle/#experimental)The goal of `{charpente}` is to significantly reduce the complexity of creating new HTML templates for Shiny:
- `{charpente}` creates a plug and play package structure.
- `{charpente}` automatically import dependencies from [jsdelivr](https://www.jsdelivr.com/), so that you don't have to do it by hand!
- `{charpente}` eases the conversion from HTML to R.
- `{charpente}` offers multiple R and JS boilerplate for `{shiny}` input bindings, `{shiny}` message handlers, ...
- `{charpente}` enables seamless JavaScript code management (powered by [esbuild](https://esbuild.github.io/)): concat, compress, mangle, bundle, minify, ... for JS and
Sass code.## Installation
You can install the development version of `{charpente}` from Github with:
``` r
# latest version
remotes::install_github("RinteRface/charpente")
```## Example
This is a basic example which shows you how to solve a common problem:
``` r
library(charpente)path <- file.path(tempdir(), "mypkg")
create_charpente(path, license = "mit")# Once the package is created and opened
# Look for all bulma flavors
get_dependency_versions("bulma")
# Get latest stable
get_dependency_versions("bulma", latest = TRUE)
# Inspect bulma
get_dependency_assets("bulma")# Download bulma locally
create_dependency("bulma")
devtools::load_all()
# Test the newly added dependencies tools
findDependencies(add_bulma_deps(div()))# Create JS handler
create_custom_handler("modal")# Create input binding
create_input_binding("myinput")# Create output binding
create_output_binding("myoutput")# Compress JS and CSS (Sass) for production
build_js()
devtools::load_all()
```## Using esbuild and mocha
If you want to use `esbuild` and `mocha` in an existing project, you can use the functions `set_esbuild()` and `set_mocha()`. A simple workflow looks as follows:
```r
# Setup esbuild for JS code management
set_esbuild()# Add mocha for tests
set_mocha()
```## Monolithic and component based bundling
`{charpente}` offers two ways of bundling your JS code: monolithic and component based. The monolithic bundling is the default one and is the simplest to use. It will bundle all your JS and CSS code into single files. By default, the entry point is `/scrjs/main.js`, which will also be created when setting esbuild for the first time with `set_esbuid()`. In this case bundling is easy and can be achieved with:
```r
build_js()
```Component based bundling might be convenient in situations where you want to create a bundle for each (standalone) component. Bundling per component will make sure that only the necessary assets are loaded. This is particularly useful when you want to create a package with multiple components, and not a complete template. To use component based bundling, you can specify multiple `entry_points` in `build_js()`.
For the below structure in the /srcjs folder:
```
srcjs
├── component1.js
└── component2.js
```You can build as follows:
```r
build_js(entry_points = c("component1.js", "component2.js"))
```CSS styles for each component can be loaded in the js files with `import` statements, e.g. `import "../styles/component1.scss";`.
You JS code will be bundled into `/inst/{package-name}-{version}/`. Dependencies for your HTML are automatically created in `R/{package-name}-dependencies.R`. There will be only one HTML dependency in case of monolithic building, and multiple in case of component based building.
## Acknowledgment
The author would like to warmly thank [Victor Perrier](https://twitter.com/_pvictorr?lang=fr),
[John Coene](https://twitter.com/jdatap), [Colin Fay](https://twitter.com/_ColinFay), [Alan Dipert](https://twitter.com/alandipert), [Kenton Russel](https://twitter.com/timelyportfolio) for providing many building block and inspiration to this package.## Code of Conduct
Please note that the `{charpente}` project is released with a [Contributor Code of Conduct](https://contributor-covenant.org/version/2/0/CODE_OF_CONDUCT.html).
By contributing to this project, you agree to abide by its terms.