mirror of
https://github.com/Alfresco/alfresco-content-app.git
synced 2025-07-31 17:38:28 +00:00
migrate the NodeNameTooltipPipe
This commit is contained in:
@@ -35,8 +35,6 @@ import { NodeRestoreDirective } from './directives/node-restore.directive';
|
||||
import { NodePermanentDeleteDirective } from './directives/node-permanent-delete.directive';
|
||||
import { NodeFavoriteDirective } from './directives/node-favorite.directive';
|
||||
|
||||
import { NodeNameTooltipPipe } from './pipes/node-name-tooltip.pipe';
|
||||
|
||||
import { ContentManagementService } from './services/content-management.service';
|
||||
import { BrowsingFilesService } from './services/browsing-files.service';
|
||||
import { NodeActionsService } from './services/node-actions.service';
|
||||
@@ -63,9 +61,7 @@ export function declarations() {
|
||||
DownloadFileDirective,
|
||||
NodeRestoreDirective,
|
||||
NodePermanentDeleteDirective,
|
||||
NodeFavoriteDirective,
|
||||
|
||||
NodeNameTooltipPipe
|
||||
NodeFavoriteDirective
|
||||
];
|
||||
}
|
||||
|
||||
|
@@ -1,145 +0,0 @@
|
||||
/*!
|
||||
* @license
|
||||
* Copyright 2017 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 { MinimalNodeEntity } from 'alfresco-js-api';
|
||||
import { NodeNameTooltipPipe } from './node-name-tooltip.pipe';
|
||||
|
||||
describe('NodeNameTooltipPipe', () => {
|
||||
|
||||
const nodeName = 'node-name';
|
||||
const nodeTitle = 'node-title';
|
||||
const nodeDescription = 'node-description';
|
||||
|
||||
let pipe: NodeNameTooltipPipe;
|
||||
|
||||
beforeEach(() => {
|
||||
pipe = new NodeNameTooltipPipe();
|
||||
});
|
||||
|
||||
it('should not transform when missing node', () => {
|
||||
expect(pipe.transform(null)).toBe(null);
|
||||
});
|
||||
|
||||
it('should not transform when missing node entry', () => {
|
||||
expect(pipe.transform(<any> {})).toBe(null);
|
||||
});
|
||||
|
||||
it('should use title and description when all fields present', () => {
|
||||
const node: any = {
|
||||
entry: {
|
||||
name: nodeName,
|
||||
properties: {
|
||||
'cm:title': nodeTitle,
|
||||
'cm:description': nodeDescription
|
||||
}
|
||||
}
|
||||
};
|
||||
let tooltip = pipe.transform(node);
|
||||
expect(tooltip).toBe(`${nodeTitle}\n${nodeDescription}`);
|
||||
});
|
||||
|
||||
it('should use name when other properties are missing', () => {
|
||||
const node = {
|
||||
entry: {
|
||||
name: nodeName
|
||||
}
|
||||
};
|
||||
let tooltip = pipe.transform(<MinimalNodeEntity> node);
|
||||
expect(tooltip).toBe(nodeName);
|
||||
});
|
||||
|
||||
it('should display name when title and description are missing', () => {
|
||||
const node: any = {
|
||||
entry: {
|
||||
name: nodeName,
|
||||
properties: {}
|
||||
}
|
||||
};
|
||||
let tooltip = pipe.transform(node);
|
||||
expect(tooltip).toBe(nodeName);
|
||||
});
|
||||
|
||||
it('should use name and description when title is missing', () => {
|
||||
const node: any = {
|
||||
entry: {
|
||||
name: nodeName,
|
||||
properties: {
|
||||
'cm:title': null,
|
||||
'cm:description': nodeDescription
|
||||
}
|
||||
}
|
||||
};
|
||||
let tooltip = pipe.transform(node);
|
||||
expect(tooltip).toBe(`${nodeName}\n${nodeDescription}`);
|
||||
});
|
||||
|
||||
it('should use name and title when description is missing', () => {
|
||||
const node: any = {
|
||||
entry: {
|
||||
name: nodeName,
|
||||
properties: {
|
||||
'cm:title': nodeTitle,
|
||||
'cm:description': null
|
||||
}
|
||||
}
|
||||
};
|
||||
let tooltip = pipe.transform(node);
|
||||
expect(tooltip).toBe(`${nodeName}\n${nodeTitle}`);
|
||||
});
|
||||
|
||||
it('should use name if name and description are the same', () => {
|
||||
const node: any = {
|
||||
entry: {
|
||||
name: nodeName,
|
||||
properties: {
|
||||
'cm:title': null,
|
||||
'cm:description': nodeName
|
||||
}
|
||||
}
|
||||
};
|
||||
let tooltip = pipe.transform(node);
|
||||
expect(tooltip).toBe(nodeName);
|
||||
});
|
||||
|
||||
it('should use name if name and title are the same', () => {
|
||||
const node: any = {
|
||||
entry: {
|
||||
name: nodeName,
|
||||
properties: {
|
||||
'cm:title': nodeName,
|
||||
'cm:description': null
|
||||
}
|
||||
}
|
||||
};
|
||||
let tooltip = pipe.transform(node);
|
||||
expect(tooltip).toBe(nodeName);
|
||||
});
|
||||
|
||||
it('should use name if all values are the same', () => {
|
||||
const node: any = {
|
||||
entry: {
|
||||
name: nodeName,
|
||||
properties: {
|
||||
'cm:title': nodeName,
|
||||
'cm:description': nodeName
|
||||
}
|
||||
}
|
||||
};
|
||||
let tooltip = pipe.transform(node);
|
||||
expect(tooltip).toBe(nodeName);
|
||||
});
|
||||
});
|
@@ -1,79 +0,0 @@
|
||||
/*!
|
||||
* @license
|
||||
* Copyright 2017 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 { Pipe, PipeTransform } from '@angular/core';
|
||||
import { MinimalNodeEntity } from 'alfresco-js-api';
|
||||
import { DataRow } from 'ng2-alfresco-datatable';
|
||||
|
||||
@Pipe({
|
||||
name: 'nodeNameTooltip'
|
||||
})
|
||||
export class NodeNameTooltipPipe implements PipeTransform {
|
||||
|
||||
transform(node: MinimalNodeEntity): string {
|
||||
if (node) {
|
||||
return this.getNodeTooltip(node);
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
private containsLine(lines: string[], line: string): boolean {
|
||||
return lines.some((item: string) => {
|
||||
return item.toLowerCase() === line.toLowerCase();
|
||||
});
|
||||
}
|
||||
|
||||
private removeDuplicateLines(lines: string[]): string[] {
|
||||
const reducer = (acc: string[], line: string): string[] => {
|
||||
if (!this.containsLine(acc, line)) { acc.push(line); }
|
||||
return acc;
|
||||
};
|
||||
|
||||
return lines.reduce(reducer, []);
|
||||
}
|
||||
|
||||
private getNodeTooltip(node: MinimalNodeEntity): string {
|
||||
if (!node || !node.entry) {
|
||||
return null;
|
||||
}
|
||||
|
||||
const { entry: { properties, name } } = node;
|
||||
const lines = [ name ];
|
||||
|
||||
if (properties) {
|
||||
const {
|
||||
'cm:title': title,
|
||||
'cm:description': description
|
||||
} = properties;
|
||||
|
||||
if (title && description) {
|
||||
lines[0] = title;
|
||||
lines[1] = description;
|
||||
}
|
||||
|
||||
if (title) {
|
||||
lines[1] = title;
|
||||
}
|
||||
|
||||
if (description) {
|
||||
lines[1] = description;
|
||||
}
|
||||
}
|
||||
|
||||
return this.removeDuplicateLines(lines).join(`\n`);
|
||||
}
|
||||
}
|
@@ -111,7 +111,7 @@
|
||||
class="app-name-column"
|
||||
title="APP.DOCUMENT_LIST.COLUMNS.NAME">
|
||||
<ng-template let-value="value" let-context>
|
||||
<span title="{{ context?.row?.obj | nodeNameTooltip }}">{{ value }}</span>
|
||||
<span title="{{ context?.row?.obj | adfNodeNameTooltip }}">{{ value }}</span>
|
||||
</ng-template>
|
||||
</data-column>
|
||||
|
||||
|
@@ -116,7 +116,7 @@
|
||||
class="app-name-column"
|
||||
title="APP.DOCUMENT_LIST.COLUMNS.NAME">
|
||||
<ng-template let-value="value" let-context>
|
||||
<span title="{{ context?.row?.obj | nodeNameTooltip }}">{{ value }}</span>
|
||||
<span title="{{ context?.row?.obj | adfNodeNameTooltip }}">{{ value }}</span>
|
||||
</ng-template>
|
||||
</data-column>
|
||||
|
||||
|
@@ -103,7 +103,7 @@
|
||||
class="app-name-column"
|
||||
title="APP.DOCUMENT_LIST.COLUMNS.NAME">
|
||||
<ng-template let-value="value" let-context>
|
||||
<span title="{{ context?.row?.obj | nodeNameTooltip }}">{{ value }}</span>
|
||||
<span title="{{ context?.row?.obj | adfNodeNameTooltip }}">{{ value }}</span>
|
||||
</ng-template>
|
||||
</data-column>
|
||||
|
||||
|
@@ -101,7 +101,7 @@
|
||||
class="app-name-column"
|
||||
title="APP.DOCUMENT_LIST.COLUMNS.NAME">
|
||||
<ng-template let-value="value" let-context>
|
||||
<span title="{{ context?.row?.obj | nodeNameTooltip }}">{{ value }}</span>
|
||||
<span title="{{ context?.row?.obj | adfNodeNameTooltip }}">{{ value }}</span>
|
||||
</ng-template>
|
||||
</data-column>
|
||||
|
||||
|
@@ -61,7 +61,7 @@
|
||||
class="app-name-column"
|
||||
title="APP.DOCUMENT_LIST.COLUMNS.NAME">
|
||||
<ng-template let-value="value" let-context>
|
||||
<span title="{{ context?.row?.obj | nodeNameTooltip }}">{{ value }}</span>
|
||||
<span title="{{ context?.row?.obj | adfNodeNameTooltip }}">{{ value }}</span>
|
||||
</ng-template>
|
||||
</data-column>
|
||||
|
||||
|
Reference in New Issue
Block a user