| 123456789101112131415161718192021222324252627282930313233343536 |
- import { feature } from 'bun:bundle'
- import type { Message } from '../types/message.js'
- import type { Attachment } from '../utils/attachments.js'
- import { getGlobalConfig } from '../utils/config.js'
- import { getCompanion } from './companion.js'
- export function companionIntroText(name: string, species: string): string {
- return `# Companion
- A small ${species} named ${name} sits beside the user's input box and occasionally comments in a speech bubble. You're not ${name} — it's a separate watcher.
- When the user addresses ${name} directly (by name), its bubble will answer. Your job in that moment is to stay out of the way: respond in ONE line or less, or just answer any part of the message meant for you. Don't explain that you're not ${name} — they know. Don't narrate what ${name} might say — the bubble handles that.`
- }
- export function getCompanionIntroAttachment(
- messages: Message[] | undefined,
- ): Attachment[] {
- if (!feature('BUDDY')) return []
- const companion = getCompanion()
- if (!companion || getGlobalConfig().companionMuted) return []
- // Skip if already announced for this companion.
- for (const msg of messages ?? []) {
- if (msg.type !== 'attachment') continue
- if (msg.attachment.type !== 'companion_intro') continue
- if (msg.attachment.name === companion.name) return []
- }
- return [
- {
- type: 'companion_intro',
- name: companion.name,
- species: companion.species,
- },
- ]
- }
|