All Projects → ghiscoding → Angular Slickgrid

ghiscoding / Angular Slickgrid

Licence: mit
Angular-Slickgrid is a wrapper of the lightning fast & customizable SlickGrid datagrid, it also includes multiple Styling Themes

Programming Languages

typescript
32286 projects

Projects that are alternatives of or similar to Angular Slickgrid

Aurelia Slickgrid
Aurelia-Slickgrid a wrapper of the lightning fast & customizable SlickGrid datagrid with a few Styling Themes
Stars: ✭ 100 (-66.44%)
Mutual labels:  graphql, grid, datagrid, datatable, jquery, bootstrap4, bootstrap3
Datatablesbundle
This Bundle integrates the jQuery DataTables plugin into your Symfony application.
Stars: ✭ 334 (+12.08%)
Mutual labels:  grid, datagrid, datatable, data-table
slickgrid-universal
Slickgrid-Universal is a monorepo which includes all Editors, Filters, Extensions, Services and is Framework Agnostic to take full advantage of SlickGrid core lib.
Stars: ✭ 29 (-90.27%)
Mutual labels:  grid, datatable, datagrid
Datatable
A simple, modern and interactive datatable library for the web
Stars: ✭ 587 (+96.98%)
Mutual labels:  grid, datagrid, datatable
ag-grid
The best JavaScript Data Table for building Enterprise Applications. Supports React / Angular / Vue / Plain JavaScript.
Stars: ✭ 8,743 (+2833.89%)
Mutual labels:  grid, datatable, datagrid
Reactgrid
Add spreadsheet-like behavior to your React app
Stars: ✭ 289 (-3.02%)
Mutual labels:  datagrid, datatable, data-table
Gijgo
Gijgo - Free Javascript Controls
Stars: ✭ 424 (+42.28%)
Mutual labels:  grid, datagrid, jquery
Awesome Grid
A curated list of grid(table) libraries and resources that developers may find useful.
Stars: ✭ 1,142 (+283.22%)
Mutual labels:  grid, datagrid, jquery
Amexio.github.io
Amexio is a rich set of Angular 7 (170+) components powered by HTML5 & CSS3 for Responsive Design and with 80+ Material Design Themes, UI Components, Charts, Gauges, Data Point Widgets, Dashboards. Amexio is completely Open Sourced and Free. It's based on Apache 2 License. You can use it in your production grade work today at no cost or no obligation.
Stars: ✭ 163 (-45.3%)
Mutual labels:  datatable, bootstrap4, bootstrap3
Grid
Declarative React Canvas Grid primitive for Data table, Pivot table, Excel Worksheets and more 💥
Stars: ✭ 573 (+92.28%)
Mutual labels:  grid, datagrid, datatable
Tui.grid
🍞🔡 The Powerful Component to Display and Edit Data. Experience the Ultimate Data Transformer!
Stars: ✭ 1,859 (+523.83%)
Mutual labels:  grid, datagrid, datatable
Bs grid
Bootstrap Datagrid
Stars: ✭ 184 (-38.26%)
Mutual labels:  grid, datagrid, jquery
svelte-datagrid
Svelte data grid spreadsheet best best features and performance from excel
Stars: ✭ 48 (-83.89%)
Mutual labels:  grid, datatable, datagrid
Ngx Datatable
✨ A feature-rich yet lightweight data-table crafted for Angular
Stars: ✭ 4,415 (+1381.54%)
Mutual labels:  grid, datagrid, datatable
Django Jinja Knockout
Django datatables and widgets, both AJAX and traditional. Display-only ModelForms. ModelForms / inline formsets with AJAX submit and validation. Works with Django templates.
Stars: ✭ 116 (-61.07%)
Mutual labels:  datagrid, bootstrap4, bootstrap3
Sensei Grid
Simple and lightweight data grid in JS/HTML
Stars: ✭ 808 (+171.14%)
Mutual labels:  grid, datagrid, data-table
Bootstrap Validate
A simple Form Validation Library for Bootstrap 3 and Bootstrap 4 not depending on jQuery.
Stars: ✭ 112 (-62.42%)
Mutual labels:  jquery, bootstrap4, bootstrap3
Django Bootstrap Modal Forms
A Django plugin for creating AJAX driven forms in Bootstrap modal.
Stars: ✭ 244 (-18.12%)
Mutual labels:  jquery, bootstrap4, bootstrap3
Ka Table
Lightweight MIT React Table component for both TS and JS with Sorting, Filtering, Grouping, Virtualization, Editing and many more
Stars: ✭ 117 (-60.74%)
Mutual labels:  grid, datagrid, datatable
React Table
⚛️ Hooks for building fast and extendable tables and datagrids for React
Stars: ✭ 15,739 (+5181.54%)
Mutual labels:  grid, datagrid, datatable

Angular-Slickgrid

License: MIT TypeScript npm version NPM downloads gzip size

CircleCI Cypress.io jest codecov

Brief introduction

One of the best javascript datagrid SlickGrid which was originally developed by @mleibman is now available to Angular. I have used a few datagrids and SlickGrid beats most of them in terms of functionalities and performance (it can easily deal with even a million row). We will be using the 6pac/SlickGrid fork, it is the most active fork since the original author @mleibman stopped working on his original repo. Also worth knowing that I have contributed a lot to the 6pac/SlickGrid fork for the benefit of Angular-Slickgrid... also a reminder, this is a wrapper of a jQuery lib (SlickGrid) and a big portion of the lib (like Editors, Filters and others) are written in jQuery/JavaScript, so just keep that in mind and that also means jQuery is a dependency.

NPM Package

Angular-Slickgrid on NPM

License

MIT License

Like it? ⭐️ it

You like and use Angular-Slickgrid? Be sure to upvote ⭐️ and feel free to contribute. 👷

Like my work?

If you like my work, you can also support me with caffeine ☕️ Buy Me a Coffee

I certainly drank many coffees to build and keep adding features for this great library.

Latest News & Releases

Check out the Releases section for all latest News & Releases.

Angular Compatibility

  • version 1.x.x for Angular 4 to 6
    • Angular 6, is only supported through rxjs-compat as shown in this post. It's preferable to upgrade to Angular 7+ to avoid using the rxjs-compat package.
  • version 2.x.x for Angular 7+
    • since version 2.11.0, you can also change your build target to ES2015 for modern browser.

Note on RxJS

Please note that RxJS is fixed at version 6.3.3 and will certainly not work with version 7.0.0. Why you might ask? Because they made structurale changes in version 6.4.0 which would impact anyone using Angular-Slickgrid that haven't upgraded and for that reason the version used by the lib is fixed at 6.3.3. Also note that I will not release a major version of Angular-Slickgrid just to support RxJS 7 (which is still in Beta), a major version of Angular-Slickgrid is many months away.

ngx-translate Compatibility

If you are facing any issues with ngx-translate library while building your Angular Project. You need to make sure that @ngx-translate/core is part of your dependencies, that is also true even if you just use a single Locale, because it is a peerDependency of Angular-Slickgrid. We use @Optional() TranslateService in the lib and for that to work, we still need it to be installed, but don't worry it should be removed by tree shaking process after a running a build. See their version compatibility table below

Angular Version @ngx-translate/core
10 13.x+
9 12.x+
8 12.x+
7 11.x+

Build Warnings (Angular 8+)

You might get warnings about SlickGrid while doing a production build, most of them are fine and the best way to fix them, is to simply remove/ignore the warnings, all you have to do is to add a file named ngcc.config.js in your project root (same location as the angular.json file) with the following content (you can also see this commit which fixes the Angular-Slickgrid-Demos prod build):

module.exports = {
  packages: {
    'angular-slickgrid': {
      ignorableDeepImportMatchers: [
        /slickgrid\//,
        /flatpickr/,
        /jquery-ui-dist\//,
      ]
    },
  }
};

You should also add Angular-Slickgrid as an allowed CommonJS dependency to your angular.json file to silent the warnings.

"options": {
  "allowedCommonJsDependencies": ["angular-slickgrid"]
}

Fully Tested with Jest (Unit Tests) - Cypress (E2E Tests)

Angular-Slickgrid reached 100% Unit Test Coverage, we are talking about +10,000 lines of code (+2,800 unit tests) that are now fully tested with Jest. On the UI side, all Angular-Slickgrid Examples are tested with Cypress, there are over 400+ Cypress E2E tests.

Installation

Refer to the Wiki - HOWTO Step by Step and/or clone the Angular-Slickgrid Demos repository. Please don't open any issue unless you have followed these steps (from the Wiki), and if any of the steps are incorrect or confusing, then please let me know.

NOTE: if you have any question, please consider asking installation and/or general questions on Stack Overflow

Demo page

Angular-Slickgrid supports both Bootstrap 3, Bootstrap 4 and even Bootstrap 5 (Beta), you can see a demo of each one below.

There are also 2 new Themes, Material & Salesforce that are available as well and if you wish to use SVG then take a look at the Wiki - SVG Icons

Working Demo

For a complete and working local demo, you can (should) clone the Angular-Slickgrid Demos repository. That repo is updated frequently and is used to update the GitHub demo pages for the Bootstrap 3 demo and Bootstrap 4 demo.

git clone https://github.com/ghiscoding/angular-slickgrid-demos
cd bootstrap4-demo-with-translate
npm install
npm start

How to load data with HttpClient?

You might notice that all demos are coded with mocked dataset in each examples, that is mainly for demo purposes, but you might be wondering how to connect this with an HttpClient? Easy... just replace the mocked data, assigned to the dataset property, by your HttpClient call and that's it. The dataset property can be changed or refreshed at any time, which is why you can use local data and/or connect it to a Promise or an Observable with HttpClient (internally it's just a SETTER that refreshes the grid). See Example 24 for a demo showing how to load a JSON file with HttpClient.

Wiki / Documentation

The Wiki is where all the documentation and instructions will go, so please consult the Angular-Slickgrid - Wiki before opening any issues. The Wiki - HOWTO is a great place to start with. You can also take a look at the Demo page, it includes sample for most of the features and it keeps growing (so you might want to consult it whenever a new version comes out).

Main features

You can see some screenshots below and the instructions down below and if that is not enough for you to decide, head over to the Wiki - Main Features.

Missing features

What if Angular-Slickgrid is missing feature(s) compare to the original core library 6pac/SlickGrid?

Fear not, and just simply reference the SlickGrid and DataView objects, just like in the core lib, those are exposed through Event Emitters. For more info continue reading on Wiki - SlickGrid & DataView objects and Wiki - Grid & DataView Events

Screenshots

Screenshots from the demo app with the Bootstrap theme.

Note that the styling changed a bit, the best is to simply head over to the Live Demo page.

Slickgrid example with Formatters (last column shown is a custom Formatter)

You can also see the Grid Menu opened (aka hambuger menu)

Default Slickgrid Example

Filters and Multi-Column Sort

Filter and Sort

Inline Editing

Editors

Pinned (aka frozen) Columns/Rows

Pinned Columns/Rows

Draggable Grouping & Aggregators

Draggable Grouping

Slickgrid Example with Server Side (Filter/Sort/Pagination)

Comes with OData & GraphQL support (you can implement custom ones too)

Slickgrid Server Side

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].