UNPKG

@cause-911/devextreme

Version:

Run `npm install @cause-911/devextreme --save` to add this library to your project

192 lines 14.2 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ElementRef, Input, NgZone, PlatformRef } from '@angular/core'; import { DxDataGridComponent, DxTemplateHost, IterableDifferHelper, NestedOptionHost, WatcherHelper } from 'devextreme-angular'; import { TransferState } from '@angular/platform-browser'; import { Location, LocationStrategy, PathLocationStrategy } from '@angular/common'; export class CauseDataGridComponent extends DxDataGridComponent { /** * @param {?} element * @param {?} ngZone * @param {?} templateHost * @param {?} watcherHelper * @param {?} idh * @param {?} optionHost * @param {?} transferState * @param {?} platform * @param {?} location * @param {?} locationStrategy */ constructor(element, ngZone, templateHost, watcherHelper, idh, optionHost, transferState, platform, location, locationStrategy) { super(element, ngZone, templateHost, watcherHelper, idh, optionHost, transferState, platform); this.location = location; this.locationStrategy = locationStrategy; this.allowPrint = true; this.hoverStateEnabled = true; this.rowAlternationEnabled = true; this.showBorders = true; this.export = { allowExportSelectedData: false, enabled: true, fileName: 'export', }; this.filterRow = { visible: true, }; this.pager = { showPageSizeSelector: true, showNavigationButtons: true, showInfo: true, visible: true, }; this.isEditing = false; optionHost.setHost(this); locationStrategy.onPopState((/** * @return {?} */ () => { if (this.isEditing) { this.isEditing = false; this.instance.cancelEditData(); } })); } /** * @return {?} */ ngOnInit() { super.ngOnInit(); this.onToolbarPreparing.subscribe((/** * @param {?} e * @return {?} */ e => this.toolbarPreparing(e))); this.onInitialized.subscribe((/** * @param {?} e * @return {?} */ e => this.initialized(e))); } /** * @private * @param {?} e * @return {?} */ toolbarPreparing(e) { /** @type {?} */ const toolbarItems = e.toolbarOptions.items; if (this.allowPrint) { toolbarItems.push({ widget: 'dxButton', location: 'after', options: { icon: 'print', onClick: (/** * @param {?} ev * @return {?} */ (ev) => { this.print(e.element); }), } }); } } /** * @private * @param {?} e * @return {?} */ initialized(e) { /** @type {?} */ const options = e.component.option('editing'); options.popup.onShowing = (/** * @param {?} ev * @return {?} */ (ev) => { this.location.go(this.location.path() + '#editing'); this.isEditing = true; }); options.popup.onHiding = (/** * @param {?} ev * @return {?} */ (ev) => { if (this.isEditing) { this.location.back(); } this.isEditing = false; }); } /** * @private * @param {?} element * @return {?} */ print(element) { element.classList.add('only-div-to-print'); window.print(); setTimeout((/** * @return {?} */ function () { element.classList.remove('only-div-to-print'); }), 1000); } } CauseDataGridComponent.decorators = [ { type: Component, args: [{ selector: 'cause-dx-data-grid', template: "<ng-content></ng-content>", providers: [NestedOptionHost, Location, { provide: LocationStrategy, useClass: PathLocationStrategy }], styles: [""] }] } ]; /** @nocollapse */ CauseDataGridComponent.ctorParameters = () => [ { type: ElementRef }, { type: NgZone }, { type: DxTemplateHost }, { type: WatcherHelper }, { type: IterableDifferHelper }, { type: NestedOptionHost }, { type: TransferState }, { type: PlatformRef }, { type: Location }, { type: LocationStrategy } ]; CauseDataGridComponent.propDecorators = { allowPrint: [{ type: Input }] }; if (false) { /** @type {?} */ CauseDataGridComponent.prototype.allowPrint; /** @type {?} */ CauseDataGridComponent.prototype.hoverStateEnabled; /** @type {?} */ CauseDataGridComponent.prototype.rowAlternationEnabled; /** @type {?} */ CauseDataGridComponent.prototype.showBorders; /** @type {?} */ CauseDataGridComponent.prototype.export; /** @type {?} */ CauseDataGridComponent.prototype.filterRow; /** @type {?} */ CauseDataGridComponent.prototype.pager; /** @type {?} */ CauseDataGridComponent.prototype.isEditing; /** * @type {?} * @private */ CauseDataGridComponent.prototype.location; /** * @type {?} * @private */ CauseDataGridComponent.prototype.locationStrategy; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cause-data-grid.component.js","sourceRoot":"ng://@cause-911/devextreme/","sources":["lib/cause-data-grid/cause-data-grid.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAC,SAAS,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,EAAU,WAAW,EAAC,MAAM,eAAe,CAAC;AACxF,OAAO,EACH,mBAAmB,EACnB,cAAc,EACd,oBAAoB,EAAE,gBAAgB,EACtC,aAAa,EAChB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAC,aAAa,EAAC,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAC,QAAQ,EAAE,gBAAgB,EAAE,oBAAoB,EAAC,MAAM,iBAAiB,CAAC;AAQjF,MAAM,OAAO,sBAAuB,SAAQ,mBAAmB;;;;;;;;;;;;;IAsB3D,YACI,OAAmB,EACnB,MAAc,EACd,YAA4B,EAC5B,aAA4B,EAC5B,GAAyB,EACzB,UAA4B,EAC5B,aAA4B,EAC5B,QAAqB,EACb,QAAkB,EAClB,gBAAkC;QAE1C,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,aAAa,EAAE,GAAG,EAAE,UAAU,EAAE,aAAa,EAAE,QAAQ,CAAC,CAAC;QAHtF,aAAQ,GAAR,QAAQ,CAAU;QAClB,qBAAgB,GAAhB,gBAAgB,CAAkB;QA/BvC,eAAU,GAAG,IAAI,CAAC;QAE3B,sBAAiB,GAAG,IAAI,CAAC;QACvB,0BAAqB,GAAG,IAAI,CAAC;QAC7B,gBAAW,GAAG,IAAI,CAAC;QACnB,WAAM,GAAG;YACL,uBAAuB,EAAE,KAAK;YAC9B,OAAO,EAAE,IAAI;YACb,QAAQ,EAAE,QAAQ;SACrB,CAAC;QACF,cAAS,GAAG;YACR,OAAO,EAAE,IAAI;SAChB,CAAC;QACF,UAAK,GAAG;YACJ,oBAAoB,EAAE,IAAI;YAC1B,qBAAqB,EAAE,IAAI;YAC3B,QAAQ,EAAE,IAAI;YACd,OAAO,EAAE,IAAI;SAChB,CAAC;QACF,cAAS,GAAG,KAAK,CAAC;QAed,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAEzB,gBAAgB,CAAC,UAAU;;;QAAC,GAAG,EAAE;YAC/B,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;gBACvB,IAAI,CAAC,QAAQ,CAAC,cAAc,EAAE,CAAC;aAChC;QACH,CAAC,EAAC,CAAC;IACP,CAAC;;;;IAED,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QAEjB,IAAI,CAAC,kBAAkB,CAAC,SAAS;;;;QAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,EAAC,CAAC;QACjE,IAAI,CAAC,aAAa,CAAC,SAAS;;;;QAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,EAAC,CAAC;IAC3D,CAAC;;;;;;IAEO,gBAAgB,CAAC,CAAC;;cAClB,YAAY,GAAG,CAAC,CAAC,cAAc,CAAC,KAAK;QAC3C,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,YAAY,CAAC,IAAI,CAAC;gBAChB,MAAM,EAAE,UAAU;gBAClB,QAAQ,EAAE,OAAO;gBACjB,OAAO,EAAE;oBACP,IAAI,EAAE,OAAO;oBACb,OAAO;;;;oBAAE,CAAC,EAAE,EAAE,EAAE;wBACd,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;oBACxB,CAAC,CAAA;iBACF;aACF,CAAC,CAAC;SACJ;IACH,CAAC;;;;;;IAEO,WAAW,CAAC,CAAC;;cACb,OAAO,GAAG,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC;QAC7C,OAAO,CAAC,KAAK,CAAC,SAAS;;;;QAAG,CAAC,EAAE,EAAE,EAAE;YAC/B,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,GAAG,UAAU,CAAC,CAAC;YACpD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACxB,CAAC,CAAA,CAAC;QACF,OAAO,CAAC,KAAK,CAAC,QAAQ;;;;QAAG,CAAC,EAAE,EAAE,EAAE;YAC9B,IAAI,IAAI,CAAC,SAAS,EAAE;gBAClB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;aACtB;YACD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACzB,CAAC,CAAA,CAAC;IACJ,CAAC;;;;;;IAEO,KAAK,CAAC,OAAO;QACjB,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;QAE3C,MAAM,CAAC,KAAK,EAAE,CAAC;QAEf,UAAU;;;QAAC;YACP,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;QAClD,CAAC,GAAE,IAAI,CAAC,CAAC;IACb,CAAC;;;YAhGJ,SAAS,SAAC;gBACP,QAAQ,EAAE,oBAAoB;gBAC9B,qCAA+C;gBAE/C,SAAS,EAAE,CAAC,gBAAgB,EAAE,QAAQ,EAAE,EAAC,OAAO,EAAE,gBAAgB,EAAE,QAAQ,EAAE,oBAAoB,EAAC,CAAC;;aACvG;;;;YAfkB,UAAU;YAAS,MAAM;YAGxC,cAAc;YAEd,aAAa;YADb,oBAAoB;YAAE,gBAAgB;YAGlC,aAAa;YAPiC,WAAW;YAQzD,QAAQ;YAAE,gBAAgB;;;yBAS/B,KAAK;;;;IAAN,4CAA2B;;IAE3B,mDAAyB;;IACvB,uDAA6B;;IAC7B,6CAAmB;;IACnB,wCAIE;;IACF,2CAEE;;IACF,uCAKE;;IACF,2CAAkB;;;;;IAWd,0CAA0B;;;;;IAC1B,kDAA0C","sourcesContent":["import {Component, ElementRef, Input, NgZone, OnInit, PlatformRef} from '@angular/core';\nimport {\n    DxDataGridComponent,\n    DxTemplateHost, INestedOptionContainer,\n    IterableDifferHelper, NestedOptionHost,\n    WatcherHelper\n} from 'devextreme-angular';\nimport {TransferState} from '@angular/platform-browser';\nimport {Location, LocationStrategy, PathLocationStrategy} from '@angular/common';\n\n@Component({\n    selector: 'cause-dx-data-grid',\n    templateUrl: './cause-data-grid.component.html',\n    styleUrls: ['./cause-data-grid.component.scss'],\n    providers: [NestedOptionHost, Location, {provide: LocationStrategy, useClass: PathLocationStrategy}],\n})\nexport class CauseDataGridComponent extends DxDataGridComponent implements OnInit, INestedOptionContainer {\n  @Input() allowPrint = true;\n\n  hoverStateEnabled = true;\n    rowAlternationEnabled = true;\n    showBorders = true;\n    export = {\n        allowExportSelectedData: false,\n        enabled: true,\n        fileName: 'export',\n    };\n    filterRow = {\n        visible: true,\n    };\n    pager = {\n        showPageSizeSelector: true,\n        showNavigationButtons: true,\n        showInfo: true,\n        visible: true,\n    };\n    isEditing = false;\n\n    constructor(\n        element: ElementRef,\n        ngZone: NgZone,\n        templateHost: DxTemplateHost,\n        watcherHelper: WatcherHelper,\n        idh: IterableDifferHelper,\n        optionHost: NestedOptionHost,\n        transferState: TransferState,\n        platform: PlatformRef,\n        private location: Location,\n        private locationStrategy: LocationStrategy\n    ) {\n        super(element, ngZone, templateHost, watcherHelper, idh, optionHost, transferState, platform);\n        optionHost.setHost(this);\n\n        locationStrategy.onPopState(() => {\n          if (this.isEditing) {\n            this.isEditing = false;\n            this.instance.cancelEditData();\n          }\n        });\n    }\n\n    ngOnInit(): void {\n        super.ngOnInit();\n\n        this.onToolbarPreparing.subscribe(e => this.toolbarPreparing(e));\n        this.onInitialized.subscribe(e => this.initialized(e));\n    }\n\n    private toolbarPreparing(e) {\n      const toolbarItems = e.toolbarOptions.items;\n      if (this.allowPrint) {\n        toolbarItems.push({\n          widget: 'dxButton',\n          location: 'after',\n          options: {\n            icon: 'print',\n            onClick: (ev) => {\n              this.print(e.element);\n            },\n          }\n        });\n      }\n    }\n\n    private initialized(e) {\n      const options = e.component.option('editing');\n      options.popup.onShowing = (ev) => {\n        this.location.go(this.location.path() + '#editing');\n        this.isEditing = true;\n      };\n      options.popup.onHiding = (ev) => {\n        if (this.isEditing) {\n          this.location.back();\n        }\n        this.isEditing = false;\n      };\n    }\n\n    private print(element) {\n        element.classList.add('only-div-to-print');\n\n        window.print();\n\n        setTimeout(function () {\n            element.classList.remove('only-div-to-print');\n        }, 1000);\n    }\n}\n\n"]}