@progress/telerik-angular-native-report-viewer
Version:
Progress® Telerik® Native Report Viewer for Angular
214 lines (212 loc) • 24.8 kB
JavaScript
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}"]}