<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Abhilash Reddy Chitiki</title>
    <description>The latest articles on DEV Community by Abhilash Reddy Chitiki (@abhilash_reddychitiki_06).</description>
    <link>https://dev.to/abhilash_reddychitiki_06</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F3935325%2F5e1c33e8-db30-440f-af64-bc45b811d9d7.png</url>
      <title>DEV Community: Abhilash Reddy Chitiki</title>
      <link>https://dev.to/abhilash_reddychitiki_06</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/abhilash_reddychitiki_06"/>
    <language>en</language>
    <item>
      <title>How I Built Memory Concierge: An AI Hotel Concierge That Remembers Guests</title>
      <dc:creator>Abhilash Reddy Chitiki</dc:creator>
      <pubDate>Sat, 16 May 2026 18:47:05 +0000</pubDate>
      <link>https://dev.to/abhilash_reddychitiki_06/how-i-built-memory-concierge-an-ai-hotel-concierge-that-remembers-guests-48ll</link>
      <guid>https://dev.to/abhilash_reddychitiki_06/how-i-built-memory-concierge-an-ai-hotel-concierge-that-remembers-guests-48ll</guid>
      <description>&lt;h2&gt;
  
  
  How I Built Memory Concierge: An AI Hotel Concierge That Remembers Guests
&lt;/h2&gt;

&lt;p&gt;I built &lt;strong&gt;Memory Concierge&lt;/strong&gt;, an AI-powered hotel concierge prototype that remembers returning guests and helps hotel staff personalize a stay before the guest even asks.&lt;/p&gt;

&lt;p&gt;The project is built around a fictional luxury hotel called &lt;strong&gt;The Aurelian Vale&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;The idea is simple:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;What if hotel service could feel proactive instead of repetitive?&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Instead of making guests repeat their preferences every time they return, Memory Concierge helps staff remember, prepare, and adapt the guest experience in real time.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://memory-concierge.vercel.app/" rel="noopener noreferrer"&gt;Live Demo&lt;/a&gt; | &lt;a href="https://github.com/abhilashreddychitiki/Memory-Concierge" rel="noopener noreferrer"&gt;GitHub Repo&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F9ccrf5ay8zpvm0t767qb.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F9ccrf5ay8zpvm0t767qb.png" alt="Memory Concierge dashboard preview"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;Memory Concierge dashboard for The Aurelian Vale.&lt;/em&gt;&lt;/p&gt;




&lt;h2&gt;
  
  
  Table of Contents
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Why I Built This&lt;/li&gt;
&lt;li&gt;What Memory Concierge Does&lt;/li&gt;
&lt;li&gt;Tech Stack&lt;/li&gt;
&lt;li&gt;How I Used AI&lt;/li&gt;
&lt;li&gt;How The App Works&lt;/li&gt;
&lt;li&gt;Using NVIDIA NIM&lt;/li&gt;
&lt;li&gt;Why Structured JSON Matters&lt;/li&gt;
&lt;li&gt;Real-Time Adaptation&lt;/li&gt;
&lt;li&gt;Adding Voice With ElevenLabs&lt;/li&gt;
&lt;li&gt;What I Learned&lt;/li&gt;
&lt;li&gt;What I Would Build Next&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  Why I Built This
&lt;/h2&gt;

&lt;p&gt;I wanted to build an AI project that felt like a &lt;strong&gt;real workflow&lt;/strong&gt;, not just another chatbot.&lt;/p&gt;

&lt;p&gt;Hotels already collect a lot of useful guest information:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Room temperature preferences&lt;/li&gt;
&lt;li&gt;Pillow type&lt;/li&gt;
&lt;li&gt;Dietary restrictions&lt;/li&gt;
&lt;li&gt;Favorite drinks&lt;/li&gt;
&lt;li&gt;Morning routines&lt;/li&gt;
&lt;li&gt;Meeting schedules&lt;/li&gt;
&lt;li&gt;Past celebrations&lt;/li&gt;
&lt;li&gt;Arrival details&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;But that information is often scattered or underused.&lt;/p&gt;

&lt;p&gt;A returning guest may still need to repeat the same preferences every time they arrive.&lt;/p&gt;

&lt;p&gt;I wanted to explore a different experience:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;The hotel already remembers you, and the concierge quietly adapts before you ask.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;That became the core idea behind &lt;strong&gt;Memory Concierge&lt;/strong&gt;.&lt;/p&gt;




&lt;h2&gt;
  
  
  What Memory Concierge Does
&lt;/h2&gt;

&lt;p&gt;Memory Concierge is a staff-facing dashboard.&lt;/p&gt;

&lt;p&gt;A staff member can select an arriving guest, and the app generates:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;A personalized welcome message&lt;/li&gt;
&lt;li&gt;Room preparation details&lt;/li&gt;
&lt;li&gt;Dinner or arrival adjustments&lt;/li&gt;
&lt;li&gt;A tomorrow morning brief&lt;/li&gt;
&lt;li&gt;A memory-based concierge note&lt;/li&gt;
&lt;li&gt;Real-time adaptation for events like delayed flights&lt;/li&gt;
&lt;li&gt;Optional voice playback for the welcome message&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The main demo guest is &lt;strong&gt;Sarah Chen&lt;/strong&gt;, a returning guest whose flight is delayed by two hours.&lt;/p&gt;

&lt;p&gt;The concierge already knows Sarah prefers:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;A high-floor city-view room&lt;/li&gt;
&lt;li&gt;68°F room temperature&lt;/li&gt;
&lt;li&gt;Firm pillows&lt;/li&gt;
&lt;li&gt;Burgundy Pinot Noir&lt;/li&gt;
&lt;li&gt;Sparkling water&lt;/li&gt;
&lt;li&gt;A yoga mat&lt;/li&gt;
&lt;li&gt;A morning gym routine&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;When her delayed flight is selected, the app generates an updated stay plan and a calm guest-facing message.&lt;/p&gt;

&lt;p&gt;That is the main product idea: &lt;strong&gt;proactive hospitality powered by memory&lt;/strong&gt;.&lt;/p&gt;




&lt;h2&gt;
  
  
  Tech Stack
&lt;/h2&gt;

&lt;p&gt;I built Memory Concierge with:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;Next.js 14 App Router&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;TypeScript&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Tailwind CSS&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Framer Motion&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Lucide React&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;NVIDIA NIM&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Llama 3.1 70B Instruct&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;ElevenLabs text-to-speech&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Local JSON guest data&lt;/strong&gt;&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;Codex as a development partner&lt;/strong&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The project is intentionally lightweight. There is no database and no authentication in the prototype. Guest memory is stored locally in &lt;code&gt;data/guests.json&lt;/code&gt; so the demo stays simple and reliable.&lt;/p&gt;




&lt;h2&gt;
  
  
  How I Used AI
&lt;/h2&gt;

&lt;p&gt;AI was used in two different ways.&lt;/p&gt;

&lt;p&gt;First, I used &lt;strong&gt;Codex&lt;/strong&gt; while building the project. It helped me scaffold the app, debug TypeScript issues, improve the README, polish the UI, and document the project.&lt;/p&gt;

&lt;p&gt;Second, the app itself uses AI at runtime. When a guest is selected, the app sends guest context to NVIDIA's Llama model and asks it to return structured JSON for the dashboard.&lt;/p&gt;

&lt;p&gt;So the AI is not just chatting — it is powering a workflow.&lt;/p&gt;




&lt;h2&gt;
  
  
  How The App Works
&lt;/h2&gt;

&lt;p&gt;The project structure looks like this:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;app/
  api/
    adapt/route.ts
    voice/route.ts
    welcome/route.ts
  globals.css
  layout.tsx
  page.tsx

components/
  AlertBanner.tsx
  DashboardHeader.tsx
  GuestSelector.tsx
  ItineraryCard.tsx
  MemoryTimeline.tsx
  RoomReadyCard.tsx
  TriggerPanel.tsx
  VoiceButton.tsx

data/
  guests.json

lib/
  elevenlabs.ts
  json.ts
  openai.ts
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;The main flow is:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;A staff member selects a guest.&lt;/li&gt;
&lt;li&gt;The frontend sends that guest profile to &lt;code&gt;/api/welcome&lt;/code&gt;.&lt;/li&gt;
&lt;li&gt;The API route calls the AI model.&lt;/li&gt;
&lt;li&gt;The model returns structured JSON.&lt;/li&gt;
&lt;li&gt;The dashboard renders the welcome, room status, dinner note, and tomorrow brief.&lt;/li&gt;
&lt;li&gt;A staff member can trigger a real-time event.&lt;/li&gt;
&lt;li&gt;The app calls &lt;code&gt;/api/adapt&lt;/code&gt;.&lt;/li&gt;
&lt;li&gt;The model returns updated actions and a guest-facing message.&lt;/li&gt;
&lt;/ol&gt;




&lt;h2&gt;
  
  
  Using NVIDIA NIM
&lt;/h2&gt;

&lt;p&gt;I used the OpenAI JavaScript SDK, but pointed it at NVIDIA's OpenAI-compatible endpoint.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight typescript"&gt;&lt;code&gt;&lt;span class="k"&gt;import&lt;/span&gt; &lt;span class="nx"&gt;OpenAI&lt;/span&gt; &lt;span class="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;openai&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="k"&gt;export&lt;/span&gt; &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;NVIDIA_MODEL&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;meta/llama-3.1-70b-instruct&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="k"&gt;export&lt;/span&gt; &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;openai&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nc"&gt;OpenAI&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt;
  &lt;span class="na"&gt;apiKey&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;process&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;env&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;NVIDIA_API_KEY&lt;/span&gt; &lt;span class="o"&gt;??&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;missing-nvidia-api-key&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="na"&gt;baseURL&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;https://integrate.api.nvidia.com/v1&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;The model used is:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;meta/llama-3.1-70b-instruct
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;I chose this because the project needs clean JSON responses that the frontend can render reliably.&lt;/p&gt;




&lt;h2&gt;
  
  
  Why Structured JSON Matters
&lt;/h2&gt;

&lt;p&gt;One important design decision was asking the model for structured output instead of free-form text.&lt;/p&gt;

&lt;p&gt;The &lt;code&gt;/api/welcome&lt;/code&gt; route asks for JSON like this:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight json"&gt;&lt;code&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"welcome_message"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"A warm personalized welcome"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"room_status"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"Room preparation details"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"dinner_note"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"Dinner or arrival adjustment"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"tomorrow_brief"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"Morning schedule preview"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"concierge_note"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"Personal memory-based note"&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;This matters because each field maps to a specific part of the dashboard. The model is not just generating text — it is generating UI-ready data. That made the app feel much more reliable.&lt;/p&gt;




&lt;h2&gt;
  
  
  Real-Time Adaptation
&lt;/h2&gt;

&lt;p&gt;The &lt;code&gt;/api/adapt&lt;/code&gt; route powers the event buttons in the dashboard.&lt;/p&gt;

&lt;p&gt;Example events include:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Flight delayed 2 hours&lt;/li&gt;
&lt;li&gt;Guest went vegan&lt;/li&gt;
&lt;li&gt;Needs quiet room&lt;/li&gt;
&lt;li&gt;Dinner moved to 9 PM&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;The model returns:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight json"&gt;&lt;code&gt;&lt;span class="p"&gt;{&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"alert_title"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"Flight Delay Handled"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"alert_detail"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"The arrival plan has been adjusted around the delayed flight."&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"actions_taken"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="s2"&gt;"Updated check-in timing"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="s2"&gt;"Held room preparation"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;&lt;span class="w"&gt;
    &lt;/span&gt;&lt;span class="s2"&gt;"Adjusted dinner reservation"&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="p"&gt;],&lt;/span&gt;&lt;span class="w"&gt;
  &lt;/span&gt;&lt;span class="nl"&gt;"guest_message"&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;&lt;span class="w"&gt; &lt;/span&gt;&lt;span class="s2"&gt;"Your arrival has been adjusted and everything will be ready when you arrive."&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="w"&gt;
&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;This is what makes the project feel like an active concierge system instead of a static guest profile page.&lt;/p&gt;




&lt;h2&gt;
  
  
  Adding Voice With ElevenLabs
&lt;/h2&gt;

&lt;p&gt;I also added optional voice playback.&lt;/p&gt;

&lt;p&gt;When the user clicks &lt;strong&gt;Play Welcome&lt;/strong&gt;, the app sends the generated welcome message to &lt;code&gt;/api/voice&lt;/code&gt;. That route uses ElevenLabs to generate MP3 audio.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight typescript"&gt;&lt;code&gt;&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;audioStream&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;await&lt;/span&gt; &lt;span class="nx"&gt;elevenlabs&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;textToSpeech&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;convert&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;CONCIERGE_VOICE_ID&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nx"&gt;text&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="na"&gt;model_id&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;eleven_v3&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="na"&gt;output_format&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;mp3_44100_128&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="na"&gt;voice_settings&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="na"&gt;stability&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="mf"&gt;0.6&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;similarity_boost&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="mf"&gt;0.85&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;style&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="mf"&gt;0.2&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
    &lt;span class="na"&gt;use_speaker_boost&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="kc"&gt;true&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;I made voice generation user-triggered because it costs API credits and should only run when the user actually wants to hear the welcome message.&lt;/p&gt;




&lt;h2&gt;
  
  
  What I Learned
&lt;/h2&gt;

&lt;p&gt;The biggest lesson was that AI products work better when the model has a clear job.&lt;/p&gt;

&lt;p&gt;For this project, the model was not asked to be a generic assistant. It was asked to act as a luxury hotel concierge and return specific structured fields. That made the output much easier to trust and display.&lt;/p&gt;

&lt;p&gt;I also learned that polish matters a lot in AI demos. Small details like loading states, clear cards, strong README documentation, a screenshot, and a simple story make the project easier to understand.&lt;/p&gt;




&lt;h2&gt;
  
  
  What I Would Build Next
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;A demo GIF showing the full interaction&lt;/li&gt;
&lt;li&gt;More guest profiles&lt;/li&gt;
&lt;li&gt;Database-backed guest memory&lt;/li&gt;
&lt;li&gt;Authentication and staff roles&lt;/li&gt;
&lt;li&gt;Real flight-status integration&lt;/li&gt;
&lt;li&gt;Staff approval before sending messages&lt;/li&gt;
&lt;li&gt;Audit logs for AI-generated actions&lt;/li&gt;
&lt;li&gt;Multilingual concierge responses&lt;/li&gt;
&lt;li&gt;Schema validation for AI responses&lt;/li&gt;
&lt;li&gt;Tests for API routes and UI states&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  Final Thoughts
&lt;/h2&gt;

&lt;p&gt;Memory Concierge helped me think about AI as a workflow layer.&lt;/p&gt;

&lt;p&gt;The most useful AI products may not be the ones that chat the most. They may be the ones that quietly read context, return structured output, and help people act faster.&lt;/p&gt;

&lt;p&gt;That was the goal of Memory Concierge:&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Make guest memory useful at the exact moment service happens.&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://memory-concierge.vercel.app/" rel="noopener noreferrer"&gt;Try the live demo&lt;/a&gt; | &lt;a href="https://github.com/abhilashreddychitiki/Memory-Concierge" rel="noopener noreferrer"&gt;View the source code&lt;/a&gt;&lt;/p&gt;

</description>
      <category>ai</category>
      <category>nextjs</category>
      <category>webdev</category>
      <category>typescript</category>
    </item>
  </channel>
</rss>
