<?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: Antar Mukhopadhyaya</title>
    <description>The latest articles on DEV Community by Antar Mukhopadhyaya (@antar_mukhopadhyaya).</description>
    <link>https://dev.to/antar_mukhopadhyaya</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%2F1713505%2F1e9d11ab-8dc8-4a8b-be10-b6fd0c5e5dfe.jpg</url>
      <title>DEV Community: Antar Mukhopadhyaya</title>
      <link>https://dev.to/antar_mukhopadhyaya</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/antar_mukhopadhyaya"/>
    <language>en</language>
    <item>
      <title>I got tired of setting up the same stack 50+ times — so I built this</title>
      <dc:creator>Antar Mukhopadhyaya</dc:creator>
      <pubDate>Thu, 09 Apr 2026 06:39:38 +0000</pubDate>
      <link>https://dev.to/antar_mukhopadhyaya/i-got-tired-of-setting-up-the-same-stack-50-times-so-i-built-this-1h1c</link>
      <guid>https://dev.to/antar_mukhopadhyaya/i-got-tired-of-setting-up-the-same-stack-50-times-so-i-built-this-1h1c</guid>
      <description>&lt;p&gt;I didn’t procrastinate because I was lazy.&lt;/p&gt;

&lt;p&gt;I procrastinated because I didn’t want to deal with setup.&lt;/p&gt;

&lt;p&gt;Next.js. Auth. Database.&lt;/p&gt;

&lt;p&gt;Not hard.&lt;/p&gt;

&lt;p&gt;Just enough friction to stop me from starting.&lt;/p&gt;




&lt;h2&gt;
  
  
  The idea was simple
&lt;/h2&gt;

&lt;p&gt;One day I wanted to build a small app for myself — a simple fact memorization app.&lt;/p&gt;

&lt;p&gt;Every day it would show me 5–6 facts and prompt me to add new ones for my competitive exams.&lt;/p&gt;

&lt;p&gt;Nothing complex. Just something useful.&lt;/p&gt;

&lt;p&gt;I was ready to build it.&lt;/p&gt;




&lt;h2&gt;
  
  
  The stack I kept repeating
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;Expo + NativeWind + Supabase
&lt;/li&gt;
&lt;li&gt;Next.js + Auth + Database
&lt;/li&gt;
&lt;li&gt;Same configs. Same steps. Every time
&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;I’ve done this 40–60 times.&lt;/p&gt;

&lt;p&gt;At some point, it’s not learning anymore.&lt;/p&gt;

&lt;p&gt;It’s just repetition.&lt;/p&gt;




&lt;h2&gt;
  
  
  Then reality hit
&lt;/h2&gt;

&lt;p&gt;Before writing a single line of actual logic, I had to:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Set up Expo
&lt;/li&gt;
&lt;li&gt;Install NativeWind packages
&lt;/li&gt;
&lt;li&gt;Configure NativeWind, Babel, and Metro
&lt;/li&gt;
&lt;li&gt;Wire Supabase into the app
&lt;/li&gt;
&lt;li&gt;Install and configure additional tools like TanStack Query
&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;And I just paused.&lt;/p&gt;

&lt;p&gt;Because I’ve done this before.&lt;/p&gt;

&lt;p&gt;Not once. Not twice.&lt;/p&gt;

&lt;p&gt;But dozens of times.&lt;/p&gt;




&lt;h2&gt;
  
  
  The real problem
&lt;/h2&gt;

&lt;p&gt;Setting things up isn’t hard.&lt;/p&gt;

&lt;p&gt;That’s not the issue.&lt;/p&gt;

&lt;p&gt;The issue is what it does to your brain.&lt;/p&gt;

&lt;p&gt;To set up a modern stack, you end up:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;opening multiple tabs
&lt;/li&gt;
&lt;li&gt;reading scattered documentation
&lt;/li&gt;
&lt;li&gt;switching between configs
&lt;/li&gt;
&lt;li&gt;debugging small, annoying errors
&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Sometimes you miss one tiny step — like updating &lt;code&gt;metro.config.js&lt;/code&gt; — and suddenly things break.&lt;/p&gt;

&lt;p&gt;Now you’re debugging instead of building.&lt;/p&gt;




&lt;h2&gt;
  
  
  And momentum is gone
&lt;/h2&gt;

&lt;p&gt;By the time everything finally works, I’ve already lost most of my momentum.&lt;/p&gt;

&lt;p&gt;Not because I don’t know what to do.&lt;/p&gt;

&lt;p&gt;But because my focus got fragmented.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;The insight:&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;The problem isn’t time.&lt;/p&gt;

&lt;p&gt;The problem is context switching.&lt;/p&gt;

&lt;p&gt;Your brain is wired for deep work.&lt;/p&gt;

&lt;p&gt;But setup forces you to constantly switch context before you even start building.&lt;/p&gt;




&lt;h2&gt;
  
  
  Repetition makes it worse
&lt;/h2&gt;

&lt;p&gt;The first time you set up a stack, you’re learning.&lt;/p&gt;

&lt;p&gt;The tenth time, you’re faster.&lt;/p&gt;

&lt;p&gt;The fiftieth time?&lt;/p&gt;

&lt;p&gt;You’re just repeating yourself.&lt;/p&gt;

&lt;p&gt;At that point, it’s no longer learning.&lt;/p&gt;

&lt;p&gt;It’s friction.&lt;/p&gt;




&lt;h2&gt;
  
  
  So I built something for myself
&lt;/h2&gt;

&lt;p&gt;I didn’t want to feel this every time I started a project.&lt;/p&gt;

&lt;p&gt;So I built a CLI tool called &lt;strong&gt;Forge&lt;/strong&gt;.&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Define your stack once. Reuse it forever.&lt;/p&gt;
&lt;/blockquote&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%2F70817b0pkiocjtat5o3u.gif" 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%2F70817b0pkiocjtat5o3u.gif" alt="Forge CLI Demo" width="1200" height="720"&gt;&lt;/a&gt;&lt;/p&gt;




&lt;h2&gt;
  
  
  What Forge does
&lt;/h2&gt;

&lt;p&gt;Forge lets you scaffold complete setups using presets.&lt;/p&gt;

&lt;p&gt;Instead of manually wiring everything every time, you just run:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;npx @antardev/forge-dev init next-saas-pro my-app
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;And you're ready to start building.&lt;/p&gt;

&lt;p&gt;No configs. No context switching. Just start building.&lt;/p&gt;

&lt;p&gt;It comes with baked-in presets like:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Expo + NativeWind + Supabase&lt;/li&gt;
&lt;li&gt;Next.js + Better-Auth + Drizzle&lt;/li&gt;
&lt;li&gt;MERN stack&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  Bring your own setup
&lt;/h3&gt;

&lt;p&gt;But I didn't want to lock you into &lt;em&gt;my&lt;/em&gt; preferences. You can define your own &lt;strong&gt;custom presets&lt;/strong&gt; or even run them directly from GitHub repositories. If your team has a specific starter kit, just point Forge to the repo, and it handles the rest.&lt;/p&gt;

&lt;h3&gt;
  
  
  What it doesn’t do
&lt;/h3&gt;

&lt;p&gt;Forge doesn’t generate business logic. It doesn’t try to be smart about your app's architecture. It only removes the most painful phase of development:&lt;/p&gt;

&lt;p&gt;&lt;code&gt;install → configure → glue&lt;/code&gt;&lt;/p&gt;




&lt;h2&gt;
  
  
  Why this matters
&lt;/h2&gt;

&lt;p&gt;Because the hardest part of building isn’t coding. It’s getting into flow. If starting your project feels annoying, you simply won’t start it.&lt;/p&gt;

&lt;h3&gt;
  
  
  What’s next?
&lt;/h3&gt;

&lt;p&gt;Right now, Forge uses predefined and custom-linked presets. But the next step is more interesting: &lt;strong&gt;Recording setup steps and turning them into reusable presets automatically.&lt;/strong&gt; So you never repeat yourself again.&lt;/p&gt;




&lt;h2&gt;
  
  
  Final thought
&lt;/h2&gt;

&lt;p&gt;I didn’t build Forge to save time. I built it to save momentum. Because once you lose that, starting becomes the hardest part.&lt;/p&gt;




&lt;h3&gt;
  
  
  Try it out:
&lt;/h3&gt;

&lt;p&gt;📦 &lt;strong&gt;&lt;a href="https://www.npmjs.com/package/@antardev/forge-dev" rel="noopener noreferrer"&gt;NPM Package&lt;/a&gt;&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;🐙 &lt;strong&gt;&lt;a href="https://github.com/AntarMukhopadhyaya/forge-dev" rel="noopener noreferrer"&gt;GitHub Repository&lt;/a&gt;&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;&lt;em&gt;If you try Forge, I’d love to know what stack you build with it.&lt;/em&gt;&lt;/p&gt;

</description>
      <category>webdev</category>
      <category>javascript</category>
      <category>productivity</category>
      <category>nextjs</category>
    </item>
    <item>
      <title>I tried “forgotten” frameworks — and shipped a client app in 3 hours</title>
      <dc:creator>Antar Mukhopadhyaya</dc:creator>
      <pubDate>Sun, 05 Apr 2026 12:10:06 +0000</pubDate>
      <link>https://dev.to/antar_mukhopadhyaya/i-tried-forgotten-frameworks-and-shipped-a-client-app-in-3-hours-31gi</link>
      <guid>https://dev.to/antar_mukhopadhyaya/i-tried-forgotten-frameworks-and-shipped-a-client-app-in-3-hours-31gi</guid>
      <description>&lt;p&gt;I didn't expect to use &lt;strong&gt;Framework7&lt;/strong&gt; or &lt;strong&gt;NativeScript&lt;/strong&gt; in 2026.&lt;br&gt;
But yesterday evening, I got a small client requirement: a simple inventory tracking system.&lt;/p&gt;

&lt;p&gt;Two roles:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Admin -&amp;gt; add items, restock, edit/delete, view audit logs.&lt;/li&gt;
&lt;li&gt;Staff -&amp;gt; only deduct/sell items.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  The usual instinct
&lt;/h2&gt;

&lt;p&gt;My first thought was obvious:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;React Native&lt;/li&gt;
&lt;li&gt;or Jetpack Compose&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;But then I paused. That meant setting up environments, fixing dependencies, dealing with configs, and running &lt;code&gt;npx expo install --fix&lt;/code&gt; type commands.&lt;/p&gt;

&lt;p&gt;And for what? A simple app. I didn't need the best stack; I needed the &lt;strong&gt;fastest path to working software&lt;/strong&gt;.&lt;/p&gt;




&lt;h2&gt;
  
  
  Trying NativeScript
&lt;/h2&gt;

&lt;p&gt;I had seen &lt;a href="https://nativescript.org" rel="noopener noreferrer"&gt;NativeScript&lt;/a&gt; before in a YouTube video, so I gave it a try.&lt;/p&gt;

&lt;p&gt;And honestly,&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;NativeScript felt closer to native and more fluid.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;The UI felt smooth and the experience was solid.&lt;/p&gt;

&lt;p&gt;But...&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;It works really well when it works.&lt;br&gt;
But when it doesn't, you are kind of on your own.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;I ran into:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;inconsistent documentation&lt;/li&gt;
&lt;li&gt;outdated packages (6-8 years old)&lt;/li&gt;
&lt;li&gt;issues with font icons not rendering&lt;/li&gt;
&lt;li&gt;styling that isn't exactly standard CSS&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;I fixed some of it, but it was slowing me down.&lt;/p&gt;

&lt;p&gt;And for this project, speed mattered more.&lt;/p&gt;




&lt;h2&gt;
  
  
  Switching to Framework7
&lt;/h2&gt;

&lt;p&gt;So I switched.&lt;/p&gt;

&lt;p&gt;I scaffolded a &lt;a href="https://capacitorjs.com" rel="noopener noreferrer"&gt;Capacitor&lt;/a&gt; app, added &lt;a href="https://framework7.io" rel="noopener noreferrer"&gt;Framework7&lt;/a&gt;, and just started building.&lt;/p&gt;

&lt;p&gt;And this is where things clicked.&lt;/p&gt;

&lt;p&gt;Framework7 already had:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;pull to refresh&lt;/li&gt;
&lt;li&gt;swipeable list items&lt;/li&gt;
&lt;li&gt;infinite scrolling&lt;/li&gt;
&lt;li&gt;built-in toasts, dialogs and alerts&lt;/li&gt;
&lt;li&gt;ready-made UI components like search bar and icons&lt;/li&gt;
&lt;/ul&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%2F23hwetnzgr4wu27uktfp.jpeg" 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%2F23hwetnzgr4wu27uktfp.jpeg" alt="Framework7 UI Components in action" width="720" height="1560"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Everything I needed for this kind of app was already there.&lt;/p&gt;

&lt;p&gt;No overthinking.&lt;/p&gt;

&lt;p&gt;Just import and use.&lt;/p&gt;

&lt;h2&gt;
  
  
  What surprised me
&lt;/h2&gt;

&lt;p&gt;I finished the entire app in &lt;strong&gt;under 3 hours (including testing)&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;Stack:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Framework7&lt;/li&gt;
&lt;li&gt;Capacitor&lt;/li&gt;
&lt;li&gt;TanStack Query&lt;/li&gt;
&lt;li&gt;Supabase&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;And the result?&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%2F1s3wzsig4q0ub9ifxd89.jpeg" 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%2F1s3wzsig4q0ub9ifxd89.jpeg" alt="inventory app UI built with Framework7" width="720" height="1560"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;The UI looked completely like a native Material app.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;If I showed it to someone, they'd probably assume it was built with Jetpack Compose.&lt;/p&gt;




&lt;h2&gt;
  
  
  The tradeoff
&lt;/h2&gt;

&lt;p&gt;Of course:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;NativeScript -&amp;gt; more native feel, smoother&lt;/li&gt;
&lt;li&gt;Framework7 -&amp;gt; runs in WebView with the help of Capacitor.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;So yes, NativeScript felt more fluid and performant.&lt;/p&gt;

&lt;p&gt;But:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;I didn't need that level of fidelity.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;I needed something:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;simple&lt;/li&gt;
&lt;li&gt;fast&lt;/li&gt;
&lt;li&gt;correct&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  The real lesson
&lt;/h2&gt;

&lt;p&gt;This project reminded me of something important:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Not every problem needs the best framework.&lt;br&gt;
It needs the right framework for the constraints.&lt;/p&gt;
&lt;/blockquote&gt;




&lt;h2&gt;
  
  
  Final thought
&lt;/h2&gt;

&lt;p&gt;Before I wrap up, one thing I want to say about NativeScript.&lt;/p&gt;

&lt;p&gt;Personally, I think the idea behind NativeScript is genuinely unique.&lt;/p&gt;

&lt;p&gt;Being able to use JavaScript/TypeScript to directly access native APIs without a heavy bridge layer is a very powerful concept. The team behind it has done some really impressive work.&lt;/p&gt;

&lt;p&gt;But at the same time:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;a great idea alone isn’t enough.&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;The ecosystem and documentation haven’t kept up, and that makes it hard to rely on in real-world scenarios where time matters.&lt;/p&gt;

&lt;p&gt;That said, I would still consider using it for future projects — especially when I have more time.&lt;/p&gt;

&lt;p&gt;The idea and execution behind NativeScript are too unique to ignore.&lt;/p&gt;




&lt;p&gt;Most clients don’t need complex systems.&lt;/p&gt;

&lt;p&gt;They don’t care about:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;architecture purity&lt;/li&gt;
&lt;li&gt;cutting-edge stacks&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;They care about:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;something that works consistently and fits into their workflow.&lt;/p&gt;
&lt;/blockquote&gt;




&lt;p&gt;And sometimes, the tools that help you do that fastest&lt;br&gt;
are the ones people stopped talking about.&lt;/p&gt;

</description>
      <category>webdev</category>
      <category>javascript</category>
      <category>productivity</category>
      <category>android</category>
    </item>
  </channel>
</rss>
