Skip to content

Commit

Permalink
proper implementation for the viewer
Browse files Browse the repository at this point in the history
  • Loading branch information
markbaas committed Feb 9, 2021
1 parent b406f2f commit 3b3b3e9
Show file tree
Hide file tree
Showing 5 changed files with 26 additions and 15 deletions.
8 changes: 8 additions & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -74,6 +74,14 @@
"mimeTypes": [
"ms-vscode.r-notebook/table"
]
},
{
"id": "r-notebook-viewer-renderer",
"displayName": "Notebook Viewer Render",
"entrypoint": "./dist/viewerRenderer.js",
"mimeTypes": [
"ms-vscode.r-notebook/viewer"
]
}
],
"viewsContainers": {
Expand Down
4 changes: 2 additions & 2 deletions samples/test1.rmd
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,10 @@ df = data.frame(a = c(1,2,3,4), b = c(10, 20, 13, 1))
library(ggplot2)
library(plotly)
df
ggplotly(ggplot(df, aes(a, b)) + geom_point())
```
```{r}
ggplot(df, aes(a, b)) + geom_point()
ggplotly(ggplot(df, aes(a, b)) + geom_point())
```
```{r}
Expand Down
12 changes: 10 additions & 2 deletions src/client/renderers/viewerRenderer.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,15 @@
const notebookApi = acquireNotebookRendererApi("r-notebook-table-renderer");
const notebookApi = acquireNotebookRendererApi("r-notebook-viewer-renderer");


notebookApi.onDidCreateOutput((evt) => {
const output = evt.output.data[evt.mimeType];
evt.element.innerHTML =
const iframe = document.createElement("iframe");
iframe.style.border = "0";
iframe.style.width = "90vw"
iframe.style.minHeight = "30vw"
iframe.sandbox.add("allow-scripts");
iframe.sandbox.add("allow-forms");
iframe.sandbox.add("allow-same-origin");
iframe.srcdoc = output
evt.element.appendChild(iframe)
});
10 changes: 2 additions & 8 deletions src/extension/notebook.ts
Original file line number Diff line number Diff line change
Expand Up @@ -341,17 +341,11 @@ export class RNotebookProvider implements vscode.NotebookContentProvider, vscode
const html = (await vscode.workspace.fs.readFile(vscode.Uri.parse(response.result))).toString();
const htmlDir = dirname(response.result)
const htmlInline = await inlineAll(html, htmlDir)
const htmlWrapped = `
<iframe id="plotly" frameborder="0" sandbox="allow-scripts allow-forms allow-same-origin"></iframe>
<script>
var iframe = document.getElementById("plotly")
iframe.srcdoc = unescape("${escape(htmlInline)}")
</script>
`

return {
outputKind: vscode.CellOutputKind.Rich,
data: {
'text/html': htmlWrapped
'ms-vscode.r-notebook/viewer': htmlInline
},
}
}
Expand Down
7 changes: 4 additions & 3 deletions webpack.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,8 @@ const extensionConfig = {
const clientConfig = {
target: 'web',
entry: {
"tableRenderer": "./src/client/renderers/tableRenderer.tsx"
"tableRenderer": "./src/client/renderers/tableRenderer.tsx",
"viewerRenderer": "./src/client/renderers/viewerRenderer.tsx"
},
output: {
// the bundle is stored in the 'dist' folder (check package.json), 📖 -> https://webpack.js.org/configuration/output/
Expand Down Expand Up @@ -108,5 +109,5 @@ const clientConfig = {
]
}

// module.exports = [extensionConfig, clientConfig]
module.exports = [clientConfig]
module.exports = [extensionConfig, clientConfig]
// module.exports = [clientConfig]

0 comments on commit 3b3b3e9

Please sign in to comment.