devexpress-reporting-angular 23.2.5-build-2440-1343 → 23.2.5-build-2447-1420

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.
@@ -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;
@@ -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', this.data.showPopup);
38
+ this.textBoxInputElement?.addEventListener('click', processClickEvent);
28
39
  this.textBoxInputElement?.addEventListener('keydown', processKeyBoardEvent);
29
40
  };
30
41
  this.unsubscribeFromEvents = () => {
31
- this.textBoxInputElement?.removeEventListener('click', this.data.showPopup);
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: (e) => {
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1yYW5nZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9keC1yZXBvcnQtdmlld2VyL2NvbXBvbmVudHMvcmVwb3J0aW5nL3BhcmFtZXRlcnNwYW5lbC9kYXRlLXJhbmdlL2RhdGUtcmFuZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vZHgtcmVwb3J0LXZpZXdlci9jb21wb25lbnRzL3JlcG9ydGluZy9wYXJhbWV0ZXJzcGFuZWwvZGF0ZS1yYW5nZS9kYXRlLXJhbmdlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFxQixNQUFNLGVBQWUsQ0FBQztBQUVoRixPQUFPLEVBQUUscUJBQXFCLEVBQTRDLE1BQU0sK0RBQStELENBQUM7QUFFaEosT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sK0RBQStELENBQUM7QUFDckcsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGtFQUFrRSxDQUFDOzs7OztBQU9oRyxNQUFNLE9BQU8sa0JBQWtCO0lBUzNCLFlBQW9CLGVBQWdDO1FBQWhDLG9CQUFlLEdBQWYsZUFBZSxDQUFpQjtJQUFHLENBQUM7SUFDeEQsV0FBVztRQUNQLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDM0IsQ0FBQztJQUNELFFBQVE7UUFDSixJQUFJLENBQUMsT0FBTyxHQUFHLHFCQUFxQixDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLGVBQWUsQ0FBQyxhQUFhLEVBQUUsSUFBSSxDQUFDLE9BQTJCLENBQUMsQ0FBQztRQUN6SCxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDeEMsSUFBSSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUMzRCxNQUFNLG9CQUFvQixHQUFHLENBQUMsQ0FBZ0IsRUFBRSxFQUFFO1lBQzlDLElBQUcsQ0FBQyxDQUFDLEdBQUcsSUFBSSxZQUFZLENBQUMsS0FBSyxJQUFJLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxZQUFZLENBQUMsU0FBUyxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRTtnQkFDN0UsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLEVBQUUsQ0FBQzthQUN6QjtRQUNMLENBQUMsQ0FBQztRQUNGLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQy9CLElBQUksQ0FBQyxtQkFBbUIsR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLGFBQWEsQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO1lBQy9FLElBQUksQ0FBQyxtQkFBbUIsRUFBRSxnQkFBZ0IsQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztZQUN6RSxJQUFJLENBQUMsbUJBQW1CLEVBQUUsZ0JBQWdCLENBQUMsU0FBUyxFQUFFLG9CQUFvQixDQUFDLENBQUM7UUFDaEYsQ0FBQyxDQUFDO1FBQ0YsSUFBSSxDQUFDLHFCQUFxQixHQUFHLEdBQUcsRUFBRTtZQUM5QixJQUFJLENBQUMsbUJBQW1CLEVBQUUsbUJBQW1CLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDNUUsSUFBSSxDQUFDLG1CQUFtQixFQUFFLG1CQUFtQixDQUFDLFNBQVMsRUFBRSxvQkFBb0IsQ0FBQyxDQUFDO1FBQ25GLENBQUMsQ0FBQztRQUNGLElBQUksQ0FBQyxnQkFBZ0IsR0FBRztZQUNwQixRQUFRLEVBQUUsS0FBSztZQUNmLE9BQU8sRUFBRSxDQUFDLENBQUMsRUFBRSxFQUFFO2dCQUNYLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDMUIsQ0FBQztZQUNELFFBQVEsRUFBRSxvQkFBb0IsQ0FBQyxtQkFBbUIsQ0FBQztZQUNuRCxJQUFJLEVBQUUsbUJBQW1CO1NBQ3JCLENBQUM7SUFDYixDQUFDOztnSEF2Q1Esa0JBQWtCO29HQUFsQixrQkFBa0IsZ0dDWi9CLDBmQWFNOzRGRERPLGtCQUFrQjtrQkFKOUIsU0FBUzsrQkFDSSxnQkFBZ0I7aUdBSVgsT0FBTztzQkFBckIsS0FBSzt1QkFBQyxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCwgT25Jbml0LCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFByb3BlcnRpZXMgfSBmcm9tICdkZXZleHRyZW1lL3VpL2J1dHRvbic7XG5pbXBvcnQgeyBjcmVhdGVEYXRlUmFuZ2VFZGl0b3IsIERhdGVSYW5nZUVkaXRvciwgSURhdGVSYW5nZUVkaXRvck9wdGlvbnMgfSBmcm9tICdkZXZleHByZXNzLXJlcG9ydGluZy92aWV3ZXIvd2lkZ2V0cy9kYXRlUmFuZ2UvZGF0ZVJhbmdlRWRpdG9yJztcbmltcG9ydCB7IElEYXRlUmFuZ2VFZGl0b3JWaWV3TW9kZWwgfSBmcm9tICdkZXZleHByZXNzLXJlcG9ydGluZy92aWV3ZXIvd2lkZ2V0cy9kYXRlUmFuZ2UvZGF0ZVJhbmdlRWRpdG9yLnZpZXdtb2RlbCc7XG5pbXBvcnQgeyBnZW5lcmF0ZUljb25UZW1wbGF0ZSB9IGZyb20gJ0BkZXZleHByZXNzL2FuYWx5dGljcy1jb3JlL2NvcmUvd2lkZ2V0cy9fZ2VuZXJhdGVJY29uVGVtcGxhdGUnO1xuaW1wb3J0IHsgS2V5Ym9hcmRFbnVtIH0gZnJvbSAnQGRldmV4cHJlc3MvYW5hbHl0aWNzLWNvcmUvcHJvcGVydHktZ3JpZC93aWRnZXRzL2ludGVybmFsL191dGlscyc7XG5pbXBvcnQgeyBJRWRpdG9yVmlld01vZGVsIH0gZnJvbSAnQGRldmV4cHJlc3MvYW5hbHl0aWNzLWNvcmUvYW5hbHl0aWNzLXdpZGdldHMtbmF0aXZlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdkeHYtZGF0ZS1yYW5nZScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2RhdGUtcmFuZ2UuY29tcG9uZW50Lmh0bWwnXG59KVxuZXhwb3J0IGNsYXNzIERhdGVSYW5nZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcbiAgICBASW5wdXQoJ2RhdGEnKSBvcHRpb25zOiBJRGF0ZVJhbmdlRWRpdG9yT3B0aW9ucztcbiAgICBwcml2YXRlIF9lZGl0b3I6IERhdGVSYW5nZUVkaXRvcjtcblxuICAgIGRhdGE6IElEYXRlUmFuZ2VFZGl0b3JWaWV3TW9kZWw7XG4gICAgc2hvd1BvcHVwT3B0aW9uczogUHJvcGVydGllcztcbiAgICB0ZXh0Qm94SW5wdXRFbGVtZW50OiBIVE1MRWxlbWVudDtcbiAgICBzdWJzY3JpYmVUb0V2ZW50czogKGV2ZW50KSA9PiB2b2lkO1xuICAgIHVuc3Vic2NyaWJlRnJvbUV2ZW50czogKCkgPT4gdm9pZDtcbiAgICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9jdXJyZW50RWxlbWVudDogRWxlbWVudFJlZjxhbnk+KSB7fVxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgICAgICB0aGlzLl9lZGl0b3IuZGlzcG9zZSgpO1xuICAgIH1cbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5fZWRpdG9yID0gY3JlYXRlRGF0ZVJhbmdlRWRpdG9yKHRoaXMub3B0aW9ucywgdGhpcy5fY3VycmVudEVsZW1lbnQubmF0aXZlRWxlbWVudCwgdGhpcy5vcHRpb25zIGFzIElFZGl0b3JWaWV3TW9kZWwpO1xuICAgICAgICB0aGlzLmRhdGEgPSB0aGlzLl9lZGl0b3IuZ2V0Vmlld01vZGVsKCk7XG4gICAgICAgIHRoaXMuZGF0YS5jYWNoZUVsZW1lbnQodGhpcy5fY3VycmVudEVsZW1lbnQubmF0aXZlRWxlbWVudCk7XG4gICAgICAgIGNvbnN0IHByb2Nlc3NLZXlCb2FyZEV2ZW50ID0gKGU6IEtleWJvYXJkRXZlbnQpID0+IHtcbiAgICAgICAgICAgIGlmKGUua2V5ID09IEtleWJvYXJkRW51bS5FbnRlciB8fCAoZS5rZXkgPT0gS2V5Ym9hcmRFbnVtLkFycm93RG93biAmJiBlLmFsdEtleSkpIHtcbiAgICAgICAgICAgICAgICB0aGlzLmRhdGEuc2hvd1BvcHVwKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH07XG4gICAgICAgIHRoaXMuc3Vic2NyaWJlVG9FdmVudHMgPSAoZXZlbnQpID0+IHtcbiAgICAgICAgICAgIHRoaXMudGV4dEJveElucHV0RWxlbWVudCA9IGV2ZW50LmVsZW1lbnQucXVlcnlTZWxlY3RvcignLmR4LXRleHRlZGl0b3ItaW5wdXQnKTtcbiAgICAgICAgICAgIHRoaXMudGV4dEJveElucHV0RWxlbWVudD8uYWRkRXZlbnRMaXN0ZW5lcignY2xpY2snLCB0aGlzLmRhdGEuc2hvd1BvcHVwKTtcbiAgICAgICAgICAgIHRoaXMudGV4dEJveElucHV0RWxlbWVudD8uYWRkRXZlbnRMaXN0ZW5lcigna2V5ZG93bicsIHByb2Nlc3NLZXlCb2FyZEV2ZW50KTtcbiAgICAgICAgfTtcbiAgICAgICAgdGhpcy51bnN1YnNjcmliZUZyb21FdmVudHMgPSAoKSA9PiB7XG4gICAgICAgICAgICB0aGlzLnRleHRCb3hJbnB1dEVsZW1lbnQ/LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ2NsaWNrJywgdGhpcy5kYXRhLnNob3dQb3B1cCk7XG4gICAgICAgICAgICB0aGlzLnRleHRCb3hJbnB1dEVsZW1lbnQ/LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ2tleWRvd24nLCBwcm9jZXNzS2V5Qm9hcmRFdmVudCk7XG4gICAgICAgIH07XG4gICAgICAgIHRoaXMuc2hvd1BvcHVwT3B0aW9ucyA9IHtcbiAgICAgICAgICAgIGRpc2FibGVkOiBmYWxzZSxcbiAgICAgICAgICAgIG9uQ2xpY2s6IChlKSA9PiB7XG4gICAgICAgICAgICAgICAgdGhpcy5kYXRhLnNob3dQb3B1cCgpO1xuICAgICAgICAgICAgfSxcbiAgICAgICAgICAgIHRlbXBsYXRlOiBnZW5lcmF0ZUljb25UZW1wbGF0ZSgnZHgtZWxsaXBzaXMtaW1hZ2UnKSxcbiAgICAgICAgICAgIGljb246ICdkeHJkLXN2Zy1lbGxpcHNpcydcbiAgICAgICAgfSBhcyBhbnk7XG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImR4cnYtZGF0ZXJhbmdlLWVkaXRvclwiPlxuICAgIDxkeC10ZXh0LWJveCBcbiAgICAgICAgW3ZhbHVlXT1cImRhdGEuZGlzcGxheVZhbHVlXCJcbiAgICAgICAgW3JlYWRPbmx5XT1cInRydWVcIlxuICAgICAgICAob25Db250ZW50UmVhZHkpPVwic3Vic2NyaWJlVG9FdmVudHMoJGV2ZW50KVwiIChvbkRpc3Bvc2luZyk9XCJ1bnN1YnNjcmliZUZyb21FdmVudHMoKVwiXG4gICAgICAgID5cbiAgICAgICAgPGR4aS1idXR0b25cbiAgICAgICAgICBuYW1lPVwic2hvd1BvcHVwXCJcbiAgICAgICAgICBsb2NhdGlvbj1cImFmdGVyXCJcbiAgICAgICAgICBbb3B0aW9uc109XCJzaG93UG9wdXBPcHRpb25zXCJcbiAgICAgICAgPjwvZHhpLWJ1dHRvbj5cbiAgICA8L2R4LXRleHQtYm94PlxuICAgIDxkeGEtdGVtcGxhdGUgW3RlbXBsYXRlXT1cImRhdGEucG9wdXBUZW1wbGF0ZVwiIFtkYXRhXT1cImRhdGEucG9wdXBNb2RlbFwiPjwvZHhhLXRlbXBsYXRlPlxuPC9kaXY+Il19
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', this.data.showPopup);
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', this.data.showPopup);
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: (e) => {
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
  }