mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-24 17:32:15 +00:00
[ADF-4219] Multivalue Metadata Card View (#4600)
* [ADF-4219] Multivalue Metadata Card View * [ADF-4219] Add documentation * [ADF-4219] Improve code, docs and tests * [ADF-4219] Fix e2e tests
This commit is contained in:
committed by
Eugenio Romano
parent
21fd0299bd
commit
8395b0baa5
66
lib/core/pipes/multi-value.pipe.spec.ts
Normal file
66
lib/core/pipes/multi-value.pipe.spec.ts
Normal file
@@ -0,0 +1,66 @@
|
||||
/*!
|
||||
* @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 { MultiValuePipe } from './multi-value.pipe';
|
||||
import { TestBed } from '@angular/core/testing';
|
||||
import { setupTestBed } from 'core';
|
||||
import { CoreTestingModule } from 'core/testing/core.testing.module';
|
||||
|
||||
describe('FullNamePipe', () => {
|
||||
|
||||
let pipe: MultiValuePipe;
|
||||
|
||||
setupTestBed({
|
||||
imports: [CoreTestingModule]
|
||||
});
|
||||
|
||||
beforeEach(() => {
|
||||
pipe = TestBed.get(MultiValuePipe);
|
||||
|
||||
});
|
||||
|
||||
it('should add the separator when a list is provided', () => {
|
||||
const values = ['cat', 'house', 'dog'];
|
||||
expect(pipe.transform(values)).toBe('cat, house, dog');
|
||||
});
|
||||
|
||||
it('should add custom separator when set', () => {
|
||||
const values = ['cat', 'house', 'dog'];
|
||||
const customSeparator = ' - ';
|
||||
expect(pipe.transform(values, customSeparator)).toBe('cat - house - dog');
|
||||
});
|
||||
|
||||
it('should not add separator when the list has only one item', () => {
|
||||
const values = ['cat'];
|
||||
expect(pipe.transform(values)).toBe('cat');
|
||||
});
|
||||
|
||||
it('should return empty string when an empty list is passed', () => {
|
||||
const values = [];
|
||||
expect(pipe.transform(values)).toBe('');
|
||||
});
|
||||
|
||||
it('should return empty string when an empty string is passed', () => {
|
||||
const values = '';
|
||||
expect(pipe.transform(values)).toBe('');
|
||||
});
|
||||
|
||||
it('should return same string when the value passed is a string', () => {
|
||||
const values = 'cat';
|
||||
expect(pipe.transform(values)).toBe('cat');
|
||||
});
|
||||
});
|
34
lib/core/pipes/multi-value.pipe.ts
Normal file
34
lib/core/pipes/multi-value.pipe.ts
Normal file
@@ -0,0 +1,34 @@
|
||||
/*!
|
||||
* @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 { Pipe, PipeTransform } from '@angular/core';
|
||||
|
||||
@Pipe({ name: 'multiValue' })
|
||||
export class MultiValuePipe implements PipeTransform {
|
||||
|
||||
static DEFAULT_SEPARATOR = ', ';
|
||||
|
||||
transform(values: string | string [], valueSeparator: string = MultiValuePipe.DEFAULT_SEPARATOR): string {
|
||||
|
||||
if (values && values instanceof Array) {
|
||||
values.map((value) => value.trim());
|
||||
return values.join(valueSeparator);
|
||||
}
|
||||
|
||||
return <string> values;
|
||||
}
|
||||
}
|
@@ -27,6 +27,7 @@ import { InitialUsernamePipe } from './user-initial.pipe';
|
||||
import { FullNamePipe } from './full-name.pipe';
|
||||
import { FormatSpacePipe } from './format-space.pipe';
|
||||
import { FileTypePipe } from './file-type.pipe';
|
||||
import { MultiValuePipe } from './multi-value.pipe';
|
||||
|
||||
@NgModule({
|
||||
imports: [
|
||||
@@ -41,7 +42,8 @@ import { FileTypePipe } from './file-type.pipe';
|
||||
FullNamePipe,
|
||||
NodeNameTooltipPipe,
|
||||
FormatSpacePipe,
|
||||
FileTypePipe
|
||||
FileTypePipe,
|
||||
MultiValuePipe
|
||||
],
|
||||
providers: [
|
||||
FileSizePipe,
|
||||
@@ -51,7 +53,8 @@ import { FileTypePipe } from './file-type.pipe';
|
||||
InitialUsernamePipe,
|
||||
NodeNameTooltipPipe,
|
||||
FormatSpacePipe,
|
||||
FileTypePipe
|
||||
FileTypePipe,
|
||||
MultiValuePipe
|
||||
],
|
||||
exports: [
|
||||
FileSizePipe,
|
||||
@@ -62,7 +65,8 @@ import { FileTypePipe } from './file-type.pipe';
|
||||
FullNamePipe,
|
||||
NodeNameTooltipPipe,
|
||||
FormatSpacePipe,
|
||||
FileTypePipe
|
||||
FileTypePipe,
|
||||
MultiValuePipe
|
||||
]
|
||||
})
|
||||
export class PipeModule {
|
||||
|
@@ -22,5 +22,6 @@ export * from './text-highlight.pipe';
|
||||
export * from './time-ago.pipe';
|
||||
export * from './user-initial.pipe';
|
||||
export * from './full-name.pipe';
|
||||
export * from './multi-value.pipe';
|
||||
|
||||
export * from './pipe.module';
|
||||
|
Reference in New Issue
Block a user