@acorex/data-grid 3.0.22 → 3.0.26

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.
Files changed (94) hide show
  1. package/README.md +2 -2
  2. package/acorex-data-grid.d.ts +4 -0
  3. package/acorex-data-grid.metadata.json +1 -0
  4. package/bundles/acorex-data-grid.umd.js +2224 -0
  5. package/bundles/acorex-data-grid.umd.js.map +1 -0
  6. package/bundles/acorex-data-grid.umd.min.js +16 -0
  7. package/bundles/acorex-data-grid.umd.min.js.map +1 -0
  8. package/esm2015/acorex-data-grid.js +5 -0
  9. package/esm2015/lib/data-grid/columns/check-column.component.js +104 -0
  10. package/esm2015/lib/data-grid/columns/column.component.js +204 -0
  11. package/esm2015/lib/data-grid/columns/command-column.component.js +103 -0
  12. package/esm2015/lib/data-grid/columns/date-column.component.js +114 -0
  13. package/esm2015/lib/data-grid/columns/row-number-column.component.js +39 -0
  14. package/esm2015/lib/data-grid/columns/selection-column.component.js +42 -0
  15. package/esm2015/lib/data-grid/columns/text-column.component.js +81 -0
  16. package/esm2015/lib/data-grid/datagrid.component.js +709 -0
  17. package/esm2015/lib/data-grid/datagrid.events.js +1 -0
  18. package/esm2015/lib/data-grid/datagrid.module.js +98 -0
  19. package/esm2015/lib/data-grid/filters/filter.component.js +25 -0
  20. package/esm2015/lib/data-grid/templates/cell-template.component.js +47 -0
  21. package/esm2015/lib/data-grid/templates/detail-template.component.js +45 -0
  22. package/esm2015/lib/data-grid/templates/row-template.component.js +40 -0
  23. package/esm2015/lib/data-lov/data-lov-popup/data-lov-popup.component.js +121 -0
  24. package/esm2015/lib/data-lov/data-lov.component.js +206 -0
  25. package/esm2015/lib/data-lov/data-lov.module.js +21 -0
  26. package/esm2015/public-api.js +17 -0
  27. package/esm5/acorex-data-grid.js +5 -0
  28. package/esm5/lib/data-grid/columns/check-column.component.js +102 -0
  29. package/esm5/lib/data-grid/columns/column.component.js +206 -0
  30. package/esm5/lib/data-grid/columns/command-column.component.js +98 -0
  31. package/esm5/lib/data-grid/columns/date-column.component.js +119 -0
  32. package/esm5/lib/data-grid/columns/row-number-column.component.js +42 -0
  33. package/esm5/lib/data-grid/columns/selection-column.component.js +46 -0
  34. package/esm5/lib/data-grid/columns/text-column.component.js +81 -0
  35. package/esm5/lib/data-grid/datagrid.component.js +767 -0
  36. package/esm5/lib/data-grid/datagrid.events.js +1 -0
  37. package/esm5/lib/data-grid/datagrid.module.js +101 -0
  38. package/esm5/lib/data-grid/filters/filter.component.js +16 -0
  39. package/esm5/lib/data-grid/templates/cell-template.component.js +46 -0
  40. package/esm5/lib/data-grid/templates/detail-template.component.js +49 -0
  41. package/esm5/lib/data-grid/templates/row-template.component.js +44 -0
  42. package/esm5/lib/data-lov/data-lov-popup/data-lov-popup.component.js +127 -0
  43. package/esm5/lib/data-lov/data-lov.component.js +216 -0
  44. package/esm5/lib/data-lov/data-lov.module.js +24 -0
  45. package/esm5/public-api.js +17 -0
  46. package/fesm2015/acorex-data-grid.js +1901 -0
  47. package/fesm2015/acorex-data-grid.js.map +1 -0
  48. package/fesm5/acorex-data-grid.js +1980 -0
  49. package/fesm5/acorex-data-grid.js.map +1 -0
  50. package/lib/data-grid/columns/check-column.component.d.ts +30 -0
  51. package/lib/data-grid/columns/column.component.d.ts +29 -0
  52. package/lib/data-grid/columns/command-column.component.d.ts +22 -0
  53. package/lib/data-grid/columns/date-column.component.d.ts +27 -0
  54. package/lib/data-grid/columns/row-number-column.component.d.ts +7 -0
  55. package/lib/data-grid/columns/selection-column.component.d.ts +8 -0
  56. package/lib/data-grid/columns/text-column.component.d.ts +20 -0
  57. package/lib/data-grid/datagrid.component.d.ts +129 -0
  58. package/{src/lib/data-grid/datagrid.events.ts → lib/data-grid/datagrid.events.d.ts} +20 -23
  59. package/lib/data-grid/datagrid.module.d.ts +3 -0
  60. package/lib/data-grid/filters/filter.component.d.ts +2 -0
  61. package/lib/data-grid/templates/cell-template.component.d.ts +17 -0
  62. package/lib/data-grid/templates/detail-template.component.d.ts +16 -0
  63. package/lib/data-grid/templates/row-template.component.d.ts +15 -0
  64. package/lib/data-lov/data-lov-popup/data-lov-popup.component.d.ts +29 -0
  65. package/lib/data-lov/data-lov.component.d.ts +39 -0
  66. package/lib/data-lov/data-lov.module.d.ts +2 -0
  67. package/package.json +27 -17
  68. package/{src/public-api.ts → public-api.d.ts} +17 -20
  69. package/karma.conf.js +0 -32
  70. package/ng-package.json +0 -12
  71. package/src/lib/data-grid/columns/check-column.component.ts +0 -113
  72. package/src/lib/data-grid/columns/column.component.ts +0 -181
  73. package/src/lib/data-grid/columns/command-column.component.ts +0 -102
  74. package/src/lib/data-grid/columns/date-column.component.ts +0 -119
  75. package/src/lib/data-grid/columns/row-number-column.component.ts +0 -36
  76. package/src/lib/data-grid/columns/selection-column.component.ts +0 -37
  77. package/src/lib/data-grid/columns/text-column.component.ts +0 -92
  78. package/src/lib/data-grid/datagrid.component.html +0 -26
  79. package/src/lib/data-grid/datagrid.component.ts +0 -724
  80. package/src/lib/data-grid/datagrid.module.ts +0 -93
  81. package/src/lib/data-grid/filters/filter.component.ts +0 -21
  82. package/src/lib/data-grid/templates/cell-template.component.ts +0 -47
  83. package/src/lib/data-grid/templates/detail-template.component.ts +0 -43
  84. package/src/lib/data-grid/templates/row-template.component.ts +0 -41
  85. package/src/lib/data-lov/data-lov-popup/data-lov-popup.component.html +0 -16
  86. package/src/lib/data-lov/data-lov-popup/data-lov-popup.component.ts +0 -135
  87. package/src/lib/data-lov/data-lov.component.html +0 -61
  88. package/src/lib/data-lov/data-lov.component.ts +0 -177
  89. package/src/lib/data-lov/data-lov.module.ts +0 -17
  90. package/src/test.ts +0 -26
  91. package/tsconfig.lib.json +0 -23
  92. package/tsconfig.lib.prod.json +0 -6
  93. package/tsconfig.spec.json +0 -17
  94. package/tslint.json +0 -17
@@ -0,0 +1,206 @@
1
+ var AXLOVComponent_1;
2
+ import { __decorate, __metadata } from "tslib";
3
+ import { Component, Input, ContentChildren, QueryList, Output, EventEmitter, ContentChild, ViewChild, ViewEncapsulation, ElementRef, TemplateRef } from '@angular/core';
4
+ import { AXPopupService, AXBaseInputComponent, AXBaseSizableComponent, AXElementSize, AXValidation } from '@acorex/components';
5
+ import { AXDataSourceComponent, AXSelectBoxComponent, AXValidatableComponent } from '@acorex/components';
6
+ import { AXDataLovPopupComponent } from './data-lov-popup/data-lov-popup.component';
7
+ import { AXGridDataColumn } from '../data-grid/columns/column.component';
8
+ import { AXConfig } from '@acorex/core';
9
+ let AXLOVComponent = AXLOVComponent_1 = class AXLOVComponent extends AXValidatableComponent {
10
+ constructor(popup, ref) {
11
+ super();
12
+ this.popup = popup;
13
+ this.ref = ref;
14
+ this.textField = '';
15
+ this.allowSearch = true;
16
+ this.valueField = '';
17
+ this.hasChildField = 'null';
18
+ this.allowNull = true;
19
+ this.popupSize = 'md';
20
+ this.selectedItems = [];
21
+ // @Input()
22
+ // selectedValues: any[] = [];
23
+ this.readonly = false;
24
+ this.disabled = false;
25
+ this.chipsWidth = '';
26
+ this.size = 'md';
27
+ this.mode = 'single';
28
+ this.onSelectionChange = new EventEmitter();
29
+ this.rtl = AXConfig.get('layout.rtl');
30
+ }
31
+ get validation() {
32
+ return this._validation ? this._validation : this._contentValidation;
33
+ }
34
+ set validation(v) {
35
+ this._validation = v;
36
+ }
37
+ focus() { this.selectBox.focus(); }
38
+ refresh() {
39
+ this.selectBox.refresh();
40
+ }
41
+ handleButtonClick() {
42
+ this.open();
43
+ }
44
+ ngOnInit() {
45
+ if (this.rtl == null) {
46
+ this.rtl = window.getComputedStyle(this.ref.nativeElement, null).getPropertyValue('direction') === 'rtl';
47
+ }
48
+ // this.selectVal = this.selectedValues;
49
+ this.onSelectionChange.subscribe(c => {
50
+ this.clearValidationStyle(this.ref.nativeElement);
51
+ });
52
+ }
53
+ ngAfterContentInit() {
54
+ this.initValidation(this.ref, 'selectedItems', this.validation);
55
+ }
56
+ handleSelectChange(e) {
57
+ // console.log('se' + JSON.stringify(e));
58
+ this.onSelectionChange.emit({ data: this.selectedItems, component: this, htmlElement: this.ref.nativeElement });
59
+ }
60
+ open() {
61
+ return new Promise((resolve) => {
62
+ this.selectBox.dropdown.close();
63
+ this.popup.open(AXDataLovPopupComponent, {
64
+ size: this.popupSize,
65
+ data: {
66
+ dataSource: this.dataSource,
67
+ selectionMode: this.mode,
68
+ columns: this.columns.toArray(),
69
+ // selectedItems: this.selectedValues,
70
+ selectedItems: this.selectedItems,
71
+ keyField: this.valueField,
72
+ allowNull: this.allowNull,
73
+ hasChildField: this.hasChildField,
74
+ rtl: this.rtl
75
+ },
76
+ title: this.caption,
77
+ }).then(c => {
78
+ if (c.data) {
79
+ // this.selectedValues = [];
80
+ this.selectedItems = [];
81
+ c.data.forEach(elm => {
82
+ this.selectedItems.push(elm);
83
+ });
84
+ // this.selectedItems = c.data;
85
+ // this.selectBox.refresh();
86
+ // console.log('se' + JSON.stringify(this.selectedItems));
87
+ this.onSelectionChange.emit({ data: this.selectedItems, component: this, htmlElement: this.ref.nativeElement });
88
+ if (resolve) {
89
+ resolve(c.data);
90
+ }
91
+ }
92
+ else {
93
+ if (resolve) {
94
+ resolve();
95
+ }
96
+ }
97
+ this.selectBox.refresh();
98
+ });
99
+ });
100
+ }
101
+ };
102
+ AXLOVComponent.ctorParameters = () => [
103
+ { type: AXPopupService },
104
+ { type: ElementRef }
105
+ ];
106
+ __decorate([
107
+ ContentChild(AXValidation, { static: true }),
108
+ __metadata("design:type", AXValidation)
109
+ ], AXLOVComponent.prototype, "_contentValidation", void 0);
110
+ __decorate([
111
+ Input(),
112
+ __metadata("design:type", AXValidation),
113
+ __metadata("design:paramtypes", [AXValidation])
114
+ ], AXLOVComponent.prototype, "validation", null);
115
+ __decorate([
116
+ ViewChild('selectBox', { static: true }),
117
+ __metadata("design:type", AXSelectBoxComponent)
118
+ ], AXLOVComponent.prototype, "selectBox", void 0);
119
+ __decorate([
120
+ ContentChild(AXDataSourceComponent, { static: true }),
121
+ __metadata("design:type", AXDataSourceComponent)
122
+ ], AXLOVComponent.prototype, "dataSource", void 0);
123
+ __decorate([
124
+ ContentChildren(AXGridDataColumn),
125
+ __metadata("design:type", QueryList)
126
+ ], AXLOVComponent.prototype, "columns", void 0);
127
+ __decorate([
128
+ ContentChild('itemTemplate', { static: true }),
129
+ __metadata("design:type", TemplateRef)
130
+ ], AXLOVComponent.prototype, "rowTemplate", void 0);
131
+ __decorate([
132
+ Input(),
133
+ __metadata("design:type", String)
134
+ ], AXLOVComponent.prototype, "textField", void 0);
135
+ __decorate([
136
+ Input(),
137
+ __metadata("design:type", Boolean)
138
+ ], AXLOVComponent.prototype, "allowSearch", void 0);
139
+ __decorate([
140
+ Input(),
141
+ __metadata("design:type", String)
142
+ ], AXLOVComponent.prototype, "valueField", void 0);
143
+ __decorate([
144
+ Input(),
145
+ __metadata("design:type", String)
146
+ ], AXLOVComponent.prototype, "hasChildField", void 0);
147
+ __decorate([
148
+ Input(),
149
+ __metadata("design:type", Boolean)
150
+ ], AXLOVComponent.prototype, "allowNull", void 0);
151
+ __decorate([
152
+ Input(),
153
+ __metadata("design:type", String)
154
+ ], AXLOVComponent.prototype, "popupSize", void 0);
155
+ __decorate([
156
+ Input(),
157
+ __metadata("design:type", Array)
158
+ ], AXLOVComponent.prototype, "selectedItems", void 0);
159
+ __decorate([
160
+ Input(),
161
+ __metadata("design:type", Boolean)
162
+ ], AXLOVComponent.prototype, "readonly", void 0);
163
+ __decorate([
164
+ Input(),
165
+ __metadata("design:type", Boolean)
166
+ ], AXLOVComponent.prototype, "disabled", void 0);
167
+ __decorate([
168
+ Input(),
169
+ __metadata("design:type", String)
170
+ ], AXLOVComponent.prototype, "chipsWidth", void 0);
171
+ __decorate([
172
+ Input(),
173
+ __metadata("design:type", String)
174
+ ], AXLOVComponent.prototype, "size", void 0);
175
+ __decorate([
176
+ Input(),
177
+ __metadata("design:type", String)
178
+ ], AXLOVComponent.prototype, "caption", void 0);
179
+ __decorate([
180
+ Input(),
181
+ __metadata("design:type", String)
182
+ ], AXLOVComponent.prototype, "mode", void 0);
183
+ __decorate([
184
+ Input(),
185
+ __metadata("design:type", String)
186
+ ], AXLOVComponent.prototype, "placeholder", void 0);
187
+ __decorate([
188
+ Output(),
189
+ __metadata("design:type", EventEmitter)
190
+ ], AXLOVComponent.prototype, "onSelectionChange", void 0);
191
+ __decorate([
192
+ Input(),
193
+ __metadata("design:type", Boolean)
194
+ ], AXLOVComponent.prototype, "rtl", void 0);
195
+ AXLOVComponent = AXLOVComponent_1 = __decorate([
196
+ Component({
197
+ selector: 'ax-lov',
198
+ template: "<ax-select-box [rowInputTemplate]=\"rowTemplate\" [rtl]=\"rtl\" [allowSearch]=\"allowSearch\" #selectBox [showDropDownButton]=\"false\" [allowNull]=\"allowNull\"\n [remoteOperation]=\"true\" [placeholder]=\"placeholder\" [size]=\"size\" [textField]=\"textField\" [valueField]=\"valueField\"\n [disabled]=\"disabled\" [mode]=\"mode\" [(selectedItems)]=\"selectedItems\"\n (selectionChanged)=\"handleSelectChange($event)\" [dataSource]=\"dataSource\">\n <ng-container start>\n <ng-content select=\"[start]\">\n </ng-content>\n </ng-container>\n <ng-container end>\n <ax-button icon=\"far fa-bars icon\" [disabled]=\"disabled\" type=\"light blank\" (click)=\"handleButtonClick()\" end\n [tabIndex]=\"-1\">\n </ax-button>\n <ng-content select=\"[end]\">\n </ng-content>\n </ng-container>\n</ax-select-box>\n\n\n<!-- <ax-select-box2 [rtl]=\"rtl\" [allowSearch]=\"allowSearch\" #selectBox [showDropDownButton]=\"false\" [allowNull]=\"allowNull\"\n [remoteOperation]=\"true\" [placeholder]=\"placeholder\" [size]=\"size\" [textField]=\"textField\" [valueField]=\"valueField\"\n [disabled]=\"disabled\" [selectionMode]=\"mode\" (onValueChanged)=\"handleSelectChange($event)\" [dataSource]=\"dataSource\"\n [(value)]=\"selectedItems\" selectionDataMode=\"item\">\n <ng-container start>\n <ng-content select=\"[start]\">\n </ng-content>\n </ng-container>\n <ng-container end>\n <ax-button icon=\"far fa-bars icon\" [disabled]=\"disabled\" type=\"primary blank\" (click)=\"handleButtonClick()\" end\n [tabIndex]=\"-1\">\n </ax-button>\n <ng-content select=\"[end]\">\n </ng-content>\n </ng-container>\n</ax-select-box2> -->\n\n\n<!-- <div class=\"ax-lov-box\" [style.display]=\"mode=='hidden' ? 'none':'unset'\">\n <div class=\"ax-field-set\">\n <div class=\"ax-field-set-wrapper\" [ngClass]=\"{ 'no-label': !label }\">\n <fieldset [ngClass]=\"{ 'input-focused': isFocused, 'input-error': errorText }\">\n <legend *ngIf=\"label\">\n {{ label }}\n </legend>\n </fieldset>\n <input type=\"text\" [(ngModel)]=\"text\" [placeholder]=\"placeholder\" (keyup)=\"handleKeyEvent($event)\"\n (blur)=\"handleBlurEvent($event)\" (focus)=\"handleFocusEvent($event)\" class=\"ax-text-box\" disabled />\n <div class=\"ax-field-set-button\">\n <button *ngIf=\"text && allowClear\" type=\"button\" class=\"btn btn-light\" (click)=\"clearText()\">\n <i class=\"far fa-times\"></i>\n </button>\n <button type=\"button\" class=\" btn btn-primary\" (click)=\"handleButtonClick($event)\">\n <i class=\"far fa-check-circle\"></i>\n </button>\n </div>\n </div>\n </div>\n <div class=\"validation-text\" *ngIf=\"errorText\">\n {{ errorText }}\n </div>\n\n</div> -->",
199
+ encapsulation: ViewEncapsulation.None,
200
+ host: { style: 'width: 100%' },
201
+ providers: [{ provide: AXValidatableComponent, useExisting: AXLOVComponent_1 }]
202
+ }),
203
+ __metadata("design:paramtypes", [AXPopupService, ElementRef])
204
+ ], AXLOVComponent);
205
+ export { AXLOVComponent };
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-lov.component.js","sourceRoot":"ng://@acorex/data-grid/","sources":["lib/data-lov/data-lov.component.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,SAAS,EAAE,iBAAiB,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AACxK,OAAO,EAAE,cAAc,EAAE,oBAAoB,EAAE,sBAAsB,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAC/H,OAAO,EAAE,qBAAqB,EAAE,oBAAoB,EAAe,sBAAsB,EAAE,MAAM,oBAAoB,CAAC;AACtH,OAAO,EAAE,uBAAuB,EAAE,MAAM,2CAA2C,CAAC;AACpF,OAAO,EAAE,gBAAgB,EAAE,MAAM,uCAAuC,CAAC;AACzE,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AAWxC,IAAa,cAAc,sBAA3B,MAAa,cAAe,SAAQ,sBAAsB;IAcxD,YAAoB,KAAqB,EAAU,GAAe;QAChE,KAAK,EAAE,CAAC;QADU,UAAK,GAAL,KAAK,CAAgB;QAAU,QAAG,GAAH,GAAG,CAAY;QAmBlE,cAAS,GAAW,EAAE,CAAC;QAGvB,gBAAW,GAAY,IAAI,CAAC;QAG5B,eAAU,GAAW,EAAE,CAAC;QAGxB,kBAAa,GAAW,MAAM,CAAC;QAG/B,cAAS,GAAY,IAAI,CAAC;QAG1B,cAAS,GAAgC,IAAI,CAAC;QAG9C,kBAAa,GAAU,EAAE,CAAC;QAE1B,WAAW;QACX,8BAA8B;QAG9B,aAAQ,GAAY,KAAK,CAAC;QAG1B,aAAQ,GAAY,KAAK,CAAC;QAG1B,eAAU,GAAW,EAAE,CAAC;QAGxB,SAAI,GAAkB,IAAI,CAAC;QAM3B,SAAI,GAA0B,QAAQ,CAAC;QAMvC,sBAAiB,GAAmC,IAAI,YAAY,EAAoB,CAAC;QAGzF,QAAG,GAAY,QAAQ,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IAjE1C,CAAC;IATD,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC;IACvE,CAAC;IACD,IAAW,UAAU,CAAC,CAAe;QACnC,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;IACvB,CAAC;IAwED,KAAK,KAAW,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IAEzC,OAAO;QACL,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,GAAG,IAAI,IAAI,EAAE;YACpB,IAAI,CAAC,GAAG,GAAG,MAAM,CAAC,gBAAgB,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC,gBAAgB,CAAC,WAAW,CAAC,KAAK,KAAK,CAAC;SAC1G;QACD,yCAAyC;QACzC,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE;YACnC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,CAAC;QACpD,CAAC,CAAC,CAAC;IACL,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,EAAE,eAAe,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAClE,CAAC;IAGD,kBAAkB,CAAC,CAAC;QAElB,0CAA0C;QAC1C,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,SAAS,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC;IAClH,CAAC;IAGM,IAAI;QACT,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YAC7B,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;YAChC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,uBAAuB,EAAE;gBACvC,IAAI,EAAE,IAAI,CAAC,SAAS;gBACpB,IAAI,EAAE;oBACJ,UAAU,EAAE,IAAI,CAAC,UAAU;oBAC3B,aAAa,EAAE,IAAI,CAAC,IAAI;oBACxB,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE;oBAC/B,uCAAuC;oBACvC,aAAa,EAAE,IAAI,CAAC,aAAa;oBACjC,QAAQ,EAAE,IAAI,CAAC,UAAU;oBACzB,SAAS,EAAE,IAAI,CAAC,SAAS;oBACzB,aAAa,EAAE,IAAI,CAAC,aAAa;oBACjC,GAAG,EAAE,IAAI,CAAC,GAAG;iBAEd;gBACD,KAAK,EAAE,IAAI,CAAC,OAAO;aAEpB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;gBAEV,IAAI,CAAC,CAAC,IAAI,EAAE;oBACV,4BAA4B;oBAC5B,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;oBACxB,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;wBACnB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;oBAC9B,CAAC,CAAC,CAAC;oBACH,gCAAgC;oBAChC,6BAA6B;oBAC7B,6DAA6D;oBAC7D,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,EAAE,SAAS,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC;oBAChH,IAAI,OAAO,EAAE;wBACX,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;qBACjB;iBACF;qBAAM;oBACL,IAAI,OAAO,EAAE;wBACX,OAAO,EAAE,CAAC;qBACX;iBACF;gBAED,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;YAC3B,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;CACF,CAAA;;YAlJ4B,cAAc;YAAe,UAAU;;AAXlE;IADC,YAAY,CAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;8BACjB,YAAY;0DAAC;AAIzC;IADC,KAAK,EAAE;8BAIiB,YAAY;qCAAZ,YAAY;gDADpC;AAUD;IADC,SAAS,CAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;8BAC9B,oBAAoB;iDAAC;AAGhC;IADC,YAAY,CAAC,qBAAqB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;8BAC1C,qBAAqB;kDAAC;AAGlC;IADC,eAAe,CAAC,gBAAgB,CAAC;8BACjB,SAAS;+CAAmB;AAI7C;IADC,YAAY,CAAC,cAAc,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;8BAClC,WAAW;mDAAM;AAI9B;IADC,KAAK,EAAE;;iDACe;AAGvB;IADC,KAAK,EAAE;;mDACoB;AAG5B;IADC,KAAK,EAAE;;kDACgB;AAGxB;IADC,KAAK,EAAE;;qDACuB;AAG/B;IADC,KAAK,EAAE;;iDACkB;AAG1B;IADC,KAAK,EAAE;;iDACsC;AAG9C;IADC,KAAK,EAAE;;qDACkB;AAM1B;IADC,KAAK,EAAE;;gDACkB;AAG1B;IADC,KAAK,EAAE;;gDACkB;AAG1B;IADC,KAAK,EAAE;;kDACgB;AAGxB;IADC,KAAK,EAAE;;4CACmB;AAG3B;IADC,KAAK,EAAE;;+CACQ;AAGhB;IADC,KAAK,EAAE;;4CAC+B;AAGvC;IADC,KAAK,EAAE;;mDACY;AAGpB;IADC,MAAM,EAAE;8BACU,YAAY;yDAA0D;AAGzF;IADC,KAAK,EAAE;;2CACkC;AAjF/B,cAAc;IAP1B,SAAS,CAAC;QACT,QAAQ,EAAE,QAAQ;QAClB,+9FAAwC;QACxC,aAAa,EAAE,iBAAiB,CAAC,IAAI;QACrC,IAAI,EAAE,EAAE,KAAK,EAAC,aAAa,EAAE;QAC7B,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,sBAAsB,EAAE,WAAW,EAAE,gBAAc,EAAE,CAAC;KAC9E,CAAC;qCAe2B,cAAc,EAAe,UAAU;GAdvD,cAAc,CAgK1B;SAhKY,cAAc","sourcesContent":["import { Component, Input, ContentChildren, QueryList, Output, EventEmitter, ContentChild, ViewChild, ViewEncapsulation, ElementRef, TemplateRef } from '@angular/core';\nimport { AXPopupService, AXBaseInputComponent, AXBaseSizableComponent, AXElementSize, AXValidation } from '@acorex/components';\nimport { AXDataSourceComponent, AXSelectBoxComponent, AXDataEvent, AXValidatableComponent } from '@acorex/components';\nimport { AXDataLovPopupComponent } from './data-lov-popup/data-lov-popup.component';\nimport { AXGridDataColumn } from '../data-grid/columns/column.component';\nimport { AXConfig } from '@acorex/core';\n\n\n\n@Component({\n  selector: 'ax-lov',\n  templateUrl: './data-lov.component.html',\n  encapsulation: ViewEncapsulation.None,\n  host: { style:'width: 100%' },\n  providers: [{ provide: AXValidatableComponent, useExisting: AXLOVComponent }]\n})\nexport class AXLOVComponent extends AXValidatableComponent implements AXBaseSizableComponent, AXBaseInputComponent {\n\n  @ContentChild(AXValidation, { static: true })\n  private _contentValidation: AXValidation;\n  private _validation: AXValidation;\n\n  @Input()\n  public get validation(): AXValidation {\n    return this._validation ? this._validation : this._contentValidation;\n  }\n  public set validation(v: AXValidation) {\n    this._validation = v;\n  }\n\n  constructor(private popup: AXPopupService, private ref: ElementRef) {\n    super();\n  }\n\n  @ViewChild('selectBox', { static: true })\n  selectBox: AXSelectBoxComponent;\n\n  @ContentChild(AXDataSourceComponent, { static: true })\n  dataSource: AXDataSourceComponent;\n\n  @ContentChildren(AXGridDataColumn)\n  private columns: QueryList<AXGridDataColumn>;\n\n\n  @ContentChild('itemTemplate', { static: true })\n  rowTemplate: TemplateRef<any>;\n\n\n  @Input()\n  textField: string = '';\n\n  @Input()\n  allowSearch: boolean = true;\n\n  @Input()\n  valueField: string = '';\n\n  @Input()\n  hasChildField: string = 'null';\n\n  @Input()\n  allowNull: boolean = true;\n\n  @Input()\n  popupSize: 'sm' | 'md' | 'lg' | 'full' = 'md';\n\n  @Input()\n  selectedItems: any[] = [];\n\n  // @Input()\n  // selectedValues: any[] = [];\n\n  @Input()\n  readonly: boolean = false;\n\n  @Input()\n  disabled: boolean = false;\n\n  @Input()\n  chipsWidth: string = '';\n\n  @Input()\n  size: AXElementSize = 'md';\n\n  @Input()\n  caption: string;\n\n  @Input()\n  mode: 'single' | 'multiple' = 'single';\n\n  @Input()\n  placeholder: string;\n\n  @Output()\n  onSelectionChange: EventEmitter<AXDataEvent<any>> = new EventEmitter<AXDataEvent<any>>();\n\n  @Input()\n  rtl: boolean = AXConfig.get('layout.rtl');\n\n\n  focus(): void { this.selectBox.focus(); }\n\n  refresh() {\n    this.selectBox.refresh();\n  }\n\n  handleButtonClick() {\n    this.open();\n  }\n\n  ngOnInit(): void {\n    if (this.rtl == null) {\n      this.rtl = window.getComputedStyle(this.ref.nativeElement, null).getPropertyValue('direction') === 'rtl';\n    }\n    //  this.selectVal = this.selectedValues;\n    this.onSelectionChange.subscribe(c => {\n      this.clearValidationStyle(this.ref.nativeElement);\n    });\n  }\n\n  ngAfterContentInit(): void {\n    this.initValidation(this.ref, 'selectedItems', this.validation);\n  }\n\n\n  handleSelectChange(e) {\n\n    //  console.log('se' + JSON.stringify(e));\n    this.onSelectionChange.emit({ data: this.selectedItems, component: this, htmlElement: this.ref.nativeElement });\n  }\n\n\n  public open(): Promise<any> {\n    return new Promise((resolve) => {\n      this.selectBox.dropdown.close();\n      this.popup.open(AXDataLovPopupComponent, {\n        size: this.popupSize,\n        data: {\n          dataSource: this.dataSource,\n          selectionMode: this.mode,\n          columns: this.columns.toArray(),\n          //  selectedItems: this.selectedValues,\n          selectedItems: this.selectedItems,\n          keyField: this.valueField,\n          allowNull: this.allowNull,\n          hasChildField: this.hasChildField,\n          rtl: this.rtl\n\n        },\n        title: this.caption,\n        // size: this.size,\n      }).then(c => {\n\n        if (c.data) {\n          // this.selectedValues = [];\n          this.selectedItems = [];\n          c.data.forEach(elm => {\n            this.selectedItems.push(elm)\n          });\n          //  this.selectedItems = c.data;\n          //  this.selectBox.refresh();\n          //    console.log('se' + JSON.stringify(this.selectedItems));\n          this.onSelectionChange.emit({ data: this.selectedItems, component: this, htmlElement: this.ref.nativeElement });\n          if (resolve) {\n            resolve(c.data);\n          }\n        } else {\n          if (resolve) {\n            resolve();\n          }\n        }\n\n        this.selectBox.refresh();\n      });\n    });\n  }\n}\n"]}
@@ -0,0 +1,21 @@
1
+ import { __decorate } from "tslib";
2
+ import { NgModule } from '@angular/core';
3
+ import { CommonModule } from '@angular/common';
4
+ import { AXLOVComponent } from './data-lov.component';
5
+ import { FormsModule } from '@angular/forms';
6
+ import { AXDataLovPopupComponent } from './data-lov-popup/data-lov-popup.component';
7
+ import { AXDataGridModule } from '../data-grid/datagrid.module';
8
+ import { AXDataSourceModule, AXButtonModule, AXToolbarModule, AXSearchBoxModule, AXSelectBoxModule } from '@acorex/components';
9
+ let AXLOVModule = class AXLOVModule {
10
+ };
11
+ AXLOVModule = __decorate([
12
+ NgModule({
13
+ declarations: [AXLOVComponent, AXDataLovPopupComponent],
14
+ imports: [CommonModule, FormsModule, AXDataGridModule, AXDataSourceModule, AXButtonModule, AXToolbarModule, AXSelectBoxModule, AXSearchBoxModule],
15
+ exports: [AXLOVComponent, AXDataLovPopupComponent],
16
+ providers: [],
17
+ entryComponents: [AXDataLovPopupComponent]
18
+ })
19
+ ], AXLOVModule);
20
+ export { AXLOVModule };
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1sb3YubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQGFjb3JleC9kYXRhLWdyaWQvIiwic291cmNlcyI6WyJsaWIvZGF0YS1sb3YvZGF0YS1sb3YubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxjQUFjLEVBQUUsZUFBZSxFQUFFLGlCQUFpQixFQUFFLGlCQUFpQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFVL0gsSUFBYSxXQUFXLEdBQXhCLE1BQWEsV0FBVztDQUFJLENBQUE7QUFBZixXQUFXO0lBUHZCLFFBQVEsQ0FBQztRQUNOLFlBQVksRUFBRSxDQUFDLGNBQWMsRUFBRSx1QkFBdUIsQ0FBQztRQUN2RCxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsV0FBVyxFQUFFLGdCQUFnQixFQUFFLGtCQUFrQixFQUFFLGNBQWMsRUFBRSxlQUFlLEVBQUUsaUJBQWlCLEVBQUUsaUJBQWlCLENBQUM7UUFDakosT0FBTyxFQUFFLENBQUMsY0FBYyxFQUFFLHVCQUF1QixDQUFDO1FBQ2xELFNBQVMsRUFBRSxFQUFFO1FBQ2IsZUFBZSxFQUFFLENBQUMsdUJBQXVCLENBQUM7S0FDN0MsQ0FBQztHQUNXLFdBQVcsQ0FBSTtTQUFmLFdBQVciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEFYTE9WQ29tcG9uZW50IH0gZnJvbSAnLi9kYXRhLWxvdi5jb21wb25lbnQnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBBWERhdGFMb3ZQb3B1cENvbXBvbmVudCB9IGZyb20gJy4vZGF0YS1sb3YtcG9wdXAvZGF0YS1sb3YtcG9wdXAuY29tcG9uZW50JztcbmltcG9ydCB7IEFYRGF0YUdyaWRNb2R1bGUgfSBmcm9tICcuLi9kYXRhLWdyaWQvZGF0YWdyaWQubW9kdWxlJztcbmltcG9ydCB7IEFYRGF0YVNvdXJjZU1vZHVsZSwgQVhCdXR0b25Nb2R1bGUsIEFYVG9vbGJhck1vZHVsZSwgQVhTZWFyY2hCb3hNb2R1bGUsIEFYU2VsZWN0Qm94TW9kdWxlIH0gZnJvbSAnQGFjb3JleC9jb21wb25lbnRzJztcblxuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW0FYTE9WQ29tcG9uZW50LCBBWERhdGFMb3ZQb3B1cENvbXBvbmVudF0sXG4gICAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIEFYRGF0YUdyaWRNb2R1bGUsIEFYRGF0YVNvdXJjZU1vZHVsZSwgQVhCdXR0b25Nb2R1bGUsIEFYVG9vbGJhck1vZHVsZSwgQVhTZWxlY3RCb3hNb2R1bGUsIEFYU2VhcmNoQm94TW9kdWxlXSxcbiAgICBleHBvcnRzOiBbQVhMT1ZDb21wb25lbnQsIEFYRGF0YUxvdlBvcHVwQ29tcG9uZW50XSxcbiAgICBwcm92aWRlcnM6IFtdLFxuICAgIGVudHJ5Q29tcG9uZW50czogW0FYRGF0YUxvdlBvcHVwQ29tcG9uZW50XVxufSlcbmV4cG9ydCBjbGFzcyBBWExPVk1vZHVsZSB7IH0iXX0=
@@ -0,0 +1,17 @@
1
+ export * from './lib/data-grid/columns/check-column.component';
2
+ export * from './lib/data-grid/columns/column.component';
3
+ export * from './lib/data-grid/columns/command-column.component';
4
+ export * from './lib/data-grid/columns/date-column.component';
5
+ export * from './lib/data-grid/columns/selection-column.component';
6
+ export * from './lib/data-grid/columns/text-column.component';
7
+ export * from './lib/data-grid/columns/row-number-column.component';
8
+ export * from './lib/data-grid/datagrid.component';
9
+ export * from './lib/data-grid/datagrid.module';
10
+ export * from './lib/data-grid/filters/filter.component';
11
+ export * from './lib/data-grid/templates/cell-template.component';
12
+ export * from './lib/data-grid/templates/row-template.component';
13
+ export * from './lib/data-grid/templates/detail-template.component';
14
+ export * from './lib/data-lov/data-lov-popup/data-lov-popup.component';
15
+ export * from './lib/data-lov/data-lov.component';
16
+ export * from './lib/data-lov/data-lov.module';
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BhY29yZXgvZGF0YS1ncmlkLyIsInNvdXJjZXMiOlsicHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsMENBQTBDLENBQUM7QUFDekQsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsb0RBQW9ELENBQUM7QUFDbkUsY0FBYywrQ0FBK0MsQ0FBQztBQUM5RCxjQUFjLHFEQUFxRCxDQUFDO0FBRXBFLGNBQWMsb0NBQW9DLENBQUM7QUFFbkQsY0FBYyxpQ0FBaUMsQ0FBQztBQUVoRCxjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLHFEQUFxRCxDQUFDO0FBRXBFLGNBQWMsd0RBQXdELENBQUM7QUFDdkUsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLGdDQUFnQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0YS1ncmlkL2NvbHVtbnMvY2hlY2stY29sdW1uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRhLWdyaWQvY29sdW1ucy9jb2x1bW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGEtZ3JpZC9jb2x1bW5zL2NvbW1hbmQtY29sdW1uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRhLWdyaWQvY29sdW1ucy9kYXRlLWNvbHVtbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0YS1ncmlkL2NvbHVtbnMvc2VsZWN0aW9uLWNvbHVtbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0YS1ncmlkL2NvbHVtbnMvdGV4dC1jb2x1bW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGEtZ3JpZC9jb2x1bW5zL3Jvdy1udW1iZXItY29sdW1uLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGEtZ3JpZC9kYXRhZ3JpZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0YS1ncmlkL2RhdGFncmlkLmV2ZW50cyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRhLWdyaWQvZGF0YWdyaWQubW9kdWxlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0YS1ncmlkL2ZpbHRlcnMvZmlsdGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRhLWdyaWQvdGVtcGxhdGVzL2NlbGwtdGVtcGxhdGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGEtZ3JpZC90ZW1wbGF0ZXMvcm93LXRlbXBsYXRlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRhLWdyaWQvdGVtcGxhdGVzL2RldGFpbC10ZW1wbGF0ZS5jb21wb25lbnQnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi9kYXRhLWxvdi9kYXRhLWxvdi1wb3B1cC9kYXRhLWxvdi1wb3B1cC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZGF0YS1sb3YvZGF0YS1sb3YuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2RhdGEtbG92L2RhdGEtbG92Lm1vZHVsZSc7XG4iXX0=
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public-api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWNvcmV4LWRhdGEtZ3JpZC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BhY29yZXgvZGF0YS1ncmlkLyIsInNvdXJjZXMiOlsiYWNvcmV4LWRhdGEtZ3JpZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL3B1YmxpYy1hcGknO1xuIl19
@@ -0,0 +1,102 @@
1
+ import { __decorate, __extends, __metadata } from "tslib";
2
+ import { Component, ChangeDetectionStrategy, ViewChild, ViewContainerRef } from '@angular/core';
3
+ import { AXGridDataColumn } from './column.component';
4
+ var AXGridCheckColumn = /** @class */ (function (_super) {
5
+ __extends(AXGridCheckColumn, _super);
6
+ function AXGridCheckColumn() {
7
+ return _super.call(this) || this;
8
+ }
9
+ AXGridCheckColumn_1 = AXGridCheckColumn;
10
+ AXGridCheckColumn.prototype.render = function () {
11
+ var col = _super.prototype.render.call(this);
12
+ if (!col.cellRendererFramework) {
13
+ col.cellRendererFramework = BooleanRenderer;
14
+ }
15
+ if (this.allowFiltering) {
16
+ col.filterFramework = BooleanFilterRenderer;
17
+ }
18
+ return col;
19
+ };
20
+ var AXGridCheckColumn_1;
21
+ AXGridCheckColumn = AXGridCheckColumn_1 = __decorate([
22
+ Component({
23
+ selector: 'ax-check-column',
24
+ template: '',
25
+ providers: [{ provide: AXGridDataColumn, useExisting: AXGridCheckColumn_1 }],
26
+ changeDetection: ChangeDetectionStrategy.OnPush
27
+ }),
28
+ __metadata("design:paramtypes", [])
29
+ ], AXGridCheckColumn);
30
+ return AXGridCheckColumn;
31
+ }(AXGridDataColumn));
32
+ export { AXGridCheckColumn };
33
+ var BooleanRenderer = /** @class */ (function () {
34
+ function BooleanRenderer() {
35
+ }
36
+ BooleanRenderer.prototype.agInit = function (params) {
37
+ this.value = params.value;
38
+ };
39
+ BooleanRenderer.prototype.refresh = function (params) {
40
+ this.value = params.value;
41
+ return true;
42
+ };
43
+ BooleanRenderer = __decorate([
44
+ Component({
45
+ template: "\n <ax-check-box [value]='value' readonly='true'></ax-check-box>\n ",
46
+ changeDetection: ChangeDetectionStrategy.OnPush
47
+ }),
48
+ __metadata("design:paramtypes", [])
49
+ ], BooleanRenderer);
50
+ return BooleanRenderer;
51
+ }());
52
+ export { BooleanRenderer };
53
+ var BooleanFilterRenderer = /** @class */ (function () {
54
+ function BooleanFilterRenderer() {
55
+ this.value = null;
56
+ this.selectItem = [
57
+ { value: 0, label: 'True' },
58
+ { value: 1, label: 'False' },
59
+ ];
60
+ }
61
+ BooleanFilterRenderer.prototype.agInit = function (params) {
62
+ this.params = params;
63
+ this.valueGetter = params.valueGetter;
64
+ };
65
+ BooleanFilterRenderer.prototype.isFilterActive = function () {
66
+ return this.value !== null && this.value !== undefined;
67
+ };
68
+ BooleanFilterRenderer.prototype.doesFilterPass = function (params) {
69
+ return this.value === this.valueGetter(params.node);
70
+ };
71
+ BooleanFilterRenderer.prototype.getModel = function () {
72
+ return { value: this.value };
73
+ };
74
+ BooleanFilterRenderer.prototype.setModel = function (model) {
75
+ this.value = model ? model.value : null;
76
+ };
77
+ BooleanFilterRenderer.prototype.ngAfterViewInit = function (params) {
78
+ var _this = this;
79
+ window.setTimeout(function () {
80
+ _this.input.element.nativeElement.focus();
81
+ });
82
+ };
83
+ BooleanFilterRenderer.prototype.onChange = function (newValue) {
84
+ if (this.value !== newValue) {
85
+ this.value = newValue;
86
+ this.params.filterChangedCallback();
87
+ }
88
+ };
89
+ __decorate([
90
+ ViewChild('input', { static: true, read: ViewContainerRef }),
91
+ __metadata("design:type", Object)
92
+ ], BooleanFilterRenderer.prototype, "input", void 0);
93
+ BooleanFilterRenderer = __decorate([
94
+ Component({
95
+ template: "\n <ax-data-grid-filter>\n <ax-select-box\n label='Select Box'\n [items]='selectItem'\n ></ax-select-box>\n </ax-data-grid-filter>\n ",
96
+ changeDetection: ChangeDetectionStrategy.OnPush
97
+ })
98
+ ], BooleanFilterRenderer);
99
+ return BooleanFilterRenderer;
100
+ }());
101
+ export { BooleanFilterRenderer };
102
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hlY2stY29sdW1uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJuZzovL0BhY29yZXgvZGF0YS1ncmlkLyIsInNvdXJjZXMiOlsibGliL2RhdGEtZ3JpZC9jb2x1bW5zL2NoZWNrLWNvbHVtbi5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFDTCxTQUFTLEVBQ1QsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxnQkFBZ0IsRUFDakIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFpQnREO0lBQXVDLHFDQUFnQjtJQUNyRDtlQUNFLGlCQUFPO0lBQ1QsQ0FBQzswQkFIVSxpQkFBaUI7SUFLNUIsa0NBQU0sR0FBTjtRQUNFLElBQU0sR0FBRyxHQUFHLGlCQUFNLE1BQU0sV0FBRSxDQUFDO1FBQzNCLElBQUksQ0FBQyxHQUFHLENBQUMscUJBQXFCLEVBQUU7WUFDOUIsR0FBRyxDQUFDLHFCQUFxQixHQUFHLGVBQWUsQ0FBQztTQUM3QztRQUNELElBQUksSUFBSSxDQUFDLGNBQWMsRUFBRTtZQUN2QixHQUFHLENBQUMsZUFBZSxHQUFHLHFCQUFxQixDQUFDO1NBQzdDO1FBQ0QsT0FBTyxHQUFHLENBQUM7SUFDYixDQUFDOztJQWRVLGlCQUFpQjtRQVA3QixTQUFTLENBQUM7WUFDVCxRQUFRLEVBQUUsaUJBQWlCO1lBQzNCLFFBQVEsRUFBRSxFQUFFO1lBQ1osU0FBUyxFQUFFLENBQUMsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLG1CQUFpQixFQUFFLENBQUM7WUFDMUUsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07U0FDaEQsQ0FBQzs7T0FFVyxpQkFBaUIsQ0FlN0I7SUFBRCx3QkFBQztDQUFBLEFBZkQsQ0FBdUMsZ0JBQWdCLEdBZXREO1NBZlksaUJBQWlCO0FBdUI5QjtJQUVFO0lBQWdCLENBQUM7SUFDakIsZ0NBQU0sR0FBTixVQUFPLE1BQTJCO1FBQ2hDLElBQUksQ0FBQyxLQUFLLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQztJQUM1QixDQUFDO0lBQ0QsaUNBQU8sR0FBUCxVQUFRLE1BQTJCO1FBQ2pDLElBQUksQ0FBQyxLQUFLLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUMxQixPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUFUVSxlQUFlO1FBTjNCLFNBQVMsQ0FBQztZQUNULFFBQVEsRUFBRSx5RUFFVDtZQUNELGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO1NBQ2hELENBQUM7O09BQ1csZUFBZSxDQVUzQjtJQUFELHNCQUFDO0NBQUEsQUFWRCxJQVVDO1NBVlksZUFBZTtBQXVCNUI7SUFBQTtRQUNTLFVBQUssR0FBYSxJQUFJLENBQUM7UUFLOUIsZUFBVSxHQUFHO1lBQ1gsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUU7WUFDM0IsRUFBRSxLQUFLLEVBQUUsQ0FBQyxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUU7U0FDN0IsQ0FBQztJQWtDSixDQUFDO0lBakNDLHNDQUFNLEdBQU4sVUFBTyxNQUFxQjtRQUMxQixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsV0FBVyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUM7SUFDeEMsQ0FBQztJQUVELDhDQUFjLEdBQWQ7UUFDRSxPQUFPLElBQUksQ0FBQyxLQUFLLEtBQUssSUFBSSxJQUFJLElBQUksQ0FBQyxLQUFLLEtBQUssU0FBUyxDQUFDO0lBQ3pELENBQUM7SUFFRCw4Q0FBYyxHQUFkLFVBQWUsTUFBNkI7UUFDMUMsT0FBTyxJQUFJLENBQUMsS0FBSyxLQUFLLElBQUksQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFRCx3Q0FBUSxHQUFSO1FBQ0UsT0FBTyxFQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDL0IsQ0FBQztJQUVELHdDQUFRLEdBQVIsVUFBUyxLQUFVO1FBQ2pCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUM7SUFDMUMsQ0FBQztJQUVELCtDQUFlLEdBQWYsVUFBZ0IsTUFBK0I7UUFBL0MsaUJBSUM7UUFIQyxNQUFNLENBQUMsVUFBVSxDQUFDO1lBQ2hCLEtBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUMzQyxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCx3Q0FBUSxHQUFSLFVBQVMsUUFBUTtRQUNmLElBQUksSUFBSSxDQUFDLEtBQUssS0FBSyxRQUFRLEVBQUU7WUFDM0IsSUFBSSxDQUFDLEtBQUssR0FBRyxRQUFRLENBQUM7WUFDdEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO1NBQ3JDO0lBQ0gsQ0FBQztJQXRDNkQ7UUFBN0QsU0FBUyxDQUFDLE9BQU8sRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFFLGdCQUFnQixFQUFFLENBQUM7O3dEQUFjO0lBSmhFLHFCQUFxQjtRQVhqQyxTQUFTLENBQUM7WUFDVCxRQUFRLEVBQUUsc0tBT1Q7WUFDRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtTQUNoRCxDQUFDO09BQ1cscUJBQXFCLENBMkNqQztJQUFELDRCQUFDO0NBQUEsQUEzQ0QsSUEyQ0M7U0EzQ1kscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50LFxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgVmlld0NoaWxkLFxuICBWaWV3Q29udGFpbmVyUmVmXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQVhHcmlkRGF0YUNvbHVtbiB9IGZyb20gJy4vY29sdW1uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJQ2VsbFJlbmRlcmVyQW5ndWxhckNvbXAsIElGaWx0ZXJBbmd1bGFyQ29tcCB9IGZyb20gJ2FnLWdyaWQtYW5ndWxhcic7XG5pbXBvcnQge1xuICBJQ2VsbFJlbmRlcmVyUGFyYW1zLFxuICBJRmlsdGVyUGFyYW1zLFxuICBSb3dOb2RlLFxuICBJRG9lc0ZpbHRlclBhc3NQYXJhbXMsXG4gIElBZnRlckd1aUF0dGFjaGVkUGFyYW1zXG59IGZyb20gJ2FnLWdyaWQtY29tbXVuaXR5JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXgtY2hlY2stY29sdW1uJyxcbiAgdGVtcGxhdGU6ICcnLFxuICBwcm92aWRlcnM6IFt7IHByb3ZpZGU6IEFYR3JpZERhdGFDb2x1bW4sIHVzZUV4aXN0aW5nOiBBWEdyaWRDaGVja0NvbHVtbiB9XSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5cbmV4cG9ydCBjbGFzcyBBWEdyaWRDaGVja0NvbHVtbiBleHRlbmRzIEFYR3JpZERhdGFDb2x1bW4ge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICB9XG5cbiAgcmVuZGVyKCkge1xuICAgIGNvbnN0IGNvbCA9IHN1cGVyLnJlbmRlcigpO1xuICAgIGlmICghY29sLmNlbGxSZW5kZXJlckZyYW1ld29yaykge1xuICAgICAgY29sLmNlbGxSZW5kZXJlckZyYW1ld29yayA9IEJvb2xlYW5SZW5kZXJlcjtcbiAgICB9XG4gICAgaWYgKHRoaXMuYWxsb3dGaWx0ZXJpbmcpIHtcbiAgICAgIGNvbC5maWx0ZXJGcmFtZXdvcmsgPSBCb29sZWFuRmlsdGVyUmVuZGVyZXI7XG4gICAgfVxuICAgIHJldHVybiBjb2w7XG4gIH1cbn1cblxuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlOiBgXG4gICAgPGF4LWNoZWNrLWJveCBbdmFsdWVdPSd2YWx1ZScgcmVhZG9ubHk9J3RydWUnPjwvYXgtY2hlY2stYm94PlxuICBgLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBCb29sZWFuUmVuZGVyZXIgaW1wbGVtZW50cyBJQ2VsbFJlbmRlcmVyQW5ndWxhckNvbXAge1xuICB2YWx1ZTogYm9vbGVhbjtcbiAgY29uc3RydWN0b3IoKSB7IH1cbiAgYWdJbml0KHBhcmFtczogSUNlbGxSZW5kZXJlclBhcmFtcyk6IHZvaWQge1xuICAgIHRoaXMudmFsdWUgPSBwYXJhbXMudmFsdWU7XG4gIH1cbiAgcmVmcmVzaChwYXJhbXM6IElDZWxsUmVuZGVyZXJQYXJhbXMpOiBib29sZWFuIHtcbiAgICB0aGlzLnZhbHVlID0gcGFyYW1zLnZhbHVlO1xuICAgIHJldHVybiB0cnVlO1xuICB9XG59XG5cbkBDb21wb25lbnQoe1xuICB0ZW1wbGF0ZTogYFxuICAgIDxheC1kYXRhLWdyaWQtZmlsdGVyPlxuICAgICAgPGF4LXNlbGVjdC1ib3hcbiAgICAgICAgbGFiZWw9J1NlbGVjdCBCb3gnXG4gICAgICAgIFtpdGVtc109J3NlbGVjdEl0ZW0nXG4gICAgICA+PC9heC1zZWxlY3QtYm94PlxuICAgIDwvYXgtZGF0YS1ncmlkLWZpbHRlcj5cbiAgYCxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgQm9vbGVhbkZpbHRlclJlbmRlcmVyIGltcGxlbWVudHMgSUZpbHRlckFuZ3VsYXJDb21wIHtcbiAgcHVibGljIHZhbHVlPzogYm9vbGVhbiA9IG51bGw7XG4gIHByaXZhdGUgcGFyYW1zOiBJRmlsdGVyUGFyYW1zO1xuICBwcml2YXRlIHZhbHVlR2V0dGVyOiAocm93Tm9kZTogUm93Tm9kZSkgPT4gYW55O1xuICBAVmlld0NoaWxkKCdpbnB1dCcsIHsgc3RhdGljOiB0cnVlLCByZWFkOiBWaWV3Q29udGFpbmVyUmVmIH0pIHB1YmxpYyBpbnB1dDtcblxuICBzZWxlY3RJdGVtID0gW1xuICAgIHsgdmFsdWU6IDAsIGxhYmVsOiAnVHJ1ZScgfSxcbiAgICB7IHZhbHVlOiAxLCBsYWJlbDogJ0ZhbHNlJyB9LFxuICBdO1xuICBhZ0luaXQocGFyYW1zOiBJRmlsdGVyUGFyYW1zKTogdm9pZCB7XG4gICAgdGhpcy5wYXJhbXMgPSBwYXJhbXM7XG4gICAgdGhpcy52YWx1ZUdldHRlciA9IHBhcmFtcy52YWx1ZUdldHRlcjtcbiAgfVxuXG4gIGlzRmlsdGVyQWN0aXZlKCk6IGJvb2xlYW4ge1xuICAgIHJldHVybiB0aGlzLnZhbHVlICE9PSBudWxsICYmIHRoaXMudmFsdWUgIT09IHVuZGVmaW5lZDtcbiAgfVxuXG4gIGRvZXNGaWx0ZXJQYXNzKHBhcmFtczogSURvZXNGaWx0ZXJQYXNzUGFyYW1zKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRoaXMudmFsdWUgPT09IHRoaXMudmFsdWVHZXR0ZXIocGFyYW1zLm5vZGUpO1xuICB9XG5cbiAgZ2V0TW9kZWwoKTogYW55IHtcbiAgICByZXR1cm4geyB2YWx1ZTogdGhpcy52YWx1ZSB9O1xuICB9XG5cbiAgc2V0TW9kZWwobW9kZWw6IGFueSk6IHZvaWQge1xuICAgIHRoaXMudmFsdWUgPSBtb2RlbCA/IG1vZGVsLnZhbHVlIDogbnVsbDtcbiAgfVxuXG4gIG5nQWZ0ZXJWaWV3SW5pdChwYXJhbXM6IElBZnRlckd1aUF0dGFjaGVkUGFyYW1zKTogdm9pZCB7XG4gICAgd2luZG93LnNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgdGhpcy5pbnB1dC5lbGVtZW50Lm5hdGl2ZUVsZW1lbnQuZm9jdXMoKTtcbiAgICB9KTtcbiAgfVxuXG4gIG9uQ2hhbmdlKG5ld1ZhbHVlKTogdm9pZCB7XG4gICAgaWYgKHRoaXMudmFsdWUgIT09IG5ld1ZhbHVlKSB7XG4gICAgICB0aGlzLnZhbHVlID0gbmV3VmFsdWU7XG4gICAgICB0aGlzLnBhcmFtcy5maWx0ZXJDaGFuZ2VkQ2FsbGJhY2soKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,206 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { AXConfig } from '@acorex/core';
3
+ import { Input, ContentChild } from '@angular/core';
4
+ import { AXDataGridCellTemplateComponent } from '../templates/cell-template.component';
5
+ var AXGridDataColumn = /** @class */ (function () {
6
+ function AXGridDataColumn() {
7
+ this.width = 100;
8
+ this.pinned = null;
9
+ this.allowSorting = true;
10
+ this.allowFiltering = AXConfig.get('datagrid.allowFiltering') || false;
11
+ this.sort = null;
12
+ this.field = '';
13
+ this.caption = '';
14
+ this.checkbox = false;
15
+ this.headerCheckbox = false;
16
+ this.groupIndex = -1;
17
+ this.treeIndex = -1;
18
+ this.enableRowGroup = false;
19
+ this.hide = false;
20
+ this.floatingFilter = AXConfig.get('datagrid.floatingFilter') || false;
21
+ this.disableMenu = false;
22
+ this.resizable = true;
23
+ this.menuColumnDisable = false;
24
+ this.menuItemDisable = false;
25
+ }
26
+ ;
27
+ AXGridDataColumn.prototype.render = function () {
28
+ var col = {
29
+ field: this.field,
30
+ width: this.width,
31
+ };
32
+ col.resizable = this.resizable;
33
+ col.suppressMenu = this.disableMenu;
34
+ col.menuTabs = ['filterMenuTab', 'columnsMenuTab', 'generalMenuTab'];
35
+ col.floatingFilter = this.floatingFilter;
36
+ if (!this.allowFiltering) {
37
+ col.filter = false;
38
+ col.menuTabs = col.menuTabs.filter(function (c) { return c != 'filterMenuTab'; });
39
+ col.floatingFilter = false;
40
+ }
41
+ if (this.menuColumnDisable == true) {
42
+ col.menuTabs = col.menuTabs.filter(function (c) { return c != 'columnsMenuTab'; });
43
+ }
44
+ if (this.menuItemDisable == true) {
45
+ col.menuTabs = col.menuTabs.filter(function (c) { return c != 'generalMenuTab'; });
46
+ }
47
+ if (this.caption) {
48
+ col.headerName = this.caption;
49
+ }
50
+ if (this.minWidth) {
51
+ col.minWidth = this.minWidth;
52
+ }
53
+ if (this.maxWidth) {
54
+ col.maxWidth = this.maxWidth;
55
+ }
56
+ if (this.pinned) {
57
+ col.pinned = this.pinned === 'start' ? 'right' : 'left';
58
+ // TODO: Change based on layout
59
+ }
60
+ if (this.allowSorting) {
61
+ col.sortable = this.allowSorting;
62
+ }
63
+ if (this.sort) {
64
+ col.sort = this.sort;
65
+ }
66
+ if (this.groupIndex >= 0) {
67
+ col.rowGroupIndex = this.groupIndex;
68
+ col.rowGroup = true;
69
+ this.enableRowGroup = true;
70
+ }
71
+ if (this.treeIndex >= 0) {
72
+ col.rowGroupIndex = this.treeIndex;
73
+ col.rowGroup = false;
74
+ }
75
+ if (this.hide) {
76
+ col.hide = true;
77
+ }
78
+ if (this.enableRowGroup) {
79
+ col.enableRowGroup = this.enableRowGroup;
80
+ }
81
+ if (this.cellClass) {
82
+ var THAT_1 = this;
83
+ if (this.cellClass instanceof Function) {
84
+ col.cellClass = function (p) {
85
+ return THAT_1.cellClass({
86
+ column: THAT_1,
87
+ rowIndex: p.node.rowIndex,
88
+ rowLevel: p.node.level,
89
+ data: p.data,
90
+ value: p.value
91
+ });
92
+ };
93
+ }
94
+ else {
95
+ col.cellClass = this.cellClass;
96
+ }
97
+ }
98
+ //
99
+ if (this.cellTemplate != null) {
100
+ col.cellRendererFramework = this.cellTemplate.renderer;
101
+ col.cellRendererParams = this.cellTemplate.params;
102
+ }
103
+ if (this.checkbox) {
104
+ col.checkboxSelection = function (params) {
105
+ return true;
106
+ };
107
+ // col.headerCheckboxSelection = this.headerCheckbox;
108
+ }
109
+ return col;
110
+ };
111
+ __decorate([
112
+ ContentChild(AXDataGridCellTemplateComponent),
113
+ __metadata("design:type", AXDataGridCellTemplateComponent)
114
+ ], AXGridDataColumn.prototype, "cellTemplate", void 0);
115
+ __decorate([
116
+ Input(),
117
+ __metadata("design:type", Number)
118
+ ], AXGridDataColumn.prototype, "width", void 0);
119
+ __decorate([
120
+ Input(),
121
+ __metadata("design:type", Number)
122
+ ], AXGridDataColumn.prototype, "maxWidth", void 0);
123
+ __decorate([
124
+ Input(),
125
+ __metadata("design:type", Number)
126
+ ], AXGridDataColumn.prototype, "minWidth", void 0);
127
+ __decorate([
128
+ Input(),
129
+ __metadata("design:type", String)
130
+ ], AXGridDataColumn.prototype, "pinned", void 0);
131
+ __decorate([
132
+ Input(),
133
+ __metadata("design:type", Boolean)
134
+ ], AXGridDataColumn.prototype, "allowSorting", void 0);
135
+ __decorate([
136
+ Input(),
137
+ __metadata("design:type", Boolean)
138
+ ], AXGridDataColumn.prototype, "allowFiltering", void 0);
139
+ __decorate([
140
+ Input(),
141
+ __metadata("design:type", Function)
142
+ ], AXGridDataColumn.prototype, "cellClass", void 0);
143
+ __decorate([
144
+ Input(),
145
+ __metadata("design:type", String)
146
+ ], AXGridDataColumn.prototype, "sort", void 0);
147
+ __decorate([
148
+ Input(),
149
+ __metadata("design:type", String)
150
+ ], AXGridDataColumn.prototype, "field", void 0);
151
+ __decorate([
152
+ Input(),
153
+ __metadata("design:type", String)
154
+ ], AXGridDataColumn.prototype, "caption", void 0);
155
+ __decorate([
156
+ Input(),
157
+ __metadata("design:type", Object)
158
+ ], AXGridDataColumn.prototype, "cellRendererParams", void 0);
159
+ __decorate([
160
+ Input(),
161
+ __metadata("design:type", Boolean)
162
+ ], AXGridDataColumn.prototype, "checkbox", void 0);
163
+ __decorate([
164
+ Input(),
165
+ __metadata("design:type", Boolean)
166
+ ], AXGridDataColumn.prototype, "headerCheckbox", void 0);
167
+ __decorate([
168
+ Input(),
169
+ __metadata("design:type", Number)
170
+ ], AXGridDataColumn.prototype, "groupIndex", void 0);
171
+ __decorate([
172
+ Input(),
173
+ __metadata("design:type", Number)
174
+ ], AXGridDataColumn.prototype, "treeIndex", void 0);
175
+ __decorate([
176
+ Input(),
177
+ __metadata("design:type", Boolean)
178
+ ], AXGridDataColumn.prototype, "enableRowGroup", void 0);
179
+ __decorate([
180
+ Input(),
181
+ __metadata("design:type", Boolean)
182
+ ], AXGridDataColumn.prototype, "hide", void 0);
183
+ __decorate([
184
+ Input(),
185
+ __metadata("design:type", Boolean)
186
+ ], AXGridDataColumn.prototype, "floatingFilter", void 0);
187
+ __decorate([
188
+ Input(),
189
+ __metadata("design:type", Boolean)
190
+ ], AXGridDataColumn.prototype, "disableMenu", void 0);
191
+ __decorate([
192
+ Input(),
193
+ __metadata("design:type", Boolean)
194
+ ], AXGridDataColumn.prototype, "resizable", void 0);
195
+ __decorate([
196
+ Input(),
197
+ __metadata("design:type", Boolean)
198
+ ], AXGridDataColumn.prototype, "menuColumnDisable", void 0);
199
+ __decorate([
200
+ Input(),
201
+ __metadata("design:type", Boolean)
202
+ ], AXGridDataColumn.prototype, "menuItemDisable", void 0);
203
+ return AXGridDataColumn;
204
+ }());
205
+ export { AXGridDataColumn };
206
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column.component.js","sourceRoot":"ng://@acorex/data-grid/","sources":["lib/data-grid/columns/column.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AXConfig } from '@acorex/core';\nimport { Input, ContentChild, TemplateRef } from '@angular/core';\nimport { AXGridCellParams } from '../datagrid.events';\nimport { AXDataGridCellTemplateComponent } from '../templates/cell-template.component';\nimport { AXDatePickerFilterComponent } from './date-column.component';\n\n\nexport abstract class AXGridDataColumn {\n\n\n    @ContentChild(AXDataGridCellTemplateComponent)\n    cellTemplate: AXDataGridCellTemplateComponent;\n\n    @Input()\n    width: number = 100;\n\n    @Input()\n    maxWidth: number;\n\n    @Input()\n    minWidth: number;\n\n    @Input()\n    pinned: 'start' | 'end' | null = null;\n\n    @Input()\n    allowSorting: boolean = true;\n\n    @Input()\n    allowFiltering: boolean = AXConfig.get('datagrid.allowFiltering') || false;;\n\n    @Input()\n    cellClass: (params: AXGridCellParams) => (string | string[]) | (string | string[]);\n\n    @Input()\n    sort: 'asc' | 'desc' | null = null;\n\n    @Input()\n    field: string = '';\n\n    @Input()\n    caption: string = '';\n\n    @Input()\n    cellRendererParams: any;\n\n    @Input()\n    checkbox: boolean = false;\n\n    @Input()\n    headerCheckbox: boolean = false;\n\n    @Input()\n    groupIndex: number = -1;\n\n    @Input()\n    treeIndex: number = -1;\n\n    @Input()\n    enableRowGroup: boolean = false;\n\n    @Input()\n    hide: boolean = false;\n\n    @Input()\n    floatingFilter: boolean = AXConfig.get('datagrid.floatingFilter') || false;\n\n    @Input()\n    disableMenu: boolean = false;\n\n    @Input()\n    resizable: boolean = true;\n\n    @Input()\n    menuColumnDisable: boolean = false;\n\n    @Input()\n    menuItemDisable: boolean = false;\n\n    constructor() { }\n\n    render(): any {\n        const col: any = {\n            field: this.field,\n            width: this.width,\n        };\n        col.resizable = this.resizable;\n        col.suppressMenu = this.disableMenu;\n        col.menuTabs = ['filterMenuTab', 'columnsMenuTab', 'generalMenuTab']\n        col.floatingFilter = this.floatingFilter;\n\n        if (!this.allowFiltering) {\n            col.filter = false;\n            col.menuTabs = col.menuTabs.filter(c => c != 'filterMenuTab');\n            col.floatingFilter = false;\n        }\n        if (this.menuColumnDisable == true) {\n            col.menuTabs = col.menuTabs.filter(c => c != 'columnsMenuTab');\n        }\n        if (this.menuItemDisable == true) {\n            col.menuTabs = col.menuTabs.filter(c => c != 'generalMenuTab');\n        }\n        if (this.caption) {\n            col.headerName = this.caption;\n        }\n        if (this.minWidth) {\n            col.minWidth = this.minWidth;\n        }\n        if (this.maxWidth) {\n            col.maxWidth = this.maxWidth;\n        }\n        if (this.pinned) {\n            col.pinned = this.pinned === 'start' ? 'right' : 'left';\n            // TODO: Change based on layout\n        }\n        if (this.allowSorting) {\n            col.sortable = this.allowSorting;\n        }\n        if (this.sort) {\n            col.sort = this.sort;\n        }\n\n        if (this.groupIndex >= 0) {\n            col.rowGroupIndex = this.groupIndex;\n            col.rowGroup = true;\n            this.enableRowGroup = true;\n        }\n\n        if (this.treeIndex >= 0) {\n            col.rowGroupIndex = this.treeIndex;\n            col.rowGroup = false;\n        }\n        if (this.hide) {\n            col.hide = true;\n\n        }\n        if (this.enableRowGroup) {\n            col.enableRowGroup = this.enableRowGroup;\n        }\n\n        if (this.cellClass) {\n            const THAT = this;\n            if (this.cellClass instanceof Function) {\n                col.cellClass = (p) => {\n                    return THAT.cellClass({\n                        column: THAT,\n                        rowIndex: p.node.rowIndex,\n                        rowLevel: p.node.level,\n                        data: p.data,\n                        value: p.value\n                    });\n                };\n            }\n            else {\n                col.cellClass = this.cellClass;\n\n            }\n        }\n        //\n        if (this.cellTemplate != null) {\n            col.cellRendererFramework = this.cellTemplate.renderer;\n            col.cellRendererParams = this.cellTemplate.params;\n        }\n\n        if (this.checkbox) {\n            col.checkboxSelection = (params) => {\n                return true;\n            };\n            //  col.headerCheckboxSelection = this.headerCheckbox;\n        }\n        return col;\n    }\n}\n\n\n\n\n\n\n\n\n"]}