devexpress-reporting-angular 23.2.5-build-2440-1343 → 23.2.5-build-2465-1730
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/dx-report-viewer/components/analytics/properties/collectioneditor/collectioneditor.component.d.ts +4 -2
- package/dx-report-viewer/components/reporting/parameterspanel/date-range/date-range.component.d.ts +4 -2
- package/dx-report-viewer/dx-report-viewer.component.d.ts +2 -0
- package/esm2020/dx-report-viewer/components/analytics/properties/collectioneditor/collectioneditor.component.mjs +9 -4
- package/esm2020/dx-report-viewer/components/reporting/parameterspanel/date-range/date-range.component.mjs +18 -9
- package/esm2020/dx-report-viewer/dx-report-viewer.component.mjs +10 -1
- package/fesm2015/devexpress-reporting-angular-dx-report-viewer.mjs +33 -11
- package/fesm2015/devexpress-reporting-angular-dx-report-viewer.mjs.map +1 -1
- package/fesm2020/devexpress-reporting-angular-dx-report-viewer.mjs +32 -11
- package/fesm2020/devexpress-reporting-angular-dx-report-viewer.mjs.map +1 -1
- package/package.json +3 -3
@@ -1,12 +1,14 @@
|
|
1
|
-
import { TemplateRef, OnInit, OnDestroy } from '@angular/core';
|
1
|
+
import { ChangeDetectorRef, TemplateRef, OnInit, OnDestroy } from '@angular/core';
|
2
2
|
import { ICollectionEditorOptions, ICollectionEditorViewModel } from '@devexpress/analytics-core/property-grid/widgets/collectioneditor/_editor';
|
3
3
|
import * as i0 from "@angular/core";
|
4
4
|
export declare class CollectionEditorComponent implements OnInit, OnDestroy {
|
5
|
+
private _changeDetectorRef;
|
5
6
|
options: ICollectionEditorOptions;
|
6
7
|
contentTemplate: TemplateRef<any>;
|
7
8
|
data: ICollectionEditorViewModel;
|
9
|
+
private _vmSubscription;
|
8
10
|
private _model;
|
9
|
-
constructor();
|
11
|
+
constructor(_changeDetectorRef: ChangeDetectorRef);
|
10
12
|
ngOnDestroy(): void;
|
11
13
|
ngOnInit(): void;
|
12
14
|
onScrollViewInitialized(args: any): void;
|
package/dx-report-viewer/components/reporting/parameterspanel/date-range/date-range.component.d.ts
CHANGED
@@ -1,18 +1,20 @@
|
|
1
|
-
import { ElementRef, OnInit, OnDestroy } from '@angular/core';
|
1
|
+
import { ChangeDetectorRef, ElementRef, OnInit, OnDestroy } from '@angular/core';
|
2
2
|
import { Properties } from 'devextreme/ui/button';
|
3
3
|
import { IDateRangeEditorOptions } from 'devexpress-reporting/viewer/widgets/dateRange/dateRangeEditor';
|
4
4
|
import { IDateRangeEditorViewModel } from 'devexpress-reporting/viewer/widgets/dateRange/dateRangeEditor.viewmodel';
|
5
5
|
import * as i0 from "@angular/core";
|
6
6
|
export declare class DateRangeComponent implements OnInit, OnDestroy {
|
7
7
|
private _currentElement;
|
8
|
+
private _changeDetectorRef;
|
8
9
|
options: IDateRangeEditorOptions;
|
9
10
|
private _editor;
|
10
11
|
data: IDateRangeEditorViewModel;
|
12
|
+
private _vmSubscription;
|
11
13
|
showPopupOptions: Properties;
|
12
14
|
textBoxInputElement: HTMLElement;
|
13
15
|
subscribeToEvents: (event: any) => void;
|
14
16
|
unsubscribeFromEvents: () => void;
|
15
|
-
constructor(_currentElement: ElementRef<any
|
17
|
+
constructor(_currentElement: ElementRef<any>, _changeDetectorRef: ChangeDetectorRef);
|
16
18
|
ngOnDestroy(): void;
|
17
19
|
ngOnInit(): void;
|
18
20
|
static ɵfac: i0.ɵɵFactoryDeclaration<DateRangeComponent, never>;
|
@@ -21,6 +21,7 @@ export declare class DxReportViewerComponent extends DxReportingComponent {
|
|
21
21
|
private _accessibilitySettings;
|
22
22
|
private _reportUrl;
|
23
23
|
private _disposableCallback;
|
24
|
+
private _disposeViewModelChangedSubscription;
|
24
25
|
viewModel: IPreviewViewModel;
|
25
26
|
model: JSReportViewer;
|
26
27
|
protected _binding: JSReportViewerBinding;
|
@@ -40,6 +41,7 @@ export declare class DxReportViewerComponent extends DxReportingComponent {
|
|
40
41
|
GetPreviewModel(): PreviewDisposableModel;
|
41
42
|
ngAfterViewInit(): void;
|
42
43
|
ngOnDestroy(): void;
|
44
|
+
private _subscribeToViewModelChanged;
|
43
45
|
isMobile: boolean;
|
44
46
|
get accessibilityCompliant(): boolean;
|
45
47
|
set accessibilityCompliant(value: boolean);
|
@@ -1,5 +1,6 @@
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
2
2
|
import { CollectionEditorViewModel } from '@devexpress/analytics-core/property-grid/widgets/collectioneditor/_editor';
|
3
|
+
import { ViewModelChangedEvent } from '@devexpress/analytics-core/serializer/native/viewModels/viewModelGenerator';
|
3
4
|
import * as i0 from "@angular/core";
|
4
5
|
import * as i1 from "@angular/common";
|
5
6
|
import * as i2 from "devextreme-angular";
|
@@ -8,29 +9,33 @@ import * as i4 from "../../directives/dx-action.directive";
|
|
8
9
|
import * as i5 from "../../directives/accordion.directive";
|
9
10
|
import * as i6 from "../../directives/dx-mutation-observer.directive";
|
10
11
|
export class CollectionEditorComponent {
|
11
|
-
constructor() {
|
12
|
+
constructor(_changeDetectorRef) {
|
13
|
+
this._changeDetectorRef = _changeDetectorRef;
|
12
14
|
}
|
13
15
|
ngOnDestroy() {
|
16
|
+
this._vmSubscription && this._vmSubscription();
|
14
17
|
this._model.dispose();
|
15
18
|
}
|
16
19
|
ngOnInit() {
|
17
20
|
this._model = new CollectionEditorViewModel(this.options);
|
18
21
|
this.data = this._model.getViewModel();
|
22
|
+
this._vmSubscription = this.data
|
23
|
+
._viewModelEvents.on(ViewModelChangedEvent, () => this._changeDetectorRef.markForCheck());
|
19
24
|
}
|
20
25
|
onScrollViewInitialized(args) {
|
21
26
|
args.component.option('useKeyboard', false);
|
22
27
|
}
|
23
28
|
}
|
24
|
-
CollectionEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CollectionEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
29
|
+
CollectionEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CollectionEditorComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
25
30
|
CollectionEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CollectionEditorComponent, selector: "dxa-collectioneditor", inputs: { options: ["data", "options"], contentTemplate: "contentTemplate" }, ngImport: i0, template: "<div class=\"dx-collectioneditor\">\n <div [dxaAccordion]=\"data\" [dxMutationObserver]=\"data.keyboardHelper\">\n <div class=\"dx-collectioneditor-header dx-accordion-header\">\n <div class=\"dx-editor-header\">\n <div role=\"treeitem\"\n class=\"dx-field dx-accessibility-focus-border-accented dxrd-accessibility-accordion-trigger\"\n [attr.aria-expanded]=\"data.alwaysShow || !data.collapsed ? 'true' : 'false'\"\n [attr.aria-owns]=\"data.contentId\" [attr.id]=\"data.headerId\">\n <div *ngIf=\"data.showButtons\" class=\"dx-collectioneditor-actions-wrapper\">\n <dx-button *ngIf=\"data.buttons.up.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.up.action($event)\" [disabled]=\"data.buttons.up.disabled\"\n icon=\"dxrd-svg-operations-moveup\" iconClass=\"dx-image-moveup\"\n [template]=\"data.buttons.up.template\"\n [attr.title]=\"data.buttons.up.text\"></dx-button>\n <dx-button *ngIf=\"data.buttons.down.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.down.action($event)\" [disabled]=\"data.buttons.down.disabled\"\n icon=\"dxrd-svg-operations-movedown\" iconClass=\"dx-image-movedown\"\n [template]=\"data.buttons.down.template\"\n [attr.title]=\"data.buttons.down.text\"></dx-button>\n <div class=\"dx-collectioneditor-action-separator\"></div>\n <dx-button *ngIf=\"data.buttons.add.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.add.action($event)\" [disabled]=\"data.buttons.add.disabled\"\n [template]=\"data.buttons.add.template\"\n icon=\"dxrd-svg-operations-add\" iconClass=\"dx-image-add\"\n [attr.title]=\"data.buttons.add.text\"></dx-button>\n <dx-button *ngIf=\"data.buttons.delete.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.delete.action($event)\" [disabled]=\"data.buttons.delete.disabled\"\n [template]=\"data.buttons.delete.template\"\n icon=\"dxrd-svg-operations-remove\" iconClass=\"dx-image-remove\"\n [attr.title]=\"data.buttons.delete.text\"></dx-button>\n </div>\n <div *ngIf=\"!!data.displayName\" class=\"dx-collectioneditor-header-text dxd-text-primary\"\n [style.padding-left]=\"data.padding + 'px'\">\n <dxa-template class=\"dx-collapsing-image dxrd-display-inline-block\"\n template=\"dxrd-svg-collapsed\"\n [class.dx-image-expanded]=\"!data.collapsed \"></dxa-template>\n <div class=\"dx-group-header-font dxd-text-primary dxrd-display-inline-block\" [attr.title]=\"data.displayName\">\n {{data.displayName}}</div>\n </div>\n </div>\n </div>\n </div>\n <div role=\"group\" class=\"dx-accordion-content\"\n [attr.aria-hidden]=\"!data.alwaysShow && data.collapsed ? 'true' : 'false'\"\n [attr.aria-labelledby]=\"data.headerId\" [attr.id]=\"data.contentId\">\n <dx-scroll-view [hidden]=\"data.disabled\" showScrollbar=\"onHover\" [disabled]=\"!data.showScroll\"\n [useNative]=\"false\" [scrollByThumb]=\"true\" (onInitialized)=\"onScrollViewInitialized($event)\">\n <div *ngIf=\"data.values.length === 0\"\n class=\"dx-collectioneditor-empty dxd-empty-area-placeholder-text-color dxd-text-info\">\n <span class=\"dx-collectioneditor-empty-text\">{{data.emptyAreaText}}</span>\n </div>\n <div *ngIf=\"data.values.length !== 0\" class=\"dx-collectioneditor-items\">\n <div *ngFor=\"let value of data.values\"\n class=\"dx-collectioneditor-item-container dxd-button-back-color dxd-state-normal dxd-back-highlighted dx-accessibility-list-item dx-accessibility-focus-border-accented\"\n [attr.aria-selected]=\"value.selected\" [dxActionModel]=\"value\" [dxAction]=\"value.select\"\n [class.dxd-state-selected]=\"value.selected\">\n <div class=\"dx-collection-item\">\n <ng-container *ngTemplateOutlet=\"contentTemplate, context: { data: value }\"></ng-container>\n </div>\n </div>\n </div>\n </dx-scroll-view>\n </div>\n </div>\n</div>", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.DxButtonComponent, selector: "dx-button", inputs: ["accessKey", "activeStateEnabled", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "icon", "rtlEnabled", "stylingMode", "tabIndex", "template", "text", "type", "useSubmitBehavior", "validationGroup", "visible", "width"], outputs: ["onClick", "onContentReady", "onDisposing", "onInitialized", "onOptionChanged", "accessKeyChange", "activeStateEnabledChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "iconChange", "rtlEnabledChange", "stylingModeChange", "tabIndexChange", "templateChange", "textChange", "typeChange", "useSubmitBehaviorChange", "validationGroupChange", "visibleChange", "widthChange"] }, { kind: "component", type: i2.DxScrollViewComponent, selector: "dx-scroll-view", inputs: ["bounceEnabled", "direction", "disabled", "elementAttr", "height", "pulledDownText", "pullingDownText", "reachBottomText", "refreshingText", "rtlEnabled", "scrollByContent", "scrollByThumb", "showScrollbar", "useNative", "width"], outputs: ["onDisposing", "onInitialized", "onOptionChanged", "onPullDown", "onReachBottom", "onScroll", "onUpdated", "bounceEnabledChange", "directionChange", "disabledChange", "elementAttrChange", "heightChange", "pulledDownTextChange", "pullingDownTextChange", "reachBottomTextChange", "refreshingTextChange", "rtlEnabledChange", "scrollByContentChange", "scrollByThumbChange", "showScrollbarChange", "useNativeChange", "widthChange"] }, { kind: "component", type: i3.TemplateComponent, selector: "dxa-template", inputs: ["data", "template"] }, { kind: "directive", type: i4.DxActionDirective, selector: "[dxAction]", inputs: ["dxActionModel", "dxAction"] }, { kind: "directive", type: i5.AccordionDirective, selector: "[dxaAccordion]", inputs: ["dxaAccordion"] }, { kind: "directive", type: i6.DxMutationObserverDirective, selector: "[dxMutationObserver]", inputs: ["dxMutationObserver"] }] });
|
26
31
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CollectionEditorComponent, decorators: [{
|
27
32
|
type: Component,
|
28
33
|
args: [{ selector: 'dxa-collectioneditor', template: "<div class=\"dx-collectioneditor\">\n <div [dxaAccordion]=\"data\" [dxMutationObserver]=\"data.keyboardHelper\">\n <div class=\"dx-collectioneditor-header dx-accordion-header\">\n <div class=\"dx-editor-header\">\n <div role=\"treeitem\"\n class=\"dx-field dx-accessibility-focus-border-accented dxrd-accessibility-accordion-trigger\"\n [attr.aria-expanded]=\"data.alwaysShow || !data.collapsed ? 'true' : 'false'\"\n [attr.aria-owns]=\"data.contentId\" [attr.id]=\"data.headerId\">\n <div *ngIf=\"data.showButtons\" class=\"dx-collectioneditor-actions-wrapper\">\n <dx-button *ngIf=\"data.buttons.up.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.up.action($event)\" [disabled]=\"data.buttons.up.disabled\"\n icon=\"dxrd-svg-operations-moveup\" iconClass=\"dx-image-moveup\"\n [template]=\"data.buttons.up.template\"\n [attr.title]=\"data.buttons.up.text\"></dx-button>\n <dx-button *ngIf=\"data.buttons.down.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.down.action($event)\" [disabled]=\"data.buttons.down.disabled\"\n icon=\"dxrd-svg-operations-movedown\" iconClass=\"dx-image-movedown\"\n [template]=\"data.buttons.down.template\"\n [attr.title]=\"data.buttons.down.text\"></dx-button>\n <div class=\"dx-collectioneditor-action-separator\"></div>\n <dx-button *ngIf=\"data.buttons.add.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.add.action($event)\" [disabled]=\"data.buttons.add.disabled\"\n [template]=\"data.buttons.add.template\"\n icon=\"dxrd-svg-operations-add\" iconClass=\"dx-image-add\"\n [attr.title]=\"data.buttons.add.text\"></dx-button>\n <dx-button *ngIf=\"data.buttons.delete.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.delete.action($event)\" [disabled]=\"data.buttons.delete.disabled\"\n [template]=\"data.buttons.delete.template\"\n icon=\"dxrd-svg-operations-remove\" iconClass=\"dx-image-remove\"\n [attr.title]=\"data.buttons.delete.text\"></dx-button>\n </div>\n <div *ngIf=\"!!data.displayName\" class=\"dx-collectioneditor-header-text dxd-text-primary\"\n [style.padding-left]=\"data.padding + 'px'\">\n <dxa-template class=\"dx-collapsing-image dxrd-display-inline-block\"\n template=\"dxrd-svg-collapsed\"\n [class.dx-image-expanded]=\"!data.collapsed \"></dxa-template>\n <div class=\"dx-group-header-font dxd-text-primary dxrd-display-inline-block\" [attr.title]=\"data.displayName\">\n {{data.displayName}}</div>\n </div>\n </div>\n </div>\n </div>\n <div role=\"group\" class=\"dx-accordion-content\"\n [attr.aria-hidden]=\"!data.alwaysShow && data.collapsed ? 'true' : 'false'\"\n [attr.aria-labelledby]=\"data.headerId\" [attr.id]=\"data.contentId\">\n <dx-scroll-view [hidden]=\"data.disabled\" showScrollbar=\"onHover\" [disabled]=\"!data.showScroll\"\n [useNative]=\"false\" [scrollByThumb]=\"true\" (onInitialized)=\"onScrollViewInitialized($event)\">\n <div *ngIf=\"data.values.length === 0\"\n class=\"dx-collectioneditor-empty dxd-empty-area-placeholder-text-color dxd-text-info\">\n <span class=\"dx-collectioneditor-empty-text\">{{data.emptyAreaText}}</span>\n </div>\n <div *ngIf=\"data.values.length !== 0\" class=\"dx-collectioneditor-items\">\n <div *ngFor=\"let value of data.values\"\n class=\"dx-collectioneditor-item-container dxd-button-back-color dxd-state-normal dxd-back-highlighted dx-accessibility-list-item dx-accessibility-focus-border-accented\"\n [attr.aria-selected]=\"value.selected\" [dxActionModel]=\"value\" [dxAction]=\"value.select\"\n [class.dxd-state-selected]=\"value.selected\">\n <div class=\"dx-collection-item\">\n <ng-container *ngTemplateOutlet=\"contentTemplate, context: { data: value }\"></ng-container>\n </div>\n </div>\n </div>\n </dx-scroll-view>\n </div>\n </div>\n</div>" }]
|
29
|
-
}], ctorParameters: function () { return []; }, propDecorators: { options: [{
|
34
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { options: [{
|
30
35
|
type: Input,
|
31
36
|
args: ['data']
|
32
37
|
}], contentTemplate: [{
|
33
38
|
type: Input,
|
34
39
|
args: ['contentTemplate']
|
35
40
|
}] } });
|
36
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collectioneditor.component.js","sourceRoot":"","sources":["../../../../../../../../dx-report-viewer/components/analytics/properties/collectioneditor/collectioneditor.component.ts","../../../../../../../../dx-report-viewer/components/analytics/properties/collectioneditor/collectioneditor.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAkC,MAAM,eAAe,CAAC;AACjF,OAAO,EAAE,yBAAyB,EAAwD,MAAM,2EAA2E,CAAC;;;;;;;;AAM5K,MAAM,OAAO,yBAAyB;IAMlC;IACA,CAAC;IACD,WAAW;QACP,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;IAC1B,CAAC;IACD,QAAQ;QACJ,IAAI,CAAC,MAAM,GAAG,IAAI,yBAAyB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC1D,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;IAC3C,CAAC;IAED,uBAAuB,CAAC,IAAI;QACxB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;IAChD,CAAC;;uHAlBQ,yBAAyB;2GAAzB,yBAAyB,0ICPtC,qrKAoEM;4FD7DO,yBAAyB;kBAJrC,SAAS;+BACI,sBAAsB;0EAIjB,OAAO;sBAArB,KAAK;uBAAC,MAAM;gBACa,eAAe;sBAAxC,KAAK;uBAAC,iBAAiB","sourcesContent":["import { Component, Input, TemplateRef, OnInit, OnDestroy } from '@angular/core';\nimport { CollectionEditorViewModel, ICollectionEditorOptions, ICollectionEditorViewModel } from '@devexpress/analytics-core/property-grid/widgets/collectioneditor/_editor';\n\n@Component({\n    selector: 'dxa-collectioneditor',\n    templateUrl: './collectioneditor.component.html'\n})\nexport class CollectionEditorComponent implements OnInit, OnDestroy {\n    @Input('data') options!: ICollectionEditorOptions;\n    @Input('contentTemplate') contentTemplate: TemplateRef<any>;\n\n    data: ICollectionEditorViewModel;\n    private _model: CollectionEditorViewModel;\n    constructor() {\n    }\n    ngOnDestroy(): void {\n        this._model.dispose();\n    }\n    ngOnInit(): void {\n        this._model = new CollectionEditorViewModel(this.options);\n        this.data = this._model.getViewModel();\n    }\n\n    onScrollViewInitialized(args): void {\n        args.component.option('useKeyboard', false);\n    }\n\n}\n","<div class=\"dx-collectioneditor\">\n    <div [dxaAccordion]=\"data\" [dxMutationObserver]=\"data.keyboardHelper\">\n        <div class=\"dx-collectioneditor-header dx-accordion-header\">\n            <div class=\"dx-editor-header\">\n                <div role=\"treeitem\"\n                    class=\"dx-field dx-accessibility-focus-border-accented dxrd-accessibility-accordion-trigger\"\n                    [attr.aria-expanded]=\"data.alwaysShow || !data.collapsed ? 'true' : 'false'\"\n                    [attr.aria-owns]=\"data.contentId\" [attr.id]=\"data.headerId\">\n                    <div *ngIf=\"data.showButtons\" class=\"dx-collectioneditor-actions-wrapper\">\n                        <dx-button *ngIf=\"data.buttons.up.visible\"\n                            class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n                            (onClick)=\"data.buttons.up.action($event)\" [disabled]=\"data.buttons.up.disabled\"\n                            icon=\"dxrd-svg-operations-moveup\" iconClass=\"dx-image-moveup\"\n                            [template]=\"data.buttons.up.template\"\n                            [attr.title]=\"data.buttons.up.text\"></dx-button>\n                        <dx-button *ngIf=\"data.buttons.down.visible\"\n                            class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n                            (onClick)=\"data.buttons.down.action($event)\" [disabled]=\"data.buttons.down.disabled\"\n                            icon=\"dxrd-svg-operations-movedown\" iconClass=\"dx-image-movedown\"\n                            [template]=\"data.buttons.down.template\"\n                            [attr.title]=\"data.buttons.down.text\"></dx-button>\n                        <div class=\"dx-collectioneditor-action-separator\"></div>\n                        <dx-button *ngIf=\"data.buttons.add.visible\"\n                            class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n                            (onClick)=\"data.buttons.add.action($event)\" [disabled]=\"data.buttons.add.disabled\"\n                            [template]=\"data.buttons.add.template\"\n                            icon=\"dxrd-svg-operations-add\" iconClass=\"dx-image-add\"\n                            [attr.title]=\"data.buttons.add.text\"></dx-button>\n                        <dx-button *ngIf=\"data.buttons.delete.visible\"\n                            class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n                            (onClick)=\"data.buttons.delete.action($event)\" [disabled]=\"data.buttons.delete.disabled\"\n                            [template]=\"data.buttons.delete.template\"\n                            icon=\"dxrd-svg-operations-remove\" iconClass=\"dx-image-remove\"\n                            [attr.title]=\"data.buttons.delete.text\"></dx-button>\n                    </div>\n                    <div *ngIf=\"!!data.displayName\" class=\"dx-collectioneditor-header-text dxd-text-primary\"\n                        [style.padding-left]=\"data.padding + 'px'\">\n                        <dxa-template class=\"dx-collapsing-image dxrd-display-inline-block\"\n                            template=\"dxrd-svg-collapsed\"\n                            [class.dx-image-expanded]=\"!data.collapsed \"></dxa-template>\n                        <div class=\"dx-group-header-font dxd-text-primary dxrd-display-inline-block\" [attr.title]=\"data.displayName\">\n                            {{data.displayName}}</div>\n                    </div>\n                </div>\n            </div>\n        </div>\n        <div role=\"group\" class=\"dx-accordion-content\"\n            [attr.aria-hidden]=\"!data.alwaysShow && data.collapsed ? 'true' : 'false'\"\n            [attr.aria-labelledby]=\"data.headerId\" [attr.id]=\"data.contentId\">\n            <dx-scroll-view [hidden]=\"data.disabled\" showScrollbar=\"onHover\" [disabled]=\"!data.showScroll\"\n                [useNative]=\"false\" [scrollByThumb]=\"true\" (onInitialized)=\"onScrollViewInitialized($event)\">\n                <div *ngIf=\"data.values.length === 0\"\n                    class=\"dx-collectioneditor-empty dxd-empty-area-placeholder-text-color dxd-text-info\">\n                    <span class=\"dx-collectioneditor-empty-text\">{{data.emptyAreaText}}</span>\n                </div>\n                <div *ngIf=\"data.values.length !== 0\" class=\"dx-collectioneditor-items\">\n                    <div *ngFor=\"let value of data.values\"\n                        class=\"dx-collectioneditor-item-container dxd-button-back-color dxd-state-normal dxd-back-highlighted dx-accessibility-list-item dx-accessibility-focus-border-accented\"\n                        [attr.aria-selected]=\"value.selected\" [dxActionModel]=\"value\" [dxAction]=\"value.select\"\n                        [class.dxd-state-selected]=\"value.selected\">\n                        <div class=\"dx-collection-item\">\n                            <ng-container *ngTemplateOutlet=\"contentTemplate, context: { data: value }\"></ng-container>\n                        </div>\n                    </div>\n                </div>\n            </dx-scroll-view>\n        </div>\n    </div>\n</div>"]}
|
41
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"collectioneditor.component.js","sourceRoot":"","sources":["../../../../../../../../dx-report-viewer/components/analytics/properties/collectioneditor/collectioneditor.component.ts","../../../../../../../../dx-report-viewer/components/analytics/properties/collectioneditor/collectioneditor.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAqB,SAAS,EAAE,KAAK,EAAkC,MAAM,eAAe,CAAC;AACpG,OAAO,EAAE,yBAAyB,EAAwD,MAAM,2EAA2E,CAAC;AAC5K,OAAO,EAAsB,qBAAqB,EAAE,MAAM,4EAA4E,CAAC;;;;;;;;AAMvI,MAAM,OAAO,yBAAyB;IAOlC,YAAoB,kBAAqC;QAArC,uBAAkB,GAAlB,kBAAkB,CAAmB;IACzD,CAAC;IACD,WAAW;QACP,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;QAC/C,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;IAC1B,CAAC;IACD,QAAQ;QACJ,IAAI,CAAC,MAAM,GAAG,IAAI,yBAAyB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC1D,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;QACvC,IAAI,CAAC,eAAe,GAAI,IAAI,CAAC,IAAuD;aAC/E,gBAAgB,CAAC,EAAE,CAAC,qBAAqB,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC,CAAC;IAClG,CAAC;IAED,uBAAuB,CAAC,IAAI;QACxB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;IAChD,CAAC;;uHAtBQ,yBAAyB;2GAAzB,yBAAyB,0ICRtC,qrKAoEM;4FD5DO,yBAAyB;kBAJrC,SAAS;+BACI,sBAAsB;wGAIjB,OAAO;sBAArB,KAAK;uBAAC,MAAM;gBACa,eAAe;sBAAxC,KAAK;uBAAC,iBAAiB","sourcesContent":["import { ChangeDetectorRef, Component, Input, TemplateRef, OnInit, OnDestroy } from '@angular/core';\nimport { CollectionEditorViewModel, ICollectionEditorOptions, ICollectionEditorViewModel } from '@devexpress/analytics-core/property-grid/widgets/collectioneditor/_editor';\nimport { EventManagerHolder, ViewModelChangedEvent } from '@devexpress/analytics-core/serializer/native/viewModels/viewModelGenerator';\n\n@Component({\n    selector: 'dxa-collectioneditor',\n    templateUrl: './collectioneditor.component.html'\n})\nexport class CollectionEditorComponent implements OnInit, OnDestroy {\n    @Input('data') options!: ICollectionEditorOptions;\n    @Input('contentTemplate') contentTemplate: TemplateRef<any>;\n\n    data: ICollectionEditorViewModel;\n    private _vmSubscription: () => void;\n    private _model: CollectionEditorViewModel;\n    constructor(private _changeDetectorRef: ChangeDetectorRef) {\n    }\n    ngOnDestroy(): void {\n        this._vmSubscription && this._vmSubscription();\n        this._model.dispose();\n    }\n    ngOnInit(): void {\n        this._model = new CollectionEditorViewModel(this.options);\n        this.data = this._model.getViewModel();\n        this._vmSubscription = (this.data as EventManagerHolder<ICollectionEditorViewModel>)\n            ._viewModelEvents.on(ViewModelChangedEvent, () => this._changeDetectorRef.markForCheck());\n    }\n\n    onScrollViewInitialized(args): void {\n        args.component.option('useKeyboard', false);\n    }\n\n}\n","<div class=\"dx-collectioneditor\">\n    <div [dxaAccordion]=\"data\" [dxMutationObserver]=\"data.keyboardHelper\">\n        <div class=\"dx-collectioneditor-header dx-accordion-header\">\n            <div class=\"dx-editor-header\">\n                <div role=\"treeitem\"\n                    class=\"dx-field dx-accessibility-focus-border-accented dxrd-accessibility-accordion-trigger\"\n                    [attr.aria-expanded]=\"data.alwaysShow || !data.collapsed ? 'true' : 'false'\"\n                    [attr.aria-owns]=\"data.contentId\" [attr.id]=\"data.headerId\">\n                    <div *ngIf=\"data.showButtons\" class=\"dx-collectioneditor-actions-wrapper\">\n                        <dx-button *ngIf=\"data.buttons.up.visible\"\n                            class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n                            (onClick)=\"data.buttons.up.action($event)\" [disabled]=\"data.buttons.up.disabled\"\n                            icon=\"dxrd-svg-operations-moveup\" iconClass=\"dx-image-moveup\"\n                            [template]=\"data.buttons.up.template\"\n                            [attr.title]=\"data.buttons.up.text\"></dx-button>\n                        <dx-button *ngIf=\"data.buttons.down.visible\"\n                            class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n                            (onClick)=\"data.buttons.down.action($event)\" [disabled]=\"data.buttons.down.disabled\"\n                            icon=\"dxrd-svg-operations-movedown\" iconClass=\"dx-image-movedown\"\n                            [template]=\"data.buttons.down.template\"\n                            [attr.title]=\"data.buttons.down.text\"></dx-button>\n                        <div class=\"dx-collectioneditor-action-separator\"></div>\n                        <dx-button *ngIf=\"data.buttons.add.visible\"\n                            class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n                            (onClick)=\"data.buttons.add.action($event)\" [disabled]=\"data.buttons.add.disabled\"\n                            [template]=\"data.buttons.add.template\"\n                            icon=\"dxrd-svg-operations-add\" iconClass=\"dx-image-add\"\n                            [attr.title]=\"data.buttons.add.text\"></dx-button>\n                        <dx-button *ngIf=\"data.buttons.delete.visible\"\n                            class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n                            (onClick)=\"data.buttons.delete.action($event)\" [disabled]=\"data.buttons.delete.disabled\"\n                            [template]=\"data.buttons.delete.template\"\n                            icon=\"dxrd-svg-operations-remove\" iconClass=\"dx-image-remove\"\n                            [attr.title]=\"data.buttons.delete.text\"></dx-button>\n                    </div>\n                    <div *ngIf=\"!!data.displayName\" class=\"dx-collectioneditor-header-text dxd-text-primary\"\n                        [style.padding-left]=\"data.padding + 'px'\">\n                        <dxa-template class=\"dx-collapsing-image dxrd-display-inline-block\"\n                            template=\"dxrd-svg-collapsed\"\n                            [class.dx-image-expanded]=\"!data.collapsed \"></dxa-template>\n                        <div class=\"dx-group-header-font dxd-text-primary dxrd-display-inline-block\" [attr.title]=\"data.displayName\">\n                            {{data.displayName}}</div>\n                    </div>\n                </div>\n            </div>\n        </div>\n        <div role=\"group\" class=\"dx-accordion-content\"\n            [attr.aria-hidden]=\"!data.alwaysShow && data.collapsed ? 'true' : 'false'\"\n            [attr.aria-labelledby]=\"data.headerId\" [attr.id]=\"data.contentId\">\n            <dx-scroll-view [hidden]=\"data.disabled\" showScrollbar=\"onHover\" [disabled]=\"!data.showScroll\"\n                [useNative]=\"false\" [scrollByThumb]=\"true\" (onInitialized)=\"onScrollViewInitialized($event)\">\n                <div *ngIf=\"data.values.length === 0\"\n                    class=\"dx-collectioneditor-empty dxd-empty-area-placeholder-text-color dxd-text-info\">\n                    <span class=\"dx-collectioneditor-empty-text\">{{data.emptyAreaText}}</span>\n                </div>\n                <div *ngIf=\"data.values.length !== 0\" class=\"dx-collectioneditor-items\">\n                    <div *ngFor=\"let value of data.values\"\n                        class=\"dx-collectioneditor-item-container dxd-button-back-color dxd-state-normal dxd-back-highlighted dx-accessibility-list-item dx-accessibility-focus-border-accented\"\n                        [attr.aria-selected]=\"value.selected\" [dxActionModel]=\"value\" [dxAction]=\"value.select\"\n                        [class.dxd-state-selected]=\"value.selected\">\n                        <div class=\"dx-collection-item\">\n                            <ng-container *ngTemplateOutlet=\"contentTemplate, context: { data: value }\"></ng-container>\n                        </div>\n                    </div>\n                </div>\n            </dx-scroll-view>\n        </div>\n    </div>\n</div>"]}
|
@@ -2,52 +2,61 @@ import { Component, Input } from '@angular/core';
|
|
2
2
|
import { createDateRangeEditor } from 'devexpress-reporting/viewer/widgets/dateRange/dateRangeEditor';
|
3
3
|
import { generateIconTemplate } from '@devexpress/analytics-core/core/widgets/_generateIconTemplate';
|
4
4
|
import { KeyboardEnum } from '@devexpress/analytics-core/property-grid/widgets/internal/_utils';
|
5
|
+
import { ViewModelChangedEvent } from '@devexpress/analytics-core/serializer/native/viewModels/viewModelGenerator';
|
5
6
|
import * as i0 from "@angular/core";
|
6
7
|
import * as i1 from "devextreme-angular/ui/nested";
|
7
8
|
import * as i2 from "devextreme-angular";
|
8
9
|
import * as i3 from "../../../analytics/template/template.component";
|
9
10
|
export class DateRangeComponent {
|
10
|
-
constructor(_currentElement) {
|
11
|
+
constructor(_currentElement, _changeDetectorRef) {
|
11
12
|
this._currentElement = _currentElement;
|
13
|
+
this._changeDetectorRef = _changeDetectorRef;
|
12
14
|
}
|
13
15
|
ngOnDestroy() {
|
16
|
+
this._vmSubscription && this._vmSubscription();
|
14
17
|
this._editor.dispose();
|
15
18
|
}
|
16
19
|
ngOnInit() {
|
17
20
|
this._editor = createDateRangeEditor(this.options, this._currentElement.nativeElement, this.options);
|
18
21
|
this.data = this._editor.getViewModel();
|
22
|
+
this._vmSubscription = this.data._viewModelEvents.on(ViewModelChangedEvent, () => {
|
23
|
+
this._changeDetectorRef.markForCheck();
|
24
|
+
});
|
19
25
|
this.data.cacheElement(this._currentElement.nativeElement);
|
26
|
+
const processClickEvent = () => {
|
27
|
+
this.data.showPopup();
|
28
|
+
this._changeDetectorRef.markForCheck();
|
29
|
+
};
|
20
30
|
const processKeyBoardEvent = (e) => {
|
21
31
|
if (e.key == KeyboardEnum.Enter || (e.key == KeyboardEnum.ArrowDown && e.altKey)) {
|
22
32
|
this.data.showPopup();
|
33
|
+
this._changeDetectorRef.markForCheck();
|
23
34
|
}
|
24
35
|
};
|
25
36
|
this.subscribeToEvents = (event) => {
|
26
37
|
this.textBoxInputElement = event.element.querySelector('.dx-texteditor-input');
|
27
|
-
this.textBoxInputElement?.addEventListener('click',
|
38
|
+
this.textBoxInputElement?.addEventListener('click', processClickEvent);
|
28
39
|
this.textBoxInputElement?.addEventListener('keydown', processKeyBoardEvent);
|
29
40
|
};
|
30
41
|
this.unsubscribeFromEvents = () => {
|
31
|
-
this.textBoxInputElement?.removeEventListener('click',
|
42
|
+
this.textBoxInputElement?.removeEventListener('click', processClickEvent);
|
32
43
|
this.textBoxInputElement?.removeEventListener('keydown', processKeyBoardEvent);
|
33
44
|
};
|
34
45
|
this.showPopupOptions = {
|
35
46
|
disabled: false,
|
36
|
-
onClick:
|
37
|
-
this.data.showPopup();
|
38
|
-
},
|
47
|
+
onClick: processClickEvent,
|
39
48
|
template: generateIconTemplate('dx-ellipsis-image'),
|
40
49
|
icon: 'dxrd-svg-ellipsis'
|
41
50
|
};
|
42
51
|
}
|
43
52
|
}
|
44
|
-
DateRangeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateRangeComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
53
|
+
DateRangeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateRangeComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
45
54
|
DateRangeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DateRangeComponent, selector: "dxv-date-range", inputs: { options: ["data", "options"] }, ngImport: i0, template: "<div class=\"dxrv-daterange-editor\">\n <dx-text-box \n [value]=\"data.displayValue\"\n [readOnly]=\"true\"\n (onContentReady)=\"subscribeToEvents($event)\" (onDisposing)=\"unsubscribeFromEvents()\"\n >\n <dxi-button\n name=\"showPopup\"\n location=\"after\"\n [options]=\"showPopupOptions\"\n ></dxi-button>\n </dx-text-box>\n <dxa-template [template]=\"data.popupTemplate\" [data]=\"data.popupModel\"></dxa-template>\n</div>", dependencies: [{ kind: "component", type: i1.DxiButtonComponent, selector: "dxi-button", inputs: ["location", "name", "options", "cssClass", "disabled", "hint", "icon", "onClick", "template", "text", "visible"] }, { kind: "component", type: i2.DxTextBoxComponent, selector: "dx-text-box", inputs: ["accessKey", "activeStateEnabled", "buttons", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "inputAttr", "isDirty", "isValid", "label", "labelMode", "mask", "maskChar", "maskInvalidMessage", "maskRules", "maxLength", "mode", "name", "placeholder", "readOnly", "rtlEnabled", "showClearButton", "showMaskMode", "spellcheck", "stylingMode", "tabIndex", "text", "useMaskedValue", "validationError", "validationErrors", "validationMessageMode", "validationMessagePosition", "validationStatus", "value", "valueChangeEvent", "visible", "width"], outputs: ["onChange", "onContentReady", "onCopy", "onCut", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onKeyDown", "onKeyUp", "onOptionChanged", "onPaste", "onValueChanged", "accessKeyChange", "activeStateEnabledChange", "buttonsChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isDirtyChange", "isValidChange", "labelChange", "labelModeChange", "maskChange", "maskCharChange", "maskInvalidMessageChange", "maskRulesChange", "maxLengthChange", "modeChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "showClearButtonChange", "showMaskModeChange", "spellcheckChange", "stylingModeChange", "tabIndexChange", "textChange", "useMaskedValueChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationMessagePositionChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "component", type: i3.TemplateComponent, selector: "dxa-template", inputs: ["data", "template"] }] });
|
46
55
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateRangeComponent, decorators: [{
|
47
56
|
type: Component,
|
48
57
|
args: [{ selector: 'dxv-date-range', template: "<div class=\"dxrv-daterange-editor\">\n <dx-text-box \n [value]=\"data.displayValue\"\n [readOnly]=\"true\"\n (onContentReady)=\"subscribeToEvents($event)\" (onDisposing)=\"unsubscribeFromEvents()\"\n >\n <dxi-button\n name=\"showPopup\"\n location=\"after\"\n [options]=\"showPopupOptions\"\n ></dxi-button>\n </dx-text-box>\n <dxa-template [template]=\"data.popupTemplate\" [data]=\"data.popupModel\"></dxa-template>\n</div>" }]
|
49
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { options: [{
|
58
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { options: [{
|
50
59
|
type: Input,
|
51
60
|
args: ['data']
|
52
61
|
}] } });
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
62
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-range.component.js","sourceRoot":"","sources":["../../../../../../../../dx-report-viewer/components/reporting/parameterspanel/date-range/date-range.component.ts","../../../../../../../../dx-report-viewer/components/reporting/parameterspanel/date-range/date-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ElementRef, Input, OnInit, OnDestroy } from '@angular/core';\nimport { Properties } from 'devextreme/ui/button';\nimport { createDateRangeEditor, DateRangeEditor, IDateRangeEditorOptions } from 'devexpress-reporting/viewer/widgets/dateRange/dateRangeEditor';\nimport { IDateRangeEditorViewModel } from 'devexpress-reporting/viewer/widgets/dateRange/dateRangeEditor.viewmodel';\nimport { generateIconTemplate } from '@devexpress/analytics-core/core/widgets/_generateIconTemplate';\nimport { KeyboardEnum } from '@devexpress/analytics-core/property-grid/widgets/internal/_utils';\nimport { IEditorViewModel } from '@devexpress/analytics-core/analytics-widgets-native';\nimport { EventManagerHolder, ViewModelChangedEvent } from '@devexpress/analytics-core/serializer/native/viewModels/viewModelGenerator';\n\n@Component({\n    selector: 'dxv-date-range',\n    templateUrl: './date-range.component.html'\n})\nexport class DateRangeComponent implements OnInit, OnDestroy {\n    @Input('data') options: IDateRangeEditorOptions;\n    private _editor: DateRangeEditor;\n\n    data: IDateRangeEditorViewModel;\n    private _vmSubscription: () => void;\n    showPopupOptions: Properties;\n    textBoxInputElement: HTMLElement;\n    subscribeToEvents: (event) => void;\n    unsubscribeFromEvents: () => void;\n    constructor(private _currentElement: ElementRef<any>, private _changeDetectorRef: ChangeDetectorRef) {}\n    ngOnDestroy(): void {\n        this._vmSubscription && this._vmSubscription();\n        this._editor.dispose();\n    }\n    ngOnInit(): void {\n        this._editor = createDateRangeEditor(this.options, this._currentElement.nativeElement, this.options as IEditorViewModel);\n        this.data = this._editor.getViewModel();\n        this._vmSubscription = (this.data as EventManagerHolder<IDateRangeEditorViewModel>)._viewModelEvents.on(ViewModelChangedEvent, () => {\n            this._changeDetectorRef.markForCheck();\n        });\n        this.data.cacheElement(this._currentElement.nativeElement);\n        const processClickEvent = () => {\n            this.data.showPopup();\n            this._changeDetectorRef.markForCheck();\n        };\n        const processKeyBoardEvent = (e: KeyboardEvent) => {\n            if(e.key == KeyboardEnum.Enter || (e.key == KeyboardEnum.ArrowDown && e.altKey)) {\n                this.data.showPopup();\n                this._changeDetectorRef.markForCheck();\n            }\n        };\n        this.subscribeToEvents = (event) => {\n            this.textBoxInputElement = event.element.querySelector('.dx-texteditor-input');\n            this.textBoxInputElement?.addEventListener('click', processClickEvent);\n            this.textBoxInputElement?.addEventListener('keydown', processKeyBoardEvent);\n        };\n        this.unsubscribeFromEvents = () => {\n            this.textBoxInputElement?.removeEventListener('click', processClickEvent);\n            this.textBoxInputElement?.removeEventListener('keydown', processKeyBoardEvent);\n        };\n        this.showPopupOptions = {\n            disabled: false,\n            onClick: processClickEvent,\n            template: generateIconTemplate('dx-ellipsis-image'),\n            icon: 'dxrd-svg-ellipsis'\n        } as any;\n    }\n}\n","<div class=\"dxrv-daterange-editor\">\n    <dx-text-box \n        [value]=\"data.displayValue\"\n        [readOnly]=\"true\"\n        (onContentReady)=\"subscribeToEvents($event)\" (onDisposing)=\"unsubscribeFromEvents()\"\n        >\n        <dxi-button\n          name=\"showPopup\"\n          location=\"after\"\n          [options]=\"showPopupOptions\"\n        ></dxi-button>\n    </dx-text-box>\n    <dxa-template [template]=\"data.popupTemplate\" [data]=\"data.popupModel\"></dxa-template>\n</div>"]}
|
@@ -13,6 +13,7 @@ import '@devexpress/analytics-core/dx-analytics-core-svg-templates';
|
|
13
13
|
import 'devexpress-reporting/dx-reporting-svg-templates';
|
14
14
|
import { JSReportViewerBinding } from 'devexpress-reporting/viewer/binding/jsReportViewerBinding';
|
15
15
|
import { AccessibilitySettings } from './utils/accessibility-settings';
|
16
|
+
import { ViewModelChangedEvent } from '@devexpress/analytics-core/serializer/native/viewModels/viewModelGenerator';
|
16
17
|
import * as i0 from "@angular/core";
|
17
18
|
import * as i1 from "./utils/accessibility-settings";
|
18
19
|
import * as i2 from "@angular/common";
|
@@ -58,18 +59,26 @@ export class DxReportViewerComponent extends DxReportingComponent {
|
|
58
59
|
super.ngAfterViewInit();
|
59
60
|
this.model = this._binding.sender;
|
60
61
|
this.viewModel = this.model.GetPreviewModel()?.getViewModel();
|
62
|
+
this._disposeViewModelChangedSubscription = this._subscribeToViewModelChanged(this.viewModel);
|
61
63
|
this._disposableCallback = this.model.events.on('propertyChanged', (args) => {
|
62
64
|
if (args.propertyName === 'previewModel') {
|
63
65
|
this.viewModel = this.model.GetPreviewModel().getViewModel();
|
66
|
+
this._disposeViewModelChangedSubscription && this._disposeViewModelChangedSubscription();
|
67
|
+
this._disposeViewModelChangedSubscription = this._subscribeToViewModelChanged(this.viewModel);
|
64
68
|
}
|
65
69
|
});
|
66
70
|
this._cd.detectChanges();
|
67
71
|
}
|
68
72
|
ngOnDestroy() {
|
69
73
|
this._disposableCallback && this._disposableCallback();
|
74
|
+
this._disposeViewModelChangedSubscription && this._disposeViewModelChangedSubscription();
|
70
75
|
this._binding.dispose();
|
71
76
|
super.ngOnDestroy();
|
72
77
|
}
|
78
|
+
_subscribeToViewModelChanged(viewModel) {
|
79
|
+
const eventHolder = viewModel;
|
80
|
+
return eventHolder?._viewModelEvents?.on(ViewModelChangedEvent, () => this._cd.markForCheck());
|
81
|
+
}
|
73
82
|
get accessibilityCompliant() {
|
74
83
|
return this._accessibilitySettings.accessibilityCompliant;
|
75
84
|
}
|
@@ -140,4 +149,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
140
149
|
}], reportUrl: [{
|
141
150
|
type: Input
|
142
151
|
}] } });
|
143
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dx-report-viewer.component.js","sourceRoot":"","sources":["../../../../dx-report-viewer/dx-report-viewer.component.ts","../../../../dx-report-viewer/dx-report-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ContentChild, ElementRef, Inject, Input, PLATFORM_ID, Renderer2, ViewChild } from '@angular/core';\n\nimport { DxReportingComponent, _booleanConverter, _inputConverter } from 'devexpress-reporting-angular/core';\n\nimport { DxReportViewerCallbacksComponent } from './dxrv-callbacks';\nimport { DxReportViewerRequestOptionsComponent } from './dxrv-request-options';\n\nimport { DxReportViewerExportSettingsComponent } from './dxrv-export-settings.component';\nimport { DxReportViewerMobileModeSettingsComponent } from './dxrv-mobile-mode-settings.component';\nimport { DxReportViewerProgressBarSettingsComponent } from './dxrv-progressbar-settings.component';\nimport { DxReportViewerRemoteSettingsComponent } from './dxrv-remote-settings.component';\nimport { DxReportViewerTabPanelSettingsComponent } from './dxrv-tabpanel-settings.component';\nimport { DxReportViewerSearchSettingsComponent } from './dxrv-search-settings.component';\n\nimport '@devexpress/analytics-core/dx-analytics-core-svg-templates';\nimport 'devexpress-reporting/dx-reporting-svg-templates';\nimport { IReportViewerOptions, JSReportViewerBinding } from 'devexpress-reporting/viewer/binding/jsReportViewerBinding';\nimport { IPreviewViewModel, PreviewDisposableModel } from 'devexpress-reporting/viewer/internal/_previewModel';\nimport { JSReportViewer } from 'devexpress-reporting/viewer/binding/jsReportViewer';\nimport { AccessibilitySettings } from './utils/accessibility-settings';\n\n @Component({\n     selector: 'dx-report-viewer',\n     templateUrl: './dx-report-viewer.component.html',\n     styleUrls: [],\n     providers: [AccessibilitySettings]\n })\nexport class DxReportViewerComponent extends DxReportingComponent {\n   private _reportUrl: string = '';\n   private _disposableCallback: () => void;\n   viewModel: IPreviewViewModel;\n   model: JSReportViewer;\n   protected _binding: JSReportViewerBinding;\n   bindingSender: JSReportViewer;\n\n   @ContentChild(DxReportViewerRequestOptionsComponent)\n   requestOptionsComponent: DxReportViewerRequestOptionsComponent;\n\n   @ContentChild(DxReportViewerCallbacksComponent)\n   callbacksComponent: DxReportViewerCallbacksComponent;\n\n   @ContentChild(DxReportViewerMobileModeSettingsComponent)\n   mobileModeSettingsComponent: DxReportViewerMobileModeSettingsComponent;\n\n   @ContentChild(DxReportViewerRemoteSettingsComponent)\n   remoteSettingsComponent: DxReportViewerRemoteSettingsComponent;\n\n   @ContentChild(DxReportViewerTabPanelSettingsComponent)\n   tabPanelSettingsComponent: DxReportViewerTabPanelSettingsComponent;\n\n   @ContentChild(DxReportViewerProgressBarSettingsComponent)\n   progressBarSettingsComponent: DxReportViewerProgressBarSettingsComponent;\n\n   @ContentChild(DxReportViewerExportSettingsComponent)\n   exportSettingsComponent: DxReportViewerExportSettingsComponent;\n\n   @ContentChild(DxReportViewerSearchSettingsComponent)\n   searchSettingsComponent: DxReportViewerSearchSettingsComponent;\n\n   constructor(renderer: Renderer2, @Inject(PLATFORM_ID) platformId: Object, private _viewer: ElementRef, private _cd: ChangeDetectorRef, private _accessibilitySettings: AccessibilitySettings) {\n       super(renderer, platformId);\n   }\n\n   getKoBinding(options: IReportViewerOptions): JSReportViewerBinding {\n       return new JSReportViewerBinding(options, this.getEventRaiser(), false);\n   }\n   getCallbacks(): DxReportViewerCallbacksComponent {\n       return this.callbacksComponent;\n   }\n   getControlOptions(): IReportViewerOptions {\n       return {\n           rtl: this.rtl,\n           developmentMode: this.developmentMode,\n           isMobile: this.isMobile,\n           accessibilityCompliant: this.accessibilityCompliant,\n           reportUrl: this._reportUrl,\n           requestOptions: this.requestOptionsComponent,\n           mobileModeSettings: this.mobileModeSettingsComponent,\n           remoteSettings: this.remoteSettingsComponent,\n           tabPanelSettings: this.tabPanelSettingsComponent,\n           progressBarSettings: this.progressBarSettingsComponent,\n           exportSettings: this.exportSettingsComponent,\n           keepReportOnComponentDisposal: this.keepReportOnComponentDisposal,\n           searchSettings: this.searchSettingsComponent,\n           callbacks: {}\n       };\n   }\n\n   GetPreviewModel(): PreviewDisposableModel {\n       return this.bindingSender.GetPreviewModel();\n   }\n\n   ngAfterViewInit(): void {\n       super.ngAfterViewInit();\n       this.model = this._binding.sender;\n       this.viewModel = this.model.GetPreviewModel()?.getViewModel() as IPreviewViewModel;\n       this._disposableCallback = this.model.events.on('propertyChanged', (args) => {\n           if(args.propertyName === 'previewModel') {\n               this.viewModel = this.model.GetPreviewModel().getViewModel() as IPreviewViewModel;\n           }\n       });\n       this._cd.detectChanges();\n   }\n\n   ngOnDestroy(): void {\n       this._disposableCallback && this._disposableCallback();\n       this._binding.dispose();\n       super.ngOnDestroy();\n   }\n\n   @Input()\n   @_inputConverter(_booleanConverter)\n   isMobile: boolean;\n\n   @Input()\n   @_inputConverter(_booleanConverter)\n   get accessibilityCompliant(): boolean {\n       return this._accessibilitySettings.accessibilityCompliant;\n   }\n   set accessibilityCompliant(value: boolean) {\n       this._accessibilitySettings.accessibilityCompliant = value;\n   }\n\n   @Input()\n   @_inputConverter(_booleanConverter)\n   keepReportOnComponentDisposal: boolean;\n   @Input()\n   @_inputConverter(_booleanConverter)\n   rtl: boolean;\n\n   @Input()\n   get reportUrl(): string {\n       return this._reportUrl;\n   }\n   set reportUrl(reportUrl: string) {\n       this._reportUrl = reportUrl;\n       if(this.bindingSender) this.bindingSender.OpenReport(reportUrl);\n   }\n}\n","<div #control [ngClass]=\"cssClass\" [ngStyle]=\"{'width': width, 'height': height }\">\n  <dxa-templates></dxa-templates>\n  <dxv-templates></dxv-templates>\n  <div class=\"dx-designer\">\n      <dxa-template *ngIf=\"!!viewModel\" template=\"dx-designer\" [data]=\"viewModel\"></dxa-template>\n  </div>\n</div>"]}
|
152
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dx-report-viewer.component.js","sourceRoot":"","sources":["../../../../dx-report-viewer/dx-report-viewer.component.ts","../../../../dx-report-viewer/dx-report-viewer.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, ContentChild, ElementRef, Inject, Input, PLATFORM_ID, Renderer2, ViewChild } from '@angular/core';\n\nimport { DxReportingComponent, _booleanConverter, _inputConverter } from 'devexpress-reporting-angular/core';\n\nimport { DxReportViewerCallbacksComponent } from './dxrv-callbacks';\nimport { DxReportViewerRequestOptionsComponent } from './dxrv-request-options';\n\nimport { DxReportViewerExportSettingsComponent } from './dxrv-export-settings.component';\nimport { DxReportViewerMobileModeSettingsComponent } from './dxrv-mobile-mode-settings.component';\nimport { DxReportViewerProgressBarSettingsComponent } from './dxrv-progressbar-settings.component';\nimport { DxReportViewerRemoteSettingsComponent } from './dxrv-remote-settings.component';\nimport { DxReportViewerTabPanelSettingsComponent } from './dxrv-tabpanel-settings.component';\nimport { DxReportViewerSearchSettingsComponent } from './dxrv-search-settings.component';\n\nimport '@devexpress/analytics-core/dx-analytics-core-svg-templates';\nimport 'devexpress-reporting/dx-reporting-svg-templates';\nimport { IReportViewerOptions, JSReportViewerBinding } from 'devexpress-reporting/viewer/binding/jsReportViewerBinding';\nimport { IPreviewViewModel, PreviewDisposableModel } from 'devexpress-reporting/viewer/internal/_previewModel';\nimport { JSReportViewer } from 'devexpress-reporting/viewer/binding/jsReportViewer';\nimport { AccessibilitySettings } from './utils/accessibility-settings';\nimport { EventManagerHolder, ViewModelChangedEvent } from '@devexpress/analytics-core/serializer/native/viewModels/viewModelGenerator';\n\n @Component({\n     selector: 'dx-report-viewer',\n     templateUrl: './dx-report-viewer.component.html',\n     styleUrls: [],\n     providers: [AccessibilitySettings]\n })\nexport class DxReportViewerComponent extends DxReportingComponent {\n   private _reportUrl: string = '';\n   private _disposableCallback: () => void;\n   private _disposeViewModelChangedSubscription: () => void;\n   viewModel: IPreviewViewModel;\n   model: JSReportViewer;\n   protected _binding: JSReportViewerBinding;\n   bindingSender: JSReportViewer;\n\n   @ContentChild(DxReportViewerRequestOptionsComponent)\n   requestOptionsComponent: DxReportViewerRequestOptionsComponent;\n\n   @ContentChild(DxReportViewerCallbacksComponent)\n   callbacksComponent: DxReportViewerCallbacksComponent;\n\n   @ContentChild(DxReportViewerMobileModeSettingsComponent)\n   mobileModeSettingsComponent: DxReportViewerMobileModeSettingsComponent;\n\n   @ContentChild(DxReportViewerRemoteSettingsComponent)\n   remoteSettingsComponent: DxReportViewerRemoteSettingsComponent;\n\n   @ContentChild(DxReportViewerTabPanelSettingsComponent)\n   tabPanelSettingsComponent: DxReportViewerTabPanelSettingsComponent;\n\n   @ContentChild(DxReportViewerProgressBarSettingsComponent)\n   progressBarSettingsComponent: DxReportViewerProgressBarSettingsComponent;\n\n   @ContentChild(DxReportViewerExportSettingsComponent)\n   exportSettingsComponent: DxReportViewerExportSettingsComponent;\n\n   @ContentChild(DxReportViewerSearchSettingsComponent)\n   searchSettingsComponent: DxReportViewerSearchSettingsComponent;\n\n   constructor(renderer: Renderer2, @Inject(PLATFORM_ID) platformId: Object, private _viewer: ElementRef, private _cd: ChangeDetectorRef, private _accessibilitySettings: AccessibilitySettings) {\n       super(renderer, platformId);\n   }\n\n   getKoBinding(options: IReportViewerOptions): JSReportViewerBinding {\n       return new JSReportViewerBinding(options, this.getEventRaiser(), false);\n   }\n   getCallbacks(): DxReportViewerCallbacksComponent {\n       return this.callbacksComponent;\n   }\n   getControlOptions(): IReportViewerOptions {\n       return {\n           rtl: this.rtl,\n           developmentMode: this.developmentMode,\n           isMobile: this.isMobile,\n           accessibilityCompliant: this.accessibilityCompliant,\n           reportUrl: this._reportUrl,\n           requestOptions: this.requestOptionsComponent,\n           mobileModeSettings: this.mobileModeSettingsComponent,\n           remoteSettings: this.remoteSettingsComponent,\n           tabPanelSettings: this.tabPanelSettingsComponent,\n           progressBarSettings: this.progressBarSettingsComponent,\n           exportSettings: this.exportSettingsComponent,\n           keepReportOnComponentDisposal: this.keepReportOnComponentDisposal,\n           searchSettings: this.searchSettingsComponent,\n           callbacks: {}\n       };\n   }\n\n   GetPreviewModel(): PreviewDisposableModel {\n       return this.bindingSender.GetPreviewModel();\n   }\n\n   ngAfterViewInit(): void {\n       super.ngAfterViewInit();\n       this.model = this._binding.sender;\n       this.viewModel = this.model.GetPreviewModel()?.getViewModel() as IPreviewViewModel;\n       this._disposeViewModelChangedSubscription = this._subscribeToViewModelChanged(this.viewModel);\n\n       this._disposableCallback = this.model.events.on('propertyChanged', (args) => {\n           if(args.propertyName === 'previewModel') {\n               this.viewModel = this.model.GetPreviewModel().getViewModel() as IPreviewViewModel;\n               this._disposeViewModelChangedSubscription && this._disposeViewModelChangedSubscription();\n               this._disposeViewModelChangedSubscription = this._subscribeToViewModelChanged(this.viewModel);\n           }\n       });\n       this._cd.detectChanges();\n   }\n\n   ngOnDestroy(): void {\n       this._disposableCallback && this._disposableCallback();\n       this._disposeViewModelChangedSubscription && this._disposeViewModelChangedSubscription();\n       this._binding.dispose();\n       super.ngOnDestroy();\n   }\n\n   private _subscribeToViewModelChanged(viewModel: IPreviewViewModel) {\n       const eventHolder = <EventManagerHolder<IPreviewViewModel>> viewModel;\n       return eventHolder?._viewModelEvents?.on(ViewModelChangedEvent, () => this._cd.markForCheck());\n   }\n\n   @Input()\n   @_inputConverter(_booleanConverter)\n   isMobile: boolean;\n\n   @Input()\n   @_inputConverter(_booleanConverter)\n   get accessibilityCompliant(): boolean {\n       return this._accessibilitySettings.accessibilityCompliant;\n   }\n   set accessibilityCompliant(value: boolean) {\n       this._accessibilitySettings.accessibilityCompliant = value;\n   }\n\n   @Input()\n   @_inputConverter(_booleanConverter)\n   keepReportOnComponentDisposal: boolean;\n   @Input()\n   @_inputConverter(_booleanConverter)\n   rtl: boolean;\n\n   @Input()\n   get reportUrl(): string {\n       return this._reportUrl;\n   }\n   set reportUrl(reportUrl: string) {\n       this._reportUrl = reportUrl;\n       if(this.bindingSender) this.bindingSender.OpenReport(reportUrl);\n   }\n}\n","<div #control [ngClass]=\"cssClass\" [ngStyle]=\"{'width': width, 'height': height }\">\n  <dxa-templates></dxa-templates>\n  <dxv-templates></dxv-templates>\n  <div class=\"dx-designer\">\n      <dxa-template *ngIf=\"!!viewModel\" template=\"dx-designer\" [data]=\"viewModel\"></dxa-template>\n  </div>\n</div>"]}
|
@@ -5,6 +5,7 @@ import { _inputConverter, _booleanConverter, DxReportingComponent } from 'devexp
|
|
5
5
|
import '@devexpress/analytics-core/dx-analytics-core-svg-templates';
|
6
6
|
import 'devexpress-reporting/dx-reporting-svg-templates';
|
7
7
|
import { JSReportViewerBinding } from 'devexpress-reporting/viewer/binding/jsReportViewerBinding';
|
8
|
+
import { ViewModelChangedEvent } from '@devexpress/analytics-core/serializer/native/viewModels/viewModelGenerator';
|
8
9
|
import * as i1 from '@angular/common';
|
9
10
|
import { CommonModule } from '@angular/common';
|
10
11
|
import { SvgTemplatesEngine } from '@devexpress/analytics-core/property-grid/widgets/internal/_svgTemplateEngine';
|
@@ -738,25 +739,29 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
738
739
|
}] });
|
739
740
|
|
740
741
|
class CollectionEditorComponent {
|
741
|
-
constructor() {
|
742
|
+
constructor(_changeDetectorRef) {
|
743
|
+
this._changeDetectorRef = _changeDetectorRef;
|
742
744
|
}
|
743
745
|
ngOnDestroy() {
|
746
|
+
this._vmSubscription && this._vmSubscription();
|
744
747
|
this._model.dispose();
|
745
748
|
}
|
746
749
|
ngOnInit() {
|
747
750
|
this._model = new CollectionEditorViewModel(this.options);
|
748
751
|
this.data = this._model.getViewModel();
|
752
|
+
this._vmSubscription = this.data
|
753
|
+
._viewModelEvents.on(ViewModelChangedEvent, () => this._changeDetectorRef.markForCheck());
|
749
754
|
}
|
750
755
|
onScrollViewInitialized(args) {
|
751
756
|
args.component.option('useKeyboard', false);
|
752
757
|
}
|
753
758
|
}
|
754
|
-
CollectionEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CollectionEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
759
|
+
CollectionEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CollectionEditorComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
755
760
|
CollectionEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: CollectionEditorComponent, selector: "dxa-collectioneditor", inputs: { options: ["data", "options"], contentTemplate: "contentTemplate" }, ngImport: i0, template: "<div class=\"dx-collectioneditor\">\n <div [dxaAccordion]=\"data\" [dxMutationObserver]=\"data.keyboardHelper\">\n <div class=\"dx-collectioneditor-header dx-accordion-header\">\n <div class=\"dx-editor-header\">\n <div role=\"treeitem\"\n class=\"dx-field dx-accessibility-focus-border-accented dxrd-accessibility-accordion-trigger\"\n [attr.aria-expanded]=\"data.alwaysShow || !data.collapsed ? 'true' : 'false'\"\n [attr.aria-owns]=\"data.contentId\" [attr.id]=\"data.headerId\">\n <div *ngIf=\"data.showButtons\" class=\"dx-collectioneditor-actions-wrapper\">\n <dx-button *ngIf=\"data.buttons.up.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.up.action($event)\" [disabled]=\"data.buttons.up.disabled\"\n icon=\"dxrd-svg-operations-moveup\" iconClass=\"dx-image-moveup\"\n [template]=\"data.buttons.up.template\"\n [attr.title]=\"data.buttons.up.text\"></dx-button>\n <dx-button *ngIf=\"data.buttons.down.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.down.action($event)\" [disabled]=\"data.buttons.down.disabled\"\n icon=\"dxrd-svg-operations-movedown\" iconClass=\"dx-image-movedown\"\n [template]=\"data.buttons.down.template\"\n [attr.title]=\"data.buttons.down.text\"></dx-button>\n <div class=\"dx-collectioneditor-action-separator\"></div>\n <dx-button *ngIf=\"data.buttons.add.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.add.action($event)\" [disabled]=\"data.buttons.add.disabled\"\n [template]=\"data.buttons.add.template\"\n icon=\"dxrd-svg-operations-add\" iconClass=\"dx-image-add\"\n [attr.title]=\"data.buttons.add.text\"></dx-button>\n <dx-button *ngIf=\"data.buttons.delete.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.delete.action($event)\" [disabled]=\"data.buttons.delete.disabled\"\n [template]=\"data.buttons.delete.template\"\n icon=\"dxrd-svg-operations-remove\" iconClass=\"dx-image-remove\"\n [attr.title]=\"data.buttons.delete.text\"></dx-button>\n </div>\n <div *ngIf=\"!!data.displayName\" class=\"dx-collectioneditor-header-text dxd-text-primary\"\n [style.padding-left]=\"data.padding + 'px'\">\n <dxa-template class=\"dx-collapsing-image dxrd-display-inline-block\"\n template=\"dxrd-svg-collapsed\"\n [class.dx-image-expanded]=\"!data.collapsed \"></dxa-template>\n <div class=\"dx-group-header-font dxd-text-primary dxrd-display-inline-block\" [attr.title]=\"data.displayName\">\n {{data.displayName}}</div>\n </div>\n </div>\n </div>\n </div>\n <div role=\"group\" class=\"dx-accordion-content\"\n [attr.aria-hidden]=\"!data.alwaysShow && data.collapsed ? 'true' : 'false'\"\n [attr.aria-labelledby]=\"data.headerId\" [attr.id]=\"data.contentId\">\n <dx-scroll-view [hidden]=\"data.disabled\" showScrollbar=\"onHover\" [disabled]=\"!data.showScroll\"\n [useNative]=\"false\" [scrollByThumb]=\"true\" (onInitialized)=\"onScrollViewInitialized($event)\">\n <div *ngIf=\"data.values.length === 0\"\n class=\"dx-collectioneditor-empty dxd-empty-area-placeholder-text-color dxd-text-info\">\n <span class=\"dx-collectioneditor-empty-text\">{{data.emptyAreaText}}</span>\n </div>\n <div *ngIf=\"data.values.length !== 0\" class=\"dx-collectioneditor-items\">\n <div *ngFor=\"let value of data.values\"\n class=\"dx-collectioneditor-item-container dxd-button-back-color dxd-state-normal dxd-back-highlighted dx-accessibility-list-item dx-accessibility-focus-border-accented\"\n [attr.aria-selected]=\"value.selected\" [dxActionModel]=\"value\" [dxAction]=\"value.select\"\n [class.dxd-state-selected]=\"value.selected\">\n <div class=\"dx-collection-item\">\n <ng-container *ngTemplateOutlet=\"contentTemplate, context: { data: value }\"></ng-container>\n </div>\n </div>\n </div>\n </dx-scroll-view>\n </div>\n </div>\n</div>", dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.DxButtonComponent, selector: "dx-button", inputs: ["accessKey", "activeStateEnabled", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "icon", "rtlEnabled", "stylingMode", "tabIndex", "template", "text", "type", "useSubmitBehavior", "validationGroup", "visible", "width"], outputs: ["onClick", "onContentReady", "onDisposing", "onInitialized", "onOptionChanged", "accessKeyChange", "activeStateEnabledChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "iconChange", "rtlEnabledChange", "stylingModeChange", "tabIndexChange", "templateChange", "textChange", "typeChange", "useSubmitBehaviorChange", "validationGroupChange", "visibleChange", "widthChange"] }, { kind: "component", type: i2.DxScrollViewComponent, selector: "dx-scroll-view", inputs: ["bounceEnabled", "direction", "disabled", "elementAttr", "height", "pulledDownText", "pullingDownText", "reachBottomText", "refreshingText", "rtlEnabled", "scrollByContent", "scrollByThumb", "showScrollbar", "useNative", "width"], outputs: ["onDisposing", "onInitialized", "onOptionChanged", "onPullDown", "onReachBottom", "onScroll", "onUpdated", "bounceEnabledChange", "directionChange", "disabledChange", "elementAttrChange", "heightChange", "pulledDownTextChange", "pullingDownTextChange", "reachBottomTextChange", "refreshingTextChange", "rtlEnabledChange", "scrollByContentChange", "scrollByThumbChange", "showScrollbarChange", "useNativeChange", "widthChange"] }, { kind: "component", type: TemplateComponent, selector: "dxa-template", inputs: ["data", "template"] }, { kind: "directive", type: DxActionDirective, selector: "[dxAction]", inputs: ["dxActionModel", "dxAction"] }, { kind: "directive", type: AccordionDirective, selector: "[dxaAccordion]", inputs: ["dxaAccordion"] }, { kind: "directive", type: DxMutationObserverDirective, selector: "[dxMutationObserver]", inputs: ["dxMutationObserver"] }] });
|
756
761
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: CollectionEditorComponent, decorators: [{
|
757
762
|
type: Component,
|
758
763
|
args: [{ selector: 'dxa-collectioneditor', template: "<div class=\"dx-collectioneditor\">\n <div [dxaAccordion]=\"data\" [dxMutationObserver]=\"data.keyboardHelper\">\n <div class=\"dx-collectioneditor-header dx-accordion-header\">\n <div class=\"dx-editor-header\">\n <div role=\"treeitem\"\n class=\"dx-field dx-accessibility-focus-border-accented dxrd-accessibility-accordion-trigger\"\n [attr.aria-expanded]=\"data.alwaysShow || !data.collapsed ? 'true' : 'false'\"\n [attr.aria-owns]=\"data.contentId\" [attr.id]=\"data.headerId\">\n <div *ngIf=\"data.showButtons\" class=\"dx-collectioneditor-actions-wrapper\">\n <dx-button *ngIf=\"data.buttons.up.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.up.action($event)\" [disabled]=\"data.buttons.up.disabled\"\n icon=\"dxrd-svg-operations-moveup\" iconClass=\"dx-image-moveup\"\n [template]=\"data.buttons.up.template\"\n [attr.title]=\"data.buttons.up.text\"></dx-button>\n <dx-button *ngIf=\"data.buttons.down.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.down.action($event)\" [disabled]=\"data.buttons.down.disabled\"\n icon=\"dxrd-svg-operations-movedown\" iconClass=\"dx-image-movedown\"\n [template]=\"data.buttons.down.template\"\n [attr.title]=\"data.buttons.down.text\"></dx-button>\n <div class=\"dx-collectioneditor-action-separator\"></div>\n <dx-button *ngIf=\"data.buttons.add.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.add.action($event)\" [disabled]=\"data.buttons.add.disabled\"\n [template]=\"data.buttons.add.template\"\n icon=\"dxrd-svg-operations-add\" iconClass=\"dx-image-add\"\n [attr.title]=\"data.buttons.add.text\"></dx-button>\n <dx-button *ngIf=\"data.buttons.delete.visible\"\n class=\"dx-collectioneditor-action dx-accessibility-focus-border-accented\"\n (onClick)=\"data.buttons.delete.action($event)\" [disabled]=\"data.buttons.delete.disabled\"\n [template]=\"data.buttons.delete.template\"\n icon=\"dxrd-svg-operations-remove\" iconClass=\"dx-image-remove\"\n [attr.title]=\"data.buttons.delete.text\"></dx-button>\n </div>\n <div *ngIf=\"!!data.displayName\" class=\"dx-collectioneditor-header-text dxd-text-primary\"\n [style.padding-left]=\"data.padding + 'px'\">\n <dxa-template class=\"dx-collapsing-image dxrd-display-inline-block\"\n template=\"dxrd-svg-collapsed\"\n [class.dx-image-expanded]=\"!data.collapsed \"></dxa-template>\n <div class=\"dx-group-header-font dxd-text-primary dxrd-display-inline-block\" [attr.title]=\"data.displayName\">\n {{data.displayName}}</div>\n </div>\n </div>\n </div>\n </div>\n <div role=\"group\" class=\"dx-accordion-content\"\n [attr.aria-hidden]=\"!data.alwaysShow && data.collapsed ? 'true' : 'false'\"\n [attr.aria-labelledby]=\"data.headerId\" [attr.id]=\"data.contentId\">\n <dx-scroll-view [hidden]=\"data.disabled\" showScrollbar=\"onHover\" [disabled]=\"!data.showScroll\"\n [useNative]=\"false\" [scrollByThumb]=\"true\" (onInitialized)=\"onScrollViewInitialized($event)\">\n <div *ngIf=\"data.values.length === 0\"\n class=\"dx-collectioneditor-empty dxd-empty-area-placeholder-text-color dxd-text-info\">\n <span class=\"dx-collectioneditor-empty-text\">{{data.emptyAreaText}}</span>\n </div>\n <div *ngIf=\"data.values.length !== 0\" class=\"dx-collectioneditor-items\">\n <div *ngFor=\"let value of data.values\"\n class=\"dx-collectioneditor-item-container dxd-button-back-color dxd-state-normal dxd-back-highlighted dx-accessibility-list-item dx-accessibility-focus-border-accented\"\n [attr.aria-selected]=\"value.selected\" [dxActionModel]=\"value\" [dxAction]=\"value.select\"\n [class.dxd-state-selected]=\"value.selected\">\n <div class=\"dx-collection-item\">\n <ng-container *ngTemplateOutlet=\"contentTemplate, context: { data: value }\"></ng-container>\n </div>\n </div>\n </div>\n </dx-scroll-view>\n </div>\n </div>\n</div>" }]
|
759
|
-
}], ctorParameters: function () { return []; }, propDecorators: { options: [{
|
764
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { options: [{
|
760
765
|
type: Input,
|
761
766
|
args: ['data']
|
762
767
|
}], contentTemplate: [{
|
@@ -1322,48 +1327,56 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
1322
1327
|
}] } });
|
1323
1328
|
|
1324
1329
|
class DateRangeComponent {
|
1325
|
-
constructor(_currentElement) {
|
1330
|
+
constructor(_currentElement, _changeDetectorRef) {
|
1326
1331
|
this._currentElement = _currentElement;
|
1332
|
+
this._changeDetectorRef = _changeDetectorRef;
|
1327
1333
|
}
|
1328
1334
|
ngOnDestroy() {
|
1335
|
+
this._vmSubscription && this._vmSubscription();
|
1329
1336
|
this._editor.dispose();
|
1330
1337
|
}
|
1331
1338
|
ngOnInit() {
|
1332
1339
|
this._editor = createDateRangeEditor(this.options, this._currentElement.nativeElement, this.options);
|
1333
1340
|
this.data = this._editor.getViewModel();
|
1341
|
+
this._vmSubscription = this.data._viewModelEvents.on(ViewModelChangedEvent, () => {
|
1342
|
+
this._changeDetectorRef.markForCheck();
|
1343
|
+
});
|
1334
1344
|
this.data.cacheElement(this._currentElement.nativeElement);
|
1345
|
+
const processClickEvent = () => {
|
1346
|
+
this.data.showPopup();
|
1347
|
+
this._changeDetectorRef.markForCheck();
|
1348
|
+
};
|
1335
1349
|
const processKeyBoardEvent = (e) => {
|
1336
1350
|
if (e.key == KeyboardEnum.Enter || (e.key == KeyboardEnum.ArrowDown && e.altKey)) {
|
1337
1351
|
this.data.showPopup();
|
1352
|
+
this._changeDetectorRef.markForCheck();
|
1338
1353
|
}
|
1339
1354
|
};
|
1340
1355
|
this.subscribeToEvents = (event) => {
|
1341
1356
|
var _a, _b;
|
1342
1357
|
this.textBoxInputElement = event.element.querySelector('.dx-texteditor-input');
|
1343
|
-
(_a = this.textBoxInputElement) === null || _a === void 0 ? void 0 : _a.addEventListener('click',
|
1358
|
+
(_a = this.textBoxInputElement) === null || _a === void 0 ? void 0 : _a.addEventListener('click', processClickEvent);
|
1344
1359
|
(_b = this.textBoxInputElement) === null || _b === void 0 ? void 0 : _b.addEventListener('keydown', processKeyBoardEvent);
|
1345
1360
|
};
|
1346
1361
|
this.unsubscribeFromEvents = () => {
|
1347
1362
|
var _a, _b;
|
1348
|
-
(_a = this.textBoxInputElement) === null || _a === void 0 ? void 0 : _a.removeEventListener('click',
|
1363
|
+
(_a = this.textBoxInputElement) === null || _a === void 0 ? void 0 : _a.removeEventListener('click', processClickEvent);
|
1349
1364
|
(_b = this.textBoxInputElement) === null || _b === void 0 ? void 0 : _b.removeEventListener('keydown', processKeyBoardEvent);
|
1350
1365
|
};
|
1351
1366
|
this.showPopupOptions = {
|
1352
1367
|
disabled: false,
|
1353
|
-
onClick:
|
1354
|
-
this.data.showPopup();
|
1355
|
-
},
|
1368
|
+
onClick: processClickEvent,
|
1356
1369
|
template: generateIconTemplate('dx-ellipsis-image'),
|
1357
1370
|
icon: 'dxrd-svg-ellipsis'
|
1358
1371
|
};
|
1359
1372
|
}
|
1360
1373
|
}
|
1361
|
-
DateRangeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateRangeComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
1374
|
+
DateRangeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateRangeComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
1362
1375
|
DateRangeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: DateRangeComponent, selector: "dxv-date-range", inputs: { options: ["data", "options"] }, ngImport: i0, template: "<div class=\"dxrv-daterange-editor\">\n <dx-text-box \n [value]=\"data.displayValue\"\n [readOnly]=\"true\"\n (onContentReady)=\"subscribeToEvents($event)\" (onDisposing)=\"unsubscribeFromEvents()\"\n >\n <dxi-button\n name=\"showPopup\"\n location=\"after\"\n [options]=\"showPopupOptions\"\n ></dxi-button>\n </dx-text-box>\n <dxa-template [template]=\"data.popupTemplate\" [data]=\"data.popupModel\"></dxa-template>\n</div>", dependencies: [{ kind: "component", type: i1$1.DxiButtonComponent, selector: "dxi-button", inputs: ["location", "name", "options", "cssClass", "disabled", "hint", "icon", "onClick", "template", "text", "visible"] }, { kind: "component", type: i2.DxTextBoxComponent, selector: "dx-text-box", inputs: ["accessKey", "activeStateEnabled", "buttons", "disabled", "elementAttr", "focusStateEnabled", "height", "hint", "hoverStateEnabled", "inputAttr", "isDirty", "isValid", "label", "labelMode", "mask", "maskChar", "maskInvalidMessage", "maskRules", "maxLength", "mode", "name", "placeholder", "readOnly", "rtlEnabled", "showClearButton", "showMaskMode", "spellcheck", "stylingMode", "tabIndex", "text", "useMaskedValue", "validationError", "validationErrors", "validationMessageMode", "validationMessagePosition", "validationStatus", "value", "valueChangeEvent", "visible", "width"], outputs: ["onChange", "onContentReady", "onCopy", "onCut", "onDisposing", "onEnterKey", "onFocusIn", "onFocusOut", "onInitialized", "onInput", "onKeyDown", "onKeyUp", "onOptionChanged", "onPaste", "onValueChanged", "accessKeyChange", "activeStateEnabledChange", "buttonsChange", "disabledChange", "elementAttrChange", "focusStateEnabledChange", "heightChange", "hintChange", "hoverStateEnabledChange", "inputAttrChange", "isDirtyChange", "isValidChange", "labelChange", "labelModeChange", "maskChange", "maskCharChange", "maskInvalidMessageChange", "maskRulesChange", "maxLengthChange", "modeChange", "nameChange", "placeholderChange", "readOnlyChange", "rtlEnabledChange", "showClearButtonChange", "showMaskModeChange", "spellcheckChange", "stylingModeChange", "tabIndexChange", "textChange", "useMaskedValueChange", "validationErrorChange", "validationErrorsChange", "validationMessageModeChange", "validationMessagePositionChange", "validationStatusChange", "valueChange", "valueChangeEventChange", "visibleChange", "widthChange", "onBlur"] }, { kind: "component", type: TemplateComponent, selector: "dxa-template", inputs: ["data", "template"] }] });
|
1363
1376
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DateRangeComponent, decorators: [{
|
1364
1377
|
type: Component,
|
1365
1378
|
args: [{ selector: 'dxv-date-range', template: "<div class=\"dxrv-daterange-editor\">\n <dx-text-box \n [value]=\"data.displayValue\"\n [readOnly]=\"true\"\n (onContentReady)=\"subscribeToEvents($event)\" (onDisposing)=\"unsubscribeFromEvents()\"\n >\n <dxi-button\n name=\"showPopup\"\n location=\"after\"\n [options]=\"showPopupOptions\"\n ></dxi-button>\n </dx-text-box>\n <dxa-template [template]=\"data.popupTemplate\" [data]=\"data.popupModel\"></dxa-template>\n</div>" }]
|
1366
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { options: [{
|
1379
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { options: [{
|
1367
1380
|
type: Input,
|
1368
1381
|
args: ['data']
|
1369
1382
|
}] } });
|
@@ -2679,18 +2692,27 @@ class DxReportViewerComponent extends DxReportingComponent {
|
|
2679
2692
|
super.ngAfterViewInit();
|
2680
2693
|
this.model = this._binding.sender;
|
2681
2694
|
this.viewModel = (_a = this.model.GetPreviewModel()) === null || _a === void 0 ? void 0 : _a.getViewModel();
|
2695
|
+
this._disposeViewModelChangedSubscription = this._subscribeToViewModelChanged(this.viewModel);
|
2682
2696
|
this._disposableCallback = this.model.events.on('propertyChanged', (args) => {
|
2683
2697
|
if (args.propertyName === 'previewModel') {
|
2684
2698
|
this.viewModel = this.model.GetPreviewModel().getViewModel();
|
2699
|
+
this._disposeViewModelChangedSubscription && this._disposeViewModelChangedSubscription();
|
2700
|
+
this._disposeViewModelChangedSubscription = this._subscribeToViewModelChanged(this.viewModel);
|
2685
2701
|
}
|
2686
2702
|
});
|
2687
2703
|
this._cd.detectChanges();
|
2688
2704
|
}
|
2689
2705
|
ngOnDestroy() {
|
2690
2706
|
this._disposableCallback && this._disposableCallback();
|
2707
|
+
this._disposeViewModelChangedSubscription && this._disposeViewModelChangedSubscription();
|
2691
2708
|
this._binding.dispose();
|
2692
2709
|
super.ngOnDestroy();
|
2693
2710
|
}
|
2711
|
+
_subscribeToViewModelChanged(viewModel) {
|
2712
|
+
var _a;
|
2713
|
+
const eventHolder = viewModel;
|
2714
|
+
return (_a = eventHolder === null || eventHolder === void 0 ? void 0 : eventHolder._viewModelEvents) === null || _a === void 0 ? void 0 : _a.on(ViewModelChangedEvent, () => this._cd.markForCheck());
|
2715
|
+
}
|
2694
2716
|
get accessibilityCompliant() {
|
2695
2717
|
return this._accessibilitySettings.accessibilityCompliant;
|
2696
2718
|
}
|