@cause-911/devextreme
Version:
Run `npm install @cause-911/devextreme --save` to add this library to your project
206 lines • 15 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
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';
var CauseDataGridComponent = /** @class */ (function (_super) {
tslib_1.__extends(CauseDataGridComponent, _super);
function CauseDataGridComponent(element, ngZone, templateHost, watcherHelper, idh, optionHost, transferState, platform, location, locationStrategy) {
var _this = _super.call(this, element, ngZone, templateHost, watcherHelper, idh, optionHost, transferState, platform) || this;
_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 {?}
*/
function () {
if (_this.isEditing) {
_this.isEditing = false;
_this.instance.cancelEditData();
}
}));
return _this;
}
/**
* @return {?}
*/
CauseDataGridComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
_super.prototype.ngOnInit.call(this);
this.onToolbarPreparing.subscribe((/**
* @param {?} e
* @return {?}
*/
function (e) { return _this.toolbarPreparing(e); }));
this.onInitialized.subscribe((/**
* @param {?} e
* @return {?}
*/
function (e) { return _this.initialized(e); }));
};
/**
* @private
* @param {?} e
* @return {?}
*/
CauseDataGridComponent.prototype.toolbarPreparing = /**
* @private
* @param {?} e
* @return {?}
*/
function (e) {
var _this = this;
/** @type {?} */
var toolbarItems = e.toolbarOptions.items;
if (this.allowPrint) {
toolbarItems.push({
widget: 'dxButton',
location: 'after',
options: {
icon: 'print',
onClick: (/**
* @param {?} ev
* @return {?}
*/
function (ev) {
_this.print(e.element);
}),
}
});
}
};
/**
* @private
* @param {?} e
* @return {?}
*/
CauseDataGridComponent.prototype.initialized = /**
* @private
* @param {?} e
* @return {?}
*/
function (e) {
var _this = this;
/** @type {?} */
var options = e.component.option('editing');
options.popup.onShowing = (/**
* @param {?} ev
* @return {?}
*/
function (ev) {
_this.location.go(_this.location.path() + '#editing');
_this.isEditing = true;
});
options.popup.onHiding = (/**
* @param {?} ev
* @return {?}
*/
function (ev) {
if (_this.isEditing) {
_this.location.back();
}
_this.isEditing = false;
});
};
/**
* @private
* @param {?} element
* @return {?}
*/
CauseDataGridComponent.prototype.print = /**
* @private
* @param {?} element
* @return {?}
*/
function (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 = function () { return [
{ 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 }]
};
return CauseDataGridComponent;
}(DxDataGridComponent));
export { CauseDataGridComponent };
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"]}