Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/c-o-l-i-n/ng-generative-ai-demo
🤖 Stream realtime generative AI to your Angular app using Google Gemini, HttpClient, RxJS, and Signals
https://github.com/c-o-l-i-n/ng-generative-ai-demo
ai angular gemini gemini-api generative-ai rxjs signals
Last synced: 2 months ago
JSON representation
🤖 Stream realtime generative AI to your Angular app using Google Gemini, HttpClient, RxJS, and Signals
- Host: GitHub
- URL: https://github.com/c-o-l-i-n/ng-generative-ai-demo
- Owner: c-o-l-i-n
- Created: 2024-02-17T10:37:13.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-03-02T18:51:49.000Z (11 months ago)
- Last Synced: 2024-07-25T18:39:24.241Z (6 months ago)
- Topics: ai, angular, gemini, gemini-api, generative-ai, rxjs, signals
- Language: TypeScript
- Homepage:
- Size: 116 KB
- Stars: 8
- Watchers: 1
- Forks: 4
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-angular - ng-generative-ai-demo - Result from this [angular-ai-chatbot tutorial](https://colinaw.com/blog/angular-ai-chatbot/). (Table of contents / Angular)
- fucking-awesome-angular - ng-generative-ai-demo - Result from this 🌎 [angular-ai-chatbot tutorial](colinaw.com/blog/angular-ai-chatbot/). (Table of contents / Angular)
- fucking-awesome-angular - ng-generative-ai-demo - Result from this 🌎 [angular-ai-chatbot tutorial](colinaw.com/blog/angular-ai-chatbot/). (Table of contents / Angular)
README
# 🤖 Angular Generative AI Demo
[Demo](https://github.com/c-o-l-i-n/ng-generative-ai-demo/assets/40863449/b296b7b6-c6b4-4f83-adcb-de9c98c2c00f)
## 🤔 Why does this matter?
Generative AI is changing the way we interact with technology. As AI chatbots become more commonplace, users expect certain behaviors from our apps, such as realtime text updates. Using LLM APIs, Signals, and some RxJS magic, we can create modern AI-driven user experiences.
## 🏃 Getting started
> [!NOTE]
> The Gemini API is free, so long as you're willing to share all of your usage data with Google.1. Run `git clone https://github.com/c-o-l-i-n/ng-generative-ai-demo.git` to clone this repo.
2. Visit the [Google AI Studio](https://aistudio.google.com/app/apikey) to generate an API key.
3. Create a `.env` file in the project root with your API key:
```
GOOGLE_AI_STUDIO_API_KEY=paste-api-key-here
```4. Run `npm install` to install dependencies.
5. Run `npm run server` to start the backend server (`server.ts`) on port 3000.
6. In another terminal, run `npm start` to start the Angular dev server on port 4200.
7. Navigate to `http://localhost:4200/`
## 🔑 Key takeaways
- **Manage State with Signals:** Keep track of the chat state (list of messages and whether the LLM is generating a new message) with Angular Signals.
- **Realtime Text Streaming with RxJS Observables:** Utilize RxJS to react to realtime updates from the LLM API.
- **HTTP Client Configuration:** Configure the Angular HTTP client to handle realtime text streams:
1. Provide the HTTP client "with fetch" in [`app.config.ts`](src/app/app.config.ts):
```typescript
provideHttpClient(withFetch());
```2. Tell the HTTP client to observe text events and report progress:
```typescript
this.http.post('http://localhost:3000/message', prompt, {
responseType: 'text',
observe: 'events',
reportProgress: true,
});
```- **Blinking Cursor:** Create a blinking cursor effect using the CSS `::after` pseudo-element and CSS `@keyframes`:
```scss
.message {
&.generating {
&::after {
content: '▋';
animation: fade-cursor ease-in-out 500ms infinite alternate;
}
}
}@keyframes fade-cursor {
from {
opacity: 25%;
}
to {
opacity: 100%;
}
}
```## 🔭 Files to explore
- [`message.service.ts`](src/app/message.service.ts)
- [`app.config.ts`](src/app/app.config.ts)
- [`server.ts`](src/server.ts)