StoryTeller
Interactive choice-based storytelling with feature flags! Explore branching narratives, use AIStoryTeller with Grok API for custom tales with text-to-speech, and manage via Flagsmith.
视频
描述
I set out to build StoryTeller, an interactive choice-based storytelling app, where I could weave tales with the magic of feature flags. Inspired by dynamic content delivery, I crafted a world where users shape their own narratives. Later, I unleashed AIStoryTeller, my proudest creation, powered by the Grok API, bringing custom stories to life with text-to-speech narration.
The Features I Forged
- Interactive Stories: I designed branching paths for adventurers to choose their destiny. 
- Feature Flag Integration: I harnessed Flagsmith to toggle features in real-time. 
- Admin Dashboard: I built a control panel for admins to wield power over the experience. 
- Dynamic Theming: I added theme shifts tied to story moods, when enabled. 
- Responsive Design: I ensured the tale shines on desktops and mobiles. 
- AIStoryTeller: I crafted a floating chatbot that conjures unique stories with medieval, futuristic, or horror themes, read aloud with a voice. 
The Tools I Wielded
I forged this with:
- React and TypeScript, my languages of choice. 
- Vite, speeding my development and builds. 
- React Router, guiding the narrative paths. 
- Tailwind CSS, styling the realm’s beauty. 
- Shadcn UI, providing my component arsenal. 
- Flagsmith, managing my feature flag spells. 
- Grok API, fueling my AI storytelling magic. 
My Quest to Bring It to Life
What I Needed
- Node.js (v16 or higher), my coding elixir. 
- npm or yarn, my trusty tools. 
How I Built It
- I gathered my resources: - bash - CollapseWrapCopy - npm install # or yarn install
- I unlocked the secrets with a .env file: - VITE_FLAGSMITH_ENVIRONMENT_ID=your_flagsmith_environment_id VITE_GROQ_API_KEY=your_groq_api_key VITE_FLAGSMITH_PROJECT_ID= VITE_FLAGSMITH_API_KEY=
- I sparked the magic: - npm run dev # or yarn dev
The Flags I Mastered
I used Flagsmith to control these powers:
| Flag Name | What It Does | 
|---|---|
| enable_dynamic_themes | Lets me shift themes with the story’s mood | 
| use_first_person_narrative | Puts the hero in their own voice | 
| enable_detective_story | Unlocks a mystery tale I crafted | 
| enable_story_sharing | Lets users share my tales | 
| is_admin | Grants access to my admin sanctum | 
Setting Up My Flagsmith Realm
- I joined flagsmith.com and claimed my account. 
- I created a project and environment. 
- I inscribed the feature flags above. 
- I sealed the environment ID in my .env file. 
The Realm I Structured
/src
/components # My village of UI components
/admin # My admin’s keep
/feature-flags # My flagsmith’s forge
/layout # My castle walls
/stories # My tale-weaver’s hall
/ui # My artisan’s tools
/contexts # My sacred contexts
/lib # My wizard’s grimoire
/types # My scrolls of type
The Spells I Cast
- npm run dev - I ignited my development flame 
- npm run build - I forged my production relic 
- npm run preview - I gazed upon my crafted world 
本次黑客松进展
90