Case study

Improved users' satisfaction with integration of modern real-time collaboration feature

How does a collaboration module increase app usability? Discover all the benefits of integrating a custom real-time collaboration (RTC) into your existing software.

A dark-themed code review visualization tool displaying a file structure with nodes, color-coded indicators for changes, and a code snippet on the right.
Clutch logo in dark mode with a five-star rating and a score of 4.9, indicating high customer satisfaction and excellent reviews.

Using leading technologies for real-time collaboration

We recently assisted a visual application provider specializing in code maintenance that needed a collaboration feature enabling real-time teamwork among developers. Integrating two leading technologies posed a significant challenge, impeding the implementation of advanced features, including the much-needed collaboration module.

Our team tackled this issue by leveraging two technologies, GoJS and React, a well-versed foundation for the client’s existing application, and Yjs, the basis of our collaboration module, introducing a new technical environment for the client.

However, successfully integrating these technologies required us to modify the code architecture of the application. We also suggested enhancing the user experience by incorporating a custom undo/redo feature and other extra functionalities.

Client

Startup with software supporting development teams’ work

Business need

Combination of two technologies – GoJS and React – to implement a real-time collaboration module based on Yjs

Scope

Real-time collaboration module implementation; code’s architecture improvement; UX features, custom undo/redo feature

gojs
react
redux
yjs
Real-time solutions
Diagrams
Manufacturing &
engeeinering

Benefits of custom real-time collaboration module

The project’s scope involved integrating the GoJS library and React framework with the RTC module to implement a real-time collaboration. To make using the app more enjoyable, our team recommended implementing some extra features and optimizing the app’s architecture.

Seamless integration with your existing software

To implement a real-time collaboration module, we first needed to improve the existing app’s architecture and perform an application state centralization. Then we support the client with our expertise to smoothly combine two technologies – React framework and GoJS library. Finally we could implement collaboration module based on Yjs.

A dark-themed code review visualization tool displaying a file structure with nodes, color-coded indicators for changes, and a code snippet on the right.

Object locking for error-free cooperation

Our collaboration module’s core functionality is the object-locking mechanism. It prevents other users from changing the properties of the currently edited object (e.g., overwriting other users’ changes in the same object). Locking is a mechanism that is mostly implemented on the backend side. The front end gets information on currently locked objects to show this on the node’s UI. Conversely, the backend gets informed whether the user wants to gain control over the object by selecting it and deciding which actions on the diagram should be allowed (moving, text editing, etc.).

A closer view of a code structure with file dependencies, highlighting user comments, task assignments, and an urgent issue related to a specific file.

Collaboration features for better user experience

The collaboration module is riched with handy features that make collaborative work even smoother, among others:

  • adding comments to objects via the comment nodes
  • attaching charts, graphics, and animations to the objects
  • hijack functionality to draw participants’ attention to a specific object
  • drag&drop functionality for real-time collaboration
A service architecture diagram showing interconnected components, API integrations, and a summary panel displaying deployment details.

Custom undo/redo feature

Besides the collaborative module, our client also needed an undo and redo feature for the GoJS diagram and React’s controls. To prevent a client from wasting time on implementing an external solution, we developed a custom undo/redo mechanism for him and integrated it with his application.

A visual representation of a service architecture, with a user interface overlay for undoing or modifying changes in the diagram.

Get real-time collaboration feature even 3x faster with our experts

The real-time collaboration module is a premade, proven, and ready-to-use component. Our developers can implement it offhand, and you will cut the cost of developing a full feature from scratch.

  • Use our expertise to reinforce your application, platform, or other projects.
  • Save your time and budget on learning new skills from scratch.
  • Trust our development team and shorten your product’s time to market.

Streamlined collaboration module’s integration with your technology stack

The image shows a purple round icon with a white stopwatch symbol inside. The stopwatch symbol consists of a circle with a small rectangular shape on top that represents the stopwatch button. This type of icon is typically used to represent time-related features, such as timers or stopwatches, and is useful in contexts where tracking or timing is important.

Ready to implement module that shortens delivery time to market

Object locking mechanism that prevents users from overwriting each other’s changes in the same object

FAQ

  • What is real-time collaboration tool?

    A real-time collaboration tool is a software application or platform that enables individuals or teams to work together on a project or task simultaneously, regardless of their physical locations. It allows for instant communication, file sharing, editing, and coordination in real-time, fostering efficient collaboration and teamwork.

  • What is real-time example for collaboration?

    A real-time example of collaboration could be a team working on a shared document or presentation using a collaborative editing tool. Multiple team members can simultaneously make edits, provide feedback, and communicate in real-time, allowing for seamless collaboration and faster progress.

  • How real-time collaboration software supports employees?

    Real-time collaboration software supports employees by facilitating seamless communication, enhancing productivity, and fostering teamwork. It enables instant messaging, audio/video conferencing, and screen sharing for effective remote collaboration. It allows multiple users to work on the same document simultaneously, ensuring real-time updates and eliminating version control issues. It also provides task management and project tracking features, enabling efficient coordination and progress monitoring.

  • Can I build a real-time collaboration tool in javascript?

    Yes, you can build a real-time collaboration tool using JavaScript. JavaScript, along with frameworks like Node.js and libraries like Socket.io, provides the necessary tools to create real-time communication and collaboration features. By leveraging these technologies, you can develop functionalities such as real-time messaging, document synchronization, and simultaneous editing capabilities to create your own real-time collaboration tool.

Build attractive interactive diagrams with React Flow and product design experts

Contact details

By sending a message you allow Synergia Pro Sp. z o.o., with its registered office in Poland, Wroclaw (51-607) Czackiego Street 71, to process your personal data provided by you in the contact form for the purpose of contacting you and providing you with the information you requested. You can withdraw your consent at any time. For more information on data processing and the data controller please refer to our Privacy policy.

*Required
Thank you! Your submission has been received!
Oops! Something went wrong while submitting the form.