stimulsoft-viewer-angular
Version:
Stimulsoft Viewer Angular
258 lines (248 loc) • 28.6 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 "../forms/form.service";
import * as i3 from "../services/export.service";
import * as i4 from "../services/collections.service";
import * as i5 from "../controls/text-box.componet";
import * as i6 from "../controls/checkbox.component";
import * as i7 from "../controls/drop-down-list-for-export-form.component";
export class DocumentSecurityMenuComponent {
constructor(model, formService, exportService, collections) {
this.model = model;
this.formService = formService;
this.exportService = exportService;
this.collections = collections;
}
ngOnInit() { }
getTextBoxType() {
return this.formService.form?.name === 'exportForm' ? 'password' : '';
}
updateUserAccessPrivileges() {
const privileges = [];
if (this.allowPrintDocument.isChecked) {
privileges.push('PrintDocument');
}
if (this.allowModifyContents.isChecked) {
privileges.push('ModifyContents');
}
if (this.allowCopyTextAndGraphics.isChecked) {
privileges.push('CopyTextAndGraphics');
}
if (this.allowAddOrModifyTextAnnotations.isChecked) {
privileges.push('AddOrModifyTextAnnotations');
}
this.exportService.exportSettings.UserAccessPrivileges = privileges.join(',');
}
getUserAccessPrivileges(name) {
return this.exportService.exportSettings?.UserAccessPrivileges === 'All' || this.exportService.exportSettings?.UserAccessPrivileges?.indexOf(name) >= 0;
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DocumentSecurityMenuComponent, deps: [{ token: i1.ModelService }, { token: i2.FormService }, { token: i3.ExportService }, { token: i4.CollectionsService }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: DocumentSecurityMenuComponent, selector: "sti-document-security-menu", viewQueries: [{ propertyName: "allowPrintDocument", first: true, predicate: ["AllowPrintDocument"], descendants: true }, { propertyName: "allowModifyContents", first: true, predicate: ["AllowModifyContents"], descendants: true }, { propertyName: "allowCopyTextAndGraphics", first: true, predicate: ["AllowCopyTextAndGraphics"], descendants: true }, { propertyName: "allowAddOrModifyTextAnnotations", first: true, predicate: ["AllowAddOrModifyTextAnnotations"], descendants: true }], ngImport: i0, template: `
<table class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0" [style.width]="'100%'">
<tbody>
<tr class="stiJsViewerClearAllStyles">
<td [style.padding]="'0px 8px'" [style.minWidth.px]="150" [attr.title]="model.loc('UserPasswordTooltip')">
{{model.loc('UserPassword')}}
</td>
<td class="stiJsViewerClearAllStyles">
<sti-text-box
[]="160"
[]="model.loc('UserPasswordTooltip')"
[]="'8px 8px 2px 8px'"
[]="getTextBoxType()"
[]="exportService.exportSettings?.PasswordInputUser"
(onchange)="exportService.exportSettings.PasswordInputUser = $event.value">
</sti-text-box>
</td>
</tr>
<tr class="stiJsViewerClearAllStyles" [attr.title]="model.loc('OwnerPasswordTooltip')">
<td [style.padding]="'0px 8px'" [style.minWidth.px]="150">
{{model.loc('OwnerPassword')}}
</td>
<td class="stiJsViewerClearAllStyles">
<sti-text-box
[]="160"
[]="model.loc('OwnerPasswordTooltip')"
[]="'2px 8px 2px 8px'"
[]="getTextBoxType()"
[]="exportService.exportSettings?.PasswordInputOwner"
(onchange)="exportService.exportSettings.PasswordInputOwner = $event.value">
</sti-text-box>
</td>
</tr>
<tr class="stiJsViewerClearAllStyles">
<td class="stiJsViewerClearAllStyles" colspan="2">
<sti-check-box
[]="model.loc('AllowPrintDocument')"
[]="model.loc('AllowPrintDocumentTooltip')"
[]="'4px 8px 4px 8px'"
[]="getUserAccessPrivileges('PrintDocument')"
(action)="updateUserAccessPrivileges()">
</sti-check-box>
</td>
</tr>
<tr class="stiJsViewerClearAllStyles">
<td class="stiJsViewerClearAllStyles" colspan="2">
<sti-check-box
[]="model.loc('AllowModifyContents')"
[]="model.loc('AllowModifyContentsTooltip')"
[]="'4px 8px 4px 8px'"
[]="getUserAccessPrivileges('ModifyContents')"
(action)="updateUserAccessPrivileges()">
</sti-check-box>
</td>
</tr>
<tr class="stiJsViewerClearAllStyles">
<td class="stiJsViewerClearAllStyles" colspan="2">
<sti-check-box
[]="model.loc('AllowCopyTextAndGraphics')"
[]="model.loc('AllowCopyTextAndGraphicsTooltip')"
[]="'4px 8px 4px 8px'"
[]="getUserAccessPrivileges('CopyTextAndGraphics')"
(action)="updateUserAccessPrivileges()">
</sti-check-box>
</td>
</tr>
<tr class="stiJsViewerClearAllStyles">
<td class="stiJsViewerClearAllStyles" colspan="2">
<sti-check-box
[]="model.loc('AllowAddOrModifyTextAnnotations')"
[]="model.loc('AllowAddOrModifyTextAnnotationsTooltip')"
[]="'4px 8px 4px 8px'"
[]="getUserAccessPrivileges('AddOrModifyTextAnnotations')"
(action)="updateUserAccessPrivileges()">
</sti-check-box>
</td>
</tr>
<tr class="stiJsViewerClearAllStyles">
<td class="stiJsViewerClearAllStyles" [style.padding]="'0px 8px'" [style.minWidth.px]="150" [attr.title]="model.loc('EncryptionKeyLengthTooltip')">
{{model.loc('EncryptionKeyLength')}}
</td>
<td>
<sti-drop-down-list-for-export-form
[]="160"
[]="collections.getEncryptionKeyLengthItems()"
[]="exportService.exportSettings?.KeyLength"
[]="'2px 8px 4px 8px'"
(action)="exportService.exportSettings.KeyLength = $event.key">
</sti-drop-down-list-for-export-form>
</td>
</tr>
</tbody>
</table>
`, isInline: true, dependencies: [{ kind: "component", type: i5.TextBoxComponent, selector: "sti-text-box", inputs: ["width", "actionLostFocus", "tooltip", "enabled", "value", "margin", "focusOnCreate", "maxLength", "color", "type", "padding", "border", "variable", "textAlign", "autocomplete", "readOnly"], outputs: ["action", "onchange", "onblur"] }, { kind: "component", type: i6.CheckboxComponent, selector: "sti-check-box", inputs: ["isEnabled", "isChecked", "indeterminate", "captionText", "tooltip", "margin", "width", "styleColors", "imageBlockParentWidth", "nullable"], outputs: ["action"] }, { kind: "component", type: i7.DropDownListForExportFormComponent, selector: "sti-drop-down-list-for-export-form", inputs: ["items", "width", "key", "margin", "enabled", "styleDisplay", "verticalAlign"], outputs: ["action"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: DocumentSecurityMenuComponent, decorators: [{
type: Component,
args: [{
selector: 'sti-document-security-menu',
template: `
<table class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0" [style.width]="'100%'">
<tbody>
<tr class="stiJsViewerClearAllStyles">
<td [style.padding]="'0px 8px'" [style.minWidth.px]="150" [attr.title]="model.loc('UserPasswordTooltip')">
{{model.loc('UserPassword')}}
</td>
<td class="stiJsViewerClearAllStyles">
<sti-text-box
[]="160"
[]="model.loc('UserPasswordTooltip')"
[]="'8px 8px 2px 8px'"
[]="getTextBoxType()"
[]="exportService.exportSettings?.PasswordInputUser"
(onchange)="exportService.exportSettings.PasswordInputUser = $event.value">
</sti-text-box>
</td>
</tr>
<tr class="stiJsViewerClearAllStyles" [attr.title]="model.loc('OwnerPasswordTooltip')">
<td [style.padding]="'0px 8px'" [style.minWidth.px]="150">
{{model.loc('OwnerPassword')}}
</td>
<td class="stiJsViewerClearAllStyles">
<sti-text-box
[]="160"
[]="model.loc('OwnerPasswordTooltip')"
[]="'2px 8px 2px 8px'"
[]="getTextBoxType()"
[]="exportService.exportSettings?.PasswordInputOwner"
(onchange)="exportService.exportSettings.PasswordInputOwner = $event.value">
</sti-text-box>
</td>
</tr>
<tr class="stiJsViewerClearAllStyles">
<td class="stiJsViewerClearAllStyles" colspan="2">
<sti-check-box
[]="model.loc('AllowPrintDocument')"
[]="model.loc('AllowPrintDocumentTooltip')"
[]="'4px 8px 4px 8px'"
[]="getUserAccessPrivileges('PrintDocument')"
(action)="updateUserAccessPrivileges()">
</sti-check-box>
</td>
</tr>
<tr class="stiJsViewerClearAllStyles">
<td class="stiJsViewerClearAllStyles" colspan="2">
<sti-check-box
[]="model.loc('AllowModifyContents')"
[]="model.loc('AllowModifyContentsTooltip')"
[]="'4px 8px 4px 8px'"
[]="getUserAccessPrivileges('ModifyContents')"
(action)="updateUserAccessPrivileges()">
</sti-check-box>
</td>
</tr>
<tr class="stiJsViewerClearAllStyles">
<td class="stiJsViewerClearAllStyles" colspan="2">
<sti-check-box
[]="model.loc('AllowCopyTextAndGraphics')"
[]="model.loc('AllowCopyTextAndGraphicsTooltip')"
[]="'4px 8px 4px 8px'"
[]="getUserAccessPrivileges('CopyTextAndGraphics')"
(action)="updateUserAccessPrivileges()">
</sti-check-box>
</td>
</tr>
<tr class="stiJsViewerClearAllStyles">
<td class="stiJsViewerClearAllStyles" colspan="2">
<sti-check-box
[]="model.loc('AllowAddOrModifyTextAnnotations')"
[]="model.loc('AllowAddOrModifyTextAnnotationsTooltip')"
[]="'4px 8px 4px 8px'"
[]="getUserAccessPrivileges('AddOrModifyTextAnnotations')"
(action)="updateUserAccessPrivileges()">
</sti-check-box>
</td>
</tr>
<tr class="stiJsViewerClearAllStyles">
<td class="stiJsViewerClearAllStyles" [style.padding]="'0px 8px'" [style.minWidth.px]="150" [attr.title]="model.loc('EncryptionKeyLengthTooltip')">
{{model.loc('EncryptionKeyLength')}}
</td>
<td>
<sti-drop-down-list-for-export-form
[]="160"
[]="collections.getEncryptionKeyLengthItems()"
[]="exportService.exportSettings?.KeyLength"
[]="'2px 8px 4px 8px'"
(action)="exportService.exportSettings.KeyLength = $event.key">
</sti-drop-down-list-for-export-form>
</td>
</tr>
</tbody>
</table>
`
}]
}], ctorParameters: () => [{ type: i1.ModelService }, { type: i2.FormService }, { type: i3.ExportService }, { type: i4.CollectionsService }], propDecorators: { allowPrintDocument: [{
type: ViewChild,
args: ['AllowPrintDocument']
}], allowModifyContents: [{
type: ViewChild,
args: ['AllowModifyContents']
}], allowCopyTextAndGraphics: [{
type: ViewChild,
args: ['AllowCopyTextAndGraphics']
}], allowAddOrModifyTextAnnotations: [{
type: ViewChild,
args: ['AllowAddOrModifyTextAnnotations']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document-security-menu.component.js","sourceRoot":"","sources":["../../../../../projects/stimulsoft-viewer-angular/src/lib/menu/document-security-menu.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,SAAS,EAAE,MAAM,eAAe,CAAC;;;;;;;;;AA8G7D,MAAM,OAAO,6BAA6B;IAOxC,YAAmB,KAAmB,EAAS,WAAwB,EAAS,aAA4B,EAAS,WAA+B;QAAjI,UAAK,GAAL,KAAK,CAAc;QAAS,gBAAW,GAAX,WAAW,CAAa;QAAS,kBAAa,GAAb,aAAa,CAAe;QAAS,gBAAW,GAAX,WAAW,CAAoB;IAAI,CAAC;IAEzJ,QAAQ,KAAK,CAAC;IAEd,cAAc;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,IAAI,KAAK,YAAY,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC;IACxE,CAAC;IAED,0BAA0B;QACxB,MAAM,UAAU,GAAG,EAAE,CAAC;QACtB,IAAI,IAAI,CAAC,kBAAkB,CAAC,SAAS,EAAE,CAAC;YAAC,UAAU,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAAC,CAAC;QAC5E,IAAI,IAAI,CAAC,mBAAmB,CAAC,SAAS,EAAE,CAAC;YAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QAAC,CAAC;QAC9E,IAAI,IAAI,CAAC,wBAAwB,CAAC,SAAS,EAAE,CAAC;YAAC,UAAU,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;QAAC,CAAC;QACxF,IAAI,IAAI,CAAC,+BAA+B,CAAC,SAAS,EAAE,CAAC;YAAC,UAAU,CAAC,IAAI,CAAC,4BAA4B,CAAC,CAAC;QAAC,CAAC;QACtG,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,oBAAoB,GAAG,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAChF,CAAC;IAED,uBAAuB,CAAC,IAAY;QAClC,OAAO,IAAI,CAAC,aAAa,CAAC,cAAc,EAAE,oBAAoB,KAAK,KAAK,IAAI,IAAI,CAAC,aAAa,CAAC,cAAc,EAAE,oBAAoB,EAAE,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1J,CAAC;+GA1BU,6BAA6B;mGAA7B,6BAA6B,qiBArG9B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAkGX;;4FAGY,6BAA6B;kBAvGzC,SAAS;mBAAC;oBACT,QAAQ,EAAE,4BAA4B;oBACtC,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAkGX;iBACA;wKAIkC,kBAAkB;sBAAlD,SAAS;uBAAC,oBAAoB;gBACG,mBAAmB;sBAApD,SAAS;uBAAC,qBAAqB;gBACO,wBAAwB;sBAA9D,SAAS;uBAAC,0BAA0B;gBACS,+BAA+B;sBAA5E,SAAS;uBAAC,iCAAiC","sourcesContent":["import { Component, OnInit, ViewChild } from '@angular/core';\r\nimport { ModelService } from '../services/model.service';\r\nimport { FormService } from '../forms/form.service';\r\nimport { ExportService } from '../services/export.service';\r\nimport { CollectionsService } from '../services/collections.service';\r\nimport { CheckboxComponent } from '../controls/checkbox.component';\r\n\r\n@Component({\r\n  selector: 'sti-document-security-menu',\r\n  template: `\r\n    <table class=\"stiJsViewerClearAllStyles\" cellpadding=\"0\" cellspacing=\"0\" [style.width]=\"'100%'\">\r\n                  <tbody>\r\n                    <tr class=\"stiJsViewerClearAllStyles\">\r\n                      <td [style.padding]=\"'0px 8px'\" [style.minWidth.px]=\"150\" [attr.title]=\"model.loc('UserPasswordTooltip')\">\r\n                        {{model.loc('UserPassword')}}\r\n                      </td>\r\n                      <td class=\"stiJsViewerClearAllStyles\">\r\n                        <sti-text-box\r\n                           [width]=\"160\"\r\n                           [tooltip]=\"model.loc('UserPasswordTooltip')\"\r\n                           [margin]=\"'8px 8px 2px 8px'\"\r\n                           [type]=\"getTextBoxType()\"\r\n                           [value]=\"exportService.exportSettings?.PasswordInputUser\"\r\n                           (onchange)=\"exportService.exportSettings.PasswordInputUser =  $event.value\">\r\n                        </sti-text-box>\r\n                      </td>\r\n                    </tr>\r\n\r\n                    <tr class=\"stiJsViewerClearAllStyles\" [attr.title]=\"model.loc('OwnerPasswordTooltip')\">\r\n                      <td [style.padding]=\"'0px 8px'\" [style.minWidth.px]=\"150\">\r\n                        {{model.loc('OwnerPassword')}}\r\n                      </td>\r\n                      <td class=\"stiJsViewerClearAllStyles\">\r\n                        <sti-text-box\r\n                           [width]=\"160\"\r\n                           [tooltip]=\"model.loc('OwnerPasswordTooltip')\"\r\n                           [margin]=\"'2px 8px 2px 8px'\"\r\n                           [type]=\"getTextBoxType()\"\r\n                           [value]=\"exportService.exportSettings?.PasswordInputOwner\"\r\n                           (onchange)=\"exportService.exportSettings.PasswordInputOwner =  $event.value\">\r\n                        </sti-text-box>\r\n                      </td>\r\n                    </tr>\r\n\r\n                    <tr class=\"stiJsViewerClearAllStyles\">\r\n                      <td class=\"stiJsViewerClearAllStyles\" colspan=\"2\">\r\n                        <sti-check-box #AllowPrintDocument\r\n                           [captionText]=\"model.loc('AllowPrintDocument')\"\r\n                           [tooltip]=\"model.loc('AllowPrintDocumentTooltip')\"\r\n                           [margin]=\"'4px 8px 4px 8px'\"\r\n                           [isChecked]=\"getUserAccessPrivileges('PrintDocument')\"\r\n                           (action)=\"updateUserAccessPrivileges()\">\r\n                        </sti-check-box>\r\n                      </td>\r\n                    </tr>\r\n\r\n                    <tr class=\"stiJsViewerClearAllStyles\">\r\n                      <td class=\"stiJsViewerClearAllStyles\" colspan=\"2\">\r\n                        <sti-check-box #AllowModifyContents\r\n                           [captionText]=\"model.loc('AllowModifyContents')\"\r\n                           [tooltip]=\"model.loc('AllowModifyContentsTooltip')\"\r\n                           [margin]=\"'4px 8px 4px 8px'\"\r\n                           [isChecked]=\"getUserAccessPrivileges('ModifyContents')\"\r\n                           (action)=\"updateUserAccessPrivileges()\">\r\n                        </sti-check-box>\r\n                      </td>\r\n                    </tr>\r\n\r\n                    <tr class=\"stiJsViewerClearAllStyles\">\r\n                      <td class=\"stiJsViewerClearAllStyles\" colspan=\"2\">\r\n                        <sti-check-box #AllowCopyTextAndGraphics\r\n                           [captionText]=\"model.loc('AllowCopyTextAndGraphics')\"\r\n                           [tooltip]=\"model.loc('AllowCopyTextAndGraphicsTooltip')\"\r\n                           [margin]=\"'4px 8px 4px 8px'\"\r\n                           [isChecked]=\"getUserAccessPrivileges('CopyTextAndGraphics')\"\r\n                           (action)=\"updateUserAccessPrivileges()\">\r\n                        </sti-check-box>\r\n                      </td>\r\n                    </tr>\r\n\r\n                    <tr class=\"stiJsViewerClearAllStyles\">\r\n                      <td class=\"stiJsViewerClearAllStyles\" colspan=\"2\">\r\n                        <sti-check-box #AllowAddOrModifyTextAnnotations\r\n                           [captionText]=\"model.loc('AllowAddOrModifyTextAnnotations')\"\r\n                           [tooltip]=\"model.loc('AllowAddOrModifyTextAnnotationsTooltip')\"\r\n                           [margin]=\"'4px 8px 4px 8px'\"\r\n                           [isChecked]=\"getUserAccessPrivileges('AddOrModifyTextAnnotations')\"\r\n                           (action)=\"updateUserAccessPrivileges()\">\r\n                        </sti-check-box>\r\n                      </td>\r\n                    </tr>\r\n                    <tr class=\"stiJsViewerClearAllStyles\">\r\n                      <td class=\"stiJsViewerClearAllStyles\" [style.padding]=\"'0px 8px'\" [style.minWidth.px]=\"150\" [attr.title]=\"model.loc('EncryptionKeyLengthTooltip')\">\r\n                        {{model.loc('EncryptionKeyLength')}}\r\n                      </td>\r\n                      <td>\r\n                        <sti-drop-down-list-for-export-form\r\n                           [width]=\"160\"\r\n                           [items]=\"collections.getEncryptionKeyLengthItems()\"\r\n                           [key]=\"exportService.exportSettings?.KeyLength\"\r\n                           [margin]=\"'2px 8px 4px 8px'\"\r\n                           (action)=\"exportService.exportSettings.KeyLength = $event.key\">\r\n                        </sti-drop-down-list-for-export-form>\r\n                      </td>\r\n                    </tr>\r\n                  </tbody>\r\n                </table>\r\n`\r\n})\r\n\r\nexport class DocumentSecurityMenuComponent implements OnInit {\r\n\r\n  @ViewChild('AllowPrintDocument') allowPrintDocument: CheckboxComponent;\r\n  @ViewChild('AllowModifyContents') allowModifyContents: CheckboxComponent;\r\n  @ViewChild('AllowCopyTextAndGraphics') allowCopyTextAndGraphics: CheckboxComponent;\r\n  @ViewChild('AllowAddOrModifyTextAnnotations') allowAddOrModifyTextAnnotations: CheckboxComponent;\r\n\r\n  constructor(public model: ModelService, public formService: FormService, public exportService: ExportService, public collections: CollectionsService) { }\r\n\r\n  ngOnInit() { }\r\n\r\n  getTextBoxType() {\r\n    return this.formService.form?.name === 'exportForm' ? 'password' : '';\r\n  }\r\n\r\n  updateUserAccessPrivileges() {\r\n    const privileges = [];\r\n    if (this.allowPrintDocument.isChecked) { privileges.push('PrintDocument'); }\r\n    if (this.allowModifyContents.isChecked) { privileges.push('ModifyContents'); }\r\n    if (this.allowCopyTextAndGraphics.isChecked) { privileges.push('CopyTextAndGraphics'); }\r\n    if (this.allowAddOrModifyTextAnnotations.isChecked) { privileges.push('AddOrModifyTextAnnotations'); }\r\n    this.exportService.exportSettings.UserAccessPrivileges = privileges.join(',');\r\n  }\r\n\r\n  getUserAccessPrivileges(name: string) {\r\n    return this.exportService.exportSettings?.UserAccessPrivileges === 'All' || this.exportService.exportSettings?.UserAccessPrivileges?.indexOf(name) >= 0;\r\n  }\r\n}\r\n"]}