mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-12 17:04:57 +00:00
* ACS-7393: content metadata as standalone * ACS-7408: version manager as standalone * ACS-7408: version manager as standalone * ACS-7408: version manager as standalone * ACS-7407: upload as standalone * ACS-7404: tag as standalone * ACS-7404: tag as standalone * ACS-7401: permission manager as standalone * ACS-7395: content node share as standalone * ACS-7402: search components [ci:force] * ACS-7402: search components [ci:force] * content node selector panel * content node selector panel * Revert "content node selector panel" This reverts commit 3ad828e443a51b9c058f97d3c9090ed0f5b2519f. * Revert "content node selector panel" This reverts commit 5a2cd5a5b32bed1ad0b0ca6004c39aaaac751b42.
98 lines
3.7 KiB
TypeScript
98 lines
3.7 KiB
TypeScript
/*!
|
|
* @license
|
|
* Copyright © 2005-2024 Hyland Software, Inc. and its affiliates. All rights reserved.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
import { Node, NodeEntry, PermissionElement } from '@alfresco/js-api';
|
|
import { Component, EventEmitter, Input, OnInit, Output, ViewEncapsulation } from '@angular/core';
|
|
import { NodePermissionService } from '../../services/node-permission.service';
|
|
import { RoleModel } from '../../models/role.model';
|
|
import { ContentService } from '../../../common/services/content.service';
|
|
import { AllowableOperationsEnum } from '../../../common/models/allowable-operations.enum';
|
|
import { CommonModule } from '@angular/common';
|
|
import { AddPermissionPanelComponent } from './add-permission-panel.component';
|
|
import { MatButtonModule } from '@angular/material/button';
|
|
import { TranslateModule } from '@ngx-translate/core';
|
|
|
|
@Component({
|
|
selector: 'adf-add-permission',
|
|
standalone: true,
|
|
imports: [CommonModule, AddPermissionPanelComponent, MatButtonModule, TranslateModule],
|
|
templateUrl: './add-permission.component.html',
|
|
styleUrls: ['./add-permission.component.scss'],
|
|
encapsulation: ViewEncapsulation.None
|
|
})
|
|
/*
|
|
* @deprecated in 4.4.0, use adf-add-permission-panel instead.
|
|
*/
|
|
export class AddPermissionComponent implements OnInit {
|
|
/** ID of the target node. */
|
|
@Input()
|
|
nodeId: string;
|
|
|
|
/** Emitted when the node is updated successfully. */
|
|
@Output()
|
|
success = new EventEmitter<Node>();
|
|
|
|
/** Emitted when an error occurs during the update. */
|
|
@Output()
|
|
error = new EventEmitter<any>();
|
|
|
|
selectedItems: NodeEntry[] = [];
|
|
currentNode: Node;
|
|
currentNodeRoles: RoleModel[];
|
|
|
|
constructor(private nodePermissionService: NodePermissionService, private contentService: ContentService) {}
|
|
|
|
ngOnInit(): void {
|
|
this.nodePermissionService.getNodeWithRoles(this.nodeId).subscribe(({ node, roles }) => {
|
|
this.currentNode = node;
|
|
this.currentNodeRoles = roles;
|
|
});
|
|
}
|
|
|
|
onSelect(selection: NodeEntry[]) {
|
|
this.selectedItems = selection;
|
|
}
|
|
|
|
isAddEnabled(): boolean {
|
|
return (
|
|
this.contentService.hasAllowableOperations(this.currentNode, AllowableOperationsEnum.UPDATEPERMISSIONS) && this.selectedItems.length !== 0
|
|
);
|
|
}
|
|
|
|
applySelection() {
|
|
if (this.contentService.hasAllowableOperations(this.currentNode, AllowableOperationsEnum.UPDATEPERMISSIONS)) {
|
|
const permissions = this.transformNodeToPermissionElement(this.selectedItems, this.currentNodeRoles[0].role);
|
|
this.nodePermissionService.updateNodePermissions(this.nodeId, permissions).subscribe(
|
|
(node) => {
|
|
this.success.emit(node);
|
|
},
|
|
(error) => {
|
|
this.error.emit(error);
|
|
}
|
|
);
|
|
}
|
|
}
|
|
|
|
private transformNodeToPermissionElement(nodes: NodeEntry[], role: string): PermissionElement[] {
|
|
return nodes.map((node) => ({
|
|
authorityId: node.entry.properties['cm:authorityName'] ?? node.entry.properties['cm:userName'],
|
|
name: role,
|
|
accessStatus: 'ALLOWED'
|
|
}));
|
|
}
|
|
}
|