mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-12 17:04:57 +00:00
* reload table cells on node updates * update unit tests * update dynamic columns * fix value type * fix tests * update code as per review * update variable name * test fixes, core automation service * fix test
110 lines
3.6 KiB
TypeScript
110 lines
3.6 KiB
TypeScript
/*!
|
|
* @license
|
|
* Copyright 2019 Alfresco Software, Ltd.
|
|
*
|
|
* 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 { DataRow, ObjectUtils, ThumbnailService, ContentService } from '@alfresco/adf-core';
|
|
import { MinimalNode, NodeEntry } from '@alfresco/js-api';
|
|
import { PermissionStyleModel } from './../models/permissions-style.model';
|
|
|
|
export class ShareDataRow implements DataRow {
|
|
|
|
static ERR_OBJECT_NOT_FOUND: string = 'Object source not found';
|
|
|
|
cache: { [key: string]: any } = {};
|
|
isSelected: boolean = false;
|
|
isDropTarget: boolean;
|
|
cssClass: string = '';
|
|
|
|
get node(): NodeEntry {
|
|
return this.obj;
|
|
}
|
|
|
|
set node(value: NodeEntry) {
|
|
this.obj = value;
|
|
this.cache = {};
|
|
}
|
|
|
|
constructor(private obj: NodeEntry,
|
|
private contentService: ContentService,
|
|
private permissionsStyle: PermissionStyleModel[],
|
|
private thumbnailService?: ThumbnailService) {
|
|
if (!obj) {
|
|
throw new Error(ShareDataRow.ERR_OBJECT_NOT_FOUND);
|
|
}
|
|
|
|
this.isDropTarget = this.isFolderAndHasPermissionToUpload(obj);
|
|
|
|
if (permissionsStyle) {
|
|
this.cssClass = this.getPermissionClass(obj);
|
|
}
|
|
}
|
|
|
|
getPermissionClass(nodeEntity: NodeEntry): string {
|
|
let permissionsClasses = '';
|
|
|
|
this.permissionsStyle.forEach((currentPermissionsStyle: PermissionStyleModel) => {
|
|
|
|
if (this.applyPermissionStyleToFolder(nodeEntity.entry, currentPermissionsStyle) || this.applyPermissionStyleToFile(nodeEntity.entry, currentPermissionsStyle)) {
|
|
|
|
if (this.contentService.hasAllowableOperations(nodeEntity.entry, currentPermissionsStyle.permission)) {
|
|
permissionsClasses += ` ${currentPermissionsStyle.css}`;
|
|
}
|
|
}
|
|
|
|
});
|
|
|
|
return permissionsClasses;
|
|
}
|
|
|
|
private applyPermissionStyleToFile(node: MinimalNode, currentPermissionsStyle: PermissionStyleModel): boolean {
|
|
return (currentPermissionsStyle.isFile && node.isFile);
|
|
}
|
|
|
|
private applyPermissionStyleToFolder(node: MinimalNode, currentPermissionsStyle: PermissionStyleModel): boolean {
|
|
return (currentPermissionsStyle.isFolder && node.isFolder);
|
|
}
|
|
|
|
isFolderAndHasPermissionToUpload(nodeEntry: NodeEntry): boolean {
|
|
return this.isFolder(nodeEntry) && this.contentService.hasAllowableOperations(nodeEntry.entry, 'create');
|
|
}
|
|
|
|
isFolder(nodeEntry: NodeEntry): boolean {
|
|
return nodeEntry.entry && nodeEntry.entry.isFolder;
|
|
}
|
|
|
|
cacheValue(key: string, value: any): any {
|
|
this.cache[key] = value;
|
|
return value;
|
|
}
|
|
|
|
getValue(key: string): any {
|
|
if (this.cache[key] !== undefined) {
|
|
return this.cache[key];
|
|
}
|
|
return ObjectUtils.getValue(this.obj.entry, key);
|
|
}
|
|
|
|
imageErrorResolver(event: Event): any {
|
|
if (this.obj.entry.content) {
|
|
return this.thumbnailService.getMimeTypeIcon(this.obj.entry.content.mimeType);
|
|
}
|
|
}
|
|
|
|
hasValue(key: string): boolean {
|
|
return this.getValue(key) !== undefined;
|
|
}
|
|
}
|