UNPKG

@progress/telerik-angular-native-report-viewer

Version:

Progress® Telerik® Native Report Viewer for Angular

214 lines (212 loc) 24.8 kB
import { Component, ViewChild, forwardRef, ViewEncapsulation, } from '@angular/core'; import { ToolBarToolComponent } from '@progress/kendo-angular-toolbar'; import { ComboBoxComponent } from '@progress/kendo-angular-dropdowns'; import { zoomOptionsData } from '../models/zoom-level.interface'; import { windowRestoreIcon } from '@progress/kendo-svg-icons'; import { isDocumentAvailable } from '@progress/kendo-angular-common'; import { Subscription } from 'rxjs'; import * as i0 from "@angular/core"; import * as i1 from "../reporting-angular-viewer.service"; import * as i2 from "@angular/common"; import * as i3 from "@progress/kendo-angular-dropdowns"; import * as i4 from "@progress/kendo-angular-dialog"; import * as i5 from "@progress/kendo-angular-icons"; import * as i6 from "@progress/kendo-angular-buttons"; export class CustomZoomComponent extends ToolBarToolComponent { constructor(service) { super(); this.service = service; this.openDialog = false; this.tabindex = -1; this.zoomOptionsData = zoomOptionsData; this.currentZoom = zoomOptionsData[5]; this.windowRestoreIcon = windowRestoreIcon; this.subs = new Subscription(); } canFocus() { return true; // marks the tools as focusable } focus() { if (!isDocumentAvailable()) return; this.tabindex = 0; if (this.overflows) { this.zoomButton?.nativeElement.focus(); } else { this.combobox?.focus(); this.combobox?.wrapper.nativeElement.focus(); } } handleKey() { this.tabindex = -1; return false; } ngAfterViewInit() { this.subs.add(this.service.onZoomChange.subscribe(zoomLevel => { this.currentZoom = zoomOptionsData?.find(zoomData => zoomData.value === zoomLevel); })); } ngOnDestroy() { this.subs.unsubscribe(); } zoomLevelChange(zoomLevel) { if (!isDocumentAvailable()) return; const defaultZoom = zoomOptionsData.filter(zoom => zoom.value === 1)[0]; if (!zoomLevel && this.currentZoom === defaultZoom) { this.currentZoom = defaultZoom; return; } if (!zoomLevel && this.currentZoom !== defaultZoom) { this.currentZoom = defaultZoom; } if (zoomLevel) this.currentZoom = zoomLevel; this.service.setScaleMode(this.getScaleModeAsNumber(this.currentZoom.type)); if (this.currentZoom.type === 'specific') { this.service.setScale(this.currentZoom.value); } } get localeMessage() { return this.service.options.messages[`ReportViewer_ToolbarZoomComboBoxPlaceholderText`]; } getScaleModeAsNumber(scaleMode) { return scaleMode === 'fitPage' ? 0 : scaleMode === 'fitPageWidth' ? 1 : 2; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomZoomComponent, deps: [{ token: i1.ReportingAngularViewerService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CustomZoomComponent, selector: "custom-zoom-tool", providers: [ { provide: ToolBarToolComponent, useExisting: forwardRef(() => CustomZoomComponent) } ], viewQueries: [{ propertyName: "toolbarTemplate", first: true, predicate: ["toolbarTemplate"], descendants: true, static: true }, { propertyName: "popupTemplate", first: true, predicate: ["popupTemplate"], descendants: true, static: true }, { propertyName: "toolbarElement", first: true, predicate: ["toolbarElement"], descendants: true }, { propertyName: "popupElement", first: true, predicate: ["popupElement"], descendants: true }, { propertyName: "zoomButton", first: true, predicate: ["zoomButton"], descendants: true }, { propertyName: "combobox", first: true, predicate: ["combobox"], descendants: true, read: ComboBoxComponent }], usesInheritance: true, ngImport: i0, template: ` <ng-template #toolbarTemplate> <span #toolbarElement> <kendo-combobox #combobox textField="text" valueField="value" [tabindex]="tabindex" [placeholder]="localeMessage" [data]="zoomOptionsData" [valuePrimitive]="false" [value]="currentZoom" (valueChange)="zoomLevelChange($event)"> [title]="localeMessage" </kendo-combobox> </span> </ng-template> <ng-template #popupTemplate> <span #popupElement> <button #zoomButton kendoButton class="zoom-level-btn" fillMode="flat" [tabindex]="tabindex" (click)="openDialog = true" > <div class="zoom-level-btn-content"> <span> {{ localeMessage }} </span> <kendo-svgicon name="window-restore" [icon]="windowRestoreIcon"></kendo-svgicon> </div> </button> </span> <kendo-dialog [width]="300" [height]="120" [title]="localeMessage" *ngIf="openDialog" (close)="openDialog = false" > <kendo-dropdownlist textField="text" valueField="value" [tabindex]="tabindex" [valuePrimitive]="false" [data]="zoomOptionsData" [value]="currentZoom" [title]="localeMessage" (valueChange)="zoomLevelChange($event)" > </kendo-dropdownlist> </kendo-dialog> </ng-template> `, isInline: true, styles: [".zoom-level-btn{width:100%}.zoom-level-btn .k-button-text{width:inherit}.zoom-level-btn .zoom-level-btn-content{display:flex;align-items:center;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.DropDownListComponent, selector: "kendo-dropdownlist", inputs: ["customIconClass", "showStickyHeader", "icon", "svgIcon", "loading", "data", "value", "textField", "valueField", "adaptiveMode", "title", "subtitle", "popupSettings", "listHeight", "defaultItem", "disabled", "itemDisabled", "readonly", "filterable", "virtual", "ignoreCase", "delay", "valuePrimitive", "tabindex", "tabIndex", "size", "rounded", "fillMode", "leftRightArrowsNavigation", "id"], outputs: ["valueChange", "filterChange", "selectionChange", "open", "opened", "close", "closed", "focus", "blur"], exportAs: ["kendoDropDownList"] }, { kind: "component", type: i4.DialogComponent, selector: "kendo-dialog", inputs: ["actions", "actionsLayout", "autoFocusedElement", "title", "width", "minWidth", "maxWidth", "height", "minHeight", "maxHeight", "animation", "themeColor"], outputs: ["action", "close"], exportAs: ["kendoDialog"] }, { kind: "component", type: i5.SVGIconComponent, selector: "kendo-svg-icon, kendo-svgicon", inputs: ["icon"], exportAs: ["kendoSVGIcon"] }, { kind: "component", type: i3.ComboBoxComponent, selector: "kendo-combobox", inputs: ["icon", "svgIcon", "inputAttributes", "showStickyHeader", "focusableId", "allowCustom", "data", "value", "textField", "valueField", "valuePrimitive", "valueNormalizer", "placeholder", "adaptiveMode", "title", "subtitle", "popupSettings", "listHeight", "loading", "suggest", "clearButton", "disabled", "itemDisabled", "readonly", "tabindex", "tabIndex", "filterable", "virtual", "size", "rounded", "fillMode"], outputs: ["valueChange", "selectionChange", "filterChange", "open", "opened", "close", "closed", "focus", "blur", "inputFocus", "inputBlur", "escape"], exportAs: ["kendoComboBox"] }, { kind: "component", type: i6.ButtonComponent, selector: "button[kendoButton]", inputs: ["arrowIcon", "toggleable", "togglable", "selected", "tabIndex", "imageUrl", "iconClass", "icon", "disabled", "size", "rounded", "fillMode", "themeColor", "svgIcon", "primary", "look"], outputs: ["selectedChange", "click"], exportAs: ["kendoButton"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomZoomComponent, decorators: [{ type: Component, args: [{ providers: [ { provide: ToolBarToolComponent, useExisting: forwardRef(() => CustomZoomComponent) } ], selector: 'custom-zoom-tool', template: ` <ng-template #toolbarTemplate> <span #toolbarElement> <kendo-combobox #combobox textField="text" valueField="value" [tabindex]="tabindex" [placeholder]="localeMessage" [data]="zoomOptionsData" [valuePrimitive]="false" [value]="currentZoom" (valueChange)="zoomLevelChange($event)"> [title]="localeMessage" </kendo-combobox> </span> </ng-template> <ng-template #popupTemplate> <span #popupElement> <button #zoomButton kendoButton class="zoom-level-btn" fillMode="flat" [tabindex]="tabindex" (click)="openDialog = true" > <div class="zoom-level-btn-content"> <span> {{ localeMessage }} </span> <kendo-svgicon name="window-restore" [icon]="windowRestoreIcon"></kendo-svgicon> </div> </button> </span> <kendo-dialog [width]="300" [height]="120" [title]="localeMessage" *ngIf="openDialog" (close)="openDialog = false" > <kendo-dropdownlist textField="text" valueField="value" [tabindex]="tabindex" [valuePrimitive]="false" [data]="zoomOptionsData" [value]="currentZoom" [title]="localeMessage" (valueChange)="zoomLevelChange($event)" > </kendo-dropdownlist> </kendo-dialog> </ng-template> `, encapsulation: ViewEncapsulation.None, styles: [".zoom-level-btn{width:100%}.zoom-level-btn .k-button-text{width:inherit}.zoom-level-btn .zoom-level-btn-content{display:flex;align-items:center;justify-content:space-between}\n"] }] }], ctorParameters: function () { return [{ type: i1.ReportingAngularViewerService }]; }, propDecorators: { toolbarTemplate: [{ type: ViewChild, args: ['toolbarTemplate', { static: true }] }], popupTemplate: [{ type: ViewChild, args: ['popupTemplate', { static: true }] }], toolbarElement: [{ type: ViewChild, args: ['toolbarElement'] }], popupElement: [{ type: ViewChild, args: ['popupElement'] }], zoomButton: [{ type: ViewChild, args: ['zoomButton'] }], combobox: [{ type: ViewChild, args: ['combobox', { read: ComboBoxComponent, static: false }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zoom.component.js","sourceRoot":"","sources":["../../../../src/lib/toolbar-tools/zoom.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    TemplateRef,\n    ViewChild,\n    ElementRef,\n    forwardRef,\n    AfterViewInit,\n    ViewEncapsulation,\n    OnDestroy,\n} from '@angular/core';\nimport { ToolBarToolComponent } from '@progress/kendo-angular-toolbar';\nimport { ReportingAngularViewerService } from '../reporting-angular-viewer.service';\nimport { ScaleMode } from '../models/types';\nimport { ComboBoxComponent } from '@progress/kendo-angular-dropdowns';\nimport { ZoomLevel, zoomOptionsData } from '../models/zoom-level.interface';\nimport { SVGIcon, windowRestoreIcon } from '@progress/kendo-svg-icons';\nimport { isDocumentAvailable } from '@progress/kendo-angular-common';\nimport { Subscription } from 'rxjs';\n\n@Component({\n    providers: [\n        { provide: ToolBarToolComponent, useExisting: forwardRef(() => CustomZoomComponent) }\n    ],\n    selector: 'custom-zoom-tool',\n    template: `\n        <ng-template #toolbarTemplate>\n            <span #toolbarElement>\n                <kendo-combobox\n                    #combobox\n                    textField=\"text\"\n                    valueField=\"value\"\n                    [tabindex]=\"tabindex\"\n                    [placeholder]=\"localeMessage\"\n                    [data]=\"zoomOptionsData\"\n                    [valuePrimitive]=\"false\"\n                    [value]=\"currentZoom\"\n                    (valueChange)=\"zoomLevelChange($event)\">\n                    [title]=\"localeMessage\"\n                </kendo-combobox>\n            </span>\n        </ng-template>\n        <ng-template #popupTemplate>\n            <span #popupElement>\n                <button\n                    #zoomButton\n                    kendoButton\n                    class=\"zoom-level-btn\"\n                    fillMode=\"flat\"\n                    [tabindex]=\"tabindex\"\n                    (click)=\"openDialog = true\"\n                >\n                    <div class=\"zoom-level-btn-content\">\n                        <span> {{ localeMessage }} </span>\n                        <kendo-svgicon name=\"window-restore\" [icon]=\"windowRestoreIcon\"></kendo-svgicon>\n                    </div>\n                </button>\n            </span>\n\n            <kendo-dialog\n                [width]=\"300\"\n                [height]=\"120\"\n                [title]=\"localeMessage\"\n                *ngIf=\"openDialog\"\n                (close)=\"openDialog = false\"\n            >\n                <kendo-dropdownlist\n                    textField=\"text\"\n                    valueField=\"value\"\n                    [tabindex]=\"tabindex\"\n                    [valuePrimitive]=\"false\"\n                    [data]=\"zoomOptionsData\"\n                    [value]=\"currentZoom\"\n                    [title]=\"localeMessage\"\n                    (valueChange)=\"zoomLevelChange($event)\"\n                >\n                </kendo-dropdownlist>\n            </kendo-dialog>\n        </ng-template>\n    `,\n    styles: [`\n        .zoom-level-btn {\n            width: 100%;\n        }\n\n        .zoom-level-btn .k-button-text {\n            width: inherit;\n        }\n\n        .zoom-level-btn .zoom-level-btn-content {\n            display: flex;\n            align-items: center;\n            justify-content: space-between;\n        }\n    `],\n    encapsulation: ViewEncapsulation.None\n})\nexport class CustomZoomComponent extends ToolBarToolComponent implements AfterViewInit, OnDestroy {\n\n\n    @ViewChild('toolbarTemplate', { static: true }) public override toolbarTemplate!: TemplateRef<unknown>;\n    @ViewChild('popupTemplate', { static: true }) public override popupTemplate!: TemplateRef<unknown>;\n    @ViewChild('toolbarElement') public toolbarElement?: ElementRef;\n    @ViewChild('popupElement') public popupElement?: ElementRef;\n    @ViewChild('zoomButton') public zoomButton?: ElementRef;\n    @ViewChild('combobox', { read: ComboBoxComponent, static: false }) public combobox?: ComboBoxComponent;\n\n    public openDialog: boolean = false;\n    public tabindex: number = -1;\n    public zoomOptionsData: ZoomLevel[] = zoomOptionsData;\n    public currentZoom: ZoomLevel = zoomOptionsData[5];\n    public windowRestoreIcon: SVGIcon = windowRestoreIcon;\n\n    private subs: Subscription = new Subscription();\n\n    constructor(public service: ReportingAngularViewerService) {\n        super();\n    }\n\n    public override canFocus(): boolean {\n        return true; // marks the tools as focusable\n    }\n\n    public override focus(): void {\n        if (!isDocumentAvailable()) return;\n\n        this.tabindex = 0;\n\n        if (this.overflows) {\n            this.zoomButton?.nativeElement.focus();\n        } else {\n            this.combobox?.focus();\n            this.combobox?.wrapper.nativeElement.focus();\n        }\n    }\n\n    public override handleKey(): boolean {\n        this.tabindex = -1;\n        return false;\n    }\n\n    public ngAfterViewInit(): void {\n        this.subs.add(this.service.onZoomChange.subscribe(zoomLevel => {\n            this.currentZoom = zoomOptionsData?.find(zoomData => zoomData.value === zoomLevel) as ZoomLevel;\n        }));\n    }\n\n    public ngOnDestroy(): void {\n        this.subs.unsubscribe();\n    }\n\n    public zoomLevelChange(zoomLevel: ZoomLevel): void {\n        if (!isDocumentAvailable()) return;\n\n        const defaultZoom = zoomOptionsData.filter(zoom => zoom.value === 1)[0];\n\n        if (!zoomLevel && this.currentZoom === defaultZoom) { \n            this.currentZoom = defaultZoom; \n            return;\n        }\n\n        if (!zoomLevel && this.currentZoom !== defaultZoom) {\n            this.currentZoom = defaultZoom;\n        }\n\n        if (zoomLevel) this.currentZoom = zoomLevel;\n\n        this.service.setScaleMode(this.getScaleModeAsNumber(this.currentZoom.type as ScaleMode));\n\n        if (this.currentZoom.type === 'specific') {\n            this.service.setScale(<number>this.currentZoom.value);\n        }\n    }\n\n    public get localeMessage(): string {\n        return this.service.options.messages[`ReportViewer_ToolbarZoomComboBoxPlaceholderText`];\n    }\n\n    private getScaleModeAsNumber(scaleMode: ScaleMode): number {\n        return scaleMode === 'fitPage' ? 0 : scaleMode === 'fitPageWidth' ? 1 : 2;\n    }\n}"]}