@colijnit/corecomponents_v12 12.0.26 → 12.0.29

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 (36) hide show
  1. package/bundles/colijnit-corecomponents_v12.umd.js +172 -31
  2. package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
  3. package/colijnit-corecomponents_v12.metadata.json +1 -1
  4. package/esm2015/lib/components/base/base-input.component.js +2 -2
  5. package/esm2015/lib/components/input-date-range-picker/input-date-range-picker.component.js +46 -0
  6. package/esm2015/lib/components/input-date-range-picker/input-date-range-picker.module.js +23 -0
  7. package/esm2015/lib/components/input-search/input-search.component.js +26 -25
  8. package/esm2015/lib/components/input-search/input-search.module.js +6 -2
  9. package/esm2015/lib/components/input-text/input-text.component.js +10 -4
  10. package/esm2015/lib/components/simple-grid/base-simple-grid.component.js +61 -8
  11. package/esm2015/lib/components/simple-grid/simple-grid-column.directive.js +7 -3
  12. package/esm2015/lib/components/simple-grid/simple-grid.component.js +59 -36
  13. package/esm2015/public-api.js +3 -1
  14. package/fesm2015/colijnit-corecomponents_v12.js +221 -67
  15. package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
  16. package/lib/components/input-date-picker/style/_theme.scss +1 -1
  17. package/lib/components/input-date-range-picker/input-date-range-picker.component.d.ts +12 -0
  18. package/lib/components/input-date-range-picker/input-date-range-picker.module.d.ts +2 -0
  19. package/lib/components/input-date-range-picker/style/_layout.scss +7 -0
  20. package/lib/components/input-date-range-picker/style/_material-definition.scss +12 -0
  21. package/lib/components/input-date-range-picker/style/_theme.scss +3 -0
  22. package/lib/components/input-date-range-picker/style/material.scss +6 -0
  23. package/lib/components/input-search/input-search.component.d.ts +7 -13
  24. package/lib/components/input-search/style/_layout.scss +0 -35
  25. package/lib/components/input-search/style/_material-definition.scss +0 -6
  26. package/lib/components/input-search/style/_theme.scss +0 -2
  27. package/lib/components/input-text/input-text.component.d.ts +3 -1
  28. package/lib/components/input-text/style/_layout.scss +11 -0
  29. package/lib/components/simple-grid/base-simple-grid.component.d.ts +12 -1
  30. package/lib/components/simple-grid/simple-grid-column.directive.d.ts +4 -1
  31. package/lib/components/simple-grid/simple-grid.component.d.ts +2 -1
  32. package/lib/components/simple-grid/style/_layout.scss +26 -9
  33. package/lib/components/simple-grid/style/_material-definition.scss +1 -1
  34. package/lib/style/_variables.scss +2 -2
  35. package/package.json +1 -1
  36. package/public-api.d.ts +2 -0
@@ -3,8 +3,9 @@ import { SimpleGridColumnDirective } from "./simple-grid-column.directive";
3
3
  import { moveItemInArray } from "@angular/cdk/drag-drop";
4
4
  export class BaseSimpleGridComponent {
5
5
  constructor() {
6
- this.data = [];
6
+ this.MIN_COLUMN_WIDTH = 60;
7
7
  this.dragDropEnabled = false;
8
+ this.resizable = false;
8
9
  this.inlineEdit = false;
9
10
  this.showToolbar = false;
10
11
  /**
@@ -17,27 +18,38 @@ export class BaseSimpleGridComponent {
17
18
  this.dblClickRow = new EventEmitter();
18
19
  this.saveRow = new EventEmitter();
19
20
  this.columns = [];
21
+ this.headerColumns = [];
22
+ this._data = [];
23
+ this._prepared = false;
20
24
  }
21
25
  set content(columnComponents) {
22
26
  this._setColumns(columnComponents.toArray());
27
+ this._prepareData();
28
+ }
29
+ set data(value) {
30
+ this._data = value;
31
+ this._prepareData();
32
+ }
33
+ get data() {
34
+ return this._data;
23
35
  }
24
36
  set extraColumns(value) {
25
37
  this._setColumns(value);
26
38
  }
27
39
  handleMouseMove(event) {
28
- if (event.buttons === 1 && this._columnForResize) {
29
- if (!this._columnForResize.width) {
30
- const rect = event.target.parentElement.getBoundingClientRect();
31
- this._columnForResize.width = rect.width;
32
- }
33
- this._columnForResize.width += event.movementX;
40
+ if (this.resizable && event.buttons === 1 && this._columnForResize) {
41
+ this._columnForResize.width = this._columnForResize.originalWidth - (this._startMousePositionX - event.clientX);
34
42
  }
35
43
  }
36
44
  handleMouseUp(event) {
45
+ this._startMousePositionX = undefined;
37
46
  this._columnForResize = undefined;
38
47
  }
39
48
  handleSizerMouseDown(event, column) {
49
+ this._setWidthOfAllColumns();
50
+ this._startMousePositionX = event.clientX;
40
51
  this._columnForResize = column;
52
+ this._columnForResize.originalWidth = this._columnForResize.width;
41
53
  }
42
54
  handleCanDragDrop(drag, drop) {
43
55
  return true;
@@ -60,10 +72,50 @@ export class BaseSimpleGridComponent {
60
72
  console.error(e);
61
73
  }
62
74
  }
75
+ isSingleColumnRow(row) {
76
+ return row.hasOwnProperty('singleColumnIndex');
77
+ }
78
+ singleColumnIndex(row) {
79
+ return row.singleColumnIndex;
80
+ }
63
81
  _setColumns(columns) {
64
82
  this.columns.push(...columns);
65
83
  this.columns.sort((a, b) => a.order < b.order ? -1 : 1);
66
84
  }
85
+ _prepareData() {
86
+ if (this._prepared) {
87
+ return;
88
+ }
89
+ if (this.columns && this.columns.length > 0 && this.data && this.data.length > 0) {
90
+ this.headerColumns = this.columns.filter(c => !c.singleColumn);
91
+ let singleColumnIndex = -1;
92
+ for (let i = 0; i < this.columns.length; i++) {
93
+ if (this.columns[i].singleColumn) {
94
+ singleColumnIndex = i;
95
+ break;
96
+ }
97
+ }
98
+ // first check if there's single column data
99
+ if (singleColumnIndex > -1) {
100
+ const field = this.columns[singleColumnIndex].field;
101
+ for (let i = 0; i < this.data.length; i++) { // then mark row as single column row
102
+ if (this.data[i][field] !== undefined && this.data[i][field] !== null && this.data[i][field] !== "") {
103
+ // bit nasty to add prop, but cool for now
104
+ this.data[i].singleColumnIndex = singleColumnIndex;
105
+ }
106
+ }
107
+ }
108
+ this._prepared = true;
109
+ }
110
+ }
111
+ _setWidthOfAllColumns() {
112
+ this.columns.forEach((column) => {
113
+ if ((column.width === undefined || column.width === null) && column.elementRef && column.elementRef.nativeElement) {
114
+ const rect = column.elementRef.nativeElement.getBoundingClientRect();
115
+ column.width = rect.width;
116
+ }
117
+ });
118
+ }
67
119
  }
68
120
  BaseSimpleGridComponent.decorators = [
69
121
  { type: Directive }
@@ -72,6 +124,7 @@ BaseSimpleGridComponent.propDecorators = {
72
124
  content: [{ type: ContentChildren, args: [SimpleGridColumnDirective,] }],
73
125
  data: [{ type: Input }],
74
126
  dragDropEnabled: [{ type: Input }],
127
+ resizable: [{ type: Input }],
75
128
  inlineEdit: [{ type: Input }],
76
129
  showToolbar: [{ type: Input }],
77
130
  emitDragDrop: [{ type: Input }],
@@ -83,4 +136,4 @@ BaseSimpleGridComponent.propDecorators = {
83
136
  handleMouseMove: [{ type: HostListener, args: ['document:mousemove', ['$event'],] }],
84
137
  handleMouseUp: [{ type: HostListener, args: ['document:mouseup', ['$event'],] }]
85
138
  };
86
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1zaW1wbGUtZ3JpZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvc2ltcGxlLWdyaWQvYmFzZS1zaW1wbGUtZ3JpZC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGVBQWUsRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUEwQixNQUFNLGVBQWUsQ0FBQztBQUM3SCxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN6RSxPQUFPLEVBQW9DLGVBQWUsRUFBQyxNQUFNLHdCQUF3QixDQUFDO0FBRzFGLE1BQU0sT0FBZ0IsdUJBQXVCO0lBRDdDO1FBT1MsU0FBSSxHQUFhLEVBQUUsQ0FBQztRQUdwQixvQkFBZSxHQUFZLEtBQUssQ0FBQztRQUdqQyxlQUFVLEdBQVksS0FBSyxDQUFDO1FBRzVCLGdCQUFXLEdBQVksS0FBSyxDQUFDO1FBRXBDOzs7V0FHRztRQUVJLGlCQUFZLEdBQVksS0FBSyxDQUFDO1FBUTlCLFdBQU0sR0FBNkMsSUFBSSxZQUFZLEVBQThCLENBQUM7UUFHbEcsY0FBUyxHQUFxQixJQUFJLFlBQVksRUFBTSxDQUFDO1FBR3JELGdCQUFXLEdBQXFCLElBQUksWUFBWSxFQUFNLENBQUM7UUFHdkQsWUFBTyxHQUFxQixJQUFJLFlBQVksRUFBTSxDQUFDO1FBa0JuRCxZQUFPLEdBQWdDLEVBQUUsQ0FBQztJQWtDbkQsQ0FBQztJQTFGQyxJQUFnRCxPQUFPLENBQUMsZ0JBQXNEO1FBQzVHLElBQUksQ0FBQyxXQUFXLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBcUJELElBQ1csWUFBWSxDQUFDLEtBQWtDO1FBQ3hELElBQUksQ0FBQyxXQUFXLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDMUIsQ0FBQztJQWVNLGVBQWUsQ0FBQyxLQUFpQjtRQUN0QyxJQUFJLEtBQUssQ0FBQyxPQUFPLEtBQUssQ0FBQyxJQUFJLElBQUksQ0FBQyxnQkFBZ0IsRUFBRTtZQUNoRCxJQUFJLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEtBQUssRUFBRTtnQkFDaEMsTUFBTSxJQUFJLEdBQWdCLEtBQUssQ0FBQyxNQUFjLENBQUMsYUFBYSxDQUFDLHFCQUFxQixFQUFFLENBQUM7Z0JBQ3JGLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQzthQUMxQztZQUNELElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLElBQUksS0FBSyxDQUFDLFNBQVMsQ0FBQztTQUNoRDtJQUNILENBQUM7SUFHTSxhQUFhLENBQUMsS0FBaUI7UUFDcEMsSUFBSSxDQUFDLGdCQUFnQixHQUFHLFNBQVMsQ0FBQztJQUNwQyxDQUFDO0lBTU0sb0JBQW9CLENBQUMsS0FBaUIsRUFBRSxNQUFpQztRQUM5RSxJQUFJLENBQUMsZ0JBQWdCLEdBQUcsTUFBTSxDQUFDO0lBQ2pDLENBQUM7SUFFTSxpQkFBaUIsQ0FBQyxJQUFhLEVBQUUsSUFBaUI7UUFDdkQsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO0lBRU0sVUFBVSxDQUFDLEtBQTRCO1FBQzVDLElBQUk7WUFDRixNQUFNLElBQUksR0FBVyxLQUFLLENBQUMsYUFBYSxDQUFDO1lBQ3pDLE1BQU0sRUFBRSxHQUFXLEtBQUssQ0FBQyxZQUFZLENBQUM7WUFDdEMsSUFBSSxJQUFJLEtBQUssRUFBRSxFQUFFO2dCQUNmLE9BQU87YUFDUjtZQUNELElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtnQkFDckIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBQyxJQUFJLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxFQUFFLEVBQUMsQ0FBQyxDQUFDO2FBQ3hDO2lCQUFNO2dCQUNMLGVBQWUsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxFQUFFLENBQUMsQ0FBQzthQUN0QztTQUNGO1FBQUMsT0FBTyxDQUFDLEVBQUU7WUFDVixPQUFPLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1NBQ2xCO0lBQ0gsQ0FBQztJQUVPLFdBQVcsQ0FBQyxPQUFvQztRQUN0RCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxHQUFHLE9BQU8sQ0FBQyxDQUFDO1FBQzlCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDMUQsQ0FBQzs7O1lBMUZGLFNBQVM7OztzQkFFUCxlQUFlLFNBQUMseUJBQXlCO21CQUl6QyxLQUFLOzhCQUdMLEtBQUs7eUJBR0wsS0FBSzswQkFHTCxLQUFLOzJCQU9MLEtBQUs7MkJBR0wsS0FBSztxQkFLTCxNQUFNO3dCQUdOLE1BQU07MEJBR04sTUFBTTtzQkFHTixNQUFNOzhCQUdOLFlBQVksU0FBQyxvQkFBb0IsRUFBRSxDQUFDLFFBQVEsQ0FBQzs0QkFXN0MsWUFBWSxTQUFDLGtCQUFrQixFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb250ZW50Q2hpbGRyZW4sIERpcmVjdGl2ZSwgRXZlbnRFbWl0dGVyLCBIb3N0TGlzdGVuZXIsIElucHV0LCBPdXRwdXQsIFF1ZXJ5TGlzdCwgVmlld0NoaWxkcmVufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge1NpbXBsZUdyaWRDb2x1bW5EaXJlY3RpdmV9IGZyb20gXCIuL3NpbXBsZS1ncmlkLWNvbHVtbi5kaXJlY3RpdmVcIjtcclxuaW1wb3J0IHtDZGtEcmFnLCBDZGtEcmFnRHJvcCwgQ2RrRHJvcExpc3QsIG1vdmVJdGVtSW5BcnJheX0gZnJvbSBcIkBhbmd1bGFyL2Nkay9kcmFnLWRyb3BcIjtcclxuXHJcbkBEaXJlY3RpdmUoKVxyXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZVNpbXBsZUdyaWRDb21wb25lbnQge1xyXG4gIEBDb250ZW50Q2hpbGRyZW4oU2ltcGxlR3JpZENvbHVtbkRpcmVjdGl2ZSkgc2V0IGNvbnRlbnQoY29sdW1uQ29tcG9uZW50czogUXVlcnlMaXN0PFNpbXBsZUdyaWRDb2x1bW5EaXJlY3RpdmU+KSB7XHJcbiAgICB0aGlzLl9zZXRDb2x1bW5zKGNvbHVtbkNvbXBvbmVudHMudG9BcnJheSgpKTtcclxuICB9XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGRhdGE6IE9iamVjdFtdID0gW107XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGRyYWdEcm9wRW5hYmxlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBpbmxpbmVFZGl0OiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHNob3dUb29sYmFyOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIC8qKlxyXG4gICAqIFNob3VsZCBjb21wb25lbnQgZW1pdCBkcmFnIGFuZCBkcm9wIGFjdGlvbnMgaW5zdGVhZCBvZiBoYW5kbGVcclxuICAgKiAodXBkYXRlIGNvbGxlY3Rpb24pIGJ5IGl0c2VsZlxyXG4gICAqL1xyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGVtaXREcmFnRHJvcDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzZXQgZXh0cmFDb2x1bW5zKHZhbHVlOiBTaW1wbGVHcmlkQ29sdW1uRGlyZWN0aXZlW10pIHtcclxuICAgIHRoaXMuX3NldENvbHVtbnModmFsdWUpO1xyXG4gIH1cclxuXHJcbiAgQE91dHB1dCgpXHJcbiAgcHVibGljIG9uRHJvcDogRXZlbnRFbWl0dGVyPHtmcm9tOiBudW1iZXIsIHRvOiBudW1iZXJ9PiA9IG5ldyBFdmVudEVtaXR0ZXI8e2Zyb206IG51bWJlcjsgdG86IG51bWJlcn0+KCk7XHJcblxyXG4gIEBPdXRwdXQoKVxyXG4gIHB1YmxpYyBzZWxlY3RSb3c6IEV2ZW50RW1pdHRlcjx7fT4gPSBuZXcgRXZlbnRFbWl0dGVyPHt9PigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgZGJsQ2xpY2tSb3c6IEV2ZW50RW1pdHRlcjx7fT4gPSBuZXcgRXZlbnRFbWl0dGVyPHt9PigpO1xyXG5cclxuICBAT3V0cHV0KClcclxuICBwdWJsaWMgc2F2ZVJvdzogRXZlbnRFbWl0dGVyPHt9PiA9IG5ldyBFdmVudEVtaXR0ZXI8e30+KCk7XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50Om1vdXNlbW92ZScsIFsnJGV2ZW50J10pXHJcbiAgcHVibGljIGhhbmRsZU1vdXNlTW92ZShldmVudDogTW91c2VFdmVudCk6IHZvaWQge1xyXG4gICAgaWYgKGV2ZW50LmJ1dHRvbnMgPT09IDEgJiYgdGhpcy5fY29sdW1uRm9yUmVzaXplKSB7XHJcbiAgICAgIGlmICghdGhpcy5fY29sdW1uRm9yUmVzaXplLndpZHRoKSB7XHJcbiAgICAgICAgY29uc3QgcmVjdDogQ2xpZW50UmVjdCA9IChldmVudC50YXJnZXQgYXMgYW55KS5wYXJlbnRFbGVtZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xyXG4gICAgICAgIHRoaXMuX2NvbHVtbkZvclJlc2l6ZS53aWR0aCA9IHJlY3Qud2lkdGg7XHJcbiAgICAgIH1cclxuICAgICAgdGhpcy5fY29sdW1uRm9yUmVzaXplLndpZHRoICs9IGV2ZW50Lm1vdmVtZW50WDtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ2RvY3VtZW50Om1vdXNldXAnLCBbJyRldmVudCddKVxyXG4gIHB1YmxpYyBoYW5kbGVNb3VzZVVwKGV2ZW50OiBNb3VzZUV2ZW50KTogdm9pZCB7XHJcbiAgICB0aGlzLl9jb2x1bW5Gb3JSZXNpemUgPSB1bmRlZmluZWQ7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgY29sdW1uczogU2ltcGxlR3JpZENvbHVtbkRpcmVjdGl2ZVtdID0gW107XHJcblxyXG4gIHByaXZhdGUgX2NvbHVtbkZvclJlc2l6ZTogU2ltcGxlR3JpZENvbHVtbkRpcmVjdGl2ZTtcclxuXHJcbiAgcHVibGljIGhhbmRsZVNpemVyTW91c2VEb3duKGV2ZW50OiBNb3VzZUV2ZW50LCBjb2x1bW46IFNpbXBsZUdyaWRDb2x1bW5EaXJlY3RpdmUpOiB2b2lkIHtcclxuICAgIHRoaXMuX2NvbHVtbkZvclJlc2l6ZSA9IGNvbHVtbjtcclxuICB9XHJcblxyXG4gIHB1YmxpYyBoYW5kbGVDYW5EcmFnRHJvcChkcmFnOiBDZGtEcmFnLCBkcm9wOiBDZGtEcm9wTGlzdCk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIHRydWU7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgaGFuZGxlRHJvcChldmVudDogQ2RrRHJhZ0Ryb3A8T2JqZWN0W10+KTogdm9pZCB7XHJcbiAgICB0cnkge1xyXG4gICAgICBjb25zdCBmcm9tOiBudW1iZXIgPSBldmVudC5wcmV2aW91c0luZGV4O1xyXG4gICAgICBjb25zdCB0bzogbnVtYmVyID0gZXZlbnQuY3VycmVudEluZGV4O1xyXG4gICAgICBpZiAoZnJvbSA9PT0gdG8pIHtcclxuICAgICAgICByZXR1cm47XHJcbiAgICAgIH1cclxuICAgICAgaWYgKHRoaXMuZW1pdERyYWdEcm9wKSB7XHJcbiAgICAgICAgdGhpcy5vbkRyb3AubmV4dCh7ZnJvbTogZnJvbSwgdG86IHRvfSk7XHJcbiAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgbW92ZUl0ZW1JbkFycmF5KHRoaXMuZGF0YSwgZnJvbSwgdG8pO1xyXG4gICAgICB9XHJcbiAgICB9IGNhdGNoIChlKSB7XHJcbiAgICAgIGNvbnNvbGUuZXJyb3IoZSk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIF9zZXRDb2x1bW5zKGNvbHVtbnM6IFNpbXBsZUdyaWRDb2x1bW5EaXJlY3RpdmVbXSk6IHZvaWQge1xyXG4gICAgdGhpcy5jb2x1bW5zLnB1c2goLi4uY29sdW1ucyk7XHJcbiAgICB0aGlzLmNvbHVtbnMuc29ydCgoYSwgYikgPT4gYS5vcmRlciA8IGIub3JkZXIgPyAtMSA6IDEpO1xyXG4gIH1cclxuXHJcbn1cclxuIl19
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-simple-grid.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/simple-grid/base-simple-grid.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ContentChildren, Directive, EventEmitter, HostListener, Input, Output, QueryList, ViewChildren} from \"@angular/core\";\r\nimport {SimpleGridColumnDirective} from \"./simple-grid-column.directive\";\r\nimport {CdkDrag, CdkDragDrop, CdkDropList, moveItemInArray} from \"@angular/cdk/drag-drop\";\r\n\r\n@Directive()\r\nexport abstract class BaseSimpleGridComponent {\r\n  private readonly MIN_COLUMN_WIDTH: number = 60;\r\n\r\n  @ContentChildren(SimpleGridColumnDirective) set content(columnComponents: QueryList<SimpleGridColumnDirective>) {\r\n    this._setColumns(columnComponents.toArray());\r\n    this._prepareData();\r\n  }\r\n\r\n  @Input()\r\n  public set data(value: Object[]) {\r\n    this._data = value;\r\n    this._prepareData();\r\n  }\r\n\r\n  public get data(): Object[] {\r\n    return this._data;\r\n  }\r\n\r\n  @Input()\r\n  public dragDropEnabled: boolean = false;\r\n\r\n  @Input()\r\n  public resizable: boolean = false;\r\n\r\n  @Input()\r\n  public inlineEdit: boolean = false;\r\n\r\n  @Input()\r\n  public showToolbar: boolean = false;\r\n\r\n  /**\r\n   * Should component emit drag and drop actions instead of handle\r\n   * (update collection) by itself\r\n   */\r\n  @Input()\r\n  public emitDragDrop: boolean = false;\r\n\r\n  @Input()\r\n  public set extraColumns(value: SimpleGridColumnDirective[]) {\r\n    this._setColumns(value);\r\n  }\r\n\r\n  @Output()\r\n  public onDrop: EventEmitter<{from: number, to: number}> = new EventEmitter<{from: number; to: number}>();\r\n\r\n  @Output()\r\n  public selectRow: EventEmitter<{}> = new EventEmitter<{}>();\r\n\r\n  @Output()\r\n  public dblClickRow: EventEmitter<{}> = new EventEmitter<{}>();\r\n\r\n  @Output()\r\n  public saveRow: EventEmitter<{}> = new EventEmitter<{}>();\r\n\r\n  @HostListener('document:mousemove', ['$event'])\r\n  public handleMouseMove(event: MouseEvent): void {\r\n    if (this.resizable && event.buttons === 1 && this._columnForResize) {\r\n      this._columnForResize.width = this._columnForResize.originalWidth - (this._startMousePositionX - event.clientX);\r\n    }\r\n  }\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  public handleMouseUp(event: MouseEvent): void {\r\n    this._startMousePositionX = undefined;\r\n    this._columnForResize = undefined;\r\n  }\r\n\r\n  public columns: SimpleGridColumnDirective[] = [];\r\n  public headerColumns: SimpleGridColumnDirective[] = [];\r\n\r\n  protected _data: Object[] = [];\r\n\r\n  private _columnForResize: SimpleGridColumnDirective;\r\n  private _prepared: boolean = false;\r\n  private _startMousePositionX: number;\r\n\r\n  public handleSizerMouseDown(event: MouseEvent, column: SimpleGridColumnDirective): void {\r\n    this._setWidthOfAllColumns();\r\n    this._startMousePositionX = event.clientX;\r\n    this._columnForResize = column;\r\n    this._columnForResize.originalWidth = this._columnForResize.width;\r\n  }\r\n\r\n  public handleCanDragDrop(drag: CdkDrag, drop: CdkDropList): boolean {\r\n    return true;\r\n  }\r\n\r\n  public handleDrop(event: CdkDragDrop<Object[]>): void {\r\n    try {\r\n      const from: number = event.previousIndex;\r\n      const to: number = event.currentIndex;\r\n      if (from === to) {\r\n        return;\r\n      }\r\n      if (this.emitDragDrop) {\r\n        this.onDrop.next({from: from, to: to});\r\n      } else {\r\n        moveItemInArray(this.data, from, to);\r\n      }\r\n    } catch (e) {\r\n      console.error(e);\r\n    }\r\n  }\r\n\r\n  public isSingleColumnRow(row: Object): boolean {\r\n    return row.hasOwnProperty('singleColumnIndex');\r\n  }\r\n\r\n  public singleColumnIndex(row: Object): number {\r\n    return (row as any).singleColumnIndex;\r\n  }\r\n\r\n  private _setColumns(columns: SimpleGridColumnDirective[]): void {\r\n    this.columns.push(...columns);\r\n    this.columns.sort((a, b) => a.order < b.order ? -1 : 1);\r\n  }\r\n\r\n  private _prepareData(): void {\r\n    if (this._prepared) {\r\n      return;\r\n    }\r\n    if (this.columns && this.columns.length > 0 && this.data && this.data.length > 0) {\r\n      this.headerColumns = this.columns.filter(c => !c.singleColumn);\r\n      let singleColumnIndex: number = -1;\r\n      for (let i = 0; i < this.columns.length; i++) {\r\n        if (this.columns[i].singleColumn) {\r\n          singleColumnIndex = i;\r\n          break;\r\n        }\r\n      }\r\n      // first check if there's single column data\r\n      if (singleColumnIndex > -1) {\r\n        const field: string = this.columns[singleColumnIndex].field;\r\n        for (let i = 0; i < this.data.length; i++) { // then mark row as single column row\r\n          if (this.data[i][field] !== undefined && this.data[i][field] !== null && this.data[i][field] !== \"\") {\r\n            // bit nasty to add prop, but cool for now\r\n            (this.data[i] as any).singleColumnIndex = singleColumnIndex;\r\n          }\r\n        }\r\n      }\r\n      this._prepared = true;\r\n    }\r\n  }\r\n\r\n  private _setWidthOfAllColumns(): void {\r\n    this.columns.forEach((column: SimpleGridColumnDirective) => {\r\n      if ((column.width === undefined || column.width === null) && column.elementRef && column.elementRef.nativeElement) {\r\n        const rect: ClientRect = column.elementRef.nativeElement.getBoundingClientRect();\r\n        column.width = rect.width;\r\n      }\r\n    });\r\n  }\r\n\r\n}\r\n"]}
@@ -1,4 +1,4 @@
1
- import { ContentChild, Directive, Input } from "@angular/core";
1
+ import { ContentChild, Directive, ElementRef, Input } from '@angular/core';
2
2
  export var ColumnAlign;
3
3
  (function (ColumnAlign) {
4
4
  ColumnAlign["Left"] = "left-align";
@@ -6,7 +6,8 @@ export var ColumnAlign;
6
6
  ColumnAlign["Right"] = "right-align";
7
7
  })(ColumnAlign || (ColumnAlign = {}));
8
8
  export class SimpleGridColumnDirective {
9
- constructor() {
9
+ constructor(elementRef) {
10
+ this.elementRef = elementRef;
10
11
  this.resizable = true;
11
12
  this.required = false;
12
13
  this.readonly = false;
@@ -55,6 +56,9 @@ SimpleGridColumnDirective.decorators = [
55
56
  selector: "co-simple-grid-column"
56
57
  },] }
57
58
  ];
59
+ SimpleGridColumnDirective.ctorParameters = () => [
60
+ { type: ElementRef }
61
+ ];
58
62
  SimpleGridColumnDirective.propDecorators = {
59
63
  template: [{ type: ContentChild, args: ['template',] }],
60
64
  editTemplate: [{ type: ContentChild, args: ['editTemplate',] }],
@@ -72,4 +76,4 @@ SimpleGridColumnDirective.propDecorators = {
72
76
  order: [{ type: Input }],
73
77
  singleColumn: [{ type: Input }]
74
78
  };
75
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2ltcGxlLWdyaWQtY29sdW1uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9zaW1wbGUtZ3JpZC9zaW1wbGUtZ3JpZC1jb2x1bW4uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFFcEYsTUFBTSxDQUFOLElBQVksV0FJWDtBQUpELFdBQVksV0FBVztJQUNyQixrQ0FBbUIsQ0FBQTtJQUNuQixzQ0FBdUIsQ0FBQTtJQUN2QixvQ0FBcUIsQ0FBQTtBQUN2QixDQUFDLEVBSlcsV0FBVyxLQUFYLFdBQVcsUUFJdEI7QUFLRCxNQUFNLE9BQU8seUJBQXlCO0lBSHRDO1FBK0NTLGNBQVMsR0FBWSxJQUFJLENBQUM7UUFHMUIsYUFBUSxHQUFZLEtBQUssQ0FBQztRQU0xQixhQUFRLEdBQVksS0FBSyxDQUFDO1FBTTFCLFVBQUssR0FBVyxDQUFDLENBQUM7UUFHbEIsaUJBQVksR0FBWSxLQUFLLENBQUM7SUEwQnZDLENBQUM7SUFyRkMsSUFDVyxRQUFRLENBQUMsUUFBMEI7UUFDNUMsSUFBSSxRQUFRLEVBQUU7WUFDWixJQUFJLENBQUMsU0FBUyxHQUFHLFFBQVEsQ0FBQztTQUMzQjtJQUNILENBQUM7SUFFRCxJQUFXLFFBQVE7UUFDakIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQ3hCLENBQUM7SUFFRCxJQUNXLFlBQVksQ0FBQyxRQUEwQjtRQUNoRCxJQUFJLFFBQVEsRUFBRTtZQUNaLElBQUksQ0FBQyxhQUFhLEdBQUcsUUFBUSxDQUFDO1NBQy9CO0lBQ0gsQ0FBQztJQUVELElBQVcsWUFBWTtRQUNyQixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUM7SUFDNUIsQ0FBQztJQXlDRCxRQUFRO1FBQ04sSUFBSSxDQUFDLHFCQUFxQixFQUFFLENBQUE7SUFDOUIsQ0FBQztJQUVNLGFBQWEsQ0FBQyxLQUFVO1FBQzdCLElBQUksSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFFO1lBQ3hDLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxLQUFLLENBQUMsQ0FBQztZQUN0RSxJQUFJLE1BQU0sRUFBRTtnQkFDVixPQUFPLE1BQU0sQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUM7YUFDbEM7U0FDRjtRQUNELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUtPLHFCQUFxQjtRQUMzQixJQUFJLElBQUksQ0FBQyxZQUFZLEVBQUM7WUFDcEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7WUFDdkIsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUM7WUFDckIsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7U0FDaEI7SUFDSCxDQUFDOztBQXRGYyxpREFBdUIsR0FBVyxFQUFFLENBQUM7O1lBSnJELFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsdUJBQXVCO2FBQ2xDOzs7dUJBSUUsWUFBWSxTQUFDLFVBQVU7MkJBV3ZCLFlBQVksU0FBQyxjQUFjO3lCQVczQixLQUFLO29CQUdMLEtBQUs7d0JBR0wsS0FBSzsyQkFHTCxLQUFLO3dCQUdMLEtBQUs7cUJBR0wsS0FBSzt3QkFHTCxLQUFLO3VCQUdMLEtBQUs7b0JBR0wsS0FBSzt1QkFHTCxLQUFLO3lCQUdMLEtBQUs7b0JBR0wsS0FBSzsyQkFHTCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29udGVudENoaWxkLCBEaXJlY3RpdmUsIElucHV0LCBPbkluaXQsIFRlbXBsYXRlUmVmIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuXHJcbmV4cG9ydCBlbnVtIENvbHVtbkFsaWduIHtcclxuICBMZWZ0ID0gXCJsZWZ0LWFsaWduXCIsXHJcbiAgQ2VudGVyID0gXCJjZW50ZXItYWxpZ25cIixcclxuICBSaWdodCA9IFwicmlnaHQtYWxpZ25cIlxyXG59XHJcblxyXG5ARGlyZWN0aXZlKHtcclxuICBzZWxlY3RvcjogXCJjby1zaW1wbGUtZ3JpZC1jb2x1bW5cIlxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2ltcGxlR3JpZENvbHVtbkRpcmVjdGl2ZSBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgcHJpdmF0ZSBzdGF0aWMgX01pbk1hbnVhbFJlc2l6ZVdpZHRoUHg6IG51bWJlciA9IDUwO1xyXG5cclxuICBAQ29udGVudENoaWxkKCd0ZW1wbGF0ZScpXHJcbiAgcHVibGljIHNldCB0ZW1wbGF0ZSh0ZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55Pikge1xyXG4gICAgaWYgKHRlbXBsYXRlKSB7XHJcbiAgICAgIHRoaXMuX3RlbXBsYXRlID0gdGVtcGxhdGU7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IHRlbXBsYXRlKCk6IFRlbXBsYXRlUmVmPGFueT4ge1xyXG4gICAgcmV0dXJuIHRoaXMuX3RlbXBsYXRlO1xyXG4gIH1cclxuXHJcbiAgQENvbnRlbnRDaGlsZCgnZWRpdFRlbXBsYXRlJylcclxuICBwdWJsaWMgc2V0IGVkaXRUZW1wbGF0ZSh0ZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55Pikge1xyXG4gICAgaWYgKHRlbXBsYXRlKSB7XHJcbiAgICAgIHRoaXMuX2VkaXRUZW1wbGF0ZSA9IHRlbXBsYXRlO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgcHVibGljIGdldCBlZGl0VGVtcGxhdGUoKTogVGVtcGxhdGVSZWY8YW55PiB7XHJcbiAgICByZXR1cm4gdGhpcy5fZWRpdFRlbXBsYXRlO1xyXG4gIH1cclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgaGVhZGVyVGV4dDogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBmaWVsZDogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjb2RlRmllbGQ6IHN0cmluZztcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZGlzcGxheUZpZWxkOiBzdHJpbmc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHRleHRBbGlnbjogQ29sdW1uQWxpZ247XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGZvcm1hdDogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyByZXNpemFibGU6IGJvb2xlYW4gPSB0cnVlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyByZXF1aXJlZDogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyB3aWR0aDogbnVtYmVyO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyByZWFkb25seTogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBjb2xsZWN0aW9uOiB7fVtdO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBvcmRlcjogbnVtYmVyID0gMDtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgc2luZ2xlQ29sdW1uOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIG5nT25Jbml0KCk6dm9pZCB7XHJcbiAgICB0aGlzLl9zZXRTaW5nbGVDb2x1bW5Qcm9wcygpXHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0RmllbGRWYWx1ZSh2YWx1ZTogYW55KTogc3RyaW5nIHtcclxuICAgIGlmICh0aGlzLmNvbGxlY3Rpb24gJiYgdGhpcy5kaXNwbGF5RmllbGQpIHtcclxuICAgICAgY29uc3QgcmVzdWx0ID0gdGhpcy5jb2xsZWN0aW9uLmZpbmQoYyA9PiBjW3RoaXMuY29kZUZpZWxkXSA9PT0gdmFsdWUpO1xyXG4gICAgICBpZiAocmVzdWx0KSB7XHJcbiAgICAgICAgcmV0dXJuIHJlc3VsdFt0aGlzLmRpc3BsYXlGaWVsZF07XHJcbiAgICAgIH1cclxuICAgIH1cclxuICAgIHJldHVybiB2YWx1ZTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgX3RlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG4gIHByaXZhdGUgX2VkaXRUZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcbiAgcHJpdmF0ZSBfc2V0U2luZ2xlQ29sdW1uUHJvcHMoKXtcclxuICAgIGlmICh0aGlzLnNpbmdsZUNvbHVtbil7XHJcbiAgICAgIHRoaXMucmVzaXphYmxlID0gZmFsc2U7XHJcbiAgICAgIHRoaXMucmVhZG9ubHkgPSB0cnVlO1xyXG4gICAgICB0aGlzLndpZHRoID0gMDtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
79
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2ltcGxlLWdyaWQtY29sdW1uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmVjb21wb25lbnRzL3NyYy9saWIvY29tcG9uZW50cy9zaW1wbGUtZ3JpZC9zaW1wbGUtZ3JpZC1jb2x1bW4uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxZQUFZLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQXNCLE1BQU0sZUFBZSxDQUFDO0FBRTlGLE1BQU0sQ0FBTixJQUFZLFdBSVg7QUFKRCxXQUFZLFdBQVc7SUFDckIsa0NBQW1CLENBQUE7SUFDbkIsc0NBQXVCLENBQUE7SUFDdkIsb0NBQXFCLENBQUE7QUFDdkIsQ0FBQyxFQUpXLFdBQVcsS0FBWCxXQUFXLFFBSXRCO0FBS0QsTUFBTSxPQUFPLHlCQUF5QjtJQWtFcEMsWUFBbUIsVUFBc0I7UUFBdEIsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQXRCbEMsY0FBUyxHQUFZLElBQUksQ0FBQztRQUcxQixhQUFRLEdBQVksS0FBSyxDQUFDO1FBTTFCLGFBQVEsR0FBWSxLQUFLLENBQUM7UUFNMUIsVUFBSyxHQUFXLENBQUMsQ0FBQztRQUdsQixpQkFBWSxHQUFZLEtBQUssQ0FBQztJQUtyQyxDQUFDO0lBaEVELElBQ1csUUFBUSxDQUFDLFFBQTBCO1FBQzVDLElBQUksUUFBUSxFQUFFO1lBQ1osSUFBSSxDQUFDLFNBQVMsR0FBRyxRQUFRLENBQUM7U0FDM0I7SUFDSCxDQUFDO0lBRUQsSUFBVyxRQUFRO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBRUQsSUFDVyxZQUFZLENBQUMsUUFBMEI7UUFDaEQsSUFBSSxRQUFRLEVBQUU7WUFDWixJQUFJLENBQUMsYUFBYSxHQUFHLFFBQVEsQ0FBQztTQUMvQjtJQUNILENBQUM7SUFFRCxJQUFXLFlBQVk7UUFDckIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDO0lBQzVCLENBQUM7SUE4Q0QsUUFBUTtRQUNOLElBQUksQ0FBQyxxQkFBcUIsRUFBRSxDQUFBO0lBQzlCLENBQUM7SUFFTSxhQUFhLENBQUMsS0FBVTtRQUM3QixJQUFJLElBQUksQ0FBQyxVQUFVLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRTtZQUN4QyxNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEtBQUssS0FBSyxDQUFDLENBQUM7WUFDdEUsSUFBSSxNQUFNLEVBQUU7Z0JBQ1YsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO2FBQ2xDO1NBQ0Y7UUFDRCxPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7SUFLTyxxQkFBcUI7UUFDM0IsSUFBSSxJQUFJLENBQUMsWUFBWSxFQUFDO1lBQ3BCLElBQUksQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxRQUFRLEdBQUcsSUFBSSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxLQUFLLEdBQUcsQ0FBQyxDQUFDO1NBQ2hCO0lBQ0gsQ0FBQzs7QUEzRmMsaURBQXVCLEdBQVcsRUFBRSxDQUFDOztZQUpyRCxTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLHVCQUF1QjthQUNsQzs7O1lBVmdDLFVBQVU7Ozt1QkFjeEMsWUFBWSxTQUFDLFVBQVU7MkJBV3ZCLFlBQVksU0FBQyxjQUFjO3lCQVczQixLQUFLO29CQUdMLEtBQUs7d0JBR0wsS0FBSzsyQkFHTCxLQUFLO3dCQUdMLEtBQUs7cUJBR0wsS0FBSzt3QkFHTCxLQUFLO3VCQUdMLEtBQUs7b0JBR0wsS0FBSzt1QkFHTCxLQUFLO3lCQUdMLEtBQUs7b0JBR0wsS0FBSzsyQkFHTCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb250ZW50Q2hpbGQsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSW5wdXQsIE9uSW5pdCwgVGVtcGxhdGVSZWZ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5cclxuZXhwb3J0IGVudW0gQ29sdW1uQWxpZ24ge1xyXG4gIExlZnQgPSBcImxlZnQtYWxpZ25cIixcclxuICBDZW50ZXIgPSBcImNlbnRlci1hbGlnblwiLFxyXG4gIFJpZ2h0ID0gXCJyaWdodC1hbGlnblwiXHJcbn1cclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiBcImNvLXNpbXBsZS1ncmlkLWNvbHVtblwiXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTaW1wbGVHcmlkQ29sdW1uRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0IHtcclxuICBwcml2YXRlIHN0YXRpYyBfTWluTWFudWFsUmVzaXplV2lkdGhQeDogbnVtYmVyID0gNTA7XHJcblxyXG4gIEBDb250ZW50Q2hpbGQoJ3RlbXBsYXRlJylcclxuICBwdWJsaWMgc2V0IHRlbXBsYXRlKHRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+KSB7XHJcbiAgICBpZiAodGVtcGxhdGUpIHtcclxuICAgICAgdGhpcy5fdGVtcGxhdGUgPSB0ZW1wbGF0ZTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHB1YmxpYyBnZXQgdGVtcGxhdGUoKTogVGVtcGxhdGVSZWY8YW55PiB7XHJcbiAgICByZXR1cm4gdGhpcy5fdGVtcGxhdGU7XHJcbiAgfVxyXG5cclxuICBAQ29udGVudENoaWxkKCdlZGl0VGVtcGxhdGUnKVxyXG4gIHB1YmxpYyBzZXQgZWRpdFRlbXBsYXRlKHRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+KSB7XHJcbiAgICBpZiAodGVtcGxhdGUpIHtcclxuICAgICAgdGhpcy5fZWRpdFRlbXBsYXRlID0gdGVtcGxhdGU7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0IGVkaXRUZW1wbGF0ZSgpOiBUZW1wbGF0ZVJlZjxhbnk+IHtcclxuICAgIHJldHVybiB0aGlzLl9lZGl0VGVtcGxhdGU7XHJcbiAgfVxyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBoZWFkZXJUZXh0OiBzdHJpbmc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGZpZWxkOiBzdHJpbmc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGNvZGVGaWVsZDogc3RyaW5nO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBkaXNwbGF5RmllbGQ6IHN0cmluZztcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgdGV4dEFsaWduOiBDb2x1bW5BbGlnbjtcclxuXHJcbiAgQElucHV0KClcclxuICBwdWJsaWMgZm9ybWF0OiBzdHJpbmc7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHJlc2l6YWJsZTogYm9vbGVhbiA9IHRydWU7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHJlcXVpcmVkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHdpZHRoOiBudW1iZXI7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIHJlYWRvbmx5OiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIGNvbGxlY3Rpb246IHt9W107XHJcblxyXG4gIEBJbnB1dCgpXHJcbiAgcHVibGljIG9yZGVyOiBudW1iZXIgPSAwO1xyXG5cclxuICBASW5wdXQoKVxyXG4gIHB1YmxpYyBzaW5nbGVDb2x1bW46IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgcHVibGljIG9yaWdpbmFsV2lkdGg6IG51bWJlcjtcclxuXHJcbiAgY29uc3RydWN0b3IocHVibGljIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYpIHtcclxuICB9XHJcblxyXG4gIG5nT25Jbml0KCk6dm9pZCB7XHJcbiAgICB0aGlzLl9zZXRTaW5nbGVDb2x1bW5Qcm9wcygpXHJcbiAgfVxyXG5cclxuICBwdWJsaWMgZ2V0RmllbGRWYWx1ZSh2YWx1ZTogYW55KTogc3RyaW5nIHtcclxuICAgIGlmICh0aGlzLmNvbGxlY3Rpb24gJiYgdGhpcy5kaXNwbGF5RmllbGQpIHtcclxuICAgICAgY29uc3QgcmVzdWx0ID0gdGhpcy5jb2xsZWN0aW9uLmZpbmQoYyA9PiBjW3RoaXMuY29kZUZpZWxkXSA9PT0gdmFsdWUpO1xyXG4gICAgICBpZiAocmVzdWx0KSB7XHJcbiAgICAgICAgcmV0dXJuIHJlc3VsdFt0aGlzLmRpc3BsYXlGaWVsZF07XHJcbiAgICAgIH1cclxuICAgIH1cclxuICAgIHJldHVybiB2YWx1ZTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgX3RlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+O1xyXG4gIHByaXZhdGUgX2VkaXRUZW1wbGF0ZTogVGVtcGxhdGVSZWY8YW55PjtcclxuXHJcbiAgcHJpdmF0ZSBfc2V0U2luZ2xlQ29sdW1uUHJvcHMoKXtcclxuICAgIGlmICh0aGlzLnNpbmdsZUNvbHVtbil7XHJcbiAgICAgIHRoaXMucmVzaXphYmxlID0gZmFsc2U7XHJcbiAgICAgIHRoaXMucmVhZG9ubHkgPSB0cnVlO1xyXG4gICAgICB0aGlzLndpZHRoID0gMDtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
@@ -1,4 +1,4 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, HostListener, ViewEncapsulation } from "@angular/core";
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, HostListener, ViewChildren, ViewEncapsulation } from '@angular/core';
2
2
  import { FormMasterService } from "../../core/service/form-master.service";
3
3
  import { BaseSimpleGridComponent } from "./base-simple-grid.component";
4
4
  import { ColumnAlign } from "./simple-grid-column.directive";
@@ -15,6 +15,12 @@ export class SimpleGridComponent extends BaseSimpleGridComponent {
15
15
  this._doubleClicked = false;
16
16
  this._newRow = false;
17
17
  }
18
+ set headerCells(cells) {
19
+ const headerElements = cells.toArray();
20
+ for (let i = 0; i < headerElements.length; i++) {
21
+ this.columns[i].elementRef = headerElements[i];
22
+ }
23
+ }
18
24
  showClass() {
19
25
  return true;
20
26
  }
@@ -252,45 +258,61 @@ SimpleGridComponent.decorators = [
252
258
  (saveClick)="validateAndSave()"
253
259
  (cancelClick)="cancelEditRow()"
254
260
  ></co-grid-toolbar>
255
- <div class="simple-grid-column-header-wrapper">
256
- <div class="simple-grid-column-header" *ngFor="let column of columns; let index = index"
257
- [style.min-width.px]="column.width" [style.max-width.px]="column.width" [style.padding-right.px]="isSingleColumn(column) ? 0 : 5">
258
- <div class="simple-grid-column-header-label" [ngClass]="column.textAlign ? column.textAlign : defaultTextAlign"
259
- [textContent]="column.headerText"
260
- ></div>
261
- <div *ngIf="column.resizable" class="simple-grid-column-sizer"
262
- (mousedown)="handleSizerMouseDown($event, column)"
263
- ></div>
264
- </div>
265
- </div>
266
- <div cdkDropListGroup class="drop-list-group">
267
- <div #dropList cdkDropList cdkDropListOrientation="vertical"
268
- class="simple-grid-drag-drop-list"
269
- [cdkDropListDisabled]="!dragDropEnabled"
270
- [cdkDropListData]="data"
271
- [cdkDropListEnterPredicate]="handleCanDragDrop"
272
- (cdkDropListDropped)="handleDrop($event)"
273
- >
274
- <div class="simple-grid-row" [class.selected]="rowIndex === selectedRowIndex"
275
- [class.editting]="rowIndex === editRowIndex" *ngFor="let row of data; let rowIndex = index" cdkDrag
276
- (click)="handleClickRow($event, rowIndex)" (dblclick)="handleDblClickRow($event, rowIndex)">
261
+ <table class="simple-grid-table">
262
+ <colgroup>
263
+ <col *ngFor="let column of headerColumns; let index = index" [attr.width]="column.width">
264
+ </colgroup>
265
+ <thead>
266
+ <tr>
267
+ <th scope="col" #headerCell class="simple-grid-column-header" *ngFor="let column of headerColumns; let index = index">
268
+ <div class="simple-grid-column-header-wrapper" [class.resizable]="resizable">
269
+ <div class="simple-grid-column-header-label" [ngClass]="column.textAlign ? column.textAlign : defaultTextAlign"
270
+ [textContent]="column.headerText"
271
+ ></div>
272
+ <div *ngIf="resizable && column.resizable" class="simple-grid-column-sizer"
273
+ (mousedown)="handleSizerMouseDown($event, column)"
274
+ ></div>
275
+ </div>
276
+ </th>
277
+ </tr>
278
+ </thead>
279
+ <tbody #dropList cdkDropList cdkDropListOrientation="vertical"
280
+ class="simple-grid-drag-drop-list"
281
+ [cdkDropListDisabled]="!dragDropEnabled"
282
+ [cdkDropListData]="data"
283
+ [cdkDropListEnterPredicate]="handleCanDragDrop"
284
+ (cdkDropListDropped)="handleDrop($event)">
285
+ <tr class="simple-grid-row" [class.selected]="rowIndex === selectedRowIndex"
286
+ [class.editting]="rowIndex === editRowIndex" *ngFor="let row of data; let rowIndex = index" cdkDrag
287
+ (click)="handleClickRow($event, rowIndex)" (dblclick)="handleDblClickRow($event, rowIndex)">
277
288
  <co-form class="simple-grid-row-form">
278
- <div class="simple-grid-column-cell" *ngFor="let column of columns; let columnIndex = index"
279
- [style.min-width]="isSingleColumn(column) ? 'fit-content' : column.width" [style.max-width.px]="column.width"
280
- [style.padding-right.px]="isSingleColumn(column) ? 0 : 5" >
289
+ <ng-container *ngIf="isSingleColumnRow(row)">
290
+ <td class="simple-grid-single-column-cell" [attr.colspan]="headerColumns.length">
281
291
  <co-simple-grid-cell
282
- [column]="column"
292
+ [column]="columns[singleColumnIndex(row)]"
283
293
  [row]="row"
284
- [editMode]="inlineEdit && editting && rowIndex === editRowIndex && !isSingleColumn(column) && !rowContainsSingleColumn(row, columns)"
285
- [fieldEditMode]="editCellIndex === columnIndex"
286
- (cellClick)="handleCellClick(columnIndex)"
294
+ [editMode]="false"
287
295
  ></co-simple-grid-cell>
288
- <div *ngIf="column.resizable" class="simple-grid-column-sizer-placeholder"></div>
289
- </div>
296
+ </td>
297
+ </ng-container>
298
+ <ng-container *ngIf="!isSingleColumnRow(row)">
299
+ <ng-container *ngFor="let column of headerColumns; let columnIndex = index">
300
+ <td class="simple-grid-column-cell" *ngIf="columnIndex !== singleColumnIndex(row)">
301
+ <co-simple-grid-cell
302
+ [column]="column"
303
+ [row]="row"
304
+ [editMode]="inlineEdit && editting && rowIndex === editRowIndex"
305
+ [fieldEditMode]="editCellIndex === columnIndex"
306
+ (cellClick)="handleCellClick(columnIndex)"
307
+ ></co-simple-grid-cell>
308
+ <div *ngIf="column.resizable" class="simple-grid-column-sizer-placeholder"></div>
309
+ </td>
310
+ </ng-container>
311
+ </ng-container>
290
312
  </co-form>
291
- </div>
292
- </div>
293
- </div>
313
+ </tr>
314
+ </tbody>
315
+ </table>
294
316
  `,
295
317
  providers: [
296
318
  FormMasterService
@@ -304,7 +326,8 @@ SimpleGridComponent.ctorParameters = () => [
304
326
  { type: FormMasterService }
305
327
  ];
306
328
  SimpleGridComponent.propDecorators = {
329
+ headerCells: [{ type: ViewChildren, args: ["headerCell",] }],
307
330
  showClass: [{ type: HostBinding, args: ["class.co-simple-grid",] }],
308
331
  handleKeyDown: [{ type: HostListener, args: ['keydown', ['$event'],] }]
309
332
  };
310
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-grid.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/simple-grid/simple-grid.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,WAAW,EACX,YAAY,EACZ,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,wCAAwC,CAAC;AAC3E,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAyD7D,MAAM,OAAO,mBAAoB,SAAQ,uBAAuB;IAuC9D,YACU,gBAAmC,EACnC,WAA8B;QAEtC,KAAK,EAAE,CAAC;QAHA,qBAAgB,GAAhB,gBAAgB,CAAmB;QACnC,gBAAW,GAAX,WAAW,CAAmB;QAxCxB,qBAAgB,GAAgB,WAAW,CAAC,IAAI,CAAC;QA6B1D,aAAQ,GAAY,KAAK,CAAC;QAC1B,iBAAY,GAAW,CAAC,CAAC,CAAC;QAC1B,kBAAa,GAAW,CAAC,CAAC,CAAC;QAC3B,qBAAgB,GAAW,CAAC,CAAC,CAAC;QAG7B,mBAAc,GAAY,KAAK,CAAC;QAChC,YAAO,GAAY,KAAK,CAAC;IAOjC,CAAC;IAxCM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAGM,aAAa,CAAC,KAAoB;QACvC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACpB,OAAO;SACR;QACD,IAAI,KAAK,CAAC,IAAI,KAAK,KAAK,EAAE;YACxB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,CAAC,wBAAwB,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,CAAC;iBAC/D,IAAI,CAAC,CAAC,KAAa,EAAE,EAAE;gBACtB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;gBAC3B,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,CAAC;YACvC,CAAC,CAAC,CAAA;YACJ,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;QACD,IAAI,KAAK,CAAC,IAAI,KAAK,QAAQ,EAAE;YAC3B,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;QACD,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;YAC1B,IAAI,CAAC,eAAe,EAAE,CAAC;SACxB;IACH,CAAC;IAkBM,cAAc,CAAC,MAAM;QAC1B,OAAO,MAAM,CAAC,YAAY,CAAC;IAC7B,CAAC;IAEM,uBAAuB,CAAC,GAAG,EAAE,OAAO;QACzC,MAAM,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;QAC/F,OAAO,CAAC,CAAC,YAAY,CAAC;IACxB,CAAC;IAEM,MAAM;QACX,MAAM,KAAK,GAAY,IAAI,CAAC,eAAe,EAAE,CAAC;QAC9C,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YACtB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;YACtB,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,KAAa,EAAE,EAAE;gBACzD,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAC7B,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;YACrB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAC9B,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IAEM,eAAe,CAAC,eAAwB,IAAI;QACjD,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,OAAO,IAAI,CAAC;SACb;QACD,MAAM,KAAK,GAAY,IAAI,CAAC,WAAW,CAAC,YAAY,EAAE,CAAC;QACvD,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,KAAK,EAAE;YACT,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;YAC5B,OAAO,IAAI,CAAC;SACb;IACH,CAAC;IAEM,aAAa;QAClB,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,OAAO;SACR;QACD,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;SACnB;aAAM;YACL,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC;SAC/C;QACD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,cAAc,CAAC,KAAiB,EAAE,KAAa;QACpD,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,IAAI,CAAC,cAAc,EAAE;gBACvB,OAAO;aACR;YACD,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAC3B,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAEM,YAAY,CAAC,KAAa,EAAE,OAAgB,IAAI;QACrD,IAAI,IAAI,CAAC,gBAAgB,KAAK,KAAK,IAAI,CAAC,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE;YACpG,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;YAC9B,IAAI,IAAI,EAAE;gBACR,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC;aACvD;SACF;QACD,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,iBAAiB,CAAC,KAAiB,EAAE,KAAa;QACvD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QACxC,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAChC,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;SACrB;QACD,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,OAAO,CAAC,KAAiB;QAC9B,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC;QAC1C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC9C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC,KAAa,EAAE,EAAE;YACzD,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC7B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEM,eAAe,CAAC,KAAa;QAClC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEO,cAAc;QACpB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC9B,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAED;;;;;OAKG;IACK,wBAAwB,CAAC,IAAa,EAAE,QAAgB,CAAC,CAAC;QAChE,OAAO,IAAI,OAAO,CAAC,CAAC,OAAiB,EAAE,MAAgB,EAAE,EAAE;YACzD,MAAM,kBAAkB,GAAW,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC;YAChF,MAAM,WAAW,GAAG,KAAK,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5C,IAAI,WAAW,IAAI,kBAAkB,EAAE;gBACrC,IAAI,CAAC,oBAAoB,EAAE;qBACxB,IAAI,CAAC,CAAC,KAAa,EAAE,EAAE;oBACtB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;oBAC1B,OAAO,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,CAAC,CAAC;gBACzC,CAAC,CAAC;qBACD,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;oBACX,MAAM,EAAE,CAAC;gBACX,CAAC,CAAC,CAAC;aACN;iBAAM,IAAI,WAAW,GAAG,CAAC,EAAE;gBAC1B,IAAI,CAAC,wBAAwB,EAAE;qBAC5B,IAAI,CAAC,CAAC,KAAa,EAAE,EAAE;oBACtB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;oBAC1B,OAAO,CAAC,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC;gBACnE,CAAC,CAAC;qBACD,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;oBACX,MAAM,EAAE,CAAC;gBACX,CAAC,CAAC,CAAC;aACN;iBAAM;gBACL,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,yBAAyB,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;aACnG;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,qBAAqB,CAAC,KAAa;QACzC,KAAK,IAAI,CAAC,GAAW,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACxD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE;gBAC7B,OAAO,CAAC,CAAC;aACV;SACF;IACH,CAAC;IAEO,yBAAyB,CAAC,KAAa;QAC7C,KAAK,IAAI,CAAC,GAAW,KAAK,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,EAAE;YACvC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE;gBAC7B,OAAO,CAAC,CAAC;aACV;SACF;IACH,CAAC;IAEO,oBAAoB;QAC1B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAiB,EAAE,MAAgB,EAAE,EAAE;YACzD,IAAI,WAAW,GAAW,CAAC,CAAC;YAC5B,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;gBAC7C,WAAW,GAAG,CAAC,CAAC;aACjB;iBAAM;gBACL,WAAW,GAAG,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;aACrC;YACD,IAAI,WAAW,KAAK,IAAI,CAAC,YAAY,EAAE,EAAE,iDAAiD;gBACxF,IAAI,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE;oBAC/B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;oBACxC,OAAO,CAAC,WAAW,CAAC,CAAC;iBACtB;qBAAM;oBACL,MAAM,EAAE,CAAC;iBACV;aACF;iBAAM;gBACL,OAAO,CAAC,WAAW,CAAC,CAAC;aACtB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,wBAAwB;QAC9B,OAAO,IAAI,OAAO,CAAC,CAAC,OAAiB,EAAE,MAAgB,EAAE,EAAE;YACzD,IAAI,WAAW,GAAW,CAAC,CAAC;YAC5B,IAAI,IAAI,CAAC,YAAY,GAAG,CAAC,GAAG,CAAC,EAAE;gBAC7B,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;aACpC;iBAAM;gBACL,WAAW,GAAG,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;aACrC;YACD,IAAI,WAAW,KAAK,IAAI,CAAC,YAAY,EAAE,EAAE,iDAAiD;gBACxF,IAAI,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE;oBAC/B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;oBACxC,OAAO,CAAC,WAAW,CAAC,CAAC;iBACtB;qBAAM;oBACL,MAAM,EAAE,CAAC;iBACV;aACF;iBAAM;gBACL,OAAO,CAAC,WAAW,CAAC,CAAC;aACtB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,QAAQ,CAAC,eAAwB,IAAI;QAC3C,iBAAiB;QACjB,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SACnC;QACD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,YAAY,EAAE;YAChB,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC;YACvB,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC;YACxB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;YACtB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;SAC5B;QACD,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEO,cAAc;QACpB,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC;IACxC,CAAC;;;YAvTF,SAAS,SAAC;gBACT,QAAQ,EAAE,gBAAgB;gBAC1B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA8CT;gBACD,SAAS,EAAE;oBACT,iBAAiB;iBAClB;gBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YAhEC,iBAAiB;YAMV,iBAAiB;;;wBA8DvB,WAAW,SAAC,sBAAsB;4BAKlC,YAAY,SAAC,SAAS,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  HostBinding,\r\n  HostListener,\r\n  ViewEncapsulation\r\n} from \"@angular/core\";\r\nimport { FormMasterService } from \"../../core/service/form-master.service\";\r\nimport { BaseSimpleGridComponent } from \"./base-simple-grid.component\";\r\nimport { ColumnAlign } from \"./simple-grid-column.directive\";\r\n\r\n@Component({\r\n  selector: \"co-simple-grid\",\r\n  template: `\r\n    <co-grid-toolbar *ngIf=\"inlineEdit && showToolbar\"\r\n                     (addClick)=\"addRow()\"\r\n                     (editClick)=\"editRow($event)\"\r\n                     (saveClick)=\"validateAndSave()\"\r\n                     (cancelClick)=\"cancelEditRow()\"\r\n    ></co-grid-toolbar>\r\n    <div class=\"simple-grid-column-header-wrapper\">\r\n      <div class=\"simple-grid-column-header\" *ngFor=\"let column of columns; let index = index\"\r\n           [style.min-width.px]=\"column.width\" [style.max-width.px]=\"column.width\" [style.padding-right.px]=\"isSingleColumn(column) ? 0 : 5\">\r\n        <div class=\"simple-grid-column-header-label\" [ngClass]=\"column.textAlign ? column.textAlign : defaultTextAlign\"\r\n             [textContent]=\"column.headerText\"\r\n        ></div>\r\n        <div *ngIf=\"column.resizable\" class=\"simple-grid-column-sizer\"\r\n             (mousedown)=\"handleSizerMouseDown($event, column)\"\r\n        ></div>\r\n      </div>\r\n    </div>\r\n    <div cdkDropListGroup class=\"drop-list-group\">\r\n      <div #dropList cdkDropList cdkDropListOrientation=\"vertical\"\r\n           class=\"simple-grid-drag-drop-list\"\r\n           [cdkDropListDisabled]=\"!dragDropEnabled\"\r\n           [cdkDropListData]=\"data\"\r\n           [cdkDropListEnterPredicate]=\"handleCanDragDrop\"\r\n           (cdkDropListDropped)=\"handleDrop($event)\"\r\n      >\r\n        <div class=\"simple-grid-row\" [class.selected]=\"rowIndex === selectedRowIndex\"\r\n             [class.editting]=\"rowIndex === editRowIndex\" *ngFor=\"let row of data; let rowIndex = index\" cdkDrag\r\n             (click)=\"handleClickRow($event, rowIndex)\" (dblclick)=\"handleDblClickRow($event, rowIndex)\">\r\n          <co-form class=\"simple-grid-row-form\">\r\n            <div class=\"simple-grid-column-cell\" *ngFor=\"let column of columns; let columnIndex = index\"\r\n                 [style.min-width]=\"isSingleColumn(column) ? 'fit-content' : column.width\" [style.max-width.px]=\"column.width\"\r\n                 [style.padding-right.px]=\"isSingleColumn(column) ? 0 : 5\" >\r\n                <co-simple-grid-cell\r\n                  [column]=\"column\"\r\n                  [row]=\"row\"\r\n                  [editMode]=\"inlineEdit && editting && rowIndex === editRowIndex && !isSingleColumn(column) && !rowContainsSingleColumn(row, columns)\"\r\n                  [fieldEditMode]=\"editCellIndex === columnIndex\"\r\n                  (cellClick)=\"handleCellClick(columnIndex)\"\r\n                ></co-simple-grid-cell>\r\n              <div *ngIf=\"column.resizable\" class=\"simple-grid-column-sizer-placeholder\"></div>\r\n            </div>\r\n          </co-form>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  providers: [\r\n    FormMasterService\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class SimpleGridComponent extends BaseSimpleGridComponent {\r\n  public readonly defaultTextAlign: ColumnAlign = ColumnAlign.Left;\r\n\r\n  @HostBinding(\"class.co-simple-grid\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @HostListener('keydown', ['$event'])\r\n  public handleKeyDown(event: KeyboardEvent): void {\r\n    if (!this.inlineEdit) {\r\n      return;\r\n    }\r\n    if (event.code === 'Tab') {\r\n      event.preventDefault();\r\n      this._nextAvailableCellToEdit(!event.shiftKey, this.editCellIndex)\r\n        .then((index: number) => {\r\n          this.editCellIndex = index;\r\n          this._changeDetection.markForCheck();\r\n        })\r\n      this._detectChanges();\r\n    }\r\n    if (event.code === 'Escape') {\r\n      this.cancelEditRow();\r\n    }\r\n    if (event.code === 'Enter') {\r\n      this.validateAndSave();\r\n    }\r\n  }\r\n\r\n  public editting: boolean = false;\r\n  public editRowIndex: number = -1;\r\n  public editCellIndex: number = -1;\r\n  public selectedRowIndex: number = -1;\r\n  public rowToEdit: any;\r\n\r\n  private _doubleClicked: boolean = false;\r\n  private _newRow: boolean = false;\r\n\r\n  constructor(\r\n    private _changeDetection: ChangeDetectorRef,\r\n    private _formMaster: FormMasterService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  public isSingleColumn(column): boolean {\r\n    return column.singleColumn;\r\n  }\r\n\r\n  public rowContainsSingleColumn(row, columns): boolean {\r\n    const singleColumn = columns.find(column => this.isSingleColumn(column) && !!row[column.field])\r\n    return !!singleColumn;\r\n  }\r\n\r\n  public addRow(): void {\r\n    const valid: boolean = this.validateAndSave();\r\n    this._detectChanges();\r\n    if (valid) {\r\n      this.data.unshift({});\r\n      this._newRow = true;\r\n      this.editRowIndex = 0;\r\n      this._nextAvailableCellToEdit(true).then((index: number) => {\r\n        this.editCellIndex = index;\r\n      });\r\n      this.editting = true;\r\n      this.rowToEdit = this.data[0];\r\n      this._detectChanges();\r\n    }\r\n  }\r\n\r\n  public validateAndSave(stopEditting: boolean = true): boolean {\r\n    if (!this.editting) {\r\n      return true;\r\n    }\r\n    const valid: boolean = this._formMaster.submitSlaves();\r\n    this._detectChanges();\r\n    if (valid) {\r\n      this._saveRow(stopEditting);\r\n      return true;\r\n    }\r\n  }\r\n\r\n  public cancelEditRow(): void {\r\n    if (!this.editting) {\r\n      return;\r\n    }\r\n    if (this._newRow) {\r\n      this.data.shift();\r\n    } else {\r\n      this.data[this.editRowIndex] = this.rowToEdit;\r\n    }\r\n    this._newRow = false;\r\n    this.editting = false;\r\n    this._detectChanges();\r\n  }\r\n\r\n  public handleClickRow(event: MouseEvent, index: number): void {\r\n    setTimeout(() => {\r\n      if (this._doubleClicked) {\r\n        return;\r\n      }\r\n      this.selectTheRow(index);\r\n    }, 200);\r\n  }\r\n\r\n  public selectTheRow(index: number, emit: boolean = true): void {\r\n    if (this.selectedRowIndex !== index && ((this.editting && this.validateAndSave()) || !this.editting)) {\r\n      this.selectedRowIndex = index;\r\n      if (emit) {\r\n        this.selectRow.next(this.data[this.selectedRowIndex]);\r\n      }\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  public handleDblClickRow(event: MouseEvent, index: number): void {\r\n    this._doubleClicked = true;\r\n    this.dblClickRow.next(this.data[index]);\r\n    this.selectTheRow(index, false);\r\n    if (this.inlineEdit) {\r\n      this.editRow(event);\r\n    }\r\n    this._resetDblClick();\r\n  }\r\n\r\n  public editRow(event: MouseEvent): void {\r\n    this.editRowIndex = this.selectedRowIndex;\r\n    this.rowToEdit = this.data[this.editRowIndex];\r\n    this.editting = true;\r\n    this._nextAvailableCellToEdit(true).then((index: number) => {\r\n      this.editCellIndex = index;\r\n    });\r\n    this._detectChanges();\r\n  }\r\n\r\n  public handleCellClick(index: number): void {\r\n    this.editCellIndex = index;\r\n    this._detectChanges();\r\n  }\r\n\r\n  private _resetDblClick(): void {\r\n    setTimeout(() => {\r\n      this._doubleClicked = false;\r\n    }, 500);\r\n  }\r\n\r\n  /**\r\n   *\r\n   * @param next; Move to next or previous cell\r\n   * @param start; Start from cellindex\r\n   * @private\r\n   */\r\n  private _nextAvailableCellToEdit(next: boolean, start: number = -1): Promise<number> {\r\n    return new Promise((resolve: Function, reject: Function) => {\r\n      const numEditableColumns: number = this.columns.filter(c => !c.readonly).length;\r\n      const wantedIndex = start + (next ? 1 : -1);\r\n      if (wantedIndex >= numEditableColumns) {\r\n        this._getNextEditRowIndex()\r\n          .then((index: number) => {\r\n            this.editRowIndex = index;\r\n            resolve(this._getNextEditCellIndex(0));\r\n          })\r\n          .catch((e) => {\r\n            reject();\r\n          });\r\n      } else if (wantedIndex < 0) {\r\n        this._getPreviousEditRowIndex()\r\n          .then((index: number) => {\r\n            this.editRowIndex = index;\r\n            resolve(this._getPreviousEditCellIndex(this.columns.length - 1));\r\n          })\r\n          .catch((e) => {\r\n            reject();\r\n          });\r\n      } else {\r\n        resolve(next ? this._getNextEditCellIndex(start + 1) : this._getPreviousEditCellIndex(start - 1));\r\n      }\r\n    });\r\n  }\r\n\r\n  private _getNextEditCellIndex(start: number): number {\r\n    for (let i: number = start; i < this.columns.length; i++) {\r\n      if (!this.columns[i].readonly) {\r\n        return i;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _getPreviousEditCellIndex(start: number): number {\r\n    for (let i: number = start; i >= 0; i--) {\r\n      if (!this.columns[i].readonly) {\r\n        return i;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _getNextEditRowIndex(): Promise<number> {\r\n    return new Promise((resolve: Function, reject: Function) => {\r\n      let newRowIndex: number = 0;\r\n      if (this.editRowIndex + 1 >= this.data.length) {\r\n        newRowIndex = 0;\r\n      } else {\r\n        newRowIndex = this.editRowIndex + 1;\r\n      }\r\n      if (newRowIndex !== this.editRowIndex) { // go to different row validate current one first\r\n        if (this.validateAndSave(false)) {\r\n          this.rowToEdit = this.data[newRowIndex];\r\n          resolve(newRowIndex);\r\n        } else {\r\n          reject();\r\n        }\r\n      } else {\r\n        resolve(newRowIndex);\r\n      }\r\n    });\r\n  }\r\n\r\n  private _getPreviousEditRowIndex(): Promise<number> {\r\n    return new Promise((resolve: Function, reject: Function) => {\r\n      let newRowIndex: number = 0;\r\n      if (this.editRowIndex - 1 < 0) {\r\n        newRowIndex = this.data.length - 1;\r\n      } else {\r\n        newRowIndex = this.editRowIndex - 1;\r\n      }\r\n      if (newRowIndex !== this.editRowIndex) { // go to different row validate current one first\r\n        if (this.validateAndSave(false)) {\r\n          this.rowToEdit = this.data[newRowIndex];\r\n          resolve(newRowIndex);\r\n        } else {\r\n          reject();\r\n        }\r\n      } else {\r\n        resolve(newRowIndex);\r\n      }\r\n    });\r\n  }\r\n\r\n  private _saveRow(stopEditting: boolean = true): void {\r\n    // emit saveEvent\r\n    if (this.rowToEdit) {\r\n      this.saveRow.next(this.rowToEdit);\r\n    }\r\n    this._newRow = false;\r\n    if (stopEditting) {\r\n      this.editRowIndex = -1;\r\n      this.editCellIndex = -1;\r\n      this.editting = false;\r\n      this.rowToEdit = undefined;\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  private _detectChanges(): void {\r\n    this._changeDetection.detectChanges();\r\n  }\r\n\r\n}\r\n"]}
333
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-grid.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/simple-grid/simple-grid.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  HostBinding,\r\n  HostListener, ViewChildren,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { FormMasterService } from \"../../core/service/form-master.service\";\r\nimport { BaseSimpleGridComponent } from \"./base-simple-grid.component\";\r\nimport { ColumnAlign } from \"./simple-grid-column.directive\";\r\n\r\n@Component({\r\n  selector: \"co-simple-grid\",\r\n  template: `\r\n    <co-grid-toolbar *ngIf=\"inlineEdit && showToolbar\"\r\n                     (addClick)=\"addRow()\"\r\n                     (editClick)=\"editRow($event)\"\r\n                     (saveClick)=\"validateAndSave()\"\r\n                     (cancelClick)=\"cancelEditRow()\"\r\n    ></co-grid-toolbar>\r\n    <table class=\"simple-grid-table\">\r\n      <colgroup>\r\n        <col *ngFor=\"let column of headerColumns; let index = index\" [attr.width]=\"column.width\">\r\n      </colgroup>\r\n      <thead>\r\n      <tr>\r\n        <th scope=\"col\" #headerCell class=\"simple-grid-column-header\" *ngFor=\"let column of headerColumns; let index = index\">\r\n          <div class=\"simple-grid-column-header-wrapper\" [class.resizable]=\"resizable\">\r\n            <div class=\"simple-grid-column-header-label\" [ngClass]=\"column.textAlign ? column.textAlign : defaultTextAlign\"\r\n                 [textContent]=\"column.headerText\"\r\n            ></div>\r\n            <div *ngIf=\"resizable && column.resizable\" class=\"simple-grid-column-sizer\"\r\n                 (mousedown)=\"handleSizerMouseDown($event, column)\"\r\n            ></div>\r\n          </div>\r\n        </th>\r\n      </tr>\r\n      </thead>\r\n      <tbody #dropList cdkDropList cdkDropListOrientation=\"vertical\"\r\n             class=\"simple-grid-drag-drop-list\"\r\n             [cdkDropListDisabled]=\"!dragDropEnabled\"\r\n             [cdkDropListData]=\"data\"\r\n             [cdkDropListEnterPredicate]=\"handleCanDragDrop\"\r\n             (cdkDropListDropped)=\"handleDrop($event)\">\r\n        <tr class=\"simple-grid-row\" [class.selected]=\"rowIndex === selectedRowIndex\"\r\n          [class.editting]=\"rowIndex === editRowIndex\" *ngFor=\"let row of data; let rowIndex = index\" cdkDrag\r\n          (click)=\"handleClickRow($event, rowIndex)\" (dblclick)=\"handleDblClickRow($event, rowIndex)\">\r\n          <co-form class=\"simple-grid-row-form\">\r\n            <ng-container *ngIf=\"isSingleColumnRow(row)\">\r\n              <td class=\"simple-grid-single-column-cell\" [attr.colspan]=\"headerColumns.length\">\r\n                <co-simple-grid-cell\r\n                  [column]=\"columns[singleColumnIndex(row)]\"\r\n                  [row]=\"row\"\r\n                  [editMode]=\"false\"\r\n                ></co-simple-grid-cell>\r\n              </td>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"!isSingleColumnRow(row)\">\r\n              <ng-container *ngFor=\"let column of headerColumns; let columnIndex = index\">\r\n                <td class=\"simple-grid-column-cell\" *ngIf=\"columnIndex !== singleColumnIndex(row)\">\r\n                  <co-simple-grid-cell\r\n                    [column]=\"column\"\r\n                    [row]=\"row\"\r\n                    [editMode]=\"inlineEdit && editting && rowIndex === editRowIndex\"\r\n                    [fieldEditMode]=\"editCellIndex === columnIndex\"\r\n                    (cellClick)=\"handleCellClick(columnIndex)\"\r\n                  ></co-simple-grid-cell>\r\n                  <div *ngIf=\"column.resizable\" class=\"simple-grid-column-sizer-placeholder\"></div>\r\n                </td>\r\n              </ng-container>\r\n            </ng-container>\r\n          </co-form>\r\n        </tr>\r\n      </tbody>\r\n    </table>\r\n  `,\r\n  providers: [\r\n    FormMasterService\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class SimpleGridComponent extends BaseSimpleGridComponent {\r\n  public readonly defaultTextAlign: ColumnAlign = ColumnAlign.Left;\r\n\r\n  @ViewChildren(\"headerCell\") set headerCells(cells) {\r\n    const headerElements = cells.toArray();\r\n    for (let i = 0; i < headerElements.length; i++) {\r\n      this.columns[i].elementRef = headerElements[i];\r\n    }\r\n  }\r\n\r\n  @HostBinding(\"class.co-simple-grid\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @HostListener('keydown', ['$event'])\r\n  public handleKeyDown(event: KeyboardEvent): void {\r\n    if (!this.inlineEdit) {\r\n      return;\r\n    }\r\n    if (event.code === 'Tab') {\r\n      event.preventDefault();\r\n      this._nextAvailableCellToEdit(!event.shiftKey, this.editCellIndex)\r\n        .then((index: number) => {\r\n          this.editCellIndex = index;\r\n          this._changeDetection.markForCheck();\r\n        })\r\n      this._detectChanges();\r\n    }\r\n    if (event.code === 'Escape') {\r\n      this.cancelEditRow();\r\n    }\r\n    if (event.code === 'Enter') {\r\n      this.validateAndSave();\r\n    }\r\n  }\r\n\r\n  public editting: boolean = false;\r\n  public editRowIndex: number = -1;\r\n  public editCellIndex: number = -1;\r\n  public selectedRowIndex: number = -1;\r\n  public rowToEdit: any;\r\n\r\n  private _doubleClicked: boolean = false;\r\n  private _newRow: boolean = false;\r\n\r\n  constructor(\r\n    private _changeDetection: ChangeDetectorRef,\r\n    private _formMaster: FormMasterService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  public isSingleColumn(column): boolean {\r\n    return column.singleColumn;\r\n  }\r\n\r\n  public rowContainsSingleColumn(row, columns): boolean {\r\n    const singleColumn = columns.find(column => this.isSingleColumn(column) && !!row[column.field])\r\n    return !!singleColumn;\r\n  }\r\n\r\n  public addRow(): void {\r\n    const valid: boolean = this.validateAndSave();\r\n    this._detectChanges();\r\n    if (valid) {\r\n      this.data.unshift({});\r\n      this._newRow = true;\r\n      this.editRowIndex = 0;\r\n      this._nextAvailableCellToEdit(true).then((index: number) => {\r\n        this.editCellIndex = index;\r\n      });\r\n      this.editting = true;\r\n      this.rowToEdit = this.data[0];\r\n      this._detectChanges();\r\n    }\r\n  }\r\n\r\n  public validateAndSave(stopEditting: boolean = true): boolean {\r\n    if (!this.editting) {\r\n      return true;\r\n    }\r\n    const valid: boolean = this._formMaster.submitSlaves();\r\n    this._detectChanges();\r\n    if (valid) {\r\n      this._saveRow(stopEditting);\r\n      return true;\r\n    }\r\n  }\r\n\r\n  public cancelEditRow(): void {\r\n    if (!this.editting) {\r\n      return;\r\n    }\r\n    if (this._newRow) {\r\n      this.data.shift();\r\n    } else {\r\n      this.data[this.editRowIndex] = this.rowToEdit;\r\n    }\r\n    this._newRow = false;\r\n    this.editting = false;\r\n    this._detectChanges();\r\n  }\r\n\r\n  public handleClickRow(event: MouseEvent, index: number): void {\r\n    setTimeout(() => {\r\n      if (this._doubleClicked) {\r\n        return;\r\n      }\r\n      this.selectTheRow(index);\r\n    }, 200);\r\n  }\r\n\r\n  public selectTheRow(index: number, emit: boolean = true): void {\r\n    if (this.selectedRowIndex !== index && ((this.editting && this.validateAndSave()) || !this.editting)) {\r\n      this.selectedRowIndex = index;\r\n      if (emit) {\r\n        this.selectRow.next(this.data[this.selectedRowIndex]);\r\n      }\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  public handleDblClickRow(event: MouseEvent, index: number): void {\r\n    this._doubleClicked = true;\r\n    this.dblClickRow.next(this.data[index]);\r\n    this.selectTheRow(index, false);\r\n    if (this.inlineEdit) {\r\n      this.editRow(event);\r\n    }\r\n    this._resetDblClick();\r\n  }\r\n\r\n  public editRow(event: MouseEvent): void {\r\n    this.editRowIndex = this.selectedRowIndex;\r\n    this.rowToEdit = this.data[this.editRowIndex];\r\n    this.editting = true;\r\n    this._nextAvailableCellToEdit(true).then((index: number) => {\r\n      this.editCellIndex = index;\r\n    });\r\n    this._detectChanges();\r\n  }\r\n\r\n  public handleCellClick(index: number): void {\r\n    this.editCellIndex = index;\r\n    this._detectChanges();\r\n  }\r\n\r\n  private _resetDblClick(): void {\r\n    setTimeout(() => {\r\n      this._doubleClicked = false;\r\n    }, 500);\r\n  }\r\n\r\n  /**\r\n   *\r\n   * @param next; Move to next or previous cell\r\n   * @param start; Start from cellindex\r\n   * @private\r\n   */\r\n  private _nextAvailableCellToEdit(next: boolean, start: number = -1): Promise<number> {\r\n    return new Promise((resolve: Function, reject: Function) => {\r\n      const numEditableColumns: number = this.columns.filter(c => !c.readonly).length;\r\n      const wantedIndex = start + (next ? 1 : -1);\r\n      if (wantedIndex >= numEditableColumns) {\r\n        this._getNextEditRowIndex()\r\n          .then((index: number) => {\r\n            this.editRowIndex = index;\r\n            resolve(this._getNextEditCellIndex(0));\r\n          })\r\n          .catch((e) => {\r\n            reject();\r\n          });\r\n      } else if (wantedIndex < 0) {\r\n        this._getPreviousEditRowIndex()\r\n          .then((index: number) => {\r\n            this.editRowIndex = index;\r\n            resolve(this._getPreviousEditCellIndex(this.columns.length - 1));\r\n          })\r\n          .catch((e) => {\r\n            reject();\r\n          });\r\n      } else {\r\n        resolve(next ? this._getNextEditCellIndex(start + 1) : this._getPreviousEditCellIndex(start - 1));\r\n      }\r\n    });\r\n  }\r\n\r\n  private _getNextEditCellIndex(start: number): number {\r\n    for (let i: number = start; i < this.columns.length; i++) {\r\n      if (!this.columns[i].readonly) {\r\n        return i;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _getPreviousEditCellIndex(start: number): number {\r\n    for (let i: number = start; i >= 0; i--) {\r\n      if (!this.columns[i].readonly) {\r\n        return i;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _getNextEditRowIndex(): Promise<number> {\r\n    return new Promise((resolve: Function, reject: Function) => {\r\n      let newRowIndex: number = 0;\r\n      if (this.editRowIndex + 1 >= this.data.length) {\r\n        newRowIndex = 0;\r\n      } else {\r\n        newRowIndex = this.editRowIndex + 1;\r\n      }\r\n      if (newRowIndex !== this.editRowIndex) { // go to different row validate current one first\r\n        if (this.validateAndSave(false)) {\r\n          this.rowToEdit = this.data[newRowIndex];\r\n          resolve(newRowIndex);\r\n        } else {\r\n          reject();\r\n        }\r\n      } else {\r\n        resolve(newRowIndex);\r\n      }\r\n    });\r\n  }\r\n\r\n  private _getPreviousEditRowIndex(): Promise<number> {\r\n    return new Promise((resolve: Function, reject: Function) => {\r\n      let newRowIndex: number = 0;\r\n      if (this.editRowIndex - 1 < 0) {\r\n        newRowIndex = this.data.length - 1;\r\n      } else {\r\n        newRowIndex = this.editRowIndex - 1;\r\n      }\r\n      if (newRowIndex !== this.editRowIndex) { // go to different row validate current one first\r\n        if (this.validateAndSave(false)) {\r\n          this.rowToEdit = this.data[newRowIndex];\r\n          resolve(newRowIndex);\r\n        } else {\r\n          reject();\r\n        }\r\n      } else {\r\n        resolve(newRowIndex);\r\n      }\r\n    });\r\n  }\r\n\r\n  private _saveRow(stopEditting: boolean = true): void {\r\n    // emit saveEvent\r\n    if (this.rowToEdit) {\r\n      this.saveRow.next(this.rowToEdit);\r\n    }\r\n    this._newRow = false;\r\n    if (stopEditting) {\r\n      this.editRowIndex = -1;\r\n      this.editCellIndex = -1;\r\n      this.editting = false;\r\n      this.rowToEdit = undefined;\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  private _detectChanges(): void {\r\n    this._changeDetection.detectChanges();\r\n  }\r\n\r\n}\r\n"]}
@@ -50,6 +50,8 @@ export * from './lib/components/input-combo-box/input-combo-box.module';
50
50
  export * from './lib/components/input-combo-box/input-combo-box.component';
51
51
  export * from './lib/components/input-date-picker/input-date-picker.module';
52
52
  export * from './lib/components/input-date-picker/input-date-picker.component';
53
+ export * from './lib/components/input-date-range-picker/input-date-range-picker.module';
54
+ export * from './lib/components/input-date-range-picker/input-date-range-picker.component';
53
55
  export * from './lib/components/input-listbox/input-listbox.component';
54
56
  export * from './lib/components/input-listbox/input-listbox.module';
55
57
  export * from './lib/components/input-number-picker/input-number-picker.module';
@@ -85,4 +87,4 @@ export * from './lib/components/icon/icon-cache.service';
85
87
  export * from './lib/components/base/component-interface-name';
86
88
  export * from './lib/pipes/price-display.pipe';
87
89
  export * from './lib/pipes/price-display-pipe.module';
88
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-api.js","sourceRoot":"","sources":["../../../projects/corecomponents/src/public-api.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,mDAAmD,CAAC;AAClE,cAAc,sDAAsD,CAAC;AACrE,cAAc,uCAAuC,CAAC;AACtD,cAAc,0CAA0C,CAAC;AACzD,cAAc,2DAA2D,CAAC;AAC1E,cAAc,8DAA8D,CAAC;AAC7E,cAAc,sCAAsC,CAAC;AACrD,cAAc,mCAAmC,CAAC;AAClD,cAAc,oDAAoD,CAAC;AACnE,cAAc,iDAAiD,CAAC;AAChE,cAAc,6CAA6C,CAAC;AAC5D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,2DAA2D,CAAC;AAC1E,cAAc,8DAA8D,CAAC;AAC7E,cAAc,2DAA2D,CAAC;AAC1E,cAAc,8DAA8D,CAAC;AAC7E,cAAc,6CAA6C,CAAC;AAC5D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,oEAAoE,CAAC;AACnF,cAAc,iEAAiE,CAAC;AAChF,cAAc,iDAAiD,CAAC;AAChE,cAAc,oDAAoD,CAAC;AACnE,cAAc,+CAA+C,CAAC;AAC9D,cAAc,kDAAkD,CAAC;AACjE,cAAc,6CAA6C,CAAC;AAC5D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,iDAAiD,CAAC;AAChE,cAAc,oDAAoD,CAAC;AACnE,cAAc,kDAAkD,CAAC;AACjE,cAAc,0DAA0D,CAAC;AACzE,cAAc,mCAAmC,CAAC;AAClD,cAAc,sCAAsC,CAAC;AACrD,cAAc,wCAAwC,CAAC;AACvD,cAAc,sCAAsC,CAAC;AACrD,cAAc,yCAAyC,CAAC;AACxD,cAAc,sDAAsD,CAAC;AACrE,cAAc,mDAAmD,CAAC;AAClE,cAAc,mCAAmC,CAAC;AAClD,cAAc,sCAAsC,CAAC;AACrD,cAAc,qCAAqC,CAAC;AACpD,cAAc,wCAAwC,CAAC;AACvD,cAAc,uDAAuD,CAAC;AACtE,cAAc,0DAA0D,CAAC;AACzE,cAAc,iFAAiF,CAAC;AAChG,cAAc,oFAAoF,CAAC;AACnG,cAAc,yDAAyD,CAAC;AACxE,cAAc,4DAA4D,CAAC;AAC3E,cAAc,6DAA6D,CAAC;AAC5E,cAAc,gEAAgE,CAAC;AAC/E,cAAc,wDAAwD,CAAC;AACvE,cAAc,qDAAqD,CAAC;AACpE,cAAc,iEAAiE,CAAC;AAChF,cAAc,oEAAoE,CAAC;AACnF,cAAc,+DAA+D,CAAC;AAC9E,cAAc,kEAAkE,CAAC;AACjF,cAAc,sDAAsD,CAAC;AACrE,cAAc,mDAAmD,CAAC;AAClE,cAAc,+CAA+C,CAAC;AAC9D,cAAc,kDAAkD,CAAC;AACjE,cAAc,uDAAuD,CAAC;AACtE,cAAc,0DAA0D,CAAC;AACzE,cAAc,yDAAyD,CAAC;AACxE,cAAc,4DAA4D,CAAC;AAC3E,cAAc,6DAA6D,CAAC;AAC5E,cAAc,gEAAgE,CAAC;AAC/E,cAAc,wCAAwC,CAAC;AACvD,cAAc,2CAA2C,CAAC;AAC1D,cAAc,qCAAqC,CAAC;AACpD,cAAc,mDAAmD,CAAC;AAClE,cAAc,qDAAqD,CAAC;AACpE,cAAc,wDAAwD,CAAC;AACvE,cAAc,gDAAgD,CAAC;AAC/D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,2DAA2D,CAAC;AAC1E,cAAc,oDAAoD,CAAC;AACnE,cAAc,iDAAiD,CAAC;AAChE,cAAc,mCAAmC,CAAC;AAClD,cAAc,sCAAsC,CAAC;AACrD,cAAc,2CAA2C,CAAC;AAC1D,cAAc,0CAA0C,CAAC;AACzD,cAAc,gDAAgD,CAAC;AAC/D,cAAc,gCAAgC,CAAC;AAC/C,cAAc,uCAAuC,CAAC","sourcesContent":["/*\n * Public API Surface of corecomponents\n */\n\nexport * from './lib/components/article-tile/article-tile.module';\nexport * from './lib/components/article-tile/article-tile.component';\nexport * from './lib/components/button/button.module';\nexport * from './lib/components/button/button.component';\nexport * from './lib/components/button-drop-down/button-drop-down.module';\nexport * from './lib/components/button-drop-down/button-drop-down.component';\nexport * from './lib/components/card/card.component';\nexport * from './lib/components/card/card.module';\nexport * from './lib/components/carousel-3d/carousel-3d.component';\nexport * from './lib/components/carousel-3d/carousel-3d.module';\nexport * from './lib/components/co-dialog/co-dialog.module';\nexport * from './lib/components/co-dialog/co-dialog.component';\nexport * from './lib/components/co-dialog-prompt/co-dialog-prompt.module';\nexport * from './lib/components/co-dialog-prompt/co-dialog-prompt.component';\nexport * from './lib/components/co-dialog-wizard/co-dialog-wizard.module';\nexport * from './lib/components/co-dialog-wizard/co-dialog-wizard.component';\nexport * from './lib/components/co-kanban/co-kanban.module';\nexport * from './lib/components/co-kanban/co-kanban.component';\nexport * from './lib/components/co-rich-text-editor/co-rich-text-editor.component';\nexport * from './lib/components/co-rich-text-editor/co-rich-text-editor.module';\nexport * from './lib/components/co-schedule/co-schedule.module';\nexport * from './lib/components/co-schedule/co-schedule.component';\nexport * from './lib/components/co-sidebar/co-sidebar.module';\nexport * from './lib/components/co-sidebar/co-sidebar.component';\nexport * from './lib/components/co-toggle/co-toggle.module';\nexport * from './lib/components/co-toggle/co-toggle.component';\nexport * from './lib/components/collapsible/collapsible.module';\nexport * from './lib/components/collapsible/collapsible.component';\nexport * from './lib/components/drop-down-list/drop-down.module';\nexport * from './lib/components/drop-down-list/drop-down-list.component';\nexport * from './lib/components/form/form.module';\nexport * from './lib/components/form/form.component';\nexport * from './lib/core/service/form-master.service';\nexport * from './lib/components/grid/co-grid.module';\nexport * from './lib/components/grid/co-grid.component';\nexport * from './lib/components/grid-toolbar/grid-toolbar.component';\nexport * from './lib/components/grid-toolbar/grid-toolbar.module';\nexport * from './lib/components/icon/icon.module';\nexport * from './lib/components/icon/icon.component';\nexport * from './lib/components/image/image.module';\nexport * from './lib/components/image/image.component';\nexport * from './lib/components/input-checkbox/input-checkbox.module';\nexport * from './lib/components/input-checkbox/input-checkbox.component';\nexport * from './lib/components/input-checkbox-multi-select/input-checkbox-multi-select.module';\nexport * from './lib/components/input-checkbox-multi-select/input-checkbox-multi-select.component';\nexport * from './lib/components/input-combo-box/input-combo-box.module';\nexport * from './lib/components/input-combo-box/input-combo-box.component';\nexport * from './lib/components/input-date-picker/input-date-picker.module';\nexport * from './lib/components/input-date-picker/input-date-picker.component';\nexport * from './lib/components/input-listbox/input-listbox.component';\nexport * from './lib/components/input-listbox/input-listbox.module';\nexport * from './lib/components/input-number-picker/input-number-picker.module';\nexport * from './lib/components/input-number-picker/input-number-picker.component';\nexport * from './lib/components/input-radio-button/input-radio-button.module';\nexport * from './lib/components/input-radio-button/input-radio-button.component';\nexport * from './lib/components/input-search/input-search.component';\nexport * from './lib/components/input-search/input-search.module';\nexport * from './lib/components/input-text/input-text.module';\nexport * from './lib/components/input-text/input-text.component';\nexport * from './lib/components/input-textarea/input-textarea.module';\nexport * from './lib/components/input-textarea/input-textarea.component';\nexport * from './lib/components/level-indicator/level-indicator.module';\nexport * from './lib/components/level-indicator/level-indicator.component';\nexport * from './lib/components/multi-select-list/multi-select-list.module';\nexport * from './lib/components/multi-select-list/multi-select-list.component';\nexport * from './lib/components/pivot/co-pivot.module';\nexport * from './lib/components/pivot/co-pivot.component';\nexport * from './lib/components/popup/popup.module';\nexport * from './lib/components/popup/text-input-popup.component';\nexport * from './lib/components/popup/popup-window-shell.component';\nexport * from './lib/components/popup/popup-message-display.component';\nexport * from './lib/components/popup/popup-buttons.component';\nexport * from './lib/components/popup/service/prompt.service';\nexport * from './lib/components/popup/popup-buttons.component';\nexport * from './lib/components/simple-grid/simple-grid-column.directive';\nexport * from './lib/components/simple-grid/simple-grid.component';\nexport * from './lib/components/simple-grid/simple-grid.module';\nexport * from './lib/components/tile/tile.module';\nexport * from './lib/components/tile/tile.component';\nexport * from './lib/core/enum/core-components-icon.enum';\nexport * from './lib/components/icon/icon-cache.service';\nexport * from './lib/components/base/component-interface-name';\nexport * from './lib/pipes/price-display.pipe';\nexport * from './lib/pipes/price-display-pipe.module';\n\n"]}
90
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"public-api.js","sourceRoot":"","sources":["../../../projects/corecomponents/src/public-api.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,cAAc,mDAAmD,CAAC;AAClE,cAAc,sDAAsD,CAAC;AACrE,cAAc,uCAAuC,CAAC;AACtD,cAAc,0CAA0C,CAAC;AACzD,cAAc,2DAA2D,CAAC;AAC1E,cAAc,8DAA8D,CAAC;AAC7E,cAAc,sCAAsC,CAAC;AACrD,cAAc,mCAAmC,CAAC;AAClD,cAAc,oDAAoD,CAAC;AACnE,cAAc,iDAAiD,CAAC;AAChE,cAAc,6CAA6C,CAAC;AAC5D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,2DAA2D,CAAC;AAC1E,cAAc,8DAA8D,CAAC;AAC7E,cAAc,2DAA2D,CAAC;AAC1E,cAAc,8DAA8D,CAAC;AAC7E,cAAc,6CAA6C,CAAC;AAC5D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,oEAAoE,CAAC;AACnF,cAAc,iEAAiE,CAAC;AAChF,cAAc,iDAAiD,CAAC;AAChE,cAAc,oDAAoD,CAAC;AACnE,cAAc,+CAA+C,CAAC;AAC9D,cAAc,kDAAkD,CAAC;AACjE,cAAc,6CAA6C,CAAC;AAC5D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,iDAAiD,CAAC;AAChE,cAAc,oDAAoD,CAAC;AACnE,cAAc,kDAAkD,CAAC;AACjE,cAAc,0DAA0D,CAAC;AACzE,cAAc,mCAAmC,CAAC;AAClD,cAAc,sCAAsC,CAAC;AACrD,cAAc,wCAAwC,CAAC;AACvD,cAAc,sCAAsC,CAAC;AACrD,cAAc,yCAAyC,CAAC;AACxD,cAAc,sDAAsD,CAAC;AACrE,cAAc,mDAAmD,CAAC;AAClE,cAAc,mCAAmC,CAAC;AAClD,cAAc,sCAAsC,CAAC;AACrD,cAAc,qCAAqC,CAAC;AACpD,cAAc,wCAAwC,CAAC;AACvD,cAAc,uDAAuD,CAAC;AACtE,cAAc,0DAA0D,CAAC;AACzE,cAAc,iFAAiF,CAAC;AAChG,cAAc,oFAAoF,CAAC;AACnG,cAAc,yDAAyD,CAAC;AACxE,cAAc,4DAA4D,CAAC;AAC3E,cAAc,6DAA6D,CAAC;AAC5E,cAAc,gEAAgE,CAAC;AAC/E,cAAc,yEAAyE,CAAC;AACxF,cAAc,4EAA4E,CAAC;AAC3F,cAAc,wDAAwD,CAAC;AACvE,cAAc,qDAAqD,CAAC;AACpE,cAAc,iEAAiE,CAAC;AAChF,cAAc,oEAAoE,CAAC;AACnF,cAAc,+DAA+D,CAAC;AAC9E,cAAc,kEAAkE,CAAC;AACjF,cAAc,sDAAsD,CAAC;AACrE,cAAc,mDAAmD,CAAC;AAClE,cAAc,+CAA+C,CAAC;AAC9D,cAAc,kDAAkD,CAAC;AACjE,cAAc,uDAAuD,CAAC;AACtE,cAAc,0DAA0D,CAAC;AACzE,cAAc,yDAAyD,CAAC;AACxE,cAAc,4DAA4D,CAAC;AAC3E,cAAc,6DAA6D,CAAC;AAC5E,cAAc,gEAAgE,CAAC;AAC/E,cAAc,wCAAwC,CAAC;AACvD,cAAc,2CAA2C,CAAC;AAC1D,cAAc,qCAAqC,CAAC;AACpD,cAAc,mDAAmD,CAAC;AAClE,cAAc,qDAAqD,CAAC;AACpE,cAAc,wDAAwD,CAAC;AACvE,cAAc,gDAAgD,CAAC;AAC/D,cAAc,+CAA+C,CAAC;AAC9D,cAAc,gDAAgD,CAAC;AAC/D,cAAc,2DAA2D,CAAC;AAC1E,cAAc,oDAAoD,CAAC;AACnE,cAAc,iDAAiD,CAAC;AAChE,cAAc,mCAAmC,CAAC;AAClD,cAAc,sCAAsC,CAAC;AACrD,cAAc,2CAA2C,CAAC;AAC1D,cAAc,0CAA0C,CAAC;AACzD,cAAc,gDAAgD,CAAC;AAC/D,cAAc,gCAAgC,CAAC;AAC/C,cAAc,uCAAuC,CAAC","sourcesContent":["/*\n * Public API Surface of corecomponents\n */\n\nexport * from './lib/components/article-tile/article-tile.module';\nexport * from './lib/components/article-tile/article-tile.component';\nexport * from './lib/components/button/button.module';\nexport * from './lib/components/button/button.component';\nexport * from './lib/components/button-drop-down/button-drop-down.module';\nexport * from './lib/components/button-drop-down/button-drop-down.component';\nexport * from './lib/components/card/card.component';\nexport * from './lib/components/card/card.module';\nexport * from './lib/components/carousel-3d/carousel-3d.component';\nexport * from './lib/components/carousel-3d/carousel-3d.module';\nexport * from './lib/components/co-dialog/co-dialog.module';\nexport * from './lib/components/co-dialog/co-dialog.component';\nexport * from './lib/components/co-dialog-prompt/co-dialog-prompt.module';\nexport * from './lib/components/co-dialog-prompt/co-dialog-prompt.component';\nexport * from './lib/components/co-dialog-wizard/co-dialog-wizard.module';\nexport * from './lib/components/co-dialog-wizard/co-dialog-wizard.component';\nexport * from './lib/components/co-kanban/co-kanban.module';\nexport * from './lib/components/co-kanban/co-kanban.component';\nexport * from './lib/components/co-rich-text-editor/co-rich-text-editor.component';\nexport * from './lib/components/co-rich-text-editor/co-rich-text-editor.module';\nexport * from './lib/components/co-schedule/co-schedule.module';\nexport * from './lib/components/co-schedule/co-schedule.component';\nexport * from './lib/components/co-sidebar/co-sidebar.module';\nexport * from './lib/components/co-sidebar/co-sidebar.component';\nexport * from './lib/components/co-toggle/co-toggle.module';\nexport * from './lib/components/co-toggle/co-toggle.component';\nexport * from './lib/components/collapsible/collapsible.module';\nexport * from './lib/components/collapsible/collapsible.component';\nexport * from './lib/components/drop-down-list/drop-down.module';\nexport * from './lib/components/drop-down-list/drop-down-list.component';\nexport * from './lib/components/form/form.module';\nexport * from './lib/components/form/form.component';\nexport * from './lib/core/service/form-master.service';\nexport * from './lib/components/grid/co-grid.module';\nexport * from './lib/components/grid/co-grid.component';\nexport * from './lib/components/grid-toolbar/grid-toolbar.component';\nexport * from './lib/components/grid-toolbar/grid-toolbar.module';\nexport * from './lib/components/icon/icon.module';\nexport * from './lib/components/icon/icon.component';\nexport * from './lib/components/image/image.module';\nexport * from './lib/components/image/image.component';\nexport * from './lib/components/input-checkbox/input-checkbox.module';\nexport * from './lib/components/input-checkbox/input-checkbox.component';\nexport * from './lib/components/input-checkbox-multi-select/input-checkbox-multi-select.module';\nexport * from './lib/components/input-checkbox-multi-select/input-checkbox-multi-select.component';\nexport * from './lib/components/input-combo-box/input-combo-box.module';\nexport * from './lib/components/input-combo-box/input-combo-box.component';\nexport * from './lib/components/input-date-picker/input-date-picker.module';\nexport * from './lib/components/input-date-picker/input-date-picker.component';\nexport * from './lib/components/input-date-range-picker/input-date-range-picker.module';\nexport * from './lib/components/input-date-range-picker/input-date-range-picker.component';\nexport * from './lib/components/input-listbox/input-listbox.component';\nexport * from './lib/components/input-listbox/input-listbox.module';\nexport * from './lib/components/input-number-picker/input-number-picker.module';\nexport * from './lib/components/input-number-picker/input-number-picker.component';\nexport * from './lib/components/input-radio-button/input-radio-button.module';\nexport * from './lib/components/input-radio-button/input-radio-button.component';\nexport * from './lib/components/input-search/input-search.component';\nexport * from './lib/components/input-search/input-search.module';\nexport * from './lib/components/input-text/input-text.module';\nexport * from './lib/components/input-text/input-text.component';\nexport * from './lib/components/input-textarea/input-textarea.module';\nexport * from './lib/components/input-textarea/input-textarea.component';\nexport * from './lib/components/level-indicator/level-indicator.module';\nexport * from './lib/components/level-indicator/level-indicator.component';\nexport * from './lib/components/multi-select-list/multi-select-list.module';\nexport * from './lib/components/multi-select-list/multi-select-list.component';\nexport * from './lib/components/pivot/co-pivot.module';\nexport * from './lib/components/pivot/co-pivot.component';\nexport * from './lib/components/popup/popup.module';\nexport * from './lib/components/popup/text-input-popup.component';\nexport * from './lib/components/popup/popup-window-shell.component';\nexport * from './lib/components/popup/popup-message-display.component';\nexport * from './lib/components/popup/popup-buttons.component';\nexport * from './lib/components/popup/service/prompt.service';\nexport * from './lib/components/popup/popup-buttons.component';\nexport * from './lib/components/simple-grid/simple-grid-column.directive';\nexport * from './lib/components/simple-grid/simple-grid.component';\nexport * from './lib/components/simple-grid/simple-grid.module';\nexport * from './lib/components/tile/tile.module';\nexport * from './lib/components/tile/tile.component';\nexport * from './lib/core/enum/core-components-icon.enum';\nexport * from './lib/components/icon/icon-cache.service';\nexport * from './lib/components/base/component-interface-name';\nexport * from './lib/pipes/price-display.pipe';\nexport * from './lib/pipes/price-display-pipe.module';\n\n"]}