Category Archives: JavaScript

Implementing Micro Frontends with Next.js

Implementing Micro Frontends with Next.js: A Real-World Experience

Micro Frontends are increasingly being adopted to enable scalable and flexible frontend development in large applications. Recently, our team integrated Micro Frontends into a project using Next.js and next-module-federation-mf. With over 18 developers working on the UI, breaking down our application into Micro Frontends made collaboration easier, but we encountered some unique challenges along the way.

This post will walk you through the challenges, solutions, and the advantages we found in adopting this architecture with Next.js, along with example code to demonstrate key setup steps.

Our Setup: Next.js and Module Federation

We used Next.js as our main framework with @module-federation/nextjs-mf to handle Module Federation. Our application was split into 13 Micro Frontends, with each section represented by an isolated Next.js project.

Each micro frontend was exposed as a federated module and imported dynamically where needed. Here’s how we set up imports, exposes, and shared modules in our configuration.

Setting Up Module Federation in Next.js

To get started, you need to configure module federation in your next.config.js file.

1. Installing Dependencies

First, install the required module federation plugin:

npm install @module-federation/nextjs-mf

2. Setting Up the next.config.js File

In each micro frontend, configure the next.config.js with @module-federation/nextjs-mf as follows:

Here’s what each option means:

Setting Up the next.config.js File

  • name: The unique identifier for each Micro Frontend. For example, app1 in this case.
  • exposes: Specifies which modules in this project will be exposed. For example, ComponentA is exposed and can be used in other applications.
  • remotes: Defines other federated modules (Micro Frontends) that this application can import. For instance, app2 is available at http://localhost:3001.
  • shared: Specifies shared dependencies between micro frontends, ensuring only a single instance of react and react-dom is used across applications.

3. Importing Federated Modules Dynamically

In the host app or another micro frontend, you can use next/dynamic to import and render the exposed modules dynamically. Here’s an example:

Importing Federated Modules Dynamically

In this example, ComponentA from app1 is dynamically imported in the host application. Setting ssr: false prevents server-side rendering, ensuring the federated component loads only on the client side.

4. Sharing Common Modules (Like Axios)

In our case, certain libraries like Axios and custom hooks didn’t work seamlessly with shared modules, so we had to isolate them in each micro frontend or manage versioning closely. Here’s how you can configure shared modules:

Sharing Common Modules (Like Axios)

Using singleton ensures only one instance of the library is loaded, but in some cases, isolated instances might work better to avoid version conflicts.

Challenges We Faced

1. Plugin Limitations with Next.js:

Micro Frontends are new, especially for server-rendered frameworks like Next.js. We had to forcefully use the page router as @module-federation/nextjs-mf does not support the app router. This impacted our project structure, and we had to adjust routing patterns accordingly.

2. Increased Build Size and Memory Usage:

Having 13 Micro Frontends increased our total build size, causing memory issues during builds. We tackled the “Node max space exceeded” error by configuring Node’s memory limit:

         NODE_OPTIONS=”–max-old-space-size=2048″

3. Deployment Complexity

Each micro frontend was hosted on a separate VM, adding significant infrastructure     costs. For large applications, this separation can quickly become expensive.

Advantages of Micro Frontends in Our Project

Despite the challenges, adopting Micro Frontends provided significant benefits:

  • Reduced Merge Conflicts:
    With 18 developers, Micro Frontends allowed teams to work on isolated parts, reducing merge conflicts.
  • Increased Development Speed:
    Each team could work independently, making development faster and more efficient.
  • Simplified Deployments:
    We could deploy updates for individual micro frontends rather than redeploying the entire application.

Which Tool is Best for Micro Frontends with Next.js?

Each bundler has its strengths:

  • Webpack: Recommended for Next.js Micro Frontends. Webpack’s Module Federation is currently the most reliable solution for federated modules in Next.js.
  • Vite: Best suited for purely client-rendered Micro Frontends with frameworks like React, Vue, and Angular. Vite’s faster builds make it ideal, though it lacks server-rendered support for Next.js.
  • Parcel: Offers a simpler setup, though it’s limited in flexibility and advanced configurations compared to Webpack.

Conclusion

Using Micro Frontends with Next.js helped us scale development and reduce conflicts, but the journey came with hurdles, especially around plugins, build sizes, and deployment costs. For large, complex applications where team autonomy and modularity are key, Micro Frontends can be a powerful architecture choice, though it’s essential to be prepared for its unique challenges, especially with server-rendered frameworks like Next.js.

Looking to build dynamic, scalable, and high-performance applications? Mindfire Solutions offers top-notch JavaScript development services tailored to your unique business needs. Whether it’s implementing cutting-edge frameworks like Next.js or adopting innovative architectures like Micro Frontends, our team delivers seamless, future-ready solutions to help you stay ahead in the digital landscape.

 

Spread the love
  •  
  •  
  •  
  •  
  •  
  •  
  •  
  •  
  •  
Virtual Fitting Room Applications

Virtual Fitting Room Applications Are Developed Best Using JavaScript?

Introduction:

The continuous innovation and development of technology have led to the creation of Virtual Fitting Room Applications. Now customers don’t have to be physically present at a store for trying out any clothing items, beauty products, and accessories. You can do it virtually through Virtual Fitting Room mobile applications.

The virtual fitting room is a technology that has revolutionized the way retailers and E-commerce businesses are offering online shopping experiences. Virtual fitting room applications are based on technologies like Artificial Intelligence (AI) and Augmented Reality (AR). With these new innovative applications, buyers don’t have to leave their homes to check the size, fitting, and style of the products that they want to purchase.

Ever since the pandemic struck, in-store shopping has taken a hit. People are hesitant about going out to retail stores and trying out things themselves. Based on a survey conducted by a leading advisory group, more than half of women and men who visit the store don’t feel safe trying out clothes in the store dressing room.

Market Trends:

As lockdowns were happening globally, clothing products saw a decline of about 43% in sales. But virtual fitting room technology is changing these numbers, and retailers are slowly getting back in the business. After the Covid-19 pandemic, the demand for virtual fitting rooms is increasing drastically.

A report predicted that by 2025, the market for virtual fitting would reach the value of 6.5 Million U.S dollars. According to an industry report by Statista, the global market size for virtual fitting rooms is expected to reach over 12 Billion U.S dollars by 2028.

Many platforms and languages can be used while adopting this technology. In the following article, we will discuss why virtual fitting rooms applications are best developed with JavaScript.

In order to understand why JavaScript (js) is the best way to develop a virtual fitting room application, we need to know how the concept of virtual fitting rooms works.

How Does Virtual Fitting Room Technology Work?

The virtual fitting room works on Artificial Intelligence (AI) or Augmented Reality (AR). In the case of Augmented Reality, a person’s body is scanned with a webcam to create a 360 degree-3D model of the body. The virtual fitting room apps that work on AI utilize machine learning algorithms to create a 360 degree-3D model of a body.

Irrespective of the technology used to scan the body, post scanning, the 3D models are combined with Radio Frequency Identification (RFID). The RFID keeps track of the products that the buyer has added to the virtual fitting room.

Finally, the virtual fitting room technology lays the product of the user’s choice on the 360-degree 3D model of their bodies. It helps shoppers check whether the item has the proper fitting, styling and how well it suits them.

Benefits Of Virtual Fitting Rooms:

Here are benefits that virtual Fitting Room Applications can offer to retailers:

● Support online sales:

Virtual fitting room application provides an enhanced shopping experience for the customers. A research paper shows that 40 % of shoppers are willing to buy more expensive products if they experience shopping through augmented reality features. Thus, virtual fitting room applications are increasing the online sales of enterprises.

● Increase customer Retention:

The virtual fitting room applications increase the target audience’s engagement with the brands and retailers. It allows shoppers to see for themselves how the product will look on them. Therefore, customers keep on trying various items, and the retention time goes on increasing. The businesses that have used virtual fitting room applications witnessed a 5 percent boost in their retention time.

● Decrease in product Return:

One of the reasons for high returns was the wrong fitting of the product. But with virtual fitting room applications, these blunders can be avoided. After opting for this technology, a retail company reported about a 36 percent decrease in the returns rate.

Why Use JavaScript To Develop Virtual Fitting Room Applications?

JavaScript is an object-oriented programming language which helps to develop dynamic web pages and applications.

As virtual fitting room applications are based on AI and AR, JavaScript is one of the best languages you can use to develop them. From the surface, it may seem like a strange choice as most enterprises use programming languages like Python or Scala for their AI/AR-based projects.

But JavaScript has some advantages that can add more value than Python or Scala. Here are some reasons why JavaScript is the best language for developing virtual fitting rooms.

● Excellent Performance:

Millions of dollars are invested in JavaScript so that it can run fast. Modern JavaScript is more advanced and translates machine code as same as Java. This allows AI-based applications to perform better in JavaScript.  Hence virtual fitting rooms can offer a more superior user experience than Python and Scala.

● Less Development Time:

We all already know that Python has less development. The same is the case with JavaScript. But the development time for JavaScript is a little quicker. Synaptic, the neural network library of JavaScript, has various features, which gives js a bit of an edge in AI-based application development.

That doesn’t mean that Python is not good. When it comes to adopting deep learning technology, there is no competition to Python. Both languages have something unique to offer. As development times go down, the production costs also go down. Hence enterprises can save a lot by using JavaScript for developing virtual fitting rooms.

● Improved Security:

JavaScript comes with built-in security. Therefore, JavaScript prevents any attacks to the application by malicious codes.

● JS has separate library for AR Features:

JavaScript offers a library named ‘AR.js’ that can provide Augmented Reality features to any web-based application using a few lines of HTML. It is a free, open-source platform and has been used by many developers. In the GitHub repository, AR.js has more than 13,000 stars.

One of the benefits of using the AR.js framework is its cross-platform and browser compatibility. This means that the web app developed on the platform is compatible with iOS as well as Android.

The AR.js comes with different AR frameworks like A-frame, ARToolKit, and three.js, making this framework very easy for developing AR-based web applications. It offers a high performance of 60fps, even older devices, so there is no need to spend money on external hardware.

That being said, AR falls short in some instances as compared to AI. There are some rendering limitations to AR. The tracking accuracy of the Augmented Reality technology is too low, which can compromise the application’s user experience. Therefore, AI in collaboration with AR helps to avoid these glitches and make the technology more effective. The data rendering done in AI is more accurate than AR technology. It also provides better identification of body parts of the 3D model.

Final Thoughts:

From the benefits listed in the above section, you can see why JavaScript is the best choice for developing AR or AI-based web applications such as virtual fitting rooms. The language is easy to code, offers better performance, provides a framework and library for adding AR features, and is even cost-effective in many aspects

The virtual fitting rooms are not only limited to the clothing industry; they are also relevant for shoes, watches, sunglasses/ spectacles, cosmetics, and jewelry. Anything wearable and used as a styling option can be paired with virtual fitting rooms applications.

Instead of hiring developers to create a virtual fitting room, retailers and E-commerce platforms can outsource this job to a service provider with relevant industry experience and reduce the workload.

Like other businesses, if you too are looking to develop Virtual Fitting Room Applications, Mindfire Solutions can be your partner of choice. We have deep expertise in JavaScript . We have a team of highly skilled and certified software professionals, who have developed many custom solutions for our global clients over the years.

There is an interesting project we have done to develop a virtual fitting room application for an advertising and content management company with JavaScript. Click here to know more: Case study on fashion imagery solution.

Spread the love
  •  
  •  
  •  
  •  
  •  
  •  
  •  
  •  
  •  
Google Puppeteer

Puppeteer : Is it time to ditch Selenium?

Google has introduced a new library based on Chromium’s dev tool protocol. The library grants high-level API to interact with chromium and handle most tasks which you can perform using Chromium dev tools. The library is implemented in node.js and is really easy to get started once you install required packages using the node package manager.

……………………………………………………………………………………………………

Why Puppeteer?

Puppeteer flexes its muscle where selenium misses out. It is not just limited to interactions with the web application under test performing tasks like for e.g. interacting with dom, submitting forms, generating screenshots and pdf of web pages but also in intercepting network activity, throttling CPU and network, generating timeline trace and mocking API amongst some. The puppeteer can be easily be used to write end-to-end automation test suites with the benefit of getting a detailed timeline of the performance of all the assets (images, javascript files and so on).

Engineers can easily switch between headless and non-headless modes. While writing the automation suite, non-headless mode gives a good view of how the browser is interacting with the application under test and helps in debugging; just like in Selenium. But in production, we can execute suite in a headless mode as it reduces execution time and save resources.

……………………………………………………………………………………………………

Is it really that Good?

Yes, it enjoys the goodness of async code execution. You can always perform multiple tasks simultaneously following the latest javascript async await conventions. You can test the behavior of your application under different screen sizes. The network can be throttled on demand to find out how your application will run at low internet speeds. For e.g. if you want to test the error messages in an application when a user loses internet connectivity, puppeteer can easily handle such a scenario. Mocking APIs can also be achieved with utmost ease. For instance, if you want to test your “payment completed” screen but don’t want to go through the payment gateway flow, you can easily perform it with puppeteer by mocking the API response. With a detailed performance matrix, puppeteer can easily be used for performance testing.

So what are the drawbacks?

Google puppeteer supports only Chromium and Chrome out of the box. Third party implementations are available for Firefox and Internet Explorer. But they are experimental as of now and are missing a good chunk of the firepower. The documentation available is minimal as compared to selenium.

Why should you prefer Puppeteer over Selenium?

The targeted audience is the major deciding factor. If it majorly comprises of Chrome users you should go ahead with Puppeteer. Other factors include performing automation tasks which are not possible with selenium, like testing Chrome extensions, mocking API calls and so on. Selenium follows WebDriver protocol and has been from a very long time in the market compared to puppeteer hence itis better documented compared to puppeteer.

……………………………………………………………………………………………………

Conclusion

Puppeteer is a powerful library which has revolutionized the automation testing by overcoming functionalities missing in WebDriver protocol used by Selenium. Although it is still in the early stages, it promises a bright future, backed up as it is by the illustrious Chrome dev tools team.

……………………………………………………………………………………………………

If you have any queries in this field, talk to Mindfire Solutions. For over 19+ years now, we have been the preferred Software Development Partner of over 1000+ Small and Medium-sized enterprises across the globe.

Spread the love
  • 1
  •  
  •  
  •  
  •  
  •  
  •  
  •  
  •  
    1
    Share
Blazor

Blazor : Will it slay the JavaScript/SPA Frameworks?

It has been a long time since Microsoft allowed support of .NET directly on client-side. The last attempt was with Silverlight which got famous when it launched but due to lack of support from browsers and security concerns it stopped; like what happened to Adobe Flash.

……………………………………………………………………………………………………

What is BLAZOR?

Blazor is an attempt to bring .NET core to the browser directly which allows supported language like C# to run directly on the browser. Blazor allows developing Single Page Application (SPA) very quickly and by using a single language on both server and client.

Blazor allows having features similar to any other SPA framework like Routing, Template, Binding – one or two way, Rendering, etc.

The name comes by combining Browser and  MVC Razor i.e Blazor.

How does it work?

It entirely relies on WebAssembly (Wasm). Wasm was developed in 2015, to run high-level language directly on browsers. It is supported by W3C which means it is standard and could be utilized by different platform too. There are runtimes available to run C++ codes on browsers too. Since it is from W3C all latest browsers generally have the support of Wasm.

Blazor runs via Wasm but in-between there needs to be a runtime. Mono Wasm allows required .NET assemblies downloads on browser directly which runs on Mono Wasm Virtual Machine.

What are all advantages of Blazor?

  • A single roof of programming language to build client and server-side codes.
  • Wasm is generally faster than JavaScript (JS) because those are binary/compiled code. No need for parsing of scripts.
  • A typed system, a fewer scope of errors due to same. Razor, model binding, etc.
  • All sweet features of C# and .NET core: Dependency Injection (DI), delegates/events, etc.
  • Visual Studio Integrated Development Environment (IDE) to allow a rich experience to develop applications quickly with many provided inbuilt or plug-in supported features.
  • A fallback approach to enable Blazor to run if Wasm is not available to any browser.
    No issue of Garbage collection like all .NET platform, Mono Wasm supports it too.

Limitations of Blazor

  • Still is in the development phase, not recommended for production use.
  • Limited debugging support of Blazor codes since it runs on Wasm.
  • No way to access DOM elements has to rely on JavaScript for same.
  • The second biggest, there is not much components/control available in Blazor to have richer User Experience (UX). Like as simple as AutoSuggestion, we have to rely on JavaScript plugin for same.

Demo of Blazor

https://www.youtube.com/watch?v=IGj49kaYPEc
The source code used in demo: https://github.com/viku85/BlazorDemo

Conclusion and Future

Blazor is easy to use with minimal effort in comparison to any JS SPA framework available in the market. Since it is on .NET, there is less learning curve for people coming from the .NET environment.

A lot of changes and development is going on with Blazor, many refinements, performance improvements, feature add-ons but still not having a final version to use on production.
I believe with the support of controls like Kendo or inbuilt controls in Blazor, application development would be much quicker and feature rich.

We need to wait for the final release (if it happens) and a wide variety of supported controls which may kill JS Frameworks at least in the Microsoft development environment.

……………………………………………………………………………………………………

The views and opinions expressed in this article are those of the author. An avid techie, Vikash enjoys sharing his thoughts on computing and technology in his personal blog.
To know more about our company, please click on Mindfire Solutions. 

Spread the love
  •  
  •  
  •  
  •  
  •  
  •  
  •  
  •  
  •  

Top Machine Learning Libraries In Java

Machine Learning Libraries In Java
Machine Learning Libraries In Java

Java is the only general purpose programming language which finds wide use by developers for building secure enterprise grade applications, desktop applications, web applications, and mobile apps. Java 9 further helps developers to build applications for both large and small devices by providing a number of new features – a new module system, a new command line tool, and several updated APIs. At the same time, Java is currently one of the most popular programming languages for machine learning. Continue reading Top Machine Learning Libraries In Java

Spread the love
  • 9
  • 3
  •  
  • 2
  •  
  •  
  •  
  •  
  •  
    14
    Shares

What Is The Best Way To Learn AngularJS?

What Is The Best Way To Learn AngularJS
What Is The Best Way To Learn AngularJS

At present, AngularJS is being used by a number of high-traffic websites including PayPal, Netflix, The Guardian, Upwork, Freelancer and jetBlue. The open source JavaScript framework is also maintained by Google.  The features provided by AngularJS help developers to build custom web applications based on varying business requirements. AngularJS has been gaining a lot of popularity, interested readers can read on the evolution and rise of AngularJS. In addition to supporting model-view-controller (MVC) design rule, AngularJS further enables JavaScript developers to create robust user interfaces (UIs) by using HTML as a template language and extending HTML tags and attributes. Continue reading What Is The Best Way To Learn AngularJS?

Spread the love
  • 18
  • 2
  •  
  • 2
  •  
  • 2
  •  
  •  
  •  
    24
    Shares

What is Redux JS?

What is Redux JS

Many web developers ask us, What is Redux JS? Redux is an open-source JavaScript library, which  makes it easier for developers to build custom user interfaces (UI) by maintaining the entire application state in a single and immutable state tree. The immutable state tree cannot be altered or manipulated directly. Each time the application state changes Redux creates a new object using specific functions. Redux takes inspiration from the functional programming language – Elm and Facebook’s application architecture for building UIs – Flux. Web application developers even have the option to integrate Redux with several widely used JavaScript frameworks. However, Redux is still different from other JavaScript libraries and model-view-controller (MVC) frameworks. Continue reading What is Redux JS?

Spread the love
  • 9
  •  
  •  
  • 2
  • 1
  • 1
  •  
  •  
  •  
    13
    Shares

Top 8 JavaScript Testing Frameworks

Top 8 JavaScript Testing FrameworksMost developers nowadays combine JavaScript, HTML5, and CSS3 to create responsive web applications that deliver richer user experience across small and large devices with a single code base. Many web developers also leverage Node JS – a cross-platform runtime environment – to write server-side code in JavaScript. The developers need to test the JavaScript applications with varying devices, operating systems, and browsers to measure their user experience. Continue reading Top 8 JavaScript Testing Frameworks

Spread the love
  • 11
  • 2
  •  
  • 2
  •  
  •  
  •  
  •  
  •  
    15
    Shares

Angular vs React: A Brief Comparison

Angular vs React: A Brief Comparison

Both AngularJS and ReactJS are widely used JavaScript frameworks. Angular is currently being maintained by Google, whereas React is developed and maintained by Facebook. The usage statistics posted on various websites indicate that Angular is currently more popular than React. But the number of stars on its Github page depicts the growing popularity of React. Angular.js and React.js further differ from each other in terms of features, usage and performance. Hence, it becomes essential for developers to know the features of both Angular and React, and understand the important points of distinction between Angular vs React. Continue reading Angular vs React: A Brief Comparison

Spread the love
  • 27
  • 2
  •  
  • 2
  •  
  •  
  •  
  •  
  •  
    31
    Shares

Full Stack JavaScript Frameworks

Full Stack JavaScript Frameworks

Many enterprises nowadays opt for full stack we application development to reduce both developments time and cost. In addition to being proficient in client-side and server-side web technologies, a full stack web developer further synchronizes the frontend and backend of a website seamlessly according to precise business requirements. Several studies suggest that JavaScript is currently the most popular programming language for full stack web development. Nowadays, JavaScript is extensively used for building large scale complex web applications. Continue reading Full Stack JavaScript Frameworks

Spread the love
  • 13
  • 2
  •  
  •  
  • 2
  •  
  •  
  •  
  •  
    17
    Shares