angular-slickgrid 3.1.0 → 3.3.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "angular-slickgrid",
3
- "version": "3.1.0",
3
+ "version": "3.3.2",
4
4
  "description": "Slickgrid components made available in Angular",
5
5
  "keywords": [
6
6
  "angular",
@@ -11,27 +11,35 @@
11
11
  ],
12
12
  "license": "MIT",
13
13
  "author": "Ghislain B.",
14
+ "homepage": "https://ghiscoding.github.io/Angular-Slickgrid/",
15
+ "bugs": {
16
+ "url": "https://github.com/ghiscoding/Angular-Slickgrid/issues"
17
+ },
14
18
  "repository": {
15
19
  "type": "git",
16
20
  "url": "http://github.com/ghiscoding/angular-slickgrid"
17
21
  },
18
22
  "main": "bundles/angular-slickgrid.umd.js",
19
23
  "private": false,
24
+ "comments": {
25
+ "new-release": "1- build library (ng-packagr), 2- 'prepare-release' (npm script) & publish to npm, typically 'npm publish dist' works if it does not then run script 'pack-lib' and 'npm publish [tar file]'"
26
+ },
20
27
  "dependencies": {
21
- "@slickgrid-universal/common": "^0.17.0",
22
- "@slickgrid-universal/custom-footer-component": "^0.17.0",
23
- "@slickgrid-universal/empty-warning-component": "^0.17.0",
24
- "@slickgrid-universal/event-pub-sub": "^0.17.0",
25
- "@slickgrid-universal/rxjs-observable": "^0.17.0",
26
- "@types/dompurify": "^2.2.3",
27
- "@types/jquery": "^3.5.6",
28
+ "@slickgrid-universal/common": "^0.19.2",
29
+ "@slickgrid-universal/custom-footer-component": "^0.19.2",
30
+ "@slickgrid-universal/empty-warning-component": "^0.19.2",
31
+ "@slickgrid-universal/event-pub-sub": "^0.19.2",
32
+ "@slickgrid-universal/pagination-component": "^0.19.2",
33
+ "@slickgrid-universal/rxjs-observable": "^0.19.2",
34
+ "@types/dompurify": "^2.3.1",
35
+ "@types/jquery": "^3.5.8",
28
36
  "dequal": "^2.0.2",
29
- "dompurify": "^2.3.1",
37
+ "dompurify": "^2.3.3",
30
38
  "font-awesome": "^4.7.0",
31
39
  "jquery": "~3.5.1",
32
40
  "jquery-ui-dist": "^1.12.1",
33
41
  "moment-mini": "^2.24.0",
34
- "rxjs": "^7.3.0",
42
+ "rxjs": ">=7.0.0",
35
43
  "tslib": "^2.2.0"
36
44
  },
37
45
  "peerDependencies": {
@@ -1,42 +0,0 @@
1
- import { OnDestroy, OnInit } from '@angular/core';
2
- import { TranslateService } from '@ngx-translate/core';
3
- import { PaginationService } from '@slickgrid-universal/common';
4
- import { GridOption } from './../models/index';
5
- export declare class SlickPaginationComponent implements OnDestroy, OnInit {
6
- private readonly translate;
7
- gridOptions: GridOption;
8
- paginationService: PaginationService;
9
- private subscriptions;
10
- private _enableTranslate;
11
- private _gridOptions;
12
- private _locales;
13
- textItemsPerPage: string;
14
- textItems: string;
15
- textOf: string;
16
- textPage: string;
17
- /** Constructor */
18
- constructor(translate: TranslateService);
19
- get availablePageSizes(): number[];
20
- get dataFrom(): number;
21
- get dataTo(): number;
22
- /** is the left side pagination disabled? */
23
- get isLeftPaginationDisabled(): boolean;
24
- /** is the right side pagination disabled? */
25
- get isRightPaginationDisabled(): boolean;
26
- get itemsPerPage(): number;
27
- get pageCount(): number;
28
- get pageNumber(): number;
29
- set pageNumber(page: number);
30
- get totalItems(): number;
31
- ngOnDestroy(): void;
32
- ngOnInit(): void;
33
- changeToFirstPage(event: MouseEvent): void;
34
- changeToLastPage(event: MouseEvent): void;
35
- changeToNextPage(event: MouseEvent): void;
36
- changeToPreviousPage(event: MouseEvent): void;
37
- changeToCurrentPage(event: any): void;
38
- changeItemPerPage(event: any): void;
39
- dispose(): void;
40
- /** Translate all the texts shown in the UI, use ngx-translate service when available or custom locales when service is null */
41
- private translateAllUiTexts;
42
- }
@@ -1,137 +0,0 @@
1
- import { Component, Input, Optional } from '@angular/core';
2
- import { TranslateService } from '@ngx-translate/core';
3
- import { getTranslationPrefix } from '@slickgrid-universal/common';
4
- import { Constants } from '../constants';
5
- import { unsubscribeAllObservables } from '../services/utilities';
6
- export class SlickPaginationComponent {
7
- /** Constructor */
8
- constructor(translate) {
9
- this.translate = translate;
10
- this.subscriptions = [];
11
- this._enableTranslate = false;
12
- // text translations (handled by ngx-translate or by custom locale)
13
- this.textItemsPerPage = 'items per page';
14
- this.textItems = 'items';
15
- this.textOf = 'of';
16
- this.textPage = 'Page';
17
- }
18
- get availablePageSizes() {
19
- return this.paginationService.availablePageSizes;
20
- }
21
- get dataFrom() {
22
- return this.paginationService.dataFrom;
23
- }
24
- get dataTo() {
25
- return this.paginationService.dataTo;
26
- }
27
- /** is the left side pagination disabled? */
28
- get isLeftPaginationDisabled() {
29
- return this.pageNumber === 1 || this.totalItems === 0;
30
- }
31
- /** is the right side pagination disabled? */
32
- get isRightPaginationDisabled() {
33
- return this.pageNumber === this.pageCount || this.totalItems === 0;
34
- }
35
- get itemsPerPage() {
36
- return this.paginationService.itemsPerPage;
37
- }
38
- get pageCount() {
39
- return this.paginationService.pageCount;
40
- }
41
- get pageNumber() {
42
- return this.paginationService.pageNumber;
43
- }
44
- set pageNumber(page) {
45
- // the setter has to be declared but we won't use it, instead we will use the "changeToCurrentPage()" to only update the value after ENTER keydown event
46
- }
47
- get totalItems() {
48
- return this.paginationService.totalItems;
49
- }
50
- ngOnDestroy() {
51
- this.dispose();
52
- }
53
- ngOnInit() {
54
- this._gridOptions = this.gridOptions || {};
55
- this._enableTranslate = this._gridOptions && this._gridOptions.enableTranslate || false;
56
- this._locales = this._gridOptions && this._gridOptions.locales || Constants.locales;
57
- if (this._enableTranslate && !this.translate) {
58
- throw new Error('[Angular-Slickgrid] requires "ngx-translate" to be installed and configured when the grid option "enableTranslate" is enabled.');
59
- }
60
- this.translateAllUiTexts(this._locales);
61
- // translate all the text using ngx-translate or custom locales
62
- if (this._enableTranslate && this.translate && this.translate.onLangChange) {
63
- this.subscriptions.push(this.translate.onLangChange.subscribe(() => this.translateAllUiTexts(this._locales)));
64
- }
65
- }
66
- changeToFirstPage(event) {
67
- if (!this.isLeftPaginationDisabled) {
68
- this.paginationService.goToFirstPage(event);
69
- }
70
- }
71
- changeToLastPage(event) {
72
- if (!this.isRightPaginationDisabled) {
73
- this.paginationService.goToLastPage(event);
74
- }
75
- }
76
- changeToNextPage(event) {
77
- if (!this.isRightPaginationDisabled) {
78
- this.paginationService.goToNextPage(event);
79
- }
80
- }
81
- changeToPreviousPage(event) {
82
- if (!this.isLeftPaginationDisabled) {
83
- this.paginationService.goToPreviousPage(event);
84
- }
85
- }
86
- changeToCurrentPage(event) {
87
- let pageNumber = 1;
88
- if (event && event.currentTarget && event.currentTarget.value) {
89
- pageNumber = +(event.currentTarget.value);
90
- }
91
- this.paginationService.goToPageNumber(pageNumber, event);
92
- }
93
- changeItemPerPage(event) {
94
- let itemsPerPage = 1;
95
- if (event && event.currentTarget && event.currentTarget.value) {
96
- itemsPerPage = +(event.currentTarget.value);
97
- }
98
- this.paginationService.changeItemPerPage(itemsPerPage, event);
99
- }
100
- dispose() {
101
- // also unsubscribe all Angular Subscriptions
102
- this.subscriptions = unsubscribeAllObservables(this.subscriptions);
103
- }
104
- // --
105
- // private functions
106
- // --------------------
107
- /** Translate all the texts shown in the UI, use ngx-translate service when available or custom locales when service is null */
108
- translateAllUiTexts(locales) {
109
- if (this._enableTranslate && this.translate && this.translate.instant && this.translate.currentLang) {
110
- const translationPrefix = getTranslationPrefix(this._gridOptions);
111
- this.textItemsPerPage = this.translate.instant(`${translationPrefix}ITEMS_PER_PAGE`);
112
- this.textItems = this.translate.instant(`${translationPrefix}ITEMS`);
113
- this.textOf = this.translate.instant(`${translationPrefix}OF`);
114
- this.textPage = this.translate.instant(`${translationPrefix}PAGE`);
115
- }
116
- else if (locales) {
117
- this.textItemsPerPage = locales.TEXT_ITEMS_PER_PAGE || 'TEXT_ITEMS_PER_PAGE';
118
- this.textItems = locales.TEXT_ITEMS || 'TEXT_ITEMS';
119
- this.textOf = locales.TEXT_OF || 'TEXT_OF';
120
- this.textPage = locales.TEXT_PAGE || 'TEXT_PAGE';
121
- }
122
- }
123
- }
124
- SlickPaginationComponent.decorators = [
125
- { type: Component, args: [{
126
- selector: 'slick-pagination',
127
- template: "<div class=\"slick-pagination\">\r\n <div class=\"slick-pagination-nav\">\r\n <nav aria-label=\"Page navigation\">\r\n <ul class=\"pagination\">\r\n <li class=\"page-item\" [ngClass]=\"isLeftPaginationDisabled ? 'disabled' : ''\">\r\n <a class=\"page-link icon-seek-first fa fa-angle-double-left\" aria-label=\"First\"\r\n (click)=\"changeToFirstPage($event)\">\r\n </a>\r\n </li>\r\n <li class=\"page-item\" [ngClass]=\"isLeftPaginationDisabled ? 'disabled' : ''\">\r\n <a class=\"page-link icon-seek-prev fa fa-angle-left\" aria-label=\"Previous\"\r\n (click)=\"changeToPreviousPage($event)\">\r\n </a>\r\n </li>\r\n </ul>\r\n </nav>\r\n\r\n <div class=\"slick-page-number\">\r\n <span>{{textPage}}</span>\r\n <input type=\"text\" class=\"form-control\" data-test=\"page-number-input\" [value]=\"pageNumber\" size=\"1\"\r\n [readOnly]=\"totalItems === 0\" (change)=\"changeToCurrentPage($event)\">\r\n <span>{{textOf}}</span><span data-test=\"page-count\"> {{pageCount}}</span>\r\n </div>\r\n\r\n <nav aria-label=\"Page navigation\">\r\n <ul class=\"pagination\">\r\n <li class=\"page-item\" [ngClass]=\"isRightPaginationDisabled ? 'disabled' : ''\">\r\n <a class=\"page-link icon-seek-next text-center fa fa-lg fa-angle-right\" aria-label=\"Next\"\r\n (click)=\"changeToNextPage($event)\">\r\n </a>\r\n </li>\r\n <li class=\"page-item\" [ngClass]=\"isRightPaginationDisabled ? 'disabled' : ''\">\r\n <a class=\"page-link icon-seek-end fa fa-lg fa-angle-double-right\" aria-label=\"Last\"\r\n (click)=\"changeToLastPage($event)\">\r\n </a>\r\n </li>\r\n </ul>\r\n </nav>\r\n </div>\r\n <span class=\"slick-pagination-settings\">\r\n <select id=\"items-per-page-label\" (change)=\"changeItemPerPage($event)\">\r\n <option value=\"{{pageSize}}\" [selected]=\"pageSize === itemsPerPage\" *ngFor=\"let pageSize of availablePageSizes\">{{pageSize}}</option>\r\n </select>\r\n <span>{{textItemsPerPage}}</span>,\r\n <span class=\"slick-pagination-count\">\r\n <span *ngIf=\"totalItems\">\r\n <span class=\"page-info-from-to\">\r\n <span data-test=\"item-from\">{{dataFrom}}</span>-<span data-test=\"item-to\">{{dataTo}}</span>\r\n {{textOf}}\r\n </span>\r\n </span>\r\n <span class=\"page-info-total-items\">\r\n <span data-test=\"total-items\">{{totalItems}}</span> {{textItems}}\r\n </span>\r\n </span>\r\n </span>\r\n</div>\r\n"
128
- },] }
129
- ];
130
- SlickPaginationComponent.ctorParameters = () => [
131
- { type: TranslateService, decorators: [{ type: Optional }] }
132
- ];
133
- SlickPaginationComponent.propDecorators = {
134
- gridOptions: [{ type: Input }],
135
- paginationService: [{ type: Input }]
136
- };
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slick-pagination.component.js","sourceRoot":"","sources":["../../../../../../src/app/modules/angular-slickgrid/components/slick-pagination.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnDestroy, OnInit, Optional } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { getTranslationPrefix, Locale, PaginationService } from '@slickgrid-universal/common';\r\nimport { Subscription } from 'rxjs';\r\n\r\nimport { Constants } from '../constants';\r\nimport { GridOption, } from './../models/index';\r\nimport { unsubscribeAllObservables } from '../services/utilities';\r\n\r\n@Component({\r\n  selector: 'slick-pagination',\r\n  templateUrl: './slick-pagination.component.html'\r\n})\r\nexport class SlickPaginationComponent implements OnDestroy, OnInit {\r\n  @Input() gridOptions!: GridOption;\r\n  @Input() paginationService!: PaginationService;\r\n\r\n  private subscriptions: Subscription[] = [];\r\n  private _enableTranslate = false;\r\n  private _gridOptions!: GridOption;\r\n  private _locales!: Locale;\r\n\r\n  // text translations (handled by ngx-translate or by custom locale)\r\n  textItemsPerPage = 'items per page';\r\n  textItems = 'items';\r\n  textOf = 'of';\r\n  textPage = 'Page';\r\n\r\n  /** Constructor */\r\n  constructor(@Optional() private readonly translate: TranslateService) { }\r\n\r\n  get availablePageSizes(): number[] {\r\n    return this.paginationService.availablePageSizes;\r\n  }\r\n\r\n  get dataFrom(): number {\r\n    return this.paginationService.dataFrom;\r\n  }\r\n\r\n  get dataTo(): number {\r\n    return this.paginationService.dataTo;\r\n  }\r\n\r\n  /** is the left side pagination disabled? */\r\n  get isLeftPaginationDisabled(): boolean {\r\n    return this.pageNumber === 1 || this.totalItems === 0;\r\n  }\r\n\r\n  /** is the right side pagination disabled? */\r\n  get isRightPaginationDisabled(): boolean {\r\n    return this.pageNumber === this.pageCount || this.totalItems === 0;\r\n  }\r\n\r\n  get itemsPerPage(): number {\r\n    return this.paginationService.itemsPerPage;\r\n  }\r\n\r\n  get pageCount(): number {\r\n    return this.paginationService.pageCount;\r\n  }\r\n\r\n  get pageNumber(): number {\r\n    return this.paginationService.pageNumber;\r\n  }\r\n  set pageNumber(page: number) {\r\n    // the setter has to be declared but we won't use it, instead we will use the \"changeToCurrentPage()\" to only update the value after ENTER keydown event\r\n  }\r\n\r\n  get totalItems() {\r\n    return this.paginationService.totalItems;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.dispose();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this._gridOptions = this.gridOptions || {};\r\n    this._enableTranslate = this._gridOptions && this._gridOptions.enableTranslate || false;\r\n    this._locales = this._gridOptions && this._gridOptions.locales || Constants.locales;\r\n\r\n    if (this._enableTranslate && !this.translate) {\r\n      throw new Error('[Angular-Slickgrid] requires \"ngx-translate\" to be installed and configured when the grid option \"enableTranslate\" is enabled.');\r\n    }\r\n\r\n    this.translateAllUiTexts(this._locales);\r\n\r\n    // translate all the text using ngx-translate or custom locales\r\n    if (this._enableTranslate && this.translate && this.translate.onLangChange) {\r\n      this.subscriptions.push(this.translate.onLangChange.subscribe(() => this.translateAllUiTexts(this._locales)));\r\n    }\r\n  }\r\n\r\n  changeToFirstPage(event: MouseEvent) {\r\n    if (!this.isLeftPaginationDisabled) {\r\n      this.paginationService.goToFirstPage(event);\r\n    }\r\n  }\r\n\r\n  changeToLastPage(event: MouseEvent) {\r\n    if (!this.isRightPaginationDisabled) {\r\n      this.paginationService.goToLastPage(event);\r\n    }\r\n  }\r\n\r\n  changeToNextPage(event: MouseEvent) {\r\n    if (!this.isRightPaginationDisabled) {\r\n      this.paginationService.goToNextPage(event);\r\n    }\r\n  }\r\n\r\n  changeToPreviousPage(event: MouseEvent) {\r\n    if (!this.isLeftPaginationDisabled) {\r\n      this.paginationService.goToPreviousPage(event);\r\n    }\r\n  }\r\n\r\n  changeToCurrentPage(event: any) {\r\n    let pageNumber = 1;\r\n    if (event && event.currentTarget && event.currentTarget.value) {\r\n      pageNumber = +(event.currentTarget.value);\r\n    }\r\n    this.paginationService.goToPageNumber(pageNumber, event);\r\n  }\r\n\r\n  changeItemPerPage(event: any) {\r\n    let itemsPerPage = 1;\r\n    if (event && event.currentTarget && event.currentTarget.value) {\r\n      itemsPerPage = +(event.currentTarget.value);\r\n    }\r\n    this.paginationService.changeItemPerPage(itemsPerPage, event);\r\n  }\r\n\r\n  dispose() {\r\n    // also unsubscribe all Angular Subscriptions\r\n    this.subscriptions = unsubscribeAllObservables(this.subscriptions);\r\n  }\r\n\r\n  // --\r\n  // private functions\r\n  // --------------------\r\n\r\n  /** Translate all the texts shown in the UI, use ngx-translate service when available or custom locales when service is null */\r\n  private translateAllUiTexts(locales: Locale) {\r\n    if (this._enableTranslate && this.translate && this.translate.instant && this.translate.currentLang) {\r\n      const translationPrefix = getTranslationPrefix(this._gridOptions);\r\n      this.textItemsPerPage = this.translate.instant(`${translationPrefix}ITEMS_PER_PAGE`);\r\n      this.textItems = this.translate.instant(`${translationPrefix}ITEMS`);\r\n      this.textOf = this.translate.instant(`${translationPrefix}OF`);\r\n      this.textPage = this.translate.instant(`${translationPrefix}PAGE`);\r\n    } else if (locales) {\r\n      this.textItemsPerPage = locales.TEXT_ITEMS_PER_PAGE || 'TEXT_ITEMS_PER_PAGE';\r\n      this.textItems = locales.TEXT_ITEMS || 'TEXT_ITEMS';\r\n      this.textOf = locales.TEXT_OF || 'TEXT_OF';\r\n      this.textPage = locales.TEXT_PAGE || 'TEXT_PAGE';\r\n    }\r\n  }\r\n}\r\n"]}