ai-jsx-test
v0.5.17
Published
[data:image/s3,"s3://crabby-images/58334/58334c0a4744c6fc98777ca9dd181bf436efbfb5" alt="Docs Site"](https://docs.ai-jsx.com) [data:image/s3,"s3://crabby-images/98e55/98e551d55808180db0a7b41a04eb59c71d46e192" alt="Discord Follow"](https://discord.gg/MsKAeKF8kU) [data:image/s3,"s3://crabby-images/fbf30/fbf302faf6a726b506b4ac87e6c9296568a1e0ed" alt="Twitter Follow".
Here is a simple example using AI.JSX to generate an AI response to a prompt:
import * as AI from 'ai-jsx';
import { ChatCompletion, UserMessage } from 'ai-jsx/core/completion';
const app = (
<ChatCompletion>
<UserMessage>Write a Shakespearean sonnet about AI models.</UserMessage>
</ChatCompletion>
);
const renderContext = AI.createRenderContext();
const response = await renderContext.render(app);
console.log(response);
Here's a more complex example that uses the built-in <Inline>
component to progressively generate multiple fields in a JSON object:
function CharacterGenerator() {
const inlineCompletion = (prompt: Node) => (
<Completion stop={['"']} temperature={1.0}>
{prompt}
</Completion>
);
return (
<Inline>
Generate a character profile for a fantasy role-playing game in JSON format.{'\n'}
{'{'}
{'\n '}"name": "{inlineCompletion}",
{'\n '}"class": "{inlineCompletion}",
{'\n '}"race": "{inlineCompletion}",
{'\n '}"alignment": "{inlineCompletion}",
{'\n '}"weapons": "{inlineCompletion}",
{'\n '}"spells": "{inlineCompletion}",
{'\n}'}
</Inline>
);
}
For a full set of examples, see the examples package.
Features
- Prompt engineering through modular, reusable components
- The ability to easily switch between model providers and LLM configurations (e.g., temperature)
- Built in support for Tools (ReAct pattern), Document Question and Answering, Chain of Thought, and more
- Ability to directly interweave LLM calls with standard UI components, including the ability for the LLM to render the UI from a set of provided components
- Built-in streaming support
- First-class support for NextJS and Create React App (more coming soon)
- Full support for LangChainJS
Contributing
We welcome contributions! See Contributing for how to get started.