@colijnit/corecomponents_v12 259.1.11 → 259.1.13
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/colijnit-corecomponents_v12.umd.js +100 -36
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/lib/components/co-dialog-wizard/co-dialog-wizard.component.js +2 -2
- package/esm2015/lib/components/list-of-icons/list-of-icons.component.js +3 -2
- package/esm2015/lib/components/simple-grid/base-simple-grid.component.js +46 -27
- package/esm2015/lib/components/simple-grid/simple-grid.component.js +17 -7
- package/esm2015/lib/core/enum/core-components-icon.enum.js +3 -1
- package/esm2015/lib/core/model/core-components-icon-svg.js +3 -1
- package/fesm2015/colijnit-corecomponents_v12.js +66 -33
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/list-of-icons/style/_layout.scss +3 -11
- package/lib/components/simple-grid/base-simple-grid.component.d.ts +5 -2
- package/lib/components/simple-grid/simple-grid.component.d.ts +4 -3
- package/lib/core/enum/core-components-icon.enum.d.ts +2 -0
- package/package.json +1 -1
- package/colijnit-corecomponents_v12-259.1.10.tgz +0 -0
|
@@ -20,7 +20,7 @@ CoDialogWizardComponent.decorators = [
|
|
|
20
20
|
<div class="dialog-header">
|
|
21
21
|
<ng-content select="[header]"></ng-content>
|
|
22
22
|
<div class="dialog-close-button" *ngIf="showCloseIcon" (click)="closeClick.emit($event)">
|
|
23
|
-
<co-icon [icon]="icons.
|
|
23
|
+
<co-icon [icon]="icons.CrossSkinny"></co-icon>
|
|
24
24
|
</div>
|
|
25
25
|
</div>
|
|
26
26
|
|
|
@@ -48,4 +48,4 @@ CoDialogWizardComponent.propDecorators = {
|
|
|
48
48
|
closeClick: [{ type: Output }],
|
|
49
49
|
showClass: [{ type: HostBinding, args: ["class.co-dialog-wizard",] }]
|
|
50
50
|
};
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY28tZGlhbG9nLXdpemFyZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY28tZGlhbG9nLXdpemFyZC9jby1kaWFsb2ctd2l6YXJkLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNyRyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsT0FBTyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBOEIvRSxNQUFNLE9BQU8sdUJBQXVCO0lBNUJwQztRQTZCa0IsVUFBSyxHQUE4QixrQkFBa0IsQ0FBQztRQUcvRCxrQkFBYSxHQUFZLElBQUksQ0FBQztRQUc5QixjQUFTLEdBQVksSUFBSSxDQUFDO1FBR2pCLGVBQVUsR0FBNkIsSUFBSSxZQUFZLEVBQWMsQ0FBQztJQU94RixDQUFDO0lBSlEsU0FBUztRQUNkLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQzs7O1lBM0NGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsa0JBQWtCO2dCQUM1QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7OztHQWVUO2dCQUNELFVBQVUsRUFBRTtvQkFDVixPQUFPLENBQUMsZ0JBQWdCLEVBQUU7d0JBQ3hCLEtBQUssQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUMsT0FBTyxFQUFFLENBQUMsRUFBQyxDQUFDLENBQUM7d0JBQy9CLEtBQUssQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLEVBQUMsT0FBTyxFQUFFLENBQUMsRUFBQyxDQUFDLENBQUM7d0JBQ2xDLFVBQVUsQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDO3dCQUMvQyxVQUFVLENBQUMsV0FBVyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztxQkFDdEMsQ0FBQztpQkFDSDtnQkFDRCxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTthQUN0Qzs7OzRCQUlFLEtBQUs7d0JBR0wsS0FBSzt5QkFHTCxNQUFNO3dCQUdOLFdBQVcsU0FBQyx3QkFBd0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBIb3N0QmluZGluZywgSW5wdXQsIE91dHB1dCwgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQge0NvcmVDb21wb25lbnRzSWNvbn0gZnJvbSBcIi4uLy4uL2NvcmUvZW51bS9jb3JlLWNvbXBvbmVudHMtaWNvbi5lbnVtXCI7XG5pbXBvcnQge2FuaW1hdGUsIHN0YXRlLCBzdHlsZSwgdHJhbnNpdGlvbiwgdHJpZ2dlcn0gZnJvbSBcIkBhbmd1bGFyL2FuaW1hdGlvbnNcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnY28tZGlhbG9nLXdpemFyZCcsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cImNvLWRpYWxvZy13aXphcmQtd3JhcHBlclwiIFtAc2hvd0hpZGVEaWFsb2ddPVwiYW5pbWF0aW9uXCI+
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY28tZGlhbG9nLXdpemFyZC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY28tZGlhbG9nLXdpemFyZC9jby1kaWFsb2ctd2l6YXJkLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFlBQVksRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNyRyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsT0FBTyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLE9BQU8sRUFBQyxNQUFNLHFCQUFxQixDQUFDO0FBOEIvRSxNQUFNLE9BQU8sdUJBQXVCO0lBNUJwQztRQTZCa0IsVUFBSyxHQUE4QixrQkFBa0IsQ0FBQztRQUcvRCxrQkFBYSxHQUFZLElBQUksQ0FBQztRQUc5QixjQUFTLEdBQVksSUFBSSxDQUFDO1FBR2pCLGVBQVUsR0FBNkIsSUFBSSxZQUFZLEVBQWMsQ0FBQztJQU94RixDQUFDO0lBSlEsU0FBUztRQUNkLE9BQU8sSUFBSSxDQUFDO0lBQ2QsQ0FBQzs7O1lBM0NGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsa0JBQWtCO2dCQUM1QixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7OztHQWVUO2dCQUNELFVBQVUsRUFBRTtvQkFDVixPQUFPLENBQUMsZ0JBQWdCLEVBQUU7d0JBQ3hCLEtBQUssQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUMsT0FBTyxFQUFFLENBQUMsRUFBQyxDQUFDLENBQUM7d0JBQy9CLEtBQUssQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLEVBQUMsT0FBTyxFQUFFLENBQUMsRUFBQyxDQUFDLENBQUM7d0JBQ2xDLFVBQVUsQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDLGFBQWEsQ0FBQyxDQUFDO3dCQUMvQyxVQUFVLENBQUMsV0FBVyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztxQkFDdEMsQ0FBQztpQkFDSDtnQkFDRCxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTthQUN0Qzs7OzRCQUlFLEtBQUs7d0JBR0wsS0FBSzt5QkFHTCxNQUFNO3dCQUdOLFdBQVcsU0FBQyx3QkFBd0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBIb3N0QmluZGluZywgSW5wdXQsIE91dHB1dCwgVmlld0VuY2Fwc3VsYXRpb259IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQge0NvcmVDb21wb25lbnRzSWNvbn0gZnJvbSBcIi4uLy4uL2NvcmUvZW51bS9jb3JlLWNvbXBvbmVudHMtaWNvbi5lbnVtXCI7XG5pbXBvcnQge2FuaW1hdGUsIHN0YXRlLCBzdHlsZSwgdHJhbnNpdGlvbiwgdHJpZ2dlcn0gZnJvbSBcIkBhbmd1bGFyL2FuaW1hdGlvbnNcIjtcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnY28tZGlhbG9nLXdpemFyZCcsXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdiBjbGFzcz1cImNvLWRpYWxvZy13aXphcmQtd3JhcHBlclwiIFtAc2hvd0hpZGVEaWFsb2ddPVwiYW5pbWF0aW9uXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwiZGlhbG9nLWhlYWRlclwiPlxuICAgICAgICA8bmctY29udGVudCBzZWxlY3Q9XCJbaGVhZGVyXVwiPjwvbmctY29udGVudD5cbiAgICAgICAgPGRpdiBjbGFzcz1cImRpYWxvZy1jbG9zZS1idXR0b25cIiAqbmdJZj1cInNob3dDbG9zZUljb25cIiAoY2xpY2spPVwiY2xvc2VDbGljay5lbWl0KCRldmVudClcIj5cbiAgICAgICAgICA8Y28taWNvbiBbaWNvbl09XCJpY29ucy5Dcm9zc1NraW5ueVwiPjwvY28taWNvbj5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cblxuICAgICAgPGhyIGNsYXNzPVwiY28tZGlhbG9nLXdpemFyZC1kaXZpZGVyXCI+XG5cbiAgICAgIDxkaXYgY2xhc3M9XCJkaWFsb2ctY29udGVudFwiPlxuICAgICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgYW5pbWF0aW9uczogW1xuICAgIHRyaWdnZXIoJ3Nob3dIaWRlRGlhbG9nJywgW1xuICAgICAgc3RhdGUoJyonLCBzdHlsZSh7b3BhY2l0eTogMX0pKSxcbiAgICAgIHN0YXRlKCd2b2lkJywgc3R5bGUoe29wYWNpdHk6IDB9KSksXG4gICAgICB0cmFuc2l0aW9uKCd2b2lkID0+IConLCBhbmltYXRlKCcyMDBtcyAyMDBtcycpKSxcbiAgICAgIHRyYW5zaXRpb24oJyogPT4gdm9pZCcsIGFuaW1hdGUoMjAwKSlcbiAgICBdKVxuICBdLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXG59KVxuZXhwb3J0IGNsYXNzIENvRGlhbG9nV2l6YXJkQ29tcG9uZW50IHtcbiAgcHVibGljIHJlYWRvbmx5IGljb25zOiB0eXBlb2YgQ29yZUNvbXBvbmVudHNJY29uID0gQ29yZUNvbXBvbmVudHNJY29uO1xuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBzaG93Q2xvc2VJY29uOiBib29sZWFuID0gdHJ1ZTtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgYW5pbWF0aW9uOiBib29sZWFuID0gdHJ1ZTtcblxuICBAT3V0cHV0KClcbiAgcHVibGljIHJlYWRvbmx5IGNsb3NlQ2xpY2s6IEV2ZW50RW1pdHRlcjxNb3VzZUV2ZW50PiA9IG5ldyBFdmVudEVtaXR0ZXI8TW91c2VFdmVudD4oKTtcblxuICBASG9zdEJpbmRpbmcoXCJjbGFzcy5jby1kaWFsb2ctd2l6YXJkXCIpXG4gIHB1YmxpYyBzaG93Q2xhc3MoKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIHRydWU7XG4gIH1cblxufVxuIl19
|
|
@@ -58,7 +58,8 @@ ListOfIconsComponent.decorators = [
|
|
|
58
58
|
template: `
|
|
59
59
|
<div class="icon-item active" [class.menu-opened]="showMenu" (click)="toggleMenu()">
|
|
60
60
|
<co-icon [iconData]="activeItem.icon" [style.width.px]="iconSize" [style.height.px]="iconSize"></co-icon>
|
|
61
|
-
<co-icon class="drop-arrow" [iconData]="icons.getIcon(Icon.
|
|
61
|
+
<co-icon *ngIf="!showMenu" class="drop-arrow" [iconData]="icons.getIcon(Icon.CaretDownSolid)"></co-icon>
|
|
62
|
+
<co-icon *ngIf="showMenu" class="drop-arrow" [iconData]="icons.getIcon(Icon.CaretUpSolid)"></co-icon>
|
|
62
63
|
</div>
|
|
63
64
|
<div class="dropdown-menu" *ngIf="showMenu" (clickOutside)="onClickOutside()">
|
|
64
65
|
<div class="icon-item" *ngFor="let item of collection" (click)="selectItem(item)"
|
|
@@ -88,4 +89,4 @@ ListOfIconsComponent.propDecorators = {
|
|
|
88
89
|
itemSelected: [{ type: Output }],
|
|
89
90
|
showClass: [{ type: HostBinding, args: ['class.co-list-of-icons',] }]
|
|
90
91
|
};
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-of-icons.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/list-of-icons/list-of-icons.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,YAAY,EAAE,WAAW,EAAE,KAAK,EAAU,MAAM,EAAE,iBAAiB,EAAC,MAAM,eAAe,CAAC;AAC7G,OAAO,EAAC,kBAAkB,EAAC,MAAM,2CAA2C,CAAC;AAC7E,OAAO,EAAC,gBAAgB,EAAC,MAAM,4BAA4B,CAAC;AA2B5D,MAAM,OAAO,oBAAoB;IAkC/B,YACS,gBAAkC,EAClC,KAAuB;QADvB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,UAAK,GAAL,KAAK,CAAkB;QAzBzB,aAAQ,GAAW,EAAE,CAAC;QAMtB,iBAAY,GAA+B,IAAI,YAAY,EAAgB,CAAC;QAOnE,SAAI,GAAQ,kBAAkB,CAAC;QACxC,aAAQ,GAAY,KAAK,CAAC;QAC1B,sBAAiB,GAAY,KAAK,CAAC;QAClC,gBAAW,GAAmB,EAAE,CAAC;QAElC,kBAAa,GAAmB;YACrC,EAAC,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,EAAE,KAAK,EAAE,cAAc,EAAC;YAC3F,EAAC,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,8BAA8B,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAC;SACjG,CAAC;IAMF,CAAC;IArCD,IACW,UAAU,CAAC,KAAqB;QACzC,IAAI,CAAC,WAAW,GAAG,KAAK,IAAI,EAAE,CAAC;IACjC,CAAC;IAED,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAYM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAkBM,QAAQ;QACb,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE;YACjC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;SACtC;IACH,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;IACjC,CAAC;IAEM,UAAU,CAAC,IAAkB;QAClC,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,WAAW,IAAI,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,KAAK,WAAW,EAAE;YACxF,IAAI,CAAC,iBAAiB,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC;YACjD,OAAO;SACR;QAED,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC;IAEM,4BAA4B,CAAC,WAAyB;QAC3D,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;QACpC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;IACjC,CAAC;;;YA9FF,SAAS,SAAC;gBACT,QAAQ,EAAE,kBAAkB;gBAC5B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;GAmBT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YA1BO,gBAAgB;YAAhB,gBAAgB;;;yBA4BrB,KAAK;uBASL,KAAK;yBAGL,KAAK;2BAGL,MAAM;wBAGN,WAAW,SAAC,wBAAwB","sourcesContent":["import {Component, EventEmitter, HostBinding, Input, OnInit, Output, ViewEncapsulation} from \"@angular/core\";\r\nimport {CoreComponentsIcon} from \"../../core/enum/core-components-icon.enum\";\r\nimport {IconCacheService} from \"../icon/icon-cache.service\";\r\nimport {IconListItem} from \"../../model/icon-list-item\";\r\n\r\n@Component({\r\n  selector: 'co-list-of-icons',\r\n  template: `\r\n    <div class=\"icon-item active\" [class.menu-opened]=\"showMenu\" (click)=\"toggleMenu()\">\r\n      <co-icon [iconData]=\"activeItem.icon\" [style.width.px]=\"iconSize\" [style.height.px]=\"iconSize\"></co-icon>\r\n      <co-icon *ngIf=\"!showMenu\" class=\"drop-arrow\" [iconData]=\"icons.getIcon(Icon.CaretDownSolid)\"></co-icon>\r\n      <co-icon *ngIf=\"showMenu\" class=\"drop-arrow\" [iconData]=\"icons.getIcon(Icon.CaretUpSolid)\"></co-icon>\r\n    </div>\r\n    <div class=\"dropdown-menu\" *ngIf=\"showMenu\" (clickOutside)=\"onClickOutside()\">\r\n      <div class=\"icon-item\" *ngFor=\"let item of collection\" (click)=\"selectItem(item)\"\r\n           [class.active]=\"item === activeItem\">\r\n        <co-icon [iconData]=\"item.icon\" [style.width.px]=\"iconSize\" [style.height.px]=\"iconSize\"></co-icon>\r\n        <div class=\"label\">{{ item.label }}</div>\r\n      </div>\r\n      <div class=\"picking-type-wrapper\" *ngIf=\"showSubCategories\">\r\n        <div class=\"button-wrapper\" *ngFor=\"let subCategory of subCategories\" (click)=\"handlePickingCategoryClicked(subCategory)\">\r\n          <co-icon class=\"co-transaction-button-bar-icon\" [iconData]=\"subCategory.icon\"></co-icon>\r\n          <span class=\"button-title\">{{subCategory.label}}</span>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class ListOfIconsComponent implements OnInit {\r\n  @Input()\r\n  public set collection(value: IconListItem[]) {\r\n    this._collection = value || [];\r\n  }\r\n\r\n  public get collection(): IconListItem[] {\r\n    return this._collection;\r\n  }\r\n\r\n  @Input()\r\n  public iconSize: number = 25;\r\n\r\n  @Input()\r\n  public activeItem?: IconListItem;\r\n\r\n  @Output()\r\n  public itemSelected: EventEmitter<IconListItem> = new EventEmitter<IconListItem>();\r\n\r\n  @HostBinding('class.co-list-of-icons')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  public readonly Icon: any = CoreComponentsIcon;\r\n  public showMenu: boolean = false;\r\n  public showSubCategories: boolean = false;\r\n  private _collection: IconListItem[] = [];\r\n\r\n  public subCategories: IconListItem[] = [\r\n    {icon: this.iconCacheService.getIcon(this.Icon.BoxesPackingRegular), label: 'To be picked'},\r\n    {icon: this.iconCacheService.getIcon(this.Icon.RegularBoxesPackingCircleCheck), label: 'Picked'}\r\n  ];\r\n\r\n  constructor(\r\n    public iconCacheService: IconCacheService,\r\n    public icons: IconCacheService\r\n  ) {\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    if (this.activeItem === undefined) {\r\n      this.activeItem = this.collection[0];\r\n    }\r\n  }\r\n\r\n  public toggleMenu(): void {\r\n    this.showMenu = !this.showMenu;\r\n  }\r\n\r\n  public selectItem(item: IconListItem): void {\r\n    if (item.label.toUpperCase() === 'LOGISTICS' || item.label.toUpperCase() === 'LOGISTIEK') {\r\n      this.showSubCategories = !this.showSubCategories;\r\n      return;\r\n    }\r\n\r\n    this.activeItem = item;\r\n    this.showMenu = false;\r\n    this.itemSelected.emit(this.activeItem);\r\n  }\r\n\r\n  public handlePickingCategoryClicked(subCategory: IconListItem): void {\r\n    this.itemSelected.emit(subCategory);\r\n    this.showMenu = false;\r\n    this.showSubCategories = false;\r\n  }\r\n\r\n  public onClickOutside(): void {\r\n    this.showMenu = false;\r\n    this.showSubCategories = false;\r\n  }\r\n}\r\n"]}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { ChangeDetectorRef, ContentChildren, Directive, EventEmitter, HostListener, Input, Output } from "@angular/core";
|
|
2
3
|
import { SimpleGridColumnDirective } from "./simple-grid-column.directive";
|
|
3
4
|
import { moveItemInArray } from "@angular/cdk/drag-drop";
|
|
4
5
|
import { Subject } from "rxjs";
|
|
5
6
|
export class BaseSimpleGridComponent {
|
|
6
|
-
constructor() {
|
|
7
|
+
constructor(changeDetection) {
|
|
8
|
+
this.changeDetection = changeDetection;
|
|
7
9
|
this.MIN_COLUMN_WIDTH = 50;
|
|
8
10
|
this.dataChanged = new Subject();
|
|
9
11
|
this.dragDropEnabled = false;
|
|
@@ -19,6 +21,7 @@ export class BaseSimpleGridComponent {
|
|
|
19
21
|
this.emitDragDrop = false;
|
|
20
22
|
this.onDrop = new EventEmitter();
|
|
21
23
|
this.selectRow = new EventEmitter();
|
|
24
|
+
this.deselectRow = new EventEmitter();
|
|
22
25
|
this.dblClickRow = new EventEmitter();
|
|
23
26
|
this.saveRow = new EventEmitter();
|
|
24
27
|
this.deleteRow = new EventEmitter();
|
|
@@ -96,40 +99,52 @@ export class BaseSimpleGridComponent {
|
|
|
96
99
|
return row.singleColumnIndex;
|
|
97
100
|
}
|
|
98
101
|
prepareDataRow(row, index) {
|
|
102
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
103
|
+
});
|
|
99
104
|
}
|
|
100
105
|
_setColumns(columns) {
|
|
101
106
|
this.columns.push(...columns);
|
|
102
107
|
this.columns.sort((a, b) => a.order < b.order ? -1 : 1);
|
|
103
108
|
}
|
|
104
109
|
_prepareData() {
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
this.disabledRows.length = 0;
|
|
109
|
-
if (this.columns && this.columns.length > 0) {
|
|
110
|
-
this.headerColumns = this.columns.filter(c => !c.singleColumn);
|
|
111
|
-
this.headerColumnsCopy = this.headerColumns;
|
|
112
|
-
let singleColumnIndex = -1;
|
|
113
|
-
for (let i = 0; i < this.columns.length; i++) {
|
|
114
|
-
if (this.columns[i].singleColumn) {
|
|
115
|
-
singleColumnIndex = i;
|
|
116
|
-
break;
|
|
117
|
-
}
|
|
110
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
111
|
+
if (this._prepared) {
|
|
112
|
+
return;
|
|
118
113
|
}
|
|
119
|
-
|
|
120
|
-
if (
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
114
|
+
this.disabledRows.length = 0;
|
|
115
|
+
if (this.columns && this.columns.length > 0) {
|
|
116
|
+
this.headerColumns = this.columns.filter(c => !c.singleColumn);
|
|
117
|
+
this.headerColumnsCopy = this.headerColumns;
|
|
118
|
+
let singleColumnIndex = -1;
|
|
119
|
+
for (let i = 0; i < this.columns.length; i++) {
|
|
120
|
+
if (this.columns[i].singleColumn) {
|
|
121
|
+
singleColumnIndex = i;
|
|
122
|
+
break;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
// first check if there's single column data
|
|
126
|
+
if (this.data && this.data.length > 0) {
|
|
127
|
+
if (singleColumnIndex > -1) {
|
|
128
|
+
const field = this.columns[singleColumnIndex].field;
|
|
129
|
+
for (let i = 0; i < this.data.length; i++) { // then mark row as single column row
|
|
130
|
+
if (this.data[i][field] !== undefined && this.data[i][field] !== null && this.data[i][field] !== "") {
|
|
131
|
+
// bit nasty to add prop, but cool for now
|
|
132
|
+
this.data[i].singleColumnIndex = singleColumnIndex;
|
|
133
|
+
}
|
|
134
|
+
yield this.prepareDataRow(this.data[i], i);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
for (let j = 0; j < this.data.length; j++) {
|
|
139
|
+
yield this.prepareDataRow(this.data[j], j);
|
|
140
|
+
}
|
|
126
141
|
}
|
|
127
|
-
this.prepareDataRow(this.data[i], i);
|
|
128
142
|
}
|
|
143
|
+
this._prepared = true;
|
|
129
144
|
}
|
|
130
|
-
this.
|
|
131
|
-
|
|
132
|
-
|
|
145
|
+
this._resizeColumnsToFit();
|
|
146
|
+
this.changeDetection.detectChanges();
|
|
147
|
+
});
|
|
133
148
|
}
|
|
134
149
|
_resizeColumnsToFit() {
|
|
135
150
|
const calculateColumns = this.columns.filter(c => !c.autoFit && !c.width);
|
|
@@ -149,6 +164,9 @@ export class BaseSimpleGridComponent {
|
|
|
149
164
|
BaseSimpleGridComponent.decorators = [
|
|
150
165
|
{ type: Directive }
|
|
151
166
|
];
|
|
167
|
+
BaseSimpleGridComponent.ctorParameters = () => [
|
|
168
|
+
{ type: ChangeDetectorRef }
|
|
169
|
+
];
|
|
152
170
|
BaseSimpleGridComponent.propDecorators = {
|
|
153
171
|
content: [{ type: ContentChildren, args: [SimpleGridColumnDirective,] }],
|
|
154
172
|
data: [{ type: Input }],
|
|
@@ -163,6 +181,7 @@ BaseSimpleGridComponent.propDecorators = {
|
|
|
163
181
|
extraColumns: [{ type: Input }],
|
|
164
182
|
onDrop: [{ type: Output }],
|
|
165
183
|
selectRow: [{ type: Output }],
|
|
184
|
+
deselectRow: [{ type: Output }],
|
|
166
185
|
dblClickRow: [{ type: Output }],
|
|
167
186
|
saveRow: [{ type: Output }],
|
|
168
187
|
deleteRow: [{ type: Output }],
|
|
@@ -171,4 +190,4 @@ BaseSimpleGridComponent.propDecorators = {
|
|
|
171
190
|
handleMouseMove: [{ type: HostListener, args: ['document:mousemove', ['$event'],] }],
|
|
172
191
|
handleMouseUp: [{ type: HostListener, args: ['document:mouseup', ['$event'],] }]
|
|
173
192
|
};
|
|
174
|
-
//# 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\nimport {Subject} from \"rxjs\";\r\n\r\n@Directive()\r\nexport abstract class BaseSimpleGridComponent {\r\n  public readonly MIN_COLUMN_WIDTH: number = 50;\r\n  public readonly dataChanged: Subject<void> = new Subject<void>();\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    this.dataChanged.next();\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 set exportData(value: Object[]) {\r\n    this._exportData = value;\r\n  }\r\n\r\n  public get exportData(): Object[] {\r\n    return this._exportData;\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 showEdit: boolean = false;\r\n\r\n  @Input()\r\n  public showToolbar: boolean = false;\r\n\r\n  @Input()\r\n  public autoAddRow: 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  @Output()\r\n  public deleteRow: EventEmitter<{}> = new EventEmitter<{}>();\r\n\r\n  @Output()\r\n  public addRow: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public rowVisible: 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  public headerColumnsCopy: SimpleGridColumnDirective[] = [];\r\n\r\n  protected _data: Object[] = [];\r\n  protected _exportData: Object[] = [];\r\n  protected disabledRows: number[] = [];\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  protected prepareDataRow(row: any, index: number): void {\r\n\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    this.disabledRows.length = 0;\r\n\r\n    if (this.columns && this.columns.length > 0) {\r\n      this.headerColumns = this.columns.filter(c => !c.singleColumn);\r\n      this.headerColumnsCopy = this.headerColumns;\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 && this.data && this.data.length > 0) {\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          this.prepareDataRow(this.data[i], i);\r\n        }\r\n      }\r\n\r\n      this._prepared = true;\r\n    }\r\n    this._resizeColumnsToFit();\r\n  }\r\n\r\n  private _resizeColumnsToFit(): void {\r\n    const calculateColumns: SimpleGridColumnDirective[] = this.columns.filter(c => !c.autoFit && !c.width);\r\n    for (let i = 0; i < calculateColumns.length; i++) {\r\n      calculateColumns[i].width = `${100 / calculateColumns.length}%`;\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"]}
|
|
193
|
+
//# 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 {\r\n  ChangeDetectorRef,\r\n  ContentChildren, Directive, EventEmitter, HostListener, Input, Output, QueryList, ViewChildren\r\n} from \"@angular/core\";\r\nimport {SimpleGridColumnDirective} from \"./simple-grid-column.directive\";\r\nimport {CdkDrag, CdkDragDrop, CdkDropList, moveItemInArray} from \"@angular/cdk/drag-drop\";\r\nimport {Subject} from \"rxjs\";\r\nimport {FormMasterService} from \"../../core/service/form-master.service\";\r\n\r\n@Directive()\r\nexport abstract class BaseSimpleGridComponent {\r\n  public readonly MIN_COLUMN_WIDTH: number = 50;\r\n  public readonly dataChanged: Subject<void> = new Subject<void>();\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    this.dataChanged.next();\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 set exportData(value: Object[]) {\r\n    this._exportData = value;\r\n  }\r\n\r\n  public get exportData(): Object[] {\r\n    return this._exportData;\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 showEdit: boolean = false;\r\n\r\n  @Input()\r\n  public showToolbar: boolean = false;\r\n\r\n  @Input()\r\n  public autoAddRow: 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 deselectRow: EventEmitter<void> = new EventEmitter<void>();\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  @Output()\r\n  public deleteRow: EventEmitter<{}> = new EventEmitter<{}>();\r\n\r\n  @Output()\r\n  public addRow: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @Output()\r\n  public rowVisible: 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  public headerColumnsCopy: SimpleGridColumnDirective[] = [];\r\n\r\n  protected _data: Object[] = [];\r\n  protected _exportData: Object[] = [];\r\n  protected disabledRows: number[] = [];\r\n\r\n  private _columnForResize: SimpleGridColumnDirective;\r\n  private _prepared: boolean = false;\r\n  private _startMousePositionX: number;\r\n\r\n  constructor(\r\n    protected changeDetection: ChangeDetectorRef\r\n  ) {\r\n  }\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  protected async prepareDataRow(row: any, index: number): Promise<void> {\r\n\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 async _prepareData(): Promise<void> {\r\n    if (this._prepared) {\r\n      return;\r\n    }\r\n    this.disabledRows.length = 0;\r\n\r\n    if (this.columns && this.columns.length > 0) {\r\n      this.headerColumns = this.columns.filter(c => !c.singleColumn);\r\n      this.headerColumnsCopy = this.headerColumns;\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 (this.data && this.data.length > 0) {\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            await this.prepareDataRow(this.data[i], i);\r\n          }\r\n        } else {\r\n          for (let j = 0; j < this.data.length; j++) {\r\n            await this.prepareDataRow(this.data[j], j);\r\n          }\r\n        }\r\n      }\r\n\r\n      this._prepared = true;\r\n    }\r\n    this._resizeColumnsToFit();\r\n    this.changeDetection.detectChanges();\r\n  }\r\n\r\n  private _resizeColumnsToFit(): void {\r\n    const calculateColumns: SimpleGridColumnDirective[] = this.columns.filter(c => !c.autoFit && !c.width);\r\n    for (let i = 0; i < calculateColumns.length; i++) {\r\n      calculateColumns[i].width = `${100 / calculateColumns.length}%`;\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"]}
|