stimulsoft-viewer-angular
Version:
Stimulsoft Viewer Angular
149 lines • 17.9 kB
JavaScript
import { Component, ViewChild } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "../services/model.service";
import * as i2 from "../services/controller.service";
import * as i3 from "../services/helper.service";
import * as i4 from "@angular/common";
import * as i5 from "../controls/button.component";
export class ResourcesPanelComponent {
constructor(model, controller, helper) {
this.model = model;
this.controller = controller;
this.helper = helper;
controller.getMessage().subscribe((message) => {
if (message.action === 'GetReport' || message.action === 'OpenReport') {
this.model.controls.resourcesPanel.visible = this.model.reportParams.resources?.length > 0;
}
});
}
ngOnInit() { }
ngAfterViewInit() {
this.model.controls.resourcesPanel.el = this.element;
}
action(resource) {
const resTypesAllowedViewInBrowser = ['Image', 'Pdf', 'Txt'];
const viewType = resTypesAllowedViewInBrowser.indexOf(resource.type) >= 0 ? 'View' : 'SaveFile';
this.controller.postReportResource(resource.name, this.model.options.jsMode ? 'SaveFile' : viewType);
}
getResourceImage(resourceType) {
if (this.model.img('BigResource' + resourceType + '.png') !== '') {
return 'BigResource' + resourceType + '.png';
}
else {
return 'BigResource.png';
}
}
getMenuItems(resource) {
const items = [];
items.push({ name: 'Resource' + 'View', caption: this.model.loc('ButtonView'), value: resource });
items.push({ name: 'Resource' + 'SaveFile', caption: this.model.loc('SaveFile'), value: resource });
return items;
}
getActionName(resource) {
if (!resource.id) {
resource.id = Math.random().toString();
}
return 'resource' + resource.name + resource.id;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ResourcesPanelComponent, deps: [{ token: i1.ModelService }, { token: i2.ControllerService }, { token: i3.HelperService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ResourcesPanelComponent, selector: "sti-resources-panel", viewQueries: [{ propertyName: "element", first: true, predicate: ["element"], descendants: true }], ngImport: i0, template: `
<div
[]="this.model.controls.resourcesPanel.visible ? '' : 'none'"
[]="model.options.toolbar.fontFamily"
[]="model.options.toolbar.fontColor"
[]="'stiJsViewerToolBar' + (model.options.toolbar.displayMode == 'Separated' ? ' stiJsViewerToolBarSeparated' : '')">
<div [style.paddingTop]="model.options.toolbar.displayMode == 'Simple' ? '2px' : ''">
<div class="stiJsViewerToolBarTable" [style.boxSizing]="'border-box'" [style.display]="'table'"
[]="model.options.toolbar.displayMode == 'Separated' ? '0px' : ''">
<table class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0">
<tbody>
<tr class="stiJsViewerClearAllStyles">
<td *ngFor="let resource of model.reportParams.resources" class="stiJsViewerClearAllStyles">
<sti-button [caption]="resource.name"
[]="helper.getHumanFileSize(resource.size, 1)"
[]="getResourceImage(resource.type)"
[]="'stiJsViewerFormButton'"
[]="'auto'"
[]="'3px 0 3px 3px'"
[]="'100%'"
[]="'80px'"
[]="'left'"
[]="'3px'"
[]="'150px'"
[]="'14px'"
[]="'nowrap'"
[]="'hidden'"
[]="'ellipsis'"
[]="'1px'"
[]="'4px 8px 4px 4px'"
[]="getMenuItems(resource)"
[]="true"
[]="32"
[]="32"
[]="getActionName(resource)"
(action)="action(resource)">
</sti-button>
</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
`, isInline: true, dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "component", type: i5.ButtonComponent, selector: "sti-button", inputs: ["caption", "caption2", "captionAlign", "captionPadding", "captionPaddingLeft", "captionWhiteSpace", "captionOverflow", "captionTextOverflow", "captionWidth", "captionMaxWidth", "captionLineHeight", "imageName", "arrow", "arrowMarginTop", "margin", "height", "selected", "minWidth", "innerTableWidth", "menuItems", "actionName", "tooltip", "imageCellTextAlign", "imageCellWidth", "imageCellPadding", "imageSizesWidth", "imageSizesHeight", "imageMargin", "width", "display", "closeButton", "resourceButton", "styleColors", "boxSizing", "navagationPanelTooltip", "cursor", "fontSize", "helpLink", "borderColor", "styleName", "enabled"], outputs: ["action", "closeButtonAction"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ResourcesPanelComponent, decorators: [{
type: Component,
args: [{
selector: 'sti-resources-panel',
template: `
<div
[]="this.model.controls.resourcesPanel.visible ? '' : 'none'"
[]="model.options.toolbar.fontFamily"
[]="model.options.toolbar.fontColor"
[]="'stiJsViewerToolBar' + (model.options.toolbar.displayMode == 'Separated' ? ' stiJsViewerToolBarSeparated' : '')">
<div [style.paddingTop]="model.options.toolbar.displayMode == 'Simple' ? '2px' : ''">
<div class="stiJsViewerToolBarTable" [style.boxSizing]="'border-box'" [style.display]="'table'"
[]="model.options.toolbar.displayMode == 'Separated' ? '0px' : ''">
<table class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0">
<tbody>
<tr class="stiJsViewerClearAllStyles">
<td *ngFor="let resource of model.reportParams.resources" class="stiJsViewerClearAllStyles">
<sti-button [caption]="resource.name"
[]="helper.getHumanFileSize(resource.size, 1)"
[]="getResourceImage(resource.type)"
[]="'stiJsViewerFormButton'"
[]="'auto'"
[]="'3px 0 3px 3px'"
[]="'100%'"
[]="'80px'"
[]="'left'"
[]="'3px'"
[]="'150px'"
[]="'14px'"
[]="'nowrap'"
[]="'hidden'"
[]="'ellipsis'"
[]="'1px'"
[]="'4px 8px 4px 4px'"
[]="getMenuItems(resource)"
[]="true"
[]="32"
[]="32"
[]="getActionName(resource)"
(action)="action(resource)">
</sti-button>
</td>
</tr>
</tbody>
</table>
</div>
</div>
</div>
`
}]
}], ctorParameters: () => [{ type: i1.ModelService }, { type: i2.ControllerService }, { type: i3.HelperService }], propDecorators: { element: [{
type: ViewChild,
args: ['element']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resources-panel.component.js","sourceRoot":"","sources":["../../../../../projects/stimulsoft-viewer-angular/src/lib/components/resources-panel.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, ViewChild, ElementRef } from '@angular/core';\r\nimport { ModelService } from '../services/model.service';\r\nimport { ControllerService } from '../services/controller.service';\r\nimport { Message, Resource } from '../services/objects';\r\nimport { HelperService } from '../services/helper.service';\r\nimport { MenuItem } from '../menu/meni-item.component';\r\n\r\n@Component({\r\n  selector: 'sti-resources-panel',\r\n  template: `\r\n    <div #element [style.zIndex]=\"3\"\r\n      [style.display]=\"this.model.controls.resourcesPanel.visible ? '' : 'none'\"\r\n      [style.fontFamily]=\"model.options.toolbar.fontFamily\"\r\n      [style.fontColor]=\"model.options.toolbar.fontColor\"\r\n      [class]=\"'stiJsViewerToolBar' + (model.options.toolbar.displayMode == 'Separated' ? ' stiJsViewerToolBarSeparated' : '')\">\r\n      <div [style.paddingTop]=\"model.options.toolbar.displayMode == 'Simple' ? '2px' : ''\">\r\n        <div class=\"stiJsViewerToolBarTable\" [style.boxSizing]=\"'border-box'\" [style.display]=\"'table'\"\r\n          [style.border]=\"model.options.toolbar.displayMode == 'Separated' ? '0px' : ''\">\r\n          <table class=\"stiJsViewerClearAllStyles\" cellpadding=\"0\" cellspacing=\"0\">\r\n            <tbody>\r\n              <tr class=\"stiJsViewerClearAllStyles\">\r\n                <td *ngFor=\"let resource of model.reportParams.resources\" class=\"stiJsViewerClearAllStyles\">\r\n                  <sti-button [caption]=\"resource.name\"\r\n                    [caption2]=\"helper.getHumanFileSize(resource.size, 1)\"\r\n                    [imageName]=\"getResourceImage(resource.type)\"\r\n                    [styleName]=\"'stiJsViewerFormButton'\"\r\n                    [height]=\"'auto'\"\r\n                    [margin]=\"'3px 0 3px 3px'\"\r\n                    [innerTableWidth]=\"'100%'\"\r\n                    [minWidth]=\"'80px'\"\r\n                    [captionAlign]=\"'left'\"\r\n                    [captionPaddingLeft]=\"'3px'\"\r\n                    [captionMaxWidth]=\"'150px'\"\r\n                    [captionLineHeight]=\"'14px'\"\r\n                    [captionWhiteSpace]=\"'nowrap'\"\r\n                    [captionOverflow]=\"'hidden'\"\r\n                    [captionTextOverflow]=\"'ellipsis'\"\r\n                    [imageCellWidth]=\"'1px'\"\r\n                    [imageCellPadding]=\"'4px 8px 4px 4px'\"\r\n                    [menuItems]=\"getMenuItems(resource)\"\r\n                    [resourceButton]=\"true\"\r\n                    [imageSizesWidth]=\"32\"\r\n                    [imageSizesHeight]=\"32\"\r\n                    [actionName]=\"getActionName(resource)\"\r\n                    (action)=\"action(resource)\">\r\n                  </sti-button>\r\n                </td>\r\n              </tr>\r\n            </tbody>\r\n          </table>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  `\r\n})\r\n\r\nexport class ResourcesPanelComponent implements OnInit, AfterViewInit {\r\n\r\n  @ViewChild('element') element: ElementRef;\r\n\r\n  constructor(public model: ModelService, public controller: ControllerService, public helper: HelperService) {\r\n    controller.getMessage().subscribe((message: Message) => {\r\n      if (message.action === 'GetReport' || message.action === 'OpenReport') {\r\n        this.model.controls.resourcesPanel.visible = this.model.reportParams.resources?.length > 0;\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnInit() { }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.model.controls.resourcesPanel.el = this.element;\r\n  }\r\n\r\n  action(resource: Resource) {\r\n    const resTypesAllowedViewInBrowser = ['Image', 'Pdf', 'Txt'];\r\n    const viewType = resTypesAllowedViewInBrowser.indexOf(resource.type) >= 0 ? 'View' : 'SaveFile';\r\n    this.controller.postReportResource(resource.name, this.model.options.jsMode ? 'SaveFile' : viewType);\r\n  }\r\n\r\n  getResourceImage(resourceType: string): string {\r\n    if (this.model.img('BigResource' + resourceType + '.png') !== '') {\r\n      return 'BigResource' + resourceType + '.png';\r\n    } else {\r\n      return 'BigResource.png';\r\n    }\r\n  }\r\n\r\n  getMenuItems(resource: Resource): MenuItem[] {\r\n    const items: MenuItem[] = [];\r\n    items.push({ name: 'Resource' + 'View', caption: this.model.loc('ButtonView'), value: resource });\r\n    items.push({ name: 'Resource' + 'SaveFile', caption: this.model.loc('SaveFile'), value: resource });\r\n    return items;\r\n  }\r\n\r\n  getActionName(resource: Resource): string {\r\n    if (!resource.id) {\r\n      resource.id = Math.random().toString();\r\n    }\r\n    return 'resource' + resource.name + resource.id;\r\n  }\r\n}\r\n"]}