2016-08-29



We know that many Enterprise Applications have been written using Sencha Ext JS framework and some of these are still using Ext JS 2.x or Ext JS 3.x or 4.x or a combination of the different versions of Ext JS. It is true that Technology has changed a lot in last 5-6 years and Ext JS has matured along the way. While the older versions were the best UI frameworks available at that moment, the Ext JS 6 is where the framework has achieved the real maturity.

Question is, are you still using older Ext JS versions? Do you have any plans to migrate or do you have any questions like why I have to migrate to Sencha Ext JS 6? Well, there are many reasons to migrate your application to Ext JS 6. Review our Application Migration presentation to learn about What, When, Why, and How of migration.

While there are numbers of exciting reasons for moving to the latest version of Ext JS, this article will describe the top 5 reasons why you should migrate your application to Sencha Ext JS 6.

#1 :  Unified Framework

One of the key changes in Ext JS 6 is merging of Ext JS and Sencha Touch frameworks into a unified framework. In Ext JS 6 we have a concept called toolkits to differentiate the frameworks. The following image depicts how the two frameworks have been merged into one:



Credit: https://cdn.sencha.com/img/20150706-extjs-frameworks-merger-img2.png

Classic – Component set with the (Ext JS) desktop themes.

Modern –  Component set with the (Sencha Touch) mobile device themes.

The UI components of Ext JS are now contained in the “classic toolkit” of Ext JS 6, while the UI components of Sencha Touch are contained in the “modern toolkit”. You can now create universal applications that utilize both the toolkits and create a single application that targets mobile devices like smartphones and / or tablets (using the modern toolkit) and desktops / laptops running various web browsers (using the classic toolkit).

Let’s say you have created a universal application, you can view the application in their respective browsers. For instance, loading the application on Mobile will show you the modern version of your application whereas loading it in a desktop browser will show you the classic version of your application. There are different ways that the presentation can be controlled. They are:

App Profile – To change things on a larger scale

Responsive Configs – For more dynamic conditions

Platform Configs – For simple tuning at load time

With all these tools at hand, it is just a matter of picking the right tool based on your requirement. We can say that Ext JS 6 is the most advanced and powerful JavaScript framework for multi-platform, multi-device application development and it is one of the main reasons to migrate.

#2: Powerful Components

Pivot Grid

Pivot Grid help users to view and analyze their data and enables rapid summarization of large sets of data often presented in Ext JS grids.



Credit: http://examples.sencha.com/extjs/6.0.2/examples/kitchensink/#excel-pivot-grid

It provides a simple way to condense many records into summary reports, either in the form of canned reports or via the configurator plugin that users can utilize to slice and dice their Ext JS grid data.With Sencha Pivot Grid, we can build applications that enable users to discover critical insights from massive sets of data and helps us to harness the power of big data.

Accessibility Improvements

Ext JS 6 integrates the ARIA functionality directly into the component lifecycle. You no longer need a special ARIA package to get the proper accessibility support.

Credit: https://cdn.sencha.com/img/20150706-extjs6-ga-accessibility-img6.png

Ext JS 6 applications support screen readers such as JAWS, and NVDA, by default. A new ‘actionable mode’ is available for the Ext JS grid, which allows keyboard navigation for all kinds of grids, including the contents of a grid cell. An added benefit of bringing this functionality down into the core of the framework is that users, who do not have specific accessibility needs, get more power to navigate any part of a grid using their keyboard.

Exporter Plugin

The Pivot Exporter plugin replaces the old excel export plugin. It is used for exporting data in MS-Excel format. This one uses a more generic approach and allows you to export the pivot grid data to any exporter available in the class system.

RowWidget Plugin

The RowWidget plugin allows other components to be rendered in the row body of a grid. So you can now use any component, even a grid or tree, inside a grid.

Credit: https://blogs.walkingtree.in/2016/06/17/nested-grid-in-ext-js-6-2-0/

Spreadsheet Selection Model

From Ext JS 5.1,Sencha added a brand new selection model that mimics the experience of a spreadsheet. Using this model, users can select cell ranges as entire columns or rows or the entire data set.

Credit: http://examples.sencha.com/extjs/6.0.2/examples/kitchensink/#spreadsheet-checked

You can even enable row checkboxes such that spreadsheet may be the only selection model you’ll ever need.

Clipboard Plugin

This plugin adds clipboard support to a grid.This class supports the following formats for grid data:

cell – Complete field data that can be matched to other grids using the same Ext.data.Model regardless of column order.

text – Cell content stripped of HTML tags.

html – Complete cell content, including any rendered HTML tags.

raw – Underlying field values based on dataIndex.

The cell format is not valid for the system clipboard format.

Dashboard

Sencha Ext JS offers classes that can be used to develop Dashboards. This class manages a drag-drop Dashboard similar to the legacy Ext JS Portal example.

Credit: http://examples.sencha.com/extjs/6.2.0-ea/examples/admin-dashboard/#dashboard

The user-directed layout of the Dashboard is preserved the Ext JS stateful mechanism to preserve potentially dynamic user sizing and collapsed states as well as order of items in their columns.

TreeList Widget

The treelist can be used similarly to a tree component. There are a few key differences:

Treelist provides a ui mixin (it generated the navigation view above).

Treelist has a “micro” mode where only top-level node icons are visible. Children are displayed in a floating element (as seen above).

Treelist renders all nodes in its TreeStore (it does not support buffered rendering). Nodes can, of course, be fetched asynchronously.

Treelist nodes are themselves rendered as Widgets.

Treelist supports selection and hover “indicator” (the vertical blue stripe on the selected node).

Treelist only supports single-selection.

Treelist does not support additional columns.

Treelist does not support grid plugins.

This makes a treelist suitable for trees that don’t contain too many nodes. For large data sets, the standard tree component should still be preferred.

Calendar Component

Ext JS 6.2 adds a new calendar component to the framework that can help you easily view and manage schedules, calendars, events and many more fully loaded features.

Credit: http://examples.sencha.com/extjs/6.2.0-ea/examples/calendar/

By leveraging this component, you can easily add a fully-functional calendar to your apps without investing a lot of time and effort in building one.

Toast Window

This class provides lightweight, auto-dismissing pop-up notifications called “toasts”. At the base level, you can display a toast message by calling Ext.toast.

Charts

The biggest new features in the charts package are the improvements to the 3D pie series (‘pie3d’). It now supports labels, legend, highlighting, tooltips, bevels and has improved shading with configurable level of 3D effects.

#3 : Advanced /Custom Theming

Triton Theme

Triton theme is a lightweight and the first Ext JS theme to provide comprehensive support for font icons. Many of the icons used in Triton are from Font Awesome with some useful additions to complete the ensemble.

Credit: http://docs.sencha.com/extjs/6.0.2classic/guides/whats_new/images/triton.png

By using the Triton theme, developers can easily control the size and color of icons in their apps because they are based on scalable vector fonts. With font icons, you don’t lose quality when they are scaled up or down.

Fashion theme compiler is a brand-new blazing fast Sass compiler from Sencha written entirely in JavaScript. We can achieve amazing improvements in productivity by using Sencha Fashion to compile the application’s CSS. With Fashion Theme Compiler, we can do incremental rebuilds of the theme during app watch, which is a real benefit during development.

Material Design Theme

Credit: https://www.sencha.com/blog/dan-tilden-wins-the-sencha-theming-contest/

With Ext JS 6.2, Sencha has introduced a new “Material” theme for the Modern Toolkit that implements the Material Design spec for every single UI component in the toolkit. You no longer need to create a “Material Theme” from scratch, because it is available out of the box.

Sencha Themer

Sencha Themer empowers you to style Ext JS 6 apps and make them look great. You can create custom themes using graphical tools – without writing code. Sencha Themer gives you access to all Ext JS components and inspection tools to set fine-grained styles and generate theme packages with dynamic stylesheets.

With Sencha Themer tool you can import/export your theme as a package for reusability.

#4 : Improved Application Performance

In-built Microloader introduced in Ext JS 5, which improves the initial load of the application much better.

With Triton theme you don’t have to make multiple HTTP requests for each image, it improves network load times.

There is an important benefit to app watch using Fashion – Live Updates! You can open an application in a (modern) browser and the .scss files we be loaded instead of the generated CSS. Fashion can then react to file changes and update the CSS without reloading the page.

Best performing grid component for huge datasets.

Smooth Scrolling and Animations.

#5 : Much Faster Development

Ext JS 6 has been  created with a clear vision and purpose to allow developers to create beautiful web applications that scale. To speed up the development we have following tools and features in Ext JS 6.

JetBrains IDE Plugin

Sencha has introduced a new plugin that creates a confluence between Sencha frameworks and JetBrains IDEs.

Credit: https://docs.sencha.com/ide_plugins/jetbrains_ide_plugin.html

The plugin integrates the Sencha frameworks with the JetBrains IDEs seamlessly in the form of code completion, code inspection, code navigation, template creation, refactoring, and many features, while cooperating with native JetBrains IDE functionalities.

Sencha Inspector

Sencha has introduced an entirely new debugging tool that provides direct access to components, classes, objects, and more for apps built using Sencha frameworks.

Credit: https://docs.sencha.com/sencha_inspector/demo_app_walkthrough.html

It also lets you analyze your application code for issues, such as over nesting of components, and helps improve your application performance. Sencha Inspector even let’s you theme your applications by inspecting and modifying the Sencha Sass-like code in near real-time.

Sencha Cmd

Sencha Cmd 6 comes with Ext JS 6, and Sencha has enhanced the installers to include the Java Runtime Environment (JRE). We no longer need to download and install Java separately. Sencha has also removed the Ruby dependency, so there are literally no prerequisites for installing Sencha Cmd, beyond the operating system.And for code sharing with packages, Sencha Cmd 6 introduces different folders for packages we generate vs. the packages we require. The location for packages can now be configured with the introduction of the workspace.json file. With Sencha Cmd 6, the Microloader has undergone major updates, and even provides support for localStorage caching.

Viewport Pinch/Zoom and Native Scrolling

With Ext JS 6.2, scrolling is now supported natively on all mobile browsers and uses the native scrollers for all devices and browsers. This allows the framework to support pinch-to-zoom at the viewport level on all touch-screen devices.

D3 Adapter

With Ext JS 6.2, Sencha has integrated D3 charts as a package. As a lightweight and extremely flexible and popular JavaScript library, D3 is a great fit for Ext JS apps. The Ext JS D3 Adapter gives you the opportunity to create more unique, customized, and dynamic visualizations than ever before.

Promises

Promises provide a simpler alternative way for executing, composing, and managing async operations when compared to callbacks. Promises provide us a great way of handling asynchronous errors using approaches that are similar to synchronous try/catch.

Summary

In this article, we talked about top 5 reasons why one must migrate to Sencha ExtJS 6. For a major release like Ext JS6, we totally understand that listing out just 5 top reasons is not fair – for example finding resources which can manage your 3.x or 4.x version of the application is a big challenge.

We wanted to highlight that it is much more beneficial to move to the newer version than staying with the older one.  Please do visit the various releases (major as well as minor) of Ext JS6 to know the more reasons for migrating to Ext JS6. Also, look at the examples to see further capabilities of the framework. Further, you may like to read about the upgrades (Sencha Touch to Ext JS6 and Ext JS5 to Ext JS6) to see what Sencha has already done for you.

WalkingTree’s professional services engineers have wide and in-depth experience in  migrating complex applications. We would love to share our experience with you and we can help with application migration to make effective use of the amazing framework. Contact us for your specific migration need.

References

What’s new in Ext JS 6.0.2

What’s new in Ext JS 5.1.2

What’s new in Ext JS 5.0.0

Universal apps using Ext JS 6

Ext JS 6.2 early access

Filed under: Sencha ExtJS, Sencha Touch

Show more