Spaces:
Running
Running
first
Browse files- Dockerfile +18 -1
- README.md +18 -33
- app.R +63 -24
- deploy_docker.sh → docker_rm.sh +2 -4
- docker_run.sh +2 -0
Dockerfile
CHANGED
|
@@ -13,6 +13,23 @@ RUN set -eux; \
|
|
| 13 |
git \
|
| 14 |
sudo \
|
| 15 |
sqlite3 \
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 16 |
ca-certificates \
|
| 17 |
gcc \
|
| 18 |
libc6-dev \
|
|
@@ -37,7 +54,7 @@ RUN set -eux; \
|
|
| 37 |
rm -rf /var/lib/apt/lists/*;
|
| 38 |
|
| 39 |
# Install R packages
|
| 40 |
-
RUN install2.r --error -s --deps TRUE htmltools tibble dplyr purrr rlang glue this.path DBI pool RSQLite remotes promises assertthat log here zeallot dbplyr stringr tidyverse
|
| 41 |
RUN Rscript -e "install.packages('b64', repos = c('https://extendr.r-universe.dev', getOption('repos')))"
|
| 42 |
RUN Rscript -e "install.packages('uwu', repos = c('https://josiahparry.r-universe.dev', getOption('repos')))"
|
| 43 |
RUN --mount=type=secret,id=GITHUB_PAT GITHUB_PAT=$(cat /run/secrets/GITHUB_PAT) \
|
|
|
|
| 13 |
git \
|
| 14 |
sudo \
|
| 15 |
sqlite3 \
|
| 16 |
+
make \
|
| 17 |
+
libcurl4-openssl-dev \
|
| 18 |
+
libssl-dev \
|
| 19 |
+
libxml2-dev \
|
| 20 |
+
zlib1g-dev \
|
| 21 |
+
libfontconfig1-dev \
|
| 22 |
+
libfreetype6-dev \
|
| 23 |
+
libpng-dev \
|
| 24 |
+
libtiff5-dev \
|
| 25 |
+
libjpeg-dev \
|
| 26 |
+
libharfbuzz-dev \
|
| 27 |
+
libfribidi-dev \
|
| 28 |
+
libpq-dev \
|
| 29 |
+
libgit2-dev \
|
| 30 |
+
gdal-bin libgdal-dev \
|
| 31 |
+
libudunits2-dev \
|
| 32 |
+
pandoc \
|
| 33 |
ca-certificates \
|
| 34 |
gcc \
|
| 35 |
libc6-dev \
|
|
|
|
| 54 |
rm -rf /var/lib/apt/lists/*;
|
| 55 |
|
| 56 |
# Install R packages
|
| 57 |
+
RUN install2.r --error -s --deps TRUE htmltools tibble dplyr purrr rlang glue this.path DBI pool RSQLite remotes promises assertthat log here zeallot dbplyr stringr tidyverse rmarkdown plotly
|
| 58 |
RUN Rscript -e "install.packages('b64', repos = c('https://extendr.r-universe.dev', getOption('repos')))"
|
| 59 |
RUN Rscript -e "install.packages('uwu', repos = c('https://josiahparry.r-universe.dev', getOption('repos')))"
|
| 60 |
RUN --mount=type=secret,id=GITHUB_PAT GITHUB_PAT=$(cat /run/secrets/GITHUB_PAT) \
|
README.md
CHANGED
|
@@ -16,27 +16,28 @@ experimental](https://img.shields.io/badge/lifecycle-experimental-orange.svg)](h
|
|
| 16 |
|
| 17 |
**THIS IS A WORK IN PROGRESS, DO NOT USE**
|
| 18 |
|
| 19 |
-
|
| 20 |
-
## Deployment options
|
| 21 |
-
|
| 22 |
-
|
| 23 |
-
### Hugging Face Spaces
|
| 24 |
-
|
| 25 |
-
When you pushing a repository to a Hugging Face Spaces with the option to deploy Dockerfile and include a Dockerfile, Hugging Face will start building and running your app in the Space.
|
| 26 |
-
|
| 27 |
-
Try the demo here:
|
| 28 |
|
| 29 |
* Direct URL to the deployed app: https://jrosell-ambhtmx-plotly.hf.space/
|
| 30 |
* Space URL: https://huggingface.co/spaces/jrosell/ambhtmx.plotly
|
| 31 |
|
|
|
|
| 32 |
|
| 33 |
-
|
|
|
|
|
|
|
|
|
|
| 34 |
|
|
|
|
| 35 |
```
|
| 36 |
-
bash
|
| 37 |
```
|
| 38 |
|
| 39 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
| 40 |
|
| 41 |
```
|
| 42 |
git init
|
|
@@ -46,36 +47,20 @@ git commit -m "My changes"
|
|
| 46 |
git remote add origin git@github.com:jrosell/ambhtmx.plotly.git
|
| 47 |
git remote add gh git@github.com:jrosell/ambhtmx.plotly.git
|
| 48 |
git remote add hf git@hf.co:spaces/jrosell/ambhtmx.plotly
|
| 49 |
-
git
|
| 50 |
-
git push --set-upstream hf main
|
| 51 |
```
|
| 52 |
|
| 53 |
-
|
| 54 |
-
### Runing the example in Docker
|
| 55 |
-
|
| 56 |
-
All in one command:
|
| 57 |
|
| 58 |
```
|
| 59 |
-
bash
|
| 60 |
-
```
|
| 61 |
-
|
| 62 |
-
It will run:
|
| 63 |
-
|
| 64 |
-
```
|
| 65 |
-
(docker container rm -f ambhtmx-plotly-container || true)\
|
| 66 |
-
&& (docker rmi $(docker images --format '{{.Repository}}:{{.ID}}'| egrep 'ambhtmx-plotly' | cut -d':' -f2 | uniq) --force || true) \
|
| 67 |
-
&& docker build -f Dockerfile -t ambhtmx-plotly-image . \
|
| 68 |
-
&& docker run --env-file=.Renviron -p 7860:7860 --name ambhtmx-plotly-container --rm ambhtmx-plotly-image
|
| 69 |
```
|
| 70 |
|
| 71 |
-
|
| 72 |
## Troubleshooting
|
| 73 |
|
| 74 |
-
|
| 75 |
|
| 76 |
-
|
| 77 |
-
docker build -f Dockerfile --no-cache --progress=plain -t ambhtmx-plotly-image . 2>&1 | tee build.log
|
| 78 |
-
```
|
| 79 |
|
| 80 |
Check the [known issues](https://github.com/jrosell/ambhtmx/issues), and if you have another issue? Please, [let me know](https://github.com/jrosell/ambhtmx/issues).
|
| 81 |
|
|
|
|
| 16 |
|
| 17 |
**THIS IS A WORK IN PROGRESS, DO NOT USE**
|
| 18 |
|
| 19 |
+
See the demo here:
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 20 |
|
| 21 |
* Direct URL to the deployed app: https://jrosell-ambhtmx-plotly.hf.space/
|
| 22 |
* Space URL: https://huggingface.co/spaces/jrosell/ambhtmx.plotly
|
| 23 |
|
| 24 |
+
Or test it locally:
|
| 25 |
|
| 26 |
+
```
|
| 27 |
+
git clone git@github.com:jrosell/ambhtmx.plotly.git
|
| 28 |
+
bash docker_run.sh
|
| 29 |
+
```
|
| 30 |
|
| 31 |
+
If you want, you can remove docker containers and images:
|
| 32 |
```
|
| 33 |
+
bash docker_rm.sh
|
| 34 |
```
|
| 35 |
|
| 36 |
+
## How to use Github and Hugging Face Spaces for my project
|
| 37 |
+
|
| 38 |
+
When you pushing a repository to a Hugging Face Spaces with the option to deploy Dockerfile and include a Dockerfile, Hugging Face will start building and running your app in the Space.
|
| 39 |
+
|
| 40 |
+
Customize this example, to enable Hugging Face Spaces as additional remote:
|
| 41 |
|
| 42 |
```
|
| 43 |
git init
|
|
|
|
| 47 |
git remote add origin git@github.com:jrosell/ambhtmx.plotly.git
|
| 48 |
git remote add gh git@github.com:jrosell/ambhtmx.plotly.git
|
| 49 |
git remote add hf git@hf.co:spaces/jrosell/ambhtmx.plotly
|
| 50 |
+
git remote -v
|
|
|
|
| 51 |
```
|
| 52 |
|
| 53 |
+
Then, to depoly to Hugging Face Spaces run:
|
|
|
|
|
|
|
|
|
|
| 54 |
|
| 55 |
```
|
| 56 |
+
bash deploy_hf.sh
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 57 |
```
|
| 58 |
|
|
|
|
| 59 |
## Troubleshooting
|
| 60 |
|
| 61 |
+
Kown issues:
|
| 62 |
|
| 63 |
+
* Only updates when refreshing the whole page. WIP should rerender on innerHTML replace.
|
|
|
|
|
|
|
| 64 |
|
| 65 |
Check the [known issues](https://github.com/jrosell/ambhtmx/issues), and if you have another issue? Please, [let me know](https://github.com/jrosell/ambhtmx/issues).
|
| 66 |
|
app.R
CHANGED
|
@@ -1,31 +1,70 @@
|
|
| 1 |
# remotes::install_github("jrosell/ambhtmx", force = TRUE)
|
| 2 |
library(ambhtmx)
|
| 3 |
-
|
|
|
|
| 4 |
|
| 5 |
-
|
| 6 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 7 |
tryCatch({
|
| 8 |
-
|
| 9 |
-
|
| 10 |
-
|
| 11 |
-
|
| 12 |
-
|
| 13 |
-
|
| 14 |
-
|
| 15 |
-
|
| 16 |
-
|
| 17 |
-
|
| 18 |
-
|
| 19 |
-
|
| 20 |
-
|
| 21 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 22 |
error = \(e) print(e)
|
| 23 |
)
|
| 24 |
-
|
| 25 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 26 |
|
| 27 |
-
|
| 28 |
-
|
| 29 |
-
card_3d_demo() |> send_page(res)
|
| 30 |
-
})$
|
| 31 |
-
start()
|
|
|
|
| 1 |
# remotes::install_github("jrosell/ambhtmx", force = TRUE)
|
| 2 |
library(ambhtmx)
|
| 3 |
+
library(ggplot2)
|
| 4 |
+
library(plotly)
|
| 5 |
|
| 6 |
+
page_title <- "WIP: ambhtmx slider example"
|
| 7 |
+
|
| 8 |
+
head_tags <- htmltools::tagList()
|
| 9 |
+
|
| 10 |
+
#' Generate a plot from rexp_data
|
| 11 |
+
generate_htmlwidget <- \(){
|
| 12 |
+
print("generate_htmlwidget")
|
| 13 |
+
rexp_df <- tibble(x = 1:length(rexp_data), y = rexp_data)
|
| 14 |
+
p_plot <- ggplot(rexp_df, aes(x, y)) + geom_line()
|
| 15 |
+
plotly::ggplotly(p_plot, width = 200, height = 100)
|
| 16 |
+
}
|
| 17 |
+
|
| 18 |
+
counter <- 1
|
| 19 |
+
rexp_data <- c(rexp(1), rexp(1))
|
| 20 |
+
|
| 21 |
+
#' Starting the app
|
| 22 |
+
c(app, context, operations) %<-% ambhtmx(host = "0.0.0.0", port = "7860")
|
| 23 |
+
|
| 24 |
+
|
| 25 |
+
#' Main page of the app
|
| 26 |
+
app$get("/", \(req, res){
|
| 27 |
+
html <- ""
|
| 28 |
tryCatch({
|
| 29 |
+
rexp_widget <- generate_htmlwidget()
|
| 30 |
+
rexp_tags <- amb_htmlwidget(rexp_widget, id = "rexp_widget")
|
| 31 |
+
html <- div(
|
| 32 |
+
style = "margin: 20px",
|
| 33 |
+
h1(page_title),
|
| 34 |
+
div(
|
| 35 |
+
id = "counter",
|
| 36 |
+
p(glue("Counter is set to {counter}")),
|
| 37 |
+
rexp_tags
|
| 38 |
+
),
|
| 39 |
+
button(
|
| 40 |
+
"+1",
|
| 41 |
+
hx_get="/increment",
|
| 42 |
+
hx_target="#counter",
|
| 43 |
+
# hx_target="#rexp_widget [data-for]",
|
| 44 |
+
# hx_target="#debug",
|
| 45 |
+
hx_swap="outerHTML"
|
| 46 |
+
),
|
| 47 |
+
div(id = "debug")
|
| 48 |
+
) |>
|
| 49 |
+
send_page(res)
|
| 50 |
+
},
|
| 51 |
error = \(e) print(e)
|
| 52 |
)
|
| 53 |
+
})
|
| 54 |
+
|
| 55 |
+
#' Call to return the plot
|
| 56 |
+
app$get("/increment", \(req, res){
|
| 57 |
+
counter <<- counter + 1
|
| 58 |
+
rexp_data <<- c(rexp_data, rexp(1))
|
| 59 |
+
rexp_widget <- generate_htmlwidget()
|
| 60 |
+
rexp_tags <- amb_htmlwidget(rexp_widget, id = "rexp_widget")
|
| 61 |
+
div(
|
| 62 |
+
id = "counter",
|
| 63 |
+
p(glue("Counter is set to {counter}")),
|
| 64 |
+
rexp_tags
|
| 65 |
+
) |>
|
| 66 |
+
send_tags(res)
|
| 67 |
+
})
|
| 68 |
|
| 69 |
+
#' Start the app with all the previous defined routes
|
| 70 |
+
app$start(open = FALSE)
|
|
|
|
|
|
|
|
|
deploy_docker.sh → docker_rm.sh
RENAMED
|
@@ -1,4 +1,2 @@
|
|
| 1 |
-
(docker container rm -f ambhtmx-plotly-container || true)\
|
| 2 |
-
&& (docker rmi $(docker images --format '{{.Repository}}:{{.ID}}'| egrep 'ambhtmx-plotly-image' | cut -d':' -f2 | uniq) --force || true)
|
| 3 |
-
&& docker build -f Dockerfile -t ambhtmx-plotly-image . \
|
| 4 |
-
&& docker run --env-file=.Renviron -p 7860:7860 --name ambhtmx-plotly-container --rm ambhtmx-plotly-image
|
|
|
|
| 1 |
+
(docker container rm -f ambhtmx-plotly-container || true) \
|
| 2 |
+
&& (docker rmi $(docker images --format '{{.Repository}}:{{.ID}}'| egrep 'ambhtmx-plotly-image' | cut -d':' -f2 | uniq) --force || true)
|
|
|
|
|
|
docker_run.sh
ADDED
|
@@ -0,0 +1,2 @@
|
|
|
|
|
|
|
|
|
|
| 1 |
+
(docker build -f Dockerfile -t ambhtmx-plotly-image . || true) \
|
| 2 |
+
&& docker run --env-file=.Renviron -p 7860:7860 --name ambhtmx-plotly-container --rm ambhtmx-plotly-image
|