tealbase-js
- Isomorphic JavaScript Client for tealbase.First of all, you need to install the library:
npm install @tealbase/tealbase-js
Then you're able to import the library and establish the connection with the database:
import { createClient } from '@tealbase/tealbase-js'
// Create a single tealbase client for interacting with your database
const tealbase = createClient('https://xyzcompany.tealbase.co', 'public-anon-key')
You can use plain <script>
s to import tealbase-js from CDNs, like:
<script src="https://cdn.jsdelivr.net/npm/@tealbase/tealbase-js@2"></script>
or even:
<script src="https://unpkg.com/@tealbase/tealbase-js@2"></script>
Then you can use it from a global tealbase
variable:
<script>
const { createClient } = tealbase
const _tealbase = createClient('https://xyzcompany.tealbase.co', 'public-anon-key')
console.log('tealbase Instance: ', _tealbase)
// ...
</script>
You can use <script type="module">
to import tealbase-js from CDNs, like:
<script type="module">
import { createClient } from 'https://cdn.jsdelivr.net/npm/@tealbase/tealbase-js/+esm'
const tealbase = createClient('https://xyzcompany.tealbase.co', 'public-anon-key')
console.log('tealbase Instance: ', tealbase)
// ...
</script>
You can use tealbase-js in the Deno runtime via JSR:
import { createClient } from 'jsr:@tealbase/tealbase-js@2'
fetch
implementationtealbase-js
uses the cross-fetch
library to make HTTP requests, but an alternative fetch
implementation can be provided as an option. This is most useful in environments where cross-fetch
is not compatible, for instance Cloudflare Workers:
import { createClient } from '@tealbase/tealbase-js'
// Provide a custom `fetch` implementation as an option
const tealbase = createClient('https://xyzcompany.tealbase.co', 'public-anon-key', {
global: {
fetch: (...args) => fetch(...args),
},
})
This section outlines the scope of support for various runtime environments in tealbase JavaScript client.
We only support Node.js versions that are in Active LTS or Maintenance status as defined by the official Node.js release schedule. This means we support versions that are currently receiving long-term support and critical bug fixes.
When a Node.js version reaches end-of-life and is no longer in Active LTS or Maintenance status, tealbase will drop it in a minor release, and this won't be considered a breaking change.
We support Deno versions that are currently receiving active development and security updates. We follow the official Deno release schedule and only support versions from the stable
and lts
release channels.
When a Deno version reaches end-of-life and is no longer receiving security updates, tealbase will drop it in a minor release, and this won't be considered a breaking change.
pnpm test
tealbase start
pnpm run test:integration
The project includes Expo integration tests to ensure compatibility with React Native environments.
The project includes Next.js integration tests to ensure compatibility with React SSR environments.
The project includes Deno integration tests to ensure compatibility with Deno runtime.
The project includes Bun integration tests to ensure compatibility with Bun runtime.
When running on CI, the tests automatically use the latest dependencies from the root project. The CI pipeline:
.tgz
) with the latest versionsFor local development of Expo, Next.js, and Deno tests, you can update dependencies using automated scripts:
# Update all test dependencies at once
npm run update:test-deps
# Or update specific test environments:
npm run update:test-deps:expo # Expo tests only
npm run update:test-deps:next # Next.js tests only
npm run update:test-deps:deno # Deno tests only
npm run update:test-deps:bun # Bun tests only
Note: The CI automatically handles dependency synchronization, so manual updates are only needed for local development and testing.