@cause-911/devextreme
Version:
Run `npm install @cause-911/devextreme --save` to add this library to your project
192 lines • 14.2 kB
JavaScript
/**
* @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":"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","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"]}