PGlite REPL Component
A REPL, or terminal, for use in the browser with PGlite, allowing you to have an interactive session with your WASM Postgres in the page.
This is the REPL with a full PGlite Postgres embedded in the page:
Features:
- Available as both a React.js component and a Web Component
- CodeMirror for input editing
- Auto complete, including table and column names from the database
- Input history (up and down keys)
\d
PSQL commands (via psql-describe)
React Component
bash
npm install @electric-sql/pglite-repl
then to include in a page:
tsx
import { PGlite } from '@electric-sql/pglite'
import { Repl } from '@electric-sql/pglite-repl'
function MyComponent() {
const pg = new PGlite()
return (
<>
<Repl pg={pg} />
</>
)
}
The props for the <Repl>
component are described by this interface:
ts
// The theme to use, auto is auto-switching based on the system
type ReplTheme = 'light' | 'dark' | 'auto'
interface ReplProps {
pg: PGlite // PGlite db instance
border?: boolean // Outer border on the component, defaults to false
lightTheme?: Extension
darkTheme?: Extension
theme?: ReplTheme // Defaults to "auto"
}
The lightTheme
and darkTheme
should be instances of a React CodeMirror theme.
Web Component
Although the PGlite REPL is built with React, it's also available as a web component for easy inclusion in any page or any other framework.
html
<script
src="https://cdn.jsdelivr.net/npm/@electric-sql/pglite/dist-webcomponent/Repl.js"
type="module"
></script>
<!-- Include the Repl web component in your page -->
<pglite-repl id="repl"></pglite-repl>
<script type="module">
import { PGlite } from 'https://cdn.jsdelivr.net/npm/@electric-sql/pglite/dist/index.js'
// Create a PGlite instance
const pg = new PGlite()
// Retrieve the Repl element
const repl = document.getElementById('repl')
// REPL to your PGlite instance
repl.pg = pg
</script>
With Vue.js
The REPL Web Component can be used with Vue.js:
vue
<script setup>
import { PGlite } from '@electric-sql/pglite'
import '@electric-sql/pglite-repl/webcomponent'
const pg = new PGlite()
</script>
<template>
<pglite-repl :pg="pg" />
</template>
You will also need to configure Vue to ignore the pglite-
prefix:
ts
app.config.compilerOptions.isCustomElement = (tag) => {
return tag.startsWith('pglite-')
}
See the Vue docs for more details.