Product
Socket Now Supports uv.lock Files
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
@codesandbox/sandpack-client
Advanced tools
A bundler that completely works in the browser and takes advantage of it.
@codesandbox/sandpack-client is a client library for embedding and interacting with Sandpack, a tool that allows you to run and manage code sandboxes directly in your web applications. It provides a way to programmatically control sandboxes, execute code, and retrieve results, making it useful for educational tools, live coding environments, and interactive documentation.
Creating a Sandpack Client
This feature allows you to create a new Sandpack client instance by providing an iframe element and a configuration object. The configuration includes the files and template to be used in the sandbox.
const { SandpackClient } = require('@codesandbox/sandpack-client');
const iframe = document.getElementById('sandpack-iframe');
const client = new SandpackClient(iframe, { files: { '/index.js': { code: 'console.log("Hello, Sandpack!");' } }, template: 'node' });
Running Code
This feature allows you to run the code inside the sandbox. After creating the Sandpack client, you can call the `run` method to execute the code.
client.run();
Listening to Events
This feature allows you to listen to events from the sandbox. You can use the `listen` method to handle messages such as logs, errors, and other events emitted by the sandbox.
client.listen((message) => { console.log('Received message:', message); });
Updating Files
This feature allows you to update the content of a file in the sandbox. You can use the `updateFile` method to change the code of a specific file.
client.updateFile('/index.js', 'console.log("Updated code!");');
The `codesandbox` package provides a way to interact with CodeSandbox programmatically. It allows you to create, update, and manage sandboxes, similar to @codesandbox/sandpack-client. However, it is more focused on the overall management of sandboxes rather than embedding and interacting with them directly in web applications.
A bundler that completely works in the browser and takes advantage of it.
Online code playgrounds are getting more popular: they provide an easy way to play with code without installation.
As CodeSandbox came along, it had a pretty basic bundler. However, as CodeSandbox got more popular its bundler got more advanced. Nowadays the bundler is used for all kinds of bigger web projects, and it would be a shame if others couldn't use the functionality.
This library acts as an interface with the bundler of CodeSandbox. It allows you to run any code on a web page, from Vue projects to React projects to Parcel projects. With everything that CodeSandbox supports client side as well.
This is a list of features that the bundler supports out of the box, the list may be outdated.
module.hot
)!raw-loader!./test.js
)create-react-app
overlay)This repo serves as an interface to communicate with the bundler. The bundler
itself is hosted on {version}-sandpack.codesandbox.io
and is heavily cached by
a CDN. We also included the necessary files under sandpack
if you want to host
the bundler yourself.
The SandpackClient is a class implementation, you can import it from the package.
import { SandpackClient } from "@codesandbox/sandpack-client";
// There are two ways of initializing a preview, you can give it either an
// iframe element or a selector of an element to create an iframe on.
const client = new SandpackClient(
"#preview", // iframe selector or element itself
{
files: {
"/index.js": {
code: `console.log(require('uuid'))`,
},
},
entry: "/index.js",
dependencies: {
uuid: "latest",
},
} /* We support a third parameter for advanced options, you can find more info below */
);
// When you make a change you can just run `updatePreview`, we'll automatically discover
// which files have changed and hot reload them.
client.updatePreview({
files: {
"/index.js": {
code: `console.log('New Text!')`,
},
},
entry: "/index.js",
dependencies: {
uuid: "latest",
},
});
If you specify a package.json
in the list of files we will use that as source
of truth. Otherwise, we infer dependencies
and entry
from it:
// We infer dependencies and the entry point from package.json
const PACKAGE_JSON_CODE = JSON.stringify(
{
title: "test",
main: "index.js",
dependencies: {
uuid: "latest",
},
},
null,
2
);
// Give it either a selector or an iframe element as first argument, the second arguments are the files
const client = new SandpackClient("#preview", {
files: {
"/index.js": {
code: `console.log(require('uuid'))`,
},
"/package.json": {
code: PACKAGE_JSON_CODE,
},
},
});
The second argument in the constructor of SandpackClient
is all sandbox info.
It has this structure:
{
/**
* Files, keys are paths.
**/
files: {
[path: string]: {
code: string
}
},
/**
* Dependencies, supports npm and GitHub dependencies
**/
dependencies?: {
[dependencyName: string]: string
},
/**
* Default file to evaluate
**/
entry?: string,
/**
* The sandbox template to use, this is inferred from the files and package.json if not specified
**/
template?: string
}
The third argument in the constructor of SandpackClient
is extra options. Here
you can pass custom bundling/evaluation options or instructions for what and how
to render inside the iframe:
{
/**
* Location of the bundler. Defaults to `${version}-sandpack.codesandbox.io`
*/
bundlerURL?: string;
/**
* Width/Height of the iframe.
*/
width?: string;
height?: string;
/**
* If we should skip the third step: evaluation. Useful if you only want to see
* transpiled results
*/
skipEval?: boolean;
/**
* Boolean flags to trigger certain UI elements in the bundler
*/
showOpenInCodeSandbox?: boolean;
showErrorScreen?: boolean;
showLoadingScreen?: boolean;
}
The client instance has several helper functions you can call.
updatePreview
Send new content like files and dependencies, to the preview. It will
automatically hot update the preview with the new files and options. Accepts a
single argument sandboxInfo
of type SandboxInfo
.
updateOptions
Updates the given options and then updates the preview. Accepts a single
argument options
of type ClientOptions
.
dispatch
Dispatch an event to the bundler and all other listeners. Accepts a single
argument, which is the data to send. The dispatch
function will pass the
internal id
of the client, so only the bundler that performed the handshake
with this client instance will respond.
client.dispatch({ type: "refresh" }); // sends a refresh action to the bundler
listen
Listens to events coming from the bundler that performed the handshake with this
client instance. Uses the internal id
to filter events coming from other
bundlers.
client.listen((message) => {
if (message.type === "status") {
console.log(message.status);
}
});
getCodeSandboxURL
Create a sandbox from the current files and return an object in this form:
{
sandboxId: sandbox_id,
editorUrl: `https://codesandbox.io/s/${sandbox_id}`,
embedUrl: `https://codesandbox.io/embed/${sandbox_id}`,
}
import
?We have three reasons to host the bundler of sandpack externally:
The bundler evaluates and transpiles all files in an iframe under a different subdomain. This is important, because it prevents attackers from tampering with cookies of the host domain when evaluating code.
We heavily make use of Web Workers for transpilations. Almost all our transpilation happens in web workers, and there is no easy way yet to bundle this in a library.
Another reason to host the bundler externally is because of code splitting: we
split all our transpilers away and load them on-demand. If a user doesn't use
sass
we won't load the transpiler. This wouldn't be possible if we would give
one big JS file as the library.
We use Service Workers to download all transpilers in the background, so the next time a user visits your website they don't have to download the bundler anymore and it can be used offline. This is possible because we host the service worker externally.
I want to highlight that you can also host the bundler by yourself, all necessary files are in the
sandpack
folder.
If you want to host the bundler yourself, you will need to do a few things.
yarn install
).yarn build:deps
to build some of the packages lerna needs for internal links.yarn build:sandpack
.This creates a www
folder in the root of codesandbox-client
. That www
folder is the
sandpack folder sandpack-client connects to on {version}-sandpack.codesandbox.io
.
Once you have this hosted on your end you can pass bundlerURL
when calling:
new SandpackClient(iframe, sandboxInfo, {
bundlerURL: "https://your-hosted-version",
});
or, if you use sandpack-react, you can bundlerURL in the options
of the Sandpack preset.
If you want to integrate the sandpack bundler into your React project, we recomment you check out the sandpack-react package, which has all the components and hooks you need for building an instant code running experience for your users.
FAQs
Unknown package
The npm package @codesandbox/sandpack-client receives a total of 79,035 weekly downloads. As such, @codesandbox/sandpack-client popularity was classified as popular.
We found that @codesandbox/sandpack-client demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.
Security News
PEP 770 proposes adding SBOM support to Python packages to improve transparency and catch hidden non-Python dependencies that security tools often miss.