<?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: B0OGI3</title>
    <description>The latest articles on DEV Community by B0OGI3 (@b0ogi3).</description>
    <link>https://dev.to/b0ogi3</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%2F3222612%2Fdd13c228-3f0e-45f7-95d5-abbfdde148c7.png</url>
      <title>DEV Community: B0OGI3</title>
      <link>https://dev.to/b0ogi3</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/b0ogi3"/>
    <language>en</language>
    <item>
      <title>How I Built a Firestore Admin Panel to Let Clients Manage Firebase Without Breaking the Database</title>
      <dc:creator>B0OGI3</dc:creator>
      <pubDate>Thu, 29 May 2025 15:05:05 +0000</pubDate>
      <link>https://dev.to/b0ogi3/how-i-built-a-firestore-admin-panel-to-let-clients-manage-firebase-without-breaking-the-database-3i32</link>
      <guid>https://dev.to/b0ogi3/how-i-built-a-firestore-admin-panel-to-let-clients-manage-firebase-without-breaking-the-database-3i32</guid>
      <description>&lt;h2&gt;
  
  
  Why I Built It
&lt;/h2&gt;

&lt;p&gt;As a freelance developer, I’ve handed Firebase projects off to clients who needed to update their app’s content themselves.&lt;/p&gt;

&lt;p&gt;But giving them access to the Firebase Console came with major problems:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Too technical&lt;/li&gt;
&lt;li&gt;No way to limit access&lt;/li&gt;
&lt;li&gt;One wrong click = production chaos 😬&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;So I built my own solution — a clean Firestore Admin Panel that gives teams access to just what they need, with full permission control.&lt;/p&gt;




&lt;h2&gt;
  
  
  What It Does
&lt;/h2&gt;

&lt;p&gt;🛠️ Features:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;🔄 Real-time Firestore document editing&lt;/li&gt;
&lt;li&gt;🔐 Role-based permissions (viewer, editor, admin)&lt;/li&gt;
&lt;li&gt;🧩 Dynamic collections + fields from Firestore itself&lt;/li&gt;
&lt;li&gt;🎨 Mantine UI v8 + Next.js App Router for clean UX&lt;/li&gt;
&lt;li&gt;🔥 Firebase Auth integration&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;It’s a no-code dashboard for anyone who wants to give &lt;strong&gt;controlled&lt;/strong&gt; Firestore access to non-devs (like clients, team leads, or content managers).&lt;/p&gt;




&lt;h2&gt;
  
  
  Stack Overview
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Frontend&lt;/strong&gt;: Next.js 15 (App Router)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;UI&lt;/strong&gt;: Mantine UI v8&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Auth&lt;/strong&gt;: Firebase Authentication&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Database&lt;/strong&gt;: Firestore (obviously)&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Extras&lt;/strong&gt;: Realtime updates, inline editing, dynamic modal rendering&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  The Goal
&lt;/h2&gt;

&lt;p&gt;I wanted:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Devs to stop giving full Console access to clients&lt;/li&gt;
&lt;li&gt;Non-devs to update data easily without risk&lt;/li&gt;
&lt;li&gt;Myself to stop getting panicked “I broke the database” messages&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  Want to Try It?
&lt;/h2&gt;

&lt;p&gt;Here’s the demo (read-only):&lt;br&gt;&lt;br&gt;
👉 &lt;a href="https://firestore-admin-panel.vercel.app" rel="noopener noreferrer"&gt;firestore-admin-panel.vercel.app&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;And if you want the full version or want to support my work:&lt;br&gt;&lt;br&gt;
📦 &lt;a href="https://iandavishub.gumroad.com/l/firestore-admin-panel" rel="noopener noreferrer"&gt;Gumroad Product Page&lt;/a&gt;&lt;/p&gt;




&lt;h2&gt;
  
  
  I’d Love Feedback
&lt;/h2&gt;

&lt;p&gt;If you’ve used Firebase/Firestore:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;What other features would you expect?&lt;/li&gt;
&lt;li&gt;Would you give this to clients?&lt;/li&gt;
&lt;li&gt;Would you use it yourself?&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Drop a comment or DM me — always happy to learn and improve!&lt;/p&gt;

</description>
      <category>firebase</category>
      <category>nextjs</category>
      <category>webdev</category>
      <category>saas</category>
    </item>
  </channel>
</rss>
