UNPKG

stimulsoft-viewer-angular

Version:
258 lines (248 loc) 28.6 kB
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 [width]="160" [tooltip]="model.loc('UserPasswordTooltip')" [margin]="'8px 8px 2px 8px'" [type]="getTextBoxType()" [value]="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 [width]="160" [tooltip]="model.loc('OwnerPasswordTooltip')" [margin]="'2px 8px 2px 8px'" [type]="getTextBoxType()" [value]="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 #AllowPrintDocument [captionText]="model.loc('AllowPrintDocument')" [tooltip]="model.loc('AllowPrintDocumentTooltip')" [margin]="'4px 8px 4px 8px'" [isChecked]="getUserAccessPrivileges('PrintDocument')" (action)="updateUserAccessPrivileges()"> </sti-check-box> </td> </tr> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles" colspan="2"> <sti-check-box #AllowModifyContents [captionText]="model.loc('AllowModifyContents')" [tooltip]="model.loc('AllowModifyContentsTooltip')" [margin]="'4px 8px 4px 8px'" [isChecked]="getUserAccessPrivileges('ModifyContents')" (action)="updateUserAccessPrivileges()"> </sti-check-box> </td> </tr> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles" colspan="2"> <sti-check-box #AllowCopyTextAndGraphics [captionText]="model.loc('AllowCopyTextAndGraphics')" [tooltip]="model.loc('AllowCopyTextAndGraphicsTooltip')" [margin]="'4px 8px 4px 8px'" [isChecked]="getUserAccessPrivileges('CopyTextAndGraphics')" (action)="updateUserAccessPrivileges()"> </sti-check-box> </td> </tr> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles" colspan="2"> <sti-check-box #AllowAddOrModifyTextAnnotations [captionText]="model.loc('AllowAddOrModifyTextAnnotations')" [tooltip]="model.loc('AllowAddOrModifyTextAnnotationsTooltip')" [margin]="'4px 8px 4px 8px'" [isChecked]="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 [width]="160" [items]="collections.getEncryptionKeyLengthItems()" [key]="exportService.exportSettings?.KeyLength" [margin]="'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 [width]="160" [tooltip]="model.loc('UserPasswordTooltip')" [margin]="'8px 8px 2px 8px'" [type]="getTextBoxType()" [value]="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 [width]="160" [tooltip]="model.loc('OwnerPasswordTooltip')" [margin]="'2px 8px 2px 8px'" [type]="getTextBoxType()" [value]="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 #AllowPrintDocument [captionText]="model.loc('AllowPrintDocument')" [tooltip]="model.loc('AllowPrintDocumentTooltip')" [margin]="'4px 8px 4px 8px'" [isChecked]="getUserAccessPrivileges('PrintDocument')" (action)="updateUserAccessPrivileges()"> </sti-check-box> </td> </tr> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles" colspan="2"> <sti-check-box #AllowModifyContents [captionText]="model.loc('AllowModifyContents')" [tooltip]="model.loc('AllowModifyContentsTooltip')" [margin]="'4px 8px 4px 8px'" [isChecked]="getUserAccessPrivileges('ModifyContents')" (action)="updateUserAccessPrivileges()"> </sti-check-box> </td> </tr> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles" colspan="2"> <sti-check-box #AllowCopyTextAndGraphics [captionText]="model.loc('AllowCopyTextAndGraphics')" [tooltip]="model.loc('AllowCopyTextAndGraphicsTooltip')" [margin]="'4px 8px 4px 8px'" [isChecked]="getUserAccessPrivileges('CopyTextAndGraphics')" (action)="updateUserAccessPrivileges()"> </sti-check-box> </td> </tr> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles" colspan="2"> <sti-check-box #AllowAddOrModifyTextAnnotations [captionText]="model.loc('AllowAddOrModifyTextAnnotations')" [tooltip]="model.loc('AllowAddOrModifyTextAnnotationsTooltip')" [margin]="'4px 8px 4px 8px'" [isChecked]="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 [width]="160" [items]="collections.getEncryptionKeyLengthItems()" [key]="exportService.exportSettings?.KeyLength" [margin]="'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"]}