Categories: Shopify

Our Experience with Shopify App Development: Challenges, Wins and Lessons

When we completed our first project using the Hydrogen framework for a client, we truly discovered the power of Shopify. This project revealed Shopify’s flexibility and the significant opportunities within its ecosystem. However, we also identified a gap: while Shopify apps are abundant, there are limited options specifically designed to support the Hydrogen framework. Most apps cater exclusively to 2.0 theme liquid online stores, leaving merchants using Hydrogen with fewer tools to enhance their businesses. This realization motivated us to bridge that gap by creating meaningful apps that empower merchants and elevate their e-commerce experiences.

As we delved deeper into Shopify app development, we were captivated by its robust APIs and the potential to solve real-world challenges for store owners. Whether it was helping customers track wishlists or enabling merchants to manage product notifications, we saw how our efforts could make a tangible impact on online shopping experiences.

This blog is a reflection of that journey—one filled with challenges, learning curves, and rewarding milestones. I’ll share insights gained, the tools and strategies that worked, and lessons learned from building Shopify apps. Whether you’re an aspiring developer, a seasoned coder curious about Shopify, or a merchant exploring app-based enhancements, I hope my experiences inspire and equip you for your own journey in the Shopify ecosystem.

Getting Started with Shopify Apps

Like any new platform, Shopify came with its challenges. Understanding Shopify’s architecture, including its APIs, Polaris design system, and the concept of app extensions, was initially overwhelming. The learning curve was steep but rewarding. We spent countless hours exploring the Shopify documentation, experimenting with the Shopify CLI, and diving into the intricacies of the app development process.

One of the main main components was learning Polaris. Creating a polished user interface for the admin dashboard using Polaris required attention to detail and adherence to Shopify’s design principles. Similarly, understanding how liquid templates worked with traditional themes and how to adapt them to hydrogen required significant effort. Each step, however, deepened our appreciation for Shopify’s well-structured ecosystem.

We started small, focusing on building a minimal viable product (MVP) that leveraged Shopify APIs for wishlist functionality and created a seamless user experience. Through trial and error, we learned to navigate challenges like handling Shopify authentication, managing app data, and ensuring compatibility with multiple store setups. This process helped us develop the app and the confidence and skills needed to tackle larger projects.

These early experiences laid the foundation for our journey in Shopify app development. They helped us identify the platform’s strengths, understand its limitations, and position ourselves to create innovative solutions tailored to merchant needs.

Tools and Technologies Used

Basically we used the following tools and technologies throughout the application development.

  • Remix react framework with Typescript for the base project
  • Polaris design system for admin UI
  • GraphQL to use admin APIs
  • Liquid templating language for theme app extensions
  • Heroku hosting platform.

Frameworks and Languages

Our journey into Shopify app development required choosing the right frameworks and languages to bring our ideas to life. React became a natural choice for building intuitive and interactive user interfaces, especially for admin dashboards using Shopify’s Polaris design system. We also worked with Remix, a powerful framework for creating server-side rendered apps, which aligned well with Shopify’s need for fast and scalable solutions.

APIs and Extensions

Shopify’s APIs are the backbone of app development, and we quickly learned how powerful they are in enabling integrations and customizations. The Admin API became essential for tasks like managing products, customers, and orders, while the Storefront API allowed us to create personalized customer-facing experiences.

One of the most exciting aspects was working with Flow triggers and theme app extensions. For example, we integrated Flow triggers in one of our apps to enable merchants to automate workflows like email integration with the app. Theme app extensions, while more challenging due to their tight restrictions, allowed us to seamlessly embed app functionalities directly into storefronts.

These tools made it possible to bridge gaps, especially for Hydrogen framework users, by combining Shopify’s robust backend with modern, headless frontend solutions.

Development Environment

A good development environment was critical for our success. The Shopify CLI became our go-to tool for scaffolding apps, managing app extensions, and syncing changes with development stores. However, in the early stages, the CLI did not support the latest Node.js versions. To get it working, we had to downgrade our Node.js environment to version 18.*. While this was an unexpected hurdle, it taught us the importance of maintaining flexible development setups to adapt to platform requirements. Coupled with version control tools like Git, it helped us maintain organized workflows and collaborate effectively as a team.

App Deployment for Production

Deploying an app to a production environment required careful planning to ensure reliability and scalability. We used Heroku as the hosting platform for our apps. Its simplicity and robust features made it an excellent choice for our needs.

We focused on setting up a seamless deployment pipeline and automating processes like building and pushing code updates. Heroku’s scalability allowed us to confidently handle varying levels of traffic while keeping costs manageable during the early stages. Additionally, we configured environment variables securely in Heroku, ensuring sensitive data like API keys and webhooks were protected.

This deployment setup gave us the confidence that our apps would perform well under real-world conditions, providing merchants with a smooth and reliable experience.

App Submission and Approval

Submitting an app to the Shopify App Store was one of the most exciting yet nerve-wracking parts of the journey. The process was meticulous, requiring us to adhere to Shopify’s strict guidelines for functionality, design, and security.

The submission process began with extensive testing to ensure the app was free from bugs and provided a seamless user experience. Shopify’s review process was thorough; they tested the app across various scenarios and provided valuable feedback for improvements. For instance, we had to make adjustments to better align with Shopify’s data privacy standards and optimize the app’s user interface.

Once the app met Shopify’s requirements, it was approved and listed on the Shopify App Store. This marked a significant milestone, allowing merchants worldwide to discover and install the app. Seeing it go live was incredibly rewarding, as it validated the months of hard work and effort we had invested.

By leveraging the right tools, navigating deployment challenges, and adhering to Shopify’s rigorous standards, we built apps that merchants could trust. Each step—from coding to deployment and approval—strengthened our expertise and prepared us for more ambitious projects in the Shopify ecosystem.

Challenges in Shopify App Development

Theme App Extensions

Shopify app development came with its share of technical challenges, especially when working with theme app extensions. One of the main difficulties was integrating our app functionality directly into Shopify storefronts, particularly since the main theme is written in Liquid. This meant we had to get comfortable with Liquid templating language to make changes and integrate app features into the theme seamlessly. Theme app extensions allowed us to add functionality, but changing the theme’s core features through these extensions felt more like working with plugins rather than direct modifications.

The strict guidelines around theme app extensions also required us to be creative in how we positioned, styled, and interacted with existing theme elements, ensuring that everything worked smoothly within the limitations. We had to think carefully about both user experience and functionality while making sure the app performed well across different themes.

Another technical hurdle was managing API requests coming from the theme app extensions. The authentication process using public.app.proxy was a challenge, as it added complexity to how we handled and authenticated API calls between the storefront and our backend. The proxy allowed us to route these requests, but it also introduced additional layers of complexity around managing sessions and ensuring security for both the app and the store.

Admin API

Admin API endpoint limitations sometimes presented roadblocks. Shopify’s Admin API has specific access restrictions depending on the merchant’s plan, which required us to build flexible solutions to ensure compatibility across various Shopify plans. This was especially challenging when we needed to pull data from the store that wasn’t universally available on all plans, requiring additional effort to provide fallback solutions.

Webhook Subscriptions

Lastly, managing webhook subscriptions proved tricky at times. Shopify uses webhooks to notify apps of events like inventory updates or product updates, and it was essential to ensure that our app handled these notifications properly. However, we encountered situations where webhooks failed intermittently, even though we had implemented them correctly. These failures required us to implement retry mechanisms and robust logging to track missing or delayed notifications. Fine-tuning and extensive testing were crucial to ensure our app could reliably handle webhook events, even under heavy load, and minimize disruptions for merchants relying on timely updates.

Each of these technical challenges taught us valuable lessons in how to develop robust, reliable, and scalable apps for Shopify. From overcoming the complexities of theme app extensions and handling API requests to navigating the intricacies of production deployment and webhook management, these experiences made us stronger developers and helped us create apps that merchants could depend on.

Key Learnings and Tips for Shopify App Development

When developing Shopify apps, we’ve learned a lot through trial and error, especially when it comes to optimizing performance and maintaining best practices. Here are some specific tips based on our experience.

  • Use Metaobjects Wisely to Avoid Over-Reliance on Databases
  • Minimize API Calls Between Theme App Extensions and the App
  • Ensure Unique API Proxy URL Paths and CSS Classes

Use Metaobjects Wisely to Avoid Over-Reliance on Databases

One of the most valuable lessons we’ve learned is the importance of using metaobjects as much as possible. Metaobjects are powerful tools for storing data without the need for a full database setup. For instance, in our app, we used metaobjects to store style settings for theme app extension components. Since we only needed one object to handle settings for the entire app, using a metaobject instead of creating a database table was much more efficient. This approach not only reduced overhead but also kept things simpler, allowing us to avoid unnecessary database calls.

Minimize API Calls Between Theme App Extensions and the App

Performance is crucial, especially when working with theme app extensions. We quickly realized that making too many API calls between the app and the theme could impact the storefront’s overall performance. To avoid this, we focused on minimizing the number of API calls. Whenever possible, we grouped requests, cached data, or used metaobjects to store reusable data. This helped reduce the strain on both the app and the storefront, ensuring a smoother and faster experience for users.

Ensure Unique API Proxy URL Paths and CSS Classes

When working with theme app extensions, we discovered that view encapsulation can be a challenge. Since the app components are embedded into the existing theme, it’s essential to make sure your app proxy URL paths and CSS classes are unique. This prevents your app’s elements from conflicting with other components on the storefront. For example, using a unique path for your app proxy ensures it doesn’t clash with other apps that might use similar routes. Similarly, making your CSS class names specific to your app reduces the risk of styles interfering with other parts of the theme.

By paying attention to these details, we were able to ensure that our app components functioned independently without causing issues for the rest of the storefront.

In Shopify app development, using metaobjects effectively, minimizing API calls, and ensuring unique paths and styles for your theme app extensions are critical practices that can improve both performance and user experience. By taking these steps, you can avoid common pitfalls and create more efficient, scalable apps that merchants can rely on.

Conclusion

In conclusion, our journey through Shopify app development has been both challenging and rewarding. From overcoming technical hurdles to learning valuable best practices, each step has helped us build stronger, more reliable apps. By leveraging the right tools, embracing Shopify’s powerful ecosystem, and continuously iterating on our solutions, we’ve created apps that empower merchants and enhance the e-commerce experience. Whether you’re just starting out or looking to improve your skills, we hope our journey provides insights and inspiration for your own Shopify app development adventure.

Shehan Rathnayake

Share
Published by
Shehan Rathnayake

Recent Posts

How Caching Works: Memory, Disk, and Distributed Caches Explained

In today’s digital world, speed and efficiency are everything. Whether you’re browsing a website, streaming…

2 months ago

Rate Limiting in APIs: Protecting Your Backend from Overload

APIs are the backbone of modern applications, powering everything from social media integrations to payment…

2 months ago

Docker Compose for Multi-Container Web Applications

Many modern software applications are composed of multiple components — for example, a web application…

2 months ago

Building a Customer Support Language Assistant using Streamlit and Google Translate API

In today’s globalized world, language differences continue to be one of the most significant barriers…

3 months ago

Fake News Detection Using Machine Learning

In today’s digital world, many people rely on social media platforms like Facebook, Twitter, and…

3 months ago

Simple Retrieval-Augmented Generation (RAG) System in Python

Despite their impressive performance on a variety of tasks, large language models (LLMs) still have…

3 months ago

This website uses cookies.